/*
Theme Name: Oponente
Theme URI: https://oponente.com.br
Author: Oponente Mídia
Description: Portal de jornalismo analítico brasileiro. Tema de blocos (FSE) com CPTs para Análise e Opinião, responsivo desktop e mobile.
Version: 1.1.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
Text Domain: oponente
*/

/* ════════════════════════════════════════════════
   TOKENS
   ════════════════════════════════════════════════ */
:root {
  --verde:   #0F5239;
  --verde-d: #0A3A28;
  --ambar:   #C58A1F;
  --brasa:   #D62A36;
  --tinta:   #111110;
  --tinta-2: #2A2A28;
  --papel:   #FFFFFF;
  --papel-2: #F7F6F1;
  --cinza:   #8A8A88;
  --cinza-d: #4A4A48;
  --linha:   #ECEAE3;
  --linha-d: #D8D5CB;

  --display: "Archivo", "Helvetica Neue", Arial, sans-serif;
  --serif:   "Instrument Serif", "Times New Roman", Georgia, serif;
  --sans:    "Public Sans", -apple-system, system-ui, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, Menlo, monospace;

  --maxw:   1240px;
  --gutter: 32px;
}

/* ── RESET ─────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--papel); color: var(--tinta); }
body {
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
h1, h2, h3, h4, h5, h6 { margin: 0; }
p { margin: 0; }
ul { margin: 0; padding: 0; list-style: none; }

/* Admin bar offset */
.admin-bar .mainnav { top: 32px; }
@media (max-width: 782px) { .admin-bar .mainnav { top: 46px; } }

/* ── HELPERS ────────────────────────────────────── */
.shell { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }

.cat {
  font-family: var(--mono); font-weight: 700; font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--brasa);
  display: inline-block;
}
.cat.verde { color: var(--verde); }
.cat.ambar { color: var(--ambar); }
.cat.cinza { color: var(--cinza); }

.meta {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--cinza);
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
}
.meta .author { color: var(--tinta); font-weight: 700; }
.meta .sep    { color: var(--linha-d); }

/* Image placeholder gradients */
.img-bg-1 { background: linear-gradient(135deg, #1A1A18, #4A4A48); }
.img-bg-2 { background: linear-gradient(135deg, #14463A, #0F5239); }
.img-bg-3 { background: linear-gradient(135deg, #C58A1F, #8A5E10); }
.img-bg-4 { background: linear-gradient(135deg, #4A4A48, #1A1A18); }
.img-bg-5 { background: linear-gradient(135deg, #2C2C28, #6B6862); }

/* ── PULSE ANIMATION ────────────────────────────── */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.3; }
}

/* ════════════════════════════════════════════════
   UTILITY RIBBON
   ════════════════════════════════════════════════ */
.util { background: var(--papel); border-bottom: 1px solid var(--linha); }
.util-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 9px var(--gutter);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--cinza);
}
.util .left  { display: flex; gap: 18px; align-items: center; }
.util .right { display: flex; gap: 16px; align-items: center; }
.util .right a { color: var(--tinta); }
.util .right a:hover { color: var(--verde); }
.util .left .live {
  color: var(--brasa); font-weight: 700;
  display: inline-flex; align-items: center; gap: 7px;
}
.util .left .live::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--brasa); animation: pulse 1.5s infinite;
}

/* ════════════════════════════════════════════════
   MASTHEAD
   ════════════════════════════════════════════════ */
.masthead { background: var(--papel); border-bottom: 1px solid var(--linha); }
.masthead-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 32px var(--gutter) 22px;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
}
.mh-left, .mh-right {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--cinza);
}
.mh-right { text-align: right; }
.mh-right .cta {
  background: var(--tinta); color: var(--papel);
  padding: 9px 14px; font-weight: 700; margin-left: 12px;
  display: inline-block;
}
.mh-right .cta:hover { background: var(--verde); }
.brand {
  font-family: var(--display); font-weight: 800;
  font-size: 56px; letter-spacing: -0.045em; line-height: 1;
  color: var(--tinta);
  text-align: center;
  display: inline-flex; align-items: baseline; gap: 3px;
}
.brand .accent {
  display: inline-block; width: 9px; height: 9px;
  background: var(--verde); margin-left: 2px;
}

/* ════════════════════════════════════════════════
   MAIN NAV
   ════════════════════════════════════════════════ */
.mainnav {
  background: var(--papel);
  border-bottom: 1px solid var(--tinta);
  position: sticky; top: 0; z-index: 50;
}
.mainnav-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex; align-items: center;
  overflow-x: auto; scrollbar-width: none;
}
.mainnav-inner::-webkit-scrollbar { height: 0; }
.mainnav a {
  padding: 14px 16px;
  font-family: var(--display); font-weight: 600; font-size: 13.5px;
  letter-spacing: 0.02em; color: var(--tinta); white-space: nowrap;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
}
.mainnav a:first-child { padding-left: 0; }
.mainnav a:hover  { color: var(--verde); }
.mainnav a.active { border-bottom-color: var(--tinta); }
.mainnav a.urgent {
  color: var(--brasa); margin-left: auto;
  display: inline-flex; align-items: center; gap: 7px;
}
.mainnav a.urgent::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--brasa); animation: pulse 1.5s infinite;
}
.ticker-mini {
  margin-left: 24px; padding-left: 24px;
  border-left: 1px solid var(--linha);
  display: flex; gap: 18px; align-items: center;
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--cinza);
  flex-shrink: 0;
}
.ticker-mini .v    { color: var(--tinta); font-weight: 700; }
.ticker-mini .up   { color: var(--verde); }
.ticker-mini .down { color: var(--brasa); }

/* ════════════════════════════════════════════════
   BREAKING
   ════════════════════════════════════════════════ */
.breaking { background: var(--papel); border-bottom: 1px solid var(--linha); }
.breaking-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 12px var(--gutter);
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 18px; align-items: center;
}
.breaking .tag {
  font-family: var(--mono); font-weight: 700; font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--brasa);
  padding: 4px 9px; border: 1px solid var(--brasa);
  display: inline-flex; align-items: center; gap: 7px; white-space: nowrap;
}
.breaking .tag::before {
  content: ""; width: 5px; height: 5px; border-radius: 50%;
  background: var(--brasa); animation: pulse 1.5s infinite;
}
.breaking .h {
  font-family: var(--display); font-weight: 600;
  font-size: 15px; line-height: 1.3; letter-spacing: -0.015em; color: var(--tinta);
}
.breaking .time {
  font-family: var(--mono); font-size: 10.5px;
  color: var(--cinza); letter-spacing: 0.1em; text-transform: uppercase; white-space: nowrap;
}

/* ════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════ */
.hero { padding: 32px 0 40px; border-bottom: 1px solid var(--linha); }
.hero-grid {
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 40px;
}

/* Lead */
.lead { display: grid; grid-template-rows: auto auto auto auto auto; gap: 14px; }
.lead .img {
  aspect-ratio: 16/9;
  background: linear-gradient(180deg, #14463A 0%, #0A2A20 100%);
  position: relative; overflow: hidden;
}
/* Filtro de linhas removido — fotos limpas */
.lead .img .credit {
  position: absolute; bottom: 8px; right: 10px;
  font-family: var(--mono); font-size: 9.5px;
  letter-spacing: 0.14em; color: rgba(255,255,255,0.55); text-transform: uppercase;
}
.lead .h {
  font-family: var(--display); font-weight: 700;
  font-size: 44px; line-height: 1.04; letter-spacing: -0.03em; color: var(--tinta);
  text-wrap: balance;
}
.lead .deck { font-family: var(--sans); font-size: 17px; line-height: 1.5; color: var(--cinza-d); }

/* Rail */
.rail { display: flex; flex-direction: column; padding-top: 2px; }
.rail .item {
  padding: 16px 0 18px; border-bottom: 1px solid var(--linha);
  display: grid; grid-template-columns: 1fr 88px; gap: 14px; align-items: start;
}
.rail .item:first-child { padding-top: 0; }
.rail .item:last-child  { border-bottom: none; padding-bottom: 0; }
.rail .item .thumb {
  aspect-ratio: 1; position: relative; overflow: hidden;
}
/* Filtro de linhas removido — fotos limpas */
.rail .item h3 {
  font-family: var(--display); font-weight: 600; font-size: 16.5px;
  line-height: 1.22; letter-spacing: -0.018em; margin: 6px 0 8px; color: var(--tinta);
}

/* ════════════════════════════════════════════════
   SECTION HEAD
   ════════════════════════════════════════════════ */
.sh {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 10px; border-bottom: 2px solid var(--tinta); margin-bottom: 20px;
}
.sh .t   { font-family: var(--display); font-weight: 800; font-size: 14px; letter-spacing: 0.06em; text-transform: uppercase; }
.sh .all { font-family: var(--mono); font-weight: 700; font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cinza); }
.sh .all:hover { color: var(--verde); }

section.block { padding: 40px 0 36px; border-bottom: 1px solid var(--linha); }

/* ════════════════════════════════════════════════
   A SEMANA EM ANÁLISE
   ════════════════════════════════════════════════ */
.analise-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 32px; }

.analise-feat .img {
  aspect-ratio: 16/9; margin-bottom: 14px; position: relative; overflow: hidden;
}
/* Filtro de linhas removido — fotos limpas */
.analise-feat .h {
  font-family: var(--display); font-weight: 700; font-size: 28px;
  line-height: 1.05; letter-spacing: -0.025em; margin: 8px 0 10px; color: var(--tinta);
}
.analise-feat .deck { font-size: 14.5px; color: var(--cinza-d); line-height: 1.5; margin: 0 0 12px; }
.analise-feat .credit {
  position: absolute; bottom: 8px; right: 10px;
  font-family: var(--mono); font-size: 9.5px;
  letter-spacing: 0.14em; color: rgba(255,255,255,0.55); text-transform: uppercase;
}

.analise-list { display: flex; flex-direction: column; }
.analise-list .it { padding: 14px 0; border-bottom: 1px solid var(--linha); }
.analise-list .it:first-child { padding-top: 0; }
.analise-list .it:last-child  { border-bottom: none; }
.analise-list .it h3 {
  font-family: var(--display); font-weight: 600; font-size: 16px;
  line-height: 1.22; letter-spacing: -0.018em; margin: 6px 0 6px; color: var(--tinta);
}

/* ════════════════════════════════════════════════
   PULL QUOTE
   ════════════════════════════════════════════════ */
.pull {
  background: var(--papel-2); padding: 56px 0;
  border-top: 1px solid var(--linha); border-bottom: 1px solid var(--linha);
}
.pull-inner { display: grid; grid-template-columns: 1fr 2fr; gap: 56px; align-items: center; }
.pull .label {
  font-family: var(--mono); font-weight: 700; font-size: 10.5px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--verde); margin-bottom: 14px;
}
.pull .who h4 { font-family: var(--display); font-weight: 700; font-size: 20px; letter-spacing: -0.018em; margin: 0 0 4px; }
.pull .who .role { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cinza); }
.pull .who .read {
  display: inline-flex; gap: 8px; align-items: center; margin-top: 16px;
  font-family: var(--mono); font-weight: 700; font-size: 10.5px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--verde);
}
.pull .quote {
  font-family: var(--serif); font-style: italic;
  font-size: 36px; line-height: 1.2; letter-spacing: -0.01em; color: var(--tinta);
  padding-left: 28px; border-left: 3px solid var(--verde); text-wrap: balance;
  margin: 0;
}

/* ════════════════════════════════════════════════
   POLÍTICA + ECONOMIA
   ════════════════════════════════════════════════ */
/* min-width:0 nos filhos de grid evita colapso de 1fr em contextos flex/grid aninhados */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; width: 100%; }
.two-col > * { min-width: 0; }

.col-block .col-head {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-top: 10px; padding-bottom: 8px; margin-bottom: 16px;
  border-top: 3px solid var(--verde); border-bottom: 1px solid var(--linha);
}
.col-block.econ .col-head { border-top-color: var(--ambar); }
.col-block .col-head .name { font-family: var(--display); font-weight: 800; font-size: 14px; letter-spacing: 0.06em; text-transform: uppercase; }
.col-block .col-head .all  { font-family: var(--mono); font-weight: 700; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cinza); }

.col-feat { padding-bottom: 18px; margin-bottom: 4px; border-bottom: 1px solid var(--linha); display: grid; grid-template-columns: 1fr; gap: 12px; }
.col-feat .img { aspect-ratio: 16/9; position: relative; overflow: hidden; }
/* Filtro de linhas removido — fotos limpas */
.col-feat h3 { font-family: var(--display); font-weight: 700; font-size: 22px; line-height: 1.1; letter-spacing: -0.024em; margin: 6px 0 8px; color: var(--tinta); }
.col-feat .deck { font-size: 14px; color: var(--cinza-d); line-height: 1.5; }

.col-list { display: flex; flex-direction: column; width: 100%; min-width: 0; }
.col-list .it {
  padding: 14px 0; border-bottom: 1px solid var(--linha);
  display: flex; flex-flow: row nowrap; align-items: baseline; gap: 12px;
}
.col-list .it:last-child { border-bottom: none; }
.col-list .it .n { font-family: var(--mono); font-weight: 700; color: var(--cinza); font-size: 11px; letter-spacing: 0.05em; flex-shrink: 0; width: 20px; }
.col-list .it > div { flex: 1 1 auto; min-width: 0; }
.col-list .it h4 { font-family: var(--display); font-weight: 600; font-size: 15px; line-height: 1.25; letter-spacing: -0.015em; margin: 0 0 5px; color: var(--tinta); }

/* ════════════════════════════════════════════════
   OPINIÃO
   ════════════════════════════════════════════════ */
.opinions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.opinion  { display: flex; flex-direction: column; gap: 10px; }
.opinion + .opinion { border-left: 1px solid var(--linha); padding-left: 28px; }
.opinion .head { display: flex; gap: 12px; align-items: center; padding-bottom: 12px; border-bottom: 1px solid var(--linha); }
.opinion .avatar { width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0; object-fit: cover; }
.opinion .avatar.a1 { background: linear-gradient(135deg, #4A4A48, #1A1A18); }
.opinion .avatar.a2 { background: linear-gradient(135deg, #C58A1F, #8A5E10); }
.opinion .avatar.a3 { background: linear-gradient(135deg, #0A3A28, #0F5239); }
.opinion .avatar.a4 { background: linear-gradient(135deg, #6B6862, #2C2C28); }
.opinion .who .name { font-family: var(--display); font-weight: 700; font-size: 14px; letter-spacing: -0.01em; }
.opinion .who .role { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cinza); margin-top: 2px; }
.opinion h3 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: 22px; line-height: 1.22; letter-spacing: -0.01em; color: var(--tinta); margin: 4px 0 8px; }
.opinion .read { margin-top: auto; font-family: var(--mono); font-weight: 700; font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--verde); }

/* ════════════════════════════════════════════════
   MAIS LIDAS + ÚLTIMAS
   ════════════════════════════════════════════════ */
.double { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; width: 100%; }
.double > * { min-width: 0; }
.ll .ll-head { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 8px; margin-bottom: 8px; border-bottom: 2px solid var(--tinta); }
.ll .ll-head .t    { font-family: var(--display); font-weight: 800; font-size: 14px; letter-spacing: 0.06em; text-transform: uppercase; }
.ll .ll-head .when { font-family: var(--mono); font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cinza); }
.ll .it {
  padding: 14px 0; border-bottom: 1px solid var(--linha);
  display: flex; flex-flow: row nowrap; align-items: baseline; gap: 12px;
}
.ll .it:last-child { border-bottom: none; }
.ll .it > div { flex: 1 1 auto; min-width: 0; }
.ll .it .rank { font-family: var(--display); font-weight: 800; font-size: 22px; line-height: 1; color: var(--cinza-d); letter-spacing: -0.04em; flex-shrink: 0; }
.ll.ult .it .rank  { font-family: var(--mono); font-size: 12px; color: var(--brasa); font-weight: 700; }
.ll .it h4 { font-family: var(--display); font-weight: 600; font-size: 15px; line-height: 1.25; letter-spacing: -0.015em; margin: 0 0 4px; color: var(--tinta); }
.ll .it .when { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--cinza); align-self: start; padding-top: 4px; white-space: nowrap; }

/* ════════════════════════════════════════════════
   NEWSLETTER
   ════════════════════════════════════════════════ */
.nl-section { padding: 56px 0; border-bottom: 1px solid var(--linha); background: var(--papel-2); }
.nl-inner {
  max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter);
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: center;
}
.nl-inner .text { border-left: 4px solid var(--verde); padding-left: 24px; }
.nl-inner .label { font-family: var(--mono); font-weight: 700; font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--verde); margin-bottom: 10px; }
.nl-inner h2 { font-family: var(--display); font-weight: 700; font-size: 36px; line-height: 1.05; letter-spacing: -0.025em; margin: 0 0 12px; color: var(--tinta); }
.nl-inner p  { font-family: var(--sans); font-size: 16px; line-height: 1.5; color: var(--cinza-d); }

.nl-form { background: var(--papel); border: 1px solid var(--linha-d); padding: 24px; }
.nl-form .ed { font-family: var(--mono); font-weight: 700; font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cinza); margin-bottom: 8px; }
.nl-form h3  { font-family: var(--display); font-weight: 700; font-size: 20px; letter-spacing: -0.02em; line-height: 1.15; color: var(--tinta); margin: 0 0 16px; }
.nl-form .input-row { display: flex; }
.nl-form input {
  flex: 1; font-family: var(--sans); font-size: 14px;
  padding: 12px 14px; border: 1px solid var(--linha-d); border-right: none;
  background: var(--papel); color: var(--tinta); outline: none; min-width: 0;
}
.nl-form input::placeholder { color: var(--cinza); }
.nl-form button {
  font-family: var(--mono); font-weight: 700; font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 12px 18px; background: var(--tinta); color: var(--papel); border: none; cursor: pointer;
}
.nl-form button:hover { background: var(--verde); }
.nl-form .small { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; color: var(--cinza); margin-top: 10px; text-transform: uppercase; }
.nl-form .small a { color: var(--tinta); text-decoration: underline; }

/* ════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════ */
footer.site { background: var(--papel); padding: 48px 0 28px; }
.foot-grid {
  max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter);
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 40px;
  padding-bottom: 32px; border-bottom: 1px solid var(--linha);
}
.foot-grid .brand-block .brand { font-size: 36px; }
.foot-grid .brand-block .deck-foot { font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.35; color: var(--cinza-d); margin: 14px 0 0; max-width: 320px; }
.foot-col h5 { font-family: var(--mono); font-weight: 700; font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cinza); margin: 0 0 14px; }
.foot-col ul { list-style: none; padding: 0; margin: 0; }
.foot-col li { padding: 5px 0; font-family: var(--display); font-weight: 500; font-size: 14px; letter-spacing: -0.005em; }
.foot-col li a:hover { color: var(--verde); }
.foot-bottom {
  max-width: var(--maxw); margin: 0 auto;
  padding: 22px var(--gutter) 0;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cinza);
}
.foot-bottom .left { display: flex; gap: 20px; align-items: center; }
.foot-bottom a { color: var(--cinza); }
.foot-bottom a:hover { color: var(--tinta); }

/* ════════════════════════════════════════════════
   TAB BAR (mobile — oculto no desktop)
   ════════════════════════════════════════════════ */
.mobile-tabbar { display: none; }

/* ════════════════════════════════════════════════
   BARRA DE PROGRESSO DE LEITURA
   ════════════════════════════════════════════════ */
.read-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px;
  background: var(--linha); z-index: 9999; pointer-events: none;
}
.read-progress-bar {
  height: 100%; width: 0%; background: var(--verde);
  transition: width .1s linear;
}

/* ════════════════════════════════════════════════
   SINGLE POST — LAYOUT
   ════════════════════════════════════════════════ */
.single-main { padding-top: 0; }

/* Outer wrappers que centralizam o texto em 720px */
.article-header-outer,
.article-body-outer,
.article-comments-outer {
  padding: 0 var(--gutter);
}

/* ── Cabeçalho ── */
.article-header { max-width: 720px; margin: 44px auto 0; }
/* Garante que o wp-block-shortcode dentro do header não vire block 100% */
.article-header .wp-block-shortcode { display: block; width: 100%; }

.article-kicker {
  display: flex !important; gap: 10px; align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}

.reading-time {
  display: inline-flex !important; align-items: center; gap: 5px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase; color: var(--cinza);
  white-space: nowrap;
}
.reading-time svg { display: inline !important; flex-shrink: 0; vertical-align: middle; }

.article-title {
  font-family: var(--display); font-weight: 800;
  font-size: 44px; line-height: 1.04; letter-spacing: -0.035em;
  color: var(--tinta); margin-bottom: 20px;
  text-wrap: balance;
}

.article-deck {
  font-family: var(--sans); font-size: 20px; line-height: 1.5;
  color: var(--cinza-d); margin-bottom: 24px;
  border-left: 3px solid var(--verde); padding-left: 16px;
}

/* Meta: autor + data */
.article-meta {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px;
  padding: 14px 0; border-top: 1px solid var(--linha); border-bottom: 1px solid var(--linha);
  margin-bottom: 20px;
}
.author-meta { display: flex; align-items: center; gap: 10px; }
.author-meta .wp-block-post-author { display: flex; align-items: center; gap: 10px; }
.author-meta .wp-block-post-author__avatar img,
.author-meta img { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; }
.author-meta .wp-block-post-author__name,
.author-meta .wp-block-post-author__byline { font-family: var(--sans); font-size: 14px; font-weight: 600; }
.date-meta { font-family: var(--mono); font-size: 11px; color: var(--cinza); letter-spacing: .06em; text-transform: uppercase; }

/* ── Imagem destaque — wide (1240px) ── */
.article-featured { margin: 32px 0 0; width: 100%; }
.article-featured img,
.article-featured figure img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; }
.article-featured figcaption,
.article-featured .wp-element-caption {
  font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--cinza); padding: 8px var(--gutter) 0; text-align: right;
  max-width: var(--maxw); margin: 0 auto;
}

/* ── Crédito da imagem destaque ── */
.image-credit {
  font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--cinza); text-align: right;
  max-width: var(--maxw); margin: 6px auto 0; padding: 0 var(--gutter);
}
.image-credit::before { content: "© "; opacity: .6; }

/* ── Corpo do artigo ── */
.article-body-outer { padding-top: 40px; }
.article-body {
  font-family: var(--sans); font-size: 18px; line-height: 1.75; color: var(--tinta-2);
  max-width: 720px; margin: 0 auto;
}
.article-body p { margin-bottom: 1.5em; }
.article-body h2 {
  font-family: var(--display); font-weight: 700; font-size: 28px;
  margin: 2.2em 0 .7em; letter-spacing: -0.022em; color: var(--tinta);
}
.article-body h3 {
  font-family: var(--display); font-weight: 600; font-size: 22px;
  margin: 2em 0 .5em; letter-spacing: -0.018em;
}
.article-body blockquote {
  font-family: var(--serif); font-style: italic; font-size: 26px; line-height: 1.35;
  border-left: 3px solid var(--verde); padding-left: 22px; margin: 2.2em 0;
  color: var(--tinta);
}
.article-body a { color: var(--verde); text-decoration: underline; text-underline-offset: 3px; }
.article-body a:hover { color: var(--verde-d); }
.article-body ul, .article-body ol { padding-left: 1.6em; margin-bottom: 1.4em; }
.article-body ul li, .article-body ol li { margin-bottom: .5em; line-height: 1.65; }
.article-body ul { list-style: disc; }
.article-body ol { list-style: decimal; }
.article-body strong { font-weight: 700; color: var(--tinta); }
.article-body figure { margin: 2em 0; }
.article-body figure img { width: 100%; display: block; }
.article-body figure figcaption {
  font-family: var(--mono); font-size: 11px; color: var(--cinza); margin-top: 6px;
  letter-spacing: .07em;
}

/* Drop cap — primeiro parágrafo */
.article-body > p:first-of-type::first-letter {
  font-family: var(--display); font-weight: 800; font-size: 4.2em; line-height: .8;
  float: left; margin: .06em .1em 0 0; color: var(--tinta);
}

/* Opinião: corpo em serif */
.opiniao-body { font-family: var(--serif); font-size: 20px; }
.opiniao-body > p:first-of-type::first-letter { font-family: var(--serif); }
.opiniao-body h2 { font-family: var(--serif); font-style: italic; font-weight: 400; font-size: 26px; }
.opiniao-title { font-family: var(--serif) !important; font-style: italic !important; font-weight: 400 !important; }

/* Autor de opinião no header */
.opiniao-author-header {
  display: flex; align-items: center; gap: 16px;
  padding: 16px 0; border-top: 1px solid var(--linha); margin-bottom: 20px;
}
.author-opiniao .wp-block-post-author { display: flex; align-items: center; gap: 12px; }
.author-opiniao .wp-block-post-author__avatar img { width: 56px; height: 56px; border-radius: 50%; }
.author-opiniao .wp-block-post-author__name { font-family: var(--display); font-weight: 700; font-size: 16px; }

/* ── Rodapé do artigo ── */
.article-footer {
  max-width: 720px; margin: 40px auto 0;
  padding-top: 32px; border-top: 1px solid var(--linha);
}

/* Tags */
.article-tags { margin-bottom: 24px; }
.article-tags .wp-block-post-terms a,
.tag-pills a {
  display: inline-block; font-family: var(--mono); font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase;
  background: var(--papel-2); border: 1px solid var(--linha-d);
  padding: 4px 10px; margin: 3px 4px 3px 0; color: var(--cinza-d);
  transition: all .15s;
}
.article-tags .wp-block-post-terms a::before,
.tag-pills a::before { content: '#'; margin-right: 2px; color: var(--cinza); }
.article-tags .wp-block-post-terms a:hover,
.tag-pills a:hover { background: var(--tinta); color: var(--papel); border-color: var(--tinta); }

/* ════════════════════════════════════════════════
   COMPARTILHAR
   ════════════════════════════════════════════════ */
.share-bar {
  display: flex !important;
  flex-flow: row wrap;
  align-items: center;
  gap: 8px;
  margin: 20px 0;
}
.share-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em;
  text-transform: uppercase; color: var(--cinza); margin-right: 4px;
  flex-shrink: 0;
}
.share-btn {
  display: inline-flex !important;
  flex-flow: row nowrap;
  align-items: center;
  gap: 6px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .07em; text-transform: uppercase;
  padding: 7px 13px; border: 1px solid var(--linha-d); background: transparent;
  cursor: pointer; color: var(--tinta-2); transition: all .15s; text-decoration: none;
  white-space: nowrap; line-height: 1; vertical-align: middle;
}
/* Garante que SVGs dentro dos botões não quebrem o layout horizontal */
.share-btn svg {
  display: inline !important;
  flex-shrink: 0;
  vertical-align: middle;
  pointer-events: none;
}
.share-btn:hover { background: var(--tinta); color: var(--papel); border-color: var(--tinta); }
.share-btn.share-whatsapp:hover { background: #25D366; border-color: #25D366; }
.share-btn.share-twitter:hover  { background: #000; border-color: #000; }
.share-btn.share-facebook:hover { background: #1877F2; border-color: #1877F2; }
.share-btn.copied { background: var(--verde); color: var(--papel); border-color: var(--verde); }

/* ── Share sticky lateral (desktop) ── */
.share-sticky {
  position: fixed; left: calc((100vw - var(--maxw)) / 2 - 56px); top: 50%;
  transform: translateY(-50%);
  display: flex !important; flex-direction: column; gap: 6px;
  z-index: 90;
}
.share-sticky-btn {
  display: flex !important; align-items: center; justify-content: center;
  width: 42px; height: 42px;
  background: var(--papel); border: 1px solid var(--linha-d);
  color: var(--tinta-2); cursor: pointer; transition: all .15s;
  text-decoration: none; line-height: 1;
}
.share-sticky-btn svg {
  display: inline !important;
  flex-shrink: 0;
  pointer-events: none;
}
.share-sticky-btn:hover { background: var(--tinta); color: var(--papel); border-color: var(--tinta); }
.share-sticky-btn.share-whatsapp:hover { background: #25D366; border-color: #25D366; }
.share-sticky-btn.share-twitter:hover  { background: #000; border-color: #000; }
.share-sticky-btn.share-facebook:hover { background: #1877F2; border-color: #1877F2; }

/* Oculta a sticky quando a viewport é menor que o conteúdo + espaço */
@media (max-width: 1360px) { .share-sticky { display: none !important; } }

/* ════════════════════════════════════════════════
   BOX DO AUTOR
   ════════════════════════════════════════════════ */
/* ── AUTHOR BOX — Redação Oponente ──────────────────── */
.author-box {
  display: flex; gap: 24px; align-items: flex-start;
  border-top: 3px solid var(--tinta);
  padding-top: 28px; margin: 40px 0 0;
}
.author-box-brand { flex-shrink: 0; }

/* Logo ou monograma */
.author-box-logo-img {
  width: 60px; height: 60px; border-radius: 12px;
  object-fit: cover; display: block;
}

/* Monograma circular (fallback quando não há logo) */
.author-box-monogram {
  width: 60px; height: 60px; border-radius: 50%;
  background: var(--tinta); color: var(--papel);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-weight: 900;
  font-size: 26px; letter-spacing: -0.04em;
  user-select: none;
}

.author-box-body { flex: 1; min-width: 0; }

.author-box-label {
  display: block;
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--verde); margin-bottom: 4px;
}
.author-box-name {
  display: block;
  font-family: var(--display); font-weight: 800; font-size: 19px;
  letter-spacing: -0.02em; color: var(--tinta);
  margin: 0 0 10px;
}
.author-box-bio {
  font-size: 14px; line-height: 1.65; color: var(--cinza-d);
  margin: 0 0 16px;
}

/* Social buttons */
.author-box-social {
  display: flex; flex-wrap: wrap; gap: 7px;
}
.author-box-social-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 13px;
  border: 1px solid var(--linha-d); border-radius: 3px;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase;
  color: var(--cinza-d); text-decoration: none;
  transition: border-color .15s, color .15s, background .15s;
  white-space: nowrap;
}
.author-box-social-btn:hover {
  border-color: var(--tinta); color: var(--tinta); background: var(--papel-2);
}
.author-box-social-btn svg {
  display: inline; width: 12px; height: 12px; flex-shrink: 0; vertical-align: middle;
}
/* Cor de hover específica por rede */
.author-box-social-twitter:hover   { border-color: #000; color: #000; }
.author-box-social-instagram:hover { border-color: #E1306C; color: #E1306C; }
.author-box-social-facebook:hover  { border-color: #1877F2; color: #1877F2; }
.author-box-social-youtube:hover   { border-color: #FF0000; color: #FF0000; }
.author-box-social-linkedin:hover  { border-color: #0A66C2; color: #0A66C2; }
.author-box-social-whatsapp:hover  { border-color: #25D366; color: #25D366; }

/* Opinião: mantém avatar do autor */
.author-box--opiniao { border-top-color: var(--verde); }
.author-box-avatar-link { flex-shrink: 0; }
.author-box-avatar { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; display: block; }
.author-box--extended .author-box-avatar { width: 80px; height: 80px; }
.author-box-specialty {
  display: block; font-family: var(--mono); font-size: 11px;
  color: var(--cinza); letter-spacing: .06em; margin-bottom: 8px;
}
.author-box-link {
  font-family: var(--mono); font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase; color: var(--verde); text-decoration: none;
}
.author-box-link:hover { text-decoration: underline; }

/* ════════════════════════════════════════════════
   POSTS RELACIONADOS
   ════════════════════════════════════════════════ */
.related-posts {
  background: var(--papel-2); border-top: 2px solid var(--tinta);
  padding: 40px 0; margin: 48px 0 0;
}
.related-posts-inner { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.related-posts-title {
  font-family: var(--mono); font-size: 11px; letter-spacing: .18em;
  text-transform: uppercase; color: var(--cinza); margin-bottom: 24px;
}
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

.related-card { display: flex; flex-direction: column; gap: 12px; }
.related-card-img { display: block; overflow: hidden; aspect-ratio: 16/9; }
.related-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.related-card-img:hover img { transform: scale(1.03); }
.related-card-body { display: flex; flex-direction: column; gap: 8px; flex: 1; }
.related-card-title {
  font-family: var(--display); font-weight: 600; font-size: 18px;
  line-height: 1.2; letter-spacing: -0.018em;
}
.related-card-title a { color: var(--tinta); }
.related-card-title a:hover { color: var(--verde); }
.related-card-meta {
  display: flex; gap: 10px; font-family: var(--mono); font-size: 11px;
  color: var(--cinza); letter-spacing: .05em; margin-top: auto;
}

/* ════════════════════════════════════════════════
   COMENTÁRIOS
   ════════════════════════════════════════════════ */
.article-comments-outer { padding-top: 0; padding-bottom: 64px; }
.wp-block-comments-title {
  font-family: var(--display); font-weight: 700; font-size: 22px;
  letter-spacing: -0.02em; margin: 32px 0 20px;
}
.wp-block-comment-author-name a { font-weight: 700; color: var(--tinta); font-size: 14px; }
.wp-block-comment-date { font-family: var(--mono); font-size: 11px; color: var(--cinza); }
.wp-block-comment-content p { font-size: 15px; line-height: 1.65; color: var(--tinta-2); margin-bottom: .8em; }
.wp-block-comment-reply-link a {
  font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--verde);
}
.wp-block-post-comments-form textarea,
.wp-block-post-comments-form input[type=text],
.wp-block-post-comments-form input[type=email],
.wp-block-post-comments-form input[type=url] {
  border: 1px solid var(--linha-d); padding: 10px 14px;
  font-family: var(--sans); font-size: 14px; width: 100%;
  background: var(--papel); color: var(--tinta);
}
.wp-block-post-comments-form input[type=submit] {
  background: var(--tinta); color: var(--papel);
  font-family: var(--mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  padding: 12px 22px; border: none; cursor: pointer;
}
.wp-block-post-comments-form input[type=submit]:hover { background: var(--verde); }

/* Archive / Index */
.archive-wrap { max-width: var(--maxw); margin: 0 auto; padding: 40px var(--gutter); }
.archive-title { font-family: var(--display); font-weight: 800; font-size: 32px; letter-spacing: -0.025em; border-bottom: 2px solid var(--tinta); padding-bottom: 12px; margin-bottom: 32px; }

/* O grid precisa estar no wp-block-post-template (ul) gerado pelo FSE,
   não no wp-block-query externo */
.archive-grid .wp-block-post-template {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.archive-grid .wp-block-post-template > li { min-width: 0; }

.archive-card .img { aspect-ratio: 16/9; margin-bottom: 14px; overflow: hidden; }
.archive-card .img img { width: 100%; height: 100%; object-fit: cover; }
.archive-card h2 { font-family: var(--display); font-weight: 600; font-size: 20px; line-height: 1.18; letter-spacing: -0.02em; margin: 8px 0 10px; }
.archive-card h2 a { color: var(--tinta); }
.archive-card h2 a:hover { color: var(--verde); }
.archive-card .deck { font-size: 14px; color: var(--cinza-d); line-height: 1.5; margin-bottom: 10px; }

/* Pagination */
.wp-block-query-pagination { display: flex; gap: 8px; align-items: center; justify-content: center; margin-top: 48px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; }
.wp-block-query-pagination a, .wp-block-query-pagination .page-numbers { padding: 8px 14px; border: 1px solid var(--linha-d); color: var(--cinza-d); }
.wp-block-query-pagination .current { background: var(--tinta); color: var(--papel); border-color: var(--tinta); }
.wp-block-query-pagination a:hover { border-color: var(--tinta); color: var(--tinta); }

/* 404 */
.not-found-wrap { max-width: 600px; margin: 80px auto; padding: 0 var(--gutter); text-align: center; }
.not-found-wrap .code { font-family: var(--display); font-weight: 800; font-size: 120px; line-height: 1; letter-spacing: -0.06em; color: var(--linha-d); }
.not-found-wrap h1 { font-family: var(--display); font-weight: 700; font-size: 32px; letter-spacing: -0.025em; margin-bottom: 14px; }
.not-found-wrap p { font-family: var(--sans); font-size: 17px; color: var(--cinza-d); margin-bottom: 32px; }
.not-found-wrap a.btn { display: inline-block; background: var(--tinta); color: var(--papel); padding: 13px 22px; font-family: var(--mono); font-weight: 700; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; }
.not-found-wrap a.btn:hover { background: var(--verde); }

/* ════════════════════════════════════════════════
   WIDGET — RESULTADOS DE FUTEBOL
   ════════════════════════════════════════════════ */

/* Sidebar layout na home */
.home-sidebar-row {
  display: flex;
  gap: 40px;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--gutter);
  align-items: flex-start;
}
.home-sidebar-row .home-main  { flex: 1 1 0; min-width: 0; }
.home-sidebar-row .home-aside { flex: 0 0 320px; width: 320px; }

/* Widget */
.futebol-widget {
  border: 1px solid var(--linha);
  border-radius: 3px;
  overflow: hidden;
  background: var(--papel);
  position: sticky;
  top: 84px; /* abaixo do nav fixo + ticker */
}

.fut-header {
  background: var(--tinta);
  color: var(--papel);
  padding: 11px 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.fut-icon { font-size: 14px; line-height: 1; flex-shrink: 0; }
.fut-titulo {
  font-family: var(--display);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .15em;
  text-transform: uppercase;
  margin: 0;
}

/* Lista de jogos */
.fut-lista { list-style: none; margin: 0; padding: 0; }

.fut-jogo {
  display: grid;
  grid-template-columns: 30px 1fr 54px 1fr;
  align-items: center;
  gap: 6px;
  padding: 9px 14px;
  border-bottom: 1px solid var(--linha);
}
.fut-jogo:last-child { border-bottom: none; }

.fut-data {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .04em;
  color: var(--cinza);
  line-height: 1;
}

/* Times */
.fut-time {
  display: flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
}
.fut-time-away {
  flex-direction: row-reverse; /* badge à direita */
}

.fut-nome {
  font-family: var(--display);
  font-size: 11px;
  font-weight: 500;
  color: var(--tinta-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fut-time.vencedor .fut-nome {
  font-weight: 800;
  color: var(--tinta);
}
.fut-time-away .fut-nome {
  text-align: right;
}

/* Badges */
.fut-badge {
  width: 22px;
  height: 22px;
  object-fit: contain;
  flex-shrink: 0;
}
.fut-badge-ph {
  display: inline-block;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--linha);
  flex-shrink: 0;
}

/* Placar */
.fut-placar {
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--tinta);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  background: var(--papel-2);
  border-radius: 3px;
  padding: 4px 0;
  min-width: 54px;
}
.fut-placar span {
  font-size: 9px;
  font-weight: 400;
  color: var(--cinza);
}
.fut-placar.empate { color: var(--cinza-d); }

.fut-vazio {
  padding: 18px 14px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--cinza);
  text-align: center;
  letter-spacing: .06em;
}


/* ════════════════════════════════════════════════
   MOBILE RESPONSIVE (≤ 768px)
   ════════════════════════════════════════════════ */
@media (max-width: 768px) {
  :root { --gutter: 18px; }
  body { padding-bottom: 64px; }

  /* Utility bar — oculto */
  .util { display: none; }

  /* Masthead */
  .masthead-inner {
    grid-template-columns: 32px 1fr 32px;
    padding: 12px 18px;
  }
  .mh-left { display: none; }
  .brand { font-size: 22px; text-align: center; }
  .brand .accent { width: 6px; height: 6px; }
  .mh-right { display: flex; gap: 8px; align-items: center; justify-content: flex-end; }
  .mh-right .cta { display: none; }

  /* Nav */
  .mainnav { border-bottom-color: var(--linha); }
  .mainnav-inner { padding: 0 18px; }
  .mainnav a { font-size: 12px; padding: 11px 14px 11px 0; margin-right: 0; }
  .mainnav a:first-child { padding-left: 0; }
  .mainnav a.urgent { margin-left: 0; }
  .ticker-mini { display: none; }

  /* Breaking */
  .breaking-inner { padding: 11px 18px; gap: 12px; }
  .breaking .tag::before { display: none; }
  .breaking .h { font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .breaking .time { font-size: 10px; }

  /* Hero — coluna única */
  .hero { padding: 22px 0 24px; }
  .hero-grid { grid-template-columns: 1fr; gap: 0; }
  .lead { gap: 10px; padding: 0 18px 24px; border-bottom: 1px solid var(--linha); }
  .lead .h { font-size: 24px; line-height: 1.12; }
  .lead .deck { font-size: 14px; }

  /* Rail — rows com imagem à esquerda */
  .rail { padding: 0 18px; }
  .rail .item {
    grid-template-columns: 100px 1fr;
    padding: 16px 0;
    border-bottom: 1px solid var(--linha);
  }
  .rail .item:last-child { border-bottom: none; }
  .rail .item .thumb { aspect-ratio: 1; }
  .rail .item > div { order: 2; }
  .rail .item .thumb { order: 1; }
  .rail .item h3 { font-size: 15px; margin: 4px 0 6px; }

  /* Section heads */
  .sh { padding-bottom: 8px; margin-bottom: 16px; }
  .sh .t { font-size: 13px; }
  section.block { padding: 22px 0 20px; }

  /* Análise */
  .analise-grid { grid-template-columns: 1fr; gap: 0; }
  .analise-feat { padding: 0 18px 20px; border-bottom: 1px solid var(--linha); margin-bottom: 0; }
  .analise-feat .h { font-size: 22px; }
  .analise-list { padding: 0 18px; }
  .analise-list .it:first-child { padding-top: 16px; }

  /* Pull quote */
  .pull { padding: 28px 18px; }
  .pull-inner { grid-template-columns: 1fr; gap: 0; }
  .pull .label { margin-bottom: 12px; }
  .pull .quote { font-size: 22px; padding-left: 16px; border-left-width: 2px; margin-top: 20px; }
  .pull .who   { padding-top: 0; }

  /* Política / Economia */
  .two-col { grid-template-columns: 1fr; gap: 0; }
  .col-block { padding: 0 18px 20px; }
  .col-block:first-child { border-bottom: 1px solid var(--linha); margin-bottom: 4px; }

  /* Opinião — lista de cards */
  .opinions { grid-template-columns: 1fr; gap: 0; padding: 0 18px; }
  .opinion + .opinion { border-left: none; padding-left: 0; border-top: 1px solid var(--linha); }
  .opinion { flex-direction: row; gap: 12px; padding: 16px 0; }
  .opinion .head { border-bottom: none; padding-bottom: 0; flex-direction: column; align-items: flex-start; }
  .opinion .who { display: block; }
  .opinion h3 { font-size: 17px; }
  .opinion .read { display: none; }

  /* Rankings */
  .double { grid-template-columns: 1fr; gap: 0; }
  .ll { padding: 0 18px 24px; }
  .ll:first-child { border-bottom: 1px solid var(--linha); }
  .ll .it { grid-template-columns: 40px 1fr auto; gap: 10px; }
  .ll .it .rank { font-size: 18px; }

  /* Newsletter */
  .nl-section { padding: 28px 0; }
  .nl-inner { grid-template-columns: 1fr; gap: 0; padding: 0; }
  .nl-inner .text { border-left: none; padding-left: 18px; border-left: 3px solid var(--verde); margin: 0 18px 20px; }
  .nl-inner h2 { font-size: 22px; }
  .nl-form { margin: 0 18px; border: 1px solid var(--linha-d); padding: 20px; }

  /* Footer */
  .foot-grid { grid-template-columns: 1fr 1fr; padding-bottom: 20px; }
  .foot-grid .brand-block { grid-column: 1 / -1; }
  .foot-bottom { flex-direction: column; gap: 10px; align-items: flex-start; padding: 16px 18px 0; }

  /* Tab bar */
  .mobile-tabbar {
    display: flex;
    position: fixed; bottom: 0; left: 0; right: 0;
    background: var(--papel); border-top: 1px solid var(--linha);
    padding: 8px 0 env(safe-area-inset-bottom, 8px);
    justify-content: space-around; align-items: center; z-index: 100;
  }
  .tab {
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    font-family: var(--display); font-weight: 600; font-size: 10px; letter-spacing: 0.01em;
    color: var(--cinza); padding: 4px 6px;
  }
  .tab.active { color: var(--tinta); }
  .tab svg { width: 22px; height: 22px; stroke: currentColor; stroke-width: 1.6; fill: none; }
  .tab.urgent { color: var(--brasa); position: relative; }
  .tab.urgent::after {
    content: ""; position: absolute; top: 2px; right: 0;
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--brasa); animation: pulse 1.5s infinite;
  }

  /* Article single */
  .article-title  { font-size: 28px; letter-spacing: -0.025em; }
  .article-deck   { font-size: 16px; }
  .article-body   { font-size: 16px; }
  .opiniao-body   { font-size: 17px; }

  .article-header-outer,
  .article-body-outer,
  .article-comments-outer { padding: 0 18px; }

  .article-featured figcaption,
  .article-featured .wp-element-caption { padding: 8px 18px 0; }

  .article-body > p:first-of-type::first-letter { font-size: 3.4em; }

  /* Share inline — oculta labels em mobile, só ícones */
  .share-btn span { display: none; }
  .share-btn { padding: 8px 10px; }
  .share-label { display: none; }

  /* Author box */
  .author-box { gap: 16px; padding-top: 20px; }
  .author-box-monogram { width: 48px; height: 48px; font-size: 20px; }
  .author-box-social-btn span { display: none; }  /* só ícone no mobile */
  .author-box-social-btn { padding: 7px 10px; }
  .author-box-avatar { width: 52px; height: 52px; }
  .author-box--extended .author-box-avatar { width: 64px; height: 64px; }

  /* Related */
  .related-grid { grid-template-columns: 1fr; gap: 20px; }
  .related-posts { padding: 28px 0; }

  /* Opinião author header */
  .opiniao-author-header { gap: 10px; }
  .author-opiniao .wp-block-post-author__avatar img { width: 44px; height: 44px; }



  /* Archive */
  .archive-grid .wp-block-post-template { grid-template-columns: 1fr; gap: 28px; }

  /* Futebol widget */
  .futebol-widget { position: static; }
  .fut-jogo       { grid-template-columns: 28px 1fr 48px 1fr; gap: 5px; padding: 9px 12px; }
  .fut-nome       { font-size: 11px; }
  .home-sidebar-row { flex-direction: column !important; gap: 0 !important; }
}
