/* ============================================================
   Blog Voitto — tema editorial (preto / branco / vermelho #d13b27)
   Direção: revista moderna, viva, com a cor do segmento como acento.
   ============================================================ */
:root {
  --vermelho: #d13b27;
  --vermelho-dark: #b8321f;
  --vermelho-soft: #fbeae6;
  --preto: #111010;
  --tinta: #1c1b1b;
  --fundo: #faf8f5;          /* off-white quente: profundidade */
  --branco: #ffffff;
  --texto: #2a2826;
  --texto-suave: #76706a;
  --titulo: #141312;
  --borda: #eceae6;
  --radius: 8px;
  --radius-lg: 18px;
  --sombra: 0 1px 2px rgba(20,15,10,.04), 0 8px 30px rgba(20,15,10,.06);
  --sombra-hover: 0 12px 40px rgba(20,15,10,.12);
  --transition: .2s cubic-bezier(.4,0,.2,1);
  --fonte: 'Montserrat', system-ui, sans-serif;
  --maxw: 1280px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--fonte); color: var(--texto); background: var(--fundo);
  font-size: 17px; line-height: 1.65; -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; }
a { color: var(--vermelho); text-decoration: none; transition: color var(--transition); }
::selection { background: var(--vermelho); color: #fff; }

/* ---------- Barra de progresso de leitura ---------- */
.leitura-progresso {
  position: fixed; top: 0; left: 0; height: 3px; width: 0;
  background: linear-gradient(90deg, var(--vermelho), #e8633f);
  z-index: 200; transition: width .1s linear;
}

/* ---------- Header ---------- */
.blog-header { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,.92); backdrop-filter: saturate(1.4) blur(8px); border-bottom: 1px solid var(--borda); }
.container { max-width: var(--maxw); margin: 0 auto; padding: 0 1.4rem; }
.blog-navbar { height: 66px; display: flex; align-items: center; }
.blog-navbar .logo { display: flex; align-items: center; gap: .6rem; }
.blog-navbar .logo img { height: 30px; width: auto; display: block; }
.blog-navbar .logo .logo-sufixo { font-weight: 700; font-size: 1.02rem; color: var(--preto); letter-spacing: -.3px; padding-left: .6rem; border-left: 1px solid var(--borda); }
.blog-navbar .nav-link { color: var(--tinta); font-weight: 600; font-size: .92rem; padding: .45rem .85rem; border-radius: var(--radius); transition: color var(--transition), background var(--transition); }
.blog-navbar .nav-link:hover { color: var(--vermelho); background: var(--vermelho-soft); }
.btn-cta {
  display: inline-flex; align-items: center; gap: .4rem;
  background: var(--vermelho); color: #fff; font-weight: 700; font-size: .9rem;
  padding: .62rem 1.3rem; border-radius: 100px; border: 0; cursor: pointer;
  box-shadow: 0 6px 16px rgba(209,59,39,.28); transition: var(--transition);
}
.btn-cta:hover { background: var(--vermelho-dark); color: #fff; transform: translateY(-1px); box-shadow: 0 10px 22px rgba(209,59,39,.36); }
.btn-burger { background: none; border: 0; font-size: 1.6rem; color: var(--preto); }

/* ---------- Barra de editorias (segmentos) ---------- */
.editorias { border-bottom: 1px solid var(--borda); background: var(--branco); }
.editorias-track { display: flex; gap: .3rem; overflow-x: auto; scrollbar-width: none; padding: .35rem 1.4rem; }
.editorias-track::-webkit-scrollbar { display: none; }
.editoria {
  display: inline-flex; align-items: center; gap: .45rem; white-space: nowrap;
  font-size: .82rem; font-weight: 600; color: var(--tinta); padding: .55rem .8rem;
  border-radius: var(--radius); transition: var(--transition); position: relative;
}
.editoria .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--seg); flex-shrink: 0; box-shadow: 0 0 0 3px color-mix(in srgb, var(--seg) 16%, transparent); }
.editoria:hover { color: var(--preto); background: color-mix(in srgb, var(--seg) 9%, transparent); }
.editoria.is-active { color: var(--preto); }
.editoria.is-active::after { content: ''; position: absolute; left: .8rem; right: .8rem; bottom: -.36rem; height: 2px; background: var(--seg); }

/* ---------- Wrap + grid do artigo ---------- */
.artigo-wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 1.4rem 4rem; }
.blog-breadcrumb { font-size: .8rem; color: var(--texto-suave); padding: 1.4rem 0 .2rem; display: flex; align-items: center; flex-wrap: wrap; gap: .1rem; }
.blog-breadcrumb a { color: var(--texto-suave); font-weight: 500; }
.blog-breadcrumb a:hover { color: var(--vermelho); }
.blog-breadcrumb .sep { margin: 0 .5rem; opacity: .45; }
.artigo-grid { display: grid; grid-template-columns: 224px minmax(0,1fr) 312px; gap: 2.6rem; align-items: start; padding-top: 1.2rem; }
.col-sticky { position: sticky; top: 128px; }

/* ---------- Hero ---------- */
.artigo-badge {
  display: inline-flex; align-items: center; gap: .4rem; font-size: .72rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .8px; color: #fff; background: var(--seg, var(--vermelho));
  padding: .4rem .85rem; border-radius: 100px; margin-bottom: 1.3rem;
}
.artigo-h1 { font-size: clamp(2rem, 4.2vw, 3rem); line-height: 1.08; font-weight: 800; color: var(--titulo); letter-spacing: -1.4px; margin-bottom: 1.1rem; }
.artigo-sub { font-size: 1.22rem; line-height: 1.5; color: var(--texto-suave); font-weight: 500; margin-bottom: 1.8rem; max-width: 40ch; }
.artigo-meta { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; padding: 1rem 0; border-top: 1px solid var(--borda); border-bottom: 1px solid var(--borda); }
.autor-bloco { display: flex; align-items: center; gap: .8rem; }
.autor-bloco img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 2px solid var(--branco); box-shadow: var(--sombra); }
.artigo-meta .autor { font-weight: 700; color: var(--preto); font-size: .95rem; }
.artigo-meta .sub { font-size: .82rem; color: var(--texto-suave); margin-top: .15rem; }
.artigo-meta .sub .pill { color: var(--vermelho); font-weight: 700; }
.artigo-capa { width: 100%; height: auto; display: block; border-radius: var(--radius-lg); margin-bottom: 2.6rem; box-shadow: var(--sombra); }

/* ---------- Conteúdo (legibilidade editorial) ---------- */
.artigo-conteudo { font-size: 1.14rem; line-height: 1.82; color: var(--texto); }
.artigo-conteudo > p:first-of-type::first-letter {
  -webkit-initial-letter: 3; initial-letter: 3;
  font-weight: 800; color: var(--vermelho); margin-right: .12em; font-family: var(--fonte);
}
.artigo-conteudo h2 { font-size: 1.7rem; font-weight: 800; color: var(--titulo); margin: 2.6rem 0 1rem; line-height: 1.25; letter-spacing: -.6px; padding-left: 1rem; border-left: 4px solid var(--vermelho); }
.artigo-conteudo h3 { font-size: 1.32rem; font-weight: 700; color: var(--titulo); margin: 2rem 0 .8rem; }
.artigo-conteudo p { margin: 0 0 1.4rem; }
.artigo-conteudo a { color: var(--vermelho); font-weight: 600; text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 3px; text-decoration-color: color-mix(in srgb, var(--vermelho) 35%, transparent); }
.artigo-conteudo a:hover { text-decoration-color: var(--vermelho); }
.artigo-conteudo img { border-radius: var(--radius); margin: 1.8rem auto; display: block; box-shadow: var(--sombra); }
.artigo-conteudo ul, .artigo-conteudo ol { margin: 0 0 1.4rem 1.3rem; }
.artigo-conteudo li { margin-bottom: .6rem; padding-left: .3rem; }
.artigo-conteudo li::marker { color: var(--vermelho); font-weight: 700; }
.artigo-conteudo blockquote { border-left: 4px solid var(--vermelho); background: var(--vermelho-soft); padding: 1.1rem 1.5rem; margin: 1.8rem 0; border-radius: 0 var(--radius) var(--radius) 0; font-style: italic; color: var(--tinta); }
.artigo-conteudo table { width: 100%; border-collapse: collapse; margin: 1.8rem 0; font-size: .96rem; box-shadow: var(--sombra); border-radius: var(--radius); overflow: hidden; }
.artigo-conteudo th, .artigo-conteudo td { border: 1px solid var(--borda); padding: .7rem .9rem; text-align: left; }
.artigo-conteudo th { background: var(--preto); color: #fff; font-weight: 700; }
.artigo-conteudo tr:nth-child(even) td { background: #fff; }
.artigo-conteudo iframe { max-width: 100%; border-radius: var(--radius); margin: 1.8rem 0; }

/* ---------- Colunas laterais: rolam por dentro (tudo alcançável sem rolar o artigo) ---------- */
.artigo-col-esq, .artigo-col-dir { max-height: calc(100vh - 150px); overflow-y: auto; overflow-x: hidden; padding-right: .35rem; scrollbar-width: thin; scrollbar-color: var(--borda) transparent; }
.artigo-col-esq::-webkit-scrollbar, .artigo-col-dir::-webkit-scrollbar { width: 5px; }
.artigo-col-esq::-webkit-scrollbar-thumb, .artigo-col-dir::-webkit-scrollbar-thumb { background: var(--borda); border-radius: 10px; }

/* ---------- Card de promo na coluna esquerda (preenche o vão) ---------- */
.rail-promo { margin-top: 1.6rem; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--borda); background: #fff; box-shadow: var(--sombra); }
.rail-promo .topo { background: linear-gradient(135deg, #111 0%, #2a2320 100%); color: #fff; padding: 1.2rem 1.1rem 1rem; position: relative; overflow: hidden; }
.rail-promo .topo::after { content: ''; position: absolute; right: -30px; bottom: -30px; width: 90px; height: 90px; background: radial-gradient(circle, rgba(209,59,39,.5), transparent 70%); }
.rail-promo .kicker { font-size: .6rem; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; color: var(--vermelho); }
.rail-promo .nome { font-size: 1.05rem; font-weight: 800; letter-spacing: -.3px; margin-top: .2rem; }
.rail-promo .corpo { padding: 1rem 1.1rem 1.2rem; }
.rail-promo p { font-size: .82rem; color: var(--texto-suave); line-height: 1.45; margin-bottom: .9rem; }
.rail-promo .btn-ghost { display: flex; align-items: center; justify-content: center; gap: .4rem; width: 100%; padding: .6rem; border: 1.5px solid var(--vermelho); color: var(--vermelho); border-radius: 100px; font-weight: 700; font-size: .85rem; transition: var(--transition); }
.rail-promo .btn-ghost:hover { background: var(--vermelho); color: #fff; }

/* ---------- Sumário (TOC) colapsável + numerado ---------- */
.sumario { margin-bottom: .4rem; }
.sumario-toggle { list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: .5rem; user-select: none; margin-bottom: 1rem; }
.sumario-toggle::-webkit-details-marker { display: none; }
.sumario-toggle .chev { color: var(--texto-suave); font-size: .9rem; transition: transform var(--transition); }
.sumario[open] .sumario-toggle .chev { transform: rotate(180deg); }
.sumario .titulo { font-weight: 800; text-transform: uppercase; letter-spacing: 1px; font-size: .68rem; color: var(--vermelho); display: flex; align-items: center; gap: .5rem; }
.sumario .titulo::before { content: ''; width: 18px; height: 2px; background: var(--vermelho); }
.sumario ol { list-style: none; counter-reset: toc; border-left: 2px solid var(--borda); }
.sumario li { counter-increment: toc; }
.sumario a { display: block; color: var(--texto-suave); padding: .42rem 0 .42rem 1rem; margin-left: -2px; border-left: 2px solid transparent; font-size: .85rem; line-height: 1.35; transition: var(--transition); }
.sumario a:hover { color: var(--preto); border-left-color: var(--vermelho); }
.sumario a.active { color: var(--vermelho); font-weight: 700; border-left-color: var(--vermelho); }

/* ---------- Share horizontal ---------- */
.share-bar { display: inline-flex; align-items: center; gap: .45rem; }
.share-bar .rotulo { font-size: .68rem; text-transform: uppercase; letter-spacing: 1px; color: var(--texto-suave); font-weight: 700; margin-right: .25rem; }
.share-bar .sh { width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--borda); background: #fff; display: inline-flex; align-items: center; justify-content: center; color: var(--tinta); font-size: 1rem; cursor: pointer; transition: var(--transition); }
.share-bar .sh:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 6px 14px rgba(0,0,0,.14); }
.share-bar .wpp:hover { background: #25D366; border-color: #25D366; }
.share-bar .fb:hover  { background: #1877F2; border-color: #1877F2; }
.share-bar .in:hover  { background: #0A66C2; border-color: #0A66C2; }
.share-bar .x:hover   { background: #000; border-color: #000; }
.share-bar .link:hover { background: var(--vermelho); border-color: var(--vermelho); }
.share-bar .link.copiado { background: #1faa59; border-color: #1faa59; color: #fff; }

/* ---------- Share de fim de artigo ---------- */
.share-fim { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; margin: 2.6rem 0 .5rem; padding: 1.4rem 0; border-top: 1px solid var(--borda); border-bottom: 1px solid var(--borda); }
.share-fim .frase { font-weight: 800; color: var(--titulo); font-size: 1.05rem; letter-spacing: -.3px; }

/* ---------- Widget lateral (Mais do segmento) ---------- */
.rail-widget { margin-top: 1.6rem; background: #fff; border: 1px solid var(--borda); border-radius: var(--radius-lg); padding: 1.2rem 1.2rem 1rem; box-shadow: var(--sombra); }
.rail-titulo { font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .8px; color: var(--titulo); padding-bottom: .9rem; margin-bottom: .4rem; border-bottom: 2px solid var(--seg, var(--vermelho)); display: inline-block; }
.rail-item { display: flex; gap: .7rem; align-items: center; padding: .7rem 0; border-bottom: 1px solid var(--borda); }
.rail-item:last-child { border-bottom: 0; }
.rail-item img { width: 56px; height: 56px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.rail-item span { font-size: .82rem; font-weight: 600; color: var(--tinta); line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; transition: color var(--transition); }
.rail-item:hover span { color: var(--vermelho); }

/* ---------- Box do colunista ---------- */
.colunista-box { display: flex; gap: 1.2rem; align-items: center; background: #fff; border: 1px solid var(--borda); border-radius: var(--radius-lg); padding: 1.5rem; margin: 3rem 0; box-shadow: var(--sombra); }
.colunista-box img { width: 76px; height: 76px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.colunista-box .rotulo { font-size: .64rem; text-transform: uppercase; letter-spacing: 1px; color: var(--vermelho); font-weight: 700; }
.colunista-box .nome { font-weight: 800; color: var(--preto); font-size: 1.1rem; margin: .1rem 0; }
.colunista-box .bio { font-size: .88rem; color: var(--texto-suave); line-height: 1.5; }

/* ---------- FAQ (acordeão) ---------- */
.faq { margin: 2.8rem 0 .5rem; }
.faq h2 { font-size: 1.5rem; font-weight: 800; color: var(--titulo); letter-spacing: -.5px; margin-bottom: 1.2rem; }
.faq-item { border: 1px solid var(--borda); border-radius: var(--radius); margin-bottom: .7rem; background: #fff; overflow: hidden; transition: var(--transition); }
.faq-item[open] { box-shadow: var(--sombra); }
.faq-item summary { list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.05rem 1.2rem; font-weight: 700; color: var(--titulo); font-size: 1rem; user-select: none; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary i { color: var(--vermelho); font-size: 1.15rem; transition: transform var(--transition); flex-shrink: 0; }
.faq-item[open] summary i { transform: rotate(45deg); }
.faq-item[open] summary { color: var(--vermelho); }
.faq-resp { padding: 0 1.2rem 1.15rem; color: var(--texto); line-height: 1.65; }

/* ---------- Veja também ---------- */
.veja-tambem { margin-top: 3.4rem; padding-top: 2.4rem; border-top: 2px solid var(--preto); }
.veja-tambem h2 { font-size: 1.5rem; font-weight: 800; color: var(--titulo); margin-bottom: 1.4rem; letter-spacing: -.5px; }
.rel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.rel-card { border: 1px solid var(--borda); border-radius: var(--radius-lg); overflow: hidden; background: #fff; transition: var(--transition); box-shadow: var(--sombra); display: flex; flex-direction: column; }
.rel-card:hover { box-shadow: var(--sombra-hover); transform: translateY(-3px); }
.rel-card .thumb { aspect-ratio: 16/9; overflow: hidden; }
.rel-card img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.rel-card:hover img { transform: scale(1.06); }
.rel-card .body { padding: 1rem 1.1rem 1.2rem; }
.rel-card .badge-seg { font-size: .66rem; font-weight: 800; text-transform: uppercase; letter-spacing: .6px; color: #fff; background: var(--seg, var(--vermelho)); padding: .25rem .6rem; border-radius: 100px; }
.rel-card .titulo { font-size: 1rem; font-weight: 700; color: var(--titulo); line-height: 1.32; margin-top: .6rem; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* ---------- CTA aside (lead magnet desenhado) ---------- */
.cta-aside { background: var(--preto); color: #fff; border-radius: var(--radius-lg); padding: 1.8rem 1.5rem; position: relative; overflow: hidden; box-shadow: var(--sombra); }
.cta-aside::before { content: ''; position: absolute; top: -40px; right: -40px; width: 130px; height: 130px; background: radial-gradient(circle, rgba(209,59,39,.55), transparent 70%); }
.cta-aside .kicker { font-size: .66rem; text-transform: uppercase; letter-spacing: 1.2px; color: var(--vermelho); font-weight: 800; }
.cta-aside .ic { width: 46px; height: 46px; border-radius: 12px; background: var(--vermelho); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; color: #fff; margin-bottom: 1rem; box-shadow: 0 8px 20px rgba(209,59,39,.4); }
.cta-aside h4 { font-size: 1.25rem; font-weight: 800; line-height: 1.2; margin: .4rem 0 .6rem; letter-spacing: -.4px; }
.cta-aside p { font-size: .86rem; color: #c9c4bf; margin-bottom: 1.2rem; line-height: 1.5; }
.cta-aside .btn-cta { width: 100%; justify-content: center; }

/* ---------- Card de artigo (grids) ---------- */
.cards-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.6rem; }
.card-artigo { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--borda); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--sombra); transition: var(--transition); }
.card-artigo:hover { box-shadow: var(--sombra-hover); transform: translateY(-3px); }
.card-artigo .thumb { aspect-ratio: 16/9; overflow: hidden; background: var(--fundo-suave); }
.card-artigo .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card-artigo:hover .thumb img { transform: scale(1.06); }
.card-artigo .body { padding: 1rem 1.1rem 1.2rem; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.card-artigo .badge-seg { align-self: flex-start; font-size: .64rem; font-weight: 800; text-transform: uppercase; letter-spacing: .6px; color: #fff; background: var(--seg, var(--vermelho)); padding: .25rem .6rem; border-radius: 100px; }
.card-artigo .titulo { font-size: 1.05rem; font-weight: 700; color: var(--titulo); line-height: 1.32; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.card-artigo .card-meta { margin-top: auto; font-size: .76rem; color: var(--texto-suave); }

.secao-titulo { font-size: 1.5rem; font-weight: 800; color: var(--titulo); letter-spacing: -.5px; margin: 2.4rem 0 1.4rem; }

/* ---------- Hero do colunista ---------- */
.colunista-hero { display: flex; gap: 1.8rem; align-items: center; background: #fff; border: 1px solid var(--borda); border-radius: var(--radius-lg); padding: 2rem; box-shadow: var(--sombra); margin-top: 1.2rem; position: relative; overflow: hidden; }
.colunista-hero::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 5px; background: var(--vermelho); }
.colunista-hero .foto { width: 120px; height: 120px; border-radius: 50%; object-fit: cover; flex-shrink: 0; border: 3px solid #fff; box-shadow: var(--sombra); }
.colunista-hero .rotulo { font-size: .68rem; text-transform: uppercase; letter-spacing: 1px; color: var(--vermelho); font-weight: 800; }
.colunista-hero h1 { font-size: 2rem; font-weight: 800; color: var(--titulo); letter-spacing: -.8px; margin: .15rem 0 .5rem; }
.colunista-hero .bio { color: var(--texto-suave); font-size: .96rem; line-height: 1.55; max-width: 60ch; }
.colunista-hero .acoes { display: flex; align-items: center; gap: 1.2rem; margin-top: 1rem; }
.colunista-hero .contador { font-size: .9rem; color: var(--tinta); }
.colunista-hero .lk { display: inline-flex; align-items: center; gap: .4rem; font-weight: 700; font-size: .88rem; color: var(--vermelho); }
@media (max-width: 600px) { .colunista-hero { flex-direction: column; text-align: center; padding: 1.6rem; } .colunista-hero .acoes { justify-content: center; } }

/* ---------- Home ---------- */
.home-wrap { max-width: var(--maxw); margin: 0 auto; padding: 2rem 1.4rem 3rem; }

/* Hero grid */
.home-hero { display: grid; grid-template-columns: 1.8fr 1fr; gap: 1.4rem; margin-bottom: 3rem; align-items: start; }

/* Destaque: imagem limpa + texto separado embaixo */
.hero-destaque { display: flex; flex-direction: column; background: #fff; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--sombra); border: 1px solid var(--borda); transition: var(--transition); }
.hero-destaque:hover { box-shadow: var(--sombra-hover); transform: translateY(-3px); }
.hero-img { display: block; overflow: hidden; background: var(--fundo); flex-shrink: 0; max-height: 440px; }
.hero-img img { width: 100%; height: auto; display: block; transition: transform .55s ease; }
.hero-destaque:hover .hero-img img { transform: scale(1.03); }
.hero-glass { padding: 1.4rem 1.7rem 1.7rem; display: flex; flex-direction: column; flex: 1; }
.hero-badge {
  display: inline-block; font-size: .65rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: .7px; color: #fff; background: var(--seg, var(--vermelho));
  padding: .28rem .72rem; border-radius: 100px; margin-bottom: .8rem; align-self: flex-start;
}
.hero-glass h2 {
  font-size: clamp(1.25rem, 2vw, 1.7rem); font-weight: 800; color: var(--titulo);
  line-height: 1.2; letter-spacing: -.5px; margin-bottom: .6rem;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.hero-glass p { font-size: .92rem; color: var(--texto-suave); line-height: 1.5; margin-bottom: 1.1rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; flex: 1; }
.hero-ler { display: inline-flex; align-items: center; gap: .4rem; font-size: .86rem; font-weight: 700; color: var(--vermelho); align-self: flex-start; transition: gap var(--transition); }
.hero-destaque:hover .hero-ler { gap: .65rem; }

/* Lista lateral de secundários */
.hero-lista { display: flex; flex-direction: column; gap: .8rem; }
.hero-item { display: flex; gap: .85rem; background: #fff; border: 1px solid var(--borda); border-radius: var(--radius-lg); padding: .8rem; transition: var(--transition); align-items: flex-start; }
.hero-item:hover { box-shadow: var(--sombra); border-color: color-mix(in srgb, var(--seg, var(--vermelho)) 35%, var(--borda)); transform: translateX(2px); }
.hero-item-img { width: 88px; height: 72px; border-radius: var(--radius); overflow: hidden; flex-shrink: 0; background: var(--fundo); }
.hero-item-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hero-item-txt { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .3rem; }
.seg-pill { display: inline-flex; align-items: center; gap: .35rem; font-size: .66rem; font-weight: 800; text-transform: uppercase; letter-spacing: .5px; color: var(--seg, var(--vermelho)); }
.seg-pill .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--seg, var(--vermelho)); flex-shrink: 0; }
.hero-item-txt h3 { font-size: .88rem; font-weight: 700; color: var(--titulo); line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.hero-item-txt .ltime { font-size: .72rem; color: var(--texto-suave); display: flex; align-items: center; gap: .3rem; margin-top: auto; }

/* Seções por editoria */
.home-secao { margin-bottom: 3rem; }
.secao-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: .85rem; margin-bottom: 1.4rem; border-bottom: 1px solid var(--borda); }
.secao-head h2 { font-size: 1.3rem; font-weight: 800; color: var(--titulo); letter-spacing: -.4px; display: flex; align-items: center; gap: .7rem; }
.secao-head h2::before { content: ''; width: 14px; height: 14px; border-radius: 4px; background: var(--seg, var(--vermelho)); flex-shrink: 0; }
.ver-todos { font-size: .82rem; font-weight: 700; color: var(--texto-suave); display: inline-flex; align-items: center; gap: .35rem; white-space: nowrap; transition: color var(--transition); }
.ver-todos:hover { color: var(--vermelho); }

@media (max-width: 960px) { .home-hero { grid-template-columns: 1fr; } .hero-lista { flex-direction: row; flex-wrap: wrap; } .hero-item { flex: 1 1 calc(50% - .4rem); } }
@media (max-width: 600px) { .hero-item { flex: 1 1 100%; } .hero-glass h2 { font-size: 1.25rem; } }

/* ---------- Colunistas: dashboard ---------- */
.col-page-head { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; padding: 2rem 0 1.6rem; }
.col-page-titulo { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; color: var(--titulo); letter-spacing: -1px; }
.col-page-sub { font-size: .88rem; color: var(--texto-suave); margin-top: .2rem; }

/* Busca */
.col-busca-field { display: flex; align-items: center; gap: .6rem; border: 2px solid var(--borda); border-radius: 100px; background: #fff; padding: .55rem 1.1rem; box-shadow: var(--sombra); transition: border-color var(--transition); min-width: 240px; }
.col-busca-field:focus-within { border-color: var(--vermelho); }
.col-busca-field i { color: var(--texto-suave); flex-shrink: 0; }
.col-busca-field input { border: 0; outline: none; font-size: .92rem; font-family: var(--fonte); background: transparent; color: var(--tinta); width: 100%; }

.col-busca-result { padding: .5rem 0 2rem; }
.col-busca-info { font-size: .82rem; color: var(--texto-suave); margin-bottom: .8rem; }
.col-busca-lista { display: flex; flex-direction: column; gap: .4rem; }

/* Strip de métricas */
.col-metricas { display: grid; grid-template-columns: repeat(3, 1fr) 1.6fr; gap: 1rem; margin-bottom: 1.4rem; }
.col-metrica { background: #fff; border: 1px solid var(--borda); border-radius: var(--radius-lg); padding: 1.2rem 1.4rem; box-shadow: var(--sombra); display: flex; flex-direction: column; gap: .25rem; }
.col-metrica-n { font-size: 2rem; font-weight: 800; color: var(--titulo); letter-spacing: -1px; line-height: 1; }
.col-metrica-label { font-size: .75rem; color: var(--texto-suave); font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.col-metrica--destaque { flex-direction: row; align-items: center; gap: 1rem; background: var(--preto); border-color: var(--preto); text-decoration: none; transition: var(--transition); }
.col-metrica--destaque:hover { transform: translateY(-2px); box-shadow: var(--sombra-hover); }
.col-metrica--destaque::before { content: ''; position: absolute; inset: 0; border-radius: inherit; } /* garante area clicável */
.col-metrica-dest-foto { width: 44px; height: 44px; border-radius: 50%; overflow: hidden; flex-shrink: 0; border: 2px solid var(--seg, var(--vermelho)); }
.col-metrica-dest-foto img { width: 100%; height: 100%; object-fit: cover; display: block; }
.col-metrica-dest-label { font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--seg, var(--vermelho)); margin-bottom: .15rem; }
.col-metrica-dest-nome { font-size: .92rem; font-weight: 800; color: #fff; line-height: 1.2; }
.col-metrica-dest-n { font-size: .75rem; color: rgba(255,255,255,.55); margin-top: .15rem; }

/* Dashboard: lado a lado */
.col-dashboard { display: grid; grid-template-columns: 340px 1fr; gap: 1.4rem; align-items: start; margin-bottom: 3rem; }

/* Painel genérico */
.col-painel { background: #fff; border: 1px solid var(--borda); border-radius: var(--radius-lg); box-shadow: var(--sombra); overflow: hidden; display: flex; flex-direction: column; }
.col-painel-head { display: flex; align-items: center; gap: .9rem; padding: 1.1rem 1.3rem; border-bottom: 1px solid var(--borda); background: var(--fundo); flex-shrink: 0; }
.col-painel-icon { width: 36px; height: 36px; border-radius: 10px; background: #f5a623; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1rem; flex-shrink: 0; }
.col-painel-icon--red { background: var(--vermelho); }
.col-painel-titulo { font-size: .95rem; font-weight: 800; color: var(--titulo); }
.col-painel-sub { font-size: .72rem; color: var(--texto-suave); margin-top: .1rem; }
.col-painel-body { overflow-y: auto; max-height: 600px; padding: .7rem; display: flex; flex-direction: column; gap: .35rem; scrollbar-width: thin; scrollbar-color: var(--borda) transparent; }
.col-painel-body::-webkit-scrollbar { width: 4px; }
.col-painel-body::-webkit-scrollbar-thumb { background: var(--borda); border-radius: 4px; }

/* Itens do ranking */
.col-rank-item { display: flex; align-items: center; gap: .75rem; padding: .6rem .75rem; border-radius: var(--radius); transition: var(--transition); cursor: pointer; }
.col-rank-item:hover { background: var(--fundo); transform: translateX(3px); }
.col-rank-pos { width: 24px; text-align: center; font-size: .78rem; font-weight: 800; color: var(--texto-suave); flex-shrink: 0; }
.col-rank-pos.is-top { font-size: 1rem; }
.col-rank-foto { width: 36px; height: 36px; border-radius: 50%; overflow: hidden; flex-shrink: 0; }
.col-rank-foto img { width: 100%; height: 100%; object-fit: cover; display: block; }
.col-rank-inicial { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: var(--seg, var(--vermelho)); color: #fff; font-size: .9rem; font-weight: 800; border-radius: 50%; }
.col-rank-info { flex: 1; min-width: 0; }
.col-rank-nome { font-size: .85rem; font-weight: 700; color: var(--titulo); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.col-rank-seg { font-size: .63rem; font-weight: 700; color: var(--seg, var(--vermelho)); text-transform: uppercase; letter-spacing: .4px; margin: .1rem 0 .28rem; }
.col-rank-barra-wrap { height: 4px; background: var(--borda); border-radius: 2px; overflow: hidden; }
.col-rank-barra { height: 100%; width: calc(var(--pct, 0) * 1%); background: var(--seg, var(--vermelho)); border-radius: 2px; }
.col-rank-n { font-size: 1rem; font-weight: 800; color: var(--titulo); flex-shrink: 0; min-width: 28px; text-align: right; }
.col-rank-n small { font-size: .62rem; color: var(--texto-suave); font-weight: 500; }

/* Painel de segmentos: grid interno com scroll */
.col-painel--segs .col-painel-body { max-height: none; overflow: visible; }
.col-segs-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .9rem; padding: .9rem; }

/* Card de segmento */
.col-seg-card { border: 1px solid var(--borda); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; border-top: 3px solid var(--seg, var(--vermelho)); }
.col-seg-head { display: flex; align-items: center; gap: .4rem; padding: .7rem .9rem; background: color-mix(in srgb, var(--seg, var(--vermelho)) 7%, #fff); border-bottom: 1px solid var(--borda); }
.col-seg-dot { width: 8px; height: 8px; border-radius: 2px; background: var(--seg, var(--vermelho)); flex-shrink: 0; }
.col-seg-head strong { font-size: .72rem; font-weight: 800; color: var(--titulo); text-transform: uppercase; letter-spacing: .5px; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.col-seg-link { color: var(--texto-suave); font-size: .8rem; transition: color var(--transition); flex-shrink: 0; }
.col-seg-link:hover { color: var(--seg, var(--vermelho)); }
.col-seg-lista { list-style: none; padding: .5rem .7rem .6rem; display: flex; flex-direction: column; gap: .5rem; }
.col-seg-item { display: flex; align-items: center; gap: .5rem; transition: var(--transition); border-radius: 6px; padding: .25rem .3rem; }
.col-seg-item:hover { background: var(--fundo); }
.col-seg-pos { width: 14px; font-size: .65rem; font-weight: 800; color: var(--texto-suave); flex-shrink: 0; text-align: center; }
.col-seg-foto { width: 28px; height: 28px; border-radius: 50%; overflow: hidden; flex-shrink: 0; }
.col-seg-foto img { width: 100%; height: 100%; object-fit: cover; display: block; }
.col-seg-inicial { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: var(--seg, var(--vermelho)); color: #fff; font-size: .7rem; font-weight: 800; border-radius: 50%; }
.col-seg-info { flex: 1; min-width: 0; }
.col-seg-nome { font-size: .75rem; font-weight: 700; color: var(--titulo); display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: .18rem; }
.col-seg-bar-wrap { height: 3px; background: var(--borda); border-radius: 2px; overflow: hidden; }
.col-seg-bar { height: 100%; width: calc(var(--pct, 0) * 1%); background: var(--seg, var(--vermelho)); border-radius: 2px; }
.col-seg-n { font-size: .8rem; font-weight: 800; color: var(--titulo); flex-shrink: 0; }

@media (max-width: 1024px) { .col-dashboard { grid-template-columns: 1fr; } .col-painel-body { max-height: 400px; } .col-metricas { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .col-segs-grid { grid-template-columns: 1fr; } .col-page-head { flex-direction: column; align-items: flex-start; } .col-busca-field { width: 100%; } .col-metricas { grid-template-columns: 1fr 1fr; } }

/* ---------- Busca: landing (sem query) ---------- */
.busca-landing { text-align: center; padding: 4rem 1rem 3rem; max-width: 720px; margin: 0 auto; }
.busca-kicker { font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: 1.2px; color: var(--vermelho); margin-bottom: .8rem; }
.busca-landing-h1 { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 800; color: var(--titulo); letter-spacing: -1px; margin-bottom: .6rem; line-height: 1.1; }
.busca-landing-sub { color: var(--texto-suave); font-size: 1rem; margin-bottom: 2rem; }
.busca-editorias { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: flex-start; margin-top: 1.8rem; }
.busca-editorias--center { justify-content: center; margin-top: 1.4rem; }
.busca-editorias-label { font-size: .78rem; font-weight: 700; color: var(--texto-suave); text-transform: uppercase; letter-spacing: .5px; align-self: center; white-space: nowrap; }
.busca-pill { display: inline-flex; align-items: center; gap: .4rem; font-size: .82rem; font-weight: 600; color: var(--tinta); border: 1.5px solid var(--borda); background: #fff; padding: .4rem .9rem; border-radius: 100px; transition: var(--transition); }
.busca-pill .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--seg, var(--vermelho)); flex-shrink: 0; }
.busca-pill:hover { border-color: var(--seg, var(--vermelho)); color: var(--seg, var(--vermelho)); background: color-mix(in srgb, var(--seg, var(--vermelho)) 7%, #fff); }

/* ---------- Busca: topo compacto (com query) ---------- */
.busca-topo { display: flex; align-items: center; flex-wrap: wrap; gap: 1rem; padding: 1.8rem 0 1.4rem; border-bottom: 1px solid var(--borda); margin-bottom: 1.8rem; }
.busca-topo .busca-form { flex: 1; min-width: 260px; max-width: 480px; }
.busca-count { font-size: .9rem; color: var(--texto-suave); margin: 0; }
.busca-count strong { color: var(--titulo); }

/* ---------- Campo de busca (compartilhado) ---------- */
.busca-form { max-width: 640px; }
.busca-field { display: flex; border: 2px solid var(--borda); border-radius: 100px; background: #fff; box-shadow: var(--sombra); overflow: hidden; transition: border-color var(--transition); }
.busca-field:focus-within { border-color: var(--vermelho); box-shadow: 0 0 0 3px color-mix(in srgb, var(--vermelho) 14%, transparent), var(--sombra); }
.busca-field input { flex: 1; border: 0; padding: .75rem 1.3rem; font-size: 1rem; font-family: var(--fonte); background: transparent; color: var(--tinta); outline: none; min-width: 0; }
.busca-field--lg input { padding: 1rem 1.5rem; font-size: 1.1rem; }
.busca-field button { background: var(--vermelho); border: 0; padding: 0 1.3rem; color: #fff; font-size: 1rem; font-family: var(--fonte); font-weight: 700; cursor: pointer; transition: background var(--transition); flex-shrink: 0; display: inline-flex; align-items: center; gap: .4rem; }
.busca-field button:hover { background: var(--vermelho-dark); }

/* ---------- Sem resultados ---------- */
.busca-vazio { text-align: center; padding: 4rem 0 2rem; }
.busca-vazio p { color: var(--texto-suave); font-size: 1rem; margin: .6rem 0 0; }
.busca-vazio p.sub { font-size: .88rem; margin-top: .3rem; }

/* ---------- Hero do segmento ---------- */
.seg-hero { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; background: #fff; border: 1px solid var(--borda); border-radius: var(--radius-lg); padding: 2rem; box-shadow: var(--sombra); margin: 1.2rem 0 2rem; position: relative; overflow: hidden; }
.seg-hero::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 5px; background: var(--seg, var(--vermelho)); }
.seg-hero h1 { font-size: clamp(1.6rem, 3vw, 2.4rem); font-weight: 800; color: var(--titulo); letter-spacing: -.8px; }
.seg-hero .contador { font-size: .88rem; color: var(--texto-suave); white-space: nowrap; }

/* ---------- Paginação ---------- */
.paginacao { display: flex; align-items: center; justify-content: center; gap: 1rem; padding: 2.8rem 0 .5rem; flex-wrap: wrap; }
.paginacao a { display: inline-flex; align-items: center; gap: .4rem; font-weight: 700; font-size: .9rem; color: var(--vermelho); border: 1.5px solid var(--borda); padding: .55rem 1.2rem; border-radius: 100px; transition: var(--transition); }
.paginacao a:hover { background: var(--vermelho); color: #fff; border-color: var(--vermelho); }
.paginacao .pag-info { font-size: .88rem; color: var(--texto-suave); }

/* ---------- Footer ---------- */
.blog-footer { background: var(--preto); color: #b8b2ac; padding: 3.4rem 0 2.4rem; margin-top: 4rem; font-size: .9rem; }
.blog-footer a { color: #b8b2ac; }
.blog-footer a:hover { color: var(--vermelho); }
.blog-footer .logo img { height: 36px; width: auto; }
.blog-footer h6 { color: #fff; font-weight: 700; margin-bottom: 1rem; font-size: .82rem; text-transform: uppercase; letter-spacing: .8px; }
.blog-footer .row > div > div { margin-bottom: .5rem; }

/* ================================================================
   Materiais Educativos
   ================================================================ */
.mat-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1.8rem; }
.mat-titulo { font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 800; color: var(--titulo); letter-spacing: -.8px; margin: 0; }
.mat-sub { color: var(--texto-suave); font-size: .95rem; margin: .3rem 0 0; }

.mat-filtros { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; margin-bottom: 2rem; padding-bottom: 1.2rem; border-bottom: 1.5px solid var(--borda); }
.mat-pill { display: inline-flex; align-items: center; gap: .4rem; border: 1.5px solid var(--borda); background: var(--branco); color: var(--texto); font-size: .85rem; font-weight: 600; padding: .4rem 1rem; border-radius: 100px; cursor: pointer; transition: var(--transition); font-family: inherit; }
.mat-pill:hover { border-color: var(--vermelho); color: var(--vermelho); }
.mat-pill.is-active { background: var(--vermelho); border-color: var(--vermelho); color: #fff; }
.mat-pill-n { background: rgba(0,0,0,.1); border-radius: 100px; padding: .05rem .45rem; font-size: .78rem; }
.mat-pill.is-active .mat-pill-n { background: rgba(255,255,255,.25); }

.mat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1.4rem; }
.mat-card { display: flex; flex-direction: column; background: var(--branco); border-radius: var(--radius-lg); border: 1.5px solid var(--borda); overflow: hidden; text-decoration: none; color: inherit; transition: var(--transition); }
.mat-card:hover { box-shadow: var(--sombra-hover); border-color: var(--seg, var(--vermelho)); transform: translateY(-3px); }
.mat-card-img { aspect-ratio: 16/9; overflow: hidden; background: var(--fundo); }
.mat-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.mat-card:hover .mat-card-img img { transform: scale(1.04); }
.mat-card-body { display: flex; flex-direction: column; flex: 1; padding: 1.1rem 1.2rem 1.2rem; gap: .4rem; }
.mat-badge { display: inline-block; font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--seg, var(--vermelho)); border: 1.5px solid currentColor; border-radius: 100px; padding: .12rem .65rem; width: max-content; }
.mat-card-body h3 { font-size: .97rem; font-weight: 700; color: var(--titulo); line-height: 1.35; margin: 0; flex: 1; }
.mat-card-body p { font-size: .83rem; color: var(--texto-suave); line-height: 1.45; margin: 0; }
.mat-cta { margin-top: auto; padding-top: .8rem; font-size: .82rem; font-weight: 700; color: var(--seg, var(--vermelho)); display: flex; align-items: center; gap: .3rem; }
.mat-vazio { display: flex; flex-direction: column; align-items: center; gap: .8rem; padding: 5rem 1rem; color: var(--texto-suave); text-align: center; }
.mat-vazio p { margin: 0; }

/* ================================================================
   VoittoCast
   ================================================================ */
.vc-hero { display: flex; align-items: center; gap: 1.4rem; margin-bottom: 2rem; padding: 2rem 2rem; background: var(--preto); border-radius: var(--radius-lg); color: #fff; }
.vc-hero-icon { width: 60px; height: 60px; background: var(--vermelho); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; flex-shrink: 0; }
.vc-hero h1 { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; letter-spacing: -.6px; margin: 0; }
.vc-hero p { margin: .3rem 0 0; color: #b8b2ac; font-size: .9rem; }

.vc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.4rem; margin-top: 1rem; }
.vc-card { display: flex; flex-direction: column; background: var(--branco); border-radius: var(--radius-lg); border: 1.5px solid var(--borda); overflow: hidden; text-decoration: none; color: inherit; transition: var(--transition); }
.vc-card:hover { box-shadow: var(--sombra-hover); border-color: var(--vermelho); transform: translateY(-3px); }
.vc-card-img { position: relative; aspect-ratio: 1/1; overflow: hidden; background: var(--fundo); }
.vc-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.vc-card:hover .vc-card-img img { transform: scale(1.04); }
.vc-card-no-img { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 2.5rem; color: var(--borda); background: var(--fundo); }
.vc-ep-num { position: absolute; bottom: .5rem; left: .5rem; background: rgba(0,0,0,.65); color: #fff; font-size: .72rem; font-weight: 700; padding: .15rem .5rem; border-radius: 100px; }
.vc-card-body { display: flex; flex-direction: column; flex: 1; padding: 1rem 1.1rem 1.1rem; gap: .35rem; }
.vc-badge { display: inline-block; font-size: .71rem; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--vermelho); border: 1.5px solid var(--vermelho); border-radius: 100px; padding: .1rem .6rem; width: max-content; }
.vc-card-body h3 { font-size: .93rem; font-weight: 700; color: var(--titulo); line-height: 1.35; margin: 0; flex: 1; }
.vc-card-body p { font-size: .82rem; color: var(--texto-suave); line-height: 1.4; margin: 0; }
.vc-meta { display: flex; align-items: center; gap: .8rem; flex-wrap: wrap; margin-top: auto; padding-top: .7rem; font-size: .78rem; color: var(--texto-suave); }
.vc-spotify { color: #1db954; font-weight: 700; display: flex; align-items: center; gap: .25rem; margin-left: auto; }

/* ---------- Responsivo ---------- */
@media (max-width: 1100px) {
  .artigo-grid { grid-template-columns: minmax(0,1fr); gap: 0; }
  .artigo-col-esq, .artigo-col-dir { display: none; }
  .artigo-main { max-width: 720px; margin: 0 auto; }
}
@media (max-width: 600px) {
  body { font-size: 16px; }
  .artigo-conteudo { font-size: 1.06rem; }
  .rel-grid { grid-template-columns: 1fr; }
  .artigo-conteudo > p:first-of-type::first-letter { font-size: 3rem; }
}
