/*
Theme Name:  Farmsala v2
Theme URI:   https://farmsala.com
Author:      Farmsala Dev Team
Description: Premium Natural Seeds & Dry Fruits — Redesigned D2C WooCommerce Theme
Version:     2.0.0
Text Domain: farmsala
Tags:        woocommerce, e-commerce, natural, organic, d2c, premium
*/

/* ═══════════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════════ */
:root {
  /* Brand Colors */
  --green-dark:    #005B1B;
  --green-fresh:   #45B000;
  --green-mid:     #1a7a2e;
  --cream:         #FAF8EF;
  --cream-dark:    #F2EFE3;
  --green-tint:    #EEF8E8;
  --beige:         #D8B56D;
  --charcoal:      #1F2A1F;
  --border:        #E3E8DD;
  --white:         #FFFFFF;

  /* Extended palette */
  --green-light-bg: #F0F9EC;
  --text-muted:    #5a6e5a;
  --text-light:    #8a9e8a;
  --gold:          #C9A227;
  --red-sale:      #D72638;
  --shadow-sm:     0 2px 12px rgba(0,91,27,0.07);
  --shadow-md:     0 6px 28px rgba(0,91,27,0.10);
  --shadow-lg:     0 16px 56px rgba(0,91,27,0.13);
  --radius-sm:     10px;
  --radius-md:     18px;
  --radius-lg:     28px;
  --radius-xl:     40px;
  --transition:    all 0.3s cubic-bezier(0.4,0,0.2,1);
}

/* ═══════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Poppins', sans-serif;
  background: var(--cream);
  color: var(--charcoal);
  overflow-x: hidden;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a  { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; }
input, select, textarea { font-family: inherit; }

/* ═══════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════ */
h1,h2,h3,h4,h5 {
  font-family: 'Playfair Display', serif;
  line-height: 1.2;
  color: var(--charcoal);
  font-weight: 700;
}
h1 { font-size: clamp(2.2rem, 5vw, 4rem); }
h2 { font-size: clamp(1.7rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); }
h4 { font-size: 1.1rem; }
p  { font-size: 0.95rem; color: var(--text-muted); line-height: 1.75; }

/* ═══════════════════════════════════════════
   LAYOUT UTILITIES
═══════════════════════════════════════════ */
.container {
  width: 92%;
  max-width: 1320px;
  margin: 0 auto;
}
.section-pad  { padding: 80px 0; }
.section-pad-sm { padding: 56px 0; }
.text-center  { text-align: center; }
.flex-center  { display: flex; align-items: center; justify-content: center; }

.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green-fresh);
  background: var(--green-tint);
  padding: 5px 14px;
  border-radius: 50px;
  margin-bottom: 12px;
  border: 1px solid var(--border);
}
.section-eyebrow::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--green-fresh);
  border-radius: 50%;
}

.section-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  font-weight: 800;
  color: var(--charcoal);
  line-height: 1.2;
  margin-bottom: 12px;
}
.section-subtitle {
  font-size: 0.95rem;
  color: var(--text-muted);
  line-height: 1.75;
  max-width: 560px;
}
.text-center .section-subtitle { margin: 0 auto; }

/* ═══════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 30px;
  border-radius: 50px;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  transition: var(--transition);
  border: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
}
.btn-primary {
  background: var(--green-dark);
  color: var(--white);
  border-color: var(--green-dark);
  box-shadow: 0 4px 18px rgba(0,91,27,0.22);
}
.btn-primary:hover {
  background: var(--green-mid);
  border-color: var(--green-mid);
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0,91,27,0.30);
}
.btn-secondary {
  background: transparent;
  color: var(--green-dark);
  border-color: var(--green-dark);
}
.btn-secondary:hover {
  background: var(--green-dark);
  color: var(--white);
  transform: translateY(-2px);
}
.btn-cream {
  background: var(--white);
  color: var(--green-dark);
  border-color: var(--white);
  box-shadow: 0 4px 18px rgba(0,0,0,0.12);
}
.btn-cream:hover {
  background: var(--green-tint);
  transform: translateY(-2px);
}
.btn-sm { padding: 9px 20px; font-size: 0.82rem; }
.btn-lg { padding: 16px 40px; font-size: 0.95rem; }
.btn-full { width: 100%; }

/* ═══════════════════════════════════════════
   ANNOUNCEMENT BAR
═══════════════════════════════════════════ */
@keyframes announcement-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.announcement-bar {
  background: var(--green-dark);
  color: rgba(255,255,255,0.92);
  padding: 9px 0;
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  overflow: hidden;
  white-space: nowrap;
}

.announcement-track {
  display: inline-flex;
  animation: announcement-scroll 22s linear infinite;
}

.announcement-bar:hover .announcement-track {
  animation-play-state: paused;
}

.announcement-item {
  display: inline-block;
  padding: 0 48px;
  position: relative;
}

.announcement-item::after {
  content: '✦';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.55rem;
  opacity: 0.5;
}

.announcement-bar strong { color: var(--beige); }

/* ═══════════════════════════════════════════
   HEADER
═══════════════════════════════════════════ */
#site-header {
  position: sticky;
  top: 0;
  z-index: 900;
  background: rgba(250,248,239,0.97);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow 0.3s;
}
#site-header.scrolled {
  box-shadow: 0 4px 20px rgba(0,91,27,0.10);
}

.header-inner {
  display: flex;
  align-items: center;
  gap: 32px;
  padding: 0;
}

/* Logo */
.site-logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.site-logo .logo-img {
  height: 110px;
  width: auto;
  display: block;
}
.logo-text {
  font-family: 'Playfair Display', serif;
  font-size: 4.16rem;
  font-weight: 900;
  color: var(--green-dark);
  line-height: 1;
}
.logo-text span { color: var(--green-fresh); }
.logo-tagline {
  font-size: 0.62rem;
  color: var(--text-muted);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: 2px;
}

/* Primary nav */
.primary-nav { display: flex; align-items: center; gap: 4px; margin-left: auto; }
.primary-nav > li { position: relative; }
.primary-nav > li > a {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--charcoal);
  border-radius: var(--radius-sm);
  transition: var(--transition);
}
.primary-nav > li > a:hover,
.primary-nav > li.current-menu-item > a {
  color: var(--green-dark);
  background: var(--green-tint);
}
.primary-nav .has-dropdown > a::after {
  content: '▾';
  font-size: 0.7rem;
  margin-left: 2px;
  transition: transform 0.2s;
}
.primary-nav .has-dropdown:hover > a::after { transform: rotate(180deg); }

/* Dropdown */
.nav-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 10px;
  min-width: 200px;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: var(--transition);
  z-index: 100;
}
.primary-nav .has-dropdown:hover .nav-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.nav-dropdown a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--charcoal);
  border-radius: var(--radius-sm);
  transition: var(--transition);
}
.nav-dropdown a:hover { background: var(--green-tint); color: var(--green-dark); }
.nav-dropdown .cat-icon,
.drawer-nav .cat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 38px; height: 38px;
  border-radius: 50%;
  overflow: hidden;
  background: none;
  border: none;
}
.nav-dropdown .cat-icon img,
.drawer-nav .cat-icon img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
  transition: transform 0.3s ease;
}
.nav-dropdown a:hover .cat-icon img,
.drawer-nav a:hover .cat-icon img {
  transform: scale(1.1);
}

/* Header actions */
.header-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: 12px;
}
.nav-icon {
  display: block;
  transition: transform 0.32s cubic-bezier(0.34, 1.56, 0.64, 1);
  flex-shrink: 0;
}
.header-icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border-radius: 12px;
  background: transparent;
  border: 1.5px solid transparent;
  color: var(--charcoal);
  cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
  position: relative;
  text-decoration: none;
}
.header-icon-btn:hover {
  background: var(--green-tint);
  border-color: rgba(69,176,0,0.18);
  color: var(--green-dark);
  box-shadow: 0 3px 14px rgba(69,176,0,0.11);
}
.header-icon-btn:hover .nav-icon {
  transform: scale(1.12);
}

/* Wishlist — heart fills with warm blush on hover, leaf turns green */
.header-icon-wishlist .heart-body {
  fill: transparent;
  transition: fill 0.32s ease, stroke 0.32s ease;
}
.header-icon-wishlist:hover .heart-body {
  fill: rgba(215,38,56,0.08);
  stroke: var(--red-sale);
}
.header-icon-wishlist .heart-leaf {
  opacity: 0.42;
  transition: fill 0.32s ease, opacity 0.32s ease;
}
.header-icon-wishlist:hover .heart-leaf {
  fill: var(--green-fresh);
  opacity: 0.85;
}

/* Cart — basket bobs upward on hover */
.header-icon-cart:hover .nav-icon {
  animation: nav-cart-bob 0.42s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
@keyframes nav-cart-bob {
  0%   { transform: scale(1) translateY(0); }
  45%  { transform: scale(1.15) translateY(-2.5px); }
  100% { transform: scale(1.12) translateY(0); }
}

/* Cart count badge */
.header-badge {
  position: absolute;
  top: 3px; right: 3px;
  min-width: 16px; height: 16px;
  background: var(--green-fresh);
  color: var(--white);
  font-size: 0.58rem;
  font-weight: 700;
  line-height: 1;
  border-radius: 8px;
  padding: 0 3.5px;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--cream);
  letter-spacing: -0.02em;
}

/* Account — leaf accent brightens on hover */
.header-icon-account .account-leaf {
  transition: opacity 0.3s ease;
}
.header-icon-account:hover .account-leaf {
  opacity: 0.72;
}

/* Search bar */
.header-search-wrap {
  position: relative;
  flex: 1;
  max-width: 320px;
}
.header-search-wrap input {
  width: 100%;
  padding: 9px 16px 9px 38px;
  border: 1.5px solid var(--border);
  border-radius: 50px;
  background: var(--white);
  font-size: 0.83rem;
  color: var(--charcoal);
  outline: none;
  transition: var(--transition);
}
.header-search-wrap input:focus { border-color: var(--green-fresh); }
.header-search-wrap .search-icon {
  position: absolute;
  left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--text-muted); font-size: 0.85rem; pointer-events: none;
}
.search-suggestions {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: auto;
  min-width: 440px;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0,0,0,0.10);
  list-style: none;
  margin: 0; padding: 6px 0;
  z-index: 1100;
  max-height: 360px;
  overflow-y: auto;
}
.search-suggestions.open { display: block; }
.search-suggestions li { margin: 0; padding: 0; }
.search-suggestion-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  text-decoration: none;
  color: var(--charcoal);
  transition: background 0.15s;
  cursor: pointer;
}
.search-suggestion-item:hover { background: var(--cream); }
.search-suggestion-item img {
  width: 36px; height: 36px;
  object-fit: cover;
  border-radius: 6px;
  flex-shrink: 0;
  border: 1px solid var(--border);
  background: var(--cream);
}
.search-suggestion-name {
  font-size: 0.85rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--charcoal);
}
.search-no-results {
  padding: 10px 16px;
  font-size: 0.85rem;
  color: var(--text-muted);
}

/* Hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: 6px;
  cursor: pointer;
}
.hamburger span {
  display: block;
  width: 22px; height: 2px;
  background: var(--charcoal);
  border-radius: 2px;
  transition: var(--transition);
}

/* Mobile Drawer */
.mobile-drawer {
  position: fixed;
  top: 0; right: -100%;
  width: min(320px, 85vw);
  height: 100vh;
  background: var(--white);
  z-index: 1000;
  box-shadow: -8px 0 40px rgba(0,0,0,0.15);
  transition: right 0.35s cubic-bezier(0.4,0,0.2,1);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.mobile-drawer.open { right: 0; }
.drawer-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}
.drawer-overlay.show { opacity: 1; pointer-events: all; }
.drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
}
.drawer-close {
  background: none; border: none;
  font-size: 1.4rem; cursor: pointer; color: var(--charcoal);
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; transition: var(--transition);
}
.drawer-close:hover { background: var(--green-tint); }
.drawer-nav { padding: 16px 0; flex: 1; }
.drawer-nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 24px;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--charcoal);
  transition: var(--transition);
  border-left: 3px solid transparent;
}
.drawer-nav a:hover {
  background: var(--green-tint);
  color: var(--green-dark);
  border-left-color: var(--green-fresh);
}
.drawer-nav .drawer-sep {
  height: 1px;
  background: var(--border);
  margin: 8px 24px;
}

/* ═══════════════════════════════════════════
   HERO BANNER SLIDER
═══════════════════════════════════════════ */
.hbs-section {
  position: relative;
  overflow: hidden;
  width: 100%;
  background: var(--green-dark);
}
.hbs-track {
  display: flex;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}
.hbs-slide {
  min-width: 100%;
  height: 520px;
  background-size: cover;
  background-position: center;
  background-color: var(--green-dark);
  position: relative;
  display: flex;
  align-items: center;
}
.hbs-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.15) 60%, transparent 100%);
}
.hbs-content {
  position: relative;
  z-index: 1;
  max-width: 560px;
}
.hbs-heading {
  font-size: 2.6rem;
  font-weight: 800;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 14px;
  text-shadow: 0 2px 12px rgba(0,0,0,0.25);
}
.hbs-sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.88);
  margin-bottom: 28px;
  line-height: 1.6;
  text-shadow: 0 1px 6px rgba(0,0,0,0.2);
}
.hbs-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.18);
  border: none;
  color: #fff;
  font-size: 2.2rem;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  cursor: pointer;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
  transition: background 0.2s;
  line-height: 1;
}
.hbs-arrow:hover { background: rgba(255,255,255,0.35); }
.hbs-prev { left: 20px; }
.hbs-next { right: 20px; }
.hbs-dots {
  position: absolute;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}
.hbs-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.4);
  cursor: pointer;
  padding: 0;
  transition: background 0.2s, transform 0.2s;
}
.hbs-dot.active {
  background: #fff;
  transform: scale(1.25);
}
@media (max-width: 768px) {
  .hbs-slide { height: 320px; }
  .hbs-heading { font-size: 1.7rem; }
  .hbs-sub { font-size: 0.9rem; }
  .hbs-arrow { width: 36px; height: 36px; font-size: 1.6rem; }
}
@media (max-width: 480px) {
  .hbs-slide { height: 260px; }
  .hbs-heading { font-size: 1.35rem; }
  .hbs-prev { left: 10px; }
  .hbs-next { right: 10px; }
}

/* ═══════════════════════════════════════════
   HERO SECTION
═══════════════════════════════════════════ */
.hero-section {
  background: var(--cream);
  padding: 100px 0 100px;
  position: relative;
  overflow: hidden;
  min-height: 88vh;
  display: flex;
  align-items: center;
}
.hero-section::before {
  content: '';
  position: absolute;
  top: -180px; right: -180px;
  width: 680px; height: 680px;
  background: radial-gradient(circle, var(--green-tint) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}
.hero-section::after {
  content: '';
  position: absolute;
  bottom: -120px; left: -120px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(216,181,109,0.12) 0%, transparent 65%);
  border-radius: 50%;
  pointer-events: none;
}
.hero-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 2;
}
.hero-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 100%;
  max-width: 840px;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green-fresh);
  background: var(--green-tint);
  border: 1px solid var(--border);
  padding: 6px 16px;
  border-radius: 50px;
  margin-bottom: 20px;
}
.hero-eyebrow span {
  width: 6px; height: 6px;
  background: var(--green-fresh);
  border-radius: 50%;
  animation: blink 2s infinite;
}
@keyframes blink {
  0%,100%{opacity:1}
  50%{opacity:0.3}
}
.hero-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.8rem, 5.5vw, 5rem);
  font-weight: 900;
  color: var(--charcoal);
  line-height: 1.08;
  margin-bottom: 20px;
  letter-spacing: -0.02em;
  max-width: 820px;
}
.hero-title em {
  color: var(--green-fresh);
  font-style: normal;
}
.hero-subtitle {
  font-size: 1.05rem;
  color: var(--text-muted);
  line-height: 1.8;
  margin-bottom: 14px;
  max-width: 560px;
}
.hero-btns {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 40px;
  justify-content: center;
}
.hero-trust {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 24px;
  justify-content: center;
}
.trust-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--green-dark);
  background: var(--white);
  border: 1px solid var(--border);
  padding: 5px 14px;
  border-radius: 50px;
  box-shadow: var(--shadow-sm);
}
.trust-badge .icon { font-size: 0.9rem; }
.hero-fssai {
  font-size: 0.72rem;
  color: var(--text-muted);
  font-weight: 500;
}
.hero-fssai strong { color: var(--green-dark); }

/* Hero visual */
.hero-visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-img-main {
  width: 100%;
  max-width: 520px;
  aspect-ratio: 1;
  border-radius: 40% 60% 60% 40% / 50% 40% 60% 50%;
  background: var(--green-tint);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  position: relative;
}
.hero-img-main img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.hero-float-card {
  position: absolute;
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  box-shadow: var(--shadow-md);
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--charcoal);
  border: 1px solid var(--border);
  animation: float 4s ease-in-out infinite;
}
.hero-float-card:nth-child(2) { top: 8%; left: -10%; animation-delay: 0s; }
.hero-float-card:nth-child(3) { bottom: 15%; right: -5%; animation-delay: 1.5s; }
.hero-float-card .fc-icon { font-size: 1.5rem; }
@keyframes float {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-10px); }
}

/* ═══════════════════════════════════════════
   HERO CAROUSEL
══════════════════════════════════════════ */
.hero-carousel {
  position: relative;
  width: 100%;
  max-width: 280px;
  border-radius: 20px;
  overflow: hidden;
  background: var(--white);
  box-shadow: var(--shadow-lg);
}
.hc-track {
  display: flex;
  transition: transform 0.45s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.hc-slide {
  min-width: 100%;
  display: flex;
  flex-direction: column;
}
.hc-img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  background: var(--green-tint);
  overflow: hidden;
}
.hc-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.hc-img-placeholder {
  display: flex; align-items: center; justify-content: center;
  height: 100%; font-size: 5rem;
}
.hc-badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--red-sale); color: #fff;
  font-size: 0.7rem; font-weight: 700;
  padding: 3px 9px; border-radius: 20px;
}
.hc-info {
  padding: 18px 20px 20px;
  display: flex; flex-direction: column; gap: 8px;
}
.hc-name {
  font-size: 0.95rem; font-weight: 700;
  color: var(--charcoal); line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
  text-decoration: none;
}
.hc-name:hover { color: var(--green-dark); }
.hc-price-wrap { display: flex; align-items: baseline; gap: 8px; }
.hc-price { font-size: 1.15rem; font-weight: 800; color: var(--green-dark); }
.hc-mrp { font-size: 0.82rem; color: var(--text-muted); text-decoration: line-through; }
.hc-buy-btn { width: 100%; text-align: center; margin-top: 4px; padding: 11px; font-size: 0.9rem; }
.hc-arrow {
  position: absolute; top: 36%;
  background: var(--white); border: none;
  border-radius: 50%; width: 34px; height: 34px;
  font-size: 1.3rem; line-height: 1;
  box-shadow: var(--shadow-md); cursor: pointer;
  color: var(--green-dark); z-index: 2;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.2s;
}
.hc-arrow:hover { background: var(--green-tint); }
.hc-prev { left: 10px; }
.hc-next { right: 10px; }
.hc-dots {
  display: flex; justify-content: center; gap: 6px;
  padding: 10px 0 14px;
  background: var(--white);
}
.hc-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--border); border: none; cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}
.hc-dot.active { background: var(--green-dark); transform: scale(1.3); }

/* ═══════════════════════════════════════════
   CATEGORIES
═══════════════════════════════════════════ */
.categories-section { background: var(--white); padding: 80px 0; }
.categories-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  margin-top: 48px;
}
.cat-card {
  background: var(--cream);
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1.5px solid var(--border);
  transition: var(--transition);
  cursor: pointer;
  text-decoration: none;
  display: block;
  position: relative;
}
.cat-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--green-fresh);
}
.cat-card-img {
  height: 200px;
  overflow: hidden;
  background: #014422;
  display: flex; align-items: center; justify-content: center;
  font-size: 4rem;
  position: relative;
}
.cat-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease;
}
.cat-card:hover .cat-card-img img { transform: scale(1.07); }
.cat-card-img img.cat-img-multiply { mix-blend-mode: multiply; background: transparent; object-fit: contain; }
.cat-card-body { padding: 20px 20px 24px; }
.cat-card-name {
  font-family: 'Playfair Display', serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 6px;
}
.cat-card-desc { font-size: 0.92rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 14px; }
.cat-card-cta {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--green-dark);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: gap 0.2s;
}
.cat-card:hover .cat-card-cta { gap: 8px; }

/* ═══════════════════════════════════════════
   PRODUCT CARDS
═══════════════════════════════════════════ */
.products-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
.product-card {
  background: var(--white);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1.5px solid var(--border);
  transition: var(--transition);
  position: relative;
  display: flex;
  flex-direction: column;
}
.product-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
  border-color: var(--green-fresh);
}
.product-card-link {
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: var(--radius-md);
}
.product-wishlist-btn,
.product-footer { position: relative; z-index: 2; }
.product-img-wrap {
  position: relative;
  overflow: hidden;
  background: var(--cream);
  aspect-ratio: 1;
}
.product-img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.5s ease;
}
.product-card:hover .product-img-wrap img { transform: scale(1.18); }
.product-badge {
  position: absolute;
  top: 10px; left: 10px;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 50px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.badge-sale { background: var(--red-sale); color: var(--white); }
.badge-new  { background: var(--green-fresh); color: var(--white); }
.badge-best { background: var(--beige); color: var(--charcoal); }
.product-wishlist-btn {
  position: absolute;
  top: 10px; right: 10px;
  width: 34px; height: 34px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem; cursor: pointer;
  transition: var(--transition);
  box-shadow: var(--shadow-sm);
}
.product-wishlist-btn:hover { background: var(--red-sale); color: var(--white); border-color: var(--red-sale); }
.product-wishlist-btn.active { background: var(--red-sale); color: var(--white); border-color: var(--red-sale); }
.product-body { padding: 16px 16px 18px; flex: 1; display: flex; flex-direction: column; }
.product-cat {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--green-fresh);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 5px;
}
.product-name {
  font-family: 'Playfair Display', serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 6px;
  line-height: 1.35;
  flex: 1;
}
.product-name a { color: inherit; }
.product-name a:hover { color: var(--green-dark); }
.product-rating {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 10px;
}
.stars { color: #F5A623; font-size: 0.75rem; letter-spacing: 1px; }
.rating-count { font-size: 0.7rem; color: var(--text-light); }
.product-price-wrap {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 12px;
}
.product-price {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--green-dark);
}
.product-mrp {
  font-size: 0.78rem;
  color: var(--text-light);
  text-decoration: line-through;
}
.product-discount {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--red-sale);
  background: #FEF0F0;
  padding: 2px 7px;
  border-radius: 50px;
}
.product-variants {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.variant-btn {
  font-size: 0.7rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 50px;
  border: 1.5px solid var(--border);
  background: var(--cream);
  color: var(--text-muted);
  cursor: pointer;
  transition: var(--transition);
}
.variant-btn:hover, .variant-btn.active {
  border-color: var(--green-dark);
  color: var(--green-dark);
  background: var(--green-tint);
}
.product-footer {
  display: flex;
  gap: 8px;
  align-items: center;
}
.btn-atc {
  flex: 1;
  background: var(--green-dark);
  color: var(--white);
  border: none;
  padding: 10px 16px;
  border-radius: 50px;
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  text-align: center;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
.btn-atc:hover { background: var(--green-mid); transform: translateY(-1px); }

/* ═══════════════════════════════════════════
   BEST SELLERS SECTION
═══════════════════════════════════════════ */
.bestsellers-section { background: var(--cream); padding: 80px 0; }
.section-header-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 40px;
  gap: 20px;
  flex-wrap: wrap;
}
.view-all-link {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--green-dark);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border-bottom: 2px solid var(--green-tint);
  padding-bottom: 2px;
  transition: var(--transition);
  white-space: nowrap;
}
.view-all-link:hover { border-color: var(--green-dark); gap: 8px; }

/* ═══════════════════════════════════════════
   WHY CHOOSE SECTION
═══════════════════════════════════════════ */
.why-section {
  background: var(--green-dark);
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}
.why-section::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(69,176,0,0.12) 0%, transparent 60%);
  border-radius: 50%;
}
.why-section .section-eyebrow { background: rgba(255,255,255,0.1); color: #a5d6a7; border-color: rgba(255,255,255,0.15); }
.why-section .section-eyebrow::before { background: #a5d6a7; }
.why-section .section-title { color: var(--white); }
.why-section .section-subtitle { color: rgba(255,255,255,0.65); }
.why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 48px;
}
.why-card {
  background: linear-gradient(150deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.10) 100%);
  border: 1.5px solid rgba(255,255,255,0.30);
  border-top: 3px solid var(--green-fresh);
  border-radius: var(--radius-md);
  padding: 32px 24px 28px;
  transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
  text-align: center;
  box-shadow: 0 4px 20px rgba(0,0,0,0.25);
}
.why-card:hover {
  background: linear-gradient(150deg, rgba(255,255,255,0.26) 0%, rgba(255,255,255,0.15) 100%);
  transform: translateY(-6px);
  border-top-color: var(--green-fresh);
  border-color: rgba(255,255,255,0.50);
  box-shadow: 0 16px 40px rgba(0,0,0,0.35);
}
.why-icon {
  width: 64px; height: 64px;
  background: rgba(69,176,0,0.38);
  border: 1.5px solid rgba(165,214,167,0.40);
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
  color: #c8e6c9;
  transition: background 0.3s ease, transform 0.3s ease, color 0.3s ease;
}
.why-icon svg { width: 28px; height: 28px; display: block; }
.why-card:hover .why-icon {
  background: rgba(69,176,0,0.55);
  transform: scale(1.1);
  color: #ffffff;
}
.why-title { font-size: 1.02rem; font-weight: 700; color: var(--white); margin-bottom: 10px; line-height: 1.3; }
.why-desc  { font-size: 0.84rem; color: rgba(255,255,255,0.82); line-height: 1.7; }

/* ═══════════════════════════════════════════
   BRAND STORY SECTION
═══════════════════════════════════════════ */
.brand-story-section { background: var(--white); padding: 80px 0; }
.brand-story-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
.brand-story-img {
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  background: var(--green-tint);
  min-height: 460px;
  display: flex; align-items: center; justify-content: center;
  font-size: 8rem;
}
.brand-story-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.brand-story-badge {
  position: absolute;
  bottom: 24px; left: 24px;
  background: var(--green-dark);
  color: var(--white);
  border-radius: var(--radius-md);
  padding: 14px 20px;
  font-size: 0.82rem;
}
.brand-story-badge strong { display: block; font-size: 1.6rem; font-family: 'Playfair Display', serif; }
.brand-story-text .section-subtitle { max-width: 100%; margin-bottom: 24px; }
.brand-story-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 28px;
}
.brand-list-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--charcoal);
}
.brand-list-item::before {
  content: '✓';
  width: 20px; height: 20px;
  background: var(--green-tint);
  color: var(--green-dark);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.7rem; font-weight: 900;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════
   WELLNESS BANNER
═══════════════════════════════════════════ */
.wellness-banner {
  background: linear-gradient(135deg, var(--green-dark) 0%, #003d10 100%);
  padding: 70px 0;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.wellness-banner::before {
  content: '';
  position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2345B000' fill-opacity='0.05'%3E%3Ccircle cx='30' cy='30' r='3'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.wellness-banner-inner { position: relative; z-index: 2; max-width: 700px; margin: 0 auto; }
.wellness-banner h2 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.7rem, 4vw, 2.8rem);
  font-weight: 900;
  color: var(--white);
  margin-bottom: 14px;
}
.wellness-banner p { color: rgba(255,255,255,0.7); font-size: 0.95rem; margin-bottom: 32px; }

/* ═══════════════════════════════════════════
   REVIEWS SECTION
═══════════════════════════════════════════ */
.reviews-section { background: var(--cream); padding: 80px 0; }
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 48px;
}
.review-card {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 28px;
  border: 1.5px solid var(--border);
  box-shadow: var(--shadow-sm);
  position: relative;
  transition: var(--transition);
}
.review-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--green-fresh); }
.review-card::before {
  content: '\201C';
  position: absolute;
  top: 14px; right: 22px;
  font-family: 'Playfair Display', serif;
  font-size: 5rem;
  color: var(--green-tint);
  line-height: 1;
  pointer-events: none;
}
.review-stars { color: #F5A623; font-size: 0.85rem; margin-bottom: 8px; letter-spacing: 2px; }
.review-title { font-weight: 700; font-size: 0.92rem; color: var(--charcoal); margin-bottom: 8px; }
.review-text { font-size: 0.85rem; color: var(--text-muted); line-height: 1.7; margin-bottom: 18px; }
.review-author { display: flex; align-items: center; gap: 10px; }
.reviewer-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--green-tint);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 1rem; color: var(--green-dark);
  flex-shrink: 0; overflow: hidden;
}
.reviewer-avatar img { width: 100%; height: 100%; object-fit: cover; }
.reviewer-name { font-weight: 700; font-size: 0.82rem; color: var(--charcoal); }
.reviewer-loc  { font-size: 0.72rem; color: var(--text-light); }
.reviewer-verified { font-size: 0.68rem; color: var(--green-fresh); font-weight: 600; }

/* ═══════════════════════════════════════════
   FAQ SECTION
═══════════════════════════════════════════ */
.faq-section { background: var(--white); padding: 80px 0; }
.faq-list { max-width: 780px; margin: 48px auto 0; display: flex; flex-direction: column; gap: 12px; }
.faq-item {
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: var(--transition);
}
.faq-item.open { border-color: var(--green-fresh); box-shadow: var(--shadow-sm); }
.faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--charcoal);
  background: var(--white);
  transition: var(--transition);
  gap: 12px;
  user-select: none;
}
.faq-item.open .faq-q { background: var(--green-tint); color: var(--green-dark); }
.faq-arrow {
  font-size: 0.75rem;
  transition: transform 0.3s;
  flex-shrink: 0;
  color: var(--text-muted);
}
.faq-item.open .faq-arrow { transform: rotate(180deg); color: var(--green-dark); }
.faq-a {
  display: none;
  padding: 0 22px 18px;
  font-size: 0.87rem;
  color: var(--text-muted);
  line-height: 1.75;
  background: var(--green-tint);
}
.faq-item.open .faq-a { display: block; }

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
#site-footer {
  background: #0d2b13;
  color: rgba(255,255,255,0.80);
  padding: 64px 0 28px;
  /* prevent any child elements from accidentally showing white backgrounds */
  isolation: isolate;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1.2fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 48px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,0.14);
}
.footer-brand .logo-img {
  filter: invert(1) brightness(4) saturate(0);
  opacity: 0.95;
  max-width: 200px;
  width: 100%;
  height: auto;
  display: block;
  background: transparent;
}
.footer-brand .site-logo { background: transparent; }
.footer-brand .logo-text { color: var(--white); font-size: 2.4rem; }
.footer-brand .logo-text span { color: var(--green-fresh); }
.footer-brand p { font-size: 0.83rem; line-height: 1.7; margin-top: 14px; max-width: 260px; color: rgba(255,255,255,0.88); }
.footer-business { margin-top: 20px; }
.footer-business li { font-size: 0.78rem; line-height: 1.9; color: rgba(255,255,255,0.82); }
.footer-business li strong { color: var(--white); }
.footer-fssai {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--beige);
  background: rgba(216,181,109,0.12);
  border: 1px solid rgba(216,181,109,0.2);
  padding: 5px 12px;
  border-radius: 50px;
  margin-top: 12px;
}
.footer-col h4 {
  font-family: 'Poppins', sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 18px;
}
.footer-col ul { display: flex; flex-direction: column; gap: 8px; }
.footer-col ul li a {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.75);
  transition: color 0.2s;
  display: inline-flex; align-items: center; gap: 5px;
}
.footer-col ul li a:hover { color: var(--green-fresh); }
.footer-social { display: flex; gap: 10px; margin-top: 4px; }
.social-icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.95rem;
  text-decoration: none;
  color: rgba(255,255,255,0.6);
  transition: var(--transition);
}
.social-icon:hover { background: var(--green-dark); color: var(--white); transform: translateY(-2px); }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.75rem;
  gap: 16px;
  flex-wrap: wrap;
}
.footer-bottom a { color: rgba(255,255,255,0.55); transition: color 0.2s; }
.footer-bottom a:hover { color: var(--green-fresh); }
.footer-bottom-links { display: flex; gap: 20px; }
.footer-credit {
  text-align: center;
  padding: 12px 0 4px;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.4);
  border-top: 1px solid rgba(255,255,255,0.08);
  margin-top: 12px;
}
.footer-credit a { color: rgba(255,255,255,0.6); text-decoration: none; transition: color 0.2s; }
.footer-credit a:hover { color: var(--green-fresh); }

/* ═══════════════════════════════════════════
   SHOP / ARCHIVE PAGE
═══════════════════════════════════════════ */
.shop-banner {
  background: linear-gradient(rgba(0,30,8,0.62), rgba(0,30,8,0.62)),
              url('assets/images/category-banner.jpg') center/cover no-repeat;
  padding: 80px 0 48px;
  position: relative;
  overflow: hidden;
}
.shop-banner::after {
  content: ''; position: absolute; bottom: -30px; left: 0; right: 0;
  height: 60px;
  background: var(--cream);
  clip-path: ellipse(55% 100% at 50% 100%);
}
.shop-banner h1 { color: var(--white); font-size: clamp(1.8rem,4vw,3rem); }
.shop-banner p { color: rgba(255,255,255,0.7); margin-top: 8px; }
.woocommerce-breadcrumb { color: rgba(255,255,255,0.45); font-size: 0.78rem; margin-bottom: 12px; }
.woocommerce-breadcrumb a { color: rgba(255,255,255,0.6); }

.shop-body { background: var(--cream); padding: 48px 0 80px; }
.shop-layout { display: grid; grid-template-columns: 260px 1fr; gap: 32px; align-items: start; }
.shop-sidebar { position: sticky; top: 90px; }
.sidebar-card {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 22px;
  border: 1.5px solid var(--border);
  margin-bottom: 18px;
}
.sidebar-card h4 {
  font-family: 'Playfair Display', serif;
  font-size: 0.95rem; font-weight: 700; color: var(--charcoal);
  margin-bottom: 16px; padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.cat-filter-list { display: flex; flex-direction: column; gap: 4px; }
.cat-filter-list a {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 12px; border-radius: var(--radius-sm);
  font-size: 0.85rem; font-weight: 500;
  color: var(--text-muted); text-decoration: none;
  transition: var(--transition);
}
.cat-filter-list a:hover,
.cat-filter-list a.active { background: var(--green-tint); color: var(--green-dark); font-weight: 600; }
.cat-filter-list span { font-size: 0.72rem; color: var(--text-light); }

.shop-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 24px; flex-wrap: wrap; gap: 12px;
}
.woocommerce-result-count { font-size: 0.83rem; color: var(--text-muted); }
.woocommerce-ordering select {
  border: 1.5px solid var(--border); border-radius: 50px;
  padding: 8px 16px; font-family: 'Poppins', sans-serif;
  font-size: 0.83rem; color: var(--charcoal); outline: none;
  background: var(--white); cursor: pointer;
}

/* WC product loop override */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
  margin: 0 !important; padding: 0 !important; list-style: none !important;
}
.woocommerce ul.products li.product { margin: 0 !important; }

/* Pagination */
.woocommerce-pagination { margin-top: 40px; text-align: center; }
.woocommerce-pagination ul { display: inline-flex; gap: 6px; list-style: none; }
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%;
  font-size: 0.85rem; font-weight: 600;
  border: 1.5px solid var(--border); color: var(--text-muted);
  text-decoration: none; transition: var(--transition);
}
.woocommerce-pagination ul li a:hover,
.woocommerce-pagination ul li span.current {
  background: var(--green-dark); color: var(--white); border-color: var(--green-dark);
}

/* ═══════════════════════════════════════════
   SINGLE PRODUCT PAGE
═══════════════════════════════════════════ */
.single-product-section { background: var(--cream); padding: 40px 0 80px; }
.product-breadcrumb { padding: 0 0 24px; }
.product-breadcrumb .woocommerce-breadcrumb { font-size: 0.78rem; color: var(--text-muted); }
.product-breadcrumb .woocommerce-breadcrumb a { color: var(--green-mid); }
.product-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }

/* Gallery */
.product-gallery { position: sticky; top: 90px; }
.gallery-main {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--white);
  aspect-ratio: 1;
  border: 1.5px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.gallery-main img { width: 100%; height: 100%; object-fit: cover; }
.gallery-badge {
  position: absolute; top: 14px; left: 14px;
  background: var(--red-sale); color: var(--white);
  font-size: 0.72rem; font-weight: 700; padding: 4px 10px; border-radius: 50px;
}
.gallery-thumbs { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.gallery-thumb {
  width: 68px; height: 68px; border-radius: var(--radius-sm);
  overflow: hidden; cursor: pointer;
  border: 2px solid transparent;
  background: var(--white);
  transition: var(--transition);
}
.gallery-thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery-thumb.active, .gallery-thumb:hover { border-color: var(--green-dark); }

/* Product info */
.product-info-col {}
.product-cats-label { font-size: 0.72rem; font-weight: 600; color: var(--green-fresh); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 8px; }
.product-title-single {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.6rem,3vw,2.2rem); font-weight: 900; color: var(--charcoal);
  margin-bottom: 12px; line-height: 1.2;
}
.product-rating-row { display: flex; align-items: center; gap: 8px; margin-bottom: 18px; }
.product-price-block {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 0 10px;
  border-top: 1px solid var(--border);
}
.product-price-meta {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.75rem; color: var(--text-muted);
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 18px;
}
.price-meta-sep { opacity: 0.4; }
.price-main { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 900; color: var(--green-dark); }
.price-mrp { font-size: 0.9rem; color: var(--text-light); text-decoration: line-through; }
.price-off {
  font-size: 0.78rem; font-weight: 700; color: var(--red-sale);
  background: #FEF0F0; padding: 3px 10px; border-radius: 50px;
}
.product-short-desc { font-size: 0.88rem; color: var(--text-muted); line-height: 1.8; margin-bottom: 22px; }
.product-variant-label { font-size: 0.78rem; font-weight: 700; color: var(--charcoal); margin-bottom: 8px; }
.product-actions {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 12px;
  align-items: center;
  margin: 22px 0;
}
/* Simple product: qty + button in a row */
.product-actions form.cart:not(.variations_form) {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 12px !important;
  flex: 1 !important;
}
/* Variable product: pills on top, qty + button below */
.product-actions .variations_form {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  width: 100% !important;
  gap: 0 !important;
}
.product-actions .variations_form .woocommerce-variation-add-to-cart,
.product-actions .variations_form .variations_button {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 12px !important;
  margin-top: 16px !important;
}
/* Hide stock quantity number */
p.stock, .stock { display: none !important; }
/* Quantity stepper wrapper */
.farmsala-qty {
  display: flex !important;
  align-items: center !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  background: var(--white) !important;
  overflow: hidden !important;
  height: 48px !important;
  flex-shrink: 0 !important;
}
/* ── Variable product — pill button variation form ── */
.farmsala-variations { margin-bottom: 20px; }
.variation-row { margin-bottom: 14px; }
.variation-label {
  display: block;
  font-size: 0.75rem; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.07em;
  margin-bottom: 10px;
}
.variation-pills {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.variation-pill {
  padding: 9px 20px;
  border: 1.5px solid var(--border);
  border-radius: 50px;
  background: var(--white);
  font-family: 'Poppins', sans-serif;
  font-size: 0.85rem; font-weight: 600;
  color: var(--charcoal);
  cursor: pointer;
  transition: all 0.18s ease;
  line-height: 1;
}
.variation-pill:hover {
  border-color: var(--green-fresh);
  color: var(--green-dark);
  background: var(--green-tint);
}
.variation-pill.active {
  background: var(--green-dark);
  border-color: var(--green-dark);
  color: var(--white);
}
/* Hide native select — kept for WC JS but not shown */
.variation-select-wrap { display: none; }
/* Hide duplicate WC variation price (we update the top price block via JS) */
.woocommerce-variation-price { display: none !important; }
.woocommerce-variation-availability .stock { display: none !important; }
.single_variation_wrap { margin-top: 4px; }
.reset_variations { display: none !important; }

/* +/- buttons */
.qty-btn {
  width: 38px !important;
  height: 100% !important;
  border: none !important;
  background: var(--cream) !important;
  color: var(--charcoal) !important;
  font-size: 1.2rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.qty-btn:hover { background: var(--green-tint) !important; color: var(--green-dark) !important; }
.qty-minus { border-right: 1.5px solid var(--border) !important; }
.qty-plus  { border-left:  1.5px solid var(--border) !important; }
/* Number input — no native arrows */
.farmsala-qty input.qty {
  border: none !important;
  width: 46px !important;
  text-align: center !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  padding: 0 !important;
  background: transparent !important;
  height: 100% !important;
  -moz-appearance: textfield !important;
  color: var(--charcoal) !important;
}
.farmsala-qty input.qty::-webkit-outer-spin-button,
.farmsala-qty input.qty::-webkit-inner-spin-button { -webkit-appearance: none !important; margin: 0 !important; }
.farmsala-qty input.qty:focus { outline: none !important; }
/* ATC button — fills remaining space */
.product-actions .single_add_to_cart_button,
.product-actions form.cart .single_add_to_cart_button {
  flex: 1 !important;
  height: 48px !important;
  padding: 0 24px !important;
  font-size: 0.92rem !important;
  border-radius: 50px !important;
  white-space: nowrap !important;
}
.btn-buynow {
  background: var(--beige);
  color: var(--charcoal);
  border: 2px solid var(--beige);
  padding: 12px 24px; border-radius: 50px;
  font-weight: 700; font-size: 0.85rem; cursor: pointer;
  transition: var(--transition); white-space: nowrap;
}
.btn-buynow:hover { background: var(--gold); border-color: var(--gold); transform: translateY(-1px); }
.product-trust-strip {
  display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 20px;
}
.product-trust-item {
  display: flex; align-items: center; gap: 5px;
  font-size: 0.72rem; font-weight: 600; color: var(--green-dark);
  background: var(--green-tint); border: 1px solid var(--border);
  padding: 5px 11px; border-radius: 50px;
}
.product-fssai {
  font-size: 0.72rem; color: var(--text-muted);
  background: var(--cream); padding: 8px 14px; border-radius: var(--radius-sm);
  border: 1px solid var(--border); margin-top: 4px;
}
.product-fssai strong { color: var(--green-dark); }

/* Product share */
.product-share-wrap {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
}
.product-share-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 50%;
  color: var(--charcoal);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,0.10);
  transition: var(--transition);
}
.product-share-btn:hover { border-color: var(--green-fresh); color: var(--green-fresh); }
.share-popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(0,0,0,0.10);
  padding: 6px 0;
  min-width: 160px;
  z-index: 200;
}
.share-popover[hidden] { display: none; }
.share-option {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 16px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--charcoal);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  transition: background 0.15s;
  white-space: nowrap;
}
.share-option:hover { background: var(--cream); }
.share-option svg { flex-shrink: 0; }
#shareWhatsapp { color: #25D366; }

/* Product Reviews Section */
.product-reviews-section {
  margin-top: 56px;
  padding-top: 48px;
  border-top: 1px solid var(--border);
}
.reviews-header { margin-bottom: 28px; }
.reviews-title { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 700; color: var(--green-dark); }

/* Summary */
.reviews-summary {
  display: flex;
  gap: 40px;
  align-items: flex-start;
  margin-bottom: 36px;
  padding: 24px 28px;
  background: var(--cream);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
}
.reviews-avg-block { text-align: center; min-width: 100px; }
.reviews-avg-score {
  font-family: 'Playfair Display', serif;
  font-size: 3rem; font-weight: 900;
  color: var(--green-dark); line-height: 1;
}
.reviews-avg-stars { display: flex; justify-content: center; gap: 2px; margin: 8px 0 6px; }
.reviews-avg-label { font-size: 0.78rem; color: var(--text-muted); }
.reviews-breakdown { flex: 1; display: flex; flex-direction: column; gap: 8px; }
.breakdown-row { display: flex; align-items: center; gap: 10px; font-size: 0.8rem; }
.breakdown-label { width: 36px; color: var(--text-muted); white-space: nowrap; text-align: right; }
.breakdown-bar-wrap {
  flex: 1; height: 8px;
  background: var(--border);
  border-radius: 99px; overflow: hidden;
}
.breakdown-bar-fill {
  height: 100%;
  background: var(--green-fresh);
  border-radius: 99px;
  transition: width 0.4s ease;
}
.breakdown-pct { width: 30px; color: var(--text-muted); font-size: 0.78rem; }

/* Stars */
.rev-star path { fill: #d1d5db; }
.rev-star.star-filled path { fill: #F59E0B; }

/* Review cards */
.reviews-list { display: flex; flex-direction: column; gap: 20px; margin-bottom: 40px; }
.review-card {
  padding: 20px 24px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--white);
}
.review-card-top {
  display: flex; align-items: center; gap: 12px; margin-bottom: 12px;
}
.review-author-avatar {
  width: 38px; height: 38px;
  background: var(--green-fresh);
  color: var(--white);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.95rem; font-weight: 700;
  flex-shrink: 0;
}
.review-author-info { flex: 1; }
.review-author-info strong { display: block; font-size: 0.9rem; color: var(--charcoal); }
.review-date { font-size: 0.75rem; color: var(--text-muted); }
.review-stars-display { display: flex; gap: 2px; }
.review-body { font-size: 0.85rem; color: var(--text-light); line-height: 1.7; margin: 0; }
.review-body p { margin: 0; }

/* Empty state */
.reviews-empty {
  text-align: center; padding: 40px 0;
  color: var(--text-muted); font-size: 0.9rem;
}
.reviews-empty-icon { font-size: 2.5rem; margin-bottom: 10px; }

/* Write a review */
.write-review-section {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 28px 32px;
}
.write-review-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem; font-weight: 700;
  color: var(--green-dark); margin-bottom: 20px;
}
.write-review-form .form-group { margin-bottom: 18px; }
.write-review-form label {
  display: block; font-size: 0.82rem; font-weight: 600;
  color: var(--charcoal); margin-bottom: 8px;
}
.req { color: var(--red-sale); }
.star-picker { display: flex; gap: 6px; }
.star-pick {
  background: none; border: none; padding: 0; cursor: pointer;
  color: #d1d5db; transition: color 0.15s, transform 0.1s;
}
.star-pick path { fill: #d1d5db; transition: fill 0.15s; }
.star-pick.active path,
.star-pick.hovered path { fill: #F59E0B; }
.star-pick:hover { transform: scale(1.15); }
.write-review-form textarea {
  width: 100%; padding: 12px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.85rem; color: var(--charcoal);
  resize: vertical; outline: none;
  transition: border-color 0.2s;
  font-family: inherit;
}
.write-review-form textarea:focus { border-color: var(--green-fresh); }
.btn-submit-review {
  background: var(--green-fresh); color: var(--white);
  border: none; border-radius: 50px;
  padding: 12px 28px; font-size: 0.9rem; font-weight: 600;
  cursor: pointer; transition: var(--transition);
}
.btn-submit-review:hover { background: var(--green-dark); }
.btn-submit-review:disabled { opacity: 0.6; cursor: not-allowed; }
.review-login-prompt {
  padding: 16px 20px;
  background: var(--cream);
  border-radius: var(--radius-sm);
  font-size: 0.87rem; color: var(--text-muted);
}
.review-login-prompt a { color: var(--green-fresh); font-weight: 500; }

/* Product Tabs */
.product-tabs-section { margin-top: 48px; }
.product-tabs-nav {
  display: flex; gap: 4px; border-bottom: 2px solid var(--border); margin-bottom: 28px; overflow-x: auto;
}
.tab-btn {
  padding: 11px 20px; font-size: 0.85rem; font-weight: 600;
  color: var(--text-muted); border: none; background: none; cursor: pointer;
  border-bottom: 3px solid transparent; margin-bottom: -2px;
  transition: var(--transition); white-space: nowrap;
}
.tab-btn.active { color: var(--green-dark); border-bottom-color: var(--green-dark); }
.tab-panel { display: none; font-size: 0.88rem; color: var(--text-muted); line-height: 1.8; }
.tab-panel.active { display: block; }
.tab-panel h4 { font-size: 0.95rem; font-weight: 700; color: var(--charcoal); margin-bottom: 10px; }
.tab-panel ul { padding-left: 18px; list-style: disc; display: flex; flex-direction: column; gap: 6px; }

/* ═══════════════════════════════════════════
   CART PAGE
═══════════════════════════════════════════ */
.cart-section { background: var(--cream); padding: 48px 0 80px; }
.cart-layout { display: grid; grid-template-columns: 1fr 380px; gap: 30px; align-items: start; }
.cart-box, .cart-summary-box {
  background: var(--white); border-radius: var(--radius-lg);
  padding: 28px; border: 1.5px solid var(--border); box-shadow: var(--shadow-sm);
}
.cart-box h3, .cart-summary-box h3 {
  font-size: 1.1rem; font-weight: 800; margin-bottom: 22px;
  padding-bottom: 14px; border-bottom: 1px solid var(--border);
}
.cart-items-table { width: 100%; border-collapse: collapse; }
.cart-items-table th {
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--text-light);
  padding: 0 0 14px; text-align: left; border-bottom: 1px solid var(--border);
}
.cart-items-table td { padding: 16px 0; border-bottom: 1px solid #f5f5f5; vertical-align: middle; }
.cart-product-cell { display: flex; align-items: center; gap: 14px; }
.cart-product-img {
  width: 68px; height: 68px; border-radius: var(--radius-sm);
  overflow: hidden; background: var(--green-tint); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 1.8rem;
}
.cart-product-img img { width: 100%; height: 100%; object-fit: cover; }
.cart-product-name { font-weight: 600; font-size: 0.88rem; color: var(--charcoal); }
.cart-product-variant { font-size: 0.75rem; color: var(--text-light); margin-top: 2px; }
.cart-price, .cart-subtotal {
  font-family: 'Playfair Display', serif; font-weight: 700;
  font-size: 0.95rem; color: var(--green-dark);
}
.cart-qty-input {
  border: 1.5px solid var(--border) !important; border-radius: var(--radius-sm) !important;
  width: 56px !important; text-align: center !important; padding: 7px !important;
  font-size: 0.88rem !important;
}
.cart-remove {
  width: 28px; height: 28px; border-radius: 50%; background: #FEF0F0;
  color: var(--red-sale); border: none; cursor: pointer; font-size: 0.8rem;
  display: flex; align-items: center; justify-content: center; transition: var(--transition);
}
.cart-remove:hover { background: var(--red-sale); color: var(--white); }
.cart-actions-row {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 18px; flex-wrap: wrap; gap: 12px;
}
.coupon-row { display: flex; gap: 10px; }
.coupon-input {
  border: 1.5px solid var(--border); border-radius: 50px;
  padding: 9px 16px; font-size: 0.85rem; outline: none;
  transition: border-color 0.2s; width: 200px;
}
.coupon-input:focus { border-color: var(--green-fresh); }
.cart-trust-strip {
  background: var(--green-tint); border-radius: var(--radius-sm);
  padding: 10px 16px; text-align: center;
  font-size: 0.75rem; font-weight: 600; color: var(--green-dark);
  margin-top: 16px; border: 1px solid var(--border);
}
.summary-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 0; border-bottom: 1px solid #f5f5f5;
  font-size: 0.88rem;
}
.summary-row:last-of-type { border-bottom: none; }
.summary-total {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 0 0; margin-top: 8px; border-top: 2px solid var(--border);
  font-family: 'Playfair Display', serif; font-size: 1.2rem; font-weight: 800; color: var(--green-dark);
}

/* ═══════════════════════════════════════════
   WISHLIST PAGE
═══════════════════════════════════════════ */
.wishlist-section { background: var(--cream); padding: 48px 0 80px; }
.wishlist-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; margin-top: 32px; }
.wishlist-empty {
  text-align: center; padding: 80px 20px;
  background: var(--white); border-radius: var(--radius-lg); border: 1.5px solid var(--border);
}
.wishlist-empty .empty-icon { font-size: 4rem; margin-bottom: 16px; }
.wishlist-empty h3 { margin-bottom: 10px; }
.wishlist-empty p { color: var(--text-muted); margin-bottom: 24px; }

/* ═══════════════════════════════════════════
   LOGIN / MY ACCOUNT
═══════════════════════════════════════════ */
.account-section { background: var(--cream); padding: 60px 0 80px; }
.account-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; max-width: 900px; margin: 0 auto; }
.account-card {
  background: var(--white); border-radius: var(--radius-lg); padding: 36px;
  border: 1.5px solid var(--border); box-shadow: var(--shadow-sm);
}
.account-card h3 { font-size: 1.3rem; margin-bottom: 8px; }
.account-card > p { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 24px; }
.form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.form-group label { font-size: 0.8rem; font-weight: 600; color: var(--charcoal); }
.form-group input, .form-group select {
  border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  padding: 11px 14px; font-family: 'Poppins',sans-serif; font-size: 0.87rem;
  color: var(--charcoal); outline: none; transition: var(--transition);
  background: var(--cream);
}
.form-group input:focus, .form-group select:focus {
  border-color: var(--green-fresh);
  box-shadow: 0 0 0 3px rgba(69,176,0,0.10);
  background: var(--white);
}
.form-helper { display: flex; justify-content: space-between; align-items: center; font-size: 0.78rem; margin-top: -10px; }
.form-helper a { color: var(--green-dark); font-weight: 600; }
.form-check { display: flex; align-items: center; gap: 8px; font-size: 0.8rem; color: var(--text-muted); cursor: pointer; }

/* My Account dashboard */
.my-account-wrap { display: grid; grid-template-columns: 240px 1fr; gap: 28px; align-items: start; }
.account-nav {
  background: var(--white); border-radius: var(--radius-md);
  padding: 16px; border: 1.5px solid var(--border);
  position: sticky; top: 90px;
}
.account-nav-list { display: flex; flex-direction: column; gap: 2px; }
.account-nav-list a {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 14px; border-radius: var(--radius-sm);
  font-size: 0.87rem; font-weight: 500; color: var(--text-muted);
  transition: var(--transition); text-decoration: none;
}
.account-nav-list a:hover,
.account-nav-list li.is-active a {
  background: var(--green-tint); color: var(--green-dark); font-weight: 600;
}
.account-nav-list .logout a:hover { background: #FEF0F0; color: var(--red-sale); }
.account-content {
  background: var(--white); border-radius: var(--radius-md);
  padding: 30px; border: 1.5px solid var(--border);
  min-width: 0;
}

/* ── Orders list table ─────────────────────────────────────────── */
.woocommerce-orders-table {
  width: 100%; border-collapse: collapse;
}
.woocommerce-orders-table thead tr { background: var(--cream); }
.woocommerce-orders-table th {
  padding: 10px 16px; font-size: 0.7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.07em; color: var(--text-light);
  border-bottom: 1.5px solid var(--border); text-align: left; white-space: nowrap;
}
.woocommerce-orders-table td {
  padding: 14px 16px; font-size: 0.87rem; color: var(--charcoal);
  border-bottom: 1px solid var(--border); vertical-align: middle;
}
.woocommerce-orders-table tbody tr:last-child td { border-bottom: none; }
.woocommerce-orders-table tbody tr:hover td { background: #fafaf8; }
.woocommerce-orders-table__cell-order-number a {
  font-weight: 700; color: var(--green-dark); text-decoration: none;
  font-family: 'Playfair Display', serif; font-size: 1rem;
}
.woocommerce-orders-table__cell-order-number a:hover { text-decoration: underline; }
.woocommerce-orders-table__cell-order-date { color: var(--text-muted); font-size: 0.83rem; }

/* Status badge pills */
.woocommerce-orders-table__cell-order-status mark {
  padding: 4px 11px; border-radius: 20px; font-size: 0.72rem;
  font-weight: 700; background: transparent; display: inline-block;
}
mark.processing, .woocommerce-orders-table__cell-order-status .wc-processing { background: #EFF6FF; color: #3B82F6; }
mark.completed,  .woocommerce-orders-table__cell-order-status .wc-completed  { background: #F0FDF4; color: #16A34A; }
mark.cancelled,  .woocommerce-orders-table__cell-order-status .wc-cancelled  { background: #FEF2F2; color: #EF4444; }
mark.on-hold,    .woocommerce-orders-table__cell-order-status .wc-on-hold    { background: #F5F3FF; color: #8B5CF6; }
mark.pending,    .woocommerce-orders-table__cell-order-status .wc-pending    { background: #FFFBEB; color: #F59E0B; }
mark.refunded,   .woocommerce-orders-table__cell-order-status .wc-refunded   { background: #F9FAFB; color: #6B7280; }

/* View / Pay action buttons */
.woocommerce-orders-table__cell-order-actions a {
  display: inline-flex; align-items: center; padding: 6px 16px;
  background: var(--green-dark); color: var(--white) !important;
  border-radius: 50px; font-size: 0.78rem; font-weight: 600;
  text-decoration: none !important; transition: background 0.2s;
  font-family: 'Poppins', sans-serif;
}
.woocommerce-orders-table__cell-order-actions a:hover { background: var(--green-fresh); }
.woocommerce-orders-table__cell-order-actions a + a { margin-left: 6px; background: transparent; color: var(--green-dark) !important; border: 1.5px solid var(--green-dark); }
.woocommerce-orders-table__cell-order-actions a + a:hover { background: var(--green-tint); }

/* Empty orders notice */
.woocommerce-message, .woocommerce-info {
  background: var(--cream); border-left: 3px solid var(--green-fresh);
  border-radius: var(--radius-sm); padding: 14px 18px;
  font-size: 0.88rem; color: var(--text-muted); margin-bottom: 20px;
}

/* ── Single order view ─────────────────────────────────────────── */
.woocommerce-order p.woocommerce-notice,
.account-content > p:first-child {
  background: var(--cream); border: 1px solid var(--border);
  border-left: 3px solid var(--green-fresh);
  border-radius: var(--radius-sm); padding: 12px 16px;
  font-size: 0.85rem; color: var(--text-muted); margin-bottom: 24px;
}
.account-content > p:first-child mark {
  background: none; font-weight: 700; color: var(--green-dark);
}
.account-content > p:first-child .woocommerce-order-status {
  background: #EFF6FF; color: #3B82F6; padding: 2px 8px;
  border-radius: 12px; font-size: 0.8rem; font-weight: 700;
}

/* Order details table */
.account-content .woocommerce-order-details,
.account-content .woocommerce-customer-details { margin-bottom: 28px; }

.account-content .woocommerce-order-details__title,
.account-content .woocommerce-column__title {
  font-family: 'Playfair Display', serif; font-size: 1.15rem;
  font-weight: 700; color: var(--charcoal);
  margin: 0 0 16px; padding-bottom: 10px;
  border-bottom: 1.5px solid var(--border);
}
.account-content .woocommerce-table--order-details {
  width: 100%; border-collapse: collapse;
}
.account-content .woocommerce-table--order-details th,
.account-content .woocommerce-table--order-details td {
  padding: 11px 14px; font-size: 0.85rem;
  border-bottom: 1px solid var(--border); text-align: left;
}
.account-content .woocommerce-table--order-details thead th {
  font-size: 0.7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-light); background: var(--cream);
}
.account-content .woocommerce-table--order-details tfoot tr td,
.account-content .woocommerce-table--order-details tfoot tr th {
  border-bottom: none; font-size: 0.85rem; color: var(--charcoal);
}
.account-content .woocommerce-table--order-details tfoot tr:last-child td,
.account-content .woocommerce-table--order-details tfoot tr:last-child th {
  font-weight: 800; font-size: 0.95rem; color: var(--green-dark);
  border-top: 1.5px solid var(--border);
}
.account-content .woocommerce-table--order-details .product-name a {
  color: var(--charcoal); font-weight: 600; text-decoration: none;
}
.account-content .woocommerce-table--order-details .product-name a:hover { color: var(--green-dark); }

/* Customer addresses */
.account-content .woocommerce-customer-details .col2-set {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.account-content .woocommerce-customer-details .col2-set .col-1,
.account-content .woocommerce-customer-details .col2-set .col-2 {
  background: var(--cream); border-radius: var(--radius-sm);
  padding: 18px 20px; border: 1.5px solid var(--border);
}
.account-content .woocommerce-customer-details address {
  font-style: normal; font-size: 0.84rem;
  color: var(--text-muted); line-height: 1.9;
}
.account-content .woocommerce-customer-details h3 {
  font-family: 'Playfair Display', serif; font-size: 0.95rem;
  font-weight: 700; color: var(--charcoal); margin: 0 0 12px;
}

@media (max-width: 640px) {
  .woocommerce-orders-table { display: block; overflow-x: auto; }
  .account-content .woocommerce-customer-details .col2-set { grid-template-columns: 1fr; }
}

/* ── WooCommerce Login / Register form ─────────────────────────── */
#customer_login.col2-set {
  display: grid; grid-template-columns: 1fr 1fr; gap: 28px;
}
#customer_login .u-column1,
#customer_login .u-column2 {
  background: var(--white); border-radius: var(--radius-lg);
  padding: 36px; border: 1.5px solid var(--border); box-shadow: var(--shadow-sm);
}
#customer_login h2 {
  font-size: 1.4rem; font-weight: 800; color: var(--green-dark);
  margin: 0 0 24px; font-family: 'Playfair Display', serif;
}
.woocommerce-form-row {
  display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px;
}
.woocommerce-form-row label {
  font-size: 0.8rem; font-weight: 600; color: var(--charcoal);
  font-family: 'Poppins', sans-serif;
}
.woocommerce-form-row .required { color: var(--red-sale); margin-left: 2px; }
.woocommerce-Input--text,
.woocommerce-form input[type="text"],
.woocommerce-form input[type="email"],
.woocommerce-form input[type="password"] {
  width: 100% !important; box-sizing: border-box !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  padding: 11px 14px !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.87rem !important; color: var(--charcoal) !important;
  background: var(--cream) !important;
  outline: none !important; transition: border-color 0.2s, box-shadow 0.2s !important;
}
.woocommerce-Input--text:focus,
.woocommerce-form input[type="text"]:focus,
.woocommerce-form input[type="email"]:focus,
.woocommerce-form input[type="password"]:focus {
  border-color: var(--green-fresh) !important;
  box-shadow: 0 0 0 3px rgba(69,176,0,0.10) !important;
  background: var(--white) !important;
}
.woocommerce-form-login .form-row,
.woocommerce-form-register .form-row:last-child {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; margin-top: 8px;
}
.woocommerce-form__label-for-checkbox {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.82rem; color: var(--text-muted); cursor: pointer;
}
.woocommerce-form__input-checkbox { width: auto !important; }
.woocommerce-form-login__submit,
.woocommerce-form-register__submit {
  background: var(--green-dark) !important; color: var(--white) !important;
  border: none !important; border-radius: 50px !important;
  padding: 11px 28px !important; font-family: 'Poppins', sans-serif !important;
  font-size: 0.88rem !important; font-weight: 700 !important;
  cursor: pointer !important; transition: background 0.2s, transform 0.2s !important;
  letter-spacing: 0.02em !important;
}
.woocommerce-form-login__submit:hover,
.woocommerce-form-register__submit:hover {
  background: var(--green-mid) !important; transform: translateY(-1px) !important;
}
.woocommerce-LostPassword { margin-top: 12px; }
.woocommerce-LostPassword a {
  font-size: 0.8rem; color: var(--green-dark); font-weight: 600; text-decoration: underline;
}
.woocommerce-privacy-policy-text {
  font-size: 0.78rem; color: var(--text-muted); margin: 12px 0;
}
@media (max-width: 640px) {
  #customer_login.col2-set { grid-template-columns: 1fr; }
}

/* ── WooCommerce Account Details (Edit Account) ─────────────────── */
.woocommerce-EditAccountForm .form-row {
  display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px;
}
.woocommerce-EditAccountForm .form-row-first,
.woocommerce-EditAccountForm .form-row-last {
  display: inline-flex; flex-direction: column; gap: 6px;
  width: calc(50% - 10px); margin-bottom: 16px;
}
.woocommerce-EditAccountForm .form-row-first { margin-right: 20px; }
.woocommerce-EditAccountForm .form-row label {
  font-size: 0.8rem; font-weight: 600;
  color: var(--charcoal); font-family: 'Poppins', sans-serif;
  display: block;
}
.woocommerce-EditAccountForm .form-row .required { color: var(--red-sale); }
.woocommerce-EditAccountForm .woocommerce-input-wrapper { display: block; }

/* All inputs */
.woocommerce-EditAccountForm input[type="text"],
.woocommerce-EditAccountForm input[type="email"],
.woocommerce-EditAccountForm input[type="password"],
.woocommerce-EditAccountForm input[type="tel"] {
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 11px 14px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  background: var(--cream) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.87rem !important;
  color: var(--charcoal) !important;
  outline: none !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
}
.woocommerce-EditAccountForm input[type="text"]:focus,
.woocommerce-EditAccountForm input[type="email"]:focus,
.woocommerce-EditAccountForm input[type="password"]:focus,
.woocommerce-EditAccountForm input[type="tel"]:focus {
  border-color: var(--green-fresh) !important;
  box-shadow: 0 0 0 3px rgba(69,176,0,0.10) !important;
  background: var(--white) !important;
}

/* Hint text below display name */
.woocommerce-EditAccountForm .woocommerce-form-row span em,
.woocommerce-EditAccountForm em {
  display: block;
  font-size: 0.75rem;
  color: var(--text-muted);
  font-style: normal;
  margin-top: 5px;
}

/* Password change fieldset */
.woocommerce-EditAccountForm fieldset {
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 22px 24px;
  margin: 8px 0 20px;
  background: var(--cream);
}
.woocommerce-EditAccountForm fieldset legend {
  font-family: 'Poppins', sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--charcoal);
  padding: 0 8px;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
.woocommerce-EditAccountForm fieldset .form-row { margin-bottom: 14px; }
.woocommerce-EditAccountForm fieldset .form-row:last-child { margin-bottom: 0; }

/* Save changes button */
.woocommerce-EditAccountForm .woocommerce-Button,
.woocommerce-EditAccountForm button[type="submit"],
.woocommerce-EditAccountForm input[type="submit"] {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--green-dark) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 12px 32px !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: background 0.2s, transform 0.15s !important;
  margin-top: 4px !important;
  letter-spacing: 0.02em !important;
}
.woocommerce-EditAccountForm .woocommerce-Button:hover,
.woocommerce-EditAccountForm button[type="submit"]:hover,
.woocommerce-EditAccountForm input[type="submit"]:hover {
  background: var(--green-fresh) !important;
  transform: translateY(-1px) !important;
}

@media (max-width: 600px) {
  .woocommerce-EditAccountForm .form-row-first,
  .woocommerce-EditAccountForm .form-row-last {
    width: 100%; margin-right: 0;
  }
}

/* ── WooCommerce Edit Address (Billing / Shipping) ─────────────── */
.woocommerce-address-fields h3,
.woocommerce-EditAddress h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.7rem; font-weight: 800;
  color: var(--green-dark); margin: 0 0 28px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--border);
}
.woocommerce-address-fields__field-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 20px;
}
.woocommerce-address-fields .form-row {
  display: flex; flex-direction: column; gap: 6px; margin: 0;
}
.woocommerce-address-fields .form-row-wide {
  grid-column: 1 / -1;
}
.woocommerce-address-fields .form-row label {
  font-size: 0.8rem; font-weight: 600;
  color: var(--charcoal); font-family: 'Poppins', sans-serif;
  display: block;
}
.woocommerce-address-fields .form-row .required { color: var(--red-sale); }
.woocommerce-address-fields .woocommerce-input-wrapper { display: block; }

/* All input types inside address form */
.woocommerce-address-fields input[type="text"],
.woocommerce-address-fields input[type="email"],
.woocommerce-address-fields input[type="tel"],
.woocommerce-address-fields input[type="number"],
.woocommerce-address-fields input[type="password"],
.woocommerce-address-fields textarea,
.woocommerce-address-fields select,
.woocommerce-address-fields .woocommerce-select {
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 11px 14px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  background: var(--cream) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.87rem !important;
  color: var(--charcoal) !important;
  outline: none !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  appearance: auto;
}
.woocommerce-address-fields input[type="text"]:focus,
.woocommerce-address-fields input[type="email"]:focus,
.woocommerce-address-fields input[type="tel"]:focus,
.woocommerce-address-fields input[type="number"]:focus,
.woocommerce-address-fields textarea:focus,
.woocommerce-address-fields select:focus {
  border-color: var(--green-fresh) !important;
  box-shadow: 0 0 0 3px rgba(69,176,0,0.10) !important;
  background: var(--white) !important;
}

/* Save address button */
.woocommerce-address-fields .button,
.woocommerce-address-fields button[type="submit"],
.woocommerce-address-fields input[type="submit"] {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--green-dark) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 12px 32px !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: background 0.2s, transform 0.15s !important;
  margin-top: 8px !important;
  letter-spacing: 0.02em !important;
}
.woocommerce-address-fields .button:hover,
.woocommerce-address-fields button[type="submit"]:hover,
.woocommerce-address-fields input[type="submit"]:hover {
  background: var(--green-fresh) !important;
  transform: translateY(-1px) !important;
}

/* Form submit row */
.woocommerce-address-fields p.form-row:last-of-type {
  grid-column: 1 / -1;
  margin-top: 8px;
}

/* Select2 override — WC sometimes replaces native select */
.select2-container .select2-selection--single {
  height: 44px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  background: var(--cream) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.87rem !important;
}
.select2-container .select2-selection--single .select2-selection__rendered {
  line-height: 44px !important;
  padding-left: 14px !important;
  color: var(--charcoal) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.87rem !important;
}
.select2-container .select2-selection--single .select2-selection__arrow {
  height: 44px !important;
}
.select2-container--open .select2-selection--single,
.select2-container--focus .select2-selection--single {
  border-color: var(--green-fresh) !important;
  box-shadow: 0 0 0 3px rgba(69,176,0,0.10) !important;
  background: var(--white) !important;
  outline: none !important;
}
.select2-dropdown {
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.87rem !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.10) !important;
}
.select2-results__option--highlighted {
  background: var(--green-tint) !important;
  color: var(--green-dark) !important;
}

@media (max-width: 600px) {
  .woocommerce-address-fields__field-wrapper { grid-template-columns: 1fr; }
  .woocommerce-address-fields .form-row-wide { grid-column: 1; }
}

/* ═══════════════════════════════════════════
   ABOUT US PAGE
═══════════════════════════════════════════ */
.about-hero { background: linear-gradient(135deg, var(--green-dark) 0%, #003d10 100%); padding: 100px 0 60px; }
.about-hero h1 { color: var(--white); font-size: clamp(2rem,5vw,3.5rem); }
.about-hero h1 em { color: var(--beige); font-style: normal; }
.about-hero p { color: rgba(255,255,255,0.85); margin-top: 12px; max-width: 500px; }
.about-hero-badge { display: inline-block; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2); color: rgba(255,255,255,0.9); padding: 5px 14px; border-radius: 50px; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 16px; }

.about-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 40px; }
.about-stat {
  background: var(--white); border-radius: var(--radius-md); padding: 24px;
  border: 1.5px solid var(--border); text-align: center; box-shadow: var(--shadow-sm);
}
.about-stat-num { font-family: 'Playfair Display', serif; font-size: 2.2rem; font-weight: 900; color: var(--green-dark); display: block; }
.about-stat-label { font-size: 0.78rem; color: var(--text-muted); margin-top: 4px; }
.about-features-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 48px; }
.about-feature {
  background: var(--white);
  border-radius: var(--radius-md);
  padding: 32px 28px;
  border: 1.5px solid var(--border);
  border-top: 3px solid var(--green-tint);
  box-shadow: var(--shadow-sm);
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
.about-feature:hover {
  transform: translateY(-7px);
  box-shadow: 0 18px 48px rgba(0,91,27,0.12);
  border-color: rgba(69,176,0,0.22);
  border-top-color: var(--green-fresh);
}
.about-feature-icon {
  width: 58px; height: 58px;
  background: var(--green-tint);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 20px;
  color: var(--green-dark);
  transition: background 0.3s ease, transform 0.3s ease;
}
.about-feature-icon svg { width: 24px; height: 24px; display: block; }
.about-feature:hover .about-feature-icon {
  background: rgba(69,176,0,0.16);
  transform: scale(1.1);
}
.about-feature h4 { font-size: 1.05rem; font-weight: 700; margin-bottom: 10px; color: var(--charcoal); line-height: 1.3; }
.about-feature p { font-size: 0.88rem; color: var(--text-muted); line-height: 1.72; }
.about-promise {
  background: linear-gradient(135deg, var(--green-dark) 0%, #003d10 100%);
  border-radius: var(--radius-lg); padding: 40px 48px;
  display: flex; justify-content: space-between; align-items: center; gap: 32px;
  margin-top: 48px;
}
.about-promise h3 { color: var(--white); font-size: 1.6rem; margin-bottom: 10px; }
.about-promise p { color: rgba(255,255,255,0.7); font-size: 0.88rem; max-width: 500px; }
.about-fssai-block {
  background: var(--green-tint); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: 18px 24px;
  display: flex; align-items: center; gap: 14px; margin-top: 24px;
}
.fssai-logo { font-size: 2rem; }
.fssai-text { font-size: 0.82rem; }
.fssai-text strong { color: var(--green-dark); font-size: 0.9rem; display: block; margin-bottom: 2px; }

/* ═══════════════════════════════════════════
   CONTACT US PAGE
═══════════════════════════════════════════ */
.contact-layout { display: grid; grid-template-columns: 1fr 1.4fr; gap: 48px; align-items: start; padding: 60px 0 80px; }
.contact-info-card {
  background: var(--white); border-radius: var(--radius-lg); padding: 32px;
  border: 1.5px solid var(--border); box-shadow: var(--shadow-sm);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.contact-info-card:hover {
  border-color: var(--green-fresh);
  box-shadow: 0 0 0 3px rgba(69,176,0,0.12), var(--shadow-sm);
}
.contact-info-card h3 { font-size: 1.2rem; margin-bottom: 6px; }
.contact-info-card > p { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 28px; }
.contact-detail-item {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 14px 0; border-bottom: 1px solid var(--border);
}
.contact-detail-item:last-child { border-bottom: none; }
.cdi-icon { font-size: 1.3rem; flex-shrink: 0; margin-top: 2px; }
.cdi-label { font-size: 0.72rem; font-weight: 700; color: var(--text-light); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 3px; }
.cdi-value { font-size: 0.88rem; font-weight: 500; color: var(--charcoal); }
.cdi-value a { color: var(--green-dark); }
.contact-form-card {
  background: var(--white); border-radius: var(--radius-lg); padding: 36px;
  border: 1.5px solid var(--border); box-shadow: var(--shadow-sm);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.contact-form-card:hover {
  border-color: var(--green-fresh);
  box-shadow: 0 0 0 3px rgba(69,176,0,0.12), var(--shadow-sm);
}
.contact-form-card h3 { font-size: 1.2rem; margin-bottom: 6px; }
.contact-form-card > p { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 28px; }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group select, .form-group textarea {
  border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  padding: 11px 14px; font-family: 'Poppins',sans-serif; font-size: 0.87rem;
  color: var(--charcoal); outline: none; transition: var(--transition);
  background: var(--cream); width: 100%;
}
.form-group textarea { min-height: 120px; resize: vertical; }
.form-group select:focus, .form-group textarea:focus {
  border-color: var(--green-fresh); box-shadow: 0 0 0 3px rgba(69,176,0,0.10); background: var(--white);
}
.form-success {
  background: var(--green-tint); color: var(--green-dark); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 14px 18px; font-size: 0.88rem; margin-bottom: 16px;
}
.form-error {
  background: #FEF0F0; color: var(--red-sale); border: 1px solid #FFCDD2;
  border-radius: var(--radius-sm); padding: 14px 18px; font-size: 0.88rem; margin-bottom: 16px;
}

/* — Upload zone — */
.upload-optional { font-size: 0.75rem; font-weight: 400; color: var(--text-light); margin-left: 4px; }
.upload-zone {
  border: 2px dashed var(--border); border-radius: var(--radius-sm);
  padding: 30px 20px; text-align: center; cursor: pointer;
  transition: border-color 0.25s ease, background 0.25s ease;
  background: var(--cream); position: relative; margin-top: 4px;
}
.upload-zone:hover, .upload-zone.drag-over { border-color: var(--green-fresh); background: var(--green-tint); }
.upload-zone input[type="file"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%; z-index: 2; }
.upload-zone-inner { pointer-events: none; }
.upload-zone-icon {
  width: 44px; height: 44px; background: var(--green-tint); border-radius: 12px;
  display: flex; align-items: center; justify-content: center; margin: 0 auto 12px;
  color: var(--green-dark); transition: transform 0.2s ease;
}
.upload-zone:hover .upload-zone-icon { transform: translateY(-3px); }
.upload-zone-icon svg { width: 22px; height: 22px; display: block; }
.upload-zone-text { font-size: 0.88rem; font-weight: 600; color: var(--charcoal); margin-bottom: 4px; }
.upload-zone-text span { color: var(--green-dark); text-decoration: underline; }
.upload-zone-hint { font-size: 0.75rem; color: var(--text-light); }
.upload-file-list { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.upload-file-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--white); border: 1.5px solid var(--border);
  border-radius: 8px; padding: 5px 10px; font-size: 0.78rem;
}
.ufc-name { color: var(--charcoal); font-weight: 500; max-width: 150px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ufc-size { color: var(--text-light); }
.ufc-remove { background: none; border: none; cursor: pointer; color: var(--text-light); font-size: 1rem; line-height: 1; padding: 0; transition: color 0.15s; }
.ufc-remove:hover { color: var(--red-sale); }
.upload-error { margin-top: 8px; font-size: 0.8rem; color: var(--red-sale); font-weight: 500; }

/* ═══════════════════════════════════════════
   POLICY PAGES
═══════════════════════════════════════════ */
.policy-hero {
  background: linear-gradient(135deg, var(--green-dark) 0%, #003d10 100%);
  padding: 90px 0 50px; text-align: center;
}
.policy-hero h1 { color: var(--white); font-size: clamp(1.8rem,4vw,3rem); }
.policy-hero p { color: rgba(255,255,255,0.6); font-size: 0.85rem; margin-top: 8px; }
.policy-body { background: var(--cream); padding: 48px 0 80px; }
.policy-layout { display: grid; grid-template-columns: 260px 1fr; gap: 36px; align-items: start; }
.policy-toc {
  background: var(--white); border-radius: var(--radius-md); padding: 22px;
  border: 1.5px solid var(--border); position: sticky; top: 90px;
}
.policy-toc h4 { font-size: 0.85rem; font-weight: 700; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--border); }
.policy-toc ol { padding-left: 16px; display: flex; flex-direction: column; gap: 7px; }
.policy-toc li a { font-size: 0.8rem; color: var(--text-muted); transition: color 0.2s; }
.policy-toc li a:hover { color: var(--green-dark); }
.policy-card {
  background: var(--white); border-radius: var(--radius-md); padding: 28px 32px;
  border: 1.5px solid var(--border); box-shadow: var(--shadow-sm); margin-bottom: 18px;
}
.policy-card h3 {
  font-size: 1rem; font-weight: 800; color: var(--charcoal);
  margin-bottom: 12px; padding-left: 12px;
  border-left: 3px solid var(--green-fresh);
  font-family: 'Poppins', sans-serif;
}
.policy-card p, .policy-card li { font-size: 0.86rem; color: var(--text-muted); line-height: 1.8; }
.policy-card ul, .policy-card ol { padding-left: 18px; margin-top: 8px; }
.policy-card ul { list-style: disc; }
.policy-card ol { list-style: decimal; }
.policy-card li { margin-bottom: 5px; }
.policy-legal-block {
  background: var(--green-tint); border-radius: var(--radius-md); padding: 22px 28px;
  border: 1px solid var(--border); margin-top: 8px;
}
.policy-legal-block p { font-size: 0.82rem; color: var(--charcoal); line-height: 1.9; }
.policy-legal-block strong { color: var(--green-dark); }

/* ═══════════════════════════════════════════
   PAGE HERO (generic)
═══════════════════════════════════════════ */
.page-hero {
  background: linear-gradient(135deg, var(--green-dark) 0%, #003d10 100%);
  padding: 90px 0 56px; text-align: center;
}
.page-hero .section-eyebrow { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.9); border-color: rgba(255,255,255,0.2); }
.page-hero .section-eyebrow::before { background: rgba(255,255,255,0.7); }
.page-hero h1 { color: var(--white); margin: 8px 0; }
.page-hero h1 em { color: var(--beige); font-style: normal; }
.page-hero p { color: rgba(255,255,255,0.85); max-width: 500px; margin: 0 auto; }

/* ═══════════════════════════════════════════
   CHECKOUT — Classic + Blocks
═══════════════════════════════════════════ */
.checkout-section { background: var(--cream); padding: 48px 0 80px; }
.checkout-layout { display: grid; grid-template-columns: 1.4fr 1fr; gap: 30px; }
.checkout-card {
  background: var(--white); border-radius: var(--radius-lg); padding: 28px 32px;
  border: 1.5px solid var(--border); box-shadow: var(--shadow-sm);
}
.checkout-card h3 { font-size: 1rem; font-weight: 800; margin-bottom: 20px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }

/* Classic checkout form fields */
.woocommerce-checkout .form-row label { font-size: 0.8rem; font-weight: 600; color: var(--charcoal); margin-bottom: 6px; display: block; }
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout select,
.woocommerce-checkout textarea {
  border: 1.5px solid var(--border) !important; border-radius: var(--radius-sm) !important;
  padding: 11px 14px !important; font-family: 'Poppins',sans-serif !important;
  font-size: 0.87rem !important; background: var(--cream) !important; width: 100% !important; outline: none !important;
}
.woocommerce-checkout input:focus, .woocommerce-checkout select:focus {
  border-color: var(--green-fresh) !important; box-shadow: 0 0 0 3px rgba(69,176,0,0.10) !important; background: var(--white) !important;
}

/* ── WC Blocks notices/snackbar — transparent wrapper, styled items ── */
.wc-block-components-notices,
.wc-block-components-notices__snackbar,
.wc-block-components-notice-snackbar-list {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  min-height: 0 !important;
}
/* Individual snackbar notice item */
.wc-block-components-notice-snackbar {
  background: var(--charcoal) !important;
  color: var(--white) !important;
  border-radius: var(--radius-sm) !important;
  padding: 12px 16px !important;
  font-size: 0.85rem !important;
  font-family: 'Poppins', sans-serif !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.18) !important;
  margin-bottom: 8px !important;
}
.wc-block-components-notice-snackbar .wc-block-components-notice-snackbar__dismiss {
  color: var(--white) !important;
}

/* ── Hide empty express-payment block (no Apple/Google Pay configured) ── */
.wp-block-woocommerce-checkout-express-payment-block,
.wc-block-checkout__express-payment,
.wc-block-express-payment-continue-rule,
.wc-block-components-express-checkout-continue-rule,
.wc-express-payment,
.wc-express-payment-buttons,
.wc-block-components-express-checkout,
.wc-block-checkout__express-payment-continue-rule,
.wc-block-express-payment {
  display: none !important;
}

/* ═══════════════════════════════════════════
   ORDER RECEIVED / THANK YOU PAGE
═══════════════════════════════════════════ */

/* Hide WooCommerce's default "Order received" h1 — we have our own heading */
body.woocommerce-order-received h1.entry-title,
body.woocommerce-order-received .page-title { display: none; }

.thankyou-wrap {
  max-width: 680px; margin: 0 auto;
  padding: 40px 0 60px; text-align: center;
}

/* ── Success card ── */
.thankyou-card {
  background: var(--white); border-radius: var(--radius-lg);
  padding: clamp(24px,5vw,48px) clamp(18px,4vw,40px);
  border: 1.5px solid var(--border); box-shadow: var(--shadow-md);
  margin-bottom: 20px;
}
.thankyou-emoji { font-size: clamp(2.5rem,8vw,4rem); margin-bottom: 16px; }
.thankyou-title { font-size: clamp(1.4rem,3vw,1.8rem); color: var(--green-dark); margin-bottom: 8px; }
.thankyou-subtitle { font-size: 0.9rem; color: var(--text-muted); margin-bottom: 24px; }

.thankyou-order-num {
  background: var(--green-tint); border-radius: var(--radius-md);
  padding: 16px 24px; margin-bottom: 24px; border: 1px solid var(--border);
  display: inline-block;
}
.thankyou-order-label {
  display: block; font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--text-light); margin-bottom: 4px;
}
.thankyou-order-value {
  font-family: 'Playfair Display', serif; font-size: 1.8rem;
  font-weight: 900; color: var(--green-dark);
}

.thankyou-steps {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(130px,1fr));
  gap: 12px; margin: 24px 0;
}
.thankyou-step {
  background: var(--cream); border-radius: var(--radius-sm);
  padding: 16px 12px; border: 1px solid var(--border);
}
.thankyou-step-icon  { font-size: 1.6rem; margin-bottom: 8px; }
.thankyou-step-title { font-weight: 700; font-size: 0.82rem; color: var(--charcoal); margin-bottom: 4px; }
.thankyou-step-desc  { font-size: 0.72rem; color: var(--text-muted); }

.thankyou-summary {
  background: var(--cream); border-radius: var(--radius-md);
  padding: 18px 20px; border: 1px solid var(--border);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 12px; text-align: left; margin-bottom: 24px;
}
.thankyou-summary-full { grid-column: 1 / -1; }
.thankyou-summary-label {
  display: block; font-size: 0.7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.07em;
  color: var(--text-light); margin-bottom: 3px;
}
.thankyou-summary-value { font-size: 0.88rem; color: var(--charcoal); font-weight: 500; }
.thankyou-total { font-family: 'Playfair Display', serif; font-weight: 800; font-size: 1.1rem; color: var(--green-dark); }

.thankyou-actions {
  display: flex; gap: 10px; justify-content: center; flex-wrap: wrap;
}
.thankyou-wa-btn { color: var(--green-dark) !important; }

/* ── WooCommerce order details output ── */
.thankyou-details {
  background: var(--white); border-radius: var(--radius-lg);
  border: 1.5px solid var(--border); padding: clamp(20px,4vw,32px);
  text-align: left; margin-bottom: 20px;
}
.thankyou-details h2,
.thankyou-details .woocommerce-order-details__title,
.thankyou-details .woocommerce-column__title {
  font-family: 'Playfair Display', serif; font-size: 1.05rem;
  font-weight: 700; color: var(--charcoal); margin: 0 0 16px;
  padding-bottom: 10px; border-bottom: 1px solid var(--border);
}
.thankyou-details h2:not(:first-child),
.thankyou-details .woocommerce-customer-details { margin-top: 24px; }

.thankyou-details .woocommerce-table--order-details {
  width: 100%; border-collapse: collapse;
}
.thankyou-details .woocommerce-table--order-details th,
.thankyou-details .woocommerce-table--order-details td {
  padding: 10px 14px; font-size: 0.85rem;
  border-bottom: 1px solid var(--border); text-align: left;
}
.thankyou-details .woocommerce-table--order-details thead th {
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--text-light);
  background: var(--cream);
}
.thankyou-details .woocommerce-table--order-details tfoot tr td,
.thankyou-details .woocommerce-table--order-details tfoot tr th {
  font-size: 0.85rem; color: var(--charcoal); border-bottom: none;
}
.thankyou-details .woocommerce-table--order-details tfoot tr:last-child td,
.thankyou-details .woocommerce-table--order-details tfoot tr:last-child th {
  font-weight: 800; font-size: 0.95rem; color: var(--green-dark);
}

.thankyou-details .woocommerce-customer-details {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 24px;
}
.thankyou-details .woocommerce-column {
  background: var(--cream); border-radius: var(--radius-sm);
  padding: 16px 18px; border: 1px solid var(--border);
}
.thankyou-details address {
  font-style: normal; font-size: 0.84rem;
  color: var(--text-muted); line-height: 1.9;
}

/* ── WooCommerce order overview list ── */
.thankyou-details .woocommerce-order-overview {
  list-style: none; padding: 0; margin: 0 0 20px;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(130px,1fr));
  gap: 10px; background: var(--cream);
  border-radius: var(--radius-sm); padding: 14px 16px;
  border: 1px solid var(--border);
}
.thankyou-details .woocommerce-order-overview li {
  font-size: 0.8rem; color: var(--text-muted);
}
.thankyou-details .woocommerce-order-overview li strong {
  display: block; font-size: 0.88rem; color: var(--charcoal); margin-top: 2px;
}

.thankyou-footer-note {
  font-size: 0.78rem; color: var(--text-muted); margin: 0;
}
.thankyou-footer-note a { color: var(--green-dark); font-weight: 600; }

@media (max-width: 640px) {
  .thankyou-summary { grid-template-columns: 1fr; }
  .thankyou-details .woocommerce-customer-details { grid-template-columns: 1fr; }
  .thankyou-actions { flex-direction: column; }
  .thankyou-actions .btn { width: 100%; text-align: center; }
}

/* ── WooCommerce Blocks Checkout ─────────────────────────────── */

/* Page background — force cream on the whole checkout page body */
body.woocommerce-checkout,
body.woocommerce-checkout #page,
body.woocommerce-checkout .site-content,
body.woocommerce-checkout main,
body.woocommerce-checkout .wp-block-post-content,
body.woocommerce-checkout .entry-content {
  background: var(--cream) !important;
}
.wp-block-woocommerce-checkout,
.wc-block-checkout { background: var(--cream) !important; }

/* ── Step cards ─────────────────────────────────────────────── */
.wc-block-components-checkout-step {
  background: var(--white) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 32px 36px !important;
  margin-bottom: 20px !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.04) !important;
}
.wc-block-components-checkout-step__heading-content::before {
  background: var(--green-dark) !important;
  color: var(--white) !important;
  border-radius: 50% !important;
  font-weight: 700 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  font-size: 0.78rem !important;
  flex-shrink: 0 !important;
}
.wc-block-components-checkout-step__title {
  font-family: 'Poppins', sans-serif !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: var(--charcoal) !important;
}
/* Space between the step content and heading */
.wc-block-components-checkout-step__container {
  margin-top: 24px !important;
}

/* ── Floating-label input wrappers ──────────────────────────── */
.wc-block-components-text-input,
.wc-block-components-country-input,
.wc-block-components-state-input {
  position: relative !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin-bottom: 6px !important;
}

/* ── Inputs: tall enough for label to float above value ──────── */
.wc-block-components-text-input input,
.wc-block-components-country-input input,
.wc-block-components-state-input input,
.wc-block-components-address-form input:not([type="checkbox"]):not([type="radio"]),
.wp-block-woocommerce-checkout input[type="text"],
.wp-block-woocommerce-checkout input[type="email"],
.wp-block-woocommerce-checkout input[type="tel"],
.wp-block-woocommerce-checkout input[type="password"] {
  min-height: 60px !important;
  padding: 24px 16px 10px !important;   /* top padding = space for the floating label */
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.9rem !important;
  color: var(--charcoal) !important;
  background: var(--white) !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.wc-block-components-text-input input:focus,
.wc-block-components-country-input input:focus,
.wc-block-components-state-input input:focus,
.wp-block-woocommerce-checkout input:focus {
  border-color: var(--green-fresh) !important;
  box-shadow: 0 0 0 3px rgba(69,176,0,0.10) !important;
  outline: none !important;
}

/* Select fields */
.wc-block-components-select select,
.wp-block-woocommerce-checkout select {
  min-height: 60px !important;
  padding: 16px 16px 10px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.9rem !important;
  color: var(--charcoal) !important;
  background: var(--white) !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.wp-block-woocommerce-checkout select:focus {
  border-color: var(--green-fresh) !important;
  box-shadow: 0 0 0 3px rgba(69,176,0,0.10) !important;
  outline: none !important;
}

/* ── Floating labels — default (empty / placeholder state) ───── */
.wc-block-components-text-input label {
  position: absolute !important;
  left: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 400 !important;
  color: var(--text-muted) !important;
  pointer-events: none !important;
  transition: top 0.18s ease, font-size 0.18s ease, color 0.18s ease, font-weight 0.18s ease !important;
  line-height: 1 !important;
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  white-space: nowrap !important;
  z-index: 1 !important;
}

/* ── Floating labels — active (has value or focused) ─────────── */
.wc-block-components-text-input.is-active label {
  top: 14px !important;
  transform: none !important;
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  color: var(--green-dark) !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

/* ── Form row spacing ──────────────────────────────────────────── */
.wc-block-components-address-form .wc-block-components-address-form__field-wrapper,
.wc-block-components-form .wc-block-components-address-form > div {
  margin-bottom: 16px !important;
}
.wc-block-components-address-form .wc-block-components-address-form__row {
  gap: 16px !important;
}

/* ── Validation error ─────────────────────────────────────────── */
.wc-block-components-validation-error p {
  color: var(--red-sale) !important;
  font-size: 0.75rem !important;
  font-family: 'Poppins', sans-serif !important;
  margin: 5px 0 0 !important;
  font-weight: 500 !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}
.wc-block-components-text-input.has-error input {
  border-color: var(--red-sale) !important;
  background: #fff8f8 !important;
}

/* ── Checkbox ─────────────────────────────────────────────────── */
.wc-block-components-checkbox__mark {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  background: var(--white) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 5px !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
}
.wc-block-components-checkbox__mark svg {
  width: 11px !important;
  height: 11px !important;
}
.wc-block-components-checkbox input:checked ~ .wc-block-components-checkbox__mark {
  background: var(--green-dark) !important;
  border-color: var(--green-dark) !important;
}
.wc-block-components-checkbox__label {
  font-size: 0.83rem !important;
  color: var(--text-muted) !important;
  font-family: 'Poppins', sans-serif !important;
  line-height: 1.5 !important;
}
/* Checkbox row spacing */
.wc-block-components-checkbox {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  margin: 16px 0 !important;
}

/* ── Create-account panel button — reset global .woocommerce button ─ */
.wc-block-components-panel__button,
.wc-block-checkout__create-account button,
.wc-block-checkout__create-account .wc-block-components-panel__button {
  background: transparent !important;
  background-color: transparent !important;
  color: var(--charcoal) !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 10px 0 !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.87rem !important;
  font-weight: 600 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  cursor: pointer !important;
  box-shadow: none !important;
  transform: none !important;
  letter-spacing: 0 !important;
}
.wc-block-components-panel__button:hover,
.wc-block-checkout__create-account button:hover {
  background: transparent !important;
  background-color: transparent !important;
  transform: none !important;
  color: var(--green-dark) !important;
}
/* Panel content (the form that expands inside create-account) */
.wc-block-components-panel__content {
  padding: 12px 0 0 !important;
}

/* ── "Log in" link / guest notice ────────────────────────────── */
.wc-block-checkout__guest-notice {
  font-size: 0.82rem !important;
  color: var(--text-muted) !important;
  font-family: 'Poppins', sans-serif !important;
  margin-bottom: 14px !important;
  line-height: 1.6 !important;
}
.wc-block-checkout__guest-notice a,
.wc-block-checkout__contact-fields a,
.wc-block-components-checkout-step__description a {
  color: var(--green-dark) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}
.wc-block-checkout__guest-notice a:hover {
  text-decoration: underline !important;
}

/* ── Order summary sidebar card ──────────────────────────────── */
.wc-block-checkout__sidebar > * {
  background: var(--white) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-lg) !important;
  padding: 24px 28px !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.04) !important;
  margin-bottom: 16px !important;
}
.wc-block-components-order-summary__title,
.wc-block-components-title {
  font-family: 'Poppins', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--charcoal) !important;
  border-bottom: 1px solid var(--border) !important;
  padding-bottom: 14px !important;
  margin-bottom: 16px !important;
}
/* Product thumbnail — locked square, flex-basis beats flex-grow */
.wc-block-components-order-summary-item__image,
.wc-block-components-product-thumbnail {
  flex: 0 0 72px !important;
  width: 72px !important;
  max-width: 72px !important;
  min-width: 72px !important;
  height: 72px !important;
  min-height: 72px !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  border: 1.5px solid var(--border) !important;
  background: var(--cream) !important;
  position: relative !important;
  align-self: flex-start !important;
  box-sizing: border-box !important;
  /* covers the case where .wc-block-components-product-thumbnail IS the <img> */
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}
.wc-block-components-order-summary-item__image img,
.wc-block-components-product-thumbnail img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* Quantity badge on thumbnail */
.wc-block-components-order-summary-item__quantity {
  position: absolute !important;
  top: -6px !important;
  right: -6px !important;
  background: var(--green-dark) !important;
  color: var(--white) !important;
  border: 2px solid var(--white) !important;
  border-radius: 50% !important;
  font-weight: 700 !important;
  font-size: 0.68rem !important;
  min-width: 20px !important;
  height: 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
}

/* Item row */
.wc-block-components-order-summary-item {
  display: flex !important;
  flex-direction: row !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 16px 0 !important;
  gap: 16px !important;
  align-items: flex-start !important;
}
/* Details column — actual class in WC Blocks HTML is __description */
.wc-block-components-order-summary-item__description {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  overflow: hidden !important;
}

/* Item name */
.wc-block-components-product-name {
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  color: var(--charcoal) !important;
  line-height: 1.4 !important;
  margin: 0 0 4px !important;
}

/* Prices */
.wc-block-components-order-summary-item__individual-prices {
  font-size: 0.76rem !important;
  color: var(--text-light) !important;
  text-decoration: line-through !important;
}
.wc-block-components-order-summary-item__full-price {
  font-size: 0.9rem !important;
  font-weight: 700 !important;
  color: var(--green-dark) !important;
}

/* "Save ₹X" badge — turn it green */
.wc-block-components-order-summary-item__subtotal-price .wc-block-components-sale-badge,
.wc-block-components-sale-badge {
  background: var(--green-tint) !important;
  color: var(--green-dark) !important;
  border: 1px solid rgba(69,176,0,0.2) !important;
  border-radius: 20px !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  padding: 2px 8px !important;
}

/* Hide only the metadata/attributes row (pack size etc.) to keep summary compact */
.wc-block-components-product-metadata {
  display: none !important;
}

/* ── Totals ─────────────────────────────────────────────────── */
.wc-block-components-totals-item {
  border-bottom: 1px solid var(--border) !important;
  padding: 12px 0 !important;
  align-items: center !important;
}
.wc-block-components-totals-item__label {
  font-size: 0.85rem !important;
  color: var(--text-muted) !important;
  font-family: 'Poppins', sans-serif !important;
}
.wc-block-components-totals-item__value {
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  color: var(--charcoal) !important;
  font-family: 'Poppins', sans-serif !important;
}
/* Grand total row */
.wc-block-components-totals-footer-item {
  border-bottom: none !important;
  margin-top: 4px !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  font-size: 1rem !important;
  font-weight: 800 !important;
  color: var(--charcoal) !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
  font-size: 1.15rem !important;
  font-weight: 800 !important;
  color: var(--green-dark) !important;
}
.wc-block-components-totals-discount .wc-block-components-totals-item__value,
.wc-block-components-totals-shipping .wc-block-components-totals-item__value {
  color: var(--green-dark) !important;
  font-weight: 700 !important;
}

/* Coupon input row */
.wc-block-components-totals-coupon__form { gap: 8px !important; }
.wc-block-components-totals-coupon input {
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  min-height: 60px !important;
  padding: 24px 16px 10px !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 0.9rem !important;
  background: var(--white) !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.wc-block-components-totals-coupon__button {
  background: var(--green-dark) !important;
  color: var(--white) !important;
  font-weight: 600 !important;
  font-size: 0.83rem !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  padding: 10px 20px !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  white-space: nowrap !important;
}
.wc-block-components-totals-coupon__button:hover {
  background: var(--green-mid) !important;
}

/* ── Payment methods ────────────────────────────────────────── */
.wc-block-components-radio-control-accordion-option {
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  margin-bottom: 10px !important;
  background: var(--cream) !important;
  transition: border-color 0.2s, background 0.2s !important;
}
.wc-block-components-radio-control-accordion-option--checked {
  border-color: var(--green-fresh) !important;
  background: var(--white) !important;
}
.wc-block-components-radio-control-accordion-option__content {
  padding: 14px 16px !important;
}

/* ── Place Order button ─────────────────────────────────────── */
.wc-block-components-checkout-place-order-button,
.wc-block-checkout__place-order .wc-block-components-button {
  background: var(--green-dark) !important;
  color: var(--white) !important;
  border-radius: 50px !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  letter-spacing: 0.02em !important;
  padding: 16px 32px !important;
  width: 100% !important;
  border: none !important;
  cursor: pointer !important;
  transition: background 0.2s, transform 0.2s !important;
  margin-top: 4px !important;
}
.wc-block-components-checkout-place-order-button:hover {
  background: var(--green-fresh) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(69,176,0,0.25) !important;
}

/* Cancellation policy injected above Place Order */
.checkout-cancel-policy {
  font-size: 0.78rem;
  color: #555;
  line-height: 1.6;
  padding: 10px 14px;
  background: #f9f7f4;
  border-left: 3px solid #c8b89a;
  border-radius: 0 4px 4px 0;
  margin-bottom: 12px;
}

/* Trust / privacy note */
.wc-block-checkout__privacy-policy {
  font-size: 0.74rem !important;
  color: var(--text-light) !important;
  text-align: center !important;
  margin-top: 14px !important;
  line-height: 1.6 !important;
}
.wc-block-checkout__privacy-policy a { color: var(--green-dark) !important; }

/* ═══════════════════════════════════════════
   WooCommerce GLOBAL OVERRIDES
═══════════════════════════════════════════ */
.woocommerce .button,
.woocommerce button.button,
.woocommerce input[type="submit"] {
  background: var(--green-dark) !important;
  color: var(--white) !important;
  border-radius: 50px !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  padding: 11px 24px !important;
  border: none !important;
  transition: var(--transition) !important;
}
.woocommerce .button:hover { background: var(--green-mid) !important; transform: translateY(-1px) !important; }
.woocommerce .price { color: var(--green-dark) !important; font-weight: 700 !important; }
.woocommerce .star-rating span::before { color: #F5A623 !important; }
.woocommerce-notices-wrapper { margin-bottom: 24px; }
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  display: block !important;
  list-style: none !important;
  width: 100% !important;
  padding: 14px 20px !important;
  margin: 0 0 12px !important;
  border-top: 4px solid var(--green-fresh) !important;
  border-radius: var(--radius-sm) !important;
  font-size: 0.88rem !important;
  font-weight: 500 !important;
  color: var(--charcoal) !important;
  clear: both !important;
  position: relative !important;
}
.woocommerce-message, .woocommerce-info {
  background: var(--green-tint) !important;
  border-top-color: var(--green-fresh) !important;
}
.woocommerce-error {
  background: #FEF0F0 !important;
  border-top-color: var(--red-sale) !important;
}
.woocommerce-message .button.wc-forward,
.woocommerce-message a.button {
  float: right !important;
  margin: -3px 0 0 20px !important;
  padding: 6px 16px !important;
  font-size: 0.8rem !important;
  border-radius: 50px !important;
}

/* ═══════════════════════════════════════════
   BEST SELLER PAGE
═══════════════════════════════════════════ */
.bestseller-page-section { background: var(--cream); padding: 48px 0 80px; }

/* ═══════════════════════════════════════════
   BLOG — Listing + Single
═══════════════════════════════════════════ */

/* Hero */
.blog-hero {
  background: linear-gradient(135deg, var(--green-dark) 0%, #003d10 100%);
  padding: 90px 0 56px;
  text-align: center;
}
.blog-hero .section-eyebrow { color: rgba(255,255,255,0.6); }
.blog-hero h1 {
  color: var(--white);
  font-size: clamp(1.8rem, 4vw, 3rem);
  margin: 10px 0 16px;
}
.blog-hero h1 em { color: var(--beige); font-style: normal; }
.blog-hero p { color: rgba(255,255,255,0.72); font-size: 0.95rem; max-width: 540px; margin: 0 auto; }

/* Listing section */
.blog-listing-section { background: var(--cream); padding: 60px 0 90px; }

/* Grid */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.blog-grid--3 { grid-template-columns: repeat(3, 1fr); }

/* Card */
.blog-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  border: 1.5px solid var(--border);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.blog-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0,91,27,0.10);
  border-color: var(--green-fresh);
}

/* Card image */
.blog-card-img-wrap {
  display: block;
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--cream);
  flex-shrink: 0;
}
.blog-card-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
  display: block;
}
.blog-card:hover .blog-card-img-wrap img { transform: scale(1.04); }

/* Placeholder when no image */
.blog-card-img-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: var(--green-tint);
  color: var(--green-dark);
}
.blog-card-img-placeholder svg { width: 48px; height: 48px; opacity: 0.5; }

/* Category badge on image */
.blog-card-cat {
  position: absolute;
  top: 12px; left: 12px;
  background: var(--green-dark);
  color: var(--white);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 20px;
}

/* Card body */
.blog-card-body {
  padding: 22px 24px 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Meta (date · category) */
.blog-card-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  color: var(--text-light);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 10px;
}
.blog-card-meta time { color: var(--text-light); }
.blog-meta-sep { color: var(--border); }
.blog-meta-cat {
  color: var(--green-dark);
  font-weight: 600;
  text-decoration: none;
}
.blog-meta-cat:hover { color: var(--green-fresh); }

/* Title */
.blog-card-title {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.45;
  margin: 0 0 10px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.blog-card-title a {
  color: var(--charcoal);
  text-decoration: none;
  transition: color 0.2s;
}
.blog-card-title a:hover { color: var(--green-dark); }

/* Excerpt */
.blog-card-excerpt {
  font-size: 0.83rem;
  color: var(--text-muted);
  line-height: 1.65;
  margin: 0 0 16px;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Read more link */
.blog-card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--green-dark);
  text-decoration: none;
  margin-top: auto;
  transition: gap 0.2s, color 0.2s;
}
.blog-card-link:hover { color: var(--green-fresh); gap: 10px; }

/* Pagination */
.blog-pagination { margin-top: 56px; display: flex; justify-content: center; }
.blog-pagination ul {
  display: inline-flex; gap: 6px; list-style: none; padding: 0; margin: 0;
}
.blog-pagination ul li a,
.blog-pagination ul li span {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border-radius: var(--radius-sm);
  border: 1.5px solid var(--border);
  background: var(--white);
  font-size: 0.85rem; font-weight: 600; color: var(--charcoal);
  text-decoration: none; transition: all 0.2s;
}
.blog-pagination ul li a:hover { border-color: var(--green-fresh); color: var(--green-dark); }
.blog-pagination ul li span.current {
  background: var(--green-dark); color: var(--white); border-color: var(--green-dark);
}
.blog-pagination ul li .prev, .blog-pagination ul li .next {
  width: auto; padding: 0 16px;
}

/* Empty state */
.blog-empty {
  text-align: center;
  padding: 80px 20px;
}
.blog-empty-icon {
  width: 72px; height: 72px;
  background: var(--green-tint);
  border-radius: 20px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
  color: var(--green-dark);
}
.blog-empty-icon svg { width: 36px; height: 36px; }
.blog-empty h3 { font-size: 1.2rem; margin-bottom: 8px; }
.blog-empty p  { font-size: 0.88rem; color: var(--text-muted); }

/* ─── Single Post ────────────────────────────────────────────── */

/* Breadcrumb */
.blog-breadcrumb {
  background: var(--cream);
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
}
.blog-breadcrumb .container {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.78rem; color: var(--text-light); flex-wrap: wrap;
}
.blog-breadcrumb a { color: var(--text-muted); text-decoration: none; transition: color 0.2s; }
.blog-breadcrumb a:hover { color: var(--green-dark); }
.blog-breadcrumb span:last-child { color: var(--charcoal); font-weight: 500; }

/* Post header */
.post-header {
  background: var(--white);
  padding: 56px 20px 48px;
  text-align: center;
}
.post-cat-badge {
  display: inline-block;
  background: var(--green-tint);
  color: var(--green-dark);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  text-decoration: none;
  margin-bottom: 18px;
}
.post-title {
  font-size: clamp(1.6rem, 4vw, 2.6rem);
  font-weight: 800;
  line-height: 1.3;
  color: var(--charcoal);
  margin-bottom: 20px;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.post-meta-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}
.post-date, .post-read-time {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.8rem; color: var(--text-muted);
}

/* Featured image */
.post-featured-img {
  background: var(--cream);
  padding: 0 20px 48px;
}
.post-featured-img img {
  width: 100%;
  border-radius: var(--radius-lg);
  display: block;
  max-height: 540px;
  object-fit: cover;
}

/* Post content */
.post-content-wrap {
  background: var(--white);
  padding: 48px 20px 60px;
}
.post-content {
  font-size: 1rem;
  line-height: 1.85;
  color: var(--charcoal);
}
.post-content h2 {
  font-size: 1.4rem; margin: 36px 0 14px; color: var(--charcoal);
}
.post-content h3 {
  font-size: 1.15rem; margin: 28px 0 10px; color: var(--charcoal);
}
.post-content p { margin-bottom: 20px; }
.post-content ul, .post-content ol {
  padding-left: 24px; margin-bottom: 20px; display: flex; flex-direction: column; gap: 8px;
}
.post-content img {
  max-width: 100%; border-radius: var(--radius-md); margin: 24px 0; display: block;
}
.post-content blockquote {
  border-left: 4px solid var(--green-fresh);
  margin: 28px 0; padding: 16px 20px;
  background: var(--green-tint);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-style: italic; color: var(--green-dark);
}
.post-content a { color: var(--green-dark); font-weight: 500; }
.post-content a:hover { color: var(--green-fresh); }
.post-content strong { font-weight: 700; color: var(--charcoal); }

/* Tags */
.post-tags {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap;
  margin: 36px 0 0;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}
.post-tags-label { font-size: 0.78rem; font-weight: 700; color: var(--charcoal); }
.post-tag {
  display: inline-block;
  background: var(--cream);
  border: 1.5px solid var(--border);
  color: var(--text-muted);
  font-size: 0.72rem; font-weight: 600;
  padding: 4px 12px; border-radius: 20px;
  text-decoration: none; transition: all 0.2s;
}
.post-tag:hover { border-color: var(--green-fresh); color: var(--green-dark); }

/* Prev / Next navigation */
.post-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 40px;
  padding-top: 28px;
  border-top: 1px solid var(--border);
}
.post-nav-link {
  display: flex; flex-direction: column; gap: 4px;
  padding: 16px 18px;
  background: var(--cream);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: all 0.2s;
}
.post-nav-link:hover { border-color: var(--green-fresh); background: var(--white); }
.post-nav-next { text-align: right; }
.pnl-dir { font-size: 0.7rem; font-weight: 700; color: var(--green-dark); text-transform: uppercase; letter-spacing: 0.06em; }
.pnl-title {
  font-size: 0.85rem; font-weight: 600; color: var(--charcoal);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* Related posts */
.related-posts-section { background: var(--cream); padding: 60px 0 80px; }

/* Back to blog */
.blog-back-cta { background: var(--white); padding: 20px 0 40px; }

/* ─── Blog responsive ────────────────────────────────────────── */
@media (max-width: 1024px) {
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .blog-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .blog-grid, .blog-grid--3 { grid-template-columns: 1fr; }
  .post-nav { grid-template-columns: 1fr; }
  .post-header { padding: 40px 20px 32px; }
}

/* ═══════════════════════════════════════════
   SCROLL ANIMATIONS
═══════════════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media (max-width: 1200px) {
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; }
  .footer-grid > *:nth-child(4) { grid-column: 1; }
  .footer-grid > *:nth-child(5) { grid-column: 2; }
  .why-grid { grid-template-columns: repeat(4,1fr); }
  /* Intermediate 3-column step for products/categories before full collapse at 1024px */
  .categories-grid { grid-template-columns: repeat(3, 1fr); }
  .products-grid   { grid-template-columns: repeat(3, 1fr); }
  .wishlist-grid   { grid-template-columns: repeat(3, 1fr); }
  /* Slightly tighter nav links so they fit without wrapping */
  .primary-nav > li > a { padding: 6px 11px; font-size: 0.83rem; }
}
@media (max-width: 1024px) {
  .brand-story-layout, .product-layout { grid-template-columns: 1fr; }
  .hero-section { min-height: auto; padding: 72px 0 80px; }
  .categories-grid, .products-grid { grid-template-columns: repeat(2,1fr); }
  .why-grid { grid-template-columns: repeat(2,1fr); }
  .reviews-grid { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .shop-layout { grid-template-columns: 1fr; }
  .product-gallery { position: static; }
  .shop-sidebar { position: static; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .cart-layout, .checkout-layout { grid-template-columns: 1fr; }
  .account-grid { grid-template-columns: 1fr; }
  .contact-layout { grid-template-columns: 1fr; }
  .policy-layout { grid-template-columns: 1fr; }
  .policy-toc { position: static; }
  .about-stats { grid-template-columns: 1fr 1fr; }
  .about-features-grid { grid-template-columns: 1fr 1fr; }
  .about-promise { flex-direction: column; text-align: center; }
  .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; }
  .my-account-wrap { grid-template-columns: 1fr; }
  .account-nav { position: static; }
  .wishlist-grid { grid-template-columns: repeat(2,1fr); }
  /* Header: shrink logo and hide search bar — 7 nav links won't fit alongside search */
  .site-logo .logo-img { height: 90px; }
  .header-search-wrap { display: none; }
  /* Brand story: reduce image height when stacked */
  .brand-story-layout { gap: 40px; }
  .brand-story-img { min-height: 320px; }
  /* Hero carousel: allow more width when the right column is gone */
  .hero-carousel { max-width: 100%; }
}
@media (max-width: 768px) {
  /* Reviews */
  .reviews-summary { flex-direction: column; gap: 20px; padding: 18px; }
  .reviews-avg-block { display: flex; align-items: center; gap: 14px; text-align: left; }
  .reviews-avg-stars { margin: 0; }
  .write-review-section { padding: 20px 18px; }

  /* Nav */
  .primary-nav, .header-search-wrap { display: none; }
  .hamburger { display: flex; }

  /* Logo — slightly larger on tablet/mobile per user request */
  .site-logo .logo-img { height: 85px; }
  .logo-text { font-size: 1.9rem; }

  /* Footer brand — center-align on single-column mobile layout */
  .footer-brand { text-align: center; }
  .footer-brand p { max-width: 100%; margin-left: auto; margin-right: auto; }
  .footer-brand .logo-img { margin: 0 auto; }
  .footer-brand .site-logo { justify-content: center; }
  .footer-social { justify-content: center; }
  .footer-business { text-align: left; display: inline-block; }

  /* Section vertical padding */
  .section-pad { padding: 48px 0; }
  .section-pad-sm { padding: 36px 0; }

  /* Hero */
  .hero-section { min-height: auto; padding: 56px 0 64px; }
  .hero-btns { flex-direction: column; align-items: center; }
  .hero-trust { gap: 10px; }

  /* Grids */
  .section-header-row { flex-direction: column; align-items: flex-start; }
  .categories-grid { grid-template-columns: 1fr 1fr; }
  .why-grid { grid-template-columns: 1fr 1fr; }
  .reviews-grid { grid-template-columns: 1fr; }

  /* Footer — clear nth-child overrides from 1200px rule before going 1-col */
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .footer-grid > *:nth-child(4),
  .footer-grid > *:nth-child(5) { grid-column: auto; }
  .footer-bottom { flex-direction: column; text-align: center; }

  /* Brand story */
  .brand-story-list { grid-template-columns: 1fr; }
  .brand-story-img { min-height: 260px; }
  .brand-story-layout { gap: 28px; }

  /* WooCommerce products */
  .woocommerce ul.products { grid-template-columns: 1fr 1fr !important; }

  /* Cart table — horizontal scroll with fade hint on right edge */
  .cart-box { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .cart-box:not(:hover) {
    -webkit-mask-image: linear-gradient(to right, black 85%, transparent 100%);
    mask-image: linear-gradient(to right, black 85%, transparent 100%);
  }
  .cart-items-table { min-width: 520px; }

  /* Cart/checkout card padding — reduce for mobile viewports */
  .cart-box, .cart-summary-box { padding: 20px 18px; }
  .checkout-card { padding: 20px 18px; }
  .account-card { padding: 24px 18px; }

  /* Coupon row */
  .coupon-row { flex-wrap: wrap; }
  .coupon-input { flex: 1; width: auto; min-width: 120px; }

  /* Single product actions */
  .btn-buynow { flex: 1 1 100%; text-align: center; }

  /* Product tabs — fade right edge to signal horizontal scrollability */
  .product-tabs-nav {
    -webkit-mask-image: linear-gradient(to right, black 80%, transparent 100%);
    mask-image: linear-gradient(to right, black 80%, transparent 100%);
    scrollbar-width: none;
  }
  .product-tabs-nav::-webkit-scrollbar { display: none; }

  /* Button tap targets — ensure 44px minimum on touch screens */
  .btn { min-height: 44px; }
  .btn-sm { min-height: 40px; }
  .header-icon-btn { width: 44px; height: 44px; }
  .toc-cancel-btn { min-height: 36px; padding: 8px 14px; }
  .track-toggle-btn { min-height: 40px; padding: 10px 18px; }

  /* Order tracking form — stack on tablet */
  .tracking-input-row { flex-direction: column; }
  #trackBtn { width: 100%; justify-content: center; }
  .tracking-card-header { flex-direction: column; gap: 12px; }

  /* About */
  .about-stats { grid-template-columns: 1fr; }
  .about-features-grid { grid-template-columns: 1fr; }
  .about-promise { padding: 32px 24px; }
  .about-hero { padding: 64px 0 40px; }

  /* Contact */
  .contact-layout { padding: 40px 0 60px; }

  /* Banners & heroes */
  .wellness-banner { padding: 48px 0; }
  .page-hero, .policy-hero, .blog-hero, .shop-banner { padding: 60px 0 40px; }

  /* Forms */
  .form-row-2 { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  /* Logo — keep shrinking on small phones but stay readable */
  .site-logo .logo-img { height: 72px; }
  .logo-text { font-size: 1.6rem; }

  /* Hide large decorative pseudo-elements that overflow on small screens */
  .hero-section::before, .hero-section::after,
  .why-section::before { display: none; }

  /* Bump sub-12px text labels to stay readable */
  .section-eyebrow { font-size: 0.75rem; }
  .product-badge { font-size: 0.72rem; }

  /* Section padding */
  .section-pad { padding: 36px 0; }
  .section-pad-sm { padding: 28px 0; }

  /* Grids */
  .categories-grid { grid-template-columns: 1fr; }
  .products-grid { grid-template-columns: 1fr 1fr; }
  .wishlist-grid { grid-template-columns: 1fr; }
  .shop-sidebar { grid-template-columns: 1fr; }
  /* FIX: why-grid feature cards need full width on small phones — was incorrectly 1fr 1fr */
  .why-grid { grid-template-columns: 1fr; }

  /* Announcement bar */
  .announcement-bar { font-size: 0.72rem; }
  .announcement-item { padding: 0 32px; }
  .announcement-track { animation-duration: 16s; }

  /* Trust badges */
  .hero-trust { gap: 8px; }
  .trust-badge { font-size: 0.68rem; }

  /* Hero — tighter vertical space on small phones */
  .hero-section { padding: 32px 0 40px; }

  /* Card padding — reduce further for small screens */
  .cart-box, .cart-summary-box { padding: 16px 14px; }
  .checkout-card { padding: 16px 14px; }
  .account-card { padding: 20px 16px; }
  .tracking-card { padding: 24px 18px; }

  /* Cart table — slightly narrower so less scroll needed on phones */
  .cart-items-table { min-width: 460px; }
  .cart-product-img { width: 52px; height: 52px; }
  .cart-product-name { font-size: 0.8rem; }
  .cart-price, .cart-subtotal { font-size: 0.88rem; }

  /* Product actions — stack on very small screens */
  .product-actions input.qty { width: 52px !important; }
  .product-actions .single_add_to_cart_button,
  .product-actions .btn-atc { flex: 1; }
  .btn-buynow { width: 100%; text-align: center; }

  /* About promise */
  .about-promise { padding: 28px 20px; }

  /* WooCommerce product loop — keep 2 cols at 480px, readable at ~200px each */
  .woocommerce ul.products { grid-template-columns: 1fr 1fr !important; }
}

/* Extra-small phones (≤ 360px) — safety net for very narrow viewports */
@media (max-width: 360px) {
  /* Product/wishlist cards become single column — 2 cols would be ~155px each, too tight */
  .products-grid, .wishlist-grid { grid-template-columns: 1fr; }
  .woocommerce ul.products { grid-template-columns: 1fr !important; }
  /* Hero buttons stack full-width */
  .hero-btns { flex-direction: column; align-items: stretch; }
  .hero-btns .btn { text-align: center; }
  /* Minimal box padding */
  .cart-box, .cart-summary-box,
  .checkout-card, .account-card { padding: 14px 12px; }
  /* Reduce header inner gap */
  .header-inner { gap: 16px; }
  /* Logo — min usable size on 360px */
  .site-logo .logo-img { height: 62px; }
  /* Tracking toggle — stack vertically so buttons don't overflow */
  .tracking-toggle { flex-direction: column; }
  .track-toggle-btn { width: 100%; justify-content: center; }
  /* Wellness banner tighter padding */
  .wellness-banner { padding: 36px 0; }
  /* Footer business info — word wrap long email */
  .footer-business a { word-break: break-all; }
  /* Contact upload zone — reduce padding on tiny screens */
  .upload-zone-inner { padding: 20px 12px; }
  /* Hero trust badges — wrap tighter */
  .trust-badge { font-size: 0.65rem; padding: 4px 8px; }
}

/* ═══════════════════════════════════════════
   PINCODE DELIVERY WIDGET (cart)
═══════════════════════════════════════════ */
.farmsala-pincode-widget {
  background: var(--cream);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 18px 20px;
  margin-bottom: 20px;
}
.pincode-widget-title {
  display: flex; align-items: center; gap: 7px;
  font-size: 0.88rem; font-weight: 700; color: var(--charcoal);
  margin: 0 0 14px;
}
.pincode-input-row {
  display: flex; gap: 8px;
}
.pincode-input-row input {
  flex: 1; height: 40px; padding: 0 12px;
  border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  font-size: 0.88rem; font-family: inherit;
  transition: border-color 0.2s;
}
.pincode-input-row input:focus { outline: none; border-color: var(--green-fresh); }
.pincode-input-row button {
  height: 40px; padding: 0 18px;
  background: var(--green-dark); color: var(--white);
  border: none; border-radius: var(--radius-sm);
  font-size: 0.83rem; font-weight: 600; cursor: pointer;
  transition: background 0.2s, opacity 0.2s;
}
.pincode-input-row button:hover  { background: var(--green-fresh); }
.pincode-input-row button:disabled { opacity: 0.6; cursor: wait; }
.pincode-result {
  display: none; align-items: center; gap: 6px;
  margin-top: 10px; font-size: 0.82rem; font-weight: 500; border-radius: 6px; padding: 8px 12px;
}
.pincode-result.pincode-ok, .pincode-result.pincode-fail { display: flex; }
.pincode-result.pincode-ok   { background: #f0fdf4; color: #15803d; }
.pincode-result.pincode-fail { background: #fef2f2; color: #b91c1c; }

/* ═══════════════════════════════════════════
   ORDER TRACKING PAGE
═══════════════════════════════════════════ */
.tracking-page-wrap {
  max-width: 700px;
  padding-top: 56px;
  padding-bottom: 80px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.tracking-card {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 36px 40px;
}
.tracking-card-header {
  display: flex; align-items: flex-start; gap: 18px; margin-bottom: 28px;
}
.tracking-card-icon {
  flex-shrink: 0; width: 52px; height: 52px;
  background: var(--green-tint); border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  color: var(--green-dark);
}
.tracking-card-icon svg { width: 26px; height: 26px; }
.tracking-card-header h3 { font-size: 1.15rem; margin: 0 0 4px; }
.tracking-card-header p  { font-size: 0.84rem; color: var(--text-muted); margin: 0; }

.tracking-toggle {
  display: flex; gap: 8px; margin-bottom: 20px;
}
.track-toggle-btn {
  padding: 8px 18px; border-radius: 50px; border: 1.5px solid var(--border);
  background: var(--white); font-size: 0.82rem; font-weight: 600;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s;
  font-family: 'Poppins', sans-serif;
}
.track-toggle-btn.active {
  background: var(--green-dark); color: var(--white); border-color: var(--green-dark);
}
.track-toggle-btn:hover:not(.active) {
  border-color: var(--green-fresh); color: var(--green-dark);
}

.tracking-input-row {
  display: flex; gap: 10px; align-items: stretch;
}
#emailWrap { flex: 1; }
.tracking-email-input {
  width: 100%; min-height: 44px; height: 52px;
  border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  padding: 0 16px; font-family: 'Poppins', sans-serif;
  font-size: 0.9rem; color: var(--charcoal);
  background: var(--white); box-sizing: border-box;
  transition: border-color 0.2s; outline: none;
}
.tracking-email-input:focus { border-color: var(--green-fresh); }
.tracking-phone-wrap {
  flex: 1; display: flex; align-items: center;
  border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  overflow: hidden; transition: border-color 0.2s;
}
.tracking-phone-wrap:focus-within { border-color: var(--green-fresh); }
.tracking-phone-prefix {
  padding: 0 12px; background: var(--cream); color: var(--text-muted);
  font-size: 0.88rem; font-weight: 600; border-right: 1.5px solid var(--border);
  white-space: nowrap; line-height: 46px;
}
.tracking-phone-wrap input {
  flex: 1; border: none; outline: none; padding: 0 14px;
  font-size: 0.95rem; font-family: inherit; background: transparent;
  height: 46px;
}
#trackBtn {
  display: flex; align-items: center; gap: 8px;
  white-space: nowrap; height: 50px; padding: 0 24px;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* result area */
.tracking-loading {
  display: flex; align-items: center; gap: 10px;
  color: var(--text-muted); font-size: 0.88rem; margin-top: 20px;
}
.tracking-spinner {
  width: 18px; height: 18px;
  border: 2.5px solid var(--border);
  border-top-color: var(--green-dark);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  flex-shrink: 0;
}
.tracking-found-title {
  font-size: 0.82rem; color: var(--text-muted); margin: 20px 0 12px;
}
.tracking-msg {
  display: flex; align-items: flex-start; gap: 8px;
  margin-top: 18px; padding: 14px 16px; border-radius: var(--radius-sm);
  font-size: 0.88rem; font-weight: 500; line-height: 1.5;
}
.tracking-err { background: #fef2f2; color: #b91c1c; }

/* individual order cards */
.tracking-order-card {
  border: 1.5px solid var(--border); border-radius: var(--radius-md);
  padding: 20px 22px; margin-bottom: 12px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.tracking-order-card:hover {
  border-color: var(--green-fresh);
  box-shadow: 0 4px 20px rgba(0,91,27,0.07);
}
.toc-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 14px;
}
.toc-id   { font-size: 0.95rem; font-weight: 700; color: var(--charcoal); }
.toc-date { font-size: 0.78rem; color: var(--text-light); margin-top: 2px; }
.toc-badge {
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.03em;
  padding: 4px 10px; border-radius: 20px; white-space: nowrap;
}
.toc-items {
  list-style: none; padding: 0; margin: 0 0 14px;
  border-top: 1px solid var(--border); padding-top: 12px;
}
.toc-items li {
  font-size: 0.84rem; color: var(--text-muted);
  padding: 3px 0;
}
.toc-footer {
  display: flex; justify-content: space-between; align-items: center;
  border-top: 1px solid var(--border); padding-top: 12px;
}
.toc-total { font-size: 0.92rem; font-weight: 700; color: var(--charcoal); }
.toc-footer-actions { display: flex; align-items: center; gap: 14px; }
.toc-link  {
  font-size: 0.82rem; font-weight: 600; color: var(--green-dark);
  text-decoration: none; transition: color 0.2s;
}
.toc-link:hover { color: var(--green-fresh); }
.toc-cancel-btn {
  font-size: 0.78rem; font-weight: 600; color: #EF4444;
  background: none; border: 1.5px solid #EF444466; border-radius: 20px;
  padding: 4px 12px; cursor: pointer; transition: background 0.2s, border-color 0.2s;
  font-family: 'Poppins', sans-serif;
}
.toc-cancel-btn:hover   { background: #EF444412; border-color: #EF4444; }
.toc-cancel-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.toc-no-cancel  { font-size: 0.75rem; color: var(--text-light); font-style: italic; }
.toc-cancelled-msg { font-size: 0.78rem; color: #EF4444; font-weight: 600; }
.toc-tracking-row {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--cream); border-radius: var(--radius-sm);
  padding: 8px 12px; margin-bottom: 12px; gap: 12px;
}
.toc-awb { font-size: 0.78rem; font-weight: 600; color: var(--text-muted); font-family: monospace; }
.toc-track-link {
  font-size: 0.78rem; font-weight: 700; color: var(--green-dark);
  text-decoration: none; white-space: nowrap; transition: color 0.2s;
}
.toc-track-link:hover { color: var(--green-fresh); }

.tracking-help {
  background: var(--cream); border-radius: var(--radius-md);
  padding: 22px 28px; border-left: 3px solid var(--green-fresh);
}
.tracking-help h4 { font-size: 0.88rem; margin: 0 0 6px; }
.tracking-help p  { font-size: 0.83rem; color: var(--text-muted); margin: 0; line-height: 1.7; }
.tracking-help a  { color: var(--green-dark); font-weight: 600; }

@media (max-width: 640px) {
  .tracking-card { padding: 24px 20px; }
  /* tracking-input-row stack + trackBtn full-width + card-header column already handled at 768px */
  .toc-footer { flex-direction: column; align-items: flex-start; gap: 10px; }
  .toc-footer-actions { width: 100%; justify-content: space-between; }
}

/* ═══════════════════════════════════════════
   RESPONSIVE REFINEMENTS
═══════════════════════════════════════════ */

/* ── Tablet (≤ 768px) ── */
@media (max-width: 768px) {
  /* Section subtitle: remove fixed max-width so it fills container on narrow screens */
  .section-subtitle { max-width: 100%; }

  /* Footer brand paragraph: was capped at 260px, looks odd on centered 1-col mobile */
  .footer-brand p { max-width: 100%; }

  /* Single product price block: allow price + MRP + badge to wrap instead of overflow */
  .product-price-block { flex-wrap: wrap; gap: 8px; }

  /* Category grid: ensure equal columns don't shrink below readable width */
  .categories-grid { gap: 16px; }

  /* Why-card text: slightly tighter on tablet */
  .why-card { padding: 28px 20px; }
}

/* ── Small phones (≤ 480px) ── */
@media (max-width: 480px) {
  /* Product cards are 2-col (~170px each) — tighten internal spacing */
  .product-body { padding: 10px 10px 14px; }
  .product-name { font-size: 0.82rem; }
  .product-price { font-size: 0.95rem; }
  .product-price-wrap { flex-wrap: wrap; gap: 4px; }
  .product-discount { font-size: 0.65rem; }
  .btn-atc { padding: 8px 10px; font-size: 0.72rem; gap: 3px; }
  .product-wishlist-btn { width: 28px; height: 28px; }

  /* Category cards become full-width — taller image looks better */
  .cat-card-img { height: 220px; }
  .cat-card-body { padding: 14px 16px 18px; }
  .cat-card-name { font-size: 1.1rem; }

  /* Variant pills wrap tightly */
  .product-variants { gap: 4px; }

  /* Section spacing */
  .bestsellers-section { padding: 48px 0; }
  .categories-section { padding: 48px 0; }

  /* Gallery thumbs slightly smaller */
  .gallery-thumb { width: 58px; height: 58px; }

  /* Footer newsletter form stack */
  .newsletter-form { flex-direction: column; gap: 10px; }
  .newsletter-form input,
  .newsletter-form button { width: 100%; }
}
