/* ==========================================================================
 * MaisPlay — style.css
 *
 * Estrutura:
 *   01. RESET & TOKENS (cores, espaçamentos, fontes)
 *   02. TIPOGRAFIA
 *   03. LAYOUT (container, grid, utilitários)
 *   04. COMPONENTES — HEADER (top bar + categorias + ticker)
 *   05. COMPONENTES — FOOTER
 *   06. COMPONENTES — BOTÕES, BADGES, AD-SLOTS
 *   07. HOMEPAGE — HERO CARROSSEL
 *   08. HOMEPAGE — MOSAICO DE DESTAQUES
 *   09. HOMEPAGE — FEED CRONOLÓGICO
 *   10. HOMEPAGE — SIDEBAR (reviews + ad + sociais)
 *   11. HOMEPAGE — SHORTS
 *   12. NEWSLETTER (compartilhado)
 *   13. SINGLE — HERO + META
 *   14. SINGLE — CORPO DA MATÉRIA
 *   15. SINGLE — SIDEBAR (TOC + reviews + ad)
 *   16. SINGLE — CHROME (progress bar, TOC flutuante, A-/A+)
 *   17. SINGLE — GALERIA + SHARE + AUTOR + RELACIONADAS
 *   18. RESPONSIVO
 * ========================================================================== */


/* ==========================================================================
 * 01. RESET & TOKENS
 * ========================================================================== */

:root {
  /* Cores base */
  --bg-0: #08070d;
  --bg-1: #0f0d18;
  --bg-2: #181523;
  --bg-3: #221d31;
  --line: rgba(255, 255, 255, 0.08);
  --line-strong: rgba(255, 255, 255, 0.16);
  --fg-0: #f5f1ea;
  --fg-1: #d8d2c4;
  --fg-2: #8e8a9a;
  --fg-3: #5a5668;

  /* Acento (laranja arcade) */
  --accent: #fbb03b;
  --accent-glow: rgba(251, 176, 59, 0.55);
  --accent-soft: rgba(251, 176, 59, 0.12);
  --accent-deep: #8a5e1f;

  /* Cores de categoria */
  --neon-cyan: #4fd6ff;
  --neon-pink: #ff3d8b;
  --neon-lime: #c8ff3d;
  --neon-violet: #a06bff;
  --hot: #ff3d3d;
  --live: #ff3d8b;

  /* Acessibilidade — escala de texto (alterada via A-/A+) */
  --read-scale: 1;

  /* Fontes */
  --font-sans: 'Space Grotesk', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --font-pixel: 'Press Start 2P', monospace;
  --font-display: 'Anton', 'Space Grotesk', sans-serif;
  --font-serif: 'Source Serif 4', Georgia, serif;
}

*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  max-width: 100%;
  overflow-x: hidden;
  background: var(--bg-0);
  color: var(--fg-0);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  -webkit-user-select: text;
  user-select: text;
}
html { scroll-behavior: smooth; }

a { color: inherit; }

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

button { font-family: inherit; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--bg-3); border-radius: 5px; }
::-webkit-scrollbar-track { background: var(--bg-1); }

/* Scanlines CRT (overlay global) */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.022) 0px,
    rgba(255, 255, 255, 0.022) 1px,
    transparent 1px,
    transparent 3px
  );
  pointer-events: none;
  z-index: 1000;
  mix-blend-mode: overlay;
}


/* ==========================================================================
 * 02. TIPOGRAFIA
 * ========================================================================== */

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.005em;
  line-height: 1.05;
  margin: 0;
}
h1 { letter-spacing: 0; }

.mono   { font-family: var(--font-mono); }
.pixel  { font-family: var(--font-pixel); }
.serif  { font-family: var(--font-serif); }

/* Destaque laranja em palavras entre aspas */
.hl { color: var(--accent); }


/* ==========================================================================
 * 03. LAYOUT
 * ========================================================================== */

.container {
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  padding: 0 32px;
}

.divider {
  border-top: 1px solid var(--line);
}


/* ==========================================================================
 * 04. COMPONENTES — HEADER (top bar + categorias + ticker)
 * ========================================================================== */

.site-header {
  border-bottom: 1px solid var(--line);
  position: relative;
  z-index: 50;
}

.site-sticky {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 110;
  border-bottom: 1px solid var(--accent);
  background: rgba(10, 8, 20, .96);
  box-shadow: 0 16px 34px rgba(0,0,0,.38), 0 0 18px rgba(255,174,43,.12);
  transform: translateY(-110%);
  transition: transform .22s ease;
}
.site-sticky.is-visible {
  transform: translateY(0);
}
.site-sticky__inner {
  min-height: 62px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
}
.site-sticky__logo .site-logo__image {
  max-height: 27px;
  max-width: 165px;
}
.site-sticky__nav {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
  min-width: 0;
  overflow: visible;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.site-sticky__nav li {
  position: relative;
  list-style: none;
  flex: 0 0 auto;
}
.site-sticky__nav a {
  color: var(--fg-1);
  text-decoration: none;
  white-space: nowrap;
}
.site-sticky__nav a:hover,
.site-sticky__nav li:hover > a {
  color: var(--accent);
}
.site-sticky__nav .menu-item-has-children > a::after {
  content: '▾';
  display: inline-block;
  margin-left: 4px;
  color: var(--accent);
  font-size: 9px;
  line-height: 1;
  transform: translateY(-1px);
}
.site-sticky__nav .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 130;
  display: none;
  min-width: 180px;
  padding: 10px;
  background: var(--bg-1);
  border: 1px solid var(--line-strong);
  box-shadow: 0 18px 36px rgba(0,0,0,.4);
}
.site-sticky__nav .sub-menu::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: -14px;
  height: 14px;
}
.site-sticky__nav .sub-menu a {
  display: block;
  padding: 8px 10px;
}
.site-sticky__nav .sub-menu a:hover,
.site-sticky__nav .sub-menu .current-menu-item > a {
  background: var(--accent);
  color: #0a0814;
}
.site-sticky__nav li:hover > .sub-menu {
  display: grid;
  gap: 8px;
}
.site-sticky__actions {
  display: flex;
  gap: 10px;
  align-items: center;
}
.site-sticky__toggle {
  display: none;
  width: 38px;
  height: 34px;
  padding: 0;
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--fg-1);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.site-sticky__toggle span {
  display: block;
  width: 16px;
  height: 2px;
  margin: 2px 0;
  background: currentColor;
}
.site-sticky__toggle[aria-expanded="true"] {
  border-color: var(--accent);
  color: var(--accent);
}
.site-sticky-drawer {
  display: none;
}

.site-header__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 32px;
}

.site-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}

.site-logo__image {
  display: block;
  width: auto;
  max-width: 273px;
  max-height: 44px;
  object-fit: contain;
}

.site-logo__mark {
  display: grid;
  grid-template-columns: repeat(11, 2.2px);
  grid-auto-rows: 2.2px;
  gap: 0;
}
.site-logo__mark span {
  width: 2.2px;
  height: 2.2px;
}
.site-logo__mark span.on {
  background: var(--accent);
  box-shadow: 0 0 4px var(--accent-glow);
}

.site-logo__name {
  font-family: var(--font-pixel);
  font-size: 13px;
  color: var(--fg-0);
  letter-spacing: 0.05em;
  line-height: 1;
}

.site-header__actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

.site-header__subscribe {
  padding: 8px 14px;
  box-shadow: 3px 3px 0 var(--accent-deep);
}

.site-menu-toggle {
  display: none;
  width: 38px;
  height: 34px;
  padding: 0;
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--fg-1);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.site-menu-toggle span {
  display: block;
  width: 16px;
  height: 2px;
  margin: 2px 0;
  background: currentColor;
}

.site-categories {
  position: relative;
  z-index: 60;
  display: flex;
  gap: 25px;
  padding: 25px 32px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  overflow: visible;
  text-transform: uppercase;
}
.site-categories ul {
  display: flex;
  gap: inherit;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
.site-categories li {
  position: relative;
  list-style: none;
  flex: 0 0 auto;
}
.site-categories a {
  color: var(--fg-1);
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  padding-bottom: 4px;
}
.site-categories a.is-active,
.site-categories .current-menu-item > a,
.site-categories .current-menu-ancestor > a {
  color: var(--fg-1);
  border-bottom-color: var(--accent);
}
.site-categories a:hover,
.site-categories li:hover > a {
  color: var(--accent);
}
.site-categories .menu-item-has-children > a {
  border-bottom-color: transparent;
}
.site-categories .menu-item-has-children > a::after {
  content: '▾';
  display: inline-block;
  margin-left: 4px;
  color: var(--accent);
  font-size: 9px;
  line-height: 1;
  transform: translateY(-1px);
}
.site-categories .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 70;
  display: none;
  min-width: 180px;
  padding: 10px;
  background: var(--bg-1);
  border: 1px solid var(--line-strong);
}
.site-categories .sub-menu a {
  display: block;
  padding: 8px 10px;
  border-bottom: 0;
}
.site-categories .sub-menu a:hover,
.site-categories .sub-menu .current-menu-item > a {
  background: var(--accent);
  color: #0a0814;
}
.site-categories li:hover > .sub-menu {
  display: grid;
  gap: 8px;
}

.search-panel[hidden] { display: none !important; }
.search-panel {
  position: fixed;
  left: 50%;
  top: 72px;
  transform: translateX(-50%);
  z-index: 120;
  width: min(560px, calc(100vw - 40px));
  background: var(--bg-1);
  border: 1px solid var(--accent);
  box-shadow: 0 18px 50px rgba(0,0,0,0.58), 0 0 24px var(--accent-glow);
  padding: 12px;
}
.search-panel form { display: flex; gap: 0; }
.search-panel input {
  flex: 1;
  min-width: 0;
  background: var(--bg-0);
  border: 1px solid var(--line-strong);
  border-right: 0;
  color: var(--fg-0);
  padding: 14px 16px;
  font: 13px var(--font-mono);
  outline: 0;
}
.search-panel button {
  border: 0;
  padding: 0 16px;
  box-shadow: none;
}

.ticker {
  position: relative;
  z-index: 1;
  overflow: hidden;
  white-space: nowrap;
  background: var(--accent);
  color: #0a0814;
  padding: 8px 0;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
}
.ticker__track {
  display: inline-block;
  animation: mp-marq 36s linear infinite;
}
.ticker:hover .ticker__track { animation-play-state: paused; }
.ticker__group { padding-right: 40px; }


/* ==========================================================================
 * 05. COMPONENTES — FOOTER
 * ========================================================================== */

.site-footer {
  border-top: 1px solid var(--line);
  padding: 20px 0;
}

.site-footer__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.site-footer__left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.site-footer__logo .site-logo__image {
  max-height: 20px;
  max-width: 126px;
}

.site-footer__copy {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.12em;
}
.site-footer__copy a {
  color: var(--accent);
  text-decoration: none;
}
.site-footer__copy a:hover {
  color: var(--fg-0);
}

.site-footer__nav {
  display: flex;
  gap: 18px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
}
.site-footer__nav li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.site-footer__nav a {
  color: var(--fg-2);
  text-decoration: none;
}


/* ==========================================================================
 * 06. COMPONENTES — BOTÕES, BADGES, AD-SLOTS
 * ========================================================================== */

.cta-primary {
  background: var(--accent);
  color: #0a0814;
  border: none;
  font-family: var(--font-pixel);
  font-size: 11px;
  letter-spacing: 0.06em;
  cursor: pointer;
  padding: 12px 18px;
  text-decoration: none;
  display: inline-block;
  transition: transform .1s, box-shadow .1s;
  box-shadow: 4px 4px 0 var(--accent-deep);
}
.cta-primary:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--accent-deep); }
.cta-primary:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--accent-deep); }

.cta-ghost {
  background: transparent;
  color: var(--fg-1);
  border: 1px solid var(--line-strong);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  cursor: pointer;
  padding: 8px 14px;
  text-transform: uppercase;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all .15s;
}
.cta-ghost:hover { border-color: var(--accent); color: var(--accent); }

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid currentColor;
  color: var(--accent);
}
.badge.is-breaking { color: var(--accent); }
.badge.is-review   { color: var(--neon-cyan); }
.badge.is-trailer  { color: var(--neon-pink); }
.badge.is-esports  { color: var(--neon-violet); }
.badge.is-indie    { color: var(--neon-lime); }
.badge.is-guia     { color: var(--neon-lime); }
.badge.is-noticia  { color: var(--accent); }
.badge.is-exclusivo { color: var(--neon-lime); }
.badge.is-opiniao  { color: var(--neon-violet); }
.badge.is-hot      { color: var(--hot); }

/* Slot de anúncio (vazio, pronto pra WP injetar) */
.ad-slot {
  position: relative;
  background: var(--bg-1);
  border: 1px dashed var(--line-strong);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  margin: 0 auto;
}
.ad-slot::before {
  content: 'AD';
  position: absolute;
  top: 6px;
  right: 6px;
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--fg-3);
  letter-spacing: 0.15em;
  background: var(--bg-0);
  padding: 2px 6px;
  border: 1px solid var(--line);
}
.ad-slot__placeholder {
  text-align: center;
}
.ad-slot__placeholder .pixel {
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.1em;
}
.ad-slot__placeholder .size {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg-2);
  margin-top: 12px;
  letter-spacing: 0.08em;
}
.ad-slot--leaderboard { width: 1000px; max-width: 100%; height: 200px; }
.ad-slot--medium      { width: 100%; max-width: 300px; height: 250px; }

.ad-break {
  margin: 48px 0;
}
.ad-break__label {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--fg-3);
  letter-spacing: 0.16em;
  margin-bottom: 8px;
  text-align: center;
}
.mpl-ad-code {
  width: 100%;
  max-width: 100%;
  display: flex;
  justify-content: center;
  overflow: hidden;
}
.mpl-ad-code iframe,
.mpl-ad-code img,
.mpl-ad-code ins {
  max-width: 100%;
}
.mpl-ad-code--footer_banner {
  padding: 28px 20px;
  border-top: 1px solid var(--line);
}

/* Placeholder de imagem (SVG carregado de img/) */
.thumb {
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--bg-2);
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 12px, transparent 12px 24px);
  position: relative;
  overflow: hidden;
}

.section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--accent);
  margin-bottom: 28px;
}
.section-header h2 {
  font-family: var(--font-pixel);
  font-size: 13px;
  color: var(--fg-0);
  letter-spacing: 0.05em;
  text-transform: none;
  font-weight: 400;
  margin: 0;
}
.section-header h2 .marker { color: var(--accent); }
.section-header__right {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.12em;
}

.archive-page,
.error-page {
  padding: 56px 0 72px;
}
.archive-head,
.error-hero {
  padding-bottom: 24px;
  margin-bottom: 34px;
  border-bottom: 2px solid var(--accent);
}
.archive-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
}
.archive-head__kicker,
.error-hero__kicker {
  margin: 0 0 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.archive-head h1,
.error-hero h1 {
  margin: 0;
  max-width: 900px;
  color: var(--fg-0);
  font-family: var(--font-display);
  font-size: clamp(42px, 6vw, 82px);
  line-height: .96;
  text-transform: uppercase;
}
.archive-head__count {
  flex: 0 0 auto;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.archive-search,
.error-search {
  display: flex;
  max-width: 760px;
  margin: 0 0 34px;
}
.archive-search input,
.error-search input {
  flex: 1;
  min-width: 0;
  border: 1px solid var(--line-strong);
  border-right: none;
  background: var(--bg-1);
  color: var(--fg-0);
  padding: 13px 14px;
  font-family: var(--font-mono);
  font-size: 12px;
}
.archive-empty {
  grid-column: 1 / -1;
  padding: 34px;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
}
.archive-empty h2 {
  margin: 0 0 10px;
  font-family: var(--font-display);
  color: var(--fg-0);
  text-transform: uppercase;
}
.archive-empty p,
.error-hero p {
  max-width: 620px;
  color: var(--fg-2);
  line-height: 1.6;
}
.error-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}


/* ==========================================================================
 * 07. HOMEPAGE — HERO CARROSSEL
 * ========================================================================== */

.hero {
  padding: 48px 0 0;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1.55fr 1fr;
  gap: 32px;
  min-height: 460px;
}

.hero__visual {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  aspect-ratio: 16 / 10;
}

.hero__slides {
  position: relative;
  width: 100%;
  height: 100%;
}
.hero__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .5s ease;
  pointer-events: none;
}
.hero__slide.is-active {
  opacity: 1;
  pointer-events: auto;
}
.hero__slide a {
  display: block;
  width: 100%;
  height: 100%;
}
.hero__slide::after,
.mosaic__big::before,
.mosaic__item__thumb::after,
.feed__item__thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.12) 0 8px, transparent 8px 16px),
    repeating-linear-gradient(to bottom, rgba(255,255,255,0.08) 0 1px, rgba(8,7,13,0.08) 1px 2px, transparent 2px 4px),
    radial-gradient(circle at 50% 45%, rgba(255,118,25,0.16), transparent 58%),
    linear-gradient(to bottom, rgba(8,7,13,0.04) 20%, rgba(8,7,13,0.38) 100%);
  mix-blend-mode: overlay;
  z-index: 1;
}
.hero__slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.16) contrast(1.08);
}

.hero__scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(8,7,13,0.7) 0%, transparent 35%);
  pointer-events: none;
}

.hero__counter {
  position: absolute;
  left: 16px;
  top: 16px;
  font-family: var(--font-pixel);
  font-size: 10px;
  color: var(--accent);
  text-shadow: 0 0 8px var(--accent-glow);
  letter-spacing: 0.05em;
  z-index: 2;
}

.hero__nav {
  position: absolute;
  right: 14px;
  bottom: 14px;
  display: flex;
  gap: 6px;
  z-index: 2;
}
.hero__nav button {
  width: 38px;
  height: 38px;
  border: 1px solid var(--line-strong);
  background: rgba(0, 0, 0, 0.55);
  color: var(--fg-0);
  cursor: pointer;
  font-family: monospace;
  font-size: 16px;
}
.hero__nav button.next {
  background: var(--accent);
  color: #0a0814;
  border: none;
  font-weight: 800;
}

.hero__text {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.hero__panel {
  display: none;
}
.hero__panel.is-active {
  display: block;
}
.hero__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.hero__meta .mono {
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.1em;
}
.hero__title {
  font-size: 48px;
  line-height: 1.02;
  margin: 0 0 14px;
}
.hero__excerpt {
  font-size: 15px;
  line-height: 1.6;
  color: var(--fg-1);
  margin: 0;
}

.hero__progress {
  display: flex;
  gap: 6px;
  margin-top: 20px;
  margin-bottom: 18px;
}
.hero__progress button {
  flex: 1;
  height: 4px;
  padding: 0;
  cursor: pointer;
  background: var(--bg-3);
  border: none;
  position: relative;
  overflow: hidden;
}
.hero__progress button.is-past { background: var(--accent); }
.hero__progress button .bar {
  position: absolute;
  inset: 0;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent-glow);
  width: 0%;
}
.hero__progress button.is-active .bar {
  animation: mp-progress 6s linear forwards;
}
.hero.is-paused .hero__progress button.is-active .bar { animation-play-state: paused; }

.hero__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.hero__byline {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-2);
}
.hero__byline strong { color: var(--fg-0); font-weight: 600; }


/* ==========================================================================
 * 07b. GAMING CALENDAR
 * ========================================================================== */

.calendar-page { padding: 54px 0 72px; }
.calendar-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  padding-bottom: 18px;
  border-bottom: 2px solid var(--accent);
}
.calendar-head__kicker,
.calendar-modal__kicker,
.release-sidebar__kicker {
  margin: 0 0 10px;
  font-family: var(--font-pixel);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: .08em;
}
.calendar-head h1 { margin: 0; font-size: 42px; line-height: 1; }
.calendar-head__actions { display: flex; gap: 8px; }
.calendar-btn,
.calendar-more {
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #0a0814;
  font-family: var(--font-pixel);
  font-size: 10px;
  text-decoration: none;
  cursor: pointer;
}
.calendar-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 36px;
  padding: 0 13px;
}
.calendar-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 18px 0 0;
}
.calendar-filters a {
  border: 1px solid var(--line-strong);
  color: var(--fg-2);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .12em;
  padding: 8px 10px;
  text-decoration: none;
  text-transform: uppercase;
}
.calendar-filters a:hover,
.calendar-filters a.is-active {
  border-color: var(--accent);
  background: var(--accent);
  color: #111;
}
.calendar-titlebar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 30px 0 18px;
}
.calendar-titlebar h2 {
  margin: 0;
  font-family: var(--font-pixel);
  font-size: 15px;
  color: var(--fg-0);
}
.calendar-titlebar span {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: .12em;
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  border-left: 1px solid var(--line);
  border-top: 1px solid var(--line);
}
.calendar-grid__weekday {
  padding: 9px 8px;
  background: var(--accent);
  color: #0a0814;
  border-right: 1px solid rgba(0,0,0,.22);
  font-family: var(--font-pixel);
  font-size: 9px;
  text-align: center;
}
.calendar-day {
  position: relative;
  min-height: 158px;
  padding: 26px 7px 8px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(18,15,29,.64);
}
.calendar-day--empty { background: rgba(7,6,12,.58); }
.calendar-day.is-today { background: linear-gradient(180deg, rgba(255,174,43,.16), rgba(18,15,29,.72)); }
.calendar-day__number {
  position: absolute;
  top: 7px;
  right: 8px;
  font-family: var(--font-mono);
  font-weight: 800;
  font-size: 11px;
  color: var(--accent);
}
.calendar-card {
  display: block;
  overflow: hidden;
  margin-bottom: 7px;
  border: 1px solid rgba(188,255,45,.55);
  background: rgba(13,62,24,.84);
  color: var(--fg-0);
  text-decoration: none;
}
.calendar-card__type {
  display: block;
  padding: 5px 6px;
  background: #178b38;
  font-family: var(--font-pixel);
  font-size: 7px;
  text-align: center;
}
.calendar-card__image {
  display: block;
  aspect-ratio: 16 / 7;
  overflow: hidden;
  background: var(--bg-2);
}
.calendar-card__image img { width: 100%; height: 100%; object-fit: cover; }
.calendar-card strong {
  display: block;
  padding: 5px 6px 7px;
  font-size: 11px;
  line-height: 1.25;
}
.calendar-more { width: 100%; min-height: 30px; }
.calendar-list { display: none; }
.calendar-modal {
  position: fixed;
  inset: 0;
  z-index: 12000;
  display: grid;
  place-items: center;
  padding: 22px;
  background: rgba(0,0,0,.72);
}
.calendar-modal[hidden] { display: none; }
.calendar-modal__box {
  position: relative;
  width: min(560px, 100%);
  padding: 28px;
  border: 1px solid var(--accent);
  background: #0c0a16;
  box-shadow: 0 0 34px rgba(255,174,43,.26);
}
.calendar-modal__box h2 { margin: 0 0 18px; font-size: 30px; }
.calendar-modal__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  border: 1px solid var(--accent);
  background: transparent;
  color: var(--accent);
  font-size: 24px;
  cursor: pointer;
}
.calendar-modal__content { display: grid; gap: 10px; }
.calendar-modal__item,
.calendar-list__item {
  display: grid;
  grid-template-columns: 86px 1fr;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--line);
  color: var(--fg-0);
  text-decoration: none;
  background: rgba(18,15,29,.86);
}
.calendar-modal__item img,
.calendar-list__item img {
  width: 86px;
  height: 58px;
  object-fit: cover;
}
.calendar-modal__item strong,
.calendar-list__item strong {
  display: block;
  font-family: var(--font-display);
  font-size: 18px;
  line-height: 1.05;
}
.calendar-modal__item small,
.calendar-list__item small {
  display: block;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
}
.calendar-list__item em {
  display: block;
  margin-top: 7px;
  color: var(--fg-2);
  font-style: normal;
  line-height: 1.45;
}

.release-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
  gap: 34px;
  padding-top: 34px;
}
.release-hero__image {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  aspect-ratio: 16 / 9;
}
.release-hero__image::after,
.release-sidebar__cover::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 10px, transparent 10px 20px);
  mix-blend-mode: screen;
}
.release-hero__image img { width: 100%; height: 100%; object-fit: cover; }
.release-hero__image .badge {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
}
.release-hero__lead {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.release-hero__lead h1 { margin: 0 0 16px; font-size: 54px; line-height: 1; }
.release-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.release-hero__meta span {
  border: 1px solid var(--line-strong);
  padding: 8px 10px;
  font-family: var(--font-pixel);
  font-size: 9px;
  color: var(--accent);
}
.release-sidebar__sticky {
  position: sticky;
  top: 86px;
  border: 1px solid var(--line);
  background: rgba(18,15,29,.82);
}
.release-sidebar__cover {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.release-sidebar__cover img { width: 100%; height: 100%; object-fit: cover; }
.release-sidebar__body { padding: 18px; }
.release-sidebar__body h2 { margin: 0 0 18px; font-size: 30px; line-height: 1; }
.release-sidebar__row {
  display: grid;
  gap: 5px;
  padding: 12px 0;
  border-top: 1px solid var(--line);
}
.release-sidebar__row span {
  font-family: var(--font-pixel);
  font-size: 8px;
  color: var(--fg-3);
}
.release-sidebar__row strong {
  font-family: var(--font-mono);
  color: var(--accent);
}
.release-sidebar__body p { color: var(--fg-1); line-height: 1.55; }
.release-sidebar__site {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 38px;
  margin-top: 8px;
  background: var(--accent);
  color: #0a0814;
  font-family: var(--font-pixel);
  font-size: 9px;
  letter-spacing: .08em;
  text-decoration: none;
  box-shadow: 4px 4px 0 var(--accent-deep);
}
.release-related-link { margin-top: 36px; }
.release-screenshots {
  margin-top: 46px;
}
.release-screenshots__list {
  display: grid;
  gap: 26px;
}
.release-screenshots__item {
  position: relative;
  overflow: hidden;
  margin: 0;
  border: 1px solid var(--line);
  background: var(--bg-2);
}
.release-screenshots__item::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px 4px),
    repeating-linear-gradient(135deg, rgba(255,255,255,.035) 0 10px, transparent 10px 20px);
  mix-blend-mode: screen;
}
.release-screenshots__item img {
  display: block;
  width: 100%;
  height: auto;
}


/* ==========================================================================
 * 08. HOMEPAGE — MOSAICO DE DESTAQUES
 * ========================================================================== */

.mosaic {
  padding: 60px 0;
}
.mosaic__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 28px;
}

.mosaic__big {
  position: relative;
  cursor: pointer;
  border: 1px solid var(--line);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  display: block;
  transition: transform .2s;
}
.mosaic__big:hover { transform: translateY(-3px); }
.mosaic__big .thumb {
  position: absolute;
  inset: 0;
  filter: saturate(1.16) contrast(1.08);
}
.mosaic__big::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(8,7,13,0.92) 0%, rgba(8,7,13,0.2) 45%, transparent 70%);
  pointer-events: none;
}
.mosaic__big .badge { position: absolute; top: 14px; left: 14px; z-index: 2; }
.mosaic__big__caption {
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 22px;
  z-index: 2;
}
.mosaic__big__caption h2 {
  font-size: 34px;
  line-height: 1.05;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.7);
  margin: 0 0 10px;
}
.mosaic__big__caption .meta {
  display: flex;
  gap: 12px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
}
.mosaic__big__caption .meta span.dot { width: 4px; height: 4px; background: var(--fg-3); }

.mosaic__col {
  display: grid;
  grid-template-rows: repeat(3, 1fr);
  gap: 18px;
}
.mosaic__item {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 14px;
  text-decoration: none;
  color: inherit;
  transition: transform .2s;
}
.mosaic__item:hover { transform: translateY(-3px); }
.mosaic__item__thumb {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.mosaic__item__thumb .thumb {
  filter: saturate(1.16) contrast(1.08);
}
.mosaic__item__thumb .score {
  position: absolute;
  bottom: 6px;
  right: 6px;
  background: var(--bg-0);
  border: 1px solid var(--accent);
  padding: 2px 6px;
  font-family: var(--font-pixel);
  font-size: 10px;
  color: var(--accent);
  text-shadow: 0 0 6px var(--accent-glow);
}
.mosaic__item__body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mosaic__item__body .badge { align-self: flex-start; font-size: 9px; }
.mosaic__item__body h3 {
  font-size: 20px;
  line-height: 1.1;
  margin: 0;
}
.mosaic__item__body .meta {
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--fg-3);
}
.mosaic__item__body .meta .author { color: var(--fg-2); }


/* ==========================================================================
 * 09. HOMEPAGE — FEED CRONOLÓGICO
 * ========================================================================== */

.feed__list {
  display: flex;
  flex-direction: column;
  margin-top: 14px;
}
.feed__item {
  display: grid;
  grid-template-columns: 70px 200px 1fr 120px;
  gap: 22px;
  align-items: flex-start;
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
  text-decoration: none;
  color: var(--fg-0);
  transition: transform .2s;
}
.feed__item:hover { transform: translateY(-3px); }
.feed__item__time {
  font-family: var(--font-pixel);
  font-size: 11px;
  color: var(--accent);
  text-shadow: 0 0 6px var(--accent-glow);
  letter-spacing: 0.05em;
  padding-top: 4px;
}
.feed__item__thumb {
  position: relative;
  aspect-ratio: 5 / 3;
  overflow: hidden;
}
.feed__item__thumb .thumb {
  filter: saturate(1.16) contrast(1.08);
}
.feed__item__thumb .score {
  position: absolute;
  bottom: 4px;
  right: 4px;
  background: var(--bg-0);
  border: 1px solid var(--accent);
  padding: 1px 4px;
  font-family: var(--font-pixel);
  font-size: 8px;
  color: var(--accent);
}
.feed__item__body { display: flex; flex-direction: column; gap: 8px; }
.feed__item__topline {
  display: flex;
  align-items: center;
  gap: 8px;
}
.feed__item__topline .tag {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
}
.feed__item__title {
  font-size: 22px;
  line-height: 1.1;
  margin: 0;
}
.feed__item__excerpt {
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--fg-2);
}
.feed__item__author {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-2);
  text-align: right;
  padding-top: 4px;
}

.feed__more {
  display: flex;
  justify-content: center;
  padding: 24px 0;
}
.feed__more button {
  background: transparent;
  border: 1px solid var(--accent);
  color: var(--accent);
  padding: 12px 24px;
  cursor: pointer;
  font-family: var(--font-pixel);
  font-size: 11px;
  letter-spacing: 0.06em;
  box-shadow: 4px 4px 0 var(--accent-deep);
  transition: all .15s;
}
.feed__more button:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--accent-deep); }
.feed__more button[disabled] {
  cursor: wait;
  background: var(--bg-2);
  box-shadow: none;
}
.feed__more .end {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.12em;
}


/* ==========================================================================
 * 10. HOMEPAGE — SIDEBAR
 * ========================================================================== */

.layout-2col {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 56px;
  align-items: stretch;
}

.aside-home {
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: relative;
  align-self: stretch;
}

.aside-home > .mpl-ad-code--home_sidebar {
  position: sticky;
  top: 86px;
  max-width: 300px;
  align-self: center;
  z-index: 2;
}

.aside-card {
  background: var(--bg-1);
  border: 1px solid var(--line);
}
.aside-card__header {
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-2);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.aside-card__header .pixel {
  font-size: 10px;
  color: var(--accent);
  letter-spacing: 0.05em;
}
.aside-card__header .mono {
  font-size: 9px;
  color: var(--fg-3);
  letter-spacing: 0.1em;
}

.reviews-list { list-style: none; margin: 0; padding: 0; }
.reviews-list a {
  display: grid;
  grid-template-columns: 52px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  text-decoration: none;
  color: var(--fg-0);
  position: relative;
}
.reviews-list a::before,
.release-month-list a::before {
  content: '';
  position: absolute;
  pointer-events: none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.12) 0 6px, transparent 6px 12px),
    repeating-linear-gradient(to bottom, rgba(255,255,255,0.08) 0 1px, rgba(8,7,13,0.08) 1px 2px, transparent 2px 4px),
    linear-gradient(to bottom, rgba(8,7,13,0.02), rgba(8,7,13,0.32));
  mix-blend-mode: overlay;
  z-index: 1;
}
.reviews-list a::before {
  left: 14px;
  top: 12px;
  width: 52px;
  height: 52px;
}
.reviews-list li:last-child a { border-bottom: none; }
.reviews-list .game { font-size: 13px; font-weight: 600; line-height: 1.2; letter-spacing: -0.005em; }
.reviews-list .platform {
  font-size: 9px;
  color: var(--fg-3);
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
  margin-top: 3px;
}
.reviews-list .score {
  font-family: var(--font-pixel);
  font-size: 14px;
  color: var(--accent);
  text-shadow: 0 0 6px var(--accent-glow);
  text-align: right;
}
.reviews-list .score.is-good { color: var(--neon-lime); text-shadow: none; }
.reviews-list .verdict {
  font-family: var(--font-mono);
  font-size: 8px;
  color: var(--fg-3);
  letter-spacing: 0.08em;
  margin-top: 3px;
  text-align: right;
}
.reviews-list .thumb {
  width: 52px;
  height: 52px;
  filter: saturate(1.16) contrast(1.08);
}

.release-month-list { list-style: none; margin: 0; padding: 0; }
.release-month-list a {
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  color: var(--fg-0);
  text-decoration: none;
  position: relative;
}
.release-month-list a::before {
  left: 14px;
  top: 12px;
  width: 58px;
  height: 44px;
}
.release-month-list li:last-child a { border-bottom: none; }
.release-month-list a:hover {
  background: var(--bg-2);
}
.release-month-list .thumb {
  width: 58px;
  height: 44px;
  object-fit: cover;
  border: 1px solid rgba(255, 176, 40, 0.24);
  filter: saturate(1.16) contrast(1.08);
}
.release-month-list strong {
  display: block;
  font-size: 12px;
  line-height: 1.18;
  color: var(--fg-0);
}
.release-month-list em,
.release-month-list__empty {
  display: block;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-style: normal;
  color: var(--accent);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.release-month-list__empty {
  padding: 14px;
  color: var(--fg-3);
}
.release-month-text {
  margin: 0;
  padding: 12px 14px 0;
  border-top: 1px solid var(--line);
  color: var(--fg-2);
  font-family: var(--font-mono);
  font-size: 10px;
  line-height: 1.55;
  letter-spacing: .04em;
}
.release-month-actions {
  padding: 12px 14px 14px;
}
.release-month-actions .cta-ghost {
  width: 100%;
  justify-content: center;
  font-size: 10px;
}

.socials-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.socials-grid a {
  padding: 14px 12px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--fg-0);
  transition: background .2s;
}
.socials-grid a:hover { background: var(--bg-2); }
.socials-grid a:nth-child(even) { border-right: none; }
.socials-grid a:last-child,
.socials-grid a:nth-last-child(2):nth-child(odd) { border-bottom: none; }

.socials-grid .glyph {
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0a0814;
  font-family: var(--font-pixel);
  font-size: 12px;
}
.socials-grid .glyph.youtube   { background: #ff3d3d; box-shadow: 0 0 8px #ff3d3d66; }
.socials-grid .glyph.youtube {
  color: #fff;
}
.socials-grid .glyph.x         { background: #ffffff; box-shadow: 0 0 8px #ffffff66; }
.socials-grid .glyph.instagram { background: #ff3d8b; box-shadow: 0 0 8px #ff3d8b66; }
.socials-grid .glyph.tiktok    { background: #4fd6ff; box-shadow: 0 0 8px #4fd6ff66; }
.socials-grid .glyph.facebook  { background: #1877f2; box-shadow: 0 0 8px #1877f266; color: #fff; }

.socials-grid .label   { font-size: 11px; font-weight: 600; line-height: 1; }
.socials-grid .count   { font-family: var(--font-mono); font-size: 9px; color: var(--fg-3); margin-top: 3px; letter-spacing: 0.08em; }


/* ==========================================================================
 * 11. HOMEPAGE — SHORTS
 * ========================================================================== */

.shorts {
  padding: 72px 0;
  border-top: 1px solid var(--line);
}
.shorts__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
  margin-top: 40px;
  margin-bottom: 40px;
}
.shorts__embed {
  margin-top: 40px;
  max-width: 100%;
  overflow: hidden;
}
.shorts__embed iframe,
.shorts__embed img,
.shorts__embed video {
  max-width: 100%;
}
.shorts__tile {
  position: relative;
  width: 100%;
  aspect-ratio: 9 / 16;
  background: var(--bg-2);
  overflow: hidden;
  border: 1px solid var(--line);
  cursor: pointer;
}
.shorts__tile button.placeholder {
  position: absolute;
  inset: 0;
  padding: 0;
  cursor: pointer;
  background: transparent;
  border: none;
  display: block;
  width: 100%;
  height: 100%;
}
.shorts__tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.shorts__tile .scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(8,7,13,0.85), transparent 50%);
  pointer-events: none;
}
.shorts__tile .play {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 56px;
  height: 56px;
  background: var(--accent);
  color: #0a0814;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-pixel);
  font-size: 18px;
  box-shadow: 0 0 24px var(--accent-glow), 4px 4px 0 var(--accent-deep);
}
.shorts__tile .number {
  position: absolute;
  top: 8px;
  left: 8px;
  font-family: var(--font-pixel);
  font-size: 8px;
  color: var(--accent);
  background: rgba(8, 7, 13, 0.7);
  padding: 3px 5px;
  letter-spacing: 0.08em;
}
.shorts__tile .label {
  position: absolute;
  bottom: 8px;
  left: 10px;
  right: 10px;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--fg-1);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.shorts__tile iframe {
  width: 100%;
  height: 100%;
  border: none;
}
.shorts__cta {
  display: flex;
  justify-content: center;
  margin-top: 32px;
}


/* ==========================================================================
 * 12. NEWSLETTER (compartilhado entre index e single)
 * ========================================================================== */

.newsletter {
  padding: 72px 0;
  border-top: 1px solid var(--line);
}
.newsletter__inner {
  background: var(--bg-1);
  border: 1px solid var(--accent);
  padding: 32px 40px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: center;
  min-width: 0;
}
.newsletter__kicker {
  font-family: var(--font-pixel);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: 0.05em;
}
.newsletter__title {
  margin: 12px 0 6px;
  font-size: 38px;
  line-height: 1.05;
}
.newsletter__sub {
  margin: 0;
  font-size: 13px;
  color: var(--fg-2);
  line-height: 1.55;
}
.newsletter__form {
  display: flex;
  gap: 0;
  min-width: 0;
}
.newsletter__form input {
  flex: 1;
  min-width: 0;
  background: var(--bg-0);
  border: 1px solid var(--line-strong);
  border-right: none;
  color: var(--fg-0);
  padding: 14px;
  font-family: var(--font-mono);
  font-size: 13px;
  outline: none;
}
.newsletter__form button {
  flex: 0 0 auto;
  background: var(--accent);
  color: #0a0814;
  border: 1px solid var(--accent);
  padding: 0 20px;
  cursor: pointer;
  font-family: var(--font-pixel);
  font-size: 11px;
  letter-spacing: 0.06em;
}
.newsletter__bar {
  display: flex;
  gap: 4px;
  margin-top: 12px;
  align-items: center;
}
.newsletter__bar span.cell { width: 8px; height: 8px; background: var(--bg-3); }
.newsletter__bar span.cell.on { background: var(--accent); }
.newsletter__bar .count {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--fg-3);
  margin-left: 8px;
  letter-spacing: 0.1em;
}


/* ==========================================================================
 * 13. SINGLE — HERO + META
 * ========================================================================== */

.breadcrumb {
  padding-top: 22px;
  padding-bottom: 18px;
}
.breadcrumb nav {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  display: flex;
  gap: 10px;
  align-items: center;
}
.breadcrumb a { color: var(--fg-2); text-decoration: none; }
.breadcrumb .sep { color: var(--fg-3); }
.breadcrumb .current { color: var(--accent); }

/* ==========================================================================
 * LINK NA BIO MOBILE
 * ========================================================================== */

.bio-link-page {
  min-height: 100vh;
  background:
    repeating-linear-gradient(to bottom, rgba(255,255,255,0.035) 0 1px, transparent 1px 4px),
    radial-gradient(circle at 50% 0%, rgba(255,176,40,0.12), transparent 34%),
    var(--bg-0);
}

.bio-shell {
  width: 100%;
  min-height: 100vh;
  padding: 18px 12px 32px;
}

.bio-card {
  width: min(100%, 430px);
  margin: 0 auto;
  border: 1px solid var(--line-strong);
  background:
    linear-gradient(180deg, rgba(22,18,33,0.96), rgba(8,7,13,0.98)),
    var(--bg-1);
  box-shadow: 0 0 0 1px rgba(255,176,40,0.16), 0 24px 70px rgba(0,0,0,0.42);
  overflow: hidden;
}

.bio-hero {
  position: relative;
  padding: 30px 20px 22px;
  text-align: center;
  border-bottom: 1px solid var(--line);
}

.bio-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.06) 0 8px, transparent 8px 16px),
    linear-gradient(to bottom, transparent 35%, rgba(8,7,13,0.38));
  mix-blend-mode: overlay;
}

.bio-logo {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 18px;
  color: var(--fg-0);
  text-decoration: none;
}

.bio-logo .site-logo__image {
  max-width: 178px;
  max-height: 54px;
  width: auto;
  height: auto;
}

.bio-kicker {
  position: relative;
  z-index: 1;
  margin: 0 0 8px;
  color: var(--accent);
  font-size: 11px;
  letter-spacing: 0.14em;
}

.bio-hero h1 {
  position: relative;
  z-index: 1;
  margin: 0;
  font-size: 28px;
  line-height: 0.98;
  color: var(--fg-0);
  text-transform: uppercase;
}

.bio-actions {
  display: grid;
  gap: 10px;
  padding: 18px 16px;
}

.bio-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 52px;
  padding: 0 16px;
  border: 1px solid var(--line-strong);
  background: var(--bg-0);
  color: var(--fg-0);
  text-decoration: none;
  font-family: var(--font-pixel);
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow: 4px 4px 0 rgba(0,0,0,0.42);
  transition: transform .18s ease, box-shadow .18s ease;
}

.bio-action:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 rgba(0,0,0,0.52);
}

.bio-action strong {
  font-size: 18px;
  line-height: 1;
}

.bio-action--accent { border-color: rgba(255,176,40,0.72); }
.bio-action--accent strong { color: var(--accent); }
.bio-action--cyan { border-color: rgba(79,214,255,0.6); }
.bio-action--cyan strong { color: var(--neon-cyan); }
.bio-action--pink { border-color: rgba(255,61,139,0.58); }
.bio-action--pink strong { color: var(--neon-pink); }
.bio-action--green { border-color: rgba(57,255,136,0.48); }
.bio-action--green strong { color: var(--neon-lime); }
.bio-action--violet { border-color: rgba(160,107,255,0.58); }
.bio-action--violet strong { color: var(--neon-violet); }

.bio-section { padding: 4px 16px 18px; }

.bio-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 13px 0;
  margin-bottom: 10px;
}

.bio-section__header h2 {
  margin: 0;
  font-size: 18px;
  line-height: 1;
}

.bio-section__header .mono {
  color: var(--fg-3);
  font-size: 9px;
  letter-spacing: 0.1em;
}

.bio-recent-list {
  display: grid;
  gap: 10px;
}

.bio-recent {
  display: grid;
  grid-template-columns: 78px 1fr;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--line);
  color: var(--fg-0);
  text-decoration: none;
  background: rgba(255,255,255,0.02);
}

.bio-recent__thumb {
  position: relative;
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid rgba(255,176,40,0.2);
}

.bio-recent__thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.12) 0 6px, transparent 6px 12px),
    repeating-linear-gradient(to bottom, rgba(255,255,255,0.08) 0 1px, rgba(8,7,13,0.08) 1px 2px, transparent 2px 4px),
    linear-gradient(to bottom, rgba(8,7,13,0.02), rgba(8,7,13,0.34));
  mix-blend-mode: overlay;
}

.bio-recent__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.16) contrast(1.08);
}

.bio-recent__body {
  min-width: 0;
  display: grid;
  gap: 5px;
}

.bio-recent__body .badge {
  width: fit-content;
  font-size: 8px;
}

.bio-recent__body strong {
  display: block;
  color: var(--fg-0);
  font-size: 15px;
  line-height: 1.08;
  text-transform: uppercase;
}

.bio-recent__body .mono {
  color: var(--fg-3);
  font-size: 9px;
}

.bio-more {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  margin-top: 12px;
  border: 1px solid var(--line-strong);
  color: var(--fg-0);
  text-decoration: none;
  font-family: var(--font-pixel);
  font-size: 11px;
  letter-spacing: 0.12em;
}

.bio-socials {
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 0 16px 22px;
}

.bio-socials a,
.bio-socials .glyph {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  text-decoration: none;
}

.bio-socials .glyph {
  color: #0a0814;
  font-family: var(--font-pixel);
  font-size: 13px;
}

.bio-socials .youtube { background: #ff3d3d; color: #fff; }
.bio-socials .x { background: #fff; }
.bio-socials .instagram { background: #ff3d8b; }
.bio-socials .tiktok { background: #4fd6ff; }
.bio-socials .facebook { background: #1877f2; color: #fff; }

.bio-link-page .newsletter {
  padding: 0;
  border-top: 1px solid var(--line);
}

.bio-link-page .newsletter .container {
  width: 100%;
  max-width: none;
  padding: 0;
}

.bio-link-page .newsletter__inner {
  grid-template-columns: 1fr;
  gap: 18px;
  padding: 22px 16px 24px;
  border: 0;
}

.bio-link-page .newsletter__title {
  font-size: 24px;
  line-height: 1.02;
}

.bio-link-page .newsletter__form {
  width: 100%;
}

.article-hero {
  padding-bottom: 32px;
}
.article-hero__image {
  position: relative;
  margin-bottom: 36px;
  aspect-ratio: 64 / 26;
  overflow: hidden;
}
.article-hero__image::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.055) 0 10px, transparent 10px 20px),
    repeating-linear-gradient(to bottom, rgba(255,255,255,0.035) 0 1px, transparent 1px 3px),
    linear-gradient(to bottom, rgba(8,7,13,0) 42%, rgba(8,7,13,0.24) 100%);
  mix-blend-mode: overlay;
  z-index: 1;
}
.article-hero__image .badge {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  background: var(--neon-cyan);
  color: #0a0814;
  border: none;
  font-weight: 800;
  letter-spacing: 0.16em;
  font-size: 10px;
  padding: 5px 10px;
}
.article-hero__image .badge.is-breaking,
.article-hero__image .badge.is-noticia { background: var(--accent); }
.article-hero__image .badge.is-review { background: var(--neon-cyan); }
.article-hero__image .badge.is-trailer { background: var(--neon-pink); }
.article-hero__image .badge.is-esports,
.article-hero__image .badge.is-opiniao { background: var(--neon-violet); }
.article-hero__image .badge.is-indie,
.article-hero__image .badge.is-guia,
.article-hero__image .badge.is-exclusivo { background: var(--neon-lime); }
.article-hero__image .badge.is-hot { background: var(--hot); }
.article-hero__lead {
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
}
.article-hero__kicker {
  font-family: var(--font-pixel);
  font-size: 11px;
  color: var(--accent);
  letter-spacing: 0.08em;
  margin-bottom: 18px;
}
.article-hero h1 {
  font-size: clamp(30px, 4.8vw, 58px);
  margin: 0 0 24px;
  line-height: 1.08;
}
.article-hero__lede {
  font-family: var(--font-serif);
  font-size: 22px;
  line-height: 1.5;
  color: var(--fg-1);
  margin: 0;
  font-style: italic;
}

.meta-bar {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg-1);
}
.meta-bar__inner {
  padding: 18px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.meta-bar__author {
  display: flex;
  align-items: center;
  gap: 14px;
}
.meta-bar__avatar {
  width: 44px;
  height: 44px;
  background: oklch(0.55 0.18 220);
  border: 2px solid var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-pixel);
  font-size: 14px;
  color: #0a0814;
  overflow: hidden;
}
.meta-bar__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.meta-bar__name {
  font-family: var(--font-display);
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: 0.01em;
}
.meta-bar__details {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.1em;
}

/* Accessibility A-/A+ controls */
.a11y-controls {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
}
.a11y-controls .label {
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.14em;
  border-right: 1px solid var(--line);
}
.a11y-controls button {
  background: transparent;
  border: none;
  border-right: 1px solid var(--line);
  color: var(--fg-0);
  cursor: pointer;
  padding: 8px 14px;
  font-family: var(--font-display);
  letter-spacing: 0.04em;
  min-width: 44px;
}
.a11y-controls button:last-child { border-right: none; }
.a11y-controls button[disabled] { color: var(--fg-3); cursor: not-allowed; }
.a11y-controls button .small { font-size: 12px; }
.a11y-controls button .med   { font-size: 14px; }
.a11y-controls button .big   { font-size: 18px; }


/* ==========================================================================
 * 14. SINGLE — CORPO DA MATÉRIA
 * ========================================================================== */

.article-wrap {
  padding: 48px 0 24px;
  overflow-x: clip;
}
.article-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 64px;
  align-items: start;
}
.article-main {
  max-width: 720px;
  margin: 0 auto;
  width: 100%;
  min-width: 0;
}
.article-body {
  max-width: 100%;
  min-width: 0;
  overflow-wrap: break-word;
  -webkit-user-select: text;
  user-select: text;
}
.article-body *,
.article-main,
.article-hero,
.feed__item,
.related__card,
.mosaic {
  -webkit-user-select: text;
  user-select: text;
}

.article-body p,
.article-body ul,
.article-body ol,
.article-body blockquote {
  font-family: var(--font-serif);
  font-size: calc(19px * var(--read-scale));
  line-height: 1.7;
  color: var(--fg-1);
  margin: 0 0 24px;
}
.article-body p .hl { font-weight: 600; }
.article-body strong,
.article-body b {
  color: var(--accent);
  font-weight: 600;
}
.article-body a {
  color: var(--accent);
  text-decoration-color: var(--accent);
  text-underline-offset: 3px;
}
.article-body a:hover { color: var(--fg-0); }

.article-body h2 {
  font-family: var(--font-display);
  font-size: calc(40px * var(--read-scale));
  margin: 56px 0 20px;
  color: var(--fg-0);
  scroll-margin-top: 80px;
}
.article-body h2::before {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: var(--accent);
  margin-bottom: 18px;
  box-shadow: 0 0 8px var(--accent-glow);
}
.article-body h3 {
  font-family: var(--font-display);
  font-size: calc(26px * var(--read-scale));
  margin: 36px 0 14px;
  color: var(--fg-0);
}

.article-body .pull {
  font-family: var(--font-display);
  font-size: calc(34px * var(--read-scale));
  line-height: 1.15;
  color: var(--accent);
  text-transform: uppercase;
  border-left: 3px solid var(--accent);
  padding: 12px 0 12px 24px;
  margin: 40px 0;
  text-shadow: 0 0 12px var(--accent-glow);
}
.article-body .pull p {
  font: inherit;
  line-height: inherit;
  color: inherit;
  margin: 0;
}

.article-body .dropcap::first-letter {
  font-family: var(--font-pixel);
  font-size: 3.4em;
  float: left;
  line-height: 0.85;
  margin: 6px 14px 0 0;
  color: var(--accent);
  text-shadow: 0 0 10px var(--accent-glow);
}

.article-body figure,
.article-body .wp-block-image {
  height: auto !important;
  min-height: 0 !important;
  max-width: 100%;
  contain-intrinsic-size: none !important;
}
.article-body figure { margin: 36px 0; }
.article-body img {
  display: block;
  max-width: 100%;
  height: auto !important;
  min-height: 0 !important;
  contain-intrinsic-size: none !important;
  content-visibility: visible !important;
}
.article-body img:is([sizes="auto" i], [sizes^="auto," i]) {
  contain-intrinsic-size: none !important;
}
.article-body figure img,
.article-body figure .thumb,
.article-body > img {
  width: 100%;
  height: auto;
  aspect-ratio: auto;
  object-fit: contain;
}
.article-body > img { margin: 36px 0; }
.article-body > figure.wp-block-image,
.article-body > .wp-block-image:not(.alignleft):not(.alignright) {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.article-body > figure.wp-block-image img,
.article-body > .wp-block-image:not(.alignleft):not(.alignright) img,
.article-body p > img:only-child {
  width: 100% !important;
  max-width: 100% !important;
  height: auto;
  aspect-ratio: auto;
  object-fit: contain;
}
.article-body p > img.alignnone,
.article-body p > img.size-full,
.article-body p > img[class*="wp-image-"] {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: min(72vh, 560px);
  object-fit: contain !important;
  margin-inline: auto;
}
.article-body figure.mpl-rawg-screenshot {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 16px 0 !important;
  padding: 0 !important;
  line-height: 0;
}
.article-body h2 + figure.mpl-rawg-screenshot {
  margin-top: 18px !important;
}
.article-body figure.mpl-rawg-screenshot + figure.mpl-rawg-screenshot {
  margin-top: 12px !important;
}
.article-body figure.mpl-rawg-screenshot img {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: none !important;
  aspect-ratio: auto !important;
  object-fit: contain !important;
  margin: 0 !important;
}
.article-body img.mpl-rawg-screenshot {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  contain-intrinsic-size: none !important;
  aspect-ratio: auto !important;
  object-fit: contain !important;
  margin: 14px 0 !important;
  line-height: 1;
}
.article-body h2 + img.mpl-rawg-screenshot {
  margin-top: 18px !important;
}
.article-body img.mpl-rawg-screenshot + img.mpl-rawg-screenshot {
  margin-top: 12px !important;
}
.article-body .mpl-rawg-screenshot-frame {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: 14px 0;
  padding: 0;
  line-height: 0;
  clear: both;
}
.article-body h2 + .mpl-rawg-screenshot-frame {
  margin-top: 18px;
}
.article-body .mpl-rawg-screenshot-frame + .mpl-rawg-screenshot-frame {
  margin-top: 12px;
}
.article-body .mpl-rawg-screenshot-frame img.mpl-rawg-screenshot {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  contain-intrinsic-size: none !important;
  aspect-ratio: auto !important;
  object-fit: contain !important;
  margin: 0 !important;
}
.article-body .alignfull,
.article-body .alignwide {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.article-body p:has(> img:only-child) {
  margin: 36px 0;
}
.article-body iframe,
.article-body embed,
.article-body object,
.article-body video {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: 36px 0;
  border: 0;
}
.article-body iframe[src*="youtube.com"],
.article-body iframe[src*="youtube-nocookie.com"],
.article-body iframe[src*="youtu.be"] {
  aspect-ratio: 16 / 9;
  height: auto;
}
.article-body .wp-block-embed {
  margin: 36px 0;
}
.article-body .wp-block-embed__wrapper {
  width: 100%;
}
.article-body .wp-block-embed__wrapper iframe {
  margin: 0;
}
.article-body .wp-block-gallery,
.article-body ul.wp-block-gallery,
.article-body .blocks-gallery-grid,
.article-body .gallery[class*="gallery-columns-"] {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  width: 100%;
  margin: 40px 0;
  padding: 0;
  list-style: none;
}
.article-body .wp-block-gallery.columns-1,
.article-body .blocks-gallery-grid.columns-1,
.article-body .gallery.gallery-columns-1 { grid-template-columns: 1fr; }
.article-body .wp-block-gallery.columns-2,
.article-body .blocks-gallery-grid.columns-2,
.article-body .gallery.gallery-columns-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.article-body .wp-block-gallery.columns-3,
.article-body .blocks-gallery-grid.columns-3,
.article-body .gallery.gallery-columns-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.article-body .wp-block-gallery.columns-4,
.article-body .blocks-gallery-grid.columns-4,
.article-body .gallery.gallery-columns-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.article-body .wp-block-gallery.columns-5,
.article-body .blocks-gallery-grid.columns-5,
.article-body .gallery.gallery-columns-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.article-body .wp-block-gallery.columns-6,
.article-body .blocks-gallery-grid.columns-6,
.article-body .gallery.gallery-columns-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.article-body .wp-block-gallery.columns-7,
.article-body .blocks-gallery-grid.columns-7,
.article-body .gallery.gallery-columns-7 { grid-template-columns: repeat(7, minmax(0, 1fr)); }
.article-body .wp-block-gallery.columns-8,
.article-body .blocks-gallery-grid.columns-8,
.article-body .gallery.gallery-columns-8 { grid-template-columns: repeat(8, minmax(0, 1fr)); }
.article-body .wp-block-gallery figure,
.article-body .wp-block-gallery .wp-block-image,
.article-body .blocks-gallery-item,
.article-body .gallery[class*="gallery-columns-"] .gallery-item {
  position: relative;
  overflow: hidden;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
  cursor: zoom-in;
}
.article-body .wp-block-gallery img,
.article-body .blocks-gallery-item img,
.article-body .gallery[class*="gallery-columns-"] img {
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  transition: transform .2s;
}
.article-body .wp-block-gallery figure:hover img,
.article-body .blocks-gallery-item:hover img,
.article-body .gallery[class*="gallery-columns-"] .gallery-item:hover img {
  transform: scale(1.03);
}
.article-body table {
  display: block;
  max-width: 100%;
  overflow-x: auto;
}
.article-body figcaption {
  font-family: var(--font-mono);
  font-size: calc(11px * var(--read-scale));
  color: var(--fg-3);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 10px;
  padding-left: 12px;
  border-left: 2px solid var(--accent);
}

.article-body ul.bullets {
  padding-left: 0;
  list-style: none;
}
.article-body ul.bullets li {
  position: relative;
  padding-left: 32px;
  margin-bottom: 12px;
  font-size: calc(19px * var(--read-scale));
  line-height: 1.55;
}
.article-body ul.bullets li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 12px;
  height: 12px;
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent-glow);
}

.page-wrap {
  padding: 56px 0 72px;
}
.page-main {
  max-width: 860px;
  margin: 0 auto;
}
.page-hero {
  padding-bottom: 22px;
  margin-bottom: 34px;
  border-bottom: 2px solid var(--accent);
}
.page-hero__kicker {
  margin-bottom: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.page-hero h1 {
  max-width: 820px;
  margin: 0;
  color: var(--fg-0);
  font-family: var(--font-display);
  font-size: clamp(44px, 6vw, 78px);
  line-height: .96;
  text-transform: uppercase;
}
.page-hero__lede {
  max-width: 680px;
  margin: 18px 0 0;
  color: var(--fg-2);
  font-family: var(--font-serif);
  font-size: 20px;
  line-height: 1.55;
}
.page-featured {
  position: relative;
  margin: 0 0 36px;
  border: 1px solid var(--line-strong);
  overflow: hidden;
}
.page-featured::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.035), rgba(255,255,255,.035) 1px, transparent 1px, transparent 4px),
    linear-gradient(135deg, rgba(255,122,0,.15), transparent 38%);
}
.page-featured img {
  width: 100%;
  height: auto;
  display: block;
}
.page-content {
  padding: 0 0 10px;
}
.page-content > :first-child {
  margin-top: 0;
}

.article-body .area-codigo {
  position: relative;
  margin: 26px 0;
  padding: 18px;
  background:
    linear-gradient(180deg, rgba(255, 122, 0, .09), rgba(255, 122, 0, 0) 48%),
    var(--bg-1);
  border: 1px solid var(--line-strong);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .03), 0 12px 28px rgba(0, 0, 0, .28);
}
.article-body .area-codigo::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(0deg, rgba(255, 255, 255, .035), rgba(255, 255, 255, .035) 1px, transparent 1px, transparent 4px);
  opacity: .22;
}
.article-body .area-codigo__title,
.article-body .area-codigo > p {
  position: relative;
  z-index: 1;
  margin: 0 0 14px;
  font-family: var(--font-display);
  font-size: 18px;
  line-height: 1.15;
  text-transform: uppercase;
  letter-spacing: 0;
}
.article-body .area-codigo__title strong,
.article-body .area-codigo > p strong {
  color: var(--accent);
}
.article-body .sequencia {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.article-body .cheat-button,
.article-body .botaoControle {
  --cheat-button-color: #050505;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  min-width: 36px;
  height: 36px;
  margin: 0;
  border: 1px solid var(--cheat-button-color);
  background: var(--cheat-button-color);
  color: #fff;
  box-shadow: none;
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 800;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  text-shadow: none;
  border-radius: 6px;
}
.article-body .cheat-button > span,
.article-body .botaoControle > span,
.article-body .botaoControle > p {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: 1;
}
.article-body .cheat-button.is-shoulder,
.article-body .cheat-button.is-key,
.article-body .botaoControle.is-shoulder,
.article-body .botaoControle.is-key {
  width: auto;
  min-width: 46px;
  padding: 0 10px;
}
.article-body .cheat-button.is-stick,
.article-body .botaoControle.is-stick,
.article-body .botaoControle.redondo {
  border-radius: 999px;
}
.article-body .cheat-button.is-shape,
.article-body .cheat-button.is-arrow {
  font-size: 21px;
}
.article-body .cheat-button.is-arrow > span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  transform: translateY(-1px);
}
.article-body .cheat-button.is-circle,
.article-body .cheat-button.is-triangle {
  border-radius: 6px;
}
.article-body .cheat-button.is-square > span {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  transform: translateY(-1px);
}
.article-body .cheat-button.is-square {
  --cheat-button-color: #d948ff;
}
.article-body .cheat-button.is-triangle,
.article-body .cheat-button.is-y {
  --cheat-button-color: #24c85a;
}
.article-body .cheat-button.is-circle,
.article-body .cheat-button.is-b {
  --cheat-button-color: #f0333d;
}
.article-body .cheat-button.is-cross,
.article-body .cheat-button.is-x {
  --cheat-button-color: #2f7dff;
}
.article-body .cheat-button.is-a {
  --cheat-button-color: #22b85a;
}
.article-body .cheat-button.is-pc-key {
  box-shadow: none;
  filter: none;
  letter-spacing: .04em;
  text-shadow: none;
}
.article-body .cheat-copy {
  position: relative;
  z-index: 1;
  margin-top: 14px;
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--fg-1);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .12em;
  padding: 8px 12px;
  text-transform: uppercase;
}
.article-body .cheat-copy:hover,
.article-body .cheat-copy.is-copied {
  border-color: var(--accent);
  color: var(--accent);
}

.upcoming-releases {
  padding: 18px 0 54px;
}
.upcoming-releases__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.upcoming-release {
  display: grid;
  grid-template-columns: 78px 1fr;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
  color: var(--fg-0);
  text-decoration: none;
}
.upcoming-release:hover {
  border-color: var(--accent);
}
.upcoming-release img {
  width: 78px;
  height: 58px;
  object-fit: cover;
}
.upcoming-release strong {
  display: block;
  font-size: 13px;
  line-height: 1.18;
}
.upcoming-release em {
  display: block;
  margin-top: 5px;
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 9px;
  font-style: normal;
  letter-spacing: .08em;
  text-transform: uppercase;
}


/* ==========================================================================
 * 15. SINGLE — SIDEBAR
 * ========================================================================== */

.aside-single {
  position: relative;
  align-self: stretch;
}
.aside-single .aside-card { margin-bottom: 24px; background: var(--bg-1); border: 1px solid var(--line-strong); }
.aside-single .aside-card__header {
  padding: 14px 16px;
  border-bottom: 2px solid var(--accent);
  background: transparent;
}
.aside-single > .ad-slot--medium,
.aside-single > .mpl-ad-code--sidebar_single {
  position: sticky;
  top: 86px;
}

.aside-single > .mpl-ad-code--sidebar_single {
  max-width: 300px;
  align-self: center;
  margin-top: 24px;
  z-index: 3;
}

@media (min-width: 901px) {
  .article-wrap {
    overflow: visible;
  }
  .aside-single > .ad-slot--medium,
  .aside-single > .mpl-ad-code--sidebar_single {
    position: sticky;
    top: 96px;
  }
}

.toc {
  list-style: none;
  margin: 0;
  padding: 8px 0;
}
.toc button {
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  border-left: 3px solid transparent;
  color: var(--fg-1);
  padding: 10px 16px;
  cursor: pointer;
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--font-display);
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  transition: background .15s, color .15s;
}
.toc button:hover { background: var(--bg-2); }
.toc button.is-active {
  background: var(--accent-soft);
  border-left-color: var(--accent);
  color: var(--accent);
}
.toc .num {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--fg-3);
  min-width: 22px;
  letter-spacing: 0.1em;
}
.toc button.is-active .num { color: var(--accent); }


/* ==========================================================================
 * 16. SINGLE — CHROME (progress bar, TOC flutuante)
 * ========================================================================== */

.reading-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  z-index: 1100;
  background: transparent;
}
.reading-bar > span {
  display: block;
  height: 100%;
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent-glow);
  width: 0%;
  transition: width .08s linear;
}

.toc-floating {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  z-index: 1200;
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--bg-1);
  border: 1px solid var(--accent);
  color: var(--fg-0);
  padding: 12px 20px;
  cursor: pointer;
  box-sizing: border-box;
  max-width: min(560px, 90vw);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5), 0 0 16px var(--accent-glow);
  transition: transform .15s, box-shadow .15s;
}
.toc-floating:hover { transform: translate(-50%, -2px); }
.toc-floating .dot {
  width: 8px;
  height: 8px;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent-glow);
}
.toc-floating .kicker {
  font-family: var(--font-pixel);
  font-size: 9px;
  color: var(--accent);
  letter-spacing: 0.05em;
}
.toc-floating .title {
  font-family: var(--font-display);
  font-size: 16px;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 360px;
}
.toc-floating .arrow {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.1em;
  margin-left: 4px;
}

.toc-modal {
  position: fixed;
  left: 50%;
  bottom: 88px;
  transform: translateX(-50%);
  width: min(640px, 92vw);
  background: var(--bg-1);
  border: 1px solid var(--accent);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6), 0 0 30px var(--accent-glow);
  z-index: 1199;
  display: none;
}
.toc-modal.is-open { display: block; }
.toc-modal__head {
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.toc-modal__head .pixel { font-size: 10px; color: var(--accent); letter-spacing: 0.05em; }
.toc-modal__head button {
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--fg-1);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 4px 10px;
}
.toc-modal__list { list-style: none; margin: 0; padding: 8px 0; }
.toc-modal__list button {
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  border-left: 3px solid transparent;
  color: var(--fg-0);
  padding: 14px 18px;
  cursor: pointer;
  display: flex;
  align-items: baseline;
  gap: 14px;
  font-family: var(--font-display);
  font-size: 15px;
  text-transform: uppercase;
}
.toc-modal__list button.is-active {
  background: var(--accent-soft);
  border-left-color: var(--accent);
  color: var(--accent);
}
.toc-modal__list button:hover:not(.is-active) { background: var(--bg-2); }

.toc-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(4px);
  z-index: 1198;
  display: none;
}
.toc-backdrop.is-open { display: block; }


/* ==========================================================================
 * 17. SINGLE — GALERIA + SHARE + AUTOR + RELACIONADAS
 * ========================================================================== */

.gallery {
  margin: 40px 0;
}
.gallery__head {
  font-family: var(--font-pixel);
  font-size: 9px;
  color: var(--accent);
  letter-spacing: 0.08em;
  margin-bottom: 12px;
}
.gallery__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.gallery__grid button {
  padding: 0;
  border: 1px solid var(--line-strong);
  background: transparent;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 10;
}
.gallery__grid button:hover { border-color: var(--accent); }
.gallery__grid .thumb { width: 100%; height: 100%; }
.gallery__grid .num {
  position: absolute;
  bottom: 8px;
  right: 8px;
  background: var(--bg-0);
  color: var(--fg-1);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  padding: 2px 6px;
  border: 1px solid var(--accent);
}

.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.92);
  z-index: 1300;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 40px;
  cursor: zoom-out;
}
.lightbox.is-open { display: flex; }
.lightbox__inner {
  max-width: 1100px;
  width: 100%;
  cursor: default;
}
.lightbox__image {
  aspect-ratio: 16 / 9;
  background: var(--bg-2);
}
.lightbox__bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 4px;
}
.lightbox__bar .caption {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-1);
  letter-spacing: 0.1em;
}
.lightbox__bar .controls { display: flex; gap: 8px; }

.review-box {
  position: relative;
  margin: 132px 0 44px;
  padding: 104px 36px 38px;
  border: 1px solid var(--line-strong);
  background:
    radial-gradient(circle at 50% 0%, rgba(255,174,43,.18), transparent 28%),
    linear-gradient(135deg, rgba(255,174,43,.08), transparent 42%),
    var(--bg-1);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02), 0 0 24px rgba(255,174,43,.08);
  overflow: visible;
}
.review-box::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--neon-cyan), var(--accent), #ff2f5f, var(--neon-lime));
}
.review-box__score {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -42%);
  display: grid;
  justify-items: center;
}
.review-box__emoji {
  width: 138px;
  height: 138px;
  display: grid;
  place-items: center;
  border: 9px solid var(--fg-0);
  border-radius: 50%;
  background: var(--accent);
  font-size: 78px;
  line-height: 1;
  box-shadow: 0 0 36px rgba(255,174,43,.48), 0 0 80px rgba(255,174,43,.16);
}
.review-box__number {
  margin-top: -12px;
  padding: 9px 16px 11px;
  background: var(--accent);
  color: #0a0814;
  font-family: var(--font-display);
  line-height: 1;
  box-shadow: 4px 4px 0 var(--accent-deep);
}
.review-box__number strong {
  font-size: 48px;
  color: inherit;
}
.review-box__number span {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
}
.review-box__content {
  text-align: center;
}
.review-box__kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 12px 0 0;
  padding: 5px 10px;
  border: 1px solid var(--line-strong);
  background: rgba(255,174,43,.08);
  color: var(--accent);
  font-size: 10px;
  letter-spacing: 0.12em;
}
.review-box h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(42px, 8vw, 76px);
  line-height: .92;
  color: var(--fg-0);
  text-transform: uppercase;
  text-shadow: 3px 3px 0 var(--accent), -3px -3px 0 var(--neon-cyan);
}
.review-box__summary {
  max-width: 680px;
  margin: 22px auto 0;
  color: var(--fg-1);
  font-size: 18px;
  line-height: 1.55;
}
.review-box__columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
  margin-top: 44px;
  text-align: left;
}
.review-box__panel {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  padding: 30px 24px 24px;
  position: relative;
}
.review-box__panel h3 {
  position: absolute;
  left: 24px;
  top: 0;
  transform: translateY(-50%);
  margin: 0;
  min-width: 112px;
  padding: 9px 18px;
  background: var(--accent);
  color: #0a0814;
  font-family: var(--font-pixel);
  font-size: 10px;
  text-align: center;
}
.review-box__panel--pros h3 { background: var(--neon-lime); }
.review-box__panel--cons h3 { background: #ff4d68; color: var(--fg-0); }
.review-box__panel ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.review-box__panel li {
  position: relative;
  padding-left: 18px;
  margin: 10px 0;
  color: var(--fg-1);
  line-height: 1.45;
}
.review-box__panel li::before {
  content: '◆';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
  font-size: 10px;
}
.review-box__panel--pros li::before { color: var(--neon-lime); }
.review-box__panel--cons li::before { color: #ff4d68; }
.review-box__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  margin-top: 34px;
  padding: 0 28px;
  border: 1px solid rgba(255,255,255,.34);
  background:
    linear-gradient(110deg, transparent 0%, rgba(255,255,255,.72) 18%, transparent 34%) -160px 0 / 140px 100% no-repeat,
    linear-gradient(135deg, #ff8a00 0%, var(--accent) 42%, #ffe27a 64%, #ff3d8b 100%);
  color: #0a0814;
  font-family: var(--font-pixel);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  box-shadow: 5px 5px 0 var(--accent-deep), 0 0 26px rgba(255,174,43,.34);
  animation: reviewCtaPulse 1.75s ease-in-out infinite;
  transition: transform .16s, box-shadow .16s, background-position .45s;
}
.review-box__cta:hover {
  transform: translate(-1px, -1px);
  background-position: 170% 0, 0 0;
  box-shadow: 7px 7px 0 var(--accent-deep), 0 0 38px rgba(255,174,43,.52);
}
@keyframes reviewCtaPulse {
  0%, 100% {
    transform: translateY(0) scale(1);
    box-shadow: 5px 5px 0 var(--accent-deep), 0 0 22px rgba(255,174,43,.32);
  }
  50% {
    transform: translateY(-1px) scale(1.035);
    box-shadow: 6px 6px 0 var(--accent-deep), 0 0 42px rgba(255,174,43,.62);
  }
}

.share-bar {
  position: relative;
  z-index: 3;
  margin: 64px 0 32px;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
  padding: 28px 24px;
  pointer-events: auto;
}
.share-bar__head {
  font-family: var(--font-pixel);
  font-size: 11px;
  color: var(--accent);
  letter-spacing: 0.06em;
  margin-bottom: 16px;
}
.share-bar__buttons {
  position: relative;
  z-index: 4;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.share-bar__buttons a,
.share-bar__buttons button {
  position: relative;
  z-index: 5;
  pointer-events: auto;
}
.share-bar__count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: 0.12em;
}
.share-bar__buttons .glyph { font-size: 13px; }
.share-bar__buttons .glyph.x         { color: #ffffff; }
.share-bar__buttons .glyph.facebook  { color: var(--neon-cyan); }
.share-bar__buttons .glyph.whatsapp  { color: var(--neon-lime); }
.share-bar__buttons .glyph.telegram  { color: var(--neon-cyan); }
.share-bar__buttons .glyph.reddit    { color: #ff7a18; }

.tags-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 32px 0;
}
.tags-row a {
  padding: 6px 12px;
  border: 1px solid var(--line-strong);
  background: var(--bg-1);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--fg-1);
  text-decoration: none;
  text-transform: lowercase;
  transition: all .15s;
}
.tags-row a:hover { border-color: var(--accent); color: var(--accent); }

.author-bio {
  margin: 48px 0;
  border: 1px solid var(--accent);
  background: var(--bg-1);
  padding: 28px 24px;
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 20px;
  align-items: start;
}
.author-bio__avatar {
  width: 88px;
  height: 88px;
  background: oklch(0.55 0.18 220);
  border: 2px solid var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-pixel);
  font-size: 22px;
  color: #0a0814;
  box-shadow: 4px 4px 0 var(--accent-deep);
  overflow: hidden;
}
.author-bio__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.author-bio__kicker {
  font-family: var(--font-pixel);
  font-size: 9px;
  color: var(--accent);
  letter-spacing: 0.05em;
  margin-bottom: 8px;
}
.author-bio h3 { margin: 0 0 4px; font-size: 26px; }
.author-bio__role {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: 0.1em;
  margin-bottom: 12px;
}
.author-bio__text {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.6;
  color: var(--fg-1);
}
.author-bio__actions { display: flex; gap: 8px; margin-top: 14px; }

.related {
  padding: 60px 0;
  border-top: 1px solid var(--line);
}
.related__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 28px;
}
.related__card {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--line);
  background: var(--bg-1);
  transition: transform .2s, border-color .2s;
}
.related__card:hover {
  transform: translateY(-3px);
  border-color: var(--accent);
}
.related__card:hover .related__card__thumb img {
  filter: saturate(1.28) contrast(1.14);
}
.related__card__thumb {
  position: relative;
  aspect-ratio: 5 / 3;
  overflow: hidden;
}
.related__card__thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.145) 0 7px, transparent 7px 14px),
    repeating-linear-gradient(to bottom, rgba(255,255,255,0.11) 0 1px, rgba(8,7,13,0.085) 1px 2px, transparent 2px 4px),
    radial-gradient(circle at 50% 45%, rgba(255,118,25,0.18), transparent 58%),
    linear-gradient(to bottom, rgba(8,7,13,0.06) 20%, rgba(8,7,13,0.48) 100%);
  mix-blend-mode: overlay;
  opacity: 1;
  z-index: 1;
}
.related__card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.16) contrast(1.08);
  transition: filter .2s, transform .2s;
}
.related__card__thumb .badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  border: none;
  color: #0a0814;
  font-weight: 800;
  letter-spacing: 0.16em;
}
.related__card__thumb .badge.is-trailer  { background: var(--neon-pink); }
.related__card__thumb .badge.is-review   { background: var(--neon-cyan); }
.related__card__thumb .badge.is-esports  { background: var(--neon-violet); }
.related__card__thumb .badge.is-indie    { background: var(--neon-lime); }
.related__card__thumb .badge.is-guia     { background: var(--neon-lime); }
.related__card__thumb .badge.is-noticia  { background: var(--accent); }
.related__card__thumb .badge.is-opiniao  { background: var(--neon-violet); }
.related__card__thumb .badge.is-breaking { background: var(--accent); }
.related__card__thumb .badge.is-exclusivo { background: var(--neon-lime); }
.related__card__thumb .badge.is-hot      { background: var(--hot); }
.related__card__body { padding: 16px 16px 18px; }
.related__card__body h3 {
  font-size: 18px;
  line-height: 1.1;
  margin: 0;
}
.related__card__body .meta {
  margin-top: 12px;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--fg-3);
  letter-spacing: 0.12em;
}


/* ==========================================================================
 * 18. RESPONSIVO
 * ========================================================================== */

@media (max-width: 1080px) {
  .hero__title { font-size: 37px; }
  .hero__grid { grid-template-columns: 1fr; }
  .hero__visual { aspect-ratio: 16 / 9; }
  .shorts__grid { grid-template-columns: repeat(3, 1fr); }
  .related__grid { grid-template-columns: repeat(2, 1fr); }
  .mosaic__grid { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .container { padding: 0 20px; }
  .site-header {
    border-bottom: 0;
    padding-top: 58px;
  }
  .site-header__bar,
  .site-categories {
    display: none !important;
  }
  .site-sticky {
    transform: translateY(0);
    border-top: 2px solid var(--accent);
    border-bottom: 1px solid var(--accent);
    background: rgba(10, 8, 20, .98);
    overflow: visible;
    contain: none;
  }
  .site-sticky.is-visible {
    transform: translateY(0);
  }
  .site-sticky::after {
    content: '';
    position: fixed;
    inset: 0;
    z-index: 9000;
    background: rgba(0,0,0,.62);
    opacity: 0;
    pointer-events: none;
    transition: opacity .22s ease;
  }
  .site-sticky.is-menu-open::after {
    opacity: 1;
    pointer-events: auto;
  }
  .site-sticky__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    min-height: 56px;
    padding-top: 9px;
    padding-bottom: 9px;
    position: relative;
    z-index: 9002;
  }
  .site-sticky__logo {
    min-width: 0;
    overflow: hidden;
  }
  .site-sticky__logo .site-logo__image {
    max-width: 156px;
    max-height: 28px;
  }
  .site-sticky__nav {
    display: none !important;
  }
  .site-sticky__actions {
    grid-column: 2;
    grid-row: 1;
    justify-content: flex-end;
    gap: 6px;
    min-width: 0;
    position: relative;
    z-index: 9004;
  }
  .site-sticky__toggle {
    display: inline-flex;
    flex: 0 0 36px;
    width: 36px;
    height: 34px;
  }
  .site-sticky__actions [data-search-toggle] {
    display: none;
  }
  .site-sticky__actions .cta-primary {
    display: none;
  }
  .ticker {
    position: relative;
    z-index: 1;
    padding: 7px 0;
    box-shadow: none;
  }
  .site-sticky-drawer {
    position: fixed;
    top: 0;
    left: 0;
    right: auto;
    bottom: 0;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    width: min(330px, 88vw);
    height: 100vh;
    max-height: 100vh;
    padding: 18px 18px 22px;
    overflow-y: auto;
    overflow-x: visible;
    background:
      linear-gradient(180deg, rgba(255,174,43,.16), transparent 190px),
      #0c0a16;
    border-right: 1px solid var(--accent);
    box-shadow: 18px 0 44px rgba(0,0,0,.55);
    transform: translateX(-105%);
    transition: transform .28s ease;
  }
  .site-sticky.is-menu-open .site-sticky-drawer {
    transform: translateX(0);
  }
  .site-sticky-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--line-strong);
  }
  .site-sticky-drawer__logo .site-logo__image {
    max-width: 160px;
    max-height: 32px;
  }
  .site-sticky-drawer__close {
    width: 38px;
    height: 38px;
    border: 1px solid var(--accent);
    background: transparent;
    color: var(--accent);
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
  }
  .site-sticky-drawer__search {
    display: flex;
    margin: 18px 0;
  }
  .site-sticky-drawer__search input {
    min-width: 0;
    flex: 1;
    border: 1px solid var(--line-strong);
    border-right: 0;
    background: var(--bg-0);
    color: var(--fg-0);
    padding: 12px;
    font: 11px var(--font-mono);
  }
  .site-sticky-drawer__search button {
    border: 0;
    background: var(--accent);
    color: #0a0814;
    padding: 0 12px;
    font-family: var(--font-pixel);
    font-size: 9px;
    cursor: pointer;
  }
  .site-sticky-drawer__nav {
    display: grid;
    gap: 0;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
  }
  .site-sticky-drawer__nav li {
    list-style: none;
  }
  .site-sticky-drawer__nav a {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 13px 0;
    border-bottom: 1px solid var(--line);
    color: var(--fg-1);
    text-decoration: none;
  }
  .site-sticky-drawer__nav .menu-item-has-children > a::after {
    content: '▾';
    color: var(--accent);
    transition: transform .2s;
  }
  .site-sticky-drawer__nav .menu-item-has-children.is-submenu-open > a::after {
    transform: rotate(180deg);
  }
  .site-sticky-drawer__nav .sub-menu {
    max-height: 0;
    overflow: hidden;
    padding-left: 14px;
    opacity: 0;
    transition: max-height .24s ease, opacity .18s ease;
  }
  .site-sticky-drawer__nav .menu-item-has-children.is-submenu-open > .sub-menu {
    max-height: 460px;
    opacity: 1;
  }
  .site-sticky-drawer__nav .sub-menu a {
    padding: 9px 0;
    border-bottom: 0;
    color: var(--fg-3);
    font-size: 10px;
  }
  .site-sticky-drawer__socials {
    display: grid;
    grid-template-columns: repeat(6, 34px);
    gap: 8px;
    margin-top: 22px;
    padding-top: 18px;
    border-top: 1px solid var(--line-strong);
  }
  .site-sticky-drawer__socials a,
  .site-sticky-drawer__socials .glyph {
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    text-decoration: none;
  }
  .site-sticky-drawer__socials .glyph {
    color: #0a0814;
    font-family: var(--font-pixel);
    font-size: 12px;
  }
  .site-sticky-drawer__socials .youtube { background: #ff3d3d; }
  .site-sticky-drawer__socials .x { background: #fff; }
  .site-sticky-drawer__socials .instagram { background: #ff3d8b; }
  .site-sticky-drawer__socials .tiktok { background: #4fd6ff; }
  .site-sticky-drawer__socials .facebook { background: #1877f2; color: #fff; }
  .site-sticky-drawer__subscribe {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    margin-top: 20px;
    background: var(--accent);
    color: #0a0814;
    font-family: var(--font-pixel);
    font-size: 11px;
    letter-spacing: .08em;
    text-decoration: none;
    box-shadow: 4px 4px 0 var(--accent-deep);
  }
  .search-panel {
    top: 72px;
    width: min(560px, calc(100vw - 32px));
  }
  .hero { padding: 28px 0 0; }
  .breadcrumb { padding-top: 28px; }
  .hero__title { font-size: 27px; }
  .calendar-page { padding: 34px 0 54px; }
  .calendar-head {
    align-items: flex-start;
    flex-direction: column;
    gap: 18px;
  }
  .calendar-head h1 { font-size: 32px; }
  .calendar-head__actions { width: 100%; }
  .calendar-btn { flex: 1; }
  .calendar-filters { margin-top: 14px; }
  .calendar-titlebar { margin: 24px 0 14px; }
  .calendar-grid { display: none; }
  .calendar-list {
    display: grid;
    gap: 18px;
  }
  .calendar-list__day {
    border-top: 1px solid var(--accent);
    padding-top: 14px;
  }
  .calendar-list__day h2 {
    margin: 0 0 12px;
    font-family: var(--font-pixel);
    font-size: 12px;
    color: var(--accent);
  }
  .calendar-list__items {
    display: grid;
    gap: 10px;
  }
  .calendar-list__item {
    grid-template-columns: 96px 1fr;
    align-items: start;
  }
  .calendar-list__item img {
    width: 96px;
    height: 72px;
  }
  .release-hero {
    grid-template-columns: 1fr;
    gap: 20px;
    padding-top: 24px;
  }
  .release-hero__lead h1 {
    font-size: 34px;
    overflow-wrap: anywhere;
  }
  .release-sidebar__sticky {
    position: static;
  }
  .mosaic { padding: 40px 0; }
  .mosaic__big__caption h2 { font-size: 22px; }
  .mosaic__item { grid-template-columns: 110px 1fr; }
  .feed__item { grid-template-columns: 1fr; gap: 10px; padding: 16px 0; }
  .feed__item__time { padding-top: 0; }
  .feed__item__thumb { aspect-ratio: 16 / 9; }
  .feed__item__author { text-align: left; padding-top: 0; }
  .feed__item__title { font-size: 18px; }
  .archive-head {
    align-items: flex-start;
    flex-direction: column;
  }
  .archive-search,
  .error-search {
    flex-direction: column;
  }
  .archive-search input,
  .error-search input {
    border-right: 1px solid var(--line-strong);
    margin-bottom: 8px;
  }
  .upcoming-releases__grid {
    grid-template-columns: 1fr;
  }
  .shorts { padding: 48px 0; }
  .shorts__grid { grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 24px; margin-bottom: 24px; }
  .newsletter { padding: 56px 0; }
  .newsletter__inner {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 24px;
    overflow: hidden;
  }
  .newsletter__title { font-size: 28px; }
  .newsletter__form { width: 100%; }
  .newsletter__form input {
    width: 100%;
    padding: 12px;
    font-size: 12px;
  }
  .newsletter__form button {
    min-width: 60px;
    padding: 0 14px;
  }
  .newsletter__bar {
    flex-wrap: wrap;
    row-gap: 8px;
    min-width: 0;
  }
  .newsletter__bar .count {
    flex-basis: 100%;
    margin-left: 0;
    font-size: 8px;
  }
  .layout-2col { grid-template-columns: 1fr; gap: 40px; }
  .article-layout { grid-template-columns: 1fr; gap: 40px; }
  .aside-home,
  .aside-single,
  .aside-home > .mpl-ad-code--home_sidebar,
  .aside-single > .ad-slot--medium,
  .aside-single > .mpl-ad-code--sidebar_single {
    position: static;
  }
  .breadcrumb nav { flex-wrap: wrap; }
  .article-hero h1 { font-size: clamp(27px, 8vw, 38px); overflow-wrap: anywhere; }
  .article-hero__image { aspect-ratio: 4 / 3; }
  .article-hero__lede { font-size: 18px; }
  .meta-bar__inner { padding: 14px 20px; }
  .article-wrap { padding: 36px 0 20px; }
  .article-layout,
  .article-main,
  .article-body {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }
  .article-body h2 { font-size: 32px; margin: 40px 0 16px; }
  .article-body p, .article-body ul, .article-body ol { font-size: calc(17px * var(--read-scale)); }
  .article-body .pull { font-size: calc(24px * var(--read-scale)); padding-left: 16px; margin: 32px 0; }
  .article-body .wp-block-gallery,
  .article-body ul.wp-block-gallery,
  .article-body .blocks-gallery-grid,
  .article-body .gallery[class*="gallery-columns-"] {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .article-body .dropcap::first-letter {
    font-size: 2.7em;
    margin-right: 10px;
  }
  .review-box {
    margin-top: 124px;
    padding: 88px 18px 28px;
  }
  .review-box__emoji {
    width: 108px;
    height: 108px;
    font-size: 58px;
    border-width: 6px;
  }
  .review-box__number strong { font-size: 38px; }
  .review-box h2 {
    font-size: clamp(34px, 14vw, 52px);
    text-shadow: 2px 2px 0 var(--accent), -2px -2px 0 var(--neon-cyan);
  }
  .review-box__summary { font-size: 16px; }
  .review-box__columns {
    grid-template-columns: 1fr;
    gap: 34px;
  }
  .related__grid { grid-template-columns: 1fr; }
  .author-bio { grid-template-columns: 1fr; }
  .author-bio__avatar { width: 64px; height: 64px; font-size: 16px; }
  .ad-slot--leaderboard { height: 120px; }
  .toc-floating { left: 12px; right: 12px; width: auto; transform: none; max-width: calc(100vw - 24px); gap: 10px; padding: 10px 12px; }
  .toc-floating:hover { transform: none; }
  .toc-floating .title { flex: 1; min-width: 0; font-size: 13px; max-width: none; }
  .toc-modal { left: 12px; right: 12px; bottom: 76px; width: auto; transform: none; }
  .toc-modal__list button {
    font-size: 9px;
    line-height: 1.25;
    padding: 12px 14px;
    gap: 10px;
  }
  .toc-modal__list .num {
    font-size: 7px;
    min-width: 26px;
  }
}

@media (max-width: 520px) {
  .site-logo__name { font-size: 12px; }
  .site-header__actions { width: 100%; justify-content: flex-end; }
  .site-header__actions .cta-ghost,
  .site-header__actions .cta-primary { font-size: 10px; padding: 8px 12px !important; }
  .newsletter__inner { padding: 24px 20px; }
  .newsletter__title { font-size: 26px; overflow-wrap: anywhere; }
  .toc-floating { left: 10px; right: 10px; max-width: calc(100vw - 20px); }
  .toc-floating .kicker { font-size: 8px; }
  .toc-floating .dot,
  .toc-floating .arrow { flex: 0 0 auto; }
  .article-hero h1 { font-size: clamp(24px, 9.6vw, 32px); }
}


/* ==========================================================================
 * Animations
 * ========================================================================== */

@keyframes mp-marq    { from { transform: translateX(0) } to { transform: translateX(-50%) } }
@keyframes mp-progress { from { width: 0% } to { width: 100% } }
@keyframes mp-fade-up  { from { opacity: 0; transform: translateY(8px) } to { opacity: 1; transform: translateY(0) } }
