.elementor-128 .elementor-element.elementor-element-c29faac{--display:flex;}body.elementor-page-128:not(.elementor-motion-effects-element-type-background), body.elementor-page-128 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#1C1F27;}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-0846932 */html,
body {
  overflow-x: hidden;
}

.elementor-widget-html,
.elementor-widget-html > .elementor-widget-container,
.elementor-widget-html .elementor-widget-container {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.npt-page {
  --color-obsidian: #0f1419;
  --color-charcoal: #131920;
  --color-charcoal-2: #1a2129;
  --color-refined-white: #f5f5f5;
  --color-platinum: #bfbfbf;
  --color-silver-mist: #8a8a8a;
  --color-gold: #d4af37;
  --color-gold-bright: #e6c95d;
  --color-gold-deep: #b89422;
  --color-emerald: #2d5a4e;
  --color-edge: rgba(212, 175, 55, 0.14);
  --color-edge-strong: rgba(212, 175, 55, 0.28);
  --shadow-soft: 0 14px 34px rgba(0, 0, 0, 0.2);
  --shadow-panel: 0 24px 70px rgba(0, 0, 0, 0.34);
  --shadow-gold: 0 18px 40px rgba(212, 175, 55, 0.14);
  --radius-sm: 12px;
  --radius-md: 16px;
  --radius-lg: 22px;
  --radius-xl: 30px;
  --shell-width: min(1240px, calc(100% - 48px));
  --transition-fast: 200ms ease;
  --transition-base: 280ms ease;
  --transition-slow: 680ms cubic-bezier(0.22, 1, 0.36, 1);
  --font-body: "Inter", sans-serif;
  --font-display: "Space Grotesk", "Inter", sans-serif;
  position: relative;
  display: block;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  max-width: 100vw;
  margin: 0 !important;
  padding: 0 !important;
  isolation: isolate;
  overflow: clip;
  color: var(--color-platinum);
  font-family: var(--font-body);
  background: linear-gradient(180deg, #0f1419 0%, #121820 46%, #0f1419 100%);
  -webkit-tap-highlight-color: rgba(212, 175, 55, 0.14);
}

.npt-page *,
.npt-page *::before,
.npt-page *::after {
  box-sizing: border-box;
}

.npt-page::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.018), transparent 18%),
    radial-gradient(circle at top left, rgba(212,175,55,0.035), transparent 24%);
  opacity: 0.9;
}

.npt-page ::selection {
  background: rgba(212, 175, 55, 0.22);
  color: var(--color-refined-white);
}

.npt-page a {
  color: inherit;
  text-decoration: none;
}

.npt-page img {
  display: block;
  max-width: 100%;
}

.npt-page button,
.npt-page input,
.npt-page textarea,
.npt-page select {
  font: inherit;
  -webkit-tap-highlight-color: rgba(212, 175, 55, 0.14);
}

.npt-page .hub-shell {
  width: min(var(--shell-width), 100%);
  margin-inline: auto;
}

.npt-page .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.npt-page .hub-stage {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.npt-page .hub-stage__grid {
  position: absolute;
  inset: 0;
  opacity: 0.14;
  background-image:
    linear-gradient(rgba(212, 175, 55, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212, 175, 55, 0.03) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(circle at 50% 12%, black 10%, rgba(0, 0, 0, 0.76) 38%, transparent 86%);
  animation: nptGridShift 40s linear infinite;
}

.npt-page .hub-stage__orb,
.npt-page .hub-stage__smoke {
  position: absolute;
  border-radius: 999px;
}

.npt-page .hub-stage__orb--gold {
  top: 90px;
  right: -110px;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, rgba(212, 175, 55, 0.14), transparent 70%);
  filter: blur(18px);
  animation: nptFloat 20s ease-in-out infinite;
}

.npt-page .hub-stage__orb--emerald {
  top: 140px;
  left: -120px;
  width: 440px;
  height: 240px;
  background: radial-gradient(circle, rgba(212, 175, 55, 0.08), rgba(255, 255, 255, 0.03) 38%, transparent 76%);
  filter: blur(40px);
  animation: nptFloat 18s ease-in-out infinite reverse;
}

.npt-page .hub-stage__smoke {
  top: 120px;
  left: 0;
  width: 520px;
  height: 150px;
  opacity: 0.2;
  filter: blur(52px);
  background:
    radial-gradient(circle at 20% 50%, rgba(255,255,255,0.06), transparent 18%),
    radial-gradient(circle at 54% 50%, rgba(212,175,55,0.10), transparent 24%),
    radial-gradient(circle at 80% 48%, rgba(255,255,255,0.04), transparent 18%);
  animation: nptSmoke 24s ease-in-out infinite;
}

.npt-page .hub-stage__watermark {
  position: absolute;
  top: 140px;
  right: 4%;
  width: 420px;
  height: 420px;
  opacity: 0.1;
  transform: rotate(-6deg);
}

.npt-page .hub-stage__watermark svg {
  width: 100%;
  height: 100%;
  display: block;
}

.npt-page .hub-stage__watermark .o {
  fill: none;
  stroke: rgba(212, 175, 55, 0.09);
  stroke-width: 1.2;
}

.npt-page .hub-stage__watermark .i {
  fill: rgba(212, 175, 55, 0.02);
  stroke: rgba(212, 175, 55, 0.05);
  stroke-width: 1;
}

.npt-page .hub-stage__watermark .c {
  fill: none;
  stroke: rgba(212, 175, 55, 0.07);
  stroke-width: 1;
}

.npt-page .section {
  position: relative;
  z-index: 1;
  padding: 88px 0;
}

.npt-page .section--tight {
  padding: 28px 0;
}

.npt-page .section--soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.015), rgba(255,255,255,0));
}

.npt-page #overview,
.npt-page #why-vulnosis,
.npt-page #deliverables,
.npt-page #general-form {
  isolation: isolate;
}

.npt-page #overview::before,
.npt-page #why-vulnosis::before,
.npt-page #deliverables::before,
.npt-page #general-form::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(212, 175, 55, 0), rgba(212, 175, 55, 0.46), rgba(212, 175, 55, 0));
  opacity: 0.58;
  animation: nptSectionScan 11s linear infinite;
  pointer-events: none;
}

.npt-page .hero__copy,
.npt-page .section-heading,
.npt-page .overview-layout__copy,
.npt-page .audience-layout__intro,
.npt-page .final-cta__panel {
  position: relative;
  z-index: 1;
}

.npt-page .section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 18px;
  color: var(--color-gold);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.npt-page .section-kicker::before {
  content: "";
  width: 36px;
  height: 1px;
  background: linear-gradient(90deg, var(--color-gold), rgba(212, 175, 55, 0));
}

.npt-page .section-title,
.npt-page .hero__title,
.npt-page h3 {
  color: var(--color-refined-white);
}

.npt-page .section-title {
  margin: 0 0 16px;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.8vw, 3.7rem);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.npt-page .section-copy,
.npt-page .hero__lede {
  margin: 0;
  max-width: 760px;
  color: var(--color-platinum);
  font-size: 1.02rem;
  line-height: 1.84;
}

.npt-page .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0.9rem 1.6rem;
  border: 1px solid transparent;
  border-radius: 16px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.01em;
  transition:
    transform var(--transition-fast),
    background var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    color var(--transition-fast);
}

.npt-page .button:hover {
  transform: translateY(-2px);
}

.npt-page .button:focus-visible,
.npt-page .faq-trigger:focus-visible,
.npt-page .inline-link:focus-visible {
  outline: 2px solid rgba(212, 175, 55, 0.56);
  outline-offset: 3px;
}

.npt-page .button--primary {
  color: #0a0d11;
  background: linear-gradient(180deg, var(--color-gold-bright) 0%, var(--color-gold) 100%);
  border-color: rgba(212, 175, 55, 0.92);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.2), 0 14px 30px rgba(212,175,55,0.24);
}

.npt-page .button--primary:hover,
.npt-page .button--primary:focus-visible {
  background: linear-gradient(180deg, #f0d87a 0%, var(--color-gold-deep) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.22), 0 18px 36px rgba(212,175,55,0.28);
}

.npt-page .button--secondary {
  color: var(--color-refined-white);
  background: rgba(255,255,255,0.04);
  border-color: rgba(212,175,55,0.28);
}

.npt-page .button--secondary:hover,
.npt-page .button--secondary:focus-visible {
  background: rgba(212,175,55,0.08);
  border-color: rgba(212,175,55,0.48);
}

.npt-page .inline-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--color-gold);
  font-weight: 600;
  font-size: 0.92rem;
}

.npt-page .inline-link::after {
  content: "\2197";
}

.npt-page .inline-link--text {
  display: inline;
  margin: 0 0.15rem;
  font-size: inherit;
  font-weight: 600;
}

.npt-page .inline-link--text::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 1px;
  vertical-align: middle;
}

.npt-page .hub-surface {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--color-edge);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.045), rgba(255,255,255,0.012)),
    linear-gradient(180deg, rgba(19,25,32,0.82), rgba(19,25,32,0.64));
  box-shadow: var(--shadow-panel);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.npt-page .hub-surface::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,0.03);
  pointer-events: none;
}

.npt-page .hub-hover {
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
  will-change: transform;
}

.npt-page .hub-hover:hover,
.npt-page .hub-hover:focus-within {
  transform: translateY(-5px);
  border-color: var(--color-edge-strong);
  box-shadow: var(--shadow-panel), var(--shadow-gold);
}

.npt-page .reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity var(--transition-slow), transform var(--transition-slow);
}

.npt-page .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.npt-page .reveal[data-delay="2"] { transition-delay: 60ms; }
.npt-page .reveal[data-delay="3"] { transition-delay: 120ms; }
.npt-page .reveal[data-delay="4"] { transition-delay: 180ms; }
.npt-page .reveal[data-delay="5"] { transition-delay: 240ms; }
.npt-page .reveal[data-delay="6"] { transition-delay: 300ms; }

.npt-page .hero {
  padding: 72px 0 56px;
}

.npt-page .hero__layout {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(460px, 1.14fr);
  gap: 2.25rem;
  align-items: center;
}

.npt-page .hero__copy {
  padding: 1.5rem 0;
  max-width: 35rem;
}

.npt-page .hero__title {
  margin: 0 0 1.15rem;
  max-width: 11.5ch;
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 5.2rem);
  line-height: 0.95;
  letter-spacing: -0.075em;
}

.npt-page .hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  margin-top: 1.75rem;
}

.npt-page .hero__microproof {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.5rem;
}

.npt-page .hero__microproof span {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(212, 175, 55, 0.12);
  background: rgba(255, 255, 255, 0.03);
  color: var(--color-platinum);
  font-size: 0.82rem;
}

.npt-page .hero__visual {
  position: relative;
  min-height: 620px;
}

.npt-page .npt-hero-system {
  position: relative;
  min-height: 620px;
}

.npt-page .npt-hero-system::before,
.npt-page .npt-hero-system::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.npt-page .npt-hero-system::before {
  inset: 60px 0 30px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 18%),
    repeating-linear-gradient(180deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 22px);
  mask-image: radial-gradient(circle at 58% 40%, rgba(0, 0, 0, 0.9), transparent 74%);
  opacity: 0.36;
}

.npt-page .npt-hero-system::after {
  left: 12%;
  right: 10%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0), rgba(212,175,55,0.34), rgba(212,175,55,0));
  animation: nptSweepLine 5.8s linear infinite;
}

.npt-page .npt-hero-system__ring,
.npt-page .npt-hero-system__pulse,
.npt-page .npt-hero-system__line,
.npt-page .npt-hero-system__sweep,
.npt-page .npt-hero-system__node,
.npt-page .npt-hero-system__link {
  position: absolute;
}

.npt-page .npt-hero-system__ring {
  border-radius: 50%;
  border: 1px solid rgba(212,175,55,0.12);
}

.npt-page .npt-hero-system__ring--outer {
  top: 82px;
  right: 72px;
  width: 316px;
  height: 316px;
  background: radial-gradient(circle at center, rgba(212,175,55,0.05), transparent 60%);
}

.npt-page .npt-hero-system__ring--middle {
  top: 112px;
  right: 102px;
  width: 256px;
  height: 256px;
}

.npt-page .npt-hero-system__ring--inner {
  top: 154px;
  right: 144px;
  width: 172px;
  height: 172px;
  border-color: rgba(212,175,55,0.1);
}

.npt-page .npt-hero-system__sweep {
  top: 78px;
  right: 68px;
  width: 324px;
  height: 324px;
  border-radius: 50%;
  background: conic-gradient(from 0deg, transparent 0deg, transparent 300deg, rgba(212,175,55,0.18) 328deg, transparent 360deg);
  mask: radial-gradient(circle at center, transparent 58%, #000 59%, #000 61%, transparent 62%);
  opacity: 0.76;
  animation: nptRadar 9s linear infinite;
}

.npt-page .npt-hero-system__line {
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0), rgba(212,175,55,0.34), rgba(212,175,55,0));
  opacity: 0.8;
}

.npt-page .npt-hero-system__line--one {
  top: 244px;
  left: 32px;
  width: 214px;
}

.npt-page .npt-hero-system__line--two {
  top: 382px;
  right: 36px;
  width: 180px;
}

.npt-page .npt-hero-system__line--one::after,
.npt-page .npt-hero-system__line--two::after {
  content: "";
  position: absolute;
  top: -3px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-gold);
  box-shadow: 0 0 14px rgba(212,175,55,0.38);
  animation: nptTraceTravel 4.8s linear infinite;
}

.npt-page .npt-hero-system__line--two::after {
  animation-delay: 1.1s;
}

.npt-page .npt-hero-system__pulse {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--color-gold);
  box-shadow: 0 0 16px rgba(212,175,55,0.36);
  animation: nptPulse 2.6s ease-in-out infinite;
}

.npt-page .npt-hero-system__pulse--one {
  top: 236px;
  left: 248px;
}

.npt-page .npt-hero-system__pulse--two {
  top: 370px;
  right: 206px;
  animation-delay: 0.85s;
}

.npt-page .npt-hero-system__node {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(212,175,55,0.96);
  box-shadow: 0 0 16px rgba(212,175,55,0.3);
}

.npt-page .npt-hero-system__node--one {
  top: 170px;
  left: 110px;
}

.npt-page .npt-hero-system__node--two {
  top: 220px;
  left: 210px;
}

.npt-page .npt-hero-system__node--three {
  top: 300px;
  left: 150px;
}

.npt-page .npt-hero-system__node--four {
  top: 280px;
  right: 150px;
}

.npt-page .npt-hero-system__link {
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0.1), rgba(212,175,55,0.52), rgba(212,175,55,0.1));
  transform-origin: left center;
}

.npt-page .npt-hero-system__link--one {
  top: 176px;
  left: 120px;
  width: 116px;
  transform: rotate(24deg);
}

.npt-page .npt-hero-system__link--two {
  top: 228px;
  left: 160px;
  width: 86px;
  transform: rotate(120deg);
}

.npt-page .npt-hero-system__link--three {
  top: 298px;
  left: 160px;
  width: 210px;
  transform: rotate(-6deg);
}

.npt-page .hero-surface {
  position: absolute;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  overflow: hidden;
}

.npt-page .hero-surface::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05), transparent 26%);
  pointer-events: none;
}

.npt-page .hero-surface::after {
  content: "";
  position: absolute;
  left: -10%;
  right: -10%;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0), rgba(212,175,55,0.76), rgba(212,175,55,0));
  opacity: 0.8;
  animation: nptScanPass 6.5s linear infinite;
  pointer-events: none;
}

.npt-page .hero-surface--primary {
  left: 16px;
  bottom: 44px;
  width: 58%;
  padding: 1.35rem;
}

.npt-page .hero-surface--secondary {
  right: 6px;
  top: 194px;
  width: 32%;
  padding: 1.05rem;
}

.npt-page .hero-surface__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  padding-bottom: 0.75rem;
  margin-bottom: 0.85rem;
  border-bottom: 1px solid rgba(212,175,55,0.08);
}

.npt-page .hero-surface__eyebrow {
  margin: 0;
  color: var(--color-gold);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.npt-page .hero-surface__title {
  margin: 0 0 0.65rem;
  color: var(--color-refined-white);
  font-size: 1.02rem;
  line-height: 1.3;
}

.npt-page .hero-surface__copy {
  margin: 0;
  color: var(--color-platinum);
  font-size: 0.9rem;
  line-height: 1.68;
}

.npt-page .live-state {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-refined-white);
  font-size: 0.82rem;
  text-transform: uppercase;
}

.npt-page .live-state::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--color-gold);
  box-shadow: 0 0 16px rgba(212,175,55,0.36);
  animation: nptPulse 2.6s ease-in-out infinite;
}

.npt-page .hero-meter {
  display: grid;
  gap: 0.8rem;
}

.npt-page .hero-meter__row {
  display: grid;
  gap: 0.5rem;
}

.npt-page .hero-meter__meta {
  display: flex;
  justify-content: space-between;
  gap: 0.625rem;
  font-size: 0.8rem;
  color: var(--color-platinum);
}

.npt-page .hero-meter__bar {
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,0.05);
}

.npt-page .hero-meter__bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(212,175,55,0.45), rgba(230,201,93,0.95));
  box-shadow: 0 0 14px rgba(212,175,55,0.16);
}

.npt-page .service-node__badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.75rem;
  padding: 0 0.65rem;
  border-radius: 999px;
  background: rgba(212,175,55,0.08);
  border: 1px solid rgba(212,175,55,0.12);
  color: var(--color-gold);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.npt-page .trust-strip {
  overflow: hidden;
}

.npt-page .trust-strip__list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.npt-page .trust-strip__list li {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 2.85rem;
  padding: 0 1rem 0 2.2rem;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,0.12);
  background: rgba(255,255,255,0.03);
  color: var(--color-platinum);
  font-size: 0.88rem;
  line-height: 1.4;
}

.npt-page .trust-strip__list li::before {
  content: "";
  position: absolute;
  left: 0.95rem;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--color-gold);
  box-shadow: 0 0 12px rgba(212,175,55,0.18);
  animation: nptPulse 3.1s ease-in-out infinite;
}

.npt-page .overview-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.94fr) minmax(320px, 1.06fr);
  gap: 2.125rem;
  align-items: start;
}

.npt-page .overview-layout__copy {
  display: grid;
  gap: 1rem;
}

.npt-page .overview-layout__signals {
  position: relative;
  display: grid;
  gap: 1rem;
  padding-left: 1rem;
}

.npt-page .overview-layout__signals::before,
.npt-page .faq-list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.35rem;
  bottom: 0.35rem;
  width: 1px;
  background: linear-gradient(180deg, rgba(212,175,55,0.08), rgba(212,175,55,0.32), rgba(212,175,55,0.08));
}

.npt-page .overview-point {
  position: relative;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(212,175,55,0.08);
}

.npt-page .overview-point:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.npt-page .overview-point::before {
  content: "";
  position: absolute;
  left: -1rem;
  top: 0.35rem;
  width: 0.52rem;
  height: 0.52rem;
  border-radius: 50%;
  background: var(--color-gold);
  box-shadow: 0 0 12px rgba(212,175,55,0.16);
}

.npt-page .overview-point strong {
  display: block;
  color: var(--color-refined-white);
  font-size: 1rem;
  margin-bottom: 0.35rem;
}

.npt-page .overview-point span {
  display: block;
  color: var(--color-platinum);
  font-size: 0.93rem;
  line-height: 1.72;
}

.npt-page .scope-grid {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.npt-page .deliverables-grid {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.npt-page .scope-card,
.npt-page .deliverable-card,
.npt-page .difference-card {
  position: relative;
  padding: 1.2rem 1.2rem 1.05rem 1.25rem;
  border: 1px solid rgba(212,175,55,0.1);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012));
  overflow: hidden;
  transition: transform var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);
}

.npt-page .scope-card::before,
.npt-page .deliverable-card::before,
.npt-page .difference-card::before,
.npt-page .scenario-card::before,
.npt-page .audience-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.95rem;
  width: 3px;
  height: calc(100% - 1.9rem);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(212,175,55,0.2), rgba(212,175,55,0.8), rgba(212,175,55,0.2));
}

.npt-page .scope-card::after,
.npt-page .deliverable-card::after,
.npt-page .difference-card::after,
.npt-page .scenario-card::after,
.npt-page .audience-item::after {
  content: "";
  position: absolute;
  left: -10%;
  right: -10%;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0), rgba(212,175,55,0.62), rgba(212,175,55,0));
  opacity: 0.64;
  animation: nptScanPass 9s linear infinite;
}

.npt-page .scope-card:hover,
.npt-page .scope-card:focus-within,
.npt-page .deliverable-card:hover,
.npt-page .deliverable-card:focus-within,
.npt-page .difference-card:hover,
.npt-page .difference-card:focus-within,
.npt-page .scenario-card:hover,
.npt-page .scenario-card:focus-within,
.npt-page .audience-item:hover,
.npt-page .audience-item:focus-within {
  transform: translateY(-4px);
  border-color: rgba(212,175,55,0.22);
  box-shadow: var(--shadow-soft), var(--shadow-gold);
}

.npt-page .scope-card h3,
.npt-page .deliverable-card h3,
.npt-page .difference-card h3,
.npt-page .scenario-card h3,
.npt-page .audience-item h3 {
  margin: 0 0 0.5rem;
  font-size: 1rem;
}

.npt-page .scope-card p,
.npt-page .deliverable-card p,
.npt-page .difference-card p,
.npt-page .scenario-card p,
.npt-page .audience-item p {
  margin: 0;
  color: var(--color-platinum);
  font-size: 0.92rem;
  line-height: 1.72;
}

.npt-page .scenario-grid {
  margin-top: 2rem;
  display: grid;
  gap: 1rem;
}

.npt-page .scenario-grid--five {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.npt-page .scenario-card {
  position: relative;
  padding: 1.15rem 1.15rem 1rem 1.25rem;
  border: 1px solid rgba(212,175,55,0.1);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012));
  overflow: hidden;
}

.npt-page .proof-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
  gap: 2.125rem;
  align-items: start;
}

.npt-page .proof-feature {
  padding: 1.85rem;
  overflow: hidden;
}

.npt-page .proof-feature::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.05), transparent 20%),
    repeating-linear-gradient(180deg, rgba(255,255,255,0.02) 0 1px, transparent 1px 20px);
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.9), transparent 90%);
  opacity: 0.3;
  pointer-events: none;
}

.npt-page .proof-feature::after {
  content: "";
  position: absolute;
  left: -10%;
  right: -10%;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0), rgba(212,175,55,0.82), rgba(212,175,55,0));
  animation: nptScanPass 7.2s linear infinite;
  pointer-events: none;
}

.npt-page .proof-feature__label {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,0.14);
  background: rgba(212,175,55,0.06);
  color: var(--color-gold);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.npt-page .proof-feature__title {
  margin: 1.1rem 0 0.75rem;
  color: var(--color-refined-white);
  font-size: 1.48rem;
  line-height: 1.16;
}

.npt-page .proof-feature__copy {
  margin: 0;
  color: var(--color-platinum);
  line-height: 1.8;
}

.npt-page .proof-feature__metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  margin-top: 1.4rem;
}

.npt-page .proof-feature__metrics strong {
  display: block;
  color: var(--color-gold);
  font-family: var(--font-display);
  font-size: 1.26rem;
  line-height: 1.1;
  margin-bottom: 0.35rem;
}

.npt-page .proof-feature__metrics span {
  display: block;
  color: var(--color-silver-mist);
  font-size: 0.82rem;
  line-height: 1.48;
}

.npt-page .proof-feature__status {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.75rem 1rem;
  align-items: center;
  margin-top: 1rem;
  padding-top: 0.9rem;
  border-top: 1px solid rgba(212,175,55,0.08);
}

.npt-page .proof-feature__signal {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 1.6rem;
  padding-left: 1rem;
  color: var(--color-platinum);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.npt-page .proof-feature__signal::before {
  content: "";
  position: absolute;
  left: 0;
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 50%;
  background: var(--color-gold);
  box-shadow: 0 0 12px rgba(212,175,55,0.22);
  animation: nptPulse 2.8s ease-in-out infinite;
}

.npt-page .proof-feature__trace {
  position: relative;
  display: block;
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,0.05);
}

.npt-page .proof-feature__trace::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(90deg, rgba(255,255,255,0.03) 0 10px, transparent 10px 18px);
}

.npt-page .proof-feature__trace i {
  position: relative;
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(212,175,55,0.34), rgba(212,175,55,0.92));
  box-shadow: 0 0 14px rgba(212,175,55,0.16);
}

.npt-page .difference-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.npt-page .process-track {
  position: relative;
  display: grid;
  gap: 1.25rem;
  margin: 2.1rem 0 0;
  padding: 0;
  list-style: none;
}

.npt-page .process-track--five {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.npt-page .process-track::before {
  content: "";
  position: absolute;
  left: 6%;
  right: 6%;
  top: 2.15rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0.1), rgba(212,175,55,0.3), rgba(212,175,55,0.1));
}

.npt-page .process-step {
  position: relative;
  z-index: 1;
  overflow: hidden;
}

.npt-page .process-step::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0), rgba(212,175,55,0.5), rgba(212,175,55,0));
  opacity: 0.54;
  animation: nptScanPass 12s linear infinite;
}

.npt-page .process-step__number {
  width: 68px;
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.1rem;
  border-radius: 20px;
  color: #0a0d11;
  background: linear-gradient(180deg, var(--color-gold-bright), var(--color-gold-deep));
  font-family: var(--font-display);
  font-size: 1.34rem;
  font-weight: 700;
  box-shadow: 0 14px 28px rgba(212,175,55,0.18);
}

.npt-page .process-step h3 {
  margin: 0 0 0.5rem;
  font-size: 1.02rem;
}

.npt-page .process-step p {
  margin: 0;
  color: var(--color-platinum);
  font-size: 0.93rem;
  line-height: 1.72;
}

.npt-page .audience-layout {
  display: grid;
  gap: 2rem;
}

.npt-page .audience-layout--single {
  grid-template-columns: 1fr;
}

.npt-page .audience-grid {
  display: grid;
  gap: 1rem;
}

.npt-page .audience-grid--five {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.npt-page .audience-item {
  position: relative;
  padding: 1rem 1rem 1rem 1.15rem;
  border: 1px solid rgba(212,175,55,0.1);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012));
  overflow: hidden;
}

.npt-page .faq-list {
  max-width: 920px;
  margin: 2rem auto 0;
  display: grid;
  gap: 0.75rem;
  position: relative;
  padding-left: 1rem;
}

.npt-page .faq-item {
  position: relative;
  border: 1px solid rgba(212,175,55,0.08);
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01)),
    rgba(15,20,25,0.68);
  overflow: hidden;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
}

.npt-page .faq-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.8rem;
  width: 3px;
  height: calc(100% - 1.6rem);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(212,175,55,0.18), rgba(212,175,55,0.84), rgba(212,175,55,0.18));
  box-shadow: 0 0 12px rgba(212,175,55,0.16);
}

.npt-page .faq-item::after {
  content: "";
  position: absolute;
  left: -10%;
  right: -10%;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0), rgba(212,175,55,0.7), rgba(212,175,55,0));
  opacity: 0.7;
  animation: nptScanPass 9.6s linear infinite;
}

.npt-page .faq-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 1.25rem;
  border: 0;
  background: transparent;
  color: var(--color-refined-white);
  text-align: left;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.98rem;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.npt-page .faq-trigger:hover,
.npt-page .faq-trigger:focus-visible,
.npt-page .faq-item.is-open .faq-trigger {
  background: rgba(212,175,55,0.06);
  color: var(--color-refined-white);
}

.npt-page .faq-trigger__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 10px;
  border: 1px solid rgba(212,175,55,0.16);
  color: var(--color-gold);
  flex: 0 0 28px;
  transition: transform var(--transition-fast), background var(--transition-fast);
}

.npt-page .faq-item.is-open .faq-trigger__icon {
  transform: rotate(45deg);
  background: rgba(212,175,55,0.08);
}

.npt-page .faq-item:hover,
.npt-page .faq-item:focus-within,
.npt-page .faq-item.is-open {
  border-color: rgba(212,175,55,0.18);
  box-shadow: 0 12px 34px rgba(0,0,0,0.18), 0 0 0 1px rgba(212,175,55,0.05) inset;
}

.npt-page .faq-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 300ms cubic-bezier(0.22, 1, 0.36, 1);
}

.npt-page .faq-panel p {
  margin: 0;
  padding: 0 1.25rem 1.25rem;
  color: var(--color-platinum);
  font-size: 0.94rem;
  line-height: 1.74;
}

.npt-page .final-cta {
  padding-top: 84px;
  padding-bottom: 0;
}

.npt-page .final-cta__panel {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  padding-top: 0.75rem;
}

.npt-page .final-cta__panel::before {
  content: "";
  position: absolute;
  left: 18%;
  right: 18%;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(212,175,55,0), rgba(212,175,55,0.66), rgba(212,175,55,0));
  animation: nptScanPass 9.4s linear infinite;
}

.npt-page .final-cta__kicker {
  justify-content: center;
}

.npt-page .final-cta__actions {
  justify-content: center;
}

@keyframes nptGridShift {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(64px, 64px, 0); }
}

@keyframes nptFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(20px, -14px, 0) scale(1.03); }
}

@keyframes nptSmoke {
  0%, 100% { transform: translate3d(0, 0, 0); opacity: 0.2; }
  50% { transform: translate3d(38px, -8px, 0); opacity: 0.3; }
}

@keyframes nptRadar {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes nptPulse {
  0%, 100% { transform: scale(1); opacity: 0.78; }
  50% { transform: scale(1.24); opacity: 1; }
}

@keyframes nptTraceTravel {
  0% { transform: translateX(0); opacity: 0; }
  15% { opacity: 1; }
  85% { opacity: 1; }
  100% { transform: translateX(100%); opacity: 0; }
}

@keyframes nptSweepLine {
  0% { transform: translateX(-8%); opacity: 0; }
  15% { opacity: 0.72; }
  70% { opacity: 0.72; }
  100% { transform: translateX(8%); opacity: 0; }
}

@keyframes nptScanPass {
  0% { transform: translateY(0); opacity: 0; }
  8% { opacity: 0.7; }
  60% { opacity: 0.7; }
  100% { transform: translateY(120px); opacity: 0; }
}

@keyframes nptSectionScan {
  0% { transform: translateY(0); opacity: 0; }
  10% { opacity: 0.58; }
  50% { opacity: 0.58; }
  100% { transform: translateY(120px); opacity: 0; }
}

@media (max-width: 1180px) {
  .npt-page {
    --shell-width: min(100% - 40px, 100%);
  }

  .npt-page .hero__layout,
  .npt-page .overview-layout,
  .npt-page .proof-layout {
    grid-template-columns: 1fr;
  }

  .npt-page .scope-grid,
  .npt-page .deliverables-grid,
  .npt-page .audience-grid--five {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .npt-page .scenario-grid--five,
  .npt-page .process-track--five {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .npt-page .hero {
    padding: 64px 0 48px;
  }

  .npt-page .section {
    padding: 76px 0;
  }

  .npt-page .hero__visual,
  .npt-page .npt-hero-system {
    min-height: 600px;
  }

  .npt-page .proof-feature__status {
    grid-template-columns: 1fr;
  }

  .npt-page .process-track::before {
    display: none;
  }
}

@media (max-width: 860px) {
  .npt-page {
    --shell-width: min(100% - 28px, 100%);
    left: 50%;
    width: 100vw;
    max-width: 100vw;
    margin: 0 !important;
    padding: 0 !important;
  }

  .npt-page .section {
    padding: 68px 0;
  }

  .npt-page .section--tight {
    padding: 24px 0;
  }

  .npt-page .hero {
    padding: 52px 0 40px;
  }

  .npt-page .hero__title {
    max-width: none;
    font-size: clamp(2.6rem, 11vw, 4.8rem);
  }

  .npt-page .hero__visual,
  .npt-page .npt-hero-system {
    min-height: auto;
  }

  .npt-page .npt-hero-system {
    min-height: 520px;
  }

  .npt-page .npt-hero-system__ring--outer {
    top: 30px;
    right: 22px;
    width: 280px;
    height: 280px;
  }

  .npt-page .npt-hero-system__ring--middle {
    top: 56px;
    right: 48px;
    width: 230px;
    height: 230px;
  }

  .npt-page .npt-hero-system__ring--inner {
    top: 96px;
    right: 88px;
    width: 150px;
    height: 150px;
  }

  .npt-page .npt-hero-system__sweep {
    top: 26px;
    right: 18px;
    width: 288px;
    height: 288px;
  }

  .npt-page .npt-hero-system__line--one {
    width: 170px;
    left: 10px;
    top: 212px;
  }

  .npt-page .npt-hero-system__line--two {
    width: 150px;
    right: 10px;
    top: 336px;
  }

  .npt-page .npt-hero-system__pulse--one {
    top: 204px;
    left: 178px;
  }

  .npt-page .npt-hero-system__pulse--two {
    top: 322px;
    right: 142px;
  }

  .npt-page .npt-hero-system__node--one {
    top: 160px;
    left: 44px;
  }

  .npt-page .npt-hero-system__node--two {
    top: 208px;
    left: 120px;
  }

  .npt-page .npt-hero-system__node--three {
    top: 290px;
    left: 78px;
  }

  .npt-page .npt-hero-system__node--four {
    top: 262px;
    right: 112px;
  }

  .npt-page .npt-hero-system__link--one {
    top: 167px;
    left: 55px;
    width: 86px;
  }

  .npt-page .npt-hero-system__link--two {
    top: 214px;
    left: 88px;
    width: 70px;
  }

  .npt-page .npt-hero-system__link--three {
    top: 286px;
    left: 90px;
    width: 132px;
  }

  .npt-page .hero-surface--primary,
  .npt-page .hero-surface--secondary {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    margin-top: 0.9rem;
  }

  .npt-page .hero__actions {
    flex-direction: column;
  }

  .npt-page .button {
    width: 100%;
  }

  .npt-page .hero__microproof {
    gap: 0.55rem;
  }

  .npt-page .hero__microproof span {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .npt-page .scope-grid,
  .npt-page .deliverables-grid,
  .npt-page .difference-grid,
  .npt-page .scenario-grid--five,
  .npt-page .audience-grid--five,
  .npt-page .proof-feature__metrics,
  .npt-page .process-track--five,
  .npt-page .trust-strip__list {
    grid-template-columns: 1fr;
  }

  .npt-page .hub-stage__watermark,
  .npt-page .hub-stage__smoke {
    display: none;
  }
}

@media (max-width: 480px) {
  .npt-page {
    --shell-width: min(100% - 24px, 100%);
  }

  .npt-page .hero {
    padding: 44px 0 34px;
  }

  .npt-page .section {
    padding: 60px 0;
  }

  .npt-page .hero__title {
    font-size: clamp(2.35rem, 11vw, 4rem);
    line-height: 0.98;
  }

  .npt-page .button {
    min-height: 52px;
    padding-inline: 1.2rem;
  }

  .npt-page .scope-card,
  .npt-page .deliverable-card,
  .npt-page .difference-card,
  .npt-page .scenario-card,
  .npt-page .audience-item,
  .npt-page .proof-feature {
    border-radius: 18px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .npt-page .hub-stage__grid,
  .npt-page .hub-stage__orb--gold,
  .npt-page .hub-stage__orb--emerald,
  .npt-page .hub-stage__smoke,
  .npt-page .npt-hero-system__sweep,
  .npt-page .npt-hero-system::after,
  .npt-page .npt-hero-system__pulse,
  .npt-page .npt-hero-system__line--one::after,
  .npt-page .npt-hero-system__line--two::after,
  .npt-page .hero-surface::after,
  .npt-page .scope-card::after,
  .npt-page .deliverable-card::after,
  .npt-page .difference-card::after,
  .npt-page .scenario-card::after,
  .npt-page .audience-item::after,
  .npt-page .faq-item::after,
  .npt-page .final-cta__panel::before,
  .npt-page .reveal,
  .npt-page .hub-hover,
  .npt-page .button {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }

  .npt-page .reveal {
    opacity: 1 !important;
  }
}/* End custom CSS */