/*
Theme Name: Radar Editorial Duro
Theme URI: https://rederadarinterior.com
Author: Adversos / Rede Radar Interior
Description: Tema WordPress editorial investigativo para rede de cidades. Layout cru, tipografia forte, homepage com hero, menu lateral, seleção de cidade, SEO clássico e dados estruturados para buscas/IA. Inspirado em lógica editorial de veículos investigativos, sem copiar marca, código ou assets de terceiros.
Version: 4.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: radar-editorial-duro
*/

:root {
  --radar-deep: #15505b;
  --radar-bg: #edf6f6;
  --radar-keppel: #44a6a3;
  --radar-blue: #4c9cac;
  --radar-amber: #d88718;
  --radar-amber-dark: #a95f06;
  --radar-ink: #15505b;
  --radar-title: #15505b;
  --radar-text: #15505b;
  --radar-muted: #4c6a70;
  --radar-paper: #edf6f6;
  --radar-surface: #f8fbfb;
  --radar-soft: #dcefed;
  --radar-line: #15505b;
  --radar-hero-text: #edf6f6;
  --radar-hero-accent: #f0b04f;
  --radar-side: 330px;
  --radar-max: 1320px;
  --font-title: Impact, Haettenschweiler, "Arial Black", "Franklin Gothic Heavy", "Arial Narrow Bold", system-ui, sans-serif;
  --font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  --font-serif: Georgia, "Times New Roman", serif;
  --font-mono: "Courier New", Courier, monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--radar-paper);
  color: var(--radar-text);
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.45;
}
body.drawer-open { overflow: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--radar-amber-dark); }
a:focus-visible, button:focus-visible, select:focus-visible, input:focus-visible, textarea:focus-visible { outline: 3px solid var(--radar-amber); outline-offset: 3px; }
button, input, select, textarea { font: inherit; }
.screen-reader-text, .skip-link {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}
.skip-link:focus {
  position: fixed !important;
  top: 14px;
  left: 14px;
  z-index: 10000;
  width: auto;
  height: auto;
  padding: 10px 14px;
  clip: auto;
  background: var(--radar-ink);
  color: var(--radar-bg);
}

/* Header brutalista */
.radar-header {
  width: 100%;
  z-index: 50;
  background: var(--radar-paper);
}
.radar-header-inner {
  display: grid;
  grid-template-columns: var(--radar-side) minmax(0, 1fr);
  min-height: 88px;
}
.radar-brand-panel {
  background: var(--radar-deep);
  color: var(--radar-bg);
  display: flex;
  align-items: flex-start;
  gap: 26px;
  padding: 28px 28px;
  min-height: 88px;
}
.home .radar-header {
  position: absolute;
  top: 0;
  left: 0;
  background: transparent;
}
.home .radar-header-inner {
  display: block;
  min-height: 0;
}
.home .radar-brand-panel {
  width: var(--radar-side);
  background: transparent;
  position: relative;
  z-index: 3;
}
.radar-logo {
  color: var(--radar-bg);
  display: inline-block;
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 900;
  font-size: 32px;
  line-height: .78;
  letter-spacing: -1.6px;
  max-width: 220px;
}
.radar-logo-text {
  display: inline-block;
  position: relative;
  padding-right: 12px;
}
.radar-logo-text::after {
  content: "_";
  position: absolute;
  right: -14px;
  bottom: -4px;
}
.custom-logo-link img {
  max-width: 210px;
  max-height: 70px;
  object-fit: contain;
}
.radar-menu-button,
.radar-close-button,
.radar-search-button {
  appearance: none;
  background: transparent;
  border: 0;
  color: inherit;
  cursor: pointer;
  padding: 0;
  line-height: 1;
}
.radar-menu-button {
  width: 26px;
  height: 22px;
  margin-top: 8px;
  display: inline-flex;
  flex-direction: column;
  justify-content: space-between;
}
.radar-menu-button span {
  display: block;
  height: 2px;
  width: 100%;
  background: currentColor;
}
.radar-nav-shell {
  min-width: 0;
  display: flex;
  align-items: stretch;
  background: var(--radar-surface);
  border-bottom: 1px solid rgba(21,80,91,.10);
}
.radar-nav {
  display: flex;
  align-items: stretch;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: thin;
  flex: 1;
}
.radar-nav a,
.radar-nav button,
.radar-support-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 88px;
  padding: 0 24px;
  color: var(--radar-ink);
  font-family: var(--font-title);
  font-size: 23px;
  letter-spacing: .4px;
  text-transform: uppercase;
  white-space: nowrap;
  border: 0;
  background: transparent;
}
.radar-nav a:hover,
.radar-nav button:hover { background: var(--radar-bg); color: var(--radar-ink); }
.radar-nav .current-menu-item > a,
.radar-nav .current_page_item > a,
.radar-nav .is-current {
  background: var(--radar-soft);
}
.radar-support-link {
  background: var(--radar-amber);
  color: var(--radar-bg);
  min-width: 210px;
  justify-content: flex-start;
  padding-left: 32px;
}
.radar-support-link:hover { background: var(--radar-amber-dark); color: var(--radar-bg); }
.radar-city-chip {
  border-left: 1px solid rgba(21,80,91,.10) !important;
  color: var(--radar-deep) !important;
}

/* Drawer lateral */
.radar-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(21,80,91,.38);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
  z-index: 90;
}
.radar-drawer {
  position: fixed;
  inset: 0 auto 0 0;
  width: min(595px, 88vw);
  background: var(--radar-paper);
  color: var(--radar-text);
  transform: translateX(-105%);
  transition: transform .23s ease;
  z-index: 100;
  padding: 34px 64px;
  overflow-y: auto;
  box-shadow: 12px 0 40px rgba(21,80,91,.22);
}
.drawer-open .radar-drawer-overlay { opacity: 1; pointer-events: auto; }
.drawer-open .radar-drawer { transform: translateX(0); }
.radar-drawer-head {
  display: flex;
  align-items: flex-start;
  gap: 28px;
  margin-bottom: 28px;
}
.radar-close-button {
  width: 28px;
  height: 28px;
  position: relative;
  margin-top: 10px;
}
.radar-close-button::before,
.radar-close-button::after {
  content: "";
  position: absolute;
  left: 0;
  top: 13px;
  width: 28px;
  height: 2px;
  background: var(--radar-ink);
}
.radar-close-button::before { transform: rotate(45deg); }
.radar-close-button::after { transform: rotate(-45deg); }
.radar-drawer .radar-logo { color: var(--radar-ink); font-size: 34px; }
.radar-drawer-search {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 24px 0;
  border: 1px solid transparent;
}
.radar-drawer-search input {
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--radar-blue);
  padding: 12px 0;
  font-family: var(--font-mono);
  font-size: 16px;
}
.radar-search-button {
  width: 22px;
  height: 22px;
  border: 1px solid var(--radar-blue);
  border-radius: 50%;
  position: relative;
  flex: 0 0 22px;
}
.radar-search-button::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 1px;
  right: -6px;
  bottom: 0;
  background: var(--radar-blue);
  transform: rotate(45deg);
}
.radar-drawer-menu,
.radar-drawer-secondary {
  list-style: none;
  padding: 0;
  margin: 0;
}
.radar-drawer-menu a,
.radar-drawer-secondary a {
  display: block;
  padding: 10px 0;
  font-family: var(--font-title);
  font-size: 24px;
  letter-spacing: .8px;
  text-transform: uppercase;
}
.radar-drawer-support {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 24px 0;
  padding: 18px 22px;
  background: var(--radar-amber);
  color: var(--radar-bg);
  font-family: var(--font-title);
  font-size: 24px;
  text-transform: uppercase;
}
.radar-drawer-line {
  border: 0;
  border-top: 1px solid var(--radar-ink);
  margin: 24px 0 14px;
}
.radar-drawer-secondary a { font-size: 20px; }

/* Hero home */
.radar-hero {
  --hero-fg: var(--radar-hero-text);
  --hero-accent: var(--radar-hero-accent);
  --hero-shadow: rgba(5, 36, 42, .72);
  --hero-overlay-a: rgba(21,80,91,.78);
  --hero-overlay-b: rgba(21,80,91,.24);
  --hero-overlay-c: rgba(21,80,91,.62);
  --hero-bottom-a: rgba(21,80,91,.97);
  --hero-bottom-b: rgba(21,80,91,0);
  min-height: 650px;
  height: 72vh;
  max-height: 850px;
  position: relative;
  background-color: var(--radar-deep);
  background-position: center;
  background-size: cover;
  color: var(--hero-fg);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.radar-hero.radar-hero-contrast-dark {
  --hero-fg: var(--radar-deep);
  --hero-accent: var(--radar-amber-dark);
  --hero-shadow: rgba(237,246,246,.82);
  --hero-overlay-a: rgba(237,246,246,.92);
  --hero-overlay-b: rgba(237,246,246,.48);
  --hero-overlay-c: rgba(237,246,246,.86);
  --hero-bottom-a: rgba(237,246,246,.97);
  --hero-bottom-b: rgba(237,246,246,0);
}
.radar-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--hero-overlay-a), var(--hero-overlay-b) 52%, var(--hero-overlay-c)),
              linear-gradient(0deg, var(--hero-bottom-a), var(--hero-bottom-b) 46%);
}
.radar-hero-content {
  position: relative;
  z-index: 2;
  width: min(1040px, calc(100% - 48px));
  margin-left: max(24px, calc((100vw - var(--radar-max)) / 2));
  padding: 0 0 68px 0;
}
.radar-hero-kicker,
.radar-kicker {
  color: var(--hero-accent);
  font-family: var(--font-title);
  text-transform: uppercase;
  letter-spacing: .8px;
  font-size: 22px;
  margin-bottom: 12px;
}
.radar-hero-title {
  margin: 0;
  max-width: 930px;
  color: var(--hero-fg);
  font-family: var(--font-title);
  font-size: clamp(48px, 5.8vw, 92px);
  line-height: .92;
  letter-spacing: .5px;
  text-transform: uppercase;
}
.radar-byline {
  margin-top: 22px;
  color: var(--hero-accent);
  font-family: var(--font-mono);
  font-size: 16px;
}
.radar-hero a,
.radar-hero a:hover {
  color: var(--hero-fg);
  text-decoration: none;
  text-shadow: 0 2px 18px var(--hero-shadow), 0 1px 0 var(--hero-shadow);
}
.radar-hero-kicker,
.radar-byline {
  text-shadow: 0 1px 10px var(--hero-shadow);
}
.radar-home-nav { border-bottom: 0; }
.radar-home-nav .radar-nav-shell {
  width: 100%;
  padding-left: max(0px, calc((100vw - var(--radar-max)) / 2));
  min-height: 94px;
  border-bottom: 0;
}
.radar-home-nav .radar-nav a,
.radar-home-nav .radar-nav button,
.radar-home-nav .radar-support-link { min-height: 94px; }

/* Seletor de cidade */
.radar-city-strip {
  background: var(--radar-deep);
  color: var(--radar-bg);
  border-top: 1px solid rgba(237,246,246,.20);
  border-bottom: 1px solid rgba(21,80,91,.22);
}
.radar-city-strip-inner {
  max-width: var(--radar-max);
  margin: 0 auto;
  min-height: 64px;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.radar-city-strip strong {
  font-family: var(--font-title);
  font-size: 21px;
  text-transform: uppercase;
  letter-spacing: .6px;
}
.radar-city-strip span { color: rgba(237,246,246,.90); }
.radar-city-select {
  min-height: 42px;
  border: 1px solid rgba(237,246,246,.48);
  background: var(--radar-surface);
  color: var(--radar-ink);
  padding: 0 12px;
  min-width: 230px;
  font-family: var(--font-mono);
}
.radar-city-actions {
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-left: auto;
}
.radar-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border: 2px solid currentColor;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-family: var(--font-title);
  text-transform: uppercase;
  font-size: 18px;
  letter-spacing: .4px;
}
.radar-btn:hover { transform: translateY(-1px); }
.radar-btn-primary { background: var(--radar-amber); border-color: var(--radar-amber); color: var(--radar-bg); }
.radar-btn-light { background: var(--radar-surface); color: var(--radar-deep); border-color: var(--radar-bg); }
.radar-city-modal {
  position: fixed;
  inset: auto 24px 24px auto;
  width: min(500px, calc(100vw - 48px));
  background: var(--radar-surface);
  border: 6px solid var(--radar-deep);
  box-shadow: 0 18px 60px rgba(21,80,91,.26);
  padding: 24px;
  z-index: 80;
  transform: translateY(24px);
  opacity: 0;
  pointer-events: none;
  transition: .22s ease;
}
.radar-city-modal.is-visible { transform: translateY(0); opacity: 1; pointer-events: auto; }
.radar-city-modal h2 {
  margin: 0 0 10px;
  font-family: var(--font-title);
  font-size: 42px;
  line-height: .92;
  text-transform: uppercase;
}
.radar-city-modal p { margin: 0 0 16px; color: var(--radar-muted); }
.radar-city-modal .radar-city-select { width: 100%; border-color: var(--radar-deep); }
.radar-city-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.radar-city-close {
  position: absolute;
  right: 10px;
  top: 8px;
  border: 0;
  background: transparent;
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
}
.radar-city-note {
  font-family: var(--font-mono);
  font-size: 13px;
  margin-top: 12px;
  color: var(--radar-muted);
}

/* Listas home / arquivo */
.radar-main { background: var(--radar-paper); }
.radar-section {
  max-width: var(--radar-max);
  margin: 0 auto;
  padding: 58px 24px;
}
.radar-section-title {
  font-family: var(--font-title);
  font-size: clamp(54px, 5vw, 82px);
  line-height: .9;
  letter-spacing: -.5px;
  text-transform: uppercase;
  margin: 0 0 44px;
}
.radar-top-grid {
  display: grid;
  grid-template-columns: minmax(380px, 1.05fr) minmax(300px, 1fr) minmax(240px, .48fr);
  gap: 42px;
  align-items: start;
}
.radar-lead-image img {
  width: 100%;
  aspect-ratio: 1.55/1;
  object-fit: cover;
  filter: saturate(.74) contrast(1.05);
}
.radar-rule {
  display: block;
  width: 90px;
  height: 10px;
  background: var(--radar-line);
  margin: 0 0 26px;
}
.radar-rule.teal { background: var(--radar-keppel); }
.radar-rule.orange { background: var(--radar-amber); }
.radar-card-kicker {
  color: var(--radar-keppel);
  font-family: var(--font-title);
  font-size: 26px;
  line-height: 1;
  margin: 0 0 18px;
  text-transform: none;
}
.radar-card-title {
  font-family: var(--font-title);
  font-size: clamp(34px, 3vw, 52px);
  line-height: .95;
  letter-spacing: .2px;
  text-transform: uppercase;
  margin: 0 0 22px;
}
.radar-card-title a:hover { color: var(--radar-amber-dark); }
a:focus-visible, button:focus-visible, select:focus-visible, input:focus-visible, textarea:focus-visible { outline: 3px solid var(--radar-amber); outline-offset: 3px; }
.radar-excerpt {
  font-family: var(--font-serif);
  font-size: 21px;
  line-height: 1.38;
  color: var(--radar-muted);
  margin: 0 0 22px;
}
.radar-rail {
  display: grid;
  gap: 50px;
}
.radar-rail-card img {
  width: 150px;
  aspect-ratio: 1.45/1;
  object-fit: cover;
  margin-bottom: 14px;
}
.radar-rail-card .radar-rule { width: 82px; height: 8px; margin-bottom: 18px; }
.radar-rail-title {
  font-family: var(--font-title);
  font-size: 25px;
  line-height: 1.03;
  text-transform: none;
  margin: 0 0 12px;
}
.radar-rail-title a { color: var(--radar-title); }
.radar-rail-title a:hover { color: var(--radar-keppel); }
.radar-meta-mono {
  color: var(--radar-keppel);
  font-family: var(--font-mono);
  font-size: 15px;
}
.radar-story-stream {
  display: grid;
  gap: 82px;
  margin-top: 72px;
}
.radar-stream-item {
  display: grid;
  grid-template-columns: minmax(300px, .86fr) minmax(400px, 1fr);
  gap: 44px;
  align-items: center;
}
.radar-stream-item:nth-child(even) .radar-stream-media { order: 2; }
.radar-stream-item:nth-child(even) .radar-stream-text { order: 1; text-align: right; }
.radar-stream-media img {
  width: 100%;
  aspect-ratio: 1.55/1;
  object-fit: cover;
}
.radar-stream-title {
  font-family: var(--font-title);
  font-size: clamp(32px, 4vw, 52px);
  line-height: .96;
  text-transform: uppercase;
  margin: 0 0 16px;
}
.radar-empty {
  border: 4px solid var(--radar-deep);
  padding: 28px;
  background: var(--radar-bg);
  max-width: 760px;
}
.radar-empty h2 {
  font-family: var(--font-title);
  font-size: 42px;
  line-height: .95;
  margin: 0 0 12px;
}
.radar-pagination {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 42px;
}
.radar-pagination .page-numbers {
  padding: 8px 12px;
  border: 2px solid var(--radar-ink);
  font-family: var(--font-title);
}
.radar-pagination .current { background: var(--radar-ink); color: var(--radar-bg); }

/* Matéria */
.single-post .radar-main,
.page .radar-main { background: var(--radar-surface); }
.radar-article-shell {
  max-width: none;
  margin: 0;
  padding: 0;
}
.radar-article-header {
  padding: 48px 24px 32px;
  margin-left: var(--radar-side);
  max-width: 1040px;
}
.radar-article-kicker {
  color: var(--radar-keppel);
  font-family: var(--font-title);
  text-transform: uppercase;
  font-size: 24px;
  margin-bottom: 14px;
}
.radar-article-title {
  font-family: var(--font-title);
  font-size: clamp(52px, 6.2vw, 98px);
  line-height: .93;
  letter-spacing: .2px;
  text-transform: uppercase;
  margin: 0 0 20px;
}
.radar-article-dek {
  font-family: var(--font-serif);
  font-size: clamp(23px, 2vw, 34px);
  line-height: 1.32;
  color: var(--radar-muted);
  margin: 0 0 26px;
  max-width: 900px;
}
.radar-article-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.radar-author-block {
  display: flex;
  align-items: center;
  gap: 16px;
}
.radar-author-avatar img,
.radar-author-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--radar-soft);
}
.radar-author-name { font-family: var(--font-mono); color: var(--radar-keppel); }
.radar-date { font-family: var(--font-mono); color: var(--radar-muted); margin-top: 6px; }
.radar-share {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--radar-keppel);
  color: var(--radar-keppel);
  padding: 9px 16px;
  font-family: var(--font-mono);
}
.radar-share:hover { background: var(--radar-bg); color: var(--radar-deep); }
.radar-featured-full img {
  width: 100%;
  max-height: 760px;
  object-fit: cover;
}
.radar-article-body-wrap {
  display: grid;
  grid-template-columns: minmax(180px, .5fr) minmax(0, 760px) minmax(220px, .45fr);
  gap: 42px;
  max-width: var(--radar-max);
  margin: 0 auto;
  padding: 62px 24px;
}
.radar-article-aside {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--radar-muted);
}
.radar-article-aside .radar-rule { width: 72px; height: 8px; }
.radar-article-content {
  font-family: var(--font-serif);
  font-size: 22px;
  line-height: 1.72;
  color: var(--radar-text);
}
.radar-article-content > p:first-child::first-letter {
  float: left;
  font-family: var(--font-title);
  font-size: 92px;
  line-height: .72;
  padding: 10px 10px 0 0;
}
.radar-article-content p { margin: 0 0 1.35em; }
.radar-article-content h2,
.radar-article-content h3 {
  font-family: var(--font-title);
  text-transform: uppercase;
  line-height: .98;
  margin: 1.25em 0 .45em;
}
.radar-article-content h2 { font-size: 44px; }
.radar-article-content h3 { font-size: 34px; }
.radar-article-content blockquote {
  margin: 42px 0;
  padding: 24px 0 24px 28px;
  border-left: 10px solid var(--radar-keppel);
  font-family: var(--font-title);
  font-size: 34px;
  line-height: 1.05;
}
.radar-newsletter-box,
.radar-source-box {
  border: 6px solid var(--radar-keppel);
  padding: 26px;
  margin: 44px 0;
  background: var(--radar-surface);
}
.radar-source-box { border-color: var(--radar-amber); background: var(--radar-bg); }
.radar-newsletter-box h2,
.radar-source-box h2 {
  margin: 0 0 12px;
  color: var(--radar-deep);
  font-family: var(--font-title);
  font-size: 42px;
  line-height: .94;
  text-transform: uppercase;
}
.radar-inline-form {
  display: flex;
  gap: 14px;
  margin-top: 18px;
}
.radar-inline-form input {
  flex: 1;
  min-width: 0;
  border: 1px solid var(--radar-keppel);
  padding: 14px 16px;
  font-family: var(--font-mono);
}
.radar-inline-form button,
.radar-source-box a {
  border: 0;
  background: var(--radar-keppel);
  color: var(--radar-bg);
  padding: 14px 22px;
  font-family: var(--font-title);
  font-size: 20px;
  text-transform: uppercase;
}
.radar-source-box a { display: inline-flex; margin-top: 10px; background: var(--radar-amber); }
.radar-related {
  background: var(--radar-bg);
  padding: 58px 0;
}
.radar-related-inner { max-width: var(--radar-max); margin: 0 auto; padding: 0 24px; }
.radar-related-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
}
.radar-related-card {
  background: var(--radar-surface);
  padding-bottom: 18px;
}
.radar-related-card img { width: 100%; aspect-ratio: 1.5/1; object-fit: cover; }
.radar-related-card h3 {
  font-family: var(--font-title);
  font-size: 27px;
  line-height: 1;
  margin: 14px 16px 10px;
}
.radar-related-card .radar-meta-mono { margin-left: 16px; }

/* Páginas, busca, arquivos */
.radar-archive-head {
  max-width: var(--radar-max);
  margin: 0 auto;
  padding: 56px 24px 10px;
}
.radar-archive-title {
  font-family: var(--font-title);
  font-size: clamp(54px, 6vw, 92px);
  line-height: .9;
  text-transform: uppercase;
  margin: 0 0 16px;
}
.radar-archive-description {
  max-width: 760px;
  font-family: var(--font-serif);
  font-size: 24px;
  color: var(--radar-muted);
}
.radar-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 42px 28px;
}
.radar-archive-card img { width: 100%; aspect-ratio: 1.45/1; object-fit: cover; margin-bottom: 14px; }
.radar-archive-card .radar-rule { height: 8px; width: 76px; margin-bottom: 15px; }
.radar-archive-card h2 {
  font-family: var(--font-title);
  font-size: 31px;
  line-height: .98;
  text-transform: uppercase;
  margin: 0 0 12px;
}


/* Links e texto em paleta */
.radar-card-title,
.radar-stream-title,
.radar-rail-title,
.radar-related-card h3,
.radar-archive-card h2,
.radar-section-title,
.radar-article-title,
.radar-archive-title,
.radar-empty h2,
.radar-newsletter-box h2,
.radar-source-box h2 {
  color: var(--radar-title);
}
.radar-card-title a,
.radar-stream-title a,
.radar-rail-title a,
.radar-related-card h3 a,
.radar-archive-card h2 a {
  color: var(--radar-title);
  text-decoration: none;
}
.radar-card-title a:hover,
.radar-stream-title a:hover,
.radar-rail-title a:hover,
.radar-related-card h3 a:hover,
.radar-archive-card h2 a:hover {
  color: var(--radar-amber-dark);
}
.radar-article-content a,
.radar-article-aside a,
.radar-archive-description a,
.radar-excerpt a {
  color: var(--radar-deep);
  text-decoration-line: underline;
  text-decoration-color: var(--radar-amber);
  text-decoration-thickness: .12em;
  text-underline-offset: .16em;
}
.radar-article-content a:hover,
.radar-article-aside a:hover,
.radar-archive-description a:hover,
.radar-excerpt a:hover {
  color: var(--radar-amber-dark);
  text-decoration-color: var(--radar-keppel);
}

/* Footer */
.radar-footer {
  background: var(--radar-deep);
  color: var(--radar-bg);
  padding: 58px 24px;
}
.radar-footer-inner {
  max-width: var(--radar-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 34px;
}
.radar-footer .radar-logo { font-size: 40px; }
.radar-footer p { max-width: 680px; color: rgba(237,246,246,.82); }
.radar-footer-menu { list-style: none; padding: 0; margin: 0; columns: 2; }
.radar-footer-menu a {
  display: block;
  padding: 5px 0;
  font-family: var(--font-title);
  text-transform: uppercase;
  font-size: 20px;
}

/* Responsivo */
@media (max-width: 1100px) {
  :root { --radar-side: 285px; }
  .radar-nav a,
  .radar-nav button,
  .radar-support-link { padding: 0 18px; font-size: 20px; }
  .radar-top-grid { grid-template-columns: 1fr 1fr; }
  .radar-rail { grid-column: 1 / -1; grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .radar-article-body-wrap { grid-template-columns: minmax(0, 760px) minmax(200px, .4fr); }
  .radar-article-aside { display: none; }
}
@media (max-width: 860px) {
  :root { --radar-side: 0px; }
  body { font-size: 16px; }
  .radar-header { position: relative; background: var(--radar-deep); }
  .home .radar-header { position: absolute; background: transparent; }
  .radar-header-inner { display: block; min-height: 76px; }
  .radar-brand-panel,
  .home .radar-brand-panel {
    width: auto;
    min-height: 76px;
    padding: 22px 24px;
    background: rgba(21,80,91,.94);
  }
  .radar-logo { font-size: 30px; }
  .custom-logo-link img { max-height: 52px; }
  .radar-nav-shell { display: none; }
  .home .radar-home-nav .radar-nav-shell {
    display: flex;
    overflow-x: auto;
    padding-left: 0;
    min-height: 66px;
  }
  .radar-home-nav .radar-nav a,
  .radar-home-nav .radar-nav button,
  .radar-home-nav .radar-support-link { min-height: 66px; font-size: 18px; padding: 0 16px; }
  .radar-support-link { min-width: 150px; }
  .radar-hero { min-height: 560px; height: 68vh; }
  .radar-hero-content { width: calc(100% - 36px); margin-left: 18px; padding-bottom: 44px; }
  .radar-hero-title { font-size: clamp(44px, 12vw, 72px); }
  .radar-city-strip-inner { display: grid; grid-template-columns: 1fr; align-items: start; }
  .radar-city-actions { margin-left: 0; }
  .radar-top-grid { grid-template-columns: 1fr; gap: 28px; }
  .radar-rail { grid-template-columns: 1fr; gap: 28px; }
  .radar-rail-card { display: grid; grid-template-columns: 120px 1fr; gap: 16px; }
  .radar-rail-card .radar-rule { grid-column: 1 / -1; margin-bottom: 0; }
  .radar-rail-card img { width: 120px; margin-bottom: 0; }
  .radar-section { padding: 42px 18px; }
  .radar-section-title { margin-bottom: 28px; }
  .radar-stream-item,
  .radar-stream-item:nth-child(even) { grid-template-columns: 1fr; gap: 20px; }
  .radar-stream-item:nth-child(even) .radar-stream-media,
  .radar-stream-item:nth-child(even) .radar-stream-text { order: initial; text-align: left; }
  .radar-article-header { margin-left: 0; padding: 38px 18px 28px; }
  .radar-article-body-wrap { grid-template-columns: 1fr; padding: 38px 18px; }
  .radar-article-content { font-size: 20px; line-height: 1.66; }
  .radar-related-grid,
  .radar-archive-grid { grid-template-columns: 1fr; }
  .radar-footer-inner { grid-template-columns: 1fr; }
  .radar-drawer { padding: 30px 36px; }
}
@media (max-width: 560px) {
  .radar-drawer { width: min(470px, 92vw); padding: 26px 28px; }
  .radar-drawer-menu a { font-size: 22px; }
  .radar-hero { min-height: 520px; }
  .radar-hero-title { font-size: clamp(38px, 12.5vw, 58px); }
  .radar-card-title { font-size: 38px; }
  .radar-stream-title { font-size: 36px; }
  .radar-article-title { font-size: clamp(42px, 13vw, 64px); }
  .radar-article-dek { font-size: 22px; }
  .radar-inline-form { display: grid; }
  .radar-city-modal { inset: auto 14px 14px 14px; width: auto; padding: 20px; border-width: 4px; }
  .radar-city-modal h2 { font-size: 36px; }
}

/* Ajuste para menus nativos do WordPress dentro da barra horizontal */
.radar-nav ul { display: contents; list-style: none; margin: 0; padding: 0; }
.radar-nav li { display: contents; list-style: none; margin: 0; padding: 0; }
.radar-drawer-menu li, .radar-drawer-secondary li, .radar-footer-menu li { list-style: none; }


/* === Radar v4.0.0 final: auditoria mobile, contraste, CTA e menus compactos === */
:root {
  --radar-link: var(--radar-keppel);
  --radar-link-hover: var(--radar-amber-dark);
  --radar-card-bg: #f8fbfb;
}

body,
.radar-article-content,
.radar-comment-form-wrap,
.rci-form,
.rci-support-box {
  color: var(--radar-deep);
}

.radar-home-nav .radar-nav a:hover,
.radar-nav a:hover,
.radar-nav button:hover,
.radar-drawer-menu a:hover,
.radar-drawer-secondary a:hover,
.radar-footer-menu a:hover {
  background: rgba(68,166,163,.16);
  color: var(--radar-deep);
}

.radar-drawer-support:hover,
.radar-support-link:hover,
.radar-inline-form button:hover,
.radar-source-box a:hover,
.rci-form button:hover,
.rci-button:hover {
  background: var(--radar-amber-dark);
  color: var(--radar-bg);
}

.radar-hero.radar-hero-contrast-light .radar-hero-title a,
.radar-hero.radar-hero-contrast-light .radar-hero-title a:hover {
  color: var(--radar-bg);
  text-shadow: 0 3px 24px rgba(21,80,91,.92), 0 1px 0 rgba(21,80,91,.9);
}

.radar-hero.radar-hero-contrast-dark .radar-hero-title a,
.radar-hero.radar-hero-contrast-dark .radar-hero-title a:hover {
  color: var(--radar-deep);
  text-shadow: 0 3px 24px rgba(237,246,246,.9), 0 1px 0 rgba(237,246,246,.9);
}

.radar-card-title a,
.radar-stream-title a,
.radar-rail-title a,
.radar-related-card h3 a,
.radar-archive-card h2 a {
  color: var(--radar-deep);
}

.radar-card-title a:hover,
.radar-stream-title a:hover,
.radar-rail-title a:hover,
.radar-related-card h3 a:hover,
.radar-archive-card h2 a:hover {
  color: var(--radar-amber-dark);
  background: transparent;
}

.radar-article-content a,
.radar-article-aside a,
.radar-archive-description a,
.radar-excerpt a,
.radar-author-links a,
.rci-form a,
.rci-support-box a:not(.rci-button) {
  color: var(--radar-link);
  text-decoration: underline;
  text-decoration-color: var(--radar-amber);
  text-decoration-thickness: .12em;
  text-underline-offset: .18em;
  background: transparent;
}

.radar-article-content a:hover,
.radar-article-aside a:hover,
.radar-archive-description a:hover,
.radar-excerpt a:hover,
.radar-author-links a:hover,
.rci-form a:hover,
.rci-support-box a:not(.rci-button):hover {
  color: var(--radar-link-hover);
  background: rgba(216,135,24,.12);
  text-decoration-color: var(--radar-keppel);
}

.radar-footer {
  padding: 64px 24px;
}
.radar-footer-inner {
  grid-template-columns: minmax(260px, .9fr) minmax(260px, .7fr);
  align-items: start;
}
.radar-footer-menu {
  columns: initial;
  display: grid;
  grid-template-columns: repeat(2, minmax(140px, 1fr));
  gap: 10px 28px;
}
.radar-footer-menu a {
  padding: 10px 0;
  color: var(--radar-bg);
}
.radar-footer-menu a:hover {
  color: var(--radar-bg);
  background: rgba(237,246,246,.08);
  padding-left: 8px;
}

.radar-share-wrap {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.radar-share {
  appearance: none;
  cursor: pointer;
  background: transparent;
  border: 2px solid var(--radar-keppel);
  color: var(--radar-deep);
}
.radar-share:hover {
  background: var(--radar-keppel);
  color: var(--radar-bg);
}
.radar-share-status {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--radar-amber-dark);
}

.radar-author-bio {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 22px;
  align-items: start;
  padding: 28px 0;
  margin: 46px 0 18px;
  border-top: 4px solid var(--radar-keppel);
  border-bottom: 1px solid rgba(21,80,91,.18);
}
.radar-author-bio-avatar img {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--radar-soft);
}
.radar-author-bio h2 {
  margin: 0 0 8px;
  font-family: var(--font-title);
  font-size: 36px;
  line-height: .96;
  text-transform: uppercase;
  color: var(--radar-deep);
}
.radar-author-bio p {
  margin: 0 0 12px;
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.45;
  color: var(--radar-muted);
}
.radar-author-links {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 15px;
}

.radar-comments {
  background: var(--radar-paper);
  padding: 42px 0 76px;
}
.radar-comments-inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 24px;
}
.radar-comments-title {
  margin: 0 0 22px;
  font-family: var(--font-title);
  font-size: clamp(38px, 5vw, 64px);
  line-height: .92;
  color: var(--radar-deep);
  text-transform: uppercase;
}
.radar-comment-list {
  margin: 0 0 34px;
  padding: 0;
  list-style: none;
}
.radar-comment-list .comment {
  background: var(--radar-card-bg);
  border-left: 6px solid var(--radar-keppel);
  padding: 18px;
  margin: 0 0 18px;
}
.radar-comment-form-wrap {
  background: var(--radar-card-bg);
  border: 3px solid rgba(21,80,91,.18);
  padding: 24px;
}
.radar-comment-reply-title {
  margin: 0 0 16px;
  font-family: var(--font-title);
  font-size: 34px;
  line-height: .95;
  text-transform: uppercase;
  color: var(--radar-deep);
}
.comment-form label,
.rci-form label {
  display: block;
  margin: 0 0 8px;
  font-family: var(--font-mono);
  color: var(--radar-deep);
}
.comment-form textarea,
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.rci-form input,
.rci-form textarea,
.rci-form select {
  width: 100%;
  border: 1px solid rgba(21,80,91,.38);
  background: #fff;
  color: var(--radar-deep);
  padding: 12px 14px;
  font-family: var(--font-sans);
  font-size: 16px;
}
.comment-form p {
  margin: 0 0 16px;
}
.radar-comment-submit,
.form-submit input[type="submit"],
.rci-form button,
.rci-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 0;
  background: var(--radar-keppel);
  color: var(--radar-bg);
  padding: 12px 20px;
  font-family: var(--font-title);
  font-size: 20px;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
}

.rci-form,
.rci-support-box {
  background: var(--radar-card-bg);
  border: 4px solid rgba(21,80,91,.18);
  padding: 24px;
  margin: 22px 0;
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.5;
}
.rci-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.rci-form-intro {
  margin-top: 0;
  color: var(--radar-muted);
}
.rci-check {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--font-sans) !important;
  color: var(--radar-muted) !important;
}
.rci-check input {
  width: auto !important;
  margin-top: 5px;
}
.rci-hp {
  position: absolute !important;
  left: -9999px !important;
  opacity: 0 !important;
}
.rci-form-notice {
  border-left: 6px solid var(--radar-keppel);
  background: var(--radar-card-bg);
  padding: 14px 18px;
  margin: 18px 0;
  font-family: var(--font-sans);
  color: var(--radar-deep);
}
.rci-newsletter-form.is-compact {
  display: flex;
  gap: 12px;
  padding: 0;
  border: 0;
  background: transparent;
}
.rci-newsletter-form.is-compact input[type="email"] {
  min-width: 0;
  flex: 1;
}
.rci-support-pix {
  border: 2px dashed var(--radar-keppel);
  padding: 14px;
  margin: 18px 0;
  background: var(--radar-bg);
  font-family: var(--font-mono);
}

.radar-source-box a {
  text-decoration: none;
  color: var(--radar-bg);
}
.radar-source-box a:hover {
  background: var(--radar-amber-dark);
  color: var(--radar-bg);
}

@media (max-width: 700px) {
  .rci-form-grid,
  .radar-author-bio,
  .radar-footer-menu {
    grid-template-columns: 1fr;
  }
  .rci-newsletter-form.is-compact {
    display: grid;
  }
  .radar-comment-form-wrap,
  .rci-form,
  .rci-support-box {
    padding: 18px;
  }
}

/* === Radar v4.0.0 FINAL: correções de auditoria === */
html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

.radar-header,
.radar-main,
.radar-footer,
.radar-section,
.radar-related,
.radar-article-shell {
  max-width: 100%;
  overflow-x: clip;
}

.radar-nav-shell {
  min-width: 0;
  overflow: hidden;
}

.radar-nav {
  min-width: 0;
  overflow: hidden;
  scrollbar-width: none;
}
.radar-nav::-webkit-scrollbar { display: none; }

.radar-nav a,
.radar-nav button,
.radar-support-link {
  flex: 0 1 auto;
  min-width: 0;
  padding-inline: clamp(12px, 1.25vw, 22px);
  font-size: clamp(18px, 1.32vw, 22px);
}

.radar-nav a,
.radar-nav button {
  max-width: 190px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.radar-nav-more {
  color: var(--radar-deep) !important;
  border-left: 1px solid rgba(21,80,91,.12) !important;
}

.radar-support-link {
  min-width: 165px;
  max-width: 220px;
  white-space: nowrap;
}

.radar-city-chip {
  max-width: 175px !important;
}

.radar-source-box .radar-source-cta,
.radar-source-box > a,
.radar-article-content .radar-source-box .radar-source-cta,
.radar-article-content .radar-source-box > a,
.radar-related .radar-source-box .radar-source-cta,
.radar-related .radar-source-box > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  margin-top: 12px;
  padding: 13px 22px;
  border: 2px solid var(--radar-amber);
  background: var(--radar-amber) !important;
  color: var(--radar-bg) !important;
  font-family: var(--font-title);
  font-size: 21px;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none !important;
  text-shadow: none !important;
  box-shadow: none;
}

.radar-source-box .radar-source-cta:hover,
.radar-source-box > a:hover,
.radar-article-content .radar-source-box .radar-source-cta:hover,
.radar-article-content .radar-source-box > a:hover,
.radar-related .radar-source-box .radar-source-cta:hover,
.radar-related .radar-source-box > a:hover {
  background: var(--radar-amber-dark) !important;
  border-color: var(--radar-amber-dark);
  color: var(--radar-bg) !important;
  transform: translateY(-1px);
}

.radar-source-box p,
.radar-newsletter-box p {
  color: var(--radar-deep);
}

.radar-source-box,
.radar-newsletter-box,
.rci-form,
.rci-support-box,
.radar-comment-form-wrap {
  box-shadow: none;
}

.radar-comments-inner {
  max-width: 920px;
}

.comment-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
  align-items: start;
}

.comment-notes,
.comment-form-comment,
.comment-form-cookies-consent,
.form-submit,
.logged-in-as {
  grid-column: 1 / -1;
}

.comment-form-url {
  display: none;
}

.comment-form textarea,
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"] {
  min-height: 46px;
  border: 2px solid rgba(21,80,91,.28);
  background: #fff;
}

.comment-form textarea {
  min-height: 170px;
  resize: vertical;
}

.comment-form textarea:focus,
.comment-form input:focus,
.rci-form input:focus,
.rci-form textarea:focus,
.rci-form select:focus {
  border-color: var(--radar-keppel);
  outline: 3px solid rgba(216,135,24,.25);
  outline-offset: 0;
}

.comment-form-cookies-consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.comment-form-cookies-consent input {
  width: auto;
  margin-top: 5px;
}

.radar-comment-submit,
.form-submit input[type="submit"],
.rci-form button,
.rci-button {
  background: var(--radar-deep);
  color: var(--radar-bg) !important;
  border: 2px solid var(--radar-deep);
}

.radar-comment-submit:hover,
.form-submit input[type="submit"]:hover,
.rci-form button:hover,
.rci-button:hover {
  background: var(--radar-amber-dark);
  border-color: var(--radar-amber-dark);
  color: var(--radar-bg) !important;
}

.rci-newsletter-form.is-compact button {
  white-space: nowrap;
}

.radar-footer .radar-logo,
.radar-footer a {
  color: var(--radar-bg);
}

.radar-footer-menu a:hover {
  color: var(--radar-bg);
  background: rgba(237,246,246,.10);
}

@media (max-width: 1180px) {
  .radar-nav a,
  .radar-nav button,
  .radar-support-link {
    padding-inline: 13px;
    font-size: 18px;
  }
  .radar-support-link { min-width: 150px; }
}

@media (max-width: 980px) {
  .radar-nav a:nth-of-type(n+4) {
    display: none;
  }
  .radar-city-chip { max-width: 145px !important; }
}

@media (max-width: 860px) {
  .radar-header .radar-nav-shell,
  .radar-home-nav,
  .home .radar-home-nav,
  .home .radar-home-nav .radar-nav-shell {
    display: none !important;
  }

  .radar-brand-panel,
  .home .radar-brand-panel {
    width: 100%;
    max-width: 100%;
    justify-content: flex-start;
  }

  .radar-city-strip-inner {
    padding: 14px 18px;
    gap: 10px;
  }

  .radar-city-strip span {
    display: none;
  }

  .radar-city-select,
  .radar-city-actions,
  .radar-city-actions .radar-btn {
    width: 100%;
  }

  .radar-city-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .radar-article-meta-row,
  .radar-author-block {
    align-items: flex-start;
  }

  .radar-share-wrap,
  .radar-share {
    width: 100%;
  }
  .radar-share { justify-content: center; }

  .radar-featured-full img {
    max-height: 420px;
    object-fit: cover;
  }

  .radar-article-content > p:first-child::first-letter {
    font-size: 72px;
  }

  .radar-source-box,
  .radar-newsletter-box {
    border-width: 4px;
    padding: 20px;
  }

  .radar-source-box .radar-source-cta,
  .radar-source-box > a,
  .radar-article-content .radar-source-box .radar-source-cta,
  .radar-article-content .radar-source-box > a,
  .radar-related .radar-source-box .radar-source-cta,
  .radar-related .radar-source-box > a {
    width: 100%;
    text-align: center;
  }

  .comment-form {
    grid-template-columns: 1fr;
  }

  .radar-footer {
    padding: 44px 20px;
  }
}

@media (max-width: 560px) {
  .radar-drawer {
    inset: 0;
    width: 100vw;
    max-width: 100vw;
    padding: 24px 24px 36px;
  }

  .radar-drawer-menu a,
  .radar-drawer-secondary a {
    font-size: 20px;
    line-height: 1.05;
    overflow-wrap: anywhere;
  }

  .radar-city-actions {
    grid-template-columns: 1fr;
  }

  .radar-related-inner,
  .radar-comments-inner {
    padding-inline: 18px;
  }

  .radar-comment-form-wrap {
    padding: 18px;
  }

  .radar-newsletter-box h2,
  .radar-source-box h2 {
    font-size: 34px;
  }
}

/* === Radar v4.1.0: auditoria 3x — cidade, mobile e rodapé === */
:root {
  --radar-card-shadow: 0 1px 0 rgba(21,80,91,.12);
}

/* Página de cidade: remove aparência quebrada dos cards e evita imagens gigantes/cortadas demais */
.radar-city-page .radar-archive-head,
.radar-city-archive-head {
  padding-top: clamp(34px, 5vw, 64px);
  padding-bottom: clamp(24px, 3vw, 36px);
  overflow: hidden;
}
.radar-city-page .radar-archive-title,
.radar-city-archive-head .radar-archive-title {
  font-size: clamp(48px, 8vw, 92px);
  line-height: .88;
  max-width: 100%;
  overflow-wrap: anywhere;
}
.radar-city-page .radar-archive-description,
.radar-city-archive-head .radar-archive-description {
  font-size: clamp(19px, 2.1vw, 26px);
  line-height: 1.45;
  color: var(--radar-muted);
}
.radar-city-list-section {
  padding-top: clamp(34px, 4vw, 54px);
}
.radar-city-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 30px;
  align-items: stretch;
}
.radar-city-card {
  min-width: 0;
  background: var(--radar-surface);
  border: 1px solid rgba(21,80,91,.14);
  border-top: 8px solid var(--radar-deep);
  box-shadow: var(--radar-card-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.radar-city-card-media {
  display: block;
  width: 100%;
  background: var(--radar-soft);
  overflow: hidden;
}
.radar-city-card-media img,
.radar-city-card img {
  width: 100%;
  max-width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center;
  display: block;
  margin: 0;
}
.radar-city-card-text {
  min-width: 0;
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}
.radar-city-card .radar-rule {
  width: 74px;
  height: 7px;
  margin-bottom: 18px;
}
.radar-city-card .radar-card-kicker {
  font-size: 22px;
  margin-bottom: 12px;
  color: var(--radar-keppel);
}
.radar-city-card h2 {
  font-size: clamp(26px, 2.15vw, 36px);
  line-height: .98;
  margin: 0 0 14px;
  overflow-wrap: anywhere;
}
.radar-city-card .radar-excerpt {
  font-size: 18px;
  line-height: 1.38;
  margin-bottom: 16px;
}
.radar-city-card .radar-meta-mono {
  margin-top: auto;
}

/* Arquivos gerais: reduz chance de estouro em textos longos */
.radar-archive-card,
.radar-related-card,
.radar-stream-item,
.radar-top-grid,
.radar-rail-card,
.radar-article-content,
.radar-source-box,
.radar-newsletter-box,
.rci-form,
.rci-support-box,
.radar-comment-form-wrap {
  min-width: 0;
}
.radar-archive-card h2,
.radar-related-card h3,
.radar-stream-title,
.radar-card-title,
.radar-rail-title,
.radar-article-title,
.radar-section-title {
  overflow-wrap: anywhere;
}

/* City strip: desktop limpo, mobile sem empurrar a largura */
.radar-city-strip-inner > * { min-width: 0; }
.radar-city-strip .radar-city-select { max-width: min(360px, 100%); }
.radar-city-actions .radar-btn { white-space: nowrap; }

/* Rodapé: impede estouro lateral, inclusive com logo textual */
.radar-footer,
.radar-footer * {
  box-sizing: border-box;
}
.radar-footer {
  overflow: hidden;
}
.radar-footer-inner,
.radar-footer-inner > *,
.radar-footer nav,
.radar-footer-menu,
.radar-footer-menu li {
  min-width: 0;
  max-width: 100%;
}
.radar-footer .radar-logo {
  max-width: 100%;
  font-size: clamp(31px, 5vw, 40px);
}
.radar-footer .radar-logo-text {
  max-width: 100%;
  padding-right: 18px;
}
.radar-footer p,
.radar-footer-menu a {
  overflow-wrap: anywhere;
  word-break: normal;
}

/* Drawer e topo: sem overflow lateral em celular */
.radar-drawer,
.radar-drawer * {
  max-width: 100%;
  box-sizing: border-box;
}
.radar-drawer .radar-logo-text {
  padding-right: 18px;
}
.radar-brand-panel,
.radar-brand-panel * {
  min-width: 0;
}

@media (max-width: 1180px) {
  .radar-city-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .radar-city-page .radar-archive-head,
  .radar-city-archive-head {
    padding: 34px 18px 22px;
  }
  .radar-city-page .radar-archive-title,
  .radar-city-archive-head .radar-archive-title {
    font-size: clamp(44px, 14vw, 64px);
    letter-spacing: 0;
  }
  .radar-city-page .radar-archive-description,
  .radar-city-archive-head .radar-archive-description {
    font-size: 19px;
    max-width: 100%;
  }
  .radar-city-list-section {
    padding: 28px 18px 44px;
  }
  .radar-city-archive-grid,
  .radar-archive-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .radar-city-card-text {
    padding: 18px;
  }
  .radar-city-card h2 {
    font-size: clamp(28px, 8.5vw, 38px);
  }
  .radar-city-card .radar-excerpt {
    font-size: 18px;
  }
  .radar-city-strip-inner {
    width: 100%;
    max-width: 100%;
  }
  .radar-city-strip .radar-city-select {
    max-width: 100%;
  }
  .radar-city-actions {
    width: 100%;
  }
  .radar-city-actions .radar-btn {
    min-width: 0;
    white-space: normal;
    text-align: center;
  }
  .radar-footer-inner {
    grid-template-columns: 1fr !important;
    gap: 26px;
  }
  .radar-footer-menu {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .radar-footer-menu a {
    font-size: 19px;
    line-height: 1.05;
  }
}

@media (max-width: 420px) {
  .radar-brand-panel,
  .home .radar-brand-panel {
    padding-left: 18px;
    padding-right: 18px;
    gap: 18px;
  }
  .radar-logo {
    font-size: 27px;
    letter-spacing: -1.1px;
  }
  .radar-city-page .radar-archive-title,
  .radar-city-archive-head .radar-archive-title {
    font-size: clamp(40px, 13vw, 56px);
  }
  .radar-section-title {
    font-size: clamp(42px, 13vw, 58px);
  }
  .radar-footer {
    padding-left: 18px;
    padding-right: 18px;
  }
}

/* Auditoria final v4.1.0: hero mobile sem vazamento visual do link inline */
.radar-hero-title a {
  display: block;
  max-width: 100%;
  overflow-wrap: anywhere;
}
