/*
 * CULTURA POP EM CASA — MAIN STYLESHEET
 * Todos os componentes do tema
 */

/* ============================================================
   1. RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--font-normal);
  line-height: var(--leading-normal);
  color: var(--color-text-primary);
  background-color: var(--color-bg-base);
  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

img, video {
  max-width: 100%;
  height: auto;
  display: block;
}

ul, ol { list-style: none; }

button {
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
}

/* Acessibilidade — skip link */
.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-4);
  padding: var(--space-2) var(--space-4);
  background: var(--color-accent);
  color: #fff;
  border-radius: var(--radius-md);
  font-weight: var(--font-bold);
  z-index: var(--z-toast);
  transition: top var(--duration-fast);
}
.skip-link:focus { top: var(--space-4); }

/* ============================================================
   2. LAYOUT — CONTAINER
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container-xl);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

.container--wide { max-width: var(--container-2xl); }
.container--narrow { max-width: var(--container-lg); }

.site-wrapper {
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 100vh;
}

/* Layout de duas colunas (conteúdo + sidebar) */
.content-with-sidebar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--sidebar-width);
  gap: var(--gap-lg);
  align-items: start;
}

/* ============================================================
   3. TOPBAR — BARRA SUPERIOR
   ============================================================ */
.topbar {
  background: #07071A;
  border-bottom: 1px solid var(--color-border);
  height: var(--topbar-height);
  display: flex;
  align-items: center;
}

.topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  width: 100%;
  max-width: var(--container-2xl);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

.topbar__date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
}

.topbar__social {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.topbar__social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) var(--ease-out);
}
.topbar__social a:hover { color: var(--color-accent); }

.topbar__links {
  display: flex;
  gap: var(--space-4);
}
.topbar__links a {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--font-heading);
  font-weight: var(--font-semi);
}
.topbar__links a:hover { color: var(--color-accent); }

/* ============================================================
   4. BREAKING NEWS TICKER
   ============================================================ */
.breaking-news {
  background: var(--color-accent);
  overflow: hidden;
  height: 36px;
  display: flex;
  align-items: center;
}

.breaking-news__label {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-4);
  background: rgba(0,0,0,0.3);
  height: 100%;
  font-family: var(--font-display);
  font-size: var(--text-sm);
  letter-spacing: 0.08em;
  color: #fff;
  white-space: nowrap;
}

.breaking-news__label .dot {
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: 50%;
  animation: blink 1s ease infinite;
}

@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.2; }
}

.breaking-news__track {
  flex: 1;
  overflow: hidden;
}

.breaking-news__inner {
  display: flex;
  gap: 0;
  animation: ticker 40s linear infinite;
  white-space: nowrap;
}

.breaking-news__inner:hover { animation-play-state: paused; }

@keyframes ticker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.breaking-news__item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
  padding: 0 var(--space-8);
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  color: #fff;
}
.breaking-news__item a { color: #fff; }
.breaking-news__item a:hover { text-decoration: underline; }
.breaking-news__item::before {
  content: '◆';
  font-size: 8px;
  opacity: 0.5;
}

/* ============================================================
   5. HEADER
   ============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: rgba(11, 11, 30, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--color-border);
  transition: all var(--duration-base) var(--ease-out);
}

.site-header.scrolled {
  box-shadow: 0 4px 32px rgba(0,0,0,0.5);
  background: rgba(11, 11, 30, 0.98);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-height);
  gap: var(--space-6);
}

/* Logo */
.site-logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  text-decoration: none;
}

.site-logo__img {
  height: 44px;
  width: auto;
}

.site-logo__text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.site-logo__title {
  font-family: var(--font-display);
  font-size: 1.6rem;
  letter-spacing: 0.04em;
  background: var(--gradient-brand);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.site-logo__subtitle {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-weight: var(--font-semi);
}

/* Navegação Principal */
.nav-primary {
  flex: 1;
  display: flex;
  justify-content: center;
}

.nav-primary__list {
  display: flex;
  align-items: center;
  gap: 0;
}

.nav-primary__item {
  position: relative;
}

.nav-primary__link {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-secondary);
  border-radius: var(--radius-md);
  transition: all var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}

.nav-primary__link:hover,
.nav-primary__item.current-menu-item .nav-primary__link {
  color: var(--color-text-primary);
}

.nav-primary__item.cat--filmes .nav-primary__link:hover     { color: var(--cat-filmes); }
.nav-primary__item.cat--series .nav-primary__link:hover     { color: var(--cat-series); }
.nav-primary__item.cat--animes .nav-primary__link:hover     { color: var(--cat-animes); }
.nav-primary__item.cat--games .nav-primary__link:hover      { color: var(--cat-games); }
.nav-primary__item.cat--quadrinhos .nav-primary__link:hover { color: var(--cat-quadrinhos); }

/* Linha ativa embaixo */
.nav-primary__item.current-menu-item .nav-primary__link::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: var(--space-4);
  right: var(--space-4);
  height: 2px;
  background: var(--gradient-brand);
  border-radius: var(--radius-full);
}

/* Dropdown */
.nav-primary__item:hover .nav-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-dropdown {
  position: absolute;
  top: calc(100% + var(--space-2));
  left: 0;
  min-width: 220px;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-2);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--duration-base) var(--ease-out);
  box-shadow: var(--shadow-xl);
  z-index: var(--z-dropdown);
}

.nav-dropdown a {
  display: block;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  border-radius: var(--radius-md);
}
.nav-dropdown a:hover {
  background: var(--color-border);
  color: var(--color-text-primary);
}

/* Header Actions */
.header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.header-search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  color: var(--color-text-secondary);
  transition: all var(--duration-fast) var(--ease-out);
}
.header-search-btn:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}

.header-menu-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  color: var(--color-text-secondary);
  flex-direction: column;
  gap: 5px;
}
.header-menu-btn span {
  display: block;
  width: 20px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  transition: all var(--duration-base) var(--ease-out);
}
.header-menu-btn.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.header-menu-btn.active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.header-menu-btn.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* Search Overlay */
.search-overlay {
  position: fixed;
  inset: 0;
  background: var(--color-bg-overlay);
  backdrop-filter: blur(8px);
  z-index: var(--z-modal);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 15vh;
  opacity: 0;
  visibility: hidden;
  transition: all var(--duration-base) var(--ease-out);
}

.search-overlay.active {
  opacity: 1;
  visibility: visible;
}

.search-overlay__inner {
  width: 100%;
  max-width: 700px;
  padding-inline: var(--space-6);
}

.search-overlay__form {
  display: flex;
  align-items: center;
  background: var(--color-bg-surface);
  border: 2px solid var(--color-accent);
  border-radius: var(--radius-full);
  overflow: hidden;
  box-shadow: var(--shadow-glow);
}

.search-overlay__input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-lg);
  color: var(--color-text-primary);
  font-family: var(--font-body);
}
.search-overlay__input::placeholder { color: var(--color-text-muted); }

.search-overlay__submit {
  padding: var(--space-3) var(--space-6);
  background: var(--gradient-brand);
  color: #fff;
  border: none;
  font-size: var(--text-lg);
  cursor: pointer;
}

.search-overlay__close {
  display: block;
  margin: var(--space-4) auto 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  background: none;
  border: none;
  cursor: pointer;
}
.search-overlay__close:hover { color: var(--color-text-primary); }

/* ============================================================
   6. HERO SLIDER
   ============================================================ */
.hero {
  position: relative;
  height: clamp(460px, 60vh, 680px);
  overflow: hidden;
  background: var(--gradient-hero);
}

.hero__slider {
  position: relative;
  width: 100%;
  height: 100%;
}

.hero__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity var(--duration-slower) var(--ease-in-out);
}

.hero__slide.active { opacity: 1; z-index: 2; }
.hero__slide.prev   { opacity: 0; z-index: 1; }

.hero__slide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,0.85) 40%, rgba(0,0,0,0.3) 70%, transparent 100%),
              linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 50%);
}

.hero__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-12) 0;
  z-index: 3;
}

.hero__content .container {
  display: flex;
  align-items: flex-end;
  gap: var(--space-8);
}

.hero__info {
  max-width: 650px;
  flex: 1;
}

.hero__badge {
  margin-bottom: var(--space-3);
}

.hero__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  line-height: var(--leading-tight);
  color: #fff;
  margin-bottom: var(--space-4);
  text-shadow: 0 2px 20px rgba(0,0,0,0.8);
  letter-spacing: 0.02em;
}

.hero__excerpt {
  font-size: var(--text-base);
  color: rgba(255,255,255,0.8);
  line-height: var(--leading-snug);
  margin-bottom: var(--space-6);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.hero__meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.6);
  font-family: var(--font-heading);
  font-weight: var(--font-semi);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.hero__meta span { display: flex; align-items: center; gap: var(--space-1); }

.hero__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* Thumbnails do hero (posts secundários à direita) */
.hero__thumbs {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  width: 280px;
  flex-shrink: 0;
}

.hero__thumb {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-3);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: all var(--duration-fast) var(--ease-out);
  backdrop-filter: blur(4px);
  cursor: pointer;
}
.hero__thumb:hover,
.hero__thumb.active {
  background: rgba(255,45,107,0.15);
  border-color: rgba(255,45,107,0.4);
}

.hero__thumb-img {
  width: 72px;
  height: 48px;
  object-fit: cover;
  border-radius: var(--radius-md);
  flex-shrink: 0;
}

.hero__thumb-info {
  flex: 1;
  overflow: hidden;
}

.hero__thumb-cat {
  font-size: 10px;
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-accent);
  margin-bottom: 4px;
}

.hero__thumb-title {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.9);
  line-height: var(--leading-snug);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-weight: var(--font-semi);
}

/* Controles do slider */
.hero__controls {
  position: absolute;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: var(--space-2);
  z-index: 10;
}

.hero__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.3);
  border: none;
  cursor: pointer;
  transition: all var(--duration-base) var(--ease-out);
}
.hero__dot.active {
  width: 28px;
  background: var(--color-accent);
}

/* ============================================================
   7. SECTION HEADER
   ============================================================ */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.section-title {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: 0.04em;
  color: var(--color-text-primary);
}

.section-title__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: var(--gradient-brand);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}

.section-title--cat-filmes     .section-title__icon { background: linear-gradient(135deg, var(--cat-filmes), #FF6B6B); }
.section-title--cat-series     .section-title__icon { background: linear-gradient(135deg, var(--cat-series), #A855F7); }
.section-title--cat-animes     .section-title__icon { background: linear-gradient(135deg, var(--cat-animes), #0EA5E9); }
.section-title--cat-games      .section-title__icon { background: linear-gradient(135deg, var(--cat-games), #10B981); }
.section-title--cat-quadrinhos .section-title__icon { background: linear-gradient(135deg, var(--cat-quadrinhos), #EF4444); }

.section-link {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-accent);
  display: flex;
  align-items: center;
  gap: var(--space-1);
  transition: gap var(--duration-fast);
}
.section-link:hover { gap: var(--space-2); }

/* ============================================================
   8. POST CARD
   ============================================================ */
.posts-grid {
  display: grid;
  grid-template-columns: var(--cols-4);
  gap: var(--gap-md);
}

.posts-grid--3 { grid-template-columns: var(--cols-3); }
.posts-grid--2 { grid-template-columns: var(--cols-2); }

.post-card {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--duration-base) var(--ease-out);
  display: flex;
  flex-direction: column;
}

.post-card:hover {
  border-color: var(--color-border-light);
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.post-card__img-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
  background: var(--color-bg-elevated);
}

.post-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease-out);
}
.post-card:hover .post-card__img { transform: scale(1.05); }

.post-card__badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  z-index: 2;
}

.post-card__video-icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.3);
}
.post-card__video-icon svg {
  width: 44px;
  height: 44px;
  color: #fff;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.5));
}

.post-card__body {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.post-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  line-height: var(--leading-snug);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color var(--duration-fast);
}
.post-card:hover .post-card__title { color: var(--color-accent); }

.post-card__excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-4);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}

.post-card__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}

.post-card__author {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex: 1;
  overflow: hidden;
}

.post-card__avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--color-bg-elevated);
}

.post-card__author-name {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: var(--font-semi);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.post-card__date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  white-space: nowrap;
}

.post-card__reading-time {
  font-size: var(--text-xs);
  color: var(--color-text-disabled);
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 3px;
}

/* Card variante horizontal */
.post-card--horizontal {
  flex-direction: row;
  align-items: stretch;
}
.post-card--horizontal .post-card__img-wrap {
  width: 130px;
  flex-shrink: 0;
  aspect-ratio: auto;
}
.post-card--horizontal .post-card__body {
  padding: var(--space-3);
}
.post-card--horizontal .post-card__title {
  font-size: var(--text-sm);
  -webkit-line-clamp: 3;
}

/* Card variante large (destaque) */
.post-card--large .post-card__title {
  font-size: var(--text-xl);
  font-family: var(--font-display);
  letter-spacing: 0.02em;
  -webkit-line-clamp: 4;
}
.post-card--large .post-card__body { padding: var(--space-6); }

/* Card overlay (texto sobre imagem) */
.post-card--overlay {
  position: relative;
  border: none;
}
.post-card--overlay .post-card__img-wrap {
  aspect-ratio: 4/5;
  height: 100%;
}
.post-card--overlay .post-card__body {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-4);
  background: var(--gradient-card-alt);
}
.post-card--overlay .post-card__title { color: #fff; margin-bottom: 0; }
.post-card--overlay .post-card__meta  { border-top: none; padding-top: var(--space-2); }
.post-card--overlay .post-card__date  { color: rgba(255,255,255,0.6); }
.post-card--overlay:hover { transform: none; }

/* ============================================================
   9. FEATURED GRID — Destaque da Homepage
   ============================================================ */
.featured-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: var(--gap-md);
}

.featured-grid__main {
  grid-column: 1 / 3;
  grid-row: 1 / 3;
}

.featured-grid__main .post-card--overlay .post-card__img-wrap {
  aspect-ratio: 4/3;
}

.featured-grid__main .post-card__title {
  font-size: var(--text-2xl);
  font-family: var(--font-display);
  letter-spacing: 0.03em;
}

.featured-grid__side {
  grid-column: 3;
  display: flex;
  flex-direction: column;
  gap: var(--gap-md);
}

/* ============================================================
   10. SIDEBAR
   ============================================================ */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.widget {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.widget__title {
  display: flex;
  align-items: center;
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: 0.06em;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  position: relative;
}
.widget__title span::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 1em;
  background: var(--gradient-brand);
  border-radius: 2px;
  margin-right: var(--space-3);
  vertical-align: middle;
}

.widget__body { padding: var(--space-4) var(--space-5); }

/* Widget: Posts Populares */
.widget-popular__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.widget-popular__item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
}

.widget-popular__number {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: 1;
  color: var(--color-border-light);
  width: 28px;
  flex-shrink: 0;
  margin-top: 2px;
}

.widget-popular__item:nth-child(1) .widget-popular__number { color: var(--color-accent); }
.widget-popular__item:nth-child(2) .widget-popular__number { color: var(--color-purple); }
.widget-popular__item:nth-child(3) .widget-popular__number { color: var(--color-orange); }

.widget-popular__content { flex: 1; }

.widget-popular__title {
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  line-height: var(--leading-snug);
  color: var(--color-text-primary);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: var(--space-1);
}
.widget-popular__title:hover { color: var(--color-accent); }

.widget-popular__date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* Widget: Categorias */
.widget-categories__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.widget-categories__item a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  color: var(--color-text-secondary);
  transition: all var(--duration-fast);
}
.widget-categories__item a:hover {
  background: var(--color-bg-elevated);
  color: var(--color-accent);
  padding-left: var(--space-4);
}
.widget-categories__count {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  background: var(--color-bg-elevated);
  padding: 2px 8px;
  border-radius: var(--radius-full);
}

/* Widget: Newsletter */
.widget-newsletter {
  background: var(--gradient-hero);
  border-color: var(--color-border-light);
}

.widget-newsletter__body {
  padding: var(--space-6);
  text-align: center;
}
.widget-newsletter__icon { font-size: 2rem; margin-bottom: var(--space-3); }
.widget-newsletter__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-2);
}
.widget-newsletter__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}
.widget-newsletter__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.widget-newsletter__input {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  outline: none;
  transition: border-color var(--duration-fast);
}
.widget-newsletter__input:focus { border-color: var(--color-accent); }
.widget-newsletter__input::placeholder { color: var(--color-text-muted); }

/* ============================================================
   11. AD SLOTS — Áreas de Anúncio (AdSense Compliant)
   ============================================================ */
.ad-slot {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-surface);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
}

.ad-slot::before {
  content: 'Publicidade';
  position: absolute;
  top: 4px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 9px;
  color: var(--color-text-disabled);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-family: var(--font-heading);
  font-weight: var(--font-semi);
  pointer-events: none;
  z-index: 1;
}

.ad-slot--leaderboard {
  height: 90px;
  min-height: 90px;
  margin: var(--space-6) 0;
}

.ad-slot--rectangle {
  min-height: 250px;
}

.ad-slot--in-content {
  min-height: 280px;
  margin: var(--space-8) 0;
}

.ad-slot--full-width {
  width: 100%;
  min-height: 90px;
}

/* ============================================================
   12. MAIN CONTENT — SECTIONS
   ============================================================ */
.site-main { padding-block: var(--space-8); }

.content-section {
  margin-bottom: var(--space-12);
}

/* ============================================================
   13. BREADCRUMB
   ============================================================ */
.breadcrumb {
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-8);
}

.breadcrumb__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.breadcrumb__item {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  font-weight: var(--font-semi);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.breadcrumb__link { color: var(--color-text-muted); }
.breadcrumb__link:hover { color: var(--color-accent); }
.breadcrumb__item--current { color: var(--color-text-secondary); }
.breadcrumb__sep { color: var(--color-border-light); }

/* ============================================================
   14. SINGLE POST — LAYOUT REDESENHADO
   ============================================================ */

/* Wrapper do breadcrumb no single */
.single-breadcrumb-wrap {
  border-bottom: 1px solid var(--color-border);
}
.single-breadcrumb-wrap .breadcrumb {
  border-bottom: none;
  margin-bottom: 0;
  padding: var(--space-3) 0;
}

/* Layout container do single */
.single-layout {
  padding-top: var(--space-6);
  padding-bottom: var(--space-12);
}

/* Grid: artigo + sidebar */
.single-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: var(--space-10);
  align-items: start;
}

/* Coluna do artigo */
.single-article {
  min-width: 0;
}

/* ── HEADER DO POST ── */
.single-header {
  margin-bottom: var(--space-6);
}

.single-header__cats {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}

.single-header__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: var(--leading-tight);
  letter-spacing: 0.02em;
  color: var(--color-text-primary);
  margin-bottom: var(--space-4);
}

.single-header__subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  line-height: var(--leading-snug);
  border-left: 3px solid var(--color-accent);
  padding-left: var(--space-4);
  margin-bottom: var(--space-5);
  font-style: italic;
}

/* ── BYLINE ── */
.single-byline {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) 0;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.single-byline__author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.single-byline__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--color-border);
  background: var(--color-bg-elevated);
}

.single-byline__author-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.single-byline__name {
  font-weight: var(--font-bold);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  text-decoration: none;
}
.single-byline__name:hover { color: var(--color-accent); }

.single-byline__role {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.single-byline__meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.single-byline__meta span {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  font-weight: var(--font-semi);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  display: flex;
  align-items: center;
  gap: 5px;
}

/* ── SHARE BUTTONS ── */
.single-byline__share {
  display: flex;
  gap: var(--space-2);
  margin-left: auto;
  align-items: center;
}

.share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  background: var(--color-bg-surface);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
  text-decoration: none;
}
.share-btn:hover { transform: translateY(-2px); }
.share-btn--twitter:hover  { background: #000;     border-color: #000;     color: #fff; }
.share-btn--facebook:hover { background: #1877F2;  border-color: #1877F2;  color: #fff; }
.share-btn--whatsapp:hover { background: #25D366;  border-color: #25D366;  color: #fff; }
.share-btn--copy:hover     { background: var(--color-accent); border-color: var(--color-accent); color: #fff; }

/* Share final bar */
.single-share-final {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-8);
  padding: var(--space-5);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.single-share-final__label {
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.share-btn--lg {
  width: auto;
  height: 36px;
  padding: 0 var(--space-4);
  gap: var(--space-2);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: var(--radius-full);
}

/* ── IMAGEM DESTACADA ── */
.single-featured-figure {
  margin: 0 0 var(--space-2);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.single-featured-img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}

.single-featured-caption {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-align: center;
  padding: var(--space-2) var(--space-4) var(--space-6);
  font-style: italic;
}

/* ── AUTHOR BOX ── */
.author-box {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
  padding: var(--space-6);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius-xl);
  margin-top: var(--space-8);
}

.author-box__avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 3px solid var(--color-border);
  background: var(--color-bg-elevated);
}

.author-box__info { flex: 1; }

.author-box__label {
  font-size: var(--text-xs);
  color: var(--color-accent);
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-1);
}

.author-box__name {
  display: block;
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  text-decoration: none;
  margin-bottom: var(--space-2);
}
.author-box__name:hover { color: var(--color-accent); }

.author-box__bio {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-3);
}

.author-box__link {
  font-size: var(--text-xs);
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-accent);
  text-decoration: none;
}
.author-box__link:hover { text-decoration: underline; }

/* ── POST NAV ── */
.post-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
}

.post-nav__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: all var(--duration-base) var(--ease-out);
}
.post-nav__item:hover {
  border-color: var(--color-accent);
  background: var(--color-bg-elevated);
  transform: translateY(-2px);
}

.post-nav__item--next { justify-content: flex-end; text-align: right; }

.post-nav__img {
  width: 56px;
  height: 56px;
  object-fit: cover;
  border-radius: var(--radius-md);
  flex-shrink: 0;
}

.post-nav__text { display: flex; flex-direction: column; gap: 4px; overflow: hidden; }

.post-nav__dir {
  font-size: var(--text-xs);
  color: var(--color-accent);
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.post-nav__title {
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  color: var(--color-text-primary);
  line-height: var(--leading-snug);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── RELATED POSTS SECTION ── */
.related-section {
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 2px solid var(--color-border);
}

/* ── COMMENTS ── */
.comments-wrap {
  margin-top: var(--space-10);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}

/* ============================================================
   SIDEBAR SINGLE — NOVA SIDEBAR RICA
   ============================================================ */
.sidebar-single {
  position: sticky;
  top: calc(var(--header-height) + var(--space-4));
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  min-width: 0;
}

/* Widget container */
.sidebar-widget {
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.sidebar-widget__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
}

.sidebar-widget__title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: 0.04em;
  color: var(--color-text-primary);
}

.sidebar-widget__icon { font-size: 1rem; line-height: 1; }

.sidebar-widget__more {
  font-size: var(--text-xs);
  font-family: var(--font-heading);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-accent);
  text-decoration: none;
}
.sidebar-widget__more:hover { text-decoration: underline; }

/* ── POPULAR LIST (com thumbnails) ── */
.popular-list {
  display: flex;
  flex-direction: column;
}

.popular-list__item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  transition: background var(--duration-fast);
}
.popular-list__item:last-child { border-bottom: none; }
.popular-list__item:hover { background: var(--color-bg-elevated); }

.popular-list__num {
  font-family: var(--font-display);
  font-size: 1.6rem;
  line-height: 1;
  width: 28px;
  flex-shrink: 0;
  text-align: center;
  color: var(--color-border-light);
}
.popular-list__num--1 { color: var(--color-accent); }
.popular-list__num--2 { color: var(--color-purple); }
.popular-list__num--3 { color: var(--color-orange); }

.popular-list__link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  flex: 1;
  min-width: 0;
}

.popular-list__thumb {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: var(--radius-md);
  flex-shrink: 0;
  background: var(--color-bg-elevated);
}

.popular-list__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
}

.popular-list__title {
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  color: var(--color-text-primary);
  line-height: var(--leading-snug);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color var(--duration-fast);
}
.popular-list__link:hover .popular-list__title { color: var(--color-accent); }

.popular-list__date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
}

/* ── MINI LIST (categoria) ── */
.mini-list {
  display: flex;
  flex-direction: column;
}

.mini-list__item {
  border-bottom: 1px solid var(--color-border);
  transition: background var(--duration-fast);
}
.mini-list__item:last-child { border-bottom: none; }
.mini-list__item:hover { background: var(--color-bg-elevated); }

.mini-list__link {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  text-decoration: none;
  align-items: center;
}

.mini-list__thumb {
  width: 80px;
  height: 56px;
  object-fit: cover;
  border-radius: var(--radius-md);
  flex-shrink: 0;
  background: var(--color-bg-elevated);
}
.mini-list__thumb--placeholder {
  background: var(--gradient-hero);
  display: flex;
  align-items: center;
  justify-content: center;
}

.mini-list__info { display: flex; flex-direction: column; gap: var(--space-1); min-width: 0; }

.mini-list__title {
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  color: var(--color-text-primary);
  line-height: var(--leading-snug);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color var(--duration-fast);
}
.mini-list__link:hover .mini-list__title { color: var(--color-accent); }

.mini-list__date {
  font-size: 11px;
  color: var(--color-text-muted);
  font-family: var(--font-heading);
}

/* ── NEWSLETTER CTA (sidebar) ── */
.sidebar-widget--newsletter {
  background: linear-gradient(160deg, #0D0B2A, #1A0533);
  border-color: rgba(123, 47, 255, 0.3);
}

.newsletter-cta {
  padding: var(--space-6) var(--space-5);
  text-align: center;
}

.newsletter-cta__icon { font-size: 2.2rem; margin-bottom: var(--space-3); }

.newsletter-cta__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: 0.04em;
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
}

.newsletter-cta__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-4);
}

.newsletter-cta__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.newsletter-cta__input {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-full);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  outline: none;
  transition: border-color var(--duration-fast);
}
.newsletter-cta__input::placeholder { color: var(--color-text-muted); }
.newsletter-cta__input:focus { border-color: var(--color-purple); }

.newsletter-cta__btn {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: var(--gradient-brand);
  border: none;
  border-radius: var(--radius-full);
  color: #fff;
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}
.newsletter-cta__btn:hover { filter: brightness(1.1); transform: translateY(-1px); }

/* ── QUICK LIST (últimas notícias) ── */
.quick-list {
  display: flex;
  flex-direction: column;
  padding: var(--space-2) 0;
}

.quick-list__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  transition: background var(--duration-fast);
}
.quick-list__item:last-child { border-bottom: none; }
.quick-list__item:hover { background: var(--color-bg-elevated); }

.quick-list__title {
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  color: var(--color-text-primary);
  line-height: var(--leading-snug);
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color var(--duration-fast);
}
.quick-list__title:hover { color: var(--color-accent); }

.quick-list__date {
  font-size: 11px;
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.single-post__header { margin-bottom: var(--space-8); }

.single-post__cats {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}

.single-post__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
  line-height: var(--leading-tight);
  letter-spacing: 0.02em;
  color: var(--color-text-primary);
  margin-bottom: var(--space-5);
}

.single-post__subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  line-height: var(--leading-snug);
  margin-bottom: var(--space-6);
  font-weight: var(--font-normal);
  border-left: 3px solid var(--color-accent);
  padding-left: var(--space-4);
}

.single-post__byline {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-4) 0;
  border-block: 1px solid var(--color-border);
  margin-bottom: var(--space-8);
  flex-wrap: wrap;
}

.single-post__author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.single-post__author-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--color-bg-elevated);
  border: 2px solid var(--color-border);
}
.single-post__author-name {
  font-weight: var(--font-bold);
  font-size: var(--text-sm);
}
.single-post__author-role {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.single-post__byline-meta {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.single-post__byline-meta span {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-family: var(--font-heading);
  font-weight: var(--font-semi);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.single-post__share {
  display: flex;
  gap: var(--space-2);
  margin-left: auto;
}
.single-post__share-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  color: var(--color-text-muted);
  background: var(--color-bg-surface);
  font-size: 0.9rem;
  transition: all var(--duration-fast);
}
.single-post__share-btn:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}

/* Featured Image */
.single-post__featured-img {
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-xl);
  margin-bottom: var(--space-2);
  aspect-ratio: 16/9;
  object-fit: cover;
}

.single-post__img-caption {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-align: center;
  margin-bottom: var(--space-8);
  font-style: italic;
}

/* Conteúdo do Post */
.post-content {
  font-size: var(--text-md);
  line-height: var(--leading-loose);
  color: var(--color-text-secondary);
}

.post-content h2 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  letter-spacing: 0.03em;
  color: var(--color-text-primary);
  margin: var(--space-10) 0 var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
}

.post-content h3 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin: var(--space-8) 0 var(--space-4);
}

.post-content h4 {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  margin: var(--space-6) 0 var(--space-3);
}

.post-content p { margin-bottom: var(--space-5); }

.post-content a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.post-content a:hover { color: var(--color-purple); }

.post-content blockquote {
  margin: var(--space-8) 0;
  padding: var(--space-6);
  background: var(--color-bg-surface);
  border-left: 4px solid var(--color-accent);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  font-size: var(--text-lg);
  font-style: italic;
  color: var(--color-text-primary);
  line-height: var(--leading-snug);
  box-shadow: var(--shadow-md);
}
.post-content blockquote cite {
  display: block;
  margin-top: var(--space-3);
  font-size: var(--text-sm);
  font-style: normal;
  color: var(--color-text-muted);
  font-weight: var(--font-semi);
}

.post-content ul, .post-content ol {
  margin: var(--space-5) 0;
  padding-left: var(--space-6);
}
.post-content ul { list-style: disc; }
.post-content ol { list-style: decimal; }
.post-content li {
  margin-bottom: var(--space-2);
  padding-left: var(--space-2);
}
.post-content ul li::marker { color: var(--color-accent); }

.post-content img {
  width: 100%;
  border-radius: var(--radius-lg);
  margin: var(--space-6) 0;
}

.post-content .wp-block-embed iframe {
  width: 100%;
  aspect-ratio: 16/9;
  border-radius: var(--radius-lg);
}

.post-content strong { color: var(--color-text-primary); font-weight: var(--font-bold); }
.post-content em { color: var(--color-text-primary); }
.post-content code {
  background: var(--color-bg-elevated);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  font-size: 0.9em;
  color: var(--color-cyan);
}

/* Tags do post */
.post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
}
.post-tags__label {
  font-size: var(--text-sm);
  font-weight: var(--font-semi);
  color: var(--color-text-muted);
  margin-right: var(--space-2);
  align-self: center;
}
.post-tag {
  display: inline-flex;
  padding: var(--space-1) var(--space-3);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: all var(--duration-fast);
  font-family: var(--font-heading);
  font-weight: var(--font-semi);
}
.post-tag:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}

/* ============================================================
   15. RELATED POSTS
   ============================================================ */
.related-posts {
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}

.related-posts__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap-md);
}

/* ============================================================
   16. PAGINATION
   ============================================================ */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-10);
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}

.page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--color-text-muted);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: all var(--duration-fast);
}
.page-numbers:hover,
.page-numbers.current {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}
.page-numbers.prev,
.page-numbers.next {
  width: auto;
  padding-inline: var(--space-4);
  gap: var(--space-2);
  display: flex;
}
.page-numbers.dots {
  background: none;
  border: none;
  color: var(--color-text-muted);
  width: auto;
}

/* Load More Button */
.load-more {
  display: flex;
  justify-content: center;
  margin-top: var(--space-10);
}
.load-more__btn {
  min-width: 200px;
  padding: var(--space-4) var(--space-8);
}
.load-more__btn.loading {
  opacity: 0.7;
  pointer-events: none;
}

/* ============================================================
   17. ARCHIVE / CATEGORY PAGE
   ============================================================ */
.archive-header {
  padding: var(--space-10) 0;
  margin-bottom: var(--space-8);
  border-bottom: 2px solid var(--color-border);
  position: relative;
  overflow: hidden;
}

.archive-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-hero);
  opacity: 0.3;
  pointer-events: none;
}

.archive-header__tag {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-accent);
  margin-bottom: var(--space-3);
}

.archive-header__title {
  font-family: var(--font-display);
  font-size: var(--text-5xl);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-3);
}

.archive-header__count {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
}

/* Category color strip */
.archive-header--filmes     { border-bottom-color: var(--cat-filmes); }
.archive-header--series     { border-bottom-color: var(--cat-series); }
.archive-header--animes     { border-bottom-color: var(--cat-animes); }
.archive-header--games      { border-bottom-color: var(--cat-games); }
.archive-header--quadrinhos { border-bottom-color: var(--cat-quadrinhos); }

/* ============================================================
   18. SEARCH PAGE
   ============================================================ */
.search-header {
  padding: var(--space-8) 0;
  margin-bottom: var(--space-8);
  border-bottom: 1px solid var(--color-border);
}

.search-header__title {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-4);
}

.search-header__query { color: var(--color-accent); }

.search-form {
  display: flex;
  gap: var(--space-3);
  max-width: 600px;
}
.search-form input[type="search"] {
  flex: 1;
  padding: var(--space-3) var(--space-5);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text-primary);
  font-family: var(--font-body);
  font-size: var(--text-base);
  outline: none;
}
.search-form input[type="search"]:focus { border-color: var(--color-accent); }

/* ============================================================
   19. 404 PAGE
   ============================================================ */
.error-404 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  text-align: center;
  padding: var(--space-12);
}

.error-404__number {
  font-family: var(--font-display);
  font-size: clamp(100px, 20vw, 200px);
  line-height: 1;
  background: var(--gradient-brand);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-6);
}

.error-404__title {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  margin-bottom: var(--space-4);
}

.error-404__desc {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  max-width: 480px;
  margin-bottom: var(--space-8);
  line-height: var(--leading-normal);
}

/* ============================================================
   20. FOOTER
   ============================================================ */
.site-footer {
  background: #07071A;
  border-top: 1px solid var(--color-border);
  margin-top: auto;
}

.footer-widgets {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--gap-lg);
  padding: var(--space-12) 0;
  border-bottom: 1px solid var(--color-border);
}

.footer-brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer-logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  margin-bottom: var(--space-2);
}

.footer-logo__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: 0.04em;
  background: var(--gradient-brand);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.footer-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
  max-width: 300px;
}

.footer-social {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-2);
}

.footer-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text-muted);
  font-size: var(--text-base);
  transition: all var(--duration-fast);
}
.footer-social__link:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
  transform: translateY(-2px);
}

.footer-col__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: 0.06em;
  color: var(--color-text-primary);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-accent);
  display: inline-block;
}

.footer-col__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.footer-col__links a {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  transition: all var(--duration-fast);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.footer-col__links a:hover {
  color: var(--color-accent);
  padding-left: var(--space-2);
}

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) 0;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer-copyright {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-family: var(--font-heading);
}

.footer-legal {
  display: flex;
  gap: var(--space-5);
}
.footer-legal a {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--font-heading);
  font-weight: var(--font-semi);
}
.footer-legal a:hover { color: var(--color-accent); }

/* ============================================================
   21. BACK TO TOP
   ============================================================ */
.back-to-top {
  position: fixed;
  bottom: var(--space-8);
  right: var(--space-6);
  width: 44px;
  height: 44px;
  background: var(--gradient-brand);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--text-base);
  cursor: pointer;
  border: none;
  z-index: var(--z-raised);
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: all var(--duration-base) var(--ease-out);
  box-shadow: 0 4px 16px var(--color-accent-glow);
}
.back-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.back-to-top:hover { transform: translateY(-3px); }

/* ============================================================
   22. COOKIE NOTICE
   ============================================================ */
.cookie-notice {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-5) var(--space-6);
  background: var(--color-bg-elevated);
  border-top: 1px solid var(--color-border);
  z-index: var(--z-overlay);
  backdrop-filter: blur(10px);
  transform: translateY(100%);
  transition: transform var(--duration-slow) var(--ease-out);
}
.cookie-notice.visible { transform: translateY(0); }

.cookie-notice__inner {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  max-width: var(--container-xl);
  margin-inline: auto;
  flex-wrap: wrap;
}
.cookie-notice__text {
  flex: 1;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.cookie-notice__text a { color: var(--color-accent); }

.cookie-notice__actions {
  display: flex;
  gap: var(--space-3);
  flex-shrink: 0;
}

/* ============================================================
   23. MOBILE MENU
   ============================================================ */
.mobile-menu {
  position: fixed;
  top: 0;
  left: -100%;
  bottom: 0;
  width: min(320px, 85vw);
  background: var(--color-bg-surface);
  border-right: 1px solid var(--color-border);
  z-index: var(--z-modal);
  transition: left var(--duration-slow) var(--ease-out);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.mobile-menu.active { left: 0; }

.mobile-menu__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}

.mobile-menu__close {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  color: var(--color-text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.mobile-menu__nav {
  padding: var(--space-4);
  flex: 1;
}

.mobile-menu__item a {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.mobile-menu__item a:hover {
  background: var(--color-bg-elevated);
  color: var(--color-accent);
}

.mobile-menu__search {
  padding: var(--space-4);
  border-top: 1px solid var(--color-border);
}

.site-overlay-menu {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  z-index: calc(var(--z-modal) - 1);
  opacity: 0;
  visibility: hidden;
  transition: all var(--duration-base);
}
.site-overlay-menu.active {
  opacity: 1;
  visibility: visible;
}

/* ============================================================
   24. UTILITIES
   ============================================================ */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

.text-center { text-align: center; }
.text-accent  { color: var(--color-accent); }
.mb-0 { margin-bottom: 0; }

/* Lazy loading */
img[data-src] { opacity: 0; transition: opacity var(--duration-base); }
img.loaded     { opacity: 1; }

/* ============================================================
   25. RESPONSIVE — TABLET (1024px)
   ============================================================ */
@media (max-width: 1024px) {
  :root { --sidebar-width: 280px; }

  .posts-grid { grid-template-columns: var(--cols-3); }

  .footer-widgets {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }

  .related-posts__grid { grid-template-columns: repeat(2, 1fr); }

  .hero__thumbs { display: none; }

  .nav-primary__link {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-xs);
  }

  /* Single grid fica coluna única abaixo de 1024px — sidebar vai abaixo */
  .single-grid {
    grid-template-columns: 1fr;
  }
  .sidebar-single {
    position: static;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-5);
  }
}

/* ============================================================
   26. RESPONSIVE — TABLET MÉDIO (768px)
   ============================================================ */
@media (max-width: 768px) {
  :root {
    --header-height: 56px;
    --topbar-height: 32px;
  }

  .container { padding-inline: var(--space-4); }

  /* Grids homepage */
  .content-with-sidebar {
    grid-template-columns: 1fr;
  }
  .sidebar { order: -1; }

  .posts-grid      { grid-template-columns: var(--cols-2); }
  .posts-grid--3   { grid-template-columns: var(--cols-2); }

  .featured-grid {
    grid-template-columns: 1fr;
  }
  .featured-grid__main { grid-column: 1; grid-row: 1; }
  .featured-grid__side { grid-column: 1; display: grid; grid-template-columns: 1fr 1fr; }

  .hero { height: clamp(360px, 55vw, 520px); }

  .nav-primary     { display: none; }
  .header-menu-btn { display: flex; }
  .topbar__links   { display: none; }
  .breaking-news   { display: none; }

  .footer-widgets {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
  .footer-bottom {
    flex-direction: column;
    text-align: center;
    gap: var(--space-3);
  }

  /* Single post 768px */
  .single-grid { grid-template-columns: 1fr; }

  .sidebar-single {
    position: static;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
  }

  .single-byline   { flex-wrap: wrap; gap: var(--space-3); }
  .single-byline__share { margin-left: 0; }

  .post-nav { grid-template-columns: 1fr; }

  .related-posts__grid { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   27. RESPONSIVE — MOBILE (480px)
   ============================================================ */
@media (max-width: 480px) {
  :root { --gap-md: var(--space-4); }

  .posts-grid,
  .posts-grid--3,
  .posts-grid--2 { grid-template-columns: 1fr; }

  .featured-grid__side { grid-template-columns: 1fr; }

  .hero { height: 280px; }
  .hero__title { font-size: var(--text-2xl); }

  /* Single 480px */
  .single-header__title { font-size: 1.9rem; }
  .post-content { font-size: var(--text-base); }
  .post-content h2 { font-size: var(--text-2xl); }

  .sidebar-single { grid-template-columns: 1fr; }

  .single-share-final { flex-direction: column; align-items: flex-start; }
  .share-btn--lg { width: 100%; justify-content: center; }

  .author-box { flex-direction: column; align-items: center; text-align: center; }
  .author-box__link { display: inline-block; margin-top: var(--space-2); }

  .related-posts__grid { grid-template-columns: 1fr; }
  .archive-header__title { font-size: var(--text-4xl); }
  .pagination .page-numbers { width: 36px; height: 36px; }
}

/* ============================================================
   28. SINGLE POST — CARD BRANCO (v4)
   ============================================================ */

/* Fundo levemente escuro da página de matéria */
.single-page-bg {
  background: #0E0E22;
  padding: 1.5rem 0 4rem;
}

/* Grid: article + sidebar */
.single-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 1.5rem;
  align-items: start;
}

/* Card branco do artigo */
.single-article {
  background: #FFFFFF;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 32px rgba(0, 0, 0, 0.35);
  min-width: 0;
}

/* Seções com padding interno */
.single-article__pad {
  padding: 2rem 2.25rem 0;
}
.single-article__body {
  padding-bottom: 3rem;
}

/* Imagem edge-to-edge dentro do card */
.single-article__hero {
  display: block;
  margin: 1.5rem 0 0;
}
.single-article__hero img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}
.single-article__caption {
  font-size: 11px;
  color: #999;
  text-align: center;
  padding: 0.4rem 1.5rem 0;
  font-style: italic;
}

/* ── CORES ESCURAS no fundo branco ── */
.single-article .single-header__cats { margin-bottom: 1rem; }

.single-article .single-header__title {
  color: #0B0B1E;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
}

.single-article .single-header__subtitle {
  color: #44445A;
  border-left-color: #FF2D6B;
}

.single-article .single-byline {
  border-top-color: #E5E5EF;
  border-bottom-color: #E5E5EF;
}

.single-article .single-byline__name { color: #0B0B1E; }
.single-article .single-byline__role { color: #888899; }
.single-article .single-byline__meta span { color: #666677; }

/* Share buttons no byline (fundo branco) */
.single-article .share-btn {
  background: #F0F0F7;
  border-color: #D8D8E8;
  color: #555566;
}
.single-article .share-btn--twitter:hover  { background: #000;     border-color: #000;     color: #fff; }
.single-article .share-btn--facebook:hover { background: #1877F2;  border-color: #1877F2;  color: #fff; }
.single-article .share-btn--whatsapp:hover { background: #25D366;  border-color: #25D366;  color: #fff; }
.single-article .share-btn--copy:hover     { background: #FF2D6B;  border-color: #FF2D6B;  color: #fff; }

/* ── TIPOGRAFIA DO CONTEÚDO ── */
.single-article .post-content {
  color: #2D2D4A;
  font-size: 1.05rem;
  line-height: 1.82;
  font-family: var(--font-body);
}
.single-article .post-content > * + * { margin-top: 1.15em; }

.single-article .post-content h2 {
  color: #0B0B1E;
  font-family: var(--font-heading);
  font-size: 1.45rem;
  font-weight: 700;
  margin-top: 2.5rem;
  margin-bottom: 0.9rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid #EEEEF8;
  line-height: 1.25;
}
.single-article .post-content h3 {
  color: #0B0B1E;
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 700;
  margin-top: 2rem;
  margin-bottom: 0.7rem;
  line-height: 1.3;
}
.single-article .post-content h4 {
  color: #1A1A30;
  font-size: 1.05rem;
  font-weight: 700;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}
.single-article .post-content p { color: #2D2D4A; margin-bottom: 0; }

.single-article .post-content a {
  color: #FF2D6B;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.single-article .post-content a:hover { color: #CC1A54; }

.single-article .post-content blockquote {
  background: #F5F5FC;
  border-left: 4px solid #FF2D6B;
  padding: 1.25rem 1.5rem;
  margin: 1.75rem 0;
  border-radius: 0 10px 10px 0;
  color: #44445A;
  font-style: italic;
}
.single-article .post-content blockquote p { color: inherit; }

.single-article .post-content ul,
.single-article .post-content ol {
  padding-left: 1.75rem;
  margin: 0.75rem 0 1.25rem;
}
.single-article .post-content li {
  color: #2D2D4A;
  margin-bottom: 0.4rem;
  line-height: 1.65;
}
.single-article .post-content li::marker { color: #FF2D6B; }

.single-article .post-content img {
  max-width: 100%;
  border-radius: 10px;
  margin: 1.5rem auto;
  display: block;
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
}
.single-article .post-content strong { color: #0B0B1E; }
.single-article .post-content em     { color: #44445A; }
.single-article .post-content code {
  background: #F0F0F7;
  color: #CC1A54;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 0.875em;
}
.single-article .post-content pre {
  background: #1C1C38;
  color: #E0E0F0;
  padding: 1.25rem 1.5rem;
  border-radius: 10px;
  overflow-x: auto;
  margin: 1.75rem 0;
}
.single-article .post-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  font-size: 0.9rem;
}
.single-article .post-content th {
  background: #EEEEF8;
  color: #0B0B1E;
  padding: 0.6rem 1rem;
  text-align: left;
  font-weight: 700;
  border: 1px solid #DDD;
}
.single-article .post-content td {
  color: #2D2D4A;
  padding: 0.5rem 1rem;
  border: 1px solid #E5E5EF;
}

/* Tags */
.single-article .post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-top: 2rem;
  padding-top: 1.25rem;
  border-top: 1px solid #EEEEF8;
}
.single-article .post-tags__label {
  font-size: 11px;
  color: #999;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  display: flex;
  align-items: center;
  gap: 4px;
}
.single-article .post-tag {
  background: #F0F0F7;
  color: #44445A;
  border: 1px solid #DDDDE8;
  padding: 3px 12px;
  border-radius: 999px;
  font-size: 12px;
  text-decoration: none;
  transition: all 150ms;
}
.single-article .post-tag:hover { background: #FF2D6B; color: #fff; border-color: #FF2D6B; }

/* Share bar final — fundo branco */
.single-article .single-share-final {
  background: #F5F5FB;
  border: 1px solid #E0E0EE;
  margin-top: 2rem;
}
.single-article .single-share-final__label { color: #888899; }

/* Author box — fundo branco */
.single-article .author-box {
  background: #F5F5FB;
  border-color: #E0E0EE;
  border-left-color: #FF2D6B;
  margin-top: 2rem;
}
.single-article .author-box__label { color: #FF2D6B; }
.single-article .author-box__name  { color: #0B0B1E; }
.single-article .author-box__bio   { color: #555568; }
.single-article .author-box__link  { color: #FF2D6B; }
.single-article .author-box__avatar {
  border-color: #E0E0EE;
  background: #F0F0F7;
}

/* Post nav — fundo branco */
.single-article .post-nav { border-top-color: #EEEEF8; }
.single-article .post-nav__item {
  background: #F5F5FB;
  border-color: #E0E0EE;
}
.single-article .post-nav__item:hover {
  border-color: #FF2D6B;
  background: #FFF5F8;
  transform: translateY(-2px);
}
.single-article .post-nav__dir   { color: #FF2D6B; }
.single-article .post-nav__title { color: #0B0B1E; }

/* Ad slot placeholder dentro do card branco */
.single-article .ad-slot--placeholder {
  background: #F5F5FB;
  border-color: #E0E0EE;
  color: #AAA;
}

/* Related section abaixo do grid */
.single-page-bg .related-section,
.single-page-bg .comments-wrap {
  margin-top: 2.5rem;
}

/* ── RESPONSIVE DO SINGLE ── */
@media (max-width: 1080px) {
  .single-grid {
    grid-template-columns: minmax(0, 1fr) 270px;
  }
}

@media (max-width: 900px) {
  .single-grid {
    grid-template-columns: 1fr;
  }
  .sidebar-single {
    position: static !important;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
  }
  .sidebar-single .sidebar-widget--newsletter {
    grid-column: 1 / -1;
  }
}

@media (max-width: 600px) {
  .single-article__pad { padding: 1.5rem 1.25rem 0; }
  .single-article .single-header__title { font-size: 1.65rem; }
  .single-article .post-content { font-size: 1rem; line-height: 1.75; }
  .single-article .single-share-final { flex-direction: column; align-items: stretch; }
  .single-article .share-btn--lg { width: 100%; justify-content: center; }
  .single-article .author-box { flex-direction: column; align-items: center; text-align: center; }
  .single-article .post-nav { grid-template-columns: 1fr; }
  .sidebar-single { grid-template-columns: 1fr; }
}

/* ============================================================
   29. PRINT
   ============================================================ */
@media print {
  .site-header,
  .site-footer,
  .sidebar,
  .ad-slot,
  .back-to-top,
  .cookie-notice,
  .breaking-news,
  .related-posts,
  .hero__controls { display: none; }

  body { background: white; color: black; }
  .post-content { color: black; }
  a { color: black; text-decoration: underline; }
}
