/* ============================================================
   blog.css
   Desktop 1440px: filter tags + 2-column horizontal card grid
   Mobile  370px:  scrollable tags, single column cards
   ============================================================ */

/* ── Section ────────────────────────────────────────────────── */
section.blog {
  padding-top:    calc(40 / var(--vw-base) * 100vw);
  padding-bottom: calc(40 / var(--vw-base) * 100vw);
  background-color: var(--color-bg);
}

/* ── Container ───────────────────────────────────────────────── */
section.blog .container {
  display: flex;
  flex-direction: column;
  gap: calc(30 / var(--vw-base) * 100vw);
}

/* ── Title ────────────────────────────────────────────────────── */
.blog__title {
  font-size:   calc(35 / var(--vw-base) * 100vw);
  font-weight: 600;
  line-height: 1.14;
  color: var(--color-text);
}

/* ── Filter tags ──────────────────────────────────────────────── */
.blog__filters {
  display: flex;
  flex-wrap: wrap;
  gap: calc(10 / var(--vw-base) * 100vw);
}

.blog__filter {
  display: flex;
  align-items: center;
  justify-content: center;
  height: calc(40 / var(--vw-base) * 100vw);
  padding: 0 calc(20 / var(--vw-base) * 100vw);
  border: 1px solid var(--color-red);
  border-radius: calc(20 / var(--vw-base) * 100vw);
  font-family: 'Inter', sans-serif;
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 500;
  line-height: 1;
  color: var(--color-red);
  background-color: transparent;
  cursor: pointer;
  transition: background-color 0.2s, color 0.2s;
}
.blog__filter:hover {
  background-color: rgba(234, 51, 35, 0.05);
}
.blog__filter.-active {
  color: var(--color-white);
  background-color: var(--color-red);
  border-color: var(--color-red);
}

/* ── Grid ─────────────────────────────────────────────────────── */
.blog__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc(30 / var(--vw-base) * 100vw);
}

/* ── Card (horizontal) ────────────────────────────────────────── */
.blog__card {
  display: flex;
  align-items: center;
  gap: calc(20 / var(--vw-base) * 100vw);
  padding: calc(15 / var(--vw-base) * 100vw);
  border-radius: calc(20 / var(--vw-base) * 100vw);
  background-color: var(--color-white);
  transition: box-shadow 0.2s;
}
.blog__card:hover {
  box-shadow: 0 4px 20px rgba(14, 13, 13, 0.08);
}

.blog__card.-hidden {
  display: none;
}

.blog__card-image {
  flex-shrink: 0;
  width:  calc(205 / var(--vw-base) * 100vw);
  height: calc(170 / var(--vw-base) * 100vw);
  border-radius: calc(10 / var(--vw-base) * 100vw);
  object-fit: cover;
}

.blog__card-body {
  display: flex;
  flex-direction: column;
  gap: calc(15 / var(--vw-base) * 100vw);
}

.blog__card-title {
  font-size:   calc(18 / var(--vw-base) * 100vw);
  font-weight: 600;
  line-height: 1.11;
  color: var(--color-text);
}

.blog__card-desc {
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 400;
  line-height: 1.43;
  color: var(--color-text);
}

.blog__card-link {
  display: inline-flex;
  align-items: center;
  gap: calc(6 / var(--vw-base) * 100vw);
  font-size:   calc(14 / var(--vw-base) * 100vw);
  font-weight: 600;
  line-height: 1.14;
  color: var(--color-red);
  transition: opacity 0.2s;
}
.blog__card:hover .blog__card-link { opacity: 0.7; }

.blog__card-link-arrow {
  width:  calc(8 / var(--vw-base) * 100vw);
  height: calc(8 / var(--vw-base) * 100vw);
  fill: none;
  stroke: var(--color-red);
  stroke-width: 2;
}

/* ============================================================
   MOBILE  (max-width: 767px)
   ============================================================ */
@media (max-width: 767px) {
  section.blog {
    padding-top:    calc(15 / var(--vw-base) * 100vw);
    padding-bottom: calc(15 / var(--vw-base) * 100vw);
  }

  section.blog .container {
    gap: calc(20 / var(--vw-base) * 100vw);
  }

  .blog__title {
    font-size:   calc(26 / var(--vw-base) * 100vw);
    line-height: 1.15;
  }

  /* Scrollable tags on mobile */
  .blog__filters {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: calc(8 / var(--vw-base) * 100vw);
  }
  .blog__filters::-webkit-scrollbar { display: none; }

  .blog__filter {
    flex-shrink: 0;
    height: calc(32 / var(--vw-base) * 100vw);
    padding: 0 calc(12 / var(--vw-base) * 100vw);
    border-radius: calc(16 / var(--vw-base) * 100vw);
    font-size: calc(12 / var(--vw-base) * 100vw);
  }

  .blog__grid {
    grid-template-columns: 1fr;
    gap: calc(15 / var(--vw-base) * 100vw);
  }

  .blog__card {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 0;
    border-radius: calc(10 / var(--vw-base) * 100vw);
    overflow: hidden;
  }

  .blog__card-image {
    width: 100%;
    height: calc(180 / var(--vw-base) * 100vw);
    border-radius: 0;
  }

  .blog__card-body {
    gap: calc(10 / var(--vw-base) * 100vw);
    padding: calc(15 / var(--vw-base) * 100vw);
  }

  .blog__card-title {
    font-size:   calc(16 / var(--vw-base) * 100vw);
    line-height: 1.25;
  }

  .blog__card-desc {
    font-size:   calc(13 / var(--vw-base) * 100vw);
    line-height: 1.38;
  }

  .blog__card-link {
    font-size: calc(13 / var(--vw-base) * 100vw);
  }
}
