/* ============================================================
   FÁBRICA IMAGENS — blog.css
============================================================ */

/* Reusa .page-header, .filter-bar e .filter-btn do portfolio.css */
@import url('portfolio.css');

.blog-page {
  padding: 56px 0 100px;
}

/* --- POST EM DESTAQUE --- */
.post-destaque {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-bottom: 3px;
  border-bottom: 1px solid var(--border-soft);
}

.post-destaque__img-link {
  display: block;
  overflow: hidden;
}

.post-destaque__img-wrap {
  position: relative;
  height: 100%;
  min-height: 440px;
  background: var(--bg-card);
  overflow: hidden;
}

.post-destaque__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.post-destaque__img-link:hover img { transform: scale(1.04); }

.post-destaque__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--border);
}

.post-destaque__content {
  padding: 56px 56px 56px 64px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--bg-elevated);
}

.post-destaque__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}

.post-destaque__titulo {
  font-size: clamp(22px, 2.8vw, 36px);
  font-weight: 200;
  line-height: 1.25;
  letter-spacing: -0.01em;
  margin-bottom: 20px;
}

.post-destaque__titulo a {
  color: var(--text);
  transition: color 0.2s;
}

.post-destaque__titulo a:hover { color: var(--accent); }

.post-destaque__excerpt {
  font-size: 14px;
  color: var(--text-soft);
  line-height: 1.8;
  margin-bottom: 32px;
  max-width: 460px;
}

.post-destaque__link {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  transition: letter-spacing 0.2s;
  align-self: flex-start;
}

.post-destaque__link:hover { letter-spacing: 0.28em; }


/* --- TAGS E DATAS --- */
.post-tag {
  display: inline-block;
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 4px 10px;
  border: 1px solid var(--accent);
  color: var(--accent);
}

.post-date {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}


/* --- GRID DE POSTS --- */
.posts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
  margin-top: 3px;
}

.post-card {
  background: var(--bg-elevated);
  display: flex;
  flex-direction: column;
  transition: background 0.2s;
}

.post-card:hover { background: var(--bg-card); }

.post-card__img-link {
  display: block;
  overflow: hidden;
}

.post-card__img-wrap {
  position: relative;
  aspect-ratio: 16 / 10;
  background: var(--bg-card);
  overflow: hidden;
}

.post-card__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.post-card__img-link:hover img { transform: scale(1.04); }

.post-card__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--border);
}

.post-card__content {
  padding: 28px 28px 32px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.post-card__meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.post-card__titulo {
  font-size: 17px;
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 12px;
  flex: 1;
}

.post-card__titulo a {
  color: var(--text);
  transition: color 0.2s;
}

.post-card__titulo a:hover { color: var(--accent); }

.post-card__excerpt {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.75;
  margin-bottom: 20px;
  flex: 1;
}

.post-card__link {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  transition: letter-spacing 0.2s;
  align-self: flex-start;
}

.post-card__link:hover { letter-spacing: 0.28em; }

/* Filtro */
.post-card.hidden,
.post-destaque.hidden { display: none; }

.filter-empty {
  display: none;
  text-align: center;
  padding: 80px 0;
  font-size: 13px;
  color: var(--text-muted);
  letter-spacing: 0.05em;
}

.filter-empty.visible { display: block; }


/* --- RESPONSIVO --- */
@media (max-width: 900px) {
  .post-destaque {
    grid-template-columns: 1fr;
  }
  .post-destaque__img-wrap { min-height: 300px; }
  .post-destaque__content  { padding: 40px 32px; }

  .posts-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .posts-grid { grid-template-columns: 1fr; }
  .post-destaque__content { padding: 32px 20px; }
}
