/* ============================================================
   Simone Cortes — main.css
   Layout editorial responsivo, estilo Medium.com
   ============================================================ */

/* ---------- Layout base ---------- */
.site {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}
.site-content {
	flex: 1;
}
.container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 20px;
}

/* ---------- Botões ---------- */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: 14px;
	line-height: 1;
	padding: 12px 20px;
	border-radius: 999px;
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: all .15s ease;
	white-space: nowrap;
}
.btn--accent { background: var(--color-brand); color: var(--color-on-brand); }
.btn--accent:hover { background: var(--color-brand-hover); color: var(--color-on-brand); }
.btn--ghost { background: transparent; border-color: var(--color-border); color: var(--color-text); }
.btn--ghost:hover { border-color: var(--color-text); color: var(--color-text); }
.btn--sm { padding: 8px 14px; font-size: 13px; }

/* ---------- Top banner ---------- */
.top-banner--bar {
	background: var(--color-primary);
	color: #fff;
	font-size: 14px;
}
.top-banner--bar .top-banner__inner {
	max-width: var(--container);
	margin: 0 auto;
	padding: 10px 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
}
.top-banner--card {
	max-width: var(--container);
	margin: 16px auto 0;
	padding: 0 20px;
}
.top-banner--card .top-banner__inner {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 18px 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}
.top-banner__tipo { font-weight: 600; }
.top-banner--bar a:not(.btn) { color: #fff; }

/* ---------- Header ---------- */
.site-header {
	background: var(--color-brand);
	border-bottom: 1px solid var(--color-border);
	position: sticky;
	top: 0;
	z-index: 50;
	backdrop-filter: saturate(180%) blur(8px);
}
.site-header__inner {
	max-width: var(--container);
	margin: 0 auto;
	padding: 14px 20px;
	display: flex;
	align-items: center;
	gap: 24px;
}
.site-brand { margin-right: auto; }
.site-brand img { max-height: 40px; width: auto; }
.site-brand__name {
	font-family: var(--font-serif);
	font-size: 22px;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: -0.02em;
}
.main-nav { display: flex; align-items: center; }
.main-nav ul#primary-menu { list-style: none; display: flex; gap: 22px; margin: 0; padding: 0; }
.main-nav li a {
	font-size: 14.5px;
	color: var(--color-text);
	font-weight: 500;
	padding: 6px 0;
}
.main-nav li a:hover { color: var(--color-accent); }
.site-header__actions { display: flex; align-items: center; gap: 10px; }
.nav-toggle {
	display: none;
	flex-direction: column;
	gap: 4px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 6px;
}
.nav-toggle__bar { width: 22px; height: 2px; background: var(--color-primary); border-radius: 2px; }

/* Busca */
.search-form { display: flex; align-items: center; border: 1px solid var(--color-border); border-radius: 999px; overflow: hidden; }
.search-field { border: none; padding: 8px 14px; font-size: 14px; font-family: var(--font-sans); background: transparent; outline: none; width: 160px; }
.search-submit { border: none; background: none; cursor: pointer; padding: 6px 12px; font-size: 16px; color: var(--color-muted); }

/* ---------- Hero ---------- */
.hero {
	max-width: var(--container);
	margin: 0 auto;
	padding: 48px 20px 40px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 48px;
	align-items: center;
}
.hero__eyebrow {
	font-family: var(--font-sans);
	text-transform: uppercase;
	letter-spacing: 0.14em;
	font-size: 12px;
	font-weight: 600;
	color: var(--color-accent);
	margin: 0 0 10px;
}
.hero__name {
	font-family: var(--font-serif);
	font-size: clamp(40px, 6vw, 64px);
	line-height: 1.05;
	font-weight: 700;
	letter-spacing: -0.03em;
	margin: 0 0 18px;
	color: var(--color-primary);
}
.hero__text {
	font-family: var(--font-serif);
	font-size: 20px;
	line-height: 1.5;
	color: var(--color-muted);
	margin: 0 0 28px;
	max-width: 36ch;
}
.hero__actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 36px; }
.hero__stats { display: flex; gap: 36px; }
.hero__stats strong {
	display: block;
	font-family: var(--font-serif);
	font-size: 30px;
	font-weight: 700;
	color: var(--color-primary);
}
.hero__stats span { font-size: 13px; color: var(--color-muted); }

.hero__featured {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 8px;
}
.hero__list { list-style: none; margin: 0; padding: 0; }
.hero__item { border-bottom: 1px solid var(--color-border); }
.hero__item:last-child { border-bottom: none; }
.hero__item-link {
	display: flex;
	gap: 14px;
	padding: 16px;
	align-items: flex-start;
}
.hero__item-thumb { flex-shrink: 0; width: 56px; height: 56px; border-radius: 6px; overflow: hidden; }
.hero__item-thumb img { width: 100%; height: 100%; object-fit: cover; }
.hero__item-text { display: flex; flex-direction: column; gap: 4px; }
.hero__item-cat { font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; color: var(--color-accent); }
.hero__item-title { font-family: var(--font-serif); font-size: 18px; font-weight: 600; line-height: 1.3; color: var(--color-primary); }
.hero__item-link:hover .hero__item-title { color: var(--color-accent); }
.hero__item-text time { font-size: 13px; color: var(--color-muted); }

/* ---------- Home layout ---------- */
.home-layout {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 20px 60px;
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 48px;
	align-items: start;
}
.home-aside { position: sticky; top: 88px; }

/* ---------- Sections ---------- */
.section { margin-bottom: 56px; }
.section__head { margin-bottom: 24px; }
.section__head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; }
.section__kicker { font-size: 12px; color: var(--color-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; }
.section__title {
	font-family: var(--font-serif);
	font-size: 30px;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin: 4px 0 0;
	color: var(--color-primary);
}
.section__desc { color: var(--color-muted); margin: 8px 0 0; font-size: 15px; }
.section__more { font-size: 14px; font-weight: 600; color: var(--color-accent); white-space: nowrap; }

/* ---------- Post grid / cards ---------- */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.post-grid--4 { grid-template-columns: repeat(4, 1fr); gap: 22px; }
.post-grid--3 { grid-template-columns: repeat(3, 1fr); }

.post-card { display: flex; flex-direction: column; }
.post-card--large { grid-column: span 3; flex-direction: row; gap: 24px; align-items: center; }
.post-card--large .post-card__thumb { flex: 1; }
.post-card--large .post-card__body { flex: 1; }
.post-card--large .post-card__title { font-size: 30px; }
.post-card__thumb { display: block; border-radius: var(--radius); overflow: hidden; margin-bottom: 14px; aspect-ratio: 16/10; }
.post-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s ease; }
.post-card:hover .post-card__thumb img { transform: scale(1.03); }
.post-card__cat { font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; color: var(--color-accent); }
.post-card__title {
	font-family: var(--font-serif);
	font-size: 21px;
	line-height: 1.25;
	font-weight: 600;
	margin: 6px 0 8px;
	letter-spacing: -0.01em;
	color: var(--color-primary);
}
.post-card__title a { color: inherit; }
.post-card__title a:hover { color: var(--color-accent); }
.post-card__excerpt { font-size: 15px; color: var(--color-muted); margin: 0 0 12px; line-height: 1.5; }
.post-card__meta { font-size: 13px; color: var(--color-muted); display: flex; gap: 6px; align-items: center; }

/* ---------- Ranking (mais lidos) ---------- */
.ranking { list-style: none; margin: 0; padding: 0; counter-reset: none; }
.ranking__item { display: flex; gap: 16px; align-items: flex-start; padding: 16px 0; border-bottom: 1px solid var(--color-border); }
.ranking__item:last-child { border-bottom: none; }
.ranking__num { font-family: var(--font-serif); font-size: 28px; font-weight: 700; color: var(--color-border); line-height: 1; min-width: 32px; }
.ranking__link { display: flex; flex-direction: column; gap: 4px; }
.ranking__title { font-family: var(--font-serif); font-size: 17px; font-weight: 600; line-height: 1.3; color: var(--color-primary); }
.ranking__link:hover .ranking__title { color: var(--color-accent); }
.ranking__cat { font-size: 12px; color: var(--color-muted); }

/* ---------- Banner de produto ---------- */
.banner-produto {
	position: relative;
	border: 1px solid var(--color-border);
	border-top: 3px solid var(--color-brand);
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-bg);
	display: flex;
	flex-direction: column;
	box-shadow: 0 2px 10px rgba(25, 25, 25, 0.06);
	transition: transform .18s ease, box-shadow .18s ease;
}
.banner-produto:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(25, 25, 25, 0.14);
}
.banner-produto--banner { flex-direction: row; align-items: stretch; }
.banner-produto--banner .banner-produto__thumb { width: 40%; flex-shrink: 0; }
.banner-produto--banner .banner-produto__thumb img { width: 100%; height: 100%; object-fit: cover; }
.banner-produto--banner .banner-produto__body { flex: 1; }
.banner-produto__body { padding: 20px; }
.banner-produto__tipo {
	display: inline-block; font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em;
	font-weight: 600; color: var(--color-accent); margin-bottom: 6px;
}
.banner-produto__badge {
	display: inline-block; background: var(--color-primary); color: #fff;
	font-size: 11px; font-weight: 600; padding: 3px 8px; border-radius: 999px; margin-bottom: 8px;
}
.banner-produto__title { font-family: var(--font-serif); font-size: 20px; font-weight: 700; line-height: 1.25; margin: 0 0 8px; color: var(--color-primary); }
.banner-produto__excerpt { font-size: 14px; color: var(--color-muted); margin: 0 0 12px; }
.banner-produto__preco { font-weight: 800; font-size: 20px; color: var(--color-primary); margin: 0 0 14px; letter-spacing: -0.01em; }
.banner-produto__cta { width: 100%; background: var(--color-brand); color: var(--color-on-brand); border-color: var(--color-brand); font-weight: 700; }
.banner-produto__cta:hover { background: var(--color-brand-hover); color: var(--color-on-brand); border-color: var(--color-brand-hover); }

/* Seção de produtos na home: faixa de destaque (contrasta com o conteúdo editorial) */
.section--produtos {
	background: var(--color-primary);
	padding: 56px 0 60px;
	margin: 72px 0 0;
}
.section--produtos .section__head--produtos { text-align: center; max-width: 640px; margin: 0 auto 36px; }
.section--produtos .section__kicker { color: var(--color-brand); }
.section--produtos .section__title { color: #fff; font-size: 34px; }
.section--produtos .section__desc { color: rgba(255, 255, 255, 0.66); }
.section--produtos .banner-produto { border-top-color: var(--color-brand); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.28); }
.section--produtos .banner-produto:hover { box-shadow: 0 18px 40px rgba(0, 0, 0, 0.38); }

/* ---------- Single post ---------- */
.single-layout {
	max-width: 1180px;
	margin: 0 auto;
	padding: 40px 20px 60px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 300px;
	gap: 56px;
	align-items: start;
}
.single-post { min-width: 0; }
.single-post__cats { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
.single-post__cat { font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; color: var(--color-accent); }
.single-post__cats .single-post__cat { padding: 3px 10px; border: 1px solid var(--color-border); border-radius: 999px; transition: border-color .15s ease, color .15s ease; }
.single-post__cats .single-post__cat:hover { border-color: var(--color-accent); }
.single-post__title {
	font-family: var(--font-serif);
	font-size: clamp(30px, 4vw, 44px);
	line-height: 1.12;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin: 10px 0 16px;
	color: var(--color-primary);
}
.single-post__meta { font-size: 14px; color: var(--color-muted); display: flex; gap: 6px; align-items: center; }
.single-post__thumb { margin: 24px 0; border-radius: var(--radius-lg); overflow: hidden; }
.single-post__content {
	font-family: var(--font-serif);
	font-size: 20px;
	line-height: 1.7;
	color: var(--color-text);
}
.single-post__content p { margin: 0 0 1.5em; }
.single-post__content h2 { font-family: var(--font-serif); font-size: 30px; margin: 1.6em 0 0.6em; font-weight: 700; }
.single-post__content h3 { font-family: var(--font-serif); font-size: 24px; margin: 1.4em 0 0.5em; font-weight: 700; }
.single-post__content a { color: var(--color-accent); text-decoration: underline; }
.single-post__content blockquote {
	border-left: 3px solid var(--color-brand);
	padding: 4px 0 4px 20px;
	margin: 1.6em 0;
	font-style: italic;
	color: var(--color-muted);
}
.single-post__content img { border-radius: var(--radius); }
.single-post__content ul, .single-post__content ol { padding-left: 1.4em; margin: 0 0 1.5em; }
.single-post__content li { margin-bottom: 0.4em; }
.single-post__content figure { margin: 1.6em 0; }
.single-post__content figcaption { font-size: 14px; color: var(--color-muted); text-align: center; margin-top: 6px; font-family: var(--font-sans); }

.single-post__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 32px; }
.single-post__tags a {
	font-size: 13px; padding: 4px 12px; border: 1px solid var(--color-border); border-radius: 999px; color: var(--color-muted);
}
.single-post__tags a:hover { border-color: var(--color-text); color: var(--color-text); }
.single-post__author-box { display: flex; gap: 16px; padding: 24px; background: var(--color-surface); border-radius: var(--radius-lg); }
.single-post__author-box .avatar { border-radius: 50%; }
.single-post__author-name { font-family: var(--font-serif); font-weight: 700; font-size: 17px; margin: 0 0 4px; color: var(--color-primary); }
.single-post__author-bio { font-size: 14px; color: var(--color-muted); margin: 0; }

.related { margin-top: 56px; }
.related__title { font-family: var(--font-serif); font-size: 24px; font-weight: 700; margin-bottom: 20px; color: var(--color-primary); }

/* ---------- Comentários ---------- */
.comments { margin-top: 56px; padding-top: 40px; border-top: 1px solid var(--color-border); }
.comments__title { font-family: var(--font-serif); font-size: 24px; font-weight: 700; margin: 0 0 24px; color: var(--color-primary); }
.comments__list { list-style: none; margin: 0 0 32px; padding: 0; }
.comments__list ol.children { list-style: none; margin: 16px 0 0; padding: 0 0 0 28px; border-left: 2px solid var(--color-border); }
.comments__list li.comment { margin-bottom: 20px; }
.comments__list .comment-body { padding: 18px 20px; background: var(--color-surface); border-radius: var(--radius-lg); }
.comments__list .comment-author { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.comments__list .comment-author .avatar { border-radius: 50%; }
.comments__list .comment-author .fn { font-family: var(--font-serif); font-weight: 700; font-size: 15px; color: var(--color-primary); font-style: normal; }
.comments__list .comment-author .says { display: none; }
.comments__list .comment-meta { font-size: 12px; color: var(--color-muted); margin-bottom: 8px; }
.comments__list .comment-meta a { color: var(--color-muted); text-decoration: none; }
.comments__list .comment-content { font-size: 15px; line-height: 1.6; color: var(--color-text); }
.comments__list .comment-content p { margin: 0 0 0.8em; }
.comments__list .reply { margin-top: 8px; font-size: 13px; }
.comments__list .reply a { color: var(--color-accent); font-weight: 600; text-decoration: none; }
.comments__list .comment-awaiting-moderation { font-size: 13px; color: var(--color-muted); font-style: italic; }
.comments__closed { font-size: 14px; color: var(--color-muted); margin-bottom: 24px; }

.comment-respond { margin-top: 8px; }
.comment-reply-title { font-family: var(--font-serif); font-size: 20px; font-weight: 700; margin: 0 0 8px; color: var(--color-primary); }
.comment-reply-title small { font-weight: 400; font-size: 14px; margin-left: 8px; }
.comment-form__notes, .comment-notes { font-size: 13px; color: var(--color-muted); margin: 0 0 18px; }
.comment-form { display: flex; flex-direction: column; gap: 14px; }
.comment-form p { margin: 0; }
.comment-form label { display: block; font-size: 13px; font-weight: 600; color: var(--color-primary); margin-bottom: 6px; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%; box-sizing: border-box; padding: 10px 12px;
	border: 1px solid var(--color-border); border-radius: 8px;
	font-family: var(--font-sans); font-size: 15px; color: var(--color-text); background: #fff;
}
.comment-form textarea { min-height: 120px; resize: vertical; }
.comment-form input:focus, .comment-form textarea:focus { outline: none; border-color: var(--color-accent); }
.comment-form .comment-form-author, .comment-form .comment-form-email, .comment-form .comment-form-url { max-width: 360px; }
.comment-form .comment-form-cookies-consent { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--color-muted); }
.comment-form .comment-form-cookies-consent label { margin: 0; font-weight: 400; }
.comment-form .form-submit { margin-top: 4px; }
.comment-form .required { color: var(--color-accent); }

.sidebar { position: sticky; top: 88px; display: flex; flex-direction: column; gap: 24px; }
.sidebar .widget { margin: 0; }
.widget-title { font-family: var(--font-serif); font-size: 18px; font-weight: 700; margin-bottom: 14px; color: var(--color-primary); }

/* Blocos da sidebar (relacionados / mais lidos) */
.sidebar-block { padding: 20px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.sidebar-block .widget-title { margin-bottom: 16px; padding-bottom: 12px; border-bottom: 2px solid var(--color-brand); }

.sidebar-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.sidebar-list__link { display: flex; gap: 12px; align-items: center; }
.sidebar-list__thumb { flex-shrink: 0; width: 60px; height: 60px; border-radius: var(--radius); overflow: hidden; }
.sidebar-list__thumb img { width: 100%; height: 100%; object-fit: cover; }
.sidebar-list__title { font-family: var(--font-serif); font-size: 14px; font-weight: 600; line-height: 1.3; color: var(--color-primary); transition: color .15s ease; }
.sidebar-list__link:hover .sidebar-list__title { color: var(--color-accent); }

.sidebar-ranking { list-style: none; margin: 0; padding: 0; counter-reset: none; display: flex; flex-direction: column; gap: 12px; }
.sidebar-ranking__item { display: flex; gap: 12px; align-items: baseline; }
.sidebar-ranking__num { font-family: var(--font-serif); font-size: 20px; font-weight: 700; color: var(--color-brand); line-height: 1; min-width: 20px; }
.sidebar-ranking__link { font-size: 14px; line-height: 1.35; color: var(--color-text); transition: color .15s ease; }
.sidebar-ranking__link:hover { color: var(--color-accent); }

/* ---------- Archive / search layouts ---------- */
.archive-layout, .archive-layout { max-width: 1180px; margin: 0 auto; padding: 40px 20px 60px; display: grid; grid-template-columns: minmax(0,1fr) 300px; gap: 56px; align-items: start; }
.archive-main { min-width: 0; }
.page-head { margin-bottom: 32px; }
.page-kicker { font-size: 12px; color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; }
.page-title { font-family: var(--font-serif); font-size: 36px; font-weight: 700; letter-spacing: -0.02em; margin: 6px 0 0; color: var(--color-primary); }
.archive-desc { color: var(--color-muted); margin-top: 10px; }

/* ---------- 404 ---------- */
.error-404 { max-width: 640px; margin: 80px auto; padding: 0 20px; text-align: center; }
.error-404 .page-title { font-family: var(--font-serif); font-size: 40px; margin-bottom: 16px; }
.error-404 p { color: var(--color-muted); margin-bottom: 24px; }
.error-404 .search-form { justify-content: center; margin-bottom: 24px; }

/* ---------- Footer ---------- */
.site-footer { background: var(--color-primary); color: rgba(255, 255, 255, 0.78); margin-top: auto; }
.site-footer__inner {
	max-width: var(--container); margin: 0 auto; padding: 56px 20px 40px;
	display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.1fr; gap: 40px; align-items: start;
}
.site-footer__brand { font-family: var(--font-serif); font-size: 22px; font-weight: 700; color: #fff; margin: 0 0 8px; }
.site-footer__desc { font-size: 14px; color: rgba(255, 255, 255, 0.6); margin: 0 0 16px; line-height: 1.5; }
.site-footer__title { font-size: 12px; text-transform: uppercase; letter-spacing: 0.12em; font-weight: 700; color: var(--color-brand); margin: 0 0 16px; }

/* Listas (posts / links / contato) */
.site-footer__posts, .site-footer__links, .site-footer__contact, .site-footer .menu {
	list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px;
}
.site-footer__posts a, .site-footer__links a, .site-footer__contact a, .site-footer .menu a {
	font-size: 14px; color: rgba(255, 255, 255, 0.78); text-decoration: none; line-height: 1.4;
	transition: color .15s ease;
}
.site-footer__posts a:hover, .site-footer__links a:hover, .site-footer__contact a:hover, .site-footer .menu a:hover { color: var(--color-brand); }
.site-footer__posts li { position: relative; padding-left: 18px; }
.site-footer__posts li::before { content: "›"; position: absolute; left: 0; color: var(--color-brand); font-weight: 700; }

/* Redes sociais */
.site-footer__social { list-style: none; margin: 0; padding: 0; display: flex; gap: 10px; }
.site-footer__social-link {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: 50%;
	background: rgba(255, 255, 255, 0.08); color: #fff;
	transition: background .15s ease, color .15s ease, transform .15s ease;
}
.site-footer__social-link:hover { background: var(--color-brand); color: var(--color-on-brand); transform: translateY(-2px); }

.site-footer__cta { margin-top: 18px; }

/* Barra inferior */
.site-footer__bottom { border-top: 1px solid rgba(255, 255, 255, 0.12); }
.site-footer__bottom-inner {
	max-width: var(--container); margin: 0 auto; padding: 20px;
	display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.site-footer__bottom p { font-size: 13px; color: rgba(255, 255, 255, 0.5); margin: 0; }
.site-footer__cnpj { display: inline-block; margin-left: 8px; padding-left: 8px; border-left: 1px solid rgba(255, 255, 255, 0.2); }
.site-footer__legal { display: flex; gap: 18px; flex-wrap: wrap; }
.site-footer__legal a { font-size: 13px; color: rgba(255, 255, 255, 0.5); text-decoration: none; }
.site-footer__legal a:hover { color: var(--color-brand); }

/* ---------- Paginação ---------- */
.pagination, .navigation { margin-top: 40px; }
.pagination .nav-links { display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; }
.pagination a, .pagination span {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 38px; height: 38px; padding: 0 12px; border: 1px solid var(--color-border); border-radius: 8px;
	font-size: 14px; color: var(--color-text); text-decoration: none;
}
.pagination a:hover { border-color: var(--color-text); }
.pagination .current { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

/* ---------- Responsivo ---------- */
@media (max-width: 1024px) {
	.home-layout { grid-template-columns: 1fr; }
	.home-aside { position: static; display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
	.single-layout, .archive-layout { grid-template-columns: 1fr; }
	.sidebar { position: static; }
	.post-grid--4 { grid-template-columns: repeat(2, 1fr); }
	.site-footer__inner { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 768px) {
	.hero { grid-template-columns: 1fr; gap: 32px; padding: 32px 20px; }
	.hero__stats { gap: 24px; }
	.post-grid { grid-template-columns: 1fr; }
	.post-card--large { grid-column: span 1; flex-direction: column; }
	.post-card--large .post-card__title { font-size: 24px; }
	.site-footer__inner { grid-template-columns: 1fr; gap: 32px; }
	.site-footer__bottom-inner { flex-direction: column; align-items: flex-start; gap: 8px; }
	.home-aside { grid-template-columns: 1fr; }
	.main-nav ul#primary-menu {
		position: absolute; top: 100%; left: 0; right: 0;
		flex-direction: column; background: var(--color-brand); border-bottom: 1px solid var(--color-border);
		padding: 12px 20px; gap: 0; display: none;
	}
	.main-nav.menu-open ul#primary-menu { display: flex; }
	.main-nav li { padding: 10px 0; border-bottom: 1px solid var(--color-border); }
	.main-nav li:last-child { border-bottom: none; }
	.nav-toggle { display: flex; }
	.search-field { width: 120px; }
}
@media (max-width: 480px) {
	.post-grid--4, .post-grid--3 { grid-template-columns: 1fr; }
	.banner-produto--banner { flex-direction: column; }
	.banner-produto--banner .banner-produto__thumb { width: 100%; aspect-ratio: 16/9; }
}
