/* =========================================================
   LILY GRAY — Global Stylesheet
   Organized by: base · layout · chrome · home · collection ·
   product · gallery · about · cart · search · content · forms · utils
   ========================================================= */

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

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

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-15);
  line-height: var(--lh-base);
  color: var(--stone-gray);
  background: var(--pearl-cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, svg { max-width: 100%; display: block; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
a { color: var(--stone-gray); text-decoration: none; transition: color var(--dur-1) var(--ease); }
a:hover { color: var(--gold-deep); }

h1, h2, h3, h4 {
  font-family: var(--font-serif);
  font-weight: 400;
  color: var(--stone-gray);
  letter-spacing: var(--ls-normal);
  line-height: var(--lh-snug);
  margin: 0;
}
h1 { font-size: clamp(2.25rem, 5vw, var(--fs-64)); line-height: var(--lh-tight); }
h2 { font-size: clamp(1.75rem, 3.4vw, var(--fs-48)); }
h3 { font-size: clamp(1.25rem, 2vw, var(--fs-28)); }
p  { margin: 0; }

::selection { background: var(--gold-soft); color: var(--ink); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius: 2px; }

/* ---------- Layout ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.container--wide   { max-width: var(--container-wide); }
.container--narrow { max-width: var(--container-narrow); }

.section { padding-block: clamp(3rem, 6vw, var(--s-96)); }
.section--tight  { padding-block: clamp(2rem, 4vw, var(--s-64)); }
.section--pad-b0 { padding-bottom: 0; }

.section--cream      { background: var(--pearl-cream); }
.section--cream-soft { background: var(--pearl-cream-soft); }
.section--cream-deep { background: var(--pearl-cream-deep); }
.section--sage       { background: var(--muted-sage-deep); color: #F3F1E7; }
.section--sage h2,
.section--sage h3    { color: #F3F1E7; }
.section--sage p,
.section--sage li,
.section--sage .muted { color: rgba(243, 241, 231, 0.85); }
.section--sage .about-block__list li { color: rgba(243, 241, 231, 0.85); }
.section--sage .about-block__list li strong { color: #F3F1E7; }
.section--sage .about-block__list li::before { background: var(--gold-soft); }

.rule-gold {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-soft) 20%, var(--gold) 50%, var(--gold-soft) 80%, transparent);
  border: 0;
  margin: 0;
}

.eyebrow {
  font-family: var(--font-sans);
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--gold-deep);
  font-weight: 500;
}

.script-mark {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--gold-deep);
  font-size: var(--fs-14);
  letter-spacing: var(--ls-normal);
}

.muted { color: var(--stone-gray-soft); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-8);
  padding: 0.85rem 1.75rem;
  font-size: var(--fs-13);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  font-weight: 500;
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: transform var(--dur-1) var(--ease),
              background var(--dur-2) var(--ease),
              color var(--dur-2) var(--ease),
              border-color var(--dur-2) var(--ease);
  border: 1px solid transparent;
}
.btn:active { transform: translateY(1px); }

.btn--primary {
  background: var(--gold);
  color: var(--white);
  border-color: var(--gold);
}
.btn--primary:hover { background: var(--gold-deep); border-color: var(--gold-deep); color: var(--white); }

.btn--outline {
  background: transparent;
  color: var(--stone-gray);
  border-color: var(--gold);
}
.btn--outline:hover { background: var(--gold); color: var(--white); }

.btn--ghost {
  background: transparent;
  color: var(--stone-gray);
  border-color: rgba(59, 58, 54, 0.2);
}
.btn--ghost:hover { border-color: var(--gold); color: var(--gold-deep); }

.btn--block { width: 100%; }
.btn--lg    { padding: 1rem 2rem; font-size: var(--fs-14); }

.link-gold {
  display: inline-flex;
  align-items: center;
  gap: var(--s-8);
  color: var(--gold-deep);
  font-size: var(--fs-13);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  font-weight: 500;
}
.link-gold::after {
  content: "→";
  transition: transform var(--dur-1) var(--ease);
}
.link-gold:hover::after { transform: translateX(3px); }

/* ---------- Announcement Bar ---------- */
.announcement {
  background: var(--muted-sage-deep);
  color: #F3F1E7;
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.announcement__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-16);
  padding: 0.55rem 0;
}
.announcement__msg { display: inline-flex; align-items: center; gap: 0.55rem; }
.announcement__locale { display: inline-flex; align-items: center; gap: 0.35rem; }
.announcement svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.5; }
@media (max-width: 600px) {
  .announcement__msg  span:last-child { display: none; }
}

/* ---------- Header ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: var(--pearl-cream);
  border-bottom: var(--border-soft);
}
.site-header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--s-16);
  padding-block: var(--s-20);
}

.brand {
  grid-column: 2;
  text-align: center;
  font-family: var(--font-serif);
  line-height: 1;
}
.brand__wordmark {
  font-size: clamp(1.6rem, 2.2vw, var(--fs-32));
  letter-spacing: 0.34em;
  color: var(--gold-deep);
  font-weight: 400;
  display: block;
}
.brand__tagline {
  display: block;
  margin-top: 0.25rem;
  font-size: var(--fs-12);
  letter-spacing: 0.12em;
  font-style: italic;
  color: var(--stone-gray-soft);
}

/* Primary nav */
.primary-nav {
  grid-column: 1;
  display: flex;
  justify-content: flex-start;
  gap: clamp(1rem, 2vw, var(--s-32));
}
.primary-nav a {
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--stone-gray);
  padding: 0.25rem 0;
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-2) var(--ease), color var(--dur-2) var(--ease);
}
.primary-nav a:hover,
.primary-nav a.is-active {
  color: var(--gold-deep);
  border-bottom-color: var(--gold);
}

/* Utility */
.utility-nav {
  grid-column: 3;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: var(--s-16);
}
.icon-btn {
  position: relative;
  width: 36px; height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-pill);
  color: var(--stone-gray);
  transition: background var(--dur-2) var(--ease), color var(--dur-2) var(--ease);
}
.icon-btn:hover { background: var(--pearl-cream-deep); color: var(--gold-deep); }
.icon-btn svg  { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.cart-count {
  position: absolute;
  top: 2px; right: 2px;
  min-width: 16px; height: 16px; padding: 0 4px;
  background: var(--gold);
  color: var(--white);
  font-size: 10px;
  border-radius: var(--r-pill);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-sans);
  letter-spacing: 0;
}

/* Mobile menu toggle */
.menu-toggle { display: none; }
@media (max-width: 960px) {
  .primary-nav { display: none; }
  .menu-toggle {
    display: inline-flex;
    justify-self: start;
    grid-column: 1;
  }
  .site-header__inner { grid-template-columns: auto 1fr auto; }
  .utility-nav .icon-btn[data-account] { display: none; }
  .brand__wordmark { font-size: 1.5rem; letter-spacing: 0.3em; }
  .brand__tagline { font-size: 10px; }
}

/* ---------- Mobile Drawer ---------- */
.drawer {
  position: fixed;
  inset: 0 auto 0 0;
  width: min(320px, 86vw);
  background: var(--pearl-cream);
  transform: translateX(-100%);
  transition: transform var(--dur-3) var(--ease);
  z-index: 60;
  display: flex;
  flex-direction: column;
  box-shadow: 0 0 40px rgba(0,0,0,0.08);
}
.drawer.is-open { transform: translateX(0); }
.drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s-20) var(--s-24);
  border-bottom: var(--rule-gold);
}
.drawer__title {
  font-family: var(--font-serif);
  letter-spacing: 0.28em;
  color: var(--gold-deep);
  font-size: var(--fs-18);
}
.drawer__nav { padding: var(--s-24); display: flex; flex-direction: column; gap: var(--s-4); }
.drawer__nav a {
  padding: var(--s-12) 0;
  font-size: var(--fs-18);
  font-family: var(--font-serif);
  border-bottom: var(--border-soft);
  color: var(--stone-gray);
}
.drawer__nav a:hover { color: var(--gold-deep); }
.drawer__group-label {
  margin-top: var(--s-20);
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--gold-deep);
}

.backdrop {
  position: fixed; inset: 0;
  background: var(--overlay);
  opacity: 0; pointer-events: none;
  transition: opacity var(--dur-2) var(--ease);
  z-index: 55;
}
.backdrop.is-open { opacity: 1; pointer-events: auto; }

/* ---------- Search overlay ---------- */
.search-overlay {
  position: fixed; inset: 0;
  background: rgba(246, 240, 230, 0.97);
  z-index: 70;
  display: flex; flex-direction: column;
  opacity: 0; pointer-events: none;
  transition: opacity var(--dur-2) var(--ease);
}
.search-overlay.is-open { opacity: 1; pointer-events: auto; }
.search-overlay__bar {
  display: flex; align-items: center; gap: var(--s-16);
  padding: var(--s-24) var(--gutter);
  border-bottom: var(--rule-gold);
}
.search-overlay input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  font-family: var(--font-serif);
  font-size: clamp(1.25rem, 3vw, var(--fs-32));
  color: var(--stone-gray);
  padding: 0.5rem 0;
}
.search-overlay input::placeholder { color: var(--stone-gray-mute); }
.search-overlay__body {
  padding: var(--s-32) var(--gutter);
  max-width: var(--container);
  margin-inline: auto;
  width: 100%;
}
.search-suggestions {
  display: grid;
  gap: var(--s-12);
  list-style: none;
  padding: 0; margin: 0;
}
.search-suggestions li a {
  display: flex; justify-content: space-between;
  padding: var(--s-12) 0;
  border-bottom: var(--border-soft);
  font-size: var(--fs-14);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  padding-block: clamp(2.5rem, 5vw, var(--s-80));
  background: linear-gradient(180deg, var(--pearl-cream-soft) 0%, var(--pearl-cream) 100%);
  overflow: hidden;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(1.5rem, 5vw, var(--s-80));
  align-items: center;
}
.hero__copy h1 {
  font-style: italic;
  letter-spacing: -0.005em;
}
.hero__copy p {
  margin-top: var(--s-20);
  font-size: var(--fs-18);
  color: var(--stone-gray-soft);
  max-width: 34ch;
  line-height: var(--lh-loose);
}
.hero__ctas {
  margin-top: var(--s-32);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-12);
}
.hero__media {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--pearl-cream-deep);
}
.hero__media::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(255,255,255,0.6), transparent 60%),
    radial-gradient(ellipse at 70% 70%, rgba(184,147,96,0.14), transparent 65%),
    linear-gradient(135deg, #F6EFE1, #E7DCC6 60%, #D9CBAD);
}
.hero__media .jewel {
  position: absolute;
  filter: drop-shadow(0 6px 18px rgba(143, 111, 66, 0.2));
}
@media (max-width: 860px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__media { aspect-ratio: 4 / 3; }
}

/* ---------- Trust strip (top / home) ---------- */
.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: var(--rule-gold);
  border-bottom: var(--rule-gold);
  background: var(--pearl-cream-soft);
}
.trust-strip__item {
  padding: var(--s-24);
  text-align: center;
  border-right: var(--border-soft);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-8);
}
.trust-strip__item:last-child { border-right: 0; }
.trust-strip__item svg {
  width: 28px; height: 28px;
  stroke: var(--gold);
  fill: none;
  stroke-width: 1.4;
}
.trust-strip__title {
  font-family: var(--font-serif);
  font-size: var(--fs-16);
  color: var(--stone-gray);
  margin-top: var(--s-4);
}
.trust-strip__body {
  font-size: var(--fs-12);
  color: var(--stone-gray-soft);
  max-width: 28ch;
  line-height: var(--lh-base);
}
@media (max-width: 780px) {
  .trust-strip { grid-template-columns: repeat(2, 1fr); }
  .trust-strip__item:nth-child(2) { border-right: 0; }
  .trust-strip__item:nth-child(-n+2) { border-bottom: var(--border-soft); }
}

/* Trust strip (bottom / footer-adjacent) uses sage */
.trust-strip--sage {
  background: var(--muted-sage-deep);
  color: #F3F1E7;
  border: 0;
}
.trust-strip--sage .trust-strip__item { border-right-color: rgba(255,255,255,0.15); }
.trust-strip--sage .trust-strip__title { color: #F3F1E7; }
.trust-strip--sage .trust-strip__body { color: rgba(243, 241, 231, 0.82); }
.trust-strip--sage svg { stroke: var(--gold-soft); }

/* ---------- Category Trio ---------- */
.category-trio {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-20);
}
.category-card {
  position: relative;
  display: block;
  border-radius: var(--r-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--pearl-cream-deep);
}
.category-card__art {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(255,255,255,0.55), transparent 65%),
    linear-gradient(135deg, #F2E8D3, #E3D3AE 70%, #C9B88A);
}
.category-card__label {
  position: absolute;
  left: var(--s-20); bottom: var(--s-20);
  padding: 0.45rem 0.85rem;
  background: rgba(246, 240, 230, 0.92);
  color: var(--stone-gray);
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  border: 1px solid var(--gold-line);
  border-radius: var(--r-sm);
}
.category-card:hover .category-card__label { background: var(--gold); color: var(--white); }
@media (max-width: 760px) {
  .category-trio { grid-template-columns: 1fr; }
}

/* ---------- Section headings ---------- */
.section-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--s-24);
  margin-bottom: var(--s-32);
}
.section-heading__title h2 {
  font-style: italic;
  letter-spacing: 0.01em;
}
.section-heading__sub {
  margin-top: var(--s-8);
  color: var(--stone-gray-soft);
  font-size: var(--fs-14);
  max-width: 52ch;
}
@media (max-width: 720px) {
  .section-heading { flex-direction: column; align-items: flex-start; }
}

/* ---------- Product grid + card ---------- */
.product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-24) var(--s-20);
}
@media (max-width: 1100px) { .product-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 820px)  { .product-grid { grid-template-columns: repeat(2, 1fr); } }

.product-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-12);
}
.product-card__media {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: var(--r-md);
  background: var(--pearl-cream-deep);
}
.product-card__media::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 38%, rgba(255,255,255,0.65), transparent 60%),
    linear-gradient(135deg, #F6ECD6, #E9D9B4 70%, #D2B985);
  transition: transform var(--dur-3) var(--ease);
}
.product-card:hover .product-card__media::before { transform: scale(1.04); }

.product-card__pill {
  position: absolute;
  top: var(--s-12); left: var(--s-12);
  padding: 0.3rem 0.6rem;
  font-size: 10px;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  background: var(--muted-sage-deep);
  color: #F3F1E7;
  border-radius: var(--r-sm);
}
.product-card__pill--gold { background: var(--gold); }

.product-card__wishlist {
  position: absolute;
  top: var(--s-12); right: var(--s-12);
  width: 32px; height: 32px;
  border-radius: var(--r-pill);
  background: rgba(246, 240, 230, 0.9);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--stone-gray);
  transition: background var(--dur-2) var(--ease), color var(--dur-2) var(--ease);
}
.product-card__wishlist svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.product-card__wishlist:hover { color: var(--gold-deep); background: var(--white); }
.product-card__wishlist.is-active { color: var(--gold); }
.product-card__wishlist.is-active svg { fill: currentColor; }

.product-card__title {
  font-family: var(--font-serif);
  font-size: var(--fs-16);
  color: var(--stone-gray);
  letter-spacing: 0.005em;
}
.product-card__price {
  font-size: var(--fs-13);
  color: var(--gold-deep);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  font-weight: 500;
}

/* ---------- Collection header + filters ---------- */
.collection-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-40);
  align-items: center;
  padding-block: clamp(2rem, 5vw, var(--s-64));
}
.collection-header__copy h1 {
  font-style: italic;
}
.collection-header__copy p {
  margin-top: var(--s-16);
  color: var(--stone-gray-soft);
  max-width: 46ch;
}
.collection-header__copy .script-mark { display: inline-block; margin-top: var(--s-16); }
.collection-header__media {
  aspect-ratio: 3 / 2;
  border-radius: var(--r-lg);
  background:
    radial-gradient(ellipse at 30% 40%, rgba(255,255,255,0.55), transparent 65%),
    linear-gradient(135deg, #F3E9D2, #E7D7B0 70%, #CDB383);
}
@media (max-width: 860px) {
  .collection-header { grid-template-columns: 1fr; }
  .collection-header__media { aspect-ratio: 4 / 3; }
}

.filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-16);
  padding: var(--s-16) 0;
  border-top: var(--rule-gold);
  border-bottom: var(--rule-gold);
  flex-wrap: wrap;
}
.filter-bar__filters,
.filter-bar__sort {
  display: flex;
  gap: var(--s-16);
  align-items: center;
  flex-wrap: wrap;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--s-6);
  padding: 0.55rem 0.85rem;
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--stone-gray);
  background: transparent;
  border: 1px solid rgba(59, 58, 54, 0.18);
  border-radius: var(--r-sm);
  transition: border-color var(--dur-2) var(--ease), color var(--dur-2) var(--ease);
}
.filter-chip:hover { border-color: var(--gold); color: var(--gold-deep); }
.filter-chip svg { width: 11px; height: 11px; stroke: currentColor; fill: none; stroke-width: 1.6; }

.filter-bar__sort select {
  font: inherit;
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  background: transparent;
  border: 0;
  color: var(--stone-gray);
  padding: 0.25rem 0.25rem 0.25rem 0;
  cursor: pointer;
}

/* ---------- New arrivals / featured ---------- */
.arrivals-grid { composes: product-grid; }

/* ---------- Story block (home) ---------- */
.story-block {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(1.5rem, 5vw, var(--s-80));
  align-items: center;
}
.story-block__media {
  aspect-ratio: 4 / 5;
  border-radius: var(--r-lg);
  background:
    radial-gradient(ellipse at 30% 35%, rgba(255,255,255,0.45), transparent 60%),
    linear-gradient(160deg, #EDE0C4, #D6C39C 70%, #B59B6E);
}
.story-block__copy .eyebrow { margin-bottom: var(--s-12); }
.story-block__copy h2 { font-style: italic; max-width: 20ch; }
.story-block__copy p  { margin-top: var(--s-20); max-width: 52ch; color: var(--stone-gray-soft); }
.story-block__cta     { margin-top: var(--s-24); }
@media (max-width: 900px) {
  .story-block { grid-template-columns: 1fr; }
}

/* ---------- Materials block ---------- */
.materials {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-20);
}
.material-card {
  padding: var(--s-24);
  text-align: center;
  border: var(--rule-gold);
  border-radius: var(--r-md);
  background: var(--pearl-cream-soft);
  display: flex; flex-direction: column; align-items: center; gap: var(--s-8);
}
.material-card svg {
  width: 36px; height: 36px;
  stroke: var(--gold);
  fill: none; stroke-width: 1.3;
}
.material-card__name {
  font-family: var(--font-serif);
  font-size: var(--fs-16);
  color: var(--stone-gray);
  margin-top: var(--s-6);
}
.material-card__body { font-size: var(--fs-12); color: var(--stone-gray-soft); max-width: 24ch; }
@media (max-width: 820px) { .materials { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Product Detail ---------- */
.pdp {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(1.5rem, 4vw, var(--s-64));
  padding-block: clamp(2rem, 4vw, var(--s-48));
}
.pdp__media {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--s-16);
}
.pdp__thumbs {
  display: flex;
  flex-direction: column;
  gap: var(--s-12);
}
.pdp__thumb {
  width: 80px; height: 80px;
  border-radius: var(--r-sm);
  border: 1px solid transparent;
  overflow: hidden;
  background: var(--pearl-cream-deep);
  cursor: pointer;
}
.pdp__thumb::before {
  content: "";
  display: block; width: 100%; height: 100%;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(255,255,255,0.55), transparent 65%),
    linear-gradient(135deg, #F3E8CF, #E1CEA4 70%, #C6AA7B);
}
.pdp__thumb.is-active { border-color: var(--gold); }

.pdp__stage {
  aspect-ratio: 4 / 5;
  border-radius: var(--r-md);
  overflow: hidden;
  background:
    radial-gradient(ellipse at 45% 40%, rgba(255,255,255,0.55), transparent 60%),
    linear-gradient(135deg, #F5ECD6, #E4D3AC 65%, #CBAE78);
  position: relative;
}
.pdp__stage svg.jewel { position: absolute; inset: 0; margin: auto; }

@media (max-width: 860px) {
  .pdp { grid-template-columns: 1fr; }
  .pdp__media { grid-template-columns: 1fr; }
  .pdp__thumbs { flex-direction: row; order: 2; }
}

.pdp__pills {
  display: flex; gap: var(--s-8); margin-bottom: var(--s-16);
}
.pdp__pill {
  display: inline-flex; align-items: center; gap: var(--s-6);
  padding: 0.3rem 0.6rem;
  font-size: 10px;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  border: 1px solid var(--gold-line);
  border-radius: var(--r-sm);
  color: var(--gold-deep);
}
.pdp__title { font-style: italic; margin-bottom: var(--s-12); }
.pdp__price {
  font-family: var(--font-sans);
  font-size: var(--fs-18);
  color: var(--gold-deep);
  letter-spacing: var(--ls-wide);
  font-weight: 500;
  margin-bottom: var(--s-20);
}
.pdp__desc { color: var(--stone-gray-soft); margin-bottom: var(--s-24); max-width: 52ch; }

.qty-row {
  display: flex;
  align-items: stretch;
  gap: var(--s-12);
  margin-bottom: var(--s-16);
}
.qty-stepper {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(59,58,54,0.18);
  border-radius: var(--r-sm);
  overflow: hidden;
}
.qty-stepper button {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--stone-gray);
}
.qty-stepper button:hover { color: var(--gold-deep); }
.qty-stepper input {
  width: 44px; height: 44px;
  border: 0; outline: 0; background: transparent;
  text-align: center;
  font: inherit; font-size: var(--fs-15);
  color: var(--stone-gray);
}
.qty-row .btn { flex: 1; }

.pdp__wishlist-row {
  display: inline-flex;
  align-items: center; gap: var(--s-8);
  color: var(--stone-gray-soft);
  font-size: var(--fs-13);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  margin-bottom: var(--s-24);
}
.pdp__wishlist-row svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.5; }

.pdp__reassurance {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-12);
  padding: var(--s-16);
  background: var(--pearl-cream-soft);
  border: var(--rule-gold);
  border-radius: var(--r-md);
  margin-bottom: var(--s-16);
}
.pdp__reassurance > div {
  text-align: center;
  font-size: var(--fs-12);
  color: var(--stone-gray-soft);
}
.pdp__reassurance strong { display: block; color: var(--stone-gray); font-weight: 500; font-size: var(--fs-13); margin-bottom: 2px; }
@media (max-width: 520px) { .pdp__reassurance { grid-template-columns: 1fr; } }

/* Accordion */
.accordion { border-top: var(--border-soft); }
.accordion__item { border-bottom: var(--border-soft); }
.accordion__trigger {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: var(--s-16) 0;
  font-size: var(--fs-13);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--stone-gray);
}
.accordion__trigger:hover { color: var(--gold-deep); }
.accordion__trigger svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 1.5; transition: transform var(--dur-2) var(--ease); }
.accordion__item.is-open .accordion__trigger svg { transform: rotate(45deg); }
.accordion__panel {
  display: none;
  padding-bottom: var(--s-20);
  color: var(--stone-gray-soft);
  font-size: var(--fs-14);
  line-height: var(--lh-loose);
  max-width: 56ch;
}
.accordion__item.is-open .accordion__panel { display: block; }

/* ---------- Style With (related) ---------- */
.style-with {
  margin-top: var(--s-64);
}
.style-with__title {
  text-align: center;
  font-style: italic;
  margin-bottom: var(--s-24);
}

/* ---------- Gallery ---------- */
.gallery-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-40);
  padding-block: clamp(2rem, 4vw, var(--s-48));
  align-items: center;
}
.gallery-hero h1 { font-style: italic; }
.gallery-hero p { color: var(--stone-gray-soft); max-width: 48ch; margin-top: var(--s-16); }
.gallery-hero__media {
  aspect-ratio: 3 / 2;
  border-radius: var(--r-lg);
  background:
    radial-gradient(ellipse at 30% 40%, rgba(255,255,255,0.55), transparent 65%),
    linear-gradient(135deg, #F2E8D3, #E1CFA4 70%, #C7AA73);
}
@media (max-width: 860px) { .gallery-hero { grid-template-columns: 1fr; } }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: var(--s-16);
}
.gallery-grid__tile {
  border-radius: var(--r-md);
  overflow: hidden;
  position: relative;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(255,255,255,0.5), transparent 60%),
    linear-gradient(135deg, #F3E8D0, #E1CEA2 70%, #C6A972);
}
.gallery-grid__tile--tall  { grid-row: span 2; }
.gallery-grid__tile--wide  { grid-column: span 2; }
.gallery-grid__tile--sage {
  background: var(--muted-sage-deep);
  color: #F3F1E7;
  padding: var(--s-24);
  display: flex; flex-direction: column; justify-content: space-between;
}
.gallery-grid__tile--cream {
  background: var(--pearl-cream-soft);
  color: var(--stone-gray);
  padding: var(--s-24);
  display: flex; flex-direction: column; justify-content: space-between;
  border: var(--rule-gold);
}
.shop-the-look .eyebrow { color: var(--gold-soft); }
.gallery-grid__tile--cream .eyebrow { color: var(--gold-deep); }
.shop-the-look h3 { margin-top: var(--s-8); font-size: var(--fs-20); }
.shop-the-look p  { margin-top: var(--s-8); font-size: var(--fs-13); opacity: 0.85; max-width: 24ch; }
.gallery-grid__tile--cream h3 { margin-top: var(--s-8); font-size: var(--fs-20); font-style: italic; }
.gallery-grid__tile--cream p  { font-size: var(--fs-13); color: var(--stone-gray-soft); }

@media (max-width: 1024px) {
  .gallery-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
  .gallery-grid__tile--wide { grid-column: span 2; }
}

/* ---------- About ---------- */
.about-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 5vw, var(--s-64));
  align-items: center;
  padding-block: clamp(2rem, 4vw, var(--s-64));
}
.about-hero h1 { font-style: italic; }
.about-hero p { color: var(--stone-gray-soft); margin-top: var(--s-20); max-width: 50ch; }
.about-hero__media {
  aspect-ratio: 4 / 5;
  border-radius: var(--r-lg);
  background:
    radial-gradient(ellipse at 40% 40%, rgba(255,255,255,0.5), transparent 60%),
    linear-gradient(145deg, #EEDFBE, #D7BE8D 70%, #B3926A);
}
@media (max-width: 820px) { .about-hero { grid-template-columns: 1fr; } }

.about-story {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-40);
  align-items: start;
}
.about-story__media {
  aspect-ratio: 4 / 5;
  border-radius: var(--r-lg);
  background:
    radial-gradient(ellipse at 40% 40%, rgba(255,255,255,0.4), transparent 60%),
    linear-gradient(145deg, #EDE3CE, #D4C098 70%, #AE9467);
}
.about-story__copy h2 { font-style: italic; }
.about-story__copy p { color: var(--stone-gray-soft); margin-top: var(--s-16); max-width: 52ch; }
.about-story__points {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--s-24);
  margin-top: var(--s-32);
}
.about-point__eyebrow { color: var(--gold-deep); font-size: var(--fs-12); letter-spacing: var(--ls-wider); text-transform: uppercase; }
.about-point__title { font-family: var(--font-serif); margin-top: var(--s-6); color: var(--stone-gray); }
.about-point__body  { color: var(--stone-gray-soft); font-size: var(--fs-13); margin-top: var(--s-4); }
@media (max-width: 820px) { .about-story { grid-template-columns: 1fr; } }

.about-philosophy, .about-process {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-40);
  align-items: center;
}
.about-process { direction: rtl; }
.about-process > * { direction: ltr; }
@media (max-width: 820px) {
  .about-philosophy, .about-process { grid-template-columns: 1fr; direction: ltr; }
}
.about-block__media {
  aspect-ratio: 4 / 3;
  border-radius: var(--r-lg);
  background:
    radial-gradient(ellipse at 40% 40%, rgba(255,255,255,0.5), transparent 60%),
    linear-gradient(145deg, #E8DDC1, #CFB98B 70%, #A98F63);
}
.about-block__copy h2 { font-style: italic; }
.about-block__copy p { color: var(--stone-gray-soft); margin-top: var(--s-16); max-width: 52ch; }
.about-block__list {
  list-style: none; padding: 0; margin-top: var(--s-24);
  display: grid; gap: var(--s-16);
}
.about-block__list li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: var(--s-12);
  align-items: start;
  font-size: var(--fs-14);
  color: var(--stone-gray-soft);
}
.about-block__list li strong { color: var(--stone-gray); font-weight: 500; }
.about-block__list li::before {
  content: "";
  display: block; margin-top: 0.55rem;
  width: 14px; height: 1px;
  background: var(--gold);
}

/* ---------- Cart ---------- */
.cart {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: var(--s-40);
}
.cart__items { list-style: none; padding: 0; margin: 0; }
.cart__item {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  gap: var(--s-20);
  padding: var(--s-20) 0;
  border-bottom: var(--border-soft);
  align-items: center;
}
.cart__thumb {
  width: 100px; height: 100px;
  border-radius: var(--r-sm);
  background:
    radial-gradient(ellipse at 50% 40%, rgba(255,255,255,0.55), transparent 65%),
    linear-gradient(135deg, #F3E8CF, #E1CEA4 70%, #C6AA7B);
}
.cart__info { display: flex; flex-direction: column; gap: var(--s-4); }
.cart__info h4 { font-family: var(--font-serif); font-weight: 400; color: var(--stone-gray); }
.cart__info p { font-size: var(--fs-12); color: var(--stone-gray-soft); }
.cart__actions { display: inline-flex; align-items: center; gap: var(--s-16); }
.cart__price { font-size: var(--fs-14); color: var(--gold-deep); letter-spacing: var(--ls-wide); }
.cart__remove {
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--stone-gray-soft);
}
.cart__remove:hover { color: var(--gold-deep); }

.cart-summary {
  padding: var(--s-24);
  background: var(--pearl-cream-soft);
  border: var(--rule-gold);
  border-radius: var(--r-md);
  height: fit-content;
  position: sticky; top: 120px;
}
.cart-summary h3 { font-family: var(--font-serif); font-style: italic; margin-bottom: var(--s-16); }
.cart-summary__row {
  display: flex; justify-content: space-between;
  padding: var(--s-8) 0;
  font-size: var(--fs-14);
  color: var(--stone-gray-soft);
}
.cart-summary__row--total {
  border-top: var(--rule-gold);
  margin-top: var(--s-8);
  padding-top: var(--s-12);
  color: var(--stone-gray);
  font-size: var(--fs-16);
  font-weight: 500;
}
.cart-summary .btn { margin-top: var(--s-16); }
.cart-summary__note { font-size: var(--fs-12); color: var(--stone-gray-soft); margin-top: var(--s-12); text-align: center; }
@media (max-width: 860px) {
  .cart { grid-template-columns: 1fr; }
  .cart-summary { position: static; }
}

/* ---------- Content page (shipping / returns / privacy / terms) ---------- */
.content-page {
  padding-block: clamp(2rem, 5vw, var(--s-64));
}
.content-page h1 { font-style: italic; margin-bottom: var(--s-24); }
.content-page h2 { font-family: var(--font-serif); margin-top: var(--s-32); margin-bottom: var(--s-12); }
.content-page p  { color: var(--stone-gray-soft); line-height: var(--lh-loose); margin-bottom: var(--s-12); max-width: 72ch; }
.content-page ul { padding-left: var(--s-20); color: var(--stone-gray-soft); line-height: var(--lh-loose); margin-bottom: var(--s-12); }

/* ---------- Contact ---------- */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 4vw, var(--s-48));
  padding-block: clamp(2rem, 4vw, var(--s-48));
}
.contact-grid h1 { font-style: italic; margin-bottom: var(--s-16); }
.contact-grid p  { color: var(--stone-gray-soft); margin-bottom: var(--s-12); max-width: 46ch; }
.contact-list { list-style: none; padding: 0; margin-top: var(--s-24); display: grid; gap: var(--s-16); }
.contact-list strong { display: block; font-size: var(--fs-12); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--gold-deep); }
.contact-list span { display: block; color: var(--stone-gray); font-size: var(--fs-14); margin-top: 2px; }

form.contact-form { display: grid; gap: var(--s-16); }
.field { display: grid; gap: var(--s-6); }
.field label {
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--stone-gray-soft);
}
.field input, .field textarea, .field select {
  width: 100%;
  font: inherit;
  font-size: var(--fs-14);
  padding: 0.75rem 0.9rem;
  border: 1px solid rgba(59,58,54,0.18);
  border-radius: var(--r-sm);
  background: var(--white);
  color: var(--stone-gray);
  transition: border-color var(--dur-2) var(--ease);
}
.field textarea { min-height: 140px; resize: vertical; }
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--gold); outline: none; }

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

/* ---------- Search page ---------- */
.search-panel {
  padding-block: clamp(2rem, 5vw, var(--s-64));
}
.search-panel h1 { font-style: italic; margin-bottom: var(--s-16); }
.search-box {
  display: flex; gap: var(--s-12);
  margin: var(--s-24) 0;
  align-items: center;
  max-width: 640px;
}
.search-box input {
  flex: 1;
  padding: 0.85rem 1rem;
  border: 1px solid rgba(59,58,54,0.18);
  border-radius: var(--r-sm);
  background: var(--white);
  font-size: var(--fs-15);
}
.search-box input:focus { border-color: var(--gold); outline: none; }

.search-chips {
  display: flex; flex-wrap: wrap; gap: var(--s-8);
  margin-bottom: var(--s-32);
}
.search-chips span { font-size: var(--fs-12); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--stone-gray-soft); margin-right: var(--s-8); }
.search-chips a {
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  padding: 0.35rem 0.7rem;
  border: 1px solid var(--gold-line);
  color: var(--gold-deep);
  border-radius: var(--r-pill);
}
.search-chips a:hover { background: var(--gold); color: var(--white); }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--muted-sage-deep);
  color: #F3F1E7;
  padding-block: var(--s-64) var(--s-24);
  margin-top: var(--s-64);
}
.site-footer a { color: #F3F1E7; }
.site-footer a:hover { color: var(--gold-soft); }
.footer-grid {
  display: grid;
  grid-template-columns: 1.3fr repeat(3, 1fr);
  gap: var(--s-40);
  padding-bottom: var(--s-40);
  border-bottom: 1px solid rgba(243,241,231,0.2);
}
.footer-brand .brand__wordmark { color: #F3F1E7; }
.footer-brand .brand__tagline  { color: rgba(243,241,231,0.75); }
.footer-brand p {
  margin-top: var(--s-16);
  font-size: var(--fs-13);
  line-height: var(--lh-loose);
  color: rgba(243,241,231,0.8);
  max-width: 36ch;
}
.footer-col h4 {
  color: #F3F1E7;
  font-family: var(--font-sans);
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  margin-bottom: var(--s-16);
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--s-8); }
.footer-col li a { font-size: var(--fs-13); }

.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: var(--s-20);
  font-size: var(--fs-12);
  color: rgba(243,241,231,0.7);
  letter-spacing: var(--ls-wide);
  flex-wrap: wrap;
  gap: var(--s-8);
}
@media (max-width: 780px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: span 2; }
}

/* ---------- Toast ---------- */
.toast {
  position: fixed;
  bottom: var(--s-24); right: var(--s-24);
  padding: var(--s-16) var(--s-20);
  background: var(--stone-gray);
  color: var(--pearl-cream);
  font-size: var(--fs-13);
  letter-spacing: var(--ls-wide);
  border-radius: var(--r-sm);
  box-shadow: var(--shadow-2);
  transform: translateY(20px);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-2) var(--ease), transform var(--dur-2) var(--ease);
  z-index: 80;
}
.toast.is-visible { opacity: 1; transform: translateY(0); }

/* ---------- Utils ---------- */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* =========================================================
   LILY GRAY — v2 refinements
   Real-image cards · Tagline tiles · Uniform Gallery · Motion ·
   Mobile overflow fixes · Asymmetric hero · Rings support
   ========================================================= */

/* Global overflow protection — prevents ANY horizontal scroll on mobile */
html, body { overflow-x: hidden; max-width: 100vw; }
img { height: auto; }

/* Softer elevation — less "prototype box" shadows */
:root {
  --shadow-soft:   0 2px 6px rgba(59, 58, 54, 0.035), 0 10px 28px rgba(59, 58, 54, 0.05);
  --shadow-lift:   0 2px 8px rgba(59, 58, 54, 0.04),  0 18px 40px rgba(59, 58, 54, 0.07);
  --dur-slow: 700ms;
}

/* ---------- Real product image support ---------- */
.product-card__media {
  background: var(--pearl-cream-deep);
  box-shadow: var(--shadow-soft);
}
.product-card__media img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease);
  display: block;
}
.product-card__media--img::before { display: none; } /* hide placeholder gradient when real image present */
.product-card:hover .product-card__media img { transform: scale(1.035); }
.product-card__title { transition: color var(--dur-2) var(--ease); }
.product-card:hover .product-card__title { color: var(--gold-deep); }

/* ---------- Hero: asymmetric + real image ---------- */
.hero__media--img {
  aspect-ratio: 4 / 5;
  box-shadow: var(--shadow-lift);
}
.hero__media--img::before { display: none; }
.hero__media img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.hero__grid--offset {
  grid-template-columns: 1.15fr 0.9fr;
  align-items: end;
}
@media (max-width: 860px) {
  .hero__grid--offset { grid-template-columns: 1fr; }
  .hero__media--img { aspect-ratio: 4 / 3; }
}

/* ---------- Category trio with real images ---------- */
.category-card { box-shadow: var(--shadow-soft); transition: transform var(--dur-3) var(--ease); }
.category-card:hover { transform: translateY(-2px); }
.category-card img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease);
}
.category-card:hover img { transform: scale(1.04); }
.category-card--img .category-card__art { display: none; }

/* ---------- Tagline Tiles (THOUGHTFULLY CRAFTED / MADE FOR EVERY DAY / etc.) ---------- */
.tagline-tiles {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--s-16);
}
.tagline-tile {
  aspect-ratio: 1;
  border-radius: var(--r-md);
  overflow: hidden;
  position: relative;
  background: var(--pearl-cream-soft);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: var(--s-12);
  text-align: center;
  transition: transform var(--dur-3) var(--ease);
}
.tagline-tile::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(255,255,255,0.55), transparent 65%),
    linear-gradient(135deg, #F2E8D3, #E3D3AE 70%, #C9B88A);
  z-index: 0;
}
.tagline-tile--sage::before { background: linear-gradient(135deg, #C9D0BE, #A8B39B 70%, #7F8A74); }
.tagline-tile--cream::before { background: linear-gradient(135deg, #FBF6EC, #EFE7D8); }
.tagline-tile--giftbox::before { background: linear-gradient(135deg, #E8DFC8, #CFB98B 70%, #A08458); }
.tagline-tile__label {
  position: relative;
  z-index: 1;
  font-family: var(--font-sans);
  font-size: var(--fs-12);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--stone-gray);
  background: rgba(246, 240, 230, 0.94);
  padding: 0.45rem 0.7rem;
  border-radius: var(--r-sm);
  border: 1px solid var(--gold-line);
  max-width: 90%;
}
.tagline-tile:hover { transform: translateY(-2px); }
@media (max-width: 1024px) { .tagline-tiles { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px)  { .tagline-tiles { grid-template-columns: repeat(2, 1fr); gap: var(--s-12); } }

/* ---------- Uniform Gallery Grid (matches reference sheet) ---------- */
.gallery-grid--uniform {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--s-16);
  grid-auto-rows: auto;
}
.gallery-grid--uniform .gallery-tile {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--pearl-cream-deep);
  box-shadow: var(--shadow-soft);
  transition: transform var(--dur-3) var(--ease);
}
.gallery-grid--uniform .gallery-tile:hover { transform: translateY(-2px); }
.gallery-grid--uniform .gallery-tile__art {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(255,255,255,0.55), transparent 65%),
    linear-gradient(135deg, #F2E8D3, #E1CFA4 70%, #C7AA73);
}
.gallery-grid--uniform .gallery-tile img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.gallery-tile__label {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 0.55rem 0.5rem;
  text-align: center;
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--stone-gray-soft);
  background: rgba(246, 240, 230, 0.92);
  backdrop-filter: blur(4px);
  border-top: 1px solid rgba(201, 168, 116, 0.25);
}
@media (max-width: 1024px) { .gallery-grid--uniform { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 720px)  { .gallery-grid--uniform { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 440px)  { .gallery-grid--uniform { grid-template-columns: repeat(2, 1fr); gap: var(--s-12); } }

/* ---------- Scroll reveal (subtle) ---------- */
.reveal {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 800ms var(--ease), transform 800ms var(--ease);
}
.reveal.is-in {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; }
}

/* ---------- Filter panel (simple, functional) ---------- */
.filter-chip[data-filter-value] { cursor: pointer; user-select: none; }
.filter-chip.is-active {
  border-color: var(--gold);
  color: var(--gold-deep);
  background: var(--pearl-cream-soft);
}
.product-card[hidden] { display: none !important; }

/* ---------- Announcement bar: fits narrow phones ---------- */
@media (max-width: 420px) {
  .announcement__inner { font-size: 10px; gap: var(--s-8); padding: 0.5rem 0; }
  .announcement__msg svg { display: none; }
  .announcement__locale { flex-shrink: 0; }
}

/* ---------- Narrow phone layout fixes (320–420px) ---------- */
@media (max-width: 560px) {
  :root { --gutter: 1rem; }

  /* Smaller hero headline so it doesn't blow out */
  .hero { padding-block: var(--s-32); }
  .hero__copy h1 { font-size: clamp(2rem, 9vw, 2.5rem); }
  .hero__ctas { gap: var(--s-8); }
  .hero__ctas .btn { flex: 1 1 calc(50% - var(--s-8)); padding: 0.75rem 1rem; font-size: var(--fs-12); }

  /* Trust strip: stack 2 cols, tighter */
  .trust-strip { grid-template-columns: repeat(2, 1fr); }
  .trust-strip__item { padding: var(--s-16) var(--s-12); }
  .trust-strip__title { font-size: var(--fs-14); }
  .trust-strip__body { font-size: 11px; }

  /* Filter bar wraps + shrinks */
  .filter-bar { padding: var(--s-12) 0; gap: var(--s-8); }
  .filter-chip { padding: 0.45rem 0.65rem; font-size: 11px; }

  /* Product cards: 2-up, tighter */
  .product-grid { gap: var(--s-16) var(--s-12); }
  .product-card__title { font-size: var(--fs-14); }
  .product-card__price { font-size: var(--fs-12); }

  /* Section headings wrap */
  .section-heading h2 { font-size: clamp(1.5rem, 6vw, 1.75rem); }
  .section-heading__sub { font-size: 13px; }

  /* Materials 2-col */
  .materials { grid-template-columns: repeat(2, 1fr); gap: var(--s-12); }
  .material-card { padding: var(--s-16); }
  .material-card__name { font-size: var(--fs-14); }
  .material-card__body { font-size: 11px; }

  /* Footer 1-col on tiny screens */
  .footer-grid { grid-template-columns: 1fr; gap: var(--s-24); }
  .footer-brand { grid-column: 1; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: var(--s-4); }

  /* PDP reassurance 1-col */
  .pdp__reassurance { grid-template-columns: 1fr; gap: var(--s-8); }

  /* About story points 1-col */
  .about-story__points { grid-template-columns: 1fr; }

  /* Cart layout tighter */
  .cart__item { grid-template-columns: 72px 1fr; gap: var(--s-12); }
  .cart__thumb { width: 72px; height: 72px; }
  .cart__actions { grid-column: 2; padding-top: var(--s-4); }
}

@media (max-width: 380px) {
  .trust-strip__title { font-size: var(--fs-13); }
  .trust-strip svg { width: 22px; height: 22px; }
  .site-header__inner { padding-block: var(--s-16); gap: var(--s-8); }
  .brand__wordmark { font-size: 1.25rem; letter-spacing: 0.25em; }
  .utility-nav { gap: var(--s-4); }
  .icon-btn { width: 32px; height: 32px; }
  .icon-btn svg { width: 18px; height: 18px; }
}

/* ---------- De-stiffen: slower, softer hovers ---------- */
.btn { transition: transform var(--dur-1) var(--ease), background var(--dur-3) var(--ease), color var(--dur-3) var(--ease), border-color var(--dur-3) var(--ease), box-shadow var(--dur-3) var(--ease); }
.btn--primary:hover { box-shadow: var(--shadow-gold); }
.btn--outline:hover { box-shadow: 0 6px 18px rgba(184,147,96,0.14); }

/* ---------- Keep nav visible on iPad/tablet ---------- */
@media (min-width: 961px) and (max-width: 1100px) {
  .primary-nav { gap: 0.9rem; }
  .primary-nav a { font-size: 11px; }
}

/* ============================================================
 * WP theme supplemental styles (added for custom templates)
 * ============================================================ */

/* Hero — WP front-page variant */
.hero--grid { padding: var(--s-64) 0 var(--s-48); background: var(--pearl-cream); }
.hero__grid {
  display: grid; grid-template-columns: 1.05fr 1fr;
  gap: var(--s-48); align-items: center;
}
.hero__copy .eyebrow { margin-bottom: var(--s-16); }
.hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4.8vw, 3.4rem);
  line-height: 1.08; color: var(--stone-gray);
  font-weight: 500; letter-spacing: -0.01em;
}
.hero__sub {
  margin-top: var(--s-20); max-width: 48ch;
  color: var(--stone-gray-soft); font-size: var(--fs-16);
  line-height: 1.6;
}
.hero__ctas { display: flex; gap: var(--s-12); margin-top: var(--s-28); flex-wrap: wrap; }
.hero__marks {
  list-style: none; padding: 0; margin: var(--s-28) 0 0;
  display: flex; flex-direction: column; gap: var(--s-8);
  font-size: var(--fs-13); color: var(--stone-gray-soft);
}
.hero__marks li { display: flex; align-items: center; gap: var(--s-8); }
.hero__marks .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--champagne-gold);
}
.hero__media {
  position: relative; display: grid; grid-template-columns: 2fr 1fr;
  gap: var(--s-16); align-items: end;
}
.hero__figure {
  margin: 0; border-radius: var(--r-lg);
  overflow: hidden; background: var(--pearl-cream-deep, #F1E9D6);
  aspect-ratio: 4 / 5;
}
.hero__figure--sm { aspect-ratio: 1 / 1; align-self: center; }
.hero__figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 900px) {
  .hero__grid { grid-template-columns: 1fr; gap: var(--s-28); }
  .hero__media { max-width: 520px; margin: 0 auto; }
}

/* Trust strip top variant */
.trust-strip--top {
  padding: var(--s-14) 0;
  background: var(--muted-sage, #C9D0BE);
  color: var(--stone-gray);
  font-size: var(--fs-13);
}
.trust-strip__row {
  display: flex; flex-wrap: wrap; align-items: center;
  justify-content: center; gap: var(--s-12);
}
.trust-strip__sep { opacity: .5; }

/* Feature categories */
.feature-categories { padding: var(--s-56) 0 var(--s-32); background: var(--pearl-cream); }
.feature-categories__grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-20);
}
@media (max-width: 1100px) { .feature-categories__grid { grid-template-columns: repeat(2, 1fr); } }
.feature-card {
  display: block; text-decoration: none; color: inherit;
  border-radius: var(--r-lg); overflow: hidden;
  background: #fff; border: 1px solid rgba(168,138,75,.15);
  transition: transform .25s ease, box-shadow .25s ease;
}
.feature-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0,0,0,.06); }
.feature-card__media { aspect-ratio: 4 / 3; overflow: hidden; background: var(--pearl-cream-deep, #F1E9D6); }
.feature-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.feature-card:hover .feature-card__media img { transform: scale(1.04); }
.feature-card__body { padding: var(--s-20) var(--s-24); }
.feature-card__title {
  font-family: var(--font-display); font-size: var(--fs-20);
  margin: 0 0 var(--s-4); color: var(--stone-gray);
}
.feature-card__cta {
  display: inline-block; font-size: var(--fs-13);
  color: var(--champagne-gold-deep, #8E7438);
  letter-spacing: .08em; text-transform: uppercase;
}
@media (max-width: 700px) { .feature-categories__grid { grid-template-columns: 1fr; gap: var(--s-16); } }

/* Section heads (alias matching wp templates) */
.section-head { text-align: center; max-width: 640px; margin: 0 auto var(--s-32); }
.section-head--tight { margin-bottom: var(--s-20); }
.section-head--tight .section-head__title { font-size: clamp(1.4rem, 2.6vw, 1.9rem); }
.section-head .eyebrow { margin-bottom: var(--s-8); }
.section-head__title {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3.2vw, 2.2rem);
  color: var(--stone-gray); font-weight: 500; font-style: italic;
  letter-spacing: -0.005em; margin: 0 0 var(--s-12);
}
.section-head__sub { color: var(--stone-gray-soft); font-size: var(--fs-14); line-height: 1.6; }
.section-foot { text-align: center; margin-top: var(--s-28); }
.section-empty { text-align: center; color: var(--stone-gray-soft); padding: var(--s-32) 0; }

/* Featured pieces */
.featured-pieces { padding: var(--s-56) 0; }

/* Product card (template variant — works alongside existing .product-card rules) */
.product-card__link { display: block; color: inherit; text-decoration: none; }
.product-card__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.product-card .cad { font-size: .75em; opacity: .6; margin-left: 2px; }

/* Tagline-tile template variant */
.tagline-tile__num {
  position: relative; z-index: 1;
  font-family: var(--font-display); font-style: italic;
  color: var(--champagne-gold-deep, #8E7438);
  font-size: var(--fs-14); letter-spacing: .12em;
}
.tagline-tile__text {
  position: relative; z-index: 1; margin-top: var(--s-8);
  font-family: var(--font-display); font-size: var(--fs-18);
  color: var(--stone-gray);
}

/* Materials template variant (alongside existing .material-card) */
.materials { padding: var(--s-56) 0 var(--s-72); background: var(--pearl-cream); }
.materials__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--s-20); margin-top: var(--s-24);
}
.material {
  padding: var(--s-24); background: #fff;
  border-radius: var(--r-md);
  border: 1px solid rgba(168,138,75,.12);
}
.material__name {
  font-family: var(--font-display); font-size: var(--fs-18);
  color: var(--stone-gray); margin: 0 0 var(--s-8); font-style: italic;
}
.material__desc { color: var(--stone-gray-soft); font-size: var(--fs-13); line-height: 1.6; }
@media (max-width: 1024px) { .materials__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .materials__grid { grid-template-columns: 1fr; } }

/* Archive + page templates */
.page-body { padding: var(--s-56) 0 var(--s-72); }
.page-body__inner { max-width: 760px; margin: 0 auto; }
.page-article__head { margin-bottom: var(--s-28); text-align: center; }
.page-article__title {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(1.8rem, 3.8vw, 2.6rem);
  color: var(--stone-gray); margin: 0;
}
.page-article__content { color: var(--stone-gray-soft); line-height: 1.75; font-size: var(--fs-15); }
.page-article__content h2, .page-article__content h3 {
  font-family: var(--font-display); color: var(--stone-gray);
  margin-top: var(--s-32);
}
.page-article__content a { color: var(--champagne-gold-deep, #8E7438); }
.page-article__media { margin: var(--s-24) 0; border-radius: var(--r-lg); overflow: hidden; }
.page-article__media img { width: 100%; display: block; }
.archive-fallback { padding: var(--s-56) 0 var(--s-72); }
.post-list { display: grid; gap: var(--s-24); }
.post-item { padding: var(--s-20) 0; border-bottom: 1px solid rgba(168,138,75,.12); }
.post-item__title { font-family: var(--font-display); font-size: var(--fs-20); }
.post-item__title a { color: var(--stone-gray); text-decoration: none; }
.post-item__meta { color: var(--stone-gray-soft); font-size: var(--fs-12); margin: 4px 0 8px; }

/* WooCommerce wrapper */
.wc-wrap { padding: var(--s-40) 0 var(--s-72); }
.wc-wrap__inner .woocommerce-notices-wrapper:empty { display: none; }
.wc-wrap .woocommerce-breadcrumb { color: var(--stone-gray-soft); font-size: var(--fs-12); margin-bottom: var(--s-16); }
.wc-wrap h1.woocommerce-products-header__title,
.wc-wrap h1.product_title {
  font-family: var(--font-display); font-style: italic;
  color: var(--stone-gray); font-weight: 500;
}
.wc-wrap .woocommerce-ordering select,
.wc-wrap .woocommerce-result-count { color: var(--stone-gray-soft); }
.wc-wrap .woocommerce ul.products li.product .price,
.wc-wrap .price { color: var(--stone-gray); }
.wc-wrap .button.single_add_to_cart_button,
.wc-wrap .woocommerce #respond input#submit,
.wc-wrap .woocommerce .button.alt,
.wc-wrap .button.wp-element-button {
  background: var(--stone-gray) !important; color: var(--pearl-cream) !important;
  border: none; padding: 14px 26px; border-radius: var(--r-sm);
  letter-spacing: .1em; text-transform: uppercase; font-size: var(--fs-12);
  font-weight: 600;
}
.wc-wrap .button:hover { background: var(--champagne-gold-deep, #8E7438) !important; }

/* Cart + checkout polish */
.lg-cart .wc-wrap, .lg-checkout .wc-wrap { background: var(--pearl-cream); }
.woocommerce-cart-form { background: #fff; padding: var(--s-24); border-radius: var(--r-md); }
.woocommerce-checkout #order_review, .cart_totals {
  background: #fff; padding: var(--s-24); border-radius: var(--r-md);
  border: 1px solid rgba(168,138,75,.15);
}

/* Drawer cart count pulse */
.cart-count { background: var(--champagne-gold); }

/* ============================================================
 * Patch v3 — mobile polish, destiffened motion, category images
 * ============================================================ */

/* Announcement: defensive padding so the text never kisses the edge */
.announcement__inner {
  padding-inline: clamp(1rem, 4vw, 1.5rem);
  flex-wrap: wrap;
}
@media (max-width: 420px) {
  .announcement__inner { justify-content: center; padding-inline: 1rem; font-size: 10px; }
  .announcement__msg   { text-align: center; }
  .announcement__locale { display: none; }
}

/* Drawer close button — visible, 44x44 tap target, rotates on hover */
.drawer__head {
  position: sticky; top: 0; z-index: 2;
  background: var(--pearl-cream);
  min-height: 56px;
  padding-inline: var(--s-20);
}
.drawer [data-drawer-close] {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(168,138,75,.35);
  background: rgba(243,241,231,.7);
  color: var(--gold-deep);
  transition: background var(--dur-2) var(--ease),
              color var(--dur-2) var(--ease),
              transform var(--dur-3) var(--ease),
              border-color var(--dur-2) var(--ease);
}
.drawer [data-drawer-close]:hover {
  background: var(--champagne-gold-deep, #8E7438);
  border-color: var(--champagne-gold-deep, #8E7438);
  color: #fff;
  transform: rotate(90deg);
}
.drawer [data-drawer-close] svg { width: 18px; height: 18px; stroke-width: 2; }

/* Footer: tighter mobile layout, compressed brand, better breaks */
@media (max-width: 780px) {
  .site-footer { padding-block: var(--s-40) var(--s-16); margin-top: var(--s-40); }
  .footer-grid { gap: var(--s-24); padding-bottom: var(--s-24); }
  .footer-brand .brand__wordmark { font-size: 1.3rem; letter-spacing: 0.24em; }
  .footer-brand p { font-size: 12px; max-width: none; margin-top: var(--s-8); line-height: 1.55; }
  .footer-col h4 { margin-bottom: var(--s-8); font-size: 11px; }
  .footer-col ul { gap: 6px; }
  .footer-col li a { font-size: 12.5px; }
}
@media (max-width: 560px) {
  .site-footer { padding-block: var(--s-28) var(--s-12); margin-top: var(--s-32); }
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--s-20) var(--s-24);
    padding-bottom: var(--s-20);
  }
  .footer-brand { grid-column: span 2; text-align: left; }
  .footer-brand p { display: none; }
  .footer-brand .brand__tagline { display: block; font-size: 11px; }
  .footer-bottom { font-size: 10.5px; }
}

/* Category cards — softer, more alive motion */
.feature-card {
  transition: transform .45s cubic-bezier(.2,.6,.2,1),
              box-shadow .45s ease,
              border-color .45s ease;
  will-change: transform;
}
.feature-card:hover {
  transform: translateY(-6px);
  border-color: rgba(184,147,96,.28);
  box-shadow: 0 18px 40px rgba(34,28,18,.09);
}
.feature-card__media { position: relative; }
.feature-card__media::after {
  content: "";
  position: absolute; inset: auto 0 0 0; height: 45%;
  background: linear-gradient(180deg, rgba(34,28,18,0) 0%, rgba(34,28,18,.18) 100%);
  opacity: .55;
  transition: opacity .5s ease;
  pointer-events: none;
}
.feature-card:hover .feature-card__media::after { opacity: .28; }
.feature-card__media img {
  transition: transform .9s cubic-bezier(.2,.6,.2,1), filter .6s ease;
  filter: saturate(.96);
}
.feature-card:hover .feature-card__media img { transform: scale(1.06); filter: saturate(1.04); }
.feature-card__body { padding: var(--s-16) var(--s-20); }
.feature-card__title { font-size: var(--fs-18); }

/* Category cards — phone layout: always 2-up, never 1-up */
@media (max-width: 700px) {
  .feature-categories__grid { grid-template-columns: repeat(2, 1fr) !important; gap: var(--s-12); }
  .feature-categories { padding: var(--s-32) 0 var(--s-20); }
  .feature-card__media { aspect-ratio: 1 / 1; }
  .feature-card__body  { padding: var(--s-12) var(--s-14); }
  .feature-card__title { font-size: var(--fs-15); margin: 0; }
  .feature-card__cta   { display: none; }
}

/* WooCommerce category archive — subcategory thumbnails always visible, with motion */
.wc-wrap ul.products li.product-category {
  background: #fff;
  border-radius: var(--r-lg);
  border: 1px solid rgba(168,138,75,.15);
  overflow: hidden;
  transition: transform .45s cubic-bezier(.2,.6,.2,1), box-shadow .45s ease;
  list-style: none;
}
.wc-wrap ul.products li.product-category:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(34,28,18,.08);
}
.wc-wrap ul.products li.product-category > a {
  display: block; color: inherit; text-decoration: none;
}
.wc-wrap ul.products li.product-category img {
  width: 100% !important; height: auto !important;
  aspect-ratio: 4 / 3; object-fit: cover; display: block;
  margin: 0 !important;
  transition: transform .9s cubic-bezier(.2,.6,.2,1), filter .6s ease;
  background: var(--pearl-cream-deep, #F1E9D6);
  filter: saturate(.96);
}
.wc-wrap ul.products li.product-category:hover img { transform: scale(1.05); filter: saturate(1.05); }
.wc-wrap ul.products li.product-category h2.woocommerce-loop-category__title,
.wc-wrap ul.products li.product-category h3 {
  padding: var(--s-14) var(--s-18);
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  color: var(--stone-gray); font-size: var(--fs-18);
  background: #fff; margin: 0;
}
.wc-wrap ul.products li.product-category .count {
  color: var(--stone-gray-soft); font-size: var(--fs-12);
  letter-spacing: .06em; margin-left: .4em;
}

/* Shop/product archive — soften default WC grid hover */
.wc-wrap ul.products li.product {
  transition: transform .45s cubic-bezier(.2,.6,.2,1);
}
.wc-wrap ul.products li.product:hover { transform: translateY(-3px); }
.wc-wrap ul.products li.product img {
  transition: transform .9s cubic-bezier(.2,.6,.2,1);
}
.wc-wrap ul.products li.product:hover img { transform: scale(1.03); }

/* Gentle page-enter fade — keeps navigation from feeling abrupt */
@media (prefers-reduced-motion: no-preference) {
  body { animation: lg-fade-in .35s ease both; }
  @keyframes lg-fade-in { from { opacity: 0; } to { opacity: 1; } }
}

/* ============================================================
 * Patch v4 — layout fixes: real grid on tagline tiles, footer
 * guaranteed multi-column on mobile, materials stay 2-up.
 * ============================================================ */

/* Tagline tiles: the grid is the inner .__grid, not the section */
.tagline-tiles__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--s-12);
}
@media (max-width: 1100px) { .tagline-tiles__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px)  { .tagline-tiles__grid { grid-template-columns: repeat(2, 1fr); gap: var(--s-8); } }

/* Materials: keep 2-up on phone so the page reads as a grid, not a list */
@media (max-width: 560px) {
  .materials__grid { grid-template-columns: repeat(2, 1fr) !important; gap: var(--s-10) !important; }
  .material { padding: var(--s-14) !important; }
  .material__name { font-size: var(--fs-15) !important; }
  .material__desc { font-size: 11.5px !important; }
}

/* Footer: force 2-col on mobile and override the prior 1fr rule */
@media (max-width: 560px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: var(--s-20) var(--s-24) !important;
  }
  .footer-brand { grid-column: 1 / -1 !important; }
  .footer-brand p { display: none !important; }
}

/* Trust strip (sage) bottom: ensure it stays 2-col on phone and isn't 1-col */
@media (max-width: 560px) {
  .trust-strip--sage { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ============================================================
 * Accounts — My Account page polish
 * ============================================================ */
.lg-myaccount .wc-wrap { background: var(--pearl-cream); }
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 2px;
  background: #fff; border-radius: var(--r-md);
  border: 1px solid rgba(168,138,75,.15); overflow: hidden;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
  display: block; padding: var(--s-14) var(--s-20);
  color: var(--stone-gray); text-decoration: none;
  font-family: var(--font-sans); font-size: var(--fs-13);
  letter-spacing: .06em; text-transform: uppercase;
  border-bottom: 1px solid rgba(168,138,75,.08);
  transition: background var(--dur-2) var(--ease), color var(--dur-2) var(--ease);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover {
  background: var(--pearl-cream-soft, #FAF5EA);
  color: var(--gold-deep);
}
.woocommerce-account .woocommerce-MyAccount-content {
  background: #fff; padding: var(--s-28); border-radius: var(--r-md);
  border: 1px solid rgba(168,138,75,.15);
}
.woocommerce-account .woocommerce-form { max-width: 440px; }
.woocommerce-account .woocommerce-form__label-for-checkbox { font-size: 12.5px; }
.woocommerce-account input[type="text"],
.woocommerce-account input[type="email"],
.woocommerce-account input[type="password"] {
  width: 100%; padding: 10px 12px;
  border: 1px solid rgba(168,138,75,.25);
  border-radius: var(--r-sm);
  background: #fff; color: var(--stone-gray);
}
.woocommerce-account input:focus {
  outline: none; border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(184,147,96,.12);
}
.woocommerce-account .lost_password a { color: var(--champagne-gold-deep,#8E7438); font-size: var(--fs-13); }
.woocommerce-MyAccount-navigation-link--customer-logout a::after { content: " →"; opacity: .6; }

/* Checkout opt-in checkbox */
.lg-opt-in { margin: var(--s-14) 0 !important; }
.lg-opt-in .woocommerce-form__label-for-checkbox {
  display: flex; align-items: flex-start; gap: var(--s-8);
  font-size: 12.5px; color: var(--stone-gray-soft); line-height: 1.45;
}
.lg-opt-in input[type="checkbox"] { margin-top: 3px; accent-color: var(--gold); }

/* ============================================================
 * Newsletter signup — footer + any embedded form
 * ============================================================ */
.newsletter {
  margin-bottom: var(--s-28);
  color: #F3F1E7;
}
.newsletter__label {
  display: block;
  font-family: var(--font-sans);
  text-transform: uppercase; letter-spacing: var(--ls-wider);
  font-size: var(--fs-12); margin-bottom: var(--s-10);
  color: rgba(243,241,231,0.85);
}
.newsletter__row {
  display: flex; gap: 8px; flex-wrap: wrap;
  background: rgba(255,255,255,0.06);
  border-radius: var(--r-pill);
  padding: 6px 6px 6px 16px;
  border: 1px solid rgba(243,241,231,0.18);
  transition: border-color var(--dur-2) var(--ease), background var(--dur-2) var(--ease);
  max-width: 420px;
}
.newsletter__row:focus-within {
  border-color: var(--gold-soft);
  background: rgba(255,255,255,0.08);
}
.newsletter__row input[type="email"] {
  flex: 1 1 180px; min-width: 0;
  background: transparent; border: 0; outline: 0;
  color: #F3F1E7; font-size: var(--fs-14);
  padding: 8px 0;
}
.newsletter__row input[type="email"]::placeholder { color: rgba(243,241,231,0.55); }
.newsletter__row button {
  background: var(--champagne-gold-deep, #8E7438);
  border: 0; border-radius: var(--r-pill);
  color: #fff; font-size: 11.5px;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 10px 18px; cursor: pointer;
  transition: background var(--dur-2) var(--ease), transform var(--dur-2) var(--ease);
}
.newsletter__row button:hover { background: var(--gold-deep); transform: translateY(-1px); }
.newsletter__note {
  margin-top: var(--s-8); font-size: 11px;
  color: rgba(243,241,231,0.55); letter-spacing: .04em;
}
.newsletter.is-success .newsletter__row { opacity: .65; }
.newsletter__status {
  font-size: 12px; margin-top: var(--s-8); color: var(--gold-soft);
  min-height: 1em;
}
.newsletter__status.is-error { color: #E8A4A4; }

@media (max-width: 560px) {
  .newsletter { margin-bottom: var(--s-20); }
  .newsletter__row { padding: 4px 4px 4px 14px; }
  .newsletter__row button { padding: 8px 14px; font-size: 10.5px; }
}

/* Header: account icon tooltip */
.site-header__inner .utility-nav a[aria-label="Account"] svg { stroke: currentColor; }

/* ============================================================
 * Patch v6 — structural fixes
 *   (1) section.tagline-tiles and section.materials had
 *       `display:grid; grid-template-columns: repeat(N, 1fr)`
 *       applied at the SECTION level. But each section contains
 *       a single `.container` child that wraps the real grid.
 *       That meant the container was being placed in a single
 *       grid track (1/N of the viewport), squashing tiles to
 *       one edge of the screen. Fix: reset those sections to
 *       block flow so the container expands normally and the
 *       inner `.__grid` does the real layout.
 *   (2) `.product-card__media` is a <span> in the WooCommerce
 *       loop template; inline elements ignore `aspect-ratio`,
 *       so the box collapsed to 0px and the absolutely-
 *       positioned <img> inside rendered invisibly. Force
 *       display:block so the aspect-ratio + absolute image
 *       actually lay out.
 *   (3) WooCommerce's default `ul.products` gets a clean
 *       responsive grid that matches the custom product-grid.
 * ============================================================ */
.tagline-tiles { display: block !important; padding-block: clamp(2rem, 5vw, var(--s-64)); }
.materials     { display: block !important; padding-block: clamp(3rem, 6vw, var(--s-96)); }

/* Real product image layout */
.product-card__media {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
}
.product-card__media--img {
  display: block !important;
  position: relative;
  overflow: hidden;
}
.product-card__media--img img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

/* WooCommerce loop (ul.products) grid — needed on shop + archive pages */
.woocommerce ul.products,
ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-24) var(--s-20);
  list-style: none;
  padding: 0;
  margin: 0 0 var(--s-24);
}
.woocommerce ul.products li.product,
ul.products li.product {
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  list-style: none !important;
}
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
  display: block;
  color: inherit;
  text-decoration: none;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-serif);
  font-size: var(--fs-16);
  color: var(--stone-gray);
  letter-spacing: 0.005em;
  padding: 0;
  margin: var(--s-10) 0 0;
}
.woocommerce ul.products li.product .product-card__price {
  margin-top: var(--s-4);
  padding-bottom: var(--s-6);
}
.woocommerce ul.products li.product .button,
ul.products li.product .button {
  display: inline-block;
  margin-top: var(--s-8);
  padding: 8px 14px;
  font-size: 11.5px;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  background: var(--pearl-cream-soft);
  color: var(--stone-gray);
  border: 1px solid var(--gold-line);
  border-radius: var(--r-sm);
  transition: background var(--dur-2) var(--ease), color var(--dur-2) var(--ease);
}
.woocommerce ul.products li.product .button:hover,
ul.products li.product .button:hover {
  background: var(--gold);
  color: #fff;
  border-color: var(--gold);
}
@media (max-width: 1100px) {
  .woocommerce ul.products,
  ul.products { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 820px) {
  .woocommerce ul.products,
  ul.products { grid-template-columns: repeat(2, 1fr); gap: var(--s-16) var(--s-12); }
}

/* Tagline tiles: make sure the old inner rules don't fight the v4 grid */
@media (max-width: 560px) {
  .tagline-tiles__grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--s-8) !important;
  }
  .tagline-tile {
    aspect-ratio: 1 / 1;
    padding: var(--s-8) !important;
  }
  .tagline-tile__label {
    font-size: 10.5px !important;
    padding: 6px 8px !important;
    line-height: 1.25;
  }
}

/* Mobile-safe overflow guard */
html, body { overflow-x: hidden; }

