/* =====================================================================
 * WonderLab Account Suite — frontend CSS for the My Account area (v1.7.0).
 *
 * Visual recipe — aligned with the cartflow checkout + admin brand UI:
 *   - Brand burgundy `#851625`, blush `#E8A9B8`, ivory `#FFFBF1`
 *   - Geologica typography (loaded site-wide by Divi)
 *   - Soft cards on warm-tan washes
 *   - Modern, generous spacing
 * ===================================================================== */

:root,
.woocommerce-account {
	--wd-burgundy:       #851625;
	--wd-burgundy-dark:  #5e0f1a;
	--wd-burgundy-soft:  #fff5f6;
	--wd-burgundy-line:  rgba(133, 22, 37, 0.14);
	--wd-blush:          #f3e0e3;
	--wd-ivory:          #fffbf1;
	--wd-ivory-dark:     #f7f0e6;
	--wd-tan:            #f6f1e8;
	--wd-ink:            #2a1a14;
	--wd-ink-soft:       #6a5e54;
	--wd-ink-muted:      #98897d;
	--wd-line:           #ece4d6;
	--wd-line-strong:    #d8ccba;
	--wd-radius:         12px;
	--wd-radius-sm:      8px;
	--wd-radius-lg:      18px;
	--wd-font:           'Geologica', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--wd-shadow:         0 1px 0 var(--wd-burgundy-line), 0 12px 24px -16px rgba(94, 15, 26, 0.18);
}


/* ---------------------------------------------------------------------
 * My Account side navigation — burgundy / ivory brand pills.
 * Specificity bumped with body.woocommerce-account so Divi's default
 * link colour can't bleed through.
 * --------------------------------------------------------------------- */

body.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	margin: 0 0 6px !important;
	padding: 0 !important;
	list-style: none !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	padding: 11px 14px !important;
	border-radius: var(--wd-radius-sm) !important;
	background: #fff !important;
	border: 1px solid var(--wd-line) !important;
	font-family: var(--wd-font) !important;
	font-weight: 500 !important;
	font-size: 14px !important;
	color: var(--wd-burgundy) !important;
	transition: all 0.2s ease !important;
	text-decoration: none !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li a:focus {
	background: var(--wd-burgundy-soft) !important;
	border-color: var(--wd-burgundy-line) !important;
	color: var(--wd-burgundy-dark) !important;
}
body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a:hover,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a:focus {
	background: var(--wd-burgundy) !important;
	border-color: var(--wd-burgundy) !important;
	color: #ffffff !important;
}

/* Mobile: collapse the stacked pill column into a horizontal scrollable
   pill row so the nav doesn't burn ~half a phone screen before the
   first card. Native scrollbar hidden; the active pill auto-scrolls
   into view via assets/myaccount-mobile-nav.js. */
@media (max-width: 768px) {
	body.woocommerce-account .woocommerce-MyAccount-navigation {
		margin-bottom: 16px !important;
		position: relative;
	}
	body.woocommerce-account .woocommerce-MyAccount-navigation ul {
		display: flex !important;
		flex-direction: row !important;
		gap: 8px !important;
		overflow-x: auto !important;
		overflow-y: hidden !important;
		-webkit-overflow-scrolling: touch;
		scroll-snap-type: x proximity;
		padding: 2px 0 6px !important;
		/* Right-edge fade hint that more pills are off-screen */
		mask-image: linear-gradient(to right, #000 calc(100% - 24px), transparent);
		-webkit-mask-image: linear-gradient(to right, #000 calc(100% - 24px), transparent);
	}
	body.woocommerce-account .woocommerce-MyAccount-navigation ul::-webkit-scrollbar {
		display: none;
	}
	body.woocommerce-account .woocommerce-MyAccount-navigation ul {
		scrollbar-width: none;
	}
	body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
		flex: 0 0 auto !important;
		margin: 0 !important;
		scroll-snap-align: start;
	}
	body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
		padding: 8px 14px !important;
		font-size: 13px !important;
		white-space: nowrap !important;
	}
}


/* ---------------------------------------------------------------------
 * Dashboard layout
 * --------------------------------------------------------------------- */

.wd-dashboard {
	font-family: var(--wd-font);
	color: var(--wd-ink);
	display: flex;
	flex-direction: column;
	gap: 24px;
}


/* ---------- Hero ---------- */
.wd-hero {
	background: linear-gradient(135deg, var(--wd-ivory) 0%, var(--wd-tan) 100%);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-lg);
	padding: 30px 32px;
	box-shadow: var(--wd-shadow);
}
.wd-hero-eyebrow {
	display: inline-block;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--wd-burgundy);
	font-weight: 600;
	margin-bottom: 8px;
}
.wd-hero-title {
	font-family: var(--wd-font);
	font-weight: 700;
	color: var(--wd-ink);
	font-size: 32px;
	line-height: 1.15;
	letter-spacing: -0.5px;
	margin: 0 0 6px;
}
.wd-hero-title em {
	color: var(--wd-burgundy);
	font-style: italic;
	font-weight: 500;
}
.wd-hero-sub {
	margin: 0;
	color: var(--wd-ink-soft);
	font-size: 14.5px;
	line-height: 1.55;
}


/* ---------- Profile completion card ---------- */
.wd-profile-card {
	display: flex;
	align-items: center;
	gap: 22px;
	background: #fff;
	border: 1px solid var(--wd-line);
	border-left: 4px solid var(--wd-burgundy);
	border-radius: var(--wd-radius);
	padding: 22px 24px;
	box-shadow: var(--wd-shadow);
}
.wd-profile-card-body {
	flex: 1 1 auto;
	min-width: 0;
}
.wd-profile-card-title {
	font-family: var(--wd-font);
	font-weight: 700;
	font-size: 16.5px;
	color: var(--wd-ink);
	margin: 0 0 4px;
	letter-spacing: -0.1px;
}
.wd-profile-card-sub {
	margin: 0 0 12px;
	font-size: 13.5px;
	color: var(--wd-ink-soft);
	line-height: 1.5;
}
.wd-progress {
	width: 100%;
	height: 6px;
	border-radius: 999px;
	background: var(--wd-blush);
	overflow: hidden;
}
.wd-progress-bar {
	height: 100%;
	background: linear-gradient(90deg, var(--wd-burgundy), var(--wd-burgundy-dark));
	border-radius: inherit;
	transition: width 0.4s ease;
}
.wd-profile-card-cta {
	flex-shrink: 0;
}
.wd-profile-card--ready {
	border-left-color: #2e7d32;
}

/* Reviews-waiting widget (v1.15.23) — sits below the profile-completion
   card, before the stat cards. Uses the same burgundy left-rail accent
   to read as a "nudge" not a "status" card. */
.wd-reviews-card {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-left: 4px solid var(--wd-burgundy);
	border-radius: var(--wd-radius);
	box-shadow: var(--wd-shadow);
	padding: 18px 22px 20px;
}
.wd-reviews-card-head {
	margin-bottom: 12px;
}
.wd-reviews-card-title {
	font-family: var(--wd-font);
	font-weight: 700;
	font-size: 16.5px;
	color: var(--wd-ink);
	margin: 0 0 4px;
	letter-spacing: -0.1px;
}
.wd-reviews-card-sub {
	margin: 0;
	font-size: 13px;
	color: var(--wd-ink-soft);
	line-height: 1.5;
}
.wd-reviews-list,
.wd-reviews-list li {
	list-style: none !important;
	list-style-type: none !important;
	list-style-image: none !important;
}
.wd-reviews-list {
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.wd-reviews-list .wd-reviews-item {
	margin: 0;
	padding: 0;
	display: block;
}
/* Some themes (Divi included) decorate list items with a ::before
   bullet — kill it explicitly. */
.wd-reviews-list .wd-reviews-item::before,
.wd-reviews-list .wd-reviews-item::marker {
	content: none !important;
	display: none !important;
}
.wd-reviews-item-link {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 12px;
	border-radius: 10px;
	background: var(--wd-blush, #fffbf1);
	text-decoration: none;
	color: inherit;
	transition: background 0.15s ease, transform 0.1s ease;
}
.wd-reviews-item-link:hover,
.wd-reviews-item-link:focus-visible {
	background: rgba(133, 22, 37, 0.07);
	outline: 0;
}
.wd-reviews-item-thumb {
	flex: 0 0 auto;
	width: 48px;
	height: 48px;
	border-radius: 8px;
	background: #f0ede8;
	overflow: hidden;
}
.wd-reviews-item-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.wd-reviews-item-body {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.wd-reviews-item-title {
	font-family: var(--wd-font);
	font-weight: 600;
	font-size: 13.5px;
	color: var(--wd-ink);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.wd-reviews-item-cta {
	font-size: 12.5px;
	color: var(--wd-burgundy, #851625);
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
@media (max-width: 600px) {
	.wd-reviews-card { padding: 16px; }
	.wd-reviews-item-thumb { width: 42px; height: 42px; }
}


/* ---------- Stats grid ---------- */
.wd-stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 14px;
}
.wd-stat {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	padding: 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 4px;
	text-decoration: none !important;
	color: inherit;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
a.wd-stat:hover {
	border-color: var(--wd-burgundy-line);
	box-shadow: var(--wd-shadow);
	transform: translateY(-1px);
}
.wd-stat-label {
	font-size: 10.5px;
	letter-spacing: 1.6px;
	text-transform: uppercase;
	color: var(--wd-ink-muted);
	font-weight: 600;
}
.wd-stat-val {
	font-size: 28px;
	font-weight: 700;
	color: var(--wd-ink);
	line-height: 1.05;
	letter-spacing: -0.5px;
}
.wd-stat-val .woocommerce-Price-amount {
	font-size: inherit;
	font-weight: inherit;
	color: inherit;
}
.wd-stat-sub {
	margin-top: 2px;
	font-size: 11.5px;
	font-weight: 500;
	color: var(--wd-burgundy);
}
.wd-stat--accent {
	background: linear-gradient(135deg, var(--wd-burgundy-soft) 0%, #fbeaee 100%);
	border-color: var(--wd-burgundy-line);
}
.wd-stat--accent .wd-stat-val { color: var(--wd-burgundy); }


/* ---------- Section header ---------- */
.wd-section {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	padding: 22px 24px;
	box-shadow: var(--wd-shadow);
}
.wd-section-head {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 14px;
}
.wd-section-title {
	font-family: var(--wd-font);
	font-weight: 700;
	font-size: 16px;
	color: var(--wd-burgundy);
	margin: 0;
	letter-spacing: -0.1px;
}
.wd-section-link {
	font-size: 13px;
	color: var(--wd-burgundy) !important;
	text-decoration: none !important;
	font-weight: 500;
}
.wd-section-link:hover { text-decoration: underline !important; }


/* ---------- Orders list (card-style rows, replaces the old table) ---------- */
.wd-orders {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.wd-order {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 14px 16px;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-sm);
	background: #fff;
	text-decoration: none !important;
	color: inherit !important;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.wd-order:hover {
	border-color: var(--wd-burgundy-line);
	box-shadow: var(--wd-shadow);
}
.wd-order-main {
	flex: 1 1 auto;
	min-width: 0;
}
.wd-order-head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 4px;
}
.wd-order-num {
	font-weight: 600;
	font-size: 14px;
	color: var(--wd-burgundy);
	letter-spacing: -0.1px;
}
.wd-order-items {
	font-size: 13px;
	color: var(--wd-ink-soft);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	max-width: 100%;
}
.wd-order-date {
	font-size: 11.5px;
	color: var(--wd-ink-muted);
	margin-top: 2px;
}
.wd-order-side {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-shrink: 0;
}
.wd-order-total {
	font-weight: 600;
	font-size: 14.5px;
	color: var(--wd-ink);
	letter-spacing: -0.2px;
}
.wd-order-total .woocommerce-Price-amount {
	font-size: inherit;
	font-weight: inherit;
	color: inherit;
}
.wd-order-arrow {
	color: var(--wd-burgundy);
	font-size: 16px;
	transition: transform 0.2s ease;
}
.wd-order:hover .wd-order-arrow { transform: translateX(2px); }


/* ---------- Status badges ---------- */
.wd-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	white-space: nowrap;
}
.wd-badge--completed  { background: #e8f5e9; color: #1b5e20; }
.wd-badge--processing { background: #fff3e0; color: #b45309; }
.wd-badge--hold       { background: #f3f0ff; color: #5b3ab7; }
.wd-badge--pending    { background: #e8f4fd; color: #1565a8; }
.wd-badge--cancelled  { background: #fce8e8; color: #9b2222; }
.wd-badge--refunded   { background: #f0f0f0; color: #555555; }
.wd-badge--default    { background: #f0f0f0; color: #555555; }


/* ---------- Empty state ---------- */
.wd-empty {
	text-align: center;
	padding: 32px 16px;
	color: var(--wd-ink-soft);
}
.wd-empty p {
	margin: 0 0 14px;
	font-size: 14px;
}


/* ---------- Quick actions grid ---------- */
.wd-actions {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 12px;
}
.wd-action {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 18px 18px 16px;
	border-radius: var(--wd-radius-sm);
	background: var(--wd-ivory);
	border: 1px solid var(--wd-line);
	color: var(--wd-burgundy) !important;
	text-decoration: none !important;
	transition: all 0.2s ease;
}
.wd-action:hover {
	background: var(--wd-burgundy);
	border-color: var(--wd-burgundy);
	color: #ffffff !important;
	transform: translateY(-1px);
}
.wd-action svg {
	stroke: currentColor;
	margin-bottom: 4px;
}
.wd-action-label {
	font-size: 14px;
	font-weight: 600;
	color: inherit;
	line-height: 1.25;
}
.wd-action-sub {
	font-size: 12px;
	color: var(--wd-ink-muted);
	transition: color 0.2s ease;
}
.wd-action:hover .wd-action-sub { color: rgba(255, 255, 255, 0.8); }


/* ---------- Primary / secondary buttons used in the dashboard ---------- */
.wd-btn-primary,
.wd-btn-secondary {
	display: inline-block;
	padding: 10px 18px;
	border-radius: var(--wd-radius-sm);
	font-size: 13.5px;
	font-weight: 600;
	letter-spacing: 0;
	text-decoration: none !important;
	transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
	cursor: pointer;
	border: 1px solid transparent;
	font-family: var(--wd-font);
}
.wd-btn-primary {
	background: var(--wd-burgundy);
	color: #fff !important;
	border-color: var(--wd-burgundy);
}
.wd-btn-primary:hover {
	background: var(--wd-burgundy-dark);
	border-color: var(--wd-burgundy-dark);
}
.wd-btn-secondary {
	background: #fff;
	color: var(--wd-burgundy) !important;
	border-color: var(--wd-burgundy-line);
}
.wd-btn-secondary:hover {
	background: var(--wd-burgundy-soft);
	border-color: var(--wd-burgundy);
}


/* ---------------------------------------------------------------------
 * Other My Account screens — keep the addresses + notices treatment
 * from the previous design (it works), tuned to the new tokens.
 * --------------------------------------------------------------------- */

.woocommerce-MyAccount-content > p:first-child {
	font-size: 14px;
	color: var(--wd-ink-soft);
	margin-bottom: 24px;
}

.woocommerce-Addresses {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
	float: none !important;
	width: 100% !important;
}

.woocommerce-Address {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	padding: 22px 24px !important;
	float: none !important;
	width: 100% !important;
	margin: 0 !important;
}

.woocommerce-Address h3,
.woocommerce-Address .woocommerce-column__title {
	font-size: 12px !important;
	font-weight: 700 !important;
	color: var(--wd-burgundy) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.12em !important;
	margin: 0 0 14px 0 !important;
	padding: 0 0 10px 0 !important;
	border-bottom: 1px solid var(--wd-line) !important;
	display: block !important;
}

.woocommerce-Address .edit,
.woocommerce-Address header a {
	position: static !important;
	display: inline-block !important;
	margin-top: 12px !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	color: #fff !important;
	text-decoration: none !important;
	background: var(--wd-burgundy) !important;
	border: 1px solid var(--wd-burgundy) !important;
	border-radius: var(--wd-radius-sm) !important;
	padding: 8px 16px !important;
	transition: all 0.2s ease !important;
}
.woocommerce-Address .edit:hover,
.woocommerce-Address header a:hover {
	background: var(--wd-burgundy-dark) !important;
	border-color: var(--wd-burgundy-dark) !important;
}

.woocommerce-Address address {
	font-style: normal !important;
	font-size: 14px !important;
	color: var(--wd-ink) !important;
	line-height: 1.7 !important;
	margin-top: 6px !important;
}


/* ---------------------------------------------------------------------
 * Notices across My Account — mirrors the cartflow plugin's notice
 * pill so success / info / error messages feel native between
 * /my-account/, /cart/ and /checkout/.
 *
 * Selectors are scoped under `body.woocommerce-account` (specificity
 * 0,2,1) to beat Divi's `.woocommerce .woocommerce-message`
 * (specificity 0,2,0) regardless of source order in WP-Rocket's
 * combined bundle. Divi also carries `!important` on color / padding /
 * font-size for these classes — our scope wins on raw specificity so
 * source order stops mattering.
 * --------------------------------------------------------------------- */

body.woocommerce-account .woocommerce-message,
body.woocommerce-account .woocommerce-info,
body.woocommerce-account .woocommerce-error {
	margin: 0 0 16px !important;
	padding: 12px 16px !important;
	border-radius: 10px !important;
	border: 1px solid rgba(133, 22, 37, 0.15) !important;
	background: var(--wd-burgundy-soft) !important;
	color: var(--wd-burgundy) !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	line-height: 1.45 !important;
	list-style: none !important;
	box-shadow: none !important;
	text-shadow: none !important;
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 12px !important;
	flex-wrap: wrap !important;
}
body.woocommerce-account .woocommerce-message::before,
body.woocommerce-account .woocommerce-info::before,
body.woocommerce-account .woocommerce-error::before {
	display: none !important;
	content: none !important;
}
body.woocommerce-account .woocommerce-error {
	border-color: rgba(183, 28, 28, 0.25) !important;
	background: #fff4f4 !important;
	color: #b71c1c !important;
}
body.woocommerce-account .woocommerce-message a,
body.woocommerce-account .woocommerce-info a,
body.woocommerce-account .woocommerce-error a {
	color: inherit !important;
	font-weight: 700 !important;
	text-decoration: underline !important;
	text-underline-offset: 2px !important;
}
body.woocommerce-account .woocommerce-message ul,
body.woocommerce-account .woocommerce-message li,
body.woocommerce-account .woocommerce-info ul,
body.woocommerce-account .woocommerce-info li,
body.woocommerce-account .woocommerce-error ul,
body.woocommerce-account .woocommerce-error li {
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}
body.woocommerce-account .woocommerce-error li + li,
body.woocommerce-account .woocommerce-message li + li,
body.woocommerce-account .woocommerce-info li + li {
	margin-top: 4px !important;
}
body.woocommerce-account .woocommerce-message .button,
body.woocommerce-account .woocommerce-info .button {
	background: var(--wd-burgundy) !important;
	color: #fff !important;
	border: 1px solid var(--wd-burgundy) !important;
	border-radius: 999px !important;
	padding: 7px 14px !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	text-decoration: none !important;
	white-space: nowrap !important;
}
body.woocommerce-account .woocommerce-message .button:hover,
body.woocommerce-account .woocommerce-info .button:hover {
	background: var(--wd-burgundy-dark) !important;
	border-color: var(--wd-burgundy-dark) !important;
}


/* Orders table page (My Account → Orders) — action button spacing. */
.woocommerce-orders-table__cell-order-actions a,
.woocommerce-orders-table__cell-order-actions button,
td.order-actions a,
td.order-actions button {
	margin-right: 10px !important;
	margin-bottom: 4px !important;
	display: inline-block !important;
}
.woocommerce-orders-table__cell-order-actions a:last-child,
.woocommerce-orders-table__cell-order-actions button:last-child,
td.order-actions a:last-child,
td.order-actions button:last-child {
	margin-right: 0 !important;
}


/* ---------------------------------------------------------------------
 * Points hub — `/my-account/points/`
 * --------------------------------------------------------------------- */

.wd-points {
	font-family: var(--wd-font);
	color: var(--wd-ink);
	display: flex;
	flex-direction: column;
	gap: 22px;
}


/* Balance card */
.wd-points-balance {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 22px;
	background: linear-gradient(135deg, var(--wd-burgundy) 0%, var(--wd-burgundy-dark) 100%);
	color: #fff;
	border-radius: var(--wd-radius-lg);
	padding: 28px 30px;
	box-shadow: 0 18px 36px -22px rgba(94, 15, 26, 0.45);
}
.wd-points-balance .wd-btn-primary {
	background: #fff !important;
	color: var(--wd-burgundy) !important;
	border-color: #fff !important;
}
.wd-points-balance .wd-btn-primary:hover {
	background: var(--wd-burgundy-soft) !important;
	color: var(--wd-burgundy-dark) !important;
}
.wd-points-balance-main {
	min-width: 0;
}
.wd-points-balance-eyebrow {
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	opacity: 0.85;
	margin-bottom: 8px;
	font-weight: 600;
}
.wd-points-balance-row {
	display: flex;
	align-items: baseline;
	gap: 10px;
	margin-bottom: 8px;
}
.wd-points-balance-num {
	font-size: 44px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.8px;
}
.wd-points-balance-unit {
	font-size: 14px;
	opacity: 0.85;
}
.wd-points-balance-value {
	font-size: 14.5px;
	opacity: 0.95;
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 4px;
}
.wd-points-balance-value .woocommerce-Price-amount {
	color: #fff !important;
	font-weight: 700;
	font-size: 16px;
}
.wd-points-balance-value-sub {
	opacity: 0.8;
	margin-left: 4px;
}


/* Active multiplier banner — brand-coloured (no amber / no flame). */
.wd-points-multiplier {
	display: flex;
	align-items: center;
	gap: 14px;
	background: var(--wd-burgundy-soft);
	border: 1px solid var(--wd-burgundy-line);
	border-radius: var(--wd-radius);
	padding: 14px 18px;
	color: var(--wd-ink);
	font-size: 14px;
}
.wd-points-multiplier-chip {
	background: var(--wd-burgundy);
	color: #fff;
	font-size: 10.5px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 700;
	padding: 4px 10px;
	border-radius: 999px;
	flex-shrink: 0;
}
.wd-points-multiplier-body {
	display: flex;
	flex-wrap: wrap;
	gap: 4px 10px;
	align-items: baseline;
}
.wd-points-multiplier-body strong {
	color: var(--wd-burgundy);
	font-weight: 700;
}
.wd-points-multiplier-body span {
	color: var(--wd-ink-soft);
	font-size: 13px;
}


/* (Removed in v1.8.2 — the "How it works" collapsible section was
 * dropped from the points page because the FAQ accordion below already
 * covers the same ground.) */


/* Load-more button */
.wd-points-loadmore-wrap {
	margin-top: 14px;
	text-align: center;
}
.wd-points-loadmore-btn {
	min-width: 180px;
}


/* Pending history row */
.was-points-history tr.is-pending td {
	background: #fff8e6;
	color: var(--wd-ink-soft);
}
.was-points-history tr.is-pending td.num {
	color: #b56304;
	font-weight: 600;
}


/* FAQ accordion */
.wd-points-faq {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.wd-points-faq-item {
	background: var(--wd-ivory);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-sm);
	overflow: hidden;
}
.wd-points-faq-item summary {
	list-style: none;
	cursor: pointer;
	padding: 16px 22px;
	font-weight: 600;
	font-size: 14px;
	color: var(--wd-ink);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	transition: background 0.18s ease;
}
.wd-points-faq-item summary::-webkit-details-marker { display: none; }
.wd-points-faq-item summary::after {
	content: '+';
	font-size: 20px;
	font-weight: 400;
	color: var(--wd-burgundy);
	transition: transform 0.2s ease;
}
.wd-points-faq-item[open] summary {
	background: #fff;
	border-bottom: 1px solid var(--wd-line);
}
.wd-points-faq-item[open] summary::after {
	content: '−';
}
.wd-points-faq-item summary:hover {
	background: #fff;
}
.wd-points-faq-item p {
	margin: 0 !important;
	padding: 16px 22px 20px 22px !important;
	font-size: 13.5px;
	color: var(--wd-ink-soft);
	line-height: 1.65;
	background: #fff;
}
.wd-points-faq-item p strong { color: var(--wd-ink); }


@media (max-width: 600px) {
	.wd-points-balance { flex-direction: column; align-items: stretch; gap: 18px; padding: 22px; }
	.wd-points-balance .wd-btn-primary { text-align: center; }
	.wd-points-balance-num { font-size: 36px; }
}


/* Points endpoint (carried over from the previous design, lightly
 * recoloured against the new tokens). */
.wd-stat-link {
	font-size: 12px;
	color: var(--wd-burgundy) !important;
	text-decoration: none !important;
	margin-top: 4px;
	font-weight: 500;
}
.wd-stat-link:hover { text-decoration: underline !important; }


.was-points-balance {
	display: flex;
	align-items: baseline;
	gap: 10px;
	background: linear-gradient(135deg, var(--wd-burgundy) 0%, var(--wd-burgundy-dark) 100%);
	color: #fff;
	border-radius: var(--wd-radius);
	padding: 24px 28px;
	margin-bottom: 24px;
}
.was-points-balance-label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	opacity: 0.85;
}
.was-points-balance-val {
	font-size: 34px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.5px;
}
.was-points-balance-unit {
	font-size: 13px;
	opacity: 0.85;
}

.was-points-history-title {
	font-family: var(--wd-font);
	font-weight: 700;
	font-size: 14px;
	color: var(--wd-burgundy);
	margin: 0 0 10px;
	letter-spacing: 0.4px;
	text-transform: uppercase;
}
.was-points-empty {
	font-size: 14px;
	color: var(--wd-ink-soft);
	padding: 20px 0;
}
.was-points-history-wrap {
	overflow-x: auto;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-sm);
	background: #fff;
}
.was-points-history {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}
.was-points-history th {
	text-align: left;
	padding: 10px 14px;
	color: var(--wd-ink-muted);
	font-weight: 600;
	font-size: 11px;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	background: var(--wd-ivory);
	border-bottom: 1px solid var(--wd-line);
}
.was-points-history th.num,
.was-points-history td.num {
	text-align: right;
	white-space: nowrap;
}
.was-points-history td {
	padding: 12px 14px;
	border-bottom: 1px solid var(--wd-line);
	color: var(--wd-ink);
	vertical-align: top;
}
.was-points-history tbody tr:last-child td { border-bottom: none; }
.was-points-history td.is-add    { color: #2e7d32; font-weight: 600; }
.was-points-history td.is-deduct { color: #b71c1c; font-weight: 600; }
.was-points-note {
	font-size: 12px;
	color: var(--wd-ink-muted);
	margin-top: 2px;
}

.was-points-pagination {
	display: flex;
	gap: 6px;
	margin-top: 14px;
	flex-wrap: wrap;
}
.was-points-pagination a,
.was-points-pagination span {
	display: inline-block;
	padding: 6px 12px;
	border-radius: 6px;
	background: var(--wd-ivory);
	color: var(--wd-burgundy);
	text-decoration: none !important;
	font-size: 13px;
	font-weight: 500;
	border: 1px solid var(--wd-line);
}
.was-points-pagination span.is-current {
	background: var(--wd-burgundy);
	color: #fff;
	border-color: var(--wd-burgundy);
}


/* ---------------------------------------------------------------------
 * Orders endpoint — /my-account/orders/
 * --------------------------------------------------------------------- */

.wd-orders-page {
	font-family: var(--wd-font);
	color: var(--wd-ink);
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.wd-orders-hero {
	background: linear-gradient(135deg, var(--wd-ivory) 0%, var(--wd-tan) 100%);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-lg);
	padding: 26px 30px;
	box-shadow: var(--wd-shadow);
}
.wd-orders-eyebrow {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--wd-burgundy);
	margin-bottom: 6px;
}
.wd-orders-title {
	font-family: var(--wd-font);
	font-size: 30px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--wd-ink);
	line-height: 1.1;
}
.wd-orders-sub {
	margin: 0;
	color: var(--wd-ink-soft);
	font-size: 14px;
}

.wd-orders-filter {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 14px;
	background: var(--wd-ivory);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
}
.wd-orders-filter-pill {
	display: inline-flex;
	align-items: center;
	padding: 7px 14px;
	font-size: 13px;
	font-weight: 500;
	font-family: var(--wd-font);
	color: var(--wd-ink-soft) !important;
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: 999px;
	text-decoration: none !important;
	transition: all 0.15s ease;
	line-height: 1;
}
.wd-orders-filter-pill:hover {
	border-color: var(--wd-burgundy-line);
	color: var(--wd-burgundy) !important;
	background: var(--wd-burgundy-soft);
}
.wd-orders-filter-pill.is-active {
	background: var(--wd-burgundy);
	border-color: var(--wd-burgundy);
	color: #fff !important;
}

.wd-order-row {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	overflow: hidden;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.wd-order-row:hover {
	border-color: var(--wd-burgundy-line);
	box-shadow: var(--wd-shadow);
}
.wd-orders .wd-order-row + .wd-order-row {
	margin-top: 12px;
}
.wd-order-row-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 20px;
	text-decoration: none !important;
	color: inherit !important;
}
.wd-order-row-main {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.wd-order-row-head {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}
.wd-order-row-head .wd-order-num {
	font-weight: 600;
	color: var(--wd-burgundy);
	font-size: 15px;
}
.wd-order-row-main .wd-order-items {
	font-size: 14px;
	color: var(--wd-ink);
	font-weight: 500;
}
.wd-order-meta {
	font-size: 13px;
	color: var(--wd-ink-soft);
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.wd-order-meta-sep { color: var(--wd-line-strong); }
.wd-order-row-side {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-shrink: 0;
}
.wd-order-row-side .wd-order-total {
	font-weight: 700;
	font-size: 17px;
	color: var(--wd-ink);
}
.wd-order-row-side .wd-order-arrow {
	color: var(--wd-burgundy);
	font-size: 18px;
	transition: transform 0.15s ease;
}
.wd-order-row:hover .wd-order-arrow { transform: translateX(2px); }

.wd-orders-pagination {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 14px 18px;
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
}
.wd-orders-pagination-btn {
	display: inline-flex;
	padding: 8px 16px;
	font-size: 13px;
	font-weight: 500;
	font-family: var(--wd-font);
	border-radius: 999px;
	border: 1px solid var(--wd-burgundy-line);
	color: var(--wd-burgundy) !important;
	background: var(--wd-burgundy-soft);
	text-decoration: none !important;
	line-height: 1;
	transition: all 0.15s ease;
}
.wd-orders-pagination-btn:hover {
	background: var(--wd-burgundy);
	color: #fff !important;
	border-color: var(--wd-burgundy);
}
.wd-orders-pagination-btn.is-disabled {
	opacity: 0.45;
	pointer-events: none;
	background: var(--wd-tan);
	color: var(--wd-ink-muted) !important;
	border-color: var(--wd-line);
}
.wd-orders-pagination-meta {
	font-size: 13px;
	color: var(--wd-ink-soft);
}


/* ---------------------------------------------------------------------
 * View Order — /my-account/view-order/{N}/ + order-received
 * --------------------------------------------------------------------- */

.wd-order-detail {
	font-family: var(--wd-font);
	color: var(--wd-ink);
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.wd-order-detail-hero {
	background: linear-gradient(135deg, var(--wd-ivory) 0%, var(--wd-tan) 100%);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-lg);
	padding: 28px 30px;
	box-shadow: var(--wd-shadow);
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 24px;
	flex-wrap: wrap;
}
.wd-order-detail-hero-main {
	flex: 1;
	min-width: 0;
}
.wd-order-detail-back {
	display: inline-block;
	margin-bottom: 14px;
	font-size: 13px;
	font-weight: 500;
	color: var(--wd-burgundy) !important;
	text-decoration: none !important;
}
.wd-order-detail-back:hover { text-decoration: underline !important; }
.wd-order-detail-eyebrow {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--wd-burgundy);
	margin-bottom: 6px;
}
.wd-order-detail-title {
	font-family: var(--wd-font);
	font-size: 32px;
	font-weight: 700;
	margin: 0 0 12px;
	color: var(--wd-ink);
	line-height: 1.1;
}
.wd-order-detail-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	font-size: 14px;
	color: var(--wd-ink-soft);
}
.wd-order-detail-meta-sep { color: var(--wd-line-strong); }
.wd-order-detail-hero-side {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 4px;
	padding: 14px 22px;
	border-radius: var(--wd-radius);
	background: rgba(255, 255, 255, 0.6);
	border: 1px solid var(--wd-burgundy-line);
	min-width: 180px;
}
.wd-order-detail-total-label {
	font-size: 12px;
	font-weight: 500;
	color: var(--wd-ink-soft);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}
.wd-order-detail-total {
	font-family: var(--wd-font);
	font-size: 26px;
	font-weight: 700;
	color: var(--wd-burgundy);
}
.wd-order-detail-total .woocommerce-Price-amount { color: var(--wd-burgundy); }

.wd-order-detail-notes {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-left: 4px solid var(--wd-burgundy);
	border-radius: var(--wd-radius);
	padding: 22px 26px;
}
.wd-order-notes { list-style: none; margin: 12px 0 0; padding: 0; }
.wd-order-note + .wd-order-note {
	margin-top: 12px;
	padding-top: 12px;
	border-top: 1px solid var(--wd-line);
}
.wd-order-note-meta {
	font-size: 12px;
	color: var(--wd-ink-muted);
	margin-bottom: 4px;
}
.wd-order-note-body { color: var(--wd-ink); font-size: 14px; line-height: 1.55; }
.wd-order-note-body p:last-child { margin-bottom: 0; }

.wd-order-detail-card {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	padding: 26px 28px;
	box-shadow: var(--wd-shadow);
}
.wd-order-detail-section-title {
	font-family: var(--wd-font);
	font-size: 16px;
	font-weight: 600;
	color: var(--wd-burgundy);
	margin: 0 0 14px;
	text-transform: none;
	letter-spacing: 0;
}
.wd-order-detail-card .wd-order-detail-section-title + .wd-order-detail-section-title { margin-top: 26px; }
.wd-order-detail-card .wd-order-summary,
.wd-order-detail-card .wd-order-items-list,
.wd-order-detail-card .wd-order-side-cards,
.wd-order-detail-card .wd-order-detail-actions { margin-bottom: 22px; }
.wd-order-detail-card > *:last-child { margin-bottom: 0; }

.wd-order-items-list {
	list-style: none;
	margin: 0;
	padding: 0;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	overflow: hidden;
}
.wd-order-item {
	display: flex;
	gap: 16px;
	padding: 16px 18px;
	align-items: center;
}
.wd-order-item + .wd-order-item { border-top: 1px solid var(--wd-line); }
.wd-order-item-thumb {
	width: 80px;
	height: 80px;
	flex-shrink: 0;
	border-radius: var(--wd-radius-sm);
	overflow: hidden;
	background: var(--wd-tan);
	display: flex;
	align-items: center;
	justify-content: center;
}
.wd-order-item-thumb img,
.wd-order-item-thumb-img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
	display: block;
}
.wd-order-item-main {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.wd-order-item-name {
	font-size: 15px;
	font-weight: 600;
	color: var(--wd-ink);
}
.wd-order-item-name a {
	color: var(--wd-ink) !important;
	text-decoration: none !important;
}
.wd-order-item-name a:hover { color: var(--wd-burgundy) !important; }
.wd-order-item-meta {
	font-size: 13px;
	color: var(--wd-ink-soft);
}
.wd-order-item-meta .wc-item-meta { list-style: none; margin: 0; padding: 0; }
.wd-order-item-meta .wc-item-meta li p { margin: 0; }
.wd-order-item-qty {
	font-size: 13px;
	color: var(--wd-ink-soft);
	font-weight: 500;
}
.wd-order-item-note {
	margin-top: 8px;
	padding: 10px 12px;
	background: var(--wd-burgundy-soft);
	border-radius: var(--wd-radius-sm);
	font-size: 13px;
	color: var(--wd-ink);
}
.wd-order-item-total {
	flex-shrink: 0;
	font-weight: 600;
	font-size: 15px;
	color: var(--wd-ink);
	text-align: right;
	min-width: 90px;
}

.wd-order-summary {
	margin: 0;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	overflow: hidden;
}
.wd-order-summary-row {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 12px 18px;
	font-size: 14px;
	color: var(--wd-ink);
}
.wd-order-summary-row + .wd-order-summary-row { border-top: 1px solid var(--wd-line); }
.wd-order-summary-row dt {
	margin: 0;
	color: var(--wd-ink-soft);
	font-weight: 500;
}
.wd-order-summary-row dd { margin: 0; font-weight: 500; }
.wd-order-summary-row.is-total {
	background: var(--wd-burgundy-soft);
	font-size: 16px;
}
.wd-order-summary-row.is-total dt,
.wd-order-summary-row.is-total dd {
	color: var(--wd-burgundy);
	font-weight: 700;
}
.wd-order-summary-row .woocommerce-Price-amount { font-weight: inherit; }

.wd-order-side-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 14px;
}
.wd-order-side-card {
	background: var(--wd-ivory);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	padding: 16px 18px;
}
.wd-order-side-card .wd-order-detail-section-title { margin-bottom: 6px; }
.wd-order-side-card-body {
	margin: 0;
	font-size: 14px;
	color: var(--wd-ink);
	line-height: 1.5;
}

.wd-order-detail-actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	padding-top: 4px;
}

/* Order-again / cancel / pay buttons rendered inside this row.
   The default .wd-btn-primary / .wd-btn-secondary styling exists,
   but Divi's .button and other theme button rules can leak in via
   the woocommerce CSS bundle and override colour / font / radius.
   Lock our look down here so the action row reads as brand-aligned
   regardless of upstream CSS. */
.wd-order-detail-actions .wd-btn-primary,
.wd-order-detail-actions .wd-btn-secondary,
.wd-order-again-row .wd-btn-primary {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 6px !important;
	padding: 10px 18px !important;
	border-radius: var(--wd-radius-sm) !important;
	font-family: var(--wd-font) !important;
	font-size: 13.5px !important;
	font-weight: 600 !important;
	line-height: 1.3 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
	text-decoration: none !important;
	text-shadow: none !important;
	box-shadow: none !important;
	border: 1px solid transparent !important;
	cursor: pointer;
	min-height: 0 !important;
	min-width: 0 !important;
	width: auto !important;
	height: auto !important;
	transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}
.wd-order-detail-actions .wd-btn-primary,
.wd-order-again-row .wd-btn-primary {
	background: var(--wd-burgundy) !important;
	color: #fff !important;
	border-color: var(--wd-burgundy) !important;
}
.wd-order-detail-actions .wd-btn-primary:hover,
.wd-order-detail-actions .wd-btn-primary:focus,
.wd-order-again-row .wd-btn-primary:hover,
.wd-order-again-row .wd-btn-primary:focus {
	background: var(--wd-burgundy-dark) !important;
	border-color: var(--wd-burgundy-dark) !important;
	color: #fff !important;
}
.wd-order-detail-actions .wd-btn-secondary {
	background: #fff !important;
	color: var(--wd-burgundy) !important;
	border-color: var(--wd-burgundy-line) !important;
}
.wd-order-detail-actions .wd-btn-secondary:hover,
.wd-order-detail-actions .wd-btn-secondary:focus {
	background: var(--wd-burgundy-soft) !important;
	border-color: var(--wd-burgundy) !important;
	color: var(--wd-burgundy-dark) !important;
}

/* Order Again row — sits below the actions row on view-order. Right-
   aligned on desktop so the primary call-to-action lives at the edge
   of the card; centered on mobile so it stays thumb-reachable. */
.wd-order-again-row {
	display: flex;
	justify-content: flex-end;
	margin: 16px 0 8px;
}
@media (max-width: 600px) {
	.wd-order-again-row {
		justify-content: center;
	}
}

.wd-order-detail-addresses { padding: 0; overflow: hidden; }
.wd-order-address-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}
.wd-order-address-grid.is-single { grid-template-columns: 1fr; }
.wd-order-address {
	padding: 24px 28px;
}
.wd-order-address + .wd-order-address {
	border-left: 1px solid var(--wd-line);
}
.wd-order-address address {
	font-style: normal;
	color: var(--wd-ink);
	font-size: 14px;
	line-height: 1.6;
	margin: 0;
}
.wd-order-address-line {
	margin: 6px 0 0;
	color: var(--wd-ink-soft);
	font-size: 13px;
}


/* ---------------------------------------------------------------------
 * Addresses — /my-account/edit-address/
 * --------------------------------------------------------------------- */

.wd-addr-page {
	font-family: var(--wd-font);
	color: var(--wd-ink);
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.wd-addr-hero {
	background: linear-gradient(135deg, var(--wd-ivory) 0%, var(--wd-tan) 100%);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-lg);
	padding: 26px 30px;
	box-shadow: var(--wd-shadow);
}
.wd-addr-eyebrow {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--wd-burgundy);
	margin-bottom: 6px;
}
.wd-addr-title {
	font-family: var(--wd-font);
	font-size: 30px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--wd-ink);
	line-height: 1.1;
}
.wd-addr-sub {
	margin: 0;
	color: var(--wd-ink-soft);
	font-size: 14px;
	max-width: 60ch;
}

.wd-addr-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}
.wd-addr-grid.is-single { grid-template-columns: 1fr; }

.wd-addr-card {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	padding: 24px 26px;
	display: flex;
	flex-direction: column;
	gap: 18px;
	box-shadow: var(--wd-shadow);
	transition: border-color 0.15s ease;
}
.wd-addr-card:hover { border-color: var(--wd-burgundy-line); }
.wd-addr-card.is-empty {
	background: linear-gradient(135deg, var(--wd-ivory) 0%, var(--wd-tan) 100%);
	border-style: dashed;
}

.wd-addr-card-head {
	display: flex;
	align-items: center;
	gap: 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--wd-line);
}
.wd-addr-card-icon {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--wd-burgundy-soft);
	color: var(--wd-burgundy);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.wd-addr-card-head-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
.wd-addr-card-eyebrow {
	font-size: 11px;
	font-weight: 600;
	color: var(--wd-ink-muted);
	text-transform: uppercase;
	letter-spacing: 0.12em;
}
.wd-addr-card-title {
	font-family: var(--wd-font);
	font-size: 17px;
	font-weight: 600;
	margin: 0;
	color: var(--wd-ink);
	letter-spacing: 0;
	text-transform: none;
	border: 0 !important;
	padding: 0 !important;
}

.wd-addr-card-body {
	flex: 1;
	min-height: 80px;
}
.wd-addr-card-body address {
	font-style: normal;
	font-size: 14px;
	line-height: 1.65;
	color: var(--wd-ink);
	margin: 0;
}
.wd-addr-card-empty {
	margin: 0;
	font-size: 14px;
	color: var(--wd-ink-soft);
	line-height: 1.5;
}

.wd-addr-card-foot {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}
.wd-addr-card-foot .wd-btn-primary {
	width: 100%;
	text-align: center;
	justify-content: center;
}


/* ---------------------------------------------------------------------
 * Edit address form — /my-account/edit-address/billing/ + /shipping/
 * --------------------------------------------------------------------- */

.wd-addr-edit {
	font-family: var(--wd-font);
	color: var(--wd-ink);
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.wd-addr-edit-hero {
	background: linear-gradient(135deg, var(--wd-ivory) 0%, var(--wd-tan) 100%);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-lg);
	padding: 26px 30px;
	box-shadow: var(--wd-shadow);
}
.wd-addr-edit-back {
	display: inline-block;
	margin-bottom: 14px;
	font-size: 13px;
	font-weight: 500;
	color: var(--wd-burgundy) !important;
	text-decoration: none !important;
}
.wd-addr-edit-back:hover { text-decoration: underline !important; }
.wd-addr-edit-eyebrow {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--wd-burgundy);
	margin-bottom: 6px;
}
.wd-addr-edit-title {
	font-family: var(--wd-font);
	font-size: 30px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--wd-ink);
	line-height: 1.1;
}
.wd-addr-edit-sub {
	margin: 0;
	font-size: 14px;
	color: var(--wd-ink-soft);
}

.wd-addr-edit-card {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	padding: 28px 30px;
	box-shadow: var(--wd-shadow);
}

/* Form rows inside the edit card — bring WC form-row markup into the
   same design system as the rest of the brand UI. */
.wd-addr-edit-form .woocommerce-address-fields__field-wrapper {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px 18px;
}
.wd-addr-edit-form .form-row {
	margin: 0 !important;
	padding: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 6px;
}
.wd-addr-edit-form .form-row.form-row-wide,
.wd-addr-edit-form .form-row.notes,
.wd-addr-edit-form .form-row.was-hidden-field {
	grid-column: 1 / -1;
}
.wd-addr-edit-form .was-hidden-field { display: none !important; }
.wd-addr-edit-form .form-row label {
	font-size: 13px;
	font-weight: 500;
	color: var(--wd-ink-soft);
	margin: 0 !important;
	line-height: 1.3;
}
.wd-addr-edit-form .form-row label .required {
	color: var(--wd-burgundy);
	text-decoration: none;
	font-weight: 700;
	margin-left: 2px;
}
.wd-addr-edit-form .form-row label .optional {
	color: var(--wd-ink-muted);
	font-weight: 400;
}
.wd-addr-edit-form .form-row input[type="text"],
.wd-addr-edit-form .form-row input[type="tel"],
.wd-addr-edit-form .form-row input[type="email"],
.wd-addr-edit-form .form-row input[type="password"],
.wd-addr-edit-form .form-row input[type="number"],
.wd-addr-edit-form .form-row select,
.wd-addr-edit-form .form-row textarea {
	width: 100% !important;
	padding: 11px 14px !important;
	font-family: var(--wd-font) !important;
	font-size: 14px !important;
	color: var(--wd-ink) !important;
	background: #fff !important;
	border: 1px solid var(--wd-line-strong) !important;
	border-radius: var(--wd-radius-sm) !important;
	height: auto !important;
	min-height: 44px;
	box-shadow: none !important;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.wd-addr-edit-form .form-row input:focus,
.wd-addr-edit-form .form-row select:focus,
.wd-addr-edit-form .form-row textarea:focus {
	border-color: var(--wd-burgundy) !important;
	outline: 0 !important;
	box-shadow: 0 0 0 3px rgba(133, 22, 37, 0.12) !important;
}
.wd-addr-edit-form .form-row.woocommerce-invalid input,
.wd-addr-edit-form .form-row.woocommerce-invalid select {
	border-color: #c0392b !important;
}
.wd-addr-edit-form .form-row.woocommerce-validated input,
.wd-addr-edit-form .form-row.woocommerce-validated select {
	border-color: var(--wd-line-strong) !important;
}

/* Select2 — WC enhances the country / state dropdowns with Select2.
   Re-skin its chrome inside our form wrapper so it doesn't read as
   a foreign widget against the rest of the brand inputs. */
.wd-addr-edit-form .select2-container--default .select2-selection--single {
	height: auto !important;
	min-height: 44px;
	padding: 7px 12px !important;
	border: 1px solid var(--wd-line-strong) !important;
	border-radius: var(--wd-radius-sm) !important;
	background: #fff !important;
	box-shadow: none !important;
}
.wd-addr-edit-form .select2-container--default .select2-selection--single .select2-selection__rendered {
	padding: 0 !important;
	font-family: var(--wd-font) !important;
	font-size: 14px !important;
	color: var(--wd-ink) !important;
	line-height: 28px !important;
}
.wd-addr-edit-form .select2-container--default .select2-selection--single .select2-selection__arrow {
	height: 44px !important;
	right: 8px !important;
}
.wd-addr-edit-form .select2-container--default.select2-container--focus .select2-selection--single,
.wd-addr-edit-form .select2-container--default.select2-container--open .select2-selection--single {
	border-color: var(--wd-burgundy) !important;
	box-shadow: 0 0 0 3px rgba(133, 22, 37, 0.12) !important;
}

/* Live character counter under the 50-char-capped address fields.
   Mirrors the cartflow checkout counter (wlcf-char-counter) so the
   affordance feels consistent across surfaces. */
.wd-addr-edit-form .wd-char-counter {
	display: block;
	text-align: right;
	margin-top: 4px;
	font-size: 12px;
	font-weight: 500;
	color: var(--wd-ink-muted);
	transition: color 0.15s ease;
}
.wd-addr-edit-form .wd-char-counter.is-hidden { display: none; }
.wd-addr-edit-form .wd-char-counter.is-near-limit { color: #b56304; }
.wd-addr-edit-form .wd-char-counter.is-at-limit {
	color: #b71c1c;
	font-weight: 600;
}
.wd-addr-edit-form .wd-char-counter-hint {
	display: block;
	margin-top: 4px;
	font-size: 12px;
	color: #b71c1c;
	font-style: normal;
	line-height: 1.4;
}

.wd-addr-edit-actions {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
	margin-top: 24px;
	padding-top: 22px;
	border-top: 1px solid var(--wd-line);
	flex-wrap: wrap;
}
.wd-addr-edit-actions .wd-btn-primary,
.wd-addr-edit-actions .wd-btn-secondary {
	min-width: 140px;
	justify-content: center;
	text-align: center;
}


/* ---------------------------------------------------------------------
 * Account details — /my-account/edit-account/
 * --------------------------------------------------------------------- */

.wd-acct-form {
	font-family: var(--wd-font);
	color: var(--wd-ink);
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.wd-acct-hero {
	background: linear-gradient(135deg, var(--wd-ivory) 0%, var(--wd-tan) 100%);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-lg);
	padding: 26px 30px;
	box-shadow: var(--wd-shadow);
}
.wd-acct-eyebrow {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--wd-burgundy);
	margin-bottom: 6px;
}
.wd-acct-title {
	font-family: var(--wd-font);
	font-size: 30px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--wd-ink);
	line-height: 1.1;
}
.wd-acct-sub {
	margin: 0;
	font-size: 14px;
	color: var(--wd-ink-soft);
}

.wd-acct-card {
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	padding: 24px 28px;
	box-shadow: var(--wd-shadow);
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.wd-acct-card-head {
	display: flex;
	align-items: center;
	gap: 14px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--wd-line);
}
.wd-acct-card-icon {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--wd-burgundy-soft);
	color: var(--wd-burgundy);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.wd-acct-card-head-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
.wd-acct-card-eyebrow {
	font-size: 11px;
	font-weight: 600;
	color: var(--wd-ink-muted);
	text-transform: uppercase;
	letter-spacing: 0.12em;
}
.wd-acct-card-title {
	font-family: var(--wd-font);
	font-size: 17px;
	font-weight: 600;
	margin: 0;
	color: var(--wd-ink);
	letter-spacing: 0;
	text-transform: none;
}
.wd-acct-card-body { display: flex; flex-direction: column; gap: 16px; }
.wd-acct-help {
	margin: 0;
	font-size: 13px;
	color: var(--wd-ink-soft);
}

/* Two-column grid for the personal-info card — Name + Phone span
   both columns; Gender + DOB pair in a single row. */
.wd-acct-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px 18px;
}
.wd-acct-grid .wd-col-wide { grid-column: 1 / -1; }

/* Form-row internals — shared with the edit-address page styling so
   labels + inputs match across the entire suite. */
.wd-acct-form .form-row {
	margin: 0 !important;
	padding: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 6px;
}
.wd-acct-form .form-row label {
	font-size: 13px;
	font-weight: 500;
	color: var(--wd-ink-soft);
	margin: 0 !important;
	line-height: 1.3;
}
.wd-acct-form .form-row label .required {
	color: var(--wd-burgundy);
	text-decoration: none;
	font-weight: 700;
	margin-left: 2px;
}
.wd-acct-form .form-row input[type="text"],
.wd-acct-form .form-row input[type="tel"],
.wd-acct-form .form-row input[type="email"],
.wd-acct-form .form-row input[type="password"],
.wd-acct-form .form-row select {
	width: 100% !important;
	padding: 11px 14px !important;
	font-family: var(--wd-font) !important;
	font-size: 14px !important;
	color: var(--wd-ink) !important;
	background: #fff !important;
	border: 1px solid var(--wd-line-strong) !important;
	border-radius: var(--wd-radius-sm) !important;
	height: auto !important;
	min-height: 44px;
	box-shadow: none !important;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.wd-acct-form .form-row input:focus,
.wd-acct-form .form-row select:focus {
	border-color: var(--wd-burgundy) !important;
	outline: 0 !important;
	box-shadow: 0 0 0 3px rgba(133, 22, 37, 0.12) !important;
}
.wd-acct-form .form-row.has-error input,
.wd-acct-form .form-row.has-error select {
	border-color: #c0392b !important;
}
.wd-acct-form .form-row.has-error .was-error-msg {
	display: block;
	margin-top: 4px;
	font-size: 12px;
	color: #b71c1c;
}

/* Custom-styled marketing opt-in checkbox. */
.wd-acct-checkbox {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 12px 14px;
	background: var(--wd-burgundy-soft);
	border: 1px solid var(--wd-burgundy-line);
	border-radius: var(--wd-radius-sm);
	cursor: pointer;
	line-height: 1.45;
}
.wd-acct-checkbox input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	pointer-events: none;
}
.wd-acct-checkbox-box {
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	border-radius: 4px;
	border: 1.5px solid var(--wd-burgundy);
	background: #fff;
	margin-top: 2px;
	display: inline-block;
	position: relative;
	transition: background 0.12s ease;
}
.wd-acct-checkbox input[type="checkbox"]:checked + .wd-acct-checkbox-box {
	background: var(--wd-burgundy);
}
.wd-acct-checkbox input[type="checkbox"]:checked + .wd-acct-checkbox-box::after {
	content: '';
	position: absolute;
	left: 5px;
	top: 1px;
	width: 5px;
	height: 10px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}
.wd-acct-checkbox input[type="checkbox"]:focus-visible + .wd-acct-checkbox-box {
	box-shadow: 0 0 0 3px rgba(133, 22, 37, 0.18);
}
.wd-acct-checkbox-label {
	font-size: 13px;
	color: var(--wd-ink);
	flex: 1;
}

/* Password strength meter — ported from account-forms.css so the
   register / lost-password / edit-account meters share one design. */
.wd-acct-form .was-pw-meter {
	margin-top: 4px;
	display: flex;
	align-items: center;
	gap: 10px;
}
.wd-acct-form .was-pw-bar {
	flex: 1 1 auto;
	height: 3px;
	border-radius: 2px;
	background: #efe6e8;
	overflow: hidden;
}
.wd-acct-form .was-pw-bar span {
	display: block;
	height: 100%;
	width: 0;
	background: #b71c1c;
	transition: width 0.18s ease, background 0.18s ease;
}
.wd-acct-form .was-pw-label {
	flex: 0 0 auto;
	font-size: 12px;
	color: var(--wd-ink-soft);
	line-height: 1.4;
	font-weight: 500;
}
.wd-acct-form .form-row.is-pw-weak   .was-pw-bar span { background: #b71c1c; }
.wd-acct-form .form-row.is-pw-ok     .was-pw-bar span { background: #b56304; }
.wd-acct-form .form-row.is-pw-strong .was-pw-bar span { background: #1b7e3c; }
.wd-acct-form .form-row.is-pw-weak   .was-pw-label    { color: #b71c1c; }
.wd-acct-form .form-row.is-pw-ok     .was-pw-label    { color: #b56304; }
.wd-acct-form .form-row.is-pw-strong .was-pw-label    { color: #1b7e3c; font-weight: 600; }

/* intl-tel-input — the picker uses `separateDialCode: true`, so the
   country flag + dial-code button sits inside the input on the left.
   Give the actual <input> enough left-padding to clear that prefix;
   without this the customer's text starts behind the dial-code chip.
   Mirrors the pattern from account-forms.css (.wl-acc-card .iti …)
   so the register, edit-account, and edit-address fields look identical.

   v1.16.5: extended to .wd-addr-edit-form. v1.16.4 added the data-was-phone
   attribute on the address form's billing_phone / shipping_phone inputs;
   without these CSS rules the iti wrapper collapsed to its intrinsic width
   and the country chip overlapped the input text. */
.wd-acct-form .iti,
.wd-addr-edit-form .iti {
	display: block;
	width: 100%;
}
.wd-acct-form .iti input.iti__tel-input,
.wd-addr-edit-form .iti input.iti__tel-input {
	width: 100% !important;
	height: 44px !important;
	min-height: 44px !important;
	padding-left: 92px !important;
	padding-right: 14px !important;
	border: 1px solid var(--wd-line-strong) !important;
	border-radius: var(--wd-radius-sm) !important;
}
.wd-acct-form .iti input.iti__tel-input:focus,
.wd-addr-edit-form .iti input.iti__tel-input:focus {
	border-color: var(--wd-burgundy) !important;
	box-shadow: 0 0 0 3px rgba(133, 22, 37, 0.12) !important;
}
.wd-acct-form .iti__selected-country,
.wd-addr-edit-form .iti__selected-country { height: 44px !important; }
.wd-acct-form .iti__dropdown-content,
.wd-addr-edit-form .iti__dropdown-content {
	border-radius: var(--wd-radius-sm) !important;
	border: 1px solid var(--wd-line-strong) !important;
	box-shadow: 0 8px 24px -8px rgba(94, 15, 26, 0.20) !important;
	overflow: hidden;
	font-family: var(--wd-font);
}
.wd-acct-form .iti__search-input,
.wd-addr-edit-form .iti__search-input {
	height: 40px !important;
	padding: 0 12px !important;
	font-size: 14px !important;
	border-bottom: 1px solid var(--wd-line) !important;
}
.wd-acct-form .iti__country.iti__highlight,
.wd-acct-form .iti__country:hover,
.wd-addr-edit-form .iti__country.iti__highlight,
.wd-addr-edit-form .iti__country:hover {
	background-color: var(--wd-burgundy-soft) !important;
}
.wd-acct-form .iti__country-list,
.wd-addr-edit-form .iti__country-list { font-family: var(--wd-font); }


/* Inline validator error (e.g. "The two passwords do not match.") —
   matches the cartflow checkout + register form patterns. */
.wd-acct-form .was-field-error {
	margin: 4px 0 0 !important;
	padding: 0 !important;
	color: #b71c1c !important;
	font-size: 12px !important;
	font-weight: 500 !important;
	line-height: 1.4 !important;
	background: transparent !important;
	border: none !important;
	display: block;
}
.wd-acct-form .form-row.was-has-error input,
.wd-acct-form .form-row.was-has-error select,
.wd-acct-form .was-has-error input,
.wd-acct-form .was-has-error select {
	border-color: #b71c1c !important;
	box-shadow: 0 0 0 3px rgba(183, 28, 28, 0.10) !important;
}

.wd-acct-actions {
	display: flex;
	justify-content: flex-end;
	gap: 10px;
	margin: 0;
	padding-top: 4px;
	flex-wrap: wrap;
}
.wd-acct-actions .wd-btn-primary {
	min-width: 160px;
	justify-content: center;
	text-align: center;
}

/* WC's hidden first / last name + display-name rows that themes /
   plugins may still inject via the form_start hook. The new template
   doesn't ship them, but defensively suppress anything that slips in. */
.wd-acct-form #account_first_name_field,
.wd-acct-form #account_last_name_field,
.wd-acct-form #account_display_name_field {
	display: none !important;
}


/* ---------------------------------------------------------------------
 * My Coupons — /my-account/my-coupons/
 *
 * Ticket-style cards mirroring the cart marketplace's voucher list.
 * Two halves divided by a "perforated" border — left side is the
 * discount description, right side is the code + copy button. Hover
 * lifts the card with a subtle ring.
 * --------------------------------------------------------------------- */

.wd-coupons-page {
	font-family: var(--wd-font);
	color: var(--wd-ink);
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.wd-coupons-hero {
	background: linear-gradient(135deg, var(--wd-ivory) 0%, var(--wd-tan) 100%);
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius-lg);
	padding: 26px 30px;
	box-shadow: var(--wd-shadow);
}
.wd-coupons-eyebrow {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--wd-burgundy);
	margin-bottom: 6px;
}
.wd-coupons-title {
	font-family: var(--wd-font);
	font-size: 30px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--wd-ink);
	line-height: 1.1;
}
.wd-coupons-sub {
	margin: 0;
	font-size: 14px;
	color: var(--wd-ink-soft);
}

.wd-coupons-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 16px;
}

.wd-coupon {
	display: flex;
	align-items: stretch;
	background: #fff;
	border: 1px solid var(--wd-line);
	border-radius: var(--wd-radius);
	overflow: hidden;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
	box-shadow: var(--wd-shadow);
	position: relative;
}
.wd-coupon:hover {
	border-color: var(--wd-burgundy-line);
	transform: translateY(-1px);
}

.wd-coupon-body {
	flex: 1;
	padding: 20px 22px;
	display: flex;
	flex-direction: column;
	gap: 6px;
	min-width: 0;
}
.wd-coupon-expiry {
	display: inline-flex;
	align-self: flex-start;
	padding: 3px 10px;
	border-radius: 999px;
	background: var(--wd-burgundy-soft);
	color: var(--wd-burgundy);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.04em;
	margin-bottom: 4px;
}
.wd-coupon-discount {
	margin: 0;
	font-family: var(--wd-font);
	font-size: 18px;
	font-weight: 700;
	color: var(--wd-burgundy);
	line-height: 1.2;
	text-transform: none;
	letter-spacing: 0;
}
.wd-coupon-summary {
	margin: 0;
	font-size: 13px;
	color: var(--wd-ink-soft);
	line-height: 1.5;
}

.wd-coupon-perf {
	flex: 0 0 1px;
	background: var(--wd-line);
	position: relative;
}
.wd-coupon-perf::before,
.wd-coupon-perf::after {
	content: '';
	position: absolute;
	left: 50%;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--wd-tan);
	transform: translateX(-50%);
	border: 1px solid var(--wd-line);
}
.wd-coupon-perf::before { top: -7px; }
.wd-coupon-perf::after  { bottom: -7px; }

.wd-coupon-side {
	flex: 0 0 160px;
	background: var(--wd-ivory);
	padding: 20px 18px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 6px;
}
.wd-coupon-code-label {
	font-size: 11px;
	font-weight: 500;
	color: var(--wd-ink-muted);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}
.wd-coupon-code {
	font-family: 'Menlo', 'Geologica', monospace;
	font-size: 16px;
	font-weight: 700;
	color: var(--wd-ink);
	letter-spacing: 0.04em;
	text-align: center;
	word-break: break-all;
	max-width: 100%;
}
.wd-coupon-copy {
	margin-top: 6px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 7px 14px;
	border-radius: 999px;
	background: var(--wd-burgundy);
	color: #fff !important;
	border: 1px solid var(--wd-burgundy);
	font-family: var(--wd-font);
	font-size: 12px;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.15s ease, border-color 0.15s ease;
	line-height: 1;
}
.wd-coupon-copy:hover {
	background: var(--wd-burgundy-dark);
	border-color: var(--wd-burgundy-dark);
}
.wd-coupon-copy.is-copied {
	background: #1b7e3c;
	border-color: #1b7e3c;
}

/* Stackable / Single-use flag — exactly one renders per card.
   `--lock` is burgundy (can't combine with other coupons), `--stack`
   is green (combinable with other coupons). Hover or focus reveals
   the explanatory tooltip. */
.wd-coupon-flag {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	margin-top: 6px;
	padding: 4px 9px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.02em;
	border-radius: 999px;
	position: relative;
	cursor: help;
	align-self: flex-start;
	max-width: 100%;
}
.wd-coupon-flag--lock {
	background: rgba(133, 22, 37, 0.07);
	color: var(--wd-burgundy);
}
.wd-coupon-flag--stack {
	background: rgba(27, 126, 60, 0.10);
	color: #1b7e3c;
}

/* Min-spend chip — appears below the description when set. */
.wd-coupon-min {
	display: inline-flex;
	align-self: flex-start;
	padding: 3px 9px;
	margin-top: 4px;
	background: var(--wd-tan);
	color: var(--wd-ink-soft);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.02em;
	border-radius: 999px;
	border: 1px solid var(--wd-line);
}
.wd-coupon-flag-icon { flex-shrink: 0; }
.wd-coupon-tooltip {
	position: absolute;
	left: 0;
	bottom: calc(100% + 6px);
	min-width: 220px;
	max-width: 280px;
	padding: 8px 10px;
	background: var(--wd-ink);
	color: #fff;
	font-size: 11.5px;
	font-weight: 500;
	line-height: 1.45;
	border-radius: 6px;
	box-shadow: 0 8px 24px -8px rgba(0, 0, 0, 0.3);
	opacity: 0;
	transform: translateY(4px);
	pointer-events: none;
	transition: opacity 0.15s ease, transform 0.15s ease;
	z-index: 5;
	text-transform: none;
	letter-spacing: 0;
}
.wd-coupon-tooltip::after {
	content: '';
	position: absolute;
	left: 14px;
	top: 100%;
	border: 5px solid transparent;
	border-top-color: var(--wd-ink);
}
.wd-coupon-flag:hover .wd-coupon-tooltip,
.wd-coupon-flag:focus .wd-coupon-tooltip,
.wd-coupon-flag:focus-within .wd-coupon-tooltip {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

/* Belt-and-braces: hide any leftover ACFW "uses remaining" marker that
   sneaks into another surface (the cart marketplace doesn't render it,
   but the ACFW shortcode + block could). Our my-coupons render
   doesn't output this class at all. */
.acfw-coupon-usage-limit {
	display: none !important;
}


/* ---------------------------------------------------------------------
 * Mobile
 * --------------------------------------------------------------------- */

@media (max-width: 768px) {
	.wd-dashboard { gap: 16px; }
	.wd-hero { padding: 24px 22px; }
	.wd-hero-title { font-size: 26px; }
	.wd-stats { grid-template-columns: repeat(2, 1fr); }
	.wd-stat-val { font-size: 24px; }
	.wd-profile-card { flex-wrap: wrap; }
	.wd-profile-card-cta { width: 100%; }
	.wd-profile-card-cta .wd-btn-primary { width: 100%; text-align: center; }
	.wd-section { padding: 18px 18px; }
	.wd-order { flex-wrap: wrap; }
	.wd-order-side { width: 100%; justify-content: space-between; }

	.wd-order-row-link { flex-wrap: wrap; padding: 16px; }
	.wd-order-row-side { width: 100%; justify-content: space-between; }
	.wd-orders-hero { padding: 22px 22px; }
	.wd-orders-title { font-size: 24px; }
	.wd-order-detail-hero { padding: 22px 22px; }
	.wd-order-detail-hero-side {
		align-items: flex-start;
		width: 100%;
		min-width: 0;
	}
	.wd-order-detail-title { font-size: 26px; }
	.wd-order-detail-card { padding: 22px 20px; }
	.wd-order-address-grid { grid-template-columns: 1fr; }
	.wd-order-address + .wd-order-address {
		border-left: 0;
		border-top: 1px solid var(--wd-line);
	}

	.wd-addr-hero { padding: 22px 22px; }
	.wd-addr-title { font-size: 24px; }
	.wd-addr-grid { grid-template-columns: 1fr; }
	.wd-addr-card { padding: 22px 20px; }
	.wd-addr-edit-hero { padding: 22px 22px; }
	.wd-addr-edit-title { font-size: 24px; }
	.wd-addr-edit-card { padding: 22px 20px; }
	.wd-addr-edit-form .woocommerce-address-fields__field-wrapper {
		grid-template-columns: 1fr;
	}
	.wd-addr-edit-actions { justify-content: stretch; }
	.wd-addr-edit-actions .wd-btn-primary,
	.wd-addr-edit-actions .wd-btn-secondary { flex: 1; }

	.wd-acct-hero { padding: 22px 22px; }
	.wd-acct-title { font-size: 24px; }
	.wd-acct-card { padding: 22px 20px; }
	.wd-acct-grid { grid-template-columns: 1fr; }
	.wd-acct-actions { justify-content: stretch; }
	.wd-acct-actions .wd-btn-primary { flex: 1; min-width: 0; }

	.wd-coupons-hero { padding: 22px 22px; }
	.wd-coupons-title { font-size: 24px; }
	.wd-coupons-grid { grid-template-columns: 1fr; }
	.wd-coupon { flex-direction: column; }
	.wd-coupon-perf { flex: 0 0 1px; height: 1px; width: 100%; background: var(--wd-line); }
	.wd-coupon-perf::before { top: 50%; left: -7px; transform: translateY(-50%); }
	.wd-coupon-perf::after  { top: 50%; left: auto; right: -7px; transform: translateY(-50%); }
	.wd-coupon-side {
		flex: none;
		flex-direction: row;
		justify-content: space-between;
		padding: 14px 18px;
	}
	.wd-coupon-code { flex: 1; text-align: left; }
	.wd-coupon-code-label { display: none; }
}

@media (max-width: 480px) {
	.wd-stats { grid-template-columns: 1fr; }
	.wd-actions { grid-template-columns: 1fr; }
	.wd-order-item { flex-wrap: wrap; }
	.wd-order-item-total {
		width: 100%;
		text-align: left;
		padding-left: 96px;
	}
	.wd-orders-filter { padding: 10px; }
	.wd-orders-filter-pill { padding: 6px 12px; font-size: 12px; }
	.wd-orders-pagination { flex-wrap: wrap; justify-content: center; }
}
