/**
 * Connect Blog CSS - Estilos básicos e 3 layouts
 * 
 * @copyright 2025 Nando Cardoso® | Connect Designers®
 * @author Nando Cardoso
 * 
 * PROPRIEDADE INTELECTUAL REGISTRADA
 * REGISTRO INPI Connect Designers®: Processo nº 923067680
 * REGISTRO INPI Nando Cardoso®: Processo nº 929564537
 * 
 * Código protegido por direitos autorais. Uso não autorizado proibido.
 */
:root { --connect-blog-font: Inter, system-ui, -apple-system, Segoe UI, Roboto; }
.connect-blog { font-family: var(--connect-blog-font); color: #111827; background: #ffffff; }
.cb-container { max-width: 1100px; margin: 0 auto; padding: 24px; }
.cb-header { margin-bottom: 18px; }
.cb-title { font-size: 32px; line-height: 1.1; margin: 0; }
.cb-empty { color: #6b7280; }
.cb-meta { 
  color: #6b7280; 
  font-size: 13px; 
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 12px 0 14px;
  padding-top: 12px;
  border-top: 1px solid #e5e7eb;
  gap: 10px;
}

.cb-meta span {
  display: flex;
  align-items: center;
  gap: 5px;
}

.cb-meta i {
  font-size: 12px;
}

/* Botão Saiba Mais */
.cb-read-more {
  display: inline-block;
  margin: 0;
  padding: 10px 20px;
  background-color: var(--connect-blog-button-color, #000000);
  color: var(--connect-blog-button-text-color, #ffffff);
  text-decoration: none;
  border-radius: 6px;
  font-weight: 600;
  font-size: 14px;
  text-align: center;
  transition: all 0.3s ease;
  width: 100%; /* Ocupa toda largura disponível */
  border: none;
  cursor: pointer;
  text-transform: none; /* Remove uppercase */
  letter-spacing: normal;
}

.cb-read-more:hover {
  background-color: var(--connect-blog-button-color, #000000);
  filter: brightness(1.3);
  color: var(--connect-blog-button-text-color, #ffffff);
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
}

.cb-read-more:focus {
  outline: none;
  box-shadow: 0 0 0 3px var(--connect-blog-button-color, #000000);
  opacity: 0.8;
}

/* Category Badge */
.cb-category-badge {
  display: inline-block;
  padding: 4px 12px;
  background: #374151;
  color: #fff !important;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-radius: 4px;
  margin-top: 12px; /* Pequeno espaço do topo */
  margin-bottom: 6px; /* Margem inferior */
  text-decoration: none !important;
  transition: all 0.3s ease;
}

.cb-category-badge:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  background: #1f2937;
  color: #fff !important;
}

/* Grid cards */
.cb-grid { 
  display: grid; 
  grid-template-columns: repeat(3, minmax(0,1fr)); 
  gap: 32px; /* Aumenta espaço entre cards */
  grid-auto-rows: auto; /* Altura automática para os cards */
}
.cb-item { 
  background: #fff; 
  border: 1px solid #e5e7eb; 
  border-radius: 12px; /* Bordas mais arredondadas */
  overflow: hidden; /* Mantém hidden para bordas arredondadas */
  display: flex; 
  flex-direction: column;
  transition: all 0.3s ease;
  position: relative;
  top: 0;
  min-height: 500px; /* Altura mínima aumentada para cards maiores */
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08); /* Sombra inicial mais visível */
}
.cb-item:hover {
  top: -4px; /* Move mais para cima */
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.18); /* Sombra mais dramática */
  border-color: #cbd5e1;
  transform: translateY(-4px); /* Move mais para cima */
}
.cb-thumb { 
  display: block; 
  width: 100%;
  height: 280px; /* Altura muito maior para imagens */
  overflow: hidden; 
  flex-shrink: 0;
  border-radius: 0; /* Remove arredondamento no topo para imagem 100% */
}
.cb-thumb img { 
  width: 100%; 
  height: 100%; 
  display: block; 
  object-fit: cover; /* Cobre toda área mantendo proporção */
  object-position: center; /* Centraliza a imagem */
  transition: transform 0.4s ease; /* Adiciona transição suave */
}
.cb-item:hover .cb-thumb img {
  transform: scale(1.08); /* Efeito zoom suave no hover */
}
.cb-content { 
  padding: 0 18px 20px; /* Remove completamente o padding superior */
  flex: 1; 
  display: flex;
  flex-direction: column;
  gap: 5px; /* Reduz espaçamento entre elementos */
}
.cb-content-top {
  flex: 1; /* Área que expande */
}
.cb-content-bottom {
  margin-top: auto; /* Sempre no final */
  padding-top: 12px;
}
.cb-item-title { 
  font-size: 19px; 
  margin: 0 0 10px; 
  line-height: 1.35; 
  min-height: auto; /* Remove altura mínima fixa */
  max-height: 54px; /* Altura máxima para 2 linhas */
  display: -webkit-box;
  -webkit-line-clamp: 2; /* Limita a 2 linhas */
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-weight: 600;
}
.cb-item-title a { 
  color: #111827; 
  text-decoration: none; 
  display: block;
}
.cb-item-title a:hover { 
  color: #1f2937;
  text-decoration: none; /* Remove sublinhado no hover */
}
.cb-excerpt { 
  color: #4b5563; 
  margin: 0 0 12px; 
  text-align: left; /* Alinha à esquerda ao invés de justificar */
  min-height: auto; /* Remove altura fixa */
  max-height: 66px; /* Altura máxima para 3 linhas */
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3; /* Limita a 3 linhas */
  -webkit-box-orient: vertical;
  line-height: 1.5;
  font-size: 14px;
}

/* List classic - Layout LATERAL com divisão 40/60 */
.cb-list { 
  display: block; 
  width: 100%;
}

.cb-list > article {
  margin-bottom: 20px;
}

.cb-item--list { 
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  width: 100%;
  min-height: 300px; /* Aumenta mais a altura mínima */
  height: auto; /* Altura automática para expandir conforme necessário */
  border: 1px solid #e5e7eb;
  border-radius: 7px;
  overflow: hidden; /* Volta para hidden mas com altura adequada */
  background: #fff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.06);
  transition: all 0.3s ease;
}

.cb-item--list:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

/* Imagem - 40% à esquerda */
.cb-item--list .cb-thumb { 
  flex: 0 0 40% !important;
  width: 40% !important;
  max-width: 40% !important;
  min-height: 300px; /* Ajusta para mesma altura do container */
  height: 100%;
  background: #fff; /* Fundo branco como o card */
  position: relative;
  overflow: hidden;
  padding: 15px; /* Aumenta espaçamento interno */
  display: flex;
  align-items: center; /* Centraliza verticalmente */
  justify-content: center;
  box-sizing: border-box;
}

.cb-item--list .cb-thumb img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: cover; /* Preenche o espaço disponível */
  display: block;
  border-radius: 7px; /* Border radius nas 4 laterais da imagem */
}

/* Conteúdo - 60% à direita */
.cb-item--list .cb-content {
  flex: 0 0 60% !important;
  width: 60% !important;
  max-width: 60% !important;
  padding: 25px 30px; /* Padding adequado */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: #fff;
  overflow: visible; /* Garante que conteúdo não seja cortado */
  min-height: 300px; /* Altura mínima igual ao container */
  height: auto; /* Permite expandir se necessário */
  box-sizing: border-box;
}

.cb-item--list .cb-item-title {
  font-size: 22px;
  font-weight: 600;
  margin: 0 0 12px;
  line-height: 1.3;
}

.cb-item--list .cb-item-title a {
  color: #111827;
  text-decoration: none;
  transition: color 0.2s ease;
}

.cb-item--list .cb-item-title a:hover {
  color: #2563eb;
}

.cb-item--list .cb-excerpt {
  color: #6b7280;
  font-size: 14px; /* Reduz um pouco o tamanho da fonte */
  line-height: 1.5; /* Ajusta line-height */
  margin: 0 0 12px; /* Reduz margem inferior */
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 4; /* Permite até 4 linhas */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cb-item--list .cb-meta {
  color: #9ca3af;
  font-size: 13px;
  margin: 0 0 16px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.cb-item--list .cb-card-cta {
  margin-top: auto;
}

.cb-item--list .cb-read-more {
  width: 100%;
  padding: 12px 24px;
  background-color: var(--connect-blog-button-color, #000000);
  color: var(--connect-blog-button-text-color, #ffffff);
  text-decoration: none;
  border-radius: 8px;
  font-weight: 600;
  font-size: 15px;
  text-align: center;
  transition: all 0.3s ease;
  display: inline-block;
  border: none;
}

.cb-item--list .cb-read-more:hover {
  background-color: var(--connect-blog-button-color, #000000);
  filter: brightness(1.3);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
}

/* Magazine Layout */
.cb-magazine { 
  display: block;
  width: 100%;
  padding: 0 15%; /* 15% de margem em cada lado */
}

/* Hero Section */
.cb-magazine-hero {
  display: block; /* Muda para block para ocupar 100% da largura disponível */
  margin-bottom: 40px;
}

/* Featured Main Post */
.cb-featured-main {
  background: #fff;
  border-radius: 0; /* Remove bordas para imagem 100% */
  overflow: hidden;
  border: none; /* Remove borda */
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.cb-featured-main:hover {
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.16);
  transform: translateY(-4px);
}

.cb-featured-thumb {
  display: block;
  width: 100%;
  height: 500px; /* Aumenta altura da imagem de destaque */
  overflow: hidden;
  background: #f3f4f6;
}

.cb-featured-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.4s ease;
}

.cb-featured-main:hover .cb-featured-thumb img {
  transform: scale(1.08); /* Zoom maior no hover */
}

.cb-featured-content {
  padding: 24px;
}

.cb-featured-title {
  font-size: 28px;
  margin: 0 0 16px;
  line-height: 1.3;
}

.cb-featured-title a {
  color: #111827;
  text-decoration: none;
  transition: color 0.3s ease;
}

.cb-featured-title a:hover {
  color: #4b5563;
}

.cb-featured-excerpt {
  color: #6b7280;
  font-size: 16px;
  line-height: 1.6;
  margin: 0 0 16px;
}

.cb-featured-meta {
  color: #9ca3af;
  font-size: 14px;
  margin-bottom: 20px;
}

.cb-featured-meta i {
  margin-right: 5px;
}

/* Magazine Sidebar */
.cb-magazine-sidebar {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cb-sidebar-item {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  overflow: hidden;
  transition: all 0.3s ease;
  flex: 1;
}

.cb-sidebar-item:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  transform: translateX(-4px);
}

.cb-sidebar-item-inner {
  display: grid;
  grid-template-columns: 120px 1fr;
  height: 100%;
}

.cb-sidebar-thumb {
  display: block;
  width: 120px;
  height: 100%;
  overflow: hidden;
  background: #f3f4f6;
}

.cb-sidebar-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.3s ease;
}

.cb-sidebar-item:hover .cb-sidebar-thumb img {
  transform: scale(1.1);
}

.cb-sidebar-content {
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cb-sidebar-title {
  font-size: 15px;
  margin: 0 0 8px;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cb-sidebar-title a {
  color: #111827;
  text-decoration: none;
  font-weight: 600;
  transition: color 0.3s ease;
}

.cb-sidebar-title a:hover {
  color: #4b5563;
}

.cb-sidebar-meta {
  color: #9ca3af;
  font-size: 12px;
}

.cb-sidebar-meta i {
  margin-right: 4px;
}

/* Magazine Grid Section */
.cb-magazine-grid {
  margin-top: 60px;
}

.cb-section-title {
  font-size: 24px;
  font-weight: 700;
  color: #111827;
  margin: 0 0 24px;
  padding-bottom: 12px;
  border-bottom: 2px solid #e5e7eb;
}

/* Responsive Magazine Layout */
@media (max-width: 1024px) {
  .cb-magazine-top {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .cb-magazine-side {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
  }
  
  .cb-magazine-featured-title {
    font-size: 24px;
  }
}

@media (max-width: 768px) {
  .cb-magazine {
    padding: 20px 10px;
  }
  
  .cb-magazine-side {
    grid-template-columns: 1fr;
  }
  
  .cb-magazine-featured-title {
    font-size: 20px;
  }
  
  .cb-magazine-featured-excerpt {
    font-size: 14px;
    -webkit-line-clamp: 2;
  }
  
  .cb-magazine-featured-content {
    padding: 20px;
  }
  
  .cb-magazine-side-content {
    padding: 12px;
  }
}

/* General Responsive */
@media (max-width: 1024px) {
  .cb-magazine-hero {
    grid-template-columns: 1fr;
  }
  
  .cb-featured-thumb {
    height: 300px;
  }
  
  .cb-magazine-sidebar {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  }
}

@media (max-width: 768px) {
  .cb-featured-thumb {
    height: 220px;
  }
  
  .cb-featured-title {
    font-size: 22px;
  }
  
  .cb-sidebar-item-inner {
    grid-template-columns: 100px 1fr;
  }
  
  .cb-sidebar-thumb {
    width: 100px;
  }
}

/* Single */
.cb-article-cover { width: 100%; border-radius: 10px; border: 1px solid #e5e7eb; margin-bottom: 14px; }
.cb-article-content { color: #111827; line-height: 1.6; text-align: justify; }

/* Footer */
.cb-footer { margin-top: 28px; padding-top: 14px; border-top: 1px solid #e5e7eb; color: #6b7280; font-size: 14px; }
.cb-footer a { color: #111827; }

@media (max-width: 1024px) {
  .cb-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .cb-item--list .cb-thumb { 
    width: 35%; /* Ajusta para 35% em tablets */
  }
  .cb-item--list .cb-content {
    width: 65%; /* Ajusta para 65% em tablets */
  }
}
@media (max-width: 768px) {
  .cb-item--list { 
    flex-direction: column; /* Muda para coluna em mobile */
    min-height: auto;
  }
  .cb-item--list .cb-thumb {
    width: 100%; /* Largura total em mobile */
    min-height: 200px;
    max-height: 250px;
  }
  .cb-item--list .cb-content {
    width: 100%; /* Largura total em mobile */
    padding: 20px;
  }
  .cb-item--list .cb-item-title {
    font-size: 20px;
  }
}
@media (max-width: 640px) {
  .cb-grid { grid-template-columns: 1fr; }
}

/* --- Single Clean Layout --- */
.cb-single{max-width:860px}
.cb-article-wrap{padding:10px 2px}
.cb-title-single{font-size:30px;line-height:1.2;margin:6px 0 8px;text-align:center;font-weight:700}
.cb-meta-row{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#6b7280;font-size:13px;margin-bottom:12px;flex-wrap:wrap}
.cb-chip{display:inline-block;padding:4px 10px;border-radius:999px;background:#eef2ff;color:#1e3a8a;margin-right:6px;text-decoration:none;font-size:12px}
.cb-chip:hover{background:#e0e7ff}
.cb-cover{width:100%;border-radius:12px;border:1px solid #e5e7eb;margin:12px 0}
.cb-cover-small{width:240px;max-width:40%;aspect-ratio:16/9;object-fit:cover;float:right;margin-left:12px;margin-bottom:8px;border-radius:10px;border:1px solid #e5e7eb;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.cb-footer-single{margin-top:22px}

/* --- Video Embed --- */
.cb-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:10px;border:1px solid #e5e7eb;margin:16px 0}
.cb-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%}

/* --- Prose (content formatting) --- */
.cb-prose{color:#111827;line-height:1.75;font-size:17px}
.cb-prose h1,.cb-prose h2,.cb-prose h3{margin:18px 0 10px;line-height:1.25}
.cb-prose h1{font-size:28px}
.cb-prose h2{font-size:22px}
.cb-prose h3{font-size:18px}
.cb-prose p{margin:12px 0;font-size:17px}
.cb-prose ul,.cb-prose ol{margin:10px 0 10px 20px}
.cb-prose blockquote{margin:14px 0;padding:10px 14px;border-left:3px solid #3b82f6;background:#f8fafc}
.cb-prose img{max-width:100%;border-radius:8px;border:1px solid #e5e7eb}
.cb-prose a{color:#1d4ed8}

/* --- Reading Progress --- */
.cb-progress{position:fixed;top:0;left:0;width:100%;height:3px;background:transparent;z-index:9999}
.cb-progress-bar{height:100%;width:0;background:#3b82f6;transition:width .1s linear}

/* Helpers */
.cb-single::after{content:"";display:block;clear:both}
@media (max-width: 768px){
  .cb-cover-small{float:none;width:100%;max-width:100%;margin-left:0}
}

/* --- Estilos para Categorias, Tags e Arquivo --- */
.cb-category-header,
.cb-tag-header,
.cb-archive-header {
  padding: 20px 0;
  margin-bottom: 30px;
  border-bottom: 2px solid #e5e7eb;
}

.cb-category-title,
.cb-tag-title,
.cb-archive-title {
  font-size: 32px;
  font-weight: 700;
  color: #111827;
  margin-bottom: 10px;
}

.cb-category-description,
.cb-tag-description,
.cb-archive-description {
  font-size: 16px;
  color: #6b7280;
  margin-top: 8px;
}

/* Grade de cartões melhorada para categorias/tags/arquivo */
.cb-category-grid,
.cb-tag-grid,
.cb-archive-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 24px;
  margin-top: 30px;
}

/* Cartão melhorado */
.cb-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  overflow: hidden;
  transition: all 0.3s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.cb-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
  border-color: #cbd5e1;
}

.cb-card-image {
  position: relative;
  padding-bottom: 56.25%; /* Aspect ratio 16:9 */
  overflow: hidden;
  background: #f3f4f6;
}

.cb-card-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cb-card-body {
  padding: 20px;
}

.cb-card-category {
  display: inline-block;
  padding: 4px 12px;
  background: #eff6ff;
  color: #1e40af;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  border-radius: 4px;
  margin-bottom: 10px;
}

.cb-card-title {
  font-size: 20px;
  font-weight: 700;
  color: #111827;
  margin-bottom: 10px;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cb-card-excerpt {
  color: #6b7280;
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 15px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cb-card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  color: #9ca3af;
  padding-top: 15px;
  border-top: 1px solid #f3f4f6;
}

.cb-card-date {
  display: flex;
  align-items: center;
}

.cb-card-date i {
  margin-right: 5px;
}

.cb-card-author {
  display: flex;
  align-items: center;
}

.cb-card-author i {
  margin-right: 5px;
}

/* --- Magazine Layout --- */
.cb-magazine {
  padding: 30px 15px;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

/* Container principal com destaque + laterais */
.cb-magazine-top {
  display: flex;
  gap: 20px;
  margin-bottom: 40px;
}

/* Post Destacado Principal */
.cb-magazine-featured {
  flex: 1;
  background: #fff;
  border-radius: 7px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.cb-magazine-featured-image {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9 */
  overflow: hidden;
  background: #f5f5f5;
}

.cb-magazine-featured-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 7px 7px 0 0;
}

.cb-magazine-featured:hover img {
  transform: scale(1.03);
  transition: transform 0.3s ease;
}

.cb-magazine-featured-content {
  padding: 25px;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.cb-magazine-featured-category {
  display: inline-block;
  padding: 4px 10px;
  background: #6b7280;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  text-align: center;
  border-radius: 3px;
  margin: 0 auto 15px auto;
  text-decoration: none;
}

.cb-magazine-featured-title {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 10px 0;
}

.cb-magazine-featured-title a {
  color: #1a1a1a;
  text-decoration: none;
}

.cb-magazine-featured-title a:hover {
  color: #0066cc;
}

.cb-magazine-featured-excerpt {
  color: #666;
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 12px;
}

.cb-magazine-featured-meta {
  color: #999;
  font-size: 12px;
  margin-bottom: 20px; /* Aumenta espaço antes do botão */
}

.cb-magazine-featured-meta i {
  margin-right: 5px;
}

.cb-magazine-featured-button {
  display: inline-block;
  padding: 8px 16px;
  background: #1a1a1a;
  color: #fff !important;
  text-decoration: none !important;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 600;
  transition: all 0.3s ease;
  margin-top: auto; /* Empurra o botão para baixo */
}

.cb-magazine-featured-button:hover {
  background: #333;
  transform: translateX(3px);
}

.cb-magazine-featured-button i {
  margin-left: 5px;
  font-size: 12px;
}

/* Posts Laterais - 4 items */
.cb-magazine-side {
  width: 420px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cb-magazine-side-item {
  display: flex;
  background: #fff;
  border-radius: 7px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  transition: transform 0.2s ease;
  height: auto;
}

.cb-magazine-side-item:hover {
  transform: translateX(-3px);
}

.cb-magazine-side-image {
  width: 130px;
  height: 73px; /* 130 * 9/16 = 73px para 16:9 */
  overflow: hidden;
  flex-shrink: 0;
}

.cb-magazine-side-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 7px 0 0 7px;
}

.cb-magazine-side-content {
  padding: 12px 15px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cb-magazine-side-category {
  display: inline-block;
  padding: 2px 8px;
  background: #4b5563;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  text-align: center;
  border-radius: 2px;
  margin-bottom: 6px;
  text-decoration: none;
  align-self: center;
}

.cb-magazine-side-title {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 5px;
}

.cb-magazine-side-title a {
  color: #1a1a1a;
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cb-magazine-side-title a:hover {
  color: #0066cc;
}

.cb-magazine-side-date {
  color: #999;
  font-size: 11px;
}

/* Seção inferior com posts em grade */
.cb-magazine-bottom {
  margin-top: 40px; /* Reduz margem pois já temos espaço do destaque */
  padding-top: 40px;
  border-top: 3px solid #e5e7eb; /* Borda mais grossa para separar */
}

.cb-magazine-section-title {
  font-size: 28px;
  font-weight: 700;
  color: #111827;
  margin-bottom: 30px;
  text-align: center;
}

.cb-magazine-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 cards por linha */
  gap: 30px; /* Espaçamento entre cards */
  margin-top: 40px;
}

.cb-magazine-grid-item {
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
}

.cb-magazine-grid-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

.cb-magazine-grid-image {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9 Aspect Ratio */
  overflow: hidden;
  background: #f3f4f6;
  border-radius: 10px 10px 0 0;
}

.cb-magazine-grid-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 10px 10px 0 0;
  transition: transform 0.3s ease;
}

.cb-magazine-grid-item:hover .cb-magazine-grid-image img {
  transform: scale(1.05);
}

.cb-magazine-grid-content {
  padding: 20px;
}

.cb-magazine-grid-title {
  font-size: 18px;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 10px;
}

.cb-magazine-grid-title a {
  color: #111827;
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cb-magazine-grid-title a:hover {
  color: #2563eb;
}

.cb-magazine-grid-excerpt {
  color: #6b7280;
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 15px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cb-magazine-grid-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 15px;
  border-top: 1px solid #f3f4f6;
}

.cb-magazine-grid-date {
  color: #9ca3af;
  font-size: 13px;
}

.cb-magazine-grid-link {
  color: #2563eb;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.2s ease;
}

.cb-magazine-grid-link:hover {
  color: #1d4ed8;
}

/* Responsividade */
@media (max-width: 1200px) {
  .cb-magazine {
    padding: 30px 10%; /* Reduz padding lateral em telas menores */
  }
}

@media (max-width: 992px) {
  .cb-magazine {
    padding: 30px 5%; /* Reduz ainda mais o padding */
  }
  
  .cb-magazine-top {
    grid-template-columns: 1fr; /* Uma coluna em mobile */
    gap: 30px;
    margin-bottom: 40px;
  }
  
  .cb-magazine-side {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  
  .cb-magazine-side-item {
    flex-direction: column;
    text-align: center;
    padding: 15px;
    min-height: auto;
  }
  
  .cb-magazine-side-image {
    width: 100%;
    height: 180px; /* Altura retangular em mobile */
    margin-right: 0;
    margin-bottom: 15px;
  }
  
  .cb-magazine-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .cb-magazine-featured-title {
    font-size: 24px;
  }
  
  .cb-magazine-side {
    grid-template-columns: 1fr;
  }
  
  .cb-magazine-side-item {
    flex-direction: row;
    text-align: left;
  }
  
  .cb-magazine-side-image {
    width: 80px;
    height: 80px;
    margin-right: 12px;
    margin-bottom: 0;
  }
  
  .cb-magazine-grid {
    grid-template-columns: 1fr;
  }
}

/* Responsividade */
@media (max-width: 1024px) {
  .cb-category-grid,
  .cb-tag-grid,
  .cb-archive-grid {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
  }
}

@media (max-width: 768px) {
  .cb-category-grid,
  .cb-tag-grid,
  .cb-archive-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .cb-category-title,
  .cb-tag-title,
  .cb-archive-title {
    font-size: 24px;
  }
}
/* Updated: Mon Sep  8 02:16:58 AM UTC 2025 */
