/* =============================================================================
 * evps-promo.css  --  EVPS-1000X Promotion Manager + client promo banner.
 *
 * Two surfaces:
 *   1. Admin: .evps-promo-card / .evps-promo-section / .evps-promo-table
 *      (the addon's Promotion Manager page chrome -- scoped, theme-aware).
 *   2. Client: .evps-promo banner rendered by promotion_banner.tpl with
 *      background variants + 7 colour-variant CTA buttons mapped to the
 *      canonical --evps-btn-*-bg tokens.
 *
 * Light/dark aware: everything reads --evps-* custom properties so it follows
 * the active scheme automatically. No hardcoded brand colours.
 * ========================================================================== */

/* ---------------------------------------------------------------------------
 * ADMIN -- Promotion Manager chrome
 * ------------------------------------------------------------------------- */
.evps-promo-card {
  background: var(--evps-surface, #121829);
  border: 1px solid var(--evps-border, rgba(255, 255, 255, 0.08));
  border-radius: var(--evps-radius-lg, 14px);
  box-shadow: var(--evps-shadow-sm, 0 1px 2px rgba(0, 0, 0, 0.2));
  padding: var(--evps-space-6, 20px);
  margin-bottom: var(--evps-space-6, 20px);
  color: var(--evps-text, #e7ecf5);
}

.evps-promo-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.evps-promo-card__head h3 {
  margin: 0;
  font-family: var(--evps-font-display, inherit);
  font-weight: var(--evps-fw-semibold, 600);
  font-size: var(--evps-fs-lg, 18px);
  color: var(--evps-text, #e7ecf5);
}

.evps-promo-card .evps-muted,
.evps-promo-card .text-muted {
  color: var(--evps-text-muted, #9aa6bd);
}

.evps-promo-section {
  border: 1px solid var(--evps-border-subtle, rgba(255, 255, 255, 0.06));
  border-radius: var(--evps-radius-md, 10px);
  padding: var(--evps-space-5, 16px);
  margin: 0 0 var(--evps-space-5, 16px);
  background: var(--evps-surface-2, rgba(255, 255, 255, 0.02));
}

.evps-promo-section > legend {
  width: auto;
  border: 0;
  margin: 0 0 10px;
  padding: 0 8px;
  font-size: var(--evps-fs-sm, 13px);
  font-weight: var(--evps-fw-semibold, 600);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--evps-accent, #6ea8fe);
}

.evps-promo-section .form-group { margin-bottom: 12px; }
.evps-promo-section label { color: var(--evps-text-soft, #c4cde0); font-weight: var(--evps-fw-medium, 500); }

.evps-req { color: var(--evps-danger, #f06464); }

.evps-promo-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
}

.evps-promo-check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: var(--evps-fw-regular, 400);
  color: var(--evps-text, #e7ecf5);
  margin: 0;
  cursor: pointer;
}

.evps-promo-multi {
  min-height: 120px;
}

.evps-promo-advanced {
  border-top: 1px dashed var(--evps-border-subtle, rgba(255, 255, 255, 0.08));
  margin-top: 10px;
  padding-top: 6px;
}
.evps-promo-advanced h4 {
  font-size: var(--evps-fs-sm, 13px);
  color: var(--evps-text-muted, #9aa6bd);
}

.evps-promo-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 8px;
}

.evps-promo-table { width: 100%; }
.evps-promo-table th {
  font-size: var(--evps-fs-xs, 12px);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--evps-text-muted, #9aa6bd);
}
.evps-promo-table td { vertical-align: middle; color: var(--evps-text, #e7ecf5); }

.evps-promo-drag {
  cursor: grab;
  user-select: none;
  white-space: nowrap;
  color: var(--evps-text-muted, #9aa6bd);
}
.evps-promo-table tr[draggable="true"]:hover .evps-promo-drag { color: var(--evps-accent, #6ea8fe); }

/* ---------------------------------------------------------------------------
 * CLIENT -- promotion banner
 * ------------------------------------------------------------------------- */
.evps-promo {
  display: flex;
  align-items: center;
  gap: var(--evps-space-5, 16px);
  padding: var(--evps-space-5, 16px) var(--evps-space-6, 22px);
  margin: 0 0 var(--evps-space-5, 16px);
  border-radius: var(--evps-radius-lg, 14px);
  border: 1px solid var(--evps-border, rgba(255, 255, 255, 0.08));
  background: var(--evps-surface, #121829);
  color: var(--evps-text, #e7ecf5);
  box-shadow: var(--evps-shadow-sm, 0 1px 2px rgba(0, 0, 0, 0.2));
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}

.evps-promo--bg-primary {
  background: linear-gradient(135deg,
    var(--evps-primary-grad-from, var(--evps-primary, #3b82f6)),
    var(--evps-primary-grad-to, var(--evps-primary-hover, #2563eb)));
  color: var(--evps-on-primary, #fff);
  border-color: transparent;
}
.evps-promo--bg-primary .evps-promo__tagline { color: rgba(255, 255, 255, 0.86); }

.evps-promo--bg-light {
  background: var(--evps-surface-2, #f5f7fb);
  color: var(--evps-text, #1c2433);
  border-color: var(--evps-border-subtle, rgba(0, 0, 0, 0.08));
}

.evps-promo--bg-dark {
  background: var(--evps-surface-3, #0c1120);
  color: var(--evps-text-inverse, #f5f7fb);
  border-color: var(--evps-border-strong, rgba(255, 255, 255, 0.14));
}
.evps-promo--bg-dark .evps-promo__tagline { color: rgba(255, 255, 255, 0.78); }

.evps-promo--bg-graphic {
  background-color: var(--evps-surface-3, #0c1120);
  color: #fff;
  border-color: transparent;
}
.evps-promo--bg-graphic .evps-promo__tagline { color: rgba(255, 255, 255, 0.85); }

.evps-promo__graphic {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.evps-promo__graphic--image img {
  width: 64px;
  height: 64px;
  object-fit: contain;
  border-radius: var(--evps-radius-md, 10px);
}
.evps-promo__graphic--icon {
  width: 56px;
  height: 56px;
  border-radius: var(--evps-radius-pill, 999px);
  background: rgba(255, 255, 255, 0.12);
  font-size: 24px;
}
.evps-promo--bg-light .evps-promo__graphic--icon {
  background: var(--evps-primary-soft, rgba(59, 130, 246, 0.12));
  color: var(--evps-primary, #3b82f6);
}

.evps-promo__body { flex: 1 1 auto; min-width: 0; }
.evps-promo__headline {
  margin: 0 0 4px;
  font-family: var(--evps-font-display, inherit);
  font-weight: var(--evps-fw-bold, 700);
  font-size: var(--evps-fs-xl, 20px);
  line-height: 1.2;
}
.evps-promo__tagline {
  margin: 0;
  font-size: var(--evps-fs-sm, 14px);
  color: var(--evps-text-muted, #9aa6bd);
  line-height: 1.4;
}

.evps-promo__action { flex: 0 0 auto; }

.evps-promo__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: var(--evps-radius-md, 10px);
  font-weight: var(--evps-fw-semibold, 600);
  font-size: var(--evps-fs-sm, 14px);
  text-decoration: none;
  border: 1px solid transparent;
  transition: transform var(--evps-dur-fast, 120ms) var(--evps-ease-out, ease),
              filter var(--evps-dur-fast, 120ms) var(--evps-ease-out, ease);
  white-space: nowrap;
  cursor: pointer;
  color: #fff;
}
.evps-promo__btn:hover { transform: translateY(-1px); filter: brightness(1.06); text-decoration: none; color: #fff; }
.evps-promo__btn:active { transform: translateY(0); }
.evps-promo__btn .fa { font-size: 0.85em; }

.evps-promo__btn--primary   { background: var(--evps-btn-primary-bg,   #3b82f6); color: var(--evps-on-primary, #fff); }
.evps-promo__btn--secondary { background: var(--evps-btn-secondary-bg, #5b6577); color: var(--evps-on-secondary, #fff); }
.evps-promo__btn--success   { background: var(--evps-btn-success-bg,   #22c55e); }
.evps-promo__btn--warning   { background: var(--evps-btn-warning-bg,   #f59e0b); color: #1c2433; }
.evps-promo__btn--danger    { background: var(--evps-btn-danger-bg,    #ef4444); }
.evps-promo__btn--info      { background: var(--evps-btn-info-bg,      #06b6d4); }
.evps-promo__btn--dark      { background: var(--evps-btn-dark-bg,      #1c2433); }

/* Responsive: stack on small viewports. */
@media (max-width: 640px) {
  .evps-promo {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }
  .evps-promo__action { width: 100%; }
  .evps-promo__btn { width: 100%; justify-content: center; }
}

/* Honour reduced-motion preference. */
@media (prefers-reduced-motion: reduce) {
  .evps-promo__btn { transition: none; }
  .evps-promo__btn:hover { transform: none; }
}
