/*
Theme Name: Africa Agribusiness Market
Theme URI: https://aagrimarket.com
Author: Africa Agribusiness Market
Author URI: https://aagrimarket.com
Description: A clean, professional agricultural marketplace theme for Africa Agribusiness Market (aagrimarket.com). Showcases farm inputs across 4 categories: Fertilizers, Seeds, Agrochemicals, and Machinery & Equipment.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aagrimarket
Tags: agriculture, marketplace, custom-menu, featured-images, responsive-layout
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --color-dark:        hsl(30, 15%, 10%);
  --color-dark-deep:   hsl(30, 15%, 8%);
  --color-gold:        hsl(46, 85%, 40%);
  --color-gold-hover:  hsl(46, 85%, 33%);
  --color-gold-light:  hsl(46, 85%, 60%);
  --color-gold-pale:   hsla(46, 85%, 40%, 0.15);
  --color-gold-border: hsla(46, 85%, 40%, 0.35);
  --color-cream:       hsl(0, 0%, 98%);
  --color-white:       #ffffff;
  --color-border:      hsl(40, 20%, 85%);
  --color-border-light:hsl(40, 20%, 92%);
  --color-text:        hsl(30, 15%, 12%);
  --color-text-muted:  hsl(30, 10%, 45%);
  --color-text-light:  hsl(30, 10%, 65%);
  --color-secondary:   hsl(40, 30%, 94%);

  --font-sans:   'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-serif:  'Georgia', 'Times New Roman', serif;

  --radius-sm:   6px;
  --radius:      10px;
  --radius-lg:   14px;
  --radius-xl:   20px;

  --shadow-sm:   0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);
  --shadow:      0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:   0 10px 40px rgba(0,0,0,.14);
  --shadow-gold: 0 4px 20px hsla(46, 85%, 40%, .30);

  --transition:  all 0.25s ease;
  --container:   1200px;
  --gap:         1.5rem;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-white);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

img { max-width: 100%; height: auto; display: block; }

a { color: inherit; text-decoration: none; }

ul, ol { list-style: none; }

button, input, textarea, select {
  font-family: inherit;
  font-size: inherit;
}

main { flex: 1; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5 {
  font-family: var(--font-serif);
  line-height: 1.2;
  color: var(--color-text);
}

h1 { font-size: clamp(1.75rem, 4vw, 3.25rem); }
h2 { font-size: clamp(1.5rem,  3vw, 2.25rem); }
h3 { font-size: clamp(1.15rem, 2vw, 1.5rem);  }
h4 { font-size: 1.1rem; }

p { color: var(--color-text-muted); line-height: 1.75; }

.label-tag {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-gold-light);
  margin-bottom: .75rem;
}

/* ============================================================
   LAYOUT
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 1.25rem;
}

@media (min-width: 640px)  { .container { padding-inline: 1.75rem; } }
@media (min-width: 1024px) { .container { padding-inline: 2rem; } }

.section-pad    { padding-block: 5rem; }
.section-pad-sm { padding-block: 3.5rem; }

.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--gap); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap); }

@media (max-width: 1023px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .grid-4, .grid-3, .grid-2 { grid-template-columns: 1fr; }
  .section-pad    { padding-block: 3.5rem; }
  .section-pad-sm { padding-block: 2.5rem; }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1.5rem;
  font-weight: 600;
  font-size: .93rem;
  border-radius: var(--radius);
  border: none;
  cursor: pointer;
  transition: var(--transition);
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-gold {
  background: var(--color-gold);
  color: #fff;
}
.btn-gold:hover { background: var(--color-gold-hover); }

.btn-outline {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.3);
}
.btn-outline:hover { border-color: rgba(255,255,255,.65); background: rgba(255,255,255,.07); }

.btn-dark {
  background: var(--color-dark);
  color: #fff;
}
.btn-dark:hover { background: hsl(30, 15%, 17%); }

.btn-lg { padding: .9rem 2rem; font-size: 1rem; }

.btn svg, .btn .icon { width: 1em; height: 1em; flex-shrink: 0; }

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar {
  background: var(--color-gold);
  color: #fff;
  font-size: .8rem;
  padding: .45rem 0;
}
.topbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.topbar a { color: #fff; font-weight: 600; }
.topbar a:hover { text-decoration: underline; }
.topbar-phones { display: flex; align-items: center; gap: .5rem; opacity: .9; flex-wrap: wrap; }
.topbar-phones span { opacity: .6; }
.topbar-email { opacity: .9; }

@media (max-width: 639px) {
  .topbar { padding: .35rem 0; }
  .topbar-inner { justify-content: center; }
  .topbar-email { display: none; }
  .topbar-label { display: none; }
  .topbar-phones { gap: .4rem; font-size: .78rem; justify-content: center; }
}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--color-dark);
  border-bottom: 2px solid var(--color-gold);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 68px;
}
@media (min-width: 768px) { .header-inner { height: 80px; } }

.site-logo img {
  height: 44px;
  width: auto;
}
@media (min-width: 768px) { .site-logo img { height: 56px; } }
.site-logo:hover { opacity: .85; }

/* Desktop Nav */
.primary-nav {
  display: none;
}
@media (min-width: 768px) {
  .primary-nav {
    display: flex;
    align-items: center;
    gap: .25rem;
  }
}

.primary-nav a,
.primary-nav .nav-dropdown-trigger {
  display: flex;
  align-items: center;
  gap: .3rem;
  padding: .55rem .85rem;
  font-size: .9rem;
  font-weight: 500;
  color: rgba(255,255,255,.7);
  border-radius: var(--radius-sm);
  transition: var(--transition);
  cursor: pointer;
  white-space: nowrap;
  background: none;
  border: none;
  font-family: var(--font-sans);
}

.primary-nav a:hover,
.primary-nav .nav-dropdown-trigger:hover,
.primary-nav a.active,
.primary-nav .nav-dropdown-trigger.active {
  color: #fff;
  background: rgba(255,255,255,.07);
}

.primary-nav a.current-menu-item,
.primary-nav a[aria-current="page"] {
  color: var(--color-gold-light);
}

.nav-dropdown-trigger svg { transition: transform .2s; }
.nav-dropdown-trigger[aria-expanded="true"] svg { transform: rotate(180deg); }

/* Dropdown */
.nav-dropdown {
  position: relative;
}
.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 210px;
  background: var(--color-dark);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius);
  padding: .4rem .4rem .6rem;
  padding-top: .65rem;
  box-shadow: var(--shadow-lg);
  z-index: 300;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown-menu:hover,
.nav-dropdown.open .nav-dropdown-menu {
  display: block;
}
.nav-dropdown-menu a {
  display: block;
  padding: .5rem .85rem;
  font-size: .87rem;
  color: rgba(255,255,255,.65);
  border-radius: var(--radius-sm);
  transition: var(--transition);
}
.nav-dropdown-menu a:hover { color: #fff; background: rgba(255,255,255,.06); }

/* Header CTA buttons */
.header-actions {
  display: none;
  align-items: center;
  gap: .6rem;
}
@media (min-width: 768px) { .header-actions { display: flex; } }

.header-actions .btn-whatsapp {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .5rem 1rem;
  font-size: .85rem;
  font-weight: 500;
  color: rgba(255,255,255,.7);
  border: 1.5px solid rgba(255,255,255,.2);
  border-radius: var(--radius);
  transition: var(--transition);
  background: none;
}
.header-actions .btn-whatsapp:hover {
  color: #fff;
  border-color: rgba(255,255,255,.45);
}

.header-actions .btn-quote {
  padding: .5rem 1.1rem;
  font-size: .85rem;
  font-weight: 600;
  background: var(--color-gold);
  color: #fff;
  border-radius: var(--radius);
  transition: var(--transition);
}
.header-actions .btn-quote:hover { background: var(--color-gold-hover); }

/* Hamburger — solid colours for reliable rendering on iOS Safari */
.hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: 44px;
  border: none;
  background: rgba(255,255,255,0.08);
  cursor: pointer;
  padding: 0;
  border-radius: var(--radius-sm);
  -webkit-appearance: none;
  appearance: none;
}
@media (min-width: 768px) { .hamburger { display: none; } }

.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: #ffffff;
  border-radius: 2px;
  transition: var(--transition);
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Menu */
.mobile-menu {
  display: none;
  background: hsl(30, 15%, 8%);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 1rem 0 1.5rem;
}
.mobile-menu.open { display: block; }

.mobile-menu a {
  display: block;
  padding: .75rem 1.25rem;
  font-size: 1rem;
  font-weight: 500;
  color: rgba(255,255,255,.75);
  border-radius: var(--radius-sm);
  margin-inline: .5rem;
  transition: var(--transition);
}
.mobile-menu a:hover,
.mobile-menu a.active { color: #fff; background: rgba(255,255,255,.06); }

.mobile-submenu { padding-left: 1.25rem; }
.mobile-submenu a { font-size: .9rem; color: rgba(255,255,255,.5); }

.mobile-menu-actions {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  padding: 1rem 1.25rem 0;
  border-top: 1px solid rgba(255,255,255,.08);
  margin-top: .75rem;
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero {
  position: relative;
  background: var(--color-dark);
  overflow: hidden;
  min-height: 85vh;
  display: flex;
  align-items: center;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: .42;
  transform: scale(1.04);
  animation: heroScale 8s ease-out forwards;
}
@keyframes heroScale {
  to { transform: scale(1); }
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right,
    hsla(30,15%,8%,.95) 0%,
    hsla(30,15%,8%,.72) 50%,
    transparent 100%);
}

.hero-content {
  position: relative;
  width: 100%;
  padding-block: 6rem;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .4rem .85rem;
  background: var(--color-gold-pale);
  border: 1px solid var(--color-gold-border);
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-gold-light);
  margin-bottom: 1.25rem;
  animation: fadeUp .6s ease .1s both;
}

.hero h1 {
  color: #fff;
  max-width: 580px;
  animation: fadeUp .75s ease .25s both;
}

.hero h1 em {
  font-style: italic;
  color: var(--color-gold-light);
}

.hero-desc {
  color: rgba(255,255,255,.7);
  max-width: 480px;
  margin-block: 1.25rem 2rem;
  animation: fadeUp .7s ease .4s both;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  animation: fadeUp .65s ease .55s both;
}

.hero-page {
  min-height: 50vh;
  align-items: center;
}
.hero-page .hero-bg { opacity: .45; }
.hero-page .hero-overlay {
  background: linear-gradient(to bottom,
    hsla(30,15%,8%,.4) 0%,
    hsla(30,15%,8%,.6) 100%);
}
.hero-page .hero-content {
  text-align: center;
  padding-block: 4.5rem;
}
.hero-page h1, .hero-page p { color: #fff; }
.hero-page .hero-label { color: var(--color-gold-light); }

/* Stats Bar */
.stats-bar {
  background: var(--color-dark);
  border-top: 1px solid rgba(255,255,255,.07);
  padding: 2.5rem 0;
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  text-align: center;
}
@media (max-width: 640px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
}
.stat-item { padding: .75rem; }
.stat-value {
  font-size: 2.25rem;
  font-weight: 800;
  color: var(--color-gold-light);
  font-family: var(--font-serif);
  line-height: 1;
  margin-bottom: .4rem;
}
.stat-label {
  font-size: .8rem;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* ============================================================
   SECTIONS — SHARED
   ============================================================ */
.section-header {
  text-align: center;
  max-width: 640px;
  margin-inline: auto;
  margin-bottom: 3.5rem;
}
.section-header h2 { margin-bottom: .75rem; }

.section-bg-cream { background: var(--color-cream); }
.section-bg-white { background: var(--color-white); }
.section-bg-gold  { background: var(--color-gold);  }
.section-bg-dark  { background: var(--color-dark);  }

/* ============================================================
   CATEGORY CARD
   ============================================================ */
.category-card {
  display: block;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: var(--transition);
  height: 100%;
  text-decoration: none;
  box-shadow: var(--shadow-sm);
}
.category-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--color-gold-border);
  transform: translateY(-3px);
}

.category-card-img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 8;
}
.category-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 60%;
  transition: transform .5s ease;
}
.category-card:hover .category-card-img img { transform: scale(1.06); }
@media (max-width: 640px) {
  .category-card-img { aspect-ratio: 16 / 9; }
}
.category-card-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, hsla(30,15%,8%,.7), transparent);
}
.category-card-icon {
  position: absolute;
  top: .75rem;
  left: .85rem;
  font-size: 1.75rem;
  transition: transform .25s;
}
.category-card:hover .category-card-icon { transform: scale(1.15); }

.category-card-body {
  padding: 1.1rem 1.25rem 1.4rem;
}
.category-card-body h3 {
  color: var(--color-text);
  margin-bottom: .35rem;
  font-size: 1.1rem;
}
.category-card-body p {
  font-size: .87rem;
  line-height: 1.6;
  color: var(--color-text-muted);
  margin-bottom: .9rem;
}
.category-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: .82rem;
}
.category-card-count {
  color: var(--color-text-light);
}
.category-card-arrow {
  color: var(--color-gold);
  font-weight: 600;
  font-size: .88rem;
  display: flex;
  align-items: center;
  gap: .25rem;
  transition: gap .2s;
}
.category-card:hover .category-card-arrow { gap: .45rem; }

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.product-card {
  display: flex;
  flex-direction: column;
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: var(--transition);
  height: 100%;
  box-shadow: var(--shadow-sm);
}
.product-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--color-gold-border);
  transform: translateY(-3px);
}

.product-card-img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: #ffffff;
}
.product-card-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: transform .5s ease;
  padding: .5rem;
}
.product-card:hover .product-card-img img { transform: scale(1.04); }

.product-card-category {
  position: absolute;
  top: .75rem;
  left: .75rem;
  background: var(--color-gold);
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  padding: .25rem .6rem;
  border-radius: 999px;
  letter-spacing: .04em;
}

.product-card-body {
  padding: 1.15rem 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.product-card-body h3 {
  font-size: 1.05rem;
  color: var(--color-text);
  margin-bottom: .4rem;
}
.product-card-desc {
  font-size: .86rem;
  color: var(--color-text-muted);
  line-height: 1.6;
  flex: 1;
  margin-bottom: 1rem;
}

.product-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--color-border-light);
  padding-top: .85rem;
  margin-bottom: .9rem;
}
.product-card-price {
  font-weight: 700;
  color: var(--color-gold);
  font-size: .95rem;
}
.product-card-unit {
  font-size: .78rem;
  color: var(--color-text-light);
}

.product-card .btn {
  width: 100%;
  justify-content: center;
  font-size: .88rem;
  padding: .65rem 1rem;
}

/* ============================================================
   WHY US / REASONS GRID
   ============================================================ */
.reasons-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
@media (max-width: 767px) { .reasons-grid { grid-template-columns: 1fr; } }

.reason-card {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.reason-icon {
  width: 44px;
  height: 44px;
  background: var(--color-gold-pale);
  border: 1px solid var(--color-gold-border);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1.1rem;
}
.reason-text h4 { margin-bottom: .3rem; font-size: 1rem; }
.reason-text p  { font-size: .87rem; }

/* ============================================================
   CONTACT INFO + FORM
   ============================================================ */
.contact-layout {
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: 3.5rem;
  align-items: start;
}
@media (max-width: 1023px) {
  .contact-layout { grid-template-columns: 1fr; gap: 2.5rem; }
}

.contact-info h2 { margin-bottom: .5rem; }
.contact-info .subtitle { margin-bottom: 2rem; font-size: .9rem; }

.contact-methods { display: flex; flex-direction: column; gap: 1rem; }

.contact-method {
  display: flex;
  align-items: flex-start;
  gap: .9rem;
  padding: 1.1rem;
  background: var(--color-cream);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: var(--transition);
  text-decoration: none;
}
.contact-method:hover {
  border-color: var(--color-gold-border);
  box-shadow: var(--shadow-sm);
}
.contact-method-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1rem;
}
.contact-method-icon.gold  { background: var(--color-gold); color: #fff; }
.contact-method-icon.green { background: #25D366; color: #fff; }
.contact-method-icon.dark  { background: var(--color-dark); color: #fff; }

.contact-method-label {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--color-text-light);
  margin-bottom: .1rem;
}
.contact-method-value {
  font-size: .95rem;
  font-weight: 600;
  color: var(--color-text);
}
.contact-method-sub {
  font-size: .8rem;
  color: var(--color-text-muted);
}

.contact-form-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 2rem;
  box-shadow: var(--shadow);
}
.contact-form-card h3 { margin-bottom: 1.5rem; }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 639px) { .form-row { grid-template-columns: 1fr; } }

.form-group { margin-bottom: 1rem; }
.form-group label {
  display: block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: .4rem;
}
.form-group input,
.form-group textarea,
.form-group select {
  width: 100%;
  padding: .7rem 1rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius);
  background: hsl(40,20%,98%);
  color: var(--color-text);
  font-size: .9rem;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--color-text-light); }
.form-group input:focus,
.form-group textarea:focus {
  border-color: var(--color-gold);
  box-shadow: 0 0 0 3px var(--color-gold-pale);
}
.form-group textarea { resize: vertical; min-height: 130px; }

.form-submit {
  width: 100%;
  justify-content: center;
  padding: .9rem;
  font-size: 1rem;
  margin-top: .5rem;
  border-radius: var(--radius-lg);
  border: none;
  cursor: pointer;
}

.form-note {
  text-align: center;
  font-size: .78rem;
  color: var(--color-text-light);
  margin-top: .75rem;
}

/* ============================================================
   CATEGORY PAGE — PRODUCT SEARCH BAR
   ============================================================ */
.cat-search-bar {
  position: relative;
  display: flex;
  align-items: center;
  max-width: 480px;
  margin-bottom: 2.25rem;
  background: #fff;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: border-color .2s, box-shadow .2s;
}
.cat-search-bar:focus-within {
  border-color: var(--color-gold);
  box-shadow: 0 0 0 3px var(--color-gold-pale);
}
.cat-search-bar > svg {
  position: absolute;
  left: 1rem;
  color: var(--color-text-light);
  pointer-events: none;
  flex-shrink: 0;
}
.cat-search-bar input[type="search"] {
  flex: 1;
  width: 100%;
  padding: .8rem 2.75rem .8rem 2.85rem;
  border: none;
  background: transparent;
  font-size: .95rem;
  color: var(--color-text);
  outline: none;
  -webkit-appearance: none;
}
.cat-search-bar input[type="search"]::placeholder { color: var(--color-text-light); }
.cat-search-bar input[type="search"]::-webkit-search-cancel-button { display: none; }
.cat-search-clear {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  margin-right: .55rem;
  border: none;
  background: var(--color-border);
  border-radius: 50%;
  cursor: pointer;
  color: var(--color-text-muted);
  flex-shrink: 0;
  transition: background .15s;
}
.cat-search-clear:hover { background: var(--color-gold); color: #fff; }

.cat-no-results {
  text-align: center;
  padding: 3.5rem 1rem;
  color: var(--color-text-muted);
  font-size: 1rem;
}

/* ============================================================
   SINGLE PRODUCT
   ============================================================ */
.product-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.5rem;
  align-items: start;
}
@media (max-width: 1023px) {
  .product-layout { grid-template-columns: 1fr; gap: 2rem; }
}

.product-image-wrap {
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}
.product-image-wrap { background: #ffffff; }
.product-image-wrap img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: contain;
  padding: .75rem;
}

.product-detail-breadcrumb {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .85rem;
  color: var(--color-text-muted);
  margin-bottom: 1rem;
}
.product-detail-breadcrumb a { color: var(--color-gold); }
.product-detail-breadcrumb a:hover { text-decoration: underline; }
.product-detail-breadcrumb span { opacity: .5; }

.product-detail h1 { margin-bottom: .75rem; }

.product-detail-category {
  display: inline-block;
  background: var(--color-gold-pale);
  color: var(--color-gold);
  border: 1px solid var(--color-gold-border);
  font-size: .75rem;
  font-weight: 700;
  padding: .25rem .75rem;
  border-radius: 999px;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 1rem;
}

.product-detail-desc {
  font-size: .95rem;
  color: var(--color-text-muted);
  line-height: 1.75;
  margin-bottom: 1.5rem;
}

.product-meta-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .65rem;
  margin-bottom: 1.75rem;
}
.product-meta-item {
  background: var(--color-cream);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: .75rem 1rem;
}
.product-meta-item-label {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--color-text-light);
  margin-bottom: .15rem;
}
.product-meta-item-value {
  font-size: .93rem;
  font-weight: 600;
  color: var(--color-text);
}
.product-meta-item-value.gold { color: var(--color-gold); font-size: 1.1rem; }

.product-detail-actions {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.product-detail-actions .btn {
  width: 100%;
  justify-content: center;
  padding: .95rem;
  font-size: .97rem;
  border-radius: var(--radius-lg);
}

.product-long-desc {
  background: var(--color-cream);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: 2rem;
  margin-top: 3rem;
}
.product-long-desc h2 { margin-bottom: 1rem; font-size: 1.3rem; }
.product-long-desc p  { font-size: .95rem; }

.product-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: 1.5rem;
}
.product-tag {
  background: var(--color-secondary);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 500;
  color: var(--color-text-muted);
  padding: .25rem .7rem;
}

/* Related products */
.related-section { padding-block: 4rem; }
.related-section h2 { margin-bottom: 2rem; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.mission-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
@media (max-width: 1023px) {
  .mission-layout { grid-template-columns: 1fr; gap: 2rem; }
}
.mission-img {
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
}
.mission-img img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }

.values-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
@media (max-width: 1023px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  { .values-grid { grid-template-columns: 1fr; } }

.value-card {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  text-align: center;
}
.value-card-icon { font-size: 1.75rem; margin-bottom: .75rem; }
.value-card h4 { color: #fff; margin-bottom: .35rem; font-size: .97rem; }
.value-card p  { color: rgba(255,255,255,.65); font-size: .85rem; }

/* Gold Stats band */
.stats-band { padding: 3rem 0; }
.stats-band .stat-value { color: #fff; }
.stats-band .stat-label { color: rgba(255,255,255,.7); }

/* ============================================================
   LOCATION SECTION
   ============================================================ */
.location-section {
  max-width: 720px;
  margin-inline: auto;
}
.location-items { display: flex; flex-direction: column; gap: .75rem; margin-block: 1.5rem; }
.location-item {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  font-size: .9rem;
  color: var(--color-text-muted);
}
.location-icon { color: var(--color-gold); margin-top: 2px; flex-shrink: 0; font-size: 1rem; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background: var(--color-dark);
  color: rgba(255,255,255,.7);
  padding-top: 3.5rem;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.4fr;
  gap: 2.5rem;
}
@media (max-width: 1023px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .footer-grid { grid-template-columns: 1fr; }
}

.footer-brand img { height: 48px; width: auto; margin-bottom: 1rem; }
.footer-brand p { font-size: .87rem; line-height: 1.7; color: rgba(255,255,255,.55); max-width: 260px; }

.footer-col h4 {
  color: #fff;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-bottom: 1rem;
  font-family: var(--font-sans);
}
.footer-col ul { display: flex; flex-direction: column; gap: .6rem; }
.footer-col a {
  font-size: .87rem;
  color: rgba(255,255,255,.55);
  transition: color .2s;
}
.footer-col a:hover { color: var(--color-gold-light); }

.footer-contact-items { display: flex; flex-direction: column; gap: .75rem; }
.footer-contact-item { display: flex; align-items: flex-start; gap: .6rem; font-size: .85rem; }
.footer-contact-icon { color: var(--color-gold); flex-shrink: 0; margin-top: 2px; font-size: .9rem; }
.footer-contact-text a { color: rgba(255,255,255,.6); }
.footer-contact-text a:hover { color: var(--color-gold-light); text-decoration: underline; }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 1.25rem 0;
  margin-top: 3rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  font-size: .8rem;
  color: rgba(255,255,255,.35);
}
@media (max-width: 640px) { .footer-bottom { flex-direction: column; text-align: center; } }
.footer-bottom a { color: rgba(255,255,255,.5); }
.footer-bottom a:hover { color: var(--color-gold-light); }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .83rem;
  color: rgba(255,255,255,.5);
  margin-bottom: 1.25rem;
}
.breadcrumb a { color: rgba(255,255,255,.6); }
.breadcrumb a:hover { color: #fff; }
.breadcrumb-sep { opacity: .4; }

/* ============================================================
   BACK LINK
   ============================================================ */
.back-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .87rem;
  color: rgba(255,255,255,.55);
  transition: color .2s;
  margin-bottom: 1.25rem;
}
.back-link:hover { color: #fff; }

/* ============================================================
   NOT FOUND / 404
   ============================================================ */
.not-found {
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 4rem 1rem;
}
.not-found h1 { font-size: 5rem; color: var(--color-gold); font-family: var(--font-serif); }
.not-found h2 { margin-block: .5rem 1rem; }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.animate-fade-up {
  opacity: 0;
  transform: translateY(28px);
}
.animate-fade-up.is-visible {
  animation: fadeUp .6s cubic-bezier(.22,1,.36,1) both;
}
.delay-1 { animation-delay: .1s; }
.delay-2 { animation-delay: .2s; }
.delay-3 { animation-delay: .3s; }
.delay-4 { animation-delay: .4s; }

/* ============================================================
   MISC
   ============================================================ */
.tags-list { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: .75rem; }
.tag {
  background: var(--color-secondary);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  font-size: .73rem;
  font-weight: 500;
  color: var(--color-text-muted);
  padding: .2rem .65rem;
}

.no-products {
  text-align: center;
  padding: 5rem 2rem;
}
.no-products .no-icon { font-size: 4rem; margin-bottom: 1rem; }
.no-products h2 { margin-bottom: .5rem; }

.page-hero-category-header {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  margin-top: .5rem;
}
.page-hero-category-icon { font-size: 3.5rem; flex-shrink: 0; }
@media (max-width: 640px) { .page-hero-category-icon { font-size: 2.5rem; } }

/* Featured section on home */
.featured-section { padding-block: 5rem; background: var(--color-cream); }
.featured-section .section-header { text-align: left; margin-inline: unset; }

/* WhatsApp float */
.wa-float {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 999;
  width: 56px;
  height: 56px;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  box-shadow: 0 4px 20px rgba(37,211,102,.45);
  transition: transform .25s, box-shadow .25s;
  text-decoration: none;
}
.wa-float:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 28px rgba(37,211,102,.55);
}

/* Responsive images in content */
.wp-post-image { width: 100%; height: auto; }

/* Clearfix */
.clearfix::after { content: ''; display: table; clear: both; }

/* Screen reader only */
.sr-only {
  position: absolute; width: 1px; height: 1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ── Product Enquiry Form ───────────────────────────────────── */
.product-enquiry-wrap {
  margin-top: 1.25rem;
}

.enquiry-toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  width: 100%;
  justify-content: center;
}

.enq-chevron {
  margin-left: auto;
  transition: transform .25s ease;
  flex-shrink: 0;
}

.enquiry-toggle-btn[aria-expanded="true"] .enq-chevron {
  transform: rotate(180deg);
}

.product-enquiry-form {
  margin-top: 1rem;
  background: var(--color-cream, #f8f4ef);
  border: 1.5px solid var(--color-border, #e5ddd4);
  border-radius: var(--radius-lg, 14px);
  padding: 1.75rem 1.5rem;
  animation: enqSlideIn .22s ease;
}

@keyframes enqSlideIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.enq-title {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-dark, #1a1a1a);
  margin: 0 0 .25rem;
}

.enq-subtitle {
  font-size: .9rem;
  color: var(--color-text-muted, #7a7065);
  margin: 0 0 1.25rem;
}

.enq-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.enq-field {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  margin-bottom: 1rem;
}

.enq-field:last-child { margin-bottom: 0; }

.enq-field label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--color-dark, #1a1a1a);
  letter-spacing: .02em;
  text-transform: uppercase;
}

.enq-req { color: var(--color-gold, #c8972a); }

.enq-field input,
.enq-field textarea {
  width: 100%;
  padding: .65rem .9rem;
  border: 1.5px solid var(--color-border, #e5ddd4);
  border-radius: var(--radius, 8px);
  background: #fff;
  font-family: inherit;
  font-size: .95rem;
  color: var(--color-dark, #1a1a1a);
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
}

.enq-field input:focus,
.enq-field textarea:focus {
  outline: none;
  border-color: var(--color-gold, #c8972a);
  box-shadow: 0 0 0 3px rgba(200,151,42,.12);
}

.enq-field input.enq-error,
.enq-field textarea.enq-error {
  border-color: #d9534f;
  box-shadow: 0 0 0 3px rgba(217,83,79,.1);
}

.enq-field textarea { resize: vertical; min-height: 88px; }

.enq-actions {
  display: flex;
  gap: .75rem;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 1.25rem;
}

#enq-feedback {
  margin-top: 1rem;
  padding: .85rem 1rem;
  border-radius: var(--radius, 8px);
  font-size: .92rem;
  font-weight: 500;
  display: none;
}

#enq-feedback.enq-success {
  display: block;
  background: #edf7ee;
  border: 1px solid #c3e6cb;
  color: #276229;
}

#enq-feedback.enq-error-msg {
  display: block;
  background: #fdf3f3;
  border: 1px solid #f5c6cb;
  color: #7b2020;
}

@media (max-width: 640px) {
  .enq-row { grid-template-columns: 1fr; }
  .product-enquiry-form { padding: 1.25rem 1rem; }
}
