/* Blog listing & detail — Cairo (site default), palette #000 / #fff / #fee002 */

.blog-page {
  font-family: "Cairo", sans-serif;
  background: #000;
  color: #fff;
  min-height: 60vh;
}

/* --- Listing: services band (hero + articles) --- */
.blog-services {
  background: #000;
  padding: 40px 5% 48px;
}

@media screen and (min-width: 768px) {
  .blog-services {
    padding: 56px 40px 56px;
  }
}

@media screen and (min-width: 1280px) {
  .blog-services {
    padding: 104px 80px 104px;
  }
}

.blog-hero-block {
  margin-bottom: 32px;
}

@media screen and (min-width: 1280px) {
  .blog-hero-block {
    margin-bottom: 56px;
  }
}

.blog-hero {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
  border-radius: 20px;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  background: #1a1a1a;
}

@media screen and (min-width: 768px) {
  .blog-hero {
    aspect-ratio: 12 / 5;
  }
}

@media screen and (min-width: 1280px) {
  .blog-hero {
    max-width: 1200px;
  }
}

.blog-hero__media {
  position: absolute;
  inset: 0;
  background-image: var(--blog-hero-mobile);
  background-size: cover;
  background-position: center;
  background-color: #1a1a1a;
}

@media screen and (min-width: 768px) {
  .blog-hero__media {
    background-image: var(--blog-hero-desktop);
  }
}

.blog-articles-section {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

@media screen and (min-width: 1280px) {
  .blog-articles-section {
    gap: 56px;
  }
}

.blog-articles-heading {
  text-align: center;
  margin: 0;
  font-weight: 600;
  font-size: 28px;
  line-height: 1.2;
  color: #fff;
}

@media screen and (min-width: 1280px) {
  .blog-articles-heading {
    font-size: 36px;
  }
}

.blog-category-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  justify-content: center;
}

.blog-category-filters a {
  color: #a4a4a4;
  text-decoration: none;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 0.9rem;
  font-weight: 500;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}

.blog-category-filters a:hover {
  color: #fff;
  border-color: rgba(254, 224, 2, 0.45);
}

.blog-category-filters a.is-active {
  background: #fee002;
  color: #121212;
  border-color: #fee002;
}

.blog-grid {
  display: grid;
  grid-template-columns: 1fr;
  width: 100%;
  gap: 28px;
  max-width: 1280px;
  margin: 0 auto;
}

@media screen and (min-width: 768px) {
  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 20px;
    row-gap: 32px;
  }
}

@media screen and (min-width: 1024px) {
  .blog-grid {
    grid-template-columns: repeat(3, 1fr);
    row-gap: 40px;
  }

  .blog-card--featured {
    grid-column: span 2;
  }
}

.blog-card {
  display: block;
  min-width: 0;
  text-decoration: none;
  color: inherit;
  background: transparent;
  transition: opacity 0.2s ease;
}

.blog-card:hover {
  opacity: 0.92;
}

.blog-card__column {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: stretch;
  width: 100%;
}

.blog-card__image-wrap {
  position: relative;
  height: 176px;
  border-radius: 20px;
  overflow: hidden;
  background: #000;
}

.blog-card__image-wrap img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 20px;
}

.blog-card__image-dim {
  position: absolute;
  inset: 0;
  border-radius: 20px;
  background: rgba(18, 18, 18, 0.6);
  pointer-events: none;
}

.blog-card__placeholder-img {
  object-fit: contain !important;
  padding: 20px;
  opacity: 0.9;
}

.blog-card__body {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 0 2px 4px;
  flex: 1;
}

.blog-card__category {
  color: #fee002;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.blog-card__title {
  font-size: 20px;
  font-weight: 600;
  margin: 0;
  line-height: normal;
  letter-spacing: -0.2px;
  color: #fff;
}

.blog-card__summary {
  color: rgba(255, 255, 255, 0.72);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  margin: 0;
  flex: 1;
}

.blog-card__read {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  margin-top: 0;
  color: #fff;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.14;
}

.blog-card__read img,
.blog-card__read-icon {
  width: 31px;
  height: 15px;
  object-fit: contain;
}

.blog-page[dir="rtl"] .blog-card__read-icon {
  transform: scaleX(-1);
}

.blog-empty {
  text-align: center;
  padding: 32px 5% 16px;
  color: #a4a4a4;
  max-width: 640px;
  margin: 0 auto;
}

/* --- Detail: article page --- */
.blog-detail-page {
  font-family: "Cairo", sans-serif;
  background: #1f1f1f;
  color: #fff;
  min-height: 60vh;
}

.blog-detail-shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 24px 5% 56px;
}

.blog-detail-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}

.blog-detail-article {
  min-width: 0;
}

.blog-detail-article__hero {
  position: relative;
  width: 100%;
  height: 184px;
  overflow: hidden;
  border-radius: 12px;
  background: #000;
}

.blog-detail-article__hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.blog-detail-article__placeholder-img,
.blog-detail-mini-card__placeholder-img,
.blog-detail-new-card__placeholder-img {
  object-fit: contain !important;
  padding: 18px;
  opacity: 0.9;
}

.blog-detail-category-button {
  display: inline-flex;
  align-items: center;
  margin-top: 18px;
  color: #fee002;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.2;
  text-decoration: none;
  transition: opacity 0.2s ease;
}

.blog-detail-category-button:hover {
  opacity: 0.8;
}

.blog-detail-article__title {
  margin: 10px 0 8px;
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.2;
}

.blog-detail-article__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0 6px;
  margin: 0 0 18px;
  color: rgba(255, 255, 255, 0.58);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.5;
}

.blog-detail-article__content {
  color: rgba(255, 255, 255, 0.82);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.75;
}

.blog-detail-article__content > *:first-child {
  margin-top: 0;
}

.blog-detail-article__content > *:last-child {
  margin-bottom: 0;
}

.blog-detail-article__content h2,
.blog-detail-article__content h3,
.blog-detail-article__content h4 {
  color: #fff;
  line-height: 1.25;
  margin: 32px 0 12px;
}

.blog-detail-article__content h2 {
  font-size: 18px;
}

.blog-detail-article__content p {
  margin: 0 0 16px;
}

.blog-detail-article__content img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  margin: 16px 0;
}

.blog-detail-sidebar {
  display: none;
}

.blog-detail-sidebar h2,
.blog-detail-new h2 {
  margin: 0;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.25;
}

.blog-detail-sidebar__list {
  display: grid;
  gap: 18px;
  margin-top: 14px;
}

.blog-detail-mini-card,
.blog-detail-new-card {
  color: inherit;
  text-decoration: none;
}

.blog-detail-mini-card {
  display: grid;
  gap: 10px;
}

.blog-detail-mini-card__image,
.blog-detail-new-card__image {
  position: relative;
  display: block;
  overflow: hidden;
  flex: 0 0 auto;
  background: #000;
}

.blog-detail-mini-card__image {
  height: 96px;
  border-radius: 8px;
}

.blog-detail-mini-card__image img,
.blog-detail-new-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.blog-detail-mini-card__body,
.blog-detail-new-card__body {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.blog-detail-mini-card__title,
.blog-detail-new-card__title {
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.25;
}

.blog-detail-mini-card__summary,
.blog-detail-new-card__summary {
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 400;
  line-height: 1.45;
  margin-top: 6px;
}

.blog-detail-read-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.14;
}

.blog-detail-read-link__icon {
  width: 20px;
  height: 17px;
  object-fit: contain;
}

.blog-detail-page[dir="rtl"] .blog-detail-read-link__icon {
  transform: scaleX(-1);
}

.blog-detail-new {
  margin-top: 48px;
}

.blog-detail-new__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: 18px;
}

.blog-detail-new-card {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.blog-detail-new-card__image {
  height: 96px;
  border-radius: 8px;
}

@media screen and (min-width: 768px) {
  .blog-detail-shell {
    padding: 40px 40px 72px;
  }

  .blog-detail-layout {
    grid-template-columns: minmax(0, 1fr) 220px;
    gap: 18px;
    align-items: start;
  }

  .blog-detail-article__hero {
    height: 232px;
  }

  .blog-detail-article__title {
    margin-top: 20px;
    font-size: 24px;
  }

  .blog-detail-article__content {
    font-size: 15px;
  }

  .blog-detail-sidebar {
    display: block;
  }

  .blog-detail-mini-card__image {
    height: 112px;
  }

  .blog-detail-new {
    margin-top: 64px;
  }

  .blog-detail-new__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px 28px;
  }

  .blog-detail-new-card {
    grid-template-columns: 128px minmax(0, 1fr);
    gap: 14px;
  }

  .blog-detail-new-card__image {
    height: 112px;
  }
}

@media screen and (min-width: 1024px) {
  .blog-detail-shell {
    padding: 72px 64px 88px;
  }

  .blog-detail-layout {
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 28px;
  }

  .blog-detail-article__hero {
    height: 376px;
    border-radius: 12px;
  }

  .blog-detail-article__title {
    font-size: 32px;
  }

  .blog-detail-sidebar__list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px 14px;
  }

  .blog-detail-mini-card__image {
    height: 86px;
  }
}

@media screen and (min-width: 1280px) {
  .blog-detail-shell {
    padding: 104px 80px;
  }

  .blog-detail-layout {
    grid-template-columns: minmax(0, 848px) 300px;
    gap: 32px;
  }

  .blog-detail-article__hero {
    height: 420px;
  }

  .blog-detail-new {
    max-width: 848px;
  }

  .blog-detail-new__grid {
    gap: 24px 48px;
  }
}
