    /* ── Blog Grid ── */
    .blog-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
      gap: 28px;
      margin-top: 48px;
    }

    .blog-card {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: 14px;
      overflow: hidden;
      transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
      display: flex;
      flex-direction: column;
    }

    .blog-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 12px 40px rgba(0,0,0,0.18);
      border-color: var(--color-accent);
    }

    .blog-card-img {
      width: 100%;
      aspect-ratio: 16 / 9;
      object-fit: cover;
      background: var(--color-border);
      border-radius: 14px 14px 0 0;
      display: block;
      min-height: 180px;
    }

    .blog-card-body {
      padding: 24px;
      display: flex;
      flex-direction: column;
      flex: 1;
    }

    .blog-card-tag {
      display: inline-block;
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--color-accent);
      background: rgba(var(--color-accent-rgb, 59,130,246), 0.1);
      border-radius: 20px;
      padding: 3px 10px;
      margin-bottom: 12px;
      width: fit-content;
    }

    .blog-card-title {
      font-size: 1.1rem;
      font-weight: 700;
      line-height: 1.4;
      color: var(--color-text);
      margin-bottom: 10px;
    }

    .blog-card-excerpt {
      font-size: 0.88rem;
      color: var(--color-muted);
      line-height: 1.65;
      flex: 1;
      margin-bottom: 20px;
    }

    .blog-card-meta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      font-size: 0.78rem;
      color: var(--color-muted);
      border-top: 1px solid var(--color-border);
      padding-top: 14px;
    }

    .blog-card-read {
      color: var(--color-accent);
      font-weight: 600;
      font-size: 0.82rem;
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 4px;
      transition: gap 0.15s ease;
    }

    .blog-card-read:hover { gap: 8px; }

    /* Coming soon placeholder */
    .blog-empty {
      text-align: center;
      padding: 72px 24px;
      color: var(--color-muted);
    }

    .blog-empty-icon {
      font-size: 3rem;
      margin-bottom: 20px;
    }

    .blog-empty h3 {
      font-size: 1.3rem;
      font-weight: 700;
      color: var(--color-text);
      margin-bottom: 10px;
    }

    .blog-empty p {
      font-size: 0.92rem;
      max-width: 400px;
      margin: 0 auto 28px;
      line-height: 1.7;
    }

    /* Category filter */
    .blog-filters {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 32px;
    }

    .blog-filter-btn {
      padding: 7px 18px;
      border-radius: 99px;
      border: 1px solid var(--color-border);
      background: transparent;
      color: var(--color-muted);
      font-size: 0.84rem;
      font-weight: 500;
      cursor: pointer;
      transition: all 0.15s ease;
      font-family: inherit;
    }

    .blog-filter-btn:hover,
    .blog-filter-btn.active {
      background: var(--color-accent);
      border-color: var(--color-accent);
      color: #fff;
    }

    @media (max-width: 900px) {
      .blog-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    }

    @media (max-width: 640px) {
      .blog-grid { grid-template-columns: 1fr; gap: 18px; }
      .blog-filters { gap: 8px; }
      .blog-filter-btn { padding: 6px 14px; font-size: 0.8rem; }
      .blog-card-img { min-height: 160px; }
    }

    @media (max-width: 480px) {
      .blog-card-body { padding: 18px; }
      .blog-card-title { font-size: 1rem; }
      .blog-filters { margin-top: 20px; }
    }
  
