/* ============================================================
   NOCTURNE — COMPONENTS: nav, footer, cards, forms, shared UI
   ============================================================ */

/* ------------------------------------------------------------
   NAVIGATION  — symmetric 3-column grid, centered wordmark.
   Left and right columns share the SAME width (1fr) so the
   logo is mathematically centered. This is the fix for the
   previously uneven top bar.
   ------------------------------------------------------------ */
.nav {
  position: fixed; top: 0; left: 0; width: 100%; z-index: 1000;
  border-bottom: 1px solid transparent;
  transition: background var(--duration-mid) var(--ease-luxury),
              backdrop-filter var(--duration-mid) ease,
              border-color var(--duration-mid) ease;
}
.nav__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;   /* even sides, centered middle */
  align-items: center;
  height: var(--nav-h);
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--space-md);
  transition: height var(--duration-mid) var(--ease-luxury);
}
.nav.scrolled {
  background: rgba(7, 7, 7, 0.92);
  backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
  border-bottom: 1px solid var(--color-border);
}
.nav.scrolled .nav__inner { height: 64px; }

/* left + right clusters */
.nav__left  { display: flex; align-items: center; gap: var(--space-md); justify-self: start; }
.nav__right { display: flex; align-items: center; gap: var(--space-sm); justify-self: end; }

.nav__logo {
  grid-column: 2;
  justify-self: center;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: var(--ls-wordmark);
  color: var(--color-gold-pale);
  padding-left: var(--ls-wordmark);
  white-space: nowrap;
  line-height: 1;
}

.nav__link {
  position: relative; font-size: 11px; letter-spacing: var(--ls-nav);
  text-transform: uppercase; color: var(--color-text-secondary);
  padding: 6px 0; transition: color var(--duration-fast) ease; white-space: nowrap;
}
.nav__link::after {
  content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px;
  background: var(--color-gold); transform: scaleX(0); transform-origin: left;
  transition: transform var(--duration-mid) var(--ease-luxury);
}
.nav__link:hover, .nav__link[aria-current="page"] { color: var(--color-gold); }
.nav__link:hover::after, .nav__link[aria-current="page"]::after { transform: scaleX(1); }

.icon-btn {
  position: relative; display: grid; place-items: center; width: 38px; height: 38px;
  color: var(--color-text-secondary); transition: color var(--duration-fast) ease;
}
.icon-btn:hover { color: var(--color-gold); }
.icon-btn svg { width: 20px; height: 20px; }
.bag-count {
  position: absolute; top: 3px; right: 1px; min-width: 15px; height: 15px; padding: 0 4px;
  border-radius: 999px; background: var(--color-gold); color: var(--color-bg);
  font-size: 9px; font-weight: 600; display: grid; place-items: center;
}
.btn-appointment {
  font-size: 10px; letter-spacing: var(--ls-nav); text-transform: uppercase; color: var(--color-gold);
  border: 1px solid var(--color-border-hover); padding: 11px 18px;
  transition: background var(--duration-mid) var(--ease-luxury), color var(--duration-mid) var(--ease-luxury);
  white-space: nowrap;
}
.btn-appointment:hover { background: var(--color-gold); color: var(--color-bg); }

.nav__hamburger { display: none; flex-direction: column; gap: 5px; width: 26px; }
.nav__hamburger span { display: block; height: 1px; width: 100%; background: var(--color-text-primary);
  transition: transform var(--duration-mid) var(--ease-luxury), opacity var(--duration-fast); }
.nav__hamburger.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav__hamburger.open span:nth-child(2) { opacity: 0; }
.nav__hamburger.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* Mobile overlay menu */
.mobile-menu {
  position: fixed; inset: 0; background: var(--color-bg); z-index: 999;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-md);
  opacity: 0; pointer-events: none; transition: opacity var(--duration-mid) var(--ease-luxury);
}
.mobile-menu.open { opacity: 1; pointer-events: auto; }
.mobile-menu a { font-family: var(--font-display); font-size: var(--text-3xl); color: var(--color-text-primary); letter-spacing: 0.04em; }
.mobile-menu a:hover, .mobile-menu a[aria-current="page"] { color: var(--color-gold); }
.mobile-menu .mm-sep { width: 30px; height: 1px; background: var(--color-border); }

/* ------------------------------------------------------------
   FOOTER
   ------------------------------------------------------------ */
.footer { border-top: 1px solid var(--color-border); padding: var(--space-xl) 0 var(--space-md); }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--space-lg); margin-bottom: var(--space-xl); }
.footer__brand .logo { font-family: var(--font-display); font-size: var(--text-2xl); letter-spacing: 0.3em; color: var(--color-gold-pale); margin-bottom: var(--space-sm); }
.footer__brand p { color: var(--color-text-secondary); font-size: var(--text-sm); max-width: 30ch; margin-bottom: var(--space-md); }
.footer__socials { display: flex; gap: var(--space-sm); }
.footer__socials a { width: 40px; height: 40px; display: grid; place-items: center; border: 1px solid var(--color-border);
  border-radius: 50%; color: var(--color-text-secondary); transition: color var(--duration-fast), border-color var(--duration-fast); }
.footer__socials a:hover { color: var(--color-gold); border-color: var(--color-border-hover); }
.footer__socials svg { width: 16px; height: 16px; }
.footer__col h4 { font-size: 11px; letter-spacing: var(--ls-nav); text-transform: uppercase; color: var(--color-text-primary); margin-bottom: var(--space-md); font-weight: 500; }
.footer__col ul { display: flex; flex-direction: column; gap: 12px; }
.footer__col a { font-size: 12px; color: var(--color-text-secondary); transition: color var(--duration-fast); }
.footer__col a:hover { color: var(--color-gold); }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: var(--space-md);
  border-top: 1px solid var(--color-border); gap: var(--space-md); flex-wrap: wrap; }
.footer__bottom span, .footer__bottom a { font-size: 11px; color: var(--color-text-muted); }
.footer__bottom .legal { display: flex; gap: var(--space-md); }
.footer__bottom .legal a:hover { color: var(--color-gold); }
.footer__bottom .tagline { color: var(--color-text-secondary); font-style: italic; font-family: var(--font-display); }

/* ------------------------------------------------------------
   PRODUCT / COLLECTION CARDS (shared)
   ------------------------------------------------------------ */
.collection-card { position: relative; aspect-ratio: 3 / 4; overflow: hidden; background: var(--color-bg-elevated); display: block; }
.collection-card__img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform var(--duration-slow) var(--ease-luxury); }
.collection-card:hover .collection-card__img { transform: scale(1.05); }
.collection-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.15) 55%, transparent 100%); transition: background var(--duration-mid) ease; }
.collection-card:hover .collection-card__overlay { background: linear-gradient(to top, rgba(0,0,0,0.94) 0%, rgba(0,0,0,0.3) 60%, rgba(0,0,0,0.08) 100%); }
.collection-card__border { position: absolute; inset: 14px; border: 1px solid var(--color-gold); opacity: 0; transition: opacity var(--duration-mid) var(--ease-luxury); pointer-events: none; }
.collection-card:hover .collection-card__border { opacity: 0.5; }
.collection-card__body { position: absolute; left: 0; bottom: 0; width: 100%; padding: var(--space-md); z-index: 2; }
.collection-card__tag { font-size: 9px; text-transform: uppercase; letter-spacing: 3px; color: var(--color-gold); margin-bottom: 8px; }
.collection-card__name { font-family: var(--font-display); font-size: var(--text-2xl); color: var(--color-white); transition: transform var(--duration-mid) var(--ease-luxury); }
.collection-card:hover .collection-card__name { transform: translateY(-6px); }
.collection-card__count { font-size: 11px; color: var(--color-text-secondary); margin-top: 4px; }
.collection-card__discover { margin-top: 14px; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-gold-pale);
  opacity: 0; transform: translateY(10px); transition: opacity var(--duration-mid) var(--ease-luxury), transform var(--duration-mid) var(--ease-luxury); }
.collection-card__discover .arrow { display: inline-block; transition: transform var(--duration-mid) var(--ease-luxury); }
.collection-card:hover .collection-card__discover { opacity: 1; transform: translateY(0); }
.collection-card:hover .collection-card__discover .arrow { transform: translateX(4px); }

/* Product card (grid) */
.product-card { display: block; }
.product-card__img { position: relative; aspect-ratio: 1 / 1; overflow: hidden; background: var(--color-bg-elevated); }
.product-card__img .pic { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform var(--duration-slow) var(--ease-luxury); }
.product-card:hover .product-card__img .pic { transform: scale(1.06); }
.wishlist { position: absolute; top: 12px; right: 12px; width: 34px; height: 34px; display: grid; place-items: center;
  background: rgba(7,7,7,0.45); backdrop-filter: blur(6px); border-radius: 50%; color: var(--color-text-secondary); z-index: 2; transition: color var(--duration-fast); }
.wishlist svg { width: 16px; height: 16px; }
.wishlist.active { color: var(--color-gold); }
.wishlist.active svg { fill: var(--color-gold); }
.product-card__name { font-family: var(--font-display); font-size: var(--text-lg); margin-top: var(--space-sm); }
.product-card__mat { font-size: 11px; color: var(--color-text-muted); margin-top: 2px; }
.product-card__price { font-size: 13px; color: var(--color-gold); margin-top: 8px; letter-spacing: 1px; }

/* ------------------------------------------------------------
   FORMS
   ------------------------------------------------------------ */
.field { position: relative; margin-bottom: var(--space-md); }
.field label { display: block; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-text-secondary); margin-bottom: 10px; }
.field input, .field textarea, .field select {
  width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--color-gold-muted);
  color: var(--color-gold-pale); font-size: var(--text-base); padding: 10px 0; letter-spacing: 0.4px; transition: border-color var(--duration-fast);
}
.field textarea { resize: vertical; min-height: 90px; }
.field input::placeholder, .field textarea::placeholder { color: var(--color-text-muted); }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--color-gold); }
.field select option { background: var(--color-bg-elevated); color: var(--color-text-primary); }

/* ------------------------------------------------------------
   PRODUCT DETAIL MODAL (click into a piece)
   ------------------------------------------------------------ */
.pdp { position: fixed; inset: 0; z-index: 1200; display: grid; place-items: center; padding: var(--space-md);
  opacity: 0; pointer-events: none; transition: opacity var(--duration-mid) var(--ease-luxury); }
.pdp.open { opacity: 1; pointer-events: auto; }
.pdp__backdrop { position: absolute; inset: 0; background: rgba(4,4,4,0.82); backdrop-filter: blur(10px); }
.pdp__panel { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  width: min(920px, 100%); max-height: 88vh; overflow: hidden; background: var(--color-bg-elevated);
  border: 1px solid var(--color-border); box-shadow: var(--shadow-float);
  transform: translateY(24px) scale(0.98); transition: transform var(--duration-mid) var(--ease-luxury); }
.pdp.open .pdp__panel { transform: none; }
.pdp__img { background-size: cover; background-position: center; min-height: 420px; }
.pdp__body { padding: var(--space-lg); display: flex; flex-direction: column; justify-content: center; }
.pdp__tag { font-size: 9px; letter-spacing: 3px; text-transform: uppercase; color: var(--color-gold); margin-bottom: var(--space-sm); }
.pdp__name { font-family: var(--font-display); font-weight: 300; font-size: var(--text-3xl); line-height: 1.05; }
.pdp__mat { color: var(--color-text-secondary); margin: var(--space-xs) 0 var(--space-sm); }
.pdp__price { color: var(--color-gold); font-size: var(--text-lg); letter-spacing: 1px; margin-bottom: var(--space-md); }
.pdp__desc { color: var(--color-text-secondary); font-size: var(--text-sm); margin-bottom: var(--space-lg); }
.pdp__cta { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.pdp__close { position: absolute; top: 14px; right: 14px; z-index: 2; width: 40px; height: 40px; display: grid; place-items: center;
  border-radius: 50%; background: rgba(7,7,7,0.5); color: var(--color-text-primary); transition: color var(--duration-fast); }
.pdp__close:hover { color: var(--color-gold); }
.pdp__close svg { width: 20px; height: 20px; }
.product-card__img { cursor: pointer; }
@media (max-width: 700px) { .pdp__panel { grid-template-columns: 1fr; max-height: 92vh; overflow-y: auto; } .pdp__img { min-height: 260px; } }

/* ------------------------------------------------------------
   SHOP TOOLBAR + FILTER PANEL
   ------------------------------------------------------------ */
.shop-toolbar { display: flex; align-items: center; gap: var(--space-md); margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm); border-bottom: 1px solid var(--color-border); flex-wrap: wrap; }
.tb-btn { display: inline-flex; align-items: center; gap: 10px; font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--color-text-primary); border: 1px solid var(--color-border); padding: 11px 18px; transition: border-color var(--duration-fast), color var(--duration-fast); }
.tb-btn:hover { color: var(--color-gold); border-color: var(--color-border-hover); }
.tb-btn svg { width: 16px; height: 16px; }
.tb-count { font-size: 11px; letter-spacing: 1px; color: var(--color-text-muted); margin-right: auto; }
.tb-sort { display: inline-flex; align-items: center; gap: 10px; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-text-secondary); }
.tb-sort select { background: var(--color-surface); color: var(--color-text-primary); border: 1px solid var(--color-border);
  padding: 10px 12px; font-size: 11px; letter-spacing: 1px; }
.tb-sort select:focus { outline: none; border-color: var(--color-gold); }
.tb-sort select option { background: var(--color-bg-elevated); }

.shop { position: relative; }
.filter-panel { position: fixed; top: 0; left: 0; height: 100%; width: 360px; max-width: 88vw; z-index: 1150;
  background: var(--color-bg-elevated); border-right: 1px solid var(--color-border); padding: var(--space-md);
  overflow-y: auto; transform: translateX(-100%); transition: transform var(--duration-mid) var(--ease-luxury); }
.filter-panel:not([hidden]) { transform: translateX(0); }
.filter-scrim { position: fixed; inset: 0; z-index: 1140; background: rgba(4,4,4,0.6); }
.fp-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-md); }
.fp-head h3 { font-family: var(--font-display); font-weight: 300; font-size: var(--text-2xl); }
.fp-head button { font-size: 18px; color: var(--color-text-secondary); }
.fp-head button:hover { color: var(--color-gold); }
.fp-group { padding: var(--space-sm) 0; border-top: 1px solid var(--color-border); }
.fp-group h4 { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-text-secondary); margin-bottom: var(--space-sm); }
.fp-opts { display: flex; flex-direction: column; gap: 10px; }
.fp-opts label { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--color-text-primary); cursor: pointer; }
.fp-opts input { accent-color: var(--color-gold); width: 15px; height: 15px; }
.fp-chips, .fp-swatches { display: flex; flex-wrap: wrap; gap: 8px; }
.fp-chip { font-size: 12px; padding: 7px 12px; border: 1px solid var(--color-border); color: var(--color-text-secondary); transition: all var(--duration-fast); }
.fp-chip[aria-pressed="true"] { border-color: var(--color-gold); color: var(--color-gold-pale); }
.fp-sw { width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--color-border); position: relative; }
.fp-sw[aria-pressed="true"] { box-shadow: 0 0 0 2px var(--color-bg-elevated), 0 0 0 3px var(--color-gold); }
.range { position: relative; height: 28px; }
.range input[type=range] { position: absolute; left: 0; top: 0; width: 100%; margin: 0; background: none; pointer-events: none; -webkit-appearance: none; appearance: none; }
.range input[type=range]::-webkit-slider-runnable-track { height: 1px; background: var(--color-gold-muted); }
.range input[type=range]::-moz-range-track { height: 1px; background: var(--color-gold-muted); }
.range input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; pointer-events: auto; width: 16px; height: 16px; border-radius: 50%; background: var(--color-gold); margin-top: -8px; cursor: pointer; }
.range input[type=range]::-moz-range-thumb { pointer-events: auto; width: 16px; height: 16px; border: none; border-radius: 50%; background: var(--color-gold); cursor: pointer; }
.range-vals { display: flex; justify-content: space-between; font-size: 12px; color: var(--color-gold-pale); margin-top: 4px; }
.fp-actions { display: flex; align-items: center; justify-content: space-between; gap: var(--space-sm); margin-top: var(--space-md); padding-top: var(--space-md); border-top: 1px solid var(--color-border); }

/* ------------------------------------------------------------
   PRODUCT DETAIL MODAL — Pandora-style
   ------------------------------------------------------------ */
.pdp { position: fixed; inset: 0; z-index: 1200; display: grid; place-items: center; padding: var(--space-md);
  opacity: 0; pointer-events: none; transition: opacity var(--duration-mid) var(--ease-luxury); }
.pdp.open { opacity: 1; pointer-events: auto; }
.pdp__backdrop { position: absolute; inset: 0; background: rgba(4,4,4,0.82); backdrop-filter: blur(10px); }
.pdp__panel { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr 1fr; gap: 0;
  width: min(1000px, 100%); max-height: 90vh; overflow: hidden; background: var(--color-bg-elevated);
  border: 1px solid var(--color-border); box-shadow: var(--shadow-float);
  transform: translateY(24px) scale(0.985); transition: transform var(--duration-mid) var(--ease-luxury); }
.pdp.open .pdp__panel { transform: none; }
.pdp__img { background-size: cover; background-position: center; min-height: 480px; }
.pdp__body { padding: var(--space-lg); overflow-y: auto; }
.pdp__new { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--color-gold); margin-bottom: var(--space-md); min-height: 12px; }
.pdp__name { font-family: var(--font-display); font-weight: 300; font-size: var(--text-3xl); line-height: 1.05; }
.pdp__mat { color: var(--color-text-secondary); margin: 6px 0 var(--space-sm); font-size: var(--text-sm); }
.pdp__price { color: var(--color-gold); font-size: var(--text-lg); letter-spacing: 1px; margin-bottom: var(--space-md); }
.pdp__opt { margin-bottom: var(--space-md); }
.pdp__opt .lbl { font-size: 11px; letter-spacing: 1px; color: var(--color-text-primary); margin-bottom: 10px; }
.pdp__row { display: flex; gap: 10px; flex-wrap: wrap; }
.pdp__metal, .pdp__col { width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--color-border); position: relative; }
.pdp__metal[aria-pressed="true"], .pdp__col[aria-pressed="true"] { box-shadow: 0 0 0 2px var(--color-bg-elevated), 0 0 0 3px var(--color-gold); }
.pdp__details { display: block; font-size: 12px; letter-spacing: 1px; color: var(--color-text-primary); border-bottom: 1px solid var(--color-gold-muted);
  padding: 10px 0; margin: var(--space-sm) 0; width: 100%; text-align: left; }
.pdp__details:hover { color: var(--color-gold); }
.pdp__story { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: 1.7; font-style: italic; font-family: var(--font-display);
  max-height: 0; overflow: hidden; transition: max-height var(--duration-mid) var(--ease-luxury), margin var(--duration-mid); }
.pdp__story.show { max-height: 220px; margin-bottom: var(--space-sm); }
.pdp__story p:first-child { margin-bottom: 8px; }
.pdp__size { display: flex; align-items: center; justify-content: space-between; width: 100%; border: 1px solid var(--color-border);
  padding: 16px 18px; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-text-primary); margin: var(--space-sm) 0;
  transition: border-color var(--duration-fast); }
.pdp__size:hover { border-color: var(--color-border-hover); }
.pdp__size svg { width: 16px; height: 16px; }
.pdp__sizes { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: var(--space-sm); }
.pdp__sizes.hidden { display: none; }
.pdp__sizebtn { min-width: 52px; padding: 10px; border: 1px solid var(--color-border); font-size: 13px; color: var(--color-text-primary); transition: all var(--duration-fast); }
.pdp__sizebtn[aria-pressed="true"] { border-color: var(--color-gold); color: var(--color-gold-pale); }
.pdp__bag { display: flex; align-items: center; justify-content: space-between; width: 100%; background: var(--color-gold); color: var(--color-bg);
  padding: 18px 22px; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; margin-top: var(--space-sm); transition: background var(--duration-fast); }
.pdp__bag:hover { background: var(--color-gold-light); }
.pdp__close { position: absolute; top: 14px; right: 14px; z-index: 2; width: 40px; height: 40px; display: grid; place-items: center;
  border-radius: 50%; background: rgba(7,7,7,0.5); color: var(--color-text-primary); transition: color var(--duration-fast); }
.pdp__close:hover { color: var(--color-gold); }
.pdp__close svg { width: 20px; height: 20px; }
.product-card__img { cursor: pointer; }
@media (max-width: 760px) { .pdp__panel { grid-template-columns: 1fr; max-height: 92vh; overflow-y: auto; } .pdp__img { min-height: 280px; } }

/* Search overlay */
.search-ov { position: fixed; inset: 0; z-index: 1300; background: rgba(7,7,7,0.96); backdrop-filter: blur(14px);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-md);
  opacity: 0; transition: opacity var(--duration-mid) var(--ease-luxury); }
.search-ov[hidden], .pdp[hidden] { display: none !important; }
.search-ov.open { opacity: 1; }
.search-ov__close { position: absolute; top: 24px; right: 28px; font-size: 22px; color: var(--color-text-secondary); }
.search-ov__close:hover { color: var(--color-gold); }
.search-ov__form { display: flex; align-items: center; gap: var(--space-sm); width: min(640px, 86vw); border-bottom: 1px solid var(--color-gold-muted); padding-bottom: 14px; }
.search-ov__form input { flex: 1; background: none; border: none; color: var(--color-gold-pale); font-family: var(--font-display); font-size: var(--text-3xl); font-weight: 300; }
.search-ov__form input:focus { outline: none; }
.search-ov__form input::placeholder { color: var(--color-text-muted); }
.search-ov__form button { font-size: var(--text-2xl); color: var(--color-gold); }
.search-ov__hint { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-text-muted); }

.shop-empty { grid-column: 1 / -1; text-align: center; color: var(--color-text-secondary); font-family: var(--font-display); font-style: italic; font-size: var(--text-xl); padding: var(--space-xl) 0; }
.pdp__img { cursor: zoom-in; transition: background-position 60ms linear; }

/* Bag drawer + checkout */
.bag-drawer { position: fixed; inset: 0; z-index: 1250; }
.bag-drawer[hidden] { display: none !important; }
.bag-drawer .bag-scrim { position: absolute; inset: 0; background: rgba(4,4,4,0.7); opacity: 0; transition: opacity var(--duration-mid) var(--ease-luxury); }
.bag-drawer.open .bag-scrim { opacity: 1; }
.bag-panel { position: absolute; top: 0; right: 0; height: 100%; width: 440px; max-width: 92vw; background: var(--color-bg-elevated);
  border-left: 1px solid var(--color-border); display: flex; flex-direction: column; padding: var(--space-md);
  transform: translateX(100%); transition: transform var(--duration-mid) var(--ease-luxury); overflow-y: auto; }
.bag-drawer.open .bag-panel { transform: none; }
.bag-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-md); }
.bag-head h3 { font-family: var(--font-display); font-weight: 300; font-size: var(--text-2xl); }
.bag-head button { font-size: 18px; color: var(--color-text-secondary); }
.bag-head button:hover { color: var(--color-gold); }
.bag-view { display: flex; flex-direction: column; flex: 1; }
.bag-list { flex: 1; }
.bag-empty { color: var(--color-text-secondary); font-style: italic; font-family: var(--font-display); padding: var(--space-md) 0; }
.bag-item { display: grid; grid-template-columns: 64px 1fr auto; gap: var(--space-sm); align-items: center; padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-border); }
.bag-thumb { width: 64px; height: 64px; background-size: cover; background-position: center; background-color: var(--color-surface); }
.bag-name { font-family: var(--font-display); font-size: var(--text-lg); }
.bag-sub { font-size: 11px; color: var(--color-text-muted); letter-spacing: .5px; }
.bag-price { font-size: 12px; color: var(--color-gold); margin-top: 4px; }
.bag-remove { color: var(--color-text-muted); font-size: 14px; align-self: start; }
.bag-remove:hover { color: var(--color-gold); }
.bag-foot { padding-top: var(--space-md); border-top: 1px solid var(--color-border); }
.bag-total { display: flex; justify-content: space-between; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-text-secondary); margin-bottom: var(--space-sm); }
.bag-total span:last-child { color: var(--color-gold-pale); font-size: var(--text-lg); }
.bag-checkout { width: 100%; text-align: center; }
.bag-checkout:disabled { opacity: .4; pointer-events: none; }
.bag-co h4, .bag-done h4 { font-family: var(--font-display); font-weight: 300; font-size: var(--text-2xl); margin-bottom: var(--space-md); }
.bag-co-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-sm); }
.bag-co .btn { width: 100%; text-align: center; margin-top: var(--space-sm); }
.bag-co #coBack { display: block; text-align: center; margin-top: var(--space-sm); }
.bag-done { text-align: center; padding: var(--space-xl) 0; }
.bag-done__mark { font-size: 40px; color: var(--color-gold); margin-bottom: var(--space-sm); }
.bag-done p { color: var(--color-text-secondary); font-size: var(--text-sm); margin-bottom: var(--space-md); }

/* Lens zoom */
.pdp__img { position: relative; overflow: hidden; cursor: zoom-in; }
.pdp__lens { position: absolute; width: 150px; height: 150px; border-radius: 50%; border: 1px solid var(--color-gold);
  transform: translate(-50%, -50%); pointer-events: none; opacity: 0; transition: opacity 140ms ease;
  background-repeat: no-repeat; box-shadow: 0 10px 36px rgba(0,0,0,0.55), inset 0 0 0 4px rgba(7,7,7,0.4); z-index: 3; }

/* Checkout page */
.checkout-main { min-height: 70vh; }
.checkout { display: grid; grid-template-columns: 1.5fr 1fr; gap: var(--space-2xl); align-items: start; padding-bottom: var(--space-xl); }
.co-block { margin-bottom: var(--space-lg); }
.co-h { font-family: var(--font-display); font-weight: 300; font-size: var(--text-2xl); margin-bottom: var(--space-md); }
.checkout__form .row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
.co-pay { width: 100%; text-align: center; margin-top: var(--space-sm); }
.co-secure { font-size: 11px; color: var(--color-text-muted); text-align: center; margin-top: var(--space-sm); }
.checkout__summary { background: var(--color-bg-elevated); border: 1px solid var(--color-border); padding: var(--space-lg); position: sticky; top: 96px; }
.co-items { margin-bottom: var(--space-md); }
.co-item { display: grid; grid-template-columns: 56px 1fr auto auto; gap: var(--space-sm); align-items: center; padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-border); }
.co-thumb { width: 56px; height: 56px; background-size: cover; background-position: center; background-color: var(--color-surface); }
.co-name { font-family: var(--font-display); font-size: var(--text-base); }
.co-sub { font-size: 10px; letter-spacing: .5px; color: var(--color-text-muted); }
.co-price { font-size: 12px; color: var(--color-gold); }
.co-rm { color: var(--color-text-muted); font-size: 13px; padding-left: 6px; }
.co-rm:hover { color: var(--color-gold); }
.co-line { display: flex; justify-content: space-between; font-size: 12px; letter-spacing: 1px; color: var(--color-text-secondary); padding: 8px 0; }
.co-line--total { border-top: 1px solid var(--color-border); margin-top: 8px; padding-top: var(--space-sm); color: var(--color-text-primary); font-size: var(--text-base); }
.co-line--total span:last-child { color: var(--color-gold-pale); font-family: var(--font-display); font-size: var(--text-xl); }
.co-done, .co-empty { text-align: center; padding: var(--space-2xl) 0; max-width: 560px; margin: 0 auto; }
.co-done__mark { font-size: 44px; color: var(--color-gold); margin-bottom: var(--space-sm); }
.co-done h2 { font-size: var(--text-4xl); font-weight: 300; margin-bottom: var(--space-md); }
.co-done p { color: var(--color-text-secondary); margin-bottom: var(--space-lg); }
.co-empty .serif { font-size: var(--text-3xl); margin-bottom: var(--space-md); display: block; }

/* ---- Mobile pass ---- */
@media (max-width: 900px) {
  .checkout { grid-template-columns: 1fr; gap: var(--space-lg); }
  .checkout__summary { position: static; order: -1; }
}
@media (max-width: 600px) {
  .bag-panel { width: 100%; max-width: 100%; }
  .checkout__form .row, .co-item { grid-template-columns: 1fr; }
  .co-item { grid-template-columns: 48px 1fr auto; }
  .co-thumb { width: 48px; height: 48px; }
  .shop-toolbar { gap: var(--space-sm); }
  .tb-count { width: 100%; order: 3; margin: 0; }
  .pdp__lens { display: none; }
  .pdp__body { padding: var(--space-md); }
}

/* Legal documents */
.legal-doc { max-width: 760px; margin: 0 auto; padding: calc(var(--nav-h) + var(--space-xl)) var(--space-md) var(--space-2xl); }
.legal-doc h1 { font-family: var(--font-display); font-weight: 300; font-size: var(--text-4xl); margin-bottom: var(--space-2xs); }
.legal-doc .upd { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--color-text-muted); margin-bottom: var(--space-lg); }
.legal-doc h2 { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 300; margin: var(--space-lg) 0 var(--space-sm); }
.legal-doc p, .legal-doc li { color: var(--color-text-secondary); font-size: var(--text-sm); line-height: 1.8; margin-bottom: var(--space-sm); }
.legal-doc ul { padding-left: 1.2em; list-style: disc; }
.legal-doc a { color: var(--color-gold); }

/* Back to top */
.back-to-top {
  position: fixed; bottom: var(--space-md); right: var(--space-md); width: 46px; height: 46px;
  border: 1px solid var(--color-border-hover); border-radius: 50%; background: rgba(7,7,7,0.7); backdrop-filter: blur(8px);
  display: grid; place-items: center; color: var(--color-gold); opacity: 0; pointer-events: none; transform: translateY(20px);
  transition: opacity var(--duration-mid) var(--ease-luxury), transform var(--duration-mid) var(--ease-luxury); z-index: 900;
}
.back-to-top.show { opacity: 1; pointer-events: auto; transform: translateY(0); }
.back-to-top svg { width: 18px; height: 18px; }

/* ------------------------------------------------------------
   NAV RESPONSIVE
   ------------------------------------------------------------ */
@media (max-width: 980px) {
  .nav__left .nav__link, .btn-appointment, .icon-btn[data-desktop] { display: none; }
  .icon-btn[aria-label="Search"] { display: grid; }   /* keep search reachable on mobile */
  .nav__hamburger { display: flex; }
  /* flex nav so the icon cluster can't overflow a narrow grid column and get clipped */
  .nav__inner { display: flex; align-items: center; justify-content: space-between; }
  .nav__logo { position: static; transform: none; justify-self: auto; font-size: var(--text-xl); }
  .nav__left { flex: 0 0 auto; }
  .nav__right { flex: 0 0 auto; gap: var(--space-xs); }
}
@media (max-width: 380px) { .nav__right { gap: 4px; } .icon-btn { width: 34px; } .nav__logo { font-size: var(--text-lg); } }
@media (max-width: 768px) {
  .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-md); }
  .footer__brand { grid-column: 1 / -1; }
  .footer__bottom { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) { .footer__grid { grid-template-columns: 1fr; } }
