/* LRB Luxe Claws – Main Theme CSS */

/* ========================================================================
   CSS VARIABLES
   ======================================================================== */
:root {
  --color-primary: #993366;
  --color-primary-foreground: #ffffff;
  --color-background: #f9f6f8;
  --color-foreground: #191114;
  --color-secondary: #ede8ec;
  --color-muted: #ddd5da;
  --color-muted-foreground: #665d62;
  --color-card: #fdfbfc;
  --color-footer-bg: #100b0e;
  --color-footer-fg: #b3a4ad;
  /* Borders track text/background contrast (Customizer “Border” removed as redundant). */
  --color-border: color-mix(in srgb, var(--color-foreground) 16%, var(--color-background));

  --font-display: 'Cormorant Garamond', serif;
  --font-body: 'Outfit', sans-serif;

  --radius: 0.5rem;
  --logo-height: 64px;

  --shadow-soft: 0 4px 24px -4px rgba(25,17,20,0.06);
  --shadow-elevated: 0 8px 40px -8px rgba(25,17,20,0.10);
  --shadow-glow: 0 8px 40px rgba(153,51,102,0.12);
  --transition-smooth: cubic-bezier(0.4, 0, 0.2, 1);

  --btn-radius: 9999px;
  --btn-height: 48px;
  --btn-padding: 0 2rem;
  --btn-font-size: 0.875rem;
  --btn-font-weight: 500;
  --btn-letter-spacing: 0.05em;
  --btn-text-transform: none;

  --header-height: 80px;
}

/* ========================================================================
   BASE RESET
   ======================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { overflow-x: hidden; }

@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

body {
  background-color: var(--color-background);
  color: var(--color-foreground);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 500;
}
img, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: var(--font-body); cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: var(--font-body); font-size: 0.875rem; }

/* ========================================================================
   LAYOUT UTILITIES
   ======================================================================== */
.container-wide {
  width: 100%;
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}
@media (min-width: 1024px) {
  .container-wide { padding-left: 2rem; padding-right: 2rem; }
}

.scroll-mt { scroll-margin-top: 6rem; }
.font-display { font-family: var(--font-display) !important; }
.text-center { text-align: center; }
.text-sm { font-size: 0.875rem; }

/* ========================================================================
   TYPOGRAPHY COMPONENTS
   ======================================================================== */
.editorial-quote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.5rem;
  line-height: 1.5;
  color: var(--color-foreground);
}
@media (min-width: 768px) { .editorial-quote { font-size: 1.875rem; } }

.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-primary);
  font-weight: 500;
  margin-bottom: 1rem;
}

.section-title {
  font-size: 1.875rem;
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}
@media (min-width: 768px) { .section-title { font-size: 2.25rem; } }
@media (min-width: 1024px) { .section-title { font-size: 3rem; } }

/* ========================================================================
   BUTTONS
   ======================================================================== */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background-color: var(--color-primary);
  color: var(--color-primary-foreground);
  padding: 0.875rem 2rem;
  border-radius: var(--btn-radius);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  transition: opacity 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 4px 20px rgba(153,51,102,0.15);
  cursor: pointer;
  border: none;
}
.btn-primary:hover { opacity: 0.9; box-shadow: 0 8px 30px rgba(153,51,102,0.25); }

.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  background: transparent;
  color: var(--color-foreground);
  border: 1px solid rgba(25,17,20,0.2);
  padding: 0.875rem 2rem;
  border-radius: var(--btn-radius);
  font-size: 0.875rem;
  font-weight: 500;
  transition: border-color 0.2s ease;
  cursor: pointer;
}
.btn-outline:hover { border-color: rgba(25,17,20,0.4); }

.btn-primary-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-primary);
  color: var(--color-primary-foreground);
  padding: 0.875rem 2rem;
  border-radius: var(--btn-radius);
  font-size: 0.875rem;
  font-weight: 500;
  transition: opacity 0.2s ease;
}
.btn-primary-link:hover { opacity: 0.9; }

/* ========================================================================
   HEADER
   ======================================================================== */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  transition: all 0.3s var(--transition-smooth);
  background: linear-gradient(to bottom, rgba(0,0,0,0.7), rgba(0,0,0,0.3), transparent);
}
.site-header.is-solid {
  background: #ffffff;
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--color-border);
}
/* WordPress admin bar: keep fixed header below toolbar (preview + logged-in users). */
body.admin-bar .site-header {
  top: 32px;
}
@media screen and (max-width: 782px) {
  body.admin-bar .site-header {
    top: 46px;
  }
}
body.admin-bar .scroll-mt {
  scroll-margin-top: calc(6rem + 32px);
}
@media screen and (max-width: 782px) {
  body.admin-bar .scroll-mt {
    scroll-margin-top: calc(6rem + 46px);
  }
}

.site-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 80px;
}
@media (min-width: 1024px) { .site-nav { height: 96px; } }

.site-logo-link { display: flex; align-items: center; }
.site-logo-img {
  height: var(--logo-height) !important;
  width: auto !important;
  display: block;
  border-radius: 50%;
  object-fit: cover;
}
.site-logo-text {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  line-height: var(--logo-height);
  display: block;
}

.desktop-nav { display: none; }
@media (min-width: 768px) { .desktop-nav { display: block; } }

.theme-nav-list {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 2.5rem;
}
.theme-nav-list a, .theme-nav-link {
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
  transition: color 0.2s ease;
  font-family: var(--font-body);
}
.site-header:not(.is-solid) .theme-nav-list a,
.site-header:not(.is-solid) .theme-nav-link {
  color: rgba(255,255,255,0.85);
}
.site-header:not(.is-solid) .theme-nav-list a:hover,
.site-header:not(.is-solid) .theme-nav-link:hover { color: #fff; }
.site-header.is-solid .theme-nav-list a,
.site-header.is-solid .theme-nav-link { color: rgba(25,17,20,0.6); }
.site-header.is-solid .theme-nav-list a:hover,
.site-header.is-solid .theme-nav-link:hover { color: var(--color-foreground); }

.header-actions { display: flex; align-items: center; gap: 0.5rem; }

.cart-btn {
  position: relative;
  padding: 0.5rem;
  transition: opacity 0.2s ease;
  display: flex;
  align-items: center;
}
.cart-btn:hover { opacity: 0.6; }
.site-header:not(.is-solid) .cart-btn { color: #fff; }
.site-header.is-solid .cart-btn { color: var(--color-foreground); }
.theme-cart-count {
  position: absolute;
  top: -2px;
  right: -2px;
  width: 1.25rem;
  height: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.625rem;
  font-weight: 500;
  background-color: var(--color-primary);
  color: var(--color-primary-foreground);
  border-radius: 50%;
}
.theme-cart-count:empty { display: none; }

.mobile-menu-btn {
  padding: 0.5rem;
  transition: opacity 0.2s ease;
  display: flex;
  align-items: center;
}
.mobile-menu-btn:hover { opacity: 0.6; }
.site-header:not(.is-solid) .mobile-menu-btn { color: #fff; }
.site-header.is-solid .mobile-menu-btn { color: var(--color-foreground); }
@media (min-width: 768px) { .mobile-menu-btn { display: none; } }

.mobile-menu {
  border-top: 1px solid transparent;
  background-color: #ffffff;
  backdrop-filter: blur(10px);
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  visibility: hidden;
  pointer-events: none;
  padding: 0 1.25rem 0 2rem;
  transition:
    max-height 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.35s ease,
    padding-top 0.35s cubic-bezier(0.4, 0, 0.2, 1),
    padding-bottom 0.35s cubic-bezier(0.4, 0, 0.2, 1),
    border-color 0.25s ease,
    visibility 0s linear 0.35s;
}
.mobile-menu.is-open {
  max-height: min(75vh, 22rem);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  padding-top: 1.125rem;
  padding-bottom: 1.25rem;
  padding-left: 2rem;
  padding-right: 1.25rem;
  border-top-color: var(--color-border);
  transition:
    max-height 0.48s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.38s ease 0.05s,
    padding-top 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    padding-bottom 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    border-color 0.3s ease,
    visibility 0s linear 0s;
}

.mobile-nav-link {
  display: block;
  padding: 0.625rem 0;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-foreground);
  opacity: 0;
  transform: translateX(-12px);
  transition:
    color 0.2s ease,
    opacity 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.38s cubic-bezier(0.33, 1, 0.68, 1);
  transition-delay: 0s;
}
.mobile-menu.is-open .mobile-nav-link {
  opacity: 1;
  transform: translateX(0);
}
.mobile-menu.is-open .mobile-nav-link:nth-child(1) { transition-delay: 0.08s; }
.mobile-menu.is-open .mobile-nav-link:nth-child(2) { transition-delay: 0.14s; }
.mobile-menu.is-open .mobile-nav-link:nth-child(3) { transition-delay: 0.2s; }
.mobile-menu.is-open .mobile-nav-link:nth-child(4) { transition-delay: 0.26s; }
.mobile-menu.is-open .mobile-nav-link:nth-child(5) { transition-delay: 0.32s; }
.mobile-menu.is-open .mobile-nav-link:nth-child(6) { transition-delay: 0.38s; }
.mobile-menu.is-open .mobile-nav-link:nth-child(7) { transition-delay: 0.44s; }
.mobile-menu.is-open .mobile-nav-link:nth-child(8) { transition-delay: 0.5s; }

.mobile-nav-link:hover { color: var(--color-primary); }

@media (prefers-reduced-motion: reduce) {
  .mobile-menu,
  .mobile-menu.is-open {
    transition-duration: 0.01ms !important;
    transition-delay: 0s !important;
  }
  .mobile-nav-link,
  .mobile-menu.is-open .mobile-nav-link {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ========================================================================
   HERO SECTION
   ======================================================================== */
.hero-section {
  height: 90vh;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  position: relative;
  overflow: hidden;
  background-color: var(--color-foreground);
}
.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.8), rgba(0,0,0,0.3) 50%, rgba(0,0,0,0.2));
}
.hero-content {
  position: relative;
  z-index: 10;
  text-align: center;
  padding-bottom: 4rem;
}
@media (min-width: 768px) { .hero-content { padding-bottom: 6rem; } }

.hero-eyebrow {
  display: block;
  font-size: 0.75rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  font-weight: 500;
  margin-bottom: 1.25rem;
  text-shadow: 0 1px 8px rgba(0,0,0,0.6);
  animation: slideUp 0.6s var(--transition-smooth) forwards;
}
@media (min-width: 768px) { .hero-eyebrow { font-size: 0.875rem; } }

.hero-title {
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.15;
  color: #fff;
  margin-bottom: 1.5rem;
  text-shadow: 0 2px 20px rgba(0,0,0,0.6);
  animation: slideUp 0.6s var(--transition-smooth) forwards;
}
@media (min-width: 768px) { .hero-title { font-size: 3.75rem; } }
@media (min-width: 1024px) { .hero-title { font-size: 4.5rem; } }

.hero-subtitle {
  color: rgba(255,255,255,0.8);
  font-size: 0.875rem;
  max-width: 28rem;
  margin: 0 auto 2rem;
  line-height: 1.7;
  text-shadow: 0 1px 8px rgba(0,0,0,0.5);
  animation: slideUp 0.6s var(--transition-smooth) 0.1s forwards;
  opacity: 0;
}
@media (min-width: 768px) { .hero-subtitle { font-size: 1rem; } }

.hero-cta {
  display: inline-block;
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.9);
  font-weight: 500;
  border-bottom: 1px solid rgba(255,255,255,0.4);
  padding-bottom: 2px;
  transition: color 0.2s ease, border-color 0.2s ease;
  cursor: pointer;
  text-shadow: 0 1px 8px rgba(0,0,0,0.5);
  animation: slideUp 0.6s var(--transition-smooth) 0.2s forwards;
  opacity: 0;
}
@media (min-width: 768px) { .hero-cta { font-size: 0.875rem; } }
.hero-cta:hover { color: #fff; border-color: #fff; }

/* ========================================================================
   TAGLINE SECTION
   ======================================================================== */
.tagline-section {
  padding: 6rem 0;
  background-color: var(--color-secondary);
  overflow: hidden;
}
.tagline-inner { max-width: 48rem; margin: 0 auto; text-align: center; }
.tagline-quote { margin-bottom: 2rem; }
.tagline-body { color: var(--color-muted-foreground); line-height: 1.8; font-size: 0.875rem; }
@media (min-width: 768px) { .tagline-body { font-size: 1rem; } }

/* ========================================================================
   FEATURED PRODUCT SECTION
   ======================================================================== */
.featured-section { padding: 6rem 0; }
@media (min-width: 1024px) { .featured-section { padding: 8rem 0; } }

.featured-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4rem;
  align-items: center;
}
@media (min-width: 1024px) {
  .featured-inner { grid-template-columns: 1fr 1fr; gap: 6rem; }
}

.featured-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-primary);
  font-weight: 600;
  margin-bottom: 1rem;
}
.featured-title {
  font-size: 1.875rem;
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}
@media (min-width: 768px) { .featured-title { font-size: 2.5rem; } }
@media (min-width: 1024px) { .featured-title { font-size: 2.75rem; } }

.featured-body { color: var(--color-muted-foreground); line-height: 1.8; margin-bottom: 1rem; font-size: 0.875rem; }
.featured-price-hint { font-size: 0.75rem; color: rgba(102,93,98,0.6); font-style: italic; margin-bottom: 2.5rem; }
.featured-price-hint del { text-decoration: none; }
.featured-price-hint ins { text-decoration: none; }

.featured-cta {
  display: inline-flex;
  align-items: center;
  gap: 1.5rem;
  padding: 0.875rem 2rem;
  border: 1px solid rgba(153,51,102,0.4);
  color: var(--color-primary);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border-radius: 9999px;
  transition: all 0.2s ease;
}
.featured-cta:hover { border-color: var(--color-primary); background-color: rgba(153,51,102,0.05); }

.featured-copy { max-width: 32rem; }
.featured-image-wrap {
  overflow: hidden;
  border-radius: 1rem;
  border: 1px solid var(--color-border);
}
.featured-image {
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 4/3;
}

/* ========================================================================
   CINEMATIC SECTION
   ======================================================================== */
.section-cinematic {
  position: relative;
  width: 100%;
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background-attachment: scroll;
}
.cinematic-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(to bottom, rgba(10,4,7,0.45) 0%, rgba(10,4,7,0.65) 50%, rgba(10,4,7,0.85) 100%);
}
.cinematic-content {
  position: relative;
  z-index: 10;
  padding: 8rem 0;
  text-align: center;
}
.cinematic-eyebrow {
  display: block;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.8);
  font-weight: 500;
  text-shadow: 0 1px 8px rgba(0,0,0,0.5);
}
.cinematic-title {
  font-family: var(--font-display);
  font-size: 1.875rem;
  font-weight: 500;
  color: #fff;
  margin: 0.75rem 0 1rem;
  text-shadow: 0 2px 30px rgba(0,0,0,0.7), 0 1px 6px rgba(0,0,0,0.5);
}
@media (min-width: 768px) { .cinematic-title { font-size: 3rem; } }
@media (min-width: 1024px) { .cinematic-title { font-size: 3.75rem; } }

.cinematic-body {
  color: rgba(255,255,255,0.9);
  font-size: 1rem;
  max-width: 32rem;
  margin: 0 auto 2rem;
  line-height: 1.7;
  text-shadow: 0 1px 12px rgba(0,0,0,0.6);
}
@media (min-width: 768px) { .cinematic-body { font-size: 1.125rem; } }

.cinematic-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: rgba(255,255,255,0.9);
  border-bottom: 1px solid rgba(255,255,255,0.5);
  padding-bottom: 2px;
  transition: color 0.2s ease, border-color 0.2s ease;
  text-shadow: 0 1px 8px rgba(0,0,0,0.5);
}
.cinematic-cta:hover { color: #fff; border-color: #fff; }

/* ========================================================================
   ABOUT SECTION (aligned with storefront reference: max-w-3xl centered stack)
   ======================================================================== */
.about-section { padding: 6rem 0; }
@media (min-width: 1024px) { .about-section { padding: 8rem 0; } }

.about-inner {
  max-width: 48rem; /* max-w-3xl */
  margin: 0 auto;
  text-align: center;
  width: 100%;
}

.about-section .section-eyebrow {
  justify-content: center;
  width: 100%;
  letter-spacing: 0.25em;
  margin-bottom: 1rem; /* mb-4 */
}

.about-section .section-title {
  line-height: 1.25; /* leading-tight */
  margin-bottom: 1.5rem; /* mb-6 */
}

.about-body {
  color: var(--color-muted-foreground);
  line-height: 1.625; /* leading-relaxed */
  font-size: 0.875rem;
  max-width: 42rem; /* max-w-2xl */
  margin: 0 auto 2rem; /* mb-8 */
}
@media (min-width: 768px) { .about-body { font-size: 1rem; } }

.about-grid-wrap {
  position: relative;
  margin-top: 0;
  text-align: center;
  color: var(--color-muted-foreground);
  line-height: 1.9;
  font-size: 0.875rem;
}
@media (min-width: 768px) { .about-grid-wrap { font-size: 1rem; } }

.about-grid-divider-v {
  display: none;
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--color-border);
  transform: translateX(-50%);
}
.about-grid-divider-h {
  display: none;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--color-border);
  transform: translateY(-50%);
}
@media (min-width: 768px) {
  .about-grid-divider-v { display: block; }
  .about-grid-divider-h { display: block; }
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}
@media (min-width: 768px) { .about-grid { grid-template-columns: 1fr 1fr; } }

.about-grid-cell {
  padding: 1.5rem; /* p-6 */
  border-bottom: 1px solid var(--color-border);
  text-align: center;
  color: var(--color-muted-foreground);
  line-height: 1.9;
  font-size: inherit;
}
@media (min-width: 768px) {
  .about-grid-cell { border-bottom: none; }
}
@media (max-width: 767px) {
  .about-grid-cell:last-child { border-bottom: none; }
}
@media (min-width: 1024px) {
  .about-grid-cell { padding: 2rem; } /* lg:p-8 */
}

.about-grid-icon { display: block; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-primary); font-family: var(--font-display); font-size: 0.875rem; }
.about-grid-title { display: block; font-size: 0.875rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-primary); font-family: var(--font-display); margin-bottom: 0.75rem; }
.about-grid-body { font-size: inherit; margin: 0; }

/* ========================================================================
   CATALOG SECTION
   ======================================================================== */
.catalog-section {
  padding: 6rem 0;
  background-color: rgba(237,232,236,0.4);
}
@media (min-width: 1024px) { .catalog-section { padding: 8rem 0; } }
.catalog-header { margin-bottom: 3rem; }
.catalog-eyebrow { justify-content: center; }
.catalog-body { color: var(--color-muted-foreground); max-width: 36rem; margin: 0 auto; font-size: 0.875rem; line-height: 1.7; }
@media (min-width: 768px) { .catalog-body { font-size: 1rem; } }
.catalog-body span { color: var(--color-foreground); font-weight: 500; }

.catalog-empty-notice {
  max-width: 36rem;
  margin: 0 auto;
  padding: 2.5rem 1.5rem;
  text-align: center;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius);
  background-color: var(--color-card);
}
.catalog-empty-text {
  font-size: 0.875rem;
  color: var(--color-muted-foreground);
  line-height: 1.6;
  margin: 0;
}

.catalog-viewer-wrap {
  max-width: 56rem;
  margin: 0 auto;
  transform: translateZ(0);
}

.catalog-viewer {
  position: relative;
  background-color: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 1rem;
  box-shadow: var(--shadow-elevated);
  overflow: hidden;
  contain: layout style;
}

.catalog-page-badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 10;
  background-color: rgba(25,17,20,0.92);
  color: var(--color-background);
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.catalog-badge-sep { opacity: 0.6; }

.catalog-expand-btn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 10;
  background-color: rgba(25,17,20,0.92);
  color: var(--color-background);
  padding: 0.5rem;
  border-radius: 50%;
  transition: background-color 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.catalog-expand-btn:hover { background-color: var(--color-foreground); }

.catalog-main-img-btn {
  display: block;
  width: 100%;
  aspect-ratio: 4/5;
  cursor: zoom-in;
  overflow: hidden;
  background-color: var(--color-muted);
}
@media (min-width: 640px) { .catalog-main-img-btn { aspect-ratio: 4/3; } }
@media (min-width: 768px) { .catalog-main-img-btn { aspect-ratio: 16/10; } }
.catalog-main-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
@media (prefers-reduced-motion: no-preference) {
  .catalog-main-image { animation: fadeIn 0.3s ease forwards; }
}

.catalog-nav-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: rgba(249,246,248,0.95);
  border: 1px solid var(--color-border);
  padding: 0.625rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  box-shadow: var(--shadow-soft);
}
.catalog-nav-btn:hover { background-color: var(--color-background); }
.catalog-nav-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.catalog-prev { left: 0.75rem; }
.catalog-next { right: 0.75rem; }

.catalog-controls {
  margin-top: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
@media (min-width: 640px) { .catalog-controls { flex-direction: row; } }

.catalog-request-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  background-color: var(--color-primary);
  color: var(--color-primary-foreground);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-radius: 9999px;
  transition: opacity 0.2s ease;
}
.catalog-request-btn:hover { opacity: 0.9; }

.catalog-jump-form { display: flex; align-items: center; gap: 0.5rem; }
.catalog-jump-label { font-size: 0.75rem; color: var(--color-muted-foreground); letter-spacing: 0.1em; text-transform: uppercase; }
.catalog-jump-input {
  width: 4rem;
  padding: 0.5rem 0.75rem;
  background-color: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: 9999px;
  font-size: 0.875rem;
  text-align: center;
  outline: none;
  transition: border-color 0.2s ease;
}
.catalog-jump-input:focus { border-color: var(--color-primary); }
.catalog-jump-go {
  padding: 0.5rem 1rem;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border: 1px solid var(--color-border);
  border-radius: 9999px;
  transition: background-color 0.2s ease;
}
.catalog-jump-go:hover { background-color: var(--color-secondary); }

.catalog-thumbnails-wrap { margin-top: 2rem; }
.catalog-thumbs-label { font-size: 0.75rem; color: var(--color-muted-foreground); letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 0.75rem; text-align: center; }
.catalog-thumbnails {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.5rem;
}
@media (min-width: 640px) { .catalog-thumbnails { grid-template-columns: repeat(8, 1fr); } }
@media (min-width: 768px) { .catalog-thumbnails { grid-template-columns: repeat(10, 1fr); } }

.catalog-thumb {
  position: relative;
  aspect-ratio: 1;
  border-radius: 0.375rem;
  overflow: hidden;
  border: 1px solid var(--color-border);
  opacity: 0.7;
  transition: all 0.2s ease;
  display: block;
}
.catalog-thumb:hover { opacity: 1; border-color: rgba(153,51,102,0.5); }
.catalog-thumb.is-active { border-color: var(--color-primary); opacity: 1; box-shadow: 0 0 0 2px rgba(153,51,102,0.3); transform: scale(1.05); }
.catalog-thumb-img { width: 100%; height: 100%; object-fit: cover; }
.catalog-thumb-num {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: rgba(25,17,20,0.7);
  color: var(--color-background);
  font-size: 0.625rem;
  font-weight: 500;
  padding: 2px 0;
  text-align: center;
}

/* Catalog Lightbox */
.catalog-lightbox {
  position: fixed;
  inset: 0;
  z-index: 200;
  background-color: rgba(249,246,248,0.98);
}
.catalog-lightbox[hidden] { display: none; }
.catalog-lightbox-inner {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.catalog-lightbox-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 20;
  background-color: rgba(25,17,20,0.8);
  color: var(--color-background);
  padding: 0.5rem;
  border-radius: 50%;
  display: flex;
  transition: background-color 0.2s ease;
}
.catalog-lightbox-close:hover { background-color: var(--color-foreground); }
.catalog-lightbox-badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 20;
  background-color: rgba(25,17,20,0.8);
  color: var(--color-background);
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
}
.catalog-lightbox-img { max-width: 100%; max-height: 85vh; object-fit: contain; animation: fadeIn 0.3s ease; }
.catalog-lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: rgba(25,17,20,0.8);
  color: var(--color-background);
  padding: 0.75rem;
  border-radius: 50%;
  display: flex;
  transition: background-color 0.2s ease;
}
.catalog-lightbox-nav:hover { background-color: var(--color-foreground); }
.catalog-lb-prev { left: 1rem; }
.catalog-lb-next { right: 1rem; }

/* ========================================================================
   SHOP SECTION
   ======================================================================== */
.shop-section { padding: 6rem 0; }
.shop-header { text-align: center; margin-bottom: 3rem; }
.shop-subtitle { font-size: 0.875rem; color: var(--color-muted-foreground); }
.shop-count { font-size: 0.875rem; color: var(--color-muted-foreground); margin-bottom: 1.5rem; }

.shop-filters-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2.5rem;
}
@media (min-width: 640px) { .shop-filters-wrap { flex-direction: row; justify-content: center; } }

.shop-search-wrap {
  position: relative;
  width: 100%;
  max-width: 24rem;
}
.shop-search-icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-muted-foreground);
}
.shop-search-input {
  width: 100%;
  padding: 0.625rem 1rem 0.625rem 2.25rem;
  background-color: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: 9999px;
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.2s ease;
}
.shop-search-input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 1px var(--color-primary); }
.shop-search-input::placeholder { color: var(--color-muted-foreground); }

.shop-filter-pills { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.5rem; }
.filter-pill {
  padding: 0.5rem 1.25rem;
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  border-radius: 9999px;
  border: 1px solid var(--color-border);
  color: var(--color-muted-foreground);
  font-family: var(--font-body);
  transition: all 0.3s var(--transition-smooth);
  cursor: pointer;
  background: transparent;
}
.filter-pill:hover { border-color: rgba(25,17,20,0.3); color: var(--color-foreground); }
.filter-pill-active {
  background-color: var(--color-primary);
  color: var(--color-primary-foreground);
  border-color: var(--color-primary);
}
.filter-pill-active:hover { border-color: var(--color-primary); color: var(--color-primary-foreground); }

/* ========================================================================
   PRODUCT GRID
   ======================================================================== */
.theme-product-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  align-items: stretch;
}
@media (min-width: 640px) { .theme-product-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .theme-product-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1280px) { .theme-product-grid { grid-template-columns: repeat(4, 1fr); } }

.theme-product-card-wrap { display: flex; flex-direction: column; height: 100%; }

/* PRODUCT CARD */
.theme-product-card {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.theme-product-card__image-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: 1rem;
  border: 1px solid var(--color-border);
  aspect-ratio: 3/4;
}
.theme-product-card__image-wrapper img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.7s ease-out;
}
.theme-product-card:hover .theme-product-card__image-wrapper img { transform: scale(1.04); }
.theme-product-card__image-wrapper img.is-sold-out { opacity: 0.6; }

/* Hit-area overlay */
.theme-card-link {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
  pointer-events: auto;
}
.theme-product-card * { pointer-events: none; }
.theme-card-link { pointer-events: auto; }

/* Hover overlay */
.card-hover-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.6), rgba(0,0,0,0.1), transparent);
  opacity: 0;
  transition: opacity 0.5s ease;
}
.theme-product-card:hover .card-hover-overlay { opacity: 1; }
.card-hover-actions {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1rem;
  display: flex;
  gap: 0.5rem;
  opacity: 0;
  transform: translateY(0.75rem);
  transition: all 0.5s ease;
  z-index: 2;
}
.theme-product-card:hover .card-hover-actions { opacity: 1; transform: translateY(0); }
.card-hover-actions * { pointer-events: auto; }

.card-quick-view-btn,
.card-atc-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  font-size: 0.75rem;
  font-weight: 500;
  padding: 0.625rem;
  border-radius: 9999px;
  transition: all 0.2s ease;
  cursor: pointer;
  border: none;
  font-family: var(--font-body);
}
.card-quick-view-btn {
  background-color: rgba(255,255,255,0.9);
  backdrop-filter: blur(4px);
  color: var(--color-foreground);
}
.card-quick-view-btn:hover { background-color: #fff; }
.card-atc-btn {
  background-color: var(--color-primary);
  color: var(--color-primary-foreground);
  text-decoration: none;
}
.card-atc-btn:hover { opacity: 0.9; }
.card-atc-btn--disabled { opacity: 0.5; cursor: not-allowed; background-color: var(--color-muted); color: var(--color-muted-foreground); }

/* Badges */
.sold-out-badge {
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
  padding: 0.25rem 0.5rem;
  font-size: 0.625rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background-color: var(--color-muted);
  color: var(--color-muted-foreground);
  border-radius: var(--radius);
  z-index: 2;
  pointer-events: none;
}
@media (min-width: 768px) { .sold-out-badge { top: 0.75rem; left: 0.75rem; padding: 0.375rem 0.75rem; font-size: 0.75rem; } }

.edition-badge {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  padding: 0.25rem 0.5rem;
  font-size: 0.625rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background-color: rgba(153,51,102,0.9);
  color: var(--color-primary-foreground);
  border-radius: var(--radius);
  z-index: 2;
  pointer-events: none;
}
@media (min-width: 768px) { .edition-badge { top: 0.75rem; right: 0.75rem; padding: 0.375rem 0.75rem; font-size: 0.75rem; } }

/* Card info */
.theme-product-card__info {
  padding-top: 1rem;
  padding-bottom: 0.5rem;
  text-align: center;
  flex: 1;
}
.card-title-link { display: block; }
.card-title {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.3;
  transition: color 0.2s ease;
  font-family: var(--font-body);
  pointer-events: auto;
}
.card-title-link:hover .card-title,
.theme-product-card:hover .card-title { color: var(--color-primary); }
.card-sku { font-size: 0.75rem; color: rgba(102,93,98,0.6); margin-top: 0.125rem; font-family: monospace; }
.card-price { font-size: 0.875rem; color: var(--color-muted-foreground); margin-top: 0.25rem; }
.card-price ins { text-decoration: none; }
.card-price del { opacity: 0.6; font-size: 0.75rem; }

.shop-empty { padding: 5rem 0; text-align: center; }
.shop-empty p { color: var(--color-muted-foreground); }
.shop-empty p:first-child { margin-bottom: 0.5rem; }

/* ========================================================================
   CONTACT SECTION
   ======================================================================== */
.contact-section { padding: 6rem 0; background-color: rgba(237,232,236,0.5); }
.contact-inner { max-width: 56rem; margin: 0 auto; }
.contact-header { text-align: center; margin-bottom: 2.5rem; }
.contact-eyebrow { justify-content: center; color: var(--color-primary); }
.contact-body { color: var(--color-muted-foreground); max-width: 28rem; margin: 0 auto; }

.contact-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 2rem;
  margin-bottom: 2rem;
}
.contact-divider-line { height: 1px; width: 4rem; background-color: var(--color-border); }
.contact-divider-dot { width: 0.375rem; height: 0.375rem; border-radius: 50%; background-color: var(--color-primary); opacity: 0.6; }

.contact-success-msg { max-width: 32rem; margin: 0 auto; text-align: center; padding: 2.5rem 0; }
.contact-success-icon {
  width: 4rem;
  height: 4rem;
  background-color: var(--color-primary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  color: var(--color-primary-foreground);
}
.contact-success-title { font-size: 1.875rem; font-weight: 500; margin-bottom: 1rem; }
@media (min-width: 768px) { .contact-success-title { font-size: 2.25rem; } }
.contact-success-body { color: var(--color-muted-foreground); margin-bottom: 2rem; }

.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
@media (min-width: 1024px) { .contact-grid { grid-template-columns: 1fr 2fr; } }

.contact-sidebar-inner {
  background-color: rgba(237,232,236,0.6);
  border: 1px solid var(--color-border);
  border-radius: 0.75rem;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  height: 100%;
}
.contact-sidebar-title { font-size: 1.125rem; font-weight: 500; margin-bottom: 0.5rem; }
.contact-sidebar-body { font-size: 0.875rem; color: var(--color-muted-foreground); line-height: 1.7; }
.contact-sidebar-divider { height: 1px; background-color: var(--color-border); }
.contact-info-list { list-style: none; display: flex; flex-direction: column; gap: 1rem; }
.contact-info-item { display: flex; align-items: center; gap: 0.75rem; font-size: 0.875rem; }
.contact-info-icon {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background-color: rgba(153,51,102,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-primary);
}
.contact-info-link { transition: color 0.2s ease; word-break: break-all; }
.contact-info-link:hover { color: var(--color-primary); }

.contact-form { display: flex; flex-direction: column; gap: 1.25rem; }
.contact-form-row { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 768px) { .contact-form-row { grid-template-columns: 1fr 1fr; } }
.contact-form-group { display: flex; flex-direction: column; }
.contact-label { font-size: 0.875rem; font-weight: 500; margin-bottom: 0.5rem; display: block; }
.contact-input {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: var(--color-background);
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  color: var(--color-foreground);
  font-family: var(--font-body);
}
.contact-input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 1px var(--color-primary); }
.contact-input::placeholder { color: var(--color-muted-foreground); }
.contact-textarea { resize: none; }
.contact-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23665d62' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem; }
.contact-submit { align-self: flex-start; }

/* ========================================================================
   FOOTER
   ======================================================================== */
.site-footer {
  margin-top: 5rem;
  background-color: var(--color-footer-bg);
  color: var(--color-footer-fg);
}
.footer-grid {
  padding: 3.5rem 0 5rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
@media (min-width: 768px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: repeat(4, 1fr); padding: 5rem 0; gap: 3rem; } }

.footer-logo { filter: brightness(1.3); }
.footer-tagline { margin-top: 1rem; font-size: 0.875rem; line-height: 1.7; opacity: 0.7; }

.footer-heading {
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  margin-bottom: 1.5rem;
  padding-bottom: 0.75rem;
  position: relative;
  color: var(--color-footer-fg);
  font-family: var(--font-body);
}
.footer-heading::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 2.5rem;
  height: 2px;
  background-color: var(--color-primary);
}

.footer-links { list-style: none; display: flex; flex-direction: column; gap: 0.75rem; }
.footer-link {
  font-size: 0.875rem;
  opacity: 0.6;
  transition: opacity 0.2s ease;
  cursor: pointer;
  background: none;
  border: none;
  font-family: var(--font-body);
  color: inherit;
  display: block;
  text-align: left;
}
.footer-link:hover { opacity: 1; }

.footer-connect-item { display: flex; align-items: center; gap: 0.5rem; opacity: 0.6; }
.footer-connect-item a { transition: opacity 0.2s ease; }
.footer-connect-item:hover { opacity: 1; }

.footer-bottom {
  padding: 2rem 0;
  border-top: 1px solid rgba(51,34,43,0.5);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}
@media (min-width: 640px) { .footer-bottom { flex-direction: row; justify-content: space-between; } }
.footer-copyright, .footer-credit { font-size: 0.75rem; opacity: 0.5; }
.footer-credit { transition: opacity 0.2s ease; }
.footer-credit:hover { opacity: 0.8; }

/* ========================================================================
   CART DRAWER
   ======================================================================== */
#theme-cart-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(25,17,20,0.2);
  z-index: 60;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
body.cart-open #theme-cart-overlay { opacity: 1; pointer-events: auto; }

#theme-cart-drawer {
  position: fixed;
  right: 0;
  top: 0;
  height: 100%;
  width: 100%;
  max-width: 28rem;
  background-color: var(--color-background);
  z-index: 70;
  box-shadow: var(--shadow-elevated);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s var(--transition-smooth);
}
body.cart-open #theme-cart-drawer { transform: translateX(0); }
#theme-cart-drawer.is-updating { opacity: 0.6; pointer-events: none; }

.cart-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem;
  border-bottom: 1px solid var(--color-border);
}
.cart-drawer-title { font-size: 1.125rem; font-weight: 500; font-family: var(--font-display); }
.cart-drawer-close { padding: 0.25rem; transition: opacity 0.2s ease; display: flex; align-items: center; }
.cart-drawer-close:hover { opacity: 0.6; }

.cart-drawer-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  text-align: center;
  gap: 1rem;
}
.cart-drawer-empty svg { color: var(--color-muted-foreground); }
.cart-empty-message { color: var(--color-muted-foreground); }
.cart-continue-btn {
  padding: 0.75rem 1.5rem;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  font-size: 0.875rem;
  transition: background-color 0.2s ease;
  background: transparent;
  font-family: var(--font-body);
}
.cart-continue-btn:hover { background-color: var(--color-secondary); }

.cart-drawer-items { flex: 1; overflow-y: auto; padding: 1.5rem; display: flex; flex-direction: column; gap: 1.5rem; }
.cart-item { display: flex; gap: 1rem; }
.cart-item-img-link {
  width: 5rem;
  height: 6rem;
  background-color: var(--color-secondary);
  overflow: hidden;
  flex-shrink: 0;
  border-radius: 0.25rem;
  display: block;
}
.cart-item-img { width: 100%; height: 100%; object-fit: cover; object-position: top; display: block; }
.cart-item-info { flex: 1; min-width: 0; }
.cart-item-name { font-size: 0.875rem; font-weight: 500; display: block; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; transition: opacity 0.2s ease; }
.cart-item-name:hover { opacity: 0.7; }
.cart-item-price { font-size: 0.875rem; color: var(--color-muted-foreground); margin-top: 0.125rem; }
.cart-item-variation { font-size: 0.75rem; color: var(--color-muted-foreground); margin-top: 0.25rem; }
.cart-item-controls { display: flex; align-items: center; gap: 0.75rem; margin-top: 0.75rem; }
.cart-item-qty { display: flex; align-items: center; gap: 0.5rem; }
.cart-qty-btn {
  width: 1.75rem;
  height: 1.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-border);
  border-radius: 0;
  font-size: 0.875rem;
  transition: background-color 0.2s ease;
  cursor: pointer;
  background: transparent;
}
.cart-qty-btn:hover { background-color: var(--color-secondary); }
.cart-qty-value { font-size: 0.875rem; width: 1.5rem; text-align: center; }
.cart-remove-btn { margin-left: auto; font-size: 0.75rem; color: var(--color-muted-foreground); transition: color 0.2s ease; cursor: pointer; background: none; border: none; font-family: var(--font-body); }
.cart-remove-btn:hover { color: var(--color-foreground); }

.cart-drawer-footer { padding: 1.5rem; border-top: 1px solid var(--color-border); display: flex; flex-direction: column; gap: 1rem; }
.cart-subtotal-row { display: flex; justify-content: space-between; font-size: 0.875rem; }
.cart-subtotal-label { color: var(--color-muted-foreground); }
.cart-subtotal-value { font-weight: 500; }
.cart-shipping-note { font-size: 0.75rem; color: var(--color-muted-foreground); }
.cart-checkout-btn { display: flex; align-items: center; justify-content: center; width: 100%; padding: 1rem; font-size: 1rem; font-weight: 500; background-color: var(--color-primary); color: var(--color-primary-foreground); border-radius: 0.5rem; transition: opacity 0.2s ease; }
.cart-checkout-btn:hover { opacity: 0.9; }

/* ========================================================================
   SINGLE PRODUCT PAGE
   ======================================================================== */
.single-product.site-main { padding-top: var(--header-height); }
.product-back-link-wrap { padding: 1.5rem 0; }
.product-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-muted-foreground);
  transition: color 0.2s ease;
}
.product-back-link:hover { color: var(--color-foreground); }

.theme-product-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  padding-bottom: 5rem;
  min-width: 0;
}
@media (min-width: 1024px) { .theme-product-layout { grid-template-columns: 1fr 1fr; gap: 4rem; } }

.theme-product-gallery { min-width: 0; max-width: 100%; }
.product-main-img-wrap {
  aspect-ratio: 1;
  border-radius: 1rem;
  overflow: hidden;
  cursor: pointer;
  position: relative;
  background-color: var(--color-secondary);
}
.product-main-img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: opacity 0.4s ease; }
.product-img-expand-overlay {
  position: absolute;
  inset: 0;
  background-color: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease;
}
.product-main-img-wrap:hover .product-img-expand-overlay { background-color: rgba(0,0,0,0.1); }
.product-img-expand-overlay svg { color: #fff; opacity: 0; transition: opacity 0.2s ease; }
.product-main-img-wrap:hover .product-img-expand-overlay svg { opacity: 0.8; }

.theme-product-thumbnails {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
  overflow-x: auto;
  flex-wrap: wrap;
  max-width: 100%;
}
.product-thumb-btn {
  width: 4rem;
  height: 4rem;
  border-radius: 0.75rem;
  overflow: hidden;
  border: 2px solid var(--color-border);
  flex-shrink: 0;
  transition: all 0.2s ease;
  cursor: pointer;
  background: none;
  padding: 0;
}
.product-thumb-btn:hover { border-color: var(--color-muted-foreground); }
.product-thumb-btn.is-active { border-color: var(--color-primary); }
.product-thumb-btn img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }

.theme-product-info { min-width: 0; max-width: 100%; }
@media (min-width: 1024px) { .theme-product-info { padding-top: 2.5rem; } }

.product-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.product-breadcrumb a { color: var(--color-muted-foreground); font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; }
.product-cats { font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-muted-foreground); }
.product-cats a { color: inherit; }
.product-type-label { font-size: 0.75rem; font-weight: 500; color: var(--color-primary); display: inline-flex; align-items: center; gap: 0.25rem; }
.product-bc-sep { width: 0.25rem; height: 0.25rem; border-radius: 50%; background-color: var(--color-border); }
.product-sku { font-size: 0.75rem; color: rgba(102,93,98,0.6); font-family: monospace; }

.product-title { font-size: 1.5rem; font-weight: 500; margin-top: 0.5rem; margin-bottom: 1rem; overflow-wrap: break-word; word-break: break-word; }
@media (min-width: 768px) { .product-title { font-size: 1.875rem; } }

.product-price { font-size: 1.25rem; color: var(--color-foreground); margin-bottom: 1.5rem; }
.product-price ins { text-decoration: none; }
.product-price del { opacity: 0.5; font-size: 1rem; }

.product-soldout-badge {
  display: inline-block;
  padding: 0.5rem 1rem;
  background-color: var(--color-muted);
  color: var(--color-muted-foreground);
  font-size: 0.875rem;
  font-weight: 500;
  border-radius: 0.75rem;
  margin-bottom: 1rem;
}

.product-description {
  color: var(--color-muted-foreground);
  line-height: 1.8;
  margin-bottom: 2rem;
  font-size: 0.875rem;
  overflow-wrap: break-word;
  word-break: break-word;
}

.theme-add-to-cart-area {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}
.theme-quantity-wrapper {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.theme-qty-minus,
.theme-qty-plus {
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-border);
  border-radius: 0.75rem;
  font-size: 1rem;
  transition: background-color 0.2s ease;
  cursor: pointer;
  background: transparent;
}
.theme-qty-minus:hover,
.theme-qty-plus:hover { background-color: var(--color-secondary); }

.theme-qty-input {
  width: 3rem;
  text-align: center;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  padding: 0.375rem;
  font-size: 0.875rem;
  background: transparent;
  -moz-appearance: textfield;
}
.theme-qty-input::-webkit-outer-spin-button,
.theme-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.theme-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  min-width: 160px;
  background-color: var(--color-primary) !important;
  color: var(--color-primary-foreground) !important;
  border: none !important;
  border-radius: var(--btn-radius) !important;
  min-height: var(--btn-height) !important;
  padding: var(--btn-padding) !important;
  font-family: var(--font-body) !important;
  font-size: var(--btn-font-size) !important;
  font-weight: var(--btn-font-weight) !important;
  letter-spacing: var(--btn-letter-spacing) !important;
  cursor: pointer !important;
  transition: opacity 0.2s ease !important;
  box-shadow: 0 4px 20px rgba(153,51,102,0.15);
  text-decoration: none;
}
.theme-btn-primary:hover { opacity: 0.9 !important; }

/* WooCommerce add-to-cart button overrides */
.single_add_to_cart_button.button,
.add_to_cart_button.button,
a.single_add_to_cart_button,
a.add_to_cart_button {
  background-color: var(--color-primary) !important;
  color: var(--color-primary-foreground) !important;
  border: none !important;
  border-radius: var(--btn-radius) !important;
  min-height: var(--btn-height) !important;
  padding: var(--btn-padding) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: var(--font-body) !important;
  font-size: var(--btn-font-size) !important;
  font-weight: var(--btn-font-weight) !important;
  letter-spacing: var(--btn-letter-spacing) !important;
  text-transform: var(--btn-text-transform) !important;
  cursor: pointer !important;
  transition: opacity 0.2s ease !important;
}
.single_add_to_cart_button.button:hover,
.add_to_cart_button.button:hover { opacity: 0.85 !important; background-color: var(--color-primary) !important; color: var(--color-primary-foreground) !important; }

.single_add_to_cart_button.button:disabled,
.single_add_to_cart_button.button.disabled,
.add_to_cart_button.button:disabled,
.add_to_cart_button.button.disabled {
  cursor: not-allowed !important;
  opacity: 0.4 !important;
  pointer-events: none !important;
}
.single_add_to_cart_button.button:disabled:hover,
.single_add_to_cart_button.button.disabled:hover,
.add_to_cart_button.button:disabled:hover,
.add_to_cart_button.button.disabled:hover {
  opacity: 0.4 !important;
  background-color: var(--color-primary) !important;
}

/* Hide WooCommerce "View cart" injected after AJAX add */
.woocommerce-page a.added_to_cart.wc-forward,
.single-product a.added_to_cart.wc-forward,
body a.added_to_cart.wc-forward { display: none !important; }

/* Hide product page WC notices (cart drawer provides feedback) */
.single-product .woocommerce-message,
.single-product .woocommerce-info { display: none; }

.ajax_add_to_cart.theme-btn-loading {
  opacity: 0.6 !important;
  pointer-events: none !important;
  cursor: wait !important;
}

.product-contact-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.875rem 2rem;
  border: 1px solid rgba(25,17,20,0.2);
  border-radius: var(--btn-radius);
  font-size: 0.875rem;
  font-weight: 500;
  margin-top: 0.75rem;
  transition: border-color 0.2s ease;
  color: var(--color-foreground);
}
.product-contact-btn:hover { border-color: rgba(25,17,20,0.4); }

.product-details-section { border-top: 1px solid var(--color-border); padding-top: 2rem; margin-top: 1.5rem; }
.product-details-title { font-size: 0.875rem; font-weight: 500; margin-bottom: 1rem; font-family: var(--font-body); }
.product-details-section ul { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; }
.product-details-section li {
  font-size: 0.875rem;
  color: var(--color-muted-foreground);
  display: flex;
  align-items: flex-start;
  line-height: 1.8;
  gap: 0.75rem;
}
.product-details-section li::before {
  content: '';
  display: inline-block;
  width: 0.375rem;
  height: 0.375rem;
  border-radius: 50%;
  background-color: rgba(153,51,102,0.4);
  flex-shrink: 0;
  margin-top: 0.6rem;
}

/* Variable product form */
.single-product .variations.shop_attributes tbody,
.single-product .variations tbody tr,
.single-product .variations tbody td { display: block; width: 100%; }
.single-product .variations tbody td.label { padding-bottom: 0.25rem; }
.single-product .variations tbody td.value { padding-top: 0; }
.single-product .variations select {
  width: 100%;
  padding: 0.625rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background-color: var(--color-background);
  font-family: var(--font-body);
  font-size: 0.875rem;
  margin-bottom: 0.75rem;
}
.single-product .woocommerce-variation-price .price { font-size: 1.25rem; }
.single-product .reset_variations { font-size: 0.75rem; color: var(--color-muted-foreground); text-decoration: underline; }

/* Related products */
.related-products-section { padding: 5rem 0; border-top: 1px solid var(--color-border); }
.related-products-title { font-size: 1.25rem; font-weight: 500; margin-bottom: 2.5rem; }
@media (min-width: 768px) { .related-products-title { font-size: 1.5rem; } }
.related-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
@media (max-width: 767px) { .related-grid { grid-template-columns: 1fr; } }

/* Product lightbox */
.product-lightbox {
  position: fixed;
  inset: 0;
  z-index: 200;
  background-color: rgba(0,0,0,0.95);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.product-lightbox[hidden] { display: none; }
.product-lightbox-inner { position: relative; width: 100%; height: 80vh; display: flex; align-items: center; justify-content: center; }
.product-lightbox-img { max-width: 100%; max-height: 100%; object-fit: contain; }
.product-lightbox-close {
  position: absolute;
  top: -3rem;
  right: 0;
  background-color: rgba(255,255,255,0.1);
  color: #fff;
  padding: 0.5rem;
  border-radius: 50%;
  display: flex;
  transition: background-color 0.2s ease;
}
.product-lightbox-close:hover { background-color: rgba(255,255,255,0.2); }
.product-lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: rgba(255,255,255,0.1);
  color: #fff;
  padding: 0.75rem;
  border-radius: 50%;
  display: flex;
  transition: background-color 0.2s ease;
}
.product-lightbox-nav:hover { background-color: rgba(255,255,255,0.2); }
.product-lb-prev { left: 0.5rem; }
.product-lb-next { right: 0.5rem; }
.product-lb-hd-btn {
  position: absolute;
  bottom: -3rem;
  right: 0;
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
  background-color: rgba(255,255,255,0.15);
  color: #fff;
  transition: background-color 0.2s ease;
}
.product-lb-hd-btn:hover { background-color: rgba(255,255,255,0.25); }
.product-lb-hd-btn.is-hd { background-color: var(--color-primary); }

/* WooCommerce notices on product pages */
.single-product .woocommerce-notices-wrapper .woocommerce-error { display: block; }

/* ========================================================================
   PAGE / 404 / CHECKOUT
   ======================================================================== */
.page-main { padding-top: var(--header-height); }
.page-title {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 500;
  padding: 2rem 0 1rem;
}
.entry-content { padding: 2rem 0 4rem; max-width: 80rem; margin: 0 auto; padding-left: 1.5rem; padding-right: 1.5rem; }

.error-404-wrap { display: flex; flex-direction: column; align-items: center; gap: 1rem; }
.error-404-title { font-family: var(--font-display); font-size: 8rem; font-weight: 300; line-height: 1; opacity: 0.2; }
.error-404-subtitle { font-family: var(--font-display); font-size: 2rem; font-weight: 500; }
.error-404-body { color: var(--color-muted-foreground); }

/* ========================================================================
   CHECKOUT (WooCommerce Blocks)
   DOM reference: .wp-block-woocommerce-checkout.wc-block-checkout (root);
   inner form fields flex split: .wc-block-components-sidebar-layout (65/35 — stacked below);
   notices: .wc-block-components-notices (Woo uses plural).
   ======================================================================== */
body.woocommerce-checkout {
  overflow-x: hidden;
  --lrb-checkout-max: 1280px;
}

/* Cuando el checkout va incrustado y el body aún no tiene clase (evitar compresión por .entry-content 80rem) */
.entry-content:has(.wp-block-woocommerce-checkout.wc-block-checkout) {
  --lrb-checkout-max: 1280px;
}

body.woocommerce-checkout .site-main,
body.woocommerce-checkout #main-content,
body.woocommerce-checkout #page-content,
body.woocommerce-checkout article,
body.woocommerce-checkout .entry-content,
.entry-content:has(.wp-block-woocommerce-checkout.wc-block-checkout),
.site-main:has(.wp-block-woocommerce-checkout.wc-block-checkout),
article:has(.wp-block-woocommerce-checkout.wc-block-checkout) {
  max-width: none !important;
  width: 100%;
  box-sizing: border-box;
}

body.woocommerce-checkout .site-main {
  padding-top: var(--header-height);
  padding-bottom: 4rem;
}

body.woocommerce-checkout .entry-content,
.entry-content:has(.wp-block-woocommerce-checkout.wc-block-checkout) {
  padding-left: 0;
  padding-right: 0;
}

/* Checkout root: full intended width, centered (matches editor “wide” content width). */
body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout,
body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout {
  width: 100%;
  max-width: var(--lrb-checkout-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  box-sizing: border-box;
}

/* Same container when checkout block is embedded without body.woocommerce-checkout yet */
.entry-content .wp-block-woocommerce-checkout.wc-block-checkout {
  width: 100%;
  max-width: min(1280px, 100%);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  box-sizing: border-box;
}

/* Avisos del bloque (clase plural .wc-block-components-notices): misma caja que el checkout */
body.woocommerce-checkout .entry-content > .wc-block-components-notices,
.entry-content:has(.wp-block-woocommerce-checkout.wc-block-checkout) > .wc-block-components-notices {
  width: 100%;
  max-width: var(--lrb-checkout-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  box-sizing: border-box;
}

/*
 * Dos columnas:
 * (A) Raíz .wc-block-checkout: hijos directos __main | __sidebar
 * (B) SidebarLayout envuelve formulario + resumen: hijo directo .wc-block-components-sidebar-layout o .wc-block-checkout-sidebar-layout
 */
@media (min-width: 768px) {
  /* A) Grid en la raíz solo si existen columnas nativas __main / __sidebar */
  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:has(> .wc-block-checkout__main):has(> .wc-block-checkout__sidebar),
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:has(> .wc-block-checkout__main):has(> .wc-block-checkout__sidebar),
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:has(> .wc-block-checkout__main):has(> .wc-block-checkout__sidebar) {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 400px);
    gap: 1.5rem;
    align-items: start;
    grid-auto-flow: row;
  }

  /* B) Raíz en columna: avisos arriba a ancho completo + layout interno en grid */
  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)),
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)),
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)) {
    display: flex !important;
    flex-direction: column;
    gap: 1.5rem;
    align-items: stretch;
  }

  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout,
  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 400px);
    gap: 1.5rem;
    align-items: start;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
  }

  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-main,
  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-sidebar,
  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout > .wc-block-components-main,
  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout > .wc-block-components-sidebar,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-main,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-sidebar,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout > .wc-block-components-main,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout > .wc-block-components-sidebar,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-main,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-sidebar,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout > .wc-block-components-main,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout > .wc-block-components-sidebar {
    min-width: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-sidebar,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-sidebar,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-sidebar {
    min-width: min(360px, 100%);
  }

  /* Fila de avisos a ancho completo (order 1); formulario y sidebar order 2 y 3 */
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-notices,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-notices {
    grid-column: 1 / -1;
    grid-row: 1;
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
    order: 1;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout__main,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout__main {
    grid-column: 1;
    min-width: 0;
    width: 100%;
    max-width: 100%;
    order: 2;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout__sidebar,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout__sidebar {
    grid-column: 2;
    min-width: min(360px, 100%);
    width: 100%;
    max-width: 100%;
    order: 3;
    align-self: start;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)) > .wc-block-components-sidebar-layout,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)) > .wc-block-checkout-sidebar-layout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)) > .wc-block-components-sidebar-layout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)) > .wc-block-checkout-sidebar-layout {
    order: 2;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)):has(> .wc-block-components-notices) > .wc-block-components-sidebar-layout,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)):has(> .wc-block-components-notices) > .wc-block-checkout-sidebar-layout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)):has(> .wc-block-components-notices) > .wc-block-components-sidebar-layout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-checkout__main)):has(> .wc-block-components-notices) > .wc-block-checkout-sidebar-layout {
    order: 3;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:has(> .wc-block-components-notices) > .wc-block-checkout__main,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:has(> .wc-block-components-notices) > .wc-block-checkout__main {
    grid-row: 2;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:has(> .wc-block-components-notices) > .wc-block-checkout__sidebar,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:has(> .wc-block-components-notices) > .wc-block-checkout__sidebar {
    grid-row: 2;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-components-notices)) > .wc-block-checkout__main,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-components-notices)) > .wc-block-checkout__main {
    grid-row: 1;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-components-notices)) > .wc-block-checkout__sidebar,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout:not(:has(> .wc-block-components-notices)) > .wc-block-checkout__sidebar {
    grid-row: 1;
  }
}

@media (max-width: 767px) {
  body.woocommerce-checkout .entry-content .wp-block-woocommerce-checkout.wc-block-checkout,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout {
    display: flex !important;
    flex-direction: column;
    gap: 1.5rem;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout__main,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout__sidebar,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout__main,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout__sidebar {
    grid-column: unset;
    grid-row: unset;
    width: 100%;
    min-width: 0;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout,
  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-checkout-sidebar-layout {
    display: flex !important;
    flex-direction: column;
    grid-template-columns: unset;
    gap: 1.5rem;
    min-width: 0;
  }

  body.woocommerce-checkout .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-sidebar,
  .entry-content .wp-block-woocommerce-checkout.wc-block-checkout > .wc-block-components-sidebar-layout > .wc-block-components-sidebar {
    min-width: 0;
  }
}

body.woocommerce-checkout .wc-block-checkout__form {
  display: block;
  margin: 0;
  max-width: none;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

body.woocommerce-checkout .wc-block-checkout__main,
body.woocommerce-checkout .wc-block-checkout__sidebar {
  min-width: 0;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

body.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block,
.entry-content .wp-block-woocommerce-checkout-order-summary-block {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

/* Woo Blocks: alinear subtotal, envío, impuestos y total (misma columna de montos a la derecha) */
body.woocommerce-checkout .wc-block-components-totals-item,
body.woocommerce-cart .wc-block-components-totals-item,
.entry-content .wc-block-checkout .wc-block-components-totals-item,
.entry-content .wc-block-cart .wc-block-components-totals-item {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  column-gap: 0.75rem;
  row-gap: 0.25rem;
  width: 100%;
  box-sizing: border-box;
}

body.woocommerce-checkout .wc-block-components-totals-item__label,
body.woocommerce-cart .wc-block-components-totals-item__label,
.entry-content .wc-block-checkout .wc-block-components-totals-item__label,
.entry-content .wc-block-cart .wc-block-components-totals-item__label {
  grid-column: 1;
  min-width: 0;
  text-align: left !important;
}

body.woocommerce-checkout .wc-block-components-totals-item__value,
body.woocommerce-cart .wc-block-components-totals-item__value,
.entry-content .wc-block-checkout .wc-block-components-totals-item__value,
.entry-content .wc-block-cart .wc-block-components-totals-item__value {
  grid-column: 2;
  justify-self: end;
  text-align: right !important;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

body.woocommerce-checkout .wc-block-components-totals-item__description,
body.woocommerce-cart .wc-block-components-totals-item__description,
.entry-content .wc-block-checkout .wc-block-components-totals-item__description,
.entry-content .wc-block-cart .wc-block-components-totals-item__description {
  grid-column: 1 / -1;
  width: 100% !important;
}

body.woocommerce-checkout .wc-block-components-totals-footer-item,
body.woocommerce-cart .wc-block-components-totals-footer-item,
.entry-content .wc-block-checkout .wc-block-components-totals-footer-item,
.entry-content .wc-block-cart .wc-block-components-totals-footer-item {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  column-gap: 0.75rem;
  width: 100%;
  box-sizing: border-box;
}

body.woocommerce-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__label,
body.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  grid-column: 1;
  min-width: 0;
  text-align: left !important;
}

body.woocommerce-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
body.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
  grid-column: 2;
  justify-self: end;
  text-align: right !important;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/*
 * Inner .wc-block-components-sidebar-layout: WooCommerce splits contact vs billing (65/35).
 * Stack into one column for steps + order note.
 */
body.woocommerce-checkout .wc-block-checkout__main .wc-block-components-sidebar-layout,
body.woocommerce-checkout .wc-block-checkout__form .wc-block-components-sidebar-layout {
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  gap: 1.5rem;
  align-items: stretch;
}

body.woocommerce-checkout .wc-block-checkout__main .wc-block-components-sidebar-layout:has(> :last-child.wp-block-woocommerce-checkout-fields-block),
body.woocommerce-checkout .wc-block-checkout__form .wc-block-components-sidebar-layout:has(> :last-child.wp-block-woocommerce-checkout-fields-block) {
  flex-direction: column !important;
}

body.woocommerce-checkout .wc-block-checkout__main .wc-block-components-sidebar-layout .wc-block-components-main,
body.woocommerce-checkout .wc-block-checkout__main .wc-block-components-sidebar-layout .wc-block-components-sidebar,
body.woocommerce-checkout .wc-block-checkout__form .wc-block-components-sidebar-layout .wc-block-components-main,
body.woocommerce-checkout .wc-block-checkout__form .wc-block-components-sidebar-layout .wc-block-components-sidebar {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box;
}

body.woocommerce-checkout .wc-block-checkout__sidebar {
  background-color: var(--color-secondary);
  border-radius: var(--radius);
  padding: 2rem;
}

body.woocommerce-checkout .wc-block-components-text-input input,
body.woocommerce-checkout .wc-block-components-select select,
body.woocommerce-checkout .wc-block-components-textarea textarea {
  width: 100% !important;
  max-width: none !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 0.5rem !important;
  font-family: var(--font-body) !important;
  font-size: 0.875rem !important;
  color: var(--color-foreground) !important;
  background-color: var(--color-background) !important;
}
body.woocommerce-checkout .wc-block-components-text-input input:focus,
body.woocommerce-checkout .wc-block-components-select select:focus {
  outline: none;
  border-color: var(--color-primary) !important;
  box-shadow: 0 0 0 1px var(--color-primary) !important;
}

body.woocommerce-checkout .wc-block-components-checkout-place-order-button {
  background-color: var(--color-primary) !important;
  color: var(--color-primary-foreground) !important;
  border: none !important;
  border-radius: var(--btn-radius) !important;
  padding: 0.875rem 2rem !important;
  font-family: var(--font-body) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  width: 100% !important;
  cursor: pointer !important;
}
body.woocommerce-checkout .wc-block-components-checkout-place-order-button:hover { opacity: 0.9 !important; }

body.woocommerce-checkout h1.page-title { text-align: center; }
body.woocommerce-checkout h1.page-title.container-wide {
  max-width: var(--lrb-checkout-max);
  box-sizing: border-box;
}

/* ========================================================================
   THANK YOU PAGE
   ======================================================================== */
body.theme-thankyou-page { overflow-x: hidden; }
body.theme-thankyou-page .entry-content {
  padding-left: 2rem;
  padding-right: 2rem;
  box-sizing: border-box;
}
@media (min-width: 1024px) {
  body.theme-thankyou-page .entry-content {
    padding-left: 2.5rem;
    padding-right: 2.5rem;
  }
}
body.theme-thankyou-page .woocommerce-order { max-width: 56rem; margin: 2rem auto; padding: 0 1.5rem; }
body.theme-thankyou-page .woocommerce-order h2,
body.theme-thankyou-page .woocommerce-order-details__title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 500;
  padding: 0 0 1rem;
  color: var(--color-foreground);
}
body.theme-thankyou-page .woocommerce-order-overview { background-color: var(--color-secondary); border-radius: var(--radius); padding: 1.5rem; list-style: none; display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 2rem; }
body.theme-thankyou-page .woocommerce-order-overview li { font-size: 0.875rem; color: var(--color-muted-foreground); }
body.theme-thankyou-page .woocommerce-order-overview li strong { color: var(--color-foreground); }
body.theme-thankyou-page .woocommerce-order-details table { width: 100%; table-layout: fixed; border-collapse: collapse; }
body.theme-thankyou-page .woocommerce-order-details thead th:last-child,
body.theme-thankyou-page .woocommerce-order-details tbody td:last-child,
body.theme-thankyou-page .woocommerce-order-details tfoot td {
  text-align: right !important;
  font-variant-numeric: tabular-nums;
}
body.theme-thankyou-page .woocommerce-order-details thead th:not(:last-child),
body.theme-thankyou-page .woocommerce-order-details tbody td:not(:last-child),
body.theme-thankyou-page .woocommerce-order-details tfoot th {
  text-align: left !important;
}
body.theme-thankyou-page .woocommerce-customer-details { display: flex; flex-direction: column; gap: 1.5rem; }
body.theme-thankyou-page .woocommerce-customer-details address { max-width: 480px; overflow-wrap: break-word; font-style: normal; font-size: 0.875rem; color: var(--color-muted-foreground); line-height: 1.7; }

/* ========================================================================
   WOOCOMMERCE ARCHIVE / SHOP
   ======================================================================== */
.woocommerce-archive-main .shop-section { padding-top: calc(var(--header-height) + 4rem); }
.woocommerce-page .woocommerce-breadcrumb { display: none; }

/* WooCommerce notice styling */
.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
  background-color: var(--color-secondary);
  border-radius: var(--radius);
  padding: 1rem 1.5rem;
  margin-bottom: 1rem;
  font-size: 0.875rem;
  border-left: 3px solid var(--color-primary);
  list-style: none;
}
.woocommerce-error { border-left-color: #dc2626; }
.woocommerce-message { border-left-color: #16a34a; }

/* ========================================================================
   ANIMATIONS
   ======================================================================== */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.animate-fade-in { animation: fadeIn 0.6s var(--transition-smooth) forwards; }
.animate-slide-up { animation: slideUp 0.6s var(--transition-smooth) forwards; }

/* ========================================================================
   RESPONSIVE FIXES
   ======================================================================== */
@media (max-width: 767px) {
  .theme-product-layout { gap: 2rem; }
  .theme-add-to-cart-area { flex-wrap: wrap; gap: 0.75rem; }
  .single_add_to_cart_button { flex: 1 1 auto; min-width: 160px; }
  .theme-product-thumbnails { flex-wrap: wrap; max-width: 100%; }
  .woocommerce-product-details__short-description,
  .woocommerce-variation-description,
  .posted_in { overflow-wrap: break-word; word-break: break-word; }
}
