:root {
  --white: #f7f8f6;
  --paper: #ffffff;
  --ink: #101314;
  --graphite: #0b1010;
  --muted: #68706f;
  --line: #dce2df;
  --line-strong: #c7cfcc;
  --navy: #061f3d;
  --orange: #ff4b1f;
  --surface: #f1f4f2;
  --max: 1332px;
  color-scheme: light;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 260px;
}

body {
  margin: 0;
  background:
    linear-gradient(90deg, rgb(16 19 20 / 2%) 1px, transparent 1px) 0 0 / 72px 72px,
    linear-gradient(180deg, #fbfcfb 0, var(--white) 420px),
    var(--white);
  color: var(--ink);
}

button,
a {
  font: inherit;
}

.store-header {
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--white) 94%, transparent);
  backdrop-filter: blur(18px);
  transition:
    box-shadow 220ms ease,
    background 220ms ease;
}

.store-header.is-condensed {
  background: color-mix(in srgb, var(--white) 98%, transparent);
  box-shadow: 0 16px 42px rgb(11 16 16 / 5%);
}

.utility-strip {
  min-height: 38px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 24px;
  padding: 0 54px;
  background: var(--graphite);
  color: var(--paper);
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
}

.utility-strip a {
  color: inherit;
  text-decoration: none;
}

.utility-strip a:hover,
.utility-strip a:focus-visible {
  color: var(--orange);
  outline: 0;
}

.store-masthead {
  min-height: 124px;
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 36px;
  align-items: center;
  padding: 0 54px;
  transition: min-height 220ms ease;
}

.store-header.is-condensed .store-masthead {
  min-height: 92px;
}

.store-brand {
  display: inline-flex;
  width: max-content;
  align-items: center;
  gap: 14px;
  color: var(--ink);
  text-decoration: none;
  font-size: 30px;
  font-weight: 950;
  line-height: 0.78;
  text-transform: uppercase;
}

.store-brand img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  transition: width 220ms ease, height 220ms ease;
}

.store-header.is-condensed .store-brand img {
  width: 42px;
  height: 42px;
}

.store-search {
  min-height: 56px;
  display: flex;
  align-items: center;
  padding: 0 28px;
  border-radius: 999px;
  background: var(--surface);
  color: var(--muted);
  font-size: 13px;
}

.store-actions {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 18px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
}

.store-actions a {
  color: inherit;
  text-decoration: none;
}

.store-actions a:hover,
.store-actions a:focus-visible {
  color: var(--ink);
  outline: 0;
}

.collection-tabs {
  display: flex;
  align-items: center;
  gap: 34px;
  min-height: 58px;
  padding: 0 54px;
  border-top: 1px solid var(--line);
}

.collection-tabs a,
.collection-tabs span {
  color: var(--ink);
  text-decoration: none;
  font-size: 14px;
  font-weight: 780;
}

.collection-tabs .is-active {
  color: var(--orange);
}

.collection-tabs span {
  color: var(--muted);
}

.site-shell {
  width: min(var(--max), calc(100vw - 108px));
  margin: 0 auto;
  padding: 48px 0 92px;
}

.gallery-shell {
  display: grid;
  gap: 54px;
}

.gallery-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(360px, 0.72fr);
  gap: 56px;
  align-items: end;
  min-height: 500px;
  padding-bottom: 34px;
  border-bottom: 1px solid var(--line);
}

.gallery-copy {
  max-width: 820px;
  min-width: 0;
}

.gallery-copy p:not(.eyebrow) {
  max-width: 700px;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.58;
}

.featured-design {
  align-self: stretch;
  display: flex;
  align-items: end;
  min-width: 0;
  transform: translateY(calc(var(--hero-shift, 0) * 22px));
  transition: transform 90ms linear;
}

.gallery-feature-card {
  width: 100%;
  min-height: 410px;
  box-shadow: 0 34px 90px rgb(11 16 16 / 12%);
}

.gallery-feature-card .pixel-preview {
  aspect-ratio: 1.04;
}

.gallery-feature-card .artifact-title {
  font-size: 20px;
}

.gallery-feature-card .artifact-status {
  align-self: end;
}

.gallery-release {
  display: grid;
  gap: 22px;
}

.gallery-section-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: end;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}

.gallery-section-head h2 {
  max-width: 780px;
  margin: 0;
  font-size: 30px;
  line-height: 1.05;
  text-transform: uppercase;
}

.design-gallery {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.gallery-card {
  min-height: 268px;
}

.intro-room {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 334px;
  gap: 112px;
  align-items: start;
  min-height: 428px;
  padding-bottom: 46px;
  border-bottom: 1px solid var(--line);
}

.intro-room::before {
  content: "";
  position: absolute;
  left: -54px;
  right: -54px;
  bottom: 0;
  height: 42%;
  pointer-events: none;
  background:
    linear-gradient(180deg, transparent, rgb(255 255 255 / 54%)),
    radial-gradient(circle at 80% 18%, rgb(255 75 31 / 6%), transparent 34%),
    radial-gradient(circle at 19% 62%, rgb(6 31 61 / 5%), transparent 36%);
  opacity: calc(1 - (var(--hero-shift, 0) * 0.58));
}

.intro-copy,
.intro-artifact {
  position: relative;
  z-index: 1;
}

.eyebrow {
  margin: 0 0 16px;
  color: var(--orange);
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
}

h1,
h2,
h3,
p,
dl {
  margin-top: 0;
}

h1 {
  max-width: 820px;
  margin-bottom: 22px;
  font-size: clamp(48px, 5.2vw, 76px);
  line-height: 0.95;
  letter-spacing: 0;
}

.tournament-title {
  max-width: 900px;
  margin-bottom: 28px;
  font-size: clamp(72px, 8.4vw, 126px);
  font-weight: 950;
  line-height: 0.84;
  text-transform: uppercase;
  transform: translateY(calc(var(--hero-shift, 0) * -18px));
  transition: transform 90ms linear;
}

.tournament-title span {
  display: block;
}

.tournament-title span:first-child {
  color: var(--orange);
  font-size: 0.72em;
}

.intro-copy p:not(.eyebrow) {
  max-width: 760px;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.58;
}

.exhibit-meta {
  max-width: 430px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  margin-top: 28px;
  border: 1px solid var(--line);
  background: var(--line);
}

.exhibit-meta span {
  min-height: 54px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding: 0 16px;
  background: rgb(255 255 255 / 70%);
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
}

.exhibit-meta strong {
  color: var(--ink);
  font: inherit;
}

.intro-artifact {
  padding-top: 40px;
  transform: translateY(calc(var(--hero-shift, 0) * 22px));
  transition: transform 90ms linear;
}

.layout {
  display: grid;
  grid-template-columns: 326px minmax(0, 1fr);
  gap: 46px;
  margin-top: 44px;
}

.room-rail {
  position: sticky;
  top: 224px;
  align-self: start;
  min-height: 560px;
  padding: 28px;
  background: var(--graphite);
  color: var(--paper);
}

.room-rail a {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 14px 0;
  border-top: 1px solid rgb(255 255 255 / 13%);
  color: var(--paper);
  text-decoration: none;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.room-rail a.is-active,
.room-rail a:hover {
  color: var(--orange);
}

.rail-note {
  margin: 42px 0 0;
  color: rgb(255 255 255 / 60%);
  font-size: 13px;
  line-height: 1.45;
}

.rooms {
  display: grid;
  gap: 92px;
}

.room-header {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  align-items: center;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}

.room-header h2 {
  margin: 0;
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.room-header::after {
  content: "";
  height: 1px;
  background: linear-gradient(90deg, var(--ink), transparent);
  opacity: 0.32;
}

.artifact-grid {
  display: grid;
  gap: 22px;
  margin-top: 30px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.artifact-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 232px;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 15px;
  background: var(--artifact-panel-bg, var(--paper));
  color: var(--artifact-panel-text, var(--ink));
  text-align: left;
  cursor: pointer;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease,
    filter 160ms ease;
}

.artifact-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgb(255 255 255 / 12%), transparent 28%),
    linear-gradient(135deg, transparent 0 54%, rgb(255 255 255 / 10%) 54% 58%, transparent 58%);
  opacity: 0.8;
}

.variant-federation .layout {
  display: block;
}

.variant-federation .room-rail {
  display: none;
}

.variant-federation .artifact-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 21px;
}

.variant-federation .artifact-card {
  border-color: rgb(255 255 255 / 18%);
}

.artifact-card:hover,
.artifact-card:focus-visible {
  border-color: var(--ink);
  box-shadow: 0 24px 54px rgb(11 16 16 / 10%);
  outline: 0;
  transform: translateY(-3px);
  filter: saturate(1.04);
}

.pixel-preview {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1.62;
  overflow: hidden;
  background: var(--artifact-preview-bg, var(--surface));
  box-shadow: inset 0 0 0 1px rgb(255 255 255 / 52%);
}

.pixel-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.98) contrast(1.02);
  transform: scale(1.012);
  transition: transform 360ms cubic-bezier(0.2, 0.7, 0.2, 1);
}

.artifact-card:hover .pixel-preview img,
.artifact-card:focus-visible .pixel-preview img {
  transform: scale(1.045);
}

.pixel-preview::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgb(255 255 255 / 76%);
  background:
    linear-gradient(90deg, rgb(255 255 255 / 18%), transparent 40%, rgb(255 255 255 / 10%)),
    linear-gradient(135deg, transparent 0 52%, rgb(255 255 255 / 14%) 52% 61%, transparent 61%);
}

.artifact-meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 14px;
  margin-top: auto;
  padding-top: 16px;
}

.artifact-kicker {
  grid-column: 1 / -1;
  color: var(--artifact-panel-muted, var(--muted));
  font-size: 10px;
  font-weight: 850;
  text-transform: uppercase;
}

.artifact-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 850;
}

.artifact-status {
  color: var(--artifact-panel-muted, var(--muted));
  font-size: 10px;
  font-weight: 850;
  text-transform: uppercase;
}

.intro-artifact .artifact-card {
  min-height: 280px;
  box-shadow: 0 26px 80px rgb(11 16 16 / 9%);
}

.drawer {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: none;
}

.drawer.is-open {
  display: block;
}

.drawer-backdrop {
  position: absolute;
  inset: 0;
  background: rgb(11 16 16 / 38%);
}

.drawer-panel {
  position: absolute;
  top: 104px;
  right: 54px;
  width: min(820px, calc(100vw - 108px));
  max-height: calc(100vh - 138px);
  display: grid;
  grid-template-columns: minmax(280px, 0.92fr) 1fr;
  gap: 36px;
  overflow: auto;
  padding: 34px;
  border: 1px solid var(--graphite);
  border-radius: 8px;
  background: var(--paper);
  box-shadow: 0 24px 80px rgb(0 0 0 / 22%);
}

.drawer-close {
  position: absolute;
  top: 14px;
  right: 16px;
  border: 0;
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  font-size: 28px;
  line-height: 1;
}

.product-media-wrap {
  min-height: 460px;
  display: grid;
  place-items: center;
  padding: 18px;
  background: var(--graphite);
}

.product-media {
  max-width: 100%;
  max-height: 430px;
  object-fit: contain;
}

.drawer-copy {
  align-self: center;
  display: flex;
  flex-direction: column;
  min-height: 420px;
  padding: 22px 22px 22px 0;
}

.drawer-copy h2 {
  max-width: 9.5em;
  margin: 10px 0 14px;
  font-size: clamp(38px, 5vw, 64px);
  line-height: 0.93;
  letter-spacing: 0;
}

.drawer-copy p,
.product-copy p {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
}

.drawer-meta {
  margin-bottom: 44px;
  color: var(--orange) !important;
  font-size: 11px !important;
  font-weight: 850;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.drawer-note {
  max-width: 31rem;
  margin: auto 0 0;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 16px !important;
  line-height: 1.55 !important;
}

.drawer-sources {
  max-width: 31rem;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.drawer-sources-label {
  margin: 0 0 10px;
  color: var(--orange) !important;
  font-size: 10px !important;
  font-weight: 850;
  text-transform: uppercase;
}

.drawer-sources ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
}

.drawer-sources li {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.drawer-sources a {
  color: var(--ink);
  font-weight: 780;
  text-decoration-color: var(--line-strong);
  text-underline-offset: 3px;
}

.drawer-sources a:hover,
.drawer-sources a:focus-visible {
  color: var(--orange);
  outline: 0;
}

.drawer-facts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  margin: 20px 0 22px;
  background: var(--line);
  border: 1px solid var(--line);
}

.drawer-facts div {
  min-height: 68px;
  padding: 12px;
  background: var(--white);
}

.drawer-facts dt {
  margin-bottom: 8px;
  color: var(--muted);
  font-size: 9px;
  font-weight: 850;
  text-transform: uppercase;
}

.drawer-facts dd {
  margin: 0;
  color: var(--ink);
  font-size: 12px;
  font-weight: 800;
}

.gift-shop-link,
.product-nav button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  border: 0;
  border-radius: 4px;
  background: var(--graphite);
  color: var(--paper);
  cursor: pointer;
  text-decoration: none;
  font-size: 14px;
  font-weight: 850;
}

.gift-shop-link {
  width: min(100%, 360px);
  margin-top: 30px;
}

.footer {
  width: min(var(--max), calc(100vw - 108px));
  min-height: 88px;
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  margin: 0 auto;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 11px;
}

.footer a {
  color: var(--ink);
  text-decoration: none;
  font-weight: 850;
}

.scroll-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 620ms cubic-bezier(0.2, 0.7, 0.2, 1),
    transform 620ms cubic-bezier(0.2, 0.7, 0.2, 1),
    filter 620ms cubic-bezier(0.2, 0.7, 0.2, 1);
  transition-delay: var(--reveal-delay, 0ms);
  filter: blur(5px);
}

.scroll-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.scroll-reveal.artifact-card.is-visible:hover,
.scroll-reveal.artifact-card.is-visible:focus-visible {
  transform: translateY(-3px);
}

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

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

  .scroll-reveal {
    opacity: 1;
    transform: none;
    filter: none;
  }
}

.product-shell {
  position: relative;
  width: min(var(--max), calc(100vw - 108px));
  margin: 0 auto;
  padding: 28px 0 96px;
}

.gallery-return {
  position: absolute;
  top: 27px;
  left: 0;
  z-index: 2;
  display: inline-grid;
  grid-template-columns: 68px 20px auto;
  gap: 10px;
  align-items: center;
  color: var(--muted);
  text-decoration: none;
  text-transform: uppercase;
  transform: translateY(-50%);
}

.gallery-return-rule {
  width: 68px;
  height: 1px;
  background: var(--line-strong);
  transition:
    width 180ms ease,
    background 180ms ease;
}

.gallery-return-arrow {
  color: var(--ink);
  font-size: 18px;
  line-height: 1;
  transform: translateY(-1px);
}

.gallery-return-label {
  font-size: 10px;
  font-weight: 850;
  letter-spacing: 0.08em;
}

.gallery-return:hover,
.gallery-return:focus-visible {
  color: var(--ink);
  outline: 0;
}

.gallery-return:hover .gallery-return-rule,
.gallery-return:focus-visible .gallery-return-rule {
  width: 92px;
  background: var(--orange);
}

.product-stage {
  display: grid;
  grid-template-columns: minmax(520px, 1.15fr) minmax(320px, 0.85fr);
  gap: 34px;
  align-items: start;
  min-height: 650px;
}

.product-visual {
  position: relative;
  grid-column: 1;
  margin-top: 18px;
  min-height: 650px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid var(--line);
  background: #fff;
  cursor: grab;
  touch-action: pan-y;
  user-select: none;
}

.product-visual.is-carousel-dragging {
  cursor: grabbing;
}

.product-visual.is-coming-soon {
  cursor: default;
}

.product-visual:focus-visible {
  border-color: var(--ink);
  box-shadow: 0 0 0 3px rgb(255 75 31 / 18%);
  outline: 0;
}

.product-copy {
  grid-column: 2;
}

.product-visual.is-gliding .product-design-card,
.product-visual.is-gliding .placeholder-label {
  animation: glide-in 340ms cubic-bezier(0.2, 0.7, 0.2, 1);
}

.product-visual > img {
  width: min(72%, 520px);
  height: auto;
  opacity: 0.96;
  filter: drop-shadow(0 24px 42px rgb(0 0 0 / 8%));
}

.product-visual > img.product-mockup {
  width: min(86%, 660px);
  max-height: 590px;
  object-fit: contain;
  opacity: 0;
  filter:
    drop-shadow(0 2px 0 rgb(16 19 20 / 4%))
    drop-shadow(0 28px 48px rgb(0 0 0 / 16%));
}

.mockup-carousel {
  position: absolute;
  inset: 40px 32px 126px;
  display: grid;
  place-items: center;
  perspective: 1200px;
  pointer-events: none;
}

.mockup-carousel[hidden] {
  display: none;
}

.mockup-carousel img {
  position: absolute;
  width: min(86%, 660px);
  max-height: 100%;
  object-fit: contain;
  opacity: var(--opacity, 0);
  filter:
    drop-shadow(0 2px 0 rgb(16 19 20 / 4%))
    drop-shadow(0 28px 48px rgb(0 0 0 / 14%));
  transform:
    translateX(var(--x, 0))
    translateY(var(--y, 0))
    rotateZ(var(--r, 0deg))
    scale(var(--s, 1));
  transition:
    opacity 180ms ease,
    filter 180ms ease;
  will-change: transform, opacity;
}

.product-visual.is-carousel-snapping .mockup-carousel img {
  transition:
    transform 260ms cubic-bezier(0.2, 0.78, 0.18, 1),
    opacity 220ms ease,
    filter 220ms ease;
}

.mockup-carousel img.is-active {
  opacity: 1;
}

.product-design-card {
  position: absolute;
  top: 138px;
  width: min(46%, 310px);
  aspect-ratio: 1.38;
  display: grid;
  place-items: center;
  padding: 12px;
  border: 1px solid var(--ink);
  background: var(--paper);
  box-shadow: 0 18px 60px rgb(0 0 0 / 14%);
}

.product-design-card img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.placeholder-label {
  position: absolute;
  left: 32px;
  right: 32px;
  bottom: 28px;
  display: grid;
  gap: 8px;
  padding: 18px;
  border: 1px solid var(--line);
  background: rgb(255 255 255 / 86%);
  backdrop-filter: blur(14px);
  text-align: center;
  text-transform: uppercase;
}

.placeholder-label span:first-child {
  color: var(--ink);
  font-size: 18px;
  font-weight: 900;
}

.placeholder-label span:last-child {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.product-copy h1 {
  font-size: clamp(42px, 4.2vw, 68px);
  text-transform: uppercase;
}

.product-price {
  margin: -10px 0 14px;
  color: var(--ink) !important;
  font-size: 18px !important;
  font-weight: 900;
}

.mockup-rotator {
  position: absolute;
  left: 32px;
  right: 32px;
  bottom: 28px;
  display: grid;
  grid-template-columns: max-content minmax(120px, 1fr);
  gap: 8px 14px;
  align-items: center;
  padding: 14px 16px;
  border: 1px solid var(--line);
  background: rgb(255 255 255 / 88%);
  backdrop-filter: blur(14px);
}

.mockup-rotator label,
.mockup-rotator > span,
.mockup-rotator output {
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
  text-transform: uppercase;
}

.mockup-rotator output {
  grid-column: 1 / -1;
  color: var(--ink);
}

.mockup-rotator input {
  width: 100%;
  accent-color: var(--orange);
}

.mockup-rotator input:focus-visible {
  outline: 0;
  filter: drop-shadow(0 0 0.25rem rgb(255 75 31 / 42%));
}

.purchase-panel {
  display: grid;
  gap: 14px;
  margin-top: 22px;
  padding: 18px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--paper) 84%, var(--surface));
}

.purchase-panel.is-disabled {
  opacity: 0.72;
}

.purchase-panel fieldset {
  margin: 0;
  padding: 0;
  border: 0;
}

.purchase-panel legend,
.purchase-row label,
.activity-log-header {
  margin-bottom: 10px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
  text-transform: uppercase;
}

.segmented-options,
.swatch-options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.option-pill,
.swatch-button,
.activity-log-header button {
  min-height: 38px;
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  background: var(--paper);
  color: var(--ink);
  cursor: pointer;
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.option-pill:disabled,
.swatch-button:disabled,
.size-select:disabled,
.purchase-row input:disabled,
.purchase-button:disabled {
  cursor: not-allowed;
  opacity: 0.58;
}

.option-pill {
  padding: 0 18px;
}

.option-pill.is-selected,
.swatch-button.is-selected {
  border-color: var(--graphite);
  background: var(--graphite);
  color: var(--paper);
}

.swatch-button {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 0 12px;
}

.swatch-button span {
  width: 18px;
  height: 18px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: var(--swatch);
}

.size-select-wrap {
  position: relative;
  width: min(100%, 190px);
}

.size-select-wrap::after {
  position: absolute;
  top: 50%;
  right: 14px;
  width: 7px;
  height: 7px;
  border-right: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  content: "";
  pointer-events: none;
  transform: translateY(-65%) rotate(45deg);
}

.size-select {
  width: 100%;
  min-height: 42px;
  appearance: none;
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  padding: 0 42px 0 14px;
  background: var(--paper);
  color: var(--ink);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.purchase-row {
  display: grid;
  grid-template-columns: 72px 92px;
  gap: 12px;
  align-items: center;
}

.purchase-row label {
  margin: 0;
}

.purchase-row input {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  padding: 0 12px;
  background: var(--paper);
  color: var(--ink);
  font: inherit;
  font-weight: 850;
}

.purchase-button {
  min-height: 52px;
  border: 0;
  border-radius: 4px;
  background: var(--orange);
  color: var(--paper);
  cursor: pointer;
  font-size: 14px;
  font-weight: 900;
  text-transform: uppercase;
}

.purchase-button:disabled {
  background: var(--graphite);
}

.activity-log-panel {
  margin-top: 18px;
  padding: 16px;
  border: 1px solid var(--line);
  background: var(--paper);
}

.activity-log-header {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  margin-bottom: 12px;
}

.activity-log-header button {
  min-height: 28px;
  padding: 0 10px;
  font-size: 9px;
}

.activity-log {
  display: grid;
  gap: 8px;
  max-height: 152px;
  margin: 0;
  padding-left: 18px;
  overflow: auto;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
}

.product-showcase {
  margin: 0 0 22px;
  padding: 16px;
  border: 1px solid var(--line);
  background: rgb(255 255 255 / 72%);
}

.product-showcase-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 420px);
  gap: 28px;
  align-items: end;
  margin-bottom: 24px;
}

.product-showcase-head h2 {
  margin: 0;
  font-size: clamp(24px, 3.6vw, 48px);
  line-height: 0.94;
  text-transform: uppercase;
}

.product-showcase-head p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.48;
}

.product-showcase-grid {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(154px, 190px);
  grid-template-columns: none;
  gap: 12px;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: x proximity;
  padding-bottom: 4px;
}

.product-showcase-card {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  background: var(--paper);
  color: var(--ink);
  cursor: pointer;
  text-align: left;
  scroll-snap-align: start;
}

.product-showcase-card.is-coming-soon {
  border-style: dashed;
}

.product-showcase-card.is-selected,
.product-showcase-card:hover,
.product-showcase-card:focus-visible {
  border-color: var(--ink);
  box-shadow: 0 20px 48px rgb(11 16 16 / 9%);
  outline: 0;
}

.product-showcase-media {
  display: grid;
  place-items: center;
  aspect-ratio: 1;
  overflow: hidden;
  background: #fff;
}

.product-showcase-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.product-showcase-fallback {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  padding: 22px;
  border: 1px solid var(--line);
  background:
    linear-gradient(90deg, rgb(16 19 20 / 3%) 1px, transparent 1px) 0 0 / 22px 22px,
    linear-gradient(180deg, #fbfcfb, #eef2ef);
  color: var(--ink);
  text-align: center;
}

.product-showcase-fallback span {
  max-width: 14ch;
  font-size: 16px;
  font-weight: 900;
  line-height: 0.98;
  text-transform: uppercase;
}

.product-showcase-fallback em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 850;
  text-transform: uppercase;
}

.product-showcase-card strong {
  font-size: 15px;
  line-height: 1.1;
}

.product-showcase-card span:last-child {
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
  text-transform: uppercase;
}

.selection-summary {
  position: sticky;
  top: 112px;
  z-index: 18;
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 18px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  background: rgb(255 255 255 / 94%);
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  box-shadow: 0 10px 32px rgb(11 16 16 / 7%);
}

.selection-summary span {
  min-width: 0;
}

.selection-summary a {
  margin-left: auto;
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.load-error {
  padding: 24px;
  border: 1px solid var(--line);
  background: var(--paper);
  color: var(--muted);
}

.shop-index-shell {
  width: min(var(--max), calc(100vw - 108px));
  margin: 0 auto;
  padding: 34px 0 96px;
}

.shop-index-hero {
  display: grid;
  gap: 12px;
  max-width: 840px;
  margin-bottom: 28px;
}

.shop-index-hero h1 {
  margin-bottom: 4px;
  font-size: clamp(46px, 7vw, 92px);
  line-height: .9;
  text-transform: uppercase;
}

.shop-index-hero p:not(.eyebrow) {
  max-width: 680px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.45;
}

.shop-back-link {
  width: max-content;
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.shop-index-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.shop-index-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--line);
  background: var(--paper);
  color: var(--ink);
  text-decoration: none;
}

.shop-index-card:hover,
.shop-index-card:focus-visible {
  border-color: var(--ink);
  box-shadow: 0 18px 44px rgb(11 16 16 / 8%);
  outline: 0;
}

.shop-index-card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: contain;
  background: #fff;
}

.shop-index-card strong {
  font-size: 22px;
  line-height: .95;
  text-transform: uppercase;
}

.shop-index-card span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.shop-design-picker {
  margin: 16px 0 22px;
  padding: 16px;
  border: 1px solid var(--line);
  background: rgb(255 255 255 / 72%);
}

.shop-design-picker-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: end;
  margin-bottom: 12px;
}

.shop-design-picker-head .eyebrow {
  margin: 0;
}

.shop-design-picker-head h2 {
  margin: 0;
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.design-picker-strip {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(154px, 190px);
  gap: 12px;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  scroll-snap-type: x proximity;
  padding-bottom: 4px;
}

.design-picker-card {
  scroll-snap-align: start;
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--line);
  background: var(--paper);
  color: var(--ink);
  cursor: pointer;
  text-align: left;
}

.design-picker-card.is-selected,
.design-picker-card:hover,
.design-picker-card:focus-visible {
  border-color: var(--ink);
  box-shadow: 0 14px 32px rgb(11 16 16 / 8%);
  outline: 0;
}

.design-picker-card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: contain;
  background: #fff;
}

.design-picker-card strong {
  font-size: 13px;
  line-height: 1.05;
  text-transform: uppercase;
}

.design-picker-card span {
  color: var(--muted);
  font-size: 9px;
  font-weight: 900;
  text-transform: uppercase;
}

.field-notes-shell {
  padding-top: 54px;
}

.field-notes-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 72px;
  align-items: end;
  padding: 0 0 42px;
  border-bottom: 1px solid var(--line);
}

.field-notes-home-hero {
  grid-template-columns: minmax(0, 1fr) minmax(330px, 480px);
  gap: 50px;
  align-items: center;
}

.field-notes-hero h1 {
  max-width: 930px;
  margin-bottom: 24px;
  font-size: clamp(58px, 7vw, 104px);
  line-height: 0.88;
  text-transform: uppercase;
}

.field-notes-hero p:not(.eyebrow) {
  max-width: 780px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.56;
}

.field-notes-persona {
  margin-top: 16px;
  font-weight: 760;
}

.field-notes-hero-image {
  margin: 0;
}

.field-notes-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 10;
  display: block;
  border: 1px solid var(--graphite);
  border-radius: 4px;
  object-fit: cover;
}

.field-notes-hero-image figcaption {
  margin-top: 10px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.35;
  text-transform: uppercase;
}

.field-notes-start {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 50px;
  align-items: stretch;
  margin-top: 18px;
}

.field-notes-start-card {
  display: grid;
  gap: 12px;
  align-content: center;
  min-height: 168px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--graphite);
  color: var(--paper);
  text-decoration: none;
}

.field-notes-start-card span,
.field-notes-start-card em {
  color: rgb(250 246 238 / 74%);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
  line-height: 1.35;
  text-transform: uppercase;
}

.field-notes-start-card strong {
  max-width: 720px;
  font-size: clamp(30px, 4vw, 56px);
  font-weight: 950;
  line-height: 0.94;
  text-transform: uppercase;
}

.field-notes-ledger {
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.field-notes-ledger span {
  min-height: 62px;
  display: flex;
  align-items: center;
  padding: 0 18px;
  background: var(--paper);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.field-notes-layout {
  display: grid;
  grid-template-columns: 326px minmax(0, 1fr);
  gap: 46px;
  margin-top: 44px;
}

.field-notes-rail nav {
  display: grid;
}

.field-notes-main {
  display: grid;
  gap: 96px;
}

.field-notes-index {
  display: grid;
  gap: 54px;
}

.field-notes-index-group {
  padding-bottom: 34px;
  border-bottom: 1px solid var(--line);
}

.field-notes-index-group h2 {
  margin-bottom: 12px;
  font-size: 34px;
  line-height: 1;
  text-transform: uppercase;
}

.field-notes-index-description {
  max-width: 720px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
}

.field-notes-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.field-note-card {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 8px 14px;
  min-height: 158px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--paper);
  color: var(--ink);
  text-decoration: none;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

.field-note-card:hover,
.field-note-card:focus-visible {
  border-color: var(--ink);
  box-shadow: 0 18px 44px rgb(11 16 16 / 8%);
  outline: 0;
  transform: translateY(-2px);
}

.field-note-card-number {
  grid-row: 1 / span 3;
  color: var(--orange);
  font-size: 18px;
  font-weight: 950;
  line-height: 1;
}

.field-note-card strong {
  grid-column: 2;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.15;
  text-transform: uppercase;
}

.field-note-card-summary {
  grid-column: 2;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.38;
}

.field-note-card-meta {
  grid-column: 2;
  align-self: end;
  color: var(--orange);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.2;
  text-transform: uppercase;
}

.field-notes-articles {
  display: grid;
  gap: 92px;
}

.field-note {
  scroll-margin-top: 260px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 282px;
  gap: 34px;
  padding-bottom: 84px;
  border-bottom: 1px solid var(--line);
}

.field-note-header {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 22px 34px;
  align-items: end;
  padding-top: 44px;
}

.field-note-header .eyebrow,
.field-note-header h2,
.field-note-header .field-note-deck {
  grid-column: 1;
}

.field-note-header h2 {
  max-width: 820px;
  margin-bottom: 0;
  font-size: clamp(36px, 4.5vw, 64px);
  line-height: 0.96;
  text-transform: uppercase;
}

.field-note-deck {
  max-width: 820px;
  margin: 0;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.45;
}

.field-note-meta {
  grid-column: 2;
  grid-row: 1 / span 3;
  align-self: stretch;
  width: 220px;
  display: grid;
  gap: 1px;
  border: 1px solid var(--line);
  background: var(--line);
}

.field-note-meta span {
  display: flex;
  align-items: center;
  min-height: 48px;
  padding: 0 14px;
  background: var(--paper);
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
  text-transform: uppercase;
}

.field-note-body {
  max-width: 760px;
}

.field-note-body p {
  color: var(--ink);
  font-size: 17px;
  line-height: 1.66;
}

.field-note-thesis {
  margin-bottom: 28px;
  padding: 18px 20px;
  border-left: 4px solid var(--orange);
  background: color-mix(in srgb, var(--surface) 78%, var(--paper));
  font-weight: 760;
}

.field-note-section {
  margin-top: 32px;
}

.field-note-section h3 {
  margin: 0 0 12px;
  font-size: 16px;
  line-height: 1.15;
  text-transform: uppercase;
}

.affected-note {
  margin-top: 34px;
  padding: 18px 20px;
  border: 1px solid var(--line);
  background: var(--paper);
}

.affected-note strong {
  display: block;
  margin-bottom: 10px;
  color: var(--orange);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.affected-note p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.note-visual {
  grid-column: 2;
  grid-row: 2;
  align-self: start;
  position: sticky;
  top: 214px;
  margin: 0;
}

.note-visual-frame {
  position: relative;
  min-height: 356px;
  display: grid;
  align-content: space-between;
  overflow: hidden;
  padding: 18px;
  border: 1px solid var(--graphite);
  border-radius: 4px;
  background:
    linear-gradient(90deg, rgb(16 19 20 / 8%) 1px, transparent 1px) 0 0 / 28px 28px,
    linear-gradient(180deg, var(--paper), var(--surface));
}

.note-visual-frame::before,
.note-visual-frame::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.note-visual-frame::before {
  inset: 18px;
  border: 1px solid rgb(16 19 20 / 16%);
}

.note-visual-frame::after {
  width: 136px;
  height: 136px;
  right: -34px;
  bottom: -34px;
  border: 22px solid var(--orange);
  opacity: 0.18;
  transform: rotate(12deg);
}

.note-visual-label,
.note-visual-title {
  position: relative;
  z-index: 1;
  display: block;
}

.note-visual-label {
  color: var(--orange);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.note-visual-title {
  max-width: 210px;
  margin-top: 12px;
  font-size: 30px;
  font-weight: 950;
  line-height: 0.9;
  text-transform: uppercase;
}

.note-visual-stats {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1px;
  margin: 26px 0 0;
  background: var(--line);
  border: 1px solid var(--line);
}

.note-visual-stats div {
  padding: 10px;
  background: rgb(255 255 255 / 82%);
}

.note-visual-stats dt {
  margin-bottom: 4px;
  color: var(--muted);
  font-size: 8px;
  font-weight: 900;
  text-transform: uppercase;
}

.note-visual-stats dd {
  margin: 0;
  font-size: 16px;
  font-weight: 950;
  line-height: 1;
}

.note-visual figcaption {
  margin-top: 10px;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
}

.visual-invoice .note-visual-frame {
  background:
    linear-gradient(180deg, transparent 0 62px, rgb(16 19 20 / 12%) 62px 63px, transparent 63px 100%),
    repeating-linear-gradient(180deg, var(--paper) 0 38px, var(--surface) 38px 39px);
}

.visual-border .note-visual-frame {
  background:
    linear-gradient(90deg, transparent 0 44%, rgb(255 75 31 / 24%) 44% 48%, transparent 48%),
    linear-gradient(180deg, var(--paper), var(--surface));
}

.visual-ticket .note-visual-frame {
  background:
    radial-gradient(circle at 0 50%, var(--white) 0 18px, transparent 19px),
    radial-gradient(circle at 100% 50%, var(--white) 0 18px, transparent 19px),
    repeating-linear-gradient(90deg, var(--paper) 0 24px, var(--surface) 24px 25px);
}

.visual-workers .note-visual-frame,
.visual-city .note-visual-frame {
  background:
    linear-gradient(90deg, rgb(16 19 20 / 12%) 0 18%, transparent 18% 100%),
    linear-gradient(180deg, var(--paper), var(--surface));
}

.visual-sponsor .note-visual-frame {
  background:
    linear-gradient(90deg, var(--graphite) 0 18%, transparent 18% 100%),
    repeating-linear-gradient(180deg, var(--paper) 0 62px, var(--surface) 62px 63px);
}

.visual-map .note-visual-frame {
  background:
    linear-gradient(35deg, transparent 0 32%, rgb(255 75 31 / 16%) 32% 34%, transparent 34% 100%),
    linear-gradient(145deg, transparent 0 58%, rgb(6 31 61 / 14%) 58% 60%, transparent 60%),
    linear-gradient(180deg, var(--paper), var(--surface));
}

.visual-fireworks .note-visual-frame {
  background:
    radial-gradient(circle at 24% 30%, rgb(255 75 31 / 28%) 0 2px, transparent 3px 100%),
    radial-gradient(circle at 72% 24%, rgb(6 31 61 / 24%) 0 2px, transparent 3px 100%),
    radial-gradient(circle at 54% 62%, rgb(255 75 31 / 18%) 0 3px, transparent 4px 100%),
    linear-gradient(180deg, var(--paper), var(--surface));
}

.note-sources {
  grid-column: 1 / -1;
  max-width: 920px;
  border: 1px solid var(--line);
  background: var(--paper);
}

.note-sources summary {
  padding: 14px 18px;
  cursor: pointer;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.note-sources ol {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0 18px 18px 42px;
}

.note-sources a {
  color: var(--ink);
  font-size: 12px;
  font-weight: 760;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.field-article-shell {
  padding-top: 54px;
}

.article-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-bottom: 28px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
}

.article-breadcrumb a {
  color: var(--orange);
  text-decoration: none;
}

.article-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 500px);
  gap: 52px;
  align-items: start;
  padding-bottom: 42px;
  border-bottom: 1px solid var(--line);
}

.article-hero h1 {
  max-width: 900px;
  margin-bottom: 24px;
  font-size: clamp(42px, 5.2vw, 78px);
  font-weight: 950;
  line-height: 0.9;
  text-transform: uppercase;
}

.article-hero-meta {
  grid-column: auto;
  grid-row: auto;
  width: min(100%, 520px);
  margin-top: 28px;
}

.article-cover {
  margin: 132px 0 0;
}

.article-cover img {
  width: 100%;
  aspect-ratio: 16 / 10;
  display: block;
  border: 1px solid var(--graphite);
  border-radius: 4px;
  object-fit: cover;
}

.article-cover figcaption {
  margin-top: 10px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.35;
}

.article-cover figcaption span {
  display: block;
  margin-bottom: 4px;
  color: var(--orange);
  font-size: 9px;
  font-weight: 900;
  text-transform: uppercase;
}

.article-layout {
  display: grid;
  grid-template-columns: minmax(220px, 300px) minmax(0, 760px);
  gap: 52px;
  align-items: start;
  margin-top: 52px;
}

.article-sidebar {
  position: sticky;
  top: 214px;
  display: grid;
  gap: 14px;
}

.article-sidebar-card {
  padding: 18px 20px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--paper);
}

.article-sidebar-card span {
  display: block;
  margin-bottom: 10px;
  color: var(--orange);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.article-sidebar-card p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

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

.article-copy p {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.72;
}

.article-section {
  margin-top: 34px;
}

.article-section h2 {
  margin-bottom: 14px;
  font-size: 18px;
  font-weight: 900;
  line-height: 1.1;
  text-transform: uppercase;
}

.article-sources {
  max-width: 980px;
  margin-top: 66px;
  padding-top: 34px;
  border-top: 1px solid var(--line);
}

.article-sources h2 {
  margin-bottom: 12px;
  font-size: 32px;
  line-height: 0.95;
  text-transform: uppercase;
}

.source-note {
  max-width: 720px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.article-sources ol {
  display: grid;
  gap: 0;
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--line);
}

.article-sources li {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 18px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}

.source-domain {
  color: var(--orange);
  font-size: 10px;
  font-weight: 900;
  line-height: 1.3;
  overflow-wrap: anywhere;
  text-transform: uppercase;
}

.article-sources a {
  color: var(--ink);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.article-pagination {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 54px;
}

.article-pagination a,
.article-nav-empty {
  min-height: 92px;
  display: grid;
  gap: 8px;
  align-content: center;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--paper);
  color: var(--ink);
  text-decoration: none;
}

.article-pagination a:hover,
.article-pagination a:focus-visible {
  border-color: var(--ink);
  outline: 0;
}

.article-pagination span {
  color: var(--orange);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.article-pagination strong {
  font-size: 14px;
  font-weight: 900;
  line-height: 1.2;
  text-transform: uppercase;
}

@keyframes glide-in {
  from {
    opacity: 0;
    transform: translateX(38px) translateY(8px) scale(0.985);
  }

  to {
    opacity: 1;
    transform: translateX(0) translateY(0) scale(1);
  }
}


@media (max-width: 980px) {
  .store-header,
  .site-shell,
  .product-shell,
  .footer {
    width: auto;
  }

  .utility-strip,
  .store-masthead,
  .collection-tabs,
  .site-shell,
  .product-shell,
  .footer {
    padding-inline: 20px;
  }

  .store-masthead {
    min-height: auto;
    grid-template-columns: 1fr auto;
    gap: 12px;
    padding-block: 12px;
  }

  .utility-strip {
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 8px 18px;
    min-height: 38px;
    padding-block: 8px;
    font-size: 10px;
    line-height: 1.2;
  }

  .store-actions {
    justify-self: end;
    gap: 12px;
  }

  .store-brand {
    gap: 9px;
    font-size: 18px;
  }

  .store-brand img {
    width: 34px;
    height: 34px;
  }

  .collection-tabs {
    flex-wrap: nowrap;
    gap: 18px;
    min-height: 42px;
    overflow-x: auto;
    white-space: nowrap;
  }

  .intro-room,
  .gallery-hero,
  .gallery-section-head,
  .layout,
  .product-stage,
  .field-notes-hero,
  .field-notes-layout,
  .field-notes-start,
  .article-hero,
  .article-layout,
  .field-note,
  .field-note-header {
    grid-template-columns: 1fr;
  }

  .product-visual,
  .product-copy,
  .field-note-header .eyebrow,
  .field-note-header h2,
  .field-note-header .field-note-deck,
  .field-note-meta,
  .note-visual {
    grid-column: auto;
  }

  .room-rail,
  .field-notes-rail,
  .note-visual,
  .article-sidebar {
    position: static;
    min-height: 0;
  }

  .artifact-grid,
  .design-gallery,
  .variant-federation .artifact-grid,
  .field-notes-card-grid,
  .article-pagination {
    grid-template-columns: 1fr;
  }

  .article-sources li {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .article-cover {
    margin-top: 0;
  }

  .field-note-meta {
    grid-row: auto;
    width: auto;
  }

  .field-note {
    gap: 24px;
  }

  .drawer-panel {
    inset: 24px 16px auto;
    width: auto;
    grid-template-columns: 1fr;
  }

  .product-visual {
    min-height: 360px;
    margin-top: 0;
  }

  .product-shell,
  .shop-index-shell {
    padding-top: 18px;
    padding-bottom: 56px;
  }

  .gallery-return {
    position: static;
    width: max-content;
    margin: 0 0 14px;
    transform: none;
  }

  .gallery-return-rule {
    width: 28px;
  }

  .shop-design-picker {
    margin-top: 0;
    margin-inline: -4px;
    padding: 12px;
  }

  .design-picker-strip {
    grid-auto-columns: minmax(132px, 42vw);
  }

  .product-stage {
    gap: 18px;
    min-height: 0;
  }

  .product-copy h1 {
    font-size: clamp(36px, 12vw, 56px);
  }

  .product-copy p {
    font-size: 14px;
  }

  .product-visual > img.product-mockup,
  .mockup-carousel img {
    width: min(92%, 420px);
    max-height: 330px;
  }

  .mockup-carousel {
    inset: 20px 10px 86px;
  }

  .mockup-rotator {
    left: 12px;
    right: 12px;
    bottom: 12px;
  }

  .purchase-panel {
    padding: 14px;
  }

  .size-select-wrap,
  .purchase-row {
    width: 100%;
  }

  .purchase-row {
    grid-template-columns: 1fr 110px;
  }

  .product-showcase {
    margin-inline: -4px;
    margin-bottom: 16px;
    padding: 12px;
  }

  .product-showcase-head {
    grid-template-columns: 1fr;
    gap: 8px;
    margin-bottom: 14px;
  }

  .product-showcase-head h2 {
    font-size: clamp(30px, 10vw, 46px);
  }

  .product-showcase-grid {
    grid-auto-columns: minmax(132px, 42vw);
    padding-bottom: 6px;
  }

  .product-showcase-card {
    scroll-snap-align: start;
    padding: 10px;
  }

  .product-showcase-card strong {
    font-size: 12px;
  }

  .selection-summary {
    top: 0;
    margin-inline: -4px;
    margin-bottom: 14px;
    padding: 9px 10px;
    gap: 6px;
    font-size: 10px;
  }

  .selection-summary span:first-child,
  .selection-summary span:nth-child(3) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .selection-summary a {
    flex: 0 0 auto;
  }

  .activity-log-panel {
    display: none;
  }

  .shop-index-grid {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  .shop-index-card {
    padding: 10px;
  }

  .shop-index-card strong {
    font-size: 17px;
  }

  .gallery-hero {
    min-height: 0;
    gap: 28px;
  }

  .gallery-copy,
  .gallery-copy p:not(.eyebrow),
  .gallery-section-head h2 {
    max-width: 100%;
    overflow-wrap: anywhere;
  }

  .gallery-hero,
  .gallery-release,
  .featured-design,
  .gallery-feature-card,
  .gallery-card {
    max-width: 100%;
    min-width: 0;
  }

  .exhibit-meta {
    width: 100%;
    max-width: 100%;
  }

  .exhibit-meta span {
    min-height: 0;
    display: block;
    padding-block: 14px;
  }

  .exhibit-meta strong {
    display: block;
    margin-bottom: 6px;
  }

  .featured-design {
    transform: none;
  }

  .gallery-feature-card {
    min-height: 360px;
  }

  .gallery-feature-card .pixel-preview {
    aspect-ratio: 1.25;
  }

  .tournament-title {
    font-size: 70px;
    line-height: 0.88;
  }

  .exhibit-meta span {
    align-content: center;
    line-height: 1.18;
  }

  .mode-switcher {
    right: 12px;
    bottom: 12px;
  }
}

@media (max-width: 480px) {
  .tournament-title {
    font-size: 52px;
  }

  .gallery-copy p:not(.eyebrow) {
    font-size: 16px;
  }

  .gallery-feature-card {
    min-height: 320px;
  }
}

/* Field Notes editorial redesign */
body.field-notes-body {
  --editorial-serif: Georgia, "Times New Roman", serif;
  background:
    radial-gradient(circle at 78% 12%, rgb(255 75 31 / 4%), transparent 28%),
    linear-gradient(180deg, #fbfcfa 0, #f7f8f6 520px, #f8f8f4 100%);
}

body.field-notes-body .store-header {
  border-bottom-color: rgb(16 19 20 / 8%);
  box-shadow: 0 1px 0 rgb(255 255 255 / 70%);
}

body.field-notes-body .scroll-reveal {
  filter: none;
  transform: translateY(16px);
}

body.field-notes-body .store-masthead {
  min-height: 104px;
  grid-template-columns: 230px 1fr;
}

body.field-notes-body .store-search {
  min-height: 44px;
  padding-inline: 0;
  border-bottom: 1px solid rgb(16 19 20 / 14%);
  border-radius: 0;
  background: transparent;
}

body.field-notes-body .collection-tabs {
  min-height: 52px;
}

body.field-notes-body .site-shell {
  width: min(1240px, calc(100vw - 96px));
}

body.field-notes-body .field-notes-shell {
  padding-top: 72px;
}

body.field-notes-body .field-notes-home-hero {
  position: relative;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 500px);
  gap: clamp(42px, 7vw, 92px);
  align-items: center;
  padding-bottom: 58px;
  border-bottom: 0;
}

body.field-notes-body .field-notes-home-hero::after,
body.field-notes-body .article-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--orange), rgb(16 19 20 / 12%) 22%, transparent 100%);
}

body.field-notes-body .field-notes-hero h1,
body.field-notes-body .article-hero h1,
body.field-notes-body .field-notes-index-group h2,
body.field-notes-body .field-notes-start-card strong,
body.field-notes-body .article-sources h2 {
  font-family: var(--editorial-serif);
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
}

body.field-notes-body .field-notes-hero h1 {
  max-width: 820px;
  margin-bottom: 26px;
  font-size: clamp(66px, 8vw, 128px);
  line-height: 0.92;
}

body.field-notes-body .field-notes-hero p:not(.eyebrow) {
  max-width: 740px;
  font-size: 20px;
  line-height: 1.58;
}

body.field-notes-body .field-notes-persona {
  max-width: 690px;
  color: var(--ink);
  font-family: var(--editorial-serif);
  font-size: 22px;
  font-style: italic;
  font-weight: 500;
  line-height: 1.42;
}

body.field-notes-body .field-notes-hero-image {
  animation: editorial-drift 900ms cubic-bezier(0.2, 0.7, 0.2, 1) both;
}

body.field-notes-body .field-notes-hero-image img,
body.field-notes-body .article-cover img {
  border: 0;
  border-radius: 2px;
  box-shadow: 0 32px 70px rgb(11 16 16 / 12%);
  filter: saturate(0.88) contrast(0.98);
}

body.field-notes-body .field-notes-hero-image figcaption,
body.field-notes-body .article-cover figcaption {
  max-width: 92%;
  color: var(--muted);
  font-size: 10px;
  font-weight: 760;
  line-height: 1.45;
  text-transform: uppercase;
}

body.field-notes-body .field-notes-start {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 38px;
  align-items: center;
  margin-top: 12px;
  padding: 28px 0 34px;
  border-top: 1px solid rgb(16 19 20 / 12%);
  border-bottom: 1px solid rgb(16 19 20 / 12%);
}

body.field-notes-body .field-notes-start-card {
  min-height: auto;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
}

body.field-notes-body .field-notes-start-card span,
body.field-notes-body .field-notes-start-card em {
  color: var(--orange);
}

body.field-notes-body .field-notes-start-card strong {
  font-size: clamp(34px, 5vw, 72px);
  line-height: 0.96;
}

body.field-notes-body .field-notes-start-card:hover strong,
body.field-notes-body .field-notes-start-card:focus-visible strong {
  color: var(--orange);
}

body.field-notes-body .field-notes-ledger {
  min-width: 220px;
  border: 0;
  background: transparent;
}

body.field-notes-body .field-notes-ledger span {
  min-height: auto;
  padding: 12px 0;
  border-bottom: 1px solid rgb(16 19 20 / 12%);
  background: transparent;
}

body.field-notes-body .field-notes-layout {
  grid-template-columns: 210px minmax(0, 1fr);
  gap: clamp(42px, 6vw, 86px);
  margin-top: 70px;
}

body.field-notes-body .field-notes-rail {
  min-height: auto;
  padding: 0;
  background: transparent;
  color: var(--ink);
}

body.field-notes-body .room-rail a {
  border-top: 1px solid rgb(16 19 20 / 12%);
  color: var(--muted);
  font-size: 11px;
}

body.field-notes-body .room-rail a:hover,
body.field-notes-body .room-rail a:focus-visible {
  color: var(--orange);
}

body.field-notes-body .rail-note {
  color: var(--muted);
  font-size: 13px;
}

body.field-notes-body .field-notes-main {
  gap: 72px;
}

body.field-notes-body .field-notes-index {
  gap: 76px;
}

body.field-notes-body .field-notes-index-group {
  display: grid;
  grid-template-columns: 138px minmax(0, 1fr);
  gap: 28px 44px;
  padding-bottom: 0;
  border-bottom: 0;
}

body.field-notes-body .field-notes-index-group > .eyebrow {
  grid-row: 1 / span 3;
  margin-top: 8px;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
}

body.field-notes-body .field-notes-index-group h2 {
  margin-bottom: 0;
  font-size: clamp(38px, 5vw, 72px);
  line-height: 0.98;
}

body.field-notes-body .field-notes-index-description {
  max-width: 720px;
  font-size: 16px;
}

body.field-notes-body .field-notes-card-grid {
  grid-template-columns: 1fr;
  gap: 0;
  margin-top: 12px;
  border-top: 1px solid rgb(16 19 20 / 14%);
}

body.field-notes-body .field-note-card {
  position: relative;
  grid-template-columns: 54px 112px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  min-height: auto;
  padding: 24px 72px 24px 0;
  border: 0;
  border-bottom: 1px solid rgb(16 19 20 / 11%);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

body.field-notes-body .field-note-card::after {
  content: "Read";
  position: absolute;
  right: 0;
  top: 28px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  transition:
    color 180ms ease,
    transform 180ms ease;
}

body.field-notes-body .field-note-card:hover,
body.field-notes-body .field-note-card:focus-visible {
  border-color: rgb(255 75 31 / 42%);
  box-shadow: none;
  transform: translateX(8px);
}

body.field-notes-body .field-note-card:hover::after,
body.field-notes-body .field-note-card:focus-visible::after {
  color: var(--orange);
  transform: translateX(4px);
}

body.field-notes-body .field-note-card-number {
  color: var(--muted);
  font-family: var(--editorial-serif);
  font-size: 24px;
  font-weight: 500;
}

body.field-notes-body .field-note-card-image {
  width: 112px;
  aspect-ratio: 1.2;
  display: block;
  overflow: hidden;
  background: var(--surface);
}

body.field-notes-body .field-note-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.82) contrast(0.96);
  transition: transform 220ms ease, filter 220ms ease;
}

body.field-notes-body .field-note-card:hover .field-note-card-image img,
body.field-notes-body .field-note-card:focus-visible .field-note-card-image img {
  filter: saturate(0.96) contrast(1);
  transform: scale(1.045);
}

body.field-notes-body .field-note-card-copy {
  display: grid;
  gap: 8px;
}

body.field-notes-body .field-note-card strong {
  font-size: clamp(18px, 2vw, 26px);
  font-weight: 820;
  line-height: 1.08;
  text-transform: none;
}

body.field-notes-body .field-note-card-summary {
  max-width: 780px;
  font-size: 14px;
  line-height: 1.5;
}

body.field-notes-body .field-note-card-meta {
  margin-top: 4px;
}

body.field-notes-body .field-article-shell {
  padding-top: 58px;
}

body.field-notes-body .article-page {
  animation: editorial-rise 460ms cubic-bezier(0.2, 0.7, 0.2, 1) both;
}

body.field-notes-body .article-breadcrumb {
  margin-bottom: 34px;
}

body.field-notes-body .article-hero {
  position: relative;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 480px);
  gap: clamp(42px, 6vw, 82px);
  padding-bottom: 62px;
  border-bottom: 0;
}

body.field-notes-body .article-hero h1 {
  max-width: 820px;
  margin-bottom: 28px;
  font-size: clamp(50px, 6vw, 104px);
  line-height: 0.94;
}

body.field-notes-body .field-note-deck {
  max-width: 780px;
  font-family: var(--editorial-serif);
  font-size: 24px;
  line-height: 1.38;
}

body.field-notes-body .field-note-meta,
body.field-notes-body .article-hero-meta {
  width: auto;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-top: 30px;
  border: 0;
  background: transparent;
}

body.field-notes-body .field-note-meta span,
body.field-notes-body .article-hero-meta span {
  min-height: auto;
  padding: 0 18px 0 0;
  border-right: 1px solid rgb(16 19 20 / 18%);
  background: transparent;
}

body.field-notes-body .field-note-meta span:last-child,
body.field-notes-body .article-hero-meta span:last-child {
  border-right: 0;
}

body.field-notes-body .article-cover {
  margin-top: 86px;
}

body.field-notes-body .article-layout {
  grid-template-columns: minmax(0, 760px) minmax(220px, 300px);
  gap: clamp(42px, 6vw, 86px);
  margin-top: 64px;
}

body.field-notes-body .article-copy {
  grid-column: 1;
}

body.field-notes-body .article-sidebar {
  grid-column: 2;
  grid-row: 1;
}

body.field-notes-body .article-copy p {
  font-family: var(--editorial-serif);
  font-size: 20px;
  line-height: 1.76;
}

body.field-notes-body .field-note-thesis {
  margin-bottom: 38px;
  padding: 0 0 0 24px;
  border-left: 2px solid var(--orange);
  background: transparent;
  font-size: 24px;
  line-height: 1.55;
}

body.field-notes-body .article-section h2 {
  margin-top: 0;
  font-size: 12px;
  letter-spacing: 0.04em;
}

body.field-notes-body .article-sidebar-card {
  padding: 20px 0;
  border: 0;
  border-top: 1px solid rgb(16 19 20 / 14%);
  border-radius: 0;
  background: transparent;
}

body.field-notes-body .article-sidebar-card p {
  font-family: var(--editorial-serif);
  font-size: 15px;
  line-height: 1.58;
}

body.field-notes-body .article-sources {
  max-width: none;
  margin-top: 84px;
  padding-top: 42px;
}

body.field-notes-body .article-sources h2 {
  font-size: clamp(34px, 5vw, 64px);
}

body.field-notes-body .article-sources ol {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 46px;
  border-top-color: rgb(16 19 20 / 14%);
}

body.field-notes-body .article-sources li {
  grid-template-columns: 140px minmax(0, 1fr);
  border-bottom-color: rgb(16 19 20 / 10%);
}

body.field-notes-body .source-domain {
  color: var(--muted);
}

body.field-notes-body .article-pagination a,
body.field-notes-body .article-nav-empty {
  border: 0;
  border-top: 1px solid rgb(16 19 20 / 14%);
  border-radius: 0;
  background: transparent;
}

.reader-notes {
  position: fixed;
  top: auto;
  bottom: 18px;
  left: 18px;
  z-index: 90;
  width: min(330px, calc(100vw - 36px));
  height: 224px;
  min-width: 220px;
  min-height: 150px;
  max-width: calc(100vw - 24px);
  max-height: calc(100vh - 24px);
  display: grid;
  grid-template-rows: 34px minmax(0, 1fr);
  border: 1px solid rgb(16 19 20 / 18%);
  background: rgb(251 252 250 / 92%);
  box-shadow: 0 18px 60px rgb(11 16 16 / 13%);
  backdrop-filter: blur(18px);
  overflow: hidden;
  resize: both;
}

.reader-notes.is-collapsed {
  width: 164px !important;
  height: 34px !important;
  min-width: 0;
  min-height: 0;
  resize: none;
}

.reader-notes.is-collapsed .reader-notes-textarea {
  display: none;
}

.reader-notes-header {
  min-height: 34px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 0 12px;
  border-bottom: 1px solid rgb(16 19 20 / 14%);
  color: var(--ink);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  cursor: grab;
  user-select: none;
  touch-action: none;
}

.reader-notes-toggle {
  margin-left: auto;
  border: 0;
  background: transparent;
  color: var(--orange);
  cursor: pointer;
  font: inherit;
  text-transform: uppercase;
}

.reader-notes-toggle:hover,
.reader-notes-toggle:focus-visible {
  color: var(--ink);
  outline: 0;
}

.reader-notes.is-dragging .reader-notes-header {
  cursor: grabbing;
}

.reader-notes-header span:last-child {
  color: var(--muted);
}

.reader-notes-textarea {
  width: 100%;
  height: 100%;
  min-height: 0;
  display: block;
  resize: none;
  border: 0;
  padding: 12px;
  background: transparent;
  color: var(--ink);
  font: 13px/1.45 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  tab-size: 2;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.reader-notes-textarea:focus {
  outline: 2px solid rgb(255 75 31 / 36%);
  outline-offset: -2px;
}

.field-note-window {
  position: fixed;
  inset: 0;
  z-index: 70;
  display: none;
}

.field-note-window.is-open {
  display: block;
}

.field-note-window-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgb(11 16 16 / 44%);
  cursor: zoom-out;
}

.field-note-window-panel {
  position: absolute;
  inset: 42px;
  overflow: auto;
  padding: clamp(26px, 4vw, 64px);
  border: 1px solid rgb(16 19 20 / 18%);
  background:
    linear-gradient(90deg, rgb(16 19 20 / 3%) 1px, transparent 1px) 0 0 / 72px 72px,
    #fbfcfa;
  box-shadow: 0 32px 90px rgb(0 0 0 / 26%);
}

.field-note-window-close {
  position: sticky;
  top: 0;
  z-index: 2;
  float: right;
  width: 42px;
  height: 42px;
  border: 1px solid rgb(16 19 20 / 16%);
  background: rgb(251 252 250 / 88%);
  color: var(--ink);
  cursor: pointer;
  font-size: 28px;
  line-height: 1;
}

.field-note-window-close:hover,
.field-note-window-close:focus-visible {
  border-color: var(--orange);
  color: var(--orange);
  outline: 0;
}

.field-note-window-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 430px);
  gap: clamp(36px, 5vw, 76px);
  align-items: end;
  padding-bottom: 42px;
  border-bottom: 1px solid rgb(16 19 20 / 12%);
}

.field-note-window-hero h1 {
  max-width: 840px;
  margin-bottom: 24px;
  font-family: var(--editorial-serif);
  font-size: clamp(46px, 6vw, 94px);
  font-weight: 500;
  line-height: 0.94;
}

.field-note-window-image {
  margin: 0;
}

.field-note-window-image img {
  width: 100%;
  aspect-ratio: 1.1;
  object-fit: cover;
  filter: saturate(0.86) contrast(0.98);
}

.field-note-window-image figcaption {
  max-width: 92%;
  margin-top: 10px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 820;
  line-height: 1.42;
  text-transform: uppercase;
}

.field-note-window-layout {
  display: grid;
  grid-template-columns: minmax(0, 760px) minmax(260px, 360px);
  gap: clamp(38px, 5vw, 78px);
  margin-top: 48px;
}

.field-note-window-copy p {
  font-family: var(--editorial-serif);
  font-size: 20px;
  line-height: 1.76;
}

.field-note-window-section h2 {
  margin: 36px 0 14px;
  color: var(--orange);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.field-note-window-sources {
  align-self: start;
  position: sticky;
  top: 24px;
  padding-top: 8px;
  border-top: 1px solid rgb(16 19 20 / 16%);
}

.field-note-window-sources ol {
  display: grid;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.field-note-window-sources li {
  display: grid;
  gap: 4px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgb(16 19 20 / 10%);
}

.field-note-window-sources a {
  color: var(--ink);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.35;
  text-decoration: none;
}

.field-note-window-sources a:hover,
.field-note-window-sources a:focus-visible {
  color: var(--orange);
  outline: 0;
}

@keyframes editorial-rise {
  from {
    opacity: 0.62;
    transform: translateY(14px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes editorial-drift {
  from {
    opacity: 0.68;
    transform: translateY(12px) rotate(0.45deg) scale(0.99);
  }

  to {
    opacity: 1;
    transform: translateY(0) rotate(0deg) scale(1);
  }
}

@media (max-width: 980px) {
  body.field-notes-body .site-shell {
    width: auto;
  }

  body.field-notes-body .store-masthead {
    min-height: auto;
    grid-template-columns: 1fr;
  }

  body.field-notes-body .field-notes-home-hero,
  body.field-notes-body .field-notes-start,
  body.field-notes-body .field-notes-layout,
  body.field-notes-body .field-notes-index-group,
  body.field-notes-body .article-hero,
  body.field-notes-body .article-layout,
  body.field-notes-body .article-sources ol,
  body.field-notes-body .article-pagination {
    grid-template-columns: 1fr;
  }

  body.field-notes-body .field-notes-hero h1 {
    font-size: clamp(54px, 16vw, 82px);
  }

  body.field-notes-body .article-hero h1 {
    font-size: clamp(46px, 14vw, 72px);
  }

  body.field-notes-body .field-notes-hero p:not(.eyebrow),
  body.field-notes-body .field-note-deck {
    font-size: 19px;
  }

  body.field-notes-body .field-notes-index-group > .eyebrow {
    grid-row: auto;
    writing-mode: horizontal-tb;
    transform: none;
  }

  body.field-notes-body .field-note-card {
    grid-template-columns: 42px minmax(0, 1fr);
    padding-right: 0;
  }

  body.field-notes-body .field-note-card::after {
    content: "";
  }

  body.field-notes-body .article-cover {
    margin-top: 0;
  }

  body.field-notes-body .article-copy,
  body.field-notes-body .article-sidebar {
    grid-column: auto;
    grid-row: auto;
  }

  body.field-notes-body .article-copy p {
    font-size: 18px;
  }

  body.field-notes-body .article-sources li {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.field-notes-body .article-page,
  body.field-notes-body .field-notes-hero-image {
    animation: none;
  }
}
