:root {
  --bg: #ffffff;
  --bg-soft: #ffffff;
  --panel: rgba(255, 255, 255, 0.84);
  --card: #ffffff;
  --text: #1f1711;
  --muted: #6a5a4d;
  --line: rgba(36, 27, 21, 0.1);
  --line-strong: rgba(36, 27, 21, 0.15);
  --accent: #e56a3d;
  --accent-deep: #ca4f25;
  --accent-soft: rgba(229, 106, 61, 0.11);
  --sage-soft: rgba(111, 131, 103, 0.12);
  --shadow: 0 26px 70px rgba(31, 23, 17, 0.09);
  --shadow-soft: 0 18px 40px rgba(31, 23, 17, 0.06);
  --radius-xl: 34px;
  --radius-lg: 26px;
  --radius-md: 20px;
  --radius-sm: 14px;
  --content-width: 1080px;
  --font-heading: "Avenir Next", Avenir, "SF Pro Display", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --font-body: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --font-accent: "Avenir Next", Avenir, "SF Pro Text", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
}

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

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

.page-shell {
  width: min(100%, 1380px);
  margin: 0 auto;
  background: var(--bg-soft);
  border: 0;
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
}

.topbar,
.hero,
.feature-section,
.activity-section,
.download-panel,
.footer {
  width: min(calc(100% - 40px), var(--content-width));
  margin: 0 auto;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  padding: 22px 0 18px;
}

.brand-lockup {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.brand-logo {
  width: 40px;
  height: 40px;
  object-fit: contain;
}

.brand-name {
  font-size: 1.08rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  font-family: var(--font-heading);
}

.store-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 24px;
  border-radius: 18px;
  background: #111111;
  color: #ffffff;
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  box-shadow: none;
  font-family: var(--font-accent);
}

.store-link.compact {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 14px;
  font-size: 0.88rem;
  box-shadow: none;
}

.hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
  padding: 40px 0 74px;
}

.hero-copy {
  max-width: 560px;
}

.hero-visual {
  display: flex;
  justify-content: center;
}

.hero-illustration {
  width: min(100%, 330px);
  height: auto;
}

.eyebrow,
.section-label {
  margin: 0 0 14px;
  color: var(--accent);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  font-family: var(--font-accent);
}

.hero h1,
.feature-copy h2,
.activity-copy h2,
.download-panel h2 {
  margin: 0;
  font-family: var(--font-heading);
  letter-spacing: -0.05em;
  font-weight: 700;
}

.hero h1 {
  font-size: clamp(2.1rem, 7vw, 3.1rem);
  line-height: 1;
}

.feature-copy h2,
.activity-copy h2,
.download-panel h2 {
  font-size: clamp(1.4rem, 5vw, 2rem);
  line-height: 1.06;
}

.lede,
.feature-copy p:not(.section-label),
.activity-copy p:not(.section-label),
.download-panel p:not(.section-label) {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.72;
  font-family: var(--font-body);
}

.micro-points,
.signal-cluster {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin-top: 18px;
}

.hero-points {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.hero-point {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  color: var(--muted);
  font-size: 0.96rem;
  line-height: 1.5;
  font-family: var(--font-body);
}

.hero-point-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(36, 27, 21, 0.08);
  background: rgba(255, 255, 255, 0.7);
  color: var(--text);
}

.hero-point-icon svg {
  width: 15px;
  height: 15px;
}

.legal-main {
  width: min(calc(100% - 40px), var(--content-width));
  margin: 0 auto;
  padding: 20px 0 48px;
}

.legal-article {
  max-width: 760px;
}

.legal-article h1 {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(2rem, 7vw, 2.8rem);
  line-height: 1.02;
  letter-spacing: -0.05em;
  font-weight: 700;
}

.legal-article h2 {
  margin: 34px 0 0;
  font-family: var(--font-heading);
  font-size: clamp(1.2rem, 4vw, 1.55rem);
  line-height: 1.12;
  letter-spacing: -0.03em;
  font-weight: 700;
}

.legal-meta {
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.6;
}

.legal-article p,
.legal-article li {
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.75;
}

.legal-article p {
  margin: 16px 0 0;
}

.legal-article ul {
  margin: 14px 0 0;
  padding-left: 22px;
}

.legal-article li + li {
  margin-top: 8px;
}

.legal-note {
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid rgba(36, 27, 21, 0.08);
  font-size: 0.95rem;
}

.how-grid {
  display: grid;
  gap: 16px;
  margin-top: 26px;
}

.how-step {
  padding: 18px 0 0;
  border-top: 1px solid rgba(36, 27, 21, 0.08);
}

.how-step:first-of-type {
  padding-top: 0;
  border-top: 0;
}

.how-step-number {
  display: inline-block;
  margin-bottom: 8px;
  color: var(--accent);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-family: var(--font-accent);
}

.how-step h2 {
  margin-top: 0;
}

.how-note {
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid rgba(36, 27, 21, 0.08);
}

.micro-points span,
.signal-cluster span {
  display: inline;
  min-height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: none;
  color: var(--muted);
  font-size: 0.95rem;
  font-weight: 500;
  font-family: var(--font-accent);
}

.micro-points span::after,
.signal-cluster span::after {
  content: "·";
  margin-left: 12px;
  color: rgba(36, 27, 21, 0.34);
}

.micro-points span:last-child::after,
.signal-cluster span:last-child::after {
  content: "";
  margin-left: 0;
}

.feature-visual,
.activity-visual {
  display: flex;
  justify-content: center;
}

.shot-crop {
  position: relative;
  overflow: visible;
  padding: 6px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, #26292c 0%, #0f1113 48%, #1a1c20 100%);
  box-shadow:
    0 18px 36px rgba(31, 23, 17, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    inset 0 -1px 0 rgba(255, 255, 255, 0.05);
  line-height: 0;
}

.shot-crop::before {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 25px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  pointer-events: none;
}

.shot-crop::after {
  content: "";
  position: absolute;
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
  width: 29%;
  max-width: 64px;
  min-width: 26px;
  height: 8px;
  border-radius: 999px;
  background: #090a0b;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
  pointer-events: none;
}

.phone-screen {
  overflow: hidden;
  border-radius: 22px;
  background: #ffffff;
}

.app-shot {
  width: 100%;
  height: auto;
  border-radius: 0;
  filter: none;
}

.feature-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: center;
  padding: 24px 0;
}

.shot-crop-vibe {
  width: min(100%, 156px);
  margin: 0 auto;
  padding: 5px;
  border-radius: 20px;
}

.shot-crop-vibe::before {
  inset: 2px;
  border-radius: 17px;
}

.shot-crop-vibe::after {
  top: 5px;
  width: 32%;
  height: 6px;
  max-width: 24px;
  min-width: 16px;
}

.shot-crop-vibe .phone-screen {
  border-radius: 14px;
}

.app-shot-vibe {
  width: 100%;
}

.activity-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: center;
  padding: 24px 0;
}

.download-panel {
  margin-bottom: 22px;
  padding: 38px 0 22px;
  border-radius: 0;
  background: transparent;
  border: 0;
  border-top: 1px solid rgba(36, 27, 21, 0.08);
  text-align: left;
  box-shadow: none;
}

.download-panel h2,
.download-panel p {
  max-width: 460px;
}

.download-panel .store-link {
  margin-top: 18px;
}

.footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 22px 0 40px;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  color: var(--muted);
  font-size: 0.95rem;
  font-family: var(--font-body);
}

@media (min-width: 760px) {
  .page-shell {
    width: min(100%, 1400px);
  }

  .topbar,
  .hero,
  .feature-section,
  .activity-section,
  .download-panel,
  .footer {
    width: min(calc(100% - 72px), var(--content-width));
  }

  .legal-main {
    width: min(calc(100% - 72px), var(--content-width));
    padding: 28px 0 64px;
  }

  .how-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 30px;
    row-gap: 22px;
  }

  .how-step {
    padding-top: 22px;
  }

  .how-step:nth-child(-n + 2) {
    padding-top: 0;
    border-top: 0;
  }

  .topbar {
    padding: 28px 0 20px;
  }

  .hero {
    grid-template-columns: minmax(0, 1fr) minmax(240px, 360px);
    gap: 28px;
    padding: 56px 0 96px;
  }

  .hero-visual {
    justify-content: flex-start;
  }

  .feature-section {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 0;
  }

  .shot-crop-vibe {
    width: min(100%, 150px);
  }

  .activity-section {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 0;
  }

  .download-panel {
    padding: 46px 0 24px;
  }

  .footer {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    padding: 12px 0 32px;
  }
}

body.xmx-home {
  --hero-progress: 0;
  --pointer-x: 0;
  --pointer-y: 0;
  --paper: #f4f0e8;
  --ink: #070707;
  --fog: #949494;
  --line: rgba(255, 255, 255, 0.1);
  --xmx-stage: min(100vw, 112svh);
  --xmx-stage-tight: min(100vw, 96svh);
  --xmx-frame-edge: clamp(20px, 3.8vmin, 56px);
  --xmx-copy-size: clamp(0.78rem, 1.65vmin, 0.94rem);
  --xmx-meta-size: clamp(0.66rem, 1.15vmin, 0.72rem);
  --xmx-link-size: clamp(0.84rem, 1.5vmin, 0.92rem);
  min-height: 100vh;
  height: 100svh;
  overflow-x: hidden;
  overflow-y: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
  scroll-behavior: smooth;
  scroll-snap-type: y mandatory;
  overscroll-behavior-y: contain;
  background:
    linear-gradient(180deg, #010101 0%, #030303 42%, #070707 100%);
  color: #e7e7e7;
  font-family:
    "IBM Plex Mono",
    "SFMono-Regular",
    SFMono-Regular,
    ui-monospace,
    Menlo,
    Monaco,
    Consolas,
    "Liberation Mono",
    monospace;
}

.xmx-scroll-root {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.xmx-scroll-root::-webkit-scrollbar,
body.xmx-home::-webkit-scrollbar {
  display: none;
}

.xmx-home::before {
  content: "";
  position: fixed;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255, 255, 255, 0.022) 1px, transparent 1px);
  background-size: 88px 88px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.8), transparent 92%);
  opacity: 0.12;
  pointer-events: none;
  z-index: 0;
}

.xmx-cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 999px;
  pointer-events: none;
  z-index: 30;
  opacity: 0;
  transform: translate3d(-120px, -120px, 0);
  mix-blend-mode: difference;
  transition:
    width 180ms ease,
    height 180ms ease,
    margin 180ms ease,
    border-color 180ms ease,
    opacity 180ms ease;
}

.xmx-cursor.is-visible {
  opacity: 0.92;
}

.xmx-cursor.is-active {
  width: 56px;
  height: 56px;
  margin-left: -9px;
  margin-top: -9px;
  border-color: rgba(255, 255, 255, 0.95);
}

.xmx-cursor-dot {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #ffffff;
  transform: translate(-50%, -50%);
}

.xmx-scroll-indicator {
  position: fixed;
  top: 50%;
  right: 14px;
  width: 1px;
  height: 116px;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 28;
}

.xmx-scroll-track,
.xmx-scroll-thumb {
  position: absolute;
  left: 0;
  width: 1px;
  border-radius: 999px;
}

.xmx-scroll-track {
  top: 0;
  bottom: 0;
  background: var(--scroll-indicator-track, rgba(255, 255, 255, 0.24));
}

.xmx-scroll-thumb {
  top: 0;
  height: 26px;
  background: var(--scroll-indicator-thumb, rgba(255, 255, 255, 0.96));
  transform: translateY(0);
  transition:
    transform 180ms ease,
    background-color 180ms ease;
}

body.xmx-home {
  --scroll-indicator-track: rgba(255, 255, 255, 0.24);
  --scroll-indicator-thumb: rgba(255, 255, 255, 0.96);
  --floating-link-ink: rgba(255, 255, 255, 0.96);
  --floating-link-line: rgba(255, 255, 255, 0.2);
  --floating-link-bg: rgba(255, 255, 255, 0.02);
}

body.xmx-home[data-panel-tone="light"] {
  --scroll-indicator-track: rgba(0, 0, 0, 0.2);
  --scroll-indicator-thumb: rgba(0, 0, 0, 0.96);
  --floating-link-ink: rgba(0, 0, 0, 0.96);
  --floating-link-line: rgba(0, 0, 0, 0.18);
  --floating-link-bg: rgba(0, 0, 0, 0.02);
}

.xmx-floating-link {
  position: fixed;
  top: 18px;
  right: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  height: 31px;
  padding: 0 12px;
  border: 1px solid var(--floating-link-line);
  border-radius: 999px;
  background: var(--floating-link-bg);
  color: var(--floating-link-ink);
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  backdrop-filter: blur(10px);
  transition:
    color 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease,
    transform 180ms ease;
  z-index: 29;
}

.xmx-floating-link:hover,
.xmx-floating-link:focus-visible {
  transform: translateY(-1px);
}

@media (pointer: fine) {
  body.xmx-home,
  body.xmx-home a,
  body.xmx-home button {
    cursor: none;
  }
}

@media (pointer: coarse), (prefers-reduced-motion: reduce) {
  .xmx-cursor {
    display: none;
  }
}

@media (max-width: 760px) {
  .xmx-panel-frame-about-hero {
    align-items: flex-start;
    padding-top: clamp(88px, 16svh, 124px);
  }

  .xmx-panel-about-hero .xmx-microcopy {
    font-size: 0.74rem;
    color: rgba(255, 255, 255, 0.74);
  }

  .xmx-floating-link {
    top: 14px;
    right: 14px;
    min-width: 58px;
    height: 29px;
    padding: 0 10px;
    font-size: 0.64rem;
  }

  .xmx-scroll-indicator {
    right: 10px;
    height: 92px;
  }

  .xmx-scroll-thumb {
    height: 22px;
  }
}

.xmx-home .page-shell {
  position: relative;
  z-index: 2;
  width: 100%;
}

.xmx-main {
  position: relative;
}

.xmx-panel {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding: clamp(24px, 4vw, 48px) 0;
  scroll-snap-align: start;
  scroll-snap-stop: always;
}

.xmx-panel-dark {
  color: #ececec;
  background: transparent;
}

.xmx-panel-dark::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 50% 22%, rgba(255, 255, 255, 0.02), transparent 16%),
    linear-gradient(180deg, rgba(6, 6, 6, 0.06), rgba(6, 6, 6, 0.14) 54%, rgba(6, 6, 6, 0.34));
  pointer-events: none;
}

.xmx-panel-particles {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}

.xmx-panel-particles::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 50%, transparent 0%, rgba(0, 0, 0, 0.12) 64%, rgba(0, 0, 0, 0.42) 100%);
  pointer-events: none;
}

.xmx-panel-particles canvas {
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0.98;
}

.xmx-panel-hero .xmx-panel-particles {
  opacity: 0.92;
}

.xmx-panel-products .xmx-panel-particles {
  opacity: 0.76;
}

.xmx-panel-hero {
  background:
    radial-gradient(circle at 52% 16%, rgba(255, 255, 255, 0.045), transparent 18%),
    linear-gradient(180deg, #020202 0%, #050505 100%);
}

.xmx-panel-about-hero {
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 255, 255, 0.04), transparent 20%),
    linear-gradient(180deg, #020202 0%, #050505 100%);
}

.xmx-panel-white {
  background: var(--paper);
  color: var(--ink);
}

.xmx-panel-frame {
  position: relative;
  z-index: 2;
  width: min(calc(100% - (var(--xmx-frame-edge) * 2)), 1440px);
  margin: 0 auto;
}

.xmx-panel-frame-hero,
.xmx-panel-frame-statement,
.xmx-panel-frame-contact {
  display: flex;
  align-items: center;
  min-height: calc(100svh - clamp(48px, 8svh, 96px));
}

.xmx-hero-copy {
  max-width: 1100px;
}

.xmx-hero-title,
.xmx-statement-title,
.xmx-contact-title,
.xmx-product-copy h3 {
  font-family:
    "Iowan Old Style",
    "Palatino Linotype",
    "Book Antiqua",
    Georgia,
    serif;
  font-weight: 500;
}

.xmx-hero-title {
  margin: 0;
  max-width: 10ch;
  color: #f0f0f0;
  font-size: clamp(2.95rem, calc(var(--xmx-stage) * 0.105), 8rem);
  line-height: 0.86;
  letter-spacing: -0.085em;
  text-wrap: balance;
}

.xmx-hero-title span {
  display: block;
}

.xmx-hero-subcopy {
  max-width: 30ch;
  margin: 24px 0 0;
  color: var(--fog);
  font-size: var(--xmx-copy-size);
  line-height: 1.75;
}

.xmx-panel-frame-statement {
  justify-content: flex-start;
}

.xmx-statement-copy {
  display: grid;
  gap: 22px;
}

.xmx-statement-title {
  margin: 0;
  max-width: 7ch;
  color: var(--ink);
  font-size: clamp(3.4rem, calc(var(--xmx-stage) * 0.128), 10.6rem);
  line-height: 0.82;
  letter-spacing: -0.1em;
  text-wrap: balance;
}

.xmx-statement-subcopy {
  max-width: 31ch;
  margin: 0;
  color: rgba(18, 18, 18, 0.64);
  font-size: var(--xmx-copy-size);
  line-height: 1.8;
}

.xmx-panel-frame-products {
  width: min(calc(100% - 28px), 1520px);
  display: grid;
  gap: clamp(22px, 4vh, 48px);
  min-height: calc(100svh - clamp(48px, 8svh, 96px));
  align-content: center;
  padding-block: clamp(10px, 3vh, 28px);
}

.xmx-microcopy,
.xmx-pod-label,
.xmx-product-cta {
  margin: 0;
  color: #818181;
  font-size: var(--xmx-meta-size);
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.xmx-products-copy {
  display: flex;
  justify-content: center;
  padding-inline: 0;
}

.xmx-panel-products {
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 255, 255, 0.03), transparent 16%),
    radial-gradient(circle at 50% 110%, rgba(255, 255, 255, 0.045), transparent 28%),
    linear-gradient(180deg, #010101 0%, #040404 100%);
}

.xmx-product-rail-shell {
  position: relative;
  overflow: hidden;
}

.xmx-product-rail-shell-single::before,
.xmx-product-rail-shell-single::after {
  display: none;
}

.xmx-product-rail-shell::before,
.xmx-product-rail-shell::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: clamp(32px, 6vw, 92px);
  pointer-events: none;
  z-index: 3;
}

.xmx-product-rail-shell::before {
  left: 0;
  background: linear-gradient(90deg, rgba(1, 1, 1, 0.94), rgba(1, 1, 1, 0));
}

.xmx-product-rail-shell::after {
  right: 0;
  background: linear-gradient(270deg, rgba(1, 1, 1, 0.94), rgba(1, 1, 1, 0));
}

.xmx-product-rail {
  display: flex;
  gap: clamp(22px, 4vw, 48px);
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scroll-snap-type: x mandatory;
  scroll-padding-inline: clamp(28px, 8vw, 110px);
  padding: 6px clamp(28px, 8vw, 110px) 26px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.xmx-product-rail::-webkit-scrollbar {
  display: none;
}

.xmx-product-rail-single {
  justify-content: center;
  overflow: visible;
  scroll-snap-type: none;
  scroll-padding-inline: 0;
  padding: 6px 0 22px;
}

.xmx-product-pod {
  position: relative;
  flex: 0 0 clamp(620px, 74vw, 760px);
  min-height: clamp(390px, 60svh, 560px);
  scroll-snap-align: center;
  color: inherit;
  text-decoration: none;
  transform-style: preserve-3d;
}

.xmx-product-rail-single .xmx-product-pod {
  flex-basis: min(100%, 620px);
  min-height: clamp(250px, 36svh, 320px);
}

.xmx-product-pod-ghost {
  flex-basis: clamp(250px, 38vw, 380px);
  opacity: 0.24;
  pointer-events: none;
  transform: translateY(22px) scale(0.96);
}

.xmx-product-glass {
  position: relative;
  min-height: 100%;
  border-radius: 30px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.006)),
    linear-gradient(128deg, rgba(255, 255, 255, 0.026), transparent 42%),
    rgba(7, 7, 7, 0.84);
  border: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow:
    0 44px 120px rgba(0, 0, 0, 0.8),
    inset 0 1px 0 rgba(255, 255, 255, 0.034),
    inset 0 -1px 0 rgba(255, 255, 255, 0.018);
  backdrop-filter: blur(6px);
  transform: perspective(1800px) rotateY(-4deg) rotateX(1deg);
  transition:
    transform 220ms ease,
    border-color 220ms ease,
    box-shadow 220ms ease;
}

.xmx-product-rail-single .xmx-product-glass {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.026), rgba(255, 255, 255, 0.004)),
    rgba(7, 7, 7, 0.82);
  transform: none;
}

.xmx-product-glass::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(112deg, rgba(255, 255, 255, 0.075), transparent 18%, transparent 82%, rgba(255, 255, 255, 0.028)),
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.06), transparent 28%);
  opacity: 0.34;
  pointer-events: none;
}

.xmx-product-pod-primary:hover .xmx-product-glass,
.xmx-product-pod-primary:focus-visible .xmx-product-glass {
  transform: perspective(1800px) rotateY(-2deg) rotateX(1deg) translateY(-6px);
  border-color: rgba(255, 255, 255, 0.1);
  box-shadow:
    0 56px 140px rgba(0, 0, 0, 0.84),
    inset 0 1px 0 rgba(255, 255, 255, 0.042),
    inset 0 -1px 0 rgba(255, 255, 255, 0.024);
}

.xmx-product-pod-primary:focus-visible {
  outline: none;
}

.xmx-product-rail-single .xmx-product-pod-primary:hover .xmx-product-glass,
.xmx-product-rail-single .xmx-product-pod-primary:focus-visible .xmx-product-glass {
  transform: translateY(-4px);
}

.xmx-product-display {
  position: absolute;
  inset: 11% 12% auto;
  height: 45%;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.018), rgba(255, 255, 255, 0.004)),
    rgba(4, 4, 4, 0.78);
  border: 1px solid rgba(255, 255, 255, 0.045);
  overflow: hidden;
  box-shadow:
    inset 0 18px 42px rgba(255, 255, 255, 0.012),
    inset 0 -28px 48px rgba(0, 0, 0, 0.48);
}

.xmx-display-orbit,
.xmx-display-core,
.xmx-display-sheen {
  position: absolute;
}

.xmx-display-orbit {
  inset: 16% 10%;
  border: 1px solid rgba(255, 255, 255, 0.048);
  border-radius: 999px;
  transform: rotate(-8deg);
}

.xmx-display-core {
  top: 50%;
  left: 50%;
  width: 28%;
  aspect-ratio: 1;
  border-radius: 38% 62% 58% 42% / 42% 38% 62% 58%;
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.34), rgba(255, 255, 255, 0.08) 38%, rgba(255, 255, 255, 0.015) 72%, transparent 100%);
  box-shadow:
    0 12px 42px rgba(0, 0, 0, 0.45);
  transform: translate(-50%, -50%) rotate(-10deg);
}

.xmx-display-sheen {
  right: 10%;
  bottom: 18%;
  left: 40%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.12), transparent);
  transform: rotate(-7deg);
}

.xmx-product-display-future .xmx-display-core {
  width: 24%;
  border-radius: 50%;
  transform: translate(-50%, -50%) scale(0.92);
  opacity: 0.58;
}

.xmx-product-copy {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: clamp(390px, 60svh, 560px);
  gap: 10px;
  width: min(100%, 332px);
  margin-left: auto;
  padding: clamp(22px, 3vw, 32px);
}

.xmx-product-rail-single .xmx-product-copy {
  justify-content: center;
  min-height: clamp(250px, 36svh, 320px);
  width: min(100%, 420px);
  margin-left: 0;
}

.xmx-product-copy h3 {
  margin: 0;
  color: #f3f3f3;
  font-size: clamp(1.8rem, calc(var(--xmx-stage-tight) * 0.043), 2.8rem);
  line-height: 0.92;
  letter-spacing: -0.07em;
}

.xmx-product-copy p {
  max-width: 26ch;
  margin: 0;
  color: #919191;
  font-size: 0.8rem;
  line-height: 1.72;
}

.xmx-product-cta {
  margin-top: 4px;
  color: #e7e7e7;
}

.xmx-panel-frame-contact {
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 18px;
}

.xmx-contact-title {
  margin: 0;
  color: #f0f0f0;
  font-size: clamp(3rem, calc(var(--xmx-stage) * 0.084), 6.8rem);
  line-height: 0.88;
  letter-spacing: -0.085em;
}

.xmx-contact-copy {
  max-width: 30ch;
  margin: 0;
  color: var(--fog);
  font-size: var(--xmx-copy-size);
  line-height: 1.8;
}

.xmx-contact-links {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 28px;
  margin-top: 4px;
}

.xmx-contact-links a {
  color: #f0f0f0;
  font-size: var(--xmx-link-size);
  letter-spacing: -0.03em;
  border-bottom: 1px solid rgba(255, 255, 255, 0.16);
  padding-bottom: 4px;
  transition:
    border-color 180ms ease,
    color 180ms ease;
}

.xmx-contact-links a:hover,
.xmx-contact-links a:focus-visible {
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.44);
}

.xmx-panel-contact {
  background:
    radial-gradient(circle at 18% 18%, rgba(0, 0, 0, 0.045), transparent 24%),
    linear-gradient(180deg, #f4f0e8 0%, #efebe3 100%);
}

.xmx-panel-contact .xmx-microcopy {
  color: rgba(25, 25, 25, 0.48);
}

.xmx-panel-contact .xmx-contact-title {
  color: #080808;
}

.xmx-panel-contact .xmx-contact-copy {
  color: rgba(18, 18, 18, 0.62);
}

.xmx-panel-contact .xmx-contact-links a {
  color: #080808;
  border-color: rgba(8, 8, 8, 0.18);
}

.xmx-panel-contact .xmx-contact-links a:hover,
.xmx-panel-contact .xmx-contact-links a:focus-visible {
  color: #000000;
  border-color: rgba(8, 8, 8, 0.42);
}

.xmx-panel-frame-about-hero,
.xmx-panel-frame-about-body {
  display: flex;
  align-items: center;
  min-height: calc(100svh - clamp(48px, 8svh, 96px));
}

.xmx-panel-frame-about-body {
  justify-content: flex-start;
}

.xmx-about-copy {
  max-width: 980px;
}

.xmx-about-title,
.xmx-about-body-title {
  margin: 0;
  font-family:
    "Iowan Old Style",
    "Palatino Linotype",
    "Book Antiqua",
    Georgia,
    serif;
  font-weight: 500;
  letter-spacing: -0.085em;
}

.xmx-about-title {
  max-width: 10ch;
  color: #f0f0f0;
  font-size: clamp(2.95rem, calc(var(--xmx-stage) * 0.1), 7.8rem);
  line-height: 0.86;
  text-wrap: balance;
}

.xmx-about-subcopy,
.xmx-about-body-copy {
  max-width: 33ch;
  margin: 22px 0 0;
  font-size: var(--xmx-copy-size);
  line-height: 1.8;
}

.xmx-about-subcopy {
  color: var(--fog);
}

.xmx-about-body-stack {
  display: grid;
  gap: 18px;
}

.xmx-about-body-title {
  max-width: 9ch;
  color: var(--ink);
  font-size: clamp(2.9rem, calc(var(--xmx-stage-tight) * 0.078), 6.6rem);
  line-height: 0.88;
  text-wrap: balance;
}

.xmx-about-body-copy {
  margin: 0;
  color: rgba(18, 18, 18, 0.7);
}

.xmx-about-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 24px;
  margin-top: 4px;
}

.xmx-about-links a {
  color: #080808;
  font-size: var(--xmx-link-size);
  letter-spacing: -0.03em;
  text-decoration: none;
  border-bottom: 1px solid rgba(8, 8, 8, 0.18);
  padding-bottom: 4px;
  transition:
    color 180ms ease,
    border-color 180ms ease;
}

.xmx-about-links a:hover,
.xmx-about-links a:focus-visible {
  color: #000000;
  border-color: rgba(8, 8, 8, 0.4);
}

@media (max-width: 1100px) {
  .xmx-panel-frame {
    width: min(calc(100% - (var(--xmx-frame-edge) * 2)), 1440px);
  }

  .xmx-hero-title {
    max-width: 10.5ch;
    font-size: clamp(2.95rem, calc(var(--xmx-stage) * 0.104), 7.2rem);
  }

  .xmx-statement-title {
    max-width: 8ch;
    font-size: clamp(3.6rem, calc(var(--xmx-stage) * 0.128), 9rem);
  }

  .xmx-product-pod {
    flex-basis: min(84vw, 700px);
    min-height: clamp(380px, 58svh, 520px);
  }

  .xmx-product-pod-ghost {
    flex-basis: min(56vw, 360px);
  }

  .xmx-product-copy {
    min-height: clamp(380px, 58svh, 520px);
    width: min(100%, 330px);
  }
}

@media (max-width: 760px) {
  body.xmx-home {
    scroll-snap-type: y mandatory;
    --xmx-stage: min(100vw, 100svh);
    --xmx-stage-tight: min(100vw, 88svh);
    --xmx-frame-edge: clamp(14px, 4vw, 28px);
    --xmx-copy-size: clamp(0.76rem, 2.15vw, 0.82rem);
    --xmx-meta-size: clamp(0.66rem, 1.9vw, 0.7rem);
    --xmx-link-size: clamp(0.84rem, 2.3vw, 0.9rem);
  }

  .xmx-panel {
    padding: 18px 0;
  }

  .xmx-panel-frame {
    width: min(calc(100% - (var(--xmx-frame-edge) * 2)), 1440px);
  }

  .xmx-panel-frame-hero,
  .xmx-panel-frame-statement,
  .xmx-panel-frame-contact {
    min-height: calc(100svh - 36px);
  }

  .xmx-hero-title {
    max-width: 11ch;
    font-size: clamp(2.5rem, calc(var(--xmx-stage) * 0.106), 5rem);
  }

  .xmx-hero-subcopy {
    max-width: 26ch;
  }

  .xmx-statement-title {
    max-width: 7.5ch;
    font-size: clamp(3.2rem, calc(var(--xmx-stage) * 0.138), 6.6rem);
  }

  .xmx-statement-subcopy {
    max-width: 27ch;
  }

  .xmx-panel-frame-products {
    gap: 18px;
  }

  .xmx-products-copy {
    justify-content: flex-start;
  }

  .xmx-product-rail {
    gap: 14px;
    padding: 8px 12px 20px;
    scroll-padding-inline: 12px;
  }

  .xmx-product-rail-single {
    padding: 8px 0 18px;
  }

  .xmx-product-pod {
    flex-basis: calc(100vw - 40px);
    min-height: 62svh;
  }

  .xmx-product-rail-single .xmx-product-pod {
    flex-basis: min(100%, 100vw - 40px);
    min-height: 240px;
  }

  .xmx-product-pod-ghost {
    flex-basis: calc(68vw - 8px);
  }

  .xmx-product-glass {
    border-radius: 28px;
    transform: perspective(1400px) rotateY(-4deg) rotateX(1deg);
  }

  .xmx-product-pod-primary:hover .xmx-product-glass,
  .xmx-product-pod-primary:focus-visible .xmx-product-glass {
    transform: perspective(1400px) rotateY(-2deg) rotateX(1deg) translateY(-4px);
  }

  .xmx-product-display {
    inset: 8% 8% auto;
    height: 46%;
    border-radius: 24px;
  }

  .xmx-product-copy {
    min-height: 62svh;
    width: 100%;
    padding: 18px;
  }

  .xmx-product-rail-single .xmx-product-copy {
    min-height: 240px;
    width: 100%;
    padding: 22px 18px;
  }

  .xmx-product-copy h3 {
    font-size: clamp(1.6rem, calc(var(--xmx-stage-tight) * 0.052), 2.15rem);
  }

  .xmx-product-copy p {
    max-width: 24ch;
    font-size: 0.76rem;
  }

  .xmx-panel-frame-contact {
    gap: 14px;
  }

  .xmx-contact-title {
    font-size: clamp(2.7rem, calc(var(--xmx-stage) * 0.093), 4.4rem);
  }

  .xmx-contact-copy {
    max-width: 25ch;
  }

  .xmx-contact-links {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .xmx-about-title {
    max-width: 10.5ch;
    font-size: clamp(2.55rem, calc(var(--xmx-stage) * 0.108), 5.1rem);
  }

  .xmx-about-subcopy,
  .xmx-about-body-copy {
    max-width: 28ch;
  }

  .xmx-about-body-title {
    max-width: 10ch;
    font-size: clamp(2.7rem, calc(var(--xmx-stage-tight) * 0.09), 4.7rem);
  }

  .xmx-about-links {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}

@media (max-width: 479px) {
  body.xmx-home {
    --xmx-stage: min(100vw, 92svh);
    --xmx-stage-tight: min(100vw, 82svh);
    --xmx-frame-edge: 10px;
    --xmx-copy-size: clamp(0.74rem, 3.25vw, 0.8rem);
    --xmx-meta-size: 0.66rem;
    --xmx-link-size: 0.84rem;
  }

  .xmx-panel-frame {
    width: min(calc(100% - (var(--xmx-frame-edge) * 2)), 1440px);
  }

  .xmx-hero-title {
    max-width: 10.5ch;
    font-size: clamp(2.2rem, calc(var(--xmx-stage) * 0.108), 3.9rem);
  }

  .xmx-statement-title {
    font-size: clamp(2.8rem, calc(var(--xmx-stage) * 0.146), 5.4rem);
  }

  .xmx-product-pod {
    flex-basis: calc(100vw - 28px);
  }

  .xmx-product-pod-ghost {
    flex-basis: 66vw;
  }

  .xmx-product-display {
    height: 48%;
  }

  .xmx-product-copy {
    padding: 16px;
  }

  .xmx-pod-label,
  .xmx-microcopy,
  .xmx-product-cta {
    font-size: 0.66rem;
  }

  .xmx-contact-links a {
  }

  .xmx-about-title {
    font-size: clamp(2.2rem, calc(var(--xmx-stage) * 0.106), 3.9rem);
  }

  .xmx-about-body-title {
    font-size: clamp(2.3rem, calc(var(--xmx-stage-tight) * 0.092), 4rem);
  }

  .xmx-about-links a {
  }
}
