/* ═══════════════════════════════════════════════════════════
   NEWS DETAIL — Página de detalhe de notícia/aviso/novidade
   ═══════════════════════════════════════════════════════════ */

.page-news-detail {
  padding: var(--space-12) 0 var(--space-20);
  background: var(--color-bg);
  min-height: 60vh;
}

/* ── Container principal ── */
.news-detail__container {
  max-width: 56rem;
}

/* ── Breadcrumb ── */
.news-detail__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
  font-size: var(--text-sm);
  flex-wrap: wrap;
}

.news-detail__breadcrumb-link {
  color: var(--color-accent-text);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.news-detail__breadcrumb-link:hover {
  text-decoration: underline;
}

.news-detail__breadcrumb-sep {
  color: var(--color-text-muted);
}

.news-detail__breadcrumb-current {
  color: var(--color-text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 30ch;
}

/* ── Artigo ── */
.news-detail__article {
  background: var(--color-surface);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

/* ── Header ── */
.news-detail__header {
  padding: var(--space-8) var(--space-8) var(--space-6);
}

.news-detail__meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.news-detail__date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.news-detail__title {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, var(--text-section));
  font-weight: 700;
  color: var(--color-text-primary);
  line-height: 1.3;
  margin-bottom: var(--space-4);
}

.news-detail__excerpt {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  line-height: 1.6;
  font-style: italic;
  border-left: 3px solid var(--color-accent-border);
  padding-left: var(--space-4);
}

/* ── Imagem de capa ── */
.news-detail__cover {
  width: 100%;
  max-height: 22rem;
  overflow: hidden;
  background: var(--color-bg-muted);
}

.news-detail__cover-img {
  width: 100%;
  height: 22rem;
  object-fit: cover;
  display: block;
}

/* ── Corpo ── */
.news-detail__body {
  padding: var(--space-8);
}

.news-detail__text {
  color: var(--color-text-secondary);
  line-height: 1.75;
  font-size: var(--text-base);
}

/* ── Botão voltar ── */
.news-detail__back {
  margin-top: var(--space-8);
}

/* ── Not found ── */
.news-detail__not-found {
  text-align: center;
  padding: var(--space-20) var(--space-4);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.news-detail__not-found-icon {
  font-size: 3rem;
  color: var(--color-text-muted);
}

.news-detail__not-found-title {
  font-family: var(--font-heading);
  font-size: var(--text-section);
  font-weight: 700;
  color: var(--color-text-primary);
}

.news-detail__not-found-text {
  color: var(--color-text-secondary);
  max-width: 40ch;
}

/* ═══════════════════════════════════════════════════════════
   MARKDOWN CONTENT — estilos para conteúdo gerado pelo parser
   ═══════════════════════════════════════════════════════════ */

.markdown-content {
  color: var(--color-text-secondary);
  font-size: var(--text-base);
  line-height: 1.75;
}

/* Headings */
.markdown-content h1,
.markdown-content h2,
.markdown-content h3,
.markdown-content h4,
.markdown-content h5,
.markdown-content h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--color-text-primary);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
  line-height: 1.3;
}

.markdown-content h1 { font-size: clamp(1.5rem, 3vw, var(--text-section)); }
.markdown-content h2 { font-size: var(--text-xl); }
.markdown-content h3 { font-size: var(--text-lg); }
.markdown-content h4,
.markdown-content h5,
.markdown-content h6 { font-size: var(--text-base); }

/* Parágrafo */
.markdown-content p {
  margin-bottom: var(--space-4);
}

/* Links */
.markdown-content a {
  color: var(--color-accent-text);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--transition-fast);
}

.markdown-content a:hover {
  color: var(--color-accent-dark);
}

/* Listas */
.markdown-content ul,
.markdown-content ol {
  margin-bottom: var(--space-4);
  padding-left: var(--space-6);
}

.markdown-content li {
  margin-bottom: var(--space-2);
}

.markdown-content ul li { list-style-type: disc; }
.markdown-content ol li { list-style-type: decimal; }

/* Blockquote */
.markdown-content blockquote {
  border-left: 4px solid var(--color-accent-border);
  padding: var(--space-3) var(--space-5);
  margin: var(--space-6) 0;
  background: var(--color-accent-bg-light);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  color: var(--color-text-secondary);
  font-style: italic;
}

/* Código inline */
.markdown-content code {
  background: var(--color-bg-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 0.1em 0.4em;
  font-size: 0.9em;
  font-family: 'Courier New', monospace;
  color: var(--color-text-primary);
}

/* Bloco de código */
.markdown-content pre {
  background: var(--color-bg-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  overflow-x: auto;
  margin-bottom: var(--space-4);
}

.markdown-content pre code {
  background: none;
  border: none;
  padding: 0;
  font-size: var(--text-sm);
}

/* Tabelas */
.markdown-content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-6);
  font-size: var(--text-sm);
  overflow-x: auto;
  display: block;
}

.markdown-content th,
.markdown-content td {
  border: 1px solid var(--color-border);
  padding: var(--space-2) var(--space-4);
  text-align: left;
}

.markdown-content th {
  background: var(--color-bg-subtle);
  font-weight: 600;
  color: var(--color-text-primary);
}

.markdown-content tr:nth-child(even) td {
  background: var(--color-bg-subtle);
}

/* Linha horizontal */
.markdown-content hr {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: var(--space-8) 0;
}

/* Clearfix — evita que floats de imagens vazem para fora do conteúdo */
.markdown-content::after {
  content: '';
  display: table;
  clear: both;
}

/* Imagens soltas (markdown padrão) */
.markdown-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  margin: var(--space-4) 0;
  display: block;
}

/* Figures usados para float — reset de margem e linha */
.markdown-content figure {
  margin: 0;
  line-height: 0;
}

.markdown-content figure img {
  margin: 0;
  border-radius: var(--radius-md);
}

/* Strong / Em */
.markdown-content strong { font-weight: 700; color: var(--color-text-primary); }
.markdown-content em     { font-style: italic; }
