/* PWC Cards component */
.pwc-cards {
  width: 100%;
}

.pwc-cards__title {
  margin: 0 0 1.25rem;
  font-size: clamp(1.5rem, 1.1vw + 1.3rem, 2rem);
  font-weight: 700;
  color: var(--pwc-heading-color, inherit);
}

/* Grid */
/* Grid uses responsive CSS custom properties derived from configured desktop column count.
   Provided vars (inline style):
     --pwc-cols-sm: min(configured,2)
     --pwc-cols-md: min(configured,3)
     --pwc-cols-lg: configured
*/
.pwc-cards__grid {
  display: grid;
  gap: var(--pwc-gap, var(--pwc-gap-default, 1rem));
  grid-template-columns: repeat(1, minmax(0, 1fr)); /* xs */
}

@media (min-width: 640px) { /* sm */
  .pwc-cards__grid {
    grid-template-columns: repeat(var(--pwc-cols-sm, 1), minmax(0, 1fr));
  }
}

@media (min-width: 768px) { /* md */
  .pwc-cards__grid {
    grid-template-columns: repeat(var(--pwc-cols-md, var(--pwc-cols-sm, 1)), minmax(0, 1fr));
  }
}

@media (min-width: 1024px) { /* lg */
  .pwc-cards__grid {
    grid-template-columns: repeat(var(--pwc-cols-lg, var(--pwc-cols-md, 3)), minmax(0, 1fr));
  }
}

/* Card wrapper uses CSS vars for theme control */
.pwc-card,
.pwc-card__link {
  display: flex;
  flex-direction: column;
  background: var(--pwc-card-bg, var(--pwc-surface));
  border-style: var(--pwc-card-border-style, var(--pwc-border-style));
  border-width: var(--pwc-card-border-width, var(--pwc-border-width));
  border-color: var(--pwc-card-border-color, var(--pwc-border-color));
  overflow: hidden;
  text-decoration: none;
  color: var(--pwc-card-text-color, inherit);
  border-radius: var(--pwc-card-radius, 0);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  height: 100%;
}

.pwc-card__link:hover,
.pwc-card__link:focus {
  transform: translateY(-2px);
  box-shadow: var(--pwc-card-shadow);
}

/* Allow “border style” field to set style+width in one token like 'dashed 1px var(--pwc-border-color)' */
.pwc-card[style*="--pwc-card-border:"],
.pwc-card__link[style*="--pwc-card-border:"] {
  border: var(--pwc-card-border, var(--pwc-border-width) var(--pwc-border-style) var(--pwc-border-color));
}

/* Headings inside the component */
.pwc-cards .pwc-card h3,
.pwc-cards .pwc-card__link h3 {
  color: var(--pwc-h3-color, var(--pwc-heading-color, inherit));
  margin: 0 0 0.5rem;
  font-weight: 700;
  font-size: 1.125rem;
}

/* Image modes */
.pwc-card__media,
.pwc-card__img-wrap {
  position: relative;
  overflow: hidden;
  border-radius: inherit;
}

.pwc-card__img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
  border-radius: inherit;
}

.pwc-card__title {
  font-size: larger;
}

.pwc-card__title--overlay {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  margin: 0;
  /* Default to white text and a dark backing for readability; allow theme overrides */
  color: var(--pwc-overlay-title-color, #fff);
  background: var(--pwc-overlay-title-bg, rgba(0, 0, 0, 0.65));
  padding: 0.25rem 0.5rem;
  font-weight: 700;
  border-radius: var(--pwc-overlay-title-radius, 0);
}

/* Body + button */
.pwc-card__body {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  flex: 1 1 auto; /* ensure background fills to bottom */
}

.pwc-card__body .button {
  align-self: flex-start;
  width: auto;
  min-width: 0;
}

.pwc-card__desc {
  font-size: 0.95rem;
  line-height: 1.6;
}

/* Visual styling comes from the active theme's .button class; we only adjust layout. */

/* Variant hooks */
.pwc-cards--image-overlay .pwc-card__body { background: var(--pwc-card-bg, var(--pwc-surface)); }

.pwc-card--no-image .pwc-card__body {
  padding-top: 1.5rem;
}

/* Spacing guard so buttons do not push backgrounds oddly */
.pwc-card__body > *:last-child { margin-bottom: 0; }

@media (prefers-reduced-motion: reduce) {
  .pwc-card,
  .pwc-card__link {
    transition: none;
  }
}

:root {
/* PwC Cards component tokens */
  --pwc-surface: var(--colour-bg-body, #fff);
  --pwc-border-style: solid;
  --pwc-border-width: 1px;
  --pwc-border-color: var(--colour-dividers, #e0e0e0);
  --pwc-heading-color: var(--colour-near-black, #111);
  --pwc-h3-color: var(--pwc-heading-color);
  --pwc-gap-default: 1rem;
  --pwc-gap-0: 0;
  --pwc-gap-1: 0.25rem;
  --pwc-gap-2: 0.5rem;
  --pwc-gap-3: 0.75rem;
  --pwc-gap-4: 1rem;
  --pwc-gap-6: 1.5rem;
  --pwc-gap-8: 2rem;
  --pwc-overlay-title-color: var(--colour-bg-body, #fff);
  --pwc-overlay-title-bg: color-mix(in srgb, var(--colour-near-black, #111) 65%, transparent);
  --pwc-button-hover-bg: color-mix(in srgb, var(--colour-bg-body, #fff) 85%, var(--colour-near-black, #111) 15%);
  --pwc-button-hover-color: var(--colour-near-black, #111);
  --pwc-button-radius: var(--corner_radius-large, 0.5rem);
  --pwc-card-overlay-body-bg: color-mix(in srgb, var(--colour-bg-body, #fff) 92%, var(--colour-near-black, #111) 8%);
}