/* ═══════════════════════════════════════════════════════════════
   KALMBYTE — DESIGN SYSTEM v2
   ═══════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;color:var(--text);background:var(--white);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,video{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,textarea,select{font:inherit}
body.no-scroll{overflow:hidden}

/* ── TOKENS ─────────────────────────────────────────────────── */
:root{
  --blue:#2563EB; --blue-dark:#1D4ED8; --blue-light:#3B82F6;
  --blue-50:#EFF6FF; --blue-100:#DBEAFE;
  --violet:#7C3AED; --violet-light:#A78BFA;
  --cyan:#06B6D4; --green:#10B981; --amber:#F59E0B;
  --dark:#0F172A; --navy:#1E293B; --navy-2:#334155;
  --text:#1E293B; --muted:#64748B; --subtle:#94A3B8;
  --border:#E2E8F0; --border-2:#CBD5E1;
  --surface:#F8FAFC; --surface-2:#F1F5F9; --white:#FFFFFF;
  --nav-h:68px;
  --r-xs:6px; --r-sm:10px; --r:16px; --r-lg:24px; --r-xl:32px; --r-full:9999px;
  --sh-sm:0 1px 3px rgba(15,23,42,.08),0 1px 2px rgba(15,23,42,.05);
  --sh:0 4px 6px -1px rgba(15,23,42,.08),0 2px 4px -2px rgba(15,23,42,.05);
  --sh-md:0 10px 15px -3px rgba(15,23,42,.1),0 4px 6px -4px rgba(15,23,42,.05);
  --sh-lg:0 20px 25px -5px rgba(15,23,42,.12),0 8px 10px -6px rgba(15,23,42,.06);
  --sh-xl:0 25px 50px -12px rgba(15,23,42,.2);
  --sh-blue:0 8px 24px rgba(37,99,235,.32);
  --ease:cubic-bezier(.4,0,.2,1); --ease-out:cubic-bezier(0,0,.2,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
}

/* ── TYPOGRAPHY ─────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-family:'Plus Jakarta Sans','Space Grotesk',sans-serif;font-weight:700;line-height:1.15;letter-spacing:0;color:var(--text)}
h1{font-size:clamp(2.25rem,5.5vw,4rem)}
h2{font-size:clamp(1.75rem,3.5vw,2.75rem)}
h3{font-size:clamp(1.15rem,2vw,1.4rem)}
p{line-height:1.75;color:var(--muted)}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.container{width:100%;max-width:1240px;margin:0 auto;padding:0 32px}
.section{padding:96px 0}
.section-sm{padding:56px 0}

/* ── SCROLL PROGRESS ────────────────────────────────────────── */
#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0%;
  background:linear-gradient(90deg,var(--blue),var(--violet),var(--cyan));
  z-index:9999;transition:width .08s linear;border-radius:0 2px 2px 0;
  box-shadow:0 0 10px rgba(37,99,235,.6)}

/* ── PAGE TRANSITION ────────────────────────────────────────── */
#page-curtain{position:fixed;inset:0;background:var(--dark);z-index:9998;
  pointer-events:none;transform:scaleY(0);transform-origin:top;
  transition:transform .45s var(--ease)}
#page-curtain.cover{transform:scaleY(1)}
#page-curtain.reveal{transform-origin:bottom;transform:scaleY(0)}

/* ── LOADER ─────────────────────────────────────────────────── */
#page-loader{position:fixed;inset:0;background:var(--dark);z-index:10000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;
  transition:opacity .5s var(--ease),visibility .5s}
#page-loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-brand{display:flex;align-items:center;gap:10px}
@keyframes loader-pop{from{transform:scale(0) rotate(-30deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.loader-brand-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.9rem;font-weight:700;
  color:white;letter-spacing:0;animation:loader-in .6s var(--ease) .15s both}
@keyframes loader-in{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:none}}
.loader-progress{width:180px;height:2px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.loader-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--violet));
  border-radius:99px;animation:loader-bar 1.5s var(--ease) forwards}
@keyframes loader-bar{from{width:0}to{width:100%}}

/* ── NAVBAR ─────────────────────────────────────────────────── */
#navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:900;
  background:rgba(13,17,23,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .3s var(--ease),box-shadow .3s var(--ease)}
#navbar.scrolled{background:rgba(13,17,23,.97);box-shadow:0 1px 0 rgba(255,255,255,.05),0 4px 16px rgba(0,0,0,.3)}
.nav-inner{display:flex;align-items:center;height:100%;max-width:1400px;margin:0 auto;padding:0 32px;gap:2rem}
.nav-brand{display:flex;align-items:center;gap:9px;flex-shrink:0}
.nav-brand-mark{width:36px;height:36px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;filter:drop-shadow(0 4px 12px rgba(37,99,235,.45));
  transition:transform .3s var(--spring),filter .3s}
.nav-brand-mark svg{display:block;width:100%;height:100%}
.nav-brand:hover .nav-brand-mark{transform:rotate(-8deg) scale(1.08);filter:drop-shadow(0 6px 20px rgba(37,99,235,.6))}
/* Loader mark */
.loader-brand-mark{display:inline-flex}
.loader-brand-mark svg{display:block;width:48px;height:48px;filter:drop-shadow(0 8px 24px rgba(37,99,235,.5));
  animation:loader-pop .55s var(--spring) forwards}
.nav-brand-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.3rem;font-weight:700;
  color:white;letter-spacing:0}
.nav-menu{display:flex;align-items:center;gap:.2rem;margin-left:auto}
.nav-menu>li>a{color:rgba(255,255,255,.7);font-size:.9rem;font-weight:500;
  padding:.5rem .9rem;border-radius:var(--r-sm);transition:all .2s;
  display:flex;align-items:center;gap:5px;position:relative}
.nav-menu>li>a::after{content:'';position:absolute;bottom:4px;left:.9rem;right:.9rem;
  height:1.5px;background:var(--blue-light);border-radius:1px;transform:scaleX(0);
  transition:transform .25s var(--ease);transform-origin:left}
.nav-menu>li>a:hover,.nav-menu>li>a.active{color:white}
.nav-menu>li>a:hover::after,.nav-menu>li>a.active::after{transform:scaleX(1)}
.nav-caret{font-size:.7rem;opacity:.5;transition:transform .25s var(--ease);margin-left:2px}
.has-mega:hover .nav-caret{transform:rotate(180deg)}
/* mega */
.mega{position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(-8px);
  background:rgba(18,22,34,.97);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);
  padding:1.75rem;display:flex;gap:2.5rem;opacity:0;visibility:hidden;pointer-events:none;
  transition:all .25s var(--ease);min-width:560px;
  box-shadow:0 24px 64px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.03);backdrop-filter:blur(20px)}
.has-mega{position:relative}
.has-mega:hover .mega{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.mega-col{flex:1;min-width:140px}
.mega-col-title{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-bottom:.75rem;padding-left:.5rem}
.mega a{display:flex;align-items:center;gap:.625rem;color:rgba(255,255,255,.62);
  font-size:.875rem;font-weight:500;padding:.45rem .625rem;border-radius:var(--r-sm);
  transition:all .18s;line-height:1.3}
.mega a:hover{color:white;background:rgba(37,99,235,.18);padding-left:1rem}
.mega-icon{width:26px;height:26px;background:rgba(37,99,235,.15);border-radius:7px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.8rem}
.nav-cta{display:flex;align-items:center;gap:.75rem;margin-left:1rem;flex-shrink:0}
.nav-toggle{display:none;width:40px;height:40px;flex-direction:column;align-items:center;
  justify-content:center;gap:5px;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.1)}
.nav-toggle span{display:block;width:20px;height:2px;background:white;border-radius:2px;transition:all .3s var(--ease)}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:.65rem 1.5rem;border-radius:var(--r-full);font-size:.9375rem;font-weight:600;
  transition:all .22s var(--ease);white-space:nowrap;position:relative;overflow:hidden;cursor:pointer}
.btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12),transparent);
  opacity:0;transition:opacity .2s;pointer-events:none}
.btn:hover::before{opacity:1}
.btn-lg{padding:.875rem 2.25rem;font-size:1rem}
.btn-sm{padding:.45rem 1.125rem;font-size:.8125rem}
.btn-wide{width:100%;justify-content:center}
.btn-primary{background:var(--blue);color:var(--white);box-shadow:var(--sh-blue)}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px) scale(1.01);
  box-shadow:0 14px 32px rgba(37,99,235,.42)}
.btn-primary:active{transform:translateY(0) scale(.99)}
/* shimmer */
.btn-primary::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transform:skewX(-20deg);transition:none}
.btn-primary:hover::after{animation:btn-shimmer .6s ease forwards}
@keyframes btn-shimmer{to{left:160%}}
.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--border);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--blue);border:2px solid var(--blue)}
.btn-outline:hover{background:var(--blue-50);transform:translateY(-1px)}
.btn-white{background:var(--white);color:var(--blue);box-shadow:0 4px 16px rgba(0,0,0,.12)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.2)}
.btn-ghost-white{background:rgba(255,255,255,.1);color:var(--white);border:1.5px solid rgba(255,255,255,.25)}
.btn-ghost-white:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.55)}
.btn-arrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;
  font-size:.9375rem;color:var(--blue);transition:gap .22s var(--ease)}
.btn-arrow:hover{gap:14px}
.btn-arrow svg{transition:transform .22s var(--ease)}
.btn-arrow:hover svg{transform:translateX(3px)}

/* ── SECTION HEADER ─────────────────────────────────────────── */
.section-header{margin-bottom:3.5rem}
.section-header.center{text-align:center;max-width:640px;margin-left:auto;margin-right:auto}
.section-header .badge{margin-bottom:1rem}
.section-header h2{margin-bottom:.875rem}
.section-header p{font-size:1.0625rem;line-height:1.75;max-width:560px}
.section-header.center p{margin:0 auto}

/* ── BADGES ─────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:6px;padding:.35rem .9rem;
  border-radius:var(--r-full);font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase}
.badge-blue{background:var(--blue-50);color:var(--blue);border:1px solid var(--blue-100)}
.badge-dark{background:rgba(255,255,255,.08);color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.12)}
.badge-dot::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;
  background:currentColor;animation:badge-pulse 2s ease infinite}
@keyframes badge-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

/* ── FOOTER ─────────────────────────────────────────────────── */
.site-footer{background:var(--dark);border-top:1px solid rgba(255,255,255,.06)}
.footer-main{padding:4.5rem 0 3rem;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr 1.5fr;gap:3rem}
.footer-brand p{color:rgba(255,255,255,.38);font-size:.875rem;line-height:1.75;margin:1rem 0 1.5rem;max-width:260px}
.footer-social{display:flex;gap:.5rem}
.footer-social a{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.38);
  font-size:.7rem;font-weight:700;transition:all .2s}
.footer-social a:hover{background:var(--blue);border-color:var(--blue);color:white;transform:translateY(-2px)}
.footer-col h5{color:white;font-size:.8125rem;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;margin-bottom:1.25rem}
.footer-col ul{display:flex;flex-direction:column;gap:.625rem}
.footer-col ul a{color:rgba(255,255,255,.38);font-size:.875rem;transition:all .2s;display:block}
.footer-col ul a:hover{color:rgba(255,255,255,.85);padding-left:5px}
.footer-col address{font-style:normal;color:rgba(255,255,255,.38);font-size:.875rem;line-height:1.85}
.footer-col address a{color:rgba(255,255,255,.5);transition:color .2s}
.footer-col address a:hover{color:white}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:1.5rem 0;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-bottom p{color:rgba(255,255,255,.26);font-size:.8125rem}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{color:rgba(255,255,255,.26);font-size:.8125rem;transition:color .2s}
.footer-legal a:hover{color:rgba(255,255,255,.7)}

/* ── GRADIENT TEXT ───────────────────────────────────────────── */
.gradient-text{background:linear-gradient(135deg,var(--blue),var(--violet));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── REVEAL ANIMATIONS ───────────────────────────────────────── */
[data-reveal]{opacity:0;transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal="up"],[data-reveal]{transform:translateY(36px)}
[data-reveal="left"]{transform:translateX(-48px)}
[data-reveal="right"]{transform:translateX(48px)}
[data-reveal="scale"]{transform:scale(0.88)}
[data-reveal="flip"]{transform:perspective(600px) rotateX(-12deg);transform-origin:bottom}
[data-reveal].visible{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
[data-reveal][data-delay="4"]{transition-delay:.32s}
[data-reveal][data-delay="5"]{transition-delay:.40s}
[data-reveal][data-delay="6"]{transition-delay:.48s}

/* ── PAGE HERO ───────────────────────────────────────────────── */
.page-hero{background:var(--dark);padding:clamp(88px,12vw,148px) 0 clamp(64px,8vw,96px);
  position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 80% at 15% 50%,rgba(37,99,235,.22),transparent),
  radial-gradient(ellipse 50% 60% at 85% 20%,rgba(124,58,237,.16),transparent);pointer-events:none}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(37,99,235,.4),rgba(124,58,237,.4),transparent)}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{color:var(--white);margin-bottom:1.25rem;
  animation:hero-title-in .8s var(--ease) .3s both}
.page-hero p{color:rgba(255,255,255,.58);font-size:1.125rem;max-width:560px;
  animation:hero-title-in .8s var(--ease) .45s both}
.page-hero .badge{margin-bottom:1.25rem;animation:hero-title-in .6s var(--ease) .15s both}
@keyframes hero-title-in{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* ═══════════════════════════════════
   HOME PAGE
═══════════════════════════════════ */
.home-hero{min-height:100vh;background:var(--dark);display:flex;align-items:center;
  position:relative;overflow:hidden;padding-top:var(--nav-h)}
.hero-gfx{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-gfx-orb{position:absolute;border-radius:50%;filter:blur(80px);animation:orb-drift 10s ease-in-out infinite alternate}
.o1{width:700px;height:700px;background:radial-gradient(circle,rgba(37,99,235,.2),transparent 70%);
  top:-200px;left:-200px;animation-delay:0s}
.o2{width:600px;height:600px;background:radial-gradient(circle,rgba(124,58,237,.18),transparent 70%);
  bottom:-100px;right:-100px;animation-delay:4s}
.o3{width:400px;height:400px;background:radial-gradient(circle,rgba(6,182,212,.1),transparent 70%);
  top:40%;right:15%;animation-delay:7s}
@keyframes orb-drift{0%{transform:translate(0,0) scale(1)}100%{transform:translate(30px,20px) scale(1.06)}}
#particles-canvas{position:absolute;inset:0;width:100%;height:100%}
.home-hero .container{position:relative;z-index:2;padding-top:48px;padding-bottom:100px}

/* hero eyebrow */
.hero-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:1.75rem;
  animation:hero-el-in .7s var(--ease) .2s both}
@keyframes hero-el-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.hero-eyebrow-dot{width:8px;height:8px;background:var(--cyan);border-radius:50%;
  box-shadow:0 0 12px var(--cyan);animation:badge-pulse 2s ease infinite}

/* hero title word animation */
.hero-title{font-size:clamp(2.5rem,6.5vw,5rem);font-weight:800;color:white;
  line-height:1.06;letter-spacing:0;margin-bottom:1.5rem}
.hero-title .word{display:inline-block;overflow:hidden;vertical-align:bottom;margin-right:.25em}
.hero-title .word-inner{display:inline-block;animation:word-up .7s var(--ease) both}
.hero-title .word:nth-child(1) .word-inner{animation-delay:.3s}
.hero-title .word:nth-child(2) .word-inner{animation-delay:.42s}
.hero-title .word:nth-child(3) .word-inner{animation-delay:.54s}
.hero-title .line-2{display:block;background:linear-gradient(90deg,var(--blue-light),var(--violet-light));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
@keyframes word-up{from{transform:translateY(110%);opacity:0}to{transform:none;opacity:1}}

.hero-desc{max-width:540px;font-size:1.125rem;line-height:1.75;color:rgba(255,255,255,.58);
  margin-bottom:2.5rem;animation:hero-el-in .7s var(--ease) .7s both}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:4rem;
  animation:hero-el-in .7s var(--ease) .85s both}

/* hero stats */
.hero-stats{display:flex;flex-wrap:wrap;animation:hero-el-in .7s var(--ease) 1s both}
.hstat-item{padding:0 2.25rem;border-right:1px solid rgba(255,255,255,.1)}
.hstat-item:first-child{padding-left:0}
.hstat-item:last-child{border-right:none}
.hstat-num{font-family:'Plus Jakarta Sans',sans-serif;font-size:2.5rem;font-weight:800;
  color:white;line-height:1;display:flex;align-items:baseline;gap:3px}
.hstat-num sup{font-size:1.25rem;font-weight:700;color:var(--blue-light)}
.hstat-label{font-size:.8125rem;color:rgba(255,255,255,.38);margin-top:.3rem;font-weight:500}

/* hero scroll */
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  animation:scroll-cue 2.5s ease infinite}
.hero-scroll span{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.28)}
.hero-scroll-bar{width:1px;height:44px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent)}
@keyframes scroll-cue{0%,100%{transform:translateX(-50%) translateY(0);opacity:.5}
  50%{transform:translateX(-50%) translateY(7px);opacity:1}}

/* ── TICKER ─────────────────────────────────────────────────── */
.ticker{background:var(--blue);padding:.75rem 0;overflow:hidden;position:relative}
.ticker::before,.ticker::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(to right,var(--blue),transparent)}
.ticker::after{right:0;background:linear-gradient(to left,var(--blue),transparent)}
.ticker-inner{display:flex;width:max-content;animation:ticker-scroll 32s linear infinite}
.ticker-inner span{padding:0 2rem;font-size:.875rem;font-weight:600;color:rgba(255,255,255,.9);white-space:nowrap}
.ticker-inner .t-dot{color:rgba(255,255,255,.4);padding:0 .5rem}
@keyframes ticker-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker:hover .ticker-inner{animation-play-state:paused}

/* ── TRUST ───────────────────────────────────────────────────── */
.trust-section{padding:3.5rem 0;border-bottom:1px solid var(--border)}
.trust-label{font-size:.8rem;font-weight:600;color:var(--subtle);letter-spacing:.07em;
  text-transform:uppercase;margin-bottom:1.75rem;text-align:center}
.trust-logos{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:2rem 3.5rem}
.trust-logo{display:flex;align-items:center;gap:.5rem;opacity:.3;transition:all .25s;filter:grayscale(1)}
.trust-logo:hover{opacity:.7;filter:grayscale(0);transform:translateY(-2px)}
.trust-logo-mark{width:28px;height:28px;background:var(--navy-2);border-radius:6px;
  display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:white}
.trust-logo-name{font-size:.9375rem;font-weight:700;color:var(--navy)}

/* ── SERVICE CARDS ───────────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.svc-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);
  padding:2rem;display:flex;flex-direction:column;gap:.875rem;
  transition:all .35s var(--ease);position:relative;overflow:hidden;
  transform-style:preserve-3d}
.svc-card::before{content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(37,99,235,.04),rgba(124,58,237,.04));
  opacity:0;transition:opacity .3s;border-radius:var(--r)}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--violet));
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.svc-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:var(--sh-xl),0 0 0 1px rgba(37,99,235,.1);border-color:rgba(37,99,235,.2)}
.svc-card:hover::before{opacity:1}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;font-size:1.5rem;flex-shrink:0;transition:transform .35s var(--spring)}
.svc-card:hover .svc-icon{transform:scale(1.15) rotate(-6deg)}
.svc-card h3{font-size:1.0625rem;font-weight:700;color:var(--text)}
.svc-card p{font-size:.875rem;line-height:1.65;flex:1}
.svc-tags{display:flex;flex-wrap:wrap;gap:5px}
.svc-tag{font-size:.7rem;font-weight:600;padding:.25rem .625rem;border-radius:var(--r-full);
  background:var(--surface-2);color:var(--muted);border:1px solid var(--border);
  transition:all .2s}
.svc-card:hover .svc-tag{background:var(--blue-50);color:var(--blue);border-color:var(--blue-100)}

/* ── ABOUT SPLIT ─────────────────────────────────────────────── */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-visual-box{background:var(--surface-2);border-radius:var(--r-xl);overflow:hidden;
  aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative}
.about-visual-box svg{width:64%;opacity:.12}
.about-stat-pill{position:absolute;background:white;border-radius:var(--r);padding:1rem 1.5rem;
  box-shadow:var(--sh-xl);animation:float-pill 5s ease-in-out infinite;min-width:150px;
  transition:transform .3s}
.about-stat-pill:hover{transform:translateY(-4px) scale(1.03) !important}
.asp-1{bottom:1.5rem;left:-2rem;animation-delay:0s}
.asp-2{top:1.5rem;right:-2rem;animation-delay:1.8s}
@keyframes float-pill{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.about-stat-pill .num{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.875rem;
  font-weight:800;color:var(--blue);line-height:1}
.about-stat-pill .lab{font-size:.8rem;color:var(--muted);margin-top:.25rem}
.about-split-text h2{margin-bottom:1.25rem}
.about-split-text .lead{font-size:1.0625rem;line-height:1.8;margin-bottom:2rem}
.about-pillars{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2.5rem}
.about-pillar{display:flex;gap:1rem;align-items:flex-start;
  padding:.875rem;border-radius:var(--r-sm);transition:background .2s}
.about-pillar:hover{background:var(--blue-50)}
.pillar-icon{width:40px;height:40px;background:var(--blue-50);border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;
  transition:transform .3s var(--spring)}
.about-pillar:hover .pillar-icon{transform:scale(1.15) rotate(-5deg)}
.pillar-text strong{color:var(--text);font-size:.9375rem;display:block;margin-bottom:.2rem}
.pillar-text p{font-size:.875rem;margin:0}

/* ── WORK CARDS ──────────────────────────────────────────────── */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.work-card{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);
  background:var(--white);transition:all .35s var(--ease)}
.work-card:hover{transform:translateY(-7px) scale(1.005);box-shadow:var(--sh-xl);border-color:transparent}
.work-thumb{height:220px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.work-thumb svg{width:90px;opacity:.2;transition:transform .4s var(--spring)}
.work-card:hover .work-thumb svg{transform:scale(1.15) rotate(-5deg)}
.work-thumb-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);opacity:0;
  transition:opacity .3s;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(5px)}
.work-card:hover .work-thumb-overlay{opacity:1}
.work-thumb-cta{padding:.6rem 1.5rem;border:2px solid white;color:white;border-radius:var(--r-full);
  font-size:.875rem;font-weight:600;transition:all .2s;animation:none}
.work-thumb-cta:hover{background:white;color:var(--blue)}
.work-body{padding:1.75rem}
.work-cats{display:flex;gap:6px;margin-bottom:.75rem;flex-wrap:wrap}
.work-cat{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  color:var(--blue);background:var(--blue-50);padding:.2rem .625rem;
  border-radius:var(--r-full);border:1px solid var(--blue-100)}
.work-body h3{font-size:1.125rem;margin-bottom:.5rem}
.work-body p{font-size:.875rem;line-height:1.65;margin-bottom:1.25rem}
.work-metric{display:flex;align-items:baseline;gap:6px;padding-top:1.25rem;border-top:1px solid var(--border)}
.wm-val{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.5rem;font-weight:800;color:var(--blue)}
.wm-desc{font-size:.8125rem;color:var(--muted)}

/* ── TESTIMONIALS ────────────────────────────────────────────── */
.testi-wrapper{overflow:hidden;position:relative}
.testi-track{display:flex;gap:1.5rem;transition:transform .55s var(--ease)}
.testi-card{flex:0 0 calc(33.333% - 1rem);background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:2rem;display:flex;flex-direction:column;gap:1rem;
  transition:all .3s var(--ease)}
.testi-card:hover{border-color:var(--blue-100);box-shadow:var(--sh-lg),0 0 0 1px rgba(37,99,235,.06);
  transform:translateY(-4px)}
.testi-stars{color:#F59E0B;font-size:1rem;letter-spacing:2px}
.testi-text{font-size:.9375rem;line-height:1.78;color:var(--muted);flex:1;font-style:italic}
.testi-author{display:flex;align-items:center;gap:.875rem;padding-top:1rem;border-top:1px solid var(--border)}
.testi-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:.8125rem;font-weight:700;color:white;flex-shrink:0}
.testi-author strong{display:block;font-size:.9rem;color:var(--text);font-weight:600}
.testi-author span{font-size:.8rem;color:var(--subtle)}
.testi-nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem}
.testi-dots{display:flex;gap:6px}
.testi-dot{width:8px;height:8px;border-radius:50%;background:var(--border-2);
  cursor:pointer;transition:all .3s;border:none}
.testi-dot.active{width:24px;border-radius:99px;background:var(--blue)}
.testi-arrow{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border-2);
  color:var(--muted);display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;transition:all .2s;cursor:pointer;background:var(--white)}
.testi-arrow:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-50);transform:scale(1.05)}

/* ── CTA BAND ────────────────────────────────────────────────── */
.cta-band{padding:72px 0;position:relative;overflow:hidden}
.cta-band-blue{background:var(--blue)}
.cta-band-dark{background:var(--dark)}
.cta-band::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 100% at 80% 50%,rgba(124,58,237,.35),transparent);
  pointer-events:none}
.cta-band .container{position:relative;z-index:1;display:flex;align-items:center;
  justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band h2{color:white;font-size:clamp(1.5rem,3vw,2.25rem);max-width:540px;margin-bottom:.75rem}
.cta-band p{color:rgba(255,255,255,.7);font-size:1rem;max-width:480px}
.cta-band-btns{display:flex;gap:1rem;flex-shrink:0;flex-wrap:wrap}

/* ── SOCIAL ICON BRAND COLOURS ───────────────────────────────── */
/* Footer social */
.footer-social a{display:flex;align-items:center;justify-content:center}
.fs-li:hover{background:#0A66C2 !important;border-color:#0A66C2 !important;color:white !important}
.fs-x:hover{background:#000 !important;border-color:#000 !important;color:white !important}
.fs-gh:hover{background:#24292e !important;border-color:#24292e !important;color:white !important}
.fs-ig:hover{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888) !important;
  border-color:#e6683c !important;color:white !important}
/* Contact page socials */
.cs-li:hover{background:#0A66C2 !important;border-color:#0A66C2 !important;color:white !important}
.cs-x:hover{background:#000 !important;border-color:#000 !important;color:white !important}
.cs-gh:hover{background:#24292e !important;border-color:#24292e !important;color:white !important}
.cs-ig:hover{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888) !important;
  border-color:#e6683c !important;color:white !important}
/* Trust logos */
.tl-wordmark{display:block;height:28px;width:auto}
.trust-logo{filter:grayscale(1);opacity:.35;transition:all .25s;transform-style:preserve-3d}
.trust-logo:hover{filter:grayscale(0);opacity:1;transform:translateY(-2px)}
/* Service icon SVG tweak */
.svc-icon svg{display:block}
/* Industry icon SVG */
.ind-icon svg{display:block}
/* Contact icon SVG */
.cd-icon svg{display:block;width:20px;height:20px}
/* Tech chip better style */
.tech-chip .tc-icon{font-size:.8rem;font-weight:900;letter-spacing:0}

/* ── PROCESS STEPS ───────────────────────────────────────────── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative}
.process-grid::before{content:'';position:absolute;top:28px;left:calc(12.5% + 28px);
  right:calc(12.5% + 28px);height:1px;
  background:linear-gradient(90deg,var(--blue),var(--violet));opacity:.2}
.process-step{background:var(--white);border:1px solid var(--border);border-radius:var(--r);
  padding:1.75rem 1.5rem;text-align:center;transition:all .3s var(--ease);
  counter-increment:process}
.process-step:hover{border-color:var(--blue-100);box-shadow:var(--sh-lg);transform:translateY(-5px)}
.ps-circle{width:56px;height:56px;border-radius:50%;background:var(--blue-50);
  border:2px solid var(--blue-100);margin:0 auto 1.25rem;display:flex;
  align-items:center;justify-content:center;font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1.125rem;font-weight:800;color:var(--blue);position:relative;z-index:1;
  transition:all .3s var(--ease)}
.process-step:hover .ps-circle{background:var(--blue);color:white;border-color:var(--blue);
  box-shadow:0 6px 20px rgba(37,99,235,.45);transform:scale(1.08) rotate(-5deg)}
.process-step h4{font-size:1rem;margin-bottom:.5rem}
.process-step p{font-size:.8125rem;line-height:1.65}

/* ── TECH STACK ──────────────────────────────────────────────── */
.tech-section{background:var(--dark)}
.tech-tabs{display:flex;justify-content:center;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.tech-tab{padding:.5rem 1.25rem;border-radius:var(--r-full);font-size:.875rem;font-weight:600;
  color:rgba(255,255,255,.45);border:1px solid rgba(255,255,255,.08);transition:all .22s;cursor:pointer}
.tech-tab.active,.tech-tab:hover{background:var(--blue);color:white;border-color:var(--blue);
  box-shadow:0 4px 14px rgba(37,99,235,.4)}
.tech-panel{display:none}
.tech-panel.active{display:block;animation:tab-in .35s var(--ease)}
@keyframes tab-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.tech-logos{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}
.tech-chip{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r);padding:1.25rem 1rem;display:flex;flex-direction:column;
  align-items:center;gap:.625rem;transition:all .3s var(--ease);cursor:default}
.tech-chip:hover{background:rgba(37,99,235,.14);border-color:rgba(37,99,235,.35);
  transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px rgba(37,99,235,.2)}
.tc-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:.875rem;font-weight:800}
.tc-name{font-size:.75rem;font-weight:600;color:rgba(255,255,255,.55);text-align:center}

/* ── INDUSTRIES ──────────────────────────────────────────────── */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.ind-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  padding:2rem;transition:all .3s var(--ease);position:relative;overflow:hidden}
.ind-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--violet));
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.ind-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);background:var(--white);
  border-color:var(--blue-100)}
.ind-card:hover::before{transform:scaleX(1)}
.ind-icon{font-size:2.25rem;margin-bottom:1rem;display:block;transition:transform .3s var(--spring)}
.ind-card:hover .ind-icon{transform:scale(1.15) rotate(-5deg)}
.ind-card h4{font-size:1rem;margin-bottom:.5rem}
.ind-card p{font-size:.875rem;line-height:1.65;margin-bottom:1rem}
.ind-result{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;font-weight:700;
  color:var(--green);background:rgba(16,185,129,.08);padding:.25rem .75rem;
  border-radius:var(--r-full);border:1px solid rgba(16,185,129,.2)}

/* ══════════════════════════════════
   SERVICES PAGE
══════════════════════════════════ */
.svc-detail-section{padding:88px 0;border-bottom:1px solid var(--border)}
.svc-detail-section:last-child{border-bottom:none}
.svc-detail-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:5rem;align-items:center}
.svc-detail-grid.reverse{direction:rtl}
.svc-detail-grid.reverse>*{direction:ltr}
.svc-detail-text .badge{margin-bottom:1.25rem}
.svc-detail-text h2{margin-bottom:1.25rem;font-size:clamp(1.5rem,2.5vw,2rem)}
.svc-detail-text .lead{font-size:1.0625rem;line-height:1.8;margin-bottom:2rem}
.svc-points{display:flex;flex-direction:column;gap:.875rem}
.svc-point{display:flex;gap:.875rem;align-items:flex-start;padding:.75rem;
  border-radius:var(--r-sm);transition:background .2s}
.svc-point:hover{background:var(--blue-50)}
.svc-point-icon{width:32px;height:32px;background:var(--blue-50);border-radius:8px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--blue);font-size:.9rem;font-weight:700;transition:all .25s var(--spring)}
.svc-point:hover .svc-point-icon{background:var(--blue);color:white;transform:scale(1.1)}
.svc-point-text strong{font-size:.9375rem;color:var(--text);display:block;margin-bottom:.15rem}
.svc-point-text p{font-size:.875rem;margin:0}
.svc-visual{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/3;
  background:var(--surface-2);display:flex;align-items:center;justify-content:center;position:relative}
.svc-visual-inner{display:flex;flex-direction:column;gap:1rem;padding:2rem;width:100%}
.svc-visual-row{display:flex;gap:.75rem}
.svc-vis-box{background:white;border-radius:var(--r-sm);padding:.75rem 1rem;flex:1;
  border:1px solid var(--border);font-size:.8125rem;font-weight:600;color:var(--text);
  display:flex;align-items:center;gap:.5rem;box-shadow:var(--sh-sm);
  transition:all .25s;cursor:default}
.svc-vis-box:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.svc-vis-bar{height:8px;border-radius:99px;background:linear-gradient(90deg,var(--blue),var(--violet));margin-top:.375rem}

/* ══════════════════════════════════
   WORK PAGE
══════════════════════════════════ */
.portfolio-filter{display:flex;gap:.625rem;flex-wrap:wrap;margin-bottom:2.5rem}
.pf-btn{padding:.5rem 1.25rem;border-radius:var(--r-full);font-size:.875rem;font-weight:600;
  color:var(--muted);border:1.5px solid var(--border);background:var(--white);
  transition:all .22s var(--ease);cursor:pointer}
.pf-btn:hover,.pf-btn.active{background:var(--blue);color:white;border-color:var(--blue);
  box-shadow:0 4px 14px rgba(37,99,235,.3)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.portfolio-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--border);transition:all .35s var(--ease)}
.portfolio-card:hover{transform:translateY(-7px) scale(1.005);box-shadow:var(--sh-xl);border-color:transparent}
.portfolio-card.hidden{display:none}
.pc-thumb{height:200px;position:relative;display:flex;align-items:center;
  justify-content:center;overflow:hidden}
.pc-thumb svg{transition:transform .4s var(--spring)}
.portfolio-card:hover .pc-thumb svg{transform:scale(1.15) rotate(-3deg)}
.pc-thumb-overlay{position:absolute;inset:0;background:rgba(0,0,0,.52);opacity:0;
  transition:opacity .3s;display:flex;align-items:center;justify-content:center;
  gap:1rem;backdrop-filter:blur(5px)}
.portfolio-card:hover .pc-thumb-overlay{opacity:1}
.pc-thumb-btn{padding:.55rem 1.25rem;border-radius:var(--r-full);font-size:.8125rem;
  font-weight:600;border:1.5px solid rgba(255,255,255,.6);color:white;
  transition:all .2s;background:rgba(255,255,255,.08)}
.pc-thumb-btn:hover{background:white;color:var(--blue);border-color:white}
.pc-body{padding:1.5rem}
.pc-cats{display:flex;gap:5px;margin-bottom:.75rem;flex-wrap:wrap}
.pc-cat{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  color:var(--blue);background:var(--blue-50);padding:.2rem .625rem;
  border-radius:var(--r-full);border:1px solid var(--blue-100)}
.pc-body h3{font-size:1.0625rem;margin-bottom:.5rem}
.pc-body p{font-size:.875rem;line-height:1.65;margin-bottom:1rem}
.pc-results{display:flex;gap:.75rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid var(--border)}
.pc-result{display:flex;flex-direction:column;align-items:center}
.pc-result-val{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.25rem;font-weight:800;color:var(--blue);line-height:1}
.pc-result-label{font-size:.7rem;color:var(--subtle);margin-top:.2rem;text-align:center}
.portfolio-card.featured{grid-column:span 2}
.portfolio-card.featured .pc-thumb{height:280px}

/* ══════════════════════════════════
   ABOUT PAGE
══════════════════════════════════ */
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.mission-card{padding:2.25rem;border-radius:var(--r-lg);border:1px solid var(--border);
  background:var(--white);transition:all .3s var(--ease)}
.mission-card:hover{border-color:var(--blue-100);box-shadow:var(--sh-md);transform:translateY(-3px)}
.mission-card .m-icon{width:56px;height:56px;border-radius:16px;display:flex;
  align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.25rem;
  transition:transform .3s var(--spring)}
.mission-card:hover .m-icon{transform:scale(1.1) rotate(-5deg)}
.mission-card h3{margin-bottom:.75rem}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.team-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;transition:all .3s var(--ease)}
.team-card:hover{box-shadow:var(--sh-lg);transform:translateY(-5px);border-color:var(--blue-100)}
.team-avatar{height:180px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden}
.team-initials{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-family:'Plus Jakarta Sans',sans-serif;font-size:1.5rem;
  font-weight:800;color:white;transition:transform .3s var(--spring)}
.team-card:hover .team-initials{transform:scale(1.1)}
.team-body{padding:1.25rem 1.5rem}
.team-body strong{display:block;font-size:.9375rem;color:var(--text);margin-bottom:.2rem}
.team-body>span{font-size:.8125rem;color:var(--muted)}
.team-links{display:flex;gap:.5rem;margin-top:.875rem}
.team-link{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;
  color:var(--muted);transition:all .2s}
.team-link:hover{background:var(--blue);border-color:var(--blue);color:white;transform:scale(1.1)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.value-card{padding:2rem;border-radius:var(--r);border:1px solid var(--border);
  background:var(--white);transition:all .3s var(--ease)}
.value-card:hover{border-color:var(--blue-100);box-shadow:var(--sh-md);transform:translateY(-3px)}
.value-num{font-family:'Plus Jakarta Sans',sans-serif;font-size:3rem;font-weight:800;
  line-height:1;background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(124,58,237,.1));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.75rem}
.value-card h4{margin-bottom:.5rem;font-size:1rem}
.timeline{display:flex;flex-direction:column;position:relative}
.timeline::before{content:'';position:absolute;left:99px;top:0;bottom:0;width:2px;
  background:linear-gradient(to bottom,var(--blue),var(--violet));opacity:.2}
.tl-item{display:flex;gap:2rem;align-items:flex-start;padding:1.5rem 0;position:relative}
.tl-year{font-family:'Plus Jakarta Sans',sans-serif;font-size:.875rem;font-weight:800;
  color:var(--blue);width:100px;flex-shrink:0;padding-top:.25rem}
.tl-dot{width:14px;height:14px;border-radius:50%;background:var(--blue);
  border:3px solid var(--blue-100);flex-shrink:0;margin-top:.3rem;position:relative;z-index:1;
  box-shadow:0 0 0 4px var(--blue-50);transition:all .3s var(--spring)}
.tl-item:hover .tl-dot{transform:scale(1.3);box-shadow:0 0 0 6px rgba(37,99,235,.1)}
.tl-content h4{margin-bottom:.375rem;font-size:1rem}
.tl-content p{font-size:.875rem;margin:0}

/* ══════════════════════════════════
   CONTACT PAGE
══════════════════════════════════ */
.contact-layout{display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:start}
.contact-info h2{margin-bottom:1rem}
.contact-info .lead{font-size:1.0625rem;line-height:1.8;margin-bottom:2.5rem}
.contact-details{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:2.5rem}
.cd-item{display:flex;gap:1rem;align-items:flex-start;padding:.875rem;border-radius:var(--r-sm);transition:background .2s}
.cd-item:hover{background:var(--blue-50)}
.cd-icon{width:44px;height:44px;border-radius:12px;background:var(--blue-50);
  border:1px solid var(--blue-100);display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;flex-shrink:0;transition:transform .3s var(--spring)}
.cd-item:hover .cd-icon{transform:scale(1.1) rotate(-5deg)}
.cd-text strong{display:block;font-size:.875rem;font-weight:600;color:var(--text);margin-bottom:.2rem}
.cd-text p,.cd-text a{font-size:.875rem;color:var(--muted);transition:color .2s}
.cd-text a:hover{color:var(--blue)}
.contact-socials{display:flex;gap:.625rem}
.contact-social-btn{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;
  color:var(--muted);transition:all .22s}
.contact-social-btn:hover{background:var(--blue);border-color:var(--blue);color:white;transform:scale(1.1) translateY(-2px)}
.contact-form-wrap{background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:2.5rem;box-shadow:var(--sh-xl)}
.form-title{font-size:1.375rem;font-weight:700;color:var(--text);margin-bottom:.5rem;font-family:'Plus Jakarta Sans',sans-serif}
.form-sub{font-size:.9rem;color:var(--muted);margin-bottom:2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.form-group{display:flex;flex-direction:column;gap:.5rem}
.form-group label{font-size:.8125rem;font-weight:600;color:var(--text)}
.form-group input,.form-group select,.form-group textarea{
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-sm);
  padding:.75rem 1rem;color:var(--text);font-size:.9375rem;transition:all .2s var(--ease);outline:none;width:100%}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--subtle)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-group select{appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748B' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1rem center}
.form-group textarea{resize:vertical;min-height:120px}
.form-success{background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.25);
  border-radius:var(--r-sm);padding:1rem;color:#059669;font-size:.9rem;font-weight:600;text-align:center}
/* FAQ */
.faq-list{border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:last-child{border-bottom:none}
.faq-q{display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 1.5rem;font-weight:600;font-size:.9375rem;color:var(--text);
  cursor:pointer;transition:background .2s;gap:1rem;width:100%;text-align:left}
.faq-q:hover{background:var(--surface)}
.faq-chevron{width:22px;height:22px;border-radius:50%;background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size:.75rem;transition:transform .3s var(--ease),background .2s;color:var(--muted)}
.faq-item.open .faq-chevron{transform:rotate(180deg);background:var(--blue-50);color:var(--blue)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:.25rem 1.5rem 1.25rem;font-size:.9rem;color:var(--muted);line-height:1.78}

/* ══════════════════════════════════
   EMPLOYEE PORTAL
══════════════════════════════════ */
.employee-page{background:var(--surface)}
.employee-hero{min-height:calc(100vh - var(--nav-h));padding-top:var(--nav-h);
  background:#101827;position:relative;overflow:hidden;display:flex;align-items:center}
.employee-hero-bg{position:absolute;inset:0;background:
  linear-gradient(120deg,rgba(37,99,235,.38),rgba(15,23,42,.06) 38%,rgba(6,182,212,.18)),
  url("https://images.unsplash.com/photo-1497366754035-f200968a6e72?auto=format&fit=crop&w=1800&q=80") center/cover;
  opacity:.72;filter:saturate(.9)}
.employee-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,23,42,.92),rgba(15,23,42,.58),rgba(15,23,42,.86))}
.employee-hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.8fr);
  gap:4rem;align-items:center;padding-top:64px;padding-bottom:64px}
.employee-copy h1{color:white;font-size:clamp(2.2rem,5vw,4.5rem);font-weight:800;line-height:1.08;
  margin:1.15rem 0 1.25rem;max-width:720px}
.employee-copy p{color:rgba(255,255,255,.72);font-size:1.0625rem;max-width:620px}
.employee-actions{display:flex;gap:.875rem;flex-wrap:wrap;margin-top:2rem}
.employee-panel{align-self:stretch;display:flex;align-items:center;justify-content:center}
.employee-panel-head{display:flex;align-items:center;gap:.625rem;color:rgba(255,255,255,.72);
  font-size:.84rem;font-weight:600;margin-bottom:1rem}
.employee-status-dot{width:9px;height:9px;border-radius:50%;background:var(--green);
  box-shadow:0 0 0 5px rgba(16,185,129,.16)}
.employee-login-card{width:100%;max-width:420px;background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.42);
  border-radius:8px;padding:2rem;box-shadow:0 24px 70px rgba(0,0,0,.32)}
.employee-login-mark{width:62px;height:62px;border-radius:8px;background:var(--blue-50);color:var(--blue);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;border:1px solid var(--blue-100)}
.employee-login-card h2{font-size:1.55rem;margin-bottom:.625rem}
.employee-login-card p{font-size:.92rem;margin-bottom:1.35rem}
.employee-cancel{display:none;margin:1rem auto 0;color:var(--muted);font-size:.84rem;font-weight:600}
.employee-cancel.is-visible{display:block}
.employee-tools-section{background:var(--white)}
.employee-tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.employee-tool-card{display:flex;flex-direction:column;gap:.7rem;padding:1.35rem;border:1px solid var(--border);
  border-radius:8px;background:var(--white);box-shadow:var(--sh-sm);transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease)}
.employee-tool-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--blue-100)}
.employee-tool-icon{width:48px;height:48px;border-radius:8px;background:var(--blue-50);color:var(--blue);
  display:flex;align-items:center;justify-content:center;border:1px solid var(--blue-100)}
.employee-tool-icon.green{background:rgba(16,185,129,.1);color:#059669;border-color:rgba(16,185,129,.22)}
.employee-tool-icon.amber{background:rgba(245,158,11,.12);color:#B45309;border-color:rgba(245,158,11,.24)}
.employee-tool-card strong{color:var(--text);font-size:1.02rem}
.employee-tool-card span:last-child{color:var(--muted);font-size:.9rem;line-height:1.55}

/* ── CURSOR ──────────────────────────────────────────────────── */
.cursor-dot{position:fixed;width:8px;height:8px;border-radius:50%;
  background:var(--blue);pointer-events:none;z-index:9997;
  transition:transform .1s var(--ease),opacity .2s;transform:translate(-50%,-50%)}
.cursor-ring{position:fixed;width:32px;height:32px;border-radius:50%;
  border:1.5px solid rgba(37,99,235,.5);pointer-events:none;z-index:9997;
  transition:transform .2s var(--ease),opacity .3s,width .2s,height .2s;
  transform:translate(-50%,-50%)}
.cursor-dot.hidden,.cursor-ring.hidden{opacity:0}
.cursor-ring.hovering{width:48px;height:48px;border-color:var(--blue);background:rgba(37,99,235,.05)}

/* ── BACK TO TOP ─────────────────────────────────────────────── */
#back-to-top{position:fixed;bottom:2rem;right:2rem;width:48px;height:48px;
  background:var(--blue);color:white;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:1.1rem;box-shadow:0 4px 16px rgba(37,99,235,.5);
  opacity:0;transform:translateY(14px);transition:all .3s var(--ease);
  pointer-events:none;z-index:800;cursor:pointer}
#back-to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
#back-to-top:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(37,99,235,.65)}

/* ── ANIMATED COUNTING ───────────────────────────────────────── */
.count-num{display:inline-block}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1100px){
  .services-grid,.portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .tech-logos{grid-template-columns:repeat(4,1fr)}
  .footer-main{grid-template-columns:1fr 1fr}
  .svc-detail-grid{gap:3rem}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid::before{display:none}
}
@media(max-width:900px){
  :root{--nav-h:64px}
  .container{padding:0 20px}
  .section{padding:72px 0}
  .about-split,.contact-layout,.svc-detail-grid,.svc-detail-grid.reverse{grid-template-columns:1fr;direction:ltr}
  .employee-hero-inner{grid-template-columns:1fr;gap:2.5rem}
  .employee-panel{justify-content:flex-start}
  .about-split-img{display:none}
  .work-grid{grid-template-columns:1fr}
  .ind-grid,.values-grid,.mission-grid{grid-template-columns:1fr 1fr}
  .testi-card{flex:0 0 calc(50% - .75rem)}
  .portfolio-card.featured{grid-column:span 1}
  .portfolio-card.featured .pc-thumb{height:200px}
  .cursor-dot,.cursor-ring{display:none}
}
@media(max-width:768px){
  .nav-menu{position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(13,17,23,.98);
    flex-direction:column;align-items:flex-start;padding:1.5rem;gap:.25rem;
    transform:translateX(-110%);transition:transform .35s var(--ease);
    max-height:calc(100vh - var(--nav-h));overflow-y:auto;
    border-top:1px solid rgba(255,255,255,.07);backdrop-filter:blur(20px)}
  .nav-menu.open{transform:none}
  .nav-menu>li{width:100%}
  .nav-menu>li>a{width:100%;padding:.75rem 1rem}
  .mega{position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;
    background:rgba(255,255,255,.04);min-width:0;width:100%;border-radius:var(--r-sm);
    border:1px solid rgba(255,255,255,.06);flex-direction:column;gap:0;
    display:none;padding:1rem;margin-top:.5rem;backdrop-filter:none}
  .has-mega.open>.mega{display:flex}
  .nav-toggle{display:flex}
  .hero-stats{gap:1.5rem}
  .hstat-item{padding:0;border:none}
  .services-grid,.ind-grid,.values-grid,.mission-grid{grid-template-columns:1fr}
  .employee-tool-grid{grid-template-columns:1fr}
  .employee-actions{flex-direction:column;align-items:stretch}
  .work-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .tech-logos{grid-template-columns:repeat(3,1fr)}
  .form-row{grid-template-columns:1fr}
  .contact-form-wrap{padding:1.75rem}
  .footer-main{grid-template-columns:1fr 1fr}
  .cta-band .container{flex-direction:column;text-align:center}
  .cta-band-btns{justify-content:center}
  .hero-btns{flex-direction:column}
  .testi-card{flex:0 0 100%}
  .process-grid{grid-template-columns:1fr}
  [data-reveal="left"],[data-reveal="right"]{transform:translateY(28px)}
}
@media(max-width:480px){
  .footer-main{grid-template-columns:1fr}
  .tech-logos{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:1fr 1fr}
  .portfolio-card.featured{grid-column:span 1}
}
