/* ============================================================
 * Novara v7.3.2 — Content Media Refinement
 * Professional rendering fixes for article bodies, cards, galleries,
 * aligned images and video embeds. Pure refinement; no redesign.
 * ============================================================ */

/* 1) Card/category thumbnails — always block-level and stable */
.novara-card__thumb,
.novara-post-card__thumb,
.novara-trending__thumb {
	display: block;
	width: 100%;
	line-height: 0;
	isolation: isolate;
}
.novara-card__thumb img,
.novara-post-card__thumb img,
.novara-trending__thumb img,
.novara-visual-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.novara-card__thumb .novara-thumb-placeholder {
	display: flex;
	width: 100%;
	height: 100%;
	min-height: 220px;
	border-radius: inherit;
}

/* 2) Featured/article images */
.novara-single__featured,
.novara-single__content figure,
.entry-content figure,
.wp-caption,
.wp-block-image {
	max-width: 100%;
}
.novara-single__featured {
	max-width: min(100%, 980px);
	max-height: none;
	aspect-ratio: auto;
	padding: 0;
	background: transparent;
}
.novara-single__featured img {
	display: block;
	width: 100%;
	height: auto !important;
	max-height: none !important;
	object-fit: contain !important;
	object-position: center;
	transform: none !important;
}
.novara-single__content figure,
.entry-content figure,
.wp-block-image,
.wp-caption {
	margin: 1.75rem auto;
}
.novara-single__content img,
.entry-content img,
.wp-block-image img,
.wp-caption img,
figure img {
	display: block;
	max-width: 100%;
	width: auto;
	height: auto !important;
	max-height: none;
	object-fit: contain !important;
	object-position: center;
	transform: none !important;
	border-radius: clamp(10px, 1.4vw, 16px);
}
.novara-single__content figcaption,
.entry-content figcaption,
.wp-caption-text,
.wp-block-image figcaption {
	margin-top: 0.75rem;
	text-align: center;
	font-size: 13px;
	line-height: 1.55;
	color: var(--text-muted);
}

/* 3) Paragraph/image coexistence + float stability */
.novara-single__content,
.entry-content {
	overflow-wrap: break-word;
}
.novara-single__content::after,
.entry-content::after {
	content: "";
	display: block;
	clear: both;
}
.novara-single__content > * + *,
.entry-content > * + * {
	margin-top: 1.15rem;
}
.novara-single__content p,
.entry-content p {
	max-width: none;
}
.novara-single__content .alignleft,
.entry-content .alignleft {
	float: left;
	max-width: min(42%, 340px);
	margin: 0.3rem 1.5rem 1rem 0;
}
.novara-single__content .alignright,
.entry-content .alignright {
	float: right;
	max-width: min(42%, 340px);
	margin: 0.3rem 0 1rem 1.5rem;
}
.novara-single__content .aligncenter,
.entry-content .aligncenter {
	margin-left: auto;
	margin-right: auto;
}
@media (max-width: 768px) {
	.novara-single__content .alignleft,
	.novara-single__content .alignright,
	.entry-content .alignleft,
	.entry-content .alignright {
		float: none;
		display: block;
		max-width: 100%;
		margin: 1rem auto;
	}
	.novara-single__featured {
		margin: 20px auto;
	}
}

/* Reactions — full + compact */
.novara-reactions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}
.novara-reaction-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 42px;
	padding: 10px 14px;
	border: 1px solid var(--border-color);
	border-radius: 999px;
	background: var(--bg-elevated, #fff);
	color: var(--text-primary);
	line-height: 1;
	transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}
.novara-reaction-btn:hover,
.novara-reaction-btn:focus-visible {
	border-color: var(--novara-crimson, #E63946);
	box-shadow: 0 10px 24px rgba(230,57,70,.12);
	transform: translateY(-1px);
}
.novara-reaction-btn.is-active {
	background: rgba(230,57,70,.08);
	border-color: var(--novara-crimson, #E63946);
	color: var(--novara-crimson, #E63946);
}
.novara-reaction-emoji {
	font-size: 1.05rem;
}
.novara-reaction-count {
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}
.novara-reactions--full {
	margin: 2rem 0;
	justify-content: flex-start;
}
.novara-reactions--compact {
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid var(--border-color);
	justify-content: flex-start;
}
.novara-reactions--compact .novara-reaction-btn {
	min-height: 36px;
	padding: 8px 10px;
	font-size: 13px;
	gap: 6px;
}
.novara-reactions--compact .novara-reaction-label {
	display: none;
}
[data-theme="dark"] .novara-reaction-btn {
	background: rgba(255,255,255,.04);
}

/* 4) Gutenberg galleries / media blocks */
.wp-block-gallery,
.blocks-gallery-grid {
	gap: clamp(10px, 1.4vw, 16px);
}
.wp-block-gallery img,
.blocks-gallery-grid img {
	width: 100%;
	height: auto;
	object-fit: contain;
}
.wp-block-cover,
.wp-block-media-text,
.wp-block-image,
.wp-block-gallery,
.wp-block-video {
	margin-top: 1.6rem;
	margin-bottom: 1.6rem;
}
.wp-block-media-text {
	align-items: center;
	gap: clamp(18px, 2vw, 28px);
}

/* 5) Responsive YouTube / Vimeo / raw iframe embeds */
.novara-embed {
	position: relative;
	margin: 1.8rem auto;
	max-width: 100%;
	border-radius: clamp(12px, 1.6vw, 18px);
	overflow: hidden;
	background: #0f1620;
	box-shadow: 0 12px 36px rgba(15, 22, 32, 0.12);
}
.novara-embed__inner {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
}
.novara-embed iframe,
.novara-embed video,
.novara-embed object,
.novara-embed embed {
	position: absolute;
	inset: 0;
	width: 100% !important;
	height: 100% !important;
	border: 0;
	display: block;
}
/* Social embeds can be taller than video */
.novara-embed--social .novara-embed__inner {
	aspect-ratio: auto;
	min-height: 420px;
}
/* Raw iframes not wrapped yet — give them sane sizing */
.novara-single__content iframe,
.entry-content iframe {
	display: block;
	width: 100%;
	max-width: 100%;
	border: 0;
}
.novara-single__content iframe[src*="youtube.com"],
.novara-single__content iframe[src*="youtu.be"],
.novara-single__content iframe[src*="vimeo.com"],
.entry-content iframe[src*="youtube.com"],
.entry-content iframe[src*="youtu.be"],
.entry-content iframe[src*="vimeo.com"] {
	aspect-ratio: 16 / 9;
	min-height: clamp(220px, 36vw, 520px);
	height: auto;
	border-radius: clamp(12px, 1.6vw, 18px);
	overflow: hidden;
	background: #0f1620;
}
/* Undo over-aggressive iframe auto-height from prior polish layers */
iframe[src*="youtube.com"],
iframe[src*="youtu.be"],
iframe[src*="vimeo.com"] {
	height: auto;
}

/* 6) WordPress embed wrappers */
.wp-block-embed,
.wp-block-video,
.wp-block-embed__wrapper {
	max-width: 100%;
}
.wp-block-embed.is-type-video,
.wp-block-embed.is-provider-youtube,
.wp-block-embed.is-provider-vimeo,
.wp-block-video {
	margin: 1.8rem auto;
}
.wp-block-embed.is-type-video iframe,
.wp-block-embed.is-provider-youtube iframe,
.wp-block-embed.is-provider-vimeo iframe,
.wp-block-video video {
	width: 100%;
	max-width: 100%;
	border-radius: clamp(12px, 1.6vw, 18px);
	background: #0f1620;
}

/* 7) Dark-mode polish */
[data-theme="dark"] .novara-embed {
	background: #05070b;
	box-shadow: 0 14px 44px rgba(0, 0, 0, 0.35);
}
[data-theme="dark"] .wp-caption-text,
[data-theme="dark"] .wp-block-image figcaption,
[data-theme="dark"] .entry-content figcaption {
	color: rgba(255,255,255,0.68);
}
