/* ==========================================================================
   Sunisla — Catalog & CMS Page Styles
   Premium editorial aesthetic: generous whitespace, refined typography
   ========================================================================== */

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

:root {
  --pl-space-section: 5rem;
  --pl-space-block: 2.5rem;
  --pl-space-element: 1.5rem;
  --pl-leading-body: 1.75;
  --pl-leading-relaxed: 1.85;
  --pl-leading-heading: 1.2;
  --pl-text-body: 1rem;
  --pl-text-sm: 0.875rem;
  --pl-text-xs: 0.75rem;
  --pl-text-lg: 1.0625rem;
  --pl-prose-max: 42rem;
}

/* ── Shared page layout ─────────────────────────────────────────────────── */

body.catalog-category-view .page-main,
body.catalog-product-view .page-main,
body.catalogsearch-result-index .page-main,
body.cms-page-view .page-main {
  margin-block: 0;
}

body.catalog-category-view .column.main,
body.catalog-product-view .column.main,
body.catalogsearch-result-index .column.main,
body.cms-page-view .column.main {
  padding-block: var(--pl-space-section);
}

/* Breadcrumbs */
.breadcrumbs {
  background: transparent !important;
  box-shadow: none !important;
  border-bottom: 1px solid var(--color-border);
}

.breadcrumbs .items {
  padding-block: 1.25rem !important;
  font-size: var(--pl-text-xs) !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-light) !important;
}

.breadcrumbs a {
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.breadcrumbs a:hover {
  color: var(--color-accent);
}

.breadcrumbs .separator {
  color: var(--color-border) !important;
  padding-inline: 0.75rem !important;
}

.breadcrumbs [aria-current="page"] {
  color: var(--color-text) !important;
}

/* Page titles */
.pl-page-header {
  padding-block: var(--pl-space-block) 0;
}

.pl-page-header .page-title,
.catalog-category-view h1.page-title,
.catalogsearch-result-index h1.page-title,
.cms-page-view h1.page-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 500;
  line-height: var(--pl-leading-heading);
  letter-spacing: -0.02em;
  color: var(--color-text);
  margin-bottom: 0 !important;
}

.pl-page-header .page-title-sub {
  margin-top: 1rem;
  max-width: var(--pl-prose-max);
  font-size: var(--pl-text-lg);
  line-height: var(--pl-leading-body);
  color: var(--color-text-muted);
}

/* ── Prose / rich content typography ──────────────────────────────────────── */

.pl-prose,
.prose,
.cms-content,
.product-description {
  font-size: var(--pl-text-body);
  line-height: var(--pl-leading-relaxed);
  color: var(--color-text-muted);
}

.pl-prose > * + *,
.prose > * + *,
.cms-content > * + *,
.category-description > * + * {
  margin-top: 1.25em;
}

.pl-prose h1, .prose h1, .cms-content h1,
.pl-prose h2, .prose h2, .cms-content h2,
.pl-prose h3, .prose h3, .cms-content h3,
.pl-prose h4, .prose h4, .cms-content h4 {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--color-text);
  line-height: var(--pl-leading-heading);
}

.pl-prose h1, .prose h1, .cms-content h1 { font-size: 2rem; margin-top: 2.5em; }
.pl-prose h2, .prose h2, .cms-content h2 { font-size: 1.625rem; margin-top: 2em; }
.pl-prose h3, .prose h3, .cms-content h3 { font-size: 1.375rem; margin-top: 1.75em; }
.pl-prose h4, .prose h4, .cms-content h4 { font-size: 1.125rem; margin-top: 1.5em; }

.pl-prose p, .prose p, .cms-content p,
.category-description p {
  margin-bottom: 0;
}

.pl-prose a, .prose a, .cms-content a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--color-accent-soft);
}

.pl-prose a:hover, .prose a:hover, .cms-content a:hover {
  text-decoration-color: var(--color-accent);
}

.pl-prose ul, .prose ul, .cms-content ul,
.pl-prose ol, .prose ol, .cms-content ol {
  padding-left: 1.25em;
}

.pl-prose li, .prose li, .cms-content li {
  margin-top: 0.5em;
}

.pl-prose blockquote, .prose blockquote, .cms-content blockquote {
  border-left: 2px solid var(--color-accent);
  padding-left: 1.5rem;
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-text);
}

.pl-prose img, .prose img, .cms-content img {
  border-radius: var(--radius-md);
}

.pl-prose table, .prose table, .cms-content table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--pl-text-sm);
}

.pl-prose th, .prose th, .cms-content th,
.pl-prose td, .prose td, .cms-content td {
  padding: 0.875rem 1rem;
  border-bottom: 1px solid var(--color-border);
  text-align: left;
}

.pl-prose th, .prose th, .cms-content th {
  font-weight: 600;
  color: var(--color-text);
  font-size: var(--pl-text-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ── Category / Product List Page ─────────────────────────────────────────── */

.catalog-category-view #category-view-container,
.catalogsearch-result-index .page-title ~ .columns {
  padding-top: 0;
}

.catalog-category-view .category-description {
  margin-top: var(--pl-space-element);
  padding-bottom: var(--pl-space-block);
}

.catalog-category-view .category-image {
  margin-bottom: var(--pl-space-block);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.catalog-category-view .category-image img {
  width: 100%;
  object-fit: cover;
  max-height: 360px;
}

/* Toolbar */
.toolbar.toolbar-products {
  padding-block: 1.25rem;
  margin-bottom: var(--pl-space-element);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--pl-text-sm);
  color: var(--color-text-muted);
}

.toolbar.toolbar-products select,
.toolbar.toolbar-products .limiter select {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 0.375rem 0.75rem;
  background: var(--color-surface);
  color: var(--color-text);
  font-size: var(--pl-text-sm);
}

.toolbar.toolbar-products a,
.toolbar.toolbar-products button {
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.toolbar.toolbar-products a:hover,
.toolbar.toolbar-products button:hover {
  color: var(--color-text);
}

/* Product grid */
#product-list {
  padding-top: 0 !important;
}

#product-list .products-grid > ul {
  gap: 2.5rem 2rem !important;
}

.pl-product-card,
.products-grid .product-item.card,
.products-grid .product-item {
  background: var(--color-surface) !important;
  border: 0 !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: none !important;
  padding: 0 !important;
  overflow: hidden;
  transition: transform var(--transition-med), box-shadow var(--transition-med);
}

.pl-product-card:hover,
.products-grid .product-item.card:hover,
.products-grid .product-item:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover) !important;
}

.pl-product-card .product-item-photo,
.products-grid .product-item-photo {
  display: block;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--color-bg-warm);
  margin-bottom: 0 !important;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}

.pl-product-card .product-item-photo img,
.products-grid .product-item-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.pl-product-card:hover .product-item-photo img,
.products-grid .product-item:hover .product-item-photo img {
  transform: scale(1.04);
}

.pl-product-card .product-info,
.products-grid .product-info {
  padding: 1.5rem 1.25rem 1.75rem !important;
  text-align: left !important;
}

.pl-product-card .product-item-link,
.products-grid .product-item-link {
  font-family: var(--font-body);
  font-size: var(--pl-text-sm) !important;
  font-weight: 500 !important;
  line-height: 1.45;
  color: var(--color-text) !important;
  letter-spacing: 0.01em;
  transition: color var(--transition-fast);
}

.pl-product-card .product-item-link:hover,
.products-grid .product-item-link:hover {
  color: var(--color-accent) !important;
}

.pl-product-card .price-box,
.products-grid .price-box {
  margin-top: 0.625rem;
  font-size: var(--pl-text-sm);
  font-weight: 600;
  color: var(--color-text);
}

.pl-product-card .old-price .price,
.products-grid .old-price .price {
  color: var(--color-text-light);
  font-weight: 400;
  text-decoration: line-through;
}

.pl-product-card .rating-summary,
.products-grid .rating-summary {
  margin-top: 0.5rem;
  color: var(--color-accent);
}

.pl-product-card .btn-primary,
.products-grid .btn-primary {
  margin-top: 1rem;
  font-size: var(--pl-text-xs) !important;
  letter-spacing: 0.06em;
  padding: 0.625rem 1.25rem !important;
}

/* Pagination */
.pages,
.pages .items {
  font-size: var(--pl-text-sm);
}

.pages .item a,
.pages .item strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  border-radius: var(--radius-sm);
  color: var(--color-text-muted);
  transition: background-color var(--transition-fast), color var(--transition-fast);
}

.pages .item a:hover {
  background: var(--color-bg-warm);
  color: var(--color-text);
}

.pages .item.current strong {
  background: var(--color-dark);
  color: var(--color-white);
  font-weight: 600;
}

/* ── Product Detail Page ──────────────────────────────────────────────────── */

.catalog-product-view .column.main {
  background: var(--color-bg);
}

.catalog-product-view .product-info-main > section {
  padding-bottom: var(--pl-space-section);
  gap: 3rem !important;
}

@media (min-width: 64rem) {
  .catalog-product-view .product-info-main > section {
    gap: 5rem !important;
  }
}

/* Gallery */
.catalog-product-view .product-media,
.catalog-product-view [class*="gallery"] {
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* Product info card */
.catalog-product-view .product-info .card.pl-product-buybox,
.catalog-product-view .product-info-main .card.pl-product-buybox {
  background: transparent;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none;
}

.catalog-product-view .product-info .card,
.catalog-product-view .product-info-main .card {
  background: var(--color-surface);
  border: 0 !important;
  border-radius: var(--radius-lg) !important;
  padding: 2.5rem !important;
  box-shadow: var(--shadow-sm);
}

.catalog-product-view .product-info .page-title,
.catalog-product-view .product-info h1 {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: 500;
  line-height: var(--pl-leading-heading);
  letter-spacing: -0.02em;
  color: var(--color-text);
  margin-bottom: 0.75rem;
}

.catalog-product-view .product-description {
  font-size: var(--pl-text-lg);
  line-height: var(--pl-leading-relaxed);
  color: var(--color-text-muted);
  margin-bottom: 0;
}

/* Buy box */
.pl-product-meta .rating-summary,
.pl-product-meta .stock {
  margin: 0;
}

.pl-product-sku {
  color: var(--color-text-light);
  padding:1rem 0;
}

.pl-product-sku__value {
  color: var(--color-text);
}

.pl-product-options {
  margin-bottom: 1.5rem;
  margin-top: 2rem;
}

.pl-product-options__heading {
  font-size: var(--pl-text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-light);
  margin-bottom: 0.75rem;
}

.pl-product-options__list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.pl-product-option__label {
  display: block;
  font-size: var(--pl-text-sm);
  font-weight: 500;
  color: var(--color-text);
  margin-bottom: 0.5rem;
}

.pl-product-option__control .form-select,
.pl-product-option__control .form-input,
.pl-product-option__control .form-textarea {
  width: 100%;
  max-width: 100%;
}

.pl-product-purchase {
  margin-top: 1.5rem;
}

.pl-product-purchase__actions .btn-primary {
  min-height: 2.75rem;
  padding-inline: 1.5rem;
  margin-left: 1rem;
}

.pl-product-purchase__secondary .btn {
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
}

.pl-product-purchase__secondary .btn:hover {
  color: var(--color-text);
  border-color: var(--color-text-light);
}

.pl-product-trust {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  background: var(--color-bg-warm);
  border-radius: var(--radius-md);
}

.pl-product-trust__item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.pl-product-trust__icon {
  flex-shrink: 0;
  margin-top: 0.125rem;
  color: var(--color-accent);
}

.pl-product-trust__label {
  display: block;
  font-size: var(--pl-text-sm);
  font-weight: 500;
  color: var(--color-text);
  margin-bottom: 0.125rem;
}

.pl-product-trust__value {
  display: block;
  font-size: var(--pl-text-sm);
  line-height: var(--pl-leading-body);
  color: var(--color-text-muted);
}

.catalog-product-view .product-options-wrapper [class*="border-t"],
.catalog-product-view .product-options-wrapper [class*="border-b"],
.catalog-product-view .product-info .swatch-attribute,
.catalog-product-view .product-info .swatch-attribute [class*="border-t"],
.catalog-product-view .product-info .swatch-attribute [class*="border-b"] {
  border: 0 !important;
}

.catalog-product-view .product-info .swatch-attribute {
  min-height: 0 !important;
  padding-block: 0.25rem;
}

.catalog-product-view .product-info .relative.mb-6 > h2 {
  font-size: var(--pl-text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-light);
  margin-bottom: 0.75rem;
  font-family: var(--font-body);
}

/* Price */
.catalog-product-view .product-info-main .price-box {
  font-family: var(--font-body);
}

.catalog-product-view .product-info-main .final-price .price {
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: -0.01em;
}

.catalog-product-view .product-info-main .old-price .price {
  font-size: var(--pl-text-body);
  color: var(--color-text-light);
  text-decoration: line-through;
}

/* Product attributes */
.catalog-product-view #product-details .product-detail-label {
  font-size: var(--pl-text-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-light) !important;
  font-weight: 500;
}

.catalog-product-view #product-details .product-detail-value {
  font-size: var(--pl-text-sm);
  color: var(--color-text) !important;
}

.catalog-product-view #product-details > div {
  border-color: var(--color-border) !important;
  padding-block: 0.875rem !important;
}

/* Delivery info */
.catalog-product-view .product-info [class*="text-gray"] {
  color: var(--color-text-muted) !important;
  font-size: var(--pl-text-sm);
  line-height: var(--pl-leading-body);
}

/* Tabs / sections */
.pl-product-tabs [role="tablist"] {
  gap: 0 !important;
  border-bottom: 1px solid var(--color-border) !important;
  margin-bottom: var(--pl-space-element) !important;
}

.pl-product-tabs [role="tab"] {
  padding: 1rem 1.5rem !important;
  font-size: var(--pl-text-sm) !important;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-light) !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -1px;
  transition: color var(--transition-fast), border-color var(--transition-fast);
  background: none !important;
}

.pl-product-tabs [role="tab"][aria-selected="true"],
.pl-product-tabs [role="tab"]:hover {
  color: var(--color-text) !important;
  border-bottom-color: var(--color-accent) !important;
}

.pl-product-tabs .card {
  background: var(--color-surface);
  border: 0 !important;
  border-radius: var(--radius-lg) !important;
  padding: 2.5rem !important;
  box-shadow: none;
}

.pl-product-tabs .prose {
  max-width: none;
}

/* Related / upsell */
.catalog-product-view .product-slider,
.catalog-product-view [class*="slider"] .card {
  border-radius: var(--radius-lg);
}

/* Reviews */
.catalog-product-view .review-list .review-item {
  padding-block: var(--pl-space-element);
  border-bottom: 1px solid var(--color-border);
}

/* ── CMS Pages ────────────────────────────────────────────────────────────── */

.cms-page-view .column.main {
  margin-inline: auto;
  padding-inline: 1.5rem;
  max-width: var(--pl-layout-max) !important;
}

.cms-page-view .cms-content,
.cms-page-view .column.main > div {
  font-size: var(--pl-text-body);
  line-height: var(--pl-leading-relaxed);
  color: var(--color-text-muted);
}

.cms-page-view .pl-page-header {
  text-align: center;
  padding-bottom: var(--pl-space-block);
  margin-bottom: var(--pl-space-block);
  border-bottom: 1px solid var(--color-border);
}

.cms-page-view .pl-page-header .page-title {
  margin-inline: auto;
}

/* ── Search results ───────────────────────────────────────────────────────── */

.catalogsearch-result-index .search.results {
  margin-top: var(--pl-space-element);
}

.catalogsearch-result-index .message.notice {
  background: var(--color-bg-warm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1.25rem 1.5rem;
  color: var(--color-text-muted);
  font-size: var(--pl-text-sm);
}

@media (min-width: 1024px) {
  body.catalog-category-view #product-list .products-grid > ul,
  body.catalogsearch-result-index #product-list .products-grid > ul {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

/* ── Responsive ───────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  :root {
    --pl-space-section: 3rem;
    --pl-space-block: 1.75rem;
  }

  .catalog-product-view .product-info .card,
  .catalog-product-view .product-info-main .card,
  .pl-product-tabs .card {
    padding: 1.75rem !important;
  }

  .pl-product-tabs [role="tab"] {
    padding: 0.75rem 1rem !important;
    font-size: var(--pl-text-xs) !important;
  }

  #product-list .products-grid > ul {
    gap: 1.5rem !important;
  }
}

/* ==========================================================================
   Demo Alignment Overrides
   目标：首页、列表页、详情页尽量贴近 demo 的结构与视觉语言
   ========================================================================== */

:root {
  --demo-bg-primary: #f7f4ef;
  --demo-bg-secondary: #ede8df;
  --demo-bg-deep: #ddd7cc;
  --demo-text-primary: #1c1a17;
  --demo-text-muted: #4a4540;
  --demo-text-soft: #8c7b6b;
  --demo-accent: #1c1a17;
  --demo-accent-soft: #c4b8a8;
  --demo-promo-bg: #2c2825;
  --demo-border: #ddd7cc;
  --demo-shadow-soft: 0 6px 20px rgba(28, 26, 23, 0.15);
  --demo-shadow-lift: 0 12px 40px rgba(28, 26, 23, 0.14);
  --demo-ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --demo-content-max: 1400px;
  --demo-section-gap: clamp(72px, 9vw, 100px);
}

body.cms-index-index,
body.catalog-category-view,
body.catalogsearch-result-index,
body.catalog-product-view {
  background: var(--demo-bg-primary);
  color: var(--demo-text-primary);
}

.pl-announcement {
  background: var(--demo-promo-bg);
  color: var(--color-white);
  padding: 9px 0;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  overflow: hidden;
  position: relative;
  z-index: 100;
}

.pl-announcement-track {
  display: flex;
  gap: 0;
  white-space: nowrap;
  animation: pl-marquee 28s linear infinite;
}

.pl-announcement-track span {
  padding: 0 40px;
  opacity: 0.9;
}

.pl-announcement-track span::after {
  content: "·";
  padding-left: 40px;
  opacity: 0.4;
}

.pl-announcement a {
  color: inherit;
  border-bottom: 1px solid rgba(255, 255, 255, 0.35);
}

@keyframes pl-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

#header.pl-site-header {
  position: sticky;
  top: 0;
  z-index: 99;
  background: rgba(247, 244, 239, 0.96);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--demo-border);
  box-shadow: none;
}

.pl-header-inner {
  max-width: var(--demo-content-max);
  margin: 0 auto;
  padding-top: 18px;
  padding-bottom: 18px;
  gap: 24px;
}

.pl-logo {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 28px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.pl-logo span {
  color: inherit;
}

#header .navigation {
  display: flex;
  justify-content: center;
  flex: 1;
}

#header .navigation ul {
  display: flex;
  align-items: center;
  gap: 20px;
}

#header .navigation .level-0 > a,
#header .navigation li.level-0 > button {
  position: relative;
  padding-bottom: 4px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--demo-text-primary) !important;
}

#header .navigation .level-0 > a::after,
#header .navigation li.level-0 > button::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 1px;
  background: var(--demo-text-primary);
  transition: width .3s var(--demo-ease);
}

#header .navigation .level-0:hover > a::after,
#header .navigation .level-0:hover > button::after,
#header .navigation .level-0[data-active] > a::after {
  width: 100%;
}

.pl-header-icon {
  width: 42px;
  height: 42px;
  padding: 0 !important;
  border-radius: 999px !important;
  color: var(--demo-text-primary) !important;
}

.pl-header-icon:hover {
  background: rgba(15, 15, 15, 0.04) !important;
}

.cms-index-index .btn-primary,
.catalog-product-view .action.primary.tocart,
.catalog-product-view .action.tocart.primary,
.catalog-category-view .quick-add {
  transition:
    transform .3s var(--demo-ease),
    background .3s var(--demo-ease),
    box-shadow .3s var(--demo-ease),
    border-color .3s var(--demo-ease);
}

.cms-index-index .btn-primary:hover,
.catalog-product-view .action.primary.tocart:hover,
.catalog-product-view .action.tocart.primary:hover {
  transform: translateY(-2px);
  box-shadow: var(--demo-shadow-soft);
}

.pl-header-search {
  background: rgba(243, 241, 236, 0.98);
  border-color: var(--demo-border) !important;
}

.pl-site-footer {
  background: transparent;
  color: var(--demo-text-primary);
  padding-top: 0;
}

.pl-site-footer .pl-container {
  max-width: var(--demo-content-max);
  margin: 0 auto;
  padding: var(--demo-section-gap) 32px 48px;
}

.pl-footer-business {
  text-align: center;
  padding-bottom: 40px;
  margin-bottom: 40px;
  border-bottom: 1px solid var(--demo-border);
  font-size: 13px;
  line-height: 1.8;
  color: var(--demo-text-muted);
}

.pl-footer-brand-name {
  margin-bottom: 8px;
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 22px;
  color: var(--demo-text-primary);
}

.pl-footer-entity-desc {
  max-width: 720px;
  margin: 0 auto 16px;
}

.pl-footer-address {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-width: 640px;
  margin: 0 auto;
  font-style: normal;
  font-size: 12px;
  line-height: 1.7;
}

.pl-footer-address a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.pl-footer-address a:hover {
  color: var(--demo-text-primary);
}

.pl-footer-address__line {
  display: block;
}

.pl-footer-trust {
  list-style: none;
  margin: 0 0 1rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pl-footer-trust a {
  font-size: 12px;
  color: var(--demo-text-muted);
  text-decoration: none;
  border-bottom: 1px solid var(--demo-border);
  padding-bottom: 2px;
  width: fit-content;
}

.pl-footer-trust a:hover {
  color: var(--demo-text-primary);
  border-color: var(--demo-text-primary);
}

.pl-footer-contact {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 300px;
  margin-bottom: 1.5rem;
  font-size: 12px;
  line-height: 1.65;
  color: var(--demo-text-muted);
}

.pl-footer-contact__item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.pl-footer-contact__icon {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--demo-text-primary);
}

.pl-footer-contact__icon svg {
  display: block;
  width: 20px;
  height: 20px;
}

.pl-footer-contact__text {
  margin: 0;
  font-size: inherit;
  line-height: inherit;
  color: inherit;
}

.pl-footer-contact__text strong {
  font-weight: 600;
  color: var(--demo-text-primary);
}

.pl-footer-contact a {
  color: inherit;
  text-decoration: none;
}

.pl-footer-contact a:hover {
  color: var(--demo-text-primary);
}

.pl-footer-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 48px;
}

.pl-footer-brand .pl-logo {
  display: inline-block;
  margin-bottom: 14px;
  color: var(--demo-text-primary);
}

.pl-footer-brand p,
.pl-footer-col a,
.pl-footer-bottom p {
  color: var(--demo-text-muted);
}

.pl-footer-col h4,
.pl-footer-accordion__title {
  margin-bottom: 20px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--demo-text-primary);
}

.pl-footer-accordion__item {
  border: 0;
}

.pl-footer-accordion__summary {
  list-style: none;
  cursor: default;
  pointer-events: none;
}

.pl-footer-accordion__summary::-webkit-details-marker {
  display: none;
}

.pl-footer-accordion__icon {
  display: none;
}

.pl-footer-social a {
  background: var(--demo-bg-secondary);
  color: var(--demo-text-primary);
}

.pl-footer-social a:hover {
  background: var(--demo-text-primary);
  color: #f3f1ec;
}

.pl-footer-bottom {
  margin-top: 40px;
  padding-top: 32px;
  border-top: 1px solid var(--demo-border);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 2rem;
}

.pl-footer-bottom__meta {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.pl-footer-meta {
  margin: 0;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--demo-text-muted);
}

.pl-footer-meta__label {
  text-transform: uppercase;
  font-weight: 600;
  margin-right: 0.5rem;
}

.pl-footer-meta__value {
  color: var(--demo-text-primary);
  font-variant-numeric: tabular-nums;
}

.pl-footer-copyright {
  margin: 0;
}

.pl-footer-legal-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 8px;
  font-size: 12px;
}

.pl-footer-legal-inline a {
  color: var(--demo-text-muted);
  text-decoration: none;
}

.pl-footer-legal-inline a:hover {
  color: var(--demo-text-primary);
  text-decoration: underline;
}

.pl-footer-legal-inline span[aria-hidden="true"] {
  color: var(--demo-border);
}

.pl-payment-icon svg {
  display: block;
  width: 38px;
  height: 24px;
}

.cms-index-index .pl-home {
  background: var(--demo-bg-primary);
}

.cms-index-index .hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: calc(100vh - 90px);
  overflow: hidden;
  max-width: none;
  padding: 0;
}

.cms-index-index .hero-media {
  position: relative;
  overflow: hidden;
}

.cms-index-index .hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 8s ease;
  transform: scale(1.03);
}

.cms-index-index .hero:hover .hero-media img {
  transform: scale(1);
}

.cms-index-index .hero-media-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(28, 26, 23, 0.05), transparent);
}

.cms-index-index .hero-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 80px 72px 80px 60px;
  background: var(--demo-bg-primary);
  color: var(--demo-text-primary);
  max-width: none;
}

.cms-index-index .section,
.catalog-category-view #category-view-container,
.catalog-category-view .columns,
.catalogsearch-result-index .columns,
.catalog-product-view .column.main {
  max-width: var(--demo-content-max);
  margin: 0 auto;
  padding-left: 32px;
  padding-right: 32px;
}

.cms-index-index .hero-eyebrow,
.cms-index-index .section-eyebrow,
.cms-index-index .section-label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.cms-index-index .hero-eyebrow {
  margin-bottom: 24px;
  color: var(--demo-text-soft);
}

.cms-index-index .hero-title,
.cms-index-index .hero-headline,
.cms-index-index .section-title {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-weight: 300;
  line-height: 1.05;
}

.cms-index-index .hero-title,
.cms-index-index .hero-headline {
  margin-bottom: 28px;
  font-size: clamp(52px, 5.5vw, 80px);
  color: var(--demo-text-primary);
  letter-spacing: -0.01em;
}

.cms-index-index .hero-title em,
.cms-index-index .hero-headline em,
.cms-index-index .section-title em {
  font-style: italic;
  font-weight: 300;
  color: var(--demo-text-soft);
}

.cms-index-index .hero-subtitle,
.cms-index-index .hero-subtext {
  max-width: 380px;
  margin-bottom: 44px;
  font-size: 15px;
  font-weight: 300;
  line-height: 1.7;
  color: var(--demo-text-muted);
}

.cms-index-index .hero-cta,
.cms-index-index .hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
}

.cms-index-index .hero-scroll-hint {
  margin-top: 64px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--demo-accent-soft);
}

.cms-index-index .hero-scroll-line {
  width: 40px;
  height: 1px;
  background: var(--demo-accent-soft);
}

.cms-index-index .btn-primary,
.cms-index-index .btn-secondary,
.cms-index-index .newsletter-form .action,
.catalog-category-view .quick-add,
.catalog-product-view .action.primary {
  border-radius: 0 !important;
  padding: 16px 40px !important;
  font-size: 12px !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
}

.cms-index-index .btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: transparent !important;
  color: var(--demo-text-primary) !important;
  border: 1px solid var(--demo-text-primary) !important;
  border-radius: 2px !important;
  padding: 13px 32px !important;
  font-size: 11.5px !important;
  font-weight: 500;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  transition: background .3s var(--demo-ease), color .3s var(--demo-ease), transform .3s var(--demo-ease);
}

.cms-index-index .btn-secondary:hover {
  background: var(--demo-text-primary) !important;
  color: var(--color-white) !important;
  transform: translateY(-1px);
}

.cms-index-index .btn-ghost {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--demo-text-primary);
  border-bottom: 1px solid var(--demo-text-primary);
  padding-bottom: 2px;
  transition: opacity .3s var(--demo-ease);
}

.cms-index-index .btn-ghost:hover {
  opacity: 0.5;
  color: var(--demo-text-primary);
}

.cms-index-index .btn-link {
  font-size: 13px;
  border-bottom: 1px solid var(--demo-text-primary);
  padding-bottom: 2px;
  color: var(--demo-text-primary);
}

.cms-index-index .section {
  padding-top: var(--demo-section-gap);
  padding-bottom: var(--demo-section-gap);
}

.cms-index-index .section-header {
  text-align: center;
  margin-bottom: 56px;
}

.cms-index-index .section-header-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 48px;
  text-align: left;
}

.cms-index-index .section-label {
  margin-bottom: 48px;
  color: var(--demo-text-soft);
  display: flex;
  align-items: center;
  gap: 16px;
}

.cms-index-index .section-label::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--demo-border);
  max-width: 120px;
}

.cms-index-index .section-eyebrow {
  margin-bottom: 12px;
  color: var(--demo-text-soft);
}

.cms-index-index .section-title {
  font-size: clamp(32px, 3vw, 48px);
  font-weight: 400;
  color: var(--demo-text-primary);
}

.cms-index-index .feature-bar {
  border-top: 1px solid var(--demo-border);
  border-bottom: 1px solid var(--demo-border);
  padding: 40px 24px;
}

.cms-index-index .feature-bar-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  text-align: center;
}

.cms-index-index .feature-item-icon {
  font-size: 22px;
  margin-bottom: 12px;
  color: var(--demo-text-soft);
}

.cms-index-index .feature-item-title {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 4px;
}

.cms-index-index .feature-item-sub {
  font-size: 12.5px;
  color: var(--demo-text-soft);
  line-height: 1.5;
}

.cms-index-index .editorial-strip {
  background: var(--demo-text-primary);
  padding: 100px 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
  max-width: none;
}

.cms-index-index .editorial-bg-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(80px, 15vw, 200px);
  font-weight: 300;
  font-style: italic;
  color: rgba(255, 255, 255, 0.04);
  white-space: nowrap;
  pointer-events: none;
  letter-spacing: -0.02em;
}

.cms-index-index .editorial-inner {
  position: relative;
  z-index: 1;
}

.cms-index-index .editorial-quote {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(28px, 3.5vw, 48px);
  font-weight: 300;
  font-style: italic;
  color: var(--color-white);
  line-height: 1.3;
  max-width: 720px;
  margin: 0 auto 32px;
}

.cms-index-index .editorial-byline {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--demo-accent-soft);
  margin-bottom: 40px;
}

.cms-index-index .editorial-strip .btn-secondary {
  border-color: rgba(255, 255, 255, 0.4) !important;
  color: var(--color-white) !important;
}

.cms-index-index .editorial-strip .btn-secondary:hover {
  background: var(--color-white) !important;
  color: var(--demo-text-primary) !important;
}

.cms-index-index .brand-story {
  padding: 100px 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  max-width: 1300px;
  margin: 0 auto;
}

.cms-index-index .brand-story-eyebrow {
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--demo-text-soft);
  margin-bottom: 20px;
}

.cms-index-index .brand-story-title {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(36px, 3.5vw, 52px);
  font-weight: 300;
  line-height: 1.15;
  margin-bottom: 24px;
}

.cms-index-index .brand-story-title em {
  font-style: italic;
  color: var(--demo-text-soft);
}

.cms-index-index .brand-story-text {
  font-size: 15px;
  font-weight: 300;
  color: var(--demo-text-muted);
  line-height: 1.8;
  margin-bottom: 36px;
}

.cms-index-index .brand-story-media {
  position: relative;
}

.cms-index-index .brand-story-media img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 4px;
}

.cms-index-index .story-accent-block {
  position: absolute;
  bottom: -24px;
  left: -24px;
  width: 140px;
  height: 140px;
  background: var(--demo-bg-secondary);
  border-radius: 4px;
  z-index: -1;
}

.cms-index-index .category-grid,
.cms-index-index .product-grid,
.cms-index-index .lookbook-grid {
  display: grid;
}

.cms-index-index .cat-strip {
  padding: 80px 24px;
  max-width: var(--demo-content-max);
  margin: 0 auto;
}

.cms-index-index .category-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
}

.cms-index-index .category-card,
.cms-index-index .lookbook-item {
  position: relative;
  overflow: hidden;
  border-radius: 4px;
}

.cms-index-index .category-card:first-child {
  grid-row: span 2;
}

.cms-index-index .category-card {
  aspect-ratio: 3 / 4;
}

.cms-index-index .category-card:first-child {
  aspect-ratio: unset;
  min-height: 100%;
}

.cms-index-index .category-card img,
.cms-index-index .lookbook-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--demo-ease);
}

.cms-index-index .category-card:hover img,
.cms-index-index .lookbook-item:hover img {
  transform: scale(1.05);
}

.cms-index-index .category-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28, 26, 23, 0.55) 0%, transparent 50%);
}

.cms-index-index .category-label {
  position: absolute;
  left: 18px;
  bottom: 20px;
  z-index: 1;
  color: var(--color-white);
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 20px;
  font-weight: 400;
  letter-spacing: 0.02em;
}

.cms-index-index .category-label small {
  display: block;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.75;
  margin-bottom: 4px;
}

.cms-index-index .product-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

.cms-index-index .product-card {
  position: relative;
  transition: transform .35s var(--demo-ease);
}

.cms-index-index .product-card:hover {
  transform: translateY(-4px);
}

.cms-index-index .product-image-wrap {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--demo-bg-secondary);
  margin-bottom: 16px;
}

.cms-index-index .product-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--demo-ease);
}

.cms-index-index .product-card:hover .product-image-wrap img {
  transform: scale(1.03);
}

.cms-index-index .quick-add,
.catalog-category-view .quick-add {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  display: block;
  background: var(--demo-text-primary);
  color: #f3f1ec !important;
  padding: 14px !important;
  font-size: 11px !important;
  font-weight: 500;
  letter-spacing: 0.15em !important;
  text-transform: uppercase;
  text-align: center;
  transform: translateY(100%);
  transition: transform .3s var(--demo-ease);
  z-index: 2;
}

.cms-index-index .product-card:hover .quick-add,
.catalog-category-view .product-card:hover .quick-add {
  transform: translateY(0);
}

.cms-index-index .product-name,
.catalog-category-view .product-item-link {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 18px !important;
  font-weight: 400 !important;
  color: var(--demo-text-primary) !important;
  line-height: 1.2;
}

.cms-index-index .product-price,
.catalog-category-view .price-box {
  margin-top: 6px;
  font-size: 14px;
  color: var(--demo-text-muted);
}

.cms-index-index .product-price s {
  margin-left: 6px;
  opacity: .7;
}

.cms-index-index .product-rating,
.catalog-category-view .rating-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  font-size: 12px;
  color: var(--demo-text-muted);
}

.cms-index-index .stars,
.catalog-category-view .rating-summary {
  color: var(--demo-text-soft);
}

.cms-index-index .badge,
.catalog-category-view .badge {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  padding: 4px 10px;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: 2px;
}

.cms-index-index .badge.new,
.catalog-category-view .badge.new {
  background: var(--demo-text-soft);
  color: var(--color-white);
}

.cms-index-index .badge.sale,
.catalog-category-view .badge.sale,
.cms-index-index .badge.bestseller,
.catalog-category-view .badge.bestseller {
  background: var(--demo-text-primary);
  color: var(--color-white);
}

.cms-index-index .usp-strip {
  background: var(--demo-bg-secondary);
  padding: 64px 32px;
}

.cms-index-index .usp-grid {
  max-width: var(--demo-content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 48px;
  text-align: center;
}

.cms-index-index .usp-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 20px;
  stroke: var(--demo-text-primary);
  fill: none;
  stroke-width: 1.2;
}

.cms-index-index .usp-title {
  margin-bottom: 8px;
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 22px;
}

.cms-index-index .usp-desc,
.cms-index-index .newsletter-desc {
  font-size: 13px;
  line-height: 1.7;
  color: var(--demo-text-muted);
}

.cms-index-index .lookbook-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.cms-index-index .lookbook-item {
  aspect-ratio: 3 / 4;
}

.cms-index-index .lookbook-watermark {
  position: absolute;
  left: 16px;
  bottom: 16px;
  color: #f3f1ec;
  font-size: 11px;
  letter-spacing: .1em;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}

.cms-index-index .testimonials {
  background: var(--demo-bg-secondary);
  padding: 100px 24px;
  max-width: none;
}

.cms-index-index .testimonials-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.cms-index-index .testimonials-header {
  text-align: center;
  margin-bottom: 60px;
}

.cms-index-index .testimonials-title {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 400;
  margin-bottom: 12px;
}

.cms-index-index .testimonials-title em {
  font-style: italic;
  color: var(--demo-text-soft);
}

.cms-index-index .testimonials-rating {
  font-size: 13px;
  color: var(--demo-text-soft);
}

.cms-index-index .reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.cms-index-index .review-card {
  background: var(--color-white);
  padding: 32px;
  border-radius: 4px;
}

.cms-index-index .review-stars {
  display: flex;
  gap: 3px;
  margin-bottom: 16px;
  color: var(--demo-text-soft);
  font-size: 11px;
}

.cms-index-index .review-text {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 17px;
  font-weight: 300;
  font-style: italic;
  line-height: 1.6;
  color: var(--demo-text-primary);
  margin-bottom: 20px;
}

.cms-index-index .review-author {
  font-size: 12px;
  font-weight: 500;
  color: var(--demo-text-soft);
  letter-spacing: 0.06em;
}

.cms-index-index .review-product {
  font-size: 11px;
  color: var(--demo-accent-soft);
  margin-top: 2px;
}

.cms-index-index .review-verified {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  color: #5a8a6a;
  margin-top: 8px;
}

.cms-index-index .newsletter {
  background: var(--demo-bg-primary);
  padding: var(--demo-section-gap) 32px;
  text-align: center;
  max-width: none;
}

.cms-index-index .newsletter-inner {
  max-width: 600px;
  margin: 0 auto;
}

.cms-index-index .newsletter-title {
  margin-bottom: 12px;
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(30px, 3vw, 44px);
  font-weight: 300;
  line-height: 1.2;
}

.cms-index-index .newsletter-title em {
  font-style: italic;
  color: var(--demo-text-soft);
}

.cms-index-index .newsletter-privacy {
  margin-top: 16px;
  font-size: 11px;
  color: var(--demo-accent-soft);
}

.cms-index-index .newsletter-privacy a {
  border-bottom: 1px solid var(--demo-accent-soft);
  color: inherit;
}

.cms-index-index .newsletter .pl-footer-social {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 14px;
  margin-top: 28px;
}

.cms-index-index .newsletter .pl-footer-social a {
  flex-shrink: 0;
}

.cms-index-index .newsletter-form,
.cms-index-index .form.subscribe {
  display: flex;
  gap: 0;
  max-width: 440px;
  margin: 32px auto 0;
}

.cms-index-index .newsletter-form input,
.cms-index-index .form.subscribe input {
  flex: 1;
  min-width: 0;
  padding: 16px 20px;
  border: 1px solid var(--demo-border);
  background: #f3f1ec;
}

.cms-index-index .newsletter-form .action,
.cms-index-index .form.subscribe .action {
  background: var(--demo-text-primary) !important;
  border: 1px solid var(--demo-text-primary) !important;
  color: #f3f1ec !important;
}

.cms-index-index .home-section-action {
  margin-top: 56px;
  text-align: center;
}

.cms-index-index .reveal {
  opacity: 1;
  transform: none;
}

.catalog-category-view .breadcrumbs,
.catalogsearch-result-index .breadcrumbs,
.catalog-product-view .breadcrumbs {
  background: transparent !important;
  border-bottom: 0 !important;
}

.catalog-category-view .breadcrumbs .items,
.catalogsearch-result-index .breadcrumbs .items,
.catalog-product-view .breadcrumbs .items {
  padding-top: 40px !important;
  padding-bottom: 16px !important;
  font-size: 12px !important;
  color: var(--demo-text-muted) !important;
}

.catalog-category-view .pl-page-header,
.catalogsearch-result-index .pl-page-header {
  padding-top: 12px;
  padding-bottom: 24px;
}

.catalog-category-view .page-title,
.catalogsearch-result-index .page-title {
  margin-bottom: 8px !important;
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(36px, 5vw, 52px);
  font-weight: 400;
  color: var(--demo-text-primary);
}

.catalog-category-view .page-desc,
.catalogsearch-result-index .page-desc,
.catalog-category-view .category-description {
  max-width: 540px;
  font-size: 14px;
  line-height: 1.75;
  color: var(--demo-text-muted);
}

.catalog-category-view .category-image {
  margin-bottom: 32px;
  overflow: hidden;
}

.catalog-category-view .category-image img {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
}

.catalog-category-view .columns,
.catalogsearch-result-index .columns {
  padding-bottom: 80px;
}

#product-list .products-grid > ul,
.catalogsearch-result-index #product-list .products-grid > ul {
  gap: 24px !important;
}

.catalog-category-view .product-card,
.catalogsearch-result-index .product-card {
  overflow: hidden;
  background: transparent !important;
  box-shadow: none !important;
  transition: transform .35s var(--demo-ease);
}

.catalog-category-view .product-card:hover,
.catalogsearch-result-index .product-card:hover {
  transform: translateY(-4px);
}

.catalog-category-view .product-image-wrap,
.catalog-category-view .product-item-photo,
.catalogsearch-result-index .product-image-wrap,
.catalogsearch-result-index .product-item-photo {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--demo-bg-secondary);
  border-radius: 0 !important;
  margin-bottom: 16px !important;
}

.catalog-category-view .product-image-wrap img,
.catalog-category-view .product-item-photo img,
.catalogsearch-result-index .product-image-wrap img,
.catalogsearch-result-index .product-item-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s var(--demo-ease);
}

.catalog-category-view .product-card:hover .product-item-photo img,
.catalogsearch-result-index .product-card:hover .product-item-photo img {
  transform: scale(1.03);
}

.catalog-category-view .product-info,
.catalogsearch-result-index .product-info {
  padding: 0 !important;
}

.catalog-category-view .price-box .price,
.catalogsearch-result-index .price-box .price {
  color: var(--demo-text-primary);
  font-weight: 500;
}

.catalog-category-view .old-price .price,
.catalogsearch-result-index .old-price .price {
  color: var(--demo-text-muted);
  font-weight: 400;
}

.catalog-category-view .product-card-details,
.catalogsearch-result-index .product-card-details {
  display: none;
}

.catalog-category-view .product-card-actions,
.catalogsearch-result-index .product-card-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
}

.catalog-category-view .product-card-links,
.catalogsearch-result-index .product-card-links {
  display: flex;
  gap: 8px;
  margin-left: auto;
}

.catalog-category-view .product-card-compare,
.catalogsearch-result-index .product-card-compare {
  width: 34px;
  height: 34px;
  padding: 0 !important;
  border: 1px solid var(--demo-border) !important;
  background: transparent !important;
  border-radius: 50% !important;
}

.catalog-category-view .toolbar.toolbar-products,
.catalogsearch-result-index .toolbar.toolbar-products {
  margin-bottom: 32px;
  padding: 0 0 24px;
  border-top: 0 !important;
  border-bottom: 1px solid var(--demo-border) !important;
  color: var(--demo-text-muted);
}

.catalog-category-view .toolbar .amount,
.catalogsearch-result-index .toolbar .amount,
.catalog-category-view .toolbar .sorter,
.catalogsearch-result-index .toolbar .sorter,
.catalog-category-view .toolbar .pages,
.catalogsearch-result-index .toolbar .pages {
  font-size: 13px !important;
  color: var(--demo-text-muted);
}

.catalog-category-view .toolbar select,
.catalogsearch-result-index .toolbar select {
  min-height: 42px;
  border: 1px solid var(--demo-border);
  background-color: transparent;
  font-size: 12px;
  letter-spacing: .05em;
}

.catalog-category-view .block.filter,
.catalogsearch-result-index .block.filter {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}

.catalog-category-view .pl-filters,
.catalogsearch-result-index .pl-filters {
  position: sticky;
  top: 108px;
  align-self: start;
}

.catalog-category-view .pl-filters-title,
.catalogsearch-result-index .pl-filters-title {
  margin-bottom: 12px;
}

.catalog-category-view .pl-filters-toggle span:first-child,
.catalogsearch-result-index .pl-filters-toggle span:first-child {
  font-size: 11px !important;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.catalog-category-view .pl-filter-group-content .items,
.catalogsearch-result-index .pl-filter-group-content .items {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.catalog-category-view .pl-filter-group-content a,
.catalogsearch-result-index .pl-filter-group-content a {
  font-size: 13px;
  color: var(--demo-text-muted);
}

.catalog-category-view .pl-filter-group-content a:hover,
.catalogsearch-result-index .pl-filter-group-content a:hover {
  color: var(--demo-text-primary);
}

.catalog-category-view .pl-filter-group-content .count,
.catalogsearch-result-index .pl-filter-group-content .count {
  color: rgba(107, 101, 96, 0.78);
}

.catalog-category-view .block.filter .filter-option.card,
.catalogsearch-result-index .block.filter .filter-option.card {
  margin: 0 0 24px !important;
  padding: 0 0 24px !important;
  border: 0 !important;
  border-bottom: 1px solid var(--demo-border) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.catalog-category-view .filter-options-title .title,
.catalogsearch-result-index .filter-options-title .title {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.catalog-product-view .column.main {
  max-width: var(--demo-content-max);
  padding-top: 0;
  padding-bottom: 80px;
}

.catalog-product-view .pdp-grid {
  display: grid;
  grid-template-columns: minmax(0, 55%) minmax(320px, 1fr);
  gap: 48px;
  align-items: start;
}

.catalog-product-view .gallery {
  min-width: 0;
}

.catalog-product-view #gallery-main {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--demo-bg-secondary);
  margin-bottom: 12px;
}

.catalog-product-view #gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover !important;
}

.catalog-product-view #thumbs {
  align-items: stretch;
  gap: 12px;
}

.catalog-product-view .js_thumbs_slides {
  gap: 12px;
  overflow: visible;
}

.catalog-product-view .js_thumbs_slide {
  margin: 0 !important;
}

.catalog-product-view .js_thumbs_slide button {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border: 2px solid transparent !important;
  opacity: .75;
  transition: border-color .3s var(--demo-ease), opacity .3s var(--demo-ease);
}

.catalog-product-view .js_thumbs_slide button[class*="border-primary"],
.catalog-product-view .js_thumbs_slide button:hover {
  border-color: var(--demo-text-primary) !important;
  opacity: 1;
}

.catalog-product-view .js_thumbs_slide img {
  width: 90px;
  height: 120px;
  object-fit: cover;
}

.catalog-product-view .pdp-info {
  position: sticky;
  top: 110px;
  padding-left: 24px;
}

.catalog-product-view .pdp-info .page-title,
.catalog-product-view .pdp-info h1 {
  margin-bottom: 16px !important;
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(32px, 4vw, 42px);
  font-weight: 400;
  line-height: 1.15;
}

.catalog-product-view .product-description {
  font-size: 15px;
  line-height: 1.8;
  color: var(--demo-text-muted);
}

.catalog-product-view .pl-product-meta {
  font-size: 12px;
  color: var(--demo-text-muted);
}

.catalog-product-view .price-box {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}

.catalog-product-view .price-box .price {
  font-size: 20px !important;
  font-weight: 500 !important;
  color: var(--demo-text-primary) !important;
}

.catalog-product-view .price-box .old-price .price,
.catalog-product-view .price-box .price-final_price + .old-price .price {
  font-size: 16px !important;
  font-weight: 400 !important;
  color: var(--demo-text-muted) !important;
  text-decoration: line-through;
}

.catalog-product-view .field.option,
.catalog-product-view .product-options-wrapper .field,
.catalog-product-view .product-options-bottom .field {
  margin-bottom: 28px;
}

.catalog-product-view .swatch-attribute-label,
.catalog-product-view .label.admin__field-label,
.catalog-product-view .field-label,
.catalog-product-view .product-options-wrapper label {
  display: block;
  margin-bottom: 12px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--demo-text-primary);
}

.catalog-product-view .swatch-option {
  min-width: 32px;
  min-height: 32px;
  border: 2px solid transparent !important;
  box-shadow: 0 0 0 1px var(--demo-border) inset;
  transition: transform .2s var(--demo-ease), border-color .2s var(--demo-ease);
}

.catalog-product-view .swatch-option:hover {
  transform: scale(1.08);
}

.catalog-product-view .swatch-option.selected,
.catalog-product-view .swatch-option[aria-checked="true"] {
  border-color: var(--demo-text-primary) !important;
}

.catalog-product-view .product-options-wrapper select,
.catalog-product-view .product-options-wrapper .form-select,
.catalog-product-view .product-options-wrapper input[type="text"],
.catalog-product-view .product-options-wrapper textarea {
  min-height: 52px;
  width: 100%;
  border: 1px solid var(--demo-border);
  background: transparent;
  padding: 12px 14px;
}

.catalog-product-view .buy-now-row {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 24px;
}

.catalog-product-view .pl-product-purchase__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.catalog-product-view .pl-product-purchase__actions > *:first-child {
  min-width: 88px;
}

.catalog-product-view .pl-product-purchase__actions .action.primary,
.catalog-product-view .pl-product-purchase__actions .action.tocart {
  flex: 1 1 240px;
}

.catalog-product-view .pl-product-purchase__secondary .action,
.catalog-product-view .pl-product-purchase__secondary button,
.catalog-product-view .pl-product-purchase__secondary a {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--demo-border) !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: var(--demo-text-primary) !important;
}

.catalog-product-view .action.primary.tocart,
.catalog-product-view .action.tocart.primary {
  min-height: 56px;
  background: var(--demo-text-primary) !important;
  border-color: var(--demo-text-primary) !important;
  color: #f3f1ec !important;
}

.catalog-product-view .qty,
.catalog-product-view input.qty {
  min-height: 56px;
  border: 1px solid var(--demo-border);
  background: transparent;
}

.catalog-product-view .trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding: 20px 0;
  margin-bottom: 32px;
  border-top: 1px solid var(--demo-border);
  border-bottom: 1px solid var(--demo-border);
}

.catalog-product-view .trust-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 12px;
  color: var(--demo-text-muted);
}

.catalog-product-view .trust-item svg {
  width: 18px;
  height: 18px;
  stroke: var(--demo-text-muted);
  fill: none;
  stroke-width: 1.2;
  flex-shrink: 0;
}

.catalog-product-view .snap-slider {
  margin-top: 80px;
  padding-top: 0;
  border-top: 1px solid var(--demo-border);
}

.catalog-product-view .snap-slider > .flex {
  align-items: center;
  margin-bottom: 32px;
}

.catalog-product-view .snap-slider h2,
.catalog-product-view .snap-slider h3,
.catalog-product-view .snap-slider h4 {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(28px, 3vw, 36px);
  font-weight: 400;
}

.catalog-product-view .snap-slider [data-prev],
.catalog-product-view .snap-slider [data-next] {
  visibility: visible !important;
  width: 40px;
  height: 40px;
  padding: 0 !important;
  border-radius: 999px !important;
  border: 1px solid var(--demo-border) !important;
  background: transparent !important;
  color: var(--demo-text-primary) !important;
}

.catalog-product-view .snap-pager {
  margin-top: 24px;
}

.catalog-product-view .pdp-sections {
  margin-top: 48px;
}

.catalog-product-view .accordion {
  border-top: 1px solid var(--demo-border);
}

.catalog-product-view .accordion-item {
  border-bottom: 1px solid var(--demo-border);
}

.catalog-product-view .accordion-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.catalog-product-view .accordion-trigger svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  transition: transform .3s var(--demo-ease);
}

.catalog-product-view .accordion-item.open .accordion-trigger svg {
  transform: rotate(45deg);
}

.catalog-product-view .accordion-content {
  padding: 0 0 24px;
  font-size: 14px;
  color: var(--demo-text-muted);
  line-height: 1.8;
}

.catalog-product-view .reviews-section {
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--demo-border);
}

.catalog-product-view .reviews-title {
  margin-bottom: 24px;
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 24px;
  font-weight: 400;
}

.catalog-product-view #customer-review-list > h2,
.catalog-product-view #review-form .text-xl,
.catalog-product-view #customer-review-list .text-2xl {
  display: none;
}

.catalog-product-view #customer-review-list .card,
.catalog-product-view #review-form .card {
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.catalog-product-view #customer-review-list [itemprop="review"] {
  background: var(--demo-bg-secondary);
  padding: 24px;
  margin: 0 0 16px !important;
  border: 0 !important;
}

.catalog-product-view #customer-review-list .rating-summary {
  color: var(--demo-accent);
}

.catalog-product-view #customer-review-list [itemprop="name"] {
  margin: 12px 0 10px !important;
  font-size: 18px;
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  color: var(--demo-text-primary);
}

.catalog-product-view #customer-review-list time,
.catalog-product-view #customer-review-list [itemprop="author"] {
  font-size: 12px;
  color: var(--demo-text-muted);
}

.catalog-product-view #customer-review-list [itemprop="description"] {
  margin-top: 12px !important;
  line-height: 1.8;
  color: var(--demo-text-muted);
}

.catalog-product-view .review-form .form-input {
  min-height: 52px;
  border: 1px solid var(--demo-border);
  background: transparent;
  padding: 14px 16px;
}

.catalog-product-view .review-form textarea.form-input {
  min-height: 140px;
}

.catalog-product-view .review-form .btn.btn-primary {
  border-radius: 0 !important;
  min-height: 54px;
  padding: 0 28px !important;
  background: var(--demo-text-primary) !important;
  border-color: var(--demo-text-primary) !important;
  color: #f3f1ec !important;
  letter-spacing: .12em;
  text-transform: uppercase;
}

@media (max-width: 1024px) {
  .cms-index-index .hero {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .cms-index-index .hero-media {
    height: 60vw;
    min-height: 300px;
  }

  .cms-index-index .hero-content {
    padding: 48px 32px;
  }

  .cms-index-index .brand-story {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .cms-index-index .feature-bar-inner {
    grid-template-columns: repeat(2, 1fr);
    gap: 28px;
  }

  .cms-index-index .reviews-grid {
    grid-template-columns: 1fr;
  }

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

  .cms-index-index .category-card:first-child {
    grid-row: span 1;
    aspect-ratio: 3 / 4;
  }

  .cms-index-index .product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .catalog-product-view .pdp-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .catalog-product-view .pdp-info {
    position: static;
    padding-left: 0;
  }

  .pl-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 32px;
  }
}

@media (max-width: 768px) {
  .cms-index-index .hero-content {
    padding: 36px 20px;
  }

  .cms-index-index .section,
  .catalog-category-view #category-view-container,
  .catalog-category-view .columns,
  .catalogsearch-result-index .columns,
  .catalog-product-view .column.main {
    padding-left: 20px;
    padding-right: 20px;
  }

  .cms-index-index .hero-cta,
  .cms-index-index .hero-ctas,
  .cms-index-index .newsletter-form,
  .cms-index-index .form.subscribe {
    flex-direction: column;
  }

  .cms-index-index .hero-ctas .btn-primary,
  .cms-index-index .hero-ctas .btn-secondary {
    width: 100%;
    justify-content: center;
  }

  .cms-index-index .brand-story {
    padding: 60px 0;
  }

  .cms-index-index .feature-bar-inner {
    grid-template-columns: 1fr;
  }

  .cms-index-index .section-header-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }

  .cms-index-index .category-grid,
  .cms-index-index .lookbook-grid,
  .cms-index-index .usp-grid,
  .catalog-category-view #product-list .products-grid > ul {
    grid-template-columns: 1fr !important;
  }

  .cms-index-index .product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }

  .catalog-product-view .pl-product-purchase__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .pl-header-inner {
    padding-top: 14px;
    padding-bottom: 14px;
  }

  #header .navigation {
    order: 3;
    width: 100%;
    justify-content: flex-start;
    overflow-x: auto;
    padding-top: 8px;
  }

  #header .navigation ul {
    gap: 20px;
    white-space: nowrap;
  }

  .catalog-category-view .pl-filters,
  .catalogsearch-result-index .pl-filters {
    position: static;
  }

  .pl-footer-business {
    padding-bottom: 24px;
    margin-bottom: 24px;
  }

  .pl-footer-entity-desc {
    font-size: 12px;
  }

  .pl-footer-address {
    text-align: left;
    margin-inline: auto;
  }

  .pl-footer-trust {
    align-items: center;
  }

  .pl-footer-trust a {
    margin-inline: auto;
  }

  .pl-footer-social {
    justify-content: center;
    margin-top: 16px;
  }

  .pl-footer-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .pl-footer-brand {
    text-align: center;
    padding-bottom: 24px;
    margin-bottom: 8px;
    border-bottom: 1px solid var(--demo-border);
  }

  .pl-footer-contact {
    max-width: none;
    margin-inline: auto;
    text-align: left;
  }

  .pl-footer-col {
    border-bottom: 1px solid var(--demo-border);
  }

  .pl-footer-accordion__summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 0;
    cursor: pointer;
    pointer-events: auto;
  }

  .pl-footer-accordion__title {
    margin-bottom: 0;
  }

  .pl-footer-accordion__icon {
    display: block;
    width: 10px;
    height: 10px;
    border-right: 1.5px solid currentColor;
    border-bottom: 1.5px solid currentColor;
    transform: rotate(45deg);
    transition: transform 0.2s ease;
    flex-shrink: 0;
  }

  .pl-footer-accordion__item[open] .pl-footer-accordion__icon {
    transform: rotate(-135deg);
  }

  .pl-footer-accordion__item ul {
    padding-bottom: 12px;
  }

  .pl-footer-accordion__item li {
    margin-top: 10px;
  }

  .pl-footer-bottom {
    flex-direction: column;
    text-align: center;
    gap: 16px;
    padding-top: 24px;
  }

  .pl-footer-legal-inline {
    justify-content: center;
  }

  .pl-payment-icons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
  }
}

/* ==========================================================================
   Sunisla — LWII quiet-luxury design layer
   ========================================================================== */

.cms-index-index .btn-primary:hover,
.catalog-product-view .action.primary.tocart:hover,
.catalog-product-view .action.tocart.primary:hover {
  background: var(--demo-text-muted) !important;
  border-color: var(--demo-text-muted) !important;
  box-shadow: var(--demo-shadow-soft);
}

.catalog-product-view .pdp-installment {
  margin-top: 12px;
  padding: 12px 16px;
  background: var(--demo-bg-secondary);
  font-size: 13px;
  color: var(--demo-text-muted);
  border-radius: 4px;
}

.catalog-product-view .pdp-installment strong {
  color: var(--demo-text-primary);
  font-weight: 500;
}

/* PLP hero + filter bar */
.catalog-category-view .plp-hero,
.catalog-category-view .page-title-wrapper.plp-hero {
  background: var(--demo-bg-secondary);
  padding: 60px 24px 24px;
  text-align: center;
  border-bottom: 1px solid var(--demo-border);
  max-width: none;
  margin: 0;
}

.catalog-category-view .page-title,
.catalog-category-view .plp-hero .page-title {
  margin-bottom: 12px !important;
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(36px, 5vw, 64px) !important;
  font-weight: 300 !important;
  line-height: 1.1;
}

.catalog-category-view .plp-hero-meta {
  max-width: var(--demo-content-max);
  margin: 0 auto;
  padding: 0 24px 24px;
  text-align: center;
  background: var(--demo-bg-secondary);
  border-bottom: 1px solid var(--demo-border);
}

.catalog-category-view .category-image {
  display: none;
}

.catalog-category-view .columns > .filter-bar {
  grid-column: 1 / -1;
}

.catalog-category-view .filter-bar {
  position: sticky;
  top: 64px;
  z-index: 50;
  background: rgba(247, 244, 239, 0.97);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid var(--demo-border);
  width: 100%;
}

.catalog-category-view .filter-bar-inner {
  max-width: var(--demo-content-max);
  margin: 0 auto;
  display: flex;
  align-items: center;
  min-height: 52px;
  padding: 0 24px;
}

.catalog-category-view .filter-pills,
.catalog-category-view .plp-filter-pills {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  flex: 1;
  padding: 8px 0;
  border: 0;
  margin: 0;
  max-width: none;
}

.catalog-category-view .filter-pills::-webkit-scrollbar {
  display: none;
}

.catalog-category-view .filter-pill,
.catalog-category-view .plp-filter-pill {
  flex-shrink: 0;
  padding: 6px 16px;
  font-size: 11.5px;
  font-weight: 400;
  letter-spacing: 0.06em;
  border: 1px solid var(--demo-border);
  border-radius: 100px;
  color: var(--demo-text-muted);
  background: var(--color-white);
  transition: all .3s var(--demo-ease);
  white-space: nowrap;
}

.catalog-category-view .filter-pill:hover,
.catalog-category-view .filter-pill.active,
.catalog-category-view .plp-filter-pill:hover,
.catalog-category-view .plp-filter-pill.is-active {
  border-color: var(--demo-text-primary);
  background: var(--demo-text-primary);
  color: var(--color-white);
}

.catalog-category-view .columns {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 0;
  max-width: var(--demo-content-max);
  margin: 0 auto;
  padding: 0 24px;
  align-items: start;
}

.catalog-category-view .sidebar-main .plp-sidebar,
.catalog-category-view .sidebar-main .pl-filters {
  padding: 36px 32px 36px 0;
  border-right: 1px solid var(--demo-border);
  position: sticky;
  top: 120px;
}

.catalog-category-view .sidebar-title,
.catalog-category-view .pl-filters-toggle-label {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--demo-text-primary);
}

.catalog-category-view .column.main {
  padding: 36px 0 36px 32px !important;
}

.catalog-category-view #product-list .products-grid > ul {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

/* PDP tabs, size guide, trust */
.catalog-product-view .pdp-tabs .tab-nav {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--demo-border);
}

.catalog-product-view .pdp-tabs .tab-btn {
  padding: 14px 20px;
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--demo-accent-soft);
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  background: none;
  cursor: pointer;
  transition: color .3s var(--demo-ease), border-color .3s var(--demo-ease);
}

.catalog-product-view .pdp-tabs .tab-btn:hover,
.catalog-product-view .pdp-tabs .tab-btn.active {
  color: var(--demo-text-primary);
  border-bottom-color: var(--demo-text-primary);
}

.catalog-product-view .pdp-tabs .tab-content {
  padding: 24px 0;
  font-size: 14px;
  line-height: 1.8;
  color: var(--demo-text-muted);
}

.catalog-product-view .size-guide-link {
  display: inline-block;
  margin: 8px 0 16px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--demo-text-soft);
  border-bottom: 1px solid var(--demo-border);
  padding-bottom: 2px;
  background: none;
  cursor: pointer;
}

.catalog-product-view .size-guide-link:hover {
  color: var(--demo-text-primary);
  border-color: var(--demo-text-primary);
}

.catalog-product-view .size-guide-panel {
  display: none;
  background: var(--demo-bg-secondary);
  border-radius: 4px;
  padding: 24px;
  margin: 8px 0 16px;
  border: 1px solid var(--demo-border);
}

.catalog-product-view .size-guide-panel.open {
  display: block;
}

.catalog-product-view .size-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
}

.catalog-product-view .size-table th {
  text-align: left;
  padding: 8px 12px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--demo-text-soft);
  border-bottom: 1px solid var(--demo-border);
}

.catalog-product-view .size-table td {
  padding: 9px 12px;
  border-bottom: 1px solid var(--demo-border);
  color: var(--demo-text-muted);
}

.catalog-product-view .pdp-trust {
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: var(--demo-bg-secondary);
  padding: 16px;
  border-radius: 4px;
  margin-top: 24px;
  border: 0;
}

.catalog-product-view .pdp-trust .trust-row-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  color: var(--demo-text-muted);
}

.catalog-product-view .cross-sell {
  background: var(--demo-bg-secondary);
  padding: 80px 24px;
  max-width: none;
}

.catalog-product-view .cross-sell-inner {
  max-width: var(--demo-content-max);
  margin: 0 auto;
}

.catalog-product-view .cross-sell .snap-slider h2,
.catalog-product-view .cross-sell .snap-slider h3 {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: clamp(26px, 2.5vw, 36px);
  font-weight: 400;
  margin-bottom: 40px;
}

.catalog-product-view .pdp-reviews-section {
  max-width: var(--demo-content-max);
  margin: 0 auto;
  padding: 0 32px 100px;
}

.catalog-product-view .pdp-reviews-header {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 60px;
  align-items: start;
  padding: 40px 0;
  border-top: 1px solid var(--demo-border);
  margin-bottom: 40px;
}

.catalog-product-view .reviews-score-big {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 80px;
  font-weight: 300;
  line-height: 1;
  color: var(--demo-text-primary);
  margin-bottom: 8px;
}

.catalog-product-view .reviews-score-stars {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-bottom: 8px;
  color: var(--demo-text-soft);
  font-size: 12px;
}

.catalog-product-view .reviews-score-count {
  font-size: 12px;
  color: var(--demo-text-soft);
}

.catalog-product-view .review-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  font-size: 12px;
  color: var(--demo-text-soft);
}

.catalog-product-view .review-bar-label {
  width: 40px;
  text-align: right;
  flex-shrink: 0;
}

.catalog-product-view .review-bar-track {
  flex: 1;
  height: 6px;
  background: var(--demo-border);
  border-radius: 100px;
  overflow: hidden;
}

.catalog-product-view .review-bar-fill {
  height: 100%;
  background: var(--demo-text-primary);
  border-radius: 100px;
}

.catalog-product-view .review-bar-count {
  width: 32px;
  flex-shrink: 0;
}

.catalog-product-view .pdp-reviews-grid #customer-review-list > h2,
.catalog-product-view .pdp-reviews-grid .text-2xl {
  display: none;
}

.catalog-product-view .review-write-prompt {
  text-align: center;
  padding: 48px;
  border: 1px solid var(--demo-border);
  border-radius: 4px;
  margin-top: 40px;
}

.catalog-product-view .review-write-title {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 22px;
  font-weight: 400;
  margin-bottom: 8px;
}

.catalog-product-view .review-write-sub {
  font-size: 13px;
  color: var(--demo-text-soft);
  margin-bottom: 20px;
}

/* Cart drawer */
.pl-cart-drawer,
#cart-drawer.cart-drawer {
  background: var(--demo-bg-primary) !important;
  color: var(--demo-text-primary);
  box-shadow: -8px 0 40px rgba(28, 26, 23, 0.12);
}

.pl-cart-drawer .cart-title,
#cart-drawer .cart-title {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
  font-size: 22px;
  font-weight: 400;
}

.pl-cart-drawer .cart-item-name,
#cart-drawer .cart-item-name {
  font-family: "Cormorant Garamond", var(--font-display), Georgia, serif;
}

.pl-cart-drawer .cart-item-img img,
#cart-drawer .cart-item-img img {
  width: 80px;
  height: 104px;
  object-fit: cover;
  border-radius: 2px;
}

.pl-cart-drawer .cart-checkout-btn,
#cart-drawer .cart-checkout-btn {
  min-height: 52px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-radius: 2px !important;
}

.pl-cart-drawer .cart-continue,
#cart-drawer .cart-continue {
  min-height: 44px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 2px !important;
  background: transparent !important;
  color: var(--demo-text-muted) !important;
  border: 1px solid var(--demo-border) !important;
}

.pl-cart-drawer .cart-shipping-note,
#cart-drawer .cart-shipping-note {
  color: #5a8a6a;
}

.pl-cart-drawer .cart-free-shipping-text,
#cart-drawer .cart-free-shipping-text {
  color: var(--demo-text-muted);
}

@media (max-width: 1100px) {
  .catalog-category-view .columns {
    grid-template-columns: 1fr;
  }

  .catalog-category-view .sidebar-main {
    display: none;
  }

  .catalog-category-view .column.main {
    padding: 24px 0 !important;
  }

  .catalog-category-view #product-list .products-grid > ul {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .catalog-product-view .pdp-reviews-header {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

@media (max-width: 640px) {
  .catalog-category-view #product-list .products-grid > ul {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #cart-drawer.cart-drawer {
    width: 100vw !important;
    max-width: 100vw !important;
  }
}

@media (min-width: 769px) {
  .pl-footer-accordion__item {
    overflow: visible;
  }

  .pl-footer-accordion__item::details-content {
    display: block;
    block-size: auto;
    content-visibility: visible;
    overflow: visible;
  }

  .pl-footer-accordion__item > :not(summary) {
    display: block !important;
  }

  .pl-footer-accordion__item ul {
    display: block !important;
  }

  .pl-footer-accordion__summary {
    padding: 0;
  }

  .pl-footer-accordion__title {
    margin-bottom: 20px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .pl-announcement-track {
    animation: none;
  }

  .cms-index-index .hero-media img {
    transition: none;
    transform: none;
  }
}
