/* ====================== Component: Offer Banner ====================== */
.offer { position: relative; overflow: hidden; color: var(--color-white); }
.offer__bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; }
.offer__overlay { position: absolute; inset: 0; background: rgba(var(--color-ink-rgb), 0.55); }
.offer__inner { position: relative; z-index: 2; }
.offer__title { color: var(--color-white); }

.offer__grid { display: grid; gap: 24px; grid-template-columns: 1fr; margin-top: 40px; }

.offer-card {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  background: rgba(var(--color-ink-rgb), 0.9);
  border-left: 2px solid var(--color-yellow);
  padding: 25px;
  transition: transform 0.3s var(--ease), background-color 0.3s var(--ease);
}
.offer-card:hover { transform: translateY(-4px); background: rgba(var(--color-ink-rgb), 0.97); }

.offer-card__icon {
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 5px;
  background: var(--color-yellow-soft);
}
.offer-card__icon img { width: 20px; height: 20px; }
.offer-card__title { color: var(--color-white); font-size: 16px; line-height: 24px; letter-spacing: -0.16px; }
.offer-card__text { margin-top: 6px; font-size: 14px; line-height: 22.75px; color: var(--color-body-dark); }

@media (min-width: 768px) {
  .offer__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .offer__grid { grid-template-columns: repeat(3, 1fr); }
}
