/* ============================================================
   DigitalBlue — shared site styles
   Brand tokens (from provided color sheet)
   ============================================================ */
:root{
  --black:#000000;
  --darker-azure:#002a40;
  --dark-azure:#004f7a;
  --vivid-azure:#008afc;
  --vivid-azure-2:#0a7fdb;
  --gray-azure:#6997b1;
  --pastel-gray:#b7cedb;
  --pastel-green:#9cfac7;
  --white:#ffffff;

  --ink:#0B2233;
  --body:#3E5366;
  --muted:#7A8DA0;
  --line:#E3EBF2;
  --line-2:#EEF3F8;
  --bg:#F6F9FC;
  --card:#ffffff;
  --highlight:#E6F3FE;

  --display:"Schibsted Grotesk","Helvetica Neue","Helvetica","Arial",sans-serif;
  --body-font:"Schibsted Grotesk","Helvetica Neue","Helvetica","Arial",sans-serif;
  --mono:"Schibsted Grotesk","Helvetica Neue","Helvetica","Arial",sans-serif;

  --r-sm:10px;
  --r-md:14px;
  --r-lg:20px;
  --r-xl:28px;

  --shadow-sm: 0 1px 0 rgba(0,42,64,.04), 0 2px 6px rgba(0,42,64,.05);
  --shadow-md: 0 2px 0 rgba(0,42,64,.04), 0 14px 34px -14px rgba(0,42,64,.2);
  --shadow-lg: 0 30px 60px -24px rgba(0,42,64,.3);

  --glass-saturate:140%;
  --glass-blur-sm:14px;
  --glass-blur-md:18px;
  --glass-blur-lg:22px;
  --glass-fill-soft:linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,.05) 100%);
  --glass-fill-panel:linear-gradient(180deg, rgba(12,33,54,.5) 0%, rgba(3,19,31,.72) 100%);
  --glass-fill-strong:linear-gradient(180deg, rgba(14,38,61,.74) 0%, rgba(3,18,29,.86) 100%);
  --footer-bg:rgba(5,39,66,.55);
  --footer-bg-fallback:#052742;
  --glass-border-soft:rgba(255,255,255,.1);
  --glass-border-panel:rgba(255,255,255,.12);
  --glass-border-strong:rgba(255,255,255,.14);
  --glass-shadow-soft:0 1px 0 rgba(255,255,255,.04), 0 14px 30px -18px rgba(0,0,0,.36);
  --glass-shadow-panel:0 8px 30px -10px rgba(0,0,0,.4);
  --glass-shadow-strong:0 24px 56px -22px rgba(0,0,0,.58);

  --hero-network-dark:url("../public/DBWebBackgrounds/hero-network-dark.svg");
  --hero-network-light:url("../public/DBWebBackgrounds/hero-network-light.svg");
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body-font);
  color:var(--ink);
  background:
    url("../public/DBWebBackgrounds/bg-dark.png") top center / cover no-repeat fixed,
    #001a28;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.55;
}
input,
textarea,
select,
button{
  font-family:inherit;
}
body[data-site-section]:not(.svc-parent-page):not(.home):not([data-site-section="home"]){
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
}
body[data-site-section]:not(.svc-parent-page):not(.home):not([data-site-section="home"]):not([data-page-bg]){
  background:
    url("../public/DBWebBackgrounds/bg-light.png") top center / cover no-repeat fixed,
    #ffffff;
}
body[data-site-section]:not(.svc-parent-page):not(.home):not([data-site-section="home"]) > :is(main, .sub-page-wrap){
  flex:1 0 auto;
}
body[data-site-section]:not(.svc-parent-page):not(.home):not([data-site-section="home"]) > .site-footer{
  margin-top:auto;
}
.page-bg{
  position:fixed;
  top:0; left:0;
  width:100%; height:200vh;
  z-index:-1; pointer-events:none;
  background:#001a28 url("../public/DBWebBackgrounds/bg-dark.png") top center / cover no-repeat;
}
@media (prefers-reduced-motion: no-preference){
  .page-bg{ will-change: transform; }
}
img{max-width:100%; display:block}
a{color:var(--vivid-azure); text-decoration:none}
a:hover{text-decoration:underline}

/* ============================================================
   Nav
   ============================================================ */
.site-nav{
  position:sticky; top:0; z-index:50;
  background:#000;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-nav .inner{
  max-width:1240px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 32px;
}
.site-nav .logo img{ height:34px; width:auto }
.site-nav ul{
  list-style:none; padding:0; margin:0;
  display:flex; gap:4px;
}
.site-nav ul a{
  color:#fff; font-size:14px; font-weight:500;
  padding:10px 14px; border-radius:999px;
  border:0.5px solid transparent;
  display:inline-flex; align-items:center; gap:6px;
  transition: background .15s, color .15s, border-color .15s;
  text-decoration:none;
}

.site-nav .desktop-nav > .has-sub > a{ border-radius:12px; }

.desktop-nav .has-sub{ position:relative; }
.desktop-nav .has-sub::after{
  content:"";
  position:absolute;
  top:100%;
  left:0;
  right:0;
  height:10px;
}
.desktop-nav .chev{ opacity:.7; transition: transform .18s; }
.desktop-nav .has-sub:hover > a .chev,
.desktop-nav .has-sub:focus-within > a .chev{ transform: rotate(180deg); }
.site-nav .desktop-nav a:is(:hover, :focus-visible, .is-current-page),
.site-nav .desktop-nav .has-sub:is(:hover, :focus-within, .is-current-branch) > a{
  background:rgba(0,79,122,.45);
  color:#9cfac7;
  border-color:rgba(156,250,199,.35);
}
.desktop-nav .sub-menu{
  list-style:none; margin:0; padding:14px 8px 10px;
  position:absolute; top:calc(100% + 10px); left:0;
  min-width:236px;
  background:linear-gradient(180deg, rgba(13,13,13,.98) 0%, rgba(5,22,33,.98) 100%);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  box-shadow:
    0 18px 38px rgba(0,0,0,.48),
    inset 0 1px 0 rgba(255,255,255,.06);
  display:flex; flex-direction:column; gap:4px;
  opacity:0; visibility:hidden;
  transform: translateY(-4px);
  transition: opacity .15s, transform .15s, visibility 0s linear .15s;
  z-index:51;
  overflow:hidden;
}
.desktop-nav .sub-menu::before{
  content:"";
  position:absolute;
  top:0;
  left:12px;
  right:12px;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(156,250,199,.28), rgba(0,138,252,.3), transparent);
  pointer-events:none;
}
.desktop-nav .sub-menu::after{
  content:"";
  position:absolute;
  top:100%;
  left:18px;
  width:calc(100% - 36px);
  height:0;
  border-top:8px solid rgba(5,22,33,.98);
  border-left:12px solid transparent;
  border-right:12px solid transparent;
  pointer-events:none;
  transition: border-top-color .24s ease;
}
.desktop-nav .has-sub:hover > .sub-menu,
.desktop-nav .has-sub:focus-within > .sub-menu{
  opacity:1; visibility:visible; transform: translateY(0);
  transition: opacity .15s, transform .15s, visibility 0s;
}
.desktop-nav .sub-menu li{ list-style:none; }
.desktop-nav .sub-menu a{
  display:block;
  padding:10px 14px;
  font-size:13px; font-weight:500;
  border-radius:11px;
  white-space:nowrap;
  border:0.5px solid transparent;
  background:rgba(255,255,255,0);
  transition: background .15s, color .15s, border-color .15s;
}
.desktop-nav .sub-menu a:hover,
.desktop-nav .sub-menu a:focus-visible{
  background:rgba(0,79,122,.32);
  border-color:rgba(156,250,199,.2);
  text-decoration:none;
}
.mobile-menu .m-sub{
  padding-left:26px !important;
  font-size:14px !important;
  opacity:.85;
}
.site-nav .cta{
  background:rgba(0,100,180,.38);
  color:#fff !important;
  padding:10px 18px; border-radius:999px;
  font-weight:600; font-size:14px;
  border:0.5px solid transparent;
  transition: background .2s, border-color .2s, transform .18s;
  text-decoration:none;
}
.site-nav .cta:hover{
  background:rgba(0,138,252,.28);
  border:0.5px solid #008afc;
  transform:translateY(-1px);
}

.burger{
  display:none;
  background:transparent; border:1px solid rgba(255,255,255,.2);
  width:40px; height:40px; border-radius:10px; align-items:center; justify-content:center; cursor:pointer;
}
.burger svg{ width:20px; height:20px; color:#fff }

.mobile-menu{ display:none }

@media (max-width:920px){
  .site-nav .desktop-nav{ display:none }
  .burger{ display:inline-flex }
  .site-nav .cta{ display:none }
  .mobile-menu{
    padding:14px 20px 28px;
    border-top:1px solid rgba(255,255,255,.08);
    background:#000;
  }
  /* Open menu is its own scroll container below the bar, so a long menu can
     reach its last item by scrolling itself instead of the whole page. */
  .mobile-menu.open{
    display:block;
    position:fixed;
    top:62px;
    left:0;
    right:0;
    max-height:calc(100vh - 62px);
    max-height:calc(100dvh - 62px);
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
  }
  /* Lock the page behind the open menu so only the menu scrolls. Fixing
     <body> (not just overflow:hidden) is what holds on iOS Safari; the bar is
     pinned so the burger stays reachable to close the menu. */
  html.nav-locked,
  html.nav-locked body{ overflow:hidden; }
  html.nav-locked body{ position:fixed; left:0; right:0; width:100%; }
  html.nav-locked .site-nav{ position:fixed; top:0; left:0; right:0; }
  .mobile-menu a{
    display:block; padding:12px 10px;
    color:#fff; font-weight:500; font-size:15px;
    border-bottom:1px solid rgba(255,255,255,.08);
    border-radius:12px;
    text-decoration:none;
    transition: background .15s, color .15s, box-shadow .15s, border-color .15s;
  }
  .mobile-menu a:not(.cta-m):is(.is-current-page, .is-current-branch){
    background:rgba(0,79,122,.45);
    color:#9cfac7;
    box-shadow:inset 0 0 0 0.5px rgba(156,250,199,.35);
    border-bottom-color:transparent;
  }
  .mobile-menu .m-sub.is-current-page{ opacity:1 }
  .mobile-menu a:last-child{ border-bottom:0 }
  .mobile-menu .cta-m{
    display:inline-block; margin-top:12px;
    background:var(--vivid-azure); color:#fff; padding:12px 18px; border-radius:999px; font-weight:600;
  }
}

/* ============================================================
   Page scaffold
   ============================================================ */
.container{ max-width:1240px; margin:0 auto; padding:0 32px }
@media (max-width:720px){ .container{ padding:0 20px } }

.section{ padding:72px 0; border-bottom:1px solid rgba(0,138,252,.12) }
@media (max-width:720px){ .section{ padding:48px 0 } }

.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:12px;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--vivid-azure);
}
.kicker::before{
  content:""; width:22px; height:1px; background:var(--vivid-azure);
  display:inline-block;
}

h1,h2,h3,h4{ font-family:var(--display); color:var(--darker-azure); letter-spacing:-0.02em; line-height:1.08; margin:0 }
h1{ font-size:clamp(40px, 5.6vw, 78px); font-weight:700 }
h2{ font-size:clamp(30px, 3.6vw, 48px); font-weight:700 }
h3{ font-size:clamp(20px, 2vw, 26px); font-weight:600 }
h4{ font-size:18px; font-weight:600 }
.lede{ font-size:18px; color:var(--body); max-width:60ch; line-height:1.6 }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  height:50px; padding:0 22px;
  border-radius:999px;
  font-weight:600; font-size:15px;
  border:1px solid transparent;
  cursor:pointer;
  transition: transform .18s, box-shadow .18s, background .18s;
  text-decoration:none;
}
.btn.primary{
  background:var(--vivid-azure); color:#fff;
  box-shadow: 0 14px 28px -12px rgba(0,138,252,.55);
}
.btn.primary:hover{ transform:translateY(-1px); background:var(--vivid-azure-2); box-shadow: 0 18px 32px -12px rgba(0,138,252,.65); text-decoration:none; }
.btn.ghost{
  background:#fff; color:var(--darker-azure);
  border-color:var(--line);
}
.btn.ghost:hover{ border-color:var(--pastel-gray); text-decoration:none; }
.btn.dark{
  background:var(--darker-azure); color:#fff;
}
.btn.dark:hover{ background:var(--dark-azure); text-decoration:none }
.btn svg{ transition:transform .18s }
.btn:hover svg{ transform:translateX(2px) }

/* Reusable frosted-glass surfaces */
.glass-surface{
  background:var(--glass-fill, var(--glass-fill-panel));
  border:1px solid var(--glass-border, var(--glass-border-panel));
  box-shadow:var(--glass-shadow, var(--glass-shadow-panel));
  backdrop-filter:blur(var(--glass-blur, var(--glass-blur-md))) saturate(var(--glass-saturate));
  -webkit-backdrop-filter:blur(var(--glass-blur, var(--glass-blur-md))) saturate(var(--glass-saturate));
}
.glass-surface--soft{
  --glass-fill:var(--glass-fill-soft);
  --glass-border:var(--glass-border-soft);
  --glass-shadow:var(--glass-shadow-soft);
  --glass-blur:var(--glass-blur-sm);
}
.glass-surface--panel{
  --glass-fill:var(--glass-fill-panel);
  --glass-border:var(--glass-border-panel);
  --glass-shadow:var(--glass-shadow-panel);
  --glass-blur:var(--glass-blur-md);
}
.glass-surface--strong{
  --glass-fill:var(--glass-fill-strong);
  --glass-border:var(--glass-border-strong);
  --glass-shadow:var(--glass-shadow-strong);
  --glass-blur:var(--glass-blur-lg);
}

/* Section head pattern */
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:40px;
  margin-bottom:44px;
}
.section-head h2{ max-width:20ch }
.section-head .lede{ max-width:46ch }
@media (max-width:760px){
  .section-head{ flex-direction:column; align-items:flex-start; gap:18px }
}

/* ============================================================
   Cards (shared patterns)
   ============================================================ */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:28px;
  box-shadow:var(--shadow-sm);
  transition: transform .22s, box-shadow .22s, border-color .22s;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--pastel-gray);
}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{
  position:relative;
  overflow:hidden;
  background:var(--footer-bg);
  backdrop-filter: blur(var(--glass-blur-lg)) saturate(var(--glass-saturate));
  -webkit-backdrop-filter: blur(var(--glass-blur-lg)) saturate(var(--glass-saturate));
  border-top: 1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
  color:#fff;
  padding:64px 0 32px;
  margin-top:0;
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){
  .site-footer{ background:var(--footer-bg-fallback) }
}
.site-footer::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(55% 80% at 0% 0%, rgba(156,250,199,.08), transparent 60%),
    radial-gradient(48% 68% at 100% 0%, rgba(0,138,252,.18), transparent 60%);
}
.site-footer .inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns: 1.5fr repeat(4, 1fr);
  gap:40px;
  max-width:1240px; margin:0 auto; padding:0 32px;
}
.site-footer .brand img{ height:32px; margin-bottom:18px }
.site-footer .brand p{ color:#fff; font-size:14px; line-height:1.6; max-width:32ch }
.site-footer h5{ color:#fff; font-family:var(--display); font-size:13px; letter-spacing:.12em; text-transform:uppercase; margin:0 0 14px; font-weight:600 }
.site-footer ul{ list-style:none; padding:0; margin:0 }
.site-footer ul li{ margin:8px 0 }
.site-footer ul a{ color:#fff; font-size:14px; text-decoration:none; transition:color .15s, font-size .15s }
.site-footer ul a:hover{ color:#9cfac7; font-size:14.5px }
.site-footer ul a svg{ display:inline-block; vertical-align:middle; margin-right:6px; opacity:.6; flex-shrink:0 }
.site-footer ul a{ display:flex; align-items:center; }

.site-footer .meta{
  position:relative;
  z-index:1;
  border-top:1px solid rgba(255,255,255,.08);
  margin-top:40px; padding-top:20px;
  max-width:1240px; margin-left:auto; margin-right:auto;
  padding-left:32px; padding-right:32px;
  display:grid; grid-template-columns:1fr auto 1fr;
  align-items:center; gap:20px;
  color:#fff; font-size:12px;
}
.site-footer .meta .meta-copy{ justify-self:start }
.site-footer .meta .meta-policy{ justify-self:center }
.site-footer .meta .meta-social{
  justify-self:end;
  display:flex;
  align-items:center;
  gap:18px;
}
.site-footer .meta a{ color:#fff; text-decoration:none; transition:color .15s }
.site-footer .meta a:hover{ color:#9cfac7 }
.site-footer .socials{ display:flex; align-items:center; gap:10px }
.site-footer .meta-locations{
  color:#fff;
  font-size:12px;
  letter-spacing:.04em;
  white-space:nowrap;
}
.site-footer .meta-locations span{
  color:#fff;
  margin:0 8px;
}
.site-footer .socials a{
  width:32px; height:32px; border-radius:8px;
  display:inline-flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.06);
  border:0.5px solid rgba(255,255,255,.12);
  color:#fff;
  transition:background .15s, border-color .15s, color .15s;
}
.site-footer .socials a:hover{ background:rgba(0,138,252,.2); border-color:rgba(0,138,252,.5); color:#9cfac7 }
@media (max-width:1100px){
  .site-footer .inner{ grid-template-columns: 1.2fr repeat(3, 1fr); }
  .site-footer .brand{ grid-column:1 / -1 }
}
@media (max-width:860px){
  .site-footer .inner{ grid-template-columns:1fr 1fr; }
  .site-footer .brand{ grid-column:1 / -1 }
}
@media (max-width:520px){
  .site-footer .inner{ grid-template-columns:1fr }
  .site-footer .meta{ grid-template-columns:1fr; gap:10px }
  .site-footer .meta .meta-copy,
  .site-footer .meta .meta-policy,
  .site-footer .meta .meta-social{ justify-self:start }
  .site-footer .meta .meta-social{ flex-wrap:wrap; gap:12px }
}

/* ============================================================
   Legal pages
   ============================================================ */
body.legal-page{
  color:var(--ink);
}
body.legal-page .legal-hero{
  padding:120px 0 32px;
}
body.legal-page .legal-hero h1{
  font-family:var(--display);
  font-size:clamp(40px, 6vw, 68px);
  line-height:1.05;
  margin:14px 0 18px;
  color:var(--darker-azure);
}
body.legal-page .legal-hero .effective{
  color:var(--body);
  font-size:15px;
  margin-top:8px;
}
body.legal-page .legal-body{
  padding:24px 0 96px;
  max-width:780px;
}
body.legal-page .legal-body h2{
  font-family:var(--display);
  font-size:24px;
  color:var(--darker-azure);
  margin:36px 0 12px;
}
body.legal-page .legal-body h3{
  font-family:var(--display);
  font-size:18px;
  color:var(--darker-azure);
  margin:22px 0 8px;
}
body.legal-page .legal-body p,
body.legal-page .legal-body li{
  color:var(--body);
  font-size:16px;
  line-height:1.7;
}
body.legal-page .legal-body ul{
  padding-left:22px;
  margin:8px 0 16px;
}
body.legal-page .legal-body li{
  margin:4px 0;
}
body.legal-page .legal-body a{
  color:var(--vivid-azure);
}
body.legal-page .legal-body strong{
  color:var(--darker-azure);
}

/* ============================================================
   Animated underline used in hero
   ============================================================ */
.accent-underline{
  position:relative;
  color:var(--vivid-azure);
}
.accent-underline::after{
  content:""; position:absolute; left:0; right:0; bottom:-4px;
  height:6px; border-radius:3px;
  background:linear-gradient(90deg, var(--vivid-azure), var(--pastel-green));
  transform:scaleX(0); transform-origin:left;
  animation: underline 1.2s cubic-bezier(.2,.7,.2,1) .3s forwards;
}
@keyframes underline{ to{ transform:scaleX(1) } }

/* Fade+rise on scroll */
[data-reveal]{
  opacity:0; transform:translateY(18px);
  transition: opacity .6s ease, transform .6s ease;
}
[data-reveal].in{ opacity:1; transform:none }

/* Focus */
a:focus-visible, button:focus-visible{
  outline:2px solid var(--vivid-azure); outline-offset:3px; border-radius:6px;
}

/* ============================================================
   Homepage
   Canonical finished design for the site. Scope all home-only
   presentation here so index.html stays mostly structural.
   ============================================================ */

/* ── Announcement banner ── */
.announce-bar{
  display:block;
  background:var(--vivid-azure);
  overflow:hidden;
  padding:10px 0;
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}
.announce-track{
  display:flex;
  width:max-content;
  animation:announce-scroll 40s linear infinite;
}
.announce-item{
  color:#fff;
  font-family:var(--body-font);
  font-size:.875rem;
  letter-spacing:.02em;
  padding:0 3rem;
  flex-shrink:0;
}
.announce-item strong{font-weight:700}
.announce-link{color:#fff;text-decoration:underline}
.announce-bar:hover{opacity:1}
.announce-sep{
  color:#fff;
  padding:0 2rem;
  font-size:.75rem;
  flex-shrink:0;
}
@keyframes announce-scroll{
  0%  {transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@media(prefers-reduced-motion:reduce){
  .announce-track{animation:none}
}

body.home .hero{
  position:relative;
  padding:80px 0 96px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(156,250,199,.05) 0%, transparent 70%);
  color:#fff;
}
body.home .hero .inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.15fr 1fr;
  gap:60px;
  align-items:center;
}
@media (max-width:1020px){
  body.home .hero .inner{ grid-template-columns:1fr; gap:40px }
}
body.home .hero .kicker{ color:#9cfac7 }
body.home .hero .kicker::before{ background:#9cfac7 }
body.home .hero h1{ color:#fff; margin:20px 0 18px; }
body.home .hero h1 .rotator-line{ display:block; white-space:nowrap; color:#9cfac7 }
body.home .hero h1 .rotator{ color:#9cfac7 }
body.home .hero p.lede{ color:#AFCBDE; margin:0 0 28px }
body.home .hero .ctas{ display:flex; gap:12px; flex-wrap:wrap; align-items:center }
body.home .hero .btn.primary{
  background:rgba(156,250,199,.18);
  color:#9cfac7;
  border:0.5px solid transparent;
  box-shadow:none;
  height:50px;
}
body.home .hero .btn.primary:hover{
  background:rgba(156,250,199,.28);
  border-color:#9cfac7;
  text-decoration:none;
}
body.home .hero .btn.svc-learn{
  height:50px;
  padding:0 22px;
  background:rgba(255,255,255,.08);
  border:0.5px solid transparent;
  margin-top:0;
}

body.home .hero-stats{
  margin-top:44px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.1);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  max-width:600px;
}
body.home .hero-stats .num{
  font-family:var(--display);
  font-weight:700;
  font-size:34px;
  color:#fff;
  letter-spacing:-0.02em;
}
body.home .hero-stats .num sup{ color:#9cfac7; font-size:.6em; margin-left:2px }
body.home .hero-stats .lbl{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#7AACC0;
  margin-top:6px;
}
@media (max-width:520px){
  body.home .hero-stats{ grid-template-columns:1fr 1fr }
  body.home .hero-stats .m:last-child{ grid-column:1/-1 }
}

body.home .hero-radar{
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:0;
}
body.home .globe-wrap{
  position:relative;
  width:min(460px, 100%);
  aspect-ratio:1;
  -webkit-mask-image: radial-gradient(circle at center, #000 62%, transparent 100%);
          mask-image: radial-gradient(circle at center, #000 62%, transparent 100%);
}
body.home #globeCanvas{
  display:block;
  width:100%;
  height:100%;
  cursor:grab;
  touch-action:none;
}
body.home #globeCanvas:active{ cursor:grabbing; }
/* Radar is decorative — never render it once the hero stacks (<=1020px).
   Placed after the base .hero-radar rule so it wins on source order. */
@media (max-width:1020px){
  body.home .hero-radar{ display:none; }
}

body.home .clients{
  padding:36px 0 28px;
  background:linear-gradient(100deg, rgba(0,42,64,.1) 0%, rgba(0,79,122,.1) 40%, rgba(0,138,252,.1) 70%, rgba(0,42,64,.1) 100%);
  border-top:1px solid rgba(0,138,252,.12);
  border-bottom:1px solid rgba(0,138,252,.12);
  overflow:hidden;
  position:relative;
}
body.home .clients .label{
  text-align:center;
  margin:0 0 20px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
}
body.home .clients .label .prefix{
  font-family:"Schibsted Grotesk","Helvetica Neue",sans-serif;
  font-size:16px;
  line-height:1.4;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
body.home .clients .label .industry{
  font-family:"Schibsted Grotesk","Helvetica Neue",sans-serif;
  font-size:15px;
  letter-spacing:.14em;
  line-height:1.4;
  text-transform:uppercase;
  color:#9cfac7;
  transition:opacity .35s ease;
  min-height:1.4em;
}
body.home .marquee-track{
  position:relative;
  overflow:hidden;
  padding:12px 0;
  mask-image:linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
  -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
}
body.home .marquee-inner{
  display:flex;
  gap:16px;
  width:max-content;
  animation:home-marquee 28s linear infinite;
}
body.home .marquee-track:hover .marquee-inner{ animation-play-state:paused }
@keyframes home-marquee{
  0%{ transform:translateX(0) }
  100%{ transform:translateX(-50%) }
}
body.home .client-item{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:8px 20px;
  flex-shrink:0;
  cursor:pointer;
  transition:transform .2s, opacity .2s, background-color .2s;
  opacity:.82;
  text-decoration:none;
  border-radius:999px;
}
body.home .client-item:hover,
body.home .client-item:focus-visible{
  transform:scale(1.08);
  opacity:1;
  background:rgba(255,255,255,.85);
}
/* Vecna and Peacemaker color logos are light — they read on black, not white. */
body.home .client-item[href*="vecna-robotics"]:is(:hover, :focus-visible),
body.home .client-item[href*="peacemaker-technologies"]:is(:hover, :focus-visible){
  background:rgba(0,0,0,.6);
}
body.home .client-item:focus-visible{
  outline:1px solid rgba(156,250,199,.7);
  outline-offset:4px;
}
body.home .client-item img{
  height:44px;
  width:auto;
  max-width:140px;
  object-fit:contain;
  display:block;
  transition: opacity .25s ease;
}
body.home .client-item .client-color{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%, -50%);
  opacity:0;
  pointer-events:none;
}
body.home .client-item:hover .client-color,
body.home .client-item:focus-visible .client-color{ opacity:1; }
body.home .client-item:hover img:not(.client-color),
body.home .client-item:focus-visible img:not(.client-color){ opacity:0; }
@media (prefers-reduced-motion: reduce){
  body.home .client-item img{ transition:none; }
}

body.home .svc-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:20px;
}
@media (max-width:800px){
  body.home .svc-grid{ grid-template-columns:1fr }
}
body.home .svc-card{
  position:relative;
  display:flex;
  flex-direction:column;
  padding:32px 28px;
  border-radius:var(--r-lg);
  background:rgba(10,30,50,.42);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 1px 0 rgba(0,0,0,.2), 0 8px 30px -10px rgba(0,0,0,.4);
  color:#D5E5F1;
  overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  min-height:240px;
  cursor:default;
}
body.home .svc-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(70% 55% at 100% 0%, rgba(0,138,252,.14), transparent 55%);
  opacity:.5;
  transition:opacity .3s;
  pointer-events:none;
}
body.home .svc-card:hover{
  transform:translateY(-4px);
  border:0.5px solid #004f7a;
  box-shadow:0 2px 0 rgba(0,0,0,.2), 0 20px 50px -16px rgba(0,0,0,.55);
}
body.home .svc-card:hover::before{ opacity:1 }
body.home .svc-learn,
body.svc-parent-page .svc-learn{
  margin-top:auto;
  font-size:14px;
  height:42px;
  padding:0 24px;
  background:rgba(255,255,255,.08);
  border:0.5px solid transparent;
  color:#fff;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:fit-content;
  border-radius:999px;
  transition:background .2s, border-color .2s, transform .18s, color .18s;
}
body.home .svc-learn svg,
body.svc-parent-page .svc-learn svg{
  flex-shrink:0;
  transition:transform .18s;
}
body.home .svc-learn:is(:hover, :focus-visible),
body.svc-parent-page .svc-learn:is(:hover, :focus-visible){
  background:rgba(0,138,252,.28) !important;
  border:0.5px solid #008afc !important;
  transform:translateY(-1px);
  text-decoration:none;
  color:#9cfac7 !important;
}
body.home .svc-ic{
  width:48px;
  height:48px;
  border-radius:12px;
  background:rgba(156,250,199,.12);
  color:#9cfac7;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(156,250,199,.22);
  flex-shrink:0;
}
body.home .svc-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}
body.home .svc-card h3{ margin:0; color:#fff; font-size:clamp(18px,1.8vw,22px) }
body.home .svc-card p{ color:#91B4C9; font-size:15px; margin:0 0 20px; max-width:40ch }
body.home #services .svc-card p{ max-width:58ch }
body.home .svc-card .chips{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:20px }
body.home .svc-card .chip{
  font-family:var(--mono);
  font-size:10.5px;
  padding:3px 9px;
  border-radius:999px;
  background:rgba(156,250,199,.12);
  color:#9cfac7;
  border:1px solid rgba(156,250,199,.22);
  letter-spacing:.06em;
  text-transform:uppercase;
}
body.home .svc-card .arrow{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--vivid-azure);
  font-weight:600;
  font-size:14px;
}
body.home .svc-card .arrow svg{ transition:transform .2s }
body.home .svc-card:hover .arrow svg{ transform:translateX(4px) }

body.home .industries-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
}
@media (max-width:900px){
  body.home .industries-grid{ grid-template-columns:repeat(2,1fr) }
}
@media (max-width:500px){
  body.home .industries-grid{ grid-template-columns:1fr }
}
body.home .ind{
  position:relative;
  overflow:hidden;
  padding:28px 22px;
  min-height:180px;
  border-radius:var(--r-lg);
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border:1px solid rgba(255,255,255,.14);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  transition:all .22s;
}
body.home .ind:hover{ border-color:rgba(156,250,199,.45); transform:translateY(-3px); box-shadow:var(--shadow-md) }
body.home .ind h4{ font-size:17px; color:#E6F3FE; margin-bottom:8px }
body.home .ind p{ font-size:13.5px; color:#AFCBDE; margin:0; line-height:1.55 }
body.home .ind .ic{
  width:40px;
  height:40px;
  border-radius:10px;
  background:var(--highlight);
  color:var(--vivid-azure);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
}

body.home .why{
  color:#D5E5F1;
  border-radius:32px;
  margin:0 auto;
  max-width:1224px;
  padding:72px 56px;
  position:relative;
  overflow:hidden;
  background:rgba(10,30,50,.38);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 4px 40px -10px rgba(0,0,0,.5);
}
body.home .why::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(60% 70% at 100% 0%, rgba(0,138,252,.18), transparent 60%),
    radial-gradient(40% 50% at 0% 100%, rgba(156,250,199,.08), transparent 60%);
  pointer-events:none;
}
body.home .why h2{ color:#fff }
body.home .why .kicker{ color:#9cfac7 }
body.home .why .kicker::before{ background:#9cfac7 }
body.home .why .lede{ color:#91B4C9 }
body.home .why-grid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:44px;
}
@media (max-width:860px){
  body.home .why-grid{ grid-template-columns:1fr }
  body.home .why{ padding:48px 28px; border-radius:22px }
}
body.home .why-item{
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(255,255,255,.1);
  padding:28px;
  border-radius:var(--r-lg);
  transition:background .2s, border-color .2s, transform .2s;
}
body.home .why-item:hover{
  background:rgba(255,255,255,.09);
  border-color:rgba(156,250,199,.3);
  transform:translateY(-3px);
}
body.home .why-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:14px;
}
body.home .why-item h3{ color:#fff; margin:0; font-size:20px }
body.home .why-item p{ color:#91B4C9; margin:0; font-size:14.5px; line-height:1.6 }
body.home .why-item .ic{
  width:44px;
  height:44px;
  border-radius:12px;
  background:rgba(156,250,199,.12);
  color:#9cfac7;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  border:1px solid rgba(156,250,199,.22);
}
body.home .why-certs{
  position:relative;
  margin-top:44px;
  padding-top:36px;
  border-top:1px solid rgba(255,255,255,.08);
}
body.home .why-certs .cert-label{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#9cfac7;
  margin-bottom:20px;
  display:flex;
  align-items:center;
  gap:10px;
}
body.home .why-certs .cert-label::before{ content:""; width:22px; height:1px; background:#9cfac7 }
body.home .why-certs .badges{ display:flex; flex-wrap:wrap; gap:12px }
body.home .why-certs .badge{
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(10px) saturate(140%);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:14px 18px;
  text-align:center;
  min-width:90px;
  transition:all .2s;
}
body.home .why-certs .badge:hover{
  border-color:rgba(156,250,199,.35);
  background:rgba(255,255,255,.09);
  transform:translateY(-2px);
}
body.home .why-certs .badge .n{ font-family:var(--display); font-weight:600; color:#fff; font-size:13px }
body.home .why-certs .badge .s{
  font-family:var(--mono);
  font-size:9.5px;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:#7AACC0;
  margin-top:4px;
}

body.home .testi-slideshow{
  position:relative;
  max-width:780px;
  margin:40px auto 0;
}
body.home .testi-slides-wrapper{
  position:relative;
  height:387px;
}
body.home .testi-slide{
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:rgba(10,30,50,.38);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-xl);
  padding:36px 40px;
  box-shadow:var(--shadow-md);
  display:flex;
  flex-direction:column;
  gap:24px;
  opacity:0;
  visibility:hidden;
  transition:opacity .5s ease, visibility 0s linear .5s, transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  pointer-events:none;
}
body.home .testi-slide.active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transition:opacity .5s ease, visibility 0s linear 0s, transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
body.home .testi-slide.active:hover{
  transform:translateY(-4px);
  border-color:#004f7a;
  box-shadow:0 2px 0 rgba(0,0,0,.2), 0 20px 50px -16px rgba(0,0,0,.55);
}
body.home .testi-slide .quote{
  font-size:16px;
  color:#D5E5F1;
  line-height:1.7;
  position:relative;
  padding-top:8px;
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  padding-right:8px;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.85) transparent;
}
body.home .testi-slide .quote::-webkit-scrollbar{ width:6px }
body.home .testi-slide .quote::-webkit-scrollbar-track{ background:transparent }
body.home .testi-slide .quote::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.85); border-radius:999px }
body.home .testi-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.1);
  flex-wrap:wrap;
}
body.home .testi-logo{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:90px;
  height:80px;
  padding:8px 20px;
  flex-shrink:0;
  border-radius:18px;
  opacity:.82;
  transition:transform .2s, opacity .2s, background-color .2s;
}
body.home .testi-logo img{
  max-height:100%;
  width:auto;
  max-width:170px;
  object-fit:contain;
  display:block;
  transition:opacity .25s ease;
}
body.home .testi-logo .testi-logo-color{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  max-height:calc(100% - 16px);
  opacity:0;
  pointer-events:none;
}
body.home .testi-slide.active:hover .testi-logo{ transform:scale(1.15); opacity:1; background:rgba(255,255,255,.85); }
body.home .testi-slide.active:hover .testi-logo > img:not(.testi-logo-color){ opacity:0 }
body.home .testi-slide.active:hover .testi-logo-color{ opacity:1 }
body.home .testi-logo .testi-logo-md{ width:132px; max-width:none }
body.home .testi-logo .testi-logo-ctsa{ width:72px; max-width:none }
body.home .testi-logo .testi-logo-pyt{ width:84px; max-width:none }
body.home .testi-logo .testi-logo-standley{ max-width:150px }
body.home .testi-logo .testi-logo-okie{ width:120px; max-width:none }
body.home .testi-author{ text-align:right }
body.home .testi-author .name{ font-family:var(--display); font-weight:600; font-size:11px; color:#fff }
body.home .testi-author .role{ font-size:11px; color:#7AACC0; margin-top:1px }
body.home .testi-author .org{ font-size:11px; color:#9cfac7; margin-top:1px; font-weight:500 }
body.home .testi-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:50%;
  background:rgba(10,30,50,.5);
  backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
  border:1px solid rgba(255,255,255,.14);
  color:#D5E5F1;
  cursor:pointer;
  padding:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background .2s, border-color .2s, color .2s, transform .2s;
  z-index:2;
}
body.home .testi-nav:hover{
  background:rgba(0,138,252,.35);
  border-color:rgba(156,250,199,.4);
  color:#9cfac7;
  transform:translateY(-50%) scale(1.05);
}
body.home .testi-nav.prev{ left:-72px }
body.home .testi-nav.next{ right:-72px }
@media (max-width:960px){
  body.home .testi-nav.prev{ left:-24px }
  body.home .testi-nav.next{ right:-24px }
}
@media (max-width:600px){
  body.home .testi-nav.prev{ left:6px }
  body.home .testi-nav.next{ right:6px }
}
body.home .testi-dots{
  display:flex;
  justify-content:center;
  gap:6px;
  margin-top:28px;
  flex-wrap:wrap;
}
body.home .dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--pastel-gray);
  border:none;
  cursor:pointer;
  padding:0;
  transition:background .2s, transform .2s;
}
body.home .dot.active{ background:var(--vivid-azure); transform:scale(1.3) }

body.home .cta-band{
  margin:0;
  color:#fff;
  padding:72px 0;
  position:relative;
  overflow:hidden;
  background:rgba(0,26,40,.35);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
}
body.home .cta-band::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse 70% 140% at 0% 50%, rgba(0,138,252,.28) 0%, transparent 60%),
    radial-gradient(ellipse 50% 100% at 100% 50%, rgba(156,250,199,.12) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 50% 100%, rgba(0,79,122,.35) 0%, transparent 60%);
}
body.home .cta-band::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 80% at 20% 50%, #000 20%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 20% 50%, #000 20%, transparent 70%);
}
body.home .cta-band .inner{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
}
body.home .cta-band h2{ color:#fff; max-width:26ch }
body.home .cta-band .btn.primary{
  background:#fff;
  color:var(--darker-azure);
  box-shadow:0 14px 28px -10px rgba(0,0,0,.3);
}
body.home .cta-band .btn.primary:hover{ background:#E6F3FE }
@media (max-width:760px){
  body.home .cta-band .inner{ flex-direction:column; align-items:flex-start }
}

body.home .home-kicker-accent{ color:#9cfac7 }
body.home .home-kicker-accent::before{ background:#9cfac7 }
body.home .home-section-title{ margin-top:14px; color:#fff }
body.home .home-section-lede{ margin-top:16px; color:#91B4C9 }
body.home .home-why-intro{ position:relative; max-width:720px }
body.home .home-why-lede{ margin-top:16px }
body.home .home-section-no-border{ border-bottom:none }
body.home .home-testi-head{ flex-direction:column; align-items:flex-start; gap:8px }
body.home .home-testi-lede{ color:#91B4C9; margin-top:10px }

/* ============================================================
   Service parent pages
   Homepage-derived system for the finished service landing pages.
   ============================================================ */
body.svc-parent-page{
  color:#D5E5F1;
}
body.svc-page.svc-parent-page{
  background:#001a28;
}
body.svc-parent-page :is(#services, #values, #story){
  scroll-margin-top:96px;
}

body.svc-parent-page .hero{
  position:relative;
  padding:86px 0 78px;
  overflow:hidden;
  color:#fff;
  background:
    radial-gradient(70% 100% at 50% 0%, rgba(156,250,199,.07) 0%, transparent 58%),
    linear-gradient(180deg, rgba(156,250,199,.035) 0%, transparent 72%);
}
@media (max-width:760px){
  body.svc-parent-page .hero{ padding:52px 0 48px; }
}
body.svc-parent-page .hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(72% 110% at 50% 0%, rgba(156,250,199,.05) 0%, transparent 60%),
    var(--hero-network-dark) center top / 720px 480px repeat;
  opacity:.36;
  mask-image:radial-gradient(ellipse at top center, #000 20%, transparent 74%);
  -webkit-mask-image:radial-gradient(ellipse at top center, #000 20%, transparent 74%);
}
body.svc-parent-page .hero .inner{
  position:relative;
  z-index:1;
  display:block;
}
body.svc-parent-page .hero-copy{
  position:relative;
}
body.svc-parent-page .crumbs{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:18px;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.62);
}
body.svc-parent-page .crumbs a{
  color:rgba(255,255,255,.86);
  text-decoration:none;
}
body.svc-parent-page .crumbs a:hover{ color:#9cfac7 }
body.svc-parent-page .crumbs span{
  margin:0 2px;
  opacity:.5;
}
body.svc-parent-page .hero h1{
  color:#fff;
  max-width:11ch;
  margin:0 0 18px;
}
body.svc-parent-page .hero .accent,
body.svc-parent-page .hero .accent-inline{ color:#9cfac7 }
body.svc-parent-page .hero .lede{
  color:#AFCBDE;
  margin:0 0 28px;
}
body.svc-parent-page .hero .ctas{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
body.svc-parent-page{
  --glass-fill-soft:rgba(255,255,255,.06);
  --glass-fill-panel:rgba(10,30,50,.42);
  --glass-fill-strong:rgba(7,24,39,.58);
  --glass-border-soft:rgba(255,255,255,.1);
  --glass-border-panel:rgba(255,255,255,.12);
  --glass-border-strong:rgba(255,255,255,.14);
  --glass-blur-md:18px;
  --glass-blur-lg:22px;
}
body.svc-parent-page .hero .btn.primary{
  background:rgba(156,250,199,.18);
  color:#9cfac7;
  border:0.5px solid transparent;
  box-shadow:none;
  height:50px;
}
body.svc-parent-page .hero .btn.primary:is(:hover, :focus-visible){
  background:rgba(156,250,199,.28);
  border-color:#9cfac7;
  text-decoration:none;
}
body.svc-parent-page .hero .btn.ghost,
body.home .hero .btn.ghost{
  background:rgba(255,255,255,.08);
  color:#fff;
  border:0.5px solid rgba(255,255,255,.12);
}
body.svc-parent-page .hero .btn.ghost:is(:hover, :focus-visible),
body.home .hero .btn.ghost:is(:hover, :focus-visible){
  background:rgba(0,138,252,.18);
  border-color:rgba(156,250,199,.3);
  transform:translateY(-1px);
  text-decoration:none;
}
body.svc-parent-page .svc-parent-note{
  margin:30px 0 0;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.1);
  color:#9AB7C8;
  font-size:16px;
  line-height:1.72;
  max-width:60ch;
}

body.svc-parent-page :is(.home-section-title, .custom-partner-title){
  color:#fff;
  margin-top:14px;
}
body.svc-parent-page :is(.home-section-lede, .home-why-lede, .custom-partner-lede){
  color:#91B4C9;
  margin-top:16px;
}
body.svc-parent-page :is(.home-why-intro, .custom-partner-intro){
  position:relative;
  max-width:740px;
}

body.svc-parent-page :is(.cyber-proof-band, .custom-proof-band){
  --glass-fill:linear-gradient(180deg, rgba(12,31,50,.58) 0%, rgba(4,19,31,.76) 100%);
  --glass-border:rgba(255,255,255,.12);
  --glass-shadow:0 24px 56px -24px rgba(0,0,0,.58);
  --glass-blur:22px;
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
  padding:18px;
  border-radius:28px;
  overflow:hidden;
}
body.svc-parent-page :is(.cyber-proof-band, .custom-proof-band)::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:
    radial-gradient(60% 78% at 0% 0%, rgba(156,250,199,.07), transparent 60%),
    radial-gradient(74% 88% at 100% 0%, rgba(0,138,252,.14), transparent 60%);
}
body.svc-parent-page :is(.cyber-proof-item, .custom-proof-item){
  --glass-fill:linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,.05) 100%);
  --glass-border:rgba(255,255,255,.1);
  --glass-shadow:0 14px 28px -18px rgba(0,0,0,.42);
  --glass-blur:16px;
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:12px;
  min-height:132px;
  padding:24px 20px;
  border-radius:22px;
  overflow:hidden;
  transition:transform .24s ease, border-color .24s ease, box-shadow .24s ease;
}
body.svc-parent-page :is(.cyber-proof-item, .custom-proof-item)::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  pointer-events:none;
  opacity:0;
  background:
    linear-gradient(128deg, rgba(156,250,199,.16) 0%, rgba(255,255,255,.04) 26%, rgba(0,138,252,.18) 52%, rgba(255,255,255,.02) 78%, rgba(156,250,199,.1) 100%),
    radial-gradient(72% 86% at 16% 10%, rgba(255,255,255,.12), transparent 58%),
    radial-gradient(66% 84% at 88% 100%, rgba(0,138,252,.16), transparent 60%);
  mix-blend-mode:screen;
  transition:opacity .42s ease-in-out;
}
body.svc-parent-page :is(.cyber-proof-item, .custom-proof-item):is(:hover, :focus-visible){
  transform:translateY(-3px);
  border-color:rgba(156,250,199,.22);
  box-shadow:0 18px 36px -22px rgba(0,0,0,.56), 0 0 0 1px rgba(156,250,199,.08);
}
body.svc-parent-page :is(.cyber-proof-item, .custom-proof-item):is(:hover, :focus-visible)::after{
  opacity:1;
}
body.svc-parent-page :is(.cyber-proof-number, .custom-proof-number){
  font-family:var(--display);
  font-size:clamp(30px, 3vw, 34px);
  font-weight:700;
  letter-spacing:-0.03em;
  color:#fff;
}
body.svc-parent-page :is(.cyber-proof-label, .custom-proof-label){
  margin-top:8px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#7AACC0;
}
body.svc-parent-page .custom-proof-support{
  margin-top:8px;
  color:#AFCBDE;
  font-size:14px;
  line-height:1.55;
}

body.svc-parent-page :is(.svc-grid, .srv-grid){
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:20px;
}
body.svc-parent-page :is(.svc-card, .srv-card){
  --glass-fill:rgba(10,30,50,.42);
  --glass-border:rgba(255,255,255,.12);
  --glass-shadow:0 1px 0 rgba(0,0,0,.2), 0 8px 30px -10px rgba(0,0,0,.4);
  --glass-blur:18px;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:18px;
  min-height:100%;
  padding:32px 28px;
  border-radius:24px;
  background:var(--glass-fill);
  border:1px solid var(--glass-border);
  box-shadow:var(--glass-shadow);
  backdrop-filter:blur(var(--glass-blur)) saturate(var(--glass-saturate));
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(var(--glass-saturate));
  color:#D5E5F1;
  overflow:hidden;
  text-decoration:none;
  transition:transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
body.svc-parent-page :is(.svc-card, .srv-card)::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:
    radial-gradient(72% 54% at 100% 0%, rgba(0,138,252,.16), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 28%);
  opacity:.62;
  transition:opacity .22s ease;
}
body.svc-parent-page :is(.svc-card, .srv-card):is(:hover, :focus-visible){
  background:var(--glass-fill);
  transform:translateY(-4px);
  border-color:rgba(156,250,199,.28);
  box-shadow:0 24px 48px -22px rgba(0,0,0,.66), 0 0 0 2px rgba(156,250,199,.08);
  text-decoration:none;
}
body.svc-parent-page :is(.svc-card, .srv-card):is(:hover, :focus-visible)::before{
  opacity:1;
}
body.svc-parent-page .svc-ic{
  width:50px;
  height:50px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(156,250,199,.12);
  color:#9cfac7;
  border:1px solid rgba(156,250,199,.22);
  flex-shrink:0;
}
body.svc-parent-page .svc-ic img{
  width:28px;
  height:28px;
  display:block;
  object-fit:contain;
  filter:brightness(0) saturate(100%) invert(88%) sepia(24%) saturate(659%) hue-rotate(84deg) brightness(103%) contrast(97%);
}
body.home .svc-ic img{
  width:28px;
  height:28px;
  display:block;
  object-fit:contain;
}
body.svc-parent-page .svc-head{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:18px;
}
body.svc-parent-page .svc-head .svc-ic{ margin-bottom:0 }
body.svc-parent-page .svc-ic{ margin-bottom:18px }
body.svc-parent-page :is(.svc-card, .srv-card) h3{
  color:#fff;
  margin:0;
  font-size:clamp(18px, 1.8vw, 22px);
}
body.svc-parent-page :is(.svc-card, .srv-card) p{
  margin:0 0 20px;
  color:#AFCBDE;
  font-size:15px;
  line-height:1.6;
  max-width:52ch;
  flex:1;
}
@media (max-width: 560px){
  body.svc-parent-page.cybersecurity-page .hero h1{ white-space:normal }
}
body.svc-parent-page .chips{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-bottom:20px;
}
body.svc-parent-page .chip{
  padding:4px 9px;
  border-radius:999px;
  background:rgba(156,250,199,.12);
  border:1px solid rgba(156,250,199,.22);
  color:#9cfac7;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
body.svc-parent-page .custom-frameworks-list span{
  padding:9px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  color:#D5E5F1;
  font-size:13px;
  font-weight:600;
  letter-spacing:.03em;
}
body.svc-parent-page :is(.why, .custom-partner){
  --glass-fill:rgba(10,30,50,.42);
  --glass-border:rgba(255,255,255,.12);
  --glass-shadow:0 1px 0 rgba(0,0,0,.2), 0 8px 30px -10px rgba(0,0,0,.4);
  --glass-blur:18px;
  position:relative;
  overflow:hidden;
  padding:56px 44px;
  border-radius:32px;
  color:#D5E5F1;
}
body.svc-parent-page :is(.why, .custom-partner)::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(60% 72% at 100% 0%, rgba(0,138,252,.16), transparent 60%),
    radial-gradient(46% 54% at 0% 100%, rgba(156,250,199,.08), transparent 62%);
}
body.svc-parent-page :is(.why-grid, .custom-partner-grid){
  position:relative;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:20px;
  margin-top:32px;
}
body.svc-parent-page :is(.why-item, .custom-partner-item){
  --glass-fill:linear-gradient(180deg, rgba(255,255,255,.11) 0%, rgba(255,255,255,.045) 100%);
  --glass-border:rgba(255,255,255,.1);
  --glass-shadow:0 12px 26px -18px rgba(0,0,0,.4);
  --glass-blur:16px;
  position:relative;
  padding:26px 24px;
  border-radius:22px;
  transition:transform .2s, border-color .2s, box-shadow .2s;
}
body.svc-parent-page :is(.why-item, .custom-partner-item):hover{
  transform:translateY(-3px);
  border-color:rgba(156,250,199,.22);
  box-shadow:0 20px 38px -24px rgba(0,0,0,.55);
}
body.svc-parent-page .why-item .ic{
  width:44px;
  height:44px;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  background:rgba(156,250,199,.12);
  border:1px solid rgba(156,250,199,.22);
  color:#9cfac7;
}
body.svc-parent-page :is(.why-item, .custom-partner-item) h3{
  color:#fff;
  margin:0 0 10px;
  font-size:clamp(20px, 2vw, 22px);
}
body.svc-parent-page :is(.why-item, .custom-partner-item) p{
  margin:0;
  color:#91B4C9;
  font-size:14.5px;
  line-height:1.6;
}
body.svc-parent-page .custom-partner-step{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:12px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
body.svc-parent-page :is(.why-certs, .custom-frameworks){
  position:relative;
  margin-top:34px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.08);
}
body.svc-parent-page :is(.why-certs .cert-label, .custom-frameworks-label){
  margin-bottom:16px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#9cfac7;
}
body.svc-parent-page .why-certs{
  text-align:center;
}
body.svc-parent-page .why-certs .cert-label{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}
body.svc-parent-page .why-certs .cert-label::before{
  content:"";
  width:22px;
  height:1px;
  background:#9cfac7;
}
body.svc-parent-page :is(.why-certs .badges, .custom-frameworks-list){
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}
body.svc-parent-page .why-certs .badges{ justify-content:center }
body.svc-parent-page .why-certs .badge{
  --glass-fill:linear-gradient(180deg, rgba(255,255,255,.11) 0%, rgba(255,255,255,.045) 100%);
  --glass-border:rgba(255,255,255,.1);
  --glass-shadow:0 12px 26px -18px rgba(0,0,0,.36);
  --glass-blur:14px;
  min-width:108px;
  padding:14px 18px;
  border-radius:12px;
  text-align:center;
  transition:transform .2s, border-color .2s, box-shadow .2s;
}
body.svc-parent-page .why-certs .badge:hover{
  transform:translateY(-2px);
  border-color:rgba(156,250,199,.26);
  box-shadow:0 18px 30px -22px rgba(0,0,0,.48);
}
body.svc-parent-page .why-certs .badge .n{
  font-family:var(--display);
  font-weight:600;
  color:#fff;
  font-size:13px;
  white-space:nowrap;
}

body.svc-parent-page .cta-band{
  --glass-fill:linear-gradient(180deg, rgba(9,28,44,.56) 0%, rgba(3,18,28,.74) 100%);
  --glass-border:rgba(255,255,255,.1);
  --glass-shadow:0 18px 44px -24px rgba(0,0,0,.54);
  --glass-blur:20px;
  position:relative;
  margin:0;
  padding:72px 0;
  color:#fff;
  overflow:hidden;
  border-radius:0;
  border-left:none;
  border-right:none;
}
body.svc-parent-page .cta-band::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse 70% 140% at 0% 50%, rgba(0,138,252,.2) 0%, transparent 60%),
    radial-gradient(ellipse 50% 100% at 100% 50%, rgba(156,250,199,.1) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 50% 100%, rgba(0,79,122,.24) 0%, transparent 60%);
}
body.svc-parent-page .cta-band::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 82% at 20% 50%, #000 20%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 80% 82% at 20% 50%, #000 20%, transparent 70%);
}
body.svc-parent-page .cta-band .inner{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
}
body.svc-parent-page .cta-band h2{
  color:#fff;
  max-width:26ch;
}
body.svc-parent-page .cta-band .btn.primary{
  background:#fff;
  color:var(--darker-azure);
  box-shadow:0 14px 28px -10px rgba(0,0,0,.3);
}
body.svc-parent-page .cta-band .btn.primary:is(:hover, :focus-visible){ background:#E6F3FE }
body.svc-parent-page .cta-band .btn.ghost{
  background:rgba(255,255,255,.08);
  color:#fff;
  border:0.5px solid rgba(255,255,255,.16);
}
body.svc-parent-page .cta-band .btn.ghost:is(:hover, :focus-visible){
  background:rgba(0,138,252,.2);
  border-color:rgba(156,250,199,.35);
  text-decoration:none;
}
body.svc-parent-page .svc-parent-cta-kicker{ margin-bottom:14px }
body.svc-parent-page .svc-parent-cta-highlight{ color:#9cfac7 }
body.svc-parent-page :is(.cyber-cta-actions, .custom-cta-actions){
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  flex-shrink:0;
}
body.svc-parent-page .cyber-radar-cta{
  --glass-fill:linear-gradient(180deg, rgba(9,29,41,.46) 0%, rgba(4,19,30,.52) 100%);
  --glass-border:rgba(0,138,252,.16);
  --glass-shadow:0 18px 42px -30px rgba(0,0,0,.52);
  --glass-blur:24px;
  width:min(1176px, calc(100% - 128px));
  margin:0 auto 72px;
  padding:0;
  border-radius:28px;
  border:1px solid rgba(0,138,252,.12);
  border-top:none;
  overflow:hidden;
}
body.svc-parent-page.cybersecurity-page .cyber-services.section{
  border-bottom:none;
}
body.svc-parent-page .cyber-radar-cta::before{
  background:
    radial-gradient(circle at 0% 0%, rgba(0,138,252,.08) 0%, transparent 26%),
    radial-gradient(circle at 100% 0%, rgba(0,138,252,.07) 0%, transparent 24%),
    linear-gradient(180deg, rgba(0,138,252,.025), rgba(0,138,252,.01));
}
body.svc-parent-page .cyber-radar-cta::after{
  inset:1px;
  border-radius:27px;
  background:linear-gradient(180deg, rgba(255,255,255,.015), rgba(255,255,255,.005));
  opacity:.45;
  mask-image:none;
  -webkit-mask-image:none;
}
body.svc-parent-page .cyber-radar-cta .inner{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0, .94fr) minmax(360px, .9fr);
  gap:24px;
  padding:34px 28px 32px;
  align-items:start;
  overflow:hidden;
}
body.svc-parent-page .cyber-radar-copy{
  position:relative;
  z-index:1;
}
body.svc-parent-page .cyber-radar-aside{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  width:100%;
}
body.svc-parent-page.cybersecurity-page .cyber-radar-visual{ z-index:1; }
body.svc-parent-page .cyber-radar-kicker{
  display:inline-flex;
  align-items:center;
  gap:0;
  margin-bottom:18px;
  padding:9px 16px;
  border-radius:999px;
  background:rgba(8,24,42,.42);
  border:1px solid rgba(156,250,199,.18);
  color:#BDF6D7;
  font-family:var(--mono);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
body.svc-parent-page .cyber-radar-kicker::after{
  content:"";
  position:absolute;
  inset:-18% auto -18% -34%;
  width:34%;
  background:linear-gradient(115deg, transparent 0%, rgba(255,255,255,.04) 30%, rgba(255,255,255,.34) 50%, rgba(156,250,199,.2) 62%, transparent 100%);
  transform:translateX(-180%) skewX(-20deg);
  pointer-events:none;
  z-index:-1;
  animation:cyber-kicker-sheen 4s ease-out infinite;
}
body.svc-parent-page .cyber-radar-cta h2{
  max-width:none;
  margin:0;
  font-size:clamp(26px, 2.6vw, 34px);
  line-height:1.08;
  letter-spacing:-0.02em;
}
body.svc-parent-page .cyber-radar-body{
  max-width:48ch;
  margin:12px 0 18px;
  color:#C7D8E4;
  font-size:14px;
  line-height:1.5;
}
body.svc-parent-page .cyber-radar-actions{
  margin-top:22px;
  width:100%;
  align-items:center;
}
body.svc-parent-page .cyber-radar-primary{
  min-width:240px;
  justify-content:center;
  background:rgba(255,255,255,.08);
  color:#fff;
  border:0.5px solid rgba(255,255,255,.12);
  box-shadow:none;
}
body.svc-parent-page .cyber-radar-primary:is(:hover, :focus-visible){
  background:rgba(0,138,252,.18);
  border-color:rgba(156,250,199,.3);
  color:#9cfac7;
  transform:translateY(-1px);
}
body.svc-parent-page .cyber-radar-time{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:#AFCBDE;
  font-size:14px;
  line-height:1.4;
}
body.svc-parent-page .cyber-radar-time svg{
  width:22px;
  height:22px;
  flex:0 0 auto;
  color:#AFCBDE;
}
body.svc-parent-page.cybersecurity-page .cyber-radar-visual{
  position:relative;
  z-index:1;
  display:grid;
  align-self:start;
}
body.svc-parent-page.cybersecurity-page .cyber-radar-scope{
  position:relative;
  padding:0;
  margin-top:-10px;
}
body.svc-parent-page.cybersecurity-page .cyber-radar-svg{
  display:block;
  width:min(100%, 360px);
  margin:0 auto;
}
body.svc-parent-page.cybersecurity-page .cyber-radar-grid path,
body.svc-parent-page.cybersecurity-page .cyber-radar-grid circle{
  stroke:rgba(61,128,184,.38);
  stroke-width:1.8;
}
body.svc-parent-page.cybersecurity-page .cyber-radar-grid circle:first-of-type{
  stroke:rgba(91,167,218,.48);
}
body.svc-parent-page.cybersecurity-page .cyber-radar-sweep{
  transform-origin:210px 210px;
  animation:cyber-radar-sweep 5.4s linear infinite;
}
body.svc-parent-page.cybersecurity-page .cyber-radar-beam-line{
  stroke:rgba(156,250,199,.72);
  stroke-width:3;
  stroke-linecap:round;
}
body.svc-parent-page.cybersecurity-page .cyber-radar-center{
  fill:#9CFAC7;
  filter:drop-shadow(0 0 14px rgba(156,250,199,.55));
}
body.svc-parent-page.cybersecurity-page .hero-radar{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
body.svc-parent-page.cybersecurity-page .attack-map{
  position:relative;
  width:380px;
  height:380px;
  max-width:100%;
  aspect-ratio:1 / 1;
  border-radius:50%;
  overflow:hidden;
  border:1px solid rgba(156,250,199,.04);
  background:radial-gradient(circle at 40% 40%, rgba(0,55,85,.4) 0%, rgba(0,18,32,.55) 100%);
  box-shadow:
    0 0 0 1px rgba(0,138,252,.04),
    0 0 0 12px rgba(0,18,32,.08),
    0 24px 76px -38px rgba(0,138,252,.24),
    inset 0 0 64px rgba(0,0,0,.18);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}
body.svc-parent-page.cybersecurity-page .attack-map-svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
}
body.svc-parent-page.cybersecurity-page .am-ring-outer{
  animation:am-ring-rotate 60s linear infinite;
  transform-origin:50% 50%;
}
body.svc-parent-page.cybersecurity-page .am-ring-inner{
  animation:am-ring-rotate-rev 45s linear infinite;
  transform-origin:50% 50%;
}
body.svc-parent-page.cybersecurity-page .am-nodes{
  display:none;
}
body.svc-parent-page.cybersecurity-page .am-ring-label{
  fill:rgba(120,170,210,.55);
  font-family:'Schibsted Grotesk', sans-serif;
  font-size:11px;
  letter-spacing:2.5px;
  font-weight:500;
}
body.svc-parent-page.cybersecurity-page .am-ring-label-inner{
  font-size:10px;
  letter-spacing:2px;
  fill:rgba(156,250,199,.55);
}
body.svc-parent-page.cybersecurity-page .am-core-pulse{
  transform-origin:50% 50%;
  animation:am-core-pulse 3.4s ease-in-out infinite;
}
body.svc-parent-page.cybersecurity-page .am-node-dot{
  fill:#3aa9ff;
  filter:drop-shadow(0 0 6px rgba(58,169,255,.7));
}
body.svc-parent-page.cybersecurity-page .am-node-inner{
  fill:#eaf6ff;
}
body.svc-parent-page.cybersecurity-page .am-node-halo{
  fill:rgba(58,169,255,.18);
  animation:am-node-pulse 2.8s ease-in-out infinite;
}
body.svc-parent-page.cybersecurity-page .am-node-label{
  fill:rgba(221,233,244,.5);
  font-family:'Schibsted Grotesk', sans-serif;
  font-size:9.5px;
  font-weight:500;
  letter-spacing:.6px;
  text-transform:uppercase;
}
body.svc-parent-page.cybersecurity-page .am-vector-head{
  filter:drop-shadow(0 0 6px rgba(255,90,80,.85));
}
body.svc-parent-page.cybersecurity-page .am-impact-ring{
  fill:none;
  stroke:rgba(156,250,199,.85);
  stroke-width:1.4;
}
body.svc-parent-page.cybersecurity-page .am-core-icon{
  position:absolute;
  top:50%;
  left:50%;
  width:38px;
  height:38px;
  transform:translate(-50%, -50%);
  filter:drop-shadow(0 0 12px rgba(156,250,199,.55))
    brightness(0) saturate(100%) invert(94%) sepia(31%) saturate(384%) hue-rotate(73deg) brightness(101%) contrast(96%);
  pointer-events:none;
}
@keyframes am-ring-rotate{
  to{ transform:rotate(360deg); }
}
@keyframes am-ring-rotate-rev{
  to{ transform:rotate(-360deg); }
}
@keyframes am-core-pulse{
  0%,100%{ opacity:.6; }
  50%{ opacity:1; }
}
@keyframes am-node-pulse{
  0%,100%{ opacity:.5; }
  50%{ opacity:.95; }
}
@media (prefers-reduced-motion: reduce){
  body.svc-parent-page.cybersecurity-page .am-ring-outer,
  body.svc-parent-page.cybersecurity-page .am-ring-inner,
  body.svc-parent-page.cybersecurity-page .am-core-pulse,
  body.svc-parent-page.cybersecurity-page .am-node-halo{
    animation:none;
  }
}
body.svc-parent-page .cyber-radar-points{
  display:grid;
  grid-template-columns:repeat(3, minmax(120px, 1fr));
  gap:0;
  margin-top:22px;
  width:100%;
  max-width:none;
}
body.svc-parent-page .cyber-radar-point{
  padding:0 18px;
  color:#D5E5F1;
}
body.svc-parent-page .cyber-radar-point:first-child{
  padding-left:0;
}
body.svc-parent-page .cyber-radar-point + .cyber-radar-point{
  border-left:1px solid rgba(255,255,255,.12);
  border-top:none;
  padding-top:0;
}
body.svc-parent-page .cyber-radar-point-icon{
  width:64px;
  height:64px;
  display:grid;
  place-items:center;
  margin:0 0 18px;
  border-radius:16px;
  background:rgba(156,250,199,.12);
  border:1px solid rgba(156,250,199,.22);
  color:#9cfac7;
}
body.svc-parent-page .cyber-radar-point-icon svg,
body.svc-parent-page .cyber-radar-point-icon img{
  width:32px;
  height:32px;
}
body.svc-parent-page .cyber-radar-point-icon img{
  display:block;
  object-fit:contain;
  filter:brightness(0) saturate(100%) invert(88%) sepia(24%) saturate(659%) hue-rotate(84deg) brightness(103%) contrast(97%);
}
body.svc-parent-page .cyber-radar-point strong{
  display:block;
  margin-bottom:12px;
  color:#D8F8E6;
  font-size:17px;
  white-space:nowrap;
}
body.svc-parent-page .cyber-radar-point span{
  color:#AFCBDE;
  font-size:15px;
  line-height:1.7;
}

@keyframes cyber-radar-sweep{
  from{ transform:rotate(0deg) }
  to{ transform:rotate(360deg) }
}
@keyframes cyber-kicker-sheen{
  0%{ transform:translateX(-180%) skewX(-20deg); opacity:0 }
  12%{ opacity:1 }
  100%{ transform:translateX(520%) skewX(-20deg); opacity:0 }
}

body.svc-parent-page.cybersecurity-page .hero-copy{ max-width:760px }
body.svc-parent-page.custom-development-page .hero-copy{ max-width:780px }
body.svc-parent-page.custom-development-page .hero .inner{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 480px);
  gap:56px;
  align-items:start;
}
body.svc-parent-page.custom-development-page .hero-copy{
  max-width:640px;
}
body.svc-parent-page.custom-development-page .custom-terminal-shell{
  position:relative;
  align-self:start;
  justify-self:end;
  width:100%;
  max-width:480px;
  height:352px;
  margin-top:37px;
  min-height:352px;
}
body.svc-parent-page.custom-development-page .custom-terminal{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  min-height:0;
  border-radius:16px;
  overflow:hidden;
  --glass-fill:linear-gradient(180deg, rgba(6,20,14,.42) 0%, rgba(2,12,9,.5) 100%);
  --glass-border:rgba(126,244,196,.18);
  --glass-shadow:0 30px 80px -40px rgba(0,0,0,.6);
  --glass-blur:18px;
  box-shadow:
    0 30px 80px -40px rgba(0,0,0,.6),
    inset 0 1px 0 rgba(126,244,196,.06);
}
body.svc-parent-page.custom-development-page .custom-terminal::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.032), transparent 24%),
    radial-gradient(120% 120% at 50% 100%, rgba(0,138,252,.08), transparent 54%);
}
body.svc-parent-page.custom-development-page .custom-terminal-bar{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
  min-height:56px;
  padding:0 18px;
  border-bottom:1px solid rgba(126,244,196,.12);
  background:rgba(2,12,9,.42);
}
body.svc-parent-page.custom-development-page .custom-terminal-dots{
  display:flex;
  align-items:center;
  gap:12px;
}
body.svc-parent-page.custom-development-page .custom-terminal-dots span{
  width:16px;
  height:16px;
  border-radius:50%;
  display:block;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14);
}
body.svc-parent-page.custom-development-page .custom-terminal-dots span:nth-child(1){ background:#ff8d83 }
body.svc-parent-page.custom-development-page .custom-terminal-dots span:nth-child(2){ background:#ffc75e }
body.svc-parent-page.custom-development-page .custom-terminal-dots span:nth-child(3){ background:#73e3a1 }
body.svc-parent-page.custom-development-page .custom-terminal-file{
  grid-column:2;
  justify-self:center;
  color:rgba(255,255,255,.42);
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.05em;
}
body.svc-parent-page.custom-development-page .custom-terminal-code{
  position:relative;
  z-index:1;
  padding:18px 0 0;
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  overflow-x:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(68,109,137,.66) rgba(255,255,255,.03);
}
body.svc-parent-page.custom-development-page .custom-terminal-code::-webkit-scrollbar{
  width:9px;
  height:9px;
}
body.svc-parent-page.custom-development-page .custom-terminal-code::-webkit-scrollbar-track{
  background:rgba(255,255,255,.03);
}
body.svc-parent-page.custom-development-page .custom-terminal-code::-webkit-scrollbar-thumb{
  background:rgba(68,109,137,.66);
  border-radius:999px;
  border:2px solid rgba(5,19,32,.3);
}
body.svc-parent-page.custom-development-page .custom-terminal pre{
  margin:0;
  min-width:820px;
  padding:0 18px 12px;
}
body.svc-parent-page.custom-development-page .custom-terminal code{
  display:block;
  color:#d6e2ed;
  font-family:var(--mono);
  font-size:13px;
  line-height:1.75;
}
body.svc-parent-page.custom-development-page .custom-terminal .line{
  display:grid;
  grid-template-columns:28px minmax(0, 1fr);
  gap:14px;
  align-items:baseline;
}
body.svc-parent-page.custom-development-page .custom-terminal .line-no{
  color:rgba(112,138,162,.36);
  text-align:right;
  user-select:none;
}
body.svc-parent-page.custom-development-page .custom-terminal .code{
  display:inline-block;
  width:max-content;
  white-space:pre;
  max-width:0;
  overflow:hidden;
  vertical-align:bottom;
}
body.svc-parent-page.custom-development-page .custom-terminal .line .code{
  animation:custom-terminal-type 9s steps(var(--typing-steps, 28), end) infinite;
  animation-delay:var(--typing-delay, 0s);
}
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(1) .code{ --typing-steps:34; --typing-delay:.08s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(3) .code{ --typing-steps:54; --typing-delay:.22s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(4) .code{ --typing-steps:58; --typing-delay:.42s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(6) .code{ --typing-steps:30; --typing-delay:.62s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(7) .code{ --typing-steps:29; --typing-delay:.78s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(8) .code{ --typing-steps:48; --typing-delay:.94s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(9) .code{ --typing-steps:28; --typing-delay:1.1s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(10) .code{ --typing-steps:42; --typing-delay:1.24s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(11) .code{ --typing-steps:30; --typing-delay:1.38s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(12) .code{ --typing-steps:2; --typing-delay:1.5s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(14) .code{ --typing-steps:49; --typing-delay:1.64s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(15) .code{ --typing-steps:49; --typing-delay:1.86s; }
body.svc-parent-page.custom-development-page .custom-terminal .line:nth-child(17) .code{ --typing-steps:44; --typing-delay:2.1s; }
body.svc-parent-page.custom-development-page .custom-terminal .line .code:empty{
  max-width:none;
  animation:none;
}
body.svc-parent-page.custom-development-page .custom-terminal .line-comment .code,
body.svc-parent-page.custom-development-page .custom-terminal .tok-comment{
  color:#597699;
  font-style:italic;
}
body.svc-parent-page.custom-development-page .custom-terminal .tok-keyword{
  color:#7ef4c4;
}
body.svc-parent-page.custom-development-page .custom-terminal .tok-symbol{
  color:#73baff;
}
body.svc-parent-page.custom-development-page .custom-terminal .tok-string{
  color:#ffd48d;
}
body.svc-parent-page.custom-development-page .custom-terminal .tok-property{
  color:#b4cce2;
}
body.svc-parent-page.custom-development-page .custom-terminal .tok-punct,
body.svc-parent-page.custom-development-page .custom-terminal .tok-operator{
  color:#8aa7c4;
}
body.svc-parent-page.custom-development-page .custom-terminal .tok-success{
  color:#70edb4;
}
body.svc-parent-page.custom-development-page .custom-terminal .line-status{
  margin-top:6px;
  padding-top:10px;
  border-top:1px dashed rgba(255,255,255,.065);
}
body.svc-parent-page.custom-development-page .custom-terminal-footer{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  padding:16px 18px 18px;
  margin-top:auto;
  border-top:1px solid rgba(126,244,196,.12);
  background:rgba(2,12,9,.42);
}
body.svc-parent-page.custom-development-page .custom-terminal-badge{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 13px;
  border-radius:999px;
  border:1px solid rgba(0,138,252,.38);
  background:rgba(0,138,252,.11);
  color:#8ec1fb;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.05em;
  text-transform:uppercase;
}
body.svc-parent-page.custom-development-page .custom-terminal-live{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:#82ddb0;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.09em;
}
body.svc-parent-page.custom-development-page .custom-terminal-live-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:currentColor;
  box-shadow:0 0 0 0 rgba(141,240,188,.55);
  animation:custom-live-pulse 1.4s ease-out infinite;
}
@keyframes custom-terminal-type{
  0%{ max-width:0 }
  35%{ max-width:100ch }
  90%{ max-width:100ch }
  100%{ max-width:0 }
}
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page, .tribal-services-page) .svc-card{
  gap:16px;
}
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page, .tribal-services-page, .public-safety-page) .svc-head{
  margin-bottom:0;
}
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page, .tribal-services-page, .public-safety-page) .svc-card p{
  margin:0;
  max-width:54ch;
}
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page, .tribal-services-page, .public-safety-page) .svc-card .svc-learn{ margin-top:auto }
body.svc-parent-page.custom-development-page .kicker{ color:#9cfac7 }
body.svc-parent-page.custom-development-page .kicker::before{ background:#9cfac7 }

/* Cybersecurity & Custom Development services cards — match Home "What we do" style & animation */
body.svc-parent-page :is(.cyber-services, .custom-dev-services, .tribal-services, .public-safety-services) .svc-card{
  min-height:240px;
  gap:0;
}
body.svc-parent-page :is(.cyber-services, .custom-dev-services, .tribal-services, .public-safety-services) .svc-head{
  margin-bottom:18px;
}
body.svc-parent-page :is(.cyber-services, .custom-dev-services, .tribal-services, .public-safety-services) .svc-card p{
  color:#91B4C9;
  max-width:58ch;
  margin:0 0 20px;
}
body.svc-parent-page :is(.cyber-services, .custom-dev-services, .tribal-services, .public-safety-services) .svc-card::before{
  background:radial-gradient(70% 55% at 100% 0%, rgba(0,138,252,.14), transparent 55%);
  opacity:.5;
}
body.svc-parent-page :is(.cyber-services, .custom-dev-services, .tribal-services, .public-safety-services) .svc-card:is(:hover, :focus-visible){
  transform:translateY(-4px);
  border:0.5px solid #004f7a;
  box-shadow:0 2px 0 rgba(0,0,0,.2), 0 20px 50px -16px rgba(0,0,0,.55);
}
body.svc-parent-page :is(.cyber-services, .custom-dev-services, .tribal-services, .public-safety-services) .svc-card:is(:hover, :focus-visible)::before{
  opacity:1;
}
body.svc-parent-page.cybersecurity-page .hero h1{
  max-width:none;
  white-space:nowrap;
  font-size:clamp(22px, 5.6vw, 60px);
}
body.svc-parent-page.cybersecurity-page .hero .inner{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(320px, 460px);
  gap:56px;
  align-items:center;
}
body.svc-parent-page.cybersecurity-page .cyber-hero-radar{
  justify-self:end;
  align-self:center;
  width:100%;
  max-width:460px;
  margin-top:0;
  filter:drop-shadow(0 24px 36px rgba(0,0,0,.34));
}
body.svc-parent-page.cybersecurity-page .hero .cyber-radar-scope{
  margin-top:0;
}
body.svc-parent-page.cybersecurity-page .hero .cyber-radar-svg{
  width:min(100%, 430px);
}
body.svc-parent-page.cybersecurity-page .hero .lede{ max-width:56ch }
body.svc-parent-page.custom-development-page .hero .lede{ max-width:56ch }
body.svc-parent-page :is(.hero, .parent-hero) .btn.bounce-down:hover svg,
body.home .hero .btn.bounce-down:hover svg{
  animation:cyber-arrow-bounce .62s cubic-bezier(.2,.88,.3,1);
  transform:translateY(0);
  transform-origin:center;
}
body.svc-parent-page.cybersecurity-page .cyber-proof-strip{
  position:relative;
  --glass-fill:linear-gradient(180deg, rgba(12,31,50,.44) 0%, rgba(4,19,31,.62) 100%);
  --glass-border:rgba(255,255,255,.1);
  --glass-shadow:0 18px 44px -28px rgba(0,0,0,.48);
  --glass-blur:18px;
  width:min(1176px, calc(100% - 64px));
  margin:0 auto 48px;
  padding:22px 0;
  border-radius:32px;
  overflow:hidden;
}
body.svc-parent-page.cybersecurity-page .cyber-proof-strip::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(60% 78% at 0% 0%, rgba(156,250,199,.05), transparent 60%),
    radial-gradient(74% 88% at 100% 0%, rgba(0,138,252,.1), transparent 60%);
}
body.svc-parent-page.cybersecurity-page .cyber-proof-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
  padding:0 24px;
}
@media (max-width:720px){
  body.svc-parent-page.cybersecurity-page .cyber-proof-strip{
    width:calc(100% - 40px);
  }
  body.svc-parent-page.cybersecurity-page .cyber-proof-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:12px;
    padding:0 16px;
  }
}

body.svc-parent-page.custom-development-page .custom-proof-strip{
  position:relative;
  z-index:2;
  width:min(1240px, calc(100% - 64px));
  margin:0 auto 48px;
  padding-bottom:0;
}
body.svc-parent-page.custom-development-page .custom-proof-strip .container{
  max-width:none;
  padding:0;
}
body.svc-parent-page.cybersecurity-page .cyber-services{ padding-top:36px }
body.svc-parent-page.public-safety-page .public-safety-services{ padding-top:36px }
body.svc-parent-page.custom-development-page .custom-dev-services{ padding-top:0 }
body.svc-parent-page.cybersecurity-page .home-kicker-accent{ color:#9cfac7 }
body.svc-parent-page.cybersecurity-page .home-kicker-accent::before{ background:#9cfac7 }
body.svc-parent-page.public-safety-page .home-kicker-accent{ color:#9cfac7 }
body.svc-parent-page.public-safety-page .home-kicker-accent::before{ background:#9cfac7 }
body.svc-parent-page.custom-development-page :is(.custom-proof-label, .custom-partner-step, .custom-frameworks-label){
  color:#9cfac7;
}
body.svc-parent-page.custom-development-page .custom-frameworks-list{
  justify-content:flex-start;
}
body.svc-parent-page.custom-development-page .hero h1,
body.svc-parent-page .parent-hero h1,
body.svc-parent-page.about-page .svc-hero h1{
  font-size:clamp(22px, 5.6vw, 60px);
  line-height:1.02;
  letter-spacing:-0.03em;
}
body.svc-parent-page.custom-development-page .hero h1{ white-space:nowrap }
@media (max-width: 560px){
  body.svc-parent-page.custom-development-page .hero h1{ white-space:normal }
}
body.svc-parent-page.custom-development-page .hero .lede,
body.svc-parent-page .parent-hero .lede,
body.svc-parent-page.about-page .svc-hero .lede{
  font-size:18px;
  line-height:1.6;
}
body.svc-parent-page.custom-development-page :is(.custom-dev-services, .custom-timeline-section, .custom-stack-section) .section-head{
  display:block;
}
body.svc-parent-page.custom-development-page :is(.custom-dev-services, .custom-timeline-section, .custom-stack-section) .section-head .home-section-lede{
  max-width:46ch;
  margin-top:16px;
}
body.svc-parent-page.custom-development-page .custom-dev-services .section-head .home-section-lede{
  max-width:58ch;
}
body.svc-parent-page.custom-development-page .custom-timeline-section .home-section-title br{
  display:block;
}
body.svc-parent-page.custom-development-page .custom-proof-band{
  --glass-fill:linear-gradient(180deg, rgba(12,31,50,.44) 0%, rgba(4,19,31,.62) 100%);
  --glass-border:rgba(255,255,255,.1);
  --glass-shadow:0 18px 44px -28px rgba(0,0,0,.48);
  --glass-blur:18px;
  border-radius:32px;
  padding:22px 24px;
}
body.svc-parent-page.custom-development-page .custom-proof-band::before{
  background:
    radial-gradient(60% 78% at 0% 0%, rgba(156,250,199,.05), transparent 60%),
    radial-gradient(74% 88% at 100% 0%, rgba(0,138,252,.1), transparent 60%);
}
body.svc-parent-page.custom-development-page .custom-partner-section,
body.svc-parent-page.about-page :is(.about-story, .about-values-section){
  padding-top:36px;
}

body.svc-parent-page .parent-hero{
  position:relative;
  padding:86px 0 78px;
  overflow:hidden;
  color:#fff;
  background:
    radial-gradient(70% 100% at 50% 0%, rgba(156,250,199,.07) 0%, transparent 58%),
    linear-gradient(180deg, rgba(156,250,199,.035) 0%, transparent 72%);
}
body.svc-parent-page .parent-hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(72% 110% at 50% 0%, rgba(156,250,199,.05) 0%, transparent 60%),
    var(--hero-network-dark) center top / 720px 480px repeat;
  opacity:.36;
  mask-image:radial-gradient(ellipse at top center, #000 20%, transparent 74%);
  -webkit-mask-image:radial-gradient(ellipse at top center, #000 20%, transparent 74%);
}
body.svc-parent-page .parent-hero .container{
  position:relative;
  z-index:1;
}
body.svc-parent-page .parent-hero h1{
  color:#fff;
  margin:0 0 18px;
  max-width:13ch;
}
body.svc-parent-page .parent-hero :is(.accent, .accent-inline){ color:#9cfac7 }
body.svc-parent-page .parent-hero .lede{
  color:#AFCBDE;
  margin:0 0 28px;
  max-width:56ch;
}
body.svc-parent-page .parent-hero .ctas{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
body.svc-parent-page .parent-hero .btn.primary{
  background:rgba(156,250,199,.18);
  color:#9cfac7;
  border:0.5px solid transparent;
  box-shadow:none;
  height:50px;
}
body.svc-parent-page .parent-hero .btn.primary:is(:hover, :focus-visible){
  background:rgba(156,250,199,.28);
  border-color:#9cfac7;
  text-decoration:none;
}
body.svc-parent-page .parent-hero .btn.ghost{
  background:rgba(255,255,255,.08);
  color:#fff;
  border:0.5px solid rgba(255,255,255,.12);
}
body.svc-parent-page .parent-hero .btn.ghost:is(:hover, :focus-visible){
  background:rgba(0,138,252,.18);
  border-color:rgba(156,250,199,.3);
  text-decoration:none;
}
body.svc-parent-page .parent-sub{
  --glass-fill:linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,.05) 100%);
  --glass-border:rgba(255,255,255,.1);
  --glass-shadow:0 14px 28px -18px rgba(0,0,0,.42);
  --glass-blur:16px;
  max-width:880px;
  margin:30px 0 0;
  padding:24px 28px;
  border-top:none;
  color:#9AB7C8;
  font-size:16px;
  line-height:1.72;
  border-radius:28px;
  overflow:hidden;
}
body.svc-parent-page .parent-sub::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(60% 78% at 0% 0%, rgba(156,250,199,.05), transparent 60%),
    radial-gradient(74% 88% at 100% 0%, rgba(0,138,252,.1), transparent 60%);
}
body.svc-parent-page:is(.tribal-services-page, .public-safety-page) .parent-sub{
  --glass-fill:none;
  --glass-border:transparent;
  --glass-shadow:none;
  --glass-blur:0px;
  max-width:60ch;
  margin:30px 0 0;
  padding:24px 0 0;
  border-top:1px solid rgba(255,255,255,.1);
  border-radius:0;
  overflow:visible;
  color:#9AB7C8;
}
body.svc-parent-page:is(.tribal-services-page, .public-safety-page) .parent-sub::before{
  content:none;
}
body.svc-parent-page .parent-body{
  position:relative;
  padding:36px 0 92px;
  background:transparent;
  color:#D5E5F1;
}
body.svc-parent-page .srv-card .head{
  display:flex;
  align-items:flex-start;
  gap:16px;
}
body.svc-parent-page .srv-card .ic{
  width:50px;
  height:50px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(156,250,199,.12);
  color:#9cfac7;
  border:1px solid rgba(156,250,199,.22);
  flex-shrink:0;
}
body.svc-parent-page .srv-card h3{ margin:0 }
body.svc-parent-page .srv-card p{
  max-width:58ch;
  margin:0 0 20px;
}
body.svc-parent-page.tribal-services-page .parent-hero h1{
  max-width:none;
  white-space:nowrap;
}
body.svc-parent-page.tribal-services-page .tribal-hero-layout{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(280px, .95fr);
  gap:52px;
  align-items:center;
}
body.svc-parent-page.tribal-services-page .tribal-hero-copy{
  min-width:0;
}
body.svc-parent-page.tribal-services-page .hero-graphic {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  justify-self:end;
  width:100%;
}
body.svc-parent-page.tribal-services-page .hg-svg {
  width: 100%;
  max-width: 460px;
  height: auto;
  filter: drop-shadow(0 0 40px rgba(0, 138, 252, 0.15));
}

/* Pulse ring expanding outward */
body.svc-parent-page.tribal-services-page .hg-pulse {
  animation: hg-pulse 3s ease-out infinite;
  transform-origin: 240px 240px;
}
@keyframes hg-pulse {
  0%   { r: 88; opacity: 0.7; }
  100% { r: 140; opacity: 0; }
}

/* Outer orbit nodes slowly rotating */
body.svc-parent-page.tribal-services-page .hg-orbit-outer {
  animation: hg-spin 40s linear infinite;
  transform-origin: 240px 240px;
}
@keyframes hg-spin {
  to { transform: rotate(360deg); }
}

/* Floating data dots blinking */
body.svc-parent-page.tribal-services-page .hg-dot { animation: hg-blink 4s ease-in-out infinite; }
body.svc-parent-page.tribal-services-page .hg-dot-1 { animation-delay: 0s; }
body.svc-parent-page.tribal-services-page .hg-dot-2 { animation-delay: 0.8s; }
body.svc-parent-page.tribal-services-page .hg-dot-3 { animation-delay: 1.6s; }
body.svc-parent-page.tribal-services-page .hg-dot-4 { animation-delay: 2.4s; }
body.svc-parent-page.tribal-services-page .hg-dot-5 { animation-delay: 0.4s; }
body.svc-parent-page.tribal-services-page .hg-dot-6 { animation-delay: 1.2s; }
@keyframes hg-blink {
  0%, 100% { opacity: 0.3; }
  50%       { opacity: 1; }
}
body.svc-parent-page.tribal-services-page .tribal-system-band{
  padding:36px 0 28px;
  background:linear-gradient(100deg, rgba(0,42,64,.1) 0%, rgba(0,79,122,.1) 40%, rgba(0,138,252,.1) 70%, rgba(0,42,64,.1) 100%);
  border-top:1px solid rgba(0,138,252,.12);
  border-bottom:1px solid rgba(0,138,252,.12);
  overflow:hidden;
  position:relative;
}
body.svc-parent-page.tribal-services-page .tribal-system-label{
  text-align:center;
  margin:0 0 28px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
}
body.svc-parent-page.tribal-services-page .tribal-system-prefix{
  font-family:"Schibsted Grotesk","Helvetica Neue",sans-serif;
  font-size:16px;
  line-height:1.4;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
body.svc-parent-page.tribal-services-page .tribal-system-industry{
  font-family:"Schibsted Grotesk","Helvetica Neue",sans-serif;
  font-size:15px;
  letter-spacing:.14em;
  line-height:1.4;
  text-transform:uppercase;
  color:#9cfac7;
  transition:opacity .35s ease;
  min-height:1.4em;
}
body.svc-parent-page.tribal-services-page .tribal-system-logos{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:56px;
  margin-top:0;
}
body.svc-parent-page.tribal-services-page .tribal-system-logos .tribal-logo{
  display:block;
  height:auto;
  object-fit:contain;
  transform-origin:center center;
  transition:transform .2s ease, filter .2s ease;
}
body.svc-parent-page.tribal-services-page .tribal-system-logos .tribal-logo:hover{
  transform:scale(1.04);
}
body.svc-parent-page.tribal-services-page .tribal-system-logos .tribal-logo-hub{
  width:min(100%, 210px);
  filter:drop-shadow(0 16px 24px rgba(0,0,0,.22));
}
body.svc-parent-page.tribal-services-page .tribal-system-logos .tribal-logo-aicco{
  width:min(100%, 259px);
}
@media (max-width: 980px){
  body.svc-parent-page.tribal-services-page .tribal-hero-layout{
    grid-template-columns:1fr;
    gap:40px;
  }
  body.svc-parent-page.tribal-services-page .hero-graphic{
    justify-self:start;
    max-width:460px;
  }
}
@media (prefers-reduced-motion: reduce){
  body.svc-parent-page.tribal-services-page .hg-pulse,
  body.svc-parent-page.tribal-services-page .hg-orbit-outer,
  body.svc-parent-page.tribal-services-page .hg-dot{
    animation:none;
  }
}
body.svc-parent-page.tribal-services-page .tribal-services .svc-grid,
body.svc-parent-page.public-safety-page .public-safety-services .svc-grid{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}
body.svc-parent-page.tribal-services-page .tribal-services .svc-ic img[src$="shield-check-duotone-solid-full.svg"],
body.svc-parent-page.public-safety-page .public-safety-services .svc-ic img[src$="shield-check-duotone-solid-full.svg"]{
  width:28px;
  height:28px;
}
body.svc-parent-page.tribal-services-page .tribal-services .svc-ic img[src$="headset-duotone-solid-full(1).svg"],
body.svc-parent-page.public-safety-page .public-safety-services .svc-ic img[src$="headset-duotone-solid-full(1).svg"]{
  width:30px;
  height:30px;
}
body.svc-parent-page.tribal-services-page .tribal-services .section-head{
  display:block;
  margin-bottom:34px;
}
body.svc-parent-page.tribal-services-page .tribal-services .home-kicker-accent{
  color:#9cfac7;
}
body.svc-parent-page.tribal-services-page .tribal-services .home-kicker-accent::before{
  background:#9cfac7;
}
body.svc-parent-page.tribal-services-page .tribal-services .home-section-lede{
  max-width:58ch;
}
@media (max-width: 560px){
  body.svc-parent-page.tribal-services-page .parent-hero h1{ white-space:normal }
}
@media (max-width: 860px){
  body.svc-parent-page.tribal-services-page .tribal-services .svc-grid,
  body.svc-parent-page.public-safety-page .public-safety-services .svc-grid{
    grid-template-columns:1fr;
  }
}
@media (max-width:760px){
  body.svc-parent-page.tribal-services-page .parent-sub{
    padding:22px 0 0;
  }
}

/* ── Tribal: Why DigitalBlue ── */
body.svc-parent-page.tribal-services-page .tribal-why-head{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(0, 1fr);
  gap:48px;
  align-items:end;
  margin-bottom:38px;
}
body.svc-parent-page.tribal-services-page .tribal-why-head-left{
  min-width:0;
}
body.svc-parent-page.tribal-services-page .tribal-why-head-left .tribal-why-head-right{
  margin-top:18px;
  justify-self:auto;
}
body.svc-parent-page.tribal-services-page .tribal-why-head-right{
  margin:0;
  color:#91B4C9;
  font-family:var(--body-font);
  font-size:18px;
  line-height:1.6;
  max-width:46ch;
  justify-self:end;
}
body.svc-parent-page.tribal-services-page .tribal-why-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
}
/* Responsive overrides declared after the base so the cascade collapses 3 -> 2 -> 1. */
@media (max-width: 920px){
  body.svc-parent-page.tribal-services-page .tribal-why-head{
    grid-template-columns:1fr;
    gap:18px;
  }
  body.svc-parent-page.tribal-services-page .tribal-why-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 560px){
  body.svc-parent-page.tribal-services-page .tribal-why-grid{
    grid-template-columns:1fr;
  }
}
body.svc-parent-page.tribal-services-page .tribal-why-item{
  position:relative;
  padding:34px 36px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  color:#D5E5F1;
  background:rgba(10,30,50,.32);
  backdrop-filter:blur(18px) saturate(1.1);
  -webkit-backdrop-filter:blur(18px) saturate(1.1);
  transition:
    background .24s ease,
    border-color .24s ease,
    box-shadow .24s ease,
    transform .24s ease;
}
body.svc-parent-page.tribal-services-page .tribal-why-item:hover{
  transform:translateY(-6px);
  background:
    radial-gradient(88% 82% at 12% 0%, rgba(156,250,199,.13), transparent 58%),
    rgba(255,255,255,.035);
  border-color:rgba(156,250,199,.26);
  box-shadow:
    inset 0 0 0 1px rgba(156,250,199,.08),
    inset 0 18px 46px rgba(156,250,199,.045);
}
body.svc-parent-page.tribal-services-page .tribal-why-icon{
  width:50px;
  height:50px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(156,250,199,.12);
  color:#9cfac7;
  border:1px solid rgba(156,250,199,.22);
  flex-shrink:0;
  transition:background .24s ease, border-color .24s ease, box-shadow .24s ease;
}
body.svc-parent-page.tribal-services-page .tribal-why-item-head{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}
body.svc-parent-page.tribal-services-page .tribal-why-icon img{
  width:28px;
  height:28px;
  display:block;
  object-fit:contain;
  filter:brightness(0) saturate(100%) invert(88%) sepia(24%) saturate(659%) hue-rotate(84deg) brightness(103%) contrast(97%);
}
body.svc-parent-page.tribal-services-page .tribal-why-item:hover .tribal-why-icon{
  background:rgba(156,250,199,.18);
  border-color:rgba(156,250,199,.36);
  box-shadow:0 0 18px rgba(156,250,199,.12);
}
body.svc-parent-page.tribal-services-page .tribal-why-item h3{
  margin:0;
  color:#fff;
  font-size:20px;
  line-height:1.3;
}
body.svc-parent-page.tribal-services-page .tribal-why-item p{
  margin:0;
  color:#91B4C9;
  font-family:var(--body-font);
  font-size:14px;
  line-height:1.6;
}
@media (prefers-reduced-motion: reduce){
  body.svc-parent-page.tribal-services-page .tribal-why-item{
    transform:none;
    transition:background .01s linear, border-color .01s linear, box-shadow .01s linear;
  }
  body.svc-parent-page.tribal-services-page .tribal-why-item:hover{
    transform:none;
  }
}
body.svc-parent-page.public-safety-page .parent-hero h1{
  max-width:none;
  white-space:normal;
}
body.svc-parent-page.public-safety-page .public-safety-hero-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(280px, 390px);
  align-items:center;
  gap:56px;
}
body.svc-parent-page.public-safety-page .public-safety-hero-copy{
  min-width:0;
}
body.svc-parent-page.public-safety-page .public-safety-cjis-mark{
  position:relative;
  justify-self:end;
  width:min(100%, 390px);
  aspect-ratio:1;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:
    radial-gradient(60% 60% at 50% 45%, rgba(156,250,199,.16), transparent 70%),
    radial-gradient(80% 80% at 50% 50%, rgba(0,138,252,.06), transparent 78%);
  border:none;
  box-shadow:0 30px 80px -46px rgba(0,0,0,.6);
  overflow:visible;
}
body.svc-parent-page.public-safety-page .public-safety-cjis-mark::before{
  content:"";
  position:absolute;
  inset:-8%;
  border-radius:50%;
  background:radial-gradient(closest-side, rgba(0,138,252,.22), transparent 72%);
  filter:blur(28px);
  opacity:.85;
  pointer-events:none;
  z-index:0;
}
body.svc-parent-page.public-safety-page .public-safety-cjis-mark::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  background:radial-gradient(closest-side, transparent 70%, rgba(156,250,199,.06) 84%, transparent 100%);
  pointer-events:none;
  z-index:0;
}
/* Invert the parent-page Explore services button.
   Resting state uses a slightly translucent white; hover stays fully opaque. */
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page, .tribal-services-page, .public-safety-page) .parent-hero .btn.ghost,
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page) .hero .btn.ghost,
body.svc-parent-page.about-page .svc-hero .btn.ghost,
body.case-studies-page .case-study-hero .btn.ghost,
body.home .hero .btn.ghost{
  background:rgba(255,255,255,.78);
  color:#031526;
  border:1px solid rgba(255,255,255,.85);
}
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page, .tribal-services-page, .public-safety-page) .parent-hero .btn.ghost:is(:hover, :focus-visible),
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page) .hero .btn.ghost:is(:hover, :focus-visible),
body.svc-parent-page.about-page .svc-hero .btn.ghost:is(:hover, :focus-visible),
body.case-studies-page .case-study-hero .btn.ghost:is(:hover, :focus-visible),
body.home .hero .btn.ghost:is(:hover, :focus-visible){
  background:#9cfac7;
  border-color:#9cfac7;
  color:#031526;
  transform:translateY(-1px);
  text-decoration:none;
}
body.svc-parent-page.public-safety-page .public-safety-cjis-mark .cjis-logo{
  position:relative;
  z-index:1;
  width:min(100%, 320px);
  height:auto;
  display:block;
  object-fit:contain;
}
body.svc-parent-page.public-safety-page .public-safety-services .section-head{
  display:block;
}
body.svc-parent-page.public-safety-page .public-safety-services .home-section-lede{
  max-width:58ch;
}
body.svc-parent-page:is(.tribal-services-page, .public-safety-page) .parent-body .srv-grid{
  gap:20px;
}
body.svc-parent-page:is(.tribal-services-page, .public-safety-page) .srv-card{
  min-height:240px;
}
body.svc-parent-page:is(.tribal-services-page, .public-safety-page) .srv-card::before{
  background:radial-gradient(70% 55% at 100% 0%, rgba(0,138,252,.14), transparent 55%);
  opacity:.5;
}
body.svc-parent-page:is(.tribal-services-page, .public-safety-page) .srv-card:is(:hover, :focus-visible){
  transform:translateY(-4px);
  border:0.5px solid #004f7a;
  box-shadow:0 2px 0 rgba(0,0,0,.2), 0 20px 50px -16px rgba(0,0,0,.55);
}
body.svc-parent-page:is(.tribal-services-page, .public-safety-page) .srv-card:is(:hover, :focus-visible)::before{
  opacity:1;
}

body.svc-parent-page.about-page .svc-hero.hero{
  position:relative;
  padding:86px 0 78px;
  overflow:hidden;
  color:#fff;
  background:
    radial-gradient(70% 100% at 50% 0%, rgba(156,250,199,.07) 0%, transparent 58%),
    linear-gradient(180deg, rgba(156,250,199,.035) 0%, transparent 72%);
}
body.svc-parent-page.about-page .svc-hero.hero::before{
  display:block;
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(72% 110% at 50% 0%, rgba(156,250,199,.05) 0%, transparent 60%),
    var(--hero-network-dark) center top / 720px 480px repeat;
  opacity:.36;
  mask-image:radial-gradient(ellipse at top center, #000 20%, transparent 74%);
  -webkit-mask-image:radial-gradient(ellipse at top center, #000 20%, transparent 74%);
}
body.svc-parent-page.about-page .svc-hero.hero .inner{
  position:relative;
  z-index:1;
  display:block;
}
body.svc-parent-page.about-page .hero-copy{ max-width:700px }
body.svc-parent-page.about-page .svc-hero h1{
  color:#fff;
  max-width:12ch;
  margin:14px 0 10px;
}
body.svc-parent-page.about-page .about-hero-subtitle{
  color:#9cfac7;
  font-family:var(--display);
  font-size:clamp(24px, 4vw, 42px);
  font-weight:600;
  line-height:1.05;
  margin:0 0 18px;
}
body.svc-parent-page.about-page .svc-hero .lede{
  color:#AFCBDE;
  font-size:18px;
  margin:0 0 28px;
  max-width:54ch;
}
body.svc-parent-page.about-page .svc-hero .ctas{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
body.svc-parent-page.about-page .svc-hero .btn.primary{
  background:rgba(156,250,199,.18);
  color:#9cfac7;
  border:0.5px solid transparent;
  box-shadow:none;
  height:50px;
}
body.svc-parent-page.about-page .svc-hero .btn.primary:is(:hover, :focus-visible){
  background:rgba(156,250,199,.28);
  border-color:#9cfac7;
  text-decoration:none;
}
/* About hero ghost button now inherits the unified opaque-white style
   defined alongside the parent-page rule above. */
body.svc-parent-page.about-page .side-card{
  background:linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,.05) 100%);
  border-color:rgba(255,255,255,.1);
  box-shadow:0 14px 28px -18px rgba(0,0,0,.42);
  color:#D5E5F1;
  border-radius:28px;
  overflow:hidden;
  max-width:760px;
  margin-top:30px;
}
body.svc-parent-page.about-page .side-card::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(60% 78% at 0% 0%, rgba(156,250,199,.05), transparent 60%),
    radial-gradient(74% 88% at 100% 0%, rgba(0,138,252,.1), transparent 60%);
}
body.svc-parent-page.about-page .side-card h4{ color:#9cfac7 }
body.svc-parent-page.about-page .side-card li{
  color:#D5E5F1;
  border-top-color:rgba(255,255,255,.08);
}
body.svc-parent-page.about-page .side-card li svg{ color:#9cfac7 }
body.svc-parent-page.about-page .about-story .home-section-title{ max-width:13ch }
body.svc-parent-page.about-page .story-copy{ max-width:720px }
body.svc-parent-page.about-page .about-story-followup{
  margin-top:18px;
  color:#9AB7C8;
  max-width:42ch;
}
body.svc-parent-page.about-page .delivery-split{
  align-items:start;
  gap:36px;
}
body.svc-parent-page.about-page .delivery-split .note{
  background:linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,.05) 100%);
  border-color:rgba(255,255,255,.1);
  box-shadow:0 14px 28px -18px rgba(0,0,0,.42);
  color:#D5E5F1;
  border-radius:28px;
}
body.svc-parent-page.about-page .delivery-split .note strong{ color:#9cfac7 }
body.svc-parent-page.about-page .about-values{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
}
body.svc-parent-page.about-page .about-values-followup{ margin-top:20px }
body.svc-parent-page.about-page .value{
  background:linear-gradient(180deg, rgba(14,36,58,.46) 0%, rgba(4,20,31,.72) 100%);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 16px 34px -18px rgba(0,0,0,.52);
  color:#D5E5F1;
  transition:border-color .22s ease, box-shadow .22s ease;
}
body.svc-parent-page.about-page .value:hover{
  background:linear-gradient(180deg, rgba(14,36,58,.46) 0%, rgba(4,20,31,.72) 100%);
  border-color:rgba(255,255,255,.14);
  box-shadow:0 16px 34px -18px rgba(0,0,0,.52);
  transform:none;
}
body.svc-parent-page.about-page .value .num{ color:#9cfac7 }
body.svc-parent-page.about-page .value h3{
  color:#fff;
  font-size:clamp(20px, 2vw, 22px);
}
body.svc-parent-page.about-page .value p{ color:#91B4C9 }
body.svc-parent-page.about-page .about-slider-section{
  position:relative;
  overflow:hidden;
}
body.svc-parent-page.about-page .about-slider-section::before{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(156,250,199,.24), transparent);
  pointer-events:none;
}
body.svc-parent-page.about-page .about-slider{
  position:relative;
  margin-top:34px;
  padding:0 58px;
}
body.svc-parent-page.about-page .about-slides{
  position:relative;
  transition:min-height .35s ease;
}
body.svc-parent-page.about-page .about-slide{
  position:absolute;
  top:0;
  left:0;
  right:0;
  display:grid;
  grid-template-columns:minmax(0, .86fr) minmax(280px, 1fr);
  gap:34px;
  align-items:stretch;
  padding:34px;
  border-radius:28px;
  background:linear-gradient(180deg, rgba(14,36,58,.5) 0%, rgba(4,20,31,.78) 100%);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 22px 48px -26px rgba(0,0,0,.6);
  opacity:0;
  visibility:hidden;
  transform:translateX(18px);
  pointer-events:none;
  transition:opacity .35s ease, transform .35s ease, visibility 0s linear .35s;
}
body.svc-parent-page.about-page .about-slide.active{
  position:relative;
  opacity:1;
  visibility:visible;
  transform:translateX(0);
  pointer-events:auto;
  transition:opacity .35s ease, transform .35s ease, visibility 0s linear 0s;
}
body.svc-parent-page.about-page .about-slide-text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:320px;
}
body.svc-parent-page.about-page .about-slide-kicker{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#9cfac7;
  margin-bottom:14px;
}
body.svc-parent-page.about-page .about-slide h3{
  color:#fff;
  font-size:clamp(30px, 4vw, 50px);
  line-height:1;
  margin:0 0 18px;
}
body.svc-parent-page.about-page .about-slide p{
  color:#AFCBDE;
  font-size:16px;
  line-height:1.7;
  max-width:46ch;
  margin:0 0 26px;
}
body.svc-parent-page.about-page .about-slide .btn.primary{
  align-self:center;
  background:rgba(156,250,199,.18);
  color:#9cfac7;
  border:1px solid rgba(156,250,199,.24);
  box-shadow:none;
}
body.svc-parent-page.about-page .about-slide .btn.primary:is(:hover, :focus-visible){
  background:rgba(156,250,199,.28);
  border-color:#9cfac7;
  text-decoration:none;
}
body.svc-parent-page.about-page .about-slide-img{
  position:relative;
  min-height:320px;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(70% 72% at 78% 20%, rgba(156,250,199,.2), transparent 58%),
    radial-gradient(70% 80% at 10% 80%, rgba(0,138,252,.28), transparent 62%),
    linear-gradient(135deg, rgba(0,79,122,.45), rgba(0,18,30,.9)),
    url("../public/DBWebBackgrounds/hero-network-dark.svg") center / cover no-repeat;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
body.svc-parent-page.about-page .about-slide-img::before,
body.svc-parent-page.about-page .about-slide-img::after{
  content:"";
  position:absolute;
  pointer-events:none;
}
body.svc-parent-page.about-page .about-slide-img::before{
  inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(135deg, #000, transparent 78%);
  -webkit-mask-image:linear-gradient(135deg, #000, transparent 78%);
}
body.svc-parent-page.about-page .about-slide-img::after{
  inset:18%;
  border-radius:50%;
  border:1px solid rgba(156,250,199,.24);
  box-shadow:
    0 0 0 48px rgba(0,138,252,.04),
    0 0 70px rgba(0,138,252,.22);
}
body.svc-parent-page.about-page .about-slide-img[data-slide-theme="dev"],
body.svc-parent-page.about-page .about-slide-img[data-slide-theme="case"]{
  background:
    radial-gradient(78% 76% at 80% 20%, rgba(0,138,252,.26), transparent 60%),
    radial-gradient(60% 68% at 18% 80%, rgba(156,250,199,.18), transparent 60%),
    linear-gradient(135deg, rgba(0,42,64,.6), rgba(0,18,30,.94)),
    url("../public/DBWebBackgrounds/hero-network-dark.svg") center / cover no-repeat;
}
body.svc-parent-page.about-page .about-slide-img[data-slide-theme="tribal"],
body.svc-parent-page.about-page .about-slide-img[data-slide-theme="partners"]{
  background:
    radial-gradient(80% 72% at 76% 22%, rgba(156,250,199,.24), transparent 60%),
    radial-gradient(70% 80% at 12% 80%, rgba(0,79,122,.34), transparent 62%),
    linear-gradient(135deg, rgba(0,68,86,.58), rgba(0,18,30,.94)),
    url("../public/DBWebBackgrounds/hero-network-dark.svg") center / cover no-repeat;
}
body.svc-parent-page.about-page .about-slide-img-label{
  position:absolute;
  left:22px;
  bottom:22px;
  z-index:1;
  display:inline-flex;
  max-width:calc(100% - 44px);
  padding:10px 14px;
  border-radius:999px;
  background:rgba(3,18,28,.62);
  border:1px solid rgba(255,255,255,.14);
  color:#E6F3FE;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
}
body.svc-parent-page.about-page .about-slider-nav{
  position:absolute;
  top:50%;
  z-index:3;
  width:44px;
  height:44px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(10,30,50,.52);
  color:#D5E5F1;
  cursor:pointer;
  transform:translateY(-50%);
  transition:background .2s, border-color .2s, color .2s, transform .2s;
}
body.svc-parent-page.about-page .about-slider-nav:is(:hover, :focus-visible){
  background:rgba(0,138,252,.35);
  border-color:rgba(156,250,199,.4);
  color:#9cfac7;
  transform:translateY(-50%) scale(1.05);
}
body.svc-parent-page.about-page .about-slider-nav.prev{ left:0 }
body.svc-parent-page.about-page .about-slider-nav.next{ right:0 }
body.svc-parent-page.about-page .about-slider-dots{
  display:flex;
  justify-content:center;
  gap:7px;
  margin-top:26px;
}
body.svc-parent-page.about-page .about-slider-dots .dot{
  width:8px;
  height:8px;
  border:0;
  border-radius:50%;
  padding:0;
  background:rgba(198,220,234,.45);
  cursor:pointer;
  transition:background .2s, transform .2s;
}
body.svc-parent-page.about-page .about-slider-dots .dot.active{
  background:#9cfac7;
  transform:scale(1.35);
}
body.svc-parent-page.about-page .home-testi-head{
  flex-direction:column;
  align-items:flex-start;
  gap:8px;
}
body.svc-parent-page.about-page .home-kicker-accent{ color:#9cfac7 }
body.svc-parent-page.about-page .home-kicker-accent::before{ background:#9cfac7 }
body.svc-parent-page.about-page .home-testi-lede{
  color:#91B4C9;
  margin-top:10px;
}
body.svc-parent-page.about-page .page-cta.cta-band{
  position:relative;
  margin:0;
  padding:72px 0;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(9,28,44,.56) 0%, rgba(3,18,28,.74) 100%);
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
body.svc-parent-page.about-page .page-cta.cta-band::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse 70% 140% at 0% 50%, rgba(0,138,252,.2) 0%, transparent 60%),
    radial-gradient(ellipse 50% 100% at 100% 50%, rgba(156,250,199,.1) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 50% 100%, rgba(0,79,122,.24) 0%, transparent 60%);
}
body.svc-parent-page.about-page .page-cta.cta-band::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 82% at 20% 50%, #000 20%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 80% 82% at 20% 50%, #000 20%, transparent 70%);
}
body.svc-parent-page.about-page .page-cta.cta-band .inner{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
}
body.svc-parent-page.about-page .page-cta.cta-band h2{
  color:#fff;
  max-width:26ch;
}
body.svc-parent-page.about-page .page-cta.cta-band .btn.primary{
  background:#fff;
  color:var(--darker-azure);
  box-shadow:0 14px 28px -10px rgba(0,0,0,.3);
}
body.svc-parent-page.about-page .page-cta.cta-band .btn.primary:is(:hover, :focus-visible){
  background:#E6F3FE;
}

@keyframes cyber-arrow-bounce{
  0%{ transform:translateY(0) }
  24%{ transform:translateY(7px) }
  46%{ transform:translateY(-3px) }
  64%{ transform:translateY(2px) }
  80%{ transform:translateY(-1px) }
  100%{ transform:translateY(0) }
}

@keyframes cyber-arrow-bounce-right{
  0%{ transform:translateX(0) }
  24%{ transform:translateX(7px) }
  46%{ transform:translateX(-3px) }
  64%{ transform:translateX(2px) }
  80%{ transform:translateX(-1px) }
  100%{ transform:translateX(0) }
}

@keyframes cyber-arrow-bounce-flip{
  0%{ transform:rotate(180deg) translateY(0) }
  24%{ transform:rotate(180deg) translateY(7px) }
  46%{ transform:rotate(180deg) translateY(-3px) }
  64%{ transform:rotate(180deg) translateY(2px) }
  80%{ transform:rotate(180deg) translateY(-1px) }
  100%{ transform:rotate(180deg) translateY(0) }
}

@keyframes case-study-card-filter-in{
  0%{
    opacity:0;
    filter:blur(4px);
    transform:translateY(12px) scale(.985);
  }
  100%{
    opacity:1;
    filter:blur(0);
    transform:translateY(0) scale(1);
  }
}

body.home .svc-learn:hover svg,
body.home .svc-learn:focus-visible svg,
body.svc-parent-page .svc-learn:is(:hover, :focus-visible) svg{
  animation:cyber-arrow-bounce-right .62s cubic-bezier(.2,.88,.3,1);
  transform:translateX(0);
  transform-origin:center;
}

@media (max-width:1080px){
  body.svc-parent-page.cybersecurity-page .hero .inner{
    grid-template-columns:1fr;
    gap:30px;
  }
  /* Cyber hero radar is decorative — hide it once the hero stacks (<=1080px). */
  body.svc-parent-page.cybersecurity-page .cyber-hero-radar{
    display:none;
  }
  body.svc-parent-page.custom-development-page .hero .inner{
    grid-template-columns:1fr;
    gap:30px;
  }
  body.svc-parent-page.public-safety-page .public-safety-hero-layout{
    grid-template-columns:1fr;
    gap:34px;
  }
  body.svc-parent-page.public-safety-page .public-safety-cjis-mark{
    justify-self:start;
    width:min(100%, 340px);
  }
  body.svc-parent-page.custom-development-page .hero-copy{
    min-height:0;
  }
  body.svc-parent-page.custom-development-page .custom-terminal-shell{
    max-width:none;
    height:auto;
    margin-top:0;
    min-height:268px;
  }
  body.svc-parent-page.custom-development-page .custom-terminal{
    position:static;
    height:auto;
  }
  body.svc-parent-page :is(.cyber-proof-band, .custom-proof-band){
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}
@media (max-width:860px){
  body.svc-parent-page.cybersecurity-page .attack-map{
    width:300px;
    height:auto;
  }
  body.svc-parent-page :is(.svc-grid, .srv-grid, .why-grid, .custom-partner-grid){
    grid-template-columns:1fr;
  }
  body.svc-parent-page.about-page .about-slider{
    padding:0;
  }
  body.svc-parent-page.about-page .about-slide{
    grid-template-columns:1fr;
    gap:24px;
    padding:26px;
  }
  body.svc-parent-page.about-page .about-slide-text{
    min-height:0;
  }
  body.svc-parent-page.about-page .about-slide-img{
    min-height:240px;
  }
  body.svc-parent-page.about-page .about-slider-nav.prev{ left:14px }
  body.svc-parent-page.about-page .about-slider-nav.next{ right:14px }
  body.svc-parent-page.about-page .testi-nav.prev{ left:-24px }
  body.svc-parent-page.about-page .testi-nav.next{ right:-24px }
}
@media (max-width:760px){
  body.svc-parent-page .hero{
    padding:72px 0 60px;
  }
  body.svc-parent-page.cybersecurity-page .hero .inner{
    grid-template-columns:1fr;
    gap:26px;
  }
  body.svc-parent-page.custom-development-page .hero .inner{
    grid-template-columns:1fr;
    gap:26px;
  }
  body.svc-parent-page.custom-development-page .custom-terminal-shell{
    min-height:240px;
  }
  body.svc-parent-page.custom-development-page .custom-terminal-code{
    max-height:134px;
  }
  body.svc-parent-page :is(.why, .custom-partner){
    padding:38px 24px;
    border-radius:24px;
  }
  body.svc-parent-page .cta-band .inner{
    flex-direction:column;
    align-items:flex-start;
  }
  body.svc-parent-page .cyber-radar-cta{
    width:calc(100% - 40px);
    margin:0 auto 56px;
  }
  body.svc-parent-page .cyber-radar-cta .inner{
    grid-template-columns:1fr;
    gap:22px;
    padding:28px 22px 24px;
  }
  body.svc-parent-page .cyber-radar-aside{
    padding-top:0;
  }
  body.svc-parent-page .cyber-radar-cta h2{
    max-width:12ch;
    font-size:clamp(24px, 7vw, 30px);
  }
  body.svc-parent-page .cyber-radar-primary{
    min-width:min(100%, 320px);
  }
  body.svc-parent-page.cybersecurity-page .cyber-radar-svg{
    width:min(100%, 300px);
    margin:0 auto;
  }
  body.svc-parent-page .cyber-radar-points{
    grid-template-columns:1fr;
    gap:16px;
  }
  body.svc-parent-page .cyber-radar-point{
    padding:0;
  }
  body.svc-parent-page .cyber-radar-point-icon{
    margin-bottom:14px;
  }
  body.svc-parent-page .cyber-radar-point + .cyber-radar-point{
    border-left:none;
    border-top:1px solid rgba(255,255,255,.12);
    padding-top:16px;
  }
  body.svc-parent-page .parent-hero,
  body.svc-parent-page.about-page .svc-hero.hero{
    padding:72px 0 60px;
  }
  body.svc-parent-page.public-safety-page .parent-hero h1{
    white-space:normal;
  }
  body.svc-parent-page.public-safety-page .public-safety-cjis-mark{
    width:min(100%, 300px);
    border-radius:28px;
  }
  body.svc-parent-page .parent-sub{ padding:22px 22px 24px }
  body.svc-parent-page.about-page .page-cta.cta-band .inner{
    flex-direction:column;
    align-items:flex-start;
  }
}
@media (max-width:600px){
  body.svc-parent-page.about-page .about-slide{
    padding:22px;
    border-radius:22px;
  }
  body.svc-parent-page.about-page .about-slide-img{
    min-height:210px;
    border-radius:18px;
  }
  body.svc-parent-page.about-page .about-slider-nav{
    top:auto;
    bottom:18px;
    transform:none;
  }
  body.svc-parent-page.about-page .about-slider-nav:is(:hover, :focus-visible){
    transform:scale(1.05);
  }
  body.svc-parent-page.about-page .about-slider-dots{
    margin-top:20px;
  }
  body.svc-parent-page.about-page .testi-nav.prev{ left:6px }
  body.svc-parent-page.about-page .testi-nav.next{ right:6px }
}
@media (max-width:1020px){
  body.svc-parent-page.about-page .svc-hero.hero .inner{
    grid-template-columns:1fr;
  }
}
@media (max-width:900px){
  body.svc-parent-page.about-page .about-values{
    grid-template-columns:1fr;
  }
}
@media (max-width:520px){
  body.svc-parent-page :is(.cyber-proof-band, .custom-proof-band){
    grid-template-columns:1fr;
  }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto }
  body.svc-page.svc-parent-page{
    background:#001a28 url("../public/DBWebBackgrounds/bg-dark.png") top center / cover no-repeat;
    background-attachment:scroll;
  }
  body[data-site-section]:not(.svc-parent-page):not(.home):not([data-site-section="home"]):not([data-page-bg]){
    background:#ffffff url("../public/DBWebBackgrounds/bg-light.png") top center / cover no-repeat;
    background-attachment:scroll;
  }
  body[data-page-bg]{
    background-attachment:scroll;
  }
  body.svc-parent-page .page-bg{ display:none }
  [data-reveal]{
    opacity:1;
    transform:none;
    transition:none;
  }
  body.svc-parent-page .btn svg{ animation:none !important }
  body.svc-parent-page .btn:hover svg{ transform:none }
  body.svc-parent-page.cybersecurity-page .cyber-radar-sweep{
    animation:none;
  }
  body.home .svc-learn:hover svg,
  body.home .svc-learn:focus-visible svg,
  body.svc-parent-page .svc-learn:is(:hover, :focus-visible) svg{
    animation:none !important;
    transform:none;
  }
  body.svc-parent-page :is(.btn, .svc-card, .srv-card, .about-slide, .about-slider-nav, .custom-timeline-card, .cyber-proof-item, .custom-proof-item, .why-item, .custom-partner-item, .why-certs .badge, .value){
    transition:none !important;
    animation:none !important;
  }
  body.svc-parent-page.custom-development-page .custom-terminal-live-dot{
    animation:none !important;
  }
  body.svc-parent-page.custom-development-page .custom-terminal .code{
    max-width:none;
    animation:none !important;
  }
  body.svc-parent-page :is(.btn, .svc-card, .srv-card, .about-slide, .about-slider-nav, .custom-timeline-card, .cyber-proof-item, .custom-proof-item, .why-item, .custom-partner-item, .why-certs .badge, .value):is(:hover, :focus-visible){
    transform:none;
  }
  body.svc-parent-page .cyber-radar-kicker::after,
  body.svc-parent-page.cybersecurity-page .cyber-radar-sweep{
    animation:none !important;
  }
}

/* Custom Development — process timeline */
body.svc-parent-page.custom-development-page .custom-timeline-section{ padding-top:24px }
body.svc-parent-page.custom-development-page .custom-timeline{
  list-style:none;
  margin:32px 0 0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:20px;
  position:relative;
}
body.svc-parent-page.custom-development-page .custom-timeline::before{
  content:"";
  position:absolute;
  top:54px;
  left:6%;
  right:6%;
  height:1px;
  background:linear-gradient(90deg, rgba(156,250,199,.0), rgba(156,250,199,.35) 20%, rgba(0,138,252,.35) 80%, rgba(0,138,252,.0));
  pointer-events:none;
  z-index:0;
}
body.svc-parent-page.custom-development-page .custom-timeline-card{
  position:relative;
  z-index:1;
  --glass-fill:linear-gradient(180deg, rgba(22,40,60,.32) 0%, rgba(16,32,50,.4) 100%);
  --glass-border:rgba(180,220,245,.14);
  --glass-blur:18px;
  border-radius:22px;
  padding:22px 22px 24px;
  display:flex;
  flex-direction:column;
  gap:14px;
  overflow:hidden;
  cursor:default;
  transition:
    transform .22s ease,
    border-color .22s ease,
    box-shadow .22s ease,
    background .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:
    radial-gradient(80% 58% at 50% 100%, rgba(0,138,252,.1), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.032), transparent 32%);
  opacity:.5;
  transition:opacity .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible){
  --glass-fill:linear-gradient(180deg, rgba(34,56,78,.36) 0%, rgba(26,46,68,.44) 100%);
  --glass-border:rgba(156,250,199,.22);
  transform:translateY(-5px);
  box-shadow:0 24px 48px -22px rgba(0,0,0,.52), 0 0 0 1px rgba(156,250,199,.05);
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible)::before{
  opacity:1;
}
body.svc-parent-page.custom-development-page .custom-timeline-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-direction:row-reverse;
}
body.svc-parent-page.custom-development-page .custom-timeline-num{
  font-family:var(--display, inherit);
  font-size:28px;
  font-weight:700;
  letter-spacing:.02em;
  color:rgba(255,255,255,.32);
  line-height:1;
  transition:color .22s ease, opacity .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:50px;
  height:50px;
  border-radius:14px;
  background:rgba(156,250,199,.12);
  color:#9cfac7;
  border:1px solid rgba(156,250,199,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
  transition:
    transform .22s ease,
    background .22s ease,
    border-color .22s ease,
    color .22s ease,
    box-shadow .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-icon svg{
  width:28px;
  height:28px;
}
body.svc-parent-page.custom-development-page .custom-timeline-kicker{
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:11px;
  font-weight:600;
  color:#9cfac7;
  margin-top:6px;
  transition:color .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-title{
  font-size:20px;
  line-height:1.25;
  margin:0;
  color:#fff;
  transition:color .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-desc{
  font-size:14.5px;
  line-height:1.55;
  color:rgba(220,233,247,.82);
  margin:0;
  transition:color .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-meta{
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  flex-direction:column;
  gap:8px;
  transition:border-color .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-time{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:#9cfac7;
  font-size:13px;
  font-weight:500;
  transition:color .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-deliverables{
  margin:0;
  font-size:13px;
  line-height:1.5;
  color:rgba(190,205,222,.7);
  transition:color .22s ease;
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible) .custom-timeline-num{
  color:rgba(255,255,255,.52);
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible) .custom-timeline-icon{
  transform:none;
  background:rgba(156,250,199,.12);
  color:#9cfac7;
  border-color:rgba(156,250,199,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible) .custom-timeline-title{
  color:#f5fbff;
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible) .custom-timeline-desc{
  color:rgba(231,241,251,.92);
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible) .custom-timeline-meta{
  border-top-color:rgba(255,255,255,.14);
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible) .custom-timeline-time{
  color:#b6ffd6;
}
body.svc-parent-page.custom-development-page .custom-timeline-card:is(:hover, :focus-visible) .custom-timeline-deliverables{
  color:rgba(205,220,236,.82);
}
@media (max-width:1080px){
  body.svc-parent-page.custom-development-page .custom-timeline{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  body.svc-parent-page.custom-development-page .custom-timeline::before{ display:none }
}
@media (max-width:560px){
  body.svc-parent-page.custom-development-page .custom-timeline{
    grid-template-columns:1fr;
  }
}

/* Custom Development — technology stack */
body.svc-parent-page.custom-development-page .custom-stack-section{ padding-top:24px }
body.svc-parent-page.custom-development-page .custom-stack-panel{
  color:#D5E5F1;
  border-radius:32px;
  margin:0 auto;
  max-width:1224px;
  padding:72px 56px;
  position:relative;
  overflow:hidden;
  background:rgba(10,30,50,.38);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 4px 40px -10px rgba(0,0,0,.5);
}
body.svc-parent-page.custom-development-page .custom-stack-panel::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(60% 70% at 100% 0%, rgba(0,138,252,.18), transparent 60%),
    radial-gradient(40% 50% at 0% 100%, rgba(156,250,199,.08), transparent 60%);
}
body.svc-parent-page.custom-development-page .custom-stack-hero{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0, .98fr) minmax(360px, .78fr);
  align-items:start;
  gap:56px;
}
body.svc-parent-page.custom-development-page .custom-stack-panel .kicker{
  color:#9cfac7;
}
body.svc-parent-page.custom-development-page .custom-stack-panel .kicker::before{
  background:#9cfac7;
}
body.svc-parent-page.custom-development-page .custom-stack-panel .home-section-title{
  color:#fff;
  font-size:clamp(30px, 3.6vw, 48px);
  line-height:1.08;
  max-width:720px;
  margin-top:14px;
  margin-bottom:0;
  text-shadow:none;
}
body.svc-parent-page.custom-development-page .custom-stack-subtitle{
  margin:16px 0 0;
  color:#9cfac7;
  font-size:18px;
  font-weight:400;
  line-height:1.6;
}
body.svc-parent-page.custom-development-page .custom-stack-panel .home-section-lede{
  color:#91B4C9;
  max-width:60ch;
  font-size:18px;
  line-height:1.6;
  margin-top:16px;
}
body.svc-parent-page.custom-development-page .custom-stack-visual{
  position:relative;
  min-height:232px;
  margin-top:-10px;
  transform:scale(.9);
  transform-origin:top right;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,.28));
}
body.svc-parent-page.custom-development-page .custom-stack-orbit{
  position:absolute;
  width:260px;
  height:82px;
  border:1px dashed rgba(255,255,255,.1);
  transform:none;
}
body.svc-parent-page.custom-development-page .custom-stack-orbit--one{
  top:48px;
  left:34px;
}
body.svc-parent-page.custom-development-page .custom-stack-orbit--two{
  right:10px;
  bottom:42px;
}
body.svc-parent-page.custom-development-page .custom-stack-node{
  position:absolute;
  width:6px;
  height:6px;
  border-radius:50%;
  background:#9cfac7;
  box-shadow:0 0 0 5px rgba(156,250,199,.13), 0 0 12px rgba(156,250,199,.72), 0 0 22px rgba(156,250,199,.34);
}
body.svc-parent-page.custom-development-page .custom-stack-node--one{ top:72px; left:174px }
body.svc-parent-page.custom-development-page .custom-stack-node--two{ right:34px; top:112px }
body.svc-parent-page.custom-development-page .custom-stack-node--three{ right:32px; bottom:72px }
body.svc-parent-page.custom-development-page .custom-stack-node--four{ left:28px; bottom:88px }
body.svc-parent-page.custom-development-page .custom-stack-layer{
  position:absolute;
  display:grid;
  place-items:center;
  width:176px;
  height:78px;
  border-radius:10px;
  transform:none;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  box-shadow:0 18px 30px -24px rgba(0,0,0,.72);
}
body.svc-parent-page.custom-development-page .custom-stack-layer::after{
  content:"";
  position:absolute;
  inset:8px;
  border-radius:7px;
  border:1px solid rgba(255,255,255,.035);
}
body.svc-parent-page.custom-development-page .custom-stack-layer svg{
  width:48px;
  height:48px;
  color:#9cfac7;
  transform:none;
}
body.svc-parent-page.custom-development-page .custom-stack-layer--code{
  top:22px;
  right:42px;
  z-index:3;
  border-color:rgba(156,250,199,.3);
  background:rgba(255,255,255,.09);
  box-shadow:0 22px 34px -24px rgba(0,0,0,.76);
}
body.svc-parent-page.custom-development-page .custom-stack-layer--cloud{
  top:130px;
  left:40px;
  z-index:2;
}
body.svc-parent-page.custom-development-page .custom-stack-layer--data{
  right:66px;
  bottom:8px;
  z-index:1;
  width:154px;
  height:68px;
}
body.svc-parent-page.custom-development-page .custom-stack-layer--data svg{
  width:42px;
  height:42px;
  color:#9cfac7;
}
body.svc-parent-page.custom-development-page .custom-stack-principles{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
  margin-top:44px;
}
body.svc-parent-page.custom-development-page .custom-stack-principle{
  display:flex;
  flex-direction:column;
  gap:14px;
  align-items:flex-start;
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid rgba(255,255,255,.1);
  padding:28px;
  border-radius:var(--r-lg);
  transition:background .2s, border-color .2s, transform .2s;
}
body.svc-parent-page.custom-development-page .custom-stack-principle:hover{
  background:rgba(255,255,255,.09);
  border-color:rgba(156,250,199,.3);
  transform:translateY(-3px);
}
body.svc-parent-page.custom-development-page .custom-stack-principle-head{
  display:flex;
  align-items:center;
  gap:14px;
}
body.svc-parent-page.custom-development-page .custom-stack-principle-icon{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:rgba(156,250,199,.12);
  border:1px solid rgba(156,250,199,.22);
}
body.svc-parent-page.custom-development-page .custom-stack-principle-icon img{
  width:22px;
  height:22px;
  filter:brightness(0) saturate(100%) invert(88%) sepia(18%) saturate(1200%) hue-rotate(96deg) brightness(105%) contrast(99%);
}
body.svc-parent-page.custom-development-page .custom-stack-principle h3{
  margin:0;
  color:#fff;
  font-size:20px;
  line-height:1.08;
}
body.svc-parent-page.custom-development-page .custom-stack-principle p{
  margin:0;
  color:#91B4C9;
  font-size:14.5px;
  line-height:1.6;
  text-align:left;
}
body.svc-parent-page.custom-development-page .custom-stack-badges{
  position:relative;
  z-index:1;
  margin-top:44px;
  padding-top:36px;
  border-top:1px solid rgba(255,255,255,.08);
}
body.svc-parent-page.custom-development-page .custom-stack-label{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:20px;
  color:#9cfac7;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
body.svc-parent-page.custom-development-page .custom-stack-label::before{
  content:"";
  width:22px;
  height:1px;
  background:#9cfac7;
}
body.svc-parent-page.custom-development-page .custom-stack-grid{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:10px;
}
body.svc-parent-page.custom-development-page .custom-stack-card{
  min-height:268px;
  max-height:268px;
  padding:14px;
  border-radius:12px;
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(10px) saturate(140%);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
  border:1px solid rgba(255,255,255,.12);
  transition:all .2s;
  display:flex;
  flex-direction:column;
  overflow:visible;
}
body.svc-parent-page.custom-development-page .custom-stack-chip-grid::-webkit-scrollbar{ width:4px; }
body.svc-parent-page.custom-development-page .custom-stack-chip-grid::-webkit-scrollbar-track{ background:transparent; }
body.svc-parent-page.custom-development-page .custom-stack-chip-grid::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.55); border-radius:4px; }
body.svc-parent-page.custom-development-page .custom-stack-chip-grid::-webkit-scrollbar-thumb:hover{ background:rgba(255,255,255,.8); }
body.svc-parent-page.custom-development-page .custom-stack-card:hover{
  border-color:rgba(156,250,199,.35);
  background:rgba(255,255,255,.09);
  transform:translateY(-2px);
}
body.svc-parent-page.custom-development-page .custom-stack-card-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
  flex:0 0 auto;
}
body.svc-parent-page.custom-development-page .custom-stack-card-icon{
  width:40px;
  height:40px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  border-radius:14px;
  background:rgba(156,250,199,.12);
  border:1px solid rgba(156,250,199,.22);
}
body.svc-parent-page.custom-development-page .custom-stack-card-icon img{
  width:22px;
  height:22px;
  filter:brightness(0) saturate(100%) invert(88%) sepia(18%) saturate(1200%) hue-rotate(96deg) brightness(105%) contrast(99%);
}
body.svc-parent-page.custom-development-page .custom-stack-card h3{
  margin:0;
  color:#fff;
  font-size:16px;
  font-weight:600;
  letter-spacing:-0.02em;
  text-transform:none;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  min-width:0;
}
body.svc-parent-page.custom-development-page .custom-stack-chip-grid{
  display:grid;
  grid-template-columns:1fr;
  grid-auto-rows:38px;
  align-content:start;
  gap:8px;
  padding:4px 2px 0;
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.55) transparent;
}
body.svc-parent-page.custom-development-page .custom-stack-chip{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:38px;
  box-sizing:border-box;
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(10px) saturate(140%);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:0 10px;
  text-align:center;
  font-family:var(--display);
  font-size:12px;
  font-weight:600;
  line-height:1;
  white-space:nowrap;
  color:#fff;
  letter-spacing:0;
  text-transform:none;
  transition:all .2s;
}
body.svc-parent-page.custom-development-page .custom-stack-chip:hover{
  background:rgba(255,255,255,.09);
  border-color:rgba(156,250,199,.35);
  transform:translateY(-2px);
}
@media (max-width:1120px){
  body.svc-parent-page.custom-development-page .custom-stack-hero{
    grid-template-columns:1fr;
    gap:28px;
  }
  body.svc-parent-page.custom-development-page .custom-stack-visual{
    transform:scale(.88);
    transform-origin:top center;
    max-width:520px;
    width:100%;
    justify-self:center;
  }
  body.svc-parent-page.custom-development-page .custom-stack-principles{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  body.svc-parent-page.custom-development-page .custom-stack-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
  body.svc-parent-page.custom-development-page .custom-stack-principle:nth-child(2){
    border-right:0;
    padding-right:0;
  }
  body.svc-parent-page.custom-development-page .custom-stack-principle:last-child{
    grid-column:1 / -1;
  }
}
@media (max-width:860px){
  body.svc-parent-page.custom-development-page .custom-stack-panel{
    padding:48px 28px;
    border-radius:22px;
  }
  body.svc-parent-page.custom-development-page .custom-stack-principles{
    grid-template-columns:1fr;
    gap:20px;
  }
  body.svc-parent-page.custom-development-page .custom-stack-principle,
  body.svc-parent-page.custom-development-page .custom-stack-principle:nth-child(2),
  body.svc-parent-page.custom-development-page .custom-stack-principle:last-child{
    grid-column:auto;
    border-right:0;
    padding-right:0;
  }
  body.svc-parent-page.custom-development-page .custom-stack-grid{
    grid-template-columns:1fr;
  }
}
@media (max-width:560px){
  body.svc-parent-page.custom-development-page .custom-stack-panel{
    padding:48px 28px;
  }
  body.svc-parent-page.custom-development-page .custom-stack-panel .home-section-title{
    font-size:clamp(30px, 3.6vw, 48px);
  }
  body.svc-parent-page.custom-development-page .custom-stack-panel .home-section-lede,
  body.svc-parent-page.custom-development-page .custom-stack-subtitle{
    font-size:18px;
  }
  body.svc-parent-page.custom-development-page .custom-stack-visual{
    min-height:210px;
    transform:scale(.78);
    transform-origin:center top;
    margin-bottom:-28px;
  }
  body.svc-parent-page.custom-development-page .custom-stack-principle-icon{
    width:58px;
    height:58px;
  }
  body.svc-parent-page.custom-development-page .custom-stack-chip-grid{
    grid-template-columns:1fr;
  }
}

/* Unified CTA and learn-more treatment */
.btn,
.site-nav .cta,
.mobile-menu .cta-m,
body.home .hero .btn,
body.home .hero .btn:is(.primary, .ghost, .dark, .svc-learn),
body.svc-parent-page .hero .btn,
body.svc-parent-page .hero .btn:is(.primary, .ghost, .dark),
body.svc-parent-page .parent-hero .btn,
body.svc-parent-page .parent-hero .btn:is(.primary, .ghost, .dark),
body.svc-parent-page.about-page .svc-hero .btn,
body.svc-parent-page.about-page .svc-hero .btn:is(.primary, .ghost, .dark),
body.home .cta-band .btn,
body.home .cta-band .btn:is(.primary, .ghost, .dark),
body.svc-parent-page .cta-band .btn,
body.svc-parent-page .cta-band .btn:is(.primary, .ghost, .dark),
body.svc-parent-page.about-page .page-cta.cta-band .btn,
body.svc-parent-page.about-page .page-cta.cta-band .btn:is(.primary, .ghost, .dark),
body.home .svc-learn,
body.svc-parent-page .svc-learn,
body.svc-parent-page .cyber-radar-primary,
body.svc-parent-page.cybersecurity-page .cyber-radar-primary{
  background:rgba(0,100,180,.38);
  color:#fff;
  border:0.5px solid transparent;
  box-shadow:none;
  transition:background .2s, border-color .2s, transform .18s, color .18s;
}
.site-nav .cta:is(:hover, :focus-visible),
.mobile-menu .cta-m:is(:hover, :focus-visible),
body.home .hero .btn:is(:hover, :focus-visible),
body.home .hero .btn:is(.primary, .ghost, .dark, .svc-learn):is(:hover, :focus-visible),
body.svc-parent-page .hero .btn:is(:hover, :focus-visible),
body.svc-parent-page .hero .btn:is(.primary, .ghost, .dark):is(:hover, :focus-visible),
body.svc-parent-page .parent-hero .btn:is(:hover, :focus-visible),
body.svc-parent-page .parent-hero .btn:is(.primary, .ghost, .dark):is(:hover, :focus-visible),
body.svc-parent-page.about-page .svc-hero .btn:is(:hover, :focus-visible),
body.svc-parent-page.about-page .svc-hero .btn:is(.primary, .ghost, .dark):is(:hover, :focus-visible),
body.home .cta-band .btn:is(:hover, :focus-visible),
body.home .cta-band .btn:is(.primary, .ghost, .dark):is(:hover, :focus-visible),
body.svc-parent-page .cta-band .btn:is(:hover, :focus-visible),
body.svc-parent-page .cta-band .btn:is(.primary, .ghost, .dark):is(:hover, :focus-visible),
body.svc-parent-page.about-page .page-cta.cta-band .btn:is(:hover, :focus-visible),
body.svc-parent-page.about-page .page-cta.cta-band .btn:is(.primary, .ghost, .dark):is(:hover, :focus-visible),
body.home .svc-learn:is(:hover, :focus-visible),
body.svc-parent-page .svc-learn:is(:hover, :focus-visible),
body.svc-parent-page .cyber-radar-primary:is(:hover, :focus-visible),
body.svc-parent-page.cybersecurity-page .cyber-radar-primary:is(:hover, :focus-visible){
  background:rgba(0,138,252,.28) !important;
  border-color:#008afc !important;
  color:#9cfac7 !important;
  transform:translateY(-1px);
  box-shadow:none;
  text-decoration:none;
}

/* Hero ghost buttons — match the Custom Development Explore services CTA.
   Placed after the unified .btn reset block to win the cascade. */
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page, .tribal-services-page, .public-safety-page) .parent-hero .btn.ghost,
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page) .hero .btn.ghost,
body.svc-parent-page.about-page .svc-hero .btn.ghost,
body.case-studies-page .case-study-hero .btn.ghost,
body.home .hero .btn.ghost{
  background:rgba(255,255,255,.78) !important;
  color:#031526 !important;
  border:1px solid rgba(255,255,255,.85) !important;
}
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page, .tribal-services-page, .public-safety-page) .parent-hero .btn.ghost:is(:hover, :focus-visible),
body.svc-parent-page:is(.cybersecurity-page, .custom-development-page) .hero .btn.ghost:is(:hover, :focus-visible),
body.svc-parent-page.about-page .svc-hero .btn.ghost:is(:hover, :focus-visible),
body.case-studies-page .case-study-hero .btn.ghost:is(:hover, :focus-visible),
body.home .hero .btn.ghost:is(:hover, :focus-visible){
  background:rgba(0,138,252,.28) !important;
  border-color:#008afc !important;
  color:#9cfac7 !important;
  transform:translateY(-1px);
  box-shadow:none;
  text-decoration:none;
}

@keyframes custom-live-pulse{
  0%{
    opacity:1;
    box-shadow:0 0 0 0 rgba(141,240,188,.45);
  }
  70%{
    opacity:.92;
    box-shadow:0 0 0 10px rgba(141,240,188,0);
  }
  100%{
    opacity:1;
    box-shadow:0 0 0 0 rgba(141,240,188,0);
  }
}
