/* Marketing primitives for Blazorponents. */
.bp-hero-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: var(--bp-hero-bg, transparent);
  padding: var(--bp-hero-padding, 0);
  color: var(--bp-ink);
}

.bp-hero-section-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-hero-section-inner {
  width: 100%;
  max-width: var(--bp-hero-max-width, 100%);
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.bp-hero-section-layout {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--bp-hero-min-column, 260px), 1fr));
  gap: var(--bp-hero-gap, 2rem);
  align-items: var(--bp-hero-align, start);
}

@media (max-width: var(--bp-hero-stack-at, 0px)) {
  .bp-hero-section-layout {
    grid-template-columns: 1fr;
  }
}

.bp-hero-section-media-stacked {
  grid-template-columns: 1fr;
}

.bp-hero-section-media-start .bp-hero-section-media {
  order: -1;
}

.bp-hero-section-media-end .bp-hero-section-media {
  order: 1;
}

.bp-hero-section-body {
  display: grid;
  gap: var(--bp-hero-body-gap, var(--bp-hero-gap, 1.5rem));
  min-width: 0;
}

.bp-hero-section-header {
  display: grid;
  gap: var(--bp-hero-header-gap, 0.5rem);
  align-content: start;
}

.bp-hero-section-subtitle {
  margin: 0;
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bp-ink-muted);
}

.bp-hero-section-title {
  margin: 0;
  font-size: clamp(1.75rem, 4vw, 3rem);
  line-height: 1.1;
  text-wrap: balance;
}

.bp-hero-section-description {
  margin: 0;
  max-width: 70ch;
  color: var(--bp-ink-muted);
}

.bp-hero-section-actions {
  display: flex;
  gap: var(--bp-hero-actions-gap, 0.75rem);
  flex-wrap: var(--bp-hero-actions-wrap, wrap);
  align-items: var(--bp-hero-actions-align, center);
  justify-content: var(--bp-hero-actions-justify, flex-start);
  flex-direction: var(--bp-hero-actions-direction, row);
}

.bp-hero-section-media {
  max-width: var(--bp-hero-media-max-width, 100%);
  min-width: var(--bp-hero-media-min-width, 0);
  width: var(--bp-hero-media-width, auto);
  aspect-ratio: var(--bp-hero-media-aspect, auto);
  border-radius: var(--bp-hero-media-radius, 0);
  overflow: hidden;
}

.bp-hero-section-media img,
.bp-hero-section-media video {
  width: 100%;
  height: 100%;
  object-fit: var(--bp-hero-media-fit, cover);
  display: block;
}

.bp-hero-section-media-stacked .bp-hero-section-media {
  width: 100%;
}

.bp-header {
  position: relative;
  padding: var(--bp-header-padding, 1rem 1.5rem);
  border-bottom: 1px solid var(--bp-header-border, var(--bp-outline-muted));
  background: var(--bp-header-bg, transparent);
  color: var(--bp-header-color, var(--bp-ink));
  overflow: hidden;
  isolation: isolate;
}

.bp-header-borderless {
  border-bottom: none;
}

.bp-header-elevated {
  box-shadow: var(--bp-shadow-1);
}

.bp-header-sticky {
  position: sticky;
  top: var(--bp-header-offset, 0);
  z-index: var(--bp-header-z, 10);
}

.bp-header-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-header-inner {
  width: 100%;
  max-width: var(--bp-header-max-width, 100%);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: var(--bp-header-align, center);
  justify-content: var(--bp-header-justify, space-between);
  gap: var(--bp-header-gap, 1.5rem);
  position: relative;
  z-index: 1;
}

@media (max-width: var(--bp-header-stack-at, 0px)) {
  .bp-header-inner {
    flex-direction: column;
    align-items: stretch;
  }

  .bp-header-brand,
  .bp-header-nav,
  .bp-header-actions {
    width: 100%;
  }

  .bp-header-nav {
    justify-content: var(--bp-header-nav-stack-justify, flex-start);
  }
}

.bp-header-brand,
.bp-header-nav,
.bp-header-actions {
  display: flex;
  align-items: center;
  gap: var(--bp-header-gap, 1rem);
}

.bp-header-nav {
  flex: 1 1 auto;
  justify-content: var(--bp-header-nav-justify, center);
  flex-wrap: var(--bp-header-nav-wrap, wrap);
  min-width: 0;
}

.bp-header-content {
  display: grid;
  gap: var(--bp-header-gap, 1rem);
}

.bp-faq {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.bp-faq-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-faq-body {
  display: grid;
  gap: var(--bp-faq-gap, 0.75rem);
  position: relative;
  z-index: 1;
}

.bp-faq-items {
  display: grid;
  gap: var(--bp-faq-gap, 0.75rem);
  margin: 0;
  padding: 0;
  list-style: none;
}

.bp-faq details {
  border-radius: var(--bp-faq-radius, 12px);
  border: var(--bp-faq-border, 1px solid var(--bp-outline-muted));
  background: var(--bp-faq-item-bg, var(--bp-surface));
  padding: var(--bp-faq-padding, 0.75rem 1rem);
}

.bp-faq summary {
  cursor: pointer;
  font-weight: 600;
}

.bp-faq-question-has-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--bp-faq-question-gap, 0.75rem);
}

.bp-faq-question-text {
  margin: 0;
}

.bp-faq-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
}

.bp-faq details[open] {
  box-shadow: var(--bp-faq-open-shadow, var(--bp-shadow-1));
}

.bp-faq-answer {
  margin-top: 0.5rem;
  color: var(--bp-ink-muted);
}

.bp-faq-empty-text {
  margin: 0;
  font-size: 0.85rem;
  color: var(--bp-muted);
}

.bp-feature-list {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.bp-feature-list-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-feature-list-body {
  display: grid;
  gap: var(--bp-feature-list-body-gap, var(--bp-feature-list-gap, 1rem));
  position: relative;
  z-index: 1;
}

.bp-feature-list-header,
.bp-feature-list-footer {
  display: grid;
  gap: 0.35rem;
}

.bp-feature-list-items {
  display: grid;
  gap: var(--bp-feature-list-gap, 1rem);
  margin: 0;
  padding: 0;
  list-style: none;
  grid-template-columns: repeat(var(--bp-feature-list-columns, 1), minmax(0, 1fr));
}

.bp-feature-list-horizontal {
  grid-auto-flow: column;
  grid-auto-columns: minmax(0, 1fr);
  grid-template-columns: none;
}

.bp-feature-list-item {
  display: flex;
  gap: var(--bp-feature-list-item-gap, 0.75rem);
  align-items: flex-start;
}

.bp-feature-list-icon {
  flex: 0 0 auto;
  font-size: var(--bp-feature-list-icon-size, 1.2rem);
  line-height: 1;
}

.bp-feature-list-content {
  display: grid;
  gap: var(--bp-feature-list-content-gap, 0.25rem);
  min-width: 0;
}

.bp-feature-list-title {
  font-weight: 600;
}

.bp-feature-list-description {
  margin: 0;
  font-size: 0.9rem;
  color: var(--bp-ink-muted);
}

.bp-feature-list-empty {
  display: grid;
}

.bp-feature-list-empty-text {
  margin: 0;
  font-size: 0.85rem;
  color: var(--bp-muted);
}

.bp-pricing-table {
  position: relative;
  display: grid;
  gap: var(--bp-pricing-table-gap, 1.5rem);
  color: var(--bp-ink);
  overflow: hidden;
  isolation: isolate;
}

.bp-pricing-table-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-pricing-table-header {
  display: flex;
  flex-wrap: wrap;
  gap: var(--bp-pricing-table-gap, 1rem);
  align-items: var(--bp-pricing-table-header-align, center);
  justify-content: var(--bp-pricing-table-header-justify, space-between);
  position: relative;
  z-index: 1;
}

.bp-pricing-table-heading {
  display: grid;
  gap: 0.35rem;
  min-width: 0;
}

.bp-pricing-table-toggle {
  display: flex;
  align-items: center;
  align-self: var(--bp-pricing-table-toggle-align, center);
  margin-left: var(--bp-pricing-table-toggle-offset, auto);
}

.bp-pricing-table-grid {
  display: grid;
  gap: var(--bp-pricing-table-gap, 1.5rem);
  grid-template-columns: repeat(var(--bp-pricing-table-columns, auto-fit), minmax(220px, 1fr));
  align-items: stretch;
  position: relative;
  z-index: 1;
}

.bp-pricing-table-plan {
  display: grid;
  gap: 0.75rem;
  padding: 1.5rem;
  border-radius: 16px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface);
  min-width: 0;
}

.bp-pricing-table-plan-featured {
  border-color: var(--bp-outline, var(--bp-outline-muted));
  box-shadow: var(--bp-shadow-1);
}

.bp-pricing-table-plan-header {
  display: grid;
  gap: 0.35rem;
}

.bp-pricing-table-plan-title {
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.3;
}

.bp-pricing-table-plan-description {
  margin: 0;
  color: var(--bp-ink-muted);
}

.bp-pricing-table-plan-price {
  font-size: 1.5rem;
  font-weight: 600;
}

.bp-pricing-table-plan-price-value {
  display: inline-block;
}

.bp-pricing-table-plan-features {
  display: grid;
  gap: 0.35rem;
  margin: 0;
  padding: 0;
  list-style: none;
  color: var(--bp-ink-muted);
  font-size: 0.9rem;
}

.bp-pricing-table-plan-feature {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.bp-pricing-table-plan-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--bp-accent-strong);
}

.bp-pricing-table-plan-cta {
  display: grid;
  gap: 0.5rem;
  margin-top: auto;
}

.bp-pricing-table-empty {
  display: grid;
  position: relative;
  z-index: 1;
}

.bp-pricing-table-empty-text {
  margin: 0;
  font-size: 0.85rem;
  color: var(--bp-muted);
}

.bp-footer {
  position: relative;
  padding: var(--bp-footer-padding, 2rem 1.5rem);
  border-top: 1px solid var(--bp-footer-border, var(--bp-outline-muted));
  background: var(--bp-footer-bg, var(--bp-surface));
  color: var(--bp-ink);
  overflow: hidden;
  isolation: isolate;
}

.bp-footer-borderless {
  border-top: none;
}

.bp-footer-elevated {
  box-shadow: var(--bp-shadow-1);
}

.bp-footer-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-footer-inner {
  width: 100%;
  max-width: var(--bp-footer-max-width, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, var(--bp-footer-secondary-width, 1fr));
  gap: var(--bp-footer-gap, 1.5rem);
  align-items: var(--bp-footer-align, stretch);
  justify-content: var(--bp-footer-justify, space-between);
  position: relative;
  z-index: 1;
}

@media (max-width: var(--bp-footer-stack-at, 720px)) {
  .bp-footer-inner {
    grid-template-columns: 1fr;
  }
}

.bp-footer-primary,
.bp-footer-secondary {
  display: grid;
  gap: var(--bp-footer-section-gap, 0.5rem);
}

.bp-footer-secondary {
  justify-items: start;
  text-align: left;
}

.bp-footer-secondary-content {
  display: grid;
  gap: var(--bp-footer-section-gap, 0.5rem);
  width: 100%;
  justify-self: stretch;
}

.bp-footer-sections {
  display: grid;
  gap: var(--bp-footer-gap, 1.5rem);
  grid-template-columns: repeat(var(--bp-footer-columns, 2), minmax(0, 1fr));
}

.bp-footer-section {
  display: grid;
  gap: var(--bp-footer-section-gap, 0.5rem);
}

.bp-footer-section-title {
  margin: 0;
  font-weight: 600;
}

.bp-footer-links {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.35rem;
}

.bp-footer-link {
  color: inherit;
  text-decoration: none;
}

.bp-footer-link:hover {
  text-decoration: underline;
}

.bp-footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  width: fit-content;
  color: inherit;
  text-decoration: none;
}

.bp-footer-legal {
  width: 100%;
  max-width: var(--bp-footer-max-width, 100%);
  margin: var(--bp-footer-gap, 1.5rem) auto 0;
  padding-top: var(--bp-footer-section-gap, 0.5rem);
  border-top: var(--bp-footer-legal-border, 1px solid var(--bp-outline-muted));
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--bp-footer-section-gap, 0.5rem);
  position: relative;
  z-index: 1;
}

.bp-call-to-action {
  position: relative;
  padding: var(--bp-call-to-action-padding, 1.5rem);
  border-radius: var(--bp-call-to-action-radius, 16px);
  border: var(--bp-call-to-action-border, 1px solid var(--bp-call-to-action-border-color, var(--bp-outline-muted)));
  background: var(--bp-call-to-action-bg, var(--bp-surface));
  box-shadow: var(--bp-call-to-action-shadow, none);
  color: var(--bp-ink);
  text-align: var(--bp-call-to-action-align, start);
  overflow: hidden;
  isolation: isolate;
}

.bp-call-to-action-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-call-to-action-layout {
  display: flex;
  gap: var(--bp-call-to-action-layout-gap, 1.5rem);
  align-items: flex-start;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.bp-call-to-action-media-start {
  flex-direction: row-reverse;
}

.bp-call-to-action-media-end {
  flex-direction: row;
}

.bp-call-to-action-media-stacked {
  flex-direction: column;
  align-items: stretch;
}

.bp-call-to-action-content {
  display: grid;
  gap: var(--bp-call-to-action-content-gap, 1.5rem);
  min-width: 0;
  flex: 1 1 0;
}

.bp-call-to-action-body {
  display: grid;
  gap: var(--bp-call-to-action-body-gap, 0.5rem);
}

.bp-call-to-action-header {
  display: grid;
  gap: var(--bp-call-to-action-header-gap, 0.5rem);
}

.bp-call-to-action-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.bp-call-to-action-title {
  margin: 0;
  font-size: clamp(1.375rem, 2.1vw, 2rem);
  line-height: 1.2;
  text-wrap: balance;
}

.bp-call-to-action-description {
  margin: 0;
  color: var(--bp-muted);
  max-width: 70ch;
}

.bp-call-to-action-actions {
  display: flex;
  flex-direction: var(--bp-call-to-action-actions-direction, row);
  align-items: var(--bp-call-to-action-actions-align, stretch);
  justify-content: var(--bp-call-to-action-actions-justify, flex-start);
  gap: var(--bp-call-to-action-actions-gap, 0.75rem);
  flex-wrap: var(--bp-call-to-action-actions-wrap, wrap);
}

.bp-call-to-action-media {
  border-radius: var(--bp-call-to-action-media-radius, 14px);
  overflow: hidden;
  max-width: var(--bp-call-to-action-media-max-width, 100%);
  min-width: var(--bp-call-to-action-media-min-width, 0);
  width: var(--bp-call-to-action-media-width, auto);
  aspect-ratio: var(--bp-call-to-action-media-aspect, auto);
  flex: 0 1 auto;
}

.bp-call-to-action-media img,
.bp-call-to-action-media video {
  width: 100%;
  height: 100%;
  object-fit: var(--bp-call-to-action-media-fit, cover);
  display: block;
}

.bp-call-to-action-media-stacked .bp-call-to-action-media {
  width: 100%;
}

.bp-comparison-table {
  position: relative;
  overflow-x: auto;
  max-width: 100%;
  color: var(--bp-ink);
}

.bp-comparison-table-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-comparison-table-table {
  width: 100%;
  border-collapse: collapse;
  min-width: var(--bp-comparison-table-min-width, 480px);
  position: relative;
  z-index: 1;
  background: var(--bp-comparison-table-table-bg, transparent);
}

.bp-comparison-table-header-row th {
  font-weight: 600;
}

.bp-comparison-table-feature-header {
  min-width: var(--bp-comparison-table-feature-column-min-width, 180px);
}

.bp-comparison-table-sticky-header thead th {
  position: sticky;
  top: var(--bp-comparison-table-sticky-top, 0);
  background: var(--bp-comparison-table-sticky-bg, var(--bp-surface));
  z-index: 3;
}

.bp-comparison-table-sticky-first thead th:first-child,
.bp-comparison-table-sticky-first th[scope="row"] {
  position: sticky;
  left: var(--bp-comparison-table-sticky-left, 0);
  background: var(--bp-comparison-table-sticky-bg, var(--bp-surface));
  z-index: 2;
}

.bp-comparison-table-sticky-header.bp-comparison-table-sticky-first thead th:first-child {
  z-index: 4;
}

.bp-comparison-table-caption {
  text-align: left;
  font-size: 0.9rem;
  color: var(--bp-muted);
  margin-bottom: 0.5rem;
}

.bp-comparison-table-table th,
.bp-comparison-table-table td {
  border-bottom: 1px solid var(--bp-outline-muted);
  padding: 0.75rem;
  text-align: left;
  vertical-align: top;
}

.bp-comparison-table-compact .bp-comparison-table-table th,
.bp-comparison-table-compact .bp-comparison-table-table td {
  padding: 0.5rem 0.65rem;
}

.bp-comparison-table-striped .bp-comparison-table-table tbody tr:nth-child(even) {
  background: var(--bp-comparison-table-striped-bg, var(--bp-surface-muted));
}

.bp-comparison-table-hover .bp-comparison-table-table tbody tr:hover {
  background: var(--bp-comparison-table-hover-bg, var(--bp-surface-muted));
}

.bp-comparison-table-feature-content {
  display: grid;
  gap: 0.15rem;
}

.bp-comparison-table-feature-name {
  font-weight: 600;
}

.bp-comparison-table-feature-description {
  font-size: 0.8rem;
  color: var(--bp-muted);
}

.bp-comparison-table-plan {
  display: grid;
  gap: 0.2rem;
}

.bp-comparison-table-plan-badge {
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bp-ink-muted);
}

.bp-comparison-table-plan-title {
  font-size: 0.95rem;
}

.bp-comparison-table-plan-price {
  font-weight: 600;
}

.bp-comparison-table-plan-description {
  font-size: 0.8rem;
  color: var(--bp-muted);
}

.bp-comparison-table-cell-missing {
  color: var(--bp-muted);
}

.bp-comparison-table-missing-text {
  color: var(--bp-muted);
  font-size: 0.85rem;
}

.bp-comparison-table-empty-text {
  margin: 0;
  font-size: 0.85rem;
  color: var(--bp-muted);
}

.bp-comparison-table-empty-cell {
  text-align: center;
}

.bp-comparison-table-plan-highlight {
  background: var(--bp-surface-muted);
}

.bp-feature-grid {
  display: grid;
  gap: var(--bp-feature-grid-gap, 1rem);
  position: relative;
  isolation: isolate;
}

.bp-feature-grid-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-feature-grid-header,
.bp-feature-grid-items,
.bp-feature-grid-footer {
  display: grid;
  gap: 0.35rem;
  position: relative;
  z-index: 1;
}

.bp-feature-grid-items {
  grid-template-columns: repeat(var(--bp-feature-grid-columns, auto-fit), minmax(var(--bp-feature-grid-min-column, 200px), 1fr));
  gap: var(--bp-feature-grid-gap, 1rem);
  list-style: none;
  margin: 0;
  padding: 0;
}

.bp-feature-grid-empty {
  display: grid;
}

.bp-feature-grid-empty-text {
  margin: 0;
  font-size: 0.85rem;
  color: var(--bp-muted);
}

.bp-feature-grid-item {
  border-radius: var(--bp-feature-grid-item-radius, 14px);
  border: var(--bp-feature-grid-item-border, 1px solid var(--bp-outline-muted));
  background: var(--bp-feature-grid-item-background, var(--bp-surface));
  padding: var(--bp-feature-grid-item-padding, 1rem);
  display: grid;
  gap: 0.4rem;
  align-content: start;
}

.bp-feature-grid-icon {
  font-size: var(--bp-feature-grid-icon-size, 1.2rem);
}

.bp-feature-grid-content {
  display: grid;
  gap: var(--bp-feature-grid-content-gap, 0.4rem);
}

.bp-feature-grid-title {
  margin: 0;
}

.bp-feature-grid-description {
  margin: 0;
  color: var(--bp-muted);
}

.bp-newsletter-signup {
  display: grid;
  gap: 1rem;
  padding: 1.25rem;
  border-radius: 16px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface);
  color: var(--bp-ink);
  max-width: var(--bp-newsletter-max-width, 100%);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.bp-newsletter-signup-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-newsletter-signup-body,
.bp-newsletter-signup-header {
  display: grid;
  gap: 0.35rem;
  position: relative;
  z-index: 1;
}

.bp-newsletter-signup-title,
.bp-newsletter-signup-description {
  margin: 0;
}

.bp-newsletter-signup-title {
  display: block;
}

.bp-newsletter-signup-form {
  display: grid;
  gap: var(--bp-newsletter-form-gap, 0.75rem);
  grid-template-columns: var(--bp-newsletter-form-columns, 1fr);
  position: relative;
  z-index: 1;
}

@media (max-width: var(--bp-newsletter-form-stack-at, 0px)) {
  .bp-newsletter-signup-form {
    grid-template-columns: 1fr;
  }
}

.bp-newsletter-signup-message {
  display: grid;
  gap: 0.25rem;
  font-size: 0.85rem;
  position: relative;
  z-index: 1;
}

.bp-newsletter-signup-message-success {
  color: var(--bp-success);
}

.bp-newsletter-signup-message-invalid {
  color: var(--bp-danger);
}

.bp-newsletter-signup-disclaimer {
  font-size: 0.8rem;
  color: var(--bp-ink-muted);
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.25rem;
}

.bp-newsletter-signup-disclaimer :where(p, ul, ol) {
  margin: 0;
}

.bp-newsletter-signup-footer {
  display: grid;
  gap: 0.35rem;
  position: relative;
  z-index: 1;
}

.bp-pricing-toggle {
  display: inline-flex;
  border-radius: 999px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface-muted);
  padding: 0.2rem;
  gap: 0.2rem;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.bp-pricing-toggle-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-pricing-toggle-full {
  width: 100%;
  display: flex;
}

.bp-pricing-toggle-option {
  border: none;
  background: transparent;
  color: var(--bp-ink);
  padding: 0.4rem 0.9rem;
  border-radius: 999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-weight: 600;
  position: relative;
  z-index: 1;
}

.bp-pricing-toggle-full .bp-pricing-toggle-option {
  flex: 1 1 0;
  justify-content: center;
}

.bp-pricing-toggle-sm .bp-pricing-toggle-option {
  padding: 0.25rem 0.6rem;
  font-size: 0.85rem;
}

.bp-pricing-toggle-lg .bp-pricing-toggle-option {
  padding: 0.55rem 1.1rem;
  font-size: 1rem;
}

.bp-pricing-toggle-option-active {
  background: var(--bp-surface);
  box-shadow: var(--bp-shadow-1);
}

.bp-pricing-toggle-option-disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.bp-pricing-toggle-badge {
  font-size: 0.7rem;
  color: var(--bp-accent-strong);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.bp-product-card {
  position: relative;
  padding: var(--bp-product-card-padding, 1rem);
  border-radius: 16px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface);
  color: var(--bp-ink);
  max-width: var(--bp-product-card-max-width, 100%);
  overflow: hidden;
  isolation: isolate;
}

.bp-product-card-interactive {
  cursor: pointer;
  transition: border-color 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}

.bp-product-card-interactive:hover {
  border-color: var(--bp-accent-soft);
  box-shadow: var(--bp-shadow-1);
}

.bp-product-card-interactive:focus-visible {
  outline: 2px solid var(--bp-focus-ring);
  outline-offset: 2px;
}

.bp-product-card-interactive:active {
  transform: translateY(1px);
}

.bp-product-card-disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.bp-product-card-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-product-card-layout {
  display: flex;
  gap: var(--bp-product-card-layout-gap, 0.75rem);
  align-items: flex-start;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.bp-product-card-media-start {
  flex-direction: row;
}

.bp-product-card-media-end {
  flex-direction: row-reverse;
}

.bp-product-card-media-stacked {
  flex-direction: column;
  align-items: stretch;
}

.bp-product-card-media {
  border-radius: var(--bp-product-card-media-radius, 12px);
  overflow: hidden;
  max-width: 100%;
  aspect-ratio: var(--bp-product-card-media-aspect, auto);
  flex: 0 1 var(--bp-product-card-media-basis, 40%);
}

.bp-product-card-media img {
  width: 100%;
  height: 100%;
  object-fit: var(--bp-product-card-media-fit, cover);
  display: block;
}

.bp-product-card-media-stacked .bp-product-card-media {
  width: 100%;
}

.bp-product-card-body {
  display: grid;
  gap: var(--bp-product-card-body-gap, 0.5rem);
  min-width: 0;
  flex: 1 1 0;
}

.bp-product-card-header {
  display: grid;
  gap: var(--bp-product-card-header-gap, 0.35rem);
}

.bp-product-card-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface-muted);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.bp-product-card-title {
  font-weight: 600;
}

.bp-product-card-subtitle {
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-product-card-price {
  display: flex;
  align-items: baseline;
  gap: 0.35rem;
}

.bp-product-card-price-value {
  font-weight: 600;
  font-size: 1.1rem;
}

.bp-product-card-price-label {
  font-weight: 400;
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-product-card-rating {
  display: inline-flex;
  gap: 0.3rem;
  align-items: center;
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-product-card-rating-icon {
  font-size: 0.9rem;
  line-height: 1;
}

.bp-product-card-rating-label {
  font-weight: 600;
  color: var(--bp-ink);
}

.bp-product-card-reviews {
  color: var(--bp-ink-muted);
}

.bp-product-card-details {
  display: grid;
  gap: var(--bp-product-card-details-gap, 0.35rem);
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-product-card-actions {
  display: flex;
  gap: var(--bp-product-card-actions-gap, 0.5rem);
  flex-wrap: wrap;
  align-items: center;
}

.bp-product-card-media-stacked .bp-product-card-actions {
  width: 100%;
}

.bp-testimonial-carousel {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  max-width: var(--bp-testimonial-carousel-max-width, 100%);
}

.bp-testimonial-carousel-surface {
  position: relative;
}

.bp-testimonial-carousel-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-testimonial-carousel .bp-carousel-header,
.bp-testimonial-carousel .bp-carousel-track,
.bp-testimonial-carousel .bp-carousel-controls,
.bp-testimonial-carousel .bp-carousel-empty,
.bp-testimonial-carousel .bp-carousel-loading {
  position: relative;
  z-index: 1;
}

.bp-testimonial-carousel-item {
  padding: var(--bp-testimonial-carousel-item-padding, 1rem);
  border-radius: var(--bp-testimonial-carousel-item-radius, 16px);
  border: var(--bp-testimonial-carousel-item-border, 1px solid var(--bp-outline-muted));
  background: var(--bp-testimonial-carousel-item-background, var(--bp-surface));
  display: grid;
  gap: var(--bp-testimonial-carousel-item-gap, 0.75rem);
}

.bp-testimonial-carousel-item-content {
  display: grid;
  gap: 0.5rem;
}

.bp-testimonial-carousel-quote {
  font-style: var(--bp-testimonial-carousel-quote-font-style, italic);
  margin: 0;
}

.bp-testimonial-carousel-author {
  display: grid;
  gap: 0.2rem;
  font-size: var(--bp-testimonial-carousel-author-font-size, 0.85rem);
  color: var(--bp-testimonial-carousel-author-color, var(--bp-ink-muted));
}

.bp-testimonial-carousel-empty {
  display: grid;
  place-items: center;
  padding: var(--bp-testimonial-carousel-empty-padding, 1rem);
  border-radius: 14px;
  border: var(--bp-testimonial-carousel-empty-border, 1px dashed var(--bp-outline-muted));
  color: var(--bp-ink-muted);
}

.bp-testimonial-carousel-empty-text {
  font-size: 0.85rem;
}

.bp-logo-cloud {
  display: grid;
  gap: var(--bp-logo-cloud-gap, 1rem);
  max-width: var(--bp-logo-cloud-max-width, 100%);
  color: var(--bp-logo-cloud-color, var(--bp-ink));
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.bp-logo-cloud-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-logo-cloud-header {
  display: grid;
  gap: 0.35rem;
  position: relative;
  z-index: 1;
}

.bp-pricing-toggle-option:focus-visible {
  outline: 2px solid var(--bp-accent-strong);
  outline-offset: 2px;
}

.bp-logo-cloud-title {
  margin: 0;
}

.bp-logo-cloud-description {
  margin: 0;
  color: var(--bp-ink-muted);
}

.bp-logo-cloud-grid {
  display: grid;
  grid-template-columns: repeat(var(--bp-logo-cloud-columns, auto-fit), minmax(var(--bp-logo-cloud-min-column, 160px), 1fr));
  gap: var(--bp-logo-cloud-gap, 1rem);
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
  z-index: 1;
}

.bp-logo-cloud-empty {
  display: grid;
}

.bp-logo-cloud-empty-text {
  margin: 0;
  font-size: 0.85rem;
  color: var(--bp-muted);
}

.bp-logo-cloud-item {
  display: grid;
  place-items: center;
  min-height: var(--bp-logo-cloud-item-min-height, auto);
  padding: var(--bp-logo-cloud-item-padding, 0.5rem);
  border-radius: var(--bp-logo-cloud-item-radius, 12px);
  border: var(--bp-logo-cloud-item-border, 1px solid var(--bp-outline-muted));
  background: var(--bp-logo-cloud-item-background, var(--bp-surface));
}

.bp-logo-cloud-link {
  display: grid;
  place-items: center;
  width: 100%;
  text-decoration: none;
  color: inherit;
}

.bp-logo-cloud-image {
  max-width: var(--bp-logo-cloud-image-max-width, 120px);
  max-height: var(--bp-logo-cloud-image-max-height, 40px);
  width: var(--bp-logo-cloud-image-width, auto);
  height: var(--bp-logo-cloud-image-height, auto);
  object-fit: var(--bp-logo-cloud-image-fit, contain);
  filter: var(--bp-logo-cloud-image-filter, grayscale(0.35));
  opacity: var(--bp-logo-cloud-image-opacity, 0.8);
  transition: filter 140ms ease, opacity 140ms ease;
}

.bp-logo-cloud-treatment-brand .bp-logo-cloud-image {
  filter: var(--bp-logo-cloud-image-filter, none);
  opacity: var(--bp-logo-cloud-image-opacity, 1);
}

.bp-logo-cloud-treatment-grayscale .bp-logo-cloud-image {
  filter: var(--bp-logo-cloud-image-filter, grayscale(1));
  opacity: var(--bp-logo-cloud-image-opacity, 1);
}

.bp-logo-cloud-treatment-muted .bp-logo-cloud-image {
  filter: var(--bp-logo-cloud-image-filter, grayscale(0.35));
  opacity: var(--bp-logo-cloud-image-opacity, 0.8);
}

.bp-logo-cloud-link:hover .bp-logo-cloud-image,
.bp-logo-cloud-link:focus-visible .bp-logo-cloud-image {
  opacity: 1;
}

.bp-logo-cloud-label {
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-stats-strip {
  display: grid;
  gap: var(--bp-stats-strip-gap, 1rem);
  max-width: var(--bp-stats-strip-max-width, 100%);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.bp-stats-strip-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-stats-strip-dense .bp-stats-strip-items {
  gap: var(--bp-stats-strip-gap, 0.75rem);
}

.bp-stats-strip-dense .bp-stats-strip-item {
  padding: 0.75rem;
}

.bp-stats-strip-header {
  display: grid;
  gap: 0.35rem;
  position: relative;
  z-index: 1;
}

.bp-stats-strip-footer {
  display: grid;
  gap: 0.35rem;
  position: relative;
  z-index: 1;
}

.bp-stats-strip-items {
  display: grid;
  grid-template-columns: repeat(var(--bp-stats-strip-columns, auto-fit), minmax(var(--bp-stats-strip-min-column, 180px), 1fr));
  gap: var(--bp-stats-strip-gap, 1rem);
  position: relative;
  z-index: 1;
  list-style: none;
  margin: 0;
  padding: 0;
}

.bp-stats-strip-empty {
  display: grid;
  place-items: center;
  padding: 1rem;
  border-radius: 14px;
  border: 1px dashed var(--bp-outline-muted);
  color: var(--bp-ink-muted);
}

.bp-stats-strip-empty-text {
  font-size: 0.85rem;
}

.bp-stats-strip-item {
  display: grid;
  gap: 0.35rem;
  padding: 1rem;
  border-radius: 14px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface);
}

.bp-stats-strip-prefix {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.bp-stats-strip-value {
  font-size: 1.4rem;
}

.bp-stats-strip-label,
.bp-stats-strip-description {
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-trust-bar {
  display: grid;
  gap: var(--bp-trust-bar-gap, 0.75rem);
  max-width: var(--bp-trust-bar-max-width, 100%);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.bp-trust-bar-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-trust-bar-header {
  display: grid;
  gap: 0.35rem;
  position: relative;
  z-index: 1;
}

.bp-trust-bar-title {
  margin: 0;
}

.bp-trust-bar-header-description {
  margin: 0;
  color: var(--bp-ink-muted);
}

.bp-trust-bar-items {
  display: grid;
  grid-template-columns: repeat(var(--bp-trust-bar-columns, auto-fit), minmax(var(--bp-trust-bar-min-column, 160px), 1fr));
  gap: var(--bp-trust-bar-gap, 0.75rem);
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
  z-index: 1;
}

.bp-trust-bar-item {
  display: grid;
  place-items: center;
  gap: 0.25rem;
  text-align: center;
}

.bp-trust-bar-item-content {
  display: grid;
  gap: 0.25rem;
}

.bp-trust-bar-item-logo .bp-trust-bar-item-content {
  justify-items: center;
}

.bp-trust-bar-item-badge .bp-trust-bar-item-content {
  justify-items: start;
}

.bp-trust-bar-link {
  text-decoration: none;
  color: inherit;
}

.bp-trust-bar-image {
  width: var(--bp-trust-bar-image-width, auto);
  height: var(--bp-trust-bar-image-height, auto);
  max-width: 140px;
  max-height: 44px;
  object-fit: var(--bp-trust-bar-image-fit, contain);
  opacity: 0.85;
}

.bp-trust-bar-badges .bp-trust-bar-item {
  align-items: start;
  text-align: left;
  padding: 0.75rem;
  border-radius: 12px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface);
}

.bp-trust-bar-badge {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--bp-ink-muted);
}

.bp-trust-bar-description {
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-trust-bar-empty {
  display: grid;
  place-items: center;
  padding: 0.75rem;
  border-radius: 12px;
  border: 1px dashed var(--bp-outline-muted);
  color: var(--bp-ink-muted);
}

.bp-trust-bar-empty-text {
  font-size: 0.85rem;
}

.bp-case-study-card {
  position: relative;
  padding: 1rem;
  border-radius: 16px;
  border: 1px solid var(--bp-outline-muted);
  background: var(--bp-surface);
  color: var(--bp-ink);
  max-width: var(--bp-case-study-max-width, 100%);
  overflow: hidden;
  isolation: isolate;
}

.bp-case-study-card-interactive {
  cursor: pointer;
  transition: border-color 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}

.bp-case-study-card-interactive:hover {
  border-color: var(--bp-accent-soft);
  box-shadow: var(--bp-shadow-1);
}

.bp-case-study-card-interactive:focus-within {
  outline: 2px solid var(--bp-focus-ring);
  outline-offset: 2px;
}

.bp-case-study-card-interactive:active {
  transform: translateY(1px);
}

.bp-case-study-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-case-study-link {
  color: inherit;
  text-decoration: none;
  display: block;
}

.bp-case-study-layout {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.bp-case-study-media-start {
  flex-direction: row;
}

.bp-case-study-media-end {
  flex-direction: row-reverse;
}

.bp-case-study-media-stacked {
  flex-direction: column;
  align-items: stretch;
}

.bp-case-study-content {
  display: grid;
  gap: 0.75rem;
  min-width: 0;
  flex: 1 1 0;
}

.bp-case-study-media {
  border-radius: 12px;
  overflow: hidden;
  max-width: 100%;
  aspect-ratio: var(--bp-case-study-media-aspect, auto);
  flex: 0 1 40%;
}

.bp-case-study-media img,
.bp-case-study-image {
  width: 100%;
  height: 100%;
  object-fit: var(--bp-case-study-media-fit, cover);
  display: block;
}

.bp-case-study-media-stacked .bp-case-study-media {
  width: 100%;
}

.bp-case-study-body {
  display: grid;
  gap: 0.4rem;
}

.bp-case-study-eyebrow {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--bp-ink-muted);
}

.bp-case-study-meta {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-case-study-metric {
  display: grid;
  gap: 0.1rem;
}

.bp-case-study-metric-item {
  display: grid;
  gap: 0.1rem;
}

.bp-case-study-metric-label {
  font-size: 0.85rem;
  color: var(--bp-ink-muted);
}

.bp-case-study-footer {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.bp-testimonial-grid {
  position: relative;
  display: grid;
  gap: var(--bp-testimonial-grid-gap, 1rem);
  max-width: var(--bp-testimonial-grid-max-width, 100%);
  isolation: isolate;
}

.bp-testimonial-grid-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.bp-testimonial-grid-header {
  display: grid;
  gap: 0.35rem;
  position: relative;
  z-index: 1;
}

.bp-testimonial-grid-title {
  margin: 0;
}

.bp-testimonial-grid-description {
  margin: 0;
  color: var(--bp-ink-muted);
}

.bp-testimonial-grid-items {
  display: grid;
  grid-template-columns: repeat(var(--bp-testimonial-grid-columns, auto-fit), minmax(var(--bp-testimonial-grid-min-column, 240px), 1fr));
  gap: var(--bp-testimonial-grid-gap, 1rem);
  position: relative;
  z-index: 1;
}

.bp-testimonial-grid-empty {
  display: grid;
  place-items: center;
  padding: 1rem;
  border-radius: 14px;
  border: 1px dashed var(--bp-outline-muted);
  color: var(--bp-ink-muted);
}

.bp-testimonial-grid-empty-text {
  font-size: 0.85rem;
}

.bp-testimonial-grid-item {
  display: grid;
  gap: var(--bp-testimonial-grid-item-gap, 0.75rem);
  padding: var(--bp-testimonial-grid-item-padding, 1rem);
  border-radius: var(--bp-testimonial-grid-item-radius, 16px);
  border: var(--bp-testimonial-grid-item-border, 1px solid var(--bp-outline-muted));
  background: var(--bp-testimonial-grid-item-background, var(--bp-surface));
}

.bp-testimonial-grid-quote {
  display: grid;
  gap: 0.35rem;
}

.bp-testimonial-grid-quote-text {
  margin: 0;
  font-style: var(--bp-testimonial-grid-quote-font-style, italic);
}

.bp-testimonial-grid-author {
  display: flex;
  gap: 0.6rem;
  align-items: center;
  font-size: var(--bp-testimonial-grid-author-font-size, 0.85rem);
  color: var(--bp-testimonial-grid-author-color, var(--bp-ink-muted));
}

.bp-testimonial-grid-author-details {
  display: grid;
  gap: 0.2rem;
}

.bp-testimonial-grid-author img {
  width: var(--bp-testimonial-grid-avatar-size, 40px);
  height: var(--bp-testimonial-grid-avatar-size, 40px);
  border-radius: var(--bp-testimonial-grid-avatar-radius, 50%);
  object-fit: cover;
}
