/** Shopify CDN: Minification failed

Line 5051:15 Expected identifier but found whitespace
Line 5051:17 Unexpected "{"
Line 5051:26 Expected ":"

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:cart (INDEX:3) */
.ppp-cart-page {
    padding-block-start: var(--cart-pt, 64px);
    padding-block-end: var(--cart-pb, 80px);
    min-height: 60vh;
  }
  .ppp-cart-page__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }

  /* ── Header ── */
  .ppp-cart-page__header { margin-bottom: 2.5rem; }
  .ppp-cart-page__title {
    font-size: var(--cart-title-size, 32px);
    font-family: var(--cart-heading-font, var(--section-heading-font, inherit));
    font-weight: var(--cart-title-weight, 800);
    letter-spacing: var(--cart-title-ls, -0.02em);
    text-transform: var(--cart-title-transform, none);
    color: var(--cart-title-color, currentColor);
    margin: 0;
    line-height: 1.1;
  }
  .ppp-cart-page__count {
    font-weight: 400;
    opacity: 0.5;
    font-size: 0.75em;
  }

  /* ── Two-column layout ── */
  .ppp-cart-page__layout {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 3rem;
    align-items: start;
  }

  /* ── Shipping bar ── */
  .ppp-cart-page__shipping-bar {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    font-size: 0.875rem;
    font-weight: 600;
    padding: 0.75rem 1rem;
    background: var(--color-surface, #f8f5f0);
    border-radius: var(--radius-lg, 16px);
    margin-bottom: 1.5rem;
    opacity: 0.9;
  }

  /* ── Item list ── */
  .ppp-cart-page__list {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .ppp-cart-page__item {
    display: grid;
    grid-template-columns: var(--cart-img-size, 100px) 1fr;
    gap: 1.25rem;
    padding-block: 1.5rem;
    border-bottom: 1px solid var(--cart-item-border, var(--color-border, #e5e5e5));
    align-items: start;
    transition: opacity 0.2s;
  }
  .ppp-cart-page__list li:first-child { border-top: 1px solid var(--cart-item-border, var(--color-border, #e5e5e5)); }

  .ppp-cart-page__item-img-link { display: block; }
  .ppp-cart-page__item-img {
    width: var(--cart-img-size, 100px);
    height: var(--cart-img-size, 100px);
    object-fit: cover;
    border-radius: var(--cart-img-radius, 12px);
    display: block;
  }
  .ppp-cart-page__item-img-placeholder {
    width: var(--cart-img-size, 100px);
    height: var(--cart-img-size, 100px);
    border-radius: var(--cart-img-radius, 12px);
    background: var(--color-surface, #f5f5f5);
  }

  .ppp-cart-page__item-details {
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
  }
  .ppp-cart-page__item-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
  }
  .ppp-cart-page__item-title {
    font-size: var(--cart-item-title-size, 15px);
    font-family: var(--cart-body-font, inherit);
    font-weight: var(--cart-item-title-weight, 600);
    letter-spacing: var(--cart-item-title-ls, 0em);
    text-transform: var(--cart-item-title-transform, none);
    text-decoration: none;
    color: var(--cart-item-title-color, currentColor);
    line-height: 1.4;
    display: block;
  }
  .ppp-cart-page__item-title:hover { opacity: 0.7; }
  .ppp-cart-page__item-variant {
    font-size: var(--cart-meta-size, 13px);
    opacity: 0.55;
    margin: 0.2rem 0 0;
  }
  .ppp-cart-page__item-price-col { text-align: right; flex-shrink: 0; }
  .ppp-cart-page__item-compare {
    font-size: var(--cart-meta-size, 13px);
    opacity: 0.45;
    text-decoration: line-through;
    display: block;
  }
  .ppp-cart-page__item-price {
    font-size: var(--cart-price-size, 15px);
    font-weight: var(--cart-price-weight, 700);
    color: var(--cart-price-color, currentColor);
    display: block;
  }

  .ppp-cart-page__item-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
  }
  .ppp-cart-page__unit-each {
    font-size: var(--cart-meta-size, 13px);
    opacity: 0.5;
  }
  .ppp-cart-page__item-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
  }
  .ppp-cart-page__remove {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.8rem;
    opacity: 0.4;
    color: currentColor;
    padding: 0;
    -webkit-tap-highlight-color: transparent;
  }
  .ppp-cart-page__remove:hover { opacity: 0.8; }

  /* ── Continue shopping ── */
  .ppp-cart-page__continue { margin-top: 2rem; }
  .ppp-cart-page__continue-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    color: currentColor;
    opacity: 0.6;
  }
  .ppp-cart-page__continue-link:hover { opacity: 1; }

  /* ── Summary panel ── */
  .ppp-cart-page__summary {
    background: var(--cart-summary-bg, var(--color-surface, #f8f5f0));
    border-radius: var(--cart-summary-radius, 16px);
    padding: 2rem;
    border: 1px solid var(--cart-summary-border, transparent);
    position: sticky;
    top: calc(var(--hdr-h, 64px) + 1.5rem);
  }
  .ppp-cart-page__summary-title {
    font-size: var(--cart-summary-title-size, 16px);
    font-weight: var(--cart-summary-title-weight, 700);
    letter-spacing: var(--cart-summary-title-ls, 0em);
    color: var(--cart-summary-text-color, currentColor);
    margin: 0 0 1.25rem;
  }
  .ppp-cart-page__summary-rows {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    margin-bottom: 1.25rem;
  }
  .ppp-cart-page__summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.9rem;
    color: var(--cart-summary-text-color, currentColor);
  }
  .ppp-cart-page__summary-row--discount { color: #28a745; }
  .ppp-cart-page__summary-row--shipping { opacity: 0.55; font-size: 0.8rem; }
  .ppp-cart-page__summary-divider {
    height: 1px;
    background: var(--cart-summary-border, var(--color-border, #e5e5e5));
    margin-bottom: 1.5rem;
  }
  .ppp-cart-page__checkout-note {
    font-size: 0.8rem;
    opacity: 0.6;
    text-align: center;
    margin: 0 0 1rem;
  }
  .ppp-cart-page__checkout-btn { font-size: 1rem; }
  .ppp-cart-page__dynamic-checkout {
    margin-top: 0.875rem;
  }
  .ppp-cart-page__dynamic-checkout .shopify-payment-button { border-radius: var(--btn-radius, 999px) !important; }
  .ppp-cart-page__trust {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    font-size: 0.8rem;
    opacity: 0.55;
    margin: 1rem 0 0;
    text-align: center;
  }

  /* ── Empty state ── */
  .ppp-cart-page__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 5rem 1rem;
    gap: 1.25rem;
    max-width: 400px;
    margin-inline: auto;
  }
  .ppp-cart-page__empty-icon { opacity: 0.2; }
  .ppp-cart-page__empty-title {
    font-size: var(--cart-title-size, 32px);
    font-family: var(--cart-heading-font, var(--section-heading-font, inherit));
    font-weight: var(--cart-title-weight, 800);
    letter-spacing: var(--cart-title-ls, -0.02em);
    margin: 0;
  }
  .ppp-cart-page__empty-text {
    opacity: 0.55;
    font-size: 1rem;
    margin: 0;
  }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-cart-page {
      padding-block-start: var(--cart-mob-pt, 40px);
      padding-block-end: var(--cart-mob-pb, 56px);
    }
    .ppp-cart-page__title { font-size: var(--cart-mob-title-size, 24px); }
    .ppp-cart-page__layout {
      grid-template-columns: 1fr;
      gap: 2rem;
    }
    .ppp-cart-page__summary { position: static; }
    .ppp-cart-page__item {
      grid-template-columns: var(--cart-mob-img-size, 80px) 1fr;
      gap: 1rem;
    }
    .ppp-cart-page__item-img {
      width: var(--cart-mob-img-size, 80px);
      height: var(--cart-mob-img-size, 80px);
    }
    .ppp-cart-page__item-img-placeholder {
      width: var(--cart-mob-img-size, 80px);
      height: var(--cart-mob-img-size, 80px);
    }
    .ppp-cart-page__summary { padding: 1.5rem; border-radius: var(--radius-lg, 16px); }
    .ppp-cart-page__item-title { font-size: var(--cart-mob-item-title-size, var(--cart-item-title-size, 15px)); }
    .ppp-cart-page__item-price { font-size: var(--cart-mob-price-size, var(--cart-price-size, 15px)); }
  }
/* END_SECTION:cart */

/* START_SECTION:collection (INDEX:4) */
.collection-products {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(500px, 1fr));
  }
/* END_SECTION:collection */

/* START_SECTION:collections (INDEX:5) */
.collections {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--collection-card-size), 100%), 1fr));
    gap: var(--grid-gap);
  }
  .collections--compact {
    --collection-card-size: 160px;
  }
  .collections--full {
    --collection-card-size: 280px;
  }
  .collection-card {
    display: flex;
    flex-direction: column;
    width: 100%;
  }
/* END_SECTION:collections */

/* START_SECTION:custom-section (INDEX:6) */
.custom-section {
    position: relative;
    overflow: hidden;
    width: 100%;
  }
  .custom-section__background {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: -1;
    overflow: hidden;
  }
  .custom-section__background img {
    position: absolute;
    width: 100%;
    height: auto;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .custom-section__content {
    display: grid;
    grid-template-columns: var(--content-grid);
  }
  .custom-section__content > * {
    grid-column: 2;
  }
/* END_SECTION:custom-section */

/* START_SECTION:footer (INDEX:7) */
footer {
    display: flex;
    justify-content: space-between;
    margin-top: 2rem;
  }
  footer a {
    text-decoration: none;
    color: var(--color-foreground);
  }
  footer .footer__links,
  footer .footer__payment {
    display: flex;
    gap: 1rem;
  }
/* END_SECTION:footer */

/* START_SECTION:header (INDEX:8) */
/* ── Wrapper / sticky ── */
  .ppp-hdr-wrap {
    position: relative;
    z-index: 200;
    background-color: var(--hdr-bg, #ffffff);
    color: var(--hdr-fg, #111111);
    border-bottom: var(--hdr-border, 0px) solid rgba(0,0,0,0.1);
    transition: background-color 0.3s, color 0.3s, box-shadow 0.3s;
  }
  .ppp-hdr-wrap--sticky-always {
    position: sticky;
    top: 0;
  }
  .ppp-hdr-wrap--sticky-scroll {
    position: sticky;
    top: 0;
  }
  .ppp-hdr-wrap--transparent {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background-color: transparent;
    border-bottom-color: transparent;
  }
  .ppp-hdr-wrap--transparent.ppp-hdr--scrolled {
    position: fixed;
    background-color: var(--hdr-bg, #ffffff);
    box-shadow: 0 2px 16px rgba(0,0,0,0.08);
  }
  .ppp-hdr-wrap--sticky-scroll.ppp-hdr--hidden {
    transform: translateY(-100%);
    transition: transform 0.3s ease, background-color 0.3s, box-shadow 0.3s;
  }
  .ppp-hdr-wrap--sticky-scroll {
    transition: transform 0.3s ease, background-color 0.3s, box-shadow 0.3s;
  }
  .ppp-hdr-wrap.ppp-hdr--scrolled:not(.ppp-hdr-wrap--transparent) {
    box-shadow: 0 2px 16px rgba(0,0,0,0.06);
  }

  /* ── Header rows ── */
  .ppp-hdr__row {
    width: 100%;
  }
  .ppp-hdr__row--bottom {
    border-top: 1px solid rgba(128,128,128,0.15);
  }
  .ppp-hdr__inner {
    max-width: var(--page-width, 1200px);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    height: var(--hdr-h, 64px);
    display: flex;
    align-items: center;
    gap: 1.5rem;
  }
  .ppp-hdr__row--bottom .ppp-hdr__inner {
    height: calc(var(--hdr-h, 64px) * 0.65);
  }

  /* ── Logo ── */
  .ppp-hdr__logo { flex-shrink: 0; }
  .ppp-hdr__logo--center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }
  .ppp-hdr__logo-link {
    display: flex;
    align-items: center;
    text-decoration: none;
    color: currentColor;
  }
  .ppp-hdr__logo-img {
    max-width: var(--hdr-logo-w, 140px);
    height: auto;
    display: block;
  }
  .ppp-hdr__logo-text {
    font-weight: var(--hdr-logo-text-fw, 800);
    font-size: var(--hdr-logo-text-size, 19px);
    letter-spacing: var(--hdr-logo-text-ls, -0.02em);
    white-space: nowrap;
  }

  /* ── Desktop nav ── */
  .ppp-hdr__nav--desktop { flex: 1; }
  .ppp-hdr__nav--full { flex: 1; justify-content: center; }
  .ppp-hdr__nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    flex-wrap: wrap;
  }
  .ppp-hdr__nav-item { position: relative; }
  .ppp-hdr__nav-link {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.5rem 0.75rem;
    font-family: var(--font-nav--family, var(--font-body--family));
    font-size: var(--hdr-font-size, 14px);
    font-weight: var(--hdr-nav-fw, 600);
    letter-spacing: var(--hdr-nav-ls, 0em);
    text-transform: var(--hdr-nav-transform, none);
    text-decoration: none;
    color: var(--hdr-nav-color, currentColor);
    border-radius: 6px;
    transition: background 0.15s, color 0.15s, opacity 0.15s;
    white-space: nowrap;
  }
  .ppp-hdr__nav-link:hover { background: rgba(128,128,128,0.1); color: var(--hdr-nav-hover, var(--hdr-nav-color, currentColor)); }
  .ppp-hdr__nav-link--active { opacity: var(--hdr-nav-active-opacity, 0.6); color: var(--hdr-nav-active-color, var(--hdr-nav-color, currentColor)); }

  /* ── Dropdowns ── */
  .ppp-hdr__drop {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    min-width: 180px;
    background: var(--hdr-bg, #ffffff);
    color: var(--hdr-fg, #111111);
    border-radius: 10px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.12);
    list-style: none;
    margin: 0;
    padding: 0.5rem;
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px);
    transition: opacity 0.15s, transform 0.15s;
    z-index: 10;
    border: 1px solid rgba(0,0,0,0.07);
  }
  .ppp-hdr__nav-item--has-drop:hover .ppp-hdr__drop,
  .ppp-hdr__nav-item--has-drop:focus-within .ppp-hdr__drop {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
  .ppp-hdr__drop-link {
    display: block;
    padding: 0.5rem 0.75rem;
    font-size: 0.85rem;
    font-weight: 500;
    text-decoration: none;
    color: currentColor;
    border-radius: 6px;
    transition: background 0.12s;
    white-space: nowrap;
  }
  .ppp-hdr__drop-link:hover { background: rgba(128,128,128,0.1); }

  /* ── Actions ── */
  .ppp-hdr__actions {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    margin-left: auto;
    flex-shrink: 0;
  }
  .ppp-hdr__action {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    border: none;
    background: transparent;
    color: currentColor;
    cursor: pointer;
    text-decoration: none;
    position: relative;
    transition: background 0.15s;
  }
  .ppp-hdr__action:hover { background: rgba(128,128,128,0.1); }
  .ppp-hdr__cart-count {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background: var(--hdr-cart-count-bg, var(--hdr-fg, #111111));
    color: var(--hdr-cart-count-color, var(--hdr-bg, #ffffff));
    border-radius: 999px;
    font-size: 0.625rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
  }
  .ppp-hdr__hamburger { display: none; }

  /* ── Search bar ── */
  .ppp-hdr__search-bar {
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.3s ease;
    border-top: 0px solid rgba(128,128,128,0.15);
    background: var(--hdr-bg, #ffffff);
  }
  .ppp-hdr__search-bar.ppp-hdr__search-bar--open {
    max-height: 80px;
    border-top-width: 1px;
  }
  .ppp-hdr__search-bar .ppp-hdr__inner { height: auto; padding-block: 0.75rem; }
  .ppp-hdr__search-form {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    border: 1px solid rgba(128,128,128,0.3);
    border-radius: 8px;
    overflow: hidden;
    padding: 0 0.75rem;
    background: rgba(128,128,128,0.05);
  }
  .ppp-hdr__search-input {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 0.95rem;
    font-family: inherit;
    color: currentColor;
    padding: 0.625rem 0;
    outline: none;
  }
  .ppp-hdr__search-input::placeholder { opacity: 0.5; }
  .ppp-hdr__search-submit, .ppp-hdr__search-close {
    border: none;
    background: transparent;
    cursor: pointer;
    color: currentColor;
    display: flex;
    align-items: center;
    padding: 0.25rem;
    opacity: 0.6;
    transition: opacity 0.15s;
    flex-shrink: 0;
  }
  .ppp-hdr__search-submit:hover, .ppp-hdr__search-close:hover { opacity: 1; }

  /* ── Mobile overlay ── */
  .ppp-hdr__overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 300;
    opacity: 0;
    transition: opacity 0.3s;
  }
  .ppp-hdr__overlay.ppp-hdr__overlay--open {
    display: block;
    opacity: 1;
  }

  /* ── Mobile drawer ── */
  .ppp-hdr__drawer {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(320px, 85vw);
    background: var(--hdr-bg, #ffffff);
    color: var(--hdr-fg, #111111);
    z-index: 400;
    display: flex;
    flex-direction: column;
    transform: translateX(-100%);
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    overflow-y: auto;
    overscroll-behavior: contain;
  }
  .ppp-hdr__drawer.ppp-hdr__drawer--open { transform: translateX(0); }
  .ppp-hdr__drawer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid rgba(128,128,128,0.15);
    flex-shrink: 0;
  }
  .ppp-hdr__drawer-logo { text-decoration: none; color: currentColor; }
  .ppp-hdr__drawer-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: none;
    background: transparent;
    cursor: pointer;
    color: currentColor;
    border-radius: 8px;
    transition: background 0.15s;
    flex-shrink: 0;
  }
  .ppp-hdr__drawer-close:hover { background: rgba(128,128,128,0.1); }
  .ppp-hdr__drawer-list { list-style: none; margin: 0; padding: 0.75rem 0; flex: 1; }
  .ppp-hdr__drawer-item { border-bottom: 1px solid rgba(128,128,128,0.08); }
  .ppp-hdr__drawer-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0.875rem 1.25rem;
    font-size: var(--hdr-drawer-fs, 16px);
    font-weight: var(--hdr-nav-fw, 600);
    letter-spacing: var(--hdr-nav-ls, 0em);
    text-transform: var(--hdr-nav-transform, none);
    text-decoration: none;
    color: currentColor;
    background: transparent;
    border: none;
    cursor: pointer;
    font-family: var(--font-nav--family, var(--font-body--family));
    text-align: left;
    transition: background 0.12s;
  }
  .ppp-hdr__drawer-link:hover { background: rgba(128,128,128,0.07); }
  .ppp-hdr__drawer-link--active { opacity: 0.5; }
  .ppp-hdr__drawer-chevron { transition: transform 0.25s; flex-shrink: 0; }
  .ppp-hdr__drawer-toggle[aria-expanded="true"] .ppp-hdr__drawer-chevron { transform: rotate(180deg); }
  .ppp-hdr__drawer-sub {
    list-style: none;
    margin: 0;
    padding: 0 0 0.5rem;
    display: none;
  }
  .ppp-hdr__drawer-sub.ppp-hdr__drawer-sub--open { display: block; }
  .ppp-hdr__drawer-sublink {
    display: block;
    padding: 0.625rem 1.25rem 0.625rem 2rem;
    font-size: 0.9rem;
    font-weight: 500;
    text-decoration: none;
    color: currentColor;
    opacity: 0.75;
    transition: opacity 0.12s;
  }
  .ppp-hdr__drawer-sublink:hover { opacity: 1; }
  .ppp-hdr__drawer-search {
    padding: 0.75rem 1.25rem;
    border-top: 1px solid rgba(128,128,128,0.1);
  }
  .ppp-hdr__drawer-search form {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid rgba(128,128,128,0.25);
    border-radius: 8px;
    padding: 0 0.75rem;
    background: rgba(128,128,128,0.05);
  }
  .ppp-hdr__drawer-search-input {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 0.9rem;
    font-family: inherit;
    color: currentColor;
    padding: 0.625rem 0;
    outline: none;
  }
  .ppp-hdr__drawer-search-input::placeholder { opacity: 0.5; }
  .ppp-hdr__drawer-search-btn {
    border: none;
    background: transparent;
    cursor: pointer;
    color: currentColor;
    display: flex;
    align-items: center;
    opacity: 0.6;
    flex-shrink: 0;
  }
  .ppp-hdr__drawer-footer {
    padding: 1rem 1.25rem;
    border-top: 1px solid rgba(128,128,128,0.12);
    display: flex;
    gap: 0.5rem;
    flex-direction: column;
    flex-shrink: 0;
  }
  .ppp-hdr__drawer-account {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    color: currentColor;
    padding: 0.5rem 0;
    opacity: 0.7;
    transition: opacity 0.15s;
  }
  .ppp-hdr__drawer-account:hover { opacity: 1; }

  /* ── Mobile overrides ── */
  @media (max-width: 749px) {
    .ppp-hdr-wrap {
      background-color: var(--hdr-mob-bg, var(--hdr-bg, #ffffff));
      color: var(--hdr-mob-fg, var(--hdr-fg, #111111));
    }
    .ppp-hdr__inner {
      height: var(--hdr-mob-h, 56px);
    }
    .ppp-hdr__logo-img { max-width: var(--hdr-mob-logo-w, 100px); }
    .ppp-hdr__logo--center { position: static; transform: none; }
    .ppp-hdr__nav--desktop { display: none; }
    .ppp-hdr__hamburger { display: flex; }
    .ppp-hdr__row--bottom { display: none; }
    .ppp-hdr__cart-count { top: 2px; right: 2px; }
  }
/* END_SECTION:header */

/* START_SECTION:hello-world (INDEX:9) */
.welcome {
    display: grid;
    grid-template-columns: var(--content-grid);
    background-color: #f6f6f7;
    padding: 72px 0;
  }

  .welcome-content {
    grid-column: 2;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    width: 100%;
    padding: 0 24px;
  }

  .welcome-description {
    max-width: 80ch;
    line-height: 1.4;
    margin-top: 1.5rem;
  }

  .icon {
    width: 300px;
  }

  .highlights {
    display: grid;
    gap: 2rem;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 50px;
  }

  @media (max-width: 1100px) {
    .highlights {
      grid-template-columns: 1fr;
    }
  }

  .highlight {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 24px;
    border-radius: 8px;
    background-color: #eef3ff;
    color: rgb(92, 95, 98);
    line-height: 1.4;
  }

  .highlight > * + * {
    margin-top: 1rem;
  }

  .highlight h3 {
    font-size: 1rem;
    color: rgb(32, 34, 35);
  }

  .highlight-description {
    flex: 1 1;
  }

  .highlight a {
    display: flex;
    width: fit-content;
    background-color: rgb(250, 251, 251);
    box-shadow: rgba(0, 0, 0, 0.2) 0px -3px 0px 0px inset, rgba(255, 255, 255, 0.9) 0px 2px 0px 0px inset;
    border: 1px solid rgb(140, 145, 150);
    border-radius: 4px;
    color: rgb(92, 95, 98);
    padding: 3px 10px 5px;
    text-decoration: none;
  }
/* END_SECTION:hello-world */

/* START_SECTION:home-esspo-product-hero (INDEX:10) */
/* ── Home product grid hero ── */
  .heph {
    padding-block-start: var(--heph-pt, 0px);
    padding-block-end: var(--heph-pb, 24px);
  }
  .heph__header {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    text-align: center;
    padding-block-end: 2.5rem;
  }
  .heph__heading {
    font-size: clamp(1.75rem, 3.5vw, 2.75rem);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--section-heading-weight, 800);
    letter-spacing: var(--section-heading-ls, -0.02em);
    text-transform: var(--section-heading-transform, none);
    line-height: 1.1;
    margin: 0;
    text-wrap: balance;
  }

  /* Desktop: constrained grid */
  .heph__track-wrap {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .heph__track {
    display: grid;
    grid-template-columns: repeat(var(--heph-cols, 4), 1fr);
    gap: var(--heph-gap, 2px);
  }

  /* Card */
  .heph__card {
    display: flex;
    flex-direction: column;
    border-radius: var(--heph-radius, 0px);
    overflow: hidden;
  }
  .heph__card-media {
    display: block;
    aspect-ratio: var(--heph-img-ratio, 3/4);
    overflow: hidden;
    position: relative;
    background: rgba(128,128,128,0.07);
  }
  .heph__card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.5s ease;
  }
  .heph__card:hover .heph__card-img { transform: scale(1.04); }

  .heph__card-placeholder {
    width: 100%;
    height: 100%;
    min-height: 260px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    font-weight: 900;
    opacity: 0.15;
  }
  .heph__badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    background: #111;
    color: #fff;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 0.3rem 0.625rem;
    border-radius: 999px;
    pointer-events: none;
    z-index: 1;
  }

  /* Card body: title + price left, CTA right */
  .heph__card-body {
    padding: 0.875rem 0 1rem;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
  }
  .heph__card-info {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
    min-width: 0;
  }
  .heph__card-title {
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.3;
    margin: 0;
    color: currentColor;
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 14ch;
  }
  .heph__card-title:hover { text-decoration: underline; }
  .heph__card-price {
    font-size: 0.8rem;
    font-weight: 500;
    margin: 0;
    opacity: 0.65;
  }
  .heph__card-cta {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0.5rem 1.125rem;
    background: var(--heph-btn-bg, #111111);
    color: var(--heph-btn-fg, #ffffff);
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
    transition: opacity 0.2s;
  }
  .heph__card-cta:hover { opacity: 0.78; }

  /* Mobile: horizontal scroll carousel */
  @media (max-width: 749px) {
    .heph {
      padding-block-start: var(--heph-mob-pt, 0px);
      padding-block-end: var(--heph-mob-pb, 16px);
    }
    .heph__track-wrap {
      padding-inline: 0;
      overflow-x: auto;
      overflow-y: hidden;
      scroll-snap-type: x mandatory;
      scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
    }
    .heph__track-wrap::-webkit-scrollbar { display: none; }
    .heph__track {
      display: flex;
      flex-wrap: nowrap;
      gap: 0.75rem;
      padding: 0 var(--page-margin, 1.5rem) 0.25rem;
      width: max-content;
    }
    .heph__card {
      flex: 0 0 var(--heph-mob-card-w, 82vw);
      scroll-snap-align: start;
    }
    .heph__card-title { max-width: none; }
    .heph__card-body { padding: 0.75rem 0 0.875rem; }
    .heph__card-cta { font-size: 0.75rem; padding: 0.5rem 0.875rem; }
  }
/* END_SECTION:home-esspo-product-hero */

/* START_SECTION:page (INDEX:11) */
.ppp-page {
    padding-block: var(--pg-pt, 64px) var(--pg-pb, 80px);
    min-height: calc(100vh - var(--hdr-h, 64px));
  }
  .ppp-page__inner {
    max-width: var(--pg-max-width, 720px);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }

  /* ── Page title ── */
  .ppp-page__title {
    font-family: var(--pg-heading-font, var(--section-heading-font, inherit));
    font-size: var(--pg-title-size, 40px);
    font-weight: var(--pg-title-weight, 800);
    letter-spacing: var(--pg-title-ls, -0.02em);
    line-height: var(--pg-title-lh, 1.15);
    text-transform: var(--pg-title-transform, none);
    text-align: var(--pg-title-align, left);
    color: var(--pg-title-color, currentColor);
    margin: 0 0 2rem;
  }

  /* ── Body content (rich text) ── */
  .ppp-page__content {
    font-family: var(--pg-body-font, inherit);
    font-size: var(--pg-body-size, 16px);
    font-weight: var(--pg-body-weight, 400);
    line-height: var(--pg-body-lh, 1.75);
    letter-spacing: var(--pg-body-ls, 0em);
    text-align: var(--pg-body-align, left);
    color: currentColor;
  }
  .ppp-page__content h2 {
    font-family: var(--pg-heading-font, inherit);
    font-size: var(--pg-h2-size, 24px);
    font-weight: var(--pg-title-weight, 800);
    letter-spacing: var(--pg-title-ls, -0.02em);
    line-height: 1.3;
    margin: 2rem 0 0.75rem;
    color: var(--pg-title-color, currentColor);
  }
  .ppp-page__content h3 {
    font-family: var(--pg-heading-font, inherit);
    font-size: var(--pg-h3-size, 20px);
    font-weight: var(--pg-title-weight, 700);
    line-height: 1.4;
    margin: 1.75rem 0 0.625rem;
    color: var(--pg-title-color, currentColor);
  }
  .ppp-page__content h4,
  .ppp-page__content h5,
  .ppp-page__content h6 {
    font-family: var(--pg-heading-font, inherit);
    font-weight: 700;
    line-height: 1.4;
    margin: 1.5rem 0 0.5rem;
    color: var(--pg-title-color, currentColor);
  }
  .ppp-page__content p {
    margin: 0 0 1.25em;
  }
  .ppp-page__content p:last-child { margin-bottom: 0; }
  .ppp-page__content a {
    color: var(--pg-link-color, currentColor);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: opacity 0.15s;
  }
  .ppp-page__content a:hover { opacity: 0.7; }
  .ppp-page__content ul,
  .ppp-page__content ol {
    padding-left: 1.5em;
    margin: 0 0 1.25em;
    display: flex;
    flex-direction: column;
    gap: 0.375em;
  }
  .ppp-page__content ul { list-style: disc; }
  .ppp-page__content ol { list-style: decimal; }
  .ppp-page__content li > ul,
  .ppp-page__content li > ol {
    margin-top: 0.375em;
    margin-bottom: 0;
  }
  .ppp-page__content strong { font-weight: 700; }
  .ppp-page__content em { font-style: italic; }
  .ppp-page__content blockquote {
    border-left: 3px solid currentColor;
    margin: 1.5em 0;
    padding-left: 1.25em;
    opacity: 0.75;
    font-style: italic;
  }
  .ppp-page__content hr {
    border: none;
    border-top: 1px solid currentColor;
    opacity: 0.15;
    margin: 2em 0;
  }
  .ppp-page__content table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.925em;
    margin-bottom: 1.5em;
  }
  .ppp-page__content th,
  .ppp-page__content td {
    padding: 0.625em 0.875em;
    border: 1px solid currentColor;
    opacity: 0.8;
    text-align: left;
  }
  .ppp-page__content th { font-weight: 700; opacity: 1; }
  .ppp-page__content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-md, 8px);
    margin: 0.5em 0;
  }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-page { padding-block: var(--pg-mob-pt, 40px) var(--pg-mob-pb, 56px); }
    .ppp-page__title { font-size: var(--pg-mob-title-size, 28px); }
    .ppp-page__content { font-size: var(--pg-mob-body-size, 15px); }
  }
/* END_SECTION:page */

/* START_SECTION:ppp-announcement-bar (INDEX:13) */
.ppp-announcement {
    background-color: var(--color-primary);
    color: #fff;
    overflow: hidden;
  }
  .ppp-announcement__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    padding-block: var(--ann-py, 10px);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    position: relative;
  }
  .ppp-announcement__text {
    font-family: var(--ann-font, inherit);
    font-size: var(--ann-fs, 13px);
    font-weight: var(--ann-fw, 500);
    letter-spacing: var(--ann-ls, 0.02em);
    text-transform: var(--ann-transform, none);
    text-align: center;
    text-decoration: none;
    color: currentColor;
    margin: 0;
    flex: 1;
  }
  a.ppp-announcement__text:hover { text-decoration: underline; }
  .ppp-announcement__close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: transparent;
    border: none;
    cursor: pointer;
    color: currentColor;
    opacity: 0.7;
    transition: opacity 0.15s;
    border-radius: 4px;
    flex-shrink: 0;
  }
  .ppp-announcement__close:hover { opacity: 1; }

  @media (max-width: 749px) {
    .ppp-announcement__inner { padding-block: var(--ann-mob-py, var(--ann-py, 8px)); }
    .ppp-announcement__text {
      font-size: var(--ann-mob-fs, var(--ann-fs, 12px));
      font-weight: var(--ann-mob-fw, var(--ann-fw, 500));
      letter-spacing: var(--ann-mob-ls, var(--ann-ls, 0.02em));
      text-transform: var(--ann-mob-transform, var(--ann-transform, none));
    }
  }
/* END_SECTION:ppp-announcement-bar */

/* START_SECTION:ppp-cart-drawer (INDEX:14) */
.ppp-cart-drawer {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(420px, 100vw);
    background: var(--color-bg);
    color: var(--color-text);
    z-index: var(--z-drawer, 400);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.4s var(--ease-out, cubic-bezier(0.16,1,0.3,1));
    box-shadow: -8px 0 40px rgba(0,0,0,0.12);
    overscroll-behavior: contain;
  }
  .ppp-cart-drawer--open { transform: translateX(0); }

  /* Head */
  .ppp-cart-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--color-border, #e5e5e5);
    flex-shrink: 0;
  }
  .ppp-cart-drawer__title {
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  .ppp-cart-drawer__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 5px;
    background: var(--color-primary, #111);
    color: #fff;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 700;
  }
  .ppp-cart-drawer__close {
    color: var(--color-text);
    border-color: transparent;
  }

  /* Shipping bar */
  .ppp-cart-drawer__ship-bar {
    padding: 0.75rem 1.5rem;
    background: var(--color-surface, #f8f5f0);
    border-bottom: 1px solid var(--color-border, #e5e5e5);
    flex-shrink: 0;
  }
  .ppp-cart-drawer__ship-msg {
    font-size: 0.8rem;
    margin-bottom: 0.5rem;
    text-align: center;
  }
  .ppp-cart-drawer__ship-msg--reached { color: #2a7a4b; font-weight: 600; }
  .ppp-cart-drawer__ship-track {
    height: 4px;
    background: var(--color-border, #e5e5e5);
    border-radius: 999px;
    overflow: hidden;
  }
  .ppp-cart-drawer__ship-fill {
    height: 100%;
    background: var(--color-primary, #111);
    border-radius: 999px;
    transition: width 0.4s var(--ease-out);
    max-width: 100%;
  }

  /* Body */
  .ppp-cart-drawer__body {
    flex: 1;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
  }

  /* Empty state */
  .ppp-cart-drawer__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    height: 100%;
    padding: 3rem 1.5rem;
    text-align: center;
    opacity: 0.6;
  }
  .ppp-cart-drawer__empty p { font-size: 1rem; font-weight: 500; }
  .ppp-cart-drawer__empty .ppp-btn { opacity: 1; }

  /* Items */
  .ppp-cart-drawer__items {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .ppp-cart-drawer__item {
    display: grid;
    grid-template-columns: 80px 1fr 32px;
    gap: 1rem;
    align-items: start;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--color-border, #e5e5e5);
    transition: opacity 0.2s;
  }
  .ppp-cart-drawer__item-img-link { display: block; border-radius: var(--radius-md, 8px); overflow: hidden; }
  .ppp-cart-drawer__item-img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    display: block;
  }
  .ppp-cart-drawer__item-img--placeholder {
    background: var(--color-surface, #f8f5f0);
  }
  .ppp-cart-drawer__item-info { display: flex; flex-direction: column; gap: 0.3rem; }
  .ppp-cart-drawer__item-title {
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.3;
    text-decoration: none;
    color: currentColor;
  }
  .ppp-cart-drawer__item-title:hover { text-decoration: underline; }
  .ppp-cart-drawer__item-variant { font-size: 0.775rem; opacity: 0.55; }
  .ppp-cart-drawer__item-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 0.5rem;
  }
  .ppp-cart-drawer__item-price { font-size: 0.875rem; font-weight: 700; }
  .ppp-cart-drawer__item-qty { font-size: 0.85rem; font-weight: 600; min-width: 24px; text-align: center; }
  .ppp-cart-drawer__item-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--color-muted, #666);
    border-radius: 4px;
    transition: color 0.15s, background 0.15s;
    margin-top: 0.25rem;
  }
  .ppp-cart-drawer__item-remove:hover { color: var(--color-text); background: rgba(0,0,0,0.06); }

  /* Qty small variant */
  .ppp-qty--sm { height: 34px; }
  .ppp-qty--sm .ppp-qty__btn { width: 32px; font-size: 1rem; }
  .ppp-qty--sm .ppp-qty__input { width: 32px; font-size: 0.85rem; }

  /* Footer */
  .ppp-cart-drawer__footer {
    padding: 1.25rem 1.5rem;
    border-top: 1px solid var(--color-border, #e5e5e5);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    flex-shrink: 0;
    background: var(--color-bg);
  }
  .ppp-cart-drawer__note-wrap { font-size: 0.85rem; cursor: pointer; }
  .ppp-cart-drawer__note-wrap summary { padding: 0.25rem 0; font-weight: 500; }
  .ppp-cart-drawer__note { margin-top: 0.5rem; resize: none; }
  .ppp-cart-drawer__subtotal {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.95rem;
  }
  .ppp-cart-drawer__subtotal-amount { font-size: 1.1rem; font-weight: 700; }
  .ppp-cart-drawer__tax-note { font-size: 0.75rem; opacity: 0.5; text-align: center; }
  .ppp-cart-drawer__checkout { text-align: center; }
  .ppp-cart-drawer__continue { opacity: 0.55; font-size: 0.85rem; }
  .ppp-cart-drawer__continue:hover { opacity: 0.8; transform: none; }
/* END_SECTION:ppp-cart-drawer */

/* START_SECTION:ppp-collection-main (INDEX:15) */
.ppp-collection {
    padding-block-start: var(--coll-pt, 0px);
    padding-block-end: var(--coll-pb, 80px);
  }

  /* Hero */
  .ppp-collection__hero {
    position: relative;
    overflow: hidden;
    min-height: 260px;
    display: flex;
    align-items: stretch;
  }
  .ppp-collection__hero-inner {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 3.5rem var(--page-margin, 1.5rem);
  }
  .ppp-collection__hero-img-wrap {
    position: absolute;
    inset: 0;
  }
  .ppp-collection__hero-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .ppp-collection__hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
  }
  .ppp-collection__hero-content {
    position: relative;
    z-index: 1;
    max-width: 560px;
  }
  .ppp-collection__hero-title {
    font-size: clamp(1.75rem, 4vw, 3rem);
    font-weight: var(--font-heading--weight, 800);
    line-height: 1.05;
    letter-spacing: var(--font-heading--letter-spacing, -0.02em);
    margin-bottom: 0.75rem;
  }
  .ppp-collection__hero-desc {
    font-size: 1rem;
    opacity: 0.8;
    max-width: 440px;
    margin-inline: auto;
    margin-bottom: 0.5rem;
    line-height: 1.6;
  }
  .ppp-collection__hero-count {
    font-size: 0.8rem;
    opacity: 0.55;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0;
  }

  /* Body */
  .ppp-collection__body {
    padding-block-start: 2rem;
  }
  .ppp-collection__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }

  /* Toolbar */
  .ppp-collection__toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--color-border, #e5e5e5);
  }
  .ppp-collection__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  .ppp-collection__filter-tag {
    transition: background 0.2s, color 0.2s, border-color 0.2s;
  }
  .ppp-collection__filter-tag--active {
    background-color: var(--color-primary, #1a0f0a);
    color: #fff;
    border-color: var(--color-primary, #1a0f0a);
  }
  .ppp-collection__sort {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
  }
  .ppp-select--sm {
    font-size: 0.85rem;
    padding: 0.35rem 0.75rem;
  }

  /* Grid */
  .ppp-collection__grid {
    display: grid;
    grid-template-columns: repeat(var(--col-dt, 4), 1fr);
    gap: 1.5rem;
  }
  .ppp-collection__empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 4rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
  }

  /* Cards */
  .ppp-collection__card {
    display: flex;
    flex-direction: column;
    background: var(--color-bg, #fff);
    border-radius: var(--radius-lg, 16px);
    overflow: hidden;
    transition: box-shadow 0.3s var(--ease-out), transform 0.3s var(--ease-out);
  }
  .ppp-collection__card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-3px);
  }
  .ppp-collection__card-media-link { display: block; }
  .ppp-collection__card-img-wrap {
    position: relative;
    aspect-ratio: 1/1;
    overflow: hidden;
    background: var(--color-surface, #f8f5f0);
  }
  .ppp-collection__card-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.4s var(--ease-out), transform 0.5s var(--ease-out);
    display: block;
  }
  .ppp-collection__card-img--hover {
    opacity: 0;
  }
  .ppp-collection__card:hover .ppp-collection__card-img:not(.ppp-collection__card-img--hover) {
    opacity: 0;
    transform: scale(1.04);
  }
  .ppp-collection__card:hover .ppp-collection__card-img--hover {
    opacity: 1;
  }

  /* Hover video */
  .ppp-collection__card-hover-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    opacity: 0;
    transition: opacity 0.4s var(--ease-out, ease);
    pointer-events: none;
  }
  /* Desktop: JS class controls visibility */
  .ppp-collection__card--video-active .ppp-collection__card-hover-video {
    opacity: 1;
  }
  .ppp-collection__card--video-active .ppp-collection__card-img {
    opacity: 0;
    transform: scale(1.04);
  }
  /* Mobile: video is always visible — JS only needs to play/pause */
  @media (hover: none) {
    .ppp-collection__card-hover-video {
      opacity: 1;
    }
  }
  .ppp-collection__card-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    font-weight: 900;
    opacity: 0.08;
  }
  .ppp-collection__card-badge {
    position: absolute;
    top: 0.625rem;
    left: 0.625rem;
    background: var(--color-primary, #1a0f0a);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    line-height: 1.4;
  }
  .ppp-collection__card-badge--sale {
    background: #c0392b;
  }
  .ppp-collection__card-badge--sold-out {
    background: #888;
  }
  .ppp-collection__card-info {
    padding: 0.875rem 1rem 1.125rem;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    flex: 1;
  }
  .ppp-collection__card-subtitle {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    opacity: 0.5;
    font-weight: 600;
    margin: 0;
  }
  .ppp-collection__card-title {
    font-size: 0.9rem;
    font-weight: 700;
    text-decoration: none;
    color: currentColor;
    line-height: 1.3;
  }
  .ppp-collection__card-title:hover { text-decoration: underline; }
  .ppp-collection__card-price-row {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    margin-top: 0.1rem;
  }
  .ppp-collection__card-price {
    font-size: 0.875rem;
    font-weight: 700;
  }
  .ppp-collection__card-compare {
    font-size: 0.8rem;
    opacity: 0.45;
    text-decoration: line-through;
  }
  .ppp-collection__card-atc {
    margin-top: auto;
    padding-top: 0.625rem;
  }

  /* Pagination */
  .ppp-collection__pagination {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--color-border, #e5e5e5);
  }
  .ppp-collection__pagination-info {
    font-size: 0.875rem;
    opacity: 0.6;
  }

  @media (max-width: 749px) {
    .ppp-collection {
      padding-block-start: var(--coll-mob-pt, 0px);
      padding-block-end: var(--coll-mob-pb, 48px);
    }
    .ppp-collection__hero { min-height: 200px; }
    .ppp-collection__hero-inner { padding: 2.5rem var(--page-margin, 1rem); }
    .ppp-collection__grid {
      grid-template-columns: repeat(var(--col-mob, 2), 1fr);
      gap: 0.875rem;
    }
    .ppp-collection__toolbar { flex-direction: column; align-items: flex-start; }
    .ppp-collection__card-info { padding: 0.625rem 0.75rem 0.875rem; }
  }
/* END_SECTION:ppp-collection-main */

/* START_SECTION:ppp-company-usps (INDEX:16) */
.ppp-usps {
    padding-block-start: var(--ppp-usps-pt, 48px);
    padding-block-end: var(--ppp-usps-pb, 48px);
  }
  .ppp-usps__wrap {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-usps__heading {
    text-align: center;
    margin-bottom: 2rem;
    font-family: var(--section-heading-font, inherit);
    font-size: var(--usps-heading-size, 1.5rem);
    font-weight: var(--section-heading-weight, 700);
    letter-spacing: var(--section-heading-ls, -0.01em);
    text-transform: var(--section-heading-transform, none);
  }
  .ppp-usps__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 2rem 1.5rem;
    text-align: center;
  }
  .ppp-usps__item { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; }
  .ppp-usps__icon { opacity: 0.85; }
  .ppp-usps__title {
    font-family: var(--usps-title-font, var(--font-body--family));
    font-size: var(--usps-title-size, 0.9rem);
    font-weight: var(--usps-title-weight, 600);
    margin: 0;
  }
  .ppp-usps__description {
    font-family: var(--usps-desc-font, var(--font-body--family));
    font-size: var(--usps-desc-size, 0.825rem);
    opacity: 0.7;
    margin: 0;
    line-height: 1.4;
  }
  @media (max-width: 749px) {
    .ppp-usps {
      padding-block-start: var(--ppp-usps-mob-pt, 32px);
      padding-block-end: var(--ppp-usps-mob-pb, 32px);
    }
    .ppp-usps__heading { font-size: var(--usps-mob-heading-size, 1.25rem); }
    .ppp-usps__title { font-size: var(--usps-mob-title-size, 0.875rem); }
    .ppp-usps__description { font-size: var(--usps-mob-desc-size, 0.8rem); }
  }
/* END_SECTION:ppp-company-usps */

/* START_SECTION:ppp-comparison-table (INDEX:17) */
.ppp-ct {
    padding-block-start: var(--ppp-ct-pt, 72px);
    padding-block-end: var(--ppp-ct-pb, 72px);
  }
  .ppp-ct__wrap {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-ct__wrapper {
    display: grid;
    grid-template-columns: minmax(180px, 260px) 1fr;
    gap: 3rem;
    align-items: center;
  }
  .ppp-ct__left {
    display: flex;
    flex-direction: column;
    gap: 1.125rem;
    align-items: flex-start;
  }
  .ppp-ct__eyebrow {
    font-size: var(--ct-eyebrow-size, 13px);
    letter-spacing: var(--ct-eyebrow-ls, 0.1em);
    text-transform: uppercase;
    color: var(--ct-eyebrow-color, currentColor);
    margin: 0;
  }
  .ppp-ct__heading {
    font-size: var(--ct-heading-size, 2.4rem);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--section-heading-weight, 800);
    line-height: 1.1;
    letter-spacing: var(--section-heading-ls, -0.02em);
    text-transform: var(--section-heading-transform, uppercase);
    margin: 0;
  }
  .ppp-ct__subheading { font-family: var(--font-subheading--family, var(--font-body--family)); font-size: var(--ct-sub-size, 15px); letter-spacing: var(--ct-sub-ls, 0em); color: var(--ct-sub-color, currentColor); line-height: 1.55; margin: 0; }
  .ppp-ct__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.875rem 2rem;
    background: var(--ct-cta-bg, #2D1208);
    color: var(--ct-cta-text, #ffffff);
    border-radius: 999px;
    font-family: var(--ct-cta-font, inherit);
    font-weight: 700;
    font-size: var(--ct-cta-size, 15px);
    letter-spacing: var(--ct-cta-ls, 0em);
    text-transform: var(--ct-cta-transform, none);
    text-decoration: none;
    cursor: pointer;
    transition: opacity 0.2s;
    margin-top: 0.5rem;
  }
  .ppp-ct__cta:hover { opacity: 0.85; }
  .ppp-ct__table-scroll { overflow-x: auto; }
  .ppp-ct__table { display: flex; flex-direction: column; gap: var(--ct-row-gap, 0); min-width: 380px; }
  .ppp-ct__row { display: flex; align-items: stretch; gap: 8px; }
  .ppp-ct__our-header {
    flex: 1 1 0;
    min-width: 90px;
    background: var(--ppp-ct-us-bg, #2D1208);
    color: var(--ct-our-text, #fff);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: 0.625rem;
    padding: 1.25rem 0.75rem 1rem;
    border-radius: 14px 14px 0 0;
    text-align: center;
  }
  .ppp-ct__col-img-wrap { display: flex; align-items: center; justify-content: center; }
  .ppp-ct__our-header .ppp-ct__col-img-wrap { height: var(--ct-our-img-h, 90px); }
  .ppp-ct__comp-header .ppp-ct__col-img-wrap { height: var(--ct-comp-img-h, 70px); }
  .ppp-ct__col-img { object-fit: contain; width: auto; max-height: var(--ct-our-img-h, 90px); }
  .ppp-ct__col-img--comp { max-height: var(--ct-comp-img-h, 70px); }
  .ppp-ct__col-name { font-family: var(--ct-table-font, inherit); font-weight: var(--ct-col-name-weight, 700); font-size: var(--ct-col-name-size, 14px); line-height: 1.2; letter-spacing: var(--ct-col-name-ls, 0em); text-transform: var(--ct-col-name-transform, none); }
  .ppp-ct__comp-header {
    flex: 1 1 0;
    min-width: 80px;
    background: rgba(128,128,128,0.07);
    color: var(--ct-comp-text, currentColor);
    border-radius: 10px 10px 0 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 1.125rem 0.625rem 0.875rem;
    text-align: center;
  }
  .ppp-ct__our-cell {
    flex: 1 1 0;
    min-width: 90px;
    background: var(--ppp-ct-us-bg, #2D1208);
    color: var(--ct-our-text, #fff);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    padding: var(--ct-cell-pad-y, 0.875rem) 0.75rem;
    text-align: center;
  }
  .ppp-ct__our-cell--last { border-radius: 0 0 14px 14px; }
  .ppp-ct__comp-cell {
    flex: 1 1 0;
    min-width: 80px;
    background: rgba(128,128,128,0.07);
    color: var(--ct-comp-text, currentColor);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    padding: var(--ct-cell-pad-y, 0.75rem) 0.625rem;
    text-align: center;
  }
  .ppp-ct__comp-cell--last { border-radius: 0 0 10px 10px; }
  .ppp-ct__comp-header--1 { background: var(--ct-comp1-bg, rgba(128,128,128,0.07)); color: var(--ct-comp1-text, var(--ct-comp-text, currentColor)); }
  .ppp-ct__comp-cell--1 { background: var(--ct-comp1-bg, rgba(128,128,128,0.07)); color: var(--ct-comp1-text, var(--ct-comp-text, currentColor)); }
  .ppp-ct__cell-val { font-family: var(--ct-table-font, inherit); font-size: var(--ct-cell-val-size, 16px); font-weight: var(--ct-cell-val-weight, 700); line-height: 1.2; letter-spacing: var(--ct-cell-val-ls, 0em); text-transform: var(--ct-cell-val-transform, none); display: block; }
  .ppp-ct__cell-note { font-size: 0.78rem; line-height: 1.3; opacity: 0.8; display: block; }
  .ppp-ct__our-cell .ppp-ct__cell-note { opacity: 0.75; color: rgba(255,255,255,0.85); }
  .ppp-ct__footer { text-align: var(--ct-footer-h-align, right); padding-top: 2.5rem; }
  .ppp-ct__footer-heading {
    font-family: var(--section-heading-font, inherit);
    font-size: var(--ct-footer-h-size, 2rem);
    font-weight: var(--ct-footer-h-weight, 700);
    letter-spacing: var(--ct-footer-h-ls, 0em);
    text-transform: var(--ct-footer-h-transform, none);
    color: var(--ct-footer-h-color, currentColor);
    margin: 0;
    line-height: 1.15;
  }
  @media (max-width: 899px) {
    .ppp-ct__wrapper { grid-template-columns: 1fr; gap: 2rem; }
    .ppp-ct__left { align-items: center; text-align: center; }
    .ppp-ct__heading { font-size: clamp(1.5rem, 6vw, 2.2rem); }
  }
  @media (max-width: 749px) {
    .ppp-ct {
      padding-block-start: var(--ppp-ct-mob-pt, 48px);
      padding-block-end: var(--ppp-ct-mob-pb, 48px);
    }
    .ppp-ct__heading { font-size: var(--ppp-ct-mob-heading-size, 24px); }
    .ppp-ct__cell-val { font-size: var(--ppp-ct-mob-cell-size, 14px); }
    .ppp-ct__cell-note { font-size: 0.7rem; }
    .ppp-ct__footer-heading { font-size: var(--ct-mob-footer-h-size, var(--ct-footer-h-size, 1.5rem)); }
  }
/* END_SECTION:ppp-comparison-table */

/* START_SECTION:ppp-contact (INDEX:18) */
.ppp-contact {
    min-height: calc(100vh - var(--hdr-h, 64px));
  }
  .ppp-contact__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    padding-block: var(--ct-pt, 80px) var(--ct-pb, 96px);
  }

  /* ── Centered layout (default) ── */
  .ppp-contact--centered .ppp-contact__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .ppp-contact--centered .ppp-contact__header {
    max-width: var(--ct-form-max, 600px);
    width: 100%;
    margin-bottom: 2.5rem;
  }
  .ppp-contact--centered .ppp-contact__form-col {
    width: 100%;
    max-width: var(--ct-form-max, 600px);
  }

  /* ── Two-column layout ── */
  .ppp-contact--two_col .ppp-contact__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ct-col-gap, 80px);
    align-items: start;
  }
  .ppp-contact--two_col .ppp-contact__header {
    position: sticky;
    top: calc(var(--hdr-h, 64px) + 2rem);
  }

  /* ── Header ── */
  .ppp-contact__eyebrow {
    font-size: 11px;
    font-family: var(--ct-body-font, inherit);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    opacity: 0.5;
    margin-bottom: 0.75rem;
  }
  .ppp-contact__heading {
    font-size: var(--ct-heading-size, 48px);
    font-family: var(--ct-heading-font, var(--section-heading-font, inherit));
    font-weight: var(--ct-heading-weight, 800);
    letter-spacing: var(--ct-heading-ls, -0.02em);
    line-height: var(--ct-heading-lh, 1.1);
    text-transform: var(--ct-heading-transform, none);
    color: var(--ct-heading-color, currentColor);
    margin: 0 0 1rem;
  }
  .ppp-contact__subtext {
    font-size: var(--ct-subtext-size, 16px);
    font-family: var(--ct-body-font, inherit);
    opacity: 0.6;
    line-height: 1.6;
    margin: 0 0 1.5rem;
  }
  .ppp-contact__info-block {
    font-size: var(--ct-subtext-size, 16px);
    font-family: var(--ct-body-font, inherit);
    line-height: 1.7;
    opacity: 0.75;
    margin-bottom: 1.5rem;
  }
  .ppp-contact__social {
    display: flex;
    gap: 1rem;
    align-items: center;
    margin-top: 0.5rem;
  }
  .ppp-contact__social-link {
    color: currentColor;
    opacity: 0.6;
    transition: opacity 0.15s;
    display: flex;
  }
  .ppp-contact__social-link:hover { opacity: 1; }

  /* ── Form fields ── */
  .ppp-contact__form-col {
    display: flex;
    flex-direction: column;
    gap: var(--ct-field-gap, 20px);
  }
  .ppp-contact__label {
    display: block;
    font-size: var(--ct-label-size, 13px);
    font-family: var(--ct-body-font, inherit);
    font-weight: var(--ct-label-weight, 600);
    color: var(--ct-label-color, currentColor);
    margin-bottom: 0.4rem;
    letter-spacing: 0.01em;
  }
  .ppp-contact__input,
  .ppp-contact__textarea,
  .ppp-contact__select {
    width: 100%;
    background: var(--ct-input-bg, transparent);
    border: 1px solid var(--ct-input-border, rgba(0,0,0,0.2));
    border-radius: var(--ct-input-radius, 8px);
    font-family: var(--ct-body-font, inherit);
    font-size: var(--ct-input-size, 15px);
    color: var(--ct-input-text, currentColor);
    padding: 0.75rem 1rem;
    transition: border-color 0.15s;
    appearance: none;
    -webkit-appearance: none;
  }
  .ppp-contact__input:focus,
  .ppp-contact__textarea:focus,
  .ppp-contact__select:focus {
    outline: none;
    border-color: currentColor;
  }
  .ppp-contact__input::placeholder,
  .ppp-contact__textarea::placeholder { opacity: 0.4; }
  .ppp-contact__textarea { resize: vertical; min-height: 120px; }

  .ppp-contact__select-wrap {
    position: relative;
  }
  .ppp-contact__select-arrow {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    opacity: 0.5;
  }
  .ppp-contact__select { padding-right: 2.5rem; cursor: pointer; }

  .ppp-contact__disclaimer {
    font-size: 0.75rem;
    font-family: var(--ct-body-font, inherit);
    opacity: 0.4;
    line-height: 1.6;
    margin: 0;
  }
  .ppp-contact__btn {
    width: 100%;
    background: var(--ct-btn-bg, var(--color-primary, #1a0f0a));
    color: var(--ct-btn-color, #ffffff);
    border: none;
    border-radius: var(--btn-radius, 999px);
    font-family: var(--ct-body-font, inherit);
    font-size: var(--ct-btn-size, 15px);
    font-weight: var(--ct-btn-weight, 700);
    padding: 0.9rem 2rem;
    cursor: pointer;
    transition: opacity 0.15s;
    letter-spacing: 0.04em;
    text-transform: uppercase;
  }
  .ppp-contact__btn:hover { opacity: 0.85; }

  .ppp-contact__errors {
    background: rgba(229,83,51,0.1);
    border: 1px solid rgba(229,83,51,0.3);
    border-radius: var(--ct-input-radius, 8px);
    padding: 0.875rem 1rem;
    font-size: 0.875rem;
    color: #c0392b;
  }

  .ppp-contact__success {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    text-align: center;
    padding: 3rem 1rem;
    opacity: 0.8;
    font-family: var(--ct-body-font, inherit);
    font-size: var(--ct-subtext-size, 16px);
  }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-contact__inner { padding-block: var(--ct-mob-pt, 48px) var(--ct-mob-pb, 64px); }
    .ppp-contact__heading { font-size: var(--ct-mob-heading-size, 32px); }
    .ppp-contact--two_col .ppp-contact__inner {
      grid-template-columns: 1fr;
      gap: 2rem;
    }
    .ppp-contact--two_col .ppp-contact__header { position: static; }
  }
/* END_SECTION:ppp-contact */

/* START_SECTION:ppp-faq (INDEX:19) */
.ppp-faq-section {
    padding-block-start: var(--faq-pt, 80px);
    padding-block-end: var(--faq-pb, 80px);
  }
  .ppp-faq-section__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-faq-section__header {
    text-align: center;
    max-width: 560px;
    margin-inline: auto;
    margin-bottom: 3rem;
  }
  .ppp-faq-section__heading {
    font-size: var(--faq-heading-size, 2.25rem);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--faq-heading-weight, 800);
    letter-spacing: var(--faq-heading-ls, -0.02em);
    text-transform: var(--faq-heading-transform, none);
    margin-bottom: 0.75rem;
  }
  .ppp-faq-section .ppp-section__eyebrow {
    font-size: var(--faq-eyebrow-size, 12px);
    font-weight: var(--faq-eyebrow-weight, 700);
    letter-spacing: var(--faq-eyebrow-ls, 0.1em);
    text-transform: var(--faq-eyebrow-transform, uppercase);
    color: var(--faq-eyebrow-color, currentColor);
    margin: 0 0 0.75rem;
  }
  .ppp-faq-section__subheading {
    font-family: var(--font-subheading--family, var(--font-body--family));
    font-size: var(--faq-sub-size, 16px);
    font-weight: var(--faq-sub-weight, 400);
    letter-spacing: var(--faq-sub-ls, 0em);
    text-transform: var(--faq-sub-transform, none);
    color: var(--faq-sub-color, currentColor);
    line-height: var(--faq-sub-lh, 1.6);
  }
  .ppp-faq-section__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 3.5rem;
  }
  .ppp-faq-section__col--full {
    grid-column: 1 / -1;
    max-width: 740px;
    margin-inline: auto;
    width: 100%;
  }
  .ppp-faq__item {
    border-bottom: 1px solid var(--color-border, #e5e5e5);
  }
  .ppp-faq__item:first-child { border-top: 1px solid var(--color-border, #e5e5e5); }
  .ppp-faq__trigger {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.125rem 0;
    background: transparent;
    border: none;
    cursor: pointer;
    font-family: var(--faq-qa-font, var(--font-body--family));
    font-size: var(--faq-q-size, 16px);
    font-weight: var(--faq-q-weight, 600);
    letter-spacing: var(--faq-q-ls, 0em);
    text-transform: var(--faq-q-transform, none);
    color: var(--faq-q-color, currentColor);
    text-align: left;
    -webkit-tap-highlight-color: transparent;
  }
  .ppp-faq__question { flex: 1; line-height: var(--faq-q-lh, 1.4); }
  .ppp-faq__panel {
    overflow: hidden;
    transition: max-height 0.35s var(--ease-out);
  }
  .ppp-faq__panel[aria-hidden="false"] { max-height: 1000px !important; }
  .ppp-faq__answer {
    font-family: var(--faq-qa-font, inherit);
    font-size: var(--faq-a-size, 15px);
    font-weight: var(--faq-a-weight, 400);
    letter-spacing: var(--faq-a-ls, 0em);
    text-transform: var(--faq-a-transform, none);
    color: var(--faq-a-color, currentColor);
    line-height: var(--faq-a-lh, 1.7);
    padding-bottom: 1.25rem;
  }
  .ppp-faq__answer p { margin-bottom: 0.6rem; }
  .ppp-faq__answer p:last-child { margin-bottom: 0; }

  @media (max-width: 749px) {
    .ppp-faq-section {
      padding-block-start: var(--faq-mob-pt, 48px);
      padding-block-end: var(--faq-mob-pb, 48px);
    }
    .ppp-faq-section__grid { grid-template-columns: 1fr; gap: 0; }
    .ppp-faq-section__header { margin-bottom: 2rem; }
    .ppp-faq-section__heading { font-size: var(--faq-mob-heading-size, 1.625rem); }
    .ppp-faq-section__subheading { font-size: var(--faq-mob-sub-size, 15px); }
    .ppp-faq__trigger { font-size: var(--faq-mob-q-size, 15px); }
    .ppp-faq__answer { font-size: var(--faq-mob-a-size, 14px); }
  }
/* END_SECTION:ppp-faq */

/* START_SECTION:ppp-featured-products (INDEX:20) */
/* ── Premium Featured Products ── */
  .ppp-fp {
    padding-block-start: var(--fp-pt, 72px);
    padding-block-end: var(--fp-pb, 72px);
    min-width: 0;
    width: 100%;
  }
  .ppp-fp__inner {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    display: flex;
    flex-direction: column;
    gap: 2.5rem;
  }

  /* ── Header ── */
  .ppp-fp__header { display: flex; flex-direction: column; gap: 0.5rem; }
  .ppp-fp__eyebrow {
    font-size: var(--fp-eyebrow-size, 11px);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--fp-eyebrow-ls, 0.15em);
    color: var(--fp-eyebrow-color, currentColor);
    margin: 0;
  }
  .ppp-fp__header-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
  }
  .ppp-fp__heading {
    font-size: var(--fp-heading-size, 44px);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--section-heading-weight, 800);
    line-height: 1.1;
    letter-spacing: var(--section-heading-ls, -0.025em);
    text-transform: var(--section-heading-transform, none);
    color: var(--fp-heading-color, currentColor);
    margin: 0;
    text-wrap: balance;
  }
  .ppp-fp__sub {
    font-family: var(--font-subheading--family, var(--font-body--family));
    font-size: var(--fp-sub-size, 16px);
    letter-spacing: var(--fp-sub-ls, 0em);
    color: var(--fp-sub-color, currentColor);
    margin: 0;
    max-width: 560px;
  }
  .ppp-fp__view-all {
    font-size: 0.875rem;
    font-weight: 600;
    color: currentColor;
    text-decoration: underline;
    text-underline-offset: 3px;
    white-space: nowrap;
    transition: opacity 0.2s;
    flex-shrink: 0;
  }
  .ppp-fp__view-all:hover { opacity: 0.65; }

  /* ── Grid ── */
  .ppp-fp__grid {
    display: grid;
    grid-template-columns: repeat(var(--fp-cols, 3), 1fr);
    gap: var(--fp-gap, 16px);
  }

  /* ── Card ── */
  .ppp-fp__card {
    display: flex;
    flex-direction: column;
    border-radius: var(--fp-radius, 16px);
    overflow: hidden;
  }
  .ppp-fp__card--placeholder { cursor: default; }

  /* ── Card media ── */
  .ppp-fp__card-media {
    display: block;
    aspect-ratio: var(--fp-img-ratio, 3/4);
    overflow: hidden;
    position: relative;
    background: rgba(128,128,128,0.08);
  }
  .ppp-fp__card-media--empty { pointer-events: none; }

  .ppp-fp__card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    position: relative;
    z-index: 1;
    transition: transform 0.5s ease, opacity 0.4s ease;
  }
  .ppp-fp__card:not(.ppp-fp__card--has-video):hover .ppp-fp__card-img {
    transform: scale(1.04);
  }
  .ppp-fp__card--has-video:hover .ppp-fp__card-img {
    opacity: 0;
    transform: scale(1.02);
  }

  /* ── Hover video ── */
  .ppp-fp__card-vid {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: 2;
    pointer-events: none;
  }
  .ppp-fp__card--has-video:hover .ppp-fp__card-vid { opacity: 1; }

  .ppp-fp__card-img-placeholder {
    width: 100%;
    height: 100%;
    min-height: 240px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    font-weight: 900;
    opacity: 0.12;
  }

  /* ── Badge ── */
  .ppp-fp__card-badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    background: #111;
    color: #fff;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 0.3rem 0.625rem;
    border-radius: 999px;
    pointer-events: none;
    z-index: 3;
  }

  /* ── Card body: title + price left, CTA right ── */
  .ppp-fp__card-body {
    padding: 0.875rem 1rem 1rem;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
  }
  .ppp-fp__card-info {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
    min-width: 0;
    overflow: hidden;
  }
  .ppp-fp__card-title {
    font-family: var(--fp-card-font, inherit);
    font-size: var(--fp-card-title-size, 14px);
    font-weight: var(--fp-card-title-fw, 700);
    line-height: 1.3;
    letter-spacing: var(--fp-card-title-ls, 0em);
    text-transform: var(--fp-card-title-transform, none);
    margin: 0;
    color: var(--fp-card-title-color, currentColor);
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .ppp-fp__card-title:hover { text-decoration: underline; }
  .ppp-fp__card-price {
    font-size: var(--fp-price-size, 13px);
    font-weight: 500;
    margin: 0;
    color: var(--fp-price-color, currentColor);
    display: flex;
    gap: 0.375rem;
    align-items: baseline;
  }
  .ppp-fp__price-sale { color: #c0392b; opacity: 1; font-weight: 700; }
  .ppp-fp__price-was { text-decoration: line-through; font-weight: 400; }
  .ppp-fp__card-cta {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0.5rem 1.125rem;
    background: var(--fp-btn-bg, #111111);
    color: var(--fp-btn-fg, #ffffff);
    border-radius: 999px;
    font-family: var(--fp-card-font, inherit);
    font-size: var(--fp-cta-size, 12px);
    font-weight: var(--fp-cta-weight, 700);
    letter-spacing: var(--fp-cta-ls, 0em);
    text-decoration: none;
    white-space: nowrap;
    transition: opacity 0.2s;
  }
  .ppp-fp__card-cta:hover { opacity: 0.78; }
  button.ppp-fp__card-cta { border: none; cursor: pointer; }
  button.ppp-fp__card-cta:disabled { opacity: 0.6; cursor: default; }
  .ppp-fp__card-cta--soldout { opacity: 0.45; cursor: default; }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-fp {
      padding-block-start: var(--fp-mob-pt, 48px);
      padding-block-end: var(--fp-mob-pb, 48px);
    }
    .ppp-fp__heading {
      font-size: var(--fp-mob-heading-size, var(--fp-heading-size, 44px));
    }
    .ppp-fp__inner { gap: 1.5rem; }
    .ppp-fp__grid {
      grid-template-columns: repeat(var(--fp-mob-cols, 2), 1fr);
      gap: calc(var(--fp-gap, 16px) * 0.75);
    }
    .ppp-fp__card-body { padding: 0.75rem 0.75rem 0.875rem; gap: 0.5rem; }
    .ppp-fp__card-cta { font-size: var(--fp-cta-size, 12px); padding: 0.5rem 0.875rem; }
    .ppp-fp__card-vid:not(.ppp-fp__card-vid--mob-on) { display: none; }
    .ppp-fp__card-vid--mob-on { opacity: 1; }
  }
/* END_SECTION:ppp-featured-products */

/* START_SECTION:ppp-features-3col (INDEX:21) */
.ppp-f3c {
    padding-block-start: var(--f3c-pt, 64px);
    padding-block-end: var(--f3c-pb, 64px);
  }
  .ppp-f3c__wrap {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-f3c__heading {
    font-family: var(--section-heading-font, inherit);
    font-size: var(--f3c-heading-size, 56px);
    font-weight: var(--section-heading-weight, 800);
    letter-spacing: var(--section-heading-ls, -0.02em);
    text-transform: var(--section-heading-transform, none);
    text-align: center;
    margin: 0 0 var(--f3c-heading-mb, 40px);
    line-height: 1.05;
  }
  .ppp-f3c__grid {
    display: grid;
    gap: var(--f3c-col-gap, 40px);
    align-items: start;
  }
  .ppp-f3c__col {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
  }

  /* SVG */
  .ppp-f3c__svg-wrap {
    width: var(--f3c-svg-w-desk, 80px);
    flex-shrink: 0;
    align-self: var(--f3c-svg-align, flex-start);
    margin-bottom: var(--f3c-svg-mb, 0px);
  }
  .ppp-f3c__svg-wrap img {
    width: 100%;
    height: auto;
    display: block;
  }

  /* Badge */
  .ppp-f3c__badge {
    display: inline-block;
    font-family: var(--f3c-badge-font, inherit);
    font-size: var(--f3c-badge-size, 18px);
    font-weight: var(--f3c-badge-weight, 800);
    letter-spacing: var(--f3c-badge-ls, 0.05em);
    text-transform: var(--f3c-badge-transform, uppercase);
    padding: var(--f3c-badge-pad-y, 16px) var(--f3c-badge-pad-x, 24px);
    border-radius: var(--f3c-badge-radius, 20px);
    line-height: 1.2;
    text-align: center;
    align-self: flex-start;
  }

  /* Body */
  .ppp-f3c__body {
    font-family: var(--f3c-body-font, inherit);
    font-size: var(--f3c-body-size, 16px);
    font-weight: var(--f3c-body-weight, 700);
    letter-spacing: var(--f3c-body-ls, 0em);
    line-height: 1.6;
  }
  .ppp-f3c__body p { margin-block: 0.75em; }
  .ppp-f3c__body p:first-child { margin-top: 0; }
  .ppp-f3c__body p:last-child { margin-bottom: 0; }

  /* Static image */
  .ppp-f3c__img-wrap {
    width: 100%;
    height: var(--f3c-img-h, 260px);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    overflow: hidden;
  }
  .ppp-f3c__img {
    max-height: 100%;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    display: block;
  }

  /* Lottie */
  .ppp-f3c__lottie-wrap {
    width: var(--f3c-lot-w-desk, 200px);
    align-self: center;
  }
  .ppp-f3c__lottie-wrap lottie-player {
    width: 100%;
    display: block;
  }

  /* Mobile */
  @media (max-width: 749px) {
    .ppp-f3c {
      padding-block-start: var(--f3c-mob-pt, 40px);
      padding-block-end: var(--f3c-mob-pb, 40px);
    }
    .ppp-f3c__heading { font-size: var(--f3c-mob-heading-size, 36px); margin-bottom: var(--f3c-mob-heading-mb, 32px); }
    .ppp-f3c__grid { grid-template-columns: 1fr !important; }
    .ppp-f3c__badge { font-size: var(--f3c-badge-mob-size, 15px); }
    .ppp-f3c__body { font-size: var(--f3c-body-mob-size, 14px); }
    .ppp-f3c__img-wrap { height: var(--f3c-mob-img-h, 200px); }
    .ppp-f3c__svg-wrap { width: var(--f3c-svg-w-mob, 60px); }
    .ppp-f3c__lottie-wrap { width: var(--f3c-lot-w-mob, 160px); }
  }
/* END_SECTION:ppp-features-3col */

/* START_SECTION:ppp-footer (INDEX:22) */
/* ── Base: explicit block stacking ── */
  .ppp-footer {
    display: block;
    margin-top: auto;
  }
  .ppp-footer__top-band,
  .ppp-footer__wordmark,
  .ppp-footer__bottom {
    display: block;
    width: 100%;
  }

  /* ── 1. Columns ── */
  .ppp-footer__top-band {
    padding-block: var(--ftr-col-pt, 56px) var(--ftr-col-pb, 56px);
  }
  .ppp-footer__columns-inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 2rem var(--ftr-col-gap, 48px);
  }
  .ppp-footer__col {
    flex: 0 1 auto;
    min-width: 140px;
  }
  .ppp-footer__col--social { margin-left: auto; }
  .ppp-footer__col-heading {
    font-size: var(--ftr-col-heading-size, 13px);
    font-family: var(--ftr-body-font, inherit);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 1.25rem;
    color: currentColor;
  }
  .ppp-footer__links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--ftr-link-gap, 10px);
  }
  .ppp-footer__link {
    font-size: var(--ftr-link-size, 15px);
    font-family: var(--ftr-body-font, inherit);
    color: currentColor;
    text-decoration: none;
    opacity: 0.8;
    transition: opacity 0.15s;
  }
  .ppp-footer__link:hover { opacity: 1; }

  /* ── 2. Wordmark ── */
  .ppp-footer__wordmark {
    padding-block: var(--ftr-wm-pt, 40px) var(--ftr-wm-pb, 0px);
    overflow: hidden;
    line-height: var(--ftr-wm-lh, 0.85);
    text-align: center;
  }
  .ppp-footer__wordmark-link {
    display: block;
    color: inherit;
    text-decoration: none;
  }
  .ppp-footer__wordmark-img {
    display: block;
    width: var(--ftr-wm-img-size, 80%);
    max-width: var(--ftr-wm-img-size, 80%);
    height: auto;
    margin-inline: auto;
  }
  .ppp-footer__wordmark-text {
    display: block;
    font-family: var(--ftr-heading-font, var(--section-heading-font, inherit));
    font-weight: 900;
    letter-spacing: -0.02em;
    text-transform: uppercase;
    line-height: var(--ftr-wm-lh, 0.85);
    white-space: nowrap;
    width: 100%;
    text-align: left;
  }

  /* ── 3. Bottom bar ── */
  .ppp-footer__bottom {
    border-top: 1px solid var(--ftr-divider, rgba(255,255,255,0.15));
    padding-block: var(--ftr-bottom-py, 20px);
  }
  .ppp-footer__bottom-row {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.4rem 0.75rem;
    font-size: var(--ftr-bottom-size, 12px);
    font-family: var(--ftr-body-font, inherit);
  }
  .ppp-footer__copyright { opacity: 0.5; }
  .ppp-footer__bullet { opacity: 0.3; }
  .ppp-footer__policy-link {
    color: currentColor;
    opacity: 0.5;
    text-decoration: none;
    transition: opacity 0.15s;
  }
  .ppp-footer__policy-link:hover { opacity: 1; text-decoration: underline; }
  .ppp-footer__payment {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    vertical-align: middle;
    opacity: 0.6;
  }
  .ppp-footer__payment-icon { height: 20px; width: auto; border-radius: 3px; }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-footer__top-band { padding-block: var(--ftr-mob-col-pt, 36px) var(--ftr-mob-col-pb, 36px); }
    .ppp-footer__columns-inner { gap: 1.75rem; }
    .ppp-footer__col { min-width: calc(50% - 0.875rem); }
    .ppp-footer__bottom-row { justify-content: center; text-align: center; }
  }
/* END_SECTION:ppp-footer */

/* START_SECTION:ppp-hero (INDEX:23) */
/* ── Shared ── */
  .ppp-hero {
    background-color: var(--hero-bg);
    color: var(--hero-fg);
    padding-block-start: var(--hero-pt);
    padding-block-end: var(--hero-pb);
  }

  /* ── Full bleed ── */
  .ppp-hero--full_bleed {
    position: relative;
    min-height: var(--hero-h-desk);
    display: flex;
    flex-direction: column;
  }
  .ppp-hero--full_bleed .ppp-hero__media {
    position: absolute;
    inset: 0;
    overflow: hidden;
  }
  .ppp-hero--full_bleed .ppp-hero__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }
  .ppp-hero--full_bleed .ppp-hero__img--mobile { display: none; }
  .ppp-hero--full_bleed .ppp-hero__video-wrap,
  .ppp-hero--full_bleed .ppp-hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .ppp-hero--full_bleed .ppp-hero__placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
  }
  .ppp-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
      var(--hero-overlay-dir),
      transparent 0%,
      color-mix(in srgb, var(--hero-overlay-color) var(--hero-overlay), transparent) 100%
    );
    pointer-events: none;
  }
  .ppp-hero--full_bleed .ppp-hero__content-wrap {
    position: relative;
    z-index: 1;
    flex: 1;
    display: flex;
    align-items: var(--hero-content-align);
    justify-content: var(--hero-content-justify);
    padding: 4rem var(--page-margin, 1.5rem);
  }
  .ppp-hero--full_bleed .ppp-hero__content {
    max-width: var(--hero-content-max-w);
    text-align: var(--hero-text-align);
  }
  .ppp-hero--full_bleed .ppp-hero__sub {
    max-width: 560px;
    align-self: center;
  }

  /* ── Split / Divided ── */
  .ppp-hero--split {
    display: grid;
    grid-template-columns: var(--hero-split-cols, 1fr 1fr);
    min-height: var(--hero-h-desk);
  }
  .ppp-hero--split-right .ppp-hero__media-col { order: 1; }
  .ppp-hero--split-right .ppp-hero__content-col { order: 0; }

  .ppp-hero__media-col {
    position: relative;
    overflow: hidden;
  }
  .ppp-hero__media-col .ppp-hero__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }
  .ppp-hero__media-col .ppp-hero__img--mobile { display: none; }
  .ppp-hero__media-col .ppp-hero__video-wrap {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
  .ppp-hero__media-col .ppp-hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .ppp-hero__media-col .ppp-hero__placeholder {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
  }

  .ppp-hero__content-col {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: var(--hero-content-align, center);
    align-items: flex-start;
    padding: var(--hero-split-content-pad, 4rem);
    background-color: var(--hero-split-content-bg, var(--hero-bg));
  }
  .ppp-hero__content-col-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: var(--hero-split-content-bg-pos, center center);
  }
  .ppp-hero__content-col-overlay {
    position: absolute;
    inset: 0;
    background-color: color-mix(in srgb, var(--hero-split-content-overlay-color, #000000) var(--hero-split-content-overlay, 0%), transparent);
    pointer-events: none;
  }
  .ppp-hero--split .ppp-hero__content {
    position: relative;
    z-index: 1;
    max-width: var(--hero-content-max-w);
    text-align: var(--hero-text-align);
    width: 100%;
  }

  /* ── Shared content ── */
  .ppp-hero__content {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .ppp-hero__eyebrow {
    font-size: 0.8rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    opacity: 0.75;
    margin: 0;
  }
  .ppp-hero__heading {
    font-size: var(--hero-heading-size);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--section-heading-weight, 800);
    line-height: 1.05;
    letter-spacing: var(--section-heading-ls, -0.02em);
    text-transform: var(--section-heading-transform, none);
    margin: 0;
  }
  .ppp-hero__heading-line { display: block; }
  .ppp-hero__sub {
    font-family: var(--font-subheading--family, var(--font-body--family));
    font-size: var(--hero-sub-size);
    line-height: 1.6;
    opacity: 0.85;
    margin: 0;
  }
  .ppp-hero__btns {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    justify-content: var(--hero-text-align);
    margin-top: 0.5rem;
  }
  .ppp-hero__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.875rem 2rem;
    border-radius: 999px;
    font-family: var(--hero-btn-font, inherit);
    font-weight: var(--hero-btn-fw, 700);
    font-size: var(--hero-btn-size, 15px);
    letter-spacing: var(--hero-btn-ls, 0em);
    text-transform: var(--hero-btn-transform, none);
    text-decoration: none;
    cursor: pointer;
    transition: opacity 0.2s, transform 0.15s;
    white-space: nowrap;
  }
  .ppp-hero__btn:hover { opacity: 0.85; transform: translateY(-1px); }
  .ppp-hero__btn--primary {
    background: var(--hero-fg);
    color: var(--hero-bg);
  }
  .ppp-hero__btn--secondary {
    background: transparent;
    color: var(--hero-fg);
    border: 2px solid var(--hero-fg);
  }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-hero {
      padding-block-start: var(--hero-mob-pt);
      padding-block-end: var(--hero-mob-pb);
    }

    /* Full bleed mobile */
    .ppp-hero--full_bleed { min-height: var(--hero-h-mob); }
    .ppp-hero--full_bleed .ppp-hero__img--desktop { display: none; }
    .ppp-hero--full_bleed .ppp-hero__img--mobile { display: block; }
    .ppp-hero--full_bleed .ppp-hero__content-wrap { padding: 2.5rem var(--page-margin, 1rem); }
    .ppp-hero--full_bleed .ppp-hero__sub { align-self: unset; max-width: 100%; }

    /* Split mobile — stack to single column */
    .ppp-hero--split {
      grid-template-columns: 1fr;
      min-height: unset;
    }
    .ppp-hero--split .ppp-hero__media-col,
    .ppp-hero--split-right .ppp-hero__media-col {
      order: var(--hero-split-mob-media-order, 0);
      min-height: var(--hero-h-mob);
    }
    .ppp-hero--split .ppp-hero__content-col,
    .ppp-hero--split-right .ppp-hero__content-col {
      order: var(--hero-split-mob-content-order, 1);
      padding: 2.5rem var(--page-margin, 1.5rem);
    }
    .ppp-hero__media-col .ppp-hero__img--desktop { display: none; }
    .ppp-hero__media-col .ppp-hero__img--mobile { display: block; }

    /* Shared mobile */
    .ppp-hero__heading { font-size: var(--hero-mob-heading-size); }
    .ppp-hero__sub { font-size: var(--hero-mob-sub-size); }
    .ppp-hero__content { text-align: var(--hero-mob-text-align); }
    .ppp-hero__btns { justify-content: var(--hero-mob-text-align); }
  }
/* END_SECTION:ppp-hero */

/* START_SECTION:ppp-lottie (INDEX:24) */
.ppp-lottie-section {
    position: relative;
    z-index: var(--ls-z, 1);
    padding-block-start: var(--ls-pt, 0px);
    padding-block-end: var(--ls-pb, 0px);
    margin-top: var(--ls-mt, 0px);
    margin-bottom: var(--ls-mb, 0px);
  }
  .ppp-lottie-section__wrap {
    display: flex;
    justify-content: var(--ls-align, center);
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-lottie-section__wrap lottie-player {
    width: var(--ls-width, 100%);
    max-width: var(--ls-max-width, 100%);
    display: block;
  }
  .ppp-lottie-section__placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 3rem 1.5rem;
    color: currentColor;
    opacity: 0.35;
    font-size: 0.875rem;
    text-align: center;
    border: 2px dashed currentColor;
    border-radius: 12px;
    margin-inline: var(--page-margin, 1.5rem);
  }
  .ppp-lottie-section__placeholder p { margin: 0; }

  @media (max-width: 749px) {
    .ppp-lottie-section {
      padding-block-start: var(--ls-mob-pt, var(--ls-pt, 0px));
      padding-block-end: var(--ls-mob-pb, var(--ls-pb, 0px));
      margin-top: var(--ls-mob-mt, var(--ls-mt, 0px));
      margin-bottom: var(--ls-mob-mb, var(--ls-mb, 0px));
    }
  }
/* END_SECTION:ppp-lottie */

/* START_SECTION:ppp-marquee (INDEX:25) */
.ppp-marquee {
    background: var(--mq-bg);
    color: var(--mq-fg);
    padding-block-start: var(--mq-pt);
    padding-block-end: var(--mq-pb);
    overflow: hidden;
    min-width: 0;
    width: 100%;
  }
  .ppp-marquee__track-wrap {
    overflow: hidden;
    display: flex;
  }
  .ppp-marquee__track {
    display: flex;
    align-items: center;
    gap: var(--mq-gap);
    animation: ppp-marquee-scroll var(--mq-speed) linear infinite;
    white-space: nowrap;
    will-change: transform;
    flex-shrink: 0;
  }
  .ppp-marquee:hover .ppp-marquee__track {
    animation-play-state: paused;
  }
  @keyframes ppp-marquee-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-25%); }
  }
  .ppp-marquee__item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: var(--mq-font-size);
    font-weight: var(--section-heading-weight, 600);
    letter-spacing: var(--section-heading-ls, 0.02em);
    text-transform: var(--section-heading-transform, uppercase);
    font-family: var(--section-heading-font, inherit);
    flex-shrink: 0;
  }
  .ppp-marquee__icon {
    font-size: 1.1em;
    line-height: 1;
  }
  .ppp-marquee__sep {
    flex-shrink: 0;
    opacity: 0.5;
    font-size: var(--mq-font-size);
  }
  .ppp-marquee__sep--svg {
    display: inline-flex;
    align-items: center;
    font-size: 0;
    opacity: 1;
  }
  .ppp-marquee__sep--svg svg {
    width: var(--mq-sep-svg-size, 20px);
    height: var(--mq-sep-svg-size, 20px);
    display: block;
    flex-shrink: 0;
  }
  @media (max-width: 749px) {
    .ppp-marquee {
      padding-block-start: var(--mq-mob-pt);
      padding-block-end: var(--mq-mob-pb);
    }
    .ppp-marquee__item,
    .ppp-marquee__sep {
      font-size: var(--mq-mob-font-size);
    }
  }
/* END_SECTION:ppp-marquee */

/* START_SECTION:ppp-media-with-content (INDEX:26) */
.ppp-mwc {
    scroll-margin-top: var(--hdr-h, 64px);
    background-color: var(--mwc-bg);
    color: var(--mwc-fg);
    padding-block-start: var(--mwc-pt);
    padding-block-end: var(--mwc-pb);
  }
  .ppp-mwc__inner {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    display: grid;
    grid-template-columns: var(--mwc-media-w) 1fr;
    gap: var(--mwc-gap);
    align-items: var(--mwc-valign);
  }
  .ppp-mwc__inner--reverse {
    grid-template-columns: 1fr var(--mwc-media-w);
  }
  .ppp-mwc__inner--reverse .ppp-mwc__media {
    order: 2;
  }
  .ppp-mwc__inner--reverse .ppp-mwc__content {
    order: 1;
  }

  /* ── Media ── */
  .ppp-mwc__media {
    border-radius: var(--mwc-media-radius);
    overflow: hidden;
  }
  .ppp-mwc__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .ppp-mwc__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .ppp-mwc__ext-video {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
  }
  .ppp-mwc__ext-video iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
  .ppp-mwc__placeholder {
    aspect-ratio: 4/3;
    background: rgba(128,128,128,0.15);
    border-radius: var(--mwc-media-radius);
  }

  /* ── Content ── */
  .ppp-mwc__content {
    padding: var(--mwc-content-padding);
    display: flex;
    flex-direction: column;
    gap: 1rem;
    text-align: var(--mwc-text-align);
    align-items: flex-start;
  }
  .ppp-mwc__eyebrow {
    font-size: var(--mwc-eyebrow-size, 13px);
    letter-spacing: var(--mwc-eyebrow-ls, 0.1em);
    text-transform: uppercase;
    color: var(--mwc-eyebrow-color, currentColor);
    margin: 0;
  }
  .ppp-mwc__heading {
    font-size: var(--mwc-heading-size);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--section-heading-weight, 800);
    line-height: 1.1;
    letter-spacing: var(--section-heading-ls, -0.02em);
    text-transform: var(--section-heading-transform, none);
    margin: 0;
    text-wrap: balance;
  }
  .ppp-mwc__body {
    font-family: var(--mwc-body-font, inherit);
    font-size: var(--mwc-body-size);
    font-weight: var(--mwc-body-weight, 400);
    letter-spacing: var(--mwc-body-ls, 0em);
    text-transform: var(--mwc-body-transform, none);
    color: var(--mwc-body-color, currentColor);
    line-height: var(--mwc-body-lh, 1.7);
  }
  .ppp-mwc__body p { margin-block: var(--mwc-body-para-gap, 0.5em); }
  .ppp-mwc__btns {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 0.5rem;
  }
  .ppp-mwc__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.8rem 1.75rem;
    border-radius: 999px;
    font-family: var(--mwc-btn-font, inherit);
    font-weight: 700;
    font-size: var(--mwc-btn-size, 14px);
    letter-spacing: var(--mwc-btn-ls, 0em);
    text-transform: var(--mwc-btn-transform, none);
    text-decoration: none;
    cursor: pointer;
    transition: opacity 0.2s, transform 0.15s;
  }
  .ppp-mwc__btn:hover { opacity: 0.8; transform: translateY(-1px); }
  .ppp-mwc__btn--primary {
    background: var(--mwc-btn-bg, var(--mwc-fg));
    color: var(--mwc-btn-text, var(--mwc-bg));
  }
  .ppp-mwc__btn--secondary {
    background: transparent;
    border: 2px solid currentColor;
    color: var(--mwc-fg);
  }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-mwc {
      padding-block-start: var(--mwc-mob-pt);
      padding-block-end: var(--mwc-mob-pb);
    }
    .ppp-mwc__inner,
    .ppp-mwc__inner--reverse {
      grid-template-columns: 1fr;
      gap: 1.5rem;
    }
    .ppp-mwc__inner--reverse .ppp-mwc__media,
    .ppp-mwc__inner--reverse .ppp-mwc__content {
      order: unset;
    }
    .ppp-mwc__inner.mob-media-first .ppp-mwc__media { order: 1; }
    .ppp-mwc__inner.mob-media-first .ppp-mwc__content { order: 2; }
    .ppp-mwc__inner.mob-text-first .ppp-mwc__media { order: 2; }
    .ppp-mwc__inner.mob-text-first .ppp-mwc__content { order: 1; }
    .ppp-mwc__media {
      aspect-ratio: var(--mwc-mob-image-ratio);
    }
    .ppp-mwc__img { height: 100%; }
    .ppp-mwc__heading { font-size: var(--mwc-mob-heading-size); }
    .ppp-mwc__body { font-size: var(--mwc-mob-body-size); }
    .ppp-mwc__content { padding: 0 0 0 0; }
  }
/* END_SECTION:ppp-media-with-content */

/* START_SECTION:ppp-newsletter (INDEX:27) */
/* ── Base (no image — centered column) ── */
  .ppp-newsletter {
    text-align: center;
  }
  .ppp-newsletter__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    padding-block: var(--nl-pt, 80px) var(--nl-pb, 80px);
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  /* ── Two-column layout when image is present ── */
  .ppp-newsletter--has-image {
    text-align: left;
  }
  .ppp-newsletter--has-image .ppp-newsletter__inner {
    flex-direction: row;
    align-items: stretch;
    gap: var(--nl-col-gap, 64px);
  }
  .ppp-newsletter__img-col {
    flex: 0 0 var(--nl-img-col, 45%);
    min-width: 0;
  }
  .ppp-newsletter__img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: var(--nl-img-radius, 0px);
  }
  .ppp-newsletter__content-col {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .ppp-newsletter--has-image .ppp-newsletter__heading {
    max-width: 100%;
  }

  /* ── Shared elements ── */
  .ppp-newsletter__eyebrow {
    font-size: 11px;
    font-family: var(--nl-body-font, inherit);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    opacity: 0.5;
    margin-bottom: 0.625rem;
  }
  .ppp-newsletter__heading {
    font-size: var(--nl-heading-size, 36px);
    font-family: var(--nl-heading-font, var(--section-heading-font, inherit));
    font-weight: var(--nl-heading-weight, 800);
    letter-spacing: var(--nl-heading-ls, -0.02em);
    text-transform: var(--nl-heading-transform, none);
    line-height: 1.15;
    max-width: var(--nl-max-width, 560px);
    margin-bottom: 1.25rem;
    color: currentColor;
  }
  .ppp-newsletter__subtext {
    font-size: var(--nl-subtext-size, 14px);
    font-family: var(--nl-body-font, inherit);
    opacity: 0.6;
    line-height: 1.6;
    max-width: 440px;
    margin-bottom: 1.5rem;
  }
  .ppp-newsletter__form-row {
    display: flex;
    gap: 0;
    border-radius: var(--btn-radius, 999px);
    overflow: hidden;
    border: 1px solid var(--nl-input-border, rgba(0,0,0,0.18));
    max-width: var(--nl-form-max-w, 560px);
    width: 100%;
  }
  .ppp-newsletter__input {
    flex: 1;
    background: transparent;
    border: none;
    font-family: var(--nl-body-font, inherit);
    font-size: var(--nl-input-size, 15px);
    padding: 0.875rem 1.25rem;
    min-width: 0;
    color: currentColor;
  }
  .ppp-newsletter__input::placeholder { opacity: 0.4; color: currentColor; }
  .ppp-newsletter__input:focus { outline: none; }
  .ppp-newsletter__btn {
    flex-shrink: 0;
    background: var(--nl-btn-bg, var(--color-primary, #1a0f0a));
    color: var(--nl-btn-color, #ffffff);
    border: none;
    font-family: var(--nl-body-font, inherit);
    font-size: var(--nl-btn-size, 14px);
    font-weight: var(--nl-btn-weight, 700);
    padding: 0.875rem 1.5rem;
    cursor: pointer;
    transition: opacity 0.15s;
    white-space: nowrap;
  }
  .ppp-newsletter__btn:hover { opacity: 0.85; }
  .ppp-newsletter__disclaimer {
    font-size: var(--nl-disclaimer-size, 12px);
    font-weight: var(--nl-disclaimer-weight, 400);
    text-transform: var(--nl-disclaimer-transform, none);
    font-family: var(--nl-body-font, inherit);
    color: var(--nl-disclaimer-color, currentColor);
    opacity: var(--nl-disclaimer-opacity, 0.4);
    line-height: 1.6;
    max-width: 440px;
    margin-top: 0.875rem;
  }
  .ppp-newsletter__success {
    font-size: var(--nl-subtext-size, 14px);
    font-family: var(--nl-body-font, inherit);
    opacity: 0.7;
  }
  .ppp-newsletter__error {
    font-size: 0.8rem;
    color: #e53;
    margin-top: 0.5rem;
  }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-newsletter__inner { padding-block: var(--nl-mob-pt, 56px) var(--nl-mob-pb, 56px); }
    .ppp-newsletter__heading { font-size: var(--nl-mob-heading-size, 26px); }
    .ppp-newsletter__form-row { max-width: 100%; }
    .ppp-newsletter--has-image .ppp-newsletter__inner {
      flex-direction: column;
      gap: 2rem;
    }
    .ppp-newsletter__img-col { flex: none; width: 100%; }
    .ppp-newsletter--has-image { text-align: center; }
    .ppp-newsletter--has-image .ppp-newsletter__form-row { margin-inline: auto; }
    .ppp-newsletter--has-image .ppp-newsletter__subtext { margin-inline: auto; }
    .ppp-newsletter--has-image .ppp-newsletter__disclaimer { margin-inline: auto; }
    .ppp-newsletter__img { max-height: 360px; width: 100%; object-fit: cover; height: auto; }
  }
/* END_SECTION:ppp-newsletter */

/* START_SECTION:ppp-pdp-accordion (INDEX:28) */
.ppp-accordion-section {
    padding-block-start: var(--acc-pt, 0px);
    padding-block-end: var(--acc-pb, 48px);
  }
  .ppp-accordion-section__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    max-width: min(680px, 100%);
  }
  .ppp-accordion__item {
    border-bottom: 1px solid var(--color-border, #e5e5e5);
  }
  .ppp-accordion__item:first-child { border-top: 1px solid var(--color-border, #e5e5e5); }
  .ppp-accordion__trigger {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.125rem 0;
    background: transparent;
    border: none;
    cursor: pointer;
    font-family: var(--section-heading-font, var(--font-body--family));
    font-size: var(--acc-trigger-size, 15px);
    letter-spacing: var(--acc-trigger-ls, 0em);
    font-weight: var(--acc-trigger-weight, 600);
    color: var(--acc-trigger-color, currentColor);
    text-align: left;
    gap: 1rem;
    -webkit-tap-highlight-color: transparent;
  }
  .ppp-accordion__title { flex: 1; }
  .ppp-accordion__chevron {
    flex-shrink: 0;
    transition: transform 0.25s var(--ease-in-out);
    opacity: 0.5;
  }
  .ppp-accordion__trigger[aria-expanded="true"] .ppp-accordion__chevron { transform: rotate(180deg); }
  .ppp-accordion__panel {
    overflow: hidden;
    transition: max-height 0.35s var(--ease-out);
  }
  .ppp-accordion__panel[aria-hidden="false"] { max-height: 2000px !important; }
  .ppp-accordion__panel-inner {
    padding-bottom: 1.25rem;
  }
  .ppp-accordion__richtext {
    font-size: var(--acc-body-size, 14px);
    letter-spacing: var(--acc-body-ls, 0em);
    color: var(--acc-body-color, currentColor);
    line-height: var(--acc-body-lh, 1.7);
  }
  .ppp-accordion__richtext p { margin-bottom: 0.75rem; }
  .ppp-accordion__richtext p:last-child { margin-bottom: 0; }
  .ppp-accordion__richtext ul,
  .ppp-accordion__richtext ol { padding-left: 1.5rem; margin-bottom: 0.75rem; }
  .ppp-accordion__richtext li { margin-bottom: 0.3rem; }
  .ppp-accordion__faq { display: flex; flex-direction: column; gap: 1.25rem; }
  .ppp-accordion__faq-q { font-size: var(--acc-faq-q-size, 14px); color: var(--acc-faq-q-color, currentColor); font-weight: 600; margin-bottom: 0.3rem; }
  .ppp-accordion__faq-a { font-size: var(--acc-faq-a-size, 14px); color: var(--acc-faq-a-color, currentColor); line-height: 1.6; }

  @media (max-width: 749px) {
    .ppp-accordion-section {
      padding-block-start: var(--acc-mob-pt, 0px);
      padding-block-end: var(--acc-mob-pb, 32px);
    }
    .ppp-accordion-section__inner { max-width: 100%; }
    .ppp-accordion__trigger { font-size: var(--acc-mob-trigger-size, 14px); }
    .ppp-accordion__richtext { font-size: var(--acc-mob-body-size, 13px); }
  }
/* END_SECTION:ppp-pdp-accordion */

/* START_SECTION:ppp-pdp-claims (INDEX:29) */
.ppp-claims {
    padding-block-start: var(--claims-pt, 48px);
    padding-block-end: var(--claims-pb, 48px);
  }
  .ppp-claims__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-claims__eyebrow {
    text-align: center;
    font-family: var(--section-heading-font, inherit);
    font-size: var(--claims-eyebrow-size, 12px);
    font-weight: var(--claims-eyebrow-weight, 700);
    text-transform: uppercase;
    letter-spacing: var(--claims-eyebrow-ls, 0.12em);
    color: var(--claims-eyebrow-color, currentColor);
    margin: 0 0 2rem;
  }
  .ppp-claims__grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem 2.75rem;
  }
  .ppp-claims__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.625rem;
    text-align: center;
  }
  .ppp-claims__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.8;
  }
  .ppp-claims__icon svg {
    width: var(--claims-icon-size, 36px);
    height: var(--claims-icon-size, 36px);
  }
  .ppp-claims__label {
    font-family: var(--section-heading-font, inherit);
    font-size: var(--claims-label-size, 11px);
    font-weight: var(--claims-label-weight, 700);
    text-transform: uppercase;
    letter-spacing: var(--claims-label-ls, 0.08em);
    color: var(--claims-label-color, currentColor);
    line-height: 1.3;
    max-width: 76px;
  }
  .ppp-claims__sublabel {
    display: block;
    font-size: var(--claims-sublabel-size, 11px);
    color: var(--claims-sublabel-color, currentColor);
    line-height: 1.3;
    max-width: 76px;
    margin-top: -0.25rem;
  }

  @media (max-width: 749px) {
    .ppp-claims {
      padding-block-start: var(--claims-mob-pt, 32px);
      padding-block-end: var(--claims-mob-pb, 32px);
    }
    .ppp-claims__grid { gap: 1.5rem 1.5rem; }
    .ppp-claims__icon svg {
      width: calc(var(--claims-icon-size, 36px) * 0.83);
      height: calc(var(--claims-icon-size, 36px) * 0.83);
    }
    .ppp-claims__label { font-size: 0.63rem; max-width: 68px; }
  }
/* END_SECTION:ppp-pdp-claims */

/* START_SECTION:ppp-pdp-hashtags (INDEX:30) */
.ppp-hashtags {
    padding-block-start: var(--ht-pt, 80px);
    padding-block-end: var(--ht-pb, 80px);
  }
  .ppp-hashtags__inner {
    max-width: var(--section-content-w, var(--page-width, 75rem));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    font-family: var(--section-heading-font, inherit);
  }
  .ppp-hashtags__eyebrow {
    font-size: var(--ht-eyebrow-size, 12px);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--ht-eyebrow-ls, 0.15em);
    color: var(--ht-eyebrow-color, currentColor);
    margin: 0 0 2.5rem;
    text-align: var(--ht-align, left);
  }

  /* List of statements */
  .ppp-hashtags__list { display: flex; flex-direction: column; }
  .ppp-hashtags__item {
    padding-block: 1.375rem;
    border-bottom: 1px solid rgba(255,255,255, var(--ht-divider-opacity, 12%));
    text-align: var(--ht-align, left);
  }
  .ppp-hashtags__item:first-child {
    border-top: 1px solid rgba(255,255,255, var(--ht-divider-opacity, 12%));
  }

  /* Primary: big bold uppercase */
  .ppp-hashtags__item--primary .ppp-hashtags__text {
    font-size: var(--ht-primary-size, clamp(2rem, 5.5vw, 4.5rem));
    color: var(--ht-primary-color, currentColor);
    font-weight: var(--section-heading-weight, 800);
    line-height: 1.0;
    letter-spacing: var(--section-heading-ls, -0.025em);
    text-transform: var(--section-heading-transform, uppercase);
    margin: 0;
  }

  /* Secondary: medium, regular case, slightly muted */
  .ppp-hashtags__item--secondary .ppp-hashtags__text {
    font-size: var(--ht-secondary-size, clamp(1.25rem, 3vw, 2.5rem));
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: var(--ht-secondary-ls, -0.01em);
    color: var(--ht-secondary-color, currentColor);
    margin: 0;
  }

  /* Accent: smaller, italic, editorial aside */
  .ppp-hashtags__item--accent .ppp-hashtags__text {
    font-size: var(--ht-accent-size, clamp(1rem, 2.5vw, 1.75rem));
    font-weight: 400;
    font-style: italic;
    line-height: 1.3;
    color: var(--ht-accent-color, currentColor);
    margin: 0;
  }

  .ppp-hashtags__prefix {
    display: inline-block;
    font-size: 0.7em;
    letter-spacing: 0.1em;
    opacity: 0.5;
    margin-right: 0.25em;
    vertical-align: middle;
  }
  .ppp-hashtags__subtext {
    font-size: var(--ht-subtext-size, clamp(0.8rem, 1.5vw, 1rem));
    color: var(--ht-subtext-color, currentColor);
    margin: 0.5rem 0 0;
    line-height: 1.5;
  }

  /* Optional CTA */
  .ppp-hashtags__cta-wrap {
    margin-top: 3rem;
    display: flex;
    justify-content: var(--ht-align, flex-start);
  }
  .ppp-hashtags__cta {
    border-color: rgba(255,255,255,0.35);
    color: #fff;
  }
  .ppp-hashtags__cta:hover { border-color: #fff; }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-hashtags {
      padding-block-start: var(--ht-mob-pt, 48px);
      padding-block-end: var(--ht-mob-pb, 48px);
    }
    .ppp-hashtags__eyebrow { margin-bottom: 1.75rem; }
    .ppp-hashtags__item { padding-block: 1.0625rem; }

    /* Mobile font sizes respect the CSS vars set by the editor */
    .ppp-hashtags__cta-wrap { justify-content: center; }
  }
/* END_SECTION:ppp-pdp-hashtags */

/* START_SECTION:ppp-pdp-how-to (INDEX:31) */
.ppp-how-to {
    padding-block-start: var(--how-to-pt, 72px);
    padding-block-end: var(--how-to-pb, 72px);
  }
  .ppp-how-to__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-how-to__header {
    text-align: center;
    max-width: var(--how-to-header-maxw, 52ch);
    margin-inline: auto;
    margin-bottom: 3rem;
  }
  .ppp-how-to__eyebrow {
    font-size: var(--how-to-eyebrow-size, 12px);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--how-to-eyebrow-ls, 0.1em);
    color: var(--how-to-eyebrow-color, currentColor);
    margin: 0 0 0.75rem;
  }
  .ppp-how-to__heading {
    font-size: var(--how-to-heading-size, 2.25rem);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--how-to-heading-weight, 800);
    line-height: var(--how-to-heading-lh, 1.1);
    white-space: var(--how-to-heading-wrap, normal);
    margin: 0 0 0.75rem;
  }
  .ppp-how-to__subheading {
    font-family: var(--font-subheading--family, var(--font-body--family));
    font-size: var(--how-to-sub-size, 16px);
    letter-spacing: var(--how-to-sub-ls, 0em);
    color: var(--how-to-sub-color, currentColor);
    line-height: 1.6;
    margin: 0;
  }

  /* Track — desktop grid */
  .ppp-how-to__track-wrap { overflow: hidden; }
  .ppp-how-to__track {
    display: grid;
    grid-template-columns: repeat(var(--how-to-cols, 3), 1fr);
    gap: 1.5rem;
  }

  /* Card */
  .ppp-how-to__card {
    display: flex;
    flex-direction: column;
    background: var(--card-bg, var(--color-bg, #fff));
    border-radius: var(--radius-xl, 24px);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
  }
  .ppp-how-to__media {
    aspect-ratio: var(--how-to-img-ratio, 4/3);
    overflow: hidden;
    background: var(--color-surface, #f8f5f0);
    position: relative;
  }
  .ppp-how-to__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.45s var(--ease-out);
  }
  .ppp-how-to__card:hover .ppp-how-to__img { transform: scale(1.04); }
  .ppp-how-to__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .ppp-how-to__video-iframe {
    width: 100%;
    height: 100%;
    border: none;
    display: block;
    pointer-events: none;
  }
  .ppp-how-to__media-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: clamp(2.5rem, 6vw, 4rem);
    font-weight: 900;
    opacity: 0.12;
  }

  /* Card body */
  .ppp-how-to__body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    flex: 1;
  }
  .ppp-how-to__step-label {
    font-size: var(--how-to-step-size, 11px);
    font-family: var(--how-to-card-font, inherit);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--how-to-step-color, currentColor);
    margin: 0;
  }
  .ppp-how-to__title {
    font-size: var(--how-to-title-size, 17px);
    font-family: var(--how-to-card-font, inherit);
    font-weight: var(--how-to-title-weight, 700);
    letter-spacing: var(--how-to-title-ls, 0em);
    text-transform: var(--how-to-title-transform, none);
    color: var(--how-to-title-color, currentColor);
    line-height: 1.3;
    margin: 0;
  }
  .ppp-how-to__desc {
    font-size: var(--how-to-desc-size, 14px);
    font-family: var(--how-to-card-font, inherit);
    font-weight: var(--how-to-desc-weight, 400);
    color: var(--how-to-desc-color, currentColor);
    line-height: var(--how-to-desc-lh, 1.65);
    margin: 0;
  }

  /* CTA */
  .ppp-how-to__cta-wrap {
    display: flex;
    justify-content: center;
    margin-top: 2.5rem;
  }

  /* Bottom heading */
  .ppp-how-to__bot-heading-wrap {
    text-align: var(--how-to-bot-align, center);
    margin-top: var(--how-to-bot-mt, 2rem);
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-how-to__bot-heading {
    font-size: var(--how-to-bot-size, 24px);
    font-family: var(--how-to-bot-font, var(--section-heading-font, inherit));
    font-weight: var(--how-to-bot-weight, 700);
    line-height: var(--how-to-bot-lh, 1.2);
    letter-spacing: var(--how-to-bot-ls, 0em);
    text-transform: var(--how-to-bot-transform, none);
    color: var(--how-to-bot-color, currentColor);
    margin: 0;
  }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-how-to {
      padding-block-start: var(--how-to-mob-pt, 48px);
      padding-block-end: var(--how-to-mob-pb, 48px);
    }

    /* Remove inner padding so track can bleed edge to edge */
    .ppp-how-to__inner { padding-inline: 0; }

    /* Re-apply padding to header and CTA only */
    .ppp-how-to__header,
    .ppp-how-to__cta-wrap {
      padding-inline: var(--page-margin, 1.5rem);
    }
    .ppp-how-to__header { margin-bottom: 1.75rem; }
    .ppp-how-to__heading { font-size: var(--how-to-mob-heading-size, 1.875rem); }

    /* Horizontal scroll carousel */
    .ppp-how-to__track-wrap {
      overflow-x: auto;
      overflow-y: hidden;
      scroll-snap-type: x mandatory;
      scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
    }
    .ppp-how-to__track-wrap::-webkit-scrollbar { display: none; }

    /* Flex row with page-margin inset at both ends */
    .ppp-how-to__track {
      display: flex;
      flex-wrap: nowrap;
      gap: 0.875rem;
      padding: 0.25rem var(--page-margin, 1.5rem) 0.75rem;
      width: max-content;
    }

    /* Fixed-width swipeable cards */
    .ppp-how-to__card {
      flex: 0 0 var(--how-to-mob-card-w, 78vw);
      scroll-snap-align: start;
      border-radius: var(--radius-lg, 16px);
    }
    .ppp-how-to__body { padding: 1.125rem 1.25rem 1.375rem; }
    .ppp-how-to__title { font-size: var(--how-to-mob-title-size, 1rem); }
    .ppp-how-to__desc { font-size: var(--how-to-mob-desc-size, 0.875rem); }
    .ppp-how-to__cta-wrap { padding-inline: var(--page-margin, 1.5rem); }
    .ppp-how-to__bot-heading { font-size: var(--how-to-mob-bot-size, 20px); }
    .ppp-how-to__bot-heading-wrap { padding-inline: var(--page-margin, 1.5rem); }

    /* ── Stack (single-column) mobile layout ── */
    [data-mob-layout="stack"] .ppp-how-to__inner { padding-inline: var(--page-margin, 1.5rem); }
    [data-mob-layout="stack"] .ppp-how-to__header { padding-inline: 0; }
    [data-mob-layout="stack"] .ppp-how-to__track-wrap {
      overflow: visible;
      scroll-snap-type: none;
      -webkit-overflow-scrolling: auto;
    }
    [data-mob-layout="stack"] .ppp-how-to__track {
      display: grid;
      grid-template-columns: 1fr;
      width: auto;
      flex-wrap: wrap;
    }
    [data-mob-layout="stack"] .ppp-how-to__card {
      flex: none;
      scroll-snap-align: none;
    }
    [data-mob-layout="stack"] .ppp-how-to__cta-wrap { padding-inline: 0; }
  }
/* END_SECTION:ppp-pdp-how-to */

/* START_SECTION:ppp-pdp-main (INDEX:32) */
.ppp-pdp {
    background: var(--pdp-bg, #fff);
    color: var(--pdp-fg, #111);
    padding-block-start: var(--pdp-pt, 48px);
    padding-block-end: var(--pdp-pb, 80px);
    width: 100%;
    overflow-x: clip;
  }
  .ppp-pdp__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: start;
    min-width: 0;
  }

  /* ── Gallery ── */
  .ppp-pdp__gallery {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 1rem;
    position: sticky;
    top: calc(var(--hdr-h, 64px) + 1.5rem);
    min-width: 0;
  }
  .ppp-pdp__thumbs {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-height: calc(var(--pdp-gallery-ratio, 4/5) * 100%);
    overflow-y: auto;
    scrollbar-width: none;
  }
  .ppp-pdp__thumbs::-webkit-scrollbar { display: none; }
  .ppp-pdp__thumb {
    width: 80px;
    height: 80px;
    border-radius: var(--radius-md, 8px);
    border: 2px solid transparent;
    overflow: hidden;
    cursor: pointer;
    padding: 0;
    background: var(--color-surface, #f8f5f0);
    transition: border-color 0.15s;
    flex-shrink: 0;
  }
  .ppp-pdp__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .ppp-pdp__thumb.is-active { border-color: var(--color-text, #111); }
  .ppp-pdp__thumb:hover:not(.is-active) { border-color: rgba(0,0,0,0.25); }

  .ppp-pdp__main-media {
    position: relative;
    aspect-ratio: var(--pdp-gallery-ratio, 4/5);
    border-radius: var(--radius-lg, 16px);
    overflow: hidden;
    background: var(--color-surface, #f8f5f0);
  }
  .ppp-pdp__main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: opacity 0.2s;
  }
  .ppp-pdp__main-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    font-weight: 900;
    opacity: 0.1;
  }
  .ppp-pdp__dots {
    position: absolute;
    bottom: 0.75rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 6px;
    z-index: 2;
  }
  .ppp-pdp__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255,255,255,0.5);
    transition: background 0.2s, transform 0.2s;
  }
  .ppp-pdp__dot.is-active { background: #fff; transform: scale(1.4); }

  /* ── Info panel ── */
  .ppp-pdp__info {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    min-width: 0;
  }
  .ppp-pdp__breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.78rem;
    opacity: 0.5;
  }
  .ppp-pdp__breadcrumb a { text-decoration: none; }
  .ppp-pdp__breadcrumb a:hover { text-decoration: underline; }

  .ppp-pdp__badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: var(--color-accent, #c8a882);
    color: var(--color-primary, #111);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-radius: var(--radius-pill);
  }
  .ppp-pdp__title {
    font-size: var(--pdp-title-size, 2.25rem);
    font-family: var(--pdp-font, inherit) !important;
    font-weight: var(--pdp-title-weight, 800);
    letter-spacing: var(--pdp-title-ls, -0.02em);
    line-height: var(--pdp-title-lh, 1.1);
    text-transform: var(--pdp-title-transform, none);
    color: var(--pdp-title-color, currentColor);
  }
  .ppp-pdp__title--upper { text-transform: uppercase; letter-spacing: 0.05em; }
  .ppp-pdp__subtitle {
    font-size: 1rem;
    opacity: 0.65;
    margin-top: -0.5rem;
  }
  .ppp-pdp__reviews-hook { min-height: 24px; }
  .ppp-pdp__price-wrap {
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
    flex-wrap: wrap;
  }
  .ppp-pdp__price { font-size: var(--pdp-price-size, 1.5rem); font-family: var(--pdp-font, inherit) !important; font-weight: var(--pdp-price-weight, 700); letter-spacing: var(--pdp-price-ls, 0em); text-transform: var(--pdp-price-transform, none); color: var(--pdp-price-color, currentColor); }
  .ppp-pdp__compare-price { font-size: 1rem; opacity: 0.45; }
  .ppp-pdp__save {
    padding: 0.2rem 0.6rem;
    background: #fef3cd;
    color: #856404;
    font-size: 0.75rem;
    font-weight: 700;
    border-radius: var(--radius-pill);
  }
  .ppp-pdp__short-desc {
    font-size: var(--pdp-desc-size, 0.95rem);
    font-family: var(--pdp-font, inherit) !important;
    font-weight: var(--pdp-desc-weight, 400);
    line-height: var(--pdp-desc-lh, 1.65);
    letter-spacing: var(--pdp-desc-ls, 0em);
    text-transform: var(--pdp-desc-transform, none);
    color: var(--pdp-desc-color, currentColor);
    opacity: var(--pdp-desc-opacity, 0.75);
  }

  /* Qty stepper — inherit section foreground so it works on dark backgrounds */
  .ppp-pdp .ppp-qty { border-color: var(--pdp-fg, currentColor); opacity: 0.85; }
  .ppp-pdp .ppp-qty__btn { color: var(--pdp-fg, currentColor); }
  .ppp-pdp .ppp-qty__btn:hover { background: rgba(255,255,255,0.1); }
  .ppp-pdp .ppp-qty__input { color: var(--pdp-fg, currentColor); }

  /* Variant options */
  .ppp-pdp__variants { display: flex; flex-direction: column; gap: 1.25rem; }
  .ppp-pdp__option-label {
    font-size: 0.825rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.5rem;
  }
  .ppp-pdp__option-selected { font-weight: 400; text-transform: none; letter-spacing: 0; opacity: 0.7; }
  .ppp-pdp__option-btns { display: flex; flex-wrap: wrap; gap: 0.5rem; }
  .ppp-pdp__option-btn {
    padding: 0.5rem 1.125rem;
    border: 1.5px solid var(--color-border, #e5e5e5);
    border-radius: var(--radius-pill);
    font-family: var(--font-body--family);
    font-size: 0.875rem;
    font-weight: 500;
    background: transparent;
    cursor: pointer;
    color: var(--color-text);
    transition: border-color 0.15s, background 0.15s;
    -webkit-tap-highlight-color: transparent;
  }
  .ppp-pdp__option-btn:hover { border-color: var(--color-text); }
  .ppp-pdp__option-btn.is-active {
    border-color: var(--color-text);
    background: var(--color-text);
    color: var(--color-bg);
  }

  /* Buy row */
  .ppp-pdp__buy-row {
    display: flex;
    gap: 0.75rem;
    align-items: stretch;
  }
  .ppp-pdp__atc { flex: 1; min-height: 52px; font-size: var(--pdp-atc-size, 1rem); }

  /* Availability */
  .ppp-pdp__availability {
    font-size: 0.8rem;
    opacity: 0.55;
    display: flex;
    align-items: center;
    gap: 0.4rem;
  }
  .ppp-pdp__availability::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #2a7a4b;
    flex-shrink: 0;
  }
  .ppp-pdp__availability[data-available="false"] { color: #c0392b; }
  .ppp-pdp__availability[data-available="false"]::before { background: #c0392b; }


  /* Details & Ingredients panels */
  .ppp-pdp__meta-panels {
    display: flex;
    flex-direction: column;
    background: var(--pdp-panel-bg, transparent);
    border-radius: var(--pdp-panel-radius, 0px);
    overflow: hidden;
    border-top: 1px solid var(--pdp-panel-border-color, var(--color-border, rgba(0,0,0,0.15)));
  }
  .ppp-pdp__panel { border-bottom: 1px solid var(--pdp-panel-border-color, var(--color-border, rgba(0,0,0,0.15))); }
  .ppp-pdp__panel-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 1rem var(--pdp-panel-px, 0px);
    cursor: pointer;
    list-style: none;
    font-size: var(--pdp-panel-label-size, 14px);
    font-family: var(--pdp-font, inherit) !important;
    font-weight: var(--pdp-panel-label-weight, 600);
    letter-spacing: var(--pdp-panel-label-ls, 0em);
    text-transform: var(--pdp-panel-label-transform, none);
    color: var(--pdp-panel-label-color, currentColor);
    gap: 0.5rem;
  }
  .ppp-pdp__panel-trigger::-webkit-details-marker { display: none; }
  .ppp-pdp__panel-chevron { flex-shrink: 0; transition: transform 0.25s; color: var(--pdp-panel-label-color, currentColor); }
  .ppp-pdp__panel[open] .ppp-pdp__panel-chevron { transform: rotate(180deg); }
  .ppp-pdp__panel-body {
    padding-bottom: 1rem;
    padding-inline: var(--pdp-panel-px, 0px);
    font-size: var(--pdp-panel-body-size, 14px);
    font-family: var(--pdp-font, inherit) !important;
    font-weight: var(--pdp-panel-body-weight, 400);
    line-height: var(--pdp-panel-body-lh, 1.65);
    letter-spacing: var(--pdp-panel-body-ls, 0em);
    text-transform: var(--pdp-panel-body-transform, none);
    color: var(--pdp-panel-body-color, currentColor);
    opacity: var(--pdp-panel-body-opacity, 0.8);
  }
  .ppp-pdp__panel-body p { margin: 0 0 0.5rem; }
  .ppp-pdp__panel-body p:last-child { margin-bottom: 0; }
  @media (max-width: 749px) {
    .ppp-pdp__panel-trigger { font-size: var(--pdp-mob-panel-label-size, 14px); }
    .ppp-pdp__panel-body { font-size: var(--pdp-mob-panel-body-size, 13px); }
  }

  /* Key stats */
  .ppp-pdp__stats {
    display: flex;
    gap: 0;
    border: 1px solid var(--color-border, #e5e5e5);
    border-radius: var(--radius-lg, 16px);
    overflow: hidden;
  }
  .ppp-pdp__stat {
    flex: 1;
    text-align: center;
    padding: 1rem 0.75rem;
    border-right: 1px solid var(--color-border, #e5e5e5);
  }
  .ppp-pdp__stat:last-child { border-right: none; }
  .ppp-pdp__stat strong { display: block; font-size: 1.25rem; font-weight: 800; letter-spacing: -0.02em; }
  .ppp-pdp__stat span { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; opacity: 0.5; }

  /* Flavor notes */
  .ppp-pdp__flavor-notes {
    padding: 1rem 1.25rem;
    background: var(--color-surface, #f8f5f0);
    border-radius: var(--radius-md, 8px);
  }
  .ppp-pdp__flavor-label { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; opacity: 0.5; margin-bottom: 0.3rem; }
  .ppp-pdp__flavor-val { font-size: 0.9rem; font-weight: 500; font-style: italic; }

  /* ── Feature badges ── */
  .ppp-pdp__badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: var(--pdp-badge-justify, center);
    gap: var(--pdp-badge-gap, 12px);
    padding-block: var(--pdp-badge-pt, 4px) var(--pdp-badge-pb, 4px);
  }
  .ppp-pdp__badge-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    flex: 0 1 auto;
  }
  .ppp-pdp__badge-icon {
    width: var(--pdp-badge-size, 40px);
    height: var(--pdp-badge-size, 40px);
    object-fit: contain;
    display: block;
    flex-shrink: 0;
  }
  .ppp-pdp__badge-label {
    font-size: var(--pdp-badge-label-size, 11px);
    font-weight: var(--pdp-badge-label-weight, 600);
    font-family: var(--pdp-font, inherit) !important;
    text-align: center;
    line-height: 1.3;
    opacity: 0.65;
    max-width: 80px;
  }
  .ppp-pdp__badge-sub {
    font-size: calc(var(--pdp-badge-label-size, 11px) - 1px);
    font-family: var(--pdp-font, inherit) !important;
    text-align: center;
    opacity: 0.4;
    line-height: 1.3;
    max-width: 80px;
  }

  /* ── Upsell cards ── */
  .ppp-pdp__upsell {
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    font-family: var(--pdp-upsell-font, inherit);
  }
  .ppp-pdp__upsell-heading {
    font-family: var(--pdp-upsell-font, inherit);
    font-size: var(--pdp-upsell-heading-size, 11px);
    font-weight: var(--pdp-upsell-heading-weight, 700);
    letter-spacing: var(--pdp-upsell-heading-ls, 0.1em);
    text-transform: var(--pdp-upsell-heading-transform, uppercase);
    color: var(--pdp-upsell-heading-color, currentColor);
    opacity: 0.55;
    margin: 0;
  }
  .ppp-pdp__upsell-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1px solid var(--color-border, rgba(0,0,0,0.12));
    border-radius: var(--pdp-upsell-card-radius, 12px);
    overflow: hidden;
  }
  .ppp-pdp__upsell-card {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    padding: 0.75rem;
    background: var(--pdp-upsell-card-bg, transparent);
    border-bottom: 1px solid var(--color-border, rgba(0,0,0,0.12));
    transition: background 0.15s;
  }
  .ppp-pdp__upsell-card:last-child { border-bottom: none; }
  .ppp-pdp__upsell-card:hover { background: var(--pdp-upsell-card-bg, rgba(0,0,0,0.02)); }
  .ppp-pdp__upsell-media {
    flex-shrink: 0;
    width: var(--pdp-upsell-img-size, 80px);
    height: var(--pdp-upsell-img-size, 80px);
    border-radius: calc(var(--pdp-upsell-card-radius, 12px) - 4px);
    overflow: hidden;
    background: var(--color-surface, #f5f5f5);
    display: block;
  }
  .ppp-pdp__upsell-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
  }
  .ppp-pdp__upsell-media:hover .ppp-pdp__upsell-img { transform: scale(1.06); }
  .ppp-pdp__upsell-img-ph {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 900;
    opacity: 0.15;
  }
  .ppp-pdp__upsell-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
  }
  .ppp-pdp__upsell-title {
    font-family: var(--pdp-upsell-font, inherit);
    font-size: var(--pdp-upsell-title-size, 14px);
    font-weight: var(--pdp-upsell-title-weight, 600);
    letter-spacing: var(--pdp-upsell-title-ls, 0em);
    text-transform: var(--pdp-upsell-title-transform, none);
    line-height: 1.3;
    color: var(--pdp-upsell-title-color, currentColor);
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .ppp-pdp__upsell-title:hover { text-decoration: underline; }
  .ppp-pdp__upsell-price {
    font-size: 0.8rem;
    font-weight: 500;
    opacity: 0.6;
    margin: 0;
    display: flex;
    gap: 0.35rem;
    align-items: baseline;
  }
  .ppp-pdp__upsell-price-sale { color: #c0392b; opacity: 1; font-weight: 700; }
  .ppp-pdp__upsell-price-was { text-decoration: line-through; font-weight: 400; opacity: 0.7; }
  .ppp-pdp__upsell-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 36px;
    padding: 0 1rem;
    background: var(--pdp-upsell-btn-bg, #111);
    color: var(--pdp-upsell-btn-fg, #fff);
    border: none;
    border-radius: 999px;
    font-family: var(--pdp-upsell-font, inherit);
    font-size: var(--pdp-upsell-btn-size, 12px);
    font-weight: var(--pdp-upsell-btn-weight, 700);
    letter-spacing: var(--pdp-upsell-btn-ls, 0em);
    text-transform: var(--pdp-upsell-btn-transform, none);
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    transition: opacity 0.2s;
  }
  .ppp-pdp__upsell-btn:hover { opacity: 0.78; }
  .ppp-pdp__upsell-btn--soldout { opacity: 0.35; cursor: default; }
  .ppp-pdp__upsell-btn:disabled { opacity: 0.6; cursor: default; }

  /* ── Sticky mobile ATC ── */
  .ppp-sticky-atc {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: var(--z-sticky, 100);
    background: var(--color-bg, #fff);
    border-top: 1px solid var(--color-border, #e5e5e5);
    transform: translateY(100%);
    transition: transform 0.3s var(--ease-out);
    box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
    display: none;
  }
  .ppp-sticky-atc--visible { transform: translateY(0); }
  .ppp-sticky-atc__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.875rem var(--page-margin, 1.5rem);
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
  }
  .ppp-sticky-atc__info { display: flex; align-items: center; gap: 0.75rem; overflow: hidden; }
  .ppp-sticky-atc__img { width: 44px; height: 44px; object-fit: cover; border-radius: var(--radius-md, 8px); flex-shrink: 0; }
  .ppp-sticky-atc__title { font-size: 0.875rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 160px; }
  .ppp-sticky-atc__price { font-size: 0.825rem; opacity: 0.6; }
  .ppp-sticky-atc__btn { min-width: 140px; white-space: nowrap; }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-pdp {
      padding-block-start: var(--pdp-mob-pt, 0px);
      padding-block-end: var(--pdp-mob-pb, 48px);
    }
    .ppp-pdp__inner {
      grid-template-columns: 1fr;
      gap: var(--pdp-mob-gallery-info-gap, 0px);
      padding-inline: 0;
    }
    /* Gallery */
    .ppp-pdp__gallery {
      grid-template-columns: 1fr;
      position: static;
      gap: 0;
    }
    .ppp-pdp__thumbs { display: none; }
    .ppp-pdp__gallery--mob-thumbs {
      display: flex;
      flex-direction: column-reverse;
    }
    .ppp-pdp__gallery--mob-thumbs .ppp-pdp__thumbs {
      display: flex;
      flex-direction: row;
      max-height: none;
      overflow-x: auto;
      overflow-y: hidden;
      padding: 0.625rem var(--page-margin, 1.5rem);
      gap: 0.5rem;
      scrollbar-width: none;
      min-width: 0;
    }
    .ppp-pdp__gallery--mob-thumbs .ppp-pdp__thumbs::-webkit-scrollbar { display: none; }
    .ppp-pdp__gallery--mob-thumbs .ppp-pdp__thumb {
      width: 60px;
      height: 60px;
      flex-shrink: 0;
    }
    .ppp-pdp__main-media {
      border-radius: var(--pdp-mob-gallery-radius, 0px);
      aspect-ratio: var(--pdp-mob-gallery-ratio, 1/1);
    }
    /* Info panel */
    .ppp-pdp__info {
      padding-block-start: var(--pdp-mob-info-pt, 24px);
      padding-block-end: var(--pdp-mob-info-pb, 24px);
      padding-inline: var(--page-margin, 1.5rem);
      gap: var(--pdp-mob-info-gap, 20px);
    }
    /* Buy row */
    .ppp-sticky-atc { display: block; }
    .ppp-pdp__buy-row { gap: 0.5rem; }
    .ppp-pdp__atc {
      min-height: var(--pdp-mob-atc-h, 52px);
      font-size: var(--pdp-mob-atc-size, var(--pdp-atc-size, 1rem));
    }
    /* Show/hide */
    .ppp-pdp__short-desc { display: var(--pdp-mob-desc-display, block); }
    .ppp-pdp .ppp-qty { display: var(--pdp-mob-qty-display, flex); }
    /* Typography */
    .ppp-pdp__title { font-size: var(--pdp-mob-title-size, 1.75rem); }
    .ppp-pdp__short-desc {
      font-size: var(--pdp-mob-desc-size, 0.875rem);
      font-weight: var(--pdp-mob-desc-weight, var(--pdp-desc-weight, 400));
      line-height: var(--pdp-mob-desc-lh, var(--pdp-desc-lh, 1.65));
      letter-spacing: var(--pdp-mob-desc-ls, var(--pdp-desc-ls, 0em));
    }
    .ppp-pdp__price { font-size: var(--pdp-mob-price-size, 1.25rem); }
  }
/* END_SECTION:ppp-pdp-main */

/* START_SECTION:ppp-pdp-related (INDEX:33) */
.ppp-related {
    padding-block-start: var(--rel-pt, 64px);
    padding-block-end: var(--rel-pb, 64px);
  }
  .ppp-related__inner {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-related__heading {
    font-size: var(--rel-heading-size, 1.75rem);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--rel-heading-weight, 700);
    letter-spacing: var(--rel-heading-ls, -0.02em);
    margin-bottom: 2rem;
    text-align: center;
  }
  .ppp-related__grid { position: relative; }
  .ppp-related__track {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .ppp-related__track::-webkit-scrollbar { display: none; }
  .ppp-related__card {
    scroll-snap-align: start;
    flex-shrink: 0;
    background: var(--color-bg, #fff);
    border-radius: var(--radius-lg, 16px);
    overflow: hidden;
  }
  .ppp-related__card-img-wrap { aspect-ratio: 1/1; overflow: hidden; background: var(--color-surface, #f8f5f0); }
  .ppp-related__card-img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; display: block; }
  .ppp-related__card:hover .ppp-related__card-img { transform: scale(1.04); }
  .ppp-related__card-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 3rem; font-weight: 900; opacity: 0.1; }
  .ppp-related__card-info { padding: 0.75rem 1rem 1rem; display: flex; flex-direction: column; gap: 0.25rem; }
  .ppp-related__card-link { display: block; }
  .ppp-related__card-title { font-size: var(--rel-card-title-size, 14px); letter-spacing: var(--rel-card-title-ls, 0em); font-weight: 600; text-decoration: none; color: var(--rel-card-title-color, currentColor); line-height: 1.3; }
  .ppp-related__card-title:hover { text-decoration: underline; }
  .ppp-related__card-price { font-size: var(--rel-price-size, 14px); font-weight: 700; color: var(--rel-price-color, currentColor); }
  .ppp-related__atc { margin-top: 0.5rem; font-size: 0.8rem; }
  .ppp-related__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: var(--color-bg, #fff);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-border, #e5e5e5);
    z-index: 2;
    display: none;
  }
  @media (min-width: 750px) {
    .ppp-related__nav { display: flex; }
    .ppp-related__nav--prev { left: -1.25rem; }
    .ppp-related__nav--next { right: -1.25rem; }
  }

  @media (max-width: 749px) {
    .ppp-related {
      padding-block-start: var(--rel-mob-pt, 40px);
      padding-block-end: var(--rel-mob-pb, 40px);
    }
    .ppp-related__track {
      grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
      scroll-snap-type: none;
    }
  }
/* END_SECTION:ppp-pdp-related */

/* START_SECTION:ppp-popup (INDEX:34) */
/* ── Prevent body scroll when popup open ── */
  body.ppp-popup-open { overflow: hidden; }

  /* ── Overlay ── */
  .ppp-popup__overlay {
    position: fixed;
    inset: 0;
    z-index: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s ease;
  }
  .ppp-popup__overlay::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--popup-overlay-color, #000);
    opacity: var(--popup-overlay-opacity, 0.55);
  }
  .ppp-popup__overlay.is-visible {
    opacity: 1;
    pointer-events: auto;
  }

  /* ── Modal ── */
  .ppp-popup__modal {
    font-family: var(--popup-font, inherit);
    position: relative;
    width: 100%;
    max-width: var(--popup-max-w, 520px);
    max-height: 90dvh;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
    background: var(--popup-bg, #fff);
    color: var(--popup-fg, #111);
    border-radius: var(--popup-radius, 16px);
    box-shadow: 0 24px 80px rgba(0,0,0,0.28);
    transform: translateY(24px);
    transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
    outline: none;
  }
  .ppp-popup__modal.is-visible { transform: translateY(0); }

  /* ── Two-column layout (with image) ── */
  .ppp-popup__modal--has-img {
    display: grid;
    max-width: calc(var(--popup-max-w, 520px) + 340px);
  }
  .ppp-popup__modal--img-left  { grid-template-columns: 320px 1fr; }
  .ppp-popup__modal--img-right { grid-template-columns: 1fr 320px; }
  .ppp-popup__modal--img-top   {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
  }
  .ppp-popup__modal--img-right .ppp-popup__img-col { order: 2; }

  /* ── Image column ── */
  .ppp-popup__img-col {
    overflow: hidden;
    border-radius: var(--popup-radius, 16px) 0 0 var(--popup-radius, 16px);
  }
  .ppp-popup__modal--img-right .ppp-popup__img-col {
    border-radius: 0 var(--popup-radius, 16px) var(--popup-radius, 16px) 0;
  }
  .ppp-popup__modal--img-top .ppp-popup__img-col {
    border-radius: var(--popup-radius, 16px) var(--popup-radius, 16px) 0 0;
  }
  .ppp-popup__img { width: 100%; height: 100%; object-fit: cover; display: block; }

  /* ── Background image mode ── */
  .ppp-popup__modal--img-background { display: block; }
  .ppp-popup__bg-img {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    border-radius: inherit;
  }
  .ppp-popup__bg-overlay {
    position: absolute;
    inset: 0;
    background: var(--popup-overlay-color, #000);
    opacity: var(--popup-overlay-opacity, 0.5);
    border-radius: inherit;
  }

  /* ── Content ── */
  .ppp-popup__content {
    position: relative;
    padding: 2.5rem 2.25rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  /* ── Close button ── */
  .ppp-popup__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 2;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: rgba(0,0,0,0.08);
    color: var(--popup-fg, #111);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
    flex-shrink: 0;
  }
  .ppp-popup__close:hover { background: rgba(0,0,0,0.15); }

  /* ── Text elements ── */
  .ppp-popup__eyebrow {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    opacity: 0.55;
    margin: 0 0 0.625rem;
  }
  .ppp-popup__heading {
    font-size: var(--popup-heading-size, 32px);
    font-family: var(--popup-heading-font, var(--popup-font, var(--section-heading-font, inherit)));
    font-weight: var(--popup-heading-weight, 800);
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0 0 0.875rem;
  }
  .ppp-popup__subtext {
    font-size: var(--popup-body-size, 15px);
    line-height: 1.6;
    opacity: 0.7;
    margin: 0 0 1.5rem;
    max-width: 34ch;
  }

  /* ── Form ── */
  .ppp-popup__form {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
  }
  .ppp-popup__input {
    width: 100%;
    padding: 0.8rem 1rem;
    border: 1.5px solid rgba(0,0,0,0.18);
    border-radius: var(--popup-input-radius, 8px);
    font-size: var(--popup-body-size, 15px);
    font-family: inherit;
    background: transparent;
    color: var(--popup-fg, #111);
    transition: border-color 0.15s, box-shadow 0.15s;
    outline: none;
    -webkit-appearance: none;
  }
  .ppp-popup__input:focus {
    border-color: var(--popup-btn-bg, #111);
    box-shadow: 0 0 0 3px rgba(0,0,0,0.08);
  }
  .ppp-popup__input::placeholder { opacity: 0.45; }
  .ppp-popup__error {
    font-size: 13px;
    color: #c0392b;
    margin: 0;
    text-align: left;
  }

  /* ── Buttons ── */
  .ppp-popup__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.875rem 1.5rem;
    background: var(--popup-btn-bg, #111);
    color: var(--popup-btn-fg, #fff);
    border: none;
    border-radius: var(--popup-input-radius, 8px);
    font-size: var(--popup-btn-size, 15px);
    font-weight: 700;
    font-family: inherit;
    letter-spacing: 0.01em;
    cursor: pointer;
    transition: opacity 0.15s, transform 0.1s;
    text-decoration: none;
    margin-top: 0.25rem;
  }
  .ppp-popup__btn:hover { opacity: 0.88; }
  .ppp-popup__btn:active { transform: scale(0.98); }
  .ppp-popup__btn[data-loading] { opacity: 0.65; pointer-events: none; }
  .ppp-popup__btn[data-loading] .ppp-popup__btn-label { opacity: 0.5; }
  .ppp-popup__btn--cta { margin-top: 1rem; }

  /* Spinner */
  .ppp-popup__btn-spinner {
    display: none;
    animation: ppp-popup-spin 0.8s linear infinite;
    flex-shrink: 0;
  }
  .ppp-popup__btn[data-loading] .ppp-popup__btn-spinner { display: block; }
  @keyframes ppp-popup-spin { to { transform: rotate(360deg); } }

  /* ── Disclaimer / no thanks ── */
  .ppp-popup__disclaimer {
    font-size: 11px;
    opacity: 0.45;
    margin: 0.875rem 0 0;
    line-height: 1.5;
    max-width: 32ch;
  }
  .ppp-popup__no-thanks {
    margin-top: 0.75rem;
    background: none;
    border: none;
    font-size: 12px;
    opacity: 0.4;
    cursor: pointer;
    text-decoration: underline;
    color: inherit;
    font-family: inherit;
    padding: 0.25rem;
    transition: opacity 0.15s;
  }
  .ppp-popup__no-thanks:hover { opacity: 0.7; }

  /* ── Success state ── */
  .ppp-popup__success-icon {
    font-size: 2.75rem;
    margin-bottom: 0.75rem;
    line-height: 1;
  }

  /* ── Discount code ── */
  .ppp-popup__code-wrap {
    display: flex;
    align-items: center;
    gap: 0;
    border: 2px dashed var(--popup-code-fg, var(--popup-btn-bg, #111));
    border-radius: var(--popup-input-radius, 8px);
    overflow: hidden;
    margin: 0.5rem 0 0.5rem;
    width: 100%;
  }
  .ppp-popup__code {
    flex: 1;
    padding: 0.75rem 1rem;
    font-size: 1.1rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    font-family: 'Courier New', monospace;
    color: var(--popup-code-fg, var(--popup-fg, #111));
    background: var(--popup-code-bg, transparent);
    user-select: all;
  }
  .ppp-popup__copy-btn {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.75rem 1rem;
    background: var(--popup-btn-bg, #111);
    color: var(--popup-btn-fg, #fff);
    border: none;
    font-size: 13px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 0.15s;
    flex-shrink: 0;
  }
  .ppp-popup__copy-btn:hover { opacity: 0.85; }
  .ppp-popup__copy-btn.is-copied { opacity: 0.7; }
  .ppp-popup__code-hint {
    font-size: 12px;
    opacity: 0.45;
    margin: 0 0 1rem;
  }

  /* ── Mobile ── */
  @media (max-width: 749px) {
    .ppp-popup__overlay { padding: 0.75rem; align-items: flex-end; }
    .ppp-popup__modal {
      max-width: 100%;
      max-height: 92dvh;
      border-radius: var(--popup-radius, 16px) var(--popup-radius, 16px) var(--popup-radius, 16px) var(--popup-radius, 16px);
      transform: translateY(40px);
    }
    .ppp-popup__modal--has-img { grid-template-columns: 1fr !important; }
    .ppp-popup__img-col {
      max-height: 220px;
      border-radius: var(--popup-radius, 16px) var(--popup-radius, 16px) 0 0 !important;
      order: 0 !important;
    }
    .ppp-popup__content { padding: 1.75rem 1.5rem; }
    .ppp-popup__heading { font-size: var(--popup-mob-heading-size, 26px); }
  }
/* END_SECTION:ppp-popup */

/* START_SECTION:ppp-product-showcase (INDEX:35) */
.ppp-showcase {
    padding-block-start: var(--ppp-sc-pt, 72px);
    padding-block-end: var(--ppp-sc-pb, 72px);
  }
  .ppp-showcase__inner {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-showcase__heading {
    text-align: var(--ppp-sc-heading-align, center);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--section-heading-weight, 800);
    letter-spacing: var(--section-heading-ls, 0.02em);
    text-transform: var(--section-heading-transform, uppercase);
    font-size: var(--ppp-sc-heading-size, 2.75rem);
    line-height: 1.1;
    margin-bottom: 2rem;
  }
  .ppp-showcase__layout {
    display: grid;
    grid-template-columns: var(--ppp-sc-list-width, 250px) 1fr 1fr;
    gap: var(--ppp-sc-gap, 20px);
    align-items: start;
  }
  .ppp-showcase__list { display: flex; flex-direction: column; gap: var(--ppp-sc-list-gap, 10px); }
  .ppp-showcase__list-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    background: rgba(255,255,255,0.55);
    border: 2px solid rgba(0,0,0,0.15);
    border-radius: 12px;
    cursor: pointer;
    text-align: left;
    width: 100%;
    color: currentColor;
    font-family: inherit;
    transition: background 0.2s, border-color 0.2s, box-shadow 0.2s;
  }
  .ppp-showcase__list-item:hover { background: rgba(255,255,255,0.8); border-color: currentColor; }
  .ppp-showcase__list-item--active { background: rgba(255,255,255,0.95); border-color: currentColor; box-shadow: 0 2px 12px rgba(0,0,0,0.1); }
  .ppp-showcase__thumb {
    flex-shrink: 0;
    width: 52px;
    height: 52px;
    border-radius: 8px;
    overflow: hidden;
    background: rgba(255,255,255,0.4);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .ppp-showcase__thumb-img { width: 100%; height: 100%; object-fit: contain; }
  .ppp-showcase__thumb-placeholder { width: 100%; height: 100%; background: rgba(128,128,128,0.2); }
  .ppp-showcase__list-name { flex: 1; font-weight: 700; font-size: var(--ppp-sc-list-name-size, 13px); line-height: 1.3; text-transform: uppercase; letter-spacing: var(--ppp-sc-list-name-ls, 0.02em); }
  .ppp-showcase__list-icon { font-size: 1.25rem; flex-shrink: 0; }
  .ppp-showcase__hero {
    position: relative;
    border-radius: var(--ppp-sc-hero-radius, 16px);
    overflow: hidden;
    aspect-ratio: var(--ppp-sc-hero-ratio, 4/5);
    background: rgba(128,128,128,0.1);
  }
  .ppp-showcase__slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.4s ease; pointer-events: none; }
  .ppp-showcase__slide--active { opacity: 1; pointer-events: auto; }
  .ppp-showcase__hero-img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .ppp-showcase__hero-placeholder { width: 100%; height: 100%; background: rgba(128,128,128,0.15); }
  .ppp-showcase__panels { position: relative; }
  .ppp-showcase__panel {
    display: none;
    flex-direction: column;
    gap: 1rem;
    background: var(--ppp-sc-panel-bg, #ffffff);
    color: #1a1a1a;
    border-radius: var(--ppp-sc-panel-radius, 16px);
    padding: var(--ppp-sc-panel-padding, 28px);
    box-shadow: 0 4px 24px rgba(0,0,0,0.1);
  }
  .ppp-showcase__panel--active { display: flex; animation: ppp-sc-in 0.3s ease both; }
  @keyframes ppp-sc-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
  .ppp-showcase__panel-title { font-size: var(--ppp-sc-panel-title-size, 16px); font-weight: 800; text-transform: uppercase; letter-spacing: var(--ppp-sc-panel-title-ls, 0.04em); margin: 0; line-height: 1.3; color: #1a1a1a; }
  .ppp-showcase__tabs { display: flex; gap: 1.5rem; border-bottom: 1px solid rgba(0,0,0,0.1); }
  .ppp-showcase__tab { background: none; border: none; padding: 0.5rem 0; font-size: var(--ppp-sc-tab-size, 14px); font-weight: 600; cursor: pointer; color: #1a1a1a; opacity: 0.5; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: opacity 0.2s, border-color 0.2s; font-family: inherit; }
  .ppp-showcase__tab--active { opacity: 1; border-bottom-color: #1a1a1a; }
  .ppp-showcase__pane { display: none; }
  .ppp-showcase__pane--active { display: block; }
  .ppp-showcase__desc { font-size: var(--ppp-sc-desc-size, 15px); line-height: 1.7; color: #333; }
  .ppp-showcase__desc p { margin: 0; }
  .ppp-showcase__actions { display: flex; flex-direction: column; gap: 0.625rem; margin-top: 0.5rem; }
  .ppp-showcase__form { display: contents; }
  .ppp-showcase__atc {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0.875rem 1.5rem;
    background: #1a1a1a;
    color: #ffffff;
    border: none;
    border-radius: 999px;
    font-weight: 700;
    font-size: var(--ppp-sc-atc-size, 15px);
    letter-spacing: var(--ppp-sc-atc-ls, 0em);
    font-family: inherit;
    cursor: pointer;
    text-decoration: none;
    transition: opacity 0.2s;
  }
  .ppp-showcase__atc:hover { opacity: 0.85; }
  .ppp-showcase__atc:disabled { opacity: 0.4; cursor: not-allowed; }
  .ppp-showcase__learn-more { display: block; text-align: center; text-decoration: underline; font-size: 0.9rem; font-weight: 600; color: #1a1a1a; transition: opacity 0.2s; }
  .ppp-showcase__learn-more:hover { opacity: 0.65; }
  @media (max-width: 1024px) { .ppp-showcase__layout { grid-template-columns: 200px 1fr 1fr; } }
  @media (max-width: 749px) {
    .ppp-showcase {
      padding-block-start: var(--ppp-sc-mob-pt, 48px);
      padding-block-end: var(--ppp-sc-mob-pb, 48px);
    }
    .ppp-showcase__heading { font-size: var(--ppp-sc-mob-heading-size, 28px); }
    .ppp-showcase__layout { grid-template-columns: 1fr; }
    .ppp-showcase__list { flex-direction: row; overflow-x: auto; padding-bottom: 4px; scrollbar-width: none; }
    .ppp-showcase__list::-webkit-scrollbar { display: none; }
    .ppp-showcase__list-item { min-width: var(--ppp-sc-mob-list-min-w, 140px); flex-shrink: 0; }
    .ppp-showcase__hero { aspect-ratio: var(--ppp-sc-mob-hero-ratio, 1/1); }
    .ppp-showcase__panel { padding: var(--ppp-sc-mob-panel-padding, 20px); }
  }
/* END_SECTION:ppp-product-showcase */

/* START_SECTION:ppp-scrolling-media (INDEX:36) */
.ppp-sm {
    background: var(--sm-bg);
    padding-block-start: var(--sm-pt);
    padding-block-end: var(--sm-pb);
    overflow: hidden;
    position: relative;
    z-index: var(--sm-z);
    min-width: 0;
    width: 100%;
  }
  .ppp-sm__header {
    text-align: center;
    padding-inline: var(--page-margin, 1.5rem);
    margin-block-end: 2rem;
  }
  .ppp-sm__eyebrow {
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--sm-eyebrow-color);
    margin: 0 0 0.5rem;
    font-family: var(--sm-heading-font, inherit);
  }
  .ppp-sm__heading {
    font-size: clamp(1.5rem, 4vw, 2.5rem);
    font-weight: 700;
    color: var(--sm-heading-color);
    margin: 0;
    font-family: var(--sm-heading-font, inherit);
    line-height: 1.2;
  }
  .ppp-sm__track-wrap {
    display: flex;
    align-items: stretch;
    gap: var(--sm-gap);
    overflow: hidden;
    width: 100%;
  }
  .ppp-sm__track {
    display: flex;
    align-items: stretch;
    gap: var(--sm-gap);
    flex-shrink: 0;
    animation: ppp-sm-scroll var(--sm-speed) linear infinite;
    will-change: transform;
  }
  [data-direction="reverse"] .ppp-sm__track {
    animation-direction: reverse;
  }
  [data-pause="true"] .ppp-sm__track-wrap:hover .ppp-sm__track {
    animation-play-state: paused;
  }
  @keyframes ppp-sm-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(calc(-100% - var(--sm-gap, 16px))); }
  }
  @media (prefers-reduced-motion: reduce) {
    .ppp-sm__track {
      animation: none;
    }
    .ppp-sm__track-wrap {
      overflow-x: auto;
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
    }
    .ppp-sm__track-wrap::-webkit-scrollbar { display: none; }
    .ppp-sm__track-wrap .ppp-sm__track:last-child {
      display: none;
    }
    .ppp-sm__tile {
      scroll-snap-align: start;
    }
  }
  .ppp-sm__tile {
    flex-shrink: 0;
    width: var(--sm-tile-w);
    background: var(--sm-tile-bg);
    border-radius: var(--sm-radius);
    overflow: hidden;
    display: block;
  }
  .ppp-sm__tile-link {
    display: block;
    width: 100%;
    height: 100%;
  }
  .ppp-sm__img {
    display: block;
    width: 100%;
    aspect-ratio: var(--sm-ratio);
    object-fit: {{ section.settings.image_fit | default: 'cover' }};
    border-radius: var(--sm-radius);
    transition: transform 0.4s ease, opacity 0.3s ease;
  }
  .ppp-sm__tile-link:hover .ppp-sm__img,
  .ppp-sm__tile-link:focus .ppp-sm__img {
    transform: scale(1.04);
    opacity: 0.9;
  }
  @media (max-width: 749px) {
    .ppp-sm {
      padding-block-start: var(--sm-mob-pt);
      padding-block-end: var(--sm-mob-pb);
    }
    .ppp-sm__tile {
      width: var(--sm-mob-tile-w);
    }
    .ppp-sm__header {
      margin-block-end: 1.25rem;
    }
  }
/* END_SECTION:ppp-scrolling-media */

/* START_SECTION:ppp-social-ugc (INDEX:37) */
.ppp-ugc {
    padding-block-start: var(--ugc-pt, 72px);
    padding-block-end: var(--ugc-pb, 72px);
  }
  .ppp-ugc__inner {
    max-width: var(--section-content-w, var(--page-width, 75rem));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-ugc__header {
    text-align: center;
    margin-bottom: 2.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
  }
  .ppp-ugc__handle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: var(--ugc-handle-size, 14px);
    letter-spacing: var(--ugc-handle-ls, 0em);
    font-weight: 600;
    color: var(--ugc-handle-color, currentColor);
    text-decoration: none;
    transition: opacity 0.2s;
  }
  .ppp-ugc__handle:hover { opacity: 0.8; }
  .ppp-ugc__heading {
    font-size: var(--ugc-heading-size, 2rem);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--section-heading-weight, 800);
    letter-spacing: var(--section-heading-ls, -0.02em);
    text-transform: var(--section-heading-transform, none);
    margin: 0;
  }
  .ppp-ugc__subheading {
    font-family: var(--font-subheading--family, var(--font-body--family));
    font-size: var(--ugc-sub-size, 15px);
    letter-spacing: var(--ugc-sub-ls, 0em);
    color: var(--ugc-sub-color, currentColor);
    max-width: 480px;
    line-height: 1.5;
    margin: 0;
  }
  .ppp-ugc__grid { position: relative; }
  .ppp-ugc__track {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.75rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .ppp-ugc__track::-webkit-scrollbar { display: none; }
  .ppp-ugc__item {
    scroll-snap-align: start;
    flex-shrink: 0;
  }
  .ppp-ugc__img-wrap {
    position: relative;
    aspect-ratio: 1/1;
    overflow: hidden;
    border-radius: var(--radius-md, 12px);
    background: var(--color-border, #e5e5e5);
  }
  .ppp-ugc__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s var(--ease-out);
  }
  .ppp-ugc__item:hover .ppp-ugc__img { transform: scale(1.04); }
  .ppp-ugc__img-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .ppp-ugc__overlay-link {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0);
    transition: background 0.25s;
    border-radius: inherit;
  }
  .ppp-ugc__overlay-link svg { opacity: 0; transition: opacity 0.25s; }
  .ppp-ugc__item:hover .ppp-ugc__overlay-link { background: rgba(0,0,0,0.35); }
  .ppp-ugc__item:hover .ppp-ugc__overlay-link svg { opacity: 1; }
  .ppp-ugc__caption {
    font-size: var(--ugc-caption-size, 12px);
    color: var(--ugc-caption-color, currentColor);
    margin-top: 0.4rem;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .ppp-ugc__cta {
    display: flex;
    justify-content: center;
    margin-top: 2rem;
  }

  @media (max-width: 989px) {
    .ppp-ugc__track { grid-template-columns: repeat(4, minmax(160px, 1fr)); }
  }
  @media (max-width: 749px) {
    .ppp-ugc {
      padding-block-start: var(--ugc-mob-pt, 48px);
      padding-block-end: var(--ugc-mob-pb, 48px);
    }
    .ppp-ugc__track { grid-template-columns: repeat(3, minmax(130px, 1fr)); gap: 0.5rem; }
    .ppp-ugc__header { margin-bottom: 1.5rem; }
  }
/* END_SECTION:ppp-social-ugc */

/* START_SECTION:ppp-svg-scroll (INDEX:38) */
.ppp-svg-scroll {
    position: relative;
    z-index: var(--svg-z, 1);
    padding-block-start: var(--svg-pt, 0px);
    padding-block-end: var(--svg-pb, 0px);
    margin-top: var(--svg-mt, 0px);
    margin-bottom: var(--svg-mb, 0px);
    overflow: hidden;
    pointer-events: none;
  }
  .ppp-svg-scroll__wrap {
    max-width: var(--page-width, 75rem);
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
    display: flex;
    justify-content: var(--svg-justify, center);
  }
  .ppp-svg-scroll__img {
    width: var(--svg-size, 120px);
    height: auto;
    display: block;
    flex-shrink: 0;
    will-change: transform;
  }
  .ppp-svg-scroll__placeholder {
    width: var(--svg-size, 120px);
    height: var(--svg-size, 120px);
    border: 2px dashed rgba(128,128,128,0.4);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 600;
    color: rgba(128,128,128,0.5);
    letter-spacing: 0.05em;
  }
  @media (max-width: 749px) {
    .ppp-svg-scroll {
      padding-block-start: var(--svg-mob-pt, var(--svg-pt, 0px));
      padding-block-end: var(--svg-mob-pb, var(--svg-pb, 0px));
      margin-top: var(--svg-mob-mt, var(--svg-mt, 0px));
      margin-bottom: var(--svg-mob-mb, var(--svg-mb, 0px));
    }
    .ppp-svg-scroll__img {
      width: var(--svg-mob-size, var(--svg-size, 80px));
    }
    .ppp-svg-scroll__placeholder {
      width: var(--svg-mob-size, var(--svg-size, 80px));
      height: var(--svg-mob-size, var(--svg-size, 80px));
    }
  }
/* END_SECTION:ppp-svg-scroll */

/* START_SECTION:ppp-testimonials (INDEX:39) */
.ppp-testimonials {
    padding-block-start: var(--ppp-ts-pt, 64px);
    padding-block-end: var(--ppp-ts-pb, 64px);
  }
  .ppp-testimonials__wrap {
    max-width: var(--section-content-w, var(--page-width, 1200px));
    margin-inline: auto;
    padding-inline: var(--page-margin, 1.5rem);
  }
  .ppp-testimonials__heading {
    text-align: center;
    margin-bottom: 0.5rem;
    font-size: var(--ts-heading-size, 2.5rem);
    font-family: var(--section-heading-font, inherit);
    font-weight: var(--section-heading-weight, 800);
    letter-spacing: var(--section-heading-ls, -0.02em);
    text-transform: var(--section-heading-transform, none);
  }
  .ppp-testimonials__subheading {
    font-family: var(--font-subheading--family, var(--font-body--family));
    text-align: center;
    font-size: var(--ts-sub-size, 16px);
    letter-spacing: var(--ts-sub-ls, 0em);
    color: var(--ts-sub-color, currentColor);
    margin-bottom: 2.5rem;
  }
  .ppp-testimonials__track-wrapper {
    overflow: hidden;
  }
  .ppp-testimonials__track {
    display: flex;
    gap: 1.5rem;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .ppp-testimonials__card {
    flex: 0 0 calc(33.333% - 1rem);
    min-width: 260px;
    border: 1px solid rgba(128,128,128,0.2);
    border-radius: 12px;
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    box-sizing: border-box;
  }
  .ppp-testimonials__stars { display: flex; gap: 3px; }
  .ppp-testimonials__star { color: rgba(128,128,128,0.3); }
  .ppp-testimonials__star--filled { color: #f5a623; }
  .ppp-testimonials__quote {
    font-size: var(--ts-quote-size, 16px);
    letter-spacing: var(--ts-quote-ls, 0em);
    color: var(--ts-quote-color, currentColor);
    line-height: 1.65;
    margin: 0;
    font-style: normal;
    flex: 1;
  }
  .ppp-testimonials__author {
    font-size: var(--ts-author-size, 14px);
    font-style: normal;
    letter-spacing: var(--ts-author-ls, 0em);
    color: var(--ts-author-color, currentColor);
    margin-top: auto;
  }
  .ppp-testimonials__nav {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    margin-top: 2rem;
  }
  .ppp-testimonials__btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid currentColor;
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: currentColor;
    opacity: 0.7;
    transition: opacity 0.2s, background 0.2s;
  }
  .ppp-testimonials__btn:hover { opacity: 1; background: rgba(128,128,128,0.1); }
  @media (max-width: 749px) {
    .ppp-testimonials {
      padding-block-start: var(--ppp-ts-mob-pt, 40px);
      padding-block-end: var(--ppp-ts-mob-pb, 40px);
    }
    .ppp-testimonials__heading { font-size: var(--ppp-ts-mob-heading-size, 24px); }
    .ppp-testimonials__card {
      flex: 0 0 var(--ppp-ts-mob-card-width, 82vw);
      min-width: 0;
    }
  }
/* END_SECTION:ppp-testimonials */

/* START_SECTION:search (INDEX:41) */
.search-results {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }
  .search-results .prev,
  .search-results .page,
  .search-results .next {
    grid-column: 1 / -1;
  }
/* END_SECTION:search */

/* CSS from block stylesheet tags */
/* START_BLOCK:group (INDEX:44) */
.group {
    display: flex;
    flex-wrap: nowrap;
    overflow: hidden;
    width: 100%;
  }

  .group--horizontal {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 0 var(--padding);
  }

  .group--vertical {
    flex-direction: column;
    align-items: var(--alignment);
    padding: var(--padding) 0;
  }
/* END_BLOCK:group */

/* START_BLOCK:text (INDEX:45) */
.text {
    text-align: var(--text-align);
  }
  .text--title {
    font-size: 2rem;
    font-weight: 700;
  }
  .text--subtitle {
    font-size: 1.5rem;
  }
/* END_BLOCK:text */

/* CSS from snippet stylesheet tags */
/* START_SNIPPET:image (INDEX:47) */
.image {
    display: block;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: auto;
  }

  .image > img {
    width: 100%;
    height: auto;
  }
/* END_SNIPPET:image */