@font-face {
  font-family: "PPNikkeiMaru";
  src: url("../fonts/PPNikkeiMaru-Ultrabold.otf") format("opentype");
  font-display: swap;
}

@font-face {
  font-family: "PPRadioGrotesk";
  src: url("../fonts/PPRadioGrotesk-Regular.otf") format("opentype");
  font-display: swap;
}

@font-face {
  font-family: "PPFrama";
  src: url("../fonts/PPFrama-Regular.otf") format("opentype");
  font-display: swap;
}

.site--kent {
  --k-bleu-cyan-light: #acd4e6;
  --k-bleu-cyan-light-oklch: oklch(0.8471 0.049 227.02);
  --k-bleu-cyan-mid: #8ab1ce;
  --k-bleu-cyan-mid-oklch: oklch(0.7422 0.0596 240.76);
  --k-bleu-cyan-dark: #5b6976;
  --k-bleu-cyan-dark-oklch: oklch(0.5138 0.0268 246.36);
  --k-jaune-clair: #faf6b5;
  --k-jaune-clair-oklch: oklch(0.961 0.0828 104.89);
  --k-orange: #e2b270;
  --k-orange-oklch: oklch(0.7929 0.1006 74.32);
  --k-bleu: #757cc1;
  --k-bleu-oklch: oklch(0.6096 0.1047 278.39);
  --k-gris: #ccccca;
  --k-gris-oklch: oklch(0.8446 0.0027 106.46);
  --k-orange-clair-gris: #f6edde;
  --k-orange-clair-gris-oklch: oklch(0.9491 0.0221 80.69);
  --k-rouge-orange-clair-gris: #fae6dd;
  --k-rouge-orange-clair-gris-oklch: oklch(0.9386 0.0251 45.87);
  --k-rose: #e8bbd0;
  --k-rose-oklch: oklch(0.8378 0.0583 348.7);
  --k-jaune-vert: #aebb8e;
  --k-jaune-vert-oklch: oklch(0.7703 0.0632 120.98);
  --k-blue-green: #709382;
  --k-blue-green-oklch: oklch(0.6318 0.0467 163.74);
  --k-vert: #b4da83;
  --k-vert-oklch: oklch(0.8409 0.1206 128);
  --k-blue-green-2: #419362;
  --k-blue-green-2-oklch: oklch(0.5988 0.1103 154.84);
  --k-rouge-bordeaux: #9e655a;
  --k-rouge-bordeaux-oklch: oklch(0.5656 0.0764 31.49);
  --k-rouge-bordeaux-light: #ad867f;
  --k-rouge-bordeaux-light-oklch: oklch(0.6553 0.0493 30.11);
  --k-vert-clair: #d6f7b4;
  --k-vert-clair-oklch: oklch(0.9361 0.094 129.38);
  --k-bleu-light: #8ab1ce;
  --k-bleu-light-oklch: oklch(0.7422 0.0596 240.76);
  --k-bleu-deep: #33759f;
  --k-bleu-deep-oklch: oklch(0.5387 0.0937 239.74);
  --k-magenta: #cc7bbf;
  --k-magenta-oklch: oklch(0.6917 0.1327 332.96);
  --k-rouge: #cc2f2e;
  --k-rouge-oklch: oklch(0.5554 0.1937 26.52);
  --k-blue-green-3: #419361;
  --k-blue-green-3-oklch: oklch(0.5986 0.1113 154.35);
  --k-jaune-orange: #e7d293;
  --k-jaune-orange-oklch: oklch(0.8666 0.0841 91.78);
  --k-vert-clair-2: #d6f7b4;
  --k-vert-clair-2-oklch: oklch(0.9361 0.094 129.38);
  --k-marron: #b86635;
  --k-marron-oklch: oklch(0.5951 0.1228 49.43);
  --k-jaune-vive: #e8cc43;
  --k-jaune-vive-oklch: oklch(0.8454 0.1526 97.31);
  --k-bleu-doux: #a6acdc;
  --k-bleu-doux-oklch: oklch(0.7565 0.0692 279.05);
  --k-rouge-orange: #d3502c;
  --k-rouge-orange-oklch: oklch(0.6015 0.1729 35.96);
  --k-rouge-orange-light: #e19675;
  --k-rouge-orange-light-oklch: oklch(0.7405 0.1018 44.48);

  --logo-color: #d2502c;
  --background: #ffffff;
  --foreground: oklch(14.5% 0 0deg);
  --card: oklch(0.985 0.004 91.446);
  --card-foreground: oklch(29.581% 0.04607 20.154);
  --popover: oklch(100% 0 0deg);
  --popover-foreground: oklch(14.5% 0 0deg);
  --muted-foreground: oklch(55.6% 0 0deg);
  --muted: oklch(97% 0 0deg);
  --border: oklch(92.2% 0 0deg);
  --border-warm: #d9d2c6;
  --primary: oklch(0.54 0.081 246.243);
  --primary-foreground: oklch(98.5% 0 0deg);
  --ink: #252223;
  --ink-light: #3a3839;
  --bg: #fcfaf7;
  --bg-muted: #f0ede9;
  --link: #33759f;
  --link-hover: #33777a;
  --accent-1: var(--logo-color);
  --accent-1-hover: #b8753d;
  --accent-2: #419361;
  --accent-2-hover: #51715e;
  --accent-2-alt: #7f86a1;
  --accent-2-alt-hover: #6b738e;
  --accent-3: #cc7bbf;
  --accent-3-hover: #a87f98;
  --accent-4: #33759f;
  --accent-4-hover: #6b738e;
  --musique: #817fc9;
  --musique-hover: #6f6bc0;
  --dessins: var(--accent-2);
  --dessins-hover: var(--accent-2-hover);
  --dessins-alt: var(--accent-2-alt);
  --dessins-alt-hover: var(--accent-2-alt-hover);
  --ecrits: var(--accent-3);
  --ecrits-hover: var(--accent-3-hover);
  --font-nikkei: "PPNikkeiMaru", sans-serif;
  --font-radio: "PPRadioGrotesk", "Libre Baskerville", Georgia, serif;
  --font-frama: "PPFrama", "PPRadioGrotesk", sans-serif;
  --font-reading: var(--font-radio);
  --font-body: var(--font-reading);
  --font-logo: var(--font-nikkei);
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
}

body {
  min-height: 100vh;
  margin: 0;
  display: flex;
  flex-direction: column;
  background: var(--background);
  color: var(--foreground);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body.has-modal-open {
  overflow: hidden;
}

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

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

.background-layers {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  isolation: isolate;
  background: var(--background);
}

.background-layers::before,
.background-layers::after {
  content: "";
  display: none;
  position: absolute;
  inset: -2rem;
  background-position: center;
  background-size: cover;
  background-repeat: repeat;
}

.background-layers::before {
  background-image: url("../assets/bg_dark.webp");
  opacity: 0.22;
  transform: scale(1.08);
}

.background-layers::after {
  background-image: url("../assets/bg_light.webp");
  opacity: 0.75;
  mix-blend-mode: plus-lighter;
}

.container {
  width: 100%;
  max-width: 86rem;
  margin-inline: auto;
  padding-inline: 1rem;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  transition: background-color 700ms ease, box-shadow 700ms ease, backdrop-filter 700ms ease;
}

.site-header.is-scrolled {
  background: color-mix(in srgb, var(--background) 15%, transparent);
  box-shadow: 0 1px 8px rgb(0 0 0 / 8%);
  backdrop-filter: blur(12px);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 0.5rem;
}

.logo {
  display: inline-block;
  width: 7.5rem;
  aspect-ratio: 1384 / 734;
  background: var(--logo-color);
  mask: url("../assets/Sig.svg") center / contain no-repeat;
  -webkit-mask: url("../assets/Sig.svg") center / contain no-repeat;
}

.site-nav {
  display: none;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  align-items: center;
  gap: 4rem;
  font-family: var(--font-frama);
  font-size: 1.125rem;
}

.site-nav a,
.shop-link,
.mobile-menu a {
  transition: color 180ms ease;
}

.nav-musique:hover {
  color: var(--musique);
}

.nav-dessins:hover {
  color: var(--dessins);
}

.nav-livres:hover {
  color: var(--ecrits);
}

.nav-dates:hover,
.shop-link:hover {
  color: var(--accent-4);
}

.menu-button {
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0.5rem;
  font: inherit;
}

.mobile-menu {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 60;
  background: var(--background);
}

.mobile-menu.is-open {
  display: block;
}

.mobile-menu__inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  padding-block: 2rem;
}

.mobile-menu__close {
  align-self: flex-end;
}

.mobile-menu nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  font-family: var(--font-frama);
  font-size: 1.5rem;
}

.page-layout {
  flex: 1;
  padding-top: 7.5rem;
  padding-bottom: 2rem;
  min-height: calc(100vh - 8rem);
}

.home-hero {
  position: relative;
  min-height: 0;
  margin: 6rem 0 2rem;
  isolation: isolate;
}

.home-hero__image-wrap {
  position: relative;
  width: 100%;
}

.home-hero__image {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: top center;
}

.home-hero__content {
  max-width: 28rem;
  margin: -1rem auto 0;
  padding-inline: 1rem;
  color: color-mix(in srgb, var(--foreground) 80%, transparent);
  text-align: center;
  will-change: opacity;
  transition: opacity 300ms ease;
}

.home-hero__text {
  margin: 0;
  font-size: 1.25rem;
  line-height: 1.55;
}

.home-hero__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-width: 14.5rem;
  margin-top: 2rem;
  padding: 0.5rem 1rem;
  border: 1px solid var(--ink);
  border-radius: 0.125rem;
  color: color-mix(in srgb, var(--foreground) 80%, transparent);
  font-size: 1.125rem;
  transition: background-color 180ms ease;
}

.home-hero__button:hover {
  background: color-mix(in srgb, var(--primary) 20%, transparent);
}

.home-hero__button img {
  width: 2rem;
  height: auto;
}

.page-layout--with-hero {
  position: relative;
  z-index: 10;
}

.section-title {
  display: block;
  width: auto;
  height: 2.5rem;
  margin-bottom: 2rem;
}

.section-title-mask {
  background-color: currentColor;
  mask: var(--section-title-image) left center / contain no-repeat;
  -webkit-mask: var(--section-title-image) left center / contain no-repeat;
}

.section-title--large {
  height: 2.75rem;
}

.section-title--news {
  color: var(--primary);
  height: 2.5rem;
  width: min(100%, 42rem);
  max-width: 100%;
}

.section-title--dates {
  height: 2.5rem;
  width: min(100%, 10.25rem);
  aspect-ratio: 535 / 131;
  color: var(--primary);
}

.section-title--album {
  height: 2.5rem;
  width: min(100%, 20.375rem);
  aspect-ratio: 1198 / 147;
  color: var(--primary);
}

.section-title--musique {
  height: 2.5rem;
  width: min(100%, 10.25rem);
  aspect-ratio: 172 / 42;
  color: var(--musique);
}

.quote {
  max-width: 56rem;
  margin: 0 0 2rem;
  padding-left: 1.25rem;
  border-left: 4px solid color-mix(in srgb, currentColor 55%, transparent);
  color: var(--muted-foreground);
}

.quote blockquote {
  margin: 0;
  white-space: pre-line;
  font-size: 1rem;
  font-style: italic;
  line-height: 1.7;
}

.quote figcaption {
  margin-top: 0.75rem;
  font-size: 0.875rem;
}

.quote--musique {
  border-left-color: color-mix(in srgb, var(--musique) 50%, transparent);
  color: color-mix(in srgb, var(--foreground) 90%, transparent);
}

.quote--musique figcaption {
  color: var(--muted-foreground);
}

.quote--livres {
  border-left-color: color-mix(in srgb, var(--ecrits) 60%, transparent);
  color: color-mix(in srgb, var(--foreground) 90%, transparent);
}

.quote--livres figcaption {
  color: var(--muted-foreground);
}

.quote--dessins {
  border-left-color: color-mix(in srgb, var(--dessins) 60%, transparent);
  color: color-mix(in srgb, var(--foreground) 90%, transparent);
}

.quote--dessins figcaption {
  color: var(--muted-foreground);
}

.quote--about {
  border-left-color: color-mix(in srgb, var(--primary) 70%, transparent);
  color: color-mix(in srgb, var(--foreground) 90%, transparent);
}

.quote--about figcaption {
  color: var(--muted-foreground);
}

.music-section h2 {
  color: var(--musique);
}

.music-album-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.music-album-grid--continued {
  margin-top: 0.75rem;
}

.music-album-grid--continued[hidden] {
  display: none;
}

.music-album-grid .album-card {
  border-color: var(--border);
}

.music-album-grid .album-card .card__body {
  padding: 0.5rem;
}

.music-album-grid .album-card .card__title {
  margin: 0;
  overflow: hidden;
  color: var(--muted-foreground);
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.3;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.music-disclosure {
  margin-top: 1.5rem;
}

.music-disclosure__button {
  display: flex;
  width: max-content;
  align-items: center;
  gap: 0.5rem;
  margin-inline: auto;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--musique);
  cursor: pointer;
  font: inherit;
  list-style: none;
  transition: color 180ms ease;
}

.music-disclosure__button:hover {
  color: var(--musique-hover);
}

.music-disclosure__button[hidden] {
  display: none;
}

.music-disclosure__chevron {
  width: 1.25rem;
  height: 1.25rem;
}

.music-disclosure__button--collapse {
  margin-top: 1.5rem;
}

.music-video-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

.music-video-card {
  display: block;
  cursor: pointer;
}

.music-video-card__media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--border-warm) 55%, transparent);
  transition: box-shadow 180ms ease;
}

.music-video-card:hover .music-video-card__media {
  box-shadow: 0 12px 24px rgb(0 0 0 / 14%);
}

.music-video-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.music-video-card__play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.music-video-card__play svg {
  box-sizing: content-box;
  width: 2rem;
  height: 2rem;
  padding: 1rem;
  border-radius: 999px;
  background: rgb(0 0 0 / 60%);
  color: #fff;
  transition: background-color 180ms ease;
}

.music-video-card:hover .music-video-card__play svg {
  background: rgb(0 0 0 / 72%);
}

.music-video-card h3 {
  margin: 0.75rem 0 0;
  color: var(--foreground);
  font-family: var(--font-body);
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.35;
}

.music-youtube-link {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-top: 2rem;
}

.music-youtube-link img {
  width: 1.5rem;
  height: auto;
}

.music-youtube-link a {
  color: var(--musique);
  text-decoration: underline;
  transition: color 180ms ease;
}

.music-youtube-link a:hover {
  color: var(--musique-hover);
}

.video-modal[hidden] {
  display: none;
}

.video-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.video-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgb(0 0 0 / 72%);
  cursor: pointer;
}

.video-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 64rem);
  background: #000;
  box-shadow: 0 24px 60px rgb(0 0 0 / 45%);
}

.video-modal__close {
  position: absolute;
  top: -2.75rem;
  right: 0;
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid rgb(255 255 255 / 70%);
  border-radius: 999px;
  background: rgb(0 0 0 / 35%);
  color: #fff;
  cursor: pointer;
  font-size: 1.75rem;
  line-height: 1;
}

.video-modal__frame {
  aspect-ratio: 16 / 9;
}

.video-modal__frame iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.home-dates__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: start;
}

.home-dates__image {
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
  object-fit: cover;
}

.home-dates__cards {
  display: grid;
  gap: 1rem;
}

.home-date-card {
  display: flex;
  gap: 1rem;
  min-height: 10rem;
  padding: 1rem;
  border: 1px solid var(--border-warm);
  border-radius: 0.5rem;
  background: var(--card);
  color: var(--card-foreground);
}

.home-date-card__date {
  display: flex;
  width: 4rem;
  height: 4rem;
  flex: 0 0 auto;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--ink) 10%, transparent);
}

.home-date-card__day {
  color: var(--ink);
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}

.home-date-card__month {
  margin-top: 0.25rem;
  color: var(--muted-foreground);
  font-size: 0.75rem;
  text-transform: uppercase;
}

.home-date-card__content {
  min-width: 0;
}

.home-date-card__title {
  margin: 0;
  font-family: var(--font-frama);
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.25;
}

.home-date-card__description {
  margin-top: 0.5rem;
  color: var(--muted-foreground);
}

.home-date-card__description p {
  margin-block: 0.5rem;
  color: var(--muted-foreground);
}

.dates-page-grid {
  display: grid;
  gap: 2.5rem;
  align-items: start;
}

.dates-list {
  display: grid;
  gap: 1rem;
}

.date-card {
  display: flex;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid var(--border-warm);
  border-radius: 0.5rem;
  background: var(--card);
  color: var(--card-foreground);
}

.date-card__date {
  display: flex;
  width: 4rem;
  height: 4rem;
  flex: 0 0 auto;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--ink) 10%, transparent);
}

.date-card__day {
  color: var(--ink);
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}

.date-card__month {
  margin-top: 0.25rem;
  color: var(--muted-foreground);
  font-size: 0.75rem;
  text-transform: uppercase;
}

.date-card__content {
  min-width: 0;
}

.date-card__title {
  margin: 0;
  font-family: var(--font-frama);
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.25;
}

.date-card__description {
  margin-top: 0.5rem;
  color: var(--muted-foreground);
}

.date-card__description p {
  margin-block: 0.5rem;
  color: var(--muted-foreground);
}

.dates-page-image {
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
  object-fit: cover;
}

.contact-page {
  max-width: 86rem;
}

.contact-page__title {
  margin: 0 0 2rem;
  font-family: var(--font-frama);
  font-size: 2.25rem;
  font-weight: 400;
  line-height: 1.1;
}

.contact-page__grid {
  display: grid;
  gap: 2.5rem;
  align-items: start;
}

.contact-page__subtitle,
.contact-info h3 {
  margin: 0 0 1rem;
  font-family: var(--font-frama);
  font-weight: 400;
}

.contact-page__subtitle {
  margin-bottom: 1.5rem;
  font-size: 1.5rem;
}

.contact-page__intro {
  margin-bottom: 1.5rem;
}

.contact-form-wrap {
  position: relative;
  max-width: 100%;
}

.contact-form {
  display: grid;
  gap: 1.5rem;
}

.contact-form--inactive {
  filter: blur(2px);
  pointer-events: none;
  user-select: none;
}

.contact-form label {
  display: block;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 0.625rem 1rem;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  background: var(--background);
  color: var(--foreground);
  font: inherit;
}

.contact-form input {
  min-height: 2.75rem;
}

.contact-form textarea {
  resize: vertical;
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: var(--primary);
  outline: 2px solid color-mix(in srgb, var(--primary) 25%, transparent);
  outline-offset: 2px;
}

.contact-form__honeypot {
  display: none;
}

.contact-form button,
.contact-status a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.25rem;
  border: 0;
  border-radius: 0.5rem;
  background: var(--primary);
  color: var(--primary-foreground);
  cursor: pointer;
  font: inherit;
  font-weight: 500;
}

.contact-form button {
  width: 100%;
}

.contact-form button:hover {
  background: color-mix(in srgb, var(--primary) 90%, black);
}

.contact-status {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  border-radius: 1rem;
  background: color-mix(in srgb, var(--background) 85%, transparent);
  backdrop-filter: blur(6px);
}

.contact-status > div {
  max-width: 28rem;
  padding: 2rem;
  border: 1px solid var(--border);
  border-radius: 1rem;
  background: var(--background);
  text-align: center;
  box-shadow: 0 18px 40px rgb(0 0 0 / 16%);
}

.contact-status__title {
  margin: 0 0 0.75rem;
  font-family: var(--font-frama);
  font-size: 1.75rem;
}

.contact-status a {
  margin-top: 1rem;
  background: transparent;
  color: var(--foreground);
  border: 1px solid var(--border);
}

.contact-info {
  margin-top: 3rem;
  max-width: 42rem;
}

.contact-info h3 {
  margin-top: 1.75rem;
  font-size: 1.375rem;
}

.contact-info p {
  margin: 0 0 1.5rem;
  color: var(--muted-foreground);
  line-height: 1.65;
}

.contact-info a {
  color: var(--primary);
}

.contact-info a:hover {
  color: var(--primary-hover);
  text-decoration: underline;
}

.contact-page__image-wrap img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
  object-fit: cover;
}

.legal-page {
  max-width: 56rem;
}

.legal-page h1 {
  margin-top: 0;
  font-family: var(--font-frama);
  font-size: 2.75rem;
  font-weight: 400;
}

.section-spacer {
  margin-block: 2rem;
}

.section-spacer img {
  width: 100%;
  height: auto;
  opacity: 0.6;
}

.grid {
  display: grid;
  gap: 1.5rem;
}

.grid--two,
.grid--four,
.detail-grid,
.song-grid {
  grid-template-columns: 1fr;
}

.section {
  margin-bottom: 4rem;
}

.section-heading-row {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  justify-content: space-between;
  margin-bottom: 2rem;
}

.section-heading-row .section-title {
  margin-bottom: 0;
}

.section-link {
  display: inline-flex;
  align-items: center;
  align-self: flex-end;
  gap: 0.5rem;
  color: var(--muted-foreground);
  transition: color 180ms ease;
}

.section-link:hover {
  color: var(--musique);
}

.section-link img {
  width: 2rem;
  height: auto;
}

.section h2,
.section h3,
.detail-title,
.panel-title {
  font-family: var(--font-frama);
  font-weight: 400;
  line-height: 1.1;
}

.section h2 {
  margin: 0 0 2rem;
  font-size: 1.875rem;
}

.section h3 {
  margin: 0 0 1rem;
  font-size: 1.5rem;
}

.card {
  display: block;
  overflow: hidden;
  border: 1px solid var(--border-warm);
  border-radius: 0.5rem;
  background: var(--card);
  color: var(--card-foreground);
  transition: transform 700ms cubic-bezier(0.16, 1, 0.3, 1), box-shadow 700ms ease, border-color 700ms ease;
}

.card:hover {
  transform: translateY(-0.125rem);
  box-shadow: 0 12px 24px rgb(0 0 0 / 12%);
}

.album-card__image {
  aspect-ratio: 1;
  background: color-mix(in srgb, var(--border-warm) 50%, transparent);
}

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

.card__body {
  padding: 1rem;
}

.card__title {
  margin: 0 0 0.25rem;
  font-family: var(--font-frama);
  font-size: 1.25rem;
  font-weight: 400;
}

.muted {
  color: var(--muted-foreground);
}

.small {
  font-size: 0.875rem;
}

.tiny {
  font-size: 0.75rem;
}

.book-card,
.bd-card,
.illustrated-card {
  display: flex;
  gap: 1rem;
  padding: 1rem;
}

.book-card {
  border-left: 2px solid color-mix(in srgb, var(--ecrits) 40%, transparent);
  border-top: 0;
  border-right: 0;
  border-bottom: 0;
  border-radius: 0;
  background: transparent;
  color: var(--foreground);
}

.book-card:hover {
  border-left-color: color-mix(in srgb, var(--ecrits) 75%, transparent);
}

.book-card__cover,
.illustrated-card__cover {
  width: 6rem;
  height: 9rem;
  flex: 0 0 auto;
  border-radius: 0.25rem;
  background: color-mix(in srgb, var(--border-warm) 50%, transparent);
  object-fit: cover;
  box-shadow: 0 1px 4px rgb(0 0 0 / 12%);
}

.bd-card {
  height: 14rem;
  border-color: color-mix(in srgb, var(--dessins) 40%, transparent);
}

.bd-card:hover,
.illustrated-card:hover {
  border-color: color-mix(in srgb, var(--dessins) 75%, transparent);
}

.bd-card__cover {
  width: 36%;
  height: 100%;
  object-fit: contain;
  border-radius: 0.25rem;
  box-shadow: 0 1px 4px rgb(0 0 0 / 12%);
}

.card__content {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.drawing-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}

.drawing-card {
  display: block;
  overflow: hidden;
}

.drawing-card__images {
  display: grid;
  gap: 0.5rem;
  grid-template-columns: 1fr;
  padding: 0.5rem;
}

.drawing-card__image {
  aspect-ratio: 4 / 3;
  background: color-mix(in srgb, var(--border-warm) 50%, transparent);
  border-radius: 0.375rem;
  overflow: hidden;
}

.drawing-card__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.drawing-card__description {
  margin-top: 0.75rem;
}

.back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 2rem;
  color: var(--link);
}

.back-link:hover {
  color: var(--link-hover);
  text-decoration: underline;
}

.back-link--dessins {
  color: var(--dessins);
}

.back-link--dessins:hover {
  color: var(--dessins-hover);
}

.detail-grid {
  display: grid;
  gap: 2.5rem;
  margin-bottom: 3rem;
}

.detail-title {
  margin: 0 0 1rem;
  font-size: 2.5rem;
}

.detail-cover {
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
  box-shadow: 0 12px 24px rgb(0 0 0 / 16%);
}

.detail-cover--contain {
  max-height: 80vh;
  object-fit: contain;
}

.gallery-title {
  margin: 0 0 1.5rem;
  font-family: var(--font-frama);
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.1;
}

.gallery-title--dessins {
  color: var(--dessins);
}

.detail-gallery {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}

.detail-gallery__item {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--border-warm) 50%, transparent);
}

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

.prose {
  max-width: 65ch;
}

.prose a {
  color: var(--link);
}

.prose a:hover {
  color: var(--link-hover);
}

.prose h2,
.prose h3 {
  font-family: var(--font-frama);
}

.about-page {
  max-width: 72rem;
}

.about-page__intro {
  display: grid;
  gap: 2.5rem;
  margin-bottom: 4rem;
  align-items: start;
}

.about-page__title {
  margin: 0 0 1.5rem;
  color: var(--primary);
  font-family: var(--font-frama);
  font-size: 2.75rem;
  font-weight: 700;
  line-height: 1;
}

.about-page__bio {
  margin-top: 2rem;
  color: color-mix(in srgb, var(--foreground) 88%, transparent);
  font-size: 1.0625rem;
  line-height: 1.75;
}

.about-photo-rail {
  display: grid;
  gap: 1.5rem;
}

.about-photo-rail__item {
  margin: 0;
}

.about-photo-rail__item[hidden] {
  display: none;
}

.about-photo-rail__item img {
  display: block;
  width: 100%;
  height: auto;
}

.about-photo-rail__item figcaption {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  gap: 0.5rem;
  padding-top: 0.5rem;
  color: var(--muted-foreground);
  font-size: 0.875rem;
}

.about-photo-rail__credit {
  display: inline-block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.about-photo-rail__story-button {
  justify-self: end;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--primary);
  cursor: pointer;
  font: inherit;
  font-size: 0.875rem;
  white-space: nowrap;
}

.about-photo-rail__story-button:hover {
  color: var(--primary-hover);
  text-decoration: underline;
}

.about-story-modal[hidden] {
  display: none;
}

.about-story-modal {
  position: fixed;
  inset: 0;
  z-index: 210;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.about-story-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgb(0 0 0 / 75%);
  cursor: pointer;
}

.about-story-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 64rem);
  max-height: 90vh;
  overflow: auto;
  border-radius: 1rem;
  background: var(--background);
  box-shadow: 0 24px 60px rgb(0 0 0 / 45%);
}

.about-story-modal__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: color-mix(in srgb, var(--background) 92%, transparent);
  color: var(--foreground);
  cursor: pointer;
  font-size: 1.75rem;
  line-height: 1;
}

.about-story-modal__grid {
  display: grid;
}

.about-story-modal__image-wrap {
  padding: 1rem;
  background: color-mix(in srgb, var(--muted) 35%, transparent);
}

.about-story-modal__image-wrap img {
  display: block;
  width: 100%;
  max-height: 72vh;
  object-fit: contain;
}

.about-story-modal__content {
  padding: 1.5rem;
}

.about-story-modal__content h3 {
  margin: 0 2.5rem 0.75rem 0;
  font-family: var(--font-frama);
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.1;
}

.about-timeline {
  max-width: 64rem;
  margin-bottom: 4rem;
  padding: 2.5rem 1.5rem;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--muted) 40%, transparent);
}

.about-timeline__eyebrow {
  margin: 0 0 0.5rem;
  color: var(--muted-foreground);
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.about-timeline__title {
  margin: 0 0 2rem;
  font-family: var(--font-frama);
  font-size: 2rem;
  font-weight: 400;
}

.about-timeline__items {
  position: relative;
  display: grid;
  gap: 1.75rem;
}

.about-timeline__items::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0.375rem;
  width: 1px;
  background: var(--border);
}

.about-timeline__item {
  position: relative;
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr);
  gap: 1rem;
}

.about-timeline__marker {
  position: relative;
  z-index: 1;
  width: 0.75rem;
  height: 0.75rem;
  margin-top: 0.375rem;
  border-radius: 999px;
  background: var(--ink);
}

.about-timeline__year {
  margin: 0;
  color: var(--ink);
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.about-timeline__content h3 {
  margin: 0.125rem 0 0;
  font-family: var(--font-frama);
  font-size: 1.375rem;
  font-weight: 400;
  line-height: 1.15;
}

.about-timeline__description {
  margin-top: 0.5rem;
  color: var(--muted-foreground);
  line-height: 1.55;
}

.about-timeline__description p {
  margin-block: 0.375rem;
}

.song-lyrics {
  color: var(--foreground);
  line-height: 1.65;
}

.song-lyrics p {
  white-space: pre-line;
}

.meta-list {
  margin-top: 1.5rem;
  display: grid;
  gap: 0.75rem;
  color: var(--muted-foreground);
  font-size: 0.875rem;
}

.meta-list dt {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: color-mix(in srgb, var(--foreground) 70%, transparent);
  font-size: 0.75rem;
}

.meta-list dd {
  margin: 0;
}

.button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 1.5rem;
  padding: 0.5rem 1rem;
  border-radius: 0.375rem;
  background: var(--primary);
  color: white;
  font-size: 0.875rem;
}

.track-list,
.album-appearance-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.5rem;
}

.track-list li {
  display: flex;
  gap: 0.75rem;
  align-items: baseline;
}

.track-number {
  width: 2rem;
  color: var(--muted-foreground);
}

.panel {
  padding: 1.5rem;
  border: 1px solid var(--border-warm);
  border-radius: 0.5rem;
  background: var(--card);
  color: var(--card-foreground);
}

.panel-title {
  margin: 0 0 1.5rem;
  font-size: 1.25rem;
}

.album-appearance {
  display: flex;
  gap: 1rem;
  align-items: center;
  min-height: 0;
  padding: 0.5rem;
  border-radius: 0.5rem;
}

.album-appearance:hover {
  background: color-mix(in srgb, var(--border-warm) 35%, transparent);
}

.album-appearance img {
  width: 3rem;
  height: 3rem;
  flex: 0 0 auto;
  object-fit: cover;
  border-radius: 0.25rem;
}

.song-albums-panel {
  align-self: start;
  padding: 1rem;
}

.song-albums-panel .panel-title {
  margin-bottom: 1rem;
}

.news-card {
  display: block;
}

.news-card__article {
  padding: 1rem 1rem 1rem 1.5rem;
  border-left: 2px solid color-mix(in srgb, var(--primary) 60%, transparent);
  transition: transform 700ms cubic-bezier(0.16, 1, 0.3, 1), border-color 700ms ease;
  will-change: transform;
}

.news-card:hover .news-card__article {
  transform: translateY(-0.125rem);
  border-left-color: var(--primary);
}

.news-card__article {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.news-card__content {
  min-width: 0;
  flex: 1;
}

.news-card__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 0.5rem;
  color: var(--muted-foreground);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.news-card__meta span + span {
  letter-spacing: 0;
  text-transform: none;
  font-weight: 400;
}

.news-card__title {
  margin: 0 0 0.5rem;
  overflow: hidden;
  color: var(--foreground);
  font-family: var(--font-frama);
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: color 180ms ease;
}

.news-card:hover .news-card__title {
  color: var(--ink);
}

.news-card__excerpt {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--muted-foreground);
  font-size: 0.875rem;
  line-height: 1.65;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;
}

.news-card__media {
  width: 100%;
  height: 11rem;
  flex: 0 0 auto;
}

.news-card__media img {
  width: 100%;
  height: 100%;
  border-radius: 0.375rem;
  object-fit: cover;
}

.featured-album {
  position: relative;
  z-index: 0;
  display: block;
  padding: 1rem;
  border: 1px solid var(--border-warm);
  border-radius: 0.5rem;
  transition: background-color 180ms ease, border-color 180ms ease;
}

.featured-album:hover {
  background: color-mix(in srgb, var(--card) 65%, transparent);
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border-warm));
}

.featured-album__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  align-items: start;
}

.featured-album__cover {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 0.5rem;
  background: color-mix(in srgb, var(--border-warm) 50%, transparent);
  object-fit: cover;
  box-shadow: 0 12px 24px rgb(0 0 0 / 16%);
}

.featured-album__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-frama);
  font-size: 1.5rem;
  font-weight: 400;
}

.featured-album__description {
  margin-top: 1rem;
  color: var(--muted-foreground);
}

.featured-album__description p {
  color: var(--muted-foreground);
}

.featured-album__cta {
  margin-top: 1rem;
  color: var(--primary);
}

.section-title--newsletter {
  width: min(100%, 36rem);
  height: auto;
  aspect-ratio: 5713 / 613;
  color: var(--primary);
  margin-bottom: 1rem;
}

.newsletter-section {
  margin-bottom: 2rem;
  padding: 1.5rem;
  overflow: hidden;
  border: 1px solid var(--border-warm);
  border-radius: 0.5rem;
  background: var(--card);
}

.newsletter-section__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: center;
}

.newsletter-section__text {
  max-width: 34rem;
  margin: 0 0 1.5rem;
  color: var(--muted-foreground);
}

.newsletter-form {
  display: flex;
  max-width: 28rem;
  flex-direction: column;
  gap: 1rem;
  padding-top: 3rem;
}

.newsletter-form__honeypot {
  display: none;
}

.newsletter-form__input {
  width: 100%;
  padding: 0.625rem 1rem;
  border: 1px solid var(--border-warm);
  border-radius: 0.5rem;
  background: var(--background);
  color: var(--foreground);
  font: inherit;
}

.newsletter-form__input:focus {
  outline: 2px solid color-mix(in srgb, var(--primary) 45%, transparent);
  outline-offset: 2px;
}

.newsletter-form__button {
  padding: 0.625rem 1.5rem;
  border: 0;
  border-radius: 0.5rem;
  background: var(--primary);
  color: var(--primary-foreground);
  cursor: pointer;
  font: inherit;
  transition: background-color 180ms ease;
}

.newsletter-form__button:hover {
  background: color-mix(in srgb, var(--primary) 90%, black);
}

.newsletter-status {
  max-width: 28rem;
  margin: 0.9rem 0 0;
  font-size: 0.95rem;
}

.newsletter-status--success {
  color: var(--accent-2);
}

.newsletter-status--error {
  color: var(--k-rouge);
}

.newsletter-section__image-wrap {
  position: relative;
  width: 100%;
  height: 18rem;
}

.newsletter-section__image {
  width: 100%;
  height: 100%;
  border-radius: 0.5rem;
  object-fit: cover;
  object-position: 50% 35%;
}

.quick-links {
  margin-top: 4rem;
}

.quick-link-card {
  display: flex;
  min-height: 17rem;
  aspect-ratio: 2 / 1;
  flex-direction: column;
  padding: 1.5rem;
  border: 1px solid transparent;
  border-radius: 0.5rem;
  color: #fff;
  transition: transform 600ms cubic-bezier(0.16, 1, 0.3, 1), box-shadow 600ms ease;
}

.quick-link-card:hover {
  transform: translateY(-0.125rem);
  box-shadow: 0 12px 24px rgb(0 0 0 / 14%);
}

.quick-link-card--about {
  background: color-mix(in srgb, var(--accent-4) 90%, transparent);
  border-color: color-mix(in srgb, var(--accent-4) 20%, transparent);
}

.quick-link-card--music {
  background: color-mix(in srgb, var(--accent-1) 90%, transparent);
  border-color: color-mix(in srgb, var(--accent-1) 20%, transparent);
}

.quick-link-card--drawings {
  background: color-mix(in srgb, var(--accent-2) 90%, transparent);
  border-color: color-mix(in srgb, var(--accent-2) 20%, transparent);
}

.quick-link-card--books {
  background: color-mix(in srgb, var(--accent-3) 90%, transparent);
  border-color: color-mix(in srgb, var(--accent-3) 20%, transparent);
}

.quick-link-card__icon {
  display: block;
  width: 2.5rem;
  height: 2.5rem;
  margin-bottom: 1rem;
}

.quick-link-card h2 {
  margin: 0 0 0.5rem;
  font-family: var(--font-frama);
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: 0.02em;
}

.quick-link-card p {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: #fff;
  font-weight: 300;
  line-height: 1.45;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 7;
}

.quick-link-card__cta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: auto;
  padding-top: 1rem;
  font-size: 0.875rem;
  font-weight: 500;
}

.quick-link-card__cta img {
  width: 2rem;
  height: auto;
  filter: brightness(0) invert(1);
}

.site-footer {
  margin-top: auto;
  border-top: 1px solid var(--border-warm);
}

.site-footer__inner {
  padding-block: 2rem;
}

.site-footer__top {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.site-footer nav {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  color: var(--muted-foreground);
}

.site-footer hr {
  margin: 2rem 0;
  border: 0;
  border-top: 1px solid var(--border-warm);
}

.text-center {
  text-align: center;
}

.empty {
  padding-block: 3rem;
  color: var(--muted-foreground);
}

@media (min-width: 48rem) {
  .container {
    padding-inline: 2rem;
  }

  .site-nav {
    display: flex;
  }

  .menu-button {
    display: none;
  }

  .grid--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .drawing-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .drawing-card__images:not(.drawing-card__images--single) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .detail-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .music-album-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .music-video-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .site-footer__top {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }

  .site-footer nav {
    flex-direction: row;
    gap: 2rem;
  }

  .section-heading-row {
    flex-direction: row;
    align-items: center;
  }

  .section-title--news {
    height: 4rem;
  }

  .home-hero {
    position: relative;
    z-index: 0;
    min-height: calc(100vh - 2rem);
    margin-top: 0;
    pointer-events: none;
  }

  .home-hero__image-wrap {
    position: fixed;
    inset: 0;
    z-index: 0;
    height: 100vh;
    pointer-events: none;
  }

  .home-hero__image {
    width: 100%;
    height: 100%;
    object-position: top center;
    transform: scale(1.06);
    transform-origin: top center;
    will-change: opacity;
    transition: opacity 300ms ease;
  }

  .home-hero__content {
    position: fixed;
    top: 8rem;
    right: 3rem;
    z-index: 20;
    margin: 0 0 0 auto;
    padding: 0;
    pointer-events: auto;
  }

  .home-hero__text {
    font-size: 1.5rem;
  }

  .page-layout--with-hero {
    margin-top: -4rem;
  }

  .home-dates__grid {
    grid-template-columns: 40% 1fr;
  }

  .dates-page-grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(20rem, 0.85fr);
  }

  .contact-page__grid {
    grid-template-columns: minmax(0, 3fr) minmax(20rem, 2.5fr);
    gap: 3rem;
  }

  .about-page__intro {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  }

  .about-story-modal__grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(18rem, 0.85fr);
  }

  .about-story-modal__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2rem;
  }

  .about-timeline {
    padding: 3rem 2.5rem;
  }

  .about-timeline__items {
    gap: 2rem;
  }

  .about-timeline__items::before {
    left: 50%;
    transform: translateX(-50%);
  }

  .about-timeline__item {
    grid-template-columns: minmax(0, 1fr) 1rem minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
  }

  .about-timeline__marker {
    grid-column: 2;
    margin: 0.5rem auto 0;
  }

  .about-timeline__content {
    max-width: 25rem;
  }

  .about-timeline__item--left .about-timeline__content {
    grid-column: 1;
    grid-row: 1;
    justify-self: end;
    text-align: right;
  }

  .about-timeline__item--right .about-timeline__content {
    grid-column: 3;
    grid-row: 1;
    justify-self: start;
  }

  .featured-album__grid {
    grid-template-columns: 1fr 2fr;
  }

  .newsletter-section {
    padding-inline: 2rem;
  }

  .newsletter-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .news-card__article {
    flex-direction: row;
    align-items: flex-start;
  }

  .news-card__media {
    width: 10rem;
    height: 8rem;
  }
}

@media (min-width: 64rem) {
  .grid--four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .drawing-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .drawing-card--wide {
    grid-column: span 4;
  }

  .detail-gallery {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .music-album-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .music-video-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .song-grid {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: 2rem;
  }

  .news-card__media {
    width: 12rem;
    height: 9rem;
  }

  .newsletter-section__image-wrap {
    height: 30rem;
  }
}
