*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --pearl:#F7F8FC;
  --snow:#FFFFFF;
  --cloud:#EEF2FA;
  --silk:#E4EAF8;
  --stone:#C8D0E8;
  --ink:#0D1B3E;
  --ink2:#1E2D5A;
  --mid:#3A4E7A;
  --blue:#1A5FCC;
  --blue2:#2272E8;
  --cyan:#0BA8E0;
  --orange:#F07224;
  --orange2:#FF9248;
  --warm:#FFF8F2;
  --warm2:#FFF2E6;
  --muted:#5A6A8A;
  --muted2:#8494B4;
  --line:rgba(26,95,204,0.12);
  --line2:rgba(26,95,204,0.07);
  --shadow:0 4px 24px rgba(13,27,62,0.08);
  --shadow2:0 12px 48px rgba(13,27,62,0.12);
  --shadow3:0 24px 80px rgba(13,27,62,0.16);
}
html{scroll-behavior:smooth}
body{font-family:"Plus Jakarta Sans",sans-serif;background:var(--pearl);color:var(--ink);overflow-x:hidden;cursor:none}

/* ── SKIP LINK (keyboard / screen-reader) ── */
.skip-link{position:absolute;top:-100px;left:16px;z-index:9999;padding:10px 20px;background:var(--blue);color:#fff;font-size:13px;font-weight:700;border-radius:6px;text-decoration:none;transition:top .2s}
.skip-link:focus{top:16px}

/* ── FOCUS STYLES ── */
:focus-visible{outline:2.5px solid var(--blue);outline-offset:3px;border-radius:4px}
a:focus-visible,button:focus-visible{outline:2.5px solid var(--orange);outline-offset:3px}

/* ── FOOTER LEGAL LINKS ── */
.f-legal-link{color:rgba(255,255,255,.28);text-decoration:none;transition:color .3s}
.f-legal-link:hover{color:var(--cyan)}

/* ── CURSOR ── */
#dot{width:9px;height:9px;background:var(--orange);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;top:0;left:0;transform:translate(-50%,-50%);transition:width .25s,height .25s}
#ring{width:32px;height:32px;border:1.5px solid var(--blue2);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;top:0;left:0;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s;opacity:.4}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:300;height:100px;display:flex;align-items:stretch;transition:height .4s,box-shadow .4s}
.nav-white{background:var(--snow);height:100px;display:flex;align-items:center;padding:0 40px 0 60px;flex-shrink:0;position:relative;z-index:2;border-right:1px solid var(--line)}
.nav-white::after{content:"";position:absolute;right:-34px;top:0;bottom:0;width:68px;background:var(--snow);clip-path:polygon(0 0,0 100%,100% 100%);z-index:1}
/* ── LOGO LOCKUP — world-class mark ────────────────────────── */
.logo-wrap{display:flex;flex-direction:row;align-items:center;height:100px;position:relative;z-index:2;padding:0 28px;gap:7px;background:var(--snow);text-decoration:none}

/* 3D extrusion — solid offset layers only, no blur shadow */
.logo-wrap img{height:62px;width:62px;object-fit:contain;display:block;flex-shrink:0;mix-blend-mode:multiply;pointer-events:none;image-rendering:-webkit-optimize-contrast;filter:drop-shadow(1px 1px 0 rgba(10,35,100,.72)) drop-shadow(2px 2px 0 rgba(10,35,100,.58)) drop-shadow(3px 3px 0 rgba(10,35,100,.42)) drop-shadow(4px 4px 0 rgba(10,35,100,.26)) drop-shadow(5px 5px 0 rgba(10,35,100,.14));transition:filter .3s,transform .3s}
.logo-wrap:hover img{filter:drop-shadow(1px 1px 0 rgba(10,35,100,.82)) drop-shadow(2px 2px 0 rgba(10,35,100,.68)) drop-shadow(3px 3px 0 rgba(10,35,100,.52)) drop-shadow(4px 4px 0 rgba(10,35,100,.36)) drop-shadow(5px 5px 0 rgba(10,35,100,.22)) drop-shadow(6px 6px 0 rgba(10,35,100,.10));transform:translateY(-2px) scale(1.03)}
.logo-wrap:hover,.logo-wrap:focus{background:var(--snow)}

/* Gradient rule between icon and wordmark */
.logo-rule{display:block;width:1px;height:38px;background:linear-gradient(to bottom,transparent,rgba(13,27,62,.18),transparent);flex-shrink:0}

/* ── WORDMARK — brand-ready for print, merch, digital ── */
.logo-text-wrap{display:flex;flex-direction:column;justify-content:center;gap:0}

/* Primary brand word — geometric sans, all-caps, deliberate tracking */
/* Scales from cap embroidery to car door to letterhead */
.logo-brand{font-family:"Plus Jakarta Sans",sans-serif;font-size:22px;font-weight:800;color:#071230;letter-spacing:5px;text-transform:uppercase;line-height:1;white-space:nowrap}

/* Brand house rule — gradient blue, fades right */
.logo-hdivider{display:block;height:1.5px;background:linear-gradient(to right,#1A5FCC,rgba(26,95,204,.15));border-radius:2px;margin:5px 0 4px;width:100%}

/* Descriptor — Fraunces italic adds prestige on letterhead & business cards */
.logo-sub{font-family:"Fraunces",serif;font-style:italic;font-size:12px;font-weight:600;color:#1A5FCC;letter-spacing:.4px;line-height:1;white-space:nowrap}

/* Tagline — tracked orange caps, brand energy */
.logo-tagline{font-family:"Plus Jakarta Sans",sans-serif;font-size:8.5px;font-weight:800;letter-spacing:3.5px;text-transform:uppercase;color:#F97316;line-height:1;white-space:nowrap;margin-top:5px}
.nav-bar{flex:1;background:var(--snow);border-bottom:1px solid var(--line2);display:flex;align-items:center;justify-content:flex-end;padding:0 44px;gap:36px;transition:all .4s}
nav.sc .nav-bar{background:rgba(255,255,255,.97);backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--line)}
nav.sc .nav-white{background:rgba(255,255,255,.97)}
nav.sc .nav-white::after{background:rgba(255,255,255,.97)}
nav.sc{box-shadow:var(--shadow)}
.nav-link{color:var(--muted);text-decoration:none;font-size:13.5px;font-weight:600;letter-spacing:.9px;text-transform:uppercase;transition:color .3s;position:relative}
.nav-link::after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--blue);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s}
.nav-link:hover{color:var(--blue)}
.nav-link:hover::after{transform:scaleX(1)}
.nav-link--active{color:var(--blue)}
.nav-link--active::after{transform:scaleX(1)}
.nav-sep{width:1px;height:20px;background:var(--line);display:inline-block;flex-shrink:0}
.nav-link--support{color:var(--muted2)}
.nav-btn{background:linear-gradient(135deg,#F97316,#EA580C);color:#fff;font-size:13px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;text-decoration:none;padding:13px 32px;border-radius:6px;transition:all .3s;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 16px rgba(249,115,22,.35)}
.nav-btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(249,115,22,.5)}

/* ── HERO ── */
.hero{min-height:100vh;position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;align-items:center;column-gap:48px;padding:0 60px;padding-top:100px;background:linear-gradient(135deg,#071230 0%,#0D1B3E 45%,#0a1f4e 100%)}
/* ambient glow orbs */
.hero-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(100px);opacity:.7;z-index:0}
.orb-1{width:620px;height:620px;background:rgba(26,95,204,.35);top:-20%;right:3%;animation:drift 20s ease-in-out infinite;will-change:transform}
.orb-2{width:420px;height:420px;background:rgba(11,168,224,.22);bottom:-5%;right:18%;animation:drift 26s 7s ease-in-out infinite reverse;will-change:transform}
.orb-3{width:340px;height:340px;background:rgba(240,114,36,.18);top:25%;left:36%;animation:drift 17s 3s ease-in-out infinite;will-change:transform}
@keyframes drift{0%,100%{transform:translate(0,0)}33%{transform:translate(28px,-22px)}66%{transform:translate(-18px,28px)}}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;background:linear-gradient(95deg,rgba(7,18,48,.9) 0%,rgba(7,18,48,.55) 45%,transparent 100%)}
.hero-grid{position:absolute;inset:0;z-index:1;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:52px 52px;animation:gridm 25s linear infinite}
@keyframes gridm{to{transform:translateY(52px)}}
/* left content */
.hero-content{position:relative;z-index:4;max-width:600px}
.h-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--cyan);margin-bottom:28px;opacity:0;animation:rise .8s .1s ease forwards}
.h-eyebrow span{width:28px;height:2px;background:linear-gradient(90deg,var(--cyan),var(--blue2));border-radius:2px;display:block}
.hero-title{font-family:"Fraunces",serif;font-size:clamp(52px,7.5vw,104px);line-height:.93;font-weight:700;color:#ffffff;margin-bottom:26px;opacity:0;animation:rise .95s .3s ease forwards;letter-spacing:-1.5px}
.hero-title .ital{font-style:italic;font-weight:400;background:linear-gradient(135deg,#6db3ff 0%,var(--cyan) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}
.hero-title .ghost{color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.2)}
.hero-body{font-size:17px;line-height:1.8;color:rgba(255,255,255,.62);max-width:460px;font-weight:400;opacity:0;animation:rise .95s .5s ease forwards;margin-bottom:42px}
.hero-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;opacity:0;animation:rise .95s .6s ease forwards}
.h-chip{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.13);border-radius:100px;padding:6px 14px;font-size:11px;font-weight:600;letter-spacing:.5px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.hero-ctas{display:flex;gap:16px;align-items:center;opacity:0;animation:rise .95s .7s ease forwards;flex-wrap:wrap}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.cta-main{background:linear-gradient(135deg,var(--orange),var(--orange2));color:var(--snow);padding:16px 38px;font-size:13px;font-weight:700;letter-spacing:.5px;text-decoration:none;display:inline-flex;align-items:center;gap:10px;border-radius:6px;transition:all .35s;position:relative;overflow:hidden;box-shadow:0 6px 24px rgba(240,114,36,.4)}
.cta-main::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--blue),var(--blue2));transform:translateX(-101%);transition:transform .4s;z-index:0}
.cta-main:hover::before{transform:translateX(0)}
.cta-main:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(26,95,204,.4)}
.cta-main span{position:relative;z-index:1}
.cta-ghost{color:var(--ink);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;text-decoration:none;display:inline-flex;align-items:center;gap:10px;padding:16px 0;border-bottom:2px solid var(--stone);transition:all .3s}
.cta-ghost:hover{color:var(--blue);border-color:var(--blue);gap:16px}
.hero-ghost{color:rgba(255,255,255,.68);font-size:13px;font-weight:600;letter-spacing:.5px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;padding:16px 0;border-bottom:2px solid rgba(255,255,255,.18);transition:all .3s}
.hero-ghost:hover{color:#fff;border-color:var(--cyan);gap:14px}
/* right: orbital sphere */
.hero-visual{position:relative;z-index:3;height:calc(100vh - 176px);min-height:400px;max-height:820px;align-self:center;display:flex;align-items:center;justify-content:center}
.h-orbit{position:absolute;top:50%;left:50%;border-radius:50%;transform:translate(-50%,-50%)}
.h-orbit-1{width:420px;height:420px;border:1px dashed rgba(26,95,204,.55);animation:h-spin 42s linear infinite;will-change:transform}
.h-orbit-2{width:278px;height:278px;border:1.5px solid rgba(11,168,224,.5);animation:h-spin 26s linear infinite reverse;will-change:transform}
.h-orbit-3{width:152px;height:152px;border:2px solid rgba(26,95,204,.65);animation:h-spin 14s linear infinite;will-change:transform}
.h-node{position:absolute;width:12px;height:12px;border-radius:50%;background:var(--cyan);box-shadow:0 0 18px rgba(11,168,224,1),0 0 36px rgba(11,168,224,.55);top:-6px;left:calc(50% - 6px)}
.h-node:nth-child(2){top:auto;bottom:-6px}
.h-node--orange{background:var(--orange);box-shadow:0 0 18px rgba(240,114,36,1),0 0 36px rgba(240,114,36,.55)}
.h-core{position:absolute;top:50%;left:50%;translate:-50% -50%;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle at 38% 35%,#FF9248,#F07224 60%,#c85a18);box-shadow:0 0 50px rgba(240,114,36,.75),0 0 100px rgba(240,114,36,.35);animation:h-breathe 3.5s ease-in-out infinite;will-change:scale;z-index:2}
.h-core-glow{position:absolute;top:50%;left:50%;translate:-50% -50%;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(240,114,36,.18) 0%,transparent 70%);animation:h-breathe 3.5s ease-in-out infinite;will-change:scale;z-index:1}
@keyframes h-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes h-breathe{0%,100%{scale:1}50%{scale:1.1}}
/* float cards */
.hero-visual .float-card{position:absolute;z-index:5}
.float-card{position:absolute;background:rgba(255,255,255,.94);border:1px solid rgba(255,255,255,.25);border-radius:12px;padding:18px 22px;box-shadow:0 12px 40px rgba(0,0,0,.3);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:5}
.fc1{top:14%;right:6%;animation:bob 7s ease-in-out infinite;width:175px}
.fc2{top:46%;left:6%;animation:bob 5s 1.3s ease-in-out infinite;width:160px;background:linear-gradient(135deg,rgba(255,245,238,.96),rgba(255,255,255,.96));border-color:rgba(240,114,36,.3)}
.fc3{bottom:12%;right:6%;animation:bob 6.5s .6s ease-in-out infinite;width:170px}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.fc-tag{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:5px}
.fc2 .fc-tag{color:var(--orange)}
.fc-val{font-family:"Fraunces",serif;font-size:28px;font-weight:700;color:var(--ink);line-height:1}
.fc-desc{font-size:11px;color:var(--muted2);margin-top:3px}
/* scroll indicator */
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.35);font-size:9px;letter-spacing:3px;text-transform:uppercase;z-index:5;pointer-events:none}
.scroll-line{width:1px;height:48px;background:linear-gradient(180deg,rgba(255,255,255,.5),transparent);animation:scroll-pulse 2s ease-in-out infinite;will-change:opacity}
@keyframes scroll-pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ── STATS ── */
.stats{background:var(--snow);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:0 60px;display:grid;grid-template-columns:repeat(4,1fr);box-shadow:var(--shadow)}
.st{padding:32px 24px;display:flex;flex-direction:column;align-items:center;border-right:1px solid var(--line);transition:background .3s}
.st:last-child{border:none}
.st:hover{background:var(--cloud)}
.st-n{font-family:"Fraunces",serif;font-size:48px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-1px}
.st-n span{color:var(--blue)}
.st-l{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);margin-top:6px;text-align:center;font-weight:600}

/* ── SHARED ── */
.sec{padding:110px 60px;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.eyebrow::before{content:"";width:22px;height:2px;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:2px;display:block}
.sec-ttl{font-family:"Fraunces",serif;font-size:clamp(36px,4.5vw,60px);font-weight:700;line-height:1.05;color:var(--ink);margin-bottom:18px;letter-spacing:-1px}
.sec-ttl em{font-style:italic;font-weight:400;background:linear-gradient(135deg,var(--blue2),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── CLIENTS ── */
.clients-strip{padding:48px 60px;background:var(--snow);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cs-label{text-align:center;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--muted2);margin-bottom:32px}
.cs-track-wrap{overflow:hidden}
.cs-track{display:flex;align-items:center;gap:48px;width:max-content;animation:cs-scroll 36s linear infinite}
.cs-track:hover{animation-play-state:paused}
.cs-logo{flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 28px;height:130px;min-width:140px;transition:box-shadow .3s,transform .3s}
.cs-logo:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.cs-logo img{max-height:90px;max-width:160px;width:auto;height:auto;object-fit:contain;display:block}
@keyframes cs-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── ABOUT ── */
.about{background:var(--snow)}
.a2{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.a-body p{font-size:16px;line-height:1.85;color:var(--muted);font-weight:400;margin-bottom:16px}
.mission{margin-top:28px;border-left:3px solid var(--blue);padding:20px 24px;background:linear-gradient(135deg,rgba(26,95,204,.04),rgba(11,168,224,.03));border-radius:0 8px 8px 0}
.m-tag{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:8px}
.mission p{font-size:14.5px;color:var(--ink2);font-style:italic;line-height:1.75;font-family:"Fraunces",serif;font-weight:400}
.vals{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}
.val{background:var(--snow);border:1.5px solid var(--line);padding:24px 20px;border-radius:10px;transition:all .4s;cursor:none;position:relative;overflow:hidden;box-shadow:0 2px 12px rgba(13,27,62,.04)}
.val:hover{border-color:var(--blue2);transform:translateY(-4px);box-shadow:var(--shadow2);background:linear-gradient(145deg,rgba(26,95,204,.03),var(--snow))}
.val::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform .4s;border-radius:10px 10px 0 0}
.val:hover::before{transform:scaleX(1)}
.val-ico{
  width:48px;height:48px;
  background:linear-gradient(135deg,rgba(26,95,204,.10),rgba(11,168,224,.07));
  border:1px solid rgba(26,95,204,.14);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
  color:var(--blue);
  transition:all .4s;
  flex-shrink:0;
}
.val-ico svg{display:block;flex-shrink:0}
.val:hover .val-ico{
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  border-color:transparent;
  color:#fff;
  box-shadow:0 6px 18px rgba(26,95,204,.30);
}
.val-nm{font-family:"Fraunces",serif;font-size:16px;font-weight:700;color:var(--ink);margin-bottom:5px}
.val-tx{font-size:12.5px;color:var(--muted);line-height:1.6}
/* ── About visual — real IT image frame ── */
.a-vis{position:relative;padding-top:28px;padding-right:28px}

/* Image fills the visual column */
.a-img{
  width:100%;height:460px;
  object-fit:cover;object-position:center 35%;
  border-radius:20px;
  display:block;
  box-shadow:var(--shadow3);
}

/* Bottom caption overlay on image */
.a-img-overlay{
  position:absolute;bottom:0;left:0;right:28px;
  border-radius:0 0 20px 20px;
  background:linear-gradient(to top,rgba(8,15,35,.88) 0%,rgba(8,15,35,.62) 55%,transparent 100%);
  padding:28px 26px 24px;
  pointer-events:none;
}
.a-img-caption{
  display:flex;align-items:center;gap:12px;
}
.a-img-caption-icon{
  width:36px;height:36px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,var(--orange),var(--orange2));
  display:flex;align-items:center;justify-content:center;
}
.a-img-caption-text strong{
  display:block;font-family:"Fraunces",serif;font-size:15px;font-weight:700;color:#fff;line-height:1.2;
}
.a-img-caption-text span{
  font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.5px;
}

/* Floating badge (top-right corner accent) */
.a-card{
  background:
    linear-gradient(165deg,rgba(13,27,62,.82) 0%,rgba(30,45,90,.78) 60%,rgba(13,27,62,.88) 100%),
    url('/images/logo.jpg') center 42% / 72% auto no-repeat,
    var(--ink);
  padding:48px;position:relative;overflow:hidden;
  min-height:400px;display:flex;flex-direction:column;justify-content:flex-end;
  border-radius:16px;box-shadow:var(--shadow3);
}
.a-card::before{content:none}
.a-badge{position:absolute;top:-24px;right:-24px;background:linear-gradient(135deg,var(--orange),var(--orange2));color:var(--snow);padding:26px;width:130px;text-align:center;border-radius:10px;box-shadow:0 12px 32px rgba(240,114,36,.35)}
.a-badge strong{font-family:"Fraunces",serif;font-size:38px;font-weight:700;display:block;line-height:1}
.a-badge span{font-size:9px;letter-spacing:2px;text-transform:uppercase;font-weight:700;opacity:.85}
.a-card h3{font-family:"Fraunces",serif;font-size:24px;font-weight:700;color:var(--snow);margin-bottom:10px;line-height:1.25}
.a-card p{font-size:13.5px;color:rgba(255,255,255,.6);line-height:1.65}

/* ── SERVICES ── */
.services{background:var(--pearl)}
.services .eyebrow{color:var(--orange)}
.services .eyebrow::before{background:linear-gradient(90deg,var(--orange),var(--orange2))}
.sv-sub{font-size:16px;color:var(--muted);max-width:520px;line-height:1.75;font-weight:400;margin-bottom:52px}
.sv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sv{background:var(--snow);padding:40px 32px;position:relative;overflow:hidden;transition:all .4s;cursor:none;border:1.5px solid var(--line);border-radius:12px;box-shadow:0 2px 12px rgba(13,27,62,.04)}
.sv:hover{border-color:var(--blue);transform:translateY(-6px);box-shadow:var(--shadow2)}
.sv:last-child{background:linear-gradient(145deg,var(--warm2),var(--snow));border-color:rgba(240,114,36,.25)}
.sv:last-child:hover{border-color:var(--orange);box-shadow:0 16px 48px rgba(240,114,36,.2)}
.sv-n{font-family:"Fraunces",serif;font-size:64px;font-weight:700;color:rgba(26,95,204,.06);position:absolute;top:12px;right:18px;line-height:1;transition:color .4s}
.sv:hover .sv-n{color:rgba(26,95,204,.1)}
.sv-ico{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:transform .35s,box-shadow .35s;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.sv-ico svg{flex-shrink:0}
.sv:hover .sv-ico{transform:rotate(-6deg) scale(1.12);box-shadow:0 6px 20px rgba(0,0,0,.14)}
.sv:nth-child(1) .sv-ico{background:linear-gradient(135deg,#E8F0FC,#C8DAFA)}
.sv:nth-child(2) .sv-ico{background:linear-gradient(135deg,#E0F4FA,#B8E8F8)}
.sv:nth-child(3) .sv-ico{background:linear-gradient(135deg,#FCE8E8,#FAC8C8)}
.sv:nth-child(4) .sv-ico{background:linear-gradient(135deg,#E8FCE8,#C8FAC8)}
.sv:nth-child(5) .sv-ico{background:linear-gradient(135deg,#FDF6E0,#FAE8B0)}
.sv:last-child .sv-ico{background:linear-gradient(135deg,#FEF0E6,#FDDCC4)}
.sv-ttl{font-family:"Fraunces",serif;font-size:19px;font-weight:700;color:var(--ink);margin-bottom:10px}
.sv-desc{font-size:13px;line-height:1.78;color:var(--muted);font-weight:400;margin-bottom:16px}
.sv-items{list-style:none;margin-bottom:22px}
.sv-items li{font-size:11.5px;color:var(--muted2);padding:5px 0;border-bottom:1px solid var(--line2);display:flex;align-items:center;gap:8px}
.sv-items li::before{content:"›";color:var(--blue);font-size:14px;font-weight:700}
.sv-more{display:inline-flex;align-items:center;gap:6px;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue);text-decoration:none;font-weight:700;transition:gap .3s,color .3s}
.sv:hover .sv-more{gap:12px;color:var(--orange)}
.sv:last-child{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;min-height:340px}
.sv:last-child .cta-main{margin-top:18px}

/* ── MARQUEE ── */
.mq{padding:40px 0;background:linear-gradient(135deg,var(--ink),var(--ink2));overflow:hidden}
.mq-t{display:flex;animation:mqs 28s linear infinite;white-space:nowrap}
.mq-i{display:flex;align-items:center;gap:28px;padding-right:56px;font-family:"Fraunces",serif;font-size:26px;font-weight:700;color:rgba(255,255,255,.15);letter-spacing:1px}
.mq-d{color:var(--orange);opacity:1;font-size:14px}
@keyframes mqs{to{transform:translateX(-50%)}}

/* ── WHY ── */
.why{background:var(--snow)}
.w2{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start}
.w-steps{display:flex;flex-direction:column}
.wst{display:flex;gap:22px;padding:28px 0;border-bottom:1px solid var(--line2);transition:all .35s;cursor:none}
.wst:first-of-type{border-top:1px solid var(--line2)}
.wst:hover{padding-left:10px}
.wst-n{font-family:"Fraunces",serif;font-size:38px;font-weight:700;color:var(--stone);min-width:50px;line-height:1;transition:color .3s}
.wst:hover .wst-n{color:var(--blue)}
.wst-c h4{font-family:"Fraunces",serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:7px}
.wst-c p{font-size:13px;line-height:1.72;color:var(--muted);font-weight:400}
.w-vis{position:relative;height:480px}
.wc{position:absolute;border-radius:16px;overflow:hidden;padding:30px}

/* ── wc1: real IT image card ── */
.wc1{width:295px;height:345px;top:0;left:0;padding:0;animation:bob 7.5s ease-in-out infinite;box-shadow:var(--shadow3)}
.wc1-img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block;transition:transform .6s ease}
.wc1:hover .wc1-img{transform:scale(1.05)}
.wc1-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,15,35,.90) 0%,rgba(8,15,35,.45) 50%,transparent 100%);padding:24px;display:flex;flex-direction:column;justify-content:flex-end}
.wc1-tag{font-size:8px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:8px}
.wc1-overlay h4{font-family:"Fraunces",serif;font-size:22px;font-weight:700;color:var(--snow);line-height:1.2}

.wc2{width:185px;height:225px;bottom:0;right:0;background:linear-gradient(135deg,var(--orange),var(--orange2));animation:bob 5.5s 1.2s ease-in-out infinite;display:flex;flex-direction:column;justify-content:center;box-shadow:0 16px 48px rgba(240,114,36,.3)}
.wc2 .qt{font-family:"Fraunces",serif;font-size:15px;color:var(--snow);line-height:1.5;font-weight:600;font-style:italic}
.wc2 cite{font-size:9px;letter-spacing:2px;color:rgba(255,255,255,.7);text-transform:uppercase;margin-top:12px;display:block;font-style:normal;font-weight:600}
.w-dots{position:absolute;bottom:50px;right:115px;display:grid;grid-template-columns:repeat(5,1fr);gap:7px}
.wd{width:5px;height:5px;border-radius:50%;background:var(--stone)}

/* ── INDUSTRIES ── */
.ind{background:var(--pearl)}
.ind .eyebrow{color:var(--cyan)}
.ind .eyebrow::before{background:linear-gradient(90deg,var(--cyan),var(--blue))}
.ind-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:48px}
.it{height:220px;position:relative;overflow:hidden;cursor:none;transition:transform .4s,box-shadow .4s;border-radius:12px;border:1.5px solid var(--line)}
.it:hover{transform:translateY(-5px) scale(1.01);box-shadow:var(--shadow3);border-color:transparent;z-index:2}
.it-bg{position:absolute;inset:0;transition:transform .5s}
.it:hover .it-bg{transform:scale(1.06)}
.it:nth-child(1) .it-bg{background:linear-gradient(145deg,#1B3A6B,#0D1B3E)}
.it:nth-child(2) .it-bg{background:linear-gradient(145deg,#5A2800,#2A1000)}
.it:nth-child(3) .it-bg{background:linear-gradient(145deg,#0A3D1A,#041A0A)}
.it:nth-child(4) .it-bg{background:linear-gradient(145deg,#2E1050,#150820)}
.it:nth-child(5) .it-bg{background:linear-gradient(145deg,#0A2545,#041020)}
.it:nth-child(6) .it-bg{background:linear-gradient(145deg,#3A2A00,#1A1200)}
.it:nth-child(7) .it-bg{background:linear-gradient(145deg,#1A3A1A,#0A1A0A)}
.it:nth-child(8) .it-bg{background:linear-gradient(145deg,#3A1A00,#1A0800)}
.it:nth-child(9) .it-bg{background:linear-gradient(145deg,#001A3A,#000A1A)}
.it:nth-child(10) .it-bg{background:linear-gradient(145deg,#1A1A3A,#0A0A1A)}
.it::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--cyan),var(--blue));opacity:0;transition:opacity .4s;z-index:3;border-radius:12px 12px 0 0}
.it:hover::after{opacity:1}
.it::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:20px 20px;opacity:0;transition:opacity .5s;z-index:2;pointer-events:none}
.it:hover::before{opacity:1}
.it-c{position:absolute;inset:0;padding:26px 24px;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(to top,rgba(13,27,62,.94) 0%,rgba(13,27,62,.2) 55%,transparent 100%)}
.it-ico{font-size:38px;margin-bottom:10px;opacity:.9;filter:drop-shadow(0 2px 8px rgba(11,168,224,.2))}
.it-nm{font-family:"Fraunces",serif;font-size:20px;font-weight:700;color:var(--snow);margin-bottom:6px}
.it-d{font-size:12px;color:rgba(255,255,255,.55);line-height:1.6;max-height:0;overflow:hidden;transition:max-height .5s,opacity .4s;font-weight:400;opacity:0}
.it:hover .it-d{max-height:90px;opacity:1}

/* ── TESTIMONIALS ── */
.testi{background:linear-gradient(155deg,var(--ink) 0%,var(--ink2) 100%);position:relative;overflow:hidden}
.testi::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 50% 50%,rgba(26,95,204,.15) 0%,transparent 65%);pointer-events:none}
.testi .eyebrow{color:var(--cyan)}
.testi .eyebrow::before{background:linear-gradient(90deg,var(--cyan),var(--blue))}
.testi .sec-ttl{color:var(--snow)}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.tc{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);padding:34px;border-radius:12px;transition:all .35s;position:relative;overflow:hidden;backdrop-filter:blur(10px)}
.tc::before{content:'"';font-family:"Fraunces",serif;font-size:110px;color:rgba(255,255,255,.05);position:absolute;top:-10px;left:14px;line-height:1}
.tc:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.3)}
.t-stars{color:var(--orange2);font-size:13px;letter-spacing:2.5px;margin-bottom:14px}
.t-q{font-family:"Fraunces",serif;font-size:15px;line-height:1.72;color:rgba(255,255,255,.88);font-style:italic;font-weight:400;margin-bottom:24px;position:relative}
.t-auth{display:flex;align-items:center;gap:12px}
.t-av{width:40px;height:40px;background:linear-gradient(135deg,var(--blue),var(--cyan));border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:"Fraunces",serif;font-size:13px;font-weight:700;color:var(--snow);flex-shrink:0}
.t-nm{font-size:13px;font-weight:700;color:var(--snow);font-family:"Fraunces",serif}
.t-ro{font-size:11px;color:rgba(255,255,255,.5)}

/* ── PROCESS ── */
.process{background:var(--pearl)}
/* Gradient connector line behind the dots */
.p2{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:64px;position:relative}
.p2::before{
  content:"";position:absolute;
  top:53px;
  left:calc(12.5% + 16px);right:calc(12.5% + 16px);
  height:2px;
  background:linear-gradient(90deg,var(--blue) 0%,var(--cyan) 33%,var(--orange) 66%,var(--orange2) 100%);
  border-radius:2px;opacity:.3;z-index:0;
}
.pst{padding:32px 26px;text-align:center;position:relative;background:var(--snow);border:1.5px solid var(--line);border-radius:12px;transition:all .4s;box-shadow:0 2px 12px rgba(13,27,62,.04)}
.pst:hover{border-color:var(--blue);transform:translateY(-4px);box-shadow:var(--shadow2)}
.p-num-bg{font-family:"Fraunces",serif;font-size:64px;font-weight:700;color:rgba(26,95,204,.06);position:absolute;top:10px;left:50%;transform:translateX(-50%);line-height:1}
.p-dot{width:44px;height:44px;background:linear-gradient(135deg,var(--blue),var(--cyan));border-radius:50%;margin:0 auto 24px;position:relative;z-index:2;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(26,95,204,.3);animation:dp 2.3s ease-in-out infinite}
.pst:nth-child(2) .p-dot{background:linear-gradient(135deg,var(--cyan),var(--orange));animation-delay:.57s}
.pst:nth-child(3) .p-dot{background:linear-gradient(135deg,var(--orange),var(--orange2));animation-delay:1.14s}
.pst:nth-child(4) .p-dot{background:linear-gradient(135deg,var(--orange2),var(--blue));animation-delay:1.7s}
@keyframes dp{0%,100%{box-shadow:0 4px 16px rgba(26,95,204,.3)}50%{box-shadow:0 4px 28px rgba(26,95,204,.5)}}
.p-num{font-family:"Fraunces",serif;font-size:18px;font-weight:700;color:var(--snow);line-height:1}
.pst h4{font-family:"Fraunces",serif;font-size:18px;font-weight:700;color:var(--ink);margin-bottom:10px}
.pst p{font-size:13px;line-height:1.72;color:var(--muted);font-weight:400}

/* ── CTA ── */
.cta-sec{
  background:
    linear-gradient(110deg,rgba(13,27,62,.97) 0%,rgba(13,27,62,.92) 45%,rgba(26,95,204,.75) 100%),
    url('/images/hero-it-arch.jpg') center 40%/cover no-repeat;
  padding:100px 60px;
  position:relative;overflow:hidden;
}
.cta-sec::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 55% 80% at 80% 50%,rgba(26,95,204,.20) 0%,transparent 65%);pointer-events:none}
.cta-sec::after{content:"UPLIFT";font-family:"Fraunces",serif;font-size:220px;font-weight:700;color:rgba(255,255,255,.03);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);letter-spacing:12px;white-space:nowrap;pointer-events:none}

/* Two-column layout */
.cta-inner{display:grid;grid-template-columns:1fr auto;gap:60px;align-items:center;position:relative;z-index:1;max-width:1100px;margin:0 auto}
.cta-left{max-width:520px}
.cta-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:14px}
.cta-eyebrow::before{content:"";width:22px;height:2px;background:linear-gradient(90deg,var(--orange),var(--orange2));border-radius:2px;display:block}
.cta-sec .sec-ttl{font-size:clamp(40px,5vw,68px);color:var(--snow);margin-bottom:16px}
.cta-sec .sec-ttl em{font-style:italic;font-weight:400;background:linear-gradient(135deg,var(--orange),var(--orange2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-sec .sub{font-size:16px;color:rgba(255,255,255,.65);max-width:440px;font-weight:400;line-height:1.8;margin:0}
.cta-right{display:flex;flex-direction:column;gap:14px;align-items:stretch;min-width:240px}
.cta-btn{background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;padding:17px 32px;font-size:13px;font-weight:700;letter-spacing:.4px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:8px;transition:all .35s;box-shadow:0 8px 28px rgba(240,114,36,.4)}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(240,114,36,.55)}
.cta-btn--ghost{background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.18);color:rgba(255,255,255,.88);box-shadow:none}
.cta-btn--ghost:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.35);box-shadow:none}
.cta-contact-info{display:flex;flex-direction:column;gap:8px;padding-top:6px}
.cta-contact-info span{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.45);font-weight:500}

/* ── FOOTER ── */
footer{background:var(--ink);padding:72px 60px 34px}
.f-top{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:52px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:30px}
.f-logo-wrap{background:var(--snow);display:inline-flex;flex-direction:row;align-items:center;gap:12px;padding:11px 15px;border-radius:8px;margin-bottom:18px;width:fit-content}
.f-logo-wrap:hover,.f-logo-wrap:focus{background:var(--snow)}
.f-logo-wrap img{height:40px;width:40px;object-fit:contain;display:block;flex-shrink:0;mix-blend-mode:multiply;pointer-events:none;image-rendering:-webkit-optimize-contrast;filter:drop-shadow(1px 1px 0 rgba(10,35,100,.72)) drop-shadow(2px 2px 0 rgba(10,35,100,.52)) drop-shadow(3px 3px 0 rgba(10,35,100,.32)) drop-shadow(4px 4px 0 rgba(10,35,100,.15))}
.f-logo-rule{display:block;width:1px;height:30px;background:linear-gradient(to bottom,transparent,rgba(13,27,62,.18),transparent);flex-shrink:0}
.f-logo-text{display:flex;flex-direction:column;gap:0}
.f-logo-brand{font-family:"Plus Jakarta Sans",sans-serif;font-size:15px;font-weight:800;color:#071230;letter-spacing:4px;text-transform:uppercase;line-height:1;white-space:nowrap}
.f-logo-hdivider{display:block;height:1.5px;background:linear-gradient(to right,#1A5FCC,rgba(26,95,204,.15));border-radius:2px;margin:4px 0 3px;width:100%}
.f-logo-sub{font-family:"Fraunces",serif;font-style:italic;font-size:10px;font-weight:600;color:#1A5FCC;letter-spacing:.4px;line-height:1;white-space:nowrap}
.f-logo-motto{font-family:"Plus Jakarta Sans",sans-serif;font-size:7.5px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:#F97316;line-height:1;white-space:nowrap;margin-top:4px}
.f-brand p{font-size:13px;line-height:1.82;color:rgba(255,255,255,.45);font-weight:400;max-width:240px;margin-bottom:24px}
.f-h{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--cyan);font-weight:700;margin-bottom:18px}
.f-links{list-style:none}
.f-links li{margin-bottom:9px}
.f-links a{font-size:13px;color:rgba(255,255,255,.45);text-decoration:none;transition:color .3s;font-weight:400}
.f-links a:hover{color:var(--cyan)}
.f-bot{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:rgba(255,255,255,.28)}
.socials{display:flex;gap:10px}
.soc{width:34px;height:34px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);text-decoration:none;font-size:12px;font-weight:700;border-radius:6px;transition:all .3s}
.soc:hover{background:var(--cyan);color:var(--ink);border-color:var(--cyan)}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(28px);transition:opacity .8s,transform .8s}
.rv.v{opacity:1;transform:translateY(0)}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}.d4{transition-delay:.48s}

/* ── RESPONSIVE ── */
/* ── HAMBURGER BUTTON ── */
.nav-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;background:none;border:none;cursor:pointer;padding:0;flex-shrink:0;z-index:10}
.nav-toggle-bar{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s,width .3s}
nav.nav--open .nav-toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
nav.nav--open .nav-toggle-bar:nth-child(2){opacity:0;width:0}
nav.nav--open .nav-toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE BACKDROP ── */
.nav-backdrop{display:none;position:fixed;inset:0;background:rgba(7,18,48,.45);z-index:198;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity .3s}
nav.nav--open .nav-backdrop{opacity:1}

/* ── TABLET (≤1100px) ── */
@media(max-width:1100px){
  .nav-white{padding:0 20px 0 20px!important}
  .nav-bar{padding:0 20px;gap:18px}
  .hero{padding:100px 28px 60px;grid-template-columns:1fr}
  .hero-visual{display:none}
  .sec{padding:80px 28px}
  .stats{padding:0 28px}
  .clients-strip{padding:40px 28px}
  .a2,.w2{grid-template-columns:1fr;gap:48px}
  .sv-grid{grid-template-columns:1fr 1fr}
  .ind-row{grid-template-columns:1fr 1fr}
  .p2{grid-template-columns:1fr 1fr;gap:14px}
  .t-grid{grid-template-columns:1fr}
  .f-top{grid-template-columns:1fr 1fr;gap:32px}
  .cta-sec{padding:72px 28px}
  .cta-inner{grid-template-columns:1fr;gap:40px}
  .cta-right{flex-direction:row;flex-wrap:wrap}
  footer{padding:52px 28px 28px}
}

/* ── MOBILE NAV (≤768px) ── */
@media(max-width:768px){
  /* Show hamburger, hide diagonal cut */
  .nav-toggle{display:flex}
  .nav-white{width:100%;justify-content:space-between;border-right:none!important}
  .nav-white::after{display:none}
  .nav-backdrop{display:block;pointer-events:none}
  nav.nav--open .nav-backdrop{pointer-events:auto}

  /* Nav bar becomes slide-down drawer */
  .nav-bar{
    position:fixed;top:100px;left:0;right:0;
    flex-direction:column;align-items:stretch;
    background:var(--snow);
    padding:12px 20px 24px;
    gap:0;
    border-top:1px solid var(--line);
    box-shadow:0 16px 40px rgba(7,18,48,.18);
    z-index:199;
    max-height:calc(100dvh - 100px);
    overflow-y:auto;
    transform:translateY(-8px);
    opacity:0;
    pointer-events:none;
    transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;
    overscroll-behavior:contain;
  }
  nav.nav--open .nav-bar{
    transform:translateY(0);
    opacity:1;
    pointer-events:auto;
  }

  /* Mobile nav links — large touch targets */
  .nav-link,.nav-link--support{
    font-size:15px;
    padding:16px 4px;
    border-bottom:1px solid var(--line2);
    display:block;
    letter-spacing:.5px;
  }
  .nav-link::after{bottom:0}
  .nav-sep{display:none}
  .nav-btn{
    display:block;
    text-align:center;
    margin-top:16px;
    padding:16px 24px;
    font-size:14px;
  }

  /* Cursor hidden on mobile */
  #dot,#ring{display:none}
}

/* ── SMALL MOBILE (≤480px) ── */
@media(max-width:480px){
  nav{height:80px}
  .nav-white{height:80px!important}
  .nav-bar{top:80px;max-height:calc(100dvh - 80px)}
  .logo-wrap{gap:10px;padding:0 16px}
  .logo-wrap img{height:44px;width:44px}
  .logo-rule{display:none}
  .logo-brand{font-size:16px;letter-spacing:3.5px}
  .logo-sub{font-size:10px}
  .logo-tagline{font-size:7px;letter-spacing:2.5px}

  .hero{padding:96px 20px 52px;min-height:0}
  .hero-title{font-size:clamp(36px,10vw,56px)}
  .hero-body{font-size:15px}
  .hero-chips{gap:6px}
  .h-chip{font-size:11px;padding:6px 10px}
  .hero-ctas{flex-direction:column;gap:12px}
  .cta-main,.hero-ghost{width:100%;text-align:center;justify-content:center}

  .sec{padding:60px 20px}
  .sec-ttl{font-size:clamp(28px,8vw,40px)}

  .stats{grid-template-columns:1fr 1fr;gap:20px;padding:0 20px}
  .stat-n{font-size:clamp(32px,9vw,48px)}

  .sv-grid,.p2,.ind-row{grid-template-columns:1fr}
  .f-top{grid-template-columns:1fr}
  .f-bot{flex-direction:column;gap:14px;text-align:center}
  .vals{grid-template-columns:1fr}

  .wc1{height:220px}
  .cta-sec{padding:60px 20px}
  footer{padding:48px 20px 24px}
  .f-logo-wrap{padding:10px 12px}
  .f-logo-wrap img{height:34px}

  .page-hero{padding:100px 20px 40px}
  .page-hero-ttl{font-size:clamp(32px,9vw,52px)}
  .page-hero-sub{font-size:15px}

  .team-grid{grid-template-columns:1fr 1fr}
  .tm-portrait{width:140px;height:140px;border-radius:20px}

  .cs-card{padding:20px;gap:20px}
  .role-card{padding:20px}
  .cta-right{flex-direction:column}
}

/* ── NAV DROPDOWN ── */
.nav-drop{position:relative;display:inline-flex;align-items:center}
.nav-drop-btn{background:none;border:none;cursor:none;color:var(--muted);font-family:"Plus Jakarta Sans",sans-serif;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;padding:0;transition:color .3s;position:relative}
.nav-drop-btn::after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--blue);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s}
.nav-drop:hover .nav-drop-btn,.nav-drop--active .nav-drop-btn{color:var(--blue)}
.nav-drop--active .nav-drop-btn::after,.nav-drop:hover .nav-drop-btn::after{transform:scaleX(1)}
.nav-drop-arrow{transition:transform .3s;flex-shrink:0}
.nav-drop:hover .nav-drop-arrow{transform:rotate(180deg)}
.nav-drop-menu{position:absolute;top:calc(100% + 18px);right:0;background:var(--snow);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow3);min-width:260px;padding:8px;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .25s,transform .25s;z-index:400}
.nav-drop:hover .nav-drop-menu{opacity:1;pointer-events:auto;transform:translateY(0)}
.nav-drop-item{display:flex;align-items:flex-start;gap:14px;padding:12px 14px;border-radius:8px;text-decoration:none;transition:background .2s;color:var(--ink)}
.nav-drop-item:hover,.nav-drop-item--active{background:var(--cloud)}
.ndi-ico{font-size:20px;width:28px;flex-shrink:0;margin-top:2px}
.ndi-label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:2px}
.ndi-sub{display:block;font-size:11px;color:var(--muted2)}
.nav-drop-item--active .ndi-label{color:var(--blue)}

/* ── PAGE HERO (inner pages) ── */
.page-hero{padding:160px 60px 80px;background:linear-gradient(155deg,var(--snow) 0%,var(--cloud) 50%,var(--silk) 100%);position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(26,95,204,.06) 0%,transparent 60%);pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:700px}
.page-hero-ttl{font-family:"Fraunces",serif;font-size:clamp(44px,6vw,80px);line-height:.95;font-weight:700;color:var(--ink);margin:16px 0 24px;letter-spacing:-1.5px}
.page-hero-ttl em{font-style:italic;font-weight:400;background:linear-gradient(135deg,var(--blue2) 0%,var(--cyan) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.page-hero-sub{font-size:17px;line-height:1.8;color:var(--muted);max-width:520px}
@media(max-width:900px){.page-hero{padding:140px 28px 60px}}
@media(max-width:680px){.page-hero{padding:120px 20px 48px}}

/* ── OUR TEAM ── */
/* ═══════════════════════════════════════════════════════
   TEAM SECTION  ·  "Dark Grid" layout
   Navy background · hex pattern · orange-frame portraits
   ═══════════════════════════════════════════════════════ */

.team-sec{
  background:var(--ink);
  position:relative;overflow:hidden;
}

/* Subtle hex-dot grid background */
.team-sec::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:28px 28px;
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);
}

/* Section heading overrides for dark bg */
.team-sec .eyebrow{color:var(--orange);border-color:var(--orange)}
.team-sec .eyebrow::before{background:var(--orange)}
.team-sec .sec-ttl{color:#fff}
.team-sec .sec-ttl em{background:linear-gradient(135deg,var(--orange) 0%,var(--orange2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:italic}
.team-sec > p{color:rgba(255,255,255,.55)!important}

/* Grid — 3 up by default, centred last row */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  align-items:start;
}

/* ── Card shell ── */
.tm-card{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:0;background:transparent;
  border:none;border-radius:0;
  transition:transform .4s;
}
.tm-card:hover{transform:translateY(-6px)}

/* ── Portrait wrapper — dark squircle frame ── */
.tm-portrait{
  position:relative;
  width:190px;height:190px;
  border-radius:28px;
  background:#07101E;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:22px;
  box-shadow:0 2px 0 0 rgba(240,114,36,.7),0 8px 32px rgba(0,0,0,.45);
  transition:box-shadow .4s;
  overflow:hidden;
  border:1.5px solid rgba(240,114,36,.22);
}
.tm-card:hover .tm-portrait{box-shadow:0 2px 0 0 rgba(240,114,36,.9),0 16px 48px rgba(0,0,0,.55)}

/* Actual photo — fills the squircle, no clip needed */
.tm-photo{
  width:100%;height:100%;
  object-fit:cover;object-position:top center;
  display:block;
  transition:transform .6s ease;
}
.tm-card:hover .tm-photo{transform:scale(1.04)}
.tm-portrait-overlay{display:none}

/* ═══════════════════════════════════════════════════════
   PLACEHOLDER  ·  "Half-Split"
   Navy dot-grid top · diagonal orange base · monogram
   ═══════════════════════════════════════════════════════ */

.tm-fallback{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  background:#06101C;
  position:relative;overflow:hidden;
}

/* Dot grid — visible in the dark top half only */
.tm-fallback::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(255,255,255,.10) 1px,transparent 1px);
  background-size:16px 16px;
  -webkit-mask-image:linear-gradient(to bottom,black 0%,black 38%,transparent 62%);
  mask-image:linear-gradient(to bottom,black 0%,black 38%,transparent 62%);
  z-index:1;
}

/* Orange bottom half — bold, bright at split edge, deep at bottom */
.tm-fallback::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background:linear-gradient(to bottom,
    #FF9A3C 0%,
    var(--orange) 35%,
    #C04408 75%,
    #8B2E04 100%
  );
  clip-path:polygon(0 50%,100% 38%,100% 100%,0 100%);
}

/* Glowing split edge line */
.tm-split-line{
  position:absolute;left:0;right:0;height:3px;z-index:3;
  /* angled to match the clip-path: left at 50%, right at 38% */
  top:calc(50% - 1px);
  transform-origin:left center;
  transform:rotate(-6.8deg) translateY(-50%);
  background:linear-gradient(90deg,
    rgba(255,200,100,.0) 0%,
    rgba(255,190,80,.9)  18%,
    rgba(255,255,200,1)  50%,
    rgba(255,190,80,.9)  82%,
    rgba(255,200,100,.0) 100%
  );
  filter:blur(1.5px);
  pointer-events:none;
}

/* ── Badge — centred on the split line ── */
.tm-fallback-badge{
  width:82px;height:82px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:4;
  background:linear-gradient(150deg,#172560 0%,#070E28 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.14),
    0 0 0 2.5px rgba(255,160,50,.90),
    0 0 0 7px  rgba(255,130,30,.20),
    0 0 0 14px rgba(240,114,36,.08),
    0 0 32px   rgba(255,140,40,.50);
  transform:translateY(-4px);
}

/* Initials */
.tm-fallback-initials{
  font-family:"Fraunces",serif;
  font-size:23px;font-weight:700;letter-spacing:2px;
  background:linear-gradient(150deg,#FFFFFF 0%,#FFD4AA 55%,var(--orange2) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;user-select:none;
  position:relative;z-index:1;
  filter:drop-shadow(0 0 7px rgba(240,114,36,.6));
}

@keyframes aurora-spin{
  from{transform:rotate(0deg)}
  to  {transform:rotate(360deg)}
}

/* ── Card body ── */
.tm-body{padding:0 8px;display:flex;flex-direction:column;align-items:center;flex:1}
.tm-identity{margin-bottom:10px}
.tm-name{
  font-family:"Fraunces",serif;
  font-size:16px;font-weight:700;
  color:#fff;letter-spacing:.5px;
  text-transform:uppercase;margin-bottom:5px;
}
.tm-role{
  font-size:11px;font-weight:600;letter-spacing:.8px;
  color:var(--orange);font-style:italic;
}
.tm-bio{
  font-size:12px;line-height:1.85;
  color:rgba(255,255,255,.45);
  flex:1;margin-bottom:14px;max-width:240px;
}
.tm-tags{display:flex;flex-wrap:wrap;gap:5px;justify-content:center}
.tm-tag{
  font-size:9px;font-weight:700;letter-spacing:.6px;
  text-transform:uppercase;
  color:var(--orange2);
  background:rgba(240,114,36,.12);
  border:1px solid rgba(240,114,36,.22);
  padding:3px 9px;border-radius:20px;
}

/* team.blade.php avatar variant (sidebar style) */
.tm-top{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.tm-avatar{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--orange) 0%,#B04A10 100%);
  display:flex;align-items:center;justify-content:center;
  font-family:"Fraunces",serif;font-size:14px;font-weight:700;
  color:#fff;letter-spacing:1px;
  box-shadow:0 0 0 2px rgba(240,114,36,.35);
}

.team-join{background:var(--ink2);text-align:center}
.team-join-inner{max-width:560px;margin:0 auto}
.team-join .eyebrow{color:var(--orange);border-color:var(--orange)}
.team-join .eyebrow::before{background:var(--orange)}
.team-join .sec-ttl{color:#fff}
.team-join .sec-ttl em{background:linear-gradient(135deg,var(--orange) 0%,var(--orange2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

@media(max-width:1100px){.team-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:780px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.team-grid{grid-template-columns:1fr}.tm-portrait{width:160px;height:160px;border-radius:24px}.tm-photo,.tm-fallback{width:140px;height:140px}}

/* ── CASE STUDIES ── */
.cs-sec{background:var(--pearl)}
.cs-list{display:flex;flex-direction:column;gap:64px}
.cs-card{display:grid;grid-template-columns:1fr 340px;gap:52px;align-items:start;padding:48px;background:var(--snow);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow)}
.cs-card--flip{grid-template-columns:340px 1fr}
.cs-card--flip .cs-content{order:2}
.cs-card--flip .cs-aside{order:1}
.cs-meta{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.cs-tag{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--snow);background:var(--blue);padding:5px 12px;border-radius:20px}
.cs-sector{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.5px}
.cs-sector svg{width:13px;height:13px;flex-shrink:0;vertical-align:middle}
.cs-title{font-family:"Fraunces",serif;font-size:clamp(22px,2.5vw,30px);font-weight:700;color:var(--ink);line-height:1.2;margin-bottom:28px}
.cs-block{margin-bottom:24px}
.cs-block-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.cs-block p{font-size:15px;line-height:1.8;color:var(--muted)}
.cs-outcomes{padding-left:20px;list-style:none}
.cs-outcomes li{font-size:14px;line-height:1.75;color:var(--muted);padding-left:20px;position:relative;margin-bottom:6px}
.cs-outcomes li::before{content:"✓";position:absolute;left:0;color:var(--blue);font-weight:700}
.cs-aside{display:flex;flex-direction:column;gap:24px;position:sticky;top:108px}
.cs-client-card{background:linear-gradient(135deg,var(--cloud) 0%,var(--silk) 100%);border:1px solid var(--line);border-radius:16px;padding:32px;text-align:center}
.cs-client-icon{
  width:64px;height:64px;border-radius:16px;
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue2) 100%);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
  box-shadow:0 8px 24px rgba(26,95,204,.25);
}
.cs-client-icon svg{width:28px;height:28px;stroke:white;flex-shrink:0}
.cs-client-name{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:6px}
.cs-client-sector{font-size:12px;color:var(--muted);letter-spacing:.5px;font-weight:500}
.cs-quote{background:var(--ink);border-radius:16px;padding:32px;margin:0;position:relative;overflow:hidden}
.cs-quote::before{content:'\201C';position:absolute;top:-10px;left:20px;font-family:"Fraunces",serif;font-size:120px;color:rgba(255,255,255,.06);line-height:1;pointer-events:none}
.cs-quote p{font-family:"Fraunces",serif;font-size:16px;font-style:italic;line-height:1.75;color:rgba(255,255,255,.88);margin-bottom:20px;position:relative;z-index:1}
.cs-quote cite{font-size:12px;font-weight:600;color:var(--cyan);letter-spacing:.5px;font-style:normal;display:block;position:relative;z-index:1}
/* Featured (first) case study — LAMU */
.cs-card--featured{
  border-color:rgba(26,95,204,.18);
  box-shadow:0 12px 48px rgba(13,27,62,.10);
  position:relative;overflow:hidden;
}
.cs-card--featured::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--violet),var(--blue2),var(--cyan));
  border-radius:20px 20px 0 0;
}
/* LAMU logo in client card */
.cs-client-card--lamu{
  background:linear-gradient(135deg,#EEF2FA 0%,#E4EAF8 100%);
  border-color:rgba(26,95,204,.15);
}
.cs-client-logo-wrap{
  width:140px;height:80px;
  display:flex;align-items:center;justify-content:center;
  background:var(--snow);
  border:1px solid var(--line);
  border-radius:12px;
  margin:0 auto 16px;
  padding:12px 16px;
  box-shadow:0 4px 16px rgba(13,27,62,.06);
}
.cs-client-logo{max-width:110px;max-height:52px;width:auto;height:auto;object-fit:contain;display:block}

@media(max-width:1024px){.cs-card,.cs-card--flip{grid-template-columns:1fr}.cs-card--flip .cs-content,.cs-card--flip .cs-aside{order:unset}.cs-aside{position:static}.cs-card{padding:32px}}
@media(max-width:680px){.cs-card{padding:24px;gap:28px}}

/* ── CAREERS HERO ── */
.careers-hero{
  position:relative;overflow:hidden;
  min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:120px 60px 80px;
  background:linear-gradient(145deg,#060f26 0%,#0a1840 50%,#0d1f52 100%);
  text-align:center;
}
.ch-grid{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:48px 48px;
}
.ch-bg-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(110px)}
.ch-orb1{width:560px;height:560px;background:rgba(26,95,204,.3);top:-15%;left:-10%;animation:drift 22s ease-in-out infinite}
.ch-orb2{width:380px;height:380px;background:rgba(240,114,36,.18);bottom:-10%;right:5%;animation:drift 18s 5s ease-in-out infinite reverse}

.ch-inner{position:relative;z-index:2;max-width:680px}

/* Status badge */
.ch-status{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);
  border-radius:100px;
  padding:8px 18px;
  font-size:12px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  margin-bottom:36px;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.ch-pulse{
  position:relative;width:8px;height:8px;border-radius:50%;
  background:#F07224;flex-shrink:0;will-change:transform;
}
.ch-pulse::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:#F07224;opacity:.7;
  animation:pulse-ring 2s ease-out infinite;
  will-change:transform,opacity;
}
@keyframes pulse-ring{
  0%  {scale:1;opacity:.7}
  70% {scale:3;opacity:0}
  100%{scale:1;opacity:0}
}

.ch-title{
  font-family:"Fraunces",serif;
  font-size:clamp(52px,9vw,96px);
  line-height:.9;letter-spacing:-2px;
  font-weight:700;color:#fff;
  margin-bottom:28px;
}
.ch-soon{
  font-style:italic;font-weight:300;
  background:linear-gradient(135deg,var(--orange2) 0%,var(--orange) 50%,var(--cyan) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  display:block;
}
.ch-sub{
  font-size:clamp(15px,2vw,18px);line-height:1.8;
  color:rgba(255,255,255,.58);
  max-width:540px;margin:0 auto 52px;
}

/* Action cards */
.ch-cards{
  display:grid;grid-template-columns:1fr 1fr;
  gap:16px;margin-bottom:36px;text-align:left;
}
.ch-card{
  border-radius:16px;padding:28px;
  display:flex;flex-direction:column;gap:16px;
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  transition:transform .3s,box-shadow .3s;
}
.ch-card:hover{transform:translateY(-4px)}
.ch-card--primary{
  background:rgba(26,95,204,.22);
  border:1px solid rgba(26,95,204,.45);
  box-shadow:0 8px 32px rgba(26,95,204,.2);
}
.ch-card--primary:hover{box-shadow:0 16px 48px rgba(26,95,204,.35)}
.ch-card--secondary{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
}
.ch-card--secondary:hover{box-shadow:0 16px 48px rgba(0,0,0,.3)}
.ch-card-icon{
  width:44px;height:44px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);flex-shrink:0;
}
.ch-card-title{font-size:15px;font-weight:700;color:#fff;margin-bottom:6px}
.ch-card-text{font-size:13px;line-height:1.7;color:rgba(255,255,255,.5);flex:1}
.ch-card-btn{
  display:inline-flex;align-items:center;
  font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  text-decoration:none;padding:11px 20px;border-radius:8px;
  transition:all .3s;align-self:flex-start;
}
.ch-card--primary .ch-card-btn{background:var(--blue2);color:#fff;box-shadow:0 4px 14px rgba(26,95,204,.4)}
.ch-card--primary .ch-card-btn:hover{background:var(--blue);box-shadow:0 8px 24px rgba(26,95,204,.55)}
.ch-card-btn--ghost{
  border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.75);
}
.ch-card-btn--ghost:hover{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.45)}

.ch-social-hint{font-size:13px;color:rgba(255,255,255,.38)}
.ch-social-hint a{color:rgba(255,255,255,.65);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.25);transition:color .2s,border-color .2s}
.ch-social-hint a:hover{color:#fff;border-color:rgba(255,255,255,.6)}

/* Floating metrics bar */
.ch-metrics{
  position:relative;z-index:2;
  display:flex;align-items:center;gap:32px;
  margin-top:64px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:100px;padding:18px 40px;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.ch-metric{display:flex;flex-direction:column;align-items:center;gap:2px}
.ch-metric-n{font-family:"Fraunces",serif;font-size:22px;font-weight:700;color:#fff;line-height:1}
.ch-metric-l{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.4);font-weight:600}
.ch-metric-div{width:1px;height:32px;background:rgba(255,255,255,.15)}

/* ── CAREERS SECTIONS ── */
.careers-why{background:var(--pearl)}
.careers-vals{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.cv-card{background:var(--snow);border:1px solid var(--line);border-radius:14px;padding:28px;transition:box-shadow .3s,transform .3s}
.cv-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.cv-icon{font-size:32px;margin-bottom:16px}
.cv-title{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:10px}
.cv-text{font-size:14px;line-height:1.75;color:var(--muted)}
.careers-roles{background:var(--cloud)}
.roles-list{display:flex;flex-direction:column;gap:24px}
.role-card{background:var(--snow);border:1px solid var(--line);border-radius:16px;padding:36px;transition:box-shadow .3s}
.role-card:hover{box-shadow:var(--shadow2)}
.role-header{display:flex;align-items:center;gap:20px;margin-bottom:20px}
.role-icon{width:52px;height:52px;border-radius:12px;background:var(--cloud);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.role-title{font-size:20px;font-weight:700;color:var(--ink);margin-bottom:6px}
.role-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.role-badge{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--snow);background:var(--blue);padding:3px 10px;border-radius:20px}
.role-location{font-size:12px;color:var(--muted);font-weight:500}
.role-desc{font-size:15px;line-height:1.8;color:var(--muted);margin-bottom:20px}
.role-reqs{background:var(--cloud);border-radius:10px;padding:20px 24px;margin-bottom:24px}
.role-reqs-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--blue);margin-bottom:12px}
.role-reqs ul{padding-left:18px;list-style:none}
.role-reqs li{font-size:14px;line-height:1.75;color:var(--muted);padding-left:18px;position:relative;margin-bottom:4px}
.role-reqs li::before{content:"→";position:absolute;left:0;color:var(--blue);font-weight:700}
.role-apply{display:inline-flex;align-items:center;gap:8px;color:var(--blue);font-size:13px;font-weight:700;letter-spacing:.5px;text-decoration:none;border:2px solid var(--blue);border-radius:6px;padding:10px 22px;transition:all .3s}
.role-apply:hover{background:var(--blue);color:var(--snow)}
.careers-open{background:var(--pearl)}
@media(max-width:1024px){.careers-vals{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.careers-vals{grid-template-columns:1fr}.role-card{padding:24px}}

/* ── SOLUTIONS PAGE ── */
.sol-deep{background:var(--pearl)}
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.sol-card{background:var(--snow);border:1px solid var(--line);border-radius:16px;padding:32px;transition:box-shadow .3s,transform .3s}
.sol-card:hover{box-shadow:var(--shadow2);transform:translateY(-4px)}
.sol-ico{font-size:32px;margin-bottom:12px}
.sol-name{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:16px}
.sol-pain-label,.sol-solve-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px}
.sol-pain-label{color:var(--orange)}
.sol-solve-label{color:var(--blue)}
.sol-pain{font-size:13px;line-height:1.7;color:var(--muted);margin-bottom:16px}
.sol-sep{height:1px;background:var(--line);margin-bottom:16px}
.sol-solve{font-size:13px;line-height:1.7;color:var(--muted)}
@media(max-width:1024px){.sol-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.sol-grid{grid-template-columns:1fr}}

/* ── RESOURCES PAGE ── */
.res-guides{background:var(--pearl)}
.guides-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.guide-card{background:var(--snow);border:1px solid var(--line);border-radius:16px;padding:32px;display:flex;flex-direction:column;transition:box-shadow .3s,transform .3s}
.guide-card:hover{box-shadow:var(--shadow2);transform:translateY(-3px)}
.guide-ico{font-size:32px;margin-bottom:12px}
.guide-tag{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue);margin-bottom:10px;display:inline-block}
.guide-title{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:10px}
.guide-desc{font-size:13px;line-height:1.75;color:var(--muted);flex:1;margin-bottom:20px}
.guide-cta{color:var(--blue);font-size:12px;font-weight:700;letter-spacing:.5px;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.guide-cta:hover{gap:10px}
.res-method{background:var(--cloud)}
.res-faq{background:var(--pearl)}
.faq-list{max-width:720px;display:flex;flex-direction:column;gap:4px;margin-top:40px}
.faq-item{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--snow)}
.faq-item[open]{border-color:var(--blue)}
.faq-q{padding:20px 24px;font-size:15px;font-weight:600;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:color .2s}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{content:"+";font-size:20px;font-weight:300;color:var(--blue);flex-shrink:0;transition:transform .3s}
.faq-item[open] .faq-q{color:var(--blue)}
.faq-item[open] .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:0 24px 20px;font-size:14px;line-height:1.8;color:var(--muted)}
@media(max-width:1024px){.guides-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.guides-grid{grid-template-columns:1fr}}

/* ── SUPPORT PAGE ── */
.sup-channels{background:var(--pearl)}
.channels-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.channel-card{background:var(--snow);border:1px solid var(--line);border-radius:16px;padding:36px;text-align:center;transition:box-shadow .3s,transform .3s}
.channel-card:hover{box-shadow:var(--shadow2);transform:translateY(-4px)}
.channel-ico{font-size:40px;margin-bottom:16px}
.channel-title{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:8px}
.channel-detail{font-size:15px;color:var(--blue);font-weight:600;margin-bottom:6px}
.channel-hours{font-size:12px;color:var(--muted);margin-bottom:24px;letter-spacing:.3px}
.channel-btn{display:inline-flex;align-items:center;gap:8px;background:var(--cloud);color:var(--ink);font-size:13px;font-weight:700;letter-spacing:.5px;text-decoration:none;padding:12px 24px;border-radius:6px;transition:all .3s}
.channel-btn:hover{background:var(--blue);color:var(--snow)}
.sup-tiers{background:var(--ink);padding:100px 60px}
.tiers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1100px;margin:0 auto}
.tier-card{border-radius:20px;padding:36px;position:relative;display:flex;flex-direction:column;gap:0}
.tier-card--featured{transform:scale(1.04);box-shadow:0 24px 80px rgba(26,95,204,.35)}
.tier-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--orange);color:var(--snow);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:5px 16px;border-radius:20px;white-space:nowrap}
.tier--blue{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1)}
.tier--orange{background:linear-gradient(135deg,rgba(26,95,204,.3),rgba(11,168,224,.2));border:1px solid rgba(26,95,204,.5)}
.tier--ink{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08)}
.tier-name{font-family:"Fraunces",serif;font-size:24px;font-weight:700;color:var(--snow);margin-bottom:6px}
.tier-desc{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:24px}
.tier-stat-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px;padding:16px;background:rgba(255,255,255,.05);border-radius:10px}
.tier-stat-val{font-size:14px;font-weight:700;color:var(--cyan);margin-bottom:3px}
.tier-stat-lbl{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.4)}
.tier-items{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px;flex:1;margin-bottom:28px}
.tier-items li{font-size:13px;color:rgba(255,255,255,.75);padding-left:20px;position:relative}
.tier-items li::before{content:"✓";position:absolute;left:0;color:var(--cyan);font-weight:700}
.tier-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,.1);color:var(--snow);font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;text-decoration:none;padding:13px 24px;border-radius:8px;transition:all .3s;border:1px solid rgba(255,255,255,.15)}
.tier-cta:hover{background:var(--blue);border-color:var(--blue)}
.tier-card--featured .tier-cta{background:var(--blue);border-color:var(--blue)}
.tier-card--featured .tier-cta:hover{background:var(--blue2)}
@media(max-width:900px){.sup-tiers{padding:80px 28px}.tiers-grid{grid-template-columns:1fr;max-width:480px}.tier-card--featured{transform:none}}
@media(max-width:680px){.channels-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════
   WORLD-CLASS PREMIUM REDESIGN  ·  Uplift Services Limited
   Richer palette · Deeper hero · Vibrant sections
   ═══════════════════════════════════════════════════════════ */

/* ── Extended palette ─────────────────────────────────────── */
:root{
  --violet:#7C3AED;
  --violet2:#A78BFA;
  --emerald:#10B981;
  --emerald2:#34D399;
  --rose:#F43F5E;
  --gold:#F59E0B;
  --deep:#020818;
  --deep2:#030D1E;
}

/* ── HERO — Full spectrum rework ──────────────────────────── */
.hero{background:linear-gradient(140deg,#020818 0%,#04112E 22%,#060D26 52%,#030A1C 78%,#020818 100%)}

/* Orbs — bigger, richer, more vibrant */
.orb-1{width:760px;height:760px;background:radial-gradient(circle at 42% 40%,rgba(124,58,237,.44) 0%,rgba(26,95,204,.22) 50%,transparent 72%);filter:blur(120px);top:-22%;right:-2%}
.orb-2{width:520px;height:520px;background:radial-gradient(circle at 50% 50%,rgba(11,168,224,.30) 0%,rgba(124,58,237,.13) 55%,transparent 78%);filter:blur(100px);bottom:-8%;right:22%}
.orb-3{width:400px;height:400px;background:radial-gradient(circle at 50% 50%,rgba(240,114,36,.28) 0%,rgba(255,146,72,.13) 55%,transparent 78%);filter:blur(88px);top:22%;left:34%}
/* 4th orb — emerald teal, bottom-left */
.orb-4{position:absolute;border-radius:50%;pointer-events:none;will-change:transform;z-index:0;width:380px;height:380px;background:radial-gradient(circle at 50% 50%,rgba(16,185,129,.20) 0%,transparent 70%);filter:blur(90px);bottom:4%;left:-7%;animation:drift 24s 6s ease-in-out infinite reverse}

/* Grid lines brighter */
.hero-grid{background-image:linear-gradient(rgba(255,255,255,.056) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.056) 1px,transparent 1px);background-size:48px 48px}

/* Left content overlay — slightly lighter for contrast */
.hero::before{background:linear-gradient(95deg,rgba(2,8,24,.92) 0%,rgba(2,8,24,.55) 42%,transparent 100%)}

/* Title italic — vivid violet→cyan gradient */
.hero-title .ital{background:linear-gradient(135deg,#A78BFA 0%,#60A5FA 42%,#22D3EE 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
/* Ghost outline — soft violet stroke */
.hero-title .ghost{-webkit-text-stroke:1.5px rgba(167,139,250,.22);color:transparent}

/* Body brighter */
.hero-body{color:rgba(255,255,255,.74)}

/* Chips — glassmorphism with hover gradient border */
.h-chip{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.90);transition:all .3s}
.h-chip:hover{background:rgba(124,58,237,.20);border-color:rgba(167,139,250,.55);color:#fff;transform:translateY(-2px);box-shadow:0 4px 18px rgba(124,58,237,.28)}

/* Float cards — dark glassmorphism */
.float-card{background:rgba(5,13,36,.86);border:1px solid rgba(255,255,255,.12);box-shadow:0 22px 64px rgba(0,0,0,.58),0 0 0 1px rgba(255,255,255,.04) inset,0 0 50px rgba(124,58,237,.07) inset}
.fc-tag{color:var(--cyan)}
.fc2 .fc-tag{color:var(--orange2)}
.fc-val{color:#ffffff}
.fc-desc{color:rgba(255,255,255,.42)}

/* Orbital nodes — dual-glow */
.h-node{width:14px;height:14px;top:-7px;left:calc(50% - 7px);background:linear-gradient(135deg,var(--cyan),var(--violet2));box-shadow:0 0 24px rgba(11,168,224,.95),0 0 60px rgba(124,58,237,.45),0 0 5px rgba(255,255,255,.9)}
.h-node:nth-child(2){top:auto;bottom:-7px}
.h-node--orange{background:linear-gradient(135deg,var(--orange),var(--orange2));box-shadow:0 0 24px rgba(240,114,36,1),0 0 60px rgba(240,114,36,.45),0 0 5px rgba(255,255,255,.8)}

/* Orbit ring colours */
.h-orbit-1{border-color:rgba(124,58,237,.42)}
.h-orbit-2{border-color:rgba(11,168,224,.52)}
.h-orbit-3{border-color:rgba(240,114,36,.62)}

/* Core sphere — richer radial + triple glow halo */
.h-core{background:radial-gradient(circle at 36% 32%,#FFAB72,#F07224 55%,#B84E14);box-shadow:0 0 60px rgba(240,114,36,.88),0 0 130px rgba(240,114,36,.42),0 0 220px rgba(124,58,237,.22)}
.h-core-glow{width:300px;height:300px;background:radial-gradient(circle,rgba(240,114,36,.24) 0%,rgba(124,58,237,.10) 50%,transparent 70%)}

/* Eyebrow line — violet-to-cyan */
.h-eyebrow span{background:linear-gradient(90deg,var(--violet2),var(--cyan))}

/* ── STATS STRIP — Dark premium ───────────────────────────── */
.stats{background:linear-gradient(135deg,#030D1E 0%,#061635 48%,#030D1E 100%);border:none;border-top:1px solid rgba(255,255,255,.055);border-bottom:1px solid rgba(255,255,255,.055);box-shadow:none;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 72% 200% at 50% 50%,rgba(26,95,204,.11) 0%,transparent 70%)}
.st{padding:42px 24px;border-right-color:rgba(255,255,255,.065)}
.st:hover{background:rgba(255,255,255,.025)}
.st-n{color:#ffffff;letter-spacing:-1.5px}
.st-n span{color:var(--cyan)}
.st-l{color:rgba(255,255,255,.38);letter-spacing:2.5px}

/* Per-stat glow accent */
.st:nth-child(1) .st-n{text-shadow:0 0 42px rgba(26,95,204,.6)}
.st:nth-child(1) .st-n span{color:#60A5FA}
.st:nth-child(2) .st-n{text-shadow:0 0 42px rgba(240,114,36,.5)}
.st:nth-child(2) .st-n span{color:var(--orange2)}
.st:nth-child(3) .st-n{text-shadow:0 0 42px rgba(16,185,129,.42)}
.st:nth-child(3) .st-n span{color:var(--emerald2)}
.st:nth-child(4) .st-n{text-shadow:0 0 42px rgba(124,58,237,.42)}
.st:nth-child(4) .st-n span{color:var(--violet2)}

/* ── CLIENTS STRIP ────────────────────────────────────────── */
.clients-strip{background:linear-gradient(180deg,var(--snow) 0%,var(--cloud) 100%)}
.cs-logo{border-radius:14px;background:var(--snow);box-shadow:0 2px 12px rgba(13,27,62,.06)}
.cs-logo:hover{box-shadow:0 8px 32px rgba(26,95,204,.14);border-color:rgba(26,95,204,.2)}

/* ── ABOUT SECTION ────────────────────────────────────────── */
.about{background:linear-gradient(160deg,var(--snow) 0%,var(--cloud) 60%,var(--silk) 100%)}

/* ── SERVICES — Gradient-border hover cards ───────────────── */
.services{background:var(--pearl)}
.sv{border-radius:14px;position:relative}
/* Gradient glow border via mask trick */
.sv::after{content:"";position:absolute;inset:0;border-radius:14px;padding:1.5px;background:linear-gradient(135deg,var(--violet),var(--cyan),var(--orange));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s;pointer-events:none;z-index:0}
.sv:hover::after{opacity:1}
.sv:hover{border-color:transparent;box-shadow:0 24px 64px rgba(13,27,62,.13),0 0 50px rgba(124,58,237,.08)}

/* Richer icon bg per service */
.sv:nth-child(1) .sv-ico{background:linear-gradient(135deg,#DBEAFE,#BFDBFE);box-shadow:0 4px 16px rgba(26,95,204,.18)}
.sv:nth-child(2) .sv-ico{background:linear-gradient(135deg,#CFFAFE,#A5F3FC);box-shadow:0 4px 16px rgba(11,168,224,.18)}
.sv:nth-child(3) .sv-ico{background:linear-gradient(135deg,#FFE4E6,#FECDD3);box-shadow:0 4px 16px rgba(244,63,94,.18)}
.sv:nth-child(4) .sv-ico{background:linear-gradient(135deg,#D1FAE5,#A7F3D0);box-shadow:0 4px 16px rgba(16,185,129,.18)}
.sv:nth-child(5) .sv-ico{background:linear-gradient(135deg,#EDE9FE,#DDD6FE);box-shadow:0 4px 16px rgba(124,58,237,.18)}
.sv:nth-child(6) .sv-ico{background:linear-gradient(135deg,#FEF3C7,#FDE68A);box-shadow:0 4px 16px rgba(245,158,11,.18)}
.sv:nth-child(7) .sv-ico{background:linear-gradient(135deg,#DCFCE7,#BBF7D0);box-shadow:0 4px 16px rgba(16,185,129,.18)}
.sv:nth-child(8) .sv-ico{background:linear-gradient(135deg,#DBEAFE,#BAE6FD);box-shadow:0 4px 16px rgba(26,95,204,.18)}
.sv:nth-child(9) .sv-ico{background:linear-gradient(135deg,#FFE4E6,#FBCFE8);box-shadow:0 4px 16px rgba(244,63,94,.18)}

/* Last card (CTA) gradient upgrade */
.sv:last-child{background:linear-gradient(145deg,rgba(124,58,237,.07),rgba(26,95,204,.05));border-color:rgba(124,58,237,.22)}
.sv:last-child:hover{border-color:transparent;box-shadow:0 24px 64px rgba(124,58,237,.18)}

/* ── MARQUEE — Chromatic premium band ─────────────────────── */
.mq{background:linear-gradient(135deg,#020D22 0%,#04112E 38%,#030C1E 72%,#020818 100%);padding:48px 0;position:relative;overflow:hidden}
.mq::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(124,58,237,.13) 22%,rgba(11,168,224,.10) 50%,rgba(240,114,36,.10) 78%,transparent 100%)}
.mq-i{color:rgba(255,255,255,.17);font-size:27px;gap:32px;padding-right:64px}
.mq-d{font-size:16px;color:var(--violet2)}

/* ── WHY SECTION — Brighter numbered steps ─────────────────── */
.why{background:linear-gradient(160deg,var(--snow) 0%,var(--cloud) 55%,var(--silk) 100%)}
.wst-n{background:linear-gradient(135deg,var(--blue2),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:brightness(.42);transition:filter .3s}
.wst:hover .wst-n{filter:brightness(1)}
.wst:hover{padding-left:12px}
.wc2{background:linear-gradient(135deg,var(--orange),var(--orange2));box-shadow:0 18px 54px rgba(240,114,36,.35)}

/* ── INDUSTRIES — More vibrant sector gradients ─────────────── */
.ind{background:var(--ink)}
.ind .eyebrow{color:var(--cyan)}
.it{border-color:rgba(255,255,255,.06);border-radius:14px}
.it:hover{box-shadow:0 24px 64px rgba(0,0,0,.55);z-index:3}
.it::after{background:linear-gradient(90deg,var(--violet2),var(--cyan))}
/* Richer per-sector gradients */
.it:nth-child(1) .it-bg{background:linear-gradient(145deg,#1A3A70,#0D1B3E)}
.it:nth-child(2) .it-bg{background:linear-gradient(145deg,#6A3000,#2E1200)}
.it:nth-child(3) .it-bg{background:linear-gradient(145deg,#0A3D28,#041E12)}
.it:nth-child(4) .it-bg{background:linear-gradient(145deg,#381462,#1A0830)}
.it:nth-child(5) .it-bg{background:linear-gradient(145deg,#3D0A22,#1A0410)}
.it:nth-child(6) .it-bg{background:linear-gradient(145deg,#3A2A02,#1A1200)}
.it:nth-child(7) .it-bg{background:linear-gradient(145deg,#0A3D1A,#041A0A)}
.it:nth-child(8) .it-bg{background:linear-gradient(145deg,#3D1A00,#1A0800)}
.it:nth-child(9) .it-bg{background:linear-gradient(145deg,#001A3D,#000A1A)}
.it:nth-child(10) .it-bg{background:linear-gradient(145deg,#1A1A3D,#0A0A1A)}
.it-ico{filter:drop-shadow(0 2px 8px rgba(167,139,250,.25))}

/* ── TESTIMONIALS — Deep space treatment ───────────────────── */
.testi{background:linear-gradient(155deg,#020818 0%,#04112E 38%,#030818 100%)}
.testi::before{background:radial-gradient(ellipse 80% 110% at 50% 50%,rgba(124,58,237,.14) 0%,rgba(26,95,204,.08) 42%,transparent 72%)}
.tc{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.09)}
.tc:hover{background:rgba(255,255,255,.09);border-color:rgba(124,58,237,.35);box-shadow:0 24px 64px rgba(0,0,0,.48),0 0 42px rgba(124,58,237,.13)}
.t-av{background:linear-gradient(135deg,var(--violet),var(--cyan))}
.t-stars{letter-spacing:3px}

/* ── PROCESS ─────────────────────────────────────────────── */
.process{background:var(--pearl)}
.pst{border-radius:14px;border-width:1.5px}
.pst:hover{background:linear-gradient(145deg,var(--snow),rgba(26,95,204,.025));transform:translateY(-6px);box-shadow:0 24px 60px rgba(13,27,62,.11)}
.p2::before{height:2px;opacity:.35;background:linear-gradient(90deg,var(--violet2) 0%,var(--cyan) 33%,var(--orange) 68%,var(--orange2) 100%)}
.p-dot{box-shadow:0 6px 22px rgba(26,95,204,.38)}
.pst:nth-child(1) .p-dot{background:linear-gradient(135deg,var(--violet),var(--blue2))}
.pst:nth-child(2) .p-dot{background:linear-gradient(135deg,var(--blue2),var(--cyan))}
.pst:nth-child(3) .p-dot{background:linear-gradient(135deg,var(--cyan),var(--orange))}
.pst:nth-child(4) .p-dot{background:linear-gradient(135deg,var(--orange),var(--orange2))}

/* ── CTA SECTION — Most dramatic ─────────────────────────── */
.cta-sec{background:linear-gradient(110deg,rgba(2,8,24,.98) 0%,rgba(3,12,32,.95) 40%,rgba(124,58,237,.32) 100%),url('/images/hero-it-arch.jpg') center 40%/cover no-repeat}
.cta-sec::before{background:radial-gradient(ellipse 58% 88% at 84% 50%,rgba(124,58,237,.30) 0%,rgba(11,168,224,.14) 55%,transparent 75%)}
.cta-btn{box-shadow:0 8px 32px rgba(240,114,36,.48)}
.cta-btn:hover{box-shadow:0 16px 52px rgba(240,114,36,.65)}
.cta-btn--ghost{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.16)}
.cta-btn--ghost:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.35)}

/* ── NAV BUTTON — violet shimmer ─────────────────────────── */
.nav-btn{background:linear-gradient(135deg,#F97316,#EA580C);box-shadow:0 4px 18px rgba(249,115,22,.35)}
.nav-btn:hover{box-shadow:0 8px 28px rgba(249,115,22,.5);transform:translateY(-1px)}

/* ── CTA MAIN BUTTON — orange to violet flip ─────────────── */
.cta-main::before{background:linear-gradient(135deg,var(--violet),var(--blue2))}

/* ── REVEAL animation — slightly faster ──────────────────── */
.rv{transition:opacity .75s,transform .75s}

/* ── VISION BLOCK (second mission card) ─────────────────── */
.mission--vision{
  margin-top:14px;
  border-left-color:var(--violet);
  background:linear-gradient(135deg,rgba(124,58,237,.04),rgba(11,168,224,.03));
}
.mission--vision .m-tag{color:var(--violet)}

/* ── HERO TRUST BAR ──────────────────────────────────────── */
.hero-trust{display:flex;align-items:center;gap:10px;margin-top:28px;opacity:0;animation:rise .95s .85s ease forwards}
.h-trust-dot{width:7px;height:7px;border-radius:50%;background:var(--emerald2);flex-shrink:0;box-shadow:0 0 10px rgba(52,211,153,.7)}
.h-trust-text{font-size:11px;letter-spacing:.5px;color:rgba(255,255,255,.38);font-weight:500}
@media(max-width:480px){.hero-trust{display:none}}

/* ── SCROLL INDICATOR — violet tint ─────────────────────── */
.scroll-line{background:linear-gradient(180deg,rgba(167,139,250,.7),transparent)}

/* ── FOOTER accent ─────────────────────────────────────────  */
footer{background:linear-gradient(155deg,#020818 0%,#030D1E 60%,#020D22 100%)}
.f-h{color:var(--violet2)}
.soc:hover{background:var(--violet);border-color:var(--violet);color:#fff}

/* ── RESPONSIVE — keep dark stats on mobile ─────────────── */
@media(max-width:1100px){
  .stats{border-left:none;border-right:none}
  .mq{padding:36px 0}
}
@media(max-width:480px){
  .stats{border:none;border-top:1px solid rgba(255,255,255,.055);border-bottom:1px solid rgba(255,255,255,.055)}
  .st{padding:32px 16px}
}

/* ══════════════════════════════════════════════════════════════
   CONTACT MODAL
══════════════════════════════════════════════════════════════ */
.cm-overlay{
  position:fixed;inset:0;z-index:9000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(2,8,24,.72);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  padding:20px;
  opacity:0;visibility:hidden;
  transition:opacity .28s ease,visibility .28s ease;
}
.cm-overlay.cm--open{opacity:1;visibility:visible}
.cm-overlay.cm--open .cm-panel{transform:translateY(0) scale(1);opacity:1}

.cm-panel{
  position:relative;
  background:linear-gradient(160deg,#0d1b3e 0%,#0a1428 100%);
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  padding:44px 40px 40px;
  width:100%;max-width:560px;
  max-height:90vh;overflow-y:auto;
  box-shadow:0 32px 80px rgba(0,0,0,.55),0 0 0 1px rgba(26,95,204,.18);
  transform:translateY(24px) scale(.97);opacity:0;
  transition:transform .32s cubic-bezier(.22,1,.36,1),opacity .28s ease;
}

/* scrollbar inside panel */
.cm-panel::-webkit-scrollbar{width:4px}
.cm-panel::-webkit-scrollbar-track{background:transparent}
.cm-panel::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}

.cm-close{
  position:absolute;top:16px;right:16px;
  width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);color:rgba(255,255,255,.6);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s;
}
.cm-close:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25)}

.cm-header{margin-bottom:28px}
.cm-eyebrow{font-size:11px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;
  color:var(--cyan);margin-bottom:8px}
.cm-title{font-family:'Fraunces',serif;font-size:clamp(24px,4vw,32px);color:#fff;
  font-weight:700;line-height:1.15;margin:0 0 10px}
.cm-title em{font-style:italic;color:var(--cyan)}
.cm-sub{font-size:14px;color:rgba(255,255,255,.5);line-height:1.6;margin:0}

/* form fields */
.cm-form{display:flex;flex-direction:column;gap:16px}
.cm-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cm-field{display:flex;flex-direction:column;gap:6px}
.cm-label{font-size:12px;font-weight:600;letter-spacing:.4px;color:rgba(255,255,255,.65)}
.cm-label span[aria-hidden]{color:var(--cyan)}
.cm-optional{font-weight:400;color:rgba(255,255,255,.35)}

.cm-input{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:12px 14px;
  font-size:14px;color:#fff;
  font-family:'Plus Jakarta Sans',sans-serif;
  outline:none;
  transition:border-color .2s,box-shadow .2s,background .2s;
  width:100%;box-sizing:border-box;
}
.cm-input::placeholder{color:rgba(255,255,255,.28)}
.cm-input:focus{
  border-color:var(--blue);
  background:rgba(26,95,204,.08);
  box-shadow:0 0 0 3px rgba(26,95,204,.18);
}
.cm-input.cm-input--err{border-color:rgba(248,113,113,.6)}
.cm-textarea{resize:vertical;min-height:100px;line-height:1.6}

.cm-err{font-size:11.5px;color:rgba(248,113,113,.85);min-height:16px;display:block}

.cm-submit{
  margin-top:4px;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  border:none;border-radius:10px;
  padding:14px 28px;
  font-size:15px;font-weight:600;font-family:'Plus Jakarta Sans',sans-serif;
  color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:opacity .2s,transform .15s,box-shadow .2s;
  box-shadow:0 4px 18px rgba(26,95,204,.35);
}
.cm-submit:hover{opacity:.88;box-shadow:0 6px 24px rgba(26,95,204,.45)}
.cm-submit:active{transform:scale(.98)}
.cm-submit:disabled{opacity:.55;cursor:not-allowed}

.cm-submit-spinner{
  display:none;
  width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;
  will-change:transform;
  animation:cm-spin .7s linear infinite;
}
.cm-submit.cm--loading .cm-submit-label{display:none}
.cm-submit.cm--loading .cm-submit-spinner{display:block}

@keyframes cm-spin{to{transform:rotate(360deg)}}

/* success state */
.cm-success{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:20px 0 8px;gap:12px;
}
.cm-success[hidden]{display:none}
.cm-success-icon{
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,rgba(52,211,153,.15),rgba(11,168,224,.10));
  border:1px solid rgba(52,211,153,.3);
  display:flex;align-items:center;justify-content:center;
  color:var(--emerald2);
}
.cm-success-ttl{font-family:'Fraunces',serif;font-size:24px;color:#fff;font-weight:700;margin:0}
.cm-success-sub{font-size:14px;color:rgba(255,255,255,.55);margin:0;max-width:340px}

.cm-send-err{
  font-size:13px;color:rgba(248,113,113,.85);text-align:center;margin-top:8px;
  line-height:1.6;
}
.cm-send-err[hidden]{display:none}
.cm-send-err a{color:var(--cyan)}

/* responsive */
@media(max-width:540px){
  .cm-panel{padding:36px 22px 28px}
  .cm-row{grid-template-columns:1fr}
}
