/**
 * Query Forge Widget Styles
 */

.qf-grid {
	display: grid;
	gap: 20px;
}

.qf-card {
	background: #fff;
	border-radius: 8px;
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.qf-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.qf-card-inner {
	display: flex;
	flex-direction: column;
	height: 100%;
}

/* Horizontal Card */
.qf-card-horizontal {
	flex-direction: row;
}

.qf-card-horizontal .qf-card-image {
	flex: 0 0 40%;
	min-width: 150px;
}

.qf-card-horizontal .qf-card-image img,
.qf-card-horizontal .qf-card-image-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.qf-card-horizontal .qf-card-content {
	flex: 1;
	padding: 20px;
}

/* Vertical Card */
.qf-card-vertical .qf-card-image {
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.qf-card-vertical .qf-card-image img,
.qf-card-vertical .qf-card-image-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.qf-card-vertical .qf-card-content {
	padding: 20px;
	flex: 1;
}

/* Minimal List */
.qf-card-minimal .qf-card-content {
	padding: 20px;
}

/* Grid Card */
.qf-card-grid .qf-card-image {
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
}

.qf-card-grid .qf-card-image img,
.qf-card-grid .qf-card-image-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.qf-card-grid .qf-card-content {
	padding: 15px;
}

/* Magazine Style */
.qf-card-magazine .qf-card-image {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.qf-card-magazine .qf-card-image img,
.qf-card-magazine .qf-card-image-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.qf-card-magazine .qf-card-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent);
	padding: 30px 20px 20px;
}

.qf-card-magazine .qf-card-overlay .qf-card-title {
	margin: 0;
}

.qf-card-magazine .qf-card-overlay .qf-card-title a {
	color: #fff;
}

.qf-card-magazine .qf-card-content {
	padding: 20px;
}

/* Basics Card (Elementor cards-inspired) */
.qf-card.qf-card-basics {
	border: 1px solid #88909c;
	border-radius: 0;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.02);
}

.qf-card.qf-card-basics:hover {
	transform: none;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.02);
}

.qf-card-basics .qf-card-image {
	width: 100%;
	aspect-ratio: 1.54 / 1;
	overflow: hidden;
}

.qf-card-basics .qf-card-image img,
.qf-card-basics .qf-card-image-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.qf-card-basics .qf-card-content {
	padding: 34px 40px 32px 40px;
}

.qf-card-basics .qf-card-title {
	margin-bottom: 18px;
	font-family: "Open Sans", Sans-serif;
	font-size: clamp(1.85rem, 3vw, 2.7rem);
	font-weight: 700;
	line-height: 1.08;
	color: #575d66;
}

.qf-card-basics .qf-card-excerpt {
	margin-bottom: 26px;
	font-family: "Open Sans", Sans-serif;
	font-size: clamp(1.05rem, 1.45vw, 1.85rem);
	font-weight: 400;
	line-height: 1.43;
	color: #73777f;
}

.qf-card-basics .qf-card-button-wrapper {
	margin-top: 0;
}

.qf-card-basics .qf-card-button {
	padding: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	font-family: "Open Sans", Sans-serif;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #800303;
}

.qf-card-basics .qf-card-button:hover {
	transform: none;
	box-shadow: none;
	background: transparent;
	color: #800303;
}

/* Classic Card (Elementor classic posts-inspired) */
.qf-card.qf-card-classic {
	border: 1px solid #d5dbe3;
	border-radius: 0;
	box-shadow: 1px 3px 10px rgba(0, 0, 0, 0.5);
}

.qf-card-classic .qf-card-image {
	width: 100%;
	aspect-ratio: 1.89 / 1;
	overflow: hidden;
}

.qf-card-classic .qf-card-image img,
.qf-card-classic .qf-card-image-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.qf-card-classic .qf-card-content {
	padding: 5px;
}

.qf-card-classic .qf-card-title {
	margin-bottom: 6px;
	font-family: "Open Sans", Sans-serif;
	font-size: 19px;
	font-weight: 700;
}

.qf-card-classic .qf-card-excerpt {
	margin-bottom: 6px;
	font-family: "Open Sans", Sans-serif;
	font-size: 14px;
	font-weight: 400;
	line-height: 21px;
}

.qf-card-button-wrapper-classic {
	margin-top: 0;
}

.qf-card-button-classic {
	padding: 0;
	background: transparent;
	border-radius: 0;
	box-shadow: none;
	font-family: "Open Sans", Sans-serif;
	font-size: 14px;
	font-weight: 600;
	color: #6f7781;
}

.qf-card-button-classic:hover {
	transform: none;
	box-shadow: none;
	background: transparent;
	color: #6f7781;
}

/* Image Placeholder */
.qf-card-image-placeholder {
	width: 100%;
	height: 100%;
	background: #f0f0f0;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
}

.qf-placeholder-icon {
	font-size: 48px;
	opacity: 0.3;
}

/* Card Content */
.qf-card-content {
	display: flex;
	flex-direction: column;
}

.qf-card-title {
	margin: 0 0 10px 0;
	font-size: 1.25em;
	line-height: 1.4;
}

.qf-card-title a {
	text-decoration: none;
	color: inherit;
	transition: color 0.2s ease;
}

/* Results summary */
.qf-results-summary {
	margin-bottom: 12px;
	font-size: 13px;
	color: #555;
}

.qf-card-title a:hover {
	color: #0073aa;
}

.qf-card-excerpt {
	margin: 0 0 10px 0;
	color: #666;
	line-height: 1.6;
}

.qf-custom-fields {
	display: grid;
	gap: 6px;
	margin: 0 0 10px 0;
}

.qf-custom-field {
	font-size: 0.92em;
	color: #555;
}

.qf-custom-field-label {
	font-weight: 600;
	margin-right: 6px;
}

.qf-custom-field-value {
	color: inherit;
}

.qf-card-meta {
	margin-top: auto;
	font-size: 0.9em;
	color: #888;
}

.qf-card-separator {
	margin: 0 5px;
}

.qf-card-author a {
	color: inherit;
	text-decoration: none;
}

.qf-card-author a:hover {
	text-decoration: underline;
}

.qf-card-button-wrapper {
	margin-top: 12px;
}

.qf-card-button {
	display: inline-block;
	padding: 6px 14px;
	border-radius: 999px;
	background-color: #ff7a1a;
	color: #ffffff;
	font-size: 12px;
	font-weight: 500;
	text-decoration: none;
	transition: transform 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.qf-card-button:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.18);
}

/* Pagination */
.qf-pagination {
	margin-top: 40px;
	text-align: center;
}

.qf-pagination .page-numbers {
	display: inline-block;
	padding: 8px 12px;
	margin: 0 4px;
	text-decoration: none;
	border: 1px solid #ddd;
	border-radius: 4px;
	transition: background 0.2s ease;
}

.qf-pagination .page-numbers:hover,
.qf-pagination .page-numbers.current {
	background: #0073aa;
	color: #fff;
	border-color: #0073aa;
}

/* Template Grid */
.qf-template-grid {
	display: grid;
	gap: 20px;
}

.qf-template-item {
	width: 100%;
}

/* Placeholder */
.qf-placeholder {
	padding: 40px;
	text-align: center;
	background: #f9f9f9;
	border: 2px dashed #ddd;
	border-radius: 8px;
	color: #666;
}


/* Pagination Styles */
.qf-pagination {
	margin-top: 30px;
	text-align: center;
}

.qf-pagination .page-numbers {
	display: inline-block;
	padding: 8px 12px;
	margin: 0 4px;
	border: 1px solid #ddd;
	text-decoration: none;
	color: #333;
	background: #fff;
}

.qf-pagination .page-numbers:hover,
.qf-pagination .page-numbers.current {
	background: #0073aa;
	color: #fff;
	border-color: #0073aa;
}

.qf-pagination.loading {
	opacity: 0.6;
	pointer-events: none;
}

.qf-grid.loading {
	opacity: 0.6;
	pointer-events: none;
}

/* Load More Button */
.qf-load-more-wrapper {
	text-align: center;
	margin-top: 30px;
}

.qf-load-more-button {
	padding: 12px 30px;
	background: #0073aa;
	color: #fff;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	font-size: 16px;
	transition: background 0.3s;
}

.qf-load-more-button:hover {
	background: #005a87;
}

.qf-load-more-button:disabled {
	background: #ccc;
	cursor: not-allowed;
}

/* Infinite Scroll Trigger (hidden) */
.qf-infinite-scroll-trigger {
	height: 1px;
	width: 100%;
	visibility: hidden;
}

/* Back to Top Link */
.qf-back-to-top {
	display: inline-block;
	padding: 10px 20px;
	background: #0073aa;
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
	transition: background 0.2s ease;
}

.qf-back-to-top:hover {
	background: #005177;
	color: #fff;
	text-decoration: none;
}

.qf-back-to-top-wrapper {
	margin-top: 40px;
	text-align: center;
}

/* Frontend search (v1.3.3+) */
.qf-search-bar {
	margin-bottom: 1rem;
}

.qf-search-align-left {
	text-align: left;
}

.qf-search-align-center {
	text-align: center;
}

.qf-search-align-center .qf-search-branded-track,
.qf-search-align-center .qf-search-input {
	margin-left: auto;
	margin-right: auto;
}

.qf-search-align-right {
	text-align: right;
}

.qf-search-align-right .qf-search-branded-track,
.qf-search-align-right .qf-search-input {
	margin-left: auto;
}

.qf-search-input {
	width: 100%;
	max-width: 28rem;
	padding: 0.55rem 0.75rem;
	border: 1px solid #c3c4c7;
	border-radius: 4px;
	font-size: 1rem;
	box-sizing: border-box;
}

.qf-search-input::placeholder {
	color: var(--qf-placeholder-color, inherit);
	opacity: 0.72;
}

.qf-search-input:focus {
	outline: 2px solid var(--qf-focus-ring, #2271b1);
	outline-offset: 2px;
}

.qf-search-branded .qf-search-branded-track {
	position: relative;
	width: 100%;
	max-width: 28rem;
}

.qf-search-branded .qf-search-icon {
	position: absolute;
	left: 0.65rem;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
	z-index: 1;
	color: #50575e;
}

.qf-search-branded .qf-search-icon-svg {
	display: block;
	vertical-align: middle;
}

.qf-search-branded .qf-search-input {
	padding-left: 2.35rem;
	border-width: 2px;
	border-style: solid;
	border-color: #8c8f94;
}

.qf-search-minimal .qf-search-input {
	max-width: 28rem;
	border: 1px solid rgba(0, 0, 0, 0.12);
	background: transparent;
}

.qf-search-floating .qf-search-input {
	max-width: 28rem;
	border: 1px solid rgba(0, 0, 0, 0.06);
	background: #fff;
}

.qf-search-floating.qf-shadow-light {
	box-shadow: 0 1px 4px var(--qf-search-shadow-color, rgba(0, 0, 0, 0.08));
}

.qf-search-floating.qf-shadow-medium {
	box-shadow: 0 2px 8px var(--qf-search-shadow-color, rgba(0, 0, 0, 0.15));
}

.qf-search-floating.qf-shadow-strong {
	box-shadow: 0 4px 16px var(--qf-search-shadow-color, rgba(0, 0, 0, 0.25));
}

.qf-query-forge-root.qf-is-loading,
[data-qf-instance-id].qf-is-loading {
	opacity: 0.65;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

/*
 * Elementor editor panel: Query Forge custom-field mounts (RAW_HTML beside native controls).
 * Scoped to .elementor-panel so block editor / frontend cards are unaffected.
 */
.elementor-panel .qf-cf-mount .elementor-choices {
	display: flex;
	width: 100%;
	gap: 2px;
	align-items: stretch;
	box-sizing: border-box;
}

.elementor-panel .qf-cf-mount .elementor-control-type-choose .elementor-control-input-choice {
	position: relative;
	flex: 1 1 0;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 27px;
	margin: 0;
	padding: 0;
	border: 1px solid var(--e-a-border-color, #d5dadf);
	border-radius: 3px;
	background-color: var(--e-a-bg-default, #fff);
	cursor: pointer;
	box-sizing: border-box;
}

.elementor-panel .qf-cf-mount .elementor-control-type-choose .elementor-control-input-choice:hover {
	border-color: var(--e-a-border-color-bold, #9da5ae);
}

.elementor-panel .qf-cf-mount .elementor-control-type-choose .elementor-choices-input {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	opacity: 0;
	cursor: pointer;
}

.elementor-panel .qf-cf-mount .elementor-control-type-choose .elementor-control-input-choice:has(.elementor-choices-input:checked) {
	border-color: var(--e-a-color-accent, #93003c);
	background-color: var(--e-a-bg-active, rgba(147, 0, 60, 0.08));
}

.elementor-panel .qf-cf-mount .elementor-control-type-choose .elementor-control-input-choice i {
	font-size: 15px;
	line-height: 1;
	color: var(--e-a-color-txt, #515962);
	pointer-events: none;
}

.elementor-panel .qf-cf-mount .elementor-control-type-choose .elementor-control-input-choice:has(.elementor-choices-input:checked) i {
	color: var(--e-a-color-accent, #93003c);
}

.elementor-panel .qf-cf-mount .qf-cf-color-control-inner {
	display: flex;
	align-items: stretch;
	gap: 8px;
	width: 100%;
	box-sizing: border-box;
}

.elementor-panel .qf-cf-mount .qf-cf-color-swatch {
	flex-shrink: 0;
	width: 28px;
	min-height: 27px;
	border-radius: 3px;
	border: 1px solid var(--e-a-border-color, #d5dadf);
	box-sizing: border-box;
	background-color: var(--e-a-bg-muted, #f1f2f3);
}

.elementor-panel .qf-cf-mount .qf-cf-color-input {
	flex: 1 1 auto;
	min-width: 0;
}

/* -------------------------------------------------------------------------
 * Query Forge single template (full single override via ?qfr=)
 * ------------------------------------------------------------------------- */
.qf-single {
	max-width: 960px;
	margin: 0 auto;
	padding: 1.5rem 1rem;
	box-sizing: border-box;
}

.qf-single__article {
	position: relative;
}

.qf-single__title {
	margin: 0 0 0.75rem;
	line-height: 1.2;
}

.qf-single__media img,
.qf-single__media .qf-single__image-el {
	display: block;
	width: 100%;
	height: auto;
}

.qf-single__meta {
	margin: 0.5rem 0 1rem;
}

.qf-single__avatar {
	vertical-align: middle;
	margin-right: 0.35rem;
	border-radius: 50%;
}

.qf-single__excerpt {
	margin: 0 0 1rem;
}

.qf-single__content {
	margin: 0 0 1.5rem;
}

.qf-single__nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 1rem;
	margin-top: 2rem;
	padding-top: 1rem;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.qf-single__terms {
	margin: 1rem 0;
}

.qf-single__terms--pills .qf-single__term-list,
.qf-single__terms--plain .qf-single__term-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.qf-single__terms--pills .qf-single__term-item a {
	display: inline-block;
	padding: 0.15rem 0.55rem;
	border-radius: 999px;
	border: 1px solid currentColor;
	text-decoration: none;
}

.qf-single__terms--plain .qf-single__term-item a {
	text-decoration: underline;
}

/* -------------------------------------------------------------------------
 * Single template: per-style layouts (.qf-single--{slug})
 * ------------------------------------------------------------------------- */

/* 1 — Vertical: stacked, full-bleed media, readable content column */
.qf-single--vertical {
	max-width: none;
	width: 100%;
	padding: 0;
}

.qf-single--vertical .qf-single__article {
	max-width: 48rem;
	margin: 0 auto;
	padding: 1.75rem clamp(1rem, 4vw, 2rem) 2.5rem;
}

.qf-single--vertical .qf-single__media--above-title,
.qf-single--vertical .qf-single__media--below-title {
	width: 100vw;
	max-width: none;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

.qf-single--vertical .qf-single__media--above-title + .qf-single__header,
.qf-single--vertical .qf-single__header {
	padding-top: 0.25rem;
}

/* 2 — Horizontal: image column | content column */
.qf-single--horizontal {
	max-width: 72rem;
	padding: 1.5rem clamp(0.75rem, 3vw, 1.5rem);
}

.qf-single--horizontal .qf-single__article {
	display: grid;
	grid-template-columns: minmax(0, 38%) minmax(0, 1fr);
	gap: clamp(1rem, 3vw, 2.25rem);
	align-items: start;
}

.qf-single--horizontal .qf-single__media--above-title,
.qf-single--horizontal .qf-single__media--below-title {
	grid-column: 1;
	margin: 0;
}

.qf-single--horizontal .qf-single__header,
.qf-single--horizontal .qf-single__meta,
.qf-single--horizontal .qf-single__excerpt,
.qf-single--horizontal .qf-single__content,
.qf-single--horizontal .qf-single__terms,
.qf-single--horizontal .qf-single__nav {
	grid-column: 2;
}

.qf-single--horizontal .qf-single__media img,
.qf-single--horizontal .qf-single__media .qf-single__image-el {
	width: 100%;
	height: auto;
	max-height: min(70vh, 520px);
	object-fit: cover;
	border-radius: 6px;
}

/* 3 — Minimal list: no featured image, tight typography */
.qf-single--minimal-list {
	max-width: 40rem;
	padding: 0.75rem 1rem 2rem;
}

.qf-single--minimal-list .qf-single__media {
	display: none !important;
}

.qf-single--minimal-list .qf-single__article > * {
	margin-top: 0;
	margin-bottom: 0.65rem;
}

.qf-single--minimal-list .qf-single__title {
	font-size: clamp(1.35rem, 3.5vw, 1.75rem);
	font-weight: 600;
	letter-spacing: -0.02em;
}

.qf-single--minimal-list .qf-single__meta {
	font-size: 0.8rem;
	opacity: 0.85;
}

.qf-single--minimal-list .qf-single__excerpt {
	font-size: 0.95rem;
	line-height: 1.45;
}

.qf-single--minimal-list .qf-single__content {
	font-size: 0.95rem;
	line-height: 1.55;
}

.qf-single--minimal-list .qf-single__nav {
	margin-top: 1.25rem;
	padding-top: 0.75rem;
	border-top-width: 1px;
}

/* 4 — Grid card: centered “card”, shadow, constrained */
.qf-single--grid-card {
	max-width: 44rem;
	margin: 2rem auto;
	padding: 0 1rem;
}

.qf-single--grid-card .qf-single__article {
	background: #fff;
	border-radius: 14px;
	box-shadow:
		0 4px 6px rgba(15, 23, 42, 0.06),
		0 18px 48px rgba(15, 23, 42, 0.12);
	padding: clamp(1.25rem, 3vw, 2rem);
	overflow: hidden;
	border: 1px solid rgba(15, 23, 42, 0.06);
}

.qf-single--grid-card .qf-single__media--above-title,
.qf-single--grid-card .qf-single__media--below-title {
	margin: clamp(-1.25rem, -3vw, -2rem) clamp(-1.25rem, -3vw, -2rem) 1.25rem;
	border-radius: 0;
}

.qf-single--grid-card .qf-single__media img,
.qf-single--grid-card .qf-single__media .qf-single__image-el {
	border-radius: 0;
}

/* 5 — Magazine: full-bleed hero + title overlay on first media */
.qf-single--magazine {
	max-width: none;
	width: 100%;
	padding: 0;
}

.qf-single--magazine .qf-single__article {
	display: grid;
	grid-template-columns: 1fr;
	max-width: 72rem;
	margin: 0 auto;
	padding: 0 0 2.5rem;
}

.qf-single--magazine .qf-single__media--above-title {
	grid-column: 1;
	grid-row: 1;
	width: 100vw;
	max-width: none;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	min-height: min(52vh, 520px);
}

.qf-single--magazine .qf-single__media--above-title img,
.qf-single--magazine .qf-single__media--above-title .qf-single__image-el {
	width: 100%;
	height: min(52vh, 520px);
	object-fit: cover;
	display: block;
}

.qf-single--magazine .qf-single__header {
	grid-column: 1;
	grid-row: 1;
	align-self: end;
	z-index: 2;
	margin: 0;
	padding: clamp(1rem, 4vw, 2.5rem);
	background: linear-gradient(to top, rgba(0, 0, 0, 0.78) 0%, rgba(0, 0, 0, 0.35) 45%, transparent 100%);
}

.qf-single--magazine .qf-single__title {
	color: #fff;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
	font-size: clamp(1.75rem, 5vw, 2.75rem);
	font-weight: 700;
	line-height: 1.1;
}

.qf-single--magazine .qf-single__media--below-title {
	grid-column: 1;
	grid-row: 2;
	width: 100%;
	max-width: 48rem;
	margin: 1.25rem auto 0;
	padding: 0 clamp(1rem, 4vw, 2rem);
}

.qf-single--magazine .qf-single__meta,
.qf-single--magazine .qf-single__excerpt,
.qf-single--magazine .qf-single__content,
.qf-single--magazine .qf-single__terms,
.qf-single--magazine .qf-single__nav {
	max-width: 48rem;
	margin-left: auto;
	margin-right: auto;
	padding-left: clamp(1rem, 4vw, 2rem);
	padding-right: clamp(1rem, 4vw, 2rem);
}

/* 6 — Hero: viewport-tall visual, title overlaid on image (shared grid cell) */
.qf-single--hero {
	max-width: none;
	width: 100%;
	padding: 0;
	min-height: 100vh;
}

.qf-single--hero .qf-single__article {
	display: grid;
	grid-template-columns: 1fr;
	min-height: 100vh;
	padding: 0;
	margin: 0;
	max-width: none;
}

.qf-single--hero .qf-single__media--above-title {
	grid-column: 1;
	grid-row: 1;
	min-height: 78vh;
	width: 100%;
	margin: 0;
}

.qf-single--hero .qf-single__media--above-title img,
.qf-single--hero .qf-single__media--above-title .qf-single__image-el {
	width: 100%;
	min-height: 78vh;
	height: 100%;
	object-fit: cover;
	display: block;
}

.qf-single--hero .qf-single__header {
	grid-column: 1;
	grid-row: 1;
	align-self: end;
	z-index: 2;
	margin: 0;
	padding: clamp(1.5rem, 5vw, 3rem);
	background: linear-gradient(to top, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.35) 50%, transparent 100%);
}

.qf-single--hero .qf-single__title {
	color: #fff;
	font-size: clamp(2rem, 6vw, 3.5rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.05;
	text-shadow: 0 2px 16px rgba(0, 0, 0, 0.45);
}

.qf-single--hero .qf-single__meta,
.qf-single--hero .qf-single__excerpt,
.qf-single--hero .qf-single__content,
.qf-single--hero .qf-single__terms,
.qf-single--hero .qf-single__nav {
	max-width: 42rem;
	margin-left: auto;
	margin-right: auto;
	padding: 0 clamp(1rem, 4vw, 2rem);
}

.qf-single--hero .qf-single__meta {
	margin-top: 1.25rem;
}

.qf-single--hero .qf-single__content {
	padding-bottom: 2.5rem;
}

/* 7 — Sidebar right: main ~65% | aside ~35% */
.qf-single--sidebar-right {
	max-width: 72rem;
	padding: 1.5rem clamp(0.75rem, 2vw, 1.5rem);
}

.qf-single--sidebar-right .qf-single__article {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(220px, 34%);
	gap: clamp(1.25rem, 3vw, 2.5rem);
	align-items: start;
}

.qf-single--sidebar-right .qf-single__media--above-title,
.qf-single--sidebar-right .qf-single__media--below-title,
.qf-single--sidebar-right .qf-single__header,
.qf-single--sidebar-right .qf-single__meta,
.qf-single--sidebar-right .qf-single__excerpt,
.qf-single--sidebar-right .qf-single__content,
.qf-single--sidebar-right .qf-single__nav {
	grid-column: 1;
}

.qf-single--sidebar-right .qf-single__terms {
	grid-column: 2;
	align-self: start;
	padding: 0.75rem 0 0.75rem 1rem;
	border-left: 1px solid rgba(15, 23, 42, 0.12);
	font-size: 0.9rem;
	margin-top: 0;
}

/* 8 — Sidebar left: aside ~35% | main ~65% */
.qf-single--sidebar-left {
	max-width: 72rem;
	padding: 1.5rem clamp(0.75rem, 2vw, 1.5rem);
}

.qf-single--sidebar-left .qf-single__article {
	display: grid;
	grid-template-columns: minmax(220px, 34%) minmax(0, 1fr);
	gap: clamp(1.25rem, 3vw, 2.5rem);
	align-items: start;
}

.qf-single--sidebar-left .qf-single__terms {
	grid-column: 1;
	padding: 0.75rem 1rem 0.75rem 0;
	border-right: 1px solid rgba(15, 23, 42, 0.12);
	font-size: 0.9rem;
	align-self: start;
}

.qf-single--sidebar-left .qf-single__media--above-title,
.qf-single--sidebar-left .qf-single__media--below-title,
.qf-single--sidebar-left .qf-single__header,
.qf-single--sidebar-left .qf-single__meta,
.qf-single--sidebar-left .qf-single__excerpt,
.qf-single--sidebar-left .qf-single__content,
.qf-single--sidebar-left .qf-single__nav {
	grid-column: 2;
}

/* 9 — Editorial: narrow column, large type, generous space */
.qf-single--editorial {
	max-width: 38rem;
	padding: clamp(2.5rem, 8vw, 5rem) 1.25rem;
}

.qf-single--editorial .qf-single__article > * + * {
	margin-top: clamp(1.25rem, 3vw, 2rem);
}

.qf-single--editorial .qf-single__title {
	font-size: clamp(2.25rem, 6vw, 3.5rem);
	font-weight: 600;
	letter-spacing: -0.035em;
	line-height: 1.08;
}

.qf-single--editorial .qf-single__meta {
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	opacity: 0.75;
}

.qf-single--editorial .qf-single__excerpt {
	font-size: 1.2rem;
	line-height: 1.55;
	font-style: italic;
	opacity: 0.9;
}

.qf-single--editorial .qf-single__content {
	font-size: 1.125rem;
	line-height: 1.75;
}

.qf-single--editorial .qf-single__nav {
	margin-top: clamp(2.5rem, 6vw, 4rem);
	border-top: none;
	padding-top: 0;
}

/* 10 — Spotlight: dominant top image, narrow reading column below */
.qf-single--spotlight {
	max-width: none;
	padding: 0;
}

.qf-single--spotlight .qf-single__article {
	max-width: 40rem;
	margin: 0 auto;
	padding: 0 1rem 3rem;
}

.qf-single--spotlight .qf-single__media--above-title,
.qf-single--spotlight .qf-single__media--below-title {
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: none;
	min-height: 48vh;
}

.qf-single--spotlight .qf-single__media img,
.qf-single--spotlight .qf-single__media .qf-single__image-el {
	width: 100%;
	min-height: 48vh;
	max-height: 58vh;
	object-fit: cover;
	display: block;
}

.qf-single--spotlight .qf-single__header,
.qf-single--spotlight .qf-single__meta,
.qf-single--spotlight .qf-single__excerpt,
.qf-single--spotlight .qf-single__content,
.qf-single--spotlight .qf-single__terms,
.qf-single--spotlight .qf-single__nav {
	max-width: 36rem;
	margin-left: auto;
	margin-right: auto;
}

.qf-single--spotlight .qf-single__title {
	font-size: clamp(1.6rem, 4vw, 2.1rem);
	margin-top: 1.5rem;
}

/* 11 — Clean: flat, minimal chrome, tight left rhythm */
.qf-single--clean {
	max-width: 42rem;
	padding: 1rem 1.25rem 2rem;
}

.qf-single--clean .qf-single__article {
	background: transparent;
	box-shadow: none;
	border: none;
}

.qf-single--clean .qf-single__media img,
.qf-single--clean .qf-single__media .qf-single__image-el {
	border-radius: 0;
}

.qf-single--clean .qf-single__title {
	font-weight: 600;
	font-size: clamp(1.5rem, 3.5vw, 2rem);
}

.qf-single--clean .qf-single__nav {
	border-top: none;
	padding-top: 0.5rem;
	margin-top: 1.5rem;
	opacity: 0.85;
}

.qf-single--clean .qf-single__terms--pills .qf-single__term-item a {
	border: none;
	padding: 0;
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* 12 — Bold: high-contrast hierarchy */
.qf-single--bold {
	max-width: 56rem;
	padding: 1.5rem clamp(1rem, 3vw, 2rem) 2.5rem;
	background: #0f172a;
	color: #f8fafc;
}

.qf-single--bold .qf-single__article {
	background: transparent;
}

.qf-single--bold .qf-single__title {
	font-size: clamp(2.25rem, 7vw, 4rem);
	font-weight: 800;
	letter-spacing: -0.04em;
	line-height: 1;
	color: #fff;
}

.qf-single--bold .qf-single__meta,
.qf-single--bold .qf-single__excerpt {
	color: #cbd5e1;
}

.qf-single--bold .qf-single__content {
	color: #e2e8f0;
}

.qf-single--bold .qf-single__content a {
	color: #7dd3fc;
}

.qf-single--bold .qf-single__nav {
	border-top-color: rgba(248, 250, 252, 0.2);
}

.qf-single--bold .qf-single__media img,
.qf-single--bold .qf-single__media .qf-single__image-el {
	border-radius: 8px;
}

/* 13 — Card centered: padded card, max 680px */
.qf-single--card-centered {
	max-width: none;
	padding: 2rem 1rem;
	background: #f1f5f9;
}

.qf-single--card-centered .qf-single__article {
	max-width: 680px;
	margin: 0 auto;
	background: #fff;
	border-radius: 12px;
	padding: clamp(1.5rem, 4vw, 2.5rem);
	box-shadow: 0 2px 8px rgba(15, 23, 42, 0.08);
}

/* 14 — News: dense, newspaper-style two-column body */
.qf-single--news {
	max-width: 52rem;
	padding: 0.75rem 1rem 2rem;
	column-gap: 1.75rem;
}

.qf-single--news .qf-single__title {
	font-family: Georgia, 'Times New Roman', serif;
	font-size: clamp(1.6rem, 3.5vw, 2.15rem);
	border-bottom: 3px double #0f172a;
	padding-bottom: 0.5rem;
	margin-bottom: 0.5rem;
}

.qf-single--news .qf-single__meta {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.qf-single--news .qf-single__excerpt {
	font-size: 0.9rem;
	line-height: 1.4;
	font-weight: 600;
}

.qf-single--news .qf-single__content {
	column-count: 2;
	column-gap: 1.75rem;
	column-rule: 1px solid rgba(15, 23, 42, 0.15);
	font-size: 0.92rem;
	line-height: 1.5;
	hyphens: auto;
}

.qf-single--news .qf-single__content p:first-of-type:first-letter {
	font-size: 2.75em;
	float: left;
	line-height: 0.85;
	padding-right: 0.08em;
	font-weight: 700;
	font-family: Georgia, serif;
}

@media (max-width: 640px) {
	.qf-single--news .qf-single__content {
		column-count: 1;
		column-rule: none;
	}
}

/* 15 — Portfolio: full-bleed image, minimal text, airy */
.qf-single--portfolio {
	max-width: none;
	width: 100%;
	padding: 0 0 4rem;
}

.qf-single--portfolio .qf-single__article {
	max-width: 34rem;
	margin: 0 auto;
	padding: 0 clamp(1rem, 4vw, 2rem);
}

.qf-single--portfolio .qf-single__media--above-title,
.qf-single--portfolio .qf-single__media--below-title {
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: none;
	margin-bottom: 2.5rem;
}

.qf-single--portfolio .qf-single__media img,
.qf-single--portfolio .qf-single__media .qf-single__image-el {
	width: 100%;
	max-height: 75vh;
	object-fit: cover;
	display: block;
}

.qf-single--portfolio .qf-single__title {
	font-size: clamp(1.25rem, 3vw, 1.6rem);
	font-weight: 500;
	letter-spacing: 0.02em;
	text-align: center;
}

.qf-single--portfolio .qf-single__meta {
	text-align: center;
	font-size: 0.8rem;
	opacity: 0.65;
}

.qf-single--portfolio .qf-single__excerpt {
	text-align: center;
	font-size: 0.95rem;
	line-height: 1.6;
	opacity: 0.85;
}

.qf-single--portfolio .qf-single__content {
	font-size: 0.95rem;
	line-height: 1.65;
	margin-top: 2rem;
}

.qf-single--portfolio .qf-single__terms,
.qf-single--portfolio .qf-single__nav {
	margin-top: 2.5rem;
}
