/* ==========================================================================
   WPRepeater — front-end output styles.
   Container-responsive (container queries, no viewport media queries).
   Theme-agnostic: inherits the theme's fonts/colors; tune via the custom
   properties below (a theme can override them on .wpr or :root).
   ========================================================================== */

.wpr {
	--wpr-accent: #2f6df6;
	--wpr-ink: inherit;
	--wpr-muted: rgba(0, 0, 0, .55);
	--wpr-line: rgba(0, 0, 0, .12);
	--wpr-surface: rgba(255, 255, 255, .65);
	--wpr-radius: 12px;
	container-type: inline-size;
	font: inherit;
	color: var(--wpr-ink);
}

.wpr-heading { margin: 0 0 6px; font-size: 1.6em; line-height: 1.2; }
.wpr-subheading { margin: 0 0 22px; color: var(--wpr-muted); }
.wpr-empty { color: var(--wpr-muted); font-style: italic; }

.wpr .screen-reader-text {
	position: absolute; width: 1px; height: 1px; overflow: hidden;
	clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap;
}

/* Shared button */
.wpr-btn {
	display: inline-flex; align-items: center; gap: 5px;
	font-size: .82em; font-weight: 700; text-decoration: none;
	color: var(--wpr-accent);
	border: 1.5px solid var(--wpr-accent); border-radius: 999px;
	padding: .5em 1.25em;
	transition: background .18s, color .18s;
}
.wpr-btn:hover { background: var(--wpr-accent); color: #fff; }
.wpr-btn--solid { background: var(--wpr-accent); color: #fff; }
.wpr-btn--solid:hover { filter: brightness(1.1); }

.wpr-badge-pill {
	display: inline-block;
	font-size: .62em; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
	background: var(--wpr-surface); color: var(--wpr-accent);
	border: 1px solid var(--wpr-line); border-radius: 999px;
	padding: .45em 1em; margin-bottom: .6em;
}
.wpr-badge-pill--light { background: rgba(255, 255, 255, .92); color: #1a1d24; border: 0; }

/* Editor-context notice */
.wpr-editor-notice {
	background: #eaf1ff; border-left: 4px solid #2f6df6;
	font-size: .85em; padding: 8px 12px; margin: 0 0 12px; border-radius: 4px;
}

/* ==========================================================================
   Lists
   ========================================================================== */

.wpr-list { list-style: none; margin: 0; padding: 0; }
.wpr-list .wpr-list__item { margin: 0; padding: 18px 0; border-bottom: 1px solid var(--wpr-line); }
.wpr-list .wpr-list__item:first-child { border-top: 1px solid var(--wpr-line); }
.wpr-list__title { margin: 0 0 4px; font-size: 1.1em; line-height: 1.35; }
.wpr-list__title a { color: inherit; text-decoration: none; }
.wpr-list__title a:hover { color: var(--wpr-accent); }
.wpr-list__title--lg { font-size: 1.45em; }
.wpr-list__desc { margin: 4px 0 8px; color: var(--wpr-muted); font-size: .92em; }
.wpr-list__desc p { margin: 0 0 .5em; }
.wpr-list__meta, .wpr-list__metarow { display: flex; flex-wrap: wrap; gap: 4px 20px; font-size: .82em; font-weight: 600; }
.wpr-list__metaitem { display: inline-flex; flex-direction: column; }
.wpr-list__metalabel {
	display: block; font-size: .78em; font-weight: 700;
	letter-spacing: .12em; text-transform: uppercase; color: var(--wpr-muted);
}
.wpr-list .wpr-btn { margin-top: 10px; }

/* simple — meta sits right of the body */
.wpr-list--simple .wpr-list__item { display: flex; gap: 24px; align-items: baseline; justify-content: space-between; }
@container (max-width: 540px) { .wpr-list--simple .wpr-list__item { flex-direction: column; gap: 8px; } }

/* media — thumbnail left */
.wpr-list--media .wpr-list__item { display: flex; gap: 20px; }
.wpr-list--media .wpr-list__media { flex: 0 0 132px; margin: 0; }
.wpr-list--media .wpr-list__media img { width: 132px; height: 96px; object-fit: cover; border-radius: var(--wpr-radius); display: block; }
@container (max-width: 540px) {
	.wpr-list--media .wpr-list__item { flex-direction: column; }
	.wpr-list--media .wpr-list__media { flex-basis: auto; }
	.wpr-list--media .wpr-list__media img { width: 100%; height: auto; aspect-ratio: 16 / 9; }
}

/* divided — kicker column */
.wpr-list--divided .wpr-list__item { display: grid; grid-template-columns: 140px 1fr; gap: 20px; }
.wpr-list--divided .wpr-list__kicker {
	font-weight: 800; color: var(--wpr-accent);
	font-size: .9em; line-height: 1.4; padding-top: 2px;
}
@container (max-width: 540px) { .wpr-list--divided .wpr-list__item { grid-template-columns: 1fr; gap: 4px; } }

/* feature — zig-zag */
.wpr-list--feature .wpr-list__item { display: flex; gap: 28px; align-items: center; padding: 26px 0; }
.wpr-list--feature .wpr-list__item:nth-child(even) { flex-direction: row-reverse; }
.wpr-list--feature .wpr-list__media { flex: 0 0 42%; margin: 0; }
.wpr-list--feature .wpr-list__media img { width: 100%; height: auto; aspect-ratio: 3 / 2; object-fit: cover; border-radius: var(--wpr-radius); display: block; }
@container (max-width: 640px) {
	.wpr-list--feature .wpr-list__item, .wpr-list--feature .wpr-list__item:nth-child(even) { flex-direction: column; align-items: stretch; }
	.wpr-list--feature .wpr-list__media { flex-basis: auto; }
}

/* ==========================================================================
   Tables
   ========================================================================== */

.wpr-tablewrap { overflow-x: auto; }
.wpr-table-el { width: 100%; border-collapse: collapse; font-size: .95em; }
.wpr-table-el thead th {
	text-align: left; font-size: .76em; font-weight: 700;
	letter-spacing: .1em; text-transform: uppercase; color: var(--wpr-muted);
	padding: 10px 14px; border-bottom: 2px solid var(--wpr-line);
}
.wpr-table-el tbody th, .wpr-table-el tbody td {
	text-align: left; font-weight: 400;
	padding: 12px 14px; border-bottom: 1px solid var(--wpr-line); vertical-align: top;
}
.wpr-table-el tbody th { font-weight: 700; }
.wpr-table-el tbody th a { color: inherit; text-decoration: none; }
.wpr-table-el tbody th a:hover { color: var(--wpr-accent); }
.wpr-table--report tbody tr:nth-child(odd) { background: rgba(0, 0, 0, .03); }
.wpr-table__actioncol { text-align: right !important; white-space: nowrap; }

/* Stacked "card rows" in narrow containers */
@container (max-width: 560px) {
	.wpr-table-el thead { display: none; }
	.wpr-table-el tbody tr {
		display: block; border: 1px solid var(--wpr-line);
		border-radius: var(--wpr-radius); padding: 8px 0; margin: 0 0 12px;
	}
	.wpr-table-el tbody th, .wpr-table-el tbody td { display: flex; gap: 12px; border: 0; padding: 6px 14px; }
	.wpr-table-el tbody th::before, .wpr-table-el tbody td::before {
		content: attr(data-label);
		flex: 0 0 38%;
		font-size: .76em; font-weight: 700; letter-spacing: .1em;
		text-transform: uppercase; color: var(--wpr-muted); padding-top: .2em;
	}
	.wpr-table__actioncol { text-align: left !important; }
}

/* ==========================================================================
   Grid / Cards
   ========================================================================== */

.wpr-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(248px, 1fr)); gap: 24px; }
.wpr-grid--compact { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 18px; }
.wpr-grid--horizontal { grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)); }
.wpr-grid--overlay { grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); }
@container (max-width: 560px) { .wpr-grid, .wpr-grid--horizontal { grid-template-columns: 1fr; gap: 18px; } }

.wpr-card {
	position: relative;
	background: var(--wpr-surface);
	border: 1px solid var(--wpr-line);
	border-radius: var(--wpr-radius);
	overflow: hidden;
	display: flex; flex-direction: column;
	transition: transform .22s ease, box-shadow .22s ease;
}
.wpr-card:hover { transform: translateY(-4px); box-shadow: 0 14px 30px rgba(0, 0, 0, .12); }

.wpr-card__media { margin: 0; position: relative; aspect-ratio: 3 / 2; overflow: hidden; }
.wpr-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.wpr-card:hover .wpr-card__media img { transform: scale(1.045); }

.wpr-card__course {
	position: absolute; top: 12px; left: 12px;
	background: rgba(255, 255, 255, .94); color: var(--wpr-accent);
	font-size: .62em; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
	border-radius: 999px; padding: .55em 1.1em;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .22);
}

.wpr-card__body { padding: 16px 18px 18px; display: flex; flex-direction: column; flex: 1; gap: 10px; }
.wpr-card__title { margin: 0; font-size: 1.08em; line-height: 1.3; }
.wpr-card__title a { color: inherit; text-decoration: none; }
.wpr-card__title a:hover { color: var(--wpr-accent); }
.wpr-card__desc { color: var(--wpr-muted); font-size: .9em; }
.wpr-card__desc p { margin: 0 0 .5em; }
.wpr-card__metaline { margin: 0; font-size: .85em; font-weight: 600; }
.wpr-card__metaline span { color: var(--wpr-muted); font-size: .85em; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-right: 4px; }

.wpr-card__meta {
	list-style: none; margin: 0; padding: 9px 0;
	border-top: 1px solid var(--wpr-line); border-bottom: 1px solid var(--wpr-line);
	display: flex; flex-wrap: wrap; gap: 5px 18px;
	font-size: .8em; font-weight: 600;
}
.wpr-card__meta li { display: flex; flex-direction: column; gap: 1px; }
.wpr-card__meta span {
	font-size: .78em; font-weight: 700; letter-spacing: .12em;
	text-transform: uppercase; color: var(--wpr-muted);
}

.wpr-card__btn {
	margin-top: auto; align-self: flex-start;
	display: inline-flex; align-items: center; gap: 4px;
	font-size: .8em; font-weight: 700; text-decoration: none;
	color: var(--wpr-accent);
	border: 1.5px solid var(--wpr-accent); border-radius: 999px; padding: .6em 1.4em;
	transition: background .18s, color .18s, gap .18s;
}
.wpr-card__btn:hover { background: var(--wpr-accent); color: #fff; gap: 8px; }

/* whole-card link helper */
.wpr-card__stretch { color: inherit; text-decoration: none; }
.wpr-card__stretch::after { content: ""; position: absolute; inset: 0; }

/* horizontal */
.wpr-card--horizontal { flex-direction: row; }
.wpr-card--horizontal .wpr-card__media { flex: 0 0 38%; aspect-ratio: auto; min-height: 160px; }
@container (max-width: 560px) {
	.wpr-card--horizontal { flex-direction: column; }
	.wpr-card--horizontal .wpr-card__media { flex-basis: auto; aspect-ratio: 16 / 9; }
}

/* overlay tiles */
.wpr-tile {
	position: relative; border-radius: var(--wpr-radius); overflow: hidden;
	aspect-ratio: 4 / 5; display: flex; align-items: flex-end;
	transition: transform .22s ease, box-shadow .22s ease;
}
.wpr-tile:hover { transform: translateY(-4px); box-shadow: 0 14px 30px rgba(0, 0, 0, .25); }
.wpr-tile__media { position: absolute; inset: 0; margin: 0; }
.wpr-tile__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.wpr-tile__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 35%, rgba(0, 0, 0, .78)); }
.wpr-tile__content { position: relative; padding: 18px 20px; color: #fff; }
.wpr-tile__title { margin: 0; font-size: 1.15em; line-height: 1.25; }
.wpr-tile__title a { color: #fff; text-decoration: none; }
.wpr-tile__meta { margin: 4px 0 0; font-size: .82em; opacity: .85; }

/* ==========================================================================
   Carousels
   ========================================================================== */

.wpr-carousel { position: relative; }
.wpr-carousel__track {
	list-style: none; margin: 0; padding: 4px;
	display: flex; gap: 20px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}
.wpr-carousel__track:focus-visible { outline: 2px solid var(--wpr-accent); outline-offset: 3px; border-radius: 6px; }
.wpr-carousel__slide { scroll-snap-align: start; flex: 0 0 auto; margin: 0; }

.wpr-carousel--cards .wpr-carousel__slide { width: clamp(240px, 31cqw, 340px); display: flex; }
.wpr-carousel--cards .wpr-card { width: 100%; }

.wpr-carousel--hero .wpr-carousel__slide { width: 100%; }
.wpr-hero { position: relative; border-radius: var(--wpr-radius); overflow: hidden; min-height: 320px; display: flex; align-items: center; }
.wpr-hero__media { position: absolute; inset: 0; margin: 0; }
.wpr-hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.wpr-hero__panel {
	position: relative; margin: 36px;
	max-width: min(58cqw, 480px);
	background: rgba(20, 22, 28, .78); color: #fff;
	border-radius: var(--wpr-radius); padding: 26px 30px;
	backdrop-filter: blur(3px);
}
.wpr-hero__title { margin: 0 0 8px; font-size: 1.5em; line-height: 1.2; }
.wpr-hero__desc { font-size: .92em; opacity: .9; margin: 0 0 16px; }
.wpr-hero__desc p { margin: 0 0 .5em; }
@container (max-width: 560px) {
	.wpr-hero { min-height: 0; align-items: flex-end; }
	.wpr-hero__panel { margin: 14px; max-width: none; padding: 18px 20px; }
}

.wpr-carousel--media .wpr-carousel__slide { width: clamp(220px, 36cqw, 420px); }
.wpr-strip { margin: 0; }
.wpr-strip img { width: 100%; height: auto; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--wpr-radius); display: block; }
.wpr-strip__caption { font-size: .82em; color: var(--wpr-muted); padding: 8px 2px 0; }

.wpr-carousel--quote .wpr-carousel__slide { width: 100%; }
.wpr-quote { margin: 0; text-align: center; padding: 26px clamp(16px, 10cqw, 90px); }
.wpr-quote__avatar img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; margin: 0 auto 14px; display: block; }
.wpr-quote__text { margin: 0 0 12px; font-size: 1.25em; line-height: 1.5; font-style: italic; }
.wpr-quote__text p { margin: 0 0 .5em; }
.wpr-quote__by { font-size: .85em; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--wpr-muted); }

.wpr-carousel__nav { display: flex; gap: 8px; justify-content: flex-end; margin-top: 12px; }
.wpr-carousel__btn {
	width: 38px; height: 38px; border-radius: 50%;
	border: 1.5px solid var(--wpr-accent); background: transparent; color: var(--wpr-accent);
	font-size: 20px; line-height: 1; cursor: pointer;
	display: grid; place-items: center;
	transition: background .18s, color .18s, opacity .18s;
}
.wpr-carousel__btn:hover { background: var(--wpr-accent); color: #fff; }
.wpr-carousel__btn[disabled] { opacity: .35; cursor: default; }
.wpr-carousel__btn[disabled]:hover { background: transparent; color: var(--wpr-accent); }
