:root{--c-bg:#FAFAF7;--c-white:#FFFFFF;--c-dark:#1A1A1A;--c-text:#3D3D3D;--c-muted:#6B7280;--c-accent:#5B7C3F;--c-accent-h:#4A6833;--c-accent-lt:#EEF4E8;--c-cream:#F5F0E8;--c-border:#E5E7EB;--c-gold:#F59E0B;--font:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--max-w:1280px;--r-md:0.625rem;--r-lg:1rem;--r-xl:1.5rem;--r-full:9999px;--sh-md:0 4px 16px rgba(0,0,0,.08);--sh-lg:0 8px 32px rgba(0,0,0,.10);--sh-xl:0 20px 60px rgba(0,0,0,.12);--t:0.25s ease}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--c-bg);color:var(--c-text);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--t)}
ul{list-style:none}
button{cursor:pointer;font-family:var(--font);border:none;background:none}
input,textarea,select{font-family:var(--font)}
.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}
.quintec-section{padding:5rem 0}
h1,h2,h3,h4,h5,h6{font-family:var(--font);font-weight:700;line-height:1.2;color:var(--c-dark)}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
.section-label{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--c-accent);background:var(--c-accent-lt);padding:.4rem 1.1rem;border-radius:var(--r-full);margin-bottom:1rem}
.section-title{font-weight:800;color:var(--c-dark);margin-bottom:.875rem;letter-spacing:-.01em}
.section-subtitle{font-size:1.1rem;color:var(--c-muted);max-width:560px;line-height:1.7}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-header .section-subtitle{margin:0 auto}
.section-cta{text-align:center;margin-top:3rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;border-radius:var(--r-full);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--t);border:2px solid transparent;white-space:nowrap;text-decoration:none;font-family:var(--font)}
.btn-primary{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}
.btn-primary:hover{background:var(--c-accent-h);border-color:var(--c-accent-h);transform:translateY(-2px);box-shadow:0 8px 24px rgba(91,124,63,.3);color:#fff}
.btn-outline{background:transparent;color:var(--c-accent);border-color:var(--c-accent)}
.btn-outline:hover{background:var(--c-accent);color:#fff;transform:translateY(-2px)}
.btn-lg{padding:1.125rem 2.75rem;font-size:1.1rem}
.btn-sm{padding:.625rem 1.5rem;font-size:.875rem}
.announcement-bar{background:var(--c-accent);color:#fff;text-align:center;padding:.7rem 1rem;font-size:.85rem;font-weight:500}
.announcement-bar a{color:#fff;text-decoration:underline}
.site-header{background:linear-gradient(135deg,#14321e 0%,#0d2015 100%);border-bottom:1px solid rgba(201,164,86,.2);position:sticky;top:0;z-index:500;transition:box-shadow var(--t);box-shadow:0 2px 20px rgba(0,0,0,.3)}
.nav-container{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;max-width:var(--max-w);margin:0 auto;gap:1.5rem}
.site-logo{font-size:1.6rem;font-weight:800;color:#d4b56a;letter-spacing:-.03em;flex-shrink:0;display:flex;align-items:center}
.site-logo span{color:#c9a456}.site-logo img,.custom-logo,.custom-logo img{max-height:65px;width:auto;display:block;background:transparent}
.main-nav{display:flex;align-items:center}
.main-nav li{list-style:none}
.main-nav li a,.main-nav a{display:block;font-size:.9rem;font-weight:500;color:#d4b56a;padding:.5rem 1rem;border-radius:var(--r-md);transition:all var(--t);letter-spacing:.04em}
.main-nav li a:hover,.main-nav a:hover{color:#f5d98a;background:rgba(201,164,86,.1)}

/* ===== DROPDOWN / SUB-MENU ===== */
.main-nav .menu-item-has-children{position:relative}
/* Invisible bridge fills the gap so cursor never leaves the parent while moving to dropdown */
.main-nav .menu-item-has-children::after{content:'';position:absolute;left:0;top:100%;width:100%;height:10px;z-index:499}
.main-nav .sub-menu{
  display:block;
  visibility:hidden;
  opacity:0;
  pointer-events:none;
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  transform:translateY(6px);
  min-width:180px;
  background:linear-gradient(160deg,#1a3d23 0%,#0d2015 100%);
  border:1px solid rgba(201,164,86,.3);
  border-radius:0.75rem;
  box-shadow:0 12px 36px rgba(0,0,0,.4),0 0 0 1px rgba(201,164,86,.08);
  padding:0.4rem 0;
  z-index:600;
  transition:opacity .2s ease,transform .2s ease,visibility .2s ease;
  list-style:none;
}
/* Invisible top extension covers the gap bridge area */
.main-nav .sub-menu::before{
  content:'';
  position:absolute;
  top:-10px;
  left:0;
  width:100%;
  height:10px;
}
.main-nav .menu-item-has-children:hover>.sub-menu,
.main-nav .menu-item-has-children:focus-within>.sub-menu{
  visibility:visible;
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.main-nav .sub-menu li{padding:0;list-style:none}
.main-nav .sub-menu li a{
  display:block;
  padding:0.65rem 1.2rem;
  font-size:.875rem;
  font-weight:500;
  color:#d4b56a;
  border-radius:0;
  letter-spacing:.03em;
  transition:color .18s ease,background .18s ease,padding-left .18s ease;
  white-space:nowrap;
}
.main-nav .sub-menu li a:hover{
  color:#f5d98a;
  background:rgba(201,164,86,.12);
  padding-left:1.5rem;
}
.main-nav .sub-menu li:first-child a{border-radius:.625rem .625rem 0 0}
.main-nav .sub-menu li:last-child a{border-radius:0 0 .625rem .625rem}
.main-nav .sub-menu li+li{border-top:1px solid rgba(201,164,86,.1)}
/* Dropdown arrow on parent items */
.main-nav .menu-item-has-children>a::after{
  content:'';
  display:inline-block;
  width:0;height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:4px solid #d4b56a;
  margin-left:6px;
  vertical-align:middle;
  transition:transform .2s ease;
}
.main-nav .menu-item-has-children:hover>a::after{transform:rotate(180deg)}

.header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.header-icon-btn{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#d4b56a;transition:all var(--t)}
.header-icon-btn:hover{background:rgba(201,164,86,.15);color:#f5d98a}
.cart-icon-btn{position:relative;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#d4b56a;transition:all var(--t)}
.cart-icon-btn:hover{background:rgba(201,164,86,.15);color:#f5d98a}
.cart-count-badge{position:absolute;top:-2px;right:-2px;background:var(--c-accent);color:#fff;font-size:.65rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff}
/* ── Search Overlay ── */
.search-toggle-btn{background:none;border:none;cursor:pointer;padding:0}
.search-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(10,25,14,.92);z-index:9999;display:flex;align-items:flex-start;justify-content:center;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;backdrop-filter:blur(6px)}
.search-overlay.is-open{opacity:1;visibility:visible}
.search-overlay-inner{width:100%;max-width:700px;padding:80px 24px 0}
.search-overlay-form{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.06);border:1.5px solid rgba(212,181,106,.35);border-radius:50px;padding:10px 16px 10px 20px;transition:border-color .2s}
.search-overlay-form:focus-within{border-color:#d4b56a;background:rgba(255,255,255,.09)}
.search-overlay-icon{color:#d4b56a;flex-shrink:0}
.search-overlay-input{flex:1;background:none;border:none;outline:none;color:#fff;font-size:1.1rem;font-family:inherit;caret-color:#d4b56a}
.search-overlay-input::placeholder{color:rgba(255,255,255,.4);font-size:1rem}
.search-overlay-close{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;flex-shrink:0;transition:color .2s,background .2s}
.search-overlay-close:hover{color:#fff;background:rgba(255,255,255,.1)}
.search-suggestions{margin-top:16px;background:rgba(20,50,30,.95);border:1px solid rgba(212,181,106,.2);border-radius:12px;overflow:hidden;display:none}
.search-suggestions.has-results{display:block}
.search-suggestion-item{display:flex;align-items:center;gap:12px;padding:10px 16px;color:#e8e8e8;text-decoration:none;font-size:.9rem;transition:background .15s}
.search-suggestion-item:hover{background:rgba(212,181,106,.12);color:#d4b56a}
.search-suggestion-item img{width:40px;height:40px;object-fit:cover;border-radius:6px;flex-shrink:0}
.search-suggestion-item .sug-title{font-weight:500}
.search-suggestion-item .sug-price{font-size:.8rem;color:#d4b56a;margin-left:auto}
.search-no-results{padding:14px 16px;color:rgba(255,255,255,.5);font-size:.9rem}
.search-view-all{display:block;text-align:center;padding:10px;color:#d4b56a;font-size:.85rem;font-weight:600;border-top:1px solid rgba(212,181,106,.15);text-decoration:none;transition:background .15s}
.search-view-all:hover{background:rgba(212,181,106,.1)}
.mobile-menu-btn{display:none;flex-direction:column;gap:5px;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--r-md)}
.mobile-menu-btn span{display:block;width:22px;height:2px;background:#d4b56a;border-radius:2px;transition:all var(--t)}
.mobile-menu-btn.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-menu-btn.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.mobile-menu-btn.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;border-top:1px solid rgba(201,164,86,.2);background:#0d2015}
.mobile-nav-inner{padding:.5rem .75rem}

/* Top-level list */
.mobile-nav-inner ul{list-style:none;margin:0;padding:0}

/* Each top-level <li> — no padding, just a bottom divider */
.mobile-nav-inner > ul > li{border-bottom:1px solid rgba(201,164,86,.08)}
.mobile-nav-inner > ul > li:last-child{border-bottom:none}

/* Top-level links only */
.mobile-nav-inner > ul > li > a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:.65rem .75rem;
  border-radius:var(--r-md);
  color:#d4b56a;
  font-weight:600;
  font-size:.95rem;
  transition:background .18s,color .18s;
}
.mobile-nav-inner > ul > li > a:hover,
.mobile-nav-inner > ul > li > a:focus{background:rgba(201,164,86,.1);color:#f5d98a}

/* Sub-menu (dropdown) on mobile — shown as accordion */
.mobile-nav-inner .sub-menu{
  list-style:none;
  margin:0;
  padding:0 0 .35rem .75rem;
  display:none;
}
.mobile-nav-inner .sub-menu.open{display:block}

/* Sub-menu links */
.mobile-nav-inner .sub-menu li a{
  display:block;
  padding:.5rem .75rem;
  border-radius:var(--r-md);
  color:rgba(212,181,106,.8);
  font-size:.875rem;
  font-weight:500;
  transition:background .18s,color .18s;
}
.mobile-nav-inner .sub-menu li a:hover{background:rgba(201,164,86,.08);color:#f5d98a}

/* Arrow toggle for parent items on mobile */
.mobile-nav-inner .menu-item-has-children > a .mob-arrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px;height:24px;
  border-radius:50%;
  background:rgba(201,164,86,.12);
  flex-shrink:0;
  transition:transform .22s ease;
}
.mobile-nav-inner .menu-item-has-children > a .mob-arrow svg{
  display:block;
  transition:transform .22s ease;
}
.mobile-nav-inner .menu-item-has-children.mob-open > a .mob-arrow{
  background:rgba(201,164,86,.22);
  transform:rotate(180deg);
}

.mobile-nav.open{display:block}
.cart-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:800;opacity:0;pointer-events:none;transition:opacity .3s ease}
.cart-drawer-overlay.active{opacity:1;pointer-events:all}
.cart-drawer{position:fixed;right:-500px;top:0;width:460px;max-width:100vw;height:100vh;background:#fff;z-index:900;transition:right .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:var(--sh-xl)}
.cart-drawer.active{right:0}
.cart-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--c-border);flex-shrink:0}
.cart-drawer-title{font-size:1.125rem;font-weight:700;color:var(--c-dark)}
.cart-drawer-close{width:34px;height:34px;border-radius:50%;background:var(--c-bg);border:1px solid var(--c-border);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--c-text);transition:all var(--t);line-height:1;cursor:pointer}
.cart-drawer-close:hover{background:var(--c-border)}
.cart-drawer-body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem}
.cart-drawer-empty{text-align:center;padding:3rem 0;color:var(--c-muted);font-size:.95rem}
.cart-drawer-item{display:flex;gap:.875rem;padding:1rem 0;border-bottom:1px solid var(--c-border);align-items:flex-start}
.cart-drawer-item:last-child{border-bottom:none}
.cart-drawer-item-img{width:68px;height:68px;border-radius:var(--r-md);overflow:hidden;flex-shrink:0;background:var(--c-bg)}
.cart-drawer-item-img img{width:100%;height:100%;object-fit:cover}
.cart-drawer-item-info{flex:1}
.cart-drawer-item-name{font-size:.9rem;font-weight:600;color:var(--c-dark);margin-bottom:.25rem;line-height:1.3}
.cart-drawer-item-qty{font-size:.8rem;color:var(--c-muted);margin-bottom:.25rem}
.cart-drawer-item-price{font-size:.9rem;font-weight:700;color:var(--c-accent)}
.cart-drawer-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--c-border);background:var(--c-bg);flex-shrink:0}
.cart-drawer-subtotal{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;font-size:1.1rem;font-weight:700;color:var(--c-dark)}
.cart-drawer-checkout{display:block;width:100%;padding:.975rem;background:var(--c-accent);color:#fff;text-align:center;border-radius:var(--r-full);font-weight:700;font-size:1rem;transition:all var(--t);margin-bottom:.75rem}
.cart-drawer-checkout:hover{background:var(--c-accent-h);color:#fff;transform:translateY(-1px)}
.cart-drawer-continue{display:block;text-align:center;color:var(--c-muted);font-size:.875rem;padding:.5rem;transition:color var(--t)}
.cart-drawer-continue:hover{color:var(--c-dark)}
.quintec-hero{background:linear-gradient(135deg,var(--c-cream) 0%,#E4EDD9 60%,#D8E9CA 100%);padding:0;overflow:hidden;position:relative;display:flex;align-items:stretch}
.quintec-hero::before{content:'';position:absolute;top:-20%;right:-8%;width:600px;height:600px;background:radial-gradient(circle,rgba(91,124,63,.1) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.hero-container{width:100%;padding:3.5rem 2rem 3.5rem 4rem;display:grid;grid-template-columns:1fr 1.15fr;gap:3rem;align-items:center;position:relative;z-index:1;box-sizing:border-box;max-width:var(--max-w);margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(91,124,63,.12);color:var(--c-accent);padding:.5rem 1.25rem;border-radius:var(--r-full);font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.5rem;border:1px solid rgba(91,124,63,.2)}
.hero-headline{font-size:clamp(2.5rem,5vw,4.25rem);font-weight:800;line-height:1.1;color:var(--c-dark);margin-bottom:1.5rem;letter-spacing:-.02em}
.hero-headline span{color:var(--c-accent)}
.hero-subheadline{font-size:1.15rem;color:var(--c-muted);margin-bottom:2.5rem;line-height:1.75;max-width:480px}
.hero-cta-group{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-trust{display:flex;gap:1.75rem;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--c-muted);font-weight:500}
.hero-trust-item svg{color:var(--c-accent);flex-shrink:0}
.hero-image-wrap{position:relative;display:flex;justify-content:flex-end;align-items:stretch;overflow:hidden}
.hero-img-placeholder{background:rgba(91,124,63,.07);border:2px dashed rgba(91,124,63,.25);border-radius:var(--r-xl);width:100%;aspect-ratio:4/5;max-width:440px;display:flex;align-items:center;justify-content:center}
.hero-img-inner{text-align:center}
.hero-stat-card{position:absolute;background:#fff;border-radius:var(--r-lg);padding:1rem 1.375rem;box-shadow:var(--sh-lg);border:1px solid var(--c-border);min-width:130px}
.hero-stat-left{bottom:12%;left:-5%}
.hero-stat-right{top:10%;right:-3%}
.hero-stat-num{font-size:1.6rem;font-weight:800;color:var(--c-dark);line-height:1.1}
.hero-stat-label{font-size:.7rem;color:var(--c-muted);font-weight:500;margin-top:.2rem}
.products-section{background:var(--c-bg)}
.no-products-placeholder{text-align:center;padding:3rem;background:#fff;border-radius:var(--r-xl);border:2px dashed var(--c-border);color:var(--c-muted)}
.no-products-placeholder a{color:var(--c-accent);text-decoration:underline}

/* ===== SHOP WRAPPER & LAYOUT ===== */
.quintec-woo-wrapper{max-width:var(--max-w);margin:0 auto;padding:3rem 2rem}
.quintec-woo-main{min-height:70vh}
.woocommerce-notices-wrapper{max-width:var(--max-w);margin:0 auto;padding:0 2rem}

/* ===== SHOP PAGE HEADER ===== */
.woocommerce-products-header{text-align:center;padding:3rem 2rem 1rem;background:linear-gradient(135deg,var(--c-cream) 0%,#E4EDD9 100%);margin-bottom:2rem}
.woocommerce-products-header__title{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--c-dark);letter-spacing:-.02em}
.woocommerce-breadcrumb{max-width:var(--max-w);margin:0 auto;padding:.75rem 2rem;font-size:.82rem;color:var(--c-muted)}
.woocommerce-breadcrumb a{color:var(--c-muted)}
.woocommerce-breadcrumb a:hover{color:var(--c-accent)}

/* ===== SORT & RESULTS BAR ===== */
.woocommerce-result-count{font-size:.875rem;color:var(--c-muted);margin:0 0 1.5rem}
.woocommerce-ordering{margin:0 0 1.5rem}
.woocommerce-ordering select{border:2px solid var(--c-border);border-radius:var(--r-md);padding:.5rem 1rem;font-family:var(--font);font-size:.875rem;background:#fff;color:var(--c-text);cursor:pointer;outline:none;transition:border-color var(--t)}
.woocommerce-ordering select:focus{border-color:var(--c-accent)}

/* ===== PRODUCT CARDS — Clean WooCommerce defaults ===== */
ul.products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.75rem;
  list-style: none;
  margin: 0 0 3rem;
  padding: 0;
}
ul.products li.product {
  background: #fff;
  border: 1px solid #E8E8E4;
  border-radius: 1rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.25s, box-shadow 0.25s;
  margin: 0;
  padding: 0;
  position: relative;
}
ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.10);
}
/* Image */
ul.products li.product a img,
ul.products li.product > a > img {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
ul.products li.product:hover a img {
  transform: scale(1.04);
}
/* Sale badge */
ul.products li.product .onsale {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  background: #EF4444;
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  padding: 0.25rem 0.65rem;
  border-radius: 9999px;
  z-index: 2;
  min-height: auto;
  min-width: auto;
  line-height: 1.5;
  margin: 0;
}
/* Product title */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2 {
  font-family: var(--font);
  font-size: 0.92rem;
  font-weight: 600;
  color: #1A1A1A;
  padding: 0.875rem 1rem 0.25rem;
  margin: 0;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
/* Price */
ul.products li.product .price {
  padding: 0 1rem 0.25rem;
  color: #5B7C3F;
  font-weight: 700;
  font-size: 1rem;
  font-family: var(--font);
  margin: 0;
}
ul.products li.product .price del {
  color: #9CA3AF;
  font-size: 0.82em;
  font-weight: 400;
  margin-right: 0.3em;
}
ul.products li.product .price ins {
  text-decoration: none;
}
/* Star rating */
ul.products li.product .star-rating {
  margin: 0 1rem 0.25rem;
  font-size: 0.85rem;
}
/* Custom SVG rating */
.quintec-loop-rating {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0 1rem 0.5rem;
}
.quintec-stars {
  display: flex;
  align-items: center;
  gap: 1px;
}
.quintec-review-count {
  font-size: 0.72rem;
  color: #6B7280;
  font-weight: 500;
}
.quintec-no-reviews {
  font-size: 0.68rem;
  color: #9CA3AF;
  font-style: italic;
}
/* Add to Cart button */
ul.products li.product .button,
ul.products li.product a.button {
  display: block;
  margin: auto 1rem 1rem;
  background: #5B7C3F;
  color: #fff;
  border: none;
  border-radius: 9999px;
  padding: 0.65rem 1rem;
  font-family: var(--font);
  font-size: 0.82rem;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  transition: background 0.22s, box-shadow 0.22s;
  cursor: pointer;
}
ul.products li.product .button:hover {
  background: #4A6833;
  box-shadow: 0 4px 12px rgba(91,124,63,0.3);
  color: #fff;
}
ul.products li.product .added_to_cart {
  display: block;
  text-align: center;
  margin: 0 1rem 0.5rem;
  font-size: 0.78rem;
  color: #5B7C3F;
  font-weight: 600;
  text-decoration: none;
}
/* Responsive product grid */
@media (max-width: 1100px) { ul.products { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { ul.products { grid-template-columns: repeat(2, 1fr); gap: 1rem; } }
@media (max-width: 480px)  {
  ul.products li.product .woocommerce-loop-product__title { font-size: 0.82rem; padding: 0.6rem 0.75rem 0.2rem; }
  ul.products li.product .price { padding: 0 0.75rem 0.15rem; font-size: 0.9rem; }
  ul.products li.product .button { margin: auto 0.75rem 0.75rem; font-size: 0.75rem; padding: 0.55rem 0.75rem; }
  .quintec-loop-rating { padding: 0 0.75rem 0.35rem; }
}

.benefits-section{background:var(--c-white)}
.benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.75rem}
.benefit-card{background:var(--c-bg);border-radius:var(--r-xl);padding:2.25rem 1.75rem;text-align:center;border:1px solid var(--c-border);transition:all var(--t)}
.benefit-card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:var(--c-accent-lt)}
.benefit-icon{width:64px;height:64px;background:var(--c-accent-lt);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:var(--c-accent)}
.benefit-title{font-size:1.05rem;font-weight:700;color:var(--c-dark);margin-bottom:.75rem}
.benefit-desc{font-size:.9rem;color:var(--c-muted);line-height:1.65}
.categories-section{background:var(--c-bg)}
.categories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.category-card{position:relative;border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/3;display:block}
.category-card img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.category-card:hover img{transform:scale(1.07)}
.category-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.68) 0%,rgba(0,0,0,.1) 55%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.75rem}
.category-name{font-size:1.375rem;font-weight:700;color:#fff;margin-bottom:.3rem}
.category-count{font-size:.82rem;color:rgba(255,255,255,.78);margin-bottom:1rem}
.category-btn{display:inline-flex;align-items:center;gap:.4rem;background:#fff;color:var(--c-dark);padding:.55rem 1.1rem;border-radius:var(--r-full);font-size:.8rem;font-weight:600;transition:all var(--t);width:fit-content}
.category-btn:hover,.category-card:hover .category-btn{background:var(--c-accent);color:#fff}
.testimonials-section{background:var(--c-bg)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.testimonial-card{background:#fff;border-radius:var(--r-xl);padding:2.25rem;border:1px solid var(--c-border);transition:all var(--t);display:flex;flex-direction:column}
.testimonial-card:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.testimonial-stars{font-size:1.1rem;color:var(--c-gold);margin-bottom:1.25rem;letter-spacing:2px}
.testimonial-text{font-size:.975rem;line-height:1.75;color:var(--c-text);margin-bottom:1.75rem;font-style:italic;flex:1}
.testimonial-author{display:flex;align-items:center;gap:.875rem}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:var(--c-accent-lt);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--c-accent);font-size:.85rem;flex-shrink:0}
.testimonial-name{font-weight:700;font-size:.9rem;color:var(--c-dark)}
.testimonial-location{font-size:.78rem;color:var(--c-muted);margin-top:.15rem}
.email-capture-section{background:var(--c-accent);padding:5.5rem 2rem;text-align:center;position:relative;overflow:hidden}
.email-capture-inner{max-width:600px;margin:0 auto;position:relative;z-index:1}
.email-capture-label{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:1.25rem}
.email-capture-section h2{color:#fff;font-size:clamp(1.75rem,3vw,2.75rem);margin-bottom:1rem;letter-spacing:-.01em}
.email-capture-inner>p{color:rgba(255,255,255,.85);font-size:1.1rem;margin-bottom:2.5rem}
.email-form{display:flex;gap:.75rem;max-width:480px;margin:0 auto}
.email-form input[type=email]{flex:1;padding:.9rem 1.5rem;border-radius:var(--r-full);border:none;font-size:1rem;background:#fff;color:var(--c-dark);outline:none;min-width:0}
.email-form input[type=email]::placeholder{color:var(--c-muted)}
.email-form button{padding:.9rem 1.75rem;background:var(--c-dark);color:#fff;border:none;border-radius:var(--r-full);font-weight:600;font-size:.95rem;cursor:pointer;transition:all var(--t);white-space:nowrap;flex-shrink:0}
.email-form button:hover{background:#333;transform:translateY(-1px)}
.email-disclaimer{font-size:.75rem;color:rgba(255,255,255,.6);margin-top:1rem}

/* =============================================================
   SITE FOOTER — Full Redesign (Dark Green / Gold Theme)
============================================================= */

/* ── Shared footer base ── */
.site-footer {
  font-family: 'Poppins', sans-serif;
  background: #0a1f12;
}

/* =============================================================
   1. MAIN GRID AREA
============================================================= */
.footer-main {
  background: linear-gradient(180deg, #14321e 0%, #0d2015 100%);
  padding: 64px 0 52px;
  border-bottom: 1px solid rgba(201,164,86,.18);
}
.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
  display: grid;
  grid-template-columns: 2.2fr 1fr 1fr 1fr;
  gap: 48px;
}

/* Brand column */
.footer-brand .footer-logo-link {
  display: inline-block;
  margin-bottom: 18px;
}
.footer-brand .footer-logo-link img,
.footer-brand .custom-logo {
  max-height: 58px;
  width: auto;
  display: block;
}
.footer-logo-text {
  font-size: 1.6rem;
  font-weight: 800;
  color: #fff;
}
.footer-logo-text span { color: #d4b56a; }

.footer-tagline {
  font-size: 13.5px;
  line-height: 1.8;
  color: rgba(255,255,255,.5);
  max-width: 260px;
  margin: 0 0 20px;
}

.footer-social {
  display: flex;
  gap: 10px;
}
.footer-social a {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(201,164,86,.1);
  border: 1px solid rgba(201,164,86,.25);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(201,164,86,.7);
  transition: all .2s;
  text-decoration: none;
}
.footer-social a:hover {
  background: rgba(201,164,86,.25);
  color: #d4b56a;
  border-color: #d4b56a;
}

/* Link columns */
.footer-col-title {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #d4b56a;
  margin: 0 0 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(201,164,86,.2);
}
.footer-links {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-links li {
  margin-bottom: 10px;
}
.footer-links li a {
  font-size: 13.5px;
  color: rgba(255,255,255,.52);
  text-decoration: none;
  transition: color .2s, padding-left .2s;
  display: inline-block;
}
.footer-links li a:hover {
  color: #d4b56a;
  padding-left: 4px;
}

/* =============================================================
   2. FDA DISCLOSURE SECTION
============================================================= */
.footer-fda-section {
  background: #091810;
  border-top: 1px solid rgba(201,164,86,.12);
  border-bottom: 1px solid rgba(201,164,86,.12);
  padding: 36px 0 32px;
}
.footer-fda-inner {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 32px;
  text-align: center;
}

/* Badges */
.fda-badge-row {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}
.fda-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(201,164,86,.08);
  border: 1px solid rgba(201,164,86,.28);
  color: #c9a456;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  padding: 5px 13px;
  border-radius: 99px;
}

/* Rule divider */
.fda-rule {
  width: 60px;
  height: 1px;
  background: rgba(201,164,86,.3);
  margin: 0 auto 16px;
}

/* FDA label */
.fda-label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(201,164,86,.65);
  margin: 0 0 12px;
}

/* FDA text lines */
.fda-text-block {
  margin: 0 auto;
  max-width: 760px;
}
.fda-line {
  font-size: 12.5px;
  line-height: 1.65;
  color: rgba(255,255,255,.42);
  margin: 0 0 5px;
}
.fda-line:last-child { margin-bottom: 0; }
.fda-line--act {
  font-size: 11.5px;
  color: rgba(255,255,255,.28);
  font-style: italic;
  margin-top: 8px;
}

/* =============================================================
   3. BOTTOM BAR — copyright · policy links · payments
============================================================= */
.footer-bottom-bar {
  background: #070f09;
  padding: 18px 0;
}
.footer-bottom-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.footer-copy {
  font-size: 12px;
  color: rgba(255,255,255,.32);
  margin: 0;
  white-space: nowrap;
}

/* Policy nav */
.footer-policy-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px 2px;
}
.footer-policy-nav a {
  font-size: 12px;
  color: rgba(255,255,255,.38);
  text-decoration: none;
  padding: 3px 9px;
  border-radius: 3px;
  transition: color .2s, background .2s;
  white-space: nowrap;
}
.footer-policy-nav a:hover {
  color: #d4b56a;
  background: rgba(201,164,86,.07);
}

/* Payment badges */
.footer-payments {
  display: flex;
  gap: 6px;
}
.payment-badge {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 4px;
  padding: 3px 9px;
  font-size: 11px;
  color: rgba(255,255,255,.45);
  white-space: nowrap;
}

/* =============================================================
   4. RESPONSIVE
============================================================= */
@media (max-width: 900px) {
  .footer-inner {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
  }
  .footer-brand { grid-column: 1 / -1; }
  .footer-tagline { max-width: 100%; }
}

@media (max-width: 580px) {
  .footer-main { padding: 44px 0 36px; }
  .footer-inner {
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    padding: 0 20px;
  }
  .footer-brand { grid-column: 1 / -1; }
  .footer-fda-inner { padding: 0 20px; }
  .footer-bottom-inner {
    flex-direction: column;
    align-items: flex-start;
    padding: 0 20px;
    gap: 10px;
  }
  .footer-policy-nav {
    gap: 2px;
  }
  .footer-policy-nav a {
    font-size: 11px;
    padding: 3px 6px;
  }
}
/* =============================================================
   END FOOTER REDESIGN
============================================================= */
.woocommerce div.product{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.woocommerce div.product .woocommerce-product-gallery{position:sticky;top:100px}
.woocommerce div.product .flex-viewport{border-radius:var(--r-xl)!important;overflow:hidden!important;box-shadow:var(--sh-lg)!important}
.woocommerce div.product .product_title{font-size:clamp(1.75rem,3vw,2.375rem)!important;font-weight:800!important;color:var(--c-dark)!important;margin-bottom:.875rem!important;line-height:1.15!important;letter-spacing:-.01em!important}
.woocommerce div.product p.price,.woocommerce div.product span.price{font-size:1.875rem!important;font-weight:800!important;color:var(--c-accent)!important;display:block;margin-bottom:1.5rem!important}
.woocommerce div.product .woocommerce-product-details__short-description{font-size:1rem;color:var(--c-muted);line-height:1.75;margin-bottom:2rem!important;padding-bottom:2rem!important;border-bottom:1px solid var(--c-border)!important}
.woocommerce form.cart{display:flex;gap:1rem;align-items:flex-end;margin-bottom:1.5rem!important;flex-wrap:wrap}
.woocommerce form.cart .quantity input.qty{width:56px;border:2px solid var(--c-border)!important;background:var(--c-bg);font-size:1rem;text-align:center;padding:.75rem .5rem!important;font-family:var(--font)!important;font-weight:600;border-radius:var(--r-md)!important}
.woocommerce form.cart .single_add_to_cart_button{background:var(--c-accent)!important;color:#fff!important;border:none!important;border-radius:var(--r-full)!important;padding:.9rem 2.5rem!important;font-size:1.1rem!important;font-weight:700!important;font-family:var(--font)!important;cursor:pointer!important;transition:all var(--t)!important;flex:1!important;min-width:200px!important}
.woocommerce form.cart .single_add_to_cart_button:hover{background:var(--c-accent-h)!important;transform:translateY(-2px)!important;box-shadow:0 8px 28px rgba(91,124,63,.35)!important}
.product-trust-badges{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem;margin:1.75rem 0!important;padding:1.375rem;background:var(--c-bg);border-radius:var(--r-lg);border:1px solid var(--c-border)}
.trust-badge{display:flex;flex-direction:column;align-items:center;gap:.4rem;text-align:center;padding:.25rem}
.trust-badge-icon{font-size:1.375rem;line-height:1}
.trust-badge-text{font-size:.7rem;font-weight:600;color:var(--c-dark);line-height:1.2}
.woocommerce div.product .woocommerce-tabs{margin-top:3.5rem!important;grid-column:1/-1}
.woocommerce div.product .woocommerce-tabs ul.tabs{border-bottom:2px solid var(--c-border)!important;padding:0!important;margin-bottom:0!important;display:flex!important;gap:.25rem!important;background:none!important}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,.woocommerce div.product .woocommerce-tabs ul.tabs li::before,.woocommerce div.product .woocommerce-tabs ul.tabs li::after{display:none!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li{border:none!important;background:none!important;border-radius:0!important;margin:0!important;padding:0!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{font-family:var(--font)!important;font-size:.9rem!important;font-weight:600!important;color:var(--c-muted)!important;padding:.875rem 1.25rem!important;display:block!important;border-bottom:2px solid transparent!important;margin-bottom:-2px!important;transition:all var(--t)!important;border-radius:0!important}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a{color:var(--c-accent)!important;border-bottom-color:var(--c-accent)!important;background:none!important}
.woocommerce div.product .woocommerce-tabs .panel{border:1px solid var(--c-border)!important;border-radius:var(--r-xl)!important;padding:2.5rem!important;margin-top:1.5rem!important;background:#fff!important;box-shadow:none!important}
.quintec-tab-content h3{font-size:1.25rem;margin-bottom:1rem}
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button{background:var(--c-accent)!important;color:#fff!important;border-radius:var(--r-full)!important;font-family:var(--font)!important;font-weight:600!important;padding:.8rem 1.75rem!important;transition:all var(--t)!important;border:none!important;font-size:.95rem!important}
.woocommerce a.button:hover,.woocommerce button.button:hover{background:var(--c-accent-h)!important}
.woocommerce a.checkout-button{display:block!important;text-align:center!important;padding:1.05rem!important;font-size:1.1rem!important;font-weight:700!important;margin-top:1.25rem!important}
.woocommerce form .form-row label{font-size:.875rem;font-weight:600;color:var(--c-dark);margin-bottom:.4rem;display:block}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row select,.woocommerce form .form-row textarea{border:2px solid var(--c-border)!important;border-radius:var(--r-md)!important;padding:.875rem 1rem!important;font-family:var(--font)!important;font-size:1rem!important;width:100%!important;transition:border-color var(--t)!important}
.woocommerce form .form-row input.input-text:focus,.woocommerce form .form-row select:focus,.woocommerce form .form-row textarea:focus{border-color:var(--c-accent)!important;outline:none!important;box-shadow:0 0 0 3px rgba(91,124,63,.12)!important}
#payment{background:var(--c-bg)!important;border:1px solid var(--c-border)!important;border-radius:var(--r-xl)!important}
#place_order{background:var(--c-accent)!important;color:#fff!important;width:100%!important;padding:1.2rem!important;font-size:1.15rem!important;font-weight:700!important;border-radius:var(--r-full)!important;border:none!important;font-family:var(--font)!important;cursor:pointer!important;transition:all var(--t)!important;display:block!important}
#place_order:hover{background:var(--c-accent-h)!important;transform:translateY(-2px)!important;box-shadow:0 8px 28px rgba(91,124,63,.35)!important}
.woocommerce .cart-collaterals .cart_totals{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:2rem!important}
.woocommerce table.shop_table thead tr th{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--c-muted);padding:1rem;border-bottom:2px solid var(--c-border)!important}
.woocommerce table.shop_table tbody tr td{padding:1.5rem 1rem!important;border-bottom:1px solid var(--c-border)!important;vertical-align:middle}
.woocommerce .woocommerce-message{background:var(--c-accent-lt)!important;border-top:none!important;border-left:4px solid var(--c-accent)!important;border-radius:var(--r-lg)!important;padding:1rem 1.5rem!important;font-family:var(--font)!important}
.fade-in{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.benefits-grid{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.hero-container{grid-template-columns:1fr;text-align:center;gap:3rem;padding:3.5rem 2rem;max-width:100%}.hero-image-wrap{display:none}.hero-cta-group,.hero-trust{justify-content:center}.hero-subheadline{margin-left:auto;margin-right:auto}.main-nav{display:none!important}.mobile-menu-btn{display:flex}.woocommerce div.product{grid-template-columns:1fr;gap:2.5rem}.woocommerce div.product .woocommerce-product-gallery{position:static}.categories-grid{grid-template-columns:1fr 1fr}.testimonials-grid{grid-template-columns:1fr}.product-trust-badges{grid-template-columns:repeat(4,1fr)}.woocommerce ul.products,.woocommerce-page ul.products{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:640px){.quintec-hero{padding:0}.quintec-section{padding:3.5rem 0}.container{padding:0 1.25rem}.nav-container{padding:.875rem 1.25rem}.benefits-grid{grid-template-columns:1fr;gap:1.25rem}.categories-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr;gap:2rem}.footer-bottom{flex-direction:column;text-align:center}.email-form{flex-direction:column}.product-trust-badges{grid-template-columns:repeat(2,1fr)}.woocommerce ul.products,.woocommerce-page ul.products{grid-template-columns:1fr 1fr!important;gap:1rem!important}.cart-drawer{width:100%;right:-100%}.quintec-woo-wrapper{padding:2rem 1.25rem}.hero-cta-group{flex-direction:column;align-items:center}.btn-lg{padding:1rem 2rem;font-size:1rem}}

/* =====================================================
   PRODUCT GRID FIX — Global (homepage + shop)
   WooCommerce outputs <ul class="products columns-4">
   without a .woocommerce parent on the homepage.
   We target it directly so it ALWAYS shows 4-col grid.
===================================================== */

/* ---- Universal grid: any ul.products anywhere ---- */
ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 1.75rem !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Hide subcategory tiles and any non-product li inside the grid */
ul.products li:not(.product),
ul.products li.product-category {
  display: none !important;
}

/* Kill the ::before pseudo-element WooCommerce injects on ul.products
   which creates a ghost first grid cell */
ul.products::before,
ul.products::after {
  display: none !important;
  content: none !important;
}
/* Hide empty product cells */
ul.products li.product:empty {
  display: none !important;
}

/* ============================================================
   PRODUCT CARD — BudPop Style
   ============================================================ */

/* ---- Card base ---- */
ul.products li.product {
  background: #f2f4f0 !important;
  border-radius: 1.5rem !important;
  overflow: hidden !important;
  border: none !important;
  box-shadow: none !important;
  transition: transform 0.28s ease, box-shadow 0.28s ease !important;
  margin: 0 !important;
  padding: 0 0 1.25rem !important;
  display: flex !important;
  flex-direction: column !important;
  position: relative !important;
  align-items: stretch !important;
}

ul.products li.product:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 12px 36px rgba(0,0,0,0.10) !important;
}

/* ---- Image block — white bg, generous padding ---- */
ul.products li.product .woocommerce-LoopProduct-link,
ul.products li.product a.woocommerce-loop-product__link {
  display: flex !important;
  flex-direction: column !important;
  text-decoration: none !important;
  background: #fff !important;
  border-radius: 1.25rem !important;
  margin: 0.6rem 0.6rem 0 !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}

ul.products li.product a.woocommerce-loop-product__link img {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: contain !important;
  object-position: center !important;
  display: block !important;
  padding: 0.75rem !important;
  transition: transform 0.4s ease !important;
  border-radius: 0 !important;
}

ul.products li.product:hover a.woocommerce-loop-product__link img {
  transform: scale(1.04) !important;
}

/* ---- SALE / BEST SELLER badge ---- */
ul.products li.product .onsale,
ul.products li.product .quintec-best-badge {
  position: absolute !important;
  top: 0.9rem !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: auto !important;
  background: #EF4444 !important;
  color: #fff !important;
  font-size: 0.52rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  padding: 0.18rem 0.65rem !important;
  border-radius: 4px !important;
  z-index: 3 !important;
  margin: 0 !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1.6 !important;
  white-space: nowrap !important;
  text-align: center !important;
  display: inline-block !important;
}

/* ---- Product title ---- */
ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Poppins', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #1A1A1A !important;
  padding: 1rem 1rem 0.3rem !important;
  margin: 0 !important;
  line-height: 1.35 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-align: center !important;
}

/* ---- Price — large, centered, dark green ---- */
ul.products li.product .price {
  font-family: 'Poppins', sans-serif !important;
  padding: 0 1rem 0.1rem !important;
  display: flex !important;
  align-items: baseline !important;
  justify-content: center !important;
  gap: 0.4rem !important;
  flex-wrap: wrap !important;
  margin: 0 !important;
  line-height: 1 !important;
  text-align: center !important;
}

ul.products li.product .price ins,
ul.products li.product .price > .woocommerce-Price-amount {
  color: #1a4d2e !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}

ul.products li.product .price del {
  color: #9CA3AF !important;
  font-size: 0.85rem !important;
  font-weight: 400 !important;
  text-decoration: line-through !important;
}

ul.products li.product .price del .woocommerce-Price-amount {
  color: #9CA3AF !important;
  font-size: 0.85rem !important;
}

/* ---- "or subscribe to save" line ---- */
.quintec-subscribe-line {
  font-size: 0.72rem !important;
  color: #6B7280 !important;
  text-align: center !important;
  padding: 0 1rem 0.5rem !important;
  font-family: 'Poppins', sans-serif !important;
}

/* ---- Rating row ---- */
ul.products li.product .star-rating {
  display: none !important;
}

.quintec-loop-rating {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.35rem !important;
  padding: 0.25rem 1rem 0.75rem !important;
}

.quintec-stars {
  display: flex !important;
  align-items: center !important;
  gap: 1px !important;
  line-height: 1 !important;
}

.quintec-stars svg { display: inline-block !important; flex-shrink: 0 !important; }

.quintec-review-count {
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.78rem !important;
  color: #4B5563 !important;
  font-weight: 500 !important;
  line-height: 1 !important;
}

.quintec-no-reviews {
  font-size: 0.68rem !important;
  color: #9CA3AF !important;
  font-style: italic !important;
}

/* ---- Spacer to push button to bottom ---- */
ul.products li.product a.woocommerce-loop-product__link::after {
  content: '' !important;
  display: block !important;
  flex: 1 !important;
}

/* ---- Add to Cart / View Product button ---- */
ul.products li.product .button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  align-self: center !important;
  width: calc(100% - 2rem) !important;
  margin: 0.6rem 1rem 0 !important;
  background: #1a4d2e !important;
  color: #fff !important;
  border: 2px solid #1a4d2e !important;
  border-radius: 9999px !important;
  padding: 0.85rem 1rem !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  letter-spacing: 0.02em !important;
  transition: background 0.22s ease, box-shadow 0.22s ease !important;
  cursor: pointer !important;
  text-decoration: none !important;
  box-sizing: border-box !important;
}

ul.products li.product .button:hover {
  background: #0f2d1a !important;
  border-color: #0f2d1a !important;
  box-shadow: 0 6px 18px rgba(26,77,46,0.3) !important;
  color: #fff !important;
}

ul.products li.product .button.loading { opacity: 0.7 !important; }
ul.products li.product .button.added::after { display: none !important; }

/* =====================================================
   SHOP PAGE LAYOUT — Banner + Toolbar
===================================================== */
.shop-page-banner {
  background: linear-gradient(135deg, #F5F0E8 0%, #EEF4E8 100%);
  padding: 3.5rem 0 3rem;
  border-bottom: 1px solid #E5E7EB;
  margin-bottom: 0;
}
.shop-banner-inner {
  text-align: center;
}
.shop-banner-title {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  color: #1A1A1A;
  margin-bottom: 0.5rem;
  letter-spacing: -0.02em;
}
.shop-banner-sub {
  color: #6B7280;
  font-size: 1.05rem;
  margin: 0;
}
.shop-banner-desc {
  color: #6B7280;
  font-size: 1rem;
  line-height: 1.7;
  max-width: 640px;
  margin: 0.75rem auto 0;
}
.shop-banner-desc p { margin-bottom: 0.5rem; }
.shop-banner-desc p:last-child { margin-bottom: 0; }

/* ---- Category rich content block (bottom of archive page) ---- */
.quintec-cat-content {
  width: 100%;
  margin: 5rem 0 0;
  padding: 3rem 0 0;
  background: transparent;
  border-radius: 0;
  border: none;
  border-top: 1px solid #E5E7EB;
  font-family: 'Poppins', sans-serif;
  color: #3D3D3D;
  font-size: 0.96rem;
  line-height: 1.8;
}
.quintec-cat-content h2,
.quintec-cat-content h3,
.quintec-cat-content h4 {
  color: #1A1A1A;
  font-weight: 700;
  margin: 1.5rem 0 0.6rem;
  line-height: 1.3;
}
.quintec-cat-content h2 { font-size: 1.5rem; }
.quintec-cat-content h3 { font-size: 1.2rem; }
.quintec-cat-content h4 { font-size: 1rem; }
.quintec-cat-content p  { margin-bottom: 1rem; }
.quintec-cat-content a  { color: #5B7C3F; text-decoration: underline; }
.quintec-cat-content a:hover { color: #4A6833; }
.quintec-cat-content ul,
.quintec-cat-content ol {
  padding-left: 1.5rem;
  margin-bottom: 1rem;
}
.quintec-cat-content ul li,
.quintec-cat-content ol li { margin-bottom: 0.4rem; }
.quintec-cat-content img {
  max-width: 100%;
  border-radius: 0.75rem;
  margin: 1rem 0;
}
.quintec-cat-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.25rem 0;
  font-size: 0.9rem;
}
.quintec-cat-content table th,
.quintec-cat-content table td {
  border: 1px solid #E5E7EB;
  padding: 0.6rem 0.9rem;
  text-align: left;
}
.quintec-cat-content table th {
  background: #F3F4F6;
  font-weight: 600;
}
.quintec-cat-content strong { font-weight: 700; color: #1A1A1A; }
.woo-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem 0 2rem;
  border-bottom: 1px solid #E5E7EB;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.woo-result-count .woocommerce-result-count {
  font-size: 0.88rem;
  color: #6B7280;
  margin: 0;
  font-family: 'Poppins', sans-serif;
}
.woo-ordering .woocommerce-ordering select {
  border: 2px solid #E5E7EB !important;
  border-radius: 9999px !important;
  padding: 0.5rem 1.25rem !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.85rem !important;
  color: #3D3D3D !important;
  background: #fff !important;
  cursor: pointer !important;
  outline: none !important;
  appearance: auto !important;
}
.woo-ordering .woocommerce-ordering select:focus {
  border-color: #5B7C3F !important;
}

/* =====================================================
   SHOP TOOLBAR — result count + ordering (injected before loop)
   These are siblings of ul.products — make sure they don't
   accidentally sit inside the grid
===================================================== */
.woocommerce-ordering,
.woocommerce-result-count,
.woocommerce-breadcrumb,
.woocommerce-notices-wrapper,
.woocommerce-info {
  grid-column: 1 / -1 !important;
  width: 100% !important;
}

/* If WC injects a blank li as first child, hide it */
ul.products li.product:empty {
  display: none !important;
}

/* Fix: result-count / ordering are output as p/form BEFORE ul.products
   but sometimes WC wraps them — ensure they never collapse into grid */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
  display: block !important;
}

/* =====================================================
   RESPONSIVE OVERRIDES — must come after the universal rules
===================================================== */

@media (max-width: 860px) {
  ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 1.1rem !important; }
}
@media (max-width: 480px) {
  ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 0.75rem !important; }
  ul.products li.product .woocommerce-loop-product__title { font-size: 0.8rem !important; padding: 0.7rem 0.75rem 0.3rem !important; }
  ul.products li.product .price { padding: 0 0.75rem 0.3rem !important; }
  ul.products li.product .price ins,
  ul.products li.product .price > .woocommerce-Price-amount { font-size: 0.95rem !important; }
  ul.products li.product .price del { font-size: 0.75rem !important; }
  ul.products li.product .button { margin: 0 0.75rem 0.75rem !important; font-size: 0.75rem !important; padding: 0.6rem 0.75rem !important; }
  .quintec-loop-rating { padding: 0 0.75rem 0.6rem !important; }
  .quintec-review-count { font-size: 0.65rem !important; }
}



/* ============================================================
   HERO IMAGE SLIDER
============================================================ */
.hero-slider {
    position: relative;
    border-radius: 2rem 0 0 2rem;
    overflow: hidden;
    box-shadow: -8px 0 40px rgba(0,0,0,.18);
    width: 100%;
    background: #e8f0e4;
    flex: 1;
    min-height: 420px;
}
.hero-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity .7s ease;
    pointer-events: none;
}
.hero-slide.active {
    opacity: 1;
    pointer-events: auto;
}
/* Slide effect */
.hero-slider[data-effect="slide"] .hero-slide {
    transform: translateX(100%);
    transition: transform .6s cubic-bezier(.4,0,.2,1), opacity .1s;
    opacity: 1;
}
.hero-slider[data-effect="slide"] .hero-slide.active {
    transform: translateX(0);
    opacity: 1;
}
.hero-slider[data-effect="slide"] .hero-slide.leaving {
    transform: translateX(-100%);
}
/* Size the slider height from the first (active) slide image */
.hero-slide img {
    width: 100%;
    height: auto;
    display: block;
}
/* Invisible first slide sets the height; all other slides fill that space */
.hero-slide:not(.active) img {
    visibility: hidden;
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.hero-slide.active img {
    visibility: visible;
    position: relative;
    height: auto;
    object-fit: unset;
}

/* Arrows */
.hero-slide-prev,
.hero-slide-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255,255,255,.85);
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    color: #14321e;
    box-shadow: 0 2px 8px rgba(0,0,0,.15);
    transition: background .2s, transform .2s;
    backdrop-filter: blur(4px);
}
.hero-slide-prev { left: 12px; }
.hero-slide-next { right: 12px; }
.hero-slide-prev:hover,
.hero-slide-next:hover {
    background: #fff;
    transform: translateY(-50%) scale(1.08);
}

/* Dots */
.hero-slide-dots {
    position: absolute;
    bottom: 14px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 7px;
    z-index: 10;
}
.hero-slide-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,.55);
    cursor: pointer;
    padding: 0;
    transition: background .25s, transform .25s;
}
.hero-slide-dot.active {
    background: #fff;
    transform: scale(1.3);
}

/* Pause on hover */
.hero-slider:hover .hero-slide-prev,
.hero-slider:hover .hero-slide-next {
    opacity: 1;
}
/* ============================================================
   END HERO SLIDER
============================================================ */

/* ===== QUINTE LOGO & HEADER FIXES ===== */

/* --- Custom logo from WP Customizer: fix layout & sizing --- */
.site-logo,
.custom-logo-link,
a.custom-logo-link {
  display: flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  text-decoration: none !important;
}

.custom-logo-link img,
.custom-logo,
img.custom-logo,
.site-logo img {
  max-height: 60px !important;
  width: auto !important;
  height: auto !important;
  display: block !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* --- Header background: dark green gradient to match logo --- */
.site-header {
  background: linear-gradient(135deg, #14321e 0%, #0d2015 100%) !important;
  border-bottom: 1px solid rgba(201, 164, 86, 0.2) !important;
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3) !important;
}

/* --- Nav container: logo LEFT, nav CENTER-RIGHT, actions RIGHT --- */
.nav-container {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0.875rem 2rem !important;
  max-width: var(--max-w) !important;
  margin: 0 auto !important;
  gap: 1.5rem !important;
}

/* --- Nav links: gold color (desktop only) --- */
@media (min-width: 901px) {
  .main-nav,
  nav.main-nav {
    display: flex !important;
    align-items: center !important;
    flex: 1 !important;
    justify-content: center !important;
    padding-right: 0 !important;
  }
}

.main-nav li {
  list-style: none !important;
}

.main-nav li a,
.main-nav a,
.main-nav ul li a {
  color: #d4b56a !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  padding: 0.5rem 1rem !important;
  border-radius: var(--r-md) !important;
  transition: all var(--t) !important;
  letter-spacing: 0.04em !important;
  text-decoration: none !important;
  display: block !important;
}

.main-nav li a:hover,
.main-nav a:hover,
.main-nav ul li a:hover {
  color: #f5d98a !important;
  background: rgba(201, 164, 86, 0.1) !important;
}

/* --- Header action icons: gold --- */
.header-actions {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  flex-shrink: 0 !important;
}

.header-icon-btn,
.cart-icon-btn {
  color: #d4b56a !important;
}

.header-icon-btn:hover,
.cart-icon-btn:hover {
  background: rgba(201, 164, 86, 0.15) !important;
  color: #f5d98a !important;
}

/* --- Mobile hamburger bars: gold --- */
.mobile-menu-btn span {
  background: #d4b56a !important;
}

/* --- Mobile nav panel: dark green background, gold links --- */
.mobile-nav,
#mobile-nav {
  background: #0d2015 !important;
  border-top: 1px solid rgba(201, 164, 86, 0.2) !important;
}

.mobile-nav-inner li a,
.mobile-nav-inner a,
.mobile-nav li a,
.mobile-nav a,
#mobile-nav a,
#mobile-nav li a {
  color: #d4b56a !important;
  font-weight: 500 !important;
}

.mobile-nav-inner li a:hover,
.mobile-nav-inner a:hover,
#mobile-nav a:hover {
  color: #f5d98a !important;
  background: rgba(201, 164, 86, 0.1) !important;
}

/* --- Footer logo: use the custom logo image --- */
.footer-brand .footer-logo-link {
  display: block !important;
  margin-bottom: 1.125rem !important;
}

.footer-brand .footer-logo-link img,
.footer-brand .footer-logo-link .custom-logo {
  max-height: 55px !important;
  width: auto !important;
  display: block !important;
  filter: brightness(1.1) !important;
}

.footer-logo-text {
  font-size: 1.65rem !important;
  font-weight: 800 !important;
  color: #fff !important;
}

.footer-logo-text span {
  color: #d4b56a !important;
}

/* --- Keep the old .site-logo text fallback gold in footer if no image --- */
.footer-brand .site-logo {
  color: #fff !important;
}

/* ===== END QUINTE HEADER FIXES ===== */


/* FDA text block — broken into readable lines */
.fda-text-block {
  max-width: 780px;
  margin: 0 auto 24px;
  font-family: 'Poppins', sans-serif;
  text-align: center;
}
.fda-headline {
  margin: 0 0 10px;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(201, 164, 86, 0.8);
}
.fda-headline strong {
  font-weight: 700;
  color: rgba(201, 164, 86, 0.85);
}
.fda-line {
  font-size: 12.5px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.5);
  margin: 0 0 6px;
  padding: 0;
}
.fda-line:last-child { margin-bottom: 0; }
.fda-line--act {
  font-size: 11.5px;
  color: rgba(255, 255, 255, 0.3);
  font-style: italic;
  margin-top: 8px;
}
.fda-policy-links {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px 4px;
}
.fda-policy-links a {
  color: rgba(255, 255, 255, 0.55);
  font-size: 12.5px;
  font-weight: 500;
  text-decoration: none;
  font-family: 'Poppins', sans-serif;
  padding: 4px 10px;
  border-radius: 4px;
  transition: color 0.2s ease, background 0.2s ease;
}
.fda-policy-links a:hover {
  color: #d4b56a;
  background: rgba(201, 164, 86, 0.08);
  text-decoration: none;
}
.fda-sep {
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(201, 164, 86, 0.35);
  vertical-align: middle;
}
@media (max-width: 640px) {
  .footer-fda-section { padding: 30px 0 24px; }
  .fda-text { font-size: 12px; }
  .fda-sep { display: none; }
  .fda-policy-links a { width: 48%; text-align: center; }
}
/* =====================================================
   END FDA SECTION
===================================================== */

/* ================================================================
   CATEGORY PAGE — Reviews Carousel + FAQ Accordion
================================================================ */
.qcat-reviews-section,.qcat-faq-section{max-width:1160px;margin:60px auto 0;padding:0 20px;box-sizing:border-box;font-family:'Poppins',sans-serif}
.qcat-reviews-header{text-align:center;margin-bottom:36px}
.qcat-reviews-title{font-size:28px;font-weight:800;color:#1a1a2e;margin:0 0 8px;font-family:'Poppins',sans-serif}
.qcat-reviews-sub{font-size:14px;color:#6b7280;margin:0}
.qcat-reviews-carousel{display:flex;align-items:center;gap:10px}
.qcat-track-outer{flex:1;overflow:hidden;min-width:0;width:0}
.qcat-track{display:flex;gap:20px;transition:transform .45s cubic-bezier(.4,0,.2,1);align-items:stretch}
.qcat-review-card{flex-shrink:0;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:22px;display:flex;flex-direction:column;gap:12px;box-shadow:0 1px 6px rgba(0,0,0,.05);transition:box-shadow .2s,transform .2s;box-sizing:border-box}
.qcat-review-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.09);transform:translateY(-2px)}
.qcat-card-top{display:flex;align-items:flex-start;gap:12px}
.qcat-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:.02em}
.qcat-card-meta{flex:1;min-width:0}
.qcat-stars-row{display:flex;align-items:center;gap:2px;margin-bottom:4px}
.qcat-date{font-size:11px;color:#9ca3af;margin-left:8px;font-weight:400}
.qcat-reviewer-name{font-size:14px;font-weight:700;color:#1a1a2e}
.qcat-tags{display:flex;flex-wrap:wrap;gap:6px}
.qcat-tag{background:#fff7ed;border:1px solid #fed7aa;color:#c2410c;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:99px}
.qcat-body{font-size:13.5px;line-height:1.75;color:#374151;margin:0;flex:1;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}
.qcat-product{display:flex;align-items:center;gap:10px;background:#f8f9fa;border-radius:10px;padding:10px 12px;margin-top:auto}
.qcat-product img{width:44px;height:44px;object-fit:cover;border-radius:6px;flex-shrink:0}
.qcat-product-label{display:block;font-size:10px;color:#9ca3af;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.qcat-product-name{font-size:12.5px;font-weight:700;color:#14321e}
.qcat-nav{width:42px;height:42px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:#374151;transition:all .2s}
.qcat-nav:hover{border-color:#14321e;color:#14321e;box-shadow:0 2px 8px rgba(20,50,30,.15)}
.qcat-dots{display:flex;justify-content:center;gap:7px;margin-top:24px}
.qcat-dot{width:9px;height:9px;border-radius:50%;border:none;background:#d1d5db;cursor:pointer;padding:0;transition:background .2s,transform .2s}
.qcat-dot.active{background:#14321e;transform:scale(1.3)}

/* FAQ */
.qcat-faq-section{margin-top:60px;padding-bottom:80px}
.qcat-faq-header{margin-bottom:28px}
.qcat-faq-title{font-size:28px;font-weight:800;color:#1a1a2e;margin:0;font-family:'Poppins',sans-serif}
.qcat-faq-list{display:flex;flex-direction:column;gap:0;border:1px solid #e5e7eb;border-radius:14px;overflow:hidden}
.qcat-faq-item{border-bottom:1px solid #e5e7eb}
.qcat-faq-item:last-child{border-bottom:none}
.qcat-faq-h3{margin:0;padding:0;font-size:inherit;font-weight:inherit;line-height:inherit}
.qcat-faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;background:#fff;border:none;cursor:pointer;text-align:left;font-family:'Poppins',sans-serif;font-size:15px;font-weight:600;color:#1a1a2e;transition:background .2s,color .2s}
.qcat-faq-q:hover{background:#f8fffe;color:#14321e}
.qcat-faq-q.open{background:#f0fdf4;color:#14321e}
.qcat-faq-icon{flex-shrink:0;transition:transform .3s ease;color:#9ca3af}
.qcat-faq-q.open .qcat-faq-icon{transform:rotate(180deg);color:#14321e}
.qcat-faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;background:#f8fffe}
.qcat-faq-a-inner{padding:4px 22px 20px;font-size:14px;line-height:1.8;color:#4b5563}
.qcat-faq-a-inner p{margin:0 0 10px}
.qcat-faq-a-inner p:last-child{margin-bottom:0}
@media(max-width:768px){.qcat-reviews-section,.qcat-faq-section{padding:0 16px}.qcat-reviews-title,.qcat-faq-title{font-size:22px}.qcat-faq-q{font-size:14px;padding:15px 16px}.qcat-faq-a-inner{padding:4px 16px 16px}}
/* ================================================================
   END CATEGORY REVIEWS + FAQ
================================================================ */
/* ================================================================
   CONTACT SECTION — Chat Card & Button
================================================================ */
.contact-card {
    display: flex;
    align-items: flex-start;
    gap: 1.1rem;
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--r-xl);
    padding: 1.5rem 1.75rem;
    box-shadow: var(--sh-sm, 0 1px 6px rgba(0,0,0,.07));
    transition: transform .2s, box-shadow .2s;
}
.contact-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sh-lg, 0 8px 30px rgba(0,0,0,.12));
}
.contact-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
    margin-top: 2.5rem;
}
.contact-icon-wrap {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.contact-icon--blue  { background: #EBF4FF; color: #2563EB; }
.contact-icon--purple{ background: #F4F0FF; color: #7C3AED; }
.contact-icon--pink  { background: #FFF0F5; color: #DB2777; }
.contact-card-body {
    display: flex;
    flex-direction: column;
    gap: .3rem;
}
.contact-card-label {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--c-muted);
}
.contact-card-value {
    font-size: 1rem;
    font-weight: 600;
    color: var(--c-dark);
    line-height: 1.35;
}
.contact-card-value a {
    color: var(--c-dark);
    text-decoration: none;
}
.contact-card-value a:hover { color: var(--c-accent); }
.contact-card-hours {
    font-size: .8rem;
    color: var(--c-muted);
    margin-top: .15rem;
}
/* Chat-specific button */
.contact-chat-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    margin-top: .75rem;
    padding: .55rem 1.15rem;
    border-radius: var(--r-full);
    background: var(--c-accent);
    color: #fff;
    font-size: .82rem;
    font-weight: 700;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: opacity .2s, transform .2s;
    width: fit-content;
}
.contact-chat-btn:hover {
    opacity: .88;
    transform: translateY(-1px);
    color: #fff;
}
.contact-card--chat {
    border-width: 1px;
    border-style: solid;
}
@media(max-width:640px){
    .contact-cards{ grid-template-columns: 1fr; }
}
/* ================================================================
   END CONTACT CHAT CARD
================================================================ */

/* ================================================================
   RAW HTML INJECT BLOCK — direct inline render
================================================================ */
.quintec-cat-html-inject {
    width: 100%;
    margin: 2rem 0;
}
/* Scoping wrapper — stops broken CSS inside from leaking out */
.qhi-block {
    /* Contain layout so a broken float/position inside can't
       shift surrounding page elements */
    display: flow-root;
    position: relative;
    /* Let content breathe full-width */
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
/* Any direct child of the block can't overflow the column */
.qhi-block > * {
    max-width: 100%;
    box-sizing: border-box;
}
/* ================================================================
   END RAW HTML INJECT BLOCK
================================================================ */

/* ================================================================
   SINGLE POST — AUTHOR BIO BOX
================================================================ */
.author-bio-box {
  display: flex;
  align-items: flex-start;
  gap: 2.5rem;
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 1.25rem;
  padding: 2.5rem;
  margin: 3rem 0;
  box-shadow: 0 2px 16px rgba(0,0,0,.05);
}

/* Left — circular portrait */
.author-bio-img-wrap {
  flex-shrink: 0 !important;
  width: 190px !important;
  height: 190px !important;
}
.author-bio-avatar {
  width: 190px !important;
  height: 190px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: top center !important;
  display: block !important;
  border: 3px solid #E5E7EB !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.12) !important;
  max-width: 190px !important;
}

/* Right — text content */
.author-bio-content {
  flex: 1;
  min-width: 0;
}

/* "About [Name]" heading with bottom underline */
.author-bio-heading {
  font-size: 1.45rem;
  font-weight: 800;
  color: #1A1A1A;
  margin: 0 0 1.1rem;
  padding-bottom: .6rem;
  border-bottom: 2px solid #1A1A1A;
  display: inline-block;
  line-height: 1.25;
  letter-spacing: -.01em;
}

/* Bio paragraph */
.author-bio-desc {
  font-size: .97rem;
  line-height: 1.8;
  color: #3D3D3D;
  margin: 0 0 1.25rem;
}

/* Footer row with "View all posts" link */
.author-bio-footer {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  flex-wrap: wrap;
}
.author-bio-link {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .875rem;
  font-weight: 700;
  color: #5B7C3F;
  text-decoration: none;
  border-bottom: 2px solid #5B7C3F;
  padding-bottom: .1rem;
  transition: color .2s, border-color .2s;
}
.author-bio-link:hover {
  color: #4A6833;
  border-color: #4A6833;
}

/* Responsive */
@media (max-width: 640px) {
  .author-bio-box {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1.75rem 1.25rem;
    gap: 1.5rem;
  }
  .author-bio-heading {
    font-size: 1.2rem;
  }
  .author-bio-footer {
    justify-content: center;
  }
}
/* ================================================================
   END AUTHOR BIO BOX
================================================================ */

/* ================================================================
   MY ACCOUNT — FULL PAGE STYLES
================================================================ */

/* ── LOGIN PAGE (logged-out): centred single-card layout ── */
/* Target: body has woocommerce-account but NOT .logged-in */
.woocommerce-account:not(.logged-in) .quintec-page-wrap{
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding:3rem 1rem 5rem;
  min-height:60vh;
}
.woocommerce-account:not(.logged-in) .quintec-page-content{
  width:100%;
  max-width:480px;
}
.woocommerce-account:not(.logged-in) .woocommerce{
  display:block !important;
  background:transparent !important;
  padding:0 !important;
  border:none !important;
  box-shadow:none !important;
  width:100%;
}
/* Login card */
.woocommerce-account:not(.logged-in) .woocommerce-form-login{
  background:#fff !important;
  border:1px solid #E5E7EB !important;
  border-radius:1.5rem !important;
  padding:2.5rem !important;
  max-width:100% !important;
  box-shadow:0 8px 40px rgba(0,0,0,.08) !important;
}
/* Card heading */
.woocommerce-account:not(.logged-in) .woocommerce > h2{
  font-size:1.6rem;
  font-weight:800;
  color:#14321e;
  text-align:center;
  margin:0 0 1.5rem;
  letter-spacing:-.02em;
}
/* Leaf accent above heading */
.woocommerce-account:not(.logged-in) .woocommerce > h2::before{
  content:'🌿 ';
  font-size:1.2rem;
}
/* Labels */
.woocommerce-account:not(.logged-in) .woocommerce-form-login label{
  font-size:.82rem !important;
  font-weight:700 !important;
  color:#374151 !important;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin-bottom:.45rem !important;
}
/* Inputs */
.woocommerce-account:not(.logged-in) .woocommerce-Input{
  width:100% !important;
  padding:.9rem 1.1rem !important;
  border:2px solid #E5E7EB !important;
  border-radius:.875rem !important;
  font-size:.975rem !important;
  font-family:Poppins,sans-serif !important;
  color:#1A1A1A !important;
  background:#FAFAF9 !important;
  transition:border-color .2s,box-shadow .2s,background .2s !important;
  box-sizing:border-box !important;
}
.woocommerce-account:not(.logged-in) .woocommerce-Input:focus{
  border-color:#5B7C3F !important;
  background:#fff !important;
  outline:none !important;
  box-shadow:0 0 0 4px rgba(91,124,63,.1) !important;
}
/* Remember me row */
.woocommerce-account:not(.logged-in) .woocommerce-form-login .form-row:last-of-type{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:.75rem;
  margin-top:.5rem;
}
.woocommerce-account:not(.logged-in) .woocommerce-form__label-for-checkbox{
  display:flex !important;
  align-items:center;
  gap:.5rem;
  font-size:.875rem !important;
  font-weight:500 !important;
  color:#6B7280 !important;
  text-transform:none !important;
  letter-spacing:0 !important;
  cursor:pointer;
}
.woocommerce-account:not(.logged-in) .woocommerce-form__label-for-checkbox input[type=checkbox]{
  width:16px;
  height:16px;
  accent-color:#5B7C3F;
  cursor:pointer;
}
/* Log in button */
.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit{
  background:linear-gradient(135deg,#14321e 0%,#1a4527 100%) !important;
  color:#fff !important;
  border:none !important;
  border-radius:9999px !important;
  padding:.9rem 2.5rem !important;
  font-size:.975rem !important;
  font-weight:700 !important;
  font-family:Poppins,sans-serif !important;
  cursor:pointer !important;
  transition:transform .22s,box-shadow .22s !important;
  letter-spacing:.01em !important;
  box-shadow:0 4px 16px rgba(20,50,30,.25) !important;
  white-space:nowrap;
}
.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit:hover{
  transform:translateY(-2px) !important;
  box-shadow:0 8px 24px rgba(20,50,30,.35) !important;
}
/* Lost password */
.woocommerce-account:not(.logged-in) .woocommerce-LostPassword{
  text-align:center;
  margin-top:1.25rem !important;
}
.woocommerce-account:not(.logged-in) .woocommerce-LostPassword a{
  font-size:.85rem;
  color:#5B7C3F;
  text-decoration:none;
  border-bottom:1px dashed #5B7C3F;
  padding-bottom:.1rem;
  transition:color .2s;
}
.woocommerce-account:not(.logged-in) .woocommerce-LostPassword a:hover{color:#14321e;border-color:#14321e}
/* Divider + register link below the card */
.woocommerce-account:not(.logged-in) .woocommerce-notices-wrapper + *{margin-top:0}

/* ── DASHBOARD (logged-in): flex nav + content layout ── */
/* Account layout — flex so nav + content sit side by side */
.logged-in.woocommerce-account .woocommerce{
  display:flex !important;
  flex-direction:row !important;
  align-items:flex-start !important;
  gap:2.5rem;
  padding-top:2rem;
  width:100%;
  box-sizing:border-box;
}
.woocommerce-MyAccount-navigation{
  background:#fff;
  border-radius:1.25rem;
  border:1px solid #E5E7EB;
  overflow:hidden;
  flex:0 0 240px;
  width:240px;
  min-width:200px;
  max-width:260px;
  position:static !important;
}
.woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0}
.woocommerce-MyAccount-navigation ul li{border-bottom:1px solid #F3F4F6}
.woocommerce-MyAccount-navigation ul li:last-child{border-bottom:none}
.woocommerce-MyAccount-navigation ul li a{display:flex;align-items:center;padding:.9rem 1.25rem;font-size:.875rem;font-weight:500;color:#3D3D3D;text-decoration:none;transition:all .2s}
.woocommerce-MyAccount-navigation ul li.is-active a,.woocommerce-MyAccount-navigation ul li a:hover{background:#EEF4E8;color:#5B7C3F;font-weight:600;padding-left:1.5rem}
.woocommerce-MyAccount-content{
  flex:1 1 0%;
  min-width:0;
  /* do NOT set overflow here — it breaks WC float clearfix inside */
}
.woocommerce-MyAccount-content h2,.woocommerce-MyAccount-content h3{font-size:1.25rem;font-weight:800;color:#1A1A1A;margin-bottom:1.25rem;letter-spacing:-.01em}
/* Notices */
.woocommerce-message,.woocommerce-error,.woocommerce-info{padding:.875rem 1.25rem;border-radius:.75rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;list-style:none}
.woocommerce-message{background:#EEF4E8;border-left:4px solid #5B7C3F;color:#3D5C24}
.woocommerce-error{background:#FEF2F2;border-left:4px solid #EF4444;color:#B91C1C}
.woocommerce-info{background:#EFF6FF;border-left:4px solid #3B82F6;color:#1D4ED8}
/* Forms */
.woocommerce-account .woocommerce-form,
.woocommerce-account form.edit-account,
.woocommerce-account form.lost_reset_password,
.woocommerce-account form.register,
.woocommerce-account form.login{background:#fff;border:1px solid #E5E7EB;border-radius:1.25rem;padding:2rem;max-width:540px}
.woocommerce-account .woocommerce-form p,.woocommerce-account form p{margin-bottom:1.1rem}
.woocommerce-account .woocommerce-form label,.woocommerce-account form label{display:block;font-size:.82rem;font-weight:600;color:#1A1A1A;margin-bottom:.4rem}
.woocommerce-account .woocommerce-Input,
.woocommerce-account input[type=text],
.woocommerce-account input[type=email],
.woocommerce-account input[type=password],
.woocommerce-account input[type=tel],
.woocommerce-account select,
.woocommerce-account textarea{width:100%;padding:.875rem 1rem;border:2px solid #E5E7EB;border-radius:.75rem;font-family:Poppins,sans-serif;font-size:.95rem;color:#1A1A1A;background:#fff;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;-webkit-appearance:none;appearance:none}
.woocommerce-account .woocommerce-Input:focus,
.woocommerce-account input[type=text]:focus,
.woocommerce-account input[type=email]:focus,
.woocommerce-account input[type=password]:focus,
.woocommerce-account select:focus,
.woocommerce-account textarea:focus{border-color:#5B7C3F;outline:none;box-shadow:0 0 0 3px rgba(91,124,63,.12)}
/* Buttons */
.woocommerce-account .button,
.woocommerce-account button[type=submit],
.woocommerce-account input[type=submit]{background:#5B7C3F;color:#fff;border:none;border-radius:9999px;padding:.875rem 2rem;font-family:Poppins,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .22s,transform .22s;text-decoration:none;display:inline-block}
.woocommerce-account .button:hover,
.woocommerce-account button[type=submit]:hover,
.woocommerce-account input[type=submit]:hover{background:#4A6833;color:#fff;transform:translateY(-1px)}
.woocommerce-account .button.small,.woocommerce-account a.button.small{padding:.5rem 1.25rem;font-size:.8rem}
/* Orders table */
.woocommerce-account table.woocommerce-orders-table,
.woocommerce-account table.shop_table{width:100%;border-collapse:collapse;font-size:.875rem}
.woocommerce-account table.woocommerce-orders-table thead th,
.woocommerce-account table.shop_table thead th{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#6B7280;border-bottom:2px solid #E5E7EB;padding:.75rem 1rem;text-align:left;white-space:nowrap}
.woocommerce-account table.woocommerce-orders-table tbody td,
.woocommerce-account table.shop_table tbody td{padding:.875rem 1rem;border-bottom:1px solid #F3F4F6;color:#3D3D3D;vertical-align:middle}
.woocommerce-account table.woocommerce-orders-table tbody tr:last-child td,
.woocommerce-account table.shop_table tbody tr:last-child td{border-bottom:none}
.woocommerce-account table.woocommerce-orders-table tbody tr:hover td,
.woocommerce-account table.shop_table tbody tr:hover td{background:#FAFAF9}
/* Order status badges */
.woocommerce-account mark.order-status{background:none;font-weight:600;font-size:.78rem;padding:.3rem .75rem;border-radius:9999px;display:inline-block}
.woocommerce-account mark.order-status.status-completed{background:#DCFCE7;color:#15803D}
.woocommerce-account mark.order-status.status-processing{background:#DBEAFE;color:#1D4ED8}
.woocommerce-account mark.order-status.status-pending{background:#FEF9C3;color:#A16207}
.woocommerce-account mark.order-status.status-on-hold{background:#FEF3C7;color:#B45309}
.woocommerce-account mark.order-status.status-cancelled,
.woocommerce-account mark.order-status.status-failed,
.woocommerce-account mark.order-status.status-refunded{background:#FEE2E2;color:#B91C1C}
/* ── Address page: override WooCommerce float-based layout ── */
/* Kill WC floats on the addresses wrapper */
.woocommerce-account .woocommerce-Addresses,
.woocommerce-account .u-columns{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:1.5rem !important;
  width:100% !important;
  float:none !important;
  overflow:visible !important;
}
/* Kill WC floats on individual address columns */
.woocommerce-account .woocommerce-Address,
.woocommerce-account .u-column1,
.woocommerce-account .u-column2{
  float:none !important;
  width:100% !important;
  background:#fff;
  border:1px solid #E5E7EB;
  border-radius:1.25rem;
  padding:1.5rem;
  box-sizing:border-box;
}
/* Clearfix removal — not needed with grid */
.woocommerce-account .woocommerce-Addresses::before,
.woocommerce-account .woocommerce-Addresses::after,
.woocommerce-account .u-columns::before,
.woocommerce-account .u-columns::after{
  display:none !important;
  content:none !important;
}
.woocommerce-account .woocommerce-Address-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:1rem;
  padding-bottom:.75rem;
  border-bottom:1px solid #F3F4F6;
}
.woocommerce-account .woocommerce-Address-title h3{font-size:1rem;font-weight:700;color:#1A1A1A;margin:0}
.woocommerce-account .woocommerce-Address-title a{font-size:.8rem;font-weight:600;color:#5B7C3F;text-decoration:none}
.woocommerce-account .woocommerce-Address-title a:hover{color:#4A6833;text-decoration:underline}
/* Address text inside the card */
.woocommerce-account address{
  background:#F9FAF7;
  border:1px solid #E5E7EB;
  border-radius:1rem;
  padding:1.25rem 1.5rem;
  font-size:.9rem;
  color:#3D3D3D;
  line-height:1.75;
  font-style:normal;
}
.woocommerce-account .woocommerce-Address address,
.woocommerce-account .u-column1 address,
.woocommerce-account .u-column2 address{
  border:none;
  background:transparent;
  padding:0;
  border-radius:0;
}
/* Edit account fieldset */
.woocommerce-account .woocommerce-EditAccountForm fieldset{border:1px solid #E5E7EB;border-radius:1rem;padding:1.25rem 1.5rem;margin:1.5rem 0}
.woocommerce-account .woocommerce-EditAccountForm fieldset legend{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#6B7280;padding:0 .5rem}
/* Login/register two-col — overridden above in address section, keep min-width only */
.woocommerce-account .u-column1,.woocommerce-account .u-column2{min-width:0}
/* Empty states */
.woocommerce-account .woocommerce-orders-table__empty{text-align:center;padding:3rem 1.5rem;background:#F9FAF7;border-radius:1.25rem;color:#6B7280;font-size:.95rem}
/* Links */
.woocommerce-account .lost_password a,.woocommerce-account .woocommerce-LostPassword a{font-size:.82rem;color:#5B7C3F;text-decoration:none;font-weight:500}
.woocommerce-account .lost_password a:hover,.woocommerce-account .woocommerce-LostPassword a:hover{text-decoration:underline}
/* Checkbox row */
.woocommerce-account .woocommerce-form__label-for-checkbox{display:flex!important;align-items:center;gap:.5rem;font-size:.875rem;font-weight:400!important;color:#4B5563;cursor:pointer}
.woocommerce-account .woocommerce-form__input-checkbox{width:1rem!important;height:1rem!important;accent-color:#5B7C3F;flex-shrink:0}
/* Form rows */
.woocommerce-account .form-row{margin-bottom:1.1rem}
.woocommerce-account .form-row-first,.woocommerce-account .form-row-last{display:inline-block;width:calc(50% - .5rem);vertical-align:top}
.woocommerce-account .form-row-first{margin-right:.5rem}
.woocommerce-account .required{color:#EF4444}
/* Order detail */
.woocommerce-account .woocommerce-order-details,.woocommerce-account .woocommerce-customer-details{margin-top:1.5rem}
.woocommerce-account .woocommerce-order-details h2,.woocommerce-account .woocommerce-customer-details h2{font-size:1.1rem;font-weight:700;color:#1A1A1A;margin-bottom:1rem;padding-bottom:.625rem;border-bottom:2px solid #E5E7EB}
/* Responsive */
@media(max-width:900px){
  .woocommerce-account .woocommerce{flex-direction:column !important;gap:1.25rem}
  .woocommerce-MyAccount-navigation{flex:none !important;width:100% !important;max-width:100% !important}
  .woocommerce-MyAccount-navigation ul{display:flex;flex-wrap:wrap;gap:.25rem;padding:.5rem}
  .woocommerce-MyAccount-navigation ul li{border-bottom:none}
  .woocommerce-MyAccount-navigation ul li a{border-radius:.625rem;padding:.5rem .875rem;font-size:.8rem}
  .woocommerce-MyAccount-navigation ul li.is-active a,.woocommerce-MyAccount-navigation ul li a:hover{padding-left:.875rem}
  .woocommerce-account .woocommerce-Addresses,
  .woocommerce-account .u-columns{grid-template-columns:1fr !important}
  .woocommerce-account .woocommerce-Address,
  .woocommerce-account .u-column1,
  .woocommerce-account .u-column2{width:100% !important}
}
@media(max-width:640px){
  .woocommerce-account .woocommerce-form,
  .woocommerce-account form.edit-account,
  .woocommerce-account form.lost_reset_password,
  .woocommerce-account form.register,
  .woocommerce-account form.login{padding:1.25rem}
  .woocommerce-account .form-row-first,.woocommerce-account .form-row-last{display:block;width:100%;margin-right:0}
  .woocommerce-account table.woocommerce-orders-table thead{display:none}
  .woocommerce-account table.woocommerce-orders-table tbody td{display:flex;justify-content:space-between;align-items:center;padding:.625rem 1rem;border-bottom:none}
  .woocommerce-account table.woocommerce-orders-table tbody tr{display:block;border:1px solid #E5E7EB;border-radius:1rem;margin-bottom:1rem;overflow:hidden}
  .woocommerce-account table.woocommerce-orders-table tbody td::before{content:attr(data-title);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#6B7280}
}
/* ================================================================
   END MY ACCOUNT STYLES
================================================================ */