/* =====================================================
   CAFEZALL — Templates CSS
   Estilos para os arquivos de template (header, single,
   index, page, sidebar, footer).
   Importado depois do cafezall.css (componentes base).
   ===================================================== */

/* =====================================================
   1. RESET ESPECÍFICO PARA SOBRESCREVER GENERATEPRESS
   ===================================================== */

/* Aplica a fonte e cor de fundo do tema globalmente. */
body.wp-singular,
body.wp-archive,
body.home,
body.search,
body.error404 {
	background-color: var(--cz-bg-page);
	color: var(--cz-text-primary);
	font-family: var(--cz-font-sans);
}

/* Esconde qualquer header/footer do GeneratePress que tenha sido emitido por engano. */
.site-header:not(.cz-site-header),
.site-footer:not(.cz-site-footer) {
	display: none !important;
}

/* GeneratePress aplica .site classes — neutralizamos seus paddings. */
.site,
#page,
.site-content {
	background-color: transparent;
	max-width: none;
	padding: 0;
	margin: 0;
}

/* Skip link */
.skip-link {
	position: absolute;
	left: -9999px;
}
.skip-link:focus {
	left: var(--cz-space-3);
	top: var(--cz-space-3);
	z-index: 9999;
	padding: var(--cz-space-2) var(--cz-space-4);
	background: var(--cz-green-800);
	color: var(--cz-neutral-50);
	border-radius: var(--cz-radius-md);
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
}

/* =====================================================
   2. SITE HEADER (header.php)
   ===================================================== */

.cz-site-header {
	background-color: var(--cz-green-800);
	color: var(--cz-neutral-50);
	position: sticky;
	top: 0;
	z-index: var(--cz-z-sticky);
}

.cz-site-header__inner {
	max-width: var(--cz-container-max);
	margin: 0 auto;
	padding: var(--cz-space-3) var(--cz-space-5);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--cz-space-5);
}

@media (min-width: 1024px) {
	.cz-site-header__inner {
		padding: var(--cz-space-3) var(--cz-space-8);
	}
}

.cz-site-header__brand {
	flex-shrink: 0;
}

.cz-site-header__logo-link {
	display: inline-flex;
	align-items: center;
	gap: var(--cz-space-2);
	color: var(--cz-neutral-50);
	text-decoration: none;
}

.cz-site-header__logo-link:hover {
	color: var(--cz-orange-300);
}

.cz-site-header__logo-img {
	max-height: 36px;
	width: auto;
	filter: brightness(0) invert(1); /* Força logo em branco sobre verde — ajustar se logo já vier branco */
}

/* Se o logo customizado for o oficial Cafezall (verde+laranja), remova o filter via classe extra: */
.cz-site-header__logo-img.is-original-color {
	filter: none;
}

.cz-site-header__name {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-md);
	font-weight: var(--cz-weight-medium);
	letter-spacing: -0.02em;
}

.cz-site-header__nav {
	display: none;
	flex: 1;
}

@media (min-width: 1024px) {
	.cz-site-header__nav {
		display: block;
	}
}

.cz-site-header__menu {
	display: flex;
	gap: var(--cz-space-6);
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: var(--cz-text-sm);
}

.cz-site-header__menu li {
	margin: 0;
}

.cz-site-header__menu a {
	color: var(--cz-neutral-300);
	text-decoration: none;
	font-weight: var(--cz-weight-regular);
	transition: color var(--cz-transition-fast);
}

.cz-site-header__menu a:hover,
.cz-site-header__menu .current-menu-item > a,
.cz-site-header__menu .current-menu-parent > a {
	color: var(--cz-neutral-50);
	font-weight: var(--cz-weight-medium);
}

.cz-site-header__menu .sub-menu {
	display: none; /* Mantém simples; pode evoluir para dropdown */
}

.cz-site-header__actions {
	display: flex;
	align-items: center;
	gap: var(--cz-space-3);
}

.cz-site-header__icon {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: transparent;
	border: none;
	color: var(--cz-neutral-200);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background var(--cz-transition-fast);
}

.cz-site-header__icon:hover {
	background-color: rgba(253, 251, 247, 0.08);
	color: var(--cz-orange-300);
}

.cz-site-header__cta {
	padding: var(--cz-space-2) var(--cz-space-4);
	background-color: var(--cz-orange-500);
	color: var(--cz-neutral-50);
	border-radius: var(--cz-radius-sm);
	font-size: var(--cz-text-xs);
	font-weight: var(--cz-weight-medium);
	text-decoration: none;
	transition: background var(--cz-transition-fast);
}

.cz-site-header__cta:hover {
	background-color: var(--cz-orange-700);
	color: var(--cz-neutral-50);
}

.cz-site-header__cta--text {
	background: transparent;
	color: var(--cz-neutral-300);
	font-size: var(--cz-text-sm);
}

.cz-site-header__cta--text:hover {
	background: transparent;
	color: var(--cz-neutral-50);
}

/* Em desktop o ícone de menu mobile some */
@media (min-width: 1024px) {
	.cz-site-header__menu-trigger {
		display: none;
	}
}

/* Search bar expandido */
.cz-site-header__search-bar {
	background-color: var(--cz-green-700);
	padding: var(--cz-space-3) var(--cz-space-5);
	border-top: 0.5px solid rgba(253, 251, 247, 0.1);
}

.cz-site-header__search-bar[hidden] {
	display: none;
}

.cz-search-form {
	display: flex;
	align-items: center;
	gap: var(--cz-space-3);
	max-width: 720px;
	margin: 0 auto;
	padding: var(--cz-space-3) var(--cz-space-4);
	background-color: var(--cz-neutral-50);
	border-radius: var(--cz-radius-pill);
	color: var(--cz-text-secondary);
}

.cz-search-form svg {
	flex-shrink: 0;
}

.cz-search-form__input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: var(--cz-text-sm);
	color: var(--cz-text-primary);
	outline: none;
	font-family: inherit;
}

.cz-search-form__input::placeholder {
	color: var(--cz-text-tertiary);
}

/* =====================================================
   3. MAIN — container do conteúdo
   ===================================================== */

.cz-main {
	min-height: 60vh;
	max-width: var(--cz-container-max);
	margin: 0 auto;
	padding: 0 var(--cz-space-5);
	width: 100%;
}

@media (min-width: 1024px) {
	.cz-main {
		padding: 0 var(--cz-space-8);
	}
}

/* =====================================================
   4. LISTING (index.php) — listagem de posts
   ===================================================== */

.cz-listing {
	padding: var(--cz-space-6) 0 var(--cz-space-12);
}

.cz-listing__header {
	margin-bottom: var(--cz-space-8);
	max-width: 720px;
}

.cz-listing__kicker {
	font-size: var(--cz-text-xs);
	color: var(--cz-orange-700);
	font-weight: var(--cz-weight-medium);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin-bottom: var(--cz-space-2);
}

.cz-listing__title {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-3xl);
	font-weight: var(--cz-weight-medium);
	line-height: var(--cz-leading-tight);
	color: var(--cz-text-primary);
	margin: 0 0 var(--cz-space-3);
	letter-spacing: -0.02em;
}

@media (max-width: 768px) {
	.cz-listing__title {
		font-size: var(--cz-text-2xl);
	}
}

.cz-listing__subtitle {
	font-size: var(--cz-text-base);
	color: var(--cz-text-secondary);
	line-height: var(--cz-leading-relaxed);
	margin: 0;
}

.cz-listing__content {
	margin-top: var(--cz-space-6);
}

/* Grid de posts */
.cz-posts-grid {
	display: grid;
	gap: var(--cz-space-6);
}

@media (min-width: 768px) {
	.cz-posts-grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--cz-space-5);
	}
}

@media (min-width: 1024px) {
	/* Em desktop com sidebar, volta para coluna única no main */
	.cz-listing__main .cz-posts-grid {
		grid-template-columns: 1fr;
	}
}

.cz-posts-grid__ad {
	grid-column: 1 / -1;
	margin: var(--cz-space-3) 0;
}

/* Post card editorial */
.cz-post-card {
	background-color: var(--cz-bg-surface);
	border: 0.5px solid var(--cz-border-subtle);
	border-radius: var(--cz-radius-xl);
	overflow: hidden;
	transition: transform var(--cz-transition-base), border-color var(--cz-transition-fast);
}

.cz-post-card:hover {
	border-color: var(--cz-green-500);
	transform: translateY(-2px);
}

.cz-post-card__media {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background-color: var(--cz-bg-muted);
}

.cz-post-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--cz-transition-base);
}

.cz-post-card:hover .cz-post-card__img {
	transform: scale(1.03);
}

.cz-post-card__body {
	padding: var(--cz-space-4) var(--cz-space-5) var(--cz-space-5);
}

.cz-post-card__category {
	display: inline-block;
	font-size: var(--cz-text-xs);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-orange-700);
	text-decoration: none;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	margin-bottom: var(--cz-space-2);
}

.cz-post-card__category:hover {
	color: var(--cz-orange-800);
}

.cz-post-card__title {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-lg);
	font-weight: var(--cz-weight-medium);
	line-height: var(--cz-leading-tight);
	margin: 0 0 var(--cz-space-3);
	letter-spacing: -0.01em;
}

.cz-post-card__title a {
	color: var(--cz-text-primary);
	text-decoration: none;
}

.cz-post-card__title a:hover {
	color: var(--cz-green-700);
}

.cz-post-card__excerpt {
	font-size: var(--cz-text-sm);
	color: var(--cz-text-secondary);
	line-height: var(--cz-leading-normal);
	margin-bottom: var(--cz-space-3);
}

.cz-post-card__excerpt p {
	margin: 0;
}

.cz-post-card__meta {
	display: flex;
	align-items: center;
	gap: var(--cz-space-2);
	font-size: var(--cz-text-xs);
	color: var(--cz-text-secondary);
}

.cz-post-card__author strong {
	color: var(--cz-text-primary);
	font-weight: var(--cz-weight-medium);
}

/* Paginação */
.cz-pagination {
	margin-top: var(--cz-space-10);
	display: flex;
	justify-content: center;
}

.cz-pagination .nav-links {
	display: flex;
	gap: var(--cz-space-2);
	flex-wrap: wrap;
	justify-content: center;
}

.cz-pagination .page-numbers,
.cz-pagination .nav-links a,
.cz-pagination .nav-links span {
	display: inline-flex;
	align-items: center;
	padding: var(--cz-space-2) var(--cz-space-4);
	background-color: var(--cz-bg-surface);
	border: 0.5px solid var(--cz-border-subtle);
	border-radius: var(--cz-radius-md);
	font-size: var(--cz-text-sm);
	color: var(--cz-text-primary);
	text-decoration: none;
	font-weight: var(--cz-weight-medium);
}

.cz-pagination .page-numbers.current {
	background-color: var(--cz-green-800);
	color: var(--cz-neutral-50);
	border-color: var(--cz-green-800);
}

.cz-pagination a:hover {
	border-color: var(--cz-green-500);
}

/* Sidebar layout */
@media (min-width: 1024px) {
	.cz-listing .cz-two-col {
		grid-template-columns: 1fr 320px;
		gap: var(--cz-space-10);
	}
}

.cz-listing__sidebar {
	margin-top: var(--cz-space-6);
}

@media (min-width: 1024px) {
	.cz-listing__sidebar {
		margin-top: 0;
	}
}

/* No results */
.cz-no-results {
	text-align: center;
	padding: var(--cz-space-12) var(--cz-space-5);
	background-color: var(--cz-bg-surface);
	border-radius: var(--cz-radius-xl);
	border: 0.5px solid var(--cz-border-subtle);
}

.cz-no-results h2 {
	font-family: var(--cz-font-serif);
	margin-bottom: var(--cz-space-2);
}

.cz-no-results p {
	color: var(--cz-text-secondary);
	margin-bottom: var(--cz-space-5);
}

/* =====================================================
   5. SIDEBAR (sidebar.php)
   ===================================================== */

.cz-sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--cz-space-5);
}

.cz-sidebar__widget {
	background-color: var(--cz-bg-surface);
	border: 0.5px solid var(--cz-border-subtle);
	border-radius: var(--cz-radius-lg);
	padding: var(--cz-space-4) var(--cz-space-5);
}

.cz-sidebar__heading {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-base);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-text-primary);
	margin: 0 0 var(--cz-space-3);
}

.cz-sidebar__search {
	display: flex;
	align-items: center;
	gap: var(--cz-space-2);
	padding: var(--cz-space-2) var(--cz-space-3);
	background-color: var(--cz-bg-muted);
	border-radius: var(--cz-radius-pill);
	color: var(--cz-text-secondary);
}

.cz-sidebar__search-input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: var(--cz-text-sm);
	color: var(--cz-text-primary);
	outline: none;
	font-family: inherit;
}

.cz-sidebar__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.cz-sidebar__list--categories li {
	border-bottom: 0.5px solid var(--cz-border-subtle);
}

.cz-sidebar__list--categories li:last-child {
	border-bottom: none;
}

.cz-sidebar__list--categories a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--cz-space-2) 0;
	color: var(--cz-orange-700);
	text-decoration: none;
	font-size: var(--cz-text-sm);
	font-weight: var(--cz-weight-medium);
}

.cz-sidebar__list--categories a:hover {
	color: var(--cz-orange-800);
}

.cz-sidebar__count {
	font-size: var(--cz-text-xs);
	color: var(--cz-text-tertiary);
	background-color: var(--cz-bg-muted);
	padding: 2px 8px;
	border-radius: var(--cz-radius-pill);
	font-weight: var(--cz-weight-regular);
}

.cz-sidebar__list--comments li {
	font-size: var(--cz-text-xs);
	color: var(--cz-text-secondary);
	line-height: var(--cz-leading-normal);
	padding: var(--cz-space-2) 0;
	border-bottom: 0.5px solid var(--cz-border-subtle);
}

.cz-sidebar__list--comments li:last-child {
	border-bottom: none;
}

.cz-sidebar__comment-author {
	font-weight: var(--cz-weight-medium);
	color: var(--cz-text-primary);
}

.cz-sidebar__comment-on {
	color: var(--cz-text-tertiary);
}

.cz-sidebar__list--comments a {
	color: var(--cz-orange-700);
	text-decoration: none;
}

.cz-sidebar__ad {
	margin-top: var(--cz-space-4);
}

/* =====================================================
   6. SINGLE POST (single.php) — leitura editorial
   ===================================================== */

.cz-single {
	background-color: var(--cz-bg-surface);
	border-radius: var(--cz-radius-2xl);
	border: 0.5px solid var(--cz-border-subtle);
	overflow: hidden;
	margin: var(--cz-space-6) 0 var(--cz-space-12);
}

.cz-single__header {
	padding: var(--cz-space-6) var(--cz-space-5) var(--cz-space-5);
}

.cz-single__header-inner {
	max-width: 720px;
	margin: 0 auto;
}

.cz-single__category {
	display: inline-block;
	font-size: var(--cz-text-xs);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-orange-700);
	text-decoration: none;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin-bottom: var(--cz-space-3);
}

.cz-single__title {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-3xl);
	font-weight: var(--cz-weight-medium);
	line-height: 1.15;
	color: var(--cz-text-primary);
	margin: 0 0 var(--cz-space-4);
	letter-spacing: -0.02em;
}

@media (max-width: 768px) {
	.cz-single__title {
		font-size: var(--cz-text-2xl);
	}
}

.cz-single__deck {
	font-size: var(--cz-text-md);
	color: var(--cz-text-secondary);
	line-height: var(--cz-leading-relaxed);
	margin: 0 0 var(--cz-space-5);
	font-family: var(--cz-font-sans);
	font-weight: var(--cz-weight-regular);
}

.cz-single__meta {
	display: flex;
	align-items: center;
	gap: var(--cz-space-3);
	padding-top: var(--cz-space-4);
	border-top: 0.5px solid var(--cz-border-subtle);
}

.cz-single__avatar {
	border-radius: 50%;
	width: 36px;
	height: 36px;
}

.cz-single__author {
	font-size: var(--cz-text-sm);
	color: var(--cz-text-primary);
}

.cz-single__date {
	font-size: var(--cz-text-xs);
	color: var(--cz-text-secondary);
}

.cz-single__hero {
	margin: 0;
	max-width: 100%;
}

.cz-single__hero-img {
	width: 100%;
	height: auto;
	display: block;
}

.cz-single__hero-caption {
	font-size: var(--cz-text-xs);
	color: var(--cz-text-tertiary);
	font-style: italic;
	padding: var(--cz-space-3) var(--cz-space-5);
	max-width: 720px;
	margin: 0 auto;
	text-align: center;
}

.cz-single__body {
	padding: var(--cz-space-8) var(--cz-space-5) var(--cz-space-8);
	max-width: 720px;
	margin: 0 auto;
}

@media (min-width: 768px) {
	.cz-single__body {
		padding: var(--cz-space-10) var(--cz-space-8);
	}
}

/* Tags do post */
.cz-single__tags {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--cz-space-2);
	margin: var(--cz-space-8) 0 var(--cz-space-6);
	padding-top: var(--cz-space-5);
	border-top: 0.5px solid var(--cz-border-subtle);
}

.cz-single__tags-label {
	font-size: var(--cz-text-xs);
	color: var(--cz-text-secondary);
	font-weight: var(--cz-weight-medium);
	margin-right: var(--cz-space-2);
}

.cz-single__tag {
	padding: 4px 10px;
	background-color: var(--cz-orange-50);
	color: var(--cz-orange-800);
	font-size: var(--cz-text-xs);
	border-radius: var(--cz-radius-pill);
	text-decoration: none;
}

.cz-single__tag:hover {
	background-color: var(--cz-orange-100);
	color: var(--cz-orange-900);
}

/* Bio do autor */
.cz-author-bio {
	display: flex;
	gap: var(--cz-space-4);
	padding: var(--cz-space-5);
	background-color: var(--cz-bg-muted);
	border-radius: var(--cz-radius-lg);
	margin: var(--cz-space-8) 0;
}

.cz-author-bio__avatar {
	border-radius: 50%;
	width: 56px;
	height: 56px;
	flex-shrink: 0;
}

.cz-author-bio__name {
	font-size: var(--cz-text-sm);
	color: var(--cz-text-primary);
	margin-bottom: var(--cz-space-1);
}

.cz-author-bio__desc {
	font-size: var(--cz-text-sm);
	color: var(--cz-text-secondary);
	line-height: var(--cz-leading-normal);
	margin: 0;
}

/* Posts relacionados */
.cz-related {
	margin: var(--cz-space-10) 0 0;
	padding-top: var(--cz-space-8);
	border-top: 0.5px solid var(--cz-border-subtle);
}

.cz-related__title {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-xl);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-text-primary);
	margin: 0 0 var(--cz-space-5);
}

.cz-related__grid {
	display: grid;
	gap: var(--cz-space-4);
}

@media (min-width: 768px) {
	.cz-related__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.cz-related__card {
	display: flex;
	gap: var(--cz-space-3);
	background-color: var(--cz-bg-surface);
	border: 0.5px solid var(--cz-border-subtle);
	border-radius: var(--cz-radius-lg);
	padding: var(--cz-space-3);
	text-decoration: none;
	transition: border-color var(--cz-transition-fast);
}

.cz-related__card:hover {
	border-color: var(--cz-green-500);
}

.cz-related__media {
	flex-shrink: 0;
	width: 80px;
	height: 80px;
	border-radius: var(--cz-radius-md);
	overflow: hidden;
}

.cz-related__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cz-related__heading {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-sm);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-text-primary);
	margin: 0 0 var(--cz-space-1);
	line-height: var(--cz-leading-tight);
}

.cz-related__date {
	font-size: var(--cz-text-xs);
	color: var(--cz-text-secondary);
}

/* =====================================================
   7. PAGE (page.php) — páginas estáticas
   ===================================================== */

.cz-page {
	background-color: var(--cz-bg-surface);
	border-radius: var(--cz-radius-2xl);
	border: 0.5px solid var(--cz-border-subtle);
	overflow: hidden;
	margin: var(--cz-space-6) 0 var(--cz-space-12);
}

.cz-page__header {
	padding: var(--cz-space-6) var(--cz-space-5) var(--cz-space-5);
}

.cz-page__header-inner {
	max-width: 720px;
	margin: 0 auto;
}

.cz-page__title {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-3xl);
	font-weight: var(--cz-weight-medium);
	line-height: 1.15;
	color: var(--cz-text-primary);
	margin: 0;
	letter-spacing: -0.02em;
}

@media (max-width: 768px) {
	.cz-page__title { font-size: var(--cz-text-2xl); }
}

.cz-page__hero img {
	width: 100%;
	height: auto;
	display: block;
}

.cz-page__body {
	padding: var(--cz-space-8) var(--cz-space-5);
	max-width: 720px;
	margin: 0 auto;
}

@media (min-width: 768px) {
	.cz-page__body {
		padding: var(--cz-space-10) var(--cz-space-8);
	}
}

/* =====================================================
   8. EDITORIAL CONTENT — corpo de posts e páginas
   ===================================================== */

.cz-editorial-content {
	font-size: var(--cz-text-base);
	line-height: 1.75;
	color: var(--cz-text-primary);
}

.cz-editorial-content p {
	margin: 0 0 var(--cz-space-5);
}

.cz-editorial-content h2 {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-xl);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-text-primary);
	margin: var(--cz-space-10) 0 var(--cz-space-4);
	line-height: 1.25;
	letter-spacing: -0.01em;
}

.cz-editorial-content h3 {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-lg);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-text-primary);
	margin: var(--cz-space-8) 0 var(--cz-space-3);
	line-height: 1.3;
}

.cz-editorial-content h4 {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-md);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-text-primary);
	margin: var(--cz-space-6) 0 var(--cz-space-2);
}

.cz-editorial-content a {
	color: var(--cz-orange-700);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

.cz-editorial-content a:hover {
	color: var(--cz-orange-800);
	text-decoration-thickness: 2px;
}

.cz-editorial-content strong,
.cz-editorial-content b {
	font-weight: var(--cz-weight-medium);
	color: var(--cz-text-primary);
}

.cz-editorial-content blockquote {
	border-left: 3px solid var(--cz-orange-500);
	padding: var(--cz-space-2) 0 var(--cz-space-2) var(--cz-space-5);
	margin: var(--cz-space-6) 0;
	font-family: var(--cz-font-serif);
	font-style: italic;
	font-size: var(--cz-text-md);
	color: var(--cz-text-secondary);
}

.cz-editorial-content blockquote p:last-child {
	margin-bottom: 0;
}

.cz-editorial-content ul,
.cz-editorial-content ol {
	margin: 0 0 var(--cz-space-5);
	padding-left: var(--cz-space-6);
}

.cz-editorial-content li {
	margin-bottom: var(--cz-space-2);
}

.cz-editorial-content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--cz-radius-lg);
	margin: var(--cz-space-6) 0;
}

.cz-editorial-content figure {
	margin: var(--cz-space-6) 0;
}

.cz-editorial-content figure img {
	margin: 0;
}

.cz-editorial-content figcaption {
	font-size: var(--cz-text-xs);
	color: var(--cz-text-tertiary);
	font-style: italic;
	text-align: center;
	margin-top: var(--cz-space-2);
}

.cz-editorial-content code {
	background-color: var(--cz-bg-muted);
	padding: 2px 6px;
	border-radius: var(--cz-radius-sm);
	font-size: 0.9em;
	font-family: ui-monospace, SFMono-Regular, monospace;
}

.cz-editorial-content pre {
	background-color: var(--cz-green-900);
	color: var(--cz-orange-100);
	padding: var(--cz-space-4);
	border-radius: var(--cz-radius-md);
	overflow-x: auto;
	margin: var(--cz-space-6) 0;
}

.cz-editorial-content pre code {
	background: transparent;
	padding: 0;
	color: inherit;
}

/* =====================================================
   9. SITE FOOTER (footer.php)
   ===================================================== */

.cz-site-footer {
	background-color: var(--cz-green-800);
	color: var(--cz-neutral-300);
	margin-top: var(--cz-space-12);
}

.cz-site-footer__inner {
	max-width: var(--cz-container-max);
	margin: 0 auto;
	padding: var(--cz-space-10) var(--cz-space-5);
	display: grid;
	gap: var(--cz-space-8);
}

@media (min-width: 768px) {
	.cz-site-footer__inner {
		grid-template-columns: 2fr 1fr 1fr;
		padding: var(--cz-space-10) var(--cz-space-8);
	}
}

.cz-site-footer__brand {
	display: flex;
	align-items: center;
	gap: var(--cz-space-2);
	margin-bottom: var(--cz-space-3);
}

.cz-site-footer__name {
	font-family: var(--cz-font-serif);
	font-size: var(--cz-text-md);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-neutral-50);
	letter-spacing: -0.02em;
}

.cz-site-footer__tagline {
	font-size: var(--cz-text-sm);
	color: var(--cz-neutral-300);
	margin: 0;
	line-height: var(--cz-leading-normal);
}

.cz-site-footer__heading {
	font-size: var(--cz-text-sm);
	font-weight: var(--cz-weight-medium);
	color: var(--cz-neutral-50);
	margin: 0 0 var(--cz-space-3);
	letter-spacing: 0.3px;
}

.cz-site-footer__list {
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: var(--cz-text-sm);
}

.cz-site-footer__list li {
	margin-bottom: var(--cz-space-2);
}

.cz-site-footer__list a {
	color: var(--cz-neutral-300);
	text-decoration: none;
	transition: color var(--cz-transition-fast);
}

.cz-site-footer__list a:hover {
	color: var(--cz-orange-300);
}

.cz-site-footer__bottom {
	border-top: 0.5px solid rgba(253, 251, 247, 0.1);
	padding: var(--cz-space-4) var(--cz-space-5);
	text-align: center;
	font-size: var(--cz-text-xs);
	color: var(--cz-neutral-500);
}

@media (min-width: 768px) {
	.cz-site-footer__bottom {
		padding: var(--cz-space-4) var(--cz-space-8);
	}
}

/* No mobile, deixa espaço para o bottom nav não cobrir o footer */
@media (max-width: 1023px) {
	.cz-site-footer {
		padding-bottom: 80px;
	}
}

/* =====================================================
   10. AJUSTES GERAIS — comments, busca, 404
   ===================================================== */

#comments {
	margin-top: var(--cz-space-10);
	padding-top: var(--cz-space-8);
	border-top: 0.5px solid var(--cz-border-subtle);
}

#comments h2,
#comments h3 {
	font-family: var(--cz-font-serif);
	color: var(--cz-text-primary);
}

.commentlist,
.comment-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: var(--cz-space-3);
	background-color: var(--cz-bg-surface);
	border: 0.5px solid var(--cz-border-subtle);
	border-radius: var(--cz-radius-md);
	font-family: var(--cz-font-sans);
	font-size: var(--cz-text-sm);
	color: var(--cz-text-primary);
}

.comment-form input[type="submit"],
.comment-form button[type="submit"],
.cz-search-submit {
	padding: var(--cz-space-3) var(--cz-space-5);
	background-color: var(--cz-green-800);
	color: var(--cz-neutral-50);
	border: none;
	border-radius: var(--cz-radius-md);
	font-size: var(--cz-text-sm);
	font-weight: var(--cz-weight-medium);
	cursor: pointer;
	font-family: inherit;
}

.comment-form input[type="submit"]:hover {
	background-color: var(--cz-green-700);
}
