@font-face {
  font-family: "Athletics";
  src:
    local("Athletics"), local("Athletics Regular"), local("Athletics-Regular"),
    local("Athletics Light"), local("Athletics-Light");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "PPEditorialNew";
  src:
    local("PPEditorialNew"), local("PP Editorial New"),
    local("PP Editorial New Regular"), local("PPEditorialNew-Regular"),
    local("PPEditorialNew-Italic");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

.uLCRoEOb1_ylDG1iwfE8 {
  --wheel-size: 970px;
  /* Fraction of the circle's height that is revealed (unitless for calc). */
  --wheel-visible: 0.55;
  --ring-width: 170px;
  --network-scale: 115%;
  --network-offset-x: 0px;
  --network-offset-y: -360px;

  /* Type */
  --font-sans: "Athletics", sans-serif;
  --font-serif: "PPEditorialNew", Georgia, serif;

  /* Color */
  --color-fg: #000000;
  --color-muted: #7c7c7c;
  --color-bg: #ffffff;
  --color-body: #282828;
  --color-disc: #111111;

  /* Spacing: the flex gap between the pinned blocks, and the intended total
     gap from one block to the next. `margin-top` makes up the difference. */
  --block-gap: 32px;
  --stack-gap: 100px;

  position: relative;
  width: 100%;
  /* Height is set by JS in pixels (pinHeight + steps * STEP_PX) — no vh, so it
     never reserves a viewport-sized empty slot above the wheel. */
  background: var(--color-bg);
}

._3YAvsEQHtDUI9YDgokl {
  height: auto;
}

/*
 * Compositor-driven pin (no per-scroll JS positioning, so iOS never repaints a
 * frame late -> no flicker). Sticking the block's TOP at `100dvh - pinHeight`
 * places its BOTTOM at the viewport bottom (wheel bottom-anchored) while the
 * scroll runway stays BELOW the block -> no reserved empty box, no whitespace.
 * On short screens the calc goes negative and the header simply clips above the
 * viewport. `--pin-h` is measured once by JS (ResizeObserver), not on scroll.
 */
.fDjwqaTDF7PVpZjbBoU0 {
  position: sticky;
  top: calc(100dvh - var(--pin-h, 100dvh));
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--block-gap);
  font-family: var(--font-sans);
}

._3YAvsEQHtDUI9YDgokl .fDjwqaTDF7PVpZjbBoU0 {
  position: relative;
  top: auto;
  height: auto;
  padding: 80px 0;
}

.kL3cD66WpcfQIDG_D7BW {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  box-sizing: border-box;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 100px 60px 0;
  text-align: left;
}

.fopEFw4CgMreRZLZwKyv {
  margin: 0 0 12px;
  font-family: var(--font-sans);
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.SQRlYk7dCC7MHKN3vYaP {
  max-width: 896px;
  margin: 0 0 50px;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 48px;
  line-height: 60px;
  color: var(--color-fg);
}

.sPruqCGFtiUGf9sOMzVw {
  max-width: 1152px;
  margin: 0 0 12px;
  font-family: var(--font-sans);
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  color: var(--color-body);
}

.sPruqCGFtiUGf9sOMzVw:last-child {
  margin-bottom: 0;
}

.zjHqcRNMosuOEBTb2hBQ {
  display: grid;
  width: 100%;
  max-width: 540px;
  /* Pin gap + this margin = --stack-gap total from the header to the text. */
  margin-top: calc(var(--stack-gap) - var(--block-gap));
  text-align: center;
}

.ud1trTHX6k7SAZR8q5qA {
  grid-area: 1 / 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 540px;
  max-width: 100%;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.ud1trTHX6k7SAZR8q5qA.u3d87Sb5VmWbsFEBeWPL {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.dlY_p_l0hFYqUnUgTU1b {
  margin: 0 0 6px;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(24px, 4vw, 36px);
  line-height: 1.2;
  color: var(--color-muted);
}

.LbqGUX7bXL2PxJK0ri6Q {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(22px, 3.5vw, 30px);
  line-height: 1.3;
  color: var(--color-fg);
  text-align: center;
}

.LPVjnBzMEiPgkGcmLHfD {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 540px;
  max-width: 100%;
  margin: 0 0 16px;
}

.JVqnCowwIyUnuP5j2M1d {
  margin: 0;
  width: 100%;
  font-family: var(--font-sans);
  font-size: clamp(14px, 2vw, 17px);
  line-height: 1.6;
  color: var(--color-muted);
  text-align: center;
}

.MpR5hX7zla1ueYreEPpc {
  position: relative;
  width: var(--wheel-size);
  height: calc(var(--wheel-size) * var(--wheel-visible));
  /* Pin gap + this margin = --stack-gap total from the text to the wheel.
     The needle (94px tall) sits inside this space. */
  margin-top: calc(var(--stack-gap) - var(--block-gap));
  flex-shrink: 0;
}

.QY8OO7HTRqulDjRa0u2w {
  position: absolute;
  top: 0;
  left: 50%;
  width: var(--wheel-size);
  height: var(--wheel-size);
  margin-left: calc(var(--wheel-size) / -2);
  border-radius: 50%;
  background-color: var(--color-disc);
  overflow: hidden;
  transform: rotate(var(--rotation, 0deg));
  transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  z-index: 1;
}

.QY8OO7HTRqulDjRa0u2w::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--network-image);
  background-size: var(--network-scale);
  background-position: var(--network-offset-x) var(--network-offset-y);
  background-repeat: no-repeat;
  opacity: 0.2;
}

.QY8OO7HTRqulDjRa0u2w::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: calc(var(--wheel-size) - (var(--ring-width) * 2));
  height: calc(var(--wheel-size) - (var(--ring-width) * 2));
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: var(--color-bg);
}

.YwO5ZFQdQuJr09bSEYHy {
  position: absolute;
  top: -94px;
  left: 50%;
  width: 3px;
  height: 94px;
  margin-left: -1.5px;
  background: var(--color-fg);
  /* Tapered: 3px wide at bottom, 1px wide at top (33%–67% of width). */
  clip-path: polygon(0% 100%, 100% 100%, 66.66% 0%, 33.33% 0%);
  z-index: 2;
  pointer-events: none;
}

._gk8i6JOS1_li4KNHVxg {
  position: absolute;
  top: 0;
  left: 0;
  width: var(--wheel-size);
  height: calc(var(--wheel-size) * var(--wheel-visible));
  overflow: hidden;
}

.SdTLt1sN9LcJxVwKZE20 {
  position: absolute;
  left: 50%;
  top: 74%;
  transform: translate(-50%, -50%);
  width: clamp(110px, 20vw, 167px);
  height: auto;
  z-index: 4;
  display: block;
  pointer-events: none;
}

._uT6VtFYQixG4_l185_J {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  color: var(--color-fg);
  padding: 0;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.Q_3YJ0QTsaOSD86nf6AY {
  left: -40px;
}

.llf00ottF9j1XQhPeHsA {
  right: -40px;
}

._uT6VtFYQixG4_l185_J:disabled {
  opacity: 0.25;
  cursor: not-allowed;
}

.ygpeA75xZ5pqO5D_C1mt {
  width: 13px;
  height: 18px;
  display: block;
}

.eB6_0CVjxknWmrBwg1jW {
  transform: rotate(180deg);
}

@media (max-width: 600px) {
  .uLCRoEOb1_ylDG1iwfE8 {
    --wheel-size: 365px;
    --ring-width: 65px;
    --network-scale: 115%;
    --network-offset-y: -136px;
  }

  .MpR5hX7zla1ueYreEPpc {
    margin-top: 50px;
  }

  .SQRlYk7dCC7MHKN3vYaP {
    font-size: 24px;
    line-height: 1.5;
  }

  .sPruqCGFtiUGf9sOMzVw {
    font-size: 12px;
  }

  .LPVjnBzMEiPgkGcmLHfD {
    width: 210px;
    margin: 0 auto 16px;
  }

  .ud1trTHX6k7SAZR8q5qA {
    width: 210px;
    margin: 0 auto;
  }

  .SdTLt1sN9LcJxVwKZE20 {
    width: 62px;
    height: auto;
  }

  .YwO5ZFQdQuJr09bSEYHy {
    width: 2px;
    height: 50px;
    top: -50px;
    margin-left: -1px;
  }
}

