/* ─── Blog List Page ──────────────────────────────────────── */

.bl-wrap {
  width: min(1200px, 92%);
  margin-inline: auto;
  padding: 28px 0 56px;
}

/* ─── Head ─────────────────────────────────────────────────── */
.bl-head { padding-bottom: 18px; }

.bl-breadcrumb {
  display: flex; align-items: center; gap: 5px;
  flex-wrap: wrap; font-size: .82rem; opacity: .72;
  margin-bottom: 8px;
}
.bl-breadcrumb a { color: inherit; text-decoration: none; }
.bl-breadcrumb a:hover { color: var(--accent); }

.bl-title {
  margin: 0;
  font-size: 1.7rem; font-weight: 900; color: var(--accent);
}

/* ─── Controls ──────────────────────────────────────────────── */
.bl-controls {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  gap: 12px;
  margin-bottom: 24px;
}

/* Search */
.bl-search {
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 12px;
  padding: 10px 14px;
  grid-column: 1;
}
.bl-search-icon { font-size: .95rem; opacity: .7; flex-shrink: 0; }
.bl-search-input {
  flex: 1; min-width: 0;
  background: transparent; border: none; outline: none;
  color: var(--ink); font-size: .92rem; font-family: inherit;
}
.bl-search-input::placeholder { opacity: .5; color: var(--ink); }

/* Sort */
.bl-sort {
  display: flex; align-items: center; gap: 8px;
  grid-column: 2;
}
.bl-sort-lbl { font-size: .85rem; white-space: nowrap; opacity: .8; }
.bl-select {
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 10px;
  padding: 9px 12px;
  color: var(--ink);
  font-size: .88rem;
  font-family: inherit;
  cursor: pointer;
  outline: none;
}

/* Chips */
.bl-chips {
  grid-column: 1 / -1;
  display: flex; flex-wrap: wrap; gap: 8px;
}
.bl-chip {
  background: rgba(255,255,255,.12);
  color: var(--ink);
  border: 2px solid transparent;
  border-radius: 999px;
  padding: .35rem .85rem;
  font-size: .85rem; font-weight: 700;
  cursor: pointer; user-select: none;
  transition: background .15s, border-color .15s, color .15s;
  font-family: inherit;
}
.bl-chip:hover { background: rgba(255,255,255,.2); }
.bl-chip.active {
  background: transparent;
  border-color: var(--accent);
  color: var(--ink);
}

/* ─── Grid ──────────────────────────────────────────────────── */
.bl-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

/* ─── Card ──────────────────────────────────────────────────── */
.bl-card {
  /* NO position:absolute — stays in grid flow */
  display: flex; flex-direction: column;
  border-radius: 18px; overflow: hidden;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.13);
  box-shadow: 0 10px 36px rgba(0,0,0,.20);
  transition: transform .22s, box-shadow .22s;
}
.bl-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 18px 48px rgba(0,0,0,.30);
}

/* Image */
.bl-img-wrap {
  display: block; position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: rgba(255,255,255,.06);
  flex-shrink: 0;
}
.bl-img-wrap img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .35s;
}
.bl-card:hover .bl-img-wrap img { transform: scale(1.05); }
.bl-img-ph {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-size: 2.5rem; opacity: .3;
}

/* Card body */
.bl-card-body {
  padding: 14px 16px 18px;
  flex: 1; display: flex; flex-direction: column; gap: 8px;
}

/* Meta row */
.bl-meta {
  display: flex; align-items: center; gap: 7px;
  flex-wrap: wrap; font-size: .8rem; opacity: .8;
}
.bl-cat-badge {
  background: rgba(255,87,12,.15);
  color: var(--accent);
  border-radius: 999px;
  padding: .1rem .55rem;
  font-size: .76rem; font-weight: 800;
}
.bl-dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--accent); display: inline-block; flex-shrink: 0;
}

/* Title */
.bl-card-title {
  margin: 0;
  font-size: 1rem; font-weight: 800; line-height: 1.5;
}
.bl-card-title a {
  color: var(--ink); text-decoration: none;
}
.bl-card-title a:hover { color: var(--accent); }

/* Excerpt */
.bl-excerpt {
  margin: 0;
  font-size: .84rem; line-height: 1.75;
  opacity: .8;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Tags */
.bl-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: auto; }
.bl-tag {
  font-size: .78rem;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  padding: .15rem .55rem; border-radius: 6px;
}

/* Empty */
.bl-empty {
  grid-column: 1 / -1;
  text-align: center; padding: 60px 0; opacity: .6;
}

/* ─── More button ───────────────────────────────────────────── */
.bl-pager { display: flex; justify-content: center; padding: 24px 0 8px; }
.bl-more-btn {
  border: 2px solid rgba(255,255,255,.2);
  background: transparent; color: var(--ink);
  border-radius: 999px; font-weight: 800; font-size: .92rem;
  padding: .65rem 2rem; cursor: pointer; font-family: inherit;
  transition: background .18s, border-color .18s;
}
.bl-more-btn:hover { background: var(--accent); color: #1b1b1b; border-color: transparent; }

/* ─── Responsive — Tablet ≤1024px ──────────────────────────── */
@media (max-width: 1024px) {
  .bl-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
  .bl-title { font-size: 1.45rem; }
}

/* ─── Responsive — Large mobile ≤720px ─────────────────────── */
@media (max-width: 720px) {
  .bl-controls { grid-template-columns: 1fr; }
  .bl-sort { grid-column: 1; justify-content: flex-start; }
  .bl-select { flex: 1; }
}

/* ─── Responsive — Mobile ≤540px ───────────────────────────── */
@media (max-width: 540px) {
  .bl-wrap { padding: 18px 0 40px; }
  .bl-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
  .bl-card-body { padding: 10px 12px 14px; gap: 6px; }
  .bl-card-title { font-size: .88rem; }
  .bl-title { font-size: 1.25rem; }
}

/* ─── Responsive — Small mobile ≤380px ─────────────────────── */
@media (max-width: 380px) {
  .bl-grid { grid-template-columns: 1fr; }
}

/* ─── Light theme ────────────────────────────────────────────── */
html.theme-light .bl-search {
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.12);
}
html.theme-light .bl-search-input { color: var(--ink); }
html.theme-light .bl-search-input::placeholder { color: var(--ink); opacity: .4; }
html.theme-light .bl-select {
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.12);
  color: var(--ink);
}
html.theme-light .bl-chip {
  background: rgba(0,0,0,.08);
  color: var(--ink);
}
html.theme-light .bl-chip:hover { background: rgba(0,0,0,.14); }
html.theme-light .bl-chip.active {
  background: transparent;
  border-color: var(--accent);
}
html.theme-light .bl-card {
  background: #fff;
  border-color: rgba(0,0,0,.09);
  box-shadow: 0 5px 20px rgba(0,0,0,.09);
}
html.theme-light .bl-img-wrap { background: rgba(0,0,0,.04); }
html.theme-light .bl-tag {
  background: rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.12);
}
html.theme-light .bl-more-btn {
  border-color: rgba(0,0,0,.2);
}
