/* ============================================================
   5i Consulting — Shared Stylesheet
   Aesthetic: refined institutional trust + digital-transformation motion
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..700;1,9..144,400&family=Archivo:wght@300;400;500;600;700&display=swap');

:root{
  --ink:#060E1F;          /* near-black navy */
  --navy:#0A1A33;         /* primary navy */
  --navy-2:#0E2547;       /* raised navy */
  --steel:#13345F;
  --teal:#16C4B8;
  --teal-bright:#2DE0CF;
  --blue:#1B6BF5;
  --blue-bright:#36C8F0;
  --cyan:#5BD0FF;
  --mist:#F4F7FB;         /* light page bg */
  --mist-2:#E9EFF7;
  --paper:#FFFFFF;
  --line:rgba(11,31,58,0.10);
  --line-light:rgba(255,255,255,0.10);
  --text:#16243B;
  --text-soft:#46587A;
  --text-on-dark:rgba(232,240,252,0.74);
  --gold:#E0B341;         /* sparing accent for "Integrity" / public-sector trust */
  --grad: linear-gradient(120deg,var(--teal) 0%,var(--blue) 60%,var(--cyan) 100%);
  --grad-soft: linear-gradient(120deg,#16C4B8 0%,#1B6BF5 100%);
  --shadow-sm:0 2px 14px rgba(10,26,51,0.08);
  --shadow:0 18px 50px -20px rgba(10,26,51,0.35);
  --shadow-lg:0 40px 90px -40px rgba(10,26,51,0.55);
  --r:14px; --r-lg:22px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Archivo',system-ui,sans-serif;
  font-size:17px;line-height:1.72;color:var(--text);
  background:var(--mist);-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;line-height:1.08;color:var(--navy);font-weight:500;letter-spacing:-0.01em}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
::selection{background:var(--teal);color:#062028}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 7%}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:'Archivo',sans-serif;font-size:.74rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--blue)}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--grad)}
.eyebrow.on-dark{color:var(--teal-bright)}
.lead{font-size:1.18rem;color:var(--text-soft);line-height:1.75}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:'Archivo',sans-serif;font-weight:600;font-size:.92rem;
  padding:.95rem 1.7rem;border-radius:100px;border:1px solid transparent;cursor:pointer;transition:.35s var(--ease);position:relative}
.btn-primary{background:var(--grad);color:#04161c;box-shadow:0 14px 34px -12px rgba(27,107,245,.6)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 44px -14px rgba(27,107,245,.8)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.28);color:#fff}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-bright);transform:translateY(-2px)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--steel);transform:translateY(-2px)}
.btn-arrow{transition:transform .3s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.4s var(--ease)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 7%;height:78px;display:flex;align-items:center;justify-content:space-between}
.nav::before{content:"";position:absolute;inset:0;background:rgba(8,17,35,.55);backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%);border-bottom:1px solid var(--line-light);opacity:0;transition:.4s var(--ease)}
.nav.scrolled::before{opacity:1}
.nav.scrolled .nav-inner{height:66px}
.nav-logo{position:relative;z-index:2;height:38px}
.nav-logo svg{height:38px;width:auto}
.nav-links{position:relative;z-index:2;display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:.9rem;font-weight:500;color:rgba(233,241,253,.82);letter-spacing:.01em;position:relative;padding:.3rem 0;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--grad);transition:width .35s var(--ease)}
.nav-links a:hover,.nav-links a.current{color:#fff}
.nav-links a:hover::after,.nav-links a.current::after{width:100%}
.nav-cta{padding:.6rem 1.3rem !important;font-size:.85rem !important}
.nav-cta::after{display:none}
.hamburger{display:none;position:relative;z-index:2;width:30px;height:22px;cursor:pointer;background:none;border:0}
.hamburger span{position:absolute;left:0;width:100%;height:2px;background:#fff;transition:.3s var(--ease)}
.hamburger span:nth-child(1){top:0}.hamburger span:nth-child(2){top:10px}.hamburger span:nth-child(3){top:20px}
.hamburger.open span:nth-child(1){top:10px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:10px;transform:rotate(-45deg)}

/* ============================================================
   HERO + ANIMATED TECH CANVAS
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--ink);overflow:hidden}
.page-hero{position:relative;min-height:64vh;display:flex;align-items:flex-end;background:var(--ink);overflow:hidden;padding-bottom:4rem}
#net-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.hero-bg-photo{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;
  opacity:.34;animation:kenburns 26s ease-in-out infinite alternate}
@keyframes kenburns{0%{transform:scale(1.05) translate(0,0)}100%{transform:scale(1.18) translate(-2%,-2%)}}
.hero-veil{position:absolute;inset:0;z-index:2;
  background:radial-gradient(120% 90% at 78% 18%,rgba(27,107,245,.28),transparent 55%),
             radial-gradient(80% 70% at 8% 90%,rgba(22,196,184,.22),transparent 55%),
             linear-gradient(180deg,rgba(6,14,31,.78) 0%,rgba(6,14,31,.62) 45%,rgba(6,14,31,.92) 100%)}
.hero-grid{position:absolute;inset:0;z-index:2;opacity:.5;
  background-image:linear-gradient(rgba(120,170,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,255,.07) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(circle at 50% 40%,#000,transparent 80%)}
.hero-inner{position:relative;z-index:5;width:100%;max-width:var(--maxw);margin:0 auto;padding:9rem 7% 4rem}
.hero-grid-2{display:grid;grid-template-columns:1.15fr .85fr;gap:4rem;align-items:center}

.hero h1{font-size:clamp(2.7rem,6vw,5rem);color:#fff;font-weight:500;line-height:1.02;letter-spacing:-.02em}
.hero h1 .accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-style:italic}
.hero-sub{margin:1.8rem 0 2.4rem;color:var(--text-on-dark);font-size:1.16rem;max-width:560px;line-height:1.7}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-tags{margin-top:2.6rem;display:flex;gap:1.6rem;flex-wrap:wrap;color:rgba(233,241,253,.55);font-size:.82rem;letter-spacing:.04em}
.hero-tags span{display:flex;align-items:center;gap:.5rem}
.hero-tags span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal-bright)}

/* animated 5-i bars panel in hero */
.hero-mark{position:relative;background:rgba(255,255,255,.04);border:1px solid var(--line-light);border-radius:var(--r-lg);
  padding:2.4rem;backdrop-filter:blur(6px);box-shadow:var(--shadow-lg)}
.hero-mark-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--teal-bright);font-weight:600;margin-bottom:1.4rem}
.bars{display:flex;align-items:flex-end;gap:14px;height:180px}
.bar{flex:1;border-radius:8px 8px 4px 4px;position:relative;transform-origin:bottom;animation:grow 1.1s var(--ease) both}
.bar::before{content:"";position:absolute;top:-15px;left:50%;transform:translateX(-50%);width:13px;height:13px;border-radius:50%;background:inherit}
.bar.b1{height:46%;background:linear-gradient(180deg,#1FD3C6,#0E7C8C);animation-delay:.1s}
.bar.b2{height:62%;background:linear-gradient(180deg,#1FD3C6,#119AAE);animation-delay:.22s}
.bar.b3{height:100%;background:linear-gradient(180deg,#2DE0CF,#1670D6);animation-delay:.34s}
.bar.b4{height:70%;background:linear-gradient(180deg,#36C8F0,#1B6BF5);animation-delay:.46s}
.bar.b5{height:52%;background:linear-gradient(180deg,#5BD0FF,#2E7DF5);animation-delay:.58s}
@keyframes grow{from{transform:scaleY(0);opacity:0}to{transform:scaleY(1);opacity:1}}
.bars-base{height:3px;background:var(--grad);border-radius:2px;margin-top:10px;opacity:.7}
.pillars-row{display:flex;justify-content:space-between;margin-top:1.1rem}
.pillars-row span{font-size:.62rem;letter-spacing:.04em;color:rgba(233,241,253,.6);text-transform:uppercase;flex:1;text-align:center}

/* ============================================================
   SECTIONS
   ============================================================ */
section{position:relative}
.sec{padding:7rem 0}
.sec-tight{padding:5rem 0}
.sec-dark{background:var(--navy);color:#fff}
.sec-dark h1,.sec-dark h2,.sec-dark h3,.sec-dark h4{color:#fff}
.sec-ink{background:var(--ink);color:#fff}
.sec-ink h2,.sec-ink h3{color:#fff}
.sec-head{max-width:680px;margin-bottom:3.4rem}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,3rem);margin:1rem 0 1.1rem}
.sec-head p{color:var(--text-soft);font-size:1.08rem}
.sec-dark .sec-head p,.sec-ink .sec-head p{color:var(--text-on-dark)}

/* page hero text */
.page-hero-inner{position:relative;z-index:5;max-width:var(--maxw);margin:0 auto;padding:0 7%;width:100%}
.page-hero h1{font-size:clamp(2.4rem,5vw,4rem);color:#fff;max-width:14ch}
.page-hero p{color:var(--text-on-dark);font-size:1.12rem;max-width:60ch;margin-top:1.2rem}
.crumb{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-bright);margin-bottom:1.3rem;font-weight:600}

/* ---------- Stat strip ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--paper);box-shadow:var(--shadow-sm)}
.stat{padding:2.2rem 1.6rem;text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat .num{font-family:'Fraunces',serif;font-size:2.7rem;font-weight:500;background:var(--grad-soft);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.stat .lbl{margin-top:.5rem;font-size:.84rem;color:var(--text-soft);letter-spacing:.02em}

/* ---------- Pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:1.8rem 1.4rem;transition:.4s var(--ease);position:relative;overflow:hidden}
.pillar::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.pillar:hover::before{transform:scaleX(1)}
.pillar .pico{width:44px;height:44px;border-radius:11px;background:linear-gradient(135deg,rgba(22,196,184,.14),rgba(27,107,245,.14));display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem}
.pillar .pico svg{width:22px;height:22px;stroke:var(--blue)}
.pillar h4{font-size:1.3rem;margin-bottom:.4rem}
.pillar p{font-size:.86rem;color:var(--text-soft);line-height:1.6}
.pillar .pnum{position:absolute;top:1rem;right:1.2rem;font-family:'Fraunces',serif;font-size:1rem;color:var(--mist-2);font-style:italic}

/* ---------- Service cards ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:2.4rem;transition:.4s var(--ease);position:relative;overflow:hidden}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(27,107,245,.25)}
.card .cico{width:54px;height:54px;border-radius:14px;background:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:1.4rem;transition:.4s var(--ease)}
.card:hover .cico{background:var(--grad)}
.card .cico svg{width:26px;height:26px;stroke:var(--teal-bright);transition:.4s}
.card:hover .cico svg{stroke:#04161c}
.card h3{font-size:1.5rem;margin-bottom:.7rem}
.card p{font-size:.95rem;color:var(--text-soft)}
.card ul{list-style:none;margin-top:1.1rem;display:flex;flex-direction:column;gap:.5rem}
.card li{font-size:.86rem;color:var(--text-soft);padding-left:1.4rem;position:relative}
.card li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;border-radius:2px;background:var(--grad)}

/* ---------- Edge / compare ---------- */
.edge-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.edge-card{border-radius:var(--r-lg);padding:2.2rem;border:1px solid}
.edge-them{background:rgba(255,255,255,.03);border-color:var(--line-light)}
.edge-us{background:linear-gradient(150deg,rgba(22,196,184,.12),rgba(27,107,245,.08));border-color:rgba(45,224,207,.3)}
.edge-card h4{font-size:1.15rem;margin-bottom:1.2rem;display:flex;align-items:center;gap:.6rem}
.edge-card ul{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.edge-card li{font-size:.92rem;padding-left:1.7rem;position:relative;color:var(--text-on-dark);line-height:1.5}
.edge-them li::before{content:"–";position:absolute;left:0;color:rgba(233,241,253,.4)}
.edge-us li{color:rgba(238,245,255,.92)}
.edge-us li::before{content:"✓";position:absolute;left:0;color:var(--teal-bright);font-weight:700}

/* ---------- Sector split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.sector{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:380px;display:flex;align-items:flex-end;color:#fff;padding:2.6rem}
.sector .sbg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1.1s var(--ease)}
.sector:hover .sbg{transform:scale(1.07)}
.sector .sveil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,14,31,.2),rgba(6,14,31,.92))}
.sector .scontent{position:relative;z-index:2}
.sector h3{color:#fff;font-size:1.9rem;margin-bottom:.6rem}
.sector p{color:rgba(238,245,255,.82);font-size:.95rem;margin-bottom:1rem}
.tag-row{display:flex;flex-wrap:wrap;gap:.5rem}
.tag{font-size:.74rem;padding:.32rem .8rem;border:1px solid rgba(255,255,255,.25);border-radius:100px;color:rgba(238,245,255,.85)}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.member{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:.4s var(--ease)}
.member:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.member-photo{position:relative;aspect-ratio:1/1;background:linear-gradient(150deg,var(--navy),var(--steel));display:flex;align-items:center;justify-content:center;overflow:hidden}
.member-photo img{width:100%;height:100%;object-fit:cover}
.member-initials{font-family:'Fraunces',serif;font-size:3.4rem;color:#fff;font-weight:500}
.member-photo .pill-own{position:absolute;top:1rem;left:1rem;z-index:3;font-size:.66rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;background:rgba(6,14,31,.6);backdrop-filter:blur(6px);color:var(--teal-bright);padding:.34rem .7rem;border-radius:100px;border:1px solid rgba(45,224,207,.3)}
.member-net{position:absolute;inset:0;z-index:1;opacity:.5;
  background-image:radial-gradient(circle at 30% 30%,rgba(45,224,207,.5),transparent 4px),radial-gradient(circle at 70% 60%,rgba(54,200,240,.4),transparent 4px),radial-gradient(circle at 50% 80%,rgba(27,107,245,.4),transparent 4px);}
.member-body{padding:1.6rem 1.6rem 1.9rem}
.member-body h3{font-size:1.35rem;margin-bottom:.15rem}
.member-role{font-size:.84rem;color:var(--blue);font-weight:600;margin-bottom:.9rem}
.member-bio{font-size:.86rem;color:var(--text-soft);line-height:1.6;margin-bottom:1.1rem}
.member-meta{display:flex;flex-direction:column;gap:.35rem;font-size:.78rem;color:var(--text-soft);margin-bottom:1.2rem}
.member-meta b{color:var(--text);font-weight:600}
.li-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;color:var(--blue);transition:.3s}
.li-link:hover{color:var(--teal);gap:.7rem}
.li-link svg{width:17px;height:17px;fill:currentColor}
.placeholder-note{font-size:.72rem;color:var(--gold);background:rgba(224,179,65,.1);border:1px dashed rgba(224,179,65,.4);border-radius:8px;padding:.5rem .7rem;margin-bottom:1rem}

/* ---------- Process timeline ---------- */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;counter-reset:s}
.step{padding:0 1rem;position:relative}
.step::before{counter-increment:s;content:"0" counter(s);font-family:'Fraunces',serif;font-size:1.5rem;color:var(--blue);font-style:italic}
.step .dot{width:14px;height:14px;border-radius:50%;background:var(--grad);margin:1rem 0;position:relative;z-index:2}
.step .line{position:absolute;top:calc(1.9rem + 7px);left:0;right:-1rem;height:2px;background:linear-gradient(90deg,var(--teal),rgba(27,107,245,.2))}
.step:last-child .line{display:none}
.step h4{font-size:1.1rem;margin:.6rem 0 .4rem}
.step p{font-size:.82rem;color:var(--text-soft)}
.sec-dark .step h4{color:#fff}.sec-dark .step p{color:var(--text-on-dark)}

/* ---------- CTA banner ---------- */
.cta{position:relative;border-radius:var(--r-lg);overflow:hidden;padding:4.5rem 3.5rem;background:var(--navy);text-align:center;isolation:isolate}
.cta::before{content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
  background:radial-gradient(60% 120% at 20% 0%,rgba(22,196,184,.5),transparent 60%),radial-gradient(60% 120% at 90% 100%,rgba(27,107,245,.55),transparent 60%)}
.cta h2{font-size:clamp(1.9rem,3.4vw,2.8rem);color:#fff;margin-bottom:1rem}
.cta p{color:rgba(238,245,255,.78);max-width:52ch;margin:0 auto 2rem}
.cta .hero-actions{justify-content:center}

/* ---------- Logo strip / trust ---------- */
.trust{display:flex;flex-wrap:wrap;gap:1.4rem 2.4rem;align-items:center;justify-content:center;opacity:.8}
.trust .badge{font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--text-soft);display:flex;align-items:center;gap:.5rem}
.trust .badge svg{width:18px;height:18px;stroke:var(--teal)}

/* ---------- Forms ---------- */
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:2.6rem;box-shadow:var(--shadow-sm)}
.field{margin-bottom:1.2rem}
.field label{display:block;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-soft);margin-bottom:.45rem}
.field input,.field select,.field textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;color:var(--text);background:var(--mist);transition:.3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px rgba(27,107,245,.1)}
.field textarea{resize:vertical;min-height:130px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-info .ci-item{display:flex;gap:1rem;padding:1.3rem 0;border-bottom:1px solid var(--line)}
.contact-info .ci-item:last-child{border-bottom:0}
.ci-ico{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,rgba(22,196,184,.14),rgba(27,107,245,.14));display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-ico svg{width:20px;height:20px;stroke:var(--blue)}
.ci-item h4{font-size:1.05rem;margin-bottom:.1rem}
.ci-item p,.ci-item a{font-size:.92rem;color:var(--text-soft)}
.ci-item a:hover{color:var(--blue)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--ink);color:rgba(233,241,253,.6);padding:5rem 0 2rem;position:relative;overflow:hidden}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--grad);opacity:.6}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.6rem;margin-bottom:3rem}
.footer-logo{height:42px;margin-bottom:1.3rem}
.footer-about{font-size:.9rem;line-height:1.7;max-width:34ch}
.footer h5{font-family:'Archivo',sans-serif;color:#fff;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem;font-weight:600}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer ul a{font-size:.9rem;transition:.3s}
.footer ul a:hover{color:var(--teal-bright)}
.footer-bottom{border-top:1px solid var(--line-light);padding-top:1.8rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-size:.8rem}
.footer-social{display:flex;gap:.8rem}
.footer-social a{width:36px;height:36px;border-radius:10px;border:1px solid var(--line-light);display:flex;align-items:center;justify-content:center;transition:.3s}
.footer-social a:hover{background:var(--grad);border-color:transparent}
.footer-social svg{width:16px;height:16px;fill:currentColor}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .hero-grid-2{grid-template-columns:1fr;gap:2.5rem}
  .hero-mark{max-width:440px}
  .grid-3,.team-grid{grid-template-columns:repeat(2,1fr)}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr);gap:2rem}
  .step .line{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body{font-size:16px}
  .nav-links{position:fixed;inset:66px 0 auto 0;flex-direction:column;background:rgba(8,17,35,.98);backdrop-filter:blur(16px);
    padding:1.4rem 7%;gap:0;transform:translateY(-120%);transition:transform .4s var(--ease);border-bottom:1px solid var(--line-light)}
  .nav-links.open{transform:translateY(0)}
  .nav-links li{width:100%;padding:.9rem 0;border-bottom:1px solid var(--line-light)}
  .nav-links li:last-child{border-bottom:0;padding-top:1.1rem}
  .nav-cta{display:inline-flex}
  .hamburger{display:block}
  .sec{padding:4.5rem 0}
  .stats{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
  .grid-3,.grid-2,.team-grid,.pillars,.edge-grid,.split,.steps,.contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta{padding:3rem 1.6rem}
  .hero-inner{padding-top:7rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s !important;transition-duration:.15s !important}
  .hero-bg-photo{animation:none}
}

/* Anchor offset so in-page links (e.g. #tolling) clear the fixed nav */
section[id]{scroll-margin-top:96px}
