/* Pro Points loyalty program — scoped design tokens */
.ns-pro-points {
  --color-primary: #8b3a52;
  --color-primary-soft: rgba(139, 58, 82, 0.12);
  --color-primary-muted: rgba(139, 58, 82, 0.55);
  --color-ring-track: rgba(139, 58, 82, 0.15);
  --color-success: #2e7d4f;
  --color-spend: #b45309;
}

/* ── Dashboard widget ── */
.ns-pro-points-widget {
  border: 1px solid var(--color-ring-track);
  border-radius: var(--ns-radius-sm, 14px);
  background: var(--ns-surface, #fff);
}

.ns-pro-points-widget__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.25rem;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--color-ring-track);
}

.ns-pro-points-ring {
  position: relative;
  width: 7.5rem;
  height: 7.5rem;
  flex-shrink: 0;
}

.ns-pro-points-ring__svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.ns-pro-points-ring__track,
.ns-pro-points-ring__fill {
  fill: none;
  stroke-width: 8;
}

.ns-pro-points-ring__track {
  stroke: var(--color-ring-track);
}

.ns-pro-points-ring__fill {
  stroke: var(--color-primary);
  stroke-linecap: round;
  transition: stroke-dashoffset 0.45s ease;
}

.ns-pro-points-ring__center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.15;
}

.ns-pro-points-ring__value {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-primary);
}

.ns-pro-points-ring__label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ns-muted, #6b6b6b);
}

.ns-pro-points-widget__tier-title {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ns-muted, #6b6b6b);
  margin-bottom: 0.25rem;
}

.ns-pro-points-widget__tier-name {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--ns-ink, #333);
}

.ns-pro-points-widget__tier-progress {
  font-size: 0.875rem;
  color: var(--ns-ink-soft, #4a4a4a);
  margin-top: 0.35rem;
}

.ns-pro-points-widget__tier-bar {
  height: 6px;
  border-radius: 999px;
  background: var(--color-ring-track);
  margin-top: 0.5rem;
  overflow: hidden;
}

.ns-pro-points-widget__tier-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: var(--color-primary);
  transition: width 0.45s ease;
}

.ns-pro-points-widget__body {
  padding: 1rem 1.5rem 1.25rem;
}

.ns-pro-points-widget__table-title {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.ns-pro-points-table {
  font-size: 0.8125rem;
}

.ns-pro-points-table th {
  font-weight: 600;
  color: var(--ns-muted, #6b6b6b);
  border-bottom-color: var(--color-ring-track) !important;
}

.ns-pro-points-table td.ns-pro-points-table__pts--earn {
  color: var(--color-success);
  font-weight: 600;
}

.ns-pro-points-table td.ns-pro-points-table__pts--spend {
  color: var(--color-spend);
  font-weight: 600;
}

.ns-pro-points-widget__loading,
.ns-pro-points-widget__empty {
  font-size: 0.875rem;
  color: var(--ns-muted, #6b6b6b);
}

/* ── PDP earn micro-copy ── */
.ns-pro-points-earn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.875rem;
  color: var(--color-primary);
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.ns-pro-points-earn__icon {
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  background: var(--color-primary-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  flex-shrink: 0;
}

/* ── Cart panel ── */
.ns-pro-points-cart {
  border: 1px solid var(--color-ring-track);
  border-radius: var(--ns-radius-sm, 14px);
  padding: 1rem 1.125rem;
  margin-bottom: 1rem;
  background: linear-gradient(135deg, var(--color-primary-soft) 0%, transparent 70%);
}

.ns-pro-points-cart__earn {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: 0.5rem;
}

.ns-pro-points-cart__redeem {
  font-size: 0.8125rem;
  color: var(--ns-ink-soft, #4a4a4a);
  margin-bottom: 0.75rem;
}

.ns-pro-points-cart__redeem strong {
  color: var(--color-primary);
}

.ns-pro-points-cart__apply {
  font-size: 0.8125rem;
  padding: 0.35rem 0.85rem;
  border-radius: var(--ns-radius-pill, 999px);
  border: 1px solid var(--color-primary);
  background: var(--color-primary);
  color: #fff;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s ease, opacity 0.15s ease;
}

.ns-pro-points-cart__apply:hover:not(:disabled) {
  filter: brightness(1.08);
}

.ns-pro-points-cart__apply:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.ns-pro-points-cart__applied {
  font-size: 0.8125rem;
  color: var(--color-success);
  font-weight: 600;
}

/* ── Checkout redeem row ── */
.ns-pro-points-checkout {
  border: 1px solid var(--color-ring-track);
  border-radius: var(--ns-radius-sm, 14px);
  padding: 1rem 1.125rem;
  margin-bottom: 1rem;
  background: var(--ns-surface, #fff);
}

.ns-pro-points-checkout__head {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
}

.ns-pro-points-checkout__radio {
  margin-top: 0.2rem;
  accent-color: var(--color-primary);
}

.ns-pro-points-checkout__title {
  font-weight: 600;
  font-size: 0.9375rem;
  margin-bottom: 0.15rem;
}

.ns-pro-points-checkout__balance {
  font-size: 0.8125rem;
  color: var(--ns-muted, #6b6b6b);
}

.ns-pro-points-checkout__panel {
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--color-ring-track);
}

.ns-pro-points-checkout__panel[hidden] {
  display: none !important;
}

.ns-pro-points-checkout__slider-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1rem;
}

.ns-pro-points-checkout__slider {
  flex: 1 1 12rem;
  accent-color: var(--color-primary);
}

.ns-pro-points-checkout__amount {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-primary);
  min-width: 5rem;
  text-align: right;
}

.ns-pro-points-checkout__hint {
  font-size: 0.75rem;
  color: var(--ns-muted, #6b6b6b);
  margin-top: 0.5rem;
}
