/*!
 * Cyberplay Arbitrage — main.css v2
 * Editorial. Core Web Vitals 99+. Zero-dependency.
 * Typography: Fraunces (display) + Inter Tight (body)
 */

/* === 0. RESET === */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html {
	-webkit-text-size-adjust: 100%; text-size-adjust: 100%;
	scroll-behavior: smooth; -webkit-tap-highlight-color: transparent;
}
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}
body { min-height: 100vh; line-height: 1.6; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; font-feature-settings: "kern" 1, "liga" 1, "calt" 1; }
img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
img { font-style: italic; }
input, button, textarea, select { font: inherit; color: inherit; }
button { background: none; border: 0; cursor: pointer; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
ul, ol { list-style: none; }
a { color: inherit; text-decoration: none; }
:focus-visible { outline: 2px solid var(--cp-accent); outline-offset: 3px; border-radius: 2px; }

/* === 1. TOKENS === */
/* v2.25.0 — REVERTIDO metric matching das v2.24.8/9 (causaram CLS 0.032, depois
   score 33). Font stack volta ao formato estável da v2.24.7. */

:root {
	--cp-primary: #0a0a0a;

	/* v2.11.4 — Paleta accent sofisticada
	 * Antes: #E4FF3A (amarelo neon) aplicado em tudo → fadiga visual
	 * Agora:
	 *   - Teal sóbrio (azul-petróleo) como primary — profissional, legível, elegante
	 *   - Amber dourado como hover de links e CTAs de atenção máxima */
	--cp-accent: #0F766E;              /* teal 700 — primary accent (nav, focus, links) */
	--cp-accent-strong: #115E59;       /* teal 800 — hover mais escuro */
	--cp-accent-soft: rgba(15, 118, 110, 0.08);  /* fill sutil */
	--cp-accent-gold: #B45309;         /* amber 700 — hover de links (elegante, não amarelão) */
	--cp-accent-gold-strong: #92400E;  /* amber 800 */

	--cp-bg: #FAFAF5; --cp-bg-elev: #FFFFFF;
	--cp-text: #0a0a0a; --cp-text-soft: #3a3a3a;
	--cp-muted: #525252; --cp-subtle: #595959; /* v2.24.6 — AAA margin: muted 7.3:1, subtle 6.7:1 no light bg (antes 6.1/5.3 — PSI ainda flagava color-contrast) */
	--cp-border: rgba(10,10,10,0.08); --cp-border-2: rgba(10,10,10,0.12);
	--cp-selection: rgba(15, 118, 110, 0.22);
	--cp-shadow-sm: 0 1px 2px rgba(10,10,10,0.04);
	--cp-shadow: 0 4px 24px rgba(10,10,10,0.06), 0 2px 8px rgba(10,10,10,0.03);
	--cp-shadow-lg: 0 24px 64px rgba(10,10,10,0.08);
	--cp-shadow-glow: 0 0 0 1px rgba(15, 118, 110, 0.25), 0 8px 28px rgba(15, 118, 110, 0.12);

	/* v2.25.0 — Font stack limpo (sem "Fallback" sintético da v2.24.8/9) */
	--cp-ff-display: "Fraunces", "Tiempos Headline", Georgia, serif;
	--cp-ff-body: "Inter Tight", "Inter", -apple-system, system-ui, sans-serif;
	--cp-ff-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;

	--cp-fz-2xs: 0.6875rem; --cp-fz-xs: 0.75rem; --cp-fz-sm: 0.875rem;
	--cp-fz-base: 1rem; --cp-fz-md: 1.0625rem; --cp-fz-lg: 1.125rem;
	--cp-fz-xl: clamp(1.25rem, 0.8vw + 1rem, 1.4375rem);
	--cp-fz-2xl: clamp(1.5rem, 1.5vw + 1rem, 1.875rem);
	--cp-fz-3xl: clamp(1.875rem, 2.5vw + 1rem, 2.5rem);
	--cp-fz-4xl: clamp(2.25rem, 4vw + 1rem, 3.5rem);
	--cp-fz-hero: clamp(2.5rem, 6vw + 1rem, 4.75rem);
	--cp-fz-mega: clamp(3rem, 8vw + 1rem, 6.5rem);

	--cp-space-1: 0.25rem; --cp-space-2: 0.5rem; --cp-space-3: 0.75rem;
	--cp-space-4: 1rem; --cp-space-5: 1.25rem; --cp-space-6: 1.5rem;
	--cp-space-8: 2rem; --cp-space-10: 2.5rem; --cp-space-12: 3rem;
	--cp-space-16: 4rem; --cp-space-20: 5rem;

	/* v2.32.5 — Container 1360px (antes 1280) para reduzir vazio lateral em
	   monitores grandes, sem exagerar a largura editorial. */
	--cp-container: 1360px; --cp-container-reading: 680px;
	--cp-gutter: clamp(16px, 3vw, 32px);
	--cp-section-y: 0;  /* v2.32.9 — desativado; estava causando padding fantasma */

	--cp-r-sm: 6px; --cp-r: 10px; --cp-r-lg: 16px; --cp-r-xl: 24px;

	--cp-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
	--cp-ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);
	--cp-duration-fast: 150ms; --cp-duration: 240ms;

	--cp-header-h: 72px;
}
.cp-dark, [data-theme="dark"] {
	--cp-primary: #FAFAF5; --cp-bg: #0a0a0a; --cp-bg-elev: #141414;
	--cp-text: #f0f0eb; --cp-text-soft: #c8c8c2;
	--cp-muted: #b8b8b3; --cp-subtle: #c0c0bb; /* v2.24.6 — AAA margin: muted 9:1, subtle 9.5:1 no dark bg (antes 7.5/8) */
	--cp-border: rgba(250,250,245,0.1); --cp-border-2: rgba(250,250,245,0.16);
	--cp-shadow: 0 4px 24px rgba(0,0,0,0.4);
}

/* === 2. BASE TYPE === */
html { font-family: var(--cp-ff-body); color: var(--cp-text); background: var(--cp-bg); font-size: 16px; }
body { font-family: var(--cp-ff-body); font-size: var(--cp-fz-base); font-weight: 400; background: var(--cp-bg); color: var(--cp-text); }
::selection { background: var(--cp-selection); color: var(--cp-primary); }
h1, h2, h3, h4, h5, h6 {
	font-family: var(--cp-ff-display); font-weight: 500; line-height: 1.08;
	letter-spacing: -0.022em; color: var(--cp-text);
	font-variation-settings: "opsz" 144;
}
h1 { font-size: var(--cp-fz-4xl); font-weight: 450; letter-spacing: -0.028em; }
h2 { font-size: var(--cp-fz-3xl); letter-spacing: -0.024em; }
h3 { font-size: var(--cp-fz-2xl); letter-spacing: -0.02em; }
h4 { font-size: var(--cp-fz-xl); letter-spacing: -0.016em; }
h5 { font-size: var(--cp-fz-lg); font-weight: 600; }
h6 { font-size: var(--cp-fz-md); font-weight: 600; }
p { line-height: 1.65; }
a { color: inherit; transition: color var(--cp-duration-fast) var(--cp-ease-smooth); }
/* v2.24.3 — skip-link com transform translateY, compatível Lighthouse */
.cp-skip-link { position: absolute; top: 0; left: 0; padding: 8px 16px; background: var(--cp-primary); color: var(--cp-bg); font-weight: 600; text-decoration: none; border-radius: 0 0 8px 0; z-index: 10000; transform: translateY(-120%); transition: transform 150ms ease; }
.cp-skip-link:focus, .cp-skip-link:focus-visible { transform: translateY(0); outline: 2px solid #fff; outline-offset: 2px; }

/* v2.24.0 — A11y: min touch target 44x44px (WCAG 2.2 Success Criterion 2.5.8) */
.btn-loan, .btn-highlight, .reward-ads, a.btn, button.btn, .cp-btn-primary, .cp-btn-secondary { min-height: 44px; min-width: 44px; display: inline-flex; align-items: center; justify-content: center; }

/* === 3. LAYOUT === */
.cp-container { width: 100%; max-width: var(--cp-container); margin-inline: auto; padding-inline: var(--cp-gutter); }
.cp-container--reading { max-width: var(--cp-container-reading); }
.cp-section { /* padding vertical removido — usar margin nos filhos */ }
.cp-section--compact { /* padding vertical removido */ }
.cp-page-grid {
	display: grid; grid-template-columns: minmax(0, 1fr);
	/* v2.32.5 — gap reduzido para aproximar sidebar do conteúdo e eliminar
	   a sensação de vazio entre as colunas. */
	gap: clamp(24px, 3vw, 40px);
}
.cp-page-grid--article {
	/* padding-block removido */
}
@media (min-width: 960px) {
	/* v2.32.6 — coluna de conteúdo fixa em 720px (largura de leitura), batendo
	   com o .cp-article__body. Elimina o vazio entre fim do texto e sidebar.
	   O grid fica: [720 content] [gap] [320 sidebar] e centraliza no container. */
	.cp-page-grid { grid-template-columns: minmax(0, 720px) 320px; justify-content: center; }
}
.cp-page-grid__content, .cp-page-grid__sidebar { min-width: 0; }

/* === 4. HEADER === */
.cp-header {
	position: sticky; top: 0; z-index: 100;
	background: rgba(250, 250, 245, 0.72);
	backdrop-filter: saturate(180%) blur(16px);
	-webkit-backdrop-filter: saturate(180%) blur(16px);
	border-bottom: 1px solid transparent;
	transition: border-color var(--cp-duration), background var(--cp-duration);
}
.cp-header.is-scrolled { border-bottom-color: var(--cp-border); background: rgba(250, 250, 245, 0.92); }
.cp-dark .cp-header, [data-theme="dark"] .cp-header { background: rgba(10, 10, 10, 0.72); }
.cp-dark .cp-header.is-scrolled, [data-theme="dark"] .cp-header.is-scrolled { background: rgba(10, 10, 10, 0.92); }
.cp-header__inner { height: var(--cp-header-h); display: flex; align-items: center; gap: clamp(16px, 3vw, 40px); }
.cp-header__brand { flex-shrink: 0; }
.cp-logo {
	font-family: var(--cp-ff-display); font-size: 1.5rem; font-weight: 500;
	letter-spacing: -0.03em; color: var(--cp-text);
	display: inline-flex; align-items: center; gap: 8px;
}
.cp-logo::before {
	content: ''; width: 8px; height: 8px; background: var(--cp-accent);
	border-radius: 50%; box-shadow: 0 0 0 3px rgba(15, 118, 110, 0.15);
	transition: box-shadow var(--cp-duration) var(--cp-ease-out);
}
.cp-logo:hover::before { box-shadow: 0 0 0 5px rgba(15, 118, 110, 0.2); }
.cp-nav { flex: 1; display: flex; align-items: center; gap: 28px; }
.cp-nav__menu { display: none; gap: 28px; align-items: center; }
@media (min-width: 900px) { .cp-nav__menu { display: flex; } }
.cp-nav__menu > li > a {
	font-size: var(--cp-fz-sm); font-weight: 500; color: var(--cp-text-soft);
	padding: 8px 0; position: relative;
	transition: color var(--cp-duration-fast) var(--cp-ease-out);
}
.cp-nav__menu > li > a:hover { color: var(--cp-accent-strong); }
.cp-nav__menu > li > a::after {
	content: ''; position: absolute; bottom: 2px; left: 50%; right: 50%;
	height: 1px; background: var(--cp-accent); opacity: 0.75;
	transition: left var(--cp-duration) var(--cp-ease-out), right var(--cp-duration) var(--cp-ease-out), opacity var(--cp-duration) var(--cp-ease-out);
}
.cp-nav__menu > li > a:hover::after,
.cp-nav__menu > li.current-menu-item > a::after { left: 0; right: 0; }
.cp-nav__menu > li.current-menu-item > a { color: var(--cp-text); }
.cp-search {
	margin-left: auto; display: flex; align-items: center; gap: 6px;
	background: var(--cp-border); border-radius: 100px;
	padding: 6px 6px 6px 14px;
	transition: box-shadow var(--cp-duration), background var(--cp-duration);
}
.cp-search:focus-within { background: var(--cp-bg-elev); box-shadow: 0 0 0 2px var(--cp-accent); }
.cp-search input[type=search] {
	background: transparent; border: 0; outline: none;
	font-size: var(--cp-fz-sm); width: 160px;
	transition: width var(--cp-duration);
}
.cp-search:focus-within input[type=search] { width: 220px; }
.cp-search input::placeholder { color: var(--cp-muted); }
.cp-search button {
	width: 30px; height: 30px; border-radius: 50%;
	background: var(--cp-primary); color: var(--cp-bg);
	display: flex; align-items: center; justify-content: center;
	font-size: 14px; transition: transform var(--cp-duration-fast);
}
.cp-search button:hover { transform: scale(1.08); }
.cp-nav-toggle {
	display: inline-flex; flex-direction: column; gap: 4px;
	width: 40px; height: 40px; align-items: center; justify-content: center;
	padding: 0; margin-left: auto; background: transparent;
}
@media (min-width: 900px) { .cp-nav-toggle { display: none; } }
.cp-nav-toggle__bar { width: 20px; height: 2px; background: var(--cp-text); border-radius: 2px; transition: transform var(--cp-duration) var(--cp-ease-out), opacity var(--cp-duration); }
.cp-nav-toggle[aria-expanded="true"] .cp-nav-toggle__bar:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.cp-nav-toggle[aria-expanded="true"] .cp-nav-toggle__bar:nth-child(2) { opacity: 0; }
.cp-nav-toggle[aria-expanded="true"] .cp-nav-toggle__bar:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* === 5. MAIN === */
.cp-main { min-height: calc(100vh - var(--cp-header-h) - 200px); }
.cp-section__title {
	font-size: var(--cp-fz-2xl); font-weight: 500;
	margin-bottom: var(--cp-space-8); letter-spacing: -0.02em;
	display: flex; align-items: baseline; gap: 12px;
}
.cp-section__title::before {
	content: ''; width: 4px; height: 1.1em; background: var(--cp-accent);
	border-radius: 2px; align-self: center;
}
.cp-section__eyebrow {
	font-family: var(--cp-ff-body); font-size: var(--cp-fz-2xs);
	font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em;
	color: var(--cp-muted); margin-bottom: 8px; display: inline-block;
}

/* === 6. HERO === */
.cp-hero { padding-block: clamp(1.5rem, 3vw, 3rem); }
.cp-hero__card { display: grid; gap: clamp(24px, 4vw, 56px); align-items: center; }
@media (min-width: 900px) { .cp-hero__card { grid-template-columns: 1.15fr 1fr; } }
.cp-hero__media {
	position: relative; aspect-ratio: 16/10;
	border-radius: var(--cp-r-lg); overflow: hidden;
	background: var(--cp-border); order: 1;
}
@media (min-width: 900px) { .cp-hero__media { order: 2; aspect-ratio: 4/5; } }
.cp-hero__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 800ms var(--cp-ease-smooth); }
.cp-hero__card:hover .cp-hero__media img { transform: scale(1.03); }
.cp-hero__body { order: 2; }
@media (min-width: 900px) { .cp-hero__body { order: 1; padding-right: 3vw; } }
.cp-hero__category {
	font-size: var(--cp-fz-2xs); font-weight: 600;
	text-transform: uppercase; letter-spacing: 0.14em;
	color: var(--cp-text);
	padding: 5px 10px; background: var(--cp-accent);
	border-radius: 4px; margin-bottom: 20px; display: inline-block;
}
.cp-hero__title {
	font-size: var(--cp-fz-hero); line-height: 1.02;
	letter-spacing: -0.03em; font-weight: 450; margin-bottom: 20px;
	font-variation-settings: "opsz" 144;
}
.cp-hero__title a { color: inherit; }
.cp-hero__title a:hover { text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 8px; }
.cp-hero__excerpt {
	font-size: var(--cp-fz-lg); line-height: 1.55;
	color: var(--cp-text-soft); max-width: 560px; margin-bottom: 24px;
}
.cp-hero__meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; font-size: var(--cp-fz-sm); color: var(--cp-muted); }
.cp-hero__meta a { color: var(--cp-text); font-weight: 500; }
.cp-hero__meta .sep { color: var(--cp-subtle); }

/* === 7. CARDS === */
.cp-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: clamp(20px, 3vw, 32px);
}
.cp-card { display: flex; flex-direction: column; gap: 14px; position: relative; }
.cp-card__link { position: absolute; inset: 0; z-index: 1; }
.cp-card__media {
	aspect-ratio: 4/3; overflow: hidden; border-radius: var(--cp-r);
	background: var(--cp-border); position: relative;
}
.cp-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 700ms var(--cp-ease-smooth); }
.cp-card:hover .cp-card__media img { transform: scale(1.06); }
.cp-card__body { display: flex; flex-direction: column; gap: 8px; }
.cp-card__category {
	font-size: var(--cp-fz-2xs); font-weight: 600;
	text-transform: uppercase; letter-spacing: 0.1em;
	color: var(--cp-text-soft); position: relative; z-index: 2;
}
.cp-card__category::before {
	content: ''; display: inline-block; width: 6px; height: 6px;
	border-radius: 50%; background: var(--cp-accent);
	margin-right: 7px; vertical-align: middle;
}
.cp-card__title {
	font-family: var(--cp-ff-display); font-size: var(--cp-fz-xl);
	font-weight: 500; line-height: 1.15; letter-spacing: -0.018em;
	color: var(--cp-text);
}
.cp-card:hover .cp-card__title { color: var(--cp-primary); }
.cp-card__excerpt {
	font-size: var(--cp-fz-sm); color: var(--cp-muted); line-height: 1.55;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.cp-card__meta {
	display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
	font-size: var(--cp-fz-xs); color: var(--cp-muted); margin-top: auto;
}
.cp-card--feature .cp-card__media { aspect-ratio: 16/9; }
.cp-card--feature .cp-card__title { font-size: var(--cp-fz-2xl); }
.cp-card--feature .cp-card__excerpt { -webkit-line-clamp: 3; font-size: var(--cp-fz-md); }
.cp-card--compact .cp-card__media { display: none; }
.cp-card--compact { padding: 20px; border-radius: var(--cp-r); background: var(--cp-bg-elev); box-shadow: var(--cp-shadow-sm); transition: box-shadow var(--cp-duration); }
.cp-card--compact:hover { box-shadow: var(--cp-shadow); }

.cp-list { display: flex; flex-direction: column; gap: 28px; }
.cp-list-item {
	display: grid; grid-template-columns: 1fr; gap: 20px;
	padding-bottom: 28px; border-bottom: 1px solid var(--cp-border);
	position: relative;
}
.cp-list-item:last-child { border-bottom: 0; }
@media (min-width: 640px) { .cp-list-item { grid-template-columns: 200px 1fr; } }
.cp-list-item__link { position: absolute; inset: 0; z-index: 1; }
.cp-list-item__media {
	aspect-ratio: 4/3; border-radius: var(--cp-r);
	overflow: hidden; background: var(--cp-border);
}
.cp-list-item__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 700ms var(--cp-ease-smooth); }
.cp-list-item:hover .cp-list-item__media img { transform: scale(1.06); }
.cp-list-item__body { display: flex; flex-direction: column; gap: 10px; }
.cp-list-item__title {
	font-family: var(--cp-ff-display); font-size: var(--cp-fz-xl);
	font-weight: 500; line-height: 1.2; letter-spacing: -0.018em;
}
.cp-list-item__excerpt {
	font-size: var(--cp-fz-sm); color: var(--cp-muted); line-height: 1.55;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.cp-list-item__meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: var(--cp-fz-xs); color: var(--cp-muted); }
.cp-list-item__read-time { display: inline-flex; align-items: center; gap: 4px; }

/* === 8. ARTICLE === */
/* v2.32.5 — Abordagem editorial final (NYT/Medium style).
   
   Histórico do problema:
   - v2.32.2: .cp-article com max-width:680px contraía dentro da coluna grid (832px),
     deixando ~76px vazios de cada lado entre título e sidebar.
   - v2.32.3: removeu o max-width:680px quando é item de grid. Filhos ainda
     ficavam left-aligned com max-widths variados, gerando inconsistência visual.
   - v2.32.4: centralizou todos os filhos em 760px. Mas isso criou um NOVO
     espaço vazio entre o conteúdo centralizado e a sidebar (~100-130px de gap
     perceptível, pois content terminava em 36+760=796 e sidebar começava após
     gap de 64px).
   
   v2.32.5 (esta): abordagem editorial tradicional.
   - Content: LEFT-aligned preenchendo a coluna inteira (como NYT, Medium, Verge).
   - Body de leitura: max-width 720px, alinhado à esquerda (não centralizado).
   - Hero, title, byline, author-box, related, comments: coluna inteira.
   - Container max-width aumentado para 1360px (sem exagero) para reduzir o
     desperdício lateral em viewports grandes.
   - Gap do grid reduzido para deixar sidebar mais próxima do conteúdo. */

.cp-article:not(.cp-page-grid__content) { max-width: var(--cp-container-reading); margin-inline: auto; }
.cp-page-grid__content.cp-article { max-width: 100%; margin-inline: 0; }

/* Limpa qualquer centering herdado do fix v2.32.4 — agora tudo é left-aligned */
.cp-page-grid__content.cp-article > .cp-breadcrumbs,
.cp-page-grid__content.cp-article > .cp-article__header,
.cp-page-grid__content.cp-article > .cp-article__toc-wrapper,
.cp-page-grid__content.cp-article > .cp-article__body,
.cp-page-grid__content.cp-article > .cp-article__tags-row,
.cp-page-grid__content.cp-article > .cp-authorbox,
.cp-page-grid__content.cp-article > .cp-related,
.cp-page-grid__content.cp-article > .cp-comments,
.cp-page-grid__content.cp-article > #comments,
.cp-page-grid__content.cp-article > .cp-newsletter,
.cp-page-grid__content.cp-article > .cp-page-nav,
.cp-page-grid__content.cp-article > .cp-article__hero {
	max-width: 100%;
	margin-inline: 0;
	width: auto;
}

.cp-article__header { margin-bottom: var(--cp-space-10); }
.cp-article__title {
	font-size: var(--cp-fz-4xl); font-weight: 450; line-height: 1.04;
	letter-spacing: -0.032em; margin-bottom: 20px;
	font-variation-settings: "opsz" 144;
}
.cp-article__excerpt {
	font-family: var(--cp-ff-display); font-size: var(--cp-fz-xl);
	font-weight: 350; line-height: 1.4; color: var(--cp-text-soft);
	letter-spacing: -0.012em; font-style: italic;
	font-variation-settings: "opsz" 72, "SOFT" 50;
	max-width: 560px;
}
.cp-article__hero {
	margin-block: var(--cp-space-10); border-radius: var(--cp-r-lg);
	overflow: hidden; aspect-ratio: 16/9;
}
.cp-article__hero img { width: 100%; height: 100%; object-fit: cover; }
.cp-article__body { font-size: 1.1875rem; line-height: 1.7; color: var(--cp-text); }
.cp-article__body > * + * { margin-top: 1.4em; }
.cp-article__body p { font-variation-settings: "opsz" 24; }
/* v2.61.17 — content-visibility:auto em containers BTF (below the fold).
   Browser pula render-tree desses blocos no first paint, libera main thread
   pro paint do hero (que estava em delay de 5.58s).
   contain-intrinsic-size reserva altura aproximada pra evitar CLS no scroll.
   Aplica APENAS em containers BTF. NÃO no .cp-article__body inteiro porque
   contém o hero (LCP element) — só em seções específicas conhecidamente BTF. */
.cp-related-posts,
.cp-comments,
.cp-footer,
aside.cp-sidebar,
.cp-article__share-bottom,
.cp-article__author-box {
	content-visibility: auto;
	contain-intrinsic-size: auto 800px;
}
.cp-article__body > p:first-of-type::first-letter {
	font-family: var(--cp-ff-display); float: left;
	font-size: 4.8em; line-height: 0.85; font-weight: 500;
	padding: 4px 14px 0 0; margin-top: 6px;
	letter-spacing: -0.04em; color: var(--cp-text);
	font-variation-settings: "opsz" 144;
}
.cp-article__body h2 { font-size: var(--cp-fz-2xl); margin-top: 2.4em; margin-bottom: 0.6em; font-weight: 500; letter-spacing: -0.022em; }
.cp-article__body h3 { font-size: var(--cp-fz-xl); margin-top: 2em; margin-bottom: 0.5em; font-weight: 500; }
.cp-article__body a:not(.cp-reward-cta) {
	color: var(--cp-accent-strong);
	text-decoration: underline;
	text-decoration-color: rgba(15, 118, 110, 0.45);
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	transition: color 180ms var(--cp-ease-out),
	            text-decoration-color 180ms var(--cp-ease-out);
}
.cp-article__body a:not(.cp-reward-cta):hover {
	color: var(--cp-accent-gold-strong);
	text-decoration-color: var(--cp-accent-gold);
}
.cp-article__body a:not(.cp-reward-cta):focus-visible {
	outline: 2px solid var(--cp-accent);
	outline-offset: 3px;
	border-radius: 2px;
}
.cp-article__body ul, .cp-article__body ol { padding-left: 1.5em; margin-top: 1.2em; }
.cp-article__body ul { list-style: disc; }
.cp-article__body ol { list-style: decimal; }
.cp-article__body li { margin-top: 0.4em; padding-left: 0.3em; }
.cp-article__body li::marker { color: var(--cp-muted); }
.cp-article__body blockquote {
	font-family: var(--cp-ff-display); font-size: var(--cp-fz-xl);
	font-weight: 400; line-height: 1.35; font-style: italic;
	letter-spacing: -0.015em; color: var(--cp-text);
	border-left: 3px solid var(--cp-accent);
	padding: 12px 0 12px 24px; margin-block: 2em;
	font-variation-settings: "opsz" 72, "SOFT" 50;
}
.cp-article__body blockquote p { margin: 0; }
.cp-article__body blockquote cite {
	display: block; font-family: var(--cp-ff-body); font-size: var(--cp-fz-sm);
	color: var(--cp-muted); font-style: normal; margin-top: 12px; font-weight: 500;
}
.cp-article__body code { font-family: var(--cp-ff-mono); font-size: 0.9em; background: var(--cp-border); padding: 2px 6px; border-radius: 4px; }
.cp-article__body pre { background: var(--cp-primary); color: var(--cp-bg); padding: 20px 24px; border-radius: var(--cp-r); overflow-x: auto; font-size: var(--cp-fz-sm); line-height: 1.6; margin-block: 1.5em; }
.cp-article__body pre code { background: transparent; padding: 0; color: inherit; font-size: inherit; }
.cp-article__body img, .cp-article__body figure { border-radius: var(--cp-r); overflow: hidden; margin-block: 1.8em; }
.cp-article__body figure img { border-radius: 0; margin: 0; }
.cp-article__body figcaption { font-size: var(--cp-fz-sm); color: var(--cp-muted); text-align: center; margin-top: 12px; font-style: italic; }
.cp-article__body hr { border: 0; height: 1px; background: var(--cp-border); margin-block: 2.8em; position: relative; }
.cp-article__body hr::after { content: '❧'; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--cp-bg); color: var(--cp-muted); padding: 0 16px; font-size: 18px; }
.cp-article__body table { width: 100%; border-collapse: collapse; margin-block: 1.8em; font-size: var(--cp-fz-sm); }
.cp-article__body th, .cp-article__body td { padding: 12px 16px; border-bottom: 1px solid var(--cp-border); text-align: left; }
.cp-article__body th { font-weight: 600; color: var(--cp-text-soft); font-size: var(--cp-fz-xs); text-transform: uppercase; letter-spacing: 0.05em; }

.cp-article__meta {
	display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
	font-size: var(--cp-fz-sm); color: var(--cp-muted);
	margin-bottom: 24px; padding-bottom: 24px;
	border-bottom: 1px solid var(--cp-border);
}
.cp-article__meta-avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--cp-border); flex-shrink: 0; }
.cp-article__meta-author a { color: var(--cp-text); font-weight: 500; }
.cp-article__meta-divider { width: 3px; height: 3px; border-radius: 50%; background: var(--cp-subtle); }

.cp-reading-progress { position: fixed; top: 0; left: 0; height: 3px; background: var(--cp-accent); width: 0; z-index: 200; transition: width 100ms linear; pointer-events: none; }

.cp-article__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-block: var(--cp-space-10); }
.cp-tags-label { font-size: var(--cp-fz-xs); font-weight: 600; color: var(--cp-muted); text-transform: uppercase; letter-spacing: 0.08em; margin-right: 6px; align-self: center; }
.cp-article__tags a {
	font-size: var(--cp-fz-xs); padding: 6px 12px;
	background: var(--cp-border); border-radius: 100px;
	color: var(--cp-text-soft); transition: all var(--cp-duration-fast);
}
.cp-article__tags a:hover { background: var(--cp-accent); color: var(--cp-primary); }

.cp-share { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; padding: 20px 0; border-block: 1px solid var(--cp-border); margin-block: var(--cp-space-8); }
.cp-share__label { font-size: var(--cp-fz-xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cp-muted); margin-right: 4px; }
.cp-share a {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 14px; border-radius: 100px;
	font-size: var(--cp-fz-xs); font-weight: 500;
	background: var(--cp-bg-elev); border: 1px solid var(--cp-border);
	color: var(--cp-text-soft); transition: all var(--cp-duration-fast);
}
.cp-share a:hover { border-color: var(--cp-primary); background: var(--cp-primary); color: var(--cp-bg); transform: translateY(-2px); }

.cp-related { margin-top: var(--cp-space-16); padding-top: var(--cp-space-10); border-top: 1px solid var(--cp-border); }
.cp-related__title { font-size: var(--cp-fz-xl); font-weight: 500; margin-bottom: 20px; letter-spacing: -0.02em; }
.cp-related__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 24px; }

.cp-pagination { display: flex; align-items: center; justify-content: center; gap: 6px; margin-top: var(--cp-space-16); padding-top: var(--cp-space-8); }
.cp-pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 40px; height: 40px; padding: 0 12px;
	border-radius: var(--cp-r-sm); font-size: var(--cp-fz-sm); font-weight: 500;
	color: var(--cp-text-soft); transition: all var(--cp-duration-fast);
}
.cp-pagination .page-numbers:hover { background: var(--cp-border); color: var(--cp-text); }
.cp-pagination .page-numbers.current { background: var(--cp-primary); color: var(--cp-bg); }

.cp-page-nav { display: flex; gap: 16px; justify-content: space-between; margin-block: var(--cp-space-8); padding-block: 20px; border-block: 1px solid var(--cp-border); }
.cp-page-nav a { flex: 1; padding: 14px 20px; background: var(--cp-bg-elev); border-radius: var(--cp-r); transition: all var(--cp-duration-fast); }
.cp-page-nav a:hover { background: var(--cp-border); transform: translateY(-2px); }
.cp-page-nav__label { font-size: var(--cp-fz-2xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--cp-muted); margin-bottom: 4px; }
.cp-page-nav__title { font-weight: 500; color: var(--cp-text); font-size: var(--cp-fz-md); }

/* === 9. SIDEBAR === */
.cp-sticky-wrap { position: sticky; top: calc(var(--cp-header-h) + 20px); display: flex; flex-direction: column; gap: 20px; }
.widget { background: var(--cp-bg-elev); border: 1px solid var(--cp-border); border-radius: var(--cp-r); padding: 24px; }
.widget-title, .widgettitle { font-family: var(--cp-ff-display); font-size: var(--cp-fz-md); font-weight: 600; margin-bottom: 14px; letter-spacing: -0.015em; }
.widget ul { display: flex; flex-direction: column; gap: 10px; }
.widget ul li { font-size: var(--cp-fz-sm); }
.widget a { color: var(--cp-text-soft); transition: color var(--cp-duration-fast); }
.widget a:hover { color: var(--cp-text); }

/* === 10. FOOTER === */
.cp-footer { background: var(--cp-primary); color: var(--cp-bg); padding-block: var(--cp-space-16) var(--cp-space-10); margin-top: 40px; }
.cp-dark .cp-footer, [data-theme="dark"] .cp-footer { background: #060606; border-top: 1px solid #1c1c1c; }
.cp-footer__cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: clamp(30px, 5vw, 60px); margin-bottom: var(--cp-space-10); }
.cp-footer .widget { background: transparent; border: 0; padding: 0; }
.cp-footer .widget-title { color: var(--cp-bg); }
.cp-footer a { color: rgba(250,250,245,0.72); }
.cp-footer a:hover { color: var(--cp-bg); }
.cp-footer__bottom { display: flex; flex-wrap: wrap; gap: 20px; justify-content: space-between; padding-top: var(--cp-space-8); border-top: 1px solid rgba(250,250,245,0.1); font-size: var(--cp-fz-sm); color: rgba(250,250,245,0.5); }
.cp-footer__nav .cp-footer__menu { display: flex; gap: 20px; flex-wrap: wrap; }

/* === 11. BUTTONS === */
.cp-btn {
	display: inline-flex; align-items: center; justify-content: center; gap: 8px;
	padding: 12px 22px; border-radius: 100px;
	font-family: inherit; font-size: var(--cp-fz-sm); font-weight: 500;
	cursor: pointer; text-decoration: none; border: 1px solid transparent;
	transition: all var(--cp-duration) var(--cp-ease-smooth); white-space: nowrap;
}
.cp-btn--primary { background: var(--cp-primary); color: var(--cp-bg); }
.cp-btn--primary:hover { transform: translateY(-1px); box-shadow: 0 10px 28px rgba(10,10,10,0.18); }

/* accent = teal sofisticado (v2.11.4) */
.cp-btn--accent { background: var(--cp-accent); color: #fff; box-shadow: 0 4px 14px rgba(15, 118, 110, 0.25); }
.cp-btn--accent:hover { background: var(--cp-accent-strong); transform: translateY(-1px); box-shadow: 0 10px 28px rgba(15, 118, 110, 0.35); }

/* gold = reservado pra call-to-action principal, chamativo sem ser neon */
.cp-btn--gold { background: var(--cp-accent-gold); color: #fff; box-shadow: 0 4px 14px rgba(180, 83, 9, 0.28); }
.cp-btn--gold:hover { background: var(--cp-accent-gold-strong); transform: translateY(-1px); box-shadow: 0 10px 28px rgba(180, 83, 9, 0.4); }

.cp-btn--ghost { border-color: var(--cp-border-2); color: var(--cp-text); }
.cp-btn--ghost:hover { border-color: var(--cp-text); background: var(--cp-text); color: var(--cp-bg); }

.cp-read-more { display: inline-flex; align-items: center; gap: 4px; font-size: var(--cp-fz-sm); font-weight: 500; color: var(--cp-text); padding: 4px 0; transition: gap var(--cp-duration) var(--cp-ease-out); }
.cp-read-more::after { content: '→'; transition: transform var(--cp-duration); }
.cp-read-more:hover { gap: 10px; }

/* === 12. BREADCRUMBS === */
.cp-breadcrumbs { font-size: var(--cp-fz-xs); color: var(--cp-muted); margin-bottom: 24px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.cp-breadcrumbs a { color: var(--cp-text-soft); transition: color var(--cp-duration-fast); }
.cp-breadcrumbs a:hover { color: var(--cp-text); }
.cp-breadcrumbs__sep { color: var(--cp-subtle); }

/* === 13. ARCHIVE — MOVIDO v2.25.1 pra assets/css/archive.css (conditional enqueue) === */
/* === 14. EMPTY / 404 — MOVIDO v2.25.1 pra assets/css/archive.css (conditional enqueue) === */

/* === 15. ADS === */
.cp-ad { display: block; margin-block: var(--cp-space-8); text-align: center; min-height: 280px; position: relative; background: var(--cp-border); border-radius: var(--cp-r); overflow: hidden; }
/* v2.28.2 — Defensive: nulls any pseudo-label that might persist from stale caches */
.cp-ad::before,
.cp-ad::after,
.cp-ad-wrapper::before,
.cp-ad-wrapper::after,
.cp-in-article-ad::before,
.cp-in-article-ad::after { content: none !important; display: none !important; }
.cp-ad > * { position: relative; z-index: 1; }
.cp-ad iframe, .cp-ad ins { margin: 0 auto; display: block !important; }
.cp-ad--anchor { position: fixed; bottom: 0; left: 0; right: 0; z-index: 80; min-height: 60px; margin: 0; background: var(--cp-bg-elev); border-top: 1px solid var(--cp-border); border-radius: 0; box-shadow: 0 -4px 24px rgba(0,0,0,0.08); animation: cpAnchorSlide 500ms var(--cp-ease-out) 2s both; }
@keyframes cpAnchorSlide { from { transform: translateY(100%); } to { transform: translateY(0); } }
.cp-ad--anchor .cp-ad__close { position: absolute; top: -24px; right: 8px; width: 24px; height: 24px; background: var(--cp-primary); color: var(--cp-bg); border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 12px; border: 2px solid var(--cp-bg); }

/* === 16. BLOCKS === */
.cp-block { margin-block: var(--cp-space-4); }
.cp-article__body .cp-block { margin-block: var(--cp-space-6); }

/* === 17. UTIL === */
.cp-visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.cp-theme-toggle { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; background: var(--cp-border); color: var(--cp-text); transition: background var(--cp-duration-fast), transform var(--cp-duration-fast); margin-left: 8px; }
.cp-theme-toggle:hover { background: var(--cp-border-2); transform: rotate(15deg); }

/* === 18. MOBILE NAV === */
.cp-mobile-nav { position: fixed; inset: var(--cp-header-h) 0 0 0; background: var(--cp-bg); z-index: 99; padding: 32px 24px; overflow-y: auto; transform: translateX(100%); transition: transform var(--cp-duration) var(--cp-ease-smooth); }
.cp-mobile-nav.is-open { transform: translateX(0); }
@media (min-width: 900px) { .cp-mobile-nav { display: none; } }
.cp-mobile-nav ul { display: flex; flex-direction: column; gap: 4px; }
.cp-mobile-nav a { display: block; font-family: var(--cp-ff-display); font-size: var(--cp-fz-2xl); font-weight: 450; padding: 10px 0; border-bottom: 1px solid var(--cp-border); }

/* === 19. REVEAL === */
.cp-reveal { opacity: 0; transform: translateY(24px); transition: opacity 800ms var(--cp-ease-out), transform 800ms var(--cp-ease-out); }
.cp-reveal.is-visible { opacity: 1; transform: translateY(0); }

/* === 20. PRINT === */
@media print {
	.cp-header, .cp-footer, .cp-ad, .cp-block, .cp-share, .cp-related, .cp-page-nav { display: none !important; }
	.cp-article { max-width: 100%; }
	a { text-decoration: underline; }
	a[href]::after { content: " (" attr(href) ")"; font-size: 0.8em; color: #666; }
}

/* ============================================================ */
/* PATCH: classes adicionais que estavam faltando                 */
/* ============================================================ */

/* Footer columns + copyright */
.cp-footer__col { min-width: 0; }
.cp-footer__copyright { max-width: 520px; line-height: 1.6; }

/* Mobile nav menu list */
.cp-mobile-nav__menu { display: flex; flex-direction: column; gap: 4px; list-style: none; padding: 0; margin: 0; }
.cp-mobile-nav__menu a { display: block; font-family: var(--cp-ff-display); font-size: var(--cp-fz-2xl); font-weight: 450; padding: 14px 0; border-bottom: 1px solid var(--cp-border); }
.cp-mobile-nav__menu li { list-style: none; }

/* Section variants */
.cp-section--hero { /* padding removido */ }
.cp-section--grid { /* padding removido */ }
.cp-section--list { /* padding removido */ }

/* Empty 404 variant */
.cp-empty--404 .cp-empty__code { animation: cp404Drop 800ms var(--cp-ease-out); }
@keyframes cp404Drop { from { transform: translateY(-40px); opacity: 0; } to { transform: none; opacity: 1; } }

/* Theme toggle icons (wrapper already defined) */
.cp-theme-toggle__icon { width: 16px; height: 16px; }

/* Meta (cyberplay_post_meta compact) */
.cp-meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; font-size: var(--cp-fz-sm); color: var(--cp-muted); margin-bottom: 16px; }
.cp-meta__cat { font-size: var(--cp-fz-2xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--cp-text); padding: 4px 10px; background: var(--cp-accent); border-radius: 4px; }
.cp-meta__date, .cp-meta__reading { font-size: var(--cp-fz-sm); }

/* Placeholder image */
.cp-img { display: block; width: 100%; height: 100%; object-fit: cover; }
.cp-img--placeholder { background: linear-gradient(135deg, var(--cp-border) 0%, var(--cp-bg-elev) 100%); }

/* Keyboard focus ring */
body.cp-using-kbd :focus { outline: 2px solid var(--cp-accent); outline-offset: 3px; }

/* Lang switcher (cp-lang-switcher) */
.cp-lang-switcher { position: relative; display: inline-flex; align-items: center; }
.cp-lang-switcher select { appearance: none; background: var(--cp-border); border: 0; border-radius: 100px; padding: 6px 28px 6px 12px; font-size: var(--cp-fz-sm); cursor: pointer; }

/* ============================================================ */
/* 21. AUTHOR BOX                                                 */
/* ============================================================ */
.cp-author-box {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: 24px;
	padding: 32px;
	margin-block: var(--cp-space-10);
	background: var(--cp-bg-elev);
	border: 1px solid var(--cp-border);
	border-radius: var(--cp-r-lg);
	position: relative;
	overflow: hidden;
}
.cp-author-box::before {
	content: '';
	position: absolute;
	top: 0; left: 0;
	width: 4px; height: 100%;
	background: var(--cp-accent);
}
@media (max-width: 600px) {
	.cp-author-box {
		grid-template-columns: 1fr;
		text-align: left;
		padding: 24px;
	}
}
.cp-author-box__avatar { flex-shrink: 0; }
.cp-author-box__img, .cp-author-box img {
	width: 80px; height: 80px;
	border-radius: 50%;
	object-fit: cover;
	background: var(--cp-border);
}
.cp-author-box__body { display: flex; flex-direction: column; gap: 6px; }
.cp-author-box__eyebrow {
	font-size: var(--cp-fz-2xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--cp-muted);
}
.cp-author-box__name {
	font-size: var(--cp-fz-xl);
	font-weight: 500;
	letter-spacing: -0.02em;
	margin: 0;
}
.cp-author-box__name a { color: var(--cp-text); transition: color var(--cp-duration-fast); }
.cp-author-box__name a:hover { color: var(--cp-primary); }
.cp-author-box__bio {
	color: var(--cp-text-soft);
	font-size: var(--cp-fz-md);
	line-height: 1.55;
	margin: 6px 0 0;
}
.cp-author-box__links {
	display: flex; flex-wrap: wrap; gap: 14px;
	margin-top: 12px;
	font-size: var(--cp-fz-sm);
}
.cp-author-box__link {
	color: var(--cp-text);
	font-weight: 500;
	border-bottom: 1px dashed var(--cp-border-2);
	padding-bottom: 2px;
	transition: border-color var(--cp-duration-fast);
}
.cp-author-box__link:hover { border-bottom-color: var(--cp-accent); border-bottom-style: solid; }

/* ============================================================ */
/* 22. NEWSLETTER                                                 */
/* ============================================================ */
.cp-newsletter {
	position: relative;
	padding: 40px clamp(24px, 4vw, 48px);
	margin-block: var(--cp-space-10);
	background: var(--cp-primary);
	color: var(--cp-bg);
	border-radius: var(--cp-r-lg);
	overflow: hidden;
}
.cp-newsletter::before {
	content: '';
	position: absolute;
	right: -120px; top: -120px;
	width: 360px; height: 360px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(15, 118, 110, 0.14) 0%, transparent 70%);
	pointer-events: none;
}
.cp-newsletter__decor {
	position: absolute;
	right: 40px; top: 30px;
	font-family: var(--cp-ff-display);
	font-size: 140px;
	font-weight: 300;
	color: var(--cp-accent);
	opacity: 0.1;
	line-height: 1;
	pointer-events: none;
	font-variation-settings: "opsz" 144;
}
.cp-newsletter__body { position: relative; z-index: 1; }
.cp-newsletter__title {
	font-family: var(--cp-ff-display);
	font-size: var(--cp-fz-3xl);
	font-weight: 450;
	line-height: 1.1;
	letter-spacing: -0.025em;
	color: var(--cp-bg);
	margin-bottom: 10px;
	max-width: 560px;
}
.cp-newsletter__desc {
	color: rgba(250,250,245,0.7);
	font-size: var(--cp-fz-md);
	line-height: 1.5;
	margin-bottom: 24px;
	max-width: 480px;
}
.cp-newsletter__form { max-width: 520px; }
.cp-newsletter__row {
	display: flex;
	gap: 8px;
	background: rgba(255,255,255,0.08);
	padding: 6px;
	border-radius: 100px;
	border: 1px solid rgba(255,255,255,0.12);
	transition: border-color var(--cp-duration-fast), background var(--cp-duration-fast);
}
.cp-newsletter__row:focus-within {
	background: rgba(255,255,255,0.12);
	border-color: var(--cp-accent);
}
.cp-newsletter__row input[type=email] {
	flex: 1;
	background: transparent;
	border: 0;
	color: var(--cp-bg);
	padding: 10px 16px;
	font-size: var(--cp-fz-md);
	outline: none;
	min-width: 0;
}
.cp-newsletter__row input[type=email]::placeholder { color: rgba(250,250,245,0.4); }
.cp-newsletter__btn {
	background: var(--cp-accent);
	color: var(--cp-primary);
	border-radius: 100px;
	padding: 10px 20px;
	font-weight: 600;
	font-size: var(--cp-fz-sm);
	cursor: pointer;
	transition: transform var(--cp-duration-fast);
	white-space: nowrap;
}
.cp-newsletter__btn:hover { transform: scale(1.03); }
.cp-newsletter__btn[disabled] { opacity: 0.6; cursor: wait; }
.cp-newsletter__message {
	margin-top: 12px;
	font-size: var(--cp-fz-sm);
	min-height: 20px;
}
.cp-newsletter__message.is-success { color: var(--cp-accent); }
.cp-newsletter__message.is-error { color: #ff8585; }

/* Sidebar variant */
.cp-newsletter--sidebar {
	padding: 24px;
	margin: 0 0 20px;
}
.cp-newsletter--sidebar .cp-newsletter__title { font-size: var(--cp-fz-xl); }
.cp-newsletter--sidebar .cp-newsletter__desc { font-size: var(--cp-fz-sm); margin-bottom: 16px; }
.cp-newsletter--sidebar .cp-newsletter__row { flex-direction: column; border-radius: var(--cp-r); padding: 8px; }
.cp-newsletter--sidebar .cp-newsletter__row input[type=email] { padding: 10px 12px; font-size: var(--cp-fz-sm); }
.cp-newsletter--sidebar .cp-newsletter__btn { border-radius: var(--cp-r-sm); padding: 10px; justify-content: center; }

/* ============================================================ */
/* 23. IN-ARTICLE RELATED                                         */
/* ============================================================ */
.cp-inarticle {
	display: block;
	margin-block: 2.5em;
	padding: 20px;
	background: var(--cp-bg-elev);
	border: 1px solid var(--cp-border);
	border-left: 3px solid var(--cp-accent);
	border-radius: var(--cp-r);
	transition: box-shadow var(--cp-duration);
	position: relative;
}
.cp-inarticle:hover { box-shadow: var(--cp-shadow); }
.cp-inarticle__eyebrow {
	font-size: var(--cp-fz-2xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--cp-muted);
	margin-bottom: 12px;
}
.cp-inarticle__link {
	display: grid;
	grid-template-columns: 100px 1fr;
	gap: 16px;
	align-items: center;
	color: inherit;
	text-decoration: none;
}
@media (max-width: 500px) {
	.cp-inarticle__link { grid-template-columns: 80px 1fr; gap: 12px; }
}
.cp-inarticle__media {
	aspect-ratio: 1/1;
	border-radius: var(--cp-r-sm);
	overflow: hidden;
	background: var(--cp-border);
}
.cp-inarticle__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 600ms var(--cp-ease-smooth);
}
.cp-inarticle:hover .cp-inarticle__media img { transform: scale(1.06); }
.cp-inarticle__body { display: flex; flex-direction: column; gap: 6px; }
.cp-inarticle__title {
	font-family: var(--cp-ff-display);
	font-size: var(--cp-fz-md);
	font-weight: 500;
	line-height: 1.2;
	letter-spacing: -0.015em;
	margin: 0;
	color: var(--cp-text);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cp-inarticle__excerpt {
	font-family: var(--cp-ff-body);
	font-size: var(--cp-fz-xs);
	color: var(--cp-muted);
	line-height: 1.45;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cp-inarticle__meta {
	display: flex; align-items: center; justify-content: space-between;
	font-size: var(--cp-fz-xs);
	color: var(--cp-muted);
	margin-top: 2px;
}
.cp-inarticle__arrow {
	color: var(--cp-text);
	font-weight: 600;
	transition: transform var(--cp-duration);
}
.cp-inarticle:hover .cp-inarticle__arrow { transform: translateX(4px); }

/* ============================================================ */
/* 24. BACK TO TOP                                                */
/* ============================================================ */
.cp-back-to-top {
	position: fixed;
	bottom: 24px; right: 24px;
	width: 44px; height: 44px;
	border-radius: 50%;
	background: var(--cp-primary); color: var(--cp-bg);
	display: flex; align-items: center; justify-content: center;
	box-shadow: var(--cp-shadow);
	z-index: 90;
	cursor: pointer;
	opacity: 0;
	transform: translateY(10px) scale(0.9);
	transition: opacity var(--cp-duration) var(--cp-ease-out),
	            transform var(--cp-duration) var(--cp-ease-out);
	pointer-events: none;
}
.cp-back-to-top.is-visible {
	opacity: 1;
	transform: none;
	pointer-events: auto;
}
.cp-back-to-top:hover { transform: translateY(-3px) scale(1.04); }
@media (max-width: 600px) {
	.cp-back-to-top { bottom: 84px; right: 16px; width: 40px; height: 40px; }
	body.cp-has-anchor .cp-back-to-top { bottom: 96px; }
}

/* ============================================================ */
/* 25. COMMENTS                                                   */
/* v2.24.8 — MOVIDO pra assets/css/comments.css (enqueue condicional   */
/* via comments_open() em functions.php). PSI flagava 12 KiB de CSS   */
/* não usado em single.php quando comments estão fechados.            */
/* ============================================================ */


/* ============================================================ */
/* 26. SEARCH FORM (standalone)                                   */
/* v2.25.1 — MOVIDO pra assets/css/archive.css (enqueue em is_search())) */
/* ============================================================ */

/* ============================================================ */
/* 27. SIDEBAR FALLBACK WIDGETS                                   */
/* ============================================================ */
.cp-widget-posts__list {
	display: flex; flex-direction: column; gap: 16px;
	padding: 0;
	counter-reset: cp-list;
}
.cp-widget-posts__item {
	display: grid;
	grid-template-columns: 36px 1fr;
	gap: 12px;
	align-items: flex-start;
	padding: 0;
}
.cp-widget-posts__num {
	font-family: var(--cp-ff-display);
	font-size: var(--cp-fz-2xl);
	font-weight: 300;
	font-variation-settings: "opsz" 144;
	color: var(--cp-accent);
	line-height: 1;
	-webkit-text-stroke: 0.5px var(--cp-text);
	letter-spacing: -0.04em;
}
.cp-widget-posts__link {
	display: flex; flex-direction: column; gap: 4px;
	color: var(--cp-text);
	min-width: 0;
}
.cp-widget-posts__title {
	font-size: var(--cp-fz-sm);
	font-weight: 500;
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	transition: color var(--cp-duration-fast);
}
.cp-widget-posts__link:hover .cp-widget-posts__title { color: var(--cp-primary); }
.cp-widget-posts__meta {
	font-size: var(--cp-fz-2xs);
	color: var(--cp-muted);
}

.cp-widget-cats__list {
	display: flex; flex-wrap: wrap; gap: 6px;
}
.cp-widget-cats__list li { list-style: none; }
.cp-widget-cats__list a {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: var(--cp-fz-xs);
	padding: 6px 12px;
	background: var(--cp-border);
	border-radius: 100px;
	color: var(--cp-text-soft);
	transition: all var(--cp-duration-fast);
}
.cp-widget-cats__list a:hover {
	background: var(--cp-accent);
	color: var(--cp-primary);
}
.cp-widget-cats__count {
	font-size: 10px;
	font-weight: 600;
	opacity: 0.6;
}

/* ============================================================ */
/* 28. LANDING PAGE TEMPLATE                                      */
/* ============================================================ */
body.cp-landing { background: var(--cp-bg); }
.cp-landing__main { min-height: 100vh; }
.cp-landing__article {
	max-width: 800px;
	margin-inline: auto;
	padding: var(--cp-gutter);
}

/* ============================================================ */
/* 29. CARD VARIANTS EXTRA                                        */
/* ============================================================ */
/* Card "overlay" — imagem fullbleed com texto sobreposto (estilo editorial) */
.cp-card--overlay {
	aspect-ratio: 3/4;
	position: relative;
	overflow: hidden;
	border-radius: var(--cp-r-lg);
	color: var(--cp-bg);
}
.cp-card--overlay .cp-card__media {
	position: absolute; inset: 0;
	aspect-ratio: auto;
	border-radius: 0;
}
.cp-card--overlay .cp-card__media::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.3) 50%, transparent 80%);
}
.cp-card--overlay .cp-card__body {
	position: absolute; inset: auto 0 0 0;
	padding: 28px;
	z-index: 2;
	color: var(--cp-bg);
}
.cp-card--overlay .cp-card__category {
	color: var(--cp-bg);
	font-weight: 700;
}
.cp-card--overlay .cp-card__category::before { background: var(--cp-accent); }
.cp-card--overlay .cp-card__title {
	color: var(--cp-bg);
	font-size: var(--cp-fz-2xl);
	font-weight: 500;
}
.cp-card--overlay .cp-card__excerpt,
.cp-card--overlay .cp-card__meta { color: rgba(250,250,245,0.8); }

/* Card "horizontal" — imagem à esquerda, texto à direita (NYT style) */
.cp-card--horizontal {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: 18px;
	align-items: flex-start;
}
.cp-card--horizontal .cp-card__media { aspect-ratio: 4/3; margin-bottom: 0; }
.cp-card--horizontal .cp-card__title { font-size: var(--cp-fz-lg); }
@media (max-width: 500px) {
	.cp-card--horizontal { grid-template-columns: 120px 1fr; gap: 14px; }
	.cp-card--horizontal .cp-card__title { font-size: var(--cp-fz-md); }
	.cp-card--horizontal .cp-card__excerpt { display: none; }
}

/* Card "small" — versão compacta p/ related */
.cp-card--small .cp-card__title { font-size: var(--cp-fz-md); }
.cp-card--small .cp-card__excerpt { display: none; }

/* ============================================================ */
/* 30. HERO VARIANTS                                              */
/* ============================================================ */
/* Hero "mega" — cobertura total de tela */
.cp-hero--mega {
	position: relative;
	min-height: 70vh;
	display: flex; align-items: end;
	padding: var(--cp-space-16) 0;
	overflow: hidden;
	border-radius: var(--cp-r-xl);
	color: var(--cp-bg);
}
.cp-hero--mega::before {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.2) 70%, transparent 100%);
	z-index: 1;
}
.cp-hero--mega .cp-hero__img-bg {
	position: absolute; inset: 0;
	object-fit: cover;
	width: 100%; height: 100%;
}
.cp-hero--mega .cp-hero__body {
	position: relative; z-index: 2;
	padding: var(--cp-space-10) clamp(24px, 4vw, 56px);
	max-width: 800px;
}
.cp-hero--mega .cp-hero__title { color: var(--cp-bg); font-size: var(--cp-fz-hero); }
.cp-hero--mega .cp-hero__excerpt,
.cp-hero--mega .cp-hero__meta { color: rgba(250,250,245,0.85); }
.cp-hero--mega .cp-hero__meta a { color: var(--cp-bg); }

/* ============================================================ */
/* 31. LQIP placeholder blur                                       */
/* ============================================================ */
.cp-img[data-blur] {
	filter: blur(12px);
	transform: scale(1.05);
	transition: filter 500ms var(--cp-ease-out), transform 500ms var(--cp-ease-out);
}
.cp-img[data-blur="loaded"] {
	filter: blur(0);
	transform: none;
}

/* ============================================================ */
/* 32. ARTICLE V2 — EDITORIAL REFINEMENT (v2.7.0)                */
/* ============================================================ */

/* Eyebrow: categoria + reading time */
.cp-article__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: var(--cp-space-2);
	font-size: var(--cp-fz-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--cp-muted);
	margin-bottom: var(--cp-space-4);
}
.cp-article__category {
	color: var(--cp-accent-ink, #b3c42e);
	position: relative;
	transition: color var(--cp-duration-fast) var(--cp-ease-smooth);
}
.cp-dark .cp-article__category { color: var(--cp-accent); }
.cp-article__category:hover { color: var(--cp-text); }
.cp-article__eyebrow-sep { opacity: 0.4; }

/* Title (H1) — more impact */
.cp-article--v2 .cp-article__title {
	font-family: var(--cp-ff-display);
	font-size: var(--cp-fz-hero);
	font-weight: 450;
	line-height: 1.04;
	letter-spacing: -0.032em;
	margin: 0 0 var(--cp-space-5);
	font-variation-settings: "opsz" 144, "wght" 450;
	text-wrap: balance;
	/* v2.32.4 — removido max-width: 22ch que forçava título a quebrar em 5+ linhas.
	   text-wrap: balance já faz o balanceamento visual naturalmente. */
}

/* Dek (subheading / excerpt) — serif italic, editorial vibe */
.cp-article__dek {
	font-family: var(--cp-ff-display);
	font-style: italic;
	font-weight: 400;
	font-size: clamp(1.15rem, 0.6vw + 1.05rem, 1.35rem);
	line-height: 1.45;
	color: var(--cp-text-soft);
	margin: 0 0 var(--cp-space-6);
	max-width: 58ch;
	text-wrap: pretty;
}

/* Byline */
.cp-article__byline {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--cp-space-4);
	padding-block: var(--cp-space-5);
	border-top: 0;
	border-bottom: 1px solid var(--cp-border);
	margin-bottom: var(--cp-space-8);
	margin-top: 40px;
	flex-wrap: wrap;
	/* v2.61.17 — min-height fixo elimina CLS de 0.135 causado pelo font swap.
	   Avatar 40px + padding-block (var --cp-space-5 = 20px × 2) = 80px mínimo.
	   Quando font swap acontece (Inter Tight), o byline NÃO reflowa porque
	   o container já tem altura reservada. Resultado: CLS desce de 0.135 → ~0. */
	min-height: 80px;
	box-sizing: border-box;
}
.cp-article__byline-author {
	display: flex;
	align-items: center;
	gap: var(--cp-space-3);
}
.cp-article__byline-avatar {
	width: 40px; height: 40px;
	border-radius: 50%;
	background: var(--cp-bg-elev);
}
.cp-article__byline-meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.cp-article__byline-by {
	font-size: var(--cp-fz-xs);
	color: var(--cp-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 500;
}
.cp-article__byline-name {
	font-weight: 600;
	color: var(--cp-text);
	font-size: var(--cp-fz-sm);
	line-height: 1.2;
}
.cp-article__byline-name:hover { color: var(--cp-accent-ink, var(--cp-text-soft)); }
.cp-article__byline-dates {
	font-size: var(--cp-fz-xs);
	color: var(--cp-muted);
	line-height: 1.2;
}
.cp-article__byline-updated {
	color: var(--cp-accent-ink, #8a9520);
	font-weight: 500;
}
.cp-dark .cp-article__byline-updated { color: var(--cp-accent); }
.cp-article__share-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--cp-space-2);
	padding: 8px 14px;
	border: 1px solid var(--cp-border-2);
	border-radius: 999px;
	font-size: var(--cp-fz-xs);
	font-weight: 500;
	color: var(--cp-text);
	transition: background var(--cp-duration-fast) var(--cp-ease-smooth),
	            border-color var(--cp-duration-fast) var(--cp-ease-smooth);
}
.cp-article__share-btn:hover {
	background: var(--cp-bg-elev);
	border-color: var(--cp-text);
}

/* Hero image — CLS safe */
.cp-article__hero {
	margin: 0 0 var(--cp-space-8);
	border-radius: var(--cp-r-lg);
	overflow: hidden;
	background: var(--cp-bg-elev);
	aspect-ratio: 16/9;
}
.cp-article__hero-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.cp-article__hero-caption {
	margin-top: var(--cp-space-3);
	font-size: var(--cp-fz-xs);
	color: var(--cp-muted);
	font-style: italic;
	text-align: center;
	padding-inline: var(--cp-space-4);
}

/* ============================================================ */
/* 32.1 ToC — Table of Contents (sticky desktop, collapsible mobile) */
/* ============================================================ */
.cp-article__toc-wrapper {
	background: var(--cp-bg-elev);
	border: 1px solid var(--cp-border);
	border-radius: var(--cp-r-lg);
	padding: var(--cp-space-5) var(--cp-space-6);
	margin-bottom: var(--cp-space-8);
}
.cp-article__toc-wrapper[aria-hidden="true"] { display: none; } /* legado v2.23.x */
.cp-article__toc-wrapper[hidden] { display: none !important; } /* v2.24.3 — usa atributo hidden padrão */
.cp-article__toc-title {
	display: flex;
	align-items: center;
	gap: var(--cp-space-2);
	font-size: var(--cp-fz-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--cp-muted);
	margin: 0 0 var(--cp-space-4);
}
.cp-article__toc-title::before {
	content: "";
	display: inline-block;
	width: 16px; height: 2px;
	background: var(--cp-accent);
	margin-right: 4px;
}
.cp-article__toc-list {
	display: grid;
	gap: 6px;
	padding: 0;
	margin: 0;
	list-style: none;
	counter-reset: toc;
}
.cp-article__toc-item--h3 { padding-left: var(--cp-space-5); }
.cp-article__toc-link {
	display: block;
	padding: 6px 0;
	font-size: var(--cp-fz-sm);
	color: var(--cp-text-soft);
	line-height: 1.4;
	border-left: 2px solid transparent;
	padding-left: var(--cp-space-3);
	margin-left: -2px;
	transition: color var(--cp-duration-fast) var(--cp-ease-smooth),
	            border-color var(--cp-duration-fast) var(--cp-ease-smooth);
}
.cp-article__toc-link:hover,
.cp-article__toc-link--active {
	color: var(--cp-text);
	border-left-color: var(--cp-accent);
}

@media (min-width: 1280px) {
	.cp-page-grid--article {
		position: relative;
	}
	/* ToC pode ficar sticky à esquerda em viewport grande — opcional */
}

/* ============================================================ */
/* 32.2 ARTICLE BODY — typography refinements                  */
/* ============================================================ */
.cp-article__body {
	/* v2.32.5 — 720px left-aligned (sem margin auto).
	   Abordagem editorial tradicional: body fica à esquerda da coluna.
	   O "espaço" à direita do body é preenchido visualmente pela proximidade
	   do sidebar no grid. */
	max-width: 720px;
	margin-inline: 0;
	font-size: clamp(1.0625rem, 0.3vw + 1rem, 1.15rem);
	line-height: 1.72;
	color: var(--cp-text);
}
.cp-article__body > * + * { margin-top: var(--cp-space-5); }
.cp-article__body > h2 {
	margin-top: var(--cp-space-12);
	margin-bottom: var(--cp-space-4);
	scroll-margin-top: calc(var(--cp-header-h) + 24px);
}
.cp-article__body > h3 {
	margin-top: var(--cp-space-10);
	margin-bottom: var(--cp-space-3);
	scroll-margin-top: calc(var(--cp-header-h) + 24px);
}
.cp-article__body > p { text-wrap: pretty; }
/* Lists within article */
.cp-article__body ul,
.cp-article__body ol {
	padding-left: var(--cp-space-6);
	list-style: revert;
}
.cp-article__body ul { list-style-type: disc; }
.cp-article__body ol { list-style-type: decimal; }
.cp-article__body li { margin-bottom: var(--cp-space-2); line-height: 1.65; }
.cp-article__body li::marker { color: var(--cp-muted); }

/* Blockquote */
.cp-article__body blockquote {
	margin-block: var(--cp-space-10);
	padding: var(--cp-space-4) 0 var(--cp-space-4) var(--cp-space-6);
	border-left: 3px solid var(--cp-accent);
	font-family: var(--cp-ff-display);
	font-size: clamp(1.25rem, 0.8vw + 1rem, 1.55rem);
	font-style: italic;
	font-weight: 400;
	line-height: 1.4;
	color: var(--cp-text);
	letter-spacing: -0.015em;
	text-wrap: balance;
}
.cp-article__body blockquote p { margin-bottom: var(--cp-space-3); }
.cp-article__body blockquote cite {
	display: block;
	margin-top: var(--cp-space-3);
	font-family: var(--cp-ff-body);
	font-style: normal;
	font-weight: 500;
	font-size: var(--cp-fz-sm);
	color: var(--cp-muted);
	letter-spacing: normal;
}
.cp-article__body blockquote cite::before { content: "— "; }

/* Pullquote (marca especial pra destacar trechos) */
.cp-article__body blockquote.cp-pullquote,
.cp-article__body .cp-pullquote {
	border-left: none;
	text-align: center;
	padding: var(--cp-space-8) var(--cp-space-4);
	margin-block: var(--cp-space-12);
	font-size: clamp(1.5rem, 1.2vw + 1rem, 2rem);
	font-weight: 450;
	line-height: 1.25;
	color: var(--cp-text);
	position: relative;
	text-wrap: balance;
}
.cp-article__body blockquote.cp-pullquote::before,
.cp-article__body .cp-pullquote::before {
	content: "“";
	display: block;
	font-size: 5rem;
	line-height: 0.5;
	color: var(--cp-accent);
	margin-bottom: var(--cp-space-4);
}

/* Images inline */
.cp-article__body img,
.cp-article__body figure img {
	border-radius: var(--cp-r);
	margin-block: var(--cp-space-5);
}
.cp-article__body figure {
	margin-block: var(--cp-space-8);
}
.cp-article__body figcaption {
	margin-top: var(--cp-space-3);
	font-size: var(--cp-fz-sm);
	color: var(--cp-muted);
	font-style: italic;
	text-align: center;
	line-height: 1.5;
}

/* Code blocks */
.cp-article__body pre {
	background: var(--cp-bg-elev);
	border: 1px solid var(--cp-border);
	border-radius: var(--cp-r);
	padding: var(--cp-space-5);
	overflow-x: auto;
	font-family: var(--cp-ff-mono);
	font-size: var(--cp-fz-sm);
	line-height: 1.6;
	margin-block: var(--cp-space-6);
}
.cp-article__body code:not(pre > code) {
	background: var(--cp-bg-elev);
	padding: 2px 6px;
	border-radius: 4px;
	font-family: var(--cp-ff-mono);
	font-size: 0.88em;
	color: var(--cp-accent-ink, #8a9520);
}
.cp-dark .cp-article__body code:not(pre > code) { color: var(--cp-accent); }

/* Tables */
.cp-article__body table {
	width: 100%;
	border-collapse: collapse;
	margin-block: var(--cp-space-6);
	font-size: var(--cp-fz-sm);
}
.cp-article__body th,
.cp-article__body td {
	padding: var(--cp-space-3) var(--cp-space-4);
	text-align: left;
	border-bottom: 1px solid var(--cp-border);
}
.cp-article__body th {
	font-weight: 600;
	color: var(--cp-text);
	background: var(--cp-bg-elev);
	text-transform: uppercase;
	font-size: var(--cp-fz-xs);
	letter-spacing: 0.08em;
}

/* ============================================================ */
/* 32.3 DROP CAP — first letter of first paragraph              */
/* ============================================================ */
.cp-article__body--dropcap p.cp-has-dropcap::first-letter {
	font-family: var(--cp-ff-display);
	float: left;
	font-size: clamp(3.5rem, 4.5vw + 1rem, 5.5rem);
	line-height: 0.8;
	font-weight: 450;
	margin: 0.02em 0.08em 0 0;
	padding: 0.04em 0 0 0;
	color: var(--cp-text);
	letter-spacing: -0.04em;
	font-variation-settings: "opsz" 144, "wght" 450;
}

/* ============================================================ */
/* 32.4 IN-ARTICLE ADS                                           */
/* ============================================================ */
.cp-in-article-ad {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 280px;
	margin-block: var(--cp-space-10);
	padding: var(--cp-space-4);
	background: var(--cp-bg);
	border: 1px dashed var(--cp-border-2);
	border-radius: var(--cp-r);
	position: relative;
}
.cp-in-article-ad::before {
	content: none !important;
	display: none !important;
}
.cp-in-article-ad:empty::after {
	content: "(ad slot — configure in Cyberplay → Blocks or Ads Manager)";
	color: var(--cp-subtle);
	font-size: var(--cp-fz-xs);
	font-style: italic;
}

/* ============================================================ */
/* 32.5 TAGS + SHARE ROW (bottom of article)                     */
/* ============================================================ */
.cp-article__tags-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cp-space-5);
	justify-content: space-between;
	align-items: center;
	padding-block: var(--cp-space-6);
	margin-top: var(--cp-space-10);
	border-top: 1px solid var(--cp-border);
	border-bottom: 1px solid var(--cp-border);
}
.cp-article__tags a {
	display: inline-block;
	padding: 6px 12px;
	margin-right: 6px;
	margin-bottom: 6px;
	font-size: var(--cp-fz-xs);
	font-weight: 500;
	color: var(--cp-text-soft);
	background: var(--cp-bg-elev);
	border: 1px solid var(--cp-border);
	border-radius: 999px;
	transition: background var(--cp-duration-fast), color var(--cp-duration-fast);
}
.cp-article__tags a:hover {
	background: var(--cp-text);
	color: var(--cp-bg);
	border-color: var(--cp-text);
}
.cp-tags-label {
	display: inline-block;
	margin-right: var(--cp-space-3);
	font-size: var(--cp-fz-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--cp-muted);
}

/* ============================================================ */
/* 32.6 AUTO INTERNAL LINKS                                       */
/* ============================================================ */
.cp-auto-link {
	color: inherit;
	border-bottom: 1px dashed var(--cp-muted);
	transition: border-color var(--cp-duration-fast);
}
.cp-auto-link:hover { border-bottom-color: var(--cp-accent); }

/* ============================================================ */
/* 33. AUTHORBOX PREMIUM v2.20.2                                 */
/* ============================================================ */

.cp-authorbox {
	position: relative;
	margin: 3.5em 0 2em;
	padding: 32px 32px 28px;
	background: linear-gradient(135deg,
		color-mix(in srgb, var(--cp-primary, #0F766E) 4%, var(--cp-bg)),
		color-mix(in srgb, var(--cp-accent, #B45309) 2%, var(--cp-bg))
	);
	border: 1px solid color-mix(in srgb, var(--cp-primary, #0F766E) 18%, transparent);
	border-radius: 16px;
	overflow: hidden;
}

/* Accent line no topo */
.cp-authorbox::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg,
		var(--cp-primary, #0F766E) 0%,
		var(--cp-accent, #B45309) 100%
	);
	opacity: 0.9;
}

.cp-authorbox__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--cp-primary, #0F766E);
	margin-bottom: 18px;
}

.cp-authorbox__eyebrow-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	background: color-mix(in srgb, var(--cp-primary, #0F766E) 12%, transparent);
	border-radius: 50%;
}

.cp-authorbox__main {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	margin-bottom: 18px;
}

.cp-authorbox__avatar {
	flex-shrink: 0;
	display: block;
	width: 88px;
	height: 88px;
	border-radius: 50%;
	overflow: hidden;
	border: 3px solid var(--cp-bg);
	box-shadow:
		0 0 0 1px color-mix(in srgb, var(--cp-primary, #0F766E) 25%, transparent),
		0 8px 24px color-mix(in srgb, var(--cp-primary, #0F766E) 12%, transparent);
	transition: transform 200ms ease, box-shadow 200ms ease;
}

.cp-authorbox__avatar:hover {
	transform: translateY(-2px);
	box-shadow:
		0 0 0 1px color-mix(in srgb, var(--cp-primary, #0F766E) 40%, transparent),
		0 12px 28px color-mix(in srgb, var(--cp-primary, #0F766E) 20%, transparent);
}

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

.cp-authorbox__info {
	flex: 1;
	min-width: 0;
	padding-top: 4px;
}

.cp-authorbox__name {
	font-size: 1.35rem;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.02em;
	margin: 0 0 6px;
	color: var(--cp-text);
}

.cp-authorbox__name a {
	color: inherit;
	text-decoration: none;
	background-image: linear-gradient(var(--cp-primary, #0F766E), var(--cp-primary, #0F766E));
	background-repeat: no-repeat;
	background-size: 0 2px;
	background-position: 0 100%;
	transition: background-size 250ms ease;
	padding-bottom: 1px;
}

.cp-authorbox__name a:hover {
	background-size: 100% 2px;
}

.cp-authorbox__tagline {
	font-family: var(--cp-ff-serif, Georgia, serif);
	font-style: italic;
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--cp-muted);
	margin-bottom: 10px;
}

.cp-authorbox__credentials {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 11.5px;
	font-weight: 600;
	padding: 4px 11px;
	background: color-mix(in srgb, var(--cp-accent, #B45309) 12%, transparent);
	color: var(--cp-accent, #B45309);
	border-radius: 999px;
	margin-top: 4px;
}

.cp-authorbox__credentials-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.cp-authorbox__bio {
	font-size: 0.975rem;
	line-height: 1.7;
	color: var(--cp-text);
	margin-bottom: 20px;
	padding-top: 16px;
	border-top: 1px solid color-mix(in srgb, var(--cp-text) 8%, transparent);
}

.cp-authorbox__bio p {
	margin: 0;
}

.cp-authorbox__footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
	padding-top: 16px;
	border-top: 1px solid color-mix(in srgb, var(--cp-text) 6%, transparent);
}

.cp-authorbox__count {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
	font-size: 0.875rem;
	color: var(--cp-muted);
	text-decoration: none;
	transition: color 180ms ease;
}

.cp-authorbox__count:hover {
	color: var(--cp-primary, #0F766E);
}

.cp-authorbox__count strong {
	font-size: 1rem;
	font-weight: 700;
	color: var(--cp-text);
}

.cp-authorbox__arrow {
	margin-left: 2px;
	transition: transform 180ms ease;
}

.cp-authorbox__count:hover .cp-authorbox__arrow {
	transform: translateX(3px);
}

.cp-authorbox__socials {
	display: flex;
	gap: 8px;
	align-items: center;
}

.cp-authorbox__social {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--cp-text) 6%, transparent);
	color: var(--cp-muted);
	transition: all 180ms ease;
	text-decoration: none;
}

.cp-authorbox__social:hover {
	background: var(--cp-primary, #0F766E);
	color: #fff;
	transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 640px) {
	.cp-authorbox {
		padding: 24px 20px 20px;
		margin: 2.5em 0 1.5em;
	}
	.cp-authorbox__main {
		gap: 14px;
	}
	.cp-authorbox__avatar {
		width: 68px;
		height: 68px;
	}
	.cp-authorbox__name {
		font-size: 1.15rem;
	}
	.cp-authorbox__footer {
		gap: 12px;
	}
}

/* ============================================================ */
/* 34. ARTICLE TYPOGRAPHY POLISH v2.20.2                         */
/* ============================================================ */

/* Links mais elegantes dentro do article body
   v2.33.4 — excluir .cp-reward-cta (CTAs clicáveis como card inteiro) */
.cp-article__body a:not(.cp-auto-link):not(.cp-reward-cta) {
	background-image: linear-gradient(
		to bottom,
		transparent 65%,
		color-mix(in srgb, var(--cp-primary, #0F766E) 22%, transparent) 65%
	);
	background-size: 100% 100%;
	background-repeat: no-repeat;
	text-decoration: none;
	color: var(--cp-text);
	transition: background-size 220ms ease, color 180ms ease;
	padding: 0 2px;
}

.cp-article__body a:not(.cp-auto-link):not(.cp-reward-cta):hover {
	background-image: linear-gradient(
		to bottom,
		transparent 0%,
		color-mix(in srgb, var(--cp-primary, #0F766E) 18%, transparent) 0%
	);
	color: var(--cp-primary, #0F766E);
}

/* Headings com accent bar sutil */
.cp-article__body h2 {
	position: relative;
	padding-left: 0;
}

.cp-article__body h2::before {
	content: "";
	position: absolute;
	left: -18px;
	top: 0.3em;
	bottom: 0.3em;
	width: 3px;
	background: var(--cp-primary, #0F766E);
	border-radius: 2px;
	opacity: 0;
	transition: opacity 250ms ease, left 250ms ease;
}

.cp-article__body h2:hover::before {
	opacity: 1;
	left: -14px;
}

@media (max-width: 768px) {
	.cp-article__body h2::before {
		display: none;
	}
}

/* Blockquotes mais editoriais */
.cp-article__body blockquote {
	position: relative;
	padding: 24px 28px 24px 48px;
	background: color-mix(in srgb, var(--cp-primary, #0F766E) 3%, transparent);
	border-left: 4px solid var(--cp-primary, #0F766E);
	border-radius: 4px;
	font-family: var(--cp-ff-serif, Georgia, serif);
	font-size: 1.15em;
	line-height: 1.6;
	font-style: italic;
}

.cp-article__body blockquote::before {
	content: """;
	position: absolute;
	top: 8px;
	left: 16px;
	font-size: 3em;
	line-height: 1;
	color: color-mix(in srgb, var(--cp-primary, #0F766E) 35%, transparent);
	font-family: var(--cp-ff-serif, Georgia, serif);
	font-style: normal;
}

/* Imagens do article com sombra sutil e cantos arredondados */
.cp-article__body img {
	border-radius: 10px;
	box-shadow: 0 4px 20px color-mix(in srgb, var(--cp-text) 8%, transparent);
}

.cp-article__body figure {
	margin: 2em 0;
}

.cp-article__body figure img {
	display: block;
	margin: 0 auto;
}

.cp-article__body figure figcaption {
	margin-top: 10px;
	text-align: center;
	font-size: 0.85rem;
	color: var(--cp-muted);
	font-style: italic;
	line-height: 1.5;
}

/* Lists mais elegantes */
.cp-article__body ul,
.cp-article__body ol {
	padding-left: 1.6em;
}

.cp-article__body li {
	line-height: 1.7;
	margin-top: 0.5em;
	padding-left: 0.4em;
}

.cp-article__body li::marker {
	color: var(--cp-primary, #0F766E);
	font-weight: 700;
}

/* Hr estilizado como separator editorial */
.cp-article__body hr {
	border: 0;
	height: 1px;
	background: linear-gradient(
		to right,
		transparent,
		color-mix(in srgb, var(--cp-text) 15%, transparent) 50%,
		transparent
	);
	margin: 3em 0;
}

.cp-article__body hr::after {
	content: "✦";
	display: block;
	text-align: center;
	margin-top: -0.65em;
	color: var(--cp-muted);
	background: var(--cp-bg);
	width: 1.5em;
	margin-left: auto;
	margin-right: auto;
	font-size: 0.85rem;
}

/* Tables mais profissionais */
.cp-article__body table {
	width: 100%;
	border-collapse: collapse;
	margin: 2em 0;
	font-size: 0.95em;
	border-radius: 8px;
	overflow: hidden;
	border: 1px solid color-mix(in srgb, var(--cp-text) 10%, transparent);
}

.cp-article__body table th,
.cp-article__body table td {
	padding: 12px 16px;
	text-align: left;
	border-bottom: 1px solid color-mix(in srgb, var(--cp-text) 8%, transparent);
}

.cp-article__body table th {
	background: color-mix(in srgb, var(--cp-primary, #0F766E) 8%, transparent);
	font-weight: 700;
	font-size: 0.9em;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.cp-article__body table tr:last-child td {
	border-bottom: 0;
}

.cp-article__body table tr:hover {
	background: color-mix(in srgb, var(--cp-primary, #0F766E) 2%, transparent);
}

/* Byline polida: avatar + infos + datas */
.cp-article__byline {
	padding: 16px 0;
	border-bottom: 1px solid color-mix(in srgb, var(--cp-text) 8%, transparent);
	/* v2.61.17 — manter min-height aqui também (override do bloco anterior).
	   Avatar 40px + padding 16px×2 = 72px. */
	min-height: 72px;
}

.cp-article__byline-avatar {
	border: 2px solid var(--cp-bg);
	box-shadow: 0 0 0 1px color-mix(in srgb, var(--cp-primary, #0F766E) 25%, transparent);
	transition: transform 180ms ease;
}

.cp-article__byline-author:hover .cp-article__byline-avatar {
	transform: scale(1.05);
}

.cp-article__byline-by {
	color: var(--cp-muted);
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
}

.cp-article__byline-name {
	font-weight: 700;
	color: var(--cp-text);
	text-decoration: none;
	display: inline-block;
	margin-left: 2px;
}

.cp-article__byline-name:hover {
	color: var(--cp-primary, #0F766E);
}

.cp-article__byline-dates {
	font-size: 0.8rem;
	color: var(--cp-muted);
	margin-top: 3px;
}

.cp-article__byline-updated {
	opacity: 0.85;
}

/* Reading time accent */
.cp-article__reading-time {
	color: var(--cp-muted);
}

.cp-article__eyebrow {
	padding-bottom: 12px;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
}

.cp-article__category {
	color: var(--cp-primary, #0F766E);
	text-decoration: none;
	transition: color 180ms;
}

.cp-article__category:hover {
	color: var(--cp-accent, #B45309);
}

/* Title hierarchy */
.cp-article__title {
	letter-spacing: -0.028em;
}

/* Dek (deck/excerpt) mais elegante */
.cp-article__dek {
	font-family: var(--cp-ff-serif, Georgia, serif);
	font-size: 1.25rem;
	line-height: 1.55;
	color: var(--cp-muted);
	margin: 1em 0 0.5em;
	font-weight: 400;
}

/* Tags row melhorada */
.cp-article__tags-row {
	margin-top: 3em;
	padding-top: 2em;
	border-top: 1px solid color-mix(in srgb, var(--cp-text) 8%, transparent);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	flex-wrap: wrap;
}

.cp-article__tags a {
	display: inline-block;
	padding: 5px 12px;
	margin-right: 8px;
	margin-bottom: 8px;
	background: color-mix(in srgb, var(--cp-text) 5%, transparent);
	color: var(--cp-muted);
	font-size: 0.825rem;
	border-radius: 999px;
	text-decoration: none;
	transition: all 180ms ease;
}

.cp-article__tags a:hover {
	background: var(--cp-primary, #0F766E);
	color: #fff;
	transform: translateY(-1px);
}

/* =========================================================================
 * === 23. ARTICLE LAYOUT POLISH (v2.31.4) ===
 * ========================================================================= */

/* === v2.32.2 — ARTICLE LAYOUT (definitivo) === */

/* Grid do article: topo apertado */
.cp-page-grid.cp-page-grid--article {
	/* v2.32.5 — gap reduzido para aproximar sidebar do conteúdo */
	gap: clamp(20px, 2.5vw, 36px);
}

/* Breadcrumb: compacto, logo após o header */
body.single .cp-breadcrumbs {
	margin-top: 0 !important;
	margin-bottom: 20px !important;
	padding: 8px 0 !important;
	font-size: 12px;
	opacity: 0.7;
}

/* Eyebrow (category + reading time): enxuto */
body.single .cp-article__eyebrow {
	margin-bottom: 16px;
}

/* Title: menos margem abaixo */
body.single .cp-article__title {
	margin-bottom: 20px !important;
}

/* Ad bloco acima do byline: margem generosa */
body.single .cp-ad-block-clean {
	margin: 28px auto !important;
}

/* Byline: SEM border-top, margem generosa do ad */
body.single .cp-article__byline {
	margin-top: 36px !important;
	margin-bottom: 28px !important;
	padding: 14px 0 !important;
	border-top: 0 !important;
	border-bottom: 1px solid var(--cp-border) !important;
}

/* Hero image: menos margem top */
body.single .cp-article__hero {
	margin-top: 12px !important;
	margin-bottom: 32px !important;
}

/* Mobile: ainda mais apertado */
@media (max-width: 640px) {
	.cp-page-grid.cp-page-grid--article {
		padding-block: 12px !important;
		padding-top: 12px !important;
	}
	body.single .cp-breadcrumbs {
		margin-bottom: 14px !important;
		font-size: 11.5px;
	}
	body.single .cp-article__eyebrow { margin-bottom: 10px; }
	body.single .cp-article__title { margin-bottom: 16px !important; }
	body.single .cp-ad-block-clean { margin: 20px auto !important; }
	body.single .cp-article__byline { margin-top: 24px !important; }
	body.single .cp-article__hero { margin-top: 8px !important; margin-bottom: 20px !important; }
}

/* v2.31.5 — Desktop: separador depois do ad fica muito junto */
@media (min-width: 900px) {
	.cp-article .cp-article__byline {
		margin-top: 40px !important;
	}
}
@media (max-width: 899px) {
	.cp-article .cp-article__byline {
		margin-top: 24px !important;
	}
}

/* 2. Breadcrumbs mais próximos do topo */
.cp-article .cp-breadcrumbs,
.cp-page-grid__content > .cp-breadcrumbs {
	margin-bottom: 16px !important;
}

/* 3. Byline mais compacto */
.cp-article .cp-article__byline {
	padding-block: 12px !important;
	margin-bottom: 20px !important;
	border-top: 0 !important;
	border-bottom: 1px solid var(--cp-border) !important;
}

/* 4. TOC colapsável */
.cp-article__toc-wrapper {
	padding: 14px 18px !important;
	margin-bottom: 24px !important;
}
.cp-article__toc-title {
	margin: 0 0 10px !important;
	cursor: pointer;
	user-select: none;
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
}
.cp-article__toc-title::after {
	content: '▾';
	font-size: 14px;
	transition: transform 200ms ease;
	opacity: 0.6;
	margin-left: auto;
}
.cp-article__toc-wrapper.is-collapsed .cp-article__toc-title::after {
	transform: rotate(-90deg);
}
.cp-article__toc-wrapper.is-collapsed .cp-article__toc-list > li:nth-child(n+5) {
	display: none !important;
}
.cp-article__toc-expand {
	display: none;
	background: transparent;
	border: 0;
	color: var(--cp-accent-ink, var(--cp-primary));
	font-size: var(--cp-fz-xs);
	font-weight: 600;
	padding: 8px 0 0;
	cursor: pointer;
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.cp-article__toc-wrapper.is-collapsed .cp-article__toc-expand {
	display: block;
}
.cp-article__toc-link {
	padding: 4px 0 4px var(--cp-space-3) !important;
	font-size: 13.5px !important;
}

/* =========================================================================
 * === 21. HEADER MOBILE FIX (v2.29.0) ===
 * Problema anterior: em telas <900px o header quebrava/empilhava porque:
 *   - `.cp-nav` tinha `flex:1` mesmo com menu escondido → consumia espaço vazio
 *   - `.cp-search` e `.cp-nav-toggle` ambos tinham `margin-left: auto`
 *     competindo pela posição
 *   - Campo de busca 160px + logo + theme toggle + burger > largura da tela
 *
 * Fix: em mobile, só logo e burger menu ficam visíveis. Search e theme toggle
 * foram movidos pra dentro do menu mobile (abre ao clicar no burger). Header
 * limpo, sem overflow, layout previsível.
 * ========================================================================= */

@media (max-width: 899px) {
	/* Nav desktop não consome espaço flex quando invisível */
	.cp-nav { flex: 0 0 auto; }

	/* Esconde search + theme toggle do header (vão pro menu mobile) */
	.cp-header .cp-search,
	.cp-header > .cp-container > .cp-theme-toggle,
	.cp-header__inner > .cp-theme-toggle { display: none; }

	/* Burger fica direita absoluta, sem competir com outros margin-left:auto */
	.cp-nav-toggle { margin-left: auto; }
}

/* Logo encolhe em telas muito pequenas */
@media (max-width: 480px) {
	.cp-logo { font-size: 1.2rem; gap: 6px; }
	.cp-logo::before { width: 6px; height: 6px; box-shadow: 0 0 0 2px rgba(15, 118, 110, 0.15); }
	.cp-header__inner { gap: 12px; }
}

/* =========================================================================
 * === 21.5 HORIZONTAL OVERFLOW GUARD (v2.29.1) ===
 * Problema: título H1 do artigo com `font-size: clamp(2.5rem, 6vw+1rem, 4.75rem)`
 * fica 40px no mobile, e uma palavra longa (ex: "Online") ocupa mais que a
 * largura da viewport. Browser cria scroll horizontal, todo o layout puxa
 * pra direita, e o header parece "quebrar" (logo some pra fora, search
 * visível além da viewport). Na realidade o header está correto — é o body
 * que está com overflow.
 *
 * Fix:
 * 1. `overflow-x: hidden` no html/body pra matar qualquer scroll lateral
 * 2. Hero title menor em mobile (reduz clamp min de 2.5rem → 1.9rem)
 * 3. `word-wrap: break-word` no title pra forçar quebra de palavras muito longas
 * 4. `overflow-wrap: anywhere` como fallback moderno
 * ========================================================================= */

html, body {
	overflow-x: hidden;
	max-width: 100vw;
}

.cp-article__title,
.cp-article--v2 .cp-article__title,
.cp-hero__title {
	word-wrap: break-word;
	overflow-wrap: anywhere;
	hyphens: auto;
}

@media (max-width: 640px) {
	/* Hero size clamp mais agressivo no mobile */
	.cp-article--v2 .cp-article__title {
		font-size: clamp(1.875rem, 7vw + 0.5rem, 2.75rem);
		letter-spacing: -0.02em; /* menos negativo pra não empilhar chars */
		max-width: 100%;
	}

	/* Garante que elementos grandes não quebram container */
	.cp-article__body,
	.cp-article__body > *,
	.cp-breadcrumbs {
		max-width: 100%;
	}
}

/* =========================================================================
 * === 22. MOBILE NAV — search + theme dentro do menu aberto ===
 * Quando o user abre o burger, os ícones que tiramos do header aparecem
 * no topo do menu mobile. Search expande num input fullwidth, theme toggle
 * como botão grande clicável.
 * ========================================================================= */

.cp-mobile-nav__tools {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 24px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--cp-border);
}

.cp-mobile-nav__search {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 8px;
	background: var(--cp-border);
	border-radius: 100px;
	padding: 8px 16px;
	transition: background var(--cp-duration);
}
.cp-mobile-nav__search:focus-within {
	background: var(--cp-bg-elev);
	box-shadow: 0 0 0 2px var(--cp-accent);
}
.cp-mobile-nav__search input[type=search] {
	flex: 1;
	background: transparent;
	border: 0;
	outline: none;
	font-size: var(--cp-fz-md);
	font-family: inherit;
	color: var(--cp-text);
	min-width: 0; /* evita overflow em flex */
}
.cp-mobile-nav__search input::placeholder { color: var(--cp-muted); }
.cp-mobile-nav__search button {
	width: 32px; height: 32px;
	border-radius: 50%;
	background: var(--cp-primary);
	color: var(--cp-bg);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 0;
	cursor: pointer;
	flex-shrink: 0;
	transition: transform var(--cp-duration-fast);
}
.cp-mobile-nav__search button:hover { transform: scale(1.08); }

/* Theme toggle dentro do menu mobile — mesma aparência, só sem margin */
.cp-mobile-nav__tools .cp-theme-toggle {
	margin-left: 0;
	flex-shrink: 0;
}
