:root {
  --emm-font-body: "Avenir Next", "Neue Haas Unica", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --emm-font-display: "IvyPresto Display", "Canela", "Times New Roman", Georgia, serif;
  --emm-font-mono: "SFMono-Regular", Menlo, Consolas, monospace;

  --emm-color-paper: #f7f4ef;
  --emm-color-ivory: #fbf9f5;
  --emm-color-white: #ffffff;
  --emm-color-ink: #15181d;
  --emm-color-ink-soft: #262c34;
  --emm-color-muted: #66717d;
  --emm-color-line: #d9d2c8;
  --emm-color-line-strong: #bfb5a8;
  --emm-color-accent: #1d324d;
  --emm-color-accent-soft: #edf2f7;
  --emm-color-success: #2d6a4f;
  --emm-color-warning: #946200;
  --emm-color-danger: #7f1f1f;

  --emm-step--2: clamp(0.72rem, 0.7rem + 0.12vw, 0.8rem);
  --emm-step--1: clamp(0.82rem, 0.78rem + 0.2vw, 0.95rem);
  --emm-step-0: clamp(0.96rem, 0.92rem + 0.25vw, 1.08rem);
  --emm-step-1: clamp(1.14rem, 1.02rem + 0.48vw, 1.34rem);
  --emm-step-2: clamp(1.38rem, 1.16rem + 0.8vw, 1.85rem);
  --emm-step-3: clamp(1.7rem, 1.3rem + 1.25vw, 2.55rem);
  --emm-step-4: clamp(2rem, 1.45rem + 2vw, 3.35rem);

  --emm-space-1: 0.25rem;
  --emm-space-2: 0.5rem;
  --emm-space-3: 0.75rem;
  --emm-space-4: 1rem;
  --emm-space-5: 1.25rem;
  --emm-space-6: 1.5rem;
  --emm-space-8: 2rem;
  --emm-space-10: 2.5rem;
  --emm-space-12: 3rem;
  --emm-space-14: 3.5rem;
  --emm-space-16: 4rem;

  --emm-radius-sm: 0.35rem;
  --emm-radius-md: 0.6rem;
  --emm-radius-lg: 0.9rem;
  --emm-radius-pill: 999px;

  --emm-border-hairline: 1px solid var(--emm-color-line);
  --emm-shadow-subtle: 0 8px 30px rgba(23, 26, 31, 0.05);

  --emm-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --emm-time-fast: 150ms;
  --emm-time-base: 200ms;
  --emm-time-slow: 250ms;

  --emm-page-pad: clamp(1rem, 2vw, 2rem);
  --emm-container-max: 78rem;
  --emm-section-pad: clamp(2.5rem, 7vw, 5.5rem);
  --emm-z-overlay: 130;
  --emm-z-header: 150;
  --emm-z-search: 155;
  --emm-z-drawer: 170;
  --emm-overlay-top: 0px;
  --emm-search-max-height: calc(100dvh - 4.35rem);
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

.emm-skip-link {
  position: absolute;
  left: var(--emm-space-4);
  top: -100%;
  z-index: 10000;
  background: var(--emm-color-ink);
  color: var(--emm-color-white);
  padding: var(--emm-space-3) var(--emm-space-4);
  border-radius: var(--emm-radius-sm);
  text-decoration: none;
}

.emm-skip-link:focus-visible {
  top: var(--emm-space-4);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  border: 0;
  white-space: nowrap;
}

.emm-section {
  background: var(--emm-section-bg, var(--emm-color-ivory));
  padding-block: var(--emm-section-pad, var(--emm-section-pad));
}

.emm-section--page {
  padding-top: clamp(1rem, 2.2vw, 1.8rem);
  padding-bottom: clamp(2.5rem, 5vw, 4.5rem);
}

.emm-section[data-emm-tone="paper"] {
  --emm-section-bg: var(--emm-color-paper);
}

.emm-section[data-emm-tone="white"] {
  --emm-section-bg: var(--emm-color-white);
}

.emm-section[data-emm-tone="ink"] {
  --emm-section-bg: var(--emm-color-ink);
  color: #f3eee6;
}

.emm-section[data-emm-tone="ink"] .emm-kicker,
.emm-section[data-emm-tone="ink"] .emm-copy,
.emm-section[data-emm-tone="ink"] .emm-muted,
.emm-section[data-emm-tone="ink"] .emm-link {
  color: rgba(243, 238, 230, 0.78);
}

.emm-section[data-emm-tone="ink"] .emm-title,
.emm-section[data-emm-tone="ink"] .emm-price {
  color: #f7f3eb;
}

.emm-section[data-emm-tone="ink"] .emm-card,
.emm-section[data-emm-tone="ink"] .emm-field,
.emm-section[data-emm-tone="ink"] .emm-btn--secondary,
.emm-section[data-emm-tone="ink"] .emm-btn--ghost,
.emm-section[data-emm-tone="ink"] .emm-faq details {
  border-color: rgba(243, 238, 230, 0.28);
  background: rgba(255, 255, 255, 0.04);
}

.emm-section[data-emm-tone="ink"] .emm-btn--primary {
  background: #f7f2e8;
  color: #171a1f;
}

.emm-container {
  width: min(var(--emm-container-max), calc(100% - (var(--emm-page-pad) * 2)));
  margin-inline: auto;
}

.emm-stack {
  display: grid;
  gap: var(--emm-space-4);
}

.emm-stack--sm {
  gap: var(--emm-space-2);
}

.emm-stack--lg {
  gap: var(--emm-space-8);
}

.emm-page-shell {
  display: grid;
  gap: var(--emm-space-8);
}

.emm-page-shell--tight {
  gap: var(--emm-space-6);
}

.emm-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--emm-space-4);
}

.emm-hairline {
  border-top: var(--emm-border-hairline);
}

.emm-kicker {
  font-size: var(--emm-step--2);
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0.02em;
  color: var(--emm-color-muted);
}

.emm-title {
  margin: 0;
  font-family: var(--emm-font-display);
  font-size: var(--emm-step-3);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--emm-color-ink);
  text-wrap: balance;
}

.emm-title--display {
  font-family: var(--emm-font-display);
  letter-spacing: -0.01em;
  line-height: 1.02;
}

/* Keep body copy readable, but align section heading typography with hero. */
.emm-section:not(.emm-hero) .emm-title,
.emm-collection-card__title,
.emm-value__title,
.emm-site-footer__title {
  font-family: var(--emm-font-display);
  letter-spacing: -0.01em;
}

.emm-title--sm {
  font-size: var(--emm-step-2);
}

.emm-copy {
  margin: 0;
  max-width: 56ch;
  color: var(--emm-color-ink-soft);
  font-size: var(--emm-step-0);
  line-height: 1.62;
}

.emm-muted {
  color: var(--emm-color-muted);
  font-size: var(--emm-step--1);
}

.emm-link {
  color: var(--emm-color-ink);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--emm-color-ink) 40%, transparent);
  transition: border-color var(--emm-time-base) var(--emm-ease), color var(--emm-time-base) var(--emm-ease);
}

.emm-link:hover {
  color: var(--emm-color-accent);
  border-color: currentColor;
}

.emm-grid {
  display: grid;
  gap: var(--emm-space-6);
}

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

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

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

.emm-card {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  background: var(--emm-color-white);
}

.emm-btn {
  --emm-btn-bg: var(--emm-color-ink);
  --emm-btn-fg: var(--emm-color-white);
  --emm-btn-border: var(--emm-color-ink);
  appearance: none;
  border: 1px solid var(--emm-btn-border);
  background: var(--emm-btn-bg);
  color: var(--emm-btn-fg);
  font-size: var(--emm-step--1);
  font-weight: 600;
  letter-spacing: 0.01em;
  min-height: 2.75rem;
  padding: 0.65rem 1.25rem;
  border-radius: var(--emm-radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  text-decoration: none;
  cursor: pointer;
  transition: transform var(--emm-time-base) var(--emm-ease), background var(--emm-time-base) var(--emm-ease), border-color var(--emm-time-base) var(--emm-ease), color var(--emm-time-base) var(--emm-ease);
}

.emm-btn:hover {
  transform: translateY(-1px);
}

.emm-btn:active {
  transform: translateY(0);
}

.emm-btn--secondary {
  --emm-btn-bg: transparent;
  --emm-btn-fg: var(--emm-color-ink);
  --emm-btn-border: var(--emm-color-line-strong);
}

.emm-btn--secondary:hover {
  --emm-btn-bg: var(--emm-color-paper);
}

.emm-btn--ghost {
  --emm-btn-bg: transparent;
  --emm-btn-fg: var(--emm-color-ink);
  --emm-btn-border: transparent;
  border-radius: 0;
  padding-inline: 0;
  min-height: auto;
  border-bottom: 1px solid currentColor;
}

.emm-btn--ghost:hover {
  color: var(--emm-color-accent);
}

.emm-field {
  appearance: none;
  width: 100%;
  min-height: 2.9rem;
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-pill);
  background: var(--emm-color-white);
  color: var(--emm-color-ink);
  font-size: var(--emm-step-0);
  padding: 0.65rem 1rem;
  line-height: 1.4;
}

textarea.emm-field {
  min-height: 7.5rem;
  border-radius: var(--emm-radius-md);
  resize: vertical;
  padding: 0.9rem 1rem;
}

.emm-field::placeholder {
  color: color-mix(in srgb, var(--emm-color-muted) 80%, white);
}

.emm-field:focus-visible,
.emm-btn:focus-visible,
a:focus-visible,
button:focus-visible,
summary:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--emm-color-accent) 60%, white);
  outline-offset: 2px;
}

.emm-announcement {
  font-size: var(--emm-step--1);
  line-height: 1.45;
  border-bottom: var(--emm-border-hairline);
}

.emm-announcement__inner {
  min-height: 2.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--emm-space-3);
  position: relative;
  padding-block: 0.4rem;
}

.emm-announcement__dismiss {
  position: absolute;
  inset-inline-end: 0;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: transparent;
  color: currentColor;
  font-size: 1rem;
  line-height: 1;
  width: 2rem;
  height: 2rem;
}

.emm-body {
  margin: 0;
  font-family: var(--emm-font-body);
  color: var(--emm-color-ink);
  background: var(--emm-color-ivory);
}

.emm-header {
  position: sticky;
  top: 0;
  z-index: var(--emm-z-header);
  background: color-mix(in srgb, var(--emm-color-ivory) 92%, #ffffff);
  border-bottom: var(--emm-border-hairline);
  backdrop-filter: saturate(140%) blur(10px);
}

.emm-header__announcement-slot {
  border-bottom: var(--emm-border-hairline);
}

.emm-header__bar {
  position: relative;
}

.emm-header__inner {
  min-height: 4.9rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: var(--emm-space-4);
  transition: min-height var(--emm-time-base) var(--emm-ease);
}

.emm-header.is-compact .emm-header__inner {
  min-height: 4.2rem;
}

.emm-header__left,
.emm-header__right {
  display: flex;
  align-items: center;
  gap: var(--emm-space-2);
}

.emm-header__left {
  min-width: 0;
}

.emm-header__right {
  justify-self: end;
}

.emm-header__wordmark {
  justify-self: center;
  text-decoration: none;
  color: var(--emm-color-ink);
  font-family: var(--emm-font-display);
  font-size: clamp(1.95rem, 1.45rem + 1.65vw, 2.55rem);
  line-height: 1;
  letter-spacing: -0.02em;
}

.emm-header__wordmark img {
  display: block;
  width: auto;
  height: clamp(1.75rem, 2vw, 2.55rem);
}

.emm-header__menu-btn,
.emm-icon-btn,
.emm-search-panel__close,
.emm-drawer__close {
  min-width: 2.75rem;
  min-height: 2.75rem;
}

.emm-header__menu-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.26rem;
  border: 1px solid transparent;
  border-radius: 50%;
  background: transparent;
  color: var(--emm-color-ink);
  cursor: pointer;
  transition: background var(--emm-time-base) var(--emm-ease), border-color var(--emm-time-base) var(--emm-ease);
}

.emm-header__menu-btn:hover {
  border-color: var(--emm-color-line);
  background: color-mix(in srgb, var(--emm-color-paper) 86%, transparent);
}

.emm-header__menu-btn span {
  display: block;
  width: 1rem;
  height: 1px;
  background: currentColor;
}

.emm-nav--desktop {
  display: none;
}

.emm-nav__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 0.45rem + 0.8vw, 1.45rem);
}

.emm-nav__item {
  position: relative;
}

.emm-nav__link {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  text-decoration: none;
  color: color-mix(in srgb, var(--emm-color-ink) 88%, white);
  font-size: var(--emm-step--2);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: none;
}

.emm-nav__link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0.56rem;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--emm-time-base) var(--emm-ease);
}

.emm-nav__link:hover::after,
.emm-nav__link.is-active::after {
  transform: scaleX(1);
}

.emm-nav__link.is-active {
  color: var(--emm-color-ink);
}

.emm-nav__item--has-submenu {
  display: inline-flex;
  align-items: center;
  gap: 0.18rem;
  position: relative;
}

/* Hover bridge: keeps mega menu open while moving pointer into panel. */
.emm-nav__item--has-submenu::after {
  content: "";
  position: absolute;
  left: -0.75rem;
  right: -0.75rem;
  top: 100%;
  height: 2.1rem;
}

.emm-nav__submenu-toggle {
  min-width: auto;
  min-height: 2rem;
  border: none;
  background: transparent;
  color: color-mix(in srgb, var(--emm-color-ink) 78%, white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0.08rem;
  transition: color var(--emm-time-base) var(--emm-ease), transform var(--emm-time-base) var(--emm-ease);
}

.emm-nav__submenu-toggle svg {
  transition: transform var(--emm-time-base) var(--emm-ease);
}

.emm-nav__submenu-toggle:hover,
.emm-nav__item--has-submenu.is-open .emm-nav__submenu-toggle {
  color: var(--emm-color-ink);
}

.emm-nav__item--has-submenu.is-open .emm-nav__submenu-toggle svg {
  transform: rotate(180deg);
}

.emm-nav__submenu {
  position: fixed;
  top: var(--emm-header-bottom, 4.6rem);
  left: 0;
  right: 0;
  border-top: var(--emm-border-hairline);
  border-bottom: var(--emm-border-hairline);
  background: color-mix(in srgb, var(--emm-color-ivory) 92%, white);
  box-shadow: 0 14px 30px rgba(17, 21, 27, 0.08);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity var(--emm-time-base) var(--emm-ease), transform var(--emm-time-base) var(--emm-ease), visibility var(--emm-time-base) var(--emm-ease);
  z-index: calc(var(--emm-z-header) - 1);
}

.emm-nav__submenu--mega {
  padding: 0;
}

.emm-nav__item--has-submenu:hover .emm-nav__submenu,
.emm-nav__item--has-submenu:focus-within .emm-nav__submenu,
.emm-nav__item--has-submenu.is-open .emm-nav__submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.emm-nav__mega-inner {
  padding-block: var(--emm-space-6);
  display: grid;
  grid-template-columns: minmax(12rem, 14rem) minmax(0, 1fr);
  gap: var(--emm-space-7, 1.75rem);
  align-items: start;
}

.emm-nav__mega-rail {
  border-right: var(--emm-border-hairline);
  padding-right: var(--emm-space-6);
}

.emm-nav__mega-kicker {
  margin: 0 0 var(--emm-space-4);
  font-size: var(--emm-step--2);
  color: var(--emm-color-muted);
  font-weight: 600;
}

.emm-nav__mega-rail-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.35rem;
}

.emm-nav__mega-rail-link {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  width: 100%;
  border: none;
  border-radius: 0;
  padding: 0.2rem 0;
  text-decoration: none;
  color: var(--emm-color-ink-soft);
  font-size: var(--emm-step--1);
  transition: color var(--emm-time-base) var(--emm-ease), transform var(--emm-time-base) var(--emm-ease);
}

.emm-nav__mega-rail-link:hover,
.emm-nav__mega-rail-link:focus-visible,
.emm-nav__mega-rail-link.is-active {
  color: var(--emm-color-ink);
  transform: translateX(2px);
}

.emm-nav__mega-collections-link {
  display: inline-flex;
  align-items: center;
  margin-top: var(--emm-space-4);
  padding-top: var(--emm-space-3);
  border-top: var(--emm-border-hairline);
  text-decoration: none;
  font-size: var(--emm-step--2);
  font-weight: 600;
  color: var(--emm-color-ink-soft);
}

.emm-nav__mega-collections-link:hover,
.emm-nav__mega-collections-link:focus-visible {
  color: var(--emm-color-ink);
}

.emm-nav__mega-content {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--emm-space-6);
}

.emm-nav__mega-group {
  min-width: 0;
}

.emm-nav__mega-title {
  margin: 0 0 var(--emm-space-3);
}

.emm-nav__mega-title-link {
  color: var(--emm-color-ink);
  text-decoration: none;
  font-family: var(--emm-font-display);
  font-size: var(--emm-step-0);
  letter-spacing: -0.01em;
}

.emm-nav__mega-title-link:hover {
  color: var(--emm-color-accent);
}

.emm-nav__mega-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.3rem;
}

.emm-nav__submenu-link {
  display: inline-flex;
  align-items: center;
  min-height: 1.95rem;
  border-radius: 0;
  padding: 0.1rem 0;
  text-decoration: none;
  color: var(--emm-color-ink-soft);
  font-size: var(--emm-step--1);
  line-height: 1.2;
}

.emm-nav__submenu-link:hover,
.emm-nav__submenu-link:focus-visible {
  color: var(--emm-color-ink);
}

.emm-nav__submenu-link.is-active {
  color: var(--emm-color-ink);
  font-weight: 600;
}

.emm-nav__mega-recent {
  min-width: 0;
  border-left: var(--emm-border-hairline);
  padding-left: var(--emm-space-6);
}

.emm-nav__mega-recent--wide {
  width: 100%;
}

.emm-nav__mega-recent-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  margin: 0 0 var(--emm-space-3);
}

.emm-nav__mega-recent-link {
  color: var(--emm-color-ink-soft);
  text-decoration: none;
  font-size: var(--emm-step--2);
  font-weight: 600;
}

.emm-nav__mega-recent-link:hover,
.emm-nav__mega-recent-link:focus-visible {
  color: var(--emm-color-ink);
}

.emm-nav__mega-recent-grid {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: nowrap;
  gap: 0.75rem;
  overflow: hidden;
}

.emm-nav__mega-recent-item {
  flex: 0 1 clamp(11rem, 16vw, 14rem);
  min-width: 11rem;
}

.emm-nav__mega-recent-card {
  display: grid;
  gap: 0.45rem;
  text-decoration: none;
  color: inherit;
}

.emm-nav__mega-recent-media {
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: color-mix(in srgb, var(--emm-color-paper) 55%, transparent);
}

.emm-nav__mega-recent-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.emm-nav__mega-recent-copy {
  min-width: 0;
  display: grid;
  gap: 0.1rem;
}

.emm-nav__mega-recent-copy strong {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--emm-color-ink);
  line-height: 1.2;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.emm-nav__mega-recent-copy em {
  font-style: normal;
  font-size: 0.7rem;
  color: var(--emm-color-ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 78rem) {
  .emm-nav__mega-inner {
    grid-template-columns: minmax(10rem, 12rem) minmax(0, 1fr);
    gap: var(--emm-space-6);
  }

  .emm-nav__mega-content {
    grid-template-columns: minmax(0, 1fr);
  }

  .emm-nav__mega-recent {
    display: none;
  }
}

.emm-icon-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 50%;
  color: var(--emm-color-ink);
  text-decoration: none;
  background: transparent;
  cursor: pointer;
  transition: background var(--emm-time-base) var(--emm-ease), border-color var(--emm-time-base) var(--emm-ease), color var(--emm-time-base) var(--emm-ease);
}

.emm-icon-btn:hover {
  border-color: var(--emm-color-line);
  background: color-mix(in srgb, var(--emm-color-paper) 88%, transparent);
}

.emm-icon-btn.is-active {
  border-color: var(--emm-color-line);
  background: color-mix(in srgb, var(--emm-color-paper) 86%, white);
}

.emm-bag-count {
  position: absolute;
  top: 0.4rem;
  right: 0.33rem;
  min-width: 1rem;
  height: 1rem;
  padding-inline: 0.22rem;
  border-radius: var(--emm-radius-pill);
  border: 1px solid var(--emm-color-line-strong);
  background: var(--emm-color-white);
  color: var(--emm-color-ink-soft);
  font-size: 0.62rem;
  font-weight: 600;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.emm-search-panel {
  position: absolute;
  inset-inline: 0;
  top: 100%;
  z-index: var(--emm-z-search);
  border-top: var(--emm-border-hairline);
  border-bottom: var(--emm-border-hairline);
  background: color-mix(in srgb, var(--emm-color-ivory) 92%, #ffffff);
  box-shadow: 0 14px 30px rgba(17, 21, 27, 0.08);
  max-height: var(--emm-search-max-height);
  overflow: auto;
}

.emm-search-panel[hidden] {
  display: none !important;
}

.emm-search-panel__inner {
  padding-block: var(--emm-space-5) var(--emm-space-6);
  display: grid;
  gap: var(--emm-space-5);
}

.emm-search-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--emm-space-3);
}

.emm-search-panel__close {
  appearance: none;
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-pill);
  padding-inline: 1rem;
  background: var(--emm-color-white);
  color: var(--emm-color-ink);
  font-size: var(--emm-step--1);
  cursor: pointer;
}

.emm-search-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--emm-space-3);
}

.emm-search-panel__predictive {
  display: grid;
  gap: var(--emm-space-2);
}

.emm-search-panel__predictive[hidden] {
  display: none !important;
}

.emm-search-suggestions {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: var(--emm-space-2);
}

.emm-search-suggestions li {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-md);
  background: color-mix(in srgb, var(--emm-color-paper) 70%, white);
}

.emm-search-suggestions a {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.68rem;
  text-decoration: none;
  color: var(--emm-color-ink);
  padding: 0.62rem 0.82rem;
}

.emm-search-suggestions a.is-no-thumb {
  grid-template-columns: minmax(0, 1fr);
}

.emm-search-suggestion__thumb {
  width: 2.9rem;
  height: 2.9rem;
  border-radius: 0.45rem;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--emm-color-line) 90%, white);
  background: color-mix(in srgb, var(--emm-color-paper) 75%, white);
}

.emm-search-suggestion__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.emm-search-suggestion__content {
  display: grid;
  gap: 0.12rem;
  min-width: 0;
}

.emm-search-suggestion__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.emm-search-suggestion__title {
  font-size: var(--emm-step--1);
  font-weight: 600;
  line-height: 1.3;
  color: var(--emm-color-ink);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.emm-search-suggestion__type {
  display: inline-flex;
  align-items: center;
  min-height: 1.4rem;
  padding: 0.06rem 0.42rem;
  border-radius: var(--emm-radius-pill);
  border: 1px solid color-mix(in srgb, var(--emm-color-line-strong) 86%, white);
  background: color-mix(in srgb, var(--emm-color-paper) 86%, white);
  color: var(--emm-color-muted);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}

.emm-search-suggestion__meta {
  color: var(--emm-color-muted);
  font-size: var(--emm-step--2);
}

.emm-search-suggestion__price {
  color: var(--emm-color-ink);
  font-size: var(--emm-step--2);
  font-weight: 600;
}

.emm-search-suggestions li.is-active,
.emm-search-suggestions li:hover {
  border-color: var(--emm-color-line-strong);
  background: color-mix(in srgb, var(--emm-color-paper) 88%, white);
}

.emm-search-panel__quick {
  display: grid;
  gap: var(--emm-space-2);
}

.emm-search-panel__links {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--emm-space-2) var(--emm-space-4);
}

.emm-search-panel__links a {
  text-decoration: none;
  color: var(--emm-color-ink-soft);
  font-size: var(--emm-step--1);
  border-bottom: 1px solid transparent;
}

.emm-search-panel__links a:hover {
  color: var(--emm-color-ink);
  border-bottom-color: currentColor;
}

.emm-account-panel {
  position: absolute;
  inset-inline: 0;
  top: 100%;
  z-index: var(--emm-z-search);
  border-top: var(--emm-border-hairline);
  border-bottom: var(--emm-border-hairline);
  background: color-mix(in srgb, var(--emm-color-ivory) 92%, #ffffff);
  box-shadow: 0 14px 30px rgba(17, 21, 27, 0.08);
  max-height: var(--emm-account-max-height, calc(100dvh - 4.35rem));
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  pointer-events: none;
  transition: opacity var(--emm-time-base) var(--emm-ease), transform var(--emm-time-base) var(--emm-ease), visibility var(--emm-time-base) var(--emm-ease);
}

.emm-account-panel[hidden] {
  display: none !important;
}

.emm-account-panel.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.emm-account-panel__inner {
  padding-block: var(--emm-space-5) var(--emm-space-6);
  display: grid;
  gap: var(--emm-space-4);
}

.emm-account-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--emm-space-3);
}

.emm-account-panel__close {
  appearance: none;
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-pill);
  padding-inline: 1rem;
  min-height: 2.6rem;
  background: var(--emm-color-white);
  color: var(--emm-color-ink);
  font-size: var(--emm-step--1);
  cursor: pointer;
}

.emm-account-panel__hello {
  margin: 0;
  font-family: var(--emm-font-display);
  font-size: var(--emm-step-1);
  color: var(--emm-color-ink);
  opacity: 0;
  transform: translateY(8px);
}

.emm-account-panel__hello span {
  color: var(--emm-color-accent);
}

.emm-account-panel.is-open .emm-account-panel__hello {
  animation: emm-account-fade-in 320ms var(--emm-ease) 90ms both;
}

@keyframes emm-account-fade-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.emm-account-panel__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10.5rem, 1fr));
  gap: var(--emm-space-3);
}

.emm-account-panel__link {
  min-height: 4.6rem;
  border: var(--emm-border-hairline);
  border-radius: 1rem;
  padding: 0.9rem 1rem;
  text-decoration: none;
  color: var(--emm-color-ink-soft);
  background: color-mix(in srgb, var(--emm-color-paper) 84%, white);
  font-size: var(--emm-step--1);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: transform var(--emm-time-base) var(--emm-ease), border-color var(--emm-time-base) var(--emm-ease), background var(--emm-time-base) var(--emm-ease), color var(--emm-time-base) var(--emm-ease);
}

.emm-account-panel__link:hover,
.emm-account-panel__link:focus-visible {
  transform: translateY(-1px);
  border-color: var(--emm-color-line-strong);
  background: color-mix(in srgb, var(--emm-color-paper) 76%, white);
  color: var(--emm-color-ink);
}

.emm-account-panel__link.is-active {
  color: var(--emm-color-ink);
  border-color: var(--emm-color-line-strong);
  background: color-mix(in srgb, var(--emm-color-paper) 72%, white);
}

.emm-cart-panel {
  position: absolute;
  inset-inline: 0;
  top: 100%;
  z-index: calc(var(--emm-z-search) + 1);
  border-top: var(--emm-border-hairline);
  border-bottom: var(--emm-border-hairline);
  background: color-mix(in srgb, var(--emm-color-ivory) 93%, #ffffff);
  box-shadow: 0 14px 30px rgba(17, 21, 27, 0.12);
  max-height: var(--emm-cart-max-height, calc(100dvh - 4.35rem));
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  pointer-events: none;
  overflow: hidden;
  transition: opacity var(--emm-time-base) var(--emm-ease), transform var(--emm-time-base) var(--emm-ease), visibility var(--emm-time-base) var(--emm-ease);
}

.emm-cart-panel[hidden] {
  display: none !important;
}

.emm-cart-panel.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.emm-cart-panel__inner {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  max-height: inherit;
}

.emm-cart-panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--emm-space-3);
  padding: var(--emm-space-4) var(--emm-space-5);
  border-bottom: var(--emm-border-hairline);
}

.emm-cart-panel__close {
  appearance: none;
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-pill);
  padding: 0.5rem 0.95rem;
  background: var(--emm-color-white);
  color: var(--emm-color-ink);
  font-size: var(--emm-step--1);
  cursor: pointer;
}

.emm-cart-panel__body {
  overflow-y: auto;
  padding: var(--emm-space-4) var(--emm-space-5);
}

.emm-cart-panel__foot {
  border-top: var(--emm-border-hairline);
  padding: var(--emm-space-4) var(--emm-space-5);
  display: grid;
  gap: var(--emm-space-3);
  background: color-mix(in srgb, var(--emm-color-paper) 90%, white);
}

.emm-cart-panel__subtotal {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--emm-step-0);
  font-weight: 600;
  color: var(--emm-color-ink);
}

.emm-cart-panel__actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--emm-space-2);
}

.emm-cart-items {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: var(--emm-space-3);
}

.emm-cart-item {
  display: grid;
  grid-template-columns: 4.1rem minmax(0, 1fr);
  gap: var(--emm-space-3);
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-md);
  padding: var(--emm-space-2);
  background: color-mix(in srgb, var(--emm-color-paper) 76%, white);
}

.emm-cart-item__media {
  width: 4.1rem;
  height: 4.1rem;
  border-radius: 0.48rem;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--emm-color-line) 88%, white);
  background: var(--emm-color-white);
}

.emm-cart-item__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.emm-cart-item__content {
  min-width: 0;
  display: grid;
  gap: 0.2rem;
}

.emm-cart-item__title {
  margin: 0;
  font-size: var(--emm-step--1);
  font-weight: 600;
  color: var(--emm-color-ink);
  line-height: 1.35;
}

.emm-cart-item__meta {
  margin: 0;
  font-size: var(--emm-step--2);
  color: var(--emm-color-muted);
}

.emm-cart-item__row {
  margin-top: 0.28rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--emm-space-2);
}

.emm-cart-item__line-total {
  font-size: var(--emm-step--1);
  font-weight: 600;
  color: var(--emm-color-ink);
}

.emm-cart-qty {
  display: inline-flex;
  align-items: center;
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-pill);
  overflow: hidden;
  background: var(--emm-color-white);
}

.emm-cart-qty button {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--emm-color-ink-soft);
  min-width: 1.9rem;
  min-height: 1.8rem;
  font-size: 1rem;
  cursor: pointer;
}

.emm-cart-qty button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.emm-cart-qty span {
  min-width: 1.8rem;
  text-align: center;
  font-size: var(--emm-step--2);
  font-weight: 600;
  color: var(--emm-color-ink);
}

.emm-cart-item__remove {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--emm-color-muted);
  font-size: var(--emm-step--2);
  text-decoration: underline;
  text-underline-offset: 0.14rem;
  padding: 0;
  cursor: pointer;
}

.emm-cart-panel__empty,
.emm-cart-panel__loading,
.emm-cart-panel__error {
  text-align: center;
  color: var(--emm-color-muted);
  padding: var(--emm-space-6) var(--emm-space-2);
  display: grid;
  gap: var(--emm-space-3);
  justify-items: center;
}

.emm-cart-panel__empty p,
.emm-cart-panel__loading p,
.emm-cart-panel__error p {
  margin: 0;
}

.emm-cart-panel__empty .emm-btn,
.emm-cart-panel__error .emm-btn {
  min-width: 10rem;
}

.emm-overlay {
  position: fixed;
  inset-inline: 0;
  bottom: 0;
  top: var(--emm-overlay-top);
  z-index: var(--emm-z-overlay);
  background: rgba(20, 24, 30, 0.24);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--emm-time-base) var(--emm-ease);
}

.emm-overlay[hidden] {
  display: none !important;
}

.emm-overlay.is-active {
  opacity: 1;
  pointer-events: auto;
}

.emm-overlay.emm-overlay--drawer {
  --emm-overlay-top: 0px;
}

.emm-overlay.emm-overlay--cart {
  --emm-overlay-top: 0px;
}

.emm-overlay.emm-overlay--account {
  --emm-overlay-top: 0px;
}

.emm-drawer {
  position: fixed;
  inset: 0;
  z-index: var(--emm-z-drawer);
  pointer-events: none;
}

.emm-drawer[hidden] {
  display: none !important;
}

.emm-drawer__panel {
  width: min(88vw, 24rem);
  max-width: 24rem;
  height: 100svh;
  max-height: 100svh;
  border-right: var(--emm-border-hairline);
  background: var(--emm-color-ivory);
  transform: translateX(-100%);
  transition: transform var(--emm-time-slow) var(--emm-ease);
  pointer-events: auto;
  display: grid;
  grid-template-rows: auto 1fr;
}

.emm-drawer.is-open .emm-drawer__panel {
  transform: translateX(0);
}

.emm-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--emm-space-3);
  padding: var(--emm-space-4);
  border-bottom: var(--emm-border-hairline);
}

.emm-drawer__wordmark {
  text-decoration: none;
  color: var(--emm-color-ink);
  font-family: var(--emm-font-display);
  font-size: clamp(1.6rem, 1.1rem + 1.5vw, 2rem);
  line-height: 1;
}

.emm-drawer__close {
  appearance: none;
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-pill);
  padding-inline: 0.95rem;
  background: var(--emm-color-white);
  color: var(--emm-color-ink);
  font-size: var(--emm-step--1);
  cursor: pointer;
}

.emm-drawer__body {
  height: 100%;
  min-height: 0;
  padding: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
}

.emm-drawer__search-pin {
  position: sticky;
  top: 0;
  z-index: 4;
  padding: 0.5rem var(--emm-space-4);
  border-bottom: var(--emm-border-hairline);
  background: color-mix(in srgb, var(--emm-color-ivory) 98%, white);
}

.emm-drawer__scroll {
  min-height: 0;
  overflow-y: auto;
  padding: var(--emm-space-3) var(--emm-space-4) calc(var(--emm-space-6) + env(safe-area-inset-bottom, 0px));
  display: grid;
  gap: var(--emm-space-3);
  align-content: start;
}

.emm-drawer__search-link {
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  text-decoration: none;
  color: var(--emm-color-ink-soft);
  font-size: var(--emm-step--1);
  border-bottom: 1px solid transparent;
  width: fit-content;
}

.emm-drawer__search-link:hover {
  border-bottom-color: currentColor;
  color: var(--emm-color-ink);
}

.emm-drawer__search-form {
  display: block;
}

.emm-drawer__search-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.5rem;
  align-items: center;
  min-height: 2.05rem;
}

.emm-drawer__search-icon {
  width: 1.6rem;
  height: 1.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--emm-color-ink-soft);
}

.emm-drawer__search-submit {
  min-width: 4.35rem;
  min-height: 2.45rem;
  padding: 0.38rem 0.72rem;
  font-size: var(--emm-step--2);
}

.emm-drawer__search-row .emm-field {
  min-height: 2.05rem;
  padding: 0.18rem 0;
  border-radius: 0;
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--emm-color-line-strong) 92%, white);
  background: transparent;
  font-size: 16px;
}

.emm-drawer__search-row .emm-field:focus {
  outline: none;
  border-bottom-color: var(--emm-color-ink);
  box-shadow: none;
}

.emm-drawer__search-row .emm-field::placeholder {
  color: color-mix(in srgb, var(--emm-color-muted) 88%, white);
}

.emm-drawer__search-predictive {
  display: grid;
  gap: var(--emm-space-2);
}

.emm-drawer__search-predictive[hidden] {
  display: none !important;
}

.emm-search-suggestions--drawer a {
  padding: 0.52rem 0.7rem;
}

.emm-search-suggestions--drawer .emm-search-suggestion__thumb {
  width: 2.35rem;
  height: 2.35rem;
}

.emm-drawer__account-link {
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  text-decoration: none;
  color: var(--emm-color-ink-soft);
  font-size: var(--emm-step--1);
  border-bottom: 1px solid transparent;
  width: fit-content;
}

.emm-drawer__account-link:hover {
  border-bottom-color: currentColor;
  color: var(--emm-color-ink);
}

.emm-drawer__group {
  display: grid;
  gap: var(--emm-space-3);
}

.emm-drawer__links {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  align-content: start;
}

.emm-drawer__links a {
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  text-decoration: none;
  color: var(--emm-color-ink);
  font-size: var(--emm-step-0);
  line-height: 1.25;
}

.emm-drawer__parent {
  display: grid;
}

.emm-drawer__parent summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  color: var(--emm-color-ink);
  font-size: var(--emm-step-0);
  line-height: 1.25;
}

.emm-drawer__parent summary::-webkit-details-marker {
  display: none;
}

.emm-drawer__parent summary::after {
  content: '+';
  margin-left: 0.45rem;
  color: var(--emm-color-muted);
  font-size: 0.9em;
}

.emm-drawer__parent[open] summary::after {
  content: '-';
}

.emm-drawer__children {
  margin: 0;
  padding: 0 0 0.2rem 0.9rem;
  list-style: none;
  display: grid;
  gap: 0.2rem;
}

.emm-drawer__children a {
  min-height: 2.15rem;
  color: var(--emm-color-ink-soft);
  font-size: var(--emm-step--1);
}

.emm-drawer__links a:hover {
  color: var(--emm-color-accent);
}

.emm-drawer__details {
  border-top: var(--emm-border-hairline);
  padding-top: var(--emm-space-3);
}

.emm-drawer__details summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  font-size: var(--emm-step--1);
  text-transform: none;
  letter-spacing: 0.02em;
  color: var(--emm-color-muted);
}

.emm-drawer__details summary::-webkit-details-marker {
  display: none;
}

.emm-drawer__details--flat {
  display: grid;
  gap: var(--emm-space-3);
}

.emm-drawer__links--secondary a {
  font-size: var(--emm-step--1);
  color: var(--emm-color-ink-soft);
}

.emm-drawer__links--account a {
  font-size: var(--emm-step--1);
  color: var(--emm-color-ink-soft);
}

.emm-drawer__newsletter {
  border-top: var(--emm-border-hairline);
  padding-top: var(--emm-space-4);
  display: grid;
  gap: var(--emm-space-2);
}

.emm-drawer__newsletter-row {
  margin-top: var(--emm-space-2);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--emm-space-2);
}

.emm-drawer__newsletter-submit {
  min-width: 2.75rem;
  padding-inline: 0.8rem;
}

.emm-drawer__social {
  border-top: var(--emm-border-hairline);
  padding-top: var(--emm-space-4);
  display: grid;
  gap: var(--emm-space-3);
}

.emm-drawer__social-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--emm-space-2) var(--emm-space-4);
}

.emm-drawer__social-list a {
  text-decoration: none;
  font-size: var(--emm-step--1);
  color: var(--emm-color-ink-soft);
  border-bottom: 1px solid transparent;
}

.emm-drawer__social-list a:hover {
  border-bottom-color: currentColor;
  color: var(--emm-color-ink);
}

.emm-drawer__account-panel {
  padding: 0.45rem var(--emm-space-4) calc(0.65rem + env(safe-area-inset-bottom, 0px));
  background: color-mix(in srgb, var(--emm-color-ivory) 98%, white);
  position: sticky;
  bottom: 0;
  z-index: 3;
  display: grid;
  gap: 0.4rem;
}

.emm-drawer__account-panel::before {
  content: '';
  width: 92%;
  height: 1px;
  justify-self: center;
  background: color-mix(in srgb, var(--emm-color-line-strong) 55%, white);
  margin-bottom: 0.35rem;
}

.emm-drawer__utility-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.2rem;
}

.emm-drawer__utility-btn {
  text-decoration: none;
  color: var(--emm-color-ink-soft);
  min-height: 2.8rem;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 0.14rem;
  padding: 0.12rem;
}

.emm-drawer__btn-icon {
  width: 0.95rem;
  height: 0.95rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: currentColor;
  flex-shrink: 0;
}

.emm-drawer__btn-label {
  font-size: 0.68rem;
  line-height: 1.15;
  text-align: center;
  letter-spacing: 0.01em;
}

.emm-drawer__utility-btn:hover {
  color: var(--emm-color-ink);
}

.emm-no-scroll {
  overflow: hidden;
}

.emm-hero {
  position: relative;
  overflow: hidden;
  border-bottom: var(--emm-border-hairline);
}

.emm-hero__shell {
  position: relative;
  display: grid;
  min-height: clamp(
    420px,
    calc((min(var(--emm-container-max), calc(100vw - (var(--emm-page-pad) * 2))) * 9) / 16),
    900px
  );
}

.emm-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.emm-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

.emm-hero__shade {
  position: absolute;
  inset: 0;
  background: #000;
}

.emm-hero__grain {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, 0.07) 0.75px, transparent 0.75px);
  background-size: 4px 4px;
  opacity: 0.18;
  mix-blend-mode: soft-light;
}

.emm-hero__inner {
  position: relative;
  z-index: 1;
  min-height: inherit;
  height: 100%;
  display: grid;
  align-items: stretch;
  justify-items: start;
  text-align: left;
  padding-block: clamp(3.5rem, 8vw, 6rem);
}

.emm-hero__content {
  display: grid;
  align-self: end;
  justify-self: start;
  gap: var(--emm-space-5);
  max-width: 40rem;
  margin-inline: 0;
}

.emm-hero--align-desktop-center .emm-hero__inner {
  justify-items: start;
}

.emm-hero--align-desktop-center .emm-hero__content {
  margin-inline: 0 auto;
}

.emm-hero--align-desktop-right .emm-hero__inner {
  justify-items: start;
}

.emm-hero--align-desktop-right .emm-hero__content {
  margin-inline: 0 auto;
}

.emm-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--emm-space-3);
  color: var(--emm-color-muted);
  font-size: var(--emm-step--1);
}

.emm-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--emm-space-3);
}

.emm-hero .emm-btn--primary {
  background: var(--emm-hero-btn-primary-bg, var(--emm-color-ink));
  color: var(--emm-hero-btn-primary-text, var(--emm-color-white));
  border-color: var(--emm-hero-btn-primary-border, var(--emm-color-ink));
}

.emm-hero .emm-btn--secondary {
  background: var(--emm-hero-btn-secondary-bg, transparent);
  color: var(--emm-hero-btn-secondary-text, var(--emm-hero-smart-color, var(--emm-color-ink)));
  border-color: var(--emm-hero-btn-secondary-border, color-mix(in srgb, var(--emm-hero-smart-color, var(--emm-color-ink)) 45%, transparent));
}

.emm-section[data-emm-tone="ink"] .emm-hero__meta {
  color: rgba(243, 238, 230, 0.8);
}

.emm-collections {
  gap: var(--emm-space-5);
}

.emm-collection-card {
  display: grid;
  gap: var(--emm-space-3);
  text-decoration: none;
  color: inherit;
}

.emm-collection-card__media {
  position: relative;
  border-radius: var(--emm-radius-lg);
  overflow: hidden;
  border: var(--emm-border-hairline);
  background: var(--emm-color-paper);
  aspect-ratio: var(--emm-card-ratio, 4 / 5);
}

.emm-collection-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--emm-time-slow) var(--emm-ease);
}

.emm-collection-card:hover .emm-collection-card__media img {
  transform: scale(1.03);
}

.emm-collection-card__title {
  font-size: var(--emm-step-1);
  margin: 0;
}

.emm-collection-card__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--emm-space-3);
}

.emm-value-grid {
  display: grid;
  gap: var(--emm-space-4);
}

.emm-value {
  display: grid;
  gap: var(--emm-space-2);
  padding: var(--emm-space-5);
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-md);
}

.emm-value__icon {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--emm-color-muted);
}

.emm-value__title {
  margin: 0;
  font-size: var(--emm-step-0);
  letter-spacing: 0.01em;
}

.emm-value__copy {
  margin: 0;
  color: var(--emm-color-muted);
  font-size: var(--emm-step--1);
  line-height: 1.55;
}

.emm-split {
  display: grid;
  gap: var(--emm-space-8);
  align-items: center;
}

.emm-split__media {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  overflow: hidden;
  background: var(--emm-color-paper);
}

.emm-split__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: var(--emm-story-ratio, 4 / 5);
}

.emm-quote {
  margin: 0;
  padding-left: var(--emm-space-4);
  border-left: 1px solid var(--emm-color-line-strong);
  font-size: var(--emm-step--1);
  color: var(--emm-color-muted);
}

.emm-image-text--quote-cta .emm-quote-cta-card {
  border: var(--emm-border-hairline);
  border-radius: clamp(1rem, 2.3vw, 1.5rem);
  padding: clamp(1.2rem, 3.2vw, 2.2rem);
  background: color-mix(in srgb, var(--emm-color-ink) 84%, #141823 16%);
  min-width: 0;
}

.emm-image-text--quote-cta[data-emm-tone="paper"] .emm-quote-cta-card {
  background: color-mix(in srgb, var(--emm-color-paper) 88%, var(--emm-color-white) 12%);
}

.emm-image-text--quote-cta[data-emm-tone="white"] .emm-quote-cta-card {
  background: color-mix(in srgb, var(--emm-color-white) 92%, var(--emm-color-paper) 8%);
}

.emm-image-text--quote-cta .emm-quote-cta-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-areas:
    "content media"
    "actions media";
  gap: clamp(1rem, 2.7vw, 2.2rem);
  align-items: stretch;
}

.emm-image-text--quote-cta .emm-quote-cta-grid.is-only-copy {
  grid-template-areas: "content media";
}

.emm-image-text--quote-cta .emm-quote-cta-grid.is-only-actions {
  grid-template-areas: "actions media";
}

.emm-image-text--quote-cta .emm-quote-cta-grid.is-media-only {
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas: "media";
}

.emm-image-text--quote-cta .emm-quote-cta-content {
  grid-area: content;
  align-self: start;
  display: grid;
  gap: clamp(0.45rem, 1.3vw, 0.9rem);
  min-width: 0;
}

.emm-image-text--quote-cta .emm-quote-cta-title {
  margin: 0;
  font-size: clamp(1.65rem, 3.1vw, 3rem);
  line-height: 1.06;
  letter-spacing: -0.02em;
  max-width: 20ch;
  overflow-wrap: anywhere;
  hyphens: auto;
}

.emm-image-text--quote-cta .emm-quote-cta-body,
.emm-image-text--quote-cta .emm-quote-cta-extra {
  margin: 0;
  color: color-mix(in srgb, var(--emm-color-ink-soft) 84%, var(--emm-color-white) 16%);
  line-height: 1.55;
  font-size: clamp(0.98rem, 1.45vw, 1.2rem);
  max-width: 62ch;
  overflow-wrap: anywhere;
  hyphens: auto;
}

.emm-image-text--quote-cta[data-emm-tone="ink"] .emm-quote-cta-body,
.emm-image-text--quote-cta[data-emm-tone="ink"] .emm-quote-cta-extra {
  color: color-mix(in srgb, #dde3ef 88%, #ffffff 12%);
}

.emm-image-text--quote-cta .emm-quote-cta-body {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.emm-image-text--quote-cta .emm-quote-cta-actions {
  grid-area: actions;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.72rem;
  min-width: 0;
}

.emm-image-text--quote-cta .emm-quote-cta-btn {
  border-radius: 999px;
  min-height: 2.95rem;
  padding-inline: 1.35rem;
  font-weight: 620;
  letter-spacing: 0.01em;
  text-decoration: none;
  overflow-wrap: anywhere;
  hyphens: auto;
  transition:
    transform 0.22s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.22s ease,
    background-color 0.22s ease,
    color 0.22s ease;
}

.emm-image-text--quote-cta .emm-quote-cta-btn--primary {
  background: #f5f7fb;
  color: #10131a;
  border: 1px solid color-mix(in srgb, #f5f7fb 72%, #9aa7bf 28%);
}

.emm-image-text--quote-cta .emm-quote-cta-btn--secondary {
  background: transparent;
  color: inherit;
  border: 1px solid color-mix(in srgb, currentColor 36%, transparent 64%);
}

.emm-image-text--quote-cta .emm-quote-cta-btn:hover {
  transform: translateY(-1px);
}

.emm-image-text--quote-cta .emm-quote-cta-btn--primary:hover {
  background: #ffffff;
  border-color: #ffffff;
}

.emm-image-text--quote-cta .emm-quote-cta-btn--secondary:hover {
  border-color: color-mix(in srgb, currentColor 52%, transparent 48%);
  background: color-mix(in srgb, currentColor 10%, transparent 90%);
}

.emm-image-text--quote-cta .emm-quote-cta-btn:focus-visible {
  outline: 2px solid color-mix(in srgb, #5ea8ff 78%, #ffffff 22%);
  outline-offset: 2px;
}

.emm-image-text--quote-cta .emm-quote-cta-media {
  grid-area: media;
  border-radius: clamp(0.9rem, 2vw, 1.35rem);
  overflow: hidden;
  border: var(--emm-border-hairline);
  background: color-mix(in srgb, var(--emm-color-ink) 82%, #0f1219 18%);
  min-height: clamp(14rem, 32vw, 23rem);
  width: 100%;
  min-width: 0;
  align-self: stretch;
}

.emm-image-text--quote-cta .emm-quote-cta-media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
}

.emm-image-text--quote-cta .emm-quote-cta-media.is-empty {
  display: grid;
  place-items: center;
}

.emm-image-text--quote-cta .emm-quote-cta-placeholder {
  width: 100%;
  height: 100%;
  min-height: inherit;
  display: grid;
  place-items: center;
  color: color-mix(in srgb, #c7d1e1 54%, #7f8ba3 46%);
  background: color-mix(in srgb, var(--emm-color-ink) 72%, #0d1017 28%);
}

.emm-image-text--quote-cta .emm-quote-cta-placeholder svg {
  width: clamp(1.8rem, 4.6vw, 2.9rem);
  height: clamp(1.8rem, 4.6vw, 2.9rem);
  opacity: 0.72;
}

.emm-image-text--quote-cta [data-cta-motion] {
  will-change: opacity, transform;
}

.emm-image-text--quote-cta.is-motion-ready [data-cta-motion] {
  opacity: 0;
  transform: translate3d(0, 14px, 0);
  transition:
    opacity 720ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 720ms cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--cta-delay, 0ms);
}

.emm-image-text--quote-cta.is-motion-ready.is-inview [data-cta-motion] {
  opacity: 1;
  transform: none;
}

.emm-image-text--quote-cta.is-editor-preview [data-cta-motion] {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

.emm-image-text--quote-cta.is-editor-preview,
.emm-image-text--quote-cta.is-editor-preview *,
.emm-image-text--quote-cta.is-editor-preview *::before,
.emm-image-text--quote-cta.is-editor-preview *::after {
  animation: none !important;
  transition: none !important;
}

.emm-product-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--emm-space-5);
  margin-bottom: var(--emm-space-6);
}

.emm-product-track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(12rem, 18rem);
  gap: var(--emm-space-4);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding-bottom: var(--emm-space-2);
}

.emm-product-track::-webkit-scrollbar {
  display: none;
}

.emm-product-item {
  scroll-snap-align: start;
  display: grid;
  gap: var(--emm-space-3);
}

.emm-product-card {
  display: grid;
  gap: var(--emm-space-3);
  color: inherit;
  text-decoration: none;
}

.emm-product-media {
  position: relative;
  border-radius: var(--emm-radius-lg);
  overflow: hidden;
  border: var(--emm-border-hairline);
  background: var(--emm-color-paper);
  aspect-ratio: 1 / 1;
  clip-path: inset(0 round var(--emm-radius-lg));
}

.emm-product-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--emm-time-slow) var(--emm-ease);
}

.emm-product-card:hover .emm-product-media img {
  transform: scale(1.02);
}

.emm-product-badge {
  position: absolute;
  top: 0.6rem;
  left: 0.6rem;
  z-index: 2;
  font-size: 0.64rem;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0.02em;
  padding: 0.32rem 0.55rem;
  border-radius: var(--emm-radius-pill);
  border: 1px solid transparent;
  background: var(--emm-color-white);
}

.emm-product-badge--coming-soon {
  color: var(--emm-color-accent);
  border-color: color-mix(in srgb, var(--emm-color-accent) 25%, transparent);
  background: color-mix(in srgb, var(--emm-color-accent-soft) 92%, white);
}

.emm-product-badge--sold-out {
  color: var(--emm-color-danger);
  border-color: color-mix(in srgb, var(--emm-color-danger) 24%, transparent);
  background: color-mix(in srgb, #fff4f2 90%, white);
}

.emm-product-badge--low-stock {
  color: var(--emm-color-warning);
  border-color: color-mix(in srgb, var(--emm-color-warning) 26%, transparent);
  background: color-mix(in srgb, #fff8e8 92%, white);
}

.emm-product-badge--in-stock {
  color: var(--emm-color-success);
  border-color: color-mix(in srgb, var(--emm-color-success) 25%, transparent);
  background: color-mix(in srgb, #edf8f1 94%, white);
}

.emm-product-title {
  margin: 0;
  font-size: var(--emm-step-0);
  line-height: 1.35;
}

.emm-price {
  margin: 0;
  font-size: var(--emm-step-1);
  line-height: 1.2;
  font-weight: 600;
}

.emm-price small {
  color: var(--emm-color-muted);
  font-size: 0.72em;
  font-weight: 500;
  margin-left: 0.35rem;
}

.emm-price s {
  font-size: 0.75em;
  color: var(--emm-color-muted);
  margin-left: 0.4rem;
}

.emm-quick-add {
  width: 100%;
  min-height: 2.45rem;
  border-radius: var(--emm-radius-pill);
  border: var(--emm-border-hairline);
  background: transparent;
  color: var(--emm-color-ink);
  font-size: var(--emm-step--1);
  letter-spacing: 0.01em;
}

.emm-quick-add:hover {
  background: var(--emm-color-paper);
}

.emm-quick-add[disabled] {
  cursor: not-allowed;
  opacity: 0.45;
}

.emm-slider-shell {
  position: relative;
}

.emm-slider-nav {
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
  width: 2.15rem;
  height: 2.15rem;
  border-radius: 50%;
  border: var(--emm-border-hairline);
  background: color-mix(in srgb, var(--emm-color-white) 88%, transparent);
  color: var(--emm-color-ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  cursor: pointer;
}

.emm-slider-nav[data-emm-slider-nav="prev"] {
  left: -0.75rem;
}

.emm-slider-nav[data-emm-slider-nav="next"] {
  right: -0.75rem;
}

.emm-slider-nav[disabled] {
  opacity: 0.25;
  pointer-events: none;
}

.emm-products-grid {
  display: grid;
  gap: var(--emm-space-5);
  grid-template-columns: repeat(var(--emm-columns, 4), minmax(0, 1fr));
}

.emm-faq {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  overflow: hidden;
}

.emm-faq details {
  border-top: var(--emm-border-hairline);
  background: var(--emm-color-white);
}

.emm-faq details:first-child {
  border-top: none;
}

.emm-faq summary {
  list-style: none;
  cursor: pointer;
  padding: var(--emm-space-4) var(--emm-space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--emm-space-4);
  font-size: var(--emm-step-0);
  font-weight: 550;
}

.emm-faq summary::-webkit-details-marker {
  display: none;
}

.emm-faq__icon {
  font-size: 1.1rem;
  color: var(--emm-color-muted);
  transition: transform var(--emm-time-base) var(--emm-ease);
}

.emm-faq details[open] .emm-faq__icon {
  transform: rotate(45deg);
}

.emm-faq__body {
  padding: 0 var(--emm-space-5) var(--emm-space-4);
  color: var(--emm-color-muted);
  font-size: var(--emm-step--1);
  line-height: 1.6;
}

.emm-newsletter {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  background: color-mix(in srgb, var(--emm-color-white) 84%, var(--emm-color-paper));
  padding: clamp(1.35rem, 3.5vw, 2.4rem);
}

.emm-newsletter form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--emm-space-3);
  margin-top: var(--emm-space-5);
}

.emm-newsletter__submit {
  min-width: 2.9rem;
  padding-inline: 0.95rem;
}

.emm-links-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--emm-space-2);
}

.emm-links-list a {
  color: var(--emm-color-ink-soft);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  width: fit-content;
}

.emm-links-list a:hover {
  border-bottom-color: currentColor;
}

.emm-slideshow {
  position: relative;
  border-radius: var(--emm-radius-lg);
  overflow: hidden;
  min-height: var(--emm-slide-height, 26rem);
  border: var(--emm-border-hairline);
}

.emm-slideshow__track {
  position: relative;
  min-height: inherit;
}

.emm-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--emm-time-slow) var(--emm-ease);
}

.emm-slide.is-active {
  opacity: 1;
  pointer-events: auto;
}

.emm-slide__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

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

.emm-slide__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(17, 20, 24, 0.16), rgba(17, 20, 24, 0.45));
}

.emm-slide__content {
  position: relative;
  z-index: 1;
  min-height: inherit;
  display: grid;
  align-content: end;
  gap: var(--emm-space-4);
  padding: clamp(1.5rem, 4vw, 2.5rem);
  max-width: 40rem;
  color: #f7f4ec;
}

.emm-slideshow__nav {
  position: absolute;
  right: var(--emm-space-4);
  bottom: var(--emm-space-4);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: var(--emm-space-2);
}

.emm-slideshow__nav button {
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(20, 23, 27, 0.45);
  color: #f7f4ec;
}

.emm-video {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  overflow: hidden;
  background: var(--emm-color-paper);
}

.emm-video__frame {
  position: relative;
  width: 100%;
  padding-bottom: var(--emm-video-ratio, 56.25%);
}

.emm-video__frame iframe,
.emm-video__placeholder {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.emm-video__placeholder {
  display: grid;
  place-items: center;
  background-size: cover;
  background-position: center;
  color: var(--emm-color-muted);
}

.emm-site-footer {
  margin-top: clamp(3rem, 8vw, 6rem);
  border-top: var(--emm-border-hairline);
  background: var(--emm-color-paper);
  color: var(--emm-color-ink);
}

.emm-site-footer__inner {
  padding-block: clamp(2.25rem, 6vw, 4rem) clamp(1.2rem, 2.8vw, 2rem);
}

.emm-site-footer__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 1.3fr;
  gap: var(--emm-space-8);
}

.emm-site-footer__block {
  display: grid;
  gap: var(--emm-space-3);
  align-content: start;
}

.emm-site-footer__title {
  margin: 0;
  font-size: var(--emm-step-0);
  font-weight: 620;
  letter-spacing: 0.01em;
}

.emm-site-footer__copy {
  margin: 0;
  color: var(--emm-color-muted);
  font-size: var(--emm-step--1);
  line-height: 1.6;
}

.emm-site-footer__form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--emm-space-2);
}

.emm-site-footer__meta {
  margin-top: var(--emm-space-8);
  padding-top: var(--emm-space-4);
  border-top: var(--emm-border-hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--emm-space-3);
  flex-wrap: wrap;
}

.emm-site-footer__meta p {
  margin: 0;
  color: var(--emm-color-muted);
  font-size: var(--emm-step--2);
}

.emm-testimonial {
  display: grid;
  gap: var(--emm-space-3);
  padding: var(--emm-space-5);
}

.emm-testimonial__quote {
  margin: 0;
  font-size: var(--emm-step-0);
  line-height: 1.65;
}

.emm-testimonial__meta {
  margin: 0;
  color: var(--emm-color-muted);
  font-size: var(--emm-step--1);
}

.emm-richtext {
  font-size: var(--emm-step-0);
  line-height: 1.75;
  color: var(--emm-color-ink-soft);
}

.emm-richtext p,
.emm-richtext ul,
.emm-richtext ol,
.emm-richtext blockquote {
  margin-block: 0 1em;
}

.emm-richtext h2,
.emm-richtext h3,
.emm-richtext h4 {
  margin: 1.2em 0 0.5em;
  color: var(--emm-color-ink);
  line-height: 1.25;
}

.emm-richtext a {
  color: var(--emm-color-accent);
}

.emm-richtext blockquote {
  border-left: 1px solid var(--emm-color-line-strong);
  padding-left: var(--emm-space-4);
  color: var(--emm-color-muted);
}

.emm-empty {
  padding: var(--emm-space-8);
  text-align: center;
  color: var(--emm-color-muted);
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-md);
}

@media (min-width: 62rem) {
  .emm-title {
    font-size: clamp(1.56rem, 1.2rem + 1.05vw, 2.2rem);
  }

  .emm-title--display {
    font-size: clamp(1.78rem, 1.28rem + 1.45vw, 2.6rem);
  }

  .emm-header__menu-btn {
    display: none;
  }

  .emm-nav--desktop {
    display: block;
  }

  .emm-header__inner {
    display: flex;
    align-items: center;
    min-height: 4.9rem;
    gap: var(--emm-space-6);
  }

  .emm-header__wordmark {
    order: 1;
    justify-self: auto;
    font-size: clamp(1.8rem, 1.4rem + 1vw, 2.3rem);
  }

  .emm-header__left {
    order: 2;
    margin-left: clamp(1.1rem, 2.6vw, 2.6rem);
  }

  .emm-header__right {
    order: 3;
    margin-left: auto;
    justify-self: auto;
  }

  .emm-cart-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: auto;
    width: min(27rem, 92vw);
    max-height: 100dvh;
    border-top: none;
    border-bottom: none;
    border-left: var(--emm-border-hairline);
    box-shadow: -14px 0 32px rgba(17, 21, 27, 0.18);
    transform: translateX(100%);
    opacity: 1;
    visibility: visible;
    pointer-events: none;
    z-index: calc(var(--emm-z-drawer) + 6);
  }

  .emm-cart-panel.is-open {
    transform: translateX(0);
    pointer-events: auto;
  }

  .emm-cart-panel__inner {
    height: 100dvh;
    background: var(--emm-color-ivory);
  }
}

@media (max-width: 61.99rem) {
  .emm-header__inner {
    min-height: 4.35rem;
    grid-template-columns: auto auto minmax(0, 1fr) auto;
    gap: 0.35rem;
  }

  .emm-header.is-compact .emm-header__inner {
    min-height: 3.9rem;
  }

  .emm-header__left {
    grid-column: 1;
    gap: 0.15rem;
  }

  .emm-header__wordmark {
    grid-column: 2;
    justify-self: start;
    font-size: clamp(1.45rem, 1.2rem + 0.8vw, 1.75rem);
  }

  .emm-header__right {
    grid-column: 4;
    gap: 0.15rem;
  }

  .emm-header__wordmark {
    letter-spacing: -0.015em;
  }

  .emm-header__wordmark img {
    height: 1.75rem;
  }

  .emm-search-form {
    grid-template-columns: 1fr;
  }

  .emm-search-form .emm-btn {
    width: 100%;
  }

  .emm-search-panel {
    max-height: var(--emm-search-max-height);
  }

  .emm-account-panel__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--emm-space-2);
  }

  .emm-account-panel__link {
    min-height: 2.7rem;
    border-radius: var(--emm-radius-pill);
    padding: 0.4rem 0.75rem;
  }

  .emm-field {
    font-size: 16px;
  }

  /* Prevent iOS focus-zoom while still allowing manual pinch-zoom. */
  input,
  textarea,
  select {
    font-size: 16px;
  }

  .emm-cart-panel {
    position: fixed;
    left: 0;
    right: 0;
    top: var(--emm-cart-top, var(--emm-header-height, 4.35rem));
    bottom: auto;
    max-height: min(78dvh, var(--emm-cart-max-height, 78dvh));
    border-left: none;
    box-shadow: 0 14px 30px rgba(17, 21, 27, 0.16);
  }

  .emm-cart-panel__actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 64rem) {
  .emm-hero__shell {
    min-height: clamp(
      300px,
      calc((min(var(--emm-container-max), calc(100vw - (var(--emm-page-pad) * 2))) * 9) / 16),
      720px
    );
  }

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

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

  .emm-products-grid {
    grid-template-columns: repeat(min(2, var(--emm-columns, 2)), minmax(0, 1fr));
  }

  .emm-slider-nav {
    display: none;
  }
}

@media (max-width: 48rem) {
  .emm-hero__shell {
    min-height: clamp(
      200px,
      calc((min(var(--emm-container-max), calc(100vw - (var(--emm-page-pad) * 2))) * 9) / 16),
      420px
    );
  }

  :root {
    --emm-section-pad: clamp(1.2rem, 5.8vw, 2rem);
  }

  .emm-section--page {
    padding-top: clamp(0.5rem, 2.8vw, 0.9rem);
    padding-bottom: clamp(1.15rem, 5.2vw, 1.9rem);
  }

  .emm-grid--2,
  .emm-grid--3,
  .emm-grid--4,
  .emm-products-grid,
  .emm-newsletter form {
    grid-template-columns: 1fr;
  }

  /* Keep category/collection section at minimum 2 columns on mobile. */
  .emm-collections .emm-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .emm-split {
    gap: var(--emm-space-3);
  }

  .emm-image-text--quote-cta .emm-quote-cta-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "content"
      "actions"
      "media";
    gap: clamp(0.9rem, 3.6vw, 1.3rem);
  }

  .emm-image-text--quote-cta .emm-quote-cta-grid.is-media-only {
    grid-template-areas: "media";
  }

  .emm-image-text--quote-cta .emm-quote-cta-body {
    -webkit-line-clamp: 4;
  }

  .emm-image-text--quote-cta .emm-quote-cta-actions {
    width: 100%;
  }

  .emm-image-text--quote-cta .emm-quote-cta-actions .emm-quote-cta-btn {
    width: 100%;
    justify-content: center;
  }

  .emm-image-text--quote-cta .emm-quote-cta-media {
    min-height: clamp(12.6rem, 54vw, 17rem);
  }

  .emm-hero__inner {
    min-height: inherit;
    height: 100%;
    align-items: stretch;
    justify-items: start;
    text-align: left;
    padding-block: clamp(1rem, 4.8vw, 1.8rem);
  }

  .emm-hero__content {
    gap: var(--emm-space-3);
    max-width: min(30rem, 100%);
  }

  .emm-hero--align-mobile-center .emm-hero__inner {
    justify-items: start;
  }

  .emm-hero--align-mobile-center .emm-hero__content {
    margin-inline: 0 auto;
  }

  .emm-hero--align-mobile-right .emm-hero__inner {
    justify-items: start;
  }

  .emm-hero--align-mobile-right .emm-hero__content {
    margin-inline: 0 auto;
  }

  .emm-hero__content .emm-title {
    font-size: clamp(1.45rem, 7.2vw, 2.1rem);
    line-height: 1.08;
  }

  .emm-hero__content .emm-copy {
    font-size: clamp(0.9rem, 3.5vw, 1.05rem);
    line-height: 1.4;
  }

  .emm-hero__meta {
    gap: var(--emm-space-2);
    font-size: var(--emm-step--1);
  }

  .emm-hero__actions {
    width: 100%;
    display: grid;
    gap: 0.7rem;
    max-width: min(26rem, 100%);
  }

  .emm-hero__actions .emm-btn {
    width: 100%;
    min-height: 2.55rem;
    font-size: var(--emm-step--1);
  }

  .emm-announcement__dismiss {
    inset-inline-end: var(--emm-space-2);
  }

  .emm-product-track {
    grid-auto-columns: minmax(11rem, 74vw);
  }

  .emm-site-footer__grid {
    grid-template-columns: 1fr;
    gap: var(--emm-space-6);
  }

  .emm-site-footer__form {
    grid-template-columns: 1fr;
  }
}

.emm-simple-header__inner {
  width: min(var(--emm-simple-header-max, 54rem), 100%);
  display: grid;
  gap: var(--emm-space-3);
}

.emm-simple-header--center .emm-simple-header__inner {
  margin-inline: auto;
  text-align: center;
}

.emm-simple-header__divider {
  width: min(5rem, 22vw);
  border-top: var(--emm-border-hairline);
  margin-bottom: var(--emm-space-2);
}

.emm-simple-header--center .emm-simple-header__divider {
  margin-inline: auto;
}

.emm-simple-text__inner {
  width: min(var(--emm-simple-text-max, 54rem), 100%);
  display: grid;
  gap: var(--emm-space-3);
}

.emm-simple-text--center .emm-simple-text__inner {
  margin-inline: auto;
  text-align: center;
}

.emm-simple-text__content {
  max-width: 72ch;
}

.emm-simple-text--center .emm-simple-text__content {
  margin-inline: auto;
}

.emm-stats-grid__items {
  display: grid;
  gap: var(--emm-space-4);
  grid-template-columns: repeat(var(--emm-stats-cols, 4), minmax(0, 1fr));
}

.emm-stats-grid__item {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  background: color-mix(in srgb, var(--emm-color-white) 92%, var(--emm-color-paper));
  padding: var(--emm-space-5);
  display: grid;
  gap: var(--emm-space-2);
}

.emm-stats-grid__value {
  margin: 0;
  font-family: var(--emm-font-display);
  font-size: clamp(1.6rem, 2.6vw, 2.5rem);
  color: var(--emm-color-ink);
  line-height: 1.08;
}

.emm-stats-grid__label {
  margin: 0;
  font-size: var(--emm-step-0);
  color: var(--emm-color-ink-soft);
}

.emm-logo-cloud__grid {
  display: grid;
  gap: var(--emm-space-4);
  grid-template-columns: repeat(var(--emm-logo-cols, 5), minmax(0, 1fr));
}

.emm-logo-cloud__item {
  border: 0;
  border-radius: 0;
  background: transparent;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  text-decoration: none;
}

.emm-logo-cloud__item img {
  width: auto;
  max-width: 100%;
  height: var(--emm-logo-height, 2.6rem);
  object-fit: contain;
}

.emm-logo-cloud--mono .emm-logo-cloud__item img {
  filter: grayscale(1);
  opacity: 0.88;
}

.emm-logo-cloud--enhanced .emm-logo-cloud__grid {
  gap: var(--emm-logo-gap, var(--emm-space-4));
}

.emm-logo-cloud .emm-stack > header + .emm-logo-cloud__viewport,
.emm-logo-cloud .emm-stack > header + .emm-logo-cloud__grid {
  margin-top: clamp(1rem, 2.4vw, 1.8rem);
}

.emm-logo-cloud__viewport {
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  --emm-logo-per-view-active: var(--emm-logo-per-view, 5);
  --emm-logo-gap-active: var(--emm-logo-gap, var(--emm-space-4));
  --emm-logo-slot: calc((100% - ((var(--emm-logo-per-view-active) - 1) * var(--emm-logo-gap-active))) / var(--emm-logo-per-view-active));
  --emm-logo-shift: calc((var(--emm-logo-count, 1) * var(--emm-logo-slot)) + ((var(--emm-logo-count, 1) - 1) * var(--emm-logo-gap-active)));
}

.emm-logo-cloud__viewport.is-fade {
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 14%, #000 86%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, #000 14%, #000 86%, transparent 100%);
  -webkit-mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
}

.emm-logo-cloud__viewport.is-fade::before,
.emm-logo-cloud__viewport.is-fade::after {
  content: "";
  position: absolute;
  top: 0;
  width: clamp(28px, 6vw, 72px);
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

.emm-logo-cloud__viewport.is-fade::before {
  left: 0;
  background: linear-gradient(to right, #000 0%, transparent 100%);
}

.emm-logo-cloud__viewport.is-fade::after {
  right: 0;
  background: linear-gradient(to left, #000 0%, transparent 100%);
}

@supports ((mask-image: linear-gradient(to right, #000, transparent)) or (-webkit-mask-image: linear-gradient(to right, #000, transparent))) {
  .emm-logo-cloud__viewport.is-fade::before,
  .emm-logo-cloud__viewport.is-fade::after {
    display: none;
  }
}

.emm-logo-cloud__track {
  display: flex;
  gap: var(--emm-logo-gap-active);
  width: max-content;
  min-width: max-content;
  align-items: center;
}

.emm-logo-cloud__track .emm-logo-cloud__item {
  min-width: var(--emm-logo-slot);
  flex: 0 0 var(--emm-logo-slot);
}

.emm-logo-cloud__track.is-animated {
  animation: emm-logo-cloud-scroll linear infinite;
  animation-duration: var(--emm-logo-speed, 36s);
}

.emm-logo-cloud__viewport.pause-on-hover:hover .emm-logo-cloud__track.is-animated {
  animation-play-state: paused;
}

@keyframes emm-logo-cloud-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-1 * var(--emm-logo-shift)));
  }
}

.emm-feature-list__items {
  display: grid;
  gap: var(--emm-space-4);
}

.emm-feature-list--grid .emm-feature-list__items {
  grid-template-columns: repeat(var(--emm-feature-cols, 3), minmax(0, 1fr));
}

.emm-feature-list__item {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  background: color-mix(in srgb, var(--emm-color-white) 90%, var(--emm-color-paper));
  padding: var(--emm-space-5);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--emm-space-4);
  align-items: start;
}

.emm-feature-list--list .emm-feature-list__item {
  grid-template-columns: 1fr;
}

.emm-feature-list__icon {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  border: var(--emm-border-hairline);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--emm-color-ink-soft);
  background: color-mix(in srgb, var(--emm-color-paper) 85%, white);
}

.emm-process-timeline__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--emm-space-4);
}

.emm-process-timeline__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--emm-space-4);
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  background: color-mix(in srgb, var(--emm-color-white) 92%, var(--emm-color-paper));
  padding: var(--emm-space-5);
}

.emm-process-timeline__index {
  width: 2.2rem;
  height: 2.2rem;
  border-radius: var(--emm-radius-pill);
  border: var(--emm-border-hairline);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--emm-step--1);
  color: var(--emm-color-muted);
}

.emm-process-timeline--compact .emm-process-timeline__list {
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
}

.emm-process-timeline--compact .emm-process-timeline__item {
  grid-template-columns: 1fr;
}

.emm-team-grid__items {
  display: grid;
  gap: var(--emm-space-4);
  grid-template-columns: repeat(var(--emm-team-cols, 3), minmax(0, 1fr));
}

.emm-team-grid__item {
  overflow: hidden;
  padding: var(--emm-space-4);
}

.emm-team-grid__media {
  border-radius: var(--emm-radius-md);
  overflow: hidden;
  border: var(--emm-border-hairline);
  background: color-mix(in srgb, var(--emm-color-paper) 85%, white);
  aspect-ratio: var(--emm-team-ratio, 4/5);
  margin-bottom: var(--emm-space-4);
}

.emm-team-grid__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.emm-quote-highlight__inner {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  background: color-mix(in srgb, var(--emm-color-white) 88%, var(--emm-color-paper));
  padding: clamp(1.35rem, 3.4vw, 2.5rem);
  display: grid;
  gap: var(--emm-space-4);
  margin: 0;
}

.emm-quote-highlight__media {
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  overflow: hidden;
  border: var(--emm-border-hairline);
}

.emm-quote-highlight__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.emm-quote-highlight blockquote {
  margin: 0;
}

.emm-quote-highlight--center .emm-quote-highlight__inner {
  justify-items: center;
  text-align: center;
}

.emm-contact-panel__inner {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  background: color-mix(in srgb, var(--emm-color-white) 88%, var(--emm-color-paper));
  padding: clamp(1.3rem, 3.4vw, 2.4rem);
  display: grid;
  gap: var(--emm-space-5);
}

.emm-contact-panel__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--emm-space-6);
  align-items: start;
}

.emm-contact-panel__details {
  margin: 0;
  font-style: normal;
  display: grid;
  gap: var(--emm-space-2);
}

.emm-contact-panel__details p {
  margin: 0;
}

.emm-contact-panel__actions {
  display: grid;
  gap: var(--emm-space-3);
  justify-items: start;
}

.emm-cta-strip__inner {
  border: var(--emm-border-hairline);
  border-radius: var(--emm-radius-lg);
  padding: clamp(1rem, 2.6vw, 1.6rem) clamp(1rem, 2.8vw, 2rem);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--emm-space-4);
  align-items: center;
}

.emm-cta-strip--center .emm-cta-strip__inner {
  justify-items: center;
  text-align: center;
  grid-template-columns: 1fr;
}

.emm-cta-strip__actions {
  display: inline-flex;
  align-items: center;
  gap: var(--emm-space-3);
  flex-wrap: wrap;
}

@media (max-width: 70rem) {
  .emm-stats-grid__items {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .emm-logo-cloud__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .emm-logo-cloud--enhanced .emm-logo-cloud__grid {
    grid-template-columns: repeat(var(--emm-logo-cols-tablet, 3), minmax(0, 1fr));
  }

  .emm-logo-cloud__viewport {
    --emm-logo-per-view-active: var(--emm-logo-per-view-tablet, 4);
  }

  .emm-feature-list--grid .emm-feature-list__items {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .emm-contact-panel__body,
  .emm-cta-strip__inner {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 48rem) {
  .emm-stats-grid__items,
  .emm-logo-cloud__grid,
  .emm-feature-list--grid .emm-feature-list__items,
  .emm-team-grid__items,
  .emm-process-timeline--compact .emm-process-timeline__list {
    grid-template-columns: 1fr;
  }

  .emm-logo-cloud--enhanced .emm-logo-cloud__grid {
    grid-template-columns: repeat(var(--emm-logo-cols-mobile, 2), minmax(0, 1fr));
  }

  .emm-logo-cloud__viewport {
    --emm-logo-per-view-active: var(--emm-logo-per-view-mobile, 2);
  }
}

@media (prefers-reduced-motion: reduce) {
  .emm-image-text--quote-cta [data-cta-motion] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

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