/* ============================================================
   Complya — site-blog.css
   ============================================================ */

.blog-hero { text-align: center; }

.blog-layout { display: grid; grid-template-columns: 260px 1fr; gap: 48px; align-items: start; }
@media (max-width: 900px) { .blog-layout { grid-template-columns: 1fr; gap: 32px; } }

.blog-sidebar { position: sticky; top: 96px; }
@media (max-width: 900px) { .blog-sidebar { position: static; } }

.blog-side-block { margin-bottom: 32px; }
.blog-side-block h3 {
  font-size: .82rem; color: var(--ink-light);
  text-transform: uppercase; letter-spacing: .12em;
  margin: 0 0 12px; font-weight: 700;
}

.cat-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.cat-list li { --cat-color: var(--primary); }
.cat-list a {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: 8px;
  color: var(--ink); font-size: .94rem;
  transition: background .15s, color .15s;
}
.cat-list a:hover { background: var(--bg-alt); color: var(--cat-color); }
.cat-list li.is-active a { background: var(--bg-alt); color: var(--cat-color); font-weight: 600; }
.cat-list i { color: var(--cat-color); }
.cat-count {
  margin-left: auto;
  background: var(--line-soft); color: var(--ink-light);
  padding: 1px 8px; border-radius: 999px;
  font-size: .78rem; font-weight: 600;
}
.cat-list li.is-active .cat-count { background: var(--cat-color); color: #fff; }

.tag-cloud { display: flex; flex-wrap: wrap; gap: 6px; }
.tag {
  --tag-color: var(--primary);
  display: inline-flex; align-items: center;
  font-size: .78rem; font-weight: 500;
  background: var(--bg-alt); color: var(--tag-color);
  padding: 4px 10px; border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--tag-color) 20%, transparent);
}

.post-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
@media (max-width: 700px) { .post-grid { grid-template-columns: 1fr; } }

.post-card {
  display: flex; flex-direction: column;
  background: #fff; border: 1px solid var(--line);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: border-color .15s, box-shadow .15s, transform .15s;
}
.post-card:hover { border-color: rgba(15,118,110,.35); box-shadow: var(--shadow); transform: translateY(-2px); }
.post-card.is-featured { border-color: var(--primary); box-shadow: 0 8px 24px rgba(15,118,110,.08); }

.post-card-img { display: block; aspect-ratio: 16 / 9; overflow: hidden; background: var(--bg-alt); }
.post-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .3s; }
.post-card:hover .post-card-img img { transform: scale(1.03); }
.post-card-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 3rem; }

.post-card-body { padding: 20px 22px; display: flex; flex-direction: column; flex: 1; }

.post-cat {
  --cat-color: var(--primary);
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .76rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--cat-color); margin-bottom: 10px;
}
.post-cat-lg { font-size: .82rem; background: color-mix(in srgb, var(--cat-color) 10%, transparent); padding: 4px 12px; border-radius: 999px; margin-bottom: 12px; }
.post-cat:hover { color: var(--cat-color); filter: brightness(.85); }

.post-card-title {
  margin: 0 0 8px; font-size: 1.15rem; line-height: 1.35;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600; letter-spacing: -0.01em;
}
.post-card-title a { color: var(--ink); }
.post-card-title a:hover { color: var(--primary); }

.post-card-resumo { color: var(--ink-light); font-size: .94rem; margin: 0 0 16px; flex: 1; }

.post-card-meta { display: flex; gap: 16px; color: var(--ink-light); font-size: .82rem; margin-top: auto; }
.post-card-meta span { display: inline-flex; align-items: center; gap: 4px; }
.post-card-meta i { color: var(--ink-light); }

.pagination {
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px; margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--line);
}
.pag-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 16px; border: 1px solid var(--line); border-radius: var(--radius);
  background: #fff; color: var(--ink); font-weight: 500; font-size: .92rem;
  transition: border-color .15s, background .15s;
}
.pag-btn:hover { border-color: var(--primary); color: var(--primary); background: var(--bg-alt); }
.pag-btn.is-disabled { opacity: .5; cursor: default; }
.pag-btn.is-disabled:hover { border-color: var(--line); color: var(--ink); background: #fff; }
.pag-info { color: var(--ink-light); font-size: .92rem; }

.blog-empty {
  text-align: center; padding: 64px 24px;
  border: 1px dashed var(--line); border-radius: var(--radius-lg);
  color: var(--ink-light);
}
.blog-empty i { font-size: 3rem; color: var(--line); display: block; margin-bottom: 16px; }
.blog-empty p { margin-bottom: 20px; }

.post-hero { padding: 56px 0 32px; background: radial-gradient(60% 70% at 80% 0%, var(--bg-alt) 0%, transparent 60%), #fff; }
.post-hero .crumbs { font-size: .9rem; color: var(--ink-light); margin-bottom: 20px; }
.post-hero .crumbs a { color: var(--ink-light); }
.post-hero .crumbs a:hover { color: var(--post-color, var(--primary)); }
.post-hero .crumb-sep { margin: 0 6px; color: var(--line); }

.post-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 700; letter-spacing: -0.02em;
  line-height: 1.2; margin: 8px 0 12px;
}

.post-sub { color: var(--ink-light); font-size: 1.15rem; line-height: 1.5; margin: 0 0 20px; }

.post-meta {
  display: flex; gap: 20px; flex-wrap: wrap;
  color: var(--ink-light); font-size: .9rem;
  padding: 16px 0;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.post-meta span { display: inline-flex; align-items: center; gap: 6px; }

.post-hero-img { margin: 32px 0 0; }
.post-hero-img img { width: 100%; max-height: 480px; object-fit: cover; border-radius: var(--radius-lg); display: block; }
.post-hero-img figcaption { text-align: center; color: var(--ink-light); font-size: .82rem; margin-top: 8px; }

.post-body-section { padding: 40px 0 64px; }

.post-chamada {
  font-size: 1.15rem; line-height: 1.6; color: var(--ink);
  padding: 20px 24px; background: var(--bg-alt);
  border-left: 4px solid var(--post-color, var(--primary));
  border-radius: 0 var(--radius) var(--radius) 0;
  margin: 0 0 32px;
}

.post-body { font-size: 1.05rem; line-height: 1.8; }

.post-conclusao { margin: 40px 0; padding: 24px 28px; background: var(--bg-alt); border-radius: var(--radius-lg); }
.post-conclusao h2 { margin: 0 0 8px; font-size: 1.2rem; color: var(--post-color, var(--primary)); }
.post-conclusao p { margin: 0; }

.post-tags { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin: 40px 0 24px; padding-top: 24px; border-top: 1px solid var(--line); }
.post-tags-label { color: var(--ink-light); font-size: .9rem; font-weight: 600; margin-right: 4px; }

.post-share { display: flex; align-items: center; gap: 12px; padding-top: 16px; }
.post-share-label { color: var(--ink-light); font-size: .9rem; font-weight: 600; margin-right: 4px; }
.post-share a {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--bg-alt); color: var(--primary);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1.05rem; transition: background .15s, color .15s;
}
.post-share a:hover { background: var(--primary); color: #fff; }
/* ============================================================
   FRONTEND PUBLICO — BLOCOS MODULARES E MIDIAS POR POSIÇÃO
   (anexar ao final de site-blog.css)
   ============================================================ */

/* ==================== MIDIAS POR POSIÇÃO ==================== */
.post-midia {
  margin: 1.8em 0;
}
.post-midia img,
.post-midia video {
  display: block;
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}
.post-midia-cap {
  margin-top: .5em;
  font-size: .85rem;
  color: #64748b;
  line-height: 1.4;
}
.post-midia-cap-legenda { display: block; font-style: italic; }
.post-midia-cap-credito { display: block; opacity: .8; font-size: .8rem; }
.post-midia-cap-credito::before { content: '— '; }

/* Estilos das mídias */
.post-midia-padrao {}
.post-midia-destaque {
  box-shadow: 0 12px 30px rgba(15, 23, 42, .15);
  border-radius: 10px;
  overflow: hidden;
  transition: transform .25s, box-shadow .25s;
}
.post-midia-destaque:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 42px rgba(15, 23, 42, .22);
}
.post-midia-quote {
  border-left: 4px solid var(--post-color, #0F766E);
  background: #f0fdfa;
  padding: 14px 18px;
  border-radius: 0 8px 8px 0;
}
.post-midia-quote img { border-radius: 4px; }
.post-midia-full-width {
  margin-left: calc(-1 * var(--wrap-narrow-margin, 0px));
  margin-right: calc(-1 * var(--wrap-narrow-margin, 0px));
  width: auto;
  max-width: none;
  border-radius: 0;
}
.post-midia-full-width img,
.post-midia-full-width video {
  width: 100%;
  border-radius: 0;
}
.post-midia-compacto {
  max-width: 75%;
  margin-left: auto;
  margin-right: auto;
}

/* Documento (PDF) */
.post-midia-doc-link {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  background: #fef9c3;
  border: 1px solid #fde047;
  border-radius: 10px;
  color: #713f12;
  text-decoration: none;
  transition: background .15s, border-color .15s;
}
.post-midia-doc-link:hover {
  background: #fef08a;
  border-color: #facc15;
}
.post-midia-doc-link > i:first-child {
  font-size: 2rem;
  color: #b91c1c;
  flex-shrink: 0;
}
.post-midia-doc-title { font-weight: 600; flex: 1; }
.post-midia-doc-meta { font-size: .82rem; opacity: .8; }

/* Embed responsivo */
.post-midia-embed {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: 8px;
}
.post-midia-embed iframe {
  width: 100%;
  min-height: 360px;
  border: 0;
}

/* Galeria seção dedicada */
.post-galeria {
  margin: 3em 0;
  padding: 2em 0;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
}
.post-galeria-title {
  margin: 0 0 1.2em;
  font-size: 1.2rem;
  color: #0f172a;
  display: flex;
  align-items: center;
  gap: 8px;
}
.post-galeria-title i { color: var(--post-color, #0F766E); }
.post-galeria-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}
.post-galeria-grid .post-midia { margin: 0; }
.post-galeria-grid img { aspect-ratio: 4/3; object-fit: cover; }

/* Hero — múltiplas mídias no cabeçalho */
.post-hero-midias {
  margin-top: 2em;
}
.post-hero-midias .post-midia { margin: 1em 0; }

/* Posições genéricas */
.post-pos { margin: 2em 0; }
.post-pos-topo { padding: 2em 0; background: linear-gradient(180deg, #f8fafc, transparent); }
.post-pos-rodape { margin-top: 3em; padding-top: 2em; border-top: 1px solid #e5e7eb; }

/* ==================== BLOCOS MODULARES ==================== */
.bloco { margin: 2em 0; }
.bloco-h {
  margin: 0 0 .6em;
  font-size: 1.25rem;
  color: #0f172a;
  font-weight: 600;
}
.bloco-sub { color: #64748b; margin: 0 0 1em; }

/* Alinhamento */
.bloco-align-left   { text-align: left; }
.bloco-align-center { text-align: center; }
.bloco-align-right  { text-align: right; }
.bloco-align-full   { width: 100%; }
.bloco-align-center img { margin-left: auto; margin-right: auto; display: block; }
.bloco-align-right  img { margin-left: auto; display: block; }

/* Titulo bloco */
.bloco-titulo {
  margin: 1.5em 0 .8em;
  color: #0f172a;
  line-height: 1.25;
}

/* Texto bloco — conteudo HTML do TinyMCE */
.bloco-texto > * { max-width: 100%; }

/* Citação */
.bloco-citacao {
  margin: 2em 0;
  padding: 1.4em 1.8em;
  background: #f0fdfa;
  border-left: 5px solid var(--post-color, #0F766E);
  border-radius: 0 10px 10px 0;
  position: relative;
}
.bloco-citacao > p {
  font-size: 1.15rem;
  font-style: italic;
  color: #134e4a;
  margin: 0 0 .8em;
  line-height: 1.6;
}
.bloco-citacao > p::before { content: '“'; font-size: 1.5em; opacity: .5; }
.bloco-citacao > p::after  { content: '”'; font-size: 1.5em; opacity: .5; }
.bloco-citacao cite {
  display: block;
  font-style: normal;
  font-size: .9rem;
  color: #475569;
}
.bloco-citacao cite strong { color: #0f172a; }
.bloco-citacao cite span::before { content: ' · '; opacity: .5; }

/* Imagem bloco */
.bloco-imagem {
  margin: 2em 0;
}
.bloco-imagem img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
}
.bloco-imagem figcaption {
  margin-top: .5em;
  font-size: .85rem;
  color: #64748b;
  text-align: center;
  font-style: italic;
}

/* Galeria bloco (dentro do post) */
.bloco-galeria-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
}
.bloco-galeria-grid figure { margin: 0; }
.bloco-galeria-grid img {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  border-radius: 6px;
  transition: transform .2s;
}
.bloco-galeria-grid img:hover { transform: scale(1.02); }

/* Vídeo bloco */
.bloco-video-frame {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  border-radius: 10px;
  overflow: hidden;
  background: #000;
}
.bloco-video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.bloco-video video { width: 100%; border-radius: 10px; }

/* Lista bloco */
.bloco-lista {
  margin: 1.5em 0;
  padding-left: 1.5em;
}
.bloco-lista li { margin: .4em 0; line-height: 1.6; }
.bloco-lista-icone {
  list-style: none;
  padding-left: 0;
}
.bloco-lista-icone li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: .6em 0;
}
.bloco-lista-icone li i {
  color: var(--post-color, #0F766E);
  font-size: 1.15rem;
  flex-shrink: 0;
  margin-top: 2px;
}

/* CTA bloco */
.bloco-cta {
  margin: 2.5em 0;
  padding: 0;
  background: linear-gradient(135deg, #0F766E, #134e4a);
  border-radius: 14px;
  color: #fff;
  overflow: hidden;
}
.bloco-cta-inner {
  padding: 2em;
  text-align: center;
}
.bloco-cta h3 { color: #fff; font-size: 1.4rem; margin: 0 0 .5em; }
.bloco-cta p  { color: #ccfbf1; margin: 0 0 1em; font-size: 1rem; }
.bloco-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  background: #fff;
  color: #0F766E !important;
  border-radius: 999px;
  font-weight: 600;
  text-decoration: none;
  transition: transform .15s, box-shadow .15s;
}
.bloco-cta-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0,0,0,.2);
}

/* Aviso bloco */
.bloco-aviso {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin: 1.6em 0;
  padding: 14px 18px;
  border-radius: 10px;
  border-left: 4px solid;
}
.bloco-aviso > i { font-size: 1.3rem; flex-shrink: 0; margin-top: 2px; }
.bloco-aviso strong { display: block; margin-bottom: .3em; }
.bloco-aviso p { margin: 0; line-height: 1.5; }
.bloco-aviso-info    { background: #eff6ff; border-color: #2563eb; color: #1e3a8a; }
.bloco-aviso-info > i    { color: #2563eb; }
.bloco-aviso-success { background: #f0fdf4; border-color: #16a34a; color: #14532d; }
.bloco-aviso-success > i { color: #16a34a; }
.bloco-aviso-warning { background: #fefce8; border-color: #ca8a04; color: #713f12; }
.bloco-aviso-warning > i { color: #ca8a04; }
.bloco-aviso-danger  { background: #fef2f2; border-color: #dc2626; color: #7f1d1d; }
.bloco-aviso-danger > i  { color: #dc2626; }

/* Divisor bloco */
.bloco-divisor {
  margin: 3em auto;
  width: 60px;
  border: 0;
  border-top: 3px solid var(--post-color, #0F766E);
  opacity: .6;
}

/* Código bloco */
.bloco-codigo {
  margin: 1.8em 0;
  border-radius: 10px;
  overflow: hidden;
  background: #0f172a;
}
.bloco-codigo-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  background: #1e293b;
  color: #e2e8f0;
  font-size: .82rem;
}
.bloco-codigo-head small {
  color: #94a3b8;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: .7rem;
}
.bloco-codigo pre {
  margin: 0;
  padding: 16px 18px;
  background: #0f172a;
  color: #e2e8f0;
  overflow-x: auto;
  font-size: .85rem;
  line-height: 1.55;
  font-family: 'SF Mono', Monaco, Consolas, 'Liberation Mono', monospace;
}

/* Embed bloco */
.bloco-embed iframe {
  width: 100%;
  border: 0;
  border-radius: 8px;
}

/* Tags, Autor, Relacionados, Conclusao */
.post-tags {
  margin: 2em 0 1em;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.post-tags-label {
  font-size: .9rem;
  color: #64748b;
  margin-right: 6px;
}
.post-tag {
  display: inline-block;
  padding: 4px 12px;
  background: #f1f5f9;
  color: #475569;
  border-radius: 999px;
  font-size: .82rem;
  text-decoration: none;
  transition: background .15s, color .15s;
}
.post-tag:hover { background: var(--post-color, #0F766E); color: #fff; }

.post-conclusao {
  margin-top: 2em;
  padding: 1.4em 1.6em;
  background: #f8fafc;
  border-radius: 10px;
  border-left: 4px solid var(--post-color, #0F766E);
  font-size: 1.05rem;
  line-height: 1.6;
}

.post-cta-final {
  margin: 2.5em 0;
  padding: 1.8em;
  background: linear-gradient(135deg, var(--post-color, #0F766E), #134e4a);
  border-radius: 14px;
  color: #fff;
  text-align: center;
}
.post-cta-final h3 { color: #fff; margin: 0 0 .6em; font-size: 1.3rem; }
.post-cta-final p  { color: rgba(255,255,255,.9); margin: 0 0 1em; }
.post-cta-final .btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  background: #fff;
  color: var(--post-color, #0F766E) !important;
  border-radius: 999px;
  font-weight: 600;
  text-decoration: none;
}

.post-autor {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin: 2.5em 0;
  padding: 1.4em;
  background: #f8fafc;
  border-radius: 12px;
}
.post-autor-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.post-autor strong { color: #0f172a; font-size: 1.05rem; display: block; margin-bottom: .3em; }
.post-autor p { color: #475569; margin: 0; font-size: .9rem; line-height: 1.5; }

.post-relacionados {
  margin: 3em 0 1em;
}
.post-relacionados h3 {
  font-size: 1.15rem;
  color: #0f172a;
  margin: 0 0 1.2em;
  display: flex;
  align-items: center;
  gap: 8px;
}
.post-relacionados h3 i { color: var(--post-color, #0F766E); }
.post-relacionados-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}
.post-relacionado-card {
  display: block;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform .15s, box-shadow .15s;
}
.post-relacionado-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,.08);
}
.post-relacionado-card img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.post-relacionado-card > div { padding: 12px 14px; }
.post-relacionado-cat {
  display: inline-block;
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--post-color, #0F766E);
  font-weight: 600;
  margin-bottom: 4px;
}
.post-relacionado-card strong {
  display: block;
  font-size: .98rem;
  color: #0f172a;
  margin-bottom: .3em;
  line-height: 1.3;
}
.post-relacionado-card small {
  color: #64748b;
  font-size: .82rem;
  line-height: 1.5;
}

/* Mobile */
@media (max-width: 600px) {
  .post-galeria-grid { grid-template-columns: repeat(2, 1fr); }
  .bloco-galeria-grid { grid-template-columns: repeat(2, 1fr); }
  .post-midia-compacto { max-width: 100%; }
  .bloco-cta-inner, .post-cta-final { padding: 1.4em; }
}
