/* ==========================================================================
   CSS Section: Design Tokens
   Global color, spacing, radius, shadow, timing, and typography variables.
   Most component rules below read from these values to keep the premium visual
   system consistent across every page.
   ========================================================================== */
:root {
  color-scheme: dark;
  --browser-chrome: #090d16;
  --bg: #050914;
  --bg-deep: #08101e;
  --panel: rgba(10, 17, 31, 0.72);
  --panel-strong: rgba(11, 20, 36, 0.9);
  --panel-soft: rgba(255, 255, 255, 0.04);
  --border: rgba(134, 176, 235, 0.18);
  --border-strong: rgba(133, 228, 255, 0.28);
  --text: #eef4ff;
  --text-soft: rgba(238, 244, 255, 0.76);
  --text-muted: rgba(238, 244, 255, 0.52);
  --accent: #79e3ff;
  --accent-strong: #53d2ff;
  --accent-warm: #ffb184;
  --accent-violet: #8c91ff;
  --success: #94ffd2;
  --shadow-xl: 0 36px 90px rgba(0, 0, 0, 0.42);
  --shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 16px 34px rgba(0, 0, 0, 0.22);
  --radius-xl: 32px;
  --radius-lg: 26px;
  --radius-md: 20px;
  --radius-sm: 14px;
  --container: 1240px;
  --ease-out: cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-smooth: cubic-bezier(0.19, 1, 0.22, 1);
  --duration-fast: 180ms;
  --duration-base: 320ms;
  --duration-slow: 760ms;
  --font-display: "Syne", "Trebuchet MS", sans-serif;
  --font-body: "Manrope", "Segoe UI", sans-serif;
  --font-mono: "IBM Plex Mono", "Consolas", monospace;
  --page-aura-a: rgba(121, 227, 255, 0.18);
  --page-aura-b: rgba(255, 177, 132, 0.16);
}

/* ==========================================================================
   CSS Section: Page Balance And Ambient Overlays
   Shared page-level polish: decorative ambient SVG layers, equalized card
   grids, text balancing, and lighter below-the-fold rendering.
   ========================================================================== */
body[data-page] main.layout-page > .page-ambient {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: clip;
}

body[data-page] main.layout-page > .page-ambient img {
  position: absolute;
  display: block;
  width: min(46vw, 40rem);
  max-width: 78vw;
  height: auto;
  opacity: 0.16;
  mix-blend-mode: screen;
  filter: saturate(1.06) blur(0.2px);
}

body[data-page] main.layout-page .section--with-overlay .shell {
  position: relative;
  isolation: isolate;
}

body[data-page] main.layout-page .section-overlay {
  position: absolute;
  inset: clamp(0.5rem, 1.4vw, 1rem);
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

body[data-page] main.layout-page .section-overlay--left,
body[data-page] main.layout-page .section-overlay--right {
  display: flex;
  align-items: center;
}

body[data-page] main.layout-page .section-overlay--left {
  justify-content: flex-start;
}

body[data-page] main.layout-page .section-overlay--right {
  justify-content: flex-end;
}

body[data-page] main.layout-page .section-overlay--center {
  display: grid;
  place-items: center;
}

body[data-page] main.layout-page .section-overlay img {
  display: block;
  width: min(40vw, 34rem);
  max-width: 46%;
  height: auto;
  opacity: 0.11;
  mix-blend-mode: screen;
  filter: saturate(1.04) blur(0.15px);
}

body[data-page] main.layout-page .section-overlay--left img {
  margin-left: clamp(-6rem, -3vw, -2rem);
}

body[data-page] main.layout-page .section-overlay--right img {
  margin-right: clamp(-6rem, -3vw, -2rem);
}

body[data-page] main.layout-page .section--with-overlay .shell > :not(.section-overlay) {
  position: relative;
  z-index: 1;
}

body[data-page] main.layout-page > [data-layout-sequence]:not(:first-child),
body[data-page] main.layout-page > .section:not(:first-child) {
  content-visibility: auto;
  contain-intrinsic-size: 1px 980px;
}

body[data-page] main.layout-page .section-title,
body[data-page] main.layout-page .layout-section__title,
body[data-page] main.layout-page .card__title,
body[data-page] main.layout-page .study-card__title,
body[data-page] main.layout-page .contact-card__title,
body[data-page] main.layout-page h1,
body[data-page] main.layout-page h2 {
  text-wrap: balance;
}

body[data-page] main.layout-page .section-text,
body[data-page] main.layout-page .layout-section__body,
body[data-page] main.layout-page .card__text,
body[data-page] main.layout-page .study-card__text,
body[data-page] main.layout-page .contact-card p,
body[data-page] main.layout-page .route-card p,
body[data-page] main.layout-page .service-detail p {
  max-width: 64ch;
}

body[data-page] main.layout-page .card-grid,
body[data-page] main.layout-page .route-grid,
body[data-page] main.layout-page .service-detail-grid,
body[data-page] main.layout-page .study-grid,
body[data-page] main.layout-page .layout-panel-grid,
body[data-page] main.layout-page .layout-panel-grid--offset,
body[data-page] main.layout-page .layout-step-grid,
body[data-page] main.layout-page .layout-category-grid,
body[data-page] main.layout-page .crosslink-grid,
body[data-page] main.layout-page .policy-atlas__cards {
  align-items: stretch;
  grid-auto-rows: minmax(0, 1fr);
}

body[data-page] main.layout-page .card-grid > *,
body[data-page] main.layout-page .route-grid > *,
body[data-page] main.layout-page .service-detail-grid > *,
body[data-page] main.layout-page .study-grid > *,
body[data-page] main.layout-page .layout-panel-grid > *,
body[data-page] main.layout-page .layout-panel-grid--offset > *,
body[data-page] main.layout-page .layout-step-grid > *,
body[data-page] main.layout-page .layout-category-grid > *,
body[data-page] main.layout-page .crosslink-grid > *,
body[data-page] main.layout-page .policy-atlas__cards > * {
  min-height: 100%;
}

body[data-page] main.layout-page .story-grid,
body[data-page] main.layout-page .contact-grid,
body[data-page] main.layout-page .payment-flow,
body[data-page] main.layout-page .layout-section__frame {
  align-items: stretch;
}

body[data-page] main.layout-page .media-frame,
body[data-page] main.layout-page .image-frame,
body[data-page] main.layout-page .video-frame {
  min-height: clamp(16rem, 32vw, 26rem);
}

@media (max-width: 900px) {
  body[data-page] main.layout-page > .page-ambient img {
    width: min(76vw, 28rem);
    opacity: 0.1;
  }

  body[data-page] main.layout-page .section-overlay img {
    width: min(72vw, 24rem);
    max-width: 72%;
    opacity: 0.07;
  }

  body[data-page] main.layout-page {
    --site-section-space: clamp(2.35rem, 9vw, 4.4rem);
    --site-frame-gap: clamp(0.95rem, 2.8vw, 1.15rem);
    --site-panel-pad: clamp(1.05rem, 3.1vw, 1.4rem);
    --site-surface-pad: clamp(1.05rem, 3vw, 1.4rem);
    --site-text-surface-pad: clamp(1.1rem, 3.2vw, 1.55rem);
  }
}

/* ==========================================================================
   CSS Section: Page Aura Themes
   Per-page glow color overrides used by the fixed background stage and body
   gradients. These are intentionally subtle so pages feel related, not cloned.
   ========================================================================== */
body[data-page="services"],
body[data-page="launch"] {
  --page-aura-a: rgba(255, 177, 132, 0.18);
  --page-aura-b: rgba(121, 227, 255, 0.12);
}

body[data-page="about"],
body[data-page="examples"] {
  --page-aura-a: rgba(121, 227, 255, 0.14);
  --page-aura-b: rgba(140, 145, 255, 0.14);
}

body[data-page="contact"],
body[data-page="process"],
body[data-page="faq"] {
  --page-aura-a: rgba(121, 227, 255, 0.14);
  --page-aura-b: rgba(255, 177, 132, 0.14);
}

body[data-page="payments"] {
  --page-aura-a: rgba(255, 177, 132, 0.18);
  --page-aura-b: rgba(121, 227, 255, 0.14);
}

body[data-page="schedule"],
body[data-page="privacy"],
body[data-page="terms"],
body[data-page="cookies"],
body[data-page="accessibility"] {
  --page-aura-a: rgba(121, 227, 255, 0.14);
  --page-aura-b: rgba(140, 145, 255, 0.16);
}

/* ==========================================================================
   CSS Section: Reset And Base Elements
   Browser reset, document background, default typography, links, media, focus,
   and text-selection behavior.
   ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

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

body {
  margin: 0;
  min-width: 320px;
  background-color: var(--browser-chrome);
  background:
    radial-gradient(circle at top left, var(--page-aura-a), transparent 32%),
    radial-gradient(circle at bottom right, var(--page-aura-b), transparent 36%),
    linear-gradient(180deg, #050914 0%, #08101d 36%, #060911 100%);
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img {
  display: block;
  max-width: 100%;
}

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

button,
input,
textarea,
select {
  font: inherit;
}

strong {
  font-weight: 700;
}

:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
}

::selection {
  background: rgba(121, 227, 255, 0.24);
  color: var(--text);
}

/* ==========================================================================
   CSS Section: Global Background Stage
   Fixed decorative atmosphere behind every page: grid, noise, glow, stars, and
   comets. Markup stays decorative and hidden from assistive tech.
   ========================================================================== */
.site-stage {
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  overflow: hidden;
}

.site-stage__grid,
.site-stage__noise,
.site-stage__glow {
  position: absolute;
  inset: 0;
}

.site-stage__grid {
  background-image:
    linear-gradient(rgba(126, 162, 214, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(126, 162, 214, 0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(circle at center, rgba(0, 0, 0, 0.9), transparent 78%);
  opacity: 0.5;
}

.site-stage__noise {
  opacity: 0.22;
  background:
    linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.04) 18%, transparent 32%),
    linear-gradient(transparent 0%, rgba(255, 255, 255, 0.03) 50%, transparent 100%);
  mix-blend-mode: screen;
}

.site-stage__glow::before,
.site-stage__glow::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(72px);
  opacity: 0.92;
  animation: drift 18s ease-in-out infinite alternate;
}

.site-stage__glow::before {
  width: min(52vw, 580px);
  height: min(52vw, 580px);
  top: -8rem;
  left: -10rem;
  background: var(--page-aura-a);
}

.site-stage__glow::after {
  width: min(52vw, 620px);
  height: min(52vw, 620px);
  right: -12rem;
  bottom: -14rem;
  background: var(--page-aura-b);
  animation-duration: 24s;
}

/* ==========================================================================
   CSS Section: Layout Utilities And Common Primitives
   Reusable wrappers, section rhythm, headings, surfaces, and visual marks used
   by multiple page templates.
   ========================================================================== */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.shell {
  width: min(var(--container), calc(100% - 1.5rem));
  margin: 0 auto;
}

.section {
  position: relative;
  padding: 2rem 0;
}

.section--tight {
  padding: 1.2rem 0;
}

.section--flush {
  padding-top: 0.5rem;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0.9rem;
  border: 1px solid rgba(129, 209, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-soft);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.eyebrow::before {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-warm));
  box-shadow: 0 0 18px rgba(121, 227, 255, 0.34);
}

.section-heading {
  max-width: 42rem;
}

.section-heading + * {
  margin-top: 1.25rem;
}

.section-title,
.hero__title,
.callout__title,
.policy-hero__title {
  margin: 1rem 0 0;
  font-family: var(--font-display);
  line-height: 0.94;
  letter-spacing: -0.05em;
  font-weight: 700;
}

.section-title {
  font-size: clamp(2rem, 7vw, 4rem);
  max-width: 12ch;
}

.callout__title {
  font-size: clamp(2rem, 5vw, 3.2rem);
  max-width: 12ch;
}

.section-text,
.hero__lede,
.policy-hero__text {
  margin: 1rem 0 0;
  color: var(--text-soft);
  font-size: clamp(1rem, 2.5vw, 1.2rem);
  max-width: 40rem;
}

.surface {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    rgba(7, 12, 21, 0.78);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
}

.surface::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(140deg, rgba(121, 227, 255, 0.12), transparent 24%),
    radial-gradient(circle at top right, rgba(255, 177, 132, 0.12), transparent 30%);
  opacity: 0.9;
  pointer-events: none;
}

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

/* ==========================================================================
   CSS Section: Buttons And Calls To Action
   Shared CTA base styles plus primary, secondary, subtle, and block variants.
   ========================================================================== */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.7rem;
  min-height: 52px;
  padding: 0.85rem 1.25rem;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  cursor: pointer;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.button svg {
  width: 1rem;
  height: 1rem;
  flex: 0 0 auto;
}

.button:hover,
.button:focus-visible {
  transform: translateY(-2px);
}

.button--primary {
  color: #07101b;
  background: linear-gradient(135deg, var(--accent), #dff7ff 54%, var(--accent-warm));
  box-shadow: 0 16px 34px rgba(121, 227, 255, 0.24);
}

.button--secondary {
  color: var(--text);
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(130, 229, 255, 0.18);
}

.button--secondary:hover,
.button--secondary:focus-visible {
  border-color: var(--border-strong);
  background: rgba(255, 255, 255, 0.09);
}

.button--subtle {
  color: var(--text-soft);
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(130, 229, 255, 0.12);
}

.button--subtle:hover,
.button--subtle:focus-visible {
  color: var(--text);
  border-color: rgba(130, 229, 255, 0.22);
  background: rgba(255, 255, 255, 0.07);
}

.button--block {
  width: 100%;
}

/* ==========================================================================
   CSS Section: Site Header And Navigation
   Sticky header, brand lockup, mobile toggle, primary nav, active states, and
   navigation-open body locking.
   ========================================================================== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  padding: 0.85rem 0.75rem 0;
  transition: padding var(--duration-fast) var(--ease-out);
}

.site-header.is-scrolled {
  padding-top: 0.55rem;
}

.site-header__inner {
  width: min(var(--container), calc(100% - 0.5rem));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(132, 194, 255, 0.16);
  border-radius: 30px;
  background: rgba(5, 10, 18, 0.8);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(20px);
}

.brand-lockup {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  min-width: 0;
}

.brand-lockup__mark {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  border: 1px solid rgba(130, 229, 255, 0.18);
  background: linear-gradient(135deg, rgba(121, 227, 255, 0.14), rgba(255, 177, 132, 0.14));
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.26);
  object-fit: cover;
  padding: 0.2rem;
}

.brand-lockup__meta {
  display: grid;
  gap: 0.12rem;
  min-width: 0;
}

.brand-lockup__title,
.footer-brand__title {
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.brand-lockup__tag,
.footer-brand__tag {
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.67rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.site-header__toggle {
  display: inline-flex;
  width: 52px;
  height: 52px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(130, 229, 255, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
}

.site-header__toggle svg {
  width: 1.25rem;
  height: 1.25rem;
}

.site-nav {
  position: fixed;
  inset: calc(82px + env(safe-area-inset-top, 0px)) 0 auto;
  margin: 0 0.75rem;
  padding: 1rem;
  border: 1px solid rgba(130, 229, 255, 0.14);
  border-radius: 28px;
  background: rgba(5, 10, 18, 0.94);
  box-shadow: var(--shadow-xl);
  backdrop-filter: blur(20px);
  display: grid;
  gap: 0.9rem;
  transform: translateY(-1rem);
  opacity: 0;
  pointer-events: none;
  transition:
    transform var(--duration-base) var(--ease-smooth),
    opacity var(--duration-base) var(--ease-smooth);
}

.site-nav.is-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.site-nav__links {
  display: grid;
  gap: 0.4rem;
}

.site-nav__links a {
  padding: 0.8rem 0.95rem;
  border-radius: 18px;
  color: var(--text-soft);
  font-weight: 700;
  transition:
    background var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out);
}

.site-nav__links a:hover,
.site-nav__links a:focus-visible,
.site-nav__links a.is-active {
  color: var(--text);
  background: rgba(255, 255, 255, 0.07);
}

.site-nav__cta {
  display: grid;
  gap: 0.6rem;
}

/* ==========================================================================
   CSS Section: Section Marks And Standard Hero Layouts
   Shared section marks, hero grids, metrics, info strips, and generic page
   layout blocks used before the newer page-specific systems below.
   ========================================================================== */
.section-heading--with-mark,
.callout--with-mark,
.quote-banner--with-mark {
  position: relative;
}

.section-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 62px;
  height: 62px;
  margin-bottom: 0.9rem;
  border-radius: 22px;
  border: 1px solid rgba(130, 229, 255, 0.16);
  background: linear-gradient(135deg, rgba(121, 227, 255, 0.12), rgba(255, 177, 132, 0.12));
  box-shadow: var(--shadow-md);
}

.section-mark img {
  width: 46px;
  height: 46px;
  object-fit: cover;
  border-radius: 16px;
}

body.has-nav-open {
  overflow: hidden;
}

.hero {
  padding-top: 1.4rem;
}

.hero__grid,
.spotlight,
.contact-grid,
.policy-grid,
.comparison,
.dual-grid {
  display: grid;
  gap: 1rem;
}

.hero__copy,
.hero__visual,
.callout,
.policy-card,
.card,
.study-card,
.service-card,
.phase-card,
.faq-shell,
.contact-card,
.form-card,
.quote-banner,
.status-card {
  padding: 1.2rem;
}

.hero__copy {
  position: relative;
}

.hero__copy,
.callout,
.contact-card,
.policy-card,
.faq-shell,
.spotlight__visual {
  display: grid;
  align-content: start;
  gap: 1rem;
}

.hero__title {
  font-size: clamp(3rem, 14vw, 7rem);
  max-width: 10ch;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.6rem;
}

.hero__metric-row,
.stats-grid,
.card-grid,
.study-grid,
.service-grid,
.phase-grid,
.detail-grid,
.contact-ways,
.mini-grid {
  display: grid;
  gap: 0.9rem;
}

.metric-chip,
.status-chip,
.tag,
.signal-card,
.tool-chip {
  border: 1px solid rgba(130, 229, 255, 0.16);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.04);
}

.metric-chip {
  padding: 1rem;
}

.metric-chip__label {
  display: block;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.metric-chip__value {
  display: block;
  margin-top: 0.5rem;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.45;
}

.info-strip {
  overflow: hidden;
  border: 1px solid rgba(130, 229, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
}

.info-strip__track {
  display: flex;
  width: max-content;
  animation: marquee 26s linear infinite;
}

.info-strip__item {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.95rem 1.15rem;
  color: var(--text-soft);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  white-space: nowrap;
}

.info-strip__item::before {
  content: "";
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-warm));
}

/* ==========================================================================
   CSS Section: Decorative Scene System
   Orbital UI frames, floating chips, media windows, and animated rings used by
   the older visual compositions.
   ========================================================================== */
.scene {
  position: relative;
  min-height: 420px;
  padding: 1rem;
  border: 1px solid rgba(130, 229, 255, 0.14);
  border-radius: calc(var(--radius-xl) - 8px);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    rgba(6, 10, 18, 0.9);
  overflow: hidden;
  isolation: isolate;
}

.scene::before,
.scene::after {
  content: "";
  position: absolute;
  inset: auto;
  border-radius: 999px;
  filter: blur(42px);
  opacity: 0.85;
}

.scene::before {
  top: 0;
  left: -8%;
  width: 42%;
  height: 32%;
  background: rgba(121, 227, 255, 0.18);
}

.scene::after {
  right: -10%;
  bottom: -8%;
  width: 46%;
  height: 34%;
  background: rgba(255, 177, 132, 0.15);
}

.scene__orbit,
.scene__ring {
  position: absolute;
  border: 1px solid rgba(130, 229, 255, 0.18);
  border-radius: 50%;
}

.scene__orbit {
  width: 20rem;
  height: 20rem;
  top: 10%;
  right: 8%;
  animation: spin 20s linear infinite;
}

.scene__orbit::after {
  content: "";
  position: absolute;
  top: 46%;
  left: -6px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 20px rgba(121, 227, 255, 0.5);
}

.scene__ring {
  width: 12rem;
  height: 12rem;
  bottom: 10%;
  left: 8%;
  border-color: rgba(255, 177, 132, 0.24);
  animation: pulseRing 4.8s ease-in-out infinite;
}

.scene__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(126, 162, 214, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(126, 162, 214, 0.05) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.85), transparent);
  opacity: 0.4;
}

.scene__window,
.scene__chip,
.scene__note {
  position: absolute;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(130, 229, 255, 0.16);
  background: rgba(8, 14, 24, 0.8);
  box-shadow: var(--shadow-md);
}

.scene__window img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.scene__window--wide {
  inset: 1.1rem 1rem auto 1rem;
  height: 58%;
}

.scene__window--tall {
  left: 1rem;
  bottom: 1rem;
  width: 34%;
  height: 34%;
}

.scene__window--card {
  right: 1rem;
  bottom: 1rem;
  width: 42%;
  height: 28%;
}

.scene__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.75rem 0.9rem;
  border-radius: 20px;
  color: var(--text-soft);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.scene__chip::before {
  content: "";
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-warm));
}

.scene__chip--top {
  top: 1rem;
  left: 1rem;
}

.scene__chip--bottom {
  bottom: 1rem;
  left: calc(36% + 1.5rem);
}

.scene__note {
  top: 1rem;
  right: 1rem;
  max-width: 14rem;
  padding: 0.9rem 1rem;
}

.scene__note strong {
  display: block;
  font-size: 0.95rem;
}

.scene__note span {
  display: block;
  margin-top: 0.35rem;
  color: var(--text-soft);
  font-size: 0.88rem;
}

.scene__footer {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.scene__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.65rem 0.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(130, 229, 255, 0.14);
  color: var(--text-soft);
  font-size: 0.86rem;
}

/* ==========================================================================
   CSS Section: Cards, Lists, Forms, FAQ, And Policy Blocks
   Common cards, study tiles, contact cards, form fields, FAQ accordions, and
   legal/policy content surfaces.
   ========================================================================== */
.card-grid {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

.card,
.service-card,
.phase-card,
.study-card,
.contact-card,
.faq-shell,
.policy-card,
.quote-banner,
.form-card,
.status-card {
  position: relative;
}

.card__title,
.service-card__title,
.phase-card__title,
.study-card__title,
.contact-card__title,
.policy-card__title,
.faq-shell__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 5vw, 1.9rem);
  line-height: 1;
  letter-spacing: -0.04em;
}

.card__text,
.service-card__text,
.phase-card__text,
.study-card__text,
.contact-card__text,
.policy-card__text {
  margin: 0.85rem 0 0;
  color: var(--text-soft);
}

.card__meta,
.study-card__meta,
.contact-card__meta,
.phase-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 1rem;
}

.tag {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  color: var(--text-soft);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.card__icon,
.phase-card__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 18px;
  border: 1px solid rgba(130, 229, 255, 0.18);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.phase-card__number {
  margin-bottom: 1rem;
}

.study-card img,
.visual-frame img {
  width: 100%;
  border-radius: calc(var(--radius-lg) - 8px);
  aspect-ratio: 1.35 / 1;
  object-fit: cover;
  border: 1px solid rgba(130, 229, 255, 0.14);
  box-shadow: var(--shadow-md);
}

.study-card__content {
  margin-top: 1rem;
}

.study-card__link,
.inline-link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-top: 1rem;
  color: var(--accent);
  font-weight: 700;
}

.inline-link svg,
.study-card__link svg {
  width: 1rem;
  height: 1rem;
}

.comparison__column,
.spotlight__copy,
.spotlight__visual,
.policy-card,
.faq-shell {
  min-width: 0;
}

.spotlight__copy {
  display: grid;
  align-content: start;
  gap: 1rem;
}

.list,
.check-list,
.icon-list,
.detail-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.check-list,
.icon-list,
.detail-list {
  display: grid;
  gap: 0.75rem;
}

.check-list li,
.icon-list li,
.detail-list li {
  display: flex;
  gap: 0.8rem;
  align-items: flex-start;
  color: var(--text-soft);
}

.check-list li::before,
.icon-list li::before,
.detail-list li::before {
  content: "";
  flex: 0 0 auto;
  width: 0.65rem;
  height: 0.65rem;
  margin-top: 0.45rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-warm));
  box-shadow: 0 0 18px rgba(121, 227, 255, 0.3);
}

.detail-list strong {
  color: var(--text);
}

.quote-banner {
  display: grid;
  gap: 1rem;
  text-align: left;
}

.quote-banner blockquote {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 4rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.quote-banner p {
  margin: 0;
  color: var(--text-soft);
  max-width: 36rem;
}

.status-card {
  display: grid;
  gap: 1rem;
}

.status-card__row {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  color: var(--text-soft);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.status-card__bar {
  position: relative;
  height: 0.75rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.status-card__bar span {
  position: absolute;
  inset: 0;
  width: var(--value, 60%);
  border-radius: inherit;
  background: linear-gradient(135deg, var(--accent), var(--accent-warm));
}

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

.contact-way {
  padding: 1rem;
  border: 1px solid rgba(130, 229, 255, 0.14);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.03);
}

.contact-way strong {
  display: block;
  font-size: 1rem;
}

.contact-way span {
  display: block;
  margin-top: 0.35rem;
  color: var(--text-soft);
  font-size: 0.92rem;
}

.form-card {
  display: grid;
  gap: 1.15rem;
}

.form-card__head {
  display: grid;
  gap: 0.6rem;
}

.form-card__head p {
  margin: 0;
  color: var(--text-soft);
}

.form-grid {
  display: grid;
  gap: 0.9rem;
}

.field {
  display: grid;
  gap: 0.45rem;
}

.field label {
  color: var(--text-soft);
  font-size: 0.94rem;
  font-weight: 700;
}

.field input,
.field textarea,
.field select {
  width: 100%;
  min-height: 54px;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(130, 229, 255, 0.16);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  transition:
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out);
}

.field textarea {
  min-height: 148px;
  resize: vertical;
}

.field input:focus,
.field textarea:focus,
.field select:focus {
  border-color: rgba(121, 227, 255, 0.42);
  background: rgba(255, 255, 255, 0.07);
  outline: none;
}

.form-note,
.success-note {
  margin: 0;
  color: var(--text-soft);
}

.success-note {
  padding: 0.95rem 1rem;
  border: 1px solid rgba(148, 255, 210, 0.22);
  border-radius: 18px;
  background: rgba(148, 255, 210, 0.06);
}

.faq-list {
  display: grid;
  gap: 0.85rem;
}

.faq-list details {
  border: 1px solid rgba(130, 229, 255, 0.14);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.03);
  overflow: hidden;
}

.faq-list summary {
  list-style: none;
  cursor: pointer;
  padding: 1rem 1.05rem;
  font-weight: 800;
  line-height: 1.35;
}

.faq-list summary::-webkit-details-marker {
  display: none;
}

.faq-list summary::after {
  content: "+";
  float: right;
  color: var(--accent);
}

.faq-list details[open] summary::after {
  content: "−";
}

.faq-list details p {
  margin: 0;
  padding: 0 1.05rem 1rem;
  color: var(--text-soft);
}

.policy-main {
  padding-top: 1.4rem;
}

.policy-hero {
  padding: 1.3rem;
}

.policy-hero__title {
  font-size: clamp(2.5rem, 10vw, 4.6rem);
  max-width: 11ch;
}

.policy-card__body {
  display: grid;
  gap: 1rem;
}

.policy-card__body > * {
  margin: 0;
}

.policy-card__body h2 {
  font-family: var(--font-display);
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: -0.04em;
  margin-top: 1rem;
}

.policy-card__body p,
.policy-card__body li {
  color: var(--text-soft);
}

.policy-card__body ul {
  margin: 0;
  padding-left: 1.2rem;
}

.empty-state {
  min-height: calc(100vh - 190px);
  display: grid;
  align-items: center;
}

/* ==========================================================================
   CSS Section: Footer And Floating Actions
   Shared footer, sitemap, WhatsApp/action rail, Orbot launcher, and back-to-top
   button treatment.
   ========================================================================== */
.site-footer {
  padding: 2rem 0 3rem;
}

.site-footer__inner {
  width: min(var(--container), calc(100% - 1.5rem));
  margin: 0 auto;
  display: grid;
  gap: 1rem;
}

.site-footer__main {
  padding: 1.35rem;
}

.footer-brand {
  display: grid;
  gap: 1rem;
}

.footer-brand__lockup {
  display: inline-flex;
  align-items: center;
  gap: 0.9rem;
}

.footer-brand__lockup img {
  width: 64px;
  height: 64px;
  object-fit: cover;
  padding: 0.28rem;
  border-radius: 20px;
  border: 1px solid rgba(130, 229, 255, 0.16);
  background: linear-gradient(135deg, rgba(121, 227, 255, 0.14), rgba(255, 177, 132, 0.14));
}

.footer-brand__text {
  margin: 0;
  color: var(--text-soft);
  max-width: 30rem;
}

.site-footer__columns {
  display: grid;
  gap: 1rem;
}

.footer-column {
  padding: 1.15rem;
  border: 1px solid rgba(130, 229, 255, 0.12);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.03);
}

.footer-column strong {
  display: block;
  margin-bottom: 0.8rem;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.footer-column a {
  display: block;
  margin-top: 0.55rem;
  color: var(--text-soft);
}

.footer-column a:hover,
.footer-column a:focus-visible {
  color: var(--text);
}

.site-footer__bottom {
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
}

.floating-rail {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 28;
  display: grid;
  gap: 0.65rem;
}

.floating-action {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 48px;
  padding: 0.75rem 0.95rem;
  border: 1px solid rgba(130, 229, 255, 0.16);
  border-radius: 999px;
  background: rgba(5, 10, 18, 0.82);
  box-shadow: var(--shadow-md);
  color: var(--text);
  backdrop-filter: blur(18px);
}

.floating-action svg {
  width: 1rem;
  height: 1rem;
}

.floating-action__label {
  font-size: 0.88rem;
  font-weight: 700;
}

/* ==========================================================================
   CSS Section: Motion, Reveals, Breakpoints, And Keyframes
   Scroll reveal behavior, tilt prep, responsive layout changes, reduced motion
   safety, and global animations.
   ========================================================================== */
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity var(--duration-slow) var(--ease-smooth),
    transform var(--duration-slow) var(--ease-smooth);
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

[data-tilt] {
  transform-style: preserve-3d;
  transition: transform var(--duration-base) var(--ease-out);
}

@media (min-width: 700px) {
  .hero__copy,
  .hero__visual,
  .callout,
  .policy-card,
  .card,
  .study-card,
  .service-card,
  .phase-card,
  .faq-shell,
  .contact-card,
  .form-card,
  .quote-banner,
  .status-card,
  .policy-hero {
    padding: 1.5rem;
  }

  .hero__metric-row,
  .stats-grid,
  .detail-grid,
  .contact-ways,
  .mini-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .card-grid,
  .service-grid,
  .phase-grid,
  .study-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .field--full {
    grid-column: 1 / -1;
  }

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

@media (min-width: 960px) {
  .section {
    padding: 2.8rem 0;
  }

  .site-header__toggle {
    display: none;
  }

  .site-nav {
    position: static;
    inset: auto;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    display: flex;
    align-items: center;
    gap: 0.65rem;
    transform: none;
    opacity: 1;
    pointer-events: auto;
  }

  .site-nav__links {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.15rem;
    padding: 0.24rem;
    border: 1px solid rgba(130, 229, 255, 0.1);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.03);
  }

  .site-nav__links a {
    padding: 0.62rem 0.74rem;
    white-space: nowrap;
    font-size: 0.94rem;
  }

  .site-nav__cta {
    display: flex;
    align-items: center;
    gap: 0.6rem;
  }

  .hero__grid,
  .spotlight,
  .contact-grid,
  .policy-grid,
  .comparison,
  .dual-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
  }

  .hero__grid {
    grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr);
  }

  .spotlight--wide {
    grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
  }

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

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

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

  .phase-grid,
  .detail-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .contact-ways {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .scene {
    min-height: 560px;
    padding: 1.2rem;
  }

  .scene__window--wide {
    inset: 1.2rem 1.2rem auto 1.2rem;
  }
}

@media (min-width: 1180px) {
  .section {
    padding: 3.2rem 0;
  }

  .shell {
    width: min(var(--container), calc(100% - 2rem));
  }

  .hero {
    padding-top: 2rem;
  }

  .hero__copy,
  .hero__visual,
  .callout,
  .policy-card,
  .card,
  .study-card,
  .service-card,
  .phase-card,
  .faq-shell,
  .contact-card,
  .form-card,
  .quote-banner,
  .status-card,
  .policy-hero {
    padding: 1.8rem;
  }

  .site-footer__main {
    padding: 1.8rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 1ms !important;
    scroll-behavior: auto !important;
  }

  [data-reveal] {
    opacity: 1;
    transform: none;
  }
}

@keyframes drift {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  100% {
    transform: translate3d(2rem, -1rem, 0) scale(1.08);
  }
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

@keyframes pulseRing {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.85;
  }
  50% {
    transform: scale(1.06);
    opacity: 1;
  }
}

@keyframes marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

/* ==========================================================================
   CSS Section: Visual Polish Overrides
   Later theme pass that sharpens the orange/blue premium palette, updates the
   stage atmosphere, and refines shared surfaces without changing markup.
   ========================================================================== */
:root {
  --accent: #5fd7ff;
  --accent-strong: #8de8ff;
  --accent-warm: #ff7b4d;
  --accent-hot: #ff4b46;
  --accent-gold: #ffd45c;
  --border: rgba(144, 180, 255, 0.16);
  --border-strong: rgba(255, 126, 83, 0.28);
  --panel: rgba(8, 13, 24, 0.74);
  --page-aura-a: rgba(255, 102, 72, 0.14);
  --page-aura-b: rgba(95, 215, 255, 0.16);
}

body[data-page="home"],
body[data-page="examples"] {
  --page-aura-a: rgba(255, 122, 84, 0.16);
  --page-aura-b: rgba(98, 215, 255, 0.18);
}

body {
  background:
    radial-gradient(circle at 12% 10%, rgba(255, 112, 80, 0.18), transparent 28%),
    radial-gradient(circle at 84% 16%, rgba(91, 212, 255, 0.12), transparent 24%),
    radial-gradient(circle at 50% 120%, rgba(27, 43, 78, 0.5), transparent 45%),
    linear-gradient(180deg, #040711 0%, #08101d 38%, #04070f 100%);
}

.site-stage {
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 122, 84, 0.14), transparent 20%),
    radial-gradient(circle at 82% 22%, rgba(93, 216, 255, 0.1), transparent 24%);
}

.site-stage__stars,
.site-stage__comets {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.site-stage__star {
  position: absolute;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: rgba(255, 245, 236, 0.95);
  box-shadow: 0 0 16px rgba(255, 231, 214, 0.6);
  animation: twinkle linear infinite;
}

.site-stage__star:nth-child(3n) {
  background: rgba(112, 225, 255, 0.85);
  box-shadow: 0 0 18px rgba(95, 215, 255, 0.42);
}

.site-stage__star:nth-child(5n) {
  background: rgba(255, 191, 153, 0.92);
  box-shadow: 0 0 18px rgba(255, 123, 77, 0.4);
}

.site-stage__comet {
  position: absolute;
  top: 18%;
  left: -14%;
  width: 18rem;
  height: 2px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 221, 196, 0.94), rgba(95, 215, 255, 0));
  box-shadow: 0 0 28px rgba(95, 215, 255, 0.28);
  transform: rotate(-18deg);
  animation: comet 16s linear infinite;
  opacity: 0.72;
}

.site-stage__comet--alt {
  top: 54%;
  left: auto;
  right: -16%;
  width: 13rem;
  transform: rotate(18deg);
  animation-duration: 22s;
  animation-delay: 7s;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 152, 99, 0.95), rgba(95, 215, 255, 0));
}

.surface {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.042), rgba(255, 255, 255, 0.01)),
    linear-gradient(180deg, rgba(16, 23, 39, 0.96), rgba(7, 11, 21, 0.86));
}

.surface::before {
  background:
    linear-gradient(135deg, rgba(255, 121, 73, 0.12), transparent 22%),
    radial-gradient(circle at top right, rgba(95, 215, 255, 0.12), transparent 32%);
}

.button--primary {
  color: #fff7f1;
  background: linear-gradient(135deg, #ff5c56 0%, #ff7d5d 48%, #ffb35f 100%);
  border-color: rgba(255, 165, 112, 0.26);
  box-shadow:
    0 18px 40px rgba(255, 85, 68, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.button--primary:hover,
.button--primary:focus-visible {
  background: linear-gradient(135deg, #ff6859 0%, #ff8a63 48%, #ffbd69 100%);
}

.button--secondary {
  border-color: rgba(255, 123, 77, 0.18);
  background: rgba(255, 129, 86, 0.06);
}

.button--secondary:hover,
.button--secondary:focus-visible {
  border-color: rgba(255, 136, 96, 0.34);
  background: rgba(255, 129, 86, 0.12);
}

.button--subtle {
  border-color: rgba(95, 215, 255, 0.16);
}

.site-header__inner {
  border-color: rgba(255, 126, 83, 0.16);
  background:
    linear-gradient(180deg, rgba(10, 15, 28, 0.92), rgba(6, 10, 18, 0.82));
}

.brand-lockup__mark {
  border-color: rgba(255, 128, 92, 0.24);
  background: linear-gradient(135deg, rgba(255, 101, 75, 0.18), rgba(95, 215, 255, 0.12));
  box-shadow: 0 18px 38px rgba(255, 90, 68, 0.14);
}

.brand-lockup__title,
.footer-brand__title {
  letter-spacing: 0.12em;
}

.site-nav__links {
  border-color: rgba(255, 123, 77, 0.1);
}

.site-nav__links a.is-active,
.site-nav__links a:hover,
.site-nav__links a:focus-visible {
  background: linear-gradient(135deg, rgba(255, 120, 73, 0.16), rgba(95, 215, 255, 0.08));
}

.eyebrow {
  border-color: rgba(255, 123, 77, 0.14);
  background: rgba(255, 255, 255, 0.025);
}

.eyebrow::before {
  background: linear-gradient(135deg, var(--accent-gold), var(--accent-hot));
  box-shadow: 0 0 18px rgba(255, 122, 84, 0.42);
}

.scene {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.012)),
    radial-gradient(circle at 16% 16%, rgba(255, 112, 83, 0.1), transparent 20%),
    rgba(5, 9, 18, 0.94);
}

.scene__grid {
  opacity: 0.28;
}

.scene__orbit {
  border-color: rgba(255, 145, 96, 0.18);
}

.scene__orbit::after {
  background: var(--accent-warm);
  box-shadow: 0 0 20px rgba(255, 123, 77, 0.56);
}

.scene__ring {
  border-color: rgba(95, 215, 255, 0.24);
}

.scene__window::after,
.study-card img::after {
  pointer-events: none;
}

.scene__window::after,
.media-frame::after,
.image-frame::after,
.video-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 86, 58, 0.22), rgba(255, 86, 58, 0.02) 38%, rgba(95, 215, 255, 0.12)),
    linear-gradient(135deg, rgba(255, 189, 118, 0.08), transparent 45%);
  mix-blend-mode: screen;
  pointer-events: none;
}

.media-frame,
.image-frame,
.video-frame {
  position: relative;
  overflow: hidden;
  border-radius: calc(var(--radius-lg) - 4px);
  border: 1px solid rgba(255, 136, 96, 0.14);
  box-shadow: var(--shadow-md);
  background: #090f19;
}

.media-frame img,
.image-frame img,
.video-frame img,
.video-frame video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(0.96) contrast(1.04) brightness(0.92);
}

.video-frame video {
  aspect-ratio: 16 / 10;
}

.section-heading {
  max-width: 52rem;
}

.hero__title {
  max-width: 9ch;
  letter-spacing: -0.06em;
}

.hero__lede,
.section-text,
.card__text,
.study-card__text,
.service-card__text,
.phase-card__text,
.contact-card__text {
  font-size: clamp(1rem, 2.3vw, 1.14rem);
}

.metric-chip,
.tag,
.contact-way,
.footer-column,
.footer-sitemap__link,
.atlas-card,
.crosslink-card {
  border-color: rgba(255, 130, 90, 0.16);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.015)),
    rgba(10, 14, 24, 0.72);
}

.tag {
  border-color: rgba(95, 215, 255, 0.18);
  background: rgba(95, 215, 255, 0.08);
}

.info-strip {
  border-color: rgba(255, 127, 81, 0.16);
  background: linear-gradient(135deg, rgba(255, 102, 72, 0.06), rgba(95, 215, 255, 0.04));
}

.info-strip__item::before {
  background: linear-gradient(135deg, var(--accent-gold), var(--accent-hot));
}

.card__icon,
.phase-card__number {
  border-color: rgba(255, 123, 77, 0.24);
  background: linear-gradient(135deg, rgba(255, 123, 77, 0.08), rgba(95, 215, 255, 0.08));
}

.field input,
.field textarea,
.field select {
  border-color: rgba(255, 123, 77, 0.16);
  background: rgba(255, 255, 255, 0.03);
}

.field input:focus,
.field textarea:focus,
.field select:focus {
  border-color: rgba(255, 123, 77, 0.42);
  box-shadow: 0 0 0 4px rgba(255, 94, 69, 0.08);
}

.success-note {
  border-color: rgba(255, 138, 83, 0.24);
  background: rgba(255, 128, 84, 0.08);
}

.site-footer {
  padding: 2.2rem 0 3.2rem;
}

.footer-mega {
  display: grid;
  gap: 1.1rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.015)),
    radial-gradient(circle at 14% 16%, rgba(255, 110, 78, 0.12), transparent 22%),
    rgba(7, 11, 20, 0.92);
}

.footer-brand__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.footer-sitemap {
  display: grid;
  gap: 1rem;
  padding: 1.2rem;
  border: 1px solid rgba(255, 126, 83, 0.14);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.03);
}

.footer-sitemap__head {
  display: grid;
  gap: 0.35rem;
}

.footer-sitemap__head strong {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.footer-sitemap__head p {
  margin: 0;
  color: var(--text-soft);
}

.footer-sitemap__grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 0.75rem;
}

.footer-sitemap__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.95rem 1rem;
  border-radius: 20px;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out);
}

.footer-sitemap__link:hover,
.footer-sitemap__link:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(255, 126, 83, 0.28);
  background: linear-gradient(135deg, rgba(255, 102, 72, 0.08), rgba(95, 215, 255, 0.05));
}

.footer-sitemap__link svg {
  width: 1rem;
  height: 1rem;
  color: var(--accent-warm);
}

.footer-column {
  border-color: rgba(95, 215, 255, 0.12);
}

.site-footer__bottom {
  color: rgba(238, 244, 255, 0.52);
}

.floating-action {
  transition:
    transform var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out);
}

.floating-action:hover,
.floating-action:focus-visible {
  transform: translateY(-2px);
}

.floating-action--whatsapp {
  border-color: rgba(255, 123, 77, 0.28);
  background: linear-gradient(135deg, rgba(255, 85, 68, 0.94), rgba(255, 134, 82, 0.94));
  color: #fff7f1;
}

.floating-action--bot {
  gap: 0.7rem;
  border-color: rgba(95, 215, 255, 0.18);
  background: linear-gradient(135deg, rgba(12, 21, 39, 0.92), rgba(34, 16, 29, 0.92));
}

.floating-action__avatar {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  animation: botFloat 4.2s ease-in-out infinite;
}
.crosslink-grid,
.story-grid {
  display: grid;
  gap: 1rem;
}

.story-grid__copy,
.story-grid__media {
  min-width: 0;
}

.route-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.route-cloud a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0.55rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 126, 83, 0.18);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-soft);
}

.route-cloud a:hover,
.route-cloud a:focus-visible {
  color: var(--text);
  border-color: rgba(255, 126, 83, 0.28);
}

.media-caption {
  margin: 0.8rem 0 0;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

@media (min-width: 700px) {
  .footer-sitemap__grid,
  .crosslink-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 960px) {
  .footer-mega {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    align-items: start;
  }

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

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

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

  .story-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    gap: 1.1rem;
    align-items: stretch;
  }

}

@keyframes twinkle {
  0%,
  100% {
    opacity: 0.24;
    transform: scale(0.72);
  }
  50% {
    opacity: 1;
    transform: scale(1.18);
  }
}

@keyframes comet {
  0% {
    transform: translate3d(0, 0, 0) rotate(-18deg);
    opacity: 0;
  }
  10%,
  55% {
    opacity: 0.76;
  }
  100% {
    transform: translate3d(130vw, 24vh, 0) rotate(-18deg);
    opacity: 0;
  }
}

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

:root {
  --accent: #79deff;
  --accent-strong: #ccf6ff;
  --accent-warm: #4f9bff;
  --accent-hot: #1d67ff;
  --accent-gold: #66f1da;
  --border: rgba(112, 184, 255, 0.18);
  --border-strong: rgba(124, 225, 255, 0.32);
  --panel: rgba(6, 12, 24, 0.78);
  --page-aura-a: rgba(43, 107, 255, 0.2);
  --page-aura-b: rgba(76, 228, 255, 0.14);
}

body {
  background:
    radial-gradient(circle at 14% 10%, rgba(38, 101, 255, 0.16), transparent 26%),
    radial-gradient(circle at 82% 18%, rgba(74, 220, 255, 0.12), transparent 24%),
    radial-gradient(circle at 50% 120%, rgba(10, 24, 54, 0.52), transparent 42%),
    linear-gradient(180deg, #03060d 0%, #07101d 34%, #020409 100%);
}

.site-stage {
  background:
    radial-gradient(circle at 18% 14%, rgba(44, 108, 255, 0.14), transparent 20%),
    radial-gradient(circle at 82% 22%, rgba(80, 225, 255, 0.1), transparent 24%);
}

.site-stage__comet {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(145, 226, 255, 0.94), rgba(29, 103, 255, 0));
  box-shadow: 0 0 28px rgba(97, 208, 255, 0.28);
}

.site-stage__comet--alt {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(95, 215, 255, 0.94), rgba(29, 103, 255, 0));
}

.surface {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)),
    linear-gradient(180deg, rgba(11, 19, 35, 0.96), rgba(4, 8, 16, 0.92));
}

.surface::before {
  background:
    linear-gradient(135deg, rgba(33, 92, 255, 0.12), transparent 24%),
    radial-gradient(circle at top right, rgba(103, 238, 255, 0.12), transparent 32%);
}

.button--primary {
  color: #fff7f1;
  background: linear-gradient(135deg, #ff5c56 0%, #ff7d5d 48%, #ffb35f 100%);
  border-color: rgba(255, 165, 112, 0.26);
  box-shadow:
    0 18px 40px rgba(255, 85, 68, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.button--primary:hover,
.button--primary:focus-visible {
  background: linear-gradient(135deg, #ff6859 0%, #ff8a63 48%, #ffbd69 100%);
}

.button--secondary {
  border-color: rgba(255, 123, 77, 0.18);
  background: rgba(255, 129, 86, 0.06);
}

.button--secondary:hover,
.button--secondary:focus-visible {
  border-color: rgba(255, 136, 96, 0.34);
  background: rgba(255, 129, 86, 0.12);
}

.button--subtle {
  border-color: rgba(121, 226, 255, 0.18);
  background: rgba(18, 37, 77, 0.44);
}

.site-header__inner {
  padding: 0.82rem 0.9rem;
  border-color: rgba(108, 184, 255, 0.18);
  background: linear-gradient(180deg, rgba(9, 16, 31, 0.94), rgba(4, 8, 16, 0.88));
}

.brand-lockup__mark {
  border-color: rgba(113, 189, 255, 0.22);
  background: linear-gradient(135deg, rgba(29, 103, 255, 0.16), rgba(121, 222, 255, 0.12));
  box-shadow: 0 18px 38px rgba(20, 73, 192, 0.18);
}

.site-nav__links {
  border-color: rgba(100, 185, 255, 0.12);
}

.site-nav__links a.is-active,
.site-nav__links a:hover,
.site-nav__links a:focus-visible {
  background: linear-gradient(135deg, rgba(31, 102, 255, 0.18), rgba(121, 222, 255, 0.08));
}

.eyebrow {
  border-color: rgba(102, 190, 255, 0.14);
  background: rgba(255, 255, 255, 0.028);
}

.eyebrow::before {
  background: linear-gradient(135deg, #7ce2ff, #1d67ff);
  box-shadow: 0 0 18px rgba(120, 222, 255, 0.4);
}

.scene {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.034), rgba(255, 255, 255, 0.012)),
    radial-gradient(circle at 16% 16%, rgba(45, 108, 255, 0.1), transparent 20%),
    rgba(3, 7, 16, 0.95);
}

.scene__orbit {
  border-color: rgba(120, 197, 255, 0.24);
}

.scene__orbit::after {
  background: #7ce2ff;
  box-shadow: 0 0 20px rgba(124, 226, 255, 0.52);
}

.scene__ring {
  border-color: rgba(92, 165, 255, 0.26);
}

.metric-chip,
.tag,
.contact-way,
.atlas-card,
.crosslink-card {
  border-color: rgba(104, 182, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.036), rgba(255, 255, 255, 0.015)),
    rgba(7, 12, 22, 0.72);
}

.tag {
  border-color: rgba(121, 222, 255, 0.18);
  background: rgba(41, 88, 201, 0.16);
}

.card__icon,
.phase-card__number {
  border-color: rgba(114, 187, 255, 0.24);
  background: linear-gradient(135deg, rgba(29, 103, 255, 0.12), rgba(103, 238, 255, 0.1));
}

.scene__window,
.media-frame,
.image-frame,
.video-frame {
  border-color: rgba(100, 185, 255, 0.18);
  background: #06101d;
}

.scene__window::after,
.media-frame::after,
.image-frame::after,
.video-frame::after {
  background:
    linear-gradient(180deg, rgba(5, 12, 28, 0.1), rgba(45, 108, 255, 0.16) 42%, rgba(104, 239, 255, 0.18)),
    radial-gradient(circle at top left, rgba(160, 239, 255, 0.08), transparent 34%);
}

.media-frame img,
.image-frame img,
.video-frame img,
.video-frame video {
  filter: saturate(0.82) contrast(1.08) brightness(0.8) hue-rotate(-10deg);
  transform: scale(1.04);
}

.field input,
.field textarea,
.field select {
  border-color: rgba(108, 184, 255, 0.18);
  background: rgba(255, 255, 255, 0.032);
}

.field input:focus,
.field textarea:focus,
.field select:focus {
  border-color: rgba(121, 222, 255, 0.44);
  box-shadow: 0 0 0 4px rgba(36, 111, 255, 0.12);
}

.success-note {
  border-color: rgba(102, 241, 218, 0.24);
  background: rgba(102, 241, 218, 0.08);
}

.error-note {
  margin: 0;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(120, 185, 255, 0.24);
  border-radius: 18px;
  background: rgba(44, 108, 255, 0.08);
  color: var(--text-soft);
}

.site-footer {
  padding: 2.2rem 0 3rem;
}

.footer-mega {
  display: grid;
  gap: 1rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.01)),
    radial-gradient(circle at 14% 16%, rgba(34, 96, 255, 0.14), transparent 24%),
    rgba(4, 8, 16, 0.94);
}

.footer-brand__lockup img {
  border-color: rgba(102, 184, 255, 0.22);
  background: linear-gradient(135deg, rgba(29, 103, 255, 0.14), rgba(121, 222, 255, 0.12));
}

.footer-brand__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.site-nav__cta .button--primary {
  justify-content: flex-start;
  min-height: 56px;
  padding-inline: 1.25rem 1.5rem;
  color: #fff7f1;
  background: linear-gradient(135deg, #ff5c56 0%, #ff7d5d 48%, #ffb35f 100%);
  border-color: rgba(255, 165, 112, 0.26);
  box-shadow:
    0 20px 44px rgba(255, 85, 68, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.site-nav__cta .button--primary span {
  display: block;
  max-width: 8.8ch;
  line-height: 1.02;
  text-align: left;
}

.footer-brand {
  max-width: 30rem;
}

.footer-brand__actions .button--primary,
.footer-brand__actions .button--secondary {
  min-height: 54px;
  padding-inline: 1.4rem;
}

.footer-brand__actions .button--primary {
  color: #fff7f1;
  background: linear-gradient(135deg, #ff5c56 0%, #ff7d5d 48%, #ffb35f 100%);
  border-color: rgba(255, 165, 112, 0.26);
  box-shadow:
    0 20px 44px rgba(255, 85, 68, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.site-nav__cta .button--primary:hover,
.site-nav__cta .button--primary:focus-visible,
.footer-brand__actions .button--primary:hover,
.footer-brand__actions .button--primary:focus-visible {
  background: linear-gradient(135deg, #ff6859 0%, #ff8a63 48%, #ffbd69 100%);
}

.floating-rail {
  right: max(0.75rem, env(safe-area-inset-right, 0px));
  bottom: calc(0.75rem + env(safe-area-inset-bottom, 0px));
  gap: 0.5rem;
}

.floating-action {
  min-height: 40px;
  padding: 0.55rem 0.75rem;
  border-radius: 18px;
  border-color: rgba(104, 184, 255, 0.18);
  background: rgba(5, 10, 18, 0.84);
}

.floating-action__label {
  font-size: 0.76rem;
  letter-spacing: -0.01em;
}

.floating-action--whatsapp {
  border-color: rgba(37, 211, 102, 0.36);
  background: linear-gradient(135deg, #25d366, #128c7e);
  color: #f3fff7;
}

.floating-action--bot {
  background: linear-gradient(135deg, rgba(6, 15, 28, 0.96), rgba(17, 41, 80, 0.96));
  border-color: rgba(121, 222, 255, 0.24);
}

.floating-action--top {
  background: rgba(8, 15, 28, 0.88);
}

.floating-action__avatar {
  width: 1.5rem;
  height: 1.5rem;
}

@media (max-width: 699px) {
  .floating-rail {
    right: max(0.35rem, env(safe-area-inset-right, 0px));
    bottom: calc(0.45rem + env(safe-area-inset-bottom, 0px));
    gap: 0.35rem;
    transform: scale(0.92);
    transform-origin: right bottom;
  }

  .brand-lockup__mark {
    width: 46px;
    height: 46px;
    border-radius: 15px;
  }

  .brand-lockup__tag {
    display: none;
  }

  .site-header__inner {
    border-radius: 24px;
  }

  .section-mark {
    width: 54px;
    height: 54px;
    border-radius: 18px;
  }

  .section-mark img {
    width: 40px;
    height: 40px;
    border-radius: 14px;
  }

  .floating-action {
    min-width: 38px;
    min-height: 38px;
    padding: 0.5rem;
    border-radius: 16px;
    justify-content: center;
  }

  .floating-action--bot {
    padding: 0.35rem 0.55rem 0.35rem 0.35rem;
  }

  .floating-action--whatsapp .floating-action__label,
  .floating-action--top .floating-action__label {
    display: none;
  }
}

@media (max-width: 1240px) {
  .brand-lockup__tag {
    display: none;
  }

  .brand-lockup__title {
    font-size: 0.94rem;
  }

  .site-header__inner {
    padding-inline: 0.82rem;
  }

  .site-nav__links a {
    padding-inline: 0.66rem;
    font-size: 0.88rem;
  }
}

@media (min-width: 700px) {
}

@media (min-width: 960px) {
  .site-header__inner {
    padding-inline: 1rem;
  }

  .footer-brand {
    grid-column: 1;
    grid-row: 1;
  }

  .footer-sitemap {
    grid-column: 2;
    grid-row: 1 / span 2;
  }

  .site-footer__columns {
    grid-column: 1;
    grid-row: 2;
  }

  .floating-action {
    min-height: 42px;
    padding-inline: 0.8rem;
  }
}

/* ==========================================================================
   CSS Section: Cinematic Hero And Route Pages
   Full-bleed video hero, page hero cards, route/service/process grids, embeds,
   and discovery form option chips.
   ========================================================================== */
.hero-cinema {
  position: relative;
  min-height: clamp(32rem, 74vw, 46rem);
  padding: 0;
  overflow: hidden;
}

.hero-cinema__media,
.hero-cinema__media video,
.hero-cinema__veil {
  position: absolute;
  inset: 0;
}

.hero-cinema__media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.46) saturate(0.78) contrast(1.08);
  transform: scale(1.06);
}

.hero-cinema__veil {
  background:
    linear-gradient(110deg, rgba(3, 8, 18, 0.92) 14%, rgba(3, 8, 18, 0.72) 48%, rgba(3, 8, 18, 0.84) 100%),
    radial-gradient(circle at 78% 22%, rgba(125, 225, 255, 0.16), transparent 24%),
    linear-gradient(180deg, rgba(7, 17, 34, 0.18), rgba(3, 8, 18, 0.82));
}

.hero-cinema__content {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: end;
  gap: 1rem;
  min-height: inherit;
  max-width: 46rem;
  padding: clamp(1.4rem, 4vw, 3rem);
}

.hero-cinema__punch,
.page-hero__punch,
.service-detail__punch {
  margin: 0;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.home-statement {
  padding-top: 0.45rem;
}

.section-callout {
  margin-top: 1rem;
}

.page-hero {
  display: grid;
  gap: 1rem;
}

.page-hero__copy,
.page-hero__media {
  min-width: 0;
}

.page-hero__copy {
  display: grid;
  align-content: start;
  gap: 1rem;
}

.page-hero__media .image-frame,
.page-hero__media .video-frame {
  min-height: 280px;
  height: 100%;
}

.page-hero__media .video-frame video,
.page-hero__media .image-frame img {
  min-height: 280px;
}

.values-grid,
.route-grid,
.service-category-grid,
.service-detail-grid,
.process-stack {
  display: grid;
  gap: 1rem;
}

.value-card,
.route-card,
.service-category,
.service-detail,
.process-step,
.brief-section {
  display: grid;
  gap: 0.9rem;
}

.value-card h3,
.route-card h3,
.service-category h3,
.service-detail h3,
.process-step h2,
.brief-section h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 3vw, 2rem);
  letter-spacing: -0.04em;
  line-height: 0.98;
}

.value-card p,
.route-card p,
.service-category p,
.service-detail p,
.process-step p,
.brief-section p {
  margin: 0;
  color: var(--text-soft);
}

.route-card__label,
.service-detail__index {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 34px;
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(105, 184, 255, 0.18);
  background: rgba(255, 255, 255, 0.035);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.service-category {
  align-content: start;
}

.service-category p {
  color: var(--text-soft);
}

.service-detail strong,
.process-step strong,
.brief-section strong {
  color: var(--text);
}

.service-detail-grid--single {
  grid-template-columns: 1fr;
}

.process-step__head,
.brief-section__head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.9rem;
  align-items: start;
}

.process-step__number,
.brief-section__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 18px;
  border: 1px solid rgba(113, 187, 255, 0.22);
  background: linear-gradient(135deg, rgba(29, 103, 255, 0.18), rgba(121, 222, 255, 0.08));
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.stacked-form {
  display: grid;
  gap: 1rem;
}

.faq-category__head {
  display: grid;
  gap: 0.7rem;
  padding: 0 1.05rem 0.35rem;
}

.faq-category__head h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 4vw, 2.35rem);
  letter-spacing: -0.04em;
  line-height: 0.98;
}

.faq-category__head p {
  margin: 0;
  color: var(--text-soft);
}

.embed-card {
  display: grid;
  gap: 1rem;
  padding: clamp(1.2rem, 3vw, 1.6rem);
}

.schedule-embed {
  overflow: hidden;
  border-radius: calc(var(--radius-lg) - 4px);
  border: 1px solid rgba(121, 227, 255, 0.18);
  background: rgba(5, 9, 20, 0.58);
  min-height: 680px;
}

.schedule-embed iframe {
  display: block;
  width: 100%;
  min-height: 680px;
  height: min(80vh, 780px);
  border: 0;
  background: #08101d;
}

.brief-section {
  padding: 1.1rem;
}

.brief-section__head p {
  margin-top: 0.25rem;
}

.brief-section__grid {
  display: grid;
  gap: 0.9rem;
}

.brief-section__grid .field--full {
  grid-column: 1 / -1;
}

fieldset.field {
  margin: 0;
  padding: 0;
  border: 0;
  min-width: 0;
}

.field legend {
  margin-bottom: 0.5rem;
  padding: 0;
  color: var(--text-soft);
  font-size: 0.94rem;
  font-weight: 700;
}

.option-grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 0.6rem;
}

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

.option-chip {
  position: relative;
  display: block;
  cursor: pointer;
}

.option-chip input {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}

.option-chip span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.75rem 0.85rem;
  border: 1px solid rgba(108, 184, 255, 0.18);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.028);
  color: var(--text-soft);
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.option-chip input:checked + span {
  transform: translateY(-1px);
  border-color: rgba(121, 222, 255, 0.4);
  background: linear-gradient(135deg, #7ce2ff, #4f9bff);
  box-shadow: 0 14px 30px rgba(44, 108, 255, 0.22);
  color: #04111f;
}

.option-chip input:focus-visible + span {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

@media (min-width: 700px) {
  .values-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .route-grid,
  .page-hero {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
  }

  .service-category-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-detail-grid,
  .brief-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

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

@media (min-width: 960px) {
  .hero-cinema__content {
    max-width: 52rem;
    padding: 2.25rem 2.3rem;
  }

  .page-hero {
    grid-template-columns: minmax(0, 0.98fr) minmax(0, 1.02fr);
  }

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

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

  .service-detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-detail-grid--single {
    grid-template-columns: minmax(0, 0.82fr);
    justify-content: start;
  }

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

/* ==========================================================================
   CSS Section: Cinematic Layout Refresh
   Higher-level page rhythm, story grids, hero systems, service clusters, and
   payment flow treatment introduced after the base components.
   ========================================================================== */
:root {
  --section-space: clamp(1.35rem, 3vw, 3.4rem);
  --panel-deep:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.012)),
    linear-gradient(180deg, rgba(8, 14, 28, 0.98), rgba(3, 7, 16, 0.94));
}

main {
  position: relative;
}

.section {
  padding: var(--section-space) 0;
}

.section-heading {
  display: grid;
  gap: 0.95rem;
  max-width: none;
}

.section-title {
  max-width: 13.5ch;
}

.section-text {
  max-width: 38rem;
}

.story-grid__copy,
.story-grid__media,
.service-card,
.value-card,
.card,
.phase-card,
.route-card,
.service-detail,
.process-step,
.faq-shell,
.policy-card,
.brief-section,
.contact-card,
.form-card,
.embed-card,
.quote-banner {
  height: 100%;
}

.story-grid__copy,
.story-grid__media,
.service-detail,
.process-step,
.route-card,
.value-card,
.brief-section {
  background: var(--panel-deep);
}

.page-hero {
  padding: clamp(1.2rem, 2.6vw, 1.75rem);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.042), rgba(255, 255, 255, 0.014)),
    radial-gradient(circle at 18% 18%, rgba(43, 107, 255, 0.14), transparent 26%),
    rgba(4, 8, 16, 0.94);
}

.page-hero__copy {
  gap: 1.1rem;
}

.page-hero__media {
  display: grid;
}

.page-hero__media .image-frame,
.page-hero__media .video-frame {
  min-height: clamp(18rem, 44vw, 34rem);
}

.page-hero__media .image-frame img,
.page-hero__media .video-frame video {
  min-height: inherit;
}

.hero-cinema {
  min-height: clamp(36rem, 78vw, 52rem);
  border-radius: 38px;
}

.hero-cinema__veil {
  background:
    linear-gradient(110deg, rgba(2, 7, 16, 0.94) 10%, rgba(2, 7, 16, 0.68) 46%, rgba(2, 7, 16, 0.9) 100%),
    radial-gradient(circle at 76% 18%, rgba(121, 222, 255, 0.18), transparent 24%),
    radial-gradient(circle at 84% 72%, rgba(44, 108, 255, 0.16), transparent 26%);
}

.hero-cinema__content {
  max-width: none;
  gap: 0;
}

.hero-cinema__layout {
  display: grid;
  gap: 1rem;
  min-height: inherit;
  align-content: end;
}

.hero-cinema__copy {
  display: grid;
  gap: 0.9rem;
  max-width: 40rem;
}

.hero-cinema__systems {
  display: grid;
  gap: 0.8rem;
  align-content: end;
}

.hero-cinema__rail,
.hero-cinema__sysline {
  border: 1px solid rgba(112, 184, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015)),
    rgba(6, 12, 24, 0.72);
  backdrop-filter: blur(16px);
}

.hero-cinema__rail {
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
  border-radius: 26px;
}

.hero-cinema__rail-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 4vw, 2rem);
  letter-spacing: -0.04em;
  line-height: 0.98;
}

.hero-cinema__rail-copy {
  margin: 0;
  color: var(--text-soft);
}

.hero-cinema__sysline {
  display: grid;
  gap: 0.3rem;
  padding: 0.95rem 1rem;
  border-radius: 22px;
}

.hero-cinema__sysline strong {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text);
}

.hero-cinema__sysline span {
  color: var(--text-soft);
  font-size: 0.96rem;
  line-height: 1.45;
}

.hero-cinema__rail .route-cloud {
  gap: 0.55rem;
}

.hero-cinema__rail .route-cloud a {
  min-height: 36px;
  padding: 0.45rem 0.72rem;
}

.home-statement {
  position: relative;
  z-index: 3;
  margin-top: -1.3rem;
  padding-top: 0;
}

.home-statement .info-strip {
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.28);
}

.quote-banner,
.callout {
  padding: clamp(1.2rem, 2.8vw, 1.75rem);
}

.quote-banner blockquote,
.callout__title {
  max-width: 13ch;
}

.media-caption,
.page-hero__punch,
.service-detail__punch,
.hero-cinema__punch {
  letter-spacing: 0.15em;
}

.service-cluster {
  display: grid;
  gap: 1rem;
}

.process-stack {
  position: relative;
}

.payment-flow {
  display: grid;
  gap: 1rem;
}

.payment-note {
  display: grid;
  gap: 0.55rem;
  padding: 1rem;
  border: 1px solid rgba(108, 184, 255, 0.18);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.032), rgba(255, 255, 255, 0.01)),
    rgba(6, 11, 21, 0.72);
}

.payment-note strong {
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.payment-note p {
  margin: 0;
  color: var(--text-soft);
}

@media (min-width: 1040px) {
  .section-heading {
    grid-template-columns: minmax(0, 0.6fr) minmax(18rem, 0.4fr);
    align-items: end;
  }

  .section-heading .section-text {
    margin-top: 0;
    justify-self: end;
  }

  .hero-cinema__layout {
    grid-template-columns: minmax(0, 1.14fr) minmax(18rem, 0.58fr);
    align-items: end;
  }

  .story-grid {
    gap: 1.15rem;
  }

  .payment-flow {
    grid-template-columns: minmax(0, 0.46fr) minmax(0, 0.54fr);
    align-items: start;
  }
}

/* ==========================================================================
   CSS Section: Hero Mast System
   Full-width hero redesign system: oversized type, cinematic glow, floating
   panels, orbital lines, page-specific variants, and responsive hero stacks.
   ========================================================================== */
.hero-mast {
  padding-top: clamp(0.6rem, 1.8vw, 1.4rem);
}

.hero-mast__shell {
  width: min(100% - 1rem, 1700px);
  margin: 0 auto;
}

.hero-mast__frame {
  position: relative;
  overflow: hidden;
  min-height: clamp(34rem, 82vh, 56rem);
  padding: clamp(1.05rem, 2vw, 1.55rem);
  border-radius: 40px;
  border: 1px solid rgba(121, 227, 255, 0.16);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    radial-gradient(circle at 18% 18%, rgba(70, 124, 255, 0.16), transparent 26%),
    radial-gradient(circle at 82% 18%, rgba(121, 227, 255, 0.12), transparent 22%),
    linear-gradient(145deg, rgba(5, 10, 20, 0.98), rgba(7, 18, 35, 0.94));
  box-shadow: 0 28px 70px rgba(2, 6, 14, 0.44);
}

.hero-mast__frame::before,
.hero-mast__frame::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.hero-mast__frame::before {
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px),
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: 88px 88px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.45), transparent 100%);
  opacity: 0.38;
}

.hero-mast__frame::after {
  inset: auto 0 0;
  height: 34%;
  background:
    linear-gradient(180deg, rgba(7, 16, 30, 0), rgba(7, 16, 30, 0.82)),
    radial-gradient(circle at 50% 100%, rgba(255, 128, 94, 0.18), transparent 48%);
}

.hero-mast__layout {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1rem;
  min-height: inherit;
}

.hero-mast__copy,
.hero-mast__stage {
  min-width: 0;
}

.hero-mast__copy {
  display: grid;
  align-content: end;
  gap: 1rem;
  padding: clamp(0.35rem, 1vw, 0.8rem);
}

.hero-mast__eyebrow,
.hero-mast__meta,
.hero-mast__micro {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  gap: 0.5rem;
  min-height: 34px;
  padding: 0.4rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(121, 227, 255, 0.16);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.hero-mast__eyebrow::before {
  content: "";
  width: 0.48rem;
  height: 0.48rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #79e3ff, #4f8bff);
  box-shadow: 0 0 12px rgba(121, 227, 255, 0.6);
}

.hero-mast__title {
  margin: 0;
  max-width: 11ch;
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 7rem);
  line-height: 0.9;
  letter-spacing: -0.065em;
  text-wrap: pretty;
}

.hero-mast__lede {
  margin: 0;
  max-width: 40rem;
  color: var(--text-soft);
  font-size: clamp(1rem, 1.6vw, 1.2rem);
  line-height: 1.65;
}

.hero-mast__punch {
  margin: 0;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.77rem;
  letter-spacing: 0.17em;
  text-transform: uppercase;
}

.hero-mast__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.hero-mast__stage {
  display: grid;
  gap: 0.9rem;
  align-content: stretch;
  padding: clamp(0.15rem, 1vw, 0.6rem);
}

.hero-mast__card,
.hero-mast__panel,
.hero-mast__signal,
.hero-mast__stat,
.hero-mast__lane,
.hero-mast__tile,
.hero-mast__topic {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(121, 227, 255, 0.14);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.052), rgba(255, 255, 255, 0.016)),
    rgba(5, 11, 22, 0.72);
  backdrop-filter: blur(18px);
}

.hero-mast__card {
  display: grid;
  gap: 0.9rem;
  padding: 1rem;
}

.hero-mast__panel {
  display: grid;
  gap: 0.8rem;
  padding: 0.95rem;
}

.hero-mast__panel h2,
.hero-mast__panel h3,
.hero-mast__card h2,
.hero-mast__card h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2.5vw, 2.1rem);
  line-height: 0.95;
  letter-spacing: -0.045em;
}

.hero-mast__panel p,
.hero-mast__card p,
.hero-mast__stat p,
.hero-mast__lane p,
.hero-mast__topic p {
  margin: 0;
  color: var(--text-soft);
}

.hero-mast__logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(3.6rem, 7vw, 5rem);
  height: clamp(3.6rem, 7vw, 5rem);
  padding: 0.45rem;
  border-radius: 22px;
  border: 1px solid rgba(121, 227, 255, 0.18);
  background:
    linear-gradient(145deg, rgba(121, 227, 255, 0.16), rgba(255, 152, 105, 0.12)),
    rgba(8, 15, 28, 0.88);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.hero-mast__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-mast__chip-row,
.hero-mast__route-row,
.hero-mast__meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.hero-mast__chip,
.hero-mast__route {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0.5rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(121, 227, 255, 0.14);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-soft);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.hero-mast__route {
  color: var(--text);
}

.hero-mast__media {
  position: relative;
  min-height: clamp(14rem, 28vw, 25rem);
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(121, 227, 255, 0.16);
  background:
    radial-gradient(circle at 24% 22%, rgba(121, 227, 255, 0.22), transparent 24%),
    radial-gradient(circle at 80% 18%, rgba(77, 127, 255, 0.22), transparent 20%),
    linear-gradient(180deg, rgba(7, 17, 33, 0.28), rgba(4, 9, 18, 0.88)),
    #07101e;
}

.hero-mast__media img,
.hero-mast__media video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.92) contrast(1.06) brightness(0.82);
}

.hero-mast__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(4, 8, 16, 0.12), rgba(4, 8, 16, 0.82)),
    linear-gradient(120deg, rgba(4, 8, 16, 0.64), rgba(4, 8, 16, 0.08));
}

.hero-mast__signal-grid,
.hero-mast__stat-grid,
.hero-mast__lane-grid,
.hero-mast__topic-grid {
  display: grid;
  gap: 0.8rem;
}

.hero-mast__signal,
.hero-mast__stat,
.hero-mast__lane,
.hero-mast__topic {
  padding: 0.95rem;
}

.hero-mast__signal strong,
.hero-mast__stat strong,
.hero-mast__lane strong,
.hero-mast__topic strong {
  display: block;
  margin-bottom: 0.45rem;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.hero-mast__signal span,
.hero-mast__stat span,
.hero-mast__lane span,
.hero-mast__topic span {
  color: var(--text-soft);
  line-height: 1.55;
}

.hero-mast__orbital {
  position: relative;
  min-height: clamp(16rem, 32vw, 26rem);
  border-radius: 28px;
  border: 1px solid rgba(121, 227, 255, 0.12);
  background:
    radial-gradient(circle at 50% 50%, rgba(121, 227, 255, 0.1), transparent 16%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.012)),
    rgba(4, 9, 18, 0.58);
  overflow: hidden;
}

.hero-mast__orbital::before,
.hero-mast__orbital::after,
.hero-mast__ring {
  content: "";
  position: absolute;
  border-radius: 999px;
  border: 1px solid rgba(121, 227, 255, 0.18);
}

.hero-mast__orbital::before {
  inset: 14% 18%;
}

.hero-mast__orbital::after {
  inset: 26% 8%;
  border-color: rgba(255, 153, 107, 0.18);
}

.hero-mast__ring {
  inset: 8% 30%;
}

.hero-mast__node {
  position: absolute;
  width: 0.85rem;
  height: 0.85rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #79e3ff, #4f8bff);
  box-shadow: 0 0 18px rgba(121, 227, 255, 0.55);
}

.hero-mast__node--a {
  top: 18%;
  right: 26%;
}

.hero-mast__node--b {
  top: 52%;
  left: 20%;
}

.hero-mast__node--c {
  right: 14%;
  bottom: 18%;
  background: linear-gradient(135deg, #ff9b6b, #ff5f73);
}

.hero-mast__note {
  position: absolute;
  display: grid;
  gap: 0.3rem;
  width: min(16rem, calc(100% - 2rem));
  padding: 0.8rem 0.9rem;
  border: 1px solid rgba(121, 227, 255, 0.14);
  border-radius: 18px;
  background: rgba(7, 14, 28, 0.82);
  backdrop-filter: blur(14px);
}

.hero-mast__note strong {
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.69rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.hero-mast__note span {
  color: var(--text-soft);
  line-height: 1.45;
}

.hero-mast__note--top {
  top: 1rem;
  left: 1rem;
}

.hero-mast__note--bottom {
  right: 1rem;
  bottom: 1rem;
}

.hero-mast__list {
  display: grid;
  gap: 0.65rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hero-mast__list li {
  display: grid;
  gap: 0.25rem;
  padding: 0.8rem 0.9rem;
  border-radius: 18px;
  border: 1px solid rgba(121, 227, 255, 0.12);
  background: rgba(255, 255, 255, 0.025);
}

.hero-mast__list strong {
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.hero-mast__list span {
  color: var(--text-soft);
  line-height: 1.5;
}

.hero-mast__calendar {
  display: grid;
  gap: 0.7rem;
}

.hero-mast__calendar-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.hero-mast__slot {
  min-height: 5.75rem;
  padding: 0.9rem;
  border-radius: 22px;
  border: 1px solid rgba(121, 227, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.016)),
    rgba(5, 11, 22, 0.72);
}

.hero-mast__slot strong {
  display: block;
  margin-bottom: 0.45rem;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.hero-mast__slot span {
  color: var(--text);
  font-weight: 700;
}

.hero-mast__slot--active {
  border-color: rgba(255, 141, 107, 0.3);
  box-shadow: 0 16px 36px rgba(255, 107, 71, 0.15);
}

.hero-mast__search {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-height: 54px;
  padding: 0 1rem;
  border-radius: 20px;
  border: 1px solid rgba(121, 227, 255, 0.14);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-soft);
}

.hero-mast__search svg {
  width: 1rem;
  height: 1rem;
  color: var(--text-muted);
}

.hero-mast__legal-grid {
  display: grid;
  gap: 0.8rem;
}

.hero-mast__legal-item {
  padding: 0.95rem;
  border-radius: 22px;
  border: 1px solid rgba(121, 227, 255, 0.12);
  background: rgba(255, 255, 255, 0.028);
}

.hero-mast__legal-item strong {
  display: block;
  margin-bottom: 0.45rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.hero-mast__legal-item span {
  color: var(--text-soft);
  line-height: 1.5;
}

body[data-page="home"] .hero-mast__frame {
  background:
    radial-gradient(circle at 18% 20%, rgba(132, 104, 255, 0.18), transparent 22%),
    radial-gradient(circle at 80% 22%, rgba(121, 227, 255, 0.16), transparent 24%),
    radial-gradient(circle at 72% 78%, rgba(255, 128, 94, 0.12), transparent 28%),
    linear-gradient(145deg, rgba(4, 10, 22, 0.99), rgba(9, 25, 49, 0.95));
}

body[data-page="about"] .hero-mast__frame {
  background:
    radial-gradient(circle at 22% 18%, rgba(121, 227, 255, 0.12), transparent 20%),
    radial-gradient(circle at 84% 20%, rgba(255, 148, 112, 0.14), transparent 20%),
    linear-gradient(155deg, rgba(5, 11, 21, 0.99), rgba(8, 22, 40, 0.95));
}

body[data-page="services"] .hero-mast__frame {
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 149, 112, 0.16), transparent 20%),
    radial-gradient(circle at 78% 24%, rgba(121, 227, 255, 0.15), transparent 22%),
    linear-gradient(145deg, rgba(6, 11, 20, 0.99), rgba(10, 22, 42, 0.95));
}

body[data-page="process"] .hero-mast__frame {
  background:
    radial-gradient(circle at 20% 24%, rgba(121, 227, 255, 0.16), transparent 22%),
    radial-gradient(circle at 82% 76%, rgba(255, 143, 109, 0.12), transparent 24%),
    linear-gradient(145deg, rgba(5, 11, 21, 0.99), rgba(8, 26, 44, 0.95));
}

body[data-page="discovery"] .hero-mast__frame {
  background:
    radial-gradient(circle at 16% 18%, rgba(86, 112, 255, 0.16), transparent 22%),
    radial-gradient(circle at 84% 22%, rgba(121, 227, 255, 0.16), transparent 24%),
    linear-gradient(145deg, rgba(5, 10, 22, 0.99), rgba(11, 24, 44, 0.95));
}

body[data-page="payments"] .hero-mast__frame,
body[data-page="schedule"] .hero-mast__frame,
body[data-page="contact"] .hero-mast__frame,
body[data-page="launch"] .hero-mast__frame,
body[data-page="examples"] .hero-mast__frame {
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 145, 108, 0.16), transparent 20%),
    radial-gradient(circle at 80% 22%, rgba(121, 227, 255, 0.14), transparent 24%),
    linear-gradient(145deg, rgba(6, 11, 21, 0.99), rgba(11, 23, 42, 0.95));
}

body[data-page="faq"] .hero-mast__frame,
body[data-page="privacy"] .hero-mast__frame,
body[data-page="terms"] .hero-mast__frame,
body[data-page="cookies"] .hero-mast__frame,
body[data-page="accessibility"] .hero-mast__frame {
  min-height: clamp(28rem, 64vh, 42rem);
  background:
    radial-gradient(circle at 18% 18%, rgba(121, 227, 255, 0.12), transparent 20%),
    radial-gradient(circle at 82% 22%, rgba(255, 145, 108, 0.1), transparent 18%),
    linear-gradient(145deg, rgba(5, 10, 20, 0.99), rgba(10, 21, 38, 0.95));
}

@media (min-width: 760px) {
  .hero-mast__signal-grid,
  .hero-mast__stat-grid,
  .hero-mast__lane-grid,
  .hero-mast__topic-grid,
  .hero-mast__legal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1040px) {
  .hero-mast__layout {
    grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
    align-items: stretch;
  }

  .hero-mast__copy {
    padding: 1.1rem 1rem 1rem 1.1rem;
  }

  .hero-mast__stage {
    align-content: end;
    padding: 0.6rem;
  }
}

@media (max-width: 759px) {
  .hero-mast__shell {
    width: min(calc(100% - 0.6rem), 1700px);
  }

  .hero-mast__frame {
    min-height: auto;
    border-radius: 28px;
    padding: 0.85rem;
  }

  .hero-mast__title {
    font-size: clamp(1.78rem, 8.6vw, 2.65rem);
    max-width: 100%;
    line-height: 0.98;
    letter-spacing: -0.045em;
    overflow-wrap: break-word;
    word-break: normal;
  }

  body[data-page="home"] .hero-mast__title {
    max-width: 7.2ch;
  }

  .hero-mast__lede {
    font-size: 0.96rem;
    line-height: 1.55;
  }

  .hero-mast__copy,
  .hero-mast__stage,
  .hero-mast__lede,
  .hero-mast__actions,
  .hero-mast__chip-row,
  .hero-mast__route-row {
    max-width: 100%;
  }

  .hero-mast__layout {
    overflow: hidden;
  }

  .hero-mast__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .hero-mast__actions .button {
    width: 100%;
    justify-content: center;
  }

  .hero-mast__chip-row,
  .hero-mast__route-row {
    overflow: hidden;
  }

  .hero-mast__calendar-row,
  .hero-mast__signal-grid,
  .hero-mast__stat-grid,
  .hero-mast__lane-grid,
  .hero-mast__topic-grid,
  .hero-mast__legal-grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 1100px) {
  body[data-page="home"] .values-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  body[data-page="home"] .values-grid .value-card {
    grid-column: span 4;
  }

  body[data-page="home"] .values-grid .value-card:nth-child(1),
  body[data-page="home"] .values-grid .value-card:nth-child(4),
  body[data-page="home"] .values-grid .value-card:nth-child(7),
  body[data-page="home"] .values-grid .value-card:nth-child(10) {
    grid-column: span 6;
  }

  body[data-page="home"] .service-grid,
  body[data-page="home"] .card-grid,
  body[data-page="home"] .phase-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  body[data-page="home"] .service-grid .service-card {
    grid-column: span 4;
  }

  body[data-page="home"] .service-grid .service-card:nth-child(1),
  body[data-page="home"] .service-grid .service-card:nth-child(2) {
    grid-column: span 6;
  }

  body[data-page="home"] .service-grid .service-card:nth-child(5) {
    grid-column: span 12;
  }

  body[data-page="home"] .card-grid .card {
    grid-column: span 6;
  }

  body[data-page="home"] .card-grid .card:nth-child(1) {
    grid-column: span 8;
  }

  body[data-page="home"] .card-grid .card:nth-child(4) {
    grid-column: span 4;
  }

  body[data-page="home"] .phase-grid .phase-card {
    grid-column: span 6;
  }

  body[data-page="home"] .phase-grid .phase-card:nth-child(2),
  body[data-page="home"] .phase-grid .phase-card:nth-child(3) {
    transform: translateY(2rem);
  }

  body[data-page="services"] .service-cluster {
    grid-template-columns: minmax(0, 0.34fr) minmax(0, 0.66fr);
    align-items: start;
  }

  body[data-page="services"] .service-cluster > .section-heading {
    position: sticky;
    top: 6.8rem;
  }

  body[data-page="about"] .card-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  body[data-page="about"] .card-grid .card {
    grid-column: span 4;
  }

  body[data-page="about"] .card-grid .card:first-child {
    grid-column: span 12;
  }

  body[data-page="process"] .process-stack {
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 1.2rem;
  }

  body[data-page="process"] .process-stack::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 1rem;
    bottom: 1rem;
    width: 1px;
    background: linear-gradient(180deg, rgba(121, 222, 255, 0), rgba(121, 222, 255, 0.3), rgba(121, 222, 255, 0));
    transform: translateX(-0.5px);
    pointer-events: none;
  }

  body[data-page="process"] .process-step {
    grid-column: 1 / span 7;
  }

  body[data-page="process"] .process-step:nth-child(even) {
    grid-column: 6 / span 7;
    margin-top: 3rem;
  }

  body[data-page="discovery"] .brief-section {
    grid-template-columns: minmax(0, 0.29fr) minmax(0, 0.71fr);
    align-items: start;
    padding: 1.25rem;
  }

body[data-page="discovery"] .brief-section__head {
    position: sticky;
    top: 6.8rem;
  }
}

/* ==========================================================================
   CSS Section: Narrative UX Overhaul
   Reading widths, section spacing, card rhythm, CTA grouping, and long-page
   narrative refinements layered over the earlier base styles.
   ========================================================================== */
:root {
  --container: 1180px;
  --reading-width: 38rem;
  --reading-width-tight: 32rem;
  --section-space: clamp(5rem, 8vw, 7.5rem);
  --section-space-tight: clamp(3.4rem, 6vw, 5rem);
}

body {
  line-height: 1.68;
  padding-bottom: 0;
}

main {
  position: relative;
}

.shell {
  width: min(var(--container), calc(100% - 1.5rem));
}

.section {
  padding: var(--section-space) 0;
}

.section--tight {
  padding: var(--section-space-tight) 0;
}

.section--flush {
  padding-top: 0;
}

.section--contrast::before {
  content: "";
  position: absolute;
  inset: 1.2rem 0;
  border-top: 1px solid rgba(255, 136, 96, 0.12);
  border-bottom: 1px solid rgba(95, 215, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.028), rgba(255, 255, 255, 0.01)),
    radial-gradient(circle at 18% 18%, rgba(255, 114, 80, 0.08), transparent 24%),
    radial-gradient(circle at 82% 28%, rgba(95, 215, 255, 0.08), transparent 26%),
    rgba(4, 8, 17, 0.72);
  pointer-events: none;
}

.section--contrast .shell {
  position: relative;
  z-index: 1;
}

.hero {
  padding-top: clamp(1.5rem, 4vw, 2.6rem);
}

.hero__title {
  font-size: clamp(3.35rem, 7vw, 5.9rem);
  max-width: 9ch;
}

.section-title {
  font-size: clamp(2.3rem, 5vw, 4rem);
  max-width: 10ch;
}

.card__title,
.service-card__title,
.phase-card__title,
.study-card__title,
.contact-card__title,
.policy-card__title,
.faq-shell__title,
.value-card h3,
.route-card h3,
.service-category h3,
.service-detail h3,
.process-step h2,
.brief-section h3 {
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.02;
}

.hero__lede,
.section-text,
.policy-hero__text,
.card__text,
.service-card__text,
.phase-card__text,
.study-card__text,
.contact-card__text,
.policy-card__text,
.value-card p,
.route-card p,
.service-category p,
.service-detail p,
.process-step p,
.brief-section p,
.quote-banner p {
  font-size: clamp(1rem, 1.8vw, 1.125rem);
  line-height: 1.72;
}

.hero__lede,
.section-text,
.quote-banner p,
.story-grid__copy p,
.story-grid__copy li,
.page-hero__copy p {
  max-width: var(--reading-width);
}

.card__text,
.service-card__text,
.phase-card__text,
.study-card__text,
.contact-card__text,
.policy-card__text,
.value-card p,
.route-card p,
.service-category p,
.service-detail p,
.process-step p,
.brief-section p,
.check-list li,
.detail-list li {
  max-width: var(--reading-width-tight);
}

.section-heading {
  gap: 1rem;
  margin-bottom: clamp(1.4rem, 3vw, 2.6rem);
}

.section-heading + * {
  margin-top: 0;
}

.story-grid,
.service-grid,
.card-grid,
.study-grid,
.service-detail-grid,
.route-grid,
.values-grid,
.service-category-grid,
.phase-grid,
.process-stack,
.contact-grid,
.crosslink-grid {
  gap: clamp(1rem, 2.1vw, 1.4rem);
}

.story-grid__copy,
.story-grid__media,
.service-card,
.value-card,
.card,
.phase-card,
.route-card,
.service-detail,
.process-step,
.faq-shell,
.policy-card,
.brief-section,
.contact-card,
.form-card,
.embed-card,
.quote-banner,
.page-hero,
.hero__copy,
.hero__visual {
  padding: clamp(1.35rem, 2.4vw, 2rem);
}

.hero__actions {
  gap: 0.85rem;
  margin-top: 1.9rem;
}

.home-statement {
  margin-top: clamp(-1.2rem, -2vw, -0.65rem);
}

.info-strip__track {
  animation-duration: 22s;
}

.site-nav {
  gap: 1rem;
}

.site-nav__cta {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.site-nav__cta .button {
  width: 100%;
  min-width: 0;
}

.footer-brand__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.footer-brand .route-cloud {
  gap: 0.55rem;
}

.footer-brand .route-cloud a {
  min-height: 36px;
  padding: 0.45rem 0.72rem;
}

@media (max-width: 699px) {
  .hero__actions {
    display: grid;
  }

  .hero__actions .button {
    width: 100%;
  }
}

@media (max-width: 959px) {
  .floating-rail {
    right: 0.75rem;
    bottom: 1rem;
  }

  .floating-action {
    min-height: 42px;
    padding: 0.75rem;
  }

  .floating-action__label {
    display: none;
  }
}

@media (min-width: 960px) {
  .site-nav__cta {
    display: flex;
    align-items: center;
    gap: 0.65rem;
  }

  .site-nav__cta .button {
    width: auto;
  }

}

@media (min-width: 1180px) {
  .shell {
    width: min(var(--container), calc(100% - 2.5rem));
  }
}

/* ==========================================================================
   CSS Section: Handwritten Body Layout System
   Reusable layout-* classes that power the redesigned body sections across
   Home, About, Services, Process, Discovery, Contact, and related pages.
   ========================================================================== */
.layout-page {
  display: block;
}

.layout-section {
  position: relative;
}

.layout-section__frame {
  display: grid;
  gap: 1rem;
}

.layout-section__intro,
.layout-panel,
.layout-metric,
.layout-cluster,
.layout-highlight,
.layout-callout,
.layout-category,
.layout-timeline {
  padding: clamp(1rem, 2vw, 1.4rem);
}

.layout-section__intro {
  display: grid;
  gap: 0.9rem;
}

.layout-section__kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.layout-section__kicker::before {
  content: "";
  width: 0.62rem;
  height: 0.62rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), var(--accent-warm));
  box-shadow: 0 0 20px rgba(121, 227, 255, 0.24);
}

.layout-section__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 7vw, 4.7rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
}

.layout-section__body {
  margin: 0;
  max-width: 42rem;
  color: var(--text-soft);
  font-size: clamp(1rem, 2vw, 1.08rem);
}

.layout-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.layout-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 78px;
  height: 78px;
  border-radius: 26px;
  border: 1px solid rgba(130, 229, 255, 0.18);
  background:
    linear-gradient(135deg, rgba(121, 227, 255, 0.12), rgba(255, 177, 132, 0.13)),
    rgba(255, 255, 255, 0.02);
  box-shadow: var(--shadow-lg);
}

.layout-mark img {
  width: 58px;
  height: 58px;
  object-fit: cover;
  border-radius: 20px;
}

.layout-section__frame--hero {
  align-items: stretch;
}

.layout-hero-grid,
.layout-split-grid,
.layout-rail-grid,
.layout-category-grid,
.layout-twin-grid {
  display: grid;
  gap: 1rem;
}

.layout-hero-copy,
.layout-story-copy,
.layout-rail-copy,
.layout-callout {
  display: grid;
  gap: 0.95rem;
}

.layout-hero-card {
  display: grid;
  gap: 1rem;
  justify-items: start;
}

.layout-signal-list,
.layout-mini-list,
.layout-pill-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.layout-signal,
.layout-pill,
.layout-tag {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0.42rem 0.8rem;
  border: 1px solid rgba(130, 229, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-soft);
  font-family: var(--font-mono);
  font-size: 0.71rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.layout-metric-grid,
.layout-panel-grid,
.layout-cluster-grid,
.layout-value-cloud,
.layout-service-mosaic,
.layout-step-grid,
.layout-proof-grid {
  display: grid;
  gap: 0.9rem;
}

.layout-metric {
  display: grid;
  gap: 0.55rem;
  border: 1px solid rgba(130, 229, 255, 0.14);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.03);
}

.layout-metric__label {
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.layout-metric__value {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.5;
}

.layout-visual-card {
  display: grid;
  gap: 0.8rem;
}

.layout-visual-card .image-frame,
.layout-visual-card .video-frame {
  min-height: 100%;
}

.layout-caption {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.9rem;
}

.layout-panel-grid--offset .layout-panel:nth-child(2) {
  transform: translateY(1rem);
}

.layout-panel-grid--offset .layout-panel:nth-child(4) {
  transform: translateY(1.5rem);
}

.layout-panel {
  display: grid;
  gap: 0.7rem;
}

.layout-panel__index {
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.layout-panel__title {
  margin: 0;
  font-size: 1.15rem;
}

.layout-panel__text,
.layout-callout__text,
.layout-category p,
.layout-timeline__text {
  margin: 0;
  color: var(--text-soft);
}

.layout-rail-card {
  display: grid;
  gap: 0.9rem;
}

.layout-proof-grid .layout-highlight {
  min-height: 100%;
}

.layout-highlight {
  display: grid;
  gap: 0.8rem;
}

.layout-highlight blockquote,
.layout-callout blockquote {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 4vw, 2.8rem);
  line-height: 1;
  letter-spacing: -0.04em;
}

.layout-callout {
  display: grid;
  gap: 0.95rem;
  justify-items: start;
}

.layout-category {
  display: grid;
  gap: 0.45rem;
}

.layout-category h3,
.layout-timeline h3,
.layout-cluster h3 {
  margin: 0;
  font-size: 1.12rem;
}

.layout-timeline {
  display: grid;
  gap: 0.65rem;
}

.layout-timeline__step {
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.layout-bullet-list,
.layout-inline-list {
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding-left: 1.2rem;
  color: var(--text-soft);
}

.layout-inline-list {
  padding-left: 0;
  list-style: none;
}

.layout-inline-list li {
  padding: 0.7rem 0.9rem;
  border: 1px solid rgba(130, 229, 255, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.03);
}

.layout-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(130, 229, 255, 0.2), transparent);
}

[data-layout-sequence].is-even .layout-section__frame > .surface {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.034), rgba(255, 255, 255, 0.012)),
    rgba(7, 11, 21, 0.72);
}

@media (min-width: 700px) {
  .layout-metric-grid,
  .layout-cluster-grid,
  .layout-step-grid,
  .layout-proof-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .layout-panel-grid--offset,
  .layout-service-mosaic {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .layout-category-grid,
  .layout-twin-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 960px) {
  .layout-section__frame--hero,
  .layout-split-grid,
  .layout-rail-grid {
    grid-template-columns: minmax(0, 1.08fr) minmax(18rem, 0.92fr);
  }

  .layout-hero-grid {
    grid-template-columns: minmax(0, 1.02fr) minmax(19rem, 0.98fr);
    align-items: stretch;
  }

  .layout-metric-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .layout-cluster-grid {
    grid-template-columns: 1.2fr 0.8fr;
  }

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

  .layout-proof-grid {
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  }

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

@media (max-width: 699px) {
  .layout-mark {
    width: 64px;
    height: 64px;
    border-radius: 22px;
  }

  .layout-mark img {
    width: 48px;
    height: 48px;
    border-radius: 16px;
  }

  .layout-panel-grid--offset .layout-panel:nth-child(2),
  .layout-panel-grid--offset .layout-panel:nth-child(4) {
    transform: none;
  }
}

/* ==========================================================================
   CSS Section: Layout Safety And Anti-Cropping Pass
   Prevents long-copy cards, media frames, and multi-column body sections from
   clipping, over-stretching, or collapsing across breakpoints.
   ========================================================================== */
.layout-page .surface,
.layout-page .layout-section__frame,
.layout-page .layout-story-copy,
.layout-page .layout-hero-copy,
.layout-page .layout-hero-card,
.layout-page .layout-panel,
.layout-page .layout-metric,
.layout-page .layout-category,
.layout-page .layout-timeline,
.layout-page .layout-highlight,
.layout-page .layout-callout {
  min-width: 0;
}

.layout-hero-grid,
.layout-split-grid,
.layout-rail-grid,
.layout-category-grid,
.layout-twin-grid,
.layout-panel-grid,
.layout-panel-grid--offset,
.layout-cluster-grid,
.layout-value-cloud,
.layout-service-mosaic,
.layout-step-grid,
.layout-proof-grid {
  grid-template-columns: 1fr;
}

.layout-hero-grid,
.layout-split-grid,
.layout-rail-grid {
  align-items: start;
}

.layout-section__title {
  max-width: 12ch;
}

.layout-panel-grid--offset .layout-panel:nth-child(2),
.layout-panel-grid--offset .layout-panel:nth-child(4) {
  transform: none;
}

@media (min-width: 860px) {
  .layout-metric-grid,
  .layout-category-grid,
  .layout-twin-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .layout-panel-grid,
  .layout-panel-grid--offset,
  .layout-step-grid,
  .layout-proof-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1180px) {
  .layout-hero-grid,
  .layout-split-grid,
  .layout-rail-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
  }

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

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

/* Compact spacing pass:
   the later overhaul widened the vertical rhythm too far for the current pages.
   Bring header-to-hero, section-to-section, and panel spacing back under control. */
:root {
  --section-space: clamp(1.55rem, 3.2vw, 3rem);
  --section-space-tight: clamp(0.95rem, 2.1vw, 1.65rem);
}

.site-header {
  padding: 0.55rem 0.75rem 0;
}

.site-header.is-scrolled {
  padding-top: 0.32rem;
}

.section {
  padding: var(--section-space) 0;
}

.section--tight {
  padding: var(--section-space-tight) 0;
}

.section--flush {
  padding-top: 0;
}

.section--contrast::before {
  inset: 0.65rem 0;
}

.hero,
.hero-mast {
  padding-top: 0.18rem;
}

body[data-page="home"] .hero-mast {
  padding-top: 0.1rem;
}

.layout-section__frame,
.hero-mast__layout,
.hero-mast__stage,
.layout-service-mosaic,
.layout-panel-grid,
.layout-panel-grid--offset,
.layout-step-grid,
.layout-metric-grid,
.layout-cluster-grid,
.layout-twin-grid,
.layout-rail-grid {
  gap: clamp(0.8rem, 1.8vw, 1.15rem);
}

.layout-section__intro,
.layout-panel,
.layout-metric,
.layout-cluster,
.layout-highlight,
.layout-callout,
.layout-category,
.layout-timeline,
.route-card,
.service-detail,
.policy-card,
.faq-shell,
.page-hero,
.hero__copy,
.hero__visual {
  padding: clamp(0.95rem, 1.9vw, 1.3rem);
}

.layout-callout {
  padding: clamp(1.05rem, 2.1vw, 1.5rem);
}

.layout-section__intro {
  gap: 0.7rem;
}

.section-heading {
  margin-bottom: clamp(0.9rem, 2vw, 1.5rem);
}

.hero-mast__frame {
  min-height: clamp(29rem, 66vh, 46rem);
  padding: clamp(0.85rem, 1.7vw, 1.2rem);
}

.hero-mast__copy {
  gap: 0.8rem;
}

.hero-mast__stage {
  padding: clamp(0.05rem, 0.6vw, 0.35rem);
}

.hero-mast__actions,
.hero__actions,
.layout-actions {
  gap: 0.65rem;
  margin-top: 0.95rem;
}

.home-statement {
  margin-top: -0.4rem;
}

.info-strip {
  padding-block: 0.1rem;
}

.info-strip__item {
  padding: 0.72rem 0.95rem;
}

.layout-panel__title,
.layout-section__title,
.section-title {
  text-wrap: balance;
}

.crosslink-grid {
  gap: clamp(0.8rem, 1.8vw, 1.15rem);
}

@media (max-width: 759px) {
  .site-header {
    padding-top: 0.35rem;
  }

  .section {
    padding: clamp(1.4rem, 6vw, 2rem) 0;
  }

  .hero-mast__frame {
    min-height: auto;
  }

  .layout-section__intro,
  .layout-panel,
  .layout-metric,
  .layout-highlight,
  .layout-callout,
  .layout-timeline,
  .route-card,
  .service-detail {
    padding: 0.9rem;
  }
}

/* Hero declutter + media-behind-text pass
   Keep the box patterns in the body sections, but simplify hero hierarchy. */
.hero-mast__frame {
  isolation: isolate;
}

/* Keep all page bodies centered even after late-stage spacing overrides. */
.shell {
  margin-inline: auto;
}

.hero-mast__layout {
  display: block;
}

.hero-mast__copy {
  position: relative;
  z-index: 2;
  max-width: min(60rem, 100%);
  width: 100%;
  min-height: clamp(18rem, 42vh, 26rem);
  align-content: end;
}

.hero-mast__stage {
  position: absolute;
  inset: 0;
  z-index: 0;
  padding: 0;
  pointer-events: none;
}

.hero-mast__media {
  position: absolute;
  inset: 0;
  min-height: 100%;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.hero-mast__media::after {
  background:
    radial-gradient(circle at 76% 18%, rgba(121, 227, 255, 0.14), transparent 24%),
    radial-gradient(circle at 14% 20%, rgba(255, 140, 105, 0.12), transparent 24%),
    linear-gradient(108deg, rgba(3, 8, 18, 0.84) 10%, rgba(3, 8, 18, 0.58) 42%, rgba(3, 8, 18, 0.86) 100%);
}

.hero-mast__media--ambient img {
  filter: saturate(0.8) contrast(1.03) brightness(0.66);
}

.hero-mast__title {
  max-width: 11ch;
  font-size: clamp(2.5rem, 6vw, 5.6rem);
  line-height: 0.92;
}

.hero-mast__lede {
  max-width: 34rem;
  width: min(100%, 34rem);
  font-size: clamp(0.98rem, 1.35vw, 1.08rem);
  line-height: 1.55;
}

/* Ensure hero copy never stays in hidden reveal state on any route. */
.hero-mast__frame[data-reveal] {
  opacity: 1;
  transform: none;
  transition: none;
}

.hero-mast__actions {
  margin-top: 0.7rem;
}

body[data-page="home"] .hero-mast__title {
  max-width: 7.8ch;
}

body[data-page="services"] .hero-mast__copy,
body[data-page="process"] .hero-mast__copy {
  max-width: min(52rem, 100%);
}

body[data-page="faq"] .hero-mast__copy,
body[data-page="privacy"] .hero-mast__copy,
body[data-page="terms"] .hero-mast__copy,
body[data-page="cookies"] .hero-mast__copy,
body[data-page="accessibility"] .hero-mast__copy {
  max-width: min(50rem, 100%);
  min-height: clamp(14rem, 32vh, 20rem);
}

@media (max-width: 959px) {
  .hero-mast__copy {
    min-height: clamp(15rem, 36vh, 22rem);
  }

  .hero-mast__title {
    max-width: 9ch;
    font-size: clamp(1.7rem, 8vw, 2.7rem);
    line-height: 0.96;
    letter-spacing: -0.03em;
  }

  .hero-mast__lede {
    max-width: 26rem;
    width: min(100%, 26rem);
    font-size: 0.93rem;
    line-height: 1.45;
  }
}

@media (max-width: 759px) {
  .hero-mast__copy {
    min-height: auto;
    max-width: 100%;
    padding-right: 0.35rem;
  }

  .hero-mast__title {
    max-width: 14ch;
    font-size: clamp(1.45rem, 7vw, 2.1rem);
    line-height: 0.98;
    overflow-wrap: anywhere;
    word-break: normal;
  }

  body[data-page="home"] .hero-mast__title {
    max-width: 9ch;
  }

  .hero-mast__actions {
    display: flex;
    flex-wrap: wrap;
  }

  .hero-mast__lede {
    max-width: 30ch;
    width: min(100%, 30ch);
  }

  .hero-mast__actions .button {
    width: auto;
  }
}

/* ==========================================================================
   CSS Section: Homepage Decision Support Cards
   Cards and lists that help visitors choose the correct project route.
   ========================================================================== */
.home-decision-grid {
  display: grid;
  gap: clamp(0.85rem, 1.8vw, 1.2rem);
}

.home-decision-card {
  display: grid;
  gap: 0.65rem;
}

.home-decision-card h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.4vw, 1.8rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
}

.home-decision-card p {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.55;
}

.home-decision-list {
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.home-decision-list li {
  padding: 0.75rem 0.85rem;
  border: 1px solid rgba(121, 227, 255, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.02);
  color: var(--text-soft);
}

@media (min-width: 900px) {
  .home-decision-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* ==========================================================================
   CSS Section: Orbot Launcher Refinement
   Keeps the floating Orbot launcher visually separate from the main action rail.
   ========================================================================== */
.floating-action--bot {
  position: relative;
  overflow: visible;
}

/* ==========================================================================
   CSS Section: Global Anti-Clipping Pass
   Keeps long copy readable across all pages and prevents card truncation after
   the denser editorial layouts are applied.
   ========================================================================== */
.layout-page .route-card,
.layout-page .service-detail,
.layout-page .process-step,
.layout-page .brief-section,
.layout-page .layout-section__intro,
.layout-page .layout-panel,
.layout-page .layout-metric,
.layout-page .layout-highlight,
.layout-page .layout-callout,
.layout-page .layout-category,
.layout-page .layout-timeline,
.layout-page .home-decision-card {
  height: auto;
  min-height: 0;
  align-content: start;
}

.layout-page .route-card p,
.layout-page .service-detail p,
.layout-page .process-step p,
.layout-page .brief-section p,
.layout-page .layout-panel__text,
.layout-page .layout-timeline__text,
.layout-page .layout-section__body,
.layout-page .layout-callout__text,
.layout-page .home-decision-card p,
.layout-page .home-decision-list li {
  overflow-wrap: anywhere;
  word-break: normal;
}

.layout-page .home-decision-grid,
.layout-page .layout-panel-grid,
.layout-page .layout-panel-grid--offset,
.layout-page .layout-service-mosaic,
.layout-page .layout-step-grid,
.layout-page .layout-cluster-grid,
.layout-page .layout-value-cloud,
.layout-page .route-grid,
.layout-page .service-detail-grid,
.layout-page .values-grid,
.layout-page .process-stack,
.layout-page .crosslink-grid {
  align-items: start;
  grid-auto-rows: auto;
}

/* Layout safety: keep card bounds clipped to avoid page-wide horizontal overflow. */
.layout-page .surface {
  overflow: hidden;
}

.layout-page .image-frame,
.layout-page .video-frame,
.layout-page .hero-mast__frame,
.layout-page .hero-mast__media {
  overflow: hidden;
}

/* Layout safety: targeted home section fixes for dense/cropped content blocks. */
body[data-page="home"] .home-section--decision .home-decision-grid {
  align-items: start;
}

body[data-page="home"] .home-section--decision .home-decision-card {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  height: auto;
  min-height: 0;
}

body[data-page="home"] .home-section--decision .home-decision-list {
  flex: 1 1 auto;
}

body[data-page="home"] .home-section--decision .home-decision-card p {
  margin-top: 0;
}

body[data-page="home"] .home-section--what-we-do .layout-split-grid,
body[data-page="home"] .home-section--why .layout-rail-grid {
  align-items: start;
}

body[data-page="home"] .home-section--why .layout-rail-card {
  align-content: start;
}

body[data-page="home"] .home-section--why .layout-rail-card .layout-highlight {
  min-height: 0;
}

body[data-page="home"] .home-section--values .layout-cluster-grid {
  align-items: start;
}

body[data-page="home"] .home-section--values .layout-pill-list {
  align-content: start;
}

/* Layout safety: override old equal-height behavior in long-copy cards. */
.layout-page .story-grid__copy,
.layout-page .story-grid__media,
.layout-page .service-card,
.layout-page .value-card,
.layout-page .card,
.layout-page .phase-card,
.layout-page .route-card,
.layout-page .service-detail,
.layout-page .process-step,
.layout-page .faq-shell,
.layout-page .policy-card,
.layout-page .brief-section,
.layout-page .contact-card,
.layout-page .form-card,
.layout-page .embed-card,
.layout-page .quote-banner {
  height: auto;
}

@media (min-width: 980px) {
  body[data-page="home"] .home-section--what-we-do .layout-split-grid {
    grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  }

  body[data-page="home"] .home-section--what-we-do .layout-service-mosaic {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="home"] .home-section--why .layout-rail-grid {
    grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr);
  }

  body[data-page="home"] .home-section--values .layout-cluster-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  }
}

@media (min-width: 1280px) {
  body[data-page="home"] .home-section--values .layout-pill-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
  }

  body[data-page="home"] .home-section--values .layout-pill {
    width: 100%;
    justify-content: flex-start;
  }
}

/* ==========================================================================
   CSS Section: Main Layout Hardening
   Ensures every main region accommodates long copy, adds card numbering/marks,
   and protects hero media from overflow in the final page layout.
   ========================================================================== */
main.layout-page {
  overflow-x: clip;
}

main.layout-page .page-info-strip {
  position: relative;
  z-index: 3;
  margin-top: -0.55rem;
  padding-top: 0;
}

main.layout-page .page-info-strip .info-strip {
  box-shadow: 0 16px 40px rgba(3, 10, 22, 0.32);
}

main.layout-page .section-title,
main.layout-page .layout-section__title {
  max-width: 15ch;
}

main.layout-page .section-text,
main.layout-page .layout-section__body,
main.layout-page .layout-panel__text,
main.layout-page .layout-timeline__text,
main.layout-page .layout-callout__text,
main.layout-page .route-card p,
main.layout-page .service-detail p,
main.layout-page .process-step p,
main.layout-page .brief-section p,
main.layout-page .policy-card p,
main.layout-page .contact-card p,
main.layout-page .study-card__text,
main.layout-page .card__text {
  max-width: 46rem;
  line-height: 1.68;
}

main.layout-page .card-grid,
main.layout-page .contact-grid,
main.layout-page .crosslink-grid,
main.layout-page .page-hero,
main.layout-page .process-stack,
main.layout-page .route-grid,
main.layout-page .service-category-grid,
main.layout-page .service-detail-grid,
main.layout-page .study-grid,
main.layout-page .values-grid,
main.layout-page .layout-category-grid,
main.layout-page .layout-cluster-grid,
main.layout-page .layout-metric-grid,
main.layout-page .layout-panel-grid,
main.layout-page .layout-panel-grid--offset,
main.layout-page .layout-proof-grid,
main.layout-page .layout-rail-grid,
main.layout-page .layout-service-mosaic,
main.layout-page .layout-split-grid,
main.layout-page .layout-step-grid,
main.layout-page .layout-twin-grid,
main.layout-page .service-cluster {
  align-items: start;
  grid-auto-rows: auto;
}

main.layout-page .card,
main.layout-page .contact-card,
main.layout-page .faq-shell,
main.layout-page .page-hero,
main.layout-page .policy-card,
main.layout-page .quote-banner,
main.layout-page .route-card,
main.layout-page .service-category,
main.layout-page .service-detail,
main.layout-page .study-card,
main.layout-page .value-card,
main.layout-page .layout-callout,
main.layout-page .layout-category,
main.layout-page .layout-highlight,
main.layout-page .layout-metric,
main.layout-page .layout-panel,
main.layout-page .layout-section__intro,
main.layout-page .layout-timeline,
main.layout-page .home-decision-card {
  min-height: 0;
  height: auto;
  align-content: start;
}

main.layout-page .check-list,
main.layout-page .detail-list,
main.layout-page .layout-bullet-list,
main.layout-page .policy-card ul {
  display: grid;
  gap: 0.6rem;
}

main.layout-page .check-list li,
main.layout-page .detail-list li,
main.layout-page .layout-bullet-list li,
main.layout-page .policy-card li {
  position: relative;
  padding-left: 1.35rem;
}

main.layout-page .check-list li::before,
main.layout-page .detail-list li::before,
main.layout-page .layout-bullet-list li::before,
main.layout-page .policy-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7rem;
  width: 0.6rem;
  height: 0.12rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 148, 112, 0.9), rgba(121, 227, 255, 0.92));
  box-shadow: 0 0 12px rgba(121, 227, 255, 0.22);
}

main.layout-page .route-card,
main.layout-page .service-detail,
main.layout-page .layout-panel,
main.layout-page .layout-timeline,
main.layout-page .layout-category,
main.layout-page .card,
main.layout-page .study-card,
main.layout-page .contact-card,
main.layout-page .policy-card,
main.layout-page .faq-shell,
main.layout-page .home-decision-card {
  position: relative;
}

main.layout-page .route-card::after,
main.layout-page .service-detail::after,
main.layout-page .layout-panel::after,
main.layout-page .layout-timeline::after,
main.layout-page .layout-category::after,
main.layout-page .card::after,
main.layout-page .study-card::after,
main.layout-page .contact-card::after,
main.layout-page .policy-card::after,
main.layout-page .faq-shell::after,
main.layout-page .home-decision-card::after {
  content: "";
  position: absolute;
  right: 0.95rem;
  bottom: 0.95rem;
  width: 2.15rem;
  height: 2.15rem;
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(121, 227, 255, 0.06), rgba(255, 177, 132, 0.08)),
    rgba(255, 255, 255, 0.02) url("../brand/ash-tra-mark.svg") center / 62% no-repeat;
  border: 1px solid rgba(121, 227, 255, 0.1);
  opacity: 0.46;
  pointer-events: none;
}

main.layout-page [data-card-seq]::before {
  content: attr(data-card-seq);
  position: absolute;
  top: 0.95rem;
  right: 0.95rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.2rem;
  min-height: 2.2rem;
  padding: 0 0.55rem;
  border-radius: 999px;
  border: 1px solid rgba(121, 227, 255, 0.18);
  background: rgba(10, 20, 35, 0.82);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  z-index: 2;
}

main.layout-page .route-card__label,
main.layout-page .service-detail__index,
main.layout-page .layout-panel__index,
main.layout-page .layout-timeline__step {
  padding-right: 0.9rem;
}

main.layout-page .hero-mast__media img {
  animation: heroMediaDrift 28s ease-in-out infinite alternate;
}

main.layout-page .hero-mast__media::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 24%, rgba(121, 227, 255, 0.12), transparent 0.45rem),
    radial-gradient(circle at 66% 28%, rgba(255, 177, 132, 0.12), transparent 0.4rem),
    radial-gradient(circle at 82% 62%, rgba(121, 227, 255, 0.12), transparent 0.38rem),
    linear-gradient(180deg, rgba(4, 10, 20, 0.06), rgba(4, 10, 20, 0.2));
  background-size: 32% 32%, 38% 38%, 44% 44%, 100% 100%;
  mix-blend-mode: screen;
  opacity: 0.56;
  pointer-events: none;
}

@media (min-width: 960px) {
  main.layout-page .route-grid,
  main.layout-page .service-detail-grid,
  main.layout-page .card-grid,
  main.layout-page .study-grid,
  main.layout-page .contact-grid,
  main.layout-page .crosslink-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  main.layout-page .service-category-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1240px) {
  main.layout-page .crosslink-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  main.layout-page .layout-section__title {
    max-width: 16ch;
  }
}

@media (max-width: 759px) {
  main.layout-page .page-info-strip {
    margin-top: -0.3rem;
  }

  main.layout-page [data-card-seq]::before {
    top: 0.72rem;
    right: 0.72rem;
  }

  main.layout-page .route-card::after,
  main.layout-page .service-detail::after,
  main.layout-page .layout-panel::after,
  main.layout-page .layout-timeline::after,
  main.layout-page .layout-category::after,
  main.layout-page .card::after,
  main.layout-page .study-card::after,
  main.layout-page .contact-card::after,
  main.layout-page .policy-card::after,
  main.layout-page .faq-shell::after,
  main.layout-page .home-decision-card::after {
    right: 0.72rem;
    bottom: 0.72rem;
  }
}

@keyframes heroMediaDrift {
  0% {
    transform: scale(1.04) translate3d(-1.5%, -1.2%, 0);
  }
  50% {
    transform: scale(1.08) translate3d(1.2%, 0.5%, 0);
  }
  100% {
    transform: scale(1.06) translate3d(0.6%, -1.8%, 0);
  }
}

/* ==========================================================================
   CSS Section: Cookie Consent Banner
   Thin bottom consent strip used by site.js before analytics, behaviour tools,
   or marketing pixels are allowed to load.
   ========================================================================== */
.consent-banner {
  position: fixed;
  right: max(0.65rem, env(safe-area-inset-right));
  bottom: max(0.65rem, env(safe-area-inset-bottom));
  left: max(0.65rem, env(safe-area-inset-left));
  z-index: 80;
  width: auto;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgba(140, 226, 255, 0.2);
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(121, 227, 255, 0.1), rgba(255, 177, 132, 0.08)),
    rgba(5, 10, 20, 0.9);
  box-shadow: 0 18px 54px rgba(0, 0, 0, 0.32);
  backdrop-filter: blur(18px) saturate(1.08);
}

.consent-banner__content {
  display: flex;
  gap: 0.7rem;
  align-items: center;
  justify-content: space-between;
  min-height: 2.65rem;
  padding: 0.35rem 0.45rem 0.35rem 0.95rem;
}

.consent-banner__copy,
.consent-banner__link,
.consent-banner__option {
  color: rgba(238, 244, 255, 0.72);
  font: 700 0.75rem/1.3 var(--font-body);
}

.consent-banner__copy {
  flex: 1 1 auto;
  margin: 0;
  max-width: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.consent-banner__copy strong {
  color: var(--text);
}

.consent-banner__options {
  position: absolute;
  right: 0.55rem;
  bottom: calc(100% + 0.55rem);
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  max-width: min(32rem, calc(100vw - 1.3rem));
  padding: 0.55rem;
  border: 1px solid rgba(140, 226, 255, 0.16);
  border-radius: 1.1rem;
  background: rgba(5, 10, 20, 0.94);
  box-shadow: 0 18px 54px rgba(0, 0, 0, 0.34);
  backdrop-filter: blur(18px) saturate(1.08);
}

.consent-banner__option {
  display: flex;
  gap: 0.4rem;
  align-items: center;
  padding: 0.45rem 0.6rem;
  border: 1px solid rgba(140, 226, 255, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
}

.consent-banner__option input {
  width: 0.85rem;
  height: 0.85rem;
  margin: 0;
  accent-color: var(--accent-warm);
}

.consent-banner__actions {
  display: flex;
  flex: 0 0 auto;
  gap: 0.35rem;
  align-items: center;
}

.consent-banner__accept,
.consent-banner__essential,
.consent-banner__manage,
.consent-banner__save,
.consent-banner__link {
  border: 0;
  text-decoration: none;
}

.consent-banner__accept,
.consent-banner__essential,
.consent-banner__manage {
  border-radius: 999px;
  padding: 0.58rem 0.76rem;
  cursor: pointer;
  font: 800 0.64rem/1 var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.consent-banner__accept {
  background: linear-gradient(135deg, var(--accent-warm), #ffd677 72%, #bffbff);
  color: #07111d;
}

.consent-banner__essential,
.consent-banner__manage,
.consent-banner__save {
  border: 1px solid rgba(140, 226, 255, 0.13);
  background: rgba(255, 255, 255, 0.045);
  color: rgba(238, 244, 255, 0.76);
}

.consent-banner__save {
  border-radius: 999px;
  padding: 0.58rem 0.76rem;
  cursor: pointer;
  font: 800 0.64rem/1 var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.consent-banner__manage:hover,
.consent-banner__manage:focus-visible,
.consent-banner__essential:hover,
.consent-banner__essential:focus-visible,
.consent-banner__save:hover,
.consent-banner__save:focus-visible,
.consent-banner__link:hover,
.consent-banner__link:focus-visible {
  color: var(--accent-warm);
}

.consent-banner__link {
  padding: 0.5rem 0.35rem;
  color: rgba(238, 244, 255, 0.58);
  font: 800 0.64rem/1 var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

@media (max-width: 760px) {
  .consent-banner {
    border-radius: 999px;
  }

  .consent-banner__content {
    display: flex;
    min-height: auto;
    padding: 0.34rem 0.4rem 0.34rem 0.76rem;
  }

  .consent-banner__copy {
    max-width: 8.5rem;
    white-space: nowrap;
  }

  .consent-banner__actions {
    display: flex;
    justify-content: flex-end;
  }

  .consent-banner__essential,
  .consent-banner__link {
    display: none;
  }

  .consent-banner__accept,
  .consent-banner__manage,
  .consent-banner__save {
    padding: 0.48rem 0.58rem;
    font-size: 0.56rem;
  }

  .consent-banner__options {
    right: 0.4rem;
    left: 0.4rem;
    max-width: none;
  }
}

/* ==========================================================================
   CSS Section: Orbot Assistant
   Premium floating assistant, launcher, chat panel, suggestions, and reduced
   motion handling for the site-routing helper.
   ========================================================================== */
:root {
  --orbot-backdrop: rgba(2, 8, 16, 0.82);
  --orbot-panel: rgba(5, 10, 18, 0.97);
  --orbot-border: rgba(108, 184, 255, 0.22);
  --orbot-warm: rgba(255, 134, 88, 0.2);
}

.orbot-launcher {
  position: relative;
  isolation: isolate;
  gap: 0.62rem;
  padding-inline: 0.85rem;
  border-color: rgba(121, 222, 255, 0.3);
  background:
    linear-gradient(135deg, rgba(3, 11, 22, 0.96), rgba(15, 29, 52, 0.96)),
    radial-gradient(circle at 18% 20%, rgba(121, 222, 255, 0.12), transparent 52%);
  box-shadow:
    0 14px 36px rgba(8, 24, 52, 0.52),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  transform: none !important;
  transition:
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.orbot-launcher:hover,
.orbot-launcher:focus-visible {
  transform: none !important;
}

.orbot-launcher[data-orbot-state="open"] {
  border-color: rgba(121, 222, 255, 0.54);
  box-shadow:
    0 16px 42px rgba(8, 24, 52, 0.62),
    0 0 0 1px rgba(121, 222, 255, 0.28);
}

.orbot-launcher__halo {
  position: absolute;
  inset: -5px;
  border-radius: 999px;
  border: 1px solid rgba(121, 222, 255, 0.2);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--duration-fast) var(--ease-out);
}

.orbot-launcher:hover .orbot-launcher__halo,
.orbot-launcher:focus-visible .orbot-launcher__halo {
  opacity: 1;
}

.orbot-launcher__avatar {
  width: 1.6rem;
  height: 1.6rem;
  animation: none;
}

.orbot {
  position: fixed;
  inset: 0;
  z-index: 44;
  display: grid;
  align-items: end;
  padding: max(0.8rem, env(safe-area-inset-top, 0px)) max(0.8rem, env(safe-area-inset-right, 0px))
    max(0.8rem, env(safe-area-inset-bottom, 0px)) max(0.8rem, env(safe-area-inset-left, 0px));
}

.orbot[hidden] {
  display: none;
}

.orbot__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: var(--orbot-backdrop);
  backdrop-filter: blur(12px);
}

.orbot__panel {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
  max-height: min(88vh, 760px);
  border: 1px solid var(--orbot-border);
  border-radius: 28px;
  background:
    radial-gradient(circle at 84% 12%, var(--orbot-warm), transparent 26%),
    radial-gradient(circle at 14% 18%, rgba(121, 222, 255, 0.14), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01)),
    var(--orbot-panel);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}

.orbot__header,
.orbot__footer {
  padding: 0.95rem;
  border-bottom: 1px solid rgba(108, 184, 255, 0.16);
}

.orbot__footer {
  border-top: 1px solid rgba(108, 184, 255, 0.14);
  border-bottom: 0;
}

.orbot__footer p {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.86rem;
}

.orbot__header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 0.8rem;
  align-items: center;
}

.orbot__avatar-shell {
  width: 3.2rem;
  height: 3.2rem;
  padding: 0.22rem;
  border-radius: 50%;
  border: 1px solid rgba(121, 222, 255, 0.3);
  background: linear-gradient(135deg, rgba(121, 222, 255, 0.16), rgba(255, 134, 88, 0.11));
}

.orbot__avatar-shell img {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 50%;
}

.orbot__intro h2 {
  margin: 0.12rem 0 0;
  font-family: var(--font-display);
  font-size: clamp(1.12rem, 4.3vw, 1.6rem);
  letter-spacing: -0.03em;
}

.orbot__intro p {
  margin: 0.35rem 0 0;
  color: var(--text-soft);
  font-size: 0.93rem;
}

.orbot__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.67rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.orbot__close {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  border: 1px solid rgba(121, 222, 255, 0.2);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
}

.orbot__close svg {
  width: 1rem;
  height: 1rem;
}

.orbot__body {
  display: grid;
  gap: 0.9rem;
  padding: 0 0.95rem 0.95rem;
}

.orbot__suggestions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
}

.orbot__suggestion {
  min-height: 42px;
  border: 1px solid rgba(108, 184, 255, 0.18);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-soft);
  font-weight: 700;
  font-size: 0.8rem;
  cursor: pointer;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out);
}

.orbot__suggestion:hover,
.orbot__suggestion:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(121, 222, 255, 0.36);
  background: rgba(121, 222, 255, 0.1);
}

.orbot__form {
  display: grid;
  gap: 0.7rem;
}

.orbot__field {
  min-height: 52px;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0 0.9rem;
  border: 1px solid rgba(108, 184, 255, 0.2);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.03);
}

.orbot__field svg {
  width: 1rem;
  height: 1rem;
  color: var(--text-muted);
}

.orbot__field input {
  width: 100%;
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--text);
}

.orbot__field input:focus {
  outline: none;
}

.orbot__send {
  min-height: 52px;
}

.orbot__status {
  margin: 0;
  color: var(--text-muted);
  font-size: 0.85rem;
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.orbot[data-orbot-state="processing"] .orbot__status {
  color: rgba(121, 222, 255, 0.92);
}

.orbot__log {
  display: grid;
  gap: 0.68rem;
  max-height: 280px;
  overflow: auto;
  padding-right: 0.1rem;
}

.orbot-entry {
  border: 1px solid rgba(108, 184, 255, 0.14);
  border-radius: 16px;
  padding: 0.78rem 0.84rem;
  background: rgba(255, 255, 255, 0.02);
}

.orbot-entry--user {
  border-color: rgba(121, 222, 255, 0.28);
  background: linear-gradient(135deg, rgba(121, 222, 255, 0.1), rgba(121, 222, 255, 0.03));
}

.orbot-entry--assistant {
  background: linear-gradient(135deg, rgba(255, 134, 88, 0.08), rgba(121, 222, 255, 0.06));
}

.orbot-entry__label {
  display: block;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.64rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.orbot-entry__text {
  margin: 0.45rem 0 0;
  color: var(--text-soft);
}

.orbot-results {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.68rem;
}

.orbot-results__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  border: 1px solid rgba(108, 184, 255, 0.16);
  border-radius: 14px;
  padding: 0.62rem 0.75rem;
  background: rgba(255, 255, 255, 0.03);
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out);
}

.orbot-results__item:hover,
.orbot-results__item:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(121, 222, 255, 0.35);
  background: rgba(121, 222, 255, 0.08);
}

.orbot-results__item span {
  min-width: 0;
  display: grid;
  gap: 0.22rem;
}

.orbot-results__item strong {
  font-size: 0.9rem;
}

.orbot-results__item small {
  color: var(--text-muted);
  line-height: 1.34;
}

.orbot-results__item svg {
  width: 0.95rem;
  height: 0.95rem;
  color: var(--accent);
  flex: 0 0 auto;
}

@media (min-width: 700px) {
  .orbot {
    align-items: center;
    justify-items: center;
  }

  .orbot__panel {
    width: min(780px, 100%);
  }

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

@media (min-width: 980px) {
  .orbot__form {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
  }

  .orbot__send {
    min-width: 134px;
  }
}

@media (max-width: 699px) {
  .orbot-launcher {
    padding: 0.35rem 0.55rem 0.35rem 0.35rem;
  }

  .orbot__intro p {
    font-size: 0.86rem;
  }

  .orbot__log {
    max-height: 240px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .orbot-launcher__halo,
  .orbot__panel,
  .orbot__suggestion,
  .orbot-results__item {
    animation: none !important;
    transition: none !important;
  }
}

/* ==========================================================================
   CSS Section: Interior Page Ordering And Motifs
   Controls section order, internal guide lines, hub navigation, body grids, and
   page-specific narrative motifs for the redesigned interiors.
   ========================================================================== */
main.layout-page {
  display: flex;
  flex-direction: column;
  gap: clamp(0.35rem, 1.1vw, 0.95rem);
  padding-bottom: 1rem;
}

main.layout-page > .section {
  order: 0;
}

main.layout-page [id] {
  scroll-margin-top: 6.75rem;
}

main.layout-page .section-heading,
main.layout-page .layout-section__intro,
main.layout-page .faq-summary,
main.layout-page .policy-summary,
main.layout-page .brief-hub__mast {
  max-width: none;
}

main.layout-page .faq-summary,
main.layout-page .policy-summary,
main.layout-page .brief-hub__mast {
  padding: clamp(1.3rem, 2vw, 1.9rem);
}

main.layout-page .home-band,
main.layout-page .about-band,
main.layout-page .services-band,
main.layout-page .process-band,
main.layout-page .contact-band,
main.layout-page .examples-band,
main.layout-page .faq-band,
main.layout-page .start-band,
main.layout-page .schedule-band,
main.layout-page .pay-band,
main.layout-page .discovery-band,
main.layout-page .policy-band {
  position: relative;
}

main.layout-page .home-band::before,
main.layout-page .about-band::before,
main.layout-page .services-band::before,
main.layout-page .process-band::before,
main.layout-page .contact-band::before,
main.layout-page .examples-band::before,
main.layout-page .faq-band::before,
main.layout-page .start-band::before,
main.layout-page .schedule-band::before,
main.layout-page .pay-band::before,
main.layout-page .discovery-band::before,
main.layout-page .policy-band::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(121, 227, 255, 0.28), rgba(255, 177, 132, 0.24), transparent);
  opacity: 0.8;
  pointer-events: none;
}

body[data-page="home"] .home-band--strip {
  order: 1;
}

body[data-page="home"] .home-band--outcomes {
  order: 2;
}

body[data-page="home"] .home-band--offers {
  order: 3;
}

body[data-page="home"] .home-band--services {
  order: 4;
}

body[data-page="home"] .home-band--fit {
  order: 5;
}

body[data-page="home"] .home-band--process {
  order: 6;
}

body[data-page="home"] .home-band--decision {
  order: 7;
}

body[data-page="home"] .home-band--atlas {
  order: 8;
}

body[data-page="home"] .home-band--values {
  order: 9;
}

body[data-page="home"] .home-band--routes {
  order: 10;
}

body[data-page="home"] .home-band--closing {
  order: 11;
}

body[data-page="about"] .about-band--premise {
  order: 1;
}

body[data-page="about"] .about-band--fit {
  order: 2;
}

body[data-page="about"] .about-band--mission {
  order: 3;
}

body[data-page="about"] .about-band--difference {
  order: 4;
}

body[data-page="about"] .about-band--method {
  order: 5;
}

body[data-page="about"] .about-band--closing {
  order: 6;
}

body[data-page="services"] .services-band--taxonomy {
  order: 1;
}

body[data-page="services"] .services-band--mosaic {
  order: 2;
}

body[data-page="services"] .services-band--closing {
  order: 3;
}

body[data-page="process"] .process-band--summary {
  order: 1;
}

body[data-page="process"] .process-band--steps {
  order: 2;
}

body[data-page="process"] .process-band--closing {
  order: 3;
}

body[data-page="launch"] .start-band--fit {
  order: 1;
}

body[data-page="launch"] .start-band--form {
  order: 2;
}

body[data-page="launch"] .start-band--after {
  order: 3;
}

body[data-page="discovery"] .discovery-band--routes {
  order: 1;
}

body[data-page="discovery"] .discovery-band--why {
  order: 2;
}

body[data-page="discovery"] .discovery-band--comparison {
  order: 3;
}

body[data-page="discovery"] .discovery-band--brief {
  order: 4;
}

body[data-page="discovery"] .discovery-band--closing {
  order: 5;
}

body[data-page="faq"] .faq-band--overview {
  order: 1;
}

body[data-page="faq"] .faq-band--atlas {
  order: 2;
}

body[data-page="faq"] .faq-band--closing {
  order: 3;
}

main.layout-page .crosslink-grid,
main.layout-page .layout-metric-grid,
main.layout-page .layout-panel-grid,
main.layout-page .layout-panel-grid--offset,
main.layout-page .layout-service-mosaic,
main.layout-page .layout-category-grid,
main.layout-page .home-decision-grid,
main.layout-page .route-grid,
main.layout-page .service-detail-grid,
main.layout-page .card-grid,
main.layout-page .study-grid,
main.layout-page .layout-step-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 1rem;
}

main.layout-page .crosslink-grid > *,
main.layout-page .layout-metric-grid > *,
main.layout-page .layout-panel-grid > *,
main.layout-page .layout-panel-grid--offset > *,
main.layout-page .layout-service-mosaic > *,
main.layout-page .layout-category-grid > *,
main.layout-page .home-decision-grid > *,
main.layout-page .route-grid > *,
main.layout-page .service-detail-grid > *,
main.layout-page .card-grid > *,
main.layout-page .study-grid > *,
main.layout-page .layout-step-grid > * {
  grid-column: 1 / -1;
  min-width: 0;
}

main.layout-page .home-band--strip .shell,
main.layout-page .home-band--fit .layout-section__frame,
main.layout-page .about-band--difference .layout-section__frame,
main.layout-page .about-band--method .layout-section__frame,
main.layout-page .examples-band--premise .shell,
main.layout-page .contact-band--routes .shell,
main.layout-page .examples-band--principles .shell,
main.layout-page .start-band--fit .shell,
main.layout-page .start-band--after .shell,
main.layout-page .discovery-band--routes .shell,
main.layout-page .discovery-band--brief .shell,
main.layout-page .contact-band--form .shell,
main.layout-page .start-band--form .shell,
main.layout-page .pay-band--routes .shell,
main.layout-page .schedule-band--embed .shell,
main.layout-page .faq-band--atlas .shell {
  position: relative;
}

main.layout-page .contact-band--routes .shell,
main.layout-page .examples-band--principles .shell,
main.layout-page .start-band--fit .shell,
main.layout-page .start-band--after .shell,
main.layout-page .discovery-band--routes .shell,
main.layout-page .discovery-band--brief .shell {
  display: grid;
  gap: 1rem;
}

main.layout-page .home-band--outcomes .layout-section__intro,
main.layout-page .home-band--offers .layout-section__intro,
main.layout-page .home-band--services .layout-story-copy,
main.layout-page .home-band--atlas .layout-section__intro,
main.layout-page .home-band--decision .layout-section__intro,
main.layout-page .home-band--process .layout-section__intro,
main.layout-page .home-band--routes .layout-section__intro,
main.layout-page .about-band--mission .layout-section__intro,
main.layout-page .about-band--fit .layout-section__intro,
main.layout-page .services-band--taxonomy .layout-section__intro,
main.layout-page .services-band--mosaic .layout-section__intro,
main.layout-page .process-band--summary .layout-section__intro,
main.layout-page .discovery-band--routes .layout-section__intro {
  background:
    linear-gradient(180deg, rgba(121, 227, 255, 0.1), rgba(255, 255, 255, 0.03)),
    rgba(7, 12, 21, 0.78);
}

main.layout-page .faq-overview,
main.layout-page .policy-atlas__frame {
  display: grid;
  gap: 1rem;
}

.faq-summary,
.policy-summary,
.brief-hub__mast {
  border: 1px solid rgba(121, 227, 255, 0.16);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(180deg, rgba(121, 227, 255, 0.09), rgba(255, 255, 255, 0.025)),
    rgba(7, 12, 21, 0.84);
  box-shadow: var(--shadow-lg);
}

.faq-summary .page-hero__punch,
.policy-summary .policy-summary__note {
  margin-top: 0.75rem;
}

.policy-summary__note {
  color: var(--text-soft);
}

.faq-compass {
  display: grid;
  gap: 0.7rem;
  padding: clamp(1.2rem, 2vw, 1.8rem);
}

.faq-compass a,
.brief-hub__nav a {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 0.95rem;
  border-radius: calc(var(--radius-md) - 4px);
  border: 1px solid rgba(121, 227, 255, 0.12);
  background: rgba(255, 255, 255, 0.03);
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out);
}

.faq-compass a:hover,
.brief-hub__nav a:hover,
.brief-hub__nav a.is-active {
  transform: translateY(-2px);
  border-color: rgba(121, 227, 255, 0.28);
  background: rgba(121, 227, 255, 0.08);
}

.faq-compass a span,
.brief-hub__nav a span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  min-height: 2rem;
  border-radius: 999px;
  border: 1px solid rgba(121, 227, 255, 0.18);
  background: rgba(10, 20, 35, 0.8);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.faq-compass a strong,
.brief-hub__nav a strong {
  font-size: 0.95rem;
  letter-spacing: -0.02em;
}

.brief-hub__mast {
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
}

.brief-hub__meta {
  display: grid;
  gap: 0.5rem;
}

.brief-hub__eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0.4rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(121, 227, 255, 0.16);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-soft);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.brief-hub__mast h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.45rem, 3vw, 2.4rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
}

.brief-hub__mast p {
  margin: 0;
  color: var(--text-soft);
}

.brief-hub__nav {
  display: flex;
  gap: 0.65rem;
  overflow-x: auto;
  padding-bottom: 0.2rem;
  scrollbar-width: thin;
}

.brief-hub__nav a {
  flex: 0 0 auto;
  min-width: 220px;
}

main.layout-page .contact-band--form .contact-grid,
main.layout-page .start-band--form .contact-grid {
  display: grid;
  gap: 1rem;
  align-items: start;
}

main.layout-page .home-band--services blockquote,
main.layout-page .home-band--routes .service-detail__punch,
main.layout-page .home-band--decision .route-card h3,
main.layout-page .examples-band--closing blockquote,
main.layout-page .discovery-band--closing blockquote {
  max-width: 14ch;
}

main.layout-page .home-band--values .layout-pill-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75rem;
}

main.layout-page .home-band--values .layout-pill {
  min-height: 100%;
  padding: 0.9rem 1rem;
  border-radius: calc(var(--radius-md) - 4px);
  border: 1px solid rgba(121, 227, 255, 0.12);
  background: rgba(255, 255, 255, 0.03);
}

main.layout-page .home-band--strip .info-strip {
  box-shadow: 0 24px 50px rgba(0, 0, 0, 0.18);
}

main.layout-page .home-band--closing .layout-callout,
main.layout-page .about-band--closing .layout-callout,
main.layout-page .services-band--closing .layout-callout,
main.layout-page .process-band--closing .layout-callout,
main.layout-page .discovery-band--closing .layout-callout,
main.layout-page .faq-band--closing .callout,
main.layout-page .pay-band--closing .callout,
main.layout-page .schedule-band--closing .callout {
  background:
    radial-gradient(circle at top left, rgba(121, 227, 255, 0.14), transparent 34%),
    radial-gradient(circle at bottom right, rgba(255, 177, 132, 0.16), transparent 40%),
    rgba(7, 12, 21, 0.88);
}

main.layout-page .faq-band--closing .callout,
main.layout-page .pay-band--closing .callout,
main.layout-page .schedule-band--closing .callout {
  padding: clamp(1.4rem, 2.2vw, 2rem);
}

@media (min-width: 700px) {
  main.layout-page .route-grid > *,
  main.layout-page .service-detail-grid > *,
  main.layout-page .card-grid > *,
  main.layout-page .study-grid > *,
  main.layout-page .layout-category-grid > * {
    grid-column: span 6;
  }

  main.layout-page .layout-metric-grid > * {
    grid-column: span 6;
  }

  main.layout-page .home-band--decision .home-decision-grid > * {
    grid-column: span 12;
  }

  main.layout-page .home-band--decision .home-decision-grid > *:nth-child(1),
  main.layout-page .home-band--decision .home-decision-grid > *:nth-child(2) {
    grid-column: span 6;
  }

  main.layout-page .home-band--decision .crosslink-grid > * {
    grid-column: span 6;
  }

  main.layout-page .home-band--decision .crosslink-grid > *:last-child {
    grid-column: 1 / -1;
  }

  main.layout-page .process-band--steps .layout-service-mosaic > * {
    grid-column: span 6;
  }

  main.layout-page .schedule-band--prep .service-detail-grid > * {
    grid-column: span 6;
  }

  main.layout-page .schedule-band--prep .service-detail-grid > *:last-child {
    grid-column: 1 / -1;
  }
}

@media (min-width: 960px) {
  main.layout-page .home-band--offers .layout-section__frame,
  main.layout-page .home-band--outcomes .layout-section__frame,
  main.layout-page .home-band--atlas .layout-section__frame,
  main.layout-page .home-band--decision .layout-section__frame,
  main.layout-page .home-band--process .layout-section__frame,
  main.layout-page .home-band--routes .layout-section__frame,
  main.layout-page .services-band--taxonomy .layout-section__frame,
  main.layout-page .services-band--mosaic .layout-section__frame,
  main.layout-page .contact-band--routes .shell,
  main.layout-page .examples-band--principles .shell,
  main.layout-page .start-band--fit .shell,
  main.layout-page .start-band--after .shell,
  main.layout-page .faq-overview,
  main.layout-page .policy-atlas__frame,
  main.layout-page .discovery-band--routes .shell,
  main.layout-page .discovery-band--brief .shell {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  }

  main.layout-page .home-band--offers .layout-section__intro,
  main.layout-page .home-band--outcomes .layout-section__intro,
  main.layout-page .home-band--atlas .layout-section__intro,
  main.layout-page .home-band--decision .layout-section__intro,
  main.layout-page .home-band--process .layout-section__intro,
  main.layout-page .home-band--routes .layout-section__intro,
  main.layout-page .services-band--taxonomy .layout-section__intro,
  main.layout-page .services-band--mosaic .layout-section__intro,
  main.layout-page .contact-band--routes .section-heading,
  main.layout-page .examples-band--principles .section-heading,
  main.layout-page .start-band--fit .section-heading,
  main.layout-page .start-band--after .section-heading,
  main.layout-page .faq-summary,
  main.layout-page .policy-summary,
  main.layout-page .discovery-band--routes .layout-section__intro {
    position: sticky;
    top: 6.5rem;
    align-self: start;
  }

  main.layout-page .crosslink-grid > *,
  main.layout-page .layout-panel-grid > *,
  main.layout-page .layout-panel-grid--offset > *,
  main.layout-page .layout-service-mosaic > *,
  main.layout-page .home-decision-grid > *,
  main.layout-page .layout-step-grid > * {
    grid-column: span 4;
  }

  main.layout-page .layout-metric-grid > * {
    grid-column: span 3;
  }

  main.layout-page .home-band--offers .route-card:nth-child(1) {
    grid-column: span 7;
  }

  main.layout-page .home-band--offers .route-card:nth-child(2) {
    grid-column: span 5;
  }

  main.layout-page .home-band--offers .route-card:nth-child(3) {
    grid-column: 1 / -1;
  }

  main.layout-page .home-band--atlas .crosslink-grid > * {
    grid-column: span 6;
  }

  main.layout-page .home-band--atlas .crosslink-grid > *:nth-child(3n + 1) {
    grid-column: 1 / -1;
  }

  main.layout-page .home-band--outcomes .layout-metric-grid > *:first-child,
  main.layout-page .home-band--outcomes .layout-metric-grid > *:last-child {
    grid-column: span 6;
  }

  main.layout-page .home-band--services .layout-panel-grid > * {
    grid-column: span 6;
  }

  main.layout-page .home-band--services .layout-panel-grid > *:nth-child(3),
  main.layout-page .home-band--services .layout-panel-grid > *:nth-child(4) {
    grid-column: span 3;
  }

  main.layout-page .home-band--process .layout-step-grid > *:nth-child(3n) {
    grid-column: 1 / -1;
  }

  main.layout-page .home-band--decision .crosslink-grid {
    grid-column: 1 / -1;
  }

  main.layout-page .home-band--values .layout-service-mosaic > * {
    grid-column: span 4;
  }

  main.layout-page .home-band--values .layout-service-mosaic > *:nth-child(1),
  main.layout-page .home-band--values .layout-service-mosaic > *:nth-child(6),
  main.layout-page .home-band--values .layout-service-mosaic > *:nth-child(10) {
    grid-column: span 6;
  }

  main.layout-page .home-band--routes .layout-twin-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  main.layout-page .home-band--routes .layout-panel:first-child {
    transform: translateY(-0.7rem);
  }

  main.layout-page .home-band--routes .layout-panel:last-child {
    transform: translateY(0.85rem);
  }

  main.layout-page .services-band--taxonomy .layout-category-grid > * {
    grid-column: span 6;
  }

  main.layout-page .services-band--taxonomy .layout-category:first-child {
    grid-column: 1 / -1;
  }

  main.layout-page .services-band--mosaic .layout-panel:nth-child(1),
  main.layout-page .services-band--mosaic .layout-panel:nth-child(6),
  main.layout-page .services-band--mosaic .layout-panel:nth-child(10) {
    grid-column: span 6;
  }

  main.layout-page .process-band--steps .layout-timeline:nth-child(even) {
    transform: translateY(1rem);
  }

  main.layout-page .process-band--steps .layout-timeline:nth-child(3),
  main.layout-page .process-band--steps .layout-timeline:nth-child(6) {
    grid-column: 1 / -1;
  }

  main.layout-page .contact-band--routes .route-grid > * {
    grid-column: span 6;
  }

  main.layout-page .contact-band--routes .route-card:first-child {
    grid-column: 1 / -1;
  }

  main.layout-page .contact-band--form .contact-grid,
  main.layout-page .start-band--form .contact-grid {
    grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
  }

  main.layout-page .contact-band--form .contact-card,
  main.layout-page .start-band--form .contact-card {
    position: sticky;
    top: 6.5rem;
    align-self: start;
  }

  main.layout-page .examples-band--studies .study-card:first-child {
    grid-column: 1 / -1;
  }

  main.layout-page .examples-band--studies .study-card:nth-child(2),
  main.layout-page .examples-band--studies .study-card:nth-child(3) {
    grid-column: span 6;
  }

  main.layout-page .examples-band--principles .card-grid > * {
    grid-column: span 6;
  }

  main.layout-page .examples-band--principles .card-grid > *:nth-child(1),
  main.layout-page .examples-band--principles .card-grid > *:nth-child(4) {
    grid-column: span 7;
  }

  main.layout-page .faq-band--atlas .faq-shell:nth-child(1),
  main.layout-page .faq-band--atlas .faq-shell:nth-child(6) {
    grid-column: 1 / -1;
  }

  main.layout-page .faq-band--atlas .faq-shell {
    grid-column: span 6;
  }

  main.layout-page .pay-band--overview .service-detail-grid > * {
    grid-column: span 6;
  }

  main.layout-page .pay-band--routes .payment-flow {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(320px, 0.78fr) minmax(0, 1.22fr);
    align-items: start;
  }

  main.layout-page .pay-band--routes .route-grid {
    align-self: start;
  }

  main.layout-page .pay-band--routes .route-card:first-child {
    grid-column: 1 / -1;
  }

  main.layout-page .pay-band--routes .route-card:nth-child(2),
  main.layout-page .pay-band--routes .route-card:nth-child(3) {
    grid-column: span 6;
  }

  main.layout-page .schedule-band--embed .embed-card {
    padding: 1.2rem;
  }

  main.layout-page .discovery-band--routes .layout-twin-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
  }

  main.layout-page .discovery-band--routes .layout-panel:first-child {
    transform: translateY(-0.55rem);
  }

  main.layout-page .discovery-band--routes .layout-panel:last-child {
    transform: translateY(0.8rem);
  }

  main.layout-page .discovery-band--brief .shell {
    align-items: start;
  }

  main.layout-page .discovery-band--brief .layout-section__intro,
  main.layout-page .discovery-band--brief .brief-hub__mast {
    grid-column: 1;
  }

  main.layout-page .discovery-band--brief .stacked-form,
  main.layout-page .discovery-band--brief [data-form-success],
  main.layout-page .discovery-band--brief [data-form-error] {
    grid-column: 2;
  }

  main.layout-page .discovery-band--brief .brief-hub__mast {
    position: sticky;
    top: 6.5rem;
    align-self: start;
  }

  main.layout-page .discovery-band--brief .stacked-form {
    margin-top: 0;
  }

  main.layout-page .brief-hub__nav {
    display: grid;
    max-height: 60vh;
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 0.25rem;
  }

  main.layout-page .brief-hub__nav a {
    min-width: 0;
  }
}

@media (min-width: 1240px) {
  main.layout-page .policy-atlas__cards > * {
    grid-column: span 6;
  }

  main.layout-page .policy-atlas__cards > *:last-child:nth-child(odd) {
    grid-column: 1 / -1;
  }
}

@media (max-width: 959px) {
  main.layout-page {
    gap: 0;
  }

  .faq-compass {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .faq-compass a strong,
  .brief-hub__nav a strong {
    font-size: 0.88rem;
  }
}

@media (max-width: 699px) {
  .faq-compass {
    grid-template-columns: 1fr;
  }

  .brief-hub__nav a {
    min-width: 190px;
  }

  main.layout-page .home-band--routes .layout-panel:first-child,
  main.layout-page .home-band--routes .layout-panel:last-child,
  main.layout-page .discovery-band--routes .layout-panel:first-child,
  main.layout-page .discovery-band--routes .layout-panel:last-child,
  main.layout-page .process-band--steps .layout-timeline:nth-child(even) {
    transform: none;
  }
}

/* Interior standardization pass:
   unify section order with DOM order, tighten the section headings into
   clear intro panels, and smooth the card/form rhythm across all pages. */
body[data-page] main.layout-page {
  gap: clamp(0.45rem, 1vw, 0.9rem);
  padding-bottom: clamp(1rem, 2vw, 1.5rem);
}

body[data-page] main.layout-page > .section {
  order: 0;
  padding-block: clamp(1.55rem, 3.4vw, 3.3rem);
}

body[data-page] main.layout-page > .section.section--flush {
  padding-top: 0.35rem;
}

body[data-page] main.layout-page > .hero-mast {
  padding-top: 0.18rem;
}

body[data-page] main.layout-page .section-heading--panel {
  display: grid;
  gap: 0.85rem;
  margin: 0;
  padding: clamp(1.15rem, 2.3vw, 1.7rem);
  align-content: start;
}

body[data-page] main.layout-page .section-heading--panel .section-mark {
  margin-bottom: 0;
}

body[data-page] main.layout-page .section-heading--panel .eyebrow {
  width: fit-content;
}

body[data-page] main.layout-page .section-heading--panel .section-title,
body[data-page] main.layout-page .section-heading--panel .section-text {
  margin: 0;
}

body[data-page] main.layout-page .section-heading--panel .section-title {
  max-width: 14ch;
}

body[data-page] main.layout-page .section-heading--panel .section-text {
  max-width: 42rem;
}

body[data-page] main.layout-page .contact-band--routes .shell,
body[data-page] main.layout-page .examples-band--studies .shell,
body[data-page] main.layout-page .examples-band--principles .shell,
body[data-page] main.layout-page .start-band--fit .shell,
body[data-page] main.layout-page .start-band--after .shell,
body[data-page] main.layout-page .pay-band--routes .shell {
  display: grid;
  gap: clamp(0.95rem, 2vw, 1.2rem);
}

body[data-page] main.layout-page .layout-section__frame,
body[data-page] main.layout-page .service-detail-grid,
body[data-page] main.layout-page .route-grid,
body[data-page] main.layout-page .card-grid,
body[data-page] main.layout-page .study-grid,
body[data-page] main.layout-page .contact-grid,
body[data-page] main.layout-page .home-decision-grid,
body[data-page] main.layout-page .faq-overview,
body[data-page] main.layout-page .policy-atlas__frame {
  gap: clamp(0.95rem, 2vw, 1.2rem);
}

body[data-page] main.layout-page .layout-section__intro,
body[data-page] main.layout-page .layout-panel,
body[data-page] main.layout-page .layout-metric,
body[data-page] main.layout-page .layout-category,
body[data-page] main.layout-page .layout-timeline,
body[data-page] main.layout-page .layout-callout,
body[data-page] main.layout-page .route-card,
body[data-page] main.layout-page .service-detail,
body[data-page] main.layout-page .card,
body[data-page] main.layout-page .study-card,
body[data-page] main.layout-page .contact-card,
body[data-page] main.layout-page .policy-card,
body[data-page] main.layout-page .faq-shell,
body[data-page] main.layout-page .home-decision-card,
body[data-page] main.layout-page .form-card,
body[data-page] main.layout-page .brief-section,
body[data-page] main.layout-page .embed-card {
  display: grid;
  gap: 0.8rem;
  padding: clamp(1.08rem, 2.2vw, 1.55rem);
}

body[data-page] main.layout-page .layout-callout,
body[data-page] main.layout-page .quote-banner {
  padding: clamp(1.2rem, 2.4vw, 1.8rem);
}

body[data-page] main.layout-page .route-card,
body[data-page] main.layout-page .service-detail,
body[data-page] main.layout-page .card,
body[data-page] main.layout-page .study-card,
body[data-page] main.layout-page .contact-card,
body[data-page] main.layout-page .policy-card,
body[data-page] main.layout-page .faq-shell,
body[data-page] main.layout-page .home-decision-card,
body[data-page] main.layout-page .form-card,
body[data-page] main.layout-page .brief-section,
body[data-page] main.layout-page .embed-card {
  border-radius: calc(var(--radius-xl) - 2px);
}

body[data-page] main.layout-page .route-card p,
body[data-page] main.layout-page .service-detail p,
body[data-page] main.layout-page .card__text,
body[data-page] main.layout-page .study-card__text,
body[data-page] main.layout-page .contact-card p,
body[data-page] main.layout-page .policy-card p,
body[data-page] main.layout-page .layout-panel__text,
body[data-page] main.layout-page .layout-timeline__text,
body[data-page] main.layout-page .brief-section p {
  margin: 0;
}

body[data-page] main.layout-page .study-card__content,
body[data-page] main.layout-page .form-card__head,
body[data-page] main.layout-page .policy-card__body,
body[data-page] main.layout-page .faq-category__head {
  display: grid;
  gap: 0.75rem;
}

body[data-page] main.layout-page .form-card__head,
body[data-page] main.layout-page .faq-category__head {
  margin: 0;
  padding: 0;
}

body[data-page] main.layout-page .form-card__head p,
body[data-page] main.layout-page .faq-category__head p {
  margin: 0;
}

body[data-page] main.layout-page .form-grid,
body[data-page] main.layout-page .brief-section__grid {
  gap: 0.9rem;
}

body[data-page] main.layout-page .policy-card__body > * {
  margin: 0;
}

body[data-page] main.layout-page .policy-card__body h2 {
  padding-top: 0.95rem;
  border-top: 1px solid rgba(121, 227, 255, 0.12);
}

body[data-page] main.layout-page .policy-card__body h2:first-child {
  padding-top: 0;
  border-top: 0;
}

body[data-page] main.layout-page .policy-card__body ul {
  margin: 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.55rem;
}

body[data-page] main.layout-page .faq-list {
  display: grid;
  gap: 0.75rem;
}

body[data-page] main.layout-page .faq-list details {
  padding: 0.95rem 1rem;
  border-radius: 22px;
  border: 1px solid rgba(121, 227, 255, 0.12);
  background: rgba(255, 255, 255, 0.03);
}

body[data-page] main.layout-page .faq-list summary {
  padding-right: 1.8rem;
  font-weight: 700;
  line-height: 1.42;
}

body[data-page] main.layout-page .faq-list details p {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(121, 227, 255, 0.1);
}

body[data-page] main.layout-page .contact-grid,
body[data-page] main.layout-page .payment-flow {
  align-items: start;
}

body[data-page] main.layout-page .route-cloud {
  margin-top: auto;
}

body[data-page] main.layout-page .quote-banner blockquote,
body[data-page] main.layout-page .layout-story-copy blockquote {
  text-wrap: balance;
}

body[data-page] main.layout-page .schedule-embed {
  min-height: clamp(36rem, 66vh, 48rem);
}

body[data-page] main.layout-page .schedule-embed iframe {
  min-height: clamp(36rem, 66vh, 48rem);
}

@media (min-width: 980px) {
  body[data-page] main.layout-page .contact-band--routes .shell,
  body[data-page] main.layout-page .examples-band--studies .shell,
  body[data-page] main.layout-page .examples-band--principles .shell,
  body[data-page] main.layout-page .start-band--fit .shell,
  body[data-page] main.layout-page .start-band--after .shell,
  body[data-page] main.layout-page .pay-band--routes .shell {
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
    align-items: start;
  }

  body[data-page] main.layout-page .section-heading--panel {
    position: sticky;
    top: 6.45rem;
    align-self: start;
  }

  body[data-page] main.layout-page .examples-band--studies .study-grid {
    grid-column: 2;
  }

  body[data-page] main.layout-page .examples-band--principles .card-grid,
  body[data-page] main.layout-page .contact-band--routes .route-grid,
  body[data-page] main.layout-page .start-band--fit .card-grid,
  body[data-page] main.layout-page .start-band--after .card-grid,
  body[data-page] main.layout-page .pay-band--routes .payment-flow {
    grid-column: 2;
  }
}

@media (max-width: 759px) {
  body[data-page] main.layout-page > .section {
    padding-block: clamp(1.35rem, 5.4vw, 1.9rem);
  }

  body[data-page] main.layout-page .section-heading--panel,
  body[data-page] main.layout-page .layout-section__intro,
  body[data-page] main.layout-page .layout-panel,
  body[data-page] main.layout-page .layout-metric,
  body[data-page] main.layout-page .layout-category,
  body[data-page] main.layout-page .layout-timeline,
  body[data-page] main.layout-page .layout-callout,
  body[data-page] main.layout-page .route-card,
  body[data-page] main.layout-page .service-detail,
  body[data-page] main.layout-page .card,
  body[data-page] main.layout-page .study-card,
  body[data-page] main.layout-page .contact-card,
  body[data-page] main.layout-page .policy-card,
  body[data-page] main.layout-page .faq-shell,
  body[data-page] main.layout-page .home-decision-card,
  body[data-page] main.layout-page .form-card,
  body[data-page] main.layout-page .brief-section,
  body[data-page] main.layout-page .embed-card {
    padding: 1rem;
  }

  body[data-page] main.layout-page .schedule-embed,
  body[data-page] main.layout-page .schedule-embed iframe {
    min-height: 34rem;
  }
}

/* Editorial launch-system override:
   this layer intentionally wins over the previous page-body rules and
   re-casts the site into a more dramatic editorial space-launch language
   without touching the shared header, footer, or floating widgets. */

@keyframes editorialOrbit {
  0%,
  100% {
    transform: rotate(0deg) scale(1);
    opacity: 0.62;
  }
  50% {
    transform: rotate(8deg) scale(1.03);
    opacity: 1;
  }
}

@keyframes editorialSweep {
  0% {
    transform: translate3d(-8%, 0, 0) rotate(-10deg);
    opacity: 0.08;
  }
  50% {
    opacity: 0.2;
  }
  100% {
    transform: translate3d(8%, 0, 0) rotate(-10deg);
    opacity: 0.08;
  }
}

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

body[data-page] {
  --page-aura-a: rgba(46, 108, 255, 0.16);
  --page-aura-b: rgba(121, 227, 255, 0.14);
  background:
    radial-gradient(circle at 16% 10%, rgba(58, 116, 255, 0.16), transparent 24%),
    radial-gradient(circle at 84% 12%, rgba(121, 227, 255, 0.12), transparent 22%),
    radial-gradient(circle at 50% 48%, rgba(104, 196, 255, 0.11), transparent 18%),
    radial-gradient(circle at 50% 112%, rgba(40, 87, 182, 0.16), transparent 28%),
    linear-gradient(180deg, #02050d 0%, #06101d 16%, #0b1f42 32%, #1a558a 50%, #0b1f42 68%, #06101d 84%, #02050d 100%);
}

body[data-page] .site-stage {
  background:
    radial-gradient(circle at 16% 16%, rgba(58, 116, 255, 0.12), transparent 22%),
    radial-gradient(circle at 84% 14%, rgba(121, 227, 255, 0.1), transparent 24%),
    radial-gradient(circle at 50% 54%, rgba(90, 165, 255, 0.08), transparent 26%);
}

body[data-page] .site-stage::before,
body[data-page] .site-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

body[data-page] .site-stage::before {
  background:
    radial-gradient(circle at 12% 22%, rgba(255, 255, 255, 0.38) 0 1px, transparent 1.4px),
    radial-gradient(circle at 34% 18%, rgba(255, 255, 255, 0.3) 0 1px, transparent 1.5px),
    radial-gradient(circle at 52% 28%, rgba(255, 255, 255, 0.32) 0 1px, transparent 1.4px),
    radial-gradient(circle at 78% 16%, rgba(255, 255, 255, 0.26) 0 1px, transparent 1.5px),
    radial-gradient(circle at 86% 34%, rgba(255, 255, 255, 0.22) 0 1px, transparent 1.6px),
    radial-gradient(circle at 66% 10%, rgba(255, 255, 255, 0.26) 0 1px, transparent 1.5px),
    radial-gradient(circle at 24% 38%, rgba(255, 255, 255, 0.22) 0 1px, transparent 1.6px);
  opacity: 0.72;
}

body[data-page] .site-stage::after {
  background:
    linear-gradient(116deg, transparent 0%, rgba(114, 204, 255, 0.12) 34%, transparent 52%),
    radial-gradient(circle at 52% 72%, rgba(58, 116, 255, 0.1), transparent 28%);
  filter: blur(34px);
  animation: editorialSweep 22s ease-in-out infinite alternate;
  opacity: 0.9;
}

body[data-page] .site-stage__grid {
  opacity: 0.28;
  background-size: 88px 88px;
  mask-image: radial-gradient(circle at center, rgba(0, 0, 0, 0.92), transparent 84%);
}

body[data-page] .site-stage__noise {
  opacity: 0.14;
  background:
    linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.03) 14%, transparent 28%),
    linear-gradient(transparent 0%, rgba(255, 255, 255, 0.018) 50%, transparent 100%);
}

body[data-page] main.layout-page {
  --editorial-text: #f3f7ff;
  --editorial-soft: rgba(243, 247, 255, 0.76);
  --editorial-muted: rgba(243, 247, 255, 0.48);
  --editorial-line: rgba(138, 170, 255, 0.14);
  --editorial-line-strong: rgba(149, 228, 255, 0.3);
  --editorial-panel: rgba(5, 9, 18, 0.7);
  --editorial-panel-strong: rgba(6, 10, 20, 0.86);
  --editorial-cold: #91e7ff;
  --editorial-cold-strong: #6f84ff;
  --editorial-hot: #ff935f;
  --editorial-hot-soft: rgba(255, 147, 95, 0.22);
  --editorial-shadow: 0 30px 90px rgba(0, 0, 0, 0.34);
  position: relative;
  overflow: clip;
  isolation: isolate;
  counter-reset: editorial-section;
}

body[data-page] main.layout-page::before,
body[data-page] main.layout-page::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

body[data-page] main.layout-page::before {
  background:
    radial-gradient(circle at 50% 0%, rgba(92, 123, 255, 0.08), transparent 22%),
    radial-gradient(circle at 50% 100%, rgba(58, 116, 255, 0.08), transparent 24%);
  opacity: 0.92;
}

body[data-page] main.layout-page::after {
  inset: 4rem auto auto 56%;
  width: min(56vw, 920px);
  height: min(120vh, 1280px);
  border-radius: 999px;
  border: 1px solid rgba(139, 172, 255, 0.12);
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.03), transparent 58%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.015), transparent);
  transform: rotate(-18deg);
  opacity: 0.55;
  filter: blur(0.2px);
  animation: editorialOrbit 26s ease-in-out infinite;
}

body[data-page] main.layout-page > * {
  position: relative;
  z-index: 1;
}

body[data-page] main.layout-page .shell {
  width: min(1440px, calc(100% - clamp(1.4rem, 4vw, 4rem)));
}

body[data-page] main.layout-page > .section {
  position: relative;
  padding-block: clamp(4rem, 8vw, 8rem);
  counter-increment: editorial-section;
}

body[data-page] main.layout-page > .section::before {
  content: "";
  position: absolute;
  left: clamp(1rem, 4vw, 3rem);
  right: clamp(1rem, 4vw, 3rem);
  top: 0;
  height: 1px;
  background:
    linear-gradient(90deg, transparent, rgba(149, 228, 255, 0.24), rgba(58, 116, 255, 0.22), rgba(149, 228, 255, 0.12), transparent);
  opacity: 0.9;
}

body[data-page] main.layout-page > .section::after {
  content: counter(editorial-section, decimal-leading-zero);
  position: absolute;
  top: clamp(0.9rem, 1.5vw, 1.3rem);
  right: clamp(1rem, 4vw, 3rem);
  color: rgba(243, 247, 255, 0.055);
  font-family: var(--font-mono);
  font-size: clamp(2.8rem, 8vw, 7rem);
  line-height: 1;
  letter-spacing: -0.08em;
  pointer-events: none;
}

body[data-page] main.layout-page .surface {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--editorial-line);
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
    linear-gradient(180deg, rgba(6, 11, 22, 0.9), rgba(4, 8, 16, 0.76));
  box-shadow: var(--editorial-shadow);
  backdrop-filter: blur(18px);
}

body[data-page] main.layout-page .surface::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 14%, rgba(111, 132, 255, 0.12), transparent 32%),
    radial-gradient(circle at 88% 18%, rgba(121, 227, 255, 0.1), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 26%);
  pointer-events: none;
}

body[data-page] main.layout-page .layout-section__intro,
body[data-page] main.layout-page .section-heading--panel,
body[data-page] main.layout-page .faq-summary,
body[data-page] main.layout-page .policy-summary {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  overflow: visible;
}

body[data-page] main.layout-page .layout-section__intro::before,
body[data-page] main.layout-page .section-heading--panel::before,
body[data-page] main.layout-page .faq-summary::before,
body[data-page] main.layout-page .policy-summary::before {
  display: none;
}

body[data-page] main.layout-page .layout-section__intro,
body[data-page] main.layout-page .section-heading--panel,
body[data-page] main.layout-page .faq-summary,
body[data-page] main.layout-page .policy-summary,
body[data-page] main.layout-page .brief-hub__mast {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body[data-page] main.layout-page .layout-section__kicker,
body[data-page] main.layout-page .hero-mast__eyebrow,
body[data-page] main.layout-page .eyebrow,
body[data-page] main.layout-page .route-card__label,
body[data-page] main.layout-page .layout-panel__index,
body[data-page] main.layout-page .layout-metric__label,
body[data-page] main.layout-page .layout-timeline__step,
body[data-page] main.layout-page .service-detail__index,
body[data-page] main.layout-page .brief-hub__eyebrow,
body[data-page] main.layout-page .tag {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  width: fit-content;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: none;
  color: var(--editorial-soft);
  font-family: var(--font-mono);
  font-size: 0.73rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

body[data-page] main.layout-page .layout-section__kicker::before,
body[data-page] main.layout-page .hero-mast__eyebrow::before,
body[data-page] main.layout-page .eyebrow::before,
body[data-page] main.layout-page .route-card__label::before,
body[data-page] main.layout-page .layout-panel__index::before,
body[data-page] main.layout-page .layout-metric__label::before,
body[data-page] main.layout-page .layout-timeline__step::before,
body[data-page] main.layout-page .service-detail__index::before,
body[data-page] main.layout-page .brief-hub__eyebrow::before,
body[data-page] main.layout-page .tag::before {
  content: "";
  width: 1.8rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(149, 228, 255, 0.8), rgba(255, 147, 95, 0.08));
  box-shadow: 0 0 18px rgba(145, 231, 255, 0.22);
}

body[data-page] main.layout-page .layout-section__title,
body[data-page] main.layout-page .section-title,
body[data-page] main.layout-page .hero-mast__title,
body[data-page] main.layout-page .callout__title,
body[data-page] main.layout-page .policy-hero__title,
body[data-page] main.layout-page .quote-banner blockquote,
body[data-page] main.layout-page .layout-highlight blockquote,
body[data-page] main.layout-page .layout-callout blockquote {
  margin: 0;
  color: var(--editorial-text);
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 0.94;
  letter-spacing: -0.065em;
  text-wrap: balance;
}

body[data-page] main.layout-page .layout-section__title,
body[data-page] main.layout-page .section-title {
  max-width: 12ch;
  font-size: clamp(2.4rem, 6vw, 5.2rem);
}

body[data-page] main.layout-page .hero-mast__title {
  max-width: 7.2ch;
  font-size: clamp(3.6rem, 11vw, 8.8rem);
}

body[data-page] main.layout-page .quote-banner blockquote,
body[data-page] main.layout-page .layout-highlight blockquote,
body[data-page] main.layout-page .layout-callout blockquote {
  max-width: 12ch;
  font-size: clamp(2.8rem, 8vw, 6.5rem);
}

body[data-page] main.layout-page .layout-section__body,
body[data-page] main.layout-page .section-text,
body[data-page] main.layout-page .hero-mast__lede,
body[data-page] main.layout-page .layout-callout__text,
body[data-page] main.layout-page .policy-summary__note,
body[data-page] main.layout-page .brief-hub__mast p,
body[data-page] main.layout-page .media-caption,
body[data-page] main.layout-page .layout-caption {
  margin: 0;
  max-width: 40rem;
  color: var(--editorial-soft);
  font-size: clamp(1.02rem, 1.6vw, 1.14rem);
  line-height: 1.76;
}

body[data-page] main.layout-page .hero-mast__lede {
  max-width: 35rem;
  padding-left: 1rem;
  border-left: 1px solid rgba(149, 228, 255, 0.16);
}

body[data-page] main.layout-page .page-hero__punch,
body[data-page] main.layout-page .hero-mast__punch,
body[data-page] main.layout-page .service-detail__punch {
  margin: 0;
  color: var(--editorial-text);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

body[data-page] main.layout-page .layout-actions,
body[data-page] main.layout-page .hero-mast__actions,
body[data-page] main.layout-page .hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

body[data-page] main.layout-page .button {
  min-height: 56px;
  padding: 0.9rem 1.35rem;
  border-radius: 999px;
  font-size: 0.94rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}

body[data-page] main.layout-page .button--primary {
  color: #081018;
  background: linear-gradient(135deg, #ff9a62 0%, #ffc67a 52%, #b9f6ff 100%);
  border-color: rgba(255, 189, 120, 0.38);
  box-shadow: 0 18px 44px rgba(255, 147, 95, 0.18);
}

body[data-page] main.layout-page .button--secondary {
  color: var(--editorial-text);
  border-color: rgba(149, 228, 255, 0.22);
  background: rgba(255, 255, 255, 0.032);
}

body[data-page] main.layout-page .button--secondary:hover,
body[data-page] main.layout-page .button--secondary:focus-visible {
  border-color: rgba(149, 228, 255, 0.36);
  background: rgba(255, 255, 255, 0.065);
}

body[data-page] main.layout-page .button--subtle {
  color: var(--editorial-soft);
  border-color: rgba(149, 228, 255, 0.12);
  background: rgba(12, 23, 44, 0.42);
}

body[data-page] main.layout-page .route-card .button--subtle,
body[data-page] main.layout-page .layout-panel .button--subtle {
  border-color: rgba(149, 228, 255, 0.18);
  background: rgba(255, 255, 255, 0.032);
}

body[data-page] main.layout-page .button--block {
  width: fit-content;
}

body[data-page] main.layout-page .hero-mast__shell {
  width: min(1440px, calc(100% - clamp(1.4rem, 4vw, 4rem)));
  margin: 0 auto;
}

body[data-page] main.layout-page .hero-mast__frame {
  min-height: clamp(34rem, 78vh, 56rem);
  padding: clamp(1.2rem, 2vw, 2rem);
  border-radius: 42px;
  background:
    radial-gradient(circle at 20% 18%, rgba(111, 132, 255, 0.15), transparent 28%),
    radial-gradient(circle at 78% 18%, rgba(255, 147, 95, 0.12), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
    linear-gradient(180deg, rgba(8, 13, 24, 0.96), rgba(4, 8, 16, 0.9));
}

body[data-page] main.layout-page .hero-mast__frame::after {
  content: "";
  position: absolute;
  inset: auto -10% -28% 46%;
  height: 62%;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 50%, rgba(255, 147, 95, 0.25), transparent 22%),
    radial-gradient(circle at 48% 50%, rgba(149, 228, 255, 0.1), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent);
  filter: blur(36px);
  transform: rotate(-16deg);
  opacity: 0.9;
  pointer-events: none;
}

body[data-page] main.layout-page .hero-mast__layout {
  display: grid;
  gap: clamp(1.2rem, 2vw, 2rem);
  min-height: 100%;
  align-items: end;
}

body[data-page] main.layout-page .hero-mast__copy,
body[data-page] main.layout-page .hero-mast__stage {
  min-width: 0;
}

body[data-page] main.layout-page .hero-mast__copy {
  display: grid;
  align-content: end;
  gap: 1rem;
  width: auto;
  max-width: none;
  min-height: 0;
  padding: clamp(0.5rem, 1.4vw, 1.1rem);
  position: relative;
  z-index: 1;
}

body[data-page] main.layout-page .hero-mast__stage {
  display: grid;
  gap: 1rem;
  align-content: stretch;
  padding: clamp(0.2rem, 1vw, 0.6rem);
  position: relative;
  inset: auto;
  min-height: clamp(22rem, 42vw, 40rem);
  align-items: stretch;
  overflow: hidden;
  z-index: 1;
  pointer-events: auto;
}

body[data-page] main.layout-page .hero-mast__card,
body[data-page] main.layout-page .hero-mast__panel,
body[data-page] main.layout-page .hero-mast__signal,
body[data-page] main.layout-page .hero-mast__stat,
body[data-page] main.layout-page .hero-mast__lane,
body[data-page] main.layout-page .hero-mast__tile,
body[data-page] main.layout-page .hero-mast__topic,
body[data-page] main.layout-page .hero-mast__legal-item {
  padding: 1rem 1.1rem;
  border: 1px solid rgba(149, 228, 255, 0.14);
  border-top-color: rgba(149, 228, 255, 0.3);
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
    rgba(6, 11, 22, 0.72);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.2);
}

body[data-page] main.layout-page .hero-mast__card {
  justify-items: start;
  gap: 0.85rem;
}

body[data-page] main.layout-page .hero-mast__signal-grid,
body[data-page] main.layout-page .hero-mast__stat-grid,
body[data-page] main.layout-page .hero-mast__lane-grid,
body[data-page] main.layout-page .hero-mast__topic-grid,
body[data-page] main.layout-page .hero-mast__legal-grid {
  display: grid;
  gap: 0.9rem;
}

body[data-page] main.layout-page .hero-mast__signal strong,
body[data-page] main.layout-page .hero-mast__stat strong,
body[data-page] main.layout-page .hero-mast__lane strong,
body[data-page] main.layout-page .hero-mast__topic strong {
  display: block;
  margin-bottom: 0.45rem;
  color: var(--editorial-text);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

body[data-page] main.layout-page .hero-mast__signal span,
body[data-page] main.layout-page .hero-mast__stat span,
body[data-page] main.layout-page .hero-mast__lane span,
body[data-page] main.layout-page .hero-mast__topic span,
body[data-page] main.layout-page .hero-mast__legal-item span,
body[data-page] main.layout-page .hero-mast__card p,
body[data-page] main.layout-page .hero-mast__panel p {
  color: var(--editorial-soft);
  line-height: 1.62;
}

body[data-page="home"] main.layout-page .hero-mast__copy {
  padding-right: clamp(1rem, 2vw, 1.6rem);
}

body[data-page="home"] main.layout-page .hero-mast__title {
  max-width: 100%;
  font-size: clamp(4.4rem, 6.4vw, 5.9rem);
  line-height: 0.92;
  text-wrap: balance;
}

body[data-page="home"] main.layout-page .hero-mast__card,
body[data-page="home"] main.layout-page .hero-mast__signal-grid {
  display: none;
}

body[data-page="home"] main.layout-page .hero-mast__media {
  min-height: clamp(24rem, 44vw, 38rem);
}

body[data-page] main.layout-page .hero-mast__logo,
body[data-page] main.layout-page .layout-mark,
body[data-page] main.layout-page .section-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 76px;
  height: 76px;
  padding: 0.45rem;
  border-radius: 24px;
  border: 1px solid rgba(149, 228, 255, 0.18);
  background:
    linear-gradient(145deg, rgba(111, 132, 255, 0.16), rgba(255, 147, 95, 0.12)),
    rgba(8, 15, 29, 0.88);
  box-shadow: 0 20px 50px rgba(18, 29, 62, 0.24);
}

body[data-page] main.layout-page .hero-mast__logo img,
body[data-page] main.layout-page .layout-mark img,
body[data-page] main.layout-page .section-mark img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 18px;
}

body[data-page] main.layout-page .hero-mast__chip-row,
body[data-page] main.layout-page .hero-mast__route-row,
body[data-page] main.layout-page .hero-mast__meta-row,
body[data-page] main.layout-page .layout-pill-list,
body[data-page] main.layout-page .layout-signal-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page] main.layout-page .hero-mast__chip,
body[data-page] main.layout-page .hero-mast__route,
body[data-page] main.layout-page .layout-pill,
body[data-page] main.layout-page .layout-signal {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0.55rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(149, 228, 255, 0.14);
  background: rgba(255, 255, 255, 0.035);
  color: var(--editorial-soft);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

body[data-page] main.layout-page .hero-mast__media,
body[data-page] main.layout-page .media-frame,
body[data-page] main.layout-page .image-frame,
body[data-page] main.layout-page .video-frame,
body[data-page] main.layout-page .scene__window {
  position: relative;
  overflow: hidden;
  border-radius: 34px;
  border: 1px solid rgba(149, 228, 255, 0.16);
  background:
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.05), transparent 28%),
    linear-gradient(180deg, rgba(7, 13, 24, 0.76), rgba(4, 8, 16, 0.96)),
    #04070d;
}

body[data-page] main.layout-page .hero-mast__media {
  min-height: clamp(18rem, 38vw, 39rem);
  position: relative;
  inset: auto;
}

body[data-page] main.layout-page .hero-mast__media::after,
body[data-page] main.layout-page .media-frame::after,
body[data-page] main.layout-page .image-frame::after,
body[data-page] main.layout-page .video-frame::after,
body[data-page] main.layout-page .scene__window::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 86%, rgba(255, 147, 95, 0.28), transparent 18%),
    linear-gradient(180deg, rgba(6, 9, 14, 0.08), rgba(6, 9, 14, 0.78) 84%);
  pointer-events: none;
}

body[data-page] main.layout-page .hero-mast__media img,
body[data-page] main.layout-page .hero-mast__media video,
body[data-page] main.layout-page .media-frame img,
body[data-page] main.layout-page .image-frame img,
body[data-page] main.layout-page .video-frame img,
body[data-page] main.layout-page .video-frame video,
body[data-page] main.layout-page .study-card img,
body[data-page] main.layout-page .visual-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.8) contrast(1.08) brightness(0.84);
}

body[data-page] main.layout-page .hero-mast__backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 24%, rgba(120, 227, 255, 0.12), transparent 22%),
    radial-gradient(circle at 82% 76%, rgba(255, 156, 104, 0.12), transparent 20%),
    linear-gradient(130deg, rgba(4, 8, 16, 0.38), rgba(4, 8, 16, 0.08) 42%, rgba(4, 8, 16, 0.44));
  pointer-events: none;
}

body[data-page] main.layout-page .hero-mast__visual {
  position: relative;
  min-height: inherit;
  isolation: isolate;
}

body[data-page] main.layout-page .hero-mast__media--cinematic {
  position: absolute;
  inset: 0;
  min-height: 100%;
  border-radius: 34px;
}

body[data-page] main.layout-page .hero-mast__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}

body[data-page] main.layout-page .hero-mast__overlay--grid {
  background:
    linear-gradient(rgba(142, 228, 255, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(142, 228, 255, 0.06) 1px, transparent 1px);
  background-size: 88px 88px;
  mask-image: linear-gradient(180deg, transparent 0, black 16%, black 72%, transparent 100%);
}

body[data-page] main.layout-page .hero-mast__overlay--glow {
  background:
    radial-gradient(circle at 22% 30%, rgba(125, 228, 255, 0.16), transparent 16%),
    radial-gradient(circle at 74% 72%, rgba(255, 161, 112, 0.12), transparent 18%);
}

body[data-page] main.layout-page .hero-mast__route-line {
  position: absolute;
  left: clamp(1rem, 2vw, 1.6rem);
  bottom: clamp(1.2rem, 2vw, 1.8rem);
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  background: rgba(5, 12, 23, 0.78);
  border: 1px solid rgba(149, 228, 255, 0.18);
  z-index: 4;
}

body[data-page] main.layout-page .hero-mast__route-line::before {
  content: "";
  width: 3.6rem;
  height: 0.24rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(149, 228, 255, 0.92), rgba(255, 159, 112, 0.95));
  box-shadow: 0 0 16px rgba(121, 227, 255, 0.24);
}

body[data-page] main.layout-page .hero-mast__route-line span,
body[data-page] main.layout-page .hero-mast__badge,
body[data-page] main.layout-page .hero-mast__stat-card strong,
body[data-page] main.layout-page .hero-mast__stat-card span,
body[data-page] main.layout-page .section-visual__label {
  font-family: var(--font-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

body[data-page] main.layout-page .hero-mast__route-line span,
body[data-page] main.layout-page .hero-mast__badge {
  font-size: 0.72rem;
  color: var(--editorial-text);
}

body[data-page] main.layout-page .hero-mast__badge {
  position: absolute;
  top: clamp(1rem, 2vw, 1.6rem);
  right: clamp(1rem, 2vw, 1.6rem);
  padding: 0.7rem 0.95rem;
  border-radius: 999px;
  background: rgba(8, 17, 29, 0.84);
  border: 1px solid rgba(149, 228, 255, 0.18);
  z-index: 4;
}

body[data-page] main.layout-page .hero-mast__chip-row--hero {
  position: absolute;
  top: clamp(1rem, 2vw, 1.6rem);
  left: clamp(1rem, 2vw, 1.6rem);
  width: min(24rem, calc(100% - 11rem));
  z-index: 4;
}

body[data-page] main.layout-page .hero-mast__stats {
  position: absolute;
  right: clamp(1rem, 2vw, 1.6rem);
  bottom: clamp(4.6rem, 7vw, 6rem);
  display: grid;
  gap: 0.8rem;
  width: min(17rem, calc(100% - 2rem));
  z-index: 4;
}

body[data-page] main.layout-page .hero-mast__stat-card {
  display: grid;
  gap: 0.35rem;
  padding: 0.95rem 1rem;
  border-radius: 22px;
  background: rgba(7, 14, 26, 0.78);
  border: 1px solid rgba(149, 228, 255, 0.16);
  backdrop-filter: blur(14px);
}

body[data-page] main.layout-page .hero-mast__stat-card strong {
  font-size: 0.68rem;
  color: var(--editorial-text);
}

body[data-page] main.layout-page .hero-mast__stat-card span {
  font-size: 0.7rem;
  color: var(--editorial-soft);
}

body[data-page] main.layout-page .section-visual {
  position: relative;
  margin: -0.3rem -0.3rem 1rem;
  min-height: 8rem;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(149, 228, 255, 0.14);
  background: rgba(4, 10, 18, 0.72);
}

body[data-page] main.layout-page .section-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.85) contrast(1.05) brightness(0.88);
}

body[data-page] main.layout-page .section-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(4, 8, 16, 0.12), rgba(4, 8, 16, 0.72)),
    linear-gradient(90deg, rgba(4, 8, 16, 0.46), rgba(4, 8, 16, 0.06));
}

body[data-page] main.layout-page .section-visual__label {
  position: absolute;
  left: 1rem;
  bottom: 0.95rem;
  z-index: 2;
  padding: 0.46rem 0.7rem;
  border-radius: 999px;
  background: rgba(7, 15, 28, 0.8);
  border: 1px solid rgba(149, 228, 255, 0.16);
  font-size: 0.64rem;
  color: var(--editorial-text);
}

body[data-page] main.layout-page .surface-arrow {
  position: absolute;
  right: 0.9rem;
  top: 0.9rem;
  width: 6rem;
  opacity: 0.82;
  pointer-events: none;
}

body[data-page] main.layout-page .surface-arrow img {
  width: 100%;
  height: auto;
  display: block;
}

body[data-page] main.layout-page .hero-mast__orbital {
  min-height: clamp(18rem, 40vw, 34rem);
  border-radius: 38px;
  border: 1px solid rgba(149, 228, 255, 0.14);
  background:
    radial-gradient(circle at 50% 50%, rgba(149, 228, 255, 0.08), transparent 16%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
    rgba(5, 10, 18, 0.82);
}

body[data-page] main.layout-page .hero-mast__orbital::before,
body[data-page] main.layout-page .hero-mast__orbital::after,
body[data-page] main.layout-page .hero-mast__ring {
  border-color: rgba(149, 228, 255, 0.18);
}

body[data-page] main.layout-page .hero-mast__node {
  box-shadow: 0 0 20px rgba(145, 231, 255, 0.56);
  animation: editorialRise 6s ease-in-out infinite;
}

body[data-page] main.layout-page .hero-mast__node--c {
  background: linear-gradient(135deg, #ff8d63, #ff6a58);
}

body[data-page] main.layout-page .hero-mast__note {
  width: min(17rem, calc(100% - 2rem));
  padding: 0.9rem 1rem;
  border-radius: 20px;
  border: 1px solid rgba(149, 228, 255, 0.14);
  background: rgba(8, 13, 24, 0.8);
  backdrop-filter: blur(16px);
}

body[data-page] main.layout-page .crosslink-grid,
body[data-page] main.layout-page .layout-metric-grid,
body[data-page] main.layout-page .layout-panel-grid,
body[data-page] main.layout-page .layout-panel-grid--offset,
body[data-page] main.layout-page .layout-service-mosaic,
body[data-page] main.layout-page .layout-category-grid,
body[data-page] main.layout-page .home-decision-grid,
body[data-page] main.layout-page .route-grid,
body[data-page] main.layout-page .service-detail-grid,
body[data-page] main.layout-page .card-grid,
body[data-page] main.layout-page .study-grid,
body[data-page] main.layout-page .layout-step-grid,
body[data-page] main.layout-page .layout-proof-grid {
  display: grid;
  gap: clamp(1rem, 1.6vw, 1.6rem);
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow: dense;
}

body[data-page] main.layout-page .crosslink-grid > *,
body[data-page] main.layout-page .layout-metric-grid > *,
body[data-page] main.layout-page .layout-panel-grid > *,
body[data-page] main.layout-page .layout-panel-grid--offset > *,
body[data-page] main.layout-page .layout-service-mosaic > *,
body[data-page] main.layout-page .layout-category-grid > *,
body[data-page] main.layout-page .home-decision-grid > *,
body[data-page] main.layout-page .route-grid > *,
body[data-page] main.layout-page .service-detail-grid > *,
body[data-page] main.layout-page .card-grid > *,
body[data-page] main.layout-page .study-grid > *,
body[data-page] main.layout-page .layout-step-grid > *,
body[data-page] main.layout-page .layout-proof-grid > * {
  grid-column: 1 / -1;
  min-width: 0;
}

body[data-page] main.layout-page .route-card,
body[data-page] main.layout-page .layout-panel,
body[data-page] main.layout-page .layout-metric,
body[data-page] main.layout-page .layout-timeline,
body[data-page] main.layout-page .card,
body[data-page] main.layout-page .service-detail,
body[data-page] main.layout-page .policy-card,
body[data-page] main.layout-page .faq-shell,
body[data-page] main.layout-page .contact-card,
body[data-page] main.layout-page .form-card,
body[data-page] main.layout-page .study-card,
body[data-page] main.layout-page .quote-banner,
body[data-page] main.layout-page .callout,
body[data-page] main.layout-page .layout-callout,
body[data-page] main.layout-page .layout-highlight,
body[data-page] main.layout-page .brief-hub__mast,
body[data-page] main.layout-page .embed-card,
body[data-page] main.layout-page .brief-section {
  padding: clamp(1.2rem, 2vw, 2rem);
  border-radius: 34px;
}

body[data-page] main.layout-page .route-card,
body[data-page] main.layout-page .layout-panel,
body[data-page] main.layout-page .layout-metric,
body[data-page] main.layout-page .layout-timeline,
body[data-page] main.layout-page .card,
body[data-page] main.layout-page .service-detail {
  border-top-color: rgba(149, 228, 255, 0.28);
}

body[data-page] main.layout-page .layout-panel,
body[data-page] main.layout-page .layout-metric,
body[data-page] main.layout-page .layout-timeline,
body[data-page] main.layout-page .route-card,
body[data-page] main.layout-page .service-detail,
body[data-page] main.layout-page .card {
  display: grid;
  align-content: start;
  gap: 0.8rem;
}

body[data-page] main.layout-page .study-card {
  display: grid;
  gap: 1.2rem;
}

body[data-page] main.layout-page .study-card__content {
  margin-top: 0;
}

body[data-page] main.layout-page .card__title,
body[data-page] main.layout-page .study-card__title,
body[data-page] main.layout-page .contact-card__title,
body[data-page] main.layout-page .policy-card__title,
body[data-page] main.layout-page .faq-shell__title,
body[data-page] main.layout-page .route-card h3,
body[data-page] main.layout-page .service-detail h3,
body[data-page] main.layout-page .layout-panel__title,
body[data-page] main.layout-page .layout-timeline h3,
body[data-page] main.layout-page .layout-category h3 {
  margin: 0;
  color: var(--editorial-text);
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
  text-wrap: balance;
}

body[data-page] main.layout-page .card__text,
body[data-page] main.layout-page .study-card__text,
body[data-page] main.layout-page .contact-card__text,
body[data-page] main.layout-page .policy-card__text,
body[data-page] main.layout-page .route-card p,
body[data-page] main.layout-page .service-detail p,
body[data-page] main.layout-page .layout-panel__text,
body[data-page] main.layout-page .layout-timeline__text,
body[data-page] main.layout-page .layout-metric__value,
body[data-page] main.layout-page .layout-category p,
body[data-page] main.layout-page .quote-banner p {
  margin: 0;
  color: var(--editorial-soft);
  line-height: 1.68;
}

body[data-page] main.layout-page .layout-metric__value {
  font-size: clamp(1.05rem, 1.5vw, 1.18rem);
  font-weight: 700;
}

body[data-page] main.layout-page .card__icon,
body[data-page] main.layout-page .phase-card__number {
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 18px;
  border: 1px solid rgba(149, 228, 255, 0.18);
  background:
    linear-gradient(145deg, rgba(111, 132, 255, 0.12), rgba(255, 147, 95, 0.08)),
    rgba(8, 14, 26, 0.9);
  color: var(--editorial-text);
}

body[data-page] main.layout-page .layout-inline-list,
body[data-page] main.layout-page .check-list,
body[data-page] main.layout-page .detail-list,
body[data-page] main.layout-page .layout-bullet-list {
  display: grid;
  gap: 0.75rem;
}

body[data-page] main.layout-page .layout-inline-list {
  padding-left: 0;
  list-style: none;
}

body[data-page] main.layout-page .layout-inline-list li,
body[data-page] main.layout-page .check-list li,
body[data-page] main.layout-page .detail-list li,
body[data-page] main.layout-page .layout-bullet-list li {
  color: var(--editorial-soft);
}

body[data-page] main.layout-page .layout-inline-list li {
  padding: 0.95rem 1.05rem;
  border: 1px solid rgba(149, 228, 255, 0.12);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.028);
}

body[data-page] main.layout-page .check-list li::before,
body[data-page] main.layout-page .icon-list li::before,
body[data-page] main.layout-page .detail-list li::before {
  width: 0.62rem;
  height: 0.62rem;
  margin-top: 0.55rem;
  background: linear-gradient(135deg, var(--editorial-cold), var(--editorial-hot));
  box-shadow: 0 0 18px rgba(145, 231, 255, 0.32);
}

body[data-page] main.layout-page .quote-banner {
  gap: 1.2rem;
  padding: clamp(1.5rem, 2.4vw, 2.3rem);
}

body[data-page] main.layout-page .quote-banner p {
  max-width: 34rem;
}

body[data-page] main.layout-page .faq-list details {
  border-color: rgba(149, 228, 255, 0.14);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.026);
}

body[data-page] main.layout-page .faq-list summary {
  padding: 1.1rem 1.1rem;
  color: var(--editorial-text);
}

body[data-page] main.layout-page .faq-list details p {
  padding: 0 1.1rem 1.1rem;
  color: var(--editorial-soft);
}

body[data-page] main.layout-page .form-card {
  gap: 1.15rem;
}

body[data-page] main.layout-page .form-card__head,
body[data-page] main.layout-page .brief-hub__meta {
  display: grid;
  gap: 0.7rem;
}

body[data-page] main.layout-page .field {
  display: grid;
  gap: 0.45rem;
}

body[data-page] main.layout-page .field label {
  color: var(--editorial-soft);
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page] main.layout-page .field input,
body[data-page] main.layout-page .field textarea,
body[data-page] main.layout-page .field select {
  min-height: 56px;
  padding: 1rem 1rem;
  border: 1px solid rgba(149, 228, 255, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.026);
  color: var(--editorial-text);
}

body[data-page] main.layout-page .field textarea {
  min-height: 154px;
}

body[data-page] main.layout-page .field input:focus,
body[data-page] main.layout-page .field textarea:focus,
body[data-page] main.layout-page .field select:focus {
  border-color: rgba(149, 228, 255, 0.34);
  background: rgba(255, 255, 255, 0.05);
  box-shadow: 0 0 0 4px rgba(111, 132, 255, 0.12);
  outline: none;
}

body[data-page] main.layout-page .success-note,
body[data-page] main.layout-page .error-note {
  border-radius: 18px;
}

body[data-page] main.layout-page .faq-compass,
body[data-page] main.layout-page .brief-hub__nav {
  gap: 0.75rem;
}

body[data-page] main.layout-page .faq-compass a,
body[data-page] main.layout-page .brief-hub__nav a {
  border-color: rgba(149, 228, 255, 0.12);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.028);
}

body[data-page] main.layout-page .faq-compass a:hover,
body[data-page] main.layout-page .brief-hub__nav a:hover,
body[data-page] main.layout-page .brief-hub__nav a.is-active {
  border-color: rgba(149, 228, 255, 0.26);
  background: rgba(255, 255, 255, 0.05);
}

body[data-page] main.layout-page .faq-compass a span,
body[data-page] main.layout-page .brief-hub__nav a span {
  border-color: rgba(149, 228, 255, 0.18);
  background: rgba(7, 12, 22, 0.92);
}

@media (min-width: 700px) {
  body[data-page] main.layout-page .crosslink-grid > *,
  body[data-page] main.layout-page .layout-panel-grid > *,
  body[data-page] main.layout-page .layout-panel-grid--offset > *,
  body[data-page] main.layout-page .layout-category-grid > *,
  body[data-page] main.layout-page .card-grid > *,
  body[data-page] main.layout-page .study-grid > *,
  body[data-page] main.layout-page .route-grid > *,
  body[data-page] main.layout-page .service-detail-grid > * {
    grid-column: span 6;
  }

  body[data-page] main.layout-page .layout-metric-grid > *,
  body[data-page] main.layout-page .layout-step-grid > *,
  body[data-page] main.layout-page .layout-proof-grid > *,
  body[data-page] main.layout-page .layout-service-mosaic > *,
  body[data-page] main.layout-page .home-decision-grid > * {
    grid-column: span 6;
  }

  body[data-page] main.layout-page .hero-mast__signal-grid,
  body[data-page] main.layout-page .hero-mast__lane-grid,
  body[data-page] main.layout-page .hero-mast__legal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 980px) {
  body[data-page] main.layout-page .hero-mast__layout {
    grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  }

  body[data-page] main.layout-page .hero-mast__stage {
    align-content: end;
  }

  body[data-page]:not([data-page="home"]) main.layout-page .hero-mast__title {
    font-size: clamp(3.2rem, 8vw, 6.8rem);
    max-width: 8.2ch;
  }

  body[data-page] main.layout-page .layout-section__frame,
  body[data-page] main.layout-page .policy-atlas__frame,
  body[data-page] main.layout-page .faq-overview,
  body[data-page] main.layout-page .contact-band--routes .shell,
  body[data-page] main.layout-page .examples-band--studies .shell,
  body[data-page] main.layout-page .examples-band--principles .shell,
  body[data-page] main.layout-page .start-band--fit .shell,
  body[data-page] main.layout-page .start-band--after .shell,
  body[data-page] main.layout-page .pay-band--routes .shell,
  body[data-page] main.layout-page .discovery-band--routes .shell,
  body[data-page] main.layout-page .discovery-band--brief .shell {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 2rem);
    align-items: start;
  }

  body[data-page] main.layout-page .layout-section__frame > .layout-section__intro,
  body[data-page] main.layout-page .section-heading--panel,
  body[data-page] main.layout-page .faq-summary,
  body[data-page] main.layout-page .policy-summary {
    grid-column: 1 / span 4;
    position: sticky;
    top: 7rem;
    align-self: start;
  }

  body[data-page] main.layout-page .layout-section__frame > :not(.layout-section__intro),
  body[data-page] main.layout-page .contact-band--routes .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .examples-band--studies .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .examples-band--principles .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .start-band--fit .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .start-band--after .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .pay-band--routes .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .faq-overview > :not(.faq-summary),
  body[data-page] main.layout-page .policy-atlas__frame > :not(.policy-summary),
  body[data-page] main.layout-page .discovery-band--routes .shell > :not(.layout-section__intro),
  body[data-page] main.layout-page .discovery-band--brief .shell > :not(.layout-section__intro) {
    grid-column: 5 / -1;
  }

  body[data-page] main.layout-page .home-band--fit .layout-rail-grid,
  body[data-page] main.layout-page .about-band--premise .layout-split-grid,
  body[data-page] main.layout-page .about-band--method .layout-split-grid {
    grid-template-columns: minmax(0, 1.04fr) minmax(18rem, 0.96fr);
    align-items: end;
  }

  body[data-page] main.layout-page .about-band--difference .layout-rail-grid {
    grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
    align-items: start;
  }

  body[data-page="home"] main.layout-page .home-band--offers .crosslink-grid > :nth-child(1) {
    grid-column: span 7;
  }

  body[data-page="home"] main.layout-page .home-band--offers .crosslink-grid > :nth-child(2) {
    grid-column: span 5;
  }

  body[data-page="home"] main.layout-page .home-band--offers .crosslink-grid > :nth-child(3) {
    grid-column: 3 / -1;
  }

  body[data-page="home"] main.layout-page .home-band--outcomes .layout-metric-grid > * {
    grid-column: span 6;
  }

  body[data-page="home"] main.layout-page .home-band--process .layout-step-grid > * {
    grid-column: span 4;
  }

  body[data-page="home"] main.layout-page .home-band--routes .layout-twin-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 1.8rem);
  }

  body[data-page="about"] main.layout-page .about-band--mission .layout-panel-grid > * {
    grid-column: span 6;
  }

  body[data-page="about"] main.layout-page .about-band--fit .layout-metric-grid > * {
    grid-column: span 6;
  }

  body[data-page="services"] main.layout-page .services-band--taxonomy .layout-category-grid > * {
    grid-column: span 4;
  }

  body[data-page="services"] main.layout-page .services-band--taxonomy .layout-category-grid > *:first-child {
    grid-column: 1 / -1;
  }

  body[data-page="services"] main.layout-page .services-band--mosaic .layout-service-mosaic > * {
    grid-column: span 4;
  }

  body[data-page="services"] main.layout-page .services-band--mosaic .layout-service-mosaic > *:nth-child(1),
  body[data-page="services"] main.layout-page .services-band--mosaic .layout-service-mosaic > *:nth-child(5),
  body[data-page="services"] main.layout-page .services-band--mosaic .layout-service-mosaic > *:nth-child(9) {
    grid-column: span 8;
  }

  body[data-page="process"] main.layout-page .process-band--steps .layout-service-mosaic {
    position: relative;
    counter-reset: process-step;
  }

  body[data-page="process"] main.layout-page .process-band--steps .layout-service-mosaic::before {
    content: "";
    position: absolute;
    top: 1.2rem;
    bottom: 1.2rem;
    left: calc(50% - 0.5px);
    width: 1px;
    background: linear-gradient(180deg, transparent, rgba(149, 228, 255, 0.26), rgba(255, 147, 95, 0.16), transparent);
    pointer-events: none;
  }

  body[data-page="process"] main.layout-page .process-band--steps .layout-timeline {
    counter-increment: process-step;
  }

  body[data-page="process"] main.layout-page .process-band--steps .layout-timeline::after {
    content: counter(process-step, decimal-leading-zero);
    position: absolute;
    top: 1rem;
    right: 1.2rem;
    color: rgba(243, 247, 255, 0.06);
    font-family: var(--font-mono);
    font-size: clamp(2.8rem, 6vw, 5.6rem);
    line-height: 1;
    letter-spacing: -0.08em;
  }

  body[data-page="process"] main.layout-page .process-band--steps .layout-service-mosaic > * {
    grid-column: span 6;
  }

  body[data-page="process"] main.layout-page .process-band--steps .layout-service-mosaic > *:nth-child(3),
  body[data-page="process"] main.layout-page .process-band--steps .layout-service-mosaic > *:nth-child(6) {
    grid-column: 3 / -1;
  }

  body[data-page="examples"] main.layout-page .examples-band--studies .study-grid > :first-child {
    grid-column: 1 / -1;
  }

  body[data-page="examples"] main.layout-page .examples-band--studies .study-grid > :nth-child(2),
  body[data-page="examples"] main.layout-page .examples-band--studies .study-grid > :nth-child(3) {
    grid-column: span 6;
  }

  body[data-page="examples"] main.layout-page .study-card {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    align-items: end;
  }

  body[data-page="examples"] main.layout-page .examples-band--studies .study-grid > :first-child .study-card,
  body[data-page="examples"] main.layout-page .examples-band--studies .study-card:first-child {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }

  body[data-page="examples"] main.layout-page .examples-band--principles .card-grid > * {
    grid-column: span 6;
  }

  body[data-page="examples"] main.layout-page .examples-band--principles .card-grid > :nth-child(1),
  body[data-page="examples"] main.layout-page .examples-band--principles .card-grid > :nth-child(4) {
    grid-column: span 7;
  }

  body[data-page="contact"] main.layout-page .contact-band--routes .route-grid > *,
  body[data-page="launch"] main.layout-page .start-band--fit .card-grid > *,
  body[data-page="launch"] main.layout-page .start-band--after .card-grid > * {
    grid-column: span 4;
  }

  body[data-page="contact"] main.layout-page .contact-grid,
  body[data-page="launch"] main.layout-page .contact-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 2rem);
  }

  body[data-page="contact"] main.layout-page .contact-grid > .form-card,
  body[data-page="launch"] main.layout-page .contact-grid > .form-card {
    grid-column: 1 / span 8;
  }

  body[data-page="contact"] main.layout-page .contact-grid > .contact-card,
  body[data-page="launch"] main.layout-page .contact-grid > .contact-card {
    grid-column: 9 / -1;
    position: sticky;
    top: 7rem;
    align-self: start;
  }

  body[data-page="payments"] main.layout-page .payment-flow {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 2rem);
    align-items: start;
  }

  body[data-page="payments"] main.layout-page .payment-flow > .route-grid {
    grid-column: 1 / span 5;
  }

  body[data-page="payments"] main.layout-page .payment-flow > .form-card {
    grid-column: 6 / -1;
  }

  body[data-page="payments"] main.layout-page .route-grid > :first-child {
    grid-column: 1 / -1;
  }

  body[data-page="discovery"] main.layout-page .layout-twin-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 1.8rem);
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .brief-hub__mast {
    grid-column: 1 / span 4;
    position: sticky;
    top: 7rem;
    align-self: start;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form,
  body[data-page="discovery"] main.layout-page .discovery-band--brief [data-form-success],
  body[data-page="discovery"] main.layout-page .discovery-band--brief [data-form-error] {
    grid-column: 5 / -1;
  }

  body[data-page="faq"] main.layout-page .faq-band--atlas .faq-shell,
  body[data-page="privacy"] main.layout-page .policy-atlas__cards > *,
  body[data-page="terms"] main.layout-page .policy-atlas__cards > *,
  body[data-page="cookies"] main.layout-page .policy-atlas__cards > *,
  body[data-page="accessibility"] main.layout-page .policy-atlas__cards > * {
    grid-column: span 6;
  }

  body[data-page="faq"] main.layout-page .faq-band--atlas .faq-shell:nth-child(1),
  body[data-page="faq"] main.layout-page .faq-band--atlas .faq-shell:nth-child(6),
  body[data-page="privacy"] main.layout-page .policy-atlas__cards > *:last-child:nth-child(odd),
  body[data-page="terms"] main.layout-page .policy-atlas__cards > *:last-child:nth-child(odd),
  body[data-page="cookies"] main.layout-page .policy-atlas__cards > *:last-child:nth-child(odd),
  body[data-page="accessibility"] main.layout-page .policy-atlas__cards > *:last-child:nth-child(odd) {
    grid-column: 1 / -1;
  }
}

@media (max-width: 979px) {
  body[data-page] main.layout-page > .section::after {
    font-size: clamp(2.4rem, 10vw, 4.8rem);
    opacity: 0.07;
  }

  body[data-page] main.layout-page .hero-mast__frame {
    min-height: auto;
  }

  body[data-page] main.layout-page .hero-mast__title {
    max-width: 8ch;
    font-size: clamp(3rem, 12vw, 6rem);
  }

  body[data-page] main.layout-page .layout-section__title,
  body[data-page] main.layout-page .section-title {
    max-width: 12ch;
    font-size: clamp(2.2rem, 9vw, 4.4rem);
  }

  body[data-page="process"] main.layout-page .process-band--steps .layout-service-mosaic::before {
    display: none;
  }
}

@media (max-width: 759px) {
  body[data-page] main.layout-page .shell,
  body[data-page] main.layout-page .hero-mast__shell {
    width: min(100%, calc(100% - 1.25rem));
  }

  body[data-page] main.layout-page > .section {
    padding-block: clamp(2.6rem, 10vw, 4rem);
  }

  body[data-page] main.layout-page > .section::after {
    top: 0.8rem;
    right: 0.9rem;
    font-size: clamp(2.2rem, 14vw, 3.6rem);
  }

  body[data-page] main.layout-page .hero-mast__frame,
  body[data-page] main.layout-page .route-card,
  body[data-page] main.layout-page .layout-panel,
  body[data-page] main.layout-page .layout-metric,
  body[data-page] main.layout-page .layout-timeline,
  body[data-page] main.layout-page .card,
  body[data-page] main.layout-page .service-detail,
  body[data-page] main.layout-page .study-card,
  body[data-page] main.layout-page .policy-card,
  body[data-page] main.layout-page .faq-shell,
  body[data-page] main.layout-page .contact-card,
  body[data-page] main.layout-page .form-card,
  body[data-page] main.layout-page .quote-banner,
  body[data-page] main.layout-page .callout,
  body[data-page] main.layout-page .layout-callout,
  body[data-page] main.layout-page .layout-highlight,
  body[data-page] main.layout-page .brief-hub__mast {
    border-radius: 28px;
  }

  body[data-page] main.layout-page .button {
    width: 100%;
  }

  body[data-page] main.layout-page .hero-mast__actions,
  body[data-page] main.layout-page .layout-actions,
  body[data-page] main.layout-page .hero__actions {
    display: grid;
  }

  body[data-page] main.layout-page .hero-mast__signal-grid,
  body[data-page] main.layout-page .hero-mast__lane-grid,
  body[data-page] main.layout-page .hero-mast__legal-grid {
    grid-template-columns: 1fr;
  }

  body[data-page] main.layout-page .hero-mast__media {
    min-height: 16rem;
  }

  body[data-page] main.layout-page .study-card {
    gap: 1rem;
  }

  body[data-page="process"] main.layout-page .hero-mast__title {
    max-width: 6.2ch;
    font-size: clamp(2.5rem, 12vw, 4.4rem);
  }

  body[data-page="process"] main.layout-page .hero-mast__lede {
    padding-left: 0.8rem;
    font-size: 0.98rem;
  }

  body[data-page="process"] main.layout-page .hero-mast__lane-grid {
    display: none;
  }

  body[data-page="process"] main.layout-page .layout-section__frame {
    display: grid;
    gap: 1rem;
  }

  body[data-page="process"] main.layout-page .layout-section__intro {
    padding: 1.2rem 1.25rem;
    border: 1px solid rgba(149, 228, 255, 0.14);
    border-top-color: rgba(149, 228, 255, 0.28);
    border-radius: 28px;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.028), rgba(255, 255, 255, 0.01)),
      rgba(6, 10, 20, 0.72);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
  }

  body[data-page="process"] main.layout-page .layout-section__intro .layout-section__body,
  body[data-page="process"] main.layout-page .layout-section__intro .layout-section__kicker,
  body[data-page="process"] main.layout-page .layout-section__intro .layout-section__title {
    color: var(--editorial-text);
  }

  body[data-page="process"] main.layout-page .layout-section__intro .layout-section__body {
    color: var(--editorial-soft);
  }

  body[data-page="contact"] main.layout-page .hero-mast__title,
  body[data-page="discovery"] main.layout-page .hero-mast__title,
  body[data-page="launch"] main.layout-page .hero-mast__title,
  body[data-page="home"] main.layout-page .hero-mast__title,
  body[data-page="payments"] main.layout-page .hero-mast__title,
  body[data-page="schedule"] main.layout-page .hero-mast__title,
  body[data-page="faq"] main.layout-page .hero-mast__title,
  body[data-page="privacy"] main.layout-page .hero-mast__title,
  body[data-page="terms"] main.layout-page .hero-mast__title,
  body[data-page="cookies"] main.layout-page .hero-mast__title,
  body[data-page="accessibility"] main.layout-page .hero-mast__title {
    max-width: 7ch;
    font-size: clamp(2.7rem, 12vw, 4.8rem);
  }

  body[data-page="home"] main.layout-page .hero-mast__title {
    max-width: 100%;
    font-size: clamp(2.85rem, 10.8vw, 4.2rem);
    line-height: 0.94;
  }

  body[data-page="contact"] main.layout-page .hero-mast__title {
    font-size: clamp(2.3rem, 10vw, 3.7rem);
    line-height: 1.04;
  }

  body[data-page="home"] main.layout-page .hero-mast__actions .button {
    width: 100%;
  }
}

/* Flat section pass:
   remove sticky split-panel behavior so every section reads in normal order
   with the intro above the content instead of hanging beside it on scroll. */
@media (min-width: 960px) {
  body[data-page] main.layout-page .layout-section__frame,
  body[data-page] main.layout-page .faq-overview,
  body[data-page] main.layout-page .policy-atlas__frame,
  body[data-page] main.layout-page .contact-band--routes .shell,
  body[data-page] main.layout-page .examples-band--studies .shell,
  body[data-page] main.layout-page .examples-band--principles .shell,
  body[data-page] main.layout-page .start-band--fit .shell,
  body[data-page] main.layout-page .start-band--after .shell,
  body[data-page] main.layout-page .pay-band--routes .shell,
  body[data-page] main.layout-page .discovery-band--routes .shell,
  body[data-page] main.layout-page .discovery-band--brief .shell,
  body[data-page] main.layout-page .contact-grid,
  body[data-page] main.layout-page .payment-flow {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: clamp(1.1rem, 2vw, 1.7rem);
    align-items: start;
  }

  body[data-page] main.layout-page .layout-section__frame > *,
  body[data-page] main.layout-page .faq-overview > *,
  body[data-page] main.layout-page .policy-atlas__frame > *,
  body[data-page] main.layout-page .contact-band--routes .shell > *,
  body[data-page] main.layout-page .examples-band--studies .shell > *,
  body[data-page] main.layout-page .examples-band--principles .shell > *,
  body[data-page] main.layout-page .start-band--fit .shell > *,
  body[data-page] main.layout-page .start-band--after .shell > *,
  body[data-page] main.layout-page .pay-band--routes .shell > *,
  body[data-page] main.layout-page .discovery-band--routes .shell > *,
  body[data-page] main.layout-page .discovery-band--brief .shell > *,
  body[data-page] main.layout-page .contact-grid > *,
  body[data-page] main.layout-page .payment-flow > * {
    grid-column: 1 / -1;
  }

  body[data-page] main.layout-page .layout-section__frame > .layout-section__intro,
  body[data-page] main.layout-page .section-heading--panel,
  body[data-page] main.layout-page .faq-summary,
  body[data-page] main.layout-page .policy-summary,
  body[data-page="discovery"] main.layout-page .discovery-band--brief .brief-hub__mast {
    grid-column: 1 / -1;
    position: static;
    top: auto;
    align-self: auto;
  }

  body[data-page] main.layout-page .layout-section__frame > :not(.layout-section__intro),
  body[data-page] main.layout-page .contact-band--routes .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .examples-band--studies .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .examples-band--principles .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .start-band--fit .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .start-band--after .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .pay-band--routes .shell > :not(.section-heading--panel),
  body[data-page] main.layout-page .faq-overview > :not(.faq-summary),
  body[data-page] main.layout-page .policy-atlas__frame > :not(.policy-summary),
  body[data-page] main.layout-page .discovery-band--routes .shell > :not(.layout-section__intro),
  body[data-page] main.layout-page .discovery-band--brief .shell > :not(.layout-section__intro) {
    grid-column: 1 / -1;
  }

  body[data-page] main.layout-page .section-heading--panel,
  body[data-page] main.layout-page .layout-section__intro,
  body[data-page] main.layout-page .faq-summary,
  body[data-page] main.layout-page .policy-summary,
  body[data-page] main.layout-page .brief-hub__mast,
  body[data-page] main.layout-page .contact-card {
    position: static;
    top: auto;
    align-self: auto;
  }

  body[data-page] main.layout-page .section-heading--panel,
  body[data-page] main.layout-page .layout-section__intro,
  body[data-page] main.layout-page .faq-summary,
  body[data-page] main.layout-page .policy-summary,
  body[data-page] main.layout-page .brief-hub__mast {
    max-width: none;
  }

  body[data-page] main.layout-page .section-heading--panel .section-title,
  body[data-page] main.layout-page .layout-section__title,
  body[data-page] main.layout-page .faq-summary .layout-section__title,
  body[data-page] main.layout-page .policy-summary .layout-section__title {
    max-width: 13ch;
  }

  body[data-page] main.layout-page .examples-band--studies .study-grid,
  body[data-page] main.layout-page .examples-band--principles .card-grid,
  body[data-page] main.layout-page .contact-band--routes .route-grid,
  body[data-page] main.layout-page .start-band--fit .card-grid,
  body[data-page] main.layout-page .start-band--after .card-grid,
  body[data-page] main.layout-page .pay-band--routes .route-grid,
  body[data-page] main.layout-page .discovery-band--routes .route-grid,
  body[data-page] main.layout-page .discovery-band--brief .stacked-form,
  body[data-page] main.layout-page .discovery-band--brief [data-form-success],
  body[data-page] main.layout-page .discovery-band--brief [data-form-error] {
    grid-column: 1 / -1;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .brief-hub__mast,
  body[data-page="contact"] main.layout-page .contact-grid > .contact-card,
  body[data-page="launch"] main.layout-page .contact-grid > .contact-card,
  body[data-page="contact"] main.layout-page .contact-grid > .form-card,
  body[data-page="launch"] main.layout-page .contact-grid > .form-card,
  body[data-page="payments"] main.layout-page .payment-flow > .route-grid,
  body[data-page="payments"] main.layout-page .payment-flow > .form-card {
    grid-column: 1 / -1;
  }

  body[data-page] main.layout-page .route-grid,
  body[data-page] main.layout-page .card-grid,
  body[data-page] main.layout-page .service-detail-grid,
  body[data-page] main.layout-page .study-grid,
  body[data-page] main.layout-page .layout-panel-grid,
  body[data-page] main.layout-page .layout-metric-grid,
  body[data-page] main.layout-page .layout-step-grid,
  body[data-page] main.layout-page .layout-category-grid,
  body[data-page] main.layout-page .home-decision-grid,
  body[data-page] main.layout-page .policy-atlas__cards {
    grid-column: 1 / -1;
  }

  body[data-page] main.layout-page .process-band--steps .layout-service-mosaic::before {
    display: none;
  }

  body[data-page] main.layout-page > .section::after {
    opacity: 0.04;
  }
}

body[data-page] main.layout-page .section-heading--panel,
body[data-page] main.layout-page .layout-section__intro,
body[data-page] main.layout-page .faq-summary,
body[data-page] main.layout-page .policy-summary,
body[data-page] main.layout-page .brief-hub__mast {
  justify-items: start;
  gap: 0.9rem;
  padding: clamp(1.2rem, 2vw, 1.7rem);
  border: 1px solid rgba(149, 228, 255, 0.14);
  border-top-color: rgba(149, 228, 255, 0.3);
  border-radius: 32px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
    rgba(6, 11, 22, 0.74);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(18px);
  overflow: hidden;
}

body[data-page] main.layout-page .section-heading--panel .section-title,
body[data-page] main.layout-page .layout-section__title,
body[data-page] main.layout-page .faq-summary .layout-section__title,
body[data-page] main.layout-page .policy-summary .layout-section__title {
  max-width: 9.5ch;
  font-size: clamp(2.2rem, 4.2vw, 3.7rem);
  line-height: 0.95;
}

body[data-page] main.layout-page .section-heading--panel .section-text,
body[data-page] main.layout-page .layout-section__body,
body[data-page] main.layout-page .faq-summary .layout-section__body,
body[data-page] main.layout-page .policy-summary p,
body[data-page] main.layout-page .brief-hub__mast p {
  max-width: 48rem;
}

@media (min-width: 1100px) {
  body[data-page="about"] main.layout-page .about-band--mission .card-grid > * {
    grid-column: span 6;
  }

  body[data-page="home"] main.layout-page .home-band--outcomes .card-grid > * {
    grid-column: span 6;
  }

  body[data-page="home"] main.layout-page .home-band--process .card-grid > * {
    grid-column: span 6;
  }

  body[data-page="home"] main.layout-page .home-band--process .card-grid > :last-child,
  body[data-page="home"] main.layout-page .home-band--offers .route-grid > :last-child {
    grid-column: 1 / -1;
  }

  body[data-page="home"] main.layout-page .home-band--offers .route-grid > :not(:last-child) {
    grid-column: span 6;
  }
}

/* Sitewide body hierarchy pass:
   keep section-level H2s left-led inside their boxes so the scan path stays
   obvious across the main body on every page. */
body[data-page] main.layout-page .section-heading.section-heading--panel,
body[data-page] main.layout-page .layout-section__intro,
body[data-page] main.layout-page .faq-summary,
body[data-page] main.layout-page .policy-summary,
body[data-page] main.layout-page .story-grid__copy,
body[data-page] main.layout-page .callout,
body[data-page] main.layout-page .form-card__head,
body[data-page] main.layout-page .faq-category__head,
body[data-page] main.layout-page .brief-hub__meta,
body[data-page] main.layout-page .contact-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-content: start;
  justify-items: start;
  gap: clamp(0.8rem, 1.4vw, 1rem);
  text-align: left;
}

body[data-page] main.layout-page .section-heading.section-heading--panel > *,
body[data-page] main.layout-page .layout-section__intro > *,
body[data-page] main.layout-page .faq-summary > *,
body[data-page] main.layout-page .policy-summary > *,
body[data-page] main.layout-page .story-grid__copy > *,
body[data-page] main.layout-page .callout > *,
body[data-page] main.layout-page .form-card__head > *,
body[data-page] main.layout-page .faq-category__head > *,
body[data-page] main.layout-page .brief-hub__meta > *,
body[data-page] main.layout-page .contact-card > * {
  justify-self: start;
  text-align: left;
}

body[data-page] main.layout-page .section-heading.section-heading--panel .section-title,
body[data-page] main.layout-page .layout-section__title,
body[data-page] main.layout-page .story-grid__copy .section-title,
body[data-page] main.layout-page .faq-summary .layout-section__title,
body[data-page] main.layout-page .policy-summary .layout-section__title,
body[data-page] main.layout-page .callout__title {
  max-width: 12.5ch;
  font-size: clamp(2rem, 3.8vw, 3.35rem);
  line-height: 0.96;
}

body[data-page] main.layout-page .faq-category__head h2,
body[data-page] main.layout-page .form-card__head .card__title,
body[data-page] main.layout-page .contact-card__title,
body[data-page] main.layout-page .policy-card__body h2 {
  max-width: 16ch;
  text-align: left;
}

body[data-page] main.layout-page .section-heading.section-heading--panel .section-text,
body[data-page] main.layout-page .layout-section__body,
body[data-page] main.layout-page .story-grid__copy .section-text,
body[data-page] main.layout-page .faq-summary .layout-section__body,
body[data-page] main.layout-page .policy-summary p,
body[data-page] main.layout-page .callout .section-text,
body[data-page] main.layout-page .form-card__head p,
body[data-page] main.layout-page .faq-category__head p,
body[data-page] main.layout-page .brief-hub__meta p,
body[data-page] main.layout-page .contact-card p {
  max-width: 44rem;
}

body[data-page] main.layout-page .section-heading.section-heading--panel .hero__actions,
body[data-page] main.layout-page .story-grid__copy .hero__actions,
body[data-page] main.layout-page .callout .hero__actions {
  margin-top: 0.15rem;
  justify-content: flex-start;
}

body[data-page] main.layout-page .section-heading.section-heading--panel .page-hero__punch,
body[data-page] main.layout-page .story-grid__copy .page-hero__punch,
body[data-page] main.layout-page .callout .page-hero__punch,
body[data-page] main.layout-page .layout-section__intro .page-hero__punch {
  justify-self: start;
}

body[data-page="home"] .home-band--premise {
  order: 1;
}

body[data-page="home"] .home-band--fit {
  order: 2;
}

body[data-page="home"] .home-band--offers {
  order: 3;
}

body[data-page="home"] .home-band--services {
  order: 4;
}

body[data-page="home"] .home-band--outcomes {
  order: 5;
}

body[data-page="home"] .home-band--examples {
  order: 6;
}

body[data-page="home"] .home-band--process {
  order: 7;
}

body[data-page="home"] .home-band--decision {
  order: 8;
}

body[data-page="home"] .home-band--atlas {
  order: 9;
}

body[data-page="home"] .home-band--values {
  order: 10;
}

body[data-page="home"] .home-band--routes {
  order: 11;
}

body[data-page="home"] .home-band--closing {
  order: 12;
}

body[data-page="home"] main.layout-page .home-band--decision a.route-card,
body[data-page="home"] main.layout-page .home-band--values a.route-card {
  color: inherit;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

body[data-page="home"] main.layout-page .home-band--decision a.route-card:hover,
body[data-page="home"] main.layout-page .home-band--decision a.route-card:focus-visible,
body[data-page="home"] main.layout-page .home-band--values a.route-card:hover,
body[data-page="home"] main.layout-page .home-band--values a.route-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(149, 228, 255, 0.28);
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.22);
  outline: none;
}

/* Sitewide spacing normalization:
   keep the editorial redesign, but tighten the vertical rhythm and unify
   surface padding so every page reads on the same spacing system. */
body[data-page] main.layout-page {
  --site-flow-gap: clamp(0.55rem, 1.2vw, 1rem);
  --site-section-space: clamp(3rem, 6.9vw, 6.4rem);
  --site-frame-gap: clamp(1.05rem, 2vw, 1.5rem);
  --site-panel-pad: clamp(1.2rem, 2.15vw, 1.7rem);
  --site-panel-gap: clamp(0.8rem, 1.5vw, 1rem);
  --site-surface-pad: clamp(1.25rem, 2.2vw, 1.9rem);
  --site-surface-gap: clamp(0.85rem, 1.5vw, 1.08rem);
  --site-text-surface-pad: clamp(1.4rem, 2.55vw, 2.15rem);
  --site-text-surface-gap: clamp(0.95rem, 1.7vw, 1.22rem);
  --site-surface-radius: clamp(1.75rem, 2.1vw, 2.125rem);
  gap: var(--site-flow-gap);
  padding-bottom: clamp(1.2rem, 2.5vw, 1.9rem);
}

body[data-page] main.layout-page > .section {
  padding-block: var(--site-section-space);
}

body[data-page] main.layout-page > .section.section--flush {
  padding-top: clamp(0.75rem, 1.8vw, 1.1rem);
}

body[data-page] main.layout-page .layout-section__frame,
body[data-page] main.layout-page .faq-overview,
body[data-page] main.layout-page .policy-atlas__frame,
body[data-page] main.layout-page .contact-band--routes .shell,
body[data-page] main.layout-page .examples-band--studies .shell,
body[data-page] main.layout-page .examples-band--principles .shell,
body[data-page] main.layout-page .start-band--fit .shell,
body[data-page] main.layout-page .start-band--after .shell,
body[data-page] main.layout-page .pay-band--routes .shell,
body[data-page] main.layout-page .discovery-band--routes .shell,
body[data-page] main.layout-page .discovery-band--brief .shell,
body[data-page] main.layout-page .contact-grid,
body[data-page] main.layout-page .payment-flow,
body[data-page] main.layout-page .route-grid,
body[data-page] main.layout-page .card-grid,
body[data-page] main.layout-page .service-detail-grid,
body[data-page] main.layout-page .study-grid,
body[data-page] main.layout-page .layout-panel-grid,
body[data-page] main.layout-page .layout-metric-grid,
body[data-page] main.layout-page .layout-step-grid,
body[data-page] main.layout-page .layout-category-grid,
body[data-page] main.layout-page .home-decision-grid,
body[data-page] main.layout-page .policy-atlas__cards {
  gap: var(--site-frame-gap);
}

body[data-page] main.layout-page .section-heading--panel,
body[data-page] main.layout-page .layout-section__intro,
body[data-page] main.layout-page .faq-summary,
body[data-page] main.layout-page .policy-summary {
  gap: var(--site-panel-gap);
  padding: var(--site-panel-pad);
}

body[data-page] main.layout-page .route-card,
body[data-page] main.layout-page .service-detail,
body[data-page] main.layout-page .card,
body[data-page] main.layout-page .study-card,
body[data-page] main.layout-page .contact-card,
body[data-page] main.layout-page .form-card,
body[data-page] main.layout-page .faq-shell,
body[data-page] main.layout-page .policy-card,
body[data-page] main.layout-page .layout-panel,
body[data-page] main.layout-page .layout-metric,
body[data-page] main.layout-page .layout-category,
body[data-page] main.layout-page .layout-timeline,
body[data-page] main.layout-page .brief-section,
body[data-page] main.layout-page .embed-card,
body[data-page] main.layout-page .home-decision-card {
  gap: var(--site-surface-gap);
  padding: var(--site-surface-pad);
  border-radius: var(--site-surface-radius);
}

body[data-page] main.layout-page .quote-banner,
body[data-page] main.layout-page .callout,
body[data-page] main.layout-page .layout-callout,
body[data-page] main.layout-page .story-grid__copy,
body[data-page] main.layout-page .story-grid__media,
body[data-page] main.layout-page .brief-hub__mast {
  gap: var(--site-text-surface-gap);
  padding: var(--site-text-surface-pad);
  border-radius: var(--site-surface-radius);
}

body[data-page] main.layout-page .form-card__head,
body[data-page] main.layout-page .faq-category__head,
body[data-page] main.layout-page .brief-hub__meta {
  gap: clamp(0.65rem, 1.2vw, 0.9rem);
}

body[data-page] main.layout-page .form-grid,
body[data-page] main.layout-page .stacked-form,
body[data-page] main.layout-page [data-form-success],
body[data-page] main.layout-page [data-form-error] {
  gap: clamp(0.95rem, 1.6vw, 1.25rem);
}

body[data-page] main.layout-page .field {
  gap: 0.5rem;
}

body[data-page] main.layout-page .check-list,
body[data-page] main.layout-page .detail-list,
body[data-page] main.layout-page .layout-bullet-list,
body[data-page] main.layout-page .policy-card ul {
  gap: clamp(0.7rem, 1.2vw, 0.95rem);
}

body[data-page] main.layout-page .check-list li,
body[data-page] main.layout-page .detail-list li,
body[data-page] main.layout-page .layout-bullet-list li,
body[data-page] main.layout-page .policy-card li {
  gap: clamp(0.7rem, 1.2vw, 0.9rem);
}

body[data-page] main.layout-page .route-cloud,
body[data-page] main.layout-page .hero__actions,
body[data-page] main.layout-page .layout-actions,
body[data-page] main.layout-page .hero-mast__actions {
  gap: clamp(0.7rem, 1.35vw, 0.95rem);
}

body[data-page] main.layout-page .story-grid__media {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-content: start;
  justify-items: stretch;
}

body[data-page] main.layout-page .story-grid__media > * {
  margin-top: 0;
}

body[data-page] main.layout-page .story-grid__media .media-caption {
  max-width: 34rem;
}

body[data-page] main.layout-page .route-cloud a {
  min-height: 40px;
  padding: 0.55rem 0.9rem;
}

body[data-page] main.layout-page .story-grid__media .route-cloud {
  width: 100%;
  justify-content: flex-end;
  align-items: center;
}

body[data-page] main.layout-page .hero__actions,
body[data-page] main.layout-page .layout-actions,
body[data-page] main.layout-page .hero-mast__actions {
  margin-top: clamp(0.65rem, 1.4vw, 0.95rem);
}

@media (max-width: 759px) {
  body[data-page] main.layout-page .story-grid__media .route-cloud {
    justify-content: flex-start;
  }

  body[data-page] main.layout-page .hero-mast__chip-row--hero {
    width: calc(100% - 2rem);
  }

  body[data-page] main.layout-page .hero-mast__stats {
    left: 1rem;
    right: 1rem;
    width: auto;
    bottom: 4.9rem;
  }

  body[data-page] main.layout-page .hero-mast__route-line {
    right: 1rem;
  }

  body[data-page] main.layout-page .surface-arrow {
    width: 4.4rem;
  }
}

body[data-page] main.layout-page .hero-mast__brand-panel {
  position: absolute;
  left: clamp(1rem, 2vw, 1.6rem);
  top: 5.25rem;
  z-index: 4;
  display: grid;
  gap: 0.8rem;
  width: min(17rem, calc(100% - 2rem));
  padding: 1rem 1.05rem;
  border-radius: 24px;
  border: 1px solid rgba(149, 228, 255, 0.16);
  background: rgba(6, 12, 22, 0.72);
  backdrop-filter: blur(14px);
}

body[data-page] main.layout-page .hero-mast__brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.25rem;
  height: 3.25rem;
  padding: 0.55rem;
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(121, 227, 255, 0.12), rgba(255, 159, 112, 0.12));
  border: 1px solid rgba(149, 228, 255, 0.16);
}

body[data-page] main.layout-page .hero-mast__brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

body[data-page] main.layout-page .hero-mast__brand-panel p {
  margin: 0;
  color: var(--editorial-soft);
  line-height: 1.55;
}

body[data-page] main.layout-page .hero-mast__ticker {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 7.65rem;
  overflow: hidden;
  z-index: 3;
  mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}

body[data-page] main.layout-page .hero-mast__ticker span {
  display: inline-block;
  min-width: max-content;
  color: rgba(234, 244, 255, 0.16);
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 2vw, 1.65rem);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  white-space: nowrap;
  animation: ashtraHeroTicker 26s linear infinite;
}

body[data-page="about"] main.layout-page .hero-mast__layout,
body[data-page="examples"] main.layout-page .hero-mast__layout,
body[data-page="contact"] main.layout-page .hero-mast__layout {
  grid-template-columns: minmax(0, 0.94fr) minmax(0, 1.06fr);
  align-items: center;
}

body[data-page="about"] main.layout-page .hero-mast__copy,
body[data-page="examples"] main.layout-page .hero-mast__copy,
body[data-page="contact"] main.layout-page .hero-mast__copy {
  align-content: center;
}

body[data-page="about"] main.layout-page .hero-mast__stage,
body[data-page="examples"] main.layout-page .hero-mast__stage,
body[data-page="contact"] main.layout-page .hero-mast__stage {
  min-height: clamp(26rem, 44vw, 42rem);
}

body[data-page="about"] main.layout-page .hero-mast__brand-panel,
body[data-page="examples"] main.layout-page .hero-mast__brand-panel,
body[data-page="contact"] main.layout-page .hero-mast__brand-panel {
  width: min(18.5rem, calc(100% - 2rem));
}

body[data-page="contact"] main.layout-page .hero-mast__stats {
  bottom: 5.4rem;
}

body[data-page="examples"] main.layout-page .hero-mast__ticker {
  bottom: 6.9rem;
}

body[data-page="about"] main.layout-page .hero-mast__title {
  max-width: 9.8ch;
  font-size: clamp(2.6rem, 3.6vw, 3.8rem);
}

body[data-page="examples"] main.layout-page .hero-mast__title {
  max-width: 9.6ch;
  font-size: clamp(2.6rem, 3.5vw, 3.8rem);
}

body[data-page="contact"] main.layout-page .hero-mast__title {
  max-width: 8.8ch;
  font-size: clamp(2.4rem, 3.4vw, 3.6rem);
}

body[data-page] main.layout-page .hero-mast__proof-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 0.25rem;
}

body[data-page] main.layout-page .hero-mast__proof {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 38px;
  padding: 0.55rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(149, 228, 255, 0.14);
  background: rgba(255, 255, 255, 0.032);
  color: var(--editorial-soft);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

body[data-page] main.layout-page .hero-mast__proof::before {
  content: "";
  width: 0.52rem;
  height: 0.52rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--editorial-cold), var(--editorial-hot));
  box-shadow: 0 0 16px rgba(145, 231, 255, 0.28);
}

body[data-page] main.layout-page .hero-mast__route-grid {
  display: grid;
  gap: 0.9rem;
}

body[data-page] main.layout-page .hero-mast__route-card {
  display: grid;
  gap: 0.55rem;
  padding: 1rem 1.05rem;
  border-radius: 24px;
  border: 1px solid rgba(149, 228, 255, 0.14);
  border-top-color: rgba(149, 228, 255, 0.28);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
    rgba(6, 11, 22, 0.74);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.16);
}

body[data-page] main.layout-page a.hero-mast__route-card {
  color: inherit;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

body[data-page] main.layout-page a.hero-mast__route-card:hover,
body[data-page] main.layout-page a.hero-mast__route-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(149, 228, 255, 0.28);
  box-shadow: 0 28px 64px rgba(0, 0, 0, 0.22);
  outline: none;
}

body[data-page] main.layout-page .hero-mast__route-card-label {
  color: var(--editorial-text);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

body[data-page] main.layout-page .hero-mast__route-card strong {
  color: var(--editorial-text);
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 2.2vw, 1.5rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
}

body[data-page] main.layout-page .hero-mast__route-card span {
  color: var(--editorial-soft);
  line-height: 1.58;
}

body[data-page] main.layout-page .hero-mast--framed .hero-mast__layout {
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
}

body[data-page] main.layout-page .hero-mast--framed .hero-mast__copy {
  max-width: min(58rem, 100%);
}

body[data-page] main.layout-page .hero-mast--framed .hero-mast__title {
  max-width: 10.6ch;
}

body[data-page] main.layout-page .hero-mast--framed .hero-mast__stage {
  min-height: auto;
}

body[data-page] main.layout-page .hero-mast--route .hero-mast__layout {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  align-items: center;
}

body[data-page] main.layout-page .hero-mast--route .hero-mast__stage {
  align-content: stretch;
}

body[data-page] main.layout-page .hero-mast--signal .hero-mast__layout {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  align-items: center;
}

body[data-page] main.layout-page .hero-mast--signal .hero-mast__stage {
  align-content: start;
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__layout {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  align-items: center;
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__copy {
  align-content: center;
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__stage {
  min-height: clamp(26rem, 44vw, 42rem);
}

body[data-page] main.layout-page .hero-mast--signal .hero-mast__panel .section-visual,
body[data-page] main.layout-page .hero-mast--route .hero-mast__panel .section-visual,
body[data-page] main.layout-page .hero-mast--framed .hero-mast__panel .section-visual {
  margin: 0 0 0.4rem;
}

body[data-page] main.layout-page .section-heading--with-rail {
  grid-template-columns: minmax(0, 1fr);
}

body[data-page] main.layout-page .section-heading__rail {
  display: grid;
  gap: 0.9rem;
  width: 100%;
  margin-top: 0.45rem;
}

body[data-page] main.layout-page .section-heading__rail-media {
  position: relative;
  min-height: 11rem;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(149, 228, 255, 0.14);
  background: rgba(4, 10, 18, 0.72);
}

body[data-page] main.layout-page .section-heading__rail-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body[data-page] main.layout-page .section-heading__rail-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(4, 8, 16, 0.12), rgba(4, 8, 16, 0.72)),
    linear-gradient(90deg, rgba(4, 8, 16, 0.42), rgba(4, 8, 16, 0.08));
}

body[data-page] main.layout-page .section-heading__rail-mark {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  padding: 0.42rem;
  border-radius: 18px;
  background: rgba(8, 16, 28, 0.84);
  border: 1px solid rgba(149, 228, 255, 0.18);
}

body[data-page] main.layout-page .section-heading__rail-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

body[data-page] main.layout-page .section-heading__rail-kicker {
  color: var(--editorial-text);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

body[data-page] main.layout-page .section-heading__rail-copy {
  display: grid;
  gap: 0.45rem;
}

body[data-page] main.layout-page .section-heading__rail-copy p {
  margin: 0;
  color: var(--editorial-soft);
  max-width: 24rem;
}

body[data-page] main.layout-page .section-visual__mark {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  padding: 0.34rem;
  border-radius: 16px;
  background: rgba(8, 16, 28, 0.82);
  border: 1px solid rgba(149, 228, 255, 0.16);
}

body[data-page] main.layout-page .section-visual__mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

body[data-page] main.layout-page .hero-mast__punch,
body[data-page] main.layout-page .page-hero__punch,
body[data-page] main.layout-page .service-detail__punch {
  width: 100%;
  justify-self: end;
  text-align: right;
}

body[data-page] main.layout-page .section-heading.section-heading--panel .page-hero__punch,
body[data-page] main.layout-page .story-grid__copy .page-hero__punch,
body[data-page] main.layout-page .callout .page-hero__punch,
body[data-page] main.layout-page .layout-section__intro .page-hero__punch {
  justify-self: end;
  text-align: right;
}

[data-tilt] {
  transition: transform 220ms ease-out, box-shadow 220ms ease-out;
}

@media (min-width: 1100px) {
  body[data-page] main.layout-page .section-heading--with-rail {
    grid-template-columns: minmax(0, 1.05fr) minmax(15rem, 0.95fr);
    align-items: start;
    column-gap: 1rem;
  }

  body[data-page] main.layout-page .section-heading--with-rail > :not(.section-heading__rail) {
    grid-column: 1;
  }

  body[data-page] main.layout-page .section-heading--with-rail > .section-heading__rail {
    grid-column: 2;
    grid-row: 1 / span 6;
    align-self: stretch;
    margin-top: 0;
  }
}

@media (max-width: 979px) {
  body[data-page] main.layout-page .hero-mast--split .hero-mast__layout,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__layout,
  body[data-page] main.layout-page .hero-mast--route .hero-mast__layout {
    grid-template-columns: 1fr;
  }

  body[data-page="about"] main.layout-page .hero-mast__layout,
  body[data-page="examples"] main.layout-page .hero-mast__layout,
  body[data-page="contact"] main.layout-page .hero-mast__layout {
    grid-template-columns: 1fr;
  }

  body[data-page] main.layout-page .hero-mast__brand-panel {
    width: min(16rem, calc(100% - 2rem));
  }
}

@media (max-width: 759px) {
  body[data-page] main.layout-page .hero-mast__ticker {
    display: none;
  }

  body[data-page] main.layout-page .hero-mast__route-grid {
    grid-template-columns: 1fr;
  }

  body[data-page] main.layout-page .hero-mast__brand-panel {
    top: 1rem;
    width: calc(100% - 2rem);
  }

  body[data-page] main.layout-page .section-heading__rail-media {
    min-height: 9rem;
  }

  body[data-page] main.layout-page .hero-mast__punch,
  body[data-page] main.layout-page .page-hero__punch,
  body[data-page] main.layout-page .service-detail__punch {
    text-align: left;
  }
}

@media (min-width: 760px) {
  body[data-page] main.layout-page .hero-mast__route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="contact"] main.layout-page .hero-mast__route-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@keyframes ashtraHeroTicker {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    transform: translate3d(-33.333%, 0, 0);
  }
}

/* Hero polish pass:
   final cascade that separates the four hero archetypes again and removes
   the over-explained card feel from the visual stage. */
body[data-page] main.layout-page .hero-mast__frame {
  min-height: clamp(32rem, 78vh, 52rem);
  padding: clamp(1rem, 2vw, 1.5rem);
  border-radius: 42px;
  border: 1px solid rgba(149, 228, 255, 0.16);
  box-shadow: 0 32px 120px rgba(0, 0, 0, 0.34);
}

body[data-page] main.layout-page .hero-mast__frame::before {
  background-size: 112px 112px;
  opacity: 0.2;
}

body[data-page] main.layout-page .hero-mast__frame::after {
  inset: auto -10% -34% 40%;
  height: 70%;
  filter: blur(44px);
  opacity: 0.82;
}

body[data-page] main.layout-page .hero-mast__layout {
  grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
  gap: clamp(1.5rem, 2.2vw, 2.6rem);
  align-items: center;
}

body[data-page] main.layout-page .hero-mast__copy {
  align-content: center;
  gap: 1.15rem;
  padding: clamp(0.75rem, 1.5vw, 1.25rem);
}

body[data-page] main.layout-page .hero-mast__title {
  max-width: 7.4ch;
  font-size: clamp(3.5rem, 6.6vw, 6.4rem);
  line-height: 0.9;
  letter-spacing: -0.075em;
}

body[data-page] main.layout-page .hero-mast__lede {
  max-width: 32rem;
  font-size: clamp(1.02rem, 1.4vw, 1.1rem);
  line-height: 1.64;
}

body[data-page] main.layout-page .hero-mast__punch {
  color: rgba(238, 244, 255, 0.76);
}

body[data-page] main.layout-page .hero-mast__proof-strip {
  max-width: 36rem;
  gap: 0.75rem;
}

body[data-page] main.layout-page .hero-mast__proof {
  background: rgba(255, 255, 255, 0.025);
}

body[data-page] main.layout-page .hero-mast__stage {
  min-height: clamp(26rem, 44vw, 44rem);
  padding: 0;
  gap: 1rem;
  overflow: visible;
}

body[data-page] main.layout-page .hero-mast__panel,
body[data-page] main.layout-page .hero-mast__signal,
body[data-page] main.layout-page .hero-mast__lane,
body[data-page] main.layout-page .hero-mast__topic,
body[data-page] main.layout-page .hero-mast__legal-item,
body[data-page] main.layout-page .hero-mast__route-card,
body[data-page] main.layout-page .hero-mast__slot {
  border-radius: 30px;
}

body[data-page] main.layout-page .hero-mast__panel p,
body[data-page] main.layout-page .hero-mast__signal span,
body[data-page] main.layout-page .hero-mast__lane span,
body[data-page] main.layout-page .hero-mast__topic span,
body[data-page] main.layout-page .hero-mast__legal-item span,
body[data-page] main.layout-page .hero-mast__route-card span {
  max-width: 26ch;
}

body[data-page] main.layout-page .hero-mast__route-card strong {
  font-size: clamp(1.22rem, 2vw, 1.72rem);
}

body[data-page] main.layout-page .hero-mast__route-card:first-child {
  border-color: rgba(255, 147, 95, 0.34);
  background:
    linear-gradient(180deg, rgba(255, 155, 111, 0.06), rgba(255, 255, 255, 0.008)),
    rgba(9, 15, 27, 0.8);
  box-shadow: 0 30px 68px rgba(0, 0, 0, 0.22);
}

body[data-page] main.layout-page .hero-mast__route-card-label {
  color: rgba(238, 244, 255, 0.78);
}

body[data-page] main.layout-page .hero-mast__ticker {
  display: none;
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__layout {
  grid-template-columns: minmax(0, 0.76fr) minmax(0, 1.24fr);
  align-items: center;
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__visual,
body[data-page="about"] main.layout-page .hero-mast__visual,
body[data-page="payments"] main.layout-page .hero-mast__visual {
  position: relative;
  min-height: clamp(28rem, 46vw, 44rem);
  border-radius: 34px;
  overflow: hidden;
  border: 1px solid rgba(149, 228, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(8, 14, 25, 0.18), rgba(4, 10, 18, 0.88)),
    radial-gradient(circle at 72% 78%, rgba(255, 150, 105, 0.18), transparent 22%),
    radial-gradient(circle at 38% 18%, rgba(149, 228, 255, 0.14), transparent 26%),
    rgba(3, 8, 16, 0.92);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 28px 80px rgba(0, 0, 0, 0.26);
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__visual::before,
body[data-page="about"] main.layout-page .hero-mast__visual::before,
body[data-page="payments"] main.layout-page .hero-mast__visual::before {
  content: "";
  position: absolute;
  inset: 0.9rem;
  border-radius: 26px;
  border: 1px solid rgba(244, 248, 255, 0.08);
  z-index: 3;
  pointer-events: none;
}

body[data-page] main.layout-page .hero-mast__media--cinematic {
  inset: 0;
  min-height: 100%;
  border-radius: 34px;
}

body[data-page] main.layout-page .hero-mast__media--cinematic img {
  filter: saturate(1.02) contrast(1.08) brightness(0.96);
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__media::after,
body[data-page="about"] main.layout-page .hero-mast__media::after,
body[data-page="payments"] main.layout-page .hero-mast__media::after {
  background:
    linear-gradient(102deg, rgba(4, 9, 17, 0.16) 0%, rgba(4, 9, 17, 0.34) 38%, rgba(4, 9, 17, 0.72) 100%),
    radial-gradient(circle at 74% 80%, rgba(255, 148, 103, 0.18), transparent 24%),
    radial-gradient(circle at 34% 16%, rgba(149, 228, 255, 0.12), transparent 26%);
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__overlay--grid,
body[data-page="about"] main.layout-page .hero-mast__overlay--grid,
body[data-page="payments"] main.layout-page .hero-mast__overlay--grid {
  background-size: 96px 96px;
  opacity: 0.52;
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__overlay--glow,
body[data-page="about"] main.layout-page .hero-mast__overlay--glow,
body[data-page="payments"] main.layout-page .hero-mast__overlay--glow {
  background:
    radial-gradient(circle at 20% 24%, rgba(125, 228, 255, 0.16), transparent 16%),
    radial-gradient(circle at 78% 72%, rgba(255, 150, 104, 0.18), transparent 20%);
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__brand-panel,
body[data-page="about"] main.layout-page .hero-mast__brand-panel,
body[data-page="payments"] main.layout-page .hero-mast__brand-panel {
  width: min(12rem, calc(100% - 2rem));
  gap: 0.55rem;
  padding: 0.8rem 0.9rem;
}

body[data-page] main.layout-page .hero-mast--split .hero-mast__brand-panel p,
body[data-page="about"] main.layout-page .hero-mast__brand-panel p,
body[data-page="payments"] main.layout-page .hero-mast__brand-panel p {
  max-width: 15ch;
  font-size: 0.84rem;
  line-height: 1.42;
}

body[data-page="home"] main.layout-page .hero-mast__brand-panel,
body[data-page="examples"] main.layout-page .hero-mast__brand-panel {
  display: none;
}

body[data-page="home"] main.layout-page .hero-mast__title {
  max-width: 6.1ch;
  font-size: clamp(4.4rem, 7.4vw, 7rem);
}

body[data-page="home"] main.layout-page .hero-mast__lede {
  max-width: 31rem;
}

body[data-page="home"] main.layout-page .hero-mast__visual::after {
  content: "";
  position: absolute;
  inset: auto -12% -22% 38%;
  height: 54%;
  border-radius: 999px;
  background:
    radial-gradient(circle at 38% 48%, rgba(255, 149, 102, 0.32), transparent 18%),
    radial-gradient(circle at 62% 38%, rgba(149, 228, 255, 0.18), transparent 26%);
  filter: blur(10px);
  z-index: 1;
  pointer-events: none;
}

body[data-page="home"] main.layout-page .hero-mast__chip-row--hero {
  max-width: 24rem;
}

body[data-page="examples"] main.layout-page .hero-mast__layout {
  grid-template-columns: minmax(0, 0.84fr) minmax(0, 1.16fr);
}

body[data-page="examples"] main.layout-page .hero-mast__chip-row--hero {
  left: auto;
  right: 1rem;
  justify-content: flex-end;
  max-width: 16rem;
}

body[data-page="examples"] main.layout-page .hero-mast__stats {
  left: 1rem;
  right: auto;
  bottom: 1rem;
  width: min(13rem, calc(100% - 2rem));
}

body[data-page="examples"] main.layout-page .hero-mast__route-line {
  left: auto;
  right: 1rem;
  bottom: 1rem;
}

body[data-page="about"] main.layout-page .hero-mast__layout,
body[data-page="payments"] main.layout-page .hero-mast__layout {
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
}

body[data-page="about"] main.layout-page .hero-mast__title,
body[data-page="payments"] main.layout-page .hero-mast__title {
  max-width: 8ch;
  font-size: clamp(3.4rem, 5.8vw, 5.8rem);
}

body[data-page="about"] main.layout-page .hero-mast__note {
  width: min(13rem, calc(100% - 2rem));
  padding: 0.75rem 0.85rem;
}

body[data-page="about"] main.layout-page .hero-mast__note span {
  font-size: 0.84rem;
  line-height: 1.38;
}

body[data-page="payments"] main.layout-page .hero-mast__stats {
  width: min(13rem, calc(100% - 2rem));
  bottom: 1rem;
}

body[data-page="payments"] main.layout-page .hero-mast__route-line {
  bottom: 1rem;
}

body[data-page] main.layout-page .hero-mast--signal .hero-mast__layout {
  grid-template-columns: minmax(0, 0.72fr) minmax(0, 1.28fr);
  align-items: start;
}

body[data-page] main.layout-page .hero-mast--signal .hero-mast__stage {
  align-content: start;
}

body[data-page] main.layout-page .hero-mast--signal .hero-mast__panel {
  padding: 1.1rem 1.15rem;
}

body[data-page] main.layout-page .hero-mast--signal .hero-mast__panel .section-visual {
  min-height: clamp(12rem, 22vw, 15rem);
}

body[data-page] main.layout-page .hero-mast--signal .hero-mast__signal-grid,
body[data-page] main.layout-page .hero-mast--signal .hero-mast__lane-grid,
body[data-page] main.layout-page .hero-mast--signal .hero-mast__legal-grid,
body[data-page] main.layout-page .hero-mast--signal .hero-mast__topic-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body[data-page="process"] main.layout-page .hero-mast__lane-grid,
body[data-page="accessibility"] main.layout-page .hero-mast__signal-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body[data-page] main.layout-page .hero-mast--route .hero-mast__layout {
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
}

body[data-page] main.layout-page .hero-mast--route .hero-mast__stage {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  align-items: stretch;
}

body[data-page] main.layout-page .hero-mast--route .hero-mast__panel {
  min-height: 100%;
  align-content: end;
}

body[data-page] main.layout-page .hero-mast__route-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body[data-page="discovery"] main.layout-page .hero-mast__route-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="contact"] main.layout-page .hero-mast__route-card:first-child,
body[data-page="launch"] main.layout-page .hero-mast__route-card:first-child,
body[data-page="discovery"] main.layout-page .hero-mast__route-card:first-child {
  transform: translateY(-0.15rem);
}

body[data-page="schedule"] main.layout-page .hero-mast__layout,
body[data-page="accessibility"] main.layout-page .hero-mast__layout {
  grid-template-columns: minmax(0, 0.76fr) minmax(0, 1.24fr);
}

body[data-page="schedule"] main.layout-page .hero-mast__stage,
body[data-page="accessibility"] main.layout-page .hero-mast__stage {
  align-content: start;
}

body[data-page="schedule"] main.layout-page .hero-mast__panel .section-visual,
body[data-page="accessibility"] main.layout-page .hero-mast__panel .section-visual {
  min-height: clamp(12rem, 20vw, 15rem);
}

@media (max-width: 1199px) {
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__signal-grid,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__lane-grid,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__legal-grid,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__topic-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page] main.layout-page .hero-mast__route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 979px) {
  body[data-page] main.layout-page .hero-mast__layout,
  body[data-page] main.layout-page .hero-mast--split .hero-mast__layout,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__layout,
  body[data-page] main.layout-page .hero-mast--route .hero-mast__layout,
  body[data-page="about"] main.layout-page .hero-mast__layout,
  body[data-page="payments"] main.layout-page .hero-mast__layout,
  body[data-page="schedule"] main.layout-page .hero-mast__layout,
  body[data-page="accessibility"] main.layout-page .hero-mast__layout,
  body[data-page="examples"] main.layout-page .hero-mast__layout {
    grid-template-columns: 1fr;
  }

  body[data-page] main.layout-page .hero-mast__copy {
    padding-right: clamp(0.5rem, 1.4vw, 1rem);
  }

  body[data-page] main.layout-page .hero-mast__stage,
  body[data-page] main.layout-page .hero-mast--route .hero-mast__stage {
    min-height: auto;
    grid-template-columns: 1fr;
  }

  body[data-page] main.layout-page .hero-mast__route-grid,
  body[data-page="process"] main.layout-page .hero-mast__lane-grid,
  body[data-page="accessibility"] main.layout-page .hero-mast__signal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 759px) {
  body[data-page] main.layout-page .hero-mast__frame {
    min-height: auto;
    border-radius: 32px;
  }

  body[data-page] main.layout-page .hero-mast__frame::after,
  body[data-page="home"] main.layout-page .hero-mast__visual::after {
    display: none;
  }

  body[data-page] main.layout-page .hero-mast__title,
  body[data-page="home"] main.layout-page .hero-mast__title,
  body[data-page="about"] main.layout-page .hero-mast__title,
  body[data-page="payments"] main.layout-page .hero-mast__title {
    max-width: 7.4ch;
    font-size: clamp(2.9rem, 12vw, 4.8rem);
  }

  body[data-page] main.layout-page .hero-mast__visual,
  body[data-page="about"] main.layout-page .hero-mast__visual,
  body[data-page="payments"] main.layout-page .hero-mast__visual {
    min-height: 18rem;
  }

  body[data-page] main.layout-page .hero-mast__overlay {
    display: none;
  }

  body[data-page] main.layout-page .hero-mast__chip-row--hero,
  body[data-page] main.layout-page .hero-mast__badge,
  body[data-page] main.layout-page .hero-mast__stats,
  body[data-page] main.layout-page .hero-mast__route-line,
  body[data-page] main.layout-page .hero-mast__note {
    position: static;
    width: auto;
  }

  body[data-page] main.layout-page .hero-mast__visual {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
    align-content: end;
  }

  body[data-page] main.layout-page .hero-mast__chip-row--hero {
    justify-content: flex-start;
    max-width: 100%;
  }

  body[data-page="examples"] main.layout-page .hero-mast__chip-row--hero {
    justify-content: flex-start;
  }

  body[data-page] main.layout-page .hero-mast__stats {
    display: grid;
    gap: 0.75rem;
  }

  body[data-page] main.layout-page .hero-mast__route-grid,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__signal-grid,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__lane-grid,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__legal-grid,
  body[data-page] main.layout-page .hero-mast--signal .hero-mast__topic-grid,
  body[data-page="process"] main.layout-page .hero-mast__lane-grid,
  body[data-page="accessibility"] main.layout-page .hero-mast__signal-grid,
  body[data-page] main.layout-page .hero-mast__calendar-row {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   Consolidated Inline Styles
   These rules used to live in page markup or tiny partial style blocks.
   Keep page-specific CSS here so the HTML stays clean and the cascade remains visible.
   ========================================================================== */

/* Component: Partial hosts
   Keeps injected header/footer wrappers neutral without adding inline display styles. */
[data-site-partial],
[data-site-header],
[data-site-footer] {
  display: contents;
}

/* Component: Header partial states
   Highlights the active navigation route and the open mobile-toggle state. */
[data-partial-root="site-header"] .site-nav__links a[aria-current="page"] {
  color: var(--text);
  background: rgba(255, 255, 255, 0.07);
}

[data-partial-root="site-header"] .site-header[data-nav-state="open"] .site-header__toggle {
  border-color: rgba(130, 229, 255, 0.24);
  background: rgba(255, 255, 255, 0.08);
}

/* Component: Homepage video statement
   Preserves the full-screen cinematic homepage block that used to be inline-styled. */
#home-cover .premium-video-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #050816;
  color: #ffffff;
  text-align: center;
  padding: 40px 20px;
}

#home-cover .premium-video-hero__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: 0.9;
}

#home-cover .premium-video-hero__shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at center, rgba(13, 18, 36, 0.18) 0%, rgba(5, 8, 22, 0.68) 55%, rgba(3, 5, 14, 0.9) 100%),
    linear-gradient(to bottom, rgba(4, 7, 18, 0.68) 0%, rgba(4, 7, 18, 0.42) 35%, rgba(4, 7, 18, 0.82) 100%);
}

#home-cover .premium-video-hero__glow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(72vw, 900px);
  height: min(72vw, 900px);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(58, 110, 255, 0.18) 0%, rgba(58, 110, 255, 0.06) 35%, rgba(58, 110, 255, 0) 70%);
  filter: blur(18px);
  z-index: 1;
}

#home-cover .premium-video-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 900px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
}

#home-cover .premium-video-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(10px);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.82);
  box-shadow: 0 0 30px rgba(53, 102, 255, 0.08);
}

#home-cover .premium-video-hero__title {
  margin: 0;
  max-width: 900px;
  font-size: clamp(42px, 7vw, 88px);
  line-height: 0.95;
  letter-spacing: -0.04em;
  font-weight: 800;
  text-wrap: balance;
  color: #ffffff;
  text-shadow: 0 10px 40px rgba(0, 0, 0, 0.35);
}

#home-cover .premium-video-hero__break {
  display: none;
}

#home-cover .premium-video-hero__lede {
  margin: 0;
  max-width: 700px;
  font-size: clamp(17px, 2vw, 22px);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.82);
  text-wrap: pretty;
}

#home-cover .premium-video-hero__actions,
#home-cover .premium-video-hero__chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

#home-cover .premium-video-hero__actions {
  gap: 14px;
  margin-top: 8px;
}

#home-cover .premium-video-hero__chips {
  gap: 10px;
  margin-top: 10px;
}

#home-cover .premium-video-hero__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 24px;
  border-radius: 999px;
  color: #ffffff;
  text-decoration: none;
  font-size: 15px;
  letter-spacing: 0.01em;
}

#home-cover .premium-video-hero__button--primary {
  background: linear-gradient(135deg, #6ca8ff 0%, #2e6bff 55%, #1742c8 100%);
  font-weight: 700;
  box-shadow: 0 18px 50px rgba(43, 103, 255, 0.38), inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

#home-cover .premium-video-hero__button--secondary {
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(10px);
  font-weight: 600;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.18);
}

#home-cover .premium-video-hero__chip {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  backdrop-filter: blur(8px);
}

/* Motion support: Reveal delays
   Replaces inline transition-delay values with small data-driven CSS states. */
[data-reveal-delay="1"] { transition-delay: 70ms; }
[data-reveal-delay="2"] { transition-delay: 140ms; }
[data-reveal-delay="3"] { transition-delay: 210ms; }
[data-reveal-delay="4"] { transition-delay: 280ms; }

/* Motion support: Orbot panel state
   Locks background scrolling through a body class instead of inline overflow styles. */
body.has-orbot-open {
  overflow: hidden;
}

/* Decorative page ambient overlays
   Positions the two handwritten neon overlays that sit behind each page layout. */
body[data-page] main.layout-page > .page-ambient img.page-ambient__image--about-brand-positioning-neon-atlas-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-11rem, -4vw, -2rem);
  width: min(48vw, 42rem);
  opacity: 0.19;
  transform: rotate(-11deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--about-business-perception-neon-manifesto-section-overlay {
  top: clamp(66rem, 88vw, 112rem);
  left: clamp(-14rem, -6vw, -2rem);
  width: min(46vw, 39rem);
  opacity: 0.12;
  transform: rotate(8deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--accessibility-web-usability-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(44vw, 38rem);
  opacity: 0.16;
  transform: rotate(-9deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--accessibility-inclusive-navigation-neon-section-overlay {
  top: clamp(54rem, 72vw, 88rem);
  left: clamp(-12rem, -5vw, -2rem);
  width: min(40vw, 34rem);
  opacity: 0.1;
  transform: rotate(7deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--contact-project-enquiry-neon-route-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(49vw, 43rem);
  opacity: 0.2;
  transform: rotate(-9deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--contact-consultation-path-neon-section-overlay {
  top: clamp(58rem, 78vw, 98rem);
  left: clamp(-15rem, -7vw, -3rem);
  width: min(46vw, 39rem);
  opacity: 0.12;
  transform: rotate(8deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--cookies-policy-preferences-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(43vw, 37rem);
  opacity: 0.16;
  transform: rotate(-9deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--cookies-consent-choice-neon-section-overlay {
  top: clamp(50rem, 68vw, 84rem);
  left: clamp(-12rem, -5vw, -2rem);
  width: min(39vw, 33rem);
  opacity: 0.1;
  transform: rotate(6deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--discovery-consultation-choice-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-11rem, -4vw, -2rem);
  width: min(48vw, 42rem);
  opacity: 0.19;
  transform: rotate(-8deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--discovery-project-questionnaire-neon-section-overlay {
  top: clamp(56rem, 75vw, 96rem);
  left: clamp(-14rem, -6vw, -3rem);
  width: min(46vw, 39rem);
  opacity: 0.12;
  transform: rotate(7deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--examples-website-portfolio-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-11rem, -4vw, -2rem);
  width: min(50vw, 44rem);
  opacity: 0.2;
  transform: rotate(-7deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--examples-case-study-gallery-neon-section-overlay {
  top: clamp(60rem, 80vw, 102rem);
  left: clamp(-15rem, -7vw, -3rem);
  width: min(48vw, 40rem);
  opacity: 0.12;
  transform: rotate(9deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--faq-website-questions-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(46vw, 39rem);
  opacity: 0.18;
  transform: rotate(-8deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--faq-support-topics-neon-section-overlay {
  top: clamp(58rem, 78vw, 98rem);
  left: clamp(-14rem, -6vw, -3rem);
  width: min(44vw, 37rem);
  opacity: 0.11;
  transform: rotate(8deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--home-premium-website-design-neon-hero-overlay {
  top: clamp(4rem, 7vw, 7rem);
  right: clamp(-12rem, -5vw, -3rem);
  width: min(54vw, 48rem);
  opacity: 0.22;
  transform: rotate(-7deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--home-premium-website-growth-neon-section-overlay {
  top: clamp(58rem, 76vw, 94rem);
  left: clamp(-16rem, -7vw, -3rem);
  width: min(50vw, 42rem);
  opacity: 0.13;
  transform: rotate(9deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--invest-website-investment-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(46vw, 40rem);
  opacity: 0.18;
  transform: rotate(-10deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--invest-growth-levels-neon-section-overlay {
  top: clamp(58rem, 78vw, 98rem);
  left: clamp(-14rem, -6vw, -2rem);
  width: min(42vw, 36rem);
  opacity: 0.11;
  transform: rotate(8deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--launch-website-project-intake-neon-hero-overlay {
  top: clamp(4rem, 7vw, 7rem);
  right: clamp(-11rem, -5vw, -2rem);
  width: min(53vw, 47rem);
  opacity: 0.22;
  transform: rotate(-7deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--launch-fast-lane-neon-section-overlay {
  top: clamp(54rem, 72vw, 92rem);
  left: clamp(-14rem, -6vw, -2rem);
  width: min(47vw, 40rem);
  opacity: 0.13;
  transform: rotate(9deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--payments-strategy-consultation-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(46vw, 40rem);
  opacity: 0.18;
  transform: rotate(-10deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--payments-project-clarity-neon-section-overlay {
  top: clamp(52rem, 68vw, 86rem);
  left: clamp(-14rem, -6vw, -2rem);
  width: min(42vw, 36rem);
  opacity: 0.11;
  transform: rotate(8deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--privacy-data-policy-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(44vw, 38rem);
  opacity: 0.16;
  transform: rotate(-10deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--privacy-information-handling-neon-section-overlay {
  top: clamp(52rem, 70vw, 88rem);
  left: clamp(-12rem, -5vw, -2rem);
  width: min(40vw, 34rem);
  opacity: 0.1;
  transform: rotate(7deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--process-web-design-route-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-12rem, -5vw, -3rem);
  width: min(50vw, 44rem);
  opacity: 0.19;
  transform: rotate(-8deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--process-project-timeline-neon-section-overlay {
  top: clamp(60rem, 80vw, 102rem);
  left: clamp(-14rem, -6vw, -3rem);
  width: min(46vw, 39rem);
  opacity: 0.12;
  transform: rotate(10deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--schedule-consultation-booking-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(44vw, 38rem);
  opacity: 0.17;
  transform: rotate(-9deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--schedule-time-slot-neon-section-overlay {
  top: clamp(50rem, 66vw, 82rem);
  left: clamp(-12rem, -5vw, -2rem);
  width: min(40vw, 34rem);
  opacity: 0.11;
  transform: rotate(7deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--services-website-services-neon-system-hero-overlay {
  top: clamp(5rem, 7vw, 7rem);
  right: clamp(-13rem, -5vw, -3rem);
  width: min(52vw, 46rem);
  opacity: 0.2;
  transform: rotate(-6deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--services-digital-growth-neon-panel-section-overlay {
  top: clamp(64rem, 82vw, 108rem);
  left: clamp(-14rem, -6vw, -2rem);
  width: min(48vw, 40rem);
  opacity: 0.12;
  transform: rotate(7deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--terms-service-agreement-neon-hero-overlay {
  top: clamp(5rem, 8vw, 8rem);
  right: clamp(-10rem, -4vw, -2rem);
  width: min(44vw, 38rem);
  opacity: 0.16;
  transform: rotate(-11deg);
}

body[data-page] main.layout-page > .page-ambient img.page-ambient__image--terms-commercial-scope-neon-section-overlay {
  top: clamp(54rem, 72vw, 90rem);
  left: clamp(-12rem, -5vw, -2rem);
  width: min(40vw, 34rem);
  opacity: 0.1;
  transform: rotate(7deg);
}

/* Motion support: Deterministic star field
   Provides per-star placement, timing, opacity, and scale without inline JS styles. */
.site-stage__star:nth-child(1) {
  left: 48%;
  top: 66%;
  animation-delay: 1.7s;
  animation-duration: 6.3s;
  opacity: 0.57;
  transform: scale(0.86);
}

.site-stage__star:nth-child(2) {
  left: 96%;
  top: 32%;
  animation-delay: 3.4s;
  animation-duration: 8.6s;
  opacity: 0.86;
  transform: scale(1.17);
}

.site-stage__star:nth-child(3) {
  left: 44%;
  top: 98%;
  animation-delay: 5.1s;
  animation-duration: 4.9s;
  opacity: 0.43;
  transform: scale(1.48);
}

.site-stage__star:nth-child(4) {
  left: 92%;
  top: 64%;
  animation-delay: 0.8s;
  animation-duration: 7.2s;
  opacity: 0.72;
  transform: scale(1.79);
}

.site-stage__star:nth-child(5) {
  left: 40%;
  top: 65%;
  animation-delay: 2.5s;
  animation-duration: 9.5s;
  opacity: 0.29;
  transform: scale(0.70);
}

.site-stage__star:nth-child(6) {
  left: 88%;
  top: 31%;
  animation-delay: 4.2s;
  animation-duration: 5.8s;
  opacity: 0.58;
  transform: scale(1.01);
}

.site-stage__star:nth-child(7) {
  left: 59%;
  top: 97%;
  animation-delay: 5.9s;
  animation-duration: 8.1s;
  opacity: 0.87;
  transform: scale(1.32);
}

.site-stage__star:nth-child(8) {
  left: 7%;
  top: 63%;
  animation-delay: 1.6s;
  animation-duration: 4.4s;
  opacity: 0.44;
  transform: scale(1.63);
}

.site-stage__star:nth-child(9) {
  left: 55%;
  top: 29%;
  animation-delay: 3.3s;
  animation-duration: 6.7s;
  opacity: 0.73;
  transform: scale(1.94);
}

.site-stage__star:nth-child(10) {
  left: 3%;
  top: 30%;
  animation-delay: 5.0s;
  animation-duration: 9.0s;
  opacity: 0.30;
  transform: scale(0.85);
}

.site-stage__star:nth-child(11) {
  left: 51%;
  top: 96%;
  animation-delay: 0.7s;
  animation-duration: 5.3s;
  opacity: 0.59;
  transform: scale(1.16);
}

.site-stage__star:nth-child(12) {
  left: 99%;
  top: 62%;
  animation-delay: 2.4s;
  animation-duration: 7.6s;
  opacity: 0.88;
  transform: scale(1.47);
}

.site-stage__star:nth-child(13) {
  left: 47%;
  top: 28%;
  animation-delay: 4.1s;
  animation-duration: 9.9s;
  opacity: 0.45;
  transform: scale(1.78);
}

.site-stage__star:nth-child(14) {
  left: 18%;
  top: 94%;
  animation-delay: 5.8s;
  animation-duration: 6.2s;
  opacity: 0.74;
  transform: scale(0.69);
}

.site-stage__star:nth-child(15) {
  left: 66%;
  top: 95%;
  animation-delay: 1.5s;
  animation-duration: 8.5s;
  opacity: 0.31;
  transform: scale(1.00);
}

.site-stage__star:nth-child(16) {
  left: 14%;
  top: 61%;
  animation-delay: 3.2s;
  animation-duration: 4.8s;
  opacity: 0.60;
  transform: scale(1.31);
}

.site-stage__star:nth-child(17) {
  left: 62%;
  top: 27%;
  animation-delay: 4.9s;
  animation-duration: 7.1s;
  opacity: 0.89;
  transform: scale(1.62);
}

.site-stage__star:nth-child(18) {
  left: 10%;
  top: 93%;
  animation-delay: 0.6s;
  animation-duration: 9.4s;
  opacity: 0.46;
  transform: scale(1.93);
}

.site-stage__star:nth-child(19) {
  left: 58%;
  top: 59%;
  animation-delay: 2.3s;
  animation-duration: 5.7s;
  opacity: 0.75;
  transform: scale(0.84);
}

.site-stage__star:nth-child(20) {
  left: 6%;
  top: 60%;
  animation-delay: 4.0s;
  animation-duration: 8.0s;
  opacity: 0.32;
  transform: scale(1.15);
}

.site-stage__star:nth-child(21) {
  left: 77%;
  top: 26%;
  animation-delay: 5.7s;
  animation-duration: 4.3s;
  opacity: 0.61;
  transform: scale(1.46);
}

.site-stage__star:nth-child(22) {
  left: 25%;
  top: 92%;
  animation-delay: 1.4s;
  animation-duration: 6.6s;
  opacity: 0.90;
  transform: scale(1.77);
}

.site-stage__star:nth-child(23) {
  left: 73%;
  top: 58%;
  animation-delay: 3.1s;
  animation-duration: 8.9s;
  opacity: 0.47;
  transform: scale(0.68);
}

.site-stage__star:nth-child(24) {
  left: 21%;
  top: 24%;
  animation-delay: 4.8s;
  animation-duration: 5.2s;
  opacity: 0.76;
  transform: scale(0.99);
}

.site-stage__star:nth-child(25) {
  left: 69%;
  top: 25%;
  animation-delay: 0.5s;
  animation-duration: 7.5s;
  opacity: 0.33;
  transform: scale(1.30);
}

.site-stage__star:nth-child(26) {
  left: 17%;
  top: 91%;
  animation-delay: 2.2s;
  animation-duration: 9.8s;
  opacity: 0.62;
  transform: scale(1.61);
}

.site-stage__star:nth-child(27) {
  left: 65%;
  top: 57%;
  animation-delay: 3.9s;
  animation-duration: 6.1s;
  opacity: 0.91;
  transform: scale(1.92);
}

.site-stage__star:nth-child(28) {
  left: 36%;
  top: 23%;
  animation-delay: 5.6s;
  animation-duration: 8.4s;
  opacity: 0.48;
  transform: scale(0.83);
}

.site-stage__star:nth-child(29) {
  left: 84%;
  top: 89%;
  animation-delay: 1.3s;
  animation-duration: 4.7s;
  opacity: 0.77;
  transform: scale(1.14);
}

.site-stage__star:nth-child(30) {
  left: 32%;
  top: 90%;
  animation-delay: 3.0s;
  animation-duration: 7.0s;
  opacity: 0.34;
  transform: scale(1.45);
}

.site-stage__star:nth-child(31) {
  left: 80%;
  top: 56%;
  animation-delay: 4.7s;
  animation-duration: 9.3s;
  opacity: 0.63;
  transform: scale(1.76);
}

.site-stage__star:nth-child(32) {
  left: 28%;
  top: 22%;
  animation-delay: 0.4s;
  animation-duration: 5.6s;
  opacity: 0.92;
  transform: scale(0.67);
}

.site-stage__star:nth-child(33) {
  left: 76%;
  top: 88%;
  animation-delay: 2.1s;
  animation-duration: 7.9s;
  opacity: 0.49;
  transform: scale(0.98);
}

.site-stage__star:nth-child(34) {
  left: 24%;
  top: 54%;
  animation-delay: 3.8s;
  animation-duration: 4.2s;
  opacity: 0.78;
  transform: scale(1.29);
}

.site-stage__star:nth-child(35) {
  left: 95%;
  top: 55%;
  animation-delay: 5.5s;
  animation-duration: 6.5s;
  opacity: 0.35;
  transform: scale(1.60);
}

.site-stage__star:nth-child(36) {
  left: 43%;
  top: 21%;
  animation-delay: 1.2s;
  animation-duration: 8.8s;
  opacity: 0.64;
  transform: scale(1.91);
}

.site-stage__star:nth-child(37) {
  left: 91%;
  top: 87%;
  animation-delay: 2.9s;
  animation-duration: 5.1s;
  opacity: 0.93;
  transform: scale(0.82);
}

.site-stage__star:nth-child(38) {
  left: 39%;
  top: 53%;
  animation-delay: 4.6s;
  animation-duration: 7.4s;
  opacity: 0.50;
  transform: scale(1.13);
}

.site-stage__star:nth-child(39) {
  left: 87%;
  top: 19%;
  animation-delay: 0.3s;
  animation-duration: 9.7s;
  opacity: 0.79;
  transform: scale(1.44);
}

.site-stage__star:nth-child(40) {
  left: 35%;
  top: 20%;
  animation-delay: 2.0s;
  animation-duration: 6.0s;
  opacity: 0.36;
  transform: scale(1.75);
}

.site-stage__star:nth-child(41) {
  left: 83%;
  top: 86%;
  animation-delay: 3.7s;
  animation-duration: 8.3s;
  opacity: 0.65;
  transform: scale(0.66);
}

.site-stage__star:nth-child(42) {
  left: 54%;
  top: 52%;
  animation-delay: 5.4s;
  animation-duration: 4.6s;
  opacity: 0.94;
  transform: scale(0.97);
}

.site-stage__star:nth-child(43) {
  left: 2%;
  top: 18%;
  animation-delay: 1.1s;
  animation-duration: 6.9s;
  opacity: 0.51;
  transform: scale(1.28);
}

.site-stage__star:nth-child(44) {
  left: 50%;
  top: 84%;
  animation-delay: 2.8s;
  animation-duration: 9.2s;
  opacity: 0.80;
  transform: scale(1.59);
}

.site-stage__star:nth-child(45) {
  left: 98%;
  top: 85%;
  animation-delay: 4.5s;
  animation-duration: 5.5s;
  opacity: 0.37;
  transform: scale(1.90);
}

.site-stage__star:nth-child(46) {
  left: 46%;
  top: 51%;
  animation-delay: 0.2s;
  animation-duration: 7.8s;
  opacity: 0.66;
  transform: scale(0.81);
}

.site-stage__star:nth-child(47) {
  left: 94%;
  top: 17%;
  animation-delay: 1.9s;
  animation-duration: 4.1s;
  opacity: 0.95;
  transform: scale(1.12);
}

.site-stage__star:nth-child(48) {
  left: 42%;
  top: 83%;
  animation-delay: 3.6s;
  animation-duration: 6.4s;
  opacity: 0.52;
  transform: scale(1.43);
}

.site-stage__star:nth-child(49) {
  left: 13%;
  top: 49%;
  animation-delay: 5.3s;
  animation-duration: 8.7s;
  opacity: 0.81;
  transform: scale(1.74);
}

.site-stage__star:nth-child(50) {
  left: 61%;
  top: 50%;
  animation-delay: 1.0s;
  animation-duration: 5.0s;
  opacity: 0.38;
  transform: scale(0.65);
}

.site-stage__star:nth-child(51) {
  left: 9%;
  top: 16%;
  animation-delay: 2.7s;
  animation-duration: 7.3s;
  opacity: 0.67;
  transform: scale(0.96);
}

.site-stage__star:nth-child(52) {
  left: 57%;
  top: 82%;
  animation-delay: 4.4s;
  animation-duration: 9.6s;
  opacity: 0.96;
  transform: scale(1.27);
}

.site-stage__star:nth-child(53) {
  left: 5%;
  top: 48%;
  animation-delay: 0.1s;
  animation-duration: 5.9s;
  opacity: 0.53;
  transform: scale(1.58);
}

.site-stage__star:nth-child(54) {
  left: 53%;
  top: 14%;
  animation-delay: 1.8s;
  animation-duration: 8.2s;
  opacity: 0.82;
  transform: scale(1.89);
}

.site-stage__star:nth-child(55) {
  left: 1%;
  top: 15%;
  animation-delay: 3.5s;
  animation-duration: 4.5s;
  opacity: 0.39;
  transform: scale(0.80);
}

.site-stage__star:nth-child(56) {
  left: 72%;
  top: 81%;
  animation-delay: 5.2s;
  animation-duration: 6.8s;
  opacity: 0.68;
  transform: scale(1.11);
}

/* Page Section: Home / #home-cover
   Homepage cover shell: keeps the cinematic video hero spacing consistent. */
#home-cover {
  padding: clamp(1rem, 2vw, 2rem) 0 0;
}

/* Page Section: About / #about-signal
   About signal section: positioning narrative, media composition, and responsive signal cards. */
#about-signal {
  padding-top: clamp(1rem, 2vw, 2rem);
}

#about-signal .about-signal__frame {
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
  padding: clamp(1rem, 2vw, 1.6rem);
  border-radius: 2.6rem;
  border: 1px solid rgba(144, 229, 255, 0.14);
  background:
    radial-gradient(circle at 15% 16%, rgba(121, 227, 255, 0.12), transparent 20%),
    radial-gradient(circle at 86% 18%, rgba(255, 177, 132, 0.14), transparent 26%),
    linear-gradient(155deg, rgba(6, 11, 22, 0.98), rgba(10, 18, 33, 0.94));
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
  gap: 1.2rem;
  box-shadow: 0 30px 110px rgba(0, 0, 0, 0.3);
}

#about-signal .about-signal__copy,
#about-signal .about-signal__board {
  display: grid;
  align-content: center;
  gap: 1rem;
}

#about-signal .about-signal__eyebrow,
#about-signal .about-signal__mini {
  font: 500 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(226, 233, 243, 0.72);
}

#about-signal h1,
#about-signal h2,
#about-signal h3 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.07em;
}

#about-signal h1 {
  max-width: 8ch;
  font-size: clamp(3.2rem, 6vw, 6rem);
  line-height: 0.92;
}

#about-signal h2 {
  font-size: clamp(1.4rem, 2.6vw, 2.2rem);
  line-height: 0.98;
}

#about-signal h3 {
  font-size: 1.08rem;
  line-height: 1.02;
}

#about-signal p {
  margin: 0;
  color: rgba(220, 228, 238, 0.82);
  font: 500 clamp(1rem, 1.35vw, 1.08rem) / 1.62 "Manrope", sans-serif;
}

#about-signal .about-signal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

#about-signal .about-signal__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0 1.1rem;
  border-radius: 999px;
  text-decoration: none;
  font: 700 0.92rem/1 "Manrope", sans-serif;
}

#about-signal .about-signal__action--primary {
  border: 0;
  color: #07111d;
  background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff);
}

#about-signal .about-signal__action--secondary {
  border: 1px solid rgba(138, 225, 255, 0.16);
  color: #edf3fb;
  background: rgba(255, 255, 255, 0.028);
}

#about-signal .about-signal__pill-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

#about-signal .about-signal__pill {
  display: grid;
  gap: 0.35rem;
  min-height: 100%;
  padding: 0.95rem 1rem;
  border-radius: 1.3rem;
  border: 1px solid rgba(138, 225, 255, 0.14);
  background: rgba(255, 255, 255, 0.03);
}

#about-signal .about-signal__scene {
  position: relative;
  min-height: clamp(22rem, 38vw, 34rem);
  border-radius: 2rem;
  overflow: hidden;
  border: 1px solid rgba(138, 225, 255, 0.14);
  background: rgba(4, 8, 18, 0.86);
}

#about-signal .about-signal__scene img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#about-signal .about-signal__scene-image {
  filter: saturate(0.95) contrast(1.08) brightness(0.86);
  transform: scale(1.05);
}

#about-signal .about-signal__scene-overlay {
  opacity: 0.22;
  mix-blend-mode: screen;
}

#about-signal .about-signal__scene-shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(4, 8, 18, 0.06), rgba(4, 8, 18, 0.78)),
    linear-gradient(100deg, rgba(4, 8, 18, 0.72), rgba(4, 8, 18, 0.18) 48%, rgba(4, 8, 18, 0.84));
}

#about-signal .about-signal__note {
  position: absolute;
  z-index: 2;
  width: min(16rem, calc(100% - 2rem));
  padding: 0.9rem 1rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(138, 225, 255, 0.16);
  background: rgba(8, 14, 27, 0.74);
  backdrop-filter: blur(16px);
  display: grid;
  gap: 0.35rem;
}

#about-signal .about-signal__note--top {
  top: 1rem;
  left: 1rem;
}

#about-signal .about-signal__note--middle {
  right: 1rem;
  top: 42%;
  transform: translateY(-50%);
}

#about-signal .about-signal__note--bottom {
  left: 1rem;
  bottom: 1rem;
}

#about-signal .about-signal__rail {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

#about-signal .about-signal__step {
  display: grid;
  gap: 0.45rem;
  padding: 1rem;
  border-radius: 1.35rem;
  border: 1px solid rgba(138, 225, 255, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.032), rgba(255, 255, 255, 0.01)),
    rgba(8, 13, 24, 0.74);
}

#about-signal .about-signal__step p,
#about-signal .about-signal__pill p,
#about-signal .about-signal__note p {
  font-size: 0.92rem;
  line-height: 1.55;
}

#about-signal .about-signal__step strong,
#about-signal .about-signal__pill strong {
  color: #f5f7fb;
  font-size: 1rem;
  letter-spacing: -0.03em;
}

#about-signal .about-signal__punch {
  color: rgba(121, 227, 255, 0.92);
  font-family: "IBM Plex Mono", monospace;
  font-size: 0.76rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

#about-signal .about-fit-callout {
  margin-top: 1rem;
}

@media (max-width: 980px) {
  #about-signal .about-signal__frame {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  #about-signal .about-signal__frame {
    width: min(100%, calc(100% - 1rem));
  }

  #about-signal .about-signal__actions,
  #about-signal .about-signal__pill-list,
  #about-signal .about-signal__rail {
    display: grid;
  }

  #about-signal .about-signal__action {
    width: 100%;
  }

  #about-signal .about-signal__note {
    position: static;
    width: auto;
    margin: 1rem;
    transform: none;
  }
}

/* Page Section: Accessibility / #access-grid
   Accessibility grid section: policy intro, inclusive usability cards, and mobile stacking. */
#access-grid { padding-top: clamp(1rem, 2vw, 2rem); }

#access-grid .access-grid__frame {
  width: min(90rem, calc(100% - 2rem)); margin: 0 auto; padding: clamp(1rem, 1.8vw, 1.5rem);
  position: relative; overflow: hidden;
  border-radius: 2.1rem; border: 1px solid rgba(140,226,255,0.14);
  background:
    linear-gradient(145deg, rgba(8,12,22,0.88), rgba(10,18,32,0.94)),
    url("/assets/media/stock/space/premium-website-services-galaxy-field.webp") center/cover no-repeat;
  display: grid; gap: 1rem; box-shadow: 0 28px 100px rgba(0,0,0,0.26);
}
#access-grid .access-grid__frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("/assets/media/overlays/premium-website-neon-orbit-grid-overlay.svg") center/cover no-repeat;
  opacity: 0.12;
  mix-blend-mode: screen;
  pointer-events: none;
}
#access-grid .access-grid__eyebrow, #access-grid .access-grid__item strong { font: 500 0.72rem/1 "IBM Plex Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(225,232,242,0.72); }
#access-grid h1 { margin: 0; max-width: 8ch; color: #f5f7fb; font: 700 clamp(2.8rem, 6vw, 5.2rem)/0.94 "Syne", sans-serif; letter-spacing: -0.07em; }
#access-grid p { margin: 0; color: rgba(220,228,239,0.82); font: 500 clamp(0.96rem, 1.2vw, 1.02rem)/1.6 "Manrope", sans-serif; }
#access-grid .access-grid__action { display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0 1.1rem; border-radius: 999px; text-decoration: none; border: 1px solid rgba(140,226,255,0.16); color: #edf3fb; background: rgba(255,255,255,0.03); font: 700 0.92rem/1 "Manrope", sans-serif; }
#access-grid .access-grid__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.75rem; }
#access-grid .access-grid__item { padding: 1rem; border-radius: 1.25rem; border: 1px solid rgba(140,226,255,0.12); background: rgba(255,255,255,0.02); display: grid; gap: 0.45rem; }
#access-grid .access-grid__eyebrow, #access-grid h1, #access-grid p, #access-grid .access-grid__action, #access-grid .access-grid__grid, #access-grid .access-grid__item { position: relative; z-index: 1; }
@media (max-width: 900px) { #access-grid .access-grid__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 720px) { #access-grid .access-grid__frame { width: min(100%, calc(100% - 1rem)); } #access-grid .access-grid__grid { grid-template-columns: 1fr; } #access-grid .access-grid__action { width: 100%; } }

/* Page Section: Contact / #contact-routes
   Contact routes section: interactive contact route hero and supporting cards. */
#contact-routes { --mx: 0; --my: 0; padding-top: clamp(1rem, 2vw, 2rem); }

#contact-routes .contact-routes__frame {
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
  padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.4rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    radial-gradient(circle at 12% 18%, rgba(140, 226, 255, 0.12), transparent 20%),
    radial-gradient(circle at 88% 16%, rgba(255, 145, 100, 0.12), transparent 24%),
    linear-gradient(145deg, rgba(6, 10, 20, 0.98), rgba(9, 17, 31, 0.94));
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(0, 1.28fr);
  gap: 1.2rem;
  box-shadow: 0 30px 110px rgba(0, 0, 0, 0.28);
}
#contact-routes .contact-routes__copy { display: grid; align-content: center; gap: 0.95rem; }
#contact-routes .contact-routes__eyebrow, #contact-routes .contact-routes__route-id {
  font: 500 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(225, 232, 242, 0.72);
}
#contact-routes h1, #contact-routes h2 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.07em;
}
#contact-routes h1 { max-width: 7ch; font-size: clamp(3rem, 6vw, 5.8rem); line-height: 0.92; }
#contact-routes p { margin: 0; color: rgba(220, 228, 239, 0.82); font: 500 clamp(0.98rem, 1.3vw, 1.06rem)/1.6 "Manrope", sans-serif; }
#contact-routes .contact-routes__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }
#contact-routes .contact-routes__action {
  display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0 1.1rem;
  border-radius: 999px; border: 1px solid rgba(140, 226, 255, 0.16); text-decoration: none; color: #edf3fb;
  background: rgba(255, 255, 255, 0.03); font: 700 0.92rem/1 "Manrope", sans-serif;
}
#contact-routes .contact-routes__action--primary { background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff); color: #07111d; border: 0; }
#contact-routes .contact-routes__stage { display: grid; grid-template-columns: minmax(0, 1.1fr) repeat(3, minmax(0, 0.74fr)); gap: 0.9rem; align-items: stretch; }
#contact-routes .contact-routes__lead, #contact-routes .contact-routes__card {
  padding: 1rem; border-radius: 1.55rem; border: 1px solid rgba(140, 226, 255, 0.14);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.008)), rgba(8, 13, 24, 0.74);
}
#contact-routes .contact-routes__lead { position: relative; overflow: hidden; display: grid; align-content: end; min-height: clamp(20rem, 28vw, 25rem); }
#contact-routes .contact-routes__lead img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  transform: scale(1.05) translate3d(calc(var(--mx) * 12px), calc(var(--my) * 12px), 0); transition: transform 180ms ease-out; opacity: 0.82;
}
#contact-routes .contact-routes__lead-overlay {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  opacity: 0.2; mix-blend-mode: screen; pointer-events: none; z-index: 1;
}
#contact-routes .contact-routes__lead::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5, 9, 17, 0.12), rgba(5, 9, 17, 0.84)); }
#contact-routes .contact-routes__lead-copy { position: relative; z-index: 1; display: grid; gap: 0.45rem; }
#contact-routes .contact-routes__card { display: grid; gap: 0.6rem; text-decoration: none; color: inherit; }
#contact-routes .contact-routes__card--primary { border-color: rgba(255, 150, 104, 0.32); background: linear-gradient(180deg, rgba(255,150,104,0.05), rgba(255,255,255,0.008)), rgba(8, 13, 24, 0.82); }
@media (max-width: 980px) {
  #contact-routes .contact-routes__frame, #contact-routes .contact-routes__stage { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  #contact-routes .contact-routes__frame { width: min(100%, calc(100% - 1rem)); }
  #contact-routes .contact-routes__actions { display: grid; }
  #contact-routes .contact-routes__action { width: 100%; }
}

/* Page Section: Cookies / #cookie-switchboard
   Cookie switchboard section: cookie policy hero and preference cards. */
#cookie-switchboard { padding-top: clamp(1rem, 2vw, 2rem); }

#cookie-switchboard .cookie-switchboard__frame {
  width: min(90rem, calc(100% - 2rem)); margin: 0 auto; padding: clamp(1rem, 1.8vw, 1.5rem);
  position: relative; overflow: hidden;
  border-radius: 2.1rem; border: 1px solid rgba(140,226,255,0.14);
  background:
    linear-gradient(145deg, rgba(8,12,22,0.88), rgba(10,18,32,0.94)),
    url("/assets/media/stock/space/premium-website-spiral-galaxy-neon-blue.webp") center/cover no-repeat;
  display: grid; gap: 1rem; box-shadow: 0 28px 100px rgba(0,0,0,0.26);
}
#cookie-switchboard .cookie-switchboard__frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("/assets/media/overlays/premium-website-neon-scan-arc-overlay.svg") center/cover no-repeat;
  opacity: 0.14;
  mix-blend-mode: screen;
  pointer-events: none;
}
#cookie-switchboard .cookie-switchboard__eyebrow, #cookie-switchboard .cookie-switchboard__item strong { font: 500 0.72rem/1 "IBM Plex Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(225,232,242,0.72); }
#cookie-switchboard h1 { margin: 0; max-width: 8ch; color: #f5f7fb; font: 700 clamp(2.8rem, 6vw, 5.2rem)/0.94 "Syne", sans-serif; letter-spacing: -0.07em; }
#cookie-switchboard p { margin: 0; color: rgba(220,228,239,0.82); font: 500 clamp(0.96rem, 1.2vw, 1.02rem)/1.6 "Manrope", sans-serif; }
#cookie-switchboard .cookie-switchboard__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.75rem; }
#cookie-switchboard .cookie-switchboard__item { padding: 1rem; border-radius: 1.25rem; border: 1px solid rgba(140,226,255,0.12); background: rgba(255,255,255,0.02); display: grid; gap: 0.55rem; }
#cookie-switchboard .cookie-switchboard__eyebrow, #cookie-switchboard h1, #cookie-switchboard p, #cookie-switchboard .cookie-switchboard__grid, #cookie-switchboard .cookie-switchboard__item { position: relative; z-index: 1; }
#cookie-switchboard .cookie-switchboard__toggle { width: 3rem; height: 1.7rem; border-radius: 999px; background: rgba(255,255,255,0.12); position: relative; }
#cookie-switchboard .cookie-switchboard__toggle::after { content: ""; position: absolute; top: 0.2rem; left: 0.2rem; width: 1.3rem; height: 1.3rem; border-radius: 50%; background: #fff; }
#cookie-switchboard .cookie-switchboard__item--active .cookie-switchboard__toggle { background: linear-gradient(135deg, #ff9064, #bffbff); }
#cookie-switchboard .cookie-switchboard__item--active .cookie-switchboard__toggle::after { left: 1.45rem; }
@media (max-width: 900px) { #cookie-switchboard .cookie-switchboard__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 720px) { #cookie-switchboard .cookie-switchboard__frame { width: min(100%, calc(100% - 1rem)); } #cookie-switchboard .cookie-switchboard__grid { grid-template-columns: 1fr; } }

/* Page Section: Discovery / #discovery-switch
   Discovery switch section: questionnaire hub, route panels, and discovery form layout. */
#discovery-switch {
  padding-top: clamp(1rem, 2vw, 2rem);
}

#discovery-switch .discovery-switch__frame {
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
  padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.4rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    radial-gradient(circle at 18% 18%, rgba(142, 229, 255, 0.12), transparent 18%),
    radial-gradient(circle at 84% 18%, rgba(255, 146, 101, 0.12), transparent 24%),
    linear-gradient(145deg, rgba(6, 10, 20, 0.98), rgba(9, 17, 31, 0.94));
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  gap: 1.2rem;
  box-shadow: 0 30px 110px rgba(0, 0, 0, 0.28);
}

#discovery-switch .discovery-switch__copy,
#discovery-switch .discovery-switch__board {
  display: grid;
  align-content: center;
  gap: 0.95rem;
}

#discovery-switch .discovery-switch__eyebrow,
#discovery-switch .discovery-switch__route-id,
#discovery-switch .discovery-switch__mini,
.discovery-brief__guide-item span,
.discovery-guide__card span {
  font: 500 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(225, 232, 242, 0.72);
}

#discovery-switch h1,
#discovery-switch h2,
#discovery-switch h3,
.discovery-brief__guide h3,
.discovery-guide__card h3 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.07em;
}

#discovery-switch h1 {
  max-width: 8ch;
  font-size: clamp(3rem, 6vw, 5.8rem);
  line-height: 0.92;
}

#discovery-switch h2,
.discovery-brief__guide h3,
.discovery-guide__card h3 {
  font-size: clamp(1.25rem, 2.3vw, 1.8rem);
  line-height: 0.98;
}

#discovery-switch p,
.discovery-brief__guide p,
.discovery-guide__card p {
  margin: 0;
  color: rgba(220, 228, 239, 0.82);
  font: 500 clamp(0.98rem, 1.3vw, 1.06rem) / 1.6 "Manrope", sans-serif;
}

#discovery-switch .discovery-switch__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

#discovery-switch .discovery-switch__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0 1.1rem;
  border-radius: 999px;
  text-decoration: none;
  font: 700 0.92rem/1 "Manrope", sans-serif;
}

#discovery-switch .discovery-switch__action--primary {
  background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff);
  color: #07111d;
  border: 0;
}

#discovery-switch .discovery-switch__action--secondary {
  border: 1px solid rgba(140, 226, 255, 0.16);
  color: #edf3fb;
  background: rgba(255, 255, 255, 0.03);
}

#discovery-switch .discovery-switch__hero {
  position: relative;
  min-height: clamp(15rem, 25vw, 19rem);
  border-radius: 1.8rem;
  overflow: hidden;
  border: 1px solid rgba(140, 226, 255, 0.14);
}

#discovery-switch .discovery-switch__hero img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#discovery-switch .discovery-switch__hero-image {
  transform: scale(1.05);
  filter: saturate(0.94) contrast(1.08) brightness(0.86);
}

#discovery-switch .discovery-switch__hero-overlay {
  opacity: 0.2;
  mix-blend-mode: screen;
}

#discovery-switch .discovery-switch__hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5, 9, 17, 0.08), rgba(5, 9, 17, 0.82));
}

#discovery-switch .discovery-switch__hero-copy {
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  z-index: 1;
  display: grid;
  gap: 0.45rem;
}

#discovery-switch .discovery-switch__route-grid,
.discovery-brief__guide-grid,
.discovery-guide__cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

#discovery-switch .discovery-switch__route,
.discovery-brief__guide-item,
.discovery-guide__card {
  display: grid;
  gap: 0.55rem;
  min-height: 100%;
  padding: 1rem;
  border-radius: 1.5rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
    rgba(8, 13, 24, 0.74);
}

#discovery-switch .discovery-switch__route {
  text-decoration: none;
  color: inherit;
}

#discovery-switch .discovery-switch__route--primary {
  border-color: rgba(255, 146, 101, 0.32);
  background: linear-gradient(180deg, rgba(255, 146, 101, 0.05), rgba(255, 255, 255, 0.008)),
    rgba(8, 13, 24, 0.82);
}

#discovery-switch .discovery-switch__micro {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

#discovery-switch .discovery-switch__micro-item {
  display: grid;
  gap: 0.35rem;
  padding: 0.9rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background: rgba(255, 255, 255, 0.025);
}

body[data-page="discovery"] .discovery-band--guide .shell {
  display: grid;
  gap: 1rem;
}

.discovery-guide__helper {
  margin-top: 0.95rem;
  padding-top: 0.95rem;
  border-top: 1px solid rgba(140, 226, 255, 0.12);
}

body[data-page="discovery"] main.layout-page .discovery-band--brief .shell {
  display: grid;
  gap: 1rem;
  align-items: start;
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
}

.discovery-brief__aside {
  display: grid;
  gap: 0.75rem;
}

.discovery-brief__guide {
  display: grid;
  gap: 0.65rem;
}

.discovery-brief__guide--rail {
  position: relative;
  overflow: hidden;
  padding: 0.85rem;
  border: 1px solid rgba(109, 164, 255, 0.24);
  background:
    radial-gradient(circle at top right, rgba(108, 168, 255, 0.24), transparent 34%),
    linear-gradient(180deg, rgba(35, 78, 197, 0.22), rgba(8, 13, 24, 0.94) 34%),
    rgba(8, 13, 24, 0.88);
}

.discovery-brief__guide .brief-hub__nav {
  scroll-snap-type: x proximity;
}

.discovery-brief__guide .brief-hub__nav a {
  min-width: min(14rem, 70vw);
  gap: 0.55rem;
  padding: 0.65rem 0.72rem;
  border-radius: 18px;
  scroll-snap-align: start;
}

.discovery-brief__guide .brief-hub__nav a span {
  min-width: 1.65rem;
  min-height: 1.65rem;
  font-size: 0.62rem;
}

.discovery-brief__guide .brief-hub__nav a strong {
  font-size: 0.82rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 980px) {
  #discovery-switch .discovery-switch__frame {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  #discovery-switch .discovery-switch__frame {
    width: min(100%, calc(100% - 1rem));
  }

  #discovery-switch .discovery-switch__actions,
  #discovery-switch .discovery-switch__route-grid,
  #discovery-switch .discovery-switch__micro,
  .discovery-brief__guide-grid,
  .discovery-guide__cards {
    display: grid;
    grid-template-columns: 1fr;
  }

  #discovery-switch .discovery-switch__action {
    width: 100%;
  }
}

/* Discovery reset */
#discovery-switch .discovery-switch__frame--reset {
  width: min(94rem, calc(100% - 2rem));
  padding: clamp(1.05rem, 2vw, 1.6rem);
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 1rem;
}

#discovery-switch .discovery-switch__frame--reset .discovery-switch__copy {
  align-content: start;
  gap: 1rem;
}

#discovery-switch .discovery-switch__frame--reset .discovery-switch__board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-content: start;
}

#discovery-switch .discovery-switch__frame--reset .discovery-switch__micro--reset {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
}

#discovery-switch .discovery-switch__frame--reset h1 {
  max-width: 6ch;
  font-size: clamp(3rem, 5.6vw, 5.2rem);
}

#discovery-switch .discovery-switch__frame--reset p {
  max-width: 33ch;
}

#discovery-switch .discovery-route-card,
#discovery-switch .discovery-step-card,
.discovery-guide-strip__card,
.discovery-form__banner,
.discovery-submit,
.discovery-exit {
  display: grid;
  gap: 0.75rem;
  padding: 1rem;
  border-radius: 1.45rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.012)),
    rgba(8, 13, 24, 0.8);
}

#discovery-switch .discovery-route-card--human {
  border-color: rgba(255, 146, 101, 0.24);
  background:
    linear-gradient(180deg, rgba(255, 146, 101, 0.06), rgba(255, 255, 255, 0.012)),
    rgba(8, 13, 24, 0.82);
}

#discovery-switch .discovery-route-card__eyebrow,
#discovery-switch .discovery-step-card__id,
.discovery-brief__action,
.brief-section__phase,
.brief-section__tag {
  font: 500 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(225, 232, 242, 0.72);
}

#discovery-switch .discovery-route-card__eyebrow,
#discovery-switch .discovery-step-card__id,
.brief-section__phase,
.brief-section__tag {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 2rem;
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(140, 226, 255, 0.16);
  background: rgba(255, 255, 255, 0.04);
}

.brief-section__tag {
  border-color: rgba(255, 146, 101, 0.2);
  background: rgba(255, 146, 101, 0.08);
}

#discovery-switch .discovery-route-card h2,
#discovery-switch .discovery-step-card h3,
.discovery-form__banner h3,
.discovery-exit h2 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.06em;
  line-height: 0.98;
}

#discovery-switch .discovery-route-card h2,
.discovery-form__banner h3,
.discovery-exit h2 {
  font-size: clamp(1.35rem, 2vw, 1.9rem);
}

#discovery-switch .discovery-step-card h3 {
  font-size: clamp(1.1rem, 1.8vw, 1.35rem);
}

#discovery-switch .discovery-route-card__list {
  margin: 0;
  padding-left: 1.05rem;
  display: grid;
  gap: 0.4rem;
  color: rgba(220, 228, 239, 0.8);
  font: 500 0.94rem/1.5 "Manrope", sans-serif;
}

#discovery-switch .discovery-route-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

#discovery-switch .discovery-step-card strong {
  color: #f5f7fb;
  font: 700 1rem/1.32 "Manrope", sans-serif;
}

body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip,
body[data-page="discovery"] main.layout-page .discovery-band--brief .shell,
body[data-page="discovery"] main.layout-page .discovery-band--closing .shell {
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
}

body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="discovery"] main.layout-page .discovery-band--brief .shell {
  display: grid;
  gap: 1rem;
  align-items: start;
}

.discovery-switch__actions .button,
#discovery-switch .discovery-route-card__actions .button,
.discovery-submit .button,
.discovery-exit .button {
  border-width: 1px;
}

.discovery-brief__actions {
  display: grid;
  gap: 0.5rem;
}

.discovery-brief__actions--compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.discovery-brief__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 2.35rem;
  padding: 0 0.8rem;
  border-radius: 999px;
  text-decoration: none;
  cursor: pointer;
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.discovery-brief__guide .brief-hub__nav {
  padding-bottom: 0.2rem;
}

.discovery-form__banner {
  border-color: rgba(255, 146, 101, 0.2);
  background:
    linear-gradient(180deg, rgba(255, 146, 101, 0.06), rgba(255, 255, 255, 0.012)),
    rgba(8, 13, 24, 0.82);
}

body[data-page="discovery"] main.layout-page .button--primary:not(.discovery-button--accent) {
  color: #f7fbff;
  background: linear-gradient(135deg, #6ca8ff 0%, #2e6bff 55%, #1742c8 100%);
  border-color: rgba(109, 164, 255, 0.36);
  box-shadow:
    0 18px 50px rgba(43, 103, 255, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

body[data-page="discovery"] main.layout-page .button--primary:not(.discovery-button--accent):hover,
body[data-page="discovery"] main.layout-page .button--primary:not(.discovery-button--accent):focus-visible {
  background: linear-gradient(135deg, #7ab3ff 0%, #3b78ff 55%, #2252d9 100%);
}

body[data-page="discovery"] main.layout-page .button--secondary,
body[data-page="discovery"] main.layout-page .button--subtle,
.discovery-brief__action {
  color: #f4f8ff;
  border-color: rgba(109, 164, 255, 0.26);
  background: linear-gradient(
    135deg,
    rgba(108, 168, 255, 0.18) 0%,
    rgba(46, 107, 255, 0.28) 55%,
    rgba(23, 66, 200, 0.4) 100%
  );
  box-shadow:
    0 12px 28px rgba(20, 52, 140, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}

body[data-page="discovery"] main.layout-page .button--secondary:hover,
body[data-page="discovery"] main.layout-page .button--secondary:focus-visible,
body[data-page="discovery"] main.layout-page .button--subtle:hover,
body[data-page="discovery"] main.layout-page .button--subtle:focus-visible,
.discovery-brief__action:hover,
.discovery-brief__action:focus-visible {
  border-color: rgba(135, 181, 255, 0.42);
  background: linear-gradient(
    135deg,
    rgba(123, 176, 255, 0.28) 0%,
    rgba(64, 128, 255, 0.36) 55%,
    rgba(28, 77, 222, 0.48) 100%
  );
}

body[data-page="discovery"] main.layout-page .button--primary.discovery-button--accent {
  color: #fff7f1;
  background: linear-gradient(135deg, #ff5c56 0%, #ff7d5d 48%, #ffb35f 100%);
  border-color: rgba(255, 165, 112, 0.26);
  box-shadow:
    0 18px 40px rgba(255, 85, 68, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

body[data-page="discovery"] main.layout-page .button--primary.discovery-button--accent:hover,
body[data-page="discovery"] main.layout-page .button--primary.discovery-button--accent:focus-visible {
  background: linear-gradient(135deg, #ff6859 0%, #ff8a63 48%, #ffbd69 100%);
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section {
  gap: 0;
  overflow: hidden;
  border: 1px solid rgba(140, 226, 255, 0.14);
  transition:
    transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out),
    background var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section.is-open,
body[data-page="discovery"].discovery-brief--enhanced .brief-section.is-current {
  border-color: rgba(140, 226, 255, 0.24);
  background:
    linear-gradient(180deg, rgba(140, 226, 255, 0.05), rgba(255, 255, 255, 0.012)),
    rgba(8, 13, 24, 0.86);
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section.is-current {
  box-shadow: 0 18px 64px rgba(0, 0, 0, 0.22);
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__head {
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  align-items: center;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__head-copy,
body[data-page="discovery"].discovery-brief--enhanced .brief-section__meta {
  display: grid;
  gap: 0.5rem;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__head p {
  max-width: 40ch;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  min-height: 2.9rem;
  padding: 0 0.95rem;
  border-radius: 999px;
  border: 1px solid rgba(109, 164, 255, 0.26);
  background: linear-gradient(
    135deg,
    rgba(108, 168, 255, 0.18) 0%,
    rgba(46, 107, 255, 0.28) 55%,
    rgba(23, 66, 200, 0.4) 100%
  );
  box-shadow:
    0 12px 28px rgba(20, 52, 140, 0.2),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
  color: #f4f8ff;
  cursor: pointer;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle:hover,
body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle:focus-visible {
  border-color: rgba(135, 181, 255, 0.42);
  background: linear-gradient(
    135deg,
    rgba(123, 176, 255, 0.28) 0%,
    rgba(64, 128, 255, 0.36) 55%,
    rgba(28, 77, 222, 0.48) 100%
  );
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle-text {
  font: 700 0.84rem/1 "Manrope", sans-serif;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle-icon {
  position: relative;
  width: 0.85rem;
  height: 0.85rem;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle-icon::before,
body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 1.5px;
  background: currentColor;
  border-radius: 999px;
  transform: translate(-50%, -50%);
  transition:
    transform var(--duration-fast) var(--ease-out),
    opacity var(--duration-fast) var(--ease-out);
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section.is-open .brief-section__toggle-icon::after {
  opacity: 0;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__grid {
  padding-top: 1rem;
  border-top: 1px solid rgba(140, 226, 255, 0.1);
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section:not(.is-open) .brief-section__grid {
  display: none;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section {
  scroll-margin-top: 7rem;
}

@media (min-width: 960px) {
  body[data-page="discovery"] main.layout-page .discovery-band--brief .shell {
    grid-template-columns: minmax(0, 1.24fr) minmax(14rem, 0.68fr);
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .discovery-brief__aside {
    position: sticky;
    top: 6.45rem;
    align-self: start;
    grid-column: 2 !important;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form,
  body[data-page="discovery"] main.layout-page .discovery-band--brief [data-form-success],
  body[data-page="discovery"] main.layout-page .discovery-band--brief [data-form-error] {
    grid-column: 1 !important;
  }

  .discovery-brief__guide--rail {
    padding: 0.8rem;
  }

  .discovery-brief__guide .brief-hub__nav {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.45rem;
    max-height: min(62vh, 38rem);
    overflow-x: visible;
    overflow-y: auto;
    padding-right: 0.2rem;
    scrollbar-width: thin;
    scroll-snap-type: none;
  }

  .discovery-brief__guide .brief-hub__nav a {
    min-width: 0;
  }

  .discovery-brief__guide .brief-hub__nav a strong {
    white-space: normal;
  }
}

@media (max-width: 959px) {
  #discovery-switch .discovery-switch__frame--reset {
    grid-template-columns: 1fr;
  }

  #discovery-switch .discovery-switch__frame--reset .discovery-switch__board,
  #discovery-switch .discovery-switch__frame--reset .discovery-switch__micro--reset,
  body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 640px) and (max-width: 959px) {
  .discovery-brief__guide {
    gap: 0.75rem;
  }
}

@media (max-width: 720px) {
  body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip,
  body[data-page="discovery"] main.layout-page .discovery-band--brief .shell,
  body[data-page="discovery"] main.layout-page .discovery-band--closing .shell,
  #discovery-switch .discovery-switch__frame--reset {
    width: min(100%, calc(100% - 1rem));
  }

  #discovery-switch .discovery-route-card__actions .button,
  #discovery-switch .discovery-switch__actions .button,
  .discovery-brief__actions > *,
  .discovery-brief__action,
  .discovery-brief__guide .brief-hub__nav a {
    width: 100%;
  }

  .discovery-brief__guide--rail {
    padding: 0.75rem;
  }

  .discovery-brief__guide .brief-hub__nav a {
    min-width: min(12rem, 64vw);
  }

  body[data-page="discovery"].discovery-brief--enhanced .brief-section__head {
    grid-template-columns: auto 1fr;
    align-items: start;
  }

  body[data-page="discovery"].discovery-brief--enhanced .brief-section__toggle {
    grid-column: 1 / -1;
    width: 100%;
    justify-content: center;
  }
}

/* Page Section: Examples / #examples-mosaic
   Examples mosaic section: portfolio hero mosaic and hover-responsive media treatment. */
#examples-mosaic { --mx: 0; --my: 0; padding-top: clamp(1rem, 2vw, 2rem); }

#examples-mosaic .examples-mosaic__frame {
  width: min(94rem, calc(100% - 2rem)); margin: 0 auto; padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.3rem; border: 1px solid rgba(140,226,255,0.14);
  background: radial-gradient(circle at 14% 20%, rgba(140,226,255,0.12), transparent 20%), linear-gradient(145deg, rgba(7,11,21,0.98), rgba(10,18,33,0.94));
  display: grid; grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr); gap: 1rem; box-shadow: 0 28px 100px rgba(0,0,0,0.26);
}
#examples-mosaic .examples-mosaic__copy, #examples-mosaic .examples-mosaic__grid { display: grid; align-content: center; gap: 0.95rem; }
#examples-mosaic .examples-mosaic__eyebrow, #examples-mosaic .examples-mosaic__label { font: 500 0.72rem/1 "IBM Plex Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(225,232,242,0.72); }
#examples-mosaic h1, #examples-mosaic h2 { margin: 0; color: #f5f7fb; font-family: "Syne", sans-serif; letter-spacing: -0.07em; }
#examples-mosaic h1 { max-width: 7ch; font-size: clamp(3rem, 6vw, 5.6rem); line-height: 0.92; }
#examples-mosaic p { margin: 0; color: rgba(220,228,239,0.82); font: 500 clamp(0.98rem, 1.3vw, 1.06rem)/1.6 "Manrope", sans-serif; }
#examples-mosaic .examples-mosaic__actions, #examples-mosaic .examples-mosaic__tags { display: flex; flex-wrap: wrap; gap: 0.75rem; }
#examples-mosaic .examples-mosaic__action, #examples-mosaic .examples-mosaic__tag { display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0 1.1rem; border-radius: 999px; text-decoration: none; font: 700 0.92rem/1 "Manrope", sans-serif; }
#examples-mosaic .examples-mosaic__action--primary { border: 0; color: #07111d; background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff); }
#examples-mosaic .examples-mosaic__action--secondary, #examples-mosaic .examples-mosaic__tag { border: 1px solid rgba(140,226,255,0.16); color: #edf3fb; background: rgba(255,255,255,0.03); }
#examples-mosaic .examples-mosaic__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); display: grid; }
#examples-mosaic .examples-mosaic__hero {
  grid-column: span 2; grid-row: span 2; position: relative; min-height: clamp(20rem, 28vw, 24rem);
  border-radius: 1.55rem; overflow: hidden; border: 1px solid rgba(140,226,255,0.12);
}
#examples-mosaic .examples-mosaic__hero img, #examples-mosaic .examples-mosaic__tile img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
#examples-mosaic .examples-mosaic__hero img { transform: scale(1.04) translate3d(calc(var(--mx) * 8px), calc(var(--my) * 8px), 0); transition: transform 180ms ease-out; }
#examples-mosaic .examples-mosaic__overlay { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.22; mix-blend-mode: screen; pointer-events: none; z-index: 1; }
#examples-mosaic .examples-mosaic__hero::after, #examples-mosaic .examples-mosaic__tile::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,9,17,0.08), rgba(5,9,17,0.72)); }
#examples-mosaic .examples-mosaic__hero-copy, #examples-mosaic .examples-mosaic__tile-copy { position: relative; z-index: 1; padding: 1rem; display: grid; gap: 0.45rem; align-content: end; height: 100%; }
#examples-mosaic .examples-mosaic__tile {
  position: relative; min-height: 11.5rem; border-radius: 1.35rem; overflow: hidden; border: 1px solid rgba(140,226,255,0.12);
}
@media (max-width: 980px) { #examples-mosaic .examples-mosaic__frame { grid-template-columns: 1fr; } }
@media (max-width: 720px) { #examples-mosaic .examples-mosaic__frame { width: min(100%, calc(100% - 1rem)); } #examples-mosaic .examples-mosaic__actions { display: grid; } #examples-mosaic .examples-mosaic__action { width: 100%; } #examples-mosaic .examples-mosaic__grid { grid-template-columns: 1fr; } #examples-mosaic .examples-mosaic__hero { grid-column: auto; grid-row: auto; } }

/* Page Section: FAQ / #faq-atlas
   FAQ atlas section: support-topic cards and question layout. */
#faq-atlas { padding-top: clamp(1rem, 2vw, 2rem); }

#faq-atlas .faq-atlas__frame {
  width: min(92rem, calc(100% - 2rem)); margin: 0 auto; padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.3rem; border: 1px solid rgba(140,226,255,0.14);
  position: relative; overflow: hidden;
  background:
    radial-gradient(circle at 14% 18%, rgba(140,226,255,0.12), transparent 18%),
    linear-gradient(145deg, rgba(8,12,22,0.84), rgba(10,18,32,0.94)),
    url("/assets/media/stock/space/premium-website-services-galaxy-field.webp") center/cover no-repeat;
  display: grid; grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr); gap: 1rem; box-shadow: 0 28px 100px rgba(0,0,0,0.26);
}
#faq-atlas .faq-atlas__frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("/assets/media/overlays/premium-website-neon-orbit-grid-overlay.svg") center/cover no-repeat;
  opacity: 0.14;
  mix-blend-mode: screen;
  pointer-events: none;
}
#faq-atlas .faq-atlas__copy, #faq-atlas .faq-atlas__board { display: grid; align-content: center; gap: 0.95rem; }
#faq-atlas .faq-atlas__copy, #faq-atlas .faq-atlas__board, #faq-atlas .faq-atlas__topic, #faq-atlas .faq-atlas__search { position: relative; z-index: 1; }
#faq-atlas .faq-atlas__eyebrow, #faq-atlas .faq-atlas__topic strong { font: 500 0.72rem/1 "IBM Plex Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(225,232,242,0.72); }
#faq-atlas h1 { margin: 0; max-width: 6ch; color: #f5f7fb; font: 700 clamp(3rem, 6vw, 5.6rem)/0.92 "Syne", sans-serif; letter-spacing: -0.07em; }
#faq-atlas p { margin: 0; color: rgba(220,228,239,0.82); font: 500 clamp(0.98rem, 1.3vw, 1.06rem)/1.6 "Manrope", sans-serif; }
#faq-atlas .faq-atlas__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }
#faq-atlas .faq-atlas__action { display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0 1.1rem; border-radius: 999px; text-decoration: none; font: 700 0.92rem/1 "Manrope", sans-serif; }
#faq-atlas .faq-atlas__action--primary { border: 0; color: #07111d; background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff); }
#faq-atlas .faq-atlas__action--secondary { border: 1px solid rgba(140,226,255,0.16); color: #edf3fb; background: rgba(255,255,255,0.03); }
#faq-atlas .faq-atlas__search { min-height: 3.5rem; border-radius: 1.2rem; border: 1px solid rgba(140,226,255,0.14); background: rgba(255,255,255,0.03); padding: 0 1rem; display: flex; align-items: center; color: rgba(220,228,239,0.82); font: 500 1rem/1 "Manrope", sans-serif; }
#faq-atlas .faq-atlas__topics { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.75rem; }
#faq-atlas .faq-atlas__topic { padding: 1rem; border-radius: 1.25rem; border: 1px solid rgba(140,226,255,0.12); background: rgba(255,255,255,0.02); display: grid; gap: 0.45rem; }
@media (max-width: 980px) { #faq-atlas .faq-atlas__frame { grid-template-columns: 1fr; } }
@media (max-width: 720px) { #faq-atlas .faq-atlas__frame { width: min(100%, calc(100% - 1rem)); } #faq-atlas .faq-atlas__actions, #faq-atlas .faq-atlas__topics { display: grid; } #faq-atlas .faq-atlas__action { width: 100%; } }

/* Page Section: Invest / #invest-orbit
   Investment orbit section: offer tiers, orbit visuals, and investment cards. */
#invest-orbit {
  padding-top: clamp(1rem, 2vw, 2rem);
}

#invest-orbit .invest-orbit__frame {
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
  padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.45rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    radial-gradient(circle at 16% 18%, rgba(121, 227, 255, 0.12), transparent 20%),
    radial-gradient(circle at 84% 18%, rgba(255, 177, 132, 0.14), transparent 26%),
    linear-gradient(145deg, rgba(6, 10, 20, 0.98), rgba(9, 17, 31, 0.94));
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  gap: 1.2rem;
  box-shadow: 0 30px 110px rgba(0, 0, 0, 0.28);
}

#invest-orbit .invest-orbit__copy,
#invest-orbit .invest-orbit__board {
  display: grid;
  align-content: center;
  gap: 0.95rem;
}

#invest-orbit .invest-orbit__eyebrow,
#invest-orbit .invest-orbit__mini,
.invest-tier__kicker,
.invest-tier__note-label {
  font: 500 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(225, 232, 242, 0.72);
}

#invest-orbit h1,
#invest-orbit h2,
.invest-tier h3 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.07em;
}

#invest-orbit h1 {
  max-width: 8ch;
  font-size: clamp(3rem, 6vw, 5.8rem);
  line-height: 0.92;
}

#invest-orbit h2 {
  font-size: clamp(1.35rem, 2.4vw, 1.95rem);
  line-height: 0.98;
}

#invest-orbit p,
.invest-tier p,
.invest-tier li {
  margin: 0;
  color: rgba(220, 228, 239, 0.82);
  font: 500 clamp(0.98rem, 1.3vw, 1.04rem) / 1.6 "Manrope", sans-serif;
}

#invest-orbit .invest-orbit__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

#invest-orbit .invest-orbit__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0 1.1rem;
  border-radius: 999px;
  text-decoration: none;
  font: 700 0.92rem/1 "Manrope", sans-serif;
}

#invest-orbit .invest-orbit__action--primary {
  background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff);
  color: #07111d;
  border: 0;
}

#invest-orbit .invest-orbit__action--secondary {
  border: 1px solid rgba(140, 226, 255, 0.16);
  color: #edf3fb;
  background: rgba(255, 255, 255, 0.03);
}

#invest-orbit .invest-orbit__hero {
  position: relative;
  min-height: clamp(15rem, 25vw, 19rem);
  border-radius: 1.8rem;
  overflow: hidden;
  border: 1px solid rgba(140, 226, 255, 0.14);
}

#invest-orbit .invest-orbit__hero img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#invest-orbit .invest-orbit__hero-image {
  transform: scale(1.05);
  filter: saturate(0.94) contrast(1.08) brightness(0.88);
}

#invest-orbit .invest-orbit__hero-overlay {
  opacity: 0.2;
  mix-blend-mode: screen;
}

#invest-orbit .invest-orbit__hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5, 9, 17, 0.08), rgba(5, 9, 17, 0.82));
}

#invest-orbit .invest-orbit__hero-copy {
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  z-index: 1;
  display: grid;
  gap: 0.45rem;
}

#invest-orbit .invest-orbit__micro {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

#invest-orbit .invest-orbit__micro-item {
  display: grid;
  gap: 0.35rem;
  padding: 0.9rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background: rgba(255, 255, 255, 0.025);
}

body[data-page="invest"] .invest-grid,
body[data-page="invest"] .invest-decision-grid {
  display: grid;
  gap: 1rem;
}

.invest-tier {
  display: grid;
  gap: 1rem;
  padding: clamp(1.15rem, 2.2vw, 1.6rem);
  border-radius: 2rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.008)),
    rgba(8, 13, 24, 0.78);
  box-shadow: var(--shadow-md);
}

.invest-tier--featured {
  border-color: rgba(255, 146, 101, 0.34);
  background:
    radial-gradient(circle at top right, rgba(255, 146, 101, 0.12), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)),
    rgba(8, 13, 24, 0.86);
}

.invest-tier__head,
.invest-tier__price,
.invest-tier__note {
  display: grid;
  gap: 0.45rem;
}

.invest-tier__price strong {
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: -0.06em;
  line-height: 0.92;
}

.invest-tier__list {
  margin: 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.55rem;
}

.invest-tier__note {
  padding-top: 0.95rem;
  border-top: 1px solid rgba(140, 226, 255, 0.12);
}

.invest-tier__tag {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0.45rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(140, 226, 255, 0.16);
  background: rgba(255, 255, 255, 0.04);
  color: rgba(238, 244, 255, 0.84);
  font-family: "IBM Plex Mono", monospace;
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.invest-decision-card {
  display: grid;
  gap: 0.6rem;
  padding: clamp(1.1rem, 2.1vw, 1.5rem);
  border-radius: 1.75rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background: rgba(8, 13, 24, 0.74);
}

@media (min-width: 960px) {
  body[data-page="invest"] .invest-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
  }

  body[data-page="invest"] .invest-decision-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  #invest-orbit .invest-orbit__frame {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  #invest-orbit .invest-orbit__frame {
    width: min(100%, calc(100% - 1rem));
  }

  #invest-orbit .invest-orbit__actions,
  #invest-orbit .invest-orbit__micro {
    display: grid;
    grid-template-columns: 1fr;
  }

  #invest-orbit .invest-orbit__action {
    width: 100%;
  }
}

/* Page Section: Launch / #launch-control
   Launch control section: project-intake hero and launch form framing. */
#launch-control { --mx: 0; --my: 0; padding-top: clamp(1rem, 2vw, 2rem); }

#launch-control .launch-control__frame {
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
  padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.4rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 148, 104, 0.12), transparent 20%),
    radial-gradient(circle at 82% 18%, rgba(142, 229, 255, 0.1), transparent 22%),
    linear-gradient(145deg, rgba(6, 10, 20, 0.98), rgba(9, 17, 31, 0.94));
  display: grid;
  grid-template-columns: minmax(0, 0.74fr) minmax(0, 1.26fr);
  gap: 1.2rem;
  box-shadow: 0 30px 110px rgba(0, 0, 0, 0.28);
}
#launch-control .launch-control__copy, #launch-control .launch-control__stage { display: grid; align-content: center; gap: 0.95rem; }
#launch-control .launch-control__eyebrow, #launch-control .launch-control__label {
  font: 500 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(225, 232, 242, 0.72);
}
#launch-control h1, #launch-control h2, #launch-control h3 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.07em;
}
#launch-control h1 { max-width: 7.2ch; font-size: clamp(3rem, 6vw, 5.8rem); line-height: 0.92; }
#launch-control p { margin: 0; color: rgba(220, 228, 239, 0.82); font: 500 clamp(0.98rem, 1.3vw, 1.06rem)/1.6 "Manrope", sans-serif; }
#launch-control .launch-control__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }
#launch-control .launch-control__action {
  display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0 1.1rem;
  border-radius: 999px; border: 1px solid rgba(140, 226, 255, 0.16); text-decoration: none; color: #edf3fb;
  background: rgba(255, 255, 255, 0.03); font: 700 0.92rem/1 "Manrope", sans-serif;
}
#launch-control .launch-control__action--primary { background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff); color: #07111d; border: 0; }
#launch-control .launch-control__stage { grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr); display: grid; }
#launch-control .launch-control__lead, #launch-control .launch-control__stack {
  padding: 1rem; border-radius: 1.55rem; border: 1px solid rgba(140, 226, 255, 0.14);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.008)), rgba(8, 13, 24, 0.74);
}
#launch-control .launch-control__lead { position: relative; overflow: hidden; min-height: clamp(22rem, 30vw, 26rem); display: grid; align-content: end; }
#launch-control .launch-control__lead img,
#launch-control .launch-control__lead video {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  transform: scale(1.04) translate3d(calc(var(--mx) * 10px), calc(var(--my) * 10px), 0); transition: transform 180ms ease-out; opacity: 0.82;
}
#launch-control .launch-control__lead-overlay {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  opacity: 0.22; mix-blend-mode: screen; pointer-events: none; z-index: 1;
}
#launch-control .launch-control__lead::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(4, 8, 17, 0.12), rgba(4, 8, 17, 0.84)); }
#launch-control .launch-control__lead-copy { position: relative; z-index: 1; display: grid; gap: 0.45rem; }
#launch-control .launch-control__stack { display: grid; gap: 0.85rem; }
#launch-control .launch-control__mini-card {
  padding: 0.95rem; border-radius: 1.2rem; border: 1px solid rgba(140, 226, 255, 0.12); background: rgba(255, 255, 255, 0.02); display: grid; gap: 0.45rem;
}
@media (max-width: 980px) {
  #launch-control .launch-control__frame, #launch-control .launch-control__stage { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  #launch-control .launch-control__frame { width: min(100%, calc(100% - 1rem)); }
  #launch-control .launch-control__actions { display: grid; }
  #launch-control .launch-control__action { width: 100%; }
}

/* Page Section: Payments / #payments-briefing
   Payments briefing section: consultation payment hero and payment route cards. */
#payments-briefing { --mx: 0; --my: 0; padding-top: clamp(1rem, 2vw, 2rem); }

#payments-briefing .payments-briefing__frame {
  width: min(92rem, calc(100% - 2rem)); margin: 0 auto; padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.3rem; border: 1px solid rgba(140,226,255,0.14);
  background: radial-gradient(circle at 16% 18%, rgba(255,148,104,0.12), transparent 20%), linear-gradient(145deg, rgba(8,12,22,0.98), rgba(10,18,32,0.94));
  display: grid; grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr); gap: 1rem; box-shadow: 0 28px 100px rgba(0,0,0,0.26);
}
#payments-briefing .payments-briefing__copy, #payments-briefing .payments-briefing__board { display: grid; align-content: center; gap: 0.95rem; }
#payments-briefing .payments-briefing__eyebrow, #payments-briefing .payments-briefing__mini { font: 500 0.72rem/1 "IBM Plex Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(225,232,242,0.72); }
#payments-briefing h1, #payments-briefing h2 { margin: 0; color: #f5f7fb; font-family: "Syne", sans-serif; letter-spacing: -0.07em; }
#payments-briefing h1 { max-width: 7ch; font-size: clamp(3rem, 6vw, 5.6rem); line-height: 0.92; }
#payments-briefing p { margin: 0; color: rgba(220,228,239,0.82); font: 500 clamp(0.98rem, 1.3vw, 1.06rem)/1.6 "Manrope", sans-serif; }
#payments-briefing .payments-briefing__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }
#payments-briefing .payments-briefing__action { display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0 1.1rem; border-radius: 999px; text-decoration: none; font: 700 0.92rem/1 "Manrope", sans-serif; }
#payments-briefing .payments-briefing__action--primary { border: 0; color: #07111d; background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff); }
#payments-briefing .payments-briefing__action--secondary { border: 1px solid rgba(140,226,255,0.16); color: #edf3fb; background: rgba(255,255,255,0.03); }
#payments-briefing .payments-briefing__board { padding: 1rem; border-radius: 1.7rem; border: 1px solid rgba(140,226,255,0.14); background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.008)), rgba(8,13,24,0.74); }
#payments-briefing .payments-briefing__hero { position: relative; min-height: clamp(13rem, 20vw, 17rem); border-radius: 1.35rem; overflow: hidden; border: 1px solid rgba(140,226,255,0.12); }
#payments-briefing .payments-briefing__hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.04) translate3d(calc(var(--mx) * 8px), calc(var(--my) * 8px), 0); transition: transform 180ms ease-out; opacity: 0.88; }
#payments-briefing .payments-briefing__hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,9,17,0.08), rgba(5,9,17,0.72)); }
#payments-briefing .payments-briefing__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.75rem; }
#payments-briefing .payments-briefing__item { padding: 0.95rem; border-radius: 1.2rem; border: 1px solid rgba(140,226,255,0.12); background: rgba(255,255,255,0.02); display: grid; gap: 0.4rem; }
@media (max-width: 980px) { #payments-briefing .payments-briefing__frame { grid-template-columns: 1fr; } }
@media (max-width: 720px) { #payments-briefing .payments-briefing__frame { width: min(100%, calc(100% - 1rem)); } #payments-briefing .payments-briefing__actions, #payments-briefing .payments-briefing__grid { display: grid; } #payments-briefing .payments-briefing__action { width: 100%; } }

/* Page Section: Privacy / #privacy-ledger
   Privacy ledger section: privacy policy hero and data handling cards. */
#privacy-ledger { padding-top: clamp(1rem, 2vw, 2rem); }

#privacy-ledger .privacy-ledger__frame {
  width: min(90rem, calc(100% - 2rem)); margin: 0 auto; padding: clamp(1rem, 1.8vw, 1.5rem);
  position: relative; overflow: hidden;
  border-radius: 2.1rem; border: 1px solid rgba(140,226,255,0.14);
  background:
    linear-gradient(145deg, rgba(8,12,22,0.88), rgba(10,18,32,0.94)),
    url("/assets/media/stock/space/premium-website-galaxy-network-space-atlas.webp") center/cover no-repeat;
  display: grid; gap: 1rem; box-shadow: 0 28px 100px rgba(0,0,0,0.26);
}
#privacy-ledger .privacy-ledger__frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("/assets/media/overlays/premium-website-neon-scan-arc-overlay.svg") center/cover no-repeat;
  opacity: 0.14;
  mix-blend-mode: screen;
  pointer-events: none;
}
#privacy-ledger .privacy-ledger__head, #privacy-ledger .privacy-ledger__grid { display: grid; gap: 0.9rem; }
#privacy-ledger .privacy-ledger__head, #privacy-ledger .privacy-ledger__grid, #privacy-ledger .privacy-ledger__item { position: relative; z-index: 1; }
#privacy-ledger .privacy-ledger__eyebrow, #privacy-ledger .privacy-ledger__item strong { font: 500 0.72rem/1 "IBM Plex Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(225,232,242,0.72); }
#privacy-ledger h1 { margin: 0; max-width: 8ch; color: #f5f7fb; font: 700 clamp(2.8rem, 6vw, 5.2rem)/0.94 "Syne", sans-serif; letter-spacing: -0.07em; }
#privacy-ledger p { margin: 0; color: rgba(220,228,239,0.82); font: 500 clamp(0.96rem, 1.2vw, 1.02rem)/1.6 "Manrope", sans-serif; }
#privacy-ledger .privacy-ledger__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
#privacy-ledger .privacy-ledger__item { padding: 1rem; border-radius: 1.25rem; border: 1px solid rgba(140,226,255,0.12); background: rgba(255,255,255,0.02); display: grid; gap: 0.45rem; }
@media (max-width: 900px) { #privacy-ledger .privacy-ledger__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 720px) { #privacy-ledger .privacy-ledger__frame { width: min(100%, calc(100% - 1rem)); } #privacy-ledger .privacy-ledger__grid { grid-template-columns: 1fr; } }

/* Page Section: Process / #process-runway
   Process runway section: project process hero and timeline presentation. */
#process-runway { --mx: 0; --my: 0; padding-top: clamp(1rem, 2vw, 2rem); }

#process-runway .process-runway__frame {
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
  padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.4rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    radial-gradient(circle at 14% 18%, rgba(142, 229, 255, 0.14), transparent 20%),
    radial-gradient(circle at 84% 82%, rgba(255, 150, 104, 0.12), transparent 22%),
    linear-gradient(145deg, rgba(6, 10, 19, 0.98), rgba(10, 19, 34, 0.94));
  display: grid;
  grid-template-columns: minmax(0, 0.76fr) minmax(0, 1.24fr);
  gap: 1.2rem;
  box-shadow: 0 30px 110px rgba(0, 0, 0, 0.28);
}
#process-runway .process-runway__copy,
#process-runway .process-runway__track { display: grid; align-content: center; gap: 0.95rem; }
#process-runway .process-runway__eyebrow,
#process-runway .process-runway__step-id {
  font: 500 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(225, 232, 242, 0.72);
}
#process-runway h1, #process-runway h3 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.065em;
}
#process-runway h1 { max-width: 7ch; font-size: clamp(3rem, 6vw, 5.8rem); line-height: 0.92; }
#process-runway p { margin: 0; color: rgba(220, 228, 239, 0.82); font: 500 clamp(0.98rem, 1.3vw, 1.06rem)/1.6 "Manrope", sans-serif; }
#process-runway .process-runway__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }
#process-runway .process-runway__action {
  display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0 1.1rem;
  border-radius: 999px; border: 1px solid rgba(140, 226, 255, 0.16); text-decoration: none; color: #edf3fb;
  background: rgba(255, 255, 255, 0.03); font: 700 0.92rem/1 "Manrope", sans-serif;
}
#process-runway .process-runway__action--primary { background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff); color: #07111d; border: 0; }
#process-runway .process-runway__track {
  position: relative; min-height: clamp(23rem, 38vw, 35rem); padding: 1.2rem; border-radius: 2rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.028), rgba(255,255,255,0.008)),
    linear-gradient(135deg, rgba(7, 12, 24, 0.68), rgba(7, 12, 24, 0.88)),
    url("/assets/media/stock/space/premium-website-galaxy-network-space-atlas.webp") center/cover no-repeat;
  overflow: hidden;
}
#process-runway .process-runway__track::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("/assets/media/overlays/premium-website-neon-scan-arc-overlay.svg") center/cover no-repeat;
  opacity: 0.32;
  mix-blend-mode: screen;
  pointer-events: none;
}
#process-runway .process-runway__line {
  position: absolute; left: 12%; right: 12%; top: 50%; height: 1px;
  background: linear-gradient(90deg, rgba(142, 229, 255, 0.22), rgba(255, 150, 104, 0.3));
  transform: translateY(-50%) rotate(-12deg);
}
#process-runway .process-runway__step {
  position: absolute; z-index: 1; width: min(13rem, 42%); padding: 0.95rem 1rem; border-radius: 1.35rem;
  border: 1px solid rgba(140, 226, 255, 0.14); background: rgba(10, 16, 29, 0.74); backdrop-filter: blur(16px);
  transform: translate3d(calc(var(--mx) * 8px), calc(var(--my) * 8px), 0);
}
#process-runway .process-runway__step--1 { top: 1.4rem; left: 1rem; }
#process-runway .process-runway__step--2 { top: 4.5rem; right: 1rem; }
#process-runway .process-runway__step--3 { bottom: 5rem; left: 2rem; }
#process-runway .process-runway__step--4 { bottom: 1.4rem; right: 2rem; }
@media (max-width: 980px) {
  #process-runway .process-runway__frame { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  #process-runway .process-runway__frame { width: min(100%, calc(100% - 1rem)); }
  #process-runway .process-runway__actions { display: grid; }
  #process-runway .process-runway__action { width: 100%; }
  #process-runway .process-runway__track { display: grid; gap: 0.9rem; min-height: auto; }
  #process-runway .process-runway__line, #process-runway .process-runway__step { position: static; width: auto; transform: none; }
}

/* Page Section: Schedule / #schedule-window
   Schedule window section: booking hero and consultation timing cards. */
#schedule-window { padding-top: clamp(1rem, 2vw, 2rem); }

#schedule-window .schedule-window__frame {
  width: min(92rem, calc(100% - 2rem)); margin: 0 auto; padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.3rem; border: 1px solid rgba(140, 226, 255, 0.14);
  background: radial-gradient(circle at 16% 18%, rgba(142,229,255,0.12), transparent 18%), linear-gradient(145deg, rgba(8,12,22,0.98), rgba(10,18,32,0.94));
  display: grid; grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr); gap: 1rem; box-shadow: 0 28px 100px rgba(0,0,0,0.26);
}
#schedule-window .schedule-window__copy, #schedule-window .schedule-window__board { display: grid; align-content: center; gap: 0.95rem; }
#schedule-window .schedule-window__eyebrow, #schedule-window .schedule-window__slot strong { font: 500 0.72rem/1 "IBM Plex Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(225,232,242,0.72); }
#schedule-window h1, #schedule-window h2 { margin: 0; color: #f5f7fb; font-family: "Syne", sans-serif; letter-spacing: -0.07em; }
#schedule-window h1 { max-width: 7ch; font-size: clamp(3rem, 6vw, 5.6rem); line-height: 0.92; }
#schedule-window p { margin: 0; color: rgba(220,228,239,0.82); font: 500 clamp(0.98rem, 1.3vw, 1.06rem)/1.6 "Manrope", sans-serif; }
#schedule-window .schedule-window__action { display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0 1.1rem; border-radius: 999px; text-decoration: none; border: 0; color: #07111d; background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff); font: 700 0.92rem/1 "Manrope", sans-serif; }
#schedule-window .schedule-window__board { padding: 1rem; border-radius: 1.7rem; border: 1px solid rgba(140,226,255,0.14); background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.008)), rgba(8,13,24,0.74); }
#schedule-window .schedule-window__hero { position: relative; min-height: clamp(12rem, 18vw, 16rem); border-radius: 1.35rem; overflow: hidden; border: 1px solid rgba(140,226,255,0.12); }
#schedule-window .schedule-window__hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.84; }
#schedule-window .schedule-window__hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,9,17,0.08), rgba(5,9,17,0.72)); }
#schedule-window .schedule-window__slots { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.75rem; }
#schedule-window .schedule-window__slot { padding: 0.95rem; border-radius: 1.2rem; border: 1px solid rgba(140,226,255,0.12); background: rgba(255,255,255,0.02); display: grid; gap: 0.4rem; color: #f5f7fb; }
#schedule-window .schedule-window__slot--active { border-color: rgba(255, 147, 101, 0.34); box-shadow: 0 18px 36px rgba(255, 147, 101, 0.12); }
@media (max-width: 980px) { #schedule-window .schedule-window__frame { grid-template-columns: 1fr; } }
@media (max-width: 720px) { #schedule-window .schedule-window__frame { width: min(100%, calc(100% - 1rem)); } #schedule-window .schedule-window__slots { grid-template-columns: 1fr; } #schedule-window .schedule-window__action { width: 100%; } }

/* Page Section: Services / #services-array
   Services array section: service-system hero, service cards, and responsive array layout. */
#services-array {
  --mx: 0;
  --my: 0;
  padding-top: clamp(1rem, 2vw, 2rem);
}

#services-array .services-array__frame {
  width: min(94rem, calc(100% - 2rem));
  margin: 0 auto;
  padding: clamp(1rem, 1.8vw, 1.5rem);
  border-radius: 2.5rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 150, 104, 0.12), transparent 22%),
    radial-gradient(circle at 84% 14%, rgba(142, 229, 255, 0.1), transparent 22%),
    linear-gradient(145deg, rgba(6, 10, 20, 0.98), rgba(8, 17, 31, 0.94));
  display: grid;
  grid-template-columns: minmax(0, 0.76fr) minmax(0, 1.24fr);
  gap: 1.2rem;
  box-shadow: 0 30px 110px rgba(0, 0, 0, 0.28);
}

#services-array .services-array__copy {
  display: grid;
  align-content: center;
  gap: 0.95rem;
}

#services-array .services-array__eyebrow,
#services-array .services-array__mini {
  font: 500 0.72rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(224, 232, 242, 0.72);
}

#services-array h1,
#services-array h2,
#services-array h3 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.065em;
}

#services-array h1 {
  max-width: 7ch;
  font-size: clamp(3rem, 6vw, 5.8rem);
  line-height: 0.92;
}

#services-array p {
  margin: 0;
  color: rgba(220, 228, 239, 0.82);
  font: 500 clamp(0.98rem, 1.3vw, 1.06rem)/1.6 "Manrope", sans-serif;
}

#services-array .services-array__actions,
#services-array .services-array__labels {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

#services-array .services-array__action,
#services-array .services-array__chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0 1.1rem;
  border-radius: 999px;
  border: 1px solid rgba(140, 226, 255, 0.16);
  text-decoration: none;
  color: #ecf2fa;
  background: rgba(255, 255, 255, 0.03);
  font: 700 0.92rem/1 "Manrope", sans-serif;
}

#services-array .services-array__action--primary {
  background: linear-gradient(135deg, #ff9064, #ffd677 72%, #bffbff);
  color: #07111d;
  border: 0;
}

#services-array .services-array__stage {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
  align-items: stretch;
}

#services-array .services-array__hero {
  grid-column: 1 / -1;
  position: relative;
  min-height: clamp(15rem, 26vw, 20rem);
  border-radius: 1.8rem;
  overflow: hidden;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background: rgba(4, 8, 18, 0.84);
}

#services-array .services-array__hero img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.05) translate3d(calc(var(--mx) * 10px), calc(var(--my) * 10px), 0);
  transition: transform 180ms ease-out;
  filter: saturate(0.96) brightness(0.86);
}

#services-array .services-array__overlay {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.22;
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 1;
}

#services-array .services-array__hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(110deg, rgba(5, 9, 17, 0.3), rgba(5, 9, 17, 0.72)),
    linear-gradient(180deg, rgba(5, 9, 17, 0.04), rgba(5, 9, 17, 0.4));
}

#services-array .services-array__signal {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  color: #f5f7fb;
}

#services-array .services-array__lane {
  padding: 1rem;
  border-radius: 1.45rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01)),
    rgba(8, 13, 24, 0.72);
  display: grid;
  gap: 0.55rem;
}

@media (max-width: 980px) {
  #services-array .services-array__frame {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  #services-array .services-array__frame {
    width: min(100%, calc(100% - 1rem));
  }

  #services-array .services-array__actions {
    display: grid;
  }

  #services-array .services-array__action,
  #services-array .services-array__stage,
  #services-array .services-array__lane {
    width: 100%;
  }

  #services-array .services-array__stage {
    grid-template-columns: 1fr;
  }

  #services-array .services-array__signal {
    position: static;
    flex-direction: column;
    padding: 1rem;
  }
}

/* Page Section: Terms / #terms-board
   Terms board section: terms hero and commercial scope cards. */
#terms-board { padding-top: clamp(1rem, 2vw, 2rem); }

#terms-board .terms-board__frame {
  width: min(90rem, calc(100% - 2rem)); margin: 0 auto; padding: clamp(1rem, 1.8vw, 1.5rem);
  position: relative; overflow: hidden;
  border-radius: 2.1rem; border: 1px solid rgba(140,226,255,0.14);
  background:
    linear-gradient(145deg, rgba(8,12,22,0.88), rgba(10,18,32,0.94)),
    url("/assets/media/stock/space/premium-website-brand-authority-giant-galaxy.webp") center/cover no-repeat;
  display: grid; gap: 1rem; box-shadow: 0 28px 100px rgba(0,0,0,0.26);
}
#terms-board .terms-board__frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("/assets/media/overlays/premium-website-neon-orbit-grid-overlay.svg") center/cover no-repeat;
  opacity: 0.12;
  mix-blend-mode: screen;
  pointer-events: none;
}
#terms-board .terms-board__eyebrow, #terms-board .terms-board__item strong { font: 500 0.72rem/1 "IBM Plex Mono", monospace; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(225,232,242,0.72); }
#terms-board h1 { margin: 0; max-width: 8ch; color: #f5f7fb; font: 700 clamp(2.8rem, 6vw, 5.2rem)/0.94 "Syne", sans-serif; letter-spacing: -0.07em; }
#terms-board p { margin: 0; color: rgba(220,228,239,0.82); font: 500 clamp(0.96rem, 1.2vw, 1.02rem)/1.6 "Manrope", sans-serif; }
#terms-board .terms-board__grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.75rem; }
#terms-board .terms-board__item { padding: 1rem; border-radius: 1.25rem; border: 1px solid rgba(140,226,255,0.12); background: rgba(255,255,255,0.02); display: grid; gap: 0.45rem; }
#terms-board .terms-board__eyebrow, #terms-board h1, #terms-board p, #terms-board .terms-board__grid, #terms-board .terms-board__item { position: relative; z-index: 1; }
@media (max-width: 900px) { #terms-board .terms-board__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 720px) { #terms-board .terms-board__frame { width: min(100%, calc(100% - 1rem)); } #terms-board .terms-board__grid { grid-template-columns: 1fr; } }

/* Sitewide rhythm and closing CTA pass:
   Re-assert consistent section spacing after the layered redesign work, and
   compress the final CTA pattern into a smaller closing bar instead of another
   oversized hero block. */
body[data-page] main.layout-page {
  --site-flow-gap: clamp(0.7rem, 1.35vw, 1rem);
  --site-section-space: clamp(2.35rem, 4.8vw, 4.35rem);
  --site-frame-gap: clamp(0.95rem, 1.8vw, 1.35rem);
  --site-panel-pad: clamp(1.15rem, 2vw, 1.55rem);
  --site-panel-gap: clamp(0.78rem, 1.3vw, 0.98rem);
  --site-surface-pad: clamp(1.1rem, 1.9vw, 1.5rem);
  --site-surface-gap: clamp(0.75rem, 1.25vw, 0.92rem);
  --site-text-surface-pad: clamp(1.2rem, 2.05vw, 1.68rem);
  --site-text-surface-gap: clamp(0.82rem, 1.35vw, 1.02rem);
  gap: var(--site-flow-gap);
  padding-bottom: clamp(1rem, 2vw, 1.45rem);
}

body[data-page] main.layout-page > .section {
  padding-block: var(--site-section-space);
}

body[data-page] main.layout-page .shell,
body[data-page] main.layout-page .hero-mast__shell {
  width: min(100% - clamp(1.25rem, 4vw, 2.75rem), var(--container));
}

body[data-page] main.layout-page .layout-section__frame,
body[data-page] main.layout-page .faq-overview,
body[data-page] main.layout-page .policy-atlas__frame,
body[data-page] main.layout-page .contact-grid,
body[data-page] main.layout-page .payment-flow,
body[data-page] main.layout-page .route-grid,
body[data-page] main.layout-page .card-grid,
body[data-page] main.layout-page .service-detail-grid,
body[data-page] main.layout-page .study-grid,
body[data-page] main.layout-page .layout-panel-grid,
body[data-page] main.layout-page .layout-metric-grid,
body[data-page] main.layout-page .layout-step-grid,
body[data-page] main.layout-page .layout-category-grid,
body[data-page] main.layout-page .home-decision-grid,
body[data-page] main.layout-page .policy-atlas__cards,
body[data-page] main.layout-page .story-grid {
  gap: var(--site-frame-gap);
}

body[data-page] main.layout-page .section-heading.section-heading--panel,
body[data-page] main.layout-page .layout-section__intro,
body[data-page] main.layout-page .faq-summary,
body[data-page] main.layout-page .policy-summary {
  gap: var(--site-panel-gap);
  padding: var(--site-panel-pad);
}

body[data-page] main.layout-page .route-card,
body[data-page] main.layout-page .service-detail,
body[data-page] main.layout-page .card,
body[data-page] main.layout-page .study-card,
body[data-page] main.layout-page .contact-card,
body[data-page] main.layout-page .form-card,
body[data-page] main.layout-page .faq-shell,
body[data-page] main.layout-page .policy-card,
body[data-page] main.layout-page .layout-panel,
body[data-page] main.layout-page .layout-metric,
body[data-page] main.layout-page .layout-category,
body[data-page] main.layout-page .layout-timeline,
body[data-page] main.layout-page .brief-section,
body[data-page] main.layout-page .embed-card,
body[data-page] main.layout-page .home-decision-card {
  gap: var(--site-surface-gap);
  padding: var(--site-surface-pad);
}

body[data-page] main.layout-page .quote-banner,
body[data-page] main.layout-page .callout,
body[data-page] main.layout-page .layout-callout,
body[data-page] main.layout-page .story-grid__copy,
body[data-page] main.layout-page .story-grid__media,
body[data-page] main.layout-page .brief-hub__mast {
  gap: var(--site-text-surface-gap);
  padding: var(--site-text-surface-pad);
}

body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout),
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: clamp(0.8rem, 1.45vw, 1.1rem) clamp(1rem, 2vw, 1.5rem);
  padding: clamp(1rem, 1.8vw, 1.3rem);
  border-radius: 26px;
  border: 1px solid rgba(149, 228, 255, 0.16);
  background:
    radial-gradient(circle at top left, rgba(121, 227, 255, 0.12), transparent 32%),
    radial-gradient(circle at bottom right, rgba(82, 128, 255, 0.12), transparent 34%),
    rgba(7, 13, 24, 0.9);
  box-shadow: 0 20px 56px rgba(0, 0, 0, 0.18);
}

body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout) > .section-mark,
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > .section-mark {
  width: 2.65rem;
  height: 2.65rem;
  margin: 0;
}

body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout) > :is(.eyebrow, .layout-section__kicker),
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > :is(.eyebrow, .layout-section__kicker) {
  margin: 0;
}

body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout) > :is(blockquote, .callout__title),
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > :is(blockquote, .callout__title) {
  flex: 0 1 12ch;
  max-width: 12ch;
  font-size: clamp(1.55rem, 2.7vw, 2.35rem);
  line-height: 0.96;
}

body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout) > p:not(.page-hero__punch),
body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout) > .section-text,
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > p:not(.page-hero__punch),
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > .section-text {
  flex: 1 1 20rem;
  max-width: 38rem;
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.58;
}

body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout) > .hero__actions,
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > .hero__actions {
  margin-top: 0;
  margin-left: auto;
  align-items: center;
}

body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout) > .hero__actions .button,
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > .hero__actions .button {
  min-height: 46px;
  padding-inline: 1rem;
}

body[data-page] main.layout-page > :is(
  .home-band--closing,
  .about-band--closing,
  .services-band--closing,
  .process-band--closing,
  .discovery-band--closing,
  .faq-band--closing,
  .pay-band--closing,
  .schedule-band--closing,
  .examples-band--closing
) :is(.quote-banner, .callout, .layout-callout) > .page-hero__punch,
body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > .page-hero__punch {
  width: 100%;
  margin: 0;
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-align: left;
  opacity: 0.76;
}

body[data-page="about"] #about-signal {
  padding-top: clamp(0.45rem, 1.5vw, 1rem);
}

body[data-page="about"] #about-signal .about-cover {
  position: relative;
  width: min(100% - clamp(1.25rem, 4vw, 2.75rem), 1700px);
  min-height: clamp(35rem, 90vh, 56rem);
  margin: 0 auto;
  overflow: hidden;
  border-radius: 42px;
  border: 1px solid rgba(149, 228, 255, 0.16);
  box-shadow: 0 32px 110px rgba(0, 0, 0, 0.34);
  background: #050814;
}

body[data-page="about"] #about-signal .about-cover__media,
body[data-page="about"] #about-signal .about-cover__shade,
body[data-page="about"] #about-signal .about-cover__glow {
  position: absolute;
  inset: 0;
}

body[data-page="about"] #about-signal .about-cover__media {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.96;
  transform: scale(1.02);
}

body[data-page="about"] #about-signal .about-cover__shade {
  background:
    radial-gradient(circle at center, rgba(8, 15, 29, 0.16) 0%, rgba(5, 10, 22, 0.68) 54%, rgba(3, 6, 16, 0.92) 100%),
    linear-gradient(180deg, rgba(4, 8, 18, 0.46) 0%, rgba(4, 8, 18, 0.2) 28%, rgba(4, 8, 18, 0.8) 100%);
}

body[data-page="about"] #about-signal .about-cover__glow {
  top: 50%;
  left: 50%;
  right: auto;
  bottom: auto;
  width: min(72vw, 58rem);
  height: min(72vw, 58rem);
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: radial-gradient(circle, rgba(74, 127, 255, 0.18) 0%, rgba(74, 127, 255, 0.05) 34%, rgba(74, 127, 255, 0) 72%);
  filter: blur(22px);
}

body[data-page="about"] #about-signal .about-cover__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.4rem;
  width: min(100% - 2rem, 54rem);
  min-height: inherit;
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 4.5rem) clamp(1rem, 3vw, 2rem);
  text-align: center;
}

body[data-page="about"] #about-signal .about-cover__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  min-height: 40px;
  padding: 0.65rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(10px);
  color: rgba(255, 255, 255, 0.82);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

body[data-page="about"] #about-signal .about-cover__eyebrow::before {
  content: "";
  width: 0.52rem;
  height: 0.52rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #79e3ff, #4f8bff);
  box-shadow: 0 0 18px rgba(121, 227, 255, 0.54);
}

body[data-page="about"] #about-signal .about-cover__title {
  margin: 0;
  max-width: 10ch;
  color: #fff;
  font-family: var(--font-display);
  font-size: clamp(3.2rem, 8vw, 6.9rem);
  line-height: 0.92;
  letter-spacing: -0.07em;
  text-wrap: balance;
  text-shadow: 0 18px 44px rgba(0, 0, 0, 0.34);
}

body[data-page="about"] #about-signal .about-cover__lede {
  margin: 0;
  max-width: 36rem;
  color: rgba(255, 255, 255, 0.82);
  font-size: clamp(1rem, 1.7vw, 1.18rem);
  line-height: 1.58;
}

body[data-page="about"] #about-signal .about-cover__actions,
body[data-page="about"] #about-signal .about-cover__chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

body[data-page="about"] #about-signal .about-cover__actions {
  gap: 0.85rem;
}

body[data-page="about"] #about-signal .about-cover__chips {
  gap: 0.65rem;
}

body[data-page="about"] #about-signal .about-cover__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 1.35rem;
  border-radius: 999px;
  font-size: 0.96rem;
  color: #fff;
}

body[data-page="about"] #about-signal .about-cover__button--primary {
  background: linear-gradient(135deg, #6ca8ff 0%, #2e6bff 56%, #1742c8 100%);
  box-shadow: 0 18px 50px rgba(43, 103, 255, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

body[data-page="about"] #about-signal .about-cover__button--secondary {
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(10px);
}

body[data-page="about"] #about-signal .about-cover__chip {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 0.95rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.8rem;
  backdrop-filter: blur(8px);
}

body[data-page="about"] main.layout-page .about-sequence__grid {
  display: grid;
  gap: var(--site-frame-gap);
}

body[data-page="about"] main.layout-page .about-band--signals .card-grid {
  display: grid;
  gap: var(--site-frame-gap);
  grid-template-columns: 1fr;
}

body[data-page="about"] main.layout-page .about-band--signals .card-grid > * {
  grid-column: auto;
}

body[data-page="about"] main.layout-page .about-sequence__step {
  display: grid;
  gap: 0.75rem;
  align-content: start;
  padding: var(--site-surface-pad);
  border-radius: calc(var(--radius-xl) - 2px);
  border: 1px solid rgba(149, 228, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.042), rgba(255, 255, 255, 0.012)),
    rgba(6, 12, 23, 0.78);
}

body[data-page="about"] main.layout-page .about-sequence__index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.1rem;
  height: 3.1rem;
  border-radius: 18px;
  border: 1px solid rgba(149, 228, 255, 0.18);
  background:
    linear-gradient(145deg, rgba(111, 132, 255, 0.12), rgba(255, 147, 95, 0.08)),
    rgba(8, 14, 26, 0.9);
  color: var(--editorial-text);
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

body[data-page="about"] main.layout-page .about-sequence__step h3 {
  margin: 0;
  color: var(--editorial-text);
  font-family: var(--font-display);
  font-size: clamp(1.45rem, 2.6vw, 2.1rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
}

body[data-page="about"] main.layout-page .about-sequence__step p {
  margin: 0;
  color: var(--editorial-soft);
  line-height: 1.62;
}

@media (min-width: 980px) {
  body[data-page="about"] main.layout-page .about-band--signals .card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="about"] main.layout-page .about-sequence__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  body[data-page] main.layout-page > :is(
    .home-band--closing,
    .about-band--closing,
    .services-band--closing,
    .process-band--closing,
    .discovery-band--closing,
    .faq-band--closing,
    .pay-band--closing,
    .schedule-band--closing,
    .examples-band--closing
  ) :is(.quote-banner, .callout, .layout-callout) > .hero__actions,
  body[data-page="invest"] main.layout-page > .section:last-of-type .layout-callout > .hero__actions {
    width: 100%;
    margin-left: 0;
    justify-content: flex-start;
  }

  body[data-page="about"] #about-signal .about-cover {
    min-height: clamp(30rem, 82vh, 44rem);
    border-radius: 32px;
  }

  body[data-page="about"] #about-signal .about-cover__content {
    width: min(100% - 1.5rem, 44rem);
    padding-inline: 0.25rem;
  }

  body[data-page="about"] #about-signal .about-cover__title {
    font-size: clamp(2.9rem, 12vw, 4.9rem);
  }
}

/* ==========================================================================
   CSS Section: Discovery Page Responsive Reset
   Simplifies the discovery hero, narrows the quick-nav rail, and keeps the
   questionnaire fully open with mobile-first spacing.
   ========================================================================== */
body[data-page="discovery"] #discovery-switch .discovery-switch__frame--reset,
body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip,
body[data-page="discovery"] main.layout-page .discovery-band--brief .shell,
body[data-page="discovery"] main.layout-page .discovery-band--closing .shell {
  width: min(calc(100% - 1rem), 96rem);
}

body[data-page="discovery"] #discovery-switch .discovery-switch__frame--reset {
  grid-template-columns: 1fr;
  grid-template-areas:
    "copy"
    "hero"
    "micro";
  gap: var(--site-frame-gap);
  padding: clamp(1rem, 2.8vw, 1.5rem);
}

body[data-page="discovery"] #discovery-switch .discovery-switch__copy {
  grid-area: copy;
  gap: 1rem;
  align-content: start;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__copy h1 {
  max-width: 7ch;
  text-wrap: balance;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__copy > p {
  max-width: 34ch;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__actions .button {
  width: 100%;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__signals {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11.5rem, 1fr));
  gap: 0.75rem;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__signal {
  display: grid;
  gap: 0.4rem;
  padding: 0.9rem 1rem;
  border-radius: 1.2rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.012)),
    rgba(8, 13, 24, 0.76);
}

body[data-page="discovery"] #discovery-switch .discovery-switch__signal span {
  font: 500 0.68rem/1 "IBM Plex Mono", monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(225, 232, 242, 0.66);
}

body[data-page="discovery"] #discovery-switch .discovery-switch__signal strong {
  color: #f5f7fb;
  font: 700 0.96rem/1.32 "Manrope", sans-serif;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__hero {
  grid-area: hero;
  margin: 0;
  min-height: clamp(18rem, 64vw, 28rem);
  border-radius: 1.7rem;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__hero-image {
  transform: scale(1.02);
  filter: saturate(0.92) contrast(1.08) brightness(0.84);
}

body[data-page="discovery"] #discovery-switch .discovery-switch__hero-copy {
  inset: auto 1rem 1rem 1rem;
  gap: 0.5rem;
  padding: 1rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(140, 226, 255, 0.14);
  background: rgba(7, 12, 21, 0.6);
  backdrop-filter: blur(12px);
}

body[data-page="discovery"] #discovery-switch .discovery-switch__hero-copy strong {
  color: #f5f7fb;
  font: 700 clamp(1.2rem, 2.4vw, 1.6rem)/1.02 "Syne", sans-serif;
  letter-spacing: -0.05em;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__hero-copy p {
  max-width: 22ch;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__board {
  grid-area: board;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

body[data-page="discovery"] #discovery-switch .discovery-switch__micro--reset {
  grid-area: micro;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.8rem;
}

body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 0.75rem;
}

body[data-page="discovery"] #discovery-switch .discovery-route-card,
body[data-page="discovery"] #discovery-switch .discovery-step-card,
body[data-page="discovery"] .discovery-guide-strip__card,
body[data-page="discovery"] .discovery-form__banner,
body[data-page="discovery"] .discovery-submit,
body[data-page="discovery"] .discovery-exit {
  padding: var(--site-surface-pad);
}

body[data-page="discovery"] #discovery-switch .discovery-route-card__note {
  margin: auto 0 0;
  padding-top: 0.8rem;
  border-top: 1px solid rgba(140, 226, 255, 0.1);
  color: rgba(225, 232, 242, 0.72);
  font: 500 0.88rem/1.5 "Manrope", sans-serif;
}

body[data-page="discovery"] .discovery-guide-strip__card {
  gap: 0.3rem;
  align-content: start;
  min-height: auto;
  padding: 0.9rem 1rem;
}

body[data-page="discovery"] .discovery-guide-strip__card h3 {
  font-size: clamp(1rem, 1.5vw, 1.18rem);
  line-height: 1.02;
}

body[data-page="discovery"] .discovery-guide-strip__card p {
  max-width: 28ch;
  font-size: 0.9rem;
  line-height: 1.45;
}

body[data-page="discovery"] .discovery-brief__guide-copy {
  display: grid;
  gap: 0.4rem;
}

body[data-page="discovery"] .discovery-brief__guide-copy h3 {
  margin: 0;
  color: #f5f7fb;
  font-family: "Syne", sans-serif;
  font-size: clamp(1.25rem, 2.2vw, 1.6rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

body[data-page="discovery"] .discovery-brief__guide-copy p {
  margin: 0;
  max-width: 26ch;
  color: rgba(220, 228, 239, 0.78);
  font-size: 0.92rem;
}

body[data-page="discovery"] main.layout-page .discovery-band--brief .shell {
  gap: var(--site-frame-gap);
}

body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form {
  display: grid;
  gap: var(--site-frame-gap);
}

body[data-page="discovery"] .discovery-brief__aside {
  display: none;
}

body[data-page="discovery"] .discovery-brief__guide--rail {
  padding: clamp(0.9rem, 2.4vw, 1.05rem);
  gap: 0.85rem;
}

body[data-page="discovery"] .discovery-brief__guide .brief-hub__nav {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10.75rem, 1fr));
  gap: 0.55rem;
  overflow: visible;
  padding-bottom: 0;
}

body[data-page="discovery"] .discovery-brief__guide .brief-hub__nav a {
  min-width: 0;
  width: 100%;
  gap: 0.6rem;
  padding: 0.72rem 0.76rem;
}

body[data-page="discovery"] .discovery-brief__guide .brief-hub__nav a span {
  min-width: 1.7rem;
  min-height: 1.7rem;
  font-size: 0.62rem;
}

body[data-page="discovery"] .discovery-brief__guide .brief-hub__nav a strong {
  white-space: normal;
  font-size: 0.8rem;
  line-height: 1.28;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section {
  display: grid;
  gap: 1rem;
  padding: clamp(1rem, 2.2vw, 1.25rem);
  scroll-margin-top: 7rem;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__head {
  grid-template-columns: auto minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  position: static;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__head-copy {
  display: grid;
  gap: 0.55rem;
  min-width: 0;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__head p {
  margin: 0;
  max-width: 34ch;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section h3 {
  font-size: clamp(1.55rem, 2vw, 1.95rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section__grid {
  display: grid;
  gap: 0.9rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(140, 226, 255, 0.1);
}

body[data-page="discovery"].discovery-brief--enhanced .brief-section:not(.is-open) .brief-section__grid {
  display: grid;
}

@media (min-width: 560px) {
  body[data-page="discovery"] #discovery-switch .discovery-switch__actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 720px) {
  body[data-page="discovery"] #discovery-switch .discovery-switch__frame--reset,
  body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip,
  body[data-page="discovery"] main.layout-page .discovery-band--brief .shell,
  body[data-page="discovery"] main.layout-page .discovery-band--closing .shell {
    width: min(calc(100% - 2rem), 108rem);
  }

  body[data-page="discovery"] #discovery-switch .discovery-switch__board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="discovery"] #discovery-switch .discovery-switch__micro--reset {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body[data-page="discovery"] .discovery-brief__aside {
    display: block;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .discovery-brief__aside {
    grid-column: 1 / -1;
  }

  body[data-page="discovery"] .discovery-brief__guide--rail {
    padding: 0.95rem 1rem;
  }

  body[data-page="discovery"] .discovery-brief__guide .brief-hub__nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 980px) and (max-width: 1199px) {
  body[data-page="discovery"] .discovery-brief__guide .brief-hub__nav {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (min-width: 1200px) and (max-width: 1439px) {
  body[data-page="discovery"] #discovery-switch .discovery-switch__frame--reset,
  body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip,
  body[data-page="discovery"] main.layout-page .discovery-band--brief .shell,
  body[data-page="discovery"] main.layout-page .discovery-band--closing .shell {
    width: min(calc(100% - 3rem), 132rem);
  }

  body[data-page="discovery"] .discovery-brief__guide .brief-hub__nav {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

@media (min-width: 960px) and (max-width: 1439px) {
  body[data-page="discovery"] main.layout-page .discovery-band--brief .shell {
    grid-template-columns: 1fr;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .discovery-brief__aside {
    position: static;
    top: auto;
    align-self: auto;
    grid-column: 1 / -1 !important;
    width: 100%;
    max-width: none;
    justify-self: stretch;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form,
  body[data-page="discovery"] main.layout-page .discovery-band--brief [data-form-success],
  body[data-page="discovery"] main.layout-page .discovery-band--brief [data-form-error] {
    grid-column: 1 / -1 !important;
  }
}

@media (min-width: 1440px) {
  body[data-page="discovery"] #discovery-switch .discovery-switch__frame--reset,
  body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip,
  body[data-page="discovery"] main.layout-page .discovery-band--brief .shell,
  body[data-page="discovery"] main.layout-page .discovery-band--closing .shell {
    width: min(calc(100% - 3rem), 132rem);
  }

  body[data-page="discovery"] #discovery-switch .discovery-switch__frame--reset {
    grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
    grid-template-areas:
      "copy hero"
      "micro micro";
    align-items: start;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form {
    grid-template-columns: minmax(0, 1fr) minmax(14rem, 16.5rem);
    align-items: start;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form > :not(.discovery-brief__aside) {
    grid-column: 1;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form > .discovery-form__banner,
  body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form > .brief-section--lead {
    grid-column: 1 / -1;
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .discovery-brief__aside {
    position: sticky;
    top: 6.45rem;
    align-self: start;
    grid-column: 2;
    grid-row: 3;
    width: 100%;
    max-width: 16.5rem;
    justify-self: end;
  }

  body[data-page="discovery"] .discovery-brief__guide .brief-hub__nav {
    grid-template-columns: 1fr;
    max-height: min(68vh, 38rem);
    overflow-y: auto;
    padding-right: 0.15rem;
  }
}

@media (min-width: 1180px) {
  body[data-page="discovery"].discovery-brief--enhanced .brief-section {
    grid-template-columns: minmax(16rem, 18rem) minmax(0, 1fr);
    align-items: start;
  }

  body[data-page="discovery"].discovery-brief--enhanced .brief-section__head {
    position: sticky;
    top: 6.8rem;
  }
}

@media (min-width: 1600px) {
  body[data-page="discovery"] #discovery-switch .discovery-switch__frame--reset,
  body[data-page="discovery"] .discovery-band--guide .shell.discovery-guide-strip,
  body[data-page="discovery"] main.layout-page .discovery-band--brief .shell,
  body[data-page="discovery"] main.layout-page .discovery-band--closing .shell {
    width: min(calc(100% - 4rem), 150rem);
  }

  body[data-page="discovery"] main.layout-page .discovery-band--brief .stacked-form {
    grid-template-columns: minmax(0, 1fr) minmax(14.5rem, 17rem);
  }

  body[data-page="discovery"].discovery-brief--enhanced .brief-section {
    grid-template-columns: minmax(17rem, 19rem) minmax(0, 1fr);
  }
}
