/*
Theme Name: Vertex Agility
Theme URI: https://vertexagility.com
Author: Vertex Agility Ltd
Description: Custom theme for Vertex Agility global digital consultancy.
Version: 1.0
License: Private
Text Domain: vertex-agility
*/

/* ============================================================
   VERTEX AGILITY — GLOBAL STYLES
   ============================================================ */

:root{
  --vx-ink:#01051E;
  --vx-ink-2:#070B26;
  --vx-ink-3:#0B1030;
  --vx-line:rgba(29,240,122,0.10);
  --vx-line-2:rgba(29,240,122,0.22);
  --vx-text:#E6E9F5;
  --vx-mute:#9BA3C2;
  --vx-accent:#1DF07A;
  --vx-accent-soft:rgba(29,240,122,0.14);
  --vx-radius:6px;
  --vx-radius-lg:10px;
  --vx-container:1280px;
  --vx-section-pad:120px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--vx-ink);scrollbar-color:var(--vx-accent) transparent;scrollbar-width:thin}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--vx-accent);border-radius:10px;border:2px solid var(--vx-ink)}
::-webkit-scrollbar-thumb:hover{background:#88ffbb}
::-webkit-scrollbar-corner{background:transparent}
body{
  font-family:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;
  background:transparent;
  color:var(--vx-text);
  line-height:1.55;
  font-weight:400;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background-image:
    linear-gradient(var(--vx-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--vx-line) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at 50% 50%, #000 25%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%, #000 25%, transparent 80%);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ─── Type scale ─────────────────────────────────────────────────────── */
.eyebrow{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--vx-accent);
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-weight:500;
}
.eyebrow::before{
  content:"";width:28px;height:1px;background:var(--vx-accent);
}
.mono{font-family:"JetBrains Mono",monospace}

h1,h2,h3,h4{font-family:"JetBrains Mono",monospace;font-weight:600;letter-spacing:-0.04em;line-height:1.02}
h1{
  font-size:clamp(46px,7vw,104px);
  font-weight:700;
  letter-spacing:-0.05em;
}
h2{
  font-size:clamp(30px,4vw,54px);
  font-weight:600;
  letter-spacing:-0.045em;
  line-height:1.05;
}
h3{font-size:clamp(20px,2vw,26px);font-weight:600;letter-spacing:-0.03em;line-height:1.2}
h4{font-size:17px;font-weight:600;letter-spacing:-0.02em;line-height:1.3;font-family:"JetBrains Mono",monospace}
p{color:var(--vx-mute);font-size:16px;line-height:1.7}
.lead{font-size:19px;line-height:1.6;color:var(--vx-text);font-weight:300}

.highlight{
  background:linear-gradient(110deg,
    var(--vx-accent) 0%,
    var(--vx-accent) 38%,
    #e8ffef 50%,
    var(--vx-accent) 62%,
    var(--vx-accent) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  position:relative;
  animation:highlight-shine 3.5s linear infinite;
}
@keyframes highlight-shine{
  0%{background-position:0% center}
  100%{background-position:200% center}
}
.bracket-tag{
  font-family:"JetBrains Mono",monospace;
  color:var(--vx-accent);
  font-weight:500;
  opacity:.8;
}

/* ─── Layout helpers ─────────────────────────────────────────────────── */
.container{max-width:var(--vx-container);margin:0 auto;padding:0 32px}
.section{padding:var(--vx-section-pad) 0;position:relative}
.divider{display:none}

/* ─── Buttons ────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;font-weight:600;font-size:13px;
  border-radius:4px;
  transition:all .25s cubic-bezier(.2,.7,.2,1);
  letter-spacing:0.02em;
  font-family:"JetBrains Mono",monospace;
  text-transform:uppercase;
}
.btn--primary{background:var(--vx-accent);color:#01051E}
.btn--primary:hover{background:#3aff95;box-shadow:0 0 32px rgba(29,240,122,0.4);transform:translateY(-2px)}
.btn--ghost{background:var(--vx-ink);color:var(--vx-text);border:1px solid var(--vx-line-2)}
.btn--ghost:hover{border-color:var(--vx-accent);color:var(--vx-accent)}
.btn .arrow{display:inline-flex;transition:transform .25s cubic-bezier(.2,.7,.2,1);font-size:14px}
.btn:hover .arrow{transform:translateX(4px)}

/* ─── Header ─────────────────────────────────────────────────────────── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:18px 0;
  background:rgba(1,5,30,0.78);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--vx-line);
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center}
.logo img{display:block;height:38px;width:auto}
.nav{display:flex;gap:32px;align-items:center}
.nav a{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--vx-mute);transition:color .25s;letter-spacing:0.04em;text-transform:uppercase;font-weight:500}
.nav a:hover{color:var(--vx-accent)}
.site-header .btn{padding:10px 18px;font-size:11px}

/* ─── Hero ───────────────────────────────────────────────────────────── */
.hero{
  padding:200px 0 120px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(900px 500px at 80% 0%, rgba(29,240,122,0.10), transparent 60%),
    radial-gradient(700px 400px at 10% 90%, rgba(29,240,122,0.06), transparent 60%);
}
.hero::after{
  content:"";
  position:absolute;inset:0;
  background:repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(255,255,255,0.012) 3px, rgba(255,255,255,0.012) 4px);
  pointer-events:none;
  z-index:1;
}
.hero__inner{position:relative}
.hero__top{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:32px;flex-wrap:wrap}
.hero h1{max-width:18ch;min-height:2.04em}
.hero h1 .cursor{
  display:inline-block;
  width:0.55ch;height:0.85em;
  background:var(--vx-accent);
  vertical-align:-0.05em;
  margin-left:0.1em;
  animation:blink 1s ease-in-out infinite;
  box-shadow:0 0 18px rgba(29,240,122,0.7);
}
@keyframes blink{0%,40%{opacity:1}50%,90%{opacity:0}100%{opacity:1}}
.hero__sub{max-width:540px;font-size:17px;color:var(--vx-mute);line-height:1.7}
.hero__actions{display:flex;gap:14px;margin-top:48px;flex-wrap:wrap}
.hero__terminal{
  margin-top:32px;
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  border-radius:4px;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  color:var(--vx-mute);
}
.hero__terminal .prompt{color:var(--vx-accent)}

.hero__stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  margin-top:120px;
  border-top:1px solid var(--vx-line-2);
  border-bottom:1px solid var(--vx-line-2);
}
.stat{padding:32px 28px;border-right:1px solid var(--vx-line);position:relative;background:var(--vx-ink)}
.stat:last-child{border-right:0}
.stat::before{
  content:"";
  position:absolute;top:32px;left:28px;
  width:6px;height:6px;background:var(--vx-accent);
  box-shadow:0 0 12px var(--vx-accent);
  border-radius:1px;
}
.stat__num{
  font-family:"JetBrains Mono",monospace;
  font-size:54px;font-weight:700;letter-spacing:-0.05em;
  line-height:1;color:var(--vx-text);
  margin-top:24px;
}
.stat__num sup{font-size:22px;color:var(--vx-accent);vertical-align:super;font-weight:600;margin-left:2px}
.stat__label{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--vx-mute);margin-top:14px;font-weight:500;
}

/* ─── Trust ticker ───────────────────────────────────────────────────── */
.trust{padding:48px 0}
.trust__label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--vx-mute);margin-bottom:32px;font-weight:500}
.ticker__viewport{overflow:hidden;mask-image:linear-gradient(to right,transparent 0,#000 64px,#000 calc(100% - 64px),transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,#000 64px,#000 calc(100% - 64px),transparent 100%)}

/* Technology partners (inside hero, above stats bar) */
.partners{margin-top:64px;text-align:center}
.partners__label{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--vx-mute);margin-bottom:28px;font-weight:500}
.partners__row{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:32px 64px;
}
.partners__row img{
  height:36px;width:auto;display:block;
  opacity:.85;transition:opacity .3s;
}
.partners__row img:hover{opacity:1}
@media(max-width:720px){
  .partners__row{gap:24px 40px}
  .partners__row img{height:28px}
}
.ticker__track{
  display:flex;align-items:center;gap:80px;
  width:max-content;
  will-change:transform;
  cursor:grab;
  user-select:none;
}
.ticker__track img{height:40px;width:auto;flex-shrink:0;display:block;opacity:.85;transition:opacity .3s;pointer-events:none}
.ticker__track img:hover{opacity:1}

/* ─── Section header ─────────────────────────────────────────────────── */
.section-head{display:grid;grid-template-columns:1fr 0.95fr;gap:80px;align-items:end;margin-bottom:64px}
.section-head:last-child{margin-bottom:0}
.section-head__title h2{max-width:14ch}
.section-head__intro p{font-size:17px;line-height:1.7}
.section-head--alt{grid-template-columns:0.95fr 1fr;align-items:start;grid-template-rows:auto auto;row-gap:24px}
.section-head--alt .section-head__title{display:contents}
.section-head--alt .section-head__title>.eyebrow{grid-column:1/-1;grid-row:1;margin-bottom:0!important}
.section-head--alt .section-head__title>h2{grid-column:2;grid-row:2;max-width:none;text-align:right}
.section-head--alt .section-head__intro{grid-column:1;grid-row:2;align-self:start}

/* ─── Specialism cards ───────────────────────────────────────────────── */
.specs{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius-lg);
  overflow:hidden;
}
.spec{
  background:var(--vx-ink-2);
  padding:48px 40px;
  position:relative;
  transition:background .4s ease, transform .25s cubic-bezier(.2,.7,.2,1);
  display:flex;flex-direction:column;
  min-height:340px;
}
.spec:hover{background:#0C1239;transform:perspective(900px) rotateY(var(--tx,0deg)) rotateX(var(--ty,0deg))}
@media(prefers-reduced-motion:reduce){.spec:hover{transform:none}}
.spec__head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:36px}
.spec__num{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;color:var(--vx-mute);letter-spacing:0.1em;
  font-weight:500;
}
.spec__num b{color:var(--vx-accent);font-weight:500}
.spec__icon{
  width:48px;height:48px;border-radius:8px;
  background:var(--vx-accent-soft);
  border:1px solid var(--vx-line-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--vx-accent);
}
.spec__icon svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.spec__icon svg path,
.spec__icon svg circle,
.spec__icon svg ellipse{
  stroke-dasharray:300;
  stroke-dashoffset:0;
}
@keyframes spec-icon-redraw{from{stroke-dashoffset:300}to{stroke-dashoffset:0}}
.spec:hover .spec__icon svg path,
.spec:hover .spec__icon svg circle,
.spec:hover .spec__icon svg ellipse{
  animation:spec-icon-redraw 1.8s cubic-bezier(.65,0,.35,1);
}
@media(prefers-reduced-motion:reduce){
  .spec:hover .spec__icon svg path,
  .spec:hover .spec__icon svg circle,
  .spec:hover .spec__icon svg ellipse{animation:none}
}
.spec h3{margin-bottom:14px}
.spec p{font-size:15px;flex:1}
@keyframes spec-jiggle{
  0%,100%{transform:translateX(0) rotate(0)}
  20%{transform:translateX(-5px) rotate(-2deg)}
  40%{transform:translateX(5px) rotate(2deg)}
  60%{transform:translateX(-3px) rotate(-1deg)}
  80%{transform:translateX(2px) rotate(.5deg)}
}
.spec:hover .spec__link,
.proc:hover .spec__link,
.value-card:hover .spec__link{animation:spec-jiggle .4s ease-in-out}
@media(prefers-reduced-motion:reduce){.spec:hover .spec__link,.proc:hover .spec__link,.value-card:hover .spec__link{animation:none}}

.spec h3 a,.proc h4 a{color:inherit;text-decoration:none;transition:color .2s}
.spec h3 a:hover,.proc h4 a:hover{color:var(--vx-accent)}

.spec__link{
  display:inline-flex;align-items:center;gap:16px;
  font-family:"JetBrains Mono",monospace;font-size:12px;
  font-weight:600;color:var(--vx-text);margin-top:24px;
  letter-spacing:0.06em;text-transform:uppercase;
}
.spec__link::after{content:"→";transition:transform .3s;color:var(--vx-accent)}
.spec:hover .spec__link::after{transform:translateX(4px)}

/* ─── Process ────────────────────────────────────────────────────────── */
.process{
  position:relative;
}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.process-grid::before{
  content:"";
  position:absolute;
  top:64px;left:5%;right:5%;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--vx-line-2) 14%, var(--vx-accent) 50%, var(--vx-line-2) 86%, transparent);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform 1.6s cubic-bezier(.65,0,.35,1) .15s;
}
.process-grid.is-in::before{transform:scaleX(1)}
@media(prefers-reduced-motion:reduce){
  .process-grid::before{transform:none;transition:none}
}
.proc{
  padding:36px 28px;
  display:flex;flex-direction:column;
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);
  background:var(--vx-ink-2);
  position:relative;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), border-color .4s, box-shadow .4s, background .4s;
}
.proc::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--vx-accent),transparent);
  opacity:0;transition:opacity .4s;
}
.proc:hover{
  transform:translateY(-6px);
  border-color:var(--vx-accent);
  box-shadow:0 0 40px rgba(29,240,122,0.15);
  background:#0C1239;
}
.proc:hover::before{opacity:1}
.proc__step{
  font-family:"JetBrains Mono",monospace;
  font-size:14px;
  font-weight:600;
  color:var(--vx-accent);
  letter-spacing:0.1em;
  display:inline-block;
  padding:6px 12px;
  background:var(--vx-accent-soft);
  border-radius:4px;
  margin-bottom:24px;
  transition:background .35s;
}
.proc:hover .proc__step{background:rgba(29,240,122,.22)}
.proc h4{margin-bottom:12px;font-size:18px}
.proc p{font-size:14px;line-height:1.65;flex:1}
.proc .spec__link{margin-top:24px}

/* ─── Vision quote ───────────────────────────────────────────────────── */
.vision{
  text-align:center;
  padding:160px 0;
  position:relative;
  overflow:hidden;
}
.vision::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px 400px at 50% 50%, rgba(29,240,122,0.06), transparent 60%);
  pointer-events:none;
}
.vision__inner{max-width:1000px;margin:0 auto;padding:0 32px;position:relative}
.vision .eyebrow{justify-content:center;margin-bottom:36px}
.vision blockquote{
  font-family:"JetBrains Mono",monospace;
  font-size:clamp(28px,3.6vw,46px);
  font-weight:500;
  line-height:1.25;
  letter-spacing:-0.035em;
  color:var(--vx-text);
}
.vision blockquote .highlight{color:var(--vx-accent);font-weight:600}
.vision blockquote .quote-mark{color:var(--vx-accent);opacity:.5;font-size:1.2em;line-height:0;vertical-align:-0.15em}
.vision__attr{
  margin-top:40px;color:var(--vx-mute);font-size:11px;
  letter-spacing:0.2em;text-transform:uppercase;
  font-family:"JetBrains Mono",monospace;font-weight:500;
}

/* ─── Case studies ───────────────────────────────────────────────────── */
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.case{
  background:var(--vx-ink-2);
  border-radius:var(--vx-radius-lg);
  overflow:hidden;
  border:1px solid var(--vx-line-2);
  display:flex;flex-direction:column;
  position:relative;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), border-color .4s;
}
.case:hover{transform:perspective(900px) rotateY(var(--tx,0deg)) rotateX(var(--ty,0deg)) translateY(-6px);border-color:var(--vx-accent)}
@media(prefers-reduced-motion:reduce){.case:hover{transform:translateY(-6px)}}
.case__img{
  height:220px;
  position:relative;
  overflow:hidden;
  background:var(--vx-ink-3);
}
.case__img--insurance::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(180deg, rgba(1,5,30,0.15) 0%, rgba(1,5,30,0.40) 55%, rgba(1,5,30,0.82) 100%),
    radial-gradient(circle at 30% 30%, rgba(29,240,122,0.16), transparent 55%),
    url("../../uploads/2022/05/case-failing-software.jpeg");
  background-size:auto, auto, cover;
  background-position:center, center, center;
  background-repeat:no-repeat;
}
.case__img--insurance::after{opacity:0.18}
[data-theme="light"] .case__img--insurance .case__tag{
  background:rgba(1,5,30,0.85);
  color:var(--vx-accent);
  border-color:var(--vx-line-2);
}
.case__img--cloud::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(180deg, rgba(1,5,30,0.15) 0%, rgba(1,5,30,0.40) 55%, rgba(1,5,30,0.82) 100%),
    radial-gradient(circle at 70% 30%, rgba(29,240,122,0.18), transparent 55%),
    url("../../uploads/2022/05/AdobeStock_272426823.jpeg");
  background-size:auto, auto, cover;
  background-position:center, center, center;
  background-repeat:no-repeat;
}
/* Soften the grid overlay so it doesn't fight the photo. */
.case__img--cloud::after{opacity:0.18}
/* Light mode usually fades the case tag; keep it strong over the photo. */
[data-theme="light"] .case__img--cloud .case__tag{
  background:rgba(1,5,30,0.85);
  color:var(--vx-accent);
  border-color:var(--vx-line-2);
}
.case__img--data::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(180deg, rgba(1,5,30,0.15) 0%, rgba(1,5,30,0.40) 55%, rgba(1,5,30,0.82) 100%),
    radial-gradient(circle at 70% 30%, rgba(29,240,122,0.16), transparent 55%),
    url("../../uploads/2022/05/case-data-bottlenecks.jpeg");
  background-size:auto, auto, cover;
  background-position:center, center, center;
  background-repeat:no-repeat;
}
.case__img--data::after{opacity:0.18}
[data-theme="light"] .case__img--data .case__tag{
  background:rgba(1,5,30,0.85);
  color:var(--vx-accent);
  border-color:var(--vx-line-2);
}
.case__img::after{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(var(--vx-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--vx-line) 1px, transparent 1px);
  background-size:24px 24px;
  opacity:.5;
}
.case__tag{
  position:absolute;top:20px;left:20px;
  font-family:"JetBrains Mono",monospace;font-size:10px;
  letter-spacing:0.16em;text-transform:uppercase;font-weight:600;
  background:rgba(1,5,30,0.85);color:var(--vx-accent);
  padding:6px 12px;border-radius:3px;border:1px solid var(--vx-line-2);
  z-index:2;
}
.case__metric{
  position:absolute;bottom:20px;left:24px;
  font-family:"JetBrains Mono",monospace;font-size:48px;line-height:1;
  color:#fff;letter-spacing:-0.05em;font-weight:700;
  z-index:2;
}
.case__metric small{
  font-size:10px;font-family:"JetBrains Mono",monospace;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--vx-mute);display:block;margin-top:8px;font-weight:500;
}
.case__body{padding:32px;flex:1;display:flex;flex-direction:column}
.case h3{font-size:20px;margin-bottom:12px;line-height:1.3}
.case__title-link{color:inherit;transition:color .2s}
.case__title-link:hover,.case__title-link:focus-visible{color:var(--vx-accent)}
.case p{font-size:14px;flex:1}
.cases__cta{display:flex;justify-content:center;margin-top:48px}
.case__link{
  margin-top:20px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--vx-text);display:inline-flex;gap:16px;
  transition:color .2s;
}
.case__link::after{content:"→";color:var(--vx-accent);transition:transform .3s}
.case:hover .case__link::after,
.case__link:hover::after,
.case__link:focus-visible::after{transform:translateX(4px)}
.case__link:hover,.case__link:focus-visible{color:var(--vx-accent)}

/* ─── Global reach ───────────────────────────────────────────────────── */
.reach{display:grid;grid-template-columns:0.95fr 1fr;gap:80px;align-items:center}
.reach__visual{
  aspect-ratio:1;
  position:relative;
  border:1px solid var(--vx-line-2);
  border-radius:50%;
  background:radial-gradient(circle at center, rgba(29,240,122,0.08), transparent 70%);
}
.reach__visual::before,.reach__visual::after{
  content:"";position:absolute;inset:0;
  border:1px dashed var(--vx-line-2);border-radius:50%;
}
.reach__visual::before{inset:14%;animation:ring-spin 48s linear infinite}
.reach__visual::after{inset:30%;border-style:solid;animation:ring-spin 12s linear infinite reverse}
@keyframes ring-spin{to{transform:rotate(360deg)}}
.reach__core{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:112px;height:112px;border-radius:50%;
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 80px rgba(29,240,122,0.5), 0 0 24px rgba(29,240,122,0.7);
  font-family:"JetBrains Mono",monospace;
  font-size:22px;font-weight:700;color:#01051E;letter-spacing:-0.03em;
}
.reach__orbit{
  position:absolute;inset:0;border-radius:50%;
  animation:ring-spin linear infinite;
}
.reach__orbit--1{inset:4%;animation-duration:38s;animation-delay:-5s}
.reach__orbit--2{inset:10%;animation-duration:15s;animation-delay:-3s}
.reach__orbit--3{inset:16%;animation-duration:50s;animation-delay:-20s}
.reach__orbit--4{inset:22%;animation-duration:22s;animation-delay:-7s}
.reach__orbit--5{inset:28%;animation-duration:12s;animation-delay:-4s}
.reach__orbit--6{inset:30%;animation-duration:32s;animation-delay:-15s}
.reach__dot{
  position:absolute;width:10px;height:10px;border-radius:50%;
  top:0;left:50%;margin:-5px 0 0 -5px;
  background:var(--vx-accent);
  box-shadow:0 0 14px var(--vx-accent);
  animation:pulse 3s ease-in-out infinite;
}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}}
.reach__list{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px 24px;
  margin-top:36px;
  border-top:1px solid var(--vx-line);padding-top:28px;
}
.reach__list li{
  list-style:none;font-size:13px;color:var(--vx-mute);
  font-family:"JetBrains Mono",monospace;letter-spacing:0.04em;font-weight:500;
}
.reach__list li::before{content:"▸ ";color:var(--vx-accent);margin-right:4px}

/* ─── Assessment page — full cards with screenshot previews ──────────── */
.assess-full{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius);
  overflow:hidden;margin-top:48px;
}
.assess-full__card{
  background:var(--vx-ink-3);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:background .3s;
}
.assess-full__card:hover{background:#0c1030}
.assess-full__preview{
  width:100%;aspect-ratio:16/9;
  overflow:hidden;border-bottom:1px solid var(--vx-line-2);
}
.assess-full__preview img{
  width:100%;height:100%;
  object-fit:cover;object-position:top center;
  display:block;transition:transform .5s ease;
}
.assess-full__card:hover .assess-full__preview img{transform:scale(1.04)}
.assess-full__body{
  padding:36px 32px 40px;flex:1;
  display:flex;flex-direction:column;
}
.assess-full__id{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;color:var(--vx-accent);letter-spacing:0.16em;
  font-weight:600;text-transform:uppercase;margin-bottom:16px;
}
.assess-full__card h3{font-size:20px;margin-bottom:14px;line-height:1.25}
.assess-full__card p{font-size:15px;color:var(--vx-mute);line-height:1.7;flex:1}
.assess-full__card .btn{margin-top:28px;align-self:flex-start}
@media(max-width:760px){.assess-full{grid-template-columns:1fr}}

/* ─── Contact page ───────────────────────────────────────────────────── */
.contact-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;margin-top:64px;
}
.contact-info__item{
  display:flex;flex-direction:column;gap:6px;
  padding:28px 0;border-bottom:1px solid var(--vx-line-2);
}
.contact-info__item:first-child{padding-top:0}
.contact-info__item:last-child{border-bottom:0}
.contact-info__label{
  font-family:"JetBrains Mono",monospace;font-size:11px;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--vx-accent);
}
.contact-info__value{font-size:15px;color:var(--vx-text);line-height:1.6}
.contact-info__value a{color:var(--vx-text);text-decoration:underline;text-underline-offset:3px}
.contact-info__value a:hover{color:var(--vx-accent)}
.contact-why{margin-top:48px;display:flex;flex-direction:column;gap:0}
.contact-why__item{
  padding:24px 0;border-bottom:1px solid var(--vx-line-2);
  display:flex;flex-direction:column;gap:8px;
}
.contact-why__item:last-child{border-bottom:0}
.contact-why__title{
  font-family:"JetBrains Mono",monospace;font-size:13px;
  font-weight:600;color:var(--vx-text);
}
.contact-why__text{font-size:14px;color:var(--vx-mute);line-height:1.7}
.form-placeholder{
  background:var(--vx-ink-3);border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);padding:48px 40px;
}
.form-placeholder__note{
  font-family:"JetBrains Mono",monospace;font-size:11px;
  color:var(--vx-accent);letter-spacing:0.14em;text-transform:uppercase;
  margin-bottom:32px;
}
@media(max-width:900px){.contact-layout{grid-template-columns:1fr;gap:48px}}

/* ─── Newsletter page ────────────────────────────────────────────────── */
.newsletter-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;margin-top:64px;
}
.newsletter-benefits{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:0}
.newsletter-benefits li{
  padding:18px 0;border-bottom:1px solid var(--vx-line-2);
  font-size:15px;color:var(--vx-mute);line-height:1.6;
  display:flex;gap:14px;align-items:flex-start;
}
.newsletter-benefits li:last-child{border-bottom:0}
.newsletter-benefits li::before{
  content:"→";font-family:"JetBrains Mono",monospace;
  color:var(--vx-accent);flex-shrink:0;margin-top:2px;
}
@media(max-width:900px){.newsletter-layout{grid-template-columns:1fr;gap:48px}}

/* ─── Assessments ────────────────────────────────────────────────────── */
.assess{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.assess__card{
  padding:40px 32px;
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);
  background:var(--vx-ink-2);
  transition:border-color .35s, transform .35s, box-shadow .35s;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.assess__card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--vx-accent), transparent);
  opacity:0;transition:opacity .35s;
}
.assess__card:hover{
  border-color:var(--vx-accent);
  transform:translateY(-4px);
  box-shadow:0 0 40px rgba(29,240,122,0.10);
}
.assess__card:hover::before{opacity:1}
.assess__id{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;color:var(--vx-accent);letter-spacing:0.16em;
  font-weight:600;text-transform:uppercase;margin-bottom:18px;
}
.assess__card h4{margin-bottom:12px;font-size:18px}
.assess__card p{font-size:14px;flex:1}
.assess__card .btn{margin-top:28px;align-self:flex-start;padding:11px 16px;font-size:11px}

/* ─── CTA ────────────────────────────────────────────────────────────── */
.cta{
  text-align:center;
  padding:140px 0;
  position:relative;
  overflow:hidden;
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 400px at 50% 50%, rgba(29,240,122,0.12), transparent 65%);
  pointer-events:none;
}
.cta__inner{position:relative;z-index:2;max-width:900px;margin:0 auto;padding:0 32px}
.cta h2{margin-bottom:32px}
.cta h2 .highlight{color:var(--vx-accent)}
.cta__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:32px}

/* ─── Office location cards ──────────────────────────────────────────── */
.location-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius);overflow:hidden;
}
.location-card{
  background:var(--vx-ink-3);padding:28px 24px;
  position:relative;overflow:hidden;
  transition:background .3s;
}
.location-card:hover{background:#0c1030}
.location-card__country{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;font-weight:600;color:var(--vx-accent);
  letter-spacing:0.12em;text-transform:uppercase;margin-bottom:12px;
  display:flex;align-items:center;gap:8px;
}
.location-card__country::before{
  content:"";width:18px;height:1px;background:var(--vx-accent);flex-shrink:0;
}
.location-card__address{
  font-size:14px;color:var(--vx-mute);line-height:1.65;
}
@media(max-width:960px){.location-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.location-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:400px){.location-grid{grid-template-columns:1fr}}

/* ─── Footer ─────────────────────────────────────────────────────────── */
.footer{background:#000311;padding:80px 0 32px;border-top:1px solid var(--vx-line-2);position:relative;z-index:2}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px}
.footer__brand p{font-size:14px;margin-top:18px;max-width:34ch}
.footer__col h5{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--vx-accent);margin-bottom:20px;font-weight:600;
}
.footer__col ul{list-style:none}
.footer__col li{margin-bottom:10px}
.footer__col a{font-size:14px;color:var(--vx-mute);transition:color .25s}
.footer__col a:hover{color:var(--vx-text)}
.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:32px;border-top:1px solid var(--vx-line);
  font-family:"JetBrains Mono",monospace;
  font-size:12px;color:var(--vx-mute);flex-wrap:wrap;gap:16px;letter-spacing:0.04em;
}
.footer__bottom a{color:var(--vx-mute)}
.footer__bottom a:hover{color:var(--vx-accent)}
.footer__bottom .status{display:inline-flex;align-items:center;gap:8px}
.footer__bottom .status::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--vx-accent);box-shadow:0 0 10px var(--vx-accent);
  animation:pulse 2s ease-in-out infinite;
}

/* ─── Responsive ─────────────────────────────────────────────────────── */
@media (max-width:960px){
  :root{--vx-section-pad:80px}
  .nav{display:none}
  .hero{padding:160px 0 80px}
  .hero__stats{grid-template-columns:repeat(2,1fr)}
  .stat{border-right:0;border-bottom:1px solid var(--vx-line)}
  .stat:nth-child(odd){border-right:1px solid var(--vx-line)}
  .stat:nth-last-child(-n+2){border-bottom:0}
  .section-head{grid-template-columns:1fr;gap:24px}
  .section-head--alt .section-head__title>.eyebrow,.section-head--alt .section-head__title>h2,.section-head--alt .section-head__intro{grid-column:auto;grid-row:auto}
  .specs{grid-template-columns:1fr}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid::before{display:none}
  .cases{grid-template-columns:1fr}
  .reach{grid-template-columns:1fr;gap:48px}
  .reach__list{grid-template-columns:repeat(2,1fr)}
  .assess{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width:560px){
  .hero__stats{grid-template-columns:1fr}
  .stat{border-right:0!important;border-bottom:1px solid var(--vx-line)}
  .stat:last-child{border-bottom:0}
  .process-grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
}

/* ─── Cursor-tracked glow on card hovers ─────────────────────────────── */
.spec::after,
.case::after,
.proc::after,
.assess-full__card::after,
.value-card::after,
.svc-card::after,
.location-card::after,
.team-card::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(320px circle at var(--mx,50%) var(--my,50%), rgba(29,240,122,0.14), transparent 45%);
  opacity:0;transition:opacity .35s ease;
  pointer-events:none;border-radius:inherit;z-index:0;
}
.spec:hover::after,
.case:hover::after,
.proc:hover::after,
.assess-full__card:hover::after,
.value-card:hover::after,
.svc-card:hover::after,
.location-card:hover::after,
.team-card:hover::after{opacity:1}
.spec>*,
.proc>*,
.value-card>*,
.svc-card>*,
.location-card>*,
.team-card>*{position:relative;z-index:1}
/* Image-led cards: lift glow above content via screen blend so it brightens the photo */
.case::after,
.assess-full__card::after{
  background:radial-gradient(360px circle at var(--mx,50%) var(--my,50%), rgba(29,240,122,0.18), transparent 45%);
  mix-blend-mode:screen;z-index:3;
}
@media(prefers-reduced-motion:reduce){
  .spec::after,.case::after,.proc::after,.assess-full__card::after,
  .value-card::after,.svc-card::after,.location-card::after,.team-card::after{display:none}
}

/* ─── Reveal on scroll ───────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.is-in{opacity:1;transform:none}
/* Grid containers reveal children individually — don't fade the wrapper */
.process-grid.reveal,.value-grid.reveal,.specs.reveal,.cases.reveal,.location-grid.reveal{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none}
  .reach__dot,.reach__orbit,.hero h1 .cursor,.footer__bottom .status::before,.highlight,.reach__visual::before,.reach__visual::after{animation:none}
}

/* ─── Grid child stagger ─────────────────────────────────────────────── */
.process-grid .proc,
.value-grid .value-card,
.specs .spec,
.cases .case,
.location-grid .location-card{
  opacity:0;transform:translateY(20px);
  transition:opacity .65s cubic-bezier(.2,.7,.2,1),transform .65s cubic-bezier(.2,.7,.2,1),
             border-color .4s,box-shadow .4s,background .4s;
}
.process-grid.is-in .proc,
.value-grid.is-in .value-card,
.specs.is-in .spec,
.cases.is-in .case,
.location-grid.is-in .location-card{opacity:1;transform:none}
/* stagger delays */
.process-grid.is-in .proc:nth-child(2),.value-grid.is-in .value-card:nth-child(2),.specs.is-in .spec:nth-child(2),.cases.is-in .case:nth-child(2){transition-delay:.1s}
.process-grid.is-in .proc:nth-child(3),.value-grid.is-in .value-card:nth-child(3),.specs.is-in .spec:nth-child(3),.cases.is-in .case:nth-child(3){transition-delay:.2s}
.process-grid.is-in .proc:nth-child(4),.value-grid.is-in .value-card:nth-child(4),.specs.is-in .spec:nth-child(4){transition-delay:.3s}
.location-grid.is-in .location-card:nth-child(2){transition-delay:.05s}
.location-grid.is-in .location-card:nth-child(3){transition-delay:.1s}
.location-grid.is-in .location-card:nth-child(4){transition-delay:.15s}
.location-grid.is-in .location-card:nth-child(5){transition-delay:.2s}
.location-grid.is-in .location-card:nth-child(6){transition-delay:.25s}
.location-grid.is-in .location-card:nth-child(7){transition-delay:.3s}
.location-grid.is-in .location-card:nth-child(8){transition-delay:.35s}
.location-grid.is-in .location-card:nth-child(9){transition-delay:.4s}
.location-grid.is-in .location-card:nth-child(10){transition-delay:.45s}
.location-grid.is-in .location-card:nth-child(11){transition-delay:.5s}
.location-grid.is-in .location-card:nth-child(12){transition-delay:.55s}

/* ─── Ambient orb ────────────────────────────────────────────────────── */
/* Raise page content above the orb (z-index:1) so its blend mode only touches the background */
section,main,footer,.partners-bar,.trust,.ticker__track{position:relative;z-index:2}

.orb{
  position:fixed;border-radius:50%;pointer-events:none;
  z-index:1;filter:blur(100px);mix-blend-mode:screen;will-change:transform;
}
.orb--1{
  width:900px;height:900px;
  top:calc(50% - 450px);left:calc(50% - 450px);
  background:radial-gradient(circle at center, rgba(29,240,122,0.8) 0%, rgba(29,240,122,0.22) 35%, transparent 67%);
  animation:orb-float-1 16s ease-in-out infinite;
}
@keyframes orb-float-1{
  0%,100%{transform:translate(0,0)}
  33%{transform:translate(-200px,-160px)}
  66%{transform:translate(180px,130px)}
}
@media(prefers-reduced-motion:reduce){.orb{display:none}}

/* ─── Hero terminal scanline ─────────────────────────────────────────── */
.hero__terminal{position:relative;overflow:hidden}
.hero__terminal::after{
  content:'';position:absolute;inset:0 0 auto 0;height:35%;
  background:linear-gradient(transparent,rgba(29,240,122,.05),transparent);
  animation:terminal-scan 6s linear infinite;pointer-events:none;
}
@keyframes terminal-scan{from{transform:translateY(-100%)}to{transform:translateY(350%)}}
@media(prefers-reduced-motion:reduce){.hero__terminal::after{display:none}}

/* ─── Header right cluster ───────────────────────────────────────────── */
.header-right{display:flex;align-items:center;gap:16px}

/* ─── Burger button ──────────────────────────────────────────────────── */
.burger{
  display:flex;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
  width:36px;height:36px;padding:4px;border-radius:4px;
  background:none;border:none;cursor:pointer;
}
.burger span{
  display:block;width:22px;height:2px;
  background:var(--vx-accent);border-radius:1px;
  transition:transform .3s cubic-bezier(.2,.7,.2,1),opacity .3s;
}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@keyframes burger-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(29,240,122,0)}
  50%{box-shadow:0 0 0 6px rgba(29,240,122,.25)}
}
.burger:not(.is-open){animation:burger-pulse 2.4s ease-in-out infinite}

@media(max-width:960px){
  .header-cta{display:none}
  /* Strip the header bar — only the burger floats */
  .site-header{
    background:transparent;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    border-bottom-color:transparent;
    padding:14px 0;
  }
  .site-header .logo{display:none}
  .site-header__inner{justify-content:flex-end}
  /* Give the burger a subtle dark pill so it stays legible over any content */
  .burger{
    background:rgba(1,5,30,.55);
    border-radius:8px;
    padding:8px 10px;
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
  }
}

/* ─── Mobile navigation ──────────────────────────────────────────────── */
.mobile-nav{
  position:fixed;inset:0;z-index:150;
  visibility:hidden;pointer-events:none;
}
.mobile-nav.is-open{visibility:visible;pointer-events:all}

.mobile-nav__backdrop{
  position:absolute;inset:0;
  background:rgba(1,5,30,.78);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;transition:opacity .4s;
}
.mobile-nav.is-open .mobile-nav__backdrop{opacity:1}

.mobile-nav__panel{
  position:absolute;top:0;right:0;bottom:0;
  width:min(400px,92vw);
  background:var(--vx-ink-2);
  border-left:1px solid var(--vx-line-2);
  transform:translateX(100%);
  transition:transform .4s cubic-bezier(.2,.7,.2,1);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.mobile-nav.is-open .mobile-nav__panel{transform:none}

.mobile-nav__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;
  border-bottom:1px solid var(--vx-line);
  flex-shrink:0;
}

.mobile-nav__close{
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  color:var(--vx-mute);font-size:18px;border-radius:4px;
  transition:color .2s,background .2s;
}
.mobile-nav__close:hover{color:var(--vx-accent);background:var(--vx-accent-soft)}

.mobile-nav__links{flex:1;overflow-y:auto;padding-bottom:8px}

.mobile-nav__item{border-bottom:1px solid var(--vx-line)}

.mobile-nav__link,
.mobile-nav__toggle{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:15px 20px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  color:var(--vx-text);
  transition:color .2s;
  text-align:left;
}
.mobile-nav__link:hover,.mobile-nav__toggle:hover{color:var(--vx-accent)}

.mobile-nav__toggle::after{
  content:"+";color:var(--vx-accent);
  font-size:20px;font-weight:300;line-height:1;
  transition:transform .3s cubic-bezier(.2,.7,.2,1);
  display:inline-block;
}
.mobile-nav__toggle.is-open::after{transform:rotate(45deg)}

.mobile-nav__item--has-sub{display:flex;flex-wrap:wrap;align-items:stretch}
.mobile-nav__item--has-sub>.mobile-nav__link{flex:1;padding-right:0}
.mobile-nav__item--has-sub>.mobile-nav__sub{width:100%}
.mobile-nav__expand{
  flex-shrink:0;width:48px;
  display:flex;align-items:center;justify-content:center;
  border-left:1px solid var(--vx-line);
  color:var(--vx-accent);font-size:20px;font-weight:300;line-height:1;
  transition:transform .3s cubic-bezier(.2,.7,.2,1),color .2s;
}
.mobile-nav__expand:hover{color:#fff}
.mobile-nav__expand span{display:inline-block;transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.mobile-nav__expand.is-open span{transform:rotate(45deg)}

.mobile-nav__sub{
  display:none;
  background:rgba(1,5,30,.45);
  border-top:1px solid var(--vx-line);
}
.mobile-nav__sub.is-open{display:block}

.mobile-nav__sub a{
  display:block;padding:11px 20px 11px 32px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--vx-mute);transition:color .2s;
}
.mobile-nav__sub a::before{content:"▸ ";color:var(--vx-accent);font-size:9px}
.mobile-nav__sub a:hover{color:var(--vx-accent)}

.mobile-nav__footer{
  padding:20px;border-top:1px solid var(--vx-line-2);
  flex-shrink:0;
  display:flex;flex-direction:column;gap:16px;
}
.mobile-nav__contact{
  display:flex;align-items:center;justify-content:space-between;
}
.mobile-nav__contact a{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.06em;
  color:var(--vx-mute);transition:color .2s;
}
.mobile-nav__contact a:hover{color:var(--vx-accent)}
.mobile-nav__contact a[aria-label="LinkedIn"]{
  display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:4px;
  border:1px solid var(--vx-line-2);
  transition:border-color .2s,color .2s;
}
.mobile-nav__contact a[aria-label="LinkedIn"]:hover{border-color:var(--vx-accent);color:var(--vx-accent)}

/* ─── WordPress admin bar offset ─────────────────────────────────────── */
/* When logged in as admin, WordPress adds a 32px bar at the top.
   Without this, it would overlap the fixed header. */
.admin-bar .site-header{top:32px}
@media screen and (max-width:782px){
  .admin-bar .site-header{top:46px}
}

/* ─── Inner page hero ────────────────────────────────────────────────── */
.page-hero{
  padding:180px 0 80px;
  position:relative;overflow:hidden;
  background:
    radial-gradient(700px 400px at 65% 0%, rgba(29,240,122,0.08), transparent 60%);
}
.page-hero__inner{position:relative}
.page-hero h1{font-size:clamp(38px,5.5vw,72px);margin-top:20px;max-width:22ch}
.page-hero .lead{max-width:600px;margin-top:20px;color:var(--vx-mute);font-size:17px}
.page-hero__breadcrumb{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--vx-mute);margin-bottom:40px;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.page-hero__breadcrumb a{color:var(--vx-mute);transition:color .2s}
.page-hero__breadcrumb a:hover{color:var(--vx-accent)}
.page-hero__breadcrumb .sep{color:var(--vx-line-2)}
.page-hero__breadcrumb .current{color:var(--vx-accent)}

/* ─── Page hero with side media ──────────────────────────────────────── */
.page-hero--split .page-hero__inner{
  display:grid;grid-template-columns:1.25fr 1fr;
  gap:72px;align-items:center;
}
.page-hero--split .page-hero__text{min-width:0}
.page-hero--split h1{max-width:none}
.page-hero--split .lead{max-width:none}
.page-hero__media{
  border-radius:var(--vx-radius);overflow:hidden;
  border:1px solid var(--vx-line-2);
  position:relative;
  box-shadow:0 30px 60px -30px rgba(0,0,0,0.5);
}
.page-hero--split .page-hero__media{margin-top:56px}
.page-hero__media img{
  width:100%;display:block;
  aspect-ratio:4/3;object-fit:cover;object-position:center;
}
@media(max-width:960px){
  .page-hero--split .page-hero__inner{grid-template-columns:1fr;gap:40px}
  .page-hero--split .page-hero__media{margin-top:0;max-width:560px}
}

/* ─── Page stat bar ──────────────────────────────────────────────────── */
.page-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  margin-top:64px;
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius-lg);overflow:hidden;
}
.page-stats--3{grid-template-columns:repeat(3,1fr);max-width:75%;margin-left:auto;margin-right:auto}
.page-stat{padding:28px 24px;border-right:1px solid var(--vx-line);position:relative;background:var(--vx-ink)}
.page-stat:last-child{border-right:0}
.page-stat::before{
  content:"";position:absolute;top:28px;left:24px;
  width:5px;height:5px;background:var(--vx-accent);
  box-shadow:0 0 10px var(--vx-accent);border-radius:1px;
}
.page-stat__num{
  font-family:"JetBrains Mono",monospace;
  font-size:clamp(28px,3vw,42px);font-weight:700;letter-spacing:-0.04em;
  color:var(--vx-text);margin-top:18px;line-height:1;
}
.page-stat__num sup{font-size:16px;color:var(--vx-accent);vertical-align:super;margin-left:3px}
.page-stat__label{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--vx-mute);margin-top:10px;font-weight:500;
}

/* ─── Capability grid variants ───────────────────────────────────────── */
.process-grid--3{grid-template-columns:repeat(3,1fr)}
.process-grid--3::before{display:none}
.process-grid--3 .proc::after{content:"";position:absolute;right:-20px;top:64px;width:20px;height:1px;background:var(--vx-line-2)}
.process-grid--3 .proc:nth-child(3n)::after,.process-grid--3 .proc:last-child::after{display:none}
.process-grid--2{grid-template-columns:repeat(2,1fr)}
.process-grid--2::before{display:none}


/* ─── Inline body-copy link (accent underline, no uppercase) ─────────── */
.inline-link{color:var(--vx-accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:color .2s}
.inline-link:hover,.inline-link:focus-visible{color:#88ffbb}


/* ─── FAQ section: narrow the accordion list for readability while
       keeping the section header at full container width so it lines up
       with the rest of the page. ──────────────────────────────────────── */
.faq-section .svc-accordion{max-width:960px;margin-left:auto;margin-right:auto}

/* ─── Team member grid ───────────────────────────────────────────────── */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;margin-top:48px;
}
.team-card{
  padding:28px 24px;
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);background:var(--vx-ink-2);
  position:relative;overflow:hidden;
  transition:border-color .3s,transform .3s;
}
.team-card:hover{border-color:var(--vx-accent);transform:translateY(-3px)}
.team-card__avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--vx-accent-soft);border:1px solid var(--vx-line-2);
  display:flex;align-items:center;justify-content:center;
  font-family:"JetBrains Mono",monospace;font-size:15px;font-weight:700;
  color:var(--vx-accent);margin-bottom:14px;letter-spacing:-0.03em;
}
.team-card__name{
  font-family:"JetBrains Mono",monospace;
  font-size:14px;font-weight:600;color:var(--vx-text);
  letter-spacing:-0.02em;margin-bottom:4px;
}
.team-card__role{
  font-family:"JetBrains Mono",monospace;
  font-size:10px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--vx-accent);margin-bottom:10px;font-weight:500;
}
.team-card__skills{font-size:13px;color:var(--vx-mute);line-height:1.55}
.team-card__avatar--photo{
  background:none;border:2px solid var(--vx-line-2);
  overflow:hidden;padding:0;width:72px;height:72px;
}
.team-card__avatar--photo img{width:100%;height:100%;object-fit:cover;display:block}
a.team-card--link{text-decoration:none;color:inherit;display:flex;flex-direction:column}
a.team-card--link:hover{border-color:var(--vx-accent);transform:translateY(-3px)}
.team-grid__intro{font-size:14px;color:var(--vx-mute);margin-top:24px}
.team-grid--collapsed > *:nth-child(n+7){display:none}
.team-expand-wrap{text-align:center;margin-top:32px}
@media(max-width:960px){.team-grid--collapsed > *:nth-child(n+5){display:none}}
@media(max-width:560px){.team-grid--collapsed > *:nth-child(n+3){display:none}}

/* ─── Single team member profile ────────────────────────────────────── */
.team-profile{display:grid;grid-template-columns:260px 1fr;gap:64px;align-items:start}
.team-profile__photo{border-radius:var(--vx-radius);overflow:hidden;border:1px solid var(--vx-line-2)}
.team-profile__photo img{width:100%;display:block;object-fit:cover}
.team-profile__initials{
  aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;
  font-family:"JetBrains Mono",monospace;font-size:72px;font-weight:700;
  color:var(--vx-accent);background:var(--vx-accent-soft);
}
.team-profile__meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.team-profile__pill{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:0.06em;
  text-transform:uppercase;padding:5px 12px;border-radius:100px;
  border:1px solid var(--vx-line-2);color:var(--vx-mute);
}
.team-profile__skills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.team-profile__skill{
  font-size:12px;padding:4px 10px;border-radius:4px;
  background:var(--vx-accent-soft);color:var(--vx-accent);
  font-family:"JetBrains Mono",monospace;
}
.team-profile__bio{font-size:15px;line-height:1.8;color:var(--vx-text);margin-bottom:32px}
.team-profile__bio p{margin-bottom:1em}
.team-profile__actions{display:flex;gap:12px;flex-wrap:wrap}

/* ─── Hero featured image ────────────────────────────────────────────── */
.hero__featured{
  margin-top:48px;border-radius:var(--vx-radius);
  overflow:hidden;border:1px solid var(--vx-line-2);
}
.hero__featured img{
  width:100%;height:auto;display:block;
  max-height:320px;object-fit:cover;object-position:center top;
}

/* ─── Section image (vision, global reach, etc.) ─────────────────────── */
.section-image{
  margin:48px auto 0;max-width:680px;
  border-radius:var(--vx-radius);
  overflow:hidden;border:1px solid var(--vx-line-2);
}
.section-image img{
  width:100%;height:auto;display:block;
  max-height:320px;object-fit:cover;object-position:center;
}

/* ─── Intro split: text + image side-by-side ─────────────────────────── */
.intro-split{
  display:grid;grid-template-columns:0.9fr 1.1fr;
  gap:72px;align-items:center;
}
.intro-split__text .eyebrow{margin-bottom:20px}
.intro-split__text h2{margin-bottom:24px;max-width:none}
.intro-split__text p{font-size:17px;color:var(--vx-mute);line-height:1.7}
.intro-split__text p+p{margin-top:16px}
.intro-split__text .spec__link{display:inline-flex;margin-top:24px}
.intro-split__media{
  border-radius:var(--vx-radius);overflow:hidden;
  border:1px solid var(--vx-line-2);
}
.intro-split__media img{
  width:100%;display:block;
  aspect-ratio:4/3;object-fit:cover;object-position:center top;
}
.intro-split--head{grid-template-columns:0.8fr 1.2fr;margin-bottom:64px}
.intro-split--head .intro-split__text{text-align:right}
.intro-split--head .intro-split__text h2{margin-left:auto}
@media(max-width:960px){
  .intro-split{grid-template-columns:1fr;gap:40px}
  .intro-split__media{max-width:560px}
  .intro-split--head{grid-template-columns:1fr;margin-bottom:48px}
}

/* ─── Partners bar ───────────────────────────────────────────────────── */
.partners-bar{padding:48px 0;margin-top:0}
.partners-bar__label{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--vx-mute);text-align:center;margin-bottom:32px;font-weight:500;
}
.partners-bar__row{display:flex;align-items:center;justify-content:center;gap:64px;flex-wrap:wrap}
.partner{
  height:44px;width:auto;display:block;
}
.partner:hover{opacity:1;color:var(--vx-accent)}

/* ─── Specialism page navigation ─────────────────────────────────────── */
.spec-nav{
  display:flex;justify-content:space-between;align-items:center;
  padding:40px 0;border-top:1px solid var(--vx-line-2);
}
.spec-nav__link{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;
  color:var(--vx-mute);transition:color .2s;
}
.spec-nav__link:hover{color:var(--vx-accent)}
.spec-nav__link--prev::before{content:"←";color:var(--vx-accent);margin-right:4px}
.spec-nav__link--next::after{content:"→";color:var(--vx-accent);margin-left:4px}

/* ─── Case study links (inner page) ─────────────────────────────────── */
.case-links{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.case-link-item{
  position:relative;
  display:flex;flex-direction:column;gap:18px;
  padding:32px 32px 28px;
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius-lg);
  background:var(--vx-ink-2);
  overflow:hidden;
  transition:border-color .35s,transform .35s,background .35s;
}
.case-link-item::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--vx-accent),transparent);
  opacity:0;transition:opacity .35s;
}
.case-link-item:hover{border-color:var(--vx-accent);transform:translateY(-4px)}
.case-link-item:hover::before{opacity:1}
.case-link-item:only-child{grid-column:1/-1}
.case-link-item__top{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:24px;
}
.case-link-item__tag{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;font-weight:600;
  letter-spacing:0.16em;color:var(--vx-accent);
}
.case-link-item__stat{
  text-align:right;flex-shrink:0;
  display:flex;flex-direction:column;align-items:flex-end;gap:8px;
}
.case-link-item__stat-value{
  font-family:"JetBrains Mono",monospace;
  font-size:32px;font-weight:700;line-height:1;
  letter-spacing:-0.04em;color:var(--vx-accent);
  white-space:nowrap;
}
.case-link-item__stat-label{
  font-family:"JetBrains Mono",monospace;
  font-size:10px;font-weight:600;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--vx-mute);line-height:1.3;
  max-width:160px;
}
.case-link-item__title{
  margin:0;
  font-size:18px;line-height:1.35;font-weight:500;
  letter-spacing:-0.01em;color:var(--vx-text);
}
.case-link-item__cta{
  margin-top:auto;
  display:inline-flex;align-items:center;gap:14px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;font-weight:600;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--vx-mute);
  transition:color .25s;
}
.case-link-item__cta .arrow{color:var(--vx-accent);transition:transform .25s}
.case-link-item:hover .case-link-item__cta{color:var(--vx-text)}
.case-link-item:hover .case-link-item__cta .arrow{transform:translateX(4px)}

/* ─── Value cards (used on Who We Are, Our Vision) ───────────────────── */
.value-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.value-card{
  padding:36px 32px;
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius-lg);
  background:var(--vx-ink-2);
  position:relative;overflow:hidden;
  transition:border-color .35s,transform .35s;
  display:flex;flex-direction:column;
}
.value-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--vx-accent),transparent);
  opacity:0;transition:opacity .35s;
}
.value-card:hover{border-color:var(--vx-accent);transform:translateY(-4px)}
.value-card:hover::before{opacity:1}
.value-card__num{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;color:var(--vx-accent);letter-spacing:0.14em;
  font-weight:600;text-transform:uppercase;margin-bottom:20px;
  transition:background .35s;padding:4px 10px;border-radius:4px;
  display:inline-block;margin-left:-10px;
}
.value-card:hover .value-card__num{background:rgba(29,240,122,.14)}
.value-card h4 a{color:inherit;text-decoration:none;transition:color .2s}
.value-card:hover h4 a{color:var(--vx-accent)}
.value-card h4{margin-bottom:18px}
.value-card p{font-size:14px;flex:1}
.value-card .spec__link{margin-top:20px}

/* ─── Responsive: inner pages ────────────────────────────────────────── */
@media(max-width:960px){
  .page-hero{padding:140px 0 60px}
  .page-stats{grid-template-columns:repeat(2,1fr)}
  .page-stat{border-right:0;border-bottom:1px solid var(--vx-line)}
  .page-stat:nth-child(odd){border-right:1px solid var(--vx-line)}
  .page-stat:nth-last-child(-n+2){border-bottom:0}
  .process-grid--3{grid-template-columns:repeat(2,1fr)}
  .process-grid--3 .proc::after{display:none}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .team-profile{grid-template-columns:1fr;gap:32px}
  .case-links{grid-template-columns:1fr}
  .value-grid{grid-template-columns:1fr}
  .partners-bar__row{gap:32px}
}
@media(max-width:560px){
  .page-stats{grid-template-columns:1fr}
  .page-stat{border-right:0!important;border-bottom:1px solid var(--vx-line)}
  .page-stat:last-child{border-bottom:0}
  .process-grid--3{grid-template-columns:1fr}
  .process-grid--2{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .spec-nav{flex-direction:column;gap:20px;text-align:center}
}

/* 3-up variant for value-grid. Declared AFTER the base .value-grid rules
   and its media queries so it actually wins the cascade. Holds a multiple
   of 3 items (e.g. 6). Tablet falls back to 2 cols, mobile to 1. */
.value-grid--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:960px){.value-grid--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.value-grid--3{grid-template-columns:1fr}}

/* ─── Contact Form 7 — download gate ────────────────────────────────── */
.wpcf7,.wpcf7 form,.wpcf7 div{background:transparent;color:inherit}
.wpcf7 fieldset{border:none;padding:0;margin:0;min-width:0}
.vx-dl-form{margin-top:4px}
.wpcf7 form p{margin:0 0 10px;background:transparent}
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea{
  width:100%;padding:11px 14px;
  background:var(--vx-ink);border:1px solid var(--vx-line-2);
  border-radius:6px;color:var(--vx-text);
  font-family:"Inter",-apple-system,sans-serif;font-size:14px;
  transition:border-color .2s;outline:none;
}
.wpcf7 textarea{resize:vertical;min-height:120px;line-height:1.6}
.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus,
.wpcf7 textarea:focus{border-color:var(--vx-accent)}
.wpcf7 input[type="text"]::placeholder,
.wpcf7 input[type="email"]::placeholder,
.wpcf7 input[type="tel"]::placeholder,
.wpcf7 textarea::placeholder{color:var(--vx-mute)}
.wpcf7 input[type="submit"]{
  margin-top:4px;
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;border-radius:6px;border:none;cursor:pointer;
  background:var(--vx-accent);color:#01051E;
  font-family:"JetBrains Mono",monospace;font-size:12px;
  font-weight:700;letter-spacing:0.06em;text-transform:uppercase;
  transition:opacity .2s,transform .2s;
}
.wpcf7 input[type="submit"]:hover{opacity:.88;transform:translateY(-1px)}
.wpcf7-response-output{
  margin-top:12px;padding:10px 14px;border-radius:6px;font-size:13px;
  border:1px solid var(--vx-line-2);color:var(--vx-text);
}
.wpcf7-response-output:empty,
.wpcf7 form:not(.invalid):not(.sent):not(.failed):not(.spam) .wpcf7-response-output{
  display:none;
}
.wpcf7-response-output a{color:var(--vx-accent);font-weight:600}
.wpcf7 .wpcf7-not-valid-tip{font-size:12px;color:#ff6b6b;margin-top:4px}
.wpcf7 span.wpcf7-spinner{display:none}

/* ─── Download pages — shared layout ────────────────────────────────── */

/* Hero CTA — Download now button under stats */
.dl-hero-cta{margin-top:48px;display:flex;justify-content:center}

/* Component cards — matches .specs grid pattern */
.dl-components{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius-lg);
  overflow:hidden;margin-top:48px;
}
.dl-component{
  background:var(--vx-ink-2);
  padding:40px 32px;
  display:flex;flex-direction:column;
  transition:background .4s ease;
}
.dl-component:hover{background:#0C1239}
.dl-component__num{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;color:var(--vx-mute);letter-spacing:0.1em;
  font-weight:500;margin-bottom:24px;
}
.dl-component__num b{color:var(--vx-accent);font-weight:500}
.dl-component h3{font-size:18px;margin-bottom:14px;line-height:1.35}
.dl-component p{font-size:14px;color:var(--vx-mute);line-height:1.7;margin:0;flex:1}
@media(max-width:900px){.dl-components{grid-template-columns:1fr}}

/* Document preview gallery — clickable */
.dl-preview{display:flex;gap:24px;align-items:flex-start;justify-content:center;margin-top:56px;flex-wrap:wrap}
.dl-preview__item{
  flex:1 1 calc(50% - 12px);max-width:480px;
  display:block;cursor:zoom-in;position:relative;
  border-radius:var(--vx-radius-lg);overflow:hidden;
  border:1px solid var(--vx-line-2);
  transition:transform .3s ease, box-shadow .3s ease;
  background:#0b1030;
}
.dl-preview__item:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 50px rgba(0,0,0,.6),0 0 0 1px var(--vx-accent);
}
.dl-preview__item img{width:100%;height:auto;display:block}
.dl-preview--single .dl-preview__item{flex:0 1 600px;max-width:600px}
.dl-preview__item--static{cursor:default}
.dl-preview__item--static:hover{transform:none;box-shadow:none}
@media(max-width:640px){.dl-preview__item{flex:1 1 100%;max-width:100%}}

/* Coverage list — responsive grid */
.dl-coverage{
  display:grid;gap:1px;
  grid-template-columns:repeat(3,1fr);
  margin-top:48px;
  background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius-lg);
  overflow:hidden;
}
.dl-coverage--4col{grid-template-columns:repeat(4,1fr)}
.dl-coverage-row{
  display:flex;gap:14px;align-items:flex-start;
  padding:24px;background:var(--vx-ink-2);
  transition:background .3s ease;
}
.dl-coverage-row:hover{background:#0C1239}
.dl-coverage-row__check{
  flex-shrink:0;width:22px;height:22px;border-radius:50%;
  background:var(--vx-accent-soft);color:var(--vx-accent);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;line-height:1;margin-top:1px;
}
.dl-coverage-row strong{display:block;font-size:14px;margin-bottom:6px;color:var(--vx-text);line-height:1.3}
.dl-coverage-row p{font-size:13px;color:var(--vx-mute);line-height:1.6;margin:0}
@media(max-width:1100px){
  .dl-coverage,.dl-coverage--4col{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .dl-coverage,.dl-coverage--4col{grid-template-columns:1fr}
}

/* Comparison table */
.dl-table-wrap{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  border-radius:var(--vx-radius-lg);border:1px solid var(--vx-line-2);
  background:var(--vx-ink-2);isolation:isolate;
}
.dl-compare-table{width:100%;border-collapse:collapse;font-size:14px;min-width:640px}
.dl-compare-table th{
  padding:16px 22px;text-align:left;background:#0b1030;
  font-family:"JetBrains Mono",monospace;font-size:11px;
  letter-spacing:0.08em;text-transform:uppercase;color:var(--vx-mute);
  font-weight:600;border-bottom:1px solid var(--vx-line-2);
}
.dl-compare-table th.dl-col--highlight{color:var(--vx-accent);background:#0d1f24}
.dl-compare-table td{
  padding:16px 22px;text-align:left;vertical-align:middle;line-height:1.5;
  background:var(--vx-ink-2);border-bottom:1px solid var(--vx-line);
}
.dl-compare-table tr:nth-child(even) td{background:#0a0f2a}
.dl-compare-table tr:last-child td{border-bottom:none}
.dl-compare-table td.dl-col--highlight{
  color:var(--vx-accent);font-weight:600;
  background:rgba(29,240,122,.06);
  border-left:1px solid var(--vx-line-2);border-right:1px solid var(--vx-line-2);
}
.dl-compare-table tr:nth-child(even) td.dl-col--highlight{background:rgba(29,240,122,.09)}
.dl-improve{color:var(--vx-accent);font-size:13px;white-space:nowrap}

/* Form layout */
.dl-form-wrap{
  display:grid;gap:64px;align-items:start;
  grid-template-columns:1fr 420px;
  max-width:1000px;margin:0 auto;
}
.dl-form-intro h2{font-size:clamp(26px,3vw,40px);margin-top:16px;line-height:1.2}
.dl-form-box{
  background:var(--vx-ink-2);border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius-lg);padding:36px;
}
.dl-form-box label{
  display:block;font-family:"JetBrains Mono",monospace;font-size:11px;
  color:var(--vx-mute);letter-spacing:0.08em;text-transform:uppercase;
  margin-bottom:6px;font-weight:600;
}
.dl-form-box label .vx-optional{
  text-transform:none;letter-spacing:0;color:var(--vx-mute);
  opacity:.7;font-weight:400;margin-left:4px;
}
.dl-form-box .vx-consent{
  font-size:13px;color:var(--vx-mute);line-height:1.55;
  margin-top:6px;
}
.dl-form-box .vx-consent .wpcf7-list-item{margin:0;display:block}
.dl-form-box .vx-consent .wpcf7-acceptance label{
  display:flex;gap:10px;align-items:flex-start;cursor:pointer;
  font-family:"Inter",-apple-system,sans-serif;font-size:13px;
  text-transform:none;letter-spacing:0;color:var(--vx-mute);
  font-weight:400;line-height:1.55;margin:0;
}
.dl-form-box .vx-consent .wpcf7-list-item-label{
  flex:1;color:var(--vx-mute);font-size:13px;line-height:1.55;
}
.dl-form-box .wpcf7-acceptance input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;border:1px solid var(--vx-line-2);
  border-radius:3px;background:var(--vx-ink);cursor:pointer;
  position:relative;flex-shrink:0;margin-top:1px;
}
.dl-form-box .wpcf7-acceptance input[type="checkbox"]:checked{
  background:var(--vx-accent);border-color:var(--vx-accent);
}
.dl-form-box .wpcf7-acceptance input[type="checkbox"]:checked::after{
  content:"✓";position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);color:#01051E;font-size:12px;font-weight:700;
}
.dl-form-box input[type="submit"]{
  margin-top:8px;width:100%;justify-content:center;
}
@media(max-width:900px){.dl-form-wrap{grid-template-columns:1fr;gap:40px}}

/* ─── Image lightbox ─────────────────────────────────────────────────── */
.vx-lightbox{
  position:fixed;inset:0;z-index:9999;
  display:none;align-items:center;justify-content:center;
  background:rgba(1,5,30,.94);backdrop-filter:blur(8px);
  padding:60px 24px 24px;
}
.vx-lightbox.is-open{display:flex}
.vx-lightbox__img{
  max-width:100%;max-height:100%;
  border-radius:var(--vx-radius-lg);
  box-shadow:0 30px 80px rgba(0,0,0,.8);
}
.vx-lightbox__close{
  position:absolute;top:20px;left:20px;
  width:44px;height:44px;border-radius:50%;
  background:var(--vx-ink-2);border:1px solid var(--vx-line-2);
  color:var(--vx-text);font-size:22px;line-height:1;
  cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  transition:background .2s, color .2s, border-color .2s;
}
.vx-lightbox__close:hover{
  background:var(--vx-accent);color:#01051E;border-color:var(--vx-accent);
}

/* ─── Basic blog post styles ─────────────────────────────────────────── */
/* Applied on single.php and page.php — inner pages that aren't the homepage */
.vx-page-content{
  padding:160px 0 100px;
}
.vx-page-content h1{
  font-size:clamp(32px,4vw,60px);
  margin-bottom:24px;
}
.vx-page-content .post-meta{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  color:var(--vx-mute);
  letter-spacing:0.08em;
  margin-bottom:48px;
  padding-bottom:32px;
  border-bottom:1px solid var(--vx-line-2);
}
.vx-page-content .entry-content{max-width:780px}
.vx-page-content .entry-content p{
  color:var(--vx-text);
  font-size:17px;
  line-height:1.75;
  margin-bottom:24px;
}
.vx-page-content .entry-content h2{
  font-size:clamp(24px,2.8vw,38px);
  margin-top:56px;
  margin-bottom:18px;
}
.vx-page-content .entry-content h3{
  font-size:clamp(20px,2vw,26px);
  margin-top:40px;
  margin-bottom:14px;
}
.vx-page-content .entry-content ul,
.vx-page-content .entry-content ol{
  margin:0 0 24px 24px;
  color:var(--vx-mute);
  font-size:16px;
  line-height:1.7;
}
.vx-page-content .entry-content li{margin-bottom:8px}
.vx-page-content .entry-content a{
  color:var(--vx-accent);
  text-decoration:underline;
  text-underline-offset:3px;
}
.vx-page-content .entry-content blockquote{
  border-left:2px solid var(--vx-accent);
  padding-left:24px;
  margin:32px 0;
  font-style:italic;
  color:var(--vx-mute);
}
.vx-page-content .entry-content img{
  border-radius:var(--vx-radius);
  margin:32px 0;
}
.vx-page-content .entry-content pre,
.vx-page-content .entry-content code{
  font-family:"JetBrains Mono",monospace;
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);
  font-size:14px;
}
.vx-page-content .entry-content pre{
  padding:20px 24px;
  overflow-x:auto;
  margin:24px 0;
}
.vx-page-content .entry-content code{
  padding:2px 7px;
  font-size:13px;
}

/* Single post */
.page-hero--single{text-align:center;padding-bottom:48px}
.page-hero--single h1{
  font-size:clamp(26px,3vw,42px);
  max-width:30ch;margin-left:auto;margin-right:auto;
  line-height:1.2;
}
.page-hero--single .lead{margin-left:auto;margin-right:auto}
.page-hero--single .page-hero__breadcrumb{justify-content:center}
.vx-single{padding-top:24px}
.vx-single .entry-content{margin:0 auto}
.vx-single .entry-content img{
  display:block;max-width:60%;height:auto;
  margin:32px auto;border-radius:var(--vx-radius);
}
.vx-single__tags{
  margin-top:64px;padding-top:32px;
  border-top:1px solid var(--vx-line-2);
}
.vx-single__tags ul{
  list-style:none;margin:16px 0 0;padding:0;
  display:flex;flex-wrap:wrap;gap:8px;
}
.vx-single__tags li a{
  display:inline-block;font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:0.04em;
  padding:6px 12px;border-radius:4px;
  background:var(--vx-ink-2);border:1px solid var(--vx-line-2);
  color:var(--vx-mute);transition:color .2s,border-color .2s;
}
.vx-single__tags li a:hover{color:var(--vx-accent);border-color:var(--vx-accent)}

/* Blog archive listing */
.vx-archive{padding:160px 0 100px}
.vx-archive__title{
  font-size:clamp(32px,4vw,60px);
  margin-bottom:64px;
  padding-bottom:32px;
  border-bottom:1px solid var(--vx-line-2);
}
.vx-archive__filters{
  margin:-32px 0 48px;
  display:flex;flex-wrap:wrap;
  align-items:flex-start;
  gap:16px;
}
.vx-archive__filters > .vx-cat-filter{margin:0;flex:1 1 auto;min-width:0}
.vx-archive__filters > .vx-tag-picker{margin:0;flex:0 0 auto}
.vx-cat-filter__list{
  list-style:none;margin:0;padding:0;
  display:flex;flex-wrap:wrap;gap:8px;
}
.vx-cat-filter__pill{
  display:inline-block;font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:0.04em;
  padding:6px 12px;border-radius:4px;
  background:var(--vx-ink-2);border:1px solid var(--vx-line-2);
  color:var(--vx-mute);text-decoration:none;
  transition:color .2s,border-color .2s,background-color .2s;
}
.vx-cat-filter__pill:hover{color:var(--vx-accent);border-color:var(--vx-accent)}
.vx-cat-filter__pill.is-active{
  color:var(--vx-accent);border-color:var(--vx-accent);
  background:rgba(29,240,122,0.08);
}

/* Tag picker (button + searchable popover) */
.vx-tag-picker{position:relative}
.vx-tag-picker__btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:0.04em;
  padding:6px 12px;border-radius:4px;
  background:var(--vx-ink-2);border:1px solid var(--vx-line-2);
  color:var(--vx-mute);cursor:pointer;
  transition:color .2s,border-color .2s,background-color .2s;
}
.vx-tag-picker__btn:hover,
.vx-tag-picker__btn[aria-expanded="true"]{
  color:var(--vx-accent);border-color:var(--vx-accent);
}
.vx-tag-picker__btn.is-active{
  color:var(--vx-accent);border-color:var(--vx-accent);
  background:var(--vx-accent-soft);
}
.vx-tag-picker__btn-caret{font-size:10px;line-height:1;transition:transform .2s}
.vx-tag-picker__btn[aria-expanded="true"] .vx-tag-picker__btn-caret{transform:rotate(180deg)}
.vx-tag-picker__panel{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  z-index:20;
  width:280px;max-width:90vw;
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius-lg);
  box-shadow:0 12px 32px rgba(0,0,0,0.45);
  padding:12px;
}
.vx-tag-picker__search{
  width:100%;box-sizing:border-box;
  font-family:inherit;font-size:13px;
  padding:8px 10px;
  background:var(--vx-ink-3);
  border:1px solid var(--vx-line-2);border-radius:4px;
  color:#fff;
  margin-bottom:8px;
}
.vx-tag-picker__search::placeholder{color:var(--vx-mute)}
.vx-tag-picker__search:focus{outline:none;border-color:var(--vx-accent)}
.vx-tag-picker__list{
  list-style:none;margin:0;padding:0;
  max-height:260px;overflow-y:auto;
}
.vx-tag-picker__item{
  display:block;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:0.04em;
  padding:6px 10px;border-radius:4px;
  color:var(--vx-mute);text-decoration:none;
  transition:color .2s,background-color .2s;
}
.vx-tag-picker__item:hover{color:var(--vx-accent);background:rgba(29,240,122,0.06)}
.vx-tag-picker__item.is-active{color:var(--vx-accent)}
.vx-tag-picker__empty{
  margin:8px 4px 4px;font-size:12px;color:var(--vx-mute);
}
@media(max-width:560px){
  .vx-tag-picker__panel{right:auto;left:0}
}
.vx-post-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.vx-post-item{
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius-lg);
  overflow:hidden;
  transition:border-color .3s,transform .3s,box-shadow .3s;
}
.vx-post-item:hover{
  border-color:var(--vx-accent);
  transform:translateY(-4px);
  box-shadow:0 0 30px rgba(29,240,122,0.10);
}
.vx-post-item__inner{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  color:inherit;
  height:100%;
}
.vx-post-item__img{
  position:relative;
  width:100%;
  padding-top:62%;
  overflow:hidden;
  background:var(--vx-ink-2);
}
.vx-post-item__img > img,
.vx-post-item__img > .vx-post-item__img-fallback{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.vx-post-item__img > img{transition:transform .4s}
.vx-post-item:hover .vx-post-item__img > img{transform:scale(1.05)}
.vx-post-item__img-fallback{
  background:linear-gradient(135deg,var(--vx-ink-3) 0%,var(--vx-ink-2) 100%);
}
.vx-post-item__body{
  padding:18px 22px 22px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.vx-post-item__date{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  color:var(--vx-mute);
  letter-spacing:0.1em;
  margin-bottom:12px;
}
.vx-post-item__body h3{
  font-size:17px;
  line-height:1.3;
  margin-bottom:8px;
  transition:color .25s;
}
.vx-post-item:hover h3{color:var(--vx-accent)}
.vx-post-item__body p{
  font-size:13px;
  color:var(--vx-mute);
  line-height:1.55;
}
@media(max-width:960px){.vx-post-list{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.vx-post-list{grid-template-columns:1fr}}

/* Posts pagination */
.vx-pagination-wrap{
  margin-top:64px;
  padding-top:32px;
  border-top:1px solid var(--vx-line-2);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
}
.vx-pagination-label{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--vx-mute);
}
.vx-pagination{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:8px;
}
.vx-pagination .page-numbers{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;
  font-weight:500;
  letter-spacing:0.04em;
  min-width:40px;
  height:40px;
  padding:0 12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:var(--vx-radius);
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  color:var(--vx-mute);
  text-decoration:none;
  transition:color .2s,border-color .2s,background .2s,transform .2s;
}
.vx-pagination a.page-numbers:hover{
  color:var(--vx-accent);
  border-color:var(--vx-accent);
  transform:translateY(-2px);
}
.vx-pagination .page-numbers.current{
  background:var(--vx-accent);
  border-color:var(--vx-accent);
  color:var(--vx-ink);
  font-weight:700;
}
.vx-pagination .page-numbers.dots{
  background:transparent;
  border-color:transparent;
}
.vx-pagination .page-numbers.prev,
.vx-pagination .page-numbers.next{
  padding:0 16px;
  text-transform:uppercase;
  font-size:12px;
}
.vx-pagination-jump{
  display:flex;
  align-items:center;
  gap:6px;
  margin-top:4px;
}
.vx-pagination-jump__input{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;
  width:84px;
  height:36px;
  padding:0 12px;
  border-radius:var(--vx-radius);
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  color:var(--vx-text);
  text-align:center;
  transition:border-color .2s,box-shadow .2s;
  -moz-appearance:textfield;
}
.vx-pagination-jump__input::-webkit-outer-spin-button,
.vx-pagination-jump__input::-webkit-inner-spin-button{
  -webkit-appearance:none;margin:0;
}
.vx-pagination-jump__input::placeholder{color:var(--vx-mute);opacity:.7}
.vx-pagination-jump__input:focus{
  outline:none;
  border-color:var(--vx-accent);
  box-shadow:0 0 0 2px var(--vx-accent-soft);
}
.vx-pagination-jump__btn{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  font-weight:600;
  letter-spacing:0.06em;
  text-transform:uppercase;
  height:36px;
  padding:0 16px;
  border-radius:var(--vx-radius);
  background:var(--vx-accent);
  border:1px solid var(--vx-accent);
  color:var(--vx-ink);
  cursor:pointer;
  transition:transform .2s,box-shadow .2s;
}
.vx-pagination-jump__btn:hover{
  transform:translateY(-2px);
  box-shadow:0 0 18px rgba(29,240,122,0.25);
}
@media(max-width:560px){
  .vx-pagination{gap:6px}
  .vx-pagination .page-numbers{
    min-width:36px;height:36px;padding:0 10px;font-size:12px;
  }
  .vx-pagination .page-numbers.prev,
  .vx-pagination .page-numbers.next{padding:0 12px}
}

/* ─── Services catalogue cards ───────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.svc-card{
  padding:32px 28px;
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius);
  background:var(--vx-ink-2);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:border-color .3s,transform .3s,box-shadow .3s;
}
.svc-card:hover{
  border-color:var(--vx-accent);
  transform:translateY(-4px);
  box-shadow:0 0 30px rgba(29,240,122,0.10);
}
.svc-badge{
  display:inline-flex;align-items:center;
  font-family:"JetBrains Mono",monospace;
  font-size:10px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;
  padding:4px 10px;border-radius:3px;border:1px solid;margin-bottom:20px;
  align-self:flex-start;
}
.svc-badge--quickstart{color:var(--vx-accent);background:var(--vx-accent-soft);border-color:rgba(29,240,122,.3)}
.svc-badge--programme{color:#7eb8f7;background:rgba(126,184,247,.1);border-color:rgba(126,184,247,.2)}
.svc-badge--recurring{color:#c9b8f7;background:rgba(201,184,247,.1);border-color:rgba(201,184,247,.2)}
.svc-card h4{font-size:17px;flex:1;line-height:1.3}
.svc-card__duration{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;color:var(--vx-mute);letter-spacing:0.06em;
  margin-top:20px;padding-top:16px;border-top:1px solid var(--vx-line);
}
.svc-card__duration span{color:var(--vx-accent)}
@media(max-width:960px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}

/* ─── Services catalogue (accordion layout) ──────────────────────────── */
.svc-catalogue-section{padding:0}

.svc-layout{
  display:grid;
  grid-template-columns:272px 1fr;
  align-items:start;
  max-width:var(--vx-container);
  margin:0 auto;
  padding:0 32px;
}

/* ── Sidebar TOC ─────────────────────────────────────────────────────── */
.svc-toc{
  position:sticky;
  top:72px;
  align-self:start;
  border-right:1px solid var(--vx-line-2);
  padding:64px 0 80px;
  min-height:calc(100vh - 72px);
}
.svc-toc__inner{padding:0 32px 0 0}
.svc-toc__heading{
  display:flex;align-items:center;gap:10px;
  font-family:"JetBrains Mono",monospace;
  font-size:14px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--vx-mute);
  padding-bottom:20px;border-bottom:1px solid var(--vx-line);
  margin-bottom:4px;
}
.svc-toc__heading svg{
  width:14px;height:14px;stroke:var(--vx-accent);
  stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round;
  flex-shrink:0;
}
.svc-toc__list{list-style:none}
.svc-toc__item{border-bottom:1px solid var(--vx-line);position:relative}
.svc-toc__item a{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 0 13px 0;
  color:var(--vx-mute);
  transition:color .25s, padding-left .25s;
}
.svc-toc__item a:hover{color:var(--vx-text);padding-left:8px}
.svc-toc__item--active a{color:var(--vx-text);padding-left:14px}
/* active left bar */
.svc-toc__item--active::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:2px;height:26px;background:var(--vx-accent);
  border-radius:1px;box-shadow:0 0 8px var(--vx-accent);
}
.svc-toc__label{
  font-family:"JetBrains Mono",monospace;
  font-size:15px;font-weight:600;letter-spacing:-0.01em;
  margin-bottom:4px;
}
.svc-toc__count{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;color:var(--vx-mute);font-weight:400;letter-spacing:0.02em;
}
.svc-toc__item--active .svc-toc__count{color:var(--vx-accent)}
.svc-toc__arrow{
  font-size:16px;color:var(--vx-mute);flex-shrink:0;margin-left:8px;
  transition:color .25s, transform .25s;
}
.svc-toc__item a:hover .svc-toc__arrow,
.svc-toc__item--active .svc-toc__arrow{color:var(--vx-accent);transform:translateX(2px)}

/* ── Main content ─────────────────────────────────────────────────────── */
.svc-main{padding:64px 0 80px 72px}
.svc-main__header{margin-bottom:8px}
.svc-main__header .eyebrow{margin-bottom:20px}
.svc-main__header h2{
  font-size:clamp(26px,3vw,40px);
  font-weight:700;letter-spacing:-0.04em;line-height:1.05;
}
.svc-main__count{
  font-family:"JetBrains Mono",monospace;
  font-size:14px;color:var(--vx-mute);
  margin-top:8px;letter-spacing:0.06em;text-transform:uppercase;
}
.svc-main__divider{
  height:1px;background:var(--vx-line-2);
  border:0;margin:32px 0 28px;
}

/* ── Accordion ────────────────────────────────────────────────────────── */
/* adopt the specs grid visual: gap-1px border approach */
.svc-accordion{
  display:flex;flex-direction:column;
  gap:1px;background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius-lg);
  overflow:hidden;
  counter-reset:svc;
}
.svc-item{
  background:var(--vx-ink-2);
  position:relative;
  overflow:hidden;
  transition:background .35s ease;
  counter-increment:svc;
}
.svc-item:hover:not(.is-open){background:#0c1239}
/* top accent line — hidden until open (mirrors assess__card::before) */
.svc-item::before{
  content:"";position:absolute;top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg, var(--vx-accent), rgba(29,240,122,.3) 60%, transparent);
  opacity:0;transition:opacity .35s;z-index:2;
}
.svc-item.is-open{background:#0a0e27}
.svc-item.is-open::before{opacity:1}

/* trigger row */
.svc-item__trigger{
  width:100%;display:flex;align-items:center;
  justify-content:space-between;
  padding:22px 28px;
  background:none;border:none;
  color:var(--vx-text);text-align:left;
  cursor:pointer;gap:20px;
}
/* trigger left: use CSS grid for icon | [num / name] stack */
.svc-item__trigger-left{
  display:grid;
  grid-template-columns:44px 1fr;
  grid-template-rows:auto auto;
  column-gap:16px;
  align-items:center;
  min-width:0;
}
/* icon box — same language as spec__icon */
.svc-item__icon{
  grid-column:1;grid-row:1/3;
  width:44px;height:44px;border-radius:8px;
  background:var(--vx-accent-soft);
  border:1px solid var(--vx-line-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--vx-accent);
  transition:background .3s, border-color .3s;
  align-self:center;flex-shrink:0;
}
.svc-item.is-open .svc-item__icon{
  background:rgba(29,240,122,.16);
  border-color:rgba(29,240,122,.4);
}
.svc-item__chevron{
  width:18px;height:18px;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.svc-item.is-open .svc-item__chevron{transform:rotate(90deg)}

/* number — mirrors spec__num with b accent */
.svc-item__num{
  grid-column:2;grid-row:1;align-self:end;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;color:var(--vx-mute);letter-spacing:0.08em;font-weight:500;
  line-height:1;margin-bottom:5px;
}
/* auto-generate the counter text */
.svc-item__num::before{
  content:"[ " counter(svc, decimal-leading-zero) " / 07 ]";
}
.svc-item__num b{color:var(--vx-accent);font-weight:500}
.svc-item.is-open .svc-item__num{color:var(--vx-accent)}

.svc-item__name{
  grid-column:2;grid-row:2;align-self:start;
  font-family:"JetBrains Mono",monospace;
  font-size:16px;font-weight:600;letter-spacing:-0.02em;
  line-height:1.2;
}
.svc-item.is-open .svc-item__name{color:var(--vx-accent)}

/* trigger right */
.svc-item__trigger-right{
  display:flex;align-items:center;gap:14px;flex-shrink:0;
}
.svc-item__trigger-right .svc-badge{margin-bottom:0;align-self:auto}
.svc-item__dur{
  display:flex;align-items:center;gap:5px;
  font-family:"JetBrains Mono",monospace;
  font-size:13px;color:var(--vx-mute);letter-spacing:0.04em;white-space:nowrap;
}
.svc-item__dur svg{
  width:12px;height:12px;stroke:currentColor;
  stroke-width:1.5;fill:none;flex-shrink:0;
}

/* ── Accordion body ───────────────────────────────────────────────────── */
.svc-item__body{
  display:none;
  padding:8px 28px 36px;
  border-top:1px solid var(--vx-line);
}
.svc-item.is-open .svc-item__body{display:block}

/* ── Content sections ─────────────────────────────────────────────────── */
.svc-section{margin-top:32px}

/* section heading */
.svc-section__title{
  font-family:"JetBrains Mono",monospace;
  font-size:16px;font-weight:600;color:var(--vx-accent);
  letter-spacing:0.04em;text-transform:uppercase;
  margin-bottom:16px;
  display:inline-flex;align-items:center;gap:12px;
}
.svc-section__title::before{
  content:"";width:24px;height:1px;background:var(--vx-accent);flex-shrink:0;
}
.svc-section>p{font-size:15px;color:var(--vx-mute);line-height:1.75;margin:0}
.svc-section ul{list-style:none;margin:0;padding:0}
.svc-section>ul li{
  font-size:15px;color:var(--vx-mute);
  padding:5px 0 5px 20px;position:relative;line-height:1.6;
}
.svc-section>ul li::before{
  content:"▸";color:var(--vx-accent);font-size:10px;
  position:absolute;left:0;top:8px;
}

/* ── Deliverables — spec-grid approach ────────────────────────────────── */
.svc-deliverables{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;margin-top:14px;
  background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);overflow:hidden;
}
.svc-deliverable-card:last-child:nth-child(odd){grid-column:1/-1;
}
.svc-deliverable-card{
  padding:28px 24px;
  background:var(--vx-ink-3);
  transition:background .35s ease;
}
.svc-deliverable-card:hover{background:#0c1030}
/* proc__step-style badge title */
.svc-deliverable-card__title{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;font-weight:600;color:var(--vx-accent);
  letter-spacing:0.08em;text-transform:uppercase;
  display:inline-block;
  padding:6px 12px;
  background:var(--vx-accent-soft);
  border-radius:4px;
  margin-bottom:16px;
}
.svc-deliverable-card ul{list-style:none;margin:0;padding:0}
.svc-deliverable-card ul li{
  font-size:14px;color:var(--vx-mute);
  padding:4px 0 4px 16px;position:relative;line-height:1.6;
}
.svc-deliverable-card ul li::before{
  content:"▸";color:var(--vx-accent);font-size:10px;
  position:absolute;left:0;top:6px;
}

/* ── Timeline / Delivery — stat-style ────────────────────────────────── */
.svc-meta-row{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);overflow:hidden;
}
.svc-meta-cell{
  background:var(--vx-ink-3);
  padding:24px 28px;position:relative;
}
/* accent dot like .stat::before */
.svc-meta-cell::before{
  content:"";position:absolute;top:24px;left:28px;
  width:5px;height:5px;background:var(--vx-accent);
  box-shadow:0 0 8px var(--vx-accent);border-radius:1px;
}
.svc-meta-cell__label{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;font-weight:500;color:var(--vx-mute);
  letter-spacing:0.12em;text-transform:uppercase;
  margin-top:20px;margin-bottom:6px;
}
.svc-meta-cell__value{
  font-family:"JetBrains Mono",monospace;
  font-size:clamp(20px,2.2vw,28px);font-weight:700;
  color:var(--vx-text);letter-spacing:-0.03em;line-height:1;
}

/* ── Outcome ──────────────────────────────────────────────────────────── */
.svc-outcome{
  padding:28px 32px;
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);
  background:var(--vx-ink-3);
}
.svc-outcome__title{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;font-weight:600;color:var(--vx-accent);
  letter-spacing:0.12em;text-transform:uppercase;margin-bottom:12px;
}
.svc-outcome p{
  font-size:16px;color:var(--vx-text);
  line-height:1.7;margin:0;font-weight:300;position:relative;
}

/* ── CTA inside accordion ─────────────────────────────────────────────── */
.svc-cta__title{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;font-weight:600;color:var(--vx-mute);
  letter-spacing:0.12em;text-transform:uppercase;margin-bottom:16px;
}
.svc-cta__buttons{display:flex;gap:12px;flex-wrap:wrap}

/* ── Proven results — page-stat style ────────────────────────────────── */
.svc-result-card{
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius);
  background:var(--vx-ink-3);padding:28px;margin-top:14px;
}
.svc-result-card__name{
  font-family:"JetBrains Mono",monospace;
  font-size:15px;font-weight:600;color:var(--vx-text);
  letter-spacing:-0.02em;margin-bottom:4px;
}
.svc-result-card__client{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--vx-accent);font-weight:600;margin-bottom:14px;
}
.svc-result-card>p{font-size:14px;color:var(--vx-mute);line-height:1.65;margin-bottom:0}
/* metrics in a stat-row */
.svc-result-card__metrics{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--vx-line-2);
  border:1px solid var(--vx-line-2);border-radius:var(--vx-radius);
  overflow:hidden;margin:20px 0 16px;
}
.svc-result-metric{
  background:var(--vx-ink-2);
  padding:20px 24px;position:relative;
}
.svc-result-metric::before{
  content:"";position:absolute;top:20px;left:24px;
  width:4px;height:4px;background:var(--vx-accent);
  box-shadow:0 0 8px var(--vx-accent);border-radius:1px;
}
.svc-result-metric__val{
  font-family:"JetBrains Mono",monospace;
  font-size:clamp(22px,2.8vw,36px);font-weight:700;
  color:var(--vx-text);letter-spacing:-0.04em;
  line-height:1;margin-top:18px;
}
.svc-result-metric__label{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;color:var(--vx-accent);font-weight:500;margin-top:4px;
}
.svc-result-metric__desc{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;color:var(--vx-mute);
  letter-spacing:0.08em;text-transform:uppercase;
  margin-top:6px;font-weight:500;
}
.svc-why-va{
  padding:16px 20px;
  background:var(--vx-ink-3);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius);
  font-size:14px;color:var(--vx-mute);line-height:1.6;
}
.svc-why-va strong{
  display:block;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--vx-accent);font-weight:600;margin-bottom:6px;
}

/* ── Responsive ───────────────────────────────────────────────────────── */
@media(max-width:1100px){
  .svc-layout{grid-template-columns:240px 1fr}
  .svc-main{padding:60px 0 60px 48px}
}
@media(max-width:800px){
  .svc-layout{grid-template-columns:1fr;padding:0}
  .svc-toc{
    position:relative;top:auto;
    min-height:auto;border-right:none;
    border-bottom:1px solid var(--vx-line-2);
    padding:32px 32px 24px;
  }
  .svc-toc__inner{padding:0}
  .svc-main{padding:40px 32px}
  .svc-item__trigger-right{display:none}
  .svc-deliverables{grid-template-columns:1fr}
  .svc-result-card__metrics{grid-template-columns:1fr}
}
@media(max-width:560px){
  .svc-toc{padding:24px 20px}
  .svc-main{padding:32px 20px}
  .svc-meta-row{grid-template-columns:1fr}
  .svc-item__trigger{padding:18px 20px}
  .svc-item__body{padding:8px 20px 28px}
}

/* ─── Newsletter popup (site-wide) ───────────────────────────────────── */
.vx-news-pop{
  position:fixed;right:24px;bottom:24px;z-index:90;
  width:300px;max-width:calc(100vw - 32px);
  opacity:0;transform:translateY(16px);pointer-events:none;
  transition:opacity .35s ease, transform .35s ease;
  filter:drop-shadow(0 24px 48px rgba(0,0,0,.45));
}
.vx-news-pop.is-visible{opacity:1;transform:translateY(0);pointer-events:auto}
.vx-news-pop__card{
  display:block;width:100%;padding:0;text-align:left;
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius-lg);
  overflow:hidden;cursor:pointer;
  transition:border-color .25s, transform .25s, box-shadow .25s;
}
.vx-news-pop__card:hover{
  border-color:var(--vx-accent);
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(29,240,122,0.12);
}
.vx-news-pop__card:focus-visible{outline:2px solid var(--vx-accent);outline-offset:2px}
.vx-news-pop__media{
  display:block;width:100%;aspect-ratio:16/9;
  background-color:var(--vx-ink-3);
  background-image:
    radial-gradient(circle at 70% 40%, rgba(29,240,122,0.18), transparent 55%),
    radial-gradient(circle at 30% 70%, rgba(29,240,122,0.08), transparent 60%),
    linear-gradient(135deg, #050a26 0%, #0b1640 60%, #0b1030 100%);
  background-size:cover;background-position:center;
}
.vx-news-pop__body{
  display:flex;flex-direction:column;gap:6px;
  padding:14px 16px 16px;
  background:linear-gradient(0deg, rgba(29,240,122,0.16), rgba(29,240,122,0.08));
  border-top:1px solid var(--vx-line-2);
}
.vx-news-pop__eyebrow{
  font-family:"JetBrains Mono",monospace;font-size:10px;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--vx-accent);
}
.vx-news-pop__title{
  font-family:"JetBrains Mono",monospace;font-size:14px;
  font-weight:600;letter-spacing:-0.01em;color:var(--vx-text);
  line-height:1.35;
}
.vx-news-pop__cta{
  margin-top:4px;
  font-family:"JetBrains Mono",monospace;font-size:12px;
  font-weight:600;color:var(--vx-accent);
  display:inline-flex;gap:6px;align-items:center;
}
.vx-news-pop__cta .arrow{transition:transform .25s}
.vx-news-pop__card:hover .vx-news-pop__cta .arrow{transform:translateX(3px)}
.vx-news-pop__close{
  position:absolute;top:-10px;right:-10px;
  width:30px;height:30px;border-radius:50%;
  background:var(--vx-ink);
  border:1px solid var(--vx-line-2);
  color:var(--vx-text);
  font-size:14px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s, color .2s, transform .2s;
}
.vx-news-pop__close:hover{border-color:var(--vx-accent);color:var(--vx-accent);transform:scale(1.08)}
.vx-news-pop__close:focus-visible{outline:2px solid var(--vx-accent);outline-offset:2px}
@media(max-width:560px){
  .vx-news-pop{right:12px;bottom:12px;width:260px}
  .vx-news-pop__title{font-size:13px}
}

/* ─── Newsletter modal ───────────────────────────────────────────────── */
.vx-news-modal{
  position:fixed;inset:0;z-index:200;
  display:none;align-items:center;justify-content:center;
  padding:24px;
}
.vx-news-modal.is-open{display:flex}
.vx-news-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(1,5,30,0.78);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.vx-news-modal__panel{
  position:relative;
  width:min(720px, 100%);
  max-height:calc(100vh - 48px);
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  border-radius:var(--vx-radius-lg);
  overflow:hidden;overflow-y:auto;
  display:grid;grid-template-columns:240px 1fr;
  box-shadow:0 40px 80px rgba(0,0,0,.55);
  animation:vx-news-modal-in .35s ease;
}
@keyframes vx-news-modal-in{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}
.vx-news-modal__media{
  background-color:var(--vx-ink-3);
  background-image:
    radial-gradient(circle at 70% 40%, rgba(29,240,122,0.22), transparent 55%),
    radial-gradient(circle at 30% 70%, rgba(29,240,122,0.10), transparent 60%),
    linear-gradient(135deg, #050a26 0%, #0b1640 60%, #0b1030 100%);
  background-size:cover;background-position:center;
  border-right:1px solid var(--vx-line-2);
}
.vx-news-modal__inner{padding:40px 36px}
.vx-news-modal__inner h2{font-size:clamp(26px,3.4vw,34px);margin:18px 0 14px}
.vx-news-modal__lead{
  color:var(--vx-mute);font-size:14px;line-height:1.7;margin-bottom:22px;
}
.vx-news-modal__close{
  position:absolute;top:12px;right:12px;z-index:2;
  width:34px;height:34px;border-radius:50%;
  background:rgba(1,5,30,0.7);
  border:1px solid var(--vx-line-2);
  color:var(--vx-text);
  font-size:16px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s, color .2s, transform .2s;
}
.vx-news-modal__close:hover{border-color:var(--vx-accent);color:var(--vx-accent);transform:scale(1.06)}
.vx-news-modal__close:focus-visible{outline:2px solid var(--vx-accent);outline-offset:2px}
body.vx-modal-open{overflow:hidden}
@media(max-width:720px){
  .vx-news-modal{padding:16px}
  .vx-news-modal__panel{grid-template-columns:1fr;max-height:calc(100vh - 32px)}
  .vx-news-modal__media{aspect-ratio:16/8;border-right:0;border-bottom:1px solid var(--vx-line-2)}
  .vx-news-modal__inner{padding:28px 24px}
}

/* ─── Theme toggle (bottom-left) ─────────────────────────────────────── */
.vx-theme-toggle{
  position:fixed;left:24px;bottom:24px;z-index:90;
  width:44px;height:44px;border-radius:50%;
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  color:var(--vx-text);
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s, transform .2s, box-shadow .2s, background .2s;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.35));
}
.vx-theme-toggle:hover{
  border-color:var(--vx-accent);
  color:var(--vx-accent);
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(29,240,122,0.18);
}
.vx-theme-toggle:focus-visible{outline:2px solid var(--vx-accent);outline-offset:2px}
.vx-theme-toggle svg{width:18px;height:18px;display:block}
.vx-theme-toggle .vx-theme-toggle__sun{display:block}
.vx-theme-toggle .vx-theme-toggle__moon{display:none}
@media(max-width:560px){
  .vx-theme-toggle{left:12px;bottom:12px;width:40px;height:40px}
  .vx-theme-toggle svg{width:16px;height:16px}
}

/* ─── Motion toggle (sits next to theme toggle) ──────────────────────── */
.vx-motion-toggle{
  position:fixed;left:80px;bottom:24px;z-index:90;
  width:44px;height:44px;border-radius:50%;
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line-2);
  color:var(--vx-text);
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s, transform .2s, box-shadow .2s, background .2s;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.35));
}
.vx-motion-toggle:hover{
  border-color:var(--vx-accent);
  color:var(--vx-accent);
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(29,240,122,0.18);
}
.vx-motion-toggle:focus-visible{outline:2px solid var(--vx-accent);outline-offset:2px}
.vx-motion-toggle svg{width:18px;height:18px;display:block}
.vx-motion-toggle .vx-motion-toggle__on{display:block}
.vx-motion-toggle .vx-motion-toggle__off{display:none}
[data-motion="reduced"] .vx-motion-toggle .vx-motion-toggle__on{display:none}
[data-motion="reduced"] .vx-motion-toggle .vx-motion-toggle__off{display:block}
@media(max-width:560px){
  .vx-motion-toggle{left:60px;bottom:12px;width:40px;height:40px}
  .vx-motion-toggle svg{width:16px;height:16px}
}

/* When motion is reduced, pause the orb's float animation in place. */
[data-motion="reduced"] .orb{animation-play-state:paused}

/* ─── Orb toggle (sits next to motion toggle) ────────────────────────── */
.vx-orb-toggle{
  position:fixed;left:136px;bottom:24px;z-index:90;
  width:44px;height:44px;border-radius:50%;
  background:var(--vx-ink-2);
  border:1px solid var(--vx-line);color:var(--vx-fg);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:border-color .2s, transform .2s, box-shadow .2s, background .2s;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.35));
}
.vx-orb-toggle:hover{
  border-color:var(--vx-accent);
  color:var(--vx-accent);
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(29,240,122,0.18);
}
.vx-orb-toggle:focus-visible{outline:2px solid var(--vx-accent);outline-offset:2px}
.vx-orb-toggle svg{width:18px;height:18px;display:block}
.vx-orb-toggle .vx-orb-toggle__on{display:block}
.vx-orb-toggle .vx-orb-toggle__off{display:none}
[data-orb="hidden"] .vx-orb-toggle .vx-orb-toggle__on{display:none}
[data-orb="hidden"] .vx-orb-toggle .vx-orb-toggle__off{display:block}
[data-orb="hidden"] .orb{display:none}
@media(max-width:560px){
  .vx-orb-toggle{left:108px;bottom:12px;width:40px;height:40px}
  .vx-orb-toggle svg{width:16px;height:16px}
}


/* Instant tooltips for the theme + motion toggles (skips the OS title delay).
   Anchored to the button's left edge so they don't overflow the viewport. */
.vx-theme-toggle,
.vx-motion-toggle,
.vx-orb-toggle{ /* tooltip needs an explicit positioning anchor */ }
.vx-theme-toggle::before,
.vx-motion-toggle::before,
.vx-orb-toggle::before{
  content:attr(data-tooltip);
  position:absolute;
  bottom:calc(100% + 10px);
  left:0;
  background:var(--vx-ink-2);
  color:var(--vx-text);
  border:1px solid var(--vx-line-2);
  padding:6px 10px;
  border-radius:4px;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:0.04em;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transform:translateY(4px);
  transition:opacity .12s, transform .12s;
}
.vx-theme-toggle:hover::before,
.vx-motion-toggle:hover::before,
.vx-orb-toggle:hover::before,
.vx-theme-toggle:focus-visible::before,
.vx-motion-toggle:focus-visible::before,
.vx-orb-toggle:focus-visible::before{
  opacity:1;
  transform:translateY(0);
}

/* ─── Light mode palette (html[data-theme="light"]) ──────────────────── */
/* Soft blue-tinted light mode — mirrors the dark navy as a "daytime" version
   of the brand, with green grid + accent preserved. */
:root[data-theme="light"]{
  --vx-ink:#B8C7DD;
  --vx-ink-2:#C6D3E5;
  --vx-ink-3:#A6B6D0;
  --vx-line:rgba(29,240,122,0.22);
  --vx-line-2:rgba(29,240,122,0.46);
  --vx-text:#01051E;
  --vx-mute:#324264;
  --vx-accent:#067A3A;
  --vx-accent-soft:rgba(29,240,122,0.18);
}

/* Toggle icon swap when light mode active. */
[data-theme="light"] .vx-theme-toggle .vx-theme-toggle__sun{display:none}
[data-theme="light"] .vx-theme-toggle .vx-theme-toggle__moon{display:block}
[data-theme="light"] .vx-theme-toggle{
  filter:drop-shadow(0 8px 20px rgba(11,16,48,0.12));
}

/* Header — uses hardcoded ink alpha so override. */
[data-theme="light"] .site-header{
  background:rgba(184,199,221,0.85);
  border-bottom:1px solid var(--vx-line-2);
}

/* Primary button — brand dark navy. Premium and unambiguous on the slate. */
[data-theme="light"] .btn--primary{
  background:#01051E;
  color:#FFFFFF;
  box-shadow:0 4px 16px rgba(1,5,30,0.25);
}
[data-theme="light"] .btn--primary:hover{
  background:#0B1240;
  box-shadow:0 8px 24px rgba(1,5,30,0.40);
  transform:translateY(-2px);
}

/* Highlight — inverse of dark mode's effect: blue text with the brand dark
   navy sweeping across as a shadow. In dark mode a brighter sheen passes
   through neon green; here a darker shadow passes through blue. */
[data-theme="light"] .highlight{
  background:linear-gradient(90deg, #1D4ED8 0%, #01051E 45%, #1D4ED8 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  animation:highlight-shine 4s linear infinite;
}

/* Hover/active dark backgrounds across cards and rows → blue-tinted variants. */
[data-theme="light"] .spec:hover,
[data-theme="light"] .dl-component:hover,
[data-theme="light"] .dl-coverage-row:hover,
[data-theme="light"] .svc-item:hover:not(.is-open){
  background:#C8DDD0;
}
[data-theme="light"] .svc-item.is-open{
  background:#C6D3E5;
}
[data-theme="light"] .assess-full__card:hover,
[data-theme="light"] .location-card:hover,
[data-theme="light"] .svc-deliverable-card:hover{
  background:#ADBDD6;
}

/* Footer (was near-black) — match the header's lightness. */
[data-theme="light"] .footer{
  background:#B8C7DD;
  border-top:1px solid var(--vx-line-2);
}

/* Download comparison table — hardcoded backgrounds. */
[data-theme="light"] .dl-compare-table th{
  background:#A6B6D0;color:var(--vx-text);
}
[data-theme="light"] .dl-compare-table th.dl-col--highlight{
  background:#A8C6B5;color:var(--vx-accent);
}
[data-theme="light"] .dl-compare-table tr:nth-child(even) td{
  background:#B8C7DD;
}

/* Mobile nav backdrop — uses hardcoded ink. */
[data-theme="light"] .mobile-nav__backdrop{
  background:rgba(11,16,48,0.45);
}

/* Hardcoded #fff text on now-light surfaces. */
[data-theme="light"] .vx-tag-picker__search{color:var(--vx-text)}
[data-theme="light"] .mobile-nav__expand:hover{color:var(--vx-text)}

/* Stat / spec / case eyebrow chips that sit on dark hardcoded backgrounds. */
[data-theme="light"] .case__tag{
  background:rgba(11,16,48,0.04);
  border-color:var(--vx-line-2);
}

/* CF7 form field surfaces. */
[data-theme="light"] .wpcf7 input[type="text"],
[data-theme="light"] .wpcf7 input[type="email"],
[data-theme="light"] .wpcf7 input[type="tel"],
[data-theme="light"] .wpcf7 textarea{
  background:#C6D3E5;
  color:var(--vx-text);
  border:1px solid var(--vx-line-2);
}
[data-theme="light"] .wpcf7 input[type="submit"]{color:#FFFFFF}

/* Newsletter popup / modal — green wash sits over blue-tinted card. */
[data-theme="light"] .vx-news-pop__body{
  background:linear-gradient(0deg, rgba(29,240,122,0.18), rgba(29,240,122,0.06));
}
[data-theme="light"] .vx-news-pop__close,
[data-theme="light"] .vx-news-modal__close{
  background:#C6D3E5;
}
[data-theme="light"] .vx-news-modal__backdrop{
  background:rgba(1,5,30,0.55);
}

/* Body grid pattern — green lines must read clearly on blue-tinted bg (brand signature). */
[data-theme="light"] body::before{opacity:0.8}

/* Orbs — brand blue glow, pushed brighter so it reads clearly against slate. */
[data-theme="light"] .orb{mix-blend-mode:normal;opacity:1}
[data-theme="light"] .orb--1{
  background:radial-gradient(circle at center, rgba(59,130,246,0.85) 0%, rgba(59,130,246,0.25) 35%, transparent 70%);
}

/* Form placeholder/info box. */
[data-theme="light"] .form-placeholder{
  background:#A6B6D0;
}

/* Hero typing cursor — match the brand blue used for highlight text. */
[data-theme="light"] .hero h1 .cursor{
  background:#1D4ED8;
}

/* Delivery-model graphic — orbiting dots become brand dark navy, rings
   darken, and the central hub swaps to the inverted logo. */
[data-theme="light"] .reach__visual{
  border-color:rgba(1,5,30,0.30);
  background:none;
}
[data-theme="light"] .reach__visual::before,
[data-theme="light"] .reach__visual::after{
  border-color:rgba(1,5,30,0.32);
}
[data-theme="light"] .reach__dot{
  background:#01051E;
  box-shadow:none;
}
[data-theme="light"] .reach__core{
  background:transparent;
  border-color:rgba(1,5,30,0.30);
  box-shadow:none;
}

/* Frame wraps .reach__visual + .reach__logo as siblings so the logo can be
   positioned over the visual without being trapped by the .reveal stacking
   context. */
.reach__frame{position:relative;aspect-ratio:1}
.reach__frame .reach__visual{position:absolute;inset:0}
.reach__logo{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.reach__logo img{display:block;width:80px;height:auto}

/* Logo swap (mirrors the .logo header/footer swap). */
.reach__logo .vx-logo--light{display:none}
[data-theme="light"] .reach__logo .vx-logo--dark{display:none}
[data-theme="light"] .reach__logo .vx-logo--light{display:block}

/* Process cards — .proc:hover hardcodes a dark navy bg; needs a light tint
   in light mode so the card doesn't go black on hover. */
[data-theme="light"] .proc:hover{
  background:#C8DDD0;
  box-shadow:0 0 40px rgba(1,5,30,0.08);
}

/* Logo swap — show inverted (dark) logo in light mode.
   Selectors are scoped under .logo so they outrank the .logo img base rule. */
.logo .vx-logo--light{display:none}
[data-theme="light"] .logo .vx-logo--dark{display:none}
[data-theme="light"] .logo .vx-logo--light{display:block}