.tpl-cb-sustain-v1 {
  --tpl-shell-bg: var(--color-surface);
  --tpl-header-bg: color-mix(in srgb, white 97%, var(--color-surface));
  --tpl-surface-solid: var(--ui-surface-solid);
  --tpl-surface-0: color-mix(in srgb, var(--color-surface) 90%, var(--tpl-surface-solid));
  --tpl-surface-1: color-mix(in srgb, var(--color-surface) 82%, var(--tpl-surface-solid));
  --tpl-surface-2: color-mix(in srgb, var(--color-surface) 72%, var(--tpl-surface-solid));
  --tpl-border-soft: color-mix(in srgb, var(--color-border) 62%, var(--tpl-surface-solid));
  --tpl-border-strong: color-mix(in srgb, var(--color-border) 88%, var(--tpl-surface-solid));
  --tpl-text-strong: color-mix(in srgb, var(--color-text) 92%, var(--ui-ink-deep));
  --tpl-text-muted: color-mix(in srgb, var(--color-text) 70%, var(--ui-ink-muted-base));
  --tpl-primary-strong: color-mix(in srgb, var(--color-primary) 82%, var(--ui-ink-deep));
  --tpl-secondary-strong: color-mix(in srgb, var(--color-secondary) 78%, var(--ui-ink-deep));
  --tpl-success-strong: color-mix(in srgb, var(--color-success) 80%, var(--ui-ink-deep));
  --tpl-danger-strong: color-mix(in srgb, var(--color-error) 80%, var(--ui-ink-deep));
  --tpl-on-accent: var(--ui-text-on-dark);
  --tpl-accent-soft: color-mix(in srgb, var(--color-primary) 12%, var(--tpl-surface-solid));
  --tpl-accent-soft-2: color-mix(in srgb, var(--color-secondary) 12%, var(--tpl-surface-solid));
  --tpl-card-shadow: var(--ui-shadow-soft);
  --tpl-card-shadow-hover: var(--ui-shadow-strong);
  --tpl-overlay-08: var(--ui-surface-overlay-08);
  --tpl-overlay-14: var(--ui-surface-overlay-14);
  --tpl-overlay-18: var(--ui-surface-overlay-18);
  --tpl-overlay-22: var(--ui-surface-overlay-22);
  --tpl-overlay-28: var(--ui-surface-overlay-28);
  --tpl-overlay-38: var(--ui-surface-overlay-38);
  --tpl-overlay-62: var(--ui-surface-overlay-62);
  --tpl-overlay-76: var(--ui-surface-overlay-76);
  --tpl-overlay-82: var(--ui-surface-overlay-82);
  --tpl-overlay-88: var(--ui-surface-overlay-88);
  --tpl-overlay-92: var(--ui-surface-overlay-92);
  --tpl-accent-panel-gradient: var(--ui-accent-panel-gradient);
  --tpl-hero-primary-wash: var(--ui-hero-wash-primary);
  --tpl-hero-secondary-wash: var(--ui-hero-wash-secondary);
  --tpl-main-bleed: var(--color-surface);
}

.tpl-cb-sustain-v1 .sustain-page {
  display: grid;
  gap: 0;
  padding-bottom: clamp(2.4rem, 4vw, 3.4rem);
}

.tpl-cb-sustain-v1 .sustain-section {
  margin-top: 0;
}

.tpl-cb-sustain-v1 .sustain-panel {
  border-radius: var(--radius-lg);
  border: none;
  background: color-mix(in srgb, var(--tpl-surface-0) 96%, var(--tpl-surface-solid));
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .sustain-card {
  border-radius: calc(var(--radius-lg) - 4px);
  border: none;
  background: color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid));
  box-shadow: var(--tpl-card-shadow);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.tpl-cb-sustain-v1 .sustain-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--tpl-card-shadow-hover);
}

.tpl-cb-sustain-v1 .sustain-row {
  border-radius: calc(var(--radius-lg) - 6px);
  border: none;
  background: color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid));
  box-shadow: 0 12px 28px color-mix(in srgb, var(--ui-text) 8%, transparent);
}

.tpl-cb-sustain-v1 .sustain-toolbar {
  border-radius: var(--radius-md);
  border: none;
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
  box-shadow: 0 12px 28px color-mix(in srgb, var(--ui-text) 7%, transparent);
}

.tpl-cb-sustain-v1 .story-canvas,
.tpl-cb-sustain-v1 .home-react-content,
.tpl-cb-sustain-v1 .stores-band,
.tpl-cb-sustain-v1 .coupons-react-content,
.tpl-cb-sustain-v1 .blogs-react-content,
.tpl-cb-sustain-v1 .categories-band-all,
.tpl-cb-sustain-v1 .store-rk-content-band,
.tpl-cb-sustain-v1 .blog-detail-react-content,
.tpl-cb-sustain-v1 .auth-react-stage,
.tpl-cb-sustain-v1 .account-react-shell,
.tpl-cb-sustain-v1 .static-page-react-page {
  background: var(--tpl-shell-bg);
}

.tpl-cb-sustain-v1 .sustain-site-main {
  position: relative;
  isolation: isolate;
  background: var(--tpl-shell-bg);
}

.tpl-cb-sustain-v1 .story-canvas {
  position: relative;
  z-index: 1;
  background: transparent;
}

.tpl-cb-sustain-v1 .site-main {
  padding-top: 8.8rem;
}

@media (max-width: 767px) {
  .tpl-cb-sustain-v1 .site-main {
    padding-top: 8.1rem;
  }
}

.tpl-cb-sustain-v1 .site-header-bg {
  border-bottom: none;
  background: var(--tpl-header-bg);
  backdrop-filter: none;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .site-promo-bar {
  background: var(--theme-promo-fill);
  border-bottom: none;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ui-text) 12%, transparent);
}

.tpl-cb-sustain-v1 .site-promo-inner,
.tpl-cb-sustain-v1 .site-promo-text {
  color: color-mix(in srgb, white 92%, var(--color-surface)) !important;
}

.tpl-cb-sustain-v1 .site-brand-logo {
  border: none;
  border-radius: 13px;
  background: var(--tpl-surface-solid);
  box-shadow: 0 10px 22px color-mix(in srgb, var(--ui-text) 10%, transparent);
}

.tpl-cb-sustain-v1 .site-nav a {
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .site-nav a:hover,
.tpl-cb-sustain-v1 .site-login-link:hover {
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .site-header-search-input {
  border-color: var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 94%, var(--tpl-surface-solid));
  color: var(--tpl-text-strong);
}

.tpl-cb-sustain-v1 .site-header-search-input::placeholder {
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .site-header-search-submit {
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .site-footer {
  margin-top: 34px;
  border-top: none;
  background: color-mix(in srgb, var(--tpl-surface-2) 82%, var(--tpl-surface-solid));
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--tpl-surface-solid) 75%, transparent);
}

.tpl-cb-sustain-v1 .landing-cta-primary,
.tpl-cb-sustain-v1 .merchant-button,
.tpl-cb-sustain-v1 .shop-now-button,
.tpl-cb-sustain-v1 .activate-cashback-button,
.tpl-cb-sustain-v1 .coupons-react-row-cta,
.tpl-cb-sustain-v1 .coupon-code-button,
.tpl-cb-sustain-v1 .site-register-button,
.tpl-cb-sustain-v1 .auth-react-submit {
  min-height: var(--component-button-height);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--color-primary) 52%, var(--tpl-surface-solid));
  background: var(--theme-accent-fill);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--color-primary) 28%, transparent);
  color: var(--tpl-surface-solid);
}

.tpl-cb-sustain-v1 .landing-cta-primary:hover,
.tpl-cb-sustain-v1 .merchant-button:hover,
.tpl-cb-sustain-v1 .shop-now-button:hover,
.tpl-cb-sustain-v1 .activate-cashback-button:hover,
.tpl-cb-sustain-v1 .site-register-button:hover,
.tpl-cb-sustain-v1 .auth-react-submit:hover {
  box-shadow: 0 14px 30px color-mix(in srgb, var(--color-primary) 32%, transparent);
  transform: translateY(-1px);
}

.tpl-cb-sustain-v1 .landing-cta-secondary,
.tpl-cb-sustain-v1 .button-outline,
.tpl-cb-sustain-v1 .site-login-link,
.tpl-cb-sustain-v1 .auth-react-google {
  min-height: var(--component-button-height);
  border-radius: var(--radius-md);
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 84%, var(--tpl-surface-solid));
  color: var(--tpl-text-strong);
}

.tpl-cb-sustain-v1 :is(input, select, textarea),
.tpl-cb-sustain-v1 .stores-rakuten-sort-label select,
.tpl-cb-sustain-v1 .stores-rakuten-all-search input,
.tpl-cb-sustain-v1 .coupons-react-search-form input,
.tpl-cb-sustain-v1 .blogs-react-hero-search input,
.tpl-cb-sustain-v1 .auth-react-input {
  min-height: var(--component-input-height);
  border-radius: var(--radius-md);
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
  color: var(--tpl-text-strong);
}

.tpl-cb-sustain-v1 .stores-react-page-link,
.tpl-cb-sustain-v1 .coupons-react-page-link,
.tpl-cb-sustain-v1 .blogs-react-page-link {
  border-radius: var(--radius-md);
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid));
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .stores-react-page-link.is-active,
.tpl-cb-sustain-v1 .coupons-react-page-link.is-active,
.tpl-cb-sustain-v1 .blogs-react-page-link.is-active {
  border-color: color-mix(in srgb, var(--color-primary) 54%, var(--tpl-surface-solid));
  background: var(--theme-accent-fill);
  color: var(--tpl-surface-solid);
}

.tpl-cb-sustain-v1 .panel,
.tpl-cb-sustain-v1 .merchant-card,
.tpl-cb-sustain-v1 .merchant-row,
.tpl-cb-sustain-v1 .coupon-card,
.tpl-cb-sustain-v1 .blogs-react-featured-card,
.tpl-cb-sustain-v1 .blogs-react-grid .blogs-react-tile,
.tpl-cb-sustain-v1 .blogs-react-row-card,
.tpl-cb-sustain-v1 .store-panel,
.tpl-cb-sustain-v1 .page-empty-state,
.tpl-cb-sustain-v1 .page-cta-panel,
.tpl-cb-sustain-v1 .auth-react-card,
.tpl-cb-sustain-v1 .account-react-section,
.tpl-cb-sustain-v1 .static-page-react-content,
.tpl-cb-sustain-v1 .categories-all-card,
.tpl-cb-sustain-v1 .stores-all-row,
.tpl-cb-sustain-v1 .coupons-react-row,
.tpl-cb-sustain-v1 .blog-detail-react-merchant,
.tpl-cb-sustain-v1 .blog-detail-react-cta,
.tpl-cb-sustain-v1 .blog-detail-react-related,
.tpl-cb-sustain-v1 .blog-detail-react-toc {
  border-radius: var(--radius-lg);
  border: none;
  background: linear-gradient(
    170deg,
    color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--tpl-surface-1) 84%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .merchant-card,
.tpl-cb-sustain-v1 .coupon-card,
.tpl-cb-sustain-v1 .blogs-react-featured-card,
.tpl-cb-sustain-v1 .blogs-react-grid .blogs-react-tile,
.tpl-cb-sustain-v1 .blogs-react-row-card,
.tpl-cb-sustain-v1 .categories-all-card,
.tpl-cb-sustain-v1 .stores-all-row,
.tpl-cb-sustain-v1 .coupons-react-row {
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.tpl-cb-sustain-v1 .merchant-card:hover,
.tpl-cb-sustain-v1 .coupon-card:hover,
.tpl-cb-sustain-v1 .blogs-react-featured-card:hover,
.tpl-cb-sustain-v1 .blogs-react-grid .blogs-react-tile:hover,
.tpl-cb-sustain-v1 .blogs-react-row-card:hover,
.tpl-cb-sustain-v1 .categories-all-card:hover,
.tpl-cb-sustain-v1 .stores-all-row:hover,
.tpl-cb-sustain-v1 .coupons-react-row:hover {
  transform: translateY(-2px);
  box-shadow: var(--tpl-card-shadow-hover);
}

.tpl-cb-sustain-v1 .section-kicker,
.tpl-cb-sustain-v1 .account-react-kicker,
.tpl-cb-sustain-v1 .coupons-react-hero-pill,
.tpl-cb-sustain-v1 .blogs-react-hero-pill,
.tpl-cb-sustain-v1 .static-page-react-kicker span {
  color: var(--tpl-primary-strong);
  background: var(--tpl-accent-soft);
  border: 1px solid color-mix(in srgb, var(--color-primary) 22%, var(--tpl-surface-solid));
  border-radius: 999px;
  padding: 0.3rem 0.7rem;
  font-weight: 700;
  font-size: 0.74rem;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tpl-cb-sustain-v1 :is(h1, h2, h3, h4) {
  color: var(--tpl-text-strong);
}

.tpl-cb-sustain-v1 p,
.tpl-cb-sustain-v1 .text-gray-600,
.tpl-cb-sustain-v1 .text-gray-500,
.tpl-cb-sustain-v1 .page-subtitle,
.tpl-cb-sustain-v1 .category-detail-band-subtitle {
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .home-react-hero {
  position: relative;
  overflow: hidden;
  padding-block: clamp(2.4rem, 5vw, 4.4rem);
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--color-secondary) 16%, transparent), transparent 46%),
    radial-gradient(circle at 92% 12%, color-mix(in srgb, var(--color-primary) 18%, transparent), transparent 52%),
    linear-gradient(
      150deg,
      color-mix(in srgb, var(--color-primary) 14%, var(--tpl-hero-primary-wash)),
      color-mix(in srgb, var(--color-secondary) 12%, var(--tpl-on-accent))
    );
  border-bottom: 1px solid color-mix(in srgb, var(--color-border) 72%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .home-react-hero-shell {
  border-radius: 28px;
  padding: clamp(1.2rem, 2.4vw, 2rem);
  border: 1px solid var(--tpl-border-soft);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--color-primary) 9%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--color-secondary) 12%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .home-react-hero-badge {
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 28%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-primary) 10%, var(--tpl-surface-solid));
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .home-react-section {
  border-radius: 24px;
  border: 1px solid var(--tpl-border-soft);
  background: linear-gradient(
    170deg,
    color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--tpl-surface-2) 76%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .home-react-section-head {
  margin-bottom: 16px;
}

.tpl-cb-sustain-v1 .home-react-section-head a {
  color: var(--tpl-primary-strong);
  font-weight: 700;
}

.tpl-cb-sustain-v1 .home-react-bottom-cta {
  border: 1px solid color-mix(in srgb, var(--color-primary) 20%, var(--tpl-surface-solid));
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--color-primary) 14%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--color-secondary) 18%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .merchant-logo,
.tpl-cb-sustain-v1 .store-logo-placeholder {
  border-radius: 14px;
  border: 1px solid var(--tpl-border-soft);
  background: var(--tpl-surface-solid);
}

.tpl-cb-sustain-v1 .merchant-cashback,
.tpl-cb-sustain-v1 .coupon-code,
.tpl-cb-sustain-v1 .cashback-tag {
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-band {
  margin-bottom: 1.4rem;
}

.tpl-cb-sustain-v1 #stores-fragment .stores-band-categories,
.tpl-cb-sustain-v1 .categories-band-categories,
.tpl-cb-sustain-v1 .static-page-react-shell {
  border-radius: 24px;
  border: 1px solid var(--tpl-border-soft);
  background: linear-gradient(
    155deg,
    color-mix(in srgb, var(--color-primary) 8%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
  padding: clamp(1rem, 2vw, 1.6rem) 0;
}

.tpl-cb-sustain-v1 #stores-fragment .stores-band-all,
.tpl-cb-sustain-v1 .categories-band-all {
  border-radius: 24px;
  border: 1px solid var(--tpl-border-soft);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--tpl-surface-2) 82%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-rakuten-all-toolbar,
.tpl-cb-sustain-v1 #stores-fragment .stores-alpha-panel,
.tpl-cb-sustain-v1 #stores-fragment .stores-filter-categories,
.tpl-cb-sustain-v1 .categories-react-search-status {
  border-radius: 16px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 #stores-fragment .stores-rakuten-category-card,
.tpl-cb-sustain-v1 .stores-featured-card,
.tpl-cb-sustain-v1 .categories-all-card,
.tpl-cb-sustain-v1 .stores-all-row {
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .stores-rakuten-category-name,
.tpl-cb-sustain-v1 .stores-all-copy strong,
.tpl-cb-sustain-v1 .stores-featured-copy strong {
  color: var(--tpl-text-strong);
}

.tpl-cb-sustain-v1 .stores-alpha-chip,
.tpl-cb-sustain-v1 .stores-rakuten-category-card,
.tpl-cb-sustain-v1 .coupons-react-type-chip,
.tpl-cb-sustain-v1 .blogs-react-category-chip,
.tpl-cb-sustain-v1 .account-react-link {
  border-radius: 999px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .stores-alpha-chip.is-active,
.tpl-cb-sustain-v1 .stores-rakuten-category-card.is-active,
.tpl-cb-sustain-v1 .coupons-react-type-chip.is-active,
.tpl-cb-sustain-v1 .blogs-react-category-chip.is-active,
.tpl-cb-sustain-v1 .account-react-link.is-active {
  border-color: color-mix(in srgb, var(--color-primary) 42%, var(--tpl-surface-solid));
  background: var(--tpl-accent-soft);
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .home-react-section,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-categories,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-featured,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-all,
.tpl-cb-sustain-v1 .categories-band-categories,
.tpl-cb-sustain-v1 .categories-band-all {
  border-color: color-mix(in srgb, var(--color-border) 54%, var(--tpl-surface-solid));
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--tpl-surface-solid) 75%, transparent), transparent 36%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--tpl-surface-0) 96%, var(--tpl-surface-solid)),
      color-mix(in srgb, var(--tpl-surface-1) 90%, var(--tpl-surface-solid))
  );
  box-shadow: 0 12px 34px color-mix(in srgb, var(--ui-text) 12%, transparent);
}

.tpl-cb-sustain-v1 .home-react-hero {
  background:
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--color-primary) 14%, transparent), transparent 42%),
    radial-gradient(circle at 92% 12%, color-mix(in srgb, var(--color-secondary) 16%, transparent), transparent 48%),
    linear-gradient(150deg, var(--tpl-hero-primary-wash), var(--tpl-hero-secondary-wash));
  border-bottom: 1px solid color-mix(in srgb, var(--color-border) 54%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .home-react-hero-shell {
  border-radius: 2rem;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--tpl-surface-solid) 78%, transparent), transparent 36%),
    linear-gradient(
      145deg,
      color-mix(in srgb, var(--tpl-surface-solid) 70%, transparent),
      color-mix(in srgb, var(--tpl-surface-solid) 82%, var(--color-bg))
    );
  border: 1px solid var(--tpl-overlay-62);
  box-shadow: 0 18px 48px color-mix(in srgb, var(--ui-text) 16%, transparent);
}

.tpl-cb-sustain-v1 .home-react-hero-badge {
  background: var(--tpl-overlay-76);
  border-color: color-mix(in srgb, var(--color-primary) 20%, transparent);
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .merchant-grid-compact,
.tpl-cb-sustain-v1 .stores-all-grid {
  display: grid;
  gap: 1rem;
}

@media (min-width: 720px) {
  .tpl-cb-sustain-v1 .merchant-grid-compact,
  .tpl-cb-sustain-v1 .stores-all-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1080px) {
  .tpl-cb-sustain-v1 .merchant-grid-compact,
  .tpl-cb-sustain-v1 .stores-all-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.tpl-cb-sustain-v1 .merchant-compact-card {
  height: 100%;
  overflow: hidden;
  border-radius: 1.45rem;
  background: var(--tpl-surface-solid);
  box-shadow: 0 12px 26px color-mix(in srgb, var(--ui-text) 10%, transparent);
}

.tpl-cb-sustain-v1 .merchant-compact-card:hover,
.tpl-cb-sustain-v1 .merchant-compact-card:focus-within {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--color-primary) 32%, var(--tpl-surface-solid));
  box-shadow: 0 18px 38px color-mix(in srgb, var(--ui-text) 14%, transparent);
}

.tpl-cb-sustain-v1 .merchant-compact-shell {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  height: 100%;
  padding: 1rem;
}

.tpl-cb-sustain-v1 .merchant-compact-main {
  display: grid;
  grid-template-columns: 5.4rem minmax(0, 1fr);
  gap: 1rem;
  align-items: center;
  text-decoration: none;
  min-height: 7rem;
}

.tpl-cb-sustain-v1 .merchant-compact-logo-wrap {
  display: grid;
  place-items: center;
  width: 5.4rem;
  height: 5.4rem;
  border-radius: 1.1rem;
  background: linear-gradient(180deg, var(--tpl-surface-solid), color-mix(in srgb, var(--tpl-surface-solid) 92%, var(--color-bg)));
  border: 1px solid color-mix(in srgb, var(--color-border) 46%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .merchant-compact-logo {
  width: 4.4rem;
  height: 4.4rem;
  object-fit: contain;
  transition: transform 0.22s ease;
}

.tpl-cb-sustain-v1 .merchant-compact-logo-fallback {
  font-size: 1.4rem;
  font-weight: 800;
}

.tpl-cb-sustain-v1 .merchant-compact-copy {
  display: grid;
  gap: 0.32rem;
  min-width: 0;
}

.tpl-cb-sustain-v1 .merchant-compact-title-row {
  display: flex;
  align-items: flex-start;
  gap: 0.45rem;
}

.tpl-cb-sustain-v1 .merchant-compact-name {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.28;
  color: var(--tpl-text-strong);
}

.tpl-cb-sustain-v1 .merchant-compact-inline-mark {
  color: var(--tpl-text-muted);
  font-size: 0.92rem;
  line-height: 1.4;
}

.tpl-cb-sustain-v1 .merchant-compact-rate {
  color: color-mix(in srgb, var(--color-secondary) 74%, var(--color-primary));
  font-size: 0.98rem;
  font-weight: 800;
  line-height: 1.32;
}

.tpl-cb-sustain-v1 .merchant-compact-cta {
  width: fit-content;
  min-width: 7.5rem;
  justify-content: center;
  align-self: flex-start;
  opacity: 0;
  transform: translateY(0.45rem);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.tpl-cb-sustain-v1 .merchant-compact-card:hover .merchant-compact-logo,
.tpl-cb-sustain-v1 .merchant-compact-card:focus-within .merchant-compact-logo {
  transform: scale(1.08);
}

.tpl-cb-sustain-v1 .merchant-compact-card:hover .merchant-compact-cta,
.tpl-cb-sustain-v1 .merchant-compact-card:focus-within .merchant-compact-cta {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.tpl-cb-sustain-v1 .category-grid-visual {
  display: grid;
  gap: 1rem;
}

@media (min-width: 720px) {
  .tpl-cb-sustain-v1 .category-grid-visual {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .tpl-cb-sustain-v1 .category-grid-visual {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.tpl-cb-sustain-v1 .category-visual-card {
  display: grid;
  gap: 0.85rem;
  padding: 0.75rem;
  text-decoration: none;
  border-radius: 1.45rem;
  background: var(--tpl-surface-solid);
  box-shadow: 0 12px 26px color-mix(in srgb, var(--ui-text) 10%, transparent);
}

.tpl-cb-sustain-v1 .category-visual-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 38px color-mix(in srgb, var(--ui-text) 14%, transparent);
}

.tpl-cb-sustain-v1 .category-visual-media {
  display: grid;
  place-items: center;
  min-height: 7.4rem;
  overflow: hidden;
  border-radius: 1rem;
  background:
    radial-gradient(circle at 18% 20%, var(--tpl-overlay-28), transparent 44%),
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--color-primary) 12%, transparent),
      color-mix(in srgb, var(--color-secondary) 10%, transparent)
    );
}

.tpl-cb-sustain-v1 .category-visual-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.22s ease;
}

.tpl-cb-sustain-v1 .category-visual-card:hover .category-visual-image {
  transform: scale(1.05);
}

.tpl-cb-sustain-v1 .category-visual-icon-wrap,
.tpl-cb-sustain-v1 .category-visual-fallback {
  display: grid;
  place-items: center;
  width: 4.3rem;
  height: 4.3rem;
  border-radius: 1rem;
  background: var(--tpl-overlay-88);
}

.tpl-cb-sustain-v1 .category-visual-icon {
  width: 2.4rem;
  height: 2.4rem;
  object-fit: contain;
}

.tpl-cb-sustain-v1 .category-visual-fallback {
  font-size: 1.25rem;
  font-weight: 800;
}

.tpl-cb-sustain-v1 .category-visual-body {
  display: grid;
  gap: 0.28rem;
}

.tpl-cb-sustain-v1 .category-visual-name {
  color: var(--tpl-text-strong);
  font-size: 1rem;
  line-height: 1.32;
}

.tpl-cb-sustain-v1 .category-visual-meta {
  color: var(--tpl-text-muted);
  font-size: 0.86rem;
  line-height: 1.4;
}

.tpl-cb-sustain-v1 .home-react-section-head p,
.tpl-cb-sustain-v1 .stores-band-head p {
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card {
  border-radius: 1.35rem;
  background: var(--tpl-surface-solid);
  border-color: color-mix(in srgb, var(--color-border) 46%, var(--tpl-surface-solid));
  color: var(--tpl-text-strong);
  box-shadow: 0 12px 26px color-mix(in srgb, var(--ui-text) 10%, transparent);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card:hover,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card.is-active {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--color-primary) 34%, var(--tpl-surface-solid));
  background: linear-gradient(
    180deg,
    var(--tpl-surface-solid),
    color-mix(in srgb, var(--tpl-surface-solid) 95%, var(--color-bg))
  );
  box-shadow: 0 18px 38px color-mix(in srgb, var(--ui-text) 14%, transparent);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-rakuten-all-toolbar,
.tpl-cb-sustain-v1 .categories-react-search-status {
  border-radius: 1.2rem;
  background: var(--tpl-overlay-82);
}

@media (hover: none), (pointer: coarse), (max-width: 820px) {
  .tpl-cb-sustain-v1 .merchant-compact-cta {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
}

.tpl-cb-sustain-v1 .coupons-react-hero,
.tpl-cb-sustain-v1 .blogs-react-hero {
  padding-top: clamp(2rem, 4vw, 3.4rem);
}

.tpl-cb-sustain-v1 .coupons-react-hero-shell,
.tpl-cb-sustain-v1 .blogs-react-hero-shell {
  border-radius: 24px;
  border: 1px solid var(--tpl-border-soft);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--color-primary) 9%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--color-secondary) 14%, var(--tpl-surface-solid))
  );
  padding: clamp(1rem, 2.4vw, 1.8rem);
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .coupons-react-search-form,
.tpl-cb-sustain-v1 .blogs-react-hero-search {
  border-radius: 16px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
  padding: 10px;
}

.tpl-cb-sustain-v1 .coupons-react-search-submit,
.tpl-cb-sustain-v1 .blogs-react-hero-search button {
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--color-primary) 52%, var(--tpl-surface-solid));
  background: var(--theme-accent-fill);
  color: var(--tpl-surface-solid);
}

.tpl-cb-sustain-v1 .coupons-react-search-status,
.tpl-cb-sustain-v1 .blogs-react-search-status {
  border-radius: 16px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .coupons-react-featured-card,
.tpl-cb-sustain-v1 .blogs-react-featured-card,
.tpl-cb-sustain-v1 .blog-detail-react-related-item {
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid));
  border-radius: 18px;
}

.tpl-cb-sustain-v1 .coupons-react-featured-badge,
.tpl-cb-sustain-v1 .blogs-react-tile-tag,
.tpl-cb-sustain-v1 .coupons-react-expire-chip {
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 24%, var(--tpl-surface-solid));
  background: var(--tpl-accent-soft);
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .blogs-react-tile-readmore,
.tpl-cb-sustain-v1 .blogs-react-row-readmore,
.tpl-cb-sustain-v1 .blog-detail-react-back-link,
.tpl-cb-sustain-v1 .blog-detail-react-cta a,
.tpl-cb-sustain-v1 .blog-detail-react-toc-link.is-active {
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .blog-detail-react-hero-banner {
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid var(--tpl-border-soft);
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .blog-detail-react-hero-overlay {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--ui-text) 8%, transparent) 0%,
    color-mix(in srgb, var(--ui-text) 66%, transparent) 100%
  );
}

.tpl-cb-sustain-v1 .blog-detail-react-copy h1,
.tpl-cb-sustain-v1 .blog-detail-react-copy .blog-detail-react-meta span,
.tpl-cb-sustain-v1 .blog-detail-react-copy .blog-detail-react-breadcrumb a,
.tpl-cb-sustain-v1 .blog-detail-react-copy .blog-detail-react-breadcrumb span {
  color: var(--tpl-on-accent);
}

.tpl-cb-sustain-v1 .blog-detail-react-article {
  border-radius: 20px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 94%, var(--tpl-surface-solid));
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .blog-detail-react-toc-link {
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .account-react-page {
  padding-top: clamp(2rem, 4vw, 3rem);
  padding-bottom: clamp(2.4rem, 4vw, 3.4rem);
}

.tpl-cb-sustain-v1 .account-react-shell,
.tpl-cb-sustain-v1 .account-react-nav,
.tpl-cb-sustain-v1 .account-react-content {
  border-radius: 24px;
}

.tpl-cb-sustain-v1 .account-react-nav {
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .account-kpi,
.tpl-cb-sustain-v1 .account-react-stat-card {
  border-radius: 16px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 94%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .account-react-trust-pill,
.tpl-cb-sustain-v1 .account-pill {
  border: 1px solid color-mix(in srgb, var(--color-primary) 24%, var(--tpl-surface-solid));
  background: var(--tpl-accent-soft);
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .auth-react-shell {
  border: 1px solid var(--tpl-border-soft);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--color-primary) 11%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--color-secondary) 15%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .auth-react-brand {
  background: linear-gradient(
    170deg,
    color-mix(in srgb, var(--color-primary) 19%, var(--tpl-on-accent)),
    color-mix(in srgb, var(--color-secondary) 20%, var(--tpl-hero-primary-wash))
  );
}

.tpl-cb-sustain-v1 .auth-react-badge,
.tpl-cb-sustain-v1 .auth-react-divider strong {
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .auth-react-alert {
  border-radius: 14px;
}

.tpl-cb-sustain-v1 .auth-react-alert.is-error {
  border: 1px solid color-mix(in srgb, var(--color-error) 38%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-error) 14%, var(--tpl-surface-solid));
  color: color-mix(in srgb, var(--color-error) 78%, var(--ui-error-strong));
}

.tpl-cb-sustain-v1 .auth-react-alert.is-info {
  border: 1px solid color-mix(in srgb, var(--color-primary) 24%, var(--tpl-surface-solid));
  background: var(--tpl-accent-soft);
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .store-rk-breadcrumb-band,
.tpl-cb-sustain-v1 .store-rk-header-band {
  border-radius: 24px;
  border: 1px solid var(--tpl-border-soft);
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--color-primary) 10%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--color-secondary) 12%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
  margin-bottom: 1rem;
}

.tpl-cb-sustain-v1 .store-header {
  border-radius: 22px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .store-cashback-pill,
.tpl-cb-sustain-v1 .discount-badge,
.tpl-cb-sustain-v1 .cashback-tag {
  border: 1px solid color-mix(in srgb, var(--color-primary) 24%, var(--tpl-surface-solid));
  background: var(--tpl-accent-soft);
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .similar-store-card {
  border-radius: 14px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 94%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .static-page-react-content h2,
.tpl-cb-sustain-v1 .static-page-react-head h1,
.tpl-cb-sustain-v1 .stores-band-head h1,
.tpl-cb-sustain-v1 .stores-band-head h2 {
  color: var(--tpl-text-strong);
}

.tpl-cb-sustain-v1 .page-empty-state {
  border-style: dashed;
  border-color: color-mix(in srgb, var(--color-border) 72%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .sustain-hero {
  border-radius: 30px;
  border: 1px solid var(--tpl-border-strong);
  background:
    radial-gradient(circle at 80% -20%, color-mix(in srgb, var(--color-primary) 22%, transparent), transparent 58%),
    radial-gradient(circle at 10% 0%, color-mix(in srgb, var(--color-secondary) 16%, transparent), transparent 52%),
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid)),
      color-mix(in srgb, var(--tpl-surface-2) 84%, var(--tpl-surface-solid))
    );
  box-shadow: 0 22px 46px color-mix(in srgb, var(--ui-text) 19%, transparent);
  padding: clamp(1.2rem, 2.4vw, 2.1rem) 0;
}

.tpl-cb-sustain-v1 .sustain-hero-shell {
  display: grid;
  gap: clamp(1rem, 2vw, 1.7rem);
  align-items: start;
}

@media (min-width: 1060px) {
  .tpl-cb-sustain-v1 .sustain-hero-shell {
    grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.82fr);
  }
}

.tpl-cb-sustain-v1 .sustain-hero-main {
  display: grid;
  gap: 0.9rem;
}

.tpl-cb-sustain-v1 .sustain-hero-badge {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--tpl-primary-strong);
  background: color-mix(in srgb, var(--color-primary) 12%, var(--tpl-surface-solid));
  border: 1px solid color-mix(in srgb, var(--color-primary) 28%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .sustain-hero-badge svg {
  width: 12px;
  height: 12px;
  fill: color-mix(in srgb, var(--color-primary) 68%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .sustain-hero-title {
  font-size: clamp(2rem, 5.3vw, 4.1rem);
  line-height: 1.03;
  letter-spacing: -0.03em;
  margin: 0;
}

.tpl-cb-sustain-v1 .sustain-hero-title-accent {
  background-image: none;
  background-clip: text;
  -webkit-background-clip: text;
  color: color-mix(in srgb, var(--color-primary) 84%, var(--color-text));
}

.tpl-cb-sustain-v1 .sustain-hero-subtitle {
  max-width: 62ch;
  font-size: 1.02rem;
  line-height: 1.7;
}

.tpl-cb-sustain-v1 .sustain-search-form {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  border-radius: 16px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid));
  padding: 10px;
}

.tpl-cb-sustain-v1 .sustain-search-form input {
  flex: 1;
  min-width: 180px;
}

.tpl-cb-sustain-v1 .sustain-trending-row,
.tpl-cb-sustain-v1 .sustain-proof-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tpl-cb-sustain-v1 .sustain-trending-pill,
.tpl-cb-sustain-v1 .sustain-proof-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid));
  color: var(--tpl-text-muted);
  padding: 5px 11px;
  font-size: 0.78rem;
  font-weight: 600;
}

.tpl-cb-sustain-v1 .sustain-proof-pill {
  color: var(--tpl-primary-strong);
  background: var(--tpl-accent-soft);
  border-color: color-mix(in srgb, var(--color-primary) 24%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .sustain-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.tpl-cb-sustain-v1 .sustain-kpi-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
}

.tpl-cb-sustain-v1 .sustain-kpi {
  border-radius: 14px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 92%, var(--tpl-surface-solid));
  padding: 10px;
  display: grid;
  gap: 3px;
}

.tpl-cb-sustain-v1 .sustain-kpi strong {
  font-size: 1.16rem;
  line-height: 1.1;
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .sustain-kpi span {
  color: var(--tpl-text-muted);
  font-size: 0.76rem;
}

.tpl-cb-sustain-v1 .sustain-hero-aside {
  position: relative;
  display: grid;
  gap: 10px;
}

.tpl-cb-sustain-v1 .sustain-impact-card {
  border-radius: 22px;
  border: 1px solid var(--tpl-border-soft);
  background: linear-gradient(
    165deg,
    color-mix(in srgb, var(--tpl-surface-0) 94%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--color-primary) 8%, var(--tpl-surface-solid))
  );
  box-shadow: var(--tpl-card-shadow);
  padding: clamp(0.9rem, 1.8vw, 1.2rem);
}

.tpl-cb-sustain-v1 .sustain-impact-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.tpl-cb-sustain-v1 .sustain-impact-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--theme-accent-fill);
}

.tpl-cb-sustain-v1 .sustain-impact-icon svg {
  width: 24px;
  height: 24px;
  stroke: var(--tpl-surface-solid);
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tpl-cb-sustain-v1 .sustain-impact-label {
  margin: 0;
  font-size: 0.78rem;
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .sustain-impact-value {
  margin: 2px 0 0;
  font-size: 1.72rem;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--tpl-text-strong);
  font-weight: 800;
}

.tpl-cb-sustain-v1 .sustain-impact-meta {
  margin: 0 0 10px;
  font-size: 0.8rem;
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .sustain-offer-list {
  display: grid;
  gap: 8px;
}

.tpl-cb-sustain-v1 .sustain-offer-item {
  border-radius: 14px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 94%, var(--tpl-surface-solid));
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.tpl-cb-sustain-v1 .sustain-offer-copy {
  display: grid;
  gap: 3px;
}

.tpl-cb-sustain-v1 .sustain-offer-copy em {
  width: fit-content;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 24%, var(--tpl-surface-solid));
  background: var(--tpl-accent-soft);
  color: var(--tpl-primary-strong);
  padding: 2px 7px;
  font-size: 0.66rem;
  font-style: normal;
  font-weight: 700;
}

.tpl-cb-sustain-v1 .sustain-offer-copy h3 {
  margin: 0;
  font-size: 0.84rem;
  color: var(--tpl-text-strong);
}

.tpl-cb-sustain-v1 .sustain-offer-copy p {
  margin: 0;
  font-size: 0.72rem;
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .sustain-offer-value {
  display: grid;
  justify-items: end;
  gap: 3px;
}

.tpl-cb-sustain-v1 .sustain-offer-value strong {
  color: var(--tpl-primary-strong);
  font-size: 0.88rem;
}

.tpl-cb-sustain-v1 .sustain-offer-value a {
  color: var(--tpl-primary-strong);
  font-size: 0.72rem;
  font-weight: 700;
  text-decoration: none;
}

.tpl-cb-sustain-v1 .sustain-impact-pill {
  position: absolute;
  right: -8px;
  top: -12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 42%, var(--tpl-surface-solid));
  background: var(--theme-accent-fill);
  color: var(--tpl-surface-solid);
  font-weight: 800;
  font-size: 0.72rem;
  padding: 7px 11px;
  box-shadow: 0 12px 28px color-mix(in srgb, var(--color-primary) 34%, transparent);
}

@media (max-width: 860px) {
  .tpl-cb-sustain-v1 .sustain-impact-pill {
    position: static;
    width: fit-content;
    margin-left: auto;
  }
}

.tpl-cb-sustain-v1 .sustain-section-head {
  display: grid;
  gap: 6px;
  margin-bottom: 12px;
}

.tpl-cb-sustain-v1 .sustain-section-head h2 {
  margin: 0;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
}

.tpl-cb-sustain-v1 .sustain-section-head p {
  margin: 0;
  max-width: 64ch;
}

.tpl-cb-sustain-v1 .sustain-eyebrow {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .sustain-slab {
  border-radius: 22px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 90%, var(--tpl-surface-solid));
  padding: clamp(1rem, 2.1vw, 1.6rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .sustain-slab h2 {
  margin: 5px 0;
  font-size: clamp(1.2rem, 2vw, 1.7rem);
}

.tpl-cb-sustain-v1 .sustain-slab p {
  margin: 0;
}

.tpl-cb-sustain-v1 .sustain-slab-highlight {
  background: linear-gradient(
    130deg,
    color-mix(in srgb, var(--color-primary) 16%, var(--tpl-surface-solid)),
    color-mix(in srgb, var(--color-secondary) 20%, var(--tpl-surface-solid))
  );
}

.tpl-cb-sustain-v1 .sustain-steps-grid {
  display: grid;
  gap: 12px;
}

@media (min-width: 900px) {
  .tpl-cb-sustain-v1 .sustain-steps-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.tpl-cb-sustain-v1 .sustain-step-card {
  border-radius: 18px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 93%, var(--tpl-surface-solid));
  padding: 14px;
  box-shadow: var(--tpl-card-shadow);
  display: grid;
  gap: 8px;
}

.tpl-cb-sustain-v1 .sustain-step-index {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 30%, var(--tpl-surface-solid));
  background: var(--tpl-accent-soft);
  color: var(--tpl-primary-strong);
  font-size: 0.8rem;
  font-weight: 800;
}

.tpl-cb-sustain-v1 .sustain-step-card h3 {
  margin: 0;
  font-size: 0.94rem;
}

.tpl-cb-sustain-v1 .sustain-step-card p {
  margin: 0;
  font-size: 0.86rem;
}

.tpl-cb-sustain-v1 .sustain-brand-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.tpl-cb-sustain-v1 .sustain-brand-card {
  border-radius: 16px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 93%, var(--tpl-surface-solid));
  padding: 12px;
  display: grid;
  justify-items: center;
  gap: 8px;
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .sustain-brand-card img {
  width: 100%;
  max-width: 92px;
  height: 38px;
  object-fit: contain;
}

.tpl-cb-sustain-v1 .sustain-brand-card span {
  font-size: 0.8rem;
  color: var(--tpl-text-muted);
  text-align: center;
}

.tpl-cb-sustain-v1 .sustain-trust-grid {
  display: grid;
  gap: 12px;
}

@media (min-width: 900px) {
  .tpl-cb-sustain-v1 .sustain-trust-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.tpl-cb-sustain-v1 .sustain-trust-card {
  border-radius: 18px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 93%, var(--tpl-surface-solid));
  padding: 14px;
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .sustain-trust-card h3 {
  margin: 0;
  font-size: 0.94rem;
}

.tpl-cb-sustain-v1 .sustain-trust-card p {
  margin: 8px 0 0;
  font-size: 0.84rem;
}

.tpl-cb-sustain-v1 .sustain-faq-grid {
  display: grid;
  gap: 10px;
}

@media (min-width: 960px) {
  .tpl-cb-sustain-v1 .sustain-faq-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.tpl-cb-sustain-v1 .sustain-faq-item {
  border-radius: 16px;
  border: 1px solid var(--tpl-border-soft);
  background: color-mix(in srgb, var(--tpl-surface-0) 93%, var(--tpl-surface-solid));
  box-shadow: var(--tpl-card-shadow);
  padding: 12px 14px;
}

.tpl-cb-sustain-v1 .sustain-faq-item summary {
  cursor: pointer;
  list-style: none;
  color: var(--tpl-text-strong);
  font-size: 0.92rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.tpl-cb-sustain-v1 .sustain-faq-item summary::-webkit-details-marker {
  display: none;
}

.tpl-cb-sustain-v1 .sustain-faq-item summary::after {
  content: "+";
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 28%, var(--tpl-surface-solid));
  background: var(--tpl-accent-soft);
  color: var(--tpl-primary-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  line-height: 1;
  flex: 0 0 auto;
}

.tpl-cb-sustain-v1 .sustain-faq-item[open] summary::after {
  content: "-";
}

.tpl-cb-sustain-v1 .sustain-faq-item p {
  margin: 10px 0 0;
  font-size: 0.84rem;
  line-height: 1.6;
}

.tpl-cb-sustain-v1 .sustain-cta-section {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--color-primary) 86%, var(--ui-ink-deep)),
    color-mix(in srgb, var(--color-secondary) 78%, var(--ui-secondary-strong))
  );
  border-radius: 30px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 42%, var(--tpl-surface-solid));
  box-shadow: 0 24px 50px color-mix(in srgb, var(--ui-text) 26%, transparent);
  padding: clamp(1.3rem, 2.5vw, 2.2rem) 0;
}

.tpl-cb-sustain-v1 .sustain-cta-shell {
  max-width: 760px;
  margin: 0 auto;
  display: grid;
  gap: 0.8rem;
  justify-items: center;
}

.tpl-cb-sustain-v1 .sustain-cta-shell .sustain-eyebrow,
.tpl-cb-sustain-v1 .sustain-cta-shell h2,
.tpl-cb-sustain-v1 .sustain-cta-shell p {
  color: var(--tpl-on-accent);
}

.tpl-cb-sustain-v1 .sustain-cta-shell .landing-cta-primary {
  min-width: 180px;
}

.tpl-cb-sustain-v1 .sustain-cta-shell .landing-cta-secondary {
  color: var(--tpl-on-accent);
  border-color: var(--tpl-overlay-38);
  background: var(--tpl-overlay-08);
}

@media (max-width: 860px) {
  .tpl-cb-sustain-v1 .sustain-slab {
    display: grid;
    justify-items: start;
  }

  .tpl-cb-sustain-v1 .sustain-cta-shell {
    justify-items: stretch;
  }

  .tpl-cb-sustain-v1 .sustain-cta-shell .landing-cta-primary,
  .tpl-cb-sustain-v1 .sustain-cta-shell .landing-cta-secondary {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .tpl-cb-sustain-v1 .home-react-hero-shell,
  .tpl-cb-sustain-v1 .home-react-section,
  .tpl-cb-sustain-v1 #stores-fragment .stores-band-all,
  .tpl-cb-sustain-v1 .categories-band-categories,
  .tpl-cb-sustain-v1 .categories-band-all,
  .tpl-cb-sustain-v1 .auth-react-shell,
  .tpl-cb-sustain-v1 .store-rk-breadcrumb-band,
  .tpl-cb-sustain-v1 .store-rk-header-band,
  .tpl-cb-sustain-v1 .sustain-hero,
  .tpl-cb-sustain-v1 .sustain-cta-section {
    border-radius: 20px;
  }

  .tpl-cb-sustain-v1 .sustain-hero {
    padding-block: 14px;
  }

  .tpl-cb-sustain-v1 .sustain-impact-card {
    border-radius: 16px;
  }

  .tpl-cb-sustain-v1 .sustain-hero-actions,
  .tpl-cb-sustain-v1 .sustain-search-form {
    gap: 8px;
  }

  .tpl-cb-sustain-v1 .sustain-search-form .landing-cta-primary,
  .tpl-cb-sustain-v1 .sustain-hero-actions .landing-cta-primary,
  .tpl-cb-sustain-v1 .sustain-hero-actions .landing-cta-secondary {
    width: 100%;
  }

  .tpl-cb-sustain-v1 .sustain-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Sustainability Platform (UUPM-aligned) landing */
.tpl-cb-sustain-v1 .sustainability-platform {
  background: var(--color-bg);
  color: var(--color-text);
}

.js-ready .tpl-cb-sustain-v1 .sustainability-platform [data-animate] {
  opacity: 1;
  transform: none;
}

.tpl-cb-sustain-v1 .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.tpl-cb-sustain-v1 .eco-shell {
  width: min(100%, 1160px);
  margin: 0 auto;
  padding: 0 1rem;
}

.tpl-cb-sustain-v1 .eco-hero-section {
  position: relative;
  overflow: hidden;
  padding-top: clamp(1.1rem, 2.8vw, 2.1rem);
  padding-bottom: clamp(2.4rem, 6vw, 4.8rem);
}

.tpl-cb-sustain-v1 .eco-hero-glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(60px);
  pointer-events: none;
}

.tpl-cb-sustain-v1 .eco-hero-glow-a {
  top: 4.2rem;
  right: 8%;
  width: clamp(190px, 24vw, 320px);
  height: clamp(190px, 24vw, 320px);
  background: color-mix(in srgb, var(--color-primary) 18%, transparent);
}

.tpl-cb-sustain-v1 .eco-hero-glow-b {
  bottom: 1rem;
  left: 6%;
  width: clamp(150px, 20vw, 260px);
  height: clamp(150px, 20vw, 260px);
  background: color-mix(in srgb, var(--color-secondary) 18%, transparent);
}

.tpl-cb-sustain-v1 .leaf-decoration {
  position: absolute;
  top: 2rem;
  right: max(2rem, calc((100vw - 1160px) / 2));
  width: 2.3rem;
  height: 2.3rem;
  color: color-mix(in srgb, var(--color-primary) 78%, var(--ui-accent-strong));
  opacity: 0.7;
}

.tpl-cb-sustain-v1 .eco-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  align-items: center;
  gap: clamp(1.3rem, 3vw, 2.1rem);
}

.tpl-cb-sustain-v1 .eco-hero-main {
  display: grid;
  gap: 1rem;
}

.tpl-cb-sustain-v1 .badge-eco {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  width: fit-content;
  padding: 0.38rem 0.72rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-primary) 26%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-primary) 10%, var(--tpl-surface-solid));
  color: color-mix(in srgb, var(--color-primary) 78%, var(--ui-accent-strong));
  font-size: 0.78rem;
  font-weight: 700;
}

.tpl-cb-sustain-v1 .badge-eco svg {
  width: 0.9rem;
  height: 0.9rem;
}

.tpl-cb-sustain-v1 .badge-eco-mini {
  font-size: 0.68rem;
  padding: 0.22rem 0.58rem;
}

.tpl-cb-sustain-v1 .badge-eco-dark {
  color: var(--tpl-overlay-92);
  border-color: var(--tpl-overlay-22);
  background: color-mix(in srgb, var(--tpl-surface-solid) 9%, transparent);
}

.tpl-cb-sustain-v1 .eco-hero-title {
  margin: 0;
  display: grid;
  gap: 0.18rem;
  font-size: clamp(2rem, 4.8vw, 3.5rem);
  line-height: 1.08;
  letter-spacing: -0.024em;
  color: color-mix(in srgb, var(--color-text) 90%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .gradient-text {
  background: none;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  color: color-mix(in srgb, var(--color-primary) 82%, var(--ui-accent-strong));
}

.tpl-cb-sustain-v1 .eco-hero-subtitle {
  margin: 0;
  max-width: 58ch;
  color: color-mix(in srgb, var(--color-text) 68%, var(--ui-ink-muted-base));
  font-size: clamp(0.97rem, 1.6vw, 1.14rem);
  line-height: 1.65;
}

.tpl-cb-sustain-v1 .eco-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
}

.tpl-cb-sustain-v1 .btn-primary,
.tpl-cb-sustain-v1 .btn-secondary {
  min-height: 2.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  text-decoration: none;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 700;
  font-size: 0.92rem;
  padding: 0.64rem 1.25rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.tpl-cb-sustain-v1 .btn-primary {
  color: var(--tpl-surface-solid);
  background: var(--theme-accent-fill);
  border-color: color-mix(in srgb, var(--color-primary) 44%, var(--tpl-surface-solid));
  box-shadow: 0 14px 30px color-mix(in srgb, var(--color-primary) 28%, transparent);
}

.tpl-cb-sustain-v1 .btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 34px color-mix(in srgb, var(--color-primary) 34%, transparent);
}

.tpl-cb-sustain-v1 .btn-secondary {
  color: color-mix(in srgb, var(--color-text) 84%, var(--ui-ink-deep));
  background: color-mix(in srgb, var(--color-surface) 92%, var(--tpl-surface-solid));
  border-color: color-mix(in srgb, var(--color-border) 72%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .btn-secondary:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--color-primary) 32%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .btn-secondary-dark {
  border-color: var(--tpl-overlay-22);
  background: var(--tpl-overlay-08);
  color: var(--tpl-surface-solid);
}

.tpl-cb-sustain-v1 .btn-secondary-dark:hover {
  background: var(--tpl-overlay-14);
}

.tpl-cb-sustain-v1 .btn-small {
  min-height: 2.26rem;
  padding: 0.5rem 0.94rem;
  font-size: 0.82rem;
}

.tpl-cb-sustain-v1 .eco-proof-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.tpl-cb-sustain-v1 .eco-proof-item {
  display: inline-flex;
  align-items: center;
  gap: 0.34rem;
  border-radius: 999px;
  padding: 0.26rem 0.62rem;
  background: color-mix(in srgb, var(--color-surface) 92%, var(--tpl-surface-solid));
  border: 1px solid color-mix(in srgb, var(--color-border) 72%, var(--tpl-surface-solid));
  color: color-mix(in srgb, var(--color-text) 70%, var(--ui-ink-muted-base));
  font-size: 0.74rem;
  font-weight: 600;
}

.tpl-cb-sustain-v1 .eco-proof-item svg {
  width: 0.84rem;
  height: 0.84rem;
  color: var(--color-primary);
}

.tpl-cb-sustain-v1 .eco-hero-visual {
  position: relative;
}

.tpl-cb-sustain-v1 .calculator-preview {
  border-radius: clamp(20px, 2.8vw, 28px);
  border: 1px solid color-mix(in srgb, var(--color-border) 68%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-surface) 96%, var(--tpl-surface-solid));
  padding: clamp(1rem, 2.2vw, 1.35rem);
  box-shadow: 0 20px 44px color-mix(in srgb, var(--ui-text) 18%, transparent);
}

.tpl-cb-sustain-v1 .calculator-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  margin-bottom: 0.9rem;
}

.tpl-cb-sustain-v1 .calculator-head h3 {
  margin: 0;
  font-size: 1rem;
  color: color-mix(in srgb, var(--color-text) 86%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .calculator-ring-wrap {
  position: relative;
  width: fit-content;
  margin: 0 auto 0.85rem;
}

.tpl-cb-sustain-v1 .calculator-ring {
  width: 9.4rem;
  height: 9.4rem;
}

.tpl-cb-sustain-v1 .calculator-ring circle {
  fill: none;
  stroke-width: 8;
  stroke: color-mix(in srgb, var(--color-border) 72%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .calculator-ring .calculator-ring-value {
  stroke: var(--color-primary);
  stroke-linecap: round;
  stroke-dasharray: 339.3;
  stroke-dashoffset: 95;
  transform: rotate(-90deg);
  transform-origin: center;
}

.tpl-cb-sustain-v1 .calculator-ring-center {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-align: center;
  gap: 0.15rem;
}

.tpl-cb-sustain-v1 .calculator-ring-center strong {
  font-size: 2rem;
  line-height: 1;
  color: color-mix(in srgb, var(--color-text) 88%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .calculator-ring-center span {
  font-size: 0.78rem;
  color: color-mix(in srgb, var(--color-text) 64%, var(--ui-ink-muted-base));
}

.tpl-cb-sustain-v1 .calculator-bars {
  display: grid;
  gap: 0.65rem;
}

.tpl-cb-sustain-v1 .calculator-bar-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  margin-bottom: 0.24rem;
  font-size: 0.8rem;
}

.tpl-cb-sustain-v1 .calculator-bar-meta span {
  color: color-mix(in srgb, var(--color-text) 66%, var(--ui-ink-muted-base));
}

.tpl-cb-sustain-v1 .calculator-bar-meta strong {
  color: color-mix(in srgb, var(--color-text) 86%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .calculator-bar-track {
  height: 0.46rem;
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--color-bg) 76%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .calculator-bar-fill {
  display: block;
  height: 100%;
  width: 0;
  border-radius: inherit;
  transition: width 0.7s ease;
}

.tpl-cb-sustain-v1 .calculator-bar-fill-1 {
  background: var(--color-primary);
}

.tpl-cb-sustain-v1 .calculator-bar-fill-2 {
  background: color-mix(in srgb, var(--color-secondary) 78%, var(--color-success));
}

.tpl-cb-sustain-v1 .calculator-bar-fill-3 {
  background: color-mix(in srgb, var(--color-primary) 45%, var(--color-secondary));
}

.tpl-cb-sustain-v1 .eco-floating-card {
  position: absolute;
  border-radius: 16px;
  padding: 0.7rem 0.86rem;
  display: grid;
  gap: 0.14rem;
  border: 1px solid color-mix(in srgb, var(--color-border) 68%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-surface) 94%, var(--tpl-surface-solid));
  box-shadow: 0 12px 24px color-mix(in srgb, var(--ui-text) 14%, transparent);
}

.tpl-cb-sustain-v1 .eco-floating-card-top {
  left: -1.4rem;
  top: -1.2rem;
}

.tpl-cb-sustain-v1 .eco-floating-card-bottom {
  right: -1.3rem;
  bottom: -1.25rem;
}

.tpl-cb-sustain-v1 .eco-floating-card strong {
  font-size: 1rem;
  color: color-mix(in srgb, var(--color-text) 88%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .eco-floating-card span {
  font-size: 0.72rem;
  color: color-mix(in srgb, var(--color-text) 64%, var(--ui-ink-muted-base));
}

.tpl-cb-sustain-v1 .eco-band {
  padding: clamp(2.4rem, 6vw, 4.6rem) 0;
}

.tpl-cb-sustain-v1 .eco-band-soft {
  background: color-mix(in srgb, var(--color-bg) 90%, color-mix(in srgb, var(--tpl-surface-solid) 90%, var(--color-bg)));
  border-block: 1px solid color-mix(in srgb, var(--color-border) 62%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .eco-section-head {
  text-align: center;
  display: grid;
  justify-items: center;
  gap: 0.62rem;
  margin-bottom: clamp(1.1rem, 2.4vw, 2rem);
}

.tpl-cb-sustain-v1 .eco-section-head h2 {
  margin: 0;
  font-size: clamp(1.6rem, 3vw, 2.55rem);
  line-height: 1.16;
  color: color-mix(in srgb, var(--color-text) 88%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .eco-section-head p {
  margin: 0;
  max-width: 64ch;
  color: color-mix(in srgb, var(--color-text) 66%, var(--ui-ink-muted-base));
  font-size: 0.97rem;
  line-height: 1.66;
}

.tpl-cb-sustain-v1 .feature-grid {
  display: grid;
  gap: 0.85rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tpl-cb-sustain-v1 .feature-card {
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--color-border) 66%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-surface) 95%, var(--tpl-surface-solid));
  padding: 1rem;
  box-shadow: 0 12px 26px color-mix(in srgb, var(--ui-text) 12%, transparent);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.tpl-cb-sustain-v1 .feature-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 30px color-mix(in srgb, var(--ui-text) 16%, transparent);
}

.tpl-cb-sustain-v1 .feature-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.65rem;
  background: color-mix(in srgb, var(--color-primary) 14%, var(--tpl-surface-solid));
  color: var(--color-primary);
}

.tpl-cb-sustain-v1 .feature-icon svg {
  width: 1.24rem;
  height: 1.24rem;
}

.tpl-cb-sustain-v1 .feature-card h3 {
  margin: 0 0 0.34rem;
  font-size: 1rem;
  color: color-mix(in srgb, var(--color-text) 88%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .feature-card p {
  margin: 0;
  color: color-mix(in srgb, var(--color-text) 68%, var(--ui-ink-muted-base));
  line-height: 1.55;
  font-size: 0.89rem;
}

.tpl-cb-sustain-v1 .impact-grid {
  display: grid;
  gap: 0.8rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: clamp(1.1rem, 2.5vw, 2rem);
}

.tpl-cb-sustain-v1 .impact-card {
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--color-border) 66%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-surface) 95%, var(--tpl-surface-solid));
  padding: 0.86rem;
  text-align: center;
}

.tpl-cb-sustain-v1 .impact-number {
  font-size: clamp(1.28rem, 2.6vw, 1.8rem);
  font-weight: 800;
  color: color-mix(in srgb, var(--color-primary) 82%, var(--ui-accent-strong));
  line-height: 1;
}

.tpl-cb-sustain-v1 .impact-label {
  margin-top: 0.32rem;
  font-size: 0.77rem;
  color: color-mix(in srgb, var(--color-text) 62%, var(--ui-ink-muted-base));
}

.tpl-cb-sustain-v1 .project-head {
  text-align: center;
  margin-bottom: 0.75rem;
}

.tpl-cb-sustain-v1 .project-head h3 {
  margin: 0;
  font-size: 1.15rem;
  color: color-mix(in srgb, var(--color-text) 86%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .project-grid {
  display: grid;
  gap: 0.8rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tpl-cb-sustain-v1 .project-card {
  overflow: hidden;
}

.tpl-cb-sustain-v1 .project-media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.tpl-cb-sustain-v1 .project-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.tpl-cb-sustain-v1 .project-card:hover .project-media img {
  transform: scale(1.04);
}

.tpl-cb-sustain-v1 .project-copy {
  padding: 0.84rem 0.9rem 0.96rem;
}

.tpl-cb-sustain-v1 .project-copy > span {
  color: color-mix(in srgb, var(--color-primary) 74%, var(--ui-secondary-strong));
  font-size: 0.75rem;
  font-weight: 700;
}

.tpl-cb-sustain-v1 .project-copy h4 {
  margin: 0.24rem 0 0.45rem;
  font-size: 0.97rem;
  color: color-mix(in srgb, var(--color-text) 88%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .project-meta {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  align-items: center;
}

.tpl-cb-sustain-v1 .project-meta small {
  color: color-mix(in srgb, var(--color-text) 62%, var(--ui-ink-muted-base));
  font-size: 0.74rem;
}

.tpl-cb-sustain-v1 .project-meta strong {
  color: color-mix(in srgb, var(--color-secondary) 78%, var(--color-success));
  font-size: 0.79rem;
}

.tpl-cb-sustain-v1 .cert-grid {
  display: grid;
  gap: 0.72rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tpl-cb-sustain-v1 .cert-badge {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.75rem;
  align-items: start;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--color-border) 66%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-surface) 95%, var(--tpl-surface-solid));
  padding: 0.9rem;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ui-text) 12%, transparent);
}

.tpl-cb-sustain-v1 .cert-mark {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.82rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--tpl-surface-solid);
  background: var(--theme-accent-fill);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.tpl-cb-sustain-v1 .cert-badge h4 {
  margin: 0;
  font-size: 0.93rem;
  color: color-mix(in srgb, var(--color-text) 88%, var(--ui-ink-deep));
}

.tpl-cb-sustain-v1 .cert-badge p {
  margin: 0.28rem 0 0;
  font-size: 0.82rem;
  line-height: 1.52;
  color: color-mix(in srgb, var(--color-text) 64%, var(--ui-ink-muted-base));
}

.tpl-cb-sustain-v1 .leaf-card {
  margin-top: clamp(1rem, 2.2vw, 1.6rem);
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--color-border) 66%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--color-surface) 96%, var(--tpl-surface-solid));
  text-align: center;
  padding: clamp(1rem, 2vw, 1.4rem);
  box-shadow: 0 14px 30px color-mix(in srgb, var(--ui-text) 12%, transparent);
}

.tpl-cb-sustain-v1 .leaf-card h3 {
  margin: 0;
  color: color-mix(in srgb, var(--color-text) 86%, var(--ui-ink-deep));
  font-size: clamp(1.14rem, 2vw, 1.46rem);
}

.tpl-cb-sustain-v1 .leaf-card p {
  margin: 0.45rem auto 0;
  max-width: 60ch;
  color: color-mix(in srgb, var(--color-text) 66%, var(--ui-ink-muted-base));
  line-height: 1.62;
  font-size: 0.91rem;
}

.tpl-cb-sustain-v1 .eco-cta-band {
  position: relative;
  overflow: hidden;
  background: color-mix(in srgb, var(--color-primary) 90%, var(--ui-ink-deep));
  border-top: none;
  border-bottom: none;
  padding: clamp(2.1rem, 5vw, 3.5rem) 0;
  margin-top: clamp(1.2rem, 2.4vw, 2.2rem);
}

.tpl-cb-sustain-v1 .eco-cta-shell {
  text-align: center;
  display: grid;
  justify-items: center;
  gap: 0.7rem;
}

.tpl-cb-sustain-v1 .eco-cta-shell h2 {
  margin: 0;
  color: var(--tpl-surface-solid);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  line-height: 1.16;
}

.tpl-cb-sustain-v1 .eco-cta-shell p {
  margin: 0;
  max-width: 58ch;
  color: color-mix(in srgb, var(--tpl-surface-solid) 78%, transparent);
  line-height: 1.62;
}

@media (max-width: 1060px) {
  .tpl-cb-sustain-v1 .eco-hero-grid,
  .tpl-cb-sustain-v1 .feature-grid,
  .tpl-cb-sustain-v1 .project-grid,
  .tpl-cb-sustain-v1 .cert-grid,
  .tpl-cb-sustain-v1 .impact-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {

  .tpl-cb-sustain-v1 .eco-hero-grid {
    grid-template-columns: 1fr;
  }

  .tpl-cb-sustain-v1 .eco-floating-card {
    position: static;
    margin-top: 0.65rem;
  }

  .tpl-cb-sustain-v1 .eco-floating-card-top,
  .tpl-cb-sustain-v1 .eco-floating-card-bottom {
    left: auto;
    top: auto;
    right: auto;
    bottom: auto;
  }
}

@media (max-width: 640px) {
  .tpl-cb-sustain-v1 .feature-grid,
  .tpl-cb-sustain-v1 .project-grid,
  .tpl-cb-sustain-v1 .cert-grid,
  .tpl-cb-sustain-v1 .impact-grid {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .tpl-cb-sustain-v1 .project-media img,
  .tpl-cb-sustain-v1 .feature-card,
  .tpl-cb-sustain-v1 .btn-primary,
  .tpl-cb-sustain-v1 .btn-secondary,
  .tpl-cb-sustain-v1 .calculator-bar-fill {
    transition: none !important;
    transform: none !important;
  }
}

/* Storefront cleanup overrides */
.tpl-cb-sustain-v1 {
  --tpl-shell-bg: var(--color-bg);
  --tpl-card-shadow: 0 18px 40px color-mix(in srgb, var(--ui-text) 10%, transparent);
  --tpl-card-shadow-hover: 0 24px 52px color-mix(in srgb, var(--ui-text) 14%, transparent);
  --tpl-primary-strong: color-mix(in srgb, var(--color-primary) 84%, var(--color-text));
  --tpl-cream-shadow: 0 14px 28px color-mix(in srgb, var(--color-primary) 20%, transparent), 0 6px 12px color-mix(in srgb, var(--ui-text) 10%, transparent);
  --tpl-cream-shadow-hover: 0 18px 34px color-mix(in srgb, var(--color-secondary) 22%, transparent), 0 8px 16px color-mix(in srgb, var(--ui-text) 12%, transparent);
  --tpl-main-bleed: linear-gradient(
      180deg,
      color-mix(in srgb, var(--color-surface) 94%, var(--color-bg)) 0%,
      color-mix(in srgb, var(--tpl-surface-solid) 0%, transparent) 58%
    );
}

.tpl-cb-sustain-v1 .home-react-content,
.tpl-cb-sustain-v1 .stores-band,
.tpl-cb-sustain-v1 .categories-band-all,
.tpl-cb-sustain-v1 .categories-band-categories,
.tpl-cb-sustain-v1 .coupons-react-content,
.tpl-cb-sustain-v1 .blogs-react-content,
.tpl-cb-sustain-v1 .blogs-react-hero,
.tpl-cb-sustain-v1 .coupons-react-hero,
.tpl-cb-sustain-v1 .store-rk-breadcrumb-band,
.tpl-cb-sustain-v1 .store-rk-header-band,
.tpl-cb-sustain-v1 .store-rk-content-band,
.tpl-cb-sustain-v1 .blog-detail-react-hero,
.tpl-cb-sustain-v1 .blog-detail-react-content,
.tpl-cb-sustain-v1 .static-page-react-page {
  background: transparent;
}

.tpl-cb-sustain-v1 .sustain-panel,
.tpl-cb-sustain-v1 .sustain-card,
.tpl-cb-sustain-v1 .sustain-toolbar,
.tpl-cb-sustain-v1 .page-empty-state,
.tpl-cb-sustain-v1 .home-react-section,
.tpl-cb-sustain-v1 .home-react-hero-shell,
.tpl-cb-sustain-v1 .categories-band-categories,
.tpl-cb-sustain-v1 .categories-band-all,
.tpl-cb-sustain-v1 .category-detail-hero-card {
  background: color-mix(in srgb, var(--color-surface) 96%, var(--tpl-surface-solid));
  border: none;
  box-shadow: var(--tpl-card-shadow);
}

.tpl-cb-sustain-v1 .sustain-card:hover,
.tpl-cb-sustain-v1 .home-react-section:hover,
.tpl-cb-sustain-v1 .category-visual-card:hover,
.tpl-cb-sustain-v1 .merchant-compact-card:hover,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card:hover {
  transform: none;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .home-react-hero {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-primary) 5%, var(--color-bg)),
    color-mix(in srgb, var(--color-surface) 18%, var(--color-bg))
  );
  border-bottom: none;
}

.tpl-cb-sustain-v1 .home-react-hero-badge,
.tpl-cb-sustain-v1 .home-react-hero-proof-pill {
  background: color-mix(in srgb, var(--color-primary) 10%, var(--tpl-surface-solid));
  border: 1px solid color-mix(in srgb, var(--color-primary) 22%, var(--tpl-surface-solid));
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .home-react-hero-proof-card,
.tpl-cb-sustain-v1 .home-react-hero-metric-card,
.tpl-cb-sustain-v1 .home-react-hero-proof-item {
  background: color-mix(in srgb, var(--color-surface) 94%, var(--tpl-surface-solid));
  border: none;
  box-shadow: 0 16px 34px color-mix(in srgb, var(--ui-text) 10%, transparent);
}

.tpl-cb-sustain-v1 .home-react-section,
.tpl-cb-sustain-v1 .categories-band-categories,
.tpl-cb-sustain-v1 .categories-band-all {
  border-radius: 20px;
}

.tpl-cb-sustain-v1 .home-react-section {
  border: none;
  box-shadow: none;
  background: transparent;
}

.tpl-cb-sustain-v1 .home-react-band-tone-primary {
  background: var(--home-band-bg-primary, transparent);
}

.tpl-cb-sustain-v1 .home-react-band-tone-secondary {
  background: var(--home-band-bg-secondary, transparent);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-band {
  margin-bottom: 0;
}

.tpl-cb-sustain-v1 #stores-fragment .stores-band-categories,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-featured,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-all {
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.tpl-cb-sustain-v1 #stores-fragment .stores-rakuten-all-toolbar {
  border-radius: 10px;
  border: none;
  background: var(--tpl-surface-solid);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ui-text) 8%, transparent);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-filter-categories,
.tpl-cb-sustain-v1 #stores-fragment .stores-alpha-panel,
.tpl-cb-sustain-v1 .categories-react-search-status {
  border: none;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.tpl-cb-sustain-v1 .merchant-compact-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  column-gap: 0.9rem;
  align-items: center;
  min-height: 0;
  padding: 0.48rem 0.18rem 0.48rem 0;
  overflow: visible;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  box-shadow: none;
  transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.tpl-cb-sustain-v1 .merchant-compact-card:hover,
.tpl-cb-sustain-v1 .merchant-compact-card:focus-within {
  transform: translateY(-2px);
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .merchant-compact-logo-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
  padding: 0;
  text-decoration: none;
  background: transparent;
}

.tpl-cb-sustain-v1 .merchant-compact-logo-wrap {
  display: grid;
  place-items: center;
  width: 4.2rem;
  height: 4.2rem;
  min-height: 4.2rem;
  overflow: hidden;
  border-radius: 8px;
  background: var(--tpl-surface-solid);
  border: none;
  box-shadow: 0 8px 18px color-mix(in srgb, var(--ui-text) 10%, transparent);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.tpl-cb-sustain-v1 .merchant-compact-logo {
  width: 3rem;
  height: 3rem;
  object-fit: contain;
  transition: transform 0.18s ease;
}

.tpl-cb-sustain-v1 .merchant-compact-logo-fallback {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--tpl-primary-strong);
}

.tpl-cb-sustain-v1 .merchant-compact-side {
  position: relative;
  display: grid;
  align-items: center;
  justify-items: start;
  min-height: 3.15rem;
  padding: 0.1rem 0.35rem 0.1rem 0;
  min-width: 0;
}

.tpl-cb-sustain-v1 .merchant-compact-details,
.tpl-cb-sustain-v1 .merchant-compact-shop {
  grid-area: 1 / 1;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.tpl-cb-sustain-v1 .merchant-compact-details {
  display: grid;
  gap: 0.18rem;
  min-width: 0;
  justify-items: stretch;
  text-align: left;
  opacity: 1;
  transform: none;
}

.tpl-cb-sustain-v1 .merchant-compact-name {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.25;
  text-align: left;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
}

.tpl-cb-sustain-v1 .merchant-compact-rate {
  color: color-mix(in srgb, var(--color-primary) 82%, var(--tpl-text-strong));
  font-size: 0.88rem;
  font-weight: 800;
  text-align: left;
}

.tpl-cb-sustain-v1 .merchant-compact-shop {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  opacity: 0;
  transform: translateX(10px);
  pointer-events: none;
}

.tpl-cb-sustain-v1 .merchant-compact-cta {
  min-width: 8rem;
  justify-content: center;
}

.tpl-cb-sustain-v1 .merchant-compact-card:hover .merchant-compact-details,
.tpl-cb-sustain-v1 .merchant-compact-card:focus-within .merchant-compact-details {
  opacity: 0;
  transform: translateX(-10px);
  pointer-events: none;
}

.tpl-cb-sustain-v1 .merchant-compact-card:hover .merchant-compact-logo-wrap,
.tpl-cb-sustain-v1 .merchant-compact-card:focus-within .merchant-compact-logo-wrap {
  transform: none;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ui-text) 12%, transparent);
}

.tpl-cb-sustain-v1 .merchant-compact-card:hover .merchant-compact-logo,
.tpl-cb-sustain-v1 .merchant-compact-card:focus-within .merchant-compact-logo {
  transform: scale(1.04);
}

.tpl-cb-sustain-v1 .merchant-compact-card:hover .merchant-compact-shop,
.tpl-cb-sustain-v1 .merchant-compact-card:focus-within .merchant-compact-shop {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

.tpl-cb-sustain-v1 .category-visual-card,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card {
  position: relative;
  overflow: visible;
  gap: 0.72rem;
  padding: 0;
  border-radius: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .category-visual-media {
  min-height: 7.3rem;
  border-radius: 10px;
  background: var(--tpl-surface-solid);
  box-shadow: 0 10px 22px color-mix(in srgb, var(--ui-text) 8%, transparent);
  transition: box-shadow 0.2s ease, background 0.2s ease;
}

.tpl-cb-sustain-v1 .category-visual-media-generic {
  background: var(--tpl-surface-solid);
}

.tpl-cb-sustain-v1 .category-visual-image {
  border-radius: inherit;
}

.tpl-cb-sustain-v1 .category-visual-icon-wrap,
.tpl-cb-sustain-v1 .category-visual-fallback,
.tpl-cb-sustain-v1 .category-visual-glyph {
  background: color-mix(in srgb, var(--color-bg) 72%, var(--tpl-surface-solid));
  border: none;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .category-visual-glyph {
  min-width: 4.2rem;
  min-height: 4.2rem;
  border-radius: 8px;
  color: var(--tpl-primary-strong);
  font-size: 0.96rem;
  font-weight: 800;
  text-transform: uppercase;
}

.tpl-cb-sustain-v1 .category-visual-card:hover,
.tpl-cb-sustain-v1 .category-visual-card:focus-visible,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card:hover,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card:focus-visible,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card.is-active {
  background: transparent;
}

.tpl-cb-sustain-v1 .category-visual-card:hover .category-visual-media,
.tpl-cb-sustain-v1 .category-visual-card:focus-visible .category-visual-media,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card:hover .category-visual-media,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card:focus-visible .category-visual-media,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card.is-active .category-visual-media {
  transform: none;
  box-shadow: 0 12px 26px color-mix(in srgb, var(--ui-text) 12%, transparent);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card.is-active .category-visual-media {
  background: color-mix(in srgb, var(--color-primary) 5%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .category-visual-card:hover .category-visual-image,
.tpl-cb-sustain-v1 .category-visual-card:focus-visible .category-visual-image,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card:hover .category-visual-image,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card:focus-visible .category-visual-image,
.tpl-cb-sustain-v1 #stores-fragment .stores-category-select-card.is-active .category-visual-image {
  transform: scale(1.04);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-filter-block,
.tpl-cb-sustain-v1 #stores-fragment .stores-alpha-panel {
  padding: 0.9rem;
  border-radius: 10px;
  border: none;
  background: var(--tpl-surface-solid);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ui-text) 8%, transparent);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-rakuten-filter-chip {
  min-height: 2rem;
  height: auto;
  padding: 0.38rem 0.65rem;
  border-radius: 6px;
  border-color: color-mix(in srgb, var(--color-border) 84%, var(--tpl-surface-solid));
  background: var(--tpl-surface-solid);
}

.tpl-cb-sustain-v1 #stores-fragment .stores-rakuten-filter-chip.is-active {
  border-color: color-mix(in srgb, var(--theme-primary) 24%, var(--tpl-surface-solid));
  background: color-mix(in srgb, var(--theme-primary) 6%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 #stores-fragment .stores-results-head p,
.tpl-cb-sustain-v1 #stores-fragment .stores-alpha-label {
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .category-detail-hero-card {
  backdrop-filter: none;
}

.tpl-cb-sustain-v1 .category-detail-hero-meta span,
.tpl-cb-sustain-v1 .stores-band-head p,
.tpl-cb-sustain-v1 .home-react-section-head p {
  color: var(--tpl-text-muted);
}

.tpl-cb-sustain-v1 .page-empty-state {
  border-style: dashed;
  border-color: color-mix(in srgb, var(--color-border) 66%, var(--tpl-surface-solid));
}

@media (hover: none), (pointer: coarse), (max-width: 820px) {
  .tpl-cb-sustain-v1 .merchant-compact-card {
    grid-template-columns: auto minmax(0, 1fr);
    column-gap: 0.7rem;
    padding: 0.52rem 0.12rem 0.52rem 0;
  }

  .tpl-cb-sustain-v1 .merchant-compact-logo-wrap {
    width: 3.85rem;
    height: 3.85rem;
    min-height: 3.85rem;
  }

  .tpl-cb-sustain-v1 .merchant-compact-logo,
  .tpl-cb-sustain-v1 .merchant-compact-logo-fallback {
    width: 2.7rem;
    height: 2.7rem;
  }

  .tpl-cb-sustain-v1 .merchant-compact-side {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.58rem;
    min-height: 0;
    padding-right: 0.12rem;
  }

  .tpl-cb-sustain-v1 .merchant-compact-details,
  .tpl-cb-sustain-v1 .merchant-compact-shop {
    grid-area: auto;
    transition: none;
  }

  .tpl-cb-sustain-v1 .merchant-compact-details {
    opacity: 1;
    transform: none;
  }

  .tpl-cb-sustain-v1 .merchant-compact-shop {
    display: flex;
    opacity: 1;
    transform: none;
    pointer-events: auto;
  }

}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-rk-breadcrumb-band,
.tpl-cb-sustain-v1 .sustain-store-detail-page .store-rk-header-band {
  margin-bottom: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-rk-breadcrumb-band {
  padding: 0.02rem 0 0;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-rk-header-band {
  padding: 0 0 0.12rem;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page {
  gap: 0.16rem;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-rk-content-band {
  padding-top: 0;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-detail-left .store-panel,
.tpl-cb-sustain-v1 .sustain-store-detail-page .store-detail-right .store-panel,
.tpl-cb-sustain-v1 .sustain-store-detail-page .compact-hub-pathways,
.tpl-cb-sustain-v1 .sustain-store-detail-page .page-empty-state {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .compact-hub-pathways-item {
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-detail-about,
.tpl-cb-sustain-v1 .sustain-store-detail-page .store-detail-related {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-detail-shop-card {
  padding: 0;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-detail-coupons .coupon-panel-list {
  display: grid;
  gap: 0.95rem;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-detail-coupons .coupons-directory-card {
  border-radius: 1.15rem;
  background: color-mix(in srgb, var(--tpl-surface-0) 96%, var(--tpl-surface-solid));
  box-shadow: 0 14px 32px color-mix(in srgb, var(--ui-text) 8%, transparent);
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-detail-coupons .coupons-directory-card:hover {
  box-shadow: 0 18px 36px color-mix(in srgb, var(--ui-text) 10%, transparent);
}

.tpl-cb-sustain-v1 .store-share-modal.hidden {
  display: none;
}

.tpl-cb-sustain-v1 .store-share-modal {
  position: fixed;
  inset: 0;
  z-index: 1400;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Final storefront gradient reset */
.tpl-cb-sustain-v1 .home-react-hero,
.tpl-cb-sustain-v1 .stores-band,
.tpl-cb-sustain-v1 .categories-band-categories,
.tpl-cb-sustain-v1 .categories-band-all,
.tpl-cb-sustain-v1 .coupons-bottom-band {
  background: transparent;
}

.tpl-cb-sustain-v1 .home-react-hero-shell {
  background: transparent;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .coupons-react-hero-shell,
.tpl-cb-sustain-v1 .blogs-react-hero-shell,
.tpl-cb-sustain-v1 .auth-react-shell,
.tpl-cb-sustain-v1 .auth-react-brand,
.tpl-cb-sustain-v1 .sustain-impact-card,
.tpl-cb-sustain-v1 .leaf-card {
  background: color-mix(in srgb, var(--color-surface) 96%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .coupons-react-hero,
.tpl-cb-sustain-v1 .blogs-react-hero,
.tpl-cb-sustain-v1 .blog-detail-react-hero,
.tpl-cb-sustain-v1 .blog-detail-react-content,
.tpl-cb-sustain-v1 .store-rk-breadcrumb-band,
.tpl-cb-sustain-v1 .store-rk-header-band,
.tpl-cb-sustain-v1 .store-rk-content-band {
  background: transparent;
}

.tpl-cb-sustain-v1 .home-react-band-tone-primary,
.tpl-cb-sustain-v1 .home-react-band-tone-secondary {
  background: transparent;
}

.tpl-cb-sustain-v1 #stores-fragment .stores-band-categories,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-featured,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-all,
.tpl-cb-sustain-v1 .categories-band-categories,
.tpl-cb-sustain-v1 .categories-band-all {
  background: transparent;
  box-shadow: none;
}

.tpl-cb-sustain-v1 .blog-detail-react-toc,
.tpl-cb-sustain-v1 .blog-detail-react-merchant,
.tpl-cb-sustain-v1 .blog-detail-react-article,
.tpl-cb-sustain-v1 .page-empty-state {
  background: color-mix(in srgb, var(--color-surface) 96%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .blog-detail-react-hero-overlay {
  background: color-mix(in srgb, var(--ui-ink-deep) 52%, transparent);
}

.tpl-cb-sustain-v1 .sustain-hero-title-accent,
.tpl-cb-sustain-v1 .gradient-text {
  background: none;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  color: color-mix(in srgb, var(--color-primary) 84%, var(--color-text));
}

.tpl-cb-sustain-v1 .sustain-impact-icon,
.tpl-cb-sustain-v1 .sustain-impact-pill,
.tpl-cb-sustain-v1 .btn-primary,
.tpl-cb-sustain-v1 .landing-cta-primary,
.tpl-cb-sustain-v1 .merchant-button,
.tpl-cb-sustain-v1 .shop-now-button,
.tpl-cb-sustain-v1 .activate-cashback-button,
.tpl-cb-sustain-v1 .coupons-react-row-cta,
.tpl-cb-sustain-v1 .coupon-code-button,
.tpl-cb-sustain-v1 .site-register-button,
.tpl-cb-sustain-v1 .auth-react-submit,
.tpl-cb-sustain-v1 .coupons-react-search-submit,
.tpl-cb-sustain-v1 .blogs-react-hero-search button {
  background: var(--theme-accent-fill);
  background-image: none;
}

.tpl-cb-sustain-v1 .eco-cta-band {
  background: color-mix(in srgb, var(--color-primary) 90%, var(--ui-ink-deep));
}

/* Final storefront brand palette unification */
.tpl-cb-sustain-v1 .panel,
.tpl-cb-sustain-v1 .merchant-card,
.tpl-cb-sustain-v1 .merchant-row,
.tpl-cb-sustain-v1 .coupon-card,
.tpl-cb-sustain-v1 .blogs-react-featured-card,
.tpl-cb-sustain-v1 .blogs-react-grid .blogs-react-tile,
.tpl-cb-sustain-v1 .blogs-react-row-card,
.tpl-cb-sustain-v1 .store-panel,
.tpl-cb-sustain-v1 .page-empty-state,
.tpl-cb-sustain-v1 .page-cta-panel,
.tpl-cb-sustain-v1 .auth-react-card,
.tpl-cb-sustain-v1 .account-react-section,
.tpl-cb-sustain-v1 .static-page-react-content,
.tpl-cb-sustain-v1 .categories-all-card,
.tpl-cb-sustain-v1 .stores-all-row,
.tpl-cb-sustain-v1 .coupons-react-row,
.tpl-cb-sustain-v1 .blog-detail-react-merchant,
.tpl-cb-sustain-v1 .blog-detail-react-cta,
.tpl-cb-sustain-v1 .blog-detail-react-related,
.tpl-cb-sustain-v1 .blog-detail-react-toc {
  background: color-mix(in srgb, var(--color-surface) 96%, var(--tpl-surface-solid)) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .sustain-store-detail-page .store-panel.store-detail-about,
.tpl-cb-sustain-v1 .sustain-store-detail-page .store-panel.store-detail-related {
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.tpl-cb-sustain-v1 .blog-detail-react-article {
  padding: clamp(1rem, 2vw, 1.5rem);
}

.tpl-cb-sustain-v1 .home-react-hero {
  background: transparent !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .sustain-site-main {
  background: var(--tpl-shell-bg) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .home-react-hero-shell,
.tpl-cb-sustain-v1 .coupons-react-hero-shell,
.tpl-cb-sustain-v1 .blogs-react-hero-shell,
.tpl-cb-sustain-v1 .auth-react-shell {
  background: color-mix(in srgb, var(--color-primary) 5%, var(--color-surface)) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .home-react-hero-shell {
  background: transparent !important;
}

.tpl-cb-sustain-v1 .home-react-hero {
  background: var(--home-band-bg-primary, transparent) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .account-react-hero {
  background: color-mix(in srgb, var(--color-primary) 5%, var(--color-surface)) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .auth-react-brand {
  background: color-mix(in srgb, var(--color-surface) 97%, var(--tpl-surface-solid)) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .home-react-band-tone-primary {
  background: var(--home-band-bg-primary, transparent) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .home-react-band-tone-secondary {
  background: var(--home-band-bg-secondary, transparent) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 #stores-fragment .stores-band-categories,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-featured,
.tpl-cb-sustain-v1 #stores-fragment .stores-band-all,
.tpl-cb-sustain-v1 .categories-band-categories,
.tpl-cb-sustain-v1 .categories-band-all,
.tpl-cb-sustain-v1 .static-page-react-shell {
  background: transparent !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .site-promo-bar {
  background: var(--theme-promo-fill) !important;
  background-image: none !important;
}

.tpl-cb-sustain-v1 .landing-cta-secondary,
.tpl-cb-sustain-v1 .button-outline,
.tpl-cb-sustain-v1 .site-login-link,
.tpl-cb-sustain-v1 .auth-react-google {
  background: color-mix(in srgb, var(--color-secondary) 10%, var(--tpl-surface-solid)) !important;
  background-image: none !important;
  border-color: color-mix(in srgb, var(--color-secondary) 22%, var(--tpl-surface-solid)) !important;
  color: var(--tpl-secondary-strong) !important;
}

.tpl-cb-sustain-v1 .account-react-link.active,
.tpl-cb-sustain-v1 .account-react-link.is-active {
  border-color: color-mix(in srgb, var(--color-primary) 42%, var(--tpl-surface-solid)) !important;
  background: var(--tpl-accent-soft) !important;
  background-image: none !important;
  color: var(--tpl-primary-strong) !important;
}

.tpl-cb-sustain-v1 .landing-pro-conversion {
  --landing-surface-a: color-mix(in srgb, var(--color-primary) 7%, var(--tpl-surface-solid));
  --landing-surface-b: color-mix(in srgb, var(--color-secondary) 8%, var(--tpl-surface-solid));
  --landing-panel: color-mix(in srgb, var(--tpl-surface-solid) 82%, var(--landing-surface-a));
  --landing-panel-strong: color-mix(in srgb, var(--tpl-surface-solid) 70%, var(--landing-surface-b));
  --landing-border: color-mix(in srgb, var(--color-text) 10%, var(--tpl-surface-solid));
  --landing-border-strong: color-mix(in srgb, var(--color-primary) 18%, var(--tpl-surface-solid));
  --landing-text: color-mix(in srgb, var(--color-text) 92%, var(--ui-ink-deep));
  --landing-muted: color-mix(in srgb, var(--color-text) 70%, var(--tpl-surface-solid));
  --landing-shadow: 0 28px 54px color-mix(in srgb, var(--color-text) 9%, transparent);
  color: var(--landing-text);
}

.tpl-cb-sustain-v1 .landing-pro-hero,
.tpl-cb-sustain-v1 .landing-pro-section {
  position: relative;
  overflow: clip;
}

.tpl-cb-sustain-v1 .landing-pro-hero {
  padding: clamp(2.6rem, 5vw, 4.4rem) 0 clamp(3.6rem, 7vw, 5.8rem);
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--color-primary) 14%, transparent) 0, transparent 42%),
    linear-gradient(180deg, var(--tpl-header-bg) 0%, var(--landing-surface-a) 12%, var(--landing-surface-a) 100%);
}

.tpl-cb-sustain-v1 .landing-pro-section {
  padding: clamp(3.4rem, 7vw, 5.6rem) 0;
}

.tpl-cb-sustain-v1 .landing-pro-tone-a {
  background: var(--landing-surface-a);
}

.tpl-cb-sustain-v1 .landing-pro-tone-b {
  background:
    radial-gradient(circle at right top, color-mix(in srgb, var(--color-secondary) 16%, transparent) 0, transparent 38%),
    var(--landing-surface-b);
}

.tpl-cb-sustain-v1 .landing-pro-hero-grid,
.tpl-cb-sustain-v1 .landing-pro-bonus-grid,
.tpl-cb-sustain-v1 .landing-pro-trust-layout,
.tpl-cb-sustain-v1 .landing-pro-final-panel {
  display: grid;
  gap: clamp(1.4rem, 3vw, 2.6rem);
}

.tpl-cb-sustain-v1 .landing-pro-hero-grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  align-items: start;
}

.tpl-cb-sustain-v1 .landing-pro-hero-copy {
  display: grid;
  gap: 1.2rem;
  padding-top: clamp(0.4rem, 1.2vw, 1rem);
}

.tpl-cb-sustain-v1 .landing-pro-kicker,
.tpl-cb-sustain-v1 .landing-pro-section-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 2rem;
  padding: 0.38rem 0.78rem;
  border: 1px solid color-mix(in srgb, var(--color-primary) 22%, var(--tpl-surface-solid));
  border-radius: 999px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 86%, var(--color-primary) 14%);
  color: var(--tpl-primary-strong);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

.tpl-cb-sustain-v1 .landing-pro-title {
  max-width: 11ch;
  margin: 0;
  color: var(--landing-text);
  font-size: clamp(3rem, 7vw, 5.8rem);
  line-height: 0.96;
  letter-spacing: -0.055em;
  text-wrap: balance;
}

.tpl-cb-sustain-v1 .landing-pro-subtitle,
.tpl-cb-sustain-v1 .landing-pro-section-head p,
.tpl-cb-sustain-v1 .landing-pro-stage-head p,
.tpl-cb-sustain-v1 .landing-pro-bonus-panel p,
.tpl-cb-sustain-v1 .landing-pro-trust-copy p,
.tpl-cb-sustain-v1 .landing-pro-final-copy p {
  max-width: 60ch;
  margin: 0;
  color: var(--landing-muted);
  font-size: clamp(1rem, 1.45vw, 1.14rem);
  line-height: 1.7;
}

.tpl-cb-sustain-v1 .landing-pro-actions,
.tpl-cb-sustain-v1 .landing-pro-final-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  align-items: center;
}

.tpl-cb-sustain-v1 .landing-pro-primary-action,
.tpl-cb-sustain-v1 .landing-pro-secondary-action,
.tpl-cb-sustain-v1 .landing-pro-inline-cta,
.tpl-cb-sustain-v1 .landing-pro-offer-link {
  text-decoration: none;
}

.tpl-cb-sustain-v1 .landing-pro-primary-action {
  padding-inline: 1.35rem;
}

.tpl-cb-sustain-v1 .landing-pro-secondary-action {
  padding-inline: 1.2rem;
}

.tpl-cb-sustain-v1 .landing-pro-trending {
  display: grid;
  gap: 0.8rem;
}

.tpl-cb-sustain-v1 .landing-pro-trending-label {
  color: var(--landing-muted);
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tpl-cb-sustain-v1 .landing-pro-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
}

.tpl-cb-sustain-v1 .landing-pro-chip {
  display: inline-flex;
  align-items: center;
  min-height: 2.3rem;
  padding: 0.48rem 0.88rem;
  border: 1px solid color-mix(in srgb, var(--color-secondary) 18%, var(--tpl-surface-solid));
  border-radius: 999px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 76%, var(--landing-surface-b));
  color: var(--landing-text);
  font-size: 0.92rem;
  font-weight: 600;
}

.tpl-cb-sustain-v1 .landing-pro-proof-list {
  display: grid;
  gap: 0.78rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tpl-cb-sustain-v1 .landing-pro-proof-list li {
  display: inline-flex;
  align-items: center;
  gap: 0.72rem;
  color: var(--landing-text);
  font-weight: 600;
}

.tpl-cb-sustain-v1 .landing-pro-proof-dot {
  width: 0.72rem;
  height: 0.72rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--color-primary) 12%, transparent);
}

.tpl-cb-sustain-v1 .landing-pro-stage {
  display: grid;
  gap: 1.15rem;
  padding: clamp(1.35rem, 2.6vw, 2rem);
  border: 1px solid var(--landing-border-strong);
  border-radius: 28px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--tpl-surface-solid) 86%, var(--landing-surface-a)) 0%, color-mix(in srgb, var(--tpl-surface-solid) 72%, var(--landing-surface-b)) 100%);
  box-shadow: var(--landing-shadow);
}

.tpl-cb-sustain-v1 .landing-pro-stage-head {
  display: grid;
  gap: 0.5rem;
}

.tpl-cb-sustain-v1 .landing-pro-stage-head h2,
.tpl-cb-sustain-v1 .landing-pro-bonus-panel h2,
.tpl-cb-sustain-v1 .landing-pro-steps-head h2,
.tpl-cb-sustain-v1 .landing-pro-section-head h2,
.tpl-cb-sustain-v1 .landing-pro-trust-copy h2,
.tpl-cb-sustain-v1 .landing-pro-final-copy h2 {
  margin: 0;
  color: var(--landing-text);
  font-size: clamp(1.95rem, 3vw, 3rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  text-wrap: balance;
}

.tpl-cb-sustain-v1 .landing-pro-offer-stack,
.tpl-cb-sustain-v1 .landing-pro-trust-grid,
.tpl-cb-sustain-v1 .landing-pro-faq-list {
  display: grid;
  gap: 0.9rem;
}

.tpl-cb-sustain-v1 .landing-pro-offer-card,
.tpl-cb-sustain-v1 .landing-pro-step-card,
.tpl-cb-sustain-v1 .landing-pro-brand-card,
.tpl-cb-sustain-v1 .landing-pro-trust-card,
.tpl-cb-sustain-v1 .landing-pro-faq-item {
  border: 1px solid var(--landing-border);
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

.tpl-cb-sustain-v1 .landing-pro-offer-card {
  display: grid;
  gap: 0.9rem;
  padding: 1rem 1rem 1.1rem;
  border-radius: 22px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 84%, transparent);
}

.tpl-cb-sustain-v1 .landing-pro-offer-card:hover,
.tpl-cb-sustain-v1 .landing-pro-step-card:hover,
.tpl-cb-sustain-v1 .landing-pro-brand-card:hover,
.tpl-cb-sustain-v1 .landing-pro-trust-card:hover,
.tpl-cb-sustain-v1 .landing-pro-faq-item:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--color-primary) 18%, var(--tpl-surface-solid));
  box-shadow: 0 18px 34px color-mix(in srgb, var(--color-text) 7%, transparent);
}

.tpl-cb-sustain-v1 .landing-pro-offer-tone-primary {
  background: color-mix(in srgb, var(--tpl-surface-solid) 80%, var(--color-primary) 20%);
}

.tpl-cb-sustain-v1 .landing-pro-offer-tone-secondary {
  background: color-mix(in srgb, var(--tpl-surface-solid) 80%, var(--color-secondary) 20%);
}

.tpl-cb-sustain-v1 .landing-pro-offer-tone-neutral {
  background: color-mix(in srgb, var(--tpl-surface-solid) 88%, var(--landing-surface-b));
}

.tpl-cb-sustain-v1 .landing-pro-offer-topline,
.tpl-cb-sustain-v1 .landing-pro-stage-callout {
  display: flex;
  gap: 0.9rem;
  align-items: center;
  justify-content: space-between;
}

.tpl-cb-sustain-v1 .landing-pro-offer-badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.8rem;
  padding: 0.28rem 0.64rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 74%, transparent);
  color: var(--landing-text);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tpl-cb-sustain-v1 .landing-pro-offer-value {
  color: var(--landing-text);
  font-size: 1.36rem;
  line-height: 1;
  letter-spacing: -0.04em;
}

.tpl-cb-sustain-v1 .landing-pro-offer-body {
  display: grid;
  gap: 0.28rem;
}

.tpl-cb-sustain-v1 .landing-pro-offer-body h3,
.tpl-cb-sustain-v1 .landing-pro-step-card h3,
.tpl-cb-sustain-v1 .landing-pro-trust-card h3 {
  margin: 0;
  color: var(--landing-text);
  font-size: 1.08rem;
  line-height: 1.25;
  letter-spacing: -0.02em;
}

.tpl-cb-sustain-v1 .landing-pro-offer-body p,
.tpl-cb-sustain-v1 .landing-pro-step-card p,
.tpl-cb-sustain-v1 .landing-pro-trust-card p,
.tpl-cb-sustain-v1 .landing-pro-stage-callout-copy p,
.tpl-cb-sustain-v1 .landing-pro-faq-item p {
  margin: 0;
  color: var(--landing-muted);
  font-size: 0.94rem;
  line-height: 1.65;
}

.tpl-cb-sustain-v1 .landing-pro-offer-link,
.tpl-cb-sustain-v1 .landing-pro-inline-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 2.5rem;
  padding: 0.55rem 0.95rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 72%, var(--color-primary) 28%);
  color: var(--tpl-primary-strong);
  font-size: 0.9rem;
  font-weight: 700;
}

.tpl-cb-sustain-v1 .landing-pro-stage-callout {
  padding: 1rem 1.05rem;
  border-radius: 20px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 72%, var(--landing-surface-a));
}

.tpl-cb-sustain-v1 .landing-pro-stage-callout-copy {
  display: grid;
  gap: 0.28rem;
}

.tpl-cb-sustain-v1 .landing-pro-stage-callout-title {
  color: var(--landing-text) !important;
  font-size: 1rem !important;
  font-weight: 700;
}

.tpl-cb-sustain-v1 .landing-pro-bonus-grid {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  align-items: start;
}

.tpl-cb-sustain-v1 .landing-pro-bonus-panel,
.tpl-cb-sustain-v1 .landing-pro-steps-shell,
.tpl-cb-sustain-v1 .landing-pro-final-panel {
  padding: clamp(1.35rem, 2.5vw, 2rem);
  border: 1px solid var(--landing-border);
  border-radius: 26px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 76%, transparent);
  box-shadow: 0 20px 40px color-mix(in srgb, var(--color-text) 6%, transparent);
}

.tpl-cb-sustain-v1 .landing-pro-bonus-panel,
.tpl-cb-sustain-v1 .landing-pro-steps-shell {
  display: grid;
  gap: 1rem;
}

.tpl-cb-sustain-v1 .landing-pro-steps-head,
.tpl-cb-sustain-v1 .landing-pro-section-head,
.tpl-cb-sustain-v1 .landing-pro-trust-copy,
.tpl-cb-sustain-v1 .landing-pro-final-copy {
  display: grid;
  gap: 0.72rem;
}

.tpl-cb-sustain-v1 .landing-pro-steps-grid,
.tpl-cb-sustain-v1 .landing-pro-brand-grid {
  display: grid;
  gap: 1rem;
}

.tpl-cb-sustain-v1 .landing-pro-steps-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tpl-cb-sustain-v1 .landing-pro-step-card {
  display: grid;
  gap: 0.72rem;
  min-height: 100%;
  padding: 1rem;
  border-radius: 22px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 72%, var(--landing-surface-b));
}

.tpl-cb-sustain-v1 .landing-pro-step-number,
.tpl-cb-sustain-v1 .landing-pro-trust-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 70%, var(--color-primary) 30%);
  color: var(--tpl-primary-strong);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.tpl-cb-sustain-v1 .landing-pro-section-head {
  max-width: 54rem;
  margin-bottom: 1.6rem;
}

.tpl-cb-sustain-v1 .landing-pro-brand-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.tpl-cb-sustain-v1 .landing-pro-brand-card {
  display: grid;
  gap: 0.9rem;
  justify-items: center;
  padding: 1rem 0.9rem;
  border-radius: 20px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 82%, transparent);
  text-align: center;
}

.tpl-cb-sustain-v1 .landing-pro-brand-mark {
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 5rem;
  padding: 0.9rem;
  border-radius: 16px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 90%, var(--landing-surface-a));
}

.tpl-cb-sustain-v1 .landing-pro-brand-mark img {
  max-width: 100%;
  max-height: 2.5rem;
  object-fit: contain;
}

.tpl-cb-sustain-v1 .landing-pro-brand-card span {
  color: var(--landing-text);
  font-size: 0.92rem;
  font-weight: 700;
}

.tpl-cb-sustain-v1 .landing-pro-trust-layout {
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  align-items: start;
}

.tpl-cb-sustain-v1 .landing-pro-trust-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tpl-cb-sustain-v1 .landing-pro-trust-card {
  display: grid;
  gap: 0.72rem;
  padding: 1.1rem;
  border-radius: 22px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 78%, transparent);
}

.tpl-cb-sustain-v1 .landing-pro-trust-tone-primary {
  background: color-mix(in srgb, var(--tpl-surface-solid) 72%, var(--color-primary) 18%);
}

.tpl-cb-sustain-v1 .landing-pro-trust-tone-secondary {
  background: color-mix(in srgb, var(--tpl-surface-solid) 72%, var(--color-secondary) 18%);
}

.tpl-cb-sustain-v1 .landing-pro-trust-tone-emerald {
  background: color-mix(in srgb, var(--tpl-surface-solid) 72%, var(--color-success) 18%);
}

.tpl-cb-sustain-v1 .landing-pro-trust-tone-amber {
  background: color-mix(in srgb, var(--tpl-surface-solid) 72%, color-mix(in srgb, var(--color-warning, #c78e34) 70%, var(--color-primary)));
}

.tpl-cb-sustain-v1 .landing-pro-faq-head {
  margin-bottom: 1.25rem;
}

.tpl-cb-sustain-v1 .landing-pro-faq-item {
  padding: 0;
  border-radius: 20px;
  background: color-mix(in srgb, var(--tpl-surface-solid) 82%, transparent);
}

.tpl-cb-sustain-v1 .landing-pro-faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.15rem 1.2rem;
  cursor: pointer;
  color: var(--landing-text);
  font-size: 1rem;
  font-weight: 700;
  list-style: none;
}

.tpl-cb-sustain-v1 .landing-pro-faq-item summary::-webkit-details-marker {
  display: none;
}

.tpl-cb-sustain-v1 .landing-pro-faq-item p {
  padding: 0 1.2rem 1.15rem;
}

.tpl-cb-sustain-v1 .landing-pro-faq-toggle {
  position: relative;
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

.tpl-cb-sustain-v1 .landing-pro-faq-toggle::before,
.tpl-cb-sustain-v1 .landing-pro-faq-toggle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background: var(--landing-text);
  transform: translate(-50%, -50%);
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.tpl-cb-sustain-v1 .landing-pro-faq-toggle::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.tpl-cb-sustain-v1 .landing-pro-faq-item[open] .landing-pro-faq-toggle::after {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(0deg);
}

.tpl-cb-sustain-v1 .landing-pro-section-cta {
  padding-top: clamp(3rem, 6vw, 4.6rem);
  padding-bottom: clamp(3rem, 6vw, 4.8rem);
}

.tpl-cb-sustain-v1 .landing-pro-final-panel {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--tpl-surface-solid) 72%, var(--color-primary) 28%) 0%, color-mix(in srgb, var(--tpl-surface-solid) 70%, var(--color-secondary) 30%) 100%);
  border-color: color-mix(in srgb, var(--color-primary) 22%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .landing-pro-final-copy p {
  color: color-mix(in srgb, var(--landing-text) 76%, var(--tpl-surface-solid));
}

.tpl-cb-sustain-v1 .landing-pro-final-actions {
  justify-content: flex-end;
}

@media (max-width: 1180px) {
  .tpl-cb-sustain-v1 .landing-pro-brand-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 1024px) {
  .tpl-cb-sustain-v1 .landing-pro-hero-grid,
  .tpl-cb-sustain-v1 .landing-pro-bonus-grid,
  .tpl-cb-sustain-v1 .landing-pro-trust-layout,
  .tpl-cb-sustain-v1 .landing-pro-final-panel {
    grid-template-columns: 1fr;
  }

  .tpl-cb-sustain-v1 .landing-pro-stage {
    order: 2;
  }

  .tpl-cb-sustain-v1 .landing-pro-title {
    max-width: 12ch;
  }

  .tpl-cb-sustain-v1 .landing-pro-steps-grid,
  .tpl-cb-sustain-v1 .landing-pro-trust-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tpl-cb-sustain-v1 .landing-pro-final-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .tpl-cb-sustain-v1 .landing-pro-hero {
    padding-top: 1.8rem;
  }

  .tpl-cb-sustain-v1 .landing-pro-title {
    font-size: clamp(2.5rem, 12vw, 4rem);
  }

  .tpl-cb-sustain-v1 .landing-pro-stage-callout,
  .tpl-cb-sustain-v1 .landing-pro-offer-topline {
    flex-direction: column;
    align-items: flex-start;
  }

  .tpl-cb-sustain-v1 .landing-pro-brand-grid,
  .tpl-cb-sustain-v1 .landing-pro-steps-grid,
  .tpl-cb-sustain-v1 .landing-pro-trust-grid {
    grid-template-columns: 1fr;
  }

  .tpl-cb-sustain-v1 .landing-pro-actions,
  .tpl-cb-sustain-v1 .landing-pro-final-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .tpl-cb-sustain-v1 .landing-pro-primary-action,
  .tpl-cb-sustain-v1 .landing-pro-secondary-action {
    width: 100%;
    justify-content: center;
  }
}
