/* ─────────────────────────────────────────────
   TOKENS, light brand
───────────────────────────────────────────── */
:root {
  --blue:       #243c8f;
  --blue-dark:  #1a2d6e;
  --blue-deep:  #0f1d52;
  --teal:       #70C3C5;
  --teal-light: #e6f6f6;
  --teal-mid:   rgba(112,195,197,.18);
  --grad:       linear-gradient(135deg,#243c8f 0%,#70C3C5 100%);
  --grad-soft:  linear-gradient(135deg,rgba(36,60,143,.07) 0%,rgba(112,195,197,.07) 100%);

  --bg:         #ffffff;
  --bg2:        #f5f8ff;
  --bg3:        #eef2fb;

  --ink:        #080f2e;
  --body:       #3d4f7a;
  --muted:      #7a8db5;
  --dim:        #b0bed8;
  --border:     #dde6f5;
  --border-light:#edf0f8;

  --shadow-xs:  0 1px 3px rgba(36,60,143,.06),0 1px 2px rgba(36,60,143,.04);
  --shadow-sm:  0 4px 12px rgba(36,60,143,.06),0 2px 6px rgba(36,60,143,.04);
  --shadow-md:  0 12px 32px rgba(36,60,143,.1),0 4px 12px rgba(36,60,143,.06);
  --shadow-lg:  0 24px 64px rgba(36,60,143,.14),0 8px 24px rgba(36,60,143,.08);

  --r:          12px;
  --rlg:        20px;
  --rxl:        28px;
  --pill:       999px;
  --ease:       cubic-bezier(.25,.46,.45,.94);
  --snap:       cubic-bezier(.76,0,.24,1);
  --w:          1200px;
}

/* ─────────────────────────────────────────────
   RESET
───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;background:var(--bg);scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg);color:var(--body);
  line-height:1.65;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}


/* ─────────────────────────────────────────────
   PRELOADER
───────────────────────────────────────────── */
#preloader{
  position:fixed;inset:0;z-index:9000;
  background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2rem;
  transition:opacity .7s var(--ease),visibility .7s;
}
#preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.pre-eyebrow{
  font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  color:var(--teal);opacity:0;animation:fadeUp .5s .1s var(--ease) forwards;
}
.pre-num{
  font-size:5.5rem;font-weight:700;letter-spacing:-.06em;line-height:1;
  padding-right:.06em;
  background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}
.pre-track{
  width:220px;height:1px;background:var(--border);overflow:hidden;border-radius:1px;
}
.pre-fill{height:100%;background:var(--grad);width:0%;transition:width .05s linear}

/* ─────────────────────────────────────────────
   SCROLL PROGRESS
───────────────────────────────────────────── */
#progress{
  position:fixed;top:0;left:0;right:0;z-index:8000;
  height:2px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:transform .08s linear;
}

/* ─────────────────────────────────────────────
   UTILITIES
───────────────────────────────────────────── */
.container{max-width:var(--w);margin:0 auto;padding:0 2.5rem}
.grad-text{
  background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}
.section-tag{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  color:var(--teal);margin-bottom:1.25rem;
}
.section-tag::before{content:'';width:18px;height:1.5px;background:var(--teal)}

/* Split-text spans, set by HTML, animated by CSS + JS */
.split-word{overflow:hidden;display:inline-block;vertical-align:bottom}
.split-inner{
  display:inline-block;
  transform:translateY(110%);
  transition:transform 1s var(--snap);
}
.hero-ready .split-inner{transform:translateY(0)}

/* ─────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem;padding:.875rem 2rem;border-radius:var(--pill);
  font-size:.9375rem;font-weight:500;cursor:pointer;
  border:1.5px solid transparent;transition:all .28s var(--ease);
  white-space:nowrap;font-family:inherit;position:relative;overflow:hidden;
  -webkit-transform:translateZ(0);transform:translateZ(0);
  -webkit-backface-visibility:hidden;backface-visibility:hidden;
}
.btn-primary{
  background:var(--grad);color:#fff;
  border:none;padding:.875rem 2rem;
  overflow:visible;
  clip-path:inset(0 round 999px);
}
.btn-primary.btn-xl{padding:1rem 2.5rem}
.btn-primary:hover{
  opacity:.88;transform:translateY(-2px);
  filter:drop-shadow(0 10px 24px rgba(36,60,143,.32));
}
.btn-outline{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-outline:hover{background:var(--bg3);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--body);border-color:var(--border)}
.btn-ghost:hover{background:var(--bg2);color:var(--blue);border-color:var(--border)}
.btn-white{
  background:#fff;color:var(--blue);font-weight:500;
  border:none;padding:.875rem 2rem;
  clip-path:inset(0 round 999px);
}
.btn-white.btn-xl{padding:1rem 2.5rem}
.btn-white:hover{background:var(--teal-light);transform:translateY(-2px);filter:drop-shadow(0 8px 20px rgba(0,0,0,.14))}
.btn-outline-white{
  background:transparent;color:#fff;
  border:1.5px solid rgba(255,255,255,.5);
  clip-path:inset(0 round 999px);
}
.btn-outline-white:hover{border-color:rgba(255,255,255,.9);background:rgba(255,255,255,.1)}
.btn-xl{padding:1rem 2.5rem;font-size:1rem}
.logo-img{height:38px;width:auto;display:block}
.footer__logo-pill{display:inline-flex;background:#fff;border-radius:10px;padding:7px 14px;margin-bottom:1.25rem;transition:opacity .2s}
.footer__logo-pill:hover{opacity:.88}
.logo-img--footer{height:30px;width:auto;display:block}

/* ─────────────────────────────────────────────
   NAV
───────────────────────────────────────────── */
.header{
  position:fixed;top:0;left:0;right:0;z-index:7000;
  padding:.875rem 0;
  transition:background .35s var(--ease),box-shadow .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.header.scrolled{
  background:rgba(255,255,255,.94);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom-color:var(--border-light);box-shadow:var(--shadow-sm);
}
.nav{display:flex;align-items:center;height:50px;gap:.5rem}
.nav__links{display:flex;list-style:none;gap:.125rem;margin-left:auto}
.nav__links a{
  display:block;padding:.5rem .875rem;color:var(--muted);
  font-size:.875rem;font-weight:500;border-radius:8px;
  transition:color .2s,background .2s;
}
.nav__links a:hover,.nav__links a.active{color:var(--blue);background:rgba(36,60,143,.05)}
.nav__links a.active{font-weight:600}
.nav__actions{display:flex;align-items:center;gap:.625rem;margin-left:1.5rem}
.nav__cta{padding:.55rem 1.25rem;font-size:.875rem}
.nav__hamburger{
  display:none;flex-direction:column;gap:5px;background:none;
  border:none;cursor:pointer;padding:.5rem;margin-left:auto;
}
.nav__hamburger span{
  display:block;width:22px;height:1.5px;background:var(--blue);
  border-radius:2px;transition:.28s var(--ease);
}
.nav__hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav__hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ─────────────────────────────────────────────
   HERO, full-height, light, Apple-style
───────────────────────────────────────────── */
.hero{
  display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;
  position:relative;padding:8rem 0 3.5rem;
  background:var(--bg);
}

/* Subtle radial light */
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 75% 60% at 50% -5%,rgba(36,60,143,.06) 0%,transparent 65%),
    radial-gradient(ellipse 50% 50% at 85% 90%,rgba(112,195,197,.07) 0%,transparent 55%),
    radial-gradient(ellipse 40% 40% at 10% 70%,rgba(36,60,143,.04) 0%,transparent 55%);
}

/* Very faint dot grid */
.hero__grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(36,60,143,.08) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 30%,transparent 100%);
}

/* Mouse-follow glow */
.hero__glow{
  position:absolute;width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(112,195,197,.09) 0%,transparent 68%);
  pointer-events:none;transform:translate(-50%,-50%);
  top:50%;left:50%;transition:left .9s var(--ease),top .9s var(--ease);
}

.hero__inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}

/* Announcement chip, animates in after preloader */
.hero__chip{
  display:inline-flex;align-items:center;gap:.625rem;
  background:rgba(36,60,143,.06);border:1px solid rgba(36,60,143,.12);
  padding:.45rem 1.1rem;border-radius:var(--pill);
  font-size:.78rem;font-weight:600;color:var(--blue);
  letter-spacing:.03em;margin-bottom:1.5rem;
  opacity:0;transform:translateY(14px);
  transition:opacity .7s .1s var(--ease),transform .7s .1s var(--ease);
}
.hero-ready .hero__chip{opacity:1;transform:translateY(0)}
.hero__chip-dot{
  width:7px;height:7px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 0 var(--teal);
  animation:chipPulse 2.2s ease-in-out infinite;
}
@keyframes chipPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(112,195,197,.5)}
  50%{box-shadow:0 0 0 5px rgba(112,195,197,0)}
}

.hero__title{
  font-size:clamp(2rem,4.5vw,5rem);font-weight:700;
  line-height:1.1;letter-spacing:-.055em;
  color:var(--ink);max-width:1050px;margin-bottom:1.5rem;overflow:visible;padding-bottom:.1em;
  opacity:0;transform:translateY(18px);
  transition:opacity .7s .2s var(--ease),transform .7s .2s var(--ease);
}
.hero-ready .hero__title{opacity:1;transform:translateY(0)}
.hero__title em{font-style:normal;display:block;padding-bottom:.18em;overflow:visible}

.hero__sub{font-size:.975rem;
  font-size:clamp(.95rem,1.6vw,1.05rem);color:var(--muted);
  line-height:1.72;max-width:660px;margin-bottom:3rem;
  opacity:0;transform:translateY(16px);
  transition:opacity .7s .4s var(--ease),transform .7s .4s var(--ease);
}
.hero-ready .hero__sub{font-size:.975rem;opacity:1;transform:translateY(0)}

.hero__ctas{
  display:flex;gap:.875rem;flex-wrap:wrap;justify-content:center;
  margin-bottom:3.5rem;
  opacity:0;transform:translateY(16px);
  transition:opacity .7s .55s var(--ease),transform .7s .55s var(--ease);
}
.hero-ready .hero__ctas{opacity:1;transform:translateY(0)}

/* Proof row */
.hero__proof{
  display:flex;align-items:center;gap:.875rem;justify-content:center;
  font-size:.82rem;color:var(--dim);font-weight:500;
  opacity:0;transition:opacity .7s .7s var(--ease);
}
.hero-ready .hero__proof{opacity:1}
.hero__avatars{display:flex;align-items:center}
.hero__av{
  width:30px;height:30px;border-radius:50%;
  border:2px solid #fff;box-shadow:var(--shadow-xs);margin-left:-8px;
}
.hero__av:first-child{margin-left:0}
.hero__av--1{background:linear-gradient(135deg,#243c8f,#70C3C5)}
.hero__av--2{background:linear-gradient(135deg,#70C3C5,#4a7fd4)}
.hero__av--3{background:linear-gradient(135deg,#1a2d6e,#70C3C5)}
.hero__proof strong{color:var(--blue)}

.hero__scroll{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.625rem;
  color:var(--dim);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  opacity:0;transition:opacity .7s .9s var(--ease);
}
.hero-ready .hero__scroll{opacity:1}
.hero__scroll-line{
  width:1px;height:44px;
  background:linear-gradient(to bottom,var(--border),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.55)}}



/* ─────────────────────────────────────────────
   SECTION COMMONS
───────────────────────────────────────────── */
section{padding:4rem 0}
h2.section-h{
  font-size:clamp(2rem,4.5vw,3.75rem);font-weight:600;
  line-height:1.08;letter-spacing:-.04em;color:var(--ink);
  margin-bottom:1.25rem;
}
p.section-p{font-size:1.05rem;color:var(--muted);line-height:1.78}


/* ── LOGO CLOUD ── */
.logos{
  padding:2.5rem 0;
  background:var(--bg2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.logos__label{
  text-align:center;font-size:.975rem;font-weight:600;
  letter-spacing:-.02em;text-transform:none;
  color:var(--ink);opacity:.7;margin-bottom:1.5rem;
}
.logos__marquee{
  display:flex;justify-content:center;user-select:none;
}
.logos__track{
  display:flex;align-items:center;justify-content:center;gap:0;
  white-space:nowrap;
}
.logos__track:hover{animation-play-state:paused}
@keyframes logoScroll{from{transform:translateX(0)}to{transform:translateX(0)}}
@keyframes logoRun{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-item.logo-dup{display:none}
.logo-item{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.75rem 4.5rem;
  font-size:.975rem;font-weight:600;letter-spacing:-.02em;
  color:var(--ink);opacity:.7;
  transition:opacity .22s;
  white-space:nowrap;
  border-right:1px solid var(--border);
}
.logo-item:last-child{border-right:none}
.logo-item:hover{opacity:.85}

/* ─────────────────────────────────────────────
   ABOUT
───────────────────────────────────────────── */
.about{background:var(--bg2)}
.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}

/* Dashboard */
.about__vis{position:relative}
.engage-card{
  background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rxl);
  box-shadow:var(--shadow-lg);overflow:hidden;
  transform:perspective(1200px) rotateY(-4deg) rotateX(2deg);
  transition:transform .6s var(--ease);
}
.about__vis:hover .engage-card{transform:perspective(1200px) rotateY(0) rotateX(0)}
.engage-card__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:.875rem 1.5rem;background:var(--bg2);border-bottom:1px solid var(--border);
}
.engage-card__label{font-size:.78rem;font-weight:600;color:var(--muted)}
.engage-live{display:flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:500;color:#16a34a}
.engage-live__dot{width:7px;height:7px;border-radius:50%;background:#16a34a;animation:pulse 1.8s ease-in-out infinite}
.engage-card__rows{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}
.engage-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.875rem 1rem;border-radius:var(--r);background:var(--bg2);
  border:1px solid var(--border-light);transition:border-color .2s,box-shadow .2s}
.engage-row:hover{border-color:rgba(112,195,197,.35);box-shadow:var(--shadow-xs)}
.engage-row__left{display:flex;flex-direction:column;gap:.2rem}
.engage-row__co{font-size:.85rem;font-weight:600;color:var(--ink)}
.engage-row__type{font-size:.75rem;color:var(--muted)}
.engage-badge{font-size:.68rem;font-weight:600;letter-spacing:.04em;
  padding:.25rem .65rem;border-radius:var(--pill);white-space:nowrap;flex-shrink:0}
.engage-badge--active{background:rgba(22,163,74,.1);color:#16a34a}
.engage-badge--pipeline{background:rgba(36,60,143,.1);color:var(--blue)}
.engage-badge--closed{background:rgba(112,195,197,.15);color:var(--teal)}
.engage-card__foot{
  display:flex;align-items:center;gap:.5rem;
  padding:.875rem 1.5rem;font-size:.75rem;font-weight:500;color:var(--dim);
  background:var(--bg2);border-top:1px solid var(--border);
}
.float-badge{
  position:absolute;bottom:-1.25rem;right:-1.25rem;
  background:var(--bg);border:1.5px solid var(--border);border-radius:16px;
  padding:.875rem 1.25rem;display:flex;align-items:center;gap:.625rem;
  font-size:.82rem;font-weight:500;color:var(--ink);box-shadow:var(--shadow-md);
  animation:floatY 4s ease-in-out infinite;
}
.float-badge__icon{
  width:30px;height:30px;border-radius:9px;
  background:var(--teal-light);border:1px solid rgba(112,195,197,.3);
  display:flex;align-items:center;justify-content:center;color:var(--blue);flex-shrink:0;
}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* Text side */
.about__text .section-tag{display:block}
.about__text .section-h{margin-bottom:1rem}
.about__text .section-p{margin-bottom:1.5rem}
.checklist{list-style:none;display:flex;flex-direction:column;gap:.75rem;margin:1.5rem 0 2.25rem}
.checklist li{display:flex;align-items:center;gap:.75rem;font-size:.9375rem;font-weight:500;color:var(--body)}
.check-icon{
  width:22px;height:22px;border-radius:50%;flex-shrink:0;
  background:var(--teal-light);border:1px solid rgba(112,195,197,.3);
  display:flex;align-items:center;justify-content:center;
}

/* ─────────────────────────────────────────────
   STATS
───────────────────────────────────────────── */
.stats{background:var(--bg);padding:3rem 0}
.stats__grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);
  border:1.5px solid var(--border);border-radius:var(--rlg);overflow:hidden;
}
.stat-block{
  background:var(--bg);padding:3.25rem 2rem;text-align:center;
  transition:background .28s var(--ease),transform .28s var(--ease),box-shadow .28s var(--ease);
}
.stat-block:hover{background:var(--bg2);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.stat-block__n{
  font-size:clamp(2.25rem,3.5vw,3.5rem);font-weight:700;
  letter-spacing:-.055em;line-height:1;
  background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  display:block;margin-bottom:.5rem;
}
.stat-block__l{font-size:.82rem;font-weight:500;color:var(--dim)}

/* ─────────────────────────────────────────────
   SERVICES, light grid
───────────────────────────────────────────── */
.services{background:var(--bg2)}
.services__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:2.5rem;flex-wrap:wrap;gap:1.5rem;
}
.services__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5px;background:var(--border);
  border:1.5px solid var(--border);border-radius:var(--rlg);overflow:hidden;
}
.svc{
  background:var(--bg);padding:2.75rem;display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:background .3s var(--ease);
}
.svc::before{
  content:'';position:absolute;inset:0;
  background:var(--grad-soft);opacity:0;transition:opacity .4s var(--ease);
}
.svc:hover::before{opacity:1}
.svc:hover{background:var(--bg2)}
.svc__num{
  font-size:.72rem;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--dim);margin-bottom:1.75rem;
}
.svc__icon{
  width:50px;height:50px;border-radius:var(--r);
  background:var(--teal-light);border:1.5px solid rgba(112,195,197,.28);
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);margin-bottom:1.5rem;position:relative;z-index:1;
  transition:transform .28s var(--ease),border-color .28s,background .28s;
}
.svc:hover .svc__icon{transform:scale(1.08) rotate(-4deg);border-color:rgba(112,195,197,.5);background:rgba(112,195,197,.12)}
.svc h3{font-size:1.15rem;font-weight:600;color:var(--ink);margin-bottom:.7rem;position:relative;z-index:1}
.svc p{font-size:.9rem;color:var(--muted);line-height:1.75;flex:1;margin-bottom:1.375rem;position:relative;z-index:1}
.svc__link{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.875rem;font-weight:600;color:var(--blue);
  position:relative;z-index:1;transition:gap .25s var(--ease),color .25s;
}
.svc:hover .svc__link{gap:.75rem;color:var(--teal)}

/* ─────────────────────────────────────────────
   PROCESS
───────────────────────────────────────────── */
.process{background:var(--bg)}
.process__head{text-align:center;margin-bottom:3rem}
.process__head .section-tag{display:block;text-align:center}
.process__head .section-tag::before{display:none}
.process__head .section-p{max-width:480px;margin:0 auto}
.process__steps{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5px;background:var(--border);
  border:1.5px solid var(--border);border-radius:var(--rlg);overflow:hidden;
}
.step{
  background:var(--bg);padding:3rem 2.5rem;
  position:relative;overflow:hidden;
  transition:background .28s var(--ease);
}
.step::after{
  content:'';position:absolute;top:0;left:0;right:0;
  height:2.5px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease);
}
.step:hover::after{transform:scaleX(1)}
.step:hover{background:var(--bg2)}
.step__n{
  font-size:4.5rem;font-weight:700;letter-spacing:-.06em;line-height:1;
  margin-bottom:1.5rem;
  background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  opacity:.2;
}
.step h3{font-size:1.25rem;font-weight:600;color:var(--ink);margin-bottom:.75rem}
.step p{font-size:.9rem;color:var(--muted);line-height:1.75;margin-bottom:1.75rem}
.step__list{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.step__list li{display:flex;align-items:center;gap:.6rem;font-size:.845rem;color:var(--muted)}
.step__list li::before{content:'';width:5px;height:5px;min-width:5px;border-radius:50%;background:var(--teal)}

/* ─────────────────────────────────────────────
   RESULTS
───────────────────────────────────────────── */
.results{background:var(--bg2)}
.results__head{text-align:center;margin-bottom:2.5rem}
.results__head .section-tag{display:block;text-align:center}
.results__head .section-tag::before{display:none}
.results__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.result{
  background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rlg);
  padding:2.5rem;display:flex;flex-direction:column;gap:.875rem;
  transition:border-color .28s var(--ease),transform .28s var(--ease),box-shadow .28s var(--ease);
  position:relative;overflow:hidden;
}
.result::before{
  content:'';position:absolute;inset:0;
  background:var(--grad-soft);opacity:0;transition:opacity .4s var(--ease);
}
.result:hover::before{opacity:1}
.result:hover{border-color:rgba(112,195,197,.45);transform:translateY(-6px);box-shadow:var(--shadow-md)}
.result__metric{
  font-size:1.65rem;font-weight:700;letter-spacing:-.04em;line-height:1.1;
  background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  position:relative;z-index:1;
}
.result__tag{
  display:inline-flex;align-items:center;
  background:var(--teal-light);border:1px solid rgba(112,195,197,.3);
  color:var(--blue);padding:.25rem .7rem;border-radius:var(--pill);
  font-size:.72rem;font-weight:500;letter-spacing:.04em;
  align-self:flex-start;position:relative;z-index:1;
}
.result h3{font-size:1rem;font-weight:600;color:var(--ink);position:relative;z-index:1}
.result p{font-size:.875rem;color:var(--muted);line-height:1.75;flex:1;position:relative;z-index:1}

/* ─────────────────────────────────────────────
   PARTNERS MARQUEE
───────────────────────────────────────────── */
.partners{
  padding:3rem 0;background:var(--bg);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;
}
.partners__label{
  text-align:center;font-size:.72rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-bottom:2rem;
}
.marquee{display:flex;overflow:hidden;user-select:none}
.marquee__track{
  display:flex;gap:4rem;align-items:center;flex-shrink:0;
  animation:marq 22s linear infinite;
}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.partner-logo{
  font-size:1rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;
  color:var(--dim);white-space:nowrap;cursor:default;
  transition:color .22s;
}
.partner-logo:hover{color:var(--blue)}

/* ─────────────────────────────────────────────
   CTA, brand gradient, full-width
───────────────────────────────────────────── */
.cta-section{
  background:var(--grad);padding:8rem 0;
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 80% at 50% -10%,rgba(255,255,255,.12) 0%,transparent 60%),
    radial-gradient(ellipse 50% 60% at 90% 120%,rgba(255,255,255,.06) 0%,transparent 50%);
}

/* Floating dots */
.cta-dots{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.cta-dot{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,.1);
  animation:dotRise linear infinite;
}
@keyframes dotRise{
  0%{transform:translateY(100vh) scale(0);opacity:0}
  10%{opacity:1}90%{opacity:.4}
  100%{transform:translateY(-20vh) scale(1);opacity:0}
}

.cta-section__inner{
  position:relative;z-index:1;
  display:flex;justify-content:space-between;align-items:center;
  gap:3rem;flex-wrap:wrap;
}
.cta-section__text{flex:1;min-width:280px}
.cta-section__text h2{
  font-size:clamp(2rem,4vw,3.25rem);font-weight:600;
  color:#fff;letter-spacing:-.04em;margin-bottom:.875rem;line-height:1.12;
}
.cta-section__text p{font-size:1rem;color:rgba(255,255,255,.8);line-height:1.72;max-width:440px}
.cta-section__btns{display:flex;gap:.875rem;flex-wrap:wrap;flex-shrink:0}

/* ─────────────────────────────────────────────
   FOOTER, deep navy
───────────────────────────────────────────── */
.footer{background:var(--blue-deep);padding-top:5rem}
.footer__top{
  display:grid;grid-template-columns:2fr 1fr 1.6fr;
  gap:4rem;padding-bottom:4rem;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer__brand p{color:rgba(255,255,255,.45);font-size:.875rem;margin-bottom:1.5rem;line-height:1.65}
.footer__socials{display:flex;gap:.5rem}
.footer__socials a{
  width:36px;height:36px;border-radius:8px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.45);transition:all .22s var(--ease);
}
.footer__socials a:hover{background:rgba(112,195,197,.14);border-color:rgba(112,195,197,.3);color:var(--teal)}
.footer__col h4{
  font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.25);margin-bottom:1.25rem;
}
.footer__col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer__col ul a{color:rgba(255,255,255,.5);font-size:.875rem;transition:color .2s}
.footer__col ul a:hover{color:var(--teal)}
.footer__col p{color:rgba(255,255,255,.5);font-size:.875rem;margin-bottom:.5rem;line-height:1.65}
.footer__col a{color:rgba(255,255,255,.5);transition:color .2s}
.footer__col a:hover{color:var(--teal)}
.footer__bottom{padding:1.5rem 0}
.footer__bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem}
.footer__bottom-inner p{color:rgba(255,255,255,.2);font-size:.8rem}
.footer__legal{display:flex;gap:1.5rem}
.footer__legal a{color:rgba(255,255,255,.2);font-size:.8rem;transition:color .2s}
.footer__legal a:hover{color:var(--teal)}

/* ─────────────────────────────────────────────
   SCROLL REVEAL
───────────────────────────────────────────── */
.sr{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.sr.in{opacity:1;transform:translateY(0)}
.sr-l{opacity:0;transform:translateX(-30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.sr-l.in{opacity:1;transform:translateX(0)}
.sr-r{opacity:0;transform:translateX(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.sr-r.in{opacity:1;transform:translateX(0)}

/* ─────────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────────── */
@media(max-width:1024px){
  .about__grid{grid-template-columns:1fr;gap:3rem}
  .about__vis{order:-1}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .process__steps{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .results__grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr;gap:2rem}
  .footer__brand{grid-column:1/-1}
  .float-badge{display:none}
  .cta-section__inner{flex-direction:column;text-align:center}
  .cta-section__text p{max-width:none}
}
@media(max-width:768px){
  .nav__links,.nav__actions{display:none}
  .nav__hamburger{display:flex}
  .nav__links.open{
    display:flex;flex-direction:column;
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(255,255,255,.98);padding:5rem 2rem 2rem;
    gap:.5rem;z-index:6999;overflow-y:auto;
  }
  .hero{padding:6rem 0 4rem}
  .hero__title{font-size:clamp(2rem,8vw,3rem);letter-spacing:-.04em}
  .hero__sub{max-width:100%;font-size:.95rem}
  .hero__ctas{flex-direction:column;align-items:center}
  .hero__ctas .btn{width:100%;max-width:300px;justify-content:center}
  .about__grid{grid-template-columns:1fr;gap:2rem}
  .about__vis{order:-1;max-width:360px;margin:0 auto}
  .footer__top{grid-template-columns:1fr;gap:2rem}
  .footer__bottom-inner{flex-direction:column;text-align:center}
  .cta-section__btns{flex-direction:column;align-items:stretch;width:100%;max-width:300px}
  .cta-section__btns .btn{text-align:center;justify-content:center}
  section{padding:5rem 0}
  .services__grid{grid-template-columns:1fr}
  .gtm__grid{grid-template-columns:1fr !important}
}
@media(max-width:480px){
  .container{padding:0 1.25rem}
  .stats__grid{grid-template-columns:1fr}
  .hero__title{font-size:clamp(1.75rem,7vw,2.5rem)}
  .logos__label{font-size:.875rem}
  .svc{padding:1.5rem}
}
@media(max-width:640px){
  .logos__marquee{overflow:hidden}
  .logos__track{
    justify-content:flex-start;
    width:max-content;
    animation:logoRun 14s linear infinite;
  }
  .logos__track:hover{animation-play-state:paused}
  .logo-item{padding:.75rem 2.5rem;font-size:.9rem}
  .logo-item.logo-dup{display:inline-flex}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  #preloader.done,#preloader{display:none}
}

/* ─────────────────────────────────────────────
   GTM GARAGE
───────────────────────────────────────────── */
.gtm{background:var(--bg2);position:relative;overflow:hidden}
.gtm::before{
  content:'';position:absolute;top:-180px;right:-180px;
  width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(112,195,197,.13) 0%,transparent 70%);
  pointer-events:none;
}
.gtm__head{text-align:center;margin-bottom:2.5rem}
.gtm__head .section-tag{display:block;text-align:center}
.gtm__head .section-tag::before{display:none}
.gtm__badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--blue);color:#fff;
  font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  padding:.45rem 1.1rem;border-radius:var(--pill);margin-bottom:1.5rem;
}
.gtm__badge-dot{
  width:7px;height:7px;border-radius:50%;background:var(--teal);
  animation:pulse 1.8s ease-in-out infinite;
}
.gtm__grid{
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:1.5px;background:var(--border);
  border:1.5px solid var(--border);border-radius:var(--rlg);overflow:hidden;
}
.gtm__left{
  background:var(--blue);padding:3.5rem;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
}
.gtm__left::after{
  content:'GARAGE';position:absolute;bottom:-20px;right:-10px;
  font-size:6.5rem;font-weight:700;letter-spacing:-.06em;
  color:rgba(255,255,255,.06);line-height:1;pointer-events:none;
  user-select:none;
}
.gtm__left-eyebrow{
  font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin-bottom:1rem;
}
.gtm__left h3{
  font-size:clamp(1.75rem,3vw,2.5rem);font-weight:600;
  color:#fff;letter-spacing:-.04em;line-height:1.18;margin-bottom:1.25rem;
}
.gtm__left p{
  font-size:.9375rem;color:rgba(255,255,255,.72);line-height:1.75;margin-bottom:2rem;
}
.gtm__left-stats{display:flex;gap:2rem;flex-wrap:wrap}
.gtm__stat{display:flex;flex-direction:column;gap:.25rem}
.gtm__stat strong{
  font-size:1.75rem;font-weight:700;color:#fff;letter-spacing:-.04em;
  background:linear-gradient(135deg,#fff 0%,var(--teal) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.gtm__stat span{font-size:.78rem;color:rgba(255,255,255,.5)}
.gtm__right{background:var(--bg);padding:3.5rem}
.gtm__items{display:flex;flex-direction:column;gap:1.75rem}
.gtm__item{display:flex;gap:1.25rem;align-items:flex-start}
.gtm__item-icon{
  width:42px;height:42px;min-width:42px;border-radius:10px;
  background:var(--teal-light);border:1.5px solid rgba(112,195,197,.28);
  display:flex;align-items:center;justify-content:center;color:var(--blue);
  transition:background .25s,border-color .25s;
}
.gtm__item:hover .gtm__item-icon{background:rgba(112,195,197,.15);border-color:rgba(112,195,197,.5)}
.gtm__item-body h4{font-size:.975rem;font-weight:600;color:var(--ink);margin-bottom:.3rem}
.gtm__item-body p{font-size:.865rem;color:var(--muted);line-height:1.7}

/* ─────────────────────────────────────────────
   TEAM PANEL
───────────────────────────────────────────── */
.team{background:var(--bg);padding:4rem 0!important}
.team-panel{
  border:1.5px solid var(--border);border-radius:var(--rxl);
  overflow:hidden;
  background:linear-gradient(135deg,var(--bg) 0%,var(--bg2) 100%);
  position:relative;
}
.team-panel::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:2.5px;background:var(--grad);
}
.team-panel__top{
  padding:3rem 3.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  flex-wrap:wrap;
  border-bottom:1.5px solid var(--border);
}
.team-panel__top-text h2{
  font-size:clamp(1.5rem,2.5vw,2.25rem);font-weight:600;
  color:var(--ink);letter-spacing:-.04em;line-height:1.2;
  margin-bottom:.75rem;
}
.team-panel__top-text p{
  font-size:.9rem;color:var(--muted);line-height:1.72;max-width:520px;
}
.pillar{
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--r);padding:1.5rem 1.25rem;
  transition:border-color .25s,box-shadow .25s,transform .25s var(--ease);
}
.pillar:hover{
  border-color:rgba(112,195,197,.4);
  box-shadow:var(--shadow-sm);
  transform:translateY(-2px);
}
.pillar__icon{font-size:1.25rem;margin-bottom:.75rem;display:block;}
.pillar h4{font-size:.9rem;font-weight:600;color:var(--ink);margin-bottom:.3rem}
.pillar p{font-size:.78rem;color:var(--muted);line-height:1.6}

/* ── TEAM MEMBER CARDS ── */
.team-members{
  display:grid;grid-template-columns:repeat(6,1fr);
  gap:1.25rem;padding:2.5rem 3.5rem 3rem;
}
.tmember{
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
  cursor:default;
}
.tmember__photo{
  width:100%;aspect-ratio:3/4;border-radius:var(--r);
  position:relative;overflow:hidden;
}
.tmember__photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(15,29,82,.55) 0%,transparent 60%);
}
.tmember__shape{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;font-weight:700;color:rgba(255,255,255,.9);
  letter-spacing:-.04em;
  position:relative;
}
.ts-1{background:linear-gradient(160deg,#243c8f 0%,#70C3C5 100%)}
.ts-2{background:linear-gradient(160deg,#1e6e8c 0%,#243c8f 100%)}
.ts-3{background:linear-gradient(160deg,#70C3C5 0%,#3a7bd5 100%)}
.ts-4{background:linear-gradient(160deg,#0f1d52 0%,#70C3C5 100%)}
.ts-5{background:linear-gradient(160deg,#3a5bd9 0%,#243c8f 100%)}
.ts-6{background:linear-gradient(160deg,#243c8f 30%,#a8d8da 100%)}
.tmember__arch{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:75%;height:80%;
  border-radius:999px 999px 0 0;
  background:rgba(255,255,255,.1);
}
.tmember__name{font-size:.78rem;font-weight:600;color:var(--ink);text-align:center}
.tmember__role{font-size:.7rem;color:var(--muted);text-align:center;line-height:1.4}
@media(max-width:1024px){.team-members{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.team-members{grid-template-columns:repeat(2,1fr)}}

/* ── GTM PIPELINE CARD (about visual) ── */
.gtm-pipeline-card{
  background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rxl);
  box-shadow:var(--shadow-lg);overflow:hidden;
  transform:perspective(1200px) rotateY(-4deg) rotateX(2deg);
  transition:transform .6s var(--ease);
}
.about__vis:hover .gtm-pipeline-card{transform:perspective(1200px) rotateY(0) rotateX(0)}
.gtm-pipeline-card__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:.875rem 1.5rem;background:var(--bg2);border-bottom:1px solid var(--border);
}
.gtm-pipeline-card__label{font-size:.78rem;font-weight:600;color:var(--muted)}
.funnel-journey{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column}
.funnel-step{display:flex;align-items:center;gap:.875rem;padding:.7rem .875rem;border-radius:var(--r);border:1px solid var(--border-light);background:var(--bg2);transition:border-color .2s,box-shadow .2s,transform .2s}
.funnel-step:hover{border-color:rgba(112,195,197,.4);box-shadow:var(--shadow-xs);transform:translateX(3px)}
.funnel-step__icon{width:28px;height:28px;min-width:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fs-1 .funnel-step__icon{background:rgba(36,60,143,.08);color:var(--blue)}
.fs-2 .funnel-step__icon{background:rgba(36,60,143,.12);color:var(--blue)}
.fs-3 .funnel-step__icon{background:rgba(60,100,180,.15);color:var(--blue)}
.fs-4 .funnel-step__icon{background:rgba(80,140,200,.15);color:var(--blue)}
.fs-5 .funnel-step__icon{background:rgba(112,195,197,.18);color:var(--blue)}
.fs-6 .funnel-step__icon{background:rgba(112,195,197,.28);color:var(--blue)}
.funnel-step__body{display:flex;flex-direction:column;gap:.1rem}
.funnel-step__label{font-size:.82rem;font-weight:600;color:var(--ink)}
.funnel-step__sub{font-size:.7rem;color:var(--muted);line-height:1.4}
.funnel-connector{width:2px;height:12px;background:linear-gradient(to bottom,rgba(36,60,143,.2),rgba(112,195,197,.3));margin-left:calc(.875rem + 13px);border-radius:2px}
.gtm-pipeline-metrics{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border);
}
.gtm-pipeline-metric{
  padding:1rem;text-align:center;
  border-right:1px solid var(--border);
}
.gtm-pipeline-metric:last-child{border-right:none}
.gtm-pipeline-metric strong{
  display:block;font-size:1.15rem;font-weight:700;letter-spacing:-.03em;
  background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.2rem;
}
.gtm-pipeline-metric span{font-size:.68rem;font-weight:500;color:var(--dim)}
.gtm-pipeline-card__foot{
  display:flex;align-items:center;gap:.5rem;
  padding:.75rem 1.5rem;font-size:.75rem;font-weight:500;color:var(--dim);
  background:var(--bg2);border-top:1px solid var(--border);
}

/* ── GTM GARAGE TEASER ── */
.gtm-teaser{background:var(--bg2)}
.gtm-teaser__inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.gtm-teaser__left .section-h{margin-bottom:1rem}
.gtm-teaser__left .section-p{margin-bottom:2rem}
.gtm-teaser__card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--rlg);overflow:hidden}
.gtm-teaser__item{display:flex;align-items:flex-start;gap:1.25rem;padding:1.5rem;border-bottom:1px solid var(--border)}
.gtm-teaser__item:last-child{border-bottom:none}
.gtm-teaser__num{font-size:.72rem;font-weight:500;letter-spacing:.1em;color:var(--teal);flex-shrink:0;padding-top:.15rem}
.gtm-teaser__item strong{font-size:.9rem;font-weight:600;color:var(--ink);display:block;margin-bottom:.25rem}
.gtm-teaser__item p{font-size:.82rem;color:var(--muted);line-height:1.6;margin:0}
@media(max-width:768px){.gtm-teaser__inner{grid-template-columns:1fr}}

/* ─── HERO WORD SWAP ─── */
.hero-swap{
  display:inline-block;
  color:var(--blue);
  transition:opacity .28s var(--ease),transform .28s var(--ease);
}
.hero-swap.out{opacity:0;transform:translateY(-10px)}
.hero-swap.in{opacity:0;transform:translateY(10px)}

/* ── FAQ visibility guard ──────────────────────────────────────────────────
   Overrides any legacy `section#faq { display:none !important }` rule that
   may be saved in WP Customizer → Additional CSS from the old dual-FAQ
   workaround. Higher specificity (111 vs 101) wins when both use !important.
─────────────────────────────────────────────────────────────────────────── */
section#faq.faq{display:block!important}

/* ── Typography overrides ──────────────────────────────────────────────────
   Wins specificity fight against Elementor / other plugin CSS that may
   inject conflicting font-size or font-family rules on the home template.
─────────────────────────────────────────────────────────────────────────── */
body.page-template-template-home .hero__title.hero__title{font-size:clamp(2rem,4.5vw,5rem)!important;font-weight:700!important;line-height:1.1!important;letter-spacing:-.055em!important}
body.page-template-template-home .hero__sub.hero__sub{font-size:clamp(.95rem,1.6vw,1.05rem)!important;line-height:1.72!important}
body.page-template-template-home h2.section-h.section-h{font-size:clamp(2rem,4.5vw,3.75rem)!important;font-weight:600!important;line-height:1.08!important;letter-spacing:-.04em!important}
body.page-template-template-home p.section-p.section-p{font-size:1.05rem!important;line-height:1.78!important}
body.page-template-template-home .btn.btn{font-size:.9375rem!important;font-weight:500!important}
body.page-template-template-home{font-size:16px!important;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important;line-height:1.65!important}
body.page-template-template-home .site-main p{font-size:1rem!important;line-height:1.65!important}
body.page-template-template-home .svc p{font-size:1rem!important;line-height:1.65!important;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important;font-weight:400!important;letter-spacing:normal!important;word-spacing:normal!important}
body.page-template-template-home .svc h3{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important}
body.page-template-template-home h1,body.page-template-template-home h2,body.page-template-template-home h3{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important}
