/** Shopify CDN: Minification failed

Line 302:17 Unterminated string token

**/
:root {
  --ivory: #f7f2eb;
  --porcelain: #fffdf9;
  --linen: #e8dfd4;
  --rose: #b98e86;
  --silver: #aaa6a0;
  --gold: #a9884a;
  --charcoal: #252320;
  --ink-soft: #625b52;
  --line: rgba(37, 35, 32, 0.13);
  --shadow: 0 18px 46px rgba(42, 34, 25, 0.08);
  --page-width: 1180px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  color: var(--charcoal);
  background: var(--porcelain);
  font-family: "Helvetica Neue", Arial, sans-serif;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
img, video { max-width: 100%; display: block; }
button, input, textarea, select { font: inherit; }

.skip-link {
  position: absolute;
  left: 1rem;
  top: -4rem;
  z-index: 100;
  padding: .75rem 1rem;
  background: var(--charcoal);
  color: #fff;
}

.skip-link:focus { top: 1rem; }

.page-width {
  width: min(var(--page-width), calc(100vw - 32px));
  margin-inline: auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  width: 100%;
  background: rgba(255, 253, 249, 0.97);
  border-bottom: 1px solid rgba(37, 35, 32, .1);
  backdrop-filter: blur(10px);
}

.site-header__inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  min-height: 76px;
  gap: clamp(1rem, 2.5vw, 2.25rem);
}

.site-header__brand {
  justify-self: center;
  color: var(--charcoal);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.55rem, 2vw, 2rem);
  line-height: 1;
  letter-spacing: .16em;
  text-transform: uppercase;
  white-space: nowrap;
}

.site-header__brand img {
  width: auto;
  max-width: 180px;
  max-height: 42px;
  object-fit: contain;
}

.site-header__nav {
  display: flex;
  align-items: center;
  gap: clamp(.9rem, 1.8vw, 1.7rem);
  color: var(--charcoal);
  font-size: .84rem;
  letter-spacing: .02em;
  white-space: nowrap;
}

.site-header__nav--left {
  justify-content: flex-start;
}

.site-header__nav--right { justify-content: flex-end; }

.site-header__nav a,
.site-header__mobile-panel a {
  color: inherit;
  transition: color .2s ease;
}

.site-header__nav a:hover,
.site-header__mobile-panel a:hover {
  color: var(--gold);
}

.site-header__mobile-menu {
  display: none;
}

.site-header__menu-toggle {
  display: grid;
  width: 42px;
  height: 42px;
  place-content: center;
  gap: 5px;
  cursor: pointer;
  list-style: none;
}

.site-header__menu-toggle::-webkit-details-marker {
  display: none;
}

.site-header__menu-toggle span {
  display: block;
  width: 22px;
  height: 1px;
  background: var(--charcoal);
}

.site-header__mobile-panel {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  display: grid;
  gap: 1.05rem;
  padding: 1.25rem 1rem 1.5rem;
  border-top: 1px solid rgba(37, 35, 32, .08);
  border-bottom: 1px solid rgba(37, 35, 32, .1);
  background: #fffdf9;
  box-shadow: 0 18px 40px rgba(37, 35, 32, .08);
  color: var(--charcoal);
  font-size: .92rem;
}

.button, .shopify-payment-button__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 1.3rem;
  border: 1px solid var(--charcoal);
  background: var(--charcoal);
  color: #fff;
  border-radius: 2px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .74rem;
}

.button--secondary {
  background: transparent;
  color: var(--charcoal);
}

.section {
  padding: 68px 0;
}

.section--soft { background: var(--ivory); }
.section--line { border-top: 1px solid var(--line); }

.eyebrow {
  margin: 0 0 .85rem;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .2em;
  font-size: .72rem;
}

.heading {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 400;
  line-height: 1.08;
}

.heading--xl { font-size: clamp(2.55rem, 4.15vw, 4.65rem); }
.heading--lg { font-size: clamp(1.95rem, 3.1vw, 3.35rem); }
.heading--md { font-size: clamp(1.55rem, 2.2vw, 2.2rem); }

.rte {
  color: var(--ink-soft);
  max-width: 72ch;
}

.hero-memory .rte {
  max-width: 460px;
  margin-top: 1rem;
  color: rgba(255, 253, 249, .88);
  font-size: clamp(1rem, 1.25vw, 1.14rem);
  line-height: 1.65;
}

.hero-memory {
  position: relative;
  min-height: clamp(520px, 66vh, 680px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(17, 14, 10, .68) 0%, rgba(17, 14, 10, .42) 35%, rgba(17, 14, 10, .1) 70%, rgba(17, 14, 10, .04) 100%),
    var(--hero-bg, linear-gradient(135deg, #2b241d, #9b8060));
  background-size: var(--hero-size, cover);
  background-repeat: no-repeat;
  background-position: var(--hero-position, center center);
  background-color: #211a14;
}

.hero-memory__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.03) 0%, rgba(0,0,0,.08) 48%, rgba(0,0,0,.28) 100%);
  pointer-events: none;
}

.hero-memory__content {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: clamp(4rem, 8vh, 5.5rem) 0 clamp(3.4rem, 6vh, 5rem);
}

.hero-memory__copy {
  max-width: 540px;
  margin-left: clamp(1.5rem, 5vw, 5rem);
}

.hero-memory__copy .eyebrow {
  margin-bottom: 1rem;
  color: rgba(255, 253, 249, .78);
  letter-spacing: .24em;
}

.hero-memory__copy .heading {
  max-width: 540px;
  color: var(--porcelain);
  font-size: clamp(2.25rem, 4.25vw, 4.35rem);
  line-height: 1.02;
  text-wrap: balance;
}

.hero-memory__actions { display: flex; flex-wrap: wrap; gap: .85rem; margin-top: 1.7rem; }

.hero-memory__actions .button {
  min-height: 46px;
  padding-inline: 1.35rem;
  border-color: var(--porcelain);
  background: var(--porcelain);
  color: var(--charcoal);
}

.hero-memory__actions .button--secondary {
  border-color: rgba(255, 253, 249, .72);
  background: transparent;
  color: var(--porcelain);
}

.hero-memory__feature-row {
  position: absolute;
  left: 50%;
  bottom: 1.1rem;
  z-index: 1;
  transform: translateX(-50%);
  display: flex;
  justify-content: space-between;
  gap: 1.25rem;
  color: rgba(255, 253, 249, .72);
  font-size: .68rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.hero-memory__feature-row span {
  white-space: nowrap;
}

.hero-memory__feature-row span:not(:last-child)::after {
  content: "鈫?;
  margin-left: 1.25rem;
  color: rgba(255, 253, 249, .46);
}

.media-frame {
  position: relative;
  min-height: 420px;
  background:
    linear-gradient(135deg, rgba(232,223,212,.72), rgba(255,253,249,.86) 52%, rgba(212,198,186,.74)),
    repeating-linear-gradient(90deg, rgba(37,35,32,.035) 0 1px, transparent 1px 54px);
  border: 1px solid var(--line);
  overflow: hidden;
  box-shadow: var(--shadow);
}

.media-frame--hero {
  aspect-ratio: 4 / 5;
  min-height: 0;
  max-height: 620px;
}

.media-frame--feature {
  aspect-ratio: 1 / 1.08;
  min-height: 0;
}

.media-frame--empty::after {
  content: "Upload product image or video";
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  padding: .75rem;
  background: rgba(255, 253, 249, .9);
  color: var(--ink-soft);
  text-align: center;
  font-size: .72rem;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.media-frame img, .media-frame video {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
}

.media-frame--fit-contain img,
.media-frame--fit-contain video {
  object-fit: contain;
  background: var(--ivory);
}

.grid-4 {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.series-card {
  border: 1px solid var(--line);
  background: #fff;
  min-height: 100%;
  transition: transform .18s ease, box-shadow .18s ease;
}

.series-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}

.series-card__media {
  aspect-ratio: var(--series-media-ratio, 4 / 5);
  background: linear-gradient(135deg, #eee6dc, #fbf8f2);
  overflow: hidden;
  display: grid;
  place-items: center;
}

.series-card__media img {
  width: 100%;
  height: 100%;
  object-fit: var(--series-media-fit, cover);
  object-position: center;
}

.series-card__media--contain img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.series-card__body { padding: 1.15rem; }
.series-card__title { margin: 0 0 .5rem; font-family: Georgia, "Times New Roman", serif; font-size: 1.2rem; line-height: 1.18; }
.series-card__text { margin: 0; color: var(--ink-soft); font-size: .95rem; }

.trust-bar {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--porcelain);
}

.trust-bar__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.trust-bar__item {
  min-height: 96px;
  padding: 1.15rem 1.25rem;
  border-left: 1px solid var(--line);
}

.trust-bar__item:last-child { border-right: 1px solid var(--line); }
.trust-bar__item h3 {
  margin: 0 0 .28rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.05rem;
  font-weight: 400;
}

.trust-bar__item p {
  margin: 0;
  color: var(--ink-soft);
  font-size: .86rem;
}

.steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  counter-reset: steps;
}

.step {
  position: relative;
  min-height: 280px;
  padding: 1.4rem 1.25rem;
  border: 1px solid var(--line);
  border-right: 0;
  background: rgba(255, 253, 249, .72);
  counter-increment: steps;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.step:last-child { border-right: 1px solid var(--line); }

.step::before {
  content: "0" counter(steps);
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--gold);
  border-radius: 50%;
  color: var(--gold);
  letter-spacing: .12em;
  font-size: .76rem;
}

.step:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 48px;
  right: -12px;
  width: 24px;
  height: 24px;
  z-index: 2;
  background: var(--porcelain);
  border-top: 1px solid var(--line);
  border-right: 1px solid var(--line);
  transform: rotate(45deg);
}

.step h3 { margin: .5rem 0; font-family: Georgia, "Times New Roman", serif; font-weight: 400; }
.step p { margin: 0; color: var(--ink-soft); }

.step__link {
  display: inline-flex;
  width: fit-content;
  margin-top: 1rem;
  padding-bottom: .18rem;
  border-bottom: 1px solid var(--gold);
  color: var(--charcoal);
  font-size: .78rem;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.process-contact {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem 1rem;
  justify-content: space-between;
  align-items: center;
  margin-top: 1.25rem;
  padding: 1rem 1.15rem;
  border: 1px solid var(--line);
  background: var(--porcelain);
}

.process-contact p { margin: 0; color: var(--ink-soft); }
.process-contact a { color: var(--charcoal); border-bottom: 1px solid var(--gold); }

.memory-process {
  position: relative;
  overflow: hidden;
  padding: clamp(4.5rem, 7vw, 7rem) 0;
  background:
    radial-gradient(circle at 50% 0%, rgba(169, 136, 74, .13), transparent 34%),
    linear-gradient(180deg, #fffdf9 0%, #f7f2eb 100%);
}

.memory-process__header {
  max-width: 760px;
  margin-inline: auto;
  text-align: center;
}

.memory-process__header .heading {
  font-size: clamp(2.2rem, 4vw, 4rem);
}

.memory-process__header > p:last-child {
  max-width: 620px;
  margin: 1rem auto 0;
  color: var(--ink-soft);
  font-size: clamp(1rem, 1.25vw, 1.16rem);
}

.memory-process__steps {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.15rem;
  margin-top: clamp(3rem, 4.8vw, 4.8rem);
}

.memory-process__steps::before {
  content: "";
  position: absolute;
  top: 48px;
  left: 12%;
  right: 12%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(169, 136, 74, .48), transparent);
}

.memory-process__step {
  position: relative;
  z-index: 1;
  min-height: 330px;
  padding: 2rem 1.25rem 1.75rem;
  border: 1px solid rgba(169, 136, 74, .24);
  background: rgba(255, 253, 249, .9);
  text-align: center;
  box-shadow: 0 14px 34px rgba(42, 34, 25, .045);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.memory-process__step:hover {
  transform: translateY(-8px);
  border-color: rgba(169, 136, 74, .5);
  box-shadow: 0 22px 48px rgba(42, 34, 25, .085);
}

.memory-process__icon {
  display: inline-flex;
  width: 112px;
  height: 112px;
  align-items: center;
  justify-content: center;
  margin-inline: auto;
  border: 1px solid rgba(169, 136, 74, .42);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 253, 249, 1) 0%, rgba(247, 242, 235, .95) 100%);
  color: var(--gold);
}

.memory-process__icon svg {
  width: 50px;
  height: 50px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.45;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.memory-process__number {
  margin: 1.45rem 0 .6rem;
  color: var(--gold);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.memory-process__step h3 {
  margin: 0;
  color: var(--charcoal);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.35rem, 1.75vw, 1.75rem);
  font-weight: 400;
  line-height: 1.15;
}

.memory-process__step > p:last-child {
  margin: .75rem 0 0;
  color: var(--ink-soft);
  font-size: .84rem;
  line-height: 1.45;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.memory-process__cta {
  display: flex;
  justify-content: center;
  margin-top: clamp(2rem, 3.5vw, 3.25rem);
}

.memory-process__cta .button {
  min-width: 220px;
}

.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.feature-list {
  display: grid;
  gap: .85rem;
  margin: 1.5rem 0 0;
  padding: 0;
  list-style: none;
}

.feature-list li {
  padding: .85rem 0;
  border-bottom: 1px solid var(--line);
}

.reviews-film-section {
  position: relative;
  overflow: hidden;
  padding: clamp(2.75rem, 4.8vw, 4.75rem) 0;
  background:
    radial-gradient(circle at 8% 16%, rgba(177, 138, 76, .16), transparent 32%),
    linear-gradient(180deg, #fffaf2 0%, #efe3d2 100%);
}

.reviews-film__header {
  max-width: 680px;
  margin: 0 auto clamp(1.1rem, 2.3vw, 2rem);
  text-align: center;
}

.reviews-film__header .heading {
  font-size: clamp(2rem, 4vw, 3.6rem);
}

.reviews-wrap {
  position: relative;
  width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  scroll-snap-type: x proximity;
  scroll-behavior: smooth;
  cursor: grab;
  user-select: none;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(102, 77, 49, .38) rgba(255, 250, 242, .62);
}

.reviews-wrap::-webkit-scrollbar {
  height: 8px;
}

.reviews-wrap::-webkit-scrollbar-track {
  background: rgba(255, 250, 242, .68);
}

.reviews-wrap::-webkit-scrollbar-thumb {
  background: rgba(102, 77, 49, .34);
  border-radius: 999px;
}

.reviews-wrap.is-dragging {
  cursor: grabbing;
  scroll-behavior: auto;
}

.reviews-track {
  position: relative;
  display: flex;
  width: max-content;
  gap: clamp(.85rem, 1.8vw, 1.4rem);
  padding: 2.15rem max(1.25rem, calc((100vw - 1180px) / 2)) 2.35rem;
}

.reviews-track::before,
.reviews-track::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 12px;
  background-image: repeating-linear-gradient(90deg, rgba(62, 49, 36, .76) 0 12px, transparent 12px 23px);
  background-size: 23px 12px;
  opacity: .54;
  pointer-events: none;
}

.reviews-track::before { top: .65rem; }
.reviews-track::after { bottom: .75rem; }

.review-card {
  scroll-snap-align: center;
  flex: 0 0 clamp(230px, 22vw, 310px);
  min-height: 0;
  padding: .65rem .65rem 1rem;
  border: 1px solid rgba(139, 105, 55, .22);
  background: linear-gradient(180deg, rgba(255, 252, 244, .98), rgba(245, 235, 219, .96));
  box-shadow: 0 18px 34px rgba(68, 52, 35, .14);
  transform: rotate(var(--review-rotation, -1deg));
  transform-origin: 50% 58%;
  transition: transform .35s ease, box-shadow .35s ease;
}

.review-card:hover {
  transform: rotate(0deg) translateY(-6px);
  box-shadow: 0 24px 46px rgba(68, 52, 35, .2);
}

.review-card--tilt-0 { --review-rotation: -1.7deg; }
.review-card--tilt-1 { --review-rotation: 1.2deg; }
.review-card--tilt-2 { --review-rotation: -0.8deg; }
.review-card--tilt-3 { --review-rotation: 1.8deg; }
.review-card--tilt-4 { --review-rotation: -1.2deg; }

.review-card__image {
  aspect-ratio: 5 / 4;
  background: linear-gradient(135deg, #e6d6be, #fbf4e8);
  overflow: hidden;
}

.review-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: sepia(.12) saturate(.92) contrast(.98);
  pointer-events: none;
}

.review-card__placeholder {
  display: grid;
  width: 100%;
  height: 100%;
  place-items: center;
  color: rgba(78, 61, 43, .34);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 5rem;
  text-transform: uppercase;
}

.review-card__copy {
  padding: .75rem .35rem 0;
}

.review-card__score {
  display: flex;
  align-items: center;
  gap: .55rem;
}

.review-card__stars {
  color: var(--gold);
  letter-spacing: .08em;
  font-size: .78rem;
}

.review-card__rating {
  color: rgba(76, 61, 45, .62);
  font-size: .72rem;
}

.review-card blockquote {
  display: -webkit-box;
  margin: .55rem 0 .7rem;
  overflow: hidden;
  color: var(--charcoal);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(.92rem, 1vw, 1.04rem);
  line-height: 1.34;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.review-card__meta {
  margin: 0;
  color: rgba(76, 61, 45, .68);
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.reviews-hint {
  margin: .1rem 0 0;
  color: rgba(76, 61, 45, .7);
  font-size: .82rem;
  text-align: center;
}

.site-footer {
  background: #3a3732;
  color: #f8f4ee;
  padding: clamp(3.5rem, 6vw, 5.5rem) 0 2rem;
}

.site-footer__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(160px, .55fr) minmax(160px, .55fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: start;
}

.site-footer__brand h2 {
  margin: 0;
  color: #fffdf9;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.85rem, 2.6vw, 2.7rem);
  font-weight: 400;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.site-footer__brand p {
  max-width: 420px;
  margin: 1.1rem 0 0;
  color: rgba(248, 244, 238, .74);
  line-height: 1.68;
}

.site-footer__nav h3 {
  margin: .2rem 0 1.1rem;
  color: #fffdf9;
  font-size: .86rem;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.site-footer__links {
  display: grid;
  gap: .72rem;
}

.site-footer a {
  width: fit-content;
  color: rgba(248, 244, 238, .72);
  transition: color .18s ease, border-color .18s ease;
}

.site-footer a:hover {
  color: #f7d99a;
  text-decoration: underline;
  text-underline-offset: .24em;
}

.site-footer__bottom {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.5rem;
  align-items: center;
  margin-top: clamp(2.5rem, 5vw, 4rem);
  padding-top: 1.35rem;
  border-top: 1px solid rgba(248, 244, 238, .14);
}

.site-footer__bottom p {
  margin: 0;
  color: rgba(248, 244, 238, .58);
  font-size: .82rem;
}

.site-footer__payments {
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-items: center;
  gap: .5rem;
  overflow-x: auto;
  scrollbar-width: none;
}

.site-footer__payments::-webkit-scrollbar {
  display: none;
}

.site-footer__payments svg {
  flex: 0 0 auto;
  width: 40px;
  height: 25px;
  border-radius: 3px;
  background: rgba(255, 253, 249, .92);
  box-shadow: 0 0 0 1px rgba(248, 244, 238, .16);
  opacity: .96;
}

.site-footer__payments span {
  display: inline-flex;
  min-height: 24px;
  align-items: center;
  padding: 0 .5rem;
  border: 1px solid rgba(248, 244, 238, .2);
  border-radius: 3px;
  color: rgba(248, 244, 238, .72);
  font-size: .68rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.product {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, .86fr);
  gap: clamp(2rem, 5vw, 4.5rem);
  padding: 50px 0 72px;
}

.product__media {
  display: grid;
  gap: 1rem;
}

.product__media-main {
  background: var(--ivory);
  border: 1px solid var(--line);
}

.product__media-main img { width: 100%; aspect-ratio: 1 / 1.12; object-fit: contain; background: var(--ivory); }

.product__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .75rem;
}

.product__thumbs img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border: 1px solid var(--line);
}

.price { font-size: 1.2rem; margin: 1rem 0; }
.form-field { margin: 1rem 0; }
.form-field label { display: block; margin-bottom: .4rem; font-size: .86rem; letter-spacing: .08em; text-transform: uppercase; }
.form-field input, .form-field textarea, .form-field select {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--charcoal);
  padding: .7rem .8rem;
  border-radius: 4px;
}

.form-field textarea { min-height: 110px; resize: vertical; }
.help-text { margin: .35rem 0 0; color: var(--ink-soft); font-size: .88rem; }
.note-box {
  margin: 1.25rem 0;
  padding: 1rem;
  background: var(--ivory);
  border: 1px solid var(--line);
  color: var(--ink-soft);
}

.quantity-row { display: flex; gap: .75rem; align-items: end; }
.quantity-row .form-field { flex: 0 0 110px; }

.page-hero {
  padding: 64px 0 56px;
  background: var(--ivory);
  border-bottom: 1px solid var(--line);
}

.page-hero--centered,
.page-hero--editorial {
  text-align: center;
}

.page-hero--editorial {
  padding: clamp(3.8rem, 7vw, 6.5rem) 0 clamp(3.2rem, 5vw, 5rem);
  background:
    radial-gradient(circle at 50% 0%, rgba(182, 152, 91, .12), transparent 34%),
    linear-gradient(180deg, #fffdf9 0%, #f7f2eb 100%);
}

.page-hero__inner {
  display: grid;
  justify-items: center;
}

.page-hero .heading {
  max-width: 860px;
  margin-inline: auto;
}

.page-hero--editorial .heading {
  max-width: 880px;
  font-size: clamp(2.25rem, 4vw, 4rem);
  line-height: 1.05;
}

.page-hero__rule {
  width: 72px;
  height: 1px;
  margin-top: 1.55rem;
  background: var(--gold);
}

.page-hero__intro {
  max-width: 660px;
  margin-top: 1rem;
  margin-inline: auto;
  color: var(--ink-soft);
  font-size: clamp(1rem, 1.2vw, 1.14rem);
}

.page-content {
  padding: 54px 0 82px;
  background:
    linear-gradient(180deg, rgba(247,242,235,.48), rgba(255,253,249,1) 34%),
    var(--porcelain);
}

.page-content--editorial {
  padding: clamp(3rem, 5vw, 5.5rem) 0 clamp(4rem, 7vw, 6.5rem);
}

.page-article {
  display: grid;
  grid-template-columns: minmax(220px, 310px) minmax(0, 720px);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}

.page-article--centered {
  display: block;
  max-width: 860px;
}

.page-article--elegant {
  padding: clamp(2rem, 4vw, 3.5rem);
  border: 1px solid var(--line);
  background: rgba(255, 253, 249, .82);
  box-shadow: 0 18px 46px rgba(42, 34, 25, 0.055);
}

.page-article--editorial {
  display: block;
  max-width: 900px;
  padding: clamp(2.1rem, 4.6vw, 4.25rem);
  border: 1px solid var(--line);
  background: rgba(255, 253, 249, .92);
  box-shadow: 0 22px 54px rgba(42, 34, 25, .06);
}

.page-article__aside {
  position: sticky;
  top: 112px;
  padding: 1.25rem;
  border: 1px solid var(--line);
  background: var(--porcelain);
}

.page-article__aside h2 {
  margin: 0 0 .75rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.35rem;
  font-weight: 400;
  line-height: 1.18;
}

.page-article__aside p {
  margin: 0 0 1rem;
  color: var(--ink-soft);
  font-size: .94rem;
}

.page-article__aside a {
  color: var(--charcoal);
  border-bottom: 1px solid var(--gold);
  word-break: break-word;
}

.page-article__note {
  max-width: 720px;
  margin: 3rem auto 0;
  padding: 1.25rem 1.4rem;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  text-align: center;
}

.page-article__note--editorial {
  max-width: 680px;
  margin-top: 3.2rem;
}

.page-article__note h2 {
  margin: 0 0 .65rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.35rem;
  font-weight: 400;
  line-height: 1.18;
}

.page-article__note p {
  max-width: 560px;
  margin: 0 auto .8rem;
  color: var(--ink-soft);
}

.page-article__note a {
  color: var(--charcoal);
  border-bottom: 1px solid var(--gold);
}

.page-article__body {
  max-width: 720px;
  margin-inline: auto;
  color: var(--ink-soft);
  font-size: clamp(1rem, 1.15vw, 1.08rem);
  line-height: 1.78;
}

.page-article--editorial .page-article__body {
  max-width: 680px;
  text-align: left;
  font-size: clamp(1.02rem, 1.12vw, 1.09rem);
}

.page-article__body > * {
  max-width: 100%;
}

.page-article__body > p:first-child {
  color: var(--charcoal);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.18rem, 1.7vw, 1.55rem);
  line-height: 1.42;
  margin-bottom: 2rem;
}

.page-article--editorial .page-article__body > p:first-child {
  text-align: center;
  margin-bottom: 2.4rem;
}

.page-article__body h2,
.page-article__body h3 {
  margin: 2.35rem 0 .85rem;
  color: var(--charcoal);
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 400;
  line-height: 1.18;
}

.page-article__body h2 { font-size: clamp(1.55rem, 2vw, 2rem); }
.page-article__body h3 { font-size: clamp(1.25rem, 1.6vw, 1.5rem); }

.page-article__body p {
  margin: 0 0 1.18rem;
}

.page-article__body ol,
.page-article__body ul {
  display: grid;
  gap: .9rem;
  margin: 1.25rem 0 1.65rem;
  padding-left: 1.35rem;
}

.page-article__body ol {
  list-style-position: outside;
}

.page-article__body li {
  padding-left: .45rem;
}

.page-article__body strong {
  color: var(--charcoal);
  font-weight: 600;
}

.manifesto-page {
  min-height: 100vh;
  width: 100%;
  overflow: hidden;
  padding: clamp(1.2rem, 2vw, 2.2rem) 0;
  background:
    radial-gradient(circle at 12% 12%, rgba(204, 158, 88, .18), transparent 36%),
    linear-gradient(180deg, #fff6e9 0%, #f3dfc2 100%);
}

.manifesto-page__sheet {
  position: relative;
  width: min(100%, 1120px);
  max-width: 100%;
  overflow: hidden;
  padding: clamp(2.2rem, 5vw, 5rem) clamp(1.25rem, 5vw, 5rem) clamp(2rem, 4vw, 4.2rem);
  border: 1px solid rgba(169, 136, 74, .18);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .28) 0 1px, transparent 1px 52px),
    linear-gradient(180deg, rgba(145, 103, 55, .045) 0 1px, transparent 1px 58px),
    radial-gradient(circle at 80% 12%, rgba(221, 184, 126, .3), transparent 25%),
    #fff3df;
  box-shadow: 0 24px 70px rgba(82, 58, 35, .15);
}

.manifesto-page__sheet::before,
.manifesto-page__sheet::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.manifesto-page__sheet::before {
  inset: 18px;
  border: 1px solid rgba(153, 113, 62, .12);
}

.manifesto-page__sheet::after {
  right: 4.5rem;
  top: 21rem;
  width: 170px;
  height: 190px;
  border: 1px solid rgba(179, 128, 65, .12);
  border-radius: 50%;
  transform: rotate(-18deg);
}

.manifesto-page__ornament {
  margin-bottom: .25rem;
  color: rgba(169, 136, 74, .82);
  text-align: center;
  font-size: 1.65rem;
}

.manifesto-page__header {
  position: relative;
  z-index: 1;
  max-width: 760px;
  margin: 0 auto clamp(2rem, 4vw, 3.5rem);
  text-align: center;
}

.manifesto-page__brand {
  margin: 0 0 .25rem;
  color: #654a31;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.1rem, 1.8vw, 1.45rem);
  letter-spacing: .18em;
}

.manifesto-page__title {
  display: grid;
  gap: .05rem;
  margin: .8rem 0 0;
  color: #57412d;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2.55rem, 5.2vw, 5rem);
  font-weight: 400;
  line-height: .92;
}

.manifesto-page__script,
.manifesto-page blockquote,
.manifesto-label,
.manifesto-ending-note,
.manifesto-paper p,
.manifesto-polaroid figcaption {
  font-family: "Segoe Script", "Lucida Handwriting", cursive;
  font-weight: 400;
}

.manifesto-page__script {
  color: #6f5234;
  font-size: clamp(2.75rem, 6.2vw, 5.8rem);
  line-height: .95;
}

.manifesto-page__script em {
  font-style: inherit;
}

.manifesto-page__top-note {
  position: absolute;
  right: clamp(1.5rem, 5vw, 4rem);
  top: clamp(2rem, 4vw, 3.5rem);
  width: min(280px, 24vw);
  transform: rotate(5deg);
}

.manifesto-paper,
.manifesto-polaroid,
.manifesto-photo,
.manifesto-note,
.manifesto-ending-note {
  background:
    linear-gradient(180deg, rgba(255,255,255,.44), rgba(255,246,229,.74)),
    #f5dfbc;
  box-shadow: 0 16px 34px rgba(88, 61, 33, .16);
}

.manifesto-paper--small {
  padding: .9rem .9rem 1.1rem;
}

.manifesto-paper--small img {
  aspect-ratio: 1 / 1;
  width: 100%;
  object-fit: cover;
  filter: sepia(.14) saturate(.9);
}

.manifesto-paper p {
  margin: .6rem 0 0;
  color: #705438;
  font-size: clamp(1rem, 1.5vw, 1.35rem);
  line-height: 1.25;
}

.manifesto-page__intro {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(240px, .72fr) minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.manifesto-polaroid {
  width: min(360px, 100%);
  margin: 0 auto;
  padding: .9rem .9rem 1.35rem;
  transform: rotate(-7deg);
}

.manifesto-polaroid__image {
  aspect-ratio: 1 / 1;
  background: rgba(114, 82, 48, .12);
  overflow: hidden;
}

.manifesto-polaroid__image img,
.manifesto-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: sepia(.18) saturate(.86) contrast(.96);
}

.manifesto-polaroid figcaption {
  margin-top: .65rem;
  color: #725437;
  text-align: center;
  font-size: clamp(1.15rem, 2.2vw, 1.75rem);
}

.manifesto-page__copy {
  max-width: 520px;
  color: #4e3d2d;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1rem, 1.25vw, 1.13rem);
  line-height: 1.78;
}

.manifesto-page__lead {
  color: #453424;
  font-size: clamp(1.08rem, 1.45vw, 1.28rem);
  line-height: 1.65;
}

.manifesto-page__rule {
  width: 100%;
  height: 1px;
  margin: 1.2rem 0;
  background: linear-gradient(90deg, rgba(169,136,74,.38), transparent);
}

.manifesto-page blockquote {
  position: relative;
  margin: clamp(1.5rem, 3vw, 2.5rem) 0;
  color: #6b4e30;
  font-size: clamp(1.25rem, 2.1vw, 1.85rem);
  line-height: 1.35;
}

.manifesto-page blockquote::before,
.manifesto-page blockquote::after {
  color: rgba(191, 139, 58, .75);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 2.4rem;
  line-height: 0;
}

.manifesto-page blockquote::before { content: open-quote; margin-right: .25rem; }
.manifesto-page blockquote::after { content: close-quote; margin-left: .25rem; }

.manifesto-page__middle {
  display: grid;
  grid-template-columns: minmax(250px, .72fr) minmax(0, 1.2fr);
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
  margin-top: clamp(2rem, 4.8vw, 4.8rem);
}

.manifesto-note {
  padding: clamp(1.4rem, 2.6vw, 2.1rem);
  border: 1px solid rgba(169, 136, 74, .12);
  color: #594536;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.75;
}

.manifesto-photo {
  padding: .55rem;
}

.manifesto-photo--wide {
  aspect-ratio: 16 / 9;
  transform: rotate(.8deg);
}

.manifesto-page__lower {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(260px, .8fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  margin-top: clamp(2.2rem, 5vw, 5rem);
}

.manifesto-page__statement h2 {
  margin: 0 0 1.4rem;
  color: #57412d;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2rem, 3.6vw, 3.35rem);
  font-weight: 400;
  line-height: 1.05;
  white-space: pre-line;
}

.manifesto-page__statement p,
.manifesto-page__ending p {
  color: #4e3d2d;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1rem, 1.16vw, 1.08rem);
  line-height: 1.75;
}

.manifesto-page__keepsake {
  position: relative;
}

.manifesto-photo--stack {
  aspect-ratio: 4 / 3;
  transform: rotate(2deg);
}

.manifesto-label {
  position: relative;
  width: fit-content;
  max-width: 80%;
  margin: -1.1rem auto 0;
  padding: .8rem 1.2rem;
  color: #755537;
  background: #f7e2bd;
  box-shadow: 0 10px 20px rgba(88, 61, 33, .13);
  transform: rotate(-3deg);
}

.manifesto-page__ending {
  position: relative;
  display: grid;
  grid-template-columns: minmax(80px, 130px) minmax(0, 1fr) minmax(260px, .72fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
  margin-top: clamp(2.2rem, 5vw, 4.8rem);
}

.manifesto-wax {
  display: grid;
  width: 86px;
  height: 86px;
  place-items: center;
  border-radius: 50%;
  color: #f8e6bf;
  background:
    radial-gradient(circle at 35% 28%, #c99a43, #8b5c23 78%);
  box-shadow: inset 0 0 0 5px rgba(255, 232, 174, .22), 0 16px 28px rgba(79, 50, 19, .18);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.25rem;
  letter-spacing: .08em;
}

.manifesto-ending-note {
  padding: clamp(1.25rem, 2.4vw, 2rem);
  color: #6b4e30;
  font-size: clamp(1.25rem, 2vw, 1.8rem);
  line-height: 1.55;
  transform: rotate(-2deg);
}

.faq-item {
  border-bottom: 1px solid var(--line);
  padding: 1.1rem 0;
}

.faq-item summary {
  cursor: pointer;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.2rem;
}

.payment-trust {
  padding: 34px 0;
  border-top: 1px solid var(--line);
  background: var(--porcelain);
}

.payment-trust__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.5rem;
  align-items: center;
}

.payment-trust__text h2 {
  margin: 0 0 .3rem;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.35rem;
  font-weight: 400;
}

.payment-trust__text p {
  margin: 0;
  color: var(--ink-soft);
  font-size: .92rem;
}

.payment-trust__icons {
  display: flex;
  flex-wrap: nowrap;
  gap: .6rem;
  justify-content: flex-end;
  align-items: center;
  overflow-x: auto;
  scrollbar-width: none;
}

.payment-trust__icons::-webkit-scrollbar {
  display: none;
}

.payment-trust__icons svg {
  flex: 0 0 auto;
  width: 44px;
  height: 28px;
  border-radius: 3px;
  box-shadow: 0 0 0 1px var(--line);
  background: #fff;
}

.payment-trust__fallback {
  display: inline-flex;
  min-width: 52px;
  min-height: 28px;
  align-items: center;
  justify-content: center;
  padding: 0 .55rem;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--charcoal);
  border-radius: 3px;
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.email-capture {
  padding: clamp(2.5rem, 4vw, 4rem) 0;
  background:
    linear-gradient(180deg, #fffdf9 0%, #f7f2eb 100%);
}

.email-capture__panel {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(360px, .78fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
  padding: clamp(1.75rem, 3vw, 3rem);
  border: 1px solid rgba(169, 136, 74, .24);
  background: rgba(255, 253, 249, .92);
  box-shadow: 0 14px 34px rgba(42, 34, 25, .045);
}

.email-capture__copy .heading {
  font-size: clamp(1.85rem, 3vw, 3rem);
}

.email-capture__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .75rem;
}

.email-capture__row input {
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(169, 136, 74, .34);
  background: #fff;
  color: var(--charcoal);
  padding: .8rem 1rem;
  border-radius: 2px;
}

.email-capture__privacy,
.email-capture__message {
  margin: .7rem 0 0;
  color: var(--ink-soft);
  font-size: .78rem;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (max-width: 1200px) {
  .site-header__inner {
    grid-template-columns: 42px minmax(0, 1fr) 42px;
    min-height: 68px;
    padding: 0;
  }
  .site-header__nav {
    display: none;
  }
  .site-header__brand {
    grid-column: 2;
    text-align: center;
    font-size: 1.45rem;
  }
  .site-header__brand img {
    max-width: 150px;
    max-height: 36px;
    margin-inline: auto;
  }
  .site-header__mobile-menu {
    display: block;
    grid-column: 1;
    grid-row: 1;
  }
  .hero-memory__grid, .split, .product { grid-template-columns: 1fr; }
  .hero-memory {
    min-height: 620px;
    background-position: center center;
    background-size: cover;
  }
  .hero-memory__content {
    padding-bottom: 4rem;
  }
  .media-frame { min-height: 380px; }
  .media-frame--hero { aspect-ratio: 5 / 4; max-height: none; }
  .grid-4, .steps, .site-footer__grid, .trust-bar__grid { grid-template-columns: 1fr 1fr; }
  .site-footer__brand { grid-column: 1 / -1; }
  .review-card { flex-basis: min(300px, 48vw); }
  .payment-trust__inner { grid-template-columns: 1fr; text-align: center; }
  .payment-trust__icons { justify-content: center; }
  .page-article { grid-template-columns: 1fr; }
  .page-article__aside { position: static; }
  .manifesto-page__top-note {
    position: relative;
    right: auto;
    top: auto;
    width: min(260px, 76vw);
    margin: -1.2rem auto 2.2rem;
  }
  .manifesto-page__intro,
  .manifesto-page__middle,
  .manifesto-page__lower,
  .manifesto-page__ending {
    grid-template-columns: 1fr;
  }
  .manifesto-page__copy,
  .manifesto-page__statement {
    max-width: 680px;
    margin-inline: auto;
  }
  .manifesto-page__ending {
    text-align: center;
  }
  .manifesto-wax {
    margin-inline: auto;
  }
  .memory-process__steps { grid-template-columns: 1fr 1fr; }
  .memory-process__steps::before { display: none; }
  .email-capture__panel { grid-template-columns: 1fr; }
  .step:nth-child(2n) { border-right: 1px solid var(--line); }
  .step::after { display: none; }
}

@media (max-width: 600px) {
  .section { padding: 48px 0; }
  .page-hero { padding: 42px 0 36px; }
  .page-content { padding: 38px 0 58px; }
  .page-article__note { text-align: left; }
  .page-article__note p { margin-inline: 0; }
  .manifesto-page {
    padding: 0;
  }
  .manifesto-page__sheet {
    width: 100%;
    padding: 2.2rem 1.1rem 2.6rem;
    border-inline: 0;
  }
  .manifesto-page__sheet::before,
  .manifesto-page__sheet::after {
    display: none;
  }
  .manifesto-page__header {
    margin-bottom: 1.6rem;
  }
  .manifesto-page__title {
    font-size: clamp(2.3rem, 11vw, 3.45rem);
  }
  .manifesto-page__script {
    font-size: clamp(2.45rem, 12vw, 3.9rem);
  }
  .manifesto-polaroid {
    width: min(280px, 86vw);
    transform: rotate(-4deg);
  }
  .manifesto-page__middle,
  .manifesto-page__lower,
  .manifesto-page__ending {
    margin-top: 2.3rem;
  }
  .manifesto-photo--wide,
  .manifesto-photo--stack {
    aspect-ratio: 4 / 3;
  }
  .manifesto-page__statement h2 {
    font-size: clamp(1.9rem, 9vw, 2.8rem);
  }
  .manifesto-ending-note {
    max-width: 92vw;
    margin-inline: auto;
    font-size: clamp(1.15rem, 6vw, 1.55rem);
  }
  .grid-4, .steps, .site-footer__grid { grid-template-columns: 1fr; }
  .site-footer__bottom { grid-template-columns: 1fr; }
  .site-footer__payments { justify-content: flex-start; gap: .38rem; }
  .site-footer__payments svg { width: 34px; height: 22px; }
  .payment-trust__icons { gap: .38rem; }
  .payment-trust__icons svg { width: 36px; height: 23px; }
  .reviews-film-section { padding: 2.5rem 0; }
  .reviews-track {
    gap: .85rem;
    padding-top: 2rem;
    padding-bottom: 2.35rem;
  }
  .reviews-track::before,
  .reviews-track::after {
    height: 14px;
    background-size: 24px 14px;
    background-image: repeating-linear-gradient(90deg, rgba(62, 49, 36, .76) 0 13px, transparent 13px 24px);
  }
  .review-card {
    flex-basis: 74vw;
    padding: .62rem .62rem .95rem;
  }
  .step { border-right: 1px solid var(--line); border-bottom: 0; min-height: 220px; }
  .step:last-child { border-bottom: 1px solid var(--line); }
  .hero-memory { min-height: 580px; }
  .hero-memory__content { padding: 3.5rem 0 3rem; }
  .hero-memory__copy { margin-left: 0; }
  .hero-memory__copy .heading { font-size: clamp(2.25rem, 11vw, 3.35rem); }
  .hero-memory .rte { max-width: 92%; }
  .hero-memory__feature-row { display: none; }
  .hero-memory__grid { padding-top: 32px; }
  .media-frame--hero, .media-frame--feature { aspect-ratio: 4 / 5; }
  .hero-memory__actions .button { width: 100%; }
  .product__thumbs { grid-template-columns: repeat(2, 1fr); }
  .trust-bar__grid { grid-template-columns: 1fr; }
  .trust-bar__item, .trust-bar__item:last-child { border-inline: 0; border-top: 1px solid var(--line); }
  .memory-process__steps { grid-template-columns: 1fr; }
  .memory-process__step { min-height: auto; padding: 1.75rem 1.15rem; }
  .memory-process__icon { width: 92px; height: 92px; }
  .memory-process__icon svg { width: 42px; height: 42px; }
  .email-capture__panel { padding: 1.35rem; }
  .email-capture__row { grid-template-columns: 1fr; }
  .email-capture__row .button { width: 100%; }
}

.tcg-manifesto-collage,
.tcg-manifesto-collage * {
  box-sizing: border-box;
}

.tcg-manifesto-collage {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.tcg-page {
  width: min(100%, 1180px);
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}

.tcg-main-title {
  max-width: 100%;
  word-break: normal;
}

.tcg-main-title em {
  display: inline-block;
  max-width: 100%;
  font-size: clamp(42px, 6vw, 55px);
  line-height: 1.05;
}

@media (max-width: 1200px) {
  .tcg-page {
    min-height: auto;
    padding: 48px 24px;
  }

  .tcg-top-jewel,
  .tcg-cat-card,
  .tcg-intro-text,
  .quote-one,
  .tcg-note-left,
  .tcg-middle-photo,
  .tcg-section-title,
  .tcg-body-text,
  .tcg-product-photo,
  .quote-two,
  .tcg-designer-text,
  .tcg-small-note,
  .tcg-ending-card,
  .tcg-stamp,
  .tcg-wax {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    max-width: 720px;
    margin: 32px auto;
    transform: none;
  }

  .tcg-main-title {
    font-size: clamp(42px, 8vw, 68px);
    line-height: 1;
  }

  .tcg-cat-card {
    max-width: 340px;
  }

  .tcg-cat-img {
    height: 280px;
  }

  .tcg-top-jewel,
  .tcg-middle-photo,
  .tcg-product-photo {
    height: 260px;
  }

  .tcg-section-title {
    text-align: center;
  }
}

@media (min-width: 1201px) {
  .tcg-manifesto-collage {
    padding: 0;
    background:
      radial-gradient(circle at 14% 8%, rgba(225, 181, 112, .22), transparent 28%),
      linear-gradient(180deg, #fff3dd 0%, #f2d7ad 100%);
  }

  .tcg-page {
    position: relative;
    width: min(100%, 1180px);
    min-height: 1660px;
    padding: 56px 62px 64px;
    overflow: hidden;
    border: 0;
    background:
      radial-gradient(circle at 18% 10%, rgba(255, 255, 255, .55), transparent 18%),
      radial-gradient(circle at 78% 12%, rgba(214, 164, 91, .24), transparent 22%),
      linear-gradient(90deg, rgba(127, 86, 38, .035) 0 1px, transparent 1px 54px),
      linear-gradient(180deg, rgba(127, 86, 38, .035) 0 1px, transparent 1px 58px),
      #fff1d9;
    box-shadow: 0 30px 80px rgba(80, 55, 28, .18);
  }

  .tcg-page::before {
    content: "";
    position: absolute;
    inset: 34px 44px;
    border: 1px solid rgba(156, 111, 55, .11);
    pointer-events: none;
  }

  .tcg-page::after {
    content: "MEMORIES\A THAT STAY";
    position: absolute;
    right: 54px;
    top: 720px;
    width: 104px;
    height: 104px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(108, 80, 48, .36);
    border-radius: 50%;
    color: rgba(92, 68, 41, .62);
    font-size: 10px;
    letter-spacing: .16em;
    line-height: 1.35;
    text-align: center;
    white-space: pre;
    transform: rotate(-12deg);
    pointer-events: none;
  }

  .manifesto-page__header {
    position: absolute;
    z-index: 3;
    top: 56px;
    left: 50%;
    width: 650px;
    max-width: 650px;
    margin: 0;
    transform: translateX(-50%);
  }

  .manifesto-page__ornament {
    position: absolute;
    top: 32px;
    left: 50%;
    z-index: 3;
    margin: 0;
    transform: translateX(-50%);
    font-size: 22px;
  }

  .manifesto-page__brand {
    font-size: 20px;
    letter-spacing: .18em;
  }

  .manifesto-page__header .eyebrow {
    margin-bottom: .7rem;
    color: #76542f;
    font-size: 12px;
    letter-spacing: .24em;
  }

  .tcg-main-title {
    display: block;
    color: #5b4129;
    font-size: 54px;
    line-height: .92;
  }

  .tcg-main-title span {
    display: block;
  }

  .tcg-main-title em {
    font-size: 70px;
    line-height: .92;
  }

  .manifesto-page__intro,
  .manifesto-page__middle,
  .manifesto-page__lower,
  .manifesto-page__ending {
    display: contents;
  }

  .tcg-top-jewel {
    position: absolute;
    z-index: 2;
    right: 64px;
    top: 18px;
    width: 270px;
    margin: 0;
    transform: rotate(5deg);
  }

  .manifesto-paper--small {
    padding: 16px 16px 24px;
    background: rgba(247, 222, 184, .8);
  }

  .tcg-cat-card {
    position: absolute;
    z-index: 3;
    left: 86px;
    top: 330px;
    width: 300px;
    margin: 0;
    padding: 14px 14px 24px;
    transform: rotate(-7deg);
  }

  .tcg-cat-img,
  .manifesto-polaroid__image {
    height: 250px;
  }

  .tcg-intro-text {
    position: absolute;
    z-index: 2;
    left: 510px;
    top: 342px;
    width: 520px;
    max-width: 520px;
    margin: 0;
    font-size: 17px;
    line-height: 1.72;
  }

  .tcg-intro-text p {
    margin: 0 0 1rem;
  }

  .quote-one {
    width: 470px;
    margin: 28px 0 0 32px;
    color: #6e5235;
    font-size: 28px;
    line-height: 1.35;
  }

  .tcg-note-left {
    position: absolute;
    z-index: 2;
    left: 96px;
    top: 750px;
    width: 300px;
    margin: 0;
    padding: 34px 28px;
    background: rgba(255, 241, 216, .42);
    box-shadow: none;
  }

  .tcg-middle-photo {
    position: absolute;
    z-index: 2;
    left: 585px;
    top: 710px;
    width: 460px;
    height: 230px;
    margin: 0;
    padding: 0;
    transform: rotate(.5deg);
  }

  .tcg-section-title {
    margin: 0 0 26px;
    font-size: 43px;
    line-height: 1.05;
    text-align: left;
  }

  .tcg-body-text {
    position: absolute;
    z-index: 2;
    left: 96px;
    top: 1015px;
    width: 440px;
    margin: 0;
  }

  .tcg-body-text p {
    margin: 0 0 1rem;
    font-size: 16px;
    line-height: 1.74;
  }

  .quote-two {
    position: absolute;
    left: -20px;
    top: 345px;
    width: 520px;
    margin: 0;
    font-size: 35px;
    line-height: 1.3;
  }

  .tcg-small-note {
    position: absolute;
    z-index: 2;
    right: 120px;
    top: 1040px;
    width: 340px;
    margin: 0;
  }

  .tcg-product-photo {
    width: 340px;
    height: 250px;
    margin: 0;
    padding: 0;
    transform: rotate(2deg);
  }

  .manifesto-label {
    margin-top: -16px;
    font-size: 18px;
  }

  .tcg-stamp,
  .tcg-wax {
    position: absolute;
    z-index: 2;
    left: 92px;
    bottom: 52px;
    margin: 0;
  }

  .tcg-designer-text {
    position: absolute;
    z-index: 2;
    left: 405px;
    bottom: 58px;
    width: 360px;
    margin: 0;
    font-size: 15px;
    line-height: 1.7;
  }

  .tcg-ending-card {
    position: absolute;
    z-index: 2;
    right: 62px;
    bottom: 44px;
    width: 360px;
    margin: 0;
    padding: 28px 34px;
    font-size: 25px;
    line-height: 1.55;
    transform: rotate(-2deg);
  }
}

/* Stable Brand Manifesto layout: keeps the scrapbook feel without overlaps. */
@media (min-width: 1201px) {
  .tcg-page {
    display: grid;
    grid-template-columns: minmax(0, .86fr) minmax(0, 1fr);
    gap: 44px 70px;
    min-height: 0;
    padding: 56px 76px 72px;
    overflow: hidden;
  }

  .manifesto-page__ornament,
  .manifesto-page__header,
  .manifesto-page__top-note,
  .manifesto-page__intro,
  .manifesto-page__middle,
  .manifesto-page__lower,
  .manifesto-page__ending {
    position: relative;
    inset: auto;
    z-index: 2;
    width: auto;
    max-width: none;
    margin: 0;
    transform: none;
  }

  .manifesto-page__ornament,
  .manifesto-page__header {
    grid-column: 1 / -1;
    text-align: center;
  }

  .manifesto-page__ornament {
    margin-bottom: -28px;
  }

  .manifesto-page__header {
    display: block;
    max-width: 820px;
    margin-inline: auto;
  }

  .tcg-main-title {
    font-size: clamp(54px, 5.2vw, 78px);
    line-height: 1.02;
  }

  .tcg-main-title em {
    font-size: inherit;
    line-height: inherit;
  }

  .manifesto-page__top-note {
    grid-column: 2;
    grid-row: 2;
    justify-self: end;
    width: min(330px, 100%);
    transform: rotate(4deg);
  }

  .manifesto-page__intro {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(260px, .78fr) minmax(0, 1fr);
    gap: 58px;
    align-items: start;
  }

  .tcg-cat-card,
  .tcg-intro-text,
  .quote-one,
  .tcg-note-left,
  .tcg-middle-photo,
  .tcg-section-title,
  .tcg-body-text,
  .tcg-product-photo,
  .quote-two,
  .tcg-designer-text,
  .tcg-small-note,
  .tcg-ending-card,
  .tcg-stamp,
  .tcg-wax {
    position: relative;
    inset: auto;
    width: auto;
    max-width: 100%;
    margin: 0;
  }

  .tcg-cat-card {
    width: min(360px, 100%);
    justify-self: center;
    transform: rotate(-4deg);
  }

  .tcg-cat-img,
  .manifesto-polaroid__image {
    height: 330px;
  }

  .tcg-intro-text {
    max-width: 620px;
    font-size: 18px;
    line-height: 1.72;
  }

  .quote-one {
    margin-top: 26px;
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1.25;
  }

  .manifesto-page__middle {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(260px, .72fr) minmax(0, 1fr);
    gap: 70px;
    align-items: center;
  }

  .tcg-note-left {
    padding: 38px 34px;
    background: rgba(255, 241, 216, .5);
  }

  .tcg-middle-photo {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    transform: rotate(.5deg);
  }

  .manifesto-page__lower {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, .78fr);
    gap: 72px;
    align-items: center;
  }

  .tcg-section-title {
    margin-bottom: 24px;
    font-size: clamp(42px, 4.4vw, 64px);
    line-height: 1.04;
    text-align: left;
  }

  .tcg-body-text p {
    font-size: 17px;
    line-height: 1.72;
  }

  .quote-two {
    margin-top: 28px;
    font-size: clamp(30px, 3.3vw, 48px);
    line-height: 1.25;
  }

  .tcg-small-note {
    justify-self: center;
    width: min(430px, 100%);
  }

  .tcg-product-photo {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    transform: rotate(2deg);
  }

  .manifesto-page__ending {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr) minmax(300px, .72fr);
    gap: 34px;
    align-items: center;
  }

  .tcg-designer-text {
    max-width: 420px;
    font-size: 16px;
    line-height: 1.72;
  }

  .tcg-ending-card {
    padding: 30px 36px;
    font-size: clamp(24px, 2.8vw, 36px);
    line-height: 1.45;
    transform: rotate(-2deg);
  }
}

.tcg-header {
  position: sticky;
  top: 0;
  z-index: 50;
  width: 100%;
  overflow-x: clip;
  background: #ffffff;
  border-bottom: 1px solid #f2f2f2;
  backdrop-filter: none;
}

.tcg-header-topbar {
  width: 100%;
  text-align: center;
  font-size: 18px;
  line-height: 1.7;
  letter-spacing: .03em;
}

.tcg-header-topbar--pink {
  background: #e8b8b8;
  color: #5f5f5f;
}

.tcg-header-topbar--teal {
  background: #8fc0c2;
  color: #ffffff;
}

.tcg-header-main {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr) 330px;
  align-items: center;
  gap: 34px;
  padding: 34px 64px 26px;
  background: #ffffff;
}

.tcg-header-logo {
  text-decoration: none;
  color: #1f1f1f;
  text-align: center;
  display: block;
}

.tcg-header-logo .tcg-logo-small {
  display: block;
  font-family: Arial, sans-serif;
  font-size: 18px;
  letter-spacing: .28em;
  margin-bottom: 4px;
  text-transform: uppercase;
}

.tcg-header-logo .tcg-logo-main {
  display: block;
  font-family: Georgia, 'Times New Roman', serif;
  font-size: 44px;
  letter-spacing: .16em;
  line-height: 1;
  text-transform: uppercase;
}

.tcg-header-search {
  display: flex;
  width: 100%;
  height: 60px;
}

.tcg-header-search input {
  flex: 1;
  min-width: 0;
  height: 60px;
  border: 1px solid #e2e2e2;
  border-right: none;
  padding: 0 26px;
  font-size: 18px;
  font-style: italic;
  color: #555;
}

.tcg-header-search button {
  display: grid;
  width: 76px;
  height: 60px;
  place-items: center;
  border: none;
  background: #2e2e2e;
  color: #ffffff;
  cursor: pointer;
}

.tcg-header-search svg {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.6;
}

.tcg-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 34px;
  font-family: Arial, sans-serif;
  font-size: 18px;
}

.tcg-header-actions a {
  color: #111;
  text-decoration: none;
  white-space: nowrap;
}

.tcg-header-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 100%;
  gap: clamp(14px, 1.8vw, 34px);
  padding: 22px clamp(20px, 4vw, 64px) 24px;
  border-top: 1px solid #f2f2f2;
  background: #ffffff;
  overflow-x: hidden;
}

.tcg-header-nav a {
  color: #4a4a4a;
  text-decoration: none;
  font-family: Arial, sans-serif;
  font-size: clamp(12px, .9vw, 16px);
  letter-spacing: clamp(.1em, .18vw, .2em);
  text-transform: uppercase;
  white-space: nowrap;
  line-height: 1.35;
}

.tcg-header-nav a.is-active,
.tcg-header-nav a:hover {
  color: #1f1f1f;
  font-weight: 700;
}

.tcg-header-cart-total {
  margin-left: 0;
  font-family: Georgia, 'Times New Roman', serif !important;
  font-size: clamp(15px, 1.1vw, 19px) !important;
  letter-spacing: .08em !important;
  color: #111 !important;
}

@media (max-width: 1200px) and (min-width: 991px) {
  .tcg-header-nav {
    gap: 16px;
    padding: 18px 20px 20px;
  }

  .tcg-header-nav a {
    font-size: 12px;
    letter-spacing: .1em;
  }
}

.tcg-header .site-header__mobile-menu {
  display: none;
}

@media (max-width: 990px) {
  .tcg-header-topbar {
    font-size: 14px;
    line-height: 1.55;
    padding: 2px 12px;
  }

  .tcg-header-main {
    grid-template-columns: 42px minmax(0, 1fr);
    padding: 24px 18px;
    gap: 18px;
  }

  .tcg-header .site-header__mobile-menu {
    display: block;
    grid-column: 1;
    grid-row: 1;
  }

  .tcg-header-logo {
    grid-column: 2;
    text-align: center;
  }

  .tcg-header-logo .tcg-logo-main {
    font-size: 34px;
  }

  .tcg-header-search {
    grid-column: 1 / -1;
    height: 52px;
  }

  .tcg-header-search input {
    height: 52px;
    padding: 0 16px;
    font-size: 15px;
  }

  .tcg-header-search button {
    width: 58px;
    height: 52px;
  }

  .tcg-header-actions {
    grid-column: 1 / -1;
    justify-content: center;
    font-size: 15px;
    gap: 18px;
  }

  .tcg-header-nav {
    display: none;
  }

  .tcg-header-cart-total {
    font-size: 17px !important;
  }

  .tcg-header .site-header__mobile-panel {
    top: auto;
    left: 0;
    right: 0;
    margin-top: 12px;
  }
}

/* Compact homepage sections */
.grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(.9rem, 1.8vw, 1.3rem);
}

.series-card {
  max-height: 400px;
  overflow: hidden;
}

.series-card__media {
  aspect-ratio: 4 / 3;
  max-height: 200px;
}

.series-card__media img {
  max-height: 200px;
  object-fit: var(--series-media-fit, cover);
}

.series-card__body {
  padding: 1rem;
}

.series-card__title {
  font-size: 1.05rem;
}

.series-card__text {
  display: -webkit-box;
  overflow: hidden;
  font-size: .88rem;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.memory-process {
  padding: clamp(2.75rem, 5vw, 4.5rem) 0;
}

.memory-process__steps {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(.85rem, 1.5vw, 1.2rem);
}

.memory-process__step {
  min-height: 0;
  max-height: 250px;
  padding: 1.25rem 1rem;
  text-align: center;
}

.memory-process__icon {
  width: 60px;
  height: 60px;
  margin-bottom: .65rem;
}

.memory-process__icon svg {
  width: 30px;
  height: 30px;
}

.memory-process__step h3 {
  font-size: clamp(1.1rem, 1.4vw, 1.35rem);
}

.memory-process__step > p:last-child {
  font-size: .74rem;
}

.split {
  max-width: 900px;
  margin-inline: auto;
  padding-block: 40px;
}

.media-frame--feature {
  max-height: 250px;
  min-height: 0;
}

.media-frame--feature img {
  max-height: 250px;
  object-fit: contain;
}

.reviews-film-section {
  padding: clamp(2.25rem, 4vw, 3.75rem) 0;
}

.reviews-track {
  padding-top: 1.9rem;
  padding-bottom: 2.15rem;
}

.review-card {
  flex-basis: clamp(230px, 30vw, 320px);
  max-height: 220px;
}

.review-card__image {
  aspect-ratio: 5 / 3;
}

.review-card blockquote {
  -webkit-line-clamp: 2;
}

.site-footer {
  padding: 40px 20px;
}

.site-footer__payments svg,
.payment-trust__icons svg {
  width: 50px;
  height: auto;
  margin-right: 10px;
}

.materials-care {
  background: #f8f1e7;
  padding: clamp(3rem, 5vw, 4.75rem) 0;
}

.materials-care__inner {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
}

.materials-care__media.media-frame--feature {
  width: 100%;
  max-height: 560px;
  min-height: 430px;
  aspect-ratio: 4 / 5;
  border: 0;
  border-radius: 18px;
  box-shadow: 0 24px 60px rgba(54, 44, 34, .16);
}

.materials-care__media.media-frame--feature img {
  max-height: none;
  object-fit: cover;
}

.materials-care__content {
  max-width: 540px;
}

.materials-care__content .heading {
  max-width: 10.5em;
  margin-bottom: 1rem;
  color: #242220;
}

.materials-care__content .rte {
  max-width: 33rem;
  color: #5f5952;
  font-size: clamp(1rem, 1.15vw, 1.1rem);
  line-height: 1.72;
}

.materials-care__trust-list {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin: 1.6rem 0 0;
  padding: 0;
  list-style: none;
}

.materials-care__trust-list li {
  border: 1px solid rgba(182, 152, 91, .38);
  border-radius: 999px;
  padding: .72rem 1rem;
  background: rgba(255, 253, 249, .68);
  color: #4b4339;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}

@media (max-width: 900px) {
  .grid-4,
  .memory-process__steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .split {
    max-width: min(900px, calc(100vw - 32px));
    padding-block: 32px;
  }

  .materials-care__inner {
    grid-template-columns: 1fr;
  }

  .materials-care__media.media-frame--feature {
    min-height: 0;
    max-height: 520px;
    aspect-ratio: 4 / 3;
  }

  .materials-care__content {
    max-width: 640px;
  }
}

@media (max-width: 600px) {
  .grid-4,
  .memory-process__steps {
    grid-template-columns: 1fr;
  }

  .series-card,
  .memory-process__step,
  .review-card {
    max-height: none;
  }

  .materials-care {
    padding: 2.5rem 0;
  }

  .materials-care__inner {
    gap: 1.75rem;
  }

  .materials-care__media.media-frame--feature {
    aspect-ratio: 1 / 1;
    border-radius: 14px;
  }

  .materials-care__trust-list {
    display: grid;
    gap: .65rem;
  }

  .materials-care__trust-list li {
    text-align: center;
  }
}

/* Compact premium footer */
.site-footer {
  padding: 30px 20px;
}

.site-footer__grid {
  gap: clamp(1.25rem, 3vw, 2.5rem);
}

.site-footer__brand h2 {
  font-size: clamp(1.45rem, 2vw, 2rem);
  line-height: 1.08;
}

.site-footer__brand p {
  margin-top: .75rem;
  font-size: .88rem;
  line-height: 1.45;
}

.site-footer__nav h3 {
  margin: .1rem 0 .7rem;
  font-size: .78rem;
  line-height: 1.2;
}

.site-footer__links {
  gap: .42rem;
}

.site-footer__links a,
.site-footer__bottom p {
  font-size: .82rem;
  line-height: 1.35;
}

.site-footer__bottom {
  gap: 1rem;
  margin-top: 1.45rem;
  padding-top: .9rem;
}

.site-footer__payments {
  gap: .32rem;
}

.site-footer__payments svg {
  width: 40px;
  height: auto;
  margin-right: 0;
}

@media (max-width: 900px) {
  .site-footer {
    padding: 30px 18px;
  }

  .site-footer__grid {
    gap: 1.2rem;
  }
}

@media (max-width: 600px) {
  .site-footer__payments {
    gap: .28rem;
  }

  .site-footer__payments svg {
    width: 38px;
  }
}
