/* =====================================================================
   AgileTech 2026 — main stylesheet (v2 redesign)
   Precision-studio look: white + warm paper neutrals, deep ink anchors,
   brand green as a sharp accent. Expo-out motion, masked reveals,
   cursor spotlights, bento grids.
   ===================================================================== */

/* ---- Fonts (self-hosted) ---- */
@font-face{font-family:"Inter";src:url(../fonts/inter-400.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url(../fonts/inter-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url(../fonts/inter-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Jakarta";src:url(../fonts/jakarta-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Jakarta";src:url(../fonts/jakarta-700.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Jakarta";src:url(../fonts/jakarta-800.woff2) format("woff2");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"General Sans";src:url(../fonts/general-sans.woff2) format("woff2");font-weight:200 700;font-style:normal;font-display:swap}

/* ---- Design tokens ---- */
:root{
  /* brand */
  --green-800:#2f6107; --green-700:#3c7a0a; --green-600:#4e8c0a; --green-500:#6fb024;
  --green-400:#8cc63f; --green-300:#a9d76a; --green-100:#e4f3cd; --green-050:#f2f9e6;
  --grad:linear-gradient(118deg,#8cc63f 0%,#5aa017 52%,#44810a 100%);
  --grad-soft:linear-gradient(135deg,#f4fae9 0%,#e9f3da 100%);

  /* ink + neutrals (green-charcoal — tinted, never pure black/white) */
  --ink-950:#080c0a; --ink-900:#0f1512; --ink-800:#1a211c; --ink-700:#2a322c;
  --ink-600:#3f4944; --ink-500:#586259; --ink-400:#79837a; --ink-300:#a4aea4;
  --bg:#ffffff; --paper:#f5f8f1; --paper-2:#ecf1e6;
  --line:#e6ebe0; --line-2:#dae0d1; --line-ink:rgba(255,255,255,.09);
  --link:#2f6b07; --link-hover:#224f05; --white:#fff;

  /* radii */
  --radius-sm:12px; --radius:18px; --radius-lg:26px; --radius-xl:34px; --radius-pill:999px;

  /* signature gradient border (mask-composite) + grain + glow */
  --grad-border:linear-gradient(135deg,rgba(140,198,63,.9),rgba(90,160,23,.25) 45%,transparent 72%);
  --grain-url:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");

  /* layered, green-tinted shadows */
  --shadow-xs:0 1px 2px rgba(22,34,10,.05);
  --shadow-sm:0 1px 2px rgba(22,34,10,.04),0 4px 12px -4px rgba(22,34,10,.07);
  --shadow:0 2px 4px rgba(22,34,10,.04),0 12px 28px -12px rgba(22,34,10,.16);
  --shadow-lg:0 4px 8px rgba(22,34,10,.04),0 36px 70px -28px rgba(25,44,10,.32);
  --shadow-green:0 10px 30px -10px rgba(86,150,22,.55);
  --ring:0 0 0 4px rgba(111,176,36,.22);

  /* layout */
  --container:1180px; --gutter:clamp(20px,5vw,60px);
  --section-y:clamp(72px,9.5vw,136px);

  /* type */
  --font:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --display:"General Sans","Jakarta","Inter",system-ui,sans-serif;

  /* motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);          /* expo-ish out  */
  --ease-spring:cubic-bezier(.34,1.4,.4,1);     /* gentle overshoot */
  --dur-1:.25s; --dur-2:.45s; --dur-3:.8s;
}

/* ---- Reset / base ---- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--font);color:var(--ink-600);background:var(--bg);
  font-size:clamp(16px,.4vw + 15px,17.5px);line-height:1.68;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--link);text-decoration:none;transition:color var(--dur-1) var(--ease)}
a:hover{color:var(--link-hover)}
.sr-only,.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
ul,ol{margin:0;padding:0;list-style:none}
figure{margin:0}
button{font:inherit;cursor:pointer}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:6px}
hr{border:0;border-top:1px solid var(--line);margin:0}
::selection{background:var(--green-400);color:var(--ink-950)}

/* global film grain — sits above content, below header/overlays; kills gradient banding */
body::after{content:"";position:fixed;inset:0;z-index:3;pointer-events:none;opacity:.04;mix-blend-mode:multiply;background-image:var(--grain-url);background-size:180px 180px}

/* reusable signature: 1px gradient border via mask-composite */
.gborder{position:relative}
.gborder::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;z-index:2;
  background:var(--grad-border);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude}

h1,h2,h3,h4{font-family:var(--display);color:var(--ink-900);line-height:1.07;letter-spacing:-.025em;margin:0 0 .5em;font-weight:800;text-wrap:balance}
h1{font-size:clamp(2.5rem,5.8vw,4.4rem)}
h2{font-size:clamp(1.95rem,3.8vw,3rem)}
h3{font-size:clamp(1.18rem,1.6vw,1.45rem);font-weight:700;letter-spacing:-.012em;line-height:1.25}
p{margin:0 0 1.1em}
.lead{font-size:clamp(1.08rem,1.4vw,1.3rem);color:var(--ink-500);line-height:1.6;text-wrap:pretty}
strong{color:var(--ink-800);font-weight:600}

/* gradient highlight word */
.hl{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- Layout ---- */
.container{width:min(var(--container),100% - (var(--gutter)*2));margin-inline:auto}
.container--wide{--container:1320px}
.container--narrow{--container:820px}
.section{padding-block:var(--section-y)}
.section--soft{background:var(--paper)}
.section--tint{background:var(--grad-soft)}
.section--ink{position:relative;background:var(--ink-900);color:#b9c2b4}
.section--ink h2,.section--ink h3{color:#fff}
.section__head{max-width:780px;margin-bottom:clamp(40px,5.5vw,72px)}
.section__head--center{margin-inline:auto;text-align:center}
.section__head--row{display:flex;justify-content:space-between;align-items:flex-end;gap:1.4rem;max-width:none;flex-wrap:wrap}
.section__head--row>div{max-width:680px}
.section__head h2{margin-bottom:.35em}
.section__head .lead{margin-bottom:0}
.muted{color:var(--ink-500)}

/* ---- Eyebrow: pill chip with pulsing dot ---- */
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--font);font-weight:600;
  font-size:.76rem;letter-spacing:.13em;text-transform:uppercase;color:var(--green-700);
  background:#fff;border:1px solid var(--line-2);border-radius:var(--radius-pill);
  padding:.5em 1em .5em .85em;margin-bottom:1.1rem;box-shadow:var(--shadow-xs)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green-500);
  box-shadow:0 0 0 0 rgba(111,176,36,.45);animation:eyebrow-pulse 2.6s var(--ease) infinite}
@keyframes eyebrow-pulse{0%{box-shadow:0 0 0 0 rgba(111,176,36,.45)}70%{box-shadow:0 0 0 7px rgba(111,176,36,0)}100%{box-shadow:0 0 0 0 rgba(111,176,36,0)}}
.section--ink .eyebrow{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:var(--green-300)}

/* ---- Buttons ---- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.55em;font-family:var(--font);font-weight:600;
  font-size:.98rem;line-height:1;padding:.95em 1.55em;border-radius:var(--radius-pill);overflow:hidden;
  border:1.5px solid transparent;white-space:nowrap;cursor:pointer;
  transition:transform var(--dur-1) var(--ease-out),box-shadow var(--dur-2) var(--ease-out),background var(--dur-1),color var(--dur-1),border-color var(--dur-1)}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-green)}
.btn--primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 16px 36px -10px rgba(86,150,22,.6)}
.btn--primary::after{content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,.36) 50%,transparent 62%);
  transform:translateX(-120%);transition:transform .8s var(--ease-out);pointer-events:none}
.btn--primary:hover::after{transform:translateX(120%)}
.btn--ghost{background:#fff;color:var(--ink-800);border-color:var(--line-2);box-shadow:var(--shadow-xs)}
.btn--ghost:hover{color:var(--ink-900);border-color:var(--green-400);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn--light{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25);backdrop-filter:blur(4px)}
.btn--light:hover{background:#fff;color:var(--ink-900);border-color:#fff}
.btn--lg{padding:1.1em 1.9em;font-size:1.04rem}
.btn .btn__arrow,.btn .icon--arrow{transition:transform var(--dur-1) var(--ease-out)}
.btn:hover .btn__arrow,.btn:hover .icon--arrow{transform:translateX(4px)}

/* ---- Scroll progress bar (injected by JS) ---- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:2.5px;z-index:120;pointer-events:none;
  background:var(--grad);transform-origin:0 50%;transform:scaleX(0)}

/* ---- Header / nav ---- */
/* NOTE: the header never changes height — only paint properties (bg/shadow/border)
   transition on scroll. Animating height on a sticky element shifts the layout,
   which moves scrollY around the toggle threshold and causes flicker.
   The tucked-away state uses its own class (`is-tucked`), NOT the global
   `.is-hidden{display:none}` utility — reusing that class made the header
   blink in/out instantly while scrolling. */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:background .35s,box-shadow .35s,border-color .35s,transform .45s var(--ease-out)}
.site-header.is-tucked{transform:translateY(-102%)}
.site-header__inner{display:flex;align-items:center;gap:1.5rem;height:72px}
.brand{display:flex;align-items:center;flex:0 0 auto;margin-right:auto}
.brand img{height:40px;width:auto}
.nav{display:flex;align-items:center;gap:.15rem}
.nav__link{position:relative;display:inline-flex;align-items:center;gap:.35em;font-weight:500;color:var(--ink-700);
  padding:.62em .9em;border-radius:var(--radius-pill);font-size:.96rem;white-space:nowrap;transition:color var(--dur-1),background var(--dur-1)}
.nav__link::after{content:"";position:absolute;left:.95em;right:.95em;bottom:.36em;height:1.5px;background:var(--green-500);
  transform:scaleX(0);transform-origin:left;transition:transform var(--dur-2) var(--ease-out)}
.nav__link:hover{color:var(--ink-900)}
.nav__link:hover::after{transform:scaleX(1)}
.nav__item{position:relative}
.nav__item--has>.nav__link svg{width:15px;height:15px;opacity:.55;transition:transform var(--dur-1) var(--ease)}
.nav__item--has:hover>.nav__link svg,.nav__item--open>.nav__link svg{transform:rotate(180deg)}
.nav__sub{position:absolute;top:calc(100% + 12px);left:0;min-width:280px;background:#fff;
  border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg);padding:9px;
  opacity:0;visibility:hidden;transform:translateY(10px) scale(.98);transform-origin:top left;
  transition:opacity var(--dur-1) var(--ease-out),transform var(--dur-2) var(--ease-out),visibility var(--dur-1)}
.nav__item:hover>.nav__sub,.nav__item--open>.nav__sub{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.nav__sub::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}  /* hover bridge */
.nav__sub a{display:flex;flex-direction:column;gap:2px;padding:.65em .85em;border-radius:12px;color:var(--ink-700);
  transition:background var(--dur-1),color var(--dur-1),transform var(--dur-1) var(--ease-out)}
.nav__sub a:hover{background:var(--paper);color:var(--ink-900);transform:translateX(3px)}
.nav__sub a span{font-weight:600}
.nav__sub a small{color:var(--ink-400);font-size:.8rem;font-weight:400}
.header-cta{display:flex;align-items:center;gap:.75rem;flex:0 0 auto}
.header-phone{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--ink-800)}
.header-phone svg{width:18px;height:18px;color:var(--green-600)}

.site-header.is-stuck{background:rgba(255,255,255,.92);box-shadow:0 10px 36px -20px rgba(20,30,10,.32);border-bottom-color:var(--line)}
body:not(.is-front) .site-header{background:rgba(255,255,255,.92);border-bottom-color:var(--line)}

/* burger — borderless icon button */
.burger{display:none;width:46px;height:46px;border:0;background:transparent;color:var(--ink-900);align-items:center;justify-content:center;border-radius:12px;transition:background var(--dur-1),color var(--dur-1)}
.burger:hover{background:var(--paper)}
.burger svg{width:26px;height:26px}

/* ---- Full-screen mobile menu with staggered reveal ---- */
.mobile-nav{position:fixed;inset:0;z-index:95;background:var(--bg);display:flex;flex-direction:column;
  padding:clamp(1rem,4vw,1.6rem) clamp(1.2rem,6vw,2.2rem) clamp(1.4rem,5vw,2rem);overflow-y:auto;overscroll-behavior:contain;
  opacity:0;visibility:hidden;transform:translateY(-12px);
  transition:opacity .35s var(--ease-out),transform .45s var(--ease-out),visibility .35s}
.mobile-nav::before{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(60% 40% at 100% 0,rgba(140,198,63,.15),transparent 60%),
  radial-gradient(50% 40% at 0 100%,rgba(78,140,10,.09),transparent 60%)}
.mobile-nav.is-open{opacity:1;visibility:visible;transform:none}
.mobile-nav>*{position:relative}
.mobile-nav__head{display:flex;align-items:center;justify-content:space-between;padding-bottom:1rem;border-bottom:1px solid var(--line);margin-bottom:.6rem}
.mobile-nav__head .brand img{height:38px}

.mobile-nav__links{display:flex;flex-direction:column;flex:1;padding-top:.4rem}
.mobile-nav__links>a,.mobile-nav__links details{border-bottom:1px solid var(--line)}
.mobile-nav__links>a,.mobile-nav__links summary{font-family:var(--display);font-weight:700;font-size:clamp(1.32rem,5.5vw,1.6rem);color:var(--ink-900);
  padding:.62em 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;letter-spacing:-.01em}
.mobile-nav__links>a:hover,.mobile-nav__links summary:hover{color:var(--green-700)}
.mobile-nav__links summary{list-style:none;cursor:pointer}
.mobile-nav__links summary::-webkit-details-marker{display:none}
.mobile-nav__links summary svg{width:24px;height:24px;color:var(--ink-300);transition:transform .3s var(--ease-out),color var(--dur-1);flex:0 0 auto}
.mobile-nav__links details[open] summary svg{transform:rotate(180deg);color:var(--green-600)}
.mobile-nav__sub{display:flex;flex-direction:column;padding:.2rem 0 .8rem .2rem}
.mobile-nav__sub a{font-family:var(--font);font-weight:500;font-size:1.02rem;color:var(--ink-500);padding:.5em 0;display:block}
.mobile-nav__sub a:hover{color:var(--green-700)}

.mobile-nav__links>*,.mobile-nav__foot{opacity:0;transform:translateY(18px);transition:opacity .5s var(--ease-out),transform .55s var(--ease-out)}
.mobile-nav.is-open .mobile-nav__links>*,.mobile-nav.is-open .mobile-nav__foot{opacity:1;transform:none}
.mobile-nav.is-open .mobile-nav__links>*:nth-child(1){transition-delay:.05s}
.mobile-nav.is-open .mobile-nav__links>*:nth-child(2){transition-delay:.09s}
.mobile-nav.is-open .mobile-nav__links>*:nth-child(3){transition-delay:.13s}
.mobile-nav.is-open .mobile-nav__links>*:nth-child(4){transition-delay:.17s}
.mobile-nav.is-open .mobile-nav__links>*:nth-child(5){transition-delay:.21s}
.mobile-nav.is-open .mobile-nav__links>*:nth-child(6){transition-delay:.25s}
.mobile-nav.is-open .mobile-nav__links>*:nth-child(7){transition-delay:.29s}
.mobile-nav.is-open .mobile-nav__foot{transition-delay:.34s}

.mobile-nav__foot{margin-top:1.6rem}
.mobile-nav__foot .btn{width:100%;justify-content:center}
.mobile-nav__contact{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin-top:1.3rem}
.mobile-nav__contact a{display:inline-flex;align-items:center;gap:.5em;color:var(--ink-500);font-weight:500;font-size:.96rem}
.mobile-nav__contact a:hover{color:var(--green-700)}
.mobile-nav__contact svg{width:18px;height:18px;color:var(--green-600)}

/* ---- Hero (front page) ---- */
.hero{position:relative;overflow:hidden;padding-block:clamp(64px,9vw,128px) clamp(72px,10vw,132px);
  background:linear-gradient(180deg,#fbfcf8 0%,#f4f8ec 100%)}
/* dot grid */
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(40,70,15,.13) 1px,transparent 1.6px);
  background-size:26px 26px;
  -webkit-mask-image:radial-gradient(75% 80% at 30% 20%,#000 0%,transparent 75%);
  mask-image:radial-gradient(75% 80% at 30% 20%,#000 0%,transparent 75%)}
/* aurora blobs */
.hero__blob{position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none;opacity:.55;will-change:transform}
.hero__blob--a{width:560px;height:560px;right:-140px;top:-180px;background:radial-gradient(circle at 35% 35%,rgba(140,198,63,.55),rgba(140,198,63,0) 70%);animation:blob-a 16s var(--ease) infinite alternate}
.hero__blob--b{width:440px;height:440px;left:-160px;bottom:-200px;background:radial-gradient(circle at 60% 40%,rgba(78,140,10,.34),rgba(78,140,10,0) 70%);animation:blob-b 20s var(--ease) infinite alternate}
@keyframes blob-a{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(-60px,50px,0) scale(1.12)}}
@keyframes blob-b{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(70px,-40px,0) scale(1.08)}}

.hero__grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.hero__title{margin-bottom:.4em}
.hero__sub{font-size:clamp(1.08rem,1.5vw,1.3rem);color:var(--ink-500);max-width:40ch;margin-bottom:2em;text-wrap:pretty}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}

/* split-word mask reveal (JS adds .w/.wi spans) */
.split .w{display:inline-block;overflow:hidden;vertical-align:bottom;padding-bottom:.12em;margin-bottom:-.12em}
.split .wi{display:inline-block;transform:translateY(115%);transition:transform .85s var(--ease-out)}
.split.in .wi{transform:none}

.hero__media{position:relative;z-index:1}
.hero__media>picture img,.hero__media>img{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;object-fit:cover;aspect-ratio:5/4;
  border:6px solid #fff;outline:1px solid var(--line)}
.hero__badge{position:absolute;left:-14px;bottom:-20px;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:.85rem 1.15rem;display:flex;align-items:center;gap:.75rem}
.hero__badge img{width:60px;height:auto;border-radius:8px;box-shadow:none;border:0;outline:0}
.hero__badge b{font-family:var(--display);color:var(--ink-900);font-size:.95rem;display:block;line-height:1.25}
.hero__badge small{color:var(--ink-400);font-size:.78rem}
/* floating experience chip */
.hero__chip{position:absolute;right:-10px;top:-18px;background:var(--ink-900);color:#fff;border-radius:16px;
  box-shadow:var(--shadow-lg);padding:.8rem 1.1rem;display:flex;align-items:baseline;gap:.5rem;
  animation:chip-float 5.5s ease-in-out infinite}
.hero__chip b{font-family:var(--display);font-size:1.5rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero__chip span{font-size:.8rem;color:#aab4a4;font-weight:500}
@keyframes chip-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

.hero__trust{display:flex;gap:.6rem .8rem;margin-top:2.3rem;flex-wrap:wrap;align-items:center}
.hero__trust .trust-item{display:inline-flex;align-items:center;gap:.5em;color:var(--ink-600);font-size:.88rem;font-weight:500;
  background:rgba(255,255,255,.75);border:1px solid var(--line);border-radius:var(--radius-pill);padding:.5em .95em;box-shadow:var(--shadow-xs)}
.hero__trust .trust-item svg{width:18px;height:18px;color:var(--green-600);flex:0 0 auto}
.hero__trust b{color:var(--ink-800);font-family:var(--display)}

/* Showcase frame for detail-page heroes — shows ANY image in full, no cropping */
.hero__showcase{position:relative}
.hero__showcase img{display:block;width:100%;height:auto;max-height:480px;object-fit:contain;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);background:var(--grad-soft);padding:clamp(12px,1.6vw,22px)}
@media (max-width:1024px){.hero__showcase{max-width:620px}.hero__showcase img{max-height:420px}}
/* …unless the image sits inside a browser mockup — the frame does the styling */
.hero__showcase--mock img{max-height:none;object-fit:cover;border-radius:0;box-shadow:none;background:none;padding:0}

/* ---- Hero dashboard mockup (crafted product UI, replaces stock hero photo) ---- */
.hero-dash{position:relative;border-radius:20px;background:linear-gradient(180deg,#fff 0%,#fbfdf7 100%);
  border:1px solid var(--line-2);box-shadow:var(--shadow-lg);overflow:hidden;color:var(--ink-800);
  transform:perspective(1500px) rotateY(-8deg) rotateX(4deg) rotate(.5deg);transform-origin:center;
  transition:transform .6s var(--ease-out)}
.hero__media:hover .hero-dash{transform:perspective(1500px) rotateY(-3deg) rotateX(1.5deg)}
.hero-dash__bar{display:flex;align-items:center;gap:.7rem;padding:.6rem .9rem;background:#fff;border-bottom:1px solid var(--line)}
.hero-dash__dots{display:flex;gap:6px;flex:0 0 auto}
.hero-dash__dots i{width:10px;height:10px;border-radius:50%;display:block}
.hero-dash__dots i:nth-child(1){background:#ff5f57}.hero-dash__dots i:nth-child(2){background:#febc2e}.hero-dash__dots i:nth-child(3){background:#28c840}
.hero-dash__url{flex:1;max-width:230px;margin-inline:auto;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-pill);
  font-size:.7rem;color:var(--ink-400);padding:.36em 1em;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.hero-dash__body{padding:clamp(.95rem,1.7vw,1.35rem);display:grid;gap:.8rem}
.hero-dash__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.hero-dash__title{font-family:var(--display);font-weight:700;color:var(--ink-900);font-size:1.02rem;letter-spacing:-.01em}
.hero-dash__live{display:inline-flex;align-items:center;gap:.4em;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--green-700);
  background:var(--green-050);border:1px solid var(--green-100);border-radius:var(--radius-pill);padding:.3em .7em}
.hero-dash__live i{width:6px;height:6px;border-radius:50%;background:var(--green-500);animation:eyebrow-pulse 2.4s var(--ease) infinite}
.hero-dash__kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:.55rem}
.kpi{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:.65rem .7rem}
.kpi b{display:block;font-family:var(--display);font-weight:700;font-size:1.4rem;line-height:1;color:var(--ink-900);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.kpi span{display:block;font-size:.66rem;color:var(--ink-400);text-transform:uppercase;letter-spacing:.05em;margin-top:.35rem;font-weight:600}
.kpi--accent{background:linear-gradient(150deg,rgba(140,198,63,.16),rgba(140,198,63,.04));border-color:var(--green-100)}
.kpi--accent b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-dash__chart{position:relative;height:118px;border:1px solid var(--line);border-radius:13px;overflow:hidden;background:linear-gradient(180deg,#fff,#f7faf1)}
.hero-dash__chart svg{position:absolute;inset:0;width:100%;height:100%}
.hero-dash__chart .ln{stroke:var(--green-600);stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:520;stroke-dashoffset:520;animation:dashdraw 1.6s .25s var(--ease-out) forwards}
@keyframes dashdraw{to{stroke-dashoffset:0}}
.hero-dash__chart .dot{fill:#fff;stroke:var(--green-600);stroke-width:2.4}
.hero-dash__rows{display:grid;gap:.55rem}
.drow{display:grid;grid-template-columns:1fr auto;gap:.2rem .5rem;align-items:center;font-size:.78rem;color:var(--ink-600);font-weight:500}
.drow b{color:var(--ink-800);font-variant-numeric:tabular-nums}
.drow .track{grid-column:1/-1;height:7px;border-radius:99px;background:var(--paper-2);overflow:hidden}
.drow .fill{height:100%;border-radius:99px;background:var(--grad);width:0;animation:fillgrow 1.3s .35s var(--ease-out) forwards}
@keyframes fillgrow{to{width:var(--p,70%)}}
@media (max-width:1024px){.hero-dash{transform:none}.hero__media:hover .hero-dash{transform:none}}
@media (prefers-reduced-motion:reduce){.hero-dash__chart .ln{animation:none;stroke-dashoffset:0}.drow .fill{animation:none;width:var(--p,70%)}.hero-dash{transform:none}}

/* CTA with animated conic glow ring (signature primary) */
@property --gangle{syntax:"<angle>";initial-value:0deg;inherits:false}
.btn--glow{position:relative;z-index:0}
.btn--glow::before{content:"";position:absolute;inset:-2px;z-index:-1;border-radius:inherit;pointer-events:none;opacity:0;
  background:conic-gradient(from var(--gangle),var(--green-400),var(--green-600),#8cc63f,var(--green-400));
  filter:blur(7px);transition:opacity .35s}
.btn--glow:hover::before{opacity:.9;animation:gspin 3.6s linear infinite}
@keyframes gspin{to{--gangle:360deg}}
@media (prefers-reduced-motion:reduce){.btn--glow:hover::before{animation:none}}

/* ===== Hero stage: SVG/product visual on a glowing horizon platform ===== */
.hero-stage{position:relative;width:100%;z-index:1}
.hero-stage__viz{position:relative;border-radius:20px;
  transform:perspective(1700px) rotateY(-8deg) rotateX(4.5deg) rotate(.5deg);
  filter:drop-shadow(0 26px 44px rgba(28,48,16,.20)) drop-shadow(0 6px 12px rgba(28,48,16,.10));
  transition:transform .7s var(--ease-out)}
.hero-stage:hover .hero-stage__viz{transform:perspective(1700px) rotateY(-3deg) rotateX(2deg)}
.hero-stage__viz .hv-svg,.hero-stage__viz .browser-mock{display:block;width:100%;height:auto}
.hero-stage .browser-mock{box-shadow:none;border-radius:18px}
.hero-stage .browser-mock img{max-height:430px;object-fit:cover;object-position:top}
/* horizon glow beneath the platform */
.hero-stage::after{content:"";position:absolute;left:8%;right:8%;bottom:-26px;height:84px;z-index:-1;pointer-events:none;
  background:radial-gradient(60% 100% at 50% 0,rgba(111,176,36,.42),transparent 72%);filter:blur(26px)}
/* centered (home) — flatter "looking down" tilt, wider */
.hero-stage--center .hero-stage__viz{transform:perspective(2200px) rotateX(3deg)}
.hero-stage--center:hover .hero-stage__viz{transform:perspective(2200px) rotateX(1deg) translateY(-4px)}
.hero-stage--center::after{left:14%;right:14%;bottom:-22px}

/* floating glass chips around the visual */
.hero-chip{position:absolute;z-index:3;display:flex;align-items:center;gap:.6rem;
  background:rgba(255,255,255,.82);-webkit-backdrop-filter:blur(12px) saturate(1.4);backdrop-filter:blur(12px) saturate(1.4);
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:.6rem .85rem;
  font-family:var(--display);font-weight:700;color:var(--ink-900);font-size:.9rem;line-height:1.1;white-space:nowrap;
  animation:chip-float 6s ease-in-out infinite}
.hero-chip small{display:block;font-family:var(--font);font-weight:500;color:var(--ink-400);font-size:.72rem;margin-top:1px}
.hero-chip .ic{flex:0 0 auto;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--grad);color:#fff}
.hero-chip .ic svg{width:17px;height:17px}
.hero-chip--tl{top:-14px;left:-22px;animation-duration:6.5s}
.hero-chip--tr{top:6%;right:-20px;animation-duration:7.5s;animation-delay:.3s}
.hero-chip--bl{bottom:8%;left:-26px;animation-duration:5.6s;animation-delay:.5s}
.hero-chip--br{bottom:-16px;right:-10px;animation-duration:6.8s;animation-delay:.2s}

/* service SVG family animations (run on load; reduced-motion settles to final via global rule) */
.hv-svg{display:block;width:100%;height:auto;border-radius:20px}
.hv-line{stroke-dasharray:640;stroke-dashoffset:640;animation:hv-draw 1.6s .35s var(--ease-out) forwards}
@keyframes hv-draw{to{stroke-dashoffset:0}}
.hv-donut{stroke-dashoffset:214;animation:hv-donut 1.5s .35s var(--ease-out) forwards}
@keyframes hv-donut{to{stroke-dashoffset:72}}
.hv-bars rect{transform:scaleY(0);transform-origin:bottom;transform-box:fill-box;animation:hv-grow .8s var(--ease-out) forwards}
@keyframes hv-grow{to{transform:scaleY(1)}}
.hv-bars rect:nth-child(1){animation-delay:.35s}.hv-bars rect:nth-child(2){animation-delay:.45s}
.hv-bars rect:nth-child(3){animation-delay:.55s}.hv-bars rect:nth-child(4){animation-delay:.65s}
.hv-float{animation:hv-bob 6s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
@keyframes hv-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
/* secondary line-draws (sparklines, comparison line) */
.hv-line2{stroke-dasharray:520;stroke-dashoffset:520;animation:hv-draw 1.2s .6s var(--ease-out) forwards}
.hv-line3{stroke-dasharray:760;stroke-dashoffset:760;animation:hv-draw 1.8s .95s var(--ease-out) forwards}
/* width/scale grow-ins (typed code line, progress bars) */
.hv-line-w{transform:scaleX(0);transform-origin:left center;transform-box:fill-box;animation:hv-growx .55s .8s var(--ease-out) forwards}
.hv-grow-w{transform:scaleX(0);transform-origin:left center;transform-box:fill-box;animation:hv-growx 1.2s .5s var(--ease-out) forwards}
@keyframes hv-growx{to{transform:scaleX(1)}}
/* blinking editor cursor */
.hv-blink{animation:hv-blink 1.1s steps(1) infinite}
@keyframes hv-blink{0%,49%{opacity:1}50%,100%{opacity:0}}
/* pop-in (success checks, badges) */
.hv-pop{transform:scale(0);transform-origin:center;transform-box:fill-box;animation:hv-pop .5s .95s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes hv-pop{to{transform:scale(1)}}
/* live status pulse */
.hv-pulse{animation:hv-pulse 1.9s ease-in-out infinite}
@keyframes hv-pulse{0%,100%{opacity:1}50%{opacity:.25}}
/* feed/progress rows rising in sequence */
.hv-rise>*{opacity:0;transform:translateY(9px);transform-box:fill-box;animation:hv-rise .55s var(--ease-out) forwards}
.hv-rise>*:nth-child(1){animation-delay:.55s}.hv-rise>*:nth-child(2){animation-delay:.7s}
.hv-rise>*:nth-child(3){animation-delay:.85s}.hv-rise>*:nth-child(4){animation-delay:1s}
@keyframes hv-rise{to{opacity:1;transform:translateY(0)}}
/* marching-ants drop target */
.hv-dash{animation:hv-dashmove 1s linear infinite}
@keyframes hv-dashmove{to{stroke-dashoffset:-28}}

/* centered home hero */
.hero--center{text-align:center}
.hero--center .hero__copy{max-width:840px;margin-inline:auto}
.hero--center .hero__sub{max-width:60ch;margin-inline:auto}
.hero--center .hero__actions{justify-content:center}
.hero--center .hero__trust{justify-content:center}
.hero--center .eyebrow{margin-inline:auto}
.hero--center .hero-stage{margin-top:clamp(44px,6vw,76px);max-width:1040px;margin-inline:auto;overflow:visible}

/* detail-page hero: asymmetric/offset split with the SVG stage oversized */
.page-hero .hero--offset{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero--offset .hero-stage{justify-self:end;width:118%}
@media (max-width:1024px){
  .hero--offset .hero-stage{width:100%}
  .hero-stage__viz,.hero-stage:hover .hero-stage__viz{transform:none}
  .hero-chip--tl{left:-8px}.hero-chip--bl{left:-10px}.hero-chip--tr{right:-8px}.hero-chip--br{right:-4px}
}
@media (max-width:980px){.page-hero .hero--offset{grid-template-columns:1fr;gap:2.5rem}}
@media (max-width:560px){
  .hero-chip{font-size:.8rem;padding:.5rem .7rem}.hero-chip .ic{width:26px;height:26px}
  .hero-chip--tl{left:0;top:-10px}.hero-chip--br{right:0;bottom:-10px}
  .hero-chip--tr,.hero-chip--bl{display:none}
}

/* ---- Browser-window mockup (for plain product screenshots) ---- */
.browser-mock{position:relative;border-radius:14px;background:#fff;border:1px solid var(--line-2);box-shadow:var(--shadow-lg);overflow:hidden}
.browser-mock__bar{display:flex;align-items:center;gap:.7rem;padding:.55rem .85rem;background:var(--paper);border-bottom:1px solid var(--line)}
.browser-mock__dots{display:flex;gap:6px;flex:0 0 auto}
.browser-mock__dots i{width:10px;height:10px;border-radius:50%;display:block}
.browser-mock__dots i:nth-child(1){background:#ff5f57}
.browser-mock__dots i:nth-child(2){background:#febc2e}
.browser-mock__dots i:nth-child(3){background:#28c840}
.browser-mock__url{flex:1;min-width:0;max-width:300px;margin-inline:auto;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-pill);font-size:.72rem;line-height:1;color:var(--ink-400);padding:.4em 1em;
  text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;letter-spacing:.02em}
.browser-mock img,.browser-mock picture img{display:block;width:100%;height:auto}
/* compact variant for overview cards — uniform crop keeps the grid tidy */
.browser-mock--card{border-radius:12px;box-shadow:var(--shadow-sm);margin-bottom:1.2rem}
.browser-mock--card .browser-mock__bar{padding:.45rem .7rem}
.browser-mock--card .browser-mock__dots i{width:8px;height:8px}
.browser-mock--card img{aspect-ratio:16/9;object-fit:cover;object-position:top}

/* ---- Cards / grids ---- */
.grid{display:grid;gap:clamp(16px,2vw,24px)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

.card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,2.6vw,34px);
  box-shadow:var(--shadow-xs);overflow:hidden;
  transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2) var(--ease-out),border-color var(--dur-2)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--green-300)}
/* cursor spotlight (JS sets --mx/--my) */
.card::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(140,198,63,.10),transparent 45%);
  transition:opacity var(--dur-2) var(--ease)}
.card:hover::after{opacity:1}
.card>*{position:relative;z-index:1}
.card__icon{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin-bottom:1.2rem;
  background:var(--grad-soft);color:var(--green-700);transition:transform var(--dur-2) var(--ease-spring),background var(--dur-2),color var(--dur-2)}
.card__icon svg{width:26px;height:26px}
.card:hover .card__icon{transform:translateY(-3px) rotate(-3deg)}
.card h3{margin-bottom:.45em}
.card p{color:var(--ink-500);margin-bottom:1.2em;font-size:.97rem}
.card__link{display:inline-flex;align-items:center;gap:.4em;font-weight:600;font-size:.92rem}
.card__link svg{width:16px;height:16px;transition:transform var(--dur-1) var(--ease-out)}
.card:hover .card__link svg{transform:translateX(4px)}
.card--service .card__icon{background:var(--ink-900);color:var(--green-400)}
.card--service:hover .card__icon{background:var(--grad);color:#fff}

/* ghost index numeral on cards (optional, via data-index) */
.card[data-index]::before{content:attr(data-index);position:absolute;right:18px;top:6px;z-index:0;
  font-family:var(--display);font-weight:800;font-size:4.4rem;line-height:1;color:var(--paper-2);
  letter-spacing:-.04em;transition:color var(--dur-2);pointer-events:none}
.card[data-index]:hover::before{color:var(--green-100)}

/* bento layout (front-page services) */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,2vw,24px)}
.bento>.card{grid-column:span 3;display:flex;flex-direction:column}
.bento>.card .card__link{margin-top:auto}
.bento>.card--lg{grid-column:span 7}
.bento>.card--md{grid-column:span 5}
.bento>.card--third{grid-column:span 4}
.card--lg p{max-width:52ch;font-size:1.02rem}
.card--cta{background:var(--ink-900);border-color:var(--ink-800);color:#c4cdbd;display:flex;flex-direction:column;justify-content:center;gap:.2rem}
.card--cta::after{background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(140,198,63,.16),transparent 45%)}
.card--cta h3{color:#fff}
.card--cta p{color:#9aa595}
.card--cta .btn{align-self:flex-start;margin-top:.4rem}
.card--cta:hover{border-color:var(--green-600)}

/* feature grid / steps / lists (block renderer) */
.page-body{display:flex;flex-direction:column;gap:clamp(34px,5vw,60px)}
.block__heading{margin-bottom:.6em}
.prose p{max-width:70ch}
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:1.4rem}
.feature-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.45rem 1.55rem;box-shadow:var(--shadow-xs);
  overflow:hidden;transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2),border-color var(--dur-2)}
.feature-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--grad);transform:scaleY(0);transform-origin:top;transition:transform var(--dur-2) var(--ease-out)}
.feature-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:var(--line-2)}
.feature-card:hover::before{transform:scaleY(1)}
.feature-card h3{margin-bottom:.35em;font-size:1.08rem}
.feature-card p{color:var(--ink-500);font-size:.95rem;margin:0}
.steps{display:grid;gap:14px;margin-top:1.4rem;counter-reset:step}
.step{display:flex;gap:1.15rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.35rem 1.55rem;box-shadow:var(--shadow-xs);
  transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2),border-color var(--dur-2)}
.step:hover{transform:translateX(4px);border-color:var(--green-300);box-shadow:var(--shadow-sm)}
.step__num{flex:0 0 auto;width:38px;height:38px;border-radius:12px;background:var(--grad);color:#fff;font-family:var(--display);font-weight:800;display:grid;place-items:center;font-size:1rem;box-shadow:var(--shadow-green)}
.step h3{margin-bottom:.25em;font-size:1.06rem}
.step p{margin:0;color:var(--ink-500);font-size:.95rem}
.list-check{display:grid;gap:.7rem;margin-top:1rem}
.list-check--cols{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.7rem 1.6rem}
.list-check li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink-600)}
.list-check svg{flex:0 0 auto;width:22px;height:22px;color:#fff;background:var(--grad);border-radius:50%;padding:4px;margin-top:2px}

/* ---- Stats (ink band with green aurora) ---- */
.section--ink::before{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(55% 90% at 88% 0,rgba(140,198,63,.16),transparent 58%),
  radial-gradient(40% 70% at 6% 100%,rgba(78,140,10,.12),transparent 60%)}
.section--ink::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1.6px);background-size:28px 28px;
  -webkit-mask-image:radial-gradient(70% 90% at 70% 10%,#000,transparent 70%);
  mask-image:radial-gradient(70% 90% at 70% 10%,#000,transparent 70%)}
.section--ink .container{position:relative;z-index:1}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,3vw,40px);text-align:center}
.stat{position:relative;padding-block:.4rem}
.stat:not(:first-child)::before{content:"";position:absolute;left:calc(-1 * clamp(8px,1.5vw,20px));top:15%;bottom:15%;width:1px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.16),transparent)}
.stat__num{font-family:var(--display);font-weight:800;color:var(--ink-900);font-size:clamp(2.3rem,4.2vw,3.4rem);line-height:1;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.section--ink .stat__num{color:#fff}
.stat__num .hl{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__label{color:var(--ink-500);font-size:.92rem;margin-top:.6rem;font-weight:500;letter-spacing:.02em}
.section--ink .stat__label{color:#97a28f}

/* ---- Client marquee ---- */
.marquee-title{text-align:center;color:var(--ink-500);margin-bottom:2.2rem;font-weight:600;letter-spacing:.02em}
.marquee{--mq-gap:clamp(48px,6vw,96px);overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;width:max-content;align-items:center;animation:marquee 50s linear infinite}
/* gap + matching padding-right live on each group so the seam between the two copies
   is the same width as every internal gap — translateX(-50%) then loops with no jump. */
.marquee__group{display:flex;flex:0 0 auto;align-items:center;gap:var(--mq-gap);padding-right:var(--mq-gap)}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track img{height:56px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.55;transition:filter .35s,opacity .35s,transform .35s var(--ease-out)}
.marquee__track img:hover{filter:none;opacity:1;transform:translateY(-3px)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* logo grid (about / capability) */
.logo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;align-items:center}
.logo-grid li{display:grid;place-items:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.3rem;min-height:104px;
  transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2),border-color var(--dur-2)}
.logo-grid li:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:var(--line-2)}
.logo-grid img{max-height:56px;width:auto;filter:grayscale(1);opacity:.72;transition:.35s}
.logo-grid li:hover img{filter:none;opacity:1}

/* ---- Testimonials ---- */
.tslider{position:relative}
.tslider__viewport{overflow:hidden;border-radius:var(--radius-lg)}
.tslider__track{display:flex}
.tcard{flex:0 0 100%;padding:clamp(28px,4vw,54px);background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
/* dim non-active slides — only inside a slider track */
.tslider__track .tcard{opacity:.25;transform:scale(.985);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.tslider__track .tcard.is-active{opacity:1;transform:none}
.tcard__quoteicon{color:var(--green-400);width:42px;height:42px;margin-bottom:1rem}
.tcard blockquote{margin:0 0 1.6rem;font-size:clamp(1.1rem,1.7vw,1.4rem);line-height:1.55;color:var(--ink-800);font-family:var(--display);font-weight:600;letter-spacing:-.01em}
.tcard__by{display:flex;align-items:center;gap:.9rem}
.tcard__by img{width:50px;height:50px;border-radius:50%;object-fit:cover;background:var(--paper-2)}
.tcard__by b{display:block;color:var(--ink-900);font-family:var(--display)}
.tcard__by span{color:var(--ink-500);font-size:.9rem}
/* Compact, wide horizontal variant (homepage slider) */
.tcard--row{display:grid;grid-template-columns:minmax(180px,228px) 1fr;gap:clamp(1.6rem,3.5vw,3.4rem);align-items:center}
.tcard--row .tcard__aside{display:flex;flex-direction:column;align-items:flex-start;gap:.8rem}
.tcard--row .avatar{width:74px;height:74px;border-radius:20px;object-fit:cover;box-shadow:var(--shadow-sm);background:var(--paper-2)}
.tcard--row .tcard__stars{display:flex;gap:3px}
.tcard--row .tcard__stars svg{width:18px;height:18px;fill:var(--green-500)}
.tcard--row .tcard__person b{display:block;font-family:var(--display);color:var(--ink-900);font-size:1.12rem;line-height:1.2}
.tcard--row .tcard__person span{display:block;color:var(--ink-500);font-size:.9rem;margin-top:.25rem}
.tcard--row .tcard__quoteicon{width:34px;height:34px;margin-bottom:.6rem}
.tcard--row blockquote{margin:0;font-size:clamp(1.02rem,1.35vw,1.26rem);line-height:1.55}
.tslider__nav{display:flex;align-items:center;justify-content:center;gap:1.1rem;margin-top:1.8rem}
.tslider__dots{display:flex;gap:.6rem}
.tslider__dot{position:relative;width:10px;height:10px;border-radius:50%;background:var(--line-2);border:0;padding:0;overflow:hidden;
  transition:width .35s var(--ease-out),background .25s;cursor:pointer}
.tslider__dot.is-active{background:var(--green-100);width:34px;border-radius:6px}
.tslider__dot.is-active::after{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--grad);
  transform-origin:left;animation:dot-progress var(--t-delay,6.5s) linear forwards}
@keyframes dot-progress{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.tslider.is-paused .tslider__dot.is-active::after{animation-play-state:paused}
.tslider__arrow{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line-2);background:#fff;color:var(--ink-700);display:grid;place-items:center;
  transition:transform var(--dur-1) var(--ease-out),border-color var(--dur-1),color var(--dur-1),box-shadow var(--dur-1)}
.tslider__arrow:hover{border-color:var(--green-400);color:var(--green-700);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.tslider__arrow svg{width:20px;height:20px}
.tslider__arrow[data-prev] svg{transform:scaleX(-1)}
@media(max-width:760px){.tcard--row{grid-template-columns:1fr;gap:1.2rem}}

/* ---- CTA band ---- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius-xl);background:var(--ink-900);color:#fff;
  padding:clamp(40px,5.5vw,76px);display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band::before{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 120% at 88% 0,rgba(140,198,63,.34),transparent 55%),
  radial-gradient(40% 90% at 4% 100%,rgba(78,140,10,.22),transparent 55%)}
.cta-band::after{content:"";position:absolute;inset:0;opacity:.45;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1.6px);background-size:26px 26px;
  -webkit-mask-image:radial-gradient(60% 100% at 80% 0,#000,transparent 70%);
  mask-image:radial-gradient(60% 100% at 80% 0,#000,transparent 70%)}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:#fff;margin-bottom:.3em;font-size:clamp(1.8rem,3.4vw,2.7rem)}
.cta-band p{color:#aeb8a6;margin:0;max-width:48ch}

/* ---- Breadcrumb / page hero ---- */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#fbfcf8 0%,#f3f7ea 100%);padding-block:clamp(44px,6.5vw,84px)}
.page-hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(40,70,15,.11) 1px,transparent 1.6px);background-size:26px 26px;
  -webkit-mask-image:radial-gradient(70% 90% at 25% 10%,#000,transparent 72%);
  mask-image:radial-gradient(70% 90% at 25% 10%,#000,transparent 72%)}
.page-hero::after{content:"";position:absolute;right:-120px;top:-160px;width:480px;height:480px;border-radius:50%;filter:blur(70px);pointer-events:none;
  background:radial-gradient(circle at 40% 40%,rgba(140,198,63,.4),transparent 70%)}
.page-hero__inner{position:relative;z-index:1}
.page-hero h1{margin:.3em 0 .25em}
.page-hero .lead{max-width:62ch}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:.5em;align-items:center;font-size:.84rem;color:var(--ink-500)}
.breadcrumb li:not(:last-child)::after{content:"/";margin-left:.5em;color:var(--ink-300)}
.breadcrumb a{color:var(--ink-500)}
.breadcrumb a:hover{color:var(--green-700)}

/* split media row (service/product detail) */
.media-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.media-row__img img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%}
.stat-chip{display:inline-flex;align-items:baseline;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1rem 1.4rem;margin-top:1rem}
.stat-chip b{font-family:var(--display);font-size:1.8rem;color:var(--green-700)}

/* ---- FAQ accordion ---- */
.faq{display:grid;gap:12px;max-width:880px;margin-inline:auto}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;transition:box-shadow var(--dur-2),border-color var(--dur-2)}
.faq__item.is-open{box-shadow:var(--shadow-sm);border-color:var(--green-300)}
.faq__q{width:100%;text-align:left;background:none;border:0;padding:1.2rem 1.4rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-family:var(--display);font-weight:700;color:var(--ink-900);font-size:1.04rem;transition:color var(--dur-1)}
.faq__q:hover{color:var(--green-700)}
.faq__q svg{flex:0 0 auto;width:22px;height:22px;color:var(--green-600);transition:transform .35s var(--ease-out)}
.faq__item.is-open .faq__q svg{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease-out)}
.faq__a-inner{padding:0 1.4rem 1.3rem;color:var(--ink-600)}

/* ---- Forms ---- */
.form{display:grid;gap:1rem}
.form .field{display:grid;gap:.4rem}
.form label{font-weight:600;font-size:.9rem;color:var(--ink-700)}
.form input,.form textarea{width:100%;padding:.9em 1.05em;border:1.5px solid var(--line-2);border-radius:14px;background:#fff;color:var(--ink-800);font:inherit;
  transition:border-color var(--dur-1),box-shadow var(--dur-1)}
.form input:focus,.form textarea:focus{border-color:var(--green-400);box-shadow:var(--ring);outline:none}
.form textarea{min-height:140px;resize:vertical}
.form .hp{position:absolute;left:-9999px}
.form-notice{padding:1rem 1.2rem;border-radius:12px;margin-bottom:1.2rem;font-weight:500}
.form-notice--ok{background:var(--green-050);color:var(--green-700);border:1px solid var(--green-300)}
.form-notice--err{background:#fdeaea;color:#a12a2a;border:1px solid #f3c4c4}

/* search form */
.search-form{display:flex;gap:.6rem}
.search-form__input{flex:1;padding:.85em 1.1em;border:1.5px solid var(--line-2);border-radius:var(--radius-pill);background:#fff;color:var(--ink-800);font:inherit;transition:border-color var(--dur-1),box-shadow var(--dur-1)}
.search-form__input:focus{border-color:var(--green-400);box-shadow:var(--ring);outline:none}
.search-form .btn{flex:0 0 auto;padding-inline:1.1em}

/* contact info list */
.info-list{display:grid;gap:1.1rem}
.info-list li{display:flex;gap:.9rem;align-items:flex-start}
.info-list .ic{flex:0 0 auto;width:44px;height:44px;border-radius:13px;background:var(--grad-soft);color:var(--green-700);display:grid;place-items:center}
.info-list .ic svg{width:20px;height:20px}
.info-list b{display:block;color:var(--ink-900);font-family:var(--display);font-size:.95rem}
.info-list a,.info-list span{color:var(--ink-600)}

/* ---- Blog ---- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,32px)}
.post-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs);
  transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2),border-color var(--dur-2)}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-2)}
.post-card__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--paper-2)}
.post-card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(12,18,6,.18));opacity:0;transition:opacity var(--dur-2)}
.post-card:hover .post-card__media::after{opacity:1}
.post-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.post-card:hover .post-card__media img{transform:scale(1.06)}
/* Contained thumbnail (product screenshots, logos) */
.thumb-contain{background:#fff!important}
.thumb-contain img{object-fit:contain!important;padding:clamp(12px,1.6vw,22px);transform:none!important}
.card:hover .thumb-contain img{transform:scale(1.03)!important}
.post-card__body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.post-card__meta{font-size:.78rem;color:var(--ink-500);text-transform:uppercase;letter-spacing:.07em;font-weight:600}
.post-card h3{font-size:1.16rem;margin:0;line-height:1.3}
.post-card h3 a{color:var(--ink-900);background-image:linear-gradient(var(--green-500),var(--green-500));background-size:0 1.5px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .4s var(--ease-out),color var(--dur-1)}
.post-card h3 a:hover{color:var(--green-800);background-size:100% 1.5px}
.post-card p{color:var(--ink-500);font-size:.94rem;margin:0}
.post-card .card__link{margin-top:auto;padding-top:.5rem}
.post-card:hover .card__link svg{transform:translateX(4px)}
.tag{display:inline-block;background:var(--green-050);color:var(--green-700);font-size:.74rem;font-weight:600;padding:.32em .75em;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}

/* single post */
.entry{max-width:760px;margin-inline:auto}
.entry__hero img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:2rem;aspect-ratio:16/8;object-fit:cover}
.entry-content{font-size:1.06rem;line-height:1.78;color:var(--ink-700)}
.entry-content>*{margin-bottom:1.2em}
.entry-content h2{margin-top:1.6em}
.entry-content h3{margin-top:1.4em}
.entry-content img{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}
.entry-content a{text-decoration:underline;text-underline-offset:3px}
.entry-content ul,.entry-content ol{padding-left:1.3em;display:grid;gap:.4em}
.entry-content ul{list-style:disc}.entry-content ol{list-style:decimal}
.entry-content blockquote{border-left:4px solid var(--green-400);padding:.4em 0 .4em 1.3em;color:var(--ink-600);font-style:italic;margin-left:0}
.entry-content pre{background:var(--ink-900);color:#e6ecdf;padding:1.2rem;border-radius:14px;overflow:auto;font-size:.9rem}
.entry-content code{background:var(--paper-2);padding:.15em .4em;border-radius:6px;font-size:.92em}
.entry-content pre code{background:none;padding:0}
.post-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:3rem;border-top:1px solid var(--line);padding-top:1.6rem;font-weight:600}

/* posts pagination */
.navigation.pagination .nav-links{display:flex;justify-content:center;align-items:center;gap:.5rem;flex-wrap:wrap}
.page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 1em;
  border:1.5px solid var(--line-2);border-radius:var(--radius-pill);background:#fff;color:var(--ink-700);font-weight:600;font-size:.95rem;
  transition:border-color var(--dur-1),color var(--dur-1),transform var(--dur-1) var(--ease-out),box-shadow var(--dur-1)}
a.page-numbers:hover{border-color:var(--green-400);color:var(--green-700);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.page-numbers.current{background:var(--grad);border-color:transparent;color:#fff;box-shadow:var(--shadow-green)}
.page-numbers.dots{border:0;background:none}

/* sidebar */
.with-sidebar{display:grid;grid-template-columns:1fr 300px;gap:clamp(28px,4vw,56px);align-items:start}
.widget{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.6rem;margin-bottom:1.4rem}
.widget h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-400);margin-bottom:1rem}
.widget ul{display:grid;gap:.7rem}
.widget a{color:var(--ink-700);font-weight:500;font-size:.95rem}
.widget a:hover{color:var(--green-700)}

/* ---- Footer ---- */
.site-footer{position:relative;background:var(--ink-900);color:#9aa595;padding-block:clamp(58px,7vw,92px) 0;overflow:hidden}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(140,198,63,.6),transparent)}
.site-footer::after{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(50% 70% at 90% 0,rgba(140,198,63,.08),transparent 60%)}
.site-footer .container{position:relative;z-index:1}
.site-footer a{color:#c8d0c2}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,56px)}
.footer-brand img{height:40px;margin-bottom:1.2rem}
.footer-brand p{font-size:.95rem;max-width:34ch;color:#8b9784}
.footer-col h4,.footer-col .footer-h{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;margin:0 0 1.15rem;font-family:var(--display);font-weight:700}
.footer-col ul{display:grid;gap:.68rem;font-size:.95rem}
.footer-col ul a{position:relative;transition:color var(--dur-1),padding-left var(--dur-2) var(--ease-out)}
.footer-col ul a::before{content:"";position:absolute;left:0;top:50%;width:0;height:1.5px;background:var(--green-400);transition:width var(--dur-2) var(--ease-out)}
.footer-col ul a:hover{padding-left:16px}
.footer-col ul a:hover::before{width:10px}
.footer-contact li{display:flex;gap:.7rem;margin-bottom:.8rem;font-size:.95rem;align-items:flex-start}
.footer-contact svg{flex:0 0 auto;width:18px;height:18px;color:var(--green-400);margin-top:2px}
.footer-social{display:flex;gap:.6rem;margin-top:1.2rem}
.footer-social a{width:40px;height:40px;border-radius:12px;border:1px solid var(--line-ink);display:grid;place-items:center;color:#c8d0c2;
  transition:background var(--dur-2),border-color var(--dur-2),color var(--dur-1),transform var(--dur-1) var(--ease-out)}
.footer-social a:hover{background:var(--grad);border-color:transparent;color:#fff;transform:translateY(-3px)}
.footer-social svg{width:19px;height:19px}
.footer-badges{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;margin-top:1.4rem}
.footer-badges img{height:74px;width:auto;background:#fff;border-radius:10px;padding:6px}
.footer-bottom{border-top:1px solid var(--line-ink);margin-top:clamp(40px,5vw,64px);padding-block:1.5rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.86rem;color:#76836d}
.footer-bottom nav{display:flex;gap:1.2rem;flex-wrap:wrap}

/* ---- Reveal animations ---- */
.reveal,[data-reveal]{opacity:0;transform:translateY(26px);filter:blur(6px);
  transition:opacity .8s var(--ease-out),transform .8s var(--ease-out),filter .8s var(--ease-out);
  transition-delay:var(--d,0s)}
.reveal.in,[data-reveal].in{opacity:1;transform:none;filter:none}
[data-reveal="left"]{transform:translateX(-32px)}
[data-reveal="right"]{transform:translateX(32px)}
[data-reveal="scale"]{transform:scale(.92)}
[data-reveal-stagger]>*{opacity:0;transform:translateY(26px);filter:blur(5px);
  transition:opacity .7s var(--ease-out),transform .7s var(--ease-out),filter .7s var(--ease-out);
  transition-delay:var(--d,0s)}
[data-reveal-stagger].in>*{opacity:1;transform:none;filter:none}

/* ---- Team (About) ---- */
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.5vw,28px)}
.team-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden;
  transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2),border-color var(--dur-2)}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.team-card__top{display:flex;gap:1.2rem;padding:clamp(20px,2.2vw,28px);align-items:center}
.team-card__photo{flex:0 0 auto;width:92px;height:92px;border-radius:20px;object-fit:cover;background:var(--paper-2)}
.team-card__name{margin:0;font-size:1.2rem}
.team-card__role{color:var(--green-700);font-weight:600;font-size:.9rem;margin:.15rem 0 .5rem}
.team-card__summary{color:var(--ink-500);font-size:.94rem;margin:0}
.team-card__tags{display:flex;flex-wrap:wrap;gap:.4rem;padding:0 clamp(20px,2.2vw,28px) 1rem}
.team-card__tags span{background:var(--paper);border:1px solid var(--line);color:var(--ink-600);font-size:.76rem;font-weight:500;padding:.3em .7em;border-radius:999px}
details.bio{border-top:1px solid var(--line)}
details.bio>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.95rem clamp(20px,2.2vw,28px);font-weight:600;color:var(--ink-800);font-size:.92rem}
details.bio>summary::-webkit-details-marker{display:none}
details.bio>summary svg{width:18px;height:18px;color:var(--green-600);transition:transform .3s var(--ease-out)}
details.bio[open]>summary svg{transform:rotate(45deg)}
details.bio .bio__body{padding:0 clamp(20px,2.2vw,28px) 1.4rem;color:var(--ink-600);font-size:.95rem}
details.bio .bio__body p{margin-bottom:.8em}

/* ---- Certifications / award cards ---- */
.cert-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.cert-card{display:flex;gap:1rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.3rem 1.5rem;box-shadow:var(--shadow-xs);
  transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2),border-color var(--dur-2)}
.cert-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:var(--green-300)}
.cert-card img{height:64px;width:auto;flex:0 0 auto}
.cert-card b{display:block;font-family:var(--display);color:var(--ink-900);font-size:1rem}
.cert-card span{color:var(--ink-500);font-size:.88rem}

/* ---- Capability statement spec block ---- */
.spec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-top:1.4rem}
.spec{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.1rem 1.3rem;box-shadow:var(--shadow-xs)}
.spec__label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-400);font-weight:600;margin-bottom:.3rem}
.spec__value{font-family:var(--display);font-weight:700;color:var(--ink-900);font-size:1.05rem;word-break:break-word}
.naics-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.naics-list span{background:var(--green-050);color:var(--green-700);border-radius:8px;padding:.35em .7em;font-weight:600;font-size:.9rem}
.fed-contact{display:flex;gap:1.2rem;align-items:center;background:var(--grad-soft);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.6rem;margin-top:1.4rem;flex-wrap:wrap}
.fed-contact img{width:96px;height:120px;object-fit:cover;border-radius:12px}

/* ---- Case study cards ---- */
.cs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,2.6vw,30px)}
.cs-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs);
  transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2),border-color var(--dur-2)}
.cs-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-2)}
.cs-card__media{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--paper-2)}
.cs-card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(12,18,6,.16));opacity:0;transition:opacity var(--dur-2)}
.cs-card:hover .cs-card__media::after{opacity:1}
.cs-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.cs-card:hover .cs-card__media img{transform:scale(1.06)}
.cs-card__body{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.cs-card__client{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--green-700)}
.cs-card h3{margin:0;font-size:1.2rem}
.cs-card p{color:var(--ink-500);font-size:.95rem;margin:0}
.cs-card .tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}
.media-figure img{border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--line);margin-block:1rem}

@media (max-width:760px){.team-grid,.cs-grid{grid-template-columns:1fr}}

/* utilities */
.text-center{text-align:center}
.mt-gap{margin-top:clamp(28px,4vw,48px)}
.is-hidden{display:none!important}
.skip-link{position:absolute;left:-9999px;top:0;background:#fff;padding:.8em 1.2em;border-radius:0 0 10px 0;z-index:200;font-weight:600}
.skip-link:focus{left:0}

/* ---- Responsive ---- */
@media (max-width:1024px){
  .hero__grid{grid-template-columns:1fr;gap:3rem}
  .hero__media{max-width:560px}
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .with-sidebar{grid-template-columns:1fr}
  .post-grid{grid-template-columns:repeat(2,1fr)}
  .bento>.card{grid-column:span 6}
  .bento>.card--lg,.bento>.card--md{grid-column:span 6}
}
/* mid widths: tighten the bar + collapse phone to an icon so the longer
   production nav labels (About us / Capability Statement) keep one line. */
@media (max-width:1320px){
  .nav{gap:0}
  .nav__link{padding:.5em .58em;font-size:.9rem}
  .header-phone{width:46px;height:46px;justify-content:center;border-radius:12px;padding:0}
  .header-phone:hover{background:var(--paper)}
  .header-phone span{display:none}
  .header-phone svg{width:24px;height:24px}
}
@media (max-width:1080px){
  .nav{display:none}
  .burger{display:inline-flex}
  .header-phone{width:46px;height:46px;justify-content:center;border-radius:12px;padding:0;transition:background var(--dur-1)}
  .header-phone:hover{background:var(--paper)}
  .header-phone span{display:none}
  .header-phone svg{width:24px;height:24px}
  .media-row,.stats{grid-template-columns:1fr 1fr}
  .stats{gap:2rem;text-align:left}
  .stat:not(:first-child)::before{display:none}
  .media-row{grid-template-columns:1fr}
  .cta-band{flex-direction:column;align-items:flex-start;text-align:left}
  .hero__chip{right:6px}
}
@media (max-width:620px){
  .grid--2,.grid--3,.grid--4,.post-grid{grid-template-columns:1fr}
  .bento>.card,.bento>.card--lg,.bento>.card--md{grid-column:span 12}
  .footer-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:1.6rem}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn{justify-content:center}
  .header-cta .btn--primary{display:none}
  .hero__badge{left:8px;bottom:-14px;padding:.7rem .9rem}
  .hero__badge img{width:48px}
}

/* =====================================================================
   FUTURISTIC DARK THEME — charcoal-green canvas + vivid green accents.
   Appended last to override the light rules. "Lit screen" components
   (inline-SVG dashboards + product browser windows) stay LIGHT on purpose
   so they read as glowing displays floating on the dark surface.
   ===================================================================== */
:root{
  /* surfaces */
  --bg:#0a110d; --paper:#0e1712; --paper-2:#17231b;
  --surface:#111c15; --surface-2:#18241d;
  --line:rgba(168,214,148,.12); --line-2:rgba(168,214,148,.2); --line-ink:rgba(255,255,255,.08);
  /* text — inverted to light, green-tinted */
  --ink-900:#ecf4e9; --ink-800:#dde9d9; --ink-700:#c6d3c1; --ink-600:#a8b7a3;
  --ink-500:#8b9b86; --ink-400:#84927e; --ink-300:#66725f; --ink-950:#06100a;
  /* brand — brighten the green that appears as text/icons on dark */
  --green-700:#9fd24f; --green-600:#8cc63f; --green-100:rgba(140,198,63,.24); --green-050:rgba(140,198,63,.10);
  --link:#abdd6f; --link-hover:#c7ea92;
  --grad-soft:linear-gradient(150deg,rgba(140,198,63,.18),rgba(78,140,10,.05));
  --shadow-xs:0 1px 2px rgba(0,0,0,.4);
  --shadow-sm:0 2px 10px rgba(0,0,0,.46);
  --shadow:0 18px 40px -16px rgba(0,0,0,.7);
  --shadow-lg:0 40px 84px -28px rgba(0,0,0,.82);
  --shadow-green:0 0 0 1px rgba(140,198,63,.4),0 14px 38px -10px rgba(120,200,40,.5);
  --ring:0 0 0 4px rgba(140,198,63,.3);
  --grad-soft2:linear-gradient(180deg,#0c1610 0%,#0a110d 100%);
}
body{background:var(--bg);color:var(--ink-600)}
body::after{mix-blend-mode:overlay;opacity:.05}
::selection{background:var(--green-400);color:var(--ink-950)}

/* card-like surfaces */
.card,.feature-card,.step,.tcard,.team-card,.cert-card,.spec,.post-card,.widget,.cs-card,
.faq__item,.nav__sub,.stat-chip,.page-numbers,.tslider__arrow,.logo-grid li{background:var(--surface);border-color:var(--line)}
.card:hover,.cs-card:hover,.post-card:hover,.team-card:hover,.cert-card:hover{border-color:var(--green-600)}
.card--service .card__icon{background:#0b1510}
.eyebrow{background:rgba(140,198,63,.08);border-color:rgba(140,198,63,.26);color:var(--green-700)}
.btn--ghost{background:var(--surface-2);color:var(--ink-800);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--green-500);color:#fff;background:var(--surface-2)}
.btn--light:hover{color:#08120b}
.tag,.naics-list span{background:rgba(140,198,63,.14);color:var(--green-700)}
.form-notice--ok{background:rgba(140,198,63,.12);border-color:rgba(140,198,63,.32);color:var(--green-700)}
.form-notice--err{background:rgba(220,70,70,.14);border-color:rgba(220,70,70,.4);color:#ff9d9d}
.form input,.form textarea,.search-form__input{background:var(--surface-2);color:var(--ink-800);border-color:var(--line-2)}

/* header — dark glass */
.site-header{background:rgba(8,14,11,.7)}
.site-header.is-stuck,body:not(.is-front) .site-header{background:rgba(8,14,11,.88);border-bottom-color:var(--line)}
.nav__sub{border-color:var(--line)}
.burger:hover,.header-phone:hover{background:var(--surface-2)}
.nav__link:hover{background:var(--surface-2)}

/* dark sections / bands */
.hero,.page-hero{background:var(--grad-soft2)}
.hero::before,.page-hero::before{background-image:radial-gradient(rgba(150,210,90,.16) 1px,transparent 1.6px)}
.hero__blob--a{opacity:.46}.hero__blob--b{opacity:.4}
.section--ink,.cta-band,.card--cta{background:#0b1510}
.card--cta{border-color:var(--line-2)}
.site-footer{background:#070d0a}
.entry-content pre{background:#0b1510;border:1px solid var(--line)}

/* floating chips + hero trust pills → dark glass */
.hero-chip{background:rgba(15,24,18,.76);border-color:var(--line-2)}
.hero__trust .trust-item{background:rgba(15,24,18,.6);border-color:var(--line)}
.hero__badge{background:rgba(15,24,18,.82)}

/* LIT SCREENS — pin to light so they glow on the dark surface */
.browser-mock{background:#fff;border-color:#e2e8da}
.browser-mock__bar{background:#f6f9f1;border-bottom-color:#e6ebe0}
.browser-mock__url{background:#fff;color:#79837a;border-color:#e6ebe0}
.hero-stage__viz{filter:drop-shadow(0 30px 60px rgba(0,0,0,.62)) drop-shadow(0 0 34px rgba(140,198,63,.14))}

/* client logos sit on clean light chips — the logos are a mix of transparent + solid-bg
   files, so a brightness(0)+invert "white silhouette" turns the solid-bg ones into blocks.
   Light chips keep every brand logo readable on the dark surface. */
.marquee__track img{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;
  padding:16px 28px;height:88px;box-sizing:border-box;object-fit:contain;filter:grayscale(1);opacity:.82}
.marquee__track img:hover{filter:none;opacity:1;transform:translateY(-3px)}
@media (max-width:600px){.marquee__track img{height:72px;padding:13px 20px;border-radius:12px}}
.logo-grid li{background:#fff;border-color:rgba(0,0,0,.06)}
.logo-grid img{filter:grayscale(1);opacity:.8}
.logo-grid li:hover img{filter:none;opacity:1}
.footer-badges img{background:#fff}

/* misc */
.skip-link{background:var(--surface);color:var(--ink-900)}
.team-card__tags span{background:var(--surface-2);border-color:var(--line)}
.marquee-title{color:var(--ink-500)}
.fed-contact{border-color:var(--line)}

/* ---- Reduced motion: calm everything ---- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal,[data-reveal],[data-reveal-stagger]>*{opacity:1!important;transform:none!important;filter:none!important}
  .split .wi{transform:none!important}
  .tcard{opacity:1!important;transform:none!important}
  .marquee__track{animation:none;flex-wrap:wrap;justify-content:center}
  .marquee__group{flex-wrap:wrap;justify-content:center;padding-right:0}
  .marquee__group+.marquee__group{display:none}
  .mobile-nav,.mobile-nav__links>*,.mobile-nav__foot{transition-duration:.01ms!important;transform:none!important}
  .hero__blob{animation:none!important}
  .hero__chip{animation:none!important}
  .scroll-progress{display:none}
}

/* ============ Case-study PDF documents ============ */
.cs-docs{display:flex;flex-direction:column;gap:clamp(28px,4vw,56px)}
.cs-doc{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3.4vw,48px);align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);padding:clamp(22px,3vw,40px)}
.cs-doc:nth-child(even) .cs-doc__info{order:2}
.cs-doc__brand{display:flex;align-items:center;gap:.85rem;margin-bottom:1rem;flex-wrap:wrap}
.cs-doc__logo{flex:0 0 auto;display:grid;place-items:center;width:56px;height:56px;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:8px}
.cs-doc__logo img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(1)}
.cs-doc__info h3{font-size:clamp(1.35rem,2.4vw,1.9rem);line-height:1.15;margin:.1rem 0 .6rem}
.cs-doc__info h3 a{color:inherit}
.cs-doc__info h3 a:hover{color:var(--green-500)}
.cs-doc__info>p{color:var(--ink-600);margin-bottom:1.2rem}
.cs-stats{list-style:none;display:flex;flex-wrap:wrap;gap:.7rem 1.7rem;margin:0 0 1.3rem;padding:0}
.cs-stats li{display:flex;flex-direction:column;gap:2px}
.cs-stats b{font-family:var(--display);font-size:clamp(1.3rem,2.2vw,1.7rem);font-weight:800;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cs-stats span{font-size:.78rem;color:var(--ink-500);max-width:16ch}
.cs-quote{border-left:2px solid var(--green-500);padding:.1rem 0 .1rem 1rem;margin:0 0 1.4rem}
.cs-quote .icon{color:var(--green-500);opacity:.5;margin-bottom:.1rem}
.cs-quote p{font-size:.98rem;color:var(--ink-700);font-style:italic;margin:0 0 .5rem}
.cs-quote cite{font-style:normal;font-weight:600;font-size:.85rem;color:var(--ink-800)}
.cs-doc__actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:1rem}
.tags{display:flex;flex-wrap:wrap;gap:.5rem}

/* PDF viewer frame — pinned light (PDFs render on white) */
.pdf-frame{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line-2);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg);text-decoration:none;color:inherit;transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2)}
.pdf-frame:hover{transform:translateY(-4px);box-shadow:0 34px 64px -24px rgba(0,0,0,.6)}
.pdf-frame__bar{display:flex;align-items:center;gap:.7rem;padding:.55rem .85rem;background:#f6f9f1;border-bottom:1px solid #e6ebe0}
.pdf-frame__dots{display:flex;gap:6px;flex:0 0 auto}
.pdf-frame__dots i{width:10px;height:10px;border-radius:50%;display:block}
.pdf-frame__dots i:nth-child(1){background:#ff5f57}.pdf-frame__dots i:nth-child(2){background:#febc2e}.pdf-frame__dots i:nth-child(3){background:#28c840}
.pdf-frame__name{flex:1;min-width:0;text-align:center;font-size:.8rem;font-weight:600;color:#79837a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pdf-frame__dl{flex:0 0 auto;display:grid;place-items:center;width:30px;height:30px;border-radius:8px;color:#3f7a0a;background:rgba(140,198,63,.16)}
.pdf-frame__dl:hover{background:rgba(140,198,63,.3)}
.pdf-frame__doc{position:relative;display:block;background:#fff;max-height:min(72vh,640px);overflow:hidden}
.pdf-frame__doc picture,.pdf-frame__doc img,.pdf-frame__img{display:block;width:100%;height:auto}
.pdf-frame__doc::after{content:"";position:absolute;left:0;right:0;bottom:0;height:110px;background:linear-gradient(180deg,transparent,#fff);pointer-events:none;z-index:1}
.pdf-frame__open{position:absolute;left:50%;bottom:18px;z-index:2;transform:translate(-50%,8px);display:inline-flex;align-items:center;gap:.4rem;
  background:var(--grad);color:#fff;padding:.55rem 1rem;border-radius:999px;font-size:.82rem;font-weight:600;
  box-shadow:0 12px 28px -8px rgba(111,176,36,.6);opacity:0;transition:opacity var(--dur-2),transform var(--dur-2) var(--ease-out)}
.pdf-frame:hover .pdf-frame__open{opacity:1;transform:translate(-50%,0)}

/* detail layout */
.cs-detail{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:start}
.cs-detail__doc{position:sticky;top:96px}
.cs-detail__doc .tags{margin-top:1rem;justify-content:center}
.cs-detail .cs-stats{margin-bottom:2rem}

@media (max-width:980px){
  .cs-doc{grid-template-columns:1fr}
  .cs-doc:nth-child(even) .cs-doc__info{order:0}
  .cs-detail{grid-template-columns:1fr}
  .cs-detail__doc{position:static}
  .pdf-frame__doc{max-height:min(80vh,540px)}
}

/* ============ YouTube video facades ============ */
.yt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(16px,2.4vw,30px)}
.yt-grid--3{grid-template-columns:repeat(3,1fr)}
.yt{margin:0}
.yt__btn{display:block;position:relative;width:100%;aspect-ratio:16/9;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  padding:0;cursor:pointer;background:#0a110d;box-shadow:var(--shadow-sm);transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2)}
.yt__btn:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.yt__thumb{display:block;width:100%;height:100%;object-fit:cover;opacity:.94;transition:opacity var(--dur-2),transform var(--dur-2) var(--ease-out)}
.yt__btn:hover .yt__thumb{opacity:1;transform:scale(1.04)}
.yt__btn::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 48%,rgba(8,12,6,.5));pointer-events:none}
.yt__play{position:absolute;inset:0;margin:auto;z-index:2;width:62px;height:62px;border-radius:50%;display:grid;place-items:center;
  background:var(--grad);color:#fff;box-shadow:0 12px 32px -8px rgba(111,176,36,.65);transition:transform var(--dur-2) var(--ease-spring)}
.yt__play svg{margin-left:3px}
.yt__btn:hover .yt__play{transform:scale(1.1)}
.yt__cap{display:flex;flex-direction:column;gap:1px;padding:.85rem .2rem .2rem}
.yt__client{font-weight:700;color:var(--ink-900);font-size:.95rem}
.yt__title{color:var(--ink-500);font-size:.85rem}
.yt__frame{display:block;width:100%;aspect-ratio:16/9;border:0;border-radius:16px;box-shadow:var(--shadow-lg);background:#000}
@media (max-width:820px){.yt-grid--3{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.yt-grid--3{grid-template-columns:1fr}}
