/*
Theme Name: Vama Foods
Theme URI: https://vamafoods.com
Author: Vama Foods
Author URI: https://vamafoods.com
Description: A premium Italian food and espresso brand theme for Vama Foods, featuring elegant typography and refined product showcases.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vama-foods
Tags: e-commerce, food, italian, minimal, elegant
*/

/* =========================================
   GOOGLE FONTS
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif:ital,wght@0,400;0,700;1,400&family=Manrope:wght@300;400;500;600;700&display=swap');

/* =========================================
   CSS CUSTOM PROPERTIES (Design Tokens)
   ========================================= */
:root {
  --color-primary:                  #26170c;
  --color-primary-container:        #3d2b1f;
  --color-secondary:                #a03f30;
  --color-surface:                  #fff8f5;
  --color-surface-low:              #fff1e8;
  --color-surface-lowest:           #ffffff;
  --color-surface-highest:          #eee0d7;
  --color-on-surface:               #211a15;
  --color-tertiary-fixed:           #ffdeae;
  --color-outline-variant:          rgba(33, 26, 21, 0.15);

  --font-display: "Noto Serif", serif;
  --font-sans:    "Manrope", sans-serif;
}

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

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-sans);
  background-color: var(--color-surface);
  color: var(--color-on-surface);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  line-height: 1.15;
}

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

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

ul, ol {
  list-style: none;
}

button {
  cursor: pointer;
  font-family: var(--font-sans);
  border: none;
  background: none;
}

/* =========================================
   UTILITIES
   ========================================= */
.serif-italic {
  font-family: var(--font-display);
  font-style: italic;
}

.container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

/* =========================================
   ANIMATIONS
   ========================================= */
@keyframes fade-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes hero-zoom {
  from { transform: scale(1.05); }
  to   { transform: scale(1.12); }
}

.animate-fade-in {
  animation: fade-in 0.8s ease-out forwards;
}

/* =========================================
   NAVBAR
   ========================================= */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  transition: background-color 0.5s ease, height 0.5s ease, box-shadow 0.5s ease;
  height: 6rem;
  /* Default: solid background so nav is always visible on non-hero pages */
  background-color: rgba(255, 248, 245, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

/* Homepage hero variant: transparent until scrolled */
.home .site-header {
  background-color: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.site-header.scrolled {
  height: 4rem;
  background-color: rgba(255, 248, 245, 0.95) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 1px 12px rgba(33, 26, 21, 0.06);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.site-header__left {
  display: flex;
  align-items: center;
  gap: 3rem;
}

.site-logo {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: var(--color-primary);
}

.primary-nav {
  display: none;
  gap: 2rem;
}

.primary-nav a {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-weight: 600;
  transition: opacity 0.2s;
}

.primary-nav a:hover {
  opacity: 0.5;
}

.site-header__actions {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.icon-btn {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  position: relative;
  transition: opacity 0.2s;
  color: var(--color-primary);
}

.icon-btn:hover { opacity: 0.5; }

.cart-count {
  position: absolute;
  top: -4px;
  right: -4px;
  background: var(--color-secondary);
  color: #fff;
  font-size: 0.625rem;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.menu-toggle {
  display: flex;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-primary);
}

/* Mobile menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--color-surface);
  z-index: 60;
  display: flex;
  flex-direction: column;
  padding: 2rem;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.mobile-menu.is-open {
  transform: translateX(0);
}

.mobile-menu__close {
  align-self: flex-end;
  margin-bottom: 3rem;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-primary);
}

.mobile-menu__nav {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.mobile-menu__nav a {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.875rem;
  color: var(--color-primary);
}

/* =========================================
   HERO
   ========================================= */
.hero {
  position: relative;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  animation: hero-zoom 10s ease-in-out infinite alternate;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(38, 23, 12, 0.4), rgba(38, 23, 12, 0.7));
}

.hero__content {
  position: relative;
  z-index: 10;
  text-align: center;
  padding: 0 1.5rem;
  max-width: 56rem;
  animation: fade-in 0.8s ease-out forwards;
}

.hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 8vw, 5rem);
  color: #fff;
  margin-bottom: 2rem;
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.hero__subtitle {
  font-size: clamp(1rem, 2vw, 1.25rem);
  color: rgba(255, 248, 245, 0.9);
  margin-bottom: 3rem;
  font-weight: 300;
  letter-spacing: 0.05em;
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.7;
}

.hero__cta-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
}

.btn--primary {
  padding: 1.25rem 2.5rem;
  background: var(--color-surface-lowest);
  color: var(--color-primary);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.75rem;
  transition: all 0.3s;
  box-shadow: 0 20px 40px rgba(0,0,0,0.2);
}

.btn--primary:hover {
  background: #fff;
  transform: scale(1.05);
}

.btn--ghost {
  padding: 1.25rem 2.5rem;
  border: 1px solid rgba(255,255,255,0.3);
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.75rem;
  backdrop-filter: blur(4px);
  transition: all 0.3s;
}

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

/* =========================================
   MACHINE FEATURE SECTION
   ========================================= */
.machine-section {
  padding: 8rem 1.5rem;
}

.machine-section__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 6rem;
  align-items: center;
}

.machine-section__image-wrap {
  position: relative;
}

.machine-section__image-bg {
  position: absolute;
  inset: -2rem;
  background: rgba(38, 23, 12, 0.05);
  border-radius: 2rem;
  transform: rotate(-2deg);
}

.machine-section__image-wrap img {
  position: relative;
  border-radius: 0.5rem;
  box-shadow: 0 40px 80px rgba(33, 26, 21, 0.15);
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.machine-section__label {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.4em;
  font-weight: 700;
  color: rgba(38, 23, 12, 0.4);
  display: block;
  margin-bottom: 1rem;
}

.machine-section__title {
  font-size: clamp(2.5rem, 5vw, 3.75rem);
  color: var(--color-primary);
  line-height: 1.1;
  margin-bottom: 2rem;
}

.machine-section__desc {
  font-size: 1.25rem;
  line-height: 1.7;
  color: rgba(33, 26, 21, 0.8);
  font-weight: 300;
  margin-bottom: 3rem;
}

.features-list {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-bottom: 3rem;
}

.feature-item {
  display: flex;
  gap: 1.5rem;
  align-items: flex-start;
}

.feature-item__icon {
  color: var(--color-primary);
  flex-shrink: 0;
  transition: transform 0.3s;
}

.feature-item:hover .feature-item__icon {
  transform: scale(1.1);
}

.feature-item__title {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.6875rem;
  letter-spacing: 0.2em;
  margin-bottom: 0.5rem;
  color: var(--color-primary);
}

.feature-item__desc {
  font-size: 0.875rem;
  color: rgba(33, 26, 21, 0.6);
  line-height: 1.6;
  max-width: 28rem;
}

.btn--link {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  border-bottom: 1px solid rgba(38, 23, 12, 0.2);
  padding-bottom: 0.5rem;
  transition: border-color 0.2s;
  color: var(--color-primary);
}

.btn--link:hover {
  border-color: var(--color-primary);
}

.btn--link svg {
  transition: transform 0.2s;
}

.btn--link:hover svg {
  transform: translateX(4px);
}

/* =========================================
   PANTRY SECTION
   ========================================= */
.pantry-section {
  background: var(--color-surface-low);
  padding: 8rem 1.5rem;
}

.pantry-section__inner {
  max-width: 1280px;
  margin: 0 auto;
}

.section-header {
  text-align: center;
  margin-bottom: 6rem;
}

.section-header__label {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.4em;
  font-weight: 700;
  color: rgba(38, 23, 12, 0.4);
  display: block;
  margin-bottom: 1rem;
}

.section-header__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(3rem, 7vw, 4.5rem);
  color: var(--color-primary);
}

.section-header__divider {
  width: 6rem;
  height: 1px;
  background: rgba(38, 23, 12, 0.1);
  margin: 2rem auto 0;
}

/* Featured Products Grid */
.featured-products {
  display: grid;
  gap: 3rem;
  margin-bottom: 8rem;
}

.product-card {
  background: var(--color-surface-lowest);
  padding: 2.5rem;
  box-shadow: 0 20px 40px rgba(33, 26, 21, 0.06);
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.3s;
}

.product-card:hover {
  box-shadow: 0 30px 60px rgba(33, 26, 21, 0.1);
}

.product-card__image {
  aspect-ratio: 4 / 5;
  background: var(--color-surface-low);
  margin-bottom: 2rem;
  overflow: hidden;
}

.product-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1s ease;
}

.product-card:hover .product-card__image img {
  transform: scale(1.1);
}

.product-card__title {
  font-family: var(--font-display);
  font-size: 1.875rem;
  margin-bottom: 0.5rem;
  color: var(--color-primary);
}

.product-card__subtitle {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(38, 23, 12, 0.5);
  font-weight: 700;
  margin-bottom: 1.5rem;
}

.product-card__desc {
  color: rgba(33, 26, 21, 0.7);
  font-style: italic;
  line-height: 1.7;
  margin-bottom: 2.5rem;
  flex-grow: 1;
}

.btn--outline {
  width: 100%;
  padding: 1rem;
  border: 1px solid var(--color-outline-variant);
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  transition: border-color 0.3s, background 0.3s;
  color: var(--color-primary);
  background: transparent;
}

.btn--outline:hover {
  border-color: var(--color-on-surface);
  background: var(--color-on-surface);
  color: var(--color-surface);
}

/* Collection Grid */
.collection-grid {
  display: grid;
  gap: 3rem;
}

.collection-item {
  cursor: pointer;
}

.collection-item__image {
  aspect-ratio: 1 / 1;
  background: var(--color-surface-highest);
  margin-bottom: 1.5rem;
  overflow: hidden;
  position: relative;
}

.collection-item__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1s ease;
}

.collection-item:hover .collection-item__image img {
  transform: scale(1.1);
}

.collection-item__overlay {
  position: absolute;
  inset: 0;
  background: rgba(38, 23, 12, 0);
  transition: background 0.5s;
}

.collection-item:hover .collection-item__overlay {
  background: rgba(38, 23, 12, 0.1);
}

.collection-item__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
  color: var(--color-primary);
}

.collection-item__desc {
  font-size: 0.875rem;
  color: rgba(33, 26, 21, 0.5);
  font-style: italic;
}

/* =========================================
   FOOTER
   ========================================= */
.site-footer {
  background: var(--color-primary);
  color: var(--color-surface);
  padding: 6rem 1.5rem;
}

.site-footer__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 4rem;
}

.footer-brand__name {
  font-family: var(--font-display);
  font-size: 1.875rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  margin-bottom: 2rem;
}

.footer-brand__tagline {
  max-width: 18rem;
  color: rgba(255, 248, 245, 0.6);
  line-height: 1.6;
  font-weight: 300;
  font-size: 0.875rem;
  margin-bottom: 2rem;
}

.social-links {
  display: flex;
  gap: 1.5rem;
}

.social-link {
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid rgba(255, 248, 245, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
  color: var(--color-surface);
}

.social-link:hover {
  background: var(--color-surface);
  color: var(--color-primary);
}

.footer-nav__title {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.625rem;
  margin-bottom: 2rem;
  color: rgba(255, 248, 245, 0.4);
}

.footer-nav__list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.footer-nav__list a {
  font-size: 0.875rem;
  font-weight: 300;
  color: rgba(255, 248, 245, 0.7);
  transition: color 0.2s;
}

.footer-nav__list a:hover {
  color: var(--color-surface);
}

.site-footer__bottom {
  max-width: 1280px;
  margin: 6rem auto 0;
  padding-top: 2rem;
  border-top: 1px solid rgba(255, 248, 245, 0.05);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  font-size: 0.5625rem;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: rgba(255, 248, 245, 0.3);
}

.footer-legal-links {
  display: flex;
  gap: 2rem;
}

.footer-legal-links a:hover {
  color: var(--color-surface);
}

/* =========================================
   WORDPRESS CORE CLASSES
   ========================================= */
.wp-block-image img { border-radius: 0.25rem; }

.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}

/* =========================================
   RESPONSIVE – TABLET (768px+)
   ========================================= */
@media (min-width: 768px) {
  .primary-nav { display: flex; }
  .menu-toggle { display: none; }

  .hero__cta-group {
    flex-direction: row;
    justify-content: center;
  }

  .machine-section__inner {
    grid-template-columns: 1fr 1fr;
  }

  .featured-products {
    grid-template-columns: 1fr 1fr;
  }

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

  .site-footer__inner {
    grid-template-columns: 2fr 1fr 1fr;
  }

  .site-footer__bottom {
    flex-direction: row;
    justify-content: space-between;
  }
}

/* =========================================
   SCROLL-REVEAL UTILITY
   ========================================= */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

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

.reveal--delay-1 { transition-delay: 0.1s; }
.reveal--delay-2 { transition-delay: 0.2s; }
.reveal--delay-3 { transition-delay: 0.3s; }


/* =========================================
   OUR STORY PAGE
   ========================================= */

/* ── Hero ── */
.os-hero {
  position: relative;
  height: 870px;
  width: 100%;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding-bottom: 6rem;
  padding-left: 2rem;
  padding-right: 2rem;
}

.os-hero__bg {
  position: absolute;
  inset: 0;
}

.os-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.75);
}

.os-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(38,23,12,0.6) 0%, transparent 60%);
}

.os-hero__content {
  position: relative;
  z-index: 10;
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
}

.os-hero__title {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 5.5rem);
  color: #fff;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: 1rem;
}

.os-hero__title em { font-style: italic; }

.os-hero__subtitle {
  font-size: clamp(1rem, 2vw, 1.25rem);
  color: #eee0d7;
  font-weight: 300;
  letter-spacing: 0.04em;
  max-width: 42rem;
}

/* ── About / Antonio's Journey ── */
.os-about {
  padding: 6rem 2rem;
  background: var(--color-surface);
}

.os-about__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 5rem;
  align-items: start;
}

.os-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-secondary);
  margin-bottom: 2rem;
}

.os-about__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.25rem);
  color: var(--color-primary);
  line-height: 1.1;
  margin-bottom: 3rem;
  letter-spacing: -0.02em;
}

.os-about__copy {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.os-about__copy p {
  font-family: var(--font-display);
  font-size: 1.25rem;
  line-height: 1.75;
  font-style: italic;
  color: rgba(79, 69, 63, 0.9);
}

.os-about__bold {
  font-style: normal !important;
  font-weight: 700;
  color: var(--color-primary) !important;
}

.os-about__portrait-wrap {
  width: 100%;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: #f4e5dc;
  padding: 1.5rem;
}

.os-about__portrait-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  box-shadow: 0 25px 50px rgba(33,26,21,0.2);
}

.os-about__quote {
  background: var(--color-primary);
  color: #fff;
  padding: 2rem 2.5rem;
  margin-top: -3rem;
  margin-left: 3rem;
  position: relative;
  z-index: 2;
  box-shadow: 0 20px 40px rgba(33,26,21,0.2);
  max-width: 20rem;
}

.os-about__quote p {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.125rem;
  line-height: 1.5;
  margin-bottom: 1rem;
}

.os-about__quote-rule {
  width: 3rem;
  height: 1px;
  background: #ffdeae;
  margin-bottom: 1rem;
}

.os-about__quote cite {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(255,248,245,0.5);
  font-style: normal;
}

/* ── Beyond the Bean – Bento Grid ── */
.os-bento-section {
  padding: 6rem 2rem;
  background: var(--color-surface-low);
}

.os-bento-section__header {
  text-align: center;
  max-width: 1280px;
  margin: 0 auto 4rem;
}

.os-bento-section__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  color: var(--color-primary);
  margin-bottom: 1rem;
}

.os-bento-section__subtitle {
  font-size: 0.9375rem;
  color: rgba(33,26,21,0.6);
  max-width: 36rem;
  margin: 0 auto;
  line-height: 1.7;
}

.os-bento {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

.os-bento__item {
  position: relative;
  overflow: hidden;
  border-radius: 0.25rem;
  box-shadow: 0 4px 12px rgba(33,26,21,0.08);
}

.os-bento__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s ease;
  min-height: 280px;
}

.os-bento__item:hover img { transform: scale(1.05); }

/* Gradient overlays */
.os-bento__grad {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.os-bento__grad--bottom {
  background: linear-gradient(to top, rgba(38,23,12,0.8) 0%, transparent 60%);
}

.os-bento__grad--left {
  background: linear-gradient(to right, rgba(38,23,12,0.8) 0%, rgba(38,23,12,0.2) 50%, transparent 100%);
}

/* Tint overlay for centered-label items */
.os-bento__tint {
  position: absolute;
  inset: 0;
  background: rgba(38,23,12,0.2);
  transition: background 0.3s;
}

.os-bento__item:hover .os-bento__tint {
  background: rgba(38,23,12,0.1);
}

/* Captions */
.os-bento__caption {
  position: absolute;
  color: #fff;
  pointer-events: none;
}

.os-bento__caption--bottom {
  bottom: 0; left: 0; right: 0;
  padding: 3rem;
}

.os-bento__caption--bottom h4 {
  font-family: var(--font-display);
  font-size: 1.75rem;
  margin-bottom: 0.75rem;
}

.os-bento__caption--bottom p {
  font-size: 0.875rem;
  color: rgba(238,224,215,0.9);
  line-height: 1.6;
  font-weight: 300;
  max-width: 28rem;
}

.os-bento__caption--center {
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2rem;
}

.os-bento__caption--center span {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-style: italic;
  border-bottom: 1px solid rgba(255,255,255,0.3);
  padding-bottom: 0.5rem;
}

.os-bento__caption--left {
  top: 0; bottom: 0; left: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 3rem;
  max-width: 32rem;
}

.os-bento__caption--left h4 {
  font-family: var(--font-display);
  font-size: 1.75rem;
  margin-bottom: 0.75rem;
}

.os-bento__caption--left p {
  font-size: 0.875rem;
  color: rgba(238,224,215,0.9);
  line-height: 1.6;
  font-weight: 300;
}

.os-bento__right-col {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 1.5rem;
}

.os-bento__right-col .os-bento__item img { min-height: 220px; }
.os-bento__item--wide img { min-height: 300px; }

/* ── Vision section ── */
.os-vision {
  padding: 8rem 2rem;
  background: var(--color-surface);
  overflow: hidden;
}

.os-vision__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 3rem;
  align-items: center;
}

.os-vision__card {
  background: var(--color-surface-lowest);
  padding: 4rem;
  box-shadow: 0 25px 50px rgba(33,26,21,0.1);
  border: 1px solid rgba(33,26,21,0.06);
}

.os-vision__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  color: var(--color-primary);
  margin-bottom: 2rem;
  line-height: 1.2;
}

.os-vision__copy {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-bottom: 3rem;
}

.os-vision__copy p {
  font-size: 1.0625rem;
  color: rgba(79,69,63,0.9);
  line-height: 1.8;
  font-weight: 300;
}

.os-vision__ctas {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}

.os-vision__image {
  overflow: hidden;
  border-radius: 0.125rem;
}

.os-vision__image img {
  width: 100%;
  height: 600px;
  object-fit: cover;
  display: block;
}

/* ── Responsive ── */
@media (min-width: 768px) {

  .os-hero {
    padding-left: 6rem;
    padding-right: 6rem;
  }

  .os-about__inner {
    grid-template-columns: 1fr 1fr;
  }

  .os-bento {
    grid-template-columns: 8fr 4fr;
    grid-template-rows: auto auto;
    height: 900px;
  }

  .os-bento__item--large {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
  }

  .os-bento__right-col {
    grid-column: 2 / 3;
    grid-row: 1 / 2;
  }

  .os-bento__item--wide {
    grid-column: 1 / -1;
    grid-row: 2 / 3;
    height: 400px;
  }

  .os-bento__item--wide img { min-height: 400px; }

  .os-vision__inner {
    grid-template-columns: 7fr 6fr;
  }

  .os-vision__card {
    margin-right: -4rem;
    position: relative;
    z-index: 2;
  }
}

/* =========================================
   THE QUADRA PAGE
   ========================================= */

.quadra-page {
  padding-top: 7rem; /* clears the fixed 6rem header with breathing room */
}

/* ── Hero / Asymmetric Layout ── */
.qp-hero {
  padding: 3rem 1.5rem 6rem;
}

.qp-hero__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 4rem;
  align-items: center;
}

/* ── Carousel ── */
.qp-carousel {
  position: relative;
}

.qp-carousel__bg-offset {
  position: absolute;
  inset: -1rem;
  background: var(--color-surface-low);
  border-radius: 0.75rem;
  transform: translate(1rem, 1rem);
  z-index: 0;
}

.qp-carousel__track-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 0.5rem;
  box-shadow: 0 20px 60px rgba(33,26,21,0.15);
  border: 1px solid rgba(210,196,188,0.15);
  aspect-ratio: 1 / 1;
  background: #fff;
  z-index: 1;
}

.qp-carousel__track {
  display: flex;
  height: 100%;
  transition: transform 0.5s ease-out;
}

.qp-carousel__slide {
  min-width: 100%;
  height: 100%;
}

.qp-carousel__slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Prev / Next buttons */
.qp-carousel__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.85);
  border: none;
  border-radius: 50%;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(33,26,21,0.15);
  opacity: 0;
  transition: opacity 0.2s, background 0.2s;
  color: var(--color-primary);
  z-index: 2;
}

.qp-carousel__btn--prev { left: 1rem; }
.qp-carousel__btn--next { right: 1rem; }

.qp-carousel__track-wrap:hover .qp-carousel__btn { opacity: 1; }
.qp-carousel__btn:hover { background: #fff; }

/* Dots */
.qp-carousel__dots {
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 0.5rem;
  z-index: 2;
}

.qp-carousel__dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 9999px;
  background: rgba(38,23,12,0.2);
  border: none;
  cursor: pointer;
  transition: width 0.3s, background 0.3s;
  padding: 0;
}

.qp-carousel__dot.is-active {
  width: 1.5rem;
  background: var(--color-primary);
}

/* Badges */
.qp-carousel__badges {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  display: flex;
  gap: 0.5rem;
  z-index: 3;
}

.qp-badge {
  padding: 0.25rem 0.75rem;
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: 9999px;
}

.qp-badge--gold {
  background: #ffdeae;
  color: #281900;
}

.qp-badge--dark {
  background: var(--color-primary);
  color: #fff;
}

/* ── Product Details ── */
.qp-details__series {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-secondary);
  margin-bottom: 1rem;
}

.qp-details__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  color: var(--color-primary);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 1.5rem;
}

.qp-details__pricing {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: 2rem;
}

.qp-details__price {
  font-size: 1.875rem;
  font-weight: 300;
  color: var(--color-on-surface);
}

.qp-details__was {
  font-size: 0.875rem;
  color: rgba(129,117,110,0.9);
  text-decoration: line-through;
}

.qp-details__desc {
  font-size: 1.0625rem;
  color: rgba(79,69,63,0.9);
  line-height: 1.75;
  margin-bottom: 2.5rem;
}

/* Buttons */
.qp-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 1.25rem 2rem;
  border: none;
  border-radius: 0.25rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  cursor: pointer;
  transition: filter 0.2s, transform 0.1s;
  text-decoration: none;
}

.qp-btn:active { transform: scale(0.98); }

.qp-btn--add {
  background: var(--color-secondary);
  color: #fff;
}

.qp-btn--add:hover { filter: brightness(1.1); color: #fff; }

.qp-btn--notify {
  background: var(--color-primary);
  color: #fff;
}

.qp-btn--notify:hover { filter: brightness(1.15); }

.qp-sold-out-label {
  font-size: 0.75rem;
  color: rgba(129,117,110,0.8);
  margin-top: 0.75rem;
  text-align: center;
  letter-spacing: 0.05em;
}

/* ── Technical Excellence ── */
.qp-features {
  background: var(--color-surface-low);
  padding: 6rem 1.5rem;
}

.qp-features__inner {
  max-width: 1280px;
  margin: 0 auto;
}

.qp-features__header {
  margin-bottom: 4rem;
  text-align: center;
}

.qp-features__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  color: var(--color-primary);
  margin-bottom: 0.75rem;
}

.qp-features__rule {
  width: 6rem;
  height: 4px;
  background: var(--color-secondary);
  margin: 0 auto;
}

.qp-features__grid {
  display: grid;
  gap: 2rem;
}

.qp-feature-card {
  background: var(--color-surface-lowest);
  padding: 2.5rem;
  border: 1px solid rgba(210,196,188,0.1);
  box-shadow: 0 2px 8px rgba(33,26,21,0.05);
  transition: box-shadow 0.3s;
}

.qp-feature-card:hover { box-shadow: 0 8px 24px rgba(33,26,21,0.1); }

.qp-feature-card__icon {
  color: var(--color-secondary);
  margin-bottom: 1.5rem;
  display: block;
}

.qp-feature-card__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--color-primary);
  margin-bottom: 1rem;
}

.qp-feature-card__desc {
  font-size: 0.875rem;
  color: rgba(79,69,63,0.9);
  line-height: 1.7;
}

/* ── Anatomy / Specs ── */
.qp-specs {
  padding: 6rem 1.5rem;
}

.qp-specs__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 4rem;
}

.qp-specs__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  color: var(--color-primary);
  margin-bottom: 1.5rem;
}

.qp-specs__desc {
  font-size: 0.9375rem;
  color: rgba(79,69,63,0.9);
  line-height: 1.75;
  margin-bottom: 2rem;
}

.qp-specs__quote {
  background: #402b05;
  color: #b19263;
  padding: 1.5rem 2rem;
  border-radius: 0.25rem;
}

.qp-specs__quote p {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.0625rem;
  line-height: 1.6;
}

.qp-spec-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem 0;
  border-bottom: 1px solid rgba(210,196,188,0.3);
  gap: 1rem;
  flex-wrap: wrap;
}

.qp-specs__table { border-top: 1px solid rgba(210,196,188,0.3); }

.qp-spec-row__label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: rgba(129,117,110,0.9);
}

.qp-spec-row__value {
  font-weight: 600;
  color: var(--color-primary);
  font-size: 0.9375rem;
  text-align: right;
}

/* ── Morning Ritual ── */
.qp-ritual {
  margin-bottom: 8rem;
  overflow: hidden;
}

.qp-ritual__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
}

.qp-ritual__text {
  background: var(--color-primary-container);
  padding: 4rem 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.qp-ritual__deco {
  position: absolute;
  top: 0;
  right: 0;
  width: 6rem;
  height: 6rem;
  background: var(--color-secondary);
  border-radius: 50%;
  transform: translate(50%, -50%);
  opacity: 0.2;
}

.qp-ritual__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.25rem);
  color: #fff;
  line-height: 1.15;
  margin-bottom: 2rem;
  position: relative;
  z-index: 1;
}

.qp-ritual__desc {
  font-size: 1.0625rem;
  color: rgba(172,145,129,0.9);
  line-height: 1.75;
  margin-bottom: 2.5rem;
  position: relative;
  z-index: 1;
}

.qp-ritual__link {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  color: #ffdeae;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  transition: color 0.2s;
  position: relative;
  z-index: 1;
}

.qp-ritual__link:hover { color: #fff; }

.qp-ritual__image {
  min-height: 24rem;
  overflow: hidden;
}

.qp-ritual__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* ── NOTIFY ME MODAL ── */
.qp-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none; /* MUST be none by default — prevents backdrop from swallowing clicks */
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none; /* extra safety: no click capture when hidden */
}

.qp-modal.is-open {
  display: flex;
  opacity: 1;
  pointer-events: auto; /* restore interactivity only when open */
}

.qp-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(38,23,12,0.6);
  backdrop-filter: blur(4px);
  pointer-events: auto; /* clicks on backdrop close the modal */
}

.qp-modal__box {
  position: relative;
  background: var(--color-surface-lowest);
  max-width: 28rem;
  width: 100%;
  padding: 2.5rem;
  border-radius: 0.25rem;
  box-shadow: 0 40px 80px rgba(33,26,21,0.25);
  transform: translateY(20px);
  transition: transform 0.3s;
  z-index: 1;
}

.qp-modal.is-open .qp-modal__box { transform: translateY(0); }

.qp-modal__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(79,69,63,0.6);
  transition: color 0.2s;
  padding: 0.25rem;
}

.qp-modal__close:hover { color: var(--color-primary); }

.qp-modal__icon {
  color: var(--color-secondary);
  margin-bottom: 1.25rem;
}

.qp-modal__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--color-primary);
  margin-bottom: 0.75rem;
}

.qp-modal__subtitle {
  font-size: 0.875rem;
  color: rgba(79,69,63,0.8);
  line-height: 1.65;
  margin-bottom: 2rem;
}

.qp-modal__field {
  margin-bottom: 1.25rem;
}

.qp-modal__label {
  display: block;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-primary);
  margin-bottom: 0.5rem;
}

.qp-modal__input {
  width: 100%;
  padding: 0.875rem 1rem;
  border: 1px solid var(--color-outline-variant);
  background: var(--color-surface);
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  color: var(--color-primary);
  border-radius: 0.125rem;
  transition: border-color 0.2s;
  outline: none;
}

.qp-modal__input:focus { border-color: var(--color-primary); }
.qp-modal__input[aria-invalid="true"] { border-color: #ba1a1a; }

.qp-modal__error {
  display: block;
  color: #ba1a1a;
  font-size: 0.75rem;
  margin-top: 0.35rem;
}

/* Honeypot — hidden from humans */
.qp-modal__honeypot {
  position: absolute;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
  height: 0;
  overflow: hidden;
}

.qp-modal__submit {
  margin-top: 0.5rem;
  justify-content: center;
  gap: 0.5rem;
}

.qp-modal__privacy {
  font-size: 0.6875rem;
  color: rgba(129,117,110,0.7);
  text-align: center;
  margin-top: 1rem;
}

/* Success state */
.qp-modal__success {
  text-align: center;
  padding: 1.5rem 0;
  color: var(--color-primary);
}

.qp-modal__success svg {
  color: #2e7d32;
  margin: 0 auto 1rem;
  display: block;
}

.qp-modal__success p {
  font-size: 0.9375rem;
  line-height: 1.65;
  color: rgba(33,26,21,0.8);
}

/* Spinner */
@keyframes qp-spin {
  to { transform: rotate(360deg); }
}

.qp-spin { animation: qp-spin 0.8s linear infinite; }

/* ── Responsive ── */
@media (min-width: 768px) {
  .qp-hero__inner         { grid-template-columns: 3fr 2fr; }
  .qp-features__header    { text-align: left; }
  .qp-features__rule      { margin: 0; }
  .qp-features__grid      { grid-template-columns: repeat(3, 1fr); }
  .qp-specs__inner        { grid-template-columns: 1fr 2fr; }
  .qp-ritual__inner       { grid-template-columns: 1fr 1fr; }
  .qp-ritual__text        { padding: 6rem; }
  .qp-ritual__image       { min-height: auto; }
}

/* =========================================
   PANTRY ARCHIVE (WooCommerce Category Page)
   ========================================= */

.pantry-archive {
  padding-top: 6rem;
  min-height: 80vh;
}

/* ── Page Hero ── */
.pa-hero {
  background: var(--color-surface-low);
  padding: 5rem 1.5rem 4rem;
}

.pa-hero__inner {
  max-width: 1280px;
  margin: 0 auto;
  text-align: center;
}

.pa-hero__label {
  display: block;
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.4em;
  font-weight: 700;
  color: rgba(38, 23, 12, 0.4);
  margin-bottom: 1rem;
}

.pa-hero__title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(3rem, 7vw, 4.5rem);
  color: var(--color-primary);
  margin-bottom: 1.25rem;
  line-height: 1.1;
}

.pa-hero__desc {
  font-size: 1rem;
  color: rgba(33, 26, 21, 0.6);
  max-width: 38rem;
  margin: 0 auto;
  line-height: 1.75;
  font-style: italic;
}

.pa-hero__rule {
  width: 6rem;
  height: 1px;
  background: rgba(38, 23, 12, 0.1);
  margin: 2rem auto 0;
}

/* ── Products Section ── */
.pa-products {
  background: var(--color-surface-low);
  padding: 4rem 1.5rem 8rem;
}

.pa-products__inner {
  max-width: 1280px;
  margin: 0 auto;
}

/* Product grid — clean div, no WooCommerce ul conflicts */
.pa-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

/* ── Product Card — slightly compact ── */
.pa-card {
  background: var(--color-surface-lowest);
  box-shadow: 0 8px 24px rgba(33, 26, 21, 0.06);
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.3s;
}

.pa-card:hover {
  box-shadow: 0 16px 40px rgba(33, 26, 21, 0.1);
}

/* Image — 3:4 ratio (slightly less tall than before) */
.pa-card__image-wrap {
  display: block;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  position: relative;
  background: var(--color-surface-low);
}

.pa-card__image,
.pa-card__image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 1s ease;
}

.pa-card:hover .pa-card__image,
.pa-card:hover .pa-card__image-wrap img {
  transform: scale(1.08);
}

.pa-card__image-placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-surface-highest);
}

/* Badges */
.pa-card__badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  padding: 0.25rem 0.75rem;
  font-size: 0.5625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  border-radius: 9999px;
  z-index: 2;
}

.pa-card__badge--sale     { background: var(--color-secondary); color: #fff; }
.pa-card__badge--featured { background: #ffdeae; color: #281900; }
.pa-card__badge--soldout  { background: rgba(33,26,21,0.6); color: #fff; }

/* Card body */
.pa-card__body {
  padding: 1.25rem 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.pa-card__title {
  font-family: var(--font-display);
  font-size: 1.375rem;
  margin-bottom: 0.35rem;
  line-height: 1.2;
}

.pa-card__title a {
  color: var(--color-primary);
  text-decoration: none;
  transition: opacity 0.2s;
}

.pa-card__title a:hover { opacity: 0.7; }

.pa-card__subtitle {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(38, 23, 12, 0.5);
  font-weight: 700;
  margin-bottom: 1rem;
}

.pa-card__desc {
  font-size: 0.9375rem;
  color: rgba(33, 26, 21, 0.7);
  font-style: italic;
  line-height: 1.75;
  margin-bottom: 1.5rem;
  flex-grow: 1;
}

/* Footer: price + button */
.pa-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: auto;
  flex-wrap: wrap;
}

/* Price */
.pa-card__price {
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--color-primary);
}

/* WooCommerce price overrides */
.pa-card__price .woocommerce-Price-amount { font-weight: 300; }
.pa-card__price del { color: rgba(33,26,21,0.4); font-size: 0.875rem; margin-right: 0.5rem; }
.pa-card__price ins { text-decoration: none; color: var(--color-secondary); }

/* Add to cart button */
.pa-card__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  border: 1px solid var(--color-outline-variant);
  background: transparent;
  color: var(--color-primary);
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.3s, border-color 0.3s, color 0.3s;
  white-space: nowrap;
}

.pa-card__btn:hover {
  background: var(--color-on-surface);
  border-color: var(--color-on-surface);
  color: var(--color-surface);
}

.pa-card__btn--disabled {
  opacity: 0.4;
  cursor: not-allowed;
  border-color: var(--color-outline-variant);
  color: var(--color-primary);
}

/* WooCommerce added-to-cart state */
.pa-card__btn.added::after {
  content: ' ✓';
}

/* ── Empty State ── */
.pa-empty {
  text-align: center;
  padding: 6rem 2rem;
  color: rgba(33, 26, 21, 0.5);
}

.pa-empty p { margin-bottom: 2rem; font-size: 1rem; }

/* ── Pagination ── */
.pa-pagination {
  margin-top: 4rem;
  text-align: center;
}

.pa-pagination .woocommerce-pagination ul {
  display: inline-flex;
  gap: 0.5rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.pa-pagination .woocommerce-pagination ul li a,
.pa-pagination .woocommerce-pagination ul li span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--color-outline-variant);
  color: var(--color-primary);
  font-size: 0.8125rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
}

.pa-pagination .woocommerce-pagination ul li a:hover,
.pa-pagination .woocommerce-pagination ul li span.current {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

/* ── Responsive ── */
@media (min-width: 640px) {
  .pa-grid { grid-template-columns: repeat(2, 1fr); }
}

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

/* =========================================
   WOOCOMMERCE — SINGLE PRODUCT PAGE
   Hide blog post meta (date / author)
   that bleeds through on product pages
   ========================================= */
.single-product .entry-footer,
.single-product .entry-meta,
.single-product .posted-on,
.single-product .byline,
.woocommerce-page.single-product article .entry-footer,
.woocommerce-page.single-product article header .entry-meta {
  display: none !important;
}



/* =========================================
   WOOCOMMERCE — SINGLE PRODUCT PAGE (sp2)
   Matches the attached HTML / screenshot reference
   ========================================= */

.sp2-page {
  padding-top: 6rem;
  min-height: 80vh;
  background: var(--color-surface);
}

/* ── Hero layout ── */
.sp2-hero {
  padding: 4rem 2rem 6rem;
}

.sp2-hero__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 4rem;
  align-items: center;
}

/* ── Image side ── */
.sp2-image-wrap {
  position: relative;
}

/* Offset warm block behind image (matches HTML: -translate-x-6 translate-y-6) */
.sp2-image-wrap__bg {
  position: absolute;
  inset: 0;
  background: var(--color-surface-low);
  transform: translate(-1.5rem, 1.5rem);
  border-radius: 0.5rem;
  z-index: 0;
}

/* Image frame */
.sp2-image-wrap__frame {
  position: relative;
  z-index: 1;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: 0.5rem;
  box-shadow: 0 20px 40px rgba(33, 26, 21, 0.1);
}

.sp2-image-wrap__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s ease;
}

.sp2-image-wrap:hover .sp2-image-wrap__img {
  transform: scale(1.05);
}

.sp2-image-wrap__placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-surface-highest);
}

/* Badge (bottom-right, outside frame — matches screenshot) */
.sp2-image-wrap__badge {
  position: absolute;
  bottom: -1rem;
  right: -1rem;
  z-index: 2;
}

.sp2-badge {
  display: inline-block;
  background: #ffdeae;
  color: #281900;
  padding: 0.5rem 1.25rem;
  font-size: 0.5625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  border-radius: 0.25rem;
  box-shadow: 0 8px 20px rgba(33, 26, 21, 0.1);
}

.sp2-badge--sale {
  background: var(--color-secondary);
  color: #fff;
}

/* ── Details side ── */
.sp2-details {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
}

/* Breadcrumb */
.sp2-breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: rgba(129, 117, 110, 0.9);
}

.sp2-breadcrumb a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s;
}

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

/* Title block */
.sp2-title-block {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.sp2-title {
  font-family: var(--font-display);
  font-size: clamp(3rem, 7vw, 4.5rem);
  color: var(--color-primary);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 700;
}

/* Italic subtitle (short description) — matches "Sulla Honey with Chili Infusion" */
.sp2-subtitle {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.25rem;
  color: rgba(79, 69, 63, 0.85);
  line-height: 1.4;
}

/* Price */
.sp2-price {
  font-size: 1.875rem;
  font-weight: 300;
  color: var(--color-primary);
  font-family: var(--font-sans);
}

/* WooCommerce price tag overrides */
.sp2-price .woocommerce-Price-amount { font-weight: 300; }
.sp2-price del { color: rgba(33,26,21,0.35); font-size: 1.1rem; margin-right: 0.5rem; }
.sp2-price ins { text-decoration: none; }

/* Long description */
.sp2-desc {
  font-size: 1.0625rem;
  line-height: 1.8;
  color: rgba(79, 69, 63, 0.9);
  max-width: 28rem;
}

/* ── Add to cart actions ── */
.sp2-actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding-top: 0.5rem;
}

/* WooCommerce form.cart reset */
.sp2-actions form.cart {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 100%;
}

/* Quantity row */
.sp2-actions form.cart .quantity {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.sp2-actions form.cart .qty {
  width: 5rem;
  height: 3rem;
  border: 1px solid var(--color-outline-variant);
  background: var(--color-surface);
  text-align: center;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-primary);
  border-radius: 0.125rem;
  outline: none;
  padding: 0 0.5rem;
}

.sp2-actions form.cart .qty:focus {
  border-color: var(--color-primary);
}

/* "Add to Collection" button — matches screenshot exactly:
   dark primary-container background, full-width, space-between, arrow right */
.sp2-actions .single_add_to_cart_button,
.sp2-actions button[type="submit"].button {
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 1.25rem 2rem !important;
  background: var(--color-primary-container) !important;  /* #3d2b1f — the dark brown */
  color: #fff !important;
  border: none !important;
  border-radius: 0.5rem !important;
  font-family: var(--font-sans) !important;
  font-size: 1.0625rem !important;
  font-weight: 700 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  transition: opacity 0.2s, transform 0.1s !important;
  box-shadow: 0 20px 40px rgba(33, 26, 21, 0.1) !important;
}

/* Arrow icon appended via ::after */
.sp2-actions .single_add_to_cart_button::after {
  content: '→';
  font-size: 1.25rem;
  transition: transform 0.2s;
}

.sp2-actions .single_add_to_cart_button:hover {
  opacity: 0.9 !important;
}

.sp2-actions .single_add_to_cart_button:hover::after {
  transform: translateX(4px);
}

.sp2-actions .single_add_to_cart_button:active {
  transform: scale(0.98) !important;
}

/* Out of stock button */
.sp2-cta--disabled {
  width: 100%;
  padding: 1.25rem 2rem;
  background: rgba(33,26,21,0.15);
  color: rgba(33,26,21,0.4);
  border: none;
  border-radius: 0.5rem;
  font-family: var(--font-sans);
  font-size: 1.0625rem;
  font-weight: 700;
  cursor: not-allowed;
  text-align: left;
}

/* Small note below button */
.sp2-actions__note {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(129, 117, 110, 0.6);
  text-align: center;
  font-weight: 600;
}

/* ── Related Products ── */
.sp2-related {
  padding: 6rem 2rem;
  background: var(--color-surface);
}

.sp2-related__inner {
  max-width: 1280px;
  margin: 0 auto;
}

.sp2-related__header {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 3rem;
}

.sp2-related__label {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--color-secondary);
  margin-bottom: 0.5rem;
}

.sp2-related__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  color: var(--color-primary);
  line-height: 1.1;
}

.sp2-related__view-all {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--color-primary);
  text-decoration: none;
  transition: gap 0.2s;
}

.sp2-related__view-all:hover { gap: 0.6rem; }

.sp2-related__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}

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

/* Related card — matches HTML reference card style */
.sp2-related-card {
  background: var(--color-surface-lowest);
  padding: 1rem;
  border-radius: 0.5rem;
  border: 1px solid rgba(210, 196, 188, 0.1);
  box-shadow: 0 8px 24px rgba(33, 26, 21, 0.06);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.sp2-related-card:hover {
  border-color: rgba(210, 196, 188, 0.4);
  box-shadow: 0 30px 60px rgba(33, 26, 21, 0.1);
}

.sp2-related-card__image {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 0.25rem;
  margin-bottom: 1rem;
}

.sp2-related-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.sp2-related-card:hover .sp2-related-card__img {
  transform: scale(1.08);
}

.sp2-related-card__body {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.sp2-related-card__info { flex: 1; }

.sp2-related-card__title {
  font-family: var(--font-display);
  font-size: 1.125rem;
  color: var(--color-primary);
  margin-bottom: 0.35rem;
}

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

.sp2-related-card__desc {
  font-size: 0.875rem;
  color: rgba(79, 69, 63, 0.8);
  line-height: 1.6;
  margin-bottom: 0.75rem;
}

.sp2-related-card__price {
  font-size: 0.9375rem;
  font-weight: 300;
  color: var(--color-primary);
}

/* Add to cart icon button (round) */
.sp2-related-card__btn {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  background: var(--color-surface-low);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-primary);
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
  align-self: center;
}

.sp2-related-card__btn:hover {
  background: var(--color-primary);
  color: #fff;
}

/* ── Product Tabs ── */
.sp2-tabs {
  background: var(--color-surface-low);
  padding: 4rem 2rem 6rem;
}

.sp2-tabs__inner {
  max-width: 1280px;
  margin: 0 auto;
}

.sp2-tabs .woocommerce-tabs ul.tabs {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem;
  display: flex;
  border-bottom: 1px solid var(--color-outline-variant);
  gap: 0;
}

.sp2-tabs .woocommerce-tabs ul.tabs::before,
.sp2-tabs .woocommerce-tabs ul.tabs::after { display: none; }

.sp2-tabs .woocommerce-tabs ul.tabs li {
  margin: 0; padding: 0; border: none; background: none; border-radius: 0;
}

.sp2-tabs .woocommerce-tabs ul.tabs li::before,
.sp2-tabs .woocommerce-tabs ul.tabs li::after { display: none; }

.sp2-tabs .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 0.875rem 1.5rem;
  font-family: var(--font-sans);
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(33,26,21,0.4);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.2s, border-color 0.2s;
}

.sp2-tabs .woocommerce-tabs ul.tabs li.active a,
.sp2-tabs .woocommerce-tabs ul.tabs li a:hover {
  color: var(--color-primary);
  border-bottom-color: var(--color-secondary);
}

.sp2-tabs .woocommerce-tabs .panel {
  padding: 2rem 0 0;
  border: none;
  background: none;
  color: rgba(33,26,21,0.75);
  font-size: 1rem;
  line-height: 1.8;
}

.sp2-tabs .woocommerce-tabs .panel h2 { display: none; }

/* ── Responsive ── */
@media (min-width: 768px) {
  .sp2-hero__inner {
    grid-template-columns: 7fr 5fr;
    gap: 5rem;
  }

  .sp2-related__header {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
  }



  .sp2-image-wrap__badge {
    bottom: -2rem;
    right: -2rem;
  }
}
