
.delivery-method-row {
  display: flex;
  gap: 10px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.delivery-method-row label {
  flex: 1;
  min-width: 140px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  cursor: pointer;
  border: 1px solid var(--border);
  transition: border-color .25s;
}
.delivery-method-row label.active-delivery {
  border-color: var(--gold);
}
.delivery-method-row label span {
  font-family: var(--font-sans);
  font-size: .62rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  white-space: nowrap;
}
.delivery-method-row input[type="radio"] {
  accent-color: var(--gold);
  cursor: pointer;
  flex-shrink: 0;
  width: auto;
}
/* ═══════════════════════════════════════════════════════════
   ELYSÉ HAFEZ — SHARED STYLESHEET
   style.css
═══════════════════════════════════════════════════════════ */

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

:root {
  --black:       #2e1f1a;
  --off-black:   #4a342a;
  --white:       #faf8f5;
  --cream:       #f2ede5;
  --rose:        #c8a39a;
  --rose-light:  #e8d5d0;
  --rose-dark:   #9e6e67;
  --gold:        #b8935a;
  --muted:       #7a7268;
  --border:      rgba(184,147,90,0.25);
  --font-display:'Cormorant Garamond', serif;
  --font-sans:   'Tenor Sans', serif;
  --font-body:   'Jost', sans-serif;
  --nav-h:       80px;
  --ease:        cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

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

body {
  font-family: var(--font-body);
  background: var(--white);
  color: var(--black);
  overflow-x: hidden;
  cursor: none;
}

::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--cream); }
::-webkit-scrollbar-thumb { background: var(--gold); border-radius: 2px; }

/* ── CURSOR ── */
.cursor-dot, .cursor-ring {
  position: fixed; border-radius: 50%;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
}
.cursor-dot { width:6px; height:6px; background:var(--gold); }
.cursor-ring {
  width:32px; height:32px;
  border:1px solid var(--gold); opacity:.5;
  transition: width .3s, height .3s, opacity .3s;
}
.cursor-ring.expand { width:56px; height:56px; opacity:.18; }

/* ── LOADER ── */
#loader {
  position:fixed; inset:0; background:#2e1f1a; z-index:9990;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:20px;
  transition: opacity .9s ease, visibility .9s ease;
}
#loader.gone { opacity:0; visibility:hidden; pointer-events:none; }
.loader-logo {
  font-family:var(--font-display); font-size:clamp(2rem,7vw,4.5rem);
  font-weight:300; color:var(--white); letter-spacing:.4em;
  text-transform:uppercase; opacity:0;
  animation: loaderUp .9s .2s ease forwards;
}
.loader-sub {
  font-family:var(--font-sans); font-size:.62rem; letter-spacing:.38em;
  color:var(--gold); text-transform:uppercase; opacity:0;
  animation: loaderUp .9s .5s ease forwards;
}
.loader-bar-wrap { width:160px; height:1px; background:rgba(255,255,255,.08); overflow:hidden; }
.loader-bar { height:100%; width:0; background:var(--gold); animation:loaderBarAnim 1.4s .3s ease forwards; }
@keyframes loaderUp { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:none} }
@keyframes loaderBarAnim { to{width:100%} }

/* ── NAVIGATION ── */
nav {
  position:fixed; top:0; left:0; right:0; height:var(--nav-h);
  z-index:800; display:flex; align-items:center; justify-content:space-between;
  padding:0 48px; transition:background .4s, box-shadow .4s;
}
nav.scrolled {
  background:rgba(250,248,245,.96);
  backdrop-filter:blur(12px);
  box-shadow:0 1px 0 var(--border);
}
.nav-logo {
  font-family:var(--font-display); font-size:1.5rem; font-weight:400;
  letter-spacing:.2em; text-decoration:none; color:var(--white);
  text-transform:uppercase; transition:color .3s; flex-shrink:0;
}
nav.scrolled .nav-logo, nav.light .nav-logo { color:#4a342a; }
nav.light { background:var(--white); box-shadow:0 1px 0 var(--border); }

.nav-right { display:flex; align-items:center; gap:24px; flex-shrink:0; }

.nav-links { display:flex; gap:40px; list-style:none; }
.nav-links a {
  font-family:var(--font-sans); font-size:.7rem; letter-spacing:.24em;
  text-transform:uppercase; text-decoration:none;
  color:rgba(250,248,245,.8); position:relative; transition:color .3s;
}
nav.scrolled .nav-links a,
nav.light .nav-links a { color:var(--muted); }
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0;
  width:0; height:1px; background:var(--gold);
  transition:width .45s var(--ease);
}
.nav-links a:hover::after { width:100%; }
.nav-links a:hover,
.nav-links a.active { color:var(--gold)!important; }
.nav-links a.active::after { width:100%; }

.nav-hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:none; background:none; border:none; padding:4px;
}
.nav-hamburger span {
  display:block; width:26px; height:1px; background:var(--white);
  transition:background .3s, transform .3s, opacity .3s;
}
nav.scrolled .nav-hamburger span,
nav.light .nav-hamburger span { background:var(--black); }
.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-menu {
  position:fixed; inset:0; background:var(--black); z-index:700;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:44px;
  opacity:0; visibility:hidden; transition:opacity .4s, visibility .4s;
}
.mobile-menu.open { opacity:1; visibility:visible; }
.mobile-menu a {
  font-family:var(--font-display); font-size:clamp(2rem,9vw,3.5rem);
  color:var(--white); text-decoration:none; letter-spacing:.1em;
  font-style:italic; transition:color .3s;
}
.mobile-menu a:hover { color:var(--gold); }

/* ── MARQUEE ── */
.marquee-wrap {
  background:var(--off-black);
  border-top:1px solid rgba(184,147,90,.15);
  border-bottom:1px solid rgba(184,147,90,.15);
  padding:14px 0; overflow:hidden;
}
.marquee-track {
  display:flex; animation:marquee 32s linear infinite; white-space:nowrap;
}
.marquee-item {
  font-family:var(--font-display); font-size:.95rem; font-style:italic;
  color:var(--rose-light); letter-spacing:.1em; padding:0 48px;
}
.marquee-sep { color:var(--gold); }
@keyframes marquee { to{transform:translateX(-50%)} }

/* ── SECTION COMMONS ── */
.section-eyebrow {
  font-family:var(--font-sans); font-size:.6rem; letter-spacing:.44em;
  color:var(--gold); text-transform:uppercase; margin-bottom:14px;
}
.section-title {
  font-family:var(--font-display); font-size:clamp(2rem,5vw,3.8rem);
  font-weight:300; line-height:1.1; color:var(--black);
}
.section-title em { font-style:italic; color:var(--rose-dark); }

/* ── REVEAL ANIMATION ── */
.reveal { opacity:0; transform:translateY(36px); transition:opacity .85s ease, transform .85s ease; }
.reveal.visible { opacity:1; transform:none; }

/* ── BUTTONS ── */
.btn-primary, .btn-ghost, .btn-dark {
  font-family:var(--font-sans); font-size:.66rem; letter-spacing:.3em;
  text-transform:uppercase; text-decoration:none;
  padding:17px 42px; transition:all .35s ease; cursor:none; display:inline-block;
  border:1px solid transparent;
}
.btn-primary { background:var(--gold); color:var(--black); border-color:var(--gold); }
.btn-primary:hover { background:transparent; color:var(--gold); }
.btn-ghost { background:transparent; color:var(--white); border-color:rgba(250,248,245,.28); }
.btn-ghost:hover { border-color:var(--rose); color:var(--rose-light); }
.btn-dark { background:var(--black); color:var(--white); border-color:var(--black); }
.btn-dark:hover { background:var(--gold); border-color:var(--gold); color:var(--black); }
.btn-outline { background:transparent; color:var(--black); border-color:var(--border); }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }

/* ── PRODUCT CARDS (shared) ── */
.products-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px,1fr));
  gap:2px;
}
.product-card { position:relative; background:var(--cream); overflow:hidden; cursor:none; }
.product-img {
  aspect-ratio:3/4;
  position:relative;
  overflow:hidden;
  display:block;
  width:100%;
  /* Ensure the box is established before children position inside it */
  isolation:isolate;
}
.product-img-bg {
  position:absolute; inset:0;
  width:100%; height:100%;
  transition:transform .7s ease;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:5rem; font-style:italic;
}
.product-card:hover .product-img-bg { transform:scale(1.06); }

/* ── Swipeable slides ──
   The track sits inside .product-img which is already overflow:hidden.
   Each slide is exactly 100% wide of .product-img — no absolute positioning
   so aspect-ratio is respected on every mobile browser. */
.pcard-track {
  display:flex;
  width:100%;
  height:100%;
  transition:transform .38s cubic-bezier(.25,.46,.45,.94);
  will-change:transform;
}
.pcard-slide {
  flex:0 0 100%;
  min-width:0;
  width:100%;
  height:100%;
  overflow:hidden;
}
.pcard-slide img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  pointer-events:none;
  /* Prevent image drag interfering with swipe */
  user-select:none;
  -webkit-user-drag:none;
}
.product-badge {
  position:absolute; top:16px; left:16px;
  font-family:var(--font-sans); font-size:.52rem; letter-spacing:.25em;
  text-transform:uppercase; padding:5px 12px; z-index:1;
}
.badge-new { background:var(--gold); color:var(--black); }
.badge-out { background:var(--black); color:var(--white); }
.product-overlay {
  position:absolute; inset:0; background:rgba(12,11,9,.6);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .4s;
}
.product-card:hover .product-overlay { opacity:1; }
.product-overlay-btn {
  font-family:var(--font-sans); font-size:.6rem; letter-spacing:.28em;
  text-transform:uppercase; padding:14px 32px;
  background:var(--white); color:var(--black); border:none; cursor:none;
  transition:background .3s, color .3s;
}
.product-overlay-btn:hover { background:var(--gold); }
.product-info { padding:20px 20px 24px; border-top:1px solid var(--border); }
.product-name { font-family:var(--font-display); font-size:1.15rem; font-weight:400; color:var(--black); letter-spacing:.04em; }
.product-sub { font-family:var(--font-body); font-size:.73rem; font-weight:300; color:var(--muted); margin-top:4px; }
.product-footer { display:flex; align-items:center; justify-content:space-between; margin-top:14px; }
.product-price { font-family:var(--font-display); font-size:1.1rem; color:var(--black); font-weight:500; }
.product-price-out { text-decoration:line-through; color:var(--muted); font-size:.95rem; }
.out-of-stock-label { font-family:var(--font-sans); font-size:.55rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }

/* ── PRODUCT MODAL ── */
.modal-overlay {
  position:fixed; inset:0; background:rgba(12,11,9,.88); z-index:1000;
  display:flex; align-items:center; justify-content:center; padding:24px;
  opacity:0; visibility:hidden; transition:opacity .4s, visibility .4s;
}
.modal-overlay.open { opacity:1; visibility:visible; }
.modal-box {
  background:var(--white); max-width:820px; width:100%;
  max-height:90vh; overflow-y:auto;
  display:grid; grid-template-columns:1fr 1fr;
  position:relative; transform:translateY(28px); transition:transform .4s ease;
}
.modal-overlay.open .modal-box { transform:none; }
.modal-img {
  aspect-ratio:3/4; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:5rem; font-style:italic;
}
.modal-content { padding:44px 36px; display:flex; flex-direction:column; gap:20px; }
.modal-close {
  position:absolute; top:16px; right:20px;
  background:none; border:none; cursor:none;
  font-size:1.3rem; color:var(--white); line-height:1; transition:color .2s;
}
.modal-close:hover { color:var(--gold); }
.modal-tag { font-family:var(--font-sans); font-size:.58rem; letter-spacing:.38em; text-transform:uppercase; color:var(--gold); }
.modal-name { font-family:var(--font-display); font-size:2.1rem; font-weight:300; line-height:1.1; }
.modal-desc { font-family:var(--font-body); font-size:.86rem; font-weight:300; line-height:1.82; color:var(--muted); }
.modal-price { font-family:var(--font-display); font-size:1.55rem; }
.modal-price-out { text-decoration:line-through; color:var(--muted); font-size:1.1rem; }
.modal-sizes { display:flex; gap:8px; flex-wrap:wrap; }
.size-btn {
  font-family:var(--font-body); font-size:.7rem;
  width:44px; height:44px; border:1px solid var(--border);
  background:none; cursor:none; transition:all .25s;
}
.size-btn:hover:not(:disabled) { border-color:var(--black); background:var(--black); color:var(--white); }
.size-btn:disabled { color:var(--muted); text-decoration:line-through; }
.size-btn.selected { border-color:var(--gold); background:var(--gold); color:var(--black); }
.modal-action-wrap { display:flex; flex-direction:column; gap:10px; }
.modal-out-notice {
  background:var(--cream); padding:12px 16px;
  font-family:var(--font-body); font-size:.78rem; color:var(--muted);
  border-left:2px solid var(--rose);
}
.modal-buy-btn {
  padding:16px 32px; font-family:var(--font-sans); font-size:.63rem;
  letter-spacing:.28em; text-transform:uppercase;
  background:var(--black); color:var(--white); border:none; cursor:none;
  transition:all .3s;
}
.modal-buy-btn:hover { background:var(--gold); color:var(--black); }

/* ── BUY / PAYMENT MODAL ── */
.order-modal-overlay {
  position:fixed; inset:0; background:rgba(12,11,9,.92); z-index:1100;
  display:flex; align-items:center; justify-content:center; padding:24px;
  opacity:0; visibility:hidden; transition:opacity .4s, visibility .4s;
}
.order-modal-overlay.open { opacity:1; visibility:visible; }
.order-modal-box {
  background:var(--white); max-width:520px; width:100%;
  max-height:90vh; overflow-y:auto; padding:52px 48px;
  position:relative; transform:translateY(28px); transition:transform .4s;
}
.order-modal-overlay.open .order-modal-box { transform:none; }
.order-modal-close {
  position:absolute; top:20px; right:24px;
  background:none; border:none; cursor:none;
  font-size:1.3rem; color:var(--muted); transition:color .2s;
}
.order-modal-close:hover { color:var(--black); }
.order-modal-eyebrow { font-family:var(--font-sans); font-size:.56rem; letter-spacing:.42em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.order-modal-title { font-family:var(--font-display); font-size:1.9rem; font-weight:300; margin-bottom:8px; }
.order-modal-sub { font-family:var(--font-body); font-size:.82rem; color:var(--muted); font-weight:300; line-height:1.65; margin-bottom:32px; }

/* ── FORM ELEMENTS ── */
.form-field { display:flex; flex-direction:column; gap:6px; margin-bottom:18px; }
.form-field label {
  font-family:var(--font-sans); font-size:.58rem; letter-spacing:.26em;
  text-transform:uppercase; color:var(--muted);
}
.form-field label .req { color:var(--gold); }
.form-field input,
.form-field textarea,
.form-field select {
  font-family:var(--font-body); font-size:.9rem; font-weight:300;
  padding:12px 0; border:none; border-bottom:1px solid var(--border);
  background:none; color:var(--black); outline:none;
  transition:border-color .3s; width:100%; cursor:none;
}
.form-field input:focus,
.form-field textarea:focus { border-color:var(--gold); }
.form-field textarea { resize:vertical; min-height:80px; }
.form-error { font-family:var(--font-body); font-size:.72rem; color:#c0392b; margin-top:4px; display:none; }
.form-error.show { display:block; }

.form-upload-area {
  border:1px dashed var(--border); padding:28px; text-align:center;
  cursor:none; transition:border-color .3s, background .3s; margin-bottom:20px;
}
.form-upload-area:hover { border-color:var(--gold); background:rgba(184,147,90,.04); }
.form-upload-area .upload-title { font-family:var(--font-body); font-size:.88rem; font-weight:300; color:var(--muted); }
.form-upload-area .upload-link { color:var(--gold); text-decoration:underline; }
.form-upload-area .upload-sub { font-family:var(--font-body); font-size:.72rem; color:var(--muted); margin-top:6px; opacity:.6; }
.upload-preview { margin-top:10px; color:var(--gold); font-family:var(--font-body); font-size:.78rem; }
#upload-input { display:none; }

.payment-info {
  background:var(--cream); padding:16px 20px; margin-bottom:22px;
  border-left:2px solid var(--gold);
}
.payment-info p { font-family:var(--font-body); font-size:.82rem; font-weight:300; color:var(--muted); line-height:1.75; }
.payment-info strong { color:var(--black); }

.form-submit {
  width:100%; padding:18px; background:var(--black); color:var(--white);
  font-family:var(--font-sans); font-size:.63rem; letter-spacing:.3em;
  text-transform:uppercase; border:none; cursor:pointer;
  transition:background .3s; margin-top:8px;
}
.form-submit:hover { background:var(--gold); color:var(--black); }

.form-success { display:none; text-align:center; padding:40px 20px; flex-direction:column; gap:14px; align-items:center; }
.form-success.show { display:flex; }
.form-success-icon { font-size:2.8rem; color:var(--gold); }
.form-success-title { font-family:var(--font-display); font-size:1.9rem; font-style:italic; }
.form-success-text { font-family:var(--font-body); font-size:.85rem; font-weight:300; color:var(--muted); line-height:1.78; max-width:320px; }

/* ── FOOTER ── */
footer { background:var(--black); padding:72px 80px 40px; }
.footer-top {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; padding-bottom:52px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.footer-brand-name { font-family:var(--font-display); font-size:1.6rem; font-weight:300; color:var(--white); letter-spacing:.2em; text-transform:uppercase; margin-bottom:6px; }
.footer-tagline { font-family:var(--font-display); font-style:italic; font-size:.95rem; color:var(--muted); margin-bottom:18px; }
.footer-desc { font-family:var(--font-body); font-size:.8rem; font-weight:300; color:rgba(250,248,245,.3); line-height:1.8; }
.footer-col-title { font-family:var(--font-sans); font-size:.58rem; letter-spacing:.32em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-links a { font-family:var(--font-body); font-size:.82rem; font-weight:300; color:rgba(250,248,245,.38); text-decoration:none; transition:color .3s; }
.footer-links a:hover { color:var(--white); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:32px; flex-wrap:wrap; gap:16px; }
.footer-copy { font-family:var(--font-body); font-size:.73rem; font-weight:300; color:rgba(250,248,245,.2); }
.footer-bottom-links { display:flex; gap:24px; }
.footer-bottom-links a { font-family:var(--font-sans); font-size:.56rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(250,248,245,.2); text-decoration:none; transition:color .3s; }
.footer-bottom-links a:hover { color:var(--gold); }

/* ── TOAST ── */
.toast {
  position:fixed; bottom:32px; right:32px;
  background:var(--black); color:var(--white);
  padding:16px 28px; font-family:var(--font-body); font-size:.82rem; font-weight:300;
  z-index:2000; transform:translateY(20px); opacity:0;
  transition:all .4s ease; border-left:2px solid var(--gold); pointer-events:none;
}
.toast.show { transform:none; opacity:1; }

/* ── KEYFRAMES ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:none} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes rotateSlow { to{transform:translate(-50%,-50%) rotate(360deg)} }
@keyframes scrollPulse { 0%,100%{transform:scaleY(1);opacity:.6} 50%{transform:scaleY(.5);opacity:.15} }

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  .footer-top { grid-template-columns:1fr 1fr; gap:40px; }
}
@media (max-width:768px) {
  nav { padding:0 24px; }
  .nav-links { display:none; }
  .nav-hamburger { display:flex; }
  .modal-box {
    grid-template-columns:1fr;
    max-height:92vh;
    overflow-y:auto;
    /* Prevent modal from being wider than viewport */
    max-width:100%;
    border-radius:0;
  }
  .modal-img {
    /* Square on mobile for best photo display */
    aspect-ratio:1/1 !important;
    min-height:260px;
    max-height:55vw;
    width:100%;
    flex-shrink:0;
    overflow:hidden;
  }
  .modal-img img {
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    display:block !important;
  }
  .modal-content {
    padding:24px 20px 32px;
    gap:14px;
  }
  .modal-name { font-size:1.55rem; }
  .modal-close { color:rgba(255,255,255,.9); top:10px; right:12px; font-size:1.5rem; z-index:10; }
  .order-modal-box { padding:40px 28px; }
  .footer-top { grid-template-columns:1fr; }
  footer { padding:56px 24px 32px; }
}
@media (max-width:480px) {
  .products-grid { grid-template-columns:1fr 1fr; gap:1px; }
  /* On touch devices arrows are always slightly visible */
  .pcard-arrow { opacity:0.55 !important; }
  /* Tighter card layout on small screens */
  .product-info { padding:14px 12px 18px; }
  .product-name { font-size:1rem; }
}

/* ── MOBILE RESPONSIVE ── */
@media (max-width:768px) {
  /* Hero — keep text inside circle */
  .hero-circle {
    width: clamp(260px, 88vw, 340px) !important;
    height: clamp(260px, 88vw, 340px) !important;
  }
  .hero-content { padding: 0 32px; max-width: 320px; margin: 0 auto; }
  .hero-eyebrow { font-size: .52rem; letter-spacing: .32em; margin-bottom: 18px; }
  .hero-divider { height: 32px; margin: 16px auto; }
  .hero-subtitle { font-size: clamp(.8rem, 3.5vw, 1rem); }
  .hero-cta { margin-top: 28px; gap: 12px; }
  .hero-scroll { display: none; }

  /* Nav */
  .nav-right { gap: 12px; }

  /* Delivery radio buttons — stack vertically on mobile */
  .delivery-method-row {
    flex-direction: column !important;
    gap: 8px !important;
  }
  .delivery-method-row label {
    min-width: 0 !important;
    width: 100% !important;
    flex: none !important;
  }

  /* Cart drawer full width */
  .cart-drawer { width: 100vw !important; }

  /* Checkout box single column */
  .checkout-box { grid-template-columns: 1fr !important; }

  /* Cart items layout on small screen */
  .cart-item { grid-template-columns: 60px 1fr; gap: 10px; }
  .cart-item-controls { grid-column: 1/-1; display: flex; flex-direction: row; align-items: center; gap: 12px; justify-content: space-between; }
}

@media (max-width:480px) {
  /* Hero title smaller to stay in circle */
  .hero-title { font-size: clamp(2.4rem, 10vw, 3.2rem) !important; letter-spacing: .06em; }
  .hero-title em { font-size: .7em; letter-spacing: .12em; }
  .hero-eyebrow { display: none; }
  .hero-divider { display: none; }
  .hero-subtitle { font-size: .82rem; }
  .hero-cta { margin-top: 20px; }

  /* Nav — show only logo + cart + hamburger */
  .nav-links { display: none !important; }
  .nav-hamburger { display: flex !important; }

  /* Cart */
  .cart-body { padding: 16px 20px; }
  .cart-header { padding: 20px 20px 14px; }
  .cart-footer { padding: 12px 20px 20px; }

  /* Checkout */
  .checkout-summary-panel { padding: 24px 20px; }
  .checkout-form-panel { padding: 24px 20px; }

  /* Collection cards */
  .collection-card { aspect-ratio: 3/4; }
}
