* {
  box-sizing: border-box;
}

@media (prefers-reduced-motion: reduce) {
  * {
  transition-duration: 0.01ms;
  }
}

html {
  scroll-behavior: smooth;
  overflow-x: clip;
}

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

body {
  margin: 0px;
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--color-ink);
  background: var(--color-cream);
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

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

h1, h2, h3, h4 {
  font-family: var(--font-display);
  line-height: 1.08;
  margin: 0px 0px 0.5em;
}

p {
  margin: 0px 0px 1em;
}

a {
  color: var(--color-cobalt);
}

.skip-link {
  position: absolute;
  left: -999px;
  top: 0px;
  background: var(--color-cobalt);
  color: var(--color-cream);
  padding: 10px 20px;
  border-top-left-radius: 0px;
  border-top-right-radius: 0px;
  border-bottom-right-radius: 16px;
  border-bottom-left-radius: 0px;
  z-index: 200;
}

.skip-link:focus {
  left: 0px;
}

.container {
  width: min(1180px, 92vw);
  margin-inline-start: auto;
  margin-inline-end: auto;
}

.section {
  padding: clamp(64px, 9vw, 120px) 0px;
  position: relative;
}

.section--tight {
  padding: clamp(40px, 6vw, 72px) 0px;
}

.bg-cream {
  background: var(--color-cream);
}

.bg-mint {
  background: var(--color-mint);
}

.bg-lilac {
  background: var(--color-lilac);
}

.bg-coral {
  background: var(--color-coral);
}

.bg-blush {
  background: var(--color-blush);
}

.bg-navy {
  background: var(--color-navy);
  color: var(--color-cream);
}

.bg-teal-dark {
  background: var(--color-teal-dark);
  color: var(--color-cream);
}

.bg-bordeaux {
  background: var(--color-bordeaux);
  color: var(--color-cream);
}

.paper-grid {
  background-image: linear-gradient(rgba(30, 30, 36, 0.043) 1px, transparent 1px), linear-gradient(90deg, rgba(30, 30, 36, 0.043) 1px, transparent 1px);
  background-size: 34px 34px;
}

.display {
  font-weight: 900;
  font-size: clamp(2.6rem, 6.5vw, 5.2rem);
  letter-spacing: -0.01em;
}

@media (max-width: 600px) {
  .display {
  font-size: clamp(2.2rem, 11vw, 3rem);
  }
}

.title-lg {
  font-weight: 800;
  font-size: clamp(2rem, 4.4vw, 3.2rem);
}

.title-md {
  font-weight: 700;
  font-size: clamp(1.4rem, 2.6vw, 1.9rem);
}

.accent-script {
  font-family: var(--font-script);
  font-weight: 700;
  font-size: 1.15em;
  line-height: 1;
  padding-right: 0.14em;
}

.accent-italic {
  font-style: italic;
  font-weight: 600;
}

.eyebrow {
  font-family: var(--font-body);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.8rem;
  margin-bottom: 14px;
}

.text-pink {
  color: var(--color-pink);
}

.text-deep {
  color: var(--color-pink-deep);
}

.text-cobalt {
  color: var(--color-cobalt);
}

.text-purple {
  color: var(--color-purple);
}

.text-gold {
  color: var(--color-gold);
}

.text-cream {
  color: var(--color-cream);
}

.text-teal {
  color: var(--color-teal);
}

.lead {
  font-size: 1.15rem;
  max-width: 56ch;
}

.script-note {
  font-family: var(--font-script);
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.15;
  display: inline-block;
}

.btn {
  display: inline-block;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: 0.03em;
  padding: 14px 30px;
  border-top-left-radius: 999px;
  border-top-right-radius: 999px;
  border-bottom-right-radius: 999px;
  border-bottom-left-radius: 999px;
  border-top-width: 2px;
  border-right-width: 2px;
  border-bottom-width: 2px;
  border-left-width: 2px;
  border-top-style: solid;
  border-right-style: solid;
  border-bottom-style: solid;
  border-left-style: solid;
  border-top-color: transparent;
  border-right-color: transparent;
  border-bottom-color: transparent;
  border-left-color: transparent;
  border-image-source: initial;
  border-image-slice: initial;
  border-image-width: initial;
  border-image-outset: initial;
  border-image-repeat: initial;
  background: var(--color-cobalt);
  color: var(--color-cream);
  text-decoration-line: none;
  text-decoration-thickness: initial;
  text-decoration-style: initial;
  text-decoration-color: initial;
  cursor: pointer;
  transition-behavior: normal, normal, normal, normal, normal;
  transition-duration: 0.25s, 0.25s, 0.25s, 0.25s, 0.25s;
  transition-timing-function: cubic-bezier(0.34, 1.56, 0.64, 1), ease, ease, ease, ease;
  transition-delay: 0s, 0s, 0s, 0s, 0s;
  transition-property: transform, background, color, border-color, box-shadow;
  will-change: transform;
}

.btn:hover, .btn:focus-visible {
  transform: scale(1.04) rotate(-0.5deg);
  background-image: initial;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: rgb(31, 56, 168);
  box-shadow: rgba(43, 75, 216, 0.28) 0px 10px 24px;
}

.btn--pink {
  background: var(--color-pink-deep);
}

.btn--pink:hover, .btn--pink:focus-visible {
  background-image: initial;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: rgb(209, 69, 136);
  box-shadow: rgba(232, 93, 158, 0.32) 0px 10px 24px;
}

.btn--ghost {
  background-image: initial;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: transparent;
  border-color: var(--color-ink);
  color: var(--color-ink);
}

.btn--ghost:hover, .btn--ghost:focus-visible {
  background: var(--color-ink);
  color: var(--color-cream);
  box-shadow: rgba(30, 30, 36, 0.22) 0px 10px 24px;
}

.btn--gold {
  background-image: initial;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: transparent;
  border-color: var(--color-gold);
  color: var(--color-gold);
}

.btn--gold:hover, .btn--gold:focus-visible {
  background: var(--color-gold);
  color: var(--color-navy);
  box-shadow: rgba(201, 162, 75, 0.3) 0px 10px 24px;
}

.btn--cream {
  background: var(--color-cream);
  color: var(--color-cobalt);
}

.btn--cream:hover, .btn--cream:focus-visible {
  background: var(--color-paper);
  color: var(--color-cobalt);
  box-shadow: rgba(30, 30, 36, 0.18) 0px 10px 24px;
}

.btn--sm {
  padding: 10px 22px;
  font-size: 0.85rem;
}

.badge {
  display: inline-block;
  font-weight: 600;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 6px 14px;
  border-top-left-radius: 999px;
  border-top-right-radius: 999px;
  border-bottom-right-radius: 999px;
  border-bottom-left-radius: 999px;
  background: var(--color-teal);
  color: var(--color-paper);
}

.badge--pink {
  background: var(--color-pink-deep);
}

.badge--cobalt {
  background: var(--color-cobalt);
}

.badge--orange {
  background: var(--color-orange);
}

.badge--purple {
  background: var(--color-purple);
}

.badge--gold {
  background: var(--color-gold);
  color: var(--color-navy);
}

.chip {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.85rem;
  padding: 10px 22px;
  border-top-left-radius: 999px;
  border-top-right-radius: 999px;
  border-bottom-right-radius: 999px;
  border-bottom-left-radius: 999px;
  border: 2px solid var(--color-ink);
  background-image: initial;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: transparent;
  color: var(--color-ink);
  cursor: pointer;
  transition-behavior: normal, normal, normal;
  transition-duration: 0.2s, 0.2s, 0.2s;
  transition-timing-function: cubic-bezier(0.34, 1.56, 0.64, 1), ease, ease;
  transition-delay: 0s, 0s, 0s;
  transition-property: transform, background, color;
}

.chip:hover {
  transform: translateY(-2px) rotate(-1deg);
}

.chip.is-active {
  background: var(--color-cobalt);
  border-color: var(--color-cobalt);
  color: var(--color-cream);
}

.filter-bar {
  display: flex;
  flex-wrap: wrap;
  row-gap: 12px;
  column-gap: 12px;
  margin: 28px 0px 40px;
}

.card {
  background: var(--color-paper);
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 20px;
  border-bottom-left-radius: 20px;
  box-shadow: rgba(30, 30, 36, 0.08) 0px 8px 24px;
  overflow-x: hidden;
  overflow-y: hidden;
  transition-behavior: normal, normal;
  transition-duration: 0.35s, 0.35s;
  transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1), ease;
  transition-delay: 0s, 0s;
  transition-property: transform, box-shadow;
}

.card:hover {
  transform: translateY(-6px);
  box-shadow: rgba(30, 30, 36, 0.14) 0px 18px 40px;
}

.site-nav {
  position: sticky;
  top: 0px;
  z-index: 100;
  background-image: initial;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: rgba(250, 244, 234, 0.92);
  backdrop-filter: blur(10px);
  transition-behavior: normal;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  transition-property: box-shadow;
}

.site-nav.is-scrolled {
  box-shadow: rgba(30, 30, 36, 0.1) 0px 6px 24px;
}

.site-nav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  row-gap: 20px;
  column-gap: 20px;
  padding-block-start: 14px;
  padding-block-end: 14px;
}

.nav-logo {
  display: flex;
  align-items: center;
  row-gap: 12px;
  column-gap: 12px;
  text-decoration-line: none;
  text-decoration-thickness: initial;
  text-decoration-style: initial;
  text-decoration-color: initial;
  color: var(--color-ink);
}

.nav-logo svg {
  transition-behavior: normal;
  transition-duration: 0.6s;
  transition-timing-function: cubic-bezier(0.34, 1.56, 0.64, 1);
  transition-delay: 0s;
  transition-property: transform;
}

.nav-logo:hover svg {
  transform: rotate(90deg);
}

.nav-logo-word {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.15rem;
  letter-spacing: 0.01em;
  line-height: 1.05;
}

.nav-logo-word em {
  font-style: italic;
  color: var(--color-pink-deep);
}

.nav-links {
  display: flex;
  align-items: center;
  row-gap: 6px;
  column-gap: 6px;
  list-style-position: initial;
  list-style-image: initial;
  list-style-type: none;
  margin: 0px;
  padding: 0px;
}

@media (max-width: 860px) {
  .nav-links {
  position: absolute;
  top: 100%;
  left: 0px;
  right: 0px;
  flex-direction: column;
  align-items: stretch;
  background: var(--color-cream);
  padding: 16px 4vw 24px;
  box-shadow: rgba(30, 30, 36, 0.15) 0px 24px 40px;
  display: none;
  }
}

.nav-links a:not(.btn) {
  display: inline-block;
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--color-ink);
  text-decoration-line: none;
  text-decoration-thickness: initial;
  text-decoration-style: initial;
  text-decoration-color: initial;
  padding: 8px 16px;
  border-top-left-radius: 999px;
  border-top-right-radius: 999px;
  border-bottom-right-radius: 999px;
  border-bottom-left-radius: 999px;
  position: relative;
  transition-behavior: normal, normal;
  transition-duration: 0.25s, 0.25s;
  transition-timing-function: ease, ease;
  transition-delay: 0s, 0s;
  transition-property: background, color;
}

@media (max-width: 860px) {
  .nav-links a:not(.btn) {
  padding: 12px 18px;
  }
}

.nav-links a:not(.btn):hover {
  background: var(--color-blush);
  color: var(--color-pink-deep);
}

.nav-links a:not(.btn).is-current {
  background: var(--color-cobalt);
  color: var(--color-cream);
}

.nav-links .btn {
  margin-left: 10px;
}

@media (max-width: 860px) {
  .nav-links .btn {
  margin: 8px 0px 0px;
  text-align: center;
  }
}

.nav-toggle {
  display: none;
  background-image: none;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: initial;
  border: 2px solid var(--color-ink);
  border-top-left-radius: 999px;
  border-top-right-radius: 999px;
  border-bottom-right-radius: 999px;
  border-bottom-left-radius: 999px;
  padding: 8px 16px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
  color: var(--color-ink);
}

@media (max-width: 860px) {
  .nav-toggle {
  display: block;
  }
}

.marquee {
  overflow-x: hidden;
  overflow-y: hidden;
  background: var(--color-cobalt);
  color: var(--color-cream);
  padding: 14px 0px;
  transform: rotate(-1deg) scale(1.02);
}

.marquee--straight {
  transform: none;
}

.marquee__track {
  display: flex;
  row-gap: 48px;
  column-gap: 48px;
  width: max-content;
  animation-duration: 28s;
  animation-timing-function: linear;
  animation-delay: 0s;
  animation-iteration-count: infinite;
  animation-direction: normal;
  animation-fill-mode: none;
  animation-play-state: running;
  animation-name: marquee;
  animation-timeline: auto;
  animation-range-start: normal;
  animation-range-end: normal;
}

.marquee:hover .marquee__track {
  animation-play-state: paused;
}

.marquee__track span {
  font-family: var(--font-display);
  font-weight: 700;
  font-style: italic;
  font-size: 1.05rem;
  letter-spacing: 0.04em;
  white-space-collapse: collapse;
  text-wrap-mode: nowrap;
  display: flex;
  align-items: center;
  row-gap: 48px;
  column-gap: 48px;
}

.marquee__track img {
  width: 18px;
  height: 18px;
}

@keyframes marquee {
  0% {
    transform: translateX(0px);
  }
  100% {
    transform: translateX(-50%);
  }
}

.hero {
  position: relative;
  padding: clamp(56px, 8vw, 110px) 0px clamp(72px, 9vw, 130px);
  overflow-x: hidden;
  overflow-y: hidden;
}

.hero::before {
  content: "";
  position: absolute;
  top: -140px;
  right: -160px;
  width: 480px;
  height: 480px;
  border-top-left-radius: 50%;
  border-top-right-radius: 50%;
  border-bottom-right-radius: 50%;
  border-bottom-left-radius: 50%;
  background-image: radial-gradient(circle, rgba(205, 185, 232, 0.55), transparent 68%);
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: initial;
  pointer-events: none;
}

.hero::after {
  content: "";
  position: absolute;
  bottom: -180px;
  left: -140px;
  width: 520px;
  height: 520px;
  border-top-left-radius: 50%;
  border-top-right-radius: 50%;
  border-bottom-right-radius: 50%;
  border-bottom-left-radius: 50%;
  background-image: radial-gradient(circle, rgba(216, 237, 228, 0.8), transparent 68%);
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: initial;
  pointer-events: none;
}

.hero .container {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  row-gap: clamp(32px, 5vw, 72px);
  column-gap: clamp(32px, 5vw, 72px);
  align-items: center;
}

.hero-copy {
  position: relative;
  z-index: 2;
}

.hero-title {
  margin-bottom: 24px;
}

.hero-title .accent-script {
  color: var(--color-pink-deep);
  display: inline-block;
  transform: rotate(-3deg);
}

.hero-ctas {
  display: flex;
  flex-wrap: wrap;
  row-gap: 14px;
  column-gap: 14px;
  margin-top: 32px;
}

.book-fan {
  position: relative;
  height: clamp(340px, 40vw, 520px);
}

@media (max-width: 860px) {
  .book-fan {
  height: 300px;
  margin-top: 12px;
  }
}

.book-fan a {
  position: absolute;
  top: 50%;
  left: 50%;
  width: clamp(150px, 16vw, 220px);
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
  border-bottom-left-radius: 8px;
  overflow-x: hidden;
  overflow-y: hidden;
  box-shadow: rgba(30, 30, 36, 0.28) 0px 24px 48px;
  transition-behavior: normal, normal;
  transition-duration: 0.45s, 0.45s;
  transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1), ease;
  transition-delay: 0s, 0s;
  transition-property: transform, box-shadow;
}

.book-fan a img {
  width: 100%;
  height: auto;
}

.book-fan a:nth-child(1) {
  transform: translate(-88%, -52%) rotate(-9deg);
  z-index: 1;
}

.book-fan a:nth-child(2) {
  transform: translate(-50%, -46%) rotate(1deg);
  z-index: 2;
}

.book-fan a:nth-child(3) {
  transform: translate(-12%, -54%) rotate(10deg);
  z-index: 3;
}

.book-fan a:hover {
  z-index: 5;
  box-shadow: rgba(30, 30, 36, 0.36) 0px 32px 64px;
}

.book-fan a:nth-child(1):hover {
  transform: translate(-88%, -58%) rotate(-6deg) scale(1.05);
}

.book-fan a:nth-child(2):hover {
  transform: translate(-50%, -52%) rotate(0deg) scale(1.05);
}

.book-fan a:nth-child(3):hover {
  transform: translate(-12%, -60%) rotate(7deg) scale(1.05);
}

.rot-badge {
  position: absolute;
  right: clamp(-10px, 1vw, 30px);
  bottom: -20px;
  width: 130px;
  height: 130px;
  z-index: 4;
  pointer-events: none;
}

@media (max-width: 600px) {
  .rot-badge {
  width: 100px;
  height: 100px;
  }
}

.rot-badge svg {
  animation-duration: 22s;
  animation-timing-function: linear;
  animation-delay: 0s;
  animation-iteration-count: infinite;
  animation-direction: normal;
  animation-fill-mode: none;
  animation-play-state: running;
  animation-name: spin;
  animation-timeline: auto;
  animation-range-start: normal;
  animation-range-end: normal;
}

@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}

.sticker {
  position: absolute;
  pointer-events: none;
  z-index: 1;
}

.sticker img {
  width: 100%;
  height: 100%;
}

.floaty {
  animation-duration: 6s;
  animation-timing-function: ease-in-out;
  animation-delay: 0s;
  animation-iteration-count: infinite;
  animation-direction: normal;
  animation-fill-mode: none;
  animation-play-state: running;
  animation-name: floaty;
  animation-timeline: auto;
  animation-range-start: normal;
  animation-range-end: normal;
}

.floaty--slow {
  animation-duration: 9s;
  animation-timing-function: ease-in-out;
  animation-delay: 0s;
  animation-iteration-count: infinite;
  animation-direction: normal;
  animation-fill-mode: none;
  animation-play-state: running;
  animation-name: floaty;
  animation-timeline: auto;
  animation-range-start: normal;
  animation-range-end: normal;
}

.floaty--rev {
  animation-duration: 7s;
  animation-timing-function: ease-in-out;
  animation-delay: 0s;
  animation-iteration-count: infinite;
  animation-direction: normal;
  animation-fill-mode: none;
  animation-play-state: running;
  animation-name: floaty-rev;
  animation-timeline: auto;
  animation-range-start: normal;
  animation-range-end: normal;
}

@keyframes floaty {
  0%, 100% {
    transform: translateY(0px) rotate(-4deg);
  }
  50% {
    transform: translateY(-14px) rotate(4deg);
  }
}

@keyframes floaty-rev {
  0%, 100% {
    transform: translateY(-10px) rotate(5deg);
  }
  50% {
    transform: translateY(4px) rotate(-3deg);
  }
}

.twinkle {
  animation-duration: 3.2s;
  animation-timing-function: ease-in-out;
  animation-delay: 0s;
  animation-iteration-count: infinite;
  animation-direction: normal;
  animation-fill-mode: none;
  animation-play-state: running;
  animation-name: twinkle;
  animation-timeline: auto;
  animation-range-start: normal;
  animation-range-end: normal;
}

.twinkle--d1 {
  animation-delay: 0.8s;
}

.twinkle--d2 {
  animation-delay: 1.6s;
}

@keyframes twinkle {
  0%, 100% {
    opacity: 1;
    transform: scale(1) rotate(0deg);
  }
  50% {
    opacity: 0.35;
    transform: scale(0.7) rotate(18deg);
  }
}

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition-behavior: normal, normal;
  transition-duration: 0.7s, 0.7s;
  transition-timing-function: ease, cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--d, 0s);
  transition-property: opacity, transform;
}

@media (prefers-reduced-motion: reduce) {
  .reveal {
  opacity: 1;
  transform: none;
  transition-behavior: normal;
  transition-duration: 0s;
  transition-timing-function: ease;
  transition-delay: 0s;
  transition-property: none;
  }
}

.reveal.in-view {
  opacity: 1;
  transform: none;
}

.reveal--pop {
  transform: scale(0.85);
}

.reveal--pop.in-view {
  transform: scale(1);
}

.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  row-gap: 24px;
  column-gap: 24px;
  flex-wrap: wrap;
  margin-bottom: clamp(32px, 4vw, 52px);
}

.section-head h2 {
  margin-bottom: 0px;
}

.spotlight {
  position: relative;
  overflow-x: hidden;
  overflow-y: hidden;
}

.spotlight .container {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  row-gap: clamp(36px, 6vw, 80px);
  column-gap: clamp(36px, 6vw, 80px);
  align-items: center;
  position: relative;
  z-index: 2;
}

.spotlight-cover {
  position: relative;
  width: min(320px, 70%);
  margin-inline-start: auto;
  margin-inline-end: auto;
}

.spotlight-cover img {
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
  box-shadow: rgba(0, 0, 0, 0.45) 0px 30px 60px;
  transition-behavior: normal;
  transition-duration: 0.5s;
  transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0s;
  transition-property: transform;
}

.spotlight-cover:hover img {
  transform: translateY(-10px) rotate(-1.5deg);
}

.spotlight-cover::after {
  content: "";
  position: absolute;
  top: auto;
  right: 8%;
  bottom: -26px;
  left: 8%;
  height: 30px;
  background-image: radial-gradient(rgba(0, 0, 0, 0.4), transparent 70%);
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: initial;
}

.spotlight h2 {
  color: var(--color-cream);
}

.spotlight .eyebrow {
  color: var(--color-gold);
}

.annotation {
  display: flex;
  align-items: flex-start;
  row-gap: 12px;
  column-gap: 12px;
  margin: 18px 0px;
  padding: 14px 20px;
  border-top-width: 1px;
  border-right-width: 1px;
  border-bottom-width: 1px;
  border-left-width: 1px;
  border-top-style: solid;
  border-right-style: solid;
  border-bottom-style: solid;
  border-left-style: solid;
  border-top-color: rgba(201, 162, 75, 0.45);
  border-right-color: rgba(201, 162, 75, 0.45);
  border-bottom-color: rgba(201, 162, 75, 0.45);
  border-left-color: rgba(201, 162, 75, 0.45);
  border-image-source: initial;
  border-image-slice: initial;
  border-image-width: initial;
  border-image-outset: initial;
  border-image-repeat: initial;
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
  border-bottom-right-radius: 16px;
  border-bottom-left-radius: 16px;
  background-image: initial;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: rgba(250, 244, 234, 0.05);
  transition-behavior: normal, normal, normal;
  transition-duration: 0.3s, 0.3s, 0.3s;
  transition-timing-function: ease, ease, ease;
  transition-delay: 0s, 0s, 0s;
  transition-property: background, border-color, transform;
}

.annotation:hover {
  background-image: initial;
  background-position-x: initial;
  background-position-y: initial;
  background-size: initial;
  background-repeat: initial;
  background-attachment: initial;
  background-origin: initial;
  background-clip: initial;
  background-color: rgba(250, 244, 234, 0.1);
  border-color: var(--color-gold);
  transform: translateX(6px);
}

.annotation img {
  width: 26px;
  height: 26px;
  flex-shrink: 0;
  margin-top: 3px;
}

.annotation p {
  margin: 0px;
  font-size: 0.98rem;
}

.annotation .accent-script {
  color: var(--color-gold);
  font-size: 1.25rem;
  display: block;
}

.gold-line {
  width: 72px;
  height: 2px;
  background: linear-gradient(90deg, var(--color-gold), transparent);
  border-top-width: medium;
  border-right-width: medium;
  border-bottom-width: medium;
  border-left-width: medium;
  border-top-style: none;
  border-right-style: none;
  border-bottom-style: none;
  border-left-style: none;
  border-top-color: currentcolor;
  border-right-color: currentcolor;
  border-bottom-color: currentcolor;
  border-left-color: currentcolor;
  border-image-source: initial;
  border-image-slice: initial;
  border-image-width: initial;
  border-image-outset: initial;
  border-image-repeat: initial;
  margin: 20px 0px;
}

.quote-block {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(1.5rem, 3.2vw, 2.4rem);
  line-height: 1.3;
  max-width: 24ch;
  margin: 0px auto;
  text-align: center;
}

.quote-block cite {
  display: block;
  font-family: var(--font-body);
  font-style: normal;
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 24px;
}

.news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  row-gap: clamp(20px, 2.6vw, 32px);
  column-gap: clamp(20px, 2.6vw, 32px);
}

@media (max-width: 860px) {
  .news-grid {
  grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 600px) {
  .news-grid {
  grid-template-columns: 1fr;
  }
}

.news-card {
  display: flex;
  flex-direction: column;
  text-decoration-line: none;
  text-decoration-thickness: initial;
  text-decoration-style: initial;
  text-decoration-color: initial;
  color: var(--color-ink);
  position: relative;
}

.news-card.is-hidden {
  display: none;
}

.news-card-visual {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow-x: hidden;
  overflow-y: hidden;
}

.news-card-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition-behavior: normal;
  transition-duration: 0.6s;
  transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0s;
  transition-property: transform;
}

.news-card:hover .news-card-visual img {
  transform: scale(1.06) rotate(0.5deg);
}

.news-card-visual .badge {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
}

.news-card-visual--book {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--vis-bg, var(--color-blush));
}

.news-card-visual--book img {
  height: 84%;
  width: auto;
  object-fit: contain;
  border-top-left-radius: 4px;
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
  border-bottom-left-radius: 4px;
  box-shadow: rgba(30, 30, 36, 0.3) 0px 14px 28px;
  transform: rotate(-2.5deg);
}

.news-card:hover .news-card-visual--book img, .news-card--featured:hover .news-card-visual--book img {
  transform: rotate(0deg) scale(1.05);
}

.news-card-body {
  padding: 22px 24px 26px;
  display: flex;
  flex-direction: column;
  row-gap: 8px;
  column-gap: 8px;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 0%;
}

.news-date {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-pink-deep);
}

.news-card h3 {
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0px;
  transition-behavior: normal;
  transition-duration: 0.25s;
  transition-timing-function: ease;
  transition-delay: 0s;
  transition-property: color;
}

.news-card:hover h3 {
  color: var(--color-cobalt);
}

.news-card p {
  margin: 0px;
  font-size: 0.95rem;
  color: rgba(30, 30, 36, 0.75);
}

.read-more {
  margin-top: auto;
  padding-top: 12px;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-cobalt);
  display: inline-flex;
  align-items: center;
  row-gap: 8px;
  column-gap: 8px;
}

.read-more::after {
  content: "→";
  transition-behavior: normal;
  transition-duration: 0.25s;
  transition-timing-function: cubic-bezier(0.34, 1.56, 0.64, 1);
  transition-delay: 0s;
  transition-property: transform;
}

.news-card:hover .read-more::after {
  transform: translateX(6px);
}

.news-card--featured {
  grid-column-start: span 2;
  grid-column-end: auto;
}

@media (max-width: 860px) {
  .news-card--featured {
  grid-column-start: span 2;
  grid-column-end: auto;
  }
}

@media (max-width: 600px) {
  .news-card--featured {
  grid-column-start: span 1;
  grid-column-end: auto;
  }
}

.news-card--featured .news-card-visual {
  aspect-ratio: 16 / 8;
}

.news-card--featured h3 {
  font-size: 1.7rem;
}

.book-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  row-gap: clamp(20px, 2.6vw, 30px);
  column-gap: clamp(20px, 2.6vw, 30px);
}

@media (max-width: 1024px) {
  .book-grid {
  grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 600px) {
  .book-grid {
  grid-template-columns: repeat(2, 1fr);
  }
}

.book-card {
  --accent: var(--color-cobalt);
  background: var(--color-paper);
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 20px;
  border-bottom-left-radius: 20px;
  box-shadow: rgba(30, 30, 36, 0.08) 0px 8px 24px;
  padding: 18px 18px 22px;
  display: flex;
  flex-direction: column;
  row-gap: 12px;
  column-gap: 12px;
  position: relative;
  transition-behavior: normal, normal;
  transition-duration: 0.35s, 0.35s;
  transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1), ease;
  transition-delay: 0s, 0s;
  transition-property: transform, box-shadow;
}

.book-card:hover {
  transform: translateY(-8px);
  box-shadow: rgba(30, 30, 36, 0.16) 0px 22px 44px;
}

.book-card.is-hidden {
  display: none;
}

.book-card::before {
  content: "";
  position: absolute;
  top: 0px;
  right: 0px;
  bottom: auto;
  left: 0px;
  height: 8px;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 0px;
  border-bottom-left-radius: 0px;
  background: var(--accent);
}

.book-cover {
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
  overflow-x: hidden;
  overflow-y: hidden;
  aspect-ratio: 2 / 3;
  background: var(--color-mint);
  transform: rotate(0deg);
  transition-behavior: normal;
  transition-duration: 0.4s;
  transition-timing-function: cubic-bezier(0.34, 1.56, 0.64, 1);
  transition-delay: 0s;
  transition-property: transform;
  box-shadow: rgba(30, 30, 36, 0.18) 0px 10px 22px;
}

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

.book-card:hover .book-cover, .shelf-item:hover .book-cover {
  transform: rotate(-2deg) scale(1.03);
}

.shelf-item {
  display: flex;
  flex-direction: column;
  row-gap: 12px;
  column-gap: 12px;
  text-decoration-line: none;
  text-decoration-thickness: initial;
  text-decoration-style: initial;
  text-decoration-color: initial;
  color: var(--color-ink);
}

.shelf-item strong {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.25;
}

.shelf-item small {
  color: rgba(30, 30, 36, 0.6);
  margin-top: -8px;
}

.book-card h3 {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 4px 0px 0px;
}

.book-author {
  font-size: 0.88rem;
  color: rgba(30, 30, 36, 0.65);
  margin: 0px;
}

.book-tags {
  display: flex;
  flex-wrap: wrap;
  row-gap: 6px;
  column-gap: 6px;
}

.book-tags .badge {
  font-size: 0.62rem;
  padding: 4px 10px;
}

.book-card .btn {
  margin-top: auto;
  text-align: center;
}

.shelf {
  display: flex;
  row-gap: clamp(18px, 2.4vw, 28px);
  column-gap: clamp(18px, 2.4vw, 28px);
  overflow-x: auto;
  padding: 20px 4px 36px;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: var(--color-pink) transparent;
}

.shelf > * {
  scroll-snap-align: start;
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: clamp(180px, 20vw, 240px);
}

.newsletter {
  position: relative;
  overflow-x: hidden;
  overflow-y: hidden;
}

.newsletter .container {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  row-gap: clamp(32px, 5vw, 72px);
  column-gap: clamp(32px, 5vw, 72px);
  align-items: center;
}

.newsletter h2 {
  color: var(--color-cream);
}

.newsletter-photo {
  border-top-left-radius: 24px;
  border-top-right-radius: 24px;
  border-bottom-right-radius: 24px;
  border-bottom-left-radius: 24px;
  overflow-x: hidden;
  overflow-y: hidden;
  box-shadow: rgba(30, 30, 36, 0.25) 0px 24px 48px;
  transform: rotate(2deg);
  transition-behavior: normal;
  transition-duration: 0.5s;
  transition-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0s;
  transition-property: transform;
}

.newsletter-photo:hover {
  transform: rotate(0deg) scale(1.02);
}

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

.newsletter-form {
  display: flex;
  flex-wrap: wrap;
  row-gap: 12px;
  column-gap: 12px;
  margin-top: 28px;
}

.newsletter-form input[type="email"] {
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: 240px;
  font-family: var(--font-body);
  font-size: 1rem;
  padding: 14px 24px;
  border-top-left-radius: 999px;
  border-top-right-radius: 999px;
  border-bottom-right-radius: 999px;
  border-bottom-left-radius: 999px;
  border-top-width: 2px;
  border-right-width: 2px;
  border-bottom-width: 2px;
  border-left-width: 2px;
  border-top-style: solid;
  border-right-style: solid;
  border-bottom-style: solid;
  border-left-style: solid;
  border-top-color: transparent;
  border-right-color: transparent;
  border-bottom-color: transparent;
  border-left-color: transparent;
  border-image-source: initial;
  border-image-slice: initial;
  border-image-width: initial;
  border-image-outset: initial;
  border-image-repeat: initial;
  background: var(--color-cream);
  color: var(--color-ink);
  outline-color: initial;
  outline-style: none;
  outline-width: initial;
  transition-behavior: normal, normal;
  transition-duration: 0.25s, 0.25s;
  transition-timing-function: ease, ease;
  transition-delay: 0s, 0s;
  transition-property: border-color, box-shadow;
}

.newsletter-form input[type="email"]:focus {
  border-color: var(--color-cobalt);
  box-shadow: rgba(43, 75, 216, 0.18) 0px 0px 0px 4px;
}

.photo-caption {
  font-size: 0.8rem;
  opacity: 0.75;
  margin-top: 10px;
}

.article-hero {
  position: relative;
  padding: clamp(56px, 7vw, 96px) 0px clamp(40px, 5vw, 64px);
  overflow-x: hidden;
  overflow-y: hidden;
}

.article-hero .container {
  max-width: 820px;
  position: relative;
  z-index: 2;
}

.article-hero h1 {
  font-size: clamp(2.1rem, 5vw, 3.6rem);
  font-weight: 900;
}

.article-meta {
  display: flex;
  align-items: center;
  row-gap: 16px;
  column-gap: 16px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.article-body {
  max-width: 720px;
  margin-inline-start: auto;
  margin-inline-end: auto;
  font-size: 1.05rem;
}

.article-body h2 {
  font-size: 1.6rem;
  margin-top: 1.6em;
}

.article-body img {
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  border-bottom-right-radius: 20px;
  border-bottom-left-radius: 20px;
  margin: 32px 0px;
}

.article-body .quote-block {
  margin: 48px auto;
}

.article-figure {
  margin: 32px 0px;
}

.article-figure img {
  margin: 0px;
}

.article-figure figcaption {
  font-size: 0.85rem;
  color: rgba(30, 30, 36, 0.6);
  margin-top: 10px;
  text-align: center;
}

.back-link {
  display: inline-flex;
  align-items: center;
  row-gap: 8px;
  column-gap: 8px;
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration-line: none;
  text-decoration-thickness: initial;
  text-decoration-style: initial;
  text-decoration-color: initial;
  color: var(--color-cobalt);
  margin-bottom: 24px;
}

.back-link::before {
  content: "←";
  transition-behavior: normal;
  transition-duration: 0.25s;
  transition-timing-function: ease;
  transition-delay: 0s;
  transition-property: transform;
}

.back-link:hover::before {
  transform: translateX(-5px);
}

.torn-bottom {
  position: relative;
}

.torn-bottom::after {
  content: "";
  position: absolute;
  left: 0px;
  right: 0px;
  bottom: -18px;
  height: 20px;
  background-repeat: repeat-x;
  background-size: 240px 20px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 20'%3E%3Cpath d='M0 0 L14 9 L30 2 L46 12 L62 4 L80 14 L98 3 L114 11 L132 2 L150 13 L166 5 L184 12 L200 3 L218 10 L240 0 L240 0 L0 0 Z' fill='%23FAF4EA'/%3E%3C/svg%3E");
  z-index: 3;
  pointer-events: none;
}

.wavy-bg::before {
  content: "";
  position: absolute;
  top: 0px;
  right: 0px;
  bottom: 0px;
  left: 0px;
  opacity: 0.5;
  background-repeat: repeat;
  background-size: 90px 260px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 90 260'%3E%3Cpath d='M22 0 C34 40 10 62 22 104 C34 146 10 168 22 210 C30 238 20 250 22 260' stroke='rgba(30,30,36,0.06)' stroke-width='16' fill='none'/%3E%3Cpath d='M68 0 C80 40 56 62 68 104 C80 146 56 168 68 210 C76 238 66 250 68 260' stroke='rgba(30,30,36,0.06)' stroke-width='16' fill='none'/%3E%3C/svg%3E");
  pointer-events: none;
}

.night-sky::before {
  content: "";
  position: absolute;
  top: 0px;
  right: 0px;
  bottom: 0px;
  left: 0px;
  opacity: 0.5;
  background-repeat: repeat;
  background-size: 340px 340px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 340 340'%3E%3Cg fill='%23C9A24B'%3E%3Ccircle cx='30' cy='40' r='1.6'/%3E%3Ccircle cx='120' cy='90' r='1.1'/%3E%3Ccircle cx='210' cy='30' r='1.4'/%3E%3Ccircle cx='300' cy='120' r='1.2'/%3E%3Ccircle cx='70' cy='200' r='1.3'/%3E%3Ccircle cx='180' cy='250' r='1.6'/%3E%3Ccircle cx='280' cy='300' r='1.1'/%3E%3Ccircle cx='40' cy='310' r='1.2'/%3E%3Cpath d='M250 170 l2.4 6 6 2.4 -6 2.4 -2.4 6 -2.4 -6 -6 -2.4 6 -2.4 Z'/%3E%3Cpath d='M100 140 l1.8 4.5 4.5 1.8 -4.5 1.8 -1.8 4.5 -1.8 -4.5 -4.5 -1.8 4.5 -1.8 Z'/%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}

.site-footer {
  background: var(--color-navy);
  color: var(--color-cream);
  padding: clamp(48px, 6vw, 80px) 0px 32px;
  position: relative;
  overflow-x: hidden;
  overflow-y: hidden;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  row-gap: clamp(28px, 4vw, 60px);
  column-gap: clamp(28px, 4vw, 60px);
  margin-bottom: 48px;
}

@media (max-width: 1024px) {
  .footer-grid {
  grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 600px) {
  .footer-grid {
  grid-template-columns: 1fr;
  }
}

.site-footer h4 {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-gold);
  margin-bottom: 16px;
}

.site-footer ul {
  list-style-position: initial;
  list-style-image: initial;
  list-style-type: none;
  margin: 0px;
  padding: 0px;
}

.site-footer li {
  margin-bottom: 10px;
}

.site-footer a {
  color: var(--color-cream);
  text-decoration-line: none;
  text-decoration-thickness: initial;
  text-decoration-style: initial;
  text-decoration-color: initial;
  transition-behavior: normal;
  transition-duration: 0.2s;
  transition-timing-function: ease;
  transition-delay: 0s;
  transition-property: color;
}

.site-footer a:hover {
  color: var(--color-pink);
}

.footer-brand p {
  max-width: 34ch;
  font-size: 0.95rem;
  opacity: 0.85;
}

.footer-bottom {
  border-top-width: 1px;
  border-top-style: solid;
  border-top-color: rgba(250, 244, 234, 0.15);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  row-gap: 16px;
  column-gap: 16px;
  flex-wrap: wrap;
  font-size: 0.85rem;
  opacity: 0.8;
}

.tilt {
  transform: perspective(700px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg));
  transition-behavior: normal;
  transition-duration: 0.2s;
  transition-timing-function: ease-out;
  transition-delay: 0s;
  transition-property: transform;
}

@media (prefers-reduced-motion: reduce) {
  .tilt {
  transform: none;
  }
}

.empty-note {
  display: none;
  text-align: center;
  padding: 48px 0px;
}

.empty-note.is-visible {
  display: block;
}

.empty-note img {
  width: 64px;
  margin: 0px auto 16px;
}

@media (prefers-reduced-motion: reduce) {
  .marquee__track, .floaty, .floaty--slow, .floaty--rev, .twinkle, .twinkle--d1, .twinkle--d2, .rot-badge svg {
  animation-duration: auto;
  animation-timing-function: ease;
  animation-delay: 0s;
  animation-iteration-count: 1;
  animation-direction: normal;
  animation-fill-mode: none;
  animation-play-state: running;
  animation-name: none;
  animation-timeline: auto;
  animation-range-start: normal;
  animation-range-end: normal;
  }
}

@media (max-width: 860px) {
  .hero .container, .spotlight .container, .newsletter .container {
  grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  .nav-links.is-open {
  display: flex;
  }
}