:root {
  --gov-navy: #0b1b3a;
  --gov-navy-2: #132244;
  --gov-blue: #6f3fe8;
  --gov-blue-2: #8b5cf6;
  --gov-core: #727986;
  --gov-desk: #6f3fe8;
  --gov-approve: #e9651a;
  --gov-ops: #16a36b;
  --gov-blue-soft: #f1ebff;
  --gov-green: #0d9e6b;
  --gov-green-soft: #e6f7f1;
  --gov-purple: #6b3fd4;
  --gov-purple-soft: #efe9fb;
  --gov-orange: #e9651a;
  --gov-orange-soft: #fff2e9;
  --gov-ink: #1e2336;
  --gov-muted: #5c667d;
  --gov-soft: #f7f9fc;
  --gov-line: #dde3ee;
  --gov-panel: #ffffff;
  --gov-max: 1160px;
  --gov-shadow: 0 22px 70px rgba(11, 27, 58, 0.14);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body.governa-landing {
  margin: 0;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 12% 8%, rgba(111, 63, 232, 0.1), transparent 28%),
    radial-gradient(circle at 88% 18%, rgba(22, 163, 107, 0.08), transparent 26%),
    linear-gradient(180deg, #f6f8fd 0%, #ffffff 34%, #f4f8fb 100%);
  color: var(--gov-ink);
  font-family: "DM Sans", Arial, sans-serif;
  line-height: 1.65;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
}

body.governa-landing a {
  color: inherit;
  text-decoration: none;
}

body.governa-landing img {
  max-width: 100%;
}

body.governa-landing svg {
  display: block;
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  clip-path: inset(50%);
}

.site-header {
  position: fixed;
  z-index: 60;
  top: 0;
  left: 0;
  right: 0;
  border-bottom: 1px solid rgba(221, 227, 238, 0.78);
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(18px);
}

.site-header.is-scrolled {
  box-shadow: 0 14px 34px rgba(11, 27, 58, 0.08);
}

.site-header,
.site-footer {
  padding-inline: max(24px, calc((100vw - var(--gov-max)) / 2));
}

.brand-lockup,
.site-header {
  display: flex;
  align-items: center;
}

.site-header {
  justify-content: space-between;
  min-height: 70px;
  gap: 24px;
}

.brand-lockup {
  gap: 10px;
  min-width: 0;
}

.brand-mark {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border-radius: 10px;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0) 42%),
    linear-gradient(135deg, rgba(111, 63, 232, 0.1), rgba(255, 255, 255, 0.82));
  box-shadow: 0 10px 24px rgba(111, 63, 232, 0.16);
}

.brand-mark img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}

.brand-lockup strong {
  display: block;
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: 1.12rem;
  font-weight: 800;
  line-height: 1;
}

.brand-lockup small {
  display: block;
  margin-top: 3px;
  color: var(--gov-muted);
  font-size: 0.76rem;
  font-weight: 700;
}

.site-nav {
  display: flex;
  align-items: center;
  gap: 26px;
  color: var(--gov-muted);
  font-size: 0.9rem;
  font-weight: 700;
}

.site-nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 40px;
}

.site-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 100%;
  bottom: 4px;
  height: 2px;
  border-radius: 99px;
  background: var(--gov-blue);
  transition: right 0.2s ease;
}

.site-nav a:hover {
  color: var(--gov-navy);
}

.site-nav a:hover::after {
  right: 0;
}

.site-nav .nav-login {
  min-height: 40px;
  border-radius: 8px;
  padding: 0 15px;
  background: var(--gov-navy);
  color: #fff;
}

.site-nav .nav-login::after {
  display: none;
}

.site-nav .nav-login:hover {
  background: var(--gov-blue);
  color: #fff;
}

.nav-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--gov-line);
  border-radius: 8px;
  background: #fff;
}

.nav-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 4px auto;
  background: var(--gov-navy);
}

.hero-section {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.84fr) minmax(520px, 1.16fr);
  gap: 46px;
  align-items: center;
  min-height: 100svh;
  overflow: hidden;
  padding: 136px max(24px, calc((100vw - var(--gov-max)) / 2)) 86px;
  background:
    linear-gradient(115deg, rgba(255, 255, 255, 0.9) 0%, rgba(246, 248, 253, 0.94) 46%, rgba(238, 245, 242, 0.86) 100%),
    linear-gradient(135deg, transparent 0 58%, rgba(111, 63, 232, 0.08) 58% 66%, transparent 66%),
    radial-gradient(circle at 72% 18%, rgba(111, 63, 232, 0.24), transparent 26%),
    radial-gradient(circle at 86% 32%, rgba(233, 101, 26, 0.16), transparent 24%),
    radial-gradient(circle at 70% 72%, rgba(22, 163, 107, 0.18), transparent 28%),
    radial-gradient(circle at 52% 48%, rgba(114, 121, 134, 0.15), transparent 32%),
    #ffffff;
}

.hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(111, 63, 232, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(111, 63, 232, 0.075) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(90deg, #000 0%, #000 64%, transparent 100%);
}

.hero-section::after {
  content: "";
  position: absolute;
  right: -14%;
  bottom: -26%;
  width: 56vw;
  height: 56vw;
  pointer-events: none;
  background:
    conic-gradient(from 210deg, rgba(111, 63, 232, 0.18), rgba(233, 101, 26, 0.16), rgba(22, 163, 107, 0.18), rgba(114, 121, 134, 0.16), rgba(111, 63, 232, 0.18));
  filter: blur(58px);
  opacity: 0.62;
  animation: chromaBreath 9s ease-in-out infinite;
}

.ambient-lines {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.ambient-lines span {
  position: absolute;
  left: -18%;
  width: 52%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(111, 63, 232, 0.36), transparent);
  animation: flowLine 8s linear infinite;
}

.ambient-lines span:nth-child(1) { top: 24%; animation-delay: 0s; }
.ambient-lines span:nth-child(2) { top: 42%; animation-delay: -2s; }
.ambient-lines span:nth-child(3) { top: 62%; animation-delay: -4s; }
.ambient-lines span:nth-child(4) { top: 78%; animation-delay: -6s; }

.hero-content,
.hero-visual {
  position: relative;
  z-index: 2;
}

.hero-eyebrow,
.eyebrow {
  color: var(--gov-blue);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin: 0 0 22px;
}

.hero-eyebrow span {
  width: 8px;
  height: 8px;
  border-radius: 99px;
  background: var(--gov-green);
  animation: pulseDot 2.4s ease-in-out infinite;
}

.hero-content h1,
.section-heading h2,
.security-layout h2,
.cta-shell h2 {
  margin: 0;
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: 0;
}

.hero-content h1 {
  max-width: 690px;
  font-size: 4.22rem;
}

.hero-subtitle {
  max-width: 620px;
  margin: 24px 0 0;
  color: var(--gov-muted);
  font-size: 1.14rem;
  line-height: 1.75;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 32px;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 0 24px;
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.92rem;
  font-weight: 800;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.btn:hover {
  transform: translateY(-2px);
}

.btn-primary {
  background: var(--gov-blue);
  color: #fff;
  box-shadow: 0 16px 28px rgba(26, 86, 196, 0.24);
}

.btn-primary:hover {
  background: var(--gov-blue-2);
  box-shadow: 0 18px 36px rgba(26, 86, 196, 0.28);
}

.btn-secondary {
  border-color: #cfd9e8;
  background: rgba(255, 255, 255, 0.88);
  color: var(--gov-navy);
}

.btn-secondary:hover {
  border-color: rgba(26, 86, 196, 0.28);
  background: var(--gov-blue-soft);
}

.trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 34px;
}

.trust-row span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border: 1px solid var(--gov-line);
  border-radius: 99px;
  padding: 0 13px;
  background: #fff;
  color: #4b5870;
  font-size: 0.82rem;
  font-weight: 800;
  box-shadow: 0 8px 22px rgba(11, 27, 58, 0.06);
}

.hero-visual {
  min-height: 640px;
}

.hero-visual::before {
  content: "";
  position: absolute;
  inset: 18px -36px 18px 20px;
  border-radius: 32px;
  background:
    conic-gradient(from 210deg,
      rgba(114, 121, 134, 0.26),
      rgba(111, 63, 232, 0.28),
      rgba(233, 101, 26, 0.22),
      rgba(22, 163, 107, 0.22),
      rgba(114, 121, 134, 0.26));
  filter: blur(32px);
  opacity: 0.82;
  animation: chromaBreath 7s ease-in-out infinite;
}

.ai-hero-art {
  position: absolute;
  z-index: 3;
  left: auto;
  right: -24px;
  top: auto;
  bottom: 36px;
  width: 260px;
  height: 372px;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(220, 226, 238, 0.78);
  background: #fff;
  opacity: 0.96;
  box-shadow: 0 28px 70px rgba(11, 27, 58, 0.14);
  filter: saturate(1.24) contrast(1.04);
}

.ai-hero-art::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.18)),
    radial-gradient(circle at 74% 18%, rgba(111, 63, 232, 0.1), transparent 30%),
    radial-gradient(circle at 64% 84%, rgba(22, 163, 107, 0.1), transparent 28%);
}

.ai-hero-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 36% center;
  transform: scale(1.03);
  animation: artDrift 12s ease-in-out infinite;
}

.module-orbit {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}

.orbit-line {
  position: absolute;
  top: 64px;
  right: 34px;
  width: min(520px, 88%);
  height: 410px;
  border-radius: 38px;
  background:
    linear-gradient(90deg, transparent, rgba(114, 121, 134, 0.46), rgba(111, 63, 232, 0.5), rgba(233, 101, 26, 0.46), rgba(22, 163, 107, 0.46), transparent);
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  padding: 1px;
  border: 1px solid transparent;
  opacity: 0.75;
  animation: orbitGlow 6s ease-in-out infinite;
}

.orbit-logo {
  position: absolute;
  z-index: 2;
  display: grid;
  width: 68px;
  height: 68px;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 20px 44px rgba(11, 27, 58, 0.16);
  backdrop-filter: blur(12px);
  animation: orbitFloat 5.8s ease-in-out infinite;
}

.orbit-logo::before {
  content: "";
  position: absolute;
  inset: -2px;
  z-index: -1;
  border-radius: 20px;
  opacity: 0.95;
}

.orbit-logo img {
  width: 46px;
  height: 46px;
  object-fit: contain;
}

.orbit-core {
  top: 8px;
  left: 58px;
}

.orbit-core::before {
  background: linear-gradient(135deg, rgba(114, 121, 134, 0.8), rgba(214, 218, 225, 0.36));
}

.orbit-desk {
  top: 92px;
  right: -10px;
  animation-delay: -1s;
}

.orbit-desk::before {
  background: linear-gradient(135deg, rgba(111, 63, 232, 0.82), rgba(167, 139, 250, 0.24));
}

.orbit-approve {
  bottom: 132px;
  right: 34px;
  animation-delay: -2s;
}

.orbit-approve::before {
  background: linear-gradient(135deg, rgba(233, 101, 26, 0.78), rgba(255, 178, 56, 0.2));
}

.orbit-ops {
  bottom: 38px;
  left: 22px;
  animation-delay: -3s;
}

.orbit-ops::before {
  background: linear-gradient(135deg, rgba(22, 163, 107, 0.78), rgba(111, 63, 232, 0.14));
}

.flow-window {
  position: absolute;
  z-index: 5;
  top: 42px;
  left: auto;
  right: 0;
  bottom: auto;
  width: min(620px, 100%);
  border: 1px solid rgba(192, 205, 224, 0.72);
  border-radius: 16px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: var(--gov-shadow);
  backdrop-filter: blur(12px);
  animation: floatWindow 7s ease-in-out infinite;
}

.flow-window__bar {
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 48px;
  padding: 0 18px;
  background:
    linear-gradient(90deg, rgba(114, 121, 134, 0.32), rgba(111, 63, 232, 0.28) 30%, rgba(233, 101, 26, 0.22) 58%, rgba(22, 163, 107, 0.24)),
    var(--gov-navy);
}

.flow-window__bar span {
  width: 10px;
  height: 10px;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.34);
}

.flow-window__bar span:nth-child(2) { background: var(--gov-green); }
.flow-window__bar span:nth-child(3) { background: var(--gov-purple); }

.flow-window__bar strong {
  margin-left: auto;
  color: rgba(255, 255, 255, 0.62);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.76rem;
  font-weight: 700;
}

.flow-path {
  display: grid;
  grid-template-columns: 1fr 42px 1fr 42px 1fr;
  gap: 0;
  align-items: center;
  padding: 22px 20px 10px;
}

.flow-path em {
  height: 2px;
  background: linear-gradient(90deg, var(--gov-core), var(--gov-desk), var(--gov-approve), var(--gov-ops));
  animation: pathPulse 2.8s ease-in-out infinite;
}

.flow-step {
  display: grid;
  justify-items: center;
  gap: 4px;
  text-align: center;
}

.flow-step i {
  display: block;
  width: 42px;
  height: 42px;
  border: 5px solid #eef2f7;
  border-radius: 99px;
  background: #c5cfdf;
}

.flow-step.is-complete i {
  background: var(--gov-green);
  box-shadow: 0 0 0 7px var(--gov-green-soft);
}

.flow-step.is-active i {
  background: var(--gov-blue);
  box-shadow: 0 0 0 7px var(--gov-blue-soft);
  animation: pulseRing 2.2s ease-in-out infinite;
}

.flow-step strong {
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.82rem;
}

.flow-step small {
  display: block;
  color: var(--gov-muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.workflow-grid {
  display: grid;
  grid-template-columns: 1.16fr 0.84fr;
  gap: 12px;
  padding: 14px 20px 20px;
}

.request-card,
.decision-card,
.kanban-card {
  border: 1px solid var(--gov-line);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(11, 27, 58, 0.07);
}

.request-card {
  border-top: 4px solid var(--gov-desk);
}

.decision-card {
  border-top: 4px solid var(--gov-approve);
}

.kanban-card {
  border-top: 4px solid var(--gov-ops);
}

.request-card {
  grid-row: span 2;
  min-height: 236px;
  padding: 18px;
}

.mini-label {
  display: inline-block;
  margin-bottom: 12px;
  color: var(--gov-blue);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.request-card h3 {
  margin: 0 0 12px;
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: 1.18rem;
  line-height: 1.22;
}

.request-card p,
.decision-card p {
  margin: 0;
  color: var(--gov-muted);
  font-size: 0.88rem;
}

.avatar-row {
  display: flex;
  margin-top: 22px;
}

.avatar-row span {
  display: grid;
  width: 30px;
  height: 30px;
  margin-left: -8px;
  place-items: center;
  border: 2px solid #fff;
  border-radius: 99px;
  background: var(--gov-navy);
  color: #fff;
  font-size: 0.67rem;
  font-weight: 900;
}

.avatar-row span:first-child {
  margin-left: 0;
  background: var(--gov-blue);
}

.avatar-row span:last-child {
  background: var(--gov-green);
}

.decision-card {
  display: grid;
  gap: 8px;
  min-height: 112px;
  padding: 14px;
}

.status-pill {
  display: inline-flex;
  width: max-content;
  align-items: center;
  min-height: 24px;
  border-radius: 99px;
  padding: 0 10px;
  font-size: 0.72rem;
  font-weight: 900;
}

.status-pill.is-approved {
  background: var(--gov-green-soft);
  color: var(--gov-green);
}

.status-pill.is-pending {
  background: var(--gov-purple-soft);
  color: var(--gov-purple);
}

.kanban-card {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-height: 112px;
  padding: 12px;
}

.kanban-card div {
  display: grid;
  align-content: start;
  gap: 7px;
}

.kanban-card strong {
  color: var(--gov-muted);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.66rem;
  text-transform: uppercase;
}

.kanban-card span {
  display: block;
  height: 24px;
  border-radius: 6px;
  background: var(--gov-blue-soft);
}

.kanban-card div:nth-child(2) span {
  background: var(--gov-purple-soft);
}

.kanban-card div:nth-child(3) span {
  background: var(--gov-green-soft);
}

.float-note {
  position: absolute;
  z-index: 6;
  border: 1px solid rgba(221, 227, 238, 0.9);
  border-radius: 12px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 44px rgba(11, 27, 58, 0.14);
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.8rem;
  font-weight: 800;
  animation: floatNote 5.8s ease-in-out infinite;
}

.note-one { top: 2px; left: 88px; animation-delay: -0.4s; }
.note-two { top: 164px; right: 70px; animation-delay: -1.4s; }
.note-three { bottom: 70px; left: 12px; animation-delay: -2.2s; }
.note-four { bottom: 0; right: 118px; animation-delay: -3s; }

.section-pad {
  position: relative;
  overflow: hidden;
  padding: 96px max(24px, calc((100vw - var(--gov-max)) / 2));
}

.section-pad::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 8% 14%, rgba(111, 63, 232, 0.07), transparent 26%),
    radial-gradient(circle at 92% 18%, rgba(22, 163, 107, 0.06), transparent 28%),
    linear-gradient(120deg, transparent 0 64%, rgba(233, 101, 26, 0.035) 64% 73%, transparent 73%);
}

.section-pad > * {
  position: relative;
  z-index: 1;
}

.section-heading {
  max-width: 800px;
  margin-bottom: 44px;
}

.section-heading.compact {
  max-width: 760px;
}

.eyebrow {
  margin: 0 0 14px;
}

.section-heading h2,
.security-layout h2,
.cta-shell h2 {
  font-size: 3.15rem;
}

.section-heading p:not(.eyebrow),
.security-layout p,
.cta-shell p {
  margin: 18px 0 0;
  color: var(--gov-muted);
  font-size: 1.06rem;
  line-height: 1.72;
}

.pain-section,
.modules-section,
.differentials-section,
.comparison-section,
.final-cta {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(247, 250, 253, 0.96)),
    radial-gradient(circle at 78% 12%, rgba(111, 63, 232, 0.08), transparent 30%),
    #fff;
}

.compare-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.compare-panel,
.value-grid article,
.feature-grid article,
.usecase-grid article,
.timeline-grid article {
  border: 1px solid var(--gov-line);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 12px 34px rgba(11, 27, 58, 0.07);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.compare-panel:hover,
.value-grid article:hover,
.feature-grid article:hover,
.usecase-grid article:hover,
.timeline-grid article:hover {
  transform: translateY(-5px);
  border-color: rgba(26, 86, 196, 0.28);
  box-shadow: 0 20px 50px rgba(11, 27, 58, 0.11);
}

.compare-panel {
  padding: 28px;
}

.compare-panel.is-before {
  border-color: transparent;
  background: #f8f9fc;
}

.compare-panel.is-before:hover {
  border-color: transparent;
}

.compare-panel.is-after {
  background: var(--gov-navy);
  color: #fff;
}

.compare-panel h3 {
  margin: 0 0 18px;
  color: inherit;
  font-family: "Sora", Arial, sans-serif;
  font-size: 1.12rem;
}

body.governa-landing .compare-icon {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 0 22px;
  color: currentColor;
}

.compare-icon path,
.compare-icon rect,
.compare-icon circle {
  vector-effect: non-scaling-stroke;
}

.wire-muted,
.wire-flow {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.wire-muted {
  stroke: rgba(92, 102, 125, 0.32);
  stroke-width: 3;
  stroke-dasharray: 8 10;
}

.wire-muted.is-broken {
  stroke: rgba(217, 83, 83, 0.34);
}

.wire-flow {
  stroke: rgba(22, 163, 107, 0.56);
  stroke-width: 3.2;
}

.wire-flow.alt {
  stroke: rgba(111, 63, 232, 0.46);
  stroke-dasharray: 10 8;
}

.tool-node rect {
  fill: #fff;
  stroke: rgba(92, 102, 125, 0.26);
  stroke-width: 2;
}

.tool-node text,
.lost-node text,
.govern-node text {
  font-family: "Sora", Arial, sans-serif;
  font-size: 10.5px;
  font-weight: 700;
  text-anchor: middle;
  dominant-baseline: middle;
}

.tool-node text {
  fill: rgba(92, 102, 125, 0.72);
}

.tool-node path {
  fill: none;
  stroke: rgba(92, 102, 125, 0.58);
  stroke-width: 2;
  stroke-linecap: round;
}

.lost-node rect {
  fill: rgba(217, 83, 83, 0.08);
  stroke: rgba(217, 83, 83, 0.34);
  stroke-width: 2;
}

.lost-node text {
  fill: rgba(217, 83, 83, 0.84);
  font-size: 10px;
}

.break-mark {
  fill: none;
  stroke: #d95353;
  stroke-width: 3;
  stroke-linecap: round;
}

.govern-node rect,
.govern-node circle {
  fill: rgba(255, 255, 255, 0.1);
  stroke-width: 2;
}

.govern-node path {
  fill: none;
  stroke: #fff;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.govern-node.is-desk rect {
  stroke: rgba(111, 63, 232, 0.72);
}

.govern-node.is-approve circle {
  stroke: rgba(233, 101, 26, 0.72);
}

.govern-node.is-ops rect {
  stroke: rgba(22, 163, 107, 0.72);
}

.govern-node.is-core circle {
  stroke: rgba(114, 121, 134, 0.72);
}

.govern-node text {
  fill: rgba(255, 255, 255, 0.7);
  font-size: 10px;
}

.compare-panel ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.compare-panel li {
  position: relative;
  padding-left: 28px;
  color: var(--gov-muted);
  font-weight: 700;
}

.compare-panel.is-after li {
  color: rgba(255, 255, 255, 0.82);
}

.compare-panel li::before {
  content: "";
  position: absolute;
  top: 0.58em;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 99px;
  background: #d95353;
}

.compare-panel.is-after li::before {
  background: var(--gov-green);
}

.value-section,
.timeline-section,
.usecase-section,
.pricing-section,
.security-section {
  background:
    linear-gradient(180deg, #f7f9fc, #edf4f6),
    linear-gradient(135deg, rgba(111, 63, 232, 0.06), transparent 42%, rgba(22, 163, 107, 0.06));
}

.value-section {
  min-height: 760px;
}

.scroll-backdrop-art {
  position: absolute;
  z-index: 0;
  top: 18px;
  right: max(-70px, calc((100vw - var(--gov-max)) / 2 - 120px));
  width: min(52vw, 680px);
  max-width: 680px;
  overflow: hidden;
  border: 1px solid rgba(221, 228, 240, 0.62);
  border-radius: 32px;
  background: #fff;
  box-shadow: 0 34px 100px rgba(11, 27, 58, 0.12);
  opacity: 0.3;
  transform: rotate(-2deg);
  mask-image: linear-gradient(90deg, transparent 0%, #000 18%, #000 78%, transparent 100%);
}

.scroll-backdrop-art img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  object-position: center;
  filter: saturate(1.16) contrast(1.02);
}

body.governa-landing .flow-circuit {
  display: block;
  width: 100%;
  height: auto;
  max-width: 980px;
  margin: -4px 0 34px;
  overflow: visible;
}

.circuit-back,
.circuit-front {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.circuit-back {
  stroke: rgba(162, 174, 197, 0.44);
  stroke-width: 16;
}

.circuit-front {
  stroke: url(#flowCircuitGradient);
  stroke-width: 4;
  stroke-dasharray: 18 12;
  animation: dashFlow 16s linear infinite;
}

.circuit-node rect {
  fill: rgba(255, 255, 255, 0.88);
  stroke-width: 2;
  filter: drop-shadow(0 14px 24px rgba(11, 27, 58, 0.13));
}

.circuit-node path {
  fill: none;
  stroke-width: 2.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.circuit-node.is-desk rect { stroke: rgba(111, 63, 232, 0.4); }
.circuit-node.is-desk path { stroke: var(--gov-desk); }
.circuit-node.is-approve rect { stroke: rgba(233, 101, 26, 0.4); }
.circuit-node.is-approve path { stroke: var(--gov-approve); }
.circuit-node.is-ops rect { stroke: rgba(22, 163, 107, 0.4); }
.circuit-node.is-ops path { stroke: var(--gov-ops); }
.circuit-node.is-core rect { stroke: rgba(114, 121, 134, 0.4); }
.circuit-node.is-core path { stroke: var(--gov-core); }

.circuit-dot {
  fill: #fff;
  stroke: url(#flowCircuitGradient);
  stroke-width: 4;
}

.value-grid,
.feature-grid,
.usecase-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.value-grid article {
  position: relative;
  overflow: hidden;
  padding: 28px;
}

.value-grid article::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.08;
  background:
    radial-gradient(circle at 18% 12%, currentColor, transparent 34%),
    linear-gradient(135deg, currentColor, transparent 56%);
}

.value-grid article > * {
  position: relative;
  z-index: 1;
}

.value-grid span {
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border-radius: 12px;
  background: var(--gov-blue-soft);
  color: var(--gov-blue);
  font-family: "Sora", Arial, sans-serif;
  font-weight: 900;
}

.value-grid svg {
  width: 54px;
  height: 54px;
  margin: 24px 0 4px;
  color: currentColor;
  stroke-width: 1.8;
}

.value-grid article.is-core {
  color: var(--gov-core);
  border-top: 4px solid var(--gov-core);
}

.value-grid article.is-desk {
  color: var(--gov-desk);
  border-top: 4px solid var(--gov-desk);
}

.value-grid article.is-approve {
  color: var(--gov-approve);
  border-top: 4px solid var(--gov-approve);
}

.value-grid article.is-ops {
  color: var(--gov-ops);
  border-top: 4px solid var(--gov-ops);
}

.value-grid article.is-core span { background: rgba(114, 121, 134, 0.13); color: var(--gov-core); }
.value-grid article.is-desk span { background: rgba(111, 63, 232, 0.13); color: var(--gov-desk); }
.value-grid article.is-approve span { background: rgba(233, 101, 26, 0.12); color: var(--gov-approve); }
.value-grid article.is-ops span { background: rgba(22, 163, 107, 0.12); color: var(--gov-ops); }

.value-grid h3,
.feature-grid h3,
.usecase-grid h3,
.timeline-grid h3 {
  margin: 18px 0 9px;
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: 1.08rem;
}

.value-grid p,
.feature-grid p,
.usecase-grid p,
.timeline-grid p {
  margin: 0;
  color: var(--gov-muted);
  line-height: 1.6;
}

.showcase-section {
  background:
    radial-gradient(circle at 14% 16%, rgba(111, 63, 232, 0.34), transparent 30%),
    radial-gradient(circle at 78% 24%, rgba(233, 101, 26, 0.22), transparent 28%),
    radial-gradient(circle at 82% 86%, rgba(22, 163, 107, 0.24), transparent 34%),
    linear-gradient(135deg, #081633 0%, #111d3b 48%, #071b24 100%);
}

.showcase-section::before {
  background:
    linear-gradient(rgba(255, 255, 255, 0.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.045) 1px, transparent 1px),
    linear-gradient(120deg, transparent 0 56%, rgba(255, 255, 255, 0.045) 56% 64%, transparent 64%);
  background-size: 48px 48px, 48px 48px, auto;
  opacity: 0.9;
}

.showcase-heading h2 {
  color: #fff;
}

.showcase-heading p:not(.eyebrow) {
  color: rgba(226, 233, 246, 0.78);
}

.showcase-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.showcase-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(18px);
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.showcase-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 34px 86px rgba(0, 0, 0, 0.34);
}

.showcase-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.72;
}

.showcase-card.is-core::before {
  background: linear-gradient(180deg, rgba(114, 121, 134, 0.24), transparent 52%);
}

.showcase-card.is-desk::before {
  background: linear-gradient(180deg, rgba(111, 63, 232, 0.28), transparent 52%);
}

.showcase-card.is-approve::before {
  background: linear-gradient(180deg, rgba(233, 101, 26, 0.3), transparent 52%);
}

.showcase-card.is-ops::before {
  background: linear-gradient(180deg, rgba(22, 163, 107, 0.28), transparent 52%);
}

.showcase-card__image {
  position: relative;
  z-index: 1;
  margin: 12px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.9);
}

.showcase-card__image img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  filter: saturate(1.08) contrast(1.02);
  transition: transform 0.35s ease;
}

.showcase-card:hover .showcase-card__image img {
  transform: scale(1.04);
}

.showcase-card__body {
  position: relative;
  z-index: 1;
  padding: 6px 20px 22px;
}

.showcase-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  padding: 0 12px 0 6px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.76rem;
  font-style: normal;
  font-weight: 900;
}

.showcase-badge img {
  width: 26px;
  height: 26px;
  object-fit: contain;
}

.showcase-badge i {
  font-style: normal;
}

.showcase-card h3 {
  margin: 18px 0 8px;
  color: #fff;
  font-family: "Sora", Arial, sans-serif;
  font-size: 1.2rem;
}

.showcase-card p {
  margin: 0;
  color: rgba(229, 235, 247, 0.76);
  line-height: 1.56;
}

.module-tabs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 22px;
}

.module-tab {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 62px;
  border: 1px solid var(--gov-line);
  border-radius: 14px;
  padding: 10px 14px;
  background: #fff;
  color: var(--gov-muted);
  font-family: "Sora", Arial, sans-serif;
  font-weight: 800;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.module-tab img {
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.module-tab:hover,
.module-tab.is-active {
  transform: translateY(-2px);
  border-color: rgba(26, 86, 196, 0.28);
  background: #f7fbff;
  color: var(--gov-navy);
  box-shadow: 0 12px 30px rgba(11, 27, 58, 0.08);
}

.module-tab[data-module-tab="core"].is-active,
.module-tab[data-module-tab="core"]:hover {
  border-color: rgba(114, 121, 134, 0.38);
  background: linear-gradient(135deg, rgba(114, 121, 134, 0.14), #fff);
}

.module-tab[data-module-tab="desk"].is-active,
.module-tab[data-module-tab="desk"]:hover {
  border-color: rgba(111, 63, 232, 0.42);
  background: linear-gradient(135deg, rgba(111, 63, 232, 0.14), #fff);
}

.module-tab[data-module-tab="approve"].is-active,
.module-tab[data-module-tab="approve"]:hover {
  border-color: rgba(233, 101, 26, 0.42);
  background: linear-gradient(135deg, rgba(233, 101, 26, 0.13), #fff);
}

.module-tab[data-module-tab="ops"].is-active,
.module-tab[data-module-tab="ops"]:hover {
  border-color: rgba(22, 163, 107, 0.42);
  background: linear-gradient(135deg, rgba(22, 163, 107, 0.13), #fff);
}

.module-panels {
  position: relative;
  min-height: 480px;
}

.module-panel {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(420px, 1.12fr);
  gap: 34px;
  align-items: stretch;
  opacity: 0;
  pointer-events: none;
  transform: translateY(18px);
  transition: opacity 0.26s ease, transform 0.26s ease;
}

.module-panel.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.module-panel__copy,
.module-panel__visual {
  border: 1px solid var(--gov-line);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 14px 38px rgba(11, 27, 58, 0.08);
}

.module-panel::before {
  content: "";
  position: absolute;
  inset: -10px;
  z-index: -1;
  border-radius: 26px;
  opacity: 0;
  filter: blur(28px);
  transition: opacity 0.24s ease;
}

.module-panel.is-active::before {
  opacity: 1;
}

.module-panel.is-core::before {
  background: linear-gradient(90deg, rgba(114, 121, 134, 0.24), transparent 54%);
}

.module-panel.is-desk::before {
  background: linear-gradient(90deg, rgba(111, 63, 232, 0.25), transparent 54%);
}

.module-panel.is-approve::before {
  background: linear-gradient(90deg, rgba(233, 101, 26, 0.24), transparent 54%);
}

.module-panel.is-ops::before {
  background: linear-gradient(90deg, rgba(22, 163, 107, 0.24), transparent 54%);
}

.module-panel__copy {
  padding: 34px;
}

.module-panel__copy > span {
  color: var(--gov-blue);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.module-panel__copy h3 {
  margin: 10px 0 14px;
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: 2rem;
}

.module-panel__copy p {
  margin: 0 0 24px;
  color: var(--gov-muted);
  line-height: 1.72;
}

.module-panel__copy ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.module-panel__copy li {
  position: relative;
  padding-left: 26px;
  color: #34425a;
  font-weight: 800;
}

.module-panel__copy li::before {
  content: "";
  position: absolute;
  top: 0.58em;
  left: 0;
  width: 9px;
  height: 9px;
  border-radius: 99px;
  background: var(--gov-green);
}

.module-panel__visual {
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
  padding: 28px;
  min-height: 460px;
  background:
    radial-gradient(circle at 24% 24%, rgba(114, 121, 134, 0.16), transparent 28%),
    radial-gradient(circle at 78% 30%, rgba(233, 101, 26, 0.13), transparent 28%),
    radial-gradient(circle at 72% 82%, rgba(22, 163, 107, 0.14), transparent 28%),
    linear-gradient(135deg, rgba(235, 241, 253, 0.82), rgba(255, 255, 255, 0.96)),
    #fff;
}

.module-screen {
  position: relative;
  z-index: 3;
  width: min(100%, 520px);
  overflow: hidden;
  border: 1px solid rgba(191, 204, 222, 0.8);
  border-radius: 16px;
  background: #fff;
  box-shadow: var(--gov-shadow);
}

.module-screen__top {
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 46px;
  padding: 0 16px;
  background:
    linear-gradient(90deg, rgba(114, 121, 134, 0.42), rgba(111, 63, 232, 0.34), rgba(233, 101, 26, 0.24), rgba(22, 163, 107, 0.3)),
    var(--gov-navy);
}

.module-screen__top span {
  width: 9px;
  height: 9px;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.28);
}

.module-screen__top strong {
  margin-left: auto;
  color: rgba(255, 255, 255, 0.7);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.78rem;
}

.org-tree,
.desk-chat,
.approve-flow,
.ops-board {
  padding: 22px;
}

.org-tree,
.desk-chat,
.approve-flow {
  display: grid;
  gap: 10px;
}

.org-tree strong,
.org-tree span,
.desk-chat,
.approve-flow span {
  border-radius: 10px;
  padding: 12px 14px;
}

.org-tree strong {
  background: var(--gov-navy);
  color: #fff;
}

.org-tree span {
  margin-left: 18px;
  background: var(--gov-blue-soft);
  color: var(--gov-blue);
  font-weight: 800;
}

.desk-chat {
  background: var(--gov-soft);
}

.desk-chat strong {
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
}

.desk-chat p {
  margin: 0;
  border: 1px solid var(--gov-line);
  border-radius: 12px;
  padding: 14px;
  background: #fff;
  color: var(--gov-muted);
}

.desk-chat span {
  color: var(--gov-green);
  font-weight: 900;
}

.approve-flow span {
  border: 1px solid var(--gov-line);
  background: #fff;
  color: var(--gov-muted);
  font-weight: 900;
}

.approve-flow .is-approved {
  border-color: rgba(13, 158, 107, 0.24);
  background: var(--gov-green-soft);
  color: var(--gov-green);
}

.approve-flow .is-current {
  border-color: rgba(233, 101, 26, 0.26);
  background: var(--gov-orange-soft);
  color: var(--gov-orange);
}

.ops-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.ops-board div {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 240px;
  border-radius: 12px;
  padding: 12px;
  background: var(--gov-soft);
}

.ops-board strong {
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.78rem;
}

.ops-board span {
  display: block;
  height: 52px;
  border-radius: 9px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(11, 27, 58, 0.08);
}

.timeline-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.timeline-grid article {
  padding: 26px;
}

.timeline-grid article span {
  display: grid;
  width: 48px;
  height: 48px;
  place-items: center;
  border-radius: 99px;
  background: var(--gov-navy);
  color: #fff;
  font-family: "Sora", Arial, sans-serif;
  font-weight: 900;
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.feature-grid article,
.usecase-grid article {
  padding: 26px;
}

.line-icon {
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border-radius: 12px;
  background: var(--gov-blue-soft);
  color: var(--gov-blue);
  box-shadow: inset 0 0 0 1px rgba(26, 86, 196, 0.14);
}

.line-icon svg {
  width: 28px;
  height: 28px;
  stroke-width: 1.8;
}

.feature-grid article:nth-child(1) .line-icon,
.feature-grid article:nth-child(4) .line-icon {
  background: linear-gradient(135deg, rgba(111, 63, 232, 0.16), rgba(114, 121, 134, 0.09));
  color: var(--gov-desk);
}

.feature-grid article:nth-child(2) .line-icon,
.feature-grid article:nth-child(5) .line-icon {
  background: linear-gradient(135deg, rgba(233, 101, 26, 0.17), rgba(255, 178, 56, 0.09));
  color: var(--gov-approve);
}

.feature-grid article:nth-child(3) .line-icon,
.feature-grid article:nth-child(6) .line-icon {
  background: linear-gradient(135deg, rgba(22, 163, 107, 0.17), rgba(111, 63, 232, 0.09));
  color: var(--gov-ops);
}

.feature-grid article::after {
  content: "";
  position: absolute;
  inset: auto 18px 0;
  height: 3px;
  border-radius: 99px 99px 0 0;
  background: linear-gradient(90deg, var(--gov-core), var(--gov-desk), var(--gov-approve), var(--gov-ops));
  opacity: 0;
  transition: opacity 0.2s ease;
}

.feature-grid article {
  position: relative;
  overflow: hidden;
}

.feature-grid article:hover::after {
  opacity: 1;
}

.usecase-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.benefits-section {
  background: var(--gov-navy);
  color: #fff;
}

.benefits-section .eyebrow {
  color: #8ec8ff;
}

.benefits-section h2 {
  color: #fff;
}

.benefit-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 34px;
}

.benefit-list div {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  min-height: 96px;
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 14px;
  padding: 17px;
  background: rgba(255, 255, 255, 0.06);
  color: #e7f0fb;
  font-weight: 800;
}

.benefit-list div:hover {
  background: rgba(255, 255, 255, 0.1);
}

.benefit-list span {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin-top: 3px;
  border-radius: 99px;
  background: var(--gov-green);
  box-shadow: 0 0 0 5px rgba(13, 158, 107, 0.15);
}

.comparison-table {
  overflow: hidden;
  border: 1px solid var(--gov-line);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 16px 44px rgba(11, 27, 58, 0.08);
}

.comparison-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.comparison-row span {
  padding: 18px 22px;
  border-top: 1px solid var(--gov-line);
  color: #59667b;
  font-weight: 700;
}

.comparison-row span + span {
  border-left: 1px solid var(--gov-line);
  background: #f4fbf8;
  color: var(--gov-navy);
}

.comparison-head span {
  border-top: 0;
  background: #eef4fb;
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
}

.comparison-head span + span {
  background: var(--gov-navy);
  color: #fff;
}

.security-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(330px, 0.86fr);
  gap: 42px;
  align-items: center;
}

.security-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.security-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  border: 1px solid rgba(26, 86, 196, 0.18);
  border-radius: 99px;
  padding: 0 15px;
  background: #fff;
  color: #40516a;
  font-weight: 900;
  box-shadow: 0 10px 24px rgba(11, 27, 58, 0.07);
}

.security-tags span:nth-child(4n + 1) {
  border-color: rgba(114, 121, 134, 0.24);
  background: linear-gradient(135deg, rgba(114, 121, 134, 0.12), #fff);
}

.security-tags span:nth-child(4n + 2) {
  border-color: rgba(111, 63, 232, 0.22);
  background: linear-gradient(135deg, rgba(111, 63, 232, 0.11), #fff);
}

.security-tags span:nth-child(4n + 3) {
  border-color: rgba(233, 101, 26, 0.22);
  background: linear-gradient(135deg, rgba(233, 101, 26, 0.1), #fff);
}

.security-tags span:nth-child(4n + 4) {
  border-color: rgba(22, 163, 107, 0.22);
  background: linear-gradient(135deg, rgba(22, 163, 107, 0.1), #fff);
}

.pricing-section {
  position: relative;
  overflow: hidden;
  padding-inline: max(10px, calc((100vw - 1680px) / 2));
}

.pricing-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 12%, rgba(111, 63, 232, 0.12), transparent 28%),
    radial-gradient(circle at 72% 18%, rgba(233, 101, 26, 0.1), transparent 30%),
    radial-gradient(circle at 48% 92%, rgba(22, 163, 107, 0.11), transparent 34%);
}

.pricing-section > * {
  position: relative;
  z-index: 1;
}

.pricing-grid {
  width: min(1680px, 100%);
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(286px, 1fr));
  align-items: end;
  gap: 22px;
  margin-top: 42px;
}

.pricing-period {
  width: max-content;
  max-width: 100%;
  display: flex;
  margin: 30px auto 0;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(111, 63, 232, 0.14);
  border-radius: 999px;
  padding: 6px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(239, 244, 252, 0.78));
  box-shadow: 0 18px 42px rgba(11, 27, 58, 0.08);
}

.pricing-period button {
  min-height: 40px;
  border: 0;
  border-radius: 999px;
  padding: 0 18px;
  background: transparent;
  color: #5f6b82;
  font: inherit;
  font-weight: 900;
  cursor: pointer;
  transition: background 0.24s ease, color 0.24s ease, box-shadow 0.24s ease;
}

.pricing-period button span {
  margin-left: 4px;
  color: var(--gov-ops);
  font-size: 0.74rem;
}

.pricing-period button.is-active {
  background:
    linear-gradient(135deg, var(--gov-navy), #1a2c55);
  color: #fff;
  box-shadow: 0 14px 30px rgba(11, 27, 58, 0.18);
}

.pricing-period button.is-active span {
  color: #bff4da;
}

.pricing-featured {
  --pricing-featured-height: 768px;
  position: relative;
  align-self: end;
  display: flex;
  flex-direction: column;
  min-height: var(--pricing-featured-height);
  gap: 8px;
  overflow: hidden;
  border-radius: 26px;
  padding: 0;
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.98), transparent 32%),
    radial-gradient(circle at 86% 14%, rgba(255, 255, 255, 0.7), transparent 34%),
    linear-gradient(135deg, rgba(238, 244, 252, 0.98), rgba(139, 153, 174, 0.34) 48%, rgba(255, 255, 255, 0.92));
  box-shadow:
    0 30px 90px rgba(119, 132, 150, 0.24),
    0 0 0 1px rgba(255, 255, 255, 0.84),
    inset 0 0 70px rgba(255, 255, 255, 0.42);
  animation: pricing-featured-silver 5.8s ease-in-out infinite;
}

.pricing-featured::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(154, 166, 184, 0.42), rgba(255, 255, 255, 0.72));
  opacity: 0.72;
  pointer-events: none;
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite: exclude;
  padding: 1px;
}

.pricing-featured__flag {
  position: relative;
  z-index: 2;
  min-height: 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  border-radius: 26px 26px 0 0;
  padding: 16px 22px;
  background:
    linear-gradient(100deg, rgba(255, 255, 255, 0.98), rgba(207, 218, 232, 0.82), rgba(255, 255, 255, 0.92)),
    radial-gradient(circle at 86% 0%, rgba(255, 255, 255, 0.95), transparent 48%);
  color: #465264;
  box-shadow:
    inset 0 -1px 0 rgba(119, 132, 150, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

.pricing-featured__flag strong {
  color: #1f2937;
  font-family: "Sora", Arial, sans-serif;
  font-size: 1rem;
  line-height: 1;
}

.pricing-featured__flag span {
  color: #667286;
  font-size: 0.82rem;
  font-weight: 850;
  line-height: 1.35;
}

.pricing-featured .pricing-card {
  width: auto;
  flex: 1;
  min-height: 0;
  margin: 0 8px 8px;
  border-radius: 18px 18px 22px 22px;
  border-color: rgba(154, 166, 184, 0.48);
  box-shadow: none;
}

.pricing-card {
  --plan-a: var(--gov-core);
  --plan-b: var(--gov-desk);
  --plan-soft: rgba(114, 121, 134, 0.12);
  position: relative;
  display: flex;
  min-height: 600px;
  flex-direction: column;
  padding: 24px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--plan-a) 28%, rgba(211, 220, 234, 0.86));
  border-radius: 22px;
  background:
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--plan-a) 18%, transparent), transparent 36%),
    radial-gradient(circle at 84% 12%, color-mix(in srgb, var(--plan-b) 13%, transparent), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), color-mix(in srgb, var(--plan-soft) 72%, #fff)),
    #fff;
  background-size: 150% 150%, 145% 145%, 100% 100%, auto;
  background-position: 0% 0%, 100% 0%, 0 0, 0 0;
  box-shadow: 0 18px 48px rgba(11, 27, 58, 0.09);
  animation: pricing-card-glow 7.4s ease-in-out infinite;
  transition: box-shadow 0.28s ease, border-color 0.28s ease, filter 0.28s ease;
}

.pricing-card::before {
  content: "";
  position: absolute;
  z-index: 3;
  inset: 0 0 auto;
  height: 8px;
  background: linear-gradient(90deg, var(--plan-a), var(--plan-b), var(--plan-a));
  background-size: 220% 100%;
  opacity: 0.92;
  animation: pricing-top-scan 5.8s linear infinite;
}

.pricing-card::after {
  content: "";
  position: absolute;
  z-index: 0;
  right: -80px;
  top: -80px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--plan-a) 22%, transparent), transparent 64%),
    radial-gradient(circle at 24% 72%, color-mix(in srgb, var(--plan-b) 16%, transparent), transparent 54%);
  pointer-events: none;
  animation: pricing-orb-drift 8.4s ease-in-out infinite;
}

.pricing-float {
  position: absolute;
  z-index: 1;
  right: 26px;
  top: 44px;
  width: 101px;
  height: 81px;
  color: var(--plan-a);
  opacity: 0.26;
  pointer-events: none;
  background: currentColor;
  overflow: visible;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
  filter:
    drop-shadow(0 18px 28px color-mix(in srgb, var(--plan-a) 42%, transparent))
    saturate(1.24);
  animation: pricing-float-ghost 8.4s ease-in-out infinite;
}

.pricing-float svg {
  display: none;
}

.pricing-float::before,
.pricing-float::after {
  content: "";
  position: absolute;
  inset: 0;
  background: currentColor;
  -webkit-mask-image: inherit;
  mask-image: inherit;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
}

.pricing-float::before {
  opacity: 0.72;
  transform: translate3d(-116px, -66px, 0) rotate(-8deg) scale(0.86);
  animation: pricing-float-echo-a 9.2s ease-in-out infinite;
}

.pricing-float::after {
  opacity: 0.55;
  transform: translate3d(-47px, 86px, 0) rotate(7deg) scale(0.68);
  animation: pricing-float-echo-b 10.4s ease-in-out infinite;
}

.pricing-float--users {
  right: 26px;
  top: 56px;
  width: 101px;
  height: 81px;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%20150%20120'%20fill%3D'none'%20stroke%3D'black'%20stroke-width%3D'8'%20stroke-linecap%3D'round'%20stroke-linejoin%3D'round'%3E%3Ccircle%20cx%3D'42'%20cy%3D'34'%20r%3D'14'%2F%3E%3Ccircle%20cx%3D'86'%20cy%3D'28'%20r%3D'18'%2F%3E%3Ccircle%20cx%3D'116'%20cy%3D'60'%20r%3D'12'%2F%3E%3Cpath%20d%3D'M18%2092c4-24%2044-24%2048%200'%2F%3E%3Cpath%20d%3D'M52%2096c6-32%2062-32%2068%200'%2F%3E%3Cpath%20d%3D'M96%2094c3-20%2038-20%2042%200'%2F%3E%3Cpath%20d%3D'M62%2048c12%2010%2028%2010%2039%200'%2F%3E%3C%2Fsvg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%20150%20120'%20fill%3D'none'%20stroke%3D'black'%20stroke-width%3D'8'%20stroke-linecap%3D'round'%20stroke-linejoin%3D'round'%3E%3Ccircle%20cx%3D'42'%20cy%3D'34'%20r%3D'14'%2F%3E%3Ccircle%20cx%3D'86'%20cy%3D'28'%20r%3D'18'%2F%3E%3Ccircle%20cx%3D'116'%20cy%3D'60'%20r%3D'12'%2F%3E%3Cpath%20d%3D'M18%2092c4-24%2044-24%2048%200'%2F%3E%3Cpath%20d%3D'M52%2096c6-32%2062-32%2068%200'%2F%3E%3Cpath%20d%3D'M96%2094c3-20%2038-20%2042%200'%2F%3E%3Cpath%20d%3D'M62%2048c12%2010%2028%2010%2039%200'%2F%3E%3C%2Fsvg%3E");
}

.pricing-float--chat {
  right: 28px;
  top: 56px;
  width: 106px;
  height: 85px;
  color: #c28513;
  animation-delay: -2s;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%20150%20120'%20fill%3D'none'%20stroke%3D'black'%20stroke-width%3D'8'%20stroke-linecap%3D'round'%20stroke-linejoin%3D'round'%3E%3Cpath%20d%3D'M26%2028h66a16%2016%200%200%201%2016%2016v18a16%2016%200%200%201-16%2016H62L34%2098V78h-8a16%2016%200%200%201-16-16V44a16%2016%200%200%201%2016-16Z'%2F%3E%3Cpath%20d%3D'M54%2038h56a14%2014%200%200%201%2014%2014v16a14%2014%200%200%201-14%2014h-8v18L80%2082'%2F%3E%3Cpath%20d%3D'M36%2050h42'%2F%3E%3Cpath%20d%3D'M36%2062h28'%2F%3E%3Cpath%20d%3D'M72%2056h34'%2F%3E%3C%2Fsvg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%20150%20120'%20fill%3D'none'%20stroke%3D'black'%20stroke-width%3D'8'%20stroke-linecap%3D'round'%20stroke-linejoin%3D'round'%3E%3Cpath%20d%3D'M26%2028h66a16%2016%200%200%201%2016%2016v18a16%2016%200%200%201-16%2016H62L34%2098V78h-8a16%2016%200%200%201-16-16V44a16%2016%200%200%201%2016-16Z'%2F%3E%3Cpath%20d%3D'M54%2038h56a14%2014%200%200%201%2014%2014v16a14%2014%200%200%201-14%2014h-8v18L80%2082'%2F%3E%3Cpath%20d%3D'M36%2050h42'%2F%3E%3Cpath%20d%3D'M36%2062h28'%2F%3E%3Cpath%20d%3D'M72%2056h34'%2F%3E%3C%2Fsvg%3E");
}

.pricing-card:hover .pricing-float {
  opacity: 0.38;
  filter:
    drop-shadow(0 24px 36px color-mix(in srgb, var(--plan-a) 52%, transparent))
    saturate(1.38);
}

.pricing-float-logos {
  position: absolute;
  z-index: 1;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}

.pricing-float-logos img {
  position: absolute;
  width: 67px;
  height: 67px;
  object-fit: contain;
  opacity: 0.26;
  filter:
    grayscale(0.25)
    saturate(1.25)
    drop-shadow(0 18px 28px rgba(71, 198, 244, 0.34));
  animation: pricing-logo-shadow 9.8s ease-in-out infinite;
}

.pricing-float-logos img:nth-child(1) {
  top: 78px;
  right: 30px;
}

.pricing-float-logos img:nth-child(2) {
  top: 194px;
  right: 128px;
  width: 77px;
  height: 77px;
  animation-delay: -2.2s;
}

.pricing-float-logos img:nth-child(3) {
  top: 328px;
  right: 42px;
  animation-delay: -4.4s;
}

.pricing-float-logos img:nth-child(4) {
  top: 446px;
  right: 146px;
  width: 61px;
  height: 61px;
  animation-delay: -6.6s;
}

.pricing-card:hover {
  animation-name: pricing-card-glow-strong;
  animation-duration: 3.6s;
  border-color: color-mix(in srgb, var(--plan-a) 58%, rgba(211, 220, 234, 0.86));
  filter: saturate(1.08);
  box-shadow:
    0 28px 80px color-mix(in srgb, var(--plan-a) 22%, rgba(11, 27, 58, 0.16)),
    0 0 0 1px color-mix(in srgb, var(--plan-b) 24%, transparent),
    inset 0 0 48px color-mix(in srgb, var(--plan-a) 12%, transparent);
}

.pricing-card:hover::before {
  opacity: 1;
  animation-duration: 2.6s;
}

.pricing-card:hover::after {
  animation-name: pricing-orb-drift-strong;
  opacity: 1;
}

.pricing-card--basic {
  --plan-a: #a98262;
  --plan-b: #d2b08e;
  --plan-soft: rgba(169, 130, 98, 0.075);
  animation-delay: -0.8s;
}

.pricing-card--basic-plus {
  --plan-a: #9aa6b8;
  --plan-b: #d9e2ee;
  --plan-soft: rgba(154, 166, 184, 0.16);
  min-height: 670px;
  box-shadow: 0 28px 80px rgba(119, 132, 150, 0.18);
  animation-delay: -2s;
}

.pricing-card--basic-plus:hover {
  box-shadow:
    0 30px 88px rgba(119, 132, 150, 0.26),
    0 0 0 1px rgba(217, 226, 238, 0.38),
    inset 0 0 54px rgba(217, 226, 238, 0.2);
}

.pricing-card--business {
  --plan-a: #d8a21f;
  --plan-b: #f5cf63;
  --plan-soft: rgba(216, 162, 31, 0.16);
  min-height: 740px;
  animation-delay: -3.2s;
}

.pricing-card--corporation {
  --plan-a: #47c6f4;
  --plan-b: #9b6cff;
  --plan-soft: rgba(71, 198, 244, 0.14);
  min-height: 768px;
  animation-delay: -4.4s;
  box-shadow: 0 30px 86px rgba(71, 198, 244, 0.18);
}

.pricing-card__head,
.pricing-price,
.pricing-chat,
.pricing-limits,
.pricing-included,
.pricing-card .btn {
  position: relative;
  z-index: 2;
}

.pricing-card__head span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  border-radius: 999px;
  padding: 0 12px;
  background: color-mix(in srgb, var(--plan-a) 11%, #fff);
  color: color-mix(in srgb, var(--plan-a) 74%, var(--gov-navy));
  font-size: 0.78rem;
  font-weight: 900;
}

.pricing-card h3 {
  margin: 20px 0 10px;
  color: var(--gov-navy);
  font-family: "Sora", Arial, sans-serif;
  font-size: clamp(1.72rem, 2.1vw, 2rem);
  line-height: 1;
}

.pricing-price {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  column-gap: 6px;
  row-gap: 5px;
  margin-top: 18px;
}

.pricing-price strong {
  display: block;
  white-space: nowrap;
  color: var(--plan-a);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--plan-a) 82%, #fff), var(--plan-b) 48%, color-mix(in srgb, var(--plan-a) 76%, #0b1b3a));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "Sora", Arial, sans-serif;
  font-size: clamp(1.75rem, 2.05vw, 2.72rem);
  line-height: 0.94;
  font-weight: 900;
  filter: drop-shadow(0 13px 24px color-mix(in srgb, var(--plan-a) 22%, transparent));
}

.pricing-card--corporation .pricing-price strong,
.pricing-card--corporation .pricing-limits strong {
  background-size: 240% 100%;
  animation: pricing-diamond-text 2.7s ease-in-out infinite;
}

.pricing-price small {
  white-space: nowrap;
  color: var(--gov-muted);
  font-weight: 900;
}

.pricing-price em {
  flex-basis: 100%;
  margin-top: 5px;
  color: color-mix(in srgb, var(--plan-a) 68%, var(--gov-muted));
  font-size: 0.76rem;
  font-style: normal;
  font-weight: 900;
  line-height: 1.25;
}

.pricing-card__head p {
  margin: 16px 0 0;
  color: var(--gov-muted);
  font-size: 0.94rem;
  line-height: 1.62;
}

.pricing-chat {
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: 16px;
  padding: 14px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--plan-a) 14%, #fff), rgba(255, 255, 255, 0.82));
  color: var(--gov-navy);
  font-weight: 900;
  box-shadow: 0 12px 28px rgba(11, 27, 58, 0.055);
}

.pricing-chat {
  margin: 22px 0 18px;
}

.pricing-chat.is-enabled {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--plan-a) 13%, #fff), color-mix(in srgb, var(--plan-b) 12%, #fff));
}

.pricing-chat.is-muted {
  color: #78849a;
  background: linear-gradient(135deg, rgba(114, 121, 134, 0.1), rgba(255, 255, 255, 0.82));
}

.pricing-chat svg {
  flex: 0 0 auto;
  width: 22px;
  height: 22px;
  color: var(--plan-a);
}

.pricing-chat.is-muted svg {
  color: #8d95a4;
}

.pricing-limits {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-bottom: 16px;
}

.pricing-limits div {
  min-height: 31px;
  display: grid;
  grid-template-columns: minmax(48px, auto) minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--plan-a) 16%, rgba(211, 220, 234, 0.82));
  border-radius: 0;
  padding: 4px 0;
  background: transparent;
  box-shadow: none;
  animation: pricing-metric-glow 6.8s ease-in-out infinite;
}

.pricing-limits div:last-child {
  border-bottom: 0;
}

.pricing-limits strong {
  color: var(--plan-a);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--plan-a) 86%, #fff), var(--plan-b) 54%, color-mix(in srgb, var(--plan-a) 76%, #071126));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "Sora", Arial, sans-serif;
  font-size: clamp(1.14rem, 1.55vw, 1.46rem);
  line-height: 1;
  white-space: nowrap;
  filter: drop-shadow(0 8px 18px color-mix(in srgb, var(--plan-a) 18%, transparent));
}

.pricing-limits span {
  color: var(--gov-muted);
  font-size: 0.76rem;
  font-weight: 900;
}

.pricing-infinity {
  width: 40px;
  height: 22px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--plan-a) 16%, #fff), color-mix(in srgb, var(--plan-b) 14%, #fff));
  animation: pricing-diamond-number 2.6s ease-in-out infinite;
}

.pricing-infinity svg {
  width: 32px;
  height: 15px;
  color: var(--plan-a);
  stroke-width: 5;
}

.pricing-included {
  margin: auto 0 24px;
  color: #465872;
  font-weight: 850;
  line-height: 1.48;
}

.pricing-included a {
  color: color-mix(in srgb, var(--plan-a) 74%, var(--gov-navy));
  font-weight: 950;
}

.pricing-included a:hover {
  color: var(--plan-a);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.pricing-card .btn {
  width: 100%;
  margin-top: 0;
  min-height: 52px;
  border: 0;
  overflow: hidden;
  isolation: isolate;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.18);
  box-shadow:
    0 18px 36px color-mix(in srgb, var(--plan-a) 20%, rgba(11, 27, 58, 0.12)),
    inset 0 1px 0 rgba(255, 255, 255, 0.48);
}

.pricing-card .btn::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--plan-a) 94%, #fff), color-mix(in srgb, var(--plan-b) 88%, #fff) 54%, color-mix(in srgb, var(--plan-a) 82%, #111));
  background-size: 180% 180%;
  transition: background-position 0.32s ease, filter 0.32s ease;
}

.pricing-card .btn:hover {
  transform: none;
  box-shadow:
    0 22px 46px color-mix(in srgb, var(--plan-a) 28%, rgba(11, 27, 58, 0.16)),
    0 0 0 1px color-mix(in srgb, var(--plan-b) 28%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.58);
}

.pricing-card .btn:hover::before {
  background-position: 100% 40%;
  filter: saturate(1.18) brightness(1.04);
}

.pricing-card--basic .btn {
  color: #fffaf2;
}

.pricing-card--basic-plus .btn {
  color: #132033;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.54);
  box-shadow:
    0 18px 38px rgba(119, 132, 150, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.74);
}

.pricing-card--basic-plus .btn::before {
  background:
    linear-gradient(135deg, #f8fbff, #becada 44%, #7f8c9f 70%, #eef4fb);
  background-size: 190% 190%;
}

.pricing-card--business .btn {
  color: #171003;
  text-shadow: 0 1px 0 rgba(255, 245, 198, 0.6);
}

.pricing-card--business .btn::before {
  background:
    linear-gradient(135deg, #fff4bd, #e1aa24 42%, #9d6e08 70%, #ffd86f);
  background-size: 190% 190%;
}

.pricing-card--corporation .btn {
  color: #fff;
  text-shadow: 0 1px 8px rgba(25, 53, 97, 0.4);
}

.pricing-card--corporation .btn::before {
  background:
    linear-gradient(135deg, #5fd6ff, #7c72ff 42%, #b66cff 70%, #eaffff);
  background-size: 190% 190%;
}

.pricing-note {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: 26px;
}

.pricing-note span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border: 1px solid rgba(111, 63, 232, 0.14);
  border-radius: 999px;
  padding: 0 14px;
  background: rgba(255, 255, 255, 0.74);
  color: #50627c;
  font-weight: 800;
  box-shadow: 0 12px 28px rgba(11, 27, 58, 0.06);
}

.cta-shell {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  padding: 70px 64px;
  background: var(--gov-navy);
  color: #fff;
  box-shadow: var(--gov-shadow);
}

.cta-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 36%, rgba(26, 86, 196, 0.36), transparent 34%),
    radial-gradient(circle at 76% 40%, rgba(107, 63, 212, 0.24), transparent 36%);
}

.cta-shell > * {
  position: relative;
  z-index: 1;
}

.cta-shell .eyebrow {
  color: #9ed1ff;
}

.cta-shell h2 {
  max-width: 780px;
  color: #fff;
}

.cta-shell p {
  max-width: 640px;
  color: rgba(255, 255, 255, 0.72);
}

.cta-shell .btn-secondary {
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.site-footer {
  position: relative;
  overflow: hidden;
  padding-top: 58px;
  padding-bottom: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background:
    radial-gradient(circle at 14% 12%, rgba(111, 63, 232, 0.32), transparent 34%),
    radial-gradient(circle at 82% 0%, rgba(22, 163, 107, 0.2), transparent 32%),
    linear-gradient(135deg, #071126, #11142b 48%, #160f28);
  color: rgba(255, 255, 255, 0.74);
}

.footer-glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent, rgba(111, 63, 232, 0.16), transparent),
    linear-gradient(135deg, rgba(114, 121, 134, 0.12), transparent 28%, rgba(233, 101, 26, 0.1) 64%, transparent);
  mask-image: linear-gradient(180deg, #000, transparent 82%);
}

.footer-shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(280px, 1.1fr) minmax(0, 1.4fr);
  gap: 64px;
  padding-bottom: 48px;
}

.footer-brand {
  max-width: 520px;
}

.footer-brand-lockup .brand-lockup strong,
.footer-brand-lockup strong {
  color: #fff;
}

.footer-brand-lockup .brand-lockup small,
.footer-brand-lockup small {
  display: block;
  color: rgba(255, 255, 255, 0.58);
  max-width: 390px;
}

.footer-brand p {
  margin: 22px 0 0;
  max-width: 430px;
  color: rgba(255, 255, 255, 0.68);
  font-size: 1rem;
}

.footer-social {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.footer-social a {
  position: relative;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.07);
  color: rgba(255, 255, 255, 0.84);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.18);
  transition: transform 0.28s ease, border-color 0.28s ease, background 0.28s ease;
}

.footer-social a::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(111, 63, 232, 0.42), rgba(22, 163, 107, 0.32), rgba(233, 101, 26, 0.3));
  opacity: 0;
  transition: opacity 0.28s ease;
}

.footer-social a:hover {
  transform: translateY(-4px);
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.12);
}

.footer-social a:hover::before {
  opacity: 1;
}

.footer-social svg {
  position: relative;
  z-index: 1;
  width: 21px;
  height: 21px;
}

.footer-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
}

.footer-columns div {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-columns strong {
  margin-bottom: 6px;
  color: #fff;
  font-family: "Sora", Arial, sans-serif;
  font-size: 0.94rem;
}

.footer-columns a {
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.92rem;
  font-weight: 800;
  transition: color 0.2s ease, transform 0.2s ease;
}

.footer-columns a:hover {
  color: #fff;
  transform: translateX(3px);
}

.footer-bottom {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  min-height: 66px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.52);
  font-size: 0.84rem;
  font-weight: 800;
}

.footer-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  border: 1px solid rgba(22, 163, 107, 0.24);
  border-radius: 999px;
  padding: 0 12px;
  background: rgba(22, 163, 107, 0.1);
  color: rgba(208, 255, 234, 0.84);
}

.footer-status i {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gov-ops);
  box-shadow: 0 0 0 6px rgba(22, 163, 107, 0.12), 0 0 18px rgba(22, 163, 107, 0.6);
}

.footer-bottom nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 14px;
}

.footer-bottom a {
  color: rgba(255, 255, 255, 0.52);
}

.footer-bottom a:hover {
  color: #fff;
}

.reveal-on-scroll {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.72s ease, transform 0.72s ease;
}

.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes pricing-card-glow {
  0%, 100% {
    background-position: 0% 0%, 100% 0%, 0 0, 0 0;
    box-shadow: 0 18px 48px rgba(11, 27, 58, 0.09);
  }
  50% {
    background-position: 72% 20%, 28% 80%, 0 0, 0 0;
    box-shadow: 0 24px 64px color-mix(in srgb, var(--plan-a) 13%, rgba(11, 27, 58, 0.12));
  }
}

@keyframes pricing-card-glow-strong {
  0%, 100% {
    background-position: 0% 0%, 100% 0%, 0 0, 0 0;
    box-shadow:
      0 28px 80px color-mix(in srgb, var(--plan-a) 22%, rgba(11, 27, 58, 0.16)),
      0 0 0 1px color-mix(in srgb, var(--plan-b) 24%, transparent),
      inset 0 0 48px color-mix(in srgb, var(--plan-a) 12%, transparent);
  }
  50% {
    background-position: 90% 28%, 10% 72%, 0 0, 0 0;
    box-shadow:
      0 36px 96px color-mix(in srgb, var(--plan-a) 30%, rgba(11, 27, 58, 0.2)),
      0 0 0 1px color-mix(in srgb, var(--plan-b) 38%, transparent),
      inset 0 0 76px color-mix(in srgb, var(--plan-b) 16%, transparent);
  }
}

@keyframes pricing-featured-silver {
  0%, 100% {
    filter: saturate(1) brightness(1);
    box-shadow:
      0 30px 90px rgba(119, 132, 150, 0.24),
      0 0 0 1px rgba(255, 255, 255, 0.84),
      inset 0 0 70px rgba(255, 255, 255, 0.42);
  }
  50% {
    filter: saturate(1.08) brightness(1.04);
    box-shadow:
      0 34px 104px rgba(119, 132, 150, 0.34),
      0 0 0 1px rgba(255, 255, 255, 0.95),
      0 0 44px rgba(217, 226, 238, 0.5),
      inset 0 0 92px rgba(255, 255, 255, 0.56);
  }
}

@keyframes pricing-top-scan {
  from { background-position: 0% 50%; }
  to { background-position: 220% 50%; }
}

@keyframes pricing-orb-drift {
  0%, 100% {
    opacity: 0.72;
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    opacity: 1;
    transform: translate3d(-18px, 16px, 0) scale(1.12);
  }
}

@keyframes pricing-orb-drift-strong {
  0%, 100% {
    opacity: 0.92;
    transform: translate3d(0, 0, 0) scale(1.12);
  }
  50% {
    opacity: 1;
    transform: translate3d(-30px, 24px, 0) scale(1.32);
  }
}

@keyframes pricing-float-drift {
  0%, 100% {
    transform: translate3d(0, 0, 0) rotate(-2deg) scale(1);
  }
  50% {
    transform: translate3d(-12px, 10px, 0) rotate(2deg) scale(1.06);
  }
}

@keyframes pricing-float-ghost {
  0%, 100% {
    opacity: 0.16;
    transform: translate3d(0, 10px, 0) rotate(-5deg) scale(0.94);
  }
  18%, 72% {
    opacity: 0.28;
  }
  46% {
    opacity: 0.42;
    transform: translate3d(-8px, -8px, 0) rotate(3deg) scale(1.04);
  }
}

@keyframes pricing-float-echo-a {
  0%, 100% {
    opacity: 0.28;
    transform: translate3d(-116px, -66px, 0) rotate(-8deg) scale(0.78);
  }
  45% {
    opacity: 0.72;
    transform: translate3d(-128px, -79px, 0) rotate(-2deg) scale(0.9);
  }
}

@keyframes pricing-float-echo-b {
  0%, 100% {
    opacity: 0.18;
    transform: translate3d(-47px, 86px, 0) rotate(7deg) scale(0.58);
  }
  52% {
    opacity: 0.56;
    transform: translate3d(-38px, 74px, 0) rotate(1deg) scale(0.72);
  }
}

@keyframes pricing-logo-shadow {
  0%, 100% {
    opacity: 0.18;
    transform: translate3d(0, 12px, 0) rotate(-8deg) scale(0.9);
  }
  42%, 68% {
    opacity: 0.34;
  }
  54% {
    opacity: 0.44;
    transform: translate3d(-10px, -8px, 0) rotate(5deg) scale(1.08);
  }
}

@keyframes pricing-diamond-text {
  0%, 100% {
    background-position: 0% 50%;
    filter: drop-shadow(0 0 0 rgba(71, 198, 244, 0));
  }
  50% {
    background-position: 100% 50%;
    filter:
      drop-shadow(0 0 16px rgba(71, 198, 244, 0.62))
      drop-shadow(0 8px 20px rgba(155, 108, 255, 0.28));
  }
}

@keyframes pricing-metric-glow {
  0%, 100% {
    border-color: color-mix(in srgb, var(--plan-a) 18%, var(--gov-line));
  }
  50% {
    border-color: color-mix(in srgb, var(--plan-a) 34%, var(--gov-line));
  }
}

@keyframes pricing-diamond-number {
  0%, 100% {
    filter: drop-shadow(0 0 0 rgba(71, 198, 244, 0));
    transform: scale(1);
  }
  50% {
    filter: drop-shadow(0 0 14px rgba(71, 198, 244, 0.72));
    transform: scale(1.04);
  }
}

@keyframes flowLine {
  from { transform: translateX(0); opacity: 0; }
  12% { opacity: 1; }
  82% { opacity: 1; }
  to { transform: translateX(250%); opacity: 0; }
}

@keyframes pulseDot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.45; transform: scale(0.72); }
}

@keyframes floatWindow {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

@keyframes floatNote {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

@keyframes pulseRing {
  0%, 100% { box-shadow: 0 0 0 7px var(--gov-blue-soft); }
  50% { box-shadow: 0 0 0 12px rgba(235, 241, 253, 0.4); }
}

@keyframes pathPulse {
  0%, 100% { opacity: 0.45; }
  50% { opacity: 1; }
}

@keyframes dashFlow {
  to { stroke-dashoffset: -240; }
}

@keyframes artDrift {
  0%, 100% { transform: scale(1.04) translate3d(0, 0, 0); }
  50% { transform: scale(1.08) translate3d(-10px, -6px, 0); }
}

@keyframes chromaBreath {
  0%, 100% { opacity: 0.68; transform: scale(0.98); }
  50% { opacity: 0.98; transform: scale(1.02); }
}

@keyframes orbitGlow {
  0%, 100% { opacity: 0.45; filter: saturate(1); }
  50% { opacity: 0.9; filter: saturate(1.35); }
}

@keyframes orbitFloat {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-10px) rotate(1.5deg); }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }

  .reveal-on-scroll {
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 1060px) {
  .site-nav {
    position: fixed;
    top: 78px;
    left: 16px;
    right: 16px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    border: 1px solid var(--gov-line);
    border-radius: 14px;
    padding: 10px;
    background: #fff;
    box-shadow: var(--gov-shadow);
  }

  .site-nav.is-open {
    display: flex;
  }

  .site-nav a {
    justify-content: center;
  }

  .site-nav a::after {
    display: none;
  }

  .nav-toggle {
    display: inline-block;
  }

  .hero-section {
    grid-template-columns: 1fr;
    gap: 46px;
    min-height: auto;
  }

  .hero-content h1 {
    font-size: 3.9rem;
  }

  .hero-visual {
    min-height: 590px;
  }

  .flow-window {
    left: 0;
    right: auto;
  }

  .orbit-line {
    left: 24px;
    right: auto;
    width: min(540px, calc(100% - 48px));
  }

  .value-grid,
  .benefit-list,
  .module-tabs,
  .showcase-grid,
  .pricing-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .module-panel {
    grid-template-columns: 1fr;
    position: relative;
    display: none;
  }

  .module-panel.is-active {
    display: grid;
  }

  .module-panels {
    min-height: 0;
  }

  .feature-grid,
  .usecase-grid,
  .timeline-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .security-layout {
    grid-template-columns: 1fr;
  }

  .pricing-card--basic-plus {
    transform: none;
  }

  .pricing-card--basic-plus:hover {
    box-shadow:
      0 30px 88px rgba(119, 132, 150, 0.26),
      0 0 0 1px rgba(217, 226, 238, 0.38),
      inset 0 0 54px rgba(217, 226, 238, 0.2);
  }

  .footer-shell {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .footer-columns {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .footer-bottom {
    flex-wrap: wrap;
    justify-content: flex-start;
    padding: 18px 0;
  }
}

@media (max-width: 720px) {
  .site-header {
    min-height: 64px;
    padding-inline: 16px;
  }

  .brand-lockup small {
    display: none;
  }

  .footer-brand-lockup small {
    display: block;
  }

  .hero-section {
    padding: 104px 18px 64px;
  }

  .hero-content h1 {
    font-size: 2.65rem;
  }

  .hero-subtitle {
    font-size: 1rem;
  }

  .hero-actions,
  .trust-row {
    flex-direction: column;
  }

  .btn,
  .trust-row span {
    width: 100%;
  }

  .hero-visual {
    min-height: 760px;
  }

  .flow-window {
    top: 86px;
    left: 0;
    right: 0;
    bottom: auto;
    width: 100%;
  }

  .hero-visual::before {
    inset: 24px 0 64px;
  }

  .module-orbit {
    top: 0;
    height: 150px;
  }

  .orbit-line {
    top: 44px;
    left: 0;
    width: 100%;
    height: 76px;
    border-radius: 22px;
  }

  .orbit-logo {
    width: 52px;
    height: 52px;
    border-radius: 14px;
  }

  .orbit-logo::before {
    border-radius: 16px;
  }

  .orbit-logo img {
    width: 36px;
    height: 36px;
  }

  .orbit-core {
    top: 6px;
    left: 0;
  }

  .orbit-desk {
    top: 22px;
    right: auto;
    left: 31%;
  }

  .orbit-approve {
    top: 22px;
    right: 31%;
    bottom: auto;
  }

  .orbit-ops {
    top: 6px;
    right: 0;
    bottom: auto;
    left: auto;
  }

  .flow-path,
  .workflow-grid,
  .kanban-card,
  .ops-board {
    grid-template-columns: 1fr;
  }

  .module-panel__visual {
    min-height: 420px;
    padding: 18px;
  }

  .module-screen {
    right: auto;
    bottom: auto;
    width: 100%;
  }

  .ai-hero-art {
    right: -44px;
    bottom: 18px;
    width: 190px;
    height: 280px;
    opacity: 0.72;
  }

  .flow-path em {
    width: 2px;
    height: 18px;
    margin: 0 auto;
  }

  .float-note {
    position: relative;
    display: inline-flex;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    margin: 558px 8px 0 0;
  }

  .note-two,
  .note-three,
  .note-four {
    margin-top: 10px;
  }

  .section-pad {
    padding: 68px 18px;
  }

  .section-heading h2,
  .security-layout h2,
  .cta-shell h2 {
    font-size: 2.16rem;
  }

  .compare-split,
  .value-grid,
  .showcase-grid,
  .module-tabs,
  .feature-grid,
  .usecase-grid,
  .pricing-grid,
  .timeline-grid,
  .benefit-list,
  .comparison-row {
    grid-template-columns: 1fr;
  }

  .module-tab {
    min-height: 58px;
  }

  .module-panel__copy,
  .module-panel__visual,
  .pricing-card,
  .cta-shell {
    padding: 24px;
  }

  .pricing-card,
  .pricing-featured .pricing-card {
    min-height: 0;
  }

  .pricing-featured {
    padding: 0;
  }

  .pricing-float,
  .pricing-float--users,
  .pricing-float--chat,
  .pricing-float--corporation {
    left: auto;
    right: 20px;
    top: 52px;
    width: 83px;
    height: 67px;
    opacity: 0.22;
  }

  .pricing-note {
    justify-content: flex-start;
  }

  .pricing-note span {
    width: 100%;
    min-height: 0;
    padding: 11px 14px;
    border-radius: 14px;
  }

  .comparison-row span + span {
    border-left: 0;
  }

  .comparison-head span + span {
    display: none;
  }

  .site-footer {
    padding: 44px 18px 0;
  }

  .footer-shell {
    padding-bottom: 34px;
  }

  .footer-columns {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .footer-bottom {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
  }

  .footer-bottom nav {
    justify-content: flex-start;
  }
}

@media (max-width: 480px) {
  .site-header {
    min-height: 60px;
    padding-inline: 14px;
  }

  .brand-mark {
    width: 38px;
    height: 38px;
    border-radius: 10px;
  }

  .brand-lockup strong {
    font-size: 0.98rem;
  }

  .site-nav {
    top: 68px;
    left: 10px;
    right: 10px;
  }

  .hero-section {
    padding: 92px 14px 54px;
  }

  .hero-content h1 {
    font-size: 2.22rem;
    line-height: 1.03;
  }

  .hero-subtitle,
  .section-heading p:not(.eyebrow),
  .security-layout p,
  .cta-shell p {
    font-size: 0.96rem;
  }

  .hero-visual {
    min-height: 630px;
  }

  .flow-window {
    top: 78px;
    border-radius: 14px;
  }

  .flow-window__bar {
    min-height: 40px;
    padding: 0 12px;
  }

  .flow-window__bar strong {
    font-size: 0.66rem;
  }

  .flow-path {
    grid-template-columns: 1fr 24px 1fr 24px 1fr;
    padding: 16px 12px 8px;
  }

  .flow-step i {
    width: 32px;
    height: 32px;
    border-width: 4px;
  }

  .flow-step strong {
    font-size: 0.68rem;
  }

  .flow-step small {
    display: none;
  }

  .workflow-grid {
    gap: 10px;
    padding: 10px 12px 14px;
  }

  .request-card {
    min-height: 178px;
    padding: 14px;
  }

  .request-card h3 {
    font-size: 1rem;
  }

  .decision-card,
  .kanban-card {
    min-height: 92px;
  }

  .float-note {
    margin-top: 468px;
    max-width: 100%;
  }

  .section-pad {
    padding: 58px 14px;
  }

  .section-heading h2,
  .security-layout h2,
  .cta-shell h2 {
    font-size: 1.82rem;
  }

  .compare-panel,
  .value-grid article,
  .feature-grid article,
  .usecase-grid article,
  .timeline-grid article,
  .pricing-card {
    border-radius: 14px;
  }

  .compare-icon {
    max-width: 100%;
  }

  .module-panel__visual {
    min-height: 320px;
  }

  .module-screen {
    min-width: 0;
  }

  .showcase-card__body,
  .module-panel__copy,
  .module-panel__visual,
  .pricing-card,
  .cta-shell {
    padding: 20px;
  }

  .pricing-card h3 {
    font-size: 1.68rem;
  }

  .site-footer {
    padding-inline: 14px;
  }
}

@media (max-width: 360px) {
  .hero-content h1 {
    font-size: 2rem;
  }

  .hero-visual {
    min-height: 600px;
  }

  .float-note {
    margin-top: 438px;
  }

  .flow-window__bar strong {
    display: none;
  }

  .section-heading h2,
  .security-layout h2,
  .cta-shell h2 {
    font-size: 1.64rem;
  }

  .pricing-card {
    padding: 18px;
  }
}
