/*
Theme Name: Querocerto Theme
Theme URI: https://www.querocerto.com.br
Description: Tema filho do TwentyTwentyFive para o Quero Certo — portal de análises de tecnologia. Visual editorial, claro e rápido. Todos os tokens de cor, fonte, tamanho e espaçamento ficam em theme.json (fonte única de verdade); este arquivo só cuida de layout fino, estados e responsividade.
Template: twentytwentyfive
Author: Quero Certo
Version: 2.0.0
Requires at least: 6.6
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: querocerto
*/

/* =========================================================================
   1. FONTES — Bricolage Grotesque (display) + Hanken Grotesk (texto)
   Variáveis (woff2) auto-hospedadas em /assets/fonts. font-display:swap evita
   bloquear a renderização (bom para Core Web Vitals).
   ========================================================================= */
@font-face {
	font-family: "Bricolage Grotesque";
	src: url("assets/fonts/bricolage-grotesque.woff2") format("woff2-variations");
	font-weight: 200 800;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Hanken Grotesk";
	src: url("assets/fonts/hanken-grotesk.woff2") format("woff2-variations");
	font-weight: 100 900;
	font-style: normal;
	font-display: swap;
}

/* =========================================================================
   2. TOKENS DE AJUSTE FINO (estruturais — cor/fonte ficam em theme.json)
   ========================================================================= */
:root {
	--qc-radius-sm: 10px;
	--qc-radius: 16px;
	--qc-radius-lg: 22px;
	--qc-radius-pill: 999px;
	--qc-header-h: 4.75rem;
	--qc-ease: cubic-bezier(0.2, 0.7, 0.2, 1);
	--qc-dur: 0.26s;
	/* Componentes RGB do verde marca para usar em rgba()/glows. Bate com #6db600. */
	--qc-brand-rgb: 109, 182, 0;
	--qc-brand-bright-rgb: 139, 232, 0;
	--qc-ring: 0 0 0 3px rgba(var(--qc-brand-rgb), 0.32);
}

/* =========================================================================
   3. BASE
   ========================================================================= */
html {
	scroll-behavior: smooth;
	scroll-padding-top: calc(var(--qc-header-h) + 1.5rem);
	-webkit-text-size-adjust: 100%;
}
body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}
::selection {
	background: var(--wp--preset--color--brand);
	color: var(--wp--preset--color--contrast);
}
:where(a):focus-visible,
:where(button, .wp-element-button):focus-visible,
:where(input, .wp-block-search__input):focus-visible {
	outline: none;
	box-shadow: var(--qc-ring);
	border-radius: var(--qc-radius-sm);
}
img {
	max-width: 100%;
	height: auto;
}

/* Destaque editorial em palavras-chave (<mark class="qc-mark">) */
.qc-mark {
	background: transparent;
	color: var(--wp--preset--color--brand-bright);
	padding: 0;
	box-decoration-break: clone;
}

/* =========================================================================
   4. CABEÇALHO
   ========================================================================= */
.qc-header {
	position: sticky;
	top: 0;
	z-index: 100;
	border-bottom: 1px solid var(--wp--preset--color--line);
	-webkit-backdrop-filter: saturate(180%) blur(8px);
	backdrop-filter: saturate(180%) blur(8px);
	background: rgba(255, 255, 255, 0.88);
}
body.admin-bar .qc-header { top: 32px; }
@media (max-width: 782px) {
	body.admin-bar .qc-header { top: 46px; }
}
.qc-header__inner {
	min-height: var(--qc-header-h);
	gap: clamp(1rem, 3vw, 2.5rem);
}

/* Marca — wrapper do logo SVG (cor vem do CSS via currentColor) */
.qc-brand { gap: 0.6rem; align-items: center; }
.qc-brand__logo {
	display: inline-flex;
	align-items: center;
	color: var(--wp--preset--color--brand);
	line-height: 0;
}
.qc-brand__logo > * { line-height: 0; margin: 0; }
.qc-brand__logo .wp-block-image,
.qc-brand__logo figure { margin: 0; }
.qc-brand__logo img,
.qc-brand__logo svg {
	display: block;
	height: 2.4rem;
	width: auto;
	max-width: 100%;
}
.qc-brand .wp-block-site-title { margin: 0; line-height: 1; }
.qc-brand .wp-block-site-title a { text-decoration: none; }
/* Esconde site-title visualmente sempre que houver logo (mantém pra a11y/SEO) */
.qc-brand:has(.qc-brand__logo) .wp-block-site-title {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
}

/* =========================================================================
   NAVEGAÇÃO — bloco custom querocerto/nav-categorias
   Desktop: barra horizontal com mega-menu por hover/click no item pai.
   Mobile : painel full-screen com slide a partir da direita.
   ========================================================================= */
.qc-nav {
	position: relative;
	display: flex;
	align-items: center;
}
.qc-nav__toggle,
.qc-nav__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: 1px solid var(--wp--preset--color--line);
	color: var(--wp--preset--color--contrast);
	width: 2.6rem;
	height: 2.6rem;
	border-radius: var(--qc-radius-pill);
	cursor: pointer;
	transition: background var(--qc-dur) var(--qc-ease),
		border-color var(--qc-dur) var(--qc-ease);
}
.qc-nav__toggle:hover,
.qc-nav__close:hover {
	background: var(--wp--preset--color--mint);
	border-color: var(--wp--preset--color--brand);
	color: var(--wp--preset--color--brand-dark);
}
.qc-nav__panel-head,
.qc-nav__close { /* só aparecem no mobile */
	display: none;
}

/* ---- Desktop ---- */
@media (min-width: 900px) {
	.qc-nav__toggle { display: none; }
	.qc-nav__panel {
		display: block !important;
		position: static;
		background: transparent;
	}
	.qc-nav__list {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: clamp(0.5rem, 2vw, 1.75rem);
		margin: 0;
		padding: 0;
		list-style: none;
	}
	.qc-nav__item { position: relative; }
	.qc-nav__expand { display: none; }
	.qc-nav__sub {
		position: absolute;
		top: calc(100% + 0.5rem);
		left: 0;
		min-width: 16rem;
		margin: 0;
		padding: 0.5rem;
		list-style: none;
		background: var(--wp--preset--color--base);
		border: 1px solid var(--wp--preset--color--line);
		border-radius: var(--qc-radius);
		box-shadow: var(--wp--preset--shadow--lift);
		opacity: 0;
		visibility: hidden;
		transform: translateY(-4px);
		transition: opacity var(--qc-dur) var(--qc-ease),
			transform var(--qc-dur) var(--qc-ease),
			visibility var(--qc-dur) linear;
		z-index: 30;
	}
	.qc-nav__item--has-children:hover > .qc-nav__sub,
	.qc-nav__item--has-children:focus-within > .qc-nav__sub {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}
	/* invisible bridge para não fechar dropdown ao atravessar gap */
	.qc-nav__item--has-children > .qc-nav__sub::before {
		content: "";
		position: absolute;
		left: 0;
		right: 0;
		top: -0.5rem;
		height: 0.5rem;
	}
}

.qc-nav__link {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.4rem 0.1rem;
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
	font-weight: 600;
	position: relative;
	white-space: nowrap;
}
.qc-nav__link-icon { color: var(--wp--preset--color--brand-dark); display: inline-flex; }
.qc-nav__link-caret { color: var(--wp--preset--color--ink-3); transition: transform var(--qc-dur) var(--qc-ease); }
.qc-nav__item--has-children:hover .qc-nav__link-caret { transform: rotate(180deg); color: var(--wp--preset--color--brand-dark); }
.qc-nav__link::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -0.1rem;
	width: 100%;
	height: 2px;
	background: var(--wp--preset--color--brand);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--qc-dur) var(--qc-ease);
}
.qc-nav__item:hover > .qc-nav__link::after,
.qc-nav__item.current-menu-item > .qc-nav__link::after { transform: scaleX(1); }

.qc-nav__sublink {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.55rem 0.75rem;
	border-radius: var(--qc-radius-sm);
	color: var(--wp--preset--color--ink-2);
	text-decoration: none;
	font-weight: 600;
	transition: background var(--qc-dur) var(--qc-ease),
		color var(--qc-dur) var(--qc-ease);
}
.qc-nav__sublink:hover {
	background: var(--wp--preset--color--mint);
	color: var(--wp--preset--color--brand-dark);
}
.qc-nav__leaf-icon { color: var(--wp--preset--color--brand-dark); display: inline-flex; }

/* ---- Mobile: overlay full-screen com slide ---- */
/* O painel é portado para <body> via JS (escapa do containing block do
   header, que tem backdrop-filter). Por isso os seletores abaixo NÃO
   ficam aninhados em .qc-nav. */
.qc-nav__panel[hidden],
.qc-nav__backdrop[hidden] { display: none !important; }

@media (max-width: 899px) {
	.qc-nav__panel {
		position: fixed;
		inset: 0 0 0 auto;
		width: min(92vw, 22rem);
		background: var(--wp--preset--color--base);
		box-shadow: -16px 0 40px -20px rgba(0, 0, 0, 0.35);
		padding: 1.25rem 1.1rem 2rem;
		overflow-y: auto;
		z-index: 1001;
		transform: translateX(100%);
		transition: transform 0.32s var(--qc-ease);
		display: flex;
		flex-direction: column;
		gap: 0.4rem;
	}
	.qc-nav__panel.is-open { transform: translateX(0); }

	.qc-nav__backdrop {
		position: fixed;
		inset: 0;
		background: rgba(0, 0, 0, 0.45);
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.32s var(--qc-ease), visibility 0.32s linear;
		z-index: 1000;
	}
	.qc-nav__backdrop.is-open { opacity: 1; visibility: visible; }

	.qc-nav__panel-head {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding-bottom: 0.5rem;
		border-bottom: 1px solid var(--wp--preset--color--line);
		margin-bottom: 0.4rem;
	}
	.qc-nav__panel-title {
		font-family: var(--wp--preset--font-family--display);
		font-weight: 800;
		font-size: var(--wp--preset--font-size--large);
		color: var(--wp--preset--color--contrast);
	}
	.qc-nav__close { display: inline-flex; }

	.qc-nav__list {
		list-style: none;
		margin: 0;
		padding: 0;
		display: flex;
		flex-direction: column;
		gap: 0.1rem;
	}
	.qc-nav__item {
		display: grid;
		grid-template-columns: 1fr auto;
		align-items: center;
		border-bottom: 1px solid var(--wp--preset--color--surface-2);
	}
	.qc-nav__link {
		padding: 0.95rem 0.4rem;
		font-size: var(--wp--preset--font-size--medium);
	}
	.qc-nav__link::after { display: none; }
	.qc-nav__link-caret { display: none; }

	.qc-nav__expand {
		grid-column: 2;
		background: transparent;
		border: 0;
		color: var(--wp--preset--color--ink-2);
		padding: 0.5rem 0.4rem;
		cursor: pointer;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		transition: transform var(--qc-dur) var(--qc-ease),
			color var(--qc-dur) var(--qc-ease);
	}
	.qc-nav__item.is-expanded .qc-nav__expand { transform: rotate(180deg); color: var(--wp--preset--color--brand-dark); }

	.qc-nav__sub {
		grid-column: 1 / -1;
		list-style: none;
		margin: 0;
		padding: 0 0 0.5rem 1.75rem;
		display: none;
	}
	.qc-nav__item.is-expanded > .qc-nav__sub { display: block; }
	.qc-nav__sublink { padding: 0.6rem 0.5rem; }

	body.qc-nav-locked { overflow: hidden; }
}

/* =========================================================================
   5. BUSCA (header, herói e páginas)
   ========================================================================= */
.qc-search .wp-block-search__inside-wrapper {
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--qc-radius-pill);
	background: var(--wp--preset--color--surface);
	padding: 0.2rem 0.2rem 0.2rem 0.35rem;
	transition: border-color var(--qc-dur) var(--qc-ease),
		box-shadow var(--qc-dur) var(--qc-ease);
}
.qc-search .wp-block-search__inside-wrapper:focus-within {
	border-color: var(--wp--preset--color--brand);
	box-shadow: var(--qc-ring);
	background: var(--wp--preset--color--base);
}
.qc-search .wp-block-search__input {
	border: none;
	background: transparent;
	padding: 0.5rem 0.75rem;
	color: var(--wp--preset--color--contrast);
}
.qc-search .wp-block-search__input::placeholder { color: var(--wp--preset--color--ink-3); }
.qc-search .wp-block-search__button {
	border-radius: var(--qc-radius-pill);
	background: var(--wp--preset--color--brand);
	color: var(--wp--preset--color--contrast);
	border: none;
	margin: 0;
	padding: 0.55rem;
	min-width: 2.5rem;
	display: grid;
	place-items: center;
	transition: background var(--qc-dur) var(--qc-ease);
}
.qc-search .wp-block-search__button:hover {
	background: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--base);
}
.qc-search .wp-block-search__button svg { fill: currentColor; }

/* Header: busca compacta */
.qc-header .qc-search { width: clamp(2.8rem, 18vw, 13rem); }

/* Herói + páginas: busca larga */
.qc-search--hero,
.qc-search--page {
	max-width: 34rem;
	margin-inline: auto;
	width: 100%;
}
.qc-search--hero .wp-block-search__inside-wrapper {
	background: var(--wp--preset--color--base);
	padding: 0.3rem 0.3rem 0.3rem 0.6rem;
	box-shadow: var(--wp--preset--shadow--lift);
	border-color: transparent;
}
.qc-search--hero .wp-block-search__input { padding-block: 0.75rem; }
.qc-search--page .wp-block-search__inside-wrapper { background: var(--wp--preset--color--base); }

/* =========================================================================
   6. HERÓI
   ========================================================================= */
.qc-hero {
	position: relative;
	overflow: hidden;
	text-align: center;
}
/* Atmosfera: brilho verde + textura de pontos sutil */
.qc-hero::before {
	content: "";
	position: absolute;
	inset: -30% -10% auto -10%;
	height: 70%;
	background: radial-gradient(
		50% 60% at 50% 0%,
		rgba(var(--qc-brand-bright-rgb), 0.22),
		transparent 70%
	);
	pointer-events: none;
}
.qc-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px);
	background-size: 26px 26px;
	mask-image: linear-gradient(to bottom, #000, transparent 75%);
	-webkit-mask-image: linear-gradient(to bottom, #000, transparent 75%);
	pointer-events: none;
}
.qc-hero > * { position: relative; z-index: 1; }
.qc-hero__title {
	max-width: 18ch;
	margin-inline: auto;
	color: var(--wp--preset--color--base);
}
.qc-hero__sub {
	max-width: 46ch;
	margin-inline: auto;
	color: var(--wp--preset--color--on-dark-muted);
}
.qc-trustrow { gap: 0.5rem 1.5rem; margin-top: 0.5rem; }
.qc-trustrow__item {
	margin: 0;
	color: var(--wp--preset--color--on-dark-muted);
	display: flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 600;
}
.qc-trustrow__item::before {
	content: "";
	width: 1rem;
	height: 1rem;
	flex: none;
	background-color: var(--wp--preset--color--brand-bright);
	-webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M5%2013l4%204L19%207'%20fill='none'%20stroke='black'%20stroke-width='3.4'%20stroke-linecap='round'%20stroke-linejoin='round'/%3E%3C/svg%3E")
		center / contain no-repeat;
	        mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M5%2013l4%204L19%207'%20fill='none'%20stroke='black'%20stroke-width='3.4'%20stroke-linecap='round'%20stroke-linejoin='round'/%3E%3C/svg%3E")
		center / contain no-repeat;
}

/* Animação de entrada do herói (suave, sem mexer no layout) */
.qc-hero > * {
	animation: qc-rise 0.7s var(--qc-ease) both;
}
.qc-hero > *:nth-child(1) { animation-delay: 0.05s; }
.qc-hero > *:nth-child(2) { animation-delay: 0.13s; }
.qc-hero > *:nth-child(3) { animation-delay: 0.21s; }
.qc-hero > *:nth-child(4) { animation-delay: 0.29s; }
.qc-hero > *:nth-child(5) { animation-delay: 0.37s; }
@keyframes qc-rise {
	from { opacity: 0; transform: translateY(14px); }
	to { opacity: 1; transform: translateY(0); }
}

/* =========================================================================
   7. SEÇÕES — cabeçalhos e eyebrows
   ========================================================================= */
.qc-eyebrow {
	margin: 0;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--wp--preset--color--brand-dark);
	display: flex;
	align-items: center;
	gap: 0.6rem;
}
.qc-eyebrow::before {
	content: "";
	width: 1.6rem;
	height: 2px;
	background: var(--wp--preset--color--brand);
	flex: none;
}
.qc-eyebrow.has-text-align-center { justify-content: center; }
.qc-eyebrow--bright { color: var(--wp--preset--color--brand-bright); }
.qc-eyebrow--bright::before { background: var(--wp--preset--color--brand-bright); }

.qc-section__head { margin-bottom: var(--wp--preset--spacing--60); }
.qc-section__head > * + * { margin-top: 0.5rem; }
.qc-section__head--center > * { margin-inline: auto; }
.qc-section__lead,
.qc-pagehead__lead {
	color: var(--wp--preset--color--ink-2);
	max-width: 52ch;
}
.qc-section__head--center .qc-section__lead { margin-inline: auto; }

/* =========================================================================
   8. GRID E CARDS DE ANÁLISE
   ========================================================================= */
.qc-grid { gap: 1.75rem !important; }

.qc-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--qc-radius);
	overflow: hidden;
	transition: transform var(--qc-dur) var(--qc-ease),
		box-shadow var(--qc-dur) var(--qc-ease),
		border-color var(--qc-dur) var(--qc-ease);
}
.qc-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--wp--preset--shadow--lift);
	border-color: var(--wp--preset--color--brand);
}
/* Imagem do card */
.qc-card__img {
	margin: 0;
	overflow: hidden;
	background: var(--wp--preset--color--mint);
}
.qc-card__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s var(--qc-ease);
}
.qc-card:hover .qc-card__img img { transform: scale(1.05); }

/* Card sem imagem: faixa de destaque + selo "Análise" */
.qc-card:not(:has(.qc-card__img)) { border-top: 3px solid var(--wp--preset--color--brand-bright); }
.qc-card:not(:has(.qc-card__img)) .qc-card__body::before {
	content: "Análise";
	align-self: flex-start;
	font-size: var(--wp--preset--font-size--x-small);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--wp--preset--color--brand-dark);
	background: var(--wp--preset--color--mint);
	padding: 0.25rem 0.6rem;
	border-radius: var(--qc-radius-pill);
}

.qc-card__body {
	flex: 1;
	gap: 0.6rem !important;
	padding: 1.35rem 1.4rem 1.5rem;
}
.qc-card__date {
	margin: 0;
	color: var(--wp--preset--color--ink-3);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.qc-card__title { margin: 0; }
.qc-card__title a {
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
	transition: color var(--qc-dur) var(--qc-ease);
}
.qc-card:hover .qc-card__title a { color: var(--wp--preset--color--brand-dark); }
.qc-card__excerpt {
	margin: 0;
	color: var(--wp--preset--color--ink-2);
	line-height: 1.6;
}
.qc-card__excerpt .wp-block-post-excerpt__excerpt { margin: 0; }
.qc-card__more {
	margin-top: auto;
	padding-top: 0.4rem;
	font-weight: 700;
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--brand-dark);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	width: max-content;
}
.qc-card__more::after {
	content: "→";
	transition: transform var(--qc-dur) var(--qc-ease);
}
.qc-card:hover .qc-card__more::after { transform: translateX(4px); }

/* =========================================================================
   9. GRID DE CATEGORIAS (diretório)
   ========================================================================= */
.qc-catgrid { gap: 0.85rem !important; }
.qc-cat { margin: 0; }
.qc-cat a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 1rem 1.15rem;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--qc-radius-sm);
	color: var(--wp--preset--color--contrast);
	font-weight: 700;
	font-size: var(--wp--preset--font-size--small);
	text-decoration: none;
	transition: transform var(--qc-dur) var(--qc-ease),
		border-color var(--qc-dur) var(--qc-ease),
		background var(--qc-dur) var(--qc-ease);
}
.qc-cat a::after {
	content: "→";
	color: var(--wp--preset--color--brand);
	transform: translateX(-3px);
	opacity: 0;
	transition: transform var(--qc-dur) var(--qc-ease),
		opacity var(--qc-dur) var(--qc-ease);
}
.qc-cat a:hover {
	transform: translateY(-3px);
	border-color: var(--wp--preset--color--brand);
	background: var(--wp--preset--color--mint);
}
.qc-cat a:hover::after { transform: translateX(0); opacity: 1; }

/* =========================================================================
   10. COMO RECOMENDAMOS — passos
   ========================================================================= */
.qc-steps { gap: 1.25rem !important; margin-top: var(--wp--preset--spacing--60); }
.qc-step {
	background: var(--wp--preset--color--surface);
	border-radius: var(--qc-radius);
	padding: 1.85rem 1.6rem;
}
.qc-step__num {
	margin: 0 0 0.85rem;
	font-family: var(--wp--preset--font-family--display);
	font-size: 2.5rem;
	font-weight: 800;
	line-height: 1;
	color: var(--wp--preset--color--brand);
	letter-spacing: -0.03em;
}
.qc-step__title { margin: 0 0 0.4rem; }
.qc-step__text { margin: 0; color: var(--wp--preset--color--ink-2); }

/* =========================================================================
   11. CABEÇALHO DE PÁGINA / ARQUIVO + estados vazios
   ========================================================================= */
.qc-pagehead { border-bottom: 1px solid var(--wp--preset--color--line); }
.qc-pagehead > * + * { margin-top: 0.6rem; }
.qc-pagehead__title { margin: 0; }
.qc-pagehead__lead { margin: 0; }

.qc-empty { color: var(--wp--preset--color--ink-3); padding-block: 2rem; }
.qc-emptybox {
	text-align: center;
	background: var(--wp--preset--color--surface);
	border: 1px dashed var(--wp--preset--color--line);
	border-radius: var(--qc-radius-lg);
	padding: clamp(2.5rem, 7vw, 4.5rem) 1.5rem;
	gap: 0.85rem !important;
	max-width: 48rem;
	margin-inline: auto;
}
.qc-emptybox__title { margin: 0; }
.qc-emptybox__text {
	margin: 0 auto;
	max-width: 44ch;
	color: var(--wp--preset--color--ink-2);
}
.qc-emptybox .wp-block-buttons { margin-top: 0.5rem; justify-content: center; display: flex; }

/* =========================================================================
   12. PAGINAÇÃO
   ========================================================================= */
.qc-pagination {
	margin-top: var(--wp--preset--spacing--70);
	gap: 0.4rem;
}
.qc-pagination .wp-block-query-pagination-numbers,
.qc-pagination > a,
.qc-pagination > .wp-block-query-pagination-previous,
.qc-pagination > .wp-block-query-pagination-next {
	display: flex;
	gap: 0.4rem;
	align-items: center;
}
.qc-pagination a,
.qc-pagination .page-numbers {
	display: grid;
	place-items: center;
	min-width: 2.6rem;
	height: 2.6rem;
	padding: 0 0.85rem;
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--qc-radius-pill);
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
	transition: all var(--qc-dur) var(--qc-ease);
}
.qc-pagination a:hover {
	border-color: var(--wp--preset--color--brand);
	background: var(--wp--preset--color--mint);
}
.qc-pagination .page-numbers.current {
	background: var(--wp--preset--color--contrast);
	color: var(--wp--preset--color--base);
	border-color: var(--wp--preset--color--contrast);
}

/* =========================================================================
   13. ARTIGO (single / page)
   ========================================================================= */
.qc-article { padding-bottom: var(--wp--preset--spacing--80); }
.qc-article__head { text-align: left; }
.qc-article__cat a,
.qc-article__cat {
	color: var(--wp--preset--color--brand-dark);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	text-decoration: none;
}
.qc-article__title { margin: 0; }
.qc-article__meta {
	gap: 0.5rem 0.9rem;
	color: var(--wp--preset--color--ink-3);
}
.qc-article__meta .qc-article__author { font-weight: 700; color: var(--wp--preset--color--contrast); }
.qc-article__meta .qc-article__date { position: relative; padding-left: 1.05rem; }
.qc-article__meta .qc-article__date::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--wp--preset--color--brand);
	transform: translateY(-50%);
}
.qc-article__img { margin-top: var(--wp--preset--spacing--60); margin-bottom: var(--wp--preset--spacing--60); }
.qc-article__img img { border-radius: var(--qc-radius-lg); width: 100%; }

/* Tipografia do conteúdo */
.qc-article__content > * { margin-block: 1.15em; }
.qc-article__content > :first-child { margin-top: 0; }
.qc-article__content :where(h2, h3, h4) { margin-top: 1.9em; }
.qc-article__content :where(h2) {
	padding-top: 0.6em;
	border-top: 1px solid var(--wp--preset--color--line);
}
.qc-article__content p { line-height: 1.75; }
.qc-article__content a { color: var(--wp--preset--color--brand-dark); text-underline-offset: 3px; }
.qc-article__content :where(img, figure img) { border-radius: var(--qc-radius); }
.qc-article__content figcaption {
	color: var(--wp--preset--color--ink-3);
	font-size: var(--wp--preset--font-size--small);
	text-align: center;
	margin-top: 0.5rem;
}
.qc-article__content ul,
.qc-article__content ol { padding-left: 1.3rem; }
.qc-article__content li { margin-block: 0.4em; }
.qc-article__content ul li::marker { color: var(--wp--preset--color--brand); }

/* Aviso de afiliados */
.qc-disclosure {
	margin-top: var(--wp--preset--spacing--60);
	background: var(--wp--preset--color--mint);
	border-radius: var(--qc-radius);
	padding: 1.1rem 1.35rem;
	border-left: 3px solid var(--wp--preset--color--brand);
}
.qc-disclosure__text { margin: 0; color: var(--wp--preset--color--brand-dark); }

/* Navegação entre posts */
.qc-postnav { gap: 1rem; border-top: 1px solid var(--wp--preset--color--line); }
.qc-postnav .wp-block-post-navigation-link {
	flex: 1 1 14rem;
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--qc-radius);
	padding: 1rem 1.2rem;
	transition: border-color var(--qc-dur) var(--qc-ease),
		background var(--qc-dur) var(--qc-ease);
}
.qc-postnav .wp-block-post-navigation-link:hover {
	border-color: var(--wp--preset--color--brand);
	background: var(--wp--preset--color--surface);
}
.qc-postnav__next { text-align: right; }
.qc-postnav .wp-block-post-navigation-link a { text-decoration: none; font-weight: 700; }

/* =========================================================================
   14. COMENTÁRIOS
   ========================================================================= */
.qc-comments .wp-block-comments-title { margin-bottom: 1.5rem; }
.qc-comment {
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--qc-radius);
	padding: 1.2rem 1.35rem;
	margin-bottom: 1rem;
}
.qc-comment__head { gap: 0.75rem; margin-bottom: 0.6rem; }
.qc-comment__avatar img { border-radius: 50%; }
.qc-comment .wp-block-comment-content { color: var(--wp--preset--color--ink-2); }
.qc-comment .wp-block-comment-reply-link a { font-weight: 700; }
.wp-block-post-comments-form .wp-block-button__link,
.wp-block-post-comments-form input[type="submit"] { cursor: pointer; }
.wp-block-post-comments-form input:not([type="submit"]),
.wp-block-post-comments-form textarea {
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--qc-radius-sm);
	padding: 0.7rem 0.9rem;
	background: var(--wp--preset--color--surface);
}

/* =========================================================================
   15. RODAPÉ
   ========================================================================= */
.qc-footer { position: relative; }
.qc-footer .wp-block-site-title { margin: 0; }
.qc-footer .wp-block-site-title a {
	color: var(--wp--preset--color--base) !important;
	text-decoration: none;
}
.qc-footer__brand { gap: 0.6rem; align-items: center; }
.qc-footer__brand .qc-brand__logo {
	color: var(--wp--preset--color--base);
}
.qc-footer__brand .qc-brand__logo .wp-block-image,
.qc-footer__brand .qc-brand__logo figure { margin: 0; line-height: 0; }
.qc-footer__brand .qc-brand__logo img,
.qc-footer__brand .qc-brand__logo svg {
	height: auto;
	width: 150px;
	max-width: 100%;
	display: block;
}
.qc-footer__blurb {
	margin: 1rem 0 0;
	color: var(--wp--preset--color--on-dark-muted);
	max-width: 38ch;
	font-size: var(--wp--preset--font-size--small);
	line-height: 1.65;
}
.qc-foot-label {
	margin: 0 0 1rem;
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--x-small);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--wp--preset--color--base);
}
.qc-footer__links { gap: 0.55rem !important; }
.qc-footer__links p { margin: 0; }
.qc-footer__links a {
	color: var(--wp--preset--color--on-dark-muted);
	text-decoration: none;
	font-size: var(--wp--preset--font-size--small);
	transition: color var(--qc-dur) var(--qc-ease);
}
.qc-footer__links a:hover { color: var(--wp--preset--color--brand-bright); }
.qc-footer__rule {
	margin-block: var(--wp--preset--spacing--60);
	border: none;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.qc-footer__bottom { gap: 0.75rem 2rem; }
.qc-footer__copy,
.qc-footer__disclosure { margin: 0; color: var(--wp--preset--color--on-dark-muted); }
.qc-footer__disclosure { max-width: 56ch; }

/* =========================================================================
   15bis. COLUNA DE LEITURA — cabeçalho do artigo, aviso, navegação e
   comentários ficam alinhados na mesma medida confortável (46rem) que o
   post-content usa.
   ========================================================================= */
.qc-article__head,
.qc-disclosure,
.qc-postnav,
.qc-comments .wp-block-comments {
	max-width: 46rem;
	margin-inline: auto;
}

/* =========================================================================
   16. PÁGINA 404
   ========================================================================= */
.qc-404 { text-align: center; }
.qc-404 > * { margin-inline: auto; }
.qc-404 .wp-block-heading { max-width: 22ch; }
.qc-404__text { max-width: 44ch; color: var(--wp--preset--color--ink-2); }

/* =========================================================================
   17. UTILIDADES / BLOCOS CORE
   ========================================================================= */
.qc-section__title { margin: 0; }
.wp-block-button__link { transition: background var(--qc-dur) var(--qc-ease), color var(--qc-dur) var(--qc-ease); }
.wp-block-separator:not(.is-style-wide) { color: var(--wp--preset--color--line); }

/* =========================================================================
   18. RESPONSIVO
   ========================================================================= */
@media (max-width: 781px) {
	.qc-header__inner { gap: 0.75rem; }
	.qc-header .qc-search { display: none; }
	.qc-footer__grid { gap: 2rem !important; }
	.qc-postnav__next { text-align: left; }
	.qc-article__meta { font-size: var(--wp--preset--font-size--small); }
}
/* O header tem backdrop-filter (frosted) — isso cria um containing block
   pros filhos position:fixed e prende o overlay mobile do menu dentro
   do header. Solução: remover o filtro só na faixa onde o overlay roda. */
@media (max-width: 899px) {
	.qc-header {
		-webkit-backdrop-filter: none;
		        backdrop-filter: none;
		background: var(--wp--preset--color--base);
	}
}
@media (max-width: 600px) {
	.qc-card__body { padding: 1.15rem 1.2rem 1.3rem; }
	.qc-step { padding: 1.4rem 1.3rem; }
}

/* =========================================================================
   19. MOVIMENTO REDUZIDO
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}
