.kpbp-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  padding: 10px;
  isolation: isolate;
  opacity: 0;
  transition: opacity 0.28s ease;
}

.kpbp-overlay.kpbp-overlay--open {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .kpbp-overlay {
    transition-duration: 0.01ms;
  }

  .kpbp-modal--toast {
    transition: none;
  }
}

.kpbp-overlay--center::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-color: rgba(0, 0, 0, 0.5) !important;
}

.kpbp-overlay--center {
  align-items: center;
  justify-content: center;
}

.kpbp-overlay--bottom-right {
  align-items: flex-end;
  justify-content: flex-end;
  padding: 10px 10px 14px;
  pointer-events: none;
}

.kpbp-modal {
  position: relative;
  z-index: 1;
  overflow: visible !important;
  width: min(520px, 100%);
  max-width: 100%;
  background: #ffffff;
  border-radius: 10px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.24);
  padding: 0;
  text-align: center;
  box-sizing: border-box;
}

/* Title, description, CTA — inset from modal edges */
.kpbp-body {
  padding: 20px;
  box-sizing: border-box;
}

.kpbp-overlay--bottom-right .kpbp-modal {
  pointer-events: auto;
  width: min(380px, calc(100vw - 20px));
  box-shadow: 0 12px 36px rgba(15, 23, 42, 0.2);
}

/* Compact toast: same radius & close as standard modal; content vs link split below */
.kpbp-modal--toast {
  border-radius: 10px;
  transition: opacity 0.26s ease;
}

/* Scroll down: compact bar — thumbnail + title + button (description hidden) */
.kpbp-modal--toast.kpbp-modal--toast-collapsed {
  display: flex !important;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  width: min(320px, calc(100vw - 24px)) !important;
  max-width: min(320px, calc(100vw - 24px)) !important;
  min-width: 0 !important;
  /* Close sits outside the corner — less inner padding needed on the right */
  padding: 10px 14px 10px 10px;
  box-sizing: border-box;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.2);
}

.kpbp-modal--toast-collapsed .kpbp-toast-stack {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  gap: 0;
}

.kpbp-modal--toast-collapsed .kpbp-toast-content {
  padding: 0 0 6px;
  text-align: left;
}

.kpbp-modal--toast-collapsed .kpbp-toast-heading {
  margin: 0 0 2px;
  font-size: 0.875rem;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}

/* Long body copy hidden; if there is no title, show 2-line preview from description */
.kpbp-modal--toast-collapsed .kpbp-toast-description {
  display: none;
}

.kpbp-modal--toast-collapsed .kpbp-toast-content--headless .kpbp-toast-description {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  margin: 0 0 4px;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #111827;
}

.kpbp-modal--toast-collapsed .kpbp-toast-link {
  border-top: 0;
  background: transparent;
  padding: 0;
  border-radius: 0;
  align-self: stretch;
  width: 100%;
  box-sizing: border-box;
}

.kpbp-modal--toast-collapsed .kpbp-toast-link .kpbp-actions {
  width: 100%;
  max-width: 100%;
}

.kpbp-modal--toast-collapsed .kpbp-toast-link .kpbp-link-btn {
  padding: 8px 12px;
  font-size: 0.8125rem;
  width: 100%;
  max-width: 100%;
  align-self: stretch;
  box-sizing: border-box;
}

.kpbp-modal--toast-collapsed.kpbp-modal--toast-has-hero > .kpbp-image-wrap {
  flex: 0 0 52px;
  width: 52px;
  align-self: center;
  --kpbp-frame-padding: 2px;
  border-radius: 10px;
}

.kpbp-modal--toast-collapsed.kpbp-modal--toast-has-hero .kpbp-image-inner {
  width: 48px;
  height: 48px;
}

.kpbp-modal--toast-collapsed.kpbp-modal--toast-has-hero .kpbp-image-inner a {
  display: block;
  width: 48px;
  height: 48px;
  overflow: hidden;
  border-radius: var(--kpbp-media-radius);
}

.kpbp-modal--toast-collapsed.kpbp-modal--toast-has-hero .kpbp-image-inner img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--kpbp-media-radius);
}

.kpbp-toast-stack {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.kpbp-toast-content {
  padding: 20px 20px 16px;
  box-sizing: border-box;
  text-align: center;
}

.kpbp-modal--toast > .kpbp-image-wrap:first-child {
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.kpbp-toast-heading {
  margin: 0 0 6px;
}

.kpbp-toast-description {
  margin: 0;
  color: #4b5563;
  font-size: 0.9375rem;
  line-height: 1.45;
  white-space: pre-line;
}

.kpbp-toast-content .kpbp-toast-description:last-child {
  margin-bottom: 0;
}

.kpbp-toast-link {
  border-top: 1px solid #e5e7eb;
  background: #f9fafb;
  padding: 14px 16px 16px;
  box-sizing: border-box;
  border-radius: 0 0 10px 10px;
}

.kpbp-toast-stack > .kpbp-toast-link:only-child {
  border-top: 0;
  border-radius: 10px;
}

.kpbp-toast-link .kpbp-actions {
  margin-top: 0;
}

/* High specificity + !important so theme button styles cannot override dismiss sizing/shape */
button.kpbp-dismiss,
.kpbp-dismiss {
  position: absolute !important;
  z-index: 5;
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  min-height: 28px !important;
  max-width: 28px !important;
  max-height: 28px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 6px !important;
  aspect-ratio: 1 / 1;
  flex: 0 0 28px !important;
  box-sizing: border-box !important;
  overflow: visible;
  appearance: none !important;
  -webkit-appearance: none !important;
  background: rgba(8, 7, 23, 0.4) !important;
  color: #ffffff !important;
  box-shadow: 0 4px 14px rgba(8, 7, 23, 0.2);
  line-height: 0;
  cursor: pointer;
}

button.kpbp-dismiss:hover,
.kpbp-dismiss:hover {
  background: rgba(8, 7, 23, 0.6) !important;
  color: #ffffff !important;
}

.kpbp-dismiss svg {
  display: block;
}

/* Close on modal when there is no image */
.kpbp-modal > .kpbp-dismiss {
  top: 10px;
  right: 10px;
}

/* Compact toast (expanded): same default 28px close as other modals */
.kpbp-modal--toast > .kpbp-dismiss {
  z-index: 6;
}

/* Collapsed bar only: × sits outside the top-right corner — size unchanged */
.kpbp-modal--toast.kpbp-modal--toast-collapsed > .kpbp-dismiss {
  top: -8px;
  right: -8px;
}

.kpbp-image-wrap {
  --kpbp-frame-padding: 5px;
  --kpbp-media-radius: 5px;
  position: relative;
  margin: 0;
  padding: var(--kpbp-frame-padding);
  border-radius: calc(var(--kpbp-media-radius) + var(--kpbp-frame-padding));
  overflow: visible;
  background: #ffffff;
}

.kpbp-image-inner {
  position: relative;
  overflow: hidden;
  border-radius: var(--kpbp-media-radius);
}

.kpbp-image-inner .kpbp-dismiss {
  top: 0;
  right: 0;
  border-radius: var(--kpbp-media-radius) !important;
}

.kpbp-image-wrap img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--kpbp-media-radius);
}

.kpbp-title {
  margin: 0 0 8px;
  padding: 0;
  color: #111827;
  font-size: 1.125rem;
  line-height: 1.3;
  font-weight: 700;
}

.kpbp-message {
  margin: 0 0 12px;
  color: #4b5563;
  font-size: 0.9375rem;
  line-height: 1.45;
  white-space: pre-line;
}

.kpbp-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 0;
  width: 100%;
}

.kpbp-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  background: #0f172a;
  color: #ffffff !important;
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1;
  padding: 12px 16px;
  width: 100%;
  min-width: 0;
  text-decoration: none !important;
  border: 0;
  cursor: pointer;
}

.kpbp-link-btn:hover {
  background: #020617;
  color: #ffffff !important;
}

/* Bottom-right: cap width on small screens (was almost full viewport width) */
@media (max-width: 480px) {
  .kpbp-overlay--bottom-right {
    padding: 8px 8px max(10px, env(safe-area-inset-bottom, 0px));
  }

  .kpbp-overlay--bottom-right .kpbp-modal {
    width: min(268px, calc(100vw - 16px));
    max-width: min(268px, calc(100vw - 16px));
  }

  /*
   * Collapsed toast — mobile: full width of overlay, calm grid layout
   * Row 1: thumb | title (close inside top-right). Row 2: full-width CTA.
   */
  .kpbp-overlay--bottom-right .kpbp-modal--toast.kpbp-modal--toast-collapsed {
    display: grid !important;
    grid-template-columns: 48px minmax(0, 1fr);
    grid-template-rows: auto auto;
    align-items: start;
    align-content: start;
    column-gap: 12px;
    row-gap: 10px;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    /* flex-end: keep toast at bottom; do NOT stretch — stretch was filling viewport height */
    align-self: flex-end;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 12px 44px 12px 12px;
    box-sizing: border-box;
    text-align: left;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed:not(.kpbp-modal--toast-has-hero) {
    grid-template-columns: minmax(0, 1fr);
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed
    .kpbp-toast-stack {
    display: contents;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed.kpbp-modal--toast-has-hero
    > .kpbp-image-wrap {
    grid-column: 1;
    grid-row: 1;
    flex: none;
    width: 48px;
    align-self: start;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed:not(.kpbp-modal--toast-has-hero)
    .kpbp-toast-content {
    grid-column: 1;
    grid-row: 1;
    padding: 0 0 0 0;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed.kpbp-modal--toast-has-hero
    .kpbp-toast-content {
    grid-column: 2;
    grid-row: 1;
    padding: 0;
    align-self: start;
    text-align: left;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed
    .kpbp-toast-heading {
    text-align: left;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed
    .kpbp-toast-link {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100%;
    max-width: none;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed
    > .kpbp-dismiss {
    top: 8px;
    right: 10px;
    left: auto;
  }

  /* No text block — only CTA: single full-width row */
  .kpbp-overlay--bottom-right
    .kpbp-modal--toast.kpbp-modal--toast-collapsed:not(.kpbp-modal--toast-has-hero)
    .kpbp-toast-stack
    > .kpbp-toast-link:only-child {
    grid-row: 1;
  }

  .kpbp-overlay--bottom-right .kpbp-body {
    padding: 14px;
  }

  /* Expanded toast only — collapsed grid sets its own padding */
  .kpbp-overlay--bottom-right
    .kpbp-modal--toast:not(.kpbp-modal--toast-collapsed)
    .kpbp-toast-content {
    padding: 14px 14px 12px;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast:not(.kpbp-modal--toast-collapsed)
    .kpbp-toast-link {
    padding: 12px 14px 14px;
    border-radius: 0 0 10px 10px;
  }

  .kpbp-overlay--bottom-right
    .kpbp-modal--toast:not(.kpbp-modal--toast-collapsed)
    .kpbp-toast-stack
    > .kpbp-toast-link:only-child {
    border-radius: 10px;
  }

  .kpbp-overlay--bottom-right .kpbp-title {
    font-size: 1rem;
  }

  .kpbp-overlay--bottom-right .kpbp-message,
  .kpbp-overlay--bottom-right .kpbp-toast-description {
    font-size: 0.875rem;
  }

  .kpbp-overlay--bottom-right .kpbp-link-btn {
    padding: 10px 12px;
    font-size: 0.875rem;
  }
}
