/* ============================================================
   ANAND GROWTH — main.css
   Design system & components. Theme: porcelain / ink / lime.
   ============================================================ */

:root{
  --bg:#F4F3EE;
  --ink:#101810;
  --green:#155943;
  --lime:#C9F25C;
  --muted:#6B7268;
  --line:rgba(16,24,16,.12);
  --display:'Archivo',sans-serif;
  --body:'Inter',sans-serif;
  --ease:cubic-bezier(.76,0,.24,1);
}

/* ---------- base ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--bg);color:var(--ink);overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.locked{overflow:hidden}
::selection{background:var(--lime)}
a{color:inherit;text-decoration:none}
button{font-family:var(--body)}
h1,h2,h3{font-family:var(--display);letter-spacing:-.025em}
svg{max-width:100%}
main{opacity:0;animation:pagein .7s .05s var(--ease) forwards}
@keyframes pagein{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- type ---------- */
.h-hero{font-weight:900;font-size:clamp(36px,6.8vw,94px);line-height:1.02;text-transform:uppercase}
.h-sec{font-weight:900;font-size:clamp(27px,4vw,54px);line-height:1.05;text-transform:uppercase}
.eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-weight:600}
.lead-p{font-size:clamp(15px,1.35vw,17px);color:var(--muted);line-height:1.75}
.lime-box{background:var(--lime);padding:0 .18em;border-radius:.16em;display:inline-block;transform:rotate(-1.4deg)}
.green-t{color:var(--green)}
.outline-t{color:transparent;-webkit-text-stroke:1.5px var(--ink)}

/* ---------- layout ---------- */
.section{padding:9vh 5vw;max-width:1320px;margin:0 auto}
.pg-hero{padding:150px 5vw 5vh;max-width:1320px;margin:0 auto}

/* ---------- reveals ---------- */
.line-mask{display:block;overflow:hidden}
.line-mask>span{display:block;transform:translateY(115%);transition:transform 1s var(--ease)}
.played .line-mask>span{transform:translateY(0)}
.played .d1>span{transition-delay:.08s}
.played .d2>span{transition-delay:.16s}
.fade{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.played .fade,.fade.played{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .line-mask>span{transform:none}.fade{opacity:1;transform:none}
  .preloader,.cursor{display:none!important}
  main{opacity:1}
}

/* ---------- logo: circular badge + sharp chevron ---------- */
.brand{display:flex;align-items:center;gap:10px;flex:none}
.brand-tile{position:relative;width:34px;height:34px;border-radius:50%;background:var(--lime);display:flex;align-items:center;justify-content:center;flex:none;overflow:hidden;box-shadow:0 6px 16px rgba(16,24,16,.22),inset 0 1.5px 0 rgba(255,255,255,.45),inset 0 -2px 4px rgba(16,24,16,.12);transition:transform .45s var(--ease)}
.brand:hover .brand-tile{transform:rotate(-8deg) scale(1.07)}
.brand-tile svg{width:62%;height:62%;position:relative;z-index:1}
.brand-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.55) 50%,transparent 65%);transform:translateX(-130%);animation:mark-sheen 6s var(--ease) infinite}
@keyframes mark-sheen{0%,58%{transform:translateX(-130%)}82%,100%{transform:translateX(130%)}}
.brand-word{font-family:var(--display);font-weight:900;font-size:15px;letter-spacing:.03em;text-transform:uppercase;line-height:1.04;white-space:nowrap;display:inline-flex;flex-direction:column;align-items:flex-start}
.brand-word .an{background:linear-gradient(110deg,var(--ink) 42%,var(--green) 50%,var(--ink) 58%);background-size:280% 100%;background-position:120% 0;-webkit-background-clip:text;background-clip:text;color:transparent;animation:wm-sheen 6s var(--ease) infinite}
.brand-word .gr{color:var(--green)}
@keyframes wm-sheen{0%,55%{background-position:120% 0}80%,100%{background-position:-120% 0}}
body.menu-open .brand-word .an{background:none;-webkit-text-fill-color:var(--bg);color:var(--bg);animation:none}
body.menu-open .brand-word .gr{color:var(--lime)}

/* ---------- preloader (wordmark entrance) ---------- */
.preloader{position:fixed;inset:0;z-index:1000;background:var(--ink);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:18px;transition:transform .8s var(--ease)}
.preloader.done{transform:translateY(-101%)}
.pl-tile{position:relative;width:72px;height:72px;border-radius:50%;background:var(--lime);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.45),inset 0 2px 0 rgba(255,255,255,.45);opacity:0;transform:scale(.4);animation:pl-tile .55s .05s var(--ease) forwards}
.pl-tile svg{width:60%;height:60%}
.pl-tile svg path{transform:translateY(26px);animation:pl-chev .6s .45s var(--ease) forwards}
@keyframes pl-tile{to{opacity:1;transform:scale(1)}}
@keyframes pl-chev{to{transform:translateY(0)}}
.pl-word{font-family:var(--display);font-weight:900;font-size:clamp(30px,6.5vw,64px);letter-spacing:-.02em;text-transform:uppercase;color:var(--bg);display:flex;align-items:baseline}
.pl-word .pl-l{display:inline-block;overflow:hidden}
.pl-word .pl-l span{display:inline-block;transform:translateY(110%);animation:pl-rise .65s var(--ease) forwards}
.pl-word .gr span{color:var(--lime)}
.pl-word .wdot{width:.16em;height:.16em;border-radius:.05em;background:var(--lime);margin-left:.14em;align-self:center;opacity:0;animation:pl-dot .45s 1.05s var(--ease) forwards}
@keyframes pl-rise{to{transform:translateY(0)}}
@keyframes pl-dot{from{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}
.preloader .pl-sub{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:rgba(244,243,238,.5);font-weight:600}

/* ---------- header ---------- */
.header{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;align-items:center;justify-content:space-between;padding:18px 5vw;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:rgba(244,243,238,.72);border-bottom:1px solid transparent;transition:border-color .3s}
.header.scrolled{border-color:var(--line)}
.nav-desk{display:flex;gap:26px;font-size:13px;font-weight:600;letter-spacing:.05em}
.nav-desk a{position:relative;padding:4px 0;color:var(--muted);transition:color .3s;text-transform:uppercase}
.nav-desk a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--lime);transition:width .35s var(--ease)}
.nav-desk a:hover,.nav-desk a.active{color:var(--ink)}
.nav-desk a.active::after{width:100%}
.h-right{display:flex;align-items:center;gap:14px}
.btn-pill{position:relative;overflow:hidden;border:1.5px solid var(--ink);border-radius:999px;padding:12px 24px;font-size:13px;font-weight:600;background:transparent;cursor:pointer;z-index:1;display:inline-block;text-align:center}
.btn-pill::after{content:"";position:absolute;inset:0;background:var(--lime);z-index:-1;transform:translateY(101%);transition:transform .4s var(--ease)}
.btn-pill:hover::after{transform:translateY(0)}
.btn-solid{background:var(--lime);border:none;color:var(--ink);font-family:var(--display);font-weight:800;font-size:13.5px;letter-spacing:.05em;text-transform:uppercase;padding:17px 36px;border-radius:999px;cursor:pointer;display:inline-block;transition:transform .4s var(--ease),box-shadow .4s}
.btn-solid:hover{transform:translateY(-3px);box-shadow:0 16px 38px rgba(16,24,16,.22)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.menu-btn i{display:block;width:24px;height:2px;background:var(--ink);transition:transform .4s var(--ease)}
body.menu-open .menu-btn i:first-child{transform:translateY(3.5px) rotate(45deg)}
body.menu-open .menu-btn i:last-child{transform:translateY(-3.5px) rotate(-45deg)}

/* ---------- mobile menu ---------- */
.menu-overlay{position:fixed;inset:0;z-index:85;background:var(--ink);color:var(--bg);transform:translateY(-101%);transition:transform .8s var(--ease);display:flex;flex-direction:column;justify-content:center;padding:0 7vw}
.menu-overlay.open{transform:translateY(0)}
.menu-overlay .mask-m{overflow:hidden;display:block}
.menu-overlay .mask-m>a{display:block;transform:translateY(115%);transition:transform .8s var(--ease);font-family:var(--display);font-weight:900;font-size:clamp(34px,8vw,60px);line-height:1.18;text-transform:uppercase;color:var(--bg)}
.menu-overlay .mask-m>a em{font-style:normal;font-size:.3em;vertical-align:super;color:var(--lime);margin-right:12px}
.menu-overlay.open .mask-m>a{transform:translateY(0)}
.menu-overlay.open .mask-m:nth-child(2)>a{transition-delay:.05s}
.menu-overlay.open .mask-m:nth-child(3)>a{transition-delay:.1s}
.menu-overlay.open .mask-m:nth-child(4)>a{transition-delay:.15s}
.menu-overlay.open .mask-m:nth-child(5)>a{transition-delay:.2s}
.menu-overlay .mfoot{position:absolute;bottom:max(4vh,24px);left:7vw;right:7vw;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:13px;color:rgba(244,243,238,.55)}
body.menu-open .header{background:transparent;border-color:transparent}
body.menu-open .brand{color:var(--bg)}
body.menu-open .brand .lm-line,body.menu-open .brand .lm-head{stroke:var(--bg)}
body.menu-open .menu-btn i{background:var(--bg)}
body.menu-open .h-right .btn-pill{border-color:var(--bg);color:var(--bg)}

/* ---------- ssdn (about only) ---------- */
.ssdn{position:fixed;top:6px;left:50%;transform:translateX(-50%);z-index:91;font-family:var(--display);font-size:9px;letter-spacing:.42em;color:var(--ink);opacity:.5;font-weight:700;pointer-events:none}
body.menu-open .ssdn{color:var(--bg)}
body[data-page="contact"] .ssdn{color:var(--bg);opacity:.55}

.menu-overlay .m-cta{display:inline-flex;align-items:center;justify-content:center;margin-top:26px;background:var(--lime);color:var(--ink);font-family:var(--display);font-weight:800;font-size:13px;letter-spacing:.04em;text-transform:uppercase;padding:15px 30px;border-radius:999px;width:fit-content}

/* ---------- cursor ---------- */
.cursor{position:fixed;top:0;left:0;width:12px;height:12px;border-radius:50%;background:var(--green);pointer-events:none;z-index:999;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s;mix-blend-mode:multiply}
.cursor.grow{width:52px;height:52px;background:var(--lime);mix-blend-mode:normal;opacity:.9}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ---------- hero side logo badge ---------- */
.hero{position:relative}
.hero>*:not(.hero-side-mark){position:relative;z-index:2}
.hero-side-mark{position:absolute;right:7vw;top:56%;transform:translateY(-50%);width:clamp(110px,12vw,170px);aspect-ratio:1;border-radius:50%;background:var(--lime);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 30px 70px rgba(16,24,16,.24),inset 0 3px 0 rgba(255,255,255,.5),inset 0 -5px 10px rgba(16,24,16,.12);animation:sidemark-float 6s ease-in-out infinite;z-index:0}
.hero-side-mark svg{width:58%;height:58%;position:relative;z-index:1}
.hero-side-mark svg path{transform:translateY(60px);transition:transform .9s .5s var(--ease)}
.played .hero-side-mark svg path{transform:translateY(0)}
.hero-side-mark::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.55) 50%,transparent 65%);transform:translateX(-130%);animation:mark-sheen 5.5s 1.8s var(--ease) infinite}
@keyframes sidemark-float{0%,100%{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 14px))}}
@media (max-width:1000px){.hero-side-mark{right:6vw;top:auto;bottom:34%;width:84px}}
@media (max-width:760px){.hero-side-mark{width:56px;top:auto;bottom:38%;right:6vw}}

/* ---------- hero ---------- */
.hero{display:flex;flex-direction:column;justify-content:flex-end;padding:130px 5vw 4vh;position:relative;max-width:1320px;margin:0 auto}
.hero .topline{margin-bottom:3vh}
.hero .h-hero .row{display:flex;align-items:center;gap:.16em;flex-wrap:wrap}
.inline-logo::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.55) 50%,transparent 65%);transform:translateX(-130%);animation:mark-sheen 5s 1.6s var(--ease) infinite}
.inline-chip{display:inline-flex;align-items:center;justify-content:center;height:.72em;width:1.55em;border-radius:999px;background:var(--lime);overflow:hidden;flex:none}
.inline-chip svg{width:72%;height:auto}
.hero .sub-row{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-top:4vh;flex-wrap:wrap}
.hero .sub-row p{max-width:42ch;font-size:15.5px;color:var(--muted);line-height:1.7}
.hero .cta-stack{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:3.5vh}
.hero .cta-note{font-size:12.5px;color:var(--muted)}
.rating-badge{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 18px;font-size:13px;font-weight:600;flex:none}
.rating-badge .stars{color:var(--green);letter-spacing:2px}

/* ---------- process (Plan → Build → Grow, dark, scroll-driven) ---------- */
.process-v{position:relative;background:var(--ink);border-radius:24px;padding:clamp(28px,4.5vw,54px)}
.process-v .pv-cap{display:flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:rgba(244,243,238,.6);font-weight:600;margin-bottom:clamp(20px,2.6vw,30px)}
.process-v .rec{width:7px;height:7px;border-radius:50%;background:var(--lime);animation:blink 1.8s infinite}
@keyframes blink{50%{opacity:.2}}
.pv-rows{position:relative;padding-left:36px}
.pv-track{position:absolute;left:5px;top:26px;bottom:30px;width:2px;background:rgba(244,243,238,.16);border-radius:2px}
.pv-fill{position:absolute;left:0;top:0;width:100%;height:0%;background:linear-gradient(180deg,var(--lime),#7FA226);border-radius:2px;box-shadow:0 0 12px rgba(201,242,92,.45);transition:height .25s ease-out}
.pv-step{position:relative;padding:clamp(16px,2.2vw,24px) 18px;border-radius:16px;transition:background .35s,box-shadow .35s}
.pv-step:hover{background:rgba(201,242,92,.09);box-shadow:inset 0 0 0 1px rgba(201,242,92,.18)}
.pv-step+.pv-step{border-top:1px solid rgba(244,243,238,.1)}
.pv-head{position:relative;display:flex;justify-content:space-between;align-items:center;gap:14px}
.pv-dot{position:absolute;left:-54px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--ink);border:2.5px solid rgba(244,243,238,.45);transition:border-color .4s,background .4s,box-shadow .4s}
.pv-step.on .pv-dot{background:var(--lime);border-color:var(--lime);box-shadow:0 0 0 5px rgba(201,242,92,.18)}
.pv-step .pv-num{font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.2em;color:rgba(244,243,238,.55);transition:color .4s}
.pv-step.on .pv-num,.pv-step:hover .pv-num{color:var(--lime)}
.pv-step h3{font-size:clamp(20px,2.2vw,28px);font-weight:900;text-transform:uppercase;color:rgba(244,243,238,.6);margin-top:5px;transition:color .4s,transform .4s var(--ease);transform-origin:left center}
.pv-step.on h3{color:#fff}
.pv-step:hover h3{color:var(--lime);transform:scale(1.05)}
.pv-tag{flex:none;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,243,238,.75);border:1.5px solid rgba(244,243,238,.3);padding:6px 13px;border-radius:999px;transition:background .35s,color .35s,border-color .35s}
.pv-step:hover .pv-tag,.pv-step.on .pv-tag{background:var(--lime);color:var(--ink);border-color:var(--lime)}
.pv-step p{font-size:13.5px;color:rgba(244,243,238,.78);line-height:1.7;margin-top:9px;max-width:62ch}
.pv-mini{margin-top:10px;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--lime);opacity:.95}

/* ---------- read-fill (text lights up as you read/scroll) ---------- */
.read-fill{font-family:var(--display);font-weight:800;font-size:clamp(20px,2.7vw,34px);line-height:1.3;letter-spacing:-.02em;max-width:980px}
.read-fill .rw{color:rgba(16,24,16,.16);transition:color .25s ease}
.read-fill .rw.lit{color:var(--ink)}
.read-fill .rw.accent.lit{color:var(--green)}

/* ---------- sticky stack cards ---------- */
.stack{display:flex;flex-direction:column;gap:20px;margin-top:5vh}
.stack-card{position:sticky;top:calc(96px + var(--i)*18px);display:grid;grid-template-columns:64px 1fr auto;gap:24px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px 32px;overflow:hidden;transition:box-shadow .4s;will-change:transform;box-shadow:0 16px 40px rgba(16,24,16,.08)}
.stack-card:hover{box-shadow:0 26px 60px rgba(16,24,16,.16)}
.stack-card .s-tile{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;flex:none;box-shadow:0 12px 26px rgba(16,24,16,.18);transform:rotate(-4deg);transition:transform .45s var(--ease)}
.stack-card:hover .s-tile{transform:rotate(4deg) scale(1.07)}
.stack-card .s-tile svg{width:44%;height:auto}
.stack-card h3{font-size:clamp(19px,2vw,26px);font-weight:900;text-transform:uppercase;line-height:1.08}
.stack-card p{font-size:13.5px;color:var(--muted);line-height:1.6;margin-top:7px;max-width:54ch}
.stack-card .wm{position:absolute;right:84px;top:50%;transform:translateY(-50%);font-family:var(--display);font-weight:900;font-size:96px;line-height:1;color:transparent;-webkit-text-stroke:1.5px rgba(16,24,16,.08);pointer-events:none;user-select:none}
.stack-card .s-arrow{font-size:22px;color:var(--muted);transition:transform .4s var(--ease),color .4s;position:relative;z-index:1}
.stack-card:hover .s-arrow{transform:translateX(6px);color:var(--green)}
.stack-card::after{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--lime);transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ease)}
.stack-card:hover::after{transform:scaleY(1)}
@media (max-width:760px){.stack-card{grid-template-columns:48px 1fr;padding:22px 20px}.stack-card .wm,.stack-card .s-arrow{display:none}.stack-card .s-tile{width:48px;height:48px}}

/* ---------- services page card extras ---------- */
.svc-block .wm{position:absolute;right:78px;bottom:6px;font-family:var(--display);font-weight:900;font-size:84px;line-height:1;color:transparent;-webkit-text-stroke:1.5px rgba(16,24,16,.07);pointer-events:none;user-select:none}
.svc-block::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(201,242,92,.16) 50%,transparent 70%);transform:translateX(-110%);transition:transform .8s var(--ease);pointer-events:none}
.svc-block:hover::before{transform:translateX(110%)}
.slide-l{opacity:0;transform:translateX(-36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.slide-r{opacity:0;transform:translateX(36px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.played .slide-l,.played .slide-r,.slide-l.played,.slide-r.played{opacity:1;transform:none}

/* ---------- counter pop ---------- */
.count{display:inline-block}
.count.pop{animation:countpop .55s var(--ease)}
@keyframes countpop{0%{transform:scale(.4);opacity:0}70%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}

/* ---------- 3d tilt ---------- */
[data-tilt]{transform-style:preserve-3d;will-change:transform}

/* ---------- eyes statement ---------- */
.eyes-statement{text-align:left}
.eyes-statement .big{font-family:var(--display);font-weight:900;font-size:clamp(28px,4.6vw,62px);line-height:1.08;text-transform:uppercase;letter-spacing:-.025em;max-width:1000px}
.eyes-statement .big .dim{color:rgba(16,24,16,.28)}
.eyes-wrap{display:inline-flex;gap:4px;vertical-align:-8%;height:.92em}
.eye{width:.52em;height:.92em;border:2.5px solid var(--ink);border-radius:50%;background:#fff;position:relative;overflow:hidden;animation:eyeblink 4.5s infinite}
.eye .pupil{position:absolute;width:46%;height:30%;border-radius:50%;background:var(--ink);left:27%;top:35%;transition:transform .18s ease-out}
@keyframes eyeblink{0%,92%,100%{transform:scaleY(1)}95.5%{transform:scaleY(.08)}}
.eye:nth-child(2){animation-delay:.08s}

/* ---------- belt marquee ---------- */
.sticker-belt{padding:4vh 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:#fff}
.belt-track{display:flex;align-items:center;gap:5vw;width:max-content;animation:belt 28s linear infinite}
@keyframes belt{to{transform:translateX(-50%)}}
.belt-item{font-family:var(--display);font-weight:900;font-size:clamp(22px,3vw,38px);text-transform:uppercase;white-space:nowrap;display:flex;align-items:center;gap:5vw}
.belt-item.outline{color:transparent;-webkit-text-stroke:1.2px var(--ink)}
.belt-dot{flex:none;width:10px;height:10px;border-radius:50%;background:var(--lime)}

/* ---------- service blocks ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:5vh}
.svc-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.svc-block{position:relative;display:block;background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 28px 26px;overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s}
.svc-block:hover{transform:translateY(-7px);box-shadow:0 26px 56px rgba(16,24,16,.13)}
.svc-block .bnum{font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:.16em;color:var(--muted)}
.svc-block h3{font-size:clamp(18px,1.7vw,23px);font-weight:900;text-transform:uppercase;line-height:1.1;margin:14px 0 10px;max-width:78%;transform-origin:left center;transition:color .35s,transform .4s var(--ease)}
.svc-block:hover h3{color:var(--green);transform:scale(1.07)}
.svc-block p{font-size:13.5px;color:var(--muted);line-height:1.6;max-width:40ch}
.svc-block .taglist{margin-top:14px;font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);opacity:.6}
.svc-block .b-arrow{position:absolute;bottom:22px;right:24px;font-size:19px;color:var(--muted);transition:transform .4s var(--ease),color .4s}
.svc-block:hover .b-arrow{transform:translateX(5px);color:var(--green)}
.svc-block .tile{position:absolute;top:20px;right:20px;width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.55) rotate(-12deg);transition:opacity .4s var(--ease),transform .5s var(--ease);box-shadow:0 14px 30px rgba(16,24,16,.22)}
.svc-block:hover .tile{opacity:1;transform:scale(1) rotate(4deg)}
.tile.h1{background:linear-gradient(140deg,#155943,#0E2A1F)}
.tile.h2{background:linear-gradient(140deg,#C9F25C,#9CCB2E)}
.tile.h3{background:linear-gradient(140deg,#101810,#2C3A2C)}
.tile svg{width:46%;height:auto}

/* ---------- expertise / service rows (legacy) ---------- */
.svc-row{position:relative;display:grid;grid-template-columns:60px 1fr 1fr;gap:3vw;align-items:center;padding:4.2vh 0;border-top:1px solid var(--line);cursor:pointer}
.svc-rows .svc-row:last-child{border-bottom:1px solid var(--line)}
.svc-row .num{font-family:var(--display);font-weight:600;font-size:14px;color:var(--muted)}
.svc-row .cat{font-family:var(--display);font-weight:900;font-size:clamp(22px,2.9vw,40px);text-transform:uppercase;line-height:1.05;transition:transform .45s var(--ease),color .45s}
.svc-row:hover .cat{transform:translateX(14px);color:var(--green)}
.svc-row .info p{font-size:14px;color:var(--muted);line-height:1.6;max-width:44ch}
.svc-row .info .taglist{margin-top:11px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);opacity:.65}
.svc-row .arrow{position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:21px;color:var(--muted);transition:transform .4s var(--ease),color .4s}
.svc-row:hover .arrow{transform:translateY(-50%) translateX(6px);color:var(--green)}
.svc-row .hover-img{position:absolute;right:6%;top:50%;width:200px;aspect-ratio:4/3;border-radius:16px;pointer-events:none;opacity:0;transform:translateY(-50%) scale(.85) rotate(-4deg);transition:opacity .4s var(--ease),transform .5s var(--ease);z-index:2;display:flex;align-items:center;justify-content:center;box-shadow:0 26px 60px rgba(16,24,16,.28)}
.svc-row:hover .hover-img{opacity:1;transform:translateY(-50%) scale(1) rotate(2deg)}
.hover-img.h1{background:linear-gradient(140deg,#155943,#0E2A1F)}
.hover-img.h2{background:linear-gradient(140deg,#C9F25C,#9CCB2E)}
.hover-img.h3{background:linear-gradient(140deg,#101810,#2C3A2C)}
.hover-img svg{width:42%;height:auto}
.svc-row .flag{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;background:var(--lime);padding:5px 11px;border-radius:999px;margin-bottom:10px}

/* ---------- flagship band ---------- */
.flagship{background:var(--green);color:var(--bg);border-radius:24px;padding:clamp(30px,5vw,58px);display:grid;grid-template-columns:1.4fr 1fr;gap:5vw;align-items:center}
.flagship .ftag{display:inline-block;font-size:10.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;background:rgba(201,242,92,.16);color:var(--lime);border:1px solid rgba(201,242,92,.4);padding:7px 14px;border-radius:999px;margin-bottom:18px}
.flagship h3{font-size:clamp(24px,3.2vw,42px);font-weight:900;text-transform:uppercase;line-height:1.06}
.flagship p{font-size:14.5px;line-height:1.7;color:rgba(244,243,238,.8);margin-top:14px;max-width:52ch}
.flagship .f-right{text-align:left}
.flagship .spots{font-family:var(--display);font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--lime);margin-bottom:18px}

/* ---------- case cards ---------- */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:6vh}
.c-card{position:relative;border-radius:20px;overflow:hidden;min-height:290px;padding:26px;display:flex;flex-direction:column;justify-content:flex-end;color:var(--bg);cursor:pointer;transition:transform .5s var(--ease),box-shadow .5s}
.c-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px rgba(16,24,16,.22)}
.c-card .ctag{position:absolute;top:20px;left:20px;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;background:rgba(244,243,238,.14);border:1px solid rgba(244,243,238,.3);padding:7px 12px;border-radius:999px;backdrop-filter:blur(4px)}
.c-card .copen{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;background:rgba(244,243,238,.14);border:1px solid rgba(244,243,238,.3);display:flex;align-items:center;justify-content:center;font-size:15px;transition:transform .4s var(--ease),background .3s,color .3s}
.c-card:hover .copen{transform:rotate(45deg);background:var(--lime);color:var(--ink);border-color:var(--lime)}
.c-card .cstat{font-family:var(--display);font-weight:900;font-size:clamp(24px,2.4vw,34px);line-height:1.05}
.c-card .cname{font-size:13px;font-weight:600;margin-top:8px;opacity:.92}
.c-card .cdesc{font-size:12.5px;color:rgba(244,243,238,.65);margin-top:4px;line-height:1.5}
.c-card .cfoot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:13px;border-top:1px solid rgba(244,243,238,.22)}
.c-card .cfoot .rd{font-size:9.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;opacity:.8}
.c-card .cfoot svg{opacity:.9}
.c-card.g2 .cfoot{border-color:rgba(16,24,16,.22)}
.c-card.g1{background:linear-gradient(160deg,#1E7A5A,#0E2A1F 80%)}
.c-card.g2{background:linear-gradient(160deg,#C9F25C,#7FA226 90%);color:var(--ink)}
.c-card.g2 .ctag{background:rgba(16,24,16,.1);border-color:rgba(16,24,16,.3)}
.c-card.g2 .cdesc{color:rgba(16,24,16,.65)}
.c-card.g2 .copen{background:rgba(16,24,16,.1);border-color:rgba(16,24,16,.3);color:var(--ink)}
.c-card.g3{background:linear-gradient(160deg,#3A4A3A,#101810 80%)}

/* ---------- testimonial slider (slide-swap, reading reveal) ---------- */
.t-slider{position:relative;max-width:1000px;margin:5vh auto 0;background:#fff;border:1px solid var(--line);border-radius:22px;padding:clamp(28px,4.5vw,56px) clamp(24px,7vw,90px)}
.t-slide{display:none}
.t-slide.on{display:block}
.t-slide .stars{color:var(--green);letter-spacing:3px;font-size:15px;margin-bottom:18px}
.t-quote{font-family:var(--display);font-weight:700;font-size:clamp(18px,2.2vw,27px);line-height:1.4;letter-spacing:-.015em;min-height:3.5em}
.t-quote .w{display:inline-block;opacity:0;transform:translateY(10px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.t-quote .w.in{opacity:1;transform:none}
.t-meta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:26px}
.t-meta .who{display:flex;align-items:center;gap:12px}
.t-meta .av{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:13px;color:#fff;flex:none}
.t-meta .nm{font-size:14px;font-weight:600}
.t-meta .rl{font-size:12px;color:var(--muted)}
.t-meta .view-cs{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--green);border-bottom:1px solid var(--lime);padding-bottom:2px}
.t-arrow{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;transition:background .3s,border-color .3s,transform .3s var(--ease);z-index:2}
.t-arrow:hover{background:var(--lime);border-color:var(--lime);transform:translateY(-50%) scale(1.08)}
.t-arrow.prev{left:-23px}
.t-arrow.next{right:-23px}
.t-dots{display:flex;gap:7px;justify-content:center;margin-top:24px}
.t-dots i{width:7px;height:7px;border-radius:50%;background:rgba(16,24,16,.18);transition:background .3s,transform .3s}
.t-dots i.on{background:var(--green);transform:scale(1.25)}

/* ---------- side-scrolling testimonials ---------- */
.t-scroll{overflow:hidden;padding:5vh 0 2vh;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.t-track{display:flex;gap:18px;width:max-content;animation:belt 48s linear infinite}
.t-scroll:hover .t-track{animation-play-state:paused}
.t-card{width:min(350px,82vw);flex:none;background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;display:flex;flex-direction:column;gap:15px;cursor:pointer;transition:transform .4s var(--ease),box-shadow .4s}
.t-card:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(16,24,16,.1)}
.t-card .stars{color:var(--green);letter-spacing:3px;font-size:13px}
.t-card p{font-size:13.5px;line-height:1.65}
.t-card .who{display:flex;align-items:center;gap:11px;margin-top:auto}
.t-card .av{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:12px;color:#fff;flex:none}
.t-card .nm{font-size:13px;font-weight:600}
.t-card .rl{font-size:11.5px;color:var(--muted)}
.t-card .view-cs{font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--green)}

/* ---------- dark stats ---------- */
.dark-sec{background:var(--ink);color:var(--bg)}
.dark-sec .outline-t{-webkit-text-stroke:1.3px var(--bg)}
.num-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3vw;margin-top:6vh}
.n-item{border-left:1px solid rgba(244,243,238,.18);padding-left:1.6vw}
.n-val{font-family:var(--display);font-weight:900;font-size:clamp(30px,3.8vw,52px);line-height:1;color:var(--lime);letter-spacing:-.03em;white-space:nowrap}
.n-val em{font-style:normal;color:var(--bg);font-size:.55em}
.n-lab{margin-top:10px;font-size:12.5px;color:rgba(244,243,238,.6);max-width:22ch;line-height:1.55}

/* ---------- values / founder ---------- */
.vals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:6vh}
.val{border-top:2px solid var(--ink);padding-top:20px}
.val .vnum{font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.16em;color:var(--green)}
.val h3{font-size:18px;font-weight:800;margin:11px 0 7px;text-transform:uppercase}
.val p{font-size:13.5px;color:var(--muted);line-height:1.6}
.founder{background:var(--ink);color:var(--bg);border-radius:24px;padding:clamp(30px,5vw,60px);margin-top:8vh;display:grid;grid-template-columns:1fr 1.5fr;gap:5vw}
.founder .f-left h3{font-size:clamp(22px,2.6vw,34px);font-weight:900;text-transform:uppercase;line-height:1.08}
.founder .f-left .frole{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--lime);margin-top:14px;font-weight:700}
.founder .f-left a{display:block;font-size:13.5px;color:rgba(244,243,238,.7);margin-top:8px;border-bottom:1px solid transparent;width:max-content;transition:border-color .3s}
.founder .f-left a:hover{border-color:var(--lime)}
.founder .f-right p{font-size:15px;line-height:1.85;color:rgba(244,243,238,.82)}
.founder .f-right p+p{margin-top:18px}
.founder .f-right b{color:var(--bg)}
.founder .f-right .hl{color:var(--lime)}
.about-band{background:var(--green);color:var(--bg);border-radius:24px;padding:clamp(28px,4.5vw,54px);margin-top:7vh;display:grid;grid-template-columns:1.2fr 1fr;gap:5vw;align-items:center}
.about-band h3{font-size:clamp(20px,2.5vw,32px);font-weight:900;text-transform:uppercase;line-height:1.12}
.about-band p{font-size:14px;line-height:1.7;color:rgba(244,243,238,.82);margin-top:12px}
.about-band .sig{font-family:var(--display);font-weight:800;font-size:14px;margin-top:18px;color:var(--lime)}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:6vh}
.info-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px}
.info-card .il{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:10px}
.info-card .iv{font-family:var(--display);font-weight:800;font-size:17px}
.info-card a.iv{border-bottom:1.5px solid var(--lime)}

/* ---------- case study pages ---------- */
.cs-hero{padding:150px 5vw 5vh;max-width:1320px;margin:0 auto}
.back-link{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:4vh;transition:color .3s}
.back-link:hover{color:var(--ink)}
.ba-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:5vh auto 0;max-width:1320px;padding:0 5vw}
.ba-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px}
.ba-card .bl{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:700}
.ba-card .before{font-size:14px;color:var(--muted);margin-top:12px;text-decoration:line-through;text-decoration-color:rgba(16,24,16,.3)}
.ba-card .after{font-family:var(--display);font-weight:900;font-size:clamp(24px,2.6vw,38px);color:var(--green);margin-top:4px}
.ba-card .arrow-d{color:var(--green);font-size:15px;margin-top:6px}
.cs-body{max-width:800px;margin:0 auto;padding:7vh 5vw}
.cs-body h3{font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--green);margin:5vh 0 13px;font-weight:800}
.cs-body h3:first-child{margin-top:0}
.cs-body p{font-size:15.5px;line-height:1.8;color:#333b34}
.cs-quote{background:var(--ink);color:var(--bg);border-radius:20px;padding:clamp(26px,4vw,44px);margin-top:6vh}
.cs-quote p{font-family:var(--display);font-weight:700;font-size:clamp(17px,1.9vw,23px);line-height:1.42;color:var(--bg)}
.cs-quote .qwho{margin-top:16px;font-size:13px;color:rgba(244,243,238,.6)}
.cs-quote .qwho b{color:var(--lime)}

/* ---------- service pages ---------- */
.sv-includes{display:flex;flex-wrap:wrap;gap:10px;margin-top:5vh}
.sv-includes span{font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border:1.5px solid var(--ink);padding:9px 16px;border-radius:999px}
.sv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:6vh}
.sv-point{border-top:2px solid var(--ink);padding-top:18px}
.sv-point h3{font-size:17px;font-weight:800;text-transform:uppercase}
.sv-point p{font-size:13.5px;color:var(--muted);line-height:1.6;margin-top:8px}

/* ---------- CTA roll ---------- */
.cta-sec{padding:10vh 0 9vh;text-align:center;overflow:hidden}
.cta-roll{margin:3.5vh 0;cursor:pointer;display:block}
.cta-roll .track{display:flex;gap:4vw;width:max-content;animation:belt 18s linear infinite}
.cta-roll h2{font-weight:900;font-size:clamp(36px,7vw,96px);text-transform:uppercase;white-space:nowrap;line-height:1;letter-spacing:-.03em}
.cta-roll h2 .o{color:transparent;-webkit-text-stroke:1.5px var(--ink)}
.cta-roll:hover h2 .o{color:var(--lime);-webkit-text-stroke:1.5px var(--green)}
.cta-sec .sub{color:var(--muted);font-size:14px;padding:0 5vw}

/* ---------- contact ---------- */
.contact-pg{background:var(--green);color:var(--bg);min-height:100svh;padding:150px 5vw 8vh}
.contact-inner{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:6vw}
.contact-pg h1{font-weight:900;font-size:clamp(32px,5vw,66px);text-transform:uppercase;line-height:1.02}
.contact-pg h1 .lime{color:var(--lime)}
.cdetails{margin-top:5vh;display:flex;flex-direction:column;gap:18px}
.cd-item{display:flex;align-items:center;gap:14px}
.cd-item .cd-ic{width:44px;height:44px;border-radius:14px;background:rgba(244,243,238,.12);border:1px solid rgba(244,243,238,.2);display:flex;align-items:center;justify-content:center;flex:none}
.cd-item a{font-size:15.5px;font-weight:600;border-bottom:1px solid transparent;transition:border-color .3s}
.cd-item a:hover{border-color:var(--lime)}
.cd-item .cd-sub{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,243,238,.5)}
.socials-row{display:flex;gap:10px;margin-top:5vh;flex-wrap:wrap}
.socials-row a{width:44px;height:44px;border-radius:50%;border:1px solid rgba(244,243,238,.3);display:flex;align-items:center;justify-content:center;transition:background .3s,border-color .3s,transform .3s var(--ease)}
.socials-row a:hover{background:var(--lime);border-color:var(--lime);transform:translateY(-3px)}
.socials-row a:hover svg{stroke:var(--ink)}
.socials-row svg{stroke:var(--bg);transition:stroke .3s}
.cform .cfield{position:relative;border-bottom:1px solid rgba(244,243,238,.35);padding:24px 0 14px}
.cform input,.cform textarea{width:100%;background:none;border:none;outline:none;color:var(--bg);font-family:var(--body);font-size:16px;padding-top:8px;resize:none}
.cform label{position:absolute;top:28px;left:0;font-size:15px;color:rgba(244,243,238,.55);transition:all .35s var(--ease);pointer-events:none}
.cform input:focus+label,.cform input:not(:placeholder-shown)+label,
.cform textarea:focus+label,.cform textarea:not(:placeholder-shown)+label{top:4px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--lime)}
.csend{margin-top:5vh;width:max-content;background:var(--lime);color:var(--ink);border:none;font-family:var(--display);font-weight:800;font-size:13.5px;letter-spacing:.06em;text-transform:uppercase;padding:17px 38px;border-radius:999px;cursor:pointer;transition:transform .4s var(--ease),box-shadow .4s}
.csend:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 18px 44px rgba(0,0,0,.3)}

/* ---------- footer badge ---------- */
.f-mark{display:flex;align-items:center;justify-content:center;gap:.2em;flex-wrap:nowrap;white-space:nowrap}
.f-badge{position:relative;width:clamp(34px,6vw,92px);aspect-ratio:1;border-radius:50%;background:var(--lime);display:flex;align-items:center;justify-content:center;overflow:hidden;flex:none;box-shadow:0 14px 34px rgba(0,0,0,.35),inset 0 2px 0 rgba(255,255,255,.45)}
.f-badge svg{width:60%;height:60%}
.f-badge::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.5) 50%,transparent 65%);transform:translateX(-130%);animation:mark-sheen 6s var(--ease) infinite}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--bg);padding:8vh 5vw 3vh;overflow:hidden}
.f-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:36px;max-width:1320px;margin:0 auto 6vh}
.f-col h4{font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:rgba(244,243,238,.45);margin-bottom:16px;font-weight:600}
.f-col a{display:block;font-size:13.5px;margin-bottom:10px;color:rgba(244,243,238,.85);width:max-content;position:relative}
.f-col a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--lime);transition:width .35s var(--ease)}
.f-col a:hover::after{width:100%}
.f-socials{display:flex;gap:9px;margin-top:4px}
.f-socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(244,243,238,.25);display:flex;align-items:center;justify-content:center;transition:background .3s,border-color .3s,transform .3s var(--ease);margin-bottom:0}
.f-socials a::after{display:none}
.f-socials a:hover{background:var(--lime);border-color:var(--lime);transform:translateY(-3px)}
.f-socials svg{stroke:rgba(244,243,238,.85);transition:stroke .3s}
.f-socials a:hover svg{stroke:var(--ink)}
.f-mark{font-family:var(--display);font-weight:900;font-size:clamp(30px,8.4vw,130px);line-height:.85;text-transform:uppercase;letter-spacing:-.04em;text-align:center;user-select:none}
.f-mark .lime{color:var(--lime)}
.f-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:11.5px;color:rgba(244,243,238,.4);border-top:1px solid rgba(244,243,238,.12);padding-top:18px;margin-top:5vh;max-width:1320px;margin-left:auto;margin-right:auto}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .nav-desk{display:none}
  .menu-btn{display:flex}
  .svc-row .hover-img{display:none}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .svc-row{grid-template-columns:40px 1fr;grid-template-rows:auto auto;row-gap:12px;padding:4vh 0}
  .svc-row .cat{grid-column:2;order:-1}
  .svc-row .num{padding-top:5px}
  .svc-row .info{grid-column:2}
  .svc-row .arrow{top:30px;transform:none}
  .num-grid{grid-template-columns:1fr 1fr;gap:24px 5vw}
  .n-item{border-left:none;border-top:1px solid rgba(244,243,238,.18);padding:16px 0 0}
  .case-grid,.vals-grid,.info-grid,.ba-grid,.sv-grid{grid-template-columns:1fr}
  .svc-grid,.svc-grid.cols-2{grid-template-columns:1fr}
  .svc-block h3{max-width:100%}
  .flagship,.founder,.about-band,.contact-inner{grid-template-columns:1fr;gap:5vh}
  .hero{padding-top:110px}
  .hero .sub-row{flex-direction:column;align-items:flex-start}
  .brand span.bt{display:none}
  .section{padding:7vh 6vw}
  .t-arrow.prev{left:8px}
  .t-arrow.next{right:8px}
  .t-slider{padding-left:60px;padding-right:60px}
}

/* ---------- mobile substitutes & polish ---------- */
@media (max-width:760px){
        .read-fill{font-size:19px}
  .brand-word{font-size:15.5px}
  .pl-word{font-size:34px}
  .stack-card{top:calc(84px + var(--i)*12px)}
  .t-quote{min-height:5.2em;font-size:16.5px}
}
@media (hover:none){
  /* touch substitute: chips drift on their own with gentle sway */
  .chip{animation:chipfloat 5s ease-in-out infinite, chipsway 7s ease-in-out infinite}
  @keyframes chipsway{0%,100%{transform:translateX(0) rotate(0deg)}50%{transform:translateX(-10px) rotate(4deg)}}
}

/* ---------- full mobile optimization pass ---------- */
@media (max-width:760px){
  .section{padding:6.5vh 5.5vw}
  .pg-hero,.cs-hero{padding-top:118px}
  .hero{padding-top:104px;padding-bottom:3vh}
  .hero .cta-stack{width:100%}
  .hero .cta-stack .btn-solid{width:100%;text-align:center}
  .pv-rows{padding-left:28px}
  .pv-dot{left:-40px}
  .pv-step{padding-left:12px;padding-right:12px}
  .pv-head{flex-wrap:wrap;gap:8px}
  .t-slider{padding:24px 52px 28px}
  .t-arrow{width:38px;height:38px}
  .stack-card h3{font-size:17px}
  .stack-card p{font-size:12.5px}
  .f-top{gap:26px}
  .f-col{min-width:42%}
  .csend,.btn-solid{padding:15px 28px;font-size:12.5px}
  .cta-roll h2{font-size:34px}
  .belt-item{font-size:20px}
  .menu-overlay .mask-m>a{font-size:32px}
  .read-fill{font-size:17.5px;line-height:1.45}
  .eyes-statement .big{font-size:24px}
  .svc-block{padding:24px 20px}
  .svc-block .wm{font-size:52px;right:64px}
  .c-card{min-height:240px;padding:22px}
  .ba-card .after{font-size:24px}
  .founder .f-right p{font-size:14px;line-height:1.8}
}
@media (max-width:400px){
  .brand-word{font-size:12.5px}
  .brand-tile{width:30px;height:30px}
  .h-right .btn-pill{padding:9px 13px;font-size:11px}
}

/* ---------- touch substitutes ---------- */
@media (hover:none){
  .eye .pupil{animation:lookaround 5.5s ease-in-out infinite}
  @keyframes lookaround{0%,18%{transform:translate(-50%,-50%)}26%,40%{transform:translate(calc(-50% - 5px),-50%)}48%,62%{transform:translate(calc(-50% + 5px),calc(-50% - 3px))}70%,84%{transform:translate(-50%,calc(-50% + 4px))}92%,100%{transform:translate(-50%,-50%)}}
}
/* ---------- preloader chevron stream ---------- */
.pl-tile svg path{animation:none;transform:none}
.pl-tile svg path:nth-of-type(1){animation:chev-stream 1.5s .25s var(--ease) infinite}
.pl-tile svg path:nth-of-type(2){animation:chev-stream 1.5s .6s var(--ease) infinite}
@keyframes chev-stream{0%{transform:translateY(30px);opacity:0}30%{opacity:1}65%{transform:translateY(0);opacity:1}100%{transform:translateY(-32px);opacity:0}}

/* ============================================================
   RESPONSIVE LAYER: tablets + phones (consolidated)
   ============================================================ */

/* ---- Tablet: 641px – 1024px ---- */
@media (min-width:641px) and (max-width:1024px){
  .section{padding:7vh 5vw}
  .h-hero{font-size:clamp(44px,8.6vw,84px)}
  .hero{padding-top:118px}
  .hero-side-mark{width:96px;bottom:30%;right:5vw}
  .case-grid{grid-template-columns:repeat(2,1fr)}
  .case-grid .c-card:last-child:nth-child(odd){grid-column:1/-1}
  .svc-grid,.svc-grid.cols-2{grid-template-columns:repeat(2,1fr)}
  .vals-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .founder{grid-template-columns:1fr;gap:4vh}
  .contact-inner{grid-template-columns:1fr;gap:5vh}
  .about-band{grid-template-columns:1fr;gap:4vh}
  .stack-card{top:calc(92px + var(--i)*16px)}
  .t-slider{padding:30px 64px 34px}
  .cta-roll h2{font-size:8vw}
  .f-top{gap:34px}
  .pl-word{font-size:44px}
}

/* ---- Phone: ≤640px ---- */
@media (max-width:640px){
  body{-webkit-text-size-adjust:100%}
  .section{padding:6vh 5.5vw}
  header{padding:12px 5vw}
  .h-right .btn-pill{display:none}
  .ssdn{top:9px;font-size:7.5px;letter-spacing:.26em;opacity:.55}
  .menu-overlay .mask-m>a{font-size:30px;padding:10px 0}

  /* hero */
  .hero{padding:100px 5.5vw 4vh;min-height:auto}
  .h-hero{font-size:clamp(34px,11.5vw,52px);letter-spacing:-.02em}
  .topline{margin-bottom:2.5vh;font-size:10px}
  .hero .sub-row p{font-size:14px;max-width:100%}
  .rating-badge{font-size:11px;padding:8px 14px}
  .cta-note{font-size:11px}
  .hero-side-mark{display:none}

  /* process */
  .process-v{padding:24px 18px;border-radius:18px}
  .pv-rows{padding-left:24px}
  .pv-dot{left:-34px;width:10px;height:10px}
  .pv-track{left:4px}
  .pv-step{padding:16px 10px}
  .pv-step h3{font-size:19px}
  .pv-step p{font-size:12.5px}
  .pv-tag{font-size:9px;padding:5px 10px}
  .pv-mini{font-size:9.5px;letter-spacing:.06em}

  /* statements */
  .read-fill{font-size:18px;line-height:1.45}
  .eyes-statement .big{font-size:clamp(22px,7.4vw,30px)}
  .eye{width:.82em;height:.82em}
  .lead-p{font-size:13.5px}

  /* belt + marquees */
  .belt-item{font-size:18px;padding:10px 18px}
  .cta-roll h2{font-size:11vw}
  .cta-sec .sub{font-size:11.5px;padding:0 6vw;text-align:center}

  /* cards */
  .stack-card{top:calc(80px + var(--i)*10px);border-radius:16px}
  .stack-card h3{font-size:16.5px}
  .stack-card p{font-size:12px;margin-top:5px}
  .c-card{min-height:228px;padding:20px;border-radius:18px}
  .cstat{font-size:21px}
  .svc-block{padding:22px 18px;border-radius:16px}
  .svc-block h3{font-size:17px}
  .svc-block p{font-size:12.5px}
  .svc-block .taglist{font-size:9.5px}
  .svc-block .wm{display:none}
  .svc-block .tile{opacity:1;transform:scale(.92) rotate(0);position:absolute}
  .svc-block .tile{width:46px;height:46px;border-radius:12px}

  /* slider */
  .t-slider{padding:22px 48px 26px;border-radius:18px}
  .t-quote{font-size:15.5px;min-height:6em}
  .t-arrow{width:34px;height:34px;font-size:14px}
  .t-meta{flex-direction:column;align-items:flex-start;gap:12px}

  /* sub-page heroes */
  .pg-hero,.cs-hero{padding-top:104px}
  .pg-hero .h-hero,.cs-hero .h-hero{font-size:clamp(32px,10.5vw,46px)}

  /* about / values / info */
  .vals-grid{gap:12px}
  .val{padding:22px 18px}
  .about-band{padding:28px 22px;border-radius:18px}
  .num-grid{grid-template-columns:1fr;gap:18px}
  .n-val{font-size:34px}
  .founder .f-left{position:static}
  .founder .f-right p{font-size:13.5px;line-height:1.75}

  /* case pages */
  .ba-card{padding:20px}
  .ba-card .after{font-size:22px}
  .cs-body h2{font-size:20px}
  .cs-body p{font-size:13.5px}

  /* contact: 16px inputs prevent iOS focus zoom */
  .cfield input,.cfield textarea,.cfield select{font-size:16px;padding:13px 14px}
  .cd-item{padding:14px 0}

  /* footer */
  .f-top{flex-direction:row;flex-wrap:wrap;gap:14px 12px}
  .f-col{min-width:calc(50% - 18px)}
  .f-col>a{padding:5px 0;display:block;width:fit-content}
  .f-bottom{flex-direction:column;gap:10px;text-align:center}
  .f-socials a{width:40px;height:40px}
  .f-badge{box-shadow:0 6px 16px rgba(0,0,0,.3);width:30px}
  .f-mark{font-size:clamp(22px,7.4vw,34px);gap:.22em}
  footer{padding:6vh 6vw 2.5vh}
  .f-top{margin-bottom:3vh;gap:14px 12px}
  .f-col h4{margin-bottom:7px;font-size:10px}
  .f-col>a{font-size:13px;padding:3px 0}
  .f-socials{margin-top:12px;gap:8px}
  .f-socials a{width:36px;height:36px}
  .f-bottom{margin-top:3vh;padding-top:14px;font-size:10.5px}
  .f-tag{font-size:12px}
}

/* ---- Small phones: ≤380px ---- */
@media (max-width:380px){
  .h-hero{font-size:32px}
  .brand-word{font-size:12px}
  .brand-tile{width:28px;height:28px}
  .btn-solid{padding:14px 22px;font-size:12px}
  .stack-card{grid-template-columns:42px 1fr;gap:14px}
  .pl-word{font-size:28px}
  .t-slider{padding:20px 42px 24px}
}

/* ---- Touch: comfortable tap targets ---- */
@media (pointer:coarse){
  .nav-desk a,.f-col a,.menu-overlay a,.btn-pill,.t-arrow,.f-socials a{min-height:40px}
  .t-arrow{min-width:40px}
}

/* ---------- growth field background (services hero) ---------- */
.ag-field-bg{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none}
.ag-field-bg canvas{display:block;width:100%;height:100%}
.pg-hero.has-field{position:relative}
.pg-hero.has-field>*:not(.ag-field-bg){position:relative;z-index:1}

/* ---------- services as stack cards (mobile only) ---------- */
@media (max-width:640px){
  .stack-mobile{display:flex;flex-direction:column;gap:16px}
  .stack-mobile .svc-block{position:sticky;top:calc(80px + var(--i)*10px);will-change:transform;box-shadow:0 14px 36px rgba(16,24,16,.1)}
  .stack-mobile .slide-l,.stack-mobile .slide-r{transform:none;opacity:1;transition:none}
}
@media (hover:none){
  .pv-step:hover{background:transparent;box-shadow:none;transform:none}
  .pv-step:hover h3{transform:none}
}
