:root{
  --navy:#011627;            /* brand colour */
  --navy-2:#02233a;
  --amber:#ff9f1c;           /* accent */
  --amber-d:#f08a00;
  --ink:#ffffff;
  --mut:#b9c6d6;
  --line:rgba(255,255,255,.16);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Sora',system-ui,sans-serif;background:var(--navy);color:var(--ink);overflow-x:hidden;line-height:1.6}
img{max-width:100%}
.mono{font-family:'JetBrains Mono',monospace}
a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 30px}

/* ============ HEADER ============ */
header{position:absolute;top:0;left:0;right:0;z-index:30;transition:.35s}
header.scrolled{position:fixed;background:rgba(1,22,39,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 10px 30px rgba(0,0,0,.35)}
nav{display:flex;align-items:center;justify-content:space-between;height:92px;transition:.35s}
header.scrolled nav{height:74px}
.logo{display:flex;align-items:center}
.logo img{height:58px;width:auto;filter:brightness(0) invert(1);transition:.35s}
.logo:hover img{filter:brightness(0) invert(1) drop-shadow(0 6px 18px rgba(255,159,28,.55));transform:translateY(-1px)}
header.scrolled .logo img{height:48px;filter:brightness(0) invert(1)}
.navlinks{display:flex;align-items:center;gap:34px}
.navlinks a.nl{font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--ink);position:relative;padding:6px 0;opacity:.92;transition:.25s}
.navlinks a.nl:hover,.navlinks a.nl.active{color:var(--amber);opacity:1}
.navlinks a.nl::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--amber);transition:.3s}
.navlinks a.nl:hover::after,.navlinks a.nl.active::after{width:100%}
.btn{display:inline-flex;align-items:center;gap:9px;border:0;cursor:pointer;font-family:inherit;font-weight:600;transition:.28s}
.btn-cta{background:linear-gradient(135deg,var(--amber),var(--amber-d));color:var(--navy);padding:13px 28px;border-radius:100px;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 10px 26px rgba(255,159,28,.32)}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(255,159,28,.5)}
.burger{display:none;flex-direction:column;gap:6px;cursor:pointer;padding:6px;z-index:40;background:none;border:0;-webkit-appearance:none;appearance:none;margin:0;line-height:0}
.burger span{width:28px;height:2px;background:#fff;transition:.3s}
.burger.x span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ============ NAV DROPDOWN (Products submenu) ============ */
.has-dropdown{position:relative;display:flex;align-items:center}
.has-dropdown::before{content:"";position:absolute;left:0;top:100%;width:100%;height:14px}
.has-dropdown > .nl{display:flex;align-items:center;gap:6px}
.has-dropdown .chev{width:13px;height:13px;flex-shrink:0;transition:.25s}
.has-dropdown:hover .chev{transform:rotate(180deg)}
.submenu{position:absolute;top:100%;left:0;margin-top:14px;width:220px;background:var(--navy-2);border:1px solid var(--line);border-radius:8px;padding:6px;list-style:none;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease,visibility .2s;box-shadow:0 18px 36px rgba(0,0,0,.4);z-index:50}
.has-dropdown:hover .submenu{opacity:1;visibility:visible;pointer-events:auto}
.submenu .sublink{display:block;padding:10px 14px;border-radius:6px;font-size:.86rem;font-weight:600;text-transform:none;letter-spacing:.2px;color:var(--mut);transition:.2s}
.submenu .sublink:hover{background:rgba(255,159,28,.1);color:var(--amber)}

@media(max-width:1024px){
  .has-dropdown{flex-direction:column;width:100%}
  .has-dropdown > .nl{justify-content:center}
  .submenu{position:static;width:auto;opacity:1;visibility:hidden;pointer-events:none;max-height:0;overflow:hidden;background:transparent;border:0;box-shadow:none;padding:0;margin-top:0;transition:max-height .35s ease}
  .has-dropdown.open .submenu{visibility:visible;pointer-events:auto;max-height:400px;margin-top:8px}
  .submenu .sublink{text-align:center;padding:10px 0;font-size:1rem}
}

/* ============ HERO SLIDER ============ */
.hero{position:relative;height:100vh;height:100svh;min-height:640px;overflow:hidden;background:var(--navy)}
.slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity 1.1s ease,visibility 1.1s}
.slide.active{opacity:1;visibility:visible}
.slide .bg{position:absolute;inset:0;background-color:var(--navy);background-size:cover;background-position:center;transform:scale(1.12);transition:transform 7s ease}
.slide.active .bg{transform:scale(1)}
/* brand-colour overlay so text always pops + photo failure looks intentional */
.slide .overlay{position:absolute;inset:0;background:
   linear-gradient(180deg,rgba(1,22,39,.48) 0%,rgba(1,22,39,.64) 50%,rgba(1,22,39,.95) 100%),
   radial-gradient(1200px 720px at 78% 26%,rgba(255,159,28,.16),transparent 58%),
   radial-gradient(130% 120% at 50% 48%,transparent 52%,rgba(1,22,39,.66) 100%)}
/* subtle tech grid that never breaks */
.slide .grid{position:absolute;inset:0;opacity:.25;background-image:
   linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
   linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:46px 46px}

.hero-inner{position:relative;z-index:5;height:100%;display:flex;flex-direction:column;justify-content:center;text-align:center}
.slide .eyebrow{display:inline-flex;align-items:center;gap:10px;align-self:center;padding:9px 20px;border:1px solid var(--line);border-radius:100px;background:rgba(255,255,255,.05);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-size:.74rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--amber);margin-bottom:30px;opacity:0;transform:translateY(24px)}
.slide .eyebrow .d{width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 14px var(--amber)}
.slide .heroh{font-size:clamp(1.9rem,4.2vw,3.5rem);line-height:1.12;font-weight:700;letter-spacing:-1px;max-width:19ch;margin:0 auto;opacity:0;transform:translateY(30px);text-shadow:0 6px 34px rgba(0,0,0,.35)}
.slide .heroh .it{font-weight:800;background:linear-gradient(120deg,#ffe2a8 0%,var(--amber) 48%,var(--amber-d) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.slide p.sub{margin:26px auto 0;color:var(--mut);font-size:clamp(1rem,1.6vw,1.22rem);max-width:60ch;opacity:0;transform:translateY(30px)}
.slide .hcta{margin-top:40px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;opacity:0;transform:translateY(30px)}
.btn-pill{background:linear-gradient(135deg,var(--amber),var(--amber-d));color:var(--navy);padding:17px 40px;border-radius:100px;font-size:.92rem;text-transform:uppercase;letter-spacing:1px;box-shadow:0 14px 34px rgba(255,159,28,.4)}
.btn-pill:hover{transform:translateY(-3px);box-shadow:0 20px 44px rgba(255,159,28,.55)}
.btn-out{padding:17px 38px;border-radius:100px;border:1.5px solid rgba(255,255,255,.4);color:#fff;font-size:.92rem;text-transform:uppercase;letter-spacing:1px;background:transparent}
.btn-out:hover{border-color:var(--amber);color:var(--amber)}

/* staggered entrance on active slide */
.slide.active .eyebrow{opacity:1;transform:none;transition:.7s ease .2s}
.slide.active .heroh{opacity:1;transform:none;transition:.9s cubic-bezier(.2,.7,.2,1) .35s}
.slide.active p.sub{opacity:1;transform:none;transition:.9s cubic-bezier(.2,.7,.2,1) .55s}
.slide.active .hcta{opacity:1;transform:none;transition:.9s cubic-bezier(.2,.7,.2,1) .72s}

/* arrows */
.arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:15;width:56px;height:56px;border-radius:50%;border:1px solid var(--line);background:rgba(1,22,39,.4);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;font-size:1.3rem;cursor:pointer;display:grid;place-items:center;transition:.28s;opacity:.7}
.arrow:hover{background:var(--amber);color:var(--navy);border-color:var(--amber);opacity:1}
.arrow.prev{left:30px}.arrow.next{right:30px}

/* dots + progress */
.dots{position:absolute;left:50%;bottom:38px;transform:translateX(-50%);z-index:15;display:flex;gap:14px;align-items:center}
.dot{width:42px;height:4px;border-radius:4px;background:rgba(255,255,255,.28);cursor:pointer;overflow:hidden;position:relative;transition:.3s}
.dot.active{background:rgba(255,255,255,.28)}
.dot .fill{position:absolute;inset:0;width:0;background:var(--amber);border-radius:4px}
.dot.active .fill{animation:prog 6s linear forwards}
@keyframes prog{from{width:0}to{width:100%}}

/* side meta (slide counter) */
.counter{position:absolute;left:30px;bottom:36px;z-index:15;font-family:'JetBrains Mono';font-size:.85rem;color:var(--mut)}
.counter b{color:var(--amber);font-size:1.1rem}

/* social rail */
.rail{position:absolute;right:30px;bottom:36px;z-index:15;display:flex;gap:18px;align-items:center;font-size:.78rem;color:var(--mut);letter-spacing:1px}
.rail a{transition:.2s}.rail a:hover{color:var(--amber)}

/* scroll cue */
.cue{position:absolute;left:50%;bottom:90px;transform:translateX(-50%);z-index:14;color:var(--mut);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;display:none}

@media(max-width:1024px){
  .navlinks{position:fixed;inset:0;flex-direction:column;justify-content:center;gap:30px;background:rgba(1,22,39,.98);transform:translateX(100%);transition:.4s;z-index:35}
  .navlinks.open{transform:none}
  .navlinks a.nl{font-size:1.2rem}
  .burger{display:flex}
  .arrow{width:46px;height:46px;font-size:1.1rem}.arrow.prev{left:14px}.arrow.next{right:14px}
  .counter,.rail{display:none}
  .dots{bottom:26px}
}
@media(max-width:560px){
  .wrap{padding:0 20px}
  .slide .hcta{flex-direction:column;align-items:center}
  .btn-pill,.btn-out{width:100%;max-width:300px;justify-content:center}
}

/* ============ MARQUEE BAR ============ */
.marquee{position:relative;background:linear-gradient(90deg,var(--navy-2),#031a2d);border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:18px 0}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:160px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,#031a2d,transparent)}
.marquee::after{right:0;background:linear-gradient(270deg,#031a2d,transparent)}
.mtrack{display:flex;width:max-content;animation:marq 38s linear infinite}
.marquee:hover .mtrack{animation-play-state:paused}
.mgroup{display:flex;align-items:center}
.mgroup .term{font-family:'JetBrains Mono';font-size:.92rem;letter-spacing:1.5px;color:var(--mut);text-transform:uppercase;padding:0 26px;white-space:nowrap;transition:.25s}
.mgroup .term:hover{color:#fff}
.mgroup .sep{color:var(--amber);font-size:.6rem;line-height:1}
@keyframes marq{to{transform:translateX(-50%)}}
@media(max-width:560px){.mgroup .term{font-size:.82rem;padding:0 18px}}

/* ============ SHARED SECTION PRIMITIVES ============ */
.sec{position:relative;padding:112px 0}
.reveal{opacity:0;transform:translateY(36px);transition:.85s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}
.eyebrow2{display:inline-flex;align-items:center;gap:12px;color:var(--amber);font-family:'JetBrains Mono';font-size:.74rem;letter-spacing:3px;text-transform:uppercase;margin-bottom:18px}
.eyebrow2::before{content:"";width:28px;height:1px;background:var(--amber)}
.h2{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:700;letter-spacing:-.6px;line-height:1.15}
.h2 .am{color:var(--amber)}
.lead{color:var(--mut);font-size:1.06rem;margin-top:18px;max-width:58ch}

/* ============ ABOUT ============ */
.about{background:radial-gradient(1000px 560px at 90% -6%,rgba(255,159,28,.055),transparent 62%)}
.about-head{display:grid;grid-template-columns:1.12fr .88fr;gap:60px;align-items:center;margin-bottom:66px}
.about-head .btn-amber{display:inline-flex;align-items:center;gap:9px;margin-top:30px;background:linear-gradient(135deg,var(--amber),var(--amber-d));color:var(--navy);padding:15px 30px;border-radius:8px;font-weight:600;font-size:.84rem;text-transform:uppercase;letter-spacing:.8px;box-shadow:0 14px 30px rgba(255,159,28,.26);transition:.28s}
.about-head .btn-amber:hover{transform:translateY(-2px);box-shadow:0 20px 42px rgba(255,159,28,.44)}
svg.ico{width:100%;height:100%;display:block}

/* discipline panel */
.domain-card{background:linear-gradient(165deg,rgba(3,40,66,.75),rgba(2,30,50,.3));border:1px solid var(--line);border-radius:16px;padding:28px 32px;position:relative;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.28)}
.domain-card::after{content:"";position:absolute;top:-60px;right:-60px;width:170px;height:170px;border-radius:50%;background:radial-gradient(circle,rgba(255,159,28,.14),transparent 70%)}
.dlabel{font-family:'JetBrains Mono';font-size:.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--mut);padding-bottom:16px;border-bottom:1px solid var(--line);margin-bottom:6px;position:relative}
.domain{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.055);position:relative}
.domain:last-child{border-bottom:0}
.di{width:42px;height:42px;border-radius:10px;background:rgba(255,159,28,.07);border:1px solid rgba(255,159,28,.2);display:grid;place-items:center;padding:10px;color:var(--amber);flex-shrink:0;transition:.32s}
.domain:hover .di{background:var(--amber);color:var(--navy);border-color:var(--amber)}
.domain b{font-weight:600;font-size:1rem;letter-spacing:.2px}

/* capability cards */
.caps{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:20px}
.cap{position:relative;background:linear-gradient(180deg,rgba(3,40,66,.55),rgba(2,30,50,.18));border:1px solid var(--line);border-radius:14px;padding:36px 30px;overflow:hidden;transition:.4s}
.cap::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--amber),var(--amber-d));transition:.5s}
.cap:hover{transform:translateY(-6px);border-color:rgba(255,159,28,.32);box-shadow:0 28px 56px rgba(0,0,0,.42);background:linear-gradient(180deg,rgba(4,52,84,.62),rgba(2,33,55,.24))}
.cap:hover::before{width:100%}
.cap .cidx{position:absolute;top:26px;right:30px;font-family:'JetBrains Mono';font-size:.78rem;color:rgba(255,255,255,.16);letter-spacing:1px}
.cap .ic{width:56px;height:56px;border-radius:13px;background:rgba(255,159,28,.07);border:1px solid rgba(255,159,28,.22);display:grid;place-items:center;padding:14px;color:var(--amber);margin-bottom:24px;transition:.38s}
.cap:hover .ic{background:var(--amber);color:var(--navy);border-color:var(--amber);transform:translateY(-2px)}
.cap h3{font-size:1.17rem;font-weight:700;margin-bottom:12px;letter-spacing:.2px}
.cap p{color:var(--mut);font-size:.92rem;margin-bottom:20px;line-height:1.66}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips span{font-family:'JetBrains Mono';font-size:.66rem;letter-spacing:.5px;color:var(--mut);background:rgba(255,255,255,.035);border:1px solid var(--line);padding:5px 10px;border-radius:6px;text-transform:uppercase;transition:.25s}
.chips span:hover{color:var(--amber);border-color:rgba(255,159,28,.4);background:rgba(255,159,28,.07)}

@media(max-width:980px){
  .sec{padding:84px 0}
  .about-head{grid-template-columns:1fr;gap:36px}
}

/* shared centered header */
.center{text-align:center;max-width:760px;margin:0 auto 56px}
.center .lead{margin-left:auto;margin-right:auto}

/* ============ SOLUTIONS / TABS ============ */
.prod{background:radial-gradient(900px 520px at 10% 0,rgba(255,159,28,.05),transparent 60%)}
.tabs{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:0 auto 40px}
.tab{display:flex;align-items:center;gap:10px;padding:13px 22px;border:1px solid var(--line);border-radius:10px;background:rgba(3,40,66,.4);color:var(--mut);font-family:inherit;font-weight:600;font-size:.88rem;cursor:pointer;transition:.28s}
.tab .tio{width:19px;height:19px;color:var(--amber);transition:.28s}
.tab:hover{color:#fff;border-color:rgba(255,159,28,.3)}
.tab.active{background:linear-gradient(135deg,var(--amber),var(--amber-d));color:var(--navy);border-color:transparent;box-shadow:0 12px 26px rgba(255,159,28,.28)}
.tab.active .tio{color:var(--navy)}
.panel{display:none}
.panel.active{display:block;animation:pfade .5s ease}
@keyframes pfade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.panel-grid{display:grid;grid-template-columns:.92fr 1.18fr;gap:46px;align-items:start;background:linear-gradient(165deg,rgba(3,40,66,.55),rgba(2,30,50,.2));border:1px solid var(--line);border-radius:18px;padding:44px}
.pic{width:62px;height:62px;border-radius:14px;background:rgba(255,159,28,.08);border:1px solid rgba(255,159,28,.22);display:grid;place-items:center;padding:16px;color:var(--amber);margin-bottom:22px}
.panel-head h3{font-size:1.55rem;font-weight:700;margin-bottom:14px;letter-spacing:-.3px}
.panel-head p{color:var(--mut);font-size:.97rem;line-height:1.72}
.pcta{display:inline-flex;align-items:center;gap:8px;margin-top:24px;color:var(--amber);font-weight:600;font-size:.9rem}
.pcta:hover{gap:12px}
.plist{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.pli{display:flex;gap:11px;align-items:flex-start;padding:14px 15px;border:1px solid var(--line);border-radius:10px;background:rgba(2,30,50,.32);font-size:.89rem;transition:.25s}
.pli:hover{border-color:rgba(255,159,28,.4);background:rgba(255,159,28,.05);transform:translateX(3px)}
.pli .pk{color:var(--amber);flex-shrink:0;width:16px;height:16px;margin-top:1px}

/* ============ SUB-SERVICE LIST (rich items with their own description) ============ */
.subnote{font-family:'JetBrains Mono';font-size:.74rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber);margin-bottom:20px}
.subitems{display:flex;flex-direction:column;gap:18px}
.subitem{display:flex;gap:30px;flex-wrap:wrap;align-items:center;padding:30px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(165deg,rgba(3,40,66,.5),rgba(2,30,50,.18));transition:.35s}
.subitem:hover{border-color:rgba(255,159,28,.32);box-shadow:0 24px 48px rgba(0,0,0,.38)}
.subitem-text{flex:1 1 280px;min-width:240px}
.subitem h4{color:var(--amber);font-size:1.08rem;font-weight:700;margin-bottom:10px;letter-spacing:.2px}
.subitem p{color:var(--mut);font-size:.92rem;line-height:1.72}
.submedia{display:flex;gap:12px;flex-wrap:wrap;flex:0 0 auto;max-width:380px}
.submedia .thumb{height:170px;width:170px;border-radius:12px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:16px;transition:.3s;flex-shrink:0;position:relative}
.submedia .thumb:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 20px 36px rgba(0,0,0,.4);border-color:var(--amber)}
.submedia .thumb img{max-width:100%;max-height:100%;object-fit:contain;cursor:zoom-in}
@media(max-width:768px){
  .subitem{padding:24px;gap:20px}
  .submedia{max-width:100%}
  .submedia .thumb{height:140px;width:140px}
}
@media(max-width:560px){.submedia .thumb{height:120px;width:120px}}

/* ============ DIAGRAM CARDS (infographics — no cropping) ============ */
.diagram-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.diagram-card{height:300px;border-radius:14px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:20px;transition:.3s;position:relative}
.diagram-card:hover{transform:translateY(-5px);box-shadow:0 22px 44px rgba(0,0,0,.4);border-color:var(--amber)}
.diagram-card img{max-width:100%;max-height:100%;object-fit:contain;cursor:zoom-in}
@media(max-width:768px){.diagram-grid{grid-template-columns:1fr}.diagram-card{height:240px}}

/* Small magnifier hint shown on hover for any zoomable diagram/thumb */
.submedia .thumb::after,.diagram-card::after{content:"";position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;background:rgba(1,22,39,.85);opacity:0;transition:.25s;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff9f1c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3Cpath d='M11 8v6M8 11h6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:16px}
.submedia .thumb:hover::after,.diagram-card:hover::after{opacity:1}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(1,10,18,.94);display:flex;align-items:center;justify-content:center;padding:50px;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.lightbox.active{opacity:1;visibility:visible}
.lightbox-inner{position:relative;max-width:92vw;max-height:88vh}
.lightbox-inner img{display:block;max-width:92vw;max-height:88vh;border-radius:10px;background:#fff;padding:14px;box-shadow:0 40px 90px rgba(0,0,0,.6)}
.lightbox-close{position:absolute;top:-46px;right:0;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.28);color:#fff;font-size:1.3rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s}
.lightbox-close:hover{background:var(--amber);color:var(--navy);border-color:var(--amber)}
@media(max-width:560px){.lightbox{padding:24px}.lightbox-close{top:-42px;right:0}}

/* ============ INDUSTRY 4.0 PILLARS ============ */
.pillars{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:50px}
.pill-card{position:relative;padding:32px 20px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,rgba(3,40,66,.5),transparent);text-align:center;transition:.35s;overflow:hidden}
.pill-card::before{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:linear-gradient(90deg,var(--amber),var(--amber-d));transition:.45s}
.pill-card:hover{transform:translateY(-6px);border-color:rgba(255,159,28,.4)}
.pill-card:hover::before{width:100%}
.pill-card .pn{font-family:'JetBrains Mono';font-size:1.5rem;font-weight:700;color:var(--amber);opacity:.55}
.pill-card h4{margin-top:12px;font-size:1rem;font-weight:600}

/* ============ INDUSTRIES / STANDARDS / STATS ============ */
.serve{background:radial-gradient(900px 520px at 90% 100%,rgba(255,159,28,.05),transparent 60%)}
.tags{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.tag{display:flex;align-items:center;gap:10px;padding:13px 22px;border:1px solid var(--line);border-radius:10px;background:rgba(3,40,66,.4);font-size:.93rem;font-weight:500;transition:.3s}
.tag .tg{width:7px;height:7px;border-radius:50%;background:var(--amber);flex-shrink:0}
.tag:hover{border-color:var(--amber);transform:translateY(-3px);background:rgba(255,159,28,.06)}
.std{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:36px}
.std span{font-family:'JetBrains Mono';font-size:.82rem;letter-spacing:1px;color:var(--amber);padding:10px 18px;border:1px dashed rgba(255,159,28,.35);border-radius:8px}
.statband{margin-top:62px;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.sbox{background:var(--navy);padding:40px 20px;text-align:center}
.sbox .n{font-family:'JetBrains Mono';font-size:2.6rem;font-weight:700;color:var(--amber);line-height:1}
.sbox .l{color:var(--mut);font-size:.84rem;margin-top:10px}

/* ============ CTA BAND ============ */
.cta-band{position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(135deg,#02233a,#011627)}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.4;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:46px 46px}
.cta-band::after{content:"";position:absolute;top:50%;left:50%;width:700px;height:700px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,159,28,.12),transparent 60%)}
.cta-band .inner{position:relative;z-index:2;padding:92px 0;text-align:center}
.cta-band h2{font-size:clamp(1.8rem,3.7vw,2.7rem);font-weight:700;line-height:1.18}
.cta-band p{color:var(--mut);margin:18px auto 32px;max-width:54ch;font-size:1.08rem}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:50px}
.crow{display:flex;gap:16px;align-items:flex-start;padding:22px 0;border-bottom:1px solid var(--line)}
.crow:last-child{border-bottom:0}
.cic{width:48px;height:48px;border-radius:11px;background:rgba(255,159,28,.08);border:1px solid rgba(255,159,28,.2);display:grid;place-items:center;padding:12px;color:var(--amber);flex-shrink:0}
.ck{font-family:'JetBrains Mono';font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--mut)}
.cv{font-size:1.03rem;margin-top:5px;display:block;line-height:1.5}
a.cv:hover{color:var(--amber)}
.cform{background:linear-gradient(165deg,rgba(3,40,66,.55),rgba(2,30,50,.2));border:1px solid var(--line);border-radius:18px;padding:38px}
.field{margin-bottom:18px}
.field label{display:block;font-family:'JetBrains Mono';font-size:.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--mut);margin-bottom:8px}
.field input,.field textarea{width:100%;padding:14px 16px;background:rgba(1,16,29,.7);border:1px solid var(--line);border-radius:10px;color:var(--ink);font-family:inherit;font-size:16px;transition:.25s}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--amber);box-shadow:0 0 0 3px rgba(255,159,28,.14)}
.field textarea{resize:vertical;min-height:130px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cform .btn-amber{width:100%;justify-content:center;display:inline-flex;align-items:center;gap:9px;background:linear-gradient(135deg,var(--amber),var(--amber-d));color:var(--navy);padding:16px;border:0;border-radius:8px;font-family:inherit;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.8px;cursor:pointer;transition:.28s}
.cform .btn-amber:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(255,159,28,.4)}
.fnote{display:none;color:var(--amber);font-family:'JetBrains Mono';font-size:.8rem;text-align:center;margin-top:14px}

/* ============ CONTACT: MAP ============ */
.map-wrap{margin-top:50px;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:rgba(3,40,66,.3)}
.map-wrap iframe{width:100%;height:420px;border:0;display:block}
@media(max-width:560px){.map-wrap iframe{height:300px}}

/* ============ FOOTER ============ */
footer{border-top:1px solid var(--line);background:#020e18;padding:66px 0 30px;position:relative;z-index:1}
.fgrid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:42px}
.flogo img{height:52px}
.fcol p{color:var(--mut);font-size:.92rem;margin-top:18px;max-width:34ch;line-height:1.7}
.fcol h5{font-family:'JetBrains Mono';font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--amber);margin-bottom:18px}
.fcol a{display:flex;gap:9px;align-items:flex-start;color:var(--mut);margin-bottom:12px;font-size:.92rem;transition:.2s}
.fcol a:hover{color:#fff}
.fcol a svg{width:16px;height:16px;color:var(--amber);flex-shrink:0;margin-top:2px}
.fcopy{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--mut);font-size:.82rem;margin-top:52px;border-top:1px solid var(--line);padding-top:26px}
.fcopy-right a{color:var(--amber);font-weight:600;transition:.2s}
.fcopy-right a:hover{color:var(--ink)}
@media(max-width:600px){.fcopy{flex-direction:column;text-align:center;gap:8px}}

/* ============ INNER-PAGE HERO (non-slider pages) ============ */
.page-hero{position:relative;overflow:hidden;min-height:560px;display:flex;align-items:center;padding:140px 0 60px;text-align:center;background:var(--navy)}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero .overlay{position:absolute;inset:0;background:
   linear-gradient(180deg,rgba(1,22,39,.55) 0%,rgba(1,22,39,.72) 55%,rgba(1,22,39,.96) 100%),
   radial-gradient(1200px 720px at 78% 26%,rgba(255,159,28,.14),transparent 58%)}
.page-hero .grid{position:absolute;inset:0;opacity:.22;background-image:
   linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
   linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:46px 46px}
.page-hero .wrap{position:relative;z-index:5;width:100%}
.page-hero .tagline{font-size:clamp(1.6rem,3.2vw,2.3rem);font-weight:700;letter-spacing:-.4px;line-height:1.3;margin:18px auto 0;max-width:22ch;color:var(--ink)}
.page-hero .lead{margin-left:auto;margin-right:auto}
@media(max-width:980px){.page-hero{min-height:440px;padding:120px 0 50px}}

/* ============ EXPERTISE / QUOTE BLOCK ============ */
.quote-block{max-width:880px;margin:0 auto;text-align:center;padding:46px 50px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(165deg,rgba(3,40,66,.55),rgba(2,30,50,.2));position:relative;overflow:hidden}
.quote-block::before{content:"";position:absolute;top:-50px;left:-50px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(255,159,28,.14),transparent 70%)}
.quote-block p{position:relative;font-size:1.18rem;line-height:1.75;color:var(--ink)}
@media(max-width:560px){.quote-block{padding:32px 24px}}

/* ============ FLOATING ============ */
.fab{position:fixed;right:22px;bottom:22px;z-index:60;width:56px;height:56px;border-radius:50%;background:#25d366;display:grid;place-items:center;color:#fff;box-shadow:0 12px 30px rgba(37,211,102,.45);transition:.25s;animation:bob 2.6s infinite}
.fab:hover{transform:scale(1.08)}
.fab svg{width:28px;height:28px}
.toTop{position:fixed;left:22px;bottom:22px;z-index:60;width:46px;height:46px;border-radius:11px;background:var(--navy-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--amber);cursor:pointer;opacity:0;pointer-events:none;transition:.3s}
.toTop.show{opacity:1;pointer-events:auto}
.toTop:hover{border-color:var(--amber)}

@media(max-width:980px){
  .panel-grid{grid-template-columns:1fr;gap:30px;padding:30px}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .statband{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:34px}
  .fgrid{grid-template-columns:1fr 1fr;gap:34px}
}
@media(max-width:700px){
  .plist{grid-template-columns:1fr}
}
@media(max-width:560px){
  .frow{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .sbox .n{font-size:2.1rem}
}
@media(max-width:420px){
  .pillars{grid-template-columns:1fr}
  .statband{grid-template-columns:1fr}
}

/* ============ IMAGE ENHANCEMENTS (photo version) ============ */
.about-head{align-items:start}
.about-photo{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);margin-bottom:20px;height:236px;background:var(--navy-2)}
.about-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:.6s}
.about-photo:hover img{transform:scale(1.06)}
.about-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(1,22,39,.55))}

.pbanner{position:relative;height:178px;border-radius:12px;overflow:hidden;border:1px solid var(--line);margin-bottom:24px;background:var(--navy-2)}
.pbanner img{width:100%;height:100%;object-fit:cover;display:block;transition:.6s}
.panel-grid:hover .pbanner img{transform:scale(1.05)}
.pbanner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(1,22,39,.2),rgba(1,22,39,.72))}

.indgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.indcard{position:relative;height:210px;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:var(--navy-2)}
.indcard img{width:100%;height:100%;object-fit:cover;display:block;transition:.6s;opacity:.9}
.indcard:hover img{transform:scale(1.08)}
.indcard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(1,22,39,.2) 0%,rgba(1,22,39,.55) 55%,rgba(1,22,39,.93) 100%)}
.indcard .ilabel{position:absolute;left:18px;right:18px;bottom:16px;z-index:2;display:flex;align-items:center;gap:10px;font-weight:600;font-size:1rem;line-height:1.3}
.indcard .ilabel .tg{width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 12px var(--amber);flex-shrink:0}
.indcard::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--amber),var(--amber-d));z-index:3;transition:.45s}
.indcard:hover::before{width:100%}

.cta-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.cta-bg img{width:100%;height:100%;object-fit:cover;opacity:.2}
.cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(2,35,58,.86),rgba(1,22,39,.93))}

@media(max-width:980px){.indgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.indcard{height:160px}}

.indgrid.gallery-3{grid-template-columns:repeat(3,1fr)}
.indgrid.gallery-3 .indcard{height:260px}
@media(max-width:980px){.indgrid.gallery-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.indgrid.gallery-3 .indcard{height:180px}}

/* ============ LIVE ANIMATED BACKGROUND + EXTRA MOTION ============ */
html{background:#011627}
body{background:transparent}
#bgfx{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
#bgfx .base{position:absolute;inset:0;background:
  radial-gradient(1200px 820px at 12% 8%,rgba(59,130,246,.13),transparent 60%),
  radial-gradient(1000px 720px at 88% 92%,rgba(255,159,28,.10),transparent 60%),
  linear-gradient(180deg,#011627 0%,#02101d 100%)}
#bgfx .blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;mix-blend-mode:screen}
#bgfx .b1{width:540px;height:540px;background:#1d4ed8;top:-140px;left:-120px;animation:bdrift1 24s ease-in-out infinite}
#bgfx .b2{width:480px;height:480px;background:#ff9f1c;bottom:-160px;right:-120px;animation:bdrift2 28s ease-in-out infinite}
#bgfx .b3{width:420px;height:420px;background:#0ea5b7;top:38%;left:56%;animation:bdrift3 32s ease-in-out infinite}
@keyframes bdrift1{0%,100%{transform:translate(0,0)}50%{transform:translate(130px,90px)}}
@keyframes bdrift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-110px,-90px)}}
@keyframes bdrift3{0%,100%{transform:translate(0,0)}50%{transform:translate(-90px,70px)}}
#net{position:absolute;inset:0;width:100%;height:100%;opacity:.4}

/* shimmering accent headings */
.h2 .am{background:linear-gradient(90deg,#ffe2a8,var(--amber) 50%,#ffd27a);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:amShine 5s linear infinite}
@keyframes amShine{to{background-position:200% center}}

/* richer hover glow */
.cap:hover,.pill-card:hover{box-shadow:0 26px 56px rgba(0,0,0,.5),0 0 0 1px rgba(255,159,28,.28),0 0 46px rgba(255,159,28,.14)}
.tag:hover{box-shadow:0 10px 30px rgba(255,159,28,.18)}
.panel-grid{box-shadow:0 32px 70px rgba(0,0,0,.45)}
.indcard:hover{box-shadow:0 24px 50px rgba(0,0,0,.55),0 0 36px rgba(255,159,28,.16)}

/* reveal with subtle scale-in */
.reveal{transform:translateY(40px) scale(.985)}
.reveal.in{transform:none}

/* animated eyebrow line */
.eyebrow2::before{transition:width .45s ease}
.center:hover .eyebrow2::before{width:44px}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.fab:hover{animation-play-state:paused}
@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}}
@media(max-width:768px){.hero{min-height:460px;height:80svh;max-height:640px}.arrow{display:none}.slide .eyebrow{margin-bottom:14px;font-size:.62rem;letter-spacing:1.5px;padding:6px 13px}.slide .heroh{font-size:clamp(1.5rem,6.2vw,2rem);letter-spacing:-.5px}.slide p.sub{margin-top:13px;font-size:.9rem;max-width:38ch}.slide .hcta{margin-top:20px}.btn-pill{padding:14px 30px;font-size:.84rem}.btn-out{padding:14px 30px;font-size:.84rem}.dots{bottom:16px}}
@media(max-width:1024px){.navlinks{gap:6px;padding:0 24px}.navlinks a.nl{font-size:1.18rem;padding:13px 0}.navlinks .btn-cta{margin-top:16px;padding:15px 40px;font-size:.95rem}}
@media(max-width:1024px){header.scrolled{-webkit-backdrop-filter:none;backdrop-filter:none}}

/* ============ BLOG: HERO STATS ============ */
.blog-hero-stats{display:flex;align-items:center;justify-content:center;gap:28px;margin-top:34px;flex-wrap:wrap}
.blog-hero-stat{text-align:center}
.blog-hero-stat .n{font-family:'JetBrains Mono';font-size:1.8rem;font-weight:700;color:var(--amber);line-height:1}
.blog-hero-stat .l{color:var(--mut);font-size:.78rem;margin-top:6px;text-transform:uppercase;letter-spacing:1px}
.blog-hero-divider{width:1px;height:34px;background:var(--line)}

/* ============ BLOG: GRID + CARD ============ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.blog-grid{grid-template-columns:1fr}}
.bcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:linear-gradient(180deg,rgba(3,40,66,.5),rgba(2,30,50,.18));transition:.35s}
.bcard:hover{transform:translateY(-6px);border-color:rgba(255,159,28,.32);box-shadow:0 28px 56px rgba(0,0,0,.42)}
.bcard-img{position:relative;height:200px;background-color:var(--navy-2);background-size:cover;background-position:center;display:block}
.bcard-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(1,22,39,.05) 0%,rgba(1,22,39,.55) 100%)}
.bcard-cat{position:absolute;top:14px;left:14px;z-index:2;font-family:'JetBrains Mono';font-size:.66rem;letter-spacing:1px;text-transform:uppercase;color:var(--navy);background:var(--amber);padding:6px 12px;border-radius:100px;font-weight:700}
.bcard-body{padding:24px;display:flex;flex-direction:column;flex:1}
.bcard-meta{display:flex;align-items:center;gap:16px;font-family:'JetBrains Mono';font-size:.72rem;color:var(--mut);margin-bottom:14px}
.bcard-meta span{display:flex;align-items:center;gap:6px}
.bcard-meta svg{width:13px;height:13px;color:var(--amber)}
.bcard h3{font-size:1.12rem;font-weight:700;line-height:1.4;margin-bottom:10px}
.bcard h3 a{transition:.2s}
.bcard h3 a:hover{color:var(--amber)}
.bcard p{color:var(--mut);font-size:.88rem;line-height:1.66;margin-bottom:18px;flex:1}
.bcard-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--line)}
.bcard-author{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--mut)}
.bcard-author svg{width:14px;height:14px;color:var(--amber)}
.bcard-cta{display:inline-flex;align-items:center;gap:6px;color:var(--amber);font-weight:600;font-size:.82rem}
.bcard-cta:hover{gap:10px}

/* ============ BLOG: PAGINATION ============ */
.blog-pagination{display:flex;justify-content:center;gap:8px;margin-top:56px;flex-wrap:wrap;list-style:none}
.blog-pagination span,.blog-pagination a{display:flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 14px;border-radius:9px;border:1px solid var(--line);color:var(--mut);font-size:.86rem;font-weight:600;transition:.2s}
.blog-pagination a:hover{border-color:var(--amber);color:var(--amber)}
.blog-pagination .current{background:linear-gradient(135deg,var(--amber),var(--amber-d));color:var(--navy);border-color:transparent}

/* ============ BLOG: EMPTY STATE ============ */
.blog-empty{text-align:center;max-width:480px;margin:0 auto;padding:70px 30px}
.blog-empty .ic{width:72px;height:72px;margin:0 auto 22px;border-radius:50%;background:rgba(255,159,28,.08);border:1px solid rgba(255,159,28,.22);display:flex;align-items:center;justify-content:center;color:var(--amber)}
.blog-empty .ic svg{width:32px;height:32px}
.blog-empty h3{font-size:1.3rem;font-weight:700;margin-bottom:10px}
.blog-empty p{color:var(--mut);margin-bottom:24px}

/* ============ BLOG: SINGLE — META ROW ============ */
.blog-breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;font-family:'JetBrains Mono';font-size:.74rem;color:var(--mut);margin-bottom:20px}
.blog-breadcrumb a:hover{color:var(--amber)}
.blog-meta-row{display:flex;align-items:center;justify-content:center;gap:30px;margin-top:30px;flex-wrap:wrap}
.blog-meta-item{display:flex;align-items:center;gap:10px}
.blog-meta-item svg{width:18px;height:18px;color:var(--amber);flex-shrink:0}
.blog-meta-item .lbl{display:block;font-family:'JetBrains Mono';font-size:.64rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--mut)}
.blog-meta-item .val{display:block;font-size:.92rem;font-weight:600;margin-top:2px}

/* ============ BLOG: SINGLE — LAYOUT ============ */
.blog-single-grid{display:grid;grid-template-columns:1fr 340px;gap:50px;align-items:start}
.blog-body{color:var(--mut);font-size:1rem;line-height:1.85}
.blog-body h2,.blog-body h3,.blog-body h4{color:var(--ink);font-weight:700;margin:34px 0 14px;line-height:1.3}
.blog-body h2{font-size:1.5rem}
.blog-body h3{font-size:1.22rem}
.blog-body p{margin-bottom:18px}
.blog-body a{color:var(--amber);text-decoration:underline;text-underline-offset:3px}
.blog-body ul,.blog-body ol{margin:0 0 18px 22px}
.blog-body li{margin-bottom:8px}
.blog-body img{max-width:100%;border-radius:12px;margin:22px 0}
.blog-body blockquote{border-left:3px solid var(--amber);padding:6px 0 6px 22px;margin:24px 0;color:var(--ink);font-style:italic}

/* Share row */
.blog-share-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:40px;padding-top:28px;border-top:1px solid var(--line)}
.blog-share-label{font-family:'JetBrains Mono';font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--mut)}
.blog-share-btns{display:flex;gap:10px;flex-wrap:wrap}
.blog-share-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:8px;border:1px solid var(--line);font-size:.82rem;font-weight:600;color:var(--mut);transition:.25s}
.blog-share-btn svg{width:15px;height:15px}
.blog-share-btn:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-2px)}
.blog-share-btns--vertical{flex-direction:column}
.blog-share-btns--vertical .blog-share-btn{width:100%}

/* Prev/next nav */
.blog-prevnext{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:30px}
.blog-prevnext-item{padding:18px;border:1px solid var(--line);border-radius:12px;transition:.25s}
.blog-prevnext-item:hover{border-color:rgba(255,159,28,.4);background:rgba(255,159,28,.05)}
.blog-prevnext-item.next{text-align:right}
.blog-prevnext-dir{display:flex;align-items:center;gap:6px;font-family:'JetBrains Mono';font-size:.68rem;letter-spacing:1px;text-transform:uppercase;color:var(--amber);margin-bottom:8px}
.blog-prevnext-item.next .blog-prevnext-dir{justify-content:flex-end}
.blog-prevnext-dir svg{width:13px;height:13px}
.blog-prevnext-title{font-size:.9rem;font-weight:600;line-height:1.4}
.blog-back-link{display:inline-flex;align-items:center;gap:8px;margin-top:30px;color:var(--mut);font-size:.88rem;font-weight:600;transition:.2s}
.blog-back-link svg{width:16px;height:16px}
.blog-back-link:hover{color:var(--amber)}

/* Sidebar */
.blog-sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:110px}
.blog-sidebar-card{border:1px solid var(--line);border-radius:14px;padding:24px;background:linear-gradient(165deg,rgba(3,40,66,.55),rgba(2,30,50,.2))}
.blog-sidebar-card.dark{background:linear-gradient(165deg,#02233a,#011627)}
.blog-sidebar-card h4{font-size:.96rem;font-weight:700;margin-bottom:16px}
.blog-sidebar-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.blog-sidebar-list li{display:flex;align-items:center;gap:12px}
.blog-sidebar-list svg{width:17px;height:17px;color:var(--amber);flex-shrink:0}
.blog-sidebar-list .lbl{display:block;font-family:'JetBrains Mono';font-size:.62rem;letter-spacing:1px;text-transform:uppercase;color:var(--mut)}
.blog-sidebar-list .val{display:block;font-size:.86rem;font-weight:600;margin-top:2px}
.blog-sidebar-card p{color:var(--mut);font-size:.86rem;line-height:1.6;margin-bottom:16px}
.blog-newsletter-form{display:flex;flex-direction:column;gap:10px}
.blog-newsletter-form input{padding:12px 14px;background:rgba(1,16,29,.7);border:1px solid var(--line);border-radius:9px;color:var(--ink);font-family:inherit;font-size:16px}
.blog-newsletter-form input:focus{outline:0;border-color:var(--amber)}
.blog-newsletter-form button{background:linear-gradient(135deg,var(--amber),var(--amber-d));color:var(--navy);border:0;padding:11px;border-radius:9px;font-weight:700;font-size:.84rem;cursor:pointer;transition:.25s}
.blog-newsletter-form button:hover{transform:translateY(-2px)}

@media(max-width:980px){
  .blog-single-grid{grid-template-columns:1fr}
  .blog-sidebar{position:static}
}
@media(max-width:560px){
  .blog-prevnext{grid-template-columns:1fr}
  .blog-prevnext-item.next{text-align:left}
  .blog-prevnext-item.next .blog-prevnext-dir{justify-content:flex-start}
}

/* ============ FAQ (AEO) ============ */
.faq-sec{padding-top:20px}
.faq-list{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,rgba(3,40,66,.5),rgba(2,30,50,.18));overflow:hidden;transition:.3s}
.faq-item[open]{border-color:rgba(255,159,28,.34);box-shadow:0 20px 44px rgba(0,0,0,.34)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 24px;font-size:1.02rem;font-weight:600;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--amber)}
.faq-ico{position:relative;flex:0 0 20px;width:20px;height:20px}
.faq-ico::before,.faq-ico::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--amber);border-radius:2px;transition:.3s}
.faq-ico::before{width:14px;height:2px}
.faq-ico::after{width:2px;height:14px}
.faq-item[open] .faq-ico::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-a{padding:0 24px 22px;color:var(--mut);font-size:.96rem;line-height:1.75;max-width:66ch}
.faq-a p{margin:0}
@media(max-width:560px){
  .faq-item summary{padding:16px 18px;font-size:.95rem}
  .faq-a{padding:0 18px 18px}
}

/* ============ FORMS (contact + newsletter) ============ */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden}
.fnote.err{color:#ff6b6b}
.nl-note{display:none;margin-top:10px;font-family:'JetBrains Mono';font-size:.78rem;color:var(--amber);line-height:1.5}
.nl-note.err{color:#ff6b6b}
.cform button[disabled],.blog-newsletter-form button[disabled]{opacity:.6;cursor:progress}

/* ============================================================
   Responsive QA fixes (coworker audit — 2026-07-02)
   ============================================================ */

/* R1 / R2 — capability & service/expertise tag chips overflowed the
   viewport by ~8-10px on very narrow phones (<=320px). Let flex items
   shrink and let long labels wrap so nothing exceeds the screen. */
.chips span,.tag{max-width:100%;min-width:0;overflow-wrap:anywhere}
@media(max-width:360px){
  .wrap{padding:0 16px}
  .chips span{padding:5px 8px}
  .tag{padding:11px 15px;font-size:.86rem;gap:8px}
}

/* R3 — footer + contact links were only ~24px tall. Give them the
   recommended 44px minimum touch target on mobile. */
@media(max-width:768px){
  .fcol a{min-height:44px;align-items:center;padding:5px 0;margin-bottom:6px}
  .fcol a svg{margin-top:0}
}

/* R4 — the open mobile nav overlay was 98% opaque, letting the hero
   show through faintly. Make it fully opaque. */
@media(max-width:1024px){
  .navlinks{background:#011627}
}

/* R5 — the fixed WhatsApp (bottom-right) and back-to-top (bottom-left)
   buttons overlapped full-width CTA buttons on small screens. Shrink
   them into the corners and give the CTA band bottom clearance. */
@media(max-width:560px){
  .fab{width:50px;height:50px;right:14px;bottom:14px}
  .fab svg{width:25px;height:25px}
  .toTop{width:42px;height:42px;left:14px;bottom:14px}
  .cta-band .inner{padding-bottom:76px}
}
