@import url("./tokens.css");

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  overflow-x: clip;
}

html {
  scroll-behavior: smooth;
  background: var(--color-bg);
}

body {
  min-width: 0;
  margin: 0;
  color: var(--color-ink);
  background:
    linear-gradient(to right, transparent calc(100% - var(--rule-thin)), rgba(0, 230, 118, 0.08) 0) 0 0 / 4rem 4rem,
    linear-gradient(to bottom, transparent calc(100% - var(--rule-thin)), rgba(0, 230, 118, 0.06) 0) 0 0 / 4rem 4rem,
    var(--color-bg);
  font-family: var(--font-body);
  font-variant-numeric: tabular-nums;
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background: linear-gradient(90deg, rgba(0, 230, 118, 0.08), transparent 26%, transparent 74%, rgba(0, 230, 118, 0.06));
  opacity: 0.5;
  pointer-events: none;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
a {
  -webkit-tap-highlight-color: transparent;
}

button {
  font: inherit;
}

h1,
h2,
h3,
p,
figure {
  margin: 0;
}

h1,
h2,
h3 {
  min-width: 0;
  color: var(--color-ink);
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

h1 {
  max-width: 14ch;
  font-size: var(--text-display);
  line-height: 0.98;
}

h2 {
  max-width: 16ch;
  font-size: var(--text-3xl);
  line-height: 1;
}

h3 {
  font-size: var(--text-xl);
  line-height: 1.05;
}

p {
  color: var(--color-ink-2);
  font-size: var(--text-md);
  line-height: 1.62;
}

ul,
ol {
  margin-block: 0;
  padding-inline-start: var(--space-md);
}

li {
  margin-block-end: var(--space-2xs);
  color: var(--color-ink-2);
  line-height: 1.55;
}

::selection {
  color: var(--color-signal-ink);
  background: var(--color-signal);
}

.scroll-meter {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: calc(var(--z-sticky-nav) + 1);
  height: var(--rule-bold);
  background: transparent;
  pointer-events: none;
}

.scroll-meter span {
  display: block;
  width: 0;
  height: 100%;
  background: var(--color-signal);
}

.site-header {
  position: sticky;
  inset-block-start: 0;
  z-index: var(--z-sticky-nav);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xs);
  padding: var(--space-sm);
  background: rgba(0, 0, 0, 0.92);
  border-block-end: var(--rule-thin) solid var(--color-rule-strong);
}

.brand {
  display: inline-grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  justify-self: start;
  gap: var(--space-xs);
  color: var(--color-ink);
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.brand-mark {
  display: grid;
  width: 2.5rem;
  height: 2.5rem;
  place-items: center;
  color: var(--color-signal-ink);
  background: var(--color-signal);
  font-size: var(--text-xs);
  font-weight: 900;
}

.main-nav {
  display: flex;
  gap: var(--space-2xs);
  overflow-x: auto;
  color: var(--color-muted);
  scrollbar-width: none;
}

.main-nav::-webkit-scrollbar {
  display: none;
}

.main-nav a {
  display: inline-flex;
  min-height: 2.25rem;
  align-items: center;
  padding-inline: var(--space-xs);
  border: var(--rule-thin) solid var(--color-rule);
  background: var(--color-bg);
  font-size: var(--text-sm);
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  transition:
    color var(--dur-short) var(--ease-out),
    background-color var(--dur-short) var(--ease-out),
    border-color var(--dur-short) var(--ease-out),
    transform var(--dur-short) var(--ease-out);
}

.main-nav a:hover,
.main-nav a:focus-visible {
  color: var(--color-signal-ink);
  background: var(--color-signal);
  border-color: var(--color-signal);
  outline: none;
}

.main-nav a:focus-visible {
  outline: var(--rule-bold) solid var(--color-focus);
  outline-offset: var(--space-3xs);
}

.main-nav a:active {
  transform: translateY(var(--rule-thin));
}

.section-grid,
.target-section,
.security-section,
.process-section,
.service-title-section,
.crm-section,
.contact-section,
.site-footer {
  width: min(100%, 88rem);
  margin-inline: auto;
  padding-inline: var(--space-sm);
}

.section-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-xl);
  padding-block: var(--space-2xl);
  border-inline: var(--rule-thin) solid var(--color-rule);
}

.hero {
  min-height: auto;
  padding-block-start: var(--space-xl);
  padding-block-end: var(--space-3xl);
}

.hero-copy {
  display: grid;
  min-width: 0;
  gap: var(--space-md);
  align-content: start;
}

.eyebrow,
.section-number,
.panel-label,
.package-item span,
.process-card span,
.crm-flow span {
  display: inline-flex;
  width: fit-content;
  margin-block-end: var(--space-sm);
  color: var(--color-signal);
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1;
}

.hero-text {
  max-width: 62ch;
  color: var(--color-ink-2);
  font-size: var(--text-lg);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  align-items: center;
}

.button,
.filter-btn,
.scroll-to-top {
  display: inline-flex;
  min-height: 2.75rem;
  align-items: center;
  justify-content: center;
  padding: var(--space-xs) var(--space-sm);
  border: var(--rule-thin) solid var(--color-rule-strong);
  border-radius: 0;
  color: var(--color-ink);
  background: var(--color-bg);
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition:
    color var(--dur-short) var(--ease-out),
    background-color var(--dur-short) var(--ease-out),
    border-color var(--dur-short) var(--ease-out),
    transform var(--dur-short) var(--ease-out);
}

.button.primary,
.filter-btn.active,
.filter-btn[aria-pressed="true"] {
  color: var(--color-signal-ink);
  background: var(--color-signal);
  border-color: var(--color-signal);
}

.button:hover,
.button:focus-visible,
.filter-btn:hover,
.filter-btn:focus-visible {
  color: var(--color-signal-ink);
  background: var(--color-signal);
  border-color: var(--color-signal);
  outline: none;
}

.button:focus-visible,
.filter-btn:focus-visible,
.scroll-to-top:focus-visible {
  outline: var(--rule-bold) solid var(--color-focus);
  outline-offset: var(--space-3xs);
}

.button:active,
.filter-btn:active,
.scroll-to-top:active {
  transform: translateY(var(--rule-thin));
}

.security-console {
  display: grid;
  min-width: 0;
  align-self: start;
  border: var(--rule-thin) solid var(--color-rule-strong);
  background: var(--color-panel);
  transform: perspective(900px) rotateX(var(--tilt-x, 0deg)) rotateY(var(--tilt-y, 0deg));
  transform-style: preserve-3d;
  transition: border-color var(--dur-short) var(--ease-out);
}

.console-head,
.console-row,
.console-checks span,
.signal-grid span,
.capability-panel,
.security-card,
.title-strip span,
.package-item,
.process-card,
.crm-flow article,
.crm-stack article,
.field-cloud span,
.pipeline-list span,
.ops-row strong,
.ops-row span,
.target-card,
.contact-card,
.code-panel {
  border-color: var(--color-rule-strong);
}

.console-head {
  display: flex;
  justify-content: space-between;
  gap: var(--space-sm);
  padding: var(--space-sm);
  border-block-end: var(--rule-thin) solid var(--color-rule-strong);
  color: var(--color-signal);
  font-size: var(--text-sm);
  font-weight: 800;
}

.console-body {
  display: grid;
}

.console-row {
  display: grid;
  grid-template-columns: minmax(0, 0.42fr) minmax(0, 1fr);
  border-block-end: var(--rule-thin) solid var(--color-rule);
}

.console-row strong,
.console-row span {
  padding: var(--space-sm);
  min-width: 0;
}

.console-row strong {
  color: var(--color-muted);
  font-size: var(--text-sm);
}

.console-row span {
  color: var(--color-ink);
  font-weight: 700;
}

.console-checks {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  border-block-start: var(--rule-thin) solid var(--color-rule-strong);
}

.console-checks span {
  min-height: 5.5rem;
  align-content: end;
  padding: var(--space-sm);
  border-block-end: var(--rule-thin) solid var(--color-rule);
  color: var(--color-ink);
  font-weight: 800;
}

.console-checks span:nth-child(2n + 1) {
  color: var(--color-signal);
}

.intro-band {
  align-items: start;
  background: var(--color-panel);
  border-block: var(--rule-thin) solid var(--color-rule-strong);
}

.intro-band p:last-child {
  max-width: 66ch;
  color: var(--color-ink);
  font-size: var(--text-xl);
  font-weight: 800;
  line-height: 1.18;
}

.security-section,
.target-section,
.process-section,
.service-title-section,
.crm-section,
.contact-section {
  padding-block: var(--space-2xl);
  border-inline: var(--rule-thin) solid var(--color-rule);
}

.section-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-md);
  margin-block-end: var(--space-lg);
}

.section-heading > p {
  max-width: 58ch;
}

.security-grid,
.target-grid,
.capability-grid,
.title-strip,
.package-list,
.process-grid,
.crm-flow,
.crm-stack,
.crm-ops-grid,
.contact-grid,
.copy-blocks {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  border-block-start: var(--rule-thin) solid var(--color-rule-strong);
  border-inline-start: var(--rule-thin) solid var(--color-rule-strong);
}

.security-card,
.target-card,
.capability-panel,
.title-strip span,
.package-item,
.process-card,
.crm-flow article,
.crm-stack article,
.crm-ops-grid article,
.contact-card,
.code-panel {
  min-width: 0;
  background: var(--color-panel);
  border-inline-end: var(--rule-thin) solid var(--color-rule-strong);
  border-block-end: var(--rule-thin) solid var(--color-rule-strong);
}

.security-card,
.capability-panel,
.process-card,
.crm-stack article,
.crm-ops-grid article,
.contact-card {
  padding: var(--space-md);
}

.security-card {
  display: grid;
  min-height: 15rem;
  align-content: space-between;
  gap: var(--space-lg);
}

.security-card p,
.capability-panel li,
.process-card p,
.target-card p,
.crm-flow p,
.ops-row span,
.contact-card p {
  font-size: var(--text-sm);
}

.security-card h3,
.capability-panel h3,
.process-card h3,
.crm-stack h3,
.crm-ops-grid h3,
.contact-card h3 {
  margin-block-end: var(--space-sm);
}

.security-card strong {
  color: var(--color-signal);
  font-size: var(--text-xs);
}

.service-section,
.package-section {
  border-block: var(--rule-thin) solid var(--color-rule-strong);
}

.capability-panel ul,
.crm-stack ul {
  list-style: none;
  padding-inline-start: 0;
}

.capability-panel li,
.crm-stack li {
  position: relative;
  padding-inline-start: var(--space-md);
}

.capability-panel li::before,
.crm-stack li::before {
  content: "";
  position: absolute;
  inset-block-start: 0.78em;
  inset-inline-start: 0;
  width: var(--space-xs);
  height: var(--rule-thin);
  background: var(--color-signal);
}

.service-title-section,
.crm-section {
  background: rgba(11, 12, 10, 0.72);
}

.title-strip span {
  min-height: 8rem;
  align-content: end;
  padding: var(--space-sm);
  color: var(--color-ink);
  font-size: var(--text-lg);
  font-weight: 800;
  line-height: 1.08;
}

.title-strip span:nth-child(3n + 1) {
  color: var(--color-signal);
}

.package-item {
  display: grid;
  gap: var(--space-lg);
  padding: var(--space-md);
}

.package-item strong {
  color: var(--color-signal);
  font-size: var(--text-2xl);
  font-weight: 900;
  line-height: 1;
}

.process-card {
  display: grid;
  min-height: 14rem;
  align-content: space-between;
  gap: var(--space-md);
}

.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
  align-items: center;
}

.filter-btn {
  min-height: 2.5rem;
  font-size: var(--text-sm);
}

.target-card {
  position: relative;
  display: grid;
  min-height: 16rem;
  align-content: start;
  gap: var(--space-sm);
  padding: var(--space-sm);
  overflow: hidden;
}

.card-glow {
  display: none;
}

.card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
}

.badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.5rem;
  padding-inline: var(--space-2xs);
  border: var(--rule-thin) solid var(--color-rule);
  color: var(--color-ink-2);
  background: var(--color-bg);
  font-size: var(--text-xs);
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.badge.security {
  color: var(--color-signal);
  border-color: var(--color-signal);
}

.target-card h3,
.target-card a {
  width: fit-content;
  color: var(--color-ink);
  font-size: var(--text-xl);
  font-weight: 800;
  line-height: 1.05;
  transition: color var(--dur-short) var(--ease-out);
}

.target-card a:hover,
.target-card a:focus-visible {
  color: var(--color-signal);
  outline: none;
}

.target-card a:focus-visible {
  outline: var(--rule-bold) solid var(--color-focus);
  outline-offset: var(--space-3xs);
}

.target-card .direction {
  color: var(--color-ink);
  font-weight: 800;
}

.target-card p:last-child {
  padding-block-start: var(--space-sm);
  border-block-start: var(--rule-thin) solid var(--color-rule);
}

.crm-flow article {
  display: grid;
  min-height: 13rem;
  align-content: space-between;
  gap: var(--space-md);
  padding: var(--space-sm);
}

.field-cloud,
.pipeline-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
}

.field-cloud span,
.pipeline-list span {
  display: inline-flex;
  min-height: 2rem;
  align-items: center;
  padding-inline: var(--space-xs);
  border: var(--rule-thin) solid var(--color-rule);
  color: var(--color-ink-2);
  background: var(--color-bg);
  font-size: var(--text-sm);
  font-weight: 700;
}

.field-cloud span:nth-child(4n + 1),
.pipeline-list span:nth-child(3n + 1) {
  color: var(--color-signal);
}

.ops-table {
  display: grid;
  border-block-start: var(--rule-thin) solid var(--color-rule-strong);
  border-inline-start: var(--rule-thin) solid var(--color-rule-strong);
}

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

.ops-row strong,
.ops-row span {
  padding: var(--space-sm);
  border-inline-end: var(--rule-thin) solid var(--color-rule-strong);
  border-block-end: var(--rule-thin) solid var(--color-rule-strong);
}

.ops-row strong {
  color: var(--color-signal);
  font-size: var(--text-md);
  font-weight: 800;
  line-height: 1.15;
}

.contact-card.primary {
  background: var(--color-signal);
}

.contact-card.primary h3,
.contact-card.primary p,
.contact-card.primary li {
  color: var(--color-signal-ink);
}

.contact-card ol {
  padding-inline-start: var(--space-md);
}

.copy-blocks {
  margin-block-start: var(--space-lg);
}

.code-panel figcaption {
  padding: var(--space-xs) var(--space-sm);
  border-block-end: var(--rule-thin) solid var(--color-rule);
  color: var(--color-signal);
  font-size: var(--text-xs);
  font-weight: 900;
}

.code-body {
  overflow-x: auto;
  padding: var(--space-sm);
}

.code-body pre {
  margin: 0;
  color: var(--color-ink);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  line-height: 1.6;
}

.t-key,
.t-keyword {
  color: var(--color-signal);
}

.t-val {
  color: var(--color-ink);
}

.t-comment {
  color: var(--color-muted);
}

.site-footer {
  display: grid;
  gap: var(--space-2xs);
  padding-block: var(--space-lg);
  border-block-start: var(--rule-thin) solid var(--color-rule-strong);
  color: var(--color-muted);
  font-size: var(--text-sm);
}

.site-footer span:first-child {
  color: var(--color-ink);
  font-weight: 900;
}

.scroll-to-top {
  position: fixed;
  inset-inline-end: var(--space-sm);
  inset-block-end: var(--space-sm);
  z-index: var(--z-sticky-nav);
  width: 2.75rem;
  padding: 0;
  opacity: 0;
  pointer-events: none;
  color: var(--color-signal-ink);
  background: var(--color-signal);
  border-color: var(--color-signal);
  transform: translateY(var(--space-2xs));
}

.scroll-to-top.visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.scroll-to-top:hover {
  color: var(--color-ink);
  background: var(--color-bg);
}

@media (min-width: 40rem) {
  .site-header {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    padding-inline: var(--space-md);
  }

  .main-nav {
    justify-content: flex-end;
  }

  .section-grid,
  .target-section,
  .security-section,
  .process-section,
  .service-title-section,
  .crm-section,
  .contact-section,
  .site-footer {
    padding-inline: var(--space-lg);
  }

  .console-checks,
  .security-grid,
  .capability-grid,
  .crm-stack,
  .crm-ops-grid,
  .contact-grid,
  .copy-blocks {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .target-grid,
  .title-strip,
  .process-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ops-row {
    grid-template-columns: minmax(12rem, 0.34fr) minmax(0, 1fr);
  }
}

@media (min-width: 60rem) {
  h1 {
    font-size: var(--text-display-lg);
  }

  h2 {
    font-size: var(--text-display);
  }

  .section-grid {
    grid-template-columns: minmax(0, 0.94fr) minmax(0, 1.06fr);
    padding-block: var(--space-3xl);
  }

  .hero {
    padding-block-start: var(--space-2xl);
    padding-block-end: var(--space-4xl);
  }

  .section-heading {
    grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
    align-items: end;
  }

  .filter-bar {
    justify-content: flex-end;
  }

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

  .title-strip,
  .process-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .package-item {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
  }

  .crm-flow {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .site-footer {
    grid-template-columns: auto 1fr;
    align-items: center;
  }

  .site-footer span:last-child {
    justify-self: end;
  }
}

@media (min-width: 72rem) {
  .card-glow {
    position: absolute;
    display: block;
    inset-inline-start: var(--glow-x, 50%);
    inset-block-start: var(--glow-y, 50%);
    width: 3rem;
    height: 3rem;
    border: var(--rule-thin) solid var(--color-signal);
    background: transparent;
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, -50%);
  }

  .target-card > *:not(.card-glow) {
    position: relative;
  }
}

@media (min-width: 90rem) {
  .section-grid,
  .target-section,
  .security-section,
  .process-section,
  .service-title-section,
  .crm-section,
  .contact-section,
  .site-footer {
    width: min(100%, 94rem);
    padding-inline: var(--space-xl);
  }
}

@media (max-width: 28rem) {
  .hero-actions,
  .button {
    width: 100%;
  }

  .filter-btn {
    flex: 1 1 100%;
  }

  h1 {
    font-size: 2.35rem;
  }
}

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