/* ============================================================
   Gram Cleaning Services Ltd
   Modern, technical, certified-clean
   Brand: blue #0A71B5 · lime #92C733
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* surfaces */
  --bg:#FFFFFF;
  --surface:#FFFFFF;
  --ice:#EDF4F9;
  --tint:#F1F6FA;
  --summit:#082633;
  --summit-700:#0C384B;
  --summit-900:#06202B;

  /* brand */
  --blue:#0A71B5;
  --blue-700:#075E97;
  --blue-800:#064C7C;
  --lime:#92C733;
  --lime-600:#7FB02B;
  --lime-700:#6A9622;
  --lime-ink:#4F7A14;        /* AA-safe lime for text on light */

  /* ink */
  --ink:#0F2A38;
  --ink-body:#48606D;
  --ink-on-dark:#E8F1F6;
  --muted-on-dark:#9BBACA;
  --sky-soft:#8FD0F4;        /* eyebrow on dark */

  /* lines + states */
  --border:#DCE7EE;
  --border-dark:rgba(255,255,255,.13);
  --focus:#0A71B5;

  /* radii */
  --r-sm:10px;
  --r-md:16px;
  --r-lg:22px;
  --r-xl:30px;
  --r-pill:999px;

  /* shadows (blue-tinted) */
  --sh-sm:0 1px 2px rgba(8,38,58,.07);
  --sh-md:0 10px 30px rgba(8,38,58,.09);
  --sh-lg:0 24px 60px rgba(8,38,58,.14);
  --sh-card:0 30px 70px rgba(8,38,58,.18);
  --sh-blue:0 14px 30px rgba(10,113,181,.30);
  --sh-lime:0 14px 30px rgba(122,178,40,.34);

  /* spacing */
  --container:1200px;
  --gutter:clamp(20px,5vw,64px);
  --section-y:clamp(64px,9vw,124px);
  --topbar-h:42px;
  --header-h:126px;
  --slope:clamp(30px,5vw,68px);

  /* motion */
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-inout:cubic-bezier(.65,0,.35,1);
  --t-micro:170ms;
  --t-ui:280ms;
  --t-reveal:720ms;

  --font-head:"Sora",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font-body);
  color:var(--ink-body);
  background:var(--bg);
  line-height:1.65;
  font-size:1.0625rem;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video{display:block;max-width:100%}
img{height:auto}
a{color:var(--blue-700);text-decoration:none}
ul{list-style:none}
ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
input,select,textarea{font-family:inherit;font-size:1rem}
:focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:4px}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
section[id],[id]{scroll-margin-top:90px}
#top{position:absolute}

.skip-link{position:fixed;left:16px;top:-60px;z-index:200;background:var(--summit);color:#fff;padding:12px 18px;border-radius:var(--r-sm);transition:top var(--t-ui)}
.skip-link:focus{top:16px}

/* ---------- Typography ---------- */
.section-title{
  font-family:var(--font-head);font-weight:700;color:var(--ink);
  line-height:1.1;letter-spacing:-.02em;font-size:clamp(1.9rem,3.7vw,3rem);
}
.on-dark .section-title{color:#fff}
.section-lead{font-size:clamp(1.05rem,1.5vw,1.22rem);line-height:1.55;color:var(--ink-body);max-width:60ch;margin-top:18px}
.center .section-lead,.section-head.center{margin-inline:auto}
.on-dark .section-lead{color:var(--muted-on-dark)}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-body);font-weight:700;text-transform:uppercase;
  font-size:.76rem;letter-spacing:.16em;color:var(--blue-700);margin-bottom:16px;
}
.eyebrow .peak{width:20px;height:20px;fill:var(--lime);stroke:none;flex:none}
.eyebrow-on-dark{color:var(--sky-soft)}
.center-eyebrow{justify-content:center}

.section-head{margin-bottom:clamp(40px,6vw,70px);max-width:66ch}
.section-head.center{text-align:center}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:600;font-size:1rem;letter-spacing:.01em;line-height:1;
  min-height:48px;padding:15px 26px;border-radius:var(--r-md);
  transition:transform var(--t-ui) var(--ease-out),background var(--t-ui),box-shadow var(--t-ui),color var(--t-ui),border-color var(--t-ui);
  white-space:nowrap;
}
.btn .ico{width:18px;height:18px;flex:none}
.btn-lg{padding:17px 32px;font-size:1.05rem}
.btn-sm{min-height:42px;padding:11px 18px;font-size:.92rem}
.btn-block{display:flex;width:100%}

.btn-primary{background:var(--lime);color:var(--summit);box-shadow:var(--sh-sm);font-weight:700}
.btn-primary:hover{background:var(--lime-600);transform:translateY(-2px);box-shadow:var(--sh-lime)}
.btn-primary:active{transform:translateY(0)}

.btn-outline{background:transparent;border:1.6px solid var(--blue);color:var(--blue-700)}
.btn-outline .ico{stroke:currentColor}
.btn-outline:hover{background:rgba(10,113,181,.08);border-color:var(--blue-700)}

.btn-ghost{background:rgba(10,113,181,.08);color:var(--blue-700)}
.btn-ghost .ico{stroke:currentColor}
.btn-ghost:hover{background:rgba(10,113,181,.15)}

/* outline/ghost on dark surfaces */
.midcta .btn-outline,.contact .btn-outline,.mobile-bar .btn-ghost,.mobile-nav .btn-ghost{
  border:1.6px solid rgba(255,255,255,.7);color:#fff;background:transparent}
.midcta .btn-outline:hover,.contact .btn-outline:hover,.mobile-bar .btn-ghost:hover,.mobile-nav .btn-ghost:hover{
  background:rgba(255,255,255,.12);border-color:#fff}

.link-more{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--blue-700);position:relative}
.link-more .arrow{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;transition:transform var(--t-ui) var(--ease-out)}
.link-more::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:0;background:var(--lime);transition:width var(--t-ui) var(--ease-out)}
.link-more:hover::after{width:calc(100% - 26px)}
.link-more:hover .arrow{transform:translateX(4px)}

/* shared line-icon defaults */
svg.ico,.tick,.select-arrow,.peak,
.creds-row svg,.ind-ico svg,.svc-ico svg,.edge-ico svg,.climb-node svg,.contact-list .ico{
  fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;
}
.peak{stroke:none}

/* contour texture */
.contours{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;stroke-width:1.4}
.contours--light{color:var(--blue);opacity:.06}
.contours--dark{color:#fff;opacity:.06}

/* ============================================================
   TOP UTILITY BAR
   ============================================================ */
.topbar{position:fixed;top:0;left:0;right:0;z-index:101;height:var(--topbar-h);
  background:var(--summit-900);color:var(--ice);transition:transform var(--t-ui) var(--ease-inout)}
.topbar.is-hidden{transform:translateY(-100%)}
.topbar-inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:18px}
.topbar-tag{display:inline-flex;align-items:center;gap:9px;font-size:.78rem;font-weight:500;letter-spacing:.01em;color:#CFE2EC;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-tag .ico{width:16px;height:16px;stroke:var(--lime);flex:none}
.topbar-peak{width:15px;height:15px;fill:var(--lime);flex:none}
.topbar-meta{display:flex;align-items:center;gap:14px}
.topbar-link{display:inline-flex;align-items:center;gap:7px;color:var(--ice);font-size:.8rem;font-weight:500;transition:color var(--t-micro)}
.topbar-link .ico{width:15px;height:15px;stroke:var(--lime)}
.topbar-link:hover{color:#fff}
.topbar-link.strong{font-weight:700}
.topbar-sep{width:1px;height:16px;background:var(--border-dark)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:var(--topbar-h);left:0;right:0;z-index:100;
  transition:top var(--t-ui) var(--ease-inout),background var(--t-ui),box-shadow var(--t-ui),padding var(--t-ui),border-color var(--t-ui);
  background:rgba(255,255,255,.9);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);
  border-bottom:1px solid rgba(220,231,238,.68)}
.header-inner{display:flex;align-items:center;gap:24px;padding-block:7px}
.brand{display:flex;align-items:center;gap:12px;flex:none}
.brand-logo{width:114px;height:auto;flex:none;transition:width var(--t-ui) var(--ease-inout)}
.brand-word{display:flex;flex-direction:column;line-height:1;white-space:nowrap}
.brand-word b{font-family:var(--font-head);font-weight:800;font-size:1.2rem;letter-spacing:-.01em;color:var(--ink)}
.brand-word em{font-family:var(--font-body);font-style:normal;font-weight:600;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--blue-700);margin-top:4px}

.primary-nav{display:flex;gap:28px;margin-inline:auto}
.primary-nav a{font-weight:600;font-size:.97rem;color:var(--ink);position:relative;padding:6px 0;white-space:nowrap;transition:color var(--t-micro)}
.primary-nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--lime);transition:width var(--t-micro) var(--ease-out)}
.primary-nav a:hover,.primary-nav a:focus-visible,.primary-nav a.is-active{color:var(--blue-700)}
.primary-nav a:hover::after,.primary-nav a:focus-visible::after,.primary-nav a.is-active::after{width:100%}
.header-cta{display:flex;align-items:center;gap:12px}

.site-header[data-state="scrolled"]{top:0;background:rgba(255,255,255,.92);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);box-shadow:var(--sh-md);border-bottom-color:var(--border)}
.site-header[data-state="scrolled"] .header-inner{padding-block:7px}
.site-header[data-state="scrolled"] .brand-logo{width:96px}

.nav-toggle{display:none;width:48px;height:48px;border-radius:var(--r-sm);position:relative}
.nav-toggle span{position:absolute;left:12px;right:12px;height:2px;background:var(--ink);border-radius:2px;transition:transform var(--t-ui) var(--ease-out),opacity var(--t-micro)}
.nav-toggle span:nth-child(1){top:16px}
.nav-toggle span:nth-child(2){top:23px}
.nav-toggle span:nth-child(3){top:30px}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav */
.mobile-nav{position:fixed;inset:0;z-index:99;visibility:hidden;pointer-events:none}
.mobile-nav::before{content:"";position:absolute;inset:0;background:rgba(6,32,43,.55);opacity:0;transition:opacity var(--t-ui)}
.mobile-nav-panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);
  background:var(--summit);padding:90px 28px 28px;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform var(--t-ui) var(--ease-out);box-shadow:-20px 0 60px rgba(0,0,0,.4)}
body.nav-open .mobile-nav{visibility:visible;pointer-events:auto}
body.nav-open .mobile-nav::before{opacity:1}
body.nav-open .mobile-nav-panel{transform:translateX(0)}
.mobile-nav-panel nav{display:flex;flex-direction:column;gap:4px}
.mobile-nav-panel nav a{color:var(--ink-on-dark);font-family:var(--font-head);font-size:1.35rem;font-weight:600;padding:12px 0;border-bottom:1px solid var(--border-dark)}
.mobile-nav-foot{margin-top:auto;display:flex;flex-direction:column;gap:12px}
.mobile-nav-note{color:var(--muted-on-dark);font-size:.8rem;text-align:center;margin-top:6px}

/* ============================================================
   HERO (full-bleed video)
   ============================================================ */
.hero{position:relative;overflow:hidden;isolation:isolate;display:flex;align-items:center;
  min-height:calc(100svh - 28px);
  padding-top:calc(var(--topbar-h) + var(--header-h) + clamp(26px,5vw,58px));
  padding-bottom:clamp(44px,6vw,76px);
  background:var(--summit)}
.hero-bg{position:absolute;inset:0;z-index:-1;overflow:hidden;background:#092735 url(../assets/video/pexels-cleaners-hero-poster.jpg) center/cover}
.hero-bg-video{width:100%;height:100%;object-fit:cover;filter:saturate(.82) contrast(1.1)}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(4,19,26,.92) 0%,rgba(4,19,26,.78) 34%,rgba(4,19,26,.46) 66%,rgba(4,19,26,.26) 100%),
    linear-gradient(180deg,rgba(4,19,26,.25) 0%,rgba(4,19,26,.24) 54%,rgba(4,19,26,.76) 100%)}
.hero-bg::before{content:"";position:absolute;inset:auto 0 0 0;height:34%;z-index:1;
  background:linear-gradient(180deg,transparent,rgba(8,38,51,.9))}
.hero-inner{position:relative;z-index:1;width:100%}
.hero-copy{max-width:920px;color:var(--ink-on-dark)}
.hero .eyebrow{color:var(--sky-soft);margin-bottom:16px}
.hero-title{font-family:var(--font-head);font-weight:800;color:#fff;
  font-size:clamp(2.65rem,6vw,5rem);line-height:.98;letter-spacing:0;margin:0 0 22px;max-width:14ch}
.hero-sub{font-size:clamp(1.05rem,1.7vw,1.28rem);color:#D3E4EC;max-width:50ch;line-height:1.62}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero .btn-outline{border-color:rgba(255,255,255,.74);color:#fff;background:rgba(255,255,255,.06)}
.hero .btn-outline:hover{background:rgba(255,255,255,.14);border-color:#fff}
@media (prefers-reduced-motion:reduce){.hero-bg-video{display:none}}

/* ============================================================
   CREDENTIALS STRIP
   ============================================================ */
.creds{background:var(--ice);padding-block:clamp(28px,4vw,40px);border-bottom:1px solid var(--border)}
.creds-lead{text-align:center;font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-body);margin-bottom:22px}
.creds-row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 38px}
.creds-row li{display:inline-flex;align-items:center;gap:12px}
.creds-row svg{width:30px;height:30px;color:var(--blue);flex:none}
.creds-row span{display:flex;flex-direction:column;font-size:.78rem;color:var(--ink-body);line-height:1.25}
.creds-row b{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--ink)}

/* ============================================================
   SECTION SHELLS
   ============================================================ */
.section{padding-block:var(--section-y);position:relative}
.section--tint{background:var(--tint)}
.section--ridge-top::before{content:"";display:block;width:64px;height:0;margin:0 auto clamp(20px,3vw,30px);
  border-bottom:3px solid var(--lime);transform:skewX(-24deg);opacity:.9}

/* ============================================================
   VALUE STATEMENT
   ============================================================ */
.statement{overflow:hidden;background:#fff}
.statement>.container{position:relative;z-index:1}
.statement-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(36px,5vw,76px);align-items:center}
.statement-copy .kw{color:var(--blue)}
.statement-copy .lede{font-size:clamp(1.1rem,1.7vw,1.32rem);color:var(--ink);font-weight:500;margin:6px 0 16px;line-height:1.5}
.statement-copy p{margin-top:14px;max-width:58ch}
.statement-values{display:grid;grid-template-columns:1fr 1fr;gap:18px 26px;margin-top:30px}
.value{padding-left:16px;border-left:3px solid var(--lime)}
.value-k{display:block;font-family:var(--font-head);font-weight:700;font-size:1.02rem;color:var(--ink)}
.value-v{display:block;font-size:.92rem;color:var(--ink-body);margin-top:3px}

.statement-figure{position:relative}
.statement-img{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);aspect-ratio:4/5;border:6px solid #fff;outline:1px solid var(--border)}
.statement-img img{width:100%;height:100%;object-fit:cover}
.statement-badge{position:absolute;left:-22px;bottom:34px;background:var(--summit);color:#fff;
  padding:18px 22px;border-radius:var(--r-md);box-shadow:var(--sh-card);text-align:center;border-bottom:3px solid var(--lime)}
.statement-badge-num{display:block;font-family:var(--font-head);font-weight:800;font-size:2.2rem;line-height:1;color:var(--lime)}
.statement-badge-lbl{display:block;font-size:.76rem;color:var(--muted-on-dark);margin-top:5px;line-height:1.3}

/* ============================================================
   INDUSTRIES
   ============================================================ */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ind-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);
  transition:transform var(--t-ui) var(--ease-out),box-shadow var(--t-ui),border-color var(--t-ui)}
.ind-card:hover{transform:translateY(-6px);box-shadow:var(--sh-card);border-color:transparent}
.ind-card--lg{grid-column:span 2}
.ind-media{overflow:hidden;aspect-ratio:16/10}
.ind-card--lg .ind-media{aspect-ratio:16/8}
.ind-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-ui) var(--ease-out)}
.ind-card:hover .ind-media img{transform:scale(1.06)}
.ind-body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.ind-ico{display:inline-flex;width:46px;height:46px;align-items:center;justify-content:center;border-radius:var(--r-md);
  background:rgba(10,113,181,.09);color:var(--blue);margin-bottom:14px}
.ind-ico svg{width:24px;height:24px}
.ind-card h3{font-family:var(--font-head);font-weight:700;font-size:1.22rem;color:var(--ink);line-height:1.2;margin-bottom:8px}
.ind-card--lg h3{font-size:1.45rem}
.ind-body p{font-size:.96rem;color:var(--ink-body);margin-bottom:16px}
.ind-body .link-more{margin-top:auto;font-size:.92rem}
.ind-foot{text-align:center;margin-top:42px;font-size:1.02rem;color:var(--ink-body)}
.ind-foot strong{color:var(--ink);font-weight:600}
.ind-foot .link-more{margin-left:8px}

/* ============================================================
   SERVICES (capabilities)
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 26px;
  box-shadow:var(--sh-sm);transition:transform var(--t-ui) var(--ease-out),box-shadow var(--t-ui),border-color var(--t-ui)}
.svc:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(10,113,181,.3)}
.svc-ico{display:inline-flex;width:52px;height:52px;align-items:center;justify-content:center;border-radius:14px;
  background:linear-gradient(145deg,rgba(10,113,181,.12),rgba(146,199,51,.16));color:var(--blue);margin-bottom:16px}
.svc-ico svg{width:26px;height:26px}
.svc h3{font-family:var(--font-head);font-weight:700;font-size:1.16rem;color:var(--ink);margin-bottom:8px}
.svc p{font-size:.95rem;color:var(--ink-body)}

/* ============================================================
   THE EVEREST EDGE (dark)
   ============================================================ */
.edge{position:relative;overflow:hidden;isolation:isolate;color:var(--ink-on-dark);
  background:linear-gradient(160deg,var(--summit) 0%,var(--summit-700) 100%);
  clip-path:polygon(0 var(--slope),100% 0,100% 100%,0 100%)}
.edge>.container{position:relative;z-index:1}
.edge .section-head{padding-top:clamp(10px,3vw,30px)}
.edge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.edge-item{background:rgba(255,255,255,.045);border:1px solid var(--border-dark);border-radius:var(--r-lg);padding:30px 26px;
  transition:transform var(--t-ui) var(--ease-out),background var(--t-ui),border-color var(--t-ui)}
.edge-item:hover{transform:translateY(-5px);background:rgba(255,255,255,.07);border-color:rgba(146,199,51,.5)}
.edge-ico{display:inline-flex;width:52px;height:52px;align-items:center;justify-content:center;border-radius:50%;
  background:rgba(146,199,51,.16);color:var(--lime);margin-bottom:16px}
.edge-ico svg{width:26px;height:26px}
.edge-item h3{font-family:var(--font-head);font-weight:600;font-size:1.2rem;color:#fff;margin-bottom:8px;line-height:1.2}
.edge-item p{font-size:.95rem;color:var(--muted-on-dark)}

/* ============================================================
   METHOD — ascending "climb"
   ============================================================ */
.climb{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:end;position:relative}
.climb-step{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:26px 24px 24px;box-shadow:var(--sh-sm);transition:transform var(--t-ui) var(--ease-out),box-shadow var(--t-ui)}
.climb-step:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.climb-step:nth-child(1){margin-top:96px}
.climb-step:nth-child(2){margin-top:64px}
.climb-step:nth-child(3){margin-top:32px}
.climb-step:nth-child(4){margin-top:0}
.climb-alt{position:absolute;top:14px;right:18px;font-family:var(--font-head);font-weight:800;font-size:2.1rem;color:rgba(10,113,181,.12);line-height:1}
.climb-node{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;border-radius:50%;
  background:#fff;border:3px solid var(--lime);color:var(--blue);margin-bottom:14px;box-shadow:var(--sh-sm)}
.climb-node svg{width:26px;height:26px}
.climb-step h3{font-family:var(--font-head);font-weight:700;font-size:1.14rem;color:var(--ink);margin-bottom:7px;line-height:1.2}
.climb-step p{font-size:.93rem;color:var(--ink-body)}
.method-cta{text-align:center;margin-top:52px}

/* ============================================================
   STATS (dark, image)
   ============================================================ */
.stats{position:relative;overflow:hidden;isolation:isolate;color:var(--ink-on-dark);
  background:var(--summit);padding-block:clamp(80px,10vw,140px) clamp(64px,8vw,110px);
  clip-path:polygon(0 var(--slope),100% 0,100% 100%,0 100%)}
.stats-bg{position:absolute;inset:0;z-index:-1;opacity:.16}
.stats-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) sepia(.5) hue-rotate(165deg) saturate(2.2)}
.stats::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(8,38,58,.86),rgba(6,32,43,.94))}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;margin-top:48px}
.stat{position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-15px;top:14%;bottom:14%;width:1px;background:var(--border-dark)}
.stat-num{display:block;font-family:var(--font-head);font-weight:800;line-height:1;font-size:clamp(2.6rem,5.5vw,4rem);color:var(--lime)}
.stat-label{display:block;margin-top:12px;color:var(--muted-on-dark);font-size:.95rem;max-width:22ch;margin-inline:auto}

/* ============================================================
   TESTIMONIAL
   ============================================================ */
.testimonial{background:#fff}
.quote-card{max-width:880px;margin-inline:auto;background:var(--ice);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:clamp(32px,5vw,56px);text-align:center;position:relative;box-shadow:var(--sh-md);border-top:4px solid var(--lime)}
.quote-stars{display:flex;justify-content:center;gap:5px;margin-bottom:20px}
.quote-stars svg{width:24px;height:24px;fill:var(--lime);stroke:none}
.quote-glyph{display:block;font-family:var(--font-head);font-weight:800;font-size:4.2rem;line-height:.7;color:var(--lime);height:2.3rem}
.quote-card blockquote{font-size:clamp(1.12rem,1.9vw,1.45rem);line-height:1.6;color:var(--ink);font-weight:500}
.quote-card figcaption{margin-top:24px}
.quote-name{display:block;font-family:var(--font-head);font-weight:700;font-size:1.05rem;color:var(--blue-800)}
.quote-role{display:block;font-size:.9rem;color:var(--ink-body);margin-top:3px}

/* ============================================================
   MID CTA (image, dark)
   ============================================================ */
.midcta{position:relative;color:#fff;text-align:center;overflow:hidden;isolation:isolate;
  padding-block:clamp(72px,10vw,120px);clip-path:polygon(0 var(--slope),100% 0,100% 100%,0 100%)}
.midcta-bg{position:absolute;inset:0;z-index:-2}
.midcta-bg img{width:100%;height:100%;object-fit:cover}
.midcta::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,rgba(6,32,43,.93),rgba(10,113,181,.74))}
.midcta-inner{max-width:760px;margin-inline:auto}
.midcta h2{font-family:var(--font-head);font-weight:800;font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.08;letter-spacing:-.02em}
.midcta-sub{color:#DCEAF3;margin:18px auto 30px;max-width:60ch;font-size:1.08rem}
.midcta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   AREAS
   ============================================================ */
.areas{background:#fff}
.areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}
.areas-copy p{margin-top:14px;max-width:54ch}
.areas-region{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;max-width:420px}
.areas-region li{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--ink)}
.areas-region li::before{content:"";width:11px;height:11px;flex:none;background:var(--lime);
  clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
.areas-copy .link-more{margin-top:24px}
.areas-card{padding:clamp(26px,4vw,40px);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-md);
  background-image:radial-gradient(circle,rgba(10,113,181,.06) 1.4px,transparent 1.6px);background-size:22px 22px}
.areas-card h3{font-family:var(--font-head);font-weight:700;font-size:1.05rem;color:var(--blue-800);text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px;font-size:.86rem}
.pill-list{display:flex;flex-wrap:wrap;gap:10px}
.pill-list li{padding:9px 16px;border-radius:var(--r-pill);background:var(--ice);border:1px solid var(--border);
  font-weight:500;font-size:.92rem;color:var(--ink);transition:all var(--t-ui) var(--ease-out);cursor:default}
.pill-list li:hover{background:rgba(146,199,51,.18);border-color:var(--lime);transform:translateY(-2px)}

/* ============================================================
   CONTACT (dark)
   ============================================================ */
.contact{position:relative;overflow:hidden;color:var(--ink-on-dark);
  background:linear-gradient(160deg,var(--summit) 0%,var(--summit-700) 100%);
  padding-block:clamp(86px,11vw,140px) var(--section-y);
  clip-path:polygon(0 var(--slope),100% 0,100% 100%,0 100%)}
.contact>.container{position:relative;z-index:1}
.contact .section-title{color:#fff}
.contact .section-head{padding-top:clamp(10px,3vw,28px)}
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(36px,5vw,72px);align-items:start}
.contact-lead{color:var(--muted-on-dark);max-width:48ch;margin-bottom:26px}
.contact-list{display:grid;gap:16px;margin-bottom:28px}
.contact-list li{display:flex;align-items:flex-start;gap:14px;color:var(--ink-on-dark)}
.contact-list .ico{width:24px;height:24px;flex:none;stroke:var(--lime);margin-top:2px}
.contact-list a{color:var(--ink-on-dark)}
.contact-list a:hover{color:var(--lime)}
.contact-creds{margin-bottom:24px}
.contact-creds-lbl{display:block;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;color:var(--muted-on-dark);margin-bottom:10px}
.contact-creds-pills{display:flex;flex-wrap:wrap;gap:8px}
.contact-creds-pills i{font-style:normal;font-size:.78rem;font-weight:700;padding:6px 12px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.08);border:1px solid var(--border-dark);color:var(--ink-on-dark)}
.contact-social{display:flex;gap:12px}
.contact-social a{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:50%;
  border:1px solid var(--border-dark);color:var(--ink-on-dark);transition:all var(--t-ui) var(--ease-out)}
.contact-social a:hover{background:var(--lime);border-color:var(--lime);color:var(--summit);transform:translateY(-3px)}
.contact-social svg{width:20px;height:20px;fill:currentColor}

.contact-form-card{background:#fff;border-radius:var(--r-xl);padding:clamp(26px,4vw,40px);box-shadow:var(--sh-lg);position:relative}
.field{margin-bottom:18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-weight:600;font-size:.88rem;color:var(--ink);margin-bottom:7px}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--border);border-radius:var(--r-sm);
  color:var(--ink);background:var(--surface);transition:border-color var(--t-ui),box-shadow var(--t-ui)}
.field textarea{resize:vertical;min-height:110px}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-body);opacity:.8}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(10,113,181,.16)}
.select-wrap{position:relative}
.select-wrap select{appearance:none;-webkit-appearance:none;padding-right:42px;cursor:pointer}
.select-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--ink-body);pointer-events:none}
.select-wrap select.just-set{border-color:var(--lime);box-shadow:0 0 0 3px rgba(146,199,51,.25)}
.field .error{display:none;color:#C23A3A;font-size:.82rem;margin-top:6px;font-weight:500}
.field.invalid input,.field.invalid select{border-color:#D14343;box-shadow:0 0 0 3px rgba(209,67,67,.14)}
.field.invalid .error{display:block}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.82rem;color:var(--ink-body);text-align:center;margin-top:14px}
.form-success{text-align:center;padding:30px 10px}
.success-check{display:inline-flex;width:64px;height:64px;border-radius:50%;align-items:center;justify-content:center;background:rgba(122,178,40,.16);color:var(--lime-700);margin-bottom:18px}
.success-check svg{width:34px;height:34px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.form-success h3{font-family:var(--font-head);font-weight:700;font-size:1.5rem;color:var(--ink);margin-bottom:10px}
.form-success p{color:var(--ink-body)}
.form-success a{color:var(--blue-700);font-weight:600}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--summit-900);color:var(--muted-on-dark);border-top:3px solid var(--lime);padding-top:clamp(54px,7vw,80px)}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:46px}
.footer-brand-link{display:inline-flex;align-items:center;gap:12px;margin-bottom:18px}
.footer-brand-link .brand-mark{width:50px;height:50px}
.footer-logo-frame{display:inline-flex;align-items:center;justify-content:center;width:230px;max-width:100%;padding:10px 12px;background:#fff;border:1px solid rgba(220,231,238,.18);border-radius:8px}
.footer-logo{width:100%;height:auto}
.brand-word--light b{color:#fff}
.brand-word--light em{color:var(--lime)}
.footer-brand p{font-size:.94rem;max-width:42ch;line-height:1.6}
.footer-tag{margin-top:14px;font-family:var(--font-head);font-weight:600;color:var(--lime);font-size:.92rem;letter-spacing:.01em}
.footer-col h4{color:#fff;font-family:var(--font-body);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:16px}
.footer-col ul{display:grid;gap:10px}
.footer-col a,.footer-col li{color:var(--muted-on-dark);font-size:.94rem}
.footer-col a{transition:color var(--t-micro)}
.footer-col a:hover{color:#fff}
.footer-social{display:flex;gap:10px;margin-top:16px}
.footer-social a{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--border-dark);color:var(--muted-on-dark);transition:all var(--t-ui)}
.footer-social a:hover{background:var(--lime);border-color:var(--lime);color:var(--summit)}
.footer-social svg{width:18px;height:18px;fill:currentColor}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-block:22px;border-top:1px solid var(--border-dark);font-size:.83rem}

/* ============================================================
   STICKY MOBILE ACTION BAR
   ============================================================ */
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;gap:10px;
  padding:12px var(--gutter) calc(12px + env(safe-area-inset-bottom));
  background:rgba(6,32,43,.97);backdrop-filter:blur(10px);border-top:1px solid var(--border-dark);
  transform:translateY(0);transition:transform var(--t-ui) var(--ease-out)}
.mobile-bar.is-hidden{transform:translateY(120%)}
.mobile-bar .btn{flex:1;min-height:50px}

/* ============================================================
   REVEAL SYSTEM
   ============================================================ */
.js [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity var(--t-reveal) var(--ease-out),transform var(--t-reveal) var(--ease-out)}
.js [data-reveal].is-in{opacity:1;transform:none}
[data-stagger] [data-reveal]{transition-delay:calc(var(--i,0)*80ms)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1040px){
  .ind-grid{grid-template-columns:repeat(2,1fr)}
  .ind-card--lg{grid-column:span 2}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .edge-grid{grid-template-columns:repeat(2,1fr)}
  .climb{grid-template-columns:repeat(2,1fr);gap:26px}
  .climb-step{margin-top:0!important}
}
@media (max-width:1100px){
  .primary-nav,.header-call{display:none}
  .header-cta{margin-left:auto}
  .nav-toggle{display:block;flex:none}
  .hero{min-height:clamp(560px,calc(100svh - 64px),720px)}
  .hero-title{font-size:3.4rem;line-height:1}
}
@media (max-width:900px){
  .statement-grid,.areas-grid,.contact-grid{grid-template-columns:1fr}
  .hero-title{font-size:3.05rem}
  .statement-figure{max-width:440px;margin-inline:auto}
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:40px 20px}
  .stat:nth-child(2)::after{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  :root{--topbar-h:0px;--header-h:106px;--section-y:clamp(54px,11vw,84px)}
  .topbar{display:none}
  .header-cta{display:none}
  .nav-toggle{margin-left:auto}
  body{padding-bottom:calc(74px + env(safe-area-inset-bottom))}
  .mobile-bar{display:flex}
  .hero{min-height:clamp(600px,calc(100svh - 144px),680px)}
  .hero-title{font-size:2.85rem}
  .brand-logo{width:92px}
  .site-header[data-state="scrolled"] .brand-logo{width:86px}
  .site-header .brand-word{display:none}
  .ind-grid,.svc-grid,.edge-grid,.climb,.statement-values,.areas-region{grid-template-columns:1fr}
  .ind-card--lg{grid-column:span 1}
  .stat-grid{gap:34px 20px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{justify-content:flex-start}
}
@media (max-width:430px){
  .field-row{grid-template-columns:1fr}
  .hero-title{font-size:2.55rem;line-height:1.02}
  .hero-sub{font-size:1rem;line-height:1.55}
  .hero-actions{margin-top:24px}
  .hero-actions .btn{min-height:48px;padding:14px 20px}
  .hero-actions .btn{width:100%}
  .creds-row{gap:14px 24px}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important}
}
