/* ============================================================
   Aidan Global — main.css
   Single stylesheet. No framework. CSS custom properties.
   ============================================================ */

/* ── 0. Local Fonts ────────────────────────────────────────── */

/* Kanit */
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/kanit-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/kanit-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/kanit-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/kanit-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url('../fonts/kanit-900.woff2') format('woff2');
}

/* Exo 2 */
@font-face {
  font-family: 'Exo 2';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/exo2-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Exo 2';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/exo2-500.woff2') format('woff2');
}
@font-face {
  font-family: 'Exo 2';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/exo2-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Exo 2';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/exo2-700.woff2') format('woff2');
}


/* ── 1. Custom Properties ─────────────────────────────────── */
:root {
  /* Colors — overridden by customizer */
  /* Site uses white bg, black text, dark navy/black accents, no bold primary colour */
  --color-primary: #000000;
  /* CTA buttons: black "ADD TO CART", "CUSTOMIZE DESIGN" */
  --color-secondary: #000000;
  /* Secondary dark */
  --color-accent: #333333;
  /* Hover state */
  --color-text: #1A1A1A;
  /* Body text */
  --color-text-muted: #6B7280;
  /* Meta, captions */
  --color-bg: #FFFFFF;
  /* Page background */
  --color-surface: #F5F5F5;
  /* Light grey surface */
  --color-border: #E8E8E8;
  /* Borders / dividers */
  --color-topbar-bg: #000000;
  /* Topbar "DISCOVER POPULAR COLLECTIONS" */
  --color-footer-bg: #1A1A1A;
  /* Dark footer */
  --color-footer-text: #CCCCCC;
  --color-price: #000000;
  /* Price in black */
  --color-sale-price: #000000;
  --color-link: #8B1A4A;
  /* Magenta/maroon links on about page */

  /* Typography — confirmed from console output */
  --font-heading: 'Kanit', sans-serif;
  /* h1–h6 */
  --font-body: 'Exo 2', system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
  /* body text */
  --font-sans: var(--font-body);
  --font-size-xs: 0.75rem;
  /* 12px */
  --font-size-sm: 0.875rem;
  /* 14px */
  --font-size-base: 1rem;
  /* 16px */
  --font-size-lg: 1.125rem;
  /* 18px */
  --font-size-xl: 1.25rem;
  /* 20px */
  --font-size-2xl: 1.5rem;
  /* 24px */
  --font-size-3xl: 1.875rem;
  /* 30px */
  --font-size-4xl: 2.25rem;
  /* 36px */
  --font-size-5xl: 3rem;
  /* 48px */

  /* Spacing */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  /* Layout */
  --container-max: 1280px;
  --container-pad: var(--space-6);
  --radius-sm: 0px;
  --radius-md: 0px;
  --radius-lg: 0px;
  --radius-full: 0px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, .10);
  --shadow-lg: 0 10px 30px rgba(0, 0, 0, .12);

  /* Transitions */
  --transition: 200ms ease;
  --transition-slow: 350ms ease;
}

/* ── 2. Reset & Base ──────────────────────────────────────── */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

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

body {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

bdi {
  font-family: var(--font-heading) !important;
}


img,
svg {
  display: block;
  max-width: 100%;
}

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

a:hover {
  color: var(--color-primary);
}

ul,
ol {
  list-style: none;
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font: inherit;
}

input,
select,
textarea {
  font: inherit;
}

/* ── 3. Layout Utilities ──────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

.section {
  padding-block: var(--space-16);
}

.section--tight {
  padding-block: clamp(2rem, 5vw, 4rem);
  /* Responsive padding instead of fixed large space */
}

/* ── 4. Typography ────────────────────────────────────────── */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Kanit', sans-serif !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: var(--color-secondary) !important;
}


/* Kanit renders with slightly different metrics — tighten up */
h1 {
  font-size: clamp(1.75rem, 4vw, var(--font-size-5xl));
  letter-spacing: -0.01em;
}

h2 {
  font-size: clamp(1.4rem, 3vw, var(--font-size-4xl));
}

h3 {
  font-size: var(--font-size-2xl);
}

h4 {
  font-size: var(--font-size-xl);
}

p {
  margin-bottom: var(--space-4);
}

p:last-child {
  margin-bottom: 0;
}

/* ── 5. Buttons ───────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: var(--font-size-sm);
  letter-spacing: .02em;
  transition: background var(--transition), color var(--transition), transform var(--transition), box-shadow var(--transition);
  white-space: nowrap;
  border: 2px solid transparent;
}

.btn:active {
  transform: translateY(1px);
}

.btn:focus-visible {
  outline: 3px solid var(--color-primary);
  outline-offset: 3px;
}

.btn--primary {
  background: #000;
  color: #fff;
  border-color: #000;
}

.btn--primary:hover {
  background: #333;
  border-color: #333;
  color: #fff;
}

.btn--outline {
  background: transparent;
  color: #000;
  border-color: #000;
}

.btn--outline:hover {
  background: #000;
  color: #fff;
}

.btn--outline-white {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, .7);
}

.btn--outline-white:hover {
  background: rgba(255, 255, 255, .15);
}

.btn--white {
  background: #fff;
  color: var(--color-secondary);
  border-color: #fff;
}

.btn--white:hover {
  background: #f0f0f0;
  color: var(--color-secondary);
}

.btn--whatsapp {
  background: #25D366;
  color: #fff;
  border-color: #25D366;
  justify-content: center;
}

.btn--whatsapp:hover {
  background: #1da851;
  border-color: #1da851;
  color: #fff;
}

.btn--sm {
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-xs);
}

.btn--lg {
  padding: var(--space-4) var(--space-8);
  font-size: var(--font-size-base);
}

.btn--block {
  width: 100%;
  justify-content: center;
}

/* ── Animations ────────────────────────────────────────────────────────── */
.reveal-fade {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.reveal-fade.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Top Bar ───────────────────────────────────────────────────────────── */
.topbar {
  background: #000;
  color: #fff;
  text-align: center;
  padding: 10px 0;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.topbar__link {
  color: inherit;
  text-decoration: none;
  transition: opacity 0.3s;
}

.topbar__link:hover {
  opacity: 0.7;
}

/* ── Site Header ───────────────────────────────────────────────────────── */
.site-header {
  background: #fff;
  border-bottom: 1px solid #eee;
  position: sticky;
  top: 0;
  z-index: 1000;
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 80px;
  gap: 20px;
}

/* Hide mobile toggle on desktop */
.menu-toggle-btn {
  display: none !important;
}

/* 3-Column Layout: Nav | Logo | Actions */
.site-nav {
  flex: 1;
  display: flex;
  justify-content: flex-start;
}

.site-header__logo {
  flex: 0 0 auto;
  text-align: center;
}

.site-header__actions {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 15px;
}

.site-nav__list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 0;
}

.site-nav__list>li {
  position: relative;
  display: flex;
  align-items: center;
}

.site-nav__list>li>a {
  display: flex;
  align-items: center;
  padding: 0 14px;
  text-decoration: none;
  color: #000;
  font-family: 'Kanit', sans-serif !important;
  font-weight: 500 !important;
  font-size: 12px !important;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
  transition: color 0.2s;
}


.site-nav__list>li>a:hover {
  color: #555;
}

/* Dropdown submenus */
.site-nav__list ul {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background: #fff;
  border: 1px solid #e5e5e5;
  border-top: 2px solid #000;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  list-style: none;
  margin: 0;
  padding: 8px 0;
  z-index: 999;
}

/* 3rd level and deeper positioning */
.site-nav__list ul ul {
  top: -8px;
  /* Alignment with parent li */
  left: 100%;
  border-top: 1px solid #e5e5e5;
}

.site-nav__list ul li {
  position: relative;
}

.site-nav__list ul li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 9px 20px;
  font-family: 'Kanit', sans-serif !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #000;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.15s;
}


/* Indicator for parent items */
.site-nav__list ul .menu-item-has-children>a::after {
  content: "›";
  font-size: 14px;
  margin-left: 10px;
}

.site-nav__list ul li a:hover {
  background: #f5f5f5;
}

/* Show dropdown on hover at any level */
.site-nav__list li:hover>ul,
.site-nav__list li:focus-within>ul {
  display: block;
}

.site-logo {
  display: block;
  max-height: 40px;
  width: auto;
}

.header-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 5px;
  color: #000;
  display: flex;
  align-items: center;
  transition: opacity 0.3s;
}

.header-btn:hover {
  opacity: 0.6;
}

/* Cart count badge */
.cart-icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cart-icon__count {
  position: absolute;
  top: -5px;
  right: -8px;
  min-width: 16px;
  height: 16px;
  background: #000;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding: 0 3px;
}

/* Hamburger */
.hamburger {
  width: 20px;
  height: 14px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.hamburger span {
  display: block;
  width: 100%;
  height: 2px;
  background: #000;
}

@media (min-width: 992px) {
  .header-btn--menu {
    display: none;
  }
}

@media (max-width: 991px) {
  .site-nav {
    display: none;
  }
}

/* Search Drawer */
.search-drawer {
  border-top: 1px solid var(--color-border);
  padding-block: var(--space-4);
  background: var(--color-bg);
  animation: slideDown .2s ease;
}

.search-drawer__form {
  display: flex;
  gap: var(--space-2);
}

.search-drawer__input {
  flex: 1;
  padding: var(--space-3) var(--space-4);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  transition: border-color var(--transition);
}

.search-drawer__input:focus {
  outline: none;
  border-color: var(--color-primary);
}

.search-drawer__btn {
  padding: var(--space-3) var(--space-4);
  background: var(--color-primary);
  color: #fff;
  border-radius: var(--radius-md);
  transition: background var(--transition);
}

.search-drawer__btn:hover {
  background: var(--color-accent);
}

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

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── 8. Breadcrumbs ───────────────────────────────────────── */
.breadcrumbs-wrap {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
}

.breadcrumbs {
  padding-block: var(--space-3);
}

.breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  font-family: 'Kanit', sans-serif !important;
  text-transform: uppercase !important;
}


.breadcrumbs__sep {
  color: var(--color-border);
}

.breadcrumbs__item a {
  color: var(--color-text-muted);
}

.breadcrumbs__item a:hover {
  color: var(--color-primary);
}

.breadcrumbs__item span {
  color: var(--color-text);
  font-weight: 500;
}

/* ── 9. Section Heading ───────────────────────────────────── */
.section-heading {
  margin-bottom: var(--space-10);
}

.section-heading--center {
  text-align: center;
}

.section-heading__title {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, var(--font-size-4xl));
  font-weight: 700;
  color: #000;
}

.section-heading__sub {
  margin-top: var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--font-size-base);
  font-family: var(--font-body);
}

/* ── 10. Hero ─────────────────────────────────────────────── */
.hero {
  position: relative;
  overflow: hidden;
  min-height: var(--h-desktop, 600px);
  display: flex;
  align-items: center;
}

@media (max-width: 768px) {
  .hero {
    min-height: var(--h-mobile, 450px);
  }
}

.hero__media {
  position: absolute;
  inset: 0;
}

.hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(0, 0, 0, .65) 0%, rgba(0, 0, 0, .2) 60%, transparent 100%);
}

.hero__content {
  position: relative;
  z-index: 1;
  color: #fff;
  max-width: 580px;
  padding-block: var(--space-16);
}

.hero__kicker {
  display: inline-block;
  background: var(--color-primary);
  color: #fff;
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-4);
}

.hero__heading {
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: #fff;
  line-height: 1.15;
  margin-bottom: var(--space-4);
}

.hero__subtext {
  font-size: var(--font-size-lg);
  opacity: .9;
  margin-bottom: var(--space-8);
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

/* ── 11. USP Strip ────────────────────────────────────────── */
.usp-strip {
  background: var(--color-secondary);
  padding-block: var(--space-6);
}

.usp-strip__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-6);
}

.usp-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  color: #fff;
}

.usp-item__icon {
  font-size: 1.75rem;
  flex-shrink: 0;
}

.usp-item__title {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: #fff;
}

.usp-item__sub {
  font-size: var(--font-size-xs);
  color: rgba(255, 255, 255, .7);
}

/* ── 12. Category Grid ────────────────────────────────────── */
.category-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.category-tile {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  aspect-ratio: 1;
  display: block;
}

.category-tile__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.category-tile:hover .category-tile__img {
  transform: scale(1.05);
}

.category-tile__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, .65) 0%, rgba(0, 0, 0, .1) 60%);
}

.category-tile__label {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  color: #fff;
  font-weight: 700;
  font-size: var(--font-size-lg);
}

/* ── 13. Product Grid ─────────────────────────────────────── */
.product-grid {
  display: grid;
  gap: 10px;
}

.product-grid--4col {
  grid-template-columns: repeat(4, 1fr);
}

.product-grid--3col {
  grid-template-columns: repeat(3, 1fr);
}

/* ── 14. Product Card ─────────────────────────────────────── */
/* ── Product Grid (bordered grid lines, matching reference) ─────── */
.product-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  border-top: 1px solid #e5e5e5;
  border-left: 1px solid #e5e5e5;
}

@media (min-width: 768px) {
  .product-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1024px) {
  .product-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (min-width: 1280px) {
  .product-grid--4col {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* ── Product Card ────────────────────────────────────────────────── */
.product-card {
  position: relative;
  border-right: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
  background: #fff;
  border-radius: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: background 0.2s;
}

.product-card:hover {
  background: #f9f9f9;
}

/* Image area — large, light-gray background, product centred */
.product-card__media,
.product-card__img-link {
  display: block;
  position: relative;
  background: #ffffff;
  height: 337px;
  overflow: hidden;
}

.product-card__img {
  width: 100%;
  height: 337px;
  object-fit: cover;
}

/* Badge (SALE, FEATURED, NEW) */
.product-card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 4px 10px;
  border-radius: 0;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  z-index: 1;
}

.product-card__badge--sale {
  background: #000;
  color: #fff;
}

.product-card__badge--new {
  background: #000;
  color: #fff;
}

.product-card__badge--featured {
  background: #000;
  color: #fff;
}

/* Product image — object-fit contain so full jersey is visible */
.product-card__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  mix-blend-mode: multiply;
  /* blends white bg of cut-out PNGs cleanly */
  transition: transform 0.4s ease;
}

.product-card:hover .product-card__img {
  transform: scale(1.04);
}

/* Card body — minimal, left-aligned text */
.product-card__body {
  padding: 16px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}

.product-card__title {
  font-family: 'Kanit', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.3;
  margin: 0;
}


.product-card__title a {
  color: #000;
  text-decoration: none;
}

.product-card__title a:hover {
  color: #555;
}

/* Price — bold, slightly larger */
.product-card__price {
  font-size: 14px;
  font-weight: 700;
  color: #222;
  margin-top: 4px;
}

.product-card__price del {
  color: #999;
  font-weight: 400;
  font-size: 12px;
  margin-right: 4px;
}

.product-card__price ins {
  text-decoration: none;
}

/* Out of stock */
.product-card__oos {
  font-size: 11px;
  color: #999;
  font-style: italic;
  margin-top: 4px;
}

/* Actions (hidden by default, shown on hover on desktop) */
.product-card__actions {
  margin-top: 10px;
}


/* ── Blog Grid & Cards ─────────────────────────────────────────────────── */
.blog-grid {
  display: grid;
  gap: 1px;
  background: #eee;
  /* Grid lines */
  border: 1px solid #eee;
  margin-bottom: 40px;
}

.blog-grid--4col {
  grid-template-columns: repeat(4, 1fr);
}

.blog-card {
  background: #fff;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s;
}

.blog-card__img-link {
  display: block;
  aspect-ratio: 1/1;
  overflow: hidden;
}

.blog-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.blog-card:hover .blog-card__img {
  transform: scale(1.05);
}

.blog-card__body {
  padding: 25px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.blog-card__title {
  font-size: 18px;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 15px;
  text-transform: uppercase;
}

.blog-card__title a {
  color: inherit;
  text-decoration: none;
}

.blog-card__excerpt {
  font-size: 14px;
  color: #666;
  line-height: 1.6;
  margin-bottom: 20px;
}

.blog-card__more {
  margin-top: auto;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  text-decoration: none;
  color: #000;
  border-bottom: 1px solid #000;
  align-self: flex-start;
  padding-bottom: 2px;
}

@media (max-width: 1100px) {
  .blog-grid--4col {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .blog-grid--4col {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .blog-grid--4col {
    grid-template-columns: 1fr;
  }
}

/* ── About Sections ────────────────────────────────────────────────────── */
.about-intro__inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.about-intro__content {
  font-size: 20px;
  line-height: 1.8;
  color: #444;
}

.about-intro__content p {
  margin-bottom: 25px;
}

/* About Values */
.about-values__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-top: 50px;
}

.value-card {
  padding: 40px;
  background: #f9f9f9;
  border: 1px solid #eee;
  text-align: center;
  transition: transform 0.3s;
}

.value-card:hover {
  transform: translateY(-5px);
  background: #fff;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}

.value-card__icon {
  font-size: 40px;
  margin-bottom: 20px;
}

.value-card__title {
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 15px;
}

.value-card__desc {
  font-size: 14px;
  color: #666;
  line-height: 1.6;
}

/* About Process */
.process-steps {
  display: flex;
  flex-direction: column;
  gap: 100px;
  margin-top: 60px;
}

.process-step {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 60px;
}

.process-step:nth-child(even) {
  direction: rtl;
}

.process-step:nth-child(even) .process-step__content {
  direction: ltr;
}

.process-step__num {
  display: block;
  font-size: 60px;
  font-weight: 900;
  color: #eee;
  line-height: 1;
  margin-bottom: 10px;
}

.process-step__title {
  font-size: 28px;
  margin-bottom: 20px;
  text-transform: uppercase;
}

.process-step__desc {
  font-size: 16px;
  color: #555;
  line-height: 1.7;
}

.process-step__media img {
  width: 100%;
  border-radius: 4px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.1);
}

/* Team Grid Enhanced */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
}

.team-card {
  text-align: center;
}

.team-card__img-wrap {
  aspect-ratio: 3/4;
  overflow: hidden;
  margin-bottom: 20px;
  background: #f5f5f5;
}

.team-card__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%);
  transition: filter 0.3s, transform 0.5s;
}

.team-card:hover .team-card__photo {
  filter: grayscale(0);
  transform: scale(1.05);
}

.product-details__title {
  font-family: 'Kanit', sans-serif !important;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 12px;
  line-height: 1.2;
  text-transform: uppercase;
}

.team-card__name {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 5px;
  text-transform: uppercase;
}

.team-card__role {
  font-size: 13px;
  color: #999;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

@media (max-width: 991px) {
  .about-values__grid {
    grid-template-columns: 1fr 1fr;
  }

  .process-step {
    grid-template-columns: 1fr;
    gap: 30px;
    text-align: center;
  }

  .process-step:nth-child(even) {
    direction: ltr;
  }

  .team-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 480px) {
  .about-values__grid {
    grid-template-columns: 1fr;
  }

  .team-grid {
    grid-template-columns: 1fr;
  }
}

/* ── FAQ Sections ───────────────────────────────────────────────────────── */
.faq-hero {
  position: relative;
  padding: 120px 0;
  background-size: cover;
  background-position: center;
  color: #fff;
  min-height: 450px;
  display: flex;
  align-items: center;
}

.faq-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
}

.faq-hero__container {
  position: relative;
  z-index: 2;
}

.faq-hero__icons {
  display: flex;
  justify-content: center;
  gap: 40px;
  margin-bottom: 40px;
}

.faq-hero__icon-item {
  color: #fff;
  text-decoration: none;
  transition: transform 0.3s;
  text-align: center;
}

.faq-hero__icon-item:hover {
  transform: translateY(-5px);
}

.faq-hero__icon-img {
  width: 60px;
  height: 60px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 10px;
  backdrop-filter: blur(5px);
}

.faq-hero__icon-img img {
  width: 30px;
  height: 30px;
  filter: brightness(0) invert(1);
}

.faq-hero__icon-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.faq-hero__title {
  font-size: 48px;
  font-weight: 900;
  text-transform: uppercase;
}

/* FAQ Groups */
.faq-group {
  padding-top: 60px;
}

.faq-group__inner {
  max-width: 800px;
  margin: 0 auto;
}

.faq-group__title {
  font-size: 24px;
  text-transform: uppercase;
  margin-bottom: 30px;
  padding-bottom: 10px;
  border-bottom: 2px solid #000;
  display: inline-block;
}

.faq-accordion {
  border-top: 1px solid #eee;
}

.faq-item {
  border-bottom: 1px solid #eee;
}

.faq-item__question {
  width: 100%;
  padding: 25px 0;
  background: none;
  border: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: left;
  font-size: 16px;
  font-weight: 600;
  color: #111;
  cursor: pointer;
  transition: color 0.3s;
}

.faq-item__question:hover {
  color: var(--color-secondary);
}

.faq-item__icon {
  width: 20px;
  height: 20px;
  position: relative;
  flex-shrink: 0;
  margin-left: 20px;
}

.faq-item__icon::before,
.faq-item__icon::after {
  content: '';
  position: absolute;
  background: currentColor;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: transform 0.3s;
}

.faq-item__icon::before {
  width: 12px;
  height: 2px;
}

.faq-item__icon::after {
  width: 2px;
  height: 12px;
}

.faq-item__question[aria-expanded="true"] .faq-item__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0;
}

.faq-item__answer {
  overflow: hidden;
  transition: max-height 0.4s ease-out, padding 0.4s ease;
}

.faq-item__answer-inner {
  padding: 0 0 30px;
  color: #666;
  font-size: 15px;
  line-height: 1.6;
}

/* FAQ CTA */
.faq-cta {
  padding: 80px 0;
}

.faq-cta__title {
  font-size: 32px;
  margin-bottom: 15px;
}

.faq-cta__desc {
  color: #666;
  margin-bottom: 30px;
}

.faq-cta__actions {
  display: flex;
  justify-content: center;
  gap: 20px;
}

@media (max-width: 767px) {
  .faq-hero__icons {
    gap: 20px;
    flex-wrap: wrap;
  }

  .faq-hero__title {
    font-size: 32px;
  }

  .faq-cta__actions {
    flex-direction: column;
    align-items: center;
  }
}

/* ── Gallery ────────────────────────────────────────────────────────────── */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 40px;
}

.gallery-item {
  position: relative;
  overflow: hidden;
}

.gallery-item__img-wrap {
  position: relative;
  aspect-ratio: 4/3;
  background: #f0f0f0;
  overflow: hidden;
}

.gallery-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.gallery-item:hover .gallery-item__img {
  transform: scale(1.1);
}

.gallery-item__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 50%);
  display: flex;
  align-items: flex-end;
  padding: 20px;
  opacity: 0;
  transition: opacity 0.3s;
}

.gallery-item:hover .gallery-item__overlay {
  opacity: 1;
}

.gallery-item__caption {
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Lightbox */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.95);
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 40px;
  opacity: 0;
  transition: opacity 0.3s;
}

.lightbox.is-open {
  display: flex;
  opacity: 1;
}

.lightbox__close {
  position: absolute;
  top: 30px;
  right: 30px;
  background: none;
  border: none;
  color: #fff;
  font-size: 40px;
  cursor: pointer;
  line-height: 1;
}

.lightbox__content {
  max-width: 100%;
  max-height: 100%;
  text-align: center;
}

.lightbox__img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  box-shadow: 0 0 50px rgba(0, 0, 0, 0.5);
}

.lightbox__caption {
  color: #fff;
  margin-top: 20px;
  font-size: 18px;
}

.lightbox__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.1);
  border: none;
  color: #fff;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  font-size: 30px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.3s;
}

.lightbox__nav:hover {
  background: rgba(255, 255, 255, 0.2);
}

.lightbox__nav--prev {
  left: 30px;
}

.lightbox__nav--next {
  right: 30px;
}

@media (max-width: 991px) {
  .gallery-grid {
    grid-template-columns: 1fr 1fr;
  }

  .lightbox__nav {
    width: 40px;
    height: 40px;
    font-size: 20px;
  }
}

@media (max-width: 480px) {
  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .lightbox {
    padding: 20px;
  }

  .lightbox__nav {
    display: none;
  }
}

/* ── 15. CTA Banner ───────────────────────────────────────── */
.cta-banner {
  background: linear-gradient(135deg, var(--color-secondary) 0%, #2d2d5e 100%);
  padding-block: var(--space-16);
}

.cta-banner__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  flex-wrap: wrap;
}

.cta-banner__heading {
  color: #fff;
  font-size: var(--font-size-3xl);
}

.cta-banner__sub {
  color: rgba(255, 255, 255, .8);
  margin-top: var(--space-2);
}

.cta-banner__actions {
  display: flex;
  gap: var(--space-3);
  flex-shrink: 0;
  flex-wrap: wrap;
}

.section__cta-wrap {
  text-align: center;
  margin-top: var(--space-10);
}

/* ── 16. Blog Grid ────────────────────────────────────────── */
.blog-grid {
  display: grid;
  gap: var(--space-6);
}

.blog-grid--3col {
  grid-template-columns: repeat(3, 1fr);
}

.blog-grid--2col {
  grid-template-columns: repeat(2, 1fr);
}

.blog-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow var(--transition);
}

.blog-card:hover {
  box-shadow: var(--shadow-md);
}

.blog-card__img-link {
  display: block;
  aspect-ratio: 16/9;
  overflow: hidden;
}

.blog-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.blog-card:hover .blog-card__img {
  transform: scale(1.03);
}

.blog-card__body {
  padding: var(--space-5);
}

.blog-card__date {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  display: block;
  margin-bottom: var(--space-2);
}

.blog-card__cat {
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-left: var(--space-2);
}

.blog-card__title {
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-3);
  line-height: 1.4;
}

.blog-card__title a {
  color: var(--color-text);
}

.blog-card__title a:hover {
  color: var(--color-primary);
}

.blog-card__excerpt {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}

.blog-card__link {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-primary);
}

/* Blog layout */
.blog-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-10);
  padding-block: var(--space-12);
  align-items: start;
}

.blog-sidebar {
  position: sticky;
  top: 80px;
}

/* Single post */
.post-header {
  margin-bottom: var(--space-8);
}

.post-header__meta {
  display: flex;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.post-header__title {
  font-size: clamp(1.75rem, 4vw, 3rem);
}

.post-featured-img {
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-8);
  aspect-ratio: 16/7;
}

.post-featured-img__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.post-content {
  max-width: 72ch;
}

.post-content p,
.post-content li {
  font-size: var(--font-size-lg);
  line-height: 1.8;
  margin-bottom: var(--space-4);
}

.post-content h2,
.post-content h3 {
  margin: var(--space-8) 0 var(--space-4);
}

.post-author {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding: var(--space-6);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  margin-top: var(--space-10);
}

.post-author__avatar {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

/* ── 17. Archive Header ───────────────────────────────────── */
.archive-header {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  padding-block: var(--space-8);
}

.archive-header__title {
  font-size: var(--font-size-4xl);
  margin-top: var(--space-3);
}

.archive-header__desc {
  margin-top: var(--space-3);
  color: var(--color-text-muted);
  max-width: 60ch;
}

/* ── 18. Shop Layout ──────────────────────────────────────── */
/* Site uses NO sidebar - full-width grid with toolbar above */
.shop-layout {
  display: block;
  padding-block: var(--space-6);
}

/* Shop/archive page title — Kanit, centred, large */
.archive-header__title {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 4vw, 2.5rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  text-align: center;
  text-transform: uppercase;
  color: #000;
  margin-top: var(--space-4);
}

/* Blog header — black bg, white text like the site */
.blog-archive-header {
  background: #000;
  color: #fff;
  text-align: center;
  padding: var(--space-6) var(--space-4);
}

.blog-archive-header .archive-header__title {
  color: #fff;
}

/* Sidebar as Drawer */
.shop-sidebar {
  display: block;
  position: fixed;
  top: 0;
  right: 0;
  width: 360px;
  height: 100%;
  background: #fff;
  z-index: 9999;
  box-shadow: -5px 0 30px rgba(0, 0, 0, .1);
  transform: translateX(105%);
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  overflow-y: auto;
  visibility: hidden;
  padding: 0;
}

.shop-sidebar.is-open {
  transform: translateX(0);
  visibility: visible;
}

.shop-sidebar__inner {
  padding: 40px 30px;
}

.shop-sidebar__close {
  position: absolute;
  top: 20px;
  right: 20px;
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: #000;
  z-index: 10;
}

.sidebar-widget {
  margin-bottom: 40px;
}

.sidebar-widget__title {
  font-family: 'Kanit', sans-serif;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 20px;
  color: #000;
  display: block;
}

/* Search Widget */
.sidebar-search {
  position: relative;
}

.sidebar-search__input {
  width: 100%;
  height: 48px;
  border: 1px solid #e0e0e0;
  padding: 0 45px 0 15px;
  font-size: 12px;
  text-transform: uppercase;
  color: #000;
  background: #fff;
}

.sidebar-search__input::placeholder {
  color: #999;
}

.sidebar-search::after {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='black' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='M21 21l-4.35-4.35'/%3E%3C/svg%3E") no-repeat center;
  background-size: contain;
  pointer-events: none;
}

/* Category & Attribute Lists */
.sidebar-cats,
.woocommerce .widget_layered_nav ul,
.woocommerce .widget_product_categories ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sidebar-cats__item,
.woocommerce .widget_layered_nav ul li,
.woocommerce .widget_product_categories ul li {
  margin-bottom: 12px;
  padding: 0 !important;
}

.sidebar-cats__item a,
.woocommerce .widget_layered_nav ul li a,
.woocommerce .widget_product_categories ul li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: #000;
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 500;
  transition: color 0.2s;
}

.sidebar-cats__item.is-active a,
.woocommerce .widget_layered_nav ul li.chosen a,
.woocommerce .widget_product_categories ul li.current-cat a {
  font-weight: 700;
}

.sidebar-cats__count,
.woocommerce .widget_layered_nav ul li .count,
.woocommerce .widget_product_categories ul li .count {
  font-size: 10px;
  color: #999;
}

/* Chips Style (Black Squares) */
.woocommerce .widget_layered_nav ul.layered-nav-list--chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.woocommerce .widget_layered_nav ul.layered-nav-list--chips li {
  margin: 0 !important;
}

.woocommerce .widget_layered_nav ul.layered-nav-list--chips li a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 10px;
  background: #000;
  color: #fff !important;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}

.woocommerce .widget_layered_nav ul.layered-nav-list--chips li.chosen a {
  background: #ff0055;
  /* Visual indicator for active if desired, otherwise stay black */
}

/* Price Filter Slider */
.woocommerce .widget_price_filter .price_slider {
  margin-bottom: 25px;
  background: #e0e0e0;
  height: 2px;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
  background-color: #000;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
  width: 12px;
  height: 12px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 50%;
  top: -5px;
  cursor: pointer;
}

.woocommerce .widget_price_filter .price_slider_amount {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: row-reverse;
}

.woocommerce .widget_price_filter .price_label {
  font-size: 12px;
  color: #000;
  font-weight: 600;
  text-transform: uppercase;
}

.woocommerce .widget_price_filter .price_slider_amount .button {
  background: #000 !important;
  color: #fff !important;
  border: none !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 10px 20px !important;
  text-transform: uppercase !important;
  cursor: pointer;
}

/* ── WooCommerce Block Filters Support ───────────────────────────────────── */

/* Block Attribute Filter (e.g. Size, Gender) as Chips */
[class*="wc-block-product-filter-checkbox-list"],
[class*="wc-block-product-filter-checkbox-list__items"],
[class*="wc-block-components-checkbox-list"],
.wc-block-components-checkbox-list {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-flow: row wrap !important;
  gap: 8px !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
  white-space: normal !important;
}

[class*="wc-block-product-filter-checkbox-list__item"],
.wc-block-components-checkbox-list-item {
  margin: 0 !important;
  display: flex !important;
  width: auto !important;
  flex: 0 0 auto !important;
}

[class*="wc-block-product-filter-checkbox-list__item"] label,
.wc-block-components-checkbox-list-item label {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  width: auto !important;
  padding: 0 10px !important;
  background: #000;
  color: #fff !important;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  cursor: pointer;
  position: relative;
  border: none !important;
}

/* Hide the checkbox and mark */
[class*="__input-wrapper"],
[class*="__mark"],
.wc-block-components-checkbox-list__input-wrapper {
  display: none !important;
}

[class*="__item"] label:has(input:checked),
.wc-block-components-checkbox-list-item label:has(input:checked) {
  background: #ff0055 !important;
  /* Selected color */
}

/* Block Price Slider */
.wc-block-product-filter-price-slider__range {
  height: 2px !important;
  background-color: #e0e0e0 !important;
}

.wc-block-product-filter-price-slider__range .wc-block-components-price-slider__range-track,
.wc-block-components-price-slider__range-track {
  background-color: #000 !important;
}

.wc-block-product-filter-price-slider__range .wc-block-components-price-slider__range-handle,
.wc-block-components-price-slider__range-handle {
  width: 12px !important;
  height: 12px !important;
  background-color: #fff !important;
  border: 1px solid #000 !important;
  border-radius: 50% !important;
}

.wc-block-product-filter-price-slider__amount {
  display: flex;
  justify-content: space-between;
  margin-top: 20px;
}

.wc-block-product-filter-price-slider__amount .wc-block-components-price-slider__input {
  border: 1px solid #e0e0e0 !important;
  font-size: 11px !important;
  padding: 5px 10px !important;
  width: 70px !important;
}

/* Block Category Filter */
.wc-block-product-categories-list {
  list-style: none !important;
  padding: 0 !important;
}

.wc-block-product-categories-list-item {
  margin-bottom: 12px;
}

.wc-block-product-categories-list-item a {
  font-size: 12px;
  color: #000;
  text-transform: uppercase;
  font-weight: 500;
  text-decoration: none;
}

/* Toolbar */
.shop-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.shop-toolbar__filter-btn {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .1em;
  color: #000;
  text-decoration: underline;
  text-underline-offset: 4px;
  margin-right: var(--space-6);
}

.shop-toolbar__filter-btn:hover {
  color: #555;
}

.shop-toolbar__count {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

/* WC ordering dropdown */
.woocommerce-ordering select {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
  cursor: pointer;
}

/* Shop grid inherits from .product-grid */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Pagination */
.shop-pagination {
  margin-top: var(--space-10);
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.shop-pagination .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--color-text);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}

.shop-pagination .page-numbers:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.shop-pagination .page-numbers.current {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

/* Empty state */
.shop-empty {
  text-align: center;
  padding: var(--space-16) 0;
}

.shop-empty__text {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}

/* Shop archive refinement */
.archive-header {
  background: #fff;
  border-bottom: 0;
  padding: 26px 0 18px;
}

.archive-header__inner {
  max-width: 1280px;
  margin: 0 auto;
}

.archive-header__title {
  margin: 0;
  font-size: clamp(1.9rem, 2.4vw, 2.6rem);
  font-weight: 700;
  letter-spacing: 0;
  text-align: center;
  text-transform: uppercase;
}

.archive-header__desc {
  margin: 12px auto 0;
  max-width: 68ch;
  text-align: center;
  font-size: 14px;
  line-height: 1.6;
}

.shop-layout {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px 56px;
}

.shop-content {
  position: relative;
}

.shop-toolbar {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 20px;
  align-items: end;
  margin-bottom: 18px;
  padding-bottom: 0;
  border-bottom: 0;
}

.shop-toolbar__count {
  margin: 0;
  font-size: 12px;
  line-height: 1.4;
  color: #6f6f6f;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.shop-toolbar__right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 18px;
}

.shop-toolbar__filter-btn {
  margin-right: 0;
  padding: 0;
  border: 0;
  background: transparent;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.woocommerce-ordering {
  margin: 0 !important;
}

.woocommerce-ordering select {
  min-width: 168px;
  height: 42px;
  padding: 0 14px;
  border: 1px solid #cbcbcb;
  border-radius: 0;
  background: #fff;
  color: #111;
  font-size: 13px;
}

.woocommerce ul.products,
.js-products-grid {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 12px !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
  width: 100% !important;
}

.product-item {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
}

/* Force first row alignment */
.js-products-grid>*:first-child {
  grid-column: 1;
}

/* Responsive columns */
body.aidan-shop-columns-2 .js-products-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

body.aidan-shop-columns-3 .js-products-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

body.aidan-shop-columns-4 .js-products-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

body.aidan-shop-columns-5 .js-products-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

body.aidan-shop-columns-6 .js-products-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
}

@media (max-width: 1200px) {
  .js-products-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 1024px) {
  .js-products-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 768px) {
  .js-products-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
}

.product-card {
  border: 1px solid #e7e7e7;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.product-card__body {
  padding: 14px 12px 16px;
  gap: 6px;
}

.product-card__title {
  font-family: 'Kanit', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  line-height: 1.3 !important;
  letter-spacing: 0 !important;
}

.product-card__price {
  margin-top: 0;
  font-size: 14px;
}

.shop-sidebar {
  width: min(380px, 92vw);
}

.shop-sidebar__close {
  width: 36px;
  height: 36px;
  border: 1px solid #ddd;
  border-radius: 999px;
}

body.has-shop-sidebar-open::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(12, 12, 12, 0.38);
  z-index: 999;
}

.shop-results {
  position: relative;
}

.shop-results.is-loading::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.7));
  pointer-events: none;
}

.shop-pagination.is-hidden {
  display: none;
}

.product-details__title {
  font-family: 'Kanit', sans-serif !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  line-height: 1.2 !important;
  margin: 0 0 15px !important;
  color: #000 !important;
}

@media (max-width: 768px) {
  .product-details__title {
    font-size: 22px !important;
  }
}

.product-details__price {
  font-size: 20px !important;
  font-weight: 700 !important;
  margin-bottom: 25px !important;
}

.shop-load-status {
  min-height: 24px;
  margin-top: 18px;
  text-align: center;
  font-size: 12px;
  color: #666;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.shop-scroll-sentinel {
  width: 100%;
  height: 1px;
}

/* ── 19. Product Single ───────────────────────────────────── */
.product-single__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  /* Reduced from space-12 */
  align-items: start;
  padding-block: var(--space-6);
  /* Reduced from space-10 */
}

/* Gallery */
.product-gallery {
  position: sticky;
  top: 80px;
}

.product-gallery__main {
  position: relative;
  display: flex;
  align-items: center;
  /* This centers it vertically */
  justify-content: center;
  /* This centers it horizontally */
  overflow: hidden;
  aspect-ratio: 1 / 1;
  /* Forces the container to be square */
  background-color: #f9f9f9;
  /* Optional: adds a light tint to empty areas */
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-3);
  cursor: crosshair;
}

.product-gallery__main-img {
  width: 100%;
  height: auto;
  object-fit: contain;
  /* Ensures the whole jersey is visible without cropping */
  transition: transform var(--transition-slow);
}

/* The Magnifier Lens */
.img-zoom-lens {
  position: absolute;
  border: 1px solid #d4d4d4;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
  cursor: none;
  display: none;
  pointer-events: none;
  z-index: 100;
}

.gallery-zoom-btn {
  position: absolute;
  bottom: var(--space-3);
  right: var(--space-3);
  background: rgba(255, 255, 255, .9);
  border-radius: var(--radius-full);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-sm);
  transition: background var(--transition);
}

.gallery-zoom-btn:hover {
  background: #fff;
}

.product-gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 15px;
}

.product-gallery__thumb {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 2px;
  overflow: hidden;
  border: 1px solid #e5e5e5;
  transition: all 0.2s ease;
  padding: 0;
  cursor: pointer;
}

.product-gallery__thumb.is-active,
.product-gallery__thumb:hover {
  border-color: #000;
}

.product-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Details */
.product-details__cats {
  font-size: var(--font-size-xs);
  color: var(--color-primary);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: var(--space-2);
}

/* Header & Share */
.product-details__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
  margin-bottom: 0;
  /* Reduced */
}

.product-details__share {
  display: flex;
  gap: var(--space-3);
  color: var(--color-text-muted);
  margin-top: 8px;
}

.product-details__share a:hover {
  color: #000;
}

.product-details__price {
  margin-bottom: var(--space-6);
}

.product-details__price-display {
  font-family: 'Exo 2', sans-serif !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  color: #000;
}

/* Features List */
.product-details__features {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-block: var(--space-8);
  padding-block: var(--space-6);
  border-block: 1px solid var(--color-border);
}

.p-feature {
  display: flex;
  gap: 15px;
  align-items: center;
  padding-bottom: 15px;
}

.p-feature__icon {
  font-size: 18px;
  width: 40px;
  height: 40px;
  background: #f9f9f9;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.p-feature__text strong {
  display: block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  color: #000;
  margin-bottom: 2px;
}

.p-feature__text span {
  font-size: 11px;
  color: #666;
}

/* Specs Table */
.product-details__specs {
  margin-top: var(--space-8);
}

.specs-table {
  width: 100%;
  border-collapse: collapse;
}

.specs-table th {
  text-align: left;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--color-text-muted);
  padding-block: var(--space-3);
  border-bottom: 1px solid var(--color-border);
  width: 30%;
}

.specs-table td {
  font-size: var(--font-size-sm);
  padding-block: var(--space-3);
  border-bottom: 1px solid var(--color-border);
  color: #000;
  font-weight: 500;
}

.product-details__payments {
  margin-top: var(--space-8);
}

/* ── WooCommerce Hook-based Summary Wrapper ───────────────────── */
/* 
  Plugins (swatches, size chart, add-ons) inject output here.
  We reset default WC layout and keep spacing tight.
*/
.product-details__wc-summary {
  margin-top: var(--space-4);
}

/* Remove WC's own title/price since we render them above */
.product-details__wc-summary .product_title,
.product-details__wc-summary .price:first-of-type {
  display: none !important;
}

/* Star rating — show inline */
.product-details__wc-summary .woocommerce-product-rating {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

/* Add to cart form */
.woocommerce div.product form.cart {
  margin-bottom: var(--space-4);
}

/* ── Variation controls ───────────────────────────────────────── */
.woocommerce div.product form.cart .variations {
  margin-bottom: var(--space-5);
}

.woocommerce div.product form.cart .variations select,
.variations_form .variations select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 2px solid #000;
  border-radius: 0;
  /* sharp square */
  font-size: var(--font-size-sm);
  font-family: var(--font-body);
  appearance: none;
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23666' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 14px center;
  cursor: pointer;
  transition: border-color var(--transition);
  margin-bottom: var(--space-3);
}

.woocommerce div.product form.cart .variations select:focus,
.variations_form .variations select:focus {
  outline: none;
  border-color: var(--color-primary);
}

/* ── Custom Theme Swatches (Square Buttons) ────────────────── */
.aidan-swatches-container {
  margin-bottom: 25px;
}

.aidan-swatch-label {
  font-family: 'Kanit', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  margin-bottom: 12px !important;
  color: #000 !important;
}


.aidan-selected-value {
  font-weight: 700;
  margin-left: 2px;
}

.aidan-swatches-items {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 15px;
  font-family: 'Kanit', sans-serif !important;
}


.aidan-swatch-item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 54px;
  height: 48px;
  background: #fff;
  border: 1px solid #e5e5e5;
  color: #000;
  font-family: 'Kanit', sans-serif !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s ease;
  padding: 0 12px;
}

.aidan-swatch-item:hover {
  border-color: #000;
}

.aidan-swatch-item.is-selected {
  border: 2px solid #000 !important;
  font-weight: 700 !important;
}

/* Clear Link Styling */
.reset_variations {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  color: #d11252 !important;
  /* Magenta/Pink from reference */
  text-decoration: none;
  margin-top: 5px;
  transition: opacity 0.2s;
}

.reset_variations:hover {
  opacity: 0.7;
}


/* Size label row with Size Chart link */
.woocommerce div.product form.cart .variations th.label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding-bottom: 10px;
  width: 100%;
}

/* ── Quantity + Add to cart row ──────────────────────────────── */
.woocommerce div.product form.cart .cart,
.woocommerce-variation-add-to-cart,
.variations_button {
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  /* Keep buttons in row on desktop */
  margin-top: 25px;
  width: 100%;
}

@media (max-width: 768px) {

  .woocommerce div.product form.cart .cart,
  .woocommerce-variation-add-to-cart,
  .variations_button {
    flex-wrap: wrap !important;
  }
}

/* ── Quantity Selector Styling ──────────────────────────────── */
.quantity {
  display: flex !important;
  align-items: stretch;
  border: 1px solid #ddd !important;
  border-radius: 0 !important;
  height: 50px;
  overflow: hidden;
  margin-right: 15px !important;
  background: #fff;
}

.qty-btn {
  width: 40px !important;
  height: 50px !important;
  background: transparent !important;
  color: #000 !important;
  border: none !important;
  font-size: 20px !important;
  font-weight: 300 !important;
  cursor: pointer;
  display: flex !important;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease;
}

.qty-btn:hover {
  background: #f9f9f9 !important;
}

.quantity input[type="number"].qty {
  width: 50px !important;
  height: 50px !important;
  border: none !important;
  text-align: center !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  color: #000 !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  -moz-appearance: textfield;
}

.quantity input::-webkit-outer-spin-button,
.quantity input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* ── Add to Cart button ─────────────────────────────────────── */
.single_add_to_cart_button,
button.single_add_to_cart_button {
  flex: 1 1 auto !important;
  min-width: 160px;
  height: 50px !important;
  background: #999 !important;
  /* Grey like reference */
  color: #fff !important;
  border: none !important;
  border-radius: 0 !important;
  font-family: 'Kanit', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;

  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  padding: 0 25px !important;
  transition: opacity 0.2s ease;
  cursor: pointer;
  white-space: nowrap;
}

/* ── Variation Table & Label Cleanup ──────────────────────── */
.variations {
  width: 100% !important;
  display: block !important;
  border: none !important;
}

.variations tbody,
.variations tr {
  display: block !important;
  width: 100% !important;
}

.variations th,
.variations td.label,
.variations label {
  display: none !important;
  width: 0 !important;
  padding: 0 !important;
}

.variations td.value {
  display: block !important;
  width: 100% !important;
  padding: 0 !important;
  margin-bottom: 20px !important;
}

/* ── Summary Layout: Vertical Stacking ─────────────────────── */
/* We use Grid to force a single-column layout for the main parts */
form.cart,
.single_variation_wrap {
  display: grid !important;
  grid-template-columns: 100% !important;
  width: 100% !important;
  gap: 20px !important;
}

/* The buttons row: Allow wrapping for plugins */
.woocommerce-variation-add-to-cart {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  /* Changed from nowrap */
  align-items: center !important;
  gap: 15px !important;
  width: 100% !important;
}

/* YITH Addons: Ensure full width row */
.yith-wapo-block {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  /* Allow full width */
  clear: both !important;
  margin-top: 15px !important;
}

/* Order Total: Dedicated Row at Bottom */
#wapo-total-price-table,
#yith-wapo-order-total {
  display: block !important;
  width: 100% !important;
  max-width: 450px !important;
  background: #fff !important;
  border: 1px solid #e5e5e5 !important;
  margin-top: 10px !important;
  padding: 0 !important;
  box-sizing: border-box !important;
}

#wapo-total-price-table table,
#yith-wapo-order-total table {
  width: 100% !important;
  margin: 0 !important;
  border-collapse: collapse !important;
  table-layout: fixed !important;
}

#wapo-total-price-table tr.wapo-total-order th,
#wapo-total-price-table tr.wapo-total-order td,
#yith-wapo-order-total tr.wapo-total-order th,
#yith-wapo-order-total tr.wapo-total-order td {
  padding: 15px 20px !important;
  font-family: 'Kanit', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: #000 !important;
  border: none !important;
  vertical-align: middle !important;
}

#wapo-total-price-table tr.wapo-total-order th,
#yith-wapo-order-total tr.wapo-total-order th {
  text-align: left !important;
  width: 60% !important;
  border-right: 1px solid #e5e5e5 !important;
}

#wapo-total-price-table tr.wapo-total-order td,
#yith-wapo-order-total tr.wapo-total-order td {
  text-align: left !important;
  padding-left: 30px !important;
  width: 40% !important;
}

/* ── Hide default WooCommerce variation price inside form ── */
/* (Since we have our own price display above) */
.single_variation_wrap .woocommerce-variation-price {
  display: none !important;
}

/* ── DESIGNIO CUSTOMIZE button (The existing one) ────────────── */
.designio-btn-wrapper,
#designio-start-customizing,
.designio-customize-btn {
  display: inline-flex !important;
  margin: 0 !important;
}

#designio-start-customizing.designio-customize-btn {
  flex: 1 1 auto !important;
  min-width: 180px;
  height: 50px !important;
  background: #000 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0 !important;
  font-family: 'Kanit', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;

  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  padding: 0 25px !important;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-decoration: none !important;
  cursor: pointer;
}

/* ── Container layout for buttons ───────────────────────────── */
form.cart {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  /* Consistent spacing between rows */
}

.woocommerce-variation-add-to-cart,
.variations_button {
  display: flex !important;
  align-items: center;
  flex-wrap: wrap !important;
  /* Allow wrapping */
  gap: 15px;
  width: 100% !important;
}

@media (max-width: 768px) {

  .woocommerce-variation-add-to-cart,
  .variations_button {
    flex-wrap: wrap !important;
  }

  .quantity {
    margin-bottom: 0;
    margin-right: 0 !important;
  }

  /* Inline quantity buttons in mobile */
  .woocommerce-variation-add-to-cart,
  .variations_button {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .variations_button .qty-btn,
  .variations_button .quantity {
    height: 45px !important;
  }

  .single_add_to_cart_button,
  #designio-start-customizing {
    width: 100% !important;
    flex: 1 1 100% !important;
    margin-bottom: 10px !important;
  }
}


/* ── Size chart link styling (most size chart plugins output a link/button) */
.woocommerce-product-attributes-item--size-guide a,
a.size-chart-link,
a.woo-size-guide-link,
button.woo-size-guide-button,
.size-chart-button {
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-decoration: underline;
  color: var(--color-text);
  cursor: pointer;
  display: inline-block;
  margin-bottom: var(--space-3);
}


/* Size chart link styling */
.size-chart-link,
.woo-size-guide-link,
.size-chart-button,
.woocommerce-product-attributes-item--size-guide a {
  font-size: 11px !important;
  font-weight: 600 !important;
  text-decoration: underline !important;
  color: #666 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
  display: inline-block !important;
  transition: color 0.2s ease;
}

.product-details__share {
  display: flex;
  gap: 10px;
  margin-left: auto;
}

.product-details__share a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: #000;
  color: #fff !important;
  border-radius: 50%;
  transition: background 0.2s ease;
}

.product-details__share a:hover {
  background: #333;
}

.product-details__share svg {
  width: 14px;
  height: 14px;
}

/* We use JS to move it inside the label, but this is a fallback */
.size-chart-link,
.woo-size-guide-link,
.size-chart-button {
  font-family: 'Kanit', sans-serif !important;
  font-size: 16px !important;
  text-decoration: underline !important;
  text-transform: uppercase;
  font-weight: 500;
  margin-left: auto !important;
}

/* Tabs */
.tabs__nav {
  display: flex;
  gap: var(--space-8);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-8);
  margin-top: 40px;
}

.tabs__tab {
  background: none;
  border: none;
  padding: 15px 0;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #888;
  cursor: pointer;
  position: relative;
  transition: color 0.2s ease;
  margin-bottom: -1px;
}

.tabs__tab.is-active {
  color: #000;
}

.tabs__tab.is-active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: #000;
}

.tabs__panel {
  display: none;
}

.tabs__panel.is-active {
  display: block;
}

.product-description {
  line-height: 1.8;
}

.product-description p,
.product-description li {
  margin-bottom: var(--space-4);
  font-size: var(--font-size-base);
}

.product-description ul,
.product-description ol {
  margin-left: var(--space-6);
  list-style: disc;
}

.product-shipping-info h3 {
  margin: var(--space-6) 0 var(--space-3);
  font-size: var(--font-size-xl);
}

.product-shipping-info ul {
  margin-left: var(--space-6);
  list-style: disc;
}

.product-shipping-info li {
  margin-bottom: var(--space-2);
  font-size: var(--font-size-sm);
}

/* ── 20. Pages ────────────────────────────────────────────── */
.page-hero {
  position: relative;
  min-height: 400px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.page-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .5);
}

.page-hero__title {
  position: relative;
  z-index: 1;
  color: #fff;
  padding: var(--space-10) var(--space-8);
  font-size: var(--font-size-4xl);
}

.page-inner-header {
  background: #000;
  padding-block: var(--space-12);
  margin-bottom: var(--space-10);
  text-align: center;
}

.page-inner-header__title {
  color: #fff;
  font-size: 2.5rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
}

.page-content {
  padding-block: var(--space-12);
  max-width: 900px;
  line-height: 1.8;
}

/* ── 21. WhatsApp FAB ─────────────────────────────────────── */
.whatsapp-fab {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  width: 56px;
  height: 56px;
  background: #25D366;
  color: #fff;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(37, 211, 102, .4);
  z-index: 999;
  transition: transform var(--transition), box-shadow var(--transition);
}

/* ── Hero Link ── */
.hero__link-wrap {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
}

/* ── Full-width Image ── */
.fw-image-section {
  line-height: 0;
}

.fw-image {
  width: 100%;
  height: auto;
  display: block;
}

/* ── Reviews ── */
.reviews-section {
  background-color: #fff;
}

.reviews-wrap {
  margin-top: 3rem;
}

/* ── Logos ── */
.logos-section {
  background-color: #fafafa;
}

.logos-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 3rem;
  margin-top: 3rem;
}

/* Slider Mode */
.logos-slider-wrap {
  overflow: hidden;
  position: relative;
  margin-top: 3rem;
  padding: 1rem 0;
}

.logos-slider-track {
  display: flex;
  align-items: center;
  gap: 3rem;
  will-change: transform;
}

/* Continuous Marquee Animation */
.logos-slider-track.is-animating {
  animation: logos-marquee 40s linear infinite;
}

@keyframes logos-marquee {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

.logo-item {
  flex: 0 0 auto;
  width: calc((100% / var(--per-view, 6)) - 3rem);
  max-width: 180px;
  opacity: 0.8;
  filter: grayscale(0.5);
  transition: all 0.3s ease;
  display: flex;
  justify-content: center;
}

@media (max-width: 1024px) {
  .logo-item {
    width: calc((100% / 4) - 3rem);
  }
}

@media (max-width: 768px) {
  .logo-item {
    width: calc((100% / 2) - 3rem);
  }
}

.logo-item:hover {
  opacity: 1;
  filter: grayscale(0);
}

.logo-item__img {
  max-width: 100%;
  height: auto;
}

.whatsapp-fab:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 20px rgba(37, 211, 102, .5);
  color: #fff;
}

/* ── 22. Footer Overhaul ──────────────────────────────────── */
.site-footer {
  background-color: #000;
  color: #fff;
  padding-top: 4rem;
}

.footer-usps {
  border-bottom: 1px solid #333;
  padding-bottom: 3rem;
  margin-bottom: 4rem;
}

.footer-usps__grid {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  gap: 2rem;
}

.footer-usp {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.footer-usp__icon {
  font-size: 1.5rem;
}

.footer-main__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 3rem;
  margin-bottom: 4rem;
}

.footer-col__heading {
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  margin-bottom: 2rem;
  font-weight: 700;
  color: #fff;
}

.footer-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-nav li {
  margin-bottom: 0.75rem;
}

.footer-nav a {
  color: #999;
  text-decoration: none;
  font-size: 0.9rem;
  transition: color 0.3s ease;
}

.footer-nav a:hover {
  color: #fff;
}

.footer-logo img {
  width: 7vw;
  height: auto;
  display: block;
}

@media (max-width: 768px) {
  .footer-logo-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: var(--space-4);
  }

  .footer-logo img {
    width: 25vw;
  }
}

.footer-about {
  margin-top: 1.5rem;
  font-size: 0.9rem;
  color: #999;
  line-height: 1.7;
}

.footer-contact-info {
  margin: 1.5rem 0;
  font-size: 0.9rem;
  color: #999;
  line-height: 1.6;
}

.footer-socials {
  display: flex;
  gap: 1.25rem;
  margin-top: 2rem;
}

.footer-socials a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 50%;
  color: #fff;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.footer-socials a:hover {
  background: var(--color-primary, #e21c23);
  transform: translateY(-3px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.3);
}

.footer-socials a svg {
  display: block;
}

/* ── Hide Floating Widgets (Theme & Plugin fallback) ─────────── */
.global-widgets,
.floating-widget,
.we-are-here-icon,
.whatsapp-fab,
#global-widgets {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* ── Footer Layout Stability ────────────────────────────────── */
.footer-main__grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
  gap: 3rem !important;
  margin-bottom: 4rem;
}

.footer-newsletter-wrap {
  border-top: 1px solid #333;
  padding: 3rem 0;
  display: flex;
  justify-content: flex-end;
}

.footer-newsletter {
  max-width: 500px;
  width: 100%;
}

.footer-newsletter__tagline {
  font-size: 0.8rem;
  color: #999;
  margin-bottom: 1rem;
}

.footer-newsletter__form {
  display: flex;
  gap: 1rem;
}

.footer-newsletter__form input {
  flex-grow: 1;
  background: #fff;
  border: none;
  padding: 0.75rem 1rem;
  color: #000;
}

.footer-newsletter__form button {
  background: #000;
  border: 1px solid #fff;
  color: #fff;
  padding: 0.75rem 2rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s ease;
}

.footer-newsletter__form button:hover {
  background: #fff;
  color: #000;
}

.footer-copyright {
  background: #000;
  border-top: 1px solid #333;
  padding: 2rem 0;
  text-align: center;
  font-size: 0.8rem;
  color: #666;
}

/* ── 23. WooCommerce Notices ──────────────────────────────── */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
  font-size: var(--font-size-sm);
}

.woocommerce-message {
  background: #d1fae5;
  border-left: 4px solid #10b981;
  color: #065f46;
}

.woocommerce-error {
  background: #fee2e2;
  border-left: 4px solid #ef4444;
  color: #991b1b;
}

.woocommerce-info {
  background: #dbeafe;
  border-left: 4px solid #3b82f6;
  color: #1e3a8a;
}

/* ── 24. Utility ──────────────────────────────────────────── */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ── 25. Responsive ───────────────────────────────────────── */
@media (max-width: 1100px) {
  .product-grid--4col {
    grid-template-columns: repeat(3, 1fr);
  }

  .footer-top__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }

  .footer-col--brand {
    max-width: 100%;
    grid-column: 1 / -1;
  }

  .category-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 900px) {
  .shop-layout {
    grid-template-columns: 1fr;
  }

  .shop-sidebar {
    position: fixed;
  }

  .shop-sidebar__mobile-toggle {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    font-weight: 600;
    margin-bottom: var(--space-4);
    width: 100%;
  }

  .shop-sidebar__inner {
    display: none;
  }

  .shop-sidebar.is-open .shop-sidebar__inner {
    display: block;
  }

  .product-single__grid {
    grid-template-columns: 1fr;
  }

  .product-gallery {
    position: static;
  }

  .blog-layout {
    grid-template-columns: 1fr;
  }

  .blog-sidebar {
    display: none;
  }

  .product-grid--3col {
    grid-template-columns: repeat(2, 1fr);
  }

  .blog-grid--3col {
    grid-template-columns: repeat(2, 1fr);
  }

  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

.mobile-menu-close {
  display: none;
}

@media (max-width: 768px) {
  :root {
    --container-pad: var(--space-4);
  }

  /* Mobile nav */
  .site-nav {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--color-bg);
    z-index: 20000; /* Above currency switcher */
    overflow-y: auto;
    padding: var(--space-8) var(--space-6) var(--space-6);
  }

  .site-nav.is-open {
    display: block;
    animation: slideDown 0.3s ease;
  }

  .mobile-menu-close {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    background: none;
    border: none;
    padding: var(--space-2);
    cursor: pointer;
    color: var(--color-text);
    z-index: 1010;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .site-nav__list {
    display: block;
    list-style: none;
    padding: 0;
    margin: 0;
  }

  /* Handle all menu items with children across all levels */
  .site-nav__list li {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    border-bottom: 1px solid var(--color-border);
    position: relative;
  }

  .site-nav__list li a {
    flex: 1;
    padding: var(--space-3) 0;
    font-size: 1rem;
    font-weight: 500;
    color: var(--color-text);
    text-decoration: none;
  }

  /* Hide any existing theme icons (right arrows) in mobile */
  .site-nav__list li a::after,
  .site-nav__list li .sub-menu-toggle {
    display: none !important;
  }

  /* Toggle button */
  .menu-toggle-btn {
    background: none;
    border: none;
    padding: var(--space-3) var(--space-4);
    cursor: pointer;
    color: var(--color-text);
    display: flex !important;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
  }

  .site-nav__list li.is-open>.menu-toggle-btn {
    transform: rotate(180deg);
  }

  /* Submenus */
  .site-nav__list ul {
    display: none !important;
    width: 100%;
    list-style: none;
    padding: 0 0 var(--space-2) var(--space-4);
    margin: 0;
    border-top: 1px solid var(--color-border-light);
  }

  .site-nav__list li.is-open>ul {
    display: block !important;
  }

  .site-nav__list ul li {
    border: none;
  }

  .site-nav__list ul a {
    display: block;
    padding: var(--space-2) 0;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    font-weight: 400;
  }

  /* Deep Nested Submenus */
  .site-nav__list ul ul {
    padding-left: var(--space-4);
    border-top: none;
  }

  .header-btn--menu {
    display: flex;
  }

  .header-btn--search {
    display: none;
  }

  .hero {
    min-height: var(--h-mobile, 450px);
  }

  .hero__content {
    padding-block: var(--space-10);
    max-width: 100%;
  }

  .hero__heading {
    font-size: 2rem;
  }

  .hero__ctas {
    flex-direction: column;
  }

  .hero__ctas .btn {
    width: 100%;
    justify-content: center;
  }

  .category-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .product-grid--4col {
    grid-template-columns: repeat(2, 1fr);
  }

  .blog-grid--3col,
  .blog-grid--2col {
    grid-template-columns: 1fr;
  }

  .cta-banner__inner {
    flex-direction: column;
    text-align: center;
  }

  .cta-banner__actions {
    width: 100%;
    flex-direction: column;
  }

  .cta-banner__actions .btn {
    width: 100%;
    justify-content: center;
  }

  .footer-top__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
  }

  .footer-bottom__inner {
    flex-direction: column;
    text-align: center;
  }

  .usp-strip__grid {
    grid-template-columns: 1fr 1fr;
  }

  .product-gallery__thumbs {
    flex-wrap: nowrap;
    overflow-x: auto;
  }
}

@media (max-width: 480px) {
  .category-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .footer-top__grid {
    grid-template-columns: 1fr;
  }

  .usp-strip__grid {
    grid-template-columns: 1fr;
  }

  .product-card__body {
    padding: var(--space-3);
  }

  .tabs__tab {
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-xs);
  }
}

/* ── 26. Print ────────────────────────────────────────────── */
@media print {

  .site-header,
  .site-footer,
  .whatsapp-fab,
  .shop-sidebar,
  .product-details__wa-btn {
    display: none !important;
  }
}

/* ── 27. ACF Layout Components ────────────────────────────── */

/* 5-column product grid */
.product-grid--5col {
  grid-template-columns: repeat(5, 1fr);
}

/* Testimonials */
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}

.testimonial-card {
  background: #ffffff;
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  border: 1px solid var(--color-border);
}

.testimonial-card__header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.testimonial-card__avatar img {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  object-fit: cover;
}

.testimonial-card__avatar-placeholder {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: var(--font-size-lg);
  flex-shrink: 0;
}

.testimonial-card__name {
  display: block;
  font-weight: 700;
  font-size: var(--font-size-sm);
}

.testimonial-card__stars {
  display: flex;
  gap: 2px;
  margin-top: var(--space-1);
}

.testimonial-card__source {
  margin-left: auto;
  flex-shrink: 0;
}

.testimonial-card__text {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: 1.7;
}

/* Sport Grid */
.sport-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}

.sport-grid__item {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 3/4;
}

.sport-grid__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.sport-grid__item:hover .sport-grid__img {
  transform: scale(1.04);
}

.sport-grid__label {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  color: #fff;
  font-family: var(--font-heading);
  font-size: var(--font-size-lg);
  font-weight: 700;
  text-transform: uppercase;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .5);
}

/* Stats Bar */
.stats-bar {
  padding-block: var(--space-10);
}

.stats-bar__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-6);
  text-align: center;
}

.stat-item__number {
  display: block;
  font-family: var(--font-heading);
  font-size: var(--font-size-4xl);
  font-weight: 900;
  color: #fff;
  line-height: 1;
}

.stat-item__label {
  display: block;
  font-size: var(--font-size-sm);
  color: rgba(255, 255, 255, .7);
  margin-top: var(--space-1);
  text-transform: uppercase;
  letter-spacing: .07em;
}

/* Image + Text Row */
.image-text-row__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}

.image-text-row--img-right .image-text-row__media {
  order: 2;
}

.image-text-row--img-right .image-text-row__body {
  order: 1;
}

.image-text-row__img {
  width: 100%;
  border-radius: var(--radius-lg);
  object-fit: cover;
  max-height: 500px;
}

.image-text-row__heading {
  font-size: var(--font-size-3xl);
  margin-bottom: var(--space-4);
}

.image-text-row__content {
  color: var(--color-text-muted);
  line-height: 1.8;
  margin-bottom: var(--space-6);
}

/* Team Grid */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  text-align: center;
}

.team-card__photo {
  width: 120px;
  height: 120px;
  border-radius: var(--radius-full);
  object-fit: cover;
  margin: 0 auto var(--space-3);
}

.team-card__name {
  font-size: var(--font-size-lg);
  font-weight: 700;
}

.team-card__role {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

/* About Intro */
.about-intro__content {
  max-width: 900px;
  margin-inline: auto;
  text-align: center;
  font-size: var(--font-size-lg);
  line-height: 1.8;
  color: var(--color-text);
}

/* Blog 4-col */
.blog-grid--4col {
  grid-template-columns: repeat(4, 1fr);
}

/* CTA banner overlay */
.cta-banner {
  position: relative;
}

.cta-banner__overlay {
  position: absolute;
  inset: 0;
}

.cta-banner--centred .cta-banner__inner {
  flex-direction: column;
  text-align: center;
}

/* Text block */
.text-block {
  line-height: 1.8;
}

.text-block p,
.text-block li {
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-4);
}

.text-block h2 {
  margin: var(--space-8) 0 var(--space-4);
}

/* ── 28. Responsive — ACF components ──────────────────────── */
@media (max-width: 1100px) {
  .product-grid--5col {
    grid-template-columns: repeat(4, 1fr);
  }

  .testimonials-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .sport-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .team-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 900px) {
  .product-grid--5col {
    grid-template-columns: repeat(3, 1fr);
  }

  .image-text-row__grid {
    grid-template-columns: 1fr;
  }

  .image-text-row--img-right .image-text-row__media {
    order: 1;
  }

  .image-text-row--img-right .image-text-row__body {
    order: 2;
  }

  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .blog-grid--4col {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .product-grid--5col {
    grid-template-columns: repeat(2, 1fr);
  }

  .testimonials-grid {
    grid-template-columns: 1fr;
  }

  .sport-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .blog-grid--4col {
    grid-template-columns: 1fr;
  }

  .stat-item__number {
    font-size: var(--font-size-3xl);
  }
}

/* ── Bulk Order Page ── */
.b2b-hero {
  height: 400px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  position: relative;
  color: #fff;
}

.b2b-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
}

.b2b-hero .container {
  position: relative;
  z-index: 2;
}

.b2b-hero__title {
  font-size: 4rem;
  margin-bottom: 1rem;
}

.b2b-form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4rem;
}

@media (min-width: 992px) {
  .b2b-form-grid {
    grid-template-columns: 2fr 1fr;
  }
}

.pro-sidebar-card {
  background: #fafafa;
  padding: 2rem;
  border: 1px solid var(--border-color);
}

.b2b-process-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 3rem;
  margin-top: 3rem;
}

.process-step {
  position: relative;
}

.process-step__num {
  font-family: var(--font-heading);
  font-size: 3rem;
  font-weight: 700;
  color: #eee;
  display: block;
  line-height: 1;
  margin-bottom: 1rem;
}

.process-step__title {
  font-size: 1.25rem;
  margin-bottom: 0.75rem;
  text-transform: uppercase;
}

/* ── 15. WooCommerce Cart & Checkout ──────────────────────── */

/* Notifications */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-top: 4px solid #8cb123;
  /* Aidan Green */
  background: #f7f7f7;
  padding: 15px 25px;
  margin-bottom: 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
}

.woocommerce-message .button {
  background: #000;
  color: #fff;
  padding: 8px 15px;
  font-size: 12px;
}


/* ── 24. WooCommerce Cart & Checkout Redesign ────────────── */

/* Page Header for Cart/Checkout */
.woocommerce-cart .entry-title,
.woocommerce-checkout .entry-title {
  display: none;
  /* We use the theme's custom header */
}


/* ── Cart Page: Full-Width 2:1 Layout ──────────────────────────── */

/* Expand page container to full width on cart */
.woocommerce-cart .container,
.woocommerce-cart .page-content {
  max-width: 100% !important;
  padding-left: 40px !important;
  padding-right: 40px !important;
}

/* Two-column wrapper */
.aidan-cart-wrapper {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 30px !important;
  align-items: flex-start !important;
  width: 100% !important;
}

/* Left: Cart form takes ~60% */
.aidan-cart-form {
  flex: 0 0 60% !important;
  min-width: 0 !important;
}

/* Right: Totals takes ~40% */
.aidan-cart-collaterals {
  flex: 0 0 38% !important;
  min-width: 0 !important;
}

/* Hide cross-sells */
.aidan-cart-collaterals .cross-sells {
  display: none !important;
}

/* Keep old .woocommerce div as block (don't flex it) */
.woocommerce-cart .woocommerce {
  display: block !important;
}

@media (max-width: 991px) {
  .aidan-cart-wrapper {
    flex-direction: column !important;
  }

  .aidan-cart-form,
  .aidan-cart-collaterals {
    flex: 1 1 auto !important;
    width: 100% !important;
  }
}

/* ── Cart Table Box ─────────────────────────────────────────────── */
.aidan-cart-table-box {
  font-family: var(--font-heading) !important;
  border: 1px solid #e0e0e0 !important;

  border-radius: 0 !important;
  overflow: hidden !important;
  margin-bottom: 0 !important;
}

.woocommerce-cart table.cart {
  width: 100% !important;
  border-collapse: collapse !important;
  border: none !important;
}

.woocommerce-cart table.cart th {
  background: #fff !important;
  color: #000 !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  padding: 16px 14px !important;
  border-bottom: 1px solid #e5e5e5 !important;
  text-align: left !important;
}

.woocommerce-cart table.cart th.product-remove,
.woocommerce-cart table.cart th.product-thumbnail {
  width: 30px !important;
}

.woocommerce-cart table.cart td {
  padding: 20px 14px !important;
  border-bottom: 1px solid #f0f0f0 !important;
  vertical-align: middle !important;
  color: #000 !important;
  background: #fff !important;
}

/* Product thumbnail size — force square */
.woocommerce-cart table.cart td.product-thumbnail {
  width: 90px !important;
  padding: 15px 10px !important;
}

.woocommerce-cart table.cart td.product-thumbnail img,
.woocommerce-cart table.cart td.product-thumbnail a img {
  display: block !important;
  width: 80px !important;
  height: 80px !important;
  min-width: 80px !important;
  min-height: 80px !important;
  max-width: 80px !important;
  object-fit: cover !important;
  object-position: center !important;
  border: 1px solid #eee !important;
}

/* Product name */
.woocommerce-cart table.cart td.product-name {
  min-width: 180px !important;
}

.woocommerce-cart table.cart td.product-name a {
  font-family: 'Kanit', sans-serif !important;
  font-weight: 600 !important;
  color: #000 !important;
  text-decoration: none !important;
  font-size: 14px !important;
}


.woocommerce-cart table.cart td.product-name dl {
  font-size: 12px !important;
  color: #666 !important;
  margin-top: 4px !important;
}

/* Remove ×  */
.woocommerce-cart table.cart .remove {
  color: #f00 !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}

/* Quantity input */
.woocommerce-cart table.cart .quantity input {
  width: 55px !important;
  height: 40px !important;
  border: 1px solid #d0d0d0 !important;
  border-radius: 0 !important;
  text-align: center !important;
  font-size: 14px !important;
}

/* ── Cart Actions: Update + Coupon ──────────────────────────────── */
.aidan-cart-actions {
  margin-top: 0 !important;
  border: 1px solid #e0e0e0 !important;
  border-top: none !important;
  padding: 16px 14px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  background: #fff !important;
}

.aidan-cart-update {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.aidan-btn-update {
  background: #f5f5f5 !important;
  color: #333 !important;
  border: 1px solid #d0d0d0 !important;
  padding: 10px 20px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  text-transform: none !important;
}

.aidan-coupon-row {
  display: flex !important;
  gap: 0 !important;
  width: 100% !important;
}

.aidan-coupon-row input#coupon_code {
  flex: 1 !important;
  height: 46px !important;
  border: 1px solid #d0d0d0 !important;
  border-right: none !important;
  padding: 0 16px !important;
  font-size: 13px !important;
  border-radius: 0 !important;
  background: #fff !important;
}

.aidan-btn-coupon {
  background: #000 !important;
  color: #fff !important;
  border: none !important;
  height: 46px !important;
  padding: 0 24px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  text-transform: none !important;
}

/* ── Cart Totals Box ────────────────────────────────────────────── */
.cart_totals {
  border: 1px solid #d0d0d0 !important;
  padding: 28px !important;
  background: #fff !important;
  border-radius: 0 !important;
}

.cart_totals h2 {
  font-size: 18px !important;
  font-weight: 700 !important;
  text-transform: none !important;
  margin-bottom: 20px !important;
  padding-bottom: 0 !important;
  border-bottom: none !important;
}

.cart_totals table {
  width: 100% !important;
  margin-bottom: 0 !important;
  border-collapse: collapse !important;
}

.cart_totals table th {
  width: 45% !important;
  text-align: left !important;
  vertical-align: top !important;
  padding: 14px 0 !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #000 !important;
  border-bottom: 1px solid #f0f0f0 !important;
}

.cart_totals table td {
  width: 55% !important;
  text-align: right !important;
  vertical-align: top !important;
  padding: 14px 0 !important;
  font-size: 14px !important;
  color: #000 !important;
  border-bottom: 1px solid #f0f0f0 !important;
}

.cart_totals .order-total th,
.cart_totals .order-total td {
  font-weight: 700 !important;
  font-size: 16px !important;
  border-bottom: none !important;
  padding-top: 16px !important;
}

.cart_totals .shipping td {
  text-align: right !important;
}

.cart_totals .shipping td address,
.cart_totals .shipping td p {
  font-style: normal !important;
  font-size: 13px !important;
  color: #555 !important;
  text-align: right !important;
}

/* Proceed to Checkout button */
.cart_totals .wc-proceed-to-checkout {
  margin-top: 20px !important;
}

.cart_totals .wc-proceed-to-checkout a.checkout-button {
  display: block !important;
  width: 100% !important;
  background: #000 !important;
  color: #fff !important;
  text-align: center !important;
  padding: 16px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  border: none !important;
  border-radius: 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.cart_totals .wc-proceed-to-checkout a.checkout-button:hover {
  background: #222 !important;
}

/* Mobile specific cart totals fix */
@media (max-width: 768px) {
  .cart_totals table th,
  .cart_totals table td {
    width: 100% !important;
    display: block !important;
    text-align: left !important;
    padding: 10px 0 !important;
  }

  .cart_totals table td {
    border-bottom: 1px solid #f0f0f0 !important;
  }

  .cart_totals .shipping td {
    text-align: left !important;
  }

  .cart_totals .shipping td address,
  .cart_totals .shipping td p {
    text-align: left !important;
  }
}


/* Woocommerce messages on cart page */
.woocommerce-cart .woocommerce-message,
.woocommerce-cart .woocommerce-info {
  margin-bottom: 20px !important;
}


/* ══════════════════════════════════════════════════════════════════
   CHECKOUT — CSS-ONLY two-column layout
   Works with WooCommerce's native DOM (no PHP template needed):
     form.checkout → display:grid with two columns
     #customer_details → left column (billing + shipping)
     #order_review_heading + #order_review → right column
   ══════════════════════════════════════════════════════════════════ */

/* Full width container */
.woocommerce-checkout .container,
.woocommerce-checkout .page-content {
  max-width: 100% !important;
  padding-left: 40px !important;
  padding-right: 40px !important;
}

/* Also support our custom PHP wrapper if/when template is active */
.aidan-checkout-wrapper {
  display: flex !important;
  flex-direction: row !important;
  gap: 30px !important;
  align-items: flex-start !important;
  width: 100% !important;
}

.aidan-checkout-left {
  flex: 0 0 58% !important;
  min-width: 0 !important;
}

.aidan-checkout-right {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  position: sticky !important;
  top: 100px !important;
}

/* ── CSS Grid on WooCommerce's native form.checkout ──────────────
   Default structure:
     form.checkout
       ├── #customer_details (.col2-set)
       ├── h2 (legal - hidden)
       ├── ... (legal paragraphs - hidden)
       ├── h3#order_review_heading
       └── #order_review
   We push #order_review_heading and #order_review to column 2.
   ──────────────────────────────────────────────────────────────── */
.woocommerce-checkout form.checkout {
  display: grid !important;
  grid-template-columns: 58fr 42fr !important;
  grid-template-rows: auto !important;
  gap: 0 30px !important;
  align-items: start !important;
}

/* Returning customer notice - above the grid, full width */
.woocommerce-checkout .woocommerce-info {
  grid-column: 1 / -1 !important;
}

/* Left column: customer details (billing + shipping) */
.woocommerce-checkout form.checkout #customer_details {
  grid-column: 1 !important;
  grid-row: 1 / span 20 !important;
}

/* Right column: Order summary heading */
.woocommerce-checkout form.checkout #order_review_heading {
  grid-column: 2 !important;
  grid-row: 1 !important;
}

/* Right column: Order review */
.woocommerce-checkout form.checkout #order_review {
  grid-column: 2 !important;
  grid-row: 2 !important;
}

/* Hide ALL legal/copyright injected content 
   (any h2 that is a direct child of form.checkout, and all their siblings) */
.woocommerce-checkout form.checkout>h2 {
  display: none !important;
}

.woocommerce-checkout form.checkout>h3:not(#order_review_heading) {
  display: none !important;
}

.woocommerce-checkout form.checkout>p {
  display: none !important;
}

.woocommerce-checkout form.checkout>ol {
  display: none !important;
}

.woocommerce-checkout form.checkout>ul:not(.payment_methods) {
  display: none !important;
}

.woocommerce-checkout form.checkout>div:not(#customer_details):not(#order_review):not(.aidan-checkout-wrapper) {
  display: none !important;
}

/* Hide the duplicate CHECKOUT page title */
.woocommerce-checkout .page-inner-header,
.woocommerce-checkout .page-hero {
  display: none !important;
}

.woocommerce-checkout h1.entry-title,
.woocommerce-checkout h1.page-title {
  display: none !important;
}

/* Mobile: stack columns */
@media (max-width: 991px) {
  .woocommerce-checkout form.checkout {
    grid-template-columns: 1fr !important;
    gap: 20px 0 !important;
  }

  .woocommerce-checkout form.checkout #customer_details,
  .woocommerce-checkout form.checkout #order_review_heading,
  .woocommerce-checkout form.checkout #order_review {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  .aidan-checkout-left,
  .aidan-checkout-right {
    flex: 1 1 auto !important;
    width: 100% !important;
    position: static !important;
  }
}


/* ── Left: Returning Customer Notice ──────────────────────────── */
.woocommerce-checkout .woocommerce-info {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 0 16px 0 !important;
  font-size: 13px !important;
  color: #333 !important;
}

.woocommerce-checkout .woocommerce-info a {
  color: #c0392b !important;
  text-decoration: none !important;
}

/* ── Billing/Shipping Box ─────────────────────────────────────── */
.aidan-checkout-left .woocommerce-billing-fields,
.aidan-checkout-left .woocommerce-shipping-fields,
.aidan-checkout-left .woocommerce-additional-fields {
  border: 1px solid #e0e0e0 !important;
  padding: 28px !important;
  background: #fff !important;
  margin-bottom: 20px !important;
}

/* Section headings */
.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3 {
  font-size: 16px !important;
  font-weight: 600 !important;
  text-transform: none !important;
  margin-bottom: 20px !important;
  padding-bottom: 0 !important;
  border-bottom: none !important;
  color: #000 !important;
}

/* col-1 and col-2 hidden borders */
.aidan-checkout-left .col-1,
.aidan-checkout-left .col-2 {
  width: 100% !important;
}

/* Two-column grid for First + Last name using WC classes */
.woocommerce-billing-fields .form-row-first,
.woocommerce-billing-fields .form-row-last,
.woocommerce-shipping-fields .form-row-first,
.woocommerce-shipping-fields .form-row-last {
  display: inline-block !important;
  width: calc(50% - 8px) !important;
}

.woocommerce-billing-fields .form-row-first,
.woocommerce-shipping-fields .form-row-first {
  margin-right: 16px !important;
}

/* Form rows */
.woocommerce-checkout .form-row {
  margin-bottom: 14px !important;
}

/* Labels */
.woocommerce-checkout .form-row label {
  display: block !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  text-transform: none !important;
  color: #555 !important;
  margin-bottom: 6px !important;
}

.woocommerce-checkout .form-row label .required {
  color: #c0392b !important;
}

/* Inputs, selects, textareas */
.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  width: 100% !important;
  padding: 11px 14px !important;
  border: 1px solid #d0d0d0 !important;
  border-radius: 0 !important;
  font-size: 14px !important;
  background: #fff !important;
  color: #000 !important;
  outline: none !important;
  box-shadow: none !important;
}

.woocommerce-checkout .form-row input.input-text:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
  border-color: #000 !important;
}

/* Textarea (order notes) */
.woocommerce-checkout .form-row textarea {
  height: 100px !important;
  resize: vertical !important;
}

/* Ship to different address */
.woocommerce-checkout #ship-to-different-address {
  margin-bottom: 10px !important;
  font-size: 13px !important;
}

/* ── Right: "Your Order" box ─────────────────────────────────── */
.aidan-checkout-right #order_review_heading {
  font-size: 16px !important;
  font-weight: 600 !important;
  text-transform: none !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
  margin-bottom: 16px !important;
}

.aidan-checkout-right #order_review {
  border: 1px solid #d0d0d0 !important;
  padding: 24px !important;
  background: #fff !important;
}

/* Order review table */
.shop_table.woocommerce-checkout-review-order-table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin-bottom: 16px !important;
}

.shop_table.woocommerce-checkout-review-order-table th {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #000 !important;
  padding: 10px 0 !important;
  border-bottom: 1px solid #eee !important;
  text-align: left !important;
}

.shop_table.woocommerce-checkout-review-order-table th:last-child,
.shop_table.woocommerce-checkout-review-order-table td:last-child {
  text-align: right !important;
}

.shop_table.woocommerce-checkout-review-order-table td {
  font-size: 13px !important;
  padding: 12px 0 !important;
  border-bottom: 1px solid #f0f0f0 !important;
  vertical-align: top !important;
  color: #000 !important;
}

.shop_table.woocommerce-checkout-review-order-table .order-total td,
.shop_table.woocommerce-checkout-review-order-table .order-total th {
  font-weight: 700 !important;
  font-size: 15px !important;
  border-bottom: none !important;
  padding-top: 16px !important;
}

/* Coupon link */
.woocommerce-checkout .woocommerce-info.woocommerce-checkout-coupon-form~*,
#coupon_toggle,
.checkout_coupon {
  margin-bottom: 16px !important;
}

.checkout-coupon-notice,
.woocommerce-checkout form .woocommerce-checkout__coupon-info {
  font-size: 13px !important;
}

/* Payment section */
#payment {
  border: none !important;
  background: none !important;
  padding: 0 !important;
  margin-top: 16px !important;
}

#payment .payment_methods {
  border: 1px solid #e0e0e0 !important;
  padding: 16px !important;
  margin-bottom: 12px !important;
  list-style: none !important;
  background: #fff !important;
}

#payment .payment_methods li label {
  font-size: 13px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
}

#payment .payment_box {
  background: none !important;
  border: none !important;
  padding: 8px 0 0 0 !important;
  font-size: 12px !important;
  color: #666 !important;
}

/* Place Order Button */
#place_order {
  display: block !important;
  width: 100% !important;
  background: #000 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 16px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  cursor: pointer !important;
  margin-top: 16px !important;
  text-align: center !important;
}

#place_order:hover {
  background: #222 !important;
}

/* Terms & Conditions */
#payment .form-row.place-order {
  padding: 0 !important;
  background: none !important;
}

.woocommerce-terms-and-conditions-wrapper {
  font-size: 12px !important;
  color: #555 !important;
  margin-bottom: 12px !important;
}

/* Checkout page: reference layout */
.woocommerce-checkout .page-content {
  max-width: 100% !important;
  padding: 0 !important;
}

.woocommerce-checkout .woocommerce {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 24px 64px !important;
}

.aidan-checkout-title {
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-bottom: 48px !important;
  padding: 68px 24px 62px !important;
  background: #000 !important;
  color: #fff !important;
  text-align: center !important;
}

.aidan-checkout-title h1 {
  margin: 0 !important;
  color: #fff !important;
  font-size: 30px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  text-transform: uppercase !important;
}

.woocommerce-checkout form.checkout {
  display: block !important;
}

.woocommerce-checkout .woocommerce-form-login-toggle,
.woocommerce-checkout .woocommerce-form-coupon-toggle {
  max-width: 680px !important;
  margin: 0 0 22px !important;
}

.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info,
.aidan-coupon-card .woocommerce-form-coupon-toggle .woocommerce-info {
  display: flex !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 24px !important;
  border: 1px solid var(--color-border) !important;
  background: #fff !important;
  color: #111 !important;
  font-family: var(--font-heading) !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  border-radius: 4px !important;
}

.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info::before,
.aidan-coupon-card .woocommerce-form-coupon-toggle .woocommerce-info::before {
  display: none !important;
}

.woocommerce-checkout .woocommerce-info a,
.woocommerce-checkout .showcoupon,
.woocommerce-checkout .showlogin {
  color: #f00 !important;
  font-weight: 500 !important;
}

.aidan-checkout-wrapper {
  display: grid !important;
  grid-template-columns: minmax(0, 1.32fr) minmax(380px, 1fr) !important;
  gap: 24px !important;
  align-items: start !important;
  width: 100% !important;
}

.aidan-checkout-left,
.aidan-checkout-right {
  flex: none !important;
  max-width: none !important;
  min-width: 0 !important;
  position: static !important;
}

.aidan-checkout-right #order_review {
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.aidan-checkout-left .col2-set,
.aidan-checkout-left .col-1,
.aidan-checkout-left .col-2 {
  float: none !important;
  width: 100% !important;
}

.aidan-checkout-left .woocommerce-billing-fields,
.aidan-checkout-left .woocommerce-shipping-fields,
.aidan-checkout-left .woocommerce-additional-fields,
.aidan-order-card,
.aidan-coupon-card,
.aidan-payment-card {
  border: 1px solid #d9dee5 !important;
  background: #fff !important;
}

.aidan-checkout-left .woocommerce-billing-fields {
  padding: 28px !important;
  margin: 0 0 28px !important;
}

.aidan-checkout-left .woocommerce-shipping-fields {
  border: 0 !important;
  padding: 0 28px !important;
  margin: 0 0 22px !important;
}

.aidan-checkout-left .woocommerce-additional-fields {
  padding: 22px 28px !important;
  margin: 0 !important;
}

.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3,
.aidan-order-card #order_review_heading {
  margin: 0 0 28px !important;
  color: #000 !important;
  font-size: 18px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  text-transform: none !important;
}

.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  column-gap: 28px !important;
}

.woocommerce-checkout .form-row {
  float: none !important;
  width: 100% !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
}

.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
  display: block !important;
  width: 100% !important;
  margin-right: 0 !important;
}

.woocommerce-checkout .form-row-wide,
.woocommerce-checkout #billing_company_field,
.woocommerce-checkout #billing_country_field,
.woocommerce-checkout #billing_address_1_field,
.woocommerce-checkout #billing_address_2_field,
.woocommerce-checkout #billing_city_field,
.woocommerce-checkout #billing_state_field,
.woocommerce-checkout #billing_postcode_field,
.woocommerce-checkout #billing_phone_field,
.woocommerce-checkout #billing_email_field,
.woocommerce-checkout .form-row label,
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea,
.woocommerce-checkout .form-row input::placeholder,
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple,
.select2-dropdown {
  font-family: 'Kanit', sans-serif !important;
}



.woocommerce-checkout #account_password_field,
.woocommerce-checkout #shipping_company_field,
.woocommerce-checkout #shipping_country_field,
.woocommerce-checkout #shipping_address_1_field,
.woocommerce-checkout #shipping_address_2_field,
.woocommerce-checkout #shipping_city_field,
.woocommerce-checkout #shipping_state_field,
.woocommerce-checkout #shipping_postcode_field {
  grid-column: 1 / -1 !important;
}

.woocommerce-checkout .form-row label {
  margin-bottom: 8px !important;
  color: #000 !important;
  font-size: 11px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
}

.woocommerce-checkout .form-row input.input-text,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
  min-height: 48px !important;
  padding: 0 18px !important;
  border: 1px solid #111 !important;
  background: #fff !important;
  color: #000 !important;
  font-size: 15px !important;
  line-height: 48px !important;
}

.woocommerce-checkout .form-row textarea {
  min-height: 72px !important;
  padding-top: 16px !important;
  line-height: 1.4 !important;
}

.woocommerce-checkout .form-row input::placeholder,
.woocommerce-checkout .form-row textarea::placeholder {
  color: #9ca3af !important;
}

.woocommerce-checkout #ship-to-different-address {
  margin: 0 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

.woocommerce-checkout #ship-to-different-address label,
.woocommerce-checkout .woocommerce-form__label-for-checkbox {
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;
  color: #000 !important;
}

.woocommerce-checkout input[type="checkbox"] {
  width: 14px !important;
  height: 14px !important;
  margin: 0 !important;
}

.aidan-order-card,
.aidan-payment-card {
  padding: 28px !important;
}

.aidan-coupon-card {
  margin: 20px 0 !important;
}

.aidan-coupon-card .woocommerce-form-coupon-toggle {
  max-width: none !important;
  margin: 0 !important;
}

.aidan-coupon-card .checkout_coupon {
  margin: 0 !important;
  padding: 18px 24px !important;
  border: 0 !important;
}

.aidan-coupon-card .checkout_coupon p {
  margin-bottom: 12px !important;
}

.aidan-coupon-card .checkout_coupon .form-row {
  margin-bottom: 0 !important;
}

.aidan-coupon-card .checkout_coupon .button {
  min-height: 42px !important;
  padding: 0 22px !important;
  border: 1px solid #000 !important;
  background: #000 !important;
  color: #fff !important;
  text-transform: uppercase !important;
}

.aidan-order-card #order_review_heading {
  margin-bottom: 26px !important;
}

.aidan-order-card .shop_table.woocommerce-checkout-review-order-table {
  margin: 0 !important;
}

.aidan-order-card .shop_table.woocommerce-checkout-review-order-table th,
.aidan-order-card .shop_table.woocommerce-checkout-review-order-table td {
  padding: 18px 0 !important;
  border-bottom: 1px solid #8c8c8c !important;
  color: #000 !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
  font-weight: 700 !important;
}

.aidan-order-card .shop_table.woocommerce-checkout-review-order-table thead th {
  padding-top: 0 !important;
  border-bottom: 0 !important;
  font-size: 16px !important;
  font-weight: 800 !important;
}

.aidan-order-card .shop_table.woocommerce-checkout-review-order-table td:last-child,
.aidan-order-card .shop_table.woocommerce-checkout-review-order-table th:last-child {
  width: 34% !important;
  text-align: left !important;
}

.aidan-order-card .shop_table.woocommerce-checkout-review-order-table .cart-subtotal th,
.aidan-order-card .shop_table.woocommerce-checkout-review-order-table .cart-subtotal td,
.aidan-order-card .shop_table.woocommerce-checkout-review-order-table .woocommerce-shipping-totals th,
.aidan-order-card .shop_table.woocommerce-checkout-review-order-table .woocommerce-shipping-totals td,
.aidan-order-card .shop_table.woocommerce-checkout-review-order-table .order-total th,
.aidan-order-card .shop_table.woocommerce-checkout-review-order-table .order-total td {
  font-family: 'Kanit', sans-serif !important;
  font-size: 16px !important;
  font-weight: 800 !important;
}



.aidan-order-card .shop_table.woocommerce-checkout-review-order-table .order-total th,
.aidan-order-card .shop_table.woocommerce-checkout-review-order-table .order-total td {
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.aidan-order-card .woocommerce-shipping-methods,
.aidan-order-card .woocommerce-shipping-methods li {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.aidan-order-card .woocommerce-shipping-methods label,
.aidan-order-card .woocommerce-shipping-destination {
  color: #6b7280 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.aidan-payment-card #payment {
  margin: 0 !important;
}

.aidan-payment-card #payment .payment_methods {
  margin: 0 0 26px !important;
  padding: 0 !important;
  border: 0 !important;
}

.aidan-payment-card #payment .payment_methods li {
  margin: 0 !important;
}

.aidan-payment-card #payment .payment_methods li label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  color: #000 !important;
  font-family: var(--font-heading) !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: color 0.2s ease !important;
}

.aidan-payment-card #payment .payment_methods li:hover label {
  color: #f00 !important;
}

.aidan-payment-card #payment .payment_methods li input[type="radio"] {
  width: 18px !important;
  height: 18px !important;
  accent-color: #000 !important;
}

.aidan-payment-card #payment .payment_box {
  margin: 20px 0 0 !important;
  padding: 0 !important;
  color: #111 !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}

.aidan-payment-card .woocommerce-privacy-policy-text {
  margin: 28px 0 20px !important;
  color: #111 !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}

.aidan-payment-card .woocommerce-terms-and-conditions-wrapper {
  margin: 0 0 14px !important;
  color: #000 !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.aidan-payment-card #place_order {
  min-height: 48px !important;
  margin: 0 !important;
  padding: 0 18px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
}

@media (max-width: 991px) {
  .woocommerce-checkout .woocommerce {
    padding: 0 18px 48px !important;
  }

  .aidan-checkout-title {
    margin-bottom: 34px !important;
    padding: 48px 18px !important;
  }

  .aidan-checkout-wrapper {
    grid-template-columns: 1fr !important;
  }

  .woocommerce-checkout .woocommerce-form-login-toggle,
  .woocommerce-checkout .woocommerce-form-coupon-toggle {
    max-width: none !important;
  }
}

@media (max-width: 640px) {

  .woocommerce-billing-fields__field-wrapper,
  .woocommerce-shipping-fields__field-wrapper {
    grid-template-columns: 1fr !important;
  }

  .aidan-checkout-left .woocommerce-billing-fields,
  .aidan-checkout-left .woocommerce-additional-fields,
  .aidan-order-card,
  .aidan-payment-card {
    padding: 22px 18px !important;
  }
}



/* Footer layout fix */
.footer-main__grid {
  display: grid !important;
  grid-template-columns: 2fr 1fr 1fr 1fr !important;
  gap: 3rem !important;
}

@media (max-width: 1024px) {
  .footer-main__grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 640px) {
  .footer-main__grid {
    grid-template-columns: 1fr !important;
  }

  .footer-usps__grid {
    justify-content: flex-start !important;
  }
}

/* Aggressive Floating Widget Hiding */
#tidio-chat,
#tidio-chat-iframe,
.tidio-chat-widget,
.join-chat,
.wa-button,
.whatsapp-chat-widget,
.crisp-client,
#crisp-chat-box,
.fb-customerchat,
#fb-root,
.ht-ctc-chat,
#ht-ctc-chat,
.wa-chat-box,
.whatsapp-button,
[class*="whatsapp"],
[id*="whatsapp"],
[class*="chat-widget"],
[id*="chat-widget"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
  z-index: -9999 !important;
}

/* ── Wishlist Removal ────────────────────────────────────────── */
.wishlist-btn,
.wishlist_button,
.add_to_wishlist,
.woocommerce-wishlist,
.header-btn--wishlist,
.wishlist-wrapper,
.yith-wcwl-add-to-wishlist,
.woocommerce-wishlists-add-to-wishlist,
.wl-add-to,
.wl-add-but,
[class*="wishlist"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  height: 0 !important;
  width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  pointer-events: none !important;
}

/* ── YITH Addons Styling ────────────────────────────────────── */
.yith-wapo-block {
  margin-top: 25px !important;
  padding-top: 20px !important;
  border-top: 1px solid #eee !important;
  width: 100% !important;
  clear: both !important;
}

.yith-wapo-addon {
  background: transparent !important;
  padding: 0 !important;
  border: none !important;
}

.yith-wapo-addon .addon-header {
  margin-bottom: 15px !important;
}

.yith-wapo-addon-label {
  font-weight: 600 !important;
  font-family: var(--font-heading) !important;
}


/* ── 22. Wishlist ─────────────────────────────────────────── */
#wl-wrapper {
  display: none !important;
}

/* ============================================================
   OVERRIDES FOR NEW PRODUCT PAGE DESIGN (Image 2)
   ============================================================ */

/* 1. Lighter Title Font */
.product-details__title {
  font-weight: 700 !important;
  font-size: 24px !important;
  margin-bottom: 12px !important;
}

/* 2. Price and Share Icon Row */
.product-details__price-share-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 25px;
}

.product-details__price {
  margin-bottom: 0 !important;
}

/* 3. Strip Backgrounds from Share Icons */
.product-details__share {
  gap: 15px;
  margin-left: auto;
}

.product-details__share a {
  background: transparent !important;
  color: #000 !important;
  width: auto !important;
  height: auto !important;
  transition: opacity 0.2s ease;
}

.product-details__share a:hover {
  background: transparent !important;
  opacity: 0.6;
}

/* 4. Align "SIZE CHART" to the right and format text */
.woocommerce div.product form.cart .variations th.label {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: 100%;
}

.size-chart-link,
.woo-size-guide-link,
.size-chart-button,
.woocommerce-product-attributes-item--size-guide a {
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-decoration: underline !important;
  text-underline-offset: 4px !important;
  text-transform: uppercase !important;
  color: #000 !important;
  margin-left: auto !important;
  /* Pushes it to the right */
  background: transparent !important;
  display: inline-block !important;
  letter-spacing: 0.05em !important;
}

/* 5. Make "ADD TO CART" Button Black */
.single_add_to_cart_button,
button.single_add_to_cart_button {
  background: #222 !important;
  /* Replaces the #999 grey */
  color: #fff !important;
}

.single_add_to_cart_button:hover,
button.single_add_to_cart_button:hover {
  background: #000 !important;
}

/* ============================================================
   FINAL PRODUCT PAGE LAYOUT FIXES
   ============================================================ */

/* 1. Force strict vertical stacking for EVERYTHING in the summary */
.product-details {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  /* Tighten overall gaps */
}

.product-details>* {
  margin-top: 0 !important;
  margin-bottom: 5px !important;
  /* Minimal gap between blocks */
}

/* 2. Fix form.cart stacking for plugins (YITH, etc.) */
.woocommerce div.product form.cart {
  display: flex !important;
  flex-direction: column !important;
  gap: 15px !important;
  margin-top: 10px !important;
  width: 100% !important;
}

/* Ensure the wrapper around buttons and YITH add-ons is also stacked */
.single_variation_wrap,
.woocommerce-variation-add-to-cart,
.variations_button {
  display: flex !important;
  flex-direction: column !important;
  /* Force stack add-ons above/below buttons */
  align-items: flex-start !important;
  width: 100% !important;
  gap: 15px !important;
}

/* Re-allow buttons to be horizontal if they are both simple buttons */
.woocommerce-variation-add-to-cart .single_add_to_cart_button,
.woocommerce-variation-add-to-cart .designio-customize-btn {
  width: 100% !important;
  /* Stack them on mobile/desktop for safety first */
  margin: 0 !important;
}

@media (min-width: 769px) {
  .woocommerce-variation-add-to-cart {
    flex-direction: row !important;
    /* Side by side buttons on desktop */
    flex-wrap: wrap !important;
  }

  .woocommerce-variation-add-to-cart .single_add_to_cart_button,
  .woocommerce-variation-add-to-cart .designio-customize-btn {
    width: auto !important;
    flex: 1 !important;
  }
}

/* 3. Ensure YITH and Order Total take full width and clear everything */
.yith-wapo-block,
#wapo-total-price-table,
#yith-wapo-order-total {
  width: 100% !important;
  max-width: 100% !important;
  display: block !important;
  clear: both !important;
  order: 10 !important;
  /* Push towards the bottom of the form */
}

/* 4. Fix Huge Gaps on Mobile */
@media (max-width: 768px) {
  .product-single__grid {
    padding-block: 10px !important;
    gap: 20px !important;
  }

  .product-details__title {
    font-size: 20px !important;
    margin-bottom: 8px !important;
  }

  .aidan-swatches-container {
    margin-bottom: 15px !important;
  }

  .product-details__payments {
    margin-top: 10px !important;
  }
}

/* 5. Fix Mobile Overlapping */
.product-details__wa-btn,
.product-details__payments,
.product-details__specs {
  position: relative !important;
  z-index: 1 !important;
  float: none !important;
  clear: both !important;
}

/* ============================================================
   YITH ADD-ON: FORCE INLINE ROW (OVERRIDE INLINE STYLES)
   ============================================================ */

/* 1. Override YITH's inline grid that shrinks the container */
.yith-wapo-block .options-container .options {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  gap: 12px !important;
}

/* 2. Strip the "position-above" stacking behavior */
.yith-wapo-block .label.position-above {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* 3. Force the main container to be a horizontal flex row */
.yith-wapo-block .option-container {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 15px !important;
  width: 100% !important;
}

/* 4. Fix the Image/Icon Size (stops it from taking up too much space) */
.yith-wapo-block .image-container {
  flex: 0 0 40px !important;
  /* Forces the icon to stay exactly 40px wide */
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

.yith-wapo-block .image-container img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
  object-fit: contain !important;
}

/* 5. Align Checkbox and Text */
.yith-wapo-block .checkbox-button-container {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
  /* Space between checkbox and text */
  margin: 0 !important;
  padding: 0 !important;
}

/* 6. Checkbox Box Sizing (Aggressive Square Reset) */
.yith-wapo-block .checkbox-button-container .checkboxbutton {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  /* Kills any background pill shape */
  background: transparent !important;
  border: none !important;
}

.yith-wapo-block .checkboxbutton input[type="checkbox"],
.yith-wapo-block .checkboxbutton input.yith-wapo-option-value {
  -webkit-appearance: checkbox !important;
  -moz-appearance: checkbox !important;
  appearance: checkbox !important;
  /* Forces native checkbox */
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  max-width: 18px !important;
  max-height: 18px !important;
  flex: 0 0 18px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 1px solid #666 !important;
  border-radius: 2px !important;
  /* THIS kills the oval stretching */
  box-sizing: border-box !important;
  opacity: 1 !important;
  visibility: visible !important;
  position: static !important;
  cursor: pointer !important;
}

/* 7. Label & Price Typography */
.yith-wapo-block .yith-wapo-addon-label {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  /* Space between "Full Sleeve" and "(+Rs100.00)" */
  margin: 0 !important;
  font-family: var(--font-heading) !important;

  font-size: 13px !important;
  font-weight: 600 !important;
  color: #000 !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

.yith-wapo-block .option-price {
  font-size: 11px !important;
  color: #666 !important;
  font-weight: 400 !important;
}

/* ── Contact Form 7 Custom Styling ──────────────────────────── */
.aidan-contact-form {
  max-width: 100%;
}

.aidan-contact-form .form-row {
  display: flex;
  gap: 20px;
  margin-bottom: 20px;
}

.aidan-contact-form .form-col {
  flex: 1;
}

.aidan-contact-form .form-row.full-width {
  display: block;
}

.aidan-contact-form input[type="text"],
.aidan-contact-form input[type="email"],
.aidan-contact-form input[type="tel"],
.aidan-contact-form textarea {
  width: 100%;
  padding: 12px 15px;
  border: 1px solid #999;
  border-radius: 4px;
  font-family: inherit;
  font-size: 15px;
  color: #333;
  background: #fff;
  transition: border-color 0.2s ease;
}

.aidan-contact-form input:focus,
.aidan-contact-form textarea:focus {
  border-color: #000;
  outline: none;
}

.aidan-contact-form textarea {
  height: 120px;
  resize: vertical;
}

.aidan-contact-form .privacy-row {
  font-size: 14px;
  color: #666;
  margin-bottom: 30px;
}

.aidan-contact-form .wpcf7-list-item {
  margin: 0;
}

.aidan-contact-form input[type="submit"] {
  background: #000;
  color: #fff;
  padding: 15px 60px;
  border: none;
  border-radius: 4px;
  font-family: inherit;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: opacity 0.2s ease;
  min-width: 200px;
}

.aidan-contact-form input[type="submit"]:hover {
  opacity: 0.8;
}

@media (max-width: 768px) {
  .aidan-contact-form .form-row {
    flex-direction: column;
    gap: 15px;
    margin-bottom: 15px;
  }
}

.woocommerce ul.products li.product a img {
  height: 337px;
}

@media (max-width: 768px) {
  .woocommerce ul.products li.product a img {
    height: 254px;
  }

  .product-card__img-link {
    height: 254px;
  }

  .product-card__img {
    width: 100%;
    height: 254px;
    object-fit: cover;
  }
}
