/** Shopify CDN: Minification failed

Line 1430:2 All "@import" rules must come first

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:cart (INDEX:3) */
.cp-cart-page {
    background-color: var(--cp-cream, #F7F5F0);
    padding: 60px 24px 100px;
    font-family: var(--cp-font-sans, 'Inter', sans-serif);
    min-height: 80vh;
  }
  .cp-cart-container {
    max-width: 1200px;
    margin: 0 auto;
  }

  /* Empty State */
  .cp-cart-empty {
    text-align: center;
    padding: 80px 20px;
    background: #fff;
    border-radius: 16px;
    box-shadow: var(--cp-shadow, 0 2px 8px rgba(0,0,0,0.06));
    max-width: 600px;
    margin: 0 auto;
  }
  .cp-cart-empty__icon {
    width: 64px;
    height: 64px;
    color: var(--cp-sage, #5C7A6B);
    margin-bottom: 24px;
  }
  .cp-cart-empty__heading {
    font-family: var(--cp-font-serif, 'Playfair Display', serif);
    font-size: 2rem;
    color: var(--cp-text, #2D2D2D);
    margin-bottom: 12px;
  }
  .cp-cart-empty__subtext {
    color: var(--cp-muted, #8A8A82);
    margin-bottom: 32px;
  }

  /* Header */
  .cp-cart-header {
    text-align: center;
    margin-bottom: 48px;
  }
  .cp-cart-header__title {
    font-family: var(--cp-font-serif, 'Playfair Display', serif);
    font-size: clamp(2rem, 4vw, 3rem);
    color: var(--cp-text, #2D2D2D);
    margin-bottom: 8px;
  }
  .cp-cart-header__subtext {
    color: var(--cp-muted, #8A8A82);
    font-size: 1rem;
  }

  /* Layout */
  .cp-cart-layout {
    display: grid;
    grid-template-columns: 1.8fr 1fr;
    gap: 40px;
    align-items: start;
  }

  /* Left Column */
  .cp-cart-items {
    background: #fff;
    border-radius: 16px;
    padding: 32px;
    box-shadow: var(--cp-shadow, 0 2px 8px rgba(0,0,0,0.06));
  }
  .cp-cart-item {
    display: flex;
    gap: 24px;
    padding: 24px 0;
    border-bottom: 1px solid var(--cp-border, #ECEAE5);
  }
  .cp-cart-item:first-child { padding-top: 0; }
  .cp-cart-item:last-child { border-bottom: none; padding-bottom: 0; }
  
  .cp-cart-item__image-wrap {
    flex-shrink: 0;
    width: 100px;
    height: 100px;
    border-radius: 12px;
    overflow: hidden;
    background: var(--cp-cream, #F7F5F0);
  }
  .cp-cart-item__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .cp-cart-item__details {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .cp-cart-item__title {
    font-family: var(--cp-font-serif, 'Playfair Display', serif);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cp-text, #2D2D2D);
    text-decoration: none;
    margin-bottom: 4px;
  }
  .cp-cart-item__variant {
    font-size: 0.85rem;
    color: var(--cp-muted, #8A8A82);
    margin-bottom: 8px;
  }
  .cp-cart-item__price {
    font-weight: 700;
    color: var(--cp-sage, #5C7A6B);
    font-size: 1.1rem;
    margin-bottom: 16px;
  }
  
  .cp-cart-item__actions {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-top: auto;
  }
  .cp-quantity {
    display: flex;
    align-items: center;
    border: 1.5px solid var(--cp-sage, #5C7A6B);
    border-radius: 100px;
    overflow: hidden;
    height: 36px;
  }
  .cp-quantity__btn {
    background: transparent;
    border: none;
    width: 36px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cp-sage, #5C7A6B);
    cursor: pointer;
    transition: background 0.2s;
  }
  .cp-quantity__btn:hover { background: rgba(92,122,107,0.05); }
  .cp-quantity__input {
    width: 40px;
    text-align: center;
    border: none;
    background: transparent;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--cp-text, #2D2D2D);
    padding: 0;
  }
  .cp-quantity__input::-webkit-outer-spin-button,
  .cp-quantity__input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
  }
  .cp-quantity__input[type=number] {
    -moz-appearance: textfield;
  }
  .cp-cart-item__remove {
    font-size: 0.85rem;
    color: var(--cp-muted, #8A8A82);
    text-decoration: underline;
    transition: color 0.2s;
  }
  .cp-cart-item__remove:hover { color: var(--cp-text, #2D2D2D); }

  .cp-cart-update-btn {
    margin-top: 24px;
    display: none;
  }
  noscript .cp-cart-update-btn { display: inline-flex; }

  /* Right Column Summary */
  .cp-cart-summary {
    background: #fff;
    border-radius: 16px;
    padding: 32px;
    box-shadow: var(--cp-shadow, 0 2px 8px rgba(0,0,0,0.06));
    position: sticky;
    top: 40px;
  }
  .cp-cart-summary__heading {
    font-family: var(--cp-font-serif, 'Playfair Display', serif);
    font-size: 1.5rem;
    margin-bottom: 24px;
    color: var(--cp-text, #2D2D2D);
  }
  .cp-cart-summary__line {
    display: flex;
    justify-content: space-between;
    margin-bottom: 16px;
    font-size: 0.95rem;
    color: var(--cp-text, #2D2D2D);
  }
  .cp-cart-summary__muted {
    color: var(--cp-muted, #8A8A82);
    font-size: 0.85rem;
  }
  
  .cp-cart-summary__discount {
    display: flex;
    gap: 8px;
    margin-bottom: 24px;
    margin-top: 24px;
  }
  .cp-discount-input {
    flex-grow: 1;
    border: 1px solid var(--cp-border, #ECEAE5);
    border-radius: 8px;
    padding: 10px 16px;
    font-size: 0.9rem;
    outline: none;
    transition: border-color 0.2s;
  }
  .cp-discount-input:focus { border-color: var(--cp-sage, #5C7A6B); }
  .cp-discount-btn {
    background: var(--cp-sage, #5C7A6B);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 0 20px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s;
  }
  .cp-discount-btn:hover { background: var(--cp-sage-dark, #3D5247); }

  .cp-cart-summary__divider {
    border: none;
    border-top: 1px solid var(--cp-border, #ECEAE5);
    margin: 24px 0;
  }
  .cp-cart-summary__total {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 24px;
  }
  
  /* Free Shipping Bar */
  .cp-free-shipping {
    background: var(--cp-cream, #F7F5F0);
    padding: 16px;
    border-radius: 12px;
    margin-bottom: 24px;
    text-align: center;
  }
  .cp-free-shipping__text {
    font-size: 0.85rem;
    color: var(--cp-text, #2D2D2D);
    margin-bottom: 10px;
  }
  .cp-free-shipping__bar {
    height: 6px;
    background: #E5E0D5;
    border-radius: 10px;
    overflow: hidden;
  }
  .cp-free-shipping__fill {
    height: 100%;
    background: var(--cp-sage, #5C7A6B);
    border-radius: 10px;
    transition: width 0.4s ease;
  }

  .cp-checkout-btn {
    width: 100%;
    justify-content: center;
    padding: 18px;
    font-size: 1.05rem;
    margin-bottom: 16px;
  }
  .cp-secure-checkout {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: var(--cp-muted, #8A8A82);
    font-size: 0.8rem;
    margin-bottom: 32px;
  }
  
  /* Trust Badges */
  .cp-trust-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
  }
  .cp-trust-badge {
    background: var(--cp-cream, #F7F5F0);
    color: var(--cp-sage-dark, #3D5247);
    font-size: 0.75rem;
    font-weight: 600;
    padding: 6px 12px;
    border-radius: 100px;
  }

  /* Recommendations */
  .cp-cart-recommendations {
    margin-top: 80px;
  }
  .cp-cart-recommendations__heading {
    text-align: center;
    font-family: var(--cp-font-serif, 'Playfair Display', serif);
    font-size: 2rem;
    color: var(--cp-text, #2D2D2D);
    margin-bottom: 40px;
  }
  .cp-cart-recommendations__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .cp-rec-card {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    text-decoration: none;
    box-shadow: var(--cp-shadow, 0 2px 8px rgba(0,0,0,0.06));
    transition: transform 0.3s, box-shadow 0.3s;
    display: flex;
    flex-direction: column;
  }
  .cp-rec-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(0,0,0,0.1);
  }
  .cp-rec-card__image-wrap {
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--cp-cream, #F7F5F0);
  }
  .cp-rec-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s;
  }
  .cp-rec-card:hover .cp-rec-card__image {
    transform: scale(1.05);
  }
  .cp-rec-card__info {
    padding: 24px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
  }
  .cp-rec-card__title {
    font-family: var(--cp-font-serif, 'Playfair Display', serif);
    font-size: 1.25rem;
    color: var(--cp-text, #2D2D2D);
    margin-bottom: 8px;
    font-weight: 700;
  }
  .cp-rec-card__price {
    color: var(--cp-sage, #5C7A6B);
    font-weight: 600;
    margin-bottom: 20px;
  }
  .cp-rec-card__cta {
    margin-top: auto;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--cp-sage, #5C7A6B);
    display: inline-flex;
    align-items: center;
    gap: 4px;
  }
  .cp-rec-card__cta::after {
    content: '→';
    transition: transform 0.2s;
  }
  .cp-rec-card:hover .cp-rec-card__cta::after {
    transform: translateX(4px);
  }

  /* Responsive */
  @media (max-width: 960px) {
    .cp-cart-layout {
      grid-template-columns: 1fr;
    }
    .cp-cart-summary {
      position: static;
    }
    .cp-cart-recommendations__grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  @media (max-width: 640px) {
    .cp-cart-page { padding: 40px 16px; }
    .cp-cart-item {
      flex-direction: column;
      gap: 16px;
    }
    .cp-cart-item__image-wrap {
      width: 100%;
      height: 200px;
    }
    .cp-cart-item__actions {
      margin-top: 16px;
      justify-content: space-between;
    }
    .cp-cart-recommendations__grid {
      grid-template-columns: 1fr;
    }
  }
/* END_SECTION:cart */

/* START_SECTION:collection (INDEX:4) */
/* ============================================================
   PetBoutiq Collection Page — Self-contained styles
   ============================================================ */

/* ── Outer wrapper ─────────────────────────────────────────── */
.cpc {
  background: #F7F5F0;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

/* ── Banner ────────────────────────────────────────────────── */
.cpc-banner {
  position: relative;
  min-height: 380px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.cpc-banner__bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  max-width: none;
}
.cpc-banner__placeholder {
  position: absolute;
  inset: 0;
}
.cpc-banner__overlay {
  position: absolute;
  inset: 0;
}
.cpc-banner__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 72px 24px 60px;
  max-width: 760px;
  width: 100%;
}
.cpc-banner__eyebrow {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(255,255,255,0.75);
  margin-bottom: 14px;
}
.cpc-banner__title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 16px;
  text-shadow: 0 2px 24px rgba(0,0,0,0.25);
}
.cpc-banner__desc {
  font-size: 1rem;
  color: rgba(255,255,255,0.82);
  line-height: 1.7;
  max-width: 520px;
  margin: 0 auto 18px;
}
.cpc-banner__count {
  display: inline-block;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.6);
  font-weight: 500;
  border: 1px solid rgba(255,255,255,0.3);
  border-radius: 100px;
  padding: 5px 16px;
}

/* ── Body ──────────────────────────────────────────────────── */
.cpc-body {
  max-width: 1240px;
  margin: 0 auto;
  padding: 52px 28px 100px;
}

/* ── Toolbar ───────────────────────────────────────────────── */
.cpc-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 1px solid #ECEAE5;
}
.cpc-toolbar__count {
  font-size: 0.88rem;
  color: #8A8A82;
}
.cpc-toolbar__count strong {
  color: #2D2D2D;
  font-weight: 600;
}
.cpc-toolbar__sort {
  display: flex;
  align-items: center;
  gap: 10px;
}
.cpc-toolbar__sort-label {
  font-size: 0.82rem;
  font-weight: 600;
  color: #8A8A82;
  white-space: nowrap;
}
.cpc-toolbar__sort-select {
  padding: 9px 36px 9px 14px;
  border-radius: 14px;
  border: 1.5px solid #ECEAE5;
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%238A8A82' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 12px center;
  -webkit-appearance: none;
  appearance: none;
  font-size: 0.875rem;
  color: #2D2D2D;
  cursor: pointer;
  outline: none;
  font-family: inherit;
  transition: border-color 0.25s ease;
}
.cpc-toolbar__sort-select:focus {
  border-color: #5C7A6B;
}

/* ── Product Grid ──────────────────────────────────────────── */
.cpc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

/* ── Card ──────────────────────────────────────────────────── */
.cpc-card {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid #ECEAE5;
  box-shadow: 0 2px 10px rgba(0,0,0,0.05);
  display: flex;
  flex-direction: column;
  transition: transform 0.35s cubic-bezier(.4,0,.2,1),
              box-shadow 0.35s cubic-bezier(.4,0,.2,1),
              border-color 0.35s ease;
  position: relative;
}
.cpc-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 20px 56px rgba(0,0,0,0.11);
  border-color: rgba(92,122,107,0.28);
}

/* ── Card image ────────────────────────────────────────────── */
.cpc-card__img-link {
  display: block;
  text-decoration: none;
}
.cpc-card__img-wrap {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: linear-gradient(160deg, #F5EDE3 0%, #EAE5DD 100%);
}
.cpc-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  max-width: none;
  transition: transform 0.5s cubic-bezier(.4,0,.2,1);
}
.cpc-card:hover .cpc-card__img {
  transform: scale(1.05);
}
.cpc-card__img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Badges ────────────────────────────────────────────────── */
.cpc-card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 4px 12px;
  border-radius: 100px;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  z-index: 2;
}
.cpc-card__badge--best { background: #5C7A6B; color: #fff; }
.cpc-card__badge--sale { background: #C4825A; color: #fff; }
.cpc-card__badge--sold { background: #2D2D2D; color: #fff; }

/* ── Card info ─────────────────────────────────────────────── */
.cpc-card__info {
  padding: 20px 20px 12px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Stars */
.cpc-card__stars {
  display: flex;
  align-items: center;
  gap: 2px;
}
.cpc-card__review-count {
  font-size: 0.74rem;
  color: #8A8A82;
  margin-left: 4px;
}

/* Name */
.cpc-card__name {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.3;
  margin: 0;
}
.cpc-card__name a {
  color: #2D2D2D;
  text-decoration: none;
  transition: color 0.2s ease;
}
.cpc-card__name a:hover {
  color: #5C7A6B;
}

/* Tagline */
.cpc-card__tagline {
  font-size: 0.82rem;
  color: #8A8A82;
  line-height: 1.5;
  margin: 0;
}

/* Price */
.cpc-card__price-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-top: 4px;
}
.cpc-card__price {
  font-size: 1.05rem;
  font-weight: 700;
  color: #5C7A6B;
}
.cpc-card__compare {
  font-size: 0.88rem;
  color: #8A8A82;
  text-decoration: line-through;
  font-weight: 400;
}

/* ── Add to Cart ───────────────────────────────────────────── */
.cpc-card__atc-wrap {
  padding: 0 16px 16px;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.cpc-card:hover .cpc-card__atc-wrap {
  opacity: 1;
  transform: translateY(0);
}
.cpc-card__form {
  width: 100%;
}
.cpc-card__atc-btn {
  width: 100%;
  padding: 13px 20px;
  border-radius: 12px;
  background: #5C7A6B;
  color: #fff;
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 600;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background 0.25s ease, transform 0.2s ease;
  white-space: nowrap;
}
.cpc-card__atc-btn:hover {
  background: #3D5247;
}
.cpc-card__atc-btn:disabled {
  background: #ECEAE5;
  color: #8A8A82;
  cursor: not-allowed;
}

/* ── Pagination ────────────────────────────────────────────── */
.cpc-pagination {
  margin-top: 64px;
  text-align: center;
  display: flex;
  justify-content: center;
}
.cpc-pagination .pagination {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}
.cpc-pagination a,
.cpc-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1.5px solid #ECEAE5;
  font-size: 0.875rem;
  font-weight: 500;
  color: #2D2D2D;
  text-decoration: none;
  transition: all 0.25s ease;
  background: #fff;
}
.cpc-pagination a:hover {
  border-color: #5C7A6B;
  color: #5C7A6B;
}
.cpc-pagination .current {
  background: #5C7A6B;
  border-color: #5C7A6B;
  color: #fff;
}

/* ── Empty state ───────────────────────────────────────────── */
.cpc-empty {
  text-align: center;
  padding: 100px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.cpc-empty__msg {
  font-size: 1.1rem;
  color: #5C7A6B;
  font-weight: 500;
  max-width: 360px;
  line-height: 1.6;
}
.cpc-empty__link {
  display: inline-flex;
  align-items: center;
  padding: 13px 28px;
  border-radius: 14px;
  background: #5C7A6B;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.25s ease, transform 0.25s ease;
}
.cpc-empty__link:hover {
  background: #3D5247;
  transform: translateY(-2px);
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .cpc-grid { gap: 24px; }
}

@media (max-width: 900px) {
  .cpc-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
  .cpc-body { padding: 40px 20px 80px; }
  .cpc-banner { min-height: 320px; }
}

@media (max-width: 600px) {
  .cpc-banner { min-height: 280px; }
  .cpc-banner__title { font-size: 2rem; }
  .cpc-body { padding: 32px 16px 72px; }
  .cpc-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
    margin: 0 auto;
    gap: 18px;
  }
  .cpc-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }
  /* Always show ATC on mobile */
  .cpc-card__atc-wrap {
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
  .cpc-card__name {
    font-size: 1rem;
  }
}
/* END_SECTION:collection */

/* START_SECTION:collections (INDEX:5) */
/* ============================================================
   PetBoutiq — Collections Landing Page
   ============================================================ */

.cpl {
  background: #F7F5F0;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

/* ── Hero Banner ─────────────────────────────────────────── */
.cpl-hero {
  position: relative;
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #3D5247 0%, #5C7A6B 50%, #7B9E87 100%);
  overflow: hidden;
}
.cpl-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.cpl-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.12);
}
.cpl-hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 72px 24px 64px;
  max-width: 700px;
}
.cpl-hero__eyebrow {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(255,255,255,0.7);
  margin-bottom: 14px;
}
.cpl-hero__title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 18px;
  text-shadow: 0 2px 24px rgba(0,0,0,0.2);
}
.cpl-hero__desc {
  font-size: 1rem;
  color: rgba(255,255,255,0.82);
  line-height: 1.75;
  max-width: 560px;
  margin: 0 auto;
}

/* ── Body ────────────────────────────────────────────────── */
.cpl-body {
  max-width: 1240px;
  margin: 0 auto;
  padding: 64px 28px 80px;
}

/* ── Collection Cards Grid ───────────────────────────────── */
.cpl-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  margin-bottom: 72px;
}

/* ── Individual Card ─────────────────────────────────────── */
.cpl-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 480px;
  border-radius: 20px;
  overflow: hidden;
  text-decoration: none;
  box-shadow: 0 4px 24px rgba(0,0,0,0.10);
  transition: transform 0.4s cubic-bezier(.4,0,.2,1),
              box-shadow 0.4s cubic-bezier(.4,0,.2,1);
  cursor: pointer;
}
.cpl-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 28px 72px rgba(0,0,0,0.20);
}
.cpl-card:hover .cpl-card__bg-img {
  transform: scale(1.07);
}
.cpl-card:hover .cpl-card__cta {
  gap: 12px;
}

/* Background image */
.cpl-card__bg {
  position: absolute;
  inset: 0;
}
.cpl-card__bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  max-width: none;
  transition: transform 0.6s cubic-bezier(.4,0,.2,1);
}

/* Overlay */
.cpl-card__overlay {
  position: absolute;
  inset: 0;
  transition: opacity 0.4s ease;
}
.cpl-card:hover .cpl-card__overlay {
  opacity: 0.8;
}

/* Content */
.cpl-card__content {
  position: relative;
  z-index: 2;
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cpl-card__eyebrow {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(255,255,255,0.65);
}
.cpl-card__title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(1.6rem, 2.5vw, 2.1rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.15;
  text-shadow: 0 2px 12px rgba(0,0,0,0.2);
  margin: 0;
}
.cpl-card__desc {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.82);
  line-height: 1.6;
  max-width: 280px;
  margin: 4px 0 8px;
}
.cpl-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
}
.cpl-card__count {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.65);
  font-weight: 500;
  border: 1px solid rgba(255,255,255,0.3);
  border-radius: 100px;
  padding: 4px 12px;
}
.cpl-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.88rem;
  font-weight: 600;
  color: #fff;
  background: rgba(255,255,255,0.18);
  backdrop-filter: blur(4px);
  border: 1.5px solid rgba(255,255,255,0.55);
  border-radius: 100px;
  padding: 9px 20px;
  transition: background 0.3s ease, gap 0.3s ease, border-color 0.3s ease;
}
.cpl-card:hover .cpl-card__cta {
  background: rgba(255,255,255,0.3);
  border-color: rgba(255,255,255,0.9);
}

/* ── Trust Bar ───────────────────────────────────────────── */
.cpl-trust {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  padding: 32px 24px;
  background: #fff;
  border-radius: 20px;
  border: 1px solid #ECEAE5;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
}
.cpl-trust__item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 28px;
  font-size: 0.88rem;
  font-weight: 600;
  color: #2D2D2D;
}
.cpl-trust__sep {
  width: 1px;
  height: 32px;
  background: #ECEAE5;
  flex-shrink: 0;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .cpl-grid { gap: 22px; }
  .cpl-card { min-height: 420px; }
}

@media (max-width: 860px) {
  .cpl-grid { grid-template-columns: 1fr; gap: 20px; }
  .cpl-card { min-height: 360px; }
  .cpl-body { padding: 48px 20px 64px; }
  .cpl-trust__sep { display: none; }
  .cpl-trust { gap: 4px; }
  .cpl-trust__item { padding: 10px 16px; }
}

@media (max-width: 560px) {
  .cpl-hero { min-height: 240px; }
  .cpl-hero__title { font-size: 2.2rem; }
  .cpl-hero__content { padding: 56px 20px 48px; }
  .cpl-body { padding: 36px 16px 56px; }
  .cpl-card { min-height: 300px; }
  .cpl-card__content { padding: 24px 20px 22px; }
}
/* 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) */
.cp-footer {
    background: var(--cp-sage-dark, #3D5247);
    color: rgba(247,245,240,0.85);
    font-family: var(--cp-font-sans);
    padding: 80px 24px 0;
  }
  .cp-footer__inner {
    max-width: 1240px; margin: 0 auto;
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
    gap: 48px;
    padding-bottom: 64px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
  }

  /* ── Column Base ───────────────── */
  .cp-footer__heading {
    font-family: var(--cp-font-sans);
    font-size: 0.72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.14em;
    color: rgba(247,245,240,0.5);
    margin-bottom: 20px;
  }

  /* ── Brand Column ──────────────── */
  .cp-footer__logo {
    display: inline-flex; align-items: center; gap: 9px;
    text-decoration: none;
    font-family: var(--cp-font-serif);
    font-size: 1.3rem; font-weight: 700;
    color: #fff;
    margin-bottom: 18px;
  }
  .cp-footer__tagline {
    font-size: 0.875rem; line-height: 1.7;
    color: rgba(247,245,240,0.65);
    margin-bottom: 20px;
    max-width: 260px;
  }
  .cp-footer__badges {
    display: flex; flex-wrap: wrap; gap: 8px;
  }
  .cp-footer__badge {
    font-size: 0.72rem; font-weight: 600;
    padding: 5px 12px; border-radius: 100px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    color: rgba(247,245,240,0.75);
  }

  /* ── Links ─────────────────────── */
  .cp-footer__links {
    display: flex; flex-direction: column; gap: 12px;
  }
  .cp-footer__link {
    font-size: 0.9rem; text-decoration: none;
    color: rgba(247,245,240,0.72);
    transition: color 0.25s ease;
  }
  .cp-footer__link:hover { color: #fff; }

  /* ── Newsletter ────────────────── */
  .cp-footer__newsletter-sub {
    font-size: 0.875rem; line-height: 1.6;
    color: rgba(247,245,240,0.65);
    margin-bottom: 16px;
  }
  .cp-footer__form {
    display: flex; gap: 8px; margin-bottom: 24px;
  }
  .cp-footer__input {
    flex: 1; padding: 12px 16px;
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: var(--cp-radius-sm);
    background: rgba(255,255,255,0.07);
    color: #fff; font-size: 0.875rem; outline: none;
    transition: border-color 0.3s ease;
  }
  .cp-footer__input::placeholder { color: rgba(255,255,255,0.35); }
  .cp-footer__input:focus { border-color: rgba(255,255,255,0.45); }
  .cp-footer__submit {
    padding: 12px 18px; border-radius: var(--cp-radius-sm);
    background: var(--cp-sage-light, #7B9E87); color: #fff;
    font-size: 0.875rem; font-weight: 600;
    border: none; cursor: pointer;
    transition: background 0.3s ease;
    white-space: nowrap;
  }
  .cp-footer__submit:hover { background: var(--cp-sage, #5C7A6B); }
  .cp-footer__success {
    font-size: 0.875rem; color: rgba(247,245,240,0.9);
    padding: 12px 0; margin-bottom: 24px;
  }

  /* ── Social ────────────────────── */
  .cp-footer__social {
    display: flex; gap: 10px;
  }
  .cp-footer__social-link {
    display: flex; align-items: center; justify-content: center;
    width: 38px; height: 38px; border-radius: 10px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.1);
    color: rgba(247,245,240,0.72);
    text-decoration: none;
    transition: all 0.3s ease;
  }
  .cp-footer__social-link:hover {
    background: rgba(255,255,255,0.16);
    color: #fff;
    transform: translateY(-2px);
  }

  /* ── Bottom Bar ────────────────── */
  .cp-footer__bottom {
    max-width: 1240px; margin: 0 auto;
    display: flex; align-items: center; justify-content: space-between;
    padding: 24px 0;
    flex-wrap: wrap; gap: 16px;
  }
  .cp-footer__copy {
    font-size: 0.8rem;
    color: rgba(247,245,240,0.4);
  }
  .cp-footer__payment {
    display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  }
  .cp-footer__payment svg { height: 22px; width: auto; opacity: 0.6; }

  /* ── Responsive ────────────────── */
  @media (max-width: 1024px) {
    .cp-footer__inner { grid-template-columns: 1fr 1fr; gap: 40px; }
  }
  @media (max-width: 640px) {
    .cp-footer { padding: 60px 20px 0; }
    .cp-footer__inner { grid-template-columns: 1fr; gap: 36px; padding-bottom: 48px; }
    .cp-footer__bottom { flex-direction: column; align-items: flex-start; }
  }
/* END_SECTION:footer */

/* START_SECTION:header (INDEX:8) */
/* ── Header Base ──────────────────────────────────────── */
  .cp-header {
    position: fixed; top: 44px; left: 0; right: 0; z-index: 1000;
    background: rgba(247,245,240,0.97);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(0,0,0,0.07);
    transition: box-shadow 0.4s ease, top 0.35s ease;
    font-family: var(--cp-font-sans);
  }
  .cp-header.scrolled {
    box-shadow: 0 1px 0 rgba(0,0,0,0.08), 0 4px 20px rgba(0,0,0,0.06);
  }
  .cp-header__inner {
    max-width: 1240px; margin: 0 auto;
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 24px; height: 72px;
  }

  /* ── Logo ─────────────────────────────────────────────── */
  .cp-header__logo {
    display: flex; align-items: center; gap: 9px;
    text-decoration: none; color: var(--cp-sage-dark, #3D5247);
    transition: color 0.3s ease;
  }
  .cp-header__logo:hover { color: var(--cp-sage, #5C7A6B); }
  .cp-header.scrolled .cp-header__logo { color: var(--cp-sage-dark); }
  .cp-header__wordmark {
    font-family: var(--cp-font-serif);
    font-size: 1.35rem; font-weight: 700;
    letter-spacing: -0.01em;
    transition: color 0.4s ease;
  }
  .cp-header__paw { flex-shrink: 0; }

  /* ── Desktop Nav ──────────────────────────────────────── */
  .cp-header__nav {
    display: flex; align-items: center; gap: 36px;
  }
  .cp-header__nav-link {
    text-decoration: none; color: var(--cp-text, #2D2D2D);
    font-size: 0.9rem; font-weight: 500;
    position: relative; padding-bottom: 2px;
    transition: color 0.3s ease;
  }
  .cp-header__nav-link::after {
    content: ''; position: absolute; bottom: -2px; left: 0; right: 0;
    height: 1.5px; background: currentColor;
    transform: scaleX(0); transform-origin: left;
    transition: transform 0.3s ease;
  }
  .cp-header__nav-link:hover::after { transform: scaleX(1); }
  .cp-header__nav-link:hover { color: var(--cp-sage, #5C7A6B); }
  .cp-header.scrolled .cp-header__nav-link { color: var(--cp-text); }
  .cp-header.scrolled .cp-header__nav-link:hover { color: var(--cp-sage); }

  /* ── Icons ────────────────────────────────────────────── */
  .cp-header__icons {
    display: flex; align-items: center; gap: 6px;
  }
  .cp-header__icon-btn {
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; border-radius: 10px;
    color: var(--cp-text, #2D2D2D);
    text-decoration: none;
    transition: var(--cp-transition);
    position: relative;
  }
  .cp-header__icon-btn:hover { background: var(--cp-cream-dark, #EDE9E1); color: var(--cp-sage); }
  .cp-header.scrolled .cp-header__icon-btn { color: var(--cp-text); }
  .cp-header.scrolled .cp-header__icon-btn:hover { background: var(--cp-cream-dark); color: var(--cp-sage); }

  .cp-header__cart-count {
    position: absolute; top: 4px; right: 4px;
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--cp-terracotta); color: #fff;
    font-size: 0.6rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
  }

  /* ── Hamburger ────────────────────────────────────────── */
  .cp-header__hamburger {
    display: none; flex-direction: column; justify-content: center;
    gap: 5px; width: 40px; height: 40px; padding: 8px;
    background: none; border: none; cursor: pointer;
    border-radius: 10px; transition: var(--cp-transition);
  }
  .cp-header__hamburger:hover { background: var(--cp-cream-dark, #EDE9E1); }
  .cp-header.scrolled .cp-header__hamburger:hover { background: var(--cp-cream-dark); }
  .cp-header__hamburger span {
    display: block; height: 1.5px; border-radius: 2px;
    background: var(--cp-text, #2D2D2D);
    transition: var(--cp-transition);
  }
  .cp-header.scrolled .cp-header__hamburger span { background: var(--cp-text); }

  /* ── Mobile Menu ──────────────────────────────────────── */
  .cp-mobile-menu {
    display: none; position: fixed; inset: 0; z-index: 1100;
  }
  .cp-mobile-menu.open { display: flex; }
  .cp-mobile-menu__backdrop {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.4);
    animation: cpFadeIn 0.3s ease;
  }
  .cp-mobile-menu__panel {
    position: relative; z-index: 1; margin-left: auto;
    width: min(320px, 85vw); height: 100%;
    background: #fff;
    display: flex; flex-direction: column;
    animation: cpSlideIn 0.35s cubic-bezier(.4,0,.2,1);
    padding: 24px;
  }
  .cp-mobile-menu__top {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 40px;
  }
  .cp-mobile-menu__close {
    display: flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 8px;
    background: var(--cp-cream); border: none; cursor: pointer;
    color: var(--cp-text); transition: var(--cp-transition);
  }
  .cp-mobile-menu__close:hover { background: var(--cp-cream-dark); }
  .cp-mobile-menu__nav {
    display: flex; flex-direction: column; gap: 4px; flex: 1;
  }
  .cp-mobile-menu__link {
    display: block; padding: 14px 16px;
    font-size: 1.05rem; font-weight: 500;
    color: var(--cp-text); text-decoration: none;
    border-radius: var(--cp-radius-sm);
    transition: var(--cp-transition);
  }
  .cp-mobile-menu__link:hover { background: var(--cp-cream); color: var(--cp-sage); }
  .cp-mobile-menu__footer { padding-top: 24px; border-top: 1px solid var(--cp-border); }

  @keyframes cpFadeIn { from { opacity: 0; } to { opacity: 1; } }
  @keyframes cpSlideIn { from { transform: translateX(100%); } to { transform: translateX(0); } }

  /* ── Spacer so content doesn't hide under fixed ann bar + header ── */
  .cp-header-spacer { height: 116px; } /* 44px ann + 72px nav */

  @media (max-width: 768px) {
    .cp-header__nav { display: none; }
    .cp-header__hamburger { display: flex; }
    .cp-header__inner { height: 64px; }
    .cp-header-spacer { height: 112px; } /* 48px ann + 64px nav */
    .cp-header { top: 48px; }
  }
/* END_SECTION:header */

/* START_SECTION:hello-world (INDEX:9) */
/* ===========================
     BrandHaus Hero — Scoped CSS
     =========================== */

  /* --- Google Font --- */
  @import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

  .hero {
    --hero-bg: #0a0a0f;
    --hero-surface: #14141f;
    --hero-text: #f0f0f5;
    --hero-text-muted: #9a9ab0;
    --hero-accent: #7c5cfc;
    --hero-accent-light: #a18aff;
    --hero-accent-glow: rgba(124, 92, 252, 0.25);
    --hero-border: rgba(255, 255, 255, 0.06);

    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 90vh;
    padding: 100px 24px 80px;
    background-color: var(--hero-bg);
    overflow: hidden;
    font-family: 'Inter', sans-serif;
  }

  /* --- Decorative gradient orbs --- */
  .hero__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(100px);
    pointer-events: none;
    will-change: transform;
  }
  .hero__orb--1 {
    width: 600px;
    height: 600px;
    top: -200px;
    left: -150px;
    background: radial-gradient(circle, rgba(124, 92, 252, 0.18) 0%, transparent 70%);
    animation: heroOrbFloat1 14s ease-in-out infinite;
  }
  .hero__orb--2 {
    width: 500px;
    height: 500px;
    bottom: -180px;
    right: -120px;
    background: radial-gradient(circle, rgba(161, 138, 255, 0.14) 0%, transparent 70%);
    animation: heroOrbFloat2 18s ease-in-out infinite;
  }

  @keyframes heroOrbFloat1 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(60px, 40px) scale(1.08); }
  }
  @keyframes heroOrbFloat2 {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50% { transform: translate(-50px, -30px) scale(1.06); }
  }

  /* --- Hero inner content --- */
  .hero__inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    max-width: 820px;
    margin: 0 auto;
  }

  /* --- Pill badge above heading --- */
  .hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 18px 6px 14px;
    border-radius: 100px;
    background: var(--hero-surface);
    border: 1px solid var(--hero-border);
    color: var(--hero-accent-light);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 32px;
    animation: heroBadgeFadeIn 0.8s ease-out both;
  }
  .hero__badge-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--hero-accent);
    box-shadow: 0 0 8px var(--hero-accent-glow);
    animation: heroDotPulse 2.4s ease-in-out infinite;
  }

  @keyframes heroDotPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(0.85); }
  }
  @keyframes heroBadgeFadeIn {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
  }

  /* --- Heading --- */
  .hero__heading {
    font-size: clamp(2.4rem, 6vw, 4.5rem);
    font-weight: 800;
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: var(--hero-text);
    margin-bottom: 24px;
    animation: heroHeadingIn 0.9s ease-out 0.15s both;
  }

  @keyframes heroHeadingIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
  }

  /* --- Subheading --- */
  .hero__subheading {
    font-size: clamp(1rem, 2vw, 1.25rem);
    line-height: 1.6;
    color: var(--hero-text-muted);
    max-width: 560px;
    margin-bottom: 44px;
    animation: heroSubIn 0.9s ease-out 0.3s both;
  }

  @keyframes heroSubIn {
    from { opacity: 0; transform: translateY(16px); }
    to { opacity: 1; transform: translateY(0); }
  }

  /* --- CTA Buttons --- */
  .hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    justify-content: center;
    animation: heroActionsIn 0.9s ease-out 0.45s both;
  }

  @keyframes heroActionsIn {
    from { opacity: 0; transform: translateY(14px); }
    to { opacity: 1; transform: translateY(0); }
  }

  .hero__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 32px;
    border-radius: 12px;
    font-size: 0.95rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    letter-spacing: 0.01em;
  }

  .hero__btn--primary {
    background: var(--hero-accent);
    color: #fff;
    box-shadow:
      0 0 0 0 var(--hero-accent-glow),
      0 4px 16px rgba(124, 92, 252, 0.3);
  }
  .hero__btn--primary:hover {
    background: var(--hero-accent-light);
    box-shadow:
      0 0 0 4px var(--hero-accent-glow),
      0 8px 32px rgba(124, 92, 252, 0.4);
    transform: translateY(-2px);
  }

  .hero__btn-arrow {
    transition: transform 0.25s ease;
  }
  .hero__btn--primary:hover .hero__btn-arrow {
    transform: translateX(4px);
  }

  .hero__btn--secondary {
    background: var(--hero-surface);
    color: var(--hero-text);
    border: 1px solid var(--hero-border);
  }
  .hero__btn--secondary:hover {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.12);
    transform: translateY(-2px);
  }

  /* --- Trust badges --- */
  .hero__trust {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 32px;
    margin-top: 72px;
    padding: 28px 40px;
    border-radius: 16px;
    background: var(--hero-surface);
    border: 1px solid var(--hero-border);
    animation: heroTrustIn 1s ease-out 0.6s both;
  }

  @keyframes heroTrustIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
  }

  .hero__trust-divider {
    width: 1px;
    height: 36px;
    background: var(--hero-border);
    flex-shrink: 0;
  }

  .hero__trust-item {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-shrink: 0;
  }

  .hero__trust-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: rgba(124, 92, 252, 0.1);
    color: var(--hero-accent-light);
    flex-shrink: 0;
  }

  .hero__trust-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .hero__trust-title {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--hero-text);
    white-space: nowrap;
  }

  .hero__trust-desc {
    font-size: 0.75rem;
    color: var(--hero-text-muted);
    white-space: nowrap;
  }

  /* --- Responsive --- */
  @media (max-width: 768px) {
    .hero {
      min-height: auto;
      padding: 80px 20px 60px;
    }
    .hero__heading {
      font-size: clamp(2rem, 8vw, 2.8rem);
    }
    .hero__trust {
      flex-direction: column;
      gap: 20px;
      padding: 24px 28px;
    }
    .hero__trust-divider {
      width: 100%;
      height: 1px;
    }
    .hero__trust-item {
      width: 100%;
    }
    .hero__actions {
      flex-direction: column;
      width: 100%;
      max-width: 320px;
    }
    .hero__btn {
      justify-content: center;
      width: 100%;
    }
  }
/* END_SECTION:hello-world */

/* START_SECTION:petboutiq-about (INDEX:12) */
.cpab { background:#F7F5F0; font-family:'Inter',system-ui,-apple-system,sans-serif; }
.cpab-label { display:inline-block; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.2em; color:#5C7A6B; margin-bottom:14px; }
.cpab-label--white { color:rgba(255,255,255,.8); }
.cpab-btn-primary { display:inline-flex; align-items:center; gap:8px; padding:16px 36px; border-radius:12px; background:#5C7A6B; color:#fff; font-size:.95rem; font-weight:600; text-decoration:none; transition:background .25s ease,transform .25s ease; }
.cpab-btn-primary:hover { background:#3D5247; transform:translateY(-2px); }
.cpab-btn-outline { display:inline-flex; align-items:center; gap:8px; padding:15px 34px; border-radius:12px; background:transparent; color:#fff; border:2px solid rgba(255,255,255,.7); font-size:.95rem; font-weight:600; text-decoration:none; transition:background .25s ease,border-color .25s ease,transform .25s ease; }
.cpab-btn-outline:hover { background:rgba(255,255,255,.12); border-color:#fff; transform:translateY(-2px); }
/* Hero */
.cpab-hero { position:relative; min-height:520px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.cpab-hero__bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 30%; display:block; max-width:none; }
.cpab-hero__overlay { position:absolute; inset:0; background:linear-gradient(180deg,rgba(30,30,20,.35) 0%,rgba(20,30,20,.68) 100%); }
.cpab-hero__content { position:relative; z-index:2; text-align:center; padding:80px 24px; max-width:800px; }
.cpab-hero__title { font-family:'Playfair Display',Georgia,serif; font-size:clamp(2.2rem,5vw,3.6rem); font-weight:700; color:#fff; line-height:1.15; margin-bottom:20px; text-shadow:0 2px 24px rgba(0,0,0,.25); }
.cpab-hero__sub { font-size:1.15rem; color:rgba(255,255,255,.85); line-height:1.7; font-style:italic; }
/* Story */
.cpab-story { display:grid; grid-template-columns:1fr 1fr; }
.cpab-story__img-wrap { overflow:hidden; max-height:600px; }
.cpab-story__img { width:100%; height:100%; object-fit:cover; display:block; max-width:none; transition:transform .6s ease; }
.cpab-story__img-wrap:hover .cpab-story__img { transform:scale(1.03); }
.cpab-story__text { background:#fff; padding:80px 72px; display:flex; flex-direction:column; justify-content:center; }
.cpab-story__heading { font-family:'Playfair Display',Georgia,serif; font-size:clamp(1.8rem,3vw,2.5rem); font-weight:700; color:#2D2D2D; line-height:1.2; margin-bottom:24px; }
.cpab-story__body { font-size:1rem; color:#5A5A5A; line-height:1.8; margin-bottom:16px; }
.cpab-story__sig { margin-top:32px; padding-top:24px; border-top:1px solid #ECEAE5; display:flex; flex-direction:column; gap:4px; }
.cpab-story__sig-name { font-family:'Playfair Display',Georgia,serif; font-size:1.1rem; font-weight:700; color:#5C7A6B; }
.cpab-story__sig-role { font-size:.82rem; color:#9A9A9A; font-style:italic; }
/* Mission */
.cpab-mission { background:#5C7A6B; padding:100px 24px; }
.cpab-mission__header { text-align:center; max-width:760px; margin:0 auto 64px; }
.cpab-mission__title { font-family:'Playfair Display',Georgia,serif; font-size:clamp(2rem,4vw,3rem); font-weight:700; color:#fff; line-height:1.15; margin-bottom:20px; }
.cpab-mission__sub { font-size:1.05rem; color:rgba(255,255,255,.82); line-height:1.75; }
.cpab-mission__cards { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1100px; margin:0 auto; }
.cpab-mission__card { background:#fff; border-radius:20px; padding:40px 32px; text-align:center; box-shadow:0 4px 24px rgba(0,0,0,.12); transition:transform .3s ease; }
.cpab-mission__card:hover { transform:translateY(-6px); }
.cpab-mission__card-icon { font-size:2.2rem; margin-bottom:20px; display:block; }
.cpab-mission__card-title { font-family:'Playfair Display',Georgia,serif; font-size:1.2rem; font-weight:700; color:#2D2D2D; margin-bottom:12px; }
.cpab-mission__card-body { font-size:.9rem; color:#6B6B6B; line-height:1.7; }
/* Promise */
.cpab-promise { padding:100px 24px; background:#F7F5F0; }
.cpab-promise__header { text-align:center; margin-bottom:60px; }
.cpab-promise__title { font-family:'Playfair Display',Georgia,serif; font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:700; color:#2D2D2D; line-height:1.2; }
.cpab-promise__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; max-width:1100px; margin:0 auto; }
.cpab-promise__card { background:#fff; border-radius:20px; padding:40px 32px; border:1.5px solid #ECEAE5; box-shadow:0 2px 12px rgba(0,0,0,.05); transition:transform .3s ease,box-shadow .3s ease; }
.cpab-promise__card:hover { transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,.09); }
.cpab-promise__card-icon { width:56px; height:56px; border-radius:14px; background:linear-gradient(135deg,rgba(92,122,107,.12),rgba(92,122,107,.05)); display:flex; align-items:center; justify-content:center; margin-bottom:24px; }
.cpab-promise__card-title { font-family:'Playfair Display',Georgia,serif; font-size:1.1rem; font-weight:700; color:#2D2D2D; margin-bottom:12px; line-height:1.3; }
.cpab-promise__card-body { font-size:.9rem; color:#6B6B6B; line-height:1.7; }
/* CTA */
.cpab-cta { position:relative; min-height:420px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.cpab-cta__bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 60%; display:block; max-width:none; }
.cpab-cta__overlay { position:absolute; inset:0; background:linear-gradient(180deg,rgba(61,82,71,.6) 0%,rgba(20,30,20,.75) 100%); }
.cpab-cta__content { position:relative; z-index:2; text-align:center; padding:80px 24px; max-width:680px; }
.cpab-cta__title { font-family:'Playfair Display',Georgia,serif; font-size:clamp(2rem,4vw,3rem); font-weight:700; color:#fff; line-height:1.15; margin-bottom:16px; }
.cpab-cta__sub { font-size:1.05rem; color:rgba(255,255,255,.82); line-height:1.7; margin-bottom:36px; }
.cpab-cta__btns { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; }
/* Responsive */
@media (max-width:900px) {
  .cpab-story { grid-template-columns:1fr; }
  .cpab-story__img-wrap { max-height:360px; }
  .cpab-story__text { padding:60px 40px; }
  .cpab-mission__cards,.cpab-promise__grid { grid-template-columns:1fr; max-width:480px; }
}
@media (max-width:600px) {
  .cpab-hero { min-height:400px; }
  .cpab-story__text { padding:48px 24px; }
  .cpab-mission,.cpab-promise { padding:72px 20px; }
  .cpab-cta__btns { flex-direction:column; align-items:stretch; }
}
/* END_SECTION:petboutiq-about */

/* START_SECTION:petboutiq-announcement-bar (INDEX:13) */
/* ── Announcement Bar — fixed, sits above fixed header ── */
  .cp-ann {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1100;
    background: #5C7A6B;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 44px;
    padding: 0 52px;
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    overflow: hidden;
    transition: height 0.35s ease, opacity 0.35s ease;
  }
  .cp-ann.cp-ann--hidden {
    height: 0;
    opacity: 0;
    pointer-events: none;
  }

  /* ── Messages container ─────────────────────────────── */
  .cp-ann__messages {
    position: relative;
    flex: 1;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }
  .cp-ann__msg {
    position: absolute;
    left: 0; right: 0;
    text-align: center;
    font-size: 0.82rem;
    font-weight: 500;
    color: #fff;
    letter-spacing: 0.025em;
    line-height: 1.4;
    opacity: 0;
    transition: opacity 0.55s ease;
    pointer-events: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 0 8px;
  }
  .cp-ann__msg--active {
    opacity: 1;
    pointer-events: auto;
  }

  /* ── Close button ───────────────────────────────────── */
  .cp-ann__close {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: rgba(255,255,255,0.7);
    font-size: 0.8rem;
    cursor: pointer;
    padding: 8px 10px;
    min-width: 36px;
    min-height: 36px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    transition: color 0.2s ease, background 0.2s ease;
    font-family: inherit;
  }
  .cp-ann__close:hover {
    color: #fff;
    background: rgba(255,255,255,0.12);
  }

  /* ── Mobile ─────────────────────────────────────────── */
  @media (max-width: 600px) {
    .cp-ann {
      height: 48px;
      padding: 0 48px;
    }
    .cp-ann__msg {
      font-size: 0.72rem;
      letter-spacing: 0.015em;
      white-space: normal;
      text-align: center;
    }
    .cp-ann__close {
      right: 10px;
      min-width: 40px;
      min-height: 40px;
    }
  }
/* END_SECTION:petboutiq-announcement-bar */

/* START_SECTION:petboutiq-before-after (INDEX:14) */
.cp-ba { padding: 120px 24px; background: #fff; font-family: 'Inter', system-ui, sans-serif; }
  .cp-ba__inner { max-width: 1100px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
  .cp-ba__header { text-align: center; margin-bottom: 60px; max-width: 640px; }
  .cp-ba__label {
    display: inline-block; font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .12em;
    color: #7B9E87; margin-bottom: 14px;
  }
  .cp-ba__heading {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 700; color: #2D2D2D; line-height: 1.15; margin-bottom: 14px;
  }
  .cp-ba__sub { font-size: 1.05rem; line-height: 1.65; color: #8A8A82; max-width: 480px; margin: 0 auto; }
  .cp-ba__grid {
    display: grid; grid-template-columns: 1fr auto 1fr;
    gap: 0; width: 100%; align-items: start;
  }
  .cp-ba__card {
    border-radius: 20px; padding: 36px 32px;
    display: flex; flex-direction: column;
    transition: transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s cubic-bezier(.4,0,.2,1);
  }
  .cp-ba__card:hover { transform: translateY(-4px); box-shadow: 0 20px 50px rgba(0,0,0,.08); }
  .cp-ba__card--before {
    background: #FDF6F2; border: 1.5px solid #ECEAE5;
    border-left: 4px solid #C67D5B;
    box-shadow: 0 4px 24px rgba(198,125,91,.08);
  }
  .cp-ba__card--after {
    background: #F0F6F2; border: 1.5px solid #DDEAE2;
    border-left: 4px solid var(--cp-sage, #5C7A6B);
    box-shadow: 0 4px 24px rgba(92,122,107,.1);
  }
  .cp-ba__card-header { margin-bottom: 24px; }
  .cp-ba__card-badge {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: .7rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .1em;
    padding: 6px 14px; border-radius: 100px;
  }
  .cp-ba__card-badge--before { background: rgba(198,125,91,.12); color: #C67D5B; border: 1px solid rgba(198,125,91,.25); }
  .cp-ba__card-badge--after { background: rgba(92,122,107,.12); color: var(--cp-sage,#5C7A6B); border: 1px solid rgba(92,122,107,.25); }
  .cp-ba__dog-icon { display: flex; justify-content: center; margin-bottom: 28px; }
  .cp-ba__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
  .cp-ba__item {
    display: flex; align-items: center; gap: 12px;
    font-size: .9rem; line-height: 1.55; color: #2D2D2D;
    padding: 12px 16px; border-radius: 12px;
    background: rgba(255,255,255,.6); border: 1px solid rgba(0,0,0,.04);
  }
  .cp-ba__item--after { background: rgba(255,255,255,.7); border-color: rgba(92,122,107,.1); }
  .cp-ba__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px; border-radius: 8px; flex-shrink: 0;
  }
  .cp-ba__icon--before { background: rgba(198,125,91,.12); color: #C67D5B; }
  .cp-ba__icon--after { background: rgba(92,122,107,.12); color: var(--cp-sage,#5C7A6B); }
  .cp-ba__arrow {
    display: flex; flex-direction: column; align-items: center;
    gap: 8px; padding: 0 20px; padding-top: 140px;
  }
  .cp-ba__arrow-label {
    font-size: .68rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .1em; color: var(--cp-sage,#5C7A6B);
    writing-mode: vertical-rl;
  }
  .cp-ba__cta { margin-top: 52px; display: flex; flex-direction: column; align-items: center; gap: 14px; }
  .cp-ba__cta-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 16px 36px; border-radius: 12px;
    background: var(--cp-sage,#5C7A6B); color: #fff;
    font-size: .95rem; font-weight: 600; text-decoration: none;
    box-shadow: 0 4px 20px rgba(92,122,107,.4);
    transition: all .35s cubic-bezier(.4,0,.2,1);
  }
  .cp-ba__cta-btn:hover {
    background: var(--cp-sage-dark,#3D5247);
    box-shadow: 0 8px 28px rgba(61,82,71,.45);
    transform: translateY(-3px);
  }
  .cp-ba__cta-btn svg { transition: transform .3s ease; }
  .cp-ba__cta-btn:hover svg { transform: translateX(4px); }
  .cp-ba__cta-note {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: .82rem; color: #8A8A82; font-weight: 500;
  }
  .cp-ba__cta-note svg { color: var(--cp-sage,#5C7A6B); }

  @media (max-width: 768px) {
    .cp-ba { padding: 90px 20px; }
    .cp-ba__grid { grid-template-columns: 1fr; gap: 0; }
    .cp-ba__arrow { padding: 20px 0; flex-direction: row; justify-content: center; }
    .cp-ba__arrow-label { writing-mode: horizontal-tb; }
    .cp-ba__card { padding: 28px 22px; }
    .cp-ba__header { margin-bottom: 40px; }
  }
/* END_SECTION:petboutiq-before-after */

/* START_SECTION:petboutiq-collections-showcase (INDEX:15) */
.cp-showcase {
    padding: 100px 24px;
    background: var(--cp-cream, #F7F5F0);
    font-family: var(--cp-font-sans, 'Inter', system-ui, sans-serif);
  }
  .cp-showcase__inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .cp-showcase__heading {
    font-family: var(--cp-font-serif, 'Playfair Display', Georgia, serif);
    font-size: clamp(1.8rem, 3.5vw, 2.5rem);
    font-weight: 700;
    color: var(--cp-text, #2D2D2D);
    margin-bottom: 52px;
    line-height: 1.2;
  }

  /* ── Grid ───────────────────────── */
  .cp-showcase__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    width: 100%;
  }

  /* ── Card ───────────────────────── */
  .cp-showcase__card {
    position: relative;
    height: 440px;
    border-radius: 16px;
    overflow: hidden;
    text-decoration: none;
    display: flex;
    align-items: flex-end;
    cursor: pointer;
    transition: transform 0.4s cubic-bezier(.4,0,.2,1), box-shadow 0.4s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 4px 24px rgba(0,0,0,0.10);
  }
  .cp-showcase__card:hover {
    transform: translateY(-8px);
    box-shadow: 0 24px 64px rgba(0,0,0,0.18);
  }
  .cp-showcase__card:hover .cp-showcase__overlay {
    opacity: 0.55;
  }
  .cp-showcase__card:hover .cp-showcase__bg-img {
    transform: scale(1.06);
  }
  .cp-showcase__card:hover .cp-showcase__cta {
    gap: 10px;
  }

  /* ── Background image ───────────── */
  .cp-showcase__bg {
    position: absolute;
    inset: 0;
  }
  .cp-showcase__bg-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(.4,0,.2,1);
    display: block;
    max-width: none;
  }

  /* ── Overlays ───────────────────── */
  .cp-showcase__overlay {
    position: absolute;
    inset: 0;
    transition: opacity 0.4s ease;
  }
  .cp-showcase__overlay--sage {
    background: linear-gradient(
      170deg,
      rgba(92,122,107,0.25) 0%,
      rgba(61,82,71,0.78) 100%
    );
    opacity: 0.72;
  }
  .cp-showcase__overlay--cream {
    background: linear-gradient(
      170deg,
      rgba(200,185,160,0.20) 0%,
      rgba(140,120,90,0.80) 100%
    );
    opacity: 0.72;
  }
  .cp-showcase__overlay--terracotta {
    background: linear-gradient(
      170deg,
      rgba(196,130,90,0.25) 0%,
      rgba(155,85,50,0.80) 100%
    );
    opacity: 0.72;
  }

  /* ── Card content ───────────────── */
  .cp-showcase__content {
    position: relative;
    z-index: 2;
    padding: 32px 28px;
    width: 100%;
    text-align: left;
  }
  .cp-showcase__card-label {
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: rgba(255,255,255,0.7);
    margin-bottom: 8px;
  }
  .cp-showcase__card-title {
    font-family: var(--cp-font-serif, 'Playfair Display', Georgia, serif);
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.15;
    margin-bottom: 10px;
    text-shadow: 0 2px 12px rgba(0,0,0,0.2);
  }
  .cp-showcase__card-subtitle {
    font-size: 0.88rem;
    color: rgba(255,255,255,0.82);
    line-height: 1.55;
    margin-bottom: 20px;
    max-width: 260px;
  }
  .cp-showcase__cta {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 0.88rem;
    font-weight: 600;
    color: #fff;
    border: 1.5px solid rgba(255,255,255,0.6);
    border-radius: 100px;
    padding: 9px 20px;
    background: rgba(255,255,255,0.15);
    backdrop-filter: blur(4px);
    transition: background 0.3s ease, gap 0.3s ease, border-color 0.3s ease;
  }
  .cp-showcase__card:hover .cp-showcase__cta {
    background: rgba(255,255,255,0.28);
    border-color: rgba(255,255,255,0.9);
  }

  /* ── Responsive ─────────────────── */
  @media (max-width: 960px) {
    .cp-showcase__grid { grid-template-columns: 1fr 1fr; }
    .cp-showcase__card:last-child { grid-column: 1 / -1; height: 380px; }
  }
  @media (max-width: 640px) {
    .cp-showcase { padding: 72px 20px; }
    .cp-showcase__grid { grid-template-columns: 1fr; gap: 18px; }
    .cp-showcase__card { height: 340px; }
    .cp-showcase__card:last-child { grid-column: auto; height: 340px; }
  }
/* END_SECTION:petboutiq-collections-showcase */

/* START_SECTION:petboutiq-comparison (INDEX:16) */
.cp-compare { padding: 120px 24px; background: var(--cp-cream,#F7F5F0); font-family: 'Inter', system-ui, sans-serif; }
  .cp-compare__inner { max-width: 860px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; }
  .cp-compare__header { text-align: center; margin-bottom: 52px; max-width: 600px; }
  .cp-compare__label {
    display: inline-block; font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .12em; color: #7B9E87; margin-bottom: 14px;
  }
  .cp-compare__heading {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 700; color: #2D2D2D; line-height: 1.15; margin-bottom: 14px;
  }
  .cp-compare__sub { font-size: 1.05rem; line-height: 1.65; color: #8A8A82; }
  .cp-compare__scroll-wrap {
    width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch;
    border-radius: 20px; box-shadow: 0 8px 40px rgba(0,0,0,.09); margin-bottom: 20px;
  }
  .cp-compare__table {
    width: 100%; min-width: 560px; border-collapse: separate;
    border-spacing: 0; border-radius: 20px; overflow: hidden;
  }
  .cp-compare__th { padding: 20px 24px; font-size: .9rem; font-weight: 700; text-align: center; }
  .cp-compare__th--feature { text-align: left; background: #2D2D2D; color: #fff; width: 48%; }
  .cp-compare__th--petboutiq { background: var(--cp-sage,#5C7A6B); color: #fff; width: 28%; }
  .cp-compare__th--others { background: #E8E4DE; color: #8A8A82; width: 24%; font-weight: 600; }
  .cp-compare__th-inner { display: flex; flex-direction: column; align-items: center; gap: 6px; font-size: 1rem; }
  .cp-compare__th-tag {
    display: inline-block; font-size: .62rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .1em;
    background: rgba(255,255,255,.2); padding: 3px 10px;
    border-radius: 100px; border: 1px solid rgba(255,255,255,.3);
  }
  .cp-compare__row--light { background: #fff; }
  .cp-compare__row--cream { background: #FAFAF7; }
  .cp-compare__td { padding: 16px 24px; border-top: 1px solid #F0EDE8; vertical-align: middle; }
  .cp-compare__td--feature { font-size: .92rem; font-weight: 500; color: #2D2D2D; text-align: left; }
  .cp-compare__td--petboutiq { text-align: center; background: rgba(92,122,107,.04); border-left: 1px solid rgba(92,122,107,.12); border-right: 1px solid rgba(92,122,107,.12); }
  .cp-compare__td--others { text-align: center; }
  .cp-compare__check { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border-radius: 50%; }
  .cp-compare__check--yes { background: rgba(92,122,107,.12); color: var(--cp-sage,#5C7A6B); }
  .cp-compare__check--no { background: rgba(139,138,130,.1); color: #C0BDB6; }
  .cp-compare__row:last-child .cp-compare__td:first-child { border-bottom-left-radius: 20px; }
  .cp-compare__row:last-child .cp-compare__td:last-child { border-bottom-right-radius: 20px; }
  .cp-compare__footnote {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: .78rem; color: #8A8A82; margin-bottom: 48px; text-align: center;
  }
  .cp-compare__footnote svg { flex-shrink: 0; color: var(--cp-sage,#5C7A6B); }
  .cp-compare__actions { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
  .cp-compare__btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 15px 32px; border-radius: 12px;
    font-size: .92rem; font-weight: 600; text-decoration: none;
    transition: all .35s cubic-bezier(.4,0,.2,1);
  }
  .cp-compare__btn--primary {
    background: var(--cp-sage,#5C7A6B); color: #fff;
    box-shadow: 0 4px 20px rgba(92,122,107,.4);
  }
  .cp-compare__btn--primary:hover { background: var(--cp-sage-dark,#3D5247); transform: translateY(-2px); }
  .cp-compare__btn--secondary {
    background: transparent; color: #4A6B55;
    border: 1.5px solid rgba(74,107,85,.3);
  }
  .cp-compare__btn--secondary:hover { background: rgba(74,107,85,.06); transform: translateY(-2px); }
  @media (max-width: 768px) {
    .cp-compare { padding: 90px 20px; }
    .cp-compare__scroll-wrap { border-radius: 14px; }
    .cp-compare__th,.cp-compare__td { padding: 14px 16px; }
    .cp-compare__actions { flex-direction: column; align-items: center; }
    .cp-compare__btn { width: 100%; max-width: 320px; justify-content: center; }
  }
/* END_SECTION:petboutiq-comparison */

/* START_SECTION:petboutiq-contact (INDEX:17) */
.cpct { background:#F7F5F0; font-family:'Inter',system-ui,-apple-system,sans-serif; }
.cpct-label { display:inline-block; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.2em; color:#5C7A6B; margin-bottom:14px; }
/* Header */
.cpct-header { text-align:center; padding:80px 24px 72px; max-width:700px; margin:0 auto; }
.cpct-header__title { font-family:'Playfair Display',Georgia,serif; font-size:clamp(2.2rem,4vw,3rem); font-weight:700; color:#2D2D2D; line-height:1.15; margin-bottom:18px; }
.cpct-header__sub { font-size:1.05rem; color:#6B6B6B; line-height:1.75; }
/* Body 2-col */
.cpct-body { display:grid; grid-template-columns:3fr 2fr; gap:64px; max-width:1100px; margin:0 auto; padding:0 28px 100px; }
.cpct-col-title { font-family:'Playfair Display',Georgia,serif; font-size:1.5rem; font-weight:700; color:#2D2D2D; margin-bottom:32px; }
/* Form */
.cpct-form { display:flex; flex-direction:column; gap:0; }
.cpct-form__row { margin-bottom:20px; }
.cpct-form__label { display:block; font-size:.82rem; font-weight:600; color:#2D2D2D; margin-bottom:7px; }
.cpct-form__input { width:100%; padding:13px 16px; border-radius:12px; border:1.5px solid #ECEAE5; background:#fff; font-family:inherit; font-size:.9rem; color:#2D2D2D; outline:none; transition:border-color .25s ease,box-shadow .25s ease; box-sizing:border-box; }
.cpct-form__input:focus { border-color:#5C7A6B; box-shadow:0 0 0 3px rgba(92,122,107,.1); }
.cpct-form__select { -webkit-appearance:none; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8A82' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:40px; cursor:pointer; }
.cpct-form__textarea { resize:vertical; min-height:140px; }
.cpct-form__btn { width:100%; padding:15px 28px; border-radius:12px; background:#5C7A6B; color:#fff; font-family:inherit; font-size:.95rem; font-weight:600; border:none; cursor:pointer; transition:background .25s ease,transform .2s ease; margin-bottom:12px; }
.cpct-form__btn:hover { background:#3D5247; transform:translateY(-1px); }
.cpct-form__note { text-align:center; font-size:.8rem; color:#9A9A9A; }
.cpct-form__success { display:flex; align-items:center; gap:12px; padding:20px; background:rgba(92,122,107,.08); border:1.5px solid rgba(92,122,107,.3); border-radius:12px; color:#5C7A6B; font-size:.95rem; font-weight:500; }
/* Info col */
.cpct-info-col { display:flex; flex-direction:column; gap:0; }
.cpct-info-block { padding:4px 0; }
.cpct-info__item { display:flex; align-items:flex-start; gap:14px; margin-bottom:20px; }
.cpct-info__icon { width:36px; height:36px; border-radius:10px; background:rgba(92,122,107,.1); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.cpct-info__key { font-size:.78rem; font-weight:600; color:#9A9A9A; text-transform:uppercase; letter-spacing:.05em; margin-bottom:3px; }
.cpct-info__val { font-size:.95rem; color:#2D2D2D; text-decoration:none; font-weight:500; }
.cpct-info__val:hover { color:#5C7A6B; }
.cpct-info__divider { height:1px; background:#ECEAE5; margin:24px 0; }
.cpct-hours { display:flex; flex-direction:column; gap:10px; }
.cpct-hours__row { display:flex; justify-content:space-between; font-size:.9rem; color:#2D2D2D; }
.cpct-hours__row--closed { color:#9A9A9A; }
.cpct-social { display:flex; gap:12px; margin-bottom:16px; }
.cpct-social__link { width:42px; height:42px; border-radius:12px; border:1.5px solid #ECEAE5; display:flex; align-items:center; justify-content:center; color:#6B6B6B; text-decoration:none; transition:border-color .25s ease,color .25s ease,background .25s ease; }
.cpct-social__link:hover { border-color:#5C7A6B; color:#5C7A6B; background:rgba(92,122,107,.06); }
.cpct-social__note { font-size:.85rem; color:#8A8A82; line-height:1.6; }
/* FAQ Strip */
.cpct-faq { background:#fff; border-top:1px solid #ECEAE5; padding:80px 28px; }
.cpct-faq__header { text-align:center; margin-bottom:52px; }
.cpct-faq__title { font-family:'Playfair Display',Georgia,serif; font-size:clamp(1.8rem,3vw,2.4rem); font-weight:700; color:#2D2D2D; line-height:1.2; }
.cpct-faq__list { max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:0; }
.cpct-faq__item { border-bottom:1px solid #ECEAE5; }
.cpct-faq__q { width:100%; background:none; border:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:22px 4px; font-family:'Inter',system-ui,sans-serif; font-size:1rem; font-weight:600; color:#2D2D2D; text-align:left; transition:color .2s ease; }
.cpct-faq__q:hover { color:#5C7A6B; }
.cpct-faq__chevron { flex-shrink:0; transition:transform .3s ease; color:#8A8A82; }
.cpct-faq__q[aria-expanded="true"] .cpct-faq__chevron { transform:rotate(180deg); color:#5C7A6B; }
.cpct-faq__a { padding:0 4px 20px; font-size:.92rem; color:#6B6B6B; line-height:1.75; }
/* Responsive */
@media (max-width:860px) {
  .cpct-body { grid-template-columns:1fr; gap:48px; padding:0 20px 80px; }
}
@media (max-width:600px) {
  .cpct-header { padding:60px 20px 56px; }
  .cpct-faq { padding:60px 20px; }
}
/* END_SECTION:petboutiq-contact */

/* START_SECTION:petboutiq-faq (INDEX:18) */
.cp-faq {
    padding: 120px 24px;
    background: #FAFAF7;
    font-family: 'Inter', system-ui, sans-serif;
  }
  .cp-faq__inner {
    max-width: 760px; margin: 0 auto;
    display: flex; flex-direction: column; align-items: center;
    text-align: center;
  }
  .cp-faq__label {
    font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .12em;
    color: #7B9E87; margin-bottom: 14px;
  }
  .cp-faq__heading {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 700; color: #2D2D2D;
    margin-bottom: 14px; line-height: 1.15;
  }
  .cp-faq__sub {
    font-size: 1.05rem; color: #8A8A82;
    line-height: 1.65; max-width: 480px; margin-bottom: 56px;
  }
  .cp-faq__list {
    width: 100%; display: flex; flex-direction: column; gap: 12px;
    text-align: left;
  }
  .cp-faq__item {
    background: #fff; border-radius: 16px;
    border: 1.5px solid #ECEAE5;
    overflow: hidden;
    transition: border-color .3s ease, box-shadow .3s ease;
  }
  .cp-faq__item[open] {
    border-color: rgba(92,122,107,.35);
    box-shadow: 0 4px 20px rgba(92,122,107,.1);
  }
  .cp-faq__question {
    display: flex; align-items: center; justify-content: space-between;
    gap: 16px; padding: 22px 24px;
    cursor: pointer; list-style: none;
    font-size: .96rem; font-weight: 600; color: #2D2D2D;
    transition: background .2s ease;
    user-select: none;
  }
  .cp-faq__question::-webkit-details-marker { display: none; }
  .cp-faq__question::marker { display: none; }
  .cp-faq__item[open] .cp-faq__question {
    color: var(--cp-sage, #5C7A6B);
    background: rgba(92,122,107,.04);
  }
  .cp-faq__question:hover { background: rgba(92,122,107,.03); }
  .cp-faq__question-text { flex: 1; line-height: 1.4; }
  .cp-faq__icon {
    flex-shrink: 0; width: 34px; height: 34px; border-radius: 10px;
    background: rgba(92,122,107,.08); color: var(--cp-sage,#5C7A6B);
    display: flex; align-items: center; justify-content: center;
    transition: background .25s ease, transform .3s ease;
  }
  .cp-faq__item[open] .cp-faq__icon {
    background: var(--cp-sage,#5C7A6B); color: #fff;
    transform: rotate(180deg);
  }
  .cp-faq__icon-plus  { display: block; }
  .cp-faq__icon-minus { display: none; }
  .cp-faq__item[open] .cp-faq__icon-plus  { display: none; }
  .cp-faq__item[open] .cp-faq__icon-minus { display: block; }
  .cp-faq__answer {
    padding: 0 24px 22px;
    animation: cpFaqOpen .28s ease-out both;
  }
  .cp-faq__answer p {
    font-size: .92rem; line-height: 1.72;
    color: #5A5A52; margin: 0;
  }
  @keyframes cpFaqOpen {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  .cp-faq__contact {
    margin-top: 52px; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: 16px;
    padding: 32px; border-radius: 16px;
    background: linear-gradient(135deg,rgba(92,122,107,.07),rgba(92,122,107,.03));
    border: 1px solid rgba(92,122,107,.15);
    width: 100%;
  }
  .cp-faq__contact-text {
    font-size: .95rem; color: #5A5A52; margin: 0; line-height: 1.6;
  }
  .cp-faq__contact-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 12px 28px; border-radius: 10px;
    background: var(--cp-sage,#5C7A6B); color: #fff;
    font-size: .88rem; font-weight: 600; text-decoration: none;
    transition: all .3s ease;
  }
  .cp-faq__contact-btn:hover {
    background: var(--cp-sage-dark,#3D5247); transform: translateY(-2px);
  }

  @media (max-width: 640px) {
    .cp-faq { padding: 90px 20px; }
    .cp-faq__question { padding: 18px 20px; font-size: .9rem; }
    .cp-faq__answer { padding: 0 20px 18px; }
  }
/* END_SECTION:petboutiq-faq */

/* START_SECTION:petboutiq-featured-products (INDEX:19) */
.cp-products {
    padding: 120px 24px;
    background: var(--cp-cream, #F7F5F0);
    font-family: var(--cp-font-sans, 'Inter', system-ui, sans-serif);
  }
  .cp-products__inner {
    max-width: 1100px; margin: 0 auto;
    display: flex; flex-direction: column; align-items: center; text-align: center;
  }
  .cp-products__heading {
    font-family: var(--cp-font-serif, 'Playfair Display', Georgia, serif);
    font-size: clamp(2rem, 4vw, 2.8rem); font-weight: 700;
    color: var(--cp-text, #2D2D2D); margin-bottom: 14px; line-height: 1.15;
  }
  .cp-products__sub {
    font-size: 1.05rem; color: var(--cp-muted, #8A8A82);
    line-height: 1.65; max-width: 480px; margin-bottom: 64px;
  }

  /* ── Grid ──────────────────────── */
  .cp-products__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px; width: 100%; margin-bottom: 52px;
  }

  /* ── Card ──────────────────────── */
  .cp-products__card {
    background: #fff;
    border-radius: var(--cp-radius-lg, 20px);
    overflow: hidden;
    text-align: left;
    border: 1px solid var(--cp-border, #ECEAE5);
    box-shadow: var(--cp-shadow, 0 2px 8px rgba(0,0,0,0.06));
    transition: transform 0.35s cubic-bezier(.4,0,.2,1), box-shadow 0.35s cubic-bezier(.4,0,.2,1);
    position: relative;
    display: flex; flex-direction: column;
  }
  .cp-products__card:hover {
    transform: translateY(-6px);
    box-shadow: var(--cp-shadow-hover, 0 20px 50px rgba(0,0,0,0.1));
    border-color: rgba(92,122,107,0.25);
  }

  /* ── Image ──────────────────────── */
  .cp-products__img-wrap {
    display: block; position: relative;
    aspect-ratio: 4 / 5; overflow: hidden;
    background: linear-gradient(170deg, #F5EDE3, #EAE5DD);
    text-decoration: none;
  }
  .cp-products__img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 0.5s cubic-bezier(.4,0,.2,1);
  }
  .cp-products__card:hover .cp-products__img { transform: scale(1.05); }
  .cp-products__placeholder-img {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
  }

  /* ── Badges ─────────────────────── */
  .cp-products__badge {
    position: absolute; top: 14px; left: 14px;
    padding: 5px 14px; border-radius: var(--cp-radius-sm, 10px);
    font-size: 0.68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.05em;
  }
  .cp-products__badge--sale { background: var(--cp-terracotta, #C67D5B); color: #fff; }
  .cp-products__badge--sold { background: var(--cp-text, #2D2D2D); color: #fff; }
  .cp-products__badge--best { background: var(--cp-sage, #5C7A6B); color: #fff; }
  .cp-products__badge--new  { background: var(--cp-terracotta, #C67D5B); color: #fff; }

  /* ── Info ───────────────────────── */
  .cp-products__info {
    padding: 18px 20px 12px; flex: 1;
  }
  .cp-products__stars {
    display: flex; align-items: center; gap: 2px;
    margin-bottom: 8px;
  }
  .cp-products__rating-count {
    font-size: 0.75rem; color: var(--cp-muted, #8A8A82);
    margin-left: 4px;
  }
  .cp-products__name {
    font-size: 0.98rem; font-weight: 600;
    color: var(--cp-text, #2D2D2D);
    margin-bottom: 6px; line-height: 1.35;
  }
  .cp-products__pdesc {
    font-size: 0.82rem; color: var(--cp-muted, #8A8A82);
    margin-bottom: 8px; line-height: 1.45;
  }
  .cp-products__price {
    font-size: 0.95rem; font-weight: 700;
    color: var(--cp-sage-dark, #3D5247);
    margin-bottom: 4px;
  }
  .cp-products__compare {
    text-decoration: line-through;
    color: var(--cp-muted, #8A8A82); font-weight: 400;
    margin-right: 6px;
  }
  .cp-products__urgency {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 0.74rem; font-weight: 600;
    color: var(--cp-terracotta, #C67D5B);
    margin-top: 6px;
  }

  /* ── Add to Cart ─────────────────── */
  .cp-products__atc-wrap {
    padding: 0 16px 16px;
    opacity: 0; transform: translateY(8px);
    transition: opacity 0.3s ease, transform 0.3s ease;
  }
  .cp-products__card:hover .cp-products__atc-wrap {
    opacity: 1; transform: translateY(0);
  }
  .cp-products__atc-btn {
    width: 100%; padding: 13px 20px; border-radius: var(--cp-radius, 14px);
    background: var(--cp-sage, #5C7A6B); color: #fff;
    font-family: var(--cp-font-sans, 'Inter', system-ui, sans-serif);
    font-size: 0.875rem; font-weight: 600;
    border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    transition: background 0.3s ease, transform 0.2s ease;
  }
  .cp-products__atc-btn:hover { background: var(--cp-sage-dark, #3D5247); transform: none; }
  .cp-products__atc-btn:disabled {
    background: var(--cp-border, #ECEAE5); color: var(--cp-muted, #8A8A82); cursor: not-allowed;
  }
  .cp-products__atc-form { width: 100%; }

  .cp-products__hint {
    font-size: 0.82rem; color: var(--cp-muted, #8A8A82);
    font-style: italic; margin-bottom: 32px;
  }

  /* ── Responsive ─────────────────── */
  @media (max-width: 900px) {
    .cp-products { padding: 90px 20px; }
    .cp-products__grid { grid-template-columns: 1fr 1fr; gap: 20px; }
  }
  @media (max-width: 560px) {
    .cp-products__grid { grid-template-columns: 1fr; max-width: 400px; }
    /* Always show Add to Cart on mobile */
    .cp-products__atc-wrap { opacity: 1; transform: none; }
  }
/* END_SECTION:petboutiq-featured-products */

/* START_SECTION:petboutiq-hero (INDEX:20) */
.cp-hero {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 120px 24px 100px;
    overflow: hidden;
    font-family: 'Inter', system-ui, sans-serif;
  }
  .cp-hero__bg {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover; object-position: center 40%;
    z-index: 0;
  }
  .cp-hero__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg,rgba(18,24,20,.28) 0%,rgba(18,24,20,.45) 55%,rgba(18,24,20,.65) 100%);
    z-index: 1;
  }
  .cp-hero__inner {
    position: relative; z-index: 2;
    display: flex; flex-direction: column; align-items: center;
    text-align: center; max-width: 820px; margin: 0 auto;
  }
  .cp-hero__badge {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 9px 22px; border-radius: 100px;
    background: rgba(255,255,255,.14);
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,.28);
    color: #fff; font-size: .8rem; font-weight: 600;
    letter-spacing: .03em; margin-bottom: 30px;
    animation: cpFadeUp .7s ease-out both;
  }
  .cp-hero__heading {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2.8rem, 7vw, 5rem);
    font-weight: 800; line-height: 1.06;
    letter-spacing: -.02em; color: #fff;
    margin-bottom: 22px;
    text-shadow: 0 2px 24px rgba(0,0,0,.22);
    animation: cpFadeUp .8s ease-out .1s both;
  }
  .cp-hero__sub {
    font-size: clamp(1.02rem, 2vw, 1.22rem);
    line-height: 1.68; color: rgba(255,255,255,.92);
    max-width: 560px; margin-bottom: 40px;
    text-shadow: 0 1px 8px rgba(0,0,0,.2);
    animation: cpFadeUp .8s ease-out .2s both;
  }
  .cp-hero__actions {
    display: flex; flex-wrap: wrap; gap: 14px;
    justify-content: center; margin-bottom: 26px;
    animation: cpFadeUp .8s ease-out .3s both;
  }
  .cp-hero__btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 17px 34px; border-radius: 12px;
    font-size: .95rem; font-weight: 600;
    text-decoration: none; cursor: pointer;
    transition: all .35s cubic-bezier(.4,0,.2,1);
  }
  .cp-hero__btn--primary {
    background: var(--cp-sage,#5C7A6B); color: #fff;
    box-shadow: 0 4px 24px rgba(92,122,107,.5);
  }
  .cp-hero__btn--primary:hover {
    background: var(--cp-sage-dark,#3D5247);
    box-shadow: 0 8px 32px rgba(61,82,71,.55);
    transform: translateY(-3px);
  }
  .cp-hero__btn--primary svg { transition: transform .3s ease; }
  .cp-hero__btn--primary:hover svg { transform: translateX(4px); }
  .cp-hero__btn--secondary {
    background: rgba(255,255,255,.14);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    color: #fff; border: 1.5px solid rgba(255,255,255,.45);
  }
  .cp-hero__btn--secondary:hover {
    background: #fff; color: var(--cp-sage,#5C7A6B);
    border-color: #fff; transform: translateY(-3px);
  }
  .cp-hero__stars {
    display: inline-flex; align-items: center; gap: 10px;
    background: rgba(255,255,255,.1);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 100px; padding: 8px 20px;
    margin-bottom: 28px;
    animation: cpFadeUp .8s ease-out .38s both;
  }
  .cp-hero__stars-icons { display: flex; align-items: center; gap: 2px; }
  .cp-hero__stars-text {
    font-size: .82rem; color: rgba(255,255,255,.92);
    font-weight: 500; letter-spacing: .01em;
  }
  .cp-hero__micro {
    display: flex; align-items: center; gap: 16px;
    flex-wrap: wrap; justify-content: center;
    animation: cpFadeUp .8s ease-out .45s both;
  }
  .cp-hero__micro-item {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: .8rem; color: rgba(255,255,255,.82); font-weight: 500;
  }
  .cp-hero__micro-dot {
    width: 3px; height: 3px; border-radius: 50%;
    background: rgba(255,255,255,.35);
  }
  @keyframes cpFadeUp {
    from { opacity: 0; transform: translateY(22px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  @media (max-width: 640px) {
    .cp-hero { min-height: 90vh; padding: 100px 20px 80px; }
    .cp-hero__actions { flex-direction: column; width: 100%; max-width: 300px; }
    .cp-hero__btn { justify-content: center; width: 100%; }
    .cp-hero__micro { flex-direction: column; gap: 8px; }
    .cp-hero__micro-dot { display: none; }
  }
  @media (prefers-reduced-motion: reduce) {
    .cp-hero__badge,.cp-hero__heading,.cp-hero__sub,
    .cp-hero__actions,.cp-hero__stars,.cp-hero__micro { animation: none; }
  }
/* END_SECTION:petboutiq-hero */

/* START_SECTION:petboutiq-how-it-works (INDEX:21) */
.cp-hiw {
    padding: 120px 24px;
    background: var(--cp-cream, #F7F5F0);
    font-family: 'Inter', system-ui, sans-serif;
  }
  .cp-hiw__inner {
    max-width: 1100px; margin: 0 auto;
    display: flex; flex-direction: column; align-items: center;
    text-align: center;
  }
  .cp-hiw__label {
    font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .12em;
    color: #7B9E87; margin-bottom: 16px;
  }
  .cp-hiw__heading {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 700; color: var(--cp-text, #2D2D2D);
    margin-bottom: 14px; line-height: 1.15;
  }
  .cp-hiw__sub {
    font-size: 1.05rem; color: var(--cp-muted, #8A8A82);
    line-height: 1.65; max-width: 480px; margin-bottom: 64px;
  }
  .cp-hiw__steps {
    display: flex; align-items: stretch;
    justify-content: center; gap: 0; width: 100%;
    margin-bottom: 52px;
  }
  .cp-hiw__connector {
    display: flex; align-items: center;
    padding-top: 52px; flex-shrink: 0;
  }
  .cp-hiw__step {
    display: flex; flex-direction: column; align-items: center;
    text-align: center; flex: 1; max-width: 280px;
    padding: 36px 24px;
    background: #fff;
    border-radius: 20px;
    border: 1.5px solid var(--cp-border, #ECEAE5);
    transition: transform .35s cubic-bezier(.4,0,.2,1),
                box-shadow .35s cubic-bezier(.4,0,.2,1),
                border-color .3s ease;
  }
  .cp-hiw__step:hover {
    transform: translateY(-5px);
    box-shadow: 0 16px 36px rgba(0,0,0,.07);
    border-color: rgba(92,122,107,.3);
  }
  .cp-hiw__step-num {
    width: 34px; height: 34px; border-radius: 50%;
    background: var(--cp-sage, #5C7A6B); color: #fff;
    font-size: .82rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 16px;
  }
  .cp-hiw__icon {
    width: 60px; height: 60px; border-radius: 16px;
    background: linear-gradient(135deg,rgba(92,122,107,.12),rgba(92,122,107,.05));
    color: var(--cp-sage, #5C7A6B);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 20px;
    transition: background .3s ease, transform .3s ease;
  }
  .cp-hiw__step:hover .cp-hiw__icon {
    background: linear-gradient(135deg,rgba(92,122,107,.2),rgba(92,122,107,.08));
    transform: scale(1.06);
  }
  .cp-hiw__title {
    font-size: 1.05rem; font-weight: 700;
    color: var(--cp-text, #2D2D2D); margin-bottom: 10px;
  }
  .cp-hiw__desc {
    font-size: .88rem; color: var(--cp-muted, #8A8A82); line-height: 1.68;
  }
  .cp-hiw__cta-wrap {
    display: flex; justify-content: center;
  }
  .cp-hiw__cta-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 16px 36px; border-radius: 12px;
    background: var(--cp-sage, #5C7A6B); color: #fff;
    font-size: .95rem; font-weight: 600; text-decoration: none;
    box-shadow: 0 4px 20px rgba(92,122,107,.4);
    transition: all .35s cubic-bezier(.4,0,.2,1);
  }
  .cp-hiw__cta-btn:hover {
    background: var(--cp-sage-dark, #3D5247);
    box-shadow: 0 8px 28px rgba(61,82,71,.45);
    transform: translateY(-3px);
  }
  .cp-hiw__cta-btn svg { transition: transform .3s ease; }
  .cp-hiw__cta-btn:hover svg { transform: translateX(4px); }

  @media (max-width: 700px) {
    .cp-hiw { padding: 90px 20px; }
    .cp-hiw__steps { flex-direction: column; align-items: center; gap: 16px; }
    .cp-hiw__connector { display: none; }
    .cp-hiw__step { max-width: 360px; width: 100%; }
  }
/* END_SECTION:petboutiq-how-it-works */

/* START_SECTION:petboutiq-lifestyle-banner (INDEX:22) */
.cp-life { position: relative; min-height: 520px; display: flex; align-items: center; justify-content: center; font-family: 'Inter', system-ui, sans-serif; overflow: hidden; }
  .cp-life__img-wrap { position: absolute; inset: 0; }
  .cp-life__bg { width: 100%; height: 100%; object-fit: cover; object-position: center; }
  .cp-life__overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(45,70,55,0.55) 0%, rgba(61,82,71,0.42) 50%, rgba(80,108,90,0.38) 100%); }
  .cp-life__inner { position: relative; z-index: 1; text-align: center; max-width: 600px; padding: 80px 24px; }
  .cp-life__heading { font-family: 'Playfair Display', Georgia, serif; font-size: clamp(2.4rem, 5.5vw, 3.6rem); font-weight: 700; color: #fff; line-height: 1.1; margin-bottom: 18px; font-style: italic; text-shadow: 0 2px 20px rgba(0,0,0,0.25); }
  .cp-life__sub { font-size: 1.05rem; color: rgba(255,255,255,0.8); line-height: 1.65; max-width: 460px; margin: 0 auto 36px; }
  .cp-life__btn { display: inline-flex; align-items: center; gap: 8px; padding: 16px 34px; border-radius: 12px; background: rgba(255,255,255,0.15); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border: 1.5px solid rgba(255,255,255,0.3); color: #fff; font-size: 0.95rem; font-weight: 600; text-decoration: none; transition: all 0.35s cubic-bezier(.4,0,.2,1); }
  .cp-life__btn:hover { background: #fff; color: #4A6B55; border-color: #fff; transform: translateY(-3px); box-shadow: 0 8px 30px rgba(0,0,0,0.2); }
  .cp-life__btn svg { transition: transform 0.3s ease; }
  .cp-life__btn:hover svg { transform: translateX(4px); }
  @media (max-width: 640px) { .cp-life { min-height: 440px; } .cp-life__inner { padding: 60px 20px; } }
/* END_SECTION:petboutiq-lifestyle-banner */

/* START_SECTION:petboutiq-newsletter (INDEX:23) */
.cp-news {
    padding: 110px 24px;
    background: linear-gradient(160deg, #3A5645 0%, #4A6B55 55%, #5A7C65 100%);
    font-family: 'Inter', system-ui, sans-serif;
    position: relative; overflow: hidden;
  }
  .cp-news::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,255,255,.05) 0%, transparent 70%);
    pointer-events: none;
  }
  .cp-news__inner {
    max-width: 560px; margin: 0 auto;
    display: flex; flex-direction: column; align-items: center;
    text-align: center; position: relative; z-index: 1;
  }
  .cp-news__icon {
    width: 60px; height: 60px; border-radius: 18px;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.9);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 26px;
  }
  .cp-news__heading {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2rem, 4.5vw, 2.7rem);
    font-weight: 700; color: #fff; margin-bottom: 14px; line-height: 1.15;
  }
  .cp-news__sub {
    font-size: 1.05rem; color: rgba(255,255,255,.82);
    line-height: 1.65; max-width: 440px; margin-bottom: 36px;
  }
  .cp-news__form { display: flex; gap: 10px; width: 100%; max-width: 460px; }
  .cp-news__input {
    flex: 1; padding: 16px 20px;
    border: 1.5px solid rgba(255,255,255,.25);
    border-radius: 12px;
    background: rgba(255,255,255,.1);
    color: #fff; font-size: .95rem; outline: none;
    transition: border-color .3s ease, background .3s ease;
  }
  .cp-news__input::placeholder { color: rgba(255,255,255,.48); }
  .cp-news__input:focus {
    border-color: rgba(255,255,255,.55);
    background: rgba(255,255,255,.14);
  }
  .cp-news__btn {
    padding: 16px 28px; border-radius: 12px;
    background: #fff; color: #3A5645;
    font-size: .9rem; font-weight: 700;
    border: none; cursor: pointer;
    transition: all .35s cubic-bezier(.4,0,.2,1);
    white-space: nowrap;
  }
  .cp-news__btn:hover {
    background: #F5F0E8; transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,.2);
  }
  .cp-news__note {
    display: inline-flex; align-items: center; gap: 6px;
    margin-top: 18px; font-size: .78rem;
    color: rgba(255,255,255,.52);
  }
  .cp-news__note svg { color: rgba(255,255,255,.6); }
  .cp-news__success {
    display: flex; align-items: center; gap: 10px;
    background: rgba(255,255,255,.15); backdrop-filter: blur(8px);
    border-radius: 12px; padding: 14px 24px; color: #fff;
    font-size: .9rem; margin-bottom: 20px;
    width: 100%; max-width: 460px; text-align: left;
  }
  .cp-news__error {
    background: rgba(198,125,91,.3); border-radius: 12px;
    padding: 14px 24px; color: #fff; font-size: .9rem;
    margin-bottom: 20px; width: 100%; max-width: 460px;
  }
  @media (max-width: 480px) {
    .cp-news { padding: 80px 20px; }
    .cp-news__form { flex-direction: column; }
    .cp-news__btn { width: 100%; }
  }
/* END_SECTION:petboutiq-newsletter */

/* START_SECTION:petboutiq-page-content (INDEX:24) */
.cp-page-content {
    background: var(--cp-cream, #F7F5F0);
    padding: 80px 24px;
    font-family: var(--cp-font-sans);
  }
  .cp-page-content__inner {
    max-width: 800px;
    margin: 0 auto;
    background: #fff;
    border-radius: var(--cp-radius, 16px);
    padding: 48px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.03);
    border: 1px solid rgba(0,0,0,0.04);
  }
  .cp-page-content__title {
    font-family: var(--cp-font-serif);
    font-size: 2.4rem;
    font-weight: 700;
    color: var(--cp-sage-dark, #3D5247);
    margin-bottom: 40px;
    text-align: center;
    letter-spacing: -0.01em;
  }
  .cp-page-content__blocks {
    display: flex;
    flex-direction: column;
    gap: 36px;
  }
  .cp-page-content__heading {
    font-family: var(--cp-font-serif);
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--cp-sage, #5C7A6B);
    margin-bottom: 12px;
  }
  .cp-page-content__text {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--cp-text, #2D2D2D);
  }
  .cp-page-content__text p {
    margin-bottom: 16px;
  }
  .cp-page-content__text p:last-child {
    margin-bottom: 0;
  }
  .cp-page-content__text a {
    color: var(--cp-sage);
    text-decoration: underline;
    text-underline-offset: 4px;
  }
  .cp-page-content__btn {
    display: inline-block;
    margin-top: 24px;
    padding: 14px 28px;
    background: var(--cp-sage, #5C7A6B);
    color: #fff;
    text-decoration: none;
    border-radius: var(--cp-radius-sm, 10px);
    font-weight: 600;
    font-size: 0.95rem;
    transition: background 0.3s ease;
  }
  .cp-page-content__btn:hover {
    background: var(--cp-sage-dark, #3D5247);
  }

  @media (max-width: 768px) {
    .cp-page-content { padding: 48px 16px; }
    .cp-page-content__inner { padding: 32px 24px; }
    .cp-page-content__title { font-size: 2rem; margin-bottom: 32px; }
  }
/* END_SECTION:petboutiq-page-content */

/* START_SECTION:petboutiq-press-bar (INDEX:25) */
/* ── Section wrapper ─────────────────────────────────────── */
  .cp-press {
    background: #EDE9E1;
    padding: 52px 24px;
    border-top: 1px solid #D8D3CB;
    border-bottom: 1px solid #D8D3CB;
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    overflow: hidden;
  }
  .cp-press__inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 28px;
  }

  /* ── Label row: ——— AS SEEN IN ——— ──────────────────────── */
  .cp-press__label-row {
    display: flex;
    align-items: center;
    gap: 16px;
    width: 100%;
    max-width: 520px;
    justify-content: center;
  }
  .cp-press__line {
    flex: 1;
    height: 1px;
    background: #5C7A6B;
    opacity: 0.35;
    max-width: 80px;
  }
  .cp-press__label {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #5C7A6B;
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* ── Dot separator ───────────────────────────────────────── */
  .cp-press__dot {
    font-size: 1rem;
    color: #5C7A6B;
    opacity: 0.6;
    line-height: 1;
    flex-shrink: 0;
    margin: 0 2px;
  }

  /* ── Publication names ───────────────────────────────────── */
  .cp-press__name {
    font-size: 1.0rem;
    font-weight: 500;
    color: #6B6B6B;
    white-space: nowrap;
    letter-spacing: 0.01em;
    transition: color 0.25s ease;
  }

  /* ── Desktop static row with fade edges ──────────────────── */
  .cp-press__desktop {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  /* Left + right fade gradient */
  .cp-press__desktop::before,
  .cp-press__desktop::after {
    content: '';
    position: absolute;
    top: 0; bottom: 0;
    width: 80px;
    z-index: 2;
    pointer-events: none;
  }
  .cp-press__desktop::before {
    left: 0;
    background: linear-gradient(to right, #EDE9E1, transparent);
  }
  .cp-press__desktop::after {
    right: 0;
    background: linear-gradient(to left, #EDE9E1, transparent);
  }
  .cp-press__track {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    gap: 10px 16px;
    padding: 4px 0;
  }
  .cp-press__track .cp-press__name:hover {
    color: #3D3D3D;
  }

  /* ── Mobile: hide desktop, show marquee ──────────────────── */
  .cp-press__mobile { display: none; }

  /* ── Marquee ticker ──────────────────────────────────────── */
  .cp-press__marquee {
    width: 100%;
    overflow: hidden;
    position: relative;
    mask-image: linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
    -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
  }
  .cp-press__marquee-track {
    display: flex;
    align-items: center;
    gap: 14px;
    width: max-content;
    animation: cp-marquee 22s linear infinite;
  }
  @keyframes cp-marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
  }
  .cp-press__marquee:hover .cp-press__marquee-track {
    animation-play-state: paused;
  }

  /* ── Responsive ──────────────────────────────────────────── */
  @media (max-width: 860px) {
    .cp-press__desktop { display: none; }
    .cp-press__mobile  { display: block; width: 100%; }
    .cp-press { padding: 44px 0; }
    .cp-press__inner { gap: 22px; padding: 0 24px; }
    .cp-press__name { font-size: 0.9rem; }
  }
/* END_SECTION:petboutiq-press-bar */

/* START_SECTION:petboutiq-problem (INDEX:26) */
.cp-problem {
    padding: 110px 24px;
    background: #FAFAF7;
    font-family: 'Inter', system-ui, sans-serif;
  }
  .cp-problem__inner {
    max-width: 1040px; margin: 0 auto;
    display: flex; flex-direction: column; align-items: center;
    text-align: center;
  }
  .cp-problem__label {
    display: inline-flex;
    font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .12em;
    color: #7B9E87; margin-bottom: 16px;
  }
  .cp-problem__heading {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 700; color: #2D2D2D;
    margin-bottom: 18px; line-height: 1.15;
  }
  .cp-problem__sub {
    font-size: 1.05rem; line-height: 1.65;
    color: #8A8A82; max-width: 520px; margin-bottom: 52px;
  }
  .cp-problem__grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 22px; width: 100%; margin-bottom: 52px;
  }
  .cp-problem__card {
    background: #fff; border-radius: 18px;
    padding: 36px 28px 28px; text-align: center;
    border: 1.5px solid #ECEAE5;
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
    transition: transform .35s cubic-bezier(.4,0,.2,1),
                box-shadow .35s cubic-bezier(.4,0,.2,1),
                border-color .35s ease;
    display: flex; flex-direction: column; align-items: center;
  }
  .cp-problem__card:hover {
    transform: translateY(-7px);
    box-shadow: 0 16px 40px rgba(0,0,0,.09);
    border-color: rgba(123,158,135,.45);
  }
  .cp-problem__icon {
    margin-bottom: 20px;
    width: 58px; height: 58px; border-radius: 16px;
    background: linear-gradient(135deg,rgba(123,158,135,.14),rgba(123,158,135,.06));
    color: #4A6B55;
    display: flex; align-items: center; justify-content: center;
    transition: background .3s ease, transform .3s ease;
  }
  .cp-problem__card:hover .cp-problem__icon {
    background: linear-gradient(135deg,rgba(123,158,135,.22),rgba(123,158,135,.1));
    transform: scale(1.08);
  }
  .cp-problem__title {
    font-size: 1.08rem; font-weight: 700;
    color: #2D2D2D; margin-bottom: 12px;
  }
  .cp-problem__desc {
    font-size: .9rem; line-height: 1.65;
    color: #7A7A72; flex: 1; margin-bottom: 20px;
  }
  .cp-problem__card-cta {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: .82rem; font-weight: 600;
    color: #4A6B55; text-decoration: none;
    padding: 8px 16px; border-radius: 100px;
    border: 1.5px solid rgba(74,107,85,.25);
    background: rgba(74,107,85,.05);
    transition: all .3s ease;
    margin-top: auto;
  }
  .cp-problem__card-cta:hover {
    background: #4A6B55; color: #fff;
    border-color: #4A6B55;
  }
  .cp-problem__card-cta svg { transition: transform .3s ease; }
  .cp-problem__card-cta:hover svg { transform: translateX(3px); }

  .cp-problem__cta-wrap {
    padding: 24px 40px; border-radius: 14px;
    background: linear-gradient(135deg,rgba(123,158,135,.08),rgba(123,158,135,.04));
    border: 1px solid rgba(123,158,135,.15);
  }
  .cp-problem__cta {
    font-size: 1.05rem; color: #4A6B55;
    font-weight: 600; max-width: 520px;
    line-height: 1.6; margin: 0;
  }

  @media (max-width: 768px) {
    .cp-problem { padding: 80px 20px; }
    .cp-problem__grid { grid-template-columns: 1fr; max-width: 380px; }
  }
/* END_SECTION:petboutiq-problem */

/* START_SECTION:petboutiq-product-btf (INDEX:27) */
.cpb-label{display:block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:#5C7A6B;margin-bottom:14px;text-align:center;}
/* Benefit Strip */
.cpb-strip{background:#F7F5F0;border-top:1px solid #ECEAE5;border-bottom:1px solid #ECEAE5;padding:48px 28px;}
.cpb-strip__grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center;}
.cpb-strip__icon{font-size:2rem;display:block;margin-bottom:12px;}
.cpb-strip__item h3{font-family:'Playfair Display',Georgia,serif;font-size:1rem;font-weight:700;color:#2C2C2C;margin-bottom:6px;}
.cpb-strip__item p{font-size:.85rem;color:#6B6B6B;line-height:1.6;}
/* Description */
.cpb-desc{background:#fff;padding:80px 28px;}
.cpb-desc__inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.cpb-desc__heading{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:#2C2C2C;line-height:1.2;margin-bottom:24px;}
.cpb-desc__body{font-size:1rem;color:#5A5A5A;line-height:1.85;}
.cpb-desc__body p{margin-bottom:14px;}
.cpb-desc__body ul{padding-left:20px;margin-bottom:14px;}
.cpb-desc__body li{margin-bottom:8px;}
.cpb-desc__img-wrap{border-radius:20px;overflow:hidden;}
.cpb-desc__img{width:100%;height:100%;object-fit:cover;display:block;max-width:none;}
/* How It Works */
.cpb-hiw{background:#F7F5F0;padding:88px 28px;}
.cpb-hiw__inner{max-width:1000px;margin:0 auto;text-align:center;}
.cpb-hiw__title{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:#2C2C2C;line-height:1.15;margin-bottom:60px;}
.cpb-hiw__steps{display:flex;align-items:flex-start;gap:0;}
.cpb-hiw__step{flex:1;text-align:center;padding:0 20px;}
.cpb-hiw__num{width:52px;height:52px;border-radius:50%;background:#5C7A6B;color:#fff;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;}
.cpb-hiw__step h3{font-family:'Playfair Display',Georgia,serif;font-size:1.1rem;font-weight:700;color:#2C2C2C;margin-bottom:10px;}
.cpb-hiw__step p{font-size:.88rem;color:#6B6B6B;line-height:1.7;}
.cpb-hiw__line{width:60px;border-top:2px dashed #C8D5CF;margin-top:26px;flex-shrink:0;}
/* Reviews */
.cpb-rev{background:#fff;padding:88px 28px;}
.cpb-rev__inner{max-width:1100px;margin:0 auto;text-align:center;}
.cpb-rev__title{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:#2C2C2C;line-height:1.15;margin-bottom:32px;}
.cpb-rev__summary{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:48px;flex-wrap:wrap;}
.cpb-rev__big{font-size:3rem;font-weight:700;color:#2C2C2C;font-family:'Playfair Display',Georgia,serif;}
.cpb-rev__stars{display:flex;gap:3px;}
.cpb-rev__ct{font-size:.88rem;color:#9A9A9A;}
.cpb-rev__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:left;}
.cpb-rev__card{background:#F7F5F0;border-radius:20px;padding:32px;border:1px solid #ECEAE5;}
.cpb-rev__card-stars{display:flex;gap:2px;margin-bottom:14px;}
.cpb-rev__quote{font-size:.95rem;color:#2C2C2C;line-height:1.75;font-style:italic;margin-bottom:16px;}
.cpb-rev__name{font-size:.8rem;color:#6B6B6B;font-weight:500;}
.cpb-rev__verified{color:#5C7A6B;font-weight:600;margin-left:6px;}
/* Ingredients */
.cpb-ing{background:#F7F5F0;padding:88px 28px;}
.cpb-ing__inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.cpb-ing__card{border-radius:20px;padding:48px 40px;}
.cpb-ing__card--green{background:#5C7A6B;}
.cpb-ing__card--cream{background:#fff;border:1.5px solid #ECEAE5;}
.cpb-ing__heading{font-family:'Playfair Display',Georgia,serif;font-size:1.4rem;font-weight:700;margin-bottom:24px;}
.cpb-ing__card--green .cpb-ing__heading{color:#fff;}
.cpb-ing__card--cream .cpb-ing__heading{color:#2C2C2C;}
.cpb-ing__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px;font-size:.92rem;line-height:1.5;}
.cpb-ing__list--white li{color:rgba(255,255,255,.9);}
.cpb-ing__card--cream .cpb-ing__list li{color:#5A5A5A;}
/* Cross-sell */
.cpb-cross{background:#F7F5F0;padding:88px 28px;border-top:1px solid #ECEAE5;}
.cpb-cross__inner{max-width:1100px;margin:0 auto;text-align:center;}
.cpb-cross__title{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:#2C2C2C;margin-bottom:48px;}
.cpb-cross__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:left;}
.cpb-cross__img-wrap{display:block;border-radius:16px;overflow:hidden;aspect-ratio:1/1;background:#fff;margin-bottom:16px;}
.cpb-cross__img{width:100%;height:100%;object-fit:cover;display:block;max-width:none;transition:transform .4s ease;}
.cpb-cross__img-wrap:hover .cpb-cross__img{transform:scale(1.04);}
.cpb-cross__info{padding:4px 4px 0;}
.cpb-cross__name a{font-family:'Playfair Display',Georgia,serif;font-size:1.05rem;font-weight:700;color:#2C2C2C;text-decoration:none;}
.cpb-cross__name a:hover{color:#5C7A6B;}
.cpb-cross__desc{font-size:.82rem;color:#6B6B6B;line-height:1.6;margin:6px 0 12px;}
.cpb-cross__price-row{display:flex;align-items:baseline;gap:10px;margin-bottom:12px;}
.cpb-cross__price{font-size:1.1rem;font-weight:700;color:#3D5247;}
.cpb-cross__compare{font-size:.9rem;text-decoration:line-through;color:#9A9A9A;}
.cpb-cross__btn{width:100%;padding:13px;border-radius:12px;background:#5C7A6B;color:#fff;font-family:'Inter',system-ui,sans-serif;font-size:.9rem;font-weight:600;border:none;cursor:pointer;transition:background .2s;}
.cpb-cross__btn:hover{background:#3D5247;}
.cpb-cross__btn:disabled{background:#ECEAE5;color:#9A9A9A;cursor:not-allowed;}
/* Responsive */
@media(max-width:860px){
  .cpb-strip__grid{grid-template-columns:repeat(2,1fr);}
  .cpb-desc__inner{grid-template-columns:1fr;gap:40px;}
  .cpb-rev__cards{grid-template-columns:1fr;}
  .cpb-ing__inner{grid-template-columns:1fr;}
  .cpb-cross__grid{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto;}
}
@media(max-width:600px){
  .cpb-hiw__steps{flex-direction:column;align-items:center;}
  .cpb-hiw__line{width:2px;height:40px;border-top:none;border-left:2px dashed #C8D5CF;margin:0;}
  .cpb-strip,.cpb-desc,.cpb-hiw,.cpb-rev,.cpb-ing,.cpb-cross{padding-left:20px;padding-right:20px;}
  .cpb-ing__card{padding:36px 28px;}
}
/* END_SECTION:petboutiq-product-btf */

/* START_SECTION:petboutiq-product-crosssell (INDEX:28) */
.cp-xsell { background: var(--cp-cream,#F7F5F0); padding: 80px 24px; border-top: 1px solid var(--cp-border,#ECEAE5); }
  .cp-xsell__inner { max-width: 1100px; margin: 0 auto; text-align: center; }
  .cp-xsell__heading {
    font-family: var(--cp-font-serif,'Playfair Display',Georgia,serif);
    font-size: clamp(1.5rem,3vw,2rem); font-weight: 700;
    color: var(--cp-text,#2D2D2D); margin-bottom: 48px;
  }
  .cp-xsell__grid {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 24px; text-align: left;
  }
  /* Mobile: always show ATC */
  @media (max-width: 900px) { .cp-xsell__grid { grid-template-columns: 1fr 1fr; } }
  @media (max-width: 560px) {
    .cp-xsell__grid { grid-template-columns: 1fr; }
    .cp-xsell__grid .cp-products__atc-wrap { opacity: 1; transform: none; }
  }
/* END_SECTION:petboutiq-product-crosssell */

/* START_SECTION:petboutiq-product-features (INDEX:29) */
.cp-pf {
    background: var(--cp-cream, #F7F5F0);
    padding: 90px 24px;
    font-family: var(--cp-font-sans, 'Inter', system-ui, sans-serif);
  }
  .cp-pf__inner { max-width: 1100px; margin: 0 auto; text-align: center; }
  .cp-pf__heading {
    font-family: var(--cp-font-serif, 'Playfair Display', Georgia, serif);
    font-size: clamp(1.7rem, 3vw, 2.3rem); font-weight: 700;
    color: var(--cp-text, #2D2D2D); margin-bottom: 12px;
  }
  .cp-pf__sub { font-size: 1rem; color: var(--cp-muted,#8A8A82); line-height: 1.6; max-width: 520px; margin: 0 auto 52px; }
  .cp-pf__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px; margin-top: 52px;
  }
  .cp-pf__col {
    background: #fff; border-radius: 20px;
    padding: 36px 28px; border: 1px solid var(--cp-border,#ECEAE5);
    box-shadow: var(--cp-shadow,0 2px 8px rgba(0,0,0,0.06));
    display: flex; flex-direction: column; align-items: center;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  .cp-pf__col:hover { transform: translateY(-5px); box-shadow: 0 16px 48px rgba(0,0,0,0.10); }
  .cp-pf__icon-wrap {
    width: 64px; height: 64px; border-radius: 50%;
    background: rgba(92,122,107,0.10);
    color: var(--cp-sage, #5C7A6B);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 20px; flex-shrink: 0;
  }
  .cp-pf__title {
    font-size: 1.05rem; font-weight: 700; color: var(--cp-text,#2D2D2D);
    margin-bottom: 10px;
  }
  .cp-pf__desc { font-size: 0.9rem; line-height: 1.65; color: var(--cp-muted,#8A8A82); }
  @media (max-width: 900px) { .cp-pf__grid { grid-template-columns: 1fr 1fr; gap: 20px; } }
  @media (max-width: 560px) { .cp-pf__grid { grid-template-columns: 1fr; } .cp-pf { padding: 70px 20px; } }
/* END_SECTION:petboutiq-product-features */

/* START_SECTION:petboutiq-product-ingredients (INDEX:30) */
.cp-ingr {
    background: var(--cp-sage, #5C7A6B);
    padding: 80px 24px;
  }
  .cp-ingr__inner {
    max-width: 1100px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1px 1fr;
    gap: 0 56px; align-items: start;
  }
  .cp-ingr__divider-v {
    background: rgba(255,255,255,0.2);
    height: 100%; min-height: 160px;
    border-radius: 2px;
  }
  .cp-ingr__label {
    display: inline-block; font-size: 0.68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.16em;
    color: rgba(255,255,255,0.65); margin-bottom: 12px;
  }
  .cp-ingr__heading {
    font-family: var(--cp-font-serif, 'Playfair Display', Georgia, serif);
    font-size: 1.5rem; font-weight: 700; color: #fff;
    margin-bottom: 20px; line-height: 1.2;
  }
  .cp-ingr__body {
    font-size: 0.95rem; line-height: 1.75;
    color: rgba(255,255,255,0.82);
  }
  .cp-ingr__body p { margin-bottom: 12px; }
  .cp-ingr__body ul, .cp-ingr__body ol { padding-left: 18px; }
  .cp-ingr__body li { margin-bottom: 6px; }
  @media (max-width: 768px) {
    .cp-ingr__inner { grid-template-columns: 1fr; gap: 40px 0; }
    .cp-ingr__divider-v { height: 1px; min-height: 0; }
  }
/* END_SECTION:petboutiq-product-ingredients */

/* START_SECTION:petboutiq-product-main (INDEX:31) */
.cpm{background:#F7F5F0;padding:48px 0 80px;font-family:'Inter',system-ui,sans-serif;}
.cpm__inner{max-width:1160px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
/* Gallery */
.cpm__main-wrap{border-radius:20px;overflow:hidden;aspect-ratio:1/1;background:#F7F5F0;border:1.5px solid #ECEAE5;position:sticky;top:136px;}
.cpm__main-img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;transition:opacity .3s;}
.cpm__img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;}
.cpm__thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap;}
.cpm__thumb{width:76px;height:76px;border-radius:12px;overflow:hidden;border:2px solid transparent;cursor:pointer;padding:0;background:#fff;transition:border-color .2s;}
.cpm__thumb img{width:100%;height:100%;object-fit:cover;}
.cpm__thumb--on,.cpm__thumb:hover{border-color:#5C7A6B;}
/* Info */
.cpm__info{padding-top:8px;}
.cpm__crumb{font-size:.75rem;color:#9A9A9A;margin-bottom:14px;}
.cpm__crumb a{color:#9A9A9A;text-decoration:none;}
.cpm__crumb a:hover{color:#5C7A6B;}
.cpm__badge{display:inline-block;background:rgba(92,122,107,.12);color:#5C7A6B;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:14px;}
.cpm__title{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:#2C2C2C;line-height:1.15;margin-bottom:14px;}
.cpm__stars{display:flex;align-items:center;gap:3px;margin-bottom:18px;}
.cpm__stars-txt{font-size:.9rem;font-weight:600;color:#2C2C2C;margin-left:6px;}
.cpm__stars-ct{color:#9A9A9A;font-weight:400;}
.cpm__price-row{display:flex;align-items:baseline;gap:12px;margin-bottom:20px;flex-wrap:wrap;}
.cpm__price{font-size:2rem;font-weight:700;color:#3D5247;}
.cpm__compare{font-size:1.1rem;text-decoration:line-through;color:#9A9A9A;}
.cpm__save{background:rgba(196,130,90,.15);color:#C4825A;font-size:.78rem;font-weight:700;padding:4px 12px;border-radius:100px;}
/* Benefits */
.cpm__benefits{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:10px;}
.cpm__benefits li{display:flex;align-items:flex-start;gap:10px;font-size:.92rem;color:#2C2C2C;font-weight:500;line-height:1.4;}
.cpm__benefits li svg{flex-shrink:0;margin-top:2px;}
.cpm__divider{border:none;border-top:1px solid #ECEAE5;margin:22px 0;}
/* Form */
.cpm__form{display:flex;flex-direction:column;gap:0;}
.cpm__lbl{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#9A9A9A;margin-bottom:7px;display:block;}
.cpm__select{width:100%;padding:13px 40px 13px 16px;border-radius:14px;border:1.5px solid #ECEAE5;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8A82' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 14px center;-webkit-appearance:none;font-size:.95rem;color:#2C2C2C;margin-bottom:18px;outline:none;cursor:pointer;transition:border-color .2s;}
.cpm__select:focus{border-color:#5C7A6B;}
.cpm__qty-row{margin-bottom:14px;}
.cpm__qty{display:inline-flex;align-items:center;border:1.5px solid #ECEAE5;border-radius:14px;overflow:hidden;background:#fff;}
.cpm__qty-btn{width:48px;height:52px;background:none;border:none;font-size:1.3rem;cursor:pointer;color:#2C2C2C;transition:background .2s;display:flex;align-items:center;justify-content:center;}
.cpm__qty-btn:hover{background:#F7F5F0;}
.cpm__qty-in{width:52px;text-align:center;border:none;outline:none;font-size:.95rem;font-weight:600;color:#2C2C2C;-moz-appearance:textfield;background:transparent;}
.cpm__qty-in::-webkit-inner-spin-button,.cpm__qty-in::-webkit-outer-spin-button{-webkit-appearance:none;}
.cpm__atc{width:100%;padding:17px;border-radius:14px;background:#5C7A6B;color:#fff;font-family:inherit;font-size:1rem;font-weight:700;border:none;cursor:pointer;transition:background .25s,transform .2s;margin-bottom:12px;letter-spacing:.01em;}
.cpm__atc:hover{background:#3D5247;transform:translateY(-1px);}
.cpm__atc:disabled{background:#ECEAE5;color:#9A9A9A;cursor:not-allowed;transform:none;}
.cpm__buynow-btn{width:100%;padding:17px;border-radius:14px;background:#2C2C2C;color:#fff;font-family:inherit;font-size:1rem;font-weight:700;border:none;cursor:pointer;transition:background .25s,transform .2s;margin-bottom:22px;letter-spacing:.01em;}
.cpm__buynow-btn:hover{background:#000;transform:translateY(-1px);}
.cpm__buynow-btn:disabled{background:#ECEAE5;color:#9A9A9A;cursor:not-allowed;transform:none;}
/* Trust */
.cpm__trust{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:18px;border-radius:14px;background:#fff;border:1px solid #ECEAE5;margin-bottom:22px;}
.cpm__trust-item{display:flex;align-items:center;gap:9px;font-size:.8rem;font-weight:500;color:#2C2C2C;}
/* Accordion */
.cpm__acc{border-top:1px solid #ECEAE5;}
.cpm__acc-item{border-bottom:1px solid #ECEAE5;}
.cpm__acc-q{width:100%;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:16px 0;font-family:inherit;font-size:.92rem;font-weight:600;color:#2C2C2C;text-align:left;transition:color .2s;}
.cpm__acc-q:hover{color:#5C7A6B;}
.cpm__acc-q svg{flex-shrink:0;transition:transform .3s;}
.cpm__acc-q[aria-expanded="true"] svg{transform:rotate(180deg);}
.cpm__acc-a{font-size:.88rem;color:#6B6B6B;line-height:1.75;padding-bottom:16px;}
/* Sticky */
.cpm-sticky{position:fixed;top:0;left:0;right:0;z-index:950;background:#5C7A6B;transform:translateY(-100%);transition:transform .35s cubic-bezier(.4,0,.2,1);font-family:'Inter',system-ui,sans-serif;}
.cpm-sticky.on{transform:translateY(0);}
.cpm-sticky__inner{max-width:1160px;margin:0 auto;padding:10px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;height:64px;}
.cpm-sticky__left{display:flex;align-items:center;gap:12px;}
.cpm-sticky__img{width:44px;height:44px;border-radius:8px;object-fit:cover;border:2px solid rgba(255,255,255,.3);}
.cpm-sticky__name{font-size:.88rem;font-weight:600;color:#fff;margin-bottom:2px;}
.cpm-sticky__price{font-size:.82rem;font-weight:700;color:rgba(255,255,255,.85);}
.cpm-sticky__btn{padding:10px 24px;border-radius:10px;background:#fff;color:#5C7A6B;font-family:inherit;font-size:.9rem;font-weight:700;border:none;cursor:pointer;transition:background .2s;white-space:nowrap;}
.cpm-sticky__btn:hover{background:#F7F5F0;}
.cpm-sticky__btn:disabled{background:rgba(255,255,255,.4);color:rgba(255,255,255,.6);cursor:not-allowed;}
/* Responsive */
@media(max-width:860px){
  .cpm__inner{grid-template-columns:1fr;gap:32px;}
  .cpm__main-wrap{position:static;}
  .cpm-sticky__left{display:none;}
  .cpm-sticky__btn{width:100%;}
}
/* END_SECTION:petboutiq-product-main */

/* START_SECTION:petboutiq-product-reviews (INDEX:32) */
.cp-pv { background: var(--cp-cream, #F7F5F0); padding: 90px 24px; }
  .cp-pv__inner { max-width: 1100px; margin: 0 auto; text-align: center; }
  .cp-pv__heading {
    font-family: var(--cp-font-serif,'Playfair Display',Georgia,serif);
    font-size: clamp(1.6rem,3vw,2.2rem); font-weight: 700;
    color: var(--cp-text,#2D2D2D); margin-bottom: 52px;
  }
  .cp-pv__grid {
    display: grid; grid-template-columns: repeat(3,1fr);
    gap: 24px; text-align: left;
  }
  .cp-pv__card {
    background: #fff; border-radius: 20px;
    padding: 32px 28px; border: 1px solid var(--cp-border,#ECEAE5);
    box-shadow: var(--cp-shadow,0 2px 8px rgba(0,0,0,0.06));
    display: flex; flex-direction: column; gap: 16px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  .cp-pv__card:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(0,0,0,0.10); }
  .cp-pv__stars { display: flex; gap: 3px; }
  .cp-pv__quote {
    font-size: 0.95rem; line-height: 1.7;
    color: var(--cp-text,#2D2D2D); flex: 1;
    font-style: italic;
  }
  .cp-pv__reviewer { display: flex; align-items: center; gap: 12px; margin-top: auto; }
  .cp-pv__avatar {
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--cp-sage,#5C7A6B);
    color: #fff; font-weight: 700; font-size: 0.9rem;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
  }
  .cp-pv__name { font-size: 0.88rem; font-weight: 700; color: var(--cp-text,#2D2D2D); }
  .cp-pv__dog { font-size: 0.78rem; color: var(--cp-muted,#8A8A82); margin-top: 2px; }
  @media (max-width: 900px) { .cp-pv__grid { grid-template-columns: 1fr 1fr; } }
  @media (max-width: 560px) { .cp-pv__grid { grid-template-columns: 1fr; } .cp-pv { padding: 70px 20px; } }
/* END_SECTION:petboutiq-product-reviews */

/* START_SECTION:petboutiq-testimonials (INDEX:33) */
.cp-test {
    padding: 120px 24px;
    background: #fff;
    font-family: 'Inter', system-ui, sans-serif;
  }
  .cp-test__inner {
    max-width: 1100px; margin: 0 auto;
    display: flex; flex-direction: column; align-items: center; text-align: center;
  }
  .cp-test__label {
    font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .12em;
    color: #7B9E87; margin-bottom: 16px;
  }
  .cp-test__heading {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 700; color: #2D2D2D;
    margin-bottom: 14px; line-height: 1.15;
  }
  .cp-test__sub {
    font-size: 1.05rem; color: #8A8A82;
    line-height: 1.65; max-width: 480px; margin-bottom: 60px;
  }
  .cp-test__grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px; width: 100%;
  }
  .cp-test__card {
    background: var(--cp-cream, #F7F5F0);
    border-radius: 20px; padding: 32px 28px;
    text-align: left; border: 1.5px solid #ECEAE5;
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
    transition: transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s cubic-bezier(.4,0,.2,1);
    display: flex; flex-direction: column;
  }
  .cp-test__card:hover {
    transform: translateY(-5px);
    box-shadow: 0 16px 40px rgba(0,0,0,.08);
    border-color: rgba(123,158,135,.3);
  }
  .cp-test__card-top {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 18px;
  }
  .cp-test__stars { display: flex; gap: 2px; }
  .cp-test__verified {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: .7rem; font-weight: 600;
    color: var(--cp-sage, #5C7A6B);
    background: rgba(92,122,107,.1);
    border: 1px solid rgba(92,122,107,.2);
    border-radius: 100px; padding: 3px 10px;
  }
  .cp-test__quote-mark { margin-bottom: 10px; flex-shrink: 0; }
  .cp-test__quote {
    font-size: .94rem; line-height: 1.72;
    color: #4A4A44; flex: 1; margin-bottom: 24px;
    font-style: italic;
  }
  .cp-test__divider { height: 1px; background: #E8E4DE; margin-bottom: 18px; }
  .cp-test__author { display: flex; align-items: center; gap: 12px; }
  .cp-test__avatar {
    width: 42px; height: 42px; border-radius: 50%;
    background: linear-gradient(135deg, #7B9E87, #5C7A6B);
    color: #fff; font-size: .88rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .cp-test__meta { display: flex; flex-direction: column; }
  .cp-test__name { font-size: .88rem; font-weight: 700; color: #2D2D2D; }
  .cp-test__dog { font-size: .78rem; color: #8A8A82; margin-top: 2px; }

  @media (max-width: 900px) {
    .cp-test { padding: 90px 20px; }
    .cp-test__grid { grid-template-columns: 1fr; max-width: 480px; }
  }
/* END_SECTION:petboutiq-testimonials */

/* START_SECTION:petboutiq-trust-bar (INDEX:34) */
.cp-trust {
    background: var(--cp-sage, #5C7A6B);
    padding: 0 24px;
    font-family: 'Inter', system-ui, sans-serif;
  }
  .cp-trust__inner {
    max-width: 1100px; margin: 0 auto;
    display: flex; align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    padding: 28px 0;
    gap: 0;
  }
  .cp-trust__item {
    display: flex; align-items: center; gap: 12px;
    padding: 0 32px; flex: 1;
    justify-content: center;
    transition: transform .25s ease;
  }
  .cp-trust__item:hover { transform: translateY(-1px); }
  .cp-trust__divider {
    width: 1px; height: 36px; flex-shrink: 0;
    background: rgba(255,255,255,.2);
  }
  .cp-trust__icon {
    color: rgba(255,255,255,.9); flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    width: 42px; height: 42px; border-radius: 12px;
    background: rgba(255,255,255,.12);
  }
  .cp-trust__text {
    display: flex; flex-direction: column; gap: 1px;
  }
  .cp-trust__title {
    font-size: .88rem; font-weight: 700;
    color: #fff; white-space: nowrap;
    letter-spacing: .01em;
  }
  .cp-trust__desc {
    font-size: .76rem; color: rgba(255,255,255,.72);
    white-space: nowrap;
  }

  @media (max-width: 900px) {
    .cp-trust__inner {
      flex-wrap: wrap;
      padding: 24px 0;
      gap: 0;
    }
    .cp-trust__item {
      flex: 0 0 50%;
      padding: 16px 24px;
      justify-content: flex-start;
      border-bottom: 1px solid rgba(255,255,255,.1);
    }
    .cp-trust__item:nth-child(odd) { border-right: 1px solid rgba(255,255,255,.1); }
    .cp-trust__item:nth-last-child(-n+3) { border-bottom: none; }
    .cp-trust__divider { display: none; }
  }
  @media (max-width: 480px) {
    .cp-trust__inner { padding: 16px 0; }
    .cp-trust__item { padding: 14px 20px; }
    .cp-trust__title { font-size: .82rem; white-space: normal; }
    .cp-trust__desc { white-space: normal; }
  }
/* END_SECTION:petboutiq-trust-bar */

/* START_SECTION:product (INDEX:35) */
.cp-pdp { background: var(--cp-cream,#F7F5F0); padding: 40px 0 80px; }
  .cp-pdp__inner {
    max-width: 1100px; margin: 0 auto; padding: 0 24px;
    display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
    align-items: start;
  }

  /* Gallery */
  .cp-pdp__main-img-wrap {
    border-radius: var(--cp-radius-lg,20px); overflow: hidden;
    aspect-ratio: 4/5; background: linear-gradient(170deg,#F5EDE3,#EAE5DD);
    position: sticky; top: 100px;
  }
  .cp-pdp__main-img { width: 100%; height: 100%; object-fit: cover; transition: opacity 0.3s ease; }
  .cp-pdp__img-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
  .cp-pdp__thumbnails { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
  .cp-pdp__thumb {
    width: 72px; height: 72px; border-radius: 12px;
    overflow: hidden; border: 2px solid transparent;
    cursor: pointer; padding: 0; background: none;
    transition: border-color 0.25s ease;
  }
  .cp-pdp__thumb img { width: 100%; height: 100%; object-fit: cover; }
  .cp-pdp__thumb--active, .cp-pdp__thumb:hover { border-color: var(--cp-sage,#5C7A6B); }

  /* Info */
  .cp-pdp__info { padding-top: 16px; }
  .cp-pdp__badges { display: flex; gap: 8px; margin-bottom: 20px; flex-wrap: wrap; }
  .cp-pdp__badge { padding: 5px 14px; border-radius: 100px; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; }
  .cp-pdp__badge--available { background: rgba(92,122,107,0.12); color: var(--cp-sage,#5C7A6B); }
  .cp-pdp__badge--sold { background: rgba(45,45,45,0.08); color: var(--cp-text,#2D2D2D); }
  .cp-pdp__badge--sale { background: rgba(198,125,91,0.12); color: var(--cp-terracotta,#C67D5B); }

  .cp-pdp__title {
    font-family: var(--cp-font-serif,'Playfair Display',Georgia,serif);
    font-size: clamp(1.8rem,3.5vw,2.4rem);
    font-weight: 700; color: var(--cp-text,#2D2D2D);
    line-height: 1.15; margin-bottom: 14px;
  }
  .cp-pdp__stars { display: flex; align-items: center; gap: 3px; margin-bottom: 18px; }
  .cp-pdp__stars-count { font-size: 0.88rem; font-weight: 600; color: var(--cp-text,#2D2D2D); margin-left: 6px; }
  .cp-pdp__price-row { display: flex; align-items: baseline; gap: 12px; margin-bottom: 20px; }
  .cp-pdp__price { font-size: 1.8rem; font-weight: 700; color: var(--cp-sage-dark,#3D5247); }
  .cp-pdp__compare { font-size: 1.1rem; text-decoration: line-through; color: var(--cp-muted,#8A8A82); }

  /* Benefits */
  .cp-pdp__benefits { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 10px; }
  .cp-pdp__benefit-item {
    display: flex; align-items: flex-start; gap: 10px;
    font-size: 0.92rem; color: var(--cp-text,#2D2D2D); font-weight: 500; line-height: 1.4;
  }
  .cp-pdp__benefit-item svg { flex-shrink: 0; margin-top: 2px; }

  .cp-pdp__divider { border: none; border-top: 1px solid var(--cp-border,#ECEAE5); margin: 24px 0; }

  /* Form */
  .cp-pdp__field-label { display: block; font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cp-muted,#8A8A82); margin-bottom: 8px; }
  .cp-pdp__select {
    width: 100%; padding: 13px 40px 13px 16px;
    border-radius: var(--cp-radius,14px); border: 1.5px solid var(--cp-border,#ECEAE5);
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8A82' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 14px center;
    -webkit-appearance: none; appearance: none;
    font-size: 0.95rem; color: var(--cp-text,#2D2D2D);
    margin-bottom: 20px; cursor: pointer; outline: none;
    transition: border-color 0.25s ease;
  }
  .cp-pdp__select:focus { border-color: var(--cp-sage,#5C7A6B); }
  .cp-pdp__variants { margin-bottom: 4px; }

  .cp-pdp__qty-atc { display: flex; gap: 12px; margin-bottom: 14px; align-items: stretch; }
  .cp-pdp__qty { display: flex; align-items: center; border: 1.5px solid var(--cp-border,#ECEAE5); border-radius: var(--cp-radius,14px); overflow: hidden; background: #fff; }
  .cp-pdp__qty-btn { width: 44px; height: 52px; background: none; border: none; font-size: 1.2rem; cursor: pointer; color: var(--cp-text,#2D2D2D); transition: background 0.2s ease; display: flex; align-items: center; justify-content: center; }
  .cp-pdp__qty-btn:hover { background: var(--cp-cream,#F7F5F0); }
  .cp-pdp__qty-input { width: 48px; text-align: center; border: none; outline: none; font-size: 0.95rem; font-weight: 600; color: var(--cp-text,#2D2D2D); -moz-appearance: textfield; background: transparent; }
  .cp-pdp__qty-input::-webkit-inner-spin-button, .cp-pdp__qty-input::-webkit-outer-spin-button { -webkit-appearance: none; }
  .cp-pdp__atc-btn { flex: 1; font-size: 1rem; padding: 15px 24px; }
  .cp-pdp__atc-btn:disabled { background: var(--cp-border,#ECEAE5); color: var(--cp-muted,#8A8A82); box-shadow: none; cursor: not-allowed; }

  .cp-pdp__buy-now-row { margin-bottom: 24px; }
  .cp-pdp__buy-now-row .shopify-payment-button__button { border-radius: var(--cp-radius,14px) !important; font-family: var(--cp-font-sans) !important; }

  /* Trust */
  .cp-pdp__trust { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 8px; padding: 20px; border-radius: var(--cp-radius,14px); background: #fff; border: 1px solid var(--cp-border,#ECEAE5); }
  .cp-pdp__trust-item { display: flex; align-items: center; gap: 10px; font-size: 0.82rem; font-weight: 500; color: var(--cp-text,#2D2D2D); }

  /* Description section */
  .cp-pdp-desc { background: #fff; padding: 80px 24px; }
  .cp-pdp-desc__inner { max-width: 760px; margin: 0 auto; text-align: center; }
  .cp-pdp-desc__heading {
    font-family: var(--cp-font-serif,'Playfair Display',Georgia,serif);
    font-size: clamp(1.6rem,3vw,2.2rem); font-weight: 700;
    color: var(--cp-text,#2D2D2D); margin-bottom: 28px;
  }
  .cp-pdp-desc__body { font-size: 1rem; line-height: 1.85; color: var(--cp-muted,#8A8A82); text-align: left; }
  .cp-pdp-desc__body p { margin-bottom: 16px; }
  .cp-pdp-desc__body ul, .cp-pdp-desc__body ol { padding-left: 20px; margin-bottom: 16px; }
  .cp-pdp-desc__body li { margin-bottom: 8px; }

  /* Sticky ATC */
  .cp-sticky-atc {
    position: fixed; top: 0; left: 0; right: 0; z-index: 900;
    background: var(--cp-sage,#5C7A6B);
    box-shadow: 0 4px 30px rgba(0,0,0,0.15);
    transform: translateY(-100%);
    transition: transform 0.4s cubic-bezier(.4,0,.2,1);
    font-family: var(--cp-font-sans,'Inter',system-ui,sans-serif);
  }
  .cp-sticky-atc.visible { transform: translateY(0); }
  .cp-sticky-atc__inner { max-width: 1100px; margin: 0 auto; padding: 12px 24px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
  .cp-sticky-atc__product { display: flex; align-items: center; gap: 14px; }
  .cp-sticky-atc__img { width: 48px; height: 48px; border-radius: 10px; object-fit: cover; border: 2px solid rgba(255,255,255,0.3); }
  .cp-sticky-atc__name { font-size: 0.9rem; font-weight: 600; color: #fff; margin-bottom: 2px; }
  .cp-sticky-atc__price { font-size: 0.875rem; font-weight: 700; color: rgba(255,255,255,0.85); }
  .cp-sticky-atc__btn { white-space: nowrap; font-size: 0.9rem; padding: 11px 26px; background: #fff; color: var(--cp-sage,#5C7A6B); box-shadow: none; }
  .cp-sticky-atc__btn:hover { background: var(--cp-cream,#F7F5F0); transform: none; }
  .cp-sticky-atc__btn:disabled { background: rgba(255,255,255,0.4); color: rgba(255,255,255,0.6); cursor: not-allowed; box-shadow: none; }

  /* Responsive */
  @media (max-width: 768px) {
    .cp-pdp__inner { grid-template-columns: 1fr; gap: 32px; }
    .cp-pdp__main-img-wrap { position: static; }
    .cp-pdp__trust { grid-template-columns: 1fr; }
    .cp-pdp-desc { padding: 60px 20px; }
  }
/* END_SECTION:product */

/* START_SECTION:search (INDEX:36) */
.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:37) */
.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:38) */
.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:40) */
.image {
    display: block;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: auto;
  }

  .image > img {
    width: 100%;
    height: auto;
  }
/* END_SNIPPET:image */