:root{
  /* Brand */
  --red:#E31E24;
  --red-hover:#C5181E;
  --red-dim:rgba(227,30,36,0.12);
  --red-glow:rgba(227,30,36,0.35);
  --charcoal:#1D1D1D;
  --charcoal-2:#161616;
  --charcoal-3:#0E0E0E;
  --dark-gray:#4A4A4A;
  --gray-1:#333333;
  --gray-2:#616161;
  --gray-3:#9E9E9E;
  --gray-4:#D9D9D9;
  --light-bg:#F2F2F2;
  --white:#FFFFFF;
  --near-black:#0A0A0A;
  --hairline-dark:rgba(255,255,255,0.08);
  --hairline-light:rgba(0,0,0,0.06);
  /* Spacing scale */
  --s-8:8px; --s-12:12px; --s-16:16px; --s-20:20px; --s-24:24px;
  --s-32:32px; --s-40:40px; --s-56:56px; --s-72:72px; --s-96:96px; --s-120:120px;
  /* Layout */
  --maxw:1320px;
  --gutter:32px;
  --section-y:120px;
  --ease:cubic-bezier(0.2,0.7,0.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  margin:0;
  font-family:'Poppins',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.65;
  color:var(--white);
  background:var(--charcoal);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
:focus-visible{outline:2px solid var(--red);outline-offset:3px;border-radius:2px}

.skip{
  position:absolute;left:-9999px;top:8px;background:var(--red);color:#fff;
  padding:10px 16px;border-radius:6px;font-weight:600;z-index:200;
}
.skip:focus{left:16px}

.container{
  width:100%;max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.eyebrow{
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:13px;font-weight:500;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--red);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:"";width:24px;height:1px;background:var(--red);
}
.eyebrow.no-line::before{display:none}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;letter-spacing:0.12em;text-transform:uppercase}

h1,h2,h3,h4{margin:0;font-family:inherit;color:var(--white)}
.h-display{
  font-weight:800;font-size:clamp(2.5rem,5.5vw,4.75rem);
  letter-spacing:-0.035em;line-height:1.02;
  text-wrap:balance;
}
.h-section{
  font-weight:700;font-size:clamp(2rem,3.6vw,3.25rem);
  letter-spacing:-0.025em;line-height:1.08;
  text-wrap:balance;
}
.h-card{
  font-size:22px;font-weight:600;letter-spacing:-0.015em;line-height:1.25;
}
.lead{
  font-weight:300;font-size:19px;line-height:1.6;
  max-width:62ch;color:var(--gray-3);
}
.on-light .lead{color:var(--gray-2)}
.on-light h1,.on-light h2,.on-light h3,.on-light h4{color:var(--charcoal)}

/* Section base */
section.section{
  padding-block:var(--section-y);
  position:relative;
}
.section.dark{background:var(--charcoal)}
.section.darker{background:var(--charcoal-2)}
.section.deepest{background:var(--charcoal-3)}
.section.light{background:var(--light-bg);color:var(--charcoal)}
.section.light h2,.section.light h3,.section.light p,.section.light{color:var(--charcoal)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:6px;
  font-weight:600;font-size:15px;letter-spacing:0.01em;
  transition:transform .25s var(--ease),background .25s var(--ease),
              border-color .25s var(--ease),box-shadow .25s var(--ease),color .25s var(--ease);
  border:1px solid transparent;
  white-space:nowrap;
  min-height:44px;
}
.btn .arr{display:inline-block;transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{
  background:var(--red);color:var(--white);
  box-shadow:0 10px 28px -10px var(--red-glow),0 2px 0 rgba(0,0,0,.15) inset;
}
.btn-primary:hover{background:var(--red-hover);transform:translateY(-1px)}
.btn-ghost{
  background:transparent;color:var(--white);
  border-color:rgba(255,255,255,0.16);
}
.btn-ghost:hover{border-color:rgba(255,255,255,0.5);background:rgba(255,255,255,0.04)}
.btn-outline-light{
  background:transparent;color:var(--charcoal);
  border-color:rgba(0,0,0,0.18);
}
.btn-outline-light:hover{border-color:rgba(0,0,0,0.5);background:rgba(0,0,0,0.03)}
.inline-arrow{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--red);font-weight:600;font-size:14px;
  letter-spacing:0.02em;
}
.inline-arrow .arr{transition:transform .3s var(--ease)}
.inline-arrow:hover .arr{transform:translateX(4px)}

/* Logo */
.logo{display:inline-flex;align-items:center;height:44px}
.logo img{display:block;height:38px;width:auto}
.foot-brand .logo{height:auto}
.foot-brand .logo img{height:64px;max-width:240px;object-fit:contain;object-position:left center}

/* Nav */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(14,14,14,0.78);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--hairline-dark);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;gap:24px;
}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--gray-3);
  transition:color .2s var(--ease);
}
.nav-links a:hover{color:var(--white)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-cta .btn{padding:10px 18px;font-size:13px;min-height:40px}
.hamb{
  display:none;width:44px;height:44px;align-items:center;justify-content:center;
  border:1px solid var(--hairline-dark);border-radius:6px;color:var(--white);
}
.hamb svg{width:18px;height:18px}
.drawer{
  display:none;position:fixed;inset:72px 0 0 0;z-index:99;
  background:rgba(14,14,14,0.98);backdrop-filter:blur(18px);
  padding:32px var(--gutter) 48px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
}
.drawer.open{display:block}
.drawer .nav-links{flex-direction:column;align-items:flex-start;gap:24px}
.drawer .nav-links a{font-size:20px;color:var(--white)}
.drawer .drawer-cta{margin-top:32px;display:flex;flex-direction:column;gap:12px}
.drawer .drawer-cta .btn{justify-content:center;width:100%}

main{padding-top:72px}
section[id]{scroll-margin-top:84px}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none!important;transition:none!important}
}

/* HERO */
.hero{
  position:relative;
  background:var(--charcoal-3);
  overflow:hidden;
  padding-block:140px 120px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.045) 1px,transparent 1px);
  background-size:80px 80px;
  -webkit-mask-image:radial-gradient(ellipse at 50% 40%,#000 30%,transparent 80%);
  mask-image:radial-gradient(ellipse at 50% 40%,#000 30%,transparent 80%);
  pointer-events:none;
}
.hero::after{
  content:"";position:absolute;top:-10%;right:-10%;
  width:55%;height:80%;
  background:radial-gradient(circle at center,rgba(227,30,36,0.18),transparent 65%);
  pointer-events:none;
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:64px;align-items:center;
  position:relative;z-index:2;
}

.hero-grid > *,
.hero-left,
.sub-hero-grid > *,
.split > *,
.sec-head > *,
.products-grid > *,
.contact-grid > *,
.legal-wrap > *{min-width:0}

.hero-meta{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--gray-3);margin-bottom:28px;
}
.live-dot{
  width:8px;height:8px;border-radius:50%;background:var(--red);
  box-shadow:0 0 0 0 rgba(227,30,36,0.55);
  animation:pulse 2.4s var(--ease) infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(227,30,36,0.55)}
  50%{box-shadow:0 0 0 10px rgba(227,30,36,0)}
}
.hero h1{margin-bottom:24px}
.hero h1 .accent-underline{
  position:relative;display:inline-block;white-space:nowrap;
}
.hero h1 .accent-underline::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:6px;
  background:var(--red);opacity:.85;border-radius:2px;
  transform:scaleX(.92);transform-origin:left;
}
.hero-sub{
  font-weight:300;font-size:19px;line-height:1.6;
  color:var(--gray-3);max-width:60ch;margin:0 0 36px;
}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}
.hero-trust{
  padding-top:24px;border-top:1px solid var(--hairline-dark);
  font-family:'JetBrains Mono',monospace;font-size:12px;
  letter-spacing:0.06em;color:var(--gray-3);
  text-transform:none;
}
.hero-trust .slash{color:var(--red);margin-right:8px}

/* Hero illustration */
.hero-illus{position:relative;aspect-ratio:1/1;width:100%}
.hero-illus svg{width:100%;height:100%}
.tele{
  position:absolute;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--gray-3);
  padding:6px 10px;border:1px solid var(--hairline-dark);
  background:rgba(14,14,14,0.7);backdrop-filter:blur(8px);
  border-radius:4px;display:inline-flex;align-items:center;gap:8px;
}
.tele .ld{width:6px;height:6px;border-radius:50%;background:var(--red)}
.tele-1{top:8%;left:-4%}
.tele-2{top:46%;right:-2%}
.tele-3{bottom:8%;left:14%}
.tele .v{color:var(--white)}

@media (max-width:1100px){
  .hero-grid{grid-template-columns:1fr}
  .hero-illus{display:none}
}

/* SECTION 2 - VALUE STRIP */
.value-strip{
  padding-block:0;background:var(--charcoal-2);
  border-block:1px solid var(--hairline-dark);
}
.value-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
}
.value-cell{
  padding:56px 40px;
  border-right:1px solid var(--hairline-dark);
  transition:background .25s var(--ease);
}
.value-cell:last-child{border-right:0}
.value-cell:hover{background:rgba(255,255,255,0.02)}
.value-cell .ix{
  font-family:'JetBrains Mono',monospace;font-size:12px;
  letter-spacing:0.16em;color:var(--red);margin-bottom:32px;display:block;
}
.value-cell .icn{
  width:32px;height:32px;color:var(--red);margin-bottom:24px;
}
.value-cell h3{font-size:18px;font-weight:600;letter-spacing:-0.015em;margin-bottom:12px}
.value-cell p{margin:0;font-size:14.5px;color:var(--gray-3);line-height:1.6}
@media (max-width:1100px){
  .value-grid{grid-template-columns:repeat(2,1fr)}
  .value-cell:nth-child(2){border-right:0}
  .value-cell:nth-child(1),.value-cell:nth-child(2){border-bottom:1px solid var(--hairline-dark)}
}
@media (max-width:760px){
  .value-grid{grid-template-columns:1fr}
  .value-cell{border-right:0;border-bottom:1px solid var(--hairline-dark);padding:40px 24px}
  .value-cell:last-child{border-bottom:0}
}

/* Section heads */
.sec-head{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:end;margin-bottom:72px}
.sec-head .left .h-section{margin-top:24px}
.sec-head .right{padding-bottom:8px}
@media (max-width:900px){
  .sec-head{grid-template-columns:1fr;gap:24px}
  .sec-head .right{padding-bottom:0}
}

/* SOLUTIONS GRID */
.solutions-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--hairline-dark);
  border-left:1px solid var(--hairline-dark);
}
.sol-card{
  position:relative;
  padding:40px 36px 36px;
  border-right:1px solid var(--hairline-dark);
  border-bottom:1px solid var(--hairline-dark);
  background:var(--charcoal);
  transition:transform .3s var(--ease),background .3s var(--ease);
  display:flex;flex-direction:column;gap:20px;min-height:300px;
}
.sol-card::before{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;
  background:var(--red);transform-origin:left;transform:scaleX(0);
  transition:transform .35s var(--ease);
}
.sol-card:hover::before{transform:scaleX(1)}
.sol-card:hover{transform:translateY(-3px);background:rgba(227,30,36,0.02)}
.icon-block{
  width:48px;height:48px;border-radius:8px;
  background:var(--red-dim);border:1px solid rgba(227,30,36,0.35);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--white);
}
.icon-block svg{width:22px;height:22px}
.sol-card h3{margin-top:auto}
.sol-card p{color:var(--gray-3);font-size:15px;margin:0}
.sol-card .inline-arrow{margin-top:auto}
@media (max-width:1100px){.solutions-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.solutions-grid{grid-template-columns:1fr}}

/* PRODUCTS */
.products-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.product-card{
  position:relative;border-radius:12px;overflow:hidden;
  background:linear-gradient(150deg,var(--charcoal-2),var(--charcoal-3));
  border:1px solid var(--hairline-dark);
  padding:40px;
  transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.product-card::after{
  content:"";position:absolute;top:-30%;right:-15%;
  width:60%;height:80%;
  background:radial-gradient(circle at center,rgba(227,30,36,0.16),transparent 65%);
  pointer-events:none;
}
.product-card:hover{
  transform:translateY(-4px);border-color:rgba(227,30,36,0.55);
  box-shadow:0 30px 60px -30px rgba(227,30,36,0.25);
}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--red-dim);border:1px solid rgba(227,30,36,0.4);
  color:var(--red);font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.14em;text-transform:uppercase;
}
.product-name{font-size:32px;font-weight:700;letter-spacing:-0.025em;margin:20px 0 12px;position:relative;z-index:2}
.product-desc{color:var(--gray-3);font-size:15.5px;line-height:1.6;max-width:48ch;margin:0 0 28px;position:relative;z-index:2}
.feat-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:14px 28px;
  border-top:1px solid var(--hairline-dark);
  padding:24px 0 32px;position:relative;z-index:2;
}
.feat{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--gray-3)}
.feat .dt{width:6px;height:6px;border-radius:50%;background:var(--red);flex-shrink:0}
.product-card .btn{position:relative;z-index:2}
@media (max-width:900px){.products-grid{grid-template-columns:1fr}.feat-grid{grid-template-columns:1fr}}

/* PODS */
.pods-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  border-top:1px solid var(--hairline-dark);
  border-left:1px solid var(--hairline-dark);
}
.pod{
  padding:36px 28px;
  border-right:1px solid var(--hairline-dark);
  border-bottom:1px solid var(--hairline-dark);
  background:var(--charcoal-2);
  transition:background .25s var(--ease);
}
.pod:hover{background:rgba(255,255,255,0.02)}
.pod .ix{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--gray-3);margin-bottom:24px;display:block;
}
.pod .ix .n{color:var(--red)}
.pod .icn{width:28px;height:28px;color:var(--red);margin-bottom:20px}
.pod h3{font-size:18px;font-weight:600;margin-bottom:10px;letter-spacing:-0.015em}
.pod p{margin:0;color:var(--gray-3);font-size:14px;line-height:1.55}
@media (max-width:1100px){.pods-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.pods-grid{grid-template-columns:1fr}}

/* ENGAGEMENT */
.eng-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.eng-card{
  position:relative;
  background:#FAFAFA;
  border:1px solid var(--hairline-light);
  padding:40px 40px 40px 44px;
  border-radius:8px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.eng-card::before{
  content:"";position:absolute;left:0;top:24px;bottom:24px;
  width:3px;background:var(--red);
  transform:scaleY(0);transform-origin:top;
  transition:transform .35s var(--ease);
}
.eng-card:hover::before{transform:scaleY(1)}
.eng-card:hover{transform:translateY(-2px);box-shadow:0 20px 40px -25px rgba(0,0,0,0.15)}
.eng-card .lbl{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--red);margin-bottom:18px;display:block;
}
.eng-card h3{font-size:22px;font-weight:600;letter-spacing:-0.015em;margin-bottom:12px;color:var(--charcoal)}
.eng-card p{margin:0;color:var(--gray-2);font-size:15px;line-height:1.6}
@media (max-width:900px){.eng-grid{grid-template-columns:1fr}}

/* INDUSTRIES */
.ind-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--hairline-dark);
  border-left:1px solid var(--hairline-dark);
}
.ind{
  position:relative;padding:36px 28px;
  border-right:1px solid var(--hairline-dark);
  border-bottom:1px solid var(--hairline-dark);
  background:var(--charcoal);
  transition:background .25s var(--ease);
}
.ind:hover{background:rgba(255,255,255,0.02)}
.ind .ix{
  position:absolute;top:18px;right:24px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--gray-3);
}
.ind .icn{width:28px;height:28px;color:var(--red);margin-bottom:24px;margin-top:8px}
.ind h3{font-size:18px;font-weight:600;letter-spacing:-0.015em;margin-bottom:10px}
.ind p{margin:0;color:var(--gray-3);font-size:14px;line-height:1.55}
.ind.dark-tile{background:var(--charcoal-3)}
.ind.dark-tile:hover{background:#070707}
.ind.dark-tile p{margin-bottom:20px}
@media (max-width:1100px){.ind-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.ind-grid{grid-template-columns:1fr}}

/* PROCESS */
.process{
  background:var(--charcoal-3);
  position:relative;
}
.process::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,0.035) 1px,transparent 1px);
  background-size:100% 80px;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
  pointer-events:none;
}
.process-track{
  position:relative;display:grid;grid-template-columns:repeat(5,1fr);
  gap:24px;margin-top:56px;
}
.process-track::before{
  content:"";position:absolute;top:36px;left:5%;right:5%;height:0;
  border-top:1.5px dashed var(--red);
  -webkit-mask-image:linear-gradient(90deg,#000,#000 65%,transparent);
  mask-image:linear-gradient(90deg,#000,#000 65%,transparent);
}
.step{position:relative;text-align:left;z-index:2}
.step .dot{
  width:72px;height:72px;border-radius:50%;
  background:var(--charcoal-2);
  border:1px solid var(--hairline-dark);
  display:flex;align-items:center;justify-content:center;
  font-family:'JetBrains Mono',monospace;font-weight:500;
  font-size:18px;color:var(--white);letter-spacing:0.04em;
  margin-bottom:28px;transition:transform .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
}
.step:hover .dot{transform:scale(1.05);color:var(--red);border-color:rgba(227,30,36,0.5)}
.step .lbl{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--red);margin-bottom:10px;display:block;
}
.step h3{font-size:19px;font-weight:600;letter-spacing:-0.015em;margin-bottom:10px}
.step p{margin:0;color:var(--gray-3);font-size:14px;line-height:1.55}
@media (max-width:900px){
  .process-track{grid-template-columns:1fr;gap:32px;padding-left:32px}
  .process-track::before{
    top:0;bottom:0;left:0;right:auto;width:0;height:auto;
    border-top:0;border-left:1.5px solid var(--red);
    -webkit-mask-image:linear-gradient(180deg,#000,#000 80%,transparent);
    mask-image:linear-gradient(180deg,#000,#000 80%,transparent);
  }
  .step .dot{margin-bottom:16px}
}

/* DIAGNOSTIC */
.diag-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.diag-card{
  background:#FAFAFA;border:1px solid var(--hairline-light);
  border-radius:10px;padding:40px;
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.diag-card:hover{transform:translateY(-3px);box-shadow:0 30px 60px -30px rgba(0,0,0,0.18)}
.diag-card.invert{background:var(--charcoal);color:var(--white);border-color:transparent}
.diag-card.invert h3{color:var(--white)}
.diag-card.invert p{color:var(--gray-3)}
.diag-card.invert .tier{color:var(--red)}
.tier{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--red);margin-bottom:24px;
  display:inline-flex;align-items:center;gap:10px;
}
.tier .dt{width:7px;height:7px;border-radius:50%;background:var(--red)}
.diag-card h3{font-size:24px;font-weight:600;letter-spacing:-0.02em;margin-bottom:14px;color:var(--charcoal)}
.diag-card p{color:var(--gray-2);font-size:15px;line-height:1.6;margin:0 0 24px;flex:1}
.diag-card .inline-arrow{margin-top:auto}
@media (max-width:900px){.diag-grid{grid-template-columns:1fr}}

/* TRUST */
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--hairline-dark);border-left:1px solid var(--hairline-dark);
}
.trust{
  padding:36px 28px;background:var(--charcoal-2);
  border-right:1px solid var(--hairline-dark);border-bottom:1px solid var(--hairline-dark);
  transition:background .25s var(--ease);
}
.trust:hover{background:rgba(255,255,255,0.02)}
.trust .lbl{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--gray-3);margin-bottom:32px;display:block;
}
.trust .lbl .n{color:var(--red)}
.trust h3{font-size:19px;font-weight:600;letter-spacing:-0.015em;margin-bottom:10px}
.trust p{margin:0;color:var(--gray-3);font-size:14px;line-height:1.55}
@media (max-width:1100px){.trust-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.trust-grid{grid-template-columns:1fr}}

/* CASE STUDY */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case-tile{
  background:var(--charcoal-2);border:1px solid var(--hairline-dark);
  border-radius:10px;overflow:hidden;
  transition:border-color .3s var(--ease),transform .3s var(--ease);
}
.case-tile:hover{border-color:rgba(227,30,36,0.45);transform:translateY(-3px)}
.case-img{
  position:relative;aspect-ratio:16/10;
  background:
    repeating-linear-gradient(135deg,rgba(255,255,255,0.04) 0 2px,transparent 2px 14px),
    linear-gradient(160deg,#1a1a1a,#0e0e0e);
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:18px 20px;
}
.case-img .tag{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--gray-3);
  padding:6px 10px;border:1px solid var(--hairline-dark);border-radius:4px;
  background:rgba(0,0,0,0.4);
}
.case-img .industry{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--white);
}
.case-body{padding:32px}
.case-body .row{display:grid;grid-template-columns:80px 1fr;gap:16px;font-size:13.5px;margin-bottom:14px;align-items:start}
.case-body .row:last-child{margin-bottom:0}
.case-body .k{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--red);padding-top:2px}
.case-body .v{color:var(--gray-3);line-height:1.55}
@media (max-width:900px){.case-grid{grid-template-columns:1fr}}

/* FINAL CTA */
.final-cta{
  background:var(--charcoal-3);position:relative;
  text-align:center;overflow:hidden;
}
.final-cta::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.04) 1px,transparent 1px);
  background-size:80px 80px;
  -webkit-mask-image:radial-gradient(ellipse at center,#000 20%,transparent 70%);
  mask-image:radial-gradient(ellipse at center,#000 20%,transparent 70%);
  pointer-events:none;
}
.final-cta::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at center,rgba(227,30,36,0.22),transparent 60%);
  pointer-events:none;
}
.final-cta .container{position:relative;z-index:2}
.final-cta h2{
  font-size:clamp(2.25rem,4.5vw,4rem);font-weight:800;
  letter-spacing:-0.035em;line-height:1.04;
  max-width:18ch;margin:24px auto 28px;
  text-wrap:balance;
}
.final-cta .lead{margin:0 auto 40px;max-width:62ch;text-align:center}
.final-cta .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* FOOTER */
footer{background:var(--near-black);color:var(--gray-3);padding:96px 0 32px;font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:48px;margin-bottom:64px}
.foot-brand .logo{margin-bottom:24px}
.foot-brand p{margin:0;color:var(--gray-3);line-height:1.6;max-width:32ch;font-size:14px}
.foot-col h4{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--white);margin-bottom:20px}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.foot-col a{color:var(--gray-3);transition:color .2s var(--ease)}
.foot-col a:hover{color:var(--white)}
.foot-contact .kv{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}
.foot-contact .kv .k{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--gray-2)}
.foot-contact .kv .v{color:var(--white);font-size:14px}
.foot-bottom{
  padding-top:24px;border-top:1px solid var(--hairline-dark);
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray-2);
}
.foot-bottom a{color:var(--gray-2)}
.foot-bottom a:hover{color:var(--white)}
.foot-bottom ul{list-style:none;padding:0;margin:0;display:flex;gap:24px}
@media (max-width:1100px){.foot-grid{grid-template-columns:1fr 1fr;gap:40px}}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr}}

/* Mobile breakpoints */
@media (max-width:1100px){
  :root{--section-y:100px}
  .nav-inner > .nav-links,
  .nav-cta .btn{display:none}
  .hamb{display:inline-flex}
  .drawer .nav-links{display:flex}
}
@media (max-width:760px){
  :root{--section-y:80px;--gutter:20px}
  body{font-size:15px}
  .logo img{height:30px;max-width:170px;object-fit:contain}
  .hero{padding-block:110px 80px}
  .hero-ctas .btn{flex:1;justify-content:center}
}
@media (max-width:520px){
  .hero-ctas,
  .sub-hero-ctas,
  .ctas{flex-direction:column}
  .hero-ctas .btn,
  .sub-hero-ctas .btn,
  .ctas .btn{width:100%;justify-content:center;white-space:normal;text-align:center}
}
@media (max-width:420px){
  .h-display{font-size:clamp(2rem,10vw,2.45rem);line-height:1.06;letter-spacing:-0.035em}
  .hero h1 .accent-underline{display:inline;white-space:normal}
  .sub-hero h1{font-size:clamp(2rem,10vw,2.4rem);line-height:1.08;letter-spacing:-0.035em}
}
@media (max-width:360px){
  .logo img{height:28px;max-width:150px}
}

/* =================== SUBPAGE STYLES =================== */

/* Subpage hero (smaller than homepage hero) */
.sub-hero{
  position:relative;background:var(--charcoal-3);overflow:hidden;
  padding-block:120px 80px;
}
.sub-hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.045) 1px,transparent 1px);
  background-size:80px 80px;
  -webkit-mask-image:radial-gradient(ellipse at 65% 40%,#000 30%,transparent 80%);
  mask-image:radial-gradient(ellipse at 65% 40%,#000 30%,transparent 80%);
  pointer-events:none;
}
.sub-hero::after{
  content:"";position:absolute;top:-15%;right:-12%;
  width:55%;height:70%;
  background:radial-gradient(circle at center,rgba(227,30,36,0.16),transparent 65%);
  pointer-events:none;
}
.sub-hero-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:64px;align-items:center;
  position:relative;z-index:2;
}
.sub-hero h1{
  font-weight:800;font-size:clamp(2.25rem,4.6vw,4rem);
  letter-spacing:-0.035em;line-height:1.04;
  margin:24px 0 24px;text-wrap:balance;
}
.sub-hero .lead{font-size:19px;margin-bottom:32px;max-width:60ch}
.sub-hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.sub-hero-media{
  position:relative;aspect-ratio:5/4;border-radius:12px;overflow:hidden;
  border:1px solid var(--hairline-dark);
}
.sub-hero-media img{width:100%;height:100%;object-fit:cover;display:block;
  filter:brightness(.72) contrast(1.05) saturate(.9);
}
.sub-hero-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(14,14,14,.55) 100%),
             linear-gradient(135deg,rgba(227,30,36,.10),transparent 45%);
  pointer-events:none;
}
.sub-hero-media .overlay-tags{
  position:absolute;left:18px;bottom:18px;display:flex;gap:8px;flex-wrap:wrap;z-index:2;
}
.sub-hero-media .tag-pill{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--white);
  padding:5px 9px;border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.45);backdrop-filter:blur(8px);border-radius:4px;
  display:inline-flex;align-items:center;gap:6px;
}
.sub-hero-media .tag-pill .dt{width:6px;height:6px;border-radius:50%;background:var(--red)}
.sub-hero-media .corner-mark{
  position:absolute;top:16px;right:16px;display:flex;flex-direction:column;gap:6px;
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--gray-3);text-align:right;z-index:2;
}
.sub-hero-media .corner-mark .v{color:var(--white)}

@media (max-width:1100px){
  .sub-hero-grid{grid-template-columns:1fr;gap:40px}
  .sub-hero-media{aspect-ratio:16/10}
}

/* Crumbs */
.crumbs{
  display:flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--gray-3);
}
.crumbs a{color:var(--gray-3);transition:color .2s var(--ease)}
.crumbs a:hover{color:var(--white)}
.crumbs .sep{color:var(--red)}
.on-light .crumbs{color:var(--gray-2)}
.on-light .crumbs a{color:var(--gray-2)}
.on-light .crumbs a:hover{color:var(--charcoal)}

/* Two-column problem/solution layout */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.split h2{margin-bottom:24px}
.split .lead{margin-bottom:0}
.split-stat{
  display:flex;align-items:baseline;gap:14px;padding-top:20px;
  border-top:1px solid var(--hairline-dark);margin-top:32px;
}
.on-light .split-stat{border-top-color:var(--hairline-light)}
.split-stat .n{font-size:36px;font-weight:700;letter-spacing:-0.03em;color:var(--red)}
.split-stat .l{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--gray-3)}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:40px}}

/* Capability grid (icon cards) */
.cap-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--hairline-dark);
  border-left:1px solid var(--hairline-dark);
}
.cap{
  padding:36px 32px;
  border-right:1px solid var(--hairline-dark);
  border-bottom:1px solid var(--hairline-dark);
  display:flex;flex-direction:column;gap:14px;
  transition:background .25s var(--ease),transform .25s var(--ease);
  position:relative;
}
.cap::before{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--red);
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);
}
.cap:hover::before{transform:scaleX(1)}
.cap:hover{background:rgba(255,255,255,0.02)}
.cap .icon-block{margin-bottom:6px}
.cap h3{font-size:19px;font-weight:600;letter-spacing:-0.015em}
.cap p{margin:0;color:var(--gray-3);font-size:14.5px;line-height:1.55}
.on-light .cap-grid{border-color:var(--hairline-light)}
.on-light .cap{border-color:var(--hairline-light);background:#FAFAFA}
.on-light .cap:hover{background:#F5F5F5}
.on-light .cap p{color:var(--gray-2)}
@media (max-width:1100px){.cap-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.cap-grid{grid-template-columns:1fr}}

/* Use-case media row (photo + text rows) */
.uc-row{
  display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;
  padding-block:64px;border-top:1px solid var(--hairline-dark);
}
.uc-row:first-child{border-top:0;padding-top:24px}
.uc-row.flip{grid-template-columns:1fr 1.05fr}
.uc-row.flip .uc-media{order:2}
.uc-row.flip .uc-text{order:1}
.on-light .uc-row{border-top-color:var(--hairline-light)}
.uc-media{
  position:relative;aspect-ratio:5/3;border-radius:10px;overflow:hidden;
  border:1px solid var(--hairline-dark);
}
.uc-media img{width:100%;height:100%;object-fit:cover;display:block;
  filter:brightness(.78) contrast(1.05) saturate(.9);
}
.uc-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(14,14,14,.5));
  pointer-events:none;
}
.uc-media .marker{
  position:absolute;font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--white);background:rgba(0,0,0,.55);backdrop-filter:blur(6px);
  padding:5px 9px;border:1px solid rgba(255,255,255,.16);border-radius:4px;
  display:inline-flex;align-items:center;gap:6px;
}
.uc-media .marker .dt{width:6px;height:6px;border-radius:50%;background:var(--red)}
.uc-text .eyebrow{margin-bottom:16px}
.uc-text h3{font-size:28px;font-weight:700;letter-spacing:-0.025em;line-height:1.15;margin-bottom:16px}
.uc-text p{color:var(--gray-3);font-size:16px;line-height:1.65;margin:0 0 20px}
.on-light .uc-text p{color:var(--gray-2)}
.uc-text ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.uc-text ul li{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--gray-3)}
.on-light .uc-text ul li{color:var(--gray-2)}
.uc-text ul li::before{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--red);
  flex-shrink:0;margin-top:8px;
}
@media (max-width:900px){
  .uc-row,.uc-row.flip{grid-template-columns:1fr;gap:28px}
  .uc-row.flip .uc-media{order:0}.uc-row.flip .uc-text{order:1}
}

/* Outcomes (bold stats / metric strip) */
.outcomes{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--hairline-dark);
  border-left:1px solid var(--hairline-dark);
}
.outcome{
  padding:40px 32px;
  border-right:1px solid var(--hairline-dark);border-bottom:1px solid var(--hairline-dark);
  transition:background .25s var(--ease);
}
.outcome:hover{background:rgba(255,255,255,0.02)}
.outcome .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--red);margin-bottom:16px;display:block}
.outcome h3{font-size:18px;font-weight:600;letter-spacing:-0.015em;margin-bottom:8px}
.outcome p{margin:0;color:var(--gray-3);font-size:14px;line-height:1.55}

/* Defensive alias for manually-authored Training & Education outcome cards. */
.out{
  padding:40px 32px;
  border-right:1px solid var(--hairline-dark);border-bottom:1px solid var(--hairline-dark);
  transition:background .25s var(--ease);
}
.out:hover{background:rgba(255,255,255,0.02)}
.out span:first-child{font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--red);margin-bottom:16px;display:block}
.out h3{font-size:18px;font-weight:600;letter-spacing:-0.015em;margin-bottom:8px}
.out p{margin:0;color:var(--gray-3);font-size:14px;line-height:1.55}
.on-light .outcomes{border-color:var(--hairline-light)}
.on-light .outcome{border-color:var(--hairline-light);background:#FAFAFA}
.on-light .outcome:hover{background:#F5F5F5}
.on-light .outcome p{color:var(--gray-2)}
@media (max-width:1100px){.outcomes{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.outcomes{grid-template-columns:1fr}}

/* Related (3 cards) */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rel-card{
  background:var(--charcoal-2);border:1px solid var(--hairline-dark);
  border-radius:10px;padding:32px;
  transition:transform .3s var(--ease),border-color .3s var(--ease);
  display:flex;flex-direction:column;gap:14px;min-height:240px;
}
.rel-card:hover{transform:translateY(-3px);border-color:rgba(227,30,36,.5)}
.rel-card .kind{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--red)}
.rel-card h3{font-size:22px;font-weight:600;letter-spacing:-0.015em}
.rel-card p{margin:0;color:var(--gray-3);font-size:14.5px;line-height:1.55;flex:1}
.rel-card .inline-arrow{margin-top:auto}
@media (max-width:900px){.related-grid{grid-template-columns:1fr}}

/* Trust strip (small icons row) */
.trust-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
  padding:48px 0;border-block:1px solid var(--hairline-dark);
}
.trust-item{display:flex;flex-direction:column;gap:8px}
.trust-item .icn{width:24px;height:24px;color:var(--red)}
.trust-item h4{font-size:15px;font-weight:600;letter-spacing:-0.01em;color:var(--white)}
.trust-item p{margin:0;color:var(--gray-3);font-size:13.5px;line-height:1.5}
.on-light .trust-strip{border-color:var(--hairline-light)}
.on-light .trust-item h4{color:var(--charcoal)}
.on-light .trust-item p{color:var(--gray-2)}
@media (max-width:900px){.trust-strip{grid-template-columns:repeat(2,1fr)}}

/* Quote / pull quote */
.pull{
  padding:48px;border:1px solid var(--hairline-dark);border-radius:12px;
  background:linear-gradient(135deg,var(--charcoal-2),var(--charcoal-3));
  position:relative;overflow:hidden;
}
.pull::before{
  content:"\201C";position:absolute;top:-20px;left:24px;
  font-size:120px;color:var(--red);opacity:.18;font-family:'Poppins';
  font-weight:800;line-height:1;
}
.pull blockquote{
  margin:0;font-size:22px;font-weight:500;letter-spacing:-0.015em;
  line-height:1.35;max-width:48ch;
}
.pull cite{
  display:block;margin-top:20px;font-style:normal;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--gray-3);
}

/* Data sources / chips (used on RevUtil, others) */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:999px;
  background:rgba(255,255,255,.03);border:1px solid var(--hairline-dark);
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--gray-3);
}
.chip .dt{width:7px;height:7px;border-radius:50%;background:var(--red)}
.on-light .chip{background:#fff;border-color:var(--hairline-light);color:var(--gray-2)}


/* =================== CONTENT / LEGAL / CONTACT PAGES =================== */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.info-card{background:var(--charcoal-2);border:1px solid var(--hairline-dark);border-radius:10px;padding:32px;min-height:220px}
.info-card h3{font-size:22px;font-weight:600;letter-spacing:-0.015em;margin-bottom:12px}
.info-card p{margin:0;color:var(--gray-3);font-size:14.5px;line-height:1.6}
.on-light .info-card{background:#FAFAFA;border-color:var(--hairline-light)}
.on-light .info-card p{color:var(--gray-2)}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.contact-card,.contact-form,.legal-panel{border:1px solid var(--hairline-dark);background:var(--charcoal-2);border-radius:12px;padding:36px}
.contact-card h3,.contact-form h3{font-size:24px;margin-bottom:16px}
.contact-method{padding:18px 0;border-top:1px solid var(--hairline-dark)}
.contact-method:first-of-type{border-top:0}
.contact-method .k{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:6px}
.contact-method .v{color:var(--white);line-height:1.55}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.field label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-3)}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--hairline-dark);background:rgba(255,255,255,.04);color:var(--white);border-radius:6px;padding:14px 14px;font:inherit;min-height:48px}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--red);outline-offset:1px}
.field select option{background:var(--charcoal);color:var(--white)}
.form-note{font-size:13px;color:var(--gray-3);margin:14px 0 0}
.legal-wrap{display:grid;grid-template-columns:280px 1fr;gap:56px;align-items:start}
.legal-nav{position:sticky;top:100px;border:1px solid var(--hairline-dark);border-radius:10px;padding:20px;background:var(--charcoal-2)}
.legal-nav a{display:block;color:var(--gray-3);padding:9px 0;font-size:14px;border-bottom:1px solid var(--hairline-dark)}
.legal-nav a:last-child{border-bottom:0}
.legal-nav a:hover{color:var(--white)}
.legal-panel h2{font-size:30px;margin:40px 0 14px;letter-spacing:-.025em}
.legal-panel h2:first-child{margin-top:0}
.legal-panel p,.legal-panel li{color:var(--gray-3);line-height:1.75}
.legal-panel ul{padding-left:20px}
.legal-panel .updated{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:28px}
.notice-box{border:1px solid rgba(227,30,36,.28);background:rgba(227,30,36,.08);border-radius:10px;padding:20px;color:var(--gray-4);margin-top:24px}
.anchor-offset{scroll-margin-top:100px}
@media (max-width:1000px){.info-grid{grid-template-columns:1fr 1fr}.contact-grid,.legal-wrap{grid-template-columns:1fr}.legal-nav{position:static}.form-row{grid-template-columns:1fr}}
@media (max-width:700px){.info-grid{grid-template-columns:1fr}.contact-card,.contact-form,.legal-panel{padding:24px}}

/* =================== PREMIUM MOTION SYSTEM ===================
   Purpose-built motion for Digitalogia's grid, card, process and data-visual language.
   Motion is intentionally subtle, transform/clip-path based, and disabled for reduced motion.
=============================================================== */
:root{
  --motion-slow:900ms;
  --motion-med:680ms;
  --motion-fast:320ms;
  --motion-ease:cubic-bezier(.16,1,.3,1);
  --motion-ease-out:cubic-bezier(.22,.61,.36,1);
}

@media (prefers-reduced-motion: no-preference){
  html.motion-enabled .nav{
    animation:nav-settle var(--motion-med) var(--motion-ease) both;
  }

  .hero::before,
  .sub-hero::before,
  .final-cta::before{
    animation:grid-drift 28s linear infinite alternate;
    will-change:background-position;
  }

  .hero::after,
  .sub-hero::after,
  .final-cta::after{
    animation:soft-red-breathe 9s var(--motion-ease-out) infinite alternate;
    will-change:transform,opacity;
  }

  .tele{
    transition:transform var(--motion-med) var(--motion-ease),border-color var(--motion-med) var(--motion-ease),background var(--motion-med) var(--motion-ease);
  }
  .hero-illus:hover .tele-1{transform:translate3d(4px,-4px,0)}
  .hero-illus:hover .tele-2{transform:translate3d(-5px,3px,0)}
  .hero-illus:hover .tele-3{transform:translate3d(5px,5px,0)}

  .reveal{
    opacity:0;
    transform:translate3d(0,10px,0) scale(.992);
    clip-path:inset(0 0 14% 0 round 0px);
    filter:blur(1px);
    transition:
      opacity var(--motion-med) var(--motion-ease),
      transform var(--motion-med) var(--motion-ease),
      clip-path var(--motion-slow) var(--motion-ease),
      filter var(--motion-med) var(--motion-ease);
    will-change:opacity,transform,clip-path,filter;
  }
  .reveal.in{
    opacity:1;
    transform:none;
    clip-path:inset(0 0 0 0 round 0px);
    filter:none;
    will-change:auto;
  }

  /* Typography enters horizontally like a technical layout being assembled, not a generic fade-up. */
  .h-display.reveal,
  .h-section.reveal,
  .sub-hero h1.reveal,
  .final-cta h2.reveal{
    transform:translate3d(-18px,0,0);
    clip-path:inset(0 18% 0 0);
    filter:none;
  }
  .h-display.reveal.in,
  .h-section.reveal.in,
  .sub-hero h1.reveal.in,
  .final-cta h2.reveal.in{transform:none;clip-path:inset(0 0 0 0)}

  .hero-sub.reveal,
  .lead.reveal{
    transform:translate3d(18px,0,0);
    clip-path:inset(0 0 0 12%);
  }
  .hero-sub.reveal.in,
  .lead.reveal.in{transform:none;clip-path:inset(0 0 0 0)}

  .eyebrow.reveal,
  .hero-meta.reveal{
    transform:translate3d(-12px,0,0);
    clip-path:inset(0 35% 0 0);
    filter:none;
  }
  .eyebrow.reveal.in,
  .hero-meta.reveal.in{transform:none;clip-path:inset(0 0 0 0)}
  .eyebrow::before{transform-origin:left;transition:transform var(--motion-med) var(--motion-ease)}
  .eyebrow.reveal:not(.in)::before{transform:scaleX(0)}
  .eyebrow.reveal.in::before{transform:scaleX(1)}

  /* Hero underline draws like an execution marker after the headline locks into place. */
  .hero h1 .accent-underline::after{
    transform:scaleX(0);
    transition:transform 820ms var(--motion-ease) 340ms;
  }
  .hero h1.in .accent-underline::after{transform:scaleX(.92)}

  /* Grid modules wipe into place from their structural edge. */
  .value-cell.reveal,
  .sol-card.reveal,
  .pod.reveal,
  .eng-card.reveal,
  .ind.reveal,
  .diag-card.reveal,
  .trust.reveal,
  .case-tile.reveal,
  .cap.reveal,
  .outcome.reveal,
  .rel-card.reveal,
  .info-card.reveal,
  .trust-item.reveal{
    transform:none;
    clip-path:inset(0 0 100% 0);
    filter:none;
  }
  .value-cell.reveal.in,
  .sol-card.reveal.in,
  .pod.reveal.in,
  .eng-card.reveal.in,
  .ind.reveal.in,
  .diag-card.reveal.in,
  .trust.reveal.in,
  .case-tile.reveal.in,
  .cap.reveal.in,
  .outcome.reveal.in,
  .rel-card.reveal.in,
  .info-card.reveal.in,
  .trust-item.reveal.in{clip-path:inset(0 0 0 0)}

  .product-card.reveal,
  .sub-hero-media.reveal,
  .uc-media.reveal,
  .pull.reveal,
  .contact-card.reveal,
  .contact-form.reveal,
  .legal-panel.reveal{
    transform:perspective(900px) rotateX(2deg) translate3d(0,18px,0);
    clip-path:inset(0 0 10% 0 round 12px);
    filter:none;
  }
  .product-card.reveal.in,
  .sub-hero-media.reveal.in,
  .uc-media.reveal.in,
  .pull.reveal.in,
  .contact-card.reveal.in,
  .contact-form.reveal.in,
  .legal-panel.reveal.in{transform:none;clip-path:inset(0 0 0 0 round 12px)}

  .hero-illus.reveal{
    transform:translate3d(20px,0,0) scale(.985);
    clip-path:inset(0 0 0 18%);
    filter:none;
  }
  .hero-illus.reveal.in{transform:none;clip-path:inset(0 0 0 0)}

  /* Process motion: track draws first, steps lock in along the line. */
  .process-track::before{
    transform:scaleX(0);
    transform-origin:left center;
    transition:transform 1250ms var(--motion-ease);
  }
  .process-track.line-in::before{transform:scaleX(1)}
  .step.reveal{
    transform:translate3d(-14px,0,0);
    clip-path:inset(0 25% 0 0);
    filter:none;
  }
  .step.reveal.in{transform:none;clip-path:inset(0 0 0 0)}
  .step .dot{transition:transform var(--motion-med) var(--motion-ease),color var(--motion-med) var(--motion-ease),border-color var(--motion-med) var(--motion-ease),box-shadow var(--motion-med) var(--motion-ease)}
  .step.in .dot{box-shadow:0 0 0 1px rgba(227,30,36,.18),0 18px 40px -28px rgba(227,30,36,.75)}

  @media (max-width:900px){
    .process-track::before{
      transform:scaleY(0);
      transform-origin:top center;
    }
    .process-track.line-in::before{transform:scaleY(1)}
  }

  /* Red rails and card chrome emphasize Digitalogia's modular layout system. */
  .sol-card::before,
  .cap::before{transition:transform var(--motion-med) var(--motion-ease)}
  .sol-card.in::before,
  .cap.in::before{transform:scaleX(.18)}
  .sol-card.in:hover::before,
  .cap.in:hover::before{transform:scaleX(1)}

  .eng-card::before{
    transition:transform var(--motion-med) var(--motion-ease);
  }
  .eng-card.in::before{transform:scaleY(.28)}
  .eng-card.in:hover::before{transform:scaleY(1)}

  .uc-media .marker,
  .sub-hero-media .tag-pill,
  .sub-hero-media .corner-mark{
    transition:transform var(--motion-med) var(--motion-ease),opacity var(--motion-med) var(--motion-ease);
  }
  .uc-media:hover .marker,
  .sub-hero-media:hover .tag-pill{transform:translate3d(2px,-2px,0)}

  .btn{
    position:relative;
    isolation:isolate;
    overflow:hidden;
  }
  .btn::after{
    content:"";position:absolute;inset:-1px;
    background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.14) 42%,transparent 58%);
    transform:translateX(-120%);
    transition:transform 720ms var(--motion-ease);
    z-index:-1;
    pointer-events:none;
  }
  .btn:hover::after{transform:translateX(120%)}

  .icon-block,
  .pod .icn,
  .ind .icn,
  .trust-item .icn{
    transition:transform var(--motion-fast) var(--motion-ease),box-shadow var(--motion-fast) var(--motion-ease);
  }
  .sol-card:hover .icon-block,
  .cap:hover .icon-block,
  .pod:hover .icn,
  .ind:hover .icn,
  .trust-item:hover .icn{transform:translate3d(0,-2px,0)}
}

@keyframes nav-settle{
  from{opacity:0;transform:translate3d(0,-10px,0)}
  to{opacity:1;transform:none}
}
@keyframes grid-drift{
  from{background-position:0 0,0 0}
  to{background-position:80px 40px,40px 80px}
}
@keyframes soft-red-breathe{
  from{opacity:.72;transform:scale(1)}
  to{opacity:1;transform:scale(1.04)}
}

/* Final reduced-motion safety net. Keeps layout visible and removes non-essential motion. */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:0.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.001ms!important;
    scroll-behavior:auto!important;
  }
  .reveal{opacity:1!important;transform:none!important;filter:none!important;clip-path:none!important}
  .process-track::before{transform:none!important}
}

/* ===============================================================
   Motion stability patch
   The previous motion layer used clip-path masks on live layout modules.
   This keeps the premium choreography but removes clipping/cropping risk.
   Content remains visible by default; reveal motion is opt-in only after JS adds
   html.motion-enabled, so the page cannot appear broken if JS is delayed.
=============================================================== */
.reveal,
.reveal.in{
  opacity:1;
  transform:none;
  filter:none;
  clip-path:none!important;
}

@media (prefers-reduced-motion: no-preference){
  html.motion-enabled .reveal:not(.in){
    opacity:0;
    transform:translate3d(0,12px,0) scale(.998);
    filter:none;
    clip-path:none!important;
    transition:
      opacity var(--motion-med) var(--motion-ease),
      transform var(--motion-med) var(--motion-ease),
      border-color var(--motion-fast) var(--motion-ease),
      background var(--motion-fast) var(--motion-ease),
      box-shadow var(--motion-fast) var(--motion-ease);
    will-change:opacity,transform;
  }

  html.motion-enabled .reveal.in{
    opacity:1;
    transform:none;
    filter:none;
    clip-path:none!important;
    will-change:auto;
  }

  html.motion-enabled .h-display.reveal:not(.in),
  html.motion-enabled .h-section.reveal:not(.in),
  html.motion-enabled .sub-hero h1.reveal:not(.in),
  html.motion-enabled .final-cta h2.reveal:not(.in){
    transform:translate3d(-14px,0,0);
  }

  html.motion-enabled .hero-sub.reveal:not(.in),
  html.motion-enabled .lead.reveal:not(.in){
    transform:translate3d(14px,0,0);
  }

  html.motion-enabled .eyebrow.reveal:not(.in),
  html.motion-enabled .hero-meta.reveal:not(.in){
    transform:translate3d(-10px,0,0);
  }

  html.motion-enabled .hero-illus.reveal:not(.in),
  html.motion-enabled .sub-hero-media.reveal:not(.in),
  html.motion-enabled .uc-media.reveal:not(.in){
    transform:translate3d(18px,0,0) scale(.992);
  }

  html.motion-enabled .product-card.reveal:not(.in),
  html.motion-enabled .pull.reveal:not(.in),
  html.motion-enabled .contact-card.reveal:not(.in),
  html.motion-enabled .contact-form.reveal:not(.in),
  html.motion-enabled .legal-panel.reveal:not(.in){
    transform:perspective(900px) rotateX(1deg) translate3d(0,14px,0);
  }

  html.motion-enabled .value-cell.reveal:not(.in),
  html.motion-enabled .sol-card.reveal:not(.in),
  html.motion-enabled .pod.reveal:not(.in),
  html.motion-enabled .eng-card.reveal:not(.in),
  html.motion-enabled .ind.reveal:not(.in),
  html.motion-enabled .diag-card.reveal:not(.in),
  html.motion-enabled .trust.reveal:not(.in),
  html.motion-enabled .case-tile.reveal:not(.in),
  html.motion-enabled .cap.reveal:not(.in),
  html.motion-enabled .outcome.reveal:not(.in),
  html.motion-enabled .rel-card.reveal:not(.in),
  html.motion-enabled .info-card.reveal:not(.in),
  html.motion-enabled .trust-item.reveal:not(.in){
    transform:translate3d(0,10px,0) scale(.997);
  }

  html.motion-enabled .step.reveal:not(.in){
    transform:translate3d(-10px,0,0);
  }

  @media (max-width:760px){
    html.motion-enabled .h-display.reveal:not(.in),
    html.motion-enabled .h-section.reveal:not(.in),
    html.motion-enabled .sub-hero h1.reveal:not(.in),
    html.motion-enabled .final-cta h2.reveal:not(.in),
    html.motion-enabled .hero-sub.reveal:not(.in),
    html.motion-enabled .lead.reveal:not(.in),
    html.motion-enabled .eyebrow.reveal:not(.in),
    html.motion-enabled .hero-meta.reveal:not(.in),
    html.motion-enabled .hero-illus.reveal:not(.in),
    html.motion-enabled .sub-hero-media.reveal:not(.in),
    html.motion-enabled .uc-media.reveal:not(.in),
    html.motion-enabled .step.reveal:not(.in){
      transform:translate3d(0,10px,0);
    }
  }
}

@media (prefers-reduced-motion: reduce){
  .reveal,
  .reveal.in{
    opacity:1!important;
    transform:none!important;
    filter:none!important;
    clip-path:none!important;
  }
}


/* Refinement after removing the homepage buffer strip */
#solutions{
  background:linear-gradient(180deg,var(--charcoal-3) 0%,var(--charcoal) 34%,var(--charcoal) 100%);
  border-top:1px solid var(--hairline-dark);
}
#solutions .sec-head{margin-top:0}
.nav .logo img{height:36px;max-width:220px;object-fit:contain}
@media (max-width:760px){.nav .logo img{height:30px;max-width:168px}}
@media (max-width:360px){.nav .logo img{height:28px;max-width:150px}}


/* Contact form production behavior */
.hp-field{position:absolute!important;left:-10000px!important;width:1px!important;height:1px!important;overflow:hidden!important;opacity:0!important;pointer-events:none!important;}
.form-status{min-height:1.5rem;margin:16px 0 0;color:var(--muted);font-size:.92rem;line-height:1.55;}
.form-status.ok{color:#b9f5cf;}
.form-status.error{color:#ffb4ad;}
.contact-form button[disabled]{opacity:.65;cursor:wait;transform:none!important;}
.form-note code{font-family:'JetBrains Mono',monospace;font-size:.88em;color:var(--red-2);}

/* Stock photo resilience: visual images use curated stock photos with local SVG fallbacks. */
.uc-media img[data-fallback], .sub-hero-media img[data-fallback]{background:linear-gradient(135deg,rgba(227,30,36,.12),rgba(255,255,255,.04));}

/* Footer logo refinement */
.site-footer .foot-brand .logo{display:inline-flex;align-items:center;line-height:0;margin-bottom:22px}
.site-footer .foot-brand .logo img{display:block;height:64px;max-width:240px;width:auto;object-fit:contain;object-position:left center}
@media (max-width:760px){.site-footer .foot-brand .logo img{height:56px;max-width:210px}}
