/* Promotions manager - sale CRUD + status table. */

.promo-header { display: flex; align-items: center; gap: 12px; }
.promo-source {
  font-size: 11px; font-weight: 600; color: var(--accent);
  border: 1px solid color-mix(in srgb, var(--accent) 45%, transparent);
  border-radius: 999px; padding: 2px 10px; cursor: help;
}
.promo-subtitle { color: var(--text-secondary); font-size: 14px; margin: 4px 0 16px; max-width: 64ch; }
.promo-toolbar { margin-bottom: 16px; }
.promo-add-btn {
  background: var(--accent); color: #1a1a1a; border: 1px solid var(--accent);
  border-radius: 8px; padding: 7px 14px; font-weight: 600; font-size: 13px; cursor: pointer;
}
.promo-add-btn:hover { background: var(--accent-hover); }

.promo-form { background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 16px; margin-bottom: 20px; }
.promo-form__grid { display: flex; flex-wrap: wrap; gap: 14px; align-items: flex-end; }
.promo-params, .promo-scopeval { display: flex; gap: 14px; align-items: flex-end; }
.promo-params[hidden], .promo-scopeval[hidden] { display: none; } /* [hidden] must beat flex */
.promo-f { display: flex; flex-direction: column; gap: 4px; font-size: 12px; }
.promo-f--wide { flex: 1 1 240px; }
.promo-f > span { color: var(--text-secondary); }
.promo-f input, .promo-f select {
  background: var(--bg); color: var(--text-primary); border: 1px solid var(--border);
  border-radius: 6px; padding: 6px 8px; font-size: 13px;
}
.promo-f input[type="number"] { width: 110px; }
.promo-form__actions { margin-top: 14px; }
.promo-submit {
  background: var(--accent); color: #1a1a1a; border: 1px solid var(--accent);
  border-radius: 6px; padding: 7px 16px; font-weight: 600; font-size: 13px; cursor: pointer;
}

.promo-table-wrap { overflow-x: auto; }
.promo-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.promo-table th, .promo-table td { border-bottom: 1px solid var(--border); padding: 8px 12px; text-align: left; }
.promo-table th { color: var(--text-secondary); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; }
.promo-window { color: var(--text-secondary); white-space: nowrap; }
.promo-badge { font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 700; border-radius: 999px; padding: 2px 8px; border: 1px solid var(--border); }
.promo-badge--active { color: var(--success); border-color: color-mix(in srgb, var(--success) 50%, transparent); }
.promo-badge--scheduled { color: var(--warning); border-color: color-mix(in srgb, var(--warning) 50%, transparent); }
.promo-badge--ended { color: var(--text-secondary); }
.promo-del { background: transparent; border: 1px solid var(--border); color: var(--error); border-radius: 6px; padding: 4px 10px; font-size: 12px; cursor: pointer; }
.promo-del:hover { border-color: var(--error); }
.promo-empty { color: var(--text-secondary); padding: 24px 4px; }

.promo-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  background: var(--surface); color: var(--text-primary); border: 1px solid var(--accent);
  border-radius: 8px; padding: 10px 16px; font-size: 13px; z-index: 9999; box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
