/* ===== RAAD design system ===== */
:root{
  --navy:#0B2A4A; --navy900:#061429; --navy800:#0a2240; --teal:#00A6B8; --aqua:#37D1C4;
  --amber:#F5A623; --ink:#0d1b2a; --slate:#3b4a5c; --muted:#697789; --line:#e7edf3;
  --bg:#ffffff; --soft:#f4f8fb; --card:#ffffff;
  --grad:linear-gradient(120deg,#00A6B8,#37D1C4);
  --grad2:linear-gradient(135deg,#0B2A4A,#0e3a63 55%,#114a7d);
  --sh-sm:0 4px 14px rgba(11,42,74,.06); --sh:0 18px 44px rgba(11,42,74,.10); --sh-lg:0 30px 70px rgba(11,42,74,.16);
  --r:18px; --rl:26px; --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,h5,.dsp{font-family:'Sora','Inter',sans-serif;letter-spacing:-.02em;line-height:1.1;color:var(--navy)}
a{text-decoration:none;color:inherit}
img,svg{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
::selection{background:var(--aqua);color:#04263b}
:focus-visible{outline:3px solid var(--teal);outline-offset:3px;border-radius:6px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Sora';font-weight:600;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--teal)}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--grad);border-radius:2px}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Sora';font-weight:600;font-size:15px;padding:14px 26px;border-radius:999px;border:0;cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;position:relative;will-change:transform}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 10px 26px rgba(0,166,184,.32)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(0,166,184,.42)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.28)}
.btn-ghost:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.55)}
.btn-dark{background:var(--navy);color:#fff}.btn-dark:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.btn-light{background:#fff;color:var(--navy)}.btn-light:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn svg{width:17px;height:17px;transition:transform .25s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
section{position:relative}
.sec{padding:104px 0}
.sec-head{max-width:660px;margin-bottom:54px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{font-size:clamp(28px,4vw,44px);font-weight:700;margin:14px 0}
.sec-head p{color:var(--muted);font-size:17px}
.lead{font-size:18px;color:var(--muted)}

/* reveal (JS-gated) */
.js [data-rev]{opacity:0;transform:translateY(28px)}
@media(prefers-reduced-motion:reduce){
  .js [data-rev]{opacity:1!important;transform:none!important}
  *{animation:none!important;scroll-behavior:auto!important}
}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:.32s var(--ease)}
.nav .inner{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mk{width:42px;height:42px;border-radius:12px;flex:0 0 auto}
.brand b{font-family:'Sora';font-weight:800;font-size:21px;letter-spacing:.04em;color:#fff;transition:.3s;line-height:1}
.brand small{display:block;font-size:8.5px;letter-spacing:.32em;color:var(--aqua);font-weight:600;margin-top:2px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:14.5px;font-weight:500;color:rgba(255,255,255,.86);transition:.2s;position:relative}
.nav-links a.lnk::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--grad);border-radius:2px;transition:width .28s var(--ease)}
.nav-links a.lnk:hover::after,.nav-links a.active::after{width:100%}
.nav-links a:hover{color:#fff}
.nav .navcta{padding:11px 22px;font-size:14px}
.nav.scrolled{background:rgba(255,255,255,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 1px 0 rgba(11,42,74,.08)}
.nav.scrolled .brand b{color:var(--navy)}
.nav.scrolled .brand small{color:var(--teal)}
.nav.scrolled .nav-links a{color:var(--slate)}
.nav.scrolled .nav-links a:hover,.nav.scrolled .nav-links a.active{color:var(--teal)}
.nav.scrolled .navcta{color:#fff}
.nav.solid{background:var(--navy900)}
.burger{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;border-radius:12px;align-items:center;justify-content:center}
.burger span,.burger span::before,.burger span::after{display:block;width:21px;height:2px;background:#fff;border-radius:2px;transition:.3s}
.burger span{position:relative}.burger span::before,.burger span::after{content:"";position:absolute;left:0}
.burger span::before{top:-6px}.burger span::after{top:6px}
.nav.scrolled .burger span,.nav.scrolled .burger span::before,.nav.scrolled .burger span::after{background:var(--navy)}
.menu-open .burger span{background:transparent}
.menu-open .burger span::before{top:0;transform:rotate(45deg)}
.menu-open .burger span::after{top:0;transform:rotate(-45deg)}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:#06182e;overflow:hidden;padding:130px 0 80px}
.hero-bg{position:absolute;inset:0;background:url('../img/page-hero.jpg') center/cover;opacity:.96;will-change:transform}
.home .hero-bg{background:url('../img/page-hero.jpg') center/cover}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#06182e 6%,rgba(6,24,46,.78) 44%,rgba(6,24,46,.28) 100%)}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.06fr .94fr;gap:40px;align-items:center;width:100%}
.hero-copy{max-width:600px}
.hero .eyebrow{color:var(--aqua)}
.hero h1{color:#fff;font-size:clamp(38px,4.8vw,56px);font-weight:800;margin:20px 0 22px}
.hero p.lead{color:#c3d4e6;max-width:520px;margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.hero-trust{display:flex;align-items:center;gap:16px;color:#9fb6cc;font-size:13.5px}
.hero-trust .av{display:flex}
.hero-trust .av span{width:36px;height:36px;border-radius:50%;border:2px solid #0c2540;margin-left:-9px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#04263b;font-family:'Sora'}
.hero-trust .av span:first-child{margin-left:0}
.hero-vis{position:relative;height:480px;display:flex;align-items:center;justify-content:center}
.radar{position:relative;width:420px;height:420px;display:flex;align-items:center;justify-content:center}
.ring{position:absolute;border-radius:50%;border:1.5px solid rgba(55,209,196,.26);left:50%;top:50%;transform:translate(-50%,-50%)}
.ring.r1{width:120px;height:120px}.ring.r2{width:230px;height:230px;border-color:rgba(55,209,196,.18)}
.ring.r3{width:340px;height:340px;border-color:rgba(55,209,196,.13)}.ring.r4{width:440px;height:440px;border-color:rgba(55,209,196,.08)}
.pulse{position:absolute;left:50%;top:50%;width:120px;height:120px;border-radius:50%;border:2px solid var(--aqua);transform:translate(-50%,-50%);animation:pulse 3s ease-out infinite}
.pulse.b{animation-delay:1.5s}
@keyframes pulse{0%{width:120px;height:120px;opacity:.7}100%{width:440px;height:440px;opacity:0}}
.core{width:108px;height:108px;border-radius:28px;background:linear-gradient(145deg,#0e3a63,#0b2a4a);display:flex;align-items:center;justify-content:center;box-shadow:0 20px 50px rgba(0,166,184,.35),inset 0 0 0 1px rgba(255,255,255,.06);position:relative;z-index:3}
.core svg{width:64px;height:64px}
.orbit{position:absolute;left:50%;top:50%;width:340px;height:340px;transform:translate(-50%,-50%);animation:spin 18s linear infinite}
.orbit2{width:230px;height:230px;animation:spin 12s linear infinite reverse}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.dot{position:absolute;width:13px;height:13px;border-radius:50%;background:var(--aqua);box-shadow:0 0 16px var(--aqua)}
.orbit .dot{top:-6px;left:50%;margin-left:-6px}
.orbit2 .dot{top:-5px;left:50%;margin-left:-5px;background:var(--amber);box-shadow:0 0 14px var(--amber)}
.gcard{position:absolute;background:rgba(255,255,255,.09);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.16);border-radius:15px;padding:13px 16px;color:#fff;box-shadow:0 18px 40px rgba(0,0,0,.3);z-index:4}
.gcard b{font-family:'Sora';font-size:21px;display:block;line-height:1}
.gcard span{font-size:11.5px;color:#a9c0d6}
.gc1{top:8px;right:0}.gc2{bottom:30px;left:-6px}.gc3{bottom:-6px;right:30px}
.scroll-ind{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;color:#9fb6cc;font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-ind .m{width:22px;height:36px;border:2px solid rgba(255,255,255,.3);border-radius:12px;position:relative}
.scroll-ind .m::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;background:var(--aqua);border-radius:2px;transform:translateX(-50%);animation:sc 1.6s infinite}
@keyframes sc{0%{opacity:0;top:7px}40%{opacity:1}100%{opacity:0;top:18px}}

/* page hero (inner) */
.phero{position:relative;background:#06182e;color:#fff;padding:170px 0 80px;overflow:hidden}
.phero .bg{position:absolute;inset:0;background:url('../img/page-hero.jpg') center/cover;opacity:.9}
.phero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,24,46,.8),rgba(6,24,46,.6))}
.phero .container{position:relative;z-index:2}
.phero h1{color:#fff;font-size:clamp(34px,5vw,56px);font-weight:800;margin:14px 0 14px;max-width:760px}
.phero p{color:#bcd2e6;font-size:18px;max-width:560px}
.crumb{font-size:13px;color:#8fa8c0;font-family:'Sora'}
.crumb a:hover{color:var(--aqua)}

/* marquee */
.marquee{background:var(--navy);color:#fff;padding:22px 0;overflow:hidden;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.marquee .track{display:flex;gap:48px;white-space:nowrap;width:max-content;animation:scrollx 28s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee b{font-family:'Sora';font-weight:600;font-size:17px;color:#cfe0ee;display:inline-flex;align-items:center;gap:48px}
.marquee b::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--teal)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* SERVICES bento */
.services{background:var(--soft)}
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:28px;transition:transform .35s var(--ease),box-shadow .35s var(--ease);position:relative;overflow:hidden}
.svc::after{content:"";position:absolute;inset:0;border-radius:var(--r);padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.35s}
.svc:hover{transform:translateY(-7px);box-shadow:var(--sh)}
.svc:hover::after{opacity:1}
.svc .chip{width:54px;height:54px;border-radius:14px;background:linear-gradient(145deg,rgba(0,166,184,.14),rgba(55,209,196,.14));display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:.35s}
.svc:hover .chip{transform:scale(1.06) rotate(-4deg)}
.svc .chip svg{width:27px;height:27px;stroke:var(--teal)}
.svc h3{font-size:19px;font-weight:600;margin-bottom:8px}
.svc p{color:var(--muted);font-size:14.5px}
.svc.feat{background:var(--grad2);border:0;color:#fff}
.svc.feat h3{color:#fff}.svc.feat p{color:#bcd2e6}
.svc.feat .chip{background:rgba(255,255,255,.12)}.svc.feat .chip svg{stroke:#fff}
.svc.feat::after{display:none}

/* SERVICE DETAIL rows */
.srow{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:54px 0;border-bottom:1px solid var(--line)}
.srow:last-child{border-bottom:0}
.srow.flip .srow-media{order:2}
.srow-media{border-radius:var(--rl);overflow:hidden;min-height:330px;position:relative;box-shadow:var(--sh)}
.srow-media .im{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s var(--ease)}
.srow:hover .srow-media .im{transform:scale(1.05)}
.srow-media .tag{position:absolute;top:18px;left:18px;z-index:2;background:rgba(6,24,46,.55);backdrop-filter:blur(8px);color:#fff;font-family:'Sora';font-size:12px;font-weight:600;letter-spacing:.06em;padding:8px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.18)}
.srow-body .num{font-family:'Sora';font-weight:800;font-size:15px;color:var(--teal);letter-spacing:.1em}
.srow-body h3{font-size:clamp(24px,3vw,32px);font-weight:700;margin:8px 0 14px}
.srow-body p{color:var(--muted);margin-bottom:16px}
.tick{list-style:none;display:grid;gap:10px}
.tick li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--slate)}
.tick li svg{flex:0 0 auto;width:20px;height:20px;stroke:var(--teal);margin-top:1px}

/* PROCESS */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative;margin-top:20px}
.steps::before{content:"";position:absolute;top:27px;left:8%;right:8%;height:2px;background:linear-gradient(90deg,var(--teal),var(--aqua));opacity:.35}
.step{text-align:center;position:relative}
.step .n{width:56px;height:56px;border-radius:50%;background:#fff;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-family:'Sora';font-weight:700;color:var(--teal);font-size:18px;position:relative;z-index:2;transition:.35s var(--ease)}
.step:hover .n{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1.1)}
.step h4{font-size:16px;margin-bottom:6px}.step p{font-size:13px;color:var(--muted)}

/* COVERAGE */
.cov{background:var(--navy900);color:#fff;overflow:hidden}
.cov .bgi{position:absolute;inset:0;background:url('../img/page-hero.jpg') center/cover;opacity:.28}
.cov .container{position:relative;z-index:2}
.cov-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.cov h2{color:#fff;font-size:clamp(28px,4vw,44px);font-weight:700;margin:14px 0}
.cov p{color:#b9cce0;font-size:17px;margin-bottom:26px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chips span{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);padding:9px 17px;border-radius:999px;font-size:13.5px;font-family:'Sora';font-weight:500;transition:.25s}
.chips span:hover{background:rgba(55,209,196,.16);border-color:rgba(55,209,196,.5)}
.map-pin{transition:.3s}
.map-pin circle{transition:.3s}
.map-pin:hover circle{r:9}
.map-pin text{font-weight:600}

/* WHY */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.why-list{display:flex;flex-direction:column;gap:6px}
.why-item{display:flex;gap:18px;padding:20px;border-radius:16px;transition:.3s}
.why-item:hover{background:var(--soft);transform:translateX(4px)}
.why-item .ic{flex:0 0 auto;width:50px;height:50px;border-radius:13px;background:linear-gradient(145deg,rgba(0,166,184,.13),rgba(55,209,196,.13));display:flex;align-items:center;justify-content:center}
.why-item .ic svg{width:24px;height:24px;stroke:var(--teal)}
.why-item h4{font-size:17px;margin-bottom:4px}.why-item p{color:var(--muted);font-size:14.5px}
.why-visual{position:relative;border-radius:var(--rl);overflow:hidden;background:var(--grad2);padding:40px;min-height:440px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:var(--sh-lg)}
.why-visual .bg{position:absolute;inset:0;background:url('../img/about.jpg') center/cover;opacity:.55}
.why-visual .q{position:relative;z-index:2;color:#fff}
.why-visual .q .mark{font-family:'Sora';font-size:64px;color:var(--aqua);line-height:.5;opacity:.7}
.why-visual .q p{font-family:'Sora';font-size:22px;font-weight:600;margin:12px 0 18px;line-height:1.4}
.why-visual .q small{color:#bcd2e6;font-size:13.5px}
.why-visual .badge{position:absolute;top:30px;right:30px;z-index:2;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:14px;padding:14px 18px;color:#fff;text-align:center}
.why-visual .badge b{font-family:'Sora';font-size:26px;display:block}.why-visual .badge span{font-size:11px;color:#bcd2e6}

/* STATS */
.stats{background:var(--navy);color:#fff;padding:70px 0}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.stat .num{font-family:'Sora';font-weight:800;font-size:clamp(34px,4.4vw,52px);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lab{color:#9fb6cc;font-size:14px;margin-top:6px}

/* PROJECTS */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.proj{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--sh-sm);cursor:pointer}
.proj .im{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s var(--ease)}
.proj:hover .im{transform:scale(1.08)}
.proj::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,20,40,0) 35%,rgba(6,20,40,.92))}
.proj .meta{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:22px;color:#fff;transform:translateY(8px);transition:.4s var(--ease)}
.proj:hover .meta{transform:none}
.proj .cat{font-family:'Sora';font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--aqua)}
.proj h3{color:#fff;font-size:19px;margin:6px 0 4px}
.proj p{color:#cdd9e6;font-size:13px;max-height:0;opacity:0;overflow:hidden;transition:.4s var(--ease)}
.proj:hover p{max-height:60px;opacity:1}
.proj .loc{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#9fb6cc;margin-top:8px}

/* SECTORS */
.sectors .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.sector{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:#fff;transition:.35s var(--ease)}
.sector:hover{transform:translateY(-7px);box-shadow:var(--sh)}
.sector .top{height:130px;position:relative;display:flex;align-items:center;justify-content:center}
.sector .top svg{width:46px;height:46px;stroke:#fff;position:relative;z-index:2}
.sector:nth-child(1) .top{background:linear-gradient(135deg,#0B2A4A,#114a7d)}
.sector:nth-child(2) .top{background:linear-gradient(135deg,#008a9a,#37D1C4)}
.sector:nth-child(3) .top{background:linear-gradient(135deg,#123a5e,#0a8ea0)}
.sector .top::after{content:"";position:absolute;inset:0;background:url('../img/page-hero.jpg') center/cover;opacity:.18}
.sector .bd{padding:24px}.sector h3{font-size:18px;margin-bottom:8px}.sector p{color:var(--muted);font-size:14.5px}

/* VALUES / ABOUT */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.val{padding:26px;border:1px solid var(--line);border-radius:var(--r);background:#fff;transition:.3s}
.val:hover{box-shadow:var(--sh);transform:translateY(-5px)}
.val .ic{width:46px;height:46px;border-radius:12px;background:linear-gradient(145deg,rgba(0,166,184,.13),rgba(55,209,196,.13));display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.val .ic svg{width:23px;height:23px;stroke:var(--teal)}
.val h4{font-size:17px;margin-bottom:6px}.val p{font-size:14px;color:var(--muted)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split .media{border-radius:var(--rl);overflow:hidden;min-height:420px;background:url('../img/about.jpg') center/cover;box-shadow:var(--sh-lg);position:relative}
.split .media .float{position:absolute;bottom:24px;left:24px;right:24px;background:rgba(255,255,255,.1);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:18px 20px;color:#fff}
.split .media .float b{font-family:'Sora';font-size:16px;display:block;margin-bottom:3px}
.split .media .float span{font-size:12.5px;color:#cdd9e6}
.timeline{position:relative;margin-top:10px;padding-left:30px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--teal),var(--aqua))}
.tl{position:relative;padding:0 0 26px 24px}
.tl::before{content:"";position:absolute;left:-30px;top:4px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--teal)}
.tl b{font-family:'Sora';color:var(--teal);font-size:14px}
.tl h4{font-size:17px;margin:3px 0 5px}.tl p{font-size:14px;color:var(--muted)}
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.member{text-align:center}
.member .av{aspect-ratio:1;border-radius:var(--r);background:var(--grad2);position:relative;overflow:hidden;margin-bottom:14px;display:flex;align-items:center;justify-content:center}
.member .av::after{content:"";position:absolute;inset:0;background:url('../img/page-hero.jpg') center/cover;opacity:.25}
.member .av span{position:relative;z-index:2;font-family:'Sora';font-weight:800;font-size:30px;color:#fff;opacity:.85}
.member h4{font-size:16px}.member p{font-size:13px;color:var(--teal);font-family:'Sora'}

/* TESTIMONIAL */
.quote{background:var(--soft)}
.quote .card{max-width:840px;margin:0 auto;text-align:center}
.quote .mk{font-family:'Sora';font-size:70px;color:var(--aqua);line-height:.4}
.quote p{font-family:'Sora';font-size:clamp(20px,2.6vw,28px);font-weight:600;color:var(--navy);line-height:1.45;margin:14px 0 20px}
.quote .who{color:var(--muted);font-size:14px}

/* CTA */
.cta{position:relative;color:#fff;text-align:center;padding:96px 0;overflow:hidden}
.cta .bg{position:absolute;inset:0;background:url('../img/page-hero.jpg') center/cover}
.cta .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(8,42,74,.6),rgba(0,140,158,.5))}
.cta .container{position:relative;z-index:2}
.cta h2{color:#fff;font-size:clamp(30px,4.4vw,46px);font-weight:700;margin-bottom:16px}
.cta p{color:#e6fbff;font-size:18px;max-width:560px;margin:0 auto 30px}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.cinfo{display:flex;flex-direction:column;gap:14px}
.cinfo a{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--line);border-radius:14px;transition:.25s var(--ease)}
.cinfo a:hover{border-color:var(--teal);box-shadow:var(--sh-sm);transform:translateX(4px)}
.cinfo .ic{width:46px;height:46px;border-radius:12px;background:linear-gradient(145deg,rgba(0,166,184,.13),rgba(55,209,196,.13));display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.cinfo .ic svg{width:21px;height:21px;stroke:var(--teal)}
.cinfo b{font-family:'Sora';font-size:15px;color:var(--navy);display:block}.cinfo span{font-size:13px;color:var(--muted)}
.form{background:var(--soft);border:1px solid var(--line);border-radius:20px;padding:32px}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form label{font-size:13px;font-weight:600;color:var(--slate);display:block;margin:14px 0 6px}
.form input,.form textarea,.form select{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:11px;font-family:inherit;font-size:14.5px;background:#fff;transition:.2s;color:var(--ink)}
.form input:focus,.form textarea:focus,.form select:focus{outline:0;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,166,184,.12)}
.form .btn{width:100%;justify-content:center;margin-top:20px}
.form .note{font-size:12px;color:var(--muted);margin-top:12px;text-align:center}

/* FOOTER */
.footer{background:var(--navy900);color:#9fb6cc;padding:68px 0 28px}
.footer .grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer h5{font-family:'Sora';color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.footer a{display:block;color:#9fb6cc;font-size:14px;padding:5px 0;transition:.2s}
.footer a:hover{color:var(--aqua);transform:translateX(3px)}
.footer .about p{font-size:14px;margin:14px 0;max-width:300px}
.footer .brand b{color:#fff}.footer .brand small{color:#7f97b0}
.footer .social{display:flex;gap:10px;margin-top:8px}
.footer .social a{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;padding:0}
.footer .social a:hover{background:var(--teal);border-color:var(--teal);transform:translateY(-3px)}
.footer .social svg{width:17px;height:17px;stroke:#cfe0ee}
.footer .social a:hover svg{stroke:#fff}
.footer .bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:13px;flex-wrap:wrap;gap:10px}

/* responsive */
@media(max-width:980px){
  .hero .container,.cov-grid,.why-grid,.contact-grid,.srow,.split{grid-template-columns:1fr}
  .srow.flip .srow-media{order:0}
  .hero-vis{height:380px;order:-1}
  .bento,.sectors .grid,.proj-grid,.values,.team{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr);gap:30px}.steps::before{display:none}
  .stats .grid{grid-template-columns:repeat(2,1fr);gap:36px}
  .footer .grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{position:fixed;inset:76px 0 auto 0;background:#fff;flex-direction:column;padding:18px 24px;gap:4px;box-shadow:var(--sh);transform:translateY(-140%);transition:.38s var(--ease);align-items:stretch}
  .menu-open .nav-links{transform:none}
  .nav-links a{color:var(--slate);padding:13px 0;border-bottom:1px solid var(--line)}
  .nav-links a.lnk::after{display:none}
  .nav-links .navcta{text-align:center;margin-top:8px;color:#fff}
  .burger{display:flex}
  .bento,.sectors .grid,.proj-grid,.values,.team,.stats .grid,.footer .grid,.form .row2{grid-template-columns:1fr}
  .sec{padding:70px 0}.hero h1{font-size:38px}
}

/* ===== capability showcase (illustrated subjects) ===== */
.caps{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.cap{position:relative;border-radius:var(--rl);overflow:hidden;min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:var(--sh);isolation:isolate}
.cap .capbg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s var(--ease);z-index:-2}
.cap:hover .capbg{transform:scale(1.06)}
.cap::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,20,40,.15) 30%,rgba(6,20,40,.9));z-index:-1}
.cap .art{position:absolute;top:0;left:0;right:0;height:62%;display:flex;align-items:center;justify-content:center;padding:22px;z-index:1}
.cap .art svg{width:min(78%,260px);height:auto;filter:drop-shadow(0 10px 26px rgba(0,0,0,.35))}
.cap .lab{position:relative;z-index:2;padding:24px 26px;color:#fff}
.cap .lab .t{font-family:'Sora';font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--aqua)}
.cap .lab h3{color:#fff;font-size:21px;margin:6px 0 6px}
.cap .lab p{color:#c7d6e6;font-size:14px;max-width:36ch}
@media(max-width:980px){.caps{grid-template-columns:1fr}}

/* reach band */
.reach{background:var(--navy900);color:#fff;overflow:hidden}
.reach .bgi{position:absolute;inset:0;background:url('../img/page-hero.jpg') center/cover;opacity:.3}
.reach .container{position:relative;z-index:2;text-align:center}
.reach h2{color:#fff;font-size:clamp(28px,4vw,44px);font-weight:700;margin:14px 0}
.reach p{color:#bcd2e6;font-size:18px;max-width:620px;margin:0 auto 8px}
.reach .net{max-width:760px;margin:34px auto 0}

/* tick + form -> flex (renderer-friendly) */
.tick{display:flex;flex-direction:column}
.form .row2{display:flex;gap:16px;flex-wrap:wrap}
.form .row2>div{flex:1 1 200px}

/* ===== two-radio comms animation ===== */
.comms{width:100%;max-width:480px;margin:0 auto}
.comms svg{width:100%;height:auto;overflow:visible;filter:drop-shadow(0 24px 50px rgba(0,166,184,.18))}
.sig-left{animation:talkL 4s ease-in-out infinite}
.sig-right{animation:talkR 4s ease-in-out infinite}
.scr-left{animation:blinkL 4s ease-in-out infinite}
.scr-right{animation:blinkR 4s ease-in-out infinite}
@keyframes talkL{0%{opacity:.12}6%{opacity:1}36%{opacity:1}42%{opacity:.12}100%{opacity:.12}}
@keyframes talkR{0%,50%{opacity:.12}56%{opacity:1}86%{opacity:1}92%{opacity:.12}100%{opacity:.12}}
@keyframes blinkL{0%,42%{opacity:.25}6%,36%{opacity:1}100%{opacity:.25}}
@keyframes blinkR{0%,50%,92%{opacity:.25}56%,86%{opacity:1}100%{opacity:.25}}
.brand .mk{box-shadow:0 6px 18px rgba(0,0,0,.28)}
@media(prefers-reduced-motion:reduce){.sig-left,.sig-right{opacity:.7;animation:none}.scr-left,.scr-right{animation:none}}

/* form status */
.formstatus{margin-top:14px;font-size:14px;font-weight:600;display:none;padding:12px 14px;border-radius:10px}
.formstatus.ok{display:block;color:#0b6b3a;background:#e7f7ee;border:1px solid #b9e6cd}
.formstatus.err{display:block;color:#9a2530;background:#fdecec;border:1px solid #f4c4c4}
