/*
 Theme Name:   Hello Elementor Child
 Theme URI:    https://shop.thecloudgrid.com/
 Description:  A child theme for Hello Elementor, optimized for CloudGrid. Vellum redesign.
 Author:       Gemini CLI
 Template:     hello-elementor
 Version:      2.0.0
*/

/* =========================================================================
   VELLUM DESIGN TOKENS
   ========================================================================= */
:root {
    --cream:      #F5F0E8;
    --cream-90:   rgba(245, 240, 232, 0.95);
    --umber:      #1A1410;
    --umber-80:   rgba(26, 20, 16, 0.80);
    --umber-50:   rgba(26, 20, 16, 0.50);
    --warm-gray:  #8A7E72;
    --taupe:      #C4B8AB;
    --taupe-40:   rgba(196, 184, 171, 0.40);
    --tomato:     #D4563C;
    --radius:     2px;
    --serif:      'Instrument Serif', Georgia, serif;
    --sans:       'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --mono:       'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
    --spot-h:        40px;   /* rotating product spotlight strip */
    --header-main-h: 72px;   /* logo / nav / icons row */
    --header-h:      112px;  /* spotlight + main row — drives body padding & all offsets */
}

/* 1. FORCE HIDE THEME ELEMENTS */
header:not(#custom-header), footer:not(#custom-footer),
.site-header:not(#custom-header), .site-footer:not(#custom-footer),
.wp-block-template-part, .site-branding, .page-header, .entry-title, .entry-header,
.woocommerce-products-header, .woocommerce-breadcrumb, .page-title {
    display: none !important; opacity: 0 !important; visibility: hidden !important; height: 0 !important; padding: 0 !important; margin: 0 !important; pointer-events: none !important;
}

/* 2. PROTECT OUR CUSTOM ELEMENTS */
#custom-header, #custom-footer { display: flex !important; opacity: 1 !important; visibility: visible !important; height: auto !important; pointer-events: auto !important; }
#cg-toast { display: none; }
#cg-toast.active { display: flex !important; }
#cg-cart-drawer { pointer-events: auto !important; }

/* 3. CORE RESET */
*, *::before, *::after { box-sizing: border-box !important; }
html, body { min-height: 100% !important; margin: 0 !important; padding: 0 !important; background-color: var(--cream) !important; width: 100% !important; overflow-x: hidden !important; font-size: 16px; line-height: 1.6; }
#page-container, #main-content, .site-main, .entry-content, .post-content, .wp-site-blocks, article { width: 100% !important; max-width: 100% !important; padding-left: 0 !important; padding-right: 0 !important; margin: 0 !important; background: transparent !important; }
body {
    display: flex; flex-direction: column; min-height: 100vh;
    color: var(--umber) !important;
    font-family: var(--sans);
    font-size: 15px;
    -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
/* Non-home pages: solid header, push content below it. Home page: hero sits under the transparent nav. */
body:not(.home) { padding-top: var(--header-h) !important; }
.admin-bar body:not(.home) { padding-top: calc(var(--header-h) + 32px) !important; }
@media screen and (max-width: 782px) {
    .admin-bar body:not(.home) { padding-top: calc(var(--header-h) + 46px) !important; }
}
#page-container, .site-main, #main-content { flex: 1 0 auto; display: flex; flex-direction: column; }
a { color: inherit; }
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 400; letter-spacing: 0; }

/* =========================================================================
   4. HEADER / NAVIGATION (Vellum)
   ========================================================================= */
#custom-header {
    position: fixed; top: 0; left: 0; width: 100%; height: var(--header-h) !important;
    background: var(--cream-90);
    -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--taupe-40);
    z-index: 9999999;
    display: flex !important; flex-direction: column; align-items: stretch; justify-content: flex-start;
    padding: 0; box-sizing: border-box;
    transition: background 0.5s ease, border-color 0.5s ease;
}
.cg-header-main {
    display: flex; align-items: center; justify-content: space-between;
    width: 100%; height: var(--header-main-h); padding: 0 5vw; box-sizing: border-box;
}

/* Header spotlight — rotating featured-product strip */
#cg-spotlight {
    flex: 0 0 var(--spot-h); width: 100%; height: var(--spot-h);
    background: var(--umber); overflow: hidden; position: relative;
}
.cg-spot-track { position: relative; width: 100%; height: 100%; }
.cg-spot {
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    gap: 11px; padding: 0 5vw; text-decoration: none !important; white-space: nowrap;
    transform: translateX(100%); transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}
.cg-spot.is-active  { transform: translateX(0); }
.cg-spot.is-leaving { transform: translateX(-100%); }
.cg-spot img { flex: 0 0 24px; width: 24px; height: 24px; object-fit: cover; border-radius: var(--radius); }
.cg-spot-label { font-family: var(--mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--tomato); }
.cg-spot-name { font-family: var(--sans); font-size: 12px; font-weight: 500; color: var(--cream); transition: color 0.2s ease; }
.cg-spot-price { font-family: var(--mono); font-size: 12px; color: var(--taupe); }
.cg-spot-price .amount, .cg-spot-price bdi { color: var(--taupe) !important; }
.cg-spot-price del { display: none; }
.cg-spot-arrow { color: var(--cream); font-size: 13px; transition: transform 0.25s ease; }
.cg-spot:hover .cg-spot-name { color: var(--tomato); }
.cg-spot:hover .cg-spot-arrow { transform: translateX(3px); }
@media screen and (max-width: 600px) {
    .cg-spot { gap: 8px; }
    .cg-spot-label { display: none; }
    .cg-spot img { flex-basis: 22px; width: 22px; height: 22px; }
    .cg-spot-name, .cg-spot-price { font-size: 11px; }
}

.admin-bar #custom-header { top: 32px !important; }
@media screen and (max-width: 782px) { .admin-bar #custom-header { top: 46px !important; } }

.header-left  { flex: 1; display: flex; align-items: center; gap: 14px; }
.header-nav   { flex: 0 0 auto; display: flex; justify-content: center; align-items: center; gap: 34px; }
.header-right { flex: 1; display: flex; align-items: center; justify-content: flex-end; gap: 18px; }

.header-link {
    font-family: var(--sans); font-size: 13px; font-weight: 400;
    letter-spacing: 0.02em; color: var(--umber) !important;
    text-decoration: none !important; transition: opacity 0.25s ease;
}
.header-link:hover { opacity: 0.6; }

.header-icon-btn {
    cursor: pointer; color: var(--umber) !important; background: transparent; border: none;
    transition: opacity 0.25s ease; display: flex !important; align-items: center;
    position: relative; text-decoration: none !important; padding: 6px;
}
.header-icon-btn:hover { opacity: 0.6; }
.header-icon-btn svg { width: 19px; height: 19px; fill: none; stroke: currentColor; stroke-width: 1.6; }
.cart-bubble {
    position: absolute; top: -2px; right: -4px;
    background: var(--tomato); color: var(--cream) !important;
    font-family: var(--mono); font-size: 9px; font-weight: 500;
    width: 16px; height: 16px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center; line-height: 1;
}
.cart-bubble:empty, .cart-bubble.is-zero { display: none; }

/* Logo (theCloudGrid branding kept, Vellum-styled) */
.header-logo { text-decoration: none !important; display: flex !important; align-items: baseline !important; position: relative; z-index: 10000001; }
.logo-prefix { font-family: var(--mono); font-size: 12px; font-weight: 400; color: var(--warm-gray) !important; margin-right: 1px; }
.logo-main-wrap { position: relative; display: inline-flex; flex-direction: column; align-items: flex-start; }
.logo-the-stacked { font-family: var(--mono); font-size: 7px; text-transform: uppercase; font-weight: 500; letter-spacing: 0.18em; color: var(--tomato) !important; position: absolute; top: -2px; left: -2px; }
.logo-main { font-family: var(--serif); font-size: 26px; font-weight: 400; letter-spacing: 0.01em; color: var(--umber) !important; line-height: 1; }

/* Transparent-over-hero state — only on the homepage before scroll */
body.home #custom-header:not(.scrolled) {
    background: transparent; border-bottom-color: transparent; backdrop-filter: none; -webkit-backdrop-filter: none;
}
body.home #custom-header:not(.scrolled) .header-link,
body.home #custom-header:not(.scrolled) .header-icon-btn,
body.home #custom-header:not(.scrolled) .logo-main { color: var(--cream) !important; }
body.home #custom-header:not(.scrolled) .logo-prefix { color: rgba(245,240,232,0.7) !important; }
body.home #custom-header:not(.scrolled) .hamburger span { background: var(--cream); }

/* 5. HAMBURGER */
.hamburger {
    display: none; cursor: pointer; z-index: 10000001;
    flex-direction: column; gap: 5px; padding: 8px;
    position: relative; width: 40px; height: 40px;
    justify-content: center; align-items: center;
}
.hamburger span { width: 20px; height: 1.5px; background: var(--umber); transition: 0.3s; display: block; }
.hamburger.active span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* 6. SEARCH BAR */
#cg-search-bar {
    position: fixed; top: var(--header-h); left: 0; width: 100%; height: 72px;
    background: var(--cream); border-bottom: 1px solid var(--taupe-40); z-index: 9999998;
    display: none; align-items: center; justify-content: center;
    padding: 0 5vw; box-sizing: border-box; transform: translateY(-100%); transition: transform 0.4s;
}
#cg-search-bar.active { display: flex !important; transform: translateY(0) !important; }
#cg-search-bar input {
    width: 100% !important; background: transparent !important;
    border: none !important; border-bottom: 1px solid var(--taupe) !important;
    border-radius: 0 !important; color: var(--umber) !important;
    font-family: var(--sans) !important; font-size: 17px !important;
    padding: 12px 4px !important; outline: none !important;
}
#cg-search-bar input::placeholder { color: var(--warm-gray) !important; }
.admin-bar #cg-search-bar { top: calc(var(--header-h) + 32px); }

@media screen and (max-width: 880px) {
    .header-nav { display: none !important; }
    .hamburger { display: flex !important; }
}
@media screen and (max-width: 782px) {
    #cg-search-bar { top: var(--header-h); }
    .admin-bar #cg-search-bar { top: calc(var(--header-h) + 46px); }
}

/* =========================================================================
   7. FOOTER (Vellum 4-column)
   ========================================================================= */
#custom-footer {
    flex-shrink: 0; background: var(--cream); border-top: 1px solid var(--taupe);
    padding: 80px 5vw 40px !important; color: var(--warm-gray);
    display: block !important; width: 100% !important; box-sizing: border-box;
}
.cg-footer-grid {
    max-width: 1280px; margin: 0 auto;
    display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px;
}
.cg-footer-col h3.cg-footer-brand {
    font-family: var(--serif); font-size: 22px; color: var(--umber);
    margin: 0 0 12px 0; letter-spacing: 0.02em;
}
.cg-footer-tagline { font-size: 13px; color: var(--warm-gray); line-height: 1.6; margin: 0; max-width: 240px; }
.cg-footer-col h4 {
    font-family: var(--sans); font-weight: 500; font-size: 13px;
    color: var(--umber); margin: 0 0 16px 0;
}
.cg-footer-col ul { list-style: none; padding: 0; margin: 0; }
.cg-footer-col ul li { margin-bottom: 10px; }
.cg-footer-col ul li a {
    font-family: var(--sans); font-size: 13px; color: var(--warm-gray) !important;
    text-decoration: none !important; transition: color 0.2s ease;
}
.cg-footer-col ul li a:hover { color: var(--umber) !important; }
.footer-socials { display: flex; gap: 16px; align-items: center; margin-top: 16px; }
.footer-socials a { color: var(--warm-gray) !important; transition: color 0.2s ease; display: flex !important; }
.footer-socials a:hover { color: var(--umber) !important; }
.footer-socials svg { width: 18px !important; height: 18px !important; fill: currentColor !important; }
.cg-footer-bottom {
    max-width: 1280px; margin: 40px auto 0; padding-top: 32px;
    border-top: 1px solid var(--taupe);
    display: flex; justify-content: space-between; align-items: center;
}
.cg-footer-bottom .footer-credits { color: var(--taupe); font-size: 12px; font-family: var(--sans); }
.cg-footer-legal { display: flex; gap: 24px; }
.cg-footer-legal a { color: var(--taupe) !important; font-size: 12px; text-decoration: none !important; transition: color 0.2s ease; }
.cg-footer-legal a:hover { color: var(--umber) !important; }

@media screen and (max-width: 880px) {
    .cg-footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media screen and (max-width: 560px) {
    #custom-footer { padding: 56px 5vw 32px !important; }
    .cg-footer-grid { grid-template-columns: 1fr; gap: 28px; }
    .cg-footer-bottom { flex-direction: column; gap: 14px; text-align: center; }
}

/* MOBILE MENU */
#menu-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: var(--umber-50); z-index: 99999998;
    opacity: 0; visibility: hidden; transition: all 0.4s;
    backdrop-filter: blur(0px); display: block !important;
}
#menu-overlay.active { opacity: 1 !important; visibility: visible !important; backdrop-filter: blur(6px) !important; }

.mobile-menu {
    position: fixed !important; top: 0 !important; left: 0 !important; width: 84% !important; max-width: 320px !important; height: 100vh !important;
    background: var(--cream) !important; z-index: 99999999 !important; padding: 28px 26px !important;
    transition: transform 0.4s ease !important; border-right: 1px solid var(--taupe) !important;
    transform: translateX(-100%) !important; visibility: hidden !important;
    display: flex !important; flex-direction: column !important;
}
.mobile-menu.active { transform: translateX(0) !important; visibility: visible !important; }
.mobile-link {
    color: var(--umber) !important; text-decoration: none !important;
    font-family: var(--sans); font-size: 16px; font-weight: 400;
    padding: 16px 0; border-bottom: 1px solid var(--taupe-40); display: block !important;
}
.mobile-link:last-child { border-bottom: none; }
.menu-top-row { display: flex; justify-content: space-between; align-items: center; padding-bottom: 18px; border-bottom: 1px solid var(--taupe); margin-bottom: 18px; }
.menu-login-btn { display: flex; align-items: center; gap: 10px; color: var(--umber) !important; text-decoration: none !important; font-family: var(--sans); font-size: 15px; font-weight: 500; }
.menu-login-btn svg { width: 19px; height: 19px; fill: var(--tomato); }
.menu-close-btn { font-size: 30px; color: var(--warm-gray); cursor: pointer; line-height: 1; padding: 4px; }
.sidebar-search-wrap { margin-bottom: 22px; position: relative; width: 100%; }
.sidebar-search-wrap form { position: relative; width: 100%; display: flex; align-items: center; }
.sidebar-search-wrap input {
    width: 100% !important; background: transparent !important;
    border: 1px solid var(--taupe) !important; border-radius: var(--radius) !important;
    color: var(--umber) !important; padding: 11px 14px 11px 40px !important;
    font-family: var(--sans) !important; font-size: 14px !important; outline: none !important; height: 42px !important;
}
.sidebar-search-wrap input::placeholder { color: var(--warm-gray) !important; }
.sidebar-search-wrap svg {
    position: absolute !important; left: 12px !important; top: 50% !important;
    transform: translateY(-50%) !important; width: 17px !important; height: 17px !important;
    fill: var(--warm-gray) !important; pointer-events: none !important; z-index: 2;
}

/* =========================================================================
   CART DRAWER (Vellum slide-out)
   ========================================================================= */
#cg-cart-drawer { position: fixed; inset: 0; z-index: 99999990; display: none; }
#cg-cart-drawer.active { display: block; }
.cg-drawer-overlay { position: absolute; inset: 0; background: var(--umber-50); opacity: 0; transition: opacity 0.35s ease; }
#cg-cart-drawer.active .cg-drawer-overlay { opacity: 1; }
.cg-drawer-panel {
    position: absolute; top: 0; right: 0; height: 100%; width: 100%; max-width: 420px;
    background: var(--cream); display: flex; flex-direction: column;
    box-shadow: -20px 0 60px rgba(26,20,16,0.25);
    transform: translateX(100%); transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
}
#cg-cart-drawer.active .cg-drawer-panel { transform: translateX(0); }
.cg-drawer-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 22px 24px; border-bottom: 1px solid var(--taupe);
}
.cg-drawer-head h2 { font-family: var(--serif); font-size: 24px; color: var(--umber); margin: 0; }
.cg-drawer-close { background: none; border: none; cursor: pointer; color: var(--umber); padding: 4px; display: flex; }
.cg-drawer-close:hover { color: var(--tomato); }
.cg-drawer-close svg { width: 20px; height: 20px; }
.cg-drawer-body { flex: 1; overflow-y: auto; padding: 8px 24px; }
.cg-drawer-foot { padding: 20px 24px; border-top: 1px solid var(--taupe); }
.cg-drawer-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; text-align: center; padding: 40px 0; }
.cg-drawer-empty p { font-family: var(--sans); color: var(--warm-gray); font-size: 14px; margin: 0 0 6px; }
.cg-drawer-empty .cg-drawer-empty-sub { color: var(--taupe); font-size: 12px; }

/* WooCommerce mini-cart inside the drawer */
#cg-cart-drawer .widget_shopping_cart_content > ul.cart_list,
#cg-cart-drawer ul.cart_list, #cg-cart-drawer ul.product_list_widget {
    list-style: none; margin: 0; padding: 0;
}
#cg-cart-drawer ul.cart_list li, #cg-cart-drawer ul.product_list_widget li {
    display: flex; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--taupe-40);
    position: relative; font-family: var(--sans);
}
#cg-cart-drawer ul.cart_list li img {
    width: 60px !important; height: 60px !important; object-fit: cover;
    border-radius: var(--radius); float: none !important; margin: 0 !important;
}
#cg-cart-drawer ul.cart_list li a { color: var(--umber) !important; text-decoration: none !important; font-size: 14px; font-weight: 500; }
#cg-cart-drawer ul.cart_list li .quantity { font-family: var(--mono); font-size: 12px; color: var(--warm-gray); }
#cg-cart-drawer ul.cart_list li .amount { font-family: var(--mono); font-weight: 500; color: var(--umber); }
#cg-cart-drawer ul.cart_list li a.remove {
    position: absolute !important; top: 16px !important; right: 0 !important;
    color: var(--warm-gray) !important; font-size: 18px !important; line-height: 1 !important;
    background: transparent !important; border: none !important;
}
#cg-cart-drawer ul.cart_list li a.remove:hover { color: var(--tomato) !important; background: transparent !important; }
#cg-cart-drawer .woocommerce-mini-cart__total {
    display: flex; justify-content: space-between; align-items: center;
    font-family: var(--sans); font-size: 14px; color: var(--warm-gray);
    border: none !important; padding: 0 0 16px 0 !important; margin: 0 !important;
}
#cg-cart-drawer .woocommerce-mini-cart__total strong { font-weight: 400; }
#cg-cart-drawer .woocommerce-mini-cart__total .amount { font-family: var(--mono); font-size: 17px; color: var(--umber); }
#cg-cart-drawer .woocommerce-mini-cart__empty-message { font-family: var(--sans); color: var(--warm-gray); font-size: 14px; text-align: center; padding: 40px 0; }
.cg-drawer-checkout {
    display: block; width: 100%; text-align: center; box-sizing: border-box;
    background: var(--umber); color: var(--cream) !important;
    font-family: var(--sans); font-size: 14px; font-weight: 500;
    padding: 15px; border: none; border-radius: var(--radius); cursor: pointer;
    text-decoration: none !important; transition: background 0.3s ease; margin-bottom: 10px;
}
.cg-drawer-checkout:hover { background: var(--tomato); }
.cg-drawer-cartlink { display: block; text-align: center; font-family: var(--sans); font-size: 12px; color: var(--warm-gray) !important; text-decoration: none !important; }
.cg-drawer-cartlink:hover { color: var(--umber) !important; }
#cg-cart-drawer .buttons, #cg-cart-drawer .woocommerce-mini-cart__buttons { display: none !important; }

/* =========================================================================
   8. CART PAGE
   ========================================================================= */
.cg-cart-page-wrapper { max-width: 1000px; margin: 0 auto !important; padding: 60px 5vw 250px !important; width: 100% !important; box-sizing: border-box; }
.cg-cart-title { font-family: var(--serif); font-size: 42px; margin-bottom: 28px; color: var(--umber); }
.woocommerce-cart-form { background: transparent; border: 1px solid var(--taupe); border-radius: var(--radius); padding: 8px 24px; margin-bottom: 40px; }

.cg-cart-item { display: flex !important; padding: 22px 0; border-bottom: 1px solid var(--taupe-40) !important; align-items: flex-start; gap: 16px; width: 100% !important; position: relative !important; }
.cg-cart-item:last-child { border-bottom: none !important; }
.cg-item-image img { width: 80px !important; height: 80px !important; object-fit: cover; border-radius: var(--radius); background: var(--taupe-40); }
.cg-item-details { flex: 1; display: flex; flex-direction: column; }
.cg-item-name a { color: var(--umber) !important; text-decoration: none !important; font-weight: 500; font-size: 15px; margin-bottom: 4px; line-height: 1.3; }
.variation { display: flex; gap: 8px; font-size: 12px; color: var(--warm-gray) !important; list-style: none; padding: 0; margin: 2px 0; }
.cg-item-controls { display: flex !important; align-items: center !important; gap: 16px !important; margin-top: 12px !important; flex-direction: row !important; }
.cg-qty-wrapper, .woocommerce .quantity { display: flex !important; align-items: center !important; gap: 6px !important; }
.cg-item-price { font-family: var(--mono); font-size: 14px; color: var(--umber); font-weight: 500; }
.qty-minus, .qty-plus { background: transparent !important; border: 1px solid var(--taupe) !important; width: 30px !important; height: 30px !important; border-radius: var(--radius) !important; font-size: 15px !important; cursor: pointer; color: var(--umber) !important; display: flex; align-items: center; justify-content: center; }
.qty-minus:hover, .qty-plus:hover { border-color: var(--umber) !important; }
.woocommerce .quantity .qty { background: transparent !important; color: var(--umber) !important; border-radius: var(--radius) !important; width: 44px !important; height: 30px !important; font-family: var(--mono) !important; font-size: 13px !important; text-align: center !important; border: 1px solid var(--taupe) !important; }
.remove { position: absolute !important; top: 18px !important; right: 0 !important; font-size: 22px !important; color: var(--warm-gray) !important; text-decoration: none !important; line-height: 1 !important; z-index: 5; background: transparent !important; border: none !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; }
.remove:hover { color: var(--tomato) !important; background: transparent !important; }

.cg-cart-actions { display: flex; margin-top: 20px; }
.coupon { width: 260px; position: relative; display: none !important; align-items: center; }
.coupon.active { display: flex !important; }
.coupon input#coupon_code { background: transparent !important; border: 1px solid var(--taupe) !important; color: var(--umber) !important; border-radius: var(--radius) !important; padding: 11px 70px 11px 14px !important; height: 42px !important; font-family: var(--sans) !important; font-size: 13px !important; width: 100% !important; }
.coupon .button { position: absolute !important; right: 12px !important; top: 50% !important; transform: translateY(-50%) !important; background: transparent !important; color: var(--tomato) !important; border: none !important; font-weight: 500; text-transform: uppercase; font-family: var(--mono) !important; font-size: 10px !important; cursor: pointer; }

/* Sticky checkout bar */
.cart-collaterals {
    position: fixed; bottom: 0; left: 0; width: 100%;
    background: var(--cream-90); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
    border-top: 1px solid var(--taupe);
    padding: 16px 5vw 18px !important; z-index: 999999; display: flex; justify-content: center;
}
.cart_totals { max-width: 1000px; width: 100%; display: flex; flex-direction: column; align-items: center; }
.cart_totals h2 { display: none !important; }
.cart_totals table { margin: 0 0 12px 0 !important; width: 100%; }
.cart_totals table tr:not(.order-total) { display: none !important; }
.cart_totals table tr.order-total { display: flex !important; justify-content: space-between; align-items: center; width: 100%; }
.cart_totals table tr.order-total td { font-family: var(--mono); font-size: 18px !important; font-weight: 500 !important; color: var(--umber) !important; border: none !important; padding: 0 !important; }
.cart_totals table tr.order-total th { font-size: 0 !important; padding: 0 !important; }
.cart_totals table tr.order-total th::before { content: "Estimated total"; font-family: var(--sans); font-size: 14px !important; color: var(--warm-gray) !important; visibility: visible; font-weight: 400; }
.wc-proceed-to-checkout { width: 100% !important; display: flex; flex-direction: column; gap: 0; padding: 0 !important; }
.checkout-button {
    display: block !important; text-align: center; background: var(--umber) !important; color: var(--cream) !important;
    font-family: var(--sans); padding: 15px 30px !important; font-size: 14px !important; font-weight: 500 !important;
    border-radius: var(--radius) !important; width: 100% !important; max-width: 100% !important;
    text-decoration: none !important; margin: 0 !important; transition: background 0.3s ease;
}
.checkout-button:hover { background: var(--tomato) !important; }
.woocommerce-cart .cart-collaterals .wc-proceed-to-checkout > *:not(.checkout-button) { display: none !important; }

/* =========================================================================
   9. MY ACCOUNT
   ========================================================================= */
.cg-account-page-wrapper { max-width: 900px; margin: 0 auto; padding: 60px 5vw 80px !important; width: 100%; box-sizing: border-box; }
.woocommerce-account .u-column1, .woocommerce-account .u-column2 { background: transparent; padding: 32px; border-radius: var(--radius); border: 1px solid var(--taupe); }
.woocommerce-account h2 { font-family: var(--serif) !important; font-size: 28px !important; font-weight: 400; margin-bottom: 20px; color: var(--umber) !important; }
.woocommerce-account .woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li { border-bottom: 1px solid var(--taupe-40); }
.woocommerce-account .woocommerce-MyAccount-navigation ul li a { color: var(--warm-gray) !important; text-decoration: none !important; font-family: var(--sans); font-size: 14px; display: block; padding: 12px 0; }
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover { color: var(--umber) !important; }
.woocommerce-Input, .input-text { background: transparent !important; border: 1px solid var(--taupe) !important; border-radius: var(--radius) !important; color: var(--umber) !important; font-family: var(--sans) !important; padding: 11px 14px !important; font-size: 14px !important; width: 100%; }
.woocommerce-Input:focus, .input-text:focus { border-color: var(--tomato) !important; outline: none !important; }
.woocommerce form .form-row label, .woocommerce-account label { font-family: var(--sans); font-size: 13px; color: var(--warm-gray); }
.woocommerce-form-login .button, .woocommerce-form-register .button {
    width: 100%; background: var(--umber) !important; color: var(--cream) !important;
    font-family: var(--sans); padding: 14px !important; border-radius: var(--radius) !important;
    font-weight: 500 !important; font-size: 14px !important; border: none !important; cursor: pointer; transition: background 0.3s ease;
}
.woocommerce-form-login .button:hover, .woocommerce-form-register .button:hover { background: var(--tomato) !important; }

/* TOAST */
#cg-toast { position: fixed; bottom: -100px; left: 50%; transform: translateX(-50%); background: var(--umber); border-radius: 100px; padding: 13px 14px 13px 26px; z-index: 99999999; display: flex; align-items: center; gap: 18px; box-shadow: 0 20px 50px rgba(26,20,16,0.35); transition: 0.6s cubic-bezier(0.2, 1, 0.3, 1); min-width: 300px; justify-content: space-between; }
#cg-toast.active { bottom: 40px; }
.toast-text { font-family: var(--sans); font-weight: 400; color: var(--cream); font-size: 14px; }
.toast-link { background: var(--tomato); color: var(--cream) !important; padding: 8px 16px; border-radius: 50px; font-family: var(--mono); font-weight: 500; text-decoration: none !important; font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; }

@media screen and (max-width: 782px) {
    .cg-cart-page-wrapper { padding: 40px 5vw 220px !important; }
    .cg-cart-title { font-size: 32px; }
    .woocommerce-cart-form { padding: 4px 16px; }
    .cg-item-image img { width: 70px !important; height: 70px !important; }
    .cart-collaterals { padding: 14px 5vw 16px !important; }
}

/* WOOCOMMERCE MESSAGES */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
    background: var(--cream) !important; border: 1px solid var(--taupe) !important;
    border-top: 2px solid var(--tomato) !important;
    color: var(--umber) !important; font-family: var(--sans) !important;
    padding: 16px 20px 16px 55px !important; border-radius: var(--radius) !important;
    margin-bottom: 25px !important; font-size: 14px !important;
    display: flex !important; align-items: center !important; justify-content: flex-start !important;
    list-style: none !important; position: relative !important; min-height: 52px !important;
}
.woocommerce-message::before, .woocommerce-info::before, .woocommerce-error::before {
    position: absolute !important; left: 20px !important; top: 50% !important;
    transform: translateY(-50%) !important; margin: 0 !important;
    font-size: 18px !important; color: var(--tomato) !important; font-weight: bold !important; z-index: 5 !important;
}
.woocommerce-message::before { content: "✓" !important; }
.woocommerce-info::before { content: "ℹ" !important; }
.woocommerce-error::before { content: "✕" !important; color: var(--tomato) !important; }
.woocommerce-message .button, .woocommerce-info .button, .woocommerce-error .button {
    margin-left: auto !important; background: var(--umber) !important; color: var(--cream) !important;
    font-family: var(--sans); padding: 8px 15px !important; border-radius: var(--radius) !important;
    font-size: 12px !important; font-weight: 500 !important; text-decoration: none !important;
}

.cg-coupon-toggle { color: var(--tomato) !important; font-family: var(--sans); font-size: 13px !important; font-weight: 500 !important; cursor: pointer; margin-bottom: 15px; display: inline-block; transition: 0.2s; }
.cg-coupon-toggle:hover { color: var(--umber) !important; text-decoration: underline !important; }

/* =========================================================================
   10. CHECKOUT
   ========================================================================= */
.cg-checkout-wrapper { max-width: 1200px; margin: 0 auto !important; padding: 60px 5vw !important; color: var(--umber) !important; }
.cg-checkout-columns { display: flex; gap: 44px; align-items: flex-start; }
.cg-col-billing { flex: 1.5; }
.cg-col-order { flex: 1; position: sticky; top: calc(var(--header-h) + 24px); }
.cg-checkout-section { background: transparent; border: 1px solid var(--taupe); border-radius: var(--radius); padding: 32px; margin-bottom: 28px; }
.cg-section-title { font-family: var(--serif) !important; font-size: 26px !important; font-weight: 400 !important; margin-bottom: 24px !important; color: var(--umber) !important; border-bottom: 1px solid var(--taupe-40); padding-bottom: 14px; }

.woocommerce-checkout label { display: block; font-family: var(--sans); font-size: 13px; font-weight: 400; color: var(--warm-gray); margin-bottom: 8px; margin-top: 14px; }
.woocommerce-checkout .input-text, .woocommerce-checkout select,
.select2-container--default .select2-selection--single {
    background: transparent !important; border: 1px solid var(--taupe) !important;
    border-radius: var(--radius) !important; color: var(--umber) !important;
    font-family: var(--sans) !important; padding: 12px 14px !important; font-size: 15px !important;
    width: 100% !important; height: auto !important; outline: none !important;
}
.woocommerce-checkout .input-text:focus { border-color: var(--tomato) !important; }
.select2-container--default .select2-selection--single { height: 48px !important; display: flex !important; align-items: center !important; }
.select2-container--default .select2-selection--single .select2-selection__rendered { color: var(--umber) !important; padding-left: 0 !important; }
.select2-dropdown { background: var(--cream) !important; border: 1px solid var(--taupe) !important; color: var(--umber) !important; border-radius: var(--radius) !important; }
.select2-results__option--highlighted[aria-selected] { background-color: var(--tomato) !important; }

.woocommerce-checkout-review-order-table { width: 100% !important; border-collapse: collapse !important; font-family: var(--sans); }
.woocommerce-checkout-review-order-table th, .woocommerce-checkout-review-order-table td { padding: 15px 0 !important; border-bottom: 1px solid var(--taupe-40) !important; font-size: 14px; }
.woocommerce-checkout-review-order-table .order-total th, .woocommerce-checkout-review-order-table .order-total td { font-family: var(--mono); font-size: 18px; font-weight: 500; color: var(--umber) !important; }

#payment { background: transparent !important; border: none !important; margin-top: 20px; }
#payment ul.payment_methods { padding: 0 !important; margin: 0 !important; border-bottom: 1px solid var(--taupe-40) !important; }
#payment div.payment_box { background: rgba(196,184,171,0.15) !important; color: var(--warm-gray) !important; border-radius: var(--radius) !important; padding: 15px !important; margin: 15px 0 !important; }
#payment div.payment_box::before { display: none !important; }

#place_order {
    width: 100% !important; background: var(--umber) !important; color: var(--cream) !important;
    font-family: var(--sans); padding: 18px !important; border-radius: var(--radius) !important;
    font-weight: 500 !important; font-size: 15px !important; margin-top: 20px !important;
    border: none !important; cursor: pointer !important; transition: background 0.3s ease !important;
}
#place_order:hover { background: var(--tomato) !important; }

@media screen and (max-width: 992px) {
    .cg-checkout-columns { flex-direction: column; }
    .cg-col-billing, .cg-col-order { width: 100%; }
    .cg-col-order { position: static; }
}
@media screen and (max-width: 782px) {
    .cg-checkout-wrapper { padding: 36px 5vw !important; }
    .cg-checkout-section { background: transparent !important; border: none !important; padding: 0 !important; margin-bottom: 40px; }
    .cg-section-title { font-size: 22px !important; }
}

.cg-checkout-coupon-section { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--taupe-40); }
.cg-checkout-coupon-form { display: none; position: relative; width: 100% !important; align-items: center; }
.cg-checkout-coupon-form.active { display: flex !important; }
.cg-checkout-coupon-form input#coupon_code { padding-right: 70px !important; }
.cg-checkout-coupon-form .button { position: absolute !important; right: 12px !important; top: 50% !important; transform: translateY(-50%) !important; background: transparent !important; color: var(--tomato) !important; border: none !important; font-family: var(--mono) !important; font-weight: 500 !important; font-size: 11px !important; text-transform: uppercase !important; cursor: pointer; z-index: 2; }

/* =========================================================================
   11. SINGLE PRODUCT
   ========================================================================= */
.single-product h1.product_title.entry-title {
    display: block !important; opacity: 1 !important; visibility: visible !important;
    height: auto !important; pointer-events: auto !important; padding: 0 !important;
    margin: 0 0 14px 0 !important; font-family: var(--serif) !important;
    font-size: 44px !important; font-weight: 400 !important; line-height: 1.1 !important; color: var(--umber) !important;
}
.single-product div.product {
    max-width: 1100px !important; margin: 0 auto !important; padding: 60px 5vw !important;
    width: 100% !important; box-sizing: border-box !important; display: flex !important;
    gap: 48px !important; align-items: flex-start !important; flex-wrap: wrap !important;
}
.single-product .woocommerce-product-gallery {
    flex: 1 1 320px !important; background: transparent !important; border: 1px solid var(--taupe) !important;
    border-radius: var(--radius) !important; padding: 18px !important; overflow: hidden !important;
    margin: 0 !important; box-sizing: border-box !important;
}
.single-product .woocommerce-product-gallery__wrapper { margin: 0 !important; }
.single-product .woocommerce-product-gallery__image img,
.single-product .woocommerce-product-gallery__wrapper img { border-radius: var(--radius) !important; width: 100% !important; height: auto !important; max-width: 100% !important; display: block !important; }
.single-product .woocommerce-product-gallery__image--placeholder { min-height: 240px !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.single-product .woocommerce-product-gallery--without-images .woocommerce-product-gallery__image--placeholder img,
.single-product .woocommerce-product-gallery__image--placeholder img { max-width: 55% !important; opacity: 0.4 !important; }

.single-product .product .summary.entry-summary { flex: 1.2 1 340px !important; margin: 0 !important; padding: 0 !important; box-sizing: border-box !important; }
.single-product .product .price, .single-product .product .summary .price {
    font-family: var(--mono) !important; font-size: 22px !important; font-weight: 500 !important;
    color: var(--umber) !important; margin: 0 0 18px 0 !important;
}
.single-product .product .price del { color: var(--warm-gray) !important; text-decoration: line-through !important; margin-right: 8px !important; }
.single-product .product .price ins { color: var(--umber) !important; text-decoration: none !important; }
.single-product .woocommerce-product-details__short-description {
    color: var(--warm-gray) !important; font-family: var(--sans) !important; font-size: 15px !important;
    line-height: 1.7 !important; margin: 0 0 22px 0 !important; padding-bottom: 22px !important;
    border-bottom: 1px solid var(--taupe-40) !important;
}
.single-product .woocommerce-product-details__short-description p:last-child { margin-bottom: 0 !important; }
.single-product form.cart { display: flex !important; align-items: center !important; gap: 12px !important; flex-wrap: wrap !important; margin: 0 0 26px 0 !important; }
.single-product .single_add_to_cart_button, .single-product .single_add_to_cart_button.button.alt {
    background: var(--umber) !important; color: var(--cream) !important; border: none !important;
    border-radius: var(--radius) !important; padding: 15px 32px !important; font-family: var(--sans) !important;
    font-weight: 500 !important; font-size: 14px !important; cursor: pointer !important;
    transition: background 0.3s ease !important; text-decoration: none !important;
}
.single-product .single_add_to_cart_button:hover { background: var(--tomato) !important; }
.single-product .single_add_to_cart_button:disabled, .single-product .single_add_to_cart_button.disabled { opacity: 0.5 !important; cursor: not-allowed !important; }
.single-product .product_meta { font-family: var(--mono) !important; font-size: 11px !important; text-transform: uppercase; letter-spacing: 0.06em; color: var(--warm-gray) !important; list-style: none !important; padding: 0 !important; margin: 0 !important; }
.single-product .product_meta > span { display: block !important; margin-bottom: 6px !important; }
.single-product .product_meta a { color: var(--tomato) !important; text-decoration: none !important; }
.single-product .product_meta a:hover { color: var(--umber) !important; }

.single-product .woocommerce-tabs.wc-tabs-wrapper { background: transparent !important; border: 1px solid var(--taupe) !important; border-radius: var(--radius) !important; padding: 28px !important; margin: 44px auto 0 !important; max-width: 1100px !important; box-sizing: border-box !important; }
.single-product ul.tabs.wc-tabs { display: flex !important; gap: 6px !important; list-style: none !important; padding: 0 !important; margin: 0 0 22px 0 !important; border-bottom: 1px solid var(--taupe-40) !important; flex-wrap: wrap !important; }
.single-product ul.tabs.wc-tabs::before, .single-product ul.tabs.wc-tabs::after,
.single-product ul.tabs.wc-tabs li::before, .single-product ul.tabs.wc-tabs li::after { display: none !important; content: none !important; }
.single-product ul.tabs.wc-tabs li { background: transparent !important; border: none !important; margin: 0 !important; padding: 0 !important; }
.single-product ul.tabs.wc-tabs li a { color: var(--warm-gray) !important; font-family: var(--sans) !important; padding: 10px 14px !important; text-decoration: none !important; font-weight: 400 !important; font-size: 14px !important; display: block !important; }
.single-product ul.tabs.wc-tabs li.active a, .single-product ul.tabs.wc-tabs li a:hover { color: var(--umber) !important; }
.single-product ul.tabs.wc-tabs li.active a { border-bottom: 2px solid var(--tomato) !important; }
.single-product .woocommerce-Tabs-panel { color: var(--umber) !important; font-family: var(--sans) !important; font-size: 14px !important; line-height: 1.7 !important; }
.single-product .woocommerce-Tabs-panel h2 { font-family: var(--serif) !important; color: var(--umber) !important; font-size: 24px !important; font-weight: 400 !important; }

.single-product .related.products { max-width: 1100px !important; margin: 52px auto 0 !important; padding: 0 5vw !important; width: 100% !important; box-sizing: border-box !important; float: none !important; }
.single-product .related.products > h2 { font-family: var(--serif) !important; color: var(--umber) !important; font-size: 32px !important; font-weight: 400 !important; margin: 0 0 24px 0 !important; }
.single-product .related.products ul.products { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 24px !important; list-style: none !important; padding: 0 !important; margin: 0 !important; }
.single-product .related.products ul.products::before, .single-product .related.products ul.products::after { display: none !important; content: none !important; }

@media screen and (max-width: 992px) {
    .single-product div.product { flex-direction: column !important; gap: 32px !important; }
    .single-product .woocommerce-product-gallery, .single-product .product .summary.entry-summary { flex: 1 1 100% !important; width: 100% !important; }
    .single-product .related.products ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}
@media screen and (max-width: 782px) {
    .single-product div.product { padding: 40px 5vw !important; gap: 28px !important; }
    .single-product h1.product_title.entry-title { font-size: 34px !important; }
    .single-product .product .price, .single-product .product .summary .price { font-size: 19px !important; }
    .single-product .single_add_to_cart_button, .single-product .single_add_to_cart_button.button.alt { flex: 1 1 100% !important; width: 100% !important; text-align: center !important; }
    .single-product .woocommerce-tabs.wc-tabs-wrapper { padding: 22px !important; margin-top: 36px !important; }
    .single-product ul.tabs.wc-tabs { flex-wrap: nowrap !important; overflow-x: auto !important; -webkit-overflow-scrolling: touch !important; }
    .single-product ul.tabs.wc-tabs li a { white-space: nowrap !important; }
    .single-product .related.products { padding: 0 5vw !important; margin-top: 40px !important; }
    .single-product .related.products ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }
}

/* =========================================================================
   PRODUCT CARD — shared by shop archive + related products (Vellum)
   ========================================================================= */
.woocommerce ul.products li.product,
.single-product .related.products ul.products li.product {
    background: transparent !important; border: none !important; border-radius: 0 !important;
    padding: 0 !important; margin: 0 !important; width: auto !important; float: none !important;
    box-sizing: border-box !important; display: flex !important; flex-direction: column !important;
    position: relative !important;
}
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
.single-product .related.products ul.products li.product a.woocommerce-LoopProduct-link {
    text-decoration: none !important; color: inherit !important; display: flex !important;
    flex-direction: column !important; flex: 1 1 auto !important;
}
.woocommerce ul.products li.product img,
.single-product .related.products ul.products li.product img {
    border-radius: var(--radius) !important; width: 100% !important; height: auto !important;
    aspect-ratio: 4 / 5 !important; object-fit: cover !important; display: block !important;
    margin: 0 0 14px 0 !important; transition: transform 0.4s ease !important;
}
.woocommerce ul.products li.product:hover img,
.single-product .related.products ul.products li.product:hover img { transform: scale(1.03) !important; }
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.single-product .related.products ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--sans) !important; color: var(--umber) !important; font-size: 15px !important;
    font-weight: 500 !important; line-height: 1.35 !important; padding: 0 !important; margin: 0 0 6px 0 !important;
}
.woocommerce ul.products li.product .price,
.single-product .related.products ul.products li.product .price {
    font-family: var(--mono) !important; color: var(--umber) !important; font-size: 14px !important;
    font-weight: 500 !important; margin: 0 0 12px 0 !important; display: block !important;
}
.woocommerce ul.products li.product .price del { color: var(--warm-gray) !important; text-decoration: line-through !important; }
.woocommerce ul.products li.product .price ins { color: var(--umber) !important; text-decoration: none !important; }
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button,
.single-product .related.products ul.products li.product .button,
.single-product .related.products ul.products li.product .add_to_cart_button {
    background: var(--umber) !important; color: var(--cream) !important; border: none !important;
    border-radius: var(--radius) !important; padding: 11px 16px !important; font-family: var(--sans) !important;
    font-weight: 500 !important; font-size: 13px !important; text-decoration: none !important;
    display: block !important; text-align: center !important; cursor: pointer !important;
    margin-top: auto !important; transition: background 0.25s ease !important;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover,
.single-product .related.products ul.products li.product .button:hover { background: var(--tomato) !important; }
.woocommerce ul.products li.product .add_to_cart_button.loading { opacity: 0.6 !important; }
.woocommerce ul.products li.product .added_to_cart { display: none !important; }

/* =========================================================================
   12. SHOP ARCHIVE
   ========================================================================= */
.woocommerce .woocommerce-products-header,
.woocommerce .woocommerce-products-header__title,
.woocommerce .woocommerce-products-header .page-title {
    display: block !important; opacity: 1 !important; visibility: visible !important;
    height: auto !important; pointer-events: auto !important;
}
.woocommerce .woocommerce-products-header {
    max-width: 1280px !important; margin: 0 auto 24px !important; padding: 60px 5vw 20px !important;
    width: 100% !important; box-sizing: border-box !important; border-bottom: 1px solid var(--taupe-40) !important;
}
.woocommerce .woocommerce-products-header__title,
.woocommerce .woocommerce-products-header .page-title {
    font-family: var(--serif) !important; font-size: 48px !important; font-weight: 400 !important;
    line-height: 1.1 !important; color: var(--umber) !important; margin: 0 0 8px 0 !important; padding: 0 !important;
}
.woocommerce .woocommerce-products-header .page-description { display: none !important; }

.woocommerce .woocommerce-result-count {
    max-width: 1280px !important; margin: 0 auto 8px !important; padding: 0 5vw !important;
    width: 100% !important; box-sizing: border-box !important; display: block !important; float: none !important;
    color: var(--warm-gray) !important; font-family: var(--mono) !important; font-size: 11px !important;
    text-transform: uppercase; letter-spacing: 0.06em;
}
.woocommerce .woocommerce-ordering {
    max-width: 1280px !important; margin: 0 auto 24px !important; padding: 0 5vw 16px !important;
    width: 100% !important; box-sizing: border-box !important; display: block !important; float: none !important;
    border-bottom: 1px solid var(--taupe-40) !important;
}
.woocommerce .woocommerce-ordering select.orderby {
    background: transparent !important; border: 1px solid var(--taupe) !important; border-radius: var(--radius) !important;
    color: var(--umber) !important; font-family: var(--sans) !important; padding: 9px 12px !important;
    font-size: 13px !important; cursor: pointer !important; max-width: 100% !important;
}
.woocommerce ul.products {
    display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 28px !important;
    list-style: none !important; padding: 0 5vw 80px !important; margin: 0 auto !important;
    max-width: 1280px !important; width: 100% !important; box-sizing: border-box !important;
}
.woocommerce ul.products::before, .woocommerce ul.products::after { display: none !important; content: none !important; }

.woocommerce nav.woocommerce-pagination {
    max-width: 1280px !important; margin: 0 auto 80px !important; padding: 0 5vw !important;
    width: 100% !important; box-sizing: border-box !important; text-align: center !important;
}
.woocommerce nav.woocommerce-pagination ul { display: inline-flex !important; flex-wrap: wrap !important; justify-content: center !important; list-style: none !important; padding: 0 !important; margin: 0 !important; border: none !important; }
.woocommerce nav.woocommerce-pagination ul li { margin: 0 4px !important; border: none !important; }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span {
    background: transparent !important; border: 1px solid var(--taupe) !important; color: var(--umber) !important;
    font-family: var(--mono) !important; border-radius: var(--radius) !important; padding: 8px 13px !important;
    text-decoration: none !important; display: block !important; font-size: 13px !important;
}
.woocommerce nav.woocommerce-pagination ul li a:hover { border-color: var(--umber) !important; }
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--umber) !important; color: var(--cream) !important; border-color: var(--umber) !important; }

@media screen and (max-width: 992px) {
    .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; }
    .single-product .related.products ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}
@media screen and (max-width: 782px) {
    .woocommerce .woocommerce-products-header { padding: 40px 5vw 16px !important; }
    .woocommerce .woocommerce-products-header__title,
    .woocommerce .woocommerce-products-header .page-title { font-size: 34px !important; }
    .woocommerce .woocommerce-result-count { padding: 0 5vw !important; }
    .woocommerce .woocommerce-ordering { padding: 0 5vw 14px !important; }
    .woocommerce .woocommerce-ordering select.orderby { width: 100% !important; }
}
@media screen and (max-width: 560px) {
    .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; padding: 0 5vw 60px !important; }
}

/* =========================================================================
   13. SEARCH RESULTS  (/?s=...)
   ========================================================================= */
/* Un-hide the search heading + per-result titles — beats the §1 force-hide,
   scoped to .search so other pages keep page-title/entry-title hidden. */
.search .page-header,
.search .page-header .entry-title,
.search .page-content article .entry-title {
    display: block !important; opacity: 1 !important; visibility: visible !important;
    height: auto !important; pointer-events: auto !important;
}

.search .site-main {
    max-width: 1080px !important; margin: 0 auto !important;
    padding: 64px 5vw 110px !important; width: 100% !important; box-sizing: border-box !important;
}

/* --- Heading --- */
.search .page-header {
    padding: 0 0 22px 0 !important; margin: 0 0 16px 0 !important;
    border-bottom: 1px solid var(--taupe-40) !important;
}
.search .page-header .entry-title {
    font-family: var(--serif) !important; font-size: 42px !important; font-weight: 400 !important;
    line-height: 1.12 !important; color: var(--umber) !important; margin: 0 !important; padding: 0 !important;
}
.search .page-header .entry-title span { color: var(--tomato) !important; font-style: italic !important; }

/* --- Results list --- */
.search .page-content { display: block !important; }
.search-results .page-content article.post {
    display: grid !important;
    grid-template-columns: 104px 1fr !important;
    grid-template-areas: "img title" "img text" !important;
    grid-template-rows: auto auto !important;
    column-gap: 24px !important; row-gap: 6px !important;
    align-content: start !important;
    padding: 28px 0 !important; margin: 0 !important;
    border-bottom: 1px solid var(--taupe-40) !important;
}
.search-results .page-content article.post:last-child { border-bottom: none !important; }
/* Image-less results (pages without a thumbnail) collapse to one column */
.search-results .page-content article.post:not(:has(> a img)) {
    grid-template-columns: 1fr !important;
    grid-template-areas: "title" "text" !important;
}
.search-results .page-content article.post > a {
    grid-area: img !important; display: block !important; align-self: start !important;
}
.search-results .page-content article.post img {
    grid-area: img !important;
    width: 104px !important; height: 128px !important; object-fit: cover !important;
    border-radius: var(--radius) !important; display: block !important;
    margin: 0 !important; max-width: none !important;
}
.search-results .page-content article.post .entry-title {
    grid-area: title !important;
    font-family: var(--serif) !important; font-size: 25px !important; font-weight: 400 !important;
    line-height: 1.2 !important; margin: 0 !important; padding: 0 !important;
}
.search-results .page-content article.post .entry-title a {
    color: var(--umber) !important; text-decoration: none !important; transition: color 0.2s ease !important;
}
.search-results .page-content article.post .entry-title a:hover { color: var(--tomato) !important; }
.search-results .page-content article.post p {
    grid-area: text !important;
    font-family: var(--sans) !important; font-size: 14px !important; color: var(--warm-gray) !important;
    line-height: 1.65 !important; margin: 0 !important;
}

/* --- Pagination (if search spans multiple pages) --- */
.search .navigation .nav-links a,
.search .navigation .nav-links span {
    font-family: var(--mono) !important; font-size: 13px !important;
    border: 1px solid var(--taupe) !important; border-radius: var(--radius) !important;
    padding: 8px 13px !important; color: var(--umber) !important;
    text-decoration: none !important; margin: 0 4px !important; display: inline-block !important;
}
.search .navigation { margin-top: 36px !important; text-align: center !important; }
.search .navigation .nav-links span.current { background: var(--umber) !important; color: var(--cream) !important; }

/* --- No results --- */
.search-no-results .page-content {
    text-align: center !important;
    padding: 70px 0 90px !important;
    max-width: 480px !important; margin: 0 auto !important;
}
.search-no-results .page-content p {
    font-family: var(--serif) !important; font-size: 26px !important; font-weight: 400 !important;
    line-height: 1.4 !important; color: var(--warm-gray) !important; margin: 0 !important;
}

@media screen and (max-width: 600px) {
    .search .site-main { padding: 44px 5vw 80px !important; }
    .search .page-header .entry-title { font-size: 32px !important; }
    .search-results .page-content article.post {
        grid-template-columns: 84px 1fr !important; column-gap: 16px !important; padding: 22px 0 !important;
    }
    .search-results .page-content article.post img { width: 84px !important; height: 104px !important; }
    .search-results .page-content article.post .entry-title { font-size: 21px !important; }
    .search-no-results .page-content p { font-size: 22px !important; }
}
