/* ============================================================
   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 ── */
.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; }
}
