/**
 * Frontend + editor preview styles for the Firecrown Popular Topics block.
 *
 * Layout: optional colored header bar at the top, then a 2-column padded
 * body — image on the left (with breathing room), separator-divided topic
 * list on the right, optional CTA button below.
 */

.firecrown-popular-topics {
	font-family: inherit;
	margin: 0 0 2em 0;
	max-width: 100%;
	box-sizing: border-box;
}

.firecrown-popular-topics *,
.firecrown-popular-topics *::before,
.firecrown-popular-topics *::after {
	box-sizing: border-box;
}

/* Colored header bar (the red "POPULAR TOPICS" strip). */
.firecrown-popular-topics .firecrown-popular-topics__header {
	display: block;
	padding: 14px 20px !important;
	margin: 0 !important;
	font-weight: 700;
	font-size: 1.05em;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	line-height: 1.2;
}

/* Plain (no-bar) heading variant. */
.firecrown-popular-topics .firecrown-popular-topics__plain-heading {
	margin: 0 0 1em 0 !important;
	padding: 1.5rem 1.5rem 0 1.5rem !important;
	font-weight: 700;
	line-height: 1.2;
}

/* Body: image left, right column (topics + button) right. Always padded. */
.firecrown-popular-topics .firecrown-popular-topics__body {
	display: flex !important;
	gap: 2rem;
	align-items: flex-start;
	padding: 1.75rem 1.75rem 2rem 1.75rem;
}

/* Image (left) - has its own breathing room thanks to body padding + gap. */
.firecrown-popular-topics .firecrown-popular-topics__image {
	flex: 0 0 auto;
	width: 38%;
	max-width: 340px;
	margin: 0 !important;
	padding: 0 !important;
}

.firecrown-popular-topics .firecrown-popular-topics__image a {
	display: block;
}

.firecrown-popular-topics .firecrown-popular-topics__image img {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
	max-height: var( --fpt-image-max-height, 500px ) !important;
	object-fit: contain;
	object-position: center top;
	margin: 0 auto !important;
	padding: 0 !important;
	border: 0 !important;
	visibility: visible !important;
	opacity: 1 !important;
}

.firecrown-popular-topics .firecrown-popular-topics__image--placeholder {
	background: #f3f3f3;
	border: 1px dashed #c0c0c0;
	min-height: 220px;
	width: 38%;
	max-width: 340px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #777;
	font-size: 0.85em;
	text-align: center;
	padding: 1em;
}

/* Right column: topic list + (optional) button. */
.firecrown-popular-topics .firecrown-popular-topics__right {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	min-width: 0;
}

/* Topic list. Reset list styles so theme bullets don't show. */
.firecrown-popular-topics ul.firecrown-popular-topics__topics,
.firecrown-popular-topics .firecrown-popular-topics__topics {
	list-style: none !important;
	list-style-type: none !important;
	list-style-image: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex;
	flex-direction: column;
}

.firecrown-popular-topics .firecrown-popular-topics__topic {
	list-style: none !important;
	list-style-type: none !important;
	margin: 0 !important;
	padding: 1rem 0 !important;
	background: none !important;
	background-image: none !important;
	border-top: 1px solid var( --fpt-separator, #E0E0E0 );
}

.firecrown-popular-topics .firecrown-popular-topics__topic:first-child {
	border-top: 0;
	padding-top: 0 !important;
}

.firecrown-popular-topics .firecrown-popular-topics__topic:last-child {
	padding-bottom: 0 !important;
}

.firecrown-popular-topics .firecrown-popular-topics__topic::before,
.firecrown-popular-topics .firecrown-popular-topics__topic::after {
	content: none !important;
	display: none !important;
}

/* Topic title. */
.firecrown-popular-topics .firecrown-popular-topics__topic-title {
	margin: 0 0 0.3em 0 !important;
	padding: 0 !important;
	font-weight: 700;
	font-size: 1.1em;
	line-height: 1.3;
	text-transform: none;
	letter-spacing: 0;
}

.firecrown-popular-topics .firecrown-popular-topics__topic-title a {
	color: inherit;
	text-decoration: none;
}

.firecrown-popular-topics .firecrown-popular-topics__topic-title a:hover,
.firecrown-popular-topics .firecrown-popular-topics__topic-title a:focus {
	text-decoration: underline;
}

/* Topic description. */
.firecrown-popular-topics .firecrown-popular-topics__topic-description {
	margin: 0 !important;
	padding: 0 !important;
	font-size: 0.92em;
	line-height: 1.5;
}

/* Optional small text-CTA under each topic. */
.firecrown-popular-topics .firecrown-popular-topics__topic-cta {
	margin: 0.5em 0 0 0 !important;
	padding: 0 !important;
	font-size: 0.78em;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-weight: 700;
}

.firecrown-popular-topics .firecrown-popular-topics__topic-cta a {
	text-decoration: none;
	border-bottom: 1px solid currentColor;
	padding-bottom: 1px;
}

.firecrown-popular-topics .firecrown-popular-topics__topic-cta a:hover,
.firecrown-popular-topics .firecrown-popular-topics__topic-cta a:focus {
	border-bottom-color: transparent;
}

/* Bottom CTA button. */
.firecrown-popular-topics .firecrown-popular-topics__button-wrap {
	margin: 1.5rem 0 0 0;
}

.firecrown-popular-topics .firecrown-popular-topics__button {
	display: inline-block !important;
	padding: 0.7em 1.6em !important;
	margin: 0 !important;
	font-weight: 600;
	font-size: 0.95em;
	line-height: 1.2;
	text-decoration: none !important;
	border: 1px solid transparent;
	border-radius: 2px;
	transition: opacity 0.15s ease-in-out;
}

.firecrown-popular-topics .firecrown-popular-topics__button:hover,
.firecrown-popular-topics .firecrown-popular-topics__button:focus {
	opacity: 0.88;
	text-decoration: none !important;
}

/* ----- Responsive breakpoints -----
 *
 * > 782px (desktop / wide tablet): two columns — image left, topics right.
 *  ≤ 782px (mobile / tablet portrait): stacked — image on top, topics below.
 *
 * 782px matches WordPress's standard mobile threshold and keeps the
 * side-by-side layout breathable on tablet portrait widths.
 */
@media (max-width: 782px) {
	.firecrown-popular-topics .firecrown-popular-topics__body {
		flex-direction: column !important;
		align-items: stretch;
		gap: 1.25rem;
		padding: 1.25rem;
	}
	.firecrown-popular-topics .firecrown-popular-topics__image,
	.firecrown-popular-topics .firecrown-popular-topics__image--placeholder {
		width: 100%;
		max-width: 100%;
	}
}

/* Inside narrow widget areas, also stack. */
.widget .firecrown-popular-topics .firecrown-popular-topics__body,
.widget_block .firecrown-popular-topics .firecrown-popular-topics__body {
	flex-direction: column;
	align-items: stretch;
	padding: 1.25rem;
}
.widget .firecrown-popular-topics .firecrown-popular-topics__image,
.widget_block .firecrown-popular-topics .firecrown-popular-topics__image,
.widget .firecrown-popular-topics .firecrown-popular-topics__image--placeholder,
.widget_block .firecrown-popular-topics .firecrown-popular-topics__image--placeholder {
	width: 100%;
	max-width: 100%;
}
