/* ============================================================
   LEHAZ — Main Stylesheet
   Brand: cream, dark-brown, rose-gold
   Approach: mobile-first, custom properties
   ============================================================ */

/* ── Custom Properties ─────────────────────────────────────── */
:root {
  --cream:           #F2EDE7;
  --cream-dark:      #E5DDD4;
  --dark-brown:      #3D2A1E;
  --mid-brown:       #5C3D2E;
  --rose-gold:       #B8865C;
  --rose-gold-light: #D4A574;
  --rose-gold-pale:  #E8C9A8;
  --text-dark:       #2A1F16;
  --text-light:      #E8D5C0;
  --border:          rgba(184, 134, 92, 0.25);
  --shadow:          0 4px 40px rgba(61, 42, 30, 0.08);
  --shadow-lg:       0 12px 60px rgba(61, 42, 30, 0.15);
  --radius:          2px;
  --transition:      0.3s ease;
  --transition-slow: 0.6s ease;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Montserrat', -apple-system, sans-serif;

  --nav-h: 72px;
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  background:   var(--cream);
  color:        var(--text-dark);
  font-family:  var(--font-body);
  font-weight:  300;
  line-height:  1.7;
  overflow-x:   hidden;
}

img { display: block; max-width: 100%; height: auto; }
a  { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, select, textarea { font-family: inherit; }
ul { list-style: none; }

/* ── Typography ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5 {
  font-family:    var(--font-display);
  font-weight:    400;
  line-height:    1.15;
  letter-spacing: 0.04em;
}

.display {
  font-family:    var(--font-display);
  font-size:      clamp(3rem, 10vw, 7rem);
  font-weight:    300;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  line-height:    1;
}

.label {
  font-family:    var(--font-body);
  font-size:      0.65rem;
  font-weight:    500;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}

/* ── Layout ─────────────────────────────────────────────────── */
.container {
  width:   100%;
  max-width: 1280px;
  margin:  0 auto;
  padding: 0 1.5rem;
}

.section { padding: 5rem 0; }
.section--sm { padding: 3rem 0; }
.section--lg { padding: 8rem 0; }

/* ── Flash Messages ─────────────────────────────────────────── */
.flash {
  position:   fixed;
  top:        1rem;
  right:      1rem;
  z-index:    9999;
  padding:    1rem 3rem 1rem 1.25rem;
  border-radius: var(--radius);
  font-size:  0.85rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  box-shadow: var(--shadow-lg);
  animation:  slideIn 0.3s ease;
}
.flash--success { background: var(--dark-brown); color: var(--cream-text, var(--text-light)); }
.flash--error   { background: #7a2323; color: #ffdede; }
.flash__close {
  position:  absolute;
  right:     0.75rem;
  top:       50%;
  transform: translateY(-50%);
  font-size: 1.2rem;
  opacity:   0.7;
  color:     inherit;
}
@keyframes slideIn { from { opacity: 0; transform: translateX(1rem); } to { opacity: 1; transform: none; } }

/* ── Navigation ─────────────────────────────────────────────── */
.nav {
  position:   fixed;
  top:        0;
  left:       0;
  right:      0;
  z-index:    1000;
  height:     var(--nav-h);
  transition: background var(--transition), box-shadow var(--transition);
}
.nav.scrolled {
  background:  var(--cream);
  box-shadow:  0 1px 0 var(--border);
}
.nav.nav--dark { background: var(--dark-brown); }
.nav.nav--dark .nav__logo,
.nav.nav--dark .nav__links a,
.nav.nav--dark .nav__cart { color: var(--text-light); }

.nav__inner {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  height:          100%;
  padding:         0 2rem;
}

.nav__logo {
  font-family:    var(--font-body);
  font-size:      1rem;
  font-weight:    400;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color:          var(--text-dark);
  transition:     color var(--transition);
  flex-shrink:    0;
}

.nav__links {
  display: flex;
  gap:     2.5rem;
}
.nav__links a {
  font-size:      0.7rem;
  font-weight:    500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color:          var(--text-dark);
  position:       relative;
  transition:     color var(--transition);
}
.nav__links a::after {
  content:    '';
  position:   absolute;
  bottom:     -3px;
  left:       0;
  width:      0;
  height:     1px;
  background: var(--rose-gold);
  transition: width var(--transition);
}
.nav__links a:hover::after { width: 100%; }
.nav__links a:hover { color: var(--rose-gold); }

.nav__cart {
  position: relative;
  color:    var(--text-dark);
  padding:  0.5rem;
  transition: color var(--transition);
}
.nav__cart:hover { color: var(--rose-gold); }
.nav__cart-count {
  position:    absolute;
  top:         -2px;
  right:       -4px;
  background:  var(--rose-gold);
  color:       #fff;
  width:       18px;
  height:      18px;
  border-radius: 50%;
  font-size:   0.6rem;
  font-weight: 600;
  display:     flex;
  align-items: center;
  justify-content: center;
  opacity:     0;
  transform:   scale(0.8);
  transition:  opacity var(--transition), transform var(--transition);
}
.nav__cart-count:not(:empty) { opacity: 1; transform: scale(1); }

.nav__burger {
  display:        none;
  flex-direction: column;
  gap:            5px;
  padding:        0.5rem;
}
.nav__burger span {
  display:    block;
  width:      22px;
  height:     1.5px;
  background: currentColor;
  transition: var(--transition);
}

/* ── Cart Drawer ─────────────────────────────────────────────── */
.cart-overlay {
  position:   fixed;
  inset:      0;
  background: rgba(42, 31, 22, 0.5);
  z-index:    1100;
  opacity:    0;
  pointer-events: none;
  transition: opacity var(--transition);
}
.cart-overlay.active { opacity: 1; pointer-events: all; }

.cart-drawer {
  position:   fixed;
  top:        0;
  right:      0;
  bottom:     0;
  width:      min(420px, 95vw);
  background: var(--cream);
  z-index:    1200;
  transform:  translateX(100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  display:    flex;
  flex-direction: column;
  overflow:   hidden;
}
.cart-drawer.open { transform: translateX(0); }

.cart-drawer__header {
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  padding:         1.75rem 1.5rem;
  border-bottom:   1px solid var(--border);
}
.cart-drawer__header h3 {
  font-family:    var(--font-body);
  font-size:      0.7rem;
  font-weight:    500;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}
.cart-drawer__close {
  font-size: 1.5rem;
  opacity:   0.5;
  transition: opacity var(--transition);
}
.cart-drawer__close:hover { opacity: 1; }

.cart-drawer__items {
  flex:       1;
  overflow-y: auto;
  padding:    1.5rem;
  display:    flex;
  flex-direction: column;
  gap:        1.25rem;
}

.cart-item {
  display: flex;
  gap:     1rem;
}
.cart-item__img {
  width:     80px;
  height:    100px;
  object-fit: cover;
  background: var(--cream-dark);
  flex-shrink: 0;
}
.cart-item__info { flex: 1; }
.cart-item__name {
  font-family:    var(--font-display);
  font-size:      1.05rem;
  margin-bottom:  0.2rem;
}
.cart-item__meta {
  font-size:      0.7rem;
  letter-spacing: 0.1em;
  color:          var(--rose-gold);
  text-transform: uppercase;
  margin-bottom:  0.5rem;
}
.cart-item__actions {
  display:     flex;
  align-items: center;
  gap:         0.75rem;
}
.cart-item__qty {
  display:     flex;
  align-items: center;
  gap:         0.5rem;
  border:      1px solid var(--border);
}
.cart-item__qty button {
  width:     28px;
  height:    28px;
  display:   flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  transition: background var(--transition);
}
.cart-item__qty button:hover { background: var(--cream-dark); }
.cart-item__qty span {
  min-width:  1.5rem;
  text-align: center;
  font-size:  0.85rem;
}
.cart-item__remove {
  font-size:  0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:      var(--rose-gold);
  margin-left: auto;
}
.cart-item__price {
  font-family: var(--font-display);
  font-size:   1.1rem;
  font-weight: 500;
}

.cart-empty {
  text-align: center;
  padding:    3rem 1rem;
  color:      rgba(42,31,22,0.4);
}
.cart-empty svg { margin: 0 auto 1rem; opacity: 0.3; }
.cart-empty p {
  font-size:      0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.cart-drawer__footer {
  border-top: 1px solid var(--border);
  padding:    1.5rem;
}
.cart-totals {
  margin-bottom: 1.25rem;
}
.cart-totals__row {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  font-size:       0.8rem;
  letter-spacing:  0.05em;
  padding:         0.4rem 0;
}
.cart-totals__row--total {
  font-family:  var(--font-display);
  font-size:    1.3rem;
  border-top:   1px solid var(--border);
  margin-top:   0.5rem;
  padding-top:  0.75rem;
}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  gap:             0.5rem;
  padding:         0.9rem 2rem;
  font-family:     var(--font-body);
  font-size:       0.65rem;
  font-weight:     500;
  letter-spacing:  0.2em;
  text-transform:  uppercase;
  border-radius:   var(--radius);
  transition:      var(--transition);
  cursor:          pointer;
  white-space:     nowrap;
}
.btn--primary {
  background: var(--dark-brown);
  color:      var(--text-light);
  border:     1px solid var(--dark-brown);
}
.btn--primary:hover {
  background: var(--mid-brown);
  border-color: var(--mid-brown);
}
.btn--gold {
  background: var(--rose-gold);
  color:      #fff;
  border:     1px solid var(--rose-gold);
}
.btn--gold:hover {
  background: var(--rose-gold-light);
  border-color: var(--rose-gold-light);
}
.btn--outline {
  background:   transparent;
  color:        var(--text-dark);
  border:       1px solid var(--text-dark);
}
.btn--outline:hover {
  background: var(--text-dark);
  color:      var(--cream);
}
.btn--outline-light {
  background:  transparent;
  color:       var(--text-light);
  border:      1px solid rgba(232,213,192,0.4);
}
.btn--outline-light:hover {
  background:  rgba(232,213,192,0.15);
  border-color: var(--text-light);
}
.btn--full { width: 100%; }
.btn--lg { padding: 1.1rem 2.5rem; font-size: 0.7rem; }
.btn--whatsapp {
  background:  #25D366;
  color:       #fff;
  border:      1px solid #25D366;
}
.btn--whatsapp:hover { background: #1fb855; }

/* ── Hero ────────────────────────────────────────────────────── */
.hero {
  min-height: 100vh;
  position:   relative;
  display:    grid;
  grid-template-rows: 1fr 1fr;
  overflow:   hidden;
}
.hero__top {
  background:  var(--cream);
  display:     flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding:     4rem 2rem 3rem;
  position:    relative;
}
.hero__bottom {
  background:  var(--dark-brown);
  display:     flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding:     3rem 2rem 5rem;
  position:    relative;
}
.hero__logo {
  font-family:    var(--font-body);
  font-size:      clamp(2.5rem, 10vw, 7rem);
  font-weight:    300;
  letter-spacing: clamp(0.1em, 3vw,0.45em);
  text-transform: uppercase;
  color:          var(--rose-gold);
  line-height:    1;
  padding-left:   clamp(0.1em, 3vw,0.45em); /* compensate letter-spacing on last char */
}
.hero__tagline {
  font-size:      0.65rem;
  font-weight:    400;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color:          var(--text-light);
  margin-top:     1.5rem;
}
.hero__divider {
  width:      40px;
  height:     1px;
  background: var(--rose-gold);
  margin:     1.5rem auto;
}
.hero__sub {
  font-family:    var(--font-display);
  font-size:      clamp(1rem, 3vw, 1.4rem);
  font-style:     italic;
  color:          var(--text-light);
  text-align:     center;
  margin-bottom:  2rem;
}
.hero__cta { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; }

/* Full-image hero variant */
.hero--image {
  grid-template-rows: 1fr;
  min-height:         60vh;
}
.hero__media {
  position:   absolute;
  inset:      0;
  object-fit: cover;
  width:      100%;
  height:     100%;
}
.hero__overlay {
  position:    absolute;
  inset:       0;
  background:  linear-gradient(to bottom, rgba(61,42,30,0.3) 0%, rgba(61,42,30,0.7) 100%);
}
.hero__content {
  position:       relative;
  z-index:        1;
  display:        flex;
  flex-direction: column;
  align-items:    center;
  justify-content: center;
  text-align:     center;
  padding:        6rem 2rem 4rem;
  color:          var(--text-light);
}

/* ── Product Grid ────────────────────────────────────────────── */
.section-header {
  text-align:    center;
  margin-bottom: 3rem;
}
.section-header .label { color: var(--rose-gold); margin-bottom: 0.75rem; display: block; }
.section-header h2 {
  font-family: var(--font-display);
  font-size:   clamp(2rem, 5vw, 3.5rem);
}
.section-header p {
  margin-top: 1rem;
  font-size:  0.85rem;
  opacity:    0.7;
  max-width:  500px;
  margin-left: auto;
  margin-right: auto;
}

.product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap:     2rem;
}

.product-card {
  position:   relative;
  cursor:     pointer;
  transition: transform var(--transition);
}
.product-card:hover { transform: translateY(-4px); }

.product-card__media {
  position:     relative;
  aspect-ratio: 3/4;
  overflow:     hidden;
  background:   var(--cream-dark);
  margin-bottom: 1rem;
}
.product-card__img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.product-card:hover .product-card__img { transform: scale(1.04); }

.product-card__badge {
  position:   absolute;
  top:        1rem;
  left:       1rem;
  background: var(--dark-brown);
  color:      var(--text-light);
  padding:    0.3rem 0.75rem;
  font-size:  0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.product-card__quick-add {
  position:   absolute;
  bottom:     0;
  left:       0;
  right:      0;
  background: rgba(61,42,30,0.9);
  color:      var(--text-light);
  padding:    0.9rem;
  font-size:  0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  text-align:  center;
  transform:   translateY(100%);
  transition:  transform 0.3s ease;
}
.product-card:hover .product-card__quick-add { transform: translateY(0); }

.product-card__collection {
  font-size:      0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  0.25rem;
}
.product-card__name {
  font-family:   var(--font-display);
  font-size:     1.3rem;
  margin-bottom: 0.25rem;
}
.product-card__price {
  font-family: var(--font-body);
  font-size:   0.85rem;
  font-weight: 500;
  color:       var(--mid-brown);
}
.product-card__compare {
  text-decoration: line-through;
  opacity:         0.5;
  margin-left:     0.5rem;
}

/* ── Product Detail ──────────────────────────────────────────── */
.product-detail {
  display:  grid;
  gap:      3rem;
  padding-top: calc(var(--nav-h) + 2rem);
}
@media (min-width: 768px) {
  .product-detail { grid-template-columns: 1fr 1fr; }
  .product-gallery { position: sticky; top: calc(var(--nav-h) + 2rem); }
}

.product-gallery { height: fit-content; }
.product-gallery__main {
  aspect-ratio: 3/4;
  overflow:     hidden;
  background:   var(--cream-dark);
  margin-bottom: 0.75rem;
}
.product-gallery__main img { width: 100%; height: 100%; object-fit: cover; }
.product-gallery__thumbs { display: flex; gap: 0.5rem; }
.product-gallery__thumb {
  width:      70px;
  height:     88px;
  object-fit: cover;
  background: var(--cream-dark);
  cursor:     pointer;
  opacity:    0.6;
  transition: opacity var(--transition);
  border:     1.5px solid transparent;
}
.product-gallery__thumb.active,
.product-gallery__thumb:hover { opacity: 1; border-color: var(--rose-gold); }

.product-info { padding: 1rem 0; }
.product-info__collection {
  font-size:      0.65rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  0.5rem;
}
.product-info__name {
  font-family: var(--font-display);
  font-size:   clamp(2rem, 4vw, 3rem);
  margin-bottom: 0.75rem;
}
.product-info__price {
  font-size:     1.5rem;
  font-family:   var(--font-display);
  color:         var(--mid-brown);
  margin-bottom: 2rem;
}
.product-info__divider {
  width:      50px;
  height:     1px;
  background: var(--border);
  margin:     1.5rem 0;
}
.product-info__desc {
  font-size:   0.875rem;
  line-height: 1.8;
  opacity:     0.8;
  margin-bottom: 2rem;
}

/* Colour Swatches */
.option-label {
  font-size:      0.65rem;
  font-weight:    500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom:  0.75rem;
  display:        block;
}
.option-label span { color: var(--rose-gold); font-weight: 600; }

.color-swatches { display: flex; gap: 0.5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.color-swatch {
  width:       32px;
  height:      32px;
  border-radius: 50%;
  cursor:      pointer;
  border:      2px solid transparent;
  box-shadow:  0 0 0 1px var(--border);
  transition:  var(--transition);
  position:    relative;
}
.color-swatch.active { box-shadow: 0 0 0 2px var(--rose-gold); }
.color-swatch[data-color="White"] { background: #F5F5F5; }

/* Size Selector */
.size-options { display: flex; gap: 0.5rem; margin-bottom: 2rem; flex-wrap: wrap; }
.size-btn {
  min-width:    52px;
  height:       48px;
  border:       1px solid var(--border);
  font-size:    0.7rem;
  font-weight:  500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition:   var(--transition);
  padding:      0 0.75rem;
}
.size-btn:hover       { border-color: var(--rose-gold); color: var(--rose-gold); }
.size-btn.active      { background: var(--dark-brown); color: var(--text-light); border-color: var(--dark-brown); }
.size-btn.out-of-stock { opacity: 0.35; cursor: not-allowed; text-decoration: line-through; }

.product-add-form { display: flex; flex-direction: column; gap: 0.75rem; }

/* ── Market Banner ───────────────────────────────────────────── */
.market-banner {
  background: var(--dark-brown);
  color:      var(--text-light);
  padding:    5rem 2rem;
}
.market-banner__inner {
  max-width: 900px;
  margin:    0 auto;
  display:   grid;
  gap:       2.5rem;
}
@media (min-width: 768px) {
  .market-banner__inner { grid-template-columns: 1fr auto; align-items: center; }
}
.market-banner__title {
  font-family:    var(--font-body);
  font-size:      0.65rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  0.75rem;
}
.market-banner__heading {
  font-family: var(--font-display);
  font-size:   clamp(1.8rem, 4vw, 3rem);
  margin-bottom: 0.75rem;
}
.market-banner__sub { font-size: 0.85rem; opacity: 0.7; }

.market-info-card {
  background:    rgba(232,213,192,0.08);
  border:        1px solid rgba(232,213,192,0.15);
  border-radius: var(--radius);
  padding:       2rem;
  min-width:     280px;
}
.market-info-row {
  display:     flex;
  align-items: center;
  gap:         1rem;
  padding:     0.75rem 0;
  border-bottom: 1px solid rgba(232,213,192,0.1);
}
.market-info-row:last-child { border-bottom: none; padding-bottom: 0; }
.market-info-row svg { opacity: 0.6; flex-shrink: 0; }
.market-info-row span {
  font-size:      0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

/* ── Collections Grid ────────────────────────────────────────── */
.collections-grid {
  display: grid;
  gap:     2px;
}
@media (min-width: 640px) {
  .collections-grid { grid-template-columns: 1fr 1fr; }
}
.collection-card {
  position:     relative;
  aspect-ratio: 4/5;
  overflow:     hidden;
  display:      flex;
  align-items:  flex-end;
}
.collection-card__bg {
  display:    block;
  position:   absolute;
  inset:      0;
  object-fit: cover;
  width:      100%;
  height:     100%;
  transition: transform var(--transition-slow);
}
.collection-card:hover .collection-card__bg { transform: scale(1.05); }
.collection-card__overlay {
  position:    absolute;
  inset:       0;
  background:  linear-gradient(to top, rgba(42,31,22,0.8) 0%, transparent 60%);
}
.collection-card__content {
  position:    relative;
  z-index:     1;
  padding:     2.5rem;
  color:       var(--text-light);
}
.collection-card__label {
  font-size:      0.6rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color:          var(--rose-gold-pale);
  margin-bottom:  0.5rem;
}
.collection-card__name {
  font-family: var(--font-display);
  font-size:   2.5rem;
  letter-spacing: 0.1em;
  margin-bottom: 1rem;
}

/* ── Cart Page ───────────────────────────────────────────────── */
.cart-page {
  padding-top: calc(var(--nav-h) + 3rem);
  min-height:  80vh;
}
.cart-page__layout {
  display: grid;
  gap:     3rem;
}
@media (min-width: 900px) {
  .cart-page__layout { grid-template-columns: 1fr 360px; align-items: start; }
}
.cart-page__items { display: flex; flex-direction: column; gap: 0; }
.cart-page__item {
  display:       grid;
  grid-template-columns: 100px 1fr auto;
  gap:           1.5rem;
  align-items:   start;
  padding:       1.5rem 0;
  border-bottom: 1px solid var(--border);
}
.cart-page__item-img {
  aspect-ratio: 3/4;
  object-fit:   cover;
  background:   var(--cream-dark);
  width:        100%;
}
.cart-page__item-name {
  font-family: var(--font-display);
  font-size:   1.4rem;
  margin-bottom: 0.25rem;
}
.cart-page__item-meta {
  font-size:      0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  1rem;
}
.cart-page__summary {
  background:    var(--dark-brown);
  color:         var(--text-light);
  padding:       2.5rem;
  position:      sticky;
  top:           calc(var(--nav-h) + 2rem);
}
.cart-page__summary h3 {
  font-family:    var(--font-body);
  font-size:      0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border-bottom:  1px solid rgba(232,213,192,0.15);
  padding-bottom: 1rem;
  margin-bottom:  1.5rem;
}
.summary-row {
  display:         flex;
  justify-content: space-between;
  font-size:       0.85rem;
  padding:         0.6rem 0;
  opacity:         0.8;
}
.summary-row--total {
  font-family:   var(--font-display);
  font-size:     1.6rem;
  opacity:       1;
  border-top:    1px solid rgba(232,213,192,0.15);
  margin-top:    0.5rem;
  padding-top:   1rem;
}
.shipping-note {
  font-size:   0.7rem;
  opacity:     0.6;
  text-align:  center;
  margin:      1rem 0;
  letter-spacing: 0.05em;
}

/* ── Checkout ────────────────────────────────────────────────── */
.checkout-page {
  padding-top: calc(var(--nav-h) + 3rem);
  min-height:  80vh;
}
.checkout-layout {
  display: grid;
  gap:     3rem;
}
@media (min-width: 900px) {
  .checkout-layout { grid-template-columns: 1fr 400px; align-items: start; }
}

.form-section {
  background:    #fff;
  border:        1px solid var(--border);
  padding:       2rem;
  margin-bottom: 1.5rem;
}
.form-section h3 {
  font-family:    var(--font-body);
  font-size:      0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom:  1.5rem;
  padding-bottom: 1rem;
  border-bottom:  1px solid var(--border);
}

.form-row { display: grid; gap: 1rem; margin-bottom: 1rem; }
@media (min-width: 480px) { .form-row--2 { grid-template-columns: 1fr 1fr; } }

.form-group { display: flex; flex-direction: column; gap: 0.4rem; }
.form-group label {
  font-size:      0.65rem;
  font-weight:    500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color:          var(--mid-brown);
}
.form-group input,
.form-group select,
.form-group textarea {
  padding:       0.8rem 1rem;
  border:        1px solid var(--border);
  border-radius: var(--radius);
  font-size:     0.9rem;
  background:    var(--cream);
  transition:    border-color var(--transition);
  outline:       none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color: var(--rose-gold); }
.form-group textarea { resize: vertical; min-height: 80px; }

.delivery-options { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
.delivery-option {
  border:    1px solid var(--border);
  padding:   1rem;
  cursor:    pointer;
  text-align: center;
  transition: var(--transition);
}
.delivery-option input { display: none; }
.delivery-option.selected { border-color: var(--rose-gold); background: rgba(184,134,92,0.05); }
.delivery-option__title {
  font-size:      0.65rem;
  font-weight:    600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom:  0.25rem;
}
.delivery-option__price { color: var(--rose-gold); font-size: 0.8rem; }

/* Order Summary sidebar */
.order-summary {
  background: var(--cream-dark);
  padding:    2rem;
  position:   sticky;
  top:        calc(var(--nav-h) + 2rem);
}
.order-summary h3 {
  font-family:    var(--font-body);
  font-size:      0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom:  1.5rem;
  border-bottom:  1px solid var(--border);
  padding-bottom: 0.75rem;
}
.order-summary-item {
  display:       flex;
  gap:           1rem;
  padding:       0.75rem 0;
  border-bottom: 1px solid var(--border);
  font-size:     0.85rem;
}
.order-summary-item__img {
  width:       60px;
  height:      75px;
  object-fit:  cover;
  background:  var(--cream-dark);
  flex-shrink: 0;
}
.order-summary-item__name { font-family: var(--font-display); font-size: 1rem; }
.order-summary-item__meta { font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--rose-gold); }

/* ── About Page ──────────────────────────────────────────────── */
.about-hero {
  background: var(--dark-brown);
  color:      var(--text-light);
  padding:    calc(var(--nav-h) + 5rem) 2rem 6rem;
  text-align: center;
}
.about-hero .display { color: var(--rose-gold-pale); }
.about-story {
  display: grid;
  gap:     4rem;
  padding: 5rem 0;
}
@media (min-width: 768px) {
  .about-story { grid-template-columns: 1fr 1fr; align-items: center; }
}
.about-story__img {
  aspect-ratio: 3/4;
  object-fit:   cover;
  width:        100%;
  background:   var(--cream-dark);
}
.about-story__text h2 {
  font-family: var(--font-display);
  font-size:   clamp(2rem, 4vw, 3rem);
  margin-bottom: 1.5rem;
}
.about-story__text p { font-size: 0.9rem; line-height: 1.9; opacity: 0.8; margin-bottom: 1.25rem; }
.values-grid {
  display: grid;
  gap:     2rem;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}
.value-card {
  text-align: center;
  padding:    2rem 1.5rem;
  border:     1px solid var(--border);
}
.value-card__icon { font-size: 2rem; margin-bottom: 1rem; }
.value-card__title {
  font-size:      0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  0.5rem;
}
.value-card p { font-size: 0.83rem; opacity: 0.7; }

/* ── Contact ─────────────────────────────────────────────────── */
.contact-page {
  padding-top: calc(var(--nav-h) + 3rem);
  min-height:  80vh;
}
.contact-layout {
  display: grid;
  gap:     3rem;
  padding: 3rem 0 5rem;
}
@media (min-width: 768px) {
  .contact-layout { grid-template-columns: 1fr 1fr; }
}
.contact-info__item {
  display:    flex;
  gap:        1rem;
  padding:    1.25rem 0;
  border-bottom: 1px solid var(--border);
}
.contact-info__item svg { color: var(--rose-gold); flex-shrink: 0; margin-top: 0.15rem; }
.contact-info__label {
  font-size:      0.65rem;
  font-weight:    500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  0.25rem;
}
.contact-info__value { font-size: 0.9rem; }

/* ── Shop Page ───────────────────────────────────────────────── */
.shop-header {
  background: var(--dark-brown);
  color:      var(--text-light);
  padding:    calc(var(--nav-h) + 3rem) 2rem 3rem;
  text-align: center;
}
.shop-filters {
  display:      flex;
  gap:          0.5rem;
  margin:       2.5rem 0;
  flex-wrap:    wrap;
  justify-content: center;
}
.filter-btn {
  padding:        0.6rem 1.5rem;
  font-size:      0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border:         1px solid var(--border);
  background:     transparent;
  transition:     var(--transition);
  cursor:         pointer;
}
.filter-btn.active,
.filter-btn:hover { background: var(--dark-brown); color: var(--text-light); border-color: var(--dark-brown); }

/* ── Footer ──────────────────────────────────────────────────── */
.footer {
  background: var(--dark-brown);
  color:      var(--text-light);
  padding:    5rem 2rem 2rem;
}
.footer__inner {
  display:     grid;
  gap:         3rem;
  max-width:   1280px;
  margin:      0 auto;
  padding-bottom: 4rem;
  border-bottom:  1px solid rgba(232,213,192,0.1);
}
@media (min-width: 640px) { .footer__inner { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .footer__inner { grid-template-columns: 2fr 1fr 1fr 1.5fr; } }

.footer__logo {
  font-family:    var(--font-body);
  font-size:      1.4rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  1rem;
}
.footer__tagline { font-size: 0.85rem; opacity: 0.6; line-height: 1.8; margin-bottom: 1.5rem; }
.footer__social { display: flex; gap: 1rem; }
.footer__social a { opacity: 0.6; transition: opacity var(--transition); }
.footer__social a:hover { opacity: 1; }

.footer__links h4 {
  font-family:    var(--font-body);
  font-size:      0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  1.25rem;
}
.footer__links a {
  display:    block;
  font-size:  0.83rem;
  opacity:    0.6;
  margin-bottom: 0.6rem;
  transition: opacity var(--transition);
}
.footer__links a:hover { opacity: 1; }

.footer__market h4 {
  font-family:    var(--font-body);
  font-size:      0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color:          var(--rose-gold);
  margin-bottom:  1.25rem;
}
.footer__market-card {
  border:   1px solid rgba(232,213,192,0.15);
  padding:  1.25rem;
  font-size: 0.83rem;
  line-height: 1.8;
  opacity:  0.7;
}
.footer__market-card strong { color: var(--rose-gold-pale); opacity: 1; }

.footer__bottom {
  display:     flex;
  justify-content: space-between;
  flex-wrap:   wrap;
  gap:         0.5rem;
  padding-top: 2rem;
  max-width:   1280px;
  margin:      0 auto;
  font-size:   0.72rem;
  opacity:     0.4;
}

/* ── Utility ─────────────────────────────────────────────────── */
.text-center { text-align: center; }
.text-gold { color: var(--rose-gold); }
.text-light { color: var(--text-light); }
.mt-1 { margin-top: 1rem; }
.mt-2 { margin-top: 2rem; }
.mt-3 { margin-top: 3rem; }
.mb-2 { margin-bottom: 2rem; }
.page-top { padding-top: calc(var(--nav-h) + 3rem); }

.divider {
  width:     40px;
  height:    1px;
  background: var(--rose-gold);
  margin:    1.5rem auto;
}
.divider--left { margin-left: 0; }

/* ── Price List Block (from brand reference) ─────────────────── */
.price-list {
  background: var(--dark-brown);
  color:      var(--text-light);
  padding:    4rem 2rem;
}
.price-list__collection {
  font-family:    var(--font-body);
  font-size:      0.65rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color:          var(--rose-gold-pale);
  text-align:     center;
  margin:         2.5rem 0 0.25rem;
}
.price-list__divider { width: 50px; height: 1px; background: rgba(232,213,192,0.2); margin: 0.75rem auto 1.5rem; }
.price-list__item {
  display:       flex;
  align-items:   center;
  padding:       0.85rem 0;
  border-bottom: 1px solid rgba(232,213,192,0.08);
  max-width:     480px;
  margin:        0 auto;
}
.price-list__item-name {
  font-size:      0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  flex:           1;
}
.price-list__item-dots { flex: 1; border-bottom: 1px dashed rgba(232,213,192,0.2); margin: 0 1rem; }
.price-list__item-price {
  font-family:  var(--font-display);
  font-size:    1.1rem;
  color:        var(--rose-gold-pale);
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 768px) {
  .nav__links {
    position:   fixed;
    top:        var(--nav-h);
    left:       0;
    right:      0;
    background: var(--cream);
    flex-direction: column;
    gap:        0;
    transform:  translateY(-100%);
    opacity:    0;
    pointer-events: none;
    transition: transform var(--transition), opacity var(--transition);
    border-bottom: 1px solid var(--border);
    padding:    1.5rem 2rem;
    box-shadow: var(--shadow);
    z-index:    999;
  }
  .nav__links.open { transform: translateY(0); opacity: 1; pointer-events: all; }
  .nav__links a {
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border);
  }
  .nav__links a:last-child { border: none; }
  .nav__burger { display: flex; }
  .nav__burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
  .nav__burger.open span:nth-child(2) { opacity: 0; }
  .nav__burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
}

@media (max-width: 480px) {
  .product-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .cart-page__item { grid-template-columns: 80px 1fr; }
  .cart-page__item-price { grid-column: 1 / -1; }
}

/* ── Animations ──────────────────────────────────────────────── */
.fade-in {
  opacity:    0;
  transform:  translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-in.visible { opacity: 1; transform: none; }

/* ── Size Selection Bottom Sheet (mobile quick-add) ──────────── */
.size-sheet-overlay {
  position:        fixed;
  inset:           0;
  background:      rgba(42, 31, 22, 0.75);
  z-index:         2000;
  animation:       ssOverlayIn 0.2s ease;
}
.size-sheet {
  position:        fixed;
  bottom:          0;
  left:            0;
  right:           0;
  background:      var(--cream);
  z-index:         2001;
  border-radius:   12px 12px 0 0;
  padding:         1.25rem 1.5rem 2rem;
  max-height:      85vh;
  overflow-y:      auto;
  animation:       ssSheetIn 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-overflow-scrolling: touch;
}
.size-sheet__handle {
  width:           40px;
  height:          4px;
  background:      var(--border);
  border-radius:   2px;
  margin:          0 auto 1.25rem;
}
.size-sheet__header {
  display:         flex;
  gap:             1rem;
  align-items:     center;
  margin-bottom:   1.5rem;
  padding-bottom:  1rem;
  border-bottom:   1px solid var(--border);
}
.size-sheet__img {
  width:           64px;
  height:          80px;
  object-fit:      cover;
  background:      var(--cream-dark);
  flex-shrink:     0;
}
.size-sheet__name {
  font-family:     var(--font-display);
  font-size:       1.25rem;
  line-height:     1.2;
}
.size-sheet__price {
  font-size:       0.85rem;
  color:           var(--rose-gold);
  margin-top:      0.3rem;
  font-weight:     500;
}
.size-sheet__close {
  margin-left:     auto;
  font-size:       1.75rem;
  line-height:     1;
  opacity:         0.4;
  flex-shrink:     0;
  align-self:      flex-start;
  padding:         0.25rem;
  transition:      opacity var(--transition);
}
.size-sheet__close:hover { opacity: 0.9; }

@keyframes ssOverlayIn { from { opacity: 0; }          to { opacity: 1; } }
@keyframes ssSheetIn   { from { transform: translateY(100%); } to { transform: translateY(0); } }
