@view-transition {
  navigation: auto;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  interpolate-size: allow-keywords;
}

html.has-dialog-open,
html.has-dialog-open body {
  overflow: hidden;
}

body {
  position: relative;
  margin: 0;
  min-width: 320px;
  font-family: var(--font-sans);
  color: var(--body-color);
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.56), transparent 28%),
    radial-gradient(circle at 85% 18%, color-mix(in srgb, var(--accent-gold) 14%, transparent), transparent 22%),
    radial-gradient(circle at 24% 72%, color-mix(in srgb, var(--accent-soft) 14%, transparent), transparent 26%),
    linear-gradient(180deg, color-mix(in srgb, var(--page-bg) 92%, white 8%) 0%, color-mix(in srgb, var(--page-bg) 78%, var(--section-bg)) 100%);
  line-height: 1.6;
  transition: background var(--transition-medium), color var(--transition-medium);
}

[data-theme="dark"] body {
  background:
    radial-gradient(circle at 12% 0%, rgba(255, 216, 180, 0.06), transparent 24%),
    radial-gradient(circle at 82% 18%, rgba(161, 116, 76, 0.10), transparent 22%),
    linear-gradient(180deg, #12100e 0%, #161310 38%, #0f0d0c 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
  background-size: 7rem 7rem;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.28), transparent 70%);
  opacity: 0.25;
}

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

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

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

button {
  cursor: pointer;
}

main {
  position: relative;
  overflow: clip;
}

main > .section,
main > .page-hero {
  content-visibility: auto;
  contain-intrinsic-size: 1px 700px;
}

::selection {
  background: color-mix(in srgb, var(--accent-soft) 70%, transparent);
  color: var(--heading-color);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  color: var(--heading-color);
  line-height: 1.12;
  text-wrap: balance;
}

@media (max-width: 48rem) {
  h1,
  h2 {
    line-height: 1.2;
    text-wrap: pretty;
    hyphens: auto;
    overflow-wrap: break-word;
  }
}

h1,
h2 {
  font-family: var(--font-display);
  letter-spacing: -0.02em;
}

h3,
h4,
h5,
h6 {
  font-family: var(--font-sans);
  letter-spacing: -0.02em;
}

p,
ul,
ol {
  margin: 0;
  text-wrap: pretty;
}

ul,
ol {
  padding: 0;
  list-style: none;
}

.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  z-index: 100;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-pill);
  background: var(--button-bg);
  color: var(--button-text);
  transition: top var(--transition-fast);
}

.skip-link:focus {
  top: 1rem;
}

:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--accent-warm) 80%, white 12%);
  outline-offset: 3px;
}

[hidden] {
  display: none !important;
}

::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 520ms;
  animation-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
}

@supports (animation-timeline: view()) {
  .page-home .hero-mosaic .visual-card img,
  .page-home .editorial-band .visual-card img {
    animation: gallery-pan linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 75%;
  }

  .section-heading__title,
  .page-hero__heading h1 {
    animation: heading-drift linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 50%;
  }

  .cta-banner {
    animation: cta-lift linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 60%;
  }
}

@keyframes gallery-pan {
  from {
    transform: scale(1.02) translateY(0);
  }
  to {
    transform: scale(1.12) translateY(-1.4rem);
  }
}

@keyframes heading-drift {
  from {
    opacity: 0.7;
    transform: translateY(0.5rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes cta-lift {
  from {
    opacity: 0.85;
    transform: scale(0.98);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

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

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

  body::before {
    display: none;
  }
}
