/* banners.css */
.banner-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.banner-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--sp-4); }
@media (max-width:900px) { .banner-grid-2,.banner-grid-3 { grid-template-columns: 1fr; } }
@media (max-width:600px) { .banner-grid-3 { grid-template-columns: 1fr; } }

.banner-card {
  position: relative;
  border-radius: var(--r-xl);
  overflow: hidden;
  min-height: 220px;
  display: flex;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: transform var(--ease-slow), box-shadow var(--ease-slow);
}
.banner-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.banner-card.big { min-height: 280px; }

.banner-bg {
  position: absolute; inset: 0;
  background: var(--gray-100);
}
.banner-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.15) 100%);
}
.banner-content {
  position: relative; z-index: 2;
  padding: var(--sp-8);
  display: flex; flex-direction: column; justify-content: flex-end;
  width: 100%;
}
.banner-tag {
  display: inline-block;
  background: var(--primary);
  color: white;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: var(--r-full);
  margin-bottom: var(--sp-2);
  width: fit-content;
  letter-spacing: .04em;
}
.banner-title { font-family: var(--font-heading); font-size: clamp(18px,2.5vw,28px); font-weight: 800; color: white; line-height: 1.25; margin-bottom: var(--sp-2); }
.banner-sub   { font-size: var(--text-sm); color: rgba(255,255,255,.75); margin-bottom: var(--sp-4); }
.banner-cta   { display: inline-flex; align-items: center; gap: 6px; background: white; color: var(--black); font-size: var(--text-xs); font-weight: 700; padding: 7px 16px; border-radius: var(--r-full); width: fit-content; transition: all var(--ease); }
.banner-card:hover .banner-cta { background: var(--primary); color: white; }

@media (max-width: 640px) {
  .banner-card.big { min-height: 240px; }
  .banner-card { min-height: 180px; }
  .banner-content { padding: var(--sp-5); }
  .banner-title { overflow-wrap: anywhere; }
}
