/* =========================================================
   PINGOU NA MÍDIA — FOLHA DE ESTILO PRINCIPAL
   1. Tokens (cores, tipo, espaços) — dark padrão + claro
   2. Reset & base
   3. Layout (container, grades)
   4. Ícones
   5. Cabeçalho (topbar, navbar, logo, busca, menu)
   6. Hero & cards
   7. Seções da home
   8. Matéria (single) & páginas
   9. Listagens, arquivos, busca, 404
   10. Comentários & widgets
   11. Rodapé
   12. Utilidades, foco, responsividade, motion
   ========================================================= */

/* ============ 1. TOKENS ============ */
:root {
	/* Cores de destaque (sobrescritas pelo Customizer via inline). */
	--accent: #FF2D6B;
	--accent-2: #00D1C7;
	--accent-contraste: #ffffff;

	/* Tipografia */
	--fonte-display: "Bricolage Grotesque", "Archivo", system-ui, sans-serif;
	--fonte-corpo: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

	/* Escala de tipo (responsiva) */
	--t-eyebrow: 0.75rem;
	--t-meta: 0.8125rem;
	--t-corpo: 1.0625rem;
	--t-card: clamp(1.05rem, 1.6vw, 1.25rem);
	--t-destaque: clamp(1.3rem, 2.2vw, 1.75rem);
	--t-hero: clamp(2rem, 4.5vw, 3.6rem);
	--t-secao: clamp(1.25rem, 2.4vw, 1.6rem);
	--t-titulo-materia: clamp(1.9rem, 4vw, 3.1rem);

	/* Espaçamento & forma */
	--gap: 24px;
	--radius: 16px;
	--radius-sm: 10px;
	--radius-pill: 999px;
	--container: 1240px;
	--container-estreito: 760px;
	--header-altura: 132px;
	--transicao: 220ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* ---- MODO ESCURO (padrão) ---- */
:root,
[data-theme="dark"] {
	--bg: #0B0B11;
	--bg-elev: #12121A;
	--surface: #181822;
	--surface-2: #20202C;
	--border: #2A2A38;
	--border-soft: #20202C;
	--text: #F4F4F8;
	--text-soft: #A6A6BA;
	--text-mute: #6E6E80;
	--sombra: 0 18px 50px -22px rgba(0, 0, 0, 0.85);
	--sombra-card: 0 12px 30px -18px rgba(0, 0, 0, 0.8);
	--overlay-hero: linear-gradient(180deg, rgba(8, 8, 14, 0) 0%, rgba(8, 8, 14, 0.15) 35%, rgba(8, 8, 14, 0.78) 78%, rgba(8, 8, 14, 0.96) 100%);
	--header-bg: rgba(11, 11, 17, 0.82);
	--scrim: rgba(0, 0, 0, 0.6);
	color-scheme: dark;
}

/* ---- MODO CLARO ---- */
[data-theme="light"] {
	--bg: #FFFFFF;
	--bg-elev: #F6F6FA;
	--surface: #FFFFFF;
	--surface-2: #F1F1F6;
	--border: #E6E6EE;
	--border-soft: #EFEFF4;
	--text: #15151E;
	--text-soft: #54545F;
	--text-mute: #8B8B98;
	--sombra: 0 20px 50px -24px rgba(30, 30, 60, 0.28);
	--sombra-card: 0 14px 34px -20px rgba(30, 30, 60, 0.22);
	--overlay-hero: linear-gradient(180deg, rgba(10, 10, 20, 0) 0%, rgba(10, 10, 20, 0.12) 35%, rgba(10, 10, 20, 0.72) 80%, rgba(10, 10, 20, 0.92) 100%);
	--header-bg: rgba(255, 255, 255, 0.86);
	--scrim: rgba(20, 20, 35, 0.45);
	color-scheme: light;
}

/* ============ 2. RESET & BASE ============ */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--bg);
	color: var(--text);
	font-family: var(--fonte-corpo);
	font-size: var(--t-corpo);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
	transition: background-color var(--transicao), color var(--transicao);
}

body.sem-scroll { overflow: hidden; }

h1, h2, h3, h4 {
	font-family: var(--fonte-display);
	font-weight: 800;
	line-height: 1.08;
	letter-spacing: -0.02em;
	margin: 0 0 0.5em;
	color: var(--text);
}

p { margin: 0 0 1.1em; }

a { color: inherit; text-decoration: none; transition: color var(--transicao); }
a:hover { color: var(--accent); }

img { max-width: 100%; height: auto; display: block; }

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

ul, ol { margin: 0; padding: 0; list-style: none; }

::selection { background: var(--accent); color: var(--accent-contraste); }

/* ============ 3. LAYOUT ============ */
.container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: 22px;
}
.container--estreito { max-width: var(--container-estreito); }

.site-content { display: block; padding-bottom: 64px; }

.pular-conteudo {
	position: absolute;
	left: -999px;
	top: 0;
	z-index: 1000;
	background: var(--accent);
	color: var(--accent-contraste);
	padding: 12px 18px;
	border-radius: 0 0 var(--radius-sm) 0;
	font-weight: 600;
}
.pular-conteudo:focus { left: 0; }

.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	width: 1px; height: 1px;
	overflow: hidden;
	word-wrap: normal !important;
}

/* ============ 4. ÍCONES (máscaras SVG, herdam cor) ============ */
.ico {
	display: inline-block;
	width: 22px;
	height: 22px;
	background-color: currentColor;
	-webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
	-webkit-mask-position: center; mask-position: center;
	-webkit-mask-size: contain; mask-size: contain;
	flex: none;
}
.ico--busca { -webkit-mask-image: var(--ic-busca); mask-image: var(--ic-busca); }
.ico--instagram { -webkit-mask-image: var(--ic-ig); mask-image: var(--ic-ig); }
.ico--facebook { -webkit-mask-image: var(--ic-fb); mask-image: var(--ic-fb); }
.ico--twitter { -webkit-mask-image: var(--ic-x); mask-image: var(--ic-x); }
.ico--youtube { -webkit-mask-image: var(--ic-yt); mask-image: var(--ic-yt); }
.ico--tiktok { -webkit-mask-image: var(--ic-tk); mask-image: var(--ic-tk); }
.ico--whatsapp { -webkit-mask-image: var(--ic-wpp); mask-image: var(--ic-wpp); }

:root {
	--ic-busca: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2.1" stroke-linecap="round"><circle cx="11" cy="11" r="7"/><line x1="21" y1="21" x2="16.5" y2="16.5"/></svg>');
	--ic-ig: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M12 2.2c3.2 0 3.6 0 4.85.07 1.17.05 1.8.25 2.23.41.56.22.96.48 1.38.9.42.42.68.82.9 1.38.16.42.36 1.06.41 2.23.06 1.27.07 1.65.07 4.85s0 3.58-.07 4.85c-.05 1.17-.25 1.8-.41 2.23a3.7 3.7 0 0 1-.9 1.38 3.7 3.7 0 0 1-1.38.9c-.42.16-1.06.36-2.23.41-1.27.06-1.65.07-4.85.07s-3.58 0-4.85-.07c-1.17-.05-1.8-.25-2.23-.41a3.7 3.7 0 0 1-1.38-.9 3.7 3.7 0 0 1-.9-1.38c-.16-.42-.36-1.06-.41-2.23C2.2 15.58 2.2 15.2 2.2 12s0-3.58.07-4.85c.05-1.17.25-1.8.41-2.23.22-.56.48-.96.9-1.38.42-.42.82-.68 1.38-.9.42-.16 1.06-.36 2.23-.41C8.42 2.2 8.8 2.2 12 2.2zm0 1.8c-3.14 0-3.5 0-4.74.07-.9.04-1.38.2-1.7.32-.43.17-.74.37-1.06.69-.32.32-.52.63-.69 1.06-.13.32-.28.8-.32 1.7C3.42 8.5 3.4 8.86 3.4 12s0 3.5.07 4.74c.04.9.2 1.38.32 1.7.17.43.37.74.69 1.06.32.32.63.52 1.06.69.32.13.8.28 1.7.32 1.24.06 1.6.07 4.74.07s3.5 0 4.74-.07c.9-.04 1.38-.2 1.7-.32.43-.17.74-.37 1.06-.69.32-.32.52-.63.69-1.06.13-.32.28-.8.32-1.7.06-1.24.07-1.6.07-4.74s0-3.5-.07-4.74c-.04-.9-.2-1.38-.32-1.7a2.85 2.85 0 0 0-.69-1.06 2.85 2.85 0 0 0-1.06-.69c-.32-.13-.8-.28-1.7-.32C15.5 4 15.14 4 12 4zm0 3.07a4.93 4.93 0 1 1 0 9.86 4.93 4.93 0 0 1 0-9.86zm0 8.13a3.2 3.2 0 1 0 0-6.4 3.2 3.2 0 0 0 0 6.4zm6.27-8.33a1.15 1.15 0 1 1-2.3 0 1.15 1.15 0 0 1 2.3 0z"/></svg>');
	--ic-fb: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M22 12a10 10 0 1 0-11.56 9.88v-6.99H7.9V12h2.54V9.8c0-2.5 1.49-3.89 3.78-3.89 1.09 0 2.24.2 2.24.2v2.46h-1.26c-1.24 0-1.63.77-1.63 1.56V12h2.78l-.44 2.89h-2.34v6.99A10 10 0 0 0 22 12z"/></svg>');
	--ic-x: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M18.24 2.25h3.31l-7.23 8.26 8.5 11.24h-6.66l-5.22-6.82-5.96 6.82H1.66l7.73-8.83L1.25 2.25h6.83l4.71 6.23 5.45-6.23zm-1.16 17.52h1.83L7.01 4.13H5.05l12.03 15.64z"/></svg>');
	--ic-yt: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M23.5 6.5a3 3 0 0 0-2.1-2.12C19.5 3.86 12 3.86 12 3.86s-7.5 0-9.4.52A3 3 0 0 0 .5 6.5C0 8.42 0 12 0 12s0 3.58.5 5.5a3 3 0 0 0 2.1 2.12c1.9.52 9.4.52 9.4.52s7.5 0 9.4-.52a3 3 0 0 0 2.1-2.12C24 15.58 24 12 24 12s0-3.58-.5-5.5zM9.6 15.6V8.4l6.25 3.6-6.25 3.6z"/></svg>');
	--ic-tk: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M16.6 5.82a4.28 4.28 0 0 1-1.06-2.82h-3.3v12.6a2.59 2.59 0 0 1-2.6 2.5 2.59 2.59 0 1 1 .8-5.05V9.66a5.86 5.86 0 0 0-.8-.06A5.9 5.9 0 1 0 15.5 15.5V9.3a7.55 7.55 0 0 0 4.4 1.4V7.4a4.28 4.28 0 0 1-3.3-1.58z"/></svg>');
	--ic-wpp: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M12.04 2C6.58 2 2.13 6.45 2.13 11.91c0 1.75.46 3.45 1.32 4.95L2 22l5.25-1.38a9.9 9.9 0 0 0 4.79 1.22c5.46 0 9.91-4.45 9.91-9.91S17.5 2 12.04 2zm0 18.13c-1.48 0-2.93-.4-4.2-1.15l-.3-.18-3.12.82.83-3.04-.2-.31a8.2 8.2 0 0 1-1.26-4.36c0-4.54 3.7-8.23 8.25-8.23 2.2 0 4.27.86 5.83 2.42a8.18 8.18 0 0 1 2.42 5.82c0 4.54-3.7 8.23-8.25 8.23zm4.52-6.16c-.25-.12-1.47-.72-1.69-.81-.23-.08-.39-.12-.56.13-.16.25-.64.8-.79.97-.14.16-.29.18-.54.06-.25-.12-1.05-.39-2-1.23-.74-.66-1.23-1.47-1.38-1.72-.14-.25-.01-.38.11-.5.11-.11.25-.29.37-.43.13-.14.17-.25.25-.41.08-.16.04-.31-.02-.43-.06-.12-.56-1.34-.76-1.84-.2-.48-.41-.42-.56-.42l-.48-.01c-.16 0-.43.06-.66.31-.22.25-.86.85-.86 2.07s.89 2.4 1.01 2.56c.12.16 1.75 2.67 4.23 3.74.59.26 1.05.41 1.41.52.59.19 1.13.16 1.56.1.48-.07 1.47-.6 1.68-1.18.21-.58.21-1.07.14-1.18-.06-.1-.22-.16-.47-.28z"/></svg>');
}

/* ============ 5. CABEÇALHO ============ */
.site-header {
	position: sticky;
	top: 0;
	z-index: 200;
	background: var(--header-bg);
	backdrop-filter: saturate(160%) blur(14px);
	-webkit-backdrop-filter: saturate(160%) blur(14px);
	border-bottom: 1px solid var(--border-soft);
}

/* --- Topbar --- */
.topbar {
	border-bottom: 1px solid var(--border-soft);
	font-size: var(--t-meta);
}
.topbar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 40px;
}
.topbar__data {
	color: var(--text-soft);
	text-transform: capitalize;
	letter-spacing: 0.01em;
}
.topbar__acoes { display: flex; align-items: center; gap: 14px; }
.topbar__redes { display: flex; align-items: center; gap: 4px; }
.topbar__rede {
	display: grid;
	place-items: center;
	width: 30px; height: 30px;
	color: var(--text-soft);
	border-radius: var(--radius-sm);
	transition: color var(--transicao), background var(--transicao);
}
.topbar__rede .ico { width: 16px; height: 16px; }
.topbar__rede:hover { color: var(--accent); background: var(--surface-2); }

/* Toggle de modo (sol/lua) */
.modo-toggle {
	position: relative;
	width: 54px; height: 28px;
	border-radius: var(--radius-pill);
	background: var(--surface-2);
	border: 1px solid var(--border);
	display: inline-flex;
	align-items: center;
	padding: 0 4px;
	transition: background var(--transicao);
}
.modo-toggle::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 4px;
	width: 20px; height: 20px;
	border-radius: 50%;
	background: var(--accent);
	transform: translateY(-50%);
	transition: transform var(--transicao), background var(--transicao);
	box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
[data-theme="light"] .modo-toggle::after { transform: translate(26px, -50%); }
.modo-toggle__sol, .modo-toggle__lua {
	width: 14px; height: 14px;
	z-index: 1;
	background-color: var(--text-mute);
	-webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
	-webkit-mask-size: contain; mask-size: contain;
	-webkit-mask-position: center; mask-position: center;
}
.modo-toggle__lua {
	margin-left: auto;
	-webkit-mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M21 12.8A9 9 0 1 1 11.2 3a7 7 0 0 0 9.8 9.8z"/></svg>');
	mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="black"><path d="M21 12.8A9 9 0 1 1 11.2 3a7 7 0 0 0 9.8 9.8z"/></svg>');
}
.modo-toggle__sol {
	-webkit-mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2" stroke-linecap="round"><circle cx="12" cy="12" r="4"/><path d="M12 2v2M12 20v2M4.9 4.9l1.4 1.4M17.7 17.7l1.4 1.4M2 12h2M20 12h2M4.9 19.1l1.4-1.4M17.7 6.3l1.4-1.4"/></svg>');
	mask-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2" stroke-linecap="round"><circle cx="12" cy="12" r="4"/><path d="M12 2v2M12 20v2M4.9 4.9l1.4 1.4M17.7 17.7l1.4 1.4M2 12h2M20 12h2M4.9 19.1l1.4-1.4M17.7 6.3l1.4-1.4"/></svg>');
}
[data-theme="dark"] .modo-toggle__lua { background-color: var(--accent-contraste); }
[data-theme="light"] .modo-toggle__sol { background-color: var(--accent-contraste); }

/* --- Navbar --- */
.navbar { position: relative; }
.navbar__inner {
	display: flex;
	align-items: center;
	gap: 20px;
	min-height: 76px;
	transition: min-height var(--transicao);
}
.site-header.encolhido .navbar__inner { min-height: 60px; }
.site-header.encolhido .topbar { display: none; }

/* Logo */
.site-branding { display: flex; align-items: center; }
.logo-link { display: inline-flex; align-items: center; }
.logo-img { display: none; max-width: 220px; object-fit: contain; }
[data-theme="dark"] .logo-img--dark { display: block; }
[data-theme="light"] .logo-img--light { display: block; }
/* fallback: se só existe um logo, ele aparece nos dois modos */
.logo-link .logo-img--dark:only-child,
.logo-link .logo-img--light:only-child { display: block; }

.logo-texto {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: clamp(1.25rem, 2.4vw, 1.7rem);
	letter-spacing: -0.03em;
	color: var(--text);
	display: inline-flex;
	align-items: center;
	gap: 0.5ch;
	line-height: 1;
}
.logo-texto__pingo {
	width: 0.62em; height: 0.62em;
	background: var(--accent);
	border-radius: 60% 60% 60% 0;
	transform: rotate(45deg);
	flex: none;
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 22%, transparent);
}

/* Menu principal (desktop) */
.nav-principal { margin-left: auto; }
.menu-principal {
	display: flex;
	align-items: center;
	gap: 4px;
}
.menu-principal li { position: relative; }
.menu-principal a {
	display: block;
	padding: 10px 14px;
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--text-soft);
	border-radius: var(--radius-sm);
}
.menu-principal a:hover,
.menu-principal .current-menu-item > a {
	color: var(--text);
	background: var(--surface-2);
}
.menu-principal .current-menu-item > a { color: var(--accent); }

/* Submenu */
.menu-principal ul.sub-menu {
	position: absolute;
	top: 100%; left: 0;
	min-width: 200px;
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--radius-sm);
	box-shadow: var(--sombra);
	padding: 6px;
	opacity: 0; visibility: hidden;
	transform: translateY(8px);
	transition: all var(--transicao);
	z-index: 50;
}
.menu-principal li:hover > ul.sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.menu-principal ul.sub-menu a { white-space: nowrap; }

/* Botões de busca e menu */
.busca-toggle, .menu-toggle {
	display: grid;
	place-items: center;
	width: 44px; height: 44px;
	border-radius: var(--radius-sm);
	color: var(--text);
	transition: background var(--transicao), color var(--transicao);
}
.busca-toggle:hover, .menu-toggle:hover { background: var(--surface-2); color: var(--accent); }
.busca-toggle { margin-left: 4px; }
.menu-toggle { display: none; }

/* Hambúrguer */
.menu-toggle__barras, .menu-toggle__barras::before, .menu-toggle__barras::after {
	content: "";
	display: block;
	width: 22px; height: 2.4px;
	background: currentColor;
	border-radius: 2px;
	transition: transform var(--transicao), opacity var(--transicao);
}
.menu-toggle__barras { position: relative; }
.menu-toggle__barras::before { position: absolute; top: -7px; }
.menu-toggle__barras::after { position: absolute; top: 7px; }

/* Painel de busca */
.busca-painel {
	border-top: 1px solid var(--border-soft);
	background: var(--surface);
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--transicao);
}
.busca-painel .container { position: relative; display: flex; align-items: center; }
.busca-painel.aberto { max-height: 120px; }
.busca-painel.aberto .container { padding-block: 16px; }
.busca-fechar {
	font-size: 1.8rem;
	line-height: 1;
	color: var(--text-mute);
	padding: 0 8px;
	margin-left: 8px;
}
.busca-fechar:hover { color: var(--accent); }

/* Form de busca */
.busca-form { position: relative; display: flex; align-items: center; width: 100%; gap: 8px; }
.busca-form__ico {
	position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
	color: var(--text-mute); width: 18px; height: 18px; pointer-events: none;
}
.busca-form__campo {
	flex: 1;
	width: 100%;
	font-family: inherit;
	font-size: 1rem;
	color: var(--text);
	background: var(--bg-elev);
	border: 1px solid var(--border);
	border-radius: var(--radius-pill);
	padding: 13px 18px 13px 44px;
	transition: border-color var(--transicao), box-shadow var(--transicao);
}
.busca-form__campo:focus {
	outline: none;
	border-color: var(--accent);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent);
}
.busca-form__campo::placeholder { color: var(--text-mute); }
.busca-form__botao {
	font-family: var(--fonte-display);
	font-weight: 700;
	font-size: 0.92rem;
	color: var(--accent-contraste);
	background: var(--accent);
	border-radius: var(--radius-pill);
	padding: 12px 22px;
	white-space: nowrap;
	transition: filter var(--transicao);
}
.busca-form__botao:hover { filter: brightness(1.08); color: var(--accent-contraste); }

/* Menu mobile (gaveta) */
.menu-mobile {
	position: fixed;
	top: 0; left: 0;
	height: 100dvh;
	width: min(82vw, 340px);
	background: var(--surface);
	border-right: 1px solid var(--border);
	z-index: 400;
	transform: translateX(-100%);
	transition: transform var(--transicao);
	display: flex;
	flex-direction: column;
	padding: 18px;
	overflow-y: auto;
}
.menu-mobile.aberto { transform: translateX(0); }
.menu-mobile__cabecalho {
	display: flex; align-items: center; justify-content: space-between;
	padding-bottom: 14px;
	margin-bottom: 8px;
	border-bottom: 1px solid var(--border-soft);
}
.menu-mobile__titulo {
	font-family: var(--fonte-display);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 0.78rem;
	color: var(--text-mute);
}
.menu-mobile__fechar { font-size: 2rem; line-height: 1; color: var(--text-soft); }
.menu-mobile__fechar:hover { color: var(--accent); }
.menu-mobile__lista a {
	display: block;
	padding: 14px 10px;
	font-family: var(--fonte-display);
	font-weight: 700;
	font-size: 1.15rem;
	letter-spacing: -0.01em;
	border-bottom: 1px solid var(--border-soft);
	color: var(--text);
}
.menu-mobile__lista a:hover { color: var(--accent); padding-left: 16px; }
.menu-mobile__lista .sub-menu a { font-size: 1rem; font-weight: 600; color: var(--text-soft); padding-left: 22px; }
.menu-overlay {
	position: fixed; inset: 0;
	background: var(--scrim);
	z-index: 300;
	opacity: 0;
	transition: opacity var(--transicao);
}
.menu-overlay.aberto { opacity: 1; }

/* ============================================================
   6. HERO & CARDS DE MATÉRIA
   ============================================================ */

/* ---- HERO ---- */
.hero {
	padding: 28px 0 8px;
}
.hero__grade {
	display: grid;
	grid-template-columns: 1.6fr 1fr;
	gap: 18px;
}
.hero__principal { min-height: 0; }
.hero__secundarias {
	display: grid;
	grid-template-rows: repeat(3, 1fr);
	gap: 18px;
}

/* ---- ARTIGO (base) ---- */
.artigo {
	position: relative;
	background: var(--surface);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius);
	overflow: hidden;
	transition: transform var(--transicao), border-color var(--transicao), box-shadow var(--transicao);
	height: 100%;
}
.artigo:hover {
	transform: translateY(-3px);
	border-color: var(--border);
	box-shadow: var(--sombra-card);
}
.artigo__link {
	position: absolute;
	inset: 0;
	z-index: 5;
	text-indent: -9999px;
	overflow: hidden;
}
.artigo__media {
	position: relative;
	display: block;
	overflow: hidden;
	background: var(--surface-2);
}
.artigo__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 600ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.artigo:hover .artigo__media img { transform: scale(1.05); }

.artigo__texto { padding: 18px 18px 20px; }
.artigo__titulo {
	font-family: var(--fonte-display);
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1.12;
	color: var(--text);
}
.artigo__resumo {
	margin-top: 8px;
	color: var(--text-soft);
	font-size: 0.96rem;
	line-height: 1.5;
}
.artigo__meta {
	margin-top: 14px;
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.82rem;
	color: var(--text-mute);
	font-weight: 600;
}
.artigo__autor { color: var(--text-soft); }
.artigo__sep { opacity: 0.5; }

/* ---- FORMATO: texto sobre imagem (hero + destaque) ---- */
.artigo--hero,
.artigo--destaque {
	border: none;
	background: var(--surface-2);
}
.artigo--hero .artigo__media,
.artigo--destaque .artigo__media {
	position: absolute;
	inset: 0;
	height: 100%;
}
.artigo--hero .artigo__media-gradiente,
.artigo--destaque .artigo__media-gradiente {
	position: absolute;
	inset: 0;
	background: var(--overlay-hero);
	z-index: 2;
}
.artigo--hero .artigo__sobre-imagem,
.artigo--destaque .artigo__sobre-imagem {
	position: relative;
	z-index: 3;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	height: 100%;
	padding: 26px;
}
.artigo--hero .artigo__titulo,
.artigo--destaque .artigo__titulo { color: #fff; }
.artigo--hero .artigo__resumo,
.artigo--destaque .artigo__resumo { color: rgba(255, 255, 255, 0.82); }
.artigo--hero .artigo__meta,
.artigo--destaque .artigo__meta { color: rgba(255, 255, 255, 0.7); }
.artigo--hero .artigo__autor,
.artigo--destaque .artigo__autor { color: rgba(255, 255, 255, 0.92); }

.artigo--hero { min-height: 540px; }
.artigo--hero .artigo__titulo { font-size: clamp(1.9rem, 3.6vw, 3rem); }
.artigo--hero .artigo__resumo { font-size: 1.06rem; max-width: 62ch; }
.artigo--hero .artigo__sobre-imagem { padding: 34px; }

.artigo--destaque { min-height: 0; }
.artigo--destaque .artigo__titulo { font-size: clamp(1.1rem, 1.5vw, 1.35rem); }
.artigo--destaque .artigo__resumo { display: none; }
.artigo--destaque .artigo__sobre-imagem { padding: 18px; }

/* ---- FORMATO: card (imagem topo / texto embaixo) ---- */
.artigo--card { display: flex; flex-direction: column; }
.artigo--card .artigo__media { aspect-ratio: 3 / 2; }
.artigo--card .artigo__titulo { font-size: 1.18rem; }

/* ---- FORMATO: lista (thumb + texto horizontal) ---- */
.artigo--lista {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 12px;
	background: transparent;
	border: none;
	border-bottom: 1px solid var(--border-soft);
	border-radius: 0;
}
.artigo--lista:hover { transform: none; box-shadow: none; background: var(--surface); border-radius: var(--radius-sm); border-color: transparent; }
.artigo--lista:last-child { border-bottom: none; }
.artigo--lista .artigo__media {
	flex: 0 0 104px;
	width: 104px;
	height: 72px;
	border-radius: var(--radius-sm);
}
.artigo--lista .artigo__texto { padding: 0; flex: 1; }
.artigo--lista .artigo__titulo { font-size: 1.02rem; line-height: 1.2; }
.artigo--lista .artigo__resumo { display: none; }
.artigo--lista .artigo__meta { margin-top: 7px; }
.artigo__numero {
	flex: 0 0 auto;
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: 1.6rem;
	line-height: 1;
	color: var(--accent);
	width: 34px;
	text-align: center;
	font-variant-numeric: tabular-nums;
}

/* ---- ARTIGO SEM IMAGEM ---- */
.artigo--sem-imagem .artigo__media { display: none; }
.artigo--hero.artigo--sem-imagem,
.artigo--destaque.artigo--sem-imagem {
	background: linear-gradient(145deg, var(--surface) 0%, var(--surface-2) 100%);
}
.artigo--hero.artigo--sem-imagem .artigo__media-gradiente,
.artigo--destaque.artigo--sem-imagem .artigo__media-gradiente { display: none; }
.artigo--hero.artigo--sem-imagem .artigo__titulo,
.artigo--hero.artigo--sem-imagem .artigo__resumo,
.artigo--hero.artigo--sem-imagem .artigo__meta,
.artigo--destaque.artigo--sem-imagem .artigo__titulo,
.artigo--destaque.artigo--sem-imagem .artigo__meta { color: var(--text); }
.artigo--hero.artigo--sem-imagem .artigo__resumo { color: var(--text-soft); }

/* ---- BADGE DE EDITORIA ---- */
.badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	align-self: flex-start;
	margin-bottom: 12px;
	padding: 5px 12px;
	font-family: var(--fonte-display);
	font-weight: 700;
	font-size: 0.74rem;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #fff;
	background: var(--accent);
	border-radius: var(--radius-pill);
}
.artigo--card .badge,
.artigo--lista .badge {
	color: var(--accent);
	background: color-mix(in srgb, var(--accent) 14%, transparent);
}

/* ============================================================
   7. SEÇÕES DA HOME
   ============================================================ */
.secao { padding: 30px 0; }
.secao--ultimas { padding-top: 18px; }

.secao__cabecalho {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 18px;
}
.secao__titulo {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: clamp(1.3rem, 2.2vw, 1.7rem);
	letter-spacing: -0.02em;
	color: var(--text);
	display: inline-flex;
	align-items: center;
	gap: 12px;
}
.secao__titulo--linha::before {
	content: "";
	width: 22px;
	height: 4px;
	border-radius: var(--radius-pill);
	background: var(--accent);
}
.secao__titulo--editoria::before {
	content: "";
	width: 10px;
	height: 22px;
	border-radius: 3px;
	background: var(--accent);
}
.secao__ver-mais {
	font-family: var(--fonte-display);
	font-weight: 700;
	font-size: 0.9rem;
	color: var(--text-soft);
	display: inline-flex;
	align-items: center;
	gap: 5px;
	white-space: nowrap;
}
.secao__ver-mais:hover { color: var(--accent); }
.secao__ver-mais::after { content: "→"; transition: transform var(--transicao); }
.secao__ver-mais:hover::after { transform: translateX(3px); }

/* ---- GRADES ---- */
.grade-cards {
	display: grid;
	gap: 20px;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.grade-cards--3 { grid-template-columns: repeat(3, 1fr); }
.grade-cards--4 { grid-template-columns: repeat(4, 1fr); }

/* ---- MAIS LIDAS ---- */
.mais-lidas {
	background: var(--bg-elev);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius);
	padding: 22px;
}
.mais-lidas__grade {
	display: grid;
	gap: 2px;
}

/* ---- CORPO DA HOME ---- */
.home__corpo {
	padding: 10px 0 40px;
}
.home__corpo--com-sidebar {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 40px;
	align-items: start;
}
.home__principal { min-width: 0; }
.home__sidebar { position: sticky; top: calc(var(--header-altura) + 16px); }

/* ============================================================
   8. MATÉRIA (single) & PÁGINAS
   ============================================================ */
.materia { padding: 30px 0 50px; }
.materia__cabecalho { margin-bottom: 24px; }
.materia__titulo {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: clamp(2rem, 4.2vw, 3.2rem);
	line-height: 1.08;
	letter-spacing: -0.025em;
	color: var(--text);
	margin: 8px 0 0;
}
.materia__linha-fina {
	margin-top: 16px;
	font-size: clamp(1.05rem, 1.6vw, 1.3rem);
	line-height: 1.45;
	color: var(--text-soft);
	font-weight: 400;
}
.materia__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 24px;
	padding: 16px 0;
	border-top: 1px solid var(--border-soft);
	border-bottom: 1px solid var(--border-soft);
}
.materia__autor-info {
	display: flex;
	align-items: center;
	gap: 11px;
}
.materia__avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	overflow: hidden;
	background: var(--surface-2);
	flex: 0 0 auto;
}
.materia__avatar img { width: 100%; height: 100%; object-fit: cover; }
.materia__autor-nome {
	font-family: var(--fonte-display);
	font-weight: 700;
	color: var(--text);
	line-height: 1.2;
}
.materia__dados {
	font-size: 0.85rem;
	color: var(--text-mute);
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}
.materia__dados span { display: inline-flex; align-items: center; gap: 5px; }
.materia__compartilhar {
	margin-left: auto;
	display: flex;
	align-items: center;
	gap: 8px;
}
.materia__compartilhar-label {
	font-size: 0.8rem;
	color: var(--text-mute);
	font-weight: 600;
}
.share {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--surface-2);
	border: 1px solid var(--border-soft);
	transition: transform var(--transicao), background var(--transicao);
}
.share:hover { transform: translateY(-2px); }
.share .icone { width: 17px; height: 17px; background: var(--text-soft); }
.share:hover .icone { background: #fff; }
.share--wpp:hover { background: #25D366; border-color: #25D366; }
.share--fb:hover { background: #1877F2; border-color: #1877F2; }
.share--x:hover { background: #000; border-color: #000; }

.materia__capa {
	margin: 28px 0;
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--surface-2);
}
.materia__capa img { width: 100%; height: auto; display: block; }
.materia__capa figcaption {
	padding: 10px 14px;
	font-size: 0.84rem;
	color: var(--text-mute);
	background: var(--surface);
}

/* ---- CORPO DO TEXTO ---- */
.materia__conteudo {
	font-size: 1.14rem;
	line-height: 1.75;
	color: var(--text);
}
.materia__conteudo > * + * { margin-top: 1.4em; }
.materia__conteudo p { color: var(--text); }
.materia__conteudo h2 {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: 1.7rem;
	letter-spacing: -0.02em;
	margin-top: 1.8em;
	line-height: 1.2;
}
.materia__conteudo h3 {
	font-family: var(--fonte-display);
	font-weight: 700;
	font-size: 1.35rem;
	margin-top: 1.6em;
}
.materia__conteudo a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
.materia__conteudo a:hover { color: var(--accent-2); }
.materia__conteudo img { max-width: 100%; height: auto; border-radius: var(--radius-sm); }
.materia__conteudo figure { margin: 1.6em 0; }
.materia__conteudo figcaption { font-size: 0.86rem; color: var(--text-mute); margin-top: 8px; text-align: center; }
.materia__conteudo blockquote {
	border-left: 4px solid var(--accent);
	padding: 6px 0 6px 22px;
	margin: 1.6em 0;
	font-family: var(--fonte-display);
	font-size: 1.3rem;
	font-weight: 600;
	line-height: 1.4;
	color: var(--text);
}
.materia__conteudo ul,
.materia__conteudo ol { padding-left: 1.4em; }
.materia__conteudo li + li { margin-top: 0.5em; }
.materia__conteudo li::marker { color: var(--accent); }

/* ---- TAGS ---- */
.materia__tags {
	margin-top: 32px;
	display: flex;
	flex-wrap: wrap;
	gap: 9px;
	align-items: center;
}
.materia__tags-label { font-size: 0.85rem; color: var(--text-mute); font-weight: 600; }
.tag-link {
	padding: 6px 13px;
	border-radius: var(--radius-pill);
	background: var(--surface-2);
	border: 1px solid var(--border-soft);
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--text-soft);
	transition: all var(--transicao);
}
.tag-link:hover { color: #fff; background: var(--accent); border-color: var(--accent); }

/* ---- CAIXA DO AUTOR ---- */
.autor-box {
	margin-top: 40px;
	display: flex;
	gap: 18px;
	padding: 22px;
	background: var(--bg-elev);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius);
}
.autor-box__avatar {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	overflow: hidden;
	flex: 0 0 auto;
	background: var(--surface-2);
}
.autor-box__avatar img { width: 100%; height: 100%; object-fit: cover; }
.autor-box__nome { font-family: var(--fonte-display); font-weight: 800; font-size: 1.2rem; }
.autor-box__bio { margin-top: 6px; color: var(--text-soft); font-size: 0.96rem; line-height: 1.55; }
.autor-box__link { margin-top: 10px; display: inline-block; font-weight: 700; font-size: 0.9rem; color: var(--accent); }

/* ---- RELACIONADAS ---- */
.relacionadas { margin-top: 48px; }

/* ============================================================
   9. LISTAGENS, ARQUIVOS, BUSCA, 404
   ============================================================ */
.pagina-lista {
	padding: 30px 0 50px;
}
.pagina-lista--com-sidebar {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 40px;
	align-items: start;
}
.pagina-lista__principal { min-width: 0; }
.pagina-lista__sidebar { position: sticky; top: calc(var(--header-altura) + 16px); }

.arquivo-cabecalho {
	padding: 36px 0 26px;
	border-bottom: 1px solid var(--border-soft);
	margin-bottom: 30px;
}
.arquivo-cabecalho__eyebrow {
	font-family: var(--fonte-display);
	font-weight: 700;
	font-size: 0.82rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--accent);
}
.arquivo-cabecalho__titulo {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: clamp(1.8rem, 3.5vw, 2.6rem);
	letter-spacing: -0.025em;
	margin-top: 6px;
	color: var(--text);
}
.arquivo-cabecalho__descricao {
	margin-top: 10px;
	color: var(--text-soft);
	max-width: 70ch;
	font-size: 1.02rem;
	line-height: 1.5;
}

.resultados-info { margin-top: 8px; color: var(--text-mute); font-weight: 600; font-size: 0.92rem; }

/* ---- LISTA DE RESULTADOS ---- */
.lista-materias {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.lista-materias .artigo--lista { padding: 16px 12px; }
.lista-materias .artigo--lista .artigo__media { flex: 0 0 150px; width: 150px; height: 100px; }
.lista-materias .artigo--lista .artigo__titulo { font-size: 1.2rem; }
.lista-materias .artigo--lista .artigo__resumo { display: block; margin-top: 6px; font-size: 0.92rem; }

/* ---- ESTADO VAZIO ---- */
.estado-vazio {
	text-align: center;
	padding: 60px 20px;
	max-width: 560px;
	margin: 0 auto;
}
.estado-vazio__pingo {
	width: 54px;
	height: 64px;
	margin: 0 auto 22px;
	background: var(--accent);
	border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
	transform: rotate(45deg);
	border-top-right-radius: 0;
	opacity: 0.92;
}
.estado-vazio__titulo {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: clamp(1.5rem, 3vw, 2.1rem);
	letter-spacing: -0.02em;
	color: var(--text);
}
.estado-vazio__texto {
	margin-top: 12px;
	color: var(--text-soft);
	font-size: 1.04rem;
	line-height: 1.55;
}
.estado-vazio__acoes {
	margin-top: 26px;
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
}
.estado-vazio .busca-form { margin: 26px auto 0; max-width: 420px; }

/* ---- 404 ---- */
.estado-vazio--404 .estado-vazio__codigo {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: clamp(5rem, 16vw, 11rem);
	line-height: 0.9;
	letter-spacing: -0.04em;
	color: var(--text);
	background: linear-gradient(135deg, var(--accent), var(--accent-2));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-bottom: 8px;
}
.estado-vazio__editorias {
	margin-top: 28px;
	display: flex;
	flex-wrap: wrap;
	gap: 9px;
	justify-content: center;
}

/* ---- BOTÕES ---- */
.botao {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 22px;
	font-family: var(--fonte-display);
	font-weight: 700;
	font-size: 0.95rem;
	border-radius: var(--radius-pill);
	background: var(--accent);
	color: #fff;
	border: 1px solid var(--accent);
	cursor: pointer;
	transition: transform var(--transicao), opacity var(--transicao);
}
.botao:hover { transform: translateY(-2px); opacity: 0.94; }
.botao--vazado {
	background: transparent;
	color: var(--text);
	border-color: var(--border);
}
.botao--vazado:hover { border-color: var(--accent); color: var(--accent); }

/* ---- PAGINAÇÃO ---- */
.paginacao {
	margin-top: 44px;
	display: flex;
	justify-content: center;
}
.paginacao .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 14px;
	margin: 0 4px;
	border-radius: var(--radius-sm);
	font-family: var(--fonte-display);
	font-weight: 700;
	color: var(--text-soft);
	background: var(--surface);
	border: 1px solid var(--border-soft);
	transition: all var(--transicao);
}
.paginacao .page-numbers:hover { color: var(--accent); border-color: var(--accent); }
.paginacao .page-numbers.current {
	background: var(--accent);
	color: #fff;
	border-color: var(--accent);
}
.paginacao .dots { background: transparent; border: none; }

/* ============================================================
   10. COMENTÁRIOS & WIDGETS
   ============================================================ */
.comentarios { margin-top: 48px; }
.comentarios__titulo {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: 1.5rem;
	letter-spacing: -0.02em;
	margin-bottom: 22px;
}
.comentarios__lista { list-style: none; }
.comentarios__lista .comment { margin-bottom: 22px; }
.comentarios__lista .children {
	list-style: none;
	margin-top: 22px;
	margin-left: 28px;
	padding-left: 20px;
	border-left: 2px solid var(--border-soft);
}
.comment-body {
	background: var(--surface);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius-sm);
	padding: 16px 18px;
}
.comment-author { display: flex; align-items: center; gap: 10px; }
.comment-author .avatar { border-radius: 50%; }
.comment-author .fn { font-family: var(--fonte-display); font-weight: 700; font-style: normal; color: var(--text); }
.comment-meta { font-size: 0.8rem; color: var(--text-mute); }
.comment-meta a { color: var(--text-mute); }
.comment-content { margin-top: 10px; color: var(--text); line-height: 1.6; }
.comment-content p + p { margin-top: 0.8em; }
.comment-reply-link {
	display: inline-block;
	margin-top: 10px;
	font-weight: 700;
	font-size: 0.85rem;
	color: var(--accent);
}

.comment-respond {
	margin-top: 32px;
	padding: 24px;
	background: var(--bg-elev);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius);
}
.comment-reply-title { font-family: var(--fonte-display); font-weight: 800; font-size: 1.3rem; margin-bottom: 16px; }
.comment-form { display: grid; gap: 14px; }
.comment-form p { display: flex; flex-direction: column; gap: 6px; margin: 0; }
.comment-form label { font-weight: 600; font-size: 0.9rem; color: var(--text-soft); }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
	width: 100%;
	padding: 12px 14px;
	font: inherit;
	color: var(--text);
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--radius-sm);
	transition: border-color var(--transicao);
}
.comment-form input:focus,
.comment-form textarea:focus { outline: none; border-color: var(--accent); }
.comment-form textarea { min-height: 120px; resize: vertical; }
.form-submit .submit {
	padding: 12px 24px;
	font-family: var(--fonte-display);
	font-weight: 700;
	color: #fff;
	background: var(--accent);
	border: none;
	border-radius: var(--radius-pill);
	cursor: pointer;
	transition: opacity var(--transicao);
}
.form-submit .submit:hover { opacity: 0.92; }

/* ---- WIDGETS / SIDEBAR ---- */
.sidebar { display: flex; flex-direction: column; gap: 26px; }
.widget {
	background: var(--surface);
	border: 1px solid var(--border-soft);
	border-radius: var(--radius);
	padding: 20px;
}
.widget__title,
.widget-title {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: 1.1rem;
	letter-spacing: -0.01em;
	margin-bottom: 14px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--border-soft);
	display: flex;
	align-items: center;
	gap: 9px;
}
.widget__title::before,
.widget-title::before {
	content: "";
	width: 8px;
	height: 18px;
	border-radius: 3px;
	background: var(--accent);
	flex: 0 0 auto;
}
.widget ul { list-style: none; }
.widget li { padding: 9px 0; border-bottom: 1px solid var(--border-soft); }
.widget li:last-child { border-bottom: none; }
.widget li a { color: var(--text-soft); font-weight: 600; transition: color var(--transicao); }
.widget li a:hover { color: var(--accent); }
.widget select {
	width: 100%;
	padding: 10px 12px;
	background: var(--surface-2);
	color: var(--text);
	border: 1px solid var(--border);
	border-radius: var(--radius-sm);
}

/* ============================================================
   11. RODAPÉ
   ============================================================ */
.site-footer {
	margin-top: 60px;
	background: var(--bg-elev);
	border-top: 1px solid var(--border-soft);
}
.site-footer__topo {
	display: grid;
	grid-template-columns: 1.4fr 2fr;
	gap: 50px;
	padding: 50px 0 40px;
}
.site-footer__marca { max-width: 360px; }
.site-footer__sobre { margin-top: 14px; color: var(--text-soft); line-height: 1.6; font-size: 0.96rem; }
.site-footer__redes { margin-top: 20px; display: flex; gap: 10px; }
.site-footer__rede {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--surface);
	border: 1px solid var(--border-soft);
	transition: transform var(--transicao), background var(--transicao);
}
.site-footer__rede:hover { transform: translateY(-2px); background: var(--accent); }
.site-footer__rede .icone { width: 18px; height: 18px; background: var(--text-soft); }
.site-footer__rede:hover .icone { background: #fff; }

.site-footer__colunas {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
}
.site-footer__coluna-titulo {
	font-family: var(--fonte-display);
	font-weight: 800;
	font-size: 1rem;
	margin-bottom: 14px;
	color: var(--text);
}
.site-footer__links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.site-footer__links a { color: var(--text-soft); font-size: 0.94rem; font-weight: 600; }
.site-footer__links a:hover { color: var(--accent); }

.site-footer__base {
	border-top: 1px solid var(--border-soft);
	padding: 22px 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
	font-size: 0.88rem;
	color: var(--text-mute);
}
.site-footer__base a { color: var(--text-soft); font-weight: 600; }
.site-footer__base a:hover { color: var(--accent); }

/* ---- VOLTAR AO TOPO ---- */
.voltar-topo {
	position: fixed;
	right: 22px;
	bottom: 22px;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--accent);
	color: #fff;
	border: none;
	cursor: pointer;
	box-shadow: var(--sombra-card);
	opacity: 0;
	visibility: hidden;
	transform: translateY(12px);
	transition: opacity var(--transicao), transform var(--transicao), visibility var(--transicao);
	z-index: 200;
}
.voltar-topo.visivel { opacity: 1; visibility: visible; transform: translateY(0); }
.voltar-topo:hover { transform: translateY(-3px); }
.voltar-topo svg { width: 22px; height: 22px; }

/* ============================================================
   12. UTILIDADES, FOCO & RESPONSIVIDADE
   ============================================================ */
.somente-desktop { display: revert; }
.somente-mobile { display: none; }

/* ---- FOCO VISÍVEL ---- */
:focus-visible {
	outline: 3px solid var(--accent);
	outline-offset: 2px;
	border-radius: 4px;
}

/* ---- TABLET / DESKTOP MENOR ---- */
@media (max-width: 1100px) {
	.home__corpo--com-sidebar,
	.pagina-lista--com-sidebar { grid-template-columns: 1fr; }
	.home__sidebar,
	.pagina-lista__sidebar { position: static; }
	.grade-cards--4 { grid-template-columns: repeat(2, 1fr); }
}

/* ---- MOBILE (cabeçalho: menu esq · logo centro · lupa dir) ---- */
@media (max-width: 980px) {
	:root { --header-altura: 64px; }

	/* topbar compacta: mantém só o toggle de modo à direita */
	.topbar__data,
	.topbar__redes { display: none; }
	.topbar__inner { justify-content: flex-end; }
	.topbar { padding: 4px 0; }

	/* navbar em 3 zonas */
	.menu-toggle { display: inline-flex; }
	.nav-principal { display: none; }
	.navbar__inner {
		display: grid;
		grid-template-columns: 1fr auto 1fr;
		align-items: center;
	}
	.menu-toggle { justify-self: start; grid-column: 1; }
	.site-branding { justify-self: center; grid-column: 2; }
	.busca-toggle { justify-self: end; grid-column: 3; }

	.hero__grade { grid-template-columns: 1fr; }
	.hero__secundarias { grid-template-rows: none; grid-template-columns: repeat(3, 1fr); }
	.artigo--hero { min-height: 420px; }

	.grade-cards--3 { grid-template-columns: repeat(2, 1fr); }

	.site-footer__topo { grid-template-columns: 1fr; gap: 34px; }

	.materia__compartilhar { margin-left: 0; width: 100%; }
}

/* ---- CELULAR ---- */
@media (max-width: 640px) {
	.hero__secundarias { grid-template-columns: 1fr; }
	.grade-cards,
	.grade-cards--3,
	.grade-cards--4 { grid-template-columns: 1fr; }
	.site-footer__colunas { grid-template-columns: 1fr 1fr; }
	.lista-materias .artigo--lista { flex-direction: column; align-items: stretch; }
	.lista-materias .artigo--lista .artigo__media { width: 100%; height: 190px; flex: none; }
	.materia__meta { gap: 12px; }
	.somente-mobile { display: revert; }
	.artigo--hero .artigo__titulo { font-size: clamp(1.5rem, 7vw, 2.1rem); }
}

/* ---- MOVIMENTO REDUZIDO ---- */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
		scroll-behavior: auto !important;
	}
	.artigo:hover .artigo__media img { transform: none; }
}
