/* =========================================================
   UNIQUE PACKAGING — Enhanced Frontend
   Preserves brand: Inter, #1a2b4c navy, #00A8E8 cyan
   ========================================================= */
:root{
  --navy: #1a2b4c;
  --navy-2: #233a66;
  --navy-deep: #0f1c36;
  --cyan: #00A8E8;
  --cyan-hot: #0095cf;
  --cyan-soft: #e6f6fd;
  --ink: #1a2b4c;
  --ink-2: #475472;
  --muted: #6b7891;
  --line: #e3e9f2;
  --bg: #ffffff;
  --bg-soft: #f5f9fc;
  --bg-cream: #f8fbfd;
  --shadow-sm: 0 2px 8px rgba(26,43,76,.06);
  --shadow: 0 12px 36px -12px rgba(26,43,76,.12);
  --shadow-lg: 0 24px 64px -16px rgba(26,43,76,.22);
  --radius: 16px;
  --radius-sm: 10px;
  --radius-lg: 24px;
  --easing: cubic-bezier(.22,.61,.36,1);
  --easing-sharp: cubic-bezier(.5,0,.1,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter','Helvetica Neue',Helvetica,Arial,sans-serif;
  font-feature-settings:'ss01','cv11';
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{margin:0;padding:0;list-style:none}

.wrap{max-width:1240px;margin:0 auto;padding:0 28px;position:relative;z-index:1}

/* =========================================================
   SCROLL PROGRESS
   ========================================================= */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--cyan),#5fd5ff);
  z-index:200;transition:width .12s linear;
  box-shadow:0 0 12px rgba(0,168,232,.6);
}

/* =========================================================
   NAVIGATION
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  transition:background .35s ease, box-shadow .35s ease, backdrop-filter .35s ease;
}
.nav__inner{
  max-width:1240px;margin:0 auto;
  display:flex;align-items:center;gap:28px;
  padding:18px 28px;
}
.nav.is-scrolled{
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  box-shadow:0 1px 0 rgba(26,43,76,.06), 0 8px 28px -16px rgba(26,43,76,.16);
}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__logo{height:42px;width:auto;display:block;transition:transform .25s var(--easing)}
.nav__brand:hover .nav__logo{transform:scale(1.04)}

.nav__links{display:flex;gap:8px;margin-left:auto;align-items:center}
.nav__links a{
  position:relative;
  padding:10px 14px;
  font-size:14.5px;font-weight:500;
  color:var(--ink-2);
  border-radius:8px;
  transition:color .2s ease;
}
.nav__links a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;border-radius:2px;
  background:var(--cyan);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--easing);
}
.nav__links a:hover{color:var(--navy)}
.nav__links a.is-active{color:var(--navy);font-weight:600}
.nav__links a.is-active::after{transform:scaleX(1)}

.nav__cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;background:var(--navy);color:#fff;
  border-radius:999px;font-weight:600;font-size:14px;
  transition:all .25s var(--easing);
  box-shadow:0 4px 14px -4px rgba(26,43,76,.4);
}
.nav__cta:hover{background:var(--cyan);transform:translateY(-1px);box-shadow:0 8px 22px -6px rgba(0,168,232,.5)}

.nav__burger{display:none;width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav__burger span{width:20px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s var(--easing)}
.nav.is-menu .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.is-menu .nav__burger span:nth-child(2){opacity:0}
.nav.is-menu .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity .8s var(--easing), transform .8s var(--easing);
}
.reveal.is-in{opacity:1;transform:none}
.stagger-1{transition-delay:.08s}
.stagger-2{transition-delay:.16s}
.stagger-3{transition-delay:.24s}
.stagger-4{transition-delay:.32s}
.stagger-5{transition-delay:.4s}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 26px;
  font-weight:600;font-size:15px;
  border-radius:999px;
  transition:all .25s var(--easing);
  white-space:nowrap;
  cursor:pointer;
}
.btn--primary{
  background:var(--cyan);color:#fff;
  box-shadow:0 8px 22px -6px rgba(0,168,232,.45);
}
.btn--primary:hover{background:var(--cyan-hot);transform:translateY(-2px);box-shadow:0 14px 28px -8px rgba(0,168,232,.6)}
.btn--primary svg{transition:transform .25s var(--easing)}
.btn--primary:hover svg{transform:translateX(3px)}

.btn--ghost{
  background:transparent;color:var(--navy);
  box-shadow:inset 0 0 0 2px rgba(26,43,76,.18);
}
.btn--ghost:hover{box-shadow:inset 0 0 0 2px var(--navy);background:rgba(26,43,76,.04)}

.btn--accent{
  background:#fff;color:var(--navy);
}
.btn--accent:hover{background:var(--cyan);color:#fff;transform:translateY(-2px)}

.btn--block{width:100%;justify-content:center}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  min-height:100vh;
  padding-top:120px;padding-bottom:80px;
  overflow:hidden;
  isolation:isolate;
}
.hero__bg{position:absolute;inset:0;z-index:-1;background:linear-gradient(160deg,#fff 0%, #f0f7fc 60%, #e6f3fa 100%)}
.hero__mesh{
  position:absolute;inset:-20%;
  background:
    radial-gradient(700px 500px at 78% 35%, rgba(0,168,232,.18), transparent 60%),
    radial-gradient(600px 500px at 18% 75%, rgba(26,43,76,.10), transparent 60%);
  filter:blur(20px);
}
.hero__blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.6;mix-blend-mode:multiply}
.hero__blob--1{width:480px;height:480px;background:radial-gradient(circle,#a9e2fb,transparent 70%);top:-100px;right:-80px;animation:floatA 14s ease-in-out infinite}
.hero__blob--2{width:520px;height:520px;background:radial-gradient(circle,#cfd8eb,transparent 70%);bottom:-150px;left:-100px;animation:floatA 18s ease-in-out -3s infinite reverse}
@keyframes floatA{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(40px,-30px) scale(1.07)}
}
.hero__grid{
  position:absolute;inset:0;opacity:.32;
  background-image:
    linear-gradient(rgba(26,43,76,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(26,43,76,.08) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 60% 70% at 50% 45%, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 60% 70% at 50% 45%, #000 30%, transparent 75%);
}

.hero__inner{
  max-width:1240px;margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;
  min-height:calc(100vh - 200px);
}

.hero__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px 8px 12px;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);
  border:1px solid rgba(26,43,76,.08);
  border-radius:999px;
  font-size:13px;font-weight:500;color:var(--navy);
  box-shadow:0 4px 14px -8px rgba(26,43,76,.2);
}
.hero__dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 0 4px rgba(0,168,232,.18);animation:pulseDot 2.2s ease-in-out infinite}
@keyframes pulseDot{
  0%,100%{box-shadow:0 0 0 4px rgba(0,168,232,.18)}
  50%{box-shadow:0 0 0 8px rgba(0,168,232,.05)}
}

.hero__title{
  margin:24px 0 22px;
  font-size:clamp(38px,5.6vw,72px);
  font-weight:800;
  line-height:1.02;
  letter-spacing:-.025em;
  color:var(--navy);
  display:flex;flex-wrap:wrap;gap:0 .25em;
}
.hero__title .word{
  display:inline-block;opacity:0;transform:translateY(28px) skewY(2deg);
  animation:rise .9s var(--easing) forwards;
}
.hero__title .word:nth-child(1){animation-delay:.05s}
.hero__title .word:nth-child(2){animation-delay:.15s}
.hero__title .word:nth-child(3){animation-delay:.25s}
.hero__title .word:nth-child(4){animation-delay:.35s}
.hero__title .word:nth-child(5){animation-delay:.45s}
@keyframes rise{to{opacity:1;transform:none}}
.hero__title--accent{
  background:linear-gradient(120deg,var(--cyan) 0%, #19c4ff 50%, var(--cyan) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  position:relative;
  animation:shimmer 6s linear infinite, rise .9s var(--easing) .45s forwards;
}
@keyframes shimmer{to{background-position:200% center}}

.hero__lede{
  max-width:560px;margin:0 0 32px;
  font-size:18px;line-height:1.65;color:var(--ink-2);
}

.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}

.hero__stats{
  display:flex;align-items:center;gap:28px;flex-wrap:wrap;
  padding:24px 28px;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(12px);
  border:1px solid rgba(26,43,76,.08);
  border-radius:18px;
  max-width:580px;
  box-shadow:0 12px 36px -16px rgba(26,43,76,.16);
}
.hero__stat{display:flex;flex-direction:column;gap:2px}
.hero__statNum{font-size:34px;font-weight:800;color:var(--navy);letter-spacing:-.02em;line-height:1}
.hero__statLabel{font-size:12.5px;color:var(--muted);font-weight:500;letter-spacing:.02em}
.hero__statDivider{width:1px;height:36px;background:linear-gradient(to bottom,transparent,rgba(26,43,76,.18),transparent)}

/* Hero right column */
.hero__right{position:relative;height:100%;display:flex;align-items:center;justify-content:center}
.hero__stage{
  position:relative;width:100%;max-width:560px;aspect-ratio:1/1;
  animation:floatStage 8s ease-in-out infinite;
}
@keyframes floatStage{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-14px)}
}
.hero__halo{
  position:absolute;inset:8%;
  background:radial-gradient(circle at 50% 55%, rgba(0,168,232,.35), transparent 55%);
  filter:blur(40px);
}
.hero__imageWrap{
  position:relative;width:100%;height:100%;
  border-radius:32px;overflow:hidden;
  background:#fff;
  box-shadow:0 40px 80px -30px rgba(26,43,76,.35), 0 0 0 1px rgba(255,255,255,.6) inset;
}
.hero__imageWrap img{width:100%;height:100%;object-fit:cover}

.hero__floatCard{
  position:absolute;
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(14px);
  border-radius:14px;
  box-shadow:0 18px 40px -16px rgba(26,43,76,.28), 0 0 0 1px rgba(26,43,76,.05);
  z-index:2;
  animation:floatCard 6s ease-in-out infinite;
}
@keyframes floatCard{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
.hero__floatCard--top{top:6%;left:-4%;animation-delay:-1s}
.hero__floatCard--bot{bottom:8%;right:-4%;animation-delay:-3s}
.hero__floatCard--botleft{bottom:8%;left:-4%;animation-delay:-2s}
.hero__floatCard--side{
  top:6%;right:-8%;padding:10px 14px;
  font-size:12.5px;font-weight:500;color:var(--navy);
  animation:none;
}
.hero__floatBadge{
  width:38px;height:38px;border-radius:10px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--cyan),#0093cf);color:#fff;
  box-shadow:0 6px 16px -4px rgba(0,168,232,.5);
}
.hero__floatBadge--alt{background:linear-gradient(135deg,var(--navy),var(--navy-2))}
.hero__floatTitle{font-size:14px;font-weight:700;color:var(--navy);line-height:1.1}
.hero__floatSub{font-size:11.5px;color:var(--muted);letter-spacing:.02em}
.hero__pingDot{
  width:8px;height:8px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 4px rgba(34,197,94,.2);
  animation:pulseGreen 2s ease-in-out infinite;
}
@keyframes pulseGreen{
  0%,100%{box-shadow:0 0 0 4px rgba(34,197,94,.2)}
  50%{box-shadow:0 0 0 8px rgba(34,197,94,.05)}
}

.hero__scrollHint{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  width:28px;height:46px;border-radius:14px;
  border:2px solid rgba(26,43,76,.22);
  display:grid;place-items:start center;
  padding-top:8px;
}
.hero__scrollHint span{
  width:4px;height:8px;border-radius:2px;background:var(--navy);
  animation:scrollHint 1.6s ease-in-out infinite;
}
@keyframes scrollHint{
  0%,100%{transform:translateY(0);opacity:0.4}
  50%{transform:translateY(10px);opacity:1}
}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{
  padding:32px 0 40px;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;
}
.marquee__label{
  text-align:center;font-size:11px;font-weight:600;
  color:var(--muted);letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:24px;
}
.marquee__track{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__row{display:flex;gap:88px;align-items:center;width:max-content;animation:marqueeMove 45s linear infinite}
.marquee:hover .marquee__row{animation-play-state:paused}
.marquee__row img{
  height:78px;max-width:160px;width:auto;object-fit:contain;
  image-rendering:-webkit-optimize-contrast;
  mix-blend-mode:multiply;
  filter:grayscale(1) contrast(.95);opacity:.62;
  transition:transform .35s var(--easing), filter .35s var(--easing), opacity .35s var(--easing);
  will-change:transform;
}
.marquee__row img:hover{filter:none;opacity:1;transform:scale(1.22) translateY(-3px)}
@keyframes marqueeMove{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* =========================================================
   GLOBAL SECTION
   ========================================================= */
.section{position:relative;padding:120px 0;isolation:isolate;overflow:hidden}
.section--light{background:#fff}
.section--cream{background:var(--bg-cream)}
.section--dark{
  background:linear-gradient(160deg,#172648 0%,#1a2b4c 50%,#0f1c36 100%);
  color:#fff;
}
.section__bgPattern{
  position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(0,168,232,.18), transparent 35%),
    radial-gradient(circle at 80% 70%, rgba(0,168,232,.12), transparent 40%);
}
.section--dark .section__bgPattern::after{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center, #000 20%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 20%, transparent 70%);
}

.sectionHead{max-width:720px;margin:0 auto 64px;text-align:center}
.sectionHead h2{
  margin:14px 0 16px;
  font-size:clamp(30px,3.8vw,46px);font-weight:800;letter-spacing:-.025em;
  color:var(--navy);line-height:1.08;
}
.sectionHead--dark h2{color:#fff}
.sectionHead p{font-size:17px;line-height:1.7;color:var(--ink-2);margin:0}
.sectionHead--dark p{color:rgba(255,255,255,.75)}

.kicker{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cyan);
}
.kicker span{width:24px;height:2px;background:var(--cyan);border-radius:2px}
.kicker::after{content:"";width:24px;height:2px;background:var(--cyan);border-radius:2px}
.kicker--dark{color:#5fd5ff}
.kicker--dark span{background:#5fd5ff}
.kicker--dark::after{background:#5fd5ff}

/* (Hover light-gradient sheen removed per request) */

/* =========================================================
   PRODUCTS
   ========================================================= */
.products{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.product{
  position:relative;
  background:#fff;
  border-radius:var(--radius-lg);
  border:1px solid var(--line);
  overflow:hidden;
  cursor:pointer;
  transition:all .35s var(--easing);
  box-shadow:var(--shadow-sm);
}
.product:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:rgba(0,168,232,.3);
}
.product__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:#f3f7fa}
.product__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--easing-sharp)}
.product:hover .product__media img{transform:scale(1.08)}
.product__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(15,28,54,.85) 0%, rgba(15,28,54,.2) 40%, transparent 60%);
  opacity:0;transition:opacity .35s var(--easing);
  display:flex;align-items:flex-end;justify-content:flex-start;
  padding:18px 20px;
}
.product:hover .product__overlay{opacity:1}
.product__viewBtn{
  display:inline-flex;align-items:center;gap:8px;
  color:#fff;font-weight:600;font-size:14px;
}
.product__viewBtn svg{transition:transform .25s var(--easing)}
.product:hover .product__viewBtn svg{transform:translateX(4px)}

.product__num{
  position:absolute;top:14px;left:14px;
  width:34px;height:34px;border-radius:8px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(6px);
  display:grid;place-items:center;
  font-size:12px;font-weight:700;color:var(--navy);letter-spacing:.02em;
  box-shadow:0 4px 12px -4px rgba(26,43,76,.2);
}
.product__badge{
  position:absolute;top:14px;right:14px;
  padding:5px 11px;border-radius:999px;
  background:var(--cyan);color:#fff;
  font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:0 4px 12px -4px rgba(0,168,232,.5);
}
.product__body{padding:24px 22px 22px}
.product__title{
  margin:0 0 6px;font-size:20px;font-weight:700;
  color:var(--navy);letter-spacing:-.015em;
  transition:color .25s var(--easing);
}
.product:hover .product__title{color:var(--cyan)}
.product__desc{margin:0 0 16px;font-size:14px;color:var(--ink-2);line-height:1.55;min-height:42px}
.product__pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}
.product__pill{
  font-size:11px;font-weight:500;
  padding:5px 10px;border-radius:999px;
  background:var(--cyan-soft);color:var(--cyan-hot);
}
.product__more{
  display:inline-flex;align-items:center;gap:5px;
  font-size:13.5px;font-weight:600;color:var(--cyan);
}
.product__more svg{transition:transform .25s var(--easing)}
.product:hover .product__more svg{transform:translateX(3px)}

/* =========================================================
   INDUSTRIES
   ========================================================= */
.industries{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
  margin-bottom:56px;
}
.industry{
  position:relative;padding:32px 28px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg);
  transition:all .35s var(--easing);
  overflow:hidden;
  isolation:isolate;
}
.industry::before{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background:linear-gradient(135deg, rgba(0,168,232,.15) 0%, rgba(0,168,232,0) 60%);
  transition:opacity .4s var(--easing);
}
.industry:hover{
  border-color:rgba(0,168,232,.35);
  transform:translateY(-4px);
  background:rgba(255,255,255,.07);
}
.industry:hover::before{opacity:1}
.industry__icon{
  width:52px;height:52px;border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(0,168,232,.18),rgba(0,168,232,.04));
  color:#5fd5ff;
  margin-bottom:20px;
  transition:all .35s var(--easing);
}
.industry:hover .industry__icon{
  background:linear-gradient(135deg,var(--cyan),#0093cf);color:#fff;
  transform:rotate(-6deg) scale(1.05);
  box-shadow:0 12px 28px -10px rgba(0,168,232,.6);
}
.industry h3{margin:0 0 8px;font-size:20px;font-weight:700;color:#fff;letter-spacing:-.015em}
.industry p{margin:0 0 18px;font-size:14px;color:rgba(255,255,255,.7);line-height:1.6}
.industry__tags{display:flex;flex-wrap:wrap;gap:6px}
.industry__tag{
  font-size:11.5px;font-weight:500;
  padding:5px 11px;border-radius:999px;
  background:rgba(0,168,232,.14);color:#5fd5ff;
  border:1px solid rgba(0,168,232,.22);
}

.industries__foot{text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px}
.industries__foot p{color:rgba(255,255,255,.75);font-size:15.5px;margin:0}

/* =========================================================
   REACH / MAP
   ========================================================= */
.reach__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
.reach__map{
  position:relative;aspect-ratio:1055/1491;
  max-width:420px;width:100%;margin:0 auto;
  background:linear-gradient(135deg,#eef6fc,#dbecf7);
  border-radius:var(--radius-lg);
  padding:24px;overflow:hidden;
  box-shadow:0 24px 48px -24px rgba(26,43,76,.18);
  border:1px solid rgba(0,168,232,.15);
}
.reach__map::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(600px 400px at 70% 50%, rgba(0,168,232,.18), transparent 60%),
    radial-gradient(400px 300px at 25% 70%, rgba(0,168,232,.10), transparent 60%);
}
.reach__mapInner{
  position:relative;z-index:1;
  width:100%;height:100%;
  display:grid;place-items:center;
}
.reach__mapImg{
  width:100%;height:100%;
  object-fit:contain;
  filter:drop-shadow(0 14px 30px rgba(26,43,76,.18)) saturate(1.4);
}
.reach__mapBadge{
  position:absolute;top:16px;left:16px;z-index:2;
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px 7px 12px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(6px);
  border-radius:999px;
  border:1px solid rgba(26,43,76,.08);
  font-size:11.5px;font-weight:700;color:var(--navy);
  letter-spacing:.04em;text-transform:uppercase;
  box-shadow:0 6px 16px -6px rgba(26,43,76,.2);
}
.reach__mapBadgeDot{
  width:8px;height:8px;border-radius:50%;background:var(--cyan);
}

/* City pins */
.reach__pin{
  position:absolute;z-index:3;
  display:inline-flex;align-items:center;gap:8px;
  transform:translate(-50%,-50%);
  pointer-events:none;
}
.reach__pin[data-side="left"]{transform:translate(calc(-100% + 5px),-50%)}
.reach__pin[data-side="right"]{transform:translate(-5px,-50%)}
.reach__pinDot{
  position:relative;flex:none;
  width:10px;height:10px;border-radius:50%;
  background:var(--cyan);
  box-shadow:0 0 0 3px rgba(255,255,255,.95), 0 2px 6px rgba(26,43,76,.35);
}
.reach__pinLabel{
  font-size:11.5px;font-weight:700;letter-spacing:.04em;
  color:var(--navy);
  background:#fff;
  padding:5px 10px;border-radius:999px;
  border:1px solid rgba(0,168,232,.25);
  box-shadow:0 4px 10px -4px rgba(26,43,76,.25);
  white-space:nowrap;
}
.reach__pinLabel em{
  font-style:normal;font-weight:800;
  color:#fff;background:var(--cyan);
  padding:2px 6px;border-radius:6px;
  margin-right:6px;font-size:10px;letter-spacing:.08em;
}
.reach__pin--hq .reach__pinDot{
  width:14px;height:14px;
  box-shadow:0 0 0 4px rgba(255,255,255,.95), 0 3px 10px rgba(26,43,76,.45);
}
.reach__pinPulse{
  position:absolute;inset:-6px;border-radius:50%;
  border:2px solid var(--cyan);
  animation:reachPulse 2.2s ease-out infinite;
}
@keyframes reachPulse{
  0%{transform:scale(.6);opacity:.9}
  100%{transform:scale(2.2);opacity:0}
}
@media (prefers-reduced-motion: reduce){
  .reach__pinPulse{animation:none;opacity:.5}
}

.reach__countries{display:flex;flex-direction:column;gap:12px}
.reach__country{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;border-radius:14px;
  background:#fff;border:1px solid var(--line);
  transition:all .3s var(--easing);
}
.reach__country:hover{transform:translateX(6px);border-color:var(--cyan);box-shadow:var(--shadow)}
.reach__country img{width:36px;height:24px;object-fit:cover;border-radius:4px;box-shadow:0 2px 6px rgba(0,0,0,.1)}
.reach__country strong{display:block;font-size:15px;color:var(--navy);font-weight:700}
.reach__country span{font-size:12px;color:var(--muted)}

/* =========================================================
   ABOUT
   ========================================================= */
.about__grid{display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:start;margin-bottom:64px}
.about__copy h3{margin:0 0 18px;font-size:26px;font-weight:700;color:var(--navy);letter-spacing:-.015em}
.about__copy p{margin:0 0 18px;font-size:15.5px;line-height:1.75;color:var(--ink-2)}

.about__stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
  position:sticky;top:120px;
}
.aboutStat{
  padding:28px 24px;border-radius:18px;
  background:#fff;border:1px solid var(--line);
  position:relative;overflow:hidden;
  transition:all .3s var(--easing);
}
.aboutStat::before{
  content:"";position:absolute;top:0;left:0;width:4px;height:100%;
  background:var(--cyan);transform:scaleY(.4);transform-origin:top;
  transition:transform .4s var(--easing);
}
.aboutStat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.aboutStat:hover::before{transform:scaleY(1)}
.aboutStat__num{font-size:42px;font-weight:800;color:var(--navy);letter-spacing:-.025em;line-height:1;margin-bottom:6px}
.aboutStat div:last-child{font-size:13.5px;color:var(--muted);font-weight:500}

.about__trusted{
  margin:0 0 96px;
  padding:44px 48px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,#fff,#f4faff);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.about__trustedLabel{
  text-align:center;font-size:16px;font-weight:800;
  letter-spacing:.2em;color:var(--navy);
  margin-bottom:36px;
  position:relative;
  display:flex;align-items:center;justify-content:center;gap:18px;
}
.about__trustedLabel::before,
.about__trustedLabel::after{
  content:"";flex:0 0 60px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,transparent,var(--cyan));
}
.about__trustedLabel::after{background:linear-gradient(90deg,var(--cyan),transparent)}
.about__trustedRow{
  display:flex;align-items:center;justify-content:space-around;flex-wrap:wrap;gap:36px;
}
.about__trustedRow img{
  height:82px;width:auto;object-fit:contain;
  filter:none;opacity:1;
  transition:transform .3s var(--easing), filter .3s var(--easing);
}
.about__trustedRow img:hover{transform:scale(1.12) translateY(-4px);filter:drop-shadow(0 10px 20px rgba(26,43,76,.18))}

/* =========================================================
   JOURNEY TIMELINE
   ========================================================= */
.journey{position:relative;padding:48px 0}
.journey__head{text-align:center;margin-bottom:64px}
.journey__head h3{margin:0;font-size:30px;font-weight:800;color:var(--navy);letter-spacing:-.02em}
.journey__line{
  position:absolute;left:50%;top:140px;bottom:0;
  width:2px;background:linear-gradient(to bottom,var(--cyan),rgba(0,168,232,.2),transparent);
  transform:translateX(-1px);
}
.journey__items{display:flex;flex-direction:column;gap:48px;position:relative}
.journeyItem{
  display:grid;grid-template-columns:1fr 80px 1fr;align-items:center;gap:24px;
  opacity:0;transform:translateY(30px);
  transition:opacity .8s var(--easing), transform .8s var(--easing);
}
.journeyItem.is-in{opacity:1;transform:none}
.journeyItem__node{
  width:64px;height:64px;border-radius:50%;
  background:#fff;border:2px solid var(--cyan);
  display:grid;place-items:center;
  font-size:15px;font-weight:800;color:var(--navy);
  box-shadow:0 8px 22px -8px rgba(0,168,232,.5);
  position:relative;z-index:2;
  margin:0 auto;
  transition:all .3s var(--easing);
}
.journeyItem__node::after{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid rgba(0,168,232,.3);
  animation:nodePulse 2.4s ease-in-out infinite;
}
@keyframes nodePulse{
  0%,100%{transform:scale(1);opacity:.7}
  50%{transform:scale(1.18);opacity:0}
}
.journeyItem__card{
  padding:24px 28px;border-radius:18px;
  background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  transition:all .3s var(--easing);
}
.journeyItem__card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(0,168,232,.3)}
.journeyItem--left .journeyItem__card{grid-column:1;text-align:right}
.journeyItem--left .journeyItem__node{grid-column:2}
.journeyItem--left .journeyItem__spacer{grid-column:3}
.journeyItem--right .journeyItem__spacer{grid-column:1}
.journeyItem--right .journeyItem__node{grid-column:2}
.journeyItem--right .journeyItem__card{grid-column:3}
.journeyItem__year{font-size:13px;color:var(--cyan);font-weight:700;letter-spacing:.05em}
.journeyItem__title{margin:4px 0 6px;font-size:17px;font-weight:700;color:var(--navy)}
.journeyItem__desc{font-size:13.5px;color:var(--ink-2);line-height:1.6;margin:0}

/* =========================================================
   VALUES
   ========================================================= */
.values__grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:18px;
}
.value{
  position:relative;padding:32px 26px;
  background:#fff;border:1px solid var(--line);border-radius:18px;
  transition:all .35s var(--easing);
  overflow:hidden;
  isolation:isolate;
}
.value::after{
  content:"";position:absolute;inset:auto 0 0 0;height:3px;
  background:linear-gradient(90deg,var(--cyan),transparent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--easing);
}
.value:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(0,168,232,.3)}
.value:hover::after{transform:scaleX(1)}
.value__icon{
  width:56px;height:56px;border-radius:16px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--cyan-soft),#fff);
  color:var(--cyan);
  margin-bottom:18px;
  transition:transform .35s var(--easing);
  border:1px solid var(--line);
}
.value:hover .value__icon{transform:rotate(-6deg) scale(1.06);background:linear-gradient(135deg,var(--cyan),#0093cf);color:#fff}
.value h3{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.value p{margin:0;font-size:13.5px;color:var(--ink-2);line-height:1.6}

/* =========================================================
   PROCESS
   ========================================================= */
.process__rail{position:relative;padding:24px 0 32px}
.process__line{
  position:absolute;left:8%;right:8%;top:54px;height:2px;
  background:var(--line);overflow:hidden;border-radius:2px;
  z-index:0;
}
.process__lineFill{
  position:absolute;inset:0;width:0%;
  background:linear-gradient(90deg,var(--cyan),#5fd5ff);
  transition:width 1.2s var(--easing);
}
.process__steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  position:relative;z-index:1;
}
.processStep{
  text-align:center;padding:0 8px;
}
.processStep__node{
  width:96px;height:96px;border-radius:50%;
  margin:0 auto 22px;
  display:grid;place-items:center;
  background:#fff;border:2px solid var(--line);
  font-size:24px;font-weight:800;color:var(--navy);letter-spacing:-.02em;
  transition:all .4s var(--easing);
  position:relative;
}
.processStep.is-active .processStep__node{
  background:linear-gradient(135deg,var(--cyan),#0093cf);
  border-color:var(--cyan);color:#fff;
  box-shadow:0 16px 36px -12px rgba(0,168,232,.6);
  transform:scale(1.05);
}
.processStep h3{margin:0 0 10px;font-size:18px;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.processStep p{margin:0;font-size:13.5px;line-height:1.6;color:var(--ink-2)}

.process__foot{
  margin-top:64px;
  display:flex;align-items:center;justify-content:center;gap:14px;
  padding:18px 28px;
  background:linear-gradient(135deg,#fff,#f0f9f3);
  border:1px solid #d5ecdb;
  border-radius:999px;
  width:fit-content;margin-left:auto;margin-right:auto;
  font-weight:600;color:#1a5d3a;
}
.process__leafBadge{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;
  display:grid;place-items:center;
}

/* =========================================================
   TECH & QA
   ========================================================= */
.techqa__grid{display:grid;grid-template-columns:1fr 1fr 0.85fr;gap:24px}
.techCard{
  padding:36px 32px;border-radius:var(--radius-lg);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  transition:all .35s var(--easing);
}
.techCard:hover{background:rgba(255,255,255,.07);border-color:rgba(0,168,232,.3);transform:translateY(-4px)}
.techCard__head{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.techCard__icon{
  width:48px;height:48px;border-radius:12px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--cyan),#0093cf);color:#fff;
  box-shadow:0 8px 22px -8px rgba(0,168,232,.5);
}
.techCard__head h3{margin:0;font-size:22px;font-weight:700;color:#fff;letter-spacing:-.015em}
.techCard__list{display:flex;flex-direction:column;gap:12px}
.techCard__list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:14.5px;color:rgba(255,255,255,.85);line-height:1.5;
}
.bullet{
  width:8px;height:8px;border-radius:50%;
  background:var(--cyan);flex-shrink:0;margin-top:8px;
  box-shadow:0 0 0 4px rgba(0,168,232,.12);
}

.certCard{
  position:relative;padding:36px 32px;
  border-radius:var(--radius-lg);
  background:linear-gradient(160deg,rgba(0,168,232,.14) 0%, rgba(0,168,232,0) 80%);
  border:1px solid rgba(0,168,232,.25);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;
}
.certCard__rings{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none}
.certCard__ring{
  position:absolute;width:240px;height:240px;border-radius:50%;
  border:1px dashed rgba(0,168,232,.35);
  animation:ringSpin 24s linear infinite;
}
.certCard__ring--2{width:300px;height:300px;border-color:rgba(0,168,232,.22);animation-duration:36s;animation-direction:reverse}
.certCard__ring--3{width:360px;height:360px;border-color:rgba(0,168,232,.12);animation-duration:48s}
@keyframes ringSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.certCard__badges{display:flex;gap:14px;margin-bottom:20px;position:relative;z-index:1;justify-content:flex-start;flex-wrap:wrap}
.certCard__head{position:relative;z-index:1}
.certCard p{position:relative;z-index:1;text-align:left}
.certBadge{
  padding:14px 16px;border-radius:14px;
  background:linear-gradient(135deg,var(--cyan),#0093cf);color:#fff;
  display:flex;flex-direction:column;align-items:center;
  min-width:96px;
  box-shadow:0 14px 32px -10px rgba(0,168,232,.6);
}
.certBadge--alt{background:linear-gradient(135deg,#fff,#e7f3fb);color:var(--navy);box-shadow:0 14px 32px -10px rgba(255,255,255,.3)}
.certBadge__small{font-size:11px;font-weight:600;letter-spacing:.1em;opacity:.85}
.certBadge__big{font-size:20px;font-weight:800;letter-spacing:-.01em;white-space:nowrap}
.certCard p{margin:0;font-size:14px;line-height:1.6;color:rgba(255,255,255,.8);position:relative;z-index:1;max-width:280px}

/* =========================================================
   CONTACT
   ========================================================= */
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.contact__infoHead{margin-bottom:28px}
.contact__infoHead h3{margin:0 0 8px;font-size:24px;font-weight:700;color:var(--navy);letter-spacing:-.015em}
.contact__infoHead p{margin:0;font-size:15px;color:var(--ink-2);line-height:1.65}

.contact__cards{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.contactCard{
  display:flex;align-items:flex-start;gap:14px;
  padding:18px 20px;border-radius:14px;
  background:#fff;border:1px solid var(--line);
  transition:all .3s var(--easing);
}
.contactCard:hover{transform:translateX(4px);border-color:rgba(0,168,232,.3);box-shadow:var(--shadow-sm)}
.contactCard__icon{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--cyan-soft),#fff);
  color:var(--cyan);border:1px solid var(--line);
}
.contactCard__label{font-size:11.5px;font-weight:700;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px}
.contactCard__value{font-size:14.5px;color:var(--navy);font-weight:500;line-height:1.5;display:block}
.contactCard__value--link:hover{color:var(--cyan)}

.contact__hours{padding:20px 22px;border-radius:14px;background:linear-gradient(135deg,#f3f8fc,#fff);border:1px solid var(--line)}
.contact__hoursHead{display:flex;align-items:center;gap:10px;margin-bottom:14px;color:var(--cyan)}
.contact__hoursHead strong{font-size:14px;color:var(--navy);font-weight:700;letter-spacing:.02em}
.contact__hours ul{display:flex;flex-direction:column;gap:8px}
.contact__hours li{display:flex;justify-content:space-between;font-size:13.5px;color:var(--ink-2)}
.contact__hours li b{font-weight:600;color:var(--navy)}
.contact__hours li b.muted{color:#c64242}

.contactForm{
  padding:36px;border-radius:var(--radius-lg);
  background:#fff;border:1px solid var(--line);
  box-shadow:0 24px 48px -24px rgba(26,43,76,.16);
  display:flex;flex-direction:column;gap:18px;
}
.contactForm__row{display:grid;gap:18px}
.contactForm__row--2{grid-template-columns:1fr 1fr}
.field{position:relative;display:block}
.field__label{
  position:absolute;left:16px;top:16px;
  font-size:14px;color:var(--muted);font-weight:500;
  pointer-events:none;
  transition:all .25s var(--easing);
  background:#fff;padding:0 4px;
}
.field__label em{color:#dc3a3a;font-style:normal;margin-left:2px}
.field input,.field textarea{
  width:100%;padding:18px 16px;
  font:inherit;font-size:14.5px;color:var(--navy);
  background:#fff;border:1.5px solid var(--line);border-radius:12px;
  outline:none;transition:all .25s var(--easing);
  resize:vertical;
  font-family:inherit;
}
.field textarea{min-height:120px;line-height:1.5}
.field input:focus,.field textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 4px rgba(0,168,232,.12)}
.field input:focus + .field__label,
.field textarea:focus + .field__label,
.field input:not(:placeholder-shown) + .field__label,
.field textarea:not(:placeholder-shown) + .field__label{
  top:-8px;font-size:11.5px;color:var(--cyan);font-weight:600;letter-spacing:.02em;
}

/* Map embed */
.contactMap{
  margin:56px auto 0;
  max-width:780px;
  border-radius:var(--radius-lg);
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.contactMap__head{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:22px 28px;
  border-bottom:1px solid var(--line);
  background:linear-gradient(135deg,#fff,#f4faff);
}
.contactMap__heading h3{
  margin:6px 0 4px;font-size:20px;font-weight:700;
  color:var(--navy);letter-spacing:-.015em;
}
.contactMap__heading p{margin:0;font-size:13.5px;color:var(--ink-2);max-width:560px}
.contactMap__cta{flex:none;font-size:13px;padding:10px 18px}
.contactMap__cta svg{transition:transform .25s var(--easing)}
.contactMap__cta:hover svg{transform:translate(2px,-2px)}
.contactMap__frame{
  position:relative;height:300px;
  background:#eef4f8;
}
.contactMap__frame iframe{
  width:100%;height:100%;border:0;display:block;
  filter:grayscale(.12) contrast(1.02);
}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  position:relative;
  background:linear-gradient(180deg,#0f1c36 0%, #0a1228 100%);
  color:rgba(255,255,255,.8);
  padding:80px 0 32px;
  overflow:hidden;
}
.footer__pattern{
  position:absolute;inset:0;opacity:.4;pointer-events:none;
  background:
    radial-gradient(circle at 15% 20%, rgba(0,168,232,.18), transparent 35%),
    radial-gradient(circle at 85% 80%, rgba(0,168,232,.10), transparent 40%);
}
.footer__grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__brand{max-width:340px}
.footer__logo{display:inline-block;margin-bottom:18px}
.footer__logoImg{
  height:56px;width:auto;display:block;
  /* Convert dark navy logo to white on dark footer */
  filter:brightness(0) invert(1);
}
.footer__brand p{margin:0 0 22px;font-size:14px;line-height:1.7;color:rgba(255,255,255,.65)}
.footer__socials{display:flex;gap:10px}
.footer__social{
  width:38px;height:38px;border-radius:10px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.75);
  border:1px solid rgba(255,255,255,.08);
  transition:all .25s var(--easing);
}
.footer__social:hover{background:var(--cyan);color:#fff;transform:translateY(-2px);box-shadow:0 8px 18px -6px rgba(0,168,232,.5);border-color:var(--cyan)}

.footer__col h4{margin:0 0 18px;font-size:14px;font-weight:700;color:#fff;letter-spacing:.04em;text-transform:uppercase}
.footer__col ul{display:flex;flex-direction:column;gap:10px}
.footer__col li a{font-size:14px;color:rgba(255,255,255,.65);transition:all .25s var(--easing);position:relative;padding-left:0}
.footer__col li a:hover{color:var(--cyan);padding-left:6px}

.footer__contact li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:rgba(255,255,255,.7);line-height:1.55}
.footer__contact svg{color:var(--cyan);flex-shrink:0;margin-top:4px}
.footer__contact a:hover{color:var(--cyan)}

.footer__bot{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  padding-top:28px;
  font-size:13px;color:rgba(255,255,255,.5);
}
.footer__botLinks{display:flex;gap:24px}
.footer__botLinks a{transition:color .25s ease}
.footer__botLinks a:hover{color:var(--cyan)}

/* =========================================================
   MODAL
   ========================================================= */
.modal{
  position:fixed;inset:0;z-index:300;
  display:none;align-items:center;justify-content:center;
  padding:20px;
}
.modal.is-open{display:flex;animation:modalFade .3s ease}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.modal__backdrop{position:absolute;inset:0;background:rgba(15,28,54,.7);backdrop-filter:blur(8px)}
.modal__panel{
  position:relative;width:100%;max-width:920px;max-height:92vh;overflow:hidden;
  background:#fff;border-radius:var(--radius-lg);
  box-shadow:0 40px 80px -20px rgba(0,0,0,.5);
  display:flex;flex-direction:column;
  animation:modalSlide .4s var(--easing);
}
@keyframes modalSlide{from{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}
.modal__close{
  position:absolute;top:16px;right:16px;z-index:5;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.9);backdrop-filter:blur(6px);
  display:grid;place-items:center;color:var(--navy);
  box-shadow:0 4px 12px rgba(0,0,0,.15);
  transition:transform .2s ease, background .2s ease;
}
.modal__close:hover{background:var(--navy);color:#fff;transform:rotate(90deg)}
.modal__body{overflow-y:auto;display:flex;flex-direction:column}

.mHero{position:relative;height:280px;overflow:hidden}
.mHero img{width:100%;height:100%;object-fit:cover}
.mHero__shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,28,54,.85) 0%, transparent 60%)}
.mHero__copy{position:absolute;bottom:24px;left:32px;right:32px;color:#fff}
.mHero__copy h3{margin:0 0 6px;font-size:30px;font-weight:800;letter-spacing:-.02em}
.mHero__copy p{margin:0;font-size:15px;color:rgba(255,255,255,.85)}

.mBody{padding:32px 36px 36px;display:flex;flex-direction:column;gap:28px}
.mBody p.lede{font-size:15px;line-height:1.7;color:var(--ink-2);margin:0}

.mGroup h4{margin:0 0 16px;font-size:15px;font-weight:700;color:var(--navy);letter-spacing:.02em;text-transform:uppercase}
.mFeatures{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}
.mFeatures li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-2);line-height:1.5}
.mFeatures svg{flex-shrink:0;color:var(--cyan);margin-top:2px}

.mTwoCol{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.mTags{display:flex;flex-wrap:wrap;gap:6px}
.mTag{font-size:13px;padding:6px 12px;border-radius:8px;background:#f0f6fb;color:var(--navy);font-weight:500}

.mMats{display:flex;flex-direction:column;gap:10px}
.mMat{padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:#fff}
.mMat__name{font-size:13.5px;font-weight:700;color:var(--navy)}
.mMat__desc{font-size:12.5px;color:var(--muted);margin-top:2px}

.mWhy{display:flex;flex-direction:column;gap:10px}
.mWhy li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-2);line-height:1.5}
.mWhy span{flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--cyan);margin-top:8px}

.mFaqs{display:flex;flex-direction:column;gap:8px}
.mFaq{padding:14px 16px;border-radius:10px;background:#f7fafc;border:1px solid var(--line)}
.mFaq__q{font-size:13.5px;font-weight:700;color:var(--navy);margin-bottom:3px}
.mFaq__a{font-size:13.5px;color:var(--ink-2);line-height:1.5}

.mCase{padding:18px 20px;border-radius:14px;background:linear-gradient(135deg,#e7f5fc,#fff);border:1px solid rgba(0,168,232,.2)}
.mCase__label{font-size:11px;font-weight:700;color:var(--cyan);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.mCase__brand{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:6px}
.mCase__desc{font-size:13.5px;color:var(--ink-2);line-height:1.6;margin:0}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1080px){
  .nav__inner{padding:14px 20px;gap:14px}
  .nav__logo{height:38px}
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav.is-menu .nav__links{
    display:flex;flex-direction:column;gap:4px;align-items:stretch;
    position:absolute;top:calc(100% + 8px);right:20px;left:20px;
    background:#fff;border-radius:18px;padding:14px;
    box-shadow:0 24px 48px -16px rgba(26,43,76,.22);
  }
  .nav.is-menu .nav__links a::after{display:none}
  .hero__inner{grid-template-columns:1fr;gap:48px;text-align:center}
  .hero__left{display:flex;flex-direction:column;align-items:center}
  .hero__title{justify-content:center}
  .hero__lede{margin-left:auto;margin-right:auto}
  .hero__ctas{justify-content:center}
  .hero__stats{margin:0 auto}
  .hero__stage{max-width:440px}
  .products{grid-template-columns:repeat(2,1fr)}
  .industries{grid-template-columns:repeat(2,1fr)}
  .values__grid{grid-template-columns:repeat(3,1fr)}
  .process__steps{grid-template-columns:repeat(2,1fr);gap:48px}
  .process__line{display:none}
  .techqa__grid{grid-template-columns:1fr 1fr}
  .certCard{grid-column:span 2}
  .reach__grid{grid-template-columns:1fr}
  .about__grid{grid-template-columns:1fr;gap:36px}
  .about__stats{position:static}
  .contact__grid{grid-template-columns:1fr;gap:32px}
  .contactMap{margin-top:36px}
  .contactMap__head{flex-direction:column;align-items:flex-start;gap:14px;padding:20px 22px}
  .contactMap__frame{height:260px}
  .footer__grid{grid-template-columns:1fr 1fr;gap:36px}
  .journey__line{left:20px;transform:none}
  .journeyItem{grid-template-columns:50px 1fr;gap:18px}
  .journeyItem--left .journeyItem__card,.journeyItem--right .journeyItem__card{grid-column:2;text-align:left}
  .journeyItem--left .journeyItem__node,.journeyItem--right .journeyItem__node{grid-column:1;width:46px;height:46px;font-size:13px}
  .journeyItem__spacer{display:none}
}

@media (max-width: 760px){
  .nav__inner{padding:12px 16px;gap:10px}
  .nav__logo{height:34px}
  /* Hide the "Contact Us" header CTA on small screens — Contact lives in the burger menu */
  .nav__cta{display:none}
}

@media (max-width: 640px){
  .wrap{padding:0 18px}
  .section{padding:72px 0}
  .sectionHead{margin-bottom:44px}
  .sectionHead h2{font-size:30px}
  .sectionHead p{font-size:15px}

  /* Nav */
  .nav__logo{height:30px}
  .nav__burger{width:38px;height:38px}

  /* Hero */
  .hero{min-height:auto;padding-top:96px;padding-bottom:56px}
  .hero__inner{gap:36px}
  .hero__eyebrow{font-size:11.5px;padding:6px 14px 6px 10px;gap:8px;text-align:left;max-width:100%}
  .hero__dot{width:6px;height:6px;flex-shrink:0}
  .hero__title{font-size:38px}
  .hero__lede{font-size:16px}
  .hero__stats{gap:14px;padding:16px 18px;border-radius:14px}
  .hero__statDivider{display:none}
  .hero__statNum{font-size:26px}
  .hero__statLabel{font-size:11.5px}
  .hero__stage{max-width:88vw}
  .hero__floatCard--top{left:2%;padding:8px 12px}
  .hero__floatCard--bot{right:2%;padding:8px 12px}
  .hero__floatCard--botleft{left:2%;padding:8px 12px}
  .hero__floatCard--side{font-size:11px;right:2%;padding:8px 12px}
  .hero__floatTitle{font-size:12.5px}
  .hero__floatSub{font-size:10px}
  .hero__floatBadge{width:32px;height:32px;border-radius:9px}
  .hero__scrollHint{display:none}

  /* Section grids → single column */
  .products,.industries,.values__grid,.process__steps{grid-template-columns:1fr;gap:18px}
  .techqa__grid{grid-template-columns:1fr;gap:18px}
  .certCard{grid-column:span 1;padding:32px 22px}
  .certCard__ring{width:200px;height:200px}
  .certCard__ring--2{width:250px;height:250px}
  .certCard__ring--3{width:300px;height:300px}
  .certBadge{padding:12px 14px;min-width:88px}
  .certBadge__big{font-size:20px}

  /* Trusted brands */
  .about__trusted{padding:28px 20px;border-radius:18px}
  .about__trustedRow{justify-content:center;gap:22px 28px}
  .about__trustedRow img{height:54px}
  .about__trustedLabel{font-size:13px;gap:10px;margin-bottom:24px;line-height:1.4}
  .about__trustedLabel::before,.about__trustedLabel::after{flex-basis:24px}

  /* Marquee row */
  .marquee{padding:24px 0 28px}
  .marquee__row{gap:56px}
  .marquee__row img{height:56px;max-width:120px}
  .marquee__label{font-size:10.5px;margin-bottom:18px;padding:0 18px;line-height:1.5}

  /* Process */
  .processStep__node{width:80px;height:80px;font-size:20px;margin-bottom:16px}
  .process__rail{padding:8px 0 16px}
  .process__foot{margin-top:36px;padding:14px 22px;font-size:14px;text-align:center;flex-wrap:wrap}

  /* Tech / QA cards */
  .techCard{padding:28px 22px}
  .techCard__head h3{font-size:20px}
  .techCard__list li{font-size:13.5px}

  /* About */
  .about__grid{gap:28px}
  .about__copy h3{font-size:22px}
  .about__copy p{font-size:14.5px}
  .about__stats{grid-template-columns:1fr 1fr;gap:12px}
  .aboutStat{padding:22px 18px;border-radius:14px}
  .aboutStat__num{font-size:34px}

  /* Journey */
  .journey{padding:32px 0 16px}
  .journey__head h3{font-size:24px}
  .journey__head{margin-bottom:40px}
  .journeyItem__card{padding:18px 20px}
  .journeyItem__title{font-size:15.5px}
  .journeyItem__desc{font-size:13px}

  /* Industries section padding */
  .industry{padding:26px 22px}
  .industry h3{font-size:18px}
  .industry p{font-size:13.5px}

  /* Products */
  .product__body{padding:20px 18px 20px}
  .product__title{font-size:18px}

  /* Reach map */
  .reach__map{aspect-ratio:1055/1491}
  .reach__pinLabel{font-size:10.5px;padding:4px 8px}
  .reach__pinLabel em{font-size:9px;padding:1px 5px;margin-right:5px}
  .reach__pinDot{width:9px;height:9px}
  .reach__pin--hq .reach__pinDot{width:12px;height:12px}
  .reach__grid{gap:28px}
  .reach__country{padding:12px 14px;gap:12px}
  .reach__country img{width:32px;height:22px}
  .reach__country strong{font-size:14px}
  .reach__country span{font-size:11.5px}

  /* Contact */
  .contact__infoHead h3{font-size:20px}
  .contact__infoHead p{font-size:14px}
  .contactCard{padding:14px 16px;gap:12px}
  .contactCard__icon{width:38px;height:38px}
  .contactCard__value{font-size:13.5px}
  .contact__hours{padding:18px 20px}
  .contact__hours li{font-size:13px}
  .contactForm{padding:22px;border-radius:18px}
  .contactForm__row--2{grid-template-columns:1fr}
  .field input,.field textarea{padding:16px 14px;font-size:14px}

  /* Footer */
  .footer{padding:60px 0 24px}
  .footer__grid{grid-template-columns:1fr;gap:32px;padding-bottom:32px}
  .footer__brand{max-width:none}
  .footer__logoImg{height:48px}
  .footer__col h4{font-size:13px;margin-bottom:14px}
  .footer__col li a,.footer__contact li{font-size:13.5px}
  .footer__bot{flex-direction:column;align-items:flex-start;gap:10px;font-size:12.5px}
  .footer__botLinks{gap:18px}

  /* Modal */
  .mTwoCol,.mFeatures{grid-template-columns:1fr}
  .mBody{padding:22px}
  .modal__panel{max-height:96vh;border-radius:18px}
  .mHero{height:200px}
  .mHero__copy{left:22px;right:22px;bottom:18px}
  .mHero__copy h3{font-size:22px}
  .mHero__copy p{font-size:13.5px}

  /* Buttons */
  .btn{padding:13px 22px;font-size:14.5px}
}

@media (max-width: 420px){
  .wrap{padding:0 14px}
  .nav__inner{padding:10px 12px}
  .nav__logo{height:28px}
  .hero__eyebrow{font-size:10.5px;padding:5px 12px 5px 8px;gap:6px;border-radius:12px}
  .hero__title{font-size:32px}
  .hero__lede{font-size:15px}
  .hero__stats{flex-wrap:nowrap;justify-content:space-around;padding:14px 12px;gap:8px}
  .hero__statNum{font-size:22px}
  .hero__statLabel{font-size:10.5px}
  .hero__floatCard--top,.hero__floatCard--bot,.hero__floatCard--botleft{padding:6px 10px}
  .hero__floatTitle{font-size:11.5px}
  .hero__floatSub{font-size:9.5px}
  .hero__floatBadge{width:28px;height:28px}
  .hero__floatCard--side{display:none}

  .about__trustedRow{gap:18px 22px}
  .about__trustedRow img{height:44px}

  .marquee__row{gap:40px}
  .marquee__row img{height:46px;max-width:100px}

  .certBadge{padding:10px 12px;min-width:78px}
  .certBadge__small{font-size:10px}
  .certBadge__big{font-size:17px}
}

/* =========================================================
   MOBILE QUICK-CALL FAB
   ========================================================= */
.mobileFab{
  display:none;
  position:fixed;bottom:24px;right:24px;z-index:90;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--cyan),#0093cf);color:#fff;
  place-items:center;
  box-shadow:0 12px 28px -8px rgba(0,168,232,.6), 0 0 0 0 rgba(0,168,232,.4);
  animation:fabPulse 2.5s ease-in-out infinite;
  transition:transform .25s var(--easing);
}
.mobileFab:hover,.mobileFab:active{transform:scale(1.08)}
@keyframes fabPulse{
  0%,100%{box-shadow:0 12px 28px -8px rgba(0,168,232,.6), 0 0 0 0 rgba(0,168,232,.4)}
  50%{box-shadow:0 12px 28px -8px rgba(0,168,232,.6), 0 0 0 12px rgba(0,168,232,0)}
}
@media (max-width: 760px){
  .mobileFab{display:grid}
}
@supports (padding: max(0px)){
  .mobileFab{bottom:max(24px, calc(env(safe-area-inset-bottom) + 12px));right:max(24px, env(safe-area-inset-right))}
}

/* =========================================================
   MOBILE TOUCH & INTERACTION IMPROVEMENTS
   ========================================================= */

/* Ensure tap targets are at least 44px for accessibility */
@media (pointer: coarse){
  .nav__links a{min-height:44px;display:flex;align-items:center}
  .footer__col li a{min-height:40px;display:inline-flex;align-items:center}
  .footer__social{width:44px;height:44px}
  .contactCard{min-height:44px}
  .reach__country{min-height:48px}
}

/* Prevent 300ms tap delay on mobile */
a,button,input,textarea,select{touch-action:manipulation}

/* Disable hover effects on touch devices to prevent sticky hover states */
@media (hover: none){
  .product:hover{transform:none;box-shadow:var(--shadow-sm)}
  .product:hover .product__media img{transform:none}
  .product:hover .product__overlay{opacity:0}
  .industry:hover{transform:none;background:rgba(255,255,255,.04)}
  .value:hover{transform:none;box-shadow:none}
  .contactCard:hover{transform:none}
  .reach__country:hover{transform:none}
  .marquee__row img:hover{filter:grayscale(1) contrast(.95);opacity:.62;transform:none}
}

/* Safe area insets for notched phones */
@supports (padding: max(0px)){
  .nav__inner{padding-left:max(20px, env(safe-area-inset-left));padding-right:max(20px, env(safe-area-inset-right))}
  .footer .wrap{padding-bottom:max(32px, env(safe-area-inset-bottom))}
}

/* Improve scrolling performance */
.modal__body{-webkit-overflow-scrolling:touch}
.marquee__row{will-change:transform}

/* Fix iOS input zoom (font-size must be >= 16px) */
@media (max-width: 640px){
  .field input,.field textarea{font-size:16px}
}
