/*!**************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./components/Wordmark.module.css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************/
.Wordmark_wordmark__yEZCL {
  font-family: var(--font-display);
  font-size: var(--step-3);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.04;
  text-wrap: balance;
}

/* Two-tone lockup: the name leads, "Solutions" recedes a step. */
.Wordmark_lead__KKkeO {
  color: var(--color-text);
}

.Wordmark_trail__k_JLS {
  color: var(--color-text-muted);
  font-weight: 500;
}

/*!***************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./components/RiverFlow.module.css ***!
  \***************************************************************************************************************************************************************************************************************************************************************************/
.RiverFlow_root__SWBDg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  /* Concentrate the motif beneath the wordmark and melt it into the page,
     so it never reads as a hard-edged banner. */
  -webkit-mask-image: radial-gradient(
    120% 78% at 50% 58%,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 0.55) 46%,
    rgba(0, 0, 0, 0) 80%
  );
  mask-image: radial-gradient(
    120% 78% at 50% 58%,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 0.55) 46%,
    rgba(0, 0, 0, 0) 80%
  );
}

.RiverFlow_svg__16F88 {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  /* Strokes inherit this via currentColor. */
  color: var(--color-accent);
}

.RiverFlow_wave__CmnPy {
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  /* Keep stroke weight constant despite the non-uniform SVG stretch. */
  vector-effect: non-scaling-stroke;
  animation-name: RiverFlow_drift__ndce2;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  will-change: transform;
}

/* Translate by exactly one tile (in SVG user units) for a seamless wrap.
   --river-tile is supplied by the RiverFlow component (see TILE). */
@keyframes RiverFlow_drift__ndce2 {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-1 * var(--river-tile, 1440px)));
  }
}

@media (prefers-reduced-motion: reduce) {
  .RiverFlow_wave__CmnPy {
    animation: none;
  }
}

/*!***************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[7].use[3]!./app/page.module.css ***!
  \***************************************************************************************************************************************************************************************************************************************************************/
.page_main__nw1Wk {
  position: relative;
  isolation: isolate; /* new stacking context so the motif sits cleanly behind */
  min-height: 100dvh;
  display: grid;
  place-items: center;
  padding: var(--space-2xl) var(--space-lg);
  overflow: hidden;
}

.page_stage__4EEoY {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-md);
  max-width: var(--measure);
}

/* "Coming soon" pill */
.page_badge__0mJr3 {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-2xs) var(--space-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  font-size: var(--step--1);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.page_dot__aVcaO {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--color-accent);
  animation: page_pulse__XPtbN 3.4s var(--ease-flow) infinite;
}

@keyframes page_pulse__XPtbN {
  0%,
  100% {
    opacity: 1;
    box-shadow: 0 0 0 0 var(--color-accent-dim);
  }
  50% {
    opacity: 0.55;
    box-shadow: 0 0 0 6px transparent;
  }
}

.page_tagline__FsEDs {
  margin-top: var(--space-2xs);
  font-family: var(--font-display);
  font-size: var(--step-2);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--color-text);
}

.page_status__e5ASC {
  font-size: var(--step-0);
  color: var(--color-text-muted);
  max-width: 36ch;
}

/* Intentional resting state when motion is reduced. */
@media (prefers-reduced-motion: reduce) {
  .page_dot__aVcaO {
    animation: none;
  }
}

