/* نیک‌یار - Minimal, modern frontend styles
 *
 * Design language:
 *  - Restrained typography-first layout
 *  - Soft sage green + warm gold as accents only
 *  - No inline SVG icons (cross-theme reliability)
 *  - Mobile-first, additive, no theme overrides forced
 *  - RTL-native: uses CSS logical properties so accents/alignment
 *    flip correctly on the Persian (rtl) site
 */

:root {
	--dtc-green: #2f6b4f;
	--dtc-green-deep: #1f4d38;
	--dtc-green-soft: #f1f6f3;
	--dtc-gold: #b8923e;
	--dtc-gold-soft: #fdf6e3;
	--dtc-text: #1f2c25;
	--dtc-muted: #6b7280;
	--dtc-border: #e5ebe7;
	--dtc-bg: #ffffff;
	--dtc-bg-subtle: #fafdfb;
	--dtc-success: #137c47;
	--dtc-error: #b3261e;
	--dtc-shadow-sm: 0 1px 2px rgba(15, 50, 35, 0.04);
	--dtc-shadow-md: 0 6px 18px -10px rgba(15, 50, 35, 0.16), 0 1px 3px rgba(15, 50, 35, 0.04);
	--dtc-radius: 12px;
	--dtc-radius-sm: 8px;
	--dtc-ease: cubic-bezier(.4, 0, .2, 1);
}

@keyframes dtc-fade-up {
	from { opacity: 0; transform: translateY(4px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ====================================================================
   Cart / Checkout box
   ==================================================================== */

.dtc-redeem-row > th {
	background: transparent !important;
	font-weight: 400 !important;
	border-top: 1px solid var(--dtc-border) !important;
	padding: 14px 0 !important;
}

.dtc-redeem-box {
	position: relative;
	background: var(--dtc-bg);
	border: 1px solid var(--dtc-border);
	border-inline-start: 3px solid var(--dtc-green);
	border-radius: var(--dtc-radius);
	padding: 16px 18px;
	color: var(--dtc-text);
	line-height: 1.5;
	box-shadow: var(--dtc-shadow-sm);
	animation: dtc-fade-up .28s var(--dtc-ease) both;
	box-sizing: border-box;
}

.dtc-redeem-box * { box-sizing: border-box; }

.dtc-redeem-box__head {
	margin-bottom: 10px;
}

.dtc-redeem-box__title {
	font-size: 1em;
	font-weight: 600;
	color: var(--dtc-green-deep);
	margin: 0 0 2px;
	letter-spacing: 0.01em;
	display: flex;
	align-items: center;
	gap: 8px;
}

/* Small accent dot, CSS-only — can't break */
.dtc-redeem-box__title::before {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--dtc-gold);
	flex-shrink: 0;
}

.dtc-redeem-box__sub {
	color: var(--dtc-muted);
	margin: 0;
}

.dtc-redeem-box .dtc-balance,
.dtc-redeem-box .dtc-info {
	margin: 8px 0 12px;
}

.dtc-redeem-box .dtc-balance strong {
	color: var(--dtc-green-deep);
}

/* Applied chip */
.dtc-applied {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	background: var(--dtc-green-soft);
	border: 1px solid #d8e4dd;
	border-radius: var(--dtc-radius-sm);
	padding: 10px 12px;
}

.dtc-applied__check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	min-width: 20px;
	border-radius: 50%;
	background: var(--dtc-success);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	flex-shrink: 0;
	line-height: 1;
}

.dtc-applied__text {
	flex: 1;
	min-width: 140px;
}

/* Form */
.dtc-redeem-box .dtc-form {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 8px;
}

.dtc-input-group {
	flex: 1 1 160px;
	display: flex;
	align-items: stretch;
	background: #fff;
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius-sm);
	overflow: hidden;
	min-width: 0;
	transition: border-color .2s var(--dtc-ease), box-shadow .2s var(--dtc-ease);
}

.dtc-input-group:focus-within {
	border-color: var(--dtc-green);
	box-shadow: 0 0 0 3px rgba(47, 107, 79, 0.14);
}

.dtc-input-group input {
	border: 0;
	flex: 1;
	min-width: 0;
	padding: 10px 12px;
	background: transparent;
	font-size: 1em;
	color: var(--dtc-text);
	outline: none;
	-moz-appearance: textfield;
}

.dtc-input-group input::-webkit-outer-spin-button,
.dtc-input-group input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.dtc-max-btn {
	border: 0;
	border-inline-start: 1px solid var(--dtc-border);
	background: var(--dtc-gold-soft);
	color: var(--dtc-gold);
	padding: 0 14px;
	font-size: 0.78em;
	font-weight: 700;
	letter-spacing: 0.04em;
	cursor: pointer;
	transition: background .2s var(--dtc-ease);
	flex-shrink: 0;
}

.dtc-max-btn:hover { background: #f7ead0; }

.dtc-redeem-box .dtc-apply-btn,
.dtc-redeem-box .dtc-remove-btn {
	border: 0;
	padding: 10px 16px;
	border-radius: var(--dtc-radius-sm);
	cursor: pointer;
	font-size: 0.92em;
	font-weight: 600;
	white-space: nowrap;
	transition: background .2s var(--dtc-ease), transform .15s var(--dtc-ease);
}

.dtc-redeem-box .dtc-apply-btn {
	color: #fff;
	background: var(--dtc-green);
}

.dtc-redeem-box .dtc-apply-btn:hover:not(:disabled) {
	background: var(--dtc-green-deep);
	transform: translateY(-1px);
}

.dtc-redeem-box .dtc-apply-btn:disabled {
	opacity: 0.7;
	cursor: progress;
}

.dtc-redeem-box .dtc-remove-btn {
	background: transparent;
	color: var(--dtc-green-deep);
	border: 1px solid var(--dtc-border);
	padding: 8px 12px;
}

.dtc-redeem-box .dtc-remove-btn:hover {
	background: var(--dtc-green-soft);
	border-color: var(--dtc-green);
}

.dtc-redeem-box .dtc-hint,
.dtc-redeem-box .dtc-disclaimer {
	flex-basis: 100%;
	color: var(--dtc-muted);
	margin: 6px 0 0;
}

/* ─── Slider variant of the redeem form ──────────────────────────────────
   Layout: readout above the slider, slider full-width, actions below. */
.dtc-redeem-box .dtc-form--slider {
	display: block;
}
.dtc-redeem-box .dtc-slider-readout {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	padding: 10px 14px;
	background: linear-gradient(180deg, var(--dtc-green-soft), #fff);
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius-sm);
	margin-bottom: 14px;
}
.dtc-redeem-box .dtc-slider-readout__main {
	display: flex;
	align-items: baseline;
	gap: 6px;
}
.dtc-redeem-box .dtc-slider-readout__num {
	font-size: 1.7em;
	font-weight: 800;
	color: var(--dtc-green-deep);
	line-height: 1.1;
}
.dtc-redeem-box .dtc-slider-readout__unit {
	font-size: 0.82em;
	color: var(--dtc-muted);
	font-weight: 600;
}
.dtc-redeem-box .dtc-slider-readout__discount {
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
	font-size: 0.95em;
	color: var(--dtc-muted);
}
.dtc-redeem-box .dtc-slider-readout__discount strong {
	font-size: 1.08em;
	color: var(--dtc-gold);
	font-weight: 800;
}
.dtc-redeem-box .dtc-slider-readout__eq {
	color: var(--dtc-muted);
	margin-inline-end: 2px;
}

/* The native range slider, themed for the redeem box. */
.dtc-redeem-box .dtc-slider-wrap {
	padding: 6px 4px 0;
}
.dtc-redeem-box .dtc-slider {
	--dtc-fill: 100%;
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	height: 8px;
	border-radius: 999px;
	/* RTL: thumb starts at the right (value=0) and moves leftward toward
	   max — matches the surrounding Persian layout and the «۰ … حداکثر»
	   labels rendered below the track. The gradient flows in the same
	   direction so the green «filled» portion grows from the right side
	   of the track toward the thumb. */
	direction: rtl;
	background: linear-gradient(to left,
		var(--dtc-green) 0 var(--dtc-fill),
		#e6eae8 var(--dtc-fill) 100%);
	outline: none;
	cursor: pointer;
	transition: box-shadow .15s ease;
}
.dtc-redeem-box .dtc-slider:focus-visible {
	box-shadow: 0 0 0 3px rgba(47, 107, 79, 0.22);
}
.dtc-redeem-box .dtc-slider::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: #fff;
	border: 3px solid var(--dtc-green);
	box-shadow: 0 2px 8px rgba(15, 50, 35, 0.18);
	cursor: grab;
	transition: transform .12s ease;
	margin-top: -7px;
}
.dtc-redeem-box .dtc-slider::-webkit-slider-thumb:active {
	cursor: grabbing;
	transform: scale(1.08);
}
.dtc-redeem-box .dtc-slider::-webkit-slider-runnable-track {
	height: 8px;
	background: transparent;
	border-radius: 999px;
}
.dtc-redeem-box .dtc-slider::-moz-range-thumb {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: #fff;
	border: 3px solid var(--dtc-green);
	box-shadow: 0 2px 8px rgba(15, 50, 35, 0.18);
	cursor: grab;
}

/* "Drag-me" hint: subtle scale + halo pulse on the thumb so users who land
   on the checkout with a fresh zero-valued slider notice it's interactive.
   The .is-hint class is added by JS every 5s and removed after 1.2s; the
   first real interaction stops the cycle for the rest of the session. */
@keyframes dtc-thumb-hint {
	0%, 100% { transform: scale(1);    box-shadow: 0 2px 8px rgba(15, 50, 35, 0.18), 0 0 0 0   rgba(47, 107, 79, 0.45); }
	30%      { transform: scale(1.22); box-shadow: 0 2px 8px rgba(15, 50, 35, 0.18), 0 0 0 8px rgba(47, 107, 79, 0.30); }
	70%      { transform: scale(1.10); box-shadow: 0 2px 8px rgba(15, 50, 35, 0.18), 0 0 0 16px rgba(47, 107, 79, 0); }
}
.dtc-redeem-box .dtc-slider.is-hint::-webkit-slider-thumb {
	animation: dtc-thumb-hint 1.2s ease-in-out;
}
.dtc-redeem-box .dtc-slider.is-hint::-moz-range-thumb {
	animation: dtc-thumb-hint 1.2s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
	.dtc-redeem-box .dtc-slider.is-hint::-webkit-slider-thumb,
	.dtc-redeem-box .dtc-slider.is-hint::-moz-range-thumb {
		animation: none;
	}
}
.dtc-redeem-box .dtc-slider::-moz-range-track {
	height: 8px;
	background: transparent;
	border-radius: 999px;
}
.dtc-redeem-box .dtc-slider-ends {
	display: flex;
	justify-content: space-between;
	margin: 6px 4px 0;
	font-size: 0.78em;
	color: var(--dtc-muted);
}

/* Action row under the slider (Apply primary, Max secondary). */
.dtc-redeem-box .dtc-form-actions {
	display: flex;
	gap: 8px;
	margin-top: 14px;
}
.dtc-redeem-box .dtc-form-actions .dtc-apply-btn {
	flex: 1 1 auto;
	padding: 12px 16px;
	font-size: 0.95em;
}
.dtc-redeem-box .dtc-form-actions .dtc-max-btn {
	border: 1px solid var(--dtc-border);
	background: var(--dtc-gold-soft);
	color: var(--dtc-gold);
	border-radius: var(--dtc-radius-sm);
	padding: 0 18px;
	flex-shrink: 0;
}

@media (max-width: 480px) {
	.dtc-redeem-box .dtc-slider-readout__num { font-size: 1.45em; }
	.dtc-redeem-box .dtc-slider-readout { padding: 10px 12px; }
}

.dtc-redeem-box .dtc-disclaimer {
	margin-top: 10px;
	padding-top: 10px;
	border-top: 1px dashed var(--dtc-border);
}

/* Inline message */
.dtc-redeem-box .dtc-message {
	margin-top: 12px;
	padding: 10px 12px;
	border-radius: var(--dtc-radius-sm);
	font-size: 0.86em;
	border: 1px solid transparent;
	animation: dtc-fade-up .22s var(--dtc-ease) both;
}

.dtc-redeem-box .dtc-message.dtc-success {
	background: #e8f7ef;
	color: #0f5a32;
	border-color: #c5e8d3;
}

.dtc-redeem-box .dtc-message.dtc-error {
	background: #fdecea;
	color: #7a1d18;
	border-color: #f4c8c4;
}

/* ====================================================================
   Guest cart marketing card
   ==================================================================== */

.dtc-guest-marketing > th {
	background: transparent !important;
	border-top: 1px solid var(--dtc-border) !important;
	padding: 12px 0 !important;
}

.dtc-guest-box {
	background: var(--dtc-gold-soft);
	border: 1px solid #f1e0bf;
	border-inline-start: 3px solid var(--dtc-gold);
	border-radius: var(--dtc-radius);
	padding: 14px 16px;
	font-size: 0.9em;
	color: #5b4426;
	line-height: 1.5;
	box-shadow: var(--dtc-shadow-sm);
	animation: dtc-fade-up .28s var(--dtc-ease) both;
}

.dtc-guest-box strong { color: #4a3517; }

.dtc-guest-box__estimate {
	margin-top: 6px;
	font-size: 0.95em;
	color: #8a6a1e;
}

/* ====================================================================
   My Account: loyalty coins
   ==================================================================== */

.dtc-account .dtc-h2 {
	margin: 0 0 16px;
	font-size: 1.4em;
	color: var(--dtc-green-deep);
}

.dtc-card {
	background: var(--dtc-bg);
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius);
	padding: 18px 20px;
	margin-bottom: 20px;
	box-shadow: var(--dtc-shadow-sm);
}

/* Hero summary */
.dtc-card--summary {
	background: var(--dtc-green-soft);
	border-color: #d8e4dd;
	border-inline-start: 3px solid var(--dtc-green);
}

.dtc-summary {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-bottom: 14px;
}

.dtc-summary__item {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.dtc-summary .dtc-label {
	color: var(--dtc-muted);
	font-size: 0.78em;
}

.dtc-summary .dtc-value {
	font-weight: 700;
	font-size: 1.6em;
	line-height: 1.1;
	color: var(--dtc-green-deep);
	display: flex;
	align-items: baseline;
	gap: 6px;
	flex-wrap: wrap;
}

.dtc-summary .dtc-value small {
	font-size: 0.55em;
	font-weight: 500;
	color: var(--dtc-muted);
	text-transform: none;
	letter-spacing: 0;
}

.dtc-explainer p {
	margin: 4px 0;
	font-size: 0.9em;
	color: var(--dtc-text);
}

.dtc-explainer .dtc-disclaimer {
	color: var(--dtc-muted);
	font-size: 0.82em;
	margin-top: 8px;
}

/* Ledger table */
.dtc-account h3 {
	margin: 22px 0 10px;
	font-size: 1.05em;
	color: var(--dtc-text);
}

.dtc-table-wrap {
	overflow-x: auto;
	background: var(--dtc-bg);
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius);
	box-shadow: var(--dtc-shadow-sm);
}

.dtc-ledger-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.92em;
}

.dtc-ledger-table th,
.dtc-ledger-table td {
	padding: 11px 14px;
	text-align: start;
	border-bottom: 1px solid var(--dtc-border);
	vertical-align: middle;
}

.dtc-ledger-table tr:last-child td { border-bottom: 0; }

.dtc-ledger-table th {
	background: var(--dtc-bg-subtle);
	font-weight: 600;
	color: var(--dtc-muted);
	font-size: 0.85em;
}

.dtc-ledger-table tbody tr {
	transition: background .15s var(--dtc-ease);
}

.dtc-ledger-table tbody tr:hover {
	background: var(--dtc-green-soft);
}

.dtc-pill {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 0.75em;
	font-weight: 600;
	background: var(--dtc-bg-subtle);
	color: var(--dtc-muted);
	border: 1px solid var(--dtc-border);
	white-space: nowrap;
}

.dtc-pill--earn      { background: #e8f7ef; color: #0f5a32; border-color: #c5e8d3; }
.dtc-pill--redeem    { background: #fdf6e3; color: #8a6a1e; border-color: #f1e0bf; }
.dtc-pill--reverse,
.dtc-pill--refund    { background: #fdecea; color: #7a1d18; border-color: #f4c8c4; }
.dtc-pill--manual    { background: #eef0ff; color: #34418e; border-color: #d3d8ff; }
.dtc-pill--bonus     { background: #fdf6e3; color: #8a6a1e; border-color: #f1e0bf; }

.dtc-ledger-table .dtc-pos { color: var(--dtc-success); font-weight: 700; }
.dtc-ledger-table .dtc-neg { color: var(--dtc-error);   font-weight: 700; }

.dtc-ledger-table .dtc-empty {
	padding: 28px 12px;
	text-align: center;
	color: var(--dtc-muted);
}

/* Pagination */
.dtc-pagination {
	margin-top: 14px;
	display: flex;
	gap: 4px;
	flex-wrap: wrap;
}

.dtc-pagination .page-numbers {
	padding: 6px 11px;
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius-sm);
	color: var(--dtc-text);
	text-decoration: none;
	font-size: 0.88em;
	transition: background .15s var(--dtc-ease), color .15s var(--dtc-ease);
}

.dtc-pagination .page-numbers:hover {
	background: var(--dtc-green-soft);
	color: var(--dtc-green-deep);
}

.dtc-pagination .page-numbers.current {
	background: var(--dtc-green-deep);
	color: #fff;
	border-color: var(--dtc-green-deep);
}

/* ====================================================================
   Floating toast
   ==================================================================== */
.dtc-toast-host {
	position: fixed;
	z-index: 9999;
	bottom: 20px;
	inset-inline-end: 20px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	pointer-events: none;
	max-width: 360px;
}

.dtc-toast {
	pointer-events: auto;
	background: #fff;
	color: var(--dtc-text);
	padding: 11px 14px;
	border-radius: var(--dtc-radius-sm);
	box-shadow: var(--dtc-shadow-md);
	font-size: 0.88em;
	border: 1px solid var(--dtc-border);
	animation: dtc-fade-up .22s var(--dtc-ease) both;
}

.dtc-toast--success { border-inline-start: 3px solid var(--dtc-success); }
.dtc-toast--error   { border-inline-start: 3px solid var(--dtc-error); }

.dtc-toast.dtc-toast--leaving {
	animation: dtc-fade-out .22s var(--dtc-ease) both;
}

@keyframes dtc-fade-out {
	from { opacity: 1; transform: translateY(0); }
	to   { opacity: 0; transform: translateY(4px); }
}

/* ====================================================================
   Responsive
   ==================================================================== */
@media (max-width: 600px) {
	.dtc-redeem-box .dtc-form {
		flex-direction: column;
	}
	.dtc-input-group {
		flex: 1 1 auto;
	}
	.dtc-redeem-box .dtc-apply-btn {
		width: 100%;
		text-align: center;
	}
	.dtc-summary { grid-template-columns: 1fr; gap: 12px; }
	.dtc-summary .dtc-value { font-size: 1.4em; }
	.dtc-toast-host { inset-inline: 12px; bottom: 12px; max-width: none; }
}

@media (prefers-reduced-motion: reduce) {
	.dtc-redeem-box,
	.dtc-toast,
	.dtc-redeem-box .dtc-message { animation: none !important; transition: none !important; }
}

/* ====================================================================
   v1.1 — My Account redesign (Hero / Banners / Stats / Buckets / etc.)
   Designed mobile-first, fits inside Woo's account-content column.
   ==================================================================== */

.dtc-account { color: var(--dtc-text); }

/* ---- Cross-link bar: from /my-account/coins/ to public /loyalty/ ---- */
.dtc-loyalty-link-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 12px 18px;
	margin-bottom: 16px;
	background: linear-gradient(135deg, #fff8e1, #fdf6e3);
	border: 1px dashed #e6c474;
	border-radius: 10px;
	color: #6f5414 !important;
	text-decoration: none !important;
	font-weight: 600;
	transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.dtc-loyalty-link-bar:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 16px -8px rgba(184, 146, 62, .35);
	background: linear-gradient(135deg, #fff3c4, #fff8e1);
	color: #6f5414 !important;
}
.dtc-loyalty-link-bar__text { flex: 1; line-height: 1.6; }
.dtc-loyalty-link-bar__arrow {
	font-size: 1.2em;
	font-weight: 700;
	color: #b8923e;
	flex-shrink: 0;
	transition: transform .15s ease;
}
.dtc-loyalty-link-bar:hover .dtc-loyalty-link-bar__arrow {
	transform: translateX(-3px);
}

.dtc-card {
	background: var(--dtc-bg);
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius);
	box-shadow: var(--dtc-shadow-sm);
	padding: 18px 20px;
	margin-bottom: 18px;
}

/* ---- Hero ---- */
.dtc-hero {
	position: relative;
	overflow: hidden;
	border-radius: 16px;
	color: #fff;
	margin-bottom: 18px;
	padding: 28px 24px;
	/* Brand-driven gradient: dark → brand → fade. Falls back to the
	   original sage-green palette when the theme tab hasn't been
	   touched, so existing installs look identical. */
	background: linear-gradient(var(--dtc-grad-angle, 135deg),
		var(--dtc-dark, #214f3a) 0%,
		var(--dtc-green, #2f6b4f) 60%,
		var(--dtc-green-light, #3b8160) 100%);
	box-shadow: 0 18px 40px -22px rgba(15,50,35,0.5), 0 2px 6px rgba(15,50,35,0.08);
}

.dtc-hero__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		radial-gradient( 480px 220px at 110% -10%, rgba(184,146,62,0.22), transparent 60%),
		radial-gradient( 360px 240px at -10% 110%, rgba(255,255,255,0.10), transparent 70%);
}

.dtc-hero__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.dtc-hero__eyebrow {
	font-size: 0.78em;
	font-weight: 600;
	margin: 0;
	color: rgba(255,255,255,0.78);
}

.dtc-hero__sub {
	margin: 4px 0 0;
	color: rgba(255,255,255,0.85);
	font-size: 0.95em;
}

.dtc-hero__balance {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.dtc-hero__coins {
	display: flex;
	align-items: baseline;
	gap: 10px;
	font-feature-settings: "tnum";
}

.dtc-hero__num {
	font-size: clamp(2.4em, 6vw, 3.6em);
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.02em;
	color: #fff;
	text-shadow: 0 1px 0 rgba(0,0,0,0.06);
}

.dtc-hero__unit {
	font-size: 1.05em;
	font-weight: 600;
	color: rgba(255,255,255,0.85);
}

.dtc-hero__value {
	font-size: 1em;
	color: rgba(255,255,255,0.95);
}

.dtc-hero__value strong {
	color: #fbe9bf;
	font-weight: 700;
}

.dtc-hero__cta {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: 4px;
}

/* Buttons */
.dtc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 18px;
	border-radius: 999px;
	font-weight: 600;
	font-size: 0.95em;
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none !important;
	transition: transform .15s var(--dtc-ease), box-shadow .15s var(--dtc-ease), background .15s var(--dtc-ease);
}

.dtc-btn--primary {
	background: var(--dtc-gold);
	color: #221604 !important;
	box-shadow: 0 4px 14px -6px rgba(184,146,62,0.7);
}
.dtc-btn--primary:hover { transform: translateY(-1px); background: #cba350; }

.dtc-btn--ghost {
	background: transparent;
	color: #fff !important;
	border-color: rgba(255,255,255,0.55);
}
.dtc-btn--ghost:hover { background: rgba(255,255,255,0.12); }

/* ---- Banners (campaign + warning) ---- */
.dtc-banner {
	display: flex;
	gap: 14px;
	align-items: flex-start;
	border-radius: 12px;
	padding: 14px 16px;
	margin-bottom: 14px;
	border: 1px solid;
	background: #fff;
	animation: dtc-fade-up .25s var(--dtc-ease) both;
}

.dtc-banner__icon {
	flex: 0 0 auto;
	width: 30px; height: 30px;
	border-radius: 50%;
	display: grid; place-items: center;
	font-weight: 800;
	font-size: 0.95em;
}

.dtc-banner__body { font-size: 0.95em; line-height: 1.5; }
.dtc-banner__sub  { color: var(--dtc-muted); margin-top: 2px; font-size: 0.92em; }
.dtc-banner__cta  {
	display: inline-block;
	margin-inline-start: 6px;
	font-weight: 600;
	white-space: nowrap;
}

.dtc-banner--campaign {
	background: linear-gradient(180deg, #fff8e6, #fdf3d2);
	border-color: #ecd58c;
	color: #6e530f;
}
.dtc-banner--campaign .dtc-banner__icon { background: #f1c452; color: #5a3f0a; }
.dtc-banner--campaign .dtc-banner__cta  { color: #6e530f; }

.dtc-banner--warning {
	background: linear-gradient(180deg, #fff4f1, #fee9e2);
	border-color: #f4c0a9;
	color: #8a3a17;
}
.dtc-banner--warning .dtc-banner__icon { background: #e07644; color: #fff; }
.dtc-banner--warning .dtc-banner__cta  { color: #8a3a17; }

/* ---- Stat tiles ---- */
.dtc-stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
	gap: 12px;
	margin-bottom: 18px;
}

.dtc-stat {
	background: #fff;
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius);
	padding: 14px 16px;
	box-shadow: var(--dtc-shadow-sm);
	display: flex; flex-direction: column; gap: 4px;
}

.dtc-stat__label {
	font-size: 0.9em;
	color: var(--dtc-muted);
	font-weight: 600;
}
.dtc-stat__value {
	font-size: 1.5em;
	font-weight: 700;
	color: var(--dtc-text);
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.dtc-stat__note {
	font-size: 0.82em;
	color: var(--dtc-muted);
}

.dtc-stat--accent {
	border-inline-start: 3px solid var(--dtc-gold);
	background: linear-gradient(180deg, #fffaee, #fff);
}
.dtc-stat--expiry {
	border-inline-start: 3px solid #e07644;
	background: linear-gradient(180deg, #fff8f4, #fff);
}

.dtc-boost-chip {
	background: var(--dtc-gold);
	color: #221604;
	font-size: 0.55em;
	font-weight: 800;
	padding: 3px 8px;
	border-radius: 999px;
}

/* ---- Explainer ---- */
.dtc-explainer__h {
	margin: 0 0 12px;
	font-size: 1em;
	font-weight: 600;
	color: var(--dtc-green-deep);
}

.dtc-steps {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	gap: 12px;
	grid-template-columns: 1fr;
}
@media (min-width: 720px) {
	.dtc-steps { grid-template-columns: repeat(3, 1fr); }
}

.dtc-steps li {
	display: flex;
	gap: 12px;
	align-items: flex-start;
}

.dtc-steps__num {
	flex: 0 0 auto;
	width: 26px; height: 26px;
	border-radius: 50%;
	background: var(--dtc-green-soft);
	color: var(--dtc-green-deep);
	font-weight: 700;
	font-size: 0.85em;
	display: grid; place-items: center;
}

.dtc-steps p {
	margin: 2px 0 0;
	font-size: 0.88em;
	color: var(--dtc-muted);
	line-height: 1.45;
}

/* ---- Expiry buckets table ---- */
.dtc-buckets__h {
	margin: 0 0 10px;
	font-size: 1em;
	font-weight: 600;
	color: var(--dtc-green-deep);
}
.dtc-buckets__table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.92em;
}
.dtc-buckets__table th,
.dtc-buckets__table td {
	padding: 8px 10px;
	border-bottom: 1px solid var(--dtc-border);
	text-align: start;
}
.dtc-buckets__table tr:last-child td { border-bottom: 0; }
.dtc-buckets__table th {
	background: var(--dtc-bg-subtle);
	color: var(--dtc-muted);
	font-size: 0.75em;
}

/* ---- History head ---- */
.dtc-history__head {
	display: inherit;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 10px;
}
.dtc-history__head h3 { margin: 0; font-size: 1em; color: var(--dtc-green-deep); }
.dtc-history__count {
	font-size: 0.78em;
	color: var(--dtc-muted);
	background: var(--dtc-bg-subtle);
	padding: 3px 9px;
	border-radius: 999px;
	border: 1px solid var(--dtc-border);
}
/* «حالا چه کنم؟» footer — closes the earn→spend loop at the end of history. */
.dtc-history__foot {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid var(--dtc-border);
}
.dtc-history__foot > span {
	font-size: 0.9em;
	color: var(--dtc-text);
	font-weight: 600;
}

/* additional pill colors for new types */
.dtc-pill--retro  { background: #eef7ff; color: #1f3f78; border-color: #c5d9f5; }
.dtc-pill--expiry { background: #f3f0ed; color: #5b4d40; border-color: #ddd4cb; }

.dtc-cell-note {
	color: var(--dtc-muted);
	font-size: 0.88em;
	max-width: 240px;
}

.dtc-muted { color: var(--dtc-muted); }

.dtc-foot-disclaimer {
	font-size: 0.82em;
	color: var(--dtc-muted);
	margin-top: 14px;
	text-align: center;
}

.dtc-empty__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 22px 8px;
}
.dtc-empty__inner strong { font-size: 1.05em; color: var(--dtc-text); }
.dtc-empty__inner span { color: var(--dtc-muted); }

/* ---- Responsive table → cards on mobile ---- */
@media (max-width: 720px) {
	.dtc-ledger-table thead { display: none; }
	.dtc-ledger-table, .dtc-ledger-table tbody, .dtc-ledger-table tr, .dtc-ledger-table td {
		display: block;
		width: 100%;
	}
	.dtc-ledger-table tr {
		border: 1px solid var(--dtc-border);
		border-radius: var(--dtc-radius-sm);
		padding: 4px 8px;
		margin-bottom: 10px;
		background: #fff;
	}
	.dtc-ledger-table td {
		display: flex;
		justify-content: space-between;
		align-items: center;
		gap: 14px;
		padding: 8px 4px;
		border-bottom: 1px dashed var(--dtc-border);
	}
	.dtc-ledger-table tr td:last-child { border-bottom: 0; }
	.dtc-ledger-table td::before {
		content: attr(data-label);
		font-size: 0.72em;
		font-weight: 600;
		color: var(--dtc-muted);
	}
	.dtc-cell-note { text-align: end; }
}

/* ══════════════════════════════════════════════════════════════════════════
   Monthly trend card (My-Account → امتیازم) — inline SVG, no JS.
   ══════════════════════════════════════════════════════════════════════════ */
.dtc-account .dtc-trend { padding: 18px 20px 14px; }
.dtc-account .dtc-trend__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 10px;
}
.dtc-account .dtc-trend__head h3 {
	margin: 0;
	font-size: 1em;
	color: var(--dtc-green-deep);
}
.dtc-account .dtc-trend__legend {
	display: inline-flex;
	gap: 12px;
	flex-wrap: wrap;
	font-size: 0.82em;
	color: var(--dtc-muted);
}
.dtc-account .dtc-trend__chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.dtc-account .dtc-trend__dot {
	width: 10px;
	height: 10px;
	border-radius: 999px;
	display: inline-block;
}
.dtc-account .dtc-trend__chip--earn   .dtc-trend__dot { background: #1a9d54; }
.dtc-account .dtc-trend__chip--redeem .dtc-trend__dot { background: #dba617; }
.dtc-account .dtc-trend__chip--expire .dtc-trend__dot { background: #d63638; }

.dtc-account .dtc-trend__chart-wrap {
	width: 100%;
	overflow: hidden;
}
.dtc-account .dtc-trend__chart {
	width: 100%;
	height: 180px;
	display: block;
}
.dtc-account .dtc-trend__baseline {
	stroke: var(--dtc-border);
	stroke-width: 1;
}
.dtc-account .dtc-trend__bar {
	transition: opacity .15s ease;
}
.dtc-account .dtc-trend__bar:hover { opacity: .82; }
.dtc-account .dtc-trend__bar--earn   { fill: #1a9d54; }
.dtc-account .dtc-trend__bar--redeem { fill: #dba617; }
.dtc-account .dtc-trend__bar--expire { fill: #d63638; }
.dtc-account .dtc-trend__xlabel {
	font-size: 11px;
	fill: var(--dtc-muted);
	font-family: inherit;
}
.dtc-account .dtc-trend__empty {
	margin: 8px 0 6px;
	padding: 14px 16px;
	background: var(--dtc-bg-subtle);
	border: 1px dashed var(--dtc-border);
	border-radius: var(--dtc-radius-sm);
	color: var(--dtc-muted);
	font-size: 0.92em;
	text-align: center;
}
.dtc-account .dtc-trend__totals {
	margin-top: 8px;
	padding-top: 10px;
	border-top: 1px dashed var(--dtc-border);
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	align-items: center;
	font-size: 0.88em;
}
.dtc-account .dtc-trend__totals-label { color: var(--dtc-muted); }
.dtc-account .dtc-trend__tot { font-weight: 700; }
.dtc-account .dtc-trend__tot--earn   { color: #0f5132; }
.dtc-account .dtc-trend__tot--redeem { color: #8a6a1e; }
.dtc-account .dtc-trend__tot--expire { color: #7a1f20; }

/* ─── Tinted history rows (subtle inline-start accent + soft bg on hover) ─ */
.dtc-account .dtc-ledger-row {
	border-inline-start: 3px solid transparent;
	transition: background .15s ease;
}
.dtc-account .dtc-ledger-row--earn    { border-inline-start-color: #1a9d54; }
.dtc-account .dtc-ledger-row--redeem  { border-inline-start-color: #dba617; }
.dtc-account .dtc-ledger-row--expire  { border-inline-start-color: #d63638; }
.dtc-account .dtc-ledger-row--reverse { border-inline-start-color: #b3261e; }
.dtc-account .dtc-ledger-row:hover    { background: var(--dtc-bg-subtle); }
.dtc-account .dtc-ledger-row--earn:hover    { background: #f3faf6; }
.dtc-account .dtc-ledger-row--redeem:hover  { background: #fdf8ec; }
.dtc-account .dtc-ledger-row--expire:hover  { background: #fdf2f2; }
.dtc-account .dtc-ledger-row--reverse:hover { background: #fdf2f2; }
.dtc-account .dtc-ledger-row--manual:hover  { background: #f3f4fb; }

@media (max-width: 600px) {
	.dtc-account .dtc-trend__chart { height: 150px; }
	.dtc-account .dtc-trend__xlabel { font-size: 13px; }
	/* On the stacked mobile cards the inline-start border is invisible — show a
	   thin top accent instead so the category is still readable. */
	.dtc-account .dtc-ledger-row { border-inline-start: 0; border-top: 3px solid transparent; }
	.dtc-account .dtc-ledger-row--earn    { border-top-color: #1a9d54; }
	.dtc-account .dtc-ledger-row--redeem  { border-top-color: #dba617; }
	.dtc-account .dtc-ledger-row--expire  { border-top-color: #d63638; }
	.dtc-account .dtc-ledger-row--reverse { border-top-color: #b3261e; }
	.dtc-account .dtc-ledger-row--manual  { border-top-color: #34418e; }
}

/* ─── Expiry days-remaining badge inside the ledger «انقضا» column ───── */
.dtc-account .dtc-expiry-days {
	display: inline-block;
	margin-top: 3px;
	font-size: 0.82em;
	font-weight: 600;
	color: var(--dtc-muted);
	line-height: 1.5;
}
.dtc-account .dtc-expiry-days--warning {
	color: #7a1d18;             /* قرمز زرشکی */
	font-weight: 800;
}
.dtc-account .dtc-expiry-days--expired {
	color: #6b7280;
	text-decoration: line-through;
	font-weight: 600;
}

/* ─── Earn hint (single product + cart/checkout totals) ─────────────────── */
.dtc-earn-hint {
	color: var(--dtc-green-deep);
	font-size: 0.93em;
	line-height: 1.8;
}
.dtc-earn-hint.is-boosted {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
	background: linear-gradient(180deg, var(--dtc-gold-soft), #fff);
	border: 1px solid #f1e0bf;
	border-radius: var(--dtc-radius-sm);
	padding: 8px 12px;
}
.dtc-earn-hint-row.is-boosted td { color: var(--dtc-green-deep); font-weight: 600; }
.dtc-earn-hint__boost {
	display: inline-block;
	background: #ffeec2;
	color: #6f5414;
	font-size: 0.84em;
	font-weight: 700;
	padding: 2px 10px;
	border-radius: 999px;
	margin-inline-start: 6px;
	white-space: nowrap;
}

/* ---- Loyalty dashboard (/loyalty/) — mobile tweaks ----------------- */
@media (max-width: 549px) {
	.dtc-account .dtc-stats { grid-template-columns: repeat(2, 1fr) !important; gap: 10px; }
	.dtc-account .dtc-hero__num { font-size: 2.4em; }
	.dtc-account .dtc-hero__cta { flex-direction: column; gap: 10px; }
	.dtc-account .dtc-hero__cta .dtc-btn { width: 100%; text-align: center; }
	.dtc-account .dtc-trend__chart { min-height: 180px; }
}

/* Collapse empty dashboard wrappers so guests don't see blank space at
   the top of the loyalty page (each personal-section shortcode renders
   a bare <div class="dtc-account"></div> when the visitor is not
   logged in). */
.dtc-account:empty { display: none; }

/* Standalone redeem-box wrapper used when the plugin can't rely on
   the WC cart-totals/review-order <table> being present (Flatsome
   and other themes override those templates). Gives the box room to
   breathe outside the totals column. */
.dtc-redeem-row--standalone {
	display: block;
	width: 100%;
	max-width: 720px;
	margin: 18px auto;
	clear: both;
}

/* Suppress theme-injected ::before backgrounds on the counter-variant
   header button (some themes layer a hover/underline pseudo-element
   over anchor tags that would otherwise sit on top of the gold pill). */
a.dtc-hbtn-counter::before {
	background: none !important;
}

/* ====================================================================
   Rewards catalog ([nikyar_rewards]) + My Rewards ([nikyar_my_rewards])
   Uses the same token palette / card + button language as the rest of
   the plugin so the storefront matches the redeem box, hero and history.
   ==================================================================== */

.dtc-rewards { max-width: 1100px; margin: 0 auto; color: var(--dtc-text); }
.dtc-rewards__balance { font-size: 1.02em; margin: 0 0 14px; }
.dtc-rewards__balance strong { color: var(--dtc-green-deep); }
.dtc-rewards__guest-note {
	background: var(--dtc-green-soft);
	border: 1px solid var(--dtc-border);
	border-inline-start: 3px solid var(--dtc-green);
	border-radius: var(--dtc-radius);
	padding: 12px 16px;
	margin: 0 0 16px;
}
.dtc-rewards__filters { display: flex; gap: 10px; margin: 0 0 18px; flex-wrap: wrap; }
.dtc-rewards__filters select {
	padding: 8px 12px;
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius-sm);
	background: var(--dtc-bg);
	color: var(--dtc-text);
	font: inherit;
}
.dtc-rewards__empty { color: var(--dtc-muted); text-align: center; padding: 30px 0; }
.dtc-rewards__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 16px;
}

.dtc-reward-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--dtc-bg);
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius);
	padding: 16px;
	box-shadow: var(--dtc-shadow-sm);
	animation: dtc-fade-up .28s var(--dtc-ease) both;
}
.dtc-reward-card__featured {
	position: absolute;
	top: 10px;
	inset-inline-start: 10px;
	background: var(--dtc-gold);
	color: #fff;
	font-size: .72em;
	font-weight: 600;
	padding: 3px 9px;
	border-radius: 999px;
}
.dtc-reward-card__img { text-align: center; margin-bottom: 12px; }
.dtc-reward-card__img img { max-width: 100%; height: 130px; object-fit: contain; }
.dtc-reward-card__brand { color: var(--dtc-muted); font-size: .85em; }
.dtc-reward-card__title { font-size: 1.05em; font-weight: 600; margin: 4px 0 8px; color: var(--dtc-text); }
.dtc-reward-card__cost { font-weight: 700; color: var(--dtc-green-deep); margin-bottom: 8px; }
.dtc-reward-card__scarce { color: var(--dtc-error); font-size: .85em; margin-bottom: 8px; }
/* Expiry #1: offer window (when the reward stops being offered) */
.dtc-reward-card__window { color: var(--dtc-gold); font-size: .82em; margin-bottom: 4px; }
/* Expiry #2: code validity after claiming */
.dtc-reward-card__codelife { color: var(--dtc-muted); font-size: .82em; margin-bottom: 8px; }
.dtc-reward-card__cta { margin-top: auto; }

.dtc-reward-btn {
	display: block;
	width: 100%;
	box-sizing: border-box;
	padding: 10px 14px;
	border: 0;
	border-radius: var(--dtc-radius-sm);
	background: var(--dtc-green);
	color: #fff;
	font-size: .95em;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	cursor: pointer;
	transition: background .2s var(--dtc-ease), transform .15s var(--dtc-ease);
}
.dtc-reward-btn:hover:not(:disabled) { background: var(--dtc-green-deep); transform: translateY(-1px); color: #fff; }
.dtc-reward-btn:disabled {
	background: var(--dtc-bg-subtle);
	color: var(--dtc-muted);
	border: 1px solid var(--dtc-border);
	cursor: not-allowed;
}
.dtc-reward-btn--login { background: var(--dtc-gold); }
.dtc-reward-btn--login:hover { filter: brightness(.95); color: #fff; }

.dtc-reward-card__terms { margin-top: 10px; font-size: .85em; color: var(--dtc-muted); }
.dtc-reward-card__terms summary { cursor: pointer; color: var(--dtc-green-deep); }

/* Confirm / address / result modal */
.dtc-rw-modal {
	position: fixed;
	inset: 0;
	display: none;
	z-index: 99999;
	align-items: center;
	justify-content: center;
	background: rgba(15, 50, 35, .55);
}
.dtc-rw-modal.is-open { display: flex; }
.dtc-rw-modal__box {
	background: var(--dtc-bg);
	color: var(--dtc-text);
	border-radius: var(--dtc-radius);
	padding: 22px;
	max-width: 420px;
	width: 92%;
	max-height: 90vh;
	overflow: auto;
	box-shadow: var(--dtc-shadow-md);
	animation: dtc-fade-up .2s var(--dtc-ease) both;
}
.dtc-rw-modal__box h3 { margin-top: 0; color: var(--dtc-green-deep); }
.dtc-rw-modal__box input {
	width: 100%;
	box-sizing: border-box;
	padding: 9px 10px;
	margin: 5px 0;
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius-sm);
	color: var(--dtc-text);
	font: inherit;
}
.dtc-rw-actions { display: flex; gap: 10px; margin-top: 16px; }
.dtc-rw-actions button,
.dtc-rw-actions a {
	flex: 1;
	padding: 11px;
	border: 0;
	border-radius: var(--dtc-radius-sm);
	cursor: pointer;
	font: inherit;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
}
.dtc-rw-confirm { background: var(--dtc-green); color: #fff; }
.dtc-rw-confirm:hover { background: var(--dtc-green-deep); }
.dtc-rw-cost {
	font-size: 1.4em;
	font-weight: 800;
	color: var(--dtc-green-deep);
	margin: 6px 0 4px;
}
.dtc-rw-codelife { color: var(--dtc-muted); font-size: .88em; margin: 4px 0 0; }
.dtc-rw-cancel { background: var(--dtc-bg-subtle); color: var(--dtc-text); border: 1px solid var(--dtc-border) !important; }
.dtc-rw-code {
	font-size: 1.3em;
	font-weight: 700;
	letter-spacing: 1px;
	background: var(--dtc-green-soft);
	color: var(--dtc-green-deep);
	border: 1px dashed var(--dtc-green);
	padding: 12px;
	border-radius: var(--dtc-radius-sm);
	text-align: center;
	direction: ltr;
	margin: 12px 0;
}

/* My Rewards list */
.dtc-my-rewards { max-width: 720px; margin: 0 auto; color: var(--dtc-text); }
.dtc-my-rewards__title { color: var(--dtc-green-deep); }
.dtc-mr-item {
	background: var(--dtc-bg);
	border: 1px solid var(--dtc-border);
	border-radius: var(--dtc-radius);
	padding: 16px;
	margin-bottom: 14px;
	box-shadow: var(--dtc-shadow-sm);
	animation: dtc-fade-up .28s var(--dtc-ease) both;
}
.dtc-mr-item__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.dtc-mr-item__brand { color: var(--dtc-muted); font-size: .85em; }
.dtc-mr-item__title { font-size: 1.05em; font-weight: 600; }
.dtc-mr-item__status {
	font-size: .78em;
	padding: 4px 11px;
	border-radius: 999px;
	white-space: nowrap;
	border: 1px solid var(--dtc-border);
	background: var(--dtc-bg-subtle);
	color: var(--dtc-muted);
}
.dtc-mr--delivered .dtc-mr-item__status,
.dtc-mr--completed .dtc-mr-item__status { background: #e8f7ef; color: #0f5a32; border-color: #c5e8d3; }
.dtc-mr--pending .dtc-mr-item__status,
.dtc-mr--shipped .dtc-mr-item__status { background: var(--dtc-gold-soft); color: #8a6a1e; border-color: #f1e0bf; }
.dtc-mr--refunded .dtc-mr-item__status,
.dtc-mr--rejected .dtc-mr-item__status { background: #fdecea; color: #7a1d18; border-color: #f4c8c4; }
.dtc-mr-item__code { display: flex; gap: 8px; align-items: center; margin: 12px 0; }
.dtc-mr-item__code code {
	flex: 1;
	background: var(--dtc-green-soft);
	color: var(--dtc-green-deep);
	border: 1px dashed var(--dtc-green);
	padding: 11px;
	border-radius: var(--dtc-radius-sm);
	font-size: 1.12em;
	letter-spacing: 1px;
	text-align: center;
}
.dtc-mr-copy {
	padding: 9px 14px;
	border: 0;
	border-radius: var(--dtc-radius-sm);
	background: var(--dtc-green);
	color: #fff;
	cursor: pointer;
	font: inherit;
	font-weight: 600;
}
.dtc-mr-copy:hover { background: var(--dtc-green-deep); }
.dtc-mr-item__expiry,
.dtc-mr-item__tracking,
.dtc-mr-item__reason,
.dtc-mr-item__meta { font-size: .85em; color: var(--dtc-muted); margin-top: 6px; }
.dtc-mr-item__reason { color: var(--dtc-error); }
.dtc-mr-item__expiry--past { color: var(--dtc-error); font-weight: 600; }

@media (max-width: 480px) {
	.dtc-rewards__grid { grid-template-columns: 1fr 1fr; gap: 12px; }
}

/* Rewards CTA button (gold) — used in the hero, the history footer, and
   anywhere we nudge the customer toward spending points on rewards. */
.dtc-btn--reward {
	background: var(--dtc-gold);
	color: #fff;
}
.dtc-btn--reward:hover { filter: brightness(.96); color: #fff; }

/* Loyalty-hub entry banner ([nikyar_rewards_entry]) */
.dtc-rewards-entry {
	display: flex;
	align-items: center;
	gap: 14px;
	width: 100%;
	max-width: 720px;
	margin: 14px auto;
	box-sizing: border-box;
	padding: 16px 18px;
	background: linear-gradient(var(--dtc-grad-angle, 135deg), var(--dtc-green-soft), var(--dtc-bg));
	border: 1px solid var(--dtc-border);
	border-inline-start: 3px solid var(--dtc-gold);
	border-radius: var(--dtc-radius);
	box-shadow: var(--dtc-shadow-sm);
	color: var(--dtc-text);
	text-decoration: none;
	transition: box-shadow .2s var(--dtc-ease), transform .15s var(--dtc-ease);
	animation: dtc-fade-up .28s var(--dtc-ease) both;
}
.dtc-rewards-entry:hover { box-shadow: var(--dtc-shadow-md); transform: translateY(-1px); }
.dtc-rewards-entry__icon { font-size: 1.8em; line-height: 1; }
.dtc-rewards-entry__body { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.dtc-rewards-entry__title { color: var(--dtc-green-deep); font-size: 1.05em; }
.dtc-rewards-entry__sub { color: var(--dtc-muted); font-size: .9em; }
.dtc-rewards-entry__cta { color: var(--dtc-gold); font-weight: 700; white-space: nowrap; }

/* My Rewards header row (title + back-to-catalog link) */
.dtc-my-rewards__head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 10px;
	flex-wrap: wrap;
}
.dtc-my-rewards__back { color: var(--dtc-gold); font-weight: 600; text-decoration: none; white-space: nowrap; }
.dtc-my-rewards__back:hover { text-decoration: underline; }
