.wapa-widget {
  --wapa-bg: #ffffff;
  --wapa-text: #111827;
  --wapa-text-muted: #4b5563;
  --wapa-border: #e5e7eb;
  --wapa-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);
  --wapa-shadow-hover: 0 10px 25px rgba(0, 0, 0, 0.15), 0 4px 10px rgba(0, 0, 0, 0.1);
  --wapa-radius: 12px;
  --wapa-radius-sm: 8px;
  --wapa-accent: #d97706;
  --wapa-accent-hover: #b45309;
  --wapa-badge-bg: #111827;
  --wapa-badge-text: #ffffff;
  --wapa-cta-text: #111827;
  --wapa-img-bg: #f3f4f6;

  margin: 2em 0;
  width: 100%;
  background: var(--wapa-bg);
  color: var(--wapa-text);
  /* Clear surrounding theme floats: the widget establishes an independent
     formatting context and would otherwise shrink to fit beside a float,
     collapsing to near-zero width. */
  clear: both;
}

@media (prefers-color-scheme: dark) {
  .wapa-widget {
    --wapa-bg: #1f2937;
    --wapa-text: #f9fafb;
    --wapa-text-muted: #d1d5db;
    --wapa-border: #374151;
    --wapa-shadow: 0 1px 3px rgba(0, 0, 0, 0.3), 0 1px 2px rgba(0, 0, 0, 0.2);
    --wapa-shadow-hover: 0 10px 25px rgba(0, 0, 0, 0.5), 0 4px 10px rgba(0, 0, 0, 0.3);
    --wapa-accent: #fbbf24;
    --wapa-accent-hover: #f59e0b;
    --wapa-badge-bg: #f9fafb;
    --wapa-badge-text: #111827;
    --wapa-cta-text: #111827;
    --wapa-img-bg: #374151;
  }
}

.wapa-heading {
  margin: 0 0 0.5em;
  line-height: 1.3;
  font-size: 1.25em;
  font-weight: 700;
  color: var(--wapa-text);
}

.wapa-intro {
  margin: 0 0 1em;
  color: var(--wapa-text-muted);
}

.wapa-disclosure {
  margin: 1em 0 0;
  font-size: 10px;
  color: var(--wapa-text-muted);
}

.wapa-herolist {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1em;
  width: 100%;
}

@media (min-width: 700px) {
  .wapa-herolist {
    grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  }
}

a.wapa-cta {
  display: block;
  color: var(--wapa-text);
  text-decoration: none;
  background: var(--wapa-bg);
  border: 1px solid var(--wapa-border);
  border-radius: var(--wapa-radius);
  overflow: hidden;
  box-shadow: var(--wapa-shadow);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

a.wapa-cta:hover,
a.wapa-cta:focus-visible {
  transform: translateY(-2px);
  box-shadow: var(--wapa-shadow-hover);
  outline: none;
}

a.wapa-cta:focus-visible {
  outline: 2px solid var(--wapa-accent);
  outline-offset: 2px;
}

.wapa-img-wrap {
  position: relative;
  overflow: hidden;
  background: var(--wapa-img-bg);
}

.wapa-img-wrap img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  transition: transform 0.4s ease;
}

.wapa-hero:hover .wapa-img-wrap img {
  transform: scale(1.05);
}

.wapa-hero .wapa-title {
  display: block;
  margin: 0.75em 1em 0.25em;
  font-weight: 600;
  font-size: 1.1em;
  line-height: 1.4;
  color: var(--wapa-text);
}

.wapa-blurb {
  display: block;
  margin: 0 1em 0.25em;
  font-size: 0.9em;
  color: var(--wapa-text-muted);
  line-height: 1.4;
}

.wapa-urgency {
  display: block;
  margin: 0 1em 0.5em;
  font-size: 0.85em;
  font-weight: 500;
  color: var(--wapa-accent);
  line-height: 1.3;
}

.wapa-discount {
  display: block;
  margin: 0 1em 0.5em;
  font-size: 0.85em;
  font-weight: 600;
  color: var(--wapa-accent);
  line-height: 1.3;
}

.wapa-badge {
  position: absolute;
  top: 0.75em;
  left: 0.75em;
  padding: 0.3em 0.7em;
  border-radius: 999px;
  background: var(--wapa-badge-bg);
  color: var(--wapa-badge-text);
  font-size: 0.7em;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.wapa-row .wapa-badge {
  position: static;
  display: inline-block;
  padding: 0.15em 0.5em;
  font-size: 0.65em;
  margin-bottom: 0.25em;
}

.wapa-cta-button {
  display: inline-block;
  align-self: start;
  margin: 0 1em 1em;
  padding: 0.6em 1.2em;
  border-radius: var(--wapa-radius-sm);
  background: var(--wapa-accent);
  color: var(--wapa-cta-text);
  font-weight: 600;
  font-size: 0.9em;
  transition: background 0.2s ease;
}

a.wapa-cta:hover .wapa-cta-button,
a.wapa-cta:focus-visible .wapa-cta-button {
  background: var(--wapa-accent-hover);
}

.wapa-list {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}

.wapa-row {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  align-items: center;
  gap: 0.75em;
  padding: 0.5em;
  border-radius: var(--wapa-radius-sm);
  transition: background 0.2s ease;
}

a.wapa-cta.wapa-row:hover,
a.wapa-cta.wapa-row:focus-visible {
  background: var(--wapa-img-bg);
  transform: none;
  box-shadow: none;
}

.wapa-row .wapa-img-wrap {
  width: 64px;
  border-radius: var(--wapa-radius-sm);
}

.wapa-row .wapa-title {
  font-weight: 500;
  font-size: 0.95em;
  line-height: 1.3;
  color: var(--wapa-text);
}

.wapa-row .wapa-cta-button {
  margin: 0;
  padding: 0;
  background: none;
  color: inherit;
}

.wapa-row .wapa-cta-button::after {
  content: '\203A';
  font-size: 1.5rem;
  color: var(--wapa-accent);
  transition: transform 0.2s ease;
}

a.wapa-cta.wapa-row:hover .wapa-cta-button::after,
a.wapa-cta.wapa-row:focus-visible .wapa-cta-button::after {
  transform: translateX(2px);
}

.wapa-show-more {
  display: inline-block;
  margin: 0.75em 0 0;
  padding: 0.5em 1.1em;
  border: 1px solid var(--wapa-border);
  border-radius: var(--wapa-radius-sm);
  background: var(--wapa-bg);
  color: var(--wapa-text);
  font-weight: 600;
  font-size: 0.9em;
  cursor: pointer;
  transition: background 0.2s ease;
}

.wapa-show-more:hover,
.wapa-show-more:focus-visible {
  background: var(--wapa-img-bg);
  outline: 2px solid var(--wapa-accent);
  outline-offset: 2px;
}

.wapa-carousel {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.5em;
  width: 100%;
}

.wapa-carousel-track {
  display: flex;
  gap: 1em;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.wapa-carousel-track::-webkit-scrollbar {
  display: none;
}

.wapa-carousel-track .wapa-slide {
  flex: 0 0 78%;
  max-width: 280px;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
}

@media (min-width: 700px) {
  .wapa-carousel-track .wapa-slide {
    flex-basis: 240px;
  }
}

.wapa-slide .wapa-img-wrap {
  aspect-ratio: 4 / 3;
}

.wapa-slide .wapa-img-wrap img {
  height: 100%;
  object-fit: cover;
}

.wapa-slide .wapa-title {
  display: block;
  margin: 0.75em 0.9em 0.35em;
  font-weight: 600;
  font-size: 1em;
  line-height: 1.35;
  color: var(--wapa-text);
}

.wapa-slide .wapa-cta-button {
  margin: auto 0.9em 0.9em;
  align-self: stretch;
  text-align: center;
}

.wapa-carousel-prev,
.wapa-carousel-next {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2em;
  height: 2.2em;
  border: 1px solid var(--wapa-border);
  border-radius: 999px;
  background: var(--wapa-bg);
  color: var(--wapa-text);
  font-size: 1.4em;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s ease;
}

.wapa-carousel-prev:hover,
.wapa-carousel-prev:focus-visible,
.wapa-carousel-next:hover,
.wapa-carousel-next:focus-visible {
  background: var(--wapa-img-bg);
  outline: 2px solid var(--wapa-accent);
  outline-offset: 2px;
}

.wapa-ad {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1em;
  width: 100%;
}

@media (min-width: 700px) {
  .wapa-ad {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  }
}

.wapa-ad-card {
  display: flex;
  flex-direction: column;
}

.wapa-ad-card .wapa-img-wrap {
  aspect-ratio: 4 / 3;
}

.wapa-ad-card .wapa-img-wrap img {
  height: 100%;
  object-fit: cover;
}

.wapa-ad-card .wapa-title {
  display: block;
  margin: 0.75em 0.9em 0.35em;
  font-weight: 600;
  font-size: 1em;
  line-height: 1.35;
  color: var(--wapa-text);
}

.wapa-ad-card .wapa-cta-button {
  margin: auto 0.9em 0.9em;
  align-self: stretch;
  text-align: center;
}

.wapa-ad-label {
  position: absolute;
  top: 0.5em;
  right: 0.5em;
  padding: 0.2em 0.55em;
  border-radius: var(--wapa-radius-sm);
  background: var(--wapa-badge-bg);
  color: var(--wapa-badge-text);
  font-size: 0.65em;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.wapa-compact {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em;
  width: 100%;
}

@media (max-width: 699px) {
  .wapa-compact {
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .wapa-compact::-webkit-scrollbar {
    display: none;
  }
}

.wapa-compact-card {
  flex: 0 0 140px;
  max-width: 160px;
  display: flex;
  flex-direction: column;
  box-shadow: none;
}

.wapa-compact-card .wapa-img-wrap {
  aspect-ratio: 1 / 1;
  border-top-left-radius: var(--wapa-radius);
  border-top-right-radius: var(--wapa-radius);
}

.wapa-compact-card .wapa-img-wrap img {
  height: 100%;
  object-fit: cover;
}

.wapa-compact-card .wapa-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  /* Reserve exactly two lines so every card's title block is the same height.
     Combined with the square image and hidden editorial copy below, this keeps
     the image, title and CTA aligned across cards regardless of title length. */
  min-height: 2.6em;
  margin: 0.5em 0.6em 0.35em;
  font-weight: 600;
  font-size: 0.85em;
  line-height: 1.3;
  color: var(--wapa-text);
}

/* Compact is a light, secondary placement: editorial copy (blurb, urgency,
   discount) belongs to the hero/list formats. Omitting it here keeps every
   compact card the same shape regardless of which fields a product carries. */
.wapa-compact-card .wapa-blurb,
.wapa-compact-card .wapa-urgency,
.wapa-compact-card .wapa-discount {
  display: none;
}

.wapa-compact-card .wapa-cta-button {
  margin: auto 0.6em 0.6em;
  padding: 0.4em 0.8em;
  align-self: stretch;
  text-align: center;
  font-size: 0.8em;
}

.wapa-pick {
  display: flex;
  flex-direction: column;
  gap: 1em;
  width: 100%;
}

.wapa-pick-hero {
  display: grid;
  grid-template-columns: 1fr;
}

@media (min-width: 700px) {
  .wapa-pick-hero {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    align-items: stretch;
  }
}

.wapa-pick-hero .wapa-img-wrap {
  aspect-ratio: 4 / 3;
}

.wapa-pick-hero .wapa-img-wrap img {
  height: 100%;
  object-fit: cover;
}

.wapa-pick-hero:hover .wapa-img-wrap img {
  transform: scale(1.05);
}

.wapa-pick-hero .wapa-title {
  display: block;
  margin: 0.85em 1em 0.35em;
  font-weight: 700;
  font-size: 1.3em;
  line-height: 1.3;
  color: var(--wapa-text);
}

.wapa-pick-hero .wapa-blurb {
  font-size: 1em;
}

.wapa-pick-hero .wapa-cta-button {
  margin: 0.5em 1em 1.1em;
  padding: 0.7em 1.4em;
  font-size: 1em;
}

.wapa-pick-more {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em;
  width: 100%;
}

@media (max-width: 699px) {
  .wapa-pick-more {
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .wapa-pick-more::-webkit-scrollbar {
    display: none;
  }
}

.wapa-pick-more-card {
  flex: 0 0 150px;
  max-width: 180px;
  display: flex;
  flex-direction: column;
  box-shadow: none;
}

.wapa-pick-more-card .wapa-img-wrap {
  aspect-ratio: 1 / 1;
  border-top-left-radius: var(--wapa-radius);
  border-top-right-radius: var(--wapa-radius);
}

.wapa-pick-more-card .wapa-img-wrap img {
  height: 100%;
  object-fit: cover;
}

.wapa-pick-more-card .wapa-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  min-height: 2.6em;
  margin: 0.5em 0.7em 0.35em;
  font-weight: 600;
  font-size: 0.9em;
  line-height: 1.3;
  color: var(--wapa-text);
}

/* The supporting row is a compact secondary strip: drop the longer editorial
   copy so every card keeps the same shape regardless of which fields a product
   carries. The hero above carries the full editorial treatment. */
.wapa-pick-more-card .wapa-blurb,
.wapa-pick-more-card .wapa-urgency,
.wapa-pick-more-card .wapa-discount {
  display: none;
}

.wapa-pick-more-card .wapa-cta-button {
  margin: auto 0.7em 0.7em;
  padding: 0.45em 0.9em;
  align-self: stretch;
  text-align: center;
  font-size: 0.8em;
}

.wapa-animate {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.wapa-animate.wapa-visible {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .wapa-img-wrap img,
  .wapa-hero:hover .wapa-img-wrap img,
  a.wapa-cta,
  a.wapa-cta:hover,
  a.wapa-cta:focus-visible,
  .wapa-cta-button,
  .wapa-cta-button::after {
    transition: none;
    transform: none;
  }

  .wapa-animate {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .wapa-carousel-track {
    scroll-behavior: auto;
  }

  .wapa-show-more,
  .wapa-carousel-prev,
  .wapa-carousel-next {
    transition: none;
  }
}
