/* =========================================================
   Alan K. Thau — Luxury Jewelry
   Palette: deep burgundy/wine + champagne gold + cream
   ========================================================= */

:root {
  --wine:        #6b2d42;
  --wine-deep:   #511f31;
  --wine-dark:   #3a1623;
  --gold:        #c9a24b;
  --gold-soft:   #e3c987;
  --gold-deep:   #a8842f;
  --cream:       #f7f1e9;
  --cream-2:     #efe6d8;
  --ink:         #21161a;
  --muted:       #8a7a80;
  --white:       #ffffff;
  --line:        rgba(107, 45, 66, 0.14);
  --shadow:      0 18px 50px -22px rgba(58, 22, 35, 0.45);
  --shadow-sm:   0 8px 24px -14px rgba(58, 22, 35, 0.4);
  --serif:       'Cormorant Garamond', Georgia, serif;
  --sans:        'Jost', 'Segoe UI', system-ui, sans-serif;
  --r:           14px;
  --container:   1240px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.65;
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; transition: color .25s ease; }
ul { list-style: none; }

h1, h2, h3, h4 { font-family: var(--serif); font-weight: 600; line-height: 1.1; letter-spacing: .4px; }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 28px; }

.eyebrow {
  font-family: var(--sans);
  text-transform: uppercase;
  letter-spacing: 4px;
  font-size: .72rem;
  font-weight: 500;
  color: var(--gold-deep);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.eyebrow::before { content: ""; width: 30px; height: 1px; background: var(--gold); }
.eyebrow.center { justify-content: center; }
.eyebrow.center::after { content: ""; width: 30px; height: 1px; background: var(--gold); }

.section { padding: 100px 0; }
.section-head { text-align: center; max-width: 620px; margin: 0 auto 60px; }
.section-head h2 { font-size: clamp(2rem, 4vw, 3rem); margin: 18px 0 14px; color: var(--wine-deep); }
.section-head p { color: var(--muted); font-size: 1.02rem; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--sans); font-weight: 500; letter-spacing: 1.5px;
  text-transform: uppercase; font-size: .76rem;
  padding: 15px 32px; border-radius: 60px; cursor: pointer; border: 1px solid transparent;
  transition: transform .3s ease, box-shadow .3s ease, background .3s ease, color .3s ease;
}
.btn-gold { background: linear-gradient(135deg, var(--gold-soft), var(--gold)); color: var(--wine-dark); box-shadow: var(--shadow-sm); }
.btn-gold:hover { transform: translateY(-3px); box-shadow: 0 16px 30px -14px rgba(168,132,47,.7); }
.btn-outline { border-color: var(--gold); color: var(--wine-deep); }
.btn-outline:hover { background: var(--wine-deep); color: var(--cream); border-color: var(--wine-deep); }
.btn-light { border-color: rgba(255,255,255,.5); color: #fff; }
.btn-light:hover { background: #fff; color: var(--wine-deep); }

/* ---------- Announcement ---------- */
.topbar {
  background: var(--wine-dark); color: var(--cream-2);
  padding: 6px 0; font-weight: 400;
}
.topbar-inner { display: flex; align-items: center; gap: 16px; flex-wrap: nowrap; }
.topbar-msg { flex: 1; min-width: 0; text-align: center; font-size: .73rem; letter-spacing: 1.8px; text-transform: uppercase; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.topbar-msg span { color: var(--gold-soft); }
.topbar-tools { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
/* compact dropdowns sitting on the dark top bar */
.topbar .lc-dd-btn { border-color: rgba(255,255,255,.26); color: var(--cream-2); padding: 5px 11px; font-size: .72rem; }
.topbar .lc-dd-btn:hover { border-color: var(--gold); background: rgba(255,255,255,.08); }
.topbar .lc-dd-sym { color: var(--gold-soft); }
.topbar .lc-dd-cv { opacity: .7; }
@media (max-width: 600px) {
  .topbar-msg { display: none; }
  .topbar-inner { justify-content: flex-end; }
}

/* ---------- Search overlay ---------- */
.search-overlay { position: fixed; inset: 0; z-index: 999; display: flex; align-items: flex-start; justify-content: center; padding-top: 12vh; opacity: 0; pointer-events: none; transition: opacity .25s ease; }
.search-overlay.open { opacity: 1; pointer-events: auto; }
.search-overlay-bg { position: absolute; inset: 0; background: rgba(33,22,26,.55); backdrop-filter: blur(6px); }
.search-box { position: relative; width: 100%; max-width: 580px; background: var(--white); border-radius: 16px; box-shadow: 0 24px 80px -16px rgba(33,22,26,.45); overflow: hidden; transform: translateY(-18px); transition: transform .3s ease; margin: 0 20px; }
.search-overlay.open .search-box { transform: translateY(0); }
.search-box-head { display: flex; align-items: center; gap: 12px; padding: 18px 22px; border-bottom: 1px solid var(--line); }
.search-box-head svg { flex-shrink: 0; color: var(--muted); }
.search-box-head input { flex: 1; border: none; outline: none; font-family: var(--sans); font-size: 1.05rem; background: transparent; color: var(--ink); }
.search-box-head input::placeholder { color: var(--muted); }
#searchClose { background: none; border: none; font-size: 1.6rem; color: var(--muted); cursor: pointer; line-height: 1; padding: 0 4px; transition: color .2s; }
#searchClose:hover { color: var(--ink); }
.search-results { max-height: 60vh; overflow-y: auto; }
.search-results:empty::after { content: none; }
.search-empty { padding: 40px 22px; text-align: center; color: var(--muted); font-size: .95rem; }
.search-item { display: flex; align-items: center; gap: 16px; padding: 14px 22px; text-decoration: none; color: var(--ink); transition: background .15s; }
.search-item:hover { background: var(--cream); }
.search-item img { width: 52px; height: 52px; object-fit: cover; border-radius: 8px; flex-shrink: 0; }
.search-item-info { flex: 1; min-width: 0; }
.search-item-info h4 { font-family: var(--serif); font-size: 1rem; font-weight: 500; margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.search-item-info small { color: var(--muted); font-size: .8rem; }
.search-item-price { font-weight: 500; color: var(--wine-deep); white-space: nowrap; font-size: .95rem; }
.search-links { display: flex; gap: 10px; padding: 14px 22px; border-top: 1px solid var(--line); }
.search-links a { font-size: .85rem; color: var(--gold-deep); font-weight: 400; }
.search-links a:hover { text-decoration: underline; }

/* ---------- Header ---------- */
.header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(247, 241, 233, 0.85);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
  transition: padding .3s ease, background .3s ease;
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 84px; }
.brand img { height: 46px; width: auto; border-radius: 6px; }
.nav-links { display: flex; gap: 38px; }
.nav-links a {
  text-transform: uppercase; letter-spacing: 2px; font-size: .78rem; font-weight: 500;
  color: var(--wine-deep); position: relative; padding: 6px 0;
}
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 1.5px;
  background: var(--gold); transition: width .3s ease;
}
.nav-links a:hover::after, .nav-links a.active::after { width: 100%; }
.nav-links a:hover { color: var(--gold-deep); }
.nav-actions { display: flex; align-items: center; gap: 12px; }
/* language / currency dropdowns */
.lc-dd { position: relative; }
.lc-dd-btn { display: inline-flex; align-items: center; gap: 7px; background: transparent; border: 1px solid var(--line); border-radius: 30px; padding: 7px 12px; cursor: pointer; font-family: var(--sans); font-size: .76rem; letter-spacing: .5px; color: var(--wine-deep); transition: border-color .15s, background .15s; }
.lc-dd-btn:hover { border-color: var(--gold); background: #fff; }
.lc-dd-cur { white-space: nowrap; font-weight: 500; }
.lc-dd-sym { color: var(--gold-deep); }
.lc-dd-cv { opacity: .55; transition: transform .2s; }
.lc-dd.open .lc-dd-cv { transform: rotate(180deg); }
.lc-dd-menu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 190px; background: #fff; border: 1px solid var(--line); border-radius: 12px; box-shadow: var(--shadow); padding: 7px; opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity .18s, transform .18s, visibility .18s; z-index: 120; }
.lc-dd.open .lc-dd-menu { opacity: 1; visibility: visible; transform: none; }
.lc-dd-head { display: block; font-size: .62rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); padding: 8px 12px 6px; }
.lc-dd-menu a { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 10px 12px; border-radius: 8px; font-size: .9rem; color: var(--ink); transition: background .12s; }
.lc-dd-menu a small { color: var(--muted); font-size: .72rem; letter-spacing: .5px; }
.lc-dd-menu a:hover { background: var(--cream); }
.lc-dd-menu a.on { background: var(--wine-deep); color: var(--cream); font-weight: 500; }
.lc-dd-menu a.on small { color: var(--gold-soft); }
.lc-dd-auto { display: block; font-size: .68rem; color: var(--gold-deep); padding: 8px 12px 4px; border-top: 1px solid var(--line); margin-top: 4px; }
/* keep the short labels (English / USD $) visible in the top bar at all sizes */
@media (max-width: 600px) { .lc-dd-menu { right: 0; } }
.icon-btn { background: none; border: none; cursor: pointer; color: var(--wine-deep); display: inline-flex; position: relative; }
.icon-btn:hover { color: var(--gold-deep); }
.icon-btn svg { width: 22px; height: 22px; }
.cart-count {
  position: absolute; top: -8px; right: -10px; background: var(--gold);
  color: var(--wine-dark); font-size: .62rem; font-weight: 700;
  width: 17px; height: 17px; border-radius: 50%; display: grid; place-items: center;
}
.burger { display: none; background: none; border: none; cursor: pointer; flex-direction: column; gap: 5px; }
.burger span { width: 26px; height: 2px; background: var(--wine-deep); transition: .3s; }

/* ---------- Hero ---------- */
.hero {
  position: relative; min-height: 88vh; display: flex; align-items: center;
  background:
    radial-gradient(circle at 75% 30%, rgba(201,162,75,.18), transparent 55%),
    linear-gradient(135deg, var(--wine-dark) 0%, var(--wine) 55%, var(--wine-deep) 100%);
  color: var(--cream); overflow: hidden;
}
.hero::after {
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M30 0L60 30 30 60 0 30z' fill='none' stroke='%23c9a24b' stroke-opacity='0.05'/%3E%3C/svg%3E");
  pointer-events: none;
}
.hero .container { display: grid; grid-template-columns: 1.05fr .95fr; gap: 50px; align-items: center; position: relative; z-index: 2; }
.hero-copy .eyebrow { color: var(--gold-soft); }
.hero-copy .eyebrow::before { background: var(--gold-soft); }
.hero-copy h1 { font-size: clamp(2.8rem, 5.5vw, 4.8rem); margin: 22px 0; line-height: 1.04; }
.hero-copy h1 em { font-style: italic; color: var(--gold-soft); }
.hero-copy p { font-size: 1.12rem; max-width: 460px; color: rgba(247,241,233,.85); margin-bottom: 34px; font-weight: 300; }
.hero-cta { display: flex; gap: 16px; flex-wrap: wrap; }
.hero-stats { display: flex; gap: 40px; margin-top: 48px; }
.hero-stats div span { font-family: var(--serif); font-size: 2.1rem; color: var(--gold-soft); display: block; }
.hero-stats div small { text-transform: uppercase; letter-spacing: 2px; font-size: .68rem; color: rgba(247,241,233,.7); }

.hero-visual { position: relative; display: grid; place-items: center; }
.hero-visual .frame {
  position: relative; border-radius: 220px 220px 18px 18px; overflow: hidden;
  border: 1px solid rgba(201,162,75,.4); box-shadow: 0 40px 80px -30px rgba(0,0,0,.6);
  background: var(--cream);
}
.hero-visual .frame img { width: 100%; aspect-ratio: 3/4; object-fit: cover; }
.hero-badge {
  position: absolute; bottom: 22px; left: -26px;
  background: var(--cream); color: var(--wine-deep); border-radius: 12px;
  padding: 14px 20px; box-shadow: var(--shadow); display: flex; align-items: center; gap: 12px;
}
.hero-badge .dot { width: 38px; height: 38px; border-radius: 50%; background: linear-gradient(135deg,var(--gold-soft),var(--gold)); display: grid; place-items: center; color: var(--wine-dark); font-weight: 700; }
.hero-badge b { font-family: var(--serif); font-size: 1.05rem; display: block; }
.hero-badge small { color: var(--muted); font-size: .72rem; letter-spacing: 1px; }

/* ---------- Marquee strip ---------- */
.strip { background: var(--wine-deep); color: var(--cream-2); padding: 22px 0; overflow: hidden; }
.strip-track { display: flex; gap: 60px; white-space: nowrap; animation: scroll 28s linear infinite; }
.strip-track span { font-family: var(--serif); font-size: 1.3rem; font-style: italic; display: inline-flex; align-items: center; gap: 60px; color: var(--gold-soft); }
.strip-track span::after { content: "✦"; color: var(--gold); }
@keyframes scroll { from { transform: translateX(0);} to { transform: translateX(-50%);} }

/* ---------- Categories ---------- */
.cats { background: var(--cream); }
.cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.cat-card {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--r);
  padding: 40px 26px; text-align: center; transition: transform .35s ease, box-shadow .35s ease, border-color .35s;
  position: relative; overflow: hidden;
}
.cat-card::before {
  content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(107,45,66,.04));
  opacity: 0; transition: opacity .35s;
}
.cat-card:hover { transform: translateY(-8px); box-shadow: var(--shadow); border-color: var(--gold-soft); }
.cat-card:hover::before { opacity: 1; }
.cat-thumb { width: 110px; height: 110px; margin: 0 auto 22px; border-radius: 50%; background: var(--cream-2); display: grid; place-items: center; overflow: hidden; border: 1px solid var(--line); }
.cat-thumb img { width: 78%; height: 78%; object-fit: contain; mix-blend-mode: multiply; }
.cat-card h3 { font-size: 1.5rem; color: var(--wine-deep); margin-bottom: 6px; }
.cat-card p { color: var(--muted); font-size: .82rem; letter-spacing: .5px; }
.cat-card .arrow { margin-top: 16px; color: var(--gold-deep); font-size: .74rem; text-transform: uppercase; letter-spacing: 2px; font-weight: 500; }

/* ---------- Products ---------- */
.prod-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.product { background: var(--white); border-radius: var(--r); overflow: hidden; border: 1px solid var(--line); transition: transform .35s ease, box-shadow .35s ease; }
.product-link { display: block; color: inherit; text-decoration: none; }
.product-body .stars small { color: var(--muted); font-size: .78rem; }
.product:hover { transform: translateY(-8px); box-shadow: var(--shadow); }
.product-media { position: relative; aspect-ratio: 1/1; background: var(--cream-2); overflow: hidden; }
.product-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.product:hover .product-media img { transform: scale(1.07); }
.product-tag { position: absolute; top: 14px; left: 14px; background: var(--wine-deep); color: var(--gold-soft); font-size: .62rem; text-transform: uppercase; letter-spacing: 1.6px; padding: 6px 12px; border-radius: 30px; }
.product-tag.sale { background: var(--gold); color: var(--wine-dark); }
.product-fav { position: absolute; top: 12px; right: 12px; background: rgba(255,255,255,.9); border: none; width: 36px; height: 36px; border-radius: 50%; display: grid; place-items: center; cursor: pointer; color: var(--wine-deep); opacity: 0; transform: translateY(-6px); transition: .3s; }
.product:hover .product-fav { opacity: 1; transform: translateY(0); }
.product-fav:hover { background: var(--wine-deep); color: var(--gold-soft); }
.product-add {
  position: absolute; bottom: 0; left: 0; right: 0; background: var(--wine-deep); color: var(--cream);
  text-align: center; padding: 14px; text-transform: uppercase; letter-spacing: 2px; font-size: .72rem; font-weight: 500;
  border: none; cursor: pointer; transform: translateY(100%); transition: transform .35s ease; width: 100%;
}
.product:hover .product-add { transform: translateY(0); }
.product-add:hover { background: var(--gold); color: var(--wine-dark); }
.product-body { padding: 20px 20px 24px; text-align: center; }
.product-cat { font-size: .68rem; text-transform: uppercase; letter-spacing: 2px; color: var(--gold-deep); }
.product-body h3 { font-size: 1.28rem; margin: 6px 0 8px; color: var(--wine-deep); font-weight: 600; }
.stars { color: var(--gold); font-size: .82rem; letter-spacing: 2px; margin-bottom: 10px; }
.price { font-family: var(--sans); font-weight: 600; font-size: 1.18rem; letter-spacing: .01em; color: var(--wine-deep); font-variant-numeric: tabular-nums lining-nums; white-space: nowrap; }
.price del { color: var(--muted); font-weight: 400; font-size: .9rem; margin-right: 8px; }
.shop-cta { text-align: center; margin-top: 56px; }

/* ---------- Feature banner (diamonds) ---------- */
.feature {
  background: linear-gradient(135deg, var(--wine-dark), var(--wine)); color: var(--cream);
  position: relative; overflow: hidden;
}
.feature .container { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.feature-media { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.feature-media img { border-radius: 12px; border: 1px solid rgba(201,162,75,.3); aspect-ratio: 4/3; object-fit: cover; }
.feature-media img:first-child { margin-top: 30px; }
.feature-copy .eyebrow { color: var(--gold-soft); }
.feature-copy .eyebrow::before { background: var(--gold-soft); }
.feature-copy h2 { font-size: clamp(2rem,4vw,3.1rem); margin: 18px 0 18px; }
.feature-copy h2 em { font-style: italic; color: var(--gold-soft); }
.feature-copy p { color: rgba(247,241,233,.82); margin-bottom: 26px; max-width: 480px; }
.cert-row { display: flex; gap: 14px; margin-bottom: 34px; flex-wrap: wrap; }
.cert { border: 1px solid rgba(201,162,75,.4); border-radius: 8px; padding: 10px 18px; font-family: var(--serif); font-size: 1.2rem; letter-spacing: 2px; color: var(--gold-soft); }

/* ---------- Promise / values ---------- */
.values { background: var(--cream-2); }
.value-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.value { background: var(--white); border-radius: var(--r); padding: 36px 26px; text-align: center; border: 1px solid var(--line); transition: transform .3s ease; }
.value:hover { transform: translateY(-6px); }
.value-ic { width: 58px; height: 58px; margin: 0 auto 18px; border-radius: 50%; background: linear-gradient(135deg, var(--wine), var(--wine-deep)); display: grid; place-items: center; color: var(--gold-soft); }
.value-ic svg { width: 26px; height: 26px; }
.value h3 { font-size: 1.3rem; color: var(--wine-deep); margin-bottom: 8px; }
.value p { color: var(--muted); font-size: .88rem; }

/* ---------- Gallery (10-image masonry) ---------- */
.gallery-grid { display: grid; grid-template-columns: repeat(5, 1fr); grid-auto-rows: 180px; gap: 12px; }
.gallery-grid a { overflow: hidden; border-radius: 12px; position: relative; }
.gallery-grid img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s ease; }
.gallery-grid a:hover img { transform: scale(1.08); }
.gallery-grid a::after { content: "↗"; position: absolute; inset: 0; background: rgba(58,22,35,.4); color: var(--gold-soft); display: grid; place-items: center; font-size: 1.6rem; opacity: 0; transition: .3s; }
.gallery-grid a:hover::after { opacity: 1; }
.g-tall { grid-row: span 2; }
.g-wide { grid-column: span 2; }

/* ---------- Testimonials ---------- */
.reviews { background: var(--cream); }
.review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.review { background: var(--white); border-radius: var(--r); padding: 38px 32px; border: 1px solid var(--line); position: relative; box-shadow: var(--shadow-sm); }
.review .stars { font-size: 1rem; }
.review .quote { font-family: var(--serif); font-size: 1.7rem; color: var(--gold-soft); line-height: 0; position: absolute; top: 30px; right: 30px; }
.review h4 { font-size: 1.15rem; color: var(--wine-deep); margin-bottom: 10px; }
.review p { color: var(--muted); font-size: .95rem; }
.review-who { display: flex; align-items: center; gap: 12px; margin-top: 22px; }
.review-who .av { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg,var(--gold-soft),var(--gold)); color: var(--wine-dark); display: grid; place-items: center; font-weight: 700; font-family: var(--serif); }
.review-who b { color: var(--ink); font-weight: 500; }
.review-who small { display: block; color: var(--muted); font-size: .74rem; letter-spacing: 1px; }

/* ---------- FAQ ---------- */
.faq { background: var(--cream-2); }
.faq-wrap { max-width: 800px; margin: 0 auto; }
.faq-item { background: var(--white); border: 1px solid var(--line); border-radius: 12px; margin-bottom: 14px; overflow: hidden; }
.faq-q { width: 100%; text-align: left; background: none; border: none; padding: 22px 26px; cursor: pointer; font-family: var(--serif); font-size: 1.25rem; color: var(--wine-deep); display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq-q .pm { color: var(--gold-deep); font-size: 1.5rem; transition: transform .3s; flex-shrink: 0; }
.faq-item.open .pm { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.faq-a p { padding: 0 26px 24px; color: var(--muted); }

/* ---------- Newsletter ---------- */
.newsletter { background: linear-gradient(135deg, var(--wine-dark), var(--wine-deep)); color: var(--cream); text-align: center; }
.newsletter h2 { font-size: clamp(2rem,4vw,3rem); margin: 16px 0 12px; }
.newsletter h2 em { font-style: italic; color: var(--gold-soft); }
.newsletter p { color: rgba(247,241,233,.8); max-width: 520px; margin: 0 auto 30px; }
.subscribe { display: flex; max-width: 480px; margin: 0 auto; gap: 10px; }
.subscribe input { flex: 1; border: 1px solid rgba(201,162,75,.4); background: rgba(255,255,255,.06); color: var(--cream); padding: 15px 22px; border-radius: 60px; font-family: var(--sans); outline: none; }
.subscribe input::placeholder { color: rgba(247,241,233,.5); }
.subscribe input:focus { border-color: var(--gold); }

/* ---------- Footer ---------- */
.footer { background: var(--wine-dark); color: rgba(247,241,233,.7); padding: 70px 0 0; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 50px; }
.footer-brand img { height: 50px; border-radius: 6px; margin-bottom: 20px; }
.footer-brand p { font-size: .92rem; max-width: 300px; margin-bottom: 22px; }
.socials { display: flex; gap: 12px; }
.socials a { width: 40px; height: 40px; border-radius: 50%; border: 1px solid rgba(201,162,75,.3); display: grid; place-items: center; color: var(--gold-soft); }
.socials a:hover { background: var(--gold); color: var(--wine-dark); border-color: var(--gold); }
.socials svg { width: 18px; height: 18px; }
.footer h4 { font-family: var(--sans); text-transform: uppercase; letter-spacing: 2px; font-size: .8rem; color: var(--gold-soft); margin-bottom: 22px; font-weight: 600; }
.footer-col a { display: block; margin-bottom: 12px; font-size: .92rem; }
.footer-col a:hover { color: var(--gold-soft); padding-left: 4px; }
.footer-col .contact-line { display: flex; gap: 10px; margin-bottom: 12px; font-size: .92rem; align-items: center; }
.footer-col .contact-line svg { width: 16px; height: 16px; color: var(--gold-soft); flex-shrink: 0; }
.footer-col a.contact-line:hover { color: var(--gold-soft); }
.footer-bottom { border-top: 1px solid rgba(201,162,75,.18); padding: 24px 0; display: flex; justify-content: space-between; align-items: center; font-size: .82rem; flex-wrap: wrap; gap: 12px; }
.footer-bottom a:hover { color: var(--gold-soft); }

/* ---------- Page hero (sub pages) ---------- */
.page-hero { background: linear-gradient(135deg, var(--wine-dark), var(--wine)); color: var(--cream); text-align: center; padding: 80px 0; position: relative; }
.page-hero h1 { font-size: clamp(2.4rem,5vw,3.6rem); margin: 16px 0 10px; }
.page-hero p { color: rgba(247,241,233,.8); max-width: 560px; margin: 0 auto; }
.crumbs { font-size: .76rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold-soft); margin-top: 14px; }
.crumbs a:hover { color: #fff; }

/* ---------- About page ---------- */
.about-founder-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.about-founder-img img { border-radius: 16px; width: 100%; aspect-ratio: 4/5; object-fit: cover; object-position: top; box-shadow: var(--shadow); }
.about-founder-text .eyebrow { margin-bottom: 16px; }
.about-founder-text h2 { font-size: clamp(1.8rem,3.5vw,2.8rem); color: var(--wine-deep); margin-bottom: 20px; }
.about-founder-text p { color: var(--muted); margin-bottom: 16px; line-height: 1.8; }
.about-mission { background: var(--cream-2); }
.about-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 48px; }
.about-pillar { background: var(--white); border-radius: var(--r); padding: 40px 28px; text-align: center; border: 1px solid var(--line); transition: transform .3s ease; }
.about-pillar:hover { transform: translateY(-6px); }
.about-pillar-ic { width: 62px; height: 62px; margin: 0 auto 20px; border-radius: 50%; background: linear-gradient(135deg, var(--wine), var(--wine-deep)); display: grid; place-items: center; color: var(--gold-soft); }
.about-pillar-ic svg { width: 28px; height: 28px; }
.about-pillar h3 { font-size: 1.3rem; color: var(--wine-deep); margin-bottom: 10px; }
.about-pillar p { color: var(--muted); font-size: .9rem; line-height: 1.7; }
.about-numbers { background: linear-gradient(135deg, var(--wine-dark), var(--wine-deep)); }
.about-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.about-stat { text-align: center; padding: 32px 16px; }
.about-stat-num { display: block; font-family: var(--serif); font-size: clamp(2rem,4vw,3rem); font-weight: 600; color: var(--gold-soft); margin-bottom: 8px; }
.about-stat-lbl { font-size: .85rem; color: rgba(247,241,233,.7); letter-spacing: .5px; }
.about-cta { background: var(--cream-2); }
@media (max-width: 1024px) {
  .about-founder-grid { grid-template-columns: 1fr; gap: 36px; }
  .about-founder-img img { max-width: 420px; margin: 0 auto; }
  .about-pillars { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .about-stats { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- Shop toolbar / filters ---------- */
.shop-layout { display: grid; grid-template-columns: 240px 1fr; gap: 40px; }
.filters { position: sticky; top: 110px; align-self: start; }
.filter-block { border-bottom: 1px solid var(--line); padding-bottom: 22px; margin-bottom: 22px; }
.filter-block h4 { font-family: var(--sans); text-transform: uppercase; letter-spacing: 2px; font-size: .76rem; color: var(--wine-deep); margin-bottom: 16px; }
.filter-block label { display: flex; align-items: center; gap: 10px; font-size: .9rem; color: var(--muted); margin-bottom: 10px; cursor: pointer; }
.filter-block label:hover { color: var(--wine-deep); }
.filter-block input { accent-color: var(--wine); }
.chip-row { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { border: 1px solid var(--line); border-radius: 30px; padding: 6px 14px; font-size: .8rem; cursor: pointer; color: var(--muted); transition: .25s; }
.chip:hover, .chip.active { background: var(--wine-deep); color: var(--cream); border-color: var(--wine-deep); }
.shop-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; flex-wrap: wrap; gap: 14px; }
.shop-toolbar .count { color: var(--muted); font-size: .9rem; }
.shop-toolbar select { border: 1px solid var(--line); border-radius: 30px; padding: 10px 18px; font-family: var(--sans); color: var(--wine-deep); background: var(--white); cursor: pointer; }
.shop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }

/* ---------- Collection page ---------- */
.collection-row { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 0; }
.collection-row img { width: 100%; aspect-ratio: 4/3; object-fit: cover; object-position: top; }
.collection-text { padding: 70px; }
.collection-text .eyebrow { margin-bottom: 18px; }
.collection-text h2 { font-size: clamp(1.8rem,3.5vw,2.8rem); color: var(--wine-deep); margin-bottom: 16px; }
.collection-text p { color: var(--muted); margin-bottom: 24px; }
.collection-row.alt { background: var(--cream-2); }
.collection-row.alt .collection-text { order: -1; }

/* ---------- Legal / Policy pages ---------- */
.policy { background: var(--cream); }
.policy-wrap { max-width: 860px; margin: 0 auto; }
.policy-meta { color: var(--muted); font-size: .82rem; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 38px; padding-bottom: 22px; border-bottom: 1px solid var(--line); }
.policy-intro { font-size: 1.12rem; color: var(--ink); font-family: var(--serif); font-style: italic; line-height: 1.55; margin-bottom: 44px; }
.policy-block { margin-bottom: 38px; }
.policy-block h2 { font-size: 1.65rem; color: var(--wine-deep); margin-bottom: 14px; display: flex; align-items: baseline; gap: 14px; }
.policy-block h2 .num { font-size: .9rem; color: var(--gold-deep); font-family: var(--sans); font-weight: 600; letter-spacing: 1px; flex-shrink: 0; }
.policy-block h3 { font-size: 1.05rem; color: var(--wine-deep); margin: 18px 0 8px; font-family: var(--sans); text-transform: uppercase; letter-spacing: 1.5px; font-weight: 600; }
.policy-block p { color: var(--ink); opacity: .85; margin-bottom: 14px; }
/* Bullet lists — styled whether or not the .bullets class is present (WYSIWYG outputs plain <ul>) */
.policy-block ul.bullets, .policy-block ul, .policy-body ul { margin: 14px 0 14px 4px; list-style: none; padding-left: 0; }
.policy-block ul.bullets li, .policy-block ul li, .policy-body ul li { position: relative; padding-left: 26px; margin-bottom: 12px; color: var(--ink); opacity: .85; }
.policy-block ul.bullets li::before, .policy-block ul li::before, .policy-body ul li::before { content: ""; position: absolute; left: 4px; top: 11px; width: 7px; height: 7px; background: var(--gold); transform: rotate(45deg); }
/* Numbered steps — styled whether or not the .steps class is present (WYSIWYG outputs plain <ol>) */
.policy-block ol.steps, .policy-block ol, .policy-body ol { counter-reset: s; margin: 14px 0; list-style: none; padding-left: 0; }
.policy-block ol.steps li, .policy-block ol li, .policy-body ol li { counter-increment: s; position: relative; padding-left: 50px; margin-bottom: 18px; color: var(--ink); opacity: .9; min-height: 34px; display: flex; align-items: center; }
.policy-block ol.steps li::before, .policy-block ol li::before, .policy-body ol li::before { content: counter(s); position: absolute; left: 0; top: 0; width: 34px; height: 34px; border-radius: 50%; background: linear-gradient(135deg,var(--gold-soft),var(--gold)); color: var(--wine-dark); display: grid; place-items: center; font-family: var(--serif); font-weight: 700; font-size: 1rem; }

/* Single-editor policy body — headings auto-numbered (01, 02, …) like sections */
.policy-body { counter-reset: secn; }
.policy-body h2 { counter-increment: secn; font-family: var(--serif); font-size: 1.65rem; color: var(--wine-deep); margin: 40px 0 14px; display: flex; align-items: baseline; gap: 14px; font-weight: 600; }
.policy-body h2::before { content: counter(secn, decimal-leading-zero); font-family: var(--sans); font-size: .9rem; font-weight: 600; letter-spacing: 1px; color: var(--gold-deep); flex-shrink: 0; }
.policy-body > h2:first-child { margin-top: 0; }
.policy-body h3 { font-family: var(--sans); text-transform: uppercase; letter-spacing: 1.5px; font-size: 1.05rem; color: var(--wine-deep); margin: 20px 0 8px; font-weight: 600; }
.policy-body p { color: var(--ink); opacity: .85; margin-bottom: 14px; }
.policy-body p:first-child { font-family: var(--serif); font-style: italic; font-size: 1.12rem; line-height: 1.55; opacity: 1; margin-bottom: 30px; }
.policy-body strong { color: var(--wine-deep); }
.policy-body a { color: var(--gold-deep); }
.policy-body a:hover { text-decoration: underline; }
.policy-body em { color: var(--muted); }
.policy-callout { background: var(--white); border: 1px solid var(--line); border-left: 3px solid var(--gold); border-radius: 10px; padding: 22px 26px; margin: 24px 0; box-shadow: var(--shadow-sm); }
.policy-callout p { margin: 0; color: var(--wine-deep); }
.policy-callout a { color: var(--gold-deep); font-weight: 500; }
.policy-callout a:hover { text-decoration: underline; }
.policy-note { font-size: .9rem; color: var(--muted); font-style: italic; margin-top: 40px; padding-top: 22px; border-top: 1px solid var(--line); }

/* ---------- Diamond vault (DiamX) ---------- */
.dx{ --dxsoft:#f6f1ea; --dxchevron:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' fill='none' stroke='%236b2d42' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E"); }
/* filter card */
.dx-filters{ border:1px solid var(--line); background:#fff; margin-bottom:22px; border-radius:18px; box-shadow:0 14px 40px -28px rgba(58,22,35,.45); overflow:hidden; }
.dx-filters-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 24px; border-bottom:1px solid var(--line); background:linear-gradient(180deg,#fff, #fdfbf8); }
.dx-filters-title{ display:inline-flex; align-items:center; gap:10px; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--wine-deep); font-weight:600; }
.dx-filters-title svg{ width:15px; height:15px; color:var(--gold-deep); }
.dx-reset{ border:none; background:none; color:var(--muted); font-family:var(--sans); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; cursor:pointer; text-decoration:underline; text-underline-offset:4px; transition:color .15s; padding:4px; }
.dx-reset:hover{ color:var(--wine-deep); }
.dx-filters-body{ padding:24px; }
.dx-inputs{ display:grid; grid-template-columns:2fr 1.1fr 1.1fr; gap:18px 20px; }
.dx-field{ display:flex; flex-direction:column; gap:8px; min-width:0; }
.dx-field label{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; }
/* pill filter rows */
.dx-pillrow{ display:flex; align-items:flex-start; gap:18px; padding:16px 0 4px; margin-top:14px; border-top:1px solid var(--line); }
.dx-pillrow:first-of-type{ margin-top:18px; }
.dx-pilllabel{ flex:0 0 78px; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; padding-top:10px; }
.dx-pills{ display:flex; flex-wrap:wrap; gap:8px; }
.dx-pill{ border:1px solid #e7ddcf; background:#fff; color:var(--ink); font-family:var(--sans); font-size:13px; letter-spacing:.02em; padding:8px 16px; border-radius:40px; cursor:pointer; transition:background .15s, border-color .15s, color .15s; line-height:1; }
.dx-pill:hover{ border-color:var(--wine); color:var(--wine-deep); }
.dx-pill.is-active{ background:var(--wine-deep); border-color:var(--wine-deep); color:var(--cream); box-shadow:0 4px 12px -6px rgba(81,31,49,.6); }
/* searchable dropdown (Shape) */
.dx-ss{ position:relative; }
.dx-ss-btn{ width:100%; text-align:left; padding:12px 38px 12px 14px; border:1px solid #e7ddcf; border-radius:11px; font-size:14px; color:var(--ink); background:#fbf8f3 var(--dxchevron) no-repeat right 14px center; background-size:11px 7px; cursor:pointer; font-family:var(--sans); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; transition:border-color .15s, box-shadow .15s, background-color .15s; }
.dx-ss-btn.placeholder{ color:#b3a79d; }
.dx-ss.open .dx-ss-btn{ border-color:var(--wine); background-color:#fff; box-shadow:0 0 0 3px rgba(107,45,66,.12); }
.dx-ss-pop{ display:none; position:absolute; z-index:60; top:calc(100% + 6px); left:0; right:0; background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:0 18px 44px -16px rgba(58,22,35,.42); overflow:hidden; }
.dx-ss.open .dx-ss-pop{ display:block; }
.dx-ss-search{ width:100%; border:none; border-bottom:1px solid var(--line); border-radius:0; padding:12px 14px; font-size:13px; font-family:var(--sans); color:var(--ink); }
.dx-ss-search:focus{ outline:none; }
.dx-ss-list{ list-style:none; margin:0; padding:6px; max-height:240px; overflow:auto; }
.dx-ss-opt{ padding:9px 12px; border-radius:8px; font-size:13.5px; color:var(--ink); cursor:pointer; }
.dx-ss-opt:hover{ background:var(--dxsoft); }
.dx-ss-opt.sel{ font-weight:600; color:var(--wine-deep); }
.dx-ss-none{ padding:16px; color:var(--muted); font-size:13px; text-align:center; }
.dx-field select,.dx-field input{ width:100%; padding:12px 14px; border:1px solid #e7ddcf; background:#fbf8f3; font-size:14px; color:var(--ink); border-radius:11px; font-family:var(--sans); transition:border-color .15s, box-shadow .15s, background .15s; }
.dx-field input::placeholder{ color:#b3a79d; }
.dx-field select{ appearance:none; -webkit-appearance:none; -moz-appearance:none; cursor:pointer; padding-right:38px; background-image:var(--dxchevron); background-repeat:no-repeat; background-position:right 14px center; background-size:11px 7px; }
.dx-field select:hover{ border-color:#cdbfac; }
.dx-field select:focus,.dx-field input:focus{ outline:none; border-color:var(--wine); background:#fff; box-shadow:0 0 0 3px rgba(107,45,66,.12); }
.dx-range{ display:flex; align-items:center; gap:10px; }
.dx-range span{ color:var(--muted); flex:0 0 auto; }
.dx-grow{ grid-column:span 2; }
/* meta + sort */
.dx-meta{ display:flex; justify-content:space-between; align-items:center; gap:14px; margin:0 4px 20px; flex-wrap:wrap; }
.dx-count{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--wine-deep); font-weight:500; }
.dx-sortwrap{ display:flex; align-items:center; gap:10px; margin-left:auto; }
.dx-sortwrap label{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.dx-sort{ appearance:none; -webkit-appearance:none; -moz-appearance:none; cursor:pointer; border:1px solid #e7ddcf; background:#fff var(--dxchevron) no-repeat right 13px center; background-size:11px 7px; border-radius:40px; padding:10px 36px 10px 16px; font-size:13px; color:var(--ink); font-family:var(--sans); transition:border-color .15s; }
.dx-sort:hover{ border-color:#cdbfac; }
.dx-sort:focus{ outline:none; border-color:var(--wine); box-shadow:0 0 0 3px rgba(107,45,66,.12); }
.dx-cards{ display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:20px; }
.dx-card{ border:1px solid var(--line); background:#fff; cursor:pointer; display:flex; flex-direction:column; border-radius:10px; overflow:hidden; transition:box-shadow .2s, transform .2s; }
.dx-card:hover{ box-shadow:var(--shadow); transform:translateY(-3px); }
.dx-card-img{ position:relative; aspect-ratio:1/1; background:var(--dxsoft); overflow:hidden; }
.dx-card-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.dx-ph{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:46%; height:46%; opacity:.18; }
.dx-badge{ position:absolute; top:10px; left:10px; background:#fff; border:1px solid var(--line); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; padding:4px 8px; color:var(--wine-deep); border-radius:20px; z-index:1; }
.dx-card-body{ padding:15px 16px 17px; display:flex; flex-direction:column; gap:5px; flex:1; }
.dx-card-title{ font-family:var(--serif); font-size:18px; font-weight:600; color:var(--wine-deep); font-variant-numeric:lining-nums tabular-nums; }
.dx-card-spec{ font-size:12.5px; color:#6a5b60; letter-spacing:.03em; font-variant-numeric:lining-nums; }
.dx-card-lab{ font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); font-variant-numeric:lining-nums; }
.dx-card-foot{ margin-top:auto; display:flex; align-items:flex-end; justify-content:space-between; gap:6px 8px; padding-top:10px; flex-wrap:wrap; }
.dx-card-price{ font-family:var(--sans); font-size:16px; font-weight:600; letter-spacing:.01em; color:var(--wine-deep); font-variant-numeric:tabular-nums lining-nums; white-space:nowrap; }
/* MXN amounts are longer (e.g. $20,978.00 MXN) — shrink so they stay on one line */
.cur-mxn .dx-card-price{ font-size:13.5px; letter-spacing:0; }
.cur-mxn .dx-bigprice{ font-size:22px; }
.cur-mxn .price{ font-size:1rem; }
.cur-mxn .cart-line, .cur-mxn .cart-unit, .cur-mxn .co-item-price{ font-size:.86rem; white-space:nowrap; }
.dx-card-cert{ font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--gold-deep); text-decoration:underline; text-underline-offset:3px; white-space:nowrap; }
.dx-card-add{ border:1px solid var(--wine-deep); background:#fff; color:var(--wine-deep); font-family:var(--sans); font-size:10px; letter-spacing:.1em; text-transform:uppercase; font-weight:500; padding:7px 14px; border-radius:40px; cursor:pointer; transition:background .15s,color .15s; white-space:nowrap; }
.dx-card-add:hover{ background:var(--wine-deep); color:var(--cream); }
.dx-btn-primary{ background:var(--wine-deep); color:var(--cream); border-color:var(--wine-deep); }
.dx-btn-primary:hover{ background:var(--wine-dark); color:var(--cream); }
.dx-loading,.dx-empty{ grid-column:1/-1; text-align:center; color:var(--muted); padding:46px; }
.dx-foot{ display:flex; flex-direction:column; align-items:center; gap:14px; margin-top:34px; }
.dx-loadmore{ min-width:240px; justify-content:center; }
.dx-loadmore:disabled{ opacity:.55; cursor:default; }
.dx-pageinfo{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.dx-sentinel{ height:1px; width:100%; }
.dx-modal{ position:fixed; inset:0; z-index:2147483000; display:none; align-items:center; justify-content:center; }
.dx-modal.dx-open{ display:flex; }
.dx-modal-bg{ position:absolute; inset:0; background:rgba(58,22,35,.55); }
.dx-modal-box{ position:relative; background:#fff; color:var(--ink); max-width:880px; width:92%; max-height:88vh; overflow:auto; padding:34px 36px; box-shadow:0 30px 70px rgba(0,0,0,.4); border-radius:14px; }
.dx-modal-x{ position:absolute; top:10px; right:16px; border:none; background:none; font-size:30px; line-height:1; cursor:pointer; color:var(--wine-deep); }
.dx-modal h3{ font-family:var(--serif); margin:0 0 4px; font-size:26px; color:var(--wine-deep); }
.dx-sub{ color:var(--muted); font-size:13px; letter-spacing:.08em; text-transform:uppercase; margin-bottom:22px; }
.dx-media{ display:flex; gap:18px; flex-wrap:wrap; align-items:flex-start; margin-bottom:22px; }
.dx-mediaimg{ width:210px; height:210px; background:var(--dxsoft); position:relative; flex:0 0 auto; overflow:hidden; border-radius:10px; }
.dx-mediaimg img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.dx-actions{ display:flex; flex-direction:column; gap:10px; }
.dx-bigprice{ font-family:var(--sans); font-size:26px; color:var(--wine-deep); font-weight:600; letter-spacing:.005em; margin-bottom:4px; font-variant-numeric:tabular-nums lining-nums; }
.dx-btn{ display:inline-block; padding:11px 20px; border:1px solid var(--wine-deep); text-decoration:none; color:var(--wine-deep); text-transform:uppercase; letter-spacing:.08em; font-size:11px; transition:.15s; text-align:center; border-radius:40px; }
.dx-btn:hover{ background:var(--wine-deep); color:var(--cream); }
.dx-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:4px 26px; }
.dx-grid .row{ display:flex; justify-content:space-between; gap:12px; padding:8px 0; border-bottom:1px solid #f0ece5; font-size:13.5px; }
.dx-grid .k{ color:var(--muted); }
.dx-grid .v{ text-align:right; font-weight:500; font-variant-numeric:tabular-nums lining-nums; }
body.dx-lock{ overflow:hidden; }
@media(max-width:760px){ .dx-inputs{ grid-template-columns:1fr 1fr;} .dx-grow{ grid-column:1/-1;} }
@media(max-width:560px){
  .dx-inputs{ grid-template-columns:1fr;}
  .dx-pillrow{ flex-direction:column; gap:10px; padding-top:14px;}
  .dx-pilllabel{ flex:none; padding-top:0;}
  .dx-cards{ grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:14px;}
  .dx-modal-box{ padding:24px 20px;}
}

/* ---------- Cart & Checkout ---------- */
.cart-empty{ text-align:center; padding:50px 20px; color:var(--muted); font-size:1.05rem; }
.cart-layout{ display:grid; grid-template-columns:1fr 340px; gap:40px; align-items:start; }
.cart-items{ display:flex; flex-direction:column; gap:0; }
.cart-item{ display:grid; grid-template-columns:90px 1fr auto auto 28px; gap:18px; align-items:center; padding:22px 0; border-bottom:1px solid var(--line); }
.cart-thumb{ width:90px; height:90px; border-radius:12px; overflow:hidden; background:var(--cream-2); display:grid; place-items:center; }
.cart-thumb img{ width:100%; height:100%; object-fit:cover; }
.cart-ph{ color:var(--gold); font-size:28px; }
.cart-info h3{ font-family:var(--serif); font-size:1.3rem; color:var(--wine-deep); margin:3px 0 4px; font-variant-numeric:lining-nums tabular-nums; }
.cart-type{ font-size:9.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; }
.cart-spec{ font-size:.85rem; color:var(--muted); }
.cart-unit{ font-size:.8rem; color:var(--muted); margin-top:4px; font-variant-numeric:tabular-nums; }
.cart-qty{ display:flex; align-items:center; gap:10px; }
.cart-qbtn{ width:30px; height:30px; border:1px solid var(--line); background:#fff; border-radius:8px; cursor:pointer; font-size:1rem; color:var(--wine-deep); transition:.15s; }
.cart-qbtn:hover{ background:var(--wine-deep); color:#fff; border-color:var(--wine-deep); }
.cart-qval{ min-width:22px; text-align:center; font-variant-numeric:tabular-nums; }
.cart-qty-one{ font-size:.8rem; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.cart-line{ font-family:var(--sans); font-weight:600; color:var(--wine-deep); font-variant-numeric:tabular-nums; min-width:90px; text-align:right; }
.cart-remove{ border:none; background:none; font-size:1.5rem; line-height:1; color:var(--muted); cursor:pointer; transition:color .15s; }
.cart-remove:hover{ color:var(--err,#b23b4b); }
.cart-summary{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:28px 26px; position:sticky; top:110px; box-shadow:var(--shadow-sm); }
.cart-summary h3{ font-family:var(--serif); font-size:1.4rem; color:var(--wine-deep); margin-bottom:20px; }
.cart-srow{ display:flex; justify-content:space-between; padding:11px 0; font-size:.95rem; color:var(--ink); border-bottom:1px solid var(--line); font-variant-numeric:tabular-nums; }
.cart-srow.cart-total{ border-bottom:none; font-family:var(--sans); font-weight:600; font-size:1.15rem; color:var(--wine-deep); padding-top:16px; }
.cart-checkout{ width:100%; justify-content:center; margin-top:22px; }
.cart-continue{ display:block; text-align:center; margin-top:16px; font-size:.85rem; color:var(--muted); }
.cart-continue:hover{ color:var(--wine-deep); }
.cart-secure{ text-align:center; font-size:.74rem; color:var(--muted); margin-top:18px; letter-spacing:.02em; }
@media(max-width:820px){ .cart-layout{ grid-template-columns:1fr; } .cart-summary{ position:static; } }
@media(max-width:560px){ .cart-item{ grid-template-columns:64px 1fr 28px; grid-template-areas:'thumb info remove' 'thumb qty line'; gap:10px 14px; } .cart-thumb{ width:64px; height:64px; grid-area:thumb; } .cart-info{ grid-area:info; } .cart-qty{ grid-area:qty; } .cart-line{ grid-area:line; } .cart-remove{ grid-area:remove; } }

/* ---------- Checkout ---------- */
.co-alert{ background:var(--cream-2); border:1px solid var(--line); border-left:3px solid var(--gold); border-radius:10px; padding:14px 18px; margin-bottom:24px; color:var(--wine-deep); }
.co-alert-err{ border-left-color:var(--err,#b23b4b); color:var(--err,#b23b4b); }
.co-layout{ display:grid; grid-template-columns:1fr 360px; gap:34px; align-items:start; }
.co-card{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:28px 28px 30px; margin-bottom:24px; }
.co-h{ font-family:var(--serif); font-size:1.4rem; color:var(--wine-deep); margin-bottom:20px; }
.co-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px 18px; }
.co-field{ display:flex; flex-direction:column; gap:7px; }
.co-field.co-full{ grid-column:1/-1; }
.co-field label{ font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; }
.co-opt{ color:var(--muted); font-size:.85rem; text-transform:none; letter-spacing:0; }
.co-field input,.co-field textarea{ border:1px solid #e7ddcf; border-radius:10px; padding:12px 14px; font-family:var(--sans); font-size:.95rem; background:#fbf8f3; color:var(--ink); outline:none; transition:border-color .15s,box-shadow .15s; }
.co-field input:focus,.co-field textarea:focus{ border-color:var(--wine); background:#fff; box-shadow:0 0 0 3px rgba(107,45,66,.12); }
.co-methods{ display:flex; flex-direction:column; gap:10px; }
.co-method{ display:flex; align-items:center; gap:12px; border:1px solid var(--line); border-radius:12px; padding:14px 16px; cursor:pointer; transition:border-color .15s, background .15s; }
.co-method:hover{ border-color:var(--gold-soft); }
.co-method input{ accent-color:var(--wine); }
.co-method input:checked ~ .co-method-name{ color:var(--wine-deep); font-weight:600; }
.co-method:has(input:checked){ border-color:var(--wine); background:#fdfbf8; }
.co-method-name{ flex:1; font-size:.95rem; }
.co-method-ic{ font-size:1.2rem; }
.co-summary{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:26px; position:sticky; top:110px; box-shadow:var(--shadow-sm); }
.co-items{ margin-bottom:16px; }
.co-item{ display:flex; justify-content:space-between; gap:12px; padding:10px 0; border-bottom:1px solid var(--line); }
.co-item-main{ display:flex; flex-direction:column; }
.co-item-title{ font-size:.92rem; color:var(--ink); }
.co-item-spec{ font-size:.76rem; color:var(--muted); }
.co-item-price{ font-variant-numeric:tabular-nums; font-weight:500; color:var(--wine-deep); white-space:nowrap; }
@media(max-width:820px){ .co-layout{ grid-template-columns:1fr; } .co-summary{ position:static; } }
@media(max-width:520px){ .co-grid{ grid-template-columns:1fr; } }

/* ---------- Order complete ---------- */
.oc-box{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:40px 36px; text-align:center; box-shadow:var(--shadow-sm); }
.oc-ic{ width:64px; height:64px; border-radius:50%; display:grid; place-items:center; margin:0 auto 18px; font-size:30px; background:linear-gradient(135deg,var(--gold-soft),var(--gold)); color:var(--wine-dark); }
.oc-pending .oc-ic{ background:var(--cream-2); color:var(--muted); }
.oc-box h2{ font-family:var(--serif); font-size:1.7rem; color:var(--wine-deep); margin-bottom:10px; }
.oc-box > p{ color:var(--muted); max-width:480px; margin:0 auto; }
.oc-summary{ background:var(--cream); border-radius:12px; padding:20px 22px; margin:26px 0 18px; text-align:left; }
.oc-row{ display:flex; justify-content:space-between; padding:7px 0; font-size:.95rem; }
.oc-row span{ color:var(--muted); }
.oc-items{ text-align:left; }
.oc-item{ display:flex; justify-content:space-between; gap:12px; padding:9px 0; border-bottom:1px solid var(--line); font-size:.92rem; }
.oc-item small{ color:var(--muted); }

/* ---------- Product detail page ---------- */
.pdp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:start; }
.pdp-main{ position:relative; aspect-ratio:1/1; border-radius:16px; overflow:hidden; background:var(--cream-2); border:1px solid var(--line); }
.pdp-main img{ width:100%; height:100%; object-fit:cover; }
.pdp-badge{ z-index:2; }
.pdp-thumbs{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.pdp-thumb{ width:74px; height:74px; border-radius:10px; overflow:hidden; border:1px solid var(--line); background:#fff; cursor:pointer; padding:0; }
.pdp-thumb.on{ border-color:var(--wine); box-shadow:0 0 0 2px rgba(107,45,66,.25); }
.pdp-thumb img{ width:100%; height:100%; object-fit:cover; }
.pdp-info h1{ font-family:var(--serif); font-size:clamp(1.9rem,4vw,2.8rem); color:var(--wine-deep); margin:8px 0 10px; }
.pdp-rating{ display:flex; align-items:center; gap:10px; margin-bottom:14px; font-size:.9rem; }
.pdp-rating .stars{ color:var(--gold); letter-spacing:2px; }
.pdp-rating a{ color:var(--muted); }
.pdp-price{ font-family:var(--sans); font-weight:600; font-size:1.5rem; color:var(--wine-deep); margin-bottom:20px; font-variant-numeric:tabular-nums lining-nums; }
.cur-mxn .pdp-price{ font-size:1.25rem; white-space:nowrap; }
.pdp-price del{ color:var(--muted); font-weight:400; font-size:1rem; margin-right:10px; }
.pdp-desc{ color:var(--ink); opacity:.85; line-height:1.7; margin-bottom:24px; }
.pdp-sizes{ margin-bottom:24px; }
.pdp-sizes label{ display:block; font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold-deep); font-weight:600; margin-bottom:10px; }
.pdp-size-opts{ display:flex; flex-wrap:wrap; gap:8px; }
.pdp-size{ min-width:46px; padding:10px 16px; border:1px solid var(--line); background:#fff; border-radius:8px; cursor:pointer; font-family:var(--sans); color:var(--ink); transition:.15s; }
.pdp-size.on, .pdp-size:hover{ border-color:var(--wine-deep); background:var(--wine-deep); color:var(--cream); }
.pdp-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:20px; }
.pdp-spec{ display:inline-flex; align-items:center; gap:8px; color:var(--gold-deep); font-size:.88rem; }
.pdp-spec:hover{ color:var(--wine-deep); }
.pdp-reviews{ display:flex; flex-direction:column; gap:16px; margin-bottom:34px; }
.pdp-review{ background:#fff; border:1px solid var(--line); border-radius:12px; padding:20px 22px; }
.pdp-review-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.pdp-review-name{ font-weight:600; color:var(--wine-deep); }
.pdp-review .stars{ color:var(--gold); letter-spacing:1px; }
.pdp-review p{ color:var(--ink); opacity:.85; margin:0 0 6px; }
.pdp-rform{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:26px; }
.pdp-rform h3{ font-family:var(--serif); font-size:1.3rem; color:var(--wine-deep); margin-bottom:14px; }
.pdp-rform input, .pdp-rform textarea{ width:100%; border:1px solid #e7ddcf; border-radius:9px; padding:11px 14px; font-family:var(--sans); margin-bottom:12px; background:var(--cream); }
.pdp-rform input:focus, .pdp-rform textarea:focus{ outline:none; border-color:var(--wine); background:#fff; }
.pdp-rstars{ font-size:1.6rem; color:#d9cdbb; cursor:pointer; margin-bottom:12px; }
.pdp-rstars span{ transition:color .1s; }
.pdp-rstars span.on{ color:var(--gold); }
@media(max-width:820px){ .pdp-grid{ grid-template-columns:1fr; gap:28px; } }

/* ---------- Custom (page-builder) sections ---------- */
.cs{ position: relative; }
.cs .section-head h2, .cs-ti-text h2, .cs-banner-in h2{ font-family: var(--serif); font-size: clamp(1.7rem,3.5vw,2.6rem); color: var(--wine-deep); margin-bottom: 14px; }
.cs-body{ color: var(--muted); font-size: 1.02rem; line-height: 1.7; }
.cs-ti{ display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; }
.cs-ti-img img{ width: 100%; border-radius: 14px; aspect-ratio: 4/3; object-fit: cover; }
.cs-banner{ background: linear-gradient(135deg, var(--wine-dark), var(--wine-deep)); }
.cs-banner-in{ text-align: center; max-width: 720px; margin: 0 auto; }
.cs-banner-in h2{ color: var(--cream); }
.cs-banner .cs-body{ color: rgba(247,241,233,.85); }
.cs-tools{ position: absolute; top: 12px; right: 18px; display: flex; gap: 6px; z-index: 5; }
.cs-tool{ width: 30px; height: 30px; border-radius: 7px; border: 1px solid var(--line); background: #fff; color: var(--wine-deep); cursor: pointer; font-size: .9rem; box-shadow: 0 4px 12px -6px rgba(0,0,0,.3); }
.cs-tool:hover{ background: var(--wine-deep); color: #fff; }
.cs-tool.danger:hover{ background: var(--err,#b23b4b); border-color: var(--err,#b23b4b); }
.cs-addbar{ display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; padding: 26px; margin: 0 auto 10px; max-width: var(--container); }
.cs-addbar span{ font-size: .82rem; letter-spacing: 1px; text-transform: uppercase; color: var(--gold-deep); font-weight: 600; }
.cs-addbar button{ border: 1px dashed var(--gold); background: rgba(201,162,75,.08); color: var(--wine-deep); padding: 9px 18px; border-radius: 30px; cursor: pointer; font-family: var(--sans); font-size: .82rem; letter-spacing: .5px; transition: .15s; }
.cs-addbar button:hover{ background: var(--wine-deep); color: var(--cream); border-color: var(--wine-deep); }
@media(max-width:760px){ .cs-ti{ grid-template-columns: 1fr; gap: 24px; } }

/* ---------- Toast ---------- */
.toast { position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%) translateY(120px); background: var(--wine-dark); color: var(--cream); padding: 16px 28px; border-radius: 60px; box-shadow: var(--shadow); z-index: 200; opacity: 0; transition: .4s; display: flex; align-items: center; gap: 10px; font-size: .9rem; letter-spacing: .5px; }
.toast.show { transform: translateX(-50%) translateY(0); opacity: 1; }
.toast svg { color: var(--gold-soft); width: 18px; height: 18px; }

/* ---------- Reveal animation ---------- */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .hero .container { grid-template-columns: 1fr; }
  .hero-visual { max-width: 420px; margin: 0 auto; }
  .feature .container, .collection-row { grid-template-columns: 1fr; }
  .cat-grid, .prod-grid, .value-grid, .shop-grid { grid-template-columns: repeat(2, 1fr); }
  .review-grid { grid-template-columns: 1fr; }
  .collection-text { padding: 48px 28px; }
  .collection-row.alt .collection-text { order: 0; }
  .shop-layout { grid-template-columns: 1fr; }
  .filters { position: static; }
}
@media (max-width: 760px) {
  .nav-links, .nav-actions .desktop-only { display: none; }
  .burger { display: flex; }
  .nav-links.open { display: flex; position: absolute; top: 84px; left: 0; right: 0; flex-direction: column; background: var(--cream); padding: 24px 28px; gap: 18px; border-bottom: 1px solid var(--line); box-shadow: var(--shadow); }
  .section { padding: 70px 0; }
  .hero-stats { gap: 26px; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
  .g-wide { grid-column: span 2; }
  .g-tall { grid-row: span 2; }
  .subscribe { flex-direction: column; border-radius: 16px; }
  .subscribe input, .subscribe .btn { width: 100%; justify-content: center; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .cat-grid, .prod-grid, .shop-grid, .value-grid, .footer-grid { grid-template-columns: 1fr; }
  .container { padding: 0 18px; }
}
