/*
Theme Name:  Bellioné & Co
Theme URI:   https://bellione.store
Author:      Bellioné Studio
Author URI:  https://bellione.store
Description: Premium WooCommerce theme for Bellioné & Co — Timeless Essentials, Modern Heritage.
Version:     1.0.0
License:     GNU General Public License v2 or later
Text Domain: bellione
Tags:        woocommerce, fashion, ecommerce, dark, minimal
*/

/* ============================================================
   GLOBAL CSS VARIABLES
   ============================================================ */
:root {
  --bg:        #0d0b0b;
  --bg2:       #111010;
  --bg3:       #161212;
  --maroon:    #7a1a1a;
  --maroon2:   #8f2020;
  --maroon3:   #a52828;
  --gold:      #c9a96e;
  --gold2:     #e0c288;
  --cream:     #f0ebe3;
  --white:     #faf8f5;
  --muted:     rgba(240,235,227,0.50);
  --muted2:    rgba(240,235,227,0.25);
  --border:    rgba(201,169,110,0.15);
  --border2:   rgba(240,235,227,0.08);
  --gap:       clamp(1.2rem, 4vw, 3rem);
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--cream);
  font-family: 'EB Garamond', Georgia, serif;
  overflow-x: hidden;
  cursor: none;
  line-height: 1.6;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button, input, textarea, select { font-family: inherit; }

/* ── CURSOR ── */
#bel-cursor {
  width: 7px; height: 7px;
  background: var(--gold);
  border-radius: 50%;
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 99999;
}
#bel-cursor-ring {
  width: 32px; height: 32px;
  border: 1px solid rgba(201,169,110,.5);
  border-radius: 50%;
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 99998;
  transition: width .25s, height .25s, border-color .25s;
}

/* ── TOPBAR ── */
.bel-topbar {
  background: var(--maroon);
  text-align: center;
  padding: .5rem 1rem;
  font-family: 'Jost', sans-serif;
  font-size: .62rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(250,248,245,.85);
}
.bel-topbar a { color: var(--gold2); }

/* ── HEADER / NAV ── */
#masthead {
  position: sticky; top: 0; z-index: 900;
  background: rgba(13,11,11,.97);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
}
.bel-nav-wrap {
  max-width: 1400px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: .9rem var(--gap);
  gap: 1rem;
}
.bel-nav-left { display: flex; gap: 2rem; }
.bel-nav-left a,
.bel-nav-right a {
  font-family: 'Jost', sans-serif;
  font-size: .67rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  transition: color .25s;
  position: relative;
}
.bel-nav-left a::after {
  content: ''; position: absolute;
  bottom: -3px; left: 0; right: 0;
  height: 1px; background: var(--gold);
  transform: scaleX(0); transform-origin: left;
  transition: transform .3s;
}
.bel-nav-left a:hover,
.bel-nav-right a:hover { color: var(--cream); }
.bel-nav-left a:hover::after { transform: scaleX(1); }
/* Current page */
.bel-nav-left .current-menu-item > a { color: var(--cream); }

.bel-logo {
  text-align: center;
}
.bel-logo-main {
  display: block;
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.3rem, 2vw, 1.7rem);
  font-weight: 500;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--white);
  line-height: 1;
}
.bel-logo-sub {
  display: block;
  font-family: 'Jost', sans-serif;
  font-size: .5rem;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: .3rem;
}
/* Custom logo image */
.custom-logo { max-height: 44px; width: auto; }

.bel-nav-right {
  display: flex; align-items: center;
  justify-content: flex-end; gap: 1.6rem;
}
.bel-cart-link {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .4rem 1rem;
  border: 1px solid var(--maroon2);
  font-family: 'Jost', sans-serif;
  font-size: .62rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--cream) !important;
  transition: background .25s;
}
.bel-cart-link:hover { background: var(--maroon); }
.bel-cart-count {
  background: var(--maroon);
  color: var(--gold2);
  width: 18px; height: 18px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: .55rem; font-weight: 600;
}
.bel-hamburger {
  display: none; flex-direction: column;
  gap: 5px; cursor: pointer; padding: 4px;
}
.bel-hamburger span {
  display: block; width: 22px; height: 1px;
  background: var(--cream); transition: .3s;
}

/* ── MOBILE MENU ── */
.bel-mobile-menu {
  display: none;
  position: fixed; inset: 0; z-index: 9000;
  background: var(--bg);
  padding: 2rem var(--gap);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  border-top: 1px solid var(--border);
}
.bel-mobile-menu.open { display: flex; }
.bel-mobile-menu a {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.5rem, 6vw, 2.5rem);
  font-style: italic;
  color: var(--cream);
  transition: color .2s;
}
.bel-mobile-menu a:hover { color: var(--gold); }
.bel-mobile-close {
  position: absolute; top: 1.5rem; right: var(--gap);
  font-family: 'Jost', sans-serif;
  font-size: .65rem; letter-spacing: .2em;
  text-transform: uppercase; color: var(--muted);
  cursor: pointer; background: none; border: none;
  color: var(--muted);
}

/* ── UTILITY ── */
.bel-container { max-width: 1400px; margin: 0 auto; padding: 0 var(--gap); }
.bel-section { padding: 5rem 0; }

.bel-eyebrow {
  font-family: 'Jost', sans-serif;
  font-size: .58rem; letter-spacing: .28em;
  text-transform: uppercase; color: var(--gold);
  margin-bottom: .6rem;
}
.bel-section-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: 400; font-style: italic;
  letter-spacing: -.01em; line-height: 1.1;
}
.bel-section-header {
  display: flex; align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 3rem; gap: 1rem; flex-wrap: wrap;
}
.bel-link-arrow {
  font-family: 'Jost', sans-serif;
  font-size: .62rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--gold);
  display: flex; align-items: center; gap: .5rem;
  white-space: nowrap; transition: gap .25s;
}
.bel-link-arrow:hover { gap: .9rem; }
.bel-link-arrow::after { content: '→'; }

/* ── BUTTONS ── */
.bel-btn-primary {
  display: inline-flex; align-items: center; gap: .7rem;
  padding: 1rem 2.2rem;
  background: var(--maroon);
  color: var(--cream);
  font-family: 'Jost', sans-serif;
  font-size: .68rem; letter-spacing: .18em;
  text-transform: uppercase;
  border: 1px solid var(--maroon2);
  transition: background .3s, border-color .3s;
  cursor: none;
}
.bel-btn-primary:hover { background: var(--maroon2); color: var(--cream); }
.bel-btn-outline {
  display: inline-flex; align-items: center; gap: .6rem;
  padding: 1rem 2rem;
  border: 1px solid var(--border);
  color: var(--muted);
  font-family: 'Jost', sans-serif;
  font-size: .68rem; letter-spacing: .18em;
  text-transform: uppercase;
  transition: border-color .3s, color .3s;
  cursor: none;
}
.bel-btn-outline:hover { border-color: var(--gold); color: var(--gold); }

/* ── MARQUEE ── */
.bel-marquee-bar {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: rgba(122,26,26,.07);
  padding: .85rem 0; overflow: hidden;
}
.bel-marquee-track {
  display: flex; gap: 0;
  white-space: nowrap;
  animation: belMarquee 30s linear infinite;
}
.bel-marquee-track:hover { animation-play-state: paused; }
.bel-mq-item {
  display: inline-flex; align-items: center;
  gap: 1.5rem; flex-shrink: 0; padding: 0 1.5rem;
}
.bel-mq-item span {
  font-family: 'Jost', sans-serif;
  font-size: .6rem; letter-spacing: .22em;
  text-transform: uppercase; color: var(--muted);
}
.bel-mq-sep { color: var(--maroon2); font-size: .8rem; }

@keyframes belMarquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── PRODUCT CARD ── */
.bel-product-card { position: relative; cursor: none; }
.bel-product-img {
  aspect-ratio: 3/4;
  position: relative; overflow: hidden;
  background: var(--bg3);
  margin-bottom: 1rem;
  border: 1px solid var(--border2);
}
.bel-product-img img,
.bel-product-img .bel-img-placeholder {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .75s cubic-bezier(.25,.46,.45,.94);
}
.bel-product-card:hover .bel-product-img img,
.bel-product-card:hover .bel-product-img .bel-img-placeholder { transform: scale(1.04); }

.bel-img-placeholder {
  background: linear-gradient(155deg, #1a1010, #2a1818, #150c0c);
}

/* Quick add */
.bel-quick-add {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: rgba(13,11,11,.95);
  border-top: 1px solid var(--border);
  padding: .9rem;
  transform: translateY(100%);
  transition: transform .35s cubic-bezier(.4,0,.2,1);
  z-index: 4;
}
.bel-product-card:hover .bel-quick-add { transform: translateY(0); }
.bel-sizes { display: flex; gap: .4rem; margin-bottom: .7rem; flex-wrap: wrap; }
.bel-sz {
  font-family: 'Jost', sans-serif;
  font-size: .55rem; letter-spacing: .1em;
  padding: .3rem .6rem;
  border: 1px solid var(--border2);
  color: var(--muted2);
  cursor: none; transition: all .2s;
}
.bel-sz:hover,
.bel-sz.selected { border-color: var(--gold); color: var(--gold); }
.bel-btn-atc {
  width: 100%; padding: .65rem;
  background: var(--maroon); color: var(--cream);
  border: none;
  font-family: 'Jost', sans-serif;
  font-size: .6rem; letter-spacing: .15em;
  text-transform: uppercase;
  cursor: none; transition: background .25s;
}
.bel-btn-atc:hover { background: var(--maroon2); }

.bel-wishlist-btn {
  position: absolute; top: .7rem; right: .7rem;
  width: 32px; height: 32px;
  background: rgba(13,11,11,.7);
  border: 1px solid var(--border2);
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem;
  cursor: none; z-index: 3;
  opacity: 0; transition: opacity .25s, background .25s;
}
.bel-product-card:hover .bel-wishlist-btn { opacity: 1; }
.bel-wishlist-btn:hover { background: var(--maroon); border-color: var(--maroon2); }

.bel-badge {
  position: absolute; top: .7rem; left: .7rem;
  font-family: 'Jost', sans-serif;
  font-size: .5rem; letter-spacing: .12em;
  text-transform: uppercase;
  padding: .28rem .65rem; z-index: 3;
}
.bel-badge-new  { background: var(--maroon); color: var(--cream); }
.bel-badge-sale { background: var(--gold); color: var(--bg); }
.bel-badge-ltd  { background: rgba(0,0,0,.7); border: 1px solid var(--gold); color: var(--gold); }

.bel-product-meta { padding: 0 .1rem; }
.bel-product-brand {
  font-family: 'Jost', sans-serif;
  font-size: .52rem; letter-spacing: .2em;
  text-transform: uppercase; color: var(--muted2);
  margin-bottom: .3rem;
}
.bel-product-name {
  font-family: 'EB Garamond', serif;
  font-size: 1.05rem; letter-spacing: .02em;
  margin-bottom: .35rem; line-height: 1.3;
}
.bel-product-name a { color: var(--cream); transition: color .2s; }
.bel-product-name a:hover { color: var(--gold); }
.bel-product-price {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem; font-style: italic; color: var(--gold);
}
.bel-product-price del { color: var(--muted2); font-style: normal; font-size: .85rem; margin-right: .3rem; }
/* WooCommerce price override */
.woocommerce .price { font-family: 'Playfair Display', serif; font-style: italic; color: var(--gold) !important; }
.woocommerce .price del { color: var(--muted2) !important; }
.woocommerce .price ins { text-decoration: none; }

/* ── HERITAGE STRIP ── */
.bel-heritage {
  background: var(--bg3);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 4rem 0;
}
.bel-heritage-grid {
  max-width: 1400px; margin: 0 auto; padding: 0 var(--gap);
  display: grid; grid-template-columns: repeat(4,1fr);
  gap: 2rem; text-align: center;
}
.bel-heritage-icon { font-size: 1.3rem; color: var(--gold); margin-bottom: .9rem; }
.bel-heritage-title {
  font-family: 'Playfair Display', serif;
  font-size: 1rem; font-style: italic; margin-bottom: .4rem;
}
.bel-heritage-text {
  font-family: 'Jost', sans-serif;
  font-size: .62rem; letter-spacing: .07em;
  color: var(--muted2); line-height: 1.75;
}

/* ── NEWSLETTER ── */
.bel-newsletter {
  background: var(--bg3);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.bel-newsletter-inner {
  max-width: 1400px; margin: 0 auto; padding: 5rem var(--gap);
  display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center;
}
.bel-nl-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.8rem, 3.5vw, 3rem);
  font-weight: 400; line-height: 1.1; margin-bottom: .8rem;
}
.bel-nl-title em { font-style: italic; color: var(--gold); }
.bel-nl-desc {
  font-size: 1rem; line-height: 1.8;
  color: var(--muted); letter-spacing: .02em; margin-bottom: 1.5rem;
}
.bel-nl-perks { display: flex; flex-direction: column; gap: .6rem; }
.bel-nl-perk {
  display: flex; align-items: center; gap: .8rem;
  font-family: 'Jost', sans-serif;
  font-size: .62rem; letter-spacing: .1em; color: var(--muted);
}
.bel-nl-perk::before { content: '✦'; color: var(--maroon2); }
.bel-nl-form { display: flex; flex-direction: column; gap: .8rem; }
.bel-nl-input {
  padding: 1rem 1.4rem;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  color: var(--cream);
  font-family: 'EB Garamond', serif;
  font-size: 1rem; outline: none;
  transition: border-color .3s;
}
.bel-nl-input:focus { border-color: var(--gold); }
.bel-nl-input::placeholder { color: var(--muted2); }

/* ── FOOTER ── */
#colophon {
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.bel-footer-top {
  max-width: 1400px; margin: 0 auto;
  display: grid; grid-template-columns: 2.2fr 1fr 1fr 1fr;
  gap: 3rem; padding: 4.5rem var(--gap) 3.5rem;
}
.bel-footer-brand-name {
  font-family: 'Playfair Display', serif;
  font-size: 1.6rem; letter-spacing: .3em;
  text-transform: uppercase; margin-bottom: .4rem;
}
.bel-footer-brand-tm {
  font-family: 'Jost', sans-serif;
  font-size: .52rem; letter-spacing: .25em;
  text-transform: uppercase; color: var(--gold); margin-bottom: 1.2rem;
}
.bel-footer-tagline {
  font-size: .95rem; line-height: 1.75;
  color: var(--muted2); max-width: 260px;
  letter-spacing: .02em; margin-bottom: 1.5rem;
}
.bel-footer-socials { display: flex; gap: .8rem; flex-wrap: wrap; }
.bel-footer-soc {
  padding: .4rem 1rem;
  border: 1px solid var(--border2);
  font-family: 'Jost', sans-serif;
  font-size: .55rem; letter-spacing: .15em;
  text-transform: uppercase; color: var(--muted2);
  transition: border-color .25s, color .25s;
}
.bel-footer-soc:hover { border-color: var(--maroon2); color: var(--cream); }
.bel-footer-col-title {
  font-family: 'Jost', sans-serif;
  font-size: .58rem; letter-spacing: .22em;
  text-transform: uppercase; color: var(--gold);
  margin-bottom: 1.2rem; padding-bottom: .6rem;
  border-bottom: 1px solid var(--border2);
}
.bel-footer-links li { margin-bottom: .65rem; }
.bel-footer-links a {
  font-family: 'EB Garamond', serif;
  font-size: .95rem; color: var(--muted2);
  letter-spacing: .03em; transition: color .25s;
}
.bel-footer-links a:hover { color: var(--cream); }
.bel-footer-bottom {
  max-width: 1400px; margin: 0 auto;
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap;
  gap: 1.2rem; padding: 1.5rem var(--gap) 2.5rem;
  border-top: 1px solid var(--border2);
}
.bel-footer-copy {
  font-family: 'Jost', sans-serif;
  font-size: .58rem; letter-spacing: .12em; color: var(--muted2);
}
.bel-payment-chips { display: flex; gap: .6rem; flex-wrap: wrap; align-items: center; }
.bel-pay-chip {
  padding: .25rem .7rem;
  border: 1px solid var(--border2);
  font-family: 'Jost', sans-serif;
  font-size: .5rem; letter-spacing: .1em;
  text-transform: uppercase; color: var(--muted2);
}
.bel-pay-chip.gold { border-color: rgba(201,169,110,.3); color: var(--gold); }

/* ── WOOCOMMERCE OVERRIDES ── */
.woocommerce-page .woocommerce,
.woocommerce { color: var(--cream); }

/* Shop grid */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 1.5rem !important;
  margin: 0 !important;
}
.woocommerce ul.products li.product {
  float: none !important;
  width: auto !important;
  text-align: left !important;
}
.woocommerce ul.products li.product a img {
  aspect-ratio: 3/4;
  object-fit: cover;
  width: 100%;
  border: 1px solid var(--border2);
  transition: transform .7s cubic-bezier(.25,.46,.45,.94);
}
.woocommerce ul.products li.product:hover a img { transform: scale(1.04); }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: 'EB Garamond', serif !important;
  font-size: 1.05rem !important;
  font-weight: 400 !important;
  color: var(--cream) !important;
  padding: .4rem 0 .2rem !important;
}
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  background: var(--maroon) !important;
  color: var(--cream) !important;
  font-family: 'Jost', sans-serif !important;
  font-size: .62rem !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  border: 1px solid var(--maroon2) !important;
  padding: .7rem 1.5rem !important;
  transition: background .25s !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover { background: var(--maroon2) !important; }

/* Single product */
.woocommerce div.product .product_title {
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(1.8rem, 3vw, 2.8rem) !important;
  font-weight: 400 !important; font-style: italic !important;
  color: var(--cream) !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  color: var(--gold) !important;
  font-family: 'Playfair Display', serif !important;
  font-style: italic !important;
  font-size: 1.5rem !important;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--muted) !important;
  font-size: 1rem !important; line-height: 1.8 !important;
}
.woocommerce form.cart .button { background: var(--maroon) !important; }

/* Cart / Checkout */
.woocommerce table.shop_table {
  border: 1px solid var(--border2) !important;
  background: var(--bg3) !important;
}
.woocommerce table.shop_table th {
  font-family: 'Jost', sans-serif !important;
  font-size: .6rem !important; letter-spacing: .2em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  background: var(--bg) !important;
  border-color: var(--border2) !important;
}
.woocommerce table.shop_table td {
  border-color: var(--border2) !important;
  color: var(--cream) !important;
}
.woocommerce-checkout .col2-set,
.woocommerce-cart .cart-collaterals {
  color: var(--cream) !important;
}
.woocommerce .woocommerce-input-wrapper input,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  background: rgba(255,255,255,.04) !important;
  border: 1px solid var(--border) !important;
  color: var(--cream) !important;
  border-radius: 0 !important;
  font-family: 'EB Garamond', serif !important;
}
.woocommerce form .form-row label {
  font-family: 'Jost', sans-serif !important;
  font-size: .62rem !important; letter-spacing: .1em !important;
  text-transform: uppercase !important; color: var(--muted) !important;
}
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-error {
  background: var(--bg3) !important;
  border-top-color: var(--maroon) !important;
  color: var(--cream) !important;
}

/* Pagination */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  background: var(--bg3) !important;
  border-color: var(--border2) !important;
  color: var(--muted) !important;
  font-family: 'Jost', sans-serif !important;
  font-size: .62rem !important; letter-spacing: .1em !important;
  border-radius: 0 !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--maroon) !important;
  color: var(--cream) !important;
  border-color: var(--maroon2) !important;
}

/* Star ratings */
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before { color: var(--maroon2) !important; }

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

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; }
  .bel-heritage-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .bel-nav-left { display: none; }
  .bel-hamburger { display: flex; }
  .bel-footer-top { grid-template-columns: 1fr 1fr; }
  .bel-newsletter-inner { grid-template-columns: 1fr; }
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px) {
  .bel-footer-top { grid-template-columns: 1fr; }
  .bel-footer-bottom { flex-direction: column; text-align: center; }
  .bel-heritage-grid { grid-template-columns: 1fr 1fr; }
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: .8rem !important; }
}
/* ============================================================
   BELLIONÉ & Co — SHOP, PRODUCT, CART STYLES
   ============================================================ */

/* ── HERO PAGE BANNER ── */
.bel-shop-hero {
    position: relative; overflow: hidden;
    background: var(--bg3);
    border-bottom: 1px solid var(--border);
}
.bel-shop-hero-bg {
    position: absolute; inset: 0;
    background: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(122,26,26,.2) 0%, transparent 65%);
    pointer-events: none;
}
.bel-shop-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(2rem, 5vw, 4rem);
    font-weight: 400; font-style: italic;
    color: var(--white);
    margin: .5rem 0 .4rem;
    letter-spacing: -.01em;
}
.bel-shop-subtitle {
    font-family: 'Jost', sans-serif;
    font-size: .65rem; letter-spacing: .2em;
    text-transform: uppercase; color: var(--muted);
}
.bel-shop-subtitle span { color: var(--gold); }

/* ── SHOP LAYOUT ── */
.bel-shop-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 3rem;
    align-items: start;
}

/* ── FILTERS SIDEBAR ── */
.bel-shop-filters {
    position: sticky; top: 80px;
    border: 1px solid var(--border2);
    padding: 1.5rem;
    background: var(--bg3);
}
.bel-filters-header {
    display: flex; align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border2);
    font-family: 'Jost', sans-serif;
    font-size: .65rem; letter-spacing: .2em;
    text-transform: uppercase; color: var(--gold);
}
.bel-filters-close {
    display: none; background: none; border: none;
    color: var(--muted); cursor: pointer; font-size: .8rem;
}
.bel-filter-group { margin-bottom: 1.5rem; }
.bel-filter-title {
    font-family: 'Jost', sans-serif;
    font-size: .58rem; letter-spacing: .2em;
    text-transform: uppercase; color: var(--muted2);
    margin-bottom: .8rem;
}
.bel-filter-cat-link {
    display: flex; justify-content: space-between;
    padding: .4rem 0;
    font-family: 'EB Garamond', serif;
    font-size: .95rem; color: var(--muted);
    border-bottom: 1px solid var(--border2);
    transition: color .2s;
}
.bel-filter-cat-link:hover { color: var(--cream); }
.bel-filter-cat-link span {
    font-family: 'Jost', sans-serif;
    font-size: .55rem; color: var(--muted2);
}

/* WC ordering select */
.woocommerce-ordering select {
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--border) !important;
    color: var(--cream) !important;
    font-family: 'Jost', sans-serif !important;
    font-size: .62rem !important; letter-spacing: .1em !important;
    padding: .6rem .8rem !important;
    border-radius: 0 !important; width: 100%;
    outline: none;
}

/* ── SHOP TOOLBAR ── */
.bel-shop-toolbar {
    display: flex; align-items: center; gap: 1rem;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border2);
}
.woocommerce-result-count {
    font-family: 'Jost', sans-serif !important;
    font-size: .6rem !important; letter-spacing: .12em !important;
    text-transform: uppercase !important; color: var(--muted2) !important;
    margin: 0 !important; margin-left: auto !important;
}

/* ── PRODUCTS GRID (homepage) ── */
.bel-products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
}

/* ── CATEGORIES GRID ── */
.bel-cats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}
.bel-cat-item {
    aspect-ratio: 3/4; position: relative;
    overflow: hidden; cursor: none;
    background: var(--bg3);
}
.bel-cat-item:first-child {
    grid-column: span 1; grid-row: span 2;
    aspect-ratio: unset;
}
.bel-cat-bg { position: absolute; inset: 0; transition: transform .8s cubic-bezier(.25,.46,.45,.94); }
.bel-cat-item:hover .bel-cat-bg { transform: scale(1.05); }
.bel-cat-img { width: 100%; height: 100%; object-fit: cover; }
.bel-cat-placeholder {
    background: linear-gradient(160deg, #1a1010, #2d1515, #160e0e);
    width: 100%; height: 100%;
}
.bel-cat-overlay {
    position: absolute; bottom: 0; left: 0; right: 0;
    padding: 1.5rem;
    background: linear-gradient(to top, rgba(0,0,0,.88), transparent);
}
.bel-cat-label {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1rem,2vw,1.4rem);
    font-style: italic; margin-bottom: .25rem;
}
.bel-cat-count {
    font-family: 'Jost', sans-serif;
    font-size: .55rem; letter-spacing: .18em;
    text-transform: uppercase; color: var(--gold);
}
.bel-cat-cta {
    display: inline-block; margin-top: .8rem;
    padding: .4rem .9rem;
    background: var(--maroon);
    font-family: 'Jost', sans-serif;
    font-size: .55rem; letter-spacing: .15em;
    text-transform: uppercase; color: var(--cream);
    opacity: 0; transform: translateY(6px);
    transition: opacity .3s, transform .3s;
}
.bel-cat-item:hover .bel-cat-cta { opacity: 1; transform: translateY(0); }

/* ── EDITORIAL ── */
.bel-editorial-wrap {
    background: var(--bg3);
    border: 1px solid var(--border2);
    display: grid; grid-template-columns: 1fr 1fr;
    overflow: hidden;
}
.bel-ed-visual {
    position: relative; min-height: 500px;
    background: linear-gradient(135deg,#1c1010,#2e1818,#181010);
    overflow: hidden;
}
.bel-ed-glow {
    position: absolute; width: 300px; height: 300px;
    border-radius: 50%;
    background: radial-gradient(circle,rgba(122,26,26,.4),transparent 70%);
    top: 30%; left: 40%; transform: translate(-50%,-50%);
}
.bel-ed-figure {
    position: absolute; bottom: 0; left: 50%;
    transform: translateX(-50%);
    width: 52%; height: 82%;
    background: linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.07));
    border: 1px solid rgba(255,255,255,.04); border-bottom: none;
}
.bel-ed-img { width: 100%; height: 100%; object-fit: cover; }
.bel-ed-tag {
    position: absolute; top: 1.5rem; left: 1.5rem;
    background: var(--maroon);
    padding: .35rem .9rem;
    font-family: 'Jost', sans-serif;
    font-size: .52rem; letter-spacing: .18em;
    text-transform: uppercase; color: var(--cream);
}
.bel-ed-num {
    position: absolute; bottom: 1.5rem; right: 1.5rem;
    font-family: 'Playfair Display', serif;
    font-size: 4rem; font-style: italic;
    color: rgba(201,169,110,.07); line-height: 1;
}
.bel-ed-text {
    padding: 3.5rem;
    display: flex; flex-direction: column; justify-content: center;
}
.bel-ed-eyebrow {
    font-family: 'Jost', sans-serif;
    font-size: .58rem; letter-spacing: .28em;
    text-transform: uppercase; color: var(--gold);
    margin-bottom: 1.2rem;
    display: flex; align-items: center; gap: .8rem;
}
.bel-ed-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--maroon2); }
.bel-ed-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.8rem,3vw,2.8rem);
    font-weight: 400; line-height: 1.1; margin-bottom: 1rem;
}
.bel-ed-title em { font-style: italic; color: var(--gold); }
.bel-ed-body {
    font-size: 1rem; line-height: 1.85;
    color: var(--muted); margin-bottom: 2rem;
}
.bel-ed-features {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: .8rem; margin-bottom: 2.5rem;
}
.bel-ed-feat {
    display: flex; align-items: center; gap: .6rem;
    font-family: 'Jost', sans-serif;
    font-size: .62rem; letter-spacing: .1em; color: var(--muted);
}
.bel-ed-feat::before { content: '✦'; color: var(--maroon2); font-size: .6rem; }

/* ── HERO VIDEO ── */
.bel-hero-video-wrap {
    position: absolute;
    inset: 0;
    overflow: hidden;
    z-index: 0;
}
.bel-hero-video {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    min-width: 100%;
    min-height: 100%;
    width: auto; height: auto;
    object-fit: cover;
    display: block;
}
.bel-video-overlay {
    position: absolute;
    inset: 0;
    /* opacity controlled inline via Customizer */
    background: rgba(0, 0, 0, 0.6);
    z-index: 1;
}
/* When video is active, grain sits above overlay */
.bel-hero--video .bel-hero-grain {
    z-index: 2;
}
.bel-hero--video .bel-hero-crest {
    z-index: 3;
}
.bel-hero--video .bel-hero-body {
    z-index: 4;
}
.bel-hero--video .bel-hero-scroll {
    z-index: 4;
}

/* Mobile: hide video, show poster */
@media (max-width: 768px) {
    .bel-hero-video.bel-pause-mobile {
        display: none;
    }
}

/* ── HERO ── */
.bel-hero {
    min-height: 100svh; display: flex; flex-direction: column;
    position: relative; overflow: hidden;
}
.bel-hero-bg {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 70% 60% at 70% 40%, rgba(122,26,26,.25) 0%, transparent 65%),
        radial-gradient(ellipse 40% 40% at 20% 80%, rgba(201,169,110,.06) 0%, transparent 55%),
        linear-gradient(160deg, #0d0b0b 0%, #130f0f 40%, #0f0b0b 100%);
}
.bel-hero-grain {
    position: absolute; inset: 0; opacity: .035;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 180px; pointer-events: none;
}
.bel-hero-crest {
    position: absolute; right: -5%; top: 50%;
    transform: translateY(-50%);
    width: clamp(380px,55vw,800px); height: clamp(380px,55vw,800px);
    opacity: .04; pointer-events: none;
}
.bel-crest-ring { position: absolute; inset: 0; border: 1px solid var(--gold); border-radius: 50%; }
.bel-crest-inner { position: absolute; inset: 15%; border: 1px solid var(--gold); border-radius: 50%; }
.bel-crest-h,.bel-crest-v { position: absolute; background: rgba(201,169,110,.3); }
.bel-crest-h { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }
.bel-crest-v { left: 50%; top: 0; bottom: 0; width: 1px; transform: translateX(-50%); }
.bel-hero-body {
    flex: 1; display: flex; align-items: center;
    position: relative; z-index: 2;
    padding: 8rem var(--gap) 4rem;
    max-width: 1400px; margin: 0 auto; width: 100%;
}
.bel-hero-left { max-width: 640px; }
.bel-hero-eyebrow {
    display: flex; align-items: center; gap: 1rem;
    margin-bottom: 1.8rem;
    font-family: 'Jost', sans-serif;
    font-size: .6rem; letter-spacing: .3em; text-transform: uppercase; color: var(--gold);
    opacity: 0; animation: belFU .9s .3s forwards;
}
.bel-hero-eyebrow::before { content: ''; width: 30px; height: 1px; background: var(--maroon2); }
.bel-hero-h1 {
    font-family: 'Playfair Display', serif;
    font-size: clamp(3.2rem,7.5vw,7.5rem);
    font-weight: 400; line-height: .93;
    letter-spacing: -.01em; margin-bottom: 1.5rem;
    opacity: 0; animation: belFU 1s .5s forwards;
}
.bel-h1-stroke {
    font-style: italic; color: transparent;
    -webkit-text-stroke: 1.5px var(--maroon2); display: block;
}
.bel-h1-sub {
    color: var(--gold); font-size: .55em;
    letter-spacing: .05em; font-style: normal; display: block;
    margin-top: .4em; -webkit-text-stroke: 0;
}
.bel-hero-desc {
    font-size: 1.1rem; font-weight: 400; color: var(--muted);
    line-height: 1.75; max-width: 440px; margin-bottom: 2.5rem;
    letter-spacing: .02em;
    opacity: 0; animation: belFU .9s .75s forwards;
}
.bel-hero-btns {
    display: flex; gap: 1rem; flex-wrap: wrap;
    opacity: 0; animation: belFU .9s 1s forwards;
}
.bel-hero-stats {
    display: flex; gap: 3rem; margin-top: 3.5rem;
    padding-top: 2rem; border-top: 1px solid var(--border2);
    opacity: 0; animation: belFU .9s 1.2s forwards;
}
.bel-stat-num {
    font-family: 'Playfair Display', serif;
    font-size: 2rem; font-style: italic; color: var(--gold);
    line-height: 1; display: block;
}
.bel-stat-label {
    font-family: 'Jost', sans-serif;
    font-size: .55rem; letter-spacing: .2em;
    text-transform: uppercase; color: var(--muted2); margin-top: .3rem;
}
.bel-hero-scroll {
    position: relative; z-index: 2;
    display: flex; align-items: center; gap: 1rem;
    padding: 1.5rem var(--gap) 2.5rem;
    max-width: 1400px; margin: 0 auto; width: 100%;
}
.bel-scroll-line { width: 40px; height: 1px; background: var(--maroon2); }
.bel-scroll-txt {
    font-family: 'Jost', sans-serif;
    font-size: .55rem; letter-spacing: .25em;
    text-transform: uppercase; color: var(--muted2);
}
@keyframes belFU {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── LOOKBOOK ── */
.bel-lookbook-scroll {
    display: flex; gap: 1rem; overflow-x: auto;
    scrollbar-width: none; padding-bottom: .5rem; cursor: grab;
}
.bel-lookbook-scroll::-webkit-scrollbar { display: none; }
.bel-look-card {
    flex: 0 0 clamp(200px,22vw,280px);
    aspect-ratio: 2/3; position: relative; overflow: hidden;
    background: var(--bg3); border: 1px solid var(--border2); flex-shrink: 0;
}
.bel-look-bg {
    position: absolute; inset: 0;
    transition: transform .7s cubic-bezier(.25,.46,.45,.94);
}
.bel-look-card:hover .bel-look-bg { transform: scale(1.05); }
.bel-lb1{background:linear-gradient(155deg,#1c1212,#301c1c,#141010);}
.bel-lb2{background:linear-gradient(155deg,#181215,#281825,#120f14);}
.bel-lb3{background:linear-gradient(155deg,#121418,#181e28,#0e1015);}
.bel-lb4{background:linear-gradient(155deg,#181512,#28221a,#141010);}
.bel-lb5{background:linear-gradient(155deg,#121818,#182825,#0e1415);}
.bel-look-img { width:100%;height:100%;object-fit:cover;position:absolute;inset:0; }
.bel-look-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.9) 100%);
    display: flex; flex-direction: column;
    justify-content: flex-end; padding: 1.2rem;
}
.bel-look-num {
    position: absolute; top: .8rem; right: .8rem;
    font-family: 'Jost', sans-serif;
    font-size: .5rem; letter-spacing: .15em; color: rgba(201,169,110,.4);
}
.bel-look-title {
    font-family: 'Playfair Display', serif;
    font-size: 1rem; font-style: italic; margin-bottom: .2rem;
}
.bel-look-sub {
    font-family: 'Jost', sans-serif;
    font-size: .52rem; letter-spacing: .12em;
    text-transform: uppercase; color: var(--gold);
}
.bel-look-hover {
    position: absolute; inset: 0;
    background: rgba(0,0,0,.45);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity .3s;
}
.bel-look-card:hover .bel-look-hover { opacity: 1; }
.bel-look-hover a {
    font-family: 'Jost', sans-serif;
    font-size: .62rem; letter-spacing: .2em;
    text-transform: uppercase; color: var(--cream);
    border-bottom: 1px solid var(--gold); padding-bottom: 2px;
}

/* ── TESTIMONIALS ── */
.bel-testimonials-grid {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 1.5rem;
}
.bel-t-card {
    background: var(--bg3);
    border: 1px solid var(--border2);
    padding: 2rem; position: relative;
}
.bel-t-card::before {
    content: '"'; position: absolute;
    top: 1rem; right: 1.5rem;
    font-family: 'Playfair Display', serif;
    font-size: 5rem; color: rgba(122,26,26,.2);
    line-height: 1; font-style: italic;
}
.bel-t-stars { color: var(--maroon2); font-size: .8rem; letter-spacing: .1em; margin-bottom: 1rem; }
.bel-t-quote {
    font-size: 1rem; line-height: 1.75;
    color: rgba(240,235,227,.7);
    margin-bottom: 1.3rem; font-style: italic;
    position: relative; z-index: 1;
}
.bel-t-author { display: flex; align-items: center; gap: .8rem; }
.bel-t-avatar {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--maroon); border: 1px solid var(--maroon2);
    display: flex; align-items: center; justify-content: center;
    font-family: 'Playfair Display', serif;
    font-size: .9rem; font-style: italic; color: var(--gold2); flex-shrink: 0;
}
.bel-t-name {
    font-family: 'Jost', sans-serif;
    font-size: .65rem; letter-spacing: .1em;
    text-transform: uppercase; color: var(--cream);
}
.bel-t-loc {
    font-family: 'Jost', sans-serif;
    font-size: .55rem; letter-spacing: .08em; color: var(--muted2);
}
.bel-t-verified {
    margin-left: auto;
    font-family: 'Jost', sans-serif;
    font-size: .5rem; letter-spacing: .1em;
    text-transform: uppercase; color: var(--gold);
    border: 1px solid var(--maroon2); padding: .2rem .5rem;
}

/* ── SINGLE PRODUCT ── */
.bel-product-layout {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 4rem; margin-top: 2rem;
}
.bel-product-page-title {
    font-family: 'Playfair Display', serif !important;
    font-size: clamp(1.8rem,3vw,2.8rem) !important;
    font-weight: 400 !important; font-style: italic !important;
    color: var(--cream) !important; margin-bottom: .8rem !important;
}
.bel-product-page-price { margin-bottom: 1.5rem; }
.bel-product-page-desc {
    color: var(--muted) !important;
    font-size: 1rem !important; line-height: 1.8 !important;
    margin-bottom: 2rem !important;
}
.bel-product-trust {
    display: flex; flex-direction: column; gap: .8rem;
    margin-top: 2rem; padding-top: 1.5rem;
    border-top: 1px solid var(--border2);
}
.bel-trust-item {
    display: flex; align-items: center; gap: .8rem;
    font-family: 'Jost', sans-serif;
    font-size: .62rem; letter-spacing: .1em; color: var(--muted);
}
.bel-trust-icon { color: var(--gold); }

/* WC gallery override */
.woocommerce div.product div.images { float: none !important; width: 100% !important; }
.woocommerce div.product div.summary { float: none !important; width: 100% !important; clear: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: var(--bg3) !important; border-color: var(--border2) !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color: var(--muted) !important; font-family: 'Jost', sans-serif !important; font-size: .65rem !important; letter-spacing: .15em !important; text-transform: uppercase !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--cream) !important; }
.woocommerce div.product .woocommerce-tabs .panel { background: var(--bg3) !important; border: 1px solid var(--border2) !important; color: var(--muted) !important; }

/* ── WC BREADCRUMB ── */
.woocommerce-breadcrumb {
    font-family: 'Jost', sans-serif !important;
    font-size: .58rem !important; letter-spacing: .15em !important;
    text-transform: uppercase !important; color: var(--muted2) !important;
    margin-bottom: 1.5rem !important;
}
.woocommerce-breadcrumb a { color: var(--gold) !important; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
    .bel-products-grid { grid-template-columns: repeat(3,1fr); }
    .bel-cats-grid { grid-template-columns: repeat(2,1fr); }
    .bel-cat-item:first-child { grid-column: span 2; grid-row: auto; aspect-ratio: 16/7; }
    .bel-shop-layout { grid-template-columns: 200px 1fr; }
    .bel-testimonials-grid { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
    .bel-products-grid { grid-template-columns: repeat(2,1fr); }
    .bel-editorial-wrap { grid-template-columns: 1fr; }
    .bel-ed-visual { min-height: 300px; }
    .bel-product-layout { grid-template-columns: 1fr; }
    .bel-shop-layout { grid-template-columns: 1fr; }
    .bel-shop-filters { position: fixed; top: 0; left: -100%; bottom: 0; z-index: 9500; width: 280px; transition: left .35s; overflow-y: auto; }
    .bel-shop-filters.open { left: 0; }
    .bel-filters-close { display: block; }
}
@media (max-width: 600px) {
    .bel-products-grid { grid-template-columns: repeat(2,1fr); gap: 1rem; }
    .bel-cats-grid { grid-template-columns: 1fr 1fr; }
    .bel-hero-stats { gap: 1.5rem; flex-wrap: wrap; }
    .bel-ed-features { grid-template-columns: 1fr; }
}
