/*
Theme Name:   Jutekraft Child
Theme URI:    https://jutekraft.com
Description:  Jutekraft Child Theme for Astra — Full brand design for eco jute bags eCommerce
Author:       JuteKraft / Vijaya Eco Industries
Author URI:   https://jutekraft.com
Template:     astra
Version:      14.1.1
License:      GNU General Public License v2 or later
Text Domain:  jutekraft-child
*/

/* ================================================
   IMPORT GOOGLE FONTS
================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Nunito+Sans:wght@300;400;600;700;800&family=Playfair+Display:ital,wght@0,700;1,500&display=swap');
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css');

/* ================================================
   SINGLE PRODUCT LAYOUT — isolated from shop grid rules
================================================ */
.jk-product-layout {
  display: grid !important;
  grid-template-columns: 500px minmax(0,1fr) !important;
  gap: 18px !important;
  align-items: start !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
/* Children use natural grid sizing — do NOT override with width:100% */
.jk-product-layout > .jk-product-gallery-col,
.jk-product-layout > .jk-product-summary-col {
  min-width: 0;
  box-sizing: border-box;
}
@media (max-width: 900px) {
  .jk-product-layout { grid-template-columns: 1fr !important; }
}

/* ================================================
   ROOT VARIABLES — JUTEKRAFT NATURAL PALETTE
================================================ */
:root {
  --jute:        #C8A96E;
  --jute-light:  #E2D0AA;
  --jute-dark:   #9E7D45;
  --jute-bg:     #F5EDD8;
  --jute-bg2:    #EDE0C4;
  --green:       #1A5C38;
  --green-mid:   #267347;
  --green-light: #3A9060;
  --green-pale:  #D4EAD8;
  --brown:       #6B3F1F;
  --brown-light: #9C6035;
  --sand:        #D9C49A;
  --dark:        #1E1A14;
  --mid:         #5A5040;
  --muted:       #8A7C68;
  --white:       #FDFAF4;
  --cream:       #FAF3E4;
  --col-natural:     #C8A96E;
  --col-offwhite:    #F0EBE0;
  --col-lemonyellow: #D4E000;
  --col-bottlegreen: #1A5C38;
  --col-parrotgreen: #4CAF1A;
  --col-csblue:      #00A3B4;
  --col-royalblue:   #2B3C9E;
  --col-orange:      #E35B04;
  --col-red:         #C0191B;
  --col-pink:        #E0487A;
  --col-purple:      #6B2F8E;
  --col-brown:       #7B4F2E;
  --radius:    8px;
  --radius-lg: 16px;
  --shadow:    0 4px 28px rgba(30,26,20,0.10);
  --shadow-lg: 0 12px 48px rgba(30,26,20,0.18);
  --jute-pattern: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8'%3E%3Crect width='8' height='8' fill='%23C8A96E' fill-opacity='0.08'/%3E%3Cline x1='0' y1='0' x2='8' y2='8' stroke='%23C8A96E' stroke-width='0.4' stroke-opacity='0.15'/%3E%3Cline x1='8' y1='0' x2='0' y2='8' stroke='%23C8A96E' stroke-width='0.4' stroke-opacity='0.1'/%3E%3C/svg%3E");
}

/* ================================================
   ASTRA OVERRIDES — REMOVE DEFAULT STYLES
================================================ */
.ast-container, .site-content .ast-container { max-width: 1300px; }
.ast-page-builder-template .hfeed, .ast-page-builder-template #page { background: var(--jute-bg); }
#page { background: var(--jute-bg); }
body { font-family: 'Nunito Sans', sans-serif; background: var(--jute-bg); color: var(--dark); }
body::before {
  content: ''; position: fixed; inset: 0;
  background: var(--jute-pattern); pointer-events: none; z-index: 0; opacity: 0.6;
}

/* Remove Astra default header/footer — we use custom */
#masthead, .site-header-primary-section { display: none !important; }
#colophon.site-footer { display: none !important; }
.ast-breadcrumbs-wrapper { display: none; }

/* ================================================
   GLOBAL RESETS
================================================ */
*, *::before, *::after { box-sizing: border-box; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
ul { list-style: none; margin: 0; padding: 0; }
button, input, select, textarea { font-family: inherit; }
button { cursor: pointer; }
.entry-content { max-width: 100%; }
.entry-content p, .entry-content ul, .entry-content ol { margin-bottom: 1rem; }

/* ================================================
   TYPOGRAPHY
================================================ */
.font-display { font-family: 'Cormorant Garamond', serif; }
.font-hero    { font-family: 'Playfair Display', serif; }
h1,h2,h3 { font-family: 'Cormorant Garamond', serif; font-weight: 700; color: var(--brown); }

/* ================================================
   UTILITIES
================================================ */
.container { max-width: 1300px; margin: 0 auto; padding: 0 28px; position: relative; z-index: 1; }
.text-center { text-align: center; }
.section { padding: 72px 0; position: relative; }
.section-alt { background: var(--jute-bg2); }
.section-green { background: var(--green); color: #fff; }
.section-dark  { background: var(--dark); color: #fff; }
.section-badge {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--green-pale); color: var(--green);
  border: 1.5px solid rgba(26,92,56,0.25);
  padding: 5px 16px; border-radius: 20px;
  font-size: 11.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.8px; margin-bottom: 14px;
}
.section-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 700; color: var(--brown); line-height: 1.15; margin-bottom: 12px;
}
.section-title em { color: var(--green); font-style: italic; }
.section-sub { color: var(--mid); font-size: 15px; max-width: 560px; margin: 0 auto; }
.divider {
  width: 64px; height: 3px;
  background: linear-gradient(90deg, var(--green), var(--jute));
  border-radius: 2px; margin: 16px auto;
}

/* ================================================
   BUTTONS
================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 12px 28px; border-radius: 6px;
  font-size: 14px; font-weight: 700; letter-spacing: .3px;
  border: 2px solid transparent;
  transition: all .26s cubic-bezier(.34,1.56,.64,1);
}
.btn-green { background: var(--green); color: #fff; border-color: var(--green); }
.btn-green:hover { background: var(--green-mid); transform: translateY(-3px); box-shadow: 0 8px 24px rgba(26,92,56,.35); }
.btn-outline-green { background: transparent; border-color: var(--green); color: var(--green); }
.btn-outline-green:hover { background: var(--green); color: #fff; transform: translateY(-3px); }
.btn-jute { background: var(--jute); color: var(--dark); border-color: var(--jute); }
.btn-jute:hover { background: var(--jute-dark); color: #fff; transform: translateY(-3px); }
.btn-white { background: #fff; color: var(--green); border-color: #fff; }
.btn-white:hover { background: var(--cream); transform: translateY(-3px); }
.btn-sm { padding: 8px 20px; font-size: 13px; }

/* ================================================
   ANNOUNCEMENT BAR
================================================ */
.announce-bar {
  background: var(--green); color: rgba(255,255,255,.9);
  font-size: 12.5px; font-weight: 600; letter-spacing: .3px;
  padding: 9px 0; overflow: hidden;
}
.announce-bar .inner {
  max-width: 1300px; margin: 0 auto; padding: 0 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.announce-track {
  overflow: hidden; flex: 1;
  -webkit-mask: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.announce-scroll {
  display: inline-flex; gap: 0;
  animation: scrollLeft 38s linear infinite; white-space: nowrap;
}
.announce-scroll span { padding: 0 40px; display: inline-flex; align-items: center; gap: 8px; }
.announce-scroll span::after { content: '·'; margin-left: 40px; opacity: .4; }
@keyframes scrollLeft { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.announce-links { display: flex; gap: 18px; flex-shrink: 0; }
.announce-links a { color: rgba(255,255,255,.8); font-size: 12px; transition: color .2s; }
.announce-links a:hover { color: #fff; }

/* ================================================
   HEADER
================================================ */
.site-header {
  background: var(--white); border-bottom: 2px solid var(--jute-light);
  position: sticky; top: 0; z-index: 900;
  box-shadow: 0 2px 16px rgba(30,26,20,.08); transition: box-shadow .3s;
}
.site-header.scrolled { box-shadow: 0 4px 28px rgba(30,26,20,.16); }
.header-inner {
  max-width: 1300px; margin: 0 auto; padding: 0 28px;
  display: flex; align-items: center; gap: 20px; height: 76px;
}
.logo { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.logo-mark {
  width: 48px; height: 48px; background: var(--green); border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.logo-mark::before { content: ''; position: absolute; inset: 0; background: var(--jute-pattern); opacity: .3; }
.logo-mark svg { position: relative; z-index: 1; }
.logo-text .brand { font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 700; color: var(--green); line-height: 1; letter-spacing: -.5px; }
.logo-text .brand span { color: var(--jute-dark); }
.logo-text .sub { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 2.5px; color: var(--muted); }
.header-search { flex: 1; max-width: 460px; position: relative; }
.header-search input { width: 100%; padding: 10px 44px 10px 18px; border: 1.5px solid var(--sand); border-radius: 28px; background: var(--cream); font-size: 13.5px; outline: none; transition: border .2s, box-shadow .2s; color: var(--dark); }
.header-search input:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(26,92,56,.12); }
.header-search input::placeholder { color: var(--muted); }
.header-search .search-btn { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--green); font-size: 15px; }
.header-actions { display: flex; align-items: center; gap: 2px; margin-left: auto; }
.hdr-action { background: none; border: none; padding: 8px 13px; border-radius: 8px; color: var(--mid); font-size: 12.5px; display: flex; flex-direction: column; align-items: center; gap: 3px; transition: background .2s, color .2s; position: relative; }
.hdr-action:hover { background: var(--jute-bg); color: var(--green); }
.hdr-action i { font-size: 20px; }
.hdr-action .label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; }
.cart-dot { position: absolute; top: 5px; right: 9px; background: var(--green); color: #fff; font-size: 9px; width: 17px; height: 17px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 800; border: 2px solid #fff; }
.whatsapp-btn { display: flex; align-items: center; gap: 7px; background: var(--green); color: #fff; border: none; padding: 9px 16px; border-radius: 24px; font-size: 13px; font-weight: 700; transition: all .25s; margin-left: 6px; }
.whatsapp-btn:hover { background: var(--green-mid); transform: translateY(-2px); box-shadow: 0 6px 18px rgba(26,92,56,.3); }

/* ================================================
   NAVIGATION
================================================ */
.site-nav { background: var(--brown); border-bottom: 3px solid var(--brown-light); position: relative; z-index: 800; }
.nav-inner { max-width: 1300px; margin: 0 auto; padding: 0 28px; display: flex; align-items: center; }
.nav-item { position: relative; }
.nav-link { display: flex; align-items: center; gap: 6px; padding: 14px 18px; color: rgba(255,255,255,.92); font-size: 12px; font-weight: 700; letter-spacing: .3px; transition: background .2s, color .2s; white-space: nowrap; text-transform: uppercase; }
.nav-link:hover { background: rgba(0,0,0,.18); color: #fff; }
.nav-link .arr { font-size: 9px; transition: transform .25s; opacity: .7; }
.nav-item:hover .arr { transform: rotate(180deg); }
.nav-link .icon { font-size: 14px; }
.nav-link.highlight { color: #FFD97D; }
.nav-link.highlight:hover { background: rgba(255,217,125,.12); }

/* MEGA MENU */
.mega-menu { display: none; position: absolute; top: 100%; left: 0; background: #fff; border: 1px solid var(--jute-light); border-top: 3px solid var(--green); border-radius: 0 0 12px 12px; box-shadow: var(--shadow-lg); min-width: 560px; padding: 28px; z-index: 999; }
.nav-item:hover .mega-menu { display: flex; gap: 28px; }
/* ── 4-column mega-menu ── */
.mega-menu { min-width: 700px; }
/* ── Simple dropdown (Celebration / Daily Use) ── */
.nav-item .dropdown { display:none; position:absolute; top:100%; left:0; background:#fff; border:1px solid var(--jute-light); border-top:3px solid var(--green); border-radius:0 0 12px 12px; box-shadow:var(--shadow-lg); min-width:200px; padding:10px 0; z-index:999; }
.nav-item:hover .dropdown { display:block; }
.nav-item .dropdown a { display:block; padding:8px 20px; font-size:13.5px; color:var(--mid); text-decoration:none; transition:background .15s,color .15s; }
.nav-item .dropdown a:hover { background:var(--cream); color:var(--green); }
.mega-col h4 { font-family: 'Cormorant Garamond', serif; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px; color: var(--brown); margin-bottom: 12px; border-bottom: 1px solid var(--sand); padding-bottom: 8px; }
.mega-col a { display: flex; align-items: center; gap: 8px; padding: 6px 0; font-size: 13.5px; color: var(--mid); transition: color .18s; }
.mega-col a:hover { color: var(--green); }
.mega-col a i { width: 18px; color: var(--jute-dark); }

/* ================================================
   FOOTER
================================================ */
.site-footer { background: var(--dark); color: rgba(255,255,255,.82); padding: 60px 0 0; position: relative; z-index: 1; }
.site-footer::before { content: ''; position: absolute; inset: 0; background: var(--jute-pattern); opacity: .04; pointer-events: none; }
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 48px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,.08); }
.footer-brand .fb-name { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 700; color: #fff; margin-bottom: 4px; }
.footer-brand .fb-name span { color: var(--jute); }
.footer-brand .fb-tag { font-size: 11px; text-transform: uppercase; letter-spacing: 2px; color: var(--muted); margin-bottom: 16px; }
.footer-brand p { font-size: 14px; line-height: 1.7; color: rgba(255,255,255,.6); margin-bottom: 20px; }
.social-row { display: flex; gap: 10px; }
.soc-btn { width: 38px; height: 38px; border-radius: 9px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center; font-size: 15px; color: rgba(255,255,255,.7); transition: all .22s; }
.soc-btn:hover { background: var(--green); border-color: var(--green); color: #fff; transform: translateY(-3px); }
.footer-col h4 { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; color: var(--jute); margin-bottom: 18px; }
.footer-col a { display: block; font-size: 13.5px; color: rgba(255,255,255,.6); margin-bottom: 9px; transition: color .18s; }
.footer-col a:hover { color: var(--jute-light); }
.footer-contact-item { display: flex; gap: 10px; font-size: 13px; color: rgba(255,255,255,.6); margin-bottom: 10px; }
.footer-contact-item i { color: var(--jute); margin-top: 2px; width: 16px; flex-shrink: 0; }
.payments-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.pay-badge { font-size: 10.5px; font-weight: 700; padding: 4px 10px; border: 1px solid rgba(200,169,110,.3); border-radius: 5px; color: var(--jute-light); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; font-size: 12px; color: rgba(255,255,255,.35); flex-wrap: wrap; gap: 12px; }
.footer-bottom .legal { display: flex; gap: 20px; }
.footer-bottom .legal a { color: rgba(255,255,255,.4); transition: color .18s; }
.footer-bottom .legal a:hover { color: var(--jute-light); }

/* ================================================
   FLOATING ELEMENTS
================================================ */
.wa-float { position: fixed; bottom: 28px; right: 28px; width: 56px; height: 56px; background: #25D366; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 26px; color: #fff; z-index: 9999; box-shadow: 0 4px 20px rgba(37,211,102,.5); transition: transform .25s; }
.wa-float:hover { transform: scale(1.1) rotate(-8deg); }
.back-top { position: fixed; bottom: 96px; right: 28px; width: 42px; height: 42px; background: var(--green); color: #fff; border: none; border-radius: 10px; font-size: 16px; display: none; align-items: center; justify-content: center; z-index: 9998; box-shadow: var(--shadow); transition: all .25s; }
.back-top.visible { display: flex; }
.back-top:hover { background: var(--green-mid); transform: translateY(-4px); }

/* ================================================
   WOOCOMMERCE OVERRIDES — SHOP / PRODUCT PAGES
================================================ */
.woocommerce-page { background: var(--jute-bg); }
.woocommerce ul.products li.product .button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button { background: var(--green); color: #fff; border-radius: 6px; font-family: 'Nunito Sans', sans-serif; font-weight: 700; font-size: 13px; padding: 9px 20px; border: none; transition: all .25s; }
.woocommerce ul.products li.product .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover { background: var(--green-mid); }
.woocommerce ul.products li.product { border: 1.5px solid var(--jute-light); border-radius: var(--radius-lg); background: var(--white); overflow: hidden; transition: all .28s; box-shadow: var(--shadow); }
.woocommerce ul.products li.product:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-family: 'Cormorant Garamond', serif; font-size: 17px; font-weight: 700; color: var(--brown); }
.woocommerce ul.products li.product .price { color: var(--green); font-weight: 700; font-size: 16px; }
.woocommerce div.product .product_title { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.6rem, 3vw, 2.4rem); color: var(--brown); }
.woocommerce div.product .price { color: var(--green); font-size: 1.6rem; font-weight: 800; }
.woocommerce .single_add_to_cart_button { background: var(--green) !important; font-family: 'Nunito Sans', sans-serif !important; font-weight: 700 !important; border-radius: 8px !important; padding: 14px 32px !important; font-size: 15px !important; transition: all .25s !important; }
.woocommerce .single_add_to_cart_button:hover { background: var(--green-mid) !important; transform: translateY(-2px) !important; }
.woocommerce-checkout #payment { background: var(--cream); border-radius: var(--radius); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea { border: 1.5px solid var(--sand); border-radius: 8px; padding: 10px 16px; font-size: 14px; background: var(--white); }
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(26,92,56,.1); outline: none; }
.woocommerce-cart-form .shop_table,
.woocommerce-checkout-review-order .shop_table { border: 1px solid var(--jute-light); border-radius: var(--radius); }
.woocommerce-breadcrumb { display: none; }
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info { background: var(--green-pale); border-top-color: var(--green); color: var(--dark); }
.woocommerce-page .woocommerce-result-count,
.woocommerce-page .woocommerce-ordering { font-size: 13px; color: var(--mid); }
.woocommerce-page .woocommerce-ordering select { border: 1.5px solid var(--sand); border-radius: 8px; padding: 7px 12px; background: var(--white); color: var(--dark); font-family: 'Nunito Sans', sans-serif; }

/* ================================================
   SCROLL REVEAL ANIMATIONS
================================================ */
.reveal, .reveal-left, .reveal-right { opacity: 0; transform: translateY(30px); transition: opacity .7s ease, transform .7s ease; }
.reveal-left { transform: translateX(-30px); }
.reveal-right { transform: translateX(30px); }
.reveal.visible, .reveal-left.visible, .reveal-right.visible { opacity: 1; transform: none; }
.delay-1 { transition-delay: .12s; }
.delay-2 { transition-delay: .24s; }
.delay-3 { transition-delay: .36s; }

/* ================================================
   RESPONSIVE
================================================ */
@media (max-width: 1024px) {
  .header-search { display: none; }
  .mega-menu { min-width: 100%; }
}
@media (max-width: 768px) {
  .footer-top { grid-template-columns: 1fr; gap: 28px; }
  .header-inner { height: 64px; }
  .nav-inner { overflow-x: auto; }
  .announce-links { display: none; }
  .hdr-action .label { display: none; }
}

/* ================================================
   WOOCOMMERCE ARCHIVE — FORCE CUSTOM CARD STYLES
   (Overrides WC default ul.products li.product)
================================================ */

/* Reset WC default list layout on our custom grid */
.woocommerce .products.custom-grid,
.woocommerce-page .products.custom-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Product card — override WC defaults completely */
.product-card {
  background: #fff !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  border: 1.5px solid var(--jute-light) !important;
  transition: all .3s cubic-bezier(.34,1.56,.64,1) !important;
  position: relative !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
  width: auto !important;
}
.product-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-color: transparent !important;
}
.product-card .product-img {
  height: 220px !important;
  background: var(--cream) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  overflow: hidden !important;
}
.product-card .product-img img {
  width: 100% !important;
  height: 220px !important;
  object-fit: cover !important;
  display: block !important;
}
.product-card .product-info {
  padding: 14px 16px 18px !important;
}
.product-card .product-cat {
  font-size: 10.5px !important;
  text-transform: uppercase !important;
  letter-spacing: 1.2px !important;
  color: var(--green) !important;
  font-weight: 800 !important;
  margin-bottom: 5px !important;
}
.product-card .product-name {
  font-weight: 700 !important;
  font-size: 14px !important;
  color: var(--dark) !important;
  margin-bottom: 5px !important;
  line-height: 1.35 !important;
}
.product-card .product-name a { color: var(--dark) !important; }
.product-card .product-name a:hover { color: var(--green) !important; }
.product-card .product-meta {
  font-size: 11.5px !important;
  color: var(--muted) !important;
  margin-bottom: 8px !important;
}
.product-card .product-price {
  display: flex !important;
  align-items: baseline !important;
  gap: 8px !important;
  margin-bottom: 13px !important;
}
.product-card .price {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--green) !important;
}
.product-card .add-cart {
  width: 100% !important;
  padding: 10px 0 !important;
  background: var(--green) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
  transition: all .25s !important;
  cursor: pointer !important;
  text-decoration: none !important;
  font-family: 'Nunito Sans', sans-serif !important;
}
.product-card .add-cart:hover {
  background: var(--green-mid) !important;
  transform: translateY(-1px) !important;
  color: #fff !important;
}

/* ── WISHLIST BUTTON — kill yellow oval completely ── */
.product-wish,
.product-card .product-wish,
.woocommerce .product-wish {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  z-index: 2 !important;
  width: 34px !important;
  height: 34px !important;
  min-width: unset !important;
  min-height: unset !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,0.9) !important;
  border: 1.5px solid var(--sand) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  color: var(--muted) !important;
  opacity: 0 !important;
  transform: translateX(6px) !important;
  transition: all .25s !important;
  box-shadow: var(--shadow) !important;
  padding: 0 !important;
  line-height: 1 !important;
  cursor: pointer !important;
}
.product-card:hover .product-wish {
  opacity: 1 !important;
  transform: translateX(0) !important;
}
.product-wish:hover {
  background: var(--green) !important;
  color: #fff !important;
  border-color: var(--green) !important;
}
.product-wish i {
  font-size: 14px !important;
  line-height: 1 !important;
  display: block !important;
}

/* ── WC ordering / result count ── */
.woocommerce-result-count {
  font-size: 13px !important;
  color: var(--muted) !important;
  margin: 0 !important;
}
.woocommerce-ordering select {
  border: 1.5px solid var(--sand) !important;
  border-radius: 8px !important;
  padding: 7px 32px 7px 12px !important;
  background: #fff !important;
  color: var(--dark) !important;
  font-family: 'Nunito Sans', sans-serif !important;
  font-size: 13px !important;
}

/* ── Pagination ── */
.woocommerce-pagination ul {
  display: flex !important;
  gap: 7px !important;
  justify-content: center !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 36px 0 0 !important;
}
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
  width: 40px !important;
  height: 40px !important;
  border-radius: 7px !important;
  border: 1.5px solid var(--jute-light) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  transition: all .2s !important;
  color: var(--dark) !important;
  background: #fff !important;
}
.woocommerce-pagination ul li a:hover,
.woocommerce-pagination ul li span.current {
  background: var(--green) !important;
  color: #fff !important;
  border-color: var(--green) !important;
}

/* ── Single product page WC fixes ── */
.woocommerce div.product form.cart .qty {
  border: 1.5px solid var(--sand) !important;
  border-radius: 8px !important;
  padding: 8px 12px !important;
  font-size: 15px !important;
  width: 70px !important;
}
.woocommerce div.product form.cart {
  display: flex !important;
  flex-direction: row !important;
  gap: 12px !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
}
/* WC wraps qty+button inside .woocommerce-variation-add-to-cart — make that flex too */
.woocommerce-variation-add-to-cart,
.woocommerce div.product form.cart .woocommerce-variation-add-to-cart {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: nowrap !important;
  width: 100% !important;
}

/* ── Kill any Astra yellow/orange button overrides ── */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt {
  background-color: var(--green) !important;
  color: #fff !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
  background-color: var(--green-mid) !important;
}

/* ================================================
   JK PRODUCT GRID — wraps WC ul.products
   Specificity battle: beat Astra's columns-N rules.
   Using body.woocommerce prefix for higher specificity.
================================================ */
body.woocommerce .jk-product-grid ul.products,
body.woocommerce-page .jk-product-grid ul.products,
.jk-product-grid ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
@media (min-width: 1400px) {
  body.woocommerce .jk-product-grid ul.products,
  body.woocommerce-page .jk-product-grid ul.products,
  .jk-product-grid ul.products {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 1200px) {
  body.woocommerce .jk-product-grid ul.products,
  body.woocommerce-page .jk-product-grid ul.products,
  .jk-product-grid ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 768px) {
  body.woocommerce .jk-product-grid ul.products,
  body.woocommerce-page .jk-product-grid ul.products,
  .jk-product-grid ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }
}
.jk-product-grid {
  width: 100% !important;
  box-sizing: border-box !important;
  display: block !important;
}
/* Force any WC-injected wrappers to be full width too */
.jk-product-grid > *,
.jk-product-grid .woocommerce-notices-wrapper ~ *,
.jk-product-grid .products.columns-4 {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}
.jk-product-grid ul.products::before,
.jk-product-grid ul.products::after { display: none !important; }
.jk-product-grid ul.products li.product {
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  max-width: 100% !important;
  float: none !important;
  clear: none !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
}
/* product-card fills the li */
.jk-product-grid ul.products li.product .product-card {
  flex: 1;
  margin: 0;
  height: 100%;
}

/* ── Kill the yellow Astra/WC wishlist button completely ── */
.product-card button.jk-wish,
button.jk-wish,
.jk-wish {
  all: unset !important;
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  z-index: 10 !important;
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,0.92) !important;
  border: 1.5px solid var(--sand) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  opacity: 0 !important;
  transform: translateX(8px) !important;
  transition: opacity .25s, transform .25s, background .2s !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.1) !important;
  color: var(--muted) !important;
  font-size: 14px !important;
  line-height: 1 !important;
}
.product-card:hover .jk-wish {
  opacity: 1 !important;
  transform: translateX(0) !important;
}
.jk-wish:hover {
  background: var(--green) !important;
  color: #fff !important;
  border-color: var(--green) !important;
}
/* Nuke any WC/Astra wishlist overrides */
.woocommerce ul.products li.product .button.add_to_wishlist,
.woocommerce a.add_to_wishlist,
.tinvwl_add_to_wishlist_button,
.ast-woocommerce-wishlist-btn {
  display: none !important;
}

/* ================================================
   NUCLEAR FIXES — V4.1
   Kill Astra wishlist yellow button completely
   Fix product card white box styling
================================================ */

/* 1. Kill Astra wishlist button — all possible selectors */
.ast-woocommerce-wishlist-btn,
.ast-woocommerce-wishlist-btn *,
.ast-wishlist-btn,
li.product .ast-woocommerce-wishlist-btn,
.woocommerce li.product .ast-woocommerce-wishlist-btn,
.product-card .ast-woocommerce-wishlist-btn {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* 2. Kill any yellow/orange WC buttons that aren't our Add to Cart */
.woocommerce li.product a.button:not(.add-cart),
.woocommerce li.product button.button:not(.add-cart):not(.jk-wish) {
  display: none !important;
}

/* 3. Force our product-card white box on WC li.product */
.woocommerce ul.products li.product.product-card,
.jk-product-grid ul.products li.product.product-card {
  background: #fff !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  border: 1.5px solid #E2D0AA !important;
  box-shadow: 0 4px 28px rgba(30,26,20,0.10) !important;
  padding: 0 !important;
  margin: 0 !important;
  transition: all .3s !important;
}
.woocommerce ul.products li.product.product-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 12px 48px rgba(30,26,20,0.18) !important;
  border-color: transparent !important;
}

/* 4. Style the Add to Cart link from WC */
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product .add-cart {
  background: #1A5C38 !important;
  color: #fff !important;
  border-radius: 6px !important;
  padding: 10px 16px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  font-family: 'Nunito Sans', sans-serif !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: 10px !important;
  transition: background .25s !important;
  text-decoration: none !important;
  border: none !important;
}
.woocommerce ul.products li.product a.add_to_cart_button:hover,
.woocommerce ul.products li.product .add-cart:hover {
  background: #267347 !important;
  color: #fff !important;
}

/* 5. Product price colour */
.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product .price .amount {
  color: #1A5C38 !important;
  font-size: 18px !important;
  font-weight: 800 !important;
}

/* 6. Product title font */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #1E1A14 !important;
  padding: 0 !important;
  margin-bottom: 6px !important;
}

/* ================================================
   FINAL NUCLEAR — Astra wishlist yellow button
================================================ */
body .ast-woocommerce-wishlist-btn,
body .ast-woocommerce-wishlist-btn *,
html body .ast-woocommerce-wishlist-btn,
.woocommerce body .ast-woocommerce-wishlist-btn,
li.product .ast-woocommerce-wishlist-btn,
.product .ast-woocommerce-wishlist-btn,
[class*="ast-"][class*="wishlist"],
button[class*="wishlist"]:not(.jk-wish),
a[class*="wishlist"]:not(.jk-wish) {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  position: absolute !important;
  pointer-events: none !important;
  opacity: 0 !important;
  clip: rect(0,0,0,0) !important;
}

/* ================================================
   SINGLE PRODUCT PAGE — Force full width layout
   Break out of Astra's narrow content container
================================================ */

/* Full width on single product and shop pages */
body.jk-product #content,
body.jk-product .site-content,
body.jk-product #primary,
body.jk-product .content-area,
body.jk-product .ast-container,
body.jk-shop #content,
body.jk-shop .site-content,
body.jk-shop #primary,
body.jk-shop .content-area {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  float: none !important;
}

/* Remove Astra's default article/entry padding on WC pages */
body.jk-product .entry-content,
body.jk-product article,
body.jk-product .ast-article-single,
body.jk-product .woocommerce,
body.jk-shop .woocommerce {
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Hide Astra's sidebar on WC pages */
body.jk-product #secondary,
body.jk-product .widget-area,
body.jk-shop #secondary {
  display: none !important;
}

/* Remove any Astra page hero/banner on product pages */
body.jk-product .ast-breadcrumbs-wrapper,
body.jk-product .ast-above-header-wrap,
body.jk-product .page-header,
body.jk-product .entry-header {
  display: none !important;
}

/* Force our single product container to be full viewport width */
body.jk-product .woocommerce-page,
body.jk-product > div,
.single-product #page {
  background: var(--jute-bg) !important;
}

/* ── Astra content layout full-width override ── */
.ast-page-builder-template .hfeed,
body.jk-product .ast-article-single,
body.jk-product #content .ast-container {
  padding: 0 !important;
  max-width: 100% !important;
}

/* ================================================
   FIX: Grey sides on single product page
   Make body background match our cream theme
================================================ */
body.single-product,
body.jk-product {
  background: #F0E8D0 !important;
}

/* Remove the white box / border Astra adds around content */
body.single-product #page,
body.single-product #content,
body.single-product .site-content,
body.single-product #primary,
body.single-product .content-area,
body.single-product .ast-article-single {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin: 0 !important;
}

/* Make the WC single product area full width */
body.single-product .woocommerce,
body.single-product .woocommerce-page {
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Fix Astra sticky header on product page */
body.single-product .ast-header-sticky-shrunk,
body.single-product #ast-fixed-header {
  width: 100% !important;
}

/* Announcement bar + header full width on product page */
body.single-product .announce-bar,
body.single-product .site-header,
body.single-product .site-nav {
  position: relative !important;
  z-index: 100 !important;
}

/* =========================================================
   ADDITIONAL CSS v7 — Baked into theme (moved from WP Customizer)
   ========================================================= */

/* ---------- Global page background ---------- */
html, body,
body.single-product, body.woocommerce, body.woocommerce-page,
.site, #page, #wrap, .hfeed,
.ast-separate-container, .ast-plain-container {
  background: #F0E8D0 !important;
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  box-shadow: none !important;
}

/* ---------- Main Astra / WooCommerce containers ---------- */
.ast-container, .ast-container > .ast-flex,
#ast-content-id, .site-content, .content-area,
.ast-article-single, .woocommerce, .woocommerce-page {
  max-width: 100% !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-shadow: none !important;
  background: transparent !important;
}
.ast-container {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

/* ---------- Single product — remove boxed look ---------- */
.single-product .site-main,
.single-product .ast-container,
.single-product #primary,
.single-product #content,
.single-product .content-area,
.single-product .woocommerce-notices-wrapper,
.single-product div.product {
  max-width: 1400px !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* ---------- Product gallery ---------- */
.single-product div.product .woocommerce-product-gallery,
.single-product div.product .summary { width: 100% !important; }
.single-product div.product .woocommerce-product-gallery img {
  width: 100% !important; height: auto !important;
  max-width: 100% !important; object-fit: cover !important;
  object-position: center !important; border-radius: 0 !important;
}

/* ---------- Shop card images 1:1 ---------- */
.product-card .product-img img,
.woocommerce ul.products li.product img,
.woocommerce-page ul.products li.product img {
  width: 100% !important; height: 220px !important;
  object-fit: cover !important; object-position: center !important;
  aspect-ratio: 1/1 !important; display: block !important;
}
.woocommerce ul.products li.product a img { margin: 0 auto !important; }

/* ---------- Announcement bar — ALL pages ---------- */
.announce-bar {
  position: relative !important; z-index: 9999 !important;
  background: #1A5C38 !important; color: #fff !important;
  display: block !important; width: 100% !important;
}
.announce-bar * { color: #fff !important; }
body.home .announce-bar, body.jk-home .announce-bar {
  display: block !important; visibility: visible !important; opacity: 1 !important;
}
body.home .hero-section, body.jk-home .hero-section { margin-top: 0 !important; }

/* ---------- Remove sidebar on WC pages ---------- */
.ast-separate-container #primary,
.ast-separate-container.ast-right-sidebar #primary,
.ast-separate-container.ast-left-sidebar #primary,
.ast-separate-container #secondary { background: transparent !important; }
body.single-product #secondary,
body.woocommerce-page #secondary,
body.woocommerce #secondary { display: none !important; }
body.single-product #primary,
body.woocommerce-page #primary,
body.woocommerce #primary {
  width: 100% !important; max-width: 100% !important; flex: 0 0 100% !important;
}

/* ---------- Mobile ---------- */
@media (max-width: 921px) {
  .ast-container { padding-left: 15px !important; padding-right: 15px !important; }
  .product-card .product-img img,
  .woocommerce ul.products li.product img,
  .woocommerce-page ul.products li.product img { height: 200px !important; }
  .single-product .site-main, .single-product .ast-container,
  .single-product #primary, .single-product #content,
  .single-product .content-area, .single-product div.product { max-width: 100% !important; }
}
@media (max-width: 544px) {
  .product-card .product-img img,
  .woocommerce ul.products li.product img,
  .woocommerce-page ul.products li.product img { height: 180px !important; }
  .ast-container { padding-left: 12px !important; padding-right: 12px !important; }
  .single-product form.cart { flex-wrap: wrap !important; }
  .single-product form.cart .qty,
  .single-product form.cart .single_add_to_cart_button {
    width: 100% !important; flex: none !important;
  }
}

/* ── FINAL OVERRIDE: Announce bar always green — must be last ── */
.announce-bar {
  background: #1A5C38 !important;
  background-color: #1A5C38 !important;
}
.announce-bar *,
.announce-bar span,
.announce-bar a,
.announce-bar i { color: #fff !important; }

/* ================================================
   BAKED FROM ADDITIONAL CSS — Final overrides
================================================ */

/* Fix announce bar partial green on product page */
.announce-bar,
.announce-bar .inner,
.announce-bar > div,
.announce-bar > .inner,
.single-product .announce-bar,
.single-product .announce-bar .inner,
.single-product .announce-bar > div {
  background: #1A5C38 !important;
  background-color: #1A5C38 !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Target ast-page-builder-template which Astra applies to product page */
body.ast-page-builder-template #content,
body.ast-page-builder-template .site-content,
body.ast-page-builder-template #primary,
body.ast-page-builder-template .ast-container {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}

/* EXACT FIX — ast-page-builder-template 840px width override */
.ast-page-builder-template {
  width: 100% !important;
  max-width: 100% !important;
}


/* =========================================================
   JK single product full-width layout fix (v6.4)
   ========================================================= */
.jk-product-breadcrumb-inner,
.jk-single-product-shell {
  width: 100%;
  max-width: none;
  margin: 0;
  padding-left: clamp(16px, 2vw, 32px);
  padding-right: clamp(16px, 2vw, 32px);
  box-sizing: border-box;
}

.jk-product-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 0.85fr);
  gap: 40px;
  align-items: start;
}

.jk-product-gallery-col,
.jk-product-summary-col {
  min-width: 0;
}

.single-product .jk-single-product-page,
.single-product .jk-single-product-shell,
.single-product .jk-product-grid {
  width: 100%;
  max-width: none;
}

@media (max-width: 1024px) {
  .jk-product-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .jk-product-summary-col {
    position: static !important;
    top: auto !important;
  }
}

@media (max-width: 544px) {
  .jk-product-breadcrumb-inner,
  .jk-single-product-shell {
    padding-left: 12px;
    padding-right: 12px;
  }
}

/* ── Remove top gap on all pages — Astra sometimes adds padding-top to html/body ── */
html { margin-top: 0 !important; }
body.single-product { margin-top: 0 !important; padding-top: 0 !important; }
body.single-product #page { margin-top: 0 !important; padding-top: 0 !important; }

/* WordPress admin bar compensation — only when logged in */
body.admin-bar .announce-bar { margin-top: 0 !important; }


/* ================================================
   SINGLE PRODUCT FIXES — v8
================================================ */
.jk-product-gallery-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #fff;
}

.jk-product-gallery-frame img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}

.jk-product-thumb-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #fff;
}

.jk-product-thumb-frame img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}

.jk-variation-cart table.variations,
.jk-variation-cart .variations {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
  display: block !important;
}

.jk-cswatch.is-active {
  border: 3px solid #1E1A14 !important;
  transform: scale(1.12);
}

#jkSizeBtns button.is-active {
  background: var(--green) !important;
  color: #fff !important;
  border: 1.5px solid var(--green) !important;
}

@media (max-width: 920px) {
  .jk-product-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }

  .jk-product-summary-col {
    position: static !important;
    top: auto !important;
  }
}


/* ================================================
   SINGLE PRODUCT FIXES — v8.1
================================================ */
.jk-product-gallery-col {
  width: 100%;
  max-width: 760px;
}

.jk-product-gallery-col > div:first-child {
  max-width: 720px;
  margin: 0 auto;
}

.jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] {
  max-width: 720px;
  margin: 12px auto 0;
}

.jk-product-gallery-frame {
  max-height: 720px;
}

@media (max-width: 1200px) {
  .jk-product-gallery-col,
  .jk-product-gallery-col > div:first-child,
  .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] {
    max-width: 640px;
  }
}

@media (max-width: 920px) {
  .jk-product-gallery-col,
  .jk-product-gallery-col > div:first-child,
  .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] {
    max-width: 100%;
  }
}

.jk-cswatch,
#jkSizeBtns button {
  user-select: none;
}

.jk-cswatch:hover {
  transform: scale(1.06);
}


/* SINGLE PRODUCT FIXES — v8.2 */
.jk-product-gallery-col { max-width: 620px !important; }
.jk-product-gallery-col > div:first-child { max-width: 560px !important; margin: 0 auto !important; }
.jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] { max-width: 560px !important; margin: 12px auto 0 !important; }
.jk-product-gallery-frame { max-height: 560px !important; }
.jk-cswatch, #jkSizeBtns button { user-select:none; -webkit-user-select:none; }
@media (max-width: 1200px) {
  .jk-product-gallery-col, .jk-product-gallery-col > div:first-child, .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] { max-width: 520px !important; }
  .jk-product-gallery-frame { max-height: 520px !important; }
}
@media (max-width: 920px) {
  .jk-product-gallery-col, .jk-product-gallery-col > div:first-child, .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] { max-width: 100% !important; }
  .jk-product-gallery-frame { max-height: none !important; }
}


/* SINGLE PRODUCT FIXES — v8.3 */
.jk-product-grid {
  grid-template-columns: minmax(0,560px) minmax(0,1fr) !important;
  gap: 22px !important;
  justify-content: start !important;
}
.jk-product-gallery-col {
  max-width: 560px !important;
  width: 100% !important;
}
.jk-product-gallery-col > div:first-child,
.jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] {
  max-width: 520px !important;
  margin: 0 !important;
}
.jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] { margin-top: 12px !important; }
.jk-product-gallery-frame { max-height: 520px !important; }
.jk-product-summary-col { min-width: 0 !important; }

#jkColourSwatches, #jkSizeBtns { position: relative; z-index: 5; }
.jk-cswatch, .jk-size-chip, #jkSizeBtns button {
  position: relative;
  z-index: 5;
  pointer-events: auto !important;
  cursor: pointer !important;
}
.jk-size-chip {
  user-select: none;
  -webkit-user-select: none;
}
.jk-size-chip:hover,
#jkSizeBtns button:hover {
  border-color: var(--green) !important;
  color: var(--green) !important;
  transform: translateY(-1px);
}
.jk-size-chip.is-active,
#jkSizeBtns button.is-active {
  background: var(--green) !important;
  color: #fff !important;
  border: 1.5px solid var(--green) !important;
}
@media (max-width: 1280px) {
  .jk-product-grid { grid-template-columns: minmax(0,500px) minmax(0,1fr) !important; gap: 18px !important; }
  .jk-product-gallery-col, .jk-product-gallery-col > div:first-child, .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] { max-width: 480px !important; }
  .jk-product-gallery-frame { max-height: 480px !important; }
}
@media (max-width: 920px) {
  .jk-product-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .jk-product-gallery-col, .jk-product-gallery-col > div:first-child, .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] { max-width: 100% !important; }
  .jk-product-gallery-frame { max-height: none !important; }
}

/* SINGLE PRODUCT FIXES — v8.4 */
body.single-product .jk-single-product-shell,
body.jk-product .jk-single-product-shell {
  max-width: 1220px !important;
  margin: 0 auto !important;
}

body.single-product .jk-product-grid,
body.jk-product .jk-product-grid {
  grid-template-columns: 500px minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: start !important;
}

body.single-product .jk-product-gallery-col,
body.jk-product .jk-product-gallery-col {
  width: 500px !important;
  max-width: 500px !important;
}

body.single-product .jk-product-gallery-col > div:first-child,
body.single-product .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"],
body.jk-product .jk-product-gallery-col > div:first-child,
body.jk-product .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] {
  width: 500px !important;
  max-width: 500px !important;
  margin: 0 !important;
}

body.single-product .jk-product-gallery-frame,
body.jk-product .jk-product-gallery-frame {
  width: 500px !important;
  height: 500px !important;
  max-height: 500px !important;
  aspect-ratio: 1 / 1 !important;
}

body.single-product .jk-product-summary-col,
body.jk-product .jk-product-summary-col {
  min-width: 0 !important;
  max-width: 760px !important;
}

body.single-product .jk-cswatch,
body.jk-product .jk-cswatch {
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease !important;
}

body.single-product .jk-cswatch:hover,
body.jk-product .jk-cswatch:hover {
  transform: scale(1.06) !important;
  box-shadow: 0 0 0 2px rgba(26,92,56,.18) !important;
}

body.single-product .jk-size-chip:hover,
body.single-product #jkSizeBtns button:hover,
body.jk-product .jk-size-chip:hover,
body.jk-product #jkSizeBtns button:hover {
  border-color: var(--green) !important;
  color: var(--green) !important;
  transform: translateY(-1px) !important;
}

body.single-product .jk-cswatch.is-active,
body.jk-product .jk-cswatch.is-active {
  border: 3px solid #1E1A14 !important;
  box-shadow: 0 0 0 2px rgba(26,92,56,.12) !important;
}

body.single-product .jk-size-chip.is-active,
body.single-product #jkSizeBtns button.is-active,
body.jk-product .jk-size-chip.is-active,
body.jk-product #jkSizeBtns button.is-active {
  background: var(--green) !important;
  color: #fff !important;
  border-color: var(--green) !important;
}

@media (max-width: 1280px) {
  body.single-product .jk-product-grid,
  body.jk-product .jk-product-grid { grid-template-columns: 460px minmax(0,1fr) !important; gap: 16px !important; }
  body.single-product .jk-product-gallery-col,
  body.single-product .jk-product-gallery-col > div:first-child,
  body.single-product .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"],
  body.jk-product .jk-product-gallery-col,
  body.jk-product .jk-product-gallery-col > div:first-child,
  body.jk-product .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] { width: 460px !important; max-width: 460px !important; }
  body.single-product .jk-product-gallery-frame,
  body.jk-product .jk-product-gallery-frame { width: 460px !important; height: 460px !important; max-height: 460px !important; }
}

@media (max-width: 920px) {
  body.single-product .jk-product-grid,
  body.jk-product .jk-product-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  body.single-product .jk-product-gallery-col,
  body.single-product .jk-product-gallery-col > div:first-child,
  body.single-product .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"],
  body.jk-product .jk-product-gallery-col,
  body.jk-product .jk-product-gallery-col > div:first-child,
  body.jk-product .jk-product-gallery-col > div[style*="grid-template-columns:repeat(4,1fr)"] { width: 100% !important; max-width: 100% !important; }
  body.single-product .jk-product-gallery-frame,
  body.jk-product .jk-product-gallery-frame { width: 100% !important; height: auto !important; max-height: none !important; }
}

