/*
Theme Name: SmartMag Child
Theme URI: https://smartmag.theme-sphere.com/
Description: INFOCO 2.0 - CNN Breaking News Experience
Author: HostingPRESS Analytics Network
Author URI: https://hostingpress.com.br
Template: smart-mag
Version: 2.0
*/

/* ============================================================
   INFOCO 2.0 — Custom CSS
   SmartMag Child Theme | HostingPRESS Analytics Network
   ============================================================ */

/* === 1. VARIÁVEIS CSS === */
:root {
  --infoco-red:     #C8102E;
  --infoco-black:   #111111;
  --infoco-dark-bg: #0D0D0D;
  --infoco-gray-bg: #F5F5F5;
  --infoco-text:    #1A1A1A;
  --infoco-muted:   #666666;
  --infoco-border:  #E5E5E5;
  --infoco-radius:  4px;
  --infoco-shadow:  0 2px 8px rgba(0,0,0,0.08);
}

/* === 2. TOP BAR === */
.bunyad-top-bar {
  background: var(--infoco-black) !important;
  color: #ccc;
  font-size: 13px;
  min-height: 36px;
}
.bunyad-top-bar a { color: #aaa !important; }
.bunyad-top-bar a:hover { color: #fff !important; }
.bunyad-top-bar .social-nav a { color: #bbb !important; }

/* === 3. MEGA MENU (fundo vermelho MS) === */
.site-nav,
#site-nav,
.ts-site-nav,
nav.navigation-wrap,
.nav-wrap {
  background: var(--infoco-red) !important;
}
.site-nav > ul > li > a,
#site-nav > ul > li > a,
.ts-site-nav > ul > li > a {
  color: #fff !important;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: 0.3px;
}
.site-nav > ul > li:hover > a,
.site-nav > ul > li.current-menu-item > a,
.site-nav > ul > li.current-menu-ancestor > a {
  background: rgba(0,0,0,0.2) !important;
  color: #fff !important;
}
.site-nav .sub-menu {
  background: #fff;
  border-top: 3px solid var(--infoco-red);
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
}
.site-nav .sub-menu a {
  color: var(--infoco-text) !important;
  font-size: 13px;
}
.site-nav .sub-menu a:hover {
  color: var(--infoco-red) !important;
  background: var(--infoco-gray-bg);
}

/* === 4. BREAKING NEWS TICKER === */
.ts-ticker,
.bunyad-ticker,
.ticker-wrap {
  background: var(--infoco-red) !important;
  min-height: 42px;
  display: flex;
  align-items: center;
}
.ticker-label,
.bunyad-ticker-label,
.ts-ticker-label {
  background: #000 !important;
  color: #fff !important;
  font-weight: 800;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 4px 14px !important;
  white-space: nowrap;
}
.ticker-item a,
.ts-ticker-item a,
.bunyad-ticker-item a {
  color: #fff !important;
  font-size: 14px;
}

/* === 5. CATEGORY BADGE COLORS === */
.cat-label { border-radius: 3px; font-size: 11px; font-weight: 700; text-transform: uppercase; padding: 2px 8px; }

.cat-policia .cat-label,
.cat-label.cat-policia,
[class*="cat-policia"] .cat-label,
.category-policia .cat-label           { background: #D32F2F !important; color: #fff !important; }

.cat-politica .cat-label,
.cat-label.cat-politica,
[class*="cat-politica"] .cat-label,
.category-politica .cat-label          { background: #1565C0 !important; color: #fff !important; }

.cat-saude .cat-label,
[class*="cat-saude"] .cat-label,
.category-saude .cat-label             { background: #2E7D32 !important; color: #fff !important; }

.cat-economia .cat-label,
[class*="cat-economia"] .cat-label,
.category-economia .cat-label          { background: #E65100 !important; color: #fff !important; }

.cat-esportes .cat-label,
[class*="cat-esportes"] .cat-label,
.category-esportes .cat-label          { background: #4527A0 !important; color: #fff !important; }

.cat-educacao .cat-label,
[class*="cat-educacao"] .cat-label,
.category-educacao .cat-label          { background: #00695C !important; color: #fff !important; }

.cat-governo .cat-label,
[class*="cat-governo"] .cat-label,
.category-governo .cat-label           { background: #4E342E !important; color: #fff !important; }

.cat-brasil .cat-label,
[class*="cat-brasil"] .cat-label,
.category-brasil .cat-label            { background: #0D47A1 !important; color: #fff !important; }

.cat-meio-ambiente .cat-label,
[class*="cat-meio-ambiente"] .cat-label { background: #558B2F !important; color: #fff !important; }

.cat-campo-grande .cat-label,
[class*="cat-campo-grande"] .cat-label { background: var(--infoco-red) !important; color: #fff !important; }

/* === 6. SEÇÕES EDITORIAIS — HEADING === */
.block-heading .title-wrap,
.posts-block-heading,
.sc-heading .title,
.bunyad-block-heading {
  border-left: 4px solid var(--infoco-red) !important;
  padding-left: 12px !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.block-heading .title-wrap::after,
.posts-block-heading::after { display: none; }

/* === 7. ARTIGO — TIPOGRAFIA === */
.single-post .entry-content {
  font-size: 17px;
  line-height: 1.75;
  color: var(--infoco-text);
}
.single-post .entry-content p { margin-bottom: 24px; }
.single-post .entry-content a {
  color: var(--infoco-red);
  text-decoration: none;
}
.single-post .entry-content a:hover { text-decoration: underline; }
.single-post .entry-content blockquote {
  border-left: 4px solid var(--infoco-red);
  padding: 16px 20px;
  background: #F9F9F9;
  font-style: italic;
  margin: 24px 0;
  border-radius: 0 var(--infoco-radius) var(--infoco-radius) 0;
}
.single-post .entry-content h2,
.single-post .entry-content h3 {
  color: var(--infoco-black);
  font-weight: 700;
  margin: 32px 0 16px;
}

/* === 8. BARRA DE PROGRESSO DE LEITURA === */
#reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: var(--infoco-red);
  z-index: 99999;
  transition: width 0.1s linear;
}

/* === 9. SHARE FLUTUANTE LATERAL === */
.float-share-wrap {
  position: sticky;
  top: 100px;
  float: left;
  width: 44px;
  margin-left: -60px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.float-share-wrap a {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  color: #fff;
  transition: transform 0.2s;
}
.float-share-wrap a:hover { transform: scale(1.1); }

/* === 10. FOOTER DARK === */
.site-footer,
.site-footer-main,
#colophon,
footer.site-footer {
  background: var(--infoco-dark-bg) !important;
  color: #aaa;
}
.footer-widget-title,
.site-footer h4,
.site-footer .widget-title {
  color: #fff !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  margin-bottom: 16px !important;
  border-bottom: 1px solid #222 !important;
  padding-bottom: 10px !important;
}
.site-footer a,
.site-footer-main a { color: #888 !important; }
.site-footer a:hover,
.site-footer-main a:hover { color: #fff !important; }
.site-footer ul li { margin-bottom: 6px; }

.footer-bottom,
.site-footer-bottom,
.copyright-bar {
  background: #060606 !important;
  color: #555 !important;
  font-size: 12px;
  border-top: 1px solid #1a1a1a;
}
.footer-bottom a,
.site-footer-bottom a { color: #666 !important; }
.footer-bottom a:hover,
.site-footer-bottom a:hover { color: #C8102E !important; }

/* Footer social icons */
.site-footer .social-nav a {
  background: #333 !important;
  color: #aaa !important;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 2px;
  transition: background 0.2s;
}
.site-footer .social-nav a:hover {
  background: var(--infoco-red) !important;
  color: #fff !important;
}

/* === 11. MOBILE SHARE BAR === */
.mobile-share-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 50px;
  background: #fff;
  border-top: 1px solid #eee;
  display: flex;
  justify-content: space-around;
  align-items: center;
  z-index: 9999;
  box-shadow: 0 -2px 8px rgba(0,0,0,0.1);
}
.mobile-share-bar a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
}

/* === 12. FAIXA ÚLTIMAS DE MS === */
.ultimas-ms-bar {
  background: #F0F0F0;
  border-top: 3px solid var(--infoco-red);
  border-bottom: 1px solid #ddd;
  padding: 10px 0;
}
.ultimas-ms-bar .bar-label {
  font-weight: 800;
  font-size: 12px;
  text-transform: uppercase;
  color: var(--infoco-red);
  white-space: nowrap;
  letter-spacing: 1px;
}
.ultimas-ms-bar .bar-items { display: flex; gap: 16px; flex-wrap: nowrap; overflow: hidden; }
.ultimas-ms-bar .bar-item a { font-size: 13px; color: var(--infoco-text); font-weight: 500; }
.ultimas-ms-bar .bar-item a:hover { color: var(--infoco-red); }
.ultimas-ms-bar .bar-sep { color: #bbb; }

/* === 13. SIDEBAR === */
.sidebar-widget,
.widget { margin-bottom: 28px !important; }
.sidebar-widget-title,
.widget-title {
  font-size: 15px !important;
  font-weight: 700 !important;
  border-bottom: 2px solid var(--infoco-red) !important;
  padding-bottom: 8px !important;
  margin-bottom: 16px !important;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* === 14. CARDS E POSTS === */
.post-item,
.ts-article,
.bunyad-block .article {
  border-radius: var(--infoco-radius);
  overflow: hidden;
  box-shadow: var(--infoco-shadow);
  transition: box-shadow 0.2s;
}
.post-item:hover,
.ts-article:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
}

/* Tags no artigo */
.post-tags a, .tags-list a {
  background: #eee;
  color: #555;
  padding: 3px 10px;
  border-radius: 3px;
  font-size: 12px;
  text-decoration: none;
  display: inline-block;
  margin: 2px;
  transition: background 0.2s, color 0.2s;
}
.post-tags a:hover, .tags-list a:hover {
  background: var(--infoco-red);
  color: #fff;
}

/* Author box */
.author-box {
  background: var(--infoco-gray-bg) !important;
  border-radius: 8px;
  padding: 20px !important;
  margin: 30px 0 !important;
}
.author-box .author-avatar img {
  border-radius: 50%;
  width: 80px !important;
  height: 80px !important;
  object-fit: cover;
}
.author-box .author-name { font-weight: 700; font-size: 16px; }

/* Paginação */
.page-numbers { border-radius: var(--infoco-radius) !important; }
.page-numbers.current,
.page-numbers:hover {
  background: var(--infoco-red) !important;
  color: #fff !important;
  border-color: var(--infoco-red) !important;
}

/* === 15. HEADER STICKY === */
.site-header.is-sticky,
.site-header.sticky-active,
.sticky-header {
  box-shadow: 0 2px 12px rgba(0,0,0,0.15) !important;
}

/* === 16. CIDADE SECTIONS === */
.cidade-section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  border-left: 4px solid var(--infoco-red);
  padding-left: 12px;
}
.cidade-section-header h2 {
  font-size: 18px;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--infoco-red);
  margin: 0;
}

/* === 17. MOBILE === */
@media (max-width: 767px) {
  .bunyad-top-bar { display: none !important; }
  .float-share-wrap { display: none !important; }

  .single-post .entry-content { font-size: 16px !important; }

  .site-header { height: 54px; }

  /* Hero mobile */
  .ts-feat-grid .first-item,
  .feat-grid-main { width: 100% !important; float: none !important; }

  .ts-feat-grid .second-wrap,
  .feat-grid-secondary { width: 100% !important; float: none !important; }

  /* Posts row de 4 vira 2 colunas */
  .ts-feat-grid .bottom-items,
  .feat-grid-small-row { 
    grid-template-columns: repeat(2, 1fr) !important; 
  }

  .sidebar { margin-top: 40px; }
}

@media (max-width: 480px) {
  .block-heading .title-wrap,
  .posts-block-heading { font-size: 15px !important; }
}

@media (min-width: 1200px) {
  .float-share-wrap { display: flex; }
}


/* ============================================================
   SPRINT 3 — NOVA HOME INFOCO 2.0
   ============================================================ */

/* ---- HERO SECTION ----------------------------------------- */
.infoco-hero-section { margin-bottom: 32px; }

.infoco-hero-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  grid-template-rows: auto auto;
  gap: 12px;
}

.infoco-hero-main {
  grid-column: 1;
  grid-row: 1 / 3;
}

.infoco-hero-secondary {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.infoco-hero-small {
  grid-column: 1 / 3;
  grid-row: 3;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  background: #f8f8f8;
  padding: 10px 12px;
  border-top: 3px solid var(--infoco-red);
  margin-top: 4px;
}

.infoco-hero-main .l-post .media { overflow: hidden; border-radius: 4px; max-height: 380px; }
.infoco-hero-main .l-post .media img { width: 100%; height: 380px; object-fit: cover; }
.infoco-hero-main .post-title { font-size: 22px; font-weight: 700; line-height: 1.3; margin-top: 8px; }
.infoco-hero-main .post-title a { color: var(--infoco-text); }
.infoco-hero-main .post-title a:hover { color: var(--infoco-red); }

.infoco-hero-secondary .l-post { display: flex; gap: 10px; align-items: flex-start; }
.infoco-hero-secondary .l-post .media { flex: 0 0 110px; max-height: 75px; overflow: hidden; border-radius: 3px; }
.infoco-hero-secondary .l-post .media img { width: 110px; height: 75px; object-fit: cover; }
.infoco-hero-secondary .l-post .content { flex: 1; }
.infoco-hero-secondary .post-title { font-size: 14px; font-weight: 600; line-height: 1.4; margin: 4px 0 0; }
.infoco-hero-secondary .post-title a { color: var(--infoco-text); }

.infoco-hero-small .l-post .media { display: none; }
.infoco-hero-small .post-title { font-size: 13px; font-weight: 600; line-height: 1.4; margin: 4px 0 0; }
.infoco-hero-small .post-title a { color: var(--infoco-text); }
.infoco-hero-small .post-title a:hover { color: var(--infoco-red); }
.infoco-hero-small .post-meta { font-size: 11px; color: var(--infoco-muted); display: block; margin-top: 4px; }

/* ---- BLOCK HEAD (shared title + ver tudo) ----------------- */
.block-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--infoco-border);
}
.block-head .block-title {
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--infoco-text);
  border-left: 4px solid var(--infoco-red);
  padding-left: 10px;
  margin: 0;
}
.block-head .block-ver-tudo {
  font-size: 12px;
  color: var(--infoco-red);
  font-weight: 600;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.block-head .block-ver-tudo:hover { text-decoration: underline; }

/* ---- ULTIMAS DE MS STRIP ---------------------------------- */
.infoco-ultimas-ms {
  background: #f0f0f0;
  border-top: 3px solid var(--infoco-red);
  padding: 16px;
  margin-bottom: 28px;
  border-radius: 4px;
}
.infoco-ultimas-strip {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}
.infoco-ultimas-strip .strip-post {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.infoco-ultimas-strip .strip-post .media { overflow: hidden; border-radius: 3px; }
.infoco-ultimas-strip .strip-post .media img { width: 100%; height: 70px; object-fit: cover; }
.infoco-ultimas-strip .strip-post .post-title { font-size: 12px; font-weight: 600; line-height: 1.4; margin: 0; }
.infoco-ultimas-strip .strip-post .post-title a { color: var(--infoco-text); }
.infoco-ultimas-strip .strip-post .post-title a:hover { color: var(--infoco-red); }

/* ---- EDITORIAL BLOCKS ------------------------------------- */
.infoco-editorial {
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--infoco-border);
}
.infoco-editorial .loop { gap: 14px; }
.infoco-editorial .l-post.grid-post { display: flex; flex-direction: column; }
.infoco-editorial .l-post .media { overflow: hidden; border-radius: 4px; margin-bottom: 8px; }
.infoco-editorial .l-post .media img { width: 100%; height: 120px; object-fit: cover; }
.infoco-editorial .post-title { font-size: 14px; font-weight: 600; line-height: 1.4; margin: 0 0 6px; }
.infoco-editorial .post-title a { color: var(--infoco-text); }
.infoco-editorial .post-title a:hover { color: var(--infoco-red); }
.infoco-editorial .post-meta { font-size: 11px; color: var(--infoco-muted); }

/* grid-4 utility for editorial blocks */
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }

/* ---- CAT LABELS ------------------------------------------- */
.cat-label {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 2px 7px;
  border-radius: 3px;
  color: #fff;
  background: var(--infoco-red);
  margin-bottom: 5px;
}

/* ---- MOBILE: SPRINT 3 ------------------------------------- */
@media (max-width: 767px) {
  .infoco-hero-grid {
    grid-template-columns: 1fr;
  }
  .infoco-hero-main { grid-row: 1; }
  .infoco-hero-secondary { grid-column: 1; grid-row: 2; }
  .infoco-hero-small { grid-template-columns: repeat(2, 1fr); grid-column: 1; grid-row: 3; }
  .infoco-ultimas-strip { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================
   SPRINT 3.6 — Audiência, Retenção e Monetização
   INFOCO 2.0 | version 2.2
   ============================================ */

/* --- STORIES BAR --- */
.infoco-stories-bar {
  background: #fff;
  border-bottom: 1px solid var(--infoco-border, #e5e5e5);
  padding: 10px 0;
  overflow: hidden;
}
.stories-inner {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 4px 0;
  justify-content: flex-start;
}
.stories-inner::-webkit-scrollbar { display: none; }
.story-item { flex: 0 0 auto; text-align: center; }
.story-item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  text-decoration: none;
  color: #1a1a1a;
  font-size: 11px;
  font-weight: 600;
}
.story-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  border: 2.5px solid var(--infoco-red, #C8102E);
  font-size: 22px;
  background: #f8f8f8;
  transition: border-color 0.2s, transform 0.2s;
}
.story-item a:hover .story-circle {
  border-color: #900d21;
  transform: scale(1.08);
}
.story-live {
  border-color: #C8102E;
  animation: pulse-border 1.5s infinite;
}
@keyframes pulse-border {
  0%,100% { box-shadow: 0 0 0 0 rgba(200,16,46,0.4); }
  50%      { box-shadow: 0 0 0 5px rgba(200,16,46,0); }
}
.story-label {
  max-width: 60px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 10px;
  color: #444;
}

/* --- AD SLOTS --- */
.infoco-ad-slot {
  text-align: center;
  margin: 16px 0;
  min-height: 32px;
  overflow: hidden;
}
.infoco-ad-slot:empty { display: none; }
.infoco-ad-top { background: #f9f9f9; padding: 8px 0; border-bottom: 1px solid #eee; }
.infoco-ad-large { padding: 12px 0; }
.infoco-ad-between { padding: 10px 0; }
.infoco-ad-footer { padding: 14px 0; border-top: 1px solid #eee; margin-top: 8px; }

/* --- TV INFOCO AO VIVO --- */
.infoco-live-tv { margin-bottom: 28px; }
.infoco-live-tv .live-badge {
  display: inline-block;
  background: #C8102E;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 3px;
  letter-spacing: 0.5px;
  animation: blink-badge 1.2s step-end infinite;
}
@keyframes blink-badge {
  0%,100% { opacity: 1; } 50% { opacity: 0.4; }
}
.live-tv-subtitle {
  font-size: 13px;
  color: #555;
  margin: 6px 0 12px;
}
.live-tv-player {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9 */
  background: #0a0a0a;
  border: 2px solid #C8102E;
  border-radius: 4px;
  overflow: hidden;
}
.live-tv-player iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  border: none;
}
.live-tv-placeholder {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: #aaa;
}
.live-play-icon {
  font-size: 48px;
  color: #C8102E;
  line-height: 1;
}
.live-tv-placeholder p { font-size: 14px; color: #ccc; margin: 0; }
.live-tv-placeholder small { font-size: 11px; color: #666; }
.live-watch-btn {
  display: inline-block;
  background: #C8102E;
  color: #fff !important;
  padding: 8px 20px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  margin-top: 6px;
}
.live-watch-btn:hover { background: #900d21; }

/* --- MUNICÍPIOS EM DESTAQUE --- */
.infoco-municipios-grid { margin-bottom: 28px; }
.municipios-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.municipio-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 14px 10px;
  background: #f7f7f7;
  border: 1px solid #e5e5e5;
  border-radius: 6px;
  text-decoration: none;
  color: #1a1a1a;
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.municipio-card:hover {
  background: var(--infoco-red, #C8102E);
  color: #fff;
  border-color: var(--infoco-red, #C8102E);
}
.municipio-icon { font-size: 22px; line-height: 1; }

/* --- CTA WHATSAPP --- */
.infoco-whatsapp-cta {
  background: linear-gradient(135deg, #075e54 0%, #128c7e 100%);
  border-radius: 8px;
  margin-bottom: 28px;
  padding: 20px 24px;
}
.whatsapp-cta-inner {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.whatsapp-icon-wrap { font-size: 36px; flex-shrink: 0; }
.whatsapp-text { flex: 1; min-width: 200px; }
.whatsapp-text strong { display: block; color: #fff; font-size: 15px; margin-bottom: 4px; }
.whatsapp-text p { color: rgba(255,255,255,0.85); font-size: 13px; margin: 0; }
.whatsapp-btn {
  display: inline-block;
  background: #25d366;
  color: #fff !important;
  padding: 10px 22px;
  border-radius: 25px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.whatsapp-btn:hover { background: #1da851; }

/* --- NEWSLETTER --- */
.infoco-newsletter-box {
  background: #1a1a2e;
  border-radius: 8px;
  padding: 24px;
  margin-bottom: 28px;
}
.newsletter-inner {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.newsletter-icon { font-size: 36px; flex-shrink: 0; }
.newsletter-text { flex: 1; min-width: 200px; }
.newsletter-text strong { display: block; color: #fff; font-size: 15px; margin-bottom: 4px; }
.newsletter-text p { color: rgba(255,255,255,0.7); font-size: 13px; margin: 0; }
.newsletter-form {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.newsletter-input {
  padding: 10px 14px;
  border: none;
  border-radius: 4px;
  font-size: 13px;
  width: 220px;
  outline: none;
}
.newsletter-btn {
  background: var(--infoco-red, #C8102E);
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}
.newsletter-btn:hover { background: #900d21; }

/* --- SIDEBAR MONETIZADA --- */
.infoco-sidebar-ad {
  text-align: center;
  margin: 16px 0;
  min-height: 10px;
}
.infoco-sidebar-ad:empty { display: none; }
.infoco-weather-widget {
  background: linear-gradient(135deg, #0f4c81 0%, #1a73e8 100%);
  border-radius: 8px;
  padding: 16px;
  margin: 16px 0;
  color: #fff;
}
.infoco-weather-widget .widget-title h3 {
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,255,255,0.9);
  margin: 0 0 12px;
  border: none;
  padding: 0;
}
.weather-body { display: flex; align-items: center; gap: 14px; }
.weather-icon-large { font-size: 38px; }
.weather-info { display: flex; flex-direction: column; gap: 2px; }
.weather-info strong { font-size: 14px; }
.weather-temp { font-size: 26px; font-weight: 700; }
.weather-desc { font-size: 11px; color: rgba(255,255,255,0.75); }
.infoco-whatsapp-sidebar {
  display: block;
  background: #25d366;
  color: #fff !important;
  text-align: center;
  padding: 12px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  margin: 16px 0;
}
.infoco-whatsapp-sidebar:hover { background: #1da851; }
.infoco-sidebar-sticky {
  text-align: center;
  margin-top: 16px;
  position: sticky;
  top: 80px;
}

/* --- MOBILE SPRINT 3.6 --- */
@media (max-width: 767px) {
  .infoco-stories-bar { padding: 8px 0; }
  .stories-inner { gap: 10px; padding: 2px 4px; }
  .story-circle { width: 46px; height: 46px; font-size: 18px; }
  .municipios-inner { grid-template-columns: repeat(2, 1fr); }
  .whatsapp-cta-inner { flex-direction: column; text-align: center; }
  .newsletter-inner { flex-direction: column; text-align: center; }
  .newsletter-input { width: 100%; }
  .newsletter-form { width: 100%; flex-direction: column; }
  .newsletter-btn { width: 100%; }
  .infoco-live-tv .live-tv-player { border-width: 1px; }
}


/* ============================================
   SPRINT 3.7 — INFOCO CIDADES Carousel (SwiperJS)
   Substitui .infoco-stories-bar
   version 2.3
   ============================================ */

/* Ocultar barra de stories antiga (substituída pelo carousel) */
.infoco-stories-bar { display: none !important; }

/* --- CAROUSEL CONTAINER --- */
.infoco-cities-carousel {
  background: #fff;
  border-bottom: 2px solid var(--infoco-red, #C8102E);
  padding: 10px 0 14px;
  overflow: hidden;
}

/* --- HEADER LABEL --- */
.cities-carousel-header {
  padding: 0 0 8px;
}
.cities-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  font-weight: 800;
  color: var(--infoco-red, #C8102E);
  text-transform: uppercase;
  letter-spacing: 1.5px;
}

/* --- SWIPER CORE OVERRIDES --- */
.infoco-cities-swiper {
  overflow: hidden;
  padding: 4px 0 2px;
  cursor: grab;
}
.infoco-cities-swiper:active { cursor: grabbing; }
.infoco-cities-swiper .swiper-wrapper {
  align-items: flex-start;
  transition-timing-function: linear !important;
}

/* --- CITY SLIDE --- */
.city-slide {
  width: auto !important;
  flex-shrink: 0;
}

/* --- CITY CARD --- */
.city-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  text-decoration: none !important;
  color: #1a1a1a;
  padding: 4px 8px;
  min-width: 78px;
  max-width: 100px;
  transition: opacity 0.2s;
}
.city-card:hover { opacity: 0.85; }

/* --- CITY CIRCLE --- */
.city-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 2.5px solid var(--infoco-red, #C8102E);
  background: #fff5f5;
  transition: background 0.2s, transform 0.2s, border-color 0.2s;
  flex-shrink: 0;
}
.city-card:hover .city-circle {
  background: #fde8e8;
  border-color: #900d21;
  transform: scale(1.07);
}
.city-circle svg {
  display: block;
  transition: transform 0.2s;
}

/* --- CITY NAME --- */
.city-name {
  font-size: 10px;
  font-weight: 700;
  text-align: center;
  color: #222;
  max-width: 90px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.3;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

/* --- CITY COUNT --- */
.city-count {
  font-size: 9px;
  color: #aaa;
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
}

/* --- MOBILE --- */
@media (max-width: 767px) {
  .infoco-cities-carousel { padding: 8px 0 10px; }
  .city-circle { width: 46px; height: 46px; }
  .city-circle svg { width: 18px; height: 18px; }
  .city-card { min-width: 68px; padding: 3px 5px; }
  .city-name { font-size: 9px; max-width: 72px; }
  .city-count { font-size: 8px; }
}

/* Accessibility: respeitar prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .infoco-cities-swiper .swiper-wrapper {
    transition-duration: 0ms !important;
    animation: none !important;
  }
}

/* ============================================
   SPRINT 4 — CNN Article Experience
   INFOCO 2.0 | version 2.3
   ============================================ */

/* === ARTICLE: HEADER PREMIUM === */

/* Category badge (injetado via JS acima do H1) */
.infoco-cat-badge {
  display: inline-block;
  background: var(--infoco-red, #C8102E);
  color: #fff !important;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  padding: 5px 14px;
  border-radius: 3px;
  margin-bottom: 14px;
  text-decoration: none !important;
  transition: background 0.2s;
}
.infoco-cat-badge:hover { background: #900d21; }

/* H1 título premium */
.single-post h1.post-title,
.single-post h1.is-title {
  font-size: 40px !important;
  font-weight: 800 !important;
  line-height: 1.18 !important;
  letter-spacing: -0.5px;
  color: #080808;
  margin-bottom: 18px;
}

/* Reading time no meta bar */
.infoco-read-time {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  color: #888;
  padding-left: 14px;
  margin-left: 10px;
  border-left: 1px solid #ddd;
}

/* === ARTICLE: TIPOGRAFIA PREMIUM === */
.single-post .post-content,
.single-post .entry-content {
  font-size: 17px;
  line-height: 1.85;
  color: #1a1a1a;
}
.single-post .entry-content p {
  margin-bottom: 22px;
}
.single-post .entry-content h2 {
  font-size: 24px;
  font-weight: 800;
  line-height: 1.3;
  margin: 36px 0 16px;
  padding-left: 14px;
  border-left: 4px solid var(--infoco-red, #C8102E);
  color: #0a0a0a;
}
.single-post .entry-content h3 {
  font-size: 20px;
  font-weight: 700;
  margin: 28px 0 12px;
  color: #111;
}
.single-post .entry-content blockquote {
  border-left: 4px solid var(--infoco-red, #C8102E);
  background: #fafafa;
  margin: 24px 0;
  padding: 18px 20px;
  border-radius: 0 6px 6px 0;
  font-style: italic;
  font-size: 18px;
  color: #333;
}
.single-post .entry-content img {
  border-radius: 6px;
  max-width: 100%;
  height: auto;
}
.single-post .entry-content figure {
  margin: 28px 0;
}
.single-post .entry-content figcaption {
  font-size: 12px;
  color: #888;
  text-align: center;
  margin-top: 8px;
  font-style: italic;
}
.single-post .entry-content a {
  color: var(--infoco-red, #C8102E);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* === PROGRESS BAR PREMIUM === */
#reading-progress {
  position: fixed !important;
  top: 0;
  left: 0;
  height: 3px !important;
  background: var(--infoco-red, #C8102E) !important;
  z-index: 99999 !important;
  transition: width 0.08s linear;
  border-radius: 0 2px 2px 0;
}

/* === SHARE FLUTUANTE PREMIUM (desktop) === */
.single-post .post-share.post-share-b {
  position: sticky;
  top: 80px;
}
@media (min-width: 1024px) {
  .single-post .post-share.post-share-b {
    display: block !important;
  }
}

/* === FEATURED IMAGE === */
.single-post .feat-image img,
.single-post .post-thumbnail img,
.single-post .ts-thumbnail img {
  width: 100%;
  max-height: 480px;
  object-fit: cover;
  border-radius: 8px;
  margin-bottom: 28px;
}

/* === AUTHOR BOX PREMIUM === */
.author-box,
.ts-author-box {
  background: #fff;
  border: 1px solid #ebebeb;
  border-left: 4px solid var(--infoco-red, #C8102E);
  border-radius: 0 8px 8px 0;
  padding: 24px 28px;
  margin: 36px 0;
  display: flex;
  gap: 20px;
  align-items: flex-start;
}
.author-box .avatar,
.author-box img,
.ts-author-box .avatar {
  width: 72px !important;
  height: 72px !important;
  border-radius: 50% !important;
  flex-shrink: 0;
  border: 3px solid var(--infoco-red, #C8102E);
  object-fit: cover;
}
.author-box .name,
.author-box .fn,
.ts-author-box .name {
  font-size: 16px;
  font-weight: 700;
  color: #111;
  margin-bottom: 4px;
  display: block;
}
.author-box .author-bio,
.author-box .description,
.ts-author-box .description {
  font-size: 13px;
  color: #666;
  line-height: 1.6;
  margin-bottom: 10px;
}
.author-box .all-posts-link,
.author-box a.posts-link {
  font-size: 12px;
  color: var(--infoco-red, #C8102E);
  font-weight: 700;
  text-transform: uppercase;
  text-decoration: none;
}
.author-box .all-posts-link:hover { text-decoration: underline; }

/* Author box — fallback quando não há avatar (injetado via JS) */
.infoco-author-box {
  background: #fff;
  border: 1px solid #ebebeb;
  border-left: 4px solid var(--infoco-red, #C8102E);
  border-radius: 0 8px 8px 0;
  padding: 20px 24px;
  margin: 36px 0;
  display: flex;
  align-items: center;
  gap: 16px;
}
.infoco-author-avatar {
  width: 60px; height: 60px;
  border-radius: 50%;
  background: var(--infoco-red, #C8102E);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: #fff; font-weight: 700;
  flex-shrink: 0;
}
.infoco-author-info strong { display: block; font-size: 15px; font-weight: 700; color: #111; }
.infoco-author-info span { font-size: 12px; color: #888; }

/* === RELATED POSTS PREMIUM === */
.related-posts {
  margin: 40px 0 28px;
  padding-top: 28px;
  border-top: 2px solid var(--infoco-red, #C8102E);
}
.related-posts .block-title,
.related-posts > h3,
.related-posts .ts-title {
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--infoco-red, #C8102E);
  margin-bottom: 20px;
}
.related-posts .loop { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.related-posts .l-post .media img {
  width: 100%; height: 120px; object-fit: cover; border-radius: 6px;
}
.related-posts .l-post .post-title {
  font-size: 13px; font-weight: 700; line-height: 1.4; margin-top: 8px;
  color: #111;
}
.related-posts .l-post .post-title a { color: inherit; }
.related-posts .l-post .post-title a:hover { color: var(--infoco-red, #C8102E); }

/* === ARTICLE: CTA WHATSAPP === */
.infoco-article-cta-wa {
  background: linear-gradient(135deg, #075e54 0%, #128c7e 100%);
  border-radius: 10px;
  padding: 22px 26px;
  margin: 36px 0 24px;
}
.cta-wa-inner {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.cta-wa-icon { font-size: 32px; flex-shrink: 0; }
.cta-wa-text { flex: 1; min-width: 200px; }
.cta-wa-text strong { display: block; color: #fff; font-size: 15px; font-weight: 700; margin-bottom: 3px; }
.cta-wa-text span { color: rgba(255,255,255,0.8); font-size: 13px; }
.cta-wa-btn {
  background: #25d366; color: #fff !important; padding: 10px 22px;
  border-radius: 25px; font-weight: 700; font-size: 13px;
  text-decoration: none !important; white-space: nowrap; flex-shrink: 0;
  transition: background 0.2s;
}
.cta-wa-btn:hover { background: #1da851; }

/* === ARTICLE: NEWSLETTER === */
.infoco-article-newsletter {
  background: #1a1a2e;
  border-radius: 10px;
  padding: 22px 26px;
  margin: 0 0 28px;
}
.infoco-article-newsletter .newsletter-inner { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.infoco-article-newsletter .newsletter-icon { font-size:30px; flex-shrink:0; }
.infoco-article-newsletter .newsletter-text { flex:1; min-width:200px; }
.infoco-article-newsletter .newsletter-text strong { display:block; color:#fff; font-size:14px; font-weight:700; margin-bottom:3px; }
.infoco-article-newsletter .newsletter-text span { color:rgba(255,255,255,0.7); font-size:12px; }
.infoco-article-newsletter .newsletter-form { display:flex; gap:8px; flex-shrink:0; flex-wrap:wrap; }
.infoco-article-newsletter .newsletter-input { padding:9px 14px; border:none; border-radius:4px; font-size:13px; width:200px; }
.infoco-article-newsletter .newsletter-btn {
  background:var(--infoco-red,#C8102E); color:#fff; border:none;
  padding:9px 18px; border-radius:4px; font-weight:700; font-size:13px; cursor:pointer;
}
.infoco-article-newsletter .newsletter-btn:hover { background:#900d21; }

/* === PRÓXIMA LEITURA === */
.infoco-next-reading {
  background: #f8f8f8;
  border: 1px solid #e8e8e8;
  border-radius: 10px;
  padding: 18px 22px;
  margin: 24px 0 36px;
}
.next-label {
  display: block; font-size: 10px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 1px; color: var(--infoco-red,#C8102E); margin-bottom: 12px;
}
.next-article-link {
  display: flex; align-items: center; gap: 14px; text-decoration: none !important;
}
.next-thumb {
  width: 80px; height: 56px; object-fit: cover; border-radius: 6px; flex-shrink: 0;
}
.next-title {
  flex: 1; font-size: 14px; font-weight: 700; color: #111; line-height: 1.4;
}
.next-article-link:hover .next-title { color: var(--infoco-red,#C8102E); }

/* === MOBILE SPRINT 4 === */
@media (max-width: 767px) {
  .single-post h1.post-title, .single-post h1.is-title { font-size: 26px !important; line-height: 1.25 !important; }
  .single-post .entry-content h2 { font-size: 20px; }
  .cta-wa-inner, .infoco-article-newsletter .newsletter-inner { flex-direction: column; text-align: center; }
  .infoco-article-newsletter .newsletter-input { width: 100%; }
  .infoco-article-newsletter .newsletter-form { width: 100%; flex-direction: column; }
  .infoco-article-newsletter .newsletter-btn { width: 100%; }
  .related-posts .loop { grid-template-columns: 1fr; }
  .author-box, .ts-author-box { flex-direction: column; align-items: center; text-align: center; }
  .next-article-link { flex-direction: column; }
  .next-thumb { width: 100%; height: 140px; }
}

/* ================================================================
   SPRINT 4.2 — Progress Bar, Share Float, Author Box, Mobile
   ================================================================ */

/* --- Progress Bar --- */
.infoco-progress-bar {
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  height: 3px;
  background: rgba(0,0,0,0.08);
  z-index: 99999;
  pointer-events: none;
}
.infoco-progress-fill {
  height: 100%;
  width: 0%;
  background: var(--infoco-red, #C8102E);
  transition: width 0.1s linear;
  border-radius: 0 2px 2px 0;
}

/* --- Share Float Sidebar --- */
.infoco-share-float {
  position: fixed;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 1000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.infoco-share-float.visible {
  opacity: 1;
  pointer-events: all;
}
.sf-label {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: #999;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  margin-bottom: 4px;
}
.sf-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  color: #fff;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.sf-btn:hover { transform: scale(1.12); box-shadow: 0 4px 12px rgba(0,0,0,0.2); }
.sf-wa  { background: #25D366; }
.sf-fb  { background: #1877F2; }
.sf-tw  { background: #000; }
.sf-li  { background: #0A66C2; }

/* Ocultar share float nativo do SmartMag (usamos o nosso) */
.post-share-float.share-float-b { display: none !important; }

/* --- Author Box Premium --- */
.infoco-author-box {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  background: #fafafa;
  border: 1px solid #eee;
  border-left: 4px solid var(--infoco-red, #C8102E);
  border-radius: 0 10px 10px 0;
  padding: 24px 28px;
  margin: 36px 0 28px;
}
.infoco-author-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--infoco-red, #C8102E);
  flex-shrink: 0;
}
.infoco-author-avatar-placeholder {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--infoco-red, #C8102E);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 28px;
  font-weight: 800;
  flex-shrink: 0;
}
.infoco-author-info { flex: 1; min-width: 0; }
.infoco-author-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--infoco-red, #C8102E);
  display: block;
  margin-bottom: 4px;
}
.infoco-author-name {
  font-size: 18px;
  font-weight: 800;
  color: #111;
  display: block;
  margin-bottom: 6px;
}
.infoco-author-bio {
  font-size: 13px;
  color: #666;
  line-height: 1.6;
  margin: 0 0 10px;
}
.infoco-author-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.infoco-author-count {
  font-size: 12px;
  color: #888;
  font-weight: 600;
}
.infoco-author-link {
  font-size: 12px;
  font-weight: 700;
  color: var(--infoco-red, #C8102E);
  text-decoration: none;
  padding: 4px 12px;
  border: 1.5px solid var(--infoco-red, #C8102E);
  border-radius: 20px;
  transition: all 0.2s;
}
.infoco-author-link:hover {
  background: var(--infoco-red, #C8102E);
  color: #fff;
}

/* --- Related Posts 3-col grid premium --- */
.related-posts .block-head { border-left: 4px solid var(--infoco-red, #C8102E); padding-left: 14px; }
.related-posts .loop-w, .related-posts .block { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.related-posts .l-post { break-inside: avoid; }
.related-posts .l-post .media { border-radius: 8px; overflow: hidden; }
.related-posts .l-post .media img { transition: transform 0.3s ease; }
.related-posts .l-post:hover .media img { transform: scale(1.04); }
.related-posts .l-post .content .title { font-size: 15px !important; font-weight: 700 !important; line-height: 1.35 !important; }

/* --- CTA WhatsApp no artigo --- */
.infoco-article-cta-wa {
  background: linear-gradient(135deg, #075e54, #128c7e);
  border-radius: 10px;
  padding: 22px 26px;
  margin: 36px 0 16px;
  clear: both;
}
.cta-wa-inner {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.cta-wa-icon { font-size: 32px; line-height: 1; flex-shrink: 0; }
.cta-wa-text { flex: 1; min-width: 0; }
.cta-wa-text strong { display: block; color: #fff; font-size: 15px; font-weight: 800; margin-bottom: 3px; }
.cta-wa-text span { color: rgba(255,255,255,0.8); font-size: 13px; }
.cta-wa-btn {
  display: inline-block;
  background: #fff;
  color: #075e54 !important;
  font-weight: 800;
  font-size: 13px;
  padding: 10px 20px;
  border-radius: 25px;
  text-decoration: none !important;
  white-space: nowrap;
  flex-shrink: 0;
  transition: transform 0.2s, box-shadow 0.2s;
}
.cta-wa-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,0.2); }

/* --- Newsletter no artigo --- */
.infoco-article-newsletter {
  background: #1a1a2e;
  border-radius: 10px;
  padding: 22px 26px;
  margin: 0 0 24px;
  clear: both;
}
.newsletter-inner {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.newsletter-icon { font-size: 28px; flex-shrink: 0; }
.newsletter-text { flex: 1; min-width: 0; }
.newsletter-text strong { display: block; color: #fff; font-size: 15px; font-weight: 800; margin-bottom: 3px; }
.newsletter-text span { color: rgba(255,255,255,0.65); font-size: 13px; }
.newsletter-form { display: flex; gap: 8px; flex-shrink: 0; }
.newsletter-input {
  padding: 9px 14px;
  border-radius: 6px;
  border: none;
  font-size: 13px;
  width: 200px;
  outline: none;
}
.newsletter-btn {
  background: var(--infoco-red, #C8102E);
  color: #fff;
  border: none;
  padding: 9px 18px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity 0.2s;
}
.newsletter-btn:hover { opacity: 0.88; }

/* --- Próxima Leitura --- */
.infoco-next-reading {
  background: #f8f8f8;
  border: 1px solid #eee;
  border-radius: 10px;
  padding: 16px 20px;
  margin: 0 0 28px;
}
.next-label {
  display: block;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #999;
  margin-bottom: 10px;
}
.next-article-link {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none !important;
  color: #111 !important;
}
.next-thumb {
  width: 72px;
  height: 50px;
  object-fit: cover;
  border-radius: 6px;
  flex-shrink: 0;
}
.next-title {
  flex: 1;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
  color: #111;
}
.next-article-link:hover .next-title { color: var(--infoco-red, #C8102E); }

/* --- MOBILE --- */
@media (max-width: 768px) {
  .single-post h1.post-title, .single-post h1.is-title {
    font-size: 26px !important;
    line-height: 1.25 !important;
  }
  .infoco-share-float { display: none !important; }
  .cta-wa-inner, .newsletter-inner { flex-direction: column; align-items: flex-start; }
  .newsletter-form { width: 100%; }
  .newsletter-input { width: 100%; flex: 1; }
  .related-posts .loop-w, .related-posts .block { grid-template-columns: 1fr !important; }
  .infoco-author-box { flex-direction: column; }
  .infoco-author-avatar, .infoco-author-avatar-placeholder { width: 56px; height: 56px; }
}
@media (max-width: 480px) {
  .infoco-article-cta-wa, .infoco-article-newsletter { padding: 16px; }
  .cta-wa-btn { width: 100%; text-align: center; }
  .newsletter-form { flex-direction: column; }
}

/* ============================================================
   INFOCO 2.0 — HOME PREMIUM FINAL — Sprint 8
   ============================================================ */

/* --- Layout two-column --- */
.infoco-home-layout {
  display: flex;
  gap: 28px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
  align-items: flex-start;
}
.infoco-main-col { flex: 1 1 0; min-width: 0; }
.infoco-sidebar-col { width: 300px; flex-shrink: 0; }
@media(max-width:900px){
  .infoco-home-layout { flex-direction: column; }
  .infoco-sidebar-col { width: 100%; }
}

/* --- Notícias Quentes --- */
.infoco-hot-section { margin: 24px 0; }
.infoco-hot-section .section-head {
  display: flex; align-items: center; gap: 10px;
  border-bottom: 3px solid #C62828; margin-bottom: 16px; padding-bottom: 6px;
}
.infoco-hot-section .section-head h2 {
  font-size: 1.15rem; font-weight: 700; color: #C62828;
  text-transform: uppercase; letter-spacing: .04em; margin: 0;
}
.hot-flame { font-size: 1.3rem; }
.hot-main-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.hot-main-article { grid-column: 1 / -1; position: relative; border-radius: 8px; overflow: hidden; }
.hot-main-article a { display: block; }
.hot-main-article img { width: 100%; height: 320px; object-fit: cover; display: block; }
.hot-main-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.82));
  padding: 32px 16px 14px;
}
.hot-main-overlay h2 { color: #fff; font-size: 1.3rem; margin: 0 0 4px; line-height: 1.3; }
.hot-main-overlay .post-meta { color: rgba(255,255,255,.75); font-size: .78rem; }
.hot-ph-img {
  width: 100%; height: 320px; background: linear-gradient(135deg,#C62828,#7B1FA2);
  display: flex; align-items: flex-end;
}
.hot-ph-img span { color: #fff; font-size: 1.25rem; font-weight: 700; padding: 16px; }
.hot-secondary { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
.hot-sec-card a { display: flex; gap: 10px; align-items: flex-start; text-decoration: none; }
.hot-sec-card img, .hot-sec-thumb { width: 90px; height: 65px; object-fit: cover; border-radius: 5px; flex-shrink: 0; }
.hot-sec-thumb { background: linear-gradient(135deg,#1B4F8A,#00838F); }
.hot-sec-card h4 { font-size: .88rem; color: #1a1a1a; margin: 0; line-height: 1.35; }
.hot-sec-card .post-meta { font-size: .73rem; color: #666; }
.hot-small-list { display: grid; grid-template-columns: repeat(2,1fr); gap: 8px; }
.hot-small-card a { display: flex; gap: 8px; align-items: flex-start; text-decoration: none; border-bottom: 1px solid #eee; padding-bottom: 7px; }
.hot-small-card img, .hot-sm-thumb { width: 68px; height: 50px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.hot-sm-thumb { background: #ddd; }
.hot-small-card h5 { font-size: .82rem; color: #1a1a1a; margin: 0; line-height: 1.3; }
@media(max-width:600px){
  .hot-main-article img, .hot-ph-img { height: 220px; }
  .hot-secondary, .hot-small-list { grid-template-columns: 1fr; }
}

/* --- Universal Carousel --- */
.infoco-section-title {
  font-size: 1.05rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; border-left: 4px solid #1B4F8A;
  padding-left: 10px; margin: 24px 0 12px; color: #1B4F8A;
}
.inf-carousel-wrap { position: relative; margin-bottom: 28px; }
.inf-track-outer { overflow: hidden; }
.inf-track { display: flex; gap: 14px; transition: transform .35s ease; }
.inf-nav-btn {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: #1B4F8A; color: #fff; border: none; border-radius: 50%;
  width: 34px; height: 34px; cursor: pointer; font-size: 1.1rem;
  z-index: 5; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px rgba(0,0,0,.25);
}
.inf-nav-btn.prev { left: -14px; }
.inf-nav-btn.next { right: -14px; }
@media(max-width:600px){ .inf-nav-btn { display: none; } }

/* --- Cidades Carousel --- */
.cidade-card {
  flex: 0 0 130px; border-radius: 8px; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.12); cursor: pointer; text-decoration: none;
}
.cidade-story { width: 130px; height: 200px; object-fit: cover; display: block; }
.cidade-ph {
  width: 130px; height: 200px;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  padding-bottom: 14px; color: #fff; font-weight: 700; font-size: .82rem; text-align: center;
}
.cidade-card .cidade-label {
  display: block; background: #1B4F8A; color: #fff;
  font-size: .75rem; font-weight: 600; padding: 5px 8px; text-align: center;
}

/* --- Shorts Carousel --- */
.short-card {
  flex: 0 0 130px; border-radius: 8px; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.14); text-decoration: none;
}
.short-ph-bg {
  width: 130px; height: 220px;
  display: flex; align-items: flex-end; padding: 10px;
  font-size: .8rem; font-weight: 700; color: #fff;
}
.short-card img { width: 130px; height: 220px; object-fit: cover; display: block; }
.short-card .short-title {
  background: #111; color: #fff; font-size: .74rem;
  padding: 5px 8px; display: block; line-height: 1.3;
}

/* --- Agenda Carousel --- */
.agenda-flyer {
  flex: 0 0 160px; height: 240px; border-radius: 10px; overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 14px 12px; color: #fff; box-shadow: 0 3px 10px rgba(0,0,0,.2);
  text-decoration: none; flex-shrink: 0;
}
.agenda-flyer .agenda-date { font-size: .7rem; opacity: .85; margin-bottom: 4px; }
.agenda-flyer .agenda-title { font-size: .9rem; font-weight: 700; line-height: 1.3; }
.agenda-flyer .agenda-local { font-size: .72rem; opacity: .8; margin-top: 4px; }

/* --- Colunistas Carousel --- */
.col-card {
  flex: 0 0 130px; text-align: center; text-decoration: none;
  padding: 12px 8px; background: #f8f9fa; border-radius: 8px;
  box-shadow: 0 1px 5px rgba(0,0,0,.08); flex-shrink: 0;
}
.col-avatar img, .col-av-ph {
  width: 72px; height: 72px; border-radius: 50%;
  margin: 0 auto 8px; display: block; object-fit: cover;
}
.col-av-ph {
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem; background: linear-gradient(135deg,#1B4F8A,#00838F);
  color: #fff; font-weight: 700;
}
.col-card .col-name { font-size: .8rem; font-weight: 700; color: #1a1a1a; display: block; }
.col-card .col-role { font-size: .7rem; color: #666; display: block; margin-top: 2px; }

/* --- Editorial Blocks --- */
.infoco-ed-block { margin-bottom: 28px; }
.block-head { margin-bottom: 12px; }
.block-title {
  font-size: 1rem; font-weight: 700; text-transform: uppercase;
  border-left: 4px solid #1B4F8A; padding-left: 10px; margin: 0;
}
.infoco-ed-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 14px; }
.ed-main a { display: block; text-decoration: none; }
.ed-main img { width: 100%; aspect-ratio: 16/9; object-fit: cover; border-radius: 6px; }
.ed-body h3 { font-size: 1rem; color: #1a1a1a; margin: 8px 0 4px; line-height: 1.35; }
.ed-list { display: flex; flex-direction: column; gap: 10px; }
.ed-item a { display: flex; gap: 8px; text-decoration: none; align-items: flex-start; }
.ed-item img { width: 80px; height: 58px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.ed-item h4 { font-size: .82rem; color: #1a1a1a; margin: 0; line-height: 1.3; }
@media(max-width:600px){ .infoco-ed-grid { grid-template-columns: 1fr; } }

/* --- Classificados --- */
.infoco-classificados { margin: 28px 0; }
.clas-grid {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-top: 14px;
}
.clas-card {
  background: #fff; border: 1px solid #e0e0e0; border-radius: 8px;
  overflow: hidden; box-shadow: 0 1px 4px rgba(0,0,0,.07); text-decoration: none;
}
.clas-img { width: 100%; height: 110px; object-fit: cover; display: block; }
.clas-ph { width: 100%; height: 110px; display: flex; align-items: center; justify-content: center; font-size: 1.8rem; }
.clas-body { padding: 10px; }
.clas-body .clas-cat {
  font-size: .65rem; font-weight: 700; text-transform: uppercase;
  background: #1B4F8A; color: #fff; padding: 2px 6px; border-radius: 3px; display: inline-block; margin-bottom: 5px;
}
.clas-body h4 { font-size: .82rem; color: #1a1a1a; margin: 0 0 4px; line-height: 1.3; }
.clas-body .clas-price { font-size: .85rem; font-weight: 700; color: #2E7D32; }
.clas-cta { text-align: center; margin-top: 16px; }
.clas-cta a {
  display: inline-block; background: #25D366; color: #fff;
  font-weight: 700; padding: 10px 26px; border-radius: 24px; text-decoration: none; font-size: .95rem;
}
@media(max-width:700px){ .clas-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:420px){ .clas-grid { grid-template-columns: 1fr; } }

/* --- Newsletter Box --- */
.infoco-newsletter {
  background: linear-gradient(135deg,#1B4F8A,#0D2E56);
  color: #fff; border-radius: 10px; padding: 22px 20px; margin: 24px 0; text-align: center;
}
.infoco-newsletter h3 { font-size: 1.1rem; margin: 0 0 6px; }
.infoco-newsletter p { font-size: .85rem; opacity: .88; margin: 0 0 14px; }
.infoco-newsletter form { display: flex; gap: 8px; max-width: 400px; margin: 0 auto; }
.infoco-newsletter input[type=email] {
  flex: 1; padding: 9px 12px; border-radius: 6px; border: none;
  font-size: .9rem; outline: none;
}
.infoco-newsletter button {
  background: #C62828; color: #fff; border: none; border-radius: 6px;
  padding: 9px 16px; font-weight: 700; cursor: pointer; font-size: .88rem;
}
@media(max-width:480px){ .infoco-newsletter form { flex-direction: column; } }

/* --- Enquete Widget --- */
.infoco-enquete-widget {
  background: #fff; border: 1px solid #e0e0e0; border-radius: 8px;
  padding: 16px; margin-bottom: 22px; box-shadow: 0 1px 5px rgba(0,0,0,.07);
}
.infoco-enquete-widget h3 { font-size: .95rem; font-weight: 700; color: #1B4F8A; margin: 0 0 12px; }
.infoco-enquete-widget .eq-question { font-size: .88rem; color: #222; margin-bottom: 12px; font-weight: 600; }
.eq-opt { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; font-size: .84rem; cursor: pointer; }
.eq-opt input { accent-color: #1B4F8A; }
.eq-vote-btn {
  background: #1B4F8A; color: #fff; border: none; border-radius: 5px;
  padding: 7px 18px; font-size: .85rem; font-weight: 700; cursor: pointer; margin-top: 8px; width: 100%;
}
.eq-results { display: none; margin-top: 12px; }
.eq-results.visible { display: block; }
.eq-bar-item { margin-bottom: 8px; font-size: .8rem; }
.eq-bar-item .eq-bar-label { display: flex; justify-content: space-between; margin-bottom: 3px; }
.eq-bar-track { background: #e0e0e0; border-radius: 4px; height: 8px; overflow: hidden; }
.eq-bar-fill { height: 100%; background: #1B4F8A; border-radius: 4px; transition: width .5s; }

/* --- Footer Institucional --- */
body.home .site-footer { display: none !important; }
.infoco-footer-institucional {
  background: #0D1B2E; color: #cdd; margin-top: 40px; padding: 40px 0 0;
}
.footer-inner {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 28px; max-width: 1200px; margin: 0 auto; padding: 0 20px 36px;
}
.footer-col h4 { color: #fff; font-size: .92rem; font-weight: 700; margin: 0 0 12px; text-transform: uppercase; letter-spacing: .05em; }
.footer-col p, .footer-col li, .footer-col a { font-size: .82rem; color: #aabbc8; line-height: 1.6; }
.footer-col a { text-decoration: none; }
.footer-col a:hover { color: #fff; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col ul li { border-bottom: 1px solid rgba(255,255,255,.07); padding: 4px 0; }
.footer-logo-txt { color: #fff; font-size: 1.4rem; font-weight: 900; letter-spacing: -.02em; margin-bottom: 10px; }
.footer-col img.custom-logo { max-width: 140px; margin-bottom: 10px; filter: brightness(0) invert(1); }
.footer-hp-box {
  background: rgba(255,255,255,.06); border-left: 3px solid #1B4F8A;
  padding: 10px 12px; border-radius: 0 6px 6px 0; margin-top: 12px; font-size: .79rem;
}
.footer-hp-box strong { color: #fff; }
.footer-social { display: flex; gap: 8px; margin-top: 14px; }
.fs-btn {
  width: 34px; height: 34px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; font-size: .75rem; font-weight: 700; color: #fff; text-decoration: none;
}
.fs-fb { background: #1877F2; }
.fs-tw { background: #000; }
.fs-ig { background: radial-gradient(circle at 30% 107%,#fdf497 0%,#fd5949 45%,#d6249f 60%,#285AEB 90%); }
.fs-yt { background: #FF0000; }
.footer-bottom {
  background: rgba(0,0,0,.35); text-align: center;
  padding: 14px 20px; border-top: 1px solid rgba(255,255,255,.08);
}
.footer-bottom p { font-size: .76rem; color: #7a8f9e; margin: 0 0 6px; }
.footer-legal { display: flex; justify-content: center; gap: 18px; }
.footer-legal a { font-size: .74rem; color: #7a8f9e; text-decoration: none; }
.footer-legal a:hover { color: #fff; }
@media(max-width:900px){
  .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media(max-width:520px){
  .footer-inner { grid-template-columns: 1fr; }
}

/* --- post-meta utility --- */
.post-meta { font-size: .75rem; color: #888; }

.infoco-newsletter-box{background:linear-gradient(135deg,#1B4F8A,#0D2E56);color:#fff;border-radius:10px;padding:22px 20px;margin:24px 0;text-align:center;}
.infoco-newsletter-box h3{font-size:1.1rem;margin:0 0 6px;color:#fff;}
.infoco-newsletter-box p{font-size:.85rem;opacity:.88;margin:0 0 14px;}
.infoco-newsletter-box .newsletter-inner{display:flex;gap:8px;max-width:400px;margin:0 auto;}
.infoco-newsletter-box input[type=email]{flex:1;padding:9px 12px;border-radius:6px;border:none;font-size:.9rem;outline:none;}
.infoco-newsletter-box button{background:#C62828;color:#fff;border:none;border-radius:6px;padding:9px 16px;font-weight:700;cursor:pointer;}
@media(max-width:480px){.infoco-newsletter-box .newsletter-inner{flex-direction:column;}}
#eq-resultados{display:none;margin-top:12px;}
#eq-resultados.visible{display:block;}


/* ============================================================
   INFOCO 2.0 — CLASS ALIAS PATCH (actual PHP class names)
   ============================================================ */

/* Hot Section — grid aliases */
.hot-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
.hot-main { grid-column:1 / -1; position:relative; border-radius:8px; overflow:hidden; }
.hot-main a,.hot-main-link { display:block; text-decoration:none; }
.hot-main img { width:100%; height:320px; object-fit:cover; display:block; }
.hot-main-overlay { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent,rgba(0,0,0,.82)); padding:32px 16px 14px; }
.hot-main-title { color:#fff; font-size:1.3rem; margin:0 0 4px; line-height:1.3; font-weight:700; }
.hot-meta { color:rgba(255,255,255,.75); font-size:.78rem; }
.hot-sec-col { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:10px; }
.hot-sec-card a { display:flex; gap:10px; align-items:flex-start; text-decoration:none; }
.hot-sec-img { width:90px; height:65px; object-fit:cover; border-radius:5px; flex-shrink:0; background:linear-gradient(135deg,#1B4F8A,#00838F); }
.hot-sec-body h4 { font-size:.88rem; color:#1a1a1a; margin:0; line-height:1.35; }
.hot-sm-col { display:grid; grid-template-columns:repeat(2,1fr); gap:8px; }
.hot-sm-card a { display:flex; gap:8px; align-items:flex-start; text-decoration:none; border-bottom:1px solid #eee; padding-bottom:7px; }
.hot-sm-img { width:68px; height:50px; object-fit:cover; border-radius:4px; flex-shrink:0; background:#ddd; }
.hot-sm-card h5 { font-size:.82rem; color:#1a1a1a; margin:0; line-height:1.3; }
@media(max-width:600px){
  .hot-main img{height:220px;}
  .hot-sec-col,.hot-sm-col{grid-template-columns:1fr;}
}

/* Cidades carousel aliases */
.cidade-overlay { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent,rgba(0,0,0,.7)); padding:20px 8px 10px; }
.cidade-nome { color:#fff; font-size:.78rem; font-weight:700; text-align:center; display:block; }
.cidade-headline { color:rgba(255,255,255,.82); font-size:.65rem; text-align:center; display:block; margin-top:2px; line-height:1.25; }
.cidade-card { flex:0 0 130px; border-radius:8px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,.12); text-decoration:none; position:relative; display:block; }
.cidade-story { width:130px; height:200px; object-fit:cover; display:block; }

/* Shorts aliases */
.short-card { flex:0 0 130px; border-radius:8px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,.14); text-decoration:none; display:block; position:relative; }
.short-ph { width:130px; height:220px; display:flex; flex-direction:column; justify-content:flex-end; }
.short-ph-bg { position:absolute; inset:0; border-radius:8px; }
.short-thumb { width:130px; height:220px; object-fit:cover; display:block; }
.short-play { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:36px; height:36px; background:rgba(255,255,255,.85); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1rem; }
.short-info { position:relative; z-index:1; padding:8px; }
.short-ph-logo { font-size:.6rem; color:rgba(255,255,255,.7); font-weight:700; text-transform:uppercase; letter-spacing:.05em; }
.short-ph-tag { font-size:.75rem; color:#fff; font-weight:700; line-height:1.3; margin:3px 0; }
.short-ph-dur { font-size:.65rem; color:rgba(255,255,255,.65); }

/* Agenda aliases */
.agenda-card { flex:0 0 160px; height:240px; border-radius:10px; overflow:hidden; position:relative; flex-shrink:0; text-decoration:none; display:block; }
.agenda-flyer-top { position:absolute; top:0; left:0; right:0; padding:10px 12px; }
.agenda-flyer-body { position:absolute; bottom:0; left:0; right:0; padding:10px 12px; background:linear-gradient(transparent,rgba(0,0,0,.75)); color:#fff; }
.agenda-flyer-body .agenda-date { font-size:.7rem; opacity:.85; margin-bottom:4px; display:block; }
.agenda-flyer-body .agenda-title { font-size:.88rem; font-weight:700; line-height:1.3; display:block; }
.agenda-flyer-body .agenda-local { font-size:.7rem; opacity:.78; margin-top:3px; display:block; }

/* Colunistas aliases */
.col-card { flex:0 0 130px; text-align:center; text-decoration:none; padding:12px 8px; background:#f8f9fa; border-radius:8px; box-shadow:0 1px 5px rgba(0,0,0,.08); flex-shrink:0; display:block; }
.col-avatar img { width:72px; height:72px; border-radius:50%; margin:0 auto 8px; display:block; object-fit:cover; }
.col-card .col-name,.col-card strong { font-size:.8rem; font-weight:700; color:#1a1a1a; display:block; }
.col-esp,.col-cidade { font-size:.7rem; color:#666; display:block; margin-top:2px; }

/* Classificados aliases */
.clas-preco { font-size:.85rem; font-weight:700; color:#2E7D32; }
.clas-emoji { font-size:1.8rem; display:flex; align-items:center; justify-content:center; height:110px; }
.clas-loc,.clas-meta { font-size:.72rem; color:#888; margin-top:2px; }

/* Enquete section header */
.infoco-home-layout .infoco-sidebar-col .infoco-enquete-widget h3 { color:#1B4F8A; }

/* Sidebar sticky */
.infoco-sidebar-col { position: sticky; top: 80px; align-self: flex-start; }
/* Hot main image overlay z-index fix */
.hot-main { overflow: hidden; }
.hot-main img { display: block; width: 100%; height: 320px; object-fit: cover; }
.hot-main-overlay { z-index: 2; }
/* Section titles consistent */
.infoco-section-title, .block-wrap .block-title { 
  font-size:1rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.05em; border-left:4px solid #1B4F8A;
  padding-left:10px; margin:0 0 14px; color:#1B4F8A;
}
