/* ==========================================================================  
   6. LAYOUT PRINCIPAL DA HOME
   ========================================================================== */
.home-grid {
  display: grid;
  gap: 2rem 1.5rem;
  margin-top: 1rem;
  padding: 2rem 0;
}
.home-grid.with-sidebar {
  grid-template-areas:
    "ticker ticker"
    "slider slider"
    "latest sidebar"
    "cats   sidebar";
  grid-template-columns: 3fr 1fr;
}
.home-grid.no-sidebar {
  grid-template-areas:
    "ticker ticker"
    "slider slider"
    "latest latest"
    "cats   cats";
  grid-template-columns: 1fr;
}
.home-grid.no-sidebar .latest-news,
.home-grid.no-sidebar .category-sections {
  padding-right: 0;
}

/* ==========================================================================  
   7. ÁREAS DO GRID
   ========================================================================== */
.news-ticker       { grid-area: ticker; }
.featured-sliderhome1   { grid-area: slider; }
.latest-news       { grid-area: latest; margin-top: 2rem; }
.category-sections { grid-area: cats; }
.sidebar-widgets   { grid-area: sidebar; }

/* ==========================================================================  
   8. NEWS TICKER – OVERLAY MODERNO
   ========================================================================== */
.news-ticker.modern {
  margin: 2rem 0;
  position: relative;
  overflow: hidden;
}
.news-ticker.modern .ticker-window {
  position: relative;
  padding: .75rem 2.5rem;
  background: #fff;
  box-shadow: inset 0 0 0 2px var(--color-link);
  border-radius: 8px;
}
.news-ticker.modern .ticker-track {
  display: flex;
  gap: 2rem;
  animation: ticker-scroll 30s linear infinite;
  will-change: transform;
}
.news-ticker.modern .ticker-item {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.news-ticker.modern .ticker-cat {
  background: var(--color-link);
  color: #fff;
  padding: .2rem .6rem;
  border-radius: 3px;
  font-size: .75rem;
  text-transform: uppercase;
}
.news-ticker.modern .ticker-item a {
  color: var(--color-text);
  text-decoration: none;
  font-weight: 500;
}
.news-ticker.modern .ticker-item a:hover {
  color: var(--color-link-hover);
}
.news-ticker.modern .ticker-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2rem;
  height: 2rem;
  background: var(--color-link);
  color: #fff;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  opacity: .7;
  cursor: pointer;
  transition: opacity .3s;
  z-index: 2;
}
.news-ticker.modern .ticker-btn:hover {
  opacity: 1;
}
.news-ticker.modern .ticker-btn.prev { left: .5rem; }
.news-ticker.modern .ticker-btn.next { right: .5rem; }
.news-ticker.modern::before,
.news-ticker.modern::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 4rem;
  pointer-events: none;
  z-index: 1;
}
.news-ticker.modern::before {
  left: 0;
  background: linear-gradient(to right, #fff, transparent);
}
.news-ticker.modern::after {
  right: 0;
  background: linear-gradient(to left, #fff, transparent);
}
.news-ticker.modern:hover .ticker-track {
  animation-play-state: paused;
}
@keyframes ticker-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ==========================================================================  
   9. FEATURED SLIDER (SWIPER)
   ========================================================================== */
.featured-sliderhome1 {
  position: relative;
  height: 45vh;
  min-height: 280px;
  border-radius: 8px;
  overflow: hidden;
  margin-top: 1rem;
  margin-left: 1rem;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}
.featured-sliderhome1 .swiper-container,
.featured-sliderhome1 .swiper-wrapper {
  width: 100%;
  height: 100%;
}
.featured-sliderhome1 .swiper-slide {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.featured-sliderhome1 .swiper-slide img.swiper-lazy {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.featured-sliderhome1 .slide-content {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background: rgba(0,0,0,0.5);
  padding: .75rem 1rem;
  box-sizing: border-box;
}
.featured-sliderhome1 .slide-content .slide-title {
  color: #fff;
  text-shadow: 0 2px 4px rgba(0,0,0,0.7);
  font-size: 1.75rem;
  font-weight: bold;
  margin: 0 0 .3rem;
}
.featured-sliderhome1 .slide-content .slide-date {
  color: #fff;
  font-size: .9rem;
  text-shadow: 0 1px 3px rgba(0,0,0,0.6);
}
.featured-sliderhome1 .swiper-button-next,
.featured-sliderhome1 .swiper-button-prev {
  width: 2.5rem;
  height: 2.5rem;
  background: rgba(0,0,0,0.4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .3s ease, transform .3s ease;
}
.featured-sliderhome1 .swiper-button-next:hover,
.featured-slider .swiper-button-prev:hover {
  background: rgba(0,0,0,0.6);
  transform: scale(1.1);
}
.featured-sliderhome1 .swiper-button-next::after,
.featured-slider .swiper-button-prev::after {
  font-size: 1.2rem;
  color: #fff;
}
.featured-sliderhome1 .swiper-button-next { right: 15px; }
.featured-sliderhome1 .swiper-button-prev { left: 15px; }

/* ==========================================================================  
 10. ÚLTIMAS NOTÍCIAS (GRID / CARDS)
   ========================================================================== */
.latest-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px,1fr));
  gap: 1.5rem;
  align-items: start;
}
.latest-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
  transition: transform .3s, box-shadow .3s;
}
.latest-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.card-thumb { width: 100%; position: relative; padding-top: 56.25%; overflow: hidden; }
.card-thumb img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.card-body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 1rem;
  flex: 1;
}
.card-body .card-title { font-size: 1.125rem; margin: 0 0 .5rem; line-height: 1.3; }
.card-body .card-date { font-size: .875rem; color: #777; margin-bottom: .75rem; }
.card-body .card-excerpt { font-size: .95rem; color: #555; margin-top: .5rem; flex-grow: 1; }

/* ==========================================================================  
 11. SEÇÕES POR CATEGORIA
   ========================================================================== */
.category-sections { margin-top: 2rem; }
.category-block { margin-bottom: 2rem; }
.category-header { padding: 1rem 0; }
.category-title a {
  font-size: 1.5rem;
  font-weight: bold;
  color: var(--color-link);
  text-decoration: none;
}
.category-title a::after {
  content: '→';
  margin-left: .5rem;
  transition: transform .3s;
}
.category-title a:hover::after {
  transform: translateX(4px);
}
.category-desc {
  font-size: 1rem;
  color: #555;
  margin-top: .5rem;
}

/* 11.1 Featured Grid (1 grande + 2 pequenos) */
.category-block.layout-featured .category-grid {
    padding: 0rem;                       /* espaço interno */
  box-sizing: border-box;              /* inclui o padding no cálculo de largura */
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: repeat(2,250px);
  gap: 1.5rem;
}
.category-block.layout-featured .category-card {
  position: relative;
  height: 100%;
  overflow: hidden;
  border-radius: 6px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
  transition: transform .3s, box-shadow .3s;
}
.category-block.layout-featured .category-card:nth-child(1) {
  grid-column: 1/2;
  grid-row: 1/span 2;
}
.category-block.layout-featured .category-card:nth-child(2) {
  grid-column: 2/3;
  grid-row: 1/2;
}
.category-block.layout-featured .category-card:nth-child(3) {
  grid-column: 2/3;
  grid-row: 2/3;
}
.category-block.layout-featured .category-card .card-thumb {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.category-block.layout-featured .category-card .card-body {
  position: absolute;
  bottom: 0; left: 0;
  width: 100%;
  padding: 1rem;
  background: linear-gradient(180deg, rgba(0,0,0,0.3), rgba(0,0,0,0.85));
}
.category-block.layout-featured .category-card .card-title,
.category-block.layout-featured .category-card .card-date {
  color: #fff;
  text-shadow: 0 2px 4px rgba(0,0,0,0.7);
}
.category-block.layout-featured .category-card .card-title {
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0 0 .25rem;
}
.category-block.layout-featured .category-card .card-date {
  font-size: .85rem;
}

/* 11.2 Grid Secundário */
.category-block.layout-grid .category-grid {
  padding: 0rem;                       /* espaço interno */
  box-sizing: border-box;              /* inclui o padding no cálculo de largura */
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap: 1rem;
}
.category-block.layout-grid .grid-card {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: #fafafa;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
  transition: transform .3s, box-shadow .3s;
}
.category-block.layout-grid .grid-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 4px 10px rgba(0,0,0,0.12);
}
.category-block.layout-grid .grid-card .card-thumb {
  border-bottom: 3px solid var(--color-link);
}
.category-block.layout-grid .grid-card .card-body {
  padding: .75rem;
}
.category-block.layout-grid .grid-card .card-title {
  font-size: 1rem;
  color: #fff;
  text-shadow: 0 2px 4px rgba(0,0,0,0.7);
  margin-bottom: .25rem;
}
/* ==========================================================================  
   6.1 Ajuste de padding nas seções para alinhar títulos/pseudo‑elementos
   ========================================================================== */
.news-ticker.modern,
.featured-sliderhome1,
.latest-news,
.category-sections,
.sidebar-widgets {
  padding: 1rem;        /* cria respiro interno */
  margin-right: 1rem;
  box-sizing: border-box;
}