/*
Theme Name: Legolas Geek HTML Real v0.5.5
Theme URI: https://legolasgeek.com
Author: Max Rodrigues / Selene Company
Description: Tema WordPress full-site convertido a partir do HTML aprovado do Legolas Geek, com templates principais, categorias e singles de review.
Version: 0.5.5
Text Domain: legolas-geek
*/

/* ============================= */
/* LEGOLAS GEEK - CSS FINAL */
/* ============================= */

:root {
  --bg: #f3e4c7;
  --paper: #f6e8cb;
  --cream: #fff3d6;
  --ink: #24150f;
  --text: #2b1a10;
  --muted: rgba(43, 26, 16, 0.74);
  --line: rgba(164, 112, 52, 0.48);
  --line-soft: rgba(164, 112, 52, 0.18);
  --purple: #562081;
  --purple-dark: #371052;
  --gold: #b88948;
  --green: #315b2d;
  --red: #8a2c25;
  --card-dark: #160904;
  --shadow: 0 14px 32px rgba(43, 26, 16, 0.08);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--text);
  background: #070407;
  font-family: Georgia, "Times New Roman", serif;
}

a {
  color: inherit;
}

img {
  max-width: 100%;
  display: block;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.page {
  width: calc(100% - 48px);
  max-width: 1920px;
  margin: 0 auto;
  min-height: 100vh;
  overflow: hidden;
  background-color: var(--bg);
  background-image: url("assets/bg-pergaminho-legolas.png"), url("assets/bg-pergaminho.png");
  background-size: cover, 720px auto;
  background-position: top center, top center;
  background-repeat: repeat-y, repeat;
}

/* ============================= */
/* HEADER GLOBAL */
/* ============================= */

.topbar {
  height: 155px;
  padding: 0 56px;
  display: grid;
  grid-template-columns: 320px 1fr 250px;
  align-items: center;
  gap: 22px;
}

.logo {
  position: relative;
  z-index: 30;
  text-decoration: none;
}

.logo img {
  width: 260px;
  max-width: none;
}

.primary-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 28px;
}

.primary-nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
}

.primary-nav a img {
  width: 20px;
  height: 20px;
  object-fit: contain;
  opacity: 0.76;
}

.primary-nav a.active,
.primary-nav a:hover {
  color: var(--purple);
}

.primary-nav a.active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -20px;
  width: 42px;
  height: 8px;
  transform: translateX(-50%);
  background: var(--purple);
  clip-path: polygon(0 35%, 42% 35%, 50% 100%, 58% 35%, 100% 35%, 100% 0, 0 0);
}

.site-search {
  width: 250px;
  display: grid;
  grid-template-columns: 1fr 44px;
  justify-self: end;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.28);
}

.site-search input {
  min-width: 0;
  height: 48px;
  border: 0;
  padding: 0 14px;
  background: transparent;
  color: var(--ink);
  font: 700 12px Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  outline: 0;
}

.site-search button {
  border: 0;
  border-left: 1px solid rgba(164, 112, 52, 0.32);
  background: var(--purple);
  color: #fff;
  cursor: pointer;
}

/* ============================= */
/* BOTÕES */
/* ============================= */

.lg-btn {
  min-height: 52px;
  padding: 0 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  border: 1px solid var(--line);
  color: var(--ink);
  background: rgba(255, 246, 222, 0.08);
  font: 700 14px Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  text-decoration: none;
  transition: 0.2s ease;
}

.lg-btn:hover {
  transform: translateY(-2px);
}

.lg-btn-primary {
  background: var(--purple);
  border-color: var(--purple);
  color: var(--cream);
}

.lg-btn-outline:hover {
  background: var(--purple);
  border-color: var(--purple);
  color: var(--cream);
}

.lg-btn-small {
  min-height: 44px;
  padding: 0 18px;
  font-size: 13px;
}

/* ============================= */
/* HOME - HERO */
/* ============================= */

/*
  Hero da home isolado do template de review.
  Mantém a arte grande, mais centralizada e com respiro abaixo do menu.
*/

#home-hero {
  position: relative;
  min-height: 720px;
  padding: 32px 56px 78px;

  display: grid;
  grid-template-columns: minmax(500px, 0.88fr) minmax(650px, 1.12fr);
  gap: 18px;
  align-items: center;

  overflow: visible;
}

#home-hero .hero-text {
  position: relative;
  z-index: 5;

  max-width: 710px;
  transform: translateY(-4px);
}

#home-hero h1 {
  max-width: 710px;
  margin: 0 0 26px;

  color: var(--ink);
  font-size: clamp(58px, 5.15vw, 88px);
  line-height: 0.92;
  letter-spacing: -0.035em;
  text-transform: uppercase;
}

#home-hero p {
  max-width: 590px;
  margin: 0 0 30px;

  color: var(--ink);
  font-size: 21px;
  line-height: 1.36;
}

#home-hero .hero-buttons,
#home-hero .buttons {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 18px;
  flex-wrap: wrap;
}

/* Compatibilidade caso o index ainda use .hero-button */
#home-hero .hero-button {
  min-height: 52px;
  padding: 0 28px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  border: 1px solid var(--line);
  color: var(--ink);
  background: rgba(255, 246, 222, 0.08);

  font: 700 14px Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  text-decoration: none;

  transition: 0.2s ease;
}

#home-hero .hero-button:hover {
  transform: translateY(-2px);
}

#home-hero .hero-button-primary {
  background: var(--purple);
  border-color: var(--purple);
  color: var(--cream);
}

#home-hero .hero-button-secondary:hover {
  background: var(--purple);
  border-color: var(--purple);
  color: var(--cream);
}

#home-hero .hero-image {
  position: relative;
  z-index: 4;

  min-height: 590px;

  display: flex;
  align-items: center;
  justify-content: flex-end;

  overflow: visible;
  pointer-events: none;
}

#home-hero .hero-image img {
  width: min(1160px, 132%);
  max-width: none;
  height: auto;

  display: block;
  object-fit: contain;
  object-position: center right;

  transform: translateX(2%) translateY(18px);
}

/* Categorias logo depois do hero */
body.home .categories {
  position: relative;
  z-index: 6;
  margin-top: 0;
}

/* ============================= */
/* CATEGORIAS */
/* ============================= */

.categories {
  margin: 0 32px 30px;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  border: 1px solid var(--line);
}

.category-card {
  min-height: 118px;
  padding: 24px 18px;
  display: grid;
  grid-template-columns: 48px 1fr;
  align-content: center;
  column-gap: 16px;
  color: var(--ink);
  text-decoration: none;
  border-right: 1px solid var(--line);
}

.category-card:last-child {
  border-right: 0;
}

.category-card img {
  grid-row: 1 / 3;
  width: 34px;
  height: 34px;
  object-fit: contain;
  align-self: center;
}

.category-card strong {
  font-size: 16px;
  line-height: 1;
  text-transform: uppercase;
}

.category-card span {
  margin-top: 5px;
  font-size: 13px;
}

/* ============================= */
/* HOME - REVIEWS */
/* ============================= */

.review-area {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  margin: 0 32px 32px;
}

.live-card {
  position: relative;
  min-height: 390px;
  padding: 24px;
  isolation: isolate;
  overflow: hidden;
  color: var(--cream);
  background-image: linear-gradient(to top, rgba(19, 7, 4, 0.98), rgba(19, 7, 4, 0.62)), var(--live-bg);
  background-size: cover;
  background-position: center;
  border: 1px solid #9f743f;
}

.live-tag,
.post-category,
.review-label,
.section-kicker,
.article-kicker {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  padding: 7px 11px;
  color: var(--cream);
  background: var(--purple);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
}

.live-content {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
}

.live-theme {
  display: block;
  margin-bottom: 10px;
  color: #f8e7bd;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.live-card h2 {
  margin: 0 0 14px;
  color: #f8e7bd;
  font-size: 30px;
  line-height: 0.96;
  text-transform: uppercase;
}

.live-meta {
  display: flex;
  gap: 8px;
  margin: 0 0 18px;
}

.live-meta span {
  padding: 6px 8px;
  background: rgba(255, 246, 222, 0.12);
  border: 1px solid rgba(255, 246, 222, 0.22);
  color: #f8e7bd;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.twitch-button img {
  width: 18px;
  height: 18px;
}

.reviews {
  min-width: 0;
}

.section-title-row {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}

.section-title-row h2 {
  margin: 0;
  color: var(--ink);
  font-size: 34px;
  line-height: 1;
  text-transform: uppercase;
}

.see-all,
.info-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  text-decoration: none;
}

.review-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.card,
.post-card {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  padding: 18px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  border: 1px solid #9f743f;
  border-radius: 8px;
  background-color: var(--card-dark);
  background-image: linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.84) 34%, rgba(20, 10, 5, 0.28) 68%, rgba(20, 10, 5, 0.06) 100%), var(--post-bg);
  background-size: cover;
  background-position: center;
}

.post-card:hover,
.mini-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.07);
}

.post-category {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
}

.post-card h3,
.mini-review-card h3 {
  margin: 0 0 6px;
  color: #f8e7bd;
  font-size: 19px;
  line-height: 1.04;
}

.post-excerpt {
  margin: 0 0 9px;
  color: #f8e7bd;
  font-size: 12px;
  text-transform: none;
}

.post-rating-icons,
.related-rating {
  display: flex;
  align-items: center;
  gap: 7px;
}

.rating-cats,
.rating-cats-card,
.rating-cats-small,
.rating-cats-feature {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  line-height: 0;
}

.rating-cats-card img,
.rating-cats-small img {
  width: 17px;
  height: 17px;
  object-fit: contain;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.35));
}

.post-rating-icons strong,
.related-rating strong {
  color: #f8e7bd;
  font-size: 13px;
  line-height: 1;
}

/* ============================= */
/* HOME - INFO, COVEN, FOOTER */
/* ============================= */

.info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin: 0 32px 34px;
}

.info-card,
.support-panel,
.partners-panel,
.social-panel,
.review-box,
.pros-cons-panel,
.article-body,
.related-carousel-section,
.quick-verdict-card,
.review-ad-card {
  position: relative;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.info-card {
  min-height: 250px;
  padding: 28px 26px;
}

.info-card h2,
.support-panel h2,
.partners-panel h2,
.social-panel h2,
.coven h2 {
  margin: 0 0 14px;
  color: var(--ink);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.info-card p,
.support-panel p,
.partners-panel p,
.social-panel p,
.coven p {
  margin: 0 0 18px;
  font-size: 15.5px;
  line-height: 1.45;
}

.calendar-card,
.coven-rating-card,
.social-panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.event-list,
.guide-list {
  display: grid;
  gap: 10px;
  width: 100%;
  margin: 14px 0 18px;
}

.event-card,
.guide-item {
  display: grid;
  grid-template-columns: 58px 1fr 34px;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--line-soft);
  text-align: left;
  text-decoration: none;
}

.event-date {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border: 1px solid var(--line);
}

.event-date strong {
  font-size: 19px;
  line-height: 1;
}

.event-date small,
.event-info small,
.guide-item small {
  font-size: 11px;
  color: var(--muted);
}

.event-info strong,
.guide-item strong {
  display: block;
  font-size: 13px;
  line-height: 1.22;
  text-transform: uppercase;
}

.event-platform img,
.guide-item img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.rating-cats-feature {
  justify-content: center;
  gap: 7px;
  margin: 10px 0 16px;
}

.rating-cats-feature img {
  width: 34px;
  height: 34px;
}

.rating-title {
  display: block;
  margin-bottom: 12px;
  color: var(--ink);
  font-weight: 700;
  text-transform: uppercase;
}

.coven {
  display: grid;
  grid-template-columns: 1.1fr 1.9fr;
  margin: 0 32px 34px;
  border: 1px solid var(--line);
}

.coven-invite {
  min-height: 250px;
  padding: 30px;
  display: grid;
  grid-template-columns: 1fr 190px;
  gap: 20px;
  align-items: center;
  border-right: 1px solid var(--line);
}

.coven-art img {
  max-height: 180px;
  margin: 0 auto;
}

.coven-features {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.coven-feature {
  min-height: 250px;
  padding: 34px 22px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-align: center;
  text-decoration: none;
  border-right: 1px solid var(--line);
}

.coven-feature:last-child {
  border-right: 0;
}

.feature-icon {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  color: var(--purple);
  font-size: 20px;
}

.coven-feature strong {
  font-size: 13px;
  text-transform: uppercase;
}

.coven-feature p {
  margin: 0;
  font-size: 13px;
}

.bottom-panels {
  display: grid;
  grid-template-columns: 1fr 1.15fr 0.85fr;
  margin: 0 32px 34px;
  border: 1px solid var(--line);
}

.support-panel,
.partners-panel,
.social-panel {
  border: 0;
  border-right: 1px solid var(--line);
  padding: 34px 32px;
}

.social-panel,
.partners-panel {
  justify-content: center;
}

.support-panel {
  display: grid;
  grid-template-columns: 1fr 150px;
  gap: 24px;
  align-items: center;
}

.support-art img {
  width: 145px;
}

.panel-actions {
  display: flex;
  gap: 12px;
}

.social-links,
.footer-social {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin: 12px 0 16px;
}

.social-links a,
.footer-social a {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--purple);
}

.social-links img,
.footer-social img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

.site-footer {
  color: var(--cream);
  background: #1a0c24;
  background-image: radial-gradient(circle at 82% 42%, rgba(95, 40, 145, 0.26), transparent 34%);
  border-top: 1px solid rgba(184, 137, 72, 0.44);
}

.footer-main {
  display: grid;
  grid-template-columns: 1.35fr 0.75fr 0.85fr 1.25fr;
  gap: 34px;
  padding: 40px 56px 32px;
}

.footer-brand img {
  width: 190px;
  margin-bottom: 16px;
}

.footer-brand p,
.footer-column p {
  color: rgba(255, 243, 214, 0.78);
  line-height: 1.45;
}

.footer-column h3 {
  margin: 0 0 12px;
  color: #f8e7bd;
  text-transform: uppercase;
}

.footer-column a {
  display: block;
  margin-bottom: 8px;
  color: rgba(255, 243, 214, 0.82);
  text-decoration: none;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding: 16px 56px;
  border-top: 1px solid rgba(184, 137, 72, 0.28);
  color: rgba(255, 243, 214, 0.70);
  font-size: 12px;
}

/* ============================= */
/* REVIEW - HERO */
/* ============================= */

.review-hero {
  min-height: 560px;
  padding: 28px 56px 44px;
  display: grid;
  grid-template-columns: 38% 62%;
  gap: 12px;
  align-items: center;
}

.review-hero-copy {
  position: relative;
  z-index: 4;
}

.breadcrumb {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  color: var(--ink);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.breadcrumb a {
  text-decoration: none;
}

.review-label {
  margin-bottom: 18px;
}

.review-hero h1 {
  margin: 0 0 12px;
  color: var(--ink);
  font-size: clamp(44px, 4.1vw, 68px);
  line-height: 0.98;
  text-transform: uppercase;
}

.review-hero h1 span {
  font-size: 0.74em;
}

.review-subtitle {
  margin: 0 0 22px;
  font-size: 22px;
  font-style: italic;
}

.review-score {
  margin-bottom: 22px;
}

.rating-row {
  display: flex;
  align-items: center;
  gap: 22px;
}

.rating-cats-large img {
  width: 34px;
  height: 34px;
}

.rating-cats-medium {
  justify-content: center;
  gap: 7px;
}

.rating-cats-medium img {
  width: 32px;
  height: 32px;
}

.rating-number {
  color: var(--purple);
  font-size: 34px;
  line-height: 1;
  font-weight: 700;
}

.rating-caption {
  display: block;
  margin-top: 9px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.review-intro {
  max-width: 610px;
  margin: 0 0 26px;
  font-size: 18px;
  line-height: 1.5;
}

.review-actions {
  display: flex;
  gap: 14px;
}

.review-hero-art {
  min-height: 470px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}

.review-hero-art img {
  width: 128%;
  max-width: none;
  height: auto;
  object-fit: contain;
  transform: translateX(-4%);
  filter: drop-shadow(0 22px 32px rgba(43, 26, 16, 0.16));
}

/* ============================= */
/* REVIEW - 3 CARDS */
/* ============================= */

.review-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.22fr;
  gap: 22px;
  padding: 0 32px 34px;
}

.review-box {
  min-height: 560px;
  padding: 30px 28px;
}

.review-box::after,
.info-card::after,
.pros-cons-panel::before,
.article-body::before,
.related-carousel-section::before,
.quick-verdict-card::before,
.review-ad-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.review-box h2 {
  position: relative;
  z-index: 2;
  margin: 0 0 24px;
  color: var(--ink);
  font-size: 25px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.tech-list {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tech-item {
  display: grid;
  grid-template-columns: 50px 1fr;
  align-items: center;
  gap: 16px;
  min-height: 68px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.tech-item:last-child {
  border-bottom: 0;
}

.tech-item img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  justify-self: center;
}

.tech-item strong {
  display: block;
  margin-bottom: 5px;
  color: var(--ink);
  font-size: 11px;
  text-transform: uppercase;
}

.tech-item small {
  display: block;
  color: var(--muted);
  font-size: 13.5px;
  line-height: 1.35;
}

.watch-box,
.coven-verdict-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.streaming-logo-image {
  position: relative;
  z-index: 2;
  width: 100%;
  min-height: 112px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 8px auto 22px;
}

.streaming-logo-image img {
  width: 300px;
  max-width: 82%;
  max-height: 112px;
  object-fit: contain;
  filter: drop-shadow(0 8px 12px rgba(43, 26, 16, 0.16));
}

.watch-button {
  position: relative;
  z-index: 2;
  min-width: 220px;
}

.available-list {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  width: 100%;
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid rgba(164, 112, 52, 0.32);
}

.device {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
}

.device img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.device small {
  color: rgba(43, 26, 16, 0.78);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
}

.verdict-rating-wrap {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}

.verdict-score {
  color: var(--ink);
  font-size: 17px;
  text-transform: uppercase;
}

.coven-verdict-box p {
  position: relative;
  z-index: 2;
  max-width: 460px;
  margin: 0 auto 28px;
  font-size: 15.5px;
  line-height: 1.52;
}

/* ============================= */
/* PONTOS FORTES E FRACOS */
/* ============================= */

.pros-cons-panel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin: 0 32px 34px;
  padding: 0;
  overflow: hidden;
}

.pros-cons-panel::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 22px;
  bottom: 22px;
  width: 1px;
  background: rgba(164, 112, 52, 0.30);
}

.pros-cons-column {
  position: relative;
  z-index: 2;
  padding: 28px 34px 30px;
}

.pros-cons-title {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-bottom: 18px;
}

.pros-cons-title img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.pros-cons-title h2 {
  margin: 0;
  font-size: 23px;
  line-height: 1;
  text-transform: uppercase;
}

.strengths h2 {
  color: var(--green);
}

.weaknesses h2 {
  color: var(--red);
}

.pros-cons-column ul {
  display: grid;
  gap: 11px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.pros-cons-column li {
  position: relative;
  padding-left: 26px;
  font-size: 15px;
  line-height: 1.42;
}

.pros-cons-column li::before {
  position: absolute;
  left: 0;
  top: 1px;
  width: 17px;
  height: 17px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
}

.strengths li::before {
  content: "✓";
  color: var(--green);
  border: 1px solid rgba(49, 91, 45, 0.42);
}

.weaknesses li::before {
  content: "!";
  color: var(--red);
  border: 1px solid rgba(138, 44, 37, 0.42);
}

/* ============================= */
/* CRÍTICA + SIDEBAR */
/* ============================= */

.editorial-review {
  display: grid;
  grid-template-columns: minmax(0, 760px) minmax(320px, 430px);
  justify-content: center;
  align-items: start;
  gap: 34px;
  padding: 0 32px 42px;
}

.article-body {
  width: 100%;
  max-width: 760px;
  padding: 34px 38px;
}

.article-heading {
  position: relative;
  z-index: 2;
  margin-bottom: 26px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

.article-kicker,
.section-kicker {
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);
  color: var(--purple);
}

.article-heading h2 {
  margin: 0 0 12px;
  color: var(--ink);
  font-size: 34px;
  line-height: 1;
  text-transform: uppercase;
}

.article-heading p {
  margin: 0;
  color: var(--muted);
  font-size: 16.5px;
  line-height: 1.5;
  font-style: italic;
}

.article-body > p,
.article-highlight {
  position: relative;
  z-index: 2;
}

.article-body > p {
  margin: 0 0 18px;
  font-size: 16.5px;
  line-height: 1.72;
}

.lead-paragraph::first-letter {
  float: left;
  margin: 7px 10px 0 0;
  color: var(--purple);
  font-size: 58px;
  line-height: 0.82;
  font-weight: 700;
}

.article-highlight {
  margin: 24px 0;
  padding: 18px 20px;
  border-left: 4px solid var(--purple);
  background: rgba(255, 246, 222, 0.22);
  font-size: 15.5px;
  line-height: 1.55;
}

.article-highlight strong {
  color: var(--purple);
  text-transform: uppercase;
}

.review-sidebar {
  display: grid;
  gap: 22px;
  width: 100%;
  max-width: 430px;
}

.review-quote-section {
  display: flex;
  justify-content: center;
}

.premium-quote {
  width: 100%;
  display: flex;
  justify-content: center;
}

.quote-frame {
  position: relative;
  width: 100%;
  max-width: 410px;
  min-height: 310px;
  padding: 70px 46px 56px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  background-image: url("assets/icons/quote-bg.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-align: center;
}

.review-quote-text {
  max-width: 280px;
  margin: 0 0 14px;
  color: rgba(43, 26, 16, 0.94);
  font-size: 19px;
  line-height: 1.34;
  font-style: italic;
  font-weight: 650;
}

.review-quote-author {
  display: block;
  color: rgba(43, 26, 16, 0.72);
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.quick-verdict-card,
.review-ad-card {
  padding: 26px 24px;
}

.quick-verdict-card h2,
.review-ad-card h2 {
  position: relative;
  z-index: 2;
  margin: 0 0 18px;
  color: var(--ink);
  font-size: 22px;
  text-align: center;
  text-transform: uppercase;
}

.quick-verdict-list {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.quick-verdict-list li {
  padding-bottom: 13px;
  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.quick-verdict-list li:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.quick-verdict-list strong {
  display: block;
  margin-bottom: 5px;
  color: var(--purple);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.quick-verdict-list span {
  color: rgba(43, 26, 16, 0.84);
  font-size: 14px;
  line-height: 1.45;
}

.ad-label {
  position: relative;
  z-index: 2;
  display: block;
  margin-bottom: 12px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.ad-slot-300x250 {
  position: relative;
  z-index: 2;
  width: 300px;
  max-width: 100%;
  aspect-ratio: 300 / 250;
  margin: 0 auto;
  display: grid;
  place-items: center;
  border: 1px dashed rgba(164, 112, 52, 0.55);
  background: rgba(255, 246, 222, 0.18);
  color: rgba(43, 26, 16, 0.46);
  font-size: 12px;
  text-transform: uppercase;
}

/* ============================= */
/* RELACIONADAS */
/* ============================= */

.related-carousel-section {
  margin: 0 32px 34px;
  padding: 30px 30px 34px;
  overflow: hidden;
}

.related-title-row {
  position: relative;
  z-index: 2;
  margin-bottom: 22px;
}

.related-title-row h2 {
  margin: 0;
  color: var(--ink);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.related-carousel-wrap {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  align-items: center;
  gap: 14px;
}

.related-carousel {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

.related-arrow {
  width: 42px;
  height: 86px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);
  color: var(--purple);
  font: 42px/1 Georgia, "Times New Roman", serif;
  cursor: pointer;
}

.related-arrow:hover {
  background: var(--purple);
  color: var(--cream);
}

.mini-review-card {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 3 / 4;
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  border: 1px solid #9f743f;
  border-radius: 8px;
  background-color: var(--card-dark);
  background-image: linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.82) 36%, rgba(20, 10, 5, 0.35) 66%, rgba(20, 10, 5, 0.08) 100%), var(--post-bg);
  background-size: cover;
  background-position: center;
}

.mini-review-card h3 {
  font-size: 16px;
}

/* ============================= */
/* RESPONSIVO */
/* ============================= */

@media (max-width: 1400px) {
  .review-grid,
  .related-carousel {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .topbar {
    height: auto;
    min-height: 155px;
    grid-template-columns: 1fr;
    justify-items: center;
    padding: 26px;
  }

  .primary-nav {
    flex-wrap: wrap;
  }

  .site-search {
    justify-self: center;
  }

  .hero,
  .review-hero,
  .review-area,
  .review-info-grid,
  .editorial-review,
  .info-grid,
  .bottom-panels,
  .footer-main {
    grid-template-columns: 1fr;
  }

  .review-hero-art img {
    width: min(100%, 760px);
    transform: none;
  }

  .coven {
    grid-template-columns: 1fr;
  }

  .coven-invite {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

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

  .review-sidebar,
  .article-body {
    max-width: 860px;
  }
}

@media (max-width: 900px) {
  .page {
    width: 100%;
  }

  .hero,
  .review-hero {
    padding: 38px 24px;
    min-height: auto;
  }

  .hero h1,
  .review-hero h1 {
    font-size: 42px;
  }

  .categories,
  .review-area,
  .info-grid,
  .coven,
  .bottom-panels,
  .pros-cons-panel,
  .related-carousel-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  .categories,
  .review-grid,
  .related-carousel,
  .available-list,
  .coven-features {
    grid-template-columns: 1fr;
  }

  .category-card {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .pros-cons-panel {
    grid-template-columns: 1fr;
  }

  .pros-cons-panel::after {
    display: none;
  }

  .pros-cons-column + .pros-cons-column {
    border-top: 1px solid var(--line);
  }

  .related-carousel-wrap {
    grid-template-columns: 1fr;
  }

  .related-arrow {
    display: none;
  }

  .mini-review-card,
  .post-card {
    max-width: 320px;
    margin: 0 auto;
  }

  .footer-bottom {
    flex-direction: column;
  }
}
/* ================================================= */
/* BOOK REVIEW TEMPLATE - HÁBITOS ATÔMICOS */
/* ajustes exclusivos para livros, sem afetar audiovisual */
/* ================================================= */

.book-review .book-review-hero {
  grid-template-columns: minmax(0, 38%) minmax(0, 62%);
  min-height: 520px;
  padding: 18px 56px 42px;
  overflow: visible;
}

.book-review .book-hero-art {
  min-height: 440px;

  display: flex;
  align-items: center;
  justify-content: flex-end;

  overflow: visible;
}

.book-review .book-hero-art img {
  width: min(780px, 92%);
  max-width: 100%;
  max-height: 500px;
  height: auto;

  object-fit: contain;
  object-position: center right;

  transform: translateX(2%) translateY(8px);

  filter: drop-shadow(0 22px 32px rgba(43, 26, 16, 0.16));
}

.book-review .book-review-hero .review-hero-copy {
  max-width: 620px;
}

.book-review .book-review-hero h1 {
  font-size: clamp(44px, 4vw, 66px);
  line-height: 0.98;
}

.book-review .book-review-hero .book-author-name {
  color: var(--purple);
  font-size: 0.78em;
}

.book-review .book-review-hero .review-intro {
  max-width: 580px;
}

/* Grid principal dos livros */

.book-review .book-info-grid {
  grid-template-columns: 1fr 1fr 1.16fr;
}

/* ================================================= */
/* BOOK REVIEW - ONDE COMPRAR COM LOGO DA LOJA */
/* ================================================= */

.book-review .book-buy-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  min-height: 560px;
  text-align: center;
}

.book-review .book-buy-main {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 380px;

  display: flex;
  flex-direction: column;
  align-items: center;
}

.book-review .buy-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  margin-bottom: 12px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-size: 10.5px;
  line-height: 1;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Logo da loja indicada, equivalente à logo de streaming no audiovisual */
.book-review .book-store-logo {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 260px;
  min-height: 92px;

  display: flex;
  align-items: center;
  justify-content: center;

  margin: 4px auto 14px;
}

.book-review .book-store-logo img {
  width: auto;
  max-width: 230px;
  max-height: 82px;

  object-fit: contain;
  display: block;

  filter:
    drop-shadow(0 8px 12px rgba(43, 26, 16, 0.12))
    drop-shadow(0 0 10px rgba(255, 246, 222, 0.18));
}

.book-review .book-store-logo.is-wide img {
  max-width: 270px;
  max-height: 72px;
}

.book-review .book-store-logo.is-square img {
  max-width: 120px;
  max-height: 120px;
}

.book-review .buy-store-name {
  display: block;

  margin: 0 0 12px;

  color: var(--ink);
  font-size: 24px;
  line-height: 1.12;
  text-transform: uppercase;
}

.book-review .book-buy-main p {
  max-width: 320px;
  margin: 0 0 20px;

  color: rgba(43, 26, 16, 0.82);
  font-size: 15px;
  line-height: 1.45;
}

.book-review .buy-main-button {
  min-width: 220px;
  margin-bottom: 12px;
}

.book-review .affiliate-note {
  display: block;

  max-width: 280px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.58);
  font-size: 11px;
  line-height: 1.35;
}

/* Formatos disponíveis */

.book-review .book-format-options {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 380px;

  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;

  margin-top: 28px;
  padding-top: 22px;

  border-top: 1px solid rgba(164, 112, 52, 0.32);
}

.book-review .book-format-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;

  padding: 12px 8px;

  border: 1px solid rgba(164, 112, 52, 0.24);
  background: rgba(255, 246, 222, 0.12);
}

.book-review .book-format-option img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  opacity: 0.86;
}

.book-review .book-format-option strong {
  color: rgba(43, 26, 16, 0.80);
  font-size: 11px;
  line-height: 1;
  text-transform: uppercase;
}

/* Links alternativos */

.book-review .buy-alt-links {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 380px;

  display: grid;
  gap: 8px;

  margin-top: 18px;
}

.book-review .buy-alt-links a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;

  padding: 10px 12px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.28);
  background: rgba(255, 246, 222, 0.10);

  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.book-review .buy-alt-links a:hover {
  background: var(--purple);
  color: var(--cream);
  transform: translateY(-2px);
}

/* ================================================= */
/* BOOK REVIEW - IDEIAS FAVORITAS */
/* ================================================= */

.book-review .book-quotes-panel {
  position: relative;

  margin: 0 32px 34px;
  padding: 30px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.book-review .book-quotes-panel::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.book-review .book-quote-grid {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.book-review .book-quote-card {
  min-height: 150px;
  padding: 24px 22px;

  display: flex;
  flex-direction: column;
  justify-content: center;

  border: 1px solid rgba(164, 112, 52, 0.32);
  background:
    radial-gradient(circle at 92% 12%, rgba(74, 35, 107, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);

  text-align: center;
}

.book-review .book-quote-card strong {
  display: block;
  margin-bottom: 12px;

  color: var(--purple);
  font-size: 14px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.book-review .book-quote-card p {
  margin: 0;

  color: rgba(43, 26, 16, 0.84);
  font-size: 15px;
  line-height: 1.48;
}

/* ================================================= */
/* BOOK REVIEW - RESPONSIVO */
/* ================================================= */

@media (max-width: 1100px) {
  .book-review .book-review-hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 30px 36px 44px;
  }

  .book-review .book-hero-art {
    min-height: auto;
    justify-content: center;
  }

  .book-review .book-hero-art img {
    width: min(100%, 720px);
    max-height: none;
    transform: none;
  }

  .book-review .book-info-grid {
    grid-template-columns: 1fr;
  }

  .book-review .book-quote-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .book-review .book-review-hero {
    padding: 30px 24px 40px;
  }

  .book-review .book-review-hero h1 {
    font-size: 42px;
  }

  .book-review .book-hero-art img {
    width: min(100%, 620px);
  }

  .book-review .book-buy-box {
    min-height: auto;
  }

  .book-review .book-format-options {
    grid-template-columns: 1fr;
  }

  .book-review .buy-main-button {
    width: 100%;
  }

  .book-review .book-quotes-panel {
    margin-left: 20px;
    margin-right: 20px;
    padding: 26px 22px;
  }
}
/* ================================================= */
/* BOOK REVIEW - FRASES FAVORITAS + PONTOS */
/* layout na mesma linha, próximo ao mockup */
/* ================================================= */

.book-review .book-middle-grid {
  display: grid;
  grid-template-columns: minmax(300px, 0.92fr) minmax(0, 1.58fr);
  gap: 22px;

  margin: 0 32px 34px;
  align-items: stretch;
}

/* FRASES FAVORITAS */

.book-review .book-favorite-quotes {
  position: relative;

  min-height: 300px;
  padding: 30px 30px 28px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 92%, rgba(184, 137, 72, 0.10), transparent 34%),
    rgba(255, 246, 222, 0.12);

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  text-align: center;
  overflow: hidden;
}

.book-review .book-favorite-quotes::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.book-review .book-favorite-quotes::after {
  content: "";
  position: absolute;
  left: 18px;
  bottom: 8px;

  width: 110px;
  height: 110px;

  background-image: url("assets/icons/ficha_formato.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: left bottom;

  opacity: 0.10;
  pointer-events: none;
}

.book-review .book-favorite-quotes h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 22px;

  color: var(--ink);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.book-review .favorite-quotes-list {
  position: relative;
  z-index: 2;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  min-height: 210px;
}

.book-review .favorite-quotes-list blockquote {
  position: relative;

  max-width: 420px;
  margin: 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 15px;
  line-height: 1.45;
  font-weight: 700;
}

.book-review .favorite-quotes-list blockquote p {
  display: inline;
  margin: 0;
}

.book-review .quote-symbol {
  display: inline-block;

  margin-right: 8px;

  color: rgba(184, 137, 72, 0.82);
  font-size: 32px;
  line-height: 0;
  font-weight: 700;
  vertical-align: -10px;
}

.book-review .quote-symbol-end {
  margin-left: 8px;
  margin-right: 0;
}

.book-review .quote-divider {
  display: block;

  margin: 16px auto;

  color: var(--gold);
  font-size: 16px;
  line-height: 1;
}

/* PONTOS FORTES / FRACOS DENTRO DO GRID */

.book-review .book-middle-grid .pros-cons-panel {
  margin: 0;
  min-height: 300px;
}

.book-review .book-pros-cons {
  grid-template-columns: 1fr 1fr;
}

.book-review .book-pros-cons .pros-cons-column {
  padding: 30px 34px;
}

.book-review .book-pros-cons .pros-cons-title {
  margin-bottom: 20px;
}

.book-review .book-pros-cons .pros-cons-title img {
  width: 42px;
  height: 42px;
}

.book-review .book-pros-cons .pros-cons-title h2 {
  font-size: 24px;
}

.book-review .book-pros-cons li {
  font-size: 15px;
  line-height: 1.45;
}

/* Remove o bloco antigo se ainda existir em algum teste */
.book-review .book-quotes-panel {
  display: none;
}

/* Responsivo */

@media (max-width: 1100px) {
  .book-review .book-middle-grid {
    grid-template-columns: 1fr;
  }

  .book-review .book-middle-grid .pros-cons-panel {
    min-height: auto;
  }
}

@media (max-width: 900px) {
  .book-review .book-middle-grid {
    margin-left: 20px;
    margin-right: 20px;
  }

  .book-review .book-pros-cons {
    grid-template-columns: 1fr;
  }

  .book-review .book-pros-cons::after {
    display: none;
  }

  .book-review .book-pros-cons .pros-cons-column + .pros-cons-column {
    border-top: 1px solid var(--line);
  }

  .book-review .book-favorite-quotes {
    padding: 28px 22px;
  }
}
/* ================================================= */
/* BOOK REVIEW - AJUSTE DO BREADCRUMB */
/* evita que o breadcrumb invada a logo sem mexer no header */
/* ================================================= */

.book-review .book-review-hero .breadcrumb {
  margin-left: clamp(170px, 13vw, 240px);
  margin-bottom: 24px;
  width: fit-content;
}

/* Em telas menores, volta ao padrão para não quebrar */
@media (max-width: 1100px) {
  .book-review .book-review-hero .breadcrumb {
    margin-left: 0;
  }
}
/* ================================================= */
/* REVIEW - AUTOR E DATA DA RESENHA */
/* bloco editorial abaixo da resenha completa */
/* ================================================= */

.review-author-box {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: 74px minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;

  margin-top: 32px;
  padding-top: 24px;

  border-top: 1px solid rgba(164, 112, 52, 0.32);
}

.review-author-avatar {
  width: 64px;
  height: 64px;

  border-radius: 50%;
  overflow: hidden;

  border: 1px solid rgba(164, 112, 52, 0.54);
  background: rgba(255, 246, 222, 0.18);

  box-shadow:
    0 8px 16px rgba(43, 26, 16, 0.10),
    inset 0 0 0 2px rgba(255, 243, 214, 0.28);
}

.review-author-avatar img {
  width: 100%;
  height: 100%;

  object-fit: cover;
  object-position: center;
}

.review-author-info {
  min-width: 0;

  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.review-author-kicker,
.review-post-date span {
  display: block;

  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.62);
  font-size: 11px;
  line-height: 1;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.review-author-name {
  display: block;

  color: var(--ink);
  font-size: 17px;
  line-height: 1.1;
  text-transform: uppercase;
}

.review-author-role {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: fit-content;
  margin-top: 7px;
  padding: 6px 9px;

  color: var(--cream);
  background: var(--purple);
  border: 1px solid rgba(74, 35, 107, 0.28);

  font-size: 10px;
  line-height: 1;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.review-post-date {
  min-width: 150px;
  padding-left: 22px;

  border-left: 1px solid rgba(164, 112, 52, 0.32);
}

.review-post-date time {
  display: block;

  color: var(--ink);
  font-size: 14px;
  line-height: 1.25;
  font-weight: 700;
}

/* Responsivo */

@media (max-width: 700px) {
  .review-author-box {
    grid-template-columns: 64px 1fr;
  }

  .review-post-date {
    grid-column: 1 / -1;

    min-width: 0;
    padding-left: 0;
    padding-top: 16px;

    border-left: 0;
    border-top: 1px solid rgba(164, 112, 52, 0.24);
  }
}
/* ================================================= */
/* REVIEW - AUTOR/DATA DENTRO DO CABEÇALHO DA RESENHA */
/* use junto com o bloco .review-author-box */
/* ================================================= */

.article-heading .review-author-box {
  margin-top: 22px;
  padding-top: 20px;
  padding-bottom: 0;
}

.article-heading .review-author-box + * {
  margin-top: 0;
}
/* ================================================= */
/* REVIEW - ESPAÇAMENTO DO SELO "RESENHA DO COVEN" */
/* ================================================= */

.article-heading .article-kicker {
  margin-bottom: 14px;
}

.article-heading h2 {
  margin-top: 0;
}
/* ================================================= */
/* HOME HERO - CORREÇÃO FINAL ISOLADA */
/* não afeta páginas de review, livros ou audiovisual */
/* ================================================= */

body.home #home-hero {
  position: relative !important;

  display: grid !important;
  grid-template-columns: minmax(0, 40%) minmax(0, 60%) !important;
  align-items: center !important;
  gap: 18px !important;

  min-height: 680px !important;
  padding: 18px 56px 70px !important;

  overflow: visible !important;
}

body.home #home-hero .hero-text {
  position: relative !important;
  z-index: 5 !important;

  max-width: 660px !important;
  transform: translateY(-6px) !important;
}

body.home #home-hero h1 {
  max-width: 650px !important;
  margin: 0 0 26px !important;

  color: var(--ink) !important;
  font-size: clamp(54px, 4.25vw, 76px) !important;
  line-height: 0.94 !important;
  letter-spacing: -0.035em !important;
  text-transform: uppercase !important;
}

body.home #home-hero p {
  max-width: 560px !important;
  margin: 0 0 30px !important;

  color: var(--ink) !important;
  font-size: 20px !important;
  line-height: 1.38 !important;
}

body.home #home-hero .hero-buttons,
body.home #home-hero .buttons {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 18px !important;
  flex-wrap: wrap !important;
}

body.home #home-hero .hero-image {
  position: relative !important;
  z-index: 4 !important;

  min-height: 560px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  overflow: visible !important;
  pointer-events: none !important;
}

body.home #home-hero .hero-image img {
  width: min(1280px, 148%) !important;
  max-width: none !important;
  height: auto !important;

  display: block !important;
  object-fit: contain !important;
  object-position: center !important;

  transform: translateX(-11%) translateY(12px) !important;
}

/* Categorias alinhadas depois do hero */

body.home .categories {
  position: relative !important;
  z-index: 6 !important;
  margin-top: 0 !important;
}

/* ================================================= */
/* HOME HERO - RESPONSIVO CORRIGIDO */
/* ================================================= */

@media (max-width: 1400px) {
  body.home #home-hero {
    grid-template-columns: minmax(0, 42%) minmax(0, 58%) !important;
    min-height: 650px !important;
    padding: 18px 48px 64px !important;
  }

  body.home #home-hero h1 {
    font-size: clamp(50px, 4.7vw, 68px) !important;
  }

  body.home #home-hero .hero-image {
    min-height: 520px !important;
  }

  body.home #home-hero .hero-image img {
    width: min(1080px, 142%) !important;
    transform: translateX(-8%) translateY(12px) !important;
  }
}

@media (max-width: 1100px) {
  body.home #home-hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 36px 32px 54px !important;
  }

  body.home #home-hero .hero-text {
    max-width: 760px !important;
    transform: none !important;
  }

  body.home #home-hero h1 {
    font-size: clamp(44px, 8vw, 64px) !important;
    line-height: 0.98 !important;
  }

  body.home #home-hero p {
    font-size: 18px !important;
  }

  body.home #home-hero .hero-image {
    min-height: auto !important;
    justify-content: center !important;
  }

  body.home #home-hero .hero-image img {
    width: min(100%, 720px) !important;
    transform: none !important;
  }
}

@media (max-width: 900px) {
  body.home #home-hero {
    padding: 32px 24px 48px !important;
  }

  body.home #home-hero h1 {
    font-size: 42px !important;
  }

  body.home #home-hero p {
    font-size: 17px !important;
  }
}
/* ================================================= */
/* HOME HERO - FIX FINAL DO TÍTULO */
/* Cole no FINAL do style.css. */
/* Este bloco vence as regras antigas sem afetar reviews/livros. */
/* ================================================= */

body.home .page #home-hero {
  position: relative !important;

  display: grid !important;
  grid-template-columns: minmax(0, 37%) minmax(0, 63%) !important;
  align-items: center !important;
  gap: 18px !important;

  min-height: 640px !important;
  padding: 18px 56px 66px !important;

  overflow: visible !important;
}

body.home .page #home-hero .hero-text {
  position: relative !important;
  z-index: 5 !important;

  width: 100% !important;
  max-width: 560px !important;

  transform: translateY(-4px) !important;
}

body.home .page #home-hero h1 {
  width: 100% !important;
  max-width: 560px !important;

  margin: 0 0 24px !important;

  color: var(--ink) !important;
  font-size: clamp(44px, 3.35vw, 62px) !important;
  line-height: 0.94 !important;
  letter-spacing: -0.035em !important;
  text-transform: uppercase !important;
}

body.home .page #home-hero p {
  width: 100% !important;
  max-width: 520px !important;

  margin: 0 0 28px !important;

  color: var(--ink) !important;
  font-size: 19px !important;
  line-height: 1.38 !important;
}

body.home .page #home-hero .hero-buttons,
body.home .page #home-hero .buttons {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 18px !important;
  flex-wrap: wrap !important;
}

body.home .page #home-hero .hero-image {
  position: relative !important;
  z-index: 4 !important;

  width: 100% !important;
  min-height: 540px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  overflow: visible !important;
  pointer-events: none !important;
}

body.home .page #home-hero .hero-image img {
  width: min(1220px, 150%) !important;
  max-width: none !important;
  height: auto !important;

  display: block !important;
  object-fit: contain !important;
  object-position: center !important;

  transform: translateX(-9%) translateY(10px) !important;
}

body.home .categories {
  position: relative !important;
  z-index: 6 !important;
  margin-top: 0 !important;
}

/* Desktop médio, incluindo seu print em 80% */
@media (max-width: 1600px) {
  body.home .page #home-hero {
    grid-template-columns: minmax(0, 38%) minmax(0, 62%) !important;
    min-height: 610px !important;
    padding: 14px 48px 62px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 520px !important;
  }

  body.home .page #home-hero h1 {
    max-width: 520px !important;
    font-size: clamp(42px, 3.15vw, 56px) !important;
  }

  body.home .page #home-hero p {
    max-width: 500px !important;
    font-size: 18px !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: 500px !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(1080px, 144%) !important;
    transform: translateX(-7%) translateY(8px) !important;
  }
}

@media (max-width: 1200px) {
  body.home .page #home-hero {
    grid-template-columns: minmax(0, 42%) minmax(0, 58%) !important;
    min-height: 570px !important;
    padding: 16px 42px 56px !important;
  }

  body.home .page #home-hero h1 {
    font-size: clamp(40px, 4.2vw, 52px) !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(920px, 138%) !important;
    transform: translateX(-5%) translateY(8px) !important;
  }
}

@media (max-width: 1100px) {
  body.home .page #home-hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 36px 32px 54px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 760px !important;
    transform: none !important;
  }

  body.home .page #home-hero h1 {
    max-width: 760px !important;
    font-size: clamp(40px, 7vw, 60px) !important;
    line-height: 0.98 !important;
  }

  body.home .page #home-hero p {
    font-size: 18px !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: auto !important;
    justify-content: center !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(100%, 720px) !important;
    transform: none !important;
  }
}

@media (max-width: 900px) {
  body.home .page #home-hero {
    padding: 32px 24px 48px !important;
  }

  body.home .page #home-hero h1 {
    font-size: 40px !important;
  }

  body.home .page #home-hero p {
    font-size: 17px !important;
  }
}
/* ================================================= */
/* HOME HERO - AJUSTE FINO FINAL */
/* desce título, aumenta arte e puxa para o centro */
/* ================================================= */

body.home .page #home-hero {
  grid-template-columns: minmax(0, 36%) minmax(0, 64%) !important;
  min-height: 680px !important;
  padding-top: 34px !important;
  padding-bottom: 70px !important;
}

body.home .page #home-hero .hero-text {
  max-width: 570px !important;
  transform: translateY(32px) !important;
}

body.home .page #home-hero h1 {
  max-width: 570px !important;
  font-size: clamp(44px, 3.25vw, 60px) !important;
  line-height: 0.94 !important;
}

body.home .page #home-hero p {
  max-width: 530px !important;
}

body.home .page #home-hero .hero-image {
  min-height: 590px !important;
  justify-content: center !important;
}

body.home .page #home-hero .hero-image img {
  width: min(1460px, 172%) !important;
  transform: translateX(-20%) translateY(10px) !important;
}

/* Ajuste para telas até 1600px, como no seu print */

@media (max-width: 1600px) {
  body.home .page #home-hero {
    grid-template-columns: minmax(0, 37%) minmax(0, 63%) !important;
    min-height: 650px !important;
    padding-top: 34px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 540px !important;
    transform: translateY(30px) !important;
  }

  body.home .page #home-hero h1 {
    max-width: 540px !important;
    font-size: clamp(42px, 3.05vw, 56px) !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: 560px !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(1300px, 176%) !important;
    transform: translateX(-18%) translateY(8px) !important;
  }
}
/* ================================================= */
/* HOME - INFO GRID REFINADO */
/* calendário, veredito centralizado e plataformas */
/* ================================================= */

body.home .info-grid {
  align-items: stretch;
}

body.home .info-card {
  overflow: hidden;
}

body.home .calendar-card,
body.home .coven-rating-card,
body.home .guides-card {
  min-height: 285px;
}

/* Calendário */

body.home .calendar-card {
  justify-content: flex-start;
}

body.home .calendar-card .event-list {
  margin-top: 14px;
  margin-bottom: 18px;
}

body.home .calendar-card .event-card {
  grid-template-columns: 58px minmax(0, 1fr) 42px;
  min-height: 58px;
}

body.home .event-platform {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

body.home .platform-icon {
  width: 32px;
  height: 32px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  box-shadow:
    0 6px 12px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

body.home .platform-icon img {
  width: 17px;
  height: 17px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

body.home .platform-twitch {
  background: var(--purple);
}

body.home .platform-youtube {
  background: #c4302b;
}

/* Veredito do Coven centralizado */

body.home .coven-rating-card {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

body.home .coven-rating-inner {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 520px;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

body.home .coven-rating-card h2 {
  margin-bottom: 18px;
}

body.home .coven-rating-card .rating-cats-feature {
  margin: 0 0 16px;
}

body.home .coven-rating-card .rating-title {
  margin-bottom: 14px;
}

body.home .coven-rating-card p {
  max-width: 430px;
  margin: 0 auto 18px;

  text-align: center;
}

body.home .coven-rating-card .info-link {
  margin-top: 0;
}

/* Guias */

body.home .guides-card {
  display: flex;
  flex-direction: column;
}

body.home .guides-card .guide-list {
  margin-top: 14px;
  margin-bottom: 18px;
}

body.home .guides-card .info-link {
  margin-top: auto;
}

/* Responsivo */

@media (max-width: 900px) {
  body.home .calendar-card,
  body.home .coven-rating-card,
  body.home .guides-card {
    min-height: auto;
  }

  body.home .calendar-card .event-card {
    grid-template-columns: 58px minmax(0, 1fr) 42px;
  }
}
/* ================================================= */
/* HOME - ÍCONES DE PLATAFORMA NO CALENDÁRIO */
/* correção Twitch / YouTube */
/* ================================================= */

body.home .event-platform {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

body.home .platform-icon {
  width: 32px;
  height: 32px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  box-shadow:
    0 6px 12px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

body.home .platform-twitch {
  background: var(--purple);
}

body.home .platform-youtube {
  background: #c4302b;
}

/* Twitch usa o PNG normal */
body.home .platform-twitch img {
  width: 17px;
  height: 17px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* YouTube usa o PNG como máscara para virar ícone branco limpo */
body.home .platform-youtube img {
  width: 18px;
  height: 18px;

  object-fit: contain;

  opacity: 1;
  filter: none;

  background: #fff;

  -webkit-mask-image: url("assets/icons/youtube-icon.png");
  mask-image: url("assets/icons/youtube-icon.png");

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;

  -webkit-mask-position: center;
  mask-position: center;

  -webkit-mask-size: contain;
  mask-size: contain;

  content: "";
}
/* ================================================= */
/* LEGOLAS GEEK - OVERRIDES FINAIS */
/* Tipografia + ajustes finais seguros */
/* Carregar DEPOIS do style.css */
/* ================================================= */

:root {
  --font-title: "Cinzel", Georgia, "Times New Roman", serif;
  --font-body: "Cormorant Garamond", Georgia, "Times New Roman", serif;
}

/* ============================= */
/* TIPOGRAFIA GLOBAL */
/* ============================= */

body,
button,
input,
textarea,
select {
  font-family: var(--font-body);
  font-weight: 600;
}

h1,
h2,
h3,
h4,
.primary-nav a,
.lg-btn,
.hero-button,
.post-category,
.review-label,
.live-tag,
.section-kicker,
.article-kicker,
.rating-title,
.verdict-score,
.tech-item strong,
.event-info strong,
.guide-item strong,
.footer-column h3,
.category-card strong,
.see-all,
.info-link,
.review-author-name,
.review-author-role,
.review-author-kicker,
.review-post-date span,
.review-post-date time {
  font-family: var(--font-title);
}

.primary-nav a {
  font-weight: 800;
  letter-spacing: -0.015em;
}

.lg-btn,
.hero-button,
.site-search input {
  font-family: var(--font-title);
  font-weight: 800;
  letter-spacing: -0.01em;
}

#home-hero h1,
.review-hero h1 {
  font-family: var(--font-title) !important;
  font-weight: 900 !important;
  letter-spacing: -0.045em !important;
}

#home-hero p,
.review-subtitle,
.review-intro,
.article-heading p,
.info-card p,
.support-panel p,
.partners-panel p,
.social-panel p,
.coven p,
.article-body > p,
.article-highlight,
.coven-verdict-box p,
.quick-verdict-list span,
.tech-item small,
.event-info small,
.guide-item small,
.category-card span,
.book-quote-card p,
.book-favorite-quotes p {
  font-family: var(--font-body);
  font-weight: 600;
}

.section-title-row h2,
.info-card h2,
.support-panel h2,
.partners-panel h2,
.social-panel h2,
.coven h2,
.review-box h2,
.pros-cons-title h2,
.related-title-row h2,
.article-heading h2,
.quick-verdict-card h2,
.review-ad-card h2,
.book-favorite-quotes h2 {
  font-family: var(--font-title);
  font-weight: 800;
  letter-spacing: -0.025em;
}

.favorite-quotes-list blockquote,
.review-quote-text {
  font-family: var(--font-body);
  font-weight: 700;
  font-style: italic;
}

/* Ajuste fino: Cormorant é mais elegante, mas ocupa diferente da Georgia */
.article-body > p,
.article-highlight {
  font-size: 18px;
}

/* ============================= */
/* HOME HERO - FIX FINAL ATUAL */
/* mantém o hero longe da logo e a arte mais centralizada */
/* ============================= */

body.home .page #home-hero {
  grid-template-columns: minmax(0, 36%) minmax(0, 64%) !important;
  min-height: 680px !important;
  padding-top: 34px !important;
  padding-bottom: 70px !important;
}

body.home .page #home-hero .hero-text {
  max-width: 570px !important;
  transform: translateY(32px) !important;
}

body.home .page #home-hero h1 {
  max-width: 570px !important;
  font-size: clamp(44px, 3.25vw, 60px) !important;
  line-height: 0.94 !important;
}

body.home .page #home-hero p {
  max-width: 530px !important;
}

body.home .page #home-hero .hero-image {
  min-height: 590px !important;
  justify-content: center !important;
}

body.home .page #home-hero .hero-image img {
  width: min(1460px, 172%) !important;
  transform: translateX(-20%) translateY(10px) !important;
}

@media (max-width: 1600px) {
  body.home .page #home-hero {
    grid-template-columns: minmax(0, 37%) minmax(0, 63%) !important;
    min-height: 650px !important;
    padding-top: 34px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 540px !important;
    transform: translateY(30px) !important;
  }

  body.home .page #home-hero h1 {
    max-width: 540px !important;
    font-size: clamp(42px, 3.05vw, 56px) !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: 560px !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(1300px, 176%) !important;
    transform: translateX(-18%) translateY(8px) !important;
  }
}

/* ============================= */
/* HOME - INFO GRID REFINADO */
/* calendário, veredito centralizado e plataformas */
/* ============================= */

body.home .info-grid {
  align-items: stretch;
}

body.home .info-card {
  overflow: hidden;
}

body.home .calendar-card,
body.home .coven-rating-card,
body.home .guides-card {
  min-height: 285px;
}

/* Calendário */

body.home .calendar-card {
  justify-content: flex-start;
}

body.home .calendar-card .event-list {
  margin-top: 14px;
  margin-bottom: 18px;
}

body.home .calendar-card .event-card {
  grid-template-columns: 58px minmax(0, 1fr) 42px;
  min-height: 58px;
}

body.home .event-platform {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

body.home .platform-icon {
  width: 32px;
  height: 32px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  box-shadow:
    0 6px 12px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

body.home .platform-icon img {
  object-fit: contain;
  display: block;
}

body.home .platform-twitch {
  background: var(--purple);
}

body.home .platform-twitch img {
  width: 17px;
  height: 17px;
  filter: brightness(0) invert(1);
}

body.home .platform-youtube {
  background: #c4302b;
}

body.home .platform-youtube img {
  width: 18px;
  height: 18px;
  filter: none;
}

/* Veredito do Coven centralizado */

body.home .coven-rating-card {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

body.home .coven-rating-inner {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 520px;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

body.home .coven-rating-card h2 {
  margin-bottom: 18px;
}

body.home .coven-rating-card .rating-cats-feature {
  margin: 0 0 16px;
}

body.home .coven-rating-card .rating-title {
  margin-bottom: 14px;
}

body.home .coven-rating-card p {
  max-width: 430px;
  margin: 0 auto 18px;
  text-align: center;
}

body.home .coven-rating-card .info-link {
  margin-top: 0;
}

/* Guias */

body.home .guides-card {
  display: flex;
  flex-direction: column;
}

body.home .guides-card .guide-list {
  margin-top: 14px;
  margin-bottom: 18px;
}

body.home .guides-card .info-link {
  margin-top: auto;
}

/* ============================= */
/* BOOK REVIEW - AJUSTES FINAIS */
/* ============================= */

.book-review .book-review-hero .breadcrumb {
  margin-left: clamp(170px, 13vw, 240px);
  margin-bottom: 24px;
  width: fit-content;
}

.article-heading .article-kicker {
  margin-bottom: 16px;
}

.article-heading h2 {
  margin-top: 0;
}

.article-heading .review-author-box {
  margin-top: 22px;
  padding-top: 20px;
  padding-bottom: 0;
}

.article-heading .review-author-box + * {
  margin-top: 0;
}

.book-review .related-title-row {
  align-items: center;
}

.book-review .related-title-row h2 {
  margin-top: 0;
}

/* ============================= */
/* RESPONSIVO */
/* ============================= */

@media (max-width: 1100px) {
  body.home .page #home-hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 36px 32px 54px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 760px !important;
    transform: none !important;
  }

  body.home .page #home-hero h1 {
    max-width: 760px !important;
    font-size: clamp(40px, 7vw, 60px) !important;
    line-height: 0.98 !important;
  }

  body.home .page #home-hero p {
    font-size: 18px !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: auto !important;
    justify-content: center !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(100%, 720px) !important;
    transform: none !important;
  }

  .book-review .book-review-hero .breadcrumb {
    margin-left: 0;
  }
}

@media (max-width: 900px) {
  body.home .calendar-card,
  body.home .coven-rating-card,
  body.home .guides-card {
    min-height: auto;
  }

  body.home .calendar-card .event-card {
    grid-template-columns: 58px minmax(0, 1fr) 42px;
  }

  body.home .page #home-hero {
    padding: 32px 24px 48px !important;
  }

  body.home .page #home-hero h1 {
    font-size: 40px !important;
  }

  body.home .page #home-hero p {
    font-size: 17px !important;
  }
}
/* ================================================= */
/* GAME REVIEW TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .game-review, não altera livro nem audiovisual */
/* ================================================= */

.game-review .game-hero {
  display: grid;
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px);
  gap: 34px;
  align-items: center;

  min-height: 560px;
  padding: 28px 56px 46px;
}

.game-review .game-cover-card {
  position: relative;
  z-index: 2;

  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
  box-shadow:
    0 16px 30px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-cover-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.game-review .game-cover-card img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.28);
}

.game-review .game-hero-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
}

.game-review .game-hero-copy .breadcrumb {
  margin-bottom: 26px;
}

.game-review .game-hero-copy .review-label {
  margin-bottom: 18px;
}

.game-review .game-hero-copy h1 {
  margin: 0 0 24px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4.1vw, 72px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.game-review .game-intro {
  max-width: 720px;
  margin: 22px 0 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 20px;
  line-height: 1.48;
  font-style: italic;
}

/* Byline do hero */

.game-review .game-byline {
  display: grid;
  grid-template-columns: minmax(210px, 1.1fr) repeat(3, minmax(120px, 0.7fr));
  align-items: center;
  gap: 16px;

  max-width: 820px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.24);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.game-review .game-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.game-review .game-author-mini img {
  width: 56px;
  height: 56px;

  border-radius: 50%;
  object-fit: cover;

  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.game-review .game-author-mini span,
.game-review .game-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.game-review .game-author-mini small,
.game-review .game-meta-item small {
  margin-bottom: 4px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.game-review .game-author-mini strong,
.game-review .game-meta-item time,
.game-review .game-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.22;
  text-transform: uppercase;
}

.game-review .game-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

/* Card lateral de informações */

.game-review .game-info-card {
  position: relative;
  z-index: 2;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-info-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-info-card h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.game-review .game-info-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 0;

  margin: 0 0 22px;
  padding: 0;

  list-style: none;
}

.game-review .game-info-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 13px;
  align-items: center;

  padding: 12px 0;

  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.game-review .game-info-list li:last-child {
  border-bottom: 0;
}

.game-review .game-info-list img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  justify-self: center;
}

.game-review .game-info-list strong {
  display: block;
  margin-bottom: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-info-list small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 13px;
  line-height: 1.28;
}

.game-review .game-store-actions {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 12px;
}

.game-review .game-store-button,
.game-review .game-wishlist-button {
  width: 100%;
}

.game-review .game-store-button img {
  width: 19px;
  height: 19px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Veredito horizontal */

.game-review .game-verdict-strip {
  position: relative;

  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) 120px;
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 32px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-verdict-strip::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy,
.game-review .game-verdict-ornament {
  position: relative;
  z-index: 2;
}

.game-review .game-verdict-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.game-review .game-verdict-cats {
  justify-content: center;
  gap: 8px;

  margin-bottom: 14px;
}

.game-review .game-verdict-cats img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.game-review .game-verdict-rating strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy p {
  max-width: 760px;
  margin: 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 18px;
  line-height: 1.52;
}

.game-review .game-verdict-ornament {
  display: flex;
  justify-content: center;
}

.game-review .game-verdict-ornament img {
  max-width: 92px;
  max-height: 110px;
  object-fit: contain;
}

/* Pontos */

.game-review .game-pros-cons {
  grid-template-columns: 1fr 1fr;
}

/* Análise completa */

.game-review .game-analysis-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 340px);
  gap: 30px;
  align-items: start;

  margin: 0 32px 34px;
}

.game-review .game-analysis-body {
  position: relative;

  min-height: 420px;
  padding: 34px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-analysis-body::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-analysis-body > p,
.game-review .game-analysis-body .article-highlight,
.game-review .game-analysis-body .article-heading {
  position: relative;
  z-index: 2;
}

.game-review .game-analysis-body > p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.90);
  font-size: 18px;
  line-height: 1.72;
}

.game-review .game-analysis-art {
  min-height: 420px;

  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 0.42;
  pointer-events: none;
}

.game-review .game-analysis-art img {
  max-width: 100%;
  max-height: 420px;
  object-fit: contain;
}

/* Relacionadas de games */

.game-review .game-related-section {
  margin-top: 0;
}

.game-review .game-related-grid {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.game-review .game-related-card {
  position: relative;

  display: grid;
  grid-template-columns: 42% 1fr;
  min-height: 180px;
  overflow: hidden;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-related-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(43, 26, 16, 0.14);
}

.game-review .game-related-card .post-category {
  top: 10px;
  left: 10px;
}

.game-review .game-related-thumb {
  min-height: 180px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.35), rgba(20, 10, 5, 0.02)),
    var(--post-bg);
  background-size: cover;
  background-position: center;
}

.game-review .game-related-copy {
  padding: 18px 18px 16px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.game-review .game-related-copy h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.05;
  text-transform: uppercase;
}

.game-review .game-related-copy p {
  margin: 0 0 12px;

  color: rgba(43, 26, 16, 0.74);
  font-size: 14px;
  line-height: 1.34;
}

/* Bloco apoio / compartilhar */

.game-review .game-support-share {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(280px, 420px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-support-art img {
  max-width: 200px;
  max-height: 150px;
  object-fit: contain;
}

.game-review .game-support-copy h2,
.game-review .game-share-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-support-copy p {
  max-width: 420px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.4;
}

.game-review .game-share-copy {
  text-align: center;
}

.game-review .game-share-copy .social-links {
  margin-bottom: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  }

  .game-review .game-info-card {
    grid-column: 1 / -1;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr 1fr;
  }

  .game-review .game-verdict-strip {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-verdict-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .game-review .game-analysis-section {
    grid-template-columns: 1fr;
  }

  .game-review .game-analysis-art {
    display: none;
  }

  .game-review .game-support-share {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-support-art img {
    margin: 0 auto;
  }

  .game-review .game-support-copy p,
  .game-review .panel-actions {
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr;
    padding: 30px 24px 42px;
  }

  .game-review .game-cover-card {
    max-width: 320px;
    margin: 0 auto;
  }

  .game-review .game-hero-copy h1 {
    font-size: 42px;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr;
  }

  .game-review .game-verdict-strip,
  .game-review .game-analysis-section,
  .game-review .game-support-share {
    margin-left: 20px;
    margin-right: 20px;
  }

  .game-review .game-verdict-cats img {
    width: 34px;
    height: 34px;
  }

  .game-review .game-pros-cons {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-grid {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-card {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-thumb {
    min-height: 220px;
  }
}
/* ================================================= */
/* GAME REVIEW TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .game-review, não altera livro nem audiovisual */
/* ================================================= */

.game-review .game-hero {
  display: grid;
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px);
  gap: 34px;
  align-items: center;

  min-height: 560px;
  padding: 28px 56px 46px;
}

.game-review .game-cover-card {
  position: relative;
  z-index: 2;

  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
  box-shadow:
    0 16px 30px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-cover-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.game-review .game-cover-card img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.28);
}

.game-review .game-hero-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
}

.game-review .game-hero-copy .breadcrumb {
  margin-bottom: 26px;
}

.game-review .game-hero-copy .review-label {
  margin-bottom: 18px;
}

.game-review .game-hero-copy h1 {
  margin: 0 0 24px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4.1vw, 72px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.game-review .game-intro {
  max-width: 720px;
  margin: 22px 0 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 20px;
  line-height: 1.48;
  font-style: italic;
}

/* Byline do hero */

.game-review .game-byline {
  display: grid;
  grid-template-columns: minmax(210px, 1.1fr) repeat(3, minmax(120px, 0.7fr));
  align-items: center;
  gap: 16px;

  max-width: 820px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.24);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.game-review .game-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.game-review .game-author-mini img {
  width: 56px;
  height: 56px;

  border-radius: 50%;
  object-fit: cover;

  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.game-review .game-author-mini span,
.game-review .game-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.game-review .game-author-mini small,
.game-review .game-meta-item small {
  margin-bottom: 4px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.game-review .game-author-mini strong,
.game-review .game-meta-item time,
.game-review .game-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.22;
  text-transform: uppercase;
}

.game-review .game-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

/* Card lateral de informações */

.game-review .game-info-card {
  position: relative;
  z-index: 2;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-info-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-info-card h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.game-review .game-info-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 0;

  margin: 0 0 22px;
  padding: 0;

  list-style: none;
}

.game-review .game-info-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 13px;
  align-items: center;

  padding: 12px 0;

  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.game-review .game-info-list li:last-child {
  border-bottom: 0;
}

.game-review .game-info-list img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  justify-self: center;
}

.game-review .game-info-list strong {
  display: block;
  margin-bottom: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-info-list small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 13px;
  line-height: 1.28;
}

.game-review .game-store-actions {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 12px;
}

.game-review .game-store-button,
.game-review .game-wishlist-button {
  width: 100%;
}

.game-review .game-store-button img {
  width: 19px;
  height: 19px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Veredito horizontal */

.game-review .game-verdict-strip {
  position: relative;

  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) 120px;
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 32px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-verdict-strip::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy,
.game-review .game-verdict-ornament {
  position: relative;
  z-index: 2;
}

.game-review .game-verdict-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.game-review .game-verdict-cats {
  justify-content: center;
  gap: 8px;

  margin-bottom: 14px;
}

.game-review .game-verdict-cats img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.game-review .game-verdict-rating strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy p {
  max-width: 760px;
  margin: 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 18px;
  line-height: 1.52;
}

.game-review .game-verdict-ornament {
  display: flex;
  justify-content: center;
}

.game-review .game-verdict-ornament img {
  max-width: 92px;
  max-height: 110px;
  object-fit: contain;
}

/* Pontos */

.game-review .game-pros-cons {
  grid-template-columns: 1fr 1fr;
}

/* Análise completa */

.game-review .game-analysis-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 340px);
  gap: 30px;
  align-items: start;

  margin: 0 32px 34px;
}

.game-review .game-analysis-body {
  position: relative;

  min-height: 420px;
  padding: 34px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-analysis-body::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-analysis-body > p,
.game-review .game-analysis-body .article-highlight,
.game-review .game-analysis-body .article-heading {
  position: relative;
  z-index: 2;
}

.game-review .game-analysis-body > p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.90);
  font-size: 18px;
  line-height: 1.72;
}

.game-review .game-analysis-art {
  min-height: 420px;

  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 0.42;
  pointer-events: none;
}

.game-review .game-analysis-art img {
  max-width: 100%;
  max-height: 420px;
  object-fit: contain;
}

/* Relacionadas de games */

.game-review .game-related-section {
  margin-top: 0;
}

.game-review .game-related-grid {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.game-review .game-related-card {
  position: relative;

  display: grid;
  grid-template-columns: 42% 1fr;
  min-height: 180px;
  overflow: hidden;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-related-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(43, 26, 16, 0.14);
}

.game-review .game-related-card .post-category {
  top: 10px;
  left: 10px;
}

.game-review .game-related-thumb {
  min-height: 180px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.35), rgba(20, 10, 5, 0.02)),
    var(--post-bg);
  background-size: cover;
  background-position: center;
}

.game-review .game-related-copy {
  padding: 18px 18px 16px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.game-review .game-related-copy h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.05;
  text-transform: uppercase;
}

.game-review .game-related-copy p {
  margin: 0 0 12px;

  color: rgba(43, 26, 16, 0.74);
  font-size: 14px;
  line-height: 1.34;
}

/* Bloco apoio / compartilhar */

.game-review .game-support-share {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(280px, 420px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-support-art img {
  max-width: 200px;
  max-height: 150px;
  object-fit: contain;
}

.game-review .game-support-copy h2,
.game-review .game-share-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-support-copy p {
  max-width: 420px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.4;
}

.game-review .game-share-copy {
  text-align: center;
}

.game-review .game-share-copy .social-links {
  margin-bottom: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  }

  .game-review .game-info-card {
    grid-column: 1 / -1;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr 1fr;
  }

  .game-review .game-verdict-strip {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-verdict-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .game-review .game-analysis-section {
    grid-template-columns: 1fr;
  }

  .game-review .game-analysis-art {
    display: none;
  }

  .game-review .game-support-share {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-support-art img {
    margin: 0 auto;
  }

  .game-review .game-support-copy p,
  .game-review .panel-actions {
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr;
    padding: 30px 24px 42px;
  }

  .game-review .game-cover-card {
    max-width: 320px;
    margin: 0 auto;
  }

  .game-review .game-hero-copy h1 {
    font-size: 42px;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr;
  }

  .game-review .game-verdict-strip,
  .game-review .game-analysis-section,
  .game-review .game-support-share {
    margin-left: 20px;
    margin-right: 20px;
  }

  .game-review .game-verdict-cats img {
    width: 34px;
    height: 34px;
  }

  .game-review .game-pros-cons {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-grid {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-card {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-thumb {
    min-height: 220px;
  }
}

/* ================================================= */
/* GAME REVIEW - CORREÇÕES DO HERO / INFO / VEREDITO */
/* Cole depois do CSS de games, ou substitua o bloco antigo */
/* ================================================= */

/* Hero mais afastado da logo e com as três colunas alinhadas */
.game-review .game-hero {
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px) !important;
  align-items: start !important;

  min-height: 560px !important;
  padding: 72px 56px 46px !important;
}

.game-review .game-cover-card,
.game-review .game-hero-copy,
.game-review .game-info-card {
  align-self: start !important;
}

/* Capa sem corte: respeita a proporção original da imagem enviada */
.game-review .game-cover-card {
  width: 100% !important;
  max-width: 330px !important;
  justify-self: center !important;
  overflow: visible !important;
}

.game-review .game-cover-card img {
  width: 100% !important;
  height: auto !important;
  max-height: none !important;

  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center !important;
}

/* Card de informações alinhado com a capa */
.game-review .game-info-card {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: end !important;
}

/* Remove ícones quebrados da lista, caso os assets game_*.png ainda não existam */
.game-review .game-info-list-clean li {
  grid-template-columns: 1fr !important;
  gap: 0 !important;
}

.game-review .game-info-list-clean li > img {
  display: none !important;
}

/* Disponível em: plataformas/lojas */
.game-review .game-available-box {
  position: relative;
  z-index: 2;

  margin-top: 22px;
  padding-top: 20px;

  border-top: 1px solid rgba(164, 112, 52, 0.28);
  text-align: center;
}

.game-review .game-available-title {
  display: block;

  margin-bottom: 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.game-review .game-platform-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.game-review .game-platform-grid a {
  min-height: 58px;
  padding: 10px 12px;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 1px solid rgba(164, 112, 52, 0.30);
  background: rgba(255, 246, 222, 0.12);

  text-decoration: none;

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-platform-grid a:hover {
  transform: translateY(-2px);
  background: rgba(255, 246, 222, 0.22);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.10);
}

.game-review .game-platform-grid img {
  width: auto !important;
  max-width: 112px !important;
  max-height: 34px !important;

  object-fit: contain !important;
}

/* Veredito do Coven centralizado */
.game-review .game-verdict-strip {
  grid-template-columns: 1fr !important;
  gap: 18px !important;

  text-align: center !important;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}

.game-review .game-verdict-copy h2 {
  text-align: center !important;
}

.game-review .game-verdict-copy p {
  max-width: 920px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.game-review .game-verdict-ornament {
  display: none !important;
}

/* Responsivo das correções */
@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) !important;
    padding-top: 54px !important;
  }

  .game-review .game-info-card {
    grid-column: 1 / -1 !important;
    max-width: none !important;
    justify-self: stretch !important;
  }

  .game-review .game-platform-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr !important;
    padding: 34px 24px 42px !important;
  }

  .game-review .game-cover-card,
  .game-review .game-info-card {
    max-width: 360px !important;
    justify-self: center !important;
  }

  .game-review .game-platform-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
/* ================================================= */
/* GAME REVIEW - PLATAFORMAS DISPONÍVEIS REFINADO */
/* logos menores, lado a lado, sem caixas */
/* ================================================= */

.game-review .game-available-box {
  position: relative;
  z-index: 2;

  margin-top: 22px;
  padding-top: 20px;

  border-top: 1px solid rgba(164, 112, 52, 0.28);
  text-align: center;
}

.game-review .game-available-title {
  display: block;

  margin-bottom: 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.game-review .game-platform-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;

  width: 100%;
  margin: 0 auto;
}

.game-review .game-platform-grid a {
  width: 42px;
  height: 42px;
  padding: 0;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 0;
  background: transparent;
  box-shadow: none;

  text-decoration: none;

  opacity: 0.82;

  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    filter 0.2s ease;
}

.game-review .game-platform-grid a:hover {
  opacity: 1;
  transform: translateY(-2px);
  filter: drop-shadow(0 6px 8px rgba(43, 26, 16, 0.16));
}

.game-review .game-platform-grid img {
  width: auto !important;
  max-width: 38px !important;
  max-height: 28px !important;

  object-fit: contain !important;
  display: block;
}

/* Ajustes finos por tipo de logo */

.game-review .game-platform-grid img[alt="PlayStation"] {
  max-width: 28px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="Xbox"] {
  max-width: 42px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="PC"] {
  max-width: 38px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="Steam"] {
  max-width: 30px !important;
  max-height: 30px !important;
}

/* Responsivo */

@media (max-width: 900px) {
  .game-review .game-platform-grid {
    gap: 16px;
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* GAME REVIEW - SIDEBAR DA ANÁLISE */
/* vídeo, ads e Discord */
/* ================================================= */

.game-review .game-analysis-section {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px) !important;
  gap: 30px !important;
  align-items: start !important;
}

.game-review .game-review-sidebar {
  display: grid;
  gap: 22px;

  width: 100%;
  max-width: 360px;
}

.game-review .game-video-box,
.game-review .game-sidebar-ad,
.game-review .game-discord-box {
  position: relative;

  padding: 24px 22px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  text-align: center;
  overflow: hidden;
}

.game-review .game-video-box::before,
.game-review .game-sidebar-ad::before,
.game-review .game-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 auto 12px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.game-review .game-video-box h2,
.game-review .game-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-video-thumb {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;

  width: 100%;
  aspect-ratio: 16 / 9;

  margin: 0 auto 16px;

  overflow: hidden;
  border: 1px solid rgba(164, 112, 52, 0.36);

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.64), rgba(20, 10, 5, 0.18)),
    var(--video-thumb);
  background-size: cover;
  background-position: center;

  text-decoration: none;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.game-review .game-video-thumb:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.16);
  filter: brightness(1.06);
}

.game-review .video-play-button {
  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: #c4302b;
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.26),
    inset 0 0 0 1px rgba(255, 243, 214, 0.24);
}

.game-review .video-play-button img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.game-review .game-video-box p,
.game-review .game-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.42;
}

.game-review .game-video-button,
.game-review .discord-button {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Ads */

.game-review .game-sidebar-ad {
  padding-top: 24px;
  padding-bottom: 24px;
}

.game-review .game-sidebar-ad .ad-label {
  position: relative;
  z-index: 2;

  display: block;
  margin-bottom: 12px;

  color: var(--muted);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.game-review .game-sidebar-ad .ad-slot-300x250 {
  position: relative;
  z-index: 2;

  width: 300px;
  max-width: 100%;
  aspect-ratio: 300 / 250;

  margin: 0 auto;

  display: grid;
  place-items: center;

  border: 1px dashed rgba(164, 112, 52, 0.55);
  background: rgba(255, 246, 222, 0.18);

  color: rgba(43, 26, 16, 0.46);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  text-transform: uppercase;
}

/* Discord */

.game-review .discord-icon-wrap {
  position: relative;
  z-index: 2;

  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;

  margin: 0 auto 14px;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.game-review .discord-icon-wrap img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Remove a antiga arte lateral se ainda existir em algum teste */

.game-review .game-analysis-art {
  display: none !important;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-analysis-section {
    grid-template-columns: 1fr !important;
  }

  .game-review .game-review-sidebar {
    max-width: none;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .game-review .game-sidebar-ad .ad-slot-300x250 {
    width: 100%;
  }
}

@media (max-width: 900px) {
  .game-review .game-review-sidebar {
    grid-template-columns: 1fr;
  }

  .game-review .game-video-box,
  .game-review .game-sidebar-ad,
  .game-review .game-discord-box {
    padding: 24px 20px;
  }
}
/* ================================================= */
/* GAME REVIEW TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .game-review, não altera livro nem audiovisual */
/* ================================================= */

.game-review .game-hero {
  display: grid;
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px);
  gap: 34px;
  align-items: center;

  min-height: 560px;
  padding: 28px 56px 46px;
}

.game-review .game-cover-card {
  position: relative;
  z-index: 2;

  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
  box-shadow:
    0 16px 30px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-cover-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.game-review .game-cover-card img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.28);
}

.game-review .game-hero-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
}

.game-review .game-hero-copy .breadcrumb {
  margin-bottom: 26px;
}

.game-review .game-hero-copy .review-label {
  margin-bottom: 18px;
}

.game-review .game-hero-copy h1 {
  margin: 0 0 24px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4.1vw, 72px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.game-review .game-intro {
  max-width: 720px;
  margin: 22px 0 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 20px;
  line-height: 1.48;
  font-style: italic;
}

/* Byline do hero */

.game-review .game-byline {
  display: grid;
  grid-template-columns: minmax(210px, 1.1fr) repeat(3, minmax(120px, 0.7fr));
  align-items: center;
  gap: 16px;

  max-width: 820px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.24);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.game-review .game-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.game-review .game-author-mini img {
  width: 56px;
  height: 56px;

  border-radius: 50%;
  object-fit: cover;

  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.game-review .game-author-mini span,
.game-review .game-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.game-review .game-author-mini small,
.game-review .game-meta-item small {
  margin-bottom: 4px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.game-review .game-author-mini strong,
.game-review .game-meta-item time,
.game-review .game-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.22;
  text-transform: uppercase;
}

.game-review .game-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

/* Card lateral de informações */

.game-review .game-info-card {
  position: relative;
  z-index: 2;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-info-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-info-card h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.game-review .game-info-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 0;

  margin: 0 0 22px;
  padding: 0;

  list-style: none;
}

.game-review .game-info-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 13px;
  align-items: center;

  padding: 12px 0;

  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.game-review .game-info-list li:last-child {
  border-bottom: 0;
}

.game-review .game-info-list img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  justify-self: center;
}

.game-review .game-info-list strong {
  display: block;
  margin-bottom: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-info-list small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 13px;
  line-height: 1.28;
}

.game-review .game-store-actions {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 12px;
}

.game-review .game-store-button,
.game-review .game-wishlist-button {
  width: 100%;
}

.game-review .game-store-button img {
  width: 19px;
  height: 19px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Veredito horizontal */

.game-review .game-verdict-strip {
  position: relative;

  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) 120px;
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 32px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-verdict-strip::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy,
.game-review .game-verdict-ornament {
  position: relative;
  z-index: 2;
}

.game-review .game-verdict-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.game-review .game-verdict-cats {
  justify-content: center;
  gap: 8px;

  margin-bottom: 14px;
}

.game-review .game-verdict-cats img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.game-review .game-verdict-rating strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy p {
  max-width: 760px;
  margin: 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 18px;
  line-height: 1.52;
}

.game-review .game-verdict-ornament {
  display: flex;
  justify-content: center;
}

.game-review .game-verdict-ornament img {
  max-width: 92px;
  max-height: 110px;
  object-fit: contain;
}

/* Pontos */

.game-review .game-pros-cons {
  grid-template-columns: 1fr 1fr;
}

/* Análise completa */

.game-review .game-analysis-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 340px);
  gap: 30px;
  align-items: start;

  margin: 0 32px 34px;
}

.game-review .game-analysis-body {
  position: relative;

  min-height: 420px;
  padding: 34px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-analysis-body::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-analysis-body > p,
.game-review .game-analysis-body .article-highlight,
.game-review .game-analysis-body .article-heading {
  position: relative;
  z-index: 2;
}

.game-review .game-analysis-body > p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.90);
  font-size: 18px;
  line-height: 1.72;
}

.game-review .game-analysis-art {
  min-height: 420px;

  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 0.42;
  pointer-events: none;
}

.game-review .game-analysis-art img {
  max-width: 100%;
  max-height: 420px;
  object-fit: contain;
}

/* Relacionadas de games */

.game-review .game-related-section {
  margin-top: 0;
}

.game-review .game-related-grid {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.game-review .game-related-card {
  position: relative;

  display: grid;
  grid-template-columns: 42% 1fr;
  min-height: 180px;
  overflow: hidden;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-related-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(43, 26, 16, 0.14);
}

.game-review .game-related-card .post-category {
  top: 10px;
  left: 10px;
}

.game-review .game-related-thumb {
  min-height: 180px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.35), rgba(20, 10, 5, 0.02)),
    var(--post-bg);
  background-size: cover;
  background-position: center;
}

.game-review .game-related-copy {
  padding: 18px 18px 16px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.game-review .game-related-copy h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.05;
  text-transform: uppercase;
}

.game-review .game-related-copy p {
  margin: 0 0 12px;

  color: rgba(43, 26, 16, 0.74);
  font-size: 14px;
  line-height: 1.34;
}

/* Bloco apoio / compartilhar */

.game-review .game-support-share {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(280px, 420px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-support-art img {
  max-width: 200px;
  max-height: 150px;
  object-fit: contain;
}

.game-review .game-support-copy h2,
.game-review .game-share-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-support-copy p {
  max-width: 420px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.4;
}

.game-review .game-share-copy {
  text-align: center;
}

.game-review .game-share-copy .social-links {
  margin-bottom: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  }

  .game-review .game-info-card {
    grid-column: 1 / -1;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr 1fr;
  }

  .game-review .game-verdict-strip {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-verdict-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .game-review .game-analysis-section {
    grid-template-columns: 1fr;
  }

  .game-review .game-analysis-art {
    display: none;
  }

  .game-review .game-support-share {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-support-art img {
    margin: 0 auto;
  }

  .game-review .game-support-copy p,
  .game-review .panel-actions {
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr;
    padding: 30px 24px 42px;
  }

  .game-review .game-cover-card {
    max-width: 320px;
    margin: 0 auto;
  }

  .game-review .game-hero-copy h1 {
    font-size: 42px;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr;
  }

  .game-review .game-verdict-strip,
  .game-review .game-analysis-section,
  .game-review .game-support-share {
    margin-left: 20px;
    margin-right: 20px;
  }

  .game-review .game-verdict-cats img {
    width: 34px;
    height: 34px;
  }

  .game-review .game-pros-cons {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-grid {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-card {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-thumb {
    min-height: 220px;
  }
}

/* ================================================= */
/* GAME REVIEW - CORREÇÕES DO HERO / INFO / VEREDITO */
/* Cole depois do CSS de games, ou substitua o bloco antigo */
/* ================================================= */

/* Hero mais afastado da logo e com as três colunas alinhadas */
.game-review .game-hero {
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px) !important;
  align-items: start !important;

  min-height: 560px !important;
  padding: 72px 56px 46px !important;
}

.game-review .game-cover-card,
.game-review .game-hero-copy,
.game-review .game-info-card {
  align-self: start !important;
}

/* Capa sem corte: respeita a proporção original da imagem enviada */
.game-review .game-cover-card {
  width: 100% !important;
  max-width: 330px !important;
  justify-self: center !important;
  overflow: visible !important;
}

.game-review .game-cover-card img {
  width: 100% !important;
  height: auto !important;
  max-height: none !important;

  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center !important;
}

/* Card de informações alinhado com a capa */
.game-review .game-info-card {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: end !important;
}

/* Remove ícones quebrados da lista, caso os assets game_*.png ainda não existam */
.game-review .game-info-list-clean li {
  grid-template-columns: 1fr !important;
  gap: 0 !important;
}

.game-review .game-info-list-clean li > img {
  display: none !important;
}

/* Disponível em: plataformas/lojas */
.game-review .game-available-box {
  position: relative;
  z-index: 2;

  margin-top: 22px;
  padding-top: 20px;

  border-top: 1px solid rgba(164, 112, 52, 0.28);
  text-align: center;
}

.game-review .game-available-title {
  display: block;

  margin-bottom: 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.game-review .game-platform-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.game-review .game-platform-grid a {
  min-height: 58px;
  padding: 10px 12px;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 1px solid rgba(164, 112, 52, 0.30);
  background: rgba(255, 246, 222, 0.12);

  text-decoration: none;

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-platform-grid a:hover {
  transform: translateY(-2px);
  background: rgba(255, 246, 222, 0.22);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.10);
}

.game-review .game-platform-grid img {
  width: auto !important;
  max-width: 112px !important;
  max-height: 34px !important;

  object-fit: contain !important;
}

/* Veredito do Coven centralizado */
.game-review .game-verdict-strip {
  grid-template-columns: 1fr !important;
  gap: 18px !important;

  text-align: center !important;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}

.game-review .game-verdict-copy h2 {
  text-align: center !important;
}

.game-review .game-verdict-copy p {
  max-width: 920px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.game-review .game-verdict-ornament {
  display: none !important;
}

/* Responsivo das correções */
@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) !important;
    padding-top: 54px !important;
  }

  .game-review .game-info-card {
    grid-column: 1 / -1 !important;
    max-width: none !important;
    justify-self: stretch !important;
  }

  .game-review .game-platform-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr !important;
    padding: 34px 24px 42px !important;
  }

  .game-review .game-cover-card,
  .game-review .game-info-card {
    max-width: 360px !important;
    justify-self: center !important;
  }

  .game-review .game-platform-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ================================================= */
/* GAME REVIEW - PLATAFORMAS DISPONÍVEIS REFINADO */
/* logos menores, lado a lado, sem caixas */
/* ================================================= */

.game-review .game-available-box {
  position: relative;
  z-index: 2;

  margin-top: 22px;
  padding-top: 20px;

  border-top: 1px solid rgba(164, 112, 52, 0.28);
  text-align: center;
}

.game-review .game-available-title {
  display: block;

  margin-bottom: 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.game-review .game-platform-grid {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 18px;

  width: 100%;
  margin: 0 auto;
}

.game-review .game-platform-grid a {
  width: 42px !important;
  height: 42px !important;
  min-height: 0 !important;
  padding: 0 !important;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  text-decoration: none;

  opacity: 0.82;

  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    filter 0.2s ease;
}

.game-review .game-platform-grid a:hover {
  opacity: 1;
  transform: translateY(-2px);
  filter: drop-shadow(0 6px 8px rgba(43, 26, 16, 0.16));
}

.game-review .game-platform-grid img {
  width: auto !important;
  max-width: 38px !important;
  max-height: 28px !important;

  object-fit: contain !important;
  display: block;
}

.game-review .game-platform-grid img[alt="PlayStation"] {
  max-width: 28px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="Xbox"] {
  max-width: 42px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="PC"] {
  max-width: 38px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="Steam"] {
  max-width: 30px !important;
  max-height: 30px !important;
}

@media (max-width: 900px) {
  .game-review .game-platform-grid {
    gap: 16px;
    flex-wrap: wrap;
  }
}

/* ================================================= */
/* GAME REVIEW - SIDEBAR DA ANÁLISE */
/* vídeo, ads e Discord */
/* ================================================= */

.game-review .game-analysis-section {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px) !important;
  gap: 30px !important;
  align-items: start !important;
}

.game-review .game-review-sidebar {
  display: grid;
  gap: 22px;

  width: 100%;
  max-width: 360px;
}

.game-review .game-video-box,
.game-review .game-sidebar-ad,
.game-review .game-discord-box {
  position: relative;

  padding: 24px 22px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  text-align: center;
  overflow: hidden;
}

.game-review .game-video-box::before,
.game-review .game-sidebar-ad::before,
.game-review .game-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 auto 12px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.game-review .game-video-box h2,
.game-review .game-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-video-thumb {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;

  width: 100%;
  aspect-ratio: 16 / 9;

  margin: 0 auto 16px;

  overflow: hidden;
  border: 1px solid rgba(164, 112, 52, 0.36);

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.64), rgba(20, 10, 5, 0.18)),
    var(--video-thumb);
  background-size: cover;
  background-position: center;

  text-decoration: none;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.game-review .game-video-thumb:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.16);
  filter: brightness(1.06);
}

.game-review .video-play-button {
  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: #c4302b;
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.26),
    inset 0 0 0 1px rgba(255, 243, 214, 0.24);
}

.game-review .video-play-button img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.game-review .game-video-box p,
.game-review .game-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.42;
}

.game-review .game-video-button,
.game-review .discord-button {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Ads */

.game-review .game-sidebar-ad {
  padding-top: 24px;
  padding-bottom: 24px;
}

.game-review .game-sidebar-ad .ad-label {
  position: relative;
  z-index: 2;

  display: block;
  margin-bottom: 12px;

  color: var(--muted);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.game-review .game-sidebar-ad .ad-slot-300x250 {
  position: relative;
  z-index: 2;

  width: 300px;
  max-width: 100%;
  aspect-ratio: 300 / 250;

  margin: 0 auto;

  display: grid;
  place-items: center;

  border: 1px dashed rgba(164, 112, 52, 0.55);
  background: rgba(255, 246, 222, 0.18);

  color: rgba(43, 26, 16, 0.46);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  text-transform: uppercase;
}

/* Discord */

.game-review .discord-icon-wrap {
  position: relative;
  z-index: 2;

  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;

  margin: 0 auto 14px;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.game-review .discord-icon-wrap img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Remove a antiga arte lateral se ainda existir em algum teste */

.game-review .game-analysis-art {
  display: none !important;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-analysis-section {
    grid-template-columns: 1fr !important;
  }

  .game-review .game-review-sidebar {
    max-width: none;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .game-review .game-sidebar-ad .ad-slot-300x250 {
    width: 100%;
  }
}

@media (max-width: 900px) {
  .game-review .game-review-sidebar {
    grid-template-columns: 1fr;
  }

  .game-review .game-video-box,
  .game-review .game-sidebar-ad,
  .game-review .game-discord-box {
    padding: 24px 20px;
  }
}

/* ================================================= */
/* GAME REVIEW - MINIATURA DO YOUTUBE */
/* usa thumbnail real do vídeo como background */
/* ================================================= */

.game-review .youtube-video-thumb {
  background-color: #160904;
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.66), rgba(20, 10, 5, 0.16)),
    var(--video-thumb);
  background-size: cover;
  background-position: center;
}

.game-review .youtube-video-thumb::after {
  content: "";

  position: absolute;
  inset: 0;

  background:
    radial-gradient(circle at center, rgba(255, 243, 214, 0.10), transparent 42%),
    linear-gradient(to bottom, rgba(255, 246, 222, 0.02), rgba(20, 10, 5, 0.24));

  pointer-events: none;
}

.game-review .youtube-video-thumb .video-play-button {
  position: relative;
  z-index: 3;
}
/* ================================================= */
/* GAME REVIEW - HERO REFINADO */
/* mais respiro, capa maior e info card alinhado */
/* ================================================= */

.game-review .game-hero {
  grid-template-columns: minmax(320px, 420px) minmax(0, 1fr) minmax(320px, 390px) !important;
  gap: 38px !important;
  align-items: stretch !important;

  min-height: 620px !important;
  padding: 108px 56px 56px !important;
}

/* Capa maior, sem corte e respeitando a proporção original */

.game-review .game-cover-card {
  width: 100% !important;
  max-width: 420px !important;
  height: 100% !important;

  justify-self: center !important;
  align-self: stretch !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  overflow: visible !important;
}

.game-review .game-cover-card img {
  width: 100% !important;
  height: auto !important;

  max-width: 100% !important;
  max-height: none !important;

  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center !important;
}

/* Texto do hero centralizado verticalmente com a capa */

.game-review .game-hero-copy {
  align-self: center !important;
}

/* Caixa de informações acompanhando a altura visual da capa */

.game-review .game-info-card {
  width: 100% !important;
  max-width: 390px !important;
  min-height: 100% !important;

  justify-self: end !important;
  align-self: stretch !important;

  display: flex !important;
  flex-direction: column !important;
}

.game-review .game-info-list {
  flex: 1 !important;
}

.game-review .game-available-box {
  margin-top: auto !important;
}

/* Ajuste fino da lista para respirar melhor no card maior */

.game-review .game-info-list-clean li {
  padding: 14px 0 !important;
}

.game-review .game-info-card h2 {
  margin-bottom: 26px !important;
}

/* Desktop médio */

@media (max-width: 1500px) {
  .game-review .game-hero {
    grid-template-columns: minmax(300px, 390px) minmax(0, 1fr) minmax(300px, 370px) !important;
    gap: 34px !important;
    padding-top: 96px !important;
  }

  .game-review .game-cover-card {
    max-width: 390px !important;
  }

  .game-review .game-info-card {
    max-width: 370px !important;
  }
}

/* Tablet */

@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(280px, 380px) minmax(0, 1fr) !important;
    padding-top: 76px !important;
  }

  .game-review .game-info-card {
    grid-column: 1 / -1 !important;
    max-width: none !important;
    min-height: auto !important;
    justify-self: stretch !important;
  }

  .game-review .game-info-list {
    flex: initial !important;
  }

  .game-review .game-available-box {
    margin-top: 22px !important;
  }
}

/* Mobile */

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr !important;
    padding: 46px 24px 42px !important;
  }

  .game-review .game-cover-card {
    max-width: 380px !important;
    height: auto !important;
  }

  .game-review .game-info-card {
    max-width: 380px !important;
    justify-self: center !important;
  }

  .game-review .game-hero-copy {
    align-self: start !important;
  }
}
/* ================================================= */
/* FOOTER GLOBAL - ÍCONES SOCIAIS CORRIGIDOS */
/* Padroniza Twitch, YouTube e Instagram no rodapé */
/* ================================================= */

.site-footer .footer-social {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;

  margin: 16px 0 0;
}

.site-footer .footer-social a {
  position: relative;

  width: 44px;
  height: 44px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);

  text-decoration: none;
  overflow: hidden;

  box-shadow:
    0 8px 16px rgba(0, 0, 0, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.16);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

/* Esconde os PNGs originais para evitar ícones quebrados/coloridos dentro da bolinha */
.site-footer .footer-social a img {
  display: none !important;
}

.site-footer .footer-social a::before {
  content: "";

  width: 22px;
  height: 22px;

  display: block;

  background: var(--cream);

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;

  -webkit-mask-position: center;
  mask-position: center;

  -webkit-mask-size: contain;
  mask-size: contain;
}

.site-footer .footer-social a:hover {
  transform: translateY(-3px);
  background: var(--purple-dark);

  box-shadow:
    0 12px 20px rgba(0, 0, 0, 0.22),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

/* Ordem atual do footer:
   1 Twitch
   2 YouTube
   3 Instagram
*/

.site-footer .footer-social a:nth-child(1)::before {
  -webkit-mask-image: url("assets/icons/twitch-icon.png");
  mask-image: url("assets/icons/twitch-icon.png");
}

.site-footer .footer-social a:nth-child(2)::before {
  -webkit-mask-image: url("assets/icons/youtube-icon.png");
  mask-image: url("assets/icons/youtube-icon.png");
}

.site-footer .footer-social a:nth-child(3)::before {
  -webkit-mask-image: url("assets/icons/instagram-icon.png");
  mask-image: url("assets/icons/instagram-icon.png");
}
/* ================================================= */
/* FOOTER GLOBAL - CORREÇÃO DO ÍCONE DO YOUTUBE */
/* cria o símbolo em CSS para não depender do PNG */
/* ================================================= */

.site-footer .footer-social a:nth-child(2)::before {
  width: 24px;
  height: 17px;

  background: var(--cream);
  border-radius: 5px;

  -webkit-mask-image: none !important;
  mask-image: none !important;

  -webkit-mask: none !important;
  mask: none !important;
}

.site-footer .footer-social a:nth-child(2)::after {
  content: "";

  position: absolute;
  left: 50%;
  top: 50%;

  width: 0;
  height: 0;

  transform: translate(-38%, -50%);

  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid var(--purple);

  z-index: 2;
}
/* ================================================= */
/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .news-article */
/* ================================================= */

.news-article .news-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.86fr) minmax(520px, 1.14fr);
  gap: 42px;
  align-items: center;

  min-height: 560px;
  padding: 46px 56px 42px;
}

.news-article .news-hero-copy {
  position: relative;
  z-index: 3;
}

.news-article .news-hero .breadcrumb {
  margin-bottom: 28px;
}

.news-article .news-label {
  margin-bottom: 18px;
}

.news-article .news-hero h1 {
  max-width: 660px;
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(44px, 4vw, 76px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.news-article .news-subtitle {
  max-width: 560px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 24px;
  line-height: 1.25;
  font-style: italic;
}

.news-article .news-byline {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(130px, 0.72fr) minmax(130px, 0.72fr) minmax(90px, 0.46fr);
  align-items: center;
  gap: 16px;

  max-width: 720px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.26);
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

.news-article .news-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.news-article .news-author-mini img {
  width: 58px;
  height: 58px;

  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.news-article .news-author-mini span,
.news-article .news-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.news-article .news-author-mini small,
.news-article .news-meta-item small {
  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.news-article .news-author-mini strong,
.news-article .news-meta-item time,
.news-article .news-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

.news-article .news-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 14px;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 34px;
  height: 34px;

  display: grid;
  place-items: center;

  color: var(--ink);
  text-decoration: none;

  border-radius: 50%;
  background: rgba(255, 246, 222, 0.10);

  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: rgba(86, 32, 129, 0.12);
}

.news-article .news-share-row img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.news-article .news-hero-image {
  position: relative;

  margin: 0;
  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  box-shadow:
    0 18px 34px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-hero-image::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.news-article .news-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.24);
}

/* Conteúdo + sidebar */

.news-article .news-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;

  margin: 0 56px 38px;
}

.news-article .news-article-body {
  position: relative;

  padding: 0;

  color: rgba(43, 26, 16, 0.92);
}

.news-article .news-article-body > p {
  max-width: 860px;
  margin: 0 0 20px;

  font-size: 20px;
  line-height: 1.66;
}

.news-article .news-article-body h2 {
  max-width: 860px;
  margin: 34px 0 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  float: left;

  margin: 7px 12px 0 0;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 78px;
  line-height: 0.78;
  font-weight: 900;
}

.news-article .news-quote {
  position: relative;

  max-width: 860px;
  margin: 34px 0;
  padding: 30px 92px 30px 60px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-quote::before {
  content: "“";

  position: absolute;
  left: 28px;
  top: 20px;

  color: var(--purple);
  font-size: 44px;
  line-height: 1;
  opacity: 0.72;
}

.news-article .news-quote::after {
  content: "";

  position: absolute;
  right: 30px;
  bottom: 24px;

  width: 64px;
  height: 64px;

  background-image: url("assets/icons/veredito-gema.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  opacity: 0.72;
}

.news-article .news-quote p {
  margin: 0 0 14px;

  color: var(--purple);
  font-size: 24px;
  line-height: 1.36;
  font-style: italic;
  font-weight: 700;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.72);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

/* Sidebar */

.news-article .news-sidebar {
  display: grid;
  gap: 22px;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  position: relative;

  padding: 26px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 0 18px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.news-article .news-summary-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 16px;

  margin: 0;
  padding: 0;

  list-style: none;
}

.news-article .news-summary-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
}

.news-article .news-summary-list img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  opacity: 0.84;
}

.news-article .news-summary-list span {
  color: rgba(43, 26, 16, 0.82);
  font-size: 15.5px;
  line-height: 1.38;
}

.news-article .news-tags {
  position: relative;
  z-index: 2;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.news-article .news-tags a {
  padding: 7px 10px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.36);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.news-article .news-tags a:hover {
  transform: translateY(-2px);
  background: var(--purple);
  color: var(--cream);
}

.news-article .news-discord-box {
  text-align: center;
}

.news-article .news-discord-art {
  position: relative;
  z-index: 2;

  margin: -8px auto 12px;
}

.news-article .news-discord-art img {
  max-width: 190px;
  max-height: 150px;

  margin: 0 auto;
  object-fit: contain;
}

.news-article .news-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.news-article .news-discord-box .lg-btn {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Mais notícias */

.news-article .more-news-section {
  position: relative;

  margin: 0 56px 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .more-news-section::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .more-news-section .section-title-row,
.news-article .more-news-grid {
  position: relative;
  z-index: 2;
}

.news-article .more-news-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.news-article .news-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 320px;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.13);
}

.news-article .news-card .post-category {
  top: 12px;
  left: 12px;
}

.news-article .news-card-image {
  min-height: 170px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.38), rgba(20, 10, 5, 0.04)),
    var(--news-bg);
  background-size: cover;
  background-position: center;
}

.news-article .news-card-copy {
  padding: 18px;

  display: flex;
  flex: 1;
  flex-direction: column;
}

.news-article .news-card-copy time {
  margin-bottom: 10px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-card-copy h3 {
  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.12;
  text-transform: uppercase;
}

.news-article .news-card-copy small {
  margin-top: auto;

  color: rgba(43, 26, 16, 0.62);
  font-size: 13px;
}

/* Newsletter */

.news-article .newsletter-panel {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .newsletter-art img {
  max-width: 190px;
  max-height: 150px;

  object-fit: contain;
}

.news-article .newsletter-copy h2 {
  margin: 0 0 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .newsletter-copy p {
  max-width: 520px;
  margin: 0;

  color: rgba(43, 26, 16, 0.80);
  font-size: 16px;
  line-height: 1.4;
}

.news-article .newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.news-article .newsletter-form input {
  min-height: 52px;
  min-width: 0;

  padding: 0 16px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.20);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15px;
  outline: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    grid-template-columns: 1fr;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr;
  }

  .news-article .news-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .news-article .newsletter-form {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .news-article .news-byline {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding: 34px 24px 40px;
  }

  .news-article .news-hero h1 {
    font-size: 42px;
  }

  .news-article .news-content-layout,
  .news-article .more-news-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 48px;
  }

  .news-article .news-quote::after {
    display: none;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr;
  }

  .news-article .newsletter-panel {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr;
  }

  .news-article .news-byline {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* NEWS HERO - TAG + BREADCRUMB NA MESMA LINHA */
/* ================================================= */

.news-article .news-label-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;

  margin: 0 0 18px;
}

.news-article .news-label-row .news-label {
  margin: 0;
  flex: 0 0 auto;
}

.news-article .news-breadcrumb-inline {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;

  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

/* Esconde o breadcrumb antigo caso ainda tenha ficado duplicado */
.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none;
}
/* ================================================= */
/* NEWS HERO - SHARE COM CÍRCULOS ROXOS */
/* ================================================= */

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  margin-right: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 36px;
  height: 36px;

  display: grid;
  place-items: center;

  color: var(--cream);
  background: var(--purple);
  border: 1px solid rgba(255, 243, 214, 0.18);
  border-radius: 50%;

  text-decoration: none;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark);

  box-shadow:
    0 12px 20px rgba(43, 26, 16, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.20);
}

.news-article .news-share-row img {
  width: 17px;
  height: 17px;

  object-fit: contain;
  display: block;

  filter: brightness(0) invert(1);
}

.news-article .news-share-row a span {
  color: var(--cream);
  font-size: 16px;
  line-height: 1;
}
/* ================================================= */
/* NEWS HERO - AJUSTE FINO DE POSIÇÃO */
/* desce o hero e afasta breadcrumb da logo */
/* ================================================= */

.news-article .news-hero {
  padding-top: 92px !important;
  padding-bottom: 46px !important;
  align-items: start !important;
}

/* Linha com tag NOTÍCIA + breadcrumb */

.news-article .news-label-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;

  margin: 0 0 20px !important;
}

/* Tag notícia */

.news-article .news-label-row .news-label {
  margin: 0 !important;
  flex: 0 0 auto !important;
}

/* Breadcrumb ao lado da tag, mais à direita e alinhado */

.news-article .news-breadcrumb-inline {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;

  margin: 0 !important;
  transform: translateY(1px);

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

/* Evita que qualquer breadcrumb antigo apareça duplicado */

.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none !important;
}

/* Ajuste do título depois que o hero desce */

.news-article .news-hero h1 {
  margin-top: 0 !important;
}

/* Compartilhamento continua onde está, só com ícones visíveis */

.news-article .news-share-row a {
  width: 36px !important;
  height: 36px !important;

  display: grid !important;
  place-items: center !important;

  color: var(--cream) !important;
  background: var(--purple) !important;
  border: 1px solid rgba(255, 243, 214, 0.18) !important;
  border-radius: 50% !important;

  text-decoration: none !important;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark) !important;
}

.news-article .news-share-row img {
  width: 17px !important;
  height: 17px !important;
  object-fit: contain !important;
  display: block !important;
  filter: brightness(0) invert(1) !important;
}

.news-article .news-share-row a span {
  color: var(--cream) !important;
  font-size: 16px !important;
  line-height: 1 !important;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    padding-top: 62px !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding-top: 34px !important;
  }

  .news-article .news-label-row {
    gap: 14px !important;
  }
}
/* ================================================= */
/* NEWS ARTICLE - AJUSTE DE COLUNAS DO CONTEÚDO */
/* aumenta área de texto e aproxima sidebar */
/* ================================================= */

.news-article .news-content-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 980px) minmax(300px, 360px) !important;
  gap: 34px !important;
  align-items: start !important;
  justify-content: center !important;

  width: 100% !important;
  max-width: 1480px !important;

  margin: 0 auto 42px !important;
  padding: 0 32px !important;
}

/* Coluna principal da matéria */

.news-article .news-article-body {
  width: 100% !important;
  max-width: none !important;
}

/* Faz texto, títulos e quote ocuparem melhor a coluna */

.news-article .news-article-body > p,
.news-article .news-article-body h2,
.news-article .news-quote {
  max-width: none !important;
  width: 100% !important;
}

/* Texto um pouco mais confortável na largura nova */

.news-article .news-article-body > p {
  font-size: 20px !important;
  line-height: 1.68 !important;
}

/* Quote acompanha a largura da coluna */

.news-article .news-quote {
  margin: 34px 0 !important;
}

/* Sidebar fica firme, sem fugir demais para a direita */

.news-article .news-sidebar {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: stretch !important;
}

/* Cards da sidebar mais estáveis */

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  width: 100% !important;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .news-article .news-content-layout {
    grid-template-columns: 1fr !important;
    max-width: 980px !important;
    gap: 28px !important;

    padding: 0 32px !important;
  }

  .news-article .news-sidebar {
    max-width: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-content-layout {
    padding: 0 20px !important;
    margin-bottom: 34px !important;
  }

  .news-article .news-article-body > p {
    font-size: 18px !important;
    line-height: 1.62 !important;
  }

  .news-article .news-sidebar {
    grid-template-columns: 1fr !important;
  }
}
/* ================================================= */
/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .news-article */
/* ================================================= */

.news-article .news-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.86fr) minmax(520px, 1.14fr);
  gap: 42px;
  align-items: center;

  min-height: 560px;
  padding: 46px 56px 42px;
}

.news-article .news-hero-copy {
  position: relative;
  z-index: 3;
}

.news-article .news-hero .breadcrumb {
  margin-bottom: 28px;
}

.news-article .news-label {
  margin-bottom: 18px;
}

.news-article .news-hero h1 {
  max-width: 660px;
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(44px, 4vw, 76px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.news-article .news-subtitle {
  max-width: 560px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 24px;
  line-height: 1.25;
  font-style: italic;
}

.news-article .news-byline {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(130px, 0.72fr) minmax(130px, 0.72fr) minmax(90px, 0.46fr);
  align-items: center;
  gap: 16px;

  max-width: 720px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.26);
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

.news-article .news-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.news-article .news-author-mini img {
  width: 58px;
  height: 58px;

  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.news-article .news-author-mini span,
.news-article .news-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.news-article .news-author-mini small,
.news-article .news-meta-item small {
  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.news-article .news-author-mini strong,
.news-article .news-meta-item time,
.news-article .news-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

.news-article .news-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 14px;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 34px;
  height: 34px;

  display: grid;
  place-items: center;

  color: var(--ink);
  text-decoration: none;

  border-radius: 50%;
  background: rgba(255, 246, 222, 0.10);

  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: rgba(86, 32, 129, 0.12);
}

.news-article .news-share-row img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.news-article .news-hero-image {
  position: relative;

  margin: 0;
  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  box-shadow:
    0 18px 34px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-hero-image::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.news-article .news-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.24);
}

/* Conteúdo + sidebar */

.news-article .news-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;

  margin: 0 56px 38px;
}

.news-article .news-article-body {
  position: relative;

  padding: 0;

  color: rgba(43, 26, 16, 0.92);
}

.news-article .news-article-body > p {
  max-width: 860px;
  margin: 0 0 20px;

  font-size: 20px;
  line-height: 1.66;
}

.news-article .news-article-body h2 {
  max-width: 860px;
  margin: 34px 0 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  float: left;

  margin: 7px 12px 0 0;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 78px;
  line-height: 0.78;
  font-weight: 900;
}

.news-article .news-quote {
  position: relative;

  max-width: 860px;
  margin: 34px 0;
  padding: 30px 92px 30px 60px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-quote::before {
  content: "“";

  position: absolute;
  left: 28px;
  top: 20px;

  color: var(--purple);
  font-size: 44px;
  line-height: 1;
  opacity: 0.72;
}

.news-article .news-quote::after {
  content: "";

  position: absolute;
  right: 30px;
  bottom: 24px;

  width: 64px;
  height: 64px;

  background-image: url("assets/icons/veredito-gema.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  opacity: 0.72;
}

.news-article .news-quote p {
  margin: 0 0 14px;

  color: var(--purple);
  font-size: 24px;
  line-height: 1.36;
  font-style: italic;
  font-weight: 700;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.72);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

/* Sidebar */

.news-article .news-sidebar {
  display: grid;
  gap: 22px;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  position: relative;

  padding: 26px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 0 18px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.news-article .news-summary-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 16px;

  margin: 0;
  padding: 0;

  list-style: none;
}

.news-article .news-summary-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
}

.news-article .news-summary-list img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  opacity: 0.84;
}

.news-article .news-summary-list span {
  color: rgba(43, 26, 16, 0.82);
  font-size: 15.5px;
  line-height: 1.38;
}

.news-article .news-tags {
  position: relative;
  z-index: 2;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.news-article .news-tags a {
  padding: 7px 10px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.36);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.news-article .news-tags a:hover {
  transform: translateY(-2px);
  background: var(--purple);
  color: var(--cream);
}

.news-article .news-discord-box {
  text-align: center;
}

.news-article .news-discord-art {
  position: relative;
  z-index: 2;

  margin: -8px auto 12px;
}

.news-article .news-discord-art img {
  max-width: 190px;
  max-height: 150px;

  margin: 0 auto;
  object-fit: contain;
}

.news-article .news-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.news-article .news-discord-box .lg-btn {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Mais notícias */

.news-article .more-news-section {
  position: relative;

  margin: 0 56px 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .more-news-section::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .more-news-section .section-title-row,
.news-article .more-news-grid {
  position: relative;
  z-index: 2;
}

.news-article .more-news-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.news-article .news-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 320px;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.13);
}

.news-article .news-card .post-category {
  top: 12px;
  left: 12px;
}

.news-article .news-card-image {
  min-height: 170px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.38), rgba(20, 10, 5, 0.04)),
    var(--news-bg);
  background-size: cover;
  background-position: center;
}

.news-article .news-card-copy {
  padding: 18px;

  display: flex;
  flex: 1;
  flex-direction: column;
}

.news-article .news-card-copy time {
  margin-bottom: 10px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-card-copy h3 {
  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.12;
  text-transform: uppercase;
}

.news-article .news-card-copy small {
  margin-top: auto;

  color: rgba(43, 26, 16, 0.62);
  font-size: 13px;
}

/* Newsletter */

.news-article .newsletter-panel {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .newsletter-art img {
  max-width: 190px;
  max-height: 150px;

  object-fit: contain;
}

.news-article .newsletter-copy h2 {
  margin: 0 0 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .newsletter-copy p {
  max-width: 520px;
  margin: 0;

  color: rgba(43, 26, 16, 0.80);
  font-size: 16px;
  line-height: 1.4;
}

.news-article .newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.news-article .newsletter-form input {
  min-height: 52px;
  min-width: 0;

  padding: 0 16px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.20);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15px;
  outline: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    grid-template-columns: 1fr;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr;
  }

  .news-article .news-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .news-article .newsletter-form {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .news-article .news-byline {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding: 34px 24px 40px;
  }

  .news-article .news-hero h1 {
    font-size: 42px;
  }

  .news-article .news-content-layout,
  .news-article .more-news-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 48px;
  }

  .news-article .news-quote::after {
    display: none;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr;
  }

  .news-article .newsletter-panel {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr;
  }

  .news-article .news-byline {
    grid-template-columns: 1fr;
  }
}

/* ================================================= */
/* NEWS HERO - TAG + BREADCRUMB NA MESMA LINHA */
/* ================================================= */

.news-article .news-hero {
  padding-top: 92px !important;
  padding-bottom: 52px !important;
  align-items: start !important;
}

.news-article .news-label-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;

  margin: 0 0 20px !important;
}

.news-article .news-label-row .news-label {
  margin: 0 !important;
  flex: 0 0 auto !important;
}

.news-article .news-breadcrumb-inline {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;

  margin: 0 !important;
  transform: translateY(1px);

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none !important;
}

.news-article .news-hero h1 {
  margin-top: 0 !important;
}

/* ================================================= */
/* NEWS HERO - SHARE COM CÍRCULOS ROXOS */
/* ================================================= */

.news-article .news-share-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;

  margin-top: 20px !important;
}

.news-article .news-share-row strong {
  margin-right: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 36px !important;
  height: 36px !important;

  display: grid !important;
  place-items: center !important;

  color: var(--cream) !important;
  background: var(--purple) !important;
  border: 1px solid rgba(255, 243, 214, 0.18) !important;
  border-radius: 50% !important;

  text-decoration: none !important;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark) !important;

  box-shadow:
    0 12px 20px rgba(43, 26, 16, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.20);
}

.news-article .news-share-row img {
  width: 17px !important;
  height: 17px !important;

  object-fit: contain !important;
  display: block !important;

  filter: brightness(0) invert(1) !important;
}

.news-article .news-share-row a span {
  color: var(--cream) !important;
  font-size: 16px !important;
  line-height: 1 !important;
}

/* ================================================= */
/* NEWS ARTICLE - AJUSTE DE COLUNAS DO CONTEÚDO */
/* aumenta área de texto e aproxima sidebar */
/* ================================================= */

.news-article .news-content-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 980px) minmax(300px, 360px) !important;
  gap: 34px !important;
  align-items: start !important;
  justify-content: center !important;

  width: 100% !important;
  max-width: 1480px !important;

  margin: 0 auto 42px !important;
  padding: 0 32px !important;
}

.news-article .news-article-body {
  width: 100% !important;
  max-width: none !important;
}

.news-article .news-article-body > p,
.news-article .news-article-body h2,
.news-article .news-quote {
  max-width: none !important;
  width: 100% !important;
}

.news-article .news-article-body > p {
  font-size: 20px !important;
  line-height: 1.68 !important;
}

.news-article .news-quote {
  margin: 34px 0 !important;
}

.news-article .news-sidebar {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: stretch !important;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  width: 100% !important;
}

/* ================================================= */
/* NEWS ARTICLE - REFINO EDITORIAL FINAL */
/* acabamento prático da página-base de notícia */
/* ================================================= */

/* Hero mais editorial */
.news-article .news-hero-image {
  box-shadow:
    0 22px 36px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22) !important;
}

.news-article .news-hero-image img {
  min-height: 360px !important;
}

/* Texto: mais presença sem virar muralha */
.news-article .news-article-body {
  padding-top: 4px !important;
}

.news-article .news-article-body h2 {
  margin: 38px 0 16px !important;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 30px !important;
  line-height: 1.05 !important;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  margin: 8px 14px 0 0 !important;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 70px !important;
  line-height: 0.78 !important;
  font-weight: 900;
}

/* Quote premium */
.news-article .news-quote {
  position: relative !important;

  min-height: 150px !important;
  padding: 34px 104px 32px 66px !important;

  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;

  border: 1px solid var(--line) !important;
  background:
    radial-gradient(circle at 92% 18%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.14) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.24),
    0 10px 22px rgba(43, 26, 16, 0.04) !important;
}

.news-article .news-quote::before {
  content: "“" !important;

  position: absolute !important;
  left: 28px !important;
  top: 28px !important;

  color: var(--purple) !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 48px !important;
  line-height: 1 !important;
  opacity: 0.72 !important;
}

.news-article .news-quote::after {
  content: "" !important;

  position: absolute !important;
  right: 30px !important;
  bottom: 24px !important;

  width: 70px !important;
  height: 70px !important;

  background-image: url("assets/icons/veredito-gema.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;

  opacity: 0.70 !important;
}

.news-article .news-quote p {
  margin: 0 0 16px !important;

  color: var(--purple) !important;
  font-size: 25px !important;
  line-height: 1.36 !important;
  font-style: italic !important;
  font-weight: 700 !important;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.76) !important;
  font-family: var(--font-title, Georgia, "Times New Roman", serif) !important;
  font-size: 12px !important;
  font-style: normal !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
}

/* Sidebar mais premium */
.news-article .news-sidebar {
  gap: 24px !important;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  padding: 28px 26px !important;

  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.05), transparent 34%),
    rgba(255, 246, 222, 0.13) !important;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  inset: 13px !important;
}

.news-article .sidebar-kicker {
  margin-bottom: 18px !important;
  padding: 8px 11px !important;

  color: var(--purple) !important;
  background: rgba(74, 35, 107, 0.10) !important;
  border: 1px solid rgba(74, 35, 107, 0.24) !important;

  font-size: 10.5px !important;
}

.news-article .news-summary-list {
  gap: 18px !important;
}

.news-article .news-summary-list li {
  grid-template-columns: 38px 1fr !important;
  gap: 13px !important;
  align-items: start !important;
}

.news-article .news-summary-list img {
  width: 28px !important;
  height: 28px !important;

  object-fit: contain !important;
  opacity: 0.92 !important;
}

.news-article .news-summary-list span {
  font-size: 16px !important;
  line-height: 1.38 !important;
}

/* Tópicos */
.news-article .news-tags {
  gap: 9px !important;
}

.news-article .news-tags a {
  padding: 8px 10px !important;

  font-size: 10px !important;
  background: rgba(255, 246, 222, 0.16) !important;
}

/* Discord */
.news-article .news-discord-art img {
  max-width: 210px !important;
  max-height: 165px !important;
}

.news-article .news-discord-box h2 {
  font-size: 24px !important;
  line-height: 1.02 !important;
}

.news-article .news-discord-box p {
  font-size: 16px !important;
  line-height: 1.44 !important;
}

.news-article .news-discord-box .lg-btn {
  min-height: 48px !important;
}

/* Mais notícias: vitrine mais forte */
.news-article .more-news-section {
  max-width: 1500px !important;
  margin: 0 auto 34px !important;
  padding: 34px 34px 38px !important;
}

.news-article .more-news-grid {
  gap: 22px !important;
}

.news-article .news-card {
  min-height: 345px !important;
}

.news-article .news-card-image {
  min-height: 190px !important;
}

.news-article .news-card-copy {
  padding: 18px 18px 20px !important;
}

.news-article .news-card-copy h3 {
  font-size: 18.5px !important;
  line-height: 1.10 !important;
}

.news-article .news-card-copy time {
  margin-bottom: 11px !important;
}

.news-article .news-card-copy small {
  font-size: 13px !important;
}

/* Newsletter: mais bloco especial, menos formulário solto */
.news-article .newsletter-panel {
  max-width: 1500px !important;
  margin: 0 auto 34px !important;

  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px) !important;
  padding: 30px 36px !important;

  background:
    radial-gradient(circle at 8% 50%, rgba(86, 32, 129, 0.06), transparent 30%),
    rgba(255, 246, 222, 0.14) !important;
}

.news-article .newsletter-art img {
  max-width: 200px !important;
  max-height: 160px !important;
}

.news-article .newsletter-copy h2 {
  font-size: 25px !important;
  line-height: 1.05 !important;
}

.news-article .newsletter-copy p {
  font-size: 16.5px !important;
}

.news-article .newsletter-form input {
  min-height: 52px !important;
}

.news-article .newsletter-form .lg-btn,
.news-article .newsletter-form button {
  min-height: 52px !important;
  white-space: nowrap !important;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .news-article .news-hero {
    padding-top: 62px !important;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr !important;
    max-width: 980px !important;
    gap: 28px !important;

    padding: 0 32px !important;
  }

  .news-article .news-sidebar {
    max-width: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .news-article .newsletter-form {
    max-width: 640px !important;
    width: 100% !important;
    margin: 0 auto !important;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .news-article .news-sidebar {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding-top: 34px !important;
  }

  .news-article .news-label-row {
    gap: 14px !important;
  }

  .news-article .news-content-layout {
    padding: 0 20px !important;
    margin-bottom: 34px !important;
  }

  .news-article .news-article-body > p {
    font-size: 18px !important;
    line-height: 1.62 !important;
  }

  .news-article .news-article-body .lead-paragraph::first-letter {
    font-size: 58px !important;
    margin-right: 10px !important;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 50px !important;
  }

  .news-article .news-quote::after {
    display: none !important;
  }

  .news-article .news-quote p {
    font-size: 21px !important;
  }

  .news-article .more-news-section,
  .news-article .newsletter-panel {
    margin-left: 20px !important;
    margin-right: 20px !important;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr !important;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr !important;
  }
}
/* ================================================= */
/* CATEGORIA - JOGOS */
/* Cole no final do style.css */
/* Escopo: .category-games */
/* ================================================= */

.category-games .category-hero {
  padding: 54px 56px 28px;
}

.category-games .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .category-breadcrumb a {
  text-decoration: none;
}

.category-games .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-games .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 28px 56px;

  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 42px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-games .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-hero-card::after {
  content: "";
  position: absolute;
  right: 28px;
  top: 22px;

  width: 190px;
  height: 190px;

  background-image: url("../assets/icons/cat_jogos.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;

  opacity: 0.06;
  pointer-events: none;
}

.category-games .category-hero-icon {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;
}

.category-games .category-hero-icon img {
  width: 220px;
  max-height: 170px;
  object-fit: contain;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-games .category-hero-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-hero-copy .review-label {
  margin-bottom: 12px;
}

.category-games .category-hero-copy h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(56px, 5vw, 88px);
  line-height: 0.92;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.04em;
}

.category-games .category-hero-copy p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 22px;
  line-height: 1.30;
}

/* Filtros */

.category-games .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-games .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-games .category-filter:hover,
.category-games .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-games .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-games .category-main {
  min-width: 0;
}

/* Destaque */

.category-games .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 36px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-games .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-games .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .featured-review-content {
  position: relative;
  z-index: 2;

  width: min(100%, 560px);
}

.category-games .featured-review-content .post-category {
  position: static;
  margin-bottom: 18px;
}

.category-games .featured-review-content h2 {
  margin: 0 0 18px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-games .featured-review-content p {
  max-width: 440px;
  margin: 0 0 24px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-games .featured-review-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  flex-wrap: wrap;
}

.category-games .featured-review-bottom a {
  color: #f8e7bd;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .featured-review-bottom a:hover {
  color: var(--cream);
}

.category-games .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-games .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-games .rating-cats-featured {
  gap: 5px;
}

.category-games .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid de cards */

.category-games .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-games .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 390px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-games .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-games .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-games .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-games .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-games .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-games .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-games .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-games .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-games .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-games .category-pagination a,
.category-games .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .category-pagination a.active,
.category-games .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-games .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-games .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-games .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-games .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-games .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-games .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-games .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-games .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-games .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-games .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-games .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-games .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-games .top-rating-box {
  text-align: center;
}

.category-games .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-games .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-games .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-games .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-games .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-games .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-games .explore-box nav a:hover {
  color: var(--purple);
}

.category-games .explore-box nav span {
  font-size: 20px;
}

/* Twitch CTA */

.category-games .twitch-category-box {
  text-align: center;
}

.category-games .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-games .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-games .twitch-category-box h2 {
  color: var(--purple);
}

.category-games .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-games .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-games .category-layout {
    grid-template-columns: 1fr;
  }

  .category-games .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-hero-card {
    grid-template-columns: 220px 1fr;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero {
    padding: 36px 20px 24px;
  }

  .category-games .category-hero-card {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 24px;
    text-align: center;
  }

  .category-games .category-hero-icon img {
    width: 150px;
  }

  .category-games .category-hero-copy h1 {
    font-size: 48px;
  }

  .category-games .category-hero-copy p {
    font-size: 18px;
  }

  .category-games .category-filter-row,
  .category-games .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-games .category-filter {
    flex: 1 1 180px;
  }

  .category-games .featured-review-card {
    min-height: 400px;
    padding: 28px 22px;
  }

  .category-games .category-card-grid,
  .category-games .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-games .category-review-card {
    min-height: 370px;
  }

  .category-games .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* CATEGORIA - JOGOS */
/* Cole no final do style.css */
/* Escopo: .category-games */
/* ================================================= */

.category-games .category-hero {
  padding: 54px 56px 28px;
}

.category-games .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .category-breadcrumb a {
  text-decoration: none;
}

.category-games .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-games .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 28px 56px;

  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 42px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-games .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-hero-card::after {
  content: "";
  position: absolute;
  right: 28px;
  top: 22px;

  width: 190px;
  height: 190px;

  background-image: url("../assets/icons/cat_jogos.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;

  opacity: 0.06;
  pointer-events: none;
}

.category-games .category-hero-icon {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;
}

.category-games .category-hero-icon img {
  width: 220px;
  max-height: 170px;
  object-fit: contain;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-games .category-hero-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-hero-copy .review-label {
  margin-bottom: 12px;
}

.category-games .category-hero-copy h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(56px, 5vw, 88px);
  line-height: 0.92;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.04em;
}

.category-games .category-hero-copy p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 22px;
  line-height: 1.30;
}

/* Filtros */

.category-games .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-games .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-games .category-filter:hover,
.category-games .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-games .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-games .category-main {
  min-width: 0;
}

/* Destaque */

.category-games .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 36px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-games .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-games .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .featured-review-content {
  position: relative;
  z-index: 2;

  width: min(100%, 560px);
}

.category-games .featured-review-content .post-category {
  position: static;
  margin-bottom: 18px;
}

.category-games .featured-review-content h2 {
  margin: 0 0 18px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-games .featured-review-content p {
  max-width: 440px;
  margin: 0 0 24px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-games .featured-review-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  flex-wrap: wrap;
}

.category-games .featured-review-bottom a {
  color: #f8e7bd;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .featured-review-bottom a:hover {
  color: var(--cream);
}

.category-games .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-games .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-games .rating-cats-featured {
  gap: 5px;
}

.category-games .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid de cards */

.category-games .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-games .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 390px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-games .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-games .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-games .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-games .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-games .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-games .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-games .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-games .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-games .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-games .category-pagination a,
.category-games .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .category-pagination a.active,
.category-games .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-games .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-games .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-games .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-games .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-games .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-games .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-games .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-games .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-games .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-games .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-games .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-games .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-games .top-rating-box {
  text-align: center;
}

.category-games .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-games .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-games .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-games .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-games .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-games .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-games .explore-box nav a:hover {
  color: var(--purple);
}

.category-games .explore-box nav span {
  font-size: 20px;
}

/* Twitch CTA */

.category-games .twitch-category-box {
  text-align: center;
}

.category-games .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-games .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-games .twitch-category-box h2 {
  color: var(--purple);
}

.category-games .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-games .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-games .category-layout {
    grid-template-columns: 1fr;
  }

  .category-games .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-hero-card {
    grid-template-columns: 220px 1fr;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero {
    padding: 36px 20px 24px;
  }

  .category-games .category-hero-card {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 24px;
    text-align: center;
  }

  .category-games .category-hero-icon img {
    width: 150px;
  }

  .category-games .category-hero-copy h1 {
    font-size: 48px;
  }

  .category-games .category-hero-copy p {
    font-size: 18px;
  }

  .category-games .category-filter-row,
  .category-games .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-games .category-filter {
    flex: 1 1 180px;
  }

  .category-games .featured-review-card {
    min-height: 400px;
    padding: 28px 22px;
  }

  .category-games .category-card-grid,
  .category-games .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-games .category-review-card {
    min-height: 370px;
  }

  .category-games .category-pagination {
    flex-wrap: wrap;
  }
}

/* ================================================= */
/* CATEGORIA JOGOS - REFINO DO HERO + GRID 3x3 */
/* controle ao lado do título, sem tag e sem imagem fantasma */
/* ================================================= */

.category-games .category-hero {
  padding-top: 58px !important;
  padding-bottom: 24px !important;
}

.category-games .category-hero-card {
  width: min(100%, 1180px) !important;
  min-height: 210px !important;

  display: block !important;
  padding: 34px 54px !important;
}

.category-games .category-hero-card::after {
  display: none !important;
}

.category-games .category-hero-copy {
  width: 100% !important;
}

.category-games .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 42px;

  width: 100%;
}

.category-games .category-title-row .category-hero-icon {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-games .category-title-row .category-hero-icon img {
  width: 230px !important;
  max-height: 170px !important;
  object-fit: contain !important;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92) !important;
}

.category-games .category-title-row h1 {
  margin: 0 0 12px !important;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px) !important;
  line-height: 0.90 !important;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-games .category-title-row p {
  max-width: 660px !important;
  margin: 0 !important;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px !important;
  line-height: 1.30 !important;
}

/* Remove a tag Categoria antiga, caso algum HTML antigo ainda tenha ficado */
.category-games .category-hero-copy > .review-label {
  display: none !important;
}

/* Grid principal com 3 colunas e 3 linhas no desktop */
.category-games .category-card-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

/* Ajuste de altura para comportar 9 cards com boa leitura */
.category-games .category-review-card {
  min-height: 385px !important;
}

/* Responsivo */
@media (max-width: 1100px) {
  .category-games .category-title-row {
    gap: 28px;
  }

  .category-games .category-title-row .category-hero-icon img {
    width: 170px !important;
  }

  .category-games .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px) !important;
  }

  .category-games .category-title-row p {
    font-size: 19px !important;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero-card {
    padding: 30px 24px !important;
  }

  .category-games .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-games .category-title-row .category-hero-icon img {
    width: 150px !important;
  }

  .category-games .category-title-row h1 {
    font-size: 48px !important;
  }

  .category-games .category-title-row p {
    font-size: 18px !important;
  }
}
/* ================================================= */
/* CATEGORIA - JOGOS */
/* Cole no final do style.css */
/* Escopo: .category-games */
/* ================================================= */

.category-games .category-hero {
  padding: 54px 56px 28px;
}

.category-games .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .category-breadcrumb a {
  text-decoration: none;
}

.category-games .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-games .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 28px 56px;

  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 42px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-games .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-hero-card::after {
  content: "";
  position: absolute;
  right: 28px;
  top: 22px;

  width: 190px;
  height: 190px;

  background-image: url("../assets/icons/cat_jogos.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;

  opacity: 0.06;
  pointer-events: none;
}

.category-games .category-hero-icon {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;
}

.category-games .category-hero-icon img {
  width: 220px;
  max-height: 170px;
  object-fit: contain;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-games .category-hero-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-hero-copy .review-label {
  margin-bottom: 12px;
}

.category-games .category-hero-copy h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(56px, 5vw, 88px);
  line-height: 0.92;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.04em;
}

.category-games .category-hero-copy p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 22px;
  line-height: 1.30;
}

/* Filtros */

.category-games .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-games .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-games .category-filter:hover,
.category-games .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-games .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-games .category-main {
  min-width: 0;
}

/* Destaque */

.category-games .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 36px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-games .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-games .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .featured-review-content {
  position: relative;
  z-index: 2;

  width: min(100%, 560px);
}

.category-games .featured-review-content .post-category {
  position: static;
  margin-bottom: 18px;
}

.category-games .featured-review-content h2 {
  margin: 0 0 18px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-games .featured-review-content p {
  max-width: 440px;
  margin: 0 0 24px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-games .featured-review-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  flex-wrap: wrap;
}

.category-games .featured-review-bottom a {
  color: #f8e7bd;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .featured-review-bottom a:hover {
  color: var(--cream);
}

.category-games .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-games .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-games .rating-cats-featured {
  gap: 5px;
}

.category-games .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid de cards */

.category-games .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-games .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 390px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-games .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-games .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-games .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-games .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-games .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-games .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-games .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-games .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-games .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-games .category-pagination a,
.category-games .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .category-pagination a.active,
.category-games .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-games .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-games .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-games .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-games .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-games .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-games .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-games .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-games .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-games .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-games .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-games .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-games .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-games .top-rating-box {
  text-align: center;
}

.category-games .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-games .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-games .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-games .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-games .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-games .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-games .explore-box nav a:hover {
  color: var(--purple);
}

.category-games .explore-box nav span {
  font-size: 20px;
}

/* Twitch CTA */

.category-games .twitch-category-box {
  text-align: center;
}

.category-games .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-games .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-games .twitch-category-box h2 {
  color: var(--purple);
}

.category-games .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-games .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-games .category-layout {
    grid-template-columns: 1fr;
  }

  .category-games .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-hero-card {
    grid-template-columns: 220px 1fr;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero {
    padding: 36px 20px 24px;
  }

  .category-games .category-hero-card {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 24px;
    text-align: center;
  }

  .category-games .category-hero-icon img {
    width: 150px;
  }

  .category-games .category-hero-copy h1 {
    font-size: 48px;
  }

  .category-games .category-hero-copy p {
    font-size: 18px;
  }

  .category-games .category-filter-row,
  .category-games .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-games .category-filter {
    flex: 1 1 180px;
  }

  .category-games .featured-review-card {
    min-height: 400px;
    padding: 28px 22px;
  }

  .category-games .category-card-grid,
  .category-games .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-games .category-review-card {
    min-height: 370px;
  }

  .category-games .category-pagination {
    flex-wrap: wrap;
  }
}

/* ================================================= */
/* CATEGORIA JOGOS - REFINO DO HERO + GRID 3x3 */
/* controle ao lado do título, sem tag e sem imagem fantasma */
/* ================================================= */

.category-games .category-hero {
  padding-top: 58px !important;
  padding-bottom: 24px !important;
}

.category-games .category-hero-card {
  width: min(100%, 1180px) !important;
  min-height: 210px !important;

  display: block !important;
  padding: 34px 54px !important;
}

.category-games .category-hero-card::after {
  display: none !important;
}

.category-games .category-hero-copy {
  width: 100% !important;
}

.category-games .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 42px;

  width: 100%;
}

.category-games .category-title-row .category-hero-icon {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-games .category-title-row .category-hero-icon img {
  width: 230px !important;
  max-height: 170px !important;
  object-fit: contain !important;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92) !important;
}

.category-games .category-title-row h1 {
  margin: 0 0 12px !important;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px) !important;
  line-height: 0.90 !important;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-games .category-title-row p {
  max-width: 660px !important;
  margin: 0 !important;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px !important;
  line-height: 1.30 !important;
}

/* Remove a tag Categoria antiga, caso algum HTML antigo ainda tenha ficado */
.category-games .category-hero-copy > .review-label {
  display: none !important;
}

/* Grid principal com 3 colunas e 3 linhas no desktop */
.category-games .category-card-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

/* Ajuste de altura para comportar 9 cards com boa leitura */
.category-games .category-review-card {
  min-height: 385px !important;
}

/* Responsivo */
@media (max-width: 1100px) {
  .category-games .category-title-row {
    gap: 28px;
  }

  .category-games .category-title-row .category-hero-icon img {
    width: 170px !important;
  }

  .category-games .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px) !important;
  }

  .category-games .category-title-row p {
    font-size: 19px !important;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero-card {
    padding: 30px 24px !important;
  }

  .category-games .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-games .category-title-row .category-hero-icon img {
    width: 150px !important;
  }

  .category-games .category-title-row h1 {
    font-size: 48px !important;
  }

  .category-games .category-title-row p {
    font-size: 18px !important;
  }
}


/* ================================================= */
/* HERO JOGOS - IMAGEM ESTILO MOCKUP */
/* usa uma arte própria no lugar do ícone simples */
/* Salve a imagem em: assets/categories/jogos-hero.png */
/* ================================================= */

.category-games .category-title-row {
  justify-content: flex-start !important;
  gap: 34px !important;
}

.category-games .category-title-row .category-hero-icon {
  width: 290px !important;
  min-width: 290px !important;
}

.category-games .category-title-row .category-hero-icon img {
  width: 100% !important;
  max-width: 290px !important;
  max-height: 190px !important;
  height: auto !important;
  object-fit: contain !important;
  opacity: 0.98 !important;
}

.category-games .category-hero-card {
  padding: 34px 46px !important;
}

.category-games .category-title-row h1 {
  margin-bottom: 10px !important;
}

.category-games .category-title-row p {
  max-width: 620px !important;
}

@media (max-width: 1100px) {
  .category-games .category-title-row .category-hero-icon {
    width: 220px !important;
    min-width: 220px !important;
  }

  .category-games .category-title-row .category-hero-icon img {
    max-width: 220px !important;
    max-height: 150px !important;
  }
}

@media (max-width: 900px) {
  .category-games .category-title-row .category-hero-icon {
    width: 170px !important;
    min-width: 170px !important;
  }

  .category-games .category-title-row .category-hero-icon img {
    max-width: 170px !important;
    max-height: 120px !important;
  }
}
/* ==========================================
   CARD DE DESTAQUE - AJUSTE FINO
========================================== */

.games-featured-card {
  position: relative;
  min-height: 430px;
  border: 1px solid #6b4a22;
  background:
    linear-gradient(90deg, rgba(18, 8, 3, 0.92) 0%, rgba(18, 8, 3, 0.78) 34%, rgba(18, 8, 3, 0.28) 72%, rgba(18, 8, 3, 0.10) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.games-featured-card::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(216, 183, 116, 0.35);
  pointer-events: none;
}

.featured-badge {
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  background: #c79a52;
  color: #24150f;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.games-featured-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 430px;
  max-width: 520px;
  padding: 92px 34px 30px 34px;
  color: #f7e6bf;
}

.games-featured-content h2 {
  margin: 0;
  color: #f8e7bd;
  font-size: clamp(44px, 4vw, 68px);
  line-height: 0.94;
  text-transform: uppercase;
}

.featured-category-tag {
  display: inline-flex;
  width: fit-content;
  margin-top: 18px;
  padding: 7px 12px;
  background: #6d28a8;
  color: #fff3d6;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
}

.games-featured-content p {
  margin: 22px 0 0;
  max-width: 420px;
  color: #f6dfae;
  font-size: 18px;
  line-height: 1.45;
}

.games-featured-footer {
  margin-top: 28px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  width: 100%;
}

.featured-rating-row {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.featured-cats {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 0;
}

.featured-cats img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.featured-rating-row strong {
  color: #f8e7bd;
  font-size: 24px;
  line-height: 1;
}

.featured-review-link {
  margin-left: auto;
  align-self: flex-end;
  color: #f8e7bd;
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
}

.featured-review-link:hover {
  opacity: 0.85;
}

/* Responsivo */
@media (max-width: 900px) {
  .games-featured-card {
    min-height: 380px;
  }

  .games-featured-content {
    max-width: 100%;
    min-height: 380px;
    padding: 86px 24px 24px;
  }

  .games-featured-content h2 {
    font-size: 42px;
  }

  .games-featured-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .featured-review-link {
    margin-left: 0;
  }
}
/* ================================================= */
/* CATEGORIA JOGOS - AJUSTE FINO DO CARD DESTAQUE */
/* desce título e joga "Ver review" para a direita */
/* ================================================= */

.category-games .featured-review-card {
  align-items: flex-end !important;
  padding: 42px 44px 38px !important;
}

.category-games .featured-review-content {
  width: 100% !important;
  max-width: none !important;
  padding-top: 34px !important;
}

/* Desce o título sem estourar a composição */
.category-games .featured-review-content h2 {
  max-width: 690px !important;
  margin-top: 22px !important;
  margin-bottom: 20px !important;
}

/* Tag fica abaixo do título */
.category-games .featured-review-content .featured-category-tag {
  position: static !important;
  display: inline-flex !important;
  width: fit-content !important;
  margin: 0 0 20px !important;
}

/* Texto continua elegante e controlado */
.category-games .featured-review-content p {
  max-width: 560px !important;
  margin-bottom: 0 !important;
}

/* Rodapé ocupa toda a largura do card */
.category-games .featured-review-bottom {
  width: 100% !important;
  max-width: none !important;

  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 28px !important;

  margin-top: 30px !important;
}

/* Nota fica à esquerda */
.category-games .featured-review-bottom .category-rating {
  flex: 0 0 auto !important;
}

/* Link vai para o canto direito */
.category-games .featured-review-link,
.category-games .featured-review-bottom > a {
  margin-left: auto !important;
  margin-right: 8px !important;

  align-self: center !important;
  justify-self: flex-end !important;

  color: #f8e7bd !important;
  font-family: var(--font-title, Georgia, "Times New Roman", serif) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-align: right !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.category-games .featured-review-link:hover,
.category-games .featured-review-bottom > a:hover {
  color: var(--cream) !important;
  transform: translateX(3px);
}

/* Responsivo */
@media (max-width: 900px) {
  .category-games .featured-review-card {
    padding: 34px 24px 28px !important;
  }

  .category-games .featured-review-content {
    padding-top: 46px !important;
  }

  .category-games .featured-review-bottom {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  .category-games .featured-review-link,
  .category-games .featured-review-bottom > a {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}
/* ================================================= */
/* CATEGORIA JOGOS - CORREÇÃO SIDEBAR DESTAQUES */
/* evita colisão com .mini-review-card global */
/* ================================================= */

.category-games .sidebar-review-item {
  position: relative !important;
  isolation: auto !important;

  display: grid !important;
  grid-template-columns: 94px 1fr !important;
  gap: 14px !important;
  align-items: start !important;

  width: 100% !important;
  min-height: auto !important;
  aspect-ratio: auto !important;

  padding: 0 0 16px !important;
  margin-bottom: 16px !important;

  color: var(--ink) !important;
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24) !important;
  border-radius: 0 !important;

  text-shadow: none !important;
  text-decoration: none !important;
  text-transform: none !important;
  overflow: visible !important;
}

.category-games .sidebar-review-item::before,
.category-games .sidebar-review-item::after {
  display: none !important;
}

.category-games .sidebar-review-item img {
  width: 94px !important;
  height: 94px !important;

  object-fit: cover !important;
  border: 1px solid rgba(164, 112, 52, 0.38) !important;
}

.category-games .sidebar-review-item strong {
  display: block !important;
  margin-bottom: 7px !important;

  color: var(--ink) !important;
  font-family: var(--font-title, Georgia, "Times New Roman", serif) !important;
  font-size: 15px !important;
  line-height: 1.12 !important;
  text-transform: uppercase !important;
}

.category-games .sidebar-review-item em {
  display: inline-flex !important;
  width: fit-content !important;
  margin-bottom: 7px !important;
  padding: 5px 7px !important;

  color: var(--cream) !important;
  background: var(--purple) !important;

  font-size: 10px !important;
  font-style: normal !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.category-games .sidebar-review-item small {
  display: block !important;

  color: rgba(43, 26, 16, 0.78) !important;
  font-size: 13px !important;
  line-height: 1.28 !important;
}
/* ================================================= */
/* CATEGORIA - FILMES WP READY */
/* Base visual herdada da categoria Jogos */
/* ================================================= */

.category-films .category-hero {
  padding: 58px 56px 24px;
}

.category-films .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-films .category-breadcrumb a {
  text-decoration: none;
}

.category-films .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-films .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-films .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-films .category-hero-card::after {
  display: none;
}

.category-films .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-films .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-films .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;

  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-films .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;

  object-fit: contain;
  opacity: 0.98;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-films .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-films .category-title-row p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-films .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-films .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-films .category-filter:hover,
.category-films .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-films .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-films .category-main {
  min-width: 0;
}

/* Destaque */

.category-films .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-films .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-films .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-films .featured-review-content {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-films .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-films .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-films .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-films .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-films .featured-review-link,
.category-films .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-films .featured-review-link:hover,
.category-films .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-films .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-films .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-films .rating-cats-featured {
  gap: 5px;
}

.category-films .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-films .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-films .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-films .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-films .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-films .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-films .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-films .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-films .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-films .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-films .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-films .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-films .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-films .category-pagination a,
.category-films .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-films .category-pagination a.active,
.category-films .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-films .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-films .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-films .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-films .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-films .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-films .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-films .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-films .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-films .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-films .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-films .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-films .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-films .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-films .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-films .top-rating-box {
  text-align: center;
}

.category-films .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-films .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-films .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-films .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-films .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-films .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-films .explore-box nav a:hover {
  color: var(--purple);
}

.category-films .explore-box nav span {
  font-size: 20px;
}

/* CTA */

.category-films .twitch-category-box {
  text-align: center;
}

.category-films .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-films .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-films .twitch-category-box h2 {
  color: var(--purple);
}

.category-films .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-films .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-films .category-layout {
    grid-template-columns: 1fr;
  }

  .category-films .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-films .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-films .category-title-row {
    gap: 28px;
  }

  .category-films .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-films .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-films .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px);
  }

  .category-films .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-films .category-hero {
    padding: 36px 20px 24px;
  }

  .category-films .category-hero-card {
    padding: 30px 24px;
  }

  .category-films .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-films .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-films .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-films .category-title-row h1 {
    font-size: 48px;
  }

  .category-films .category-title-row p {
    font-size: 18px;
  }

  .category-films .category-filter-row,
  .category-films .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-films .category-filter {
    flex: 1 1 180px;
  }

  .category-films .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-films .featured-review-content {
    padding-top: 46px;
  }

  .category-films .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-films .featured-review-link,
  .category-films .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-films .category-card-grid,
  .category-films .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-films .category-review-card {
    min-height: 370px;
  }

  .category-films .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* CATEGORIA - SÉRIES WP READY */
/* Base visual herdada da categoria Jogos/Filmes */
/* ================================================= */

.category-series .category-hero {
  padding: 58px 56px 24px;
}

.category-series .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-series .category-breadcrumb a {
  text-decoration: none;
}

.category-series .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-series .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-series .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-series .category-hero-card::after {
  display: none;
}

.category-series .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-series .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-series .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;

  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-series .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;

  object-fit: contain;
  opacity: 0.98;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-series .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-series .category-title-row p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-series .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-series .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-series .category-filter:hover,
.category-series .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-series .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-series .category-main {
  min-width: 0;
}

/* Destaque */

.category-series .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-series .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-series .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-series .featured-review-content {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-series .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-series .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-series .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-series .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-series .featured-review-link,
.category-series .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-series .featured-review-link:hover,
.category-series .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-series .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-series .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-series .rating-cats-featured {
  gap: 5px;
}

.category-series .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-series .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-series .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-series .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-series .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-series .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-series .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-series .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-series .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-series .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-series .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-series .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-series .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-series .category-pagination a,
.category-series .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-series .category-pagination a.active,
.category-series .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-series .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-series .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-series .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-series .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-series .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-series .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-series .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-series .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-series .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-series .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-series .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-series .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-series .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-series .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-series .top-rating-box {
  text-align: center;
}

.category-series .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-series .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-series .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-series .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-series .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-series .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-series .explore-box nav a:hover {
  color: var(--purple);
}

.category-series .explore-box nav span {
  font-size: 20px;
}

/* CTA */

.category-series .twitch-category-box {
  text-align: center;
}

.category-series .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-series .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-series .twitch-category-box h2 {
  color: var(--purple);
}

.category-series .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-series .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-series .category-layout {
    grid-template-columns: 1fr;
  }

  .category-series .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-series .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-series .category-title-row {
    gap: 28px;
  }

  .category-series .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-series .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-series .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px);
  }

  .category-series .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-series .category-hero {
    padding: 36px 20px 24px;
  }

  .category-series .category-hero-card {
    padding: 30px 24px;
  }

  .category-series .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-series .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-series .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-series .category-title-row h1 {
    font-size: 48px;
  }

  .category-series .category-title-row p {
    font-size: 18px;
  }

  .category-series .category-filter-row,
  .category-series .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-series .category-filter {
    flex: 1 1 180px;
  }

  .category-series .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-series .featured-review-content {
    padding-top: 46px;
  }

  .category-series .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-series .featured-review-link,
  .category-series .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-series .category-card-grid,
  .category-series .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-series .category-review-card {
    min-height: 370px;
  }

  .category-series .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* CATEGORIA - ANIMES WP READY */
/* Base visual herdada de Jogos / Filmes & Séries */
/* Cole no final do style.css */
/* ================================================= */

.category-animes .category-hero {
  padding: 58px 56px 24px;
}

.category-animes .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-animes .category-breadcrumb a {
  text-decoration: none;
}

.category-animes .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-animes .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-animes .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-animes .category-hero-card::after {
  display: none;
}

.category-animes .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-animes .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-animes .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-animes .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;
  object-fit: contain;
  opacity: 0.98;
  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-animes .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-animes .category-title-row p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-animes .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-animes .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-animes .category-filter:hover,
.category-animes .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-animes .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-animes .category-main {
  min-width: 0;
}

/* Destaque */

.category-animes .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-animes .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-animes .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-animes .featured-review-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-animes .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-animes .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-animes .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-animes .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-animes .featured-review-link,
.category-animes .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-animes .featured-review-link:hover,
.category-animes .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-animes .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-animes .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-animes .rating-cats-featured {
  gap: 5px;
}

.category-animes .rating-cats-featured img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-animes .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-animes .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-animes .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-animes .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-animes .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-animes .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-animes .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-animes .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-animes .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-animes .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-animes .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-animes .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 26px auto 0;
}

.category-animes .category-pagination a,
.category-animes .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-animes .category-pagination a.active,
.category-animes .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-animes .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-animes .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-animes .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-animes .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-animes .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-animes .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-animes .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-animes .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-animes .sidebar-highlight img {
  width: 94px;
  height: 94px;
  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-animes .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-animes .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-animes .sidebar-highlight small {
  display: block;
  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-animes .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-animes .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-animes .top-rating-box {
  text-align: center;
}

.category-animes .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-animes .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-animes .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-animes .top-rating-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-animes .explore-box nav {
  display: grid;
  gap: 0;
  margin-bottom: 18px;
}

.category-animes .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-animes .explore-box nav a:hover {
  color: var(--purple);
}

.category-animes .explore-box nav span {
  font-size: 20px;
}

/* CTA com badge do YouTube */

.category-animes .twitch-category-box {
  text-align: center;
}

.category-animes .youtube-badge {
  width: 64px;
  height: 44px;
  margin: 0 auto 18px;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 12px;
  background: #d92d27;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.category-animes .youtube-badge img {
  width: 26px;
  height: 26px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-animes .twitch-category-box h2 {
  color: var(--purple);
}

.category-animes .twitch-category-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-animes .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-animes .category-layout {
    grid-template-columns: 1fr;
  }

  .category-animes .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-animes .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-animes .category-title-row {
    gap: 28px;
  }

  .category-animes .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-animes .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-animes .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px);
  }

  .category-animes .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-animes .category-hero {
    padding: 36px 20px 24px;
  }

  .category-animes .category-hero-card {
    padding: 30px 24px;
  }

  .category-animes .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-animes .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-animes .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-animes .category-title-row h1 {
    font-size: 48px;
  }

  .category-animes .category-title-row p {
    font-size: 18px;
  }

  .category-animes .category-filter-row,
  .category-animes .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-animes .category-filter {
    flex: 1 1 180px;
  }

  .category-animes .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-animes .featured-review-content {
    padding-top: 46px;
  }

  .category-animes .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-animes .featured-review-link,
  .category-animes .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-animes .category-card-grid,
  .category-animes .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-animes .category-review-card {
    min-height: 370px;
  }

  .category-animes .category-pagination {
    flex-wrap: wrap;
  }
}
/* ============================= */
/* CTA LATERAL - TWITCH */
/* ============================= */

.category-cta-card,
.cta-card-twitch {
  position: relative;
  padding: 28px 22px 22px;
  text-align: center;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.category-cta-card::before,
.cta-card-twitch::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-cta-icon {
  width: 74px;
  height: 74px;
  margin: 0 auto 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--purple);
  box-shadow: 0 10px 18px rgba(86, 32, 129, 0.18);
  position: relative;
  z-index: 2;
}

.category-cta-icon img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  display: block;
  filter: brightness(0) invert(1);
}

.category-cta-card h3,
.cta-card-twitch h3 {
  position: relative;
  z-index: 2;
  margin: 0 0 16px;
  color: var(--purple);
  font-size: 20px;
  line-height: 1.05;
  text-transform: uppercase;
}

.category-cta-card p,
.cta-card-twitch p {
  position: relative;
  z-index: 2;
  margin: 0 0 22px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.5;
}

.category-cta-button {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 54px;
  padding: 0 18px;
  border: 1px solid var(--purple);
  background: var(--purple);
  color: var(--cream);
  font: 700 14px Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  text-decoration: none;
  transition: 0.2s ease;
}

.category-cta-button:hover {
  background: var(--purple-dark);
  border-color: var(--purple-dark);
  transform: translateY(-2px);
}
/* ================================================= */
/* CATEGORIA - LIVROS & HQS WP READY */
/* Base visual herdada de Jogos / Filmes & Séries */
/* Cole no final do style.css */
/* ================================================= */

.category-books .category-hero {
  padding: 58px 56px 24px;
}

.category-books .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-books .category-breadcrumb a {
  text-decoration: none;
}

.category-books .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-books .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-books .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-books .category-hero-card::after {
  display: none;
}

.category-books .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-books .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-books .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-books .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;
  object-fit: contain;
  opacity: 0.98;
  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-books .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(54px, 4.5vw, 82px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-books .category-title-row p {
  max-width: 650px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-books .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-books .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-books .category-filter:hover,
.category-books .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-books .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-books .category-main {
  min-width: 0;
}

/* Destaque */

.category-books .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-books .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-books .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-books .featured-review-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-books .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-books .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-books .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-books .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-books .featured-review-link,
.category-books .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-books .featured-review-link:hover,
.category-books .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-books .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-books .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-books .rating-cats-featured {
  gap: 5px;
}

.category-books .rating-cats-featured img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-books .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-books .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-books .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-books .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-books .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-books .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-books .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-books .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-books .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-books .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-books .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-books .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 26px auto 0;
}

.category-books .category-pagination a,
.category-books .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-books .category-pagination a.active,
.category-books .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-books .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-books .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-books .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-books .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-books .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-books .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-books .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-books .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-books .sidebar-highlight img {
  width: 94px;
  height: 94px;
  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-books .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-books .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-books .sidebar-highlight small {
  display: block;
  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-books .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-books .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-books .top-rating-box {
  text-align: center;
}

.category-books .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-books .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-books .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-books .top-rating-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-books .explore-box nav {
  display: grid;
  gap: 0;
  margin-bottom: 18px;
}

.category-books .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-books .explore-box nav a:hover {
  color: var(--purple);
}

.category-books .explore-box nav span {
  font-size: 20px;
}

/* CTA Clube do livro */

.category-books .twitch-category-box {
  text-align: center;
}

.category-books .book-club-badge {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;
  background: var(--purple);

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.category-books .book-club-badge img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-books .twitch-category-box h2 {
  color: var(--purple);
}

.category-books .twitch-category-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-books .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-books .category-layout {
    grid-template-columns: 1fr;
  }

  .category-books .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-books .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-books .category-title-row {
    gap: 28px;
  }

  .category-books .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-books .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-books .category-title-row h1 {
    font-size: clamp(42px, 6.8vw, 66px);
  }

  .category-books .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-books .category-hero {
    padding: 36px 20px 24px;
  }

  .category-books .category-hero-card {
    padding: 30px 24px;
  }

  .category-books .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-books .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-books .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-books .category-title-row h1 {
    font-size: 42px;
  }

  .category-books .category-title-row p {
    font-size: 18px;
  }

  .category-books .category-filter-row,
  .category-books .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-books .category-filter {
    flex: 1 1 180px;
  }

  .category-books .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-books .featured-review-content {
    padding-top: 46px;
  }

  .category-books .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-books .featured-review-link,
  .category-books .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-books .category-card-grid,
  .category-books .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-books .category-review-card {
    min-height: 370px;
  }

  .category-books .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* CATEGORIA - RETROGAMING WP READY */
/* Base visual herdada de Jogos / categorias anteriores */
/* Cole no final do style.css */
/* ================================================= */

.category-retrogaming .category-hero {
  padding: 58px 56px 24px;
}

.category-retrogaming .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-retrogaming .category-breadcrumb a {
  text-decoration: none;
}

.category-retrogaming .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-retrogaming .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-retrogaming .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-retrogaming .category-hero-card::after {
  display: none;
}

.category-retrogaming .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-retrogaming .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-retrogaming .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-retrogaming .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;
  object-fit: contain;
  opacity: 0.98;
  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-retrogaming .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(54px, 4.5vw, 82px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-retrogaming .category-title-row p {
  max-width: 660px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-retrogaming .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-retrogaming .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-retrogaming .category-filter:hover,
.category-retrogaming .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-retrogaming .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-retrogaming .category-main {
  min-width: 0;
}

/* Destaque */

.category-retrogaming .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-retrogaming .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-retrogaming .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-retrogaming .featured-review-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-retrogaming .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-retrogaming .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-retrogaming .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-retrogaming .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-retrogaming .featured-review-link,
.category-retrogaming .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-retrogaming .featured-review-link:hover,
.category-retrogaming .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-retrogaming .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-retrogaming .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-retrogaming .rating-cats-featured {
  gap: 5px;
}

.category-retrogaming .rating-cats-featured img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-retrogaming .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-retrogaming .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-retrogaming .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-retrogaming .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-retrogaming .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-retrogaming .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-retrogaming .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-retrogaming .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-retrogaming .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-retrogaming .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-retrogaming .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-retrogaming .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 26px auto 0;
}

.category-retrogaming .category-pagination a,
.category-retrogaming .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-retrogaming .category-pagination a.active,
.category-retrogaming .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-retrogaming .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-retrogaming .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-retrogaming .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-retrogaming .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-retrogaming .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-retrogaming .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-retrogaming .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-retrogaming .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-retrogaming .sidebar-highlight img {
  width: 94px;
  height: 94px;
  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-retrogaming .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-retrogaming .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-retrogaming .sidebar-highlight small {
  display: block;
  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-retrogaming .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-retrogaming .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-retrogaming .top-rating-box {
  text-align: center;
}

.category-retrogaming .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-retrogaming .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-retrogaming .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-retrogaming .top-rating-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-retrogaming .explore-box nav {
  display: grid;
  gap: 0;
  margin-bottom: 18px;
}

.category-retrogaming .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-retrogaming .explore-box nav a:hover {
  color: var(--purple);
}

.category-retrogaming .explore-box nav span {
  font-size: 20px;
}

/* CTA Twitch */

.category-retrogaming .twitch-category-box {
  text-align: center;
}

.category-retrogaming .retro-live-badge {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;
  background: var(--purple);

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.category-retrogaming .retro-live-badge img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-retrogaming .twitch-category-box h2 {
  color: var(--purple);
}

.category-retrogaming .twitch-category-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-retrogaming .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-retrogaming .category-layout {
    grid-template-columns: 1fr;
  }

  .category-retrogaming .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-retrogaming .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-retrogaming .category-title-row {
    gap: 28px;
  }

  .category-retrogaming .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-retrogaming .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-retrogaming .category-title-row h1 {
    font-size: clamp(42px, 6.8vw, 66px);
  }

  .category-retrogaming .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-retrogaming .category-hero {
    padding: 36px 20px 24px;
  }

  .category-retrogaming .category-hero-card {
    padding: 30px 24px;
  }

  .category-retrogaming .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-retrogaming .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-retrogaming .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-retrogaming .category-title-row h1 {
    font-size: 42px;
  }

  .category-retrogaming .category-title-row p {
    font-size: 18px;
  }

  .category-retrogaming .category-filter-row,
  .category-retrogaming .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-retrogaming .category-filter {
    flex: 1 1 180px;
  }

  .category-retrogaming .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-retrogaming .featured-review-content {
    padding-top: 46px;
  }

  .category-retrogaming .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-retrogaming .featured-review-link,
  .category-retrogaming .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-retrogaming .category-card-grid,
  .category-retrogaming .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-retrogaming .category-review-card {
    min-height: 370px;
  }

  .category-retrogaming .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* REVIEWS GERAL V2 - WP READY */
/* Estrutura: título + heros das categorias + listas por categoria */
/* Cole no final do style.css */
/* ================================================= */

.reviews-hub-page-v2 .reviews-archive-hero {
  padding: 58px 56px 28px;
}

.reviews-archive-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-archive-breadcrumb a {
  text-decoration: none;
}

.reviews-archive-breadcrumb a:hover {
  color: var(--purple);
}

.reviews-archive-hero-card {
  position: relative;

  width: min(100%, 1420px);
  margin: 0 auto;
  min-height: 250px;
  padding: 42px 50px;

  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

  text-align: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 0%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.reviews-archive-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-archive-hero-card > * {
  position: relative;
  z-index: 2;
}

.reviews-archive-hero-card .section-kicker {
  margin-bottom: 18px;
}

.reviews-archive-hero-card h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.reviews-archive-hero-card p {
  max-width: 780px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

/* ================================================= */
/* HEROS DAS CATEGORIAS */
/* ================================================= */

.reviews-category-showcase {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.reviews-hub-title-row {
  margin-bottom: 18px;
}

.reviews-category-hero-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.reviews-category-hero-card {
  position: relative;
  min-height: 310px;
  padding: 18px 16px 16px;

  display: grid;
  grid-template-rows: 150px auto auto;
  gap: 12px;
  align-items: start;

  color: var(--ink);
  text-decoration: none;
  text-align: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 8%, rgba(86, 32, 129, 0.06), transparent 38%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    0 10px 20px rgba(43, 26, 16, 0.05);

  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.reviews-category-hero-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-category-hero-card:hover {
  transform: translateY(-5px);
  background:
    radial-gradient(circle at 50% 8%, rgba(86, 32, 129, 0.10), transparent 38%),
    rgba(255, 246, 222, 0.16);
  box-shadow: 0 18px 28px rgba(43, 26, 16, 0.13);
}

.reviews-category-hero-card > * {
  position: relative;
  z-index: 2;
}

.reviews-category-hero-card__image {
  width: 100%;
  height: 150px;
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.reviews-category-hero-card__image img {
  width: min(100%, 190px);
  max-height: 145px;
  object-fit: contain;
  filter: drop-shadow(0 10px 16px rgba(43, 26, 16, 0.14));
}

.reviews-category-hero-card__copy strong {
  display: block;
  margin-bottom: 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 21px;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-category-hero-card__copy small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 14px;
  line-height: 1.32;
}

.reviews-category-hero-card__link {
  align-self: end;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  min-height: 38px;
  padding: 0 12px;
  margin-top: 6px;

  color: var(--purple);
  border: 1px solid rgba(86, 32, 129, 0.22);
  background: rgba(86, 32, 129, 0.06);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-category-hero-card:hover .reviews-category-hero-card__link {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* ================================================= */
/* LAYOUT V2 */
/* ================================================= */

.reviews-v2-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.reviews-v2-main {
  min-width: 0;
  display: grid;
  gap: 26px;
}

/* ================================================= */
/* SEÇÕES POR CATEGORIA */
/* ================================================= */

.reviews-category-section {
  position: relative;
  padding: 28px 28px 30px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.04), transparent 32%),
    rgba(255, 246, 222, 0.10);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);
  overflow: hidden;
}

.reviews-category-section::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-category-section > * {
  position: relative;
  z-index: 2;
}

.reviews-category-section__header {
  margin-bottom: 22px;

  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
}

.reviews-category-section__header h2 {
  margin: 10px 0 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-category-section__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.reviews-category-post-card {
  min-height: 320px;
}

.reviews-category-post-card__copy {
  position: relative;
  z-index: 2;
}

/* ================================================= */
/* SIDEBAR MANTIDA */
/* ================================================= */

.reviews-v2-sidebar,
.reviews-hub-sidebar {
  display: grid;
  gap: 24px;
}

.reviews-hub-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.reviews-hub-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-hub-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.reviews-hub-sidebar-box h2 {
  margin: 0 0 20px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.reviews-hub-methodology {
  text-align: center;
}

.reviews-hub-methodology .rating-cats-feature {
  margin: 4px auto 14px;
}

.reviews-hub-methodology .rating-cats-feature img {
  width: 38px;
  height: 38px;
}

.reviews-hub-methodology strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 17px;
  text-transform: uppercase;
}

.reviews-hub-methodology p,
.reviews-hub-submit p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.38;
}

.reviews-hub-sidebar .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.reviews-hub-sidebar .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.reviews-hub-top-terms nav {
  display: grid;
  gap: 0;
}

.reviews-hub-top-terms nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.reviews-hub-top-terms nav a:hover {
  color: var(--purple);
}

.reviews-hub-submit {
  text-align: center;
}

.reviews-hub-submit-icon {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 32px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.reviews-hub-submit .lg-btn {
  width: 100%;
}

/* ================================================= */
/* NEWSLETTER FINAL */
/* ================================================= */

.reviews-hub-newsletter {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px);
  gap: 28px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 80%, rgba(184, 137, 72, 0.10), transparent 36%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.reviews-hub-newsletter h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-hub-newsletter p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.reviews-hub-newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.reviews-hub-newsletter-form input {
  min-width: 0;
  height: 52px;
  padding: 0 16px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.22);
  color: var(--ink);

  font: 600 14px var(--font-body, Georgia, "Times New Roman", serif);
  outline: 0;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1400px) {
  .reviews-category-hero-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .reviews-v2-layout {
    grid-template-columns: 1fr;
  }

  .reviews-v2-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .reviews-category-hero-grid,
  .reviews-category-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .reviews-hub-newsletter {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .reviews-hub-page-v2 .reviews-archive-hero {
    padding: 36px 20px 28px;
  }

  .reviews-archive-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .reviews-archive-hero-card h1 {
    font-size: 46px;
  }

  .reviews-archive-hero-card p {
    font-size: 18px;
  }

  .reviews-category-showcase,
  .reviews-v2-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .reviews-category-hero-grid,
  .reviews-category-section__grid {
    grid-template-columns: 1fr;
  }

  .reviews-category-section {
    padding: 26px 20px 28px;
  }

  .reviews-category-section__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .reviews-hub-newsletter {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .reviews-hub-newsletter-form {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* NOTÍCIAS GERAL - WP READY */
/* Estrutura: título + destaques + editorias + listas por editoria */
/* Cole no final do style.css */
/* ================================================= */

.news-hub-page .news-archive-hero {
  padding: 58px 56px 28px;
}

.news-archive-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-archive-breadcrumb a {
  text-decoration: none;
}

.news-archive-breadcrumb a:hover {
  color: var(--purple);
}

.news-archive-hero-card {
  position: relative;

  width: min(100%, 1420px);
  margin: 0 auto;
  min-height: 250px;
  padding: 42px 50px;

  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

  text-align: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 0%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.news-archive-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-archive-hero-card > * {
  position: relative;
  z-index: 2;
}

.news-archive-hero-card h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.news-archive-hero-card p {
  max-width: 780px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

/* ================================================= */
/* DESTAQUES */
/* ================================================= */

.news-featured-area {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.news-featured-main {
  position: relative;
  min-height: 460px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.72) 42%, rgba(20, 10, 5, 0.22) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.news-featured-main::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.news-featured-main > * {
  position: relative;
  z-index: 2;
}

.news-featured-main .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.news-featured-main .post-category {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.news-featured-main h2 {
  max-width: 720px;
  margin: 0 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.news-featured-main p {
  max-width: 620px;
  margin: 0 0 18px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.news-post-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;

  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.news-featured-main .featured-review-link {
  display: inline-flex;
  margin-left: 22px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.news-featured-secondary {
  display: grid;
  gap: 18px;
}

.news-secondary-card {
  position: relative;
  min-height: 140px;
  padding: 18px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;

  color: #f8e7bd;
  text-decoration: none;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98), rgba(20, 10, 5, 0.34)),
    var(--post-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);
  overflow: hidden;
}

.news-secondary-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.news-secondary-card > * {
  position: relative;
  z-index: 2;
}

.news-secondary-card .post-category {
  position: absolute;
  top: 14px;
  left: 14px;
}

.news-secondary-card strong {
  display: block;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 20px;
  line-height: 1.05;
  text-transform: uppercase;
}

.news-secondary-card small {
  color: rgba(248, 231, 189, 0.84);
  font-size: 13px;
}

/* ================================================= */
/* EDITORIAS */
/* ================================================= */

.news-editorial-showcase {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.news-title-row {
  margin-bottom: 18px;
}

.news-editorial-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.news-editorial-card {
  position: relative;
  min-height: 150px;
  padding: 24px 20px;

  display: grid;
  grid-template-columns: 54px 1fr 24px;
  gap: 14px;
  align-items: center;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.news-editorial-card:hover {
  transform: translateY(-4px);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.09), transparent 30%),
    rgba(255, 246, 222, 0.16);
  box-shadow: 0 16px 26px rgba(43, 26, 16, 0.11);
}

.news-editorial-card__icon {
  width: 50px;
  height: 50px;

  display: grid;
  place-items: center;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
}

.news-editorial-card__icon img {
  width: 26px;
  height: 26px;
  object-fit: contain;
}

.news-editorial-card__copy strong {
  display: block;
  margin-bottom: 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 20px;
  line-height: 1;
  text-transform: uppercase;
}

.news-editorial-card__copy small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 14px;
  line-height: 1.32;
}

.news-editorial-card__arrow {
  color: var(--purple);
  font-size: 24px;
  font-weight: 900;
}

/* ================================================= */
/* LAYOUT PRINCIPAL */
/* ================================================= */

.news-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.news-main {
  min-width: 0;
  display: grid;
  gap: 26px;
}

/* ================================================= */
/* SEÇÕES POR EDITORIA */
/* ================================================= */

.news-category-section {
  position: relative;
  padding: 28px 28px 30px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.04), transparent 32%),
    rgba(255, 246, 222, 0.10);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);
  overflow: hidden;
}

.news-category-section::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-category-section > * {
  position: relative;
  z-index: 2;
}

.news-category-section__header {
  margin-bottom: 22px;

  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
}

.news-category-section__header h2 {
  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.news-category-section__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.news-post-card {
  position: relative;
  isolation: isolate;

  min-height: 320px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--post-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.news-post-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.news-post-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.news-post-card .post-category {
  top: 14px;
  left: 14px;
}

.news-post-card__copy {
  position: relative;
  z-index: 2;
}

.news-post-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1.03;
}

.news-post-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

/* ================================================= */
/* SIDEBAR */
/* ================================================= */

.news-sidebar {
  display: grid;
  gap: 24px;
}

.news-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.news-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.news-sidebar-box h2 {
  margin: 0 0 20px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.news-mini-link {
  display: block;
  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.news-mini-link:last-child {
  margin-bottom: 0;
}

.news-mini-link strong {
  display: block;
  margin-bottom: 6px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.15;
  text-transform: uppercase;
}

.news-mini-link small {
  color: rgba(43, 26, 16, 0.70);
  font-size: 13px;
}

.news-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.news-tag-cloud a {
  min-height: 34px;
  padding: 0 12px;

  display: inline-flex;
  align-items: center;

  color: var(--purple);
  border: 1px solid rgba(86, 32, 129, 0.22);
  background: rgba(86, 32, 129, 0.05);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.news-tag-cloud a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.news-discord-cta,
.news-tip-cta {
  text-align: center;
}

.news-discord-icon,
.news-tip-icon {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 32px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.news-discord-icon img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.news-discord-cta p,
.news-tip-cta p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.38;
}

.news-discord-cta .lg-btn {
  width: 100%;
}

.news-sidebar .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.news-sidebar .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* ================================================= */
/* NEWSLETTER FINAL */
/* ================================================= */

.news-newsletter {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px);
  gap: 28px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 80%, rgba(184, 137, 72, 0.10), transparent 36%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-newsletter h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.news-newsletter p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.news-newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.news-newsletter-form input {
  min-width: 0;
  height: 52px;
  padding: 0 16px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.22);
  color: var(--ink);

  font: 600 14px var(--font-body, Georgia, "Times New Roman", serif);
  outline: 0;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .news-featured-area,
  .news-layout {
    grid-template-columns: 1fr;
  }

  .news-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .news-editorial-grid,
  .news-category-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .news-featured-secondary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .news-featured-secondary,
  .news-sidebar {
    grid-template-columns: 1fr;
  }

  .news-newsletter {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .news-hub-page .news-archive-hero {
    padding: 36px 20px 28px;
  }

  .news-archive-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .news-archive-hero-card h1 {
    font-size: 46px;
  }

  .news-archive-hero-card p {
    font-size: 18px;
  }

  .news-featured-area,
  .news-editorial-showcase,
  .news-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .news-editorial-grid,
  .news-category-section__grid {
    grid-template-columns: 1fr;
  }

  .news-featured-main {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .news-featured-main .featured-review-link {
    display: flex;
    margin: 16px 0 0;
  }

  .news-category-section {
    padding: 26px 20px 28px;
  }

  .news-category-section__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .news-newsletter {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .news-newsletter-form {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* GUIAS GERAL - WP READY */
/* Estrutura: hero + destaque + categorias + listas por categoria */
/* Cole no final do style.css */
/* ================================================= */

.guides-hub-page .guides-archive-hero {
  padding: 58px 56px 28px;
}

.guides-archive-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.guides-archive-breadcrumb a {
  text-decoration: none;
}

.guides-archive-breadcrumb a:hover {
  color: var(--purple);
}

.guides-archive-hero-card {
  position: relative;

  width: min(100%, 1420px);
  margin: 0 auto;
  min-height: 330px;
  padding: 42px 50px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  gap: 34px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 20%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.guides-archive-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.guides-archive-hero-card > * {
  position: relative;
  z-index: 2;
}

.guides-archive-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.guides-archive-hero-copy p {
  max-width: 780px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.guides-archive-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.guides-archive-hero-art {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}

.guides-archive-hero-art img {
  width: 138px;
  height: 138px;
  object-fit: contain;
  opacity: 0.90;
  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

/* ================================================= */
/* DESTAQUE */
/* ================================================= */

.guides-featured-area {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.guides-featured-main {
  position: relative;
  min-height: 460px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.72) 42%, rgba(20, 10, 5, 0.22) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.guides-featured-main::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.guides-featured-main > * {
  position: relative;
  z-index: 2;
}

.guides-featured-main .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.guides-featured-main .post-category {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.guides-featured-main h2 {
  max-width: 720px;
  margin: 0 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.guides-featured-main p {
  max-width: 620px;
  margin: 0 0 18px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.guide-post-meta {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.guide-post-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 9px;

  color: var(--cream);
  background: var(--purple);
  border: 1px solid rgba(255, 243, 214, 0.20);
}

.guides-featured-main .featured-review-link {
  display: inline-flex;
  margin-left: 22px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.guides-featured-secondary {
  display: grid;
  gap: 18px;
}

.guides-secondary-card {
  position: relative;
  min-height: 140px;
  padding: 18px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;

  color: #f8e7bd;
  text-decoration: none;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98), rgba(20, 10, 5, 0.34)),
    var(--post-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);
  overflow: hidden;
}

.guides-secondary-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.guides-secondary-card > * {
  position: relative;
  z-index: 2;
}

.guides-secondary-card .post-category {
  position: absolute;
  top: 14px;
  left: 14px;
}

.guides-secondary-card strong {
  display: block;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 20px;
  line-height: 1.05;
  text-transform: uppercase;
}

.guides-secondary-card small {
  color: rgba(248, 231, 189, 0.84);
  font-size: 13px;
}

/* ================================================= */
/* CATEGORIAS */
/* ================================================= */

.guides-category-showcase {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.guides-title-row {
  margin-bottom: 18px;
}

.guides-category-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.guides-category-card {
  position: relative;
  min-height: 190px;
  padding: 22px 18px;

  display: grid;
  grid-template-rows: 54px 1fr 24px;
  gap: 14px;
  justify-items: center;
  text-align: center;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.guides-category-card:hover {
  transform: translateY(-4px);
  background:
    radial-gradient(circle at 50% 10%, rgba(86, 32, 129, 0.09), transparent 30%),
    rgba(255, 246, 222, 0.16);
  box-shadow: 0 16px 26px rgba(43, 26, 16, 0.11);
}

.guides-category-card__icon {
  width: 54px;
  height: 54px;

  display: grid;
  place-items: center;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
}

.guides-category-card__icon img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.guides-category-card__copy strong {
  display: block;
  margin-bottom: 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.guides-category-card__copy small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 14px;
  line-height: 1.32;
}

.guides-category-card__arrow {
  color: var(--purple);
  font-size: 24px;
  font-weight: 900;
}

/* ================================================= */
/* LAYOUT PRINCIPAL */
/* ================================================= */

.guides-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.guides-main {
  min-width: 0;
  display: grid;
  gap: 26px;
}

/* ================================================= */
/* SEÇÕES POR CATEGORIA */
/* ================================================= */

.guides-category-section {
  position: relative;
  padding: 28px 28px 30px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.04), transparent 32%),
    rgba(255, 246, 222, 0.10);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);
  overflow: hidden;
}

.guides-category-section::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.guides-category-section > * {
  position: relative;
  z-index: 2;
}

.guides-category-section__header {
  margin-bottom: 22px;

  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
}

.guides-category-section__header h2 {
  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.guides-category-section__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.guide-post-card {
  position: relative;
  isolation: isolate;

  min-height: 320px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--post-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.guide-post-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.guide-post-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.guide-post-card .post-category {
  top: 14px;
  left: 14px;
}

.guide-post-card__copy {
  position: relative;
  z-index: 2;
}

.guide-post-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1.03;
}

.guide-post-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

/* ================================================= */
/* SIDEBAR */
/* ================================================= */

.guides-sidebar {
  display: grid;
  gap: 24px;
}

.guides-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.guides-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.guides-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.guides-sidebar-box h2 {
  margin: 0 0 20px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.guides-mini-link {
  display: block;
  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.guides-mini-link:last-child {
  margin-bottom: 0;
}

.guides-mini-link strong {
  display: block;
  margin-bottom: 6px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.15;
  text-transform: uppercase;
}

.guides-mini-link small {
  color: rgba(43, 26, 16, 0.70);
  font-size: 13px;
}

.guides-difficulty nav {
  display: grid;
  gap: 0;
}

.guides-difficulty nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.guides-difficulty nav a:hover {
  color: var(--purple);
}

.guides-toolbox,
.guides-suggest {
  text-align: center;
}

.guides-toolbox-icon,
.guides-suggest-icon {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 32px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.guides-toolbox p,
.guides-suggest p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.38;
}

.guides-toolbox .lg-btn {
  width: 100%;
}

.guides-sidebar .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.guides-sidebar .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* ================================================= */
/* NEWSLETTER FINAL */
/* ================================================= */

.guides-newsletter {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px);
  gap: 28px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 80%, rgba(184, 137, 72, 0.10), transparent 36%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.guides-newsletter h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.guides-newsletter p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.guides-newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.guides-newsletter-form input {
  min-width: 0;
  height: 52px;
  padding: 0 16px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.22);
  color: var(--ink);

  font: 600 14px var(--font-body, Georgia, "Times New Roman", serif);
  outline: 0;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .guides-featured-area,
  .guides-layout {
    grid-template-columns: 1fr;
  }

  .guides-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .guides-category-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .guides-category-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .guides-featured-secondary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .guides-archive-hero-card {
    grid-template-columns: 1fr;
  }

  .guides-archive-hero-art {
    display: none;
  }

  .guides-featured-secondary,
  .guides-sidebar {
    grid-template-columns: 1fr;
  }

  .guides-newsletter {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .guides-hub-page .guides-archive-hero {
    padding: 36px 20px 28px;
  }

  .guides-archive-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .guides-archive-hero-copy h1 {
    font-size: 46px;
  }

  .guides-archive-hero-copy p {
    font-size: 18px;
  }

  .guides-featured-area,
  .guides-category-showcase,
  .guides-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .guides-category-grid,
  .guides-category-section__grid {
    grid-template-columns: 1fr;
  }

  .guides-featured-main {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .guides-featured-main .featured-review-link {
    display: flex;
    margin: 16px 0 0;
  }

  .guides-category-section {
    padding: 26px 20px 28px;
  }

  .guides-category-section__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .guides-newsletter {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .guides-newsletter-form {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* COVEN / COMUNIDADE - WP READY */
/* Página estática institucional */
/* Cole no final do style.css */
/* ================================================= */

.coven-page .coven-hero {
  padding: 58px 56px 32px;
}

.coven-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.coven-breadcrumb a {
  text-decoration: none;
}

.coven-breadcrumb a:hover {
  color: var(--purple);
}

.coven-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.coven-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.coven-hero-card > * {
  position: relative;
  z-index: 2;
}

.coven-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.coven-hero-copy p {
  max-width: 780px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.coven-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.coven-hero-art {
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.coven-hero-art img {
  width: min(100%, 330px);
  max-height: 290px;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16));
}

/* Intro */

.coven-intro {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.coven-intro-card,
.coven-intro-aside,
.coven-ritual-card,
.coven-discord,
.coven-mascot-card,
.coven-rules,
.coven-final-cta {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.coven-intro-card::before,
.coven-intro-aside::before,
.coven-ritual-card::before,
.coven-discord::before,
.coven-mascot-card::before,
.coven-rules::before,
.coven-final-cta::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.coven-intro-card > *,
.coven-intro-aside > *,
.coven-ritual-card > *,
.coven-discord > *,
.coven-mascot-card > *,
.coven-rules > *,
.coven-final-cta > * {
  position: relative;
  z-index: 2;
}

.coven-intro-card {
  padding: 38px 40px;
}

.coven-intro-card h2 {
  max-width: 800px;
  margin: 12px 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 42px;
  line-height: 0.98;
  text-transform: uppercase;
}

.coven-intro-card p {
  max-width: 850px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.coven-intro-card p:last-child {
  margin-bottom: 0;
}

.coven-intro-aside {
  padding: 34px 28px;
}

.coven-intro-aside h3 {
  margin: 0 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-intro-aside ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.coven-intro-aside li {
  padding: 13px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
  font-size: 16px;
  font-weight: 700;
}

.coven-intro-aside li::before {
  content: "✦ ";
  color: var(--purple);
}

/* Rituais */

.coven-rituals,
.coven-mascots {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.coven-title-row {
  margin-bottom: 18px;
}

.coven-ritual-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.coven-ritual-card {
  min-height: 230px;
  padding: 28px 24px;
  text-align: center;
}

.coven-ritual-card__icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.coven-ritual-card h3,
.coven-mascot-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-ritual-card p,
.coven-mascot-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15.5px;
  line-height: 1.38;
}

/* Discord */

.coven-discord {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 42px 46px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: 34px;
  align-items: center;
}

.coven-discord-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 46px;
  line-height: 0.95;
  text-transform: uppercase;
}

.coven-discord-copy p {
  max-width: 760px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.coven-discord-card {
  padding: 28px 24px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.12);
}

.coven-discord-icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 32px;
}

.coven-discord-icon img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.coven-discord-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-discord-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.76);
  font-size: 15px;
  line-height: 1.38;
}

/* Mascotes */

.coven-mascot-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.coven-mascot-card {
  min-height: 170px;
  padding: 24px;

  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 18px;
  align-items: center;
}

.coven-mascot-card figure {
  margin: 0;
}

.coven-mascot-card img {
  width: 92px;
  height: 92px;
  object-fit: contain;
}

/* Regras */

.coven-rules {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.coven-rules-header {
  margin-bottom: 24px;
  text-align: center;
}

.coven-rules-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-rules-header p {
  margin: 0 auto;
  max-width: 720px;
  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.coven-rule-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.coven-rule-card {
  padding: 22px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.coven-rule-card strong {
  display: block;
  margin-bottom: 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 17px;
  text-transform: uppercase;
}

.coven-rule-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 14.5px;
  line-height: 1.34;
}

/* CTA final */

.coven-final-cta {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
}

.coven-final-cta h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-final-cta p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.coven-final-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Responsivo */

@media (max-width: 1300px) {
  .coven-intro,
  .coven-discord,
  .coven-final-cta {
    grid-template-columns: 1fr;
  }

  .coven-ritual-grid,
  .coven-rule-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .coven-mascot-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1100px) {
  .coven-hero-card {
    grid-template-columns: 1fr;
  }

  .coven-hero-art {
    display: none;
  }
}

@media (max-width: 900px) {
  .coven-page .coven-hero {
    padding: 36px 20px 28px;
  }

  .coven-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .coven-hero-copy h1 {
    font-size: 46px;
  }

  .coven-hero-copy p,
  .coven-intro-card p,
  .coven-discord-copy p {
    font-size: 18px;
  }

  .coven-intro,
  .coven-rituals,
  .coven-mascots {
    padding-left: 20px;
    padding-right: 20px;
  }

  .coven-intro-card,
  .coven-intro-aside,
  .coven-discord,
  .coven-rules,
  .coven-final-cta {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .coven-intro-card h2,
  .coven-discord-copy h2,
  .coven-rules-header h2 {
    font-size: 32px;
  }

  .coven-ritual-grid,
  .coven-rule-grid {
    grid-template-columns: 1fr;
  }

  .coven-mascot-card {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
  }

  .coven-final-actions {
    width: 100%;
  }

  .coven-final-actions .lg-btn {
    width: 100%;
  }
}
/* ================================================= */
/* COVEN - GUARDIÕES FELINOS EM DESTAQUE */
/* imagens em cima + descrição embaixo */
/* ================================================= */

.coven-mascot-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.coven-mascot-card {
  min-height: auto;
  padding: 26px 24px 28px;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;

  gap: 18px;
  text-align: center;
}

.coven-mascot-card figure {
  width: 100%;
  height: 230px;
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.coven-mascot-card img {
  width: 100%;
  max-width: 210px;
  height: 210px;

  object-fit: contain;

  filter:
    drop-shadow(0 14px 20px rgba(43, 26, 16, 0.16))
    saturate(1.03);

  transition:
    transform 0.22s ease,
    filter 0.22s ease;
}

.coven-mascot-card:hover img {
  transform: translateY(-4px) scale(1.04);
  filter:
    drop-shadow(0 18px 26px rgba(43, 26, 16, 0.22))
    saturate(1.08);
}

.coven-mascot-card div {
  max-width: 320px;
}

.coven-mascot-card h3 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.coven-mascot-card p {
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.42;
  text-align: center;
}
@media (max-width: 1100px) {
  .coven-mascot-grid {
    grid-template-columns: 1fr;
  }

  .coven-mascot-card figure {
    height: 250px;
  }

  .coven-mascot-card img {
    max-width: 230px;
    height: 230px;
  }
}

@media (max-width: 640px) {
  .coven-mascot-card {
    padding: 24px 20px 26px;
  }

  .coven-mascot-card figure {
    height: 210px;
  }

  .coven-mascot-card img {
    max-width: 190px;
    height: 190px;
  }

  .coven-mascot-card h3 {
    font-size: 23px;
  }

  .coven-mascot-card p {
    font-size: 15px;
  }
}/* ================================================= */
/* PARCERIAS - WP READY */
/* Página comercial / institucional */
/* Cole no final do style.css */
/* ================================================= */

.partners-page .partners-hero {
  padding: 58px 56px 32px;
}

.partners-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.partners-breadcrumb a {
  text-decoration: none;
}

.partners-breadcrumb a:hover {
  color: var(--purple);
}

.partners-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.partners-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-hero-card > * {
  position: relative;
  z-index: 2;
}

.partners-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(58px, 5.4vw, 96px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.partners-hero-copy p {
  max-width: 800px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.partners-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.partners-hero-panel {
  padding: 30px 26px;

  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.14);
}

.partners-hero-panel__icon {
  width: 76px;
  height: 76px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.partners-hero-panel__icon img {
  width: 38px;
  height: 38px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.partners-hero-panel h2 {
  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-hero-panel p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.38;
}

/* Blocos base */

.partners-intro,
.partners-contact {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.partners-intro-card,
.partners-intro-aside,
.partners-format-card,
.partners-audience,
.partners-plan-card,
.partners-process,
.partners-contact,
.partners-contact-form {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.partners-intro-card::before,
.partners-intro-aside::before,
.partners-format-card::before,
.partners-audience::before,
.partners-plan-card::before,
.partners-process::before,
.partners-contact::before,
.partners-contact-form::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-intro-card > *,
.partners-intro-aside > *,
.partners-format-card > *,
.partners-audience > *,
.partners-plan-card > *,
.partners-process > *,
.partners-contact > *,
.partners-contact-form > * {
  position: relative;
  z-index: 2;
}

/* Intro */

.partners-intro-card {
  padding: 38px 40px;
}

.partners-intro-card h2 {
  max-width: 850px;
  margin: 12px 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 42px;
  line-height: 0.98;
  text-transform: uppercase;
}

.partners-intro-card p {
  max-width: 900px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.partners-intro-card p:last-child {
  margin-bottom: 0;
}

.partners-intro-aside {
  padding: 34px 28px;
}

.partners-intro-aside h3 {
  margin: 0 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-intro-aside ul,
.partners-plan-card ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.partners-intro-aside li {
  padding: 13px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
  font-size: 16px;
  font-weight: 700;
}

.partners-intro-aside li::before,
.partners-plan-card li::before {
  content: "✦ ";
  color: var(--purple);
}

/* Formatos */

.partners-formats,
.partners-plans {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.partners-title-row {
  margin-bottom: 18px;
}

.partners-format-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.partners-format-card {
  min-height: 230px;
  padding: 28px 24px;
  text-align: center;
}

.partners-format-card__icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.partners-format-card h3,
.partners-audience-card h3,
.partners-plan-card h3,
.partners-step-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-format-card p,
.partners-audience-card p,
.partners-plan-card p,
.partners-step-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15.5px;
  line-height: 1.38;
}

/* Audiência */

.partners-audience {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.partners-audience-header,
.partners-process-header {
  text-align: center;
  margin-bottom: 24px;
}

.partners-audience-header h2,
.partners-process-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-audience-header p,
.partners-process-header p {
  max-width: 760px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.partners-audience-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.partners-audience-card {
  padding: 22px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

/* Planos */

.partners-plan-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.partners-plan-card {
  padding: 30px 26px;
}

.partners-plan-card__label {
  display: inline-flex;
  width: fit-content;
  min-height: 28px;
  margin-bottom: 18px;
  padding: 0 10px;

  align-items: center;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.partners-plan-card p {
  margin-bottom: 18px;
}

.partners-plan-card li {
  padding: 10px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
  font-size: 15px;
  font-weight: 700;
}

.partners-plan-card .sidebar-button {
  margin-top: 22px;
}

/* Processo */

.partners-process {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.partners-step-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.partners-step-card {
  padding: 24px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.partners-step-card span {
  width: 52px;
  height: 52px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  font-weight: 900;
}

/* Contato */

.partners-contact {
  padding-top: 0;
  padding-bottom: 0;
}

.partners-contact::before {
  display: none;
}

.partners-contact-copy {
  position: relative;
  padding: 38px 40px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
}

.partners-contact-copy::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-contact-copy > * {
  position: relative;
  z-index: 2;
}

.partners-contact-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 46px;
  line-height: 0.95;
  text-transform: uppercase;
}

.partners-contact-copy p {
  max-width: 760px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.partners-contact-list {
  display: grid;
  gap: 10px;
}

.partners-contact-list a {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  text-decoration: none;
}

.partners-contact-list a:hover {
  color: var(--purple);
}

.partners-contact-form {
  padding: 34px 28px;
  display: grid;
  gap: 10px;
}

.partners-contact-form label {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.partners-contact-form input,
.partners-contact-form textarea {
  width: 100%;
  padding: 13px 14px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.22);

  font: 600 15px var(--font-body, Georgia, "Times New Roman", serif);
  outline: 0;
  resize: vertical;
}

.partners-contact-form input:focus,
.partners-contact-form textarea:focus {
  border-color: var(--purple);
}

.partners-contact-form .lg-btn {
  width: 100%;
  margin-top: 10px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .partners-intro,
  .partners-contact,
  .partners-hero-card {
    grid-template-columns: 1fr;
  }

  .partners-format-grid,
  .partners-plan-grid,
  .partners-audience-grid,
  .partners-step-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .partners-page .partners-hero {
    padding: 36px 20px 28px;
  }

  .partners-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .partners-hero-copy h1 {
    font-size: 46px;
  }

  .partners-hero-copy p,
  .partners-intro-card p,
  .partners-contact-copy p {
    font-size: 18px;
  }

  .partners-intro,
  .partners-formats,
  .partners-plans,
  .partners-contact {
    padding-left: 20px;
    padding-right: 20px;
  }

  .partners-audience,
  .partners-process {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .partners-intro-card,
  .partners-intro-aside,
  .partners-contact-copy,
  .partners-contact-form {
    padding: 28px 22px;
  }

  .partners-intro-card h2,
  .partners-contact-copy h2,
  .partners-audience-header h2,
  .partners-process-header h2 {
    font-size: 32px;
  }

  .partners-format-grid,
  .partners-plan-grid,
  .partners-audience-grid,
  .partners-step-grid {
    grid-template-columns: 1fr;
  }

  .partners-hero-actions .lg-btn {
    width: 100%;
  }
}
/* ================================================= */
/* CONTATO / PARCERIAS - AJUSTE VISUAL */
/* ================================================= */

.partners-contact {
  width: min(100%, 1500px);
  margin: 0 auto 40px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: 1.45fr 0.95fr;
  gap: 24px;
  align-items: stretch;
}

.partners-contact-copy,
.partners-contact-form {
  position: relative;
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.04), transparent 30%),
    rgba(255, 246, 222, 0.14);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
  overflow: hidden;
}

.partners-contact-copy::before,
.partners-contact-form::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-contact-copy > *,
.partners-contact-form > * {
  position: relative;
  z-index: 2;
}

/* COLUNA ESQUERDA */
.partners-contact-copy {
  padding: 40px 42px;
  min-height: 420px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.partners-contact-copy .section-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 30px;
  padding: 0 14px;
  margin-bottom: 18px;

  border: 1px solid rgba(164, 112, 52, 0.28);
  background: rgba(255, 246, 222, 0.65);

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.partners-contact-copy h2 {
  margin: 0 0 20px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 64px);
  line-height: 0.95;
  font-weight: 900;
  text-transform: uppercase;
}

.partners-contact-copy p {
  max-width: 760px;
  margin: 0 0 28px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 20px;
  line-height: 1.5;
}

.partners-contact-list {
  display: grid;
  gap: 12px;
}

.partners-contact-list a {
  width: fit-content;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.2s ease;
}

.partners-contact-list a:hover {
  color: var(--purple);
}

/* COLUNA DIREITA / FORM */
.partners-contact-form {
  padding: 34px 28px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.partners-contact-form form,
.partners-contact-form-inner {
  display: grid;
  gap: 12px;
}

.partners-contact-form label {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.partners-contact-form input,
.partners-contact-form textarea {
  width: 100%;
  padding: 14px 16px;

  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.30);
  color: var(--ink);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 16px;
  line-height: 1.4;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.partners-contact-form input:focus,
.partners-contact-form textarea:focus {
  border-color: var(--purple);
  box-shadow: 0 0 0 2px rgba(86, 32, 129, 0.10);
}

.partners-contact-form textarea {
  min-height: 130px;
  resize: vertical;
}

.partners-contact-form .lg-btn,
.partners-contact-form button {
  margin-top: 8px;
  width: 100%;
  min-height: 54px;

  border: 0;
  cursor: pointer;

  background: var(--purple);
  color: #fff;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 800;
  text-transform: uppercase;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.partners-contact-form .lg-btn:hover,
.partners-contact-form button:hover {
  opacity: 0.92;
  transform: translateY(-1px);
}

/* RESPONSIVO */
@media (max-width: 980px) {
  .partners-contact {
    grid-template-columns: 1fr;
    padding: 0 20px;
  }

  .partners-contact-copy,
  .partners-contact-form {
    min-height: auto;
    padding: 28px 22px;
  }

  .partners-contact-copy h2 {
    font-size: 38px;
  }

  .partners-contact-copy p {
    font-size: 18px;
  }
}/* ================================================= */
/* PARCERIAS - CONTATO REFINADO */
/* ícones + linha ornamental + formulário premium */
/* ================================================= */

.partners-contact-refined {
  width: min(100%, 1500px);
  margin: 0 auto 40px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(360px, 0.85fr);
  gap: 26px;
  align-items: stretch;

  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

.partners-contact-refined::before {
  display: none;
}

/* COLUNAS */

.partners-contact-refined .partners-contact-copy,
.partners-contact-refined .partners-contact-form {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 86% 16%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.15);

  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    0 14px 24px rgba(43, 26, 16, 0.05);

  overflow: hidden;
}

.partners-contact-refined .partners-contact-copy::before,
.partners-contact-refined .partners-contact-form::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-contact-refined .partners-contact-copy > *,
.partners-contact-refined .partners-contact-form > * {
  position: relative;
  z-index: 2;
}

/* COLUNA ESQUERDA */

.partners-contact-refined .partners-contact-copy {
  min-height: 430px;
  padding: 44px 46px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.partners-contact-refined .section-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: fit-content;
  min-height: 30px;
  padding: 0 14px;
  margin-bottom: 20px;

  border: 1px solid rgba(164, 112, 52, 0.30);
  background: rgba(255, 246, 222, 0.60);

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.partners-contact-refined .partners-contact-copy h2 {
  max-width: 860px;
  margin: 0 0 22px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4.4vw, 70px);
  line-height: 0.92;
  font-weight: 900;
  letter-spacing: -0.035em;
  text-transform: uppercase;
}

.partners-contact-refined .partners-contact-copy p {
  max-width: 820px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 20px;
  line-height: 1.48;
}

/* LINHA ORNAMENTAL */

.partners-contact-divider {
  width: min(100%, 520px);
  margin: 30px 0 26px;

  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 14px;
}

.partners-contact-divider span {
  display: block;
  height: 1px;
  background: rgba(164, 112, 52, 0.34);
}

.partners-contact-divider i {
  color: var(--purple);
  font-style: normal;
  font-size: 17px;
  line-height: 1;
}

/* LINKS DE CONTATO */

.partners-contact-refined .partners-contact-list {
  display: grid;
  gap: 14px;
}

.partners-contact-link {
  width: fit-content;

  display: inline-flex;
  align-items: center;
  gap: 12px;

  color: var(--ink);
  text-decoration: none;

  transition:
    color 0.2s ease,
    transform 0.2s ease;
}

.partners-contact-link:hover {
  color: var(--purple);
  transform: translateX(3px);
}

.partners-contact-icon {
  width: 38px;
  height: 38px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;
  background: var(--purple);
  color: var(--cream);

  font-size: 17px;
  font-weight: 900;

  box-shadow:
    0 8px 16px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.partners-contact-icon img {
  width: 18px;
  height: 18px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.partners-contact-link span:last-child {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

/* FORMULÁRIO */

.partners-contact-refined .partners-contact-form {
  min-height: 430px;
  padding: 34px 30px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.partners-form-header {
  margin-bottom: 20px;
  text-align: center;
}

.partners-form-header > span {
  width: 50px;
  height: 50px;
  margin: 0 auto 14px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  color: var(--cream);

  font-size: 22px;

  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.partners-form-header h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-form-header p {
  max-width: 330px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.72);
  font-size: 14.5px;
  line-height: 1.34;
}

.partners-contact-refined .partners-contact-form label {
  margin: 10px 0 6px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.partners-contact-refined .partners-contact-form input,
.partners-contact-refined .partners-contact-form textarea {
  width: 100%;
  padding: 14px 16px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.34);
  background: rgba(255, 246, 222, 0.32);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15.5px;
  line-height: 1.4;

  outline: 0;
  resize: vertical;

  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.partners-contact-refined .partners-contact-form input::placeholder,
.partners-contact-refined .partners-contact-form textarea::placeholder {
  color: rgba(43, 26, 16, 0.52);
}

.partners-contact-refined .partners-contact-form input:focus,
.partners-contact-refined .partners-contact-form textarea:focus {
  border-color: var(--purple);
  background: rgba(255, 246, 222, 0.42);
  box-shadow: 0 0 0 2px rgba(86, 32, 129, 0.10);
}

.partners-contact-refined .partners-contact-form textarea {
  min-height: 132px;
}

.partners-contact-refined .partners-contact-form .lg-btn,
.partners-contact-refined .partners-contact-form button {
  width: 100%;
  min-height: 54px;
  margin-top: 18px;

  border: 1px solid var(--purple);
  background: var(--purple);
  color: var(--cream);
  cursor: pointer;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.partners-contact-refined .partners-contact-form .lg-btn:hover,
.partners-contact-refined .partners-contact-form button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 20px rgba(43, 26, 16, 0.16);
}

/* RESPONSIVO */

@media (max-width: 1100px) {
  .partners-contact-refined {
    grid-template-columns: 1fr;
  }

  .partners-contact-refined .partners-contact-copy,
  .partners-contact-refined .partners-contact-form {
    min-height: auto;
  }
}

@media (max-width: 700px) {
  .partners-contact-refined {
    padding: 0 20px;
  }

  .partners-contact-refined .partners-contact-copy,
  .partners-contact-refined .partners-contact-form {
    padding: 30px 22px;
  }

  .partners-contact-refined .partners-contact-copy h2 {
    font-size: 38px;
  }

  .partners-contact-refined .partners-contact-copy p {
    font-size: 18px;
  }

  .partners-contact-link {
    align-items: flex-start;
  }

  .partners-contact-link span:last-child {
    font-size: 15px;
    word-break: break-word;
  }

  .partners-contact-divider {
    margin: 24px 0 22px;
  }
}/* ================================================= */
/* SOBRE - WP READY */
/* Página institucional */
/* Cole no final do style.css */
/* ================================================= */

.about-page .about-hero {
  padding: 58px 56px 32px;
}

.about-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.about-breadcrumb a {
  text-decoration: none;
}

.about-breadcrumb a:hover {
  color: var(--purple);
}

.about-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.about-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.about-hero-card > * {
  position: relative;
  z-index: 2;
}

.about-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.about-hero-copy p {
  max-width: 820px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.about-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.about-hero-art {
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.about-hero-art img {
  width: min(100%, 300px);
  max-height: 260px;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16));
}

/* Manifesto */

.about-manifesto {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.about-manifesto-card,
.about-manifesto-aside,
.about-pillar-card,
.about-creator,
.about-values,
.about-ecosystem,
.about-final-cta {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.about-manifesto-card::before,
.about-manifesto-aside::before,
.about-pillar-card::before,
.about-creator::before,
.about-values::before,
.about-ecosystem::before,
.about-final-cta::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.about-manifesto-card > *,
.about-manifesto-aside > *,
.about-pillar-card > *,
.about-creator > *,
.about-values > *,
.about-ecosystem > *,
.about-final-cta > * {
  position: relative;
  z-index: 2;
}

.about-manifesto-card {
  padding: 38px 40px;
}

.about-manifesto-card h2 {
  max-width: 860px;
  margin: 12px 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 42px;
  line-height: 0.98;
  text-transform: uppercase;
}

.about-manifesto-card p {
  max-width: 900px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.about-manifesto-card p:last-child {
  margin-bottom: 0;
}

.about-manifesto-aside {
  padding: 34px 28px;
}

.about-manifesto-aside h3 {
  margin: 0 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.about-manifesto-aside ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.about-manifesto-aside li {
  padding: 13px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
  font-size: 16px;
  font-weight: 700;
}

.about-manifesto-aside li::before {
  content: "✦ ";
  color: var(--purple);
}

/* Pilares */

.about-pillars {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.about-title-row {
  margin-bottom: 18px;
}

.about-pillar-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.about-pillar-card {
  min-height: 240px;
  padding: 28px 24px;
  text-align: center;
}

.about-pillar-card__icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.about-pillar-card h3,
.about-value-card strong,
.about-timeline-card h3,
.about-creator-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 21px;
  line-height: 1;
  text-transform: uppercase;
}

.about-pillar-card p,
.about-value-card p,
.about-timeline-card p,
.about-creator-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15.5px;
  line-height: 1.38;
}

/* Criador */

.about-creator {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 42px 46px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: 34px;
  align-items: center;
}

.about-creator-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 46px;
  line-height: 0.95;
  text-transform: uppercase;
}

.about-creator-copy p {
  max-width: 820px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.about-creator-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px;
}

.about-creator-card {
  padding: 30px 24px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.12);
}

.about-creator-icon {
  width: 82px;
  height: 82px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  font-weight: 900;
}

/* Valores + ecossistema */

.about-values,
.about-ecosystem {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.about-values-header,
.about-ecosystem-header {
  text-align: center;
  margin-bottom: 24px;
}

.about-values-header h2,
.about-ecosystem-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.about-values-header p,
.about-ecosystem-header p {
  max-width: 760px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.about-value-grid,
.about-timeline-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.about-value-card,
.about-timeline-card {
  padding: 24px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.about-value-card strong {
  display: block;
  color: var(--purple);
}

.about-timeline-card span {
  width: 52px;
  height: 52px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  font-weight: 900;
}

/* CTA final */

.about-final-cta {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
}

.about-final-cta h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.about-final-cta p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.about-final-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Responsivo */

@media (max-width: 1300px) {
  .about-manifesto,
  .about-creator,
  .about-final-cta,
  .about-hero-card {
    grid-template-columns: 1fr;
  }

  .about-pillar-grid,
  .about-value-grid,
  .about-timeline-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-hero-art {
    display: none;
  }
}

@media (max-width: 900px) {
  .about-page .about-hero {
    padding: 36px 20px 28px;
  }

  .about-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .about-hero-copy h1 {
    font-size: 46px;
  }

  .about-hero-copy p,
  .about-manifesto-card p,
  .about-creator-copy p {
    font-size: 18px;
  }

  .about-manifesto,
  .about-pillars {
    padding-left: 20px;
    padding-right: 20px;
  }

  .about-creator,
  .about-values,
  .about-ecosystem,
  .about-final-cta {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .about-manifesto-card,
  .about-manifesto-aside {
    padding: 28px 22px;
  }

  .about-manifesto-card h2,
  .about-creator-copy h2,
  .about-values-header h2,
  .about-ecosystem-header h2 {
    font-size: 32px;
  }

  .about-pillar-grid,
  .about-value-grid,
  .about-timeline-grid {
    grid-template-columns: 1fr;
  }

  .about-final-actions,
  .about-final-actions .lg-btn,
  .about-creator-actions .lg-btn {
    width: 100%;
  }
}
/* ================================================= */
/* SOBRE - WP READY */
/* Página institucional */
/* Cole no final do style.css */
/* ================================================= */

.about-page .about-hero {
  padding: 58px 56px 32px;
}

.about-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.about-breadcrumb a {
  text-decoration: none;
}

.about-breadcrumb a:hover {
  color: var(--purple);
}

.about-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.about-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.about-hero-card > * {
  position: relative;
  z-index: 2;
}

.about-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.about-hero-copy p {
  max-width: 820px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.about-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.about-hero-art {
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.about-hero-art img {
  width: min(100%, 300px);
  max-height: 260px;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16));
}

/* Manifesto */

.about-manifesto {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.about-manifesto-card,
.about-manifesto-aside,
.about-pillar-card,
.about-creator,
.about-values,
.about-ecosystem,
.about-final-cta {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.about-manifesto-card::before,
.about-manifesto-aside::before,
.about-pillar-card::before,
.about-creator::before,
.about-values::before,
.about-ecosystem::before,
.about-final-cta::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.about-manifesto-card > *,
.about-manifesto-aside > *,
.about-pillar-card > *,
.about-creator > *,
.about-values > *,
.about-ecosystem > *,
.about-final-cta > * {
  position: relative;
  z-index: 2;
}

.about-manifesto-card {
  padding: 38px 40px;
}

.about-manifesto-card h2 {
  max-width: 860px;
  margin: 12px 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 42px;
  line-height: 0.98;
  text-transform: uppercase;
}

.about-manifesto-card p {
  max-width: 900px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.about-manifesto-card p:last-child {
  margin-bottom: 0;
}

.about-manifesto-aside {
  padding: 34px 28px;
}

.about-manifesto-aside h3 {
  margin: 0 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.about-manifesto-aside ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.about-manifesto-aside li {
  padding: 13px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
  font-size: 16px;
  font-weight: 700;
}

.about-manifesto-aside li::before {
  content: "✦ ";
  color: var(--purple);
}

/* Pilares */

.about-pillars {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.about-title-row {
  margin-bottom: 18px;
}

.about-pillar-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.about-pillar-card {
  min-height: 240px;
  padding: 28px 24px;
  text-align: center;
}

.about-pillar-card__icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.about-pillar-card h3,
.about-value-card strong,
.about-timeline-card h3,
.about-creator-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 21px;
  line-height: 1;
  text-transform: uppercase;
}

.about-pillar-card p,
.about-value-card p,
.about-timeline-card p,
.about-creator-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15.5px;
  line-height: 1.38;
}

/* Criador */

.about-creator {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 42px 46px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: 34px;
  align-items: center;
}

.about-creator-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 46px;
  line-height: 0.95;
  text-transform: uppercase;
}

.about-creator-copy p {
  max-width: 820px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.about-creator-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px;
}

.about-creator-card {
  padding: 30px 24px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.12);
}

.about-creator-icon {
  width: 82px;
  height: 82px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  font-weight: 900;
}

/* Valores + ecossistema */

.about-values,
.about-ecosystem {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.about-values-header,
.about-ecosystem-header {
  text-align: center;
  margin-bottom: 24px;
}

.about-values-header h2,
.about-ecosystem-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.about-values-header p,
.about-ecosystem-header p {
  max-width: 760px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.about-value-grid,
.about-timeline-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.about-value-card,
.about-timeline-card {
  padding: 24px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.about-value-card strong {
  display: block;
  color: var(--purple);
}

.about-timeline-card span {
  width: 52px;
  height: 52px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  font-weight: 900;
}

/* CTA final */

.about-final-cta {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
}

.about-final-cta h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.about-final-cta p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.about-final-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Responsivo */

@media (max-width: 1300px) {
  .about-manifesto,
  .about-creator,
  .about-final-cta,
  .about-hero-card {
    grid-template-columns: 1fr;
  }

  .about-pillar-grid,
  .about-value-grid,
  .about-timeline-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-hero-art {
    display: none;
  }
}

@media (max-width: 900px) {
  .about-page .about-hero {
    padding: 36px 20px 28px;
  }

  .about-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .about-hero-copy h1 {
    font-size: 46px;
  }

  .about-hero-copy p,
  .about-manifesto-card p,
  .about-creator-copy p {
    font-size: 18px;
  }

  .about-manifesto,
  .about-pillars {
    padding-left: 20px;
    padding-right: 20px;
  }

  .about-creator,
  .about-values,
  .about-ecosystem,
  .about-final-cta {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .about-manifesto-card,
  .about-manifesto-aside {
    padding: 28px 22px;
  }

  .about-manifesto-card h2,
  .about-creator-copy h2,
  .about-values-header h2,
  .about-ecosystem-header h2 {
    font-size: 32px;
  }

  .about-pillar-grid,
  .about-value-grid,
  .about-timeline-grid {
    grid-template-columns: 1fr;
  }

  .about-final-actions,
  .about-final-actions .lg-btn,
  .about-creator-actions .lg-btn {
    width: 100%;
  }
}

/* ================================================= */
/* SOBRE - BLOCO MAX RODRIGUES COM FOTO */
/* versão limpa, sem corte e sem caixas duplicadas */
/* Caminho da imagem: assets/about/max-rodrigues.png */
/* ================================================= */

/* Estrutura geral da área */
.about-creator.about-creator-with-photo {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 430px);
  gap: 52px;
  align-items: center;

  position: relative;
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 86% 16%, rgba(86, 32, 129, 0.045), transparent 34%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

/* Moldura interna única da seção */
.about-creator.about-creator-with-photo::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
  z-index: 1;
}

.about-creator.about-creator-with-photo > * {
  position: relative;
  z-index: 2;
}

/* Coluna de texto */
.about-creator-with-photo .about-creator-copy {
  max-width: 900px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.about-creator-with-photo .about-creator-copy .section-kicker {
  margin-bottom: 18px;
}

.about-creator-with-photo .about-creator-copy h2 {
  margin: 0 0 22px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4vw, 64px);
  line-height: 0.95;
  font-weight: 900;
  letter-spacing: -0.035em;
  text-transform: uppercase;
}

.about-creator-with-photo .about-creator-copy p {
  max-width: 840px;
  margin: 0 0 20px;

  color: rgba(43, 26, 16, 0.86);
  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 21px;
  line-height: 1.44;
}

.about-creator-with-photo .about-creator-copy p:last-of-type {
  margin-bottom: 0;
}

.about-creator-with-photo .about-creator-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 34px;
}

/* Coluna da foto, sem card dentro de card */
.about-creator-photo-card {
  width: 100%;
  max-width: 430px;
  justify-self: center;

  position: relative;
  padding: 0;

  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;

  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

/* Remove molduras antigas da coluna */
.about-creator-photo-card::before,
.about-creator-photo-card::after {
  display: none !important;
}

/* Foto */
.about-creator-photo-card figure {
  width: 100%;
  margin: 0;

  position: relative;

  display: block;

  border: 1px solid rgba(164, 112, 52, 0.42);
  background: rgba(255, 246, 222, 0.10);
  box-shadow:
    0 16px 26px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.18);

  overflow: hidden;
}

/* Desliga véus antigos que davam sensação de corte */
.about-creator-photo-card figure::before,
.about-creator-photo-card figure::after {
  display: none !important;
}

/* Imagem sem corte */
.about-creator-photo-card img {
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: none !important;

  display: block !important;

  object-fit: contain !important;
  object-position: center !important;

  filter:
    saturate(0.98)
    contrast(1.02)
    drop-shadow(0 12px 18px rgba(43, 26, 16, 0.10));
}

/* Legenda sem caixa duplicada */
.about-creator-photo-caption {
  width: 100%;
  padding: 0 8px;

  position: relative;
  text-align: center;

  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.about-creator-photo-caption::before {
  content: "";
  display: block;

  width: 78%;
  height: 1px;
  margin: 2px auto 18px;

  background: linear-gradient(
    to right,
    transparent,
    rgba(164, 112, 52, 0.46),
    transparent
  );
}

.about-creator-photo-caption span {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: fit-content;
  min-height: 28px;
  margin: 0 auto 12px;
  padding: 0 12px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.about-creator-photo-caption h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  font-weight: 900;
  text-transform: uppercase;
}

.about-creator-photo-caption p {
  max-width: 330px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 16px;
  line-height: 1.34;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .about-creator.about-creator-with-photo {
    grid-template-columns: 1fr;
    gap: 38px;
  }

  .about-creator-photo-card {
    max-width: 520px;
  }

  .about-creator-with-photo .about-creator-copy {
    max-width: none;
  }
}

@media (max-width: 900px) {
  .about-creator.about-creator-with-photo {
    width: calc(100% - 40px);
    padding: 34px 24px;
  }

  .about-creator-with-photo .about-creator-copy h2 {
    font-size: 38px;
  }

  .about-creator-with-photo .about-creator-copy p {
    font-size: 18px;
  }

  .about-creator-with-photo .about-creator-actions {
    width: 100%;
  }

  .about-creator-with-photo .about-creator-actions .lg-btn {
    width: 100%;
  }

  .about-creator-photo-card {
    max-width: 440px;
  }
}

@media (max-width: 640px) {
  .about-creator.about-creator-with-photo {
    width: calc(100% - 32px);
    padding: 30px 20px;
  }

  .about-creator-photo-caption h3 {
    font-size: 23px;
  }

  .about-creator-photo-caption p {
    font-size: 14.5px;
  }
}

/* ================================================= */
/* LIVES - WP READY */
/* Página de lives, links sociais e VODs */
/* Cole no final do style.css */
/* ================================================= */

.lives-page .lives-hero {
  padding: 58px 56px 32px;
}

.lives-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.lives-breadcrumb a {
  text-decoration: none;
}

.lives-breadcrumb a:hover {
  color: var(--purple);
}

.lives-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.lives-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.lives-hero-card > * {
  position: relative;
  z-index: 2;
}

.lives-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.lives-hero-copy p {
  max-width: 800px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.lives-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.lives-hero-panel {
  padding: 30px 26px;

  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.14);
}

.lives-hero-panel__icon {
  width: 76px;
  height: 76px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;
  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.lives-hero-panel h2 {
  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-hero-panel p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.38;
}

/* ================================================= */
/* LINKS DAS PLATAFORMAS */
/* ================================================= */

.lives-platforms,
.vod-gallery {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.lives-title-row {
  margin-bottom: 18px;
}

.lives-platform-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.lives-platform-card {
  position: relative;
  min-height: 210px;
  padding: 28px 22px;

  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 16px;
  justify-items: center;

  color: var(--ink);
  text-align: center;
  text-decoration: none;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 8%, rgba(86, 32, 129, 0.06), transparent 34%),
    rgba(255, 246, 222, 0.13);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    0 12px 22px rgba(43, 26, 16, 0.04);

  overflow: hidden;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.lives-platform-card::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.lives-platform-card > * {
  position: relative;
  z-index: 2;
}

.lives-platform-card:hover {
  transform: translateY(-4px);
  background:
    radial-gradient(circle at 50% 8%, rgba(86, 32, 129, 0.10), transparent 34%),
    rgba(255, 246, 222, 0.16);
  box-shadow: 0 16px 26px rgba(43, 26, 16, 0.10);
}

.lives-platform-card__icon {
  width: 66px;
  height: 66px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  font-weight: 900;

  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.lives-platform-card__copy strong {
  display: block;
  margin-bottom: 6px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-platform-card__copy small {
  display: block;
  margin-bottom: 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lives-platform-card__copy em {
  display: block;
  max-width: 240px;

  color: rgba(43, 26, 16, 0.76);
  font-size: 15px;
  font-style: normal;
  line-height: 1.34;
}

.lives-platform-card__arrow {
  color: var(--purple);
  font-size: 24px;
  font-weight: 900;
}

/* ================================================= */
/* ÚLTIMO VOD EM DESTAQUE */
/* ================================================= */

.latest-vod-feature {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 40px;

  display: grid;
  grid-template-columns: minmax(0, 0.75fr) minmax(480px, 1.25fr);
  gap: 28px;
  align-items: center;

  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.13);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.latest-vod-feature::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.latest-vod-feature > * {
  position: relative;
  z-index: 2;
}

.latest-vod-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(34px, 3.4vw, 52px);
  line-height: 0.95;
  text-transform: uppercase;
}

.latest-vod-copy p {
  max-width: 620px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 19px;
  line-height: 1.42;
}

.latest-vod-embed {
  width: 100%;
}

.latest-vod-placeholder {
  aspect-ratio: 16 / 9;
  width: 100%;
  min-height: 300px;

  display: grid;
  place-items: center;
  align-content: center;
  gap: 12px;

  text-align: center;
  color: #f8e7bd;

  border: 1px solid #9f743f;
  background:
    radial-gradient(circle at 50% 20%, rgba(86, 32, 129, 0.36), transparent 36%),
    linear-gradient(135deg, rgba(22, 8, 20, 0.98), rgba(43, 26, 16, 0.94));
  box-shadow:
    inset 0 0 0 1px rgba(255, 243, 214, 0.15),
    0 18px 28px rgba(43, 26, 16, 0.18);
}

.latest-vod-placeholder span {
  width: 78px;
  height: 78px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;
}

.latest-vod-placeholder strong {
  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  text-transform: uppercase;
}

.latest-vod-placeholder small {
  max-width: 420px;
  color: rgba(248, 231, 189, 0.76);
  font-size: 15px;
  line-height: 1.34;
}

/* ================================================= */
/* GALERIA VOD */
/* ================================================= */

.vod-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.vod-card {
  position: relative;
  min-width: 0;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    0 12px 22px rgba(43, 26, 16, 0.04);
  overflow: hidden;
}

.vod-card::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
  z-index: 2;
}

.vod-card__thumb {
  position: relative;
  min-height: 205px;
  display: flex;
  align-items: center;
  justify-content: center;

  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.78), rgba(20, 10, 5, 0.10)),
    var(--vod-thumb);
  background-size: cover;
  background-position: center;

  text-decoration: none;
}

.vod-card__play {
  width: 62px;
  height: 62px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 24px;

  box-shadow:
    0 10px 20px rgba(0, 0, 0, 0.30),
    inset 0 0 0 1px rgba(255, 255, 255, 0.18);
}

.vod-card__duration {
  position: absolute;
  right: 14px;
  bottom: 14px;

  min-height: 28px;
  padding: 0 10px;

  display: inline-flex;
  align-items: center;

  color: var(--cream);
  background: rgba(20, 10, 5, 0.82);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.vod-card__copy {
  position: relative;
  z-index: 3;
  padding: 22px 22px 24px;
}

.vod-card__copy .post-category {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin-bottom: 14px;
}

.vod-card__copy h3 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1.05;
  text-transform: uppercase;
}

.vod-card__copy p {
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.76);
  font-size: 15.5px;
  line-height: 1.36;
}

.vod-card__copy a {
  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

/* ================================================= */
/* PROGRAMAÇÃO */
/* ================================================= */

.lives-schedule {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;

  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 0%, rgba(86, 32, 129, 0.05), transparent 34%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.lives-schedule::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.lives-schedule > * {
  position: relative;
  z-index: 2;
}

.lives-schedule-header {
  margin-bottom: 24px;
  text-align: center;
}

.lives-schedule-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-schedule-header p {
  max-width: 720px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.lives-schedule-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.lives-schedule-card {
  padding: 24px 20px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.lives-schedule-card span {
  display: inline-flex;
  min-height: 28px;
  margin-bottom: 14px;
  padding: 0 10px;
  align-items: center;
  justify-content: center;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.lives-schedule-card h3 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-schedule-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.34;
}

/* ================================================= */
/* CTA COMUNIDADE */
/* ================================================= */

.lives-community-cta {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;

  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 80%, rgba(184, 137, 72, 0.10), transparent 36%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.lives-community-cta::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.lives-community-cta > * {
  position: relative;
  z-index: 2;
}

.lives-community-cta h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-community-cta p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.lives-community-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .lives-hero-card,
  .latest-vod-feature,
  .lives-community-cta {
    grid-template-columns: 1fr;
  }

  .lives-platform-grid,
  .vod-gallery-grid,
  .lives-schedule-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .latest-vod-feature {
    padding: 34px;
  }
}

@media (max-width: 900px) {
  .lives-page .lives-hero {
    padding: 36px 20px 28px;
  }

  .lives-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .lives-hero-copy h1 {
    font-size: 46px;
  }

  .lives-hero-copy p,
  .latest-vod-copy p {
    font-size: 18px;
  }

  .lives-platforms,
  .vod-gallery {
    padding-left: 20px;
    padding-right: 20px;
  }

  .latest-vod-feature,
  .lives-schedule,
  .lives-community-cta {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .lives-platform-grid,
  .vod-gallery-grid,
  .lives-schedule-grid {
    grid-template-columns: 1fr;
  }

  .latest-vod-placeholder {
    min-height: 220px;
  }

  .lives-hero-actions .lg-btn,
  .lives-community-actions,
  .lives-community-actions .lg-btn {
    width: 100%;
  }
}


/* ================================================= */
/* AJUSTE FINAL - HOME COM 5 CATEGORIAS */
/* Filmes & Séries unificados */
/* ================================================= */

body.home .categories {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

@media (max-width: 900px) {
  body.home .categories {
    grid-template-columns: 1fr;
  }
}

/* ================================================= */
/* REVIEW SIDEBAR - GATINHOS DO VEREDITO RÁPIDO */
/* Corrige ícones gigantes/quebrados na lateral */
/* ================================================= */

.review-sidebar .quick-verdict-card {
  overflow: hidden;
}

.review-sidebar .sidebar-kicker {
  position: relative;
  z-index: 2;
}

.review-sidebar .quick-verdict-rating {
  position: relative;
  z-index: 2;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;

  width: 100%;
  margin: 18px auto 22px;
  text-align: center;
}

.review-sidebar .rating-cats-sidebar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  gap: 6px;

  width: auto;
  max-width: 100%;
  line-height: 0;
}

.review-sidebar .rating-cats-sidebar img {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px;
  max-width: 28px !important;

  display: block;
  object-fit: contain;

  filter: drop-shadow(0 2px 2px rgba(43, 26, 16, 0.20));
}

.review-sidebar .quick-verdict-rating strong {
  display: block;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

@media (max-width: 700px) {
  .review-sidebar .rating-cats-sidebar img {
    width: 25px !important;
    height: 25px !important;
    min-width: 25px;
    max-width: 25px !important;
  }
}

/* ================================================= */
/* REVIEW - RELACIONADAS COM TAMANHO CONTROLADO */
/* Corrige cards relacionados gigantes em páginas single */
/* ================================================= */

.review-page .related-carousel-section {
  overflow: hidden;
}

.review-page .related-carousel-wrap {
  width: 100%;
  max-width: 100%;
}

.review-page .related-carousel {
  width: 100%;
  max-width: 100%;

  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 220px));
  justify-content: center;
  gap: 18px;
}

.review-page .mini-review-card {
  width: 100%;
  max-width: 220px;
  min-height: 0;

  aspect-ratio: 3 / 4;

  justify-self: center;
  align-self: stretch;

  background-size: cover;
  background-position: center;
}

/* Caso a seção tenha apenas 1 ou 2 cards, impede que eles virem banners gigantes */
.review-page .related-carousel:has(.mini-review-card:first-child:last-child) {
  grid-template-columns: minmax(170px, 220px);
}

.review-page .related-carousel:has(.mini-review-card:nth-child(2):last-child) {
  grid-template-columns: repeat(2, minmax(170px, 220px));
}

/* Compatibilidade: se o navegador não suportar :has, o max-width do card acima já segura o layout */

.review-page .mini-review-card h3 {
  font-size: 16px;
  line-height: 1.04;
}

.review-page .mini-review-card .post-category {
  top: 12px;
  left: 12px;
}

@media (max-width: 900px) {
  .review-page .related-carousel {
    grid-template-columns: repeat(auto-fit, minmax(160px, 220px));
  }

  .review-page .mini-review-card {
    max-width: 220px;
  }
}

@media (max-width: 520px) {
  .review-page .related-carousel {
    grid-template-columns: minmax(0, 260px);
  }

  .review-page .mini-review-card {
    max-width: 260px;
  }
}

/* ================================================= */
/* REVIEW - RELACIONADAS HORIZONTAIS E LINK SEGURO */
/* Corrige cards empilhados e "ver todas" escapando */
/* ================================================= */

.review-page .related-carousel-section {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 30px 34px;

  overflow: hidden;
}

.review-page .related-carousel-section .related-title-row,
.review-page .related-carousel-section .section-title-row {
  width: 100%;
  max-width: 100%;

  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;

  margin-bottom: 22px;
}

.review-page .related-carousel-section .related-title-row h2,
.review-page .related-carousel-section .section-title-row h2 {
  min-width: 0;
  margin: 0;

  overflow-wrap: anywhere;
}

.review-page .related-carousel-section .see-all,
.review-page .related-carousel-section .info-link {
  flex: 0 0 auto;
  margin-left: auto;
  max-width: 45%;

  white-space: nowrap;
  text-align: right;
}

/* Desativa o layout antigo de carrossel com setas para evitar colunas fantasmas */
.review-page .related-carousel-section .related-carousel-wrap {
  width: 100%;
  max-width: 100%;

  display: block !important;
}

.review-page .related-carousel-section .related-arrow {
  display: none !important;
}

/* Desktop/tablet: cards lado a lado */
.review-page .related-carousel-section .related-carousel {
  width: 100%;
  max-width: 100%;

  display: grid !important;
  grid-template-columns: repeat(3, minmax(170px, 220px)) !important;
  justify-content: center;
  align-items: stretch;
  gap: 18px;
}

.review-page .related-carousel-section .mini-review-card {
  width: 100% !important;
  max-width: 220px !important;
  min-width: 0 !important;

  aspect-ratio: 3 / 4;
  justify-self: center;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* Quando houver 4 ou 5 cards, permite mais colunas em telas amplas */
@media (min-width: 1280px) {
  .review-page .related-carousel-section .related-carousel {
    grid-template-columns: repeat(auto-fit, minmax(170px, 220px)) !important;
  }
}

/* Tablet pequeno: 2 colunas */
@media (max-width: 900px) {
  .review-page .related-carousel-section {
    width: calc(100% - 40px);
    padding: 26px 22px 30px;
  }

  .review-page .related-carousel-section .related-carousel {
    grid-template-columns: repeat(2, minmax(150px, 220px)) !important;
  }

  .review-page .related-carousel-section .see-all,
  .review-page .related-carousel-section .info-link {
    max-width: 50%;
  }
}

/* Mobile: empilha de propósito, mas sem quebrar o título/link */
@media (max-width: 560px) {
  .review-page .related-carousel-section .related-title-row,
  .review-page .related-carousel-section .section-title-row {
    align-items: flex-start;
    flex-direction: column;
    gap: 10px;
  }

  .review-page .related-carousel-section .see-all,
  .review-page .related-carousel-section .info-link {
    max-width: 100%;
    margin-left: 0;
    text-align: left;
  }

  .review-page .related-carousel-section .related-carousel {
    grid-template-columns: minmax(0, 260px) !important;
  }

  .review-page .related-carousel-section .mini-review-card {
    max-width: 260px !important;
  }
}

/* ================================================= */
/* REVIEW - RELATED-GRID / RELATED-REVIEWS */
/* Corrige a estrutura real do HTML de posts/the-last-of-us.html */
/* O HTML usa .related-reviews e .related-grid, não .related-carousel */
/* ================================================= */

.review-page .related-reviews {
  position: relative;

  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.045), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);

  overflow: hidden;
}

.review-page .related-reviews::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.review-page .related-reviews > * {
  position: relative;
  z-index: 2;
}

.review-page .related-reviews .section-title-row {
  width: 100%;
  max-width: 100%;

  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;

  margin: 0 0 22px;
}

.review-page .related-reviews .section-title-row h2 {
  min-width: 0;
  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.review-page .related-reviews .see-all {
  flex: 0 0 auto;
  margin-left: auto;

  max-width: 45%;
  white-space: nowrap;
  text-align: right;
}

/* AQUI É O PULO DO GATO:
   o HTML real usa .related-grid */
.review-page .related-grid {
  width: 100%;
  max-width: 100%;

  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(170px, 220px)) !important;
  justify-content: center;
  align-items: stretch;
  gap: 18px;
}

.review-page .related-grid .mini-review-card {
  width: 100% !important;
  max-width: 220px !important;
  min-width: 0 !important;

  aspect-ratio: 3 / 4;
  justify-self: center;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;

  background-size: cover;
  background-position: center;
}

.review-page .related-grid .mini-review-card h3 {
  font-size: 16px;
  line-height: 1.04;
}

.review-page .related-grid .mini-review-card .post-category {
  top: 12px;
  left: 12px;
}

@media (max-width: 900px) {
  .review-page .related-reviews {
    width: calc(100% - 40px);
    padding: 26px 22px 30px;
  }

  .review-page .related-grid {
    grid-template-columns: repeat(2, minmax(150px, 220px)) !important;
  }

  .review-page .related-reviews .see-all {
    max-width: 50%;
  }
}

@media (max-width: 560px) {
  .review-page .related-reviews .section-title-row {
    align-items: flex-start;
    flex-direction: column;
    gap: 10px;
  }

  .review-page .related-reviews .see-all {
    max-width: 100%;
    margin-left: 0;
    text-align: left;
  }

  .review-page .related-grid {
    grid-template-columns: minmax(0, 260px) !important;
  }

  .review-page .related-grid .mini-review-card {
    max-width: 260px !important;
  }
}

/* ================================================= */
/* RODADA 2B - HOME/ARCHIVES WP READY */
/* index.html => front-page.php */
/* noticias.html => archive-noticia.php */
/* guias.html => archive-guia.php */
/* Sem alterações visuais nesta rodada */
/* ================================================= */

/* ================================================= */
/* WP HOTFIX v0.1.1 - ajustes de fidelidade visual */
/* ================================================= */

/* Remove bolinhas/list-style que o wp_nav_menu cria com <li> */
.primary-nav ul,
.primary-nav li,
.primary-nav .menu,
.primary-nav .primary-menu {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.primary-nav ul,
.primary-nav .menu,
.primary-nav .primary-menu {
  display: flex !important;
  justify-content: center;
  align-items: center;
  gap: 28px;
}

.primary-nav li {
  display: inline-flex !important;
  align-items: center;
}

/* Garante marcador roxo no item ativo do menu WordPress */
.primary-nav li.current-menu-item > a,
.primary-nav li.current-menu-ancestor > a,
.primary-nav a.active {
  color: var(--purple);
}

.primary-nav li.current-menu-item > a::after,
.primary-nav li.current-menu-ancestor > a::after,
.primary-nav a.active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -20px;
  width: 42px;
  height: 8px;
  transform: translateX(-50%);
  background: var(--purple);
  clip-path: polygon(0 35%, 42% 35%, 50% 100%, 58% 35%, 100% 35%, 100% 0, 0 0);
}

/* Afasta breadcrumb do bloco da logo no single review */
.single-review .review-hero {
  margin-top: 34px;
}

.single-review .review-hero .breadcrumb {
  margin-top: 12px;
}

/* Meio gatinho robusto, sem depender de arquivo cat-half.png */
.rating-cats .cat-icon {
  position: relative;
  display: inline-block;
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
}

.rating-cats-large .cat-icon {
  width: 34px;
  height: 34px;
}

.rating-cats-medium .cat-icon {
  width: 32px;
  height: 32px;
}

.rating-cats-small .cat-icon {
  width: 20px;
  height: 20px;
}

.rating-cats-sidebar .cat-icon {
  width: 28px;
  height: 28px;
}

.rating-cats .cat-icon img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
}

.rating-cats .cat-half .cat-empty-base {
  z-index: 1;
}

.rating-cats .cat-half .cat-full-half {
  z-index: 2;
  clip-path: inset(0 50% 0 0);
}

/* Logo HBO/loja precisa ter presença visual quando vier do fallback */
.streaming-logo-image img {
  max-width: 190px;
  width: auto;
  height: auto;
  margin: 0 auto 18px;
  object-fit: contain;
}

.watch-box .available-list:empty {
  display: none;
}

/* Hero art fallback: mantém o pôster/hero no espaço correto */
.review-hero-art img {
  display: block;
}

@media (max-width: 980px) {
  .single-review .review-hero {
    margin-top: 12px;
  }

  .primary-nav ul,
  .primary-nav .menu,
  .primary-nav .primary-menu {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
}

/* ================================================= */
/* WP HOTFIX v0.1.2 - fidelidade single audiovisual */
/* ================================================= */

/* Header com respiro semelhante ao HTML aprovado */
.topbar.site-header {
  min-height: 155px;
  padding-top: 18px;
  padding-bottom: 10px;
  align-items: center;
}

.site-logo,
.logo {
  align-self: center;
}

.site-logo img,
.logo img {
  display: block;
}

/* Breadcrumb fora da área da logo, com respiro real */
.single-review .review-hero {
  margin-top: 18px;
}

.single-review .review-hero .breadcrumb {
  margin-top: 0;
  margin-bottom: 22px;
}

/* Hero art: garante presença e alinhamento quando a imagem existir */
.single-review .review-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(360px, 1.08fr);
  align-items: center;
  gap: 34px;
}

.single-review .review-hero-copy {
  min-width: 0;
}

.single-review .review-hero-art {
  align-self: center;
  justify-self: center;
  width: 100%;
  min-height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.single-review .review-hero-art img {
  width: 100%;
  max-height: 520px;
  object-fit: contain;
}

/* Nome correto do bloco audiovisual */
.audiovisual-review .watch-box h2,
.single-review[data-review-kind="audiovisual"] .watch-box h2 {
  text-transform: uppercase;
}

/* Devices oficiais abaixo do botão */
.watch-box .available-list {
  margin-top: 22px;
}

.watch-box .device {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  min-width: 58px;
}

.watch-box .device img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

/* Logo HBO Max mais próxima do aprovado */
.streaming-logo-image {
  min-height: 72px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.streaming-logo-image img {
  max-width: 170px;
  margin: 0 auto 18px;
}

/* Meio gatinho direto ou composto */
.rating-cats img {
  display: block;
}

.rating-cats .cat-icon {
  position: relative;
  display: inline-block;
  flex: 0 0 auto;
}

.rating-cats-large .cat-icon { width: 32px; height: 32px; }
.rating-cats-medium .cat-icon { width: 28px; height: 28px; }
.rating-cats-small .cat-icon { width: 18px; height: 18px; }
.rating-cats-sidebar .cat-icon { width: 24px; height: 24px; }

.rating-cats .cat-icon img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
}

.rating-cats .cat-half .cat-full-half {
  clip-path: inset(0 50% 0 0);
}

/* Quote lateral aprovado */
.review-quote-section {
  width: 100%;
}

.quote-card.premium-quote {
  position: relative;
  min-height: 190px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.quote-card.premium-quote::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("assets/icons/quote-bg.png");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 1;
  pointer-events: none;
}

.quote-card .quote-frame {
  position: relative;
  z-index: 2;
  max-width: 245px;
  margin: 0 auto;
  text-align: center;
}

.review-quote-text {
  margin: 0 0 10px;
}

.review-quote-author {
  display: block;
}

/* Reviews relacionadas não encostam no rodapé */
.related-reviews {
  margin-bottom: 46px;
}

@media (max-width: 1000px) {
  .single-review .review-hero {
    grid-template-columns: 1fr;
  }

  .single-review .review-hero-art {
    min-height: 260px;
  }
}

/* ================================================= */
/* WP HOTFIX v0.1.3 - fidelidade ao single aprovado */
/* ================================================= */

/* O CSS original depende do body.review-page; o WP precisa disso para ativar o layout certo. */
body.review-page .review-hero {
  margin-top: 54px !important;
}

/* Breadcrumb com respiro real abaixo da logo/header */
body.review-page .review-hero .breadcrumb {
  margin-top: 0 !important;
  margin-bottom: 22px !important;
}

/* Mantém a logo respirando no topo, sem encostar na hero */
body.review-page .topbar.site-header {
  margin-bottom: 18px;
}

/* Cancela o fundo duplicado que entrou no hotfix anterior.
   No HTML aprovado o fundo fica no .quote-frame, não no ::before do card. */
.quote-card.premium-quote::before {
  content: none !important;
  background: none !important;
}

/* Garante que o quote use apenas o bg oficial do HTML aprovado */
.premium-quote .quote-frame {
  background-image: url("assets/icons/quote-bg.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
}

/* Onde assistir precisa mostrar logo e devices no audiovisual */
body.review-page .watch-box[data-watch-platform="hbomax"] h2 {
  text-transform: uppercase;
}

body.review-page .watch-box[data-watch-platform="hbomax"] .streaming-logo-image {
  min-height: 112px !important;
  margin: 8px auto 22px !important;
}

body.review-page .watch-box[data-watch-platform="hbomax"] .streaming-logo-image img {
  width: 300px !important;
  max-width: 82% !important;
  max-height: 112px !important;
  object-fit: contain !important;
  display: block !important;
}

body.review-page .watch-box[data-watch-platform="hbomax"] .available-list {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
}

/* Esconde o kicker extra que não existe no layout aprovado, caso algum cache ainda mostre */
.related-reviews .section-kicker {
  display: none !important;
}

/* Compact coven abaixo de relacionadas, como no HTML aprovado */
body.review-page .compact-coven {
  margin-top: 0;
}

/* Fallback de relacionados não deve parecer mensagem de erro */
.related-empty-note {
  grid-column: 1 / -1;
  text-align: center;
  font-weight: 700;
  color: rgba(43, 26, 16, 0.72);
}

/* Se o WordPress não tiver posts relacionados, cards placeholder seguem o mesmo layout aprovado */
.mini-review-card.is-placeholder {
  pointer-events: none;
}

/* Meio gatinho com arquivo real ou fallback composto */
.rating-cats .cat-icon {
  position: relative;
  display: inline-block;
  flex: 0 0 auto;
}

.rating-cats-large .cat-icon { width: 34px; height: 34px; }
.rating-cats-medium .cat-icon { width: 32px; height: 32px; }
.rating-cats-small .cat-icon { width: 20px; height: 20px; }
.rating-cats-sidebar .cat-icon { width: 28px; height: 28px; }

.rating-cats .cat-icon img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
}

.rating-cats .cat-half .cat-full-half {
  clip-path: inset(0 50% 0 0);
}

/* ================================================= */
/* WP HOTFIX v0.1.4 - quote aprovado + relacionados reais */
/* ================================================= */

/* Quote no tamanho do HTML aprovado, sem fundo pequeno ou duplicado */
.review-quote-section {
  width: 100%;
}

.quote-card.premium-quote {
  min-height: 278px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.quote-card.premium-quote::before,
.quote-card.premium-quote::after {
  content: none !important;
  display: none !important;
}

.premium-quote .quote-frame {
  width: min(100%, 390px) !important;
  min-height: 248px !important;
  max-width: 390px !important;
  padding: 58px 58px 52px !important;
  margin: 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  background-image: url("assets/icons/quote-bg.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 100% 100% !important;
  text-align: center !important;
}

.review-quote-text {
  max-width: 250px !important;
  margin: 0 auto 12px !important;
  font-style: italic;
  line-height: 1.25;
}

.review-quote-author {
  display: block;
  margin-top: 6px;
  font-family: var(--font-title);
  font-size: 12px;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Relacionados sempre clicáveis, puxados de posts reais */
.related-grid .mini-review-card {
  pointer-events: auto !important;
}

.related-grid .mini-review-card.is-placeholder {
  display: none !important;
}

.related-empty-note {
  grid-column: 1 / -1;
  text-align: center;
  padding: 28px;
  border: 1px solid var(--line-soft);
}

/* ================================================= */
/* WP v0.1.5 - Single review game conforme HTML aprovado */
/* ================================================= */

body.game-review .game-support-share a[href="https://discord.gg/tts6wdX"],
body.game-review .game-discord-box a[href="https://discord.gg/tts6wdX"] {
  pointer-events: auto;
}

body.game-review .game-related-section .related-grid .mini-review-card {
  pointer-events: auto !important;
}

/* Mantém área de relacionados real sem placeholders fake */
body.game-review .game-related-section .related-empty-note {
  grid-column: 1 / -1;
  padding: 28px;
  text-align: center;
  border: 1px solid var(--line-soft);
  font-weight: 700;
}

/* Garante que a capa vertical respeite o card aprovado */
body.game-review .game-cover-card img {
  object-fit: cover;
}

/* Pequeno respiro para evitar colagem com header em WP */
body.game-review .game-hero {
  margin-top: 42px;
}

/* ================================================= */
/* WP v0.1.6 - Onde assistir: logo sem imagem destacada */
/* ================================================= */

.watch-box .streaming-logo-image img {
  object-fit: contain !important;
  background: transparent !important;
}

/* Caso o logo não exista, a área não deve mostrar capa/featured image por engano */
.watch-box .streaming-logo-image:empty {
  display: none !important;
}

/* ================================================= */
/* WP v0.1.7 - Plataforma principal automática */
/* ================================================= */

.watch-box[data-platform-selected] .streaming-logo-image img {
  object-fit: contain !important;
}

.watch-box .platform-note {
  margin-top: 14px;
  opacity: 0.78;
  font-size: 0.92em;
}

/* O bloco nunca deve usar imagem destacada como logo. Se não houver logo, some. */
.watch-box .streaming-logo-image:empty {
  display: none !important;
}

/* ================================================= */
/* WP v0.1.8 - Quote BG blindado por IMG real */
/* ================================================= */

/*
  A versão aprovada usa o ornamento como fundo visual do quote.
  No WordPress, background-image pode falhar se o asset não estiver copiado.
  Esta versão usa uma <img> real dentro do HTML, com fallback para o CSS.
*/
.quote-card.premium-quote {
  position: relative !important;
  min-height: 278px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  overflow: visible !important;
}

.premium-quote .quote-frame {
  position: relative !important;
  width: min(100%, 390px) !important;
  min-height: 248px !important;
  max-width: 390px !important;
  padding: 58px 58px 52px !important;
  margin: 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  text-align: center !important;
  z-index: 1 !important;
}

.premium-quote .quote-bg-img {
  position: absolute !important;
  inset: 50% auto auto 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 390px !important;
  max-width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  z-index: 0 !important;
  pointer-events: none !important;
  user-select: none !important;
}

.premium-quote .review-quote-text,
.premium-quote .review-quote-author {
  position: relative !important;
  z-index: 2 !important;
}

/* Fallback CSS caso a imagem inline não carregue por algum cache */
.premium-quote .quote-frame.no-inline-bg {
  background-image: url("assets/icons/quote-bg.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
}

/* ================================================= */
/* WP v0.2.0 - Pacote consolidado para revisão por página */
/* ================================================= */

/*
  Este pacote consolida:
  - Single audiovisual aprovado como base The Last of Us.
  - Single games baseado no HTML aprovado de Elden Ring.
  - Plataforma principal automática.
  - Discord oficial.
  - Quote com imagem inline.
  - Relacionados reais do WordPress.
*/

/* Segurança: não exibir placeholder fictício */
.mini-review-card.is-placeholder {
  display: none !important;
}

/* CTA Discord oficial, garantindo clique em qualquer bloco do Coven */
a[href="https://discord.gg/tts6wdX"] {
  pointer-events: auto;
}

/* Ajuste de quote consolidado */
.quote-card.premium-quote {
  position: relative !important;
  min-height: 278px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  overflow: visible !important;
}

.premium-quote .quote-frame {
  position: relative !important;
  width: min(100%, 390px) !important;
  min-height: 248px !important;
  max-width: 390px !important;
  padding: 58px 58px 52px !important;
  margin: 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  background: transparent !important;
  text-align: center !important;
  z-index: 1 !important;
}

.premium-quote .quote-bg-img {
  position: absolute !important;
  inset: 50% auto auto 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 390px !important;
  max-width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  z-index: 0 !important;
  pointer-events: none !important;
  user-select: none !important;
}

.premium-quote .review-quote-text,
.premium-quote .review-quote-author {
  position: relative !important;
  z-index: 2 !important;
}

/* Área de plataforma: nunca usa imagem destacada por engano */
.watch-box .streaming-logo-image:empty {
  display: none !important;
}

.watch-box .streaming-logo-image img {
  object-fit: contain !important;
}


/* FULL SITE STATIC CSS IMPORT - HTML aprovado */
/* ============================= */
/* LEGOLAS GEEK - CSS FINAL */
/* ============================= */

:root {
  --bg: #f3e4c7;
  --paper: #f6e8cb;
  --cream: #fff3d6;
  --ink: #24150f;
  --text: #2b1a10;
  --muted: rgba(43, 26, 16, 0.74);
  --line: rgba(164, 112, 52, 0.48);
  --line-soft: rgba(164, 112, 52, 0.18);
  --purple: #562081;
  --purple-dark: #371052;
  --gold: #b88948;
  --green: #315b2d;
  --red: #8a2c25;
  --card-dark: #160904;
  --shadow: 0 14px 32px rgba(43, 26, 16, 0.08);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--text);
  background: #070407;
  font-family: Georgia, "Times New Roman", serif;
}

a {
  color: inherit;
}

img {
  max-width: 100%;
  display: block;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.page {
  width: calc(100% - 48px);
  max-width: 1920px;
  margin: 0 auto;
  min-height: 100vh;
  overflow: hidden;
  background-color: var(--bg);
  background-image: url("assets/bg-pergaminho-legolas.png"), url("assets/bg-pergaminho.png");
  background-size: cover, 720px auto;
  background-position: top center, top center;
  background-repeat: repeat-y, repeat;
}

/* ============================= */
/* HEADER GLOBAL */
/* ============================= */

.topbar {
  height: 155px;
  padding: 0 56px;
  display: grid;
  grid-template-columns: 320px 1fr 250px;
  align-items: center;
  gap: 22px;
}

.logo {
  position: relative;
  z-index: 30;
  text-decoration: none;
}

.logo img {
  width: 260px;
  max-width: none;
}

.primary-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 28px;
}

.primary-nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
}

.primary-nav a img {
  width: 20px;
  height: 20px;
  object-fit: contain;
  opacity: 0.76;
}

.primary-nav a.active,
.primary-nav a:hover {
  color: var(--purple);
}

.primary-nav a.active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -20px;
  width: 42px;
  height: 8px;
  transform: translateX(-50%);
  background: var(--purple);
  clip-path: polygon(0 35%, 42% 35%, 50% 100%, 58% 35%, 100% 35%, 100% 0, 0 0);
}

.site-search {
  width: 250px;
  display: grid;
  grid-template-columns: 1fr 44px;
  justify-self: end;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.28);
}

.site-search input {
  min-width: 0;
  height: 48px;
  border: 0;
  padding: 0 14px;
  background: transparent;
  color: var(--ink);
  font: 700 12px Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  outline: 0;
}

.site-search button {
  border: 0;
  border-left: 1px solid rgba(164, 112, 52, 0.32);
  background: var(--purple);
  color: #fff;
  cursor: pointer;
}

/* ============================= */
/* BOTÕES */
/* ============================= */

.lg-btn {
  min-height: 52px;
  padding: 0 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  border: 1px solid var(--line);
  color: var(--ink);
  background: rgba(255, 246, 222, 0.08);
  font: 700 14px Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  text-decoration: none;
  transition: 0.2s ease;
}

.lg-btn:hover {
  transform: translateY(-2px);
}

.lg-btn-primary {
  background: var(--purple);
  border-color: var(--purple);
  color: var(--cream);
}

.lg-btn-outline:hover {
  background: var(--purple);
  border-color: var(--purple);
  color: var(--cream);
}

.lg-btn-small {
  min-height: 44px;
  padding: 0 18px;
  font-size: 13px;
}

/* ============================= */
/* HOME - HERO */
/* ============================= */

/*
  Hero da home isolado do template de review.
  Mantém a arte grande, mais centralizada e com respiro abaixo do menu.
*/

#home-hero {
  position: relative;
  min-height: 720px;
  padding: 32px 56px 78px;

  display: grid;
  grid-template-columns: minmax(500px, 0.88fr) minmax(650px, 1.12fr);
  gap: 18px;
  align-items: center;

  overflow: visible;
}

#home-hero .hero-text {
  position: relative;
  z-index: 5;

  max-width: 710px;
  transform: translateY(-4px);
}

#home-hero h1 {
  max-width: 710px;
  margin: 0 0 26px;

  color: var(--ink);
  font-size: clamp(58px, 5.15vw, 88px);
  line-height: 0.92;
  letter-spacing: -0.035em;
  text-transform: uppercase;
}

#home-hero p {
  max-width: 590px;
  margin: 0 0 30px;

  color: var(--ink);
  font-size: 21px;
  line-height: 1.36;
}

#home-hero .hero-buttons,
#home-hero .buttons {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 18px;
  flex-wrap: wrap;
}

/* Compatibilidade caso o index ainda use .hero-button */
#home-hero .hero-button {
  min-height: 52px;
  padding: 0 28px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  border: 1px solid var(--line);
  color: var(--ink);
  background: rgba(255, 246, 222, 0.08);

  font: 700 14px Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  text-decoration: none;

  transition: 0.2s ease;
}

#home-hero .hero-button:hover {
  transform: translateY(-2px);
}

#home-hero .hero-button-primary {
  background: var(--purple);
  border-color: var(--purple);
  color: var(--cream);
}

#home-hero .hero-button-secondary:hover {
  background: var(--purple);
  border-color: var(--purple);
  color: var(--cream);
}

#home-hero .hero-image {
  position: relative;
  z-index: 4;

  min-height: 590px;

  display: flex;
  align-items: center;
  justify-content: flex-end;

  overflow: visible;
  pointer-events: none;
}

#home-hero .hero-image img {
  width: min(1160px, 132%);
  max-width: none;
  height: auto;

  display: block;
  object-fit: contain;
  object-position: center right;

  transform: translateX(2%) translateY(18px);
}

/* Categorias logo depois do hero */
body.home .categories {
  position: relative;
  z-index: 6;
  margin-top: 0;
}

/* ============================= */
/* CATEGORIAS */
/* ============================= */

.categories {
  margin: 0 32px 30px;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  border: 1px solid var(--line);
}

.category-card {
  min-height: 118px;
  padding: 24px 18px;
  display: grid;
  grid-template-columns: 48px 1fr;
  align-content: center;
  column-gap: 16px;
  color: var(--ink);
  text-decoration: none;
  border-right: 1px solid var(--line);
}

.category-card:last-child {
  border-right: 0;
}

.category-card img {
  grid-row: 1 / 3;
  width: 34px;
  height: 34px;
  object-fit: contain;
  align-self: center;
}

.category-card strong {
  font-size: 16px;
  line-height: 1;
  text-transform: uppercase;
}

.category-card span {
  margin-top: 5px;
  font-size: 13px;
}

/* ============================= */
/* HOME - REVIEWS */
/* ============================= */

.review-area {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  margin: 0 32px 32px;
}

.live-card {
  position: relative;
  min-height: 390px;
  padding: 24px;
  isolation: isolate;
  overflow: hidden;
  color: var(--cream);
  background-image: linear-gradient(to top, rgba(19, 7, 4, 0.98), rgba(19, 7, 4, 0.62)), var(--live-bg);
  background-size: cover;
  background-position: center;
  border: 1px solid #9f743f;
}

.live-tag,
.post-category,
.review-label,
.section-kicker,
.article-kicker {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  padding: 7px 11px;
  color: var(--cream);
  background: var(--purple);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
}

.live-content {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
}

.live-theme {
  display: block;
  margin-bottom: 10px;
  color: #f8e7bd;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.live-card h2 {
  margin: 0 0 14px;
  color: #f8e7bd;
  font-size: 30px;
  line-height: 0.96;
  text-transform: uppercase;
}

.live-meta {
  display: flex;
  gap: 8px;
  margin: 0 0 18px;
}

.live-meta span {
  padding: 6px 8px;
  background: rgba(255, 246, 222, 0.12);
  border: 1px solid rgba(255, 246, 222, 0.22);
  color: #f8e7bd;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.twitch-button img {
  width: 18px;
  height: 18px;
}

.reviews {
  min-width: 0;
}

.section-title-row {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
}

.section-title-row h2 {
  margin: 0;
  color: var(--ink);
  font-size: 34px;
  line-height: 1;
  text-transform: uppercase;
}

.see-all,
.info-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  text-decoration: none;
}

.review-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.card,
.post-card {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  padding: 18px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  border: 1px solid #9f743f;
  border-radius: 8px;
  background-color: var(--card-dark);
  background-image: linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.84) 34%, rgba(20, 10, 5, 0.28) 68%, rgba(20, 10, 5, 0.06) 100%), var(--post-bg);
  background-size: cover;
  background-position: center;
}

.post-card:hover,
.mini-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.07);
}

.post-category {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
}

.post-card h3,
.mini-review-card h3 {
  margin: 0 0 6px;
  color: #f8e7bd;
  font-size: 19px;
  line-height: 1.04;
}

.post-excerpt {
  margin: 0 0 9px;
  color: #f8e7bd;
  font-size: 12px;
  text-transform: none;
}

.post-rating-icons,
.related-rating {
  display: flex;
  align-items: center;
  gap: 7px;
}

.rating-cats,
.rating-cats-card,
.rating-cats-small,
.rating-cats-feature {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  line-height: 0;
}

.rating-cats-card img,
.rating-cats-small img {
  width: 17px;
  height: 17px;
  object-fit: contain;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.35));
}

.post-rating-icons strong,
.related-rating strong {
  color: #f8e7bd;
  font-size: 13px;
  line-height: 1;
}

/* ============================= */
/* HOME - INFO, COVEN, FOOTER */
/* ============================= */

.info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin: 0 32px 34px;
}

.info-card,
.support-panel,
.partners-panel,
.social-panel,
.review-box,
.pros-cons-panel,
.article-body,
.related-carousel-section,
.quick-verdict-card,
.review-ad-card {
  position: relative;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.info-card {
  min-height: 250px;
  padding: 28px 26px;
}

.info-card h2,
.support-panel h2,
.partners-panel h2,
.social-panel h2,
.coven h2 {
  margin: 0 0 14px;
  color: var(--ink);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.info-card p,
.support-panel p,
.partners-panel p,
.social-panel p,
.coven p {
  margin: 0 0 18px;
  font-size: 15.5px;
  line-height: 1.45;
}

.calendar-card,
.coven-rating-card,
.social-panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.event-list,
.guide-list {
  display: grid;
  gap: 10px;
  width: 100%;
  margin: 14px 0 18px;
}

.event-card,
.guide-item {
  display: grid;
  grid-template-columns: 58px 1fr 34px;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--line-soft);
  text-align: left;
  text-decoration: none;
}

.event-date {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border: 1px solid var(--line);
}

.event-date strong {
  font-size: 19px;
  line-height: 1;
}

.event-date small,
.event-info small,
.guide-item small {
  font-size: 11px;
  color: var(--muted);
}

.event-info strong,
.guide-item strong {
  display: block;
  font-size: 13px;
  line-height: 1.22;
  text-transform: uppercase;
}

.event-platform img,
.guide-item img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.rating-cats-feature {
  justify-content: center;
  gap: 7px;
  margin: 10px 0 16px;
}

.rating-cats-feature img {
  width: 34px;
  height: 34px;
}

.rating-title {
  display: block;
  margin-bottom: 12px;
  color: var(--ink);
  font-weight: 700;
  text-transform: uppercase;
}

.coven {
  display: grid;
  grid-template-columns: 1.1fr 1.9fr;
  margin: 0 32px 34px;
  border: 1px solid var(--line);
}

.coven-invite {
  min-height: 250px;
  padding: 30px;
  display: grid;
  grid-template-columns: 1fr 190px;
  gap: 20px;
  align-items: center;
  border-right: 1px solid var(--line);
}

.coven-art img {
  max-height: 180px;
  margin: 0 auto;
}

.coven-features {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.coven-feature {
  min-height: 250px;
  padding: 34px 22px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-align: center;
  text-decoration: none;
  border-right: 1px solid var(--line);
}

.coven-feature:last-child {
  border-right: 0;
}

.feature-icon {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  color: var(--purple);
  font-size: 20px;
}

.coven-feature strong {
  font-size: 13px;
  text-transform: uppercase;
}

.coven-feature p {
  margin: 0;
  font-size: 13px;
}

.bottom-panels {
  display: grid;
  grid-template-columns: 1fr 1.15fr 0.85fr;
  margin: 0 32px 34px;
  border: 1px solid var(--line);
}

.support-panel,
.partners-panel,
.social-panel {
  border: 0;
  border-right: 1px solid var(--line);
  padding: 34px 32px;
}

.social-panel,
.partners-panel {
  justify-content: center;
}

.support-panel {
  display: grid;
  grid-template-columns: 1fr 150px;
  gap: 24px;
  align-items: center;
}

.support-art img {
  width: 145px;
}

.panel-actions {
  display: flex;
  gap: 12px;
}

.social-links,
.footer-social {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin: 12px 0 16px;
}

.social-links a,
.footer-social a {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--purple);
}

.social-links img,
.footer-social img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

.site-footer {
  color: var(--cream);
  background: #1a0c24;
  background-image: radial-gradient(circle at 82% 42%, rgba(95, 40, 145, 0.26), transparent 34%);
  border-top: 1px solid rgba(184, 137, 72, 0.44);
}

.footer-main {
  display: grid;
  grid-template-columns: 1.35fr 0.75fr 0.85fr 1.25fr;
  gap: 34px;
  padding: 40px 56px 32px;
}

.footer-brand img {
  width: 190px;
  margin-bottom: 16px;
}

.footer-brand p,
.footer-column p {
  color: rgba(255, 243, 214, 0.78);
  line-height: 1.45;
}

.footer-column h3 {
  margin: 0 0 12px;
  color: #f8e7bd;
  text-transform: uppercase;
}

.footer-column a {
  display: block;
  margin-bottom: 8px;
  color: rgba(255, 243, 214, 0.82);
  text-decoration: none;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding: 16px 56px;
  border-top: 1px solid rgba(184, 137, 72, 0.28);
  color: rgba(255, 243, 214, 0.70);
  font-size: 12px;
}

/* ============================= */
/* REVIEW - HERO */
/* ============================= */

.review-hero {
  min-height: 560px;
  padding: 28px 56px 44px;
  display: grid;
  grid-template-columns: 38% 62%;
  gap: 12px;
  align-items: center;
}

.review-hero-copy {
  position: relative;
  z-index: 4;
}

.breadcrumb {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
  color: var(--ink);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.breadcrumb a {
  text-decoration: none;
}

.review-label {
  margin-bottom: 18px;
}

.review-hero h1 {
  margin: 0 0 12px;
  color: var(--ink);
  font-size: clamp(44px, 4.1vw, 68px);
  line-height: 0.98;
  text-transform: uppercase;
}

.review-hero h1 span {
  font-size: 0.74em;
}

.review-subtitle {
  margin: 0 0 22px;
  font-size: 22px;
  font-style: italic;
}

.review-score {
  margin-bottom: 22px;
}

.rating-row {
  display: flex;
  align-items: center;
  gap: 22px;
}

.rating-cats-large img {
  width: 34px;
  height: 34px;
}

.rating-cats-medium {
  justify-content: center;
  gap: 7px;
}

.rating-cats-medium img {
  width: 32px;
  height: 32px;
}

.rating-number {
  color: var(--purple);
  font-size: 34px;
  line-height: 1;
  font-weight: 700;
}

.rating-caption {
  display: block;
  margin-top: 9px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.review-intro {
  max-width: 610px;
  margin: 0 0 26px;
  font-size: 18px;
  line-height: 1.5;
}

.review-actions {
  display: flex;
  gap: 14px;
}

.review-hero-art {
  min-height: 470px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}

.review-hero-art img {
  width: 128%;
  max-width: none;
  height: auto;
  object-fit: contain;
  transform: translateX(-4%);
  filter: drop-shadow(0 22px 32px rgba(43, 26, 16, 0.16));
}

/* ============================= */
/* REVIEW - 3 CARDS */
/* ============================= */

.review-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.22fr;
  gap: 22px;
  padding: 0 32px 34px;
}

.review-box {
  min-height: 560px;
  padding: 30px 28px;
}

.review-box::after,
.info-card::after,
.pros-cons-panel::before,
.article-body::before,
.related-carousel-section::before,
.quick-verdict-card::before,
.review-ad-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.review-box h2 {
  position: relative;
  z-index: 2;
  margin: 0 0 24px;
  color: var(--ink);
  font-size: 25px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.tech-list {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tech-item {
  display: grid;
  grid-template-columns: 50px 1fr;
  align-items: center;
  gap: 16px;
  min-height: 68px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.tech-item:last-child {
  border-bottom: 0;
}

.tech-item img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  justify-self: center;
}

.tech-item strong {
  display: block;
  margin-bottom: 5px;
  color: var(--ink);
  font-size: 11px;
  text-transform: uppercase;
}

.tech-item small {
  display: block;
  color: var(--muted);
  font-size: 13.5px;
  line-height: 1.35;
}

.watch-box,
.coven-verdict-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.streaming-logo-image {
  position: relative;
  z-index: 2;
  width: 100%;
  min-height: 112px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 8px auto 22px;
}

.streaming-logo-image img {
  width: 300px;
  max-width: 82%;
  max-height: 112px;
  object-fit: contain;
  filter: drop-shadow(0 8px 12px rgba(43, 26, 16, 0.16));
}

.watch-button {
  position: relative;
  z-index: 2;
  min-width: 220px;
}

.available-list {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  width: 100%;
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid rgba(164, 112, 52, 0.32);
}

.device {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
}

.device img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.device small {
  color: rgba(43, 26, 16, 0.78);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
}

.verdict-rating-wrap {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}

.verdict-score {
  color: var(--ink);
  font-size: 17px;
  text-transform: uppercase;
}

.coven-verdict-box p {
  position: relative;
  z-index: 2;
  max-width: 460px;
  margin: 0 auto 28px;
  font-size: 15.5px;
  line-height: 1.52;
}

/* ============================= */
/* PONTOS FORTES E FRACOS */
/* ============================= */

.pros-cons-panel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin: 0 32px 34px;
  padding: 0;
  overflow: hidden;
}

.pros-cons-panel::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 22px;
  bottom: 22px;
  width: 1px;
  background: rgba(164, 112, 52, 0.30);
}

.pros-cons-column {
  position: relative;
  z-index: 2;
  padding: 28px 34px 30px;
}

.pros-cons-title {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-bottom: 18px;
}

.pros-cons-title img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.pros-cons-title h2 {
  margin: 0;
  font-size: 23px;
  line-height: 1;
  text-transform: uppercase;
}

.strengths h2 {
  color: var(--green);
}

.weaknesses h2 {
  color: var(--red);
}

.pros-cons-column ul {
  display: grid;
  gap: 11px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.pros-cons-column li {
  position: relative;
  padding-left: 26px;
  font-size: 15px;
  line-height: 1.42;
}

.pros-cons-column li::before {
  position: absolute;
  left: 0;
  top: 1px;
  width: 17px;
  height: 17px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
}

.strengths li::before {
  content: "✓";
  color: var(--green);
  border: 1px solid rgba(49, 91, 45, 0.42);
}

.weaknesses li::before {
  content: "!";
  color: var(--red);
  border: 1px solid rgba(138, 44, 37, 0.42);
}

/* ============================= */
/* CRÍTICA + SIDEBAR */
/* ============================= */

.editorial-review {
  display: grid;
  grid-template-columns: minmax(0, 760px) minmax(320px, 430px);
  justify-content: center;
  align-items: start;
  gap: 34px;
  padding: 0 32px 42px;
}

.article-body {
  width: 100%;
  max-width: 760px;
  padding: 34px 38px;
}

.article-heading {
  position: relative;
  z-index: 2;
  margin-bottom: 26px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

.article-kicker,
.section-kicker {
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);
  color: var(--purple);
}

.article-heading h2 {
  margin: 0 0 12px;
  color: var(--ink);
  font-size: 34px;
  line-height: 1;
  text-transform: uppercase;
}

.article-heading p {
  margin: 0;
  color: var(--muted);
  font-size: 16.5px;
  line-height: 1.5;
  font-style: italic;
}

.article-body > p,
.article-highlight {
  position: relative;
  z-index: 2;
}

.article-body > p {
  margin: 0 0 18px;
  font-size: 16.5px;
  line-height: 1.72;
}

.lead-paragraph::first-letter {
  float: left;
  margin: 7px 10px 0 0;
  color: var(--purple);
  font-size: 58px;
  line-height: 0.82;
  font-weight: 700;
}

.article-highlight {
  margin: 24px 0;
  padding: 18px 20px;
  border-left: 4px solid var(--purple);
  background: rgba(255, 246, 222, 0.22);
  font-size: 15.5px;
  line-height: 1.55;
}

.article-highlight strong {
  color: var(--purple);
  text-transform: uppercase;
}

.review-sidebar {
  display: grid;
  gap: 22px;
  width: 100%;
  max-width: 430px;
}

.review-quote-section {
  display: flex;
  justify-content: center;
}

.premium-quote {
  width: 100%;
  display: flex;
  justify-content: center;
}

.quote-frame {
  position: relative;
  width: 100%;
  max-width: 410px;
  min-height: 310px;
  padding: 70px 46px 56px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  background-image: url("assets/icons/quote-bg.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-align: center;
}

.review-quote-text {
  max-width: 280px;
  margin: 0 0 14px;
  color: rgba(43, 26, 16, 0.94);
  font-size: 19px;
  line-height: 1.34;
  font-style: italic;
  font-weight: 650;
}

.review-quote-author {
  display: block;
  color: rgba(43, 26, 16, 0.72);
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.quick-verdict-card,
.review-ad-card {
  padding: 26px 24px;
}

.quick-verdict-card h2,
.review-ad-card h2 {
  position: relative;
  z-index: 2;
  margin: 0 0 18px;
  color: var(--ink);
  font-size: 22px;
  text-align: center;
  text-transform: uppercase;
}

.quick-verdict-list {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.quick-verdict-list li {
  padding-bottom: 13px;
  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.quick-verdict-list li:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.quick-verdict-list strong {
  display: block;
  margin-bottom: 5px;
  color: var(--purple);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.quick-verdict-list span {
  color: rgba(43, 26, 16, 0.84);
  font-size: 14px;
  line-height: 1.45;
}

.ad-label {
  position: relative;
  z-index: 2;
  display: block;
  margin-bottom: 12px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.ad-slot-300x250 {
  position: relative;
  z-index: 2;
  width: 300px;
  max-width: 100%;
  aspect-ratio: 300 / 250;
  margin: 0 auto;
  display: grid;
  place-items: center;
  border: 1px dashed rgba(164, 112, 52, 0.55);
  background: rgba(255, 246, 222, 0.18);
  color: rgba(43, 26, 16, 0.46);
  font-size: 12px;
  text-transform: uppercase;
}

/* ============================= */
/* RELACIONADAS */
/* ============================= */

.related-carousel-section {
  margin: 0 32px 34px;
  padding: 30px 30px 34px;
  overflow: hidden;
}

.related-title-row {
  position: relative;
  z-index: 2;
  margin-bottom: 22px;
}

.related-title-row h2 {
  margin: 0;
  color: var(--ink);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.related-carousel-wrap {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  align-items: center;
  gap: 14px;
}

.related-carousel {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

.related-arrow {
  width: 42px;
  height: 86px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);
  color: var(--purple);
  font: 42px/1 Georgia, "Times New Roman", serif;
  cursor: pointer;
}

.related-arrow:hover {
  background: var(--purple);
  color: var(--cream);
}

.mini-review-card {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 3 / 4;
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  border: 1px solid #9f743f;
  border-radius: 8px;
  background-color: var(--card-dark);
  background-image: linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.82) 36%, rgba(20, 10, 5, 0.35) 66%, rgba(20, 10, 5, 0.08) 100%), var(--post-bg);
  background-size: cover;
  background-position: center;
}

.mini-review-card h3 {
  font-size: 16px;
}

/* ============================= */
/* RESPONSIVO */
/* ============================= */

@media (max-width: 1400px) {
  .review-grid,
  .related-carousel {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .topbar {
    height: auto;
    min-height: 155px;
    grid-template-columns: 1fr;
    justify-items: center;
    padding: 26px;
  }

  .primary-nav {
    flex-wrap: wrap;
  }

  .site-search {
    justify-self: center;
  }

  .hero,
  .review-hero,
  .review-area,
  .review-info-grid,
  .editorial-review,
  .info-grid,
  .bottom-panels,
  .footer-main {
    grid-template-columns: 1fr;
  }

  .review-hero-art img {
    width: min(100%, 760px);
    transform: none;
  }

  .coven {
    grid-template-columns: 1fr;
  }

  .coven-invite {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

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

  .review-sidebar,
  .article-body {
    max-width: 860px;
  }
}

@media (max-width: 900px) {
  .page {
    width: 100%;
  }

  .hero,
  .review-hero {
    padding: 38px 24px;
    min-height: auto;
  }

  .hero h1,
  .review-hero h1 {
    font-size: 42px;
  }

  .categories,
  .review-area,
  .info-grid,
  .coven,
  .bottom-panels,
  .pros-cons-panel,
  .related-carousel-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  .categories,
  .review-grid,
  .related-carousel,
  .available-list,
  .coven-features {
    grid-template-columns: 1fr;
  }

  .category-card {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .pros-cons-panel {
    grid-template-columns: 1fr;
  }

  .pros-cons-panel::after {
    display: none;
  }

  .pros-cons-column + .pros-cons-column {
    border-top: 1px solid var(--line);
  }

  .related-carousel-wrap {
    grid-template-columns: 1fr;
  }

  .related-arrow {
    display: none;
  }

  .mini-review-card,
  .post-card {
    max-width: 320px;
    margin: 0 auto;
  }

  .footer-bottom {
    flex-direction: column;
  }
}
/* ================================================= */
/* BOOK REVIEW TEMPLATE - HÁBITOS ATÔMICOS */
/* ajustes exclusivos para livros, sem afetar audiovisual */
/* ================================================= */

.book-review .book-review-hero {
  grid-template-columns: minmax(0, 38%) minmax(0, 62%);
  min-height: 520px;
  padding: 18px 56px 42px;
  overflow: visible;
}

.book-review .book-hero-art {
  min-height: 440px;

  display: flex;
  align-items: center;
  justify-content: flex-end;

  overflow: visible;
}

.book-review .book-hero-art img {
  width: min(780px, 92%);
  max-width: 100%;
  max-height: 500px;
  height: auto;

  object-fit: contain;
  object-position: center right;

  transform: translateX(2%) translateY(8px);

  filter: drop-shadow(0 22px 32px rgba(43, 26, 16, 0.16));
}

.book-review .book-review-hero .review-hero-copy {
  max-width: 620px;
}

.book-review .book-review-hero h1 {
  font-size: clamp(44px, 4vw, 66px);
  line-height: 0.98;
}

.book-review .book-review-hero .book-author-name {
  color: var(--purple);
  font-size: 0.78em;
}

.book-review .book-review-hero .review-intro {
  max-width: 580px;
}

/* Grid principal dos livros */

.book-review .book-info-grid {
  grid-template-columns: 1fr 1fr 1.16fr;
}

/* ================================================= */
/* BOOK REVIEW - ONDE COMPRAR COM LOGO DA LOJA */
/* ================================================= */

.book-review .book-buy-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  min-height: 560px;
  text-align: center;
}

.book-review .book-buy-main {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 380px;

  display: flex;
  flex-direction: column;
  align-items: center;
}

.book-review .buy-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  margin-bottom: 12px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-size: 10.5px;
  line-height: 1;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Logo da loja indicada, equivalente à logo de streaming no audiovisual */
.book-review .book-store-logo {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 260px;
  min-height: 92px;

  display: flex;
  align-items: center;
  justify-content: center;

  margin: 4px auto 14px;
}

.book-review .book-store-logo img {
  width: auto;
  max-width: 230px;
  max-height: 82px;

  object-fit: contain;
  display: block;

  filter:
    drop-shadow(0 8px 12px rgba(43, 26, 16, 0.12))
    drop-shadow(0 0 10px rgba(255, 246, 222, 0.18));
}

.book-review .book-store-logo.is-wide img {
  max-width: 270px;
  max-height: 72px;
}

.book-review .book-store-logo.is-square img {
  max-width: 120px;
  max-height: 120px;
}

.book-review .buy-store-name {
  display: block;

  margin: 0 0 12px;

  color: var(--ink);
  font-size: 24px;
  line-height: 1.12;
  text-transform: uppercase;
}

.book-review .book-buy-main p {
  max-width: 320px;
  margin: 0 0 20px;

  color: rgba(43, 26, 16, 0.82);
  font-size: 15px;
  line-height: 1.45;
}

.book-review .buy-main-button {
  min-width: 220px;
  margin-bottom: 12px;
}

.book-review .affiliate-note {
  display: block;

  max-width: 280px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.58);
  font-size: 11px;
  line-height: 1.35;
}

/* Formatos disponíveis */

.book-review .book-format-options {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 380px;

  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;

  margin-top: 28px;
  padding-top: 22px;

  border-top: 1px solid rgba(164, 112, 52, 0.32);
}

.book-review .book-format-option {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;

  padding: 12px 8px;

  border: 1px solid rgba(164, 112, 52, 0.24);
  background: rgba(255, 246, 222, 0.12);
}

.book-review .book-format-option img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  opacity: 0.86;
}

.book-review .book-format-option strong {
  color: rgba(43, 26, 16, 0.80);
  font-size: 11px;
  line-height: 1;
  text-transform: uppercase;
}

/* Links alternativos */

.book-review .buy-alt-links {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 380px;

  display: grid;
  gap: 8px;

  margin-top: 18px;
}

.book-review .buy-alt-links a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;

  padding: 10px 12px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.28);
  background: rgba(255, 246, 222, 0.10);

  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.book-review .buy-alt-links a:hover {
  background: var(--purple);
  color: var(--cream);
  transform: translateY(-2px);
}

/* ================================================= */
/* BOOK REVIEW - IDEIAS FAVORITAS */
/* ================================================= */

.book-review .book-quotes-panel {
  position: relative;

  margin: 0 32px 34px;
  padding: 30px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.book-review .book-quotes-panel::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.book-review .book-quote-grid {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.book-review .book-quote-card {
  min-height: 150px;
  padding: 24px 22px;

  display: flex;
  flex-direction: column;
  justify-content: center;

  border: 1px solid rgba(164, 112, 52, 0.32);
  background:
    radial-gradient(circle at 92% 12%, rgba(74, 35, 107, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);

  text-align: center;
}

.book-review .book-quote-card strong {
  display: block;
  margin-bottom: 12px;

  color: var(--purple);
  font-size: 14px;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.book-review .book-quote-card p {
  margin: 0;

  color: rgba(43, 26, 16, 0.84);
  font-size: 15px;
  line-height: 1.48;
}

/* ================================================= */
/* BOOK REVIEW - RESPONSIVO */
/* ================================================= */

@media (max-width: 1100px) {
  .book-review .book-review-hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 30px 36px 44px;
  }

  .book-review .book-hero-art {
    min-height: auto;
    justify-content: center;
  }

  .book-review .book-hero-art img {
    width: min(100%, 720px);
    max-height: none;
    transform: none;
  }

  .book-review .book-info-grid {
    grid-template-columns: 1fr;
  }

  .book-review .book-quote-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .book-review .book-review-hero {
    padding: 30px 24px 40px;
  }

  .book-review .book-review-hero h1 {
    font-size: 42px;
  }

  .book-review .book-hero-art img {
    width: min(100%, 620px);
  }

  .book-review .book-buy-box {
    min-height: auto;
  }

  .book-review .book-format-options {
    grid-template-columns: 1fr;
  }

  .book-review .buy-main-button {
    width: 100%;
  }

  .book-review .book-quotes-panel {
    margin-left: 20px;
    margin-right: 20px;
    padding: 26px 22px;
  }
}
/* ================================================= */
/* BOOK REVIEW - FRASES FAVORITAS + PONTOS */
/* layout na mesma linha, próximo ao mockup */
/* ================================================= */

.book-review .book-middle-grid {
  display: grid;
  grid-template-columns: minmax(300px, 0.92fr) minmax(0, 1.58fr);
  gap: 22px;

  margin: 0 32px 34px;
  align-items: stretch;
}

/* FRASES FAVORITAS */

.book-review .book-favorite-quotes {
  position: relative;

  min-height: 300px;
  padding: 30px 30px 28px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 92%, rgba(184, 137, 72, 0.10), transparent 34%),
    rgba(255, 246, 222, 0.12);

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  text-align: center;
  overflow: hidden;
}

.book-review .book-favorite-quotes::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.book-review .book-favorite-quotes::after {
  content: "";
  position: absolute;
  left: 18px;
  bottom: 8px;

  width: 110px;
  height: 110px;

  background-image: url("assets/icons/ficha_formato.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: left bottom;

  opacity: 0.10;
  pointer-events: none;
}

.book-review .book-favorite-quotes h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 22px;

  color: var(--ink);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.book-review .favorite-quotes-list {
  position: relative;
  z-index: 2;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  min-height: 210px;
}

.book-review .favorite-quotes-list blockquote {
  position: relative;

  max-width: 420px;
  margin: 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 15px;
  line-height: 1.45;
  font-weight: 700;
}

.book-review .favorite-quotes-list blockquote p {
  display: inline;
  margin: 0;
}

.book-review .quote-symbol {
  display: inline-block;

  margin-right: 8px;

  color: rgba(184, 137, 72, 0.82);
  font-size: 32px;
  line-height: 0;
  font-weight: 700;
  vertical-align: -10px;
}

.book-review .quote-symbol-end {
  margin-left: 8px;
  margin-right: 0;
}

.book-review .quote-divider {
  display: block;

  margin: 16px auto;

  color: var(--gold);
  font-size: 16px;
  line-height: 1;
}

/* PONTOS FORTES / FRACOS DENTRO DO GRID */

.book-review .book-middle-grid .pros-cons-panel {
  margin: 0;
  min-height: 300px;
}

.book-review .book-pros-cons {
  grid-template-columns: 1fr 1fr;
}

.book-review .book-pros-cons .pros-cons-column {
  padding: 30px 34px;
}

.book-review .book-pros-cons .pros-cons-title {
  margin-bottom: 20px;
}

.book-review .book-pros-cons .pros-cons-title img {
  width: 42px;
  height: 42px;
}

.book-review .book-pros-cons .pros-cons-title h2 {
  font-size: 24px;
}

.book-review .book-pros-cons li {
  font-size: 15px;
  line-height: 1.45;
}

/* Remove o bloco antigo se ainda existir em algum teste */
.book-review .book-quotes-panel {
  display: none;
}

/* Responsivo */

@media (max-width: 1100px) {
  .book-review .book-middle-grid {
    grid-template-columns: 1fr;
  }

  .book-review .book-middle-grid .pros-cons-panel {
    min-height: auto;
  }
}

@media (max-width: 900px) {
  .book-review .book-middle-grid {
    margin-left: 20px;
    margin-right: 20px;
  }

  .book-review .book-pros-cons {
    grid-template-columns: 1fr;
  }

  .book-review .book-pros-cons::after {
    display: none;
  }

  .book-review .book-pros-cons .pros-cons-column + .pros-cons-column {
    border-top: 1px solid var(--line);
  }

  .book-review .book-favorite-quotes {
    padding: 28px 22px;
  }
}
/* ================================================= */
/* BOOK REVIEW - AJUSTE DO BREADCRUMB */
/* evita que o breadcrumb invada a logo sem mexer no header */
/* ================================================= */

.book-review .book-review-hero .breadcrumb {
  margin-left: clamp(170px, 13vw, 240px);
  margin-bottom: 24px;
  width: fit-content;
}

/* Em telas menores, volta ao padrão para não quebrar */
@media (max-width: 1100px) {
  .book-review .book-review-hero .breadcrumb {
    margin-left: 0;
  }
}
/* ================================================= */
/* REVIEW - AUTOR E DATA DA RESENHA */
/* bloco editorial abaixo da resenha completa */
/* ================================================= */

.review-author-box {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: 74px minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;

  margin-top: 32px;
  padding-top: 24px;

  border-top: 1px solid rgba(164, 112, 52, 0.32);
}

.review-author-avatar {
  width: 64px;
  height: 64px;

  border-radius: 50%;
  overflow: hidden;

  border: 1px solid rgba(164, 112, 52, 0.54);
  background: rgba(255, 246, 222, 0.18);

  box-shadow:
    0 8px 16px rgba(43, 26, 16, 0.10),
    inset 0 0 0 2px rgba(255, 243, 214, 0.28);
}

.review-author-avatar img {
  width: 100%;
  height: 100%;

  object-fit: cover;
  object-position: center;
}

.review-author-info {
  min-width: 0;

  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.review-author-kicker,
.review-post-date span {
  display: block;

  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.62);
  font-size: 11px;
  line-height: 1;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.review-author-name {
  display: block;

  color: var(--ink);
  font-size: 17px;
  line-height: 1.1;
  text-transform: uppercase;
}

.review-author-role {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: fit-content;
  margin-top: 7px;
  padding: 6px 9px;

  color: var(--cream);
  background: var(--purple);
  border: 1px solid rgba(74, 35, 107, 0.28);

  font-size: 10px;
  line-height: 1;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.review-post-date {
  min-width: 150px;
  padding-left: 22px;

  border-left: 1px solid rgba(164, 112, 52, 0.32);
}

.review-post-date time {
  display: block;

  color: var(--ink);
  font-size: 14px;
  line-height: 1.25;
  font-weight: 700;
}

/* Responsivo */

@media (max-width: 700px) {
  .review-author-box {
    grid-template-columns: 64px 1fr;
  }

  .review-post-date {
    grid-column: 1 / -1;

    min-width: 0;
    padding-left: 0;
    padding-top: 16px;

    border-left: 0;
    border-top: 1px solid rgba(164, 112, 52, 0.24);
  }
}
/* ================================================= */
/* REVIEW - AUTOR/DATA DENTRO DO CABEÇALHO DA RESENHA */
/* use junto com o bloco .review-author-box */
/* ================================================= */

.article-heading .review-author-box {
  margin-top: 22px;
  padding-top: 20px;
  padding-bottom: 0;
}

.article-heading .review-author-box + * {
  margin-top: 0;
}
/* ================================================= */
/* REVIEW - ESPAÇAMENTO DO SELO "RESENHA DO COVEN" */
/* ================================================= */

.article-heading .article-kicker {
  margin-bottom: 14px;
}

.article-heading h2 {
  margin-top: 0;
}
/* ================================================= */
/* HOME HERO - CORREÇÃO FINAL ISOLADA */
/* não afeta páginas de review, livros ou audiovisual */
/* ================================================= */

body.home #home-hero {
  position: relative !important;

  display: grid !important;
  grid-template-columns: minmax(0, 40%) minmax(0, 60%) !important;
  align-items: center !important;
  gap: 18px !important;

  min-height: 680px !important;
  padding: 18px 56px 70px !important;

  overflow: visible !important;
}

body.home #home-hero .hero-text {
  position: relative !important;
  z-index: 5 !important;

  max-width: 660px !important;
  transform: translateY(-6px) !important;
}

body.home #home-hero h1 {
  max-width: 650px !important;
  margin: 0 0 26px !important;

  color: var(--ink) !important;
  font-size: clamp(54px, 4.25vw, 76px) !important;
  line-height: 0.94 !important;
  letter-spacing: -0.035em !important;
  text-transform: uppercase !important;
}

body.home #home-hero p {
  max-width: 560px !important;
  margin: 0 0 30px !important;

  color: var(--ink) !important;
  font-size: 20px !important;
  line-height: 1.38 !important;
}

body.home #home-hero .hero-buttons,
body.home #home-hero .buttons {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 18px !important;
  flex-wrap: wrap !important;
}

body.home #home-hero .hero-image {
  position: relative !important;
  z-index: 4 !important;

  min-height: 560px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  overflow: visible !important;
  pointer-events: none !important;
}

body.home #home-hero .hero-image img {
  width: min(1280px, 148%) !important;
  max-width: none !important;
  height: auto !important;

  display: block !important;
  object-fit: contain !important;
  object-position: center !important;

  transform: translateX(-11%) translateY(12px) !important;
}

/* Categorias alinhadas depois do hero */

body.home .categories {
  position: relative !important;
  z-index: 6 !important;
  margin-top: 0 !important;
}

/* ================================================= */
/* HOME HERO - RESPONSIVO CORRIGIDO */
/* ================================================= */

@media (max-width: 1400px) {
  body.home #home-hero {
    grid-template-columns: minmax(0, 42%) minmax(0, 58%) !important;
    min-height: 650px !important;
    padding: 18px 48px 64px !important;
  }

  body.home #home-hero h1 {
    font-size: clamp(50px, 4.7vw, 68px) !important;
  }

  body.home #home-hero .hero-image {
    min-height: 520px !important;
  }

  body.home #home-hero .hero-image img {
    width: min(1080px, 142%) !important;
    transform: translateX(-8%) translateY(12px) !important;
  }
}

@media (max-width: 1100px) {
  body.home #home-hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 36px 32px 54px !important;
  }

  body.home #home-hero .hero-text {
    max-width: 760px !important;
    transform: none !important;
  }

  body.home #home-hero h1 {
    font-size: clamp(44px, 8vw, 64px) !important;
    line-height: 0.98 !important;
  }

  body.home #home-hero p {
    font-size: 18px !important;
  }

  body.home #home-hero .hero-image {
    min-height: auto !important;
    justify-content: center !important;
  }

  body.home #home-hero .hero-image img {
    width: min(100%, 720px) !important;
    transform: none !important;
  }
}

@media (max-width: 900px) {
  body.home #home-hero {
    padding: 32px 24px 48px !important;
  }

  body.home #home-hero h1 {
    font-size: 42px !important;
  }

  body.home #home-hero p {
    font-size: 17px !important;
  }
}
/* ================================================= */
/* HOME HERO - FIX FINAL DO TÍTULO */
/* Cole no FINAL do style.css. */
/* Este bloco vence as regras antigas sem afetar reviews/livros. */
/* ================================================= */

body.home .page #home-hero {
  position: relative !important;

  display: grid !important;
  grid-template-columns: minmax(0, 37%) minmax(0, 63%) !important;
  align-items: center !important;
  gap: 18px !important;

  min-height: 640px !important;
  padding: 18px 56px 66px !important;

  overflow: visible !important;
}

body.home .page #home-hero .hero-text {
  position: relative !important;
  z-index: 5 !important;

  width: 100% !important;
  max-width: 560px !important;

  transform: translateY(-4px) !important;
}

body.home .page #home-hero h1 {
  width: 100% !important;
  max-width: 560px !important;

  margin: 0 0 24px !important;

  color: var(--ink) !important;
  font-size: clamp(44px, 3.35vw, 62px) !important;
  line-height: 0.94 !important;
  letter-spacing: -0.035em !important;
  text-transform: uppercase !important;
}

body.home .page #home-hero p {
  width: 100% !important;
  max-width: 520px !important;

  margin: 0 0 28px !important;

  color: var(--ink) !important;
  font-size: 19px !important;
  line-height: 1.38 !important;
}

body.home .page #home-hero .hero-buttons,
body.home .page #home-hero .buttons {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 18px !important;
  flex-wrap: wrap !important;
}

body.home .page #home-hero .hero-image {
  position: relative !important;
  z-index: 4 !important;

  width: 100% !important;
  min-height: 540px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  overflow: visible !important;
  pointer-events: none !important;
}

body.home .page #home-hero .hero-image img {
  width: min(1220px, 150%) !important;
  max-width: none !important;
  height: auto !important;

  display: block !important;
  object-fit: contain !important;
  object-position: center !important;

  transform: translateX(-9%) translateY(10px) !important;
}

body.home .categories {
  position: relative !important;
  z-index: 6 !important;
  margin-top: 0 !important;
}

/* Desktop médio, incluindo seu print em 80% */
@media (max-width: 1600px) {
  body.home .page #home-hero {
    grid-template-columns: minmax(0, 38%) minmax(0, 62%) !important;
    min-height: 610px !important;
    padding: 14px 48px 62px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 520px !important;
  }

  body.home .page #home-hero h1 {
    max-width: 520px !important;
    font-size: clamp(42px, 3.15vw, 56px) !important;
  }

  body.home .page #home-hero p {
    max-width: 500px !important;
    font-size: 18px !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: 500px !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(1080px, 144%) !important;
    transform: translateX(-7%) translateY(8px) !important;
  }
}

@media (max-width: 1200px) {
  body.home .page #home-hero {
    grid-template-columns: minmax(0, 42%) minmax(0, 58%) !important;
    min-height: 570px !important;
    padding: 16px 42px 56px !important;
  }

  body.home .page #home-hero h1 {
    font-size: clamp(40px, 4.2vw, 52px) !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(920px, 138%) !important;
    transform: translateX(-5%) translateY(8px) !important;
  }
}

@media (max-width: 1100px) {
  body.home .page #home-hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 36px 32px 54px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 760px !important;
    transform: none !important;
  }

  body.home .page #home-hero h1 {
    max-width: 760px !important;
    font-size: clamp(40px, 7vw, 60px) !important;
    line-height: 0.98 !important;
  }

  body.home .page #home-hero p {
    font-size: 18px !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: auto !important;
    justify-content: center !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(100%, 720px) !important;
    transform: none !important;
  }
}

@media (max-width: 900px) {
  body.home .page #home-hero {
    padding: 32px 24px 48px !important;
  }

  body.home .page #home-hero h1 {
    font-size: 40px !important;
  }

  body.home .page #home-hero p {
    font-size: 17px !important;
  }
}
/* ================================================= */
/* HOME HERO - AJUSTE FINO FINAL */
/* desce título, aumenta arte e puxa para o centro */
/* ================================================= */

body.home .page #home-hero {
  grid-template-columns: minmax(0, 36%) minmax(0, 64%) !important;
  min-height: 680px !important;
  padding-top: 34px !important;
  padding-bottom: 70px !important;
}

body.home .page #home-hero .hero-text {
  max-width: 570px !important;
  transform: translateY(32px) !important;
}

body.home .page #home-hero h1 {
  max-width: 570px !important;
  font-size: clamp(44px, 3.25vw, 60px) !important;
  line-height: 0.94 !important;
}

body.home .page #home-hero p {
  max-width: 530px !important;
}

body.home .page #home-hero .hero-image {
  min-height: 590px !important;
  justify-content: center !important;
}

body.home .page #home-hero .hero-image img {
  width: min(1460px, 172%) !important;
  transform: translateX(-20%) translateY(10px) !important;
}

/* Ajuste para telas até 1600px, como no seu print */

@media (max-width: 1600px) {
  body.home .page #home-hero {
    grid-template-columns: minmax(0, 37%) minmax(0, 63%) !important;
    min-height: 650px !important;
    padding-top: 34px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 540px !important;
    transform: translateY(30px) !important;
  }

  body.home .page #home-hero h1 {
    max-width: 540px !important;
    font-size: clamp(42px, 3.05vw, 56px) !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: 560px !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(1300px, 176%) !important;
    transform: translateX(-18%) translateY(8px) !important;
  }
}
/* ================================================= */
/* HOME - INFO GRID REFINADO */
/* calendário, veredito centralizado e plataformas */
/* ================================================= */

body.home .info-grid {
  align-items: stretch;
}

body.home .info-card {
  overflow: hidden;
}

body.home .calendar-card,
body.home .coven-rating-card,
body.home .guides-card {
  min-height: 285px;
}

/* Calendário */

body.home .calendar-card {
  justify-content: flex-start;
}

body.home .calendar-card .event-list {
  margin-top: 14px;
  margin-bottom: 18px;
}

body.home .calendar-card .event-card {
  grid-template-columns: 58px minmax(0, 1fr) 42px;
  min-height: 58px;
}

body.home .event-platform {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

body.home .platform-icon {
  width: 32px;
  height: 32px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  box-shadow:
    0 6px 12px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

body.home .platform-icon img {
  width: 17px;
  height: 17px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

body.home .platform-twitch {
  background: var(--purple);
}

body.home .platform-youtube {
  background: #c4302b;
}

/* Veredito do Coven centralizado */

body.home .coven-rating-card {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

body.home .coven-rating-inner {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 520px;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

body.home .coven-rating-card h2 {
  margin-bottom: 18px;
}

body.home .coven-rating-card .rating-cats-feature {
  margin: 0 0 16px;
}

body.home .coven-rating-card .rating-title {
  margin-bottom: 14px;
}

body.home .coven-rating-card p {
  max-width: 430px;
  margin: 0 auto 18px;

  text-align: center;
}

body.home .coven-rating-card .info-link {
  margin-top: 0;
}

/* Guias */

body.home .guides-card {
  display: flex;
  flex-direction: column;
}

body.home .guides-card .guide-list {
  margin-top: 14px;
  margin-bottom: 18px;
}

body.home .guides-card .info-link {
  margin-top: auto;
}

/* Responsivo */

@media (max-width: 900px) {
  body.home .calendar-card,
  body.home .coven-rating-card,
  body.home .guides-card {
    min-height: auto;
  }

  body.home .calendar-card .event-card {
    grid-template-columns: 58px minmax(0, 1fr) 42px;
  }
}
/* ================================================= */
/* HOME - ÍCONES DE PLATAFORMA NO CALENDÁRIO */
/* correção Twitch / YouTube */
/* ================================================= */

body.home .event-platform {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

body.home .platform-icon {
  width: 32px;
  height: 32px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  box-shadow:
    0 6px 12px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

body.home .platform-twitch {
  background: var(--purple);
}

body.home .platform-youtube {
  background: #c4302b;
}

/* Twitch usa o PNG normal */
body.home .platform-twitch img {
  width: 17px;
  height: 17px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* YouTube usa o PNG como máscara para virar ícone branco limpo */
body.home .platform-youtube img {
  width: 18px;
  height: 18px;

  object-fit: contain;

  opacity: 1;
  filter: none;

  background: #fff;

  -webkit-mask-image: url("assets/icons/youtube-icon.png");
  mask-image: url("assets/icons/youtube-icon.png");

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;

  -webkit-mask-position: center;
  mask-position: center;

  -webkit-mask-size: contain;
  mask-size: contain;

  content: "";
}
/* ================================================= */
/* LEGOLAS GEEK - OVERRIDES FINAIS */
/* Tipografia + ajustes finais seguros */
/* Carregar DEPOIS do style.css */
/* ================================================= */

:root {
  --font-title: "Cinzel", Georgia, "Times New Roman", serif;
  --font-body: "Cormorant Garamond", Georgia, "Times New Roman", serif;
}

/* ============================= */
/* TIPOGRAFIA GLOBAL */
/* ============================= */

body,
button,
input,
textarea,
select {
  font-family: var(--font-body);
  font-weight: 600;
}

h1,
h2,
h3,
h4,
.primary-nav a,
.lg-btn,
.hero-button,
.post-category,
.review-label,
.live-tag,
.section-kicker,
.article-kicker,
.rating-title,
.verdict-score,
.tech-item strong,
.event-info strong,
.guide-item strong,
.footer-column h3,
.category-card strong,
.see-all,
.info-link,
.review-author-name,
.review-author-role,
.review-author-kicker,
.review-post-date span,
.review-post-date time {
  font-family: var(--font-title);
}

.primary-nav a {
  font-weight: 800;
  letter-spacing: -0.015em;
}

.lg-btn,
.hero-button,
.site-search input {
  font-family: var(--font-title);
  font-weight: 800;
  letter-spacing: -0.01em;
}

#home-hero h1,
.review-hero h1 {
  font-family: var(--font-title) !important;
  font-weight: 900 !important;
  letter-spacing: -0.045em !important;
}

#home-hero p,
.review-subtitle,
.review-intro,
.article-heading p,
.info-card p,
.support-panel p,
.partners-panel p,
.social-panel p,
.coven p,
.article-body > p,
.article-highlight,
.coven-verdict-box p,
.quick-verdict-list span,
.tech-item small,
.event-info small,
.guide-item small,
.category-card span,
.book-quote-card p,
.book-favorite-quotes p {
  font-family: var(--font-body);
  font-weight: 600;
}

.section-title-row h2,
.info-card h2,
.support-panel h2,
.partners-panel h2,
.social-panel h2,
.coven h2,
.review-box h2,
.pros-cons-title h2,
.related-title-row h2,
.article-heading h2,
.quick-verdict-card h2,
.review-ad-card h2,
.book-favorite-quotes h2 {
  font-family: var(--font-title);
  font-weight: 800;
  letter-spacing: -0.025em;
}

.favorite-quotes-list blockquote,
.review-quote-text {
  font-family: var(--font-body);
  font-weight: 700;
  font-style: italic;
}

/* Ajuste fino: Cormorant é mais elegante, mas ocupa diferente da Georgia */
.article-body > p,
.article-highlight {
  font-size: 18px;
}

/* ============================= */
/* HOME HERO - FIX FINAL ATUAL */
/* mantém o hero longe da logo e a arte mais centralizada */
/* ============================= */

body.home .page #home-hero {
  grid-template-columns: minmax(0, 36%) minmax(0, 64%) !important;
  min-height: 680px !important;
  padding-top: 34px !important;
  padding-bottom: 70px !important;
}

body.home .page #home-hero .hero-text {
  max-width: 570px !important;
  transform: translateY(32px) !important;
}

body.home .page #home-hero h1 {
  max-width: 570px !important;
  font-size: clamp(44px, 3.25vw, 60px) !important;
  line-height: 0.94 !important;
}

body.home .page #home-hero p {
  max-width: 530px !important;
}

body.home .page #home-hero .hero-image {
  min-height: 590px !important;
  justify-content: center !important;
}

body.home .page #home-hero .hero-image img {
  width: min(1460px, 172%) !important;
  transform: translateX(-20%) translateY(10px) !important;
}

@media (max-width: 1600px) {
  body.home .page #home-hero {
    grid-template-columns: minmax(0, 37%) minmax(0, 63%) !important;
    min-height: 650px !important;
    padding-top: 34px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 540px !important;
    transform: translateY(30px) !important;
  }

  body.home .page #home-hero h1 {
    max-width: 540px !important;
    font-size: clamp(42px, 3.05vw, 56px) !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: 560px !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(1300px, 176%) !important;
    transform: translateX(-18%) translateY(8px) !important;
  }
}

/* ============================= */
/* HOME - INFO GRID REFINADO */
/* calendário, veredito centralizado e plataformas */
/* ============================= */

body.home .info-grid {
  align-items: stretch;
}

body.home .info-card {
  overflow: hidden;
}

body.home .calendar-card,
body.home .coven-rating-card,
body.home .guides-card {
  min-height: 285px;
}

/* Calendário */

body.home .calendar-card {
  justify-content: flex-start;
}

body.home .calendar-card .event-list {
  margin-top: 14px;
  margin-bottom: 18px;
}

body.home .calendar-card .event-card {
  grid-template-columns: 58px minmax(0, 1fr) 42px;
  min-height: 58px;
}

body.home .event-platform {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

body.home .platform-icon {
  width: 32px;
  height: 32px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  box-shadow:
    0 6px 12px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

body.home .platform-icon img {
  object-fit: contain;
  display: block;
}

body.home .platform-twitch {
  background: var(--purple);
}

body.home .platform-twitch img {
  width: 17px;
  height: 17px;
  filter: brightness(0) invert(1);
}

body.home .platform-youtube {
  background: #c4302b;
}

body.home .platform-youtube img {
  width: 18px;
  height: 18px;
  filter: none;
}

/* Veredito do Coven centralizado */

body.home .coven-rating-card {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

body.home .coven-rating-inner {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: 520px;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

body.home .coven-rating-card h2 {
  margin-bottom: 18px;
}

body.home .coven-rating-card .rating-cats-feature {
  margin: 0 0 16px;
}

body.home .coven-rating-card .rating-title {
  margin-bottom: 14px;
}

body.home .coven-rating-card p {
  max-width: 430px;
  margin: 0 auto 18px;
  text-align: center;
}

body.home .coven-rating-card .info-link {
  margin-top: 0;
}

/* Guias */

body.home .guides-card {
  display: flex;
  flex-direction: column;
}

body.home .guides-card .guide-list {
  margin-top: 14px;
  margin-bottom: 18px;
}

body.home .guides-card .info-link {
  margin-top: auto;
}

/* ============================= */
/* BOOK REVIEW - AJUSTES FINAIS */
/* ============================= */

.book-review .book-review-hero .breadcrumb {
  margin-left: clamp(170px, 13vw, 240px);
  margin-bottom: 24px;
  width: fit-content;
}

.article-heading .article-kicker {
  margin-bottom: 16px;
}

.article-heading h2 {
  margin-top: 0;
}

.article-heading .review-author-box {
  margin-top: 22px;
  padding-top: 20px;
  padding-bottom: 0;
}

.article-heading .review-author-box + * {
  margin-top: 0;
}

.book-review .related-title-row {
  align-items: center;
}

.book-review .related-title-row h2 {
  margin-top: 0;
}

/* ============================= */
/* RESPONSIVO */
/* ============================= */

@media (max-width: 1100px) {
  body.home .page #home-hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 36px 32px 54px !important;
  }

  body.home .page #home-hero .hero-text {
    max-width: 760px !important;
    transform: none !important;
  }

  body.home .page #home-hero h1 {
    max-width: 760px !important;
    font-size: clamp(40px, 7vw, 60px) !important;
    line-height: 0.98 !important;
  }

  body.home .page #home-hero p {
    font-size: 18px !important;
  }

  body.home .page #home-hero .hero-image {
    min-height: auto !important;
    justify-content: center !important;
  }

  body.home .page #home-hero .hero-image img {
    width: min(100%, 720px) !important;
    transform: none !important;
  }

  .book-review .book-review-hero .breadcrumb {
    margin-left: 0;
  }
}

@media (max-width: 900px) {
  body.home .calendar-card,
  body.home .coven-rating-card,
  body.home .guides-card {
    min-height: auto;
  }

  body.home .calendar-card .event-card {
    grid-template-columns: 58px minmax(0, 1fr) 42px;
  }

  body.home .page #home-hero {
    padding: 32px 24px 48px !important;
  }

  body.home .page #home-hero h1 {
    font-size: 40px !important;
  }

  body.home .page #home-hero p {
    font-size: 17px !important;
  }
}
/* ================================================= */
/* GAME REVIEW TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .game-review, não altera livro nem audiovisual */
/* ================================================= */

.game-review .game-hero {
  display: grid;
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px);
  gap: 34px;
  align-items: center;

  min-height: 560px;
  padding: 28px 56px 46px;
}

.game-review .game-cover-card {
  position: relative;
  z-index: 2;

  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
  box-shadow:
    0 16px 30px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-cover-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.game-review .game-cover-card img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.28);
}

.game-review .game-hero-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
}

.game-review .game-hero-copy .breadcrumb {
  margin-bottom: 26px;
}

.game-review .game-hero-copy .review-label {
  margin-bottom: 18px;
}

.game-review .game-hero-copy h1 {
  margin: 0 0 24px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4.1vw, 72px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.game-review .game-intro {
  max-width: 720px;
  margin: 22px 0 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 20px;
  line-height: 1.48;
  font-style: italic;
}

/* Byline do hero */

.game-review .game-byline {
  display: grid;
  grid-template-columns: minmax(210px, 1.1fr) repeat(3, minmax(120px, 0.7fr));
  align-items: center;
  gap: 16px;

  max-width: 820px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.24);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.game-review .game-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.game-review .game-author-mini img {
  width: 56px;
  height: 56px;

  border-radius: 50%;
  object-fit: cover;

  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.game-review .game-author-mini span,
.game-review .game-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.game-review .game-author-mini small,
.game-review .game-meta-item small {
  margin-bottom: 4px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.game-review .game-author-mini strong,
.game-review .game-meta-item time,
.game-review .game-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.22;
  text-transform: uppercase;
}

.game-review .game-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

/* Card lateral de informações */

.game-review .game-info-card {
  position: relative;
  z-index: 2;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-info-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-info-card h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.game-review .game-info-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 0;

  margin: 0 0 22px;
  padding: 0;

  list-style: none;
}

.game-review .game-info-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 13px;
  align-items: center;

  padding: 12px 0;

  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.game-review .game-info-list li:last-child {
  border-bottom: 0;
}

.game-review .game-info-list img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  justify-self: center;
}

.game-review .game-info-list strong {
  display: block;
  margin-bottom: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-info-list small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 13px;
  line-height: 1.28;
}

.game-review .game-store-actions {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 12px;
}

.game-review .game-store-button,
.game-review .game-wishlist-button {
  width: 100%;
}

.game-review .game-store-button img {
  width: 19px;
  height: 19px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Veredito horizontal */

.game-review .game-verdict-strip {
  position: relative;

  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) 120px;
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 32px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-verdict-strip::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy,
.game-review .game-verdict-ornament {
  position: relative;
  z-index: 2;
}

.game-review .game-verdict-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.game-review .game-verdict-cats {
  justify-content: center;
  gap: 8px;

  margin-bottom: 14px;
}

.game-review .game-verdict-cats img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.game-review .game-verdict-rating strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy p {
  max-width: 760px;
  margin: 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 18px;
  line-height: 1.52;
}

.game-review .game-verdict-ornament {
  display: flex;
  justify-content: center;
}

.game-review .game-verdict-ornament img {
  max-width: 92px;
  max-height: 110px;
  object-fit: contain;
}

/* Pontos */

.game-review .game-pros-cons {
  grid-template-columns: 1fr 1fr;
}

/* Análise completa */

.game-review .game-analysis-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 340px);
  gap: 30px;
  align-items: start;

  margin: 0 32px 34px;
}

.game-review .game-analysis-body {
  position: relative;

  min-height: 420px;
  padding: 34px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-analysis-body::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-analysis-body > p,
.game-review .game-analysis-body .article-highlight,
.game-review .game-analysis-body .article-heading {
  position: relative;
  z-index: 2;
}

.game-review .game-analysis-body > p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.90);
  font-size: 18px;
  line-height: 1.72;
}

.game-review .game-analysis-art {
  min-height: 420px;

  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 0.42;
  pointer-events: none;
}

.game-review .game-analysis-art img {
  max-width: 100%;
  max-height: 420px;
  object-fit: contain;
}

/* Relacionadas de games */

.game-review .game-related-section {
  margin-top: 0;
}

.game-review .game-related-grid {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.game-review .game-related-card {
  position: relative;

  display: grid;
  grid-template-columns: 42% 1fr;
  min-height: 180px;
  overflow: hidden;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-related-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(43, 26, 16, 0.14);
}

.game-review .game-related-card .post-category {
  top: 10px;
  left: 10px;
}

.game-review .game-related-thumb {
  min-height: 180px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.35), rgba(20, 10, 5, 0.02)),
    var(--post-bg);
  background-size: cover;
  background-position: center;
}

.game-review .game-related-copy {
  padding: 18px 18px 16px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.game-review .game-related-copy h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.05;
  text-transform: uppercase;
}

.game-review .game-related-copy p {
  margin: 0 0 12px;

  color: rgba(43, 26, 16, 0.74);
  font-size: 14px;
  line-height: 1.34;
}

/* Bloco apoio / compartilhar */

.game-review .game-support-share {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(280px, 420px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-support-art img {
  max-width: 200px;
  max-height: 150px;
  object-fit: contain;
}

.game-review .game-support-copy h2,
.game-review .game-share-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-support-copy p {
  max-width: 420px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.4;
}

.game-review .game-share-copy {
  text-align: center;
}

.game-review .game-share-copy .social-links {
  margin-bottom: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  }

  .game-review .game-info-card {
    grid-column: 1 / -1;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr 1fr;
  }

  .game-review .game-verdict-strip {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-verdict-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .game-review .game-analysis-section {
    grid-template-columns: 1fr;
  }

  .game-review .game-analysis-art {
    display: none;
  }

  .game-review .game-support-share {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-support-art img {
    margin: 0 auto;
  }

  .game-review .game-support-copy p,
  .game-review .panel-actions {
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr;
    padding: 30px 24px 42px;
  }

  .game-review .game-cover-card {
    max-width: 320px;
    margin: 0 auto;
  }

  .game-review .game-hero-copy h1 {
    font-size: 42px;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr;
  }

  .game-review .game-verdict-strip,
  .game-review .game-analysis-section,
  .game-review .game-support-share {
    margin-left: 20px;
    margin-right: 20px;
  }

  .game-review .game-verdict-cats img {
    width: 34px;
    height: 34px;
  }

  .game-review .game-pros-cons {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-grid {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-card {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-thumb {
    min-height: 220px;
  }
}
/* ================================================= */
/* GAME REVIEW TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .game-review, não altera livro nem audiovisual */
/* ================================================= */

.game-review .game-hero {
  display: grid;
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px);
  gap: 34px;
  align-items: center;

  min-height: 560px;
  padding: 28px 56px 46px;
}

.game-review .game-cover-card {
  position: relative;
  z-index: 2;

  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
  box-shadow:
    0 16px 30px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-cover-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.game-review .game-cover-card img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.28);
}

.game-review .game-hero-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
}

.game-review .game-hero-copy .breadcrumb {
  margin-bottom: 26px;
}

.game-review .game-hero-copy .review-label {
  margin-bottom: 18px;
}

.game-review .game-hero-copy h1 {
  margin: 0 0 24px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4.1vw, 72px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.game-review .game-intro {
  max-width: 720px;
  margin: 22px 0 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 20px;
  line-height: 1.48;
  font-style: italic;
}

/* Byline do hero */

.game-review .game-byline {
  display: grid;
  grid-template-columns: minmax(210px, 1.1fr) repeat(3, minmax(120px, 0.7fr));
  align-items: center;
  gap: 16px;

  max-width: 820px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.24);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.game-review .game-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.game-review .game-author-mini img {
  width: 56px;
  height: 56px;

  border-radius: 50%;
  object-fit: cover;

  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.game-review .game-author-mini span,
.game-review .game-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.game-review .game-author-mini small,
.game-review .game-meta-item small {
  margin-bottom: 4px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.game-review .game-author-mini strong,
.game-review .game-meta-item time,
.game-review .game-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.22;
  text-transform: uppercase;
}

.game-review .game-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

/* Card lateral de informações */

.game-review .game-info-card {
  position: relative;
  z-index: 2;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-info-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-info-card h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.game-review .game-info-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 0;

  margin: 0 0 22px;
  padding: 0;

  list-style: none;
}

.game-review .game-info-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 13px;
  align-items: center;

  padding: 12px 0;

  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.game-review .game-info-list li:last-child {
  border-bottom: 0;
}

.game-review .game-info-list img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  justify-self: center;
}

.game-review .game-info-list strong {
  display: block;
  margin-bottom: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-info-list small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 13px;
  line-height: 1.28;
}

.game-review .game-store-actions {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 12px;
}

.game-review .game-store-button,
.game-review .game-wishlist-button {
  width: 100%;
}

.game-review .game-store-button img {
  width: 19px;
  height: 19px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Veredito horizontal */

.game-review .game-verdict-strip {
  position: relative;

  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) 120px;
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 32px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-verdict-strip::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy,
.game-review .game-verdict-ornament {
  position: relative;
  z-index: 2;
}

.game-review .game-verdict-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.game-review .game-verdict-cats {
  justify-content: center;
  gap: 8px;

  margin-bottom: 14px;
}

.game-review .game-verdict-cats img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.game-review .game-verdict-rating strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy p {
  max-width: 760px;
  margin: 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 18px;
  line-height: 1.52;
}

.game-review .game-verdict-ornament {
  display: flex;
  justify-content: center;
}

.game-review .game-verdict-ornament img {
  max-width: 92px;
  max-height: 110px;
  object-fit: contain;
}

/* Pontos */

.game-review .game-pros-cons {
  grid-template-columns: 1fr 1fr;
}

/* Análise completa */

.game-review .game-analysis-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 340px);
  gap: 30px;
  align-items: start;

  margin: 0 32px 34px;
}

.game-review .game-analysis-body {
  position: relative;

  min-height: 420px;
  padding: 34px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-analysis-body::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-analysis-body > p,
.game-review .game-analysis-body .article-highlight,
.game-review .game-analysis-body .article-heading {
  position: relative;
  z-index: 2;
}

.game-review .game-analysis-body > p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.90);
  font-size: 18px;
  line-height: 1.72;
}

.game-review .game-analysis-art {
  min-height: 420px;

  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 0.42;
  pointer-events: none;
}

.game-review .game-analysis-art img {
  max-width: 100%;
  max-height: 420px;
  object-fit: contain;
}

/* Relacionadas de games */

.game-review .game-related-section {
  margin-top: 0;
}

.game-review .game-related-grid {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.game-review .game-related-card {
  position: relative;

  display: grid;
  grid-template-columns: 42% 1fr;
  min-height: 180px;
  overflow: hidden;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-related-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(43, 26, 16, 0.14);
}

.game-review .game-related-card .post-category {
  top: 10px;
  left: 10px;
}

.game-review .game-related-thumb {
  min-height: 180px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.35), rgba(20, 10, 5, 0.02)),
    var(--post-bg);
  background-size: cover;
  background-position: center;
}

.game-review .game-related-copy {
  padding: 18px 18px 16px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.game-review .game-related-copy h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.05;
  text-transform: uppercase;
}

.game-review .game-related-copy p {
  margin: 0 0 12px;

  color: rgba(43, 26, 16, 0.74);
  font-size: 14px;
  line-height: 1.34;
}

/* Bloco apoio / compartilhar */

.game-review .game-support-share {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(280px, 420px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-support-art img {
  max-width: 200px;
  max-height: 150px;
  object-fit: contain;
}

.game-review .game-support-copy h2,
.game-review .game-share-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-support-copy p {
  max-width: 420px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.4;
}

.game-review .game-share-copy {
  text-align: center;
}

.game-review .game-share-copy .social-links {
  margin-bottom: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  }

  .game-review .game-info-card {
    grid-column: 1 / -1;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr 1fr;
  }

  .game-review .game-verdict-strip {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-verdict-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .game-review .game-analysis-section {
    grid-template-columns: 1fr;
  }

  .game-review .game-analysis-art {
    display: none;
  }

  .game-review .game-support-share {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-support-art img {
    margin: 0 auto;
  }

  .game-review .game-support-copy p,
  .game-review .panel-actions {
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr;
    padding: 30px 24px 42px;
  }

  .game-review .game-cover-card {
    max-width: 320px;
    margin: 0 auto;
  }

  .game-review .game-hero-copy h1 {
    font-size: 42px;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr;
  }

  .game-review .game-verdict-strip,
  .game-review .game-analysis-section,
  .game-review .game-support-share {
    margin-left: 20px;
    margin-right: 20px;
  }

  .game-review .game-verdict-cats img {
    width: 34px;
    height: 34px;
  }

  .game-review .game-pros-cons {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-grid {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-card {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-thumb {
    min-height: 220px;
  }
}

/* ================================================= */
/* GAME REVIEW - CORREÇÕES DO HERO / INFO / VEREDITO */
/* Cole depois do CSS de games, ou substitua o bloco antigo */
/* ================================================= */

/* Hero mais afastado da logo e com as três colunas alinhadas */
.game-review .game-hero {
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px) !important;
  align-items: start !important;

  min-height: 560px !important;
  padding: 72px 56px 46px !important;
}

.game-review .game-cover-card,
.game-review .game-hero-copy,
.game-review .game-info-card {
  align-self: start !important;
}

/* Capa sem corte: respeita a proporção original da imagem enviada */
.game-review .game-cover-card {
  width: 100% !important;
  max-width: 330px !important;
  justify-self: center !important;
  overflow: visible !important;
}

.game-review .game-cover-card img {
  width: 100% !important;
  height: auto !important;
  max-height: none !important;

  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center !important;
}

/* Card de informações alinhado com a capa */
.game-review .game-info-card {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: end !important;
}

/* Remove ícones quebrados da lista, caso os assets game_*.png ainda não existam */
.game-review .game-info-list-clean li {
  grid-template-columns: 1fr !important;
  gap: 0 !important;
}

.game-review .game-info-list-clean li > img {
  display: none !important;
}

/* Disponível em: plataformas/lojas */
.game-review .game-available-box {
  position: relative;
  z-index: 2;

  margin-top: 22px;
  padding-top: 20px;

  border-top: 1px solid rgba(164, 112, 52, 0.28);
  text-align: center;
}

.game-review .game-available-title {
  display: block;

  margin-bottom: 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.game-review .game-platform-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.game-review .game-platform-grid a {
  min-height: 58px;
  padding: 10px 12px;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 1px solid rgba(164, 112, 52, 0.30);
  background: rgba(255, 246, 222, 0.12);

  text-decoration: none;

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-platform-grid a:hover {
  transform: translateY(-2px);
  background: rgba(255, 246, 222, 0.22);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.10);
}

.game-review .game-platform-grid img {
  width: auto !important;
  max-width: 112px !important;
  max-height: 34px !important;

  object-fit: contain !important;
}

/* Veredito do Coven centralizado */
.game-review .game-verdict-strip {
  grid-template-columns: 1fr !important;
  gap: 18px !important;

  text-align: center !important;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}

.game-review .game-verdict-copy h2 {
  text-align: center !important;
}

.game-review .game-verdict-copy p {
  max-width: 920px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.game-review .game-verdict-ornament {
  display: none !important;
}

/* Responsivo das correções */
@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) !important;
    padding-top: 54px !important;
  }

  .game-review .game-info-card {
    grid-column: 1 / -1 !important;
    max-width: none !important;
    justify-self: stretch !important;
  }

  .game-review .game-platform-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr !important;
    padding: 34px 24px 42px !important;
  }

  .game-review .game-cover-card,
  .game-review .game-info-card {
    max-width: 360px !important;
    justify-self: center !important;
  }

  .game-review .game-platform-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
/* ================================================= */
/* GAME REVIEW - PLATAFORMAS DISPONÍVEIS REFINADO */
/* logos menores, lado a lado, sem caixas */
/* ================================================= */

.game-review .game-available-box {
  position: relative;
  z-index: 2;

  margin-top: 22px;
  padding-top: 20px;

  border-top: 1px solid rgba(164, 112, 52, 0.28);
  text-align: center;
}

.game-review .game-available-title {
  display: block;

  margin-bottom: 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.game-review .game-platform-grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;

  width: 100%;
  margin: 0 auto;
}

.game-review .game-platform-grid a {
  width: 42px;
  height: 42px;
  padding: 0;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 0;
  background: transparent;
  box-shadow: none;

  text-decoration: none;

  opacity: 0.82;

  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    filter 0.2s ease;
}

.game-review .game-platform-grid a:hover {
  opacity: 1;
  transform: translateY(-2px);
  filter: drop-shadow(0 6px 8px rgba(43, 26, 16, 0.16));
}

.game-review .game-platform-grid img {
  width: auto !important;
  max-width: 38px !important;
  max-height: 28px !important;

  object-fit: contain !important;
  display: block;
}

/* Ajustes finos por tipo de logo */

.game-review .game-platform-grid img[alt="PlayStation"] {
  max-width: 28px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="Xbox"] {
  max-width: 42px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="PC"] {
  max-width: 38px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="Steam"] {
  max-width: 30px !important;
  max-height: 30px !important;
}

/* Responsivo */

@media (max-width: 900px) {
  .game-review .game-platform-grid {
    gap: 16px;
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* GAME REVIEW - SIDEBAR DA ANÁLISE */
/* vídeo, ads e Discord */
/* ================================================= */

.game-review .game-analysis-section {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px) !important;
  gap: 30px !important;
  align-items: start !important;
}

.game-review .game-review-sidebar {
  display: grid;
  gap: 22px;

  width: 100%;
  max-width: 360px;
}

.game-review .game-video-box,
.game-review .game-sidebar-ad,
.game-review .game-discord-box {
  position: relative;

  padding: 24px 22px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  text-align: center;
  overflow: hidden;
}

.game-review .game-video-box::before,
.game-review .game-sidebar-ad::before,
.game-review .game-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 auto 12px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.game-review .game-video-box h2,
.game-review .game-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-video-thumb {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;

  width: 100%;
  aspect-ratio: 16 / 9;

  margin: 0 auto 16px;

  overflow: hidden;
  border: 1px solid rgba(164, 112, 52, 0.36);

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.64), rgba(20, 10, 5, 0.18)),
    var(--video-thumb);
  background-size: cover;
  background-position: center;

  text-decoration: none;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.game-review .game-video-thumb:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.16);
  filter: brightness(1.06);
}

.game-review .video-play-button {
  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: #c4302b;
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.26),
    inset 0 0 0 1px rgba(255, 243, 214, 0.24);
}

.game-review .video-play-button img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.game-review .game-video-box p,
.game-review .game-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.42;
}

.game-review .game-video-button,
.game-review .discord-button {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Ads */

.game-review .game-sidebar-ad {
  padding-top: 24px;
  padding-bottom: 24px;
}

.game-review .game-sidebar-ad .ad-label {
  position: relative;
  z-index: 2;

  display: block;
  margin-bottom: 12px;

  color: var(--muted);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.game-review .game-sidebar-ad .ad-slot-300x250 {
  position: relative;
  z-index: 2;

  width: 300px;
  max-width: 100%;
  aspect-ratio: 300 / 250;

  margin: 0 auto;

  display: grid;
  place-items: center;

  border: 1px dashed rgba(164, 112, 52, 0.55);
  background: rgba(255, 246, 222, 0.18);

  color: rgba(43, 26, 16, 0.46);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  text-transform: uppercase;
}

/* Discord */

.game-review .discord-icon-wrap {
  position: relative;
  z-index: 2;

  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;

  margin: 0 auto 14px;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.game-review .discord-icon-wrap img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Remove a antiga arte lateral se ainda existir em algum teste */

.game-review .game-analysis-art {
  display: none !important;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-analysis-section {
    grid-template-columns: 1fr !important;
  }

  .game-review .game-review-sidebar {
    max-width: none;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .game-review .game-sidebar-ad .ad-slot-300x250 {
    width: 100%;
  }
}

@media (max-width: 900px) {
  .game-review .game-review-sidebar {
    grid-template-columns: 1fr;
  }

  .game-review .game-video-box,
  .game-review .game-sidebar-ad,
  .game-review .game-discord-box {
    padding: 24px 20px;
  }
}
/* ================================================= */
/* GAME REVIEW TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .game-review, não altera livro nem audiovisual */
/* ================================================= */

.game-review .game-hero {
  display: grid;
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px);
  gap: 34px;
  align-items: center;

  min-height: 560px;
  padding: 28px 56px 46px;
}

.game-review .game-cover-card {
  position: relative;
  z-index: 2;

  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
  box-shadow:
    0 16px 30px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-cover-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.game-review .game-cover-card img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.28);
}

.game-review .game-hero-copy {
  position: relative;
  z-index: 3;
  min-width: 0;
}

.game-review .game-hero-copy .breadcrumb {
  margin-bottom: 26px;
}

.game-review .game-hero-copy .review-label {
  margin-bottom: 18px;
}

.game-review .game-hero-copy h1 {
  margin: 0 0 24px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4.1vw, 72px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.game-review .game-intro {
  max-width: 720px;
  margin: 22px 0 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 20px;
  line-height: 1.48;
  font-style: italic;
}

/* Byline do hero */

.game-review .game-byline {
  display: grid;
  grid-template-columns: minmax(210px, 1.1fr) repeat(3, minmax(120px, 0.7fr));
  align-items: center;
  gap: 16px;

  max-width: 820px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.24);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.game-review .game-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.game-review .game-author-mini img {
  width: 56px;
  height: 56px;

  border-radius: 50%;
  object-fit: cover;

  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.game-review .game-author-mini span,
.game-review .game-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.game-review .game-author-mini small,
.game-review .game-meta-item small {
  margin-bottom: 4px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.game-review .game-author-mini strong,
.game-review .game-meta-item time,
.game-review .game-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.22;
  text-transform: uppercase;
}

.game-review .game-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

/* Card lateral de informações */

.game-review .game-info-card {
  position: relative;
  z-index: 2;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-info-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-info-card h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.game-review .game-info-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 0;

  margin: 0 0 22px;
  padding: 0;

  list-style: none;
}

.game-review .game-info-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 13px;
  align-items: center;

  padding: 12px 0;

  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
}

.game-review .game-info-list li:last-child {
  border-bottom: 0;
}

.game-review .game-info-list img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  justify-self: center;
}

.game-review .game-info-list strong {
  display: block;
  margin-bottom: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-info-list small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 13px;
  line-height: 1.28;
}

.game-review .game-store-actions {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 12px;
}

.game-review .game-store-button,
.game-review .game-wishlist-button {
  width: 100%;
}

.game-review .game-store-button img {
  width: 19px;
  height: 19px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Veredito horizontal */

.game-review .game-verdict-strip {
  position: relative;

  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr) 120px;
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 32px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-verdict-strip::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy,
.game-review .game-verdict-ornament {
  position: relative;
  z-index: 2;
}

.game-review .game-verdict-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.game-review .game-verdict-cats {
  justify-content: center;
  gap: 8px;

  margin-bottom: 14px;
}

.game-review .game-verdict-cats img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.game-review .game-verdict-rating strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-verdict-copy p {
  max-width: 760px;
  margin: 0;

  color: rgba(43, 26, 16, 0.88);
  font-size: 18px;
  line-height: 1.52;
}

.game-review .game-verdict-ornament {
  display: flex;
  justify-content: center;
}

.game-review .game-verdict-ornament img {
  max-width: 92px;
  max-height: 110px;
  object-fit: contain;
}

/* Pontos */

.game-review .game-pros-cons {
  grid-template-columns: 1fr 1fr;
}

/* Análise completa */

.game-review .game-analysis-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 340px);
  gap: 30px;
  align-items: start;

  margin: 0 32px 34px;
}

.game-review .game-analysis-body {
  position: relative;

  min-height: 420px;
  padding: 34px 38px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-analysis-body::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .game-analysis-body > p,
.game-review .game-analysis-body .article-highlight,
.game-review .game-analysis-body .article-heading {
  position: relative;
  z-index: 2;
}

.game-review .game-analysis-body > p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.90);
  font-size: 18px;
  line-height: 1.72;
}

.game-review .game-analysis-art {
  min-height: 420px;

  display: flex;
  align-items: center;
  justify-content: center;

  opacity: 0.42;
  pointer-events: none;
}

.game-review .game-analysis-art img {
  max-width: 100%;
  max-height: 420px;
  object-fit: contain;
}

/* Relacionadas de games */

.game-review .game-related-section {
  margin-top: 0;
}

.game-review .game-related-grid {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.game-review .game-related-card {
  position: relative;

  display: grid;
  grid-template-columns: 42% 1fr;
  min-height: 180px;
  overflow: hidden;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-related-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 26px rgba(43, 26, 16, 0.14);
}

.game-review .game-related-card .post-category {
  top: 10px;
  left: 10px;
}

.game-review .game-related-thumb {
  min-height: 180px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.35), rgba(20, 10, 5, 0.02)),
    var(--post-bg);
  background-size: cover;
  background-position: center;
}

.game-review .game-related-copy {
  padding: 18px 18px 16px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.game-review .game-related-copy h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.05;
  text-transform: uppercase;
}

.game-review .game-related-copy p {
  margin: 0 0 12px;

  color: rgba(43, 26, 16, 0.74);
  font-size: 14px;
  line-height: 1.34;
}

/* Bloco apoio / compartilhar */

.game-review .game-support-share {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(280px, 420px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.game-review .game-support-art img {
  max-width: 200px;
  max-height: 150px;
  object-fit: contain;
}

.game-review .game-support-copy h2,
.game-review .game-share-copy h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-support-copy p {
  max-width: 420px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.4;
}

.game-review .game-share-copy {
  text-align: center;
}

.game-review .game-share-copy .social-links {
  margin-bottom: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
  }

  .game-review .game-info-card {
    grid-column: 1 / -1;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr 1fr;
  }

  .game-review .game-verdict-strip {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-verdict-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .game-review .game-analysis-section {
    grid-template-columns: 1fr;
  }

  .game-review .game-analysis-art {
    display: none;
  }

  .game-review .game-support-share {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .game-review .game-support-art img {
    margin: 0 auto;
  }

  .game-review .game-support-copy p,
  .game-review .panel-actions {
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr;
    padding: 30px 24px 42px;
  }

  .game-review .game-cover-card {
    max-width: 320px;
    margin: 0 auto;
  }

  .game-review .game-hero-copy h1 {
    font-size: 42px;
  }

  .game-review .game-byline {
    grid-template-columns: 1fr;
  }

  .game-review .game-verdict-strip,
  .game-review .game-analysis-section,
  .game-review .game-support-share {
    margin-left: 20px;
    margin-right: 20px;
  }

  .game-review .game-verdict-cats img {
    width: 34px;
    height: 34px;
  }

  .game-review .game-pros-cons {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-grid {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-card {
    grid-template-columns: 1fr;
  }

  .game-review .game-related-thumb {
    min-height: 220px;
  }
}

/* ================================================= */
/* GAME REVIEW - CORREÇÕES DO HERO / INFO / VEREDITO */
/* Cole depois do CSS de games, ou substitua o bloco antigo */
/* ================================================= */

/* Hero mais afastado da logo e com as três colunas alinhadas */
.game-review .game-hero {
  grid-template-columns: minmax(250px, 330px) minmax(0, 1fr) minmax(280px, 360px) !important;
  align-items: start !important;

  min-height: 560px !important;
  padding: 72px 56px 46px !important;
}

.game-review .game-cover-card,
.game-review .game-hero-copy,
.game-review .game-info-card {
  align-self: start !important;
}

/* Capa sem corte: respeita a proporção original da imagem enviada */
.game-review .game-cover-card {
  width: 100% !important;
  max-width: 330px !important;
  justify-self: center !important;
  overflow: visible !important;
}

.game-review .game-cover-card img {
  width: 100% !important;
  height: auto !important;
  max-height: none !important;

  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center !important;
}

/* Card de informações alinhado com a capa */
.game-review .game-info-card {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: end !important;
}

/* Remove ícones quebrados da lista, caso os assets game_*.png ainda não existam */
.game-review .game-info-list-clean li {
  grid-template-columns: 1fr !important;
  gap: 0 !important;
}

.game-review .game-info-list-clean li > img {
  display: none !important;
}

/* Disponível em: plataformas/lojas */
.game-review .game-available-box {
  position: relative;
  z-index: 2;

  margin-top: 22px;
  padding-top: 20px;

  border-top: 1px solid rgba(164, 112, 52, 0.28);
  text-align: center;
}

.game-review .game-available-title {
  display: block;

  margin-bottom: 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.game-review .game-platform-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.game-review .game-platform-grid a {
  min-height: 58px;
  padding: 10px 12px;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 1px solid rgba(164, 112, 52, 0.30);
  background: rgba(255, 246, 222, 0.12);

  text-decoration: none;

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.game-review .game-platform-grid a:hover {
  transform: translateY(-2px);
  background: rgba(255, 246, 222, 0.22);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.10);
}

.game-review .game-platform-grid img {
  width: auto !important;
  max-width: 112px !important;
  max-height: 34px !important;

  object-fit: contain !important;
}

/* Veredito do Coven centralizado */
.game-review .game-verdict-strip {
  grid-template-columns: 1fr !important;
  gap: 18px !important;

  text-align: center !important;
}

.game-review .game-verdict-rating,
.game-review .game-verdict-copy {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}

.game-review .game-verdict-copy h2 {
  text-align: center !important;
}

.game-review .game-verdict-copy p {
  max-width: 920px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.game-review .game-verdict-ornament {
  display: none !important;
}

/* Responsivo das correções */
@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) !important;
    padding-top: 54px !important;
  }

  .game-review .game-info-card {
    grid-column: 1 / -1 !important;
    max-width: none !important;
    justify-self: stretch !important;
  }

  .game-review .game-platform-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr !important;
    padding: 34px 24px 42px !important;
  }

  .game-review .game-cover-card,
  .game-review .game-info-card {
    max-width: 360px !important;
    justify-self: center !important;
  }

  .game-review .game-platform-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ================================================= */
/* GAME REVIEW - PLATAFORMAS DISPONÍVEIS REFINADO */
/* logos menores, lado a lado, sem caixas */
/* ================================================= */

.game-review .game-available-box {
  position: relative;
  z-index: 2;

  margin-top: 22px;
  padding-top: 20px;

  border-top: 1px solid rgba(164, 112, 52, 0.28);
  text-align: center;
}

.game-review .game-available-title {
  display: block;

  margin-bottom: 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.game-review .game-platform-grid {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 18px;

  width: 100%;
  margin: 0 auto;
}

.game-review .game-platform-grid a {
  width: 42px !important;
  height: 42px !important;
  min-height: 0 !important;
  padding: 0 !important;

  display: flex;
  align-items: center;
  justify-content: center;

  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  text-decoration: none;

  opacity: 0.82;

  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    filter 0.2s ease;
}

.game-review .game-platform-grid a:hover {
  opacity: 1;
  transform: translateY(-2px);
  filter: drop-shadow(0 6px 8px rgba(43, 26, 16, 0.16));
}

.game-review .game-platform-grid img {
  width: auto !important;
  max-width: 38px !important;
  max-height: 28px !important;

  object-fit: contain !important;
  display: block;
}

.game-review .game-platform-grid img[alt="PlayStation"] {
  max-width: 28px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="Xbox"] {
  max-width: 42px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="PC"] {
  max-width: 38px !important;
  max-height: 28px !important;
}

.game-review .game-platform-grid img[alt="Steam"] {
  max-width: 30px !important;
  max-height: 30px !important;
}

@media (max-width: 900px) {
  .game-review .game-platform-grid {
    gap: 16px;
    flex-wrap: wrap;
  }
}

/* ================================================= */
/* GAME REVIEW - SIDEBAR DA ANÁLISE */
/* vídeo, ads e Discord */
/* ================================================= */

.game-review .game-analysis-section {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px) !important;
  gap: 30px !important;
  align-items: start !important;
}

.game-review .game-review-sidebar {
  display: grid;
  gap: 22px;

  width: 100%;
  max-width: 360px;
}

.game-review .game-video-box,
.game-review .game-sidebar-ad,
.game-review .game-discord-box {
  position: relative;

  padding: 24px 22px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  text-align: center;
  overflow: hidden;
}

.game-review .game-video-box::before,
.game-review .game-sidebar-ad::before,
.game-review .game-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.game-review .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 auto 12px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.game-review .game-video-box h2,
.game-review .game-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.game-review .game-video-thumb {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;

  width: 100%;
  aspect-ratio: 16 / 9;

  margin: 0 auto 16px;

  overflow: hidden;
  border: 1px solid rgba(164, 112, 52, 0.36);

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.64), rgba(20, 10, 5, 0.18)),
    var(--video-thumb);
  background-size: cover;
  background-position: center;

  text-decoration: none;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.game-review .game-video-thumb:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.16);
  filter: brightness(1.06);
}

.game-review .video-play-button {
  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: #c4302b;
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.26),
    inset 0 0 0 1px rgba(255, 243, 214, 0.24);
}

.game-review .video-play-button img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.game-review .game-video-box p,
.game-review .game-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.42;
}

.game-review .game-video-button,
.game-review .discord-button {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Ads */

.game-review .game-sidebar-ad {
  padding-top: 24px;
  padding-bottom: 24px;
}

.game-review .game-sidebar-ad .ad-label {
  position: relative;
  z-index: 2;

  display: block;
  margin-bottom: 12px;

  color: var(--muted);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.game-review .game-sidebar-ad .ad-slot-300x250 {
  position: relative;
  z-index: 2;

  width: 300px;
  max-width: 100%;
  aspect-ratio: 300 / 250;

  margin: 0 auto;

  display: grid;
  place-items: center;

  border: 1px dashed rgba(164, 112, 52, 0.55);
  background: rgba(255, 246, 222, 0.18);

  color: rgba(43, 26, 16, 0.46);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  text-transform: uppercase;
}

/* Discord */

.game-review .discord-icon-wrap {
  position: relative;
  z-index: 2;

  width: 58px;
  height: 58px;

  display: grid;
  place-items: center;

  margin: 0 auto 14px;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.game-review .discord-icon-wrap img {
  width: 28px;
  height: 28px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* Remove a antiga arte lateral se ainda existir em algum teste */

.game-review .game-analysis-art {
  display: none !important;
}

/* Responsivo */

@media (max-width: 1300px) {
  .game-review .game-analysis-section {
    grid-template-columns: 1fr !important;
  }

  .game-review .game-review-sidebar {
    max-width: none;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .game-review .game-sidebar-ad .ad-slot-300x250 {
    width: 100%;
  }
}

@media (max-width: 900px) {
  .game-review .game-review-sidebar {
    grid-template-columns: 1fr;
  }

  .game-review .game-video-box,
  .game-review .game-sidebar-ad,
  .game-review .game-discord-box {
    padding: 24px 20px;
  }
}

/* ================================================= */
/* GAME REVIEW - MINIATURA DO YOUTUBE */
/* usa thumbnail real do vídeo como background */
/* ================================================= */

.game-review .youtube-video-thumb {
  background-color: #160904;
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.66), rgba(20, 10, 5, 0.16)),
    var(--video-thumb);
  background-size: cover;
  background-position: center;
}

.game-review .youtube-video-thumb::after {
  content: "";

  position: absolute;
  inset: 0;

  background:
    radial-gradient(circle at center, rgba(255, 243, 214, 0.10), transparent 42%),
    linear-gradient(to bottom, rgba(255, 246, 222, 0.02), rgba(20, 10, 5, 0.24));

  pointer-events: none;
}

.game-review .youtube-video-thumb .video-play-button {
  position: relative;
  z-index: 3;
}
/* ================================================= */
/* GAME REVIEW - HERO REFINADO */
/* mais respiro, capa maior e info card alinhado */
/* ================================================= */

.game-review .game-hero {
  grid-template-columns: minmax(320px, 420px) minmax(0, 1fr) minmax(320px, 390px) !important;
  gap: 38px !important;
  align-items: stretch !important;

  min-height: 620px !important;
  padding: 108px 56px 56px !important;
}

/* Capa maior, sem corte e respeitando a proporção original */

.game-review .game-cover-card {
  width: 100% !important;
  max-width: 420px !important;
  height: 100% !important;

  justify-self: center !important;
  align-self: stretch !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  overflow: visible !important;
}

.game-review .game-cover-card img {
  width: 100% !important;
  height: auto !important;

  max-width: 100% !important;
  max-height: none !important;

  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center !important;
}

/* Texto do hero centralizado verticalmente com a capa */

.game-review .game-hero-copy {
  align-self: center !important;
}

/* Caixa de informações acompanhando a altura visual da capa */

.game-review .game-info-card {
  width: 100% !important;
  max-width: 390px !important;
  min-height: 100% !important;

  justify-self: end !important;
  align-self: stretch !important;

  display: flex !important;
  flex-direction: column !important;
}

.game-review .game-info-list {
  flex: 1 !important;
}

.game-review .game-available-box {
  margin-top: auto !important;
}

/* Ajuste fino da lista para respirar melhor no card maior */

.game-review .game-info-list-clean li {
  padding: 14px 0 !important;
}

.game-review .game-info-card h2 {
  margin-bottom: 26px !important;
}

/* Desktop médio */

@media (max-width: 1500px) {
  .game-review .game-hero {
    grid-template-columns: minmax(300px, 390px) minmax(0, 1fr) minmax(300px, 370px) !important;
    gap: 34px !important;
    padding-top: 96px !important;
  }

  .game-review .game-cover-card {
    max-width: 390px !important;
  }

  .game-review .game-info-card {
    max-width: 370px !important;
  }
}

/* Tablet */

@media (max-width: 1300px) {
  .game-review .game-hero {
    grid-template-columns: minmax(280px, 380px) minmax(0, 1fr) !important;
    padding-top: 76px !important;
  }

  .game-review .game-info-card {
    grid-column: 1 / -1 !important;
    max-width: none !important;
    min-height: auto !important;
    justify-self: stretch !important;
  }

  .game-review .game-info-list {
    flex: initial !important;
  }

  .game-review .game-available-box {
    margin-top: 22px !important;
  }
}

/* Mobile */

@media (max-width: 900px) {
  .game-review .game-hero {
    grid-template-columns: 1fr !important;
    padding: 46px 24px 42px !important;
  }

  .game-review .game-cover-card {
    max-width: 380px !important;
    height: auto !important;
  }

  .game-review .game-info-card {
    max-width: 380px !important;
    justify-self: center !important;
  }

  .game-review .game-hero-copy {
    align-self: start !important;
  }
}
/* ================================================= */
/* FOOTER GLOBAL - ÍCONES SOCIAIS CORRIGIDOS */
/* Padroniza Twitch, YouTube e Instagram no rodapé */
/* ================================================= */

.site-footer .footer-social {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;

  margin: 16px 0 0;
}

.site-footer .footer-social a {
  position: relative;

  width: 44px;
  height: 44px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);

  text-decoration: none;
  overflow: hidden;

  box-shadow:
    0 8px 16px rgba(0, 0, 0, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.16);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

/* Esconde os PNGs originais para evitar ícones quebrados/coloridos dentro da bolinha */
.site-footer .footer-social a img {
  display: none !important;
}

.site-footer .footer-social a::before {
  content: "";

  width: 22px;
  height: 22px;

  display: block;

  background: var(--cream);

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;

  -webkit-mask-position: center;
  mask-position: center;

  -webkit-mask-size: contain;
  mask-size: contain;
}

.site-footer .footer-social a:hover {
  transform: translateY(-3px);
  background: var(--purple-dark);

  box-shadow:
    0 12px 20px rgba(0, 0, 0, 0.22),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

/* Ordem atual do footer:
   1 Twitch
   2 YouTube
   3 Instagram
*/

.site-footer .footer-social a:nth-child(1)::before {
  -webkit-mask-image: url("assets/icons/twitch-icon.png");
  mask-image: url("assets/icons/twitch-icon.png");
}

.site-footer .footer-social a:nth-child(2)::before {
  -webkit-mask-image: url("assets/icons/youtube-icon.png");
  mask-image: url("assets/icons/youtube-icon.png");
}

.site-footer .footer-social a:nth-child(3)::before {
  -webkit-mask-image: url("assets/icons/instagram-icon.png");
  mask-image: url("assets/icons/instagram-icon.png");
}
/* ================================================= */
/* FOOTER GLOBAL - CORREÇÃO DO ÍCONE DO YOUTUBE */
/* cria o símbolo em CSS para não depender do PNG */
/* ================================================= */

.site-footer .footer-social a:nth-child(2)::before {
  width: 24px;
  height: 17px;

  background: var(--cream);
  border-radius: 5px;

  -webkit-mask-image: none !important;
  mask-image: none !important;

  -webkit-mask: none !important;
  mask: none !important;
}

.site-footer .footer-social a:nth-child(2)::after {
  content: "";

  position: absolute;
  left: 50%;
  top: 50%;

  width: 0;
  height: 0;

  transform: translate(-38%, -50%);

  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid var(--purple);

  z-index: 2;
}
/* ================================================= */
/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .news-article */
/* ================================================= */

.news-article .news-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.86fr) minmax(520px, 1.14fr);
  gap: 42px;
  align-items: center;

  min-height: 560px;
  padding: 46px 56px 42px;
}

.news-article .news-hero-copy {
  position: relative;
  z-index: 3;
}

.news-article .news-hero .breadcrumb {
  margin-bottom: 28px;
}

.news-article .news-label {
  margin-bottom: 18px;
}

.news-article .news-hero h1 {
  max-width: 660px;
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(44px, 4vw, 76px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.news-article .news-subtitle {
  max-width: 560px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 24px;
  line-height: 1.25;
  font-style: italic;
}

.news-article .news-byline {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(130px, 0.72fr) minmax(130px, 0.72fr) minmax(90px, 0.46fr);
  align-items: center;
  gap: 16px;

  max-width: 720px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.26);
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

.news-article .news-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.news-article .news-author-mini img {
  width: 58px;
  height: 58px;

  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.news-article .news-author-mini span,
.news-article .news-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.news-article .news-author-mini small,
.news-article .news-meta-item small {
  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.news-article .news-author-mini strong,
.news-article .news-meta-item time,
.news-article .news-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

.news-article .news-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 14px;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 34px;
  height: 34px;

  display: grid;
  place-items: center;

  color: var(--ink);
  text-decoration: none;

  border-radius: 50%;
  background: rgba(255, 246, 222, 0.10);

  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: rgba(86, 32, 129, 0.12);
}

.news-article .news-share-row img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.news-article .news-hero-image {
  position: relative;

  margin: 0;
  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  box-shadow:
    0 18px 34px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-hero-image::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.news-article .news-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.24);
}

/* Conteúdo + sidebar */

.news-article .news-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;

  margin: 0 56px 38px;
}

.news-article .news-article-body {
  position: relative;

  padding: 0;

  color: rgba(43, 26, 16, 0.92);
}

.news-article .news-article-body > p {
  max-width: 860px;
  margin: 0 0 20px;

  font-size: 20px;
  line-height: 1.66;
}

.news-article .news-article-body h2 {
  max-width: 860px;
  margin: 34px 0 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  float: left;

  margin: 7px 12px 0 0;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 78px;
  line-height: 0.78;
  font-weight: 900;
}

.news-article .news-quote {
  position: relative;

  max-width: 860px;
  margin: 34px 0;
  padding: 30px 92px 30px 60px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-quote::before {
  content: "“";

  position: absolute;
  left: 28px;
  top: 20px;

  color: var(--purple);
  font-size: 44px;
  line-height: 1;
  opacity: 0.72;
}

.news-article .news-quote::after {
  content: "";

  position: absolute;
  right: 30px;
  bottom: 24px;

  width: 64px;
  height: 64px;

  background-image: url("assets/icons/veredito-gema.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  opacity: 0.72;
}

.news-article .news-quote p {
  margin: 0 0 14px;

  color: var(--purple);
  font-size: 24px;
  line-height: 1.36;
  font-style: italic;
  font-weight: 700;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.72);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

/* Sidebar */

.news-article .news-sidebar {
  display: grid;
  gap: 22px;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  position: relative;

  padding: 26px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 0 18px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.news-article .news-summary-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 16px;

  margin: 0;
  padding: 0;

  list-style: none;
}

.news-article .news-summary-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
}

.news-article .news-summary-list img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  opacity: 0.84;
}

.news-article .news-summary-list span {
  color: rgba(43, 26, 16, 0.82);
  font-size: 15.5px;
  line-height: 1.38;
}

.news-article .news-tags {
  position: relative;
  z-index: 2;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.news-article .news-tags a {
  padding: 7px 10px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.36);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.news-article .news-tags a:hover {
  transform: translateY(-2px);
  background: var(--purple);
  color: var(--cream);
}

.news-article .news-discord-box {
  text-align: center;
}

.news-article .news-discord-art {
  position: relative;
  z-index: 2;

  margin: -8px auto 12px;
}

.news-article .news-discord-art img {
  max-width: 190px;
  max-height: 150px;

  margin: 0 auto;
  object-fit: contain;
}

.news-article .news-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.news-article .news-discord-box .lg-btn {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Mais notícias */

.news-article .more-news-section {
  position: relative;

  margin: 0 56px 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .more-news-section::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .more-news-section .section-title-row,
.news-article .more-news-grid {
  position: relative;
  z-index: 2;
}

.news-article .more-news-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.news-article .news-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 320px;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.13);
}

.news-article .news-card .post-category {
  top: 12px;
  left: 12px;
}

.news-article .news-card-image {
  min-height: 170px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.38), rgba(20, 10, 5, 0.04)),
    var(--news-bg);
  background-size: cover;
  background-position: center;
}

.news-article .news-card-copy {
  padding: 18px;

  display: flex;
  flex: 1;
  flex-direction: column;
}

.news-article .news-card-copy time {
  margin-bottom: 10px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-card-copy h3 {
  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.12;
  text-transform: uppercase;
}

.news-article .news-card-copy small {
  margin-top: auto;

  color: rgba(43, 26, 16, 0.62);
  font-size: 13px;
}

/* Newsletter */

.news-article .newsletter-panel {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .newsletter-art img {
  max-width: 190px;
  max-height: 150px;

  object-fit: contain;
}

.news-article .newsletter-copy h2 {
  margin: 0 0 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .newsletter-copy p {
  max-width: 520px;
  margin: 0;

  color: rgba(43, 26, 16, 0.80);
  font-size: 16px;
  line-height: 1.4;
}

.news-article .newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.news-article .newsletter-form input {
  min-height: 52px;
  min-width: 0;

  padding: 0 16px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.20);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15px;
  outline: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    grid-template-columns: 1fr;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr;
  }

  .news-article .news-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .news-article .newsletter-form {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .news-article .news-byline {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding: 34px 24px 40px;
  }

  .news-article .news-hero h1 {
    font-size: 42px;
  }

  .news-article .news-content-layout,
  .news-article .more-news-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 48px;
  }

  .news-article .news-quote::after {
    display: none;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr;
  }

  .news-article .newsletter-panel {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr;
  }

  .news-article .news-byline {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* NEWS HERO - TAG + BREADCRUMB NA MESMA LINHA */
/* ================================================= */

.news-article .news-label-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;

  margin: 0 0 18px;
}

.news-article .news-label-row .news-label {
  margin: 0;
  flex: 0 0 auto;
}

.news-article .news-breadcrumb-inline {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;

  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

/* Esconde o breadcrumb antigo caso ainda tenha ficado duplicado */
.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none;
}
/* ================================================= */
/* NEWS HERO - SHARE COM CÍRCULOS ROXOS */
/* ================================================= */

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  margin-right: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 36px;
  height: 36px;

  display: grid;
  place-items: center;

  color: var(--cream);
  background: var(--purple);
  border: 1px solid rgba(255, 243, 214, 0.18);
  border-radius: 50%;

  text-decoration: none;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark);

  box-shadow:
    0 12px 20px rgba(43, 26, 16, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.20);
}

.news-article .news-share-row img {
  width: 17px;
  height: 17px;

  object-fit: contain;
  display: block;

  filter: brightness(0) invert(1);
}

.news-article .news-share-row a span {
  color: var(--cream);
  font-size: 16px;
  line-height: 1;
}
/* ================================================= */
/* NEWS HERO - AJUSTE FINO DE POSIÇÃO */
/* desce o hero e afasta breadcrumb da logo */
/* ================================================= */

.news-article .news-hero {
  padding-top: 92px !important;
  padding-bottom: 46px !important;
  align-items: start !important;
}

/* Linha com tag NOTÍCIA + breadcrumb */

.news-article .news-label-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;

  margin: 0 0 20px !important;
}

/* Tag notícia */

.news-article .news-label-row .news-label {
  margin: 0 !important;
  flex: 0 0 auto !important;
}

/* Breadcrumb ao lado da tag, mais à direita e alinhado */

.news-article .news-breadcrumb-inline {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;

  margin: 0 !important;
  transform: translateY(1px);

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

/* Evita que qualquer breadcrumb antigo apareça duplicado */

.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none !important;
}

/* Ajuste do título depois que o hero desce */

.news-article .news-hero h1 {
  margin-top: 0 !important;
}

/* Compartilhamento continua onde está, só com ícones visíveis */

.news-article .news-share-row a {
  width: 36px !important;
  height: 36px !important;

  display: grid !important;
  place-items: center !important;

  color: var(--cream) !important;
  background: var(--purple) !important;
  border: 1px solid rgba(255, 243, 214, 0.18) !important;
  border-radius: 50% !important;

  text-decoration: none !important;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark) !important;
}

.news-article .news-share-row img {
  width: 17px !important;
  height: 17px !important;
  object-fit: contain !important;
  display: block !important;
  filter: brightness(0) invert(1) !important;
}

.news-article .news-share-row a span {
  color: var(--cream) !important;
  font-size: 16px !important;
  line-height: 1 !important;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    padding-top: 62px !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding-top: 34px !important;
  }

  .news-article .news-label-row {
    gap: 14px !important;
  }
}
/* ================================================= */
/* NEWS ARTICLE - AJUSTE DE COLUNAS DO CONTEÚDO */
/* aumenta área de texto e aproxima sidebar */
/* ================================================= */

.news-article .news-content-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 980px) minmax(300px, 360px) !important;
  gap: 34px !important;
  align-items: start !important;
  justify-content: center !important;

  width: 100% !important;
  max-width: 1480px !important;

  margin: 0 auto 42px !important;
  padding: 0 32px !important;
}

/* Coluna principal da matéria */

.news-article .news-article-body {
  width: 100% !important;
  max-width: none !important;
}

/* Faz texto, títulos e quote ocuparem melhor a coluna */

.news-article .news-article-body > p,
.news-article .news-article-body h2,
.news-article .news-quote {
  max-width: none !important;
  width: 100% !important;
}

/* Texto um pouco mais confortável na largura nova */

.news-article .news-article-body > p {
  font-size: 20px !important;
  line-height: 1.68 !important;
}

/* Quote acompanha a largura da coluna */

.news-article .news-quote {
  margin: 34px 0 !important;
}

/* Sidebar fica firme, sem fugir demais para a direita */

.news-article .news-sidebar {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: stretch !important;
}

/* Cards da sidebar mais estáveis */

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  width: 100% !important;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .news-article .news-content-layout {
    grid-template-columns: 1fr !important;
    max-width: 980px !important;
    gap: 28px !important;

    padding: 0 32px !important;
  }

  .news-article .news-sidebar {
    max-width: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-content-layout {
    padding: 0 20px !important;
    margin-bottom: 34px !important;
  }

  .news-article .news-article-body > p {
    font-size: 18px !important;
    line-height: 1.62 !important;
  }

  .news-article .news-sidebar {
    grid-template-columns: 1fr !important;
  }
}
/* ================================================= */
/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .news-article */
/* ================================================= */

.news-article .news-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.86fr) minmax(520px, 1.14fr);
  gap: 42px;
  align-items: center;

  min-height: 560px;
  padding: 46px 56px 42px;
}

.news-article .news-hero-copy {
  position: relative;
  z-index: 3;
}

.news-article .news-hero .breadcrumb {
  margin-bottom: 28px;
}

.news-article .news-label {
  margin-bottom: 18px;
}

.news-article .news-hero h1 {
  max-width: 660px;
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(44px, 4vw, 76px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.news-article .news-subtitle {
  max-width: 560px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 24px;
  line-height: 1.25;
  font-style: italic;
}

.news-article .news-byline {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(130px, 0.72fr) minmax(130px, 0.72fr) minmax(90px, 0.46fr);
  align-items: center;
  gap: 16px;

  max-width: 720px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.26);
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

.news-article .news-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.news-article .news-author-mini img {
  width: 58px;
  height: 58px;

  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.news-article .news-author-mini span,
.news-article .news-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.news-article .news-author-mini small,
.news-article .news-meta-item small {
  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.news-article .news-author-mini strong,
.news-article .news-meta-item time,
.news-article .news-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

.news-article .news-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 14px;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 34px;
  height: 34px;

  display: grid;
  place-items: center;

  color: var(--ink);
  text-decoration: none;

  border-radius: 50%;
  background: rgba(255, 246, 222, 0.10);

  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: rgba(86, 32, 129, 0.12);
}

.news-article .news-share-row img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.news-article .news-hero-image {
  position: relative;

  margin: 0;
  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  box-shadow:
    0 18px 34px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-hero-image::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.news-article .news-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.24);
}

/* Conteúdo + sidebar */

.news-article .news-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;

  margin: 0 56px 38px;
}

.news-article .news-article-body {
  position: relative;

  padding: 0;

  color: rgba(43, 26, 16, 0.92);
}

.news-article .news-article-body > p {
  max-width: 860px;
  margin: 0 0 20px;

  font-size: 20px;
  line-height: 1.66;
}

.news-article .news-article-body h2 {
  max-width: 860px;
  margin: 34px 0 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  float: left;

  margin: 7px 12px 0 0;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 78px;
  line-height: 0.78;
  font-weight: 900;
}

.news-article .news-quote {
  position: relative;

  max-width: 860px;
  margin: 34px 0;
  padding: 30px 92px 30px 60px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-quote::before {
  content: "“";

  position: absolute;
  left: 28px;
  top: 20px;

  color: var(--purple);
  font-size: 44px;
  line-height: 1;
  opacity: 0.72;
}

.news-article .news-quote::after {
  content: "";

  position: absolute;
  right: 30px;
  bottom: 24px;

  width: 64px;
  height: 64px;

  background-image: url("assets/icons/veredito-gema.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  opacity: 0.72;
}

.news-article .news-quote p {
  margin: 0 0 14px;

  color: var(--purple);
  font-size: 24px;
  line-height: 1.36;
  font-style: italic;
  font-weight: 700;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.72);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

/* Sidebar */

.news-article .news-sidebar {
  display: grid;
  gap: 22px;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  position: relative;

  padding: 26px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 0 18px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.news-article .news-summary-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 16px;

  margin: 0;
  padding: 0;

  list-style: none;
}

.news-article .news-summary-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
}

.news-article .news-summary-list img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  opacity: 0.84;
}

.news-article .news-summary-list span {
  color: rgba(43, 26, 16, 0.82);
  font-size: 15.5px;
  line-height: 1.38;
}

.news-article .news-tags {
  position: relative;
  z-index: 2;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.news-article .news-tags a {
  padding: 7px 10px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.36);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.news-article .news-tags a:hover {
  transform: translateY(-2px);
  background: var(--purple);
  color: var(--cream);
}

.news-article .news-discord-box {
  text-align: center;
}

.news-article .news-discord-art {
  position: relative;
  z-index: 2;

  margin: -8px auto 12px;
}

.news-article .news-discord-art img {
  max-width: 190px;
  max-height: 150px;

  margin: 0 auto;
  object-fit: contain;
}

.news-article .news-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.news-article .news-discord-box .lg-btn {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Mais notícias */

.news-article .more-news-section {
  position: relative;

  margin: 0 56px 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .more-news-section::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .more-news-section .section-title-row,
.news-article .more-news-grid {
  position: relative;
  z-index: 2;
}

.news-article .more-news-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.news-article .news-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 320px;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.13);
}

.news-article .news-card .post-category {
  top: 12px;
  left: 12px;
}

.news-article .news-card-image {
  min-height: 170px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.38), rgba(20, 10, 5, 0.04)),
    var(--news-bg);
  background-size: cover;
  background-position: center;
}

.news-article .news-card-copy {
  padding: 18px;

  display: flex;
  flex: 1;
  flex-direction: column;
}

.news-article .news-card-copy time {
  margin-bottom: 10px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-card-copy h3 {
  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.12;
  text-transform: uppercase;
}

.news-article .news-card-copy small {
  margin-top: auto;

  color: rgba(43, 26, 16, 0.62);
  font-size: 13px;
}

/* Newsletter */

.news-article .newsletter-panel {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .newsletter-art img {
  max-width: 190px;
  max-height: 150px;

  object-fit: contain;
}

.news-article .newsletter-copy h2 {
  margin: 0 0 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .newsletter-copy p {
  max-width: 520px;
  margin: 0;

  color: rgba(43, 26, 16, 0.80);
  font-size: 16px;
  line-height: 1.4;
}

.news-article .newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.news-article .newsletter-form input {
  min-height: 52px;
  min-width: 0;

  padding: 0 16px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.20);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15px;
  outline: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    grid-template-columns: 1fr;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr;
  }

  .news-article .news-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .news-article .newsletter-form {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .news-article .news-byline {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding: 34px 24px 40px;
  }

  .news-article .news-hero h1 {
    font-size: 42px;
  }

  .news-article .news-content-layout,
  .news-article .more-news-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 48px;
  }

  .news-article .news-quote::after {
    display: none;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr;
  }

  .news-article .newsletter-panel {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr;
  }

  .news-article .news-byline {
    grid-template-columns: 1fr;
  }
}

/* ================================================= */
/* NEWS HERO - TAG + BREADCRUMB NA MESMA LINHA */
/* ================================================= */

.news-article .news-hero {
  padding-top: 92px !important;
  padding-bottom: 52px !important;
  align-items: start !important;
}

.news-article .news-label-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;

  margin: 0 0 20px !important;
}

.news-article .news-label-row .news-label {
  margin: 0 !important;
  flex: 0 0 auto !important;
}

.news-article .news-breadcrumb-inline {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;

  margin: 0 !important;
  transform: translateY(1px);

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none !important;
}

.news-article .news-hero h1 {
  margin-top: 0 !important;
}

/* ================================================= */
/* NEWS HERO - SHARE COM CÍRCULOS ROXOS */
/* ================================================= */

.news-article .news-share-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;

  margin-top: 20px !important;
}

.news-article .news-share-row strong {
  margin-right: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 36px !important;
  height: 36px !important;

  display: grid !important;
  place-items: center !important;

  color: var(--cream) !important;
  background: var(--purple) !important;
  border: 1px solid rgba(255, 243, 214, 0.18) !important;
  border-radius: 50% !important;

  text-decoration: none !important;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark) !important;

  box-shadow:
    0 12px 20px rgba(43, 26, 16, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.20);
}

.news-article .news-share-row img {
  width: 17px !important;
  height: 17px !important;

  object-fit: contain !important;
  display: block !important;

  filter: brightness(0) invert(1) !important;
}

.news-article .news-share-row a span {
  color: var(--cream) !important;
  font-size: 16px !important;
  line-height: 1 !important;
}

/* ================================================= */
/* NEWS ARTICLE - AJUSTE DE COLUNAS DO CONTEÚDO */
/* aumenta área de texto e aproxima sidebar */
/* ================================================= */

.news-article .news-content-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 980px) minmax(300px, 360px) !important;
  gap: 34px !important;
  align-items: start !important;
  justify-content: center !important;

  width: 100% !important;
  max-width: 1480px !important;

  margin: 0 auto 42px !important;
  padding: 0 32px !important;
}

.news-article .news-article-body {
  width: 100% !important;
  max-width: none !important;
}

.news-article .news-article-body > p,
.news-article .news-article-body h2,
.news-article .news-quote {
  max-width: none !important;
  width: 100% !important;
}

.news-article .news-article-body > p {
  font-size: 20px !important;
  line-height: 1.68 !important;
}

.news-article .news-quote {
  margin: 34px 0 !important;
}

.news-article .news-sidebar {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: stretch !important;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  width: 100% !important;
}

/* ================================================= */
/* NEWS ARTICLE - REFINO EDITORIAL FINAL */
/* acabamento prático da página-base de notícia */
/* ================================================= */

/* Hero mais editorial */
.news-article .news-hero-image {
  box-shadow:
    0 22px 36px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22) !important;
}

.news-article .news-hero-image img {
  min-height: 360px !important;
}

/* Texto: mais presença sem virar muralha */
.news-article .news-article-body {
  padding-top: 4px !important;
}

.news-article .news-article-body h2 {
  margin: 38px 0 16px !important;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 30px !important;
  line-height: 1.05 !important;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  margin: 8px 14px 0 0 !important;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 70px !important;
  line-height: 0.78 !important;
  font-weight: 900;
}

/* Quote premium */
.news-article .news-quote {
  position: relative !important;

  min-height: 150px !important;
  padding: 34px 104px 32px 66px !important;

  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;

  border: 1px solid var(--line) !important;
  background:
    radial-gradient(circle at 92% 18%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.14) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.24),
    0 10px 22px rgba(43, 26, 16, 0.04) !important;
}

.news-article .news-quote::before {
  content: "“" !important;

  position: absolute !important;
  left: 28px !important;
  top: 28px !important;

  color: var(--purple) !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 48px !important;
  line-height: 1 !important;
  opacity: 0.72 !important;
}

.news-article .news-quote::after {
  content: "" !important;

  position: absolute !important;
  right: 30px !important;
  bottom: 24px !important;

  width: 70px !important;
  height: 70px !important;

  background-image: url("assets/icons/veredito-gema.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;

  opacity: 0.70 !important;
}

.news-article .news-quote p {
  margin: 0 0 16px !important;

  color: var(--purple) !important;
  font-size: 25px !important;
  line-height: 1.36 !important;
  font-style: italic !important;
  font-weight: 700 !important;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.76) !important;
  font-family: var(--font-title, Georgia, "Times New Roman", serif) !important;
  font-size: 12px !important;
  font-style: normal !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
}

/* Sidebar mais premium */
.news-article .news-sidebar {
  gap: 24px !important;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  padding: 28px 26px !important;

  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.05), transparent 34%),
    rgba(255, 246, 222, 0.13) !important;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  inset: 13px !important;
}

.news-article .sidebar-kicker {
  margin-bottom: 18px !important;
  padding: 8px 11px !important;

  color: var(--purple) !important;
  background: rgba(74, 35, 107, 0.10) !important;
  border: 1px solid rgba(74, 35, 107, 0.24) !important;

  font-size: 10.5px !important;
}

.news-article .news-summary-list {
  gap: 18px !important;
}

.news-article .news-summary-list li {
  grid-template-columns: 38px 1fr !important;
  gap: 13px !important;
  align-items: start !important;
}

.news-article .news-summary-list img {
  width: 28px !important;
  height: 28px !important;

  object-fit: contain !important;
  opacity: 0.92 !important;
}

.news-article .news-summary-list span {
  font-size: 16px !important;
  line-height: 1.38 !important;
}

/* Tópicos */
.news-article .news-tags {
  gap: 9px !important;
}

.news-article .news-tags a {
  padding: 8px 10px !important;

  font-size: 10px !important;
  background: rgba(255, 246, 222, 0.16) !important;
}

/* Discord */
.news-article .news-discord-art img {
  max-width: 210px !important;
  max-height: 165px !important;
}

.news-article .news-discord-box h2 {
  font-size: 24px !important;
  line-height: 1.02 !important;
}

.news-article .news-discord-box p {
  font-size: 16px !important;
  line-height: 1.44 !important;
}

.news-article .news-discord-box .lg-btn {
  min-height: 48px !important;
}

/* Mais notícias: vitrine mais forte */
.news-article .more-news-section {
  max-width: 1500px !important;
  margin: 0 auto 34px !important;
  padding: 34px 34px 38px !important;
}

.news-article .more-news-grid {
  gap: 22px !important;
}

.news-article .news-card {
  min-height: 345px !important;
}

.news-article .news-card-image {
  min-height: 190px !important;
}

.news-article .news-card-copy {
  padding: 18px 18px 20px !important;
}

.news-article .news-card-copy h3 {
  font-size: 18.5px !important;
  line-height: 1.10 !important;
}

.news-article .news-card-copy time {
  margin-bottom: 11px !important;
}

.news-article .news-card-copy small {
  font-size: 13px !important;
}

/* Newsletter: mais bloco especial, menos formulário solto */
.news-article .newsletter-panel {
  max-width: 1500px !important;
  margin: 0 auto 34px !important;

  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px) !important;
  padding: 30px 36px !important;

  background:
    radial-gradient(circle at 8% 50%, rgba(86, 32, 129, 0.06), transparent 30%),
    rgba(255, 246, 222, 0.14) !important;
}

.news-article .newsletter-art img {
  max-width: 200px !important;
  max-height: 160px !important;
}

.news-article .newsletter-copy h2 {
  font-size: 25px !important;
  line-height: 1.05 !important;
}

.news-article .newsletter-copy p {
  font-size: 16.5px !important;
}

.news-article .newsletter-form input {
  min-height: 52px !important;
}

.news-article .newsletter-form .lg-btn,
.news-article .newsletter-form button {
  min-height: 52px !important;
  white-space: nowrap !important;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .news-article .news-hero {
    padding-top: 62px !important;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr !important;
    max-width: 980px !important;
    gap: 28px !important;

    padding: 0 32px !important;
  }

  .news-article .news-sidebar {
    max-width: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .news-article .newsletter-form {
    max-width: 640px !important;
    width: 100% !important;
    margin: 0 auto !important;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .news-article .news-sidebar {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding-top: 34px !important;
  }

  .news-article .news-label-row {
    gap: 14px !important;
  }

  .news-article .news-content-layout {
    padding: 0 20px !important;
    margin-bottom: 34px !important;
  }

  .news-article .news-article-body > p {
    font-size: 18px !important;
    line-height: 1.62 !important;
  }

  .news-article .news-article-body .lead-paragraph::first-letter {
    font-size: 58px !important;
    margin-right: 10px !important;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 50px !important;
  }

  .news-article .news-quote::after {
    display: none !important;
  }

  .news-article .news-quote p {
    font-size: 21px !important;
  }

  .news-article .more-news-section,
  .news-article .newsletter-panel {
    margin-left: 20px !important;
    margin-right: 20px !important;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr !important;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr !important;
  }
}
/* ================================================= */
/* CATEGORIA - JOGOS */
/* Cole no final do style.css */
/* Escopo: .category-games */
/* ================================================= */

.category-games .category-hero {
  padding: 54px 56px 28px;
}

.category-games .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .category-breadcrumb a {
  text-decoration: none;
}

.category-games .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-games .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 28px 56px;

  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 42px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-games .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-hero-card::after {
  content: "";
  position: absolute;
  right: 28px;
  top: 22px;

  width: 190px;
  height: 190px;

  background-image: url("../assets/icons/cat_jogos.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;

  opacity: 0.06;
  pointer-events: none;
}

.category-games .category-hero-icon {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;
}

.category-games .category-hero-icon img {
  width: 220px;
  max-height: 170px;
  object-fit: contain;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-games .category-hero-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-hero-copy .review-label {
  margin-bottom: 12px;
}

.category-games .category-hero-copy h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(56px, 5vw, 88px);
  line-height: 0.92;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.04em;
}

.category-games .category-hero-copy p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 22px;
  line-height: 1.30;
}

/* Filtros */

.category-games .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-games .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-games .category-filter:hover,
.category-games .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-games .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-games .category-main {
  min-width: 0;
}

/* Destaque */

.category-games .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 36px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-games .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-games .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .featured-review-content {
  position: relative;
  z-index: 2;

  width: min(100%, 560px);
}

.category-games .featured-review-content .post-category {
  position: static;
  margin-bottom: 18px;
}

.category-games .featured-review-content h2 {
  margin: 0 0 18px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-games .featured-review-content p {
  max-width: 440px;
  margin: 0 0 24px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-games .featured-review-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  flex-wrap: wrap;
}

.category-games .featured-review-bottom a {
  color: #f8e7bd;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .featured-review-bottom a:hover {
  color: var(--cream);
}

.category-games .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-games .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-games .rating-cats-featured {
  gap: 5px;
}

.category-games .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid de cards */

.category-games .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-games .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 390px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-games .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-games .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-games .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-games .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-games .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-games .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-games .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-games .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-games .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-games .category-pagination a,
.category-games .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .category-pagination a.active,
.category-games .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-games .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-games .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-games .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-games .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-games .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-games .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-games .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-games .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-games .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-games .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-games .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-games .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-games .top-rating-box {
  text-align: center;
}

.category-games .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-games .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-games .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-games .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-games .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-games .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-games .explore-box nav a:hover {
  color: var(--purple);
}

.category-games .explore-box nav span {
  font-size: 20px;
}

/* Twitch CTA */

.category-games .twitch-category-box {
  text-align: center;
}

.category-games .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-games .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-games .twitch-category-box h2 {
  color: var(--purple);
}

.category-games .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-games .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-games .category-layout {
    grid-template-columns: 1fr;
  }

  .category-games .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-hero-card {
    grid-template-columns: 220px 1fr;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero {
    padding: 36px 20px 24px;
  }

  .category-games .category-hero-card {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 24px;
    text-align: center;
  }

  .category-games .category-hero-icon img {
    width: 150px;
  }

  .category-games .category-hero-copy h1 {
    font-size: 48px;
  }

  .category-games .category-hero-copy p {
    font-size: 18px;
  }

  .category-games .category-filter-row,
  .category-games .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-games .category-filter {
    flex: 1 1 180px;
  }

  .category-games .featured-review-card {
    min-height: 400px;
    padding: 28px 22px;
  }

  .category-games .category-card-grid,
  .category-games .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-games .category-review-card {
    min-height: 370px;
  }

  .category-games .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* CATEGORIA - JOGOS */
/* Cole no final do style.css */
/* Escopo: .category-games */
/* ================================================= */

.category-games .category-hero {
  padding: 54px 56px 28px;
}

.category-games .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .category-breadcrumb a {
  text-decoration: none;
}

.category-games .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-games .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 28px 56px;

  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 42px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-games .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-hero-card::after {
  content: "";
  position: absolute;
  right: 28px;
  top: 22px;

  width: 190px;
  height: 190px;

  background-image: url("../assets/icons/cat_jogos.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;

  opacity: 0.06;
  pointer-events: none;
}

.category-games .category-hero-icon {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;
}

.category-games .category-hero-icon img {
  width: 220px;
  max-height: 170px;
  object-fit: contain;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-games .category-hero-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-hero-copy .review-label {
  margin-bottom: 12px;
}

.category-games .category-hero-copy h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(56px, 5vw, 88px);
  line-height: 0.92;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.04em;
}

.category-games .category-hero-copy p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 22px;
  line-height: 1.30;
}

/* Filtros */

.category-games .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-games .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-games .category-filter:hover,
.category-games .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-games .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-games .category-main {
  min-width: 0;
}

/* Destaque */

.category-games .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 36px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-games .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-games .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .featured-review-content {
  position: relative;
  z-index: 2;

  width: min(100%, 560px);
}

.category-games .featured-review-content .post-category {
  position: static;
  margin-bottom: 18px;
}

.category-games .featured-review-content h2 {
  margin: 0 0 18px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-games .featured-review-content p {
  max-width: 440px;
  margin: 0 0 24px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-games .featured-review-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  flex-wrap: wrap;
}

.category-games .featured-review-bottom a {
  color: #f8e7bd;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .featured-review-bottom a:hover {
  color: var(--cream);
}

.category-games .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-games .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-games .rating-cats-featured {
  gap: 5px;
}

.category-games .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid de cards */

.category-games .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-games .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 390px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-games .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-games .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-games .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-games .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-games .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-games .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-games .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-games .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-games .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-games .category-pagination a,
.category-games .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .category-pagination a.active,
.category-games .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-games .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-games .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-games .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-games .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-games .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-games .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-games .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-games .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-games .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-games .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-games .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-games .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-games .top-rating-box {
  text-align: center;
}

.category-games .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-games .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-games .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-games .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-games .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-games .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-games .explore-box nav a:hover {
  color: var(--purple);
}

.category-games .explore-box nav span {
  font-size: 20px;
}

/* Twitch CTA */

.category-games .twitch-category-box {
  text-align: center;
}

.category-games .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-games .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-games .twitch-category-box h2 {
  color: var(--purple);
}

.category-games .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-games .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-games .category-layout {
    grid-template-columns: 1fr;
  }

  .category-games .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-hero-card {
    grid-template-columns: 220px 1fr;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero {
    padding: 36px 20px 24px;
  }

  .category-games .category-hero-card {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 24px;
    text-align: center;
  }

  .category-games .category-hero-icon img {
    width: 150px;
  }

  .category-games .category-hero-copy h1 {
    font-size: 48px;
  }

  .category-games .category-hero-copy p {
    font-size: 18px;
  }

  .category-games .category-filter-row,
  .category-games .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-games .category-filter {
    flex: 1 1 180px;
  }

  .category-games .featured-review-card {
    min-height: 400px;
    padding: 28px 22px;
  }

  .category-games .category-card-grid,
  .category-games .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-games .category-review-card {
    min-height: 370px;
  }

  .category-games .category-pagination {
    flex-wrap: wrap;
  }
}

/* ================================================= */
/* CATEGORIA JOGOS - REFINO DO HERO + GRID 3x3 */
/* controle ao lado do título, sem tag e sem imagem fantasma */
/* ================================================= */

.category-games .category-hero {
  padding-top: 58px !important;
  padding-bottom: 24px !important;
}

.category-games .category-hero-card {
  width: min(100%, 1180px) !important;
  min-height: 210px !important;

  display: block !important;
  padding: 34px 54px !important;
}

.category-games .category-hero-card::after {
  display: none !important;
}

.category-games .category-hero-copy {
  width: 100% !important;
}

.category-games .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 42px;

  width: 100%;
}

.category-games .category-title-row .category-hero-icon {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-games .category-title-row .category-hero-icon img {
  width: 230px !important;
  max-height: 170px !important;
  object-fit: contain !important;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92) !important;
}

.category-games .category-title-row h1 {
  margin: 0 0 12px !important;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px) !important;
  line-height: 0.90 !important;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-games .category-title-row p {
  max-width: 660px !important;
  margin: 0 !important;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px !important;
  line-height: 1.30 !important;
}

/* Remove a tag Categoria antiga, caso algum HTML antigo ainda tenha ficado */
.category-games .category-hero-copy > .review-label {
  display: none !important;
}

/* Grid principal com 3 colunas e 3 linhas no desktop */
.category-games .category-card-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

/* Ajuste de altura para comportar 9 cards com boa leitura */
.category-games .category-review-card {
  min-height: 385px !important;
}

/* Responsivo */
@media (max-width: 1100px) {
  .category-games .category-title-row {
    gap: 28px;
  }

  .category-games .category-title-row .category-hero-icon img {
    width: 170px !important;
  }

  .category-games .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px) !important;
  }

  .category-games .category-title-row p {
    font-size: 19px !important;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero-card {
    padding: 30px 24px !important;
  }

  .category-games .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-games .category-title-row .category-hero-icon img {
    width: 150px !important;
  }

  .category-games .category-title-row h1 {
    font-size: 48px !important;
  }

  .category-games .category-title-row p {
    font-size: 18px !important;
  }
}
/* ================================================= */
/* CATEGORIA - JOGOS */
/* Cole no final do style.css */
/* Escopo: .category-games */
/* ================================================= */

.category-games .category-hero {
  padding: 54px 56px 28px;
}

.category-games .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .category-breadcrumb a {
  text-decoration: none;
}

.category-games .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-games .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 28px 56px;

  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 42px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-games .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-hero-card::after {
  content: "";
  position: absolute;
  right: 28px;
  top: 22px;

  width: 190px;
  height: 190px;

  background-image: url("../assets/icons/cat_jogos.png");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;

  opacity: 0.06;
  pointer-events: none;
}

.category-games .category-hero-icon {
  position: relative;
  z-index: 2;

  display: grid;
  place-items: center;
}

.category-games .category-hero-icon img {
  width: 220px;
  max-height: 170px;
  object-fit: contain;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-games .category-hero-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-hero-copy .review-label {
  margin-bottom: 12px;
}

.category-games .category-hero-copy h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(56px, 5vw, 88px);
  line-height: 0.92;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.04em;
}

.category-games .category-hero-copy p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 22px;
  line-height: 1.30;
}

/* Filtros */

.category-games .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-games .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-games .category-filter:hover,
.category-games .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-games .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-games .category-main {
  min-width: 0;
}

/* Destaque */

.category-games .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 36px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-games .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-games .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .featured-review-content {
  position: relative;
  z-index: 2;

  width: min(100%, 560px);
}

.category-games .featured-review-content .post-category {
  position: static;
  margin-bottom: 18px;
}

.category-games .featured-review-content h2 {
  margin: 0 0 18px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-games .featured-review-content p {
  max-width: 440px;
  margin: 0 0 24px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-games .featured-review-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  flex-wrap: wrap;
}

.category-games .featured-review-bottom a {
  color: #f8e7bd;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .featured-review-bottom a:hover {
  color: var(--cream);
}

.category-games .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-games .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-games .rating-cats-featured {
  gap: 5px;
}

.category-games .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid de cards */

.category-games .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-games .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 390px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-games .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-games .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-games .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-games .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-games .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-games .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-games .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-games .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-games .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-games .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-games .category-pagination a,
.category-games .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-games .category-pagination a.active,
.category-games .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-games .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-games .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-games .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-games .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-games .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-games .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-games .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-games .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-games .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-games .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-games .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-games .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-games .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-games .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-games .top-rating-box {
  text-align: center;
}

.category-games .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-games .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-games .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-games .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-games .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-games .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-games .explore-box nav a:hover {
  color: var(--purple);
}

.category-games .explore-box nav span {
  font-size: 20px;
}

/* Twitch CTA */

.category-games .twitch-category-box {
  text-align: center;
}

.category-games .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-games .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-games .twitch-category-box h2 {
  color: var(--purple);
}

.category-games .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-games .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-games .category-layout {
    grid-template-columns: 1fr;
  }

  .category-games .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-games .category-hero-card {
    grid-template-columns: 220px 1fr;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero {
    padding: 36px 20px 24px;
  }

  .category-games .category-hero-card {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 28px 24px;
    text-align: center;
  }

  .category-games .category-hero-icon img {
    width: 150px;
  }

  .category-games .category-hero-copy h1 {
    font-size: 48px;
  }

  .category-games .category-hero-copy p {
    font-size: 18px;
  }

  .category-games .category-filter-row,
  .category-games .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-games .category-filter {
    flex: 1 1 180px;
  }

  .category-games .featured-review-card {
    min-height: 400px;
    padding: 28px 22px;
  }

  .category-games .category-card-grid,
  .category-games .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-games .category-review-card {
    min-height: 370px;
  }

  .category-games .category-pagination {
    flex-wrap: wrap;
  }
}

/* ================================================= */
/* CATEGORIA JOGOS - REFINO DO HERO + GRID 3x3 */
/* controle ao lado do título, sem tag e sem imagem fantasma */
/* ================================================= */

.category-games .category-hero {
  padding-top: 58px !important;
  padding-bottom: 24px !important;
}

.category-games .category-hero-card {
  width: min(100%, 1180px) !important;
  min-height: 210px !important;

  display: block !important;
  padding: 34px 54px !important;
}

.category-games .category-hero-card::after {
  display: none !important;
}

.category-games .category-hero-copy {
  width: 100% !important;
}

.category-games .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 42px;

  width: 100%;
}

.category-games .category-title-row .category-hero-icon {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-games .category-title-row .category-hero-icon img {
  width: 230px !important;
  max-height: 170px !important;
  object-fit: contain !important;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92) !important;
}

.category-games .category-title-row h1 {
  margin: 0 0 12px !important;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px) !important;
  line-height: 0.90 !important;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-games .category-title-row p {
  max-width: 660px !important;
  margin: 0 !important;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px !important;
  line-height: 1.30 !important;
}

/* Remove a tag Categoria antiga, caso algum HTML antigo ainda tenha ficado */
.category-games .category-hero-copy > .review-label {
  display: none !important;
}

/* Grid principal com 3 colunas e 3 linhas no desktop */
.category-games .category-card-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

/* Ajuste de altura para comportar 9 cards com boa leitura */
.category-games .category-review-card {
  min-height: 385px !important;
}

/* Responsivo */
@media (max-width: 1100px) {
  .category-games .category-title-row {
    gap: 28px;
  }

  .category-games .category-title-row .category-hero-icon img {
    width: 170px !important;
  }

  .category-games .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px) !important;
  }

  .category-games .category-title-row p {
    font-size: 19px !important;
  }
}

@media (max-width: 900px) {
  .category-games .category-hero-card {
    padding: 30px 24px !important;
  }

  .category-games .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-games .category-title-row .category-hero-icon img {
    width: 150px !important;
  }

  .category-games .category-title-row h1 {
    font-size: 48px !important;
  }

  .category-games .category-title-row p {
    font-size: 18px !important;
  }
}


/* ================================================= */
/* HERO JOGOS - IMAGEM ESTILO MOCKUP */
/* usa uma arte própria no lugar do ícone simples */
/* Salve a imagem em: assets/categories/jogos-hero.png */
/* ================================================= */

.category-games .category-title-row {
  justify-content: flex-start !important;
  gap: 34px !important;
}

.category-games .category-title-row .category-hero-icon {
  width: 290px !important;
  min-width: 290px !important;
}

.category-games .category-title-row .category-hero-icon img {
  width: 100% !important;
  max-width: 290px !important;
  max-height: 190px !important;
  height: auto !important;
  object-fit: contain !important;
  opacity: 0.98 !important;
}

.category-games .category-hero-card {
  padding: 34px 46px !important;
}

.category-games .category-title-row h1 {
  margin-bottom: 10px !important;
}

.category-games .category-title-row p {
  max-width: 620px !important;
}

@media (max-width: 1100px) {
  .category-games .category-title-row .category-hero-icon {
    width: 220px !important;
    min-width: 220px !important;
  }

  .category-games .category-title-row .category-hero-icon img {
    max-width: 220px !important;
    max-height: 150px !important;
  }
}

@media (max-width: 900px) {
  .category-games .category-title-row .category-hero-icon {
    width: 170px !important;
    min-width: 170px !important;
  }

  .category-games .category-title-row .category-hero-icon img {
    max-width: 170px !important;
    max-height: 120px !important;
  }
}
/* ==========================================
   CARD DE DESTAQUE - AJUSTE FINO
========================================== */

.games-featured-card {
  position: relative;
  min-height: 430px;
  border: 1px solid #6b4a22;
  background:
    linear-gradient(90deg, rgba(18, 8, 3, 0.92) 0%, rgba(18, 8, 3, 0.78) 34%, rgba(18, 8, 3, 0.28) 72%, rgba(18, 8, 3, 0.10) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.games-featured-card::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(216, 183, 116, 0.35);
  pointer-events: none;
}

.featured-badge {
  position: absolute;
  top: 18px;
  left: 18px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  background: #c79a52;
  color: #24150f;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.games-featured-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 430px;
  max-width: 520px;
  padding: 92px 34px 30px 34px;
  color: #f7e6bf;
}

.games-featured-content h2 {
  margin: 0;
  color: #f8e7bd;
  font-size: clamp(44px, 4vw, 68px);
  line-height: 0.94;
  text-transform: uppercase;
}

.featured-category-tag {
  display: inline-flex;
  width: fit-content;
  margin-top: 18px;
  padding: 7px 12px;
  background: #6d28a8;
  color: #fff3d6;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
}

.games-featured-content p {
  margin: 22px 0 0;
  max-width: 420px;
  color: #f6dfae;
  font-size: 18px;
  line-height: 1.45;
}

.games-featured-footer {
  margin-top: 28px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  width: 100%;
}

.featured-rating-row {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.featured-cats {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 0;
}

.featured-cats img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.featured-rating-row strong {
  color: #f8e7bd;
  font-size: 24px;
  line-height: 1;
}

.featured-review-link {
  margin-left: auto;
  align-self: flex-end;
  color: #f8e7bd;
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
}

.featured-review-link:hover {
  opacity: 0.85;
}

/* Responsivo */
@media (max-width: 900px) {
  .games-featured-card {
    min-height: 380px;
  }

  .games-featured-content {
    max-width: 100%;
    min-height: 380px;
    padding: 86px 24px 24px;
  }

  .games-featured-content h2 {
    font-size: 42px;
  }

  .games-featured-footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .featured-review-link {
    margin-left: 0;
  }
}
/* ================================================= */
/* CATEGORIA JOGOS - AJUSTE FINO DO CARD DESTAQUE */
/* desce título e joga "Ver review" para a direita */
/* ================================================= */

.category-games .featured-review-card {
  align-items: flex-end !important;
  padding: 42px 44px 38px !important;
}

.category-games .featured-review-content {
  width: 100% !important;
  max-width: none !important;
  padding-top: 34px !important;
}

/* Desce o título sem estourar a composição */
.category-games .featured-review-content h2 {
  max-width: 690px !important;
  margin-top: 22px !important;
  margin-bottom: 20px !important;
}

/* Tag fica abaixo do título */
.category-games .featured-review-content .featured-category-tag {
  position: static !important;
  display: inline-flex !important;
  width: fit-content !important;
  margin: 0 0 20px !important;
}

/* Texto continua elegante e controlado */
.category-games .featured-review-content p {
  max-width: 560px !important;
  margin-bottom: 0 !important;
}

/* Rodapé ocupa toda a largura do card */
.category-games .featured-review-bottom {
  width: 100% !important;
  max-width: none !important;

  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 28px !important;

  margin-top: 30px !important;
}

/* Nota fica à esquerda */
.category-games .featured-review-bottom .category-rating {
  flex: 0 0 auto !important;
}

/* Link vai para o canto direito */
.category-games .featured-review-link,
.category-games .featured-review-bottom > a {
  margin-left: auto !important;
  margin-right: 8px !important;

  align-self: center !important;
  justify-self: flex-end !important;

  color: #f8e7bd !important;
  font-family: var(--font-title, Georgia, "Times New Roman", serif) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-align: right !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.category-games .featured-review-link:hover,
.category-games .featured-review-bottom > a:hover {
  color: var(--cream) !important;
  transform: translateX(3px);
}

/* Responsivo */
@media (max-width: 900px) {
  .category-games .featured-review-card {
    padding: 34px 24px 28px !important;
  }

  .category-games .featured-review-content {
    padding-top: 46px !important;
  }

  .category-games .featured-review-bottom {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  .category-games .featured-review-link,
  .category-games .featured-review-bottom > a {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}
/* ================================================= */
/* CATEGORIA JOGOS - CORREÇÃO SIDEBAR DESTAQUES */
/* evita colisão com .mini-review-card global */
/* ================================================= */

.category-games .sidebar-review-item {
  position: relative !important;
  isolation: auto !important;

  display: grid !important;
  grid-template-columns: 94px 1fr !important;
  gap: 14px !important;
  align-items: start !important;

  width: 100% !important;
  min-height: auto !important;
  aspect-ratio: auto !important;

  padding: 0 0 16px !important;
  margin-bottom: 16px !important;

  color: var(--ink) !important;
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24) !important;
  border-radius: 0 !important;

  text-shadow: none !important;
  text-decoration: none !important;
  text-transform: none !important;
  overflow: visible !important;
}

.category-games .sidebar-review-item::before,
.category-games .sidebar-review-item::after {
  display: none !important;
}

.category-games .sidebar-review-item img {
  width: 94px !important;
  height: 94px !important;

  object-fit: cover !important;
  border: 1px solid rgba(164, 112, 52, 0.38) !important;
}

.category-games .sidebar-review-item strong {
  display: block !important;
  margin-bottom: 7px !important;

  color: var(--ink) !important;
  font-family: var(--font-title, Georgia, "Times New Roman", serif) !important;
  font-size: 15px !important;
  line-height: 1.12 !important;
  text-transform: uppercase !important;
}

.category-games .sidebar-review-item em {
  display: inline-flex !important;
  width: fit-content !important;
  margin-bottom: 7px !important;
  padding: 5px 7px !important;

  color: var(--cream) !important;
  background: var(--purple) !important;

  font-size: 10px !important;
  font-style: normal !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
}

.category-games .sidebar-review-item small {
  display: block !important;

  color: rgba(43, 26, 16, 0.78) !important;
  font-size: 13px !important;
  line-height: 1.28 !important;
}
/* ================================================= */
/* CATEGORIA - FILMES WP READY */
/* Base visual herdada da categoria Jogos */
/* ================================================= */

.category-films .category-hero {
  padding: 58px 56px 24px;
}

.category-films .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-films .category-breadcrumb a {
  text-decoration: none;
}

.category-films .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-films .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-films .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-films .category-hero-card::after {
  display: none;
}

.category-films .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-films .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-films .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;

  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-films .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;

  object-fit: contain;
  opacity: 0.98;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-films .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-films .category-title-row p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-films .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-films .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-films .category-filter:hover,
.category-films .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-films .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-films .category-main {
  min-width: 0;
}

/* Destaque */

.category-films .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-films .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-films .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-films .featured-review-content {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-films .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-films .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-films .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-films .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-films .featured-review-link,
.category-films .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-films .featured-review-link:hover,
.category-films .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-films .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-films .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-films .rating-cats-featured {
  gap: 5px;
}

.category-films .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-films .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-films .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-films .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-films .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-films .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-films .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-films .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-films .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-films .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-films .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-films .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-films .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-films .category-pagination a,
.category-films .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-films .category-pagination a.active,
.category-films .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-films .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-films .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-films .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-films .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-films .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-films .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-films .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-films .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-films .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-films .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-films .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-films .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-films .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-films .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-films .top-rating-box {
  text-align: center;
}

.category-films .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-films .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-films .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-films .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-films .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-films .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-films .explore-box nav a:hover {
  color: var(--purple);
}

.category-films .explore-box nav span {
  font-size: 20px;
}

/* CTA */

.category-films .twitch-category-box {
  text-align: center;
}

.category-films .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-films .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-films .twitch-category-box h2 {
  color: var(--purple);
}

.category-films .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-films .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-films .category-layout {
    grid-template-columns: 1fr;
  }

  .category-films .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-films .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-films .category-title-row {
    gap: 28px;
  }

  .category-films .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-films .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-films .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px);
  }

  .category-films .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-films .category-hero {
    padding: 36px 20px 24px;
  }

  .category-films .category-hero-card {
    padding: 30px 24px;
  }

  .category-films .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-films .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-films .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-films .category-title-row h1 {
    font-size: 48px;
  }

  .category-films .category-title-row p {
    font-size: 18px;
  }

  .category-films .category-filter-row,
  .category-films .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-films .category-filter {
    flex: 1 1 180px;
  }

  .category-films .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-films .featured-review-content {
    padding-top: 46px;
  }

  .category-films .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-films .featured-review-link,
  .category-films .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-films .category-card-grid,
  .category-films .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-films .category-review-card {
    min-height: 370px;
  }

  .category-films .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* CATEGORIA - SÉRIES WP READY */
/* Base visual herdada da categoria Jogos/Filmes */
/* ================================================= */

.category-series .category-hero {
  padding: 58px 56px 24px;
}

.category-series .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-series .category-breadcrumb a {
  text-decoration: none;
}

.category-series .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-series .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-series .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-series .category-hero-card::after {
  display: none;
}

.category-series .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-series .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-series .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;

  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-series .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;

  object-fit: contain;
  opacity: 0.98;

  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-series .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-series .category-title-row p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-series .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-series .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-series .category-filter:hover,
.category-series .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-series .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-series .category-main {
  min-width: 0;
}

/* Destaque */

.category-series .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;

  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-series .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-series .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-series .featured-review-content {
  position: relative;
  z-index: 2;

  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-series .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-series .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-series .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-series .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-series .featured-review-link,
.category-series .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-series .featured-review-link:hover,
.category-series .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-series .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-series .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-series .rating-cats-featured {
  gap: 5px;
}

.category-series .rating-cats-featured img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-series .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-series .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-series .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;

  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-series .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-series .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-series .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-series .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-series .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-series .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-series .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-series .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-series .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;

  margin: 26px auto 0;
}

.category-series .category-pagination a,
.category-series .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-series .category-pagination a.active,
.category-series .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-series .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-series .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-series .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-series .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-series .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-series .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-series .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;

  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-series .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-series .sidebar-highlight img {
  width: 94px;
  height: 94px;

  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-series .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-series .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-series .sidebar-highlight small {
  display: block;

  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-series .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-series .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-series .top-rating-box {
  text-align: center;
}

.category-series .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-series .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-series .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-series .top-rating-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-series .explore-box nav {
  display: grid;
  gap: 0;

  margin-bottom: 18px;
}

.category-series .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-series .explore-box nav a:hover {
  color: var(--purple);
}

.category-series .explore-box nav span {
  font-size: 20px;
}

/* CTA */

.category-series .twitch-category-box {
  text-align: center;
}

.category-series .twitch-category-icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.16),
    inset 0 0 0 1px rgba(255, 243, 214, 0.22);
}

.category-series .twitch-category-icon img {
  width: 30px;
  height: 30px;

  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-series .twitch-category-box h2 {
  color: var(--purple);
}

.category-series .twitch-category-box p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-series .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-series .category-layout {
    grid-template-columns: 1fr;
  }

  .category-series .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-series .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-series .category-title-row {
    gap: 28px;
  }

  .category-series .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-series .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-series .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px);
  }

  .category-series .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-series .category-hero {
    padding: 36px 20px 24px;
  }

  .category-series .category-hero-card {
    padding: 30px 24px;
  }

  .category-series .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-series .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-series .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-series .category-title-row h1 {
    font-size: 48px;
  }

  .category-series .category-title-row p {
    font-size: 18px;
  }

  .category-series .category-filter-row,
  .category-series .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-series .category-filter {
    flex: 1 1 180px;
  }

  .category-series .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-series .featured-review-content {
    padding-top: 46px;
  }

  .category-series .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-series .featured-review-link,
  .category-series .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-series .category-card-grid,
  .category-series .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-series .category-review-card {
    min-height: 370px;
  }

  .category-series .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* CATEGORIA - ANIMES WP READY */
/* Base visual herdada de Jogos / Filmes & Séries */
/* Cole no final do style.css */
/* ================================================= */

.category-animes .category-hero {
  padding: 58px 56px 24px;
}

.category-animes .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-animes .category-breadcrumb a {
  text-decoration: none;
}

.category-animes .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-animes .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-animes .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-animes .category-hero-card::after {
  display: none;
}

.category-animes .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-animes .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-animes .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-animes .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;
  object-fit: contain;
  opacity: 0.98;
  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-animes .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(62px, 5vw, 92px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-animes .category-title-row p {
  max-width: 620px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-animes .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-animes .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-animes .category-filter:hover,
.category-animes .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-animes .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-animes .category-main {
  min-width: 0;
}

/* Destaque */

.category-animes .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-animes .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-animes .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-animes .featured-review-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-animes .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-animes .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-animes .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-animes .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-animes .featured-review-link,
.category-animes .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-animes .featured-review-link:hover,
.category-animes .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-animes .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-animes .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-animes .rating-cats-featured {
  gap: 5px;
}

.category-animes .rating-cats-featured img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-animes .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-animes .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-animes .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-animes .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-animes .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-animes .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-animes .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-animes .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-animes .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-animes .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-animes .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-animes .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 26px auto 0;
}

.category-animes .category-pagination a,
.category-animes .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-animes .category-pagination a.active,
.category-animes .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-animes .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-animes .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-animes .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-animes .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-animes .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-animes .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-animes .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-animes .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-animes .sidebar-highlight img {
  width: 94px;
  height: 94px;
  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-animes .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-animes .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-animes .sidebar-highlight small {
  display: block;
  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-animes .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-animes .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-animes .top-rating-box {
  text-align: center;
}

.category-animes .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-animes .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-animes .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-animes .top-rating-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-animes .explore-box nav {
  display: grid;
  gap: 0;
  margin-bottom: 18px;
}

.category-animes .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-animes .explore-box nav a:hover {
  color: var(--purple);
}

.category-animes .explore-box nav span {
  font-size: 20px;
}

/* CTA com badge do YouTube */

.category-animes .twitch-category-box {
  text-align: center;
}

.category-animes .youtube-badge {
  width: 64px;
  height: 44px;
  margin: 0 auto 18px;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 12px;
  background: #d92d27;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.category-animes .youtube-badge img {
  width: 26px;
  height: 26px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-animes .twitch-category-box h2 {
  color: var(--purple);
}

.category-animes .twitch-category-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-animes .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-animes .category-layout {
    grid-template-columns: 1fr;
  }

  .category-animes .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-animes .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-animes .category-title-row {
    gap: 28px;
  }

  .category-animes .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-animes .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-animes .category-title-row h1 {
    font-size: clamp(48px, 7vw, 72px);
  }

  .category-animes .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-animes .category-hero {
    padding: 36px 20px 24px;
  }

  .category-animes .category-hero-card {
    padding: 30px 24px;
  }

  .category-animes .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-animes .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-animes .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-animes .category-title-row h1 {
    font-size: 48px;
  }

  .category-animes .category-title-row p {
    font-size: 18px;
  }

  .category-animes .category-filter-row,
  .category-animes .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-animes .category-filter {
    flex: 1 1 180px;
  }

  .category-animes .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-animes .featured-review-content {
    padding-top: 46px;
  }

  .category-animes .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-animes .featured-review-link,
  .category-animes .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-animes .category-card-grid,
  .category-animes .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-animes .category-review-card {
    min-height: 370px;
  }

  .category-animes .category-pagination {
    flex-wrap: wrap;
  }
}
/* ============================= */
/* CTA LATERAL - TWITCH */
/* ============================= */

.category-cta-card,
.cta-card-twitch {
  position: relative;
  padding: 28px 22px 22px;
  text-align: center;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.category-cta-card::before,
.cta-card-twitch::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-cta-icon {
  width: 74px;
  height: 74px;
  margin: 0 auto 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--purple);
  box-shadow: 0 10px 18px rgba(86, 32, 129, 0.18);
  position: relative;
  z-index: 2;
}

.category-cta-icon img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  display: block;
  filter: brightness(0) invert(1);
}

.category-cta-card h3,
.cta-card-twitch h3 {
  position: relative;
  z-index: 2;
  margin: 0 0 16px;
  color: var(--purple);
  font-size: 20px;
  line-height: 1.05;
  text-transform: uppercase;
}

.category-cta-card p,
.cta-card-twitch p {
  position: relative;
  z-index: 2;
  margin: 0 0 22px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.5;
}

.category-cta-button {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 54px;
  padding: 0 18px;
  border: 1px solid var(--purple);
  background: var(--purple);
  color: var(--cream);
  font: 700 14px Georgia, "Times New Roman", serif;
  text-transform: uppercase;
  text-decoration: none;
  transition: 0.2s ease;
}

.category-cta-button:hover {
  background: var(--purple-dark);
  border-color: var(--purple-dark);
  transform: translateY(-2px);
}
/* ================================================= */
/* CATEGORIA - LIVROS & HQS WP READY */
/* Base visual herdada de Jogos / Filmes & Séries */
/* Cole no final do style.css */
/* ================================================= */

.category-books .category-hero {
  padding: 58px 56px 24px;
}

.category-books .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-books .category-breadcrumb a {
  text-decoration: none;
}

.category-books .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-books .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-books .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-books .category-hero-card::after {
  display: none;
}

.category-books .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-books .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-books .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-books .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;
  object-fit: contain;
  opacity: 0.98;
  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-books .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(54px, 4.5vw, 82px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-books .category-title-row p {
  max-width: 650px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-books .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-books .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-books .category-filter:hover,
.category-books .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-books .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-books .category-main {
  min-width: 0;
}

/* Destaque */

.category-books .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-books .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-books .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-books .featured-review-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-books .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-books .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-books .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-books .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-books .featured-review-link,
.category-books .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-books .featured-review-link:hover,
.category-books .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-books .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-books .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-books .rating-cats-featured {
  gap: 5px;
}

.category-books .rating-cats-featured img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-books .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-books .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-books .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-books .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-books .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-books .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-books .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-books .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-books .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-books .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-books .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-books .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 26px auto 0;
}

.category-books .category-pagination a,
.category-books .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-books .category-pagination a.active,
.category-books .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-books .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-books .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-books .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-books .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-books .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-books .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-books .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-books .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-books .sidebar-highlight img {
  width: 94px;
  height: 94px;
  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-books .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-books .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-books .sidebar-highlight small {
  display: block;
  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-books .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-books .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-books .top-rating-box {
  text-align: center;
}

.category-books .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-books .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-books .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-books .top-rating-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-books .explore-box nav {
  display: grid;
  gap: 0;
  margin-bottom: 18px;
}

.category-books .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-books .explore-box nav a:hover {
  color: var(--purple);
}

.category-books .explore-box nav span {
  font-size: 20px;
}

/* CTA Clube do livro */

.category-books .twitch-category-box {
  text-align: center;
}

.category-books .book-club-badge {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;
  background: var(--purple);

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.category-books .book-club-badge img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-books .twitch-category-box h2 {
  color: var(--purple);
}

.category-books .twitch-category-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-books .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-books .category-layout {
    grid-template-columns: 1fr;
  }

  .category-books .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-books .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-books .category-title-row {
    gap: 28px;
  }

  .category-books .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-books .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-books .category-title-row h1 {
    font-size: clamp(42px, 6.8vw, 66px);
  }

  .category-books .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-books .category-hero {
    padding: 36px 20px 24px;
  }

  .category-books .category-hero-card {
    padding: 30px 24px;
  }

  .category-books .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-books .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-books .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-books .category-title-row h1 {
    font-size: 42px;
  }

  .category-books .category-title-row p {
    font-size: 18px;
  }

  .category-books .category-filter-row,
  .category-books .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-books .category-filter {
    flex: 1 1 180px;
  }

  .category-books .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-books .featured-review-content {
    padding-top: 46px;
  }

  .category-books .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-books .featured-review-link,
  .category-books .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-books .category-card-grid,
  .category-books .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-books .category-review-card {
    min-height: 370px;
  }

  .category-books .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* CATEGORIA - RETROGAMING WP READY */
/* Base visual herdada de Jogos / categorias anteriores */
/* Cole no final do style.css */
/* ================================================= */

.category-retrogaming .category-hero {
  padding: 58px 56px 24px;
}

.category-retrogaming .category-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1180px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.category-retrogaming .category-breadcrumb a {
  text-decoration: none;
}

.category-retrogaming .category-breadcrumb a:hover {
  color: var(--purple);
}

.category-retrogaming .category-hero-card {
  position: relative;

  width: min(100%, 1180px);
  min-height: 210px;
  margin: 0 auto;
  padding: 34px 46px;

  display: block;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 85% 20%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.category-retrogaming .category-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-retrogaming .category-hero-card::after {
  display: none;
}

.category-retrogaming .category-hero-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}

.category-retrogaming .category-title-row {
  position: relative;
  z-index: 2;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 34px;

  width: 100%;
}

.category-retrogaming .category-title-row .category-hero-icon {
  width: 290px;
  min-width: 290px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
}

.category-retrogaming .category-title-row .category-hero-icon img {
  width: 100%;
  max-width: 290px;
  max-height: 190px;
  height: auto;
  object-fit: contain;
  opacity: 0.98;
  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

.category-retrogaming .category-title-row h1 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(54px, 4.5vw, 82px);
  line-height: 0.90;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.category-retrogaming .category-title-row p {
  max-width: 660px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.30;
}

/* Filtros */

.category-retrogaming .category-filter-row {
  width: min(100%, 1500px);
  margin: 28px auto 24px;
  padding: 0 32px;

  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.category-retrogaming .category-filter {
  min-height: 48px;
  padding: 0 22px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.category-retrogaming .category-filter:hover,
.category-retrogaming .category-filter.active {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
  box-shadow: 0 10px 18px rgba(43, 26, 16, 0.12);
}

/* Layout principal */

.category-retrogaming .category-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.category-retrogaming .category-main {
  min-width: 0;
}

/* Destaque */

.category-retrogaming .featured-review-card {
  position: relative;
  min-height: 430px;
  margin-bottom: 24px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.78) 36%, rgba(20, 10, 5, 0.34) 70%, rgba(20, 10, 5, 0.12) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.category-retrogaming .featured-review-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.category-retrogaming .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-retrogaming .featured-review-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: none;
  padding-top: 34px;
}

.category-retrogaming .featured-review-content h2 {
  max-width: 690px;
  margin: 22px 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.category-retrogaming .featured-review-content .featured-category-tag {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.category-retrogaming .featured-review-content p {
  max-width: 560px;
  margin: 0;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.category-retrogaming .featured-review-bottom {
  width: 100%;
  max-width: none;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;

  margin-top: 30px;
}

.category-retrogaming .featured-review-link,
.category-retrogaming .featured-review-bottom > a {
  margin-left: auto;
  margin-right: 8px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: right;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}

.category-retrogaming .featured-review-link:hover,
.category-retrogaming .featured-review-bottom > a:hover {
  color: var(--cream);
  transform: translateX(3px);
}

.category-retrogaming .category-rating {
  display: flex;
  align-items: center;
  gap: 10px;
}

.category-retrogaming .category-rating strong {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  line-height: 1;
}

.category-retrogaming .rating-cats-featured {
  gap: 5px;
}

.category-retrogaming .rating-cats-featured img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.40));
}

/* Grid */

.category-retrogaming .category-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.category-retrogaming .category-review-card {
  position: relative;
  isolation: isolate;

  min-height: 385px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--card-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.category-retrogaming .category-review-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.category-retrogaming .category-review-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.category-retrogaming .category-review-card .post-category {
  top: 14px;
  left: 14px;
}

.category-retrogaming .category-review-card-copy {
  position: relative;
  z-index: 2;
}

.category-retrogaming .category-review-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 27px;
  line-height: 1.02;
}

.category-retrogaming .category-review-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

.category-retrogaming .category-review-card .rating-cats-small img {
  width: 18px;
  height: 18px;
}

.category-retrogaming .category-review-card .category-rating strong {
  font-size: 14px;
}

.category-retrogaming .review-card-link {
  display: block;
  margin-top: 16px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-align: right;
  text-transform: uppercase;
}

/* Paginação */

.category-retrogaming .category-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 26px auto 0;
}

.category-retrogaming .category-pagination a,
.category-retrogaming .category-pagination span {
  min-width: 48px;
  height: 48px;
  padding: 0 16px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.category-retrogaming .category-pagination a.active,
.category-retrogaming .category-pagination a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.category-retrogaming .category-pagination .next {
  min-width: 150px;
  gap: 8px;
}

/* Sidebar */

.category-retrogaming .category-sidebar {
  display: grid;
  gap: 24px;
}

.category-retrogaming .category-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.category-retrogaming .category-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.category-retrogaming .category-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.category-retrogaming .category-sidebar-box h2 {
  margin: 0 0 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.category-retrogaming .sidebar-highlight {
  display: grid;
  grid-template-columns: 94px 1fr;
  gap: 14px;
  align-items: start;

  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.category-retrogaming .sidebar-highlight:last-of-type {
  margin-bottom: 18px;
}

.category-retrogaming .sidebar-highlight img {
  width: 94px;
  height: 94px;
  object-fit: cover;
  border: 1px solid rgba(164, 112, 52, 0.38);
}

.category-retrogaming .sidebar-highlight strong {
  display: block;
  margin-bottom: 7px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.12;
  text-transform: uppercase;
}

.category-retrogaming .sidebar-highlight em {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 7px;
  padding: 5px 7px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.category-retrogaming .sidebar-highlight small {
  display: block;
  color: rgba(43, 26, 16, 0.78);
  font-size: 13px;
  line-height: 1.28;
}

.category-retrogaming .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.category-retrogaming .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* Top notas */

.category-retrogaming .top-rating-box {
  text-align: center;
}

.category-retrogaming .top-rating-box .rating-cats-feature {
  margin: 4px auto 14px;
}

.category-retrogaming .top-rating-box .rating-cats-feature img {
  width: 40px;
  height: 40px;
}

.category-retrogaming .top-rating-box > strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  text-transform: uppercase;
}

.category-retrogaming .top-rating-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.35;
}

/* Explorar */

.category-retrogaming .explore-box nav {
  display: grid;
  gap: 0;
  margin-bottom: 18px;
}

.category-retrogaming .explore-box nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.category-retrogaming .explore-box nav a:hover {
  color: var(--purple);
}

.category-retrogaming .explore-box nav span {
  font-size: 20px;
}

/* CTA Twitch */

.category-retrogaming .twitch-category-box {
  text-align: center;
}

.category-retrogaming .retro-live-badge {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;
  background: var(--purple);

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.category-retrogaming .retro-live-badge img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.category-retrogaming .twitch-category-box h2 {
  color: var(--purple);
}

.category-retrogaming .twitch-category-box p {
  margin: 0 0 18px;
  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.category-retrogaming .twitch-category-box .lg-btn {
  width: 100%;
  min-height: 48px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .category-retrogaming .category-layout {
    grid-template-columns: 1fr;
  }

  .category-retrogaming .category-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-retrogaming .category-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .category-retrogaming .category-title-row {
    gap: 28px;
  }

  .category-retrogaming .category-title-row .category-hero-icon {
    width: 220px;
    min-width: 220px;
  }

  .category-retrogaming .category-title-row .category-hero-icon img {
    max-width: 220px;
    max-height: 150px;
  }

  .category-retrogaming .category-title-row h1 {
    font-size: clamp(42px, 6.8vw, 66px);
  }

  .category-retrogaming .category-title-row p {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .category-retrogaming .category-hero {
    padding: 36px 20px 24px;
  }

  .category-retrogaming .category-hero-card {
    padding: 30px 24px;
  }

  .category-retrogaming .category-title-row {
    flex-direction: column;
    text-align: center;
    gap: 18px;
  }

  .category-retrogaming .category-title-row .category-hero-icon {
    width: 170px;
    min-width: 170px;
  }

  .category-retrogaming .category-title-row .category-hero-icon img {
    max-width: 170px;
    max-height: 120px;
  }

  .category-retrogaming .category-title-row h1 {
    font-size: 42px;
  }

  .category-retrogaming .category-title-row p {
    font-size: 18px;
  }

  .category-retrogaming .category-filter-row,
  .category-retrogaming .category-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .category-retrogaming .category-filter {
    flex: 1 1 180px;
  }

  .category-retrogaming .featured-review-card {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .category-retrogaming .featured-review-content {
    padding-top: 46px;
  }

  .category-retrogaming .featured-review-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-retrogaming .featured-review-link,
  .category-retrogaming .featured-review-bottom > a {
    margin-left: 0;
    margin-right: 0;
  }

  .category-retrogaming .category-card-grid,
  .category-retrogaming .category-sidebar {
    grid-template-columns: 1fr;
  }

  .category-retrogaming .category-review-card {
    min-height: 370px;
  }

  .category-retrogaming .category-pagination {
    flex-wrap: wrap;
  }
}
/* ================================================= */
/* REVIEWS GERAL V2 - WP READY */
/* Estrutura: título + heros das categorias + listas por categoria */
/* Cole no final do style.css */
/* ================================================= */

.reviews-hub-page-v2 .reviews-archive-hero {
  padding: 58px 56px 28px;
}

.reviews-archive-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-archive-breadcrumb a {
  text-decoration: none;
}

.reviews-archive-breadcrumb a:hover {
  color: var(--purple);
}

.reviews-archive-hero-card {
  position: relative;

  width: min(100%, 1420px);
  margin: 0 auto;
  min-height: 250px;
  padding: 42px 50px;

  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

  text-align: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 0%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.reviews-archive-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-archive-hero-card > * {
  position: relative;
  z-index: 2;
}

.reviews-archive-hero-card .section-kicker {
  margin-bottom: 18px;
}

.reviews-archive-hero-card h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.reviews-archive-hero-card p {
  max-width: 780px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

/* ================================================= */
/* HEROS DAS CATEGORIAS */
/* ================================================= */

.reviews-category-showcase {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.reviews-hub-title-row {
  margin-bottom: 18px;
}

.reviews-category-hero-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.reviews-category-hero-card {
  position: relative;
  min-height: 310px;
  padding: 18px 16px 16px;

  display: grid;
  grid-template-rows: 150px auto auto;
  gap: 12px;
  align-items: start;

  color: var(--ink);
  text-decoration: none;
  text-align: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 8%, rgba(86, 32, 129, 0.06), transparent 38%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    0 10px 20px rgba(43, 26, 16, 0.05);

  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.reviews-category-hero-card::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-category-hero-card:hover {
  transform: translateY(-5px);
  background:
    radial-gradient(circle at 50% 8%, rgba(86, 32, 129, 0.10), transparent 38%),
    rgba(255, 246, 222, 0.16);
  box-shadow: 0 18px 28px rgba(43, 26, 16, 0.13);
}

.reviews-category-hero-card > * {
  position: relative;
  z-index: 2;
}

.reviews-category-hero-card__image {
  width: 100%;
  height: 150px;
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.reviews-category-hero-card__image img {
  width: min(100%, 190px);
  max-height: 145px;
  object-fit: contain;
  filter: drop-shadow(0 10px 16px rgba(43, 26, 16, 0.14));
}

.reviews-category-hero-card__copy strong {
  display: block;
  margin-bottom: 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 21px;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-category-hero-card__copy small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 14px;
  line-height: 1.32;
}

.reviews-category-hero-card__link {
  align-self: end;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  min-height: 38px;
  padding: 0 12px;
  margin-top: 6px;

  color: var(--purple);
  border: 1px solid rgba(86, 32, 129, 0.22);
  background: rgba(86, 32, 129, 0.06);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-category-hero-card:hover .reviews-category-hero-card__link {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* ================================================= */
/* LAYOUT V2 */
/* ================================================= */

.reviews-v2-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.reviews-v2-main {
  min-width: 0;
  display: grid;
  gap: 26px;
}

/* ================================================= */
/* SEÇÕES POR CATEGORIA */
/* ================================================= */

.reviews-category-section {
  position: relative;
  padding: 28px 28px 30px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.04), transparent 32%),
    rgba(255, 246, 222, 0.10);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);
  overflow: hidden;
}

.reviews-category-section::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-category-section > * {
  position: relative;
  z-index: 2;
}

.reviews-category-section__header {
  margin-bottom: 22px;

  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
}

.reviews-category-section__header h2 {
  margin: 10px 0 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-category-section__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.reviews-category-post-card {
  min-height: 320px;
}

.reviews-category-post-card__copy {
  position: relative;
  z-index: 2;
}

/* ================================================= */
/* SIDEBAR MANTIDA */
/* ================================================= */

.reviews-v2-sidebar,
.reviews-hub-sidebar {
  display: grid;
  gap: 24px;
}

.reviews-hub-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.reviews-hub-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-hub-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.reviews-hub-sidebar-box h2 {
  margin: 0 0 20px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.reviews-hub-methodology {
  text-align: center;
}

.reviews-hub-methodology .rating-cats-feature {
  margin: 4px auto 14px;
}

.reviews-hub-methodology .rating-cats-feature img {
  width: 38px;
  height: 38px;
}

.reviews-hub-methodology strong {
  display: block;
  margin-bottom: 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 17px;
  text-transform: uppercase;
}

.reviews-hub-methodology p,
.reviews-hub-submit p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.38;
}

.reviews-hub-sidebar .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.reviews-hub-sidebar .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.reviews-hub-top-terms nav {
  display: grid;
  gap: 0;
}

.reviews-hub-top-terms nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.reviews-hub-top-terms nav a:hover {
  color: var(--purple);
}

.reviews-hub-submit {
  text-align: center;
}

.reviews-hub-submit-icon {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 32px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.reviews-hub-submit .lg-btn {
  width: 100%;
}

/* ================================================= */
/* NEWSLETTER FINAL */
/* ================================================= */

.reviews-hub-newsletter {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px);
  gap: 28px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 80%, rgba(184, 137, 72, 0.10), transparent 36%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.reviews-hub-newsletter h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.reviews-hub-newsletter p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.reviews-hub-newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.reviews-hub-newsletter-form input {
  min-width: 0;
  height: 52px;
  padding: 0 16px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.22);
  color: var(--ink);

  font: 600 14px var(--font-body, Georgia, "Times New Roman", serif);
  outline: 0;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1400px) {
  .reviews-category-hero-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .reviews-v2-layout {
    grid-template-columns: 1fr;
  }

  .reviews-v2-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .reviews-category-hero-grid,
  .reviews-category-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .reviews-hub-newsletter {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .reviews-hub-page-v2 .reviews-archive-hero {
    padding: 36px 20px 28px;
  }

  .reviews-archive-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .reviews-archive-hero-card h1 {
    font-size: 46px;
  }

  .reviews-archive-hero-card p {
    font-size: 18px;
  }

  .reviews-category-showcase,
  .reviews-v2-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .reviews-category-hero-grid,
  .reviews-category-section__grid {
    grid-template-columns: 1fr;
  }

  .reviews-category-section {
    padding: 26px 20px 28px;
  }

  .reviews-category-section__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .reviews-hub-newsletter {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .reviews-hub-newsletter-form {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* NOTÍCIAS GERAL - WP READY */
/* Estrutura: título + destaques + editorias + listas por editoria */
/* Cole no final do style.css */
/* ================================================= */

.news-hub-page .news-archive-hero {
  padding: 58px 56px 28px;
}

.news-archive-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-archive-breadcrumb a {
  text-decoration: none;
}

.news-archive-breadcrumb a:hover {
  color: var(--purple);
}

.news-archive-hero-card {
  position: relative;

  width: min(100%, 1420px);
  margin: 0 auto;
  min-height: 250px;
  padding: 42px 50px;

  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

  text-align: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 0%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.news-archive-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-archive-hero-card > * {
  position: relative;
  z-index: 2;
}

.news-archive-hero-card h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.news-archive-hero-card p {
  max-width: 780px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

/* ================================================= */
/* DESTAQUES */
/* ================================================= */

.news-featured-area {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.news-featured-main {
  position: relative;
  min-height: 460px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.72) 42%, rgba(20, 10, 5, 0.22) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.news-featured-main::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.news-featured-main > * {
  position: relative;
  z-index: 2;
}

.news-featured-main .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.news-featured-main .post-category {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.news-featured-main h2 {
  max-width: 720px;
  margin: 0 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.news-featured-main p {
  max-width: 620px;
  margin: 0 0 18px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.news-post-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;

  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.news-featured-main .featured-review-link {
  display: inline-flex;
  margin-left: 22px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.news-featured-secondary {
  display: grid;
  gap: 18px;
}

.news-secondary-card {
  position: relative;
  min-height: 140px;
  padding: 18px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;

  color: #f8e7bd;
  text-decoration: none;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98), rgba(20, 10, 5, 0.34)),
    var(--post-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);
  overflow: hidden;
}

.news-secondary-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.news-secondary-card > * {
  position: relative;
  z-index: 2;
}

.news-secondary-card .post-category {
  position: absolute;
  top: 14px;
  left: 14px;
}

.news-secondary-card strong {
  display: block;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 20px;
  line-height: 1.05;
  text-transform: uppercase;
}

.news-secondary-card small {
  color: rgba(248, 231, 189, 0.84);
  font-size: 13px;
}

/* ================================================= */
/* EDITORIAS */
/* ================================================= */

.news-editorial-showcase {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.news-title-row {
  margin-bottom: 18px;
}

.news-editorial-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.news-editorial-card {
  position: relative;
  min-height: 150px;
  padding: 24px 20px;

  display: grid;
  grid-template-columns: 54px 1fr 24px;
  gap: 14px;
  align-items: center;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.news-editorial-card:hover {
  transform: translateY(-4px);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.09), transparent 30%),
    rgba(255, 246, 222, 0.16);
  box-shadow: 0 16px 26px rgba(43, 26, 16, 0.11);
}

.news-editorial-card__icon {
  width: 50px;
  height: 50px;

  display: grid;
  place-items: center;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
}

.news-editorial-card__icon img {
  width: 26px;
  height: 26px;
  object-fit: contain;
}

.news-editorial-card__copy strong {
  display: block;
  margin-bottom: 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 20px;
  line-height: 1;
  text-transform: uppercase;
}

.news-editorial-card__copy small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 14px;
  line-height: 1.32;
}

.news-editorial-card__arrow {
  color: var(--purple);
  font-size: 24px;
  font-weight: 900;
}

/* ================================================= */
/* LAYOUT PRINCIPAL */
/* ================================================= */

.news-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.news-main {
  min-width: 0;
  display: grid;
  gap: 26px;
}

/* ================================================= */
/* SEÇÕES POR EDITORIA */
/* ================================================= */

.news-category-section {
  position: relative;
  padding: 28px 28px 30px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.04), transparent 32%),
    rgba(255, 246, 222, 0.10);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);
  overflow: hidden;
}

.news-category-section::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-category-section > * {
  position: relative;
  z-index: 2;
}

.news-category-section__header {
  margin-bottom: 22px;

  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
}

.news-category-section__header h2 {
  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.news-category-section__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.news-post-card {
  position: relative;
  isolation: isolate;

  min-height: 320px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--post-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.news-post-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.news-post-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.news-post-card .post-category {
  top: 14px;
  left: 14px;
}

.news-post-card__copy {
  position: relative;
  z-index: 2;
}

.news-post-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1.03;
}

.news-post-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

/* ================================================= */
/* SIDEBAR */
/* ================================================= */

.news-sidebar {
  display: grid;
  gap: 24px;
}

.news-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.news-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.news-sidebar-box h2 {
  margin: 0 0 20px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.news-mini-link {
  display: block;
  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.news-mini-link:last-child {
  margin-bottom: 0;
}

.news-mini-link strong {
  display: block;
  margin-bottom: 6px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.15;
  text-transform: uppercase;
}

.news-mini-link small {
  color: rgba(43, 26, 16, 0.70);
  font-size: 13px;
}

.news-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.news-tag-cloud a {
  min-height: 34px;
  padding: 0 12px;

  display: inline-flex;
  align-items: center;

  color: var(--purple);
  border: 1px solid rgba(86, 32, 129, 0.22);
  background: rgba(86, 32, 129, 0.05);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.news-tag-cloud a:hover {
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

.news-discord-cta,
.news-tip-cta {
  text-align: center;
}

.news-discord-icon,
.news-tip-icon {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 32px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.news-discord-icon img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.news-discord-cta p,
.news-tip-cta p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.38;
}

.news-discord-cta .lg-btn {
  width: 100%;
}

.news-sidebar .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.news-sidebar .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* ================================================= */
/* NEWSLETTER FINAL */
/* ================================================= */

.news-newsletter {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px);
  gap: 28px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 80%, rgba(184, 137, 72, 0.10), transparent 36%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-newsletter h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.news-newsletter p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.news-newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.news-newsletter-form input {
  min-width: 0;
  height: 52px;
  padding: 0 16px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.22);
  color: var(--ink);

  font: 600 14px var(--font-body, Georgia, "Times New Roman", serif);
  outline: 0;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .news-featured-area,
  .news-layout {
    grid-template-columns: 1fr;
  }

  .news-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .news-editorial-grid,
  .news-category-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .news-featured-secondary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .news-featured-secondary,
  .news-sidebar {
    grid-template-columns: 1fr;
  }

  .news-newsletter {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .news-hub-page .news-archive-hero {
    padding: 36px 20px 28px;
  }

  .news-archive-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .news-archive-hero-card h1 {
    font-size: 46px;
  }

  .news-archive-hero-card p {
    font-size: 18px;
  }

  .news-featured-area,
  .news-editorial-showcase,
  .news-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .news-editorial-grid,
  .news-category-section__grid {
    grid-template-columns: 1fr;
  }

  .news-featured-main {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .news-featured-main .featured-review-link {
    display: flex;
    margin: 16px 0 0;
  }

  .news-category-section {
    padding: 26px 20px 28px;
  }

  .news-category-section__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .news-newsletter {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .news-newsletter-form {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* GUIAS GERAL - WP READY */
/* Estrutura: hero + destaque + categorias + listas por categoria */
/* Cole no final do style.css */
/* ================================================= */

.guides-hub-page .guides-archive-hero {
  padding: 58px 56px 28px;
}

.guides-archive-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.guides-archive-breadcrumb a {
  text-decoration: none;
}

.guides-archive-breadcrumb a:hover {
  color: var(--purple);
}

.guides-archive-hero-card {
  position: relative;

  width: min(100%, 1420px);
  margin: 0 auto;
  min-height: 330px;
  padding: 42px 50px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  gap: 34px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 20%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.guides-archive-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.guides-archive-hero-card > * {
  position: relative;
  z-index: 2;
}

.guides-archive-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.guides-archive-hero-copy p {
  max-width: 780px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.guides-archive-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.guides-archive-hero-art {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}

.guides-archive-hero-art img {
  width: 138px;
  height: 138px;
  object-fit: contain;
  opacity: 0.90;
  filter:
    drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16))
    saturate(0.92);
}

/* ================================================= */
/* DESTAQUE */
/* ================================================= */

.guides-featured-area {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.guides-featured-main {
  position: relative;
  min-height: 460px;
  padding: 42px 44px 38px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20, 10, 5, 0.96) 0%, rgba(20, 10, 5, 0.72) 42%, rgba(20, 10, 5, 0.22) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.10);
}

.guides-featured-main::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.guides-featured-main > * {
  position: relative;
  z-index: 2;
}

.guides-featured-main .featured-ribbon {
  position: absolute;
  left: 0;
  top: 24px;
  z-index: 3;

  padding: 10px 20px;

  color: #2b1a10;
  background: var(--gold);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.guides-featured-main .post-category {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin: 0 0 20px;
}

.guides-featured-main h2 {
  max-width: 720px;
  margin: 0 0 20px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 62px);
  line-height: 0.95;
  text-transform: uppercase;
}

.guides-featured-main p {
  max-width: 620px;
  margin: 0 0 18px;

  color: rgba(248, 231, 189, 0.90);
  font-size: 19px;
  line-height: 1.40;
}

.guide-post-meta {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.guide-post-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 9px;

  color: var(--cream);
  background: var(--purple);
  border: 1px solid rgba(255, 243, 214, 0.20);
}

.guides-featured-main .featured-review-link {
  display: inline-flex;
  margin-left: 22px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.guides-featured-secondary {
  display: grid;
  gap: 18px;
}

.guides-secondary-card {
  position: relative;
  min-height: 140px;
  padding: 18px;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;

  color: #f8e7bd;
  text-decoration: none;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98), rgba(20, 10, 5, 0.34)),
    var(--post-bg);
  background-size: cover;
  background-position: center;

  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);
  overflow: hidden;
}

.guides-secondary-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.guides-secondary-card > * {
  position: relative;
  z-index: 2;
}

.guides-secondary-card .post-category {
  position: absolute;
  top: 14px;
  left: 14px;
}

.guides-secondary-card strong {
  display: block;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 20px;
  line-height: 1.05;
  text-transform: uppercase;
}

.guides-secondary-card small {
  color: rgba(248, 231, 189, 0.84);
  font-size: 13px;
}

/* ================================================= */
/* CATEGORIAS */
/* ================================================= */

.guides-category-showcase {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.guides-title-row {
  margin-bottom: 18px;
}

.guides-category-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.guides-category-card {
  position: relative;
  min-height: 190px;
  padding: 22px 18px;

  display: grid;
  grid-template-rows: 54px 1fr 24px;
  gap: 14px;
  justify-items: center;
  text-align: center;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.guides-category-card:hover {
  transform: translateY(-4px);
  background:
    radial-gradient(circle at 50% 10%, rgba(86, 32, 129, 0.09), transparent 30%),
    rgba(255, 246, 222, 0.16);
  box-shadow: 0 16px 26px rgba(43, 26, 16, 0.11);
}

.guides-category-card__icon {
  width: 54px;
  height: 54px;

  display: grid;
  place-items: center;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.18);
}

.guides-category-card__icon img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.guides-category-card__copy strong {
  display: block;
  margin-bottom: 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.guides-category-card__copy small {
  display: block;

  color: rgba(43, 26, 16, 0.76);
  font-size: 14px;
  line-height: 1.32;
}

.guides-category-card__arrow {
  color: var(--purple);
  font-size: 24px;
  font-weight: 900;
}

/* ================================================= */
/* LAYOUT PRINCIPAL */
/* ================================================= */

.guides-layout {
  width: min(100%, 1500px);
  margin: 0 auto 36px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;
}

.guides-main {
  min-width: 0;
  display: grid;
  gap: 26px;
}

/* ================================================= */
/* SEÇÕES POR CATEGORIA */
/* ================================================= */

.guides-category-section {
  position: relative;
  padding: 28px 28px 30px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.04), transparent 32%),
    rgba(255, 246, 222, 0.10);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.20);
  overflow: hidden;
}

.guides-category-section::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.guides-category-section > * {
  position: relative;
  z-index: 2;
}

.guides-category-section__header {
  margin-bottom: 22px;

  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 22px;
}

.guides-category-section__header h2 {
  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 32px;
  line-height: 1;
  text-transform: uppercase;
}

.guides-category-section__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.guide-post-card {
  position: relative;
  isolation: isolate;

  min-height: 320px;
  padding: 18px;

  display: flex;
  align-items: flex-end;

  color: #f8e7bd;
  text-decoration: none;
  text-transform: uppercase;

  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.98) 0%, rgba(20, 10, 5, 0.78) 42%, rgba(20, 10, 5, 0.20) 74%, rgba(20, 10, 5, 0.04) 100%),
    var(--post-bg);
  background-size: cover;
  background-position: center;

  overflow: hidden;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.82);

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}

.guide-post-card::before {
  content: "";
  position: absolute;
  inset: 8px;
  border: 1px solid rgba(255, 243, 214, 0.18);
  pointer-events: none;
}

.guide-post-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 28px rgba(43, 26, 16, 0.24);
  filter: brightness(1.06);
}

.guide-post-card .post-category {
  top: 14px;
  left: 14px;
}

.guide-post-card__copy {
  position: relative;
  z-index: 2;
}

.guide-post-card h3 {
  margin: 0 0 10px;

  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1.03;
}

.guide-post-card p {
  margin: 0 0 14px;

  color: rgba(248, 231, 189, 0.86);
  font-size: 15px;
  line-height: 1.34;
  text-transform: none;
}

/* ================================================= */
/* SIDEBAR */
/* ================================================= */

.guides-sidebar {
  display: grid;
  gap: 24px;
}

.guides-sidebar-box {
  position: relative;

  padding: 28px 24px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);

  overflow: hidden;
}

.guides-sidebar-box::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.guides-sidebar-box > * {
  position: relative;
  z-index: 2;
}

.guides-sidebar-box h2 {
  margin: 0 0 20px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.guides-mini-link {
  display: block;
  padding: 0 0 16px;
  margin-bottom: 16px;

  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
}

.guides-mini-link:last-child {
  margin-bottom: 0;
}

.guides-mini-link strong {
  display: block;
  margin-bottom: 6px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  line-height: 1.15;
  text-transform: uppercase;
}

.guides-mini-link small {
  color: rgba(43, 26, 16, 0.70);
  font-size: 13px;
}

.guides-difficulty nav {
  display: grid;
  gap: 0;
}

.guides-difficulty nav a {
  min-height: 42px;
  padding: 0 6px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.guides-difficulty nav a:hover {
  color: var(--purple);
}

.guides-toolbox,
.guides-suggest {
  text-align: center;
}

.guides-toolbox-icon,
.guides-suggest-icon {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 32px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.guides-toolbox p,
.guides-suggest p {
  margin: 0 0 18px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.38;
}

.guides-toolbox .lg-btn {
  width: 100%;
}

.guides-sidebar .sidebar-button {
  min-height: 44px;
  padding: 0 14px;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.guides-sidebar .sidebar-button:hover {
  transform: translateY(-2px);
  color: var(--cream);
  background: var(--purple);
  border-color: var(--purple);
}

/* ================================================= */
/* NEWSLETTER FINAL */
/* ================================================= */

.guides-newsletter {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 520px);
  gap: 28px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 80%, rgba(184, 137, 72, 0.10), transparent 36%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.guides-newsletter h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.guides-newsletter p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.guides-newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.guides-newsletter-form input {
  min-width: 0;
  height: 52px;
  padding: 0 16px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.22);
  color: var(--ink);

  font: 600 14px var(--font-body, Georgia, "Times New Roman", serif);
  outline: 0;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .guides-featured-area,
  .guides-layout {
    grid-template-columns: 1fr;
  }

  .guides-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .guides-category-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .guides-category-section__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .guides-featured-secondary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .guides-archive-hero-card {
    grid-template-columns: 1fr;
  }

  .guides-archive-hero-art {
    display: none;
  }

  .guides-featured-secondary,
  .guides-sidebar {
    grid-template-columns: 1fr;
  }

  .guides-newsletter {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .guides-hub-page .guides-archive-hero {
    padding: 36px 20px 28px;
  }

  .guides-archive-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .guides-archive-hero-copy h1 {
    font-size: 46px;
  }

  .guides-archive-hero-copy p {
    font-size: 18px;
  }

  .guides-featured-area,
  .guides-category-showcase,
  .guides-layout {
    padding-left: 20px;
    padding-right: 20px;
  }

  .guides-category-grid,
  .guides-category-section__grid {
    grid-template-columns: 1fr;
  }

  .guides-featured-main {
    min-height: 400px;
    padding: 34px 24px 28px;
  }

  .guides-featured-main .featured-review-link {
    display: flex;
    margin: 16px 0 0;
  }

  .guides-category-section {
    padding: 26px 20px 28px;
  }

  .guides-category-section__header {
    align-items: flex-start;
    flex-direction: column;
  }

  .guides-newsletter {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .guides-newsletter-form {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* COVEN / COMUNIDADE - WP READY */
/* Página estática institucional */
/* Cole no final do style.css */
/* ================================================= */

.coven-page .coven-hero {
  padding: 58px 56px 32px;
}

.coven-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.coven-breadcrumb a {
  text-decoration: none;
}

.coven-breadcrumb a:hover {
  color: var(--purple);
}

.coven-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.coven-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.coven-hero-card > * {
  position: relative;
  z-index: 2;
}

.coven-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.coven-hero-copy p {
  max-width: 780px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.coven-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.coven-hero-art {
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.coven-hero-art img {
  width: min(100%, 330px);
  max-height: 290px;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16));
}

/* Intro */

.coven-intro {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.coven-intro-card,
.coven-intro-aside,
.coven-ritual-card,
.coven-discord,
.coven-mascot-card,
.coven-rules,
.coven-final-cta {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.coven-intro-card::before,
.coven-intro-aside::before,
.coven-ritual-card::before,
.coven-discord::before,
.coven-mascot-card::before,
.coven-rules::before,
.coven-final-cta::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.coven-intro-card > *,
.coven-intro-aside > *,
.coven-ritual-card > *,
.coven-discord > *,
.coven-mascot-card > *,
.coven-rules > *,
.coven-final-cta > * {
  position: relative;
  z-index: 2;
}

.coven-intro-card {
  padding: 38px 40px;
}

.coven-intro-card h2 {
  max-width: 800px;
  margin: 12px 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 42px;
  line-height: 0.98;
  text-transform: uppercase;
}

.coven-intro-card p {
  max-width: 850px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.coven-intro-card p:last-child {
  margin-bottom: 0;
}

.coven-intro-aside {
  padding: 34px 28px;
}

.coven-intro-aside h3 {
  margin: 0 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-intro-aside ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.coven-intro-aside li {
  padding: 13px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
  font-size: 16px;
  font-weight: 700;
}

.coven-intro-aside li::before {
  content: "✦ ";
  color: var(--purple);
}

/* Rituais */

.coven-rituals,
.coven-mascots {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.coven-title-row {
  margin-bottom: 18px;
}

.coven-ritual-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.coven-ritual-card {
  min-height: 230px;
  padding: 28px 24px;
  text-align: center;
}

.coven-ritual-card__icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.coven-ritual-card h3,
.coven-mascot-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-ritual-card p,
.coven-mascot-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15.5px;
  line-height: 1.38;
}

/* Discord */

.coven-discord {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 42px 46px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: 34px;
  align-items: center;
}

.coven-discord-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 46px;
  line-height: 0.95;
  text-transform: uppercase;
}

.coven-discord-copy p {
  max-width: 760px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.coven-discord-card {
  padding: 28px 24px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.12);
}

.coven-discord-icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 32px;
}

.coven-discord-icon img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.coven-discord-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-discord-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.76);
  font-size: 15px;
  line-height: 1.38;
}

/* Mascotes */

.coven-mascot-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.coven-mascot-card {
  min-height: 170px;
  padding: 24px;

  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 18px;
  align-items: center;
}

.coven-mascot-card figure {
  margin: 0;
}

.coven-mascot-card img {
  width: 92px;
  height: 92px;
  object-fit: contain;
}

/* Regras */

.coven-rules {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.coven-rules-header {
  margin-bottom: 24px;
  text-align: center;
}

.coven-rules-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-rules-header p {
  margin: 0 auto;
  max-width: 720px;
  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.coven-rule-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.coven-rule-card {
  padding: 22px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.coven-rule-card strong {
  display: block;
  margin-bottom: 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 17px;
  text-transform: uppercase;
}

.coven-rule-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 14.5px;
  line-height: 1.34;
}

/* CTA final */

.coven-final-cta {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
}

.coven-final-cta h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.coven-final-cta p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.coven-final-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Responsivo */

@media (max-width: 1300px) {
  .coven-intro,
  .coven-discord,
  .coven-final-cta {
    grid-template-columns: 1fr;
  }

  .coven-ritual-grid,
  .coven-rule-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .coven-mascot-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1100px) {
  .coven-hero-card {
    grid-template-columns: 1fr;
  }

  .coven-hero-art {
    display: none;
  }
}

@media (max-width: 900px) {
  .coven-page .coven-hero {
    padding: 36px 20px 28px;
  }

  .coven-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .coven-hero-copy h1 {
    font-size: 46px;
  }

  .coven-hero-copy p,
  .coven-intro-card p,
  .coven-discord-copy p {
    font-size: 18px;
  }

  .coven-intro,
  .coven-rituals,
  .coven-mascots {
    padding-left: 20px;
    padding-right: 20px;
  }

  .coven-intro-card,
  .coven-intro-aside,
  .coven-discord,
  .coven-rules,
  .coven-final-cta {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .coven-intro-card h2,
  .coven-discord-copy h2,
  .coven-rules-header h2 {
    font-size: 32px;
  }

  .coven-ritual-grid,
  .coven-rule-grid {
    grid-template-columns: 1fr;
  }

  .coven-mascot-card {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
  }

  .coven-final-actions {
    width: 100%;
  }

  .coven-final-actions .lg-btn {
    width: 100%;
  }
}
/* ================================================= */
/* COVEN - GUARDIÕES FELINOS EM DESTAQUE */
/* imagens em cima + descrição embaixo */
/* ================================================= */

.coven-mascot-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.coven-mascot-card {
  min-height: auto;
  padding: 26px 24px 28px;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;

  gap: 18px;
  text-align: center;
}

.coven-mascot-card figure {
  width: 100%;
  height: 230px;
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.coven-mascot-card img {
  width: 100%;
  max-width: 210px;
  height: 210px;

  object-fit: contain;

  filter:
    drop-shadow(0 14px 20px rgba(43, 26, 16, 0.16))
    saturate(1.03);

  transition:
    transform 0.22s ease,
    filter 0.22s ease;
}

.coven-mascot-card:hover img {
  transform: translateY(-4px) scale(1.04);
  filter:
    drop-shadow(0 18px 26px rgba(43, 26, 16, 0.22))
    saturate(1.08);
}

.coven-mascot-card div {
  max-width: 320px;
}

.coven-mascot-card h3 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

.coven-mascot-card p {
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.42;
  text-align: center;
}
@media (max-width: 1100px) {
  .coven-mascot-grid {
    grid-template-columns: 1fr;
  }

  .coven-mascot-card figure {
    height: 250px;
  }

  .coven-mascot-card img {
    max-width: 230px;
    height: 230px;
  }
}

@media (max-width: 640px) {
  .coven-mascot-card {
    padding: 24px 20px 26px;
  }

  .coven-mascot-card figure {
    height: 210px;
  }

  .coven-mascot-card img {
    max-width: 190px;
    height: 190px;
  }

  .coven-mascot-card h3 {
    font-size: 23px;
  }

  .coven-mascot-card p {
    font-size: 15px;
  }
}/* ================================================= */
/* PARCERIAS - WP READY */
/* Página comercial / institucional */
/* Cole no final do style.css */
/* ================================================= */

.partners-page .partners-hero {
  padding: 58px 56px 32px;
}

.partners-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.partners-breadcrumb a {
  text-decoration: none;
}

.partners-breadcrumb a:hover {
  color: var(--purple);
}

.partners-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.partners-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-hero-card > * {
  position: relative;
  z-index: 2;
}

.partners-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(58px, 5.4vw, 96px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.partners-hero-copy p {
  max-width: 800px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.partners-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.partners-hero-panel {
  padding: 30px 26px;

  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.14);
}

.partners-hero-panel__icon {
  width: 76px;
  height: 76px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.partners-hero-panel__icon img {
  width: 38px;
  height: 38px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.partners-hero-panel h2 {
  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-hero-panel p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.38;
}

/* Blocos base */

.partners-intro,
.partners-contact {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.partners-intro-card,
.partners-intro-aside,
.partners-format-card,
.partners-audience,
.partners-plan-card,
.partners-process,
.partners-contact,
.partners-contact-form {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.partners-intro-card::before,
.partners-intro-aside::before,
.partners-format-card::before,
.partners-audience::before,
.partners-plan-card::before,
.partners-process::before,
.partners-contact::before,
.partners-contact-form::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-intro-card > *,
.partners-intro-aside > *,
.partners-format-card > *,
.partners-audience > *,
.partners-plan-card > *,
.partners-process > *,
.partners-contact > *,
.partners-contact-form > * {
  position: relative;
  z-index: 2;
}

/* Intro */

.partners-intro-card {
  padding: 38px 40px;
}

.partners-intro-card h2 {
  max-width: 850px;
  margin: 12px 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 42px;
  line-height: 0.98;
  text-transform: uppercase;
}

.partners-intro-card p {
  max-width: 900px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.partners-intro-card p:last-child {
  margin-bottom: 0;
}

.partners-intro-aside {
  padding: 34px 28px;
}

.partners-intro-aside h3 {
  margin: 0 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-intro-aside ul,
.partners-plan-card ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.partners-intro-aside li {
  padding: 13px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
  font-size: 16px;
  font-weight: 700;
}

.partners-intro-aside li::before,
.partners-plan-card li::before {
  content: "✦ ";
  color: var(--purple);
}

/* Formatos */

.partners-formats,
.partners-plans {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.partners-title-row {
  margin-bottom: 18px;
}

.partners-format-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.partners-format-card {
  min-height: 230px;
  padding: 28px 24px;
  text-align: center;
}

.partners-format-card__icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.partners-format-card h3,
.partners-audience-card h3,
.partners-plan-card h3,
.partners-step-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-format-card p,
.partners-audience-card p,
.partners-plan-card p,
.partners-step-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15.5px;
  line-height: 1.38;
}

/* Audiência */

.partners-audience {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.partners-audience-header,
.partners-process-header {
  text-align: center;
  margin-bottom: 24px;
}

.partners-audience-header h2,
.partners-process-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-audience-header p,
.partners-process-header p {
  max-width: 760px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.partners-audience-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.partners-audience-card {
  padding: 22px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

/* Planos */

.partners-plan-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.partners-plan-card {
  padding: 30px 26px;
}

.partners-plan-card__label {
  display: inline-flex;
  width: fit-content;
  min-height: 28px;
  margin-bottom: 18px;
  padding: 0 10px;

  align-items: center;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.partners-plan-card p {
  margin-bottom: 18px;
}

.partners-plan-card li {
  padding: 10px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.22);
  font-size: 15px;
  font-weight: 700;
}

.partners-plan-card .sidebar-button {
  margin-top: 22px;
}

/* Processo */

.partners-process {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.partners-step-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.partners-step-card {
  padding: 24px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.partners-step-card span {
  width: 52px;
  height: 52px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  font-weight: 900;
}

/* Contato */

.partners-contact {
  padding-top: 0;
  padding-bottom: 0;
}

.partners-contact::before {
  display: none;
}

.partners-contact-copy {
  position: relative;
  padding: 38px 40px;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
}

.partners-contact-copy::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-contact-copy > * {
  position: relative;
  z-index: 2;
}

.partners-contact-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 46px;
  line-height: 0.95;
  text-transform: uppercase;
}

.partners-contact-copy p {
  max-width: 760px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.partners-contact-list {
  display: grid;
  gap: 10px;
}

.partners-contact-list a {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  text-decoration: none;
}

.partners-contact-list a:hover {
  color: var(--purple);
}

.partners-contact-form {
  padding: 34px 28px;
  display: grid;
  gap: 10px;
}

.partners-contact-form label {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.partners-contact-form input,
.partners-contact-form textarea {
  width: 100%;
  padding: 13px 14px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.22);

  font: 600 15px var(--font-body, Georgia, "Times New Roman", serif);
  outline: 0;
  resize: vertical;
}

.partners-contact-form input:focus,
.partners-contact-form textarea:focus {
  border-color: var(--purple);
}

.partners-contact-form .lg-btn {
  width: 100%;
  margin-top: 10px;
}

/* Responsivo */

@media (max-width: 1300px) {
  .partners-intro,
  .partners-contact,
  .partners-hero-card {
    grid-template-columns: 1fr;
  }

  .partners-format-grid,
  .partners-plan-grid,
  .partners-audience-grid,
  .partners-step-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .partners-page .partners-hero {
    padding: 36px 20px 28px;
  }

  .partners-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .partners-hero-copy h1 {
    font-size: 46px;
  }

  .partners-hero-copy p,
  .partners-intro-card p,
  .partners-contact-copy p {
    font-size: 18px;
  }

  .partners-intro,
  .partners-formats,
  .partners-plans,
  .partners-contact {
    padding-left: 20px;
    padding-right: 20px;
  }

  .partners-audience,
  .partners-process {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .partners-intro-card,
  .partners-intro-aside,
  .partners-contact-copy,
  .partners-contact-form {
    padding: 28px 22px;
  }

  .partners-intro-card h2,
  .partners-contact-copy h2,
  .partners-audience-header h2,
  .partners-process-header h2 {
    font-size: 32px;
  }

  .partners-format-grid,
  .partners-plan-grid,
  .partners-audience-grid,
  .partners-step-grid {
    grid-template-columns: 1fr;
  }

  .partners-hero-actions .lg-btn {
    width: 100%;
  }
}
/* ================================================= */
/* CONTATO / PARCERIAS - AJUSTE VISUAL */
/* ================================================= */

.partners-contact {
  width: min(100%, 1500px);
  margin: 0 auto 40px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: 1.45fr 0.95fr;
  gap: 24px;
  align-items: stretch;
}

.partners-contact-copy,
.partners-contact-form {
  position: relative;
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.04), transparent 30%),
    rgba(255, 246, 222, 0.14);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
  overflow: hidden;
}

.partners-contact-copy::before,
.partners-contact-form::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-contact-copy > *,
.partners-contact-form > * {
  position: relative;
  z-index: 2;
}

/* COLUNA ESQUERDA */
.partners-contact-copy {
  padding: 40px 42px;
  min-height: 420px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.partners-contact-copy .section-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 30px;
  padding: 0 14px;
  margin-bottom: 18px;

  border: 1px solid rgba(164, 112, 52, 0.28);
  background: rgba(255, 246, 222, 0.65);

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.partners-contact-copy h2 {
  margin: 0 0 20px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(38px, 4vw, 64px);
  line-height: 0.95;
  font-weight: 900;
  text-transform: uppercase;
}

.partners-contact-copy p {
  max-width: 760px;
  margin: 0 0 28px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 20px;
  line-height: 1.5;
}

.partners-contact-list {
  display: grid;
  gap: 12px;
}

.partners-contact-list a {
  width: fit-content;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.2s ease;
}

.partners-contact-list a:hover {
  color: var(--purple);
}

/* COLUNA DIREITA / FORM */
.partners-contact-form {
  padding: 34px 28px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.partners-contact-form form,
.partners-contact-form-inner {
  display: grid;
  gap: 12px;
}

.partners-contact-form label {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.partners-contact-form input,
.partners-contact-form textarea {
  width: 100%;
  padding: 14px 16px;

  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.30);
  color: var(--ink);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 16px;
  line-height: 1.4;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.partners-contact-form input:focus,
.partners-contact-form textarea:focus {
  border-color: var(--purple);
  box-shadow: 0 0 0 2px rgba(86, 32, 129, 0.10);
}

.partners-contact-form textarea {
  min-height: 130px;
  resize: vertical;
}

.partners-contact-form .lg-btn,
.partners-contact-form button {
  margin-top: 8px;
  width: 100%;
  min-height: 54px;

  border: 0;
  cursor: pointer;

  background: var(--purple);
  color: #fff;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 800;
  text-transform: uppercase;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.partners-contact-form .lg-btn:hover,
.partners-contact-form button:hover {
  opacity: 0.92;
  transform: translateY(-1px);
}

/* RESPONSIVO */
@media (max-width: 980px) {
  .partners-contact {
    grid-template-columns: 1fr;
    padding: 0 20px;
  }

  .partners-contact-copy,
  .partners-contact-form {
    min-height: auto;
    padding: 28px 22px;
  }

  .partners-contact-copy h2 {
    font-size: 38px;
  }

  .partners-contact-copy p {
    font-size: 18px;
  }
}/* ================================================= */
/* PARCERIAS - CONTATO REFINADO */
/* ícones + linha ornamental + formulário premium */
/* ================================================= */

.partners-contact-refined {
  width: min(100%, 1500px);
  margin: 0 auto 40px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(360px, 0.85fr);
  gap: 26px;
  align-items: stretch;

  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

.partners-contact-refined::before {
  display: none;
}

/* COLUNAS */

.partners-contact-refined .partners-contact-copy,
.partners-contact-refined .partners-contact-form {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 86% 16%, rgba(86, 32, 129, 0.05), transparent 32%),
    rgba(255, 246, 222, 0.15);

  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    0 14px 24px rgba(43, 26, 16, 0.05);

  overflow: hidden;
}

.partners-contact-refined .partners-contact-copy::before,
.partners-contact-refined .partners-contact-form::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.partners-contact-refined .partners-contact-copy > *,
.partners-contact-refined .partners-contact-form > * {
  position: relative;
  z-index: 2;
}

/* COLUNA ESQUERDA */

.partners-contact-refined .partners-contact-copy {
  min-height: 430px;
  padding: 44px 46px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.partners-contact-refined .section-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: fit-content;
  min-height: 30px;
  padding: 0 14px;
  margin-bottom: 20px;

  border: 1px solid rgba(164, 112, 52, 0.30);
  background: rgba(255, 246, 222, 0.60);

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.partners-contact-refined .partners-contact-copy h2 {
  max-width: 860px;
  margin: 0 0 22px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4.4vw, 70px);
  line-height: 0.92;
  font-weight: 900;
  letter-spacing: -0.035em;
  text-transform: uppercase;
}

.partners-contact-refined .partners-contact-copy p {
  max-width: 820px;
  margin: 0;

  color: rgba(43, 26, 16, 0.86);
  font-size: 20px;
  line-height: 1.48;
}

/* LINHA ORNAMENTAL */

.partners-contact-divider {
  width: min(100%, 520px);
  margin: 30px 0 26px;

  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 14px;
}

.partners-contact-divider span {
  display: block;
  height: 1px;
  background: rgba(164, 112, 52, 0.34);
}

.partners-contact-divider i {
  color: var(--purple);
  font-style: normal;
  font-size: 17px;
  line-height: 1;
}

/* LINKS DE CONTATO */

.partners-contact-refined .partners-contact-list {
  display: grid;
  gap: 14px;
}

.partners-contact-link {
  width: fit-content;

  display: inline-flex;
  align-items: center;
  gap: 12px;

  color: var(--ink);
  text-decoration: none;

  transition:
    color 0.2s ease,
    transform 0.2s ease;
}

.partners-contact-link:hover {
  color: var(--purple);
  transform: translateX(3px);
}

.partners-contact-icon {
  width: 38px;
  height: 38px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  border-radius: 50%;
  background: var(--purple);
  color: var(--cream);

  font-size: 17px;
  font-weight: 900;

  box-shadow:
    0 8px 16px rgba(43, 26, 16, 0.12),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.partners-contact-icon img {
  width: 18px;
  height: 18px;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.partners-contact-link span:last-child {
  color: inherit;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

/* FORMULÁRIO */

.partners-contact-refined .partners-contact-form {
  min-height: 430px;
  padding: 34px 30px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.partners-form-header {
  margin-bottom: 20px;
  text-align: center;
}

.partners-form-header > span {
  width: 50px;
  height: 50px;
  margin: 0 auto 14px;

  display: grid;
  place-items: center;

  border-radius: 50%;
  background: var(--purple);
  color: var(--cream);

  font-size: 22px;

  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.partners-form-header h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.partners-form-header p {
  max-width: 330px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.72);
  font-size: 14.5px;
  line-height: 1.34;
}

.partners-contact-refined .partners-contact-form label {
  margin: 10px 0 6px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.partners-contact-refined .partners-contact-form input,
.partners-contact-refined .partners-contact-form textarea {
  width: 100%;
  padding: 14px 16px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.34);
  background: rgba(255, 246, 222, 0.32);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15.5px;
  line-height: 1.4;

  outline: 0;
  resize: vertical;

  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.partners-contact-refined .partners-contact-form input::placeholder,
.partners-contact-refined .partners-contact-form textarea::placeholder {
  color: rgba(43, 26, 16, 0.52);
}

.partners-contact-refined .partners-contact-form input:focus,
.partners-contact-refined .partners-contact-form textarea:focus {
  border-color: var(--purple);
  background: rgba(255, 246, 222, 0.42);
  box-shadow: 0 0 0 2px rgba(86, 32, 129, 0.10);
}

.partners-contact-refined .partners-contact-form textarea {
  min-height: 132px;
}

.partners-contact-refined .partners-contact-form .lg-btn,
.partners-contact-refined .partners-contact-form button {
  width: 100%;
  min-height: 54px;
  margin-top: 18px;

  border: 1px solid var(--purple);
  background: var(--purple);
  color: var(--cream);
  cursor: pointer;

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 15px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.partners-contact-refined .partners-contact-form .lg-btn:hover,
.partners-contact-refined .partners-contact-form button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 20px rgba(43, 26, 16, 0.16);
}

/* RESPONSIVO */

@media (max-width: 1100px) {
  .partners-contact-refined {
    grid-template-columns: 1fr;
  }

  .partners-contact-refined .partners-contact-copy,
  .partners-contact-refined .partners-contact-form {
    min-height: auto;
  }
}

@media (max-width: 700px) {
  .partners-contact-refined {
    padding: 0 20px;
  }

  .partners-contact-refined .partners-contact-copy,
  .partners-contact-refined .partners-contact-form {
    padding: 30px 22px;
  }

  .partners-contact-refined .partners-contact-copy h2 {
    font-size: 38px;
  }

  .partners-contact-refined .partners-contact-copy p {
    font-size: 18px;
  }

  .partners-contact-link {
    align-items: flex-start;
  }

  .partners-contact-link span:last-child {
    font-size: 15px;
    word-break: break-word;
  }

  .partners-contact-divider {
    margin: 24px 0 22px;
  }
}/* ================================================= */
/* SOBRE - WP READY */
/* Página institucional */
/* Cole no final do style.css */
/* ================================================= */

.about-page .about-hero {
  padding: 58px 56px 32px;
}

.about-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.about-breadcrumb a {
  text-decoration: none;
}

.about-breadcrumb a:hover {
  color: var(--purple);
}

.about-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.about-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.about-hero-card > * {
  position: relative;
  z-index: 2;
}

.about-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.about-hero-copy p {
  max-width: 820px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.about-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.about-hero-art {
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.about-hero-art img {
  width: min(100%, 300px);
  max-height: 260px;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16));
}

/* Manifesto */

.about-manifesto {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.about-manifesto-card,
.about-manifesto-aside,
.about-pillar-card,
.about-creator,
.about-values,
.about-ecosystem,
.about-final-cta {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.about-manifesto-card::before,
.about-manifesto-aside::before,
.about-pillar-card::before,
.about-creator::before,
.about-values::before,
.about-ecosystem::before,
.about-final-cta::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.about-manifesto-card > *,
.about-manifesto-aside > *,
.about-pillar-card > *,
.about-creator > *,
.about-values > *,
.about-ecosystem > *,
.about-final-cta > * {
  position: relative;
  z-index: 2;
}

.about-manifesto-card {
  padding: 38px 40px;
}

.about-manifesto-card h2 {
  max-width: 860px;
  margin: 12px 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 42px;
  line-height: 0.98;
  text-transform: uppercase;
}

.about-manifesto-card p {
  max-width: 900px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.about-manifesto-card p:last-child {
  margin-bottom: 0;
}

.about-manifesto-aside {
  padding: 34px 28px;
}

.about-manifesto-aside h3 {
  margin: 0 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.about-manifesto-aside ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.about-manifesto-aside li {
  padding: 13px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
  font-size: 16px;
  font-weight: 700;
}

.about-manifesto-aside li::before {
  content: "✦ ";
  color: var(--purple);
}

/* Pilares */

.about-pillars {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.about-title-row {
  margin-bottom: 18px;
}

.about-pillar-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.about-pillar-card {
  min-height: 240px;
  padding: 28px 24px;
  text-align: center;
}

.about-pillar-card__icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.about-pillar-card h3,
.about-value-card strong,
.about-timeline-card h3,
.about-creator-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 21px;
  line-height: 1;
  text-transform: uppercase;
}

.about-pillar-card p,
.about-value-card p,
.about-timeline-card p,
.about-creator-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15.5px;
  line-height: 1.38;
}

/* Criador */

.about-creator {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 42px 46px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: 34px;
  align-items: center;
}

.about-creator-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 46px;
  line-height: 0.95;
  text-transform: uppercase;
}

.about-creator-copy p {
  max-width: 820px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.about-creator-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px;
}

.about-creator-card {
  padding: 30px 24px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.12);
}

.about-creator-icon {
  width: 82px;
  height: 82px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  font-weight: 900;
}

/* Valores + ecossistema */

.about-values,
.about-ecosystem {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.about-values-header,
.about-ecosystem-header {
  text-align: center;
  margin-bottom: 24px;
}

.about-values-header h2,
.about-ecosystem-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.about-values-header p,
.about-ecosystem-header p {
  max-width: 760px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.about-value-grid,
.about-timeline-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.about-value-card,
.about-timeline-card {
  padding: 24px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.about-value-card strong {
  display: block;
  color: var(--purple);
}

.about-timeline-card span {
  width: 52px;
  height: 52px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  font-weight: 900;
}

/* CTA final */

.about-final-cta {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
}

.about-final-cta h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.about-final-cta p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.about-final-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Responsivo */

@media (max-width: 1300px) {
  .about-manifesto,
  .about-creator,
  .about-final-cta,
  .about-hero-card {
    grid-template-columns: 1fr;
  }

  .about-pillar-grid,
  .about-value-grid,
  .about-timeline-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-hero-art {
    display: none;
  }
}

@media (max-width: 900px) {
  .about-page .about-hero {
    padding: 36px 20px 28px;
  }

  .about-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .about-hero-copy h1 {
    font-size: 46px;
  }

  .about-hero-copy p,
  .about-manifesto-card p,
  .about-creator-copy p {
    font-size: 18px;
  }

  .about-manifesto,
  .about-pillars {
    padding-left: 20px;
    padding-right: 20px;
  }

  .about-creator,
  .about-values,
  .about-ecosystem,
  .about-final-cta {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .about-manifesto-card,
  .about-manifesto-aside {
    padding: 28px 22px;
  }

  .about-manifesto-card h2,
  .about-creator-copy h2,
  .about-values-header h2,
  .about-ecosystem-header h2 {
    font-size: 32px;
  }

  .about-pillar-grid,
  .about-value-grid,
  .about-timeline-grid {
    grid-template-columns: 1fr;
  }

  .about-final-actions,
  .about-final-actions .lg-btn,
  .about-creator-actions .lg-btn {
    width: 100%;
  }
}
/* ================================================= */
/* SOBRE - WP READY */
/* Página institucional */
/* Cole no final do style.css */
/* ================================================= */

.about-page .about-hero {
  padding: 58px 56px 32px;
}

.about-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.about-breadcrumb a {
  text-decoration: none;
}

.about-breadcrumb a:hover {
  color: var(--purple);
}

.about-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.about-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.about-hero-card > * {
  position: relative;
  z-index: 2;
}

.about-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.about-hero-copy p {
  max-width: 820px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.about-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.about-hero-art {
  margin: 0;

  display: flex;
  align-items: center;
  justify-content: center;
}

.about-hero-art img {
  width: min(100%, 300px);
  max-height: 260px;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(43, 26, 16, 0.16));
}

/* Manifesto */

.about-manifesto {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.about-manifesto-card,
.about-manifesto-aside,
.about-pillar-card,
.about-creator,
.about-values,
.about-ecosystem,
.about-final-cta {
  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.about-manifesto-card::before,
.about-manifesto-aside::before,
.about-pillar-card::before,
.about-creator::before,
.about-values::before,
.about-ecosystem::before,
.about-final-cta::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.about-manifesto-card > *,
.about-manifesto-aside > *,
.about-pillar-card > *,
.about-creator > *,
.about-values > *,
.about-ecosystem > *,
.about-final-cta > * {
  position: relative;
  z-index: 2;
}

.about-manifesto-card {
  padding: 38px 40px;
}

.about-manifesto-card h2 {
  max-width: 860px;
  margin: 12px 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 42px;
  line-height: 0.98;
  text-transform: uppercase;
}

.about-manifesto-card p {
  max-width: 900px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.about-manifesto-card p:last-child {
  margin-bottom: 0;
}

.about-manifesto-aside {
  padding: 34px 28px;
}

.about-manifesto-aside h3 {
  margin: 0 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.about-manifesto-aside ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.about-manifesto-aside li {
  padding: 13px 0;
  color: var(--ink);
  border-bottom: 1px solid rgba(164, 112, 52, 0.24);
  font-size: 16px;
  font-weight: 700;
}

.about-manifesto-aside li::before {
  content: "✦ ";
  color: var(--purple);
}

/* Pilares */

.about-pillars {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.about-title-row {
  margin-bottom: 18px;
}

.about-pillar-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.about-pillar-card {
  min-height: 240px;
  padding: 28px 24px;
  text-align: center;
}

.about-pillar-card__icon {
  width: 62px;
  height: 62px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;

  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.about-pillar-card h3,
.about-value-card strong,
.about-timeline-card h3,
.about-creator-card h3 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 21px;
  line-height: 1;
  text-transform: uppercase;
}

.about-pillar-card p,
.about-value-card p,
.about-timeline-card p,
.about-creator-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15.5px;
  line-height: 1.38;
}

/* Criador */

.about-creator {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 42px 46px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: 34px;
  align-items: center;
}

.about-creator-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 46px;
  line-height: 0.95;
  text-transform: uppercase;
}

.about-creator-copy p {
  max-width: 820px;
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 20px;
  line-height: 1.42;
}

.about-creator-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 24px;
}

.about-creator-card {
  padding: 30px 24px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.12);
}

.about-creator-icon {
  width: 82px;
  height: 82px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  font-weight: 900;
}

/* Valores + ecossistema */

.about-values,
.about-ecosystem {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;
}

.about-values-header,
.about-ecosystem-header {
  text-align: center;
  margin-bottom: 24px;
}

.about-values-header h2,
.about-ecosystem-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.about-values-header p,
.about-ecosystem-header p {
  max-width: 760px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.about-value-grid,
.about-timeline-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.about-value-card,
.about-timeline-card {
  padding: 24px 18px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.about-value-card strong {
  display: block;
  color: var(--purple);
}

.about-timeline-card span {
  width: 52px;
  height: 52px;
  margin: 0 auto 16px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  font-weight: 900;
}

/* CTA final */

.about-final-cta {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
}

.about-final-cta h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.about-final-cta p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.about-final-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Responsivo */

@media (max-width: 1300px) {
  .about-manifesto,
  .about-creator,
  .about-final-cta,
  .about-hero-card {
    grid-template-columns: 1fr;
  }

  .about-pillar-grid,
  .about-value-grid,
  .about-timeline-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-hero-art {
    display: none;
  }
}

@media (max-width: 900px) {
  .about-page .about-hero {
    padding: 36px 20px 28px;
  }

  .about-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .about-hero-copy h1 {
    font-size: 46px;
  }

  .about-hero-copy p,
  .about-manifesto-card p,
  .about-creator-copy p {
    font-size: 18px;
  }

  .about-manifesto,
  .about-pillars {
    padding-left: 20px;
    padding-right: 20px;
  }

  .about-creator,
  .about-values,
  .about-ecosystem,
  .about-final-cta {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .about-manifesto-card,
  .about-manifesto-aside {
    padding: 28px 22px;
  }

  .about-manifesto-card h2,
  .about-creator-copy h2,
  .about-values-header h2,
  .about-ecosystem-header h2 {
    font-size: 32px;
  }

  .about-pillar-grid,
  .about-value-grid,
  .about-timeline-grid {
    grid-template-columns: 1fr;
  }

  .about-final-actions,
  .about-final-actions .lg-btn,
  .about-creator-actions .lg-btn {
    width: 100%;
  }
}

/* ================================================= */
/* SOBRE - BLOCO MAX RODRIGUES COM FOTO */
/* versão limpa, sem corte e sem caixas duplicadas */
/* Caminho da imagem: assets/about/max-rodrigues.png */
/* ================================================= */

/* Estrutura geral da área */
.about-creator.about-creator-with-photo {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 430px);
  gap: 52px;
  align-items: center;

  position: relative;
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 86% 16%, rgba(86, 32, 129, 0.045), transparent 34%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

/* Moldura interna única da seção */
.about-creator.about-creator-with-photo::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
  z-index: 1;
}

.about-creator.about-creator-with-photo > * {
  position: relative;
  z-index: 2;
}

/* Coluna de texto */
.about-creator-with-photo .about-creator-copy {
  max-width: 900px;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.about-creator-with-photo .about-creator-copy .section-kicker {
  margin-bottom: 18px;
}

.about-creator-with-photo .about-creator-copy h2 {
  margin: 0 0 22px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(42px, 4vw, 64px);
  line-height: 0.95;
  font-weight: 900;
  letter-spacing: -0.035em;
  text-transform: uppercase;
}

.about-creator-with-photo .about-creator-copy p {
  max-width: 840px;
  margin: 0 0 20px;

  color: rgba(43, 26, 16, 0.86);
  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 21px;
  line-height: 1.44;
}

.about-creator-with-photo .about-creator-copy p:last-of-type {
  margin-bottom: 0;
}

.about-creator-with-photo .about-creator-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 34px;
}

/* Coluna da foto, sem card dentro de card */
.about-creator-photo-card {
  width: 100%;
  max-width: 430px;
  justify-self: center;

  position: relative;
  padding: 0;

  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;

  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

/* Remove molduras antigas da coluna */
.about-creator-photo-card::before,
.about-creator-photo-card::after {
  display: none !important;
}

/* Foto */
.about-creator-photo-card figure {
  width: 100%;
  margin: 0;

  position: relative;

  display: block;

  border: 1px solid rgba(164, 112, 52, 0.42);
  background: rgba(255, 246, 222, 0.10);
  box-shadow:
    0 16px 26px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.18);

  overflow: hidden;
}

/* Desliga véus antigos que davam sensação de corte */
.about-creator-photo-card figure::before,
.about-creator-photo-card figure::after {
  display: none !important;
}

/* Imagem sem corte */
.about-creator-photo-card img {
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: none !important;

  display: block !important;

  object-fit: contain !important;
  object-position: center !important;

  filter:
    saturate(0.98)
    contrast(1.02)
    drop-shadow(0 12px 18px rgba(43, 26, 16, 0.10));
}

/* Legenda sem caixa duplicada */
.about-creator-photo-caption {
  width: 100%;
  padding: 0 8px;

  position: relative;
  text-align: center;

  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.about-creator-photo-caption::before {
  content: "";
  display: block;

  width: 78%;
  height: 1px;
  margin: 2px auto 18px;

  background: linear-gradient(
    to right,
    transparent,
    rgba(164, 112, 52, 0.46),
    transparent
  );
}

.about-creator-photo-caption span {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: fit-content;
  min-height: 28px;
  margin: 0 auto 12px;
  padding: 0 12px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.about-creator-photo-caption h3 {
  margin: 0 0 8px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  font-weight: 900;
  text-transform: uppercase;
}

.about-creator-photo-caption p {
  max-width: 330px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 16px;
  line-height: 1.34;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .about-creator.about-creator-with-photo {
    grid-template-columns: 1fr;
    gap: 38px;
  }

  .about-creator-photo-card {
    max-width: 520px;
  }

  .about-creator-with-photo .about-creator-copy {
    max-width: none;
  }
}

@media (max-width: 900px) {
  .about-creator.about-creator-with-photo {
    width: calc(100% - 40px);
    padding: 34px 24px;
  }

  .about-creator-with-photo .about-creator-copy h2 {
    font-size: 38px;
  }

  .about-creator-with-photo .about-creator-copy p {
    font-size: 18px;
  }

  .about-creator-with-photo .about-creator-actions {
    width: 100%;
  }

  .about-creator-with-photo .about-creator-actions .lg-btn {
    width: 100%;
  }

  .about-creator-photo-card {
    max-width: 440px;
  }
}

@media (max-width: 640px) {
  .about-creator.about-creator-with-photo {
    width: calc(100% - 32px);
    padding: 30px 20px;
  }

  .about-creator-photo-caption h3 {
    font-size: 23px;
  }

  .about-creator-photo-caption p {
    font-size: 14.5px;
  }
}

/* ================================================= */
/* LIVES - WP READY */
/* Página de lives, links sociais e VODs */
/* Cole no final do style.css */
/* ================================================= */

.lives-page .lives-hero {
  padding: 58px 56px 32px;
}

.lives-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;

  width: min(100%, 1420px);
  margin: 0 auto 22px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.lives-breadcrumb a {
  text-decoration: none;
}

.lives-breadcrumb a:hover {
  color: var(--purple);
}

.lives-hero-card {
  position: relative;

  width: min(100%, 1420px);
  min-height: 420px;
  margin: 0 auto;
  padding: 54px 56px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
  gap: 40px;
  align-items: center;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 84% 22%, rgba(86, 32, 129, 0.08), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.lives-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.lives-hero-card > * {
  position: relative;
  z-index: 2;
}

.lives-hero-copy h1 {
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: 0.88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.045em;
}

.lives-hero-copy p {
  max-width: 800px;
  margin: 0 0 26px;

  color: rgba(43, 26, 16, 0.86);
  font-size: 23px;
  line-height: 1.32;
}

.lives-hero-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.lives-hero-panel {
  padding: 30px 26px;

  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.14);
}

.lives-hero-panel__icon {
  width: 76px;
  height: 76px;
  margin: 0 auto 18px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;
  box-shadow:
    0 10px 20px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.lives-hero-panel h2 {
  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-hero-panel p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 16px;
  line-height: 1.38;
}

/* ================================================= */
/* LINKS DAS PLATAFORMAS */
/* ================================================= */

.lives-platforms,
.vod-gallery {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
}

.lives-title-row {
  margin-bottom: 18px;
}

.lives-platform-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.lives-platform-card {
  position: relative;
  min-height: 210px;
  padding: 28px 22px;

  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 16px;
  justify-items: center;

  color: var(--ink);
  text-align: center;
  text-decoration: none;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 8%, rgba(86, 32, 129, 0.06), transparent 34%),
    rgba(255, 246, 222, 0.13);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    0 12px 22px rgba(43, 26, 16, 0.04);

  overflow: hidden;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.lives-platform-card::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.lives-platform-card > * {
  position: relative;
  z-index: 2;
}

.lives-platform-card:hover {
  transform: translateY(-4px);
  background:
    radial-gradient(circle at 50% 8%, rgba(86, 32, 129, 0.10), transparent 34%),
    rgba(255, 246, 222, 0.16);
  box-shadow: 0 16px 26px rgba(43, 26, 16, 0.10);
}

.lives-platform-card__icon {
  width: 66px;
  height: 66px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  font-weight: 900;

  box-shadow:
    0 10px 18px rgba(43, 26, 16, 0.14),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
}

.lives-platform-card__copy strong {
  display: block;
  margin-bottom: 6px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-platform-card__copy small {
  display: block;
  margin-bottom: 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lives-platform-card__copy em {
  display: block;
  max-width: 240px;

  color: rgba(43, 26, 16, 0.76);
  font-size: 15px;
  font-style: normal;
  line-height: 1.34;
}

.lives-platform-card__arrow {
  color: var(--purple);
  font-size: 24px;
  font-weight: 900;
}

/* ================================================= */
/* ÚLTIMO VOD EM DESTAQUE */
/* ================================================= */

.latest-vod-feature {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 40px;

  display: grid;
  grid-template-columns: minmax(0, 0.75fr) minmax(480px, 1.25fr);
  gap: 28px;
  align-items: center;

  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.13);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 24px rgba(43, 26, 16, 0.05);
  overflow: hidden;
}

.latest-vod-feature::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.latest-vod-feature > * {
  position: relative;
  z-index: 2;
}

.latest-vod-copy h2 {
  margin: 12px 0 18px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(34px, 3.4vw, 52px);
  line-height: 0.95;
  text-transform: uppercase;
}

.latest-vod-copy p {
  max-width: 620px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.84);
  font-size: 19px;
  line-height: 1.42;
}

.latest-vod-embed {
  width: 100%;
}

.latest-vod-placeholder {
  aspect-ratio: 16 / 9;
  width: 100%;
  min-height: 300px;

  display: grid;
  place-items: center;
  align-content: center;
  gap: 12px;

  text-align: center;
  color: #f8e7bd;

  border: 1px solid #9f743f;
  background:
    radial-gradient(circle at 50% 20%, rgba(86, 32, 129, 0.36), transparent 36%),
    linear-gradient(135deg, rgba(22, 8, 20, 0.98), rgba(43, 26, 16, 0.94));
  box-shadow:
    inset 0 0 0 1px rgba(255, 243, 214, 0.15),
    0 18px 28px rgba(43, 26, 16, 0.18);
}

.latest-vod-placeholder span {
  width: 78px;
  height: 78px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 30px;
}

.latest-vod-placeholder strong {
  color: #f8e7bd;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  text-transform: uppercase;
}

.latest-vod-placeholder small {
  max-width: 420px;
  color: rgba(248, 231, 189, 0.76);
  font-size: 15px;
  line-height: 1.34;
}

/* ================================================= */
/* GALERIA VOD */
/* ================================================= */

.vod-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.vod-card {
  position: relative;
  min-width: 0;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 92% 10%, rgba(86, 32, 129, 0.05), transparent 30%),
    rgba(255, 246, 222, 0.13);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.20),
    0 12px 22px rgba(43, 26, 16, 0.04);
  overflow: hidden;
}

.vod-card::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
  z-index: 2;
}

.vod-card__thumb {
  position: relative;
  min-height: 205px;
  display: flex;
  align-items: center;
  justify-content: center;

  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.78), rgba(20, 10, 5, 0.10)),
    var(--vod-thumb);
  background-size: cover;
  background-position: center;

  text-decoration: none;
}

.vod-card__play {
  width: 62px;
  height: 62px;

  display: grid;
  place-items: center;

  color: var(--cream);
  border-radius: 50%;
  background: var(--purple);
  font-size: 24px;

  box-shadow:
    0 10px 20px rgba(0, 0, 0, 0.30),
    inset 0 0 0 1px rgba(255, 255, 255, 0.18);
}

.vod-card__duration {
  position: absolute;
  right: 14px;
  bottom: 14px;

  min-height: 28px;
  padding: 0 10px;

  display: inline-flex;
  align-items: center;

  color: var(--cream);
  background: rgba(20, 10, 5, 0.82);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.vod-card__copy {
  position: relative;
  z-index: 3;
  padding: 22px 22px 24px;
}

.vod-card__copy .post-category {
  position: static;
  display: inline-flex;
  width: fit-content;
  margin-bottom: 14px;
}

.vod-card__copy h3 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1.05;
  text-transform: uppercase;
}

.vod-card__copy p {
  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.76);
  font-size: 15.5px;
  line-height: 1.36;
}

.vod-card__copy a {
  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

/* ================================================= */
/* PROGRAMAÇÃO */
/* ================================================= */

.lives-schedule {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 38px 40px;

  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 0%, rgba(86, 32, 129, 0.05), transparent 34%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.lives-schedule::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.lives-schedule > * {
  position: relative;
  z-index: 2;
}

.lives-schedule-header {
  margin-bottom: 24px;
  text-align: center;
}

.lives-schedule-header h2 {
  margin: 0 0 12px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 38px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-schedule-header p {
  max-width: 720px;
  margin: 0 auto;

  color: rgba(43, 26, 16, 0.78);
  font-size: 17px;
  line-height: 1.35;
}

.lives-schedule-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.lives-schedule-card {
  padding: 24px 20px;
  text-align: center;
  border: 1px solid rgba(164, 112, 52, 0.32);
  background: rgba(255, 246, 222, 0.10);
}

.lives-schedule-card span {
  display: inline-flex;
  min-height: 28px;
  margin-bottom: 14px;
  padding: 0 10px;
  align-items: center;
  justify-content: center;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.lives-schedule-card h3 {
  margin: 0 0 10px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-schedule-card p {
  margin: 0;
  color: rgba(43, 26, 16, 0.78);
  font-size: 15px;
  line-height: 1.34;
}

/* ================================================= */
/* CTA COMUNIDADE */
/* ================================================= */

.lives-community-cta {
  width: calc(100% - 64px);
  max-width: 1500px;
  margin: 0 auto 34px;
  padding: 30px 34px;

  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;

  position: relative;

  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 8% 80%, rgba(184, 137, 72, 0.10), transparent 36%),
    rgba(255, 246, 222, 0.13);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.lives-community-cta::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.lives-community-cta > * {
  position: relative;
  z-index: 2;
}

.lives-community-cta h2 {
  margin: 0 0 8px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.lives-community-cta p {
  margin: 0;
  color: rgba(43, 26, 16, 0.82);
  font-size: 16px;
  line-height: 1.35;
}

.lives-community-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .lives-hero-card,
  .latest-vod-feature,
  .lives-community-cta {
    grid-template-columns: 1fr;
  }

  .lives-platform-grid,
  .vod-gallery-grid,
  .lives-schedule-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .latest-vod-feature {
    padding: 34px;
  }
}

@media (max-width: 900px) {
  .lives-page .lives-hero {
    padding: 36px 20px 28px;
  }

  .lives-hero-card {
    min-height: auto;
    padding: 34px 24px;
  }

  .lives-hero-copy h1 {
    font-size: 46px;
  }

  .lives-hero-copy p,
  .latest-vod-copy p {
    font-size: 18px;
  }

  .lives-platforms,
  .vod-gallery {
    padding-left: 20px;
    padding-right: 20px;
  }

  .latest-vod-feature,
  .lives-schedule,
  .lives-community-cta {
    width: calc(100% - 40px);
    padding: 28px 22px;
  }

  .lives-platform-grid,
  .vod-gallery-grid,
  .lives-schedule-grid {
    grid-template-columns: 1fr;
  }

  .latest-vod-placeholder {
    min-height: 220px;
  }

  .lives-hero-actions .lg-btn,
  .lives-community-actions,
  .lives-community-actions .lg-btn {
    width: 100%;
  }
}


/* ================================================= */
/* WP v0.3.0 - Full site shell */
/* ================================================= */

body.full-static-page .wp-static-shell {
  width: 100%;
}

/* Quando uma página estática carrega dentro do header/footer global, evita sobras inesperadas */
.wp-static-shell > :first-child {
  margin-top: 0;
}

/* Links sem href válido não devem parecer quebrados quando forem âncoras visuais do HTML aprovado */
.wp-static-shell a[href="#"] {
  cursor: default;
}

/* Em páginas convertidas, garante que imagens locais nunca vazem proporção */
.wp-static-shell img {
  max-width: 100%;
}

/* Discord oficial em CTAs */
a[href="https://discord.gg/tts6wdX"] {
  pointer-events: auto;
}

/* ================================================= */
/* WP v0.3.1 - Correção crítica: parse + rolagem */
/* ================================================= */

/* O HTML aprovado usava overflow hidden na .page para o mockup estático.
   No WordPress isso trava páginas longas como Lives. */
html,
body {
  min-height: 100%;
  overflow-x: hidden;
  overflow-y: auto !important;
}

.page,
.site-page,
body.full-static-page .page,
body.full-static-page .site-page {
  overflow: visible !important;
  min-height: 100vh;
}

/* Garante que páginas longas possam rolar mesmo quando algum template estático trouxer alturas do mockup. */
.wp-static-shell {
  overflow: visible !important;
  min-height: auto;
}


/* WP v0.3.2 - correção final de strings de assets em PHP */


/* ============================================================
   v0.4.2 - visual aprovado + loops reais + singles saneados
   ============================================================ */

html, body { min-height: 100%; overflow-x: hidden; overflow-y: auto !important; }
.page, .site-page, .wp-static-shell { overflow: visible !important; }

/* Respiros de arquivo para não colar no header */
.lives-platforms,
.reviews-category-showcase,
.category-filter-row,
.more-news-section,
.guides-featured-area,
.partners-intro,
.partners-contact { margin-top: clamp(26px, 4vw, 64px); }

/* Categorias da home: 5 cards e Filmes & Séries unificado */
.categories { grid-template-columns: repeat(5, minmax(0, 1fr)); }
@media (max-width: 1100px) { .categories { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 640px) { .categories { grid-template-columns: 1fr; } }

/* Gatinhos nunca mais Kaiju */
.rating-cats img,
.post-rating-icons img,
.review-card__rating img,
.category-rating img,
.related-rating img,
.rating-cats-small img,
.rating-cats-card img,
.rating-cats-sidebar img {
  width: 17px !important;
  height: 17px !important;
  max-width: 17px !important;
  max-height: 17px !important;
  object-fit: contain !important;
  display: inline-block !important;
}
.rating-cats-feature img,
.rating-cats-featured img { width: 30px !important; height: 30px !important; max-width: 30px !important; max-height: 30px !important; }
.rating-cats-large img { width: 26px !important; height: 26px !important; max-width: 26px !important; max-height: 26px !important; }
.rating-cats-medium img { width: 22px !important; height: 22px !important; max-width: 22px !important; max-height: 22px !important; }

.cat-icon.cat-half { position: relative; display: inline-block; width: 17px; height: 17px; overflow: hidden; }
.cat-icon.cat-half img { position: absolute; inset: 0; width: 17px !important; height: 17px !important; }
.cat-icon.cat-half .cat-full-half { clip-path: inset(0 50% 0 0); }

/* Cards dinâmicos dentro da roupa aprovada */
.post-card,
.category-review-card,
.featured-review-card,
.mini-review-card,
.news-card,
.guide-post-card,
.guides-secondary-card,
.vod-card {
  background-size: cover;
  background-position: center;
}
.card.post-card,
.category-review-card,
.featured-review-card,
.mini-review-card,
.guide-post-card,
.vod-card {
  background-image: linear-gradient(to top, rgba(20,10,5,.98) 0%, rgba(20,10,5,.84) 34%, rgba(20,10,5,.28) 68%, rgba(20,10,5,.06) 100%), var(--post-bg);
}
.news-card { background-image: linear-gradient(to top, rgba(20,10,5,.96), rgba(20,10,5,.20)), var(--news-bg); }

.legolas-empty-state {
  width: 100%;
  border: 1px solid var(--line-soft);
  padding: 24px;
  text-align: center;
  background: rgba(255, 248, 226, .45);
  color: var(--ink);
  font-weight: 700;
}

.lives-platform-card__icon img,
.platform-icon img,
.event-platform img {
  width: 24px !important;
  height: 24px !important;
  object-fit: contain !important;
}

.lives-hero-panel__icon.is-youtube,
.lives-hero-card__icon.is-youtube,
.latest-vod-placeholder .is-youtube,
.vod-card__play.is-youtube {
  background: #e62117 !important;
  color: #fff !important;
}

.book-review .book-store-logo img { max-width: 220px !important; max-height: 90px !important; object-fit: contain !important; }
.book-review .review-content { margin-bottom: clamp(36px, 5vw, 80px); }
.book-review .book-favorite-quotes { min-height: unset; }
.book-review .favorite-quotes-list blockquote { margin-bottom: 18px; }

.form-status { border: 1px solid var(--line-soft); padding: 14px 18px; margin: 0 0 18px; font-weight: 700; }
.form-status.success { color: #195c2e; background: rgba(47,132,78,.1); }
.form-status.error { color: #7a1e1e; background: rgba(180,42,42,.1); }
.legolas-honeypot { position: absolute !important; left: -9999px !important; opacity: 0 !important; pointer-events: none !important; }

a[href="https://discord.gg/tts6wdX"], a[href^="mailto:pautas@legolasgeek.com"] { pointer-events: auto; }


/* ============================================================
   v0.4.3 - pente fino: legibilidade + blocos aprovados preservados
   ============================================================ */

/* Legibilidade geral: texto um pouco maior sem inflar títulos */
body {
  font-size: 17px;
}

p,
li,
small,
.review-intro,
.post-excerpt,
.guide-post-card p,
.news-card-copy small,
.lives-platform-card__copy em {
  font-size: clamp(1rem, 0.95rem + 0.16vw, 1.12rem);
  line-height: 1.58;
}

.footer-column a,
.footer-column p {
  color: rgba(255, 245, 210, 0.86) !important;
}

/* Home: manter o bloco Guias & Listas minimalista, sem ícone gigante */
.info-card.guides-card > img,
.info-card.guide-card > img,
.guides-card > img,
.guide-card > img {
  display: none !important;
}

.guides-card .guide-list,
.guide-card .guide-list {
  margin-top: 22px;
}

.guides-card .guide-item img,
.guide-card .guide-item img {
  width: 28px !important;
  height: 28px !important;
  object-fit: contain !important;
}

.coven-features {
  display: grid !important;
}

.social-panel .social-links,
.social-panel .footer-social {
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}

.social-panel .social-links a,
.social-panel .footer-social a,
.footer-social a {
  width: 42px !important;
  height: 42px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--purple) !important;
  color: #fff !important;
  overflow: hidden !important;
  text-indent: -9999px !important;
}

.social-panel .social-links a img,
.social-panel .footer-social a img,
.footer-social a img {
  width: 22px !important;
  height: 22px !important;
  object-fit: contain !important;
  display: block !important;
  text-indent: 0 !important;
}

/* Lives: o ícone roxo do card principal continua roxo; apenas elementos YouTube ficam vermelhos */
.lives-hero-panel__icon,
.lives-hero-card__icon {
  background: var(--purple) !important;
  color: #fff !important;
}

.latest-vod-placeholder span,
.vod-card__play,
.vod-card__play.is-youtube,
.latest-vod-copy .lg-btn-primary {
  background: #e62117 !important;
  color: #fff !important;
}

.lives-platforms {
  margin-top: clamp(36px, 5vw, 82px) !important;
}

.lives-platform-card__icon img {
  width: 28px !important;
  height: 28px !important;
  object-fit: contain !important;
}

.lives-schedule-header {
  text-align: center;
  margin-bottom: 28px;
}

.lives-schedule-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.lives-schedule-card {
  min-height: 126px;
}

@media (max-width: 900px) {
  .lives-schedule-grid {
    grid-template-columns: 1fr;
  }
}

/* Reviews archive e categorias: respiro e grid menos esmagado */
.reviews-archive-hero,
.reviews-category-showcase,
.category-hero {
  margin-top: clamp(22px, 3vw, 54px) !important;
}

.reviews-category-section__grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(170px, 220px));
  gap: 18px;
  align-items: stretch;
}

.reviews-category-post-card,
.mini-review-card {
  min-height: 250px;
}

.category-card-grid,
.archive-grid,
.review-grid-loop {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 22px;
}

.category-review-card {
  min-height: 330px;
}

/* Notícias: template aprovado com grade real */
.news-index-hero {
  margin-top: clamp(24px, 3vw, 56px) !important;
}

.more-news-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 22px;
}

.news-card {
  min-height: 330px;
  text-decoration: none;
}

/* Guias single/archive */
.guides-archive-hero {
  margin-top: clamp(24px, 3vw, 56px) !important;
}

.guide-single-layout {
  margin: clamp(32px, 5vw, 72px) auto;
  max-width: 1180px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 28px;
}

@media (max-width: 980px) {
  .guide-single-layout {
    grid-template-columns: 1fr;
  }
}

/* Livro/HQ: usar hero cadastrado, centralização e área de Ads */
.book-review-hero {
  align-items: center !important;
}

.book-review-hero .book-hero-art {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.book-review-hero .book-hero-art img {
  max-width: min(560px, 100%) !important;
  width: auto !important;
  max-height: 520px !important;
  object-fit: contain !important;
}

.book-store-logo img {
  max-width: 220px !important;
  max-height: 90px !important;
  object-fit: contain !important;
}

.premium-quote .quote-frame {
  position: relative;
  min-height: 240px;
  padding: 52px 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  flex-direction: column;
}

.premium-quote .quote-bg-img {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 390px;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  opacity: 1;
  z-index: 0;
  pointer-events: none;
}

.premium-quote .review-quote-text,
.premium-quote .review-quote-author {
  position: relative;
  z-index: 2;
}

.review-ad-card {
  border: 1px solid var(--line-soft);
  padding: 16px;
  margin-top: 22px;
  background: rgba(255, 248, 226, 0.42);
}

.ad-slot-300x250 {
  min-height: 250px;
  border: 1px dashed rgba(104, 44, 150, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(43, 26, 16, 0.65);
}


/* ============================================================
   v0.4.4 - pente fino 2: header global + reviews/news + fields
   ============================================================ */

/* Header global com respiro para a logo não comer breadcrumb/hero */
.topbar,
.topbar.site-header {
  height: auto !important;
  min-height: 205px !important;
  padding-top: 18px !important;
  padding-bottom: 28px !important;
  align-items: center !important;
}

.logo img,
.site-logo img {
  width: 250px !important;
  height: auto !important;
}

/* Todas as primeiras seções começam depois do brasão respirar */
.site-page > section:first-of-type,
.page > section:first-of-type {
  margin-top: clamp(16px, 2vw, 34px);
}

/* Páginas internas com header mais confortável */
.review-hero,
.news-hero,
.news-index-hero,
.guides-archive-hero,
.reviews-archive-hero,
.category-hero,
.partners-hero,
.coven-hero,
.about-hero {
  margin-top: clamp(28px, 4vw, 70px) !important;
}

/* Reviews geral: ativar visual do V2 mesmo se body class vier diferente */
.reviews-hub-page .reviews-archive-hero,
.reviews-hub-page-v2 .reviews-archive-hero {
  padding: 58px 56px 28px !important;
}

.reviews-hub-page .reviews-archive-hero-card,
.reviews-hub-page-v2 .reviews-archive-hero-card {
  position: relative;
  width: min(100%, 1420px);
  margin: 0 auto;
  min-height: 250px;
  padding: 42px 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 0%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.22),
    0 12px 28px rgba(43, 26, 16, 0.05);
}

.reviews-hub-page .reviews-archive-hero-card::before,
.reviews-hub-page-v2 .reviews-archive-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.reviews-hub-page .reviews-archive-hero-copy,
.reviews-hub-page-v2 .reviews-archive-hero-copy {
  position: relative;
  z-index: 2;
  max-width: 760px;
  margin: 0 auto;
}

.reviews-category-hero-card__image {
  width: 100%;
  height: 150px;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.reviews-category-hero-card__image img {
  max-width: 128px;
  max-height: 128px;
  object-fit: contain;
  display: block;
}

.reviews-category-hero-card__copy {
  min-height: 74px;
  display: grid;
  gap: 8px;
  align-content: start;
}

.reviews-category-hero-card__copy strong {
  color: var(--ink);
  font-family: var(--font-title);
  font-size: 20px;
  text-transform: uppercase;
}

.reviews-category-hero-card__copy small {
  color: rgba(43, 26, 16, 0.82);
}

.reviews-category-hero-card__link {
  justify-self: center;
  padding: 9px 12px;
  border: 1px solid var(--line);
  color: var(--purple);
  font-weight: 900;
  font-size: 11px;
  text-transform: uppercase;
}

/* Notícias single aprovado */
.news-hero {
  width: min(100%, 1500px);
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 56px 42px;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.85fr);
  gap: 42px;
  align-items: center;
}

.news-hero h1 {
  font-family: var(--font-title);
  font-size: clamp(46px, 6vw, 92px);
  line-height: 0.95;
  color: var(--ink);
  text-transform: uppercase;
}

.news-subtitle {
  max-width: 760px;
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.28;
  font-style: italic;
}

.news-hero-image img {
  width: 100%;
  max-height: 520px;
  object-fit: contain;
}

.news-byline {
  margin-top: 24px;
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  align-items: center;
}

.news-author-mini {
  display: flex;
  gap: 10px;
  align-items: center;
}

.news-author-mini img {
  width: 48px;
  height: 48px;
  object-fit: contain;
}

.news-content-layout {
  width: min(100%, 1320px);
  margin: 36px auto 56px;
  padding: 0 32px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 34px;
  align-items: start;
}

.news-article-body {
  border: 1px solid var(--line);
  padding: clamp(28px, 4vw, 56px);
  background: rgba(255, 246, 222, 0.16);
  font-size: 1.15rem;
  line-height: 1.72;
}

.news-article-body .lead-paragraph {
  font-size: 1.28rem;
  line-height: 1.6;
  font-weight: 600;
}

.news-quote,
.news-summary-box,
.news-tags-box,
.news-discord-box {
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.16);
  padding: 22px;
}

.news-sidebar {
  display: grid;
  gap: 18px;
}

.news-summary-list {
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
  display: grid;
  gap: 12px;
}

.news-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.news-tags a {
  padding: 7px 10px;
  border: 1px solid var(--line);
  color: var(--purple);
  text-decoration: none;
  font-weight: 800;
}

.news-discord-art img {
  max-width: 130px;
  display: block;
  margin: 0 auto 12px;
}

@media (max-width: 980px) {
  .news-hero,
  .news-content-layout {
    grid-template-columns: 1fr;
    padding-left: 24px;
    padding-right: 24px;
  }
}

/* Livro: frases favoritas e quote lateral são campos diferentes */
.book-favorite-quotes .legolas-empty-state {
  max-width: 520px;
  margin: 40px auto;
}

/* Games: plataformas disponíveis por campo marcado */
.game-platform-logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.game-platform-logos a,
.game-platform-logos span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.game-platform-logos img {
  max-width: 58px !important;
  max-height: 42px !important;
  object-fit: contain !important;
}

.game-available-box.is-empty {
  display: none !important;
}


/* ============================================================
   v0.4.5 - notícias aprovadas + ajuste fino de header
   ============================================================ */

/* A home volta para a altura original. Não mexer no que estava aprovado. */
body.home .topbar,
body.home .topbar.site-header {
  height: 155px !important;
  min-height: 155px !important;
  padding: 0 56px !important;
}

/* Páginas internas: respiro suficiente para a logo, sem jogar conteúdo lá pra Nárnia. */
body:not(.home) .topbar,
body:not(.home) .topbar.site-header {
  min-height: 185px !important;
  height: 185px !important;
  padding-top: 10px !important;
  padding-bottom: 8px !important;
}

body:not(.home) .logo img,
body:not(.home) .site-logo img {
  width: 252px !important;
  max-width: none !important;
}

/* sobe de volta os conteúdos internos que ficaram baixos demais na v0.4.4 */
body:not(.home) .review-hero,
body:not(.home) .news-hero,
body:not(.home) .news-archive-hero,
body:not(.home) .news-index-hero,
body:not(.home) .guides-archive-hero,
body:not(.home) .reviews-archive-hero,
body:not(.home) .category-hero,
body:not(.home) .partners-hero,
body:not(.home) .coven-hero,
body:not(.home) .about-hero {
  margin-top: clamp(10px, 1.6vw, 26px) !important;
}

/* Notícias geral, espelhando o HTML final aprovado */
.news-hub-page .news-archive-hero {
  padding: 24px 56px 28px !important;
}

.news-archive-breadcrumb {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;
  width: min(100%, 1420px);
  margin: 0 auto 18px;
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-archive-hero-card {
  position: relative;
  width: min(100%, 1420px);
  margin: 0 auto;
  min-height: 250px;
  padding: 42px 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at 50% 0%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.22), 0 12px 24px rgba(43,26,16,.05);
  overflow: hidden;
}

.news-archive-hero-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-archive-hero-card > * {
  position: relative;
  z-index: 2;
}

.news-archive-hero-card h1 {
  margin: 0 0 18px;
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(64px, 5.6vw, 104px);
  line-height: .88;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -.045em;
}

.news-archive-hero-card p {
  max-width: 780px;
  margin: 0 auto;
  color: rgba(43,26,16,.86);
  font-size: 23px;
  line-height: 1.32;
}

.news-featured-area {
  width: min(100%, 1500px);
  margin: 0 auto 34px;
  padding: 0 32px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: 24px;
  align-items: stretch;
}

.news-featured-main {
  position: relative;
  min-height: 460px;
  padding: 42px 44px 38px;
  display: flex;
  align-items: flex-end;
  color: #f8e7bd;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to right, rgba(20,10,5,.96) 0%, rgba(20,10,5,.72) 42%, rgba(20,10,5,.22) 100%),
    var(--featured-bg);
  background-size: cover;
  background-position: center;
  text-shadow: 0 2px 8px rgba(0,0,0,.86);
  overflow: hidden;
  box-shadow: 0 16px 28px rgba(43,26,16,.10);
}

.news-featured-main::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255,243,214,.22);
  pointer-events: none;
}

.news-featured-main > * {
  position: relative;
  z-index: 2;
}

.news-featured-main h2 {
  max-width: 720px;
  margin: 10px 0 10px;
  color: #ffe6a7;
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(34px, 4vw, 64px);
  line-height: .94;
  font-weight: 900;
  text-transform: uppercase;
}

.news-featured-main p {
  max-width: 560px;
  color: #f8e7bd;
}

.news-featured-secondary {
  display: grid;
  gap: 16px;
}

.news-secondary-card {
  min-height: 132px;
  padding: 22px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #ffe6a7;
  text-decoration: none;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20,10,5,.96), rgba(20,10,5,.42)),
    var(--post-bg);
  background-size: cover;
  background-position: center;
}

.news-secondary-card strong {
  font-family: var(--font-title);
  font-size: 18px;
  line-height: 1;
  text-transform: uppercase;
}

.news-editorial-showcase,
.news-layout,
.news-newsletter {
  width: min(100%, 1500px);
  margin-left: auto;
  margin-right: auto;
  padding-left: 32px;
  padding-right: 32px;
}

.news-editorial-showcase {
  margin-bottom: 34px;
}

.news-title-row {
  margin-bottom: 16px;
}

.news-editorial-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.news-editorial-card {
  min-height: 92px;
  padding: 18px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  color: var(--ink);
  text-decoration: none;
  border: 1px solid var(--line);
  background: rgba(255,246,222,.16);
}

.news-editorial-card__icon img {
  width: 26px;
  height: 26px;
  object-fit: contain;
}

.news-editorial-card__copy {
  display: grid;
  gap: 4px;
}

.news-editorial-card__copy strong {
  font-family: var(--font-title);
  font-size: 16px;
  text-transform: uppercase;
}

.news-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 28px;
  align-items: start;
  margin-bottom: 38px;
}

.news-main {
  display: grid;
  gap: 28px;
}

.news-category-section {
  border: 1px solid var(--line);
  padding: 20px;
  background: rgba(255,246,222,.10);
}

.news-category-section__header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  margin-bottom: 16px;
}

.news-category-section__header h2 {
  margin: 0;
  font-family: var(--font-title);
  font-size: 28px;
  line-height: 1;
  text-transform: uppercase;
}

.news-category-section__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.news-post-card {
  min-height: 330px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #ffe6a7;
  text-decoration: none;
  border: 1px solid #9f743f;
  background-color: var(--card-dark);
  background-image:
    linear-gradient(to top, rgba(20,10,5,.98) 0%, rgba(20,10,5,.84) 42%, rgba(20,10,5,.20) 100%),
    var(--post-bg);
  background-size: cover;
  background-position: center;
  text-shadow: 0 2px 8px rgba(0,0,0,.78);
}

.news-post-card h3 {
  margin: 12px 0 8px;
  color: #ffe6a7;
  font-family: var(--font-title);
  font-size: 22px;
  line-height: .96;
  text-transform: uppercase;
}

.news-post-card p,
.news-post-card small {
  color: #f8e7bd !important;
}

.news-post-meta {
  margin-top: 10px;
  display: inline-flex;
  gap: 8px;
  align-items: center;
  color: #f8e7bd;
  font-size: 13px;
  font-weight: 800;
}

.news-sidebar {
  display: grid;
  gap: 18px;
}

.news-sidebar-box {
  border: 1px solid var(--line);
  padding: 22px;
  background: rgba(255,246,222,.16);
}

.news-most-read ol {
  margin: 14px 0 0;
  padding-left: 22px;
  display: grid;
  gap: 10px;
}

.news-most-read a {
  color: var(--ink);
  font-weight: 800;
}

.news-trending-tags,
.news-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.news-trending-tags a,
.news-tags a {
  padding: 7px 10px;
  border: 1px solid var(--line);
  color: var(--purple);
  text-decoration: none;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 12px;
}

.news-discord-art img {
  max-width: 140px;
  display: block;
  margin: 0 auto 14px;
}

.news-newsletter {
  margin-bottom: 54px;
}

/* Single notícia aprovado */
body.single-noticia .news-hero,
body.news-article .news-hero {
  width: min(100%, 1500px);
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 56px 42px;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(360px, .85fr);
  gap: 42px;
  align-items: center;
}

.news-hero h1 {
  font-family: var(--font-title);
  font-size: clamp(46px, 6vw, 92px);
  line-height: .95;
  color: var(--ink);
  text-transform: uppercase;
}

.news-hero-image {
  margin: 0;
  min-height: 420px;
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,246,222,.12);
}

.news-hero-image img {
  width: 100%;
  max-height: 520px;
  object-fit: contain;
}

.news-content-layout {
  width: min(100%, 1320px);
  margin: 36px auto 56px;
  padding: 0 32px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 34px;
  align-items: start;
}

.news-article-body {
  border: none;
  background: transparent;
  padding: 0;
  font-size: 1.15rem;
  line-height: 1.72;
}

.news-article-body h2 {
  font-family: var(--font-title);
  text-transform: uppercase;
  margin-top: 34px;
}

.news-quote {
  border: 1px solid var(--line);
  background: rgba(255,246,222,.28);
  padding: 22px 26px;
  margin: 28px 0;
  color: var(--purple);
  font-style: italic;
}

.news-summary-box,
.news-tags-box,
.news-discord-box {
  border: 1px solid var(--line);
  background: rgba(255,246,222,.16);
  padding: 22px;
}

.news-summary-list {
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
  display: grid;
  gap: 12px;
}

.news-share-row a img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

@media (max-width: 980px) {
  .news-featured-area,
  .news-layout,
  body.single-noticia .news-hero,
  body.news-article .news-hero,
  .news-content-layout {
    grid-template-columns: 1fr;
  }

  .news-editorial-grid,
  .news-category-section__grid {
    grid-template-columns: 1fr;
  }
}


/* ============================================================
   v0.4.6 - single notícia: restauração do CSS aprovado
   ============================================================ */

/* Força o post individual de notícia a usar a escala aprovada, sem ficar miniaturizado */
body.single-noticia,
body.news-article {
  font-size: 16px;
}

/* Não deixar overrides anteriores estreitarem o single de notícia */
body.single-noticia .site-page,
body.news-article .site-page {
  width: 100%;
  max-width: none;
}

body.single-noticia .news-hero,
body.news-article .news-hero {
  max-width: none !important;
  width: auto !important;
  margin-top: 0 !important;
}

/* Hero sem imagem cadastrada continua elegante, sem alt quebrado */
body.single-noticia .news-hero:not(:has(.news-hero-image)),
body.news-article .news-hero:not(:has(.news-hero-image)) {
  grid-template-columns: minmax(0, 1fr) !important;
}

body.single-noticia .news-hero-image,
body.news-article .news-hero-image {
  min-height: unset !important;
  border: 0 !important;
  background: transparent !important;
}

body.single-noticia .news-hero-image img,
body.news-article .news-hero-image img {
  display: block !important;
}


/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .news-article */

/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: body.single-noticia */



/* Correções finas por cima do CSS aprovado */
body.single-noticia .news-hero,
body.news-article .news-hero {
  padding-top: 26px !important;
}

body.single-noticia .news-byline,
body.news-article .news-byline {
  align-items: stretch;
}

body.single-noticia .news-share-row a,
body.news-article .news-share-row a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

body.single-noticia .news-share-row img,
body.news-article .news-share-row img {
  width: 22px !important;
  height: 22px !important;
  object-fit: contain !important;
}

body.single-noticia .news-summary-list li,
body.news-article .news-summary-list li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

body.single-noticia .news-summary-list li::before,
body.news-article .news-summary-list li::before {
  content: "✦";
  color: var(--purple);
  font-weight: 900;
}

body.single-noticia .news-summary-list li img,
body.news-article .news-summary-list li img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

body.single-noticia .news-discord-art img,
body.news-article .news-discord-art img {
  max-width: 150px !important;
  height: auto !important;
}

body.single-noticia .more-news-section,
body.news-article .more-news-section {
  width: auto !important;
}

body.single-noticia .more-news-grid .legolas-empty-state,
body.news-article .more-news-grid .legolas-empty-state {
  grid-column: 1 / -1;
}


/* ============================================================
   v0.4.7 - SINGLE NOTÍCIA: CSS aprovado completo
   Fonte: noticias/novo-trailer-de-fantasia.html + style.css final
   ============================================================ */

/* Cancela as correções experimentais anteriores apenas no single de notícia */
body.single-noticia.news-article .news-hero,
body.single-noticia.news-article .news-content-layout,
body.single-noticia.news-article .more-news-section,
body.single-noticia.news-article .newsletter-panel {
  box-sizing: border-box;
}

body.single-noticia.news-article .news-hero-image--empty {
  min-height: 330px;
}

body.single-noticia.news-article .news-hero-image--empty::after {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
}

/* Nunca usar o hero da home como fallback de notícia */
body.single-noticia.news-article .news-hero-image img[src*="hero.png"] {
  display: none !important;
}

/* Força a imagem da notícia a se comportar como o mockup aprovado */
body.single-noticia.news-article .news-hero-image img {
  display: block;
  width: 100%;
}


/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .news-article */
/* ================================================= */

.news-article .news-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.86fr) minmax(520px, 1.14fr);
  gap: 42px;
  align-items: center;

  min-height: 560px;
  padding: 46px 56px 42px;
}

.news-article .news-hero-copy {
  position: relative;
  z-index: 3;
}

.news-article .news-hero .breadcrumb {
  margin-bottom: 28px;
}

.news-article .news-label {
  margin-bottom: 18px;
}

.news-article .news-hero h1 {
  max-width: 660px;
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(44px, 4vw, 76px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.news-article .news-subtitle {
  max-width: 560px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 24px;
  line-height: 1.25;
  font-style: italic;
}

.news-article .news-byline {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(130px, 0.72fr) minmax(130px, 0.72fr) minmax(90px, 0.46fr);
  align-items: center;
  gap: 16px;

  max-width: 720px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.26);
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

.news-article .news-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.news-article .news-author-mini img {
  width: 58px;
  height: 58px;

  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.news-article .news-author-mini span,
.news-article .news-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.news-article .news-author-mini small,
.news-article .news-meta-item small {
  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.news-article .news-author-mini strong,
.news-article .news-meta-item time,
.news-article .news-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

.news-article .news-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 14px;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 34px;
  height: 34px;

  display: grid;
  place-items: center;

  color: var(--ink);
  text-decoration: none;

  border-radius: 50%;
  background: rgba(255, 246, 222, 0.10);

  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: rgba(86, 32, 129, 0.12);
}

.news-article .news-share-row img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.news-article .news-hero-image {
  position: relative;

  margin: 0;
  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  box-shadow:
    0 18px 34px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-hero-image::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.news-article .news-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.24);
}

/* Conteúdo + sidebar */

.news-article .news-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;

  margin: 0 56px 38px;
}

.news-article .news-article-body {
  position: relative;

  padding: 0;

  color: rgba(43, 26, 16, 0.92);
}

.news-article .news-article-body > p {
  max-width: 860px;
  margin: 0 0 20px;

  font-size: 20px;
  line-height: 1.66;
}

.news-article .news-article-body h2 {
  max-width: 860px;
  margin: 34px 0 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  float: left;

  margin: 7px 12px 0 0;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 78px;
  line-height: 0.78;
  font-weight: 900;
}

.news-article .news-quote {
  position: relative;

  max-width: 860px;
  margin: 34px 0;
  padding: 30px 92px 30px 60px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-quote::before {
  content: "“";

  position: absolute;
  left: 28px;
  top: 20px;

  color: var(--purple);
  font-size: 44px;
  line-height: 1;
  opacity: 0.72;
}

.news-article .news-quote::after {
  content: "";

  position: absolute;
  right: 30px;
  bottom: 24px;

  width: 64px;
  height: 64px;

  background-image: url("assets/icons/veredito-gema.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  opacity: 0.72;
}

.news-article .news-quote p {
  margin: 0 0 14px;

  color: var(--purple);
  font-size: 24px;
  line-height: 1.36;
  font-style: italic;
  font-weight: 700;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.72);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

/* Sidebar */

.news-article .news-sidebar {
  display: grid;
  gap: 22px;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  position: relative;

  padding: 26px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 0 18px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.news-article .news-summary-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 16px;

  margin: 0;
  padding: 0;

  list-style: none;
}

.news-article .news-summary-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
}

.news-article .news-summary-list img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  opacity: 0.84;
}

.news-article .news-summary-list span {
  color: rgba(43, 26, 16, 0.82);
  font-size: 15.5px;
  line-height: 1.38;
}

.news-article .news-tags {
  position: relative;
  z-index: 2;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.news-article .news-tags a {
  padding: 7px 10px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.36);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.news-article .news-tags a:hover {
  transform: translateY(-2px);
  background: var(--purple);
  color: var(--cream);
}

.news-article .news-discord-box {
  text-align: center;
}

.news-article .news-discord-art {
  position: relative;
  z-index: 2;

  margin: -8px auto 12px;
}

.news-article .news-discord-art img {
  max-width: 190px;
  max-height: 150px;

  margin: 0 auto;
  object-fit: contain;
}

.news-article .news-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.news-article .news-discord-box .lg-btn {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Mais notícias */

.news-article .more-news-section {
  position: relative;

  margin: 0 56px 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .more-news-section::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .more-news-section .section-title-row,
.news-article .more-news-grid {
  position: relative;
  z-index: 2;
}

.news-article .more-news-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.news-article .news-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 320px;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.13);
}

.news-article .news-card .post-category {
  top: 12px;
  left: 12px;
}

.news-article .news-card-image {
  min-height: 170px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.38), rgba(20, 10, 5, 0.04)),
    var(--news-bg);
  background-size: cover;
  background-position: center;
}

.news-article .news-card-copy {
  padding: 18px;

  display: flex;
  flex: 1;
  flex-direction: column;
}

.news-article .news-card-copy time {
  margin-bottom: 10px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-card-copy h3 {
  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.12;
  text-transform: uppercase;
}

.news-article .news-card-copy small {
  margin-top: auto;

  color: rgba(43, 26, 16, 0.62);
  font-size: 13px;
}

/* Newsletter */

.news-article .newsletter-panel {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .newsletter-art img {
  max-width: 190px;
  max-height: 150px;

  object-fit: contain;
}

.news-article .newsletter-copy h2 {
  margin: 0 0 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .newsletter-copy p {
  max-width: 520px;
  margin: 0;

  color: rgba(43, 26, 16, 0.80);
  font-size: 16px;
  line-height: 1.4;
}

.news-article .newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.news-article .newsletter-form input {
  min-height: 52px;
  min-width: 0;

  padding: 0 16px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.20);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15px;
  outline: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    grid-template-columns: 1fr;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr;
  }

  .news-article .news-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .news-article .newsletter-form {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .news-article .news-byline {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding: 34px 24px 40px;
  }

  .news-article .news-hero h1 {
    font-size: 42px;
  }

  .news-article .news-content-layout,
  .news-article .more-news-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 48px;
  }

  .news-article .news-quote::after {
    display: none;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr;
  }

  .news-article .newsletter-panel {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr;
  }

  .news-article .news-byline {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* NEWS HERO - TAG + BREADCRUMB NA MESMA LINHA */
/* ================================================= */

.news-article .news-label-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;

  margin: 0 0 18px;
}

.news-article .news-label-row .news-label {
  margin: 0;
  flex: 0 0 auto;
}

.news-article .news-breadcrumb-inline {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;

  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

/* Esconde o breadcrumb antigo caso ainda tenha ficado duplicado */
.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none;
}
/* ================================================= */
/* NEWS HERO - SHARE COM CÍRCULOS ROXOS */
/* ================================================= */

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  margin-right: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 36px;
  height: 36px;

  display: grid;
  place-items: center;

  color: var(--cream);
  background: var(--purple);
  border: 1px solid rgba(255, 243, 214, 0.18);
  border-radius: 50%;

  text-decoration: none;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark);

  box-shadow:
    0 12px 20px rgba(43, 26, 16, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.20);
}

.news-article .news-share-row img {
  width: 17px;
  height: 17px;

  object-fit: contain;
  display: block;

  filter: brightness(0) invert(1);
}

.news-article .news-share-row a span {
  color: var(--cream);
  font-size: 16px;
  line-height: 1;
}
/* ================================================= */
/* NEWS HERO - AJUSTE FINO DE POSIÇÃO */
/* desce o hero e afasta breadcrumb da logo */
/* ================================================= */

.news-article .news-hero {
  padding-top: 92px !important;
  padding-bottom: 46px !important;
  align-items: start !important;
}

/* Linha com tag NOTÍCIA + breadcrumb */

.news-article .news-label-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;

  margin: 0 0 20px !important;
}

/* Tag notícia */

.news-article .news-label-row .news-label {
  margin: 0 !important;
  flex: 0 0 auto !important;
}

/* Breadcrumb ao lado da tag, mais à direita e alinhado */

.news-article .news-breadcrumb-inline {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;

  margin: 0 !important;
  transform: translateY(1px);

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

/* Evita que qualquer breadcrumb antigo apareça duplicado */

.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none !important;
}

/* Ajuste do título depois que o hero desce */

.news-article .news-hero h1 {
  margin-top: 0 !important;
}

/* Compartilhamento continua onde está, só com ícones visíveis */

.news-article .news-share-row a {
  width: 36px !important;
  height: 36px !important;

  display: grid !important;
  place-items: center !important;

  color: var(--cream) !important;
  background: var(--purple) !important;
  border: 1px solid rgba(255, 243, 214, 0.18) !important;
  border-radius: 50% !important;

  text-decoration: none !important;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark) !important;
}

.news-article .news-share-row img {
  width: 17px !important;
  height: 17px !important;
  object-fit: contain !important;
  display: block !important;
  filter: brightness(0) invert(1) !important;
}

.news-article .news-share-row a span {
  color: var(--cream) !important;
  font-size: 16px !important;
  line-height: 1 !important;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    padding-top: 62px !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding-top: 34px !important;
  }

  .news-article .news-label-row {
    gap: 14px !important;
  }
}
/* ================================================= */
/* NEWS ARTICLE - AJUSTE DE COLUNAS DO CONTEÚDO */
/* aumenta área de texto e aproxima sidebar */
/* ================================================= */

.news-article .news-content-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 980px) minmax(300px, 360px) !important;
  gap: 34px !important;
  align-items: start !important;
  justify-content: center !important;

  width: 100% !important;
  max-width: 1480px !important;

  margin: 0 auto 42px !important;
  padding: 0 32px !important;
}

/* Coluna principal da matéria */

.news-article .news-article-body {
  width: 100% !important;
  max-width: none !important;
}

/* Faz texto, títulos e quote ocuparem melhor a coluna */

.news-article .news-article-body > p,
.news-article .news-article-body h2,
.news-article .news-quote {
  max-width: none !important;
  width: 100% !important;
}

/* Texto um pouco mais confortável na largura nova */

.news-article .news-article-body > p {
  font-size: 20px !important;
  line-height: 1.68 !important;
}

/* Quote acompanha a largura da coluna */

.news-article .news-quote {
  margin: 34px 0 !important;
}

/* Sidebar fica firme, sem fugir demais para a direita */

.news-article .news-sidebar {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: stretch !important;
}

/* Cards da sidebar mais estáveis */

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  width: 100% !important;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .news-article .news-content-layout {
    grid-template-columns: 1fr !important;
    max-width: 980px !important;
    gap: 28px !important;

    padding: 0 32px !important;
  }

  .news-article .news-sidebar {
    max-width: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-content-layout {
    padding: 0 20px !important;
    margin-bottom: 34px !important;
  }

  .news-article .news-article-body > p {
    font-size: 18px !important;
    line-height: 1.62 !important;
  }

  .news-article .news-sidebar {
    grid-template-columns: 1fr !important;
  }
}
/* ================================================= */
/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: .news-article */
/* ================================================= */

.news-article .news-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.86fr) minmax(520px, 1.14fr);
  gap: 42px;
  align-items: center;

  min-height: 560px;
  padding: 46px 56px 42px;
}

.news-article .news-hero-copy {
  position: relative;
  z-index: 3;
}

.news-article .news-hero .breadcrumb {
  margin-bottom: 28px;
}

.news-article .news-label {
  margin-bottom: 18px;
}

.news-article .news-hero h1 {
  max-width: 660px;
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(44px, 4vw, 76px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

.news-article .news-subtitle {
  max-width: 560px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 24px;
  line-height: 1.25;
  font-style: italic;
}

.news-article .news-byline {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(130px, 0.72fr) minmax(130px, 0.72fr) minmax(90px, 0.46fr);
  align-items: center;
  gap: 16px;

  max-width: 720px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.26);
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

.news-article .news-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

.news-article .news-author-mini img {
  width: 58px;
  height: 58px;

  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

.news-article .news-author-mini span,
.news-article .news-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.news-article .news-author-mini small,
.news-article .news-meta-item small {
  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.news-article .news-author-mini strong,
.news-article .news-meta-item time,
.news-article .news-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

.news-article .news-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 14px;

  margin-top: 20px;
}

.news-article .news-share-row strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 34px;
  height: 34px;

  display: grid;
  place-items: center;

  color: var(--ink);
  text-decoration: none;

  border-radius: 50%;
  background: rgba(255, 246, 222, 0.10);

  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: rgba(86, 32, 129, 0.12);
}

.news-article .news-share-row img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.news-article .news-hero-image {
  position: relative;

  margin: 0;
  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  box-shadow:
    0 18px 34px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-hero-image::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

.news-article .news-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.24);
}

/* Conteúdo + sidebar */

.news-article .news-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;

  margin: 0 56px 38px;
}

.news-article .news-article-body {
  position: relative;

  padding: 0;

  color: rgba(43, 26, 16, 0.92);
}

.news-article .news-article-body > p {
  max-width: 860px;
  margin: 0 0 20px;

  font-size: 20px;
  line-height: 1.66;
}

.news-article .news-article-body h2 {
  max-width: 860px;
  margin: 34px 0 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  float: left;

  margin: 7px 12px 0 0;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 78px;
  line-height: 0.78;
  font-weight: 900;
}

.news-article .news-quote {
  position: relative;

  max-width: 860px;
  margin: 34px 0;
  padding: 30px 92px 30px 60px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .news-quote::before {
  content: "“";

  position: absolute;
  left: 28px;
  top: 20px;

  color: var(--purple);
  font-size: 44px;
  line-height: 1;
  opacity: 0.72;
}

.news-article .news-quote::after {
  content: "";

  position: absolute;
  right: 30px;
  bottom: 24px;

  width: 64px;
  height: 64px;

  background-image: url("assets/icons/veredito-gema.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  opacity: 0.72;
}

.news-article .news-quote p {
  margin: 0 0 14px;

  color: var(--purple);
  font-size: 24px;
  line-height: 1.36;
  font-style: italic;
  font-weight: 700;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.72);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

/* Sidebar */

.news-article .news-sidebar {
  display: grid;
  gap: 22px;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  position: relative;

  padding: 26px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 0 18px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.news-article .news-summary-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 16px;

  margin: 0;
  padding: 0;

  list-style: none;
}

.news-article .news-summary-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
}

.news-article .news-summary-list img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  opacity: 0.84;
}

.news-article .news-summary-list span {
  color: rgba(43, 26, 16, 0.82);
  font-size: 15.5px;
  line-height: 1.38;
}

.news-article .news-tags {
  position: relative;
  z-index: 2;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.news-article .news-tags a {
  padding: 7px 10px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.36);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.news-article .news-tags a:hover {
  transform: translateY(-2px);
  background: var(--purple);
  color: var(--cream);
}

.news-article .news-discord-box {
  text-align: center;
}

.news-article .news-discord-art {
  position: relative;
  z-index: 2;

  margin: -8px auto 12px;
}

.news-article .news-discord-art img {
  max-width: 190px;
  max-height: 150px;

  margin: 0 auto;
  object-fit: contain;
}

.news-article .news-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

.news-article .news-discord-box .lg-btn {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Mais notícias */

.news-article .more-news-section {
  position: relative;

  margin: 0 56px 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .more-news-section::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

.news-article .more-news-section .section-title-row,
.news-article .more-news-grid {
  position: relative;
  z-index: 2;
}

.news-article .more-news-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.news-article .news-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 320px;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.13);
}

.news-article .news-card .post-category {
  top: 12px;
  left: 12px;
}

.news-article .news-card-image {
  min-height: 170px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.38), rgba(20, 10, 5, 0.04)),
    var(--news-bg);
  background-size: cover;
  background-position: center;
}

.news-article .news-card-copy {
  padding: 18px;

  display: flex;
  flex: 1;
  flex-direction: column;
}

.news-article .news-card-copy time {
  margin-bottom: 10px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-card-copy h3 {
  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.12;
  text-transform: uppercase;
}

.news-article .news-card-copy small {
  margin-top: auto;

  color: rgba(43, 26, 16, 0.62);
  font-size: 13px;
}

/* Newsletter */

.news-article .newsletter-panel {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.news-article .newsletter-art img {
  max-width: 190px;
  max-height: 150px;

  object-fit: contain;
}

.news-article .newsletter-copy h2 {
  margin: 0 0 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .newsletter-copy p {
  max-width: 520px;
  margin: 0;

  color: rgba(43, 26, 16, 0.80);
  font-size: 16px;
  line-height: 1.4;
}

.news-article .newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

.news-article .newsletter-form input {
  min-height: 52px;
  min-width: 0;

  padding: 0 16px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.20);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15px;
  outline: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  .news-article .news-hero {
    grid-template-columns: 1fr;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr;
  }

  .news-article .news-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .news-article .newsletter-form {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .news-article .news-byline {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding: 34px 24px 40px;
  }

  .news-article .news-hero h1 {
    font-size: 42px;
  }

  .news-article .news-content-layout,
  .news-article .more-news-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 48px;
  }

  .news-article .news-quote::after {
    display: none;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr;
  }

  .news-article .newsletter-panel {
    margin-left: 20px;
    margin-right: 20px;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr;
  }

  .news-article .news-byline {
    grid-template-columns: 1fr;
  }
}

/* ================================================= */
/* NEWS HERO - TAG + BREADCRUMB NA MESMA LINHA */
/* ================================================= */

.news-article .news-hero {
  padding-top: 92px !important;
  padding-bottom: 52px !important;
  align-items: start !important;
}

.news-article .news-label-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;

  margin: 0 0 20px !important;
}

.news-article .news-label-row .news-label {
  margin: 0 !important;
  flex: 0 0 auto !important;
}

.news-article .news-breadcrumb-inline {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;

  margin: 0 !important;
  transform: translateY(1px);

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none !important;
}

.news-article .news-hero h1 {
  margin-top: 0 !important;
}

/* ================================================= */
/* NEWS HERO - SHARE COM CÍRCULOS ROXOS */
/* ================================================= */

.news-article .news-share-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;

  margin-top: 20px !important;
}

.news-article .news-share-row strong {
  margin-right: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.news-article .news-share-row a {
  width: 36px !important;
  height: 36px !important;

  display: grid !important;
  place-items: center !important;

  color: var(--cream) !important;
  background: var(--purple) !important;
  border: 1px solid rgba(255, 243, 214, 0.18) !important;
  border-radius: 50% !important;

  text-decoration: none !important;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark) !important;

  box-shadow:
    0 12px 20px rgba(43, 26, 16, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.20);
}

.news-article .news-share-row img {
  width: 17px !important;
  height: 17px !important;

  object-fit: contain !important;
  display: block !important;

  filter: brightness(0) invert(1) !important;
}

.news-article .news-share-row a span {
  color: var(--cream) !important;
  font-size: 16px !important;
  line-height: 1 !important;
}

/* ================================================= */
/* NEWS ARTICLE - AJUSTE DE COLUNAS DO CONTEÚDO */
/* aumenta área de texto e aproxima sidebar */
/* ================================================= */

.news-article .news-content-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 980px) minmax(300px, 360px) !important;
  gap: 34px !important;
  align-items: start !important;
  justify-content: center !important;

  width: 100% !important;
  max-width: 1480px !important;

  margin: 0 auto 42px !important;
  padding: 0 32px !important;
}

.news-article .news-article-body {
  width: 100% !important;
  max-width: none !important;
}

.news-article .news-article-body > p,
.news-article .news-article-body h2,
.news-article .news-quote {
  max-width: none !important;
  width: 100% !important;
}

.news-article .news-article-body > p {
  font-size: 20px !important;
  line-height: 1.68 !important;
}

.news-article .news-quote {
  margin: 34px 0 !important;
}

.news-article .news-sidebar {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: stretch !important;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  width: 100% !important;
}

/* ================================================= */
/* NEWS ARTICLE - REFINO EDITORIAL FINAL */
/* acabamento prático da página-base de notícia */
/* ================================================= */

/* Hero mais editorial */
.news-article .news-hero-image {
  box-shadow:
    0 22px 36px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22) !important;
}

.news-article .news-hero-image img {
  min-height: 360px !important;
}

/* Texto: mais presença sem virar muralha */
.news-article .news-article-body {
  padding-top: 4px !important;
}

.news-article .news-article-body h2 {
  margin: 38px 0 16px !important;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 30px !important;
  line-height: 1.05 !important;
  text-transform: uppercase;
}

.news-article .news-article-body .lead-paragraph::first-letter {
  margin: 8px 14px 0 0 !important;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 70px !important;
  line-height: 0.78 !important;
  font-weight: 900;
}

/* Quote premium */
.news-article .news-quote {
  position: relative !important;

  min-height: 150px !important;
  padding: 34px 104px 32px 66px !important;

  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;

  border: 1px solid var(--line) !important;
  background:
    radial-gradient(circle at 92% 18%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.14) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.24),
    0 10px 22px rgba(43, 26, 16, 0.04) !important;
}

.news-article .news-quote::before {
  content: "“" !important;

  position: absolute !important;
  left: 28px !important;
  top: 28px !important;

  color: var(--purple) !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 48px !important;
  line-height: 1 !important;
  opacity: 0.72 !important;
}

.news-article .news-quote::after {
  content: "" !important;

  position: absolute !important;
  right: 30px !important;
  bottom: 24px !important;

  width: 70px !important;
  height: 70px !important;

  background-image: url("assets/icons/veredito-gema.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;

  opacity: 0.70 !important;
}

.news-article .news-quote p {
  margin: 0 0 16px !important;

  color: var(--purple) !important;
  font-size: 25px !important;
  line-height: 1.36 !important;
  font-style: italic !important;
  font-weight: 700 !important;
}

.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.76) !important;
  font-family: var(--font-title, Georgia, "Times New Roman", serif) !important;
  font-size: 12px !important;
  font-style: normal !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
}

/* Sidebar mais premium */
.news-article .news-sidebar {
  gap: 24px !important;
}

.news-article .news-summary-box,
.news-article .news-tags-box,
.news-article .news-discord-box {
  padding: 28px 26px !important;

  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.05), transparent 34%),
    rgba(255, 246, 222, 0.13) !important;
}

.news-article .news-summary-box::before,
.news-article .news-tags-box::before,
.news-article .news-discord-box::before {
  inset: 13px !important;
}

.news-article .sidebar-kicker {
  margin-bottom: 18px !important;
  padding: 8px 11px !important;

  color: var(--purple) !important;
  background: rgba(74, 35, 107, 0.10) !important;
  border: 1px solid rgba(74, 35, 107, 0.24) !important;

  font-size: 10.5px !important;
}

.news-article .news-summary-list {
  gap: 18px !important;
}

.news-article .news-summary-list li {
  grid-template-columns: 38px 1fr !important;
  gap: 13px !important;
  align-items: start !important;
}

.news-article .news-summary-list img {
  width: 28px !important;
  height: 28px !important;

  object-fit: contain !important;
  opacity: 0.92 !important;
}

.news-article .news-summary-list span {
  font-size: 16px !important;
  line-height: 1.38 !important;
}

/* Tópicos */
.news-article .news-tags {
  gap: 9px !important;
}

.news-article .news-tags a {
  padding: 8px 10px !important;

  font-size: 10px !important;
  background: rgba(255, 246, 222, 0.16) !important;
}

/* Discord */
.news-article .news-discord-art img {
  max-width: 210px !important;
  max-height: 165px !important;
}

.news-article .news-discord-box h2 {
  font-size: 24px !important;
  line-height: 1.02 !important;
}

.news-article .news-discord-box p {
  font-size: 16px !important;
  line-height: 1.44 !important;
}

.news-article .news-discord-box .lg-btn {
  min-height: 48px !important;
}

/* Mais notícias: vitrine mais forte */
.news-article .more-news-section {
  max-width: 1500px !important;
  margin: 0 auto 34px !important;
  padding: 34px 34px 38px !important;
}

.news-article .more-news-grid {
  gap: 22px !important;
}

.news-article .news-card {
  min-height: 345px !important;
}

.news-article .news-card-image {
  min-height: 190px !important;
}

.news-article .news-card-copy {
  padding: 18px 18px 20px !important;
}

.news-article .news-card-copy h3 {
  font-size: 18.5px !important;
  line-height: 1.10 !important;
}

.news-article .news-card-copy time {
  margin-bottom: 11px !important;
}

.news-article .news-card-copy small {
  font-size: 13px !important;
}

/* Newsletter: mais bloco especial, menos formulário solto */
.news-article .newsletter-panel {
  max-width: 1500px !important;
  margin: 0 auto 34px !important;

  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px) !important;
  padding: 30px 36px !important;

  background:
    radial-gradient(circle at 8% 50%, rgba(86, 32, 129, 0.06), transparent 30%),
    rgba(255, 246, 222, 0.14) !important;
}

.news-article .newsletter-art img {
  max-width: 200px !important;
  max-height: 160px !important;
}

.news-article .newsletter-copy h2 {
  font-size: 25px !important;
  line-height: 1.05 !important;
}

.news-article .newsletter-copy p {
  font-size: 16.5px !important;
}

.news-article .newsletter-form input {
  min-height: 52px !important;
}

.news-article .newsletter-form .lg-btn,
.news-article .newsletter-form button {
  min-height: 52px !important;
  white-space: nowrap !important;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  .news-article .news-hero {
    padding-top: 62px !important;
  }

  .news-article .news-content-layout {
    grid-template-columns: 1fr !important;
    max-width: 980px !important;
    gap: 28px !important;

    padding: 0 32px !important;
  }

  .news-article .news-sidebar {
    max-width: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }

  .news-article .newsletter-panel {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .news-article .newsletter-art img,
  .news-article .newsletter-copy p {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .news-article .newsletter-form {
    max-width: 640px !important;
    width: 100% !important;
    margin: 0 auto !important;
  }
}

@media (max-width: 1100px) {
  .news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .news-article .news-sidebar {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 900px) {
  .news-article .news-hero {
    padding-top: 34px !important;
  }

  .news-article .news-label-row {
    gap: 14px !important;
  }

  .news-article .news-content-layout {
    padding: 0 20px !important;
    margin-bottom: 34px !important;
  }

  .news-article .news-article-body > p {
    font-size: 18px !important;
    line-height: 1.62 !important;
  }

  .news-article .news-article-body .lead-paragraph::first-letter {
    font-size: 58px !important;
    margin-right: 10px !important;
  }

  .news-article .news-quote {
    padding: 28px 24px 28px 50px !important;
  }

  .news-article .news-quote::after {
    display: none !important;
  }

  .news-article .news-quote p {
    font-size: 21px !important;
  }

  .news-article .more-news-section,
  .news-article .newsletter-panel {
    margin-left: 20px !important;
    margin-right: 20px !important;
  }

  .news-article .more-news-grid {
    grid-template-columns: 1fr !important;
  }

  .news-article .newsletter-form {
    grid-template-columns: 1fr !important;
  }
}
/* ================================================= */
/* CATEGORIA - JOGOS */
/* Cole no final do style.css */
/* Escopo: 
/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: body.single-noticia.news-article */
/* ================================================= */

body.single-noticia.news-article .news-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.86fr) minmax(520px, 1.14fr);
  gap: 42px;
  align-items: center;

  min-height: 560px;
  padding: 46px 56px 42px;
}

body.single-noticia.news-article .news-hero-copy {
  position: relative;
  z-index: 3;
}

body.single-noticia.news-article .news-hero .breadcrumb {
  margin-bottom: 28px;
}

body.single-noticia.news-article .news-label {
  margin-bottom: 18px;
}

body.single-noticia.news-article .news-hero h1 {
  max-width: 660px;
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(44px, 4vw, 76px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-subtitle {
  max-width: 560px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 24px;
  line-height: 1.25;
  font-style: italic;
}

body.single-noticia.news-article .news-byline {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(130px, 0.72fr) minmax(130px, 0.72fr) minmax(90px, 0.46fr);
  align-items: center;
  gap: 16px;

  max-width: 720px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.26);
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

body.single-noticia.news-article .news-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

body.single-noticia.news-article .news-author-mini img {
  width: 58px;
  height: 58px;

  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

body.single-noticia.news-article .news-author-mini span,
body.single-noticia.news-article .news-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

body.single-noticia.news-article .news-author-mini small,
body.single-noticia.news-article .news-meta-item small {
  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

body.single-noticia.news-article .news-author-mini strong,
body.single-noticia.news-article .news-meta-item time,
body.single-noticia.news-article .news-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 14px;

  margin-top: 20px;
}

body.single-noticia.news-article .news-share-row strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-share-row a {
  width: 34px;
  height: 34px;

  display: grid;
  place-items: center;

  color: var(--ink);
  text-decoration: none;

  border-radius: 50%;
  background: rgba(255, 246, 222, 0.10);

  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

body.single-noticia.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: rgba(86, 32, 129, 0.12);
}

body.single-noticia.news-article .news-share-row img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

body.single-noticia.news-article .news-hero-image {
  position: relative;

  margin: 0;
  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  box-shadow:
    0 18px 34px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

body.single-noticia.news-article .news-hero-image::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

body.single-noticia.news-article .news-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.24);
}

/* Conteúdo + sidebar */

body.single-noticia.news-article .news-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;

  margin: 0 56px 38px;
}

body.single-noticia.news-article .news-article-body {
  position: relative;

  padding: 0;

  color: rgba(43, 26, 16, 0.92);
}

body.single-noticia.news-article .news-article-body > p {
  max-width: 860px;
  margin: 0 0 20px;

  font-size: 20px;
  line-height: 1.66;
}

body.single-noticia.news-article .news-article-body h2 {
  max-width: 860px;
  margin: 34px 0 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-article-body .lead-paragraph::first-letter {
  float: left;

  margin: 7px 12px 0 0;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 78px;
  line-height: 0.78;
  font-weight: 900;
}

body.single-noticia.news-article .news-quote {
  position: relative;

  max-width: 860px;
  margin: 34px 0;
  padding: 30px 92px 30px 60px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

body.single-noticia.news-article .news-quote::before {
  content: "“";

  position: absolute;
  left: 28px;
  top: 20px;

  color: var(--purple);
  font-size: 44px;
  line-height: 1;
  opacity: 0.72;
}

body.single-noticia.news-article .news-quote::after {
  content: "";

  position: absolute;
  right: 30px;
  bottom: 24px;

  width: 64px;
  height: 64px;

  background-image: url("assets/icons/veredito-gema.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  opacity: 0.72;
}

body.single-noticia.news-article .news-quote p {
  margin: 0 0 14px;

  color: var(--purple);
  font-size: 24px;
  line-height: 1.36;
  font-style: italic;
  font-weight: 700;
}

body.single-noticia.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.72);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

/* Sidebar */

body.single-noticia.news-article .news-sidebar {
  display: grid;
  gap: 22px;
}

body.single-noticia.news-article .news-summary-box,
body.single-noticia.news-article .news-tags-box,
body.single-noticia.news-article .news-discord-box {
  position: relative;

  padding: 26px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

body.single-noticia.news-article .news-summary-box::before,
body.single-noticia.news-article .news-tags-box::before,
body.single-noticia.news-article .news-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

body.single-noticia.news-article .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 0 18px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

body.single-noticia.news-article .news-summary-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 16px;

  margin: 0;
  padding: 0;

  list-style: none;
}

body.single-noticia.news-article .news-summary-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
}

body.single-noticia.news-article .news-summary-list img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  opacity: 0.84;
}

body.single-noticia.news-article .news-summary-list span {
  color: rgba(43, 26, 16, 0.82);
  font-size: 15.5px;
  line-height: 1.38;
}

body.single-noticia.news-article .news-tags {
  position: relative;
  z-index: 2;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

body.single-noticia.news-article .news-tags a {
  padding: 7px 10px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.36);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

body.single-noticia.news-article .news-tags a:hover {
  transform: translateY(-2px);
  background: var(--purple);
  color: var(--cream);
}

body.single-noticia.news-article .news-discord-box {
  text-align: center;
}

body.single-noticia.news-article .news-discord-art {
  position: relative;
  z-index: 2;

  margin: -8px auto 12px;
}

body.single-noticia.news-article .news-discord-art img {
  max-width: 190px;
  max-height: 150px;

  margin: 0 auto;
  object-fit: contain;
}

body.single-noticia.news-article .news-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

body.single-noticia.news-article .news-discord-box .lg-btn {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Mais notícias */

body.single-noticia.news-article .more-news-section {
  position: relative;

  margin: 0 56px 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

body.single-noticia.news-article .more-news-section::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

body.single-noticia.news-article .more-news-section .section-title-row,
body.single-noticia.news-article .more-news-grid {
  position: relative;
  z-index: 2;
}

body.single-noticia.news-article .more-news-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

body.single-noticia.news-article .news-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 320px;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

body.single-noticia.news-article .news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.13);
}

body.single-noticia.news-article .news-card .post-category {
  top: 12px;
  left: 12px;
}

body.single-noticia.news-article .news-card-image {
  min-height: 170px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.38), rgba(20, 10, 5, 0.04)),
    var(--news-bg);
  background-size: cover;
  background-position: center;
}

body.single-noticia.news-article .news-card-copy {
  padding: 18px;

  display: flex;
  flex: 1;
  flex-direction: column;
}

body.single-noticia.news-article .news-card-copy time {
  margin-bottom: 10px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-card-copy h3 {
  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.12;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-card-copy small {
  margin-top: auto;

  color: rgba(43, 26, 16, 0.62);
  font-size: 13px;
}

/* Newsletter */

body.single-noticia.news-article .newsletter-panel {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

body.single-noticia.news-article .newsletter-art img {
  max-width: 190px;
  max-height: 150px;

  object-fit: contain;
}

body.single-noticia.news-article .newsletter-copy h2 {
  margin: 0 0 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .newsletter-copy p {
  max-width: 520px;
  margin: 0;

  color: rgba(43, 26, 16, 0.80);
  font-size: 16px;
  line-height: 1.4;
}

body.single-noticia.news-article .newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

body.single-noticia.news-article .newsletter-form input {
  min-height: 52px;
  min-width: 0;

  padding: 0 16px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.20);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15px;
  outline: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  body.single-noticia.news-article .news-hero {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .news-content-layout {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .news-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.single-noticia.news-article .newsletter-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  body.single-noticia.news-article .newsletter-art img,
  body.single-noticia.news-article .newsletter-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  body.single-noticia.news-article .newsletter-form {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
  }
}

@media (max-width: 1100px) {
  body.single-noticia.news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.single-noticia.news-article .news-sidebar {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .news-byline {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  body.single-noticia.news-article .news-hero {
    padding: 34px 24px 40px;
  }

  body.single-noticia.news-article .news-hero h1 {
    font-size: 42px;
  }

  body.single-noticia.news-article .news-content-layout,
  body.single-noticia.news-article .more-news-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  body.single-noticia.news-article .news-quote {
    padding: 28px 24px 28px 48px;
  }

  body.single-noticia.news-article .news-quote::after {
    display: none;
  }

  body.single-noticia.news-article .more-news-grid {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .newsletter-panel {
    margin-left: 20px;
    margin-right: 20px;
  }

  body.single-noticia.news-article .newsletter-form {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .news-byline {
    grid-template-columns: 1fr;
  }
}
/* ================================================= */
/* NEWS HERO - TAG + BREADCRUMB NA MESMA LINHA */
/* ================================================= */

body.single-noticia.news-article .news-label-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;

  margin: 0 0 18px;
}

body.single-noticia.news-article .news-label-row .news-label {
  margin: 0;
  flex: 0 0 auto;
}

body.single-noticia.news-article .news-breadcrumb-inline {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;

  margin: 0;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

body.single-noticia.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

body.single-noticia.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

/* Esconde o breadcrumb antigo caso ainda tenha ficado duplicado */
body.single-noticia.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none;
}
/* ================================================= */
/* NEWS HERO - SHARE COM CÍRCULOS ROXOS */
/* ================================================= */

body.single-noticia.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;

  margin-top: 20px;
}

body.single-noticia.news-article .news-share-row strong {
  margin-right: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-share-row a {
  width: 36px;
  height: 36px;

  display: grid;
  place-items: center;

  color: var(--cream);
  background: var(--purple);
  border: 1px solid rgba(255, 243, 214, 0.18);
  border-radius: 50%;

  text-decoration: none;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

body.single-noticia.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark);

  box-shadow:
    0 12px 20px rgba(43, 26, 16, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.20);
}

body.single-noticia.news-article .news-share-row img {
  width: 17px;
  height: 17px;

  object-fit: contain;
  display: block;

  filter: brightness(0) invert(1);
}

body.single-noticia.news-article .news-share-row a span {
  color: var(--cream);
  font-size: 16px;
  line-height: 1;
}
/* ================================================= */
/* NEWS HERO - AJUSTE FINO DE POSIÇÃO */
/* desce o hero e afasta breadcrumb da logo */
/* ================================================= */

body.single-noticia.news-article .news-hero {
  padding-top: 92px !important;
  padding-bottom: 46px !important;
  align-items: start !important;
}

/* Linha com tag NOTÍCIA + breadcrumb */

body.single-noticia.news-article .news-label-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;

  margin: 0 0 20px !important;
}

/* Tag notícia */

body.single-noticia.news-article .news-label-row .news-label {
  margin: 0 !important;
  flex: 0 0 auto !important;
}

/* Breadcrumb ao lado da tag, mais à direita e alinhado */

body.single-noticia.news-article .news-breadcrumb-inline {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;

  margin: 0 !important;
  transform: translateY(1px);

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

body.single-noticia.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

body.single-noticia.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

/* Evita que qualquer breadcrumb antigo apareça duplicado */

body.single-noticia.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none !important;
}

/* Ajuste do título depois que o hero desce */

body.single-noticia.news-article .news-hero h1 {
  margin-top: 0 !important;
}

/* Compartilhamento continua onde está, só com ícones visíveis */

body.single-noticia.news-article .news-share-row a {
  width: 36px !important;
  height: 36px !important;

  display: grid !important;
  place-items: center !important;

  color: var(--cream) !important;
  background: var(--purple) !important;
  border: 1px solid rgba(255, 243, 214, 0.18) !important;
  border-radius: 50% !important;

  text-decoration: none !important;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);
}

body.single-noticia.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark) !important;
}

body.single-noticia.news-article .news-share-row img {
  width: 17px !important;
  height: 17px !important;
  object-fit: contain !important;
  display: block !important;
  filter: brightness(0) invert(1) !important;
}

body.single-noticia.news-article .news-share-row a span {
  color: var(--cream) !important;
  font-size: 16px !important;
  line-height: 1 !important;
}

/* Responsivo */

@media (max-width: 1300px) {
  body.single-noticia.news-article .news-hero {
    padding-top: 62px !important;
  }
}

@media (max-width: 900px) {
  body.single-noticia.news-article .news-hero {
    padding-top: 34px !important;
  }

  body.single-noticia.news-article .news-label-row {
    gap: 14px !important;
  }
}
/* ================================================= */
/* NEWS ARTICLE - AJUSTE DE COLUNAS DO CONTEÚDO */
/* aumenta área de texto e aproxima sidebar */
/* ================================================= */

body.single-noticia.news-article .news-content-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 980px) minmax(300px, 360px) !important;
  gap: 34px !important;
  align-items: start !important;
  justify-content: center !important;

  width: 100% !important;
  max-width: 1480px !important;

  margin: 0 auto 42px !important;
  padding: 0 32px !important;
}

/* Coluna principal da matéria */

body.single-noticia.news-article .news-article-body {
  width: 100% !important;
  max-width: none !important;
}

/* Faz texto, títulos e quote ocuparem melhor a coluna */

body.single-noticia.news-article .news-article-body > p,
body.single-noticia.news-article .news-article-body h2,
body.single-noticia.news-article .news-quote {
  max-width: none !important;
  width: 100% !important;
}

/* Texto um pouco mais confortável na largura nova */

body.single-noticia.news-article .news-article-body > p {
  font-size: 20px !important;
  line-height: 1.68 !important;
}

/* Quote acompanha a largura da coluna */

body.single-noticia.news-article .news-quote {
  margin: 34px 0 !important;
}

/* Sidebar fica firme, sem fugir demais para a direita */

body.single-noticia.news-article .news-sidebar {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: stretch !important;
}

/* Cards da sidebar mais estáveis */

body.single-noticia.news-article .news-summary-box,
body.single-noticia.news-article .news-tags-box,
body.single-noticia.news-article .news-discord-box {
  width: 100% !important;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  body.single-noticia.news-article .news-content-layout {
    grid-template-columns: 1fr !important;
    max-width: 980px !important;
    gap: 28px !important;

    padding: 0 32px !important;
  }

  body.single-noticia.news-article .news-sidebar {
    max-width: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }
}

@media (max-width: 900px) {
  body.single-noticia.news-article .news-content-layout {
    padding: 0 20px !important;
    margin-bottom: 34px !important;
  }

  body.single-noticia.news-article .news-article-body > p {
    font-size: 18px !important;
    line-height: 1.62 !important;
  }

  body.single-noticia.news-article .news-sidebar {
    grid-template-columns: 1fr !important;
  }
}
/* ================================================= */
/* NEWS ARTICLE TEMPLATE - LEGOLAS GEEK */
/* Cole no final do style.css */
/* Escopo: body.single-noticia.news-article */
/* ================================================= */

body.single-noticia.news-article .news-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.86fr) minmax(520px, 1.14fr);
  gap: 42px;
  align-items: center;

  min-height: 560px;
  padding: 46px 56px 42px;
}

body.single-noticia.news-article .news-hero-copy {
  position: relative;
  z-index: 3;
}

body.single-noticia.news-article .news-hero .breadcrumb {
  margin-bottom: 28px;
}

body.single-noticia.news-article .news-label {
  margin-bottom: 18px;
}

body.single-noticia.news-article .news-hero h1 {
  max-width: 660px;
  margin: 0 0 18px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: clamp(44px, 4vw, 76px);
  line-height: 0.96;
  font-weight: 900;
  letter-spacing: -0.045em;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-subtitle {
  max-width: 560px;
  margin: 0 0 24px;

  color: rgba(43, 26, 16, 0.78);
  font-size: 24px;
  line-height: 1.25;
  font-style: italic;
}

body.single-noticia.news-article .news-byline {
  display: grid;
  grid-template-columns: minmax(190px, 1fr) minmax(130px, 0.72fr) minmax(130px, 0.72fr) minmax(90px, 0.46fr);
  align-items: center;
  gap: 16px;

  max-width: 720px;
  padding: 16px 0;

  border-top: 1px solid rgba(164, 112, 52, 0.26);
  border-bottom: 1px solid rgba(164, 112, 52, 0.26);
}

body.single-noticia.news-article .news-author-mini {
  display: flex;
  align-items: center;
  gap: 12px;
}

body.single-noticia.news-article .news-author-mini img {
  width: 58px;
  height: 58px;

  object-fit: cover;
  border-radius: 50%;
  border: 1px solid rgba(164, 112, 52, 0.52);
  background: rgba(255, 246, 222, 0.18);
}

body.single-noticia.news-article .news-author-mini span,
body.single-noticia.news-article .news-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

body.single-noticia.news-article .news-author-mini small,
body.single-noticia.news-article .news-meta-item small {
  margin-bottom: 5px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

body.single-noticia.news-article .news-author-mini strong,
body.single-noticia.news-article .news-meta-item time,
body.single-noticia.news-article .news-meta-item span {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.25;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-author-mini em {
  width: fit-content;
  margin-top: 6px;
  padding: 5px 8px;

  color: var(--cream);
  background: var(--purple);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 9px;
  font-style: normal;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-share-row {
  display: flex;
  align-items: center;
  gap: 14px;

  margin-top: 20px;
}

body.single-noticia.news-article .news-share-row strong {
  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-share-row a {
  width: 34px;
  height: 34px;

  display: grid;
  place-items: center;

  color: var(--ink);
  text-decoration: none;

  border-radius: 50%;
  background: rgba(255, 246, 222, 0.10);

  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

body.single-noticia.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: rgba(86, 32, 129, 0.12);
}

body.single-noticia.news-article .news-share-row img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

body.single-noticia.news-article .news-hero-image {
  position: relative;

  margin: 0;
  padding: 8px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  box-shadow:
    0 18px 34px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

body.single-noticia.news-article .news-hero-image::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid rgba(255, 243, 214, 0.22);
  pointer-events: none;
}

body.single-noticia.news-article .news-hero-image img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;

  border: 1px solid rgba(43, 26, 16, 0.24);
}

/* Conteúdo + sidebar */

body.single-noticia.news-article .news-content-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 34px;
  align-items: start;

  margin: 0 56px 38px;
}

body.single-noticia.news-article .news-article-body {
  position: relative;

  padding: 0;

  color: rgba(43, 26, 16, 0.92);
}

body.single-noticia.news-article .news-article-body > p {
  max-width: 860px;
  margin: 0 0 20px;

  font-size: 20px;
  line-height: 1.66;
}

body.single-noticia.news-article .news-article-body h2 {
  max-width: 860px;
  margin: 34px 0 14px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 26px;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-article-body .lead-paragraph::first-letter {
  float: left;

  margin: 7px 12px 0 0;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 78px;
  line-height: 0.78;
  font-weight: 900;
}

body.single-noticia.news-article .news-quote {
  position: relative;

  max-width: 860px;
  margin: 34px 0;
  padding: 30px 92px 30px 60px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

body.single-noticia.news-article .news-quote::before {
  content: "“";

  position: absolute;
  left: 28px;
  top: 20px;

  color: var(--purple);
  font-size: 44px;
  line-height: 1;
  opacity: 0.72;
}

body.single-noticia.news-article .news-quote::after {
  content: "";

  position: absolute;
  right: 30px;
  bottom: 24px;

  width: 64px;
  height: 64px;

  background-image: url("assets/icons/veredito-gema.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;

  opacity: 0.72;
}

body.single-noticia.news-article .news-quote p {
  margin: 0 0 14px;

  color: var(--purple);
  font-size: 24px;
  line-height: 1.36;
  font-style: italic;
  font-weight: 700;
}

body.single-noticia.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.72);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  text-transform: uppercase;
}

/* Sidebar */

body.single-noticia.news-article .news-sidebar {
  display: grid;
  gap: 22px;
}

body.single-noticia.news-article .news-summary-box,
body.single-noticia.news-article .news-tags-box,
body.single-noticia.news-article .news-discord-box {
  position: relative;

  padding: 26px 24px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
  overflow: hidden;
}

body.single-noticia.news-article .news-summary-box::before,
body.single-noticia.news-article .news-tags-box::before,
body.single-noticia.news-article .news-discord-box::before {
  content: "";
  position: absolute;
  inset: 12px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

body.single-noticia.news-article .sidebar-kicker {
  position: relative;
  z-index: 2;

  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;

  margin: 0 0 18px;
  padding: 7px 10px;

  color: var(--purple);
  background: rgba(74, 35, 107, 0.10);
  border: 1px solid rgba(74, 35, 107, 0.22);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

body.single-noticia.news-article .news-summary-list {
  position: relative;
  z-index: 2;

  display: grid;
  gap: 16px;

  margin: 0;
  padding: 0;

  list-style: none;
}

body.single-noticia.news-article .news-summary-list li {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: start;
}

body.single-noticia.news-article .news-summary-list img {
  width: 24px;
  height: 24px;

  object-fit: contain;
  opacity: 0.84;
}

body.single-noticia.news-article .news-summary-list span {
  color: rgba(43, 26, 16, 0.82);
  font-size: 15.5px;
  line-height: 1.38;
}

body.single-noticia.news-article .news-tags {
  position: relative;
  z-index: 2;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

body.single-noticia.news-article .news-tags a {
  padding: 7px 10px;

  color: var(--ink);
  border: 1px solid rgba(164, 112, 52, 0.36);
  background: rgba(255, 246, 222, 0.12);

  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;

  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

body.single-noticia.news-article .news-tags a:hover {
  transform: translateY(-2px);
  background: var(--purple);
  color: var(--cream);
}

body.single-noticia.news-article .news-discord-box {
  text-align: center;
}

body.single-noticia.news-article .news-discord-art {
  position: relative;
  z-index: 2;

  margin: -8px auto 12px;
}

body.single-noticia.news-article .news-discord-art img {
  max-width: 190px;
  max-height: 150px;

  margin: 0 auto;
  object-fit: contain;
}

body.single-noticia.news-article .news-discord-box h2 {
  position: relative;
  z-index: 2;

  margin: 0 0 12px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 22px;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-discord-box p {
  position: relative;
  z-index: 2;

  margin: 0 0 16px;

  color: rgba(43, 26, 16, 0.80);
  font-size: 15.5px;
  line-height: 1.42;
}

body.single-noticia.news-article .news-discord-box .lg-btn {
  position: relative;
  z-index: 2;

  width: 100%;
}

/* Mais notícias */

body.single-noticia.news-article .more-news-section {
  position: relative;

  margin: 0 56px 34px;
  padding: 30px 30px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

body.single-noticia.news-article .more-news-section::before {
  content: "";
  position: absolute;
  inset: 14px;

  border: 1px solid var(--line-soft);
  pointer-events: none;
}

body.single-noticia.news-article .more-news-section .section-title-row,
body.single-noticia.news-article .more-news-grid {
  position: relative;
  z-index: 2;
}

body.single-noticia.news-article .more-news-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

body.single-noticia.news-article .news-card {
  position: relative;

  display: flex;
  flex-direction: column;

  min-height: 320px;

  color: var(--ink);
  text-decoration: none;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.14);
  overflow: hidden;

  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

body.single-noticia.news-article .news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 24px rgba(43, 26, 16, 0.13);
}

body.single-noticia.news-article .news-card .post-category {
  top: 12px;
  left: 12px;
}

body.single-noticia.news-article .news-card-image {
  min-height: 170px;

  background-image:
    linear-gradient(to top, rgba(20, 10, 5, 0.38), rgba(20, 10, 5, 0.04)),
    var(--news-bg);
  background-size: cover;
  background-position: center;
}

body.single-noticia.news-article .news-card-copy {
  padding: 18px;

  display: flex;
  flex: 1;
  flex-direction: column;
}

body.single-noticia.news-article .news-card-copy time {
  margin-bottom: 10px;

  color: rgba(43, 26, 16, 0.58);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-card-copy h3 {
  margin: 0 0 16px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 18px;
  line-height: 1.12;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-card-copy small {
  margin-top: auto;

  color: rgba(43, 26, 16, 0.62);
  font-size: 13px;
}

/* Newsletter */

body.single-noticia.news-article .newsletter-panel {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px);
  gap: 28px;
  align-items: center;

  margin: 0 32px 34px;
  padding: 28px 34px;

  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

body.single-noticia.news-article .newsletter-art img {
  max-width: 190px;
  max-height: 150px;

  object-fit: contain;
}

body.single-noticia.news-article .newsletter-copy h2 {
  margin: 0 0 10px;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 24px;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .newsletter-copy p {
  max-width: 520px;
  margin: 0;

  color: rgba(43, 26, 16, 0.80);
  font-size: 16px;
  line-height: 1.4;
}

body.single-noticia.news-article .newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}

body.single-noticia.news-article .newsletter-form input {
  min-height: 52px;
  min-width: 0;

  padding: 0 16px;

  color: var(--ink);
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, 0.20);

  font-family: var(--font-body, Georgia, "Times New Roman", serif);
  font-size: 15px;
  outline: 0;
}

/* Responsivo */

@media (max-width: 1300px) {
  body.single-noticia.news-article .news-hero {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .news-content-layout {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .news-sidebar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.single-noticia.news-article .newsletter-panel {
    grid-template-columns: 1fr;
    text-align: center;
  }

  body.single-noticia.news-article .newsletter-art img,
  body.single-noticia.news-article .newsletter-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  body.single-noticia.news-article .newsletter-form {
    max-width: 640px;
    width: 100%;
    margin: 0 auto;
  }
}

@media (max-width: 1100px) {
  body.single-noticia.news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.single-noticia.news-article .news-sidebar {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .news-byline {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  body.single-noticia.news-article .news-hero {
    padding: 34px 24px 40px;
  }

  body.single-noticia.news-article .news-hero h1 {
    font-size: 42px;
  }

  body.single-noticia.news-article .news-content-layout,
  body.single-noticia.news-article .more-news-section {
    margin-left: 20px;
    margin-right: 20px;
  }

  body.single-noticia.news-article .news-quote {
    padding: 28px 24px 28px 48px;
  }

  body.single-noticia.news-article .news-quote::after {
    display: none;
  }

  body.single-noticia.news-article .more-news-grid {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .newsletter-panel {
    margin-left: 20px;
    margin-right: 20px;
  }

  body.single-noticia.news-article .newsletter-form {
    grid-template-columns: 1fr;
  }

  body.single-noticia.news-article .news-byline {
    grid-template-columns: 1fr;
  }
}

/* ================================================= */
/* NEWS HERO - TAG + BREADCRUMB NA MESMA LINHA */
/* ================================================= */

body.single-noticia.news-article .news-hero {
  padding-top: 92px !important;
  padding-bottom: 52px !important;
  align-items: start !important;
}

body.single-noticia.news-article .news-label-row {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;

  margin: 0 0 20px !important;
}

body.single-noticia.news-article .news-label-row .news-label {
  margin: 0 !important;
  flex: 0 0 auto !important;
}

body.single-noticia.news-article .news-breadcrumb-inline {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;

  margin: 0 !important;
  transform: translateY(1px);

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-breadcrumb-inline a {
  color: var(--ink);
  text-decoration: none;
}

body.single-noticia.news-article .news-breadcrumb-inline a:hover {
  color: var(--purple);
}

body.single-noticia.news-article .news-breadcrumb-inline span {
  color: rgba(43, 26, 16, 0.68);
}

body.single-noticia.news-article .news-hero-copy > .breadcrumb:not(.news-breadcrumb-inline) {
  display: none !important;
}

body.single-noticia.news-article .news-hero h1 {
  margin-top: 0 !important;
}

/* ================================================= */
/* NEWS HERO - SHARE COM CÍRCULOS ROXOS */
/* ================================================= */

body.single-noticia.news-article .news-share-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;

  margin-top: 20px !important;
}

body.single-noticia.news-article .news-share-row strong {
  margin-right: 4px;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-share-row a {
  width: 36px !important;
  height: 36px !important;

  display: grid !important;
  place-items: center !important;

  color: var(--cream) !important;
  background: var(--purple) !important;
  border: 1px solid rgba(255, 243, 214, 0.18) !important;
  border-radius: 50% !important;

  text-decoration: none !important;

  box-shadow:
    0 8px 14px rgba(43, 26, 16, 0.13),
    inset 0 0 0 1px rgba(255, 243, 214, 0.12);

  transition:
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

body.single-noticia.news-article .news-share-row a:hover {
  transform: translateY(-2px);
  background: var(--purple-dark) !important;

  box-shadow:
    0 12px 20px rgba(43, 26, 16, 0.18),
    inset 0 0 0 1px rgba(255, 243, 214, 0.20);
}

body.single-noticia.news-article .news-share-row img {
  width: 17px !important;
  height: 17px !important;

  object-fit: contain !important;
  display: block !important;

  filter: brightness(0) invert(1) !important;
}

body.single-noticia.news-article .news-share-row a span {
  color: var(--cream) !important;
  font-size: 16px !important;
  line-height: 1 !important;
}

/* ================================================= */
/* NEWS ARTICLE - AJUSTE DE COLUNAS DO CONTEÚDO */
/* aumenta área de texto e aproxima sidebar */
/* ================================================= */

body.single-noticia.news-article .news-content-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 980px) minmax(300px, 360px) !important;
  gap: 34px !important;
  align-items: start !important;
  justify-content: center !important;

  width: 100% !important;
  max-width: 1480px !important;

  margin: 0 auto 42px !important;
  padding: 0 32px !important;
}

body.single-noticia.news-article .news-article-body {
  width: 100% !important;
  max-width: none !important;
}

body.single-noticia.news-article .news-article-body > p,
body.single-noticia.news-article .news-article-body h2,
body.single-noticia.news-article .news-quote {
  max-width: none !important;
  width: 100% !important;
}

body.single-noticia.news-article .news-article-body > p {
  font-size: 20px !important;
  line-height: 1.68 !important;
}

body.single-noticia.news-article .news-quote {
  margin: 34px 0 !important;
}

body.single-noticia.news-article .news-sidebar {
  width: 100% !important;
  max-width: 360px !important;
  justify-self: stretch !important;
}

body.single-noticia.news-article .news-summary-box,
body.single-noticia.news-article .news-tags-box,
body.single-noticia.news-article .news-discord-box {
  width: 100% !important;
}

/* ================================================= */
/* NEWS ARTICLE - REFINO EDITORIAL FINAL */
/* acabamento prático da página-base de notícia */
/* ================================================= */

/* Hero mais editorial */
body.single-noticia.news-article .news-hero-image {
  box-shadow:
    0 22px 36px rgba(43, 26, 16, 0.10),
    inset 0 0 0 1px rgba(255, 255, 255, 0.22) !important;
}

body.single-noticia.news-article .news-hero-image img {
  min-height: 360px !important;
}

/* Texto: mais presença sem virar muralha */
body.single-noticia.news-article .news-article-body {
  padding-top: 4px !important;
}

body.single-noticia.news-article .news-article-body h2 {
  margin: 38px 0 16px !important;

  color: var(--ink);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 30px !important;
  line-height: 1.05 !important;
  text-transform: uppercase;
}

body.single-noticia.news-article .news-article-body .lead-paragraph::first-letter {
  margin: 8px 14px 0 0 !important;

  color: var(--purple);
  font-family: var(--font-title, Georgia, "Times New Roman", serif);
  font-size: 70px !important;
  line-height: 0.78 !important;
  font-weight: 900;
}

/* Quote premium */
body.single-noticia.news-article .news-quote {
  position: relative !important;

  min-height: 150px !important;
  padding: 34px 104px 32px 66px !important;

  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;

  border: 1px solid var(--line) !important;
  background:
    radial-gradient(circle at 92% 18%, rgba(86, 32, 129, 0.07), transparent 34%),
    rgba(255, 246, 222, 0.14) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.24),
    0 10px 22px rgba(43, 26, 16, 0.04) !important;
}

body.single-noticia.news-article .news-quote::before {
  content: "“" !important;

  position: absolute !important;
  left: 28px !important;
  top: 28px !important;

  color: var(--purple) !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 48px !important;
  line-height: 1 !important;
  opacity: 0.72 !important;
}

body.single-noticia.news-article .news-quote::after {
  content: "" !important;

  position: absolute !important;
  right: 30px !important;
  bottom: 24px !important;

  width: 70px !important;
  height: 70px !important;

  background-image: url("assets/icons/veredito-gema.png") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;

  opacity: 0.70 !important;
}

body.single-noticia.news-article .news-quote p {
  margin: 0 0 16px !important;

  color: var(--purple) !important;
  font-size: 25px !important;
  line-height: 1.36 !important;
  font-style: italic !important;
  font-weight: 700 !important;
}

body.single-noticia.news-article .news-quote cite {
  color: rgba(43, 26, 16, 0.76) !important;
  font-family: var(--font-title, Georgia, "Times New Roman", serif) !important;
  font-size: 12px !important;
  font-style: normal !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
}

/* Sidebar mais premium */
body.single-noticia.news-article .news-sidebar {
  gap: 24px !important;
}

body.single-noticia.news-article .news-summary-box,
body.single-noticia.news-article .news-tags-box,
body.single-noticia.news-article .news-discord-box {
  padding: 28px 26px !important;

  background:
    radial-gradient(circle at 92% 12%, rgba(86, 32, 129, 0.05), transparent 34%),
    rgba(255, 246, 222, 0.13) !important;
}

body.single-noticia.news-article .news-summary-box::before,
body.single-noticia.news-article .news-tags-box::before,
body.single-noticia.news-article .news-discord-box::before {
  inset: 13px !important;
}

body.single-noticia.news-article .sidebar-kicker {
  margin-bottom: 18px !important;
  padding: 8px 11px !important;

  color: var(--purple) !important;
  background: rgba(74, 35, 107, 0.10) !important;
  border: 1px solid rgba(74, 35, 107, 0.24) !important;

  font-size: 10.5px !important;
}

body.single-noticia.news-article .news-summary-list {
  gap: 18px !important;
}

body.single-noticia.news-article .news-summary-list li {
  grid-template-columns: 38px 1fr !important;
  gap: 13px !important;
  align-items: start !important;
}

body.single-noticia.news-article .news-summary-list img {
  width: 28px !important;
  height: 28px !important;

  object-fit: contain !important;
  opacity: 0.92 !important;
}

body.single-noticia.news-article .news-summary-list span {
  font-size: 16px !important;
  line-height: 1.38 !important;
}

/* Tópicos */
body.single-noticia.news-article .news-tags {
  gap: 9px !important;
}

body.single-noticia.news-article .news-tags a {
  padding: 8px 10px !important;

  font-size: 10px !important;
  background: rgba(255, 246, 222, 0.16) !important;
}

/* Discord */
body.single-noticia.news-article .news-discord-art img {
  max-width: 210px !important;
  max-height: 165px !important;
}

body.single-noticia.news-article .news-discord-box h2 {
  font-size: 24px !important;
  line-height: 1.02 !important;
}

body.single-noticia.news-article .news-discord-box p {
  font-size: 16px !important;
  line-height: 1.44 !important;
}

body.single-noticia.news-article .news-discord-box .lg-btn {
  min-height: 48px !important;
}

/* Mais notícias: vitrine mais forte */
body.single-noticia.news-article .more-news-section {
  max-width: 1500px !important;
  margin: 0 auto 34px !important;
  padding: 34px 34px 38px !important;
}

body.single-noticia.news-article .more-news-grid {
  gap: 22px !important;
}

body.single-noticia.news-article .news-card {
  min-height: 345px !important;
}

body.single-noticia.news-article .news-card-image {
  min-height: 190px !important;
}

body.single-noticia.news-article .news-card-copy {
  padding: 18px 18px 20px !important;
}

body.single-noticia.news-article .news-card-copy h3 {
  font-size: 18.5px !important;
  line-height: 1.10 !important;
}

body.single-noticia.news-article .news-card-copy time {
  margin-bottom: 11px !important;
}

body.single-noticia.news-article .news-card-copy small {
  font-size: 13px !important;
}

/* Newsletter: mais bloco especial, menos formulário solto */
body.single-noticia.news-article .newsletter-panel {
  max-width: 1500px !important;
  margin: 0 auto 34px !important;

  grid-template-columns: 220px minmax(0, 1fr) minmax(340px, 520px) !important;
  padding: 30px 36px !important;

  background:
    radial-gradient(circle at 8% 50%, rgba(86, 32, 129, 0.06), transparent 30%),
    rgba(255, 246, 222, 0.14) !important;
}

body.single-noticia.news-article .newsletter-art img {
  max-width: 200px !important;
  max-height: 160px !important;
}

body.single-noticia.news-article .newsletter-copy h2 {
  font-size: 25px !important;
  line-height: 1.05 !important;
}

body.single-noticia.news-article .newsletter-copy p {
  font-size: 16.5px !important;
}

body.single-noticia.news-article .newsletter-form input {
  min-height: 52px !important;
}

body.single-noticia.news-article .newsletter-form .lg-btn,
body.single-noticia.news-article .newsletter-form button {
  min-height: 52px !important;
  white-space: nowrap !important;
}

/* ================================================= */
/* RESPONSIVO */
/* ================================================= */

@media (max-width: 1300px) {
  body.single-noticia.news-article .news-hero {
    padding-top: 62px !important;
  }

  body.single-noticia.news-article .news-content-layout {
    grid-template-columns: 1fr !important;
    max-width: 980px !important;
    gap: 28px !important;

    padding: 0 32px !important;
  }

  body.single-noticia.news-article .news-sidebar {
    max-width: none !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 22px !important;
  }

  body.single-noticia.news-article .newsletter-panel {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  body.single-noticia.news-article .newsletter-art img,
  body.single-noticia.news-article .newsletter-copy p {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  body.single-noticia.news-article .newsletter-form {
    max-width: 640px !important;
    width: 100% !important;
    margin: 0 auto !important;
  }
}

@media (max-width: 1100px) {
  body.single-noticia.news-article .more-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body.single-noticia.news-article .news-sidebar {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 900px) {
  body.single-noticia.news-article .news-hero {
    padding-top: 34px !important;
  }

  body.single-noticia.news-article .news-label-row {
    gap: 14px !important;
  }

  body.single-noticia.news-article .news-content-layout {
    padding: 0 20px !important;
    margin-bottom: 34px !important;
  }

  body.single-noticia.news-article .news-article-body > p {
    font-size: 18px !important;
    line-height: 1.62 !important;
  }

  body.single-noticia.news-article .news-article-body .lead-paragraph::first-letter {
    font-size: 58px !important;
    margin-right: 10px !important;
  }

  body.single-noticia.news-article .news-quote {
    padding: 28px 24px 28px 50px !important;
  }

  body.single-noticia.news-article .news-quote::after {
    display: none !important;
  }

  body.single-noticia.news-article .news-quote p {
    font-size: 21px !important;
  }

  body.single-noticia.news-article .more-news-section,
  body.single-noticia.news-article .newsletter-panel {
    margin-left: 20px !important;
    margin-right: 20px !important;
  }

  body.single-noticia.news-article .more-news-grid {
    grid-template-columns: 1fr !important;
  }

  body.single-noticia.news-article .newsletter-form {
    grid-template-columns: 1fr !important;
  }
}
/* ================================================= */
/* CATEGORIA - JOGOS */
/* Cole no final do style.css */
/* Escopo: 


/* ============================================================
   v0.4.8 - correção resumo rápido + categorias de notícia estritas
   ============================================================ */

/* Resumo rápido do single de notícia: sem ícones quebrados e sem texto espremido */
body.single-noticia.news-article .news-summary-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 14px 0 0 !important;
  display: grid !important;
  gap: 13px !important;
}

body.single-noticia.news-article .news-summary-list li {
  display: grid !important;
  grid-template-columns: 18px minmax(0, 1fr) !important;
  gap: 10px !important;
  align-items: start !important;
  width: 100% !important;
  max-width: none !important;
}

body.single-noticia.news-article .news-summary-list li::before {
  content: "✦" !important;
  color: var(--purple) !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
}

body.single-noticia.news-article .news-summary-list li img {
  display: none !important;
}

body.single-noticia.news-article .news-summary-list li span {
  display: block !important;
  min-width: 0 !important;
  width: auto !important;
  max-width: none !important;
  white-space: normal !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  line-height: 1.45 !important;
}

/* Página-mãe: editorias de notícias não puxam posts fora da categoria */
.news-category-section .legolas-empty-state {
  grid-column: 1 / -1;
  min-height: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.news-category-section__grid > .legolas-empty-state {
  background: rgba(255, 248, 226, 0.44) !important;
  color: rgba(43, 26, 16, 0.82) !important;
  border: 1px solid var(--line-soft) !important;
  text-shadow: none !important;
}


/* ============================================================
   v0.4.9 - Lives/VODs: destaque real + galeria sem repetição
   ============================================================ */

.latest-vod-embed .legolas-youtube-embed {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border: 1px solid var(--line);
  background: radial-gradient(circle at 50% 50%, rgba(95, 36, 139, .35), rgba(20, 10, 5, .98));
  box-shadow: inset 0 0 0 10px rgba(255, 244, 218, .08);
}

.latest-vod-embed .legolas-youtube-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.vod-gallery-grid {
  align-items: stretch;
}

.vod-card__thumb {
  background-image:
    linear-gradient(to top, rgba(20, 10, 5, .45), rgba(20, 10, 5, .08)),
    var(--vod-thumb);
  background-size: cover;
  background-position: center;
}

.vod-card__thumb:not([style*="--vod-thumb"]) {
  background-image: radial-gradient(circle at 50% 50%, rgba(95, 36, 139, .35), rgba(20, 10, 5, .98));
}

.vod-card__copy small {
  display: block;
  margin-top: 6px;
  color: rgba(43, 26, 16, .72);
  font-weight: 700;
}

.vod-pagination {
  margin: 34px auto 0;
  display: flex;
  justify-content: center;
}

.vod-pagination ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.vod-pagination a,
.vod-pagination span {
  display: inline-flex;
  min-width: 38px;
  height: 38px;
  padding: 0 12px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  background: rgba(255, 246, 222, .32);
  color: var(--ink);
  text-decoration: none;
  font-weight: 900;
}

.vod-pagination .current {
  background: var(--purple);
  color: #fff;
}


/* ============================================================
   v0.5.0 - Último VOD com thumbnail real
   ============================================================ */

.latest-vod-thumb-card {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid var(--line);
  background:
    linear-gradient(to top, rgba(20, 10, 5, .42), rgba(20, 10, 5, .12)),
    var(--featured-vod-thumb),
    radial-gradient(circle at 50% 50%, rgba(95, 36, 139, .35), rgba(20, 10, 5, .98));
  background-size: cover;
  background-position: center;
  text-decoration: none;
  box-shadow:
    inset 0 0 0 10px rgba(255, 244, 218, .08),
    0 14px 28px rgba(43, 26, 16, .11);
}

.latest-vod-thumb-card::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(255, 246, 222, .26);
  pointer-events: none;
}

.latest-vod-thumb-card__play {
  position: relative;
  z-index: 2;
  width: 68px;
  height: 68px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e62117;
  color: #fff;
  font-size: 28px;
  box-shadow: 0 10px 22px rgba(20, 10, 5, .35);
}

.latest-vod-thumb-card__label {
  position: absolute;
  left: 22px;
  bottom: 20px;
  z-index: 2;
  padding: 8px 10px;
  background: rgba(20, 10, 5, .82);
  color: #ffe6a7;
  font-family: var(--font-title);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.latest-vod-thumb-card:not([style*="--featured-vod-thumb"]) .latest-vod-thumb-card__label::after {
  content: " • thumbnail aguardando";
  opacity: .8;
}


/* ============================================================
   v0.5.3 - Twitch Live dentro da página Lives, abaixo do hero
   ============================================================ */

.lives-twitch-slot {
  width: min(100%, 1500px);
  margin: 0 auto clamp(30px, 4vw, 56px);
  padding: 0 32px;
}

.lives-twitch-slot .legolas-twitch-live-shell {
  width: 100%;
  margin: 0;
  padding: 0;
}

.lives-twitch-slot + .lives-platforms {
  margin-top: clamp(18px, 3vw, 42px) !important;
}

@media (max-width: 980px) {
  .lives-twitch-slot {
    padding: 0 18px;
  }
}


/* ============================================================
   v0.5.4 - PATCH MOBILE GLOBAL
   Foco: header, menu, busca, hero e grids sem sobreposição.
   ============================================================ */

@media (max-width: 900px) {
  html, body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  .site-header,
  .main-header,
  .lg-header,
  header,
  .header {
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: auto !important;
    padding: 18px 14px 12px !important;
    z-index: 50 !important;
  }

  .header-inner,
  .site-header__inner,
  .main-header__inner,
  .lg-header__inner,
  .site-header .container,
  .main-header .container,
  header .container {
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 0 !important;
    margin: 0 auto !important;
  }

  .site-logo,
  .site-branding,
  .custom-logo-link,
  .brand,
  .logo {
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto 4px !important;
    display: flex !important;
    justify-content: center !important;
    text-align: center !important;
  }

  .site-logo img,
  .site-branding img,
  .custom-logo-link img,
  .brand img,
  .logo img,
  .wp-custom-logo img {
    width: min(210px, 54vw) !important;
    max-width: min(210px, 54vw) !important;
    height: auto !important;
    display: block !important;
    margin: 0 auto !important;
    object-fit: contain !important;
  }

  .main-navigation,
  .site-navigation,
  .primary-navigation,
  nav,
  .menu-principal-container,
  .primary-menu-container {
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    text-align: center !important;
  }

  .main-navigation ul,
  .site-navigation ul,
  .primary-navigation ul,
  nav ul,
  .menu,
  .primary-menu,
  #primary-menu,
  .nav-menu {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 7px 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
    list-style: none !important;
  }

  .main-navigation a,
  .site-navigation a,
  .primary-navigation a,
  nav a,
  .menu a,
  .primary-menu a,
  #primary-menu a,
  .nav-menu a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    padding: 4px 2px !important;
    font-size: 10.5px !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
  }

  nav a img,
  .menu a img,
  .primary-menu a img {
    width: 13px !important;
    height: 13px !important;
    object-fit: contain !important;
  }

  .site-search,
  .header-search,
  .search-form,
  .lg-search,
  header form[role="search"] {
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    display: flex !important;
    width: min(340px, 86vw) !important;
    max-width: min(340px, 86vw) !important;
    margin: 4px auto 0 !important;
  }

  .site-search input,
  .header-search input,
  .search-form input[type="search"],
  .lg-search input {
    min-width: 0 !important;
    width: 100% !important;
    height: 42px !important;
    font-size: 13px !important;
  }

  .site-search button,
  .header-search button,
  .search-form button,
  .lg-search button {
    flex: 0 0 46px !important;
    height: 42px !important;
  }

  .breadcrumb,
  .breadcrumbs,
  .lives-breadcrumb {
    max-width: calc(100vw - 28px) !important;
    margin: 10px auto 8px !important;
    font-size: 10px !important;
    line-height: 1.35 !important;
  }

  main,
  .site-main,
  .content-area,
  .page-content {
    max-width: 100% !important;
    overflow-x: hidden !important;
  }
}

@media (max-width: 760px) {
  .container,
  .lg-container,
  .wrap,
  .page-wrap,
  .content-wrap {
    width: min(100%, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .home-hero,
  .hero,
  .front-hero,
  .site-hero,
  .lives-hero,
  .review-hero,
  .archive-hero,
  .news-hero,
  .guides-hero,
  .page-hero {
    width: min(100%, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    margin: 8px auto 26px !important;
    padding: 0 !important;
    min-height: auto !important;
  }

  .home-hero-card,
  .hero-card,
  .front-hero-card,
  .lives-hero-card,
  .review-hero-card,
  .archive-hero-card,
  .news-hero-card,
  .guides-hero-card,
  .page-hero-card {
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    padding: 22px 16px !important;
    min-height: auto !important;
  }

  .home-hero-copy,
  .hero-copy,
  .front-hero-copy,
  .lives-hero-copy,
  .review-hero-copy,
  .archive-hero-copy,
  .news-hero-copy,
  .guides-hero-copy,
  .page-hero-copy {
    width: 100% !important;
    max-width: 100% !important;
    order: 1 !important;
    text-align: left !important;
  }

  .home-hero-media,
  .hero-media,
  .front-hero-media,
  .lives-hero-panel,
  .review-hero-media,
  .archive-hero-media,
  .news-hero-media,
  .guides-hero-media,
  .page-hero-media {
    width: 100% !important;
    max-width: 100% !important;
    order: 2 !important;
    margin: 0 auto !important;
  }

  .home-hero h1,
  .hero h1,
  .front-hero h1,
  .lives-hero h1,
  .review-hero h1,
  .archive-hero h1,
  .news-hero h1,
  .guides-hero h1,
  .page-hero h1,
  .entry-title {
    max-width: 100% !important;
    margin: 0 0 12px !important;
    font-size: clamp(34px, 12vw, 54px) !important;
    line-height: .9 !important;
    letter-spacing: -.045em !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
  }

  .home-hero p,
  .hero p,
  .front-hero p,
  .lives-hero p,
  .review-hero p,
  .archive-hero p,
  .news-hero p,
  .guides-hero p,
  .page-hero p {
    max-width: 100% !important;
    font-size: 16px !important;
    line-height: 1.45 !important;
  }

  .home-hero-actions,
  .hero-actions,
  .front-hero-actions,
  .lives-hero-actions,
  .review-hero-actions,
  .page-hero-actions {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-top: 18px !important;
  }

  .lg-btn,
  .button,
  .wp-block-button__link,
  .home-hero-actions a,
  .hero-actions a,
  .front-hero-actions a {
    width: 100% !important;
    min-height: 48px !important;
    justify-content: center !important;
    text-align: center !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .home-hero-media img,
  .hero-media img,
  .front-hero-media img,
  .review-hero-media img,
  .archive-hero-media img,
  .news-hero-media img,
  .guides-hero-media img,
  .page-hero-media img {
    width: 100% !important;
    max-width: 360px !important;
    height: auto !important;
    display: block !important;
    margin: 0 auto !important;
    object-fit: contain !important;
  }

  .category-strip,
  .home-categories,
  .review-category-strip,
  .category-grid,
  .lives-platform-grid,
  .vod-gallery-grid,
  .reviews-grid,
  .news-grid,
  .guides-grid,
  .footer-grid,
  .home-lower-grid,
  .home-support-grid,
  .posts-grid,
  .cards-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .latest-vod-feature,
  .lives-schedule,
  .lives-community-cta,
  .home-section,
  .support-section,
  .newsletter-section,
  .review-content-grid,
  .news-single-grid,
  .guide-single-grid {
    width: min(100%, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .legolas-twitch-live-shell {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 12px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .legolas-twitch-live__inner {
    grid-template-columns: 1fr !important;
    padding: 24px 16px !important;
  }

  .legolas-twitch-live__title {
    font-size: clamp(34px, 12vw, 54px) !important;
    line-height: .9 !important;
  }

  .legolas-twitch-live__player,
  .latest-vod-thumb-card,
  .latest-vod-embed .legolas-youtube-embed {
    min-height: 210px !important;
    aspect-ratio: 16 / 9 !important;
  }

  .site-footer .container,
  .footer .container,
  .lg-footer .container,
  footer .container {
    width: min(100%, calc(100vw - 28px)) !important;
    max-width: calc(100vw - 28px) !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 22px !important;
    text-align: left !important;
  }
}

@media (max-width: 480px) {
  .site-logo img,
  .site-branding img,
  .custom-logo-link img,
  .brand img,
  .logo img,
  .wp-custom-logo img {
    width: min(185px, 58vw) !important;
    max-width: min(185px, 58vw) !important;
  }

  .main-navigation a,
  .site-navigation a,
  .primary-navigation a,
  nav a,
  .menu a,
  .primary-menu a,
  #primary-menu a,
  .nav-menu a {
    font-size: 9.5px !important;
    padding: 4px 1px !important;
  }

  .home-hero h1,
  .hero h1,
  .front-hero h1,
  .lives-hero h1,
  .review-hero h1,
  .archive-hero h1,
  .news-hero h1,
  .guides-hero h1,
  .page-hero h1,
  .entry-title {
    font-size: clamp(32px, 11.5vw, 46px) !important;
  }

  .home-hero-card,
  .hero-card,
  .front-hero-card,
  .lives-hero-card,
  .review-hero-card,
  .archive-hero-card,
  .news-hero-card,
  .guides-hero-card,
  .page-hero-card {
    padding: 20px 14px !important;
  }
}


/* ============================================================
   v0.5.5 - Patch mobile real: header/topbar + hero
   Alvo: corrigir sobreposição de menu/título no mobile.
   ============================================================ */

@media (max-width: 782px) {
  body {
    overflow-x: hidden !important;
  }

  body .page {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  body .page > .topbar.site-header,
  body .page > header.topbar,
  body .topbar.site-header {
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    z-index: 50 !important;

    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;

    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: center !important;

    grid-template-columns: 1fr !important;
    gap: 10px !important;

    padding: 18px 18px 22px !important;
    margin: 0 auto 10px !important;
    overflow: visible !important;
    box-sizing: border-box !important;
  }

  body .topbar .logo,
  body .topbar .site-logo,
  body .topbar a.logo.site-logo {
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    z-index: 2 !important;

    display: flex !important;
    justify-content: center !important;
    align-items: center !important;

    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
  }

  body .topbar .logo img,
  body .topbar .site-logo img,
  body .topbar a.logo.site-logo img {
    width: min(190px, 52vw) !important;
    max-width: min(190px, 52vw) !important;
    height: auto !important;
    max-height: none !important;
    display: block !important;
    margin: 0 auto !important;
    object-fit: contain !important;
  }

  body .topbar .primary-nav,
  body .topbar nav.primary-nav {
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    z-index: 3 !important;

    width: min(100%, 500px) !important;
    max-width: calc(100vw - 28px) !important;

    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px 11px !important;

    margin: 0 auto !important;
    padding: 0 !important;
    clear: both !important;
    line-height: 1 !important;
  }

  body .topbar .primary-nav a,
  body .topbar nav.primary-nav a {
    position: relative !important;
    inset: auto !important;
    transform: none !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;

    margin: 0 !important;
    padding: 3px 1px !important;

    font-size: 10px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    white-space: nowrap !important;
  }

  body .topbar .primary-nav a img,
  body .topbar nav.primary-nav a img {
    width: 13px !important;
    height: 13px !important;
    object-fit: contain !important;
  }

  body .topbar .primary-nav a.active::after,
  body .topbar nav.primary-nav a.active::after {
    bottom: -8px !important;
    width: 24px !important;
    height: 5px !important;
  }

  body .topbar .site-search,
  body .topbar form.site-search {
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    z-index: 1 !important;

    width: min(330px, 86vw) !important;
    max-width: min(330px, 86vw) !important;
    height: 40px !important;

    display: grid !important;
    grid-template-columns: 1fr 44px !important;
    justify-self: auto !important;

    margin: 10px auto 0 !important;
    padding: 0 !important;
  }

  body .topbar .site-search input[type="search"],
  body .topbar form.site-search input[type="search"] {
    width: 100% !important;
    min-width: 0 !important;
    height: 40px !important;
    padding: 0 14px !important;
    font-size: 12px !important;
    box-sizing: border-box !important;
  }

  body .topbar .site-search button,
  body .topbar form.site-search button {
    width: 44px !important;
    height: 40px !important;
    min-width: 44px !important;
    padding: 0 !important;
  }

  /* Home hero: usa seletores exatos para vencer regras desktop antigas */
  body.home .page #home-hero,
  body .page #home-hero {
    position: relative !important;
    z-index: 1 !important;

    width: min(100%, calc(100vw - 28px)) !important;
    max-width: calc(100vw - 28px) !important;

    display: grid !important;
    grid-template-columns: 1fr !important;
    align-items: start !important;
    justify-items: stretch !important;
    gap: 22px !important;

    min-height: auto !important;
    height: auto !important;

    margin: 0 auto 34px !important;
    padding: 14px 14px 42px !important;

    overflow: visible !important;
    box-sizing: border-box !important;
  }

  body.home .page #home-hero .hero-text,
  body .page #home-hero .hero-text {
    position: relative !important;
    z-index: 2 !important;

    width: 100% !important;
    max-width: 100% !important;

    display: block !important;
    order: 1 !important;

    margin: 0 !important;
    padding: 0 !important;

    transform: none !important;
    text-align: left !important;
  }

  body.home .page #home-hero h1,
  body .page #home-hero h1 {
    width: 100% !important;
    max-width: 100% !important;

    margin: 0 0 16px !important;
    padding: 0 !important;

    font-size: clamp(34px, 10.7vw, 48px) !important;
    line-height: .92 !important;
    letter-spacing: -.04em !important;

    overflow: visible !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
  }

  body.home .page #home-hero p,
  body .page #home-hero p {
    width: 100% !important;
    max-width: 100% !important;

    margin: 0 0 22px !important;

    font-size: 16px !important;
    line-height: 1.42 !important;
  }

  body.home .page #home-hero .hero-buttons,
  body.home .page #home-hero .buttons,
  body .page #home-hero .hero-buttons,
  body .page #home-hero .buttons {
    width: 100% !important;

    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;

    margin: 0 !important;
    padding: 0 !important;
  }

  body.home .page #home-hero .hero-buttons a,
  body.home .page #home-hero .buttons a,
  body .page #home-hero .hero-buttons a,
  body .page #home-hero .buttons a,
  body.home .page #home-hero .lg-btn,
  body .page #home-hero .lg-btn {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 50px !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }

  body.home .page #home-hero .hero-image,
  body .page #home-hero .hero-image {
    position: relative !important;
    z-index: 1 !important;

    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;

    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    order: 2 !important;

    margin: 10px auto 0 !important;
    padding: 0 !important;

    overflow: visible !important;
    transform: none !important;
  }

  body.home .page #home-hero .hero-image img,
  body .page #home-hero .hero-image img {
    width: min(380px, 92vw) !important;
    max-width: min(380px, 92vw) !important;
    height: auto !important;

    display: block !important;
    margin: 0 auto !important;

    object-fit: contain !important;
    object-position: center !important;

    transform: none !important;
  }

  body.home .page .categories,
  body .page .categories {
    width: min(100%, calc(100vw - 28px)) !important;
    max-width: calc(100vw - 28px) !important;

    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;

    margin: 0 auto 28px !important;
  }

  body.home .page .category-card,
  body .page .category-card {
    min-height: auto !important;
    padding: 18px !important;
  }
}

@media (max-width: 420px) {
  body .topbar .logo img,
  body .topbar .site-logo img,
  body .topbar a.logo.site-logo img {
    width: min(170px, 50vw) !important;
    max-width: min(170px, 50vw) !important;
  }

  body .topbar .primary-nav,
  body .topbar nav.primary-nav {
    gap: 7px 9px !important;
  }

  body .topbar .primary-nav a,
  body .topbar nav.primary-nav a {
    font-size: 9px !important;
  }

  body.home .page #home-hero h1,
  body .page #home-hero h1 {
    font-size: clamp(31px, 10.2vw, 43px) !important;
  }
}
