/* campaign.css — v1.2.0 (20.03.2026) — klaudiusz@seco */
/* Frontend styles for ecommerce_campaign pages */

.campaign-page { padding-bottom: 60px; }

/* Hero */
.campaign-hero {
  background: linear-gradient(135deg, #1a1a1a 0%, #0d1117 50%, #1a0a00 100%);
  padding: 60px 0;
  text-align: center;
}
.campaign-hero__badge {
  display: inline-block;
  background: var(--seco-primary, #c85014);
  color: #fff;
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px;
  padding: 5px 14px; border-radius: 20px;
  margin-bottom: 20px;
}
.campaign-hero__title {
  font-size: clamp(24px, 4vw, 42px);
  font-weight: 800; line-height: 1.2;
  color: #fff;
  margin-bottom: 24px;
}
.campaign-hero__gratis {
  display: inline-flex; align-items: center; gap: 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px; padding: 10px 20px;
}
.campaign-hero__gratis img {
  width: 56px; height: 56px; object-fit: contain;
  border-radius: 6px; background: #fff;
}
.campaign-hero__gratis-text { text-align: left; }
.campaign-hero__gratis-label {
  display: block;
  font-size: 10px; text-transform: uppercase; letter-spacing: 1px;
  color: var(--seco-primary, #e8712a); font-weight: 600;
}
.campaign-hero__gratis-name {
  display: block;
  font-size: 14px; font-weight: 600; color: #fff; margin-top: 2px;
}

/* Description */
.campaign-description {
  padding: 40px 0;
}
.campaign-description .container {
  max-width: 800px;
  line-height: 1.7;
  font-size: 15px;
}
.campaign-description img { max-width: 100%; height: auto; border-radius: 8px; }

/* Products grid */
.campaign-products { padding: 40px 0; }
.campaign-products__heading {
  font-size: 22px; font-weight: 700;
  text-align: center; margin-bottom: 32px;
}
.campaign-products__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
}

/* Product card */
.campaign-product-card {
  display: block; text-decoration: none; color: inherit;
  border: 1px solid #e5e5e5; border-radius: 10px;
  overflow: hidden; transition: border-color 0.2s, box-shadow 0.2s;
  background: #fff;
}
.campaign-product-card:hover {
  border-color: var(--seco-primary, #c85014);
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
.campaign-product-card__image {
  aspect-ratio: 1; background: #fff; padding: 12px;
  display: flex; align-items: center; justify-content: center;
}
.campaign-product-card__image img {
  max-width: 100%; max-height: 100%; object-fit: contain;
}
.campaign-product-card__body { padding: 14px; }
.campaign-product-card__title {
  font-size: 13px; font-weight: 500; line-height: 1.4;
  margin-bottom: 6px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.campaign-product-card__price {
  font-size: 17px; font-weight: 700;
  color: var(--seco-primary, #c85014);
}
.campaign-product-card__tag {
  display: inline-block; margin-top: 8px;
  background: rgba(200,80,20,0.1); color: var(--seco-primary, #c85014);
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px;
  padding: 3px 8px; border-radius: 4px;
}

/* Campaign banner on product page — SECO red style */
.campaign-banner {
  display: flex; align-items: center; gap: 20px;
  background: #E34636;
  border-radius: 0;
  padding: 14px 20px;
  margin: 16px 0;
}
.campaign-banner__icon {
  flex-shrink: 0;
  font-size: 24px; line-height: 1;
  color: #fff;
}
.campaign-banner__content { flex: 1; min-width: 0; }
.campaign-banner__title {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  color: #fff;
  margin-bottom: 2px;
}
.campaign-banner__reward { font-size: 14px; color: rgba(255,255,255,0.9); line-height: 1.4; font-weight: 500; }
.campaign-banner__reward strong { color: #fff; }
.campaign-banner__link {
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  color: rgba(255,255,255,0.8); font-weight: 600;
  text-decoration: none; font-size: 14px; white-space: nowrap;
  flex-shrink: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  transition: color 0.2s;
}
.campaign-banner__link:hover {
  color: #fff;
  text-decoration: underline;
}

/* Campaign banner variants — active (green) + progress (orange) */
.campaign-banner--active {
  background: #2a8f2a;
}
.campaign-banner--active .campaign-banner__icon { color: #fff; }

.campaign-banner--progress {
  background: #f5a623;
}
.campaign-banner--progress .campaign-banner__icon { color: #fff; }
.campaign-banner--progress .campaign-banner__title { color: #fff; }
.campaign-banner--progress .campaign-banner__reward { color: rgba(255,255,255,0.95); }

/* Progress bar */
.campaign-banner__progress-bar {
  width: 100%;
  height: 4px;
  background: rgba(255,255,255,0.3);
  border-radius: 2px;
  margin-top: 6px;
  overflow: hidden;
}
.campaign-banner__progress-fill {
  height: 100%;
  background: #fff;
  border-radius: 2px;
  transition: width 0.4s ease;
}

/* Mini cart campaign progress */
.campaign-mini--progress {
  background: #fff8f0;
  border-left: 3px solid #f5a623;
  padding: 8px 12px;
}
.campaign-mini__title {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: #c47a1a;
  margin-bottom: 2px;
}
.campaign-mini__message {
  font-size: 0.8rem;
  color: #8b5e1a;
  font-weight: 500;
  margin-bottom: 4px;
}
.campaign-mini--progress .campaign-banner__progress-bar {
  background: rgba(245,166,35,0.2);
}
.campaign-mini--progress .campaign-banner__progress-fill {
  background: #f5a623;
}

/* Badge GRATIS on campaign product cards */
.b2c-product-card__badge--gratis {
  position: absolute;
  top: 8px; left: 8px;
  background: #2a8f2a;
  color: #fff;
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 4px 10px;
  border-radius: 4px;
  z-index: 2;
  display: inline-flex; align-items: center; gap: 4px;
}
.b2c-product-card__badge--gratis i { font-size: 12px; }

/* Mobile */
@media (max-width: 768px) {
  .campaign-hero { padding: 40px 0; }
}
