/* ============================================================
   TSP Brasil — estilos do tema
   Tokens extraidos do Figma "TSP - SITE".
   ============================================================ */

:root {
	/* Cores */
	--cor-navy:    #021d29;  /* texto principal */
	--cor-ciano:   #51c9ef;  /* destaque / scores / bordas */
	--cor-magenta: #ee2c48;  /* CTA / destaque */
	--cor-menta:   #dbeae9;  /* fundos suaves */
	--cor-branco:  #ffffff;
	--cor-cinza-bg: #f3f4f4; /* fundo de secoes alternadas */

	/* Gradiente da marca (botoes / detalhes) */
	--grad-marca: linear-gradient(90deg, #51c9ef 0%, #b06ab3 55%, #ee2c48 100%);

	/* Tipografia — Poppins substitui a Noka do layout original */
	--fonte: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	/* Layout */
	--container: 1440px;
	--raio-card: 56px;
	--raio-score: 12px;
}

/* ---------- Reset enxuto ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--fonte);
	font-weight: 500;
	color: var(--cor-navy);
	background: var(--cor-branco);
	line-height: 1.4;
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
h1, h2, h3, p { margin: 0; }
button { font-family: inherit; cursor: pointer; }

/* ---------- Acessibilidade ---------- */
.screen-reader-text {
	position: absolute;
	width: 1px; height: 1px;
	margin: -1px; padding: 0;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
	border: 0;
}

/* ---------- Layout base ---------- */
.container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: 24px;
}

.site-main { overflow-x: clip; }

/* ---------- Tipografia utilitaria ---------- */
.titulo-secao {
	font-size: clamp(2rem, 1.4rem + 2.6vw, 3rem);   /* ~48px no desktop */
	font-weight: 600;
	line-height: 1.1;
}
.titulo-hero {
	font-size: clamp(2.4rem, 1.4rem + 4vw, 4rem);    /* ~64px no desktop */
	font-weight: 600;
	line-height: 1.05;
}
.texto-destaque-ciano   { color: var(--cor-ciano); }
.texto-destaque-magenta { color: var(--cor-magenta); }

/* ---------- Cabecalho do site ---------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 30;
	background: var(--cor-branco);
	border-bottom: 1px solid rgba(2,29,41,.08);
	padding-block: 18px;
}
.site-header__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 24px;
}
.site-header__logo img { height: 48px; width: auto; }
.site-header__logo-text {
	font-weight: 700;
	font-size: 1.6rem;
	letter-spacing: .02em;
}
.site-nav {
	display: flex;
	align-items: center;
	gap: 28px;
}
.site-nav a {
	text-decoration: none;
	font-weight: 600;
	font-size: .98rem;
	color: var(--cor-navy);
}
.site-nav a:hover { color: var(--cor-magenta); }
.site-nav__cta {
	background: var(--cor-magenta);
	color: var(--cor-branco) !important;
	padding: 10px 22px;
	border-radius: 999px;
}
.site-nav__cta:hover { filter: brightness(1.08); }

/* Na home, o cabecalho flutua transparente sobre o hero. */
body.home .site-header {
	position: absolute;
	inset: 0 0 auto 0;
	background: transparent;
	border-bottom: 0;
	padding-block: 28px;
}

@media (max-width: 600px) {
	.site-nav { gap: 16px; }
	.site-nav a:not(.site-nav__cta) { display: none; }
}

/* ============================================================
   SECAO: HERO
   ============================================================ */
.hero {
	padding-top: 112px;
}
.hero__card {
	position: relative;
	background: var(--cor-menta);
	border-radius: var(--raio-card);
	min-height: 706px;
	display: grid;
	grid-template-columns: 42% 58%;
	align-items: center;
}
.hero__media {
	position: relative;
	align-self: stretch;
}
.hero__woman {
	position: absolute;
	left: 0;
	bottom: 0;
	height: 112%;
	width: auto;
	max-width: none;
	object-fit: contain;
	object-position: bottom left;
}
.hero__content {
	position: relative;
	padding: 64px 72px 64px 24px;
}
.hero__titulo {
	max-width: 18ch;
}
.hero__subtitulo {
	margin-top: 32px;
	font-size: 1.5rem;
	max-width: 30ch;
}
.hero__sticker {
	position: absolute;
	display: grid;
	place-items: center;
}
.hero__sticker svg { width: 60%; height: 60%; }
.hero__sticker--heart {
	width: 64px; height: 64px;
	left: -34px; top: 96px;
	color: var(--cor-ciano);
	transform: rotate(-12deg);
}
.hero__sticker--save {
	width: 60px; height: 60px;
	border-radius: 14px;
	background: var(--cor-magenta);
	color: var(--cor-branco);
	left: 300px; top: 24px;
	transform: rotate(14deg);
	box-shadow: 0 10px 24px rgba(238, 44, 72, .35);
}

@media (max-width: 900px) {
	.hero { padding-top: 96px; }
	.hero__card {
		grid-template-columns: 1fr;
		min-height: 0;
		text-align: center;
	}
	.hero__media {
		height: 360px;
		order: 2;
	}
	.hero__woman {
		height: 100%;
		left: 50%;
		transform: translateX(-50%);
		object-position: bottom center;
	}
	.hero__content {
		order: 1;
		padding: 56px 28px 0;
	}
	.hero__titulo, .hero__subtitulo { max-width: none; margin-inline: auto; }
	.hero__sticker--save { left: auto; right: 24px; }
	.hero__sticker--heart { left: 16px; }
}

/* ============================================================
   BOTOES
   ============================================================ */
.botao {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	border: 2px solid transparent;
	border-radius: 999px;
	padding: 14px 32px;
	font-family: var(--fonte);
	font-weight: 600;
	font-size: 1rem;
	line-height: 1;
	text-decoration: none;
	transition: transform .15s ease, filter .15s ease;
}
.botao:hover { transform: translateY(-2px); }
.botao--preenchido {
	background: var(--cor-magenta);
	color: var(--cor-branco);
}
.botao--preenchido:hover { filter: brightness(1.08); }
.botao--linha {
	background: transparent;
	border-color: var(--cor-magenta);
	color: var(--cor-magenta);
}

/* ============================================================
   SECAO GENERICA
   ============================================================ */
.canal, .vender, .rotina, .loop, .gmv, .perfis, .quem, .form {
	padding-block: clamp(64px, 4vw + 40px, 112px);
}
.titulo-secao { text-align: center; }

/* ============================================================
   SECAO: O CANAL ESTA ABERTO
   ============================================================ */
.canal__titulo { max-width: 22ch; margin-inline: auto; }
.canal__grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 32px;
	margin-top: 96px;
}
.canal-card {
	position: relative;
	flex: 1 1 380px;
	max-width: 469px;
	background: var(--cor-branco);
	border: 2px solid var(--cor-ciano);
	border-radius: var(--raio-card);
	padding: 64px 40px 40px;
	text-align: center;
}
.canal-card__score {
	position: absolute;
	top: -28px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--cor-ciano);
	color: var(--cor-navy);
	border-radius: var(--raio-score);
	padding: 16px 28px;
	font-size: clamp(1.6rem, 1rem + 1.8vw, 2.6rem);
	font-weight: 600;
	white-space: nowrap;
}
.canal-card__desc {
	font-size: 1.25rem;
	line-height: 1.35;
}
.canal-card__fonte {
	margin-top: 16px;
	font-size: .72rem;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	opacity: .65;
}
.canal__texto {
	max-width: 60ch;
	margin: 72px auto 0;
	text-align: center;
	font-size: 1.25rem;
}

/* ============================================================
   SECAO: VENDER NO TIKTOK SHOP
   ============================================================ */
.vender .container {
	background: var(--cor-menta);
	border-radius: var(--raio-card);
	padding: 72px clamp(24px, 4vw, 96px);
}
.vender__titulo { max-width: 26ch; margin-inline: auto; }
.vender__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	margin-top: 56px;
}
.vender-card {
	background: var(--cor-branco);
	border-radius: 32px;
	padding: 40px 32px;
}
.vender-card__icone {
	display: flex;
	width: 56px; height: 56px;
	margin-bottom: 24px;
}
.vender-card__icone img { width: 100%; height: 100%; object-fit: contain; }
.vender-card__texto { font-size: 1.15rem; line-height: 1.45; }

/* ============================================================
   SECAO: ROTINA — carrossel dos 7 pilares
   ============================================================ */
.rotina__titulo { max-width: 24ch; margin-inline: auto; }
.rotina__subtitulo {
	text-align: center;
	font-size: 1.25rem;
	margin-top: 16px;
}
.rotina-carrossel { margin-top: 56px; }
.rotina-carrossel__track {
	display: flex;
	gap: 16px;
	height: 560px;
}
.pilar {
	position: relative;
	flex: 0 0 96px;
	border-radius: 40px;
	overflow: hidden;
	background-color: var(--cor-navy);
	background-image:
		linear-gradient(180deg, rgba(2,29,41,.15) 0%, rgba(2,29,41,.85) 78%),
		var(--pilar-img);
	background-size: cover;
	background-position: center;
	transition: flex-basis .45s ease;
	cursor: pointer;
}
.pilar.is-aberto {
	flex: 1 1 auto;
	cursor: default;
}
.pilar__toggle {
	position: absolute;
	top: 24px; left: 50%;
	transform: translateX(-50%);
	background: none;
	border: 0;
	padding: 0;
}
.pilar__numero {
	display: grid;
	place-items: center;
	width: 60px; height: 60px;
	border-radius: 999px;
	background: rgba(255,255,255,.16);
	border: 2px solid rgba(255,255,255,.55);
	color: var(--cor-branco);
	font-weight: 600;
	font-size: 1.1rem;
	backdrop-filter: blur(4px);
}
.pilar.is-aberto .pilar__numero {
	background: var(--cor-branco);
	color: var(--cor-navy);
	border-color: var(--cor-branco);
}
.pilar__conteudo {
	position: absolute;
	inset: auto 0 0 0;
	padding: 48px;
	color: var(--cor-branco);
	opacity: 0;
	transition: opacity .3s ease .15s;
}
.pilar.is-aberto .pilar__conteudo { opacity: 1; }
.pilar__titulo {
	font-size: 2rem;
	font-weight: 600;
	line-height: 1.1;
	max-width: 14ch;
}
.pilar__desc {
	margin-top: 16px;
	font-size: 1.05rem;
	max-width: 42ch;
}
.rotina-carrossel__nav {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	margin-top: 32px;
}
.rotina-carrossel__seta {
	width: 44px; height: 44px;
	border-radius: 999px;
	border: 1.5px solid rgba(2,29,41,.3);
	background: var(--cor-branco);
	color: var(--cor-navy);
	font-size: 1.3rem;
	line-height: 1;
}
.rotina-carrossel__dots { display: flex; gap: 10px; }
.rotina-carrossel__dot {
	width: 28px; height: 6px;
	border-radius: 999px;
	border: 0;
	background: rgba(2,29,41,.18);
	padding: 0;
	transition: background .2s ease;
}
.rotina-carrossel__dot.is-ativo { background: var(--cor-magenta); }

/* ============================================================
   SECAO: FUNCIONA COMO LOOP
   ============================================================ */
.loop__topo {
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 48px;
	align-items: start;
}
.loop__titulo {
	text-align: left;
	max-width: 16ch;
}
.loop__texto { font-size: 1.1rem; line-height: 1.5; }
.loop__diagrama {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 14px;
	margin-top: 64px;
}
.loop__palavra {
	background: linear-gradient(var(--cor-branco), var(--cor-branco)) padding-box,
		var(--grad-marca) border-box;
	border: 2px solid transparent;
	border-radius: 999px;
	padding: 12px 26px;
	font-weight: 600;
	font-size: .95rem;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--cor-navy);
}
.loop__seta { color: var(--cor-ciano); font-size: 1.2rem; }

/* ============================================================
   SECAO: GMV / MARGEM
   ============================================================ */
.gmv__card {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 56px;
	align-items: center;
	background: var(--cor-cinza-bg);
	border-radius: var(--raio-card);
	padding: clamp(40px, 4vw, 80px);
}
.gmv__titulo { text-align: left; max-width: 14ch; }
.gmv__texto {
	margin-top: 28px;
	font-size: 1.05rem;
	line-height: 1.55;
}
.gmv__media img {
	width: 100%;
	border-radius: 32px;
}

/* ============================================================
   SECAO: PERFIS
   ============================================================ */
.perfis__titulo { max-width: 26ch; margin-inline: auto; }
.perfis__grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 28px;
	margin-top: 56px;
}
.perfil-card {
	flex: 1 1 380px;
	max-width: 469px;
	background: var(--cor-branco);
	border: 1.5px solid rgba(2,29,41,.1);
	border-radius: 40px;
	padding: 40px;
}
.perfil-card__icone {
	display: flex;
	width: 64px; height: 64px;
	margin-bottom: 24px;
}
.perfil-card__icone img { width: 100%; height: 100%; object-fit: contain; }
.perfil-card__titulo {
	font-size: 1.5rem;
	font-weight: 600;
}
.perfil-card__desc {
	margin-top: 16px;
	font-size: 1.05rem;
	line-height: 1.45;
}

/* ============================================================
   SECAO: QUEM OPERA
   ============================================================ */
.quem { background: var(--cor-cinza-bg); }
.quem__sobre {
	max-width: 780px;
	margin: 0 auto;
}
.quem__titulo { text-align: center; }
.quem__texto {
	margin-top: 28px;
	font-size: 1.12rem;
	line-height: 1.65;
}
.quem__time {
	margin-top: 80px;
}
.quem__time-titulo {
	font-size: 1.75rem;
	font-weight: 600;
	margin-bottom: 32px;
	text-align: center;
}
.quem__time-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
.quem-membro {
	background: var(--cor-branco);
	border-radius: 32px;
	padding: 36px 32px;
}
.quem-membro__nome {
	font-size: 1.3rem;
	font-weight: 600;
	margin: 0;
}
.quem-membro__cargo {
	margin-top: 6px;
	font-weight: 600;
	color: var(--cor-magenta);
}
.quem-membro__bio {
	margin-top: 16px;
	font-size: 1rem;
	line-height: 1.5;
}

/* ============================================================
   SECAO: FORMULARIO
   ============================================================ */
.form__titulo { max-width: 22ch; margin-inline: auto; }
.form__box {
	background: var(--cor-cinza-bg);
	border-radius: var(--raio-card);
	padding: clamp(32px, 4vw, 72px);
	margin-top: 56px;
}
.form__box-titulo {
	font-size: 2rem;
	font-weight: 600;
	margin-bottom: 40px;
}
.form__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px 40px;
	align-items: stretch;
}
.form__col {
	display: flex;
	flex-direction: column;
}
.form__campo {
	display: flex;
	flex-direction: column;
	margin-bottom: 20px;
}
.form__campo:last-child { margin-bottom: 0; }
.form__campo > span {
	margin-bottom: 8px;
	font-size: .98rem;
	font-weight: 500;
}
.form__campo input,
.form__campo textarea {
	width: 100%;
	font-family: var(--fonte);
	font-size: 1rem;
	padding: 15px 18px;
	border: 1.5px solid rgba(2,29,41,.1);
	border-radius: 14px;
	background: var(--cor-branco);
	color: var(--cor-navy);
}
.form__campo input:focus,
.form__campo textarea:focus {
	outline: none;
	border-color: var(--cor-ciano);
}
.form__campo--mensagem {
	flex: 1;
	margin-bottom: 20px;
}
.form__campo--mensagem textarea {
	flex: 1;
	resize: vertical;
	min-height: 200px;
}
.form__col .botao { align-self: flex-start; }
.form__honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form__sucesso {
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--cor-magenta);
	padding: 24px 0;
}
.form__erro {
	background: #fdecef;
	color: var(--cor-magenta);
	font-weight: 600;
	padding: 14px 20px;
	border-radius: 14px;
	margin-bottom: 24px;
}

/* ============================================================
   RODAPE
   ============================================================ */
.rodape {
	background: var(--cor-navy);
	color: var(--cor-branco);
	padding-block: 80px 40px;
}
.rodape__grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr;
	gap: 48px;
}
.rodape__logo { height: 56px; width: auto; }
.rodape__logo-text { font-weight: 700; font-size: 1.6rem; }
.rodape__descricao {
	margin-top: 20px;
	max-width: 32ch;
	opacity: .8;
	line-height: 1.5;
}
.rodape__col-titulo {
	font-size: 1.1rem;
	font-weight: 600;
	margin-bottom: 16px;
}
.rodape__col-titulo--redes { margin-top: 32px; }
.rodape__links {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	gap: 10px;
}
.rodape__links a,
.rodape__contato a {
	text-decoration: none;
	opacity: .8;
}
.rodape__links a:hover,
.rodape__contato a:hover { opacity: 1; }
.rodape__redes {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	gap: 14px;
}
.rodape__redes a {
	display: grid;
	place-items: center;
	width: 36px; height: 36px;
}
.rodape__redes svg { width: 22px; height: 22px; }
.rodape__disclaimer {
	margin-top: 56px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,.15);
	font-size: .8rem;
	opacity: .6;
	line-height: 1.5;
}

/* ============================================================
   RESPONSIVO — secoes
   ============================================================ */
@media (max-width: 900px) {
	.vender__grid { grid-template-columns: 1fr; }
	.loop__topo { grid-template-columns: 1fr; gap: 24px; }
	.loop__titulo { text-align: center; max-width: none; }
	.gmv__card { grid-template-columns: 1fr; }
	.gmv__titulo { text-align: center; max-width: none; }
	.quem__time-grid { grid-template-columns: 1fr; }
	.form__grid { grid-template-columns: 1fr; }
	.rotina-carrossel__track {
		flex-direction: column;
		height: auto;
		gap: 12px;
	}
	.pilar {
		flex: none;
		min-height: 96px;
	}
	.pilar.is-aberto { min-height: 420px; }
	.rodape__grid { grid-template-columns: 1fr; gap: 32px; }
}

/* ============================================================
   BLOG
   ============================================================ */
.container--estreito { max-width: 760px; }

.blog-cabecalho {
	padding: 72px 0 40px;
	text-align: center;
}
.blog-cabecalho__kicker {
	font-weight: 600;
	color: var(--cor-magenta);
	text-transform: uppercase;
	letter-spacing: .08em;
	font-size: .85rem;
	margin-bottom: 12px;
}
.blog-cabecalho__titulo { margin-bottom: 12px; }
.blog-cabecalho__sub {
	font-size: 1.2rem;
	max-width: 52ch;
	margin: 0 auto;
	opacity: .8;
}
.blog-filtros {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
	margin-top: 32px;
}
.blog-filtros__item {
	text-decoration: none;
	font-weight: 600;
	font-size: .9rem;
	padding: 8px 18px;
	border-radius: 999px;
	border: 1.5px solid rgba(2,29,41,.15);
	color: var(--cor-navy);
}
.blog-filtros__item:hover,
.blog-filtros__item.is-ativo {
	background: var(--cor-navy);
	color: var(--cor-branco);
	border-color: var(--cor-navy);
}

.blog-lista { padding-block: 40px 96px; }
.blog-lista--relacionados {
	padding-top: 64px;
	border-top: 1px solid rgba(2,29,41,.08);
}
.blog-lista--relacionados .titulo-secao { margin-bottom: 40px; }
.blog-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}
.post-card {
	display: flex;
	flex-direction: column;
	background: var(--cor-branco);
	border: 1.5px solid rgba(2,29,41,.1);
	border-radius: 28px;
	overflow: hidden;
	transition: transform .15s ease, box-shadow .15s ease;
}
.post-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 18px 40px rgba(2,29,41,.1);
}
.post-card__img {
	display: block;
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
}
.post-card__img img {
	width: 100%; height: 100%;
	object-fit: cover;
}
/* Filtro gradiente da marca sobre as imagens de capa. */
.post-card__img::after,
.post-single__capa::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(81,201,239,.16) 0%, rgba(176,106,179,.06) 50%, rgba(238,44,72,.16) 100%);
	pointer-events: none;
}
.post-card__img-vazia {
	display: block;
	width: 100%; height: 100%;
	background: var(--grad-marca);
	opacity: .85;
}
.post-card__corpo {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 28px;
	flex: 1;
}
.post-card__cat {
	align-self: flex-start;
	text-decoration: none;
	font-weight: 600;
	font-size: .78rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--cor-magenta);
}
.post-card__titulo {
	font-size: 1.25rem;
	font-weight: 600;
	line-height: 1.25;
	margin: 0;
}
.post-card__titulo a { text-decoration: none; }
.post-card__titulo a:hover { color: var(--cor-magenta); }
.post-card__excerpt {
	font-size: .98rem;
	line-height: 1.5;
	opacity: .8;
	flex: 1;
}
.post-card__data {
	font-size: .82rem;
	opacity: .55;
}

.blog-paginacao { margin-top: 56px; }
.blog-paginacao .nav-links {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 8px;
}
.blog-paginacao .page-numbers {
	display: grid;
	place-items: center;
	min-width: 44px;
	height: 44px;
	padding: 0 14px;
	border-radius: 999px;
	border: 1.5px solid rgba(2,29,41,.15);
	text-decoration: none;
	font-weight: 600;
}
.blog-paginacao .page-numbers.current {
	background: var(--cor-navy);
	color: var(--cor-branco);
	border-color: var(--cor-navy);
}
.blog-vazio {
	text-align: center;
	font-size: 1.15rem;
	opacity: .7;
	padding: 64px 0;
}

/* ---------- Post individual ---------- */
.post-single { padding-bottom: 96px; }
.post-single__cabecalho {
	padding: 64px 0 32px;
	text-align: center;
}
.post-single__meta {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 14px;
	margin-bottom: 18px;
	font-size: .9rem;
}
.post-single__cat {
	text-decoration: none;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--cor-magenta);
}
.post-single__meta time { opacity: .6; }
.post-single__titulo {
	font-size: clamp(2rem, 1.4rem + 2.4vw, 3rem);
	font-weight: 600;
	line-height: 1.15;
}
.post-single__capa {
	position: relative;
	margin: 16px auto 8px;
	border-radius: 32px;
	overflow: hidden;
}
.post-single__capa img { width: 100%; height: auto; display: block; }
.post-single__leitura { opacity: .6; }
.post-single__leitura::before { content: "·"; margin-right: 14px; }

/* CTA ao fim do post */
.post-cta {
	margin-top: 56px;
	padding: 40px;
	border-radius: 32px;
	background: var(--cor-menta);
	text-align: center;
}
.post-cta__titulo {
	font-size: 1.5rem;
	font-weight: 600;
	line-height: 1.2;
}
.post-cta__texto {
	margin: 12px 0 24px;
	opacity: .85;
}
.post-single__conteudo {
	margin-top: 40px;
	font-size: 1.12rem;
	line-height: 1.7;
}
.post-single__conteudo > * + * { margin-top: 1.5em; }
.post-single__conteudo h2 {
	font-size: 1.7rem;
	font-weight: 600;
	margin-top: 2em;
}
.post-single__conteudo h3 {
	font-size: 1.35rem;
	font-weight: 600;
	margin-top: 1.6em;
}
.post-single__conteudo a { color: var(--cor-magenta); }
.post-single__conteudo ul,
.post-single__conteudo ol { padding-left: 1.4em; }
.post-single__conteudo li + li { margin-top: .5em; }
.post-single__conteudo img { border-radius: 20px; }
.post-single__conteudo blockquote {
	border-left: 4px solid var(--cor-ciano);
	padding-left: 24px;
	font-size: 1.2rem;
	font-style: italic;
}

@media (max-width: 900px) {
	.blog-grid { grid-template-columns: 1fr; }
}
