:root {
  /* Color system */
  --mpd-color-ink: #27272f;
  --mpd-color-ink-soft: #3c3c41;
  --mpd-color-muted: #6f7280;
  --mpd-color-canvas: #f7f7f9;
  --mpd-color-surface: #ffffff;
  --mpd-color-line: #dedfe6;
  --mpd-color-pink: #e3007c;
  --mpd-color-blue: #2e82ff;
  --mpd-color-green: #1f9d73;
  --mpd-radius: 0.5rem;

  /* Layout system */
  --mpd-layout-content-max: 70rem;
  --mpd-layout-wide-max: 90rem;
  --mpd-layout-page-max: 131.25rem;
  --mpd-page-gutter: clamp(0.875rem, 4vw, 1.25rem);
  --mpd-page-inline-size: calc(100% - var(--mpd-page-gutter) - var(--mpd-page-gutter));
  --mpd-width: min(var(--mpd-layout-content-max), var(--mpd-page-inline-size));
  --mpd-wide: min(var(--mpd-layout-wide-max), var(--mpd-page-inline-size));
  --mpd-full-bleed-width: 100vw;
  --mpd-full-bleed-margin-inline: calc(50% - 50vw);
  --mpd-vh: 100vh;
  --mpd-initial-vh: 100svh;
  --mpd-container-narrow: 60rem;
  --mpd-container-default: 112.5rem;
  --mpd-container-wide: var(--mpd-layout-page-max);
  --mpd-page-space: var(--mpd-page-gutter);
  --mpd-space-light: 0.8rem;
  --mpd-space-default: clamp(2rem, 5vw, 3.125rem);
  --mpd-space-xs: 0.4rem;
  --mpd-space-sm: 0.8rem;
  --mpd-space-md: 1rem;
  --mpd-space-lg: 1.5rem;
  --mpd-space-xl: 2rem;
  --mpd-space-block-md: 0.4rem 0.7rem;
  --mpd-space-block-lg: 0.6rem 1.8rem;
  --mpd-space-block-v-md: 1rem 0;
  --mpd-space-button: 0.9375rem 2.5rem;
  --mpd-grid-gap: clamp(0.875rem, 2.4vw, 1.75rem);
  --mpd-section-gap: var(--mpd-space-default);
  --mpd-content-cta-background: var(--mpd-color-dark-ink);
  --mpd-content-cta-color: var(--mpd-color-light-pure);
  --mpd-content-cta-radius: var(--mpd-radius);
  --mpd-content-cta-gap: var(--mpd-gap-md);
  --mpd-content-cta-margin-block: var(--mpd-space-default);
  --mpd-content-cta-max-width: var(--mpd-width);
  --mpd-content-cta-padding-block: calc(var(--mpd-space-xl) * 1.15);
  --mpd-content-cta-padding-inline: var(--mpd-space-xl);
  --mpd-content-cta-copy-max-width: 62rem;
  --mpd-color-light-canvas: #eeeeee;
  --mpd-color-light-ink: #fafafa;
  --mpd-color-light-pure: #ffffff;
  --mpd-color-light-platinum: #d3d3d3;
  --mpd-color-light-transparent-1: #ffffff6b;
  --mpd-color-light-transparent-2: #ffffffcf;
  --mpd-color-dark-ink: #3c3c3c;
  --mpd-color-dark-graphite: #4f4f4f;
  --mpd-color-dark-silver: #959595;
  --mpd-color-primary: #e3007c;
  --mpd-color-primary-light: #ff53a0;
  --mpd-color-secondary: #2e82ff;
  --mpd-color-secondary-light: #589bff;
  --mpd-font-family-base: "Quicksand", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mpd-font-size-xs: 0.7rem;
  --mpd-font-size-sm: 0.9rem;
  --mpd-font-size-md: 1rem;
  --mpd-font-size-lg: 1.4rem;
  --mpd-font-size-btn: 1.1rem;
  --mpd-font-size-nav: 1.3rem;
  --mpd-font-line-height-md: 1.3rem;
  --mpd-heading-color: currentColor;
  --mpd-heading-font-family: var(--mpd-font-family-base);
  --mpd-heading-font-style: normal;
  --mpd-heading-letter-spacing: 0;
  --mpd-heading-text-transform: none;
  --mpd-h1-size: 2.5rem;
  --mpd-h1-weight: 650;
  --mpd-h1-line-height: 1.15;
  --mpd-h1-margin: 0 0 var(--mpd-space-lg);
  --mpd-h2-size: 1.75rem;
  --mpd-h2-weight: 650;
  --mpd-h2-line-height: 1.18;
  --mpd-h2-margin: var(--mpd-space-xl) 0 var(--mpd-space-md);
  --mpd-h3-size: 1.35rem;
  --mpd-h3-weight: 600;
  --mpd-h3-line-height: 1.22;
  --mpd-h3-margin: var(--mpd-space-lg) 0 var(--mpd-space-sm);
  --mpd-h4-size: 1.12rem;
  --mpd-h4-weight: 600;
  --mpd-h4-line-height: 1.28;
  --mpd-h4-margin: var(--mpd-space-md) 0 var(--mpd-space-xs);
  --mpd-h5-size: 1rem;
  --mpd-h5-weight: 650;
  --mpd-h5-line-height: 1.32;
  --mpd-h5-margin: var(--mpd-space-md) 0 var(--mpd-space-xs);
  --mpd-h6-size: 0.92rem;
  --mpd-h6-weight: 700;
  --mpd-h6-line-height: 1.35;
  --mpd-h6-margin: var(--mpd-space-md) 0 var(--mpd-space-xs);
  --mpd-gap-sm: 0.5rem;
  --mpd-gap-md: 1rem;
  --mpd-gap-lg: 1.5rem;

  /* Radius and elevation system */
  --mpd-radius-sm: 12px;
  --mpd-radius-md: 30px;
  --mpd-radius-lg: 50px;
  --mpd-shadow-null: none;
  --mpd-shadow-sm: 2px 4px 10px rgba(39, 39, 47, 0.35);
  --mpd-shadow-md: 5px 10px 18px rgba(39, 39, 47, 0.30);
  --mpd-shadow-lg: 8px 18px 42px rgba(39, 39, 47, 0.32);

  /* Popup system */
  --mpd-popup-surface-background: var(--mpd-color-dark-ink);
  --mpd-popup-surface-border: 1px solid var(--mpd-color-light-canvas);
  --mpd-popup-surface-radius: var(--mpd-radius-md);
  --mpd-popup-backdrop-background: #00000080;

  /* Button system */
  --mpd-button-size-s: 2.3rem;
  --mpd-button-size-m: 3.5rem;
  --mpd-button-size-l: 5rem;
  --mpd-button-radius: var(--mpd-radius-lg);
  --mpd-button-transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
  --mpd-button-text-transform: uppercase;
  --mpd-ui-label-text-transform: uppercase;

  /* Field system */
  --mpd-field-height: 54px;
  --mpd-field-padding: 0 16px;
  --mpd-field-radius: var(--mpd-radius-md);
  --mpd-field-background: var(--mpd-color-canvas);
  --mpd-field-border: 1px solid var(--mpd-color-line);
  --mpd-field-color: var(--mpd-color-ink);
  --mpd-field-placeholder-color: var(--mpd-color-muted);
  --mpd-field-focus-border-color: var(--mpd-color-primary);
  --mpd-field-focus-outline: 3px solid rgba(227, 0, 124, 0.16);
  --mpd-field-focus-outline-offset: 0;
  --mpd-field-font-size: 1rem;
  --mpd-field-transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;

  /* Header menu system */
  --mpd-mobile-menu-item-height: 130px;
  --mpd-mobile-menu-item-insights-height: 140px;
  --mpd-mobile-menu-item-max-height: 200px;
  --mpd-mobile-menu-header-offset: 220px;
  --mpd-header-menu-display: block;
}

@media (min-width: 48rem) {
  :root {
    --mpd-page-gutter: clamp(1.25rem, 3vw, 2.5rem);
  }
}

@media (max-width: 47.999rem) {
  :root {
    --wp--style--block-gap: 18px;
    --mpd-page-gutter: var(--wp--style--block-gap);
    --mpd-grid-gap: var(--wp--style--block-gap);
    --mpd-section-gap: var(--wp--style--block-gap);
    --mpd-h1-size: 1.65rem;
    --mpd-h2-size: 1.45rem;
    --mpd-h3-size: 1.2rem;
    --mpd-h4-size: 1.05rem;
    --mpd-h5-size: 0.98rem;
    --mpd-h6-size: 0.9rem;
  }

  :where(.wp-site-blocks) > * {
    margin-block-start: var(--wp--style--block-gap);
  }

  :root :where(.is-layout-flow) > *,
  :root :where(.is-layout-constrained) > * {
    margin-block-start: var(--wp--style--block-gap);
  }

  :root :where(.is-layout-flex),
  :root :where(.is-layout-grid) {
    gap: var(--wp--style--block-gap);
  }

  .mpd-collection-section > .mpd-catalog-grid {
    width: 100%;
  }
}

@media (min-width: 80rem) {
  :root {
    --mpd-page-gutter: clamp(2rem, 4vw, 4rem);
  }
}

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

body {
  margin: 0;
  background: var(--mpd-color-canvas);
  color: var(--mpd-color-ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 16px;
  line-height: 1.55;
  letter-spacing: 0;
}

body.mpd-context-collection,
body.mpd-context-collections,
body.mpd-context-service_archive {
  background: var(--mpd-color-light-canvas);
}

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

a {
  color: inherit;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.2em;
}

:where(h1, h2, h3, h4, h5, h6) {
  color: var(--mpd-heading-color);
  font-family: var(--mpd-heading-font-family);
  font-style: var(--mpd-heading-font-style);
  letter-spacing: var(--mpd-heading-letter-spacing);
  text-transform: var(--mpd-heading-text-transform);
  overflow-wrap: anywhere;
}

h1 {
  margin: var(--mpd-h1-margin);
  font-size: var(--mpd-h1-size);
  font-weight: var(--mpd-h1-weight);
  line-height: var(--mpd-h1-line-height);
}

h2 {
  margin: var(--mpd-h2-margin);
  font-size: var(--mpd-h2-size);
  font-weight: var(--mpd-h2-weight);
  line-height: var(--mpd-h2-line-height);
}

h3 {
  margin: var(--mpd-h3-margin);
  font-size: var(--mpd-h3-size);
  font-weight: var(--mpd-h3-weight);
  line-height: var(--mpd-h3-line-height);
}

h4 {
  margin: var(--mpd-h4-margin);
  font-size: var(--mpd-h4-size);
  font-weight: var(--mpd-h4-weight);
  line-height: var(--mpd-h4-line-height);
}

h5 {
  margin: var(--mpd-h5-margin);
  font-size: var(--mpd-h5-size);
  font-weight: var(--mpd-h5-weight);
  line-height: var(--mpd-h5-line-height);
}

h6 {
  margin: var(--mpd-h6-margin);
  font-size: var(--mpd-h6-size);
  font-weight: var(--mpd-h6-weight);
  line-height: var(--mpd-h6-line-height);
}

body.mpd-hide-overlay {
  overflow: hidden;
  min-width: 100vw;
  min-height: var(--mpd-vh, 100vh);
}

body.mpd-service-search-open {
  overflow: hidden;
  overscroll-behavior: none;
}

.mpd-skip-link {
  position: fixed;
  top: 8px;
  left: 8px;
  transform: translateY(-160%);
  z-index: 1000;
  background: var(--mpd-color-ink);
  color: white;
  padding: 10px 14px;
}

.mpd-skip-link:focus {
  transform: translateY(0);
}

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.mpd-popup-surface {
  background: var(--mpd-popup-surface-background);
  border: var(--mpd-popup-surface-border);
  border-radius: var(--mpd-popup-surface-radius);
  box-shadow: var(--mpd-shadow-lg);
  color: var(--mpd-color-light-ink);
}

.mpd-popup-surface a {
  color: inherit;
}

.mpd-popup-backdrop {
  background: var(--mpd-popup-backdrop-background);
}

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

.mpd-request-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: var(--mpd-service-modal-padding, var(--mpd-space-lg));
}

.mpd-request-modal-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
}

.mpd-request-dialog {
  position: relative;
  z-index: 1;
}

body.mpd-request-modal-open {
  overflow: hidden;
  overscroll-behavior: none;
}

.mpd-popup-open .mpd-popup-backdrop {
  animation: mpd-popup-backdrop-in 0.4s ease forwards;
}

.mpd-popup-open .mpd-popup-surface {
  animation: mpd-slide-in-top 0.4s ease forwards;
}

.mpd-popup-closing .mpd-popup-backdrop {
  animation: mpd-popup-backdrop-out 0.4s ease forwards;
  pointer-events: none;
}

.mpd-popup-closing .mpd-popup-surface {
  animation: mpd-popup-slide-out-down 0.4s ease forwards;
  pointer-events: none;
}

.mpd-ui-button {
  --mpd-ui-button-size: var(--mpd-button-size-m);
  --mpd-ui-button-height: var(--mpd-button-size-m);
  --mpd-ui-button-padding: 0 1.8em;
  --mpd-ui-button-icon-padding: 10px;
  --mpd-ui-button-background: transparent;
  --mpd-ui-button-border-color: transparent;
  --mpd-ui-button-color: currentColor;
  --mpd-ui-button-shadow: var(--mpd-shadow-md);
  --mpd-ui-button-hover-background: var(--mpd-ui-button-background);
  --mpd-ui-button-hover-border-color: var(--mpd-ui-button-border-color);
  --mpd-ui-button-hover-color: var(--mpd-ui-button-color);
  --mpd-ui-button-hover-shadow: var(--mpd-shadow-lg);
  --mpd-ui-button-hover-transform: scale(1.015);
  --mpd-ui-button-active-shadow: var(--mpd-shadow-null);
  --mpd-ui-button-active-transform: scale(0.985);
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--mpd-ui-button-height);
  padding: var(--mpd-ui-button-padding);
  border: 1px solid var(--mpd-ui-button-border-color);
  border-radius: var(--mpd-button-radius);
  background: var(--mpd-ui-button-background);
  box-shadow: var(--mpd-ui-button-shadow);
  color: var(--mpd-ui-button-color);
  fill: currentColor;
  font: inherit;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  text-transform: var(--mpd-button-text-transform);
  cursor: pointer;
  transition: var(--mpd-button-transition);
}

.mpd-ui-button:hover,
.mpd-ui-button:focus-visible {
  background: var(--mpd-ui-button-hover-background);
  border-color: var(--mpd-ui-button-hover-border-color);
  box-shadow: var(--mpd-ui-button-hover-shadow);
  color: var(--mpd-ui-button-hover-color);
  outline: none;
  transform: var(--mpd-ui-button-hover-transform);
}

.mpd-ui-button:disabled,
.mpd-ui-button[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.58;
  transform: none;
}

.mpd-ui-button:active:not(:disabled):not([aria-disabled="true"]) {
  box-shadow: var(--mpd-ui-button-active-shadow);
  transform: var(--mpd-ui-button-active-transform);
}

.mpd-ui-button svg,
.mpd-ui-button svg path {
  fill: currentColor;
}

.mpd-ui-button--square,
.mpd-ui-button--icon {
  width: var(--mpd-ui-button-size);
  min-width: var(--mpd-ui-button-size);
  height: var(--mpd-ui-button-size);
  min-height: var(--mpd-ui-button-size);
  aspect-ratio: 1 / 1;
  padding: var(--mpd-ui-button-icon-padding);
  border-radius: 50%;
}

.mpd-ui-button--square svg,
.mpd-ui-button--icon svg {
  width: 100%;
  height: 100%;
}

.mpd-ui-button--rectangle,
.mpd-ui-button--text {
  min-height: var(--mpd-ui-button-height);
  padding: var(--mpd-ui-button-padding);
  border-radius: var(--mpd-button-radius);
  white-space: nowrap;
}

.mpd-ui-button--s {
  --mpd-ui-button-size: var(--mpd-button-size-s);
  --mpd-ui-button-height: 40px;
  --mpd-ui-button-padding: 0 1.25em;
  --mpd-ui-button-icon-padding: 7px;
  font-size: 1rem;
}

.mpd-ui-button--m {
  --mpd-ui-button-size: var(--mpd-button-size-m);
  --mpd-ui-button-height: 58px;
  --mpd-ui-button-padding: var(--mpd-space-button);
  --mpd-ui-button-icon-padding: 10px;
  font-size: var(--mpd-font-size-btn);
}

.mpd-ui-button--l {
  --mpd-ui-button-size: var(--mpd-button-size-l);
  --mpd-ui-button-height: 64px;
  --mpd-ui-button-padding: 18px 46px;
  --mpd-ui-button-icon-padding: 3px;
  font-size: 1.2rem;
}

.mpd-ui-button--image-icon {
  --mpd-ui-button-icon-padding: 0;
}

.mpd-ui-button--image-icon img {
  width: 100%;
  max-width: none;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
}

.mpd-ui-button--primary {
  --mpd-ui-button-background: var(--mpd-color-primary);
  --mpd-ui-button-border-color: var(--mpd-color-primary);
  --mpd-ui-button-color: var(--mpd-color-light-pure);
  --mpd-ui-button-hover-background: var(--mpd-color-primary);
  --mpd-ui-button-hover-border-color: var(--mpd-color-primary);
  --mpd-ui-button-hover-color: var(--mpd-color-light-pure);
}

.mpd-ui-button--light,
.mpd-ui-button--white {
  --mpd-ui-button-background: var(--mpd-color-light-pure);
  --mpd-ui-button-border-color: var(--mpd-color-line);
  --mpd-ui-button-color: var(--mpd-color-ink);
  --mpd-ui-button-hover-background: var(--mpd-color-light-pure);
  --mpd-ui-button-hover-border-color: var(--mpd-color-primary);
  --mpd-ui-button-hover-color: var(--mpd-color-ink);
}

.mpd-ui-button--dark,
.mpd-ui-button--black {
  --mpd-ui-button-background: var(--mpd-color-dark-ink);
  --mpd-ui-button-border-color: var(--mpd-color-dark-ink);
  --mpd-ui-button-color: var(--mpd-color-light-ink);
  --mpd-ui-button-hover-background: var(--mpd-color-dark-graphite);
  --mpd-ui-button-hover-border-color: var(--mpd-color-dark-graphite);
  --mpd-ui-button-hover-color: var(--mpd-color-light-ink);
}

.mpd-ui-button--ghost-light,
.mpd-ui-button--ghost-white {
  --mpd-ui-button-color: var(--mpd-color-light-ink);
  --mpd-ui-button-hover-color: var(--mpd-color-light-pure);
  --mpd-ui-button-hover-background: rgba(255, 255, 255, 0.08);
}

.mpd-ui-button--ghost-dark,
.mpd-ui-button--ghost-black {
  --mpd-ui-button-color: var(--mpd-color-ink);
  --mpd-ui-button-hover-color: var(--mpd-color-ink);
  --mpd-ui-button-hover-background: rgba(39, 39, 47, 0.06);
}

.mpd-ui-button--flat {
  --mpd-ui-button-shadow: var(--mpd-shadow-null);
  --mpd-ui-button-hover-shadow: var(--mpd-shadow-null);
  --mpd-ui-button-active-shadow: var(--mpd-shadow-null);
}

.mpd-ui-button-group {
  --mpd-ui-button-size: var(--mpd-button-size-m);
  --mpd-ui-button-height: var(--mpd-button-size-m);
  --mpd-ui-button-padding: 0 1.8em;
  --mpd-ui-button-background: transparent;
  --mpd-ui-button-border-color: transparent;
  --mpd-ui-button-color: currentColor;
  --mpd-ui-button-shadow: var(--mpd-shadow-md);
  --mpd-ui-button-hover-background: var(--mpd-ui-button-background);
  --mpd-ui-button-hover-border-color: var(--mpd-ui-button-border-color);
  --mpd-ui-button-hover-color: var(--mpd-ui-button-color);
  --mpd-ui-button-hover-shadow: var(--mpd-shadow-lg);
  --mpd-ui-button-hover-transform: scale(1.015);
  --mpd-ui-button-active-shadow: var(--mpd-shadow-null);
  --mpd-ui-button-active-transform: scale(0.985);
}

.mpd-ui-button-group > :is(a, button, span) {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--mpd-ui-button-height);
  padding: var(--mpd-ui-button-padding);
  border: 1px solid var(--mpd-ui-button-border-color);
  border-radius: var(--mpd-button-radius);
  background: var(--mpd-ui-button-background);
  box-shadow: var(--mpd-ui-button-shadow);
  color: var(--mpd-ui-button-color);
  fill: currentColor;
  font: inherit;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  text-transform: var(--mpd-button-text-transform);
  transition: var(--mpd-button-transition);
}

.mpd-ui-button-group > :is(a, button) {
  cursor: pointer;
}

.mpd-ui-button-group > :is(a, button):hover,
.mpd-ui-button-group > :is(a, button):focus-visible {
  background: var(--mpd-ui-button-hover-background);
  border-color: var(--mpd-ui-button-hover-border-color);
  box-shadow: var(--mpd-ui-button-hover-shadow);
  color: var(--mpd-ui-button-hover-color);
  outline: none;
  transform: var(--mpd-ui-button-hover-transform);
}

.mpd-ui-button-group > :is(a, button):active {
  box-shadow: var(--mpd-ui-button-active-shadow);
  transform: var(--mpd-ui-button-active-transform);
}

@media (prefers-reduced-motion: reduce) {
  .mpd-ui-button,
  .mpd-button,
  .mpd-ui-button-group > :is(a, button, span) {
    transition: none;
  }

  .mpd-ui-button:hover,
  .mpd-ui-button:focus-visible,
  .mpd-ui-button:active,
  .mpd-button:hover,
  .mpd-button:focus,
  .mpd-button:active,
  .mpd-ui-button-group > :is(a, button):hover,
  .mpd-ui-button-group > :is(a, button):focus-visible,
  .mpd-ui-button-group > :is(a, button):active {
    transform: none;
  }
}

/* WPForms bridge: map third-party form markup onto the MPD field and button system. */
.wpforms-container,
div.wpforms-container-full {
  --mpd-wpforms-gap: var(--mpd-form-gap, var(--mpd-gap-md));
  --mpd-wpforms-field-height: var(--mpd-field-height);
  --mpd-wpforms-field-padding: var(--mpd-field-padding);
  --mpd-wpforms-field-radius: var(--mpd-field-radius);
  --mpd-wpforms-field-background: var(--mpd-field-background);
  --mpd-wpforms-field-border: var(--mpd-field-border);
  --mpd-wpforms-field-color: var(--mpd-field-color);
  --mpd-wpforms-field-placeholder-color: var(--mpd-field-placeholder-color);
  --mpd-wpforms-field-focus-border-color: var(--mpd-field-focus-border-color);
  --mpd-wpforms-field-focus-outline: var(--mpd-field-focus-outline);
  --mpd-wpforms-field-focus-outline-offset: var(--mpd-field-focus-outline-offset);
  --mpd-wpforms-field-font-size: var(--mpd-field-font-size);
  --mpd-wpforms-textarea-min-height: 118px;
  --mpd-wpforms-label-color: var(--mpd-color-muted);
  --mpd-wpforms-label-font-size: var(--mpd-font-size-sm);
  --mpd-wpforms-error-color: var(--mpd-color-primary-light);
  --mpd-wpforms-button-height: var(--mpd-button-size-m);
  --mpd-wpforms-button-padding: var(--mpd-space-button);
  --mpd-wpforms-button-radius: var(--mpd-button-radius);
  --mpd-wpforms-button-background: var(--mpd-color-primary);
  --mpd-wpforms-button-border-color: var(--mpd-color-primary);
  --mpd-wpforms-button-color: var(--mpd-color-light-pure);
  --mpd-wpforms-button-hover-background: var(--mpd-color-primary);
  --mpd-wpforms-button-hover-border-color: var(--mpd-color-primary);
  --mpd-wpforms-button-hover-color: var(--mpd-color-light-pure);
  --mpd-wpforms-button-shadow: var(--mpd-shadow-md);
  --mpd-wpforms-button-hover-shadow: var(--mpd-shadow-lg);
  --mpd-wpforms-button-hover-transform: scale(1.015);
  --mpd-wpforms-secondary-button-background: rgba(39, 39, 47, 0.08);
  --mpd-wpforms-secondary-button-border-color: rgba(39, 39, 47, 0.14);
  --mpd-wpforms-secondary-button-color: var(--mpd-color-ink);
  --mpd-wpforms-secondary-button-hover-background: rgba(39, 39, 47, 0.12);
  --mpd-wpforms-secondary-button-hover-border-color: var(--mpd-color-primary);
  --mpd-wpforms-secondary-button-hover-color: var(--mpd-color-ink);
  width: 100%;
  max-width: 100%;
  margin: 0;
  color: inherit;
  font-family: var(--mpd-font-family-base);
}

html.mpd-color-mode-inverted body.mpd-color-mode-enabled main.mpd-main :where(.wpforms-container, div.wpforms-container-full),
body.mpd-invert main.mpd-main :where(.wpforms-container, div.wpforms-container-full),
.mpd-popup-surface :where(.wpforms-container, div.wpforms-container-full) {
  --mpd-wpforms-field-background: #1d1f28;
  --mpd-wpforms-field-border: 1px solid rgba(255, 255, 255, 0.16);
  --mpd-wpforms-field-color: var(--mpd-color-mode-text, var(--mpd-color-light-ink));
  --mpd-wpforms-field-placeholder-color: var(--mpd-color-mode-muted-soft, rgba(255, 255, 255, 0.58));
  --mpd-wpforms-label-color: var(--mpd-color-mode-muted, rgba(255, 255, 255, 0.76));
  --mpd-wpforms-secondary-button-background: rgba(255, 255, 255, 0.08);
  --mpd-wpforms-secondary-button-border-color: rgba(255, 255, 255, 0.16);
  --mpd-wpforms-secondary-button-color: var(--mpd-color-mode-text, var(--mpd-color-light-ink));
  --mpd-wpforms-secondary-button-hover-background: rgba(255, 255, 255, 0.12);
  --mpd-wpforms-secondary-button-hover-border-color: var(--mpd-color-primary-light);
  --mpd-wpforms-secondary-button-hover-color: var(--mpd-color-mode-heading, var(--mpd-color-light-pure));
}

.wpforms-container .wpforms-form,
div.wpforms-container-full .wpforms-form {
  width: 100%;
  margin: 0;
  color: inherit;
  font-family: inherit;
}

.wpforms-container .wpforms-field-container,
div.wpforms-container-full .wpforms-form .wpforms-field-container {
  display: block;
  width: 100%;
}

.wpforms-container .wpforms-field,
div.wpforms-container-full .wpforms-form .wpforms-field {
  min-width: 0;
  margin: 0;
  padding: 0 0 var(--mpd-wpforms-gap);
}

.wpforms-container .wpforms-field-pagebreak,
div.wpforms-container-full .wpforms-form .wpforms-field-pagebreak {
  padding-bottom: 0;
}

.wpforms-container :where(.wpforms-field-label, .wpforms-field-sublabel, .wpforms-field-description),
div.wpforms-container-full .wpforms-form :where(.wpforms-field-label, .wpforms-field-sublabel, .wpforms-field-description) {
  color: var(--mpd-wpforms-label-color);
  font: inherit;
  font-size: var(--mpd-wpforms-label-font-size);
  line-height: 1.3;
}

.wpforms-container .wpforms-field-label,
div.wpforms-container-full .wpforms-form .wpforms-field-label {
  margin: 0 0 0.45rem;
  font-weight: 700;
}

.wpforms-container :where(.wpforms-required-label, label.wpforms-error, .wpforms-error),
div.wpforms-container-full .wpforms-form :where(.wpforms-required-label, label.wpforms-error, .wpforms-error) {
  color: var(--mpd-wpforms-error-color) !important;
}

.wpforms-container label.wpforms-error,
div.wpforms-container-full .wpforms-form label.wpforms-error {
  display: block;
  margin: 0.4rem 0 0 0.95rem !important;
  font-size: 0.86rem;
  line-height: 1.25;
}

.wpforms-container .wpforms-form :where(input[type="text"], input[type="search"], input[type="email"], input[type="tel"], input[type="url"], input[type="number"], input[type="password"], input[type="date"], input[type="time"], textarea, select),
div.wpforms-container-full .wpforms-form :where(input[type="text"], input[type="search"], input[type="email"], input[type="tel"], input[type="url"], input[type="number"], input[type="password"], input[type="date"], input[type="time"], textarea, select) {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  min-height: var(--mpd-wpforms-field-height) !important;
  box-sizing: border-box !important;
  padding: var(--mpd-wpforms-field-padding) !important;
  border: var(--mpd-wpforms-field-border) !important;
  border-radius: var(--mpd-wpforms-field-radius) !important;
  background-color: var(--mpd-wpforms-field-background) !important;
  box-shadow: var(--mpd-shadow-null) !important;
  color: var(--mpd-wpforms-field-color) !important;
  font: inherit !important;
  font-size: var(--mpd-wpforms-field-font-size) !important;
  line-height: 1.25 !important;
  transition: var(--mpd-field-transition);
}

.wpforms-container .wpforms-form textarea,
div.wpforms-container-full .wpforms-form textarea {
  min-height: var(--mpd-wpforms-textarea-min-height) !important;
  padding-block: 14px !important;
  resize: vertical;
}

.wpforms-container .wpforms-form select,
div.wpforms-container-full .wpforms-form select {
  appearance: none;
  padding-right: 42px !important;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position:
    calc(100% - 19px) 50%,
    calc(100% - 13px) 50%;
  background-repeat: no-repeat;
  background-size: 6px 6px, 6px 6px;
}

.wpforms-container .wpforms-form :where(input, textarea)::placeholder,
div.wpforms-container-full .wpforms-form :where(input, textarea)::placeholder {
  color: var(--mpd-wpforms-field-placeholder-color);
  opacity: 1;
}

.wpforms-container .wpforms-form :where(input[type="text"], input[type="search"], input[type="email"], input[type="tel"], input[type="url"], input[type="number"], input[type="password"], input[type="date"], input[type="time"], textarea, select):focus,
div.wpforms-container-full .wpforms-form :where(input[type="text"], input[type="search"], input[type="email"], input[type="tel"], input[type="url"], input[type="number"], input[type="password"], input[type="date"], input[type="time"], textarea, select):focus {
  border-color: var(--mpd-wpforms-field-focus-border-color) !important;
  outline: var(--mpd-wpforms-field-focus-outline) !important;
  outline-offset: var(--mpd-wpforms-field-focus-outline-offset) !important;
}

.wpforms-container .wpforms-form :where(input[type="checkbox"], input[type="radio"]),
div.wpforms-container-full .wpforms-form :where(input[type="checkbox"], input[type="radio"]) {
  accent-color: var(--mpd-color-primary);
}

.wpforms-container .wpforms-field-row,
.wpforms-container .wpforms-field-row-block,
div.wpforms-container-full .wpforms-form .wpforms-field-row,
div.wpforms-container-full .wpforms-form .wpforms-field-row-block {
  width: 100%;
  max-width: 100% !important;
  min-width: 0;
  margin: 0 !important;
  padding: 0 !important;
}

.wpforms-container :where(.wpforms-pagebreak-left, .wpforms-pagebreak-right, .wpforms-pagebreak-center),
div.wpforms-container-full .wpforms-form :where(.wpforms-pagebreak-left, .wpforms-pagebreak-right, .wpforms-pagebreak-center) {
  display: flex;
  width: 100%;
  gap: var(--mpd-gap-sm);
  align-items: center;
  justify-content: flex-end;
  margin: 0 !important;
  padding: 0 !important;
}

.wpforms-container .wpforms-pagebreak-center,
div.wpforms-container-full .wpforms-form .wpforms-pagebreak-center {
  justify-content: center;
}

.wpforms-container .wpforms-pagebreak-left,
div.wpforms-container-full .wpforms-form .wpforms-pagebreak-left {
  justify-content: flex-start;
}

.wpforms-container .wpforms-submit-container,
div.wpforms-container-full .wpforms-form .wpforms-submit-container {
  margin: 0 !important;
  padding: 0 !important;
}

.wpforms-container .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]),
div.wpforms-container-full .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]) {
  appearance: none;
  display: inline-flex;
  min-height: var(--mpd-wpforms-button-height) !important;
  align-items: center;
  justify-content: center;
  padding: var(--mpd-wpforms-button-padding) !important;
  border: 1px solid var(--mpd-wpforms-button-border-color) !important;
  border-radius: var(--mpd-wpforms-button-radius) !important;
  background: var(--mpd-wpforms-button-background) !important;
  box-shadow: var(--mpd-wpforms-button-shadow) !important;
  color: var(--mpd-wpforms-button-color) !important;
  fill: currentColor;
  font: inherit;
  font-size: var(--mpd-font-size-btn);
  font-weight: 700;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  text-transform: var(--mpd-button-text-transform);
  cursor: pointer;
  transition: var(--mpd-button-transition);
}

.wpforms-container .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]):hover,
.wpforms-container .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]):focus-visible,
div.wpforms-container-full .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]):hover,
div.wpforms-container-full .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]):focus-visible {
  border-color: var(--mpd-wpforms-button-hover-border-color) !important;
  background: var(--mpd-wpforms-button-hover-background) !important;
  box-shadow: var(--mpd-wpforms-button-hover-shadow) !important;
  color: var(--mpd-wpforms-button-hover-color) !important;
  outline: none;
  transform: var(--mpd-wpforms-button-hover-transform);
}

.wpforms-container .wpforms-form button.wpforms-page-prev,
div.wpforms-container-full .wpforms-form button.wpforms-page-prev {
  border-color: var(--mpd-wpforms-secondary-button-border-color) !important;
  background: var(--mpd-wpforms-secondary-button-background) !important;
  color: var(--mpd-wpforms-secondary-button-color) !important;
}

.wpforms-container .wpforms-form button.wpforms-page-prev:hover,
.wpforms-container .wpforms-form button.wpforms-page-prev:focus-visible,
div.wpforms-container-full .wpforms-form button.wpforms-page-prev:hover,
div.wpforms-container-full .wpforms-form button.wpforms-page-prev:focus-visible {
  border-color: var(--mpd-wpforms-secondary-button-hover-border-color) !important;
  background: var(--mpd-wpforms-secondary-button-hover-background) !important;
  color: var(--mpd-wpforms-secondary-button-hover-color) !important;
}

.wpforms-container .wpforms-form :where(button, input, textarea, select):disabled,
.wpforms-container .wpforms-form [aria-disabled="true"],
div.wpforms-container-full .wpforms-form :where(button, input, textarea, select):disabled,
div.wpforms-container-full .wpforms-form [aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.58;
  transform: none;
}

.wpforms-container .wpforms-page-indicator,
div.wpforms-container-full .wpforms-form .wpforms-page-indicator {
  margin: 0 0 var(--mpd-gap-md);
}

.wpforms-container .wpforms-page-indicator-page,
div.wpforms-container-full .wpforms-form .wpforms-page-indicator-page {
  border-color: var(--mpd-wpforms-secondary-button-border-color);
  color: inherit;
  font-family: inherit;
}

.wpforms-container .wpforms-confirmation-container-full,
.wpforms-container div[submit-success],
div.wpforms-container-full .wpforms-confirmation-container-full,
div.wpforms-container-full div[submit-success] {
  border: var(--mpd-wpforms-field-border);
  border-radius: var(--mpd-radius);
  background: var(--mpd-wpforms-field-background);
  color: var(--mpd-wpforms-field-color);
}

@media (prefers-reduced-motion: reduce) {
  .wpforms-container .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]),
  div.wpforms-container-full .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]) {
    transition: none;
  }

  .wpforms-container .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]):hover,
  .wpforms-container .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]):focus-visible,
  div.wpforms-container-full .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]):hover,
  div.wpforms-container-full .wpforms-form :where(button.wpforms-page-button, button.wpforms-submit, input[type="submit"]):focus-visible {
    transform: none;
  }
}

.mpd-site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid rgba(222, 223, 230, 0.75);
  backdrop-filter: blur(14px);
}

.mpd-site-header.is-scrolled {
  box-shadow: var(--mpd-shadow-lg);
}

.mpd-header-inner,
.mpd-footer-inner,
.mpd-footer-bottom {
  width: var(--mpd-wide);
  margin: 0 auto;
}

.mpd-header-inner {
  min-height: 76px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: center;
}

.mpd-brand-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  font-weight: 800;
}

.mpd-brand-mark {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: var(--mpd-radius);
  background: var(--mpd-color-pink);
  color: white;
  font-size: 0.9rem;
}

.custom-logo-link img {
  max-width: 220px;
  height: auto;
}

.mpd-primary-menu,
.mpd-footer-menu {
  display: flex;
  gap: 18px;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.mpd-primary-nav {
  justify-self: center;
}

.mpd-primary-menu a,
.mpd-footer-menu a {
  text-decoration: none;
  color: var(--mpd-color-ink);
}

.mpd-primary-menu a:hover,
.mpd-footer-menu a:hover {
  color: var(--mpd-color-pink);
}

.mpd-header-actions {
  display: inline-flex;
  gap: 12px;
  align-items: center;
}

.mpd-phone-link {
  color: var(--mpd-color-muted);
  text-decoration: none;
  white-space: nowrap;
}

.mpd-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 18px;
  border: 1px solid var(--mpd-color-pink);
  border-radius: var(--mpd-button-radius);
  background: var(--mpd-color-pink);
  color: white;
  font-weight: 750;
  box-shadow: var(--mpd-shadow-md);
  text-decoration: none;
  text-transform: var(--mpd-button-text-transform);
  transition: var(--mpd-button-transition);
}

.mpd-button:hover,
.mpd-button:focus {
  box-shadow: var(--mpd-shadow-lg);
  transform: scale(1.015);
}

.mpd-button:active {
  box-shadow: var(--mpd-shadow-null);
  transform: scale(0.985);
}

.mpd-button-small {
  min-height: 40px;
  padding: 9px 14px;
}

.mpd-button-muted {
  background: var(--mpd-color-surface);
  border-color: var(--mpd-color-line);
  color: var(--mpd-color-ink);
}

.mpd-button-outline {
  background: transparent;
  color: var(--mpd-color-surface);
  border-color: rgba(255, 255, 255, 0.42);
}

.mpd-menu-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--mpd-color-line);
  border-radius: var(--mpd-radius);
  background: var(--mpd-color-surface);
  color: var(--mpd-color-ink);
}

.mpd-menu-toggle-bars,
.mpd-menu-toggle-bars::before,
.mpd-menu-toggle-bars::after {
  display: block;
  width: 20px;
  height: 2px;
  background: currentColor;
  margin: 0 auto;
  content: "";
}

.mpd-menu-toggle-bars::before {
  transform: translateY(-7px);
}

.mpd-menu-toggle-bars::after {
  transform: translateY(5px);
}

.mpd-main {
  min-height: 60vh;
}

.mpd-content-entry,
.mpd-narrow,
.mpd-archive-header {
  width: var(--mpd-width);
  margin: 0 auto;
  padding: 56px 0;
}

.mpd-entry-header,
.mpd-archive-header,
.mpd-error-page {
  --mpd-h1-margin: 0 0 16px;
}

.mpd-entry-summary,
.mpd-archive-description,
.mpd-empty-state p,
.mpd-error-page p {
  color: var(--mpd-color-muted);
  font-size: 1.08rem;
}

.mpd-entry-content {
  background: var(--mpd-color-surface);
  border: 1px solid var(--mpd-color-line);
  border-radius: var(--mpd-radius);
  padding: clamp(22px, 4vw, 42px);
}

.mpd-page-hero {
  position: relative;
  display: flex;
  align-items: stretch;
  justify-content: center;
  width: 100%;
  min-height: clamp(28rem, 64vh, 42rem);
  overflow: hidden;
  background: var(--mpd-color-dark-ink);
  color: var(--mpd-color-light-pure);
}

.mpd-page-hero picture {
  display: contents;
}

.mpd-page-hero-image {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  object-position: center;
}

.mpd-page-hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to top, rgba(20, 20, 24, 0.78), rgba(20, 20, 24, 0.18));
}

.mpd-page-hero::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  height: clamp(5rem, 18vh, 12rem);
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    rgba(19, 20, 28, 0),
    var(--mpd-color-mode-page, var(--mpd-color-canvas)) 92%
  );
}

.mpd-page-hero-content {
  --mpd-heading-color: currentColor;
  position: relative;
  z-index: 2;
  display: flex;
  width: min(var(--mpd-wide), calc(100% - (var(--mpd-page-space) * 2)));
  min-height: inherit;
  margin: 0 auto;
  flex-direction: column;
  justify-content: flex-end;
  gap: var(--mpd-space-md);
  padding: clamp(5rem, 12vh, 8rem) 0 clamp(2rem, 8vh, 4rem);
  text-align: left;
}

.mpd-page-hero-content .mpd-kicker,
.mpd-page-hero-content h1,
.mpd-page-hero-content p {
  max-width: min(100%, 42rem);
  margin: 0;
}

.mpd-page-hero-content .mpd-kicker {
  color: var(--mpd-color-primary-light);
}

.mpd-page-hero-content p {
  color: rgba(255, 255, 255, 0.84);
  font-size: clamp(1rem, 2vw, 1.22rem);
  line-height: 1.45;
}

.mpd-page-hero-content .mpd-page-hero-summary {
  max-width: min(100%, 34rem);
  color: rgba(255, 255, 255, 0.78);
  font-size: clamp(0.94rem, 1.5vw, 1.06rem);
}

.mpd-page-hero-actions {
  display: flex;
  width: min(100%, 42rem);
  flex-wrap: wrap;
  gap: var(--mpd-space-sm);
}

.mpd-page-hero-cta {
  min-width: 0;
  white-space: normal;
}

.mpd-entry-image {
  margin: 0 auto 28px;
  width: var(--mpd-width);
}

.mpd-entry-image img {
  width: 100%;
  border-radius: var(--mpd-radius);
}

.mpd-post-grid {
  width: var(--mpd-wide);
  margin: 0 auto 72px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.mpd-post-card {
  background: var(--mpd-color-surface);
  border: 1px solid var(--mpd-color-line);
  border-radius: var(--mpd-radius);
  overflow: hidden;
}

.mpd-post-card a {
  display: block;
  height: 100%;
  text-decoration: none;
}

.mpd-post-card-image img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.mpd-post-card-body {
  display: grid;
  gap: 8px;
  padding: 18px;
}

.mpd-post-card {
  --mpd-h2-margin: 0;
}

.mpd-post-card-body span {
  color: var(--mpd-color-muted);
}

.mpd-catalog-archive {
  --mpd-catalog-page-background: var(--mpd-color-light-canvas);
  --mpd-catalog-text: var(--mpd-color-dark-ink);
  --mpd-catalog-heading: var(--mpd-color-dark-graphite);
  --mpd-catalog-muted: var(--mpd-color-muted);
  --mpd-catalog-muted-soft: var(--mpd-color-dark-silver);
  --mpd-catalog-surface: var(--mpd-color-light-pure);
  --mpd-catalog-line: var(--mpd-color-line);
  --mpd-catalog-accent: var(--mpd-color-primary);
  --mpd-catalog-card-gradient: linear-gradient(to top, rgba(0, 0, 0, 0.58), rgba(0, 0, 0, 0));
  --mpd-catalog-hero-padding: calc(var(--mpd-space-xl) + var(--mpd-space-sm)) 0 var(--mpd-space-lg);
  --mpd-catalog-hero-title-max-width: var(--mpd-width);
  --mpd-catalog-breadcrumb-gap: calc(var(--mpd-gap-sm) * 0.875);
  --mpd-catalog-section-gap: var(--mpd-section-gap);
  --mpd-catalog-grid-gap: var(--mpd-grid-gap);
  --mpd-catalog-card-body-padding: calc(var(--mpd-space-xl) + var(--mpd-space-xs)) var(--mpd-space-sm) var(--mpd-space-sm);
  --mpd-heading-color: var(--mpd-catalog-heading);
  background: var(--mpd-catalog-page-background);
  color: var(--mpd-catalog-text);
  font-family: var(--mpd-font-family-base);
  padding-bottom: var(--mpd-catalog-section-gap);
}

.mpd-catalog-hero,
.mpd-catalog-directory-header,
.mpd-collection-section,
.mpd-catalog-result-count,
.mpd-catalog-grid,
.mpd-pagination,
.mpd-collection-content {
  width: var(--mpd-wide);
  margin-inline: auto;
}

.mpd-catalog-hero,
.mpd-catalog-directory-header {
  --mpd-h1-margin: 0;
  display: grid;
  justify-items: center;
  gap: var(--mpd-space-md);
  padding: var(--mpd-catalog-hero-padding);
  text-align: center;
}

.mpd-catalog-directory-header {
  width: var(--mpd-width);
}

.mpd-collection-hero-icon {
  width: clamp(190px, 34vw, 430px);
  margin: 0;
}

.mpd-collection-hero-icon img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

.mpd-catalog-hero h1,
.mpd-catalog-directory-header h1 {
  max-width: var(--mpd-catalog-hero-title-max-width);
}

.mpd-collection-hero-quote {
  --mpd-ui-button-border-color: var(--mpd-color-dark-silver);
  --mpd-ui-button-shadow: var(--mpd-shadow-md);
  --mpd-ui-button-hover-border-color: var(--mpd-color-primary);
  min-width: min(100%, 270px);
}

.mpd-catalog-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: var(--mpd-catalog-breadcrumb-gap);
  align-items: center;
  justify-content: center;
  padding: 0;
  color: var(--mpd-catalog-muted-soft);
  font-size: 1rem;
  text-align: center;
}

.mpd-catalog-breadcrumb a,
.mpd-catalog-breadcrumb a:visited {
  color: inherit;
  text-decoration: none;
}

.mpd-catalog-breadcrumb a:hover,
.mpd-catalog-breadcrumb a:focus-visible {
  color: var(--mpd-catalog-accent);
}

.mpd-collection-hero-description {
  max-width: min(760px, 100%);
  color: var(--mpd-catalog-muted);
  font-size: 1.05rem;
  line-height: 1.5;
  text-align: center;
  overflow-wrap: break-word;
}

.mpd-collection-page .mpd-service-gallery {
  --mpd-service-heading: var(--mpd-catalog-heading);
  --mpd-service-surface: var(--mpd-catalog-surface);
  --mpd-service-pink: var(--mpd-color-primary-light);
  --mpd-service-control-surface: var(--mpd-color-light-transparent-2);
  --mpd-service-control-overlay: rgba(79, 80, 86, 0.38);
  --mpd-service-dark-overlay: rgba(39, 39, 47, 0.72);
  --mpd-service-lightbox-offset: 96px;
  --mpd-service-modal-padding: var(--mpd-space-lg);
  --mpd-service-gallery-border-width: 2px;
  --mpd-service-gallery-border: var(--mpd-service-gallery-border-width) solid var(--mpd-service-pink);
  --mpd-service-control-offset: var(--mpd-space-sm);
  --mpd-service-control-size: calc(var(--mpd-button-size-s) * 1.14);
  --mpd-service-nav-size: calc(var(--mpd-button-size-s) * 1.25);
  --mpd-service-nav-font-size: calc(var(--mpd-font-size-lg) * 1.7);
  --mpd-service-dot-size: calc(var(--mpd-space-sm) * 0.78);
  width: min(100%, calc(100vw - (var(--mpd-page-gutter) * 2)));
  margin-inline: auto;
}

@media (max-width: 760px) {
  .mpd-collection-page .mpd-service-gallery {
    --mpd-service-lightbox-offset: 32px;
  }
}

.mpd-collection-hero-description > :first-child,
.mpd-collection-content > :first-child {
  margin-top: 0;
}

.mpd-collection-hero-description > :last-child,
.mpd-collection-content > :last-child {
  margin-bottom: 0;
}

.mpd-catalog-archive > :last-child,
.mpd-collection-section > :last-child {
  margin-bottom: 0;
}

.mpd-collection-section {
  --mpd-h2-margin: 0 0 var(--mpd-space-lg);
  margin-bottom: var(--mpd-catalog-section-gap);
}

.mpd-catalog-result-count {
  margin-top: 0;
  margin-bottom: var(--mpd-space-lg);
  color: var(--mpd-catalog-heading);
  font-size: 0.95rem;
}

.mpd-catalog-grid {
  --mpd-catalog-grid-columns: var(--mpd-catalog-grid-mobile, 2);
  display: grid;
  grid-template-columns: repeat(var(--mpd-catalog-grid-columns), minmax(0, 1fr));
  gap: var(--mpd-catalog-grid-gap);
  margin-bottom: var(--mpd-catalog-section-gap);
}

.mpd-catalog-grid .mpd-service-card,
.mpd-catalog-grid .mpd-collection-card {
  position: relative;
  min-width: 0;
  overflow: hidden;
  border: 0;
  border-radius: var(--mpd-radius);
  background: var(--mpd-catalog-line);
  box-shadow: var(--mpd-shadow-sm);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.mpd-catalog-grid .mpd-service-card:hover,
.mpd-catalog-grid .mpd-service-card:focus-within,
.mpd-catalog-grid .mpd-collection-card:hover,
.mpd-catalog-grid .mpd-collection-card:focus-within {
  box-shadow: var(--mpd-shadow-md);
  transform: scale(1.01);
}

.mpd-catalog-grid .mpd-service-card:active,
.mpd-catalog-grid .mpd-collection-card:active {
  box-shadow: var(--mpd-shadow-null);
  transform: scale(0.99);
}

.mpd-catalog-grid .mpd-service-card a,
.mpd-catalog-grid .mpd-collection-card a {
  position: relative;
  display: block;
  min-height: 100%;
  color: inherit;
  text-decoration: none;
}

.mpd-catalog-grid .mpd-service-card-image,
.mpd-catalog-grid .mpd-collection-card-image {
  display: block;
  background: var(--mpd-catalog-surface);
}

.mpd-catalog-grid .mpd-service-card-image img,
.mpd-catalog-grid .mpd-collection-card-image img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
}

.mpd-catalog-grid .mpd-collection-card-image img {
  object-fit: contain;
}

.mpd-catalog-grid .mpd-service-card-body,
.mpd-catalog-grid .mpd-collection-card-body {
  position: absolute;
  inset: auto 0 0;
  display: grid;
  gap: 0;
  min-height: 34%;
  align-content: end;
  padding: var(--mpd-catalog-card-body-padding);
  background: var(--mpd-catalog-card-gradient);
  color: var(--mpd-color-light-pure);
}

.mpd-catalog-grid .mpd-service-card-title,
.mpd-catalog-grid .mpd-collection-card-title {
  color: inherit;
  font-size: clamp(1rem, 1.45vw, 1.18rem);
  font-weight: 500;
  line-height: 1.08;
  text-align: center;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.35);
}

.mpd-catalog-grid .mpd-service-card-text,
.mpd-catalog-grid .mpd-collection-card-text {
  display: none;
}

.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card {
  aspect-ratio: 1 / 1;
  overflow: visible;
  border-radius: 0;
  background: transparent;
  box-shadow: var(--mpd-shadow-null);
  transition: none;
}

.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card:hover,
.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card:focus-within,
.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card:active {
  box-shadow: var(--mpd-shadow-null);
  transform: none;
}

.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card a {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  min-height: 0;
  height: 100%;
  color: var(--mpd-catalog-text);
}

.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card-image {
  display: flex;
  align-items: end;
  justify-content: center;
  min-height: 0;
  padding: 0 var(--mpd-space-xs);
  background: transparent;
}

.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card-image img {
  width: 100%;
  height: 100%;
  max-height: 100%;
  aspect-ratio: auto;
  object-fit: contain;
}

.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card-body {
  position: static;
  min-height: 0;
  padding: var(--mpd-space-sm) 0 0;
  background: transparent;
  color: var(--mpd-catalog-text);
}

.mpd-collections-directory .mpd-catalog-grid .mpd-collection-card-title {
  color: var(--mpd-catalog-text);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.12;
  text-shadow: none;
  text-transform: uppercase;
  overflow-wrap: anywhere;
}

.mpd-collection-content {
  width: var(--mpd-width);
  margin-bottom: var(--mpd-catalog-section-gap);
  color: var(--mpd-catalog-heading);
  font-size: 1.02rem;
  line-height: 1.75;
}

.mpd-collection-delivery-note {
  font-weight: 400;
}

.mpd-collection-delivery-note a {
  color: inherit;
  text-decoration-color: var(--mpd-catalog-accent);
  text-decoration-thickness: 0.06em;
  text-underline-offset: 0.16em;
}

.mpd-pagination {
  --mpd-ui-button-size: 45px;
  --mpd-ui-button-height: 45px;
  --mpd-ui-button-padding: 0;
  --mpd-ui-button-background: var(--mpd-catalog-surface);
  --mpd-ui-button-border-color: var(--mpd-color-primary-light);
  --mpd-ui-button-color: var(--mpd-catalog-accent);
  --mpd-ui-button-hover-background: var(--mpd-catalog-surface);
  --mpd-ui-button-hover-border-color: var(--mpd-catalog-accent);
  --mpd-ui-button-hover-color: var(--mpd-catalog-accent);
  --mpd-ui-button-hover-shadow: var(--mpd-shadow-md);
  display: flex;
  flex-wrap: wrap;
  gap: var(--mpd-gap-sm);
  align-items: center;
  justify-content: center;
  margin-top: calc(var(--mpd-space-lg) * -0.25);
  margin-bottom: var(--mpd-catalog-section-gap);
}

.mpd-collection-section .mpd-pagination {
  width: 100%;
  margin-top: var(--mpd-space-lg);
}

.mpd-pagination :is(a, span) {
  width: var(--mpd-ui-button-size);
  min-width: var(--mpd-ui-button-size);
  height: var(--mpd-ui-button-size);
  min-height: var(--mpd-ui-button-size);
  border-radius: 50%;
  font-size: 1.15rem;
}

.mpd-pagination span[aria-current="page"] {
  --mpd-ui-button-background: var(--mpd-catalog-accent);
  --mpd-ui-button-border-color: var(--mpd-catalog-accent);
  --mpd-ui-button-color: var(--mpd-catalog-surface);
  --mpd-ui-button-shadow: var(--mpd-shadow-md);
  background: var(--mpd-catalog-accent);
  color: var(--mpd-catalog-surface);
}

@media (max-width: 699px) {
  .mpd-collection-page .mpd-collection-hero--has-slider {
    --mpd-collection-hero-viewport-offset: 0px;
    --mpd-collection-hero-visible-height: calc(var(--mpd-vh, 100vh) - var(--mpd-collection-hero-viewport-offset));
    --mpd-collection-hero-padding-block: clamp(0.75rem, 2vh, 1.15rem);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: clamp(0.45rem, 1.2vh, 0.75rem);
    height: var(--mpd-collection-hero-visible-height);
    min-height: var(--mpd-collection-hero-visible-height);
    overflow: visible;
    padding-block: var(--mpd-collection-hero-padding-block);
  }

  .mpd-collection-page .mpd-collection-hero--has-slider.mpd-collection-hero--height-animating {
    transition: height 220ms ease-out, min-height 220ms ease-out;
    will-change: height, min-height;
  }

  .mpd-collection-page .mpd-collection-hero--has-slider .mpd-catalog-slider--full-height-mobile,
  .mpd-collection-page .mpd-collection-hero--has-slider .mpd-catalog-slider--full-height-mobile .mpd-service-gallery-main,
  .mpd-collection-page .mpd-collection-hero--has-slider .mpd-catalog-slider--full-height-mobile .mpd-service-gallery-viewer {
    height: auto;
  }

  .mpd-collection-page .mpd-collection-hero--has-slider .mpd-catalog-slider--full-height-mobile .mpd-slider-x-wrap {
    height: var(--mpd-collection-hero-slider-track-height, min(52vh, 28rem));
  }

  .mpd-collection-page .mpd-collection-hero--has-slider.mpd-collection-hero--height-animating .mpd-slider-x-wrap {
    transition: height 220ms ease-out;
    will-change: height;
  }

  .mpd-collection-page .mpd-collection-hero--has-slider .mpd-gallery-dots {
    margin-top: clamp(0.1rem, 0.7vh, 0.35rem);
  }

  .mpd-collection-page .mpd-collection-hero--has-slider .mpd-gallery-dot,
  .mpd-collection-page .mpd-collection-hero--has-slider .mpd-gallery-dots .mpd-slider-x-dot {
    width: clamp(32px, 5.2vh, 40px);
    height: clamp(32px, 5.2vh, 40px);
  }

  .mpd-collection-page .mpd-catalog-breadcrumb {
    font-size: clamp(0.88rem, 3.7vw, 1rem);
  }

  .mpd-collection-page .mpd-collection-hero-description {
    max-width: min(100%, 36rem);
    font-size: clamp(0.94rem, 3.8vw, 1.04rem);
    line-height: 1.38;
  }

  .mpd-collection-hero-icon {
    width: 100%;
    max-width: 26rem;
  }

  .mpd-collection-hero-icon img {
    width: 100%;
    max-height: 26rem;
  }
}

@media (max-width: 699px) and (max-height: 700px) {
  .mpd-collection-page .mpd-collection-hero--has-slider {
    --mpd-collection-hero-padding-block: clamp(0.55rem, 1.6vh, 0.9rem);
    gap: clamp(0.35rem, 1vh, 0.55rem);
  }

  .mpd-collection-page .mpd-catalog-breadcrumb {
    font-size: 0.86rem;
  }

  .mpd-collection-page .mpd-collection-hero-description {
    font-size: 0.92rem;
    line-height: 1.32;
  }
}

@media (max-width: 699px) and (min-height: 820px) {
  .mpd-collection-page .mpd-collection-hero--has-slider .mpd-collection-hero-description {
    line-height: 1.42;
  }
}

@media (max-width: 699px) and (prefers-reduced-motion: reduce) {
  .mpd-collection-page .mpd-collection-hero--has-slider.mpd-collection-hero--height-animating,
  .mpd-collection-page .mpd-collection-hero--has-slider.mpd-collection-hero--height-animating .mpd-slider-x-wrap {
    transition: none;
  }
}

@media (min-width: 700px) {
  .mpd-catalog-grid {
    --mpd-catalog-grid-columns: var(--mpd-catalog-grid-tablet-portrait, 3);
  }
}

@media (min-width: 980px) {
  .mpd-catalog-grid {
    --mpd-catalog-grid-columns: var(--mpd-catalog-grid-tablet-landscape, 4);
  }
}

@media (min-width: 1280px) {
  .mpd-catalog-grid {
    --mpd-catalog-grid-columns: var(--mpd-catalog-grid-desktop, 5);
  }
}

@media (min-width: 1680px) {
  .mpd-catalog-grid {
    --mpd-catalog-grid-columns: var(--mpd-catalog-grid-wide, 5);
  }
}

.mpd-site-footer {
  background: var(--mpd-color-ink);
  color: var(--mpd-color-surface);
  margin-top: 72px;
}

.mpd-footer-inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 32px;
  padding: 46px 0;
}

.mpd-footer-brand {
  --mpd-h2-margin: 0 0 10px;
}

.mpd-footer-brand p {
  color: rgba(255, 255, 255, 0.72);
}

.mpd-footer-menu {
  display: grid;
  gap: 10px;
}

.mpd-footer-menu a,
.mpd-footer-social a,
.mpd-footer-legal a {
  color: rgba(255, 255, 255, 0.82);
}

.mpd-footer-social {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-content: start;
}

.mpd-footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.16);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 0;
  color: rgba(255, 255, 255, 0.72);
}

.mpd-footer-legal {
  display: inline-flex;
  gap: 14px;
}

.mpd-kicker {
  color: var(--mpd-color-blue);
  font-size: 0.78rem;
  font-weight: 850;
  letter-spacing: 0.08em;
  margin: 0 0 12px;
  text-transform: var(--mpd-ui-label-text-transform);
}

.mpd-content-cta {
  --mpd-heading-color: inherit;
  --mpd-h1-margin: 0;
  --mpd-h2-margin: 0;
  --mpd-h3-margin: 0;
  --mpd-h4-margin: 0;
  display: grid;
  width: 100%;
  max-width: var(--mpd-content-cta-max-width);
  gap: var(--mpd-content-cta-gap);
  justify-items: center;
  margin: var(--mpd-content-cta-margin-block) auto;
  padding: var(--mpd-content-cta-padding-block) var(--mpd-content-cta-padding-inline);
  border-radius: var(--mpd-content-cta-radius);
  background: var(--mpd-content-cta-background);
  color: var(--mpd-content-cta-color);
  text-align: center;
}

.mpd-content-cta > * {
  color: var(--mpd-content-cta-color);
}

.mpd-content-cta > :first-child {
  margin-top: 0;
}

.mpd-content-cta > :last-child {
  margin-bottom: 0;
}

.mpd-content-cta :where(h1, h2, h3, h4, p) {
  width: min(100%, var(--mpd-content-cta-copy-max-width));
}

.mpd-content-cta p {
  margin: 0;
}

.mpd-content-cta .mpd-button-container {
  display: flex;
  justify-content: center;
}

@media (max-width: 760px) {
  .mpd-content-cta {
    --mpd-content-cta-radius: 0;
    --mpd-content-cta-padding-block: calc(var(--mpd-space-xl) * 1.2);
    --mpd-content-cta-padding-inline: var(--mpd-page-space);
    width: var(--mpd-full-bleed-width);
    max-width: none;
    margin-inline: var(--mpd-full-bleed-margin-inline);
  }
}

@keyframes mpd-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes mpd-fade-out {
  from { opacity: 1; }
  to { opacity: 0; }
}

@keyframes mpd-slide-in-top {
  from {
    opacity: 0;
    transform: translateY(-40px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes mpd-slide-out-top {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-40px);
  }
}

@keyframes mpd-popup-slide-out-down {
    from {
        opacity: 1;
        transform: translateY(0);
    }

    to {
        opacity: 0;
        transform: translateY(40px);
    }
}

@keyframes mpd-popup-backdrop-in {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes mpd-popup-backdrop-out {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
    }
}

@keyframes mpd-slide-in-left {
  from {
    opacity: 0;
    transform: translateX(-60px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes mpd-slide-out-left {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(-60px);
  }
}

@media (max-width: 980px) {
  .mpd-header-inner {
    grid-template-columns: auto auto;
  }

  .mpd-menu-toggle {
    display: inline-grid;
    place-items: center;
    justify-self: end;
  }

  .mpd-primary-nav {
    display: none;
    grid-column: 1 / -1;
    justify-self: stretch;
    padding-bottom: 18px;
  }

  .mpd-primary-nav.is-open {
    display: block;
  }

  .mpd-primary-menu {
    display: grid;
    gap: 4px;
  }

  .mpd-primary-menu a {
    display: block;
    padding: 12px 0;
  }

  .mpd-header-actions {
    grid-column: 1 / -1;
    justify-content: space-between;
    padding-bottom: 14px;
  }

  .mpd-post-grid,
  .mpd-footer-inner {
    grid-template-columns: 1fr;
  }

  .mpd-catalog-hero {
    gap: var(--mpd-space-sm);
  }
}

@media (max-width: 640px) {
  .mpd-header-inner {
    min-height: 68px;
    gap: 12px;
  }

  .mpd-brand-name,
  .mpd-phone-link {
    display: none;
  }

  .mpd-content-entry,
  .mpd-narrow,
  .mpd-archive-header,
  .mpd-collection-hero {
    padding: 36px 0;
  }

  .mpd-entry-content {
    padding: 20px;
  }

  .mpd-page-hero {
    min-height: min(70svh, 42rem);
  }

  .mpd-page-hero-content {
    width: min(100% - 1.5rem, var(--mpd-wide));
    padding-bottom: clamp(2rem, 8vh, 4rem);
  }

  .mpd-footer-bottom {
    display: grid;
  }
}
