/* =============================================================================
   Pro Conferences – My Account styles
   ============================================================================= */

/* ── Design tokens ────────────────────────────────────────────────────────── */

:root {
	--ma-accent:        #1d6fa4;
	--ma-accent-light:  #e8f3fb;
	--ma-accent-mid:    #b8d8ef;
	--ma-text:          #0f172a;
	--ma-muted:         #64748b;
	--ma-border:        #e2e8f0;
	--ma-surface:       #ffffff;
	--ma-surface-2:     #f7f9fc;
	--ma-radius:        14px;
	--ma-radius-sm:     8px;
	--ma-shadow-sm:     0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
	--ma-shadow:        0 4px 16px rgba(0,0,0,.08);
	--ma-shadow-hover:  0 8px 28px rgba(0,0,0,.12);
	--ma-ease:          cubic-bezier(.4,0,.2,1);
	--ma-duration:      200ms;
}

/* ── Full-width dashboard layout ──────────────────────────────────────────── */
/* Hide the default sidebar nav on the main dashboard — the card grid IS the nav */

.prc-account-home .woocommerce-MyAccount-navigation {
	display: none !important;
}

.prc-account-home .woocommerce-MyAccount-content {
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* ── Dashboard hero ───────────────────────────────────────────────────────── */

.prc-dashboard {
	max-width: 900px;
	margin: 0 auto;
	padding: 0 0 3em;
}

.prc-dashboard__hero {
	display: flex;
	align-items: center;
	gap: 1.1em;
	padding: 2em 0 2em;
	border-bottom: 1px solid var(--ma-border);
	margin-bottom: 2em;
}

.prc-dashboard__avatar-img {
	width: 72px !important;
	height: 72px !important;
	border-radius: 50% !important;
	border: 3px solid var(--ma-accent-mid);
	display: block;
}

.prc-dashboard__time {
	font-size: .8em;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .07em;
	color: var(--ma-muted);
	margin: 0 0 .15em;
}

.prc-dashboard__name {
	font-size: 1.7em;
	font-weight: 700;
	color: var(--ma-text);
	margin: 0;
	line-height: 1.1;
}

/* ── App home card grid ───────────────────────────────────────────────────── */

.prc-dashboard__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1em;
}

.prc-dashboard__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: .6em;
	padding: 1.75em 1em 1.5em;
	background: var(--ma-surface);
	border: 1px solid var(--ma-border);
	border-radius: var(--ma-radius);
	box-shadow: var(--ma-shadow-sm);
	text-decoration: none !important;
	color: var(--ma-text) !important;
	transition:
		transform      var(--ma-duration) var(--ma-ease),
		box-shadow     var(--ma-duration) var(--ma-ease),
		border-color   var(--ma-duration) var(--ma-ease),
		background     var(--ma-duration) var(--ma-ease);
	position: relative;
	overflow: hidden;
}

.prc-dashboard__card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--ma-accent-light) 0%, transparent 60%);
	opacity: 0;
	transition: opacity var(--ma-duration) var(--ma-ease);
	border-radius: var(--ma-radius);
}

.prc-dashboard__card:hover {
	transform: translateY(-4px);
	box-shadow: var(--ma-shadow-hover);
	border-color: var(--ma-accent-mid);
	text-decoration: none !important;
}

.prc-dashboard__card:hover::before {
	opacity: 1;
}

.prc-dashboard__card:active {
	transform: translateY(-1px);
	box-shadow: var(--ma-shadow-sm);
}

/* Icon circle */
.prc-dashboard__card-icon {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: var(--ma-accent-light);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: background var(--ma-duration) var(--ma-ease),
	            transform  var(--ma-duration) var(--ma-ease);
	position: relative;
	z-index: 1;
}

.prc-dashboard__card-icon svg {
	width: 26px;
	height: 26px;
	color: var(--ma-accent);
	transition: color var(--ma-duration) var(--ma-ease);
}

.prc-dashboard__card:hover .prc-dashboard__card-icon {
	background: var(--ma-accent);
	transform: scale(1.08);
}

.prc-dashboard__card:hover .prc-dashboard__card-icon svg {
	color: #fff;
}

.prc-dashboard__card-title {
	font-size: .9em;
	font-weight: 700;
	color: var(--ma-text);
	line-height: 1.2;
	position: relative;
	z-index: 1;
}

.prc-dashboard__card-desc {
	font-size: .75em;
	color: var(--ma-muted);
	line-height: 1.4;
	position: relative;
	z-index: 1;
}

/* Individual card accent colours */
.prc-dashboard__card--my-courses      { --card-accent: #1d6fa4; }
.prc-dashboard__card--certificates    { --card-accent: #b45309; }
.prc-dashboard__card--orders          { --card-accent: #16a34a; }
.prc-dashboard__card--delegates       { --card-accent: #7c3aed; }
.prc-dashboard__card--teams           { --card-accent: #db2777; }
.prc-dashboard__card--my-details      { --card-accent: #4f46e5; }
.prc-dashboard__card--payment-methods { --card-accent: #059669; }

.prc-dashboard__card-icon {
	background: color-mix(in srgb, var(--card-accent, var(--ma-accent)) 12%, white);
}

.prc-dashboard__card-icon svg {
	color: var(--card-accent, var(--ma-accent));
}

.prc-dashboard__card:hover .prc-dashboard__card-icon {
	background: var(--card-accent, var(--ma-accent));
}

.prc-dashboard__card::before {
	background: linear-gradient(
		135deg,
		color-mix(in srgb, var(--card-accent, var(--ma-accent)) 8%, white) 0%,
		transparent 60%
	);
}

.prc-dashboard__card:hover {
	border-color: color-mix(in srgb, var(--card-accent, var(--ma-accent)) 40%, white);
}

/* ── Complete Purchase banner ─────────────────────────────────────────────── */

.prc-dashboard__cart-banner {
	display: flex;
	align-items: center;
	gap: 1em;
	margin-top: 1.25em;
	padding: 1.1em 1.4em;
	background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
	border: 1px solid #86efac;
	border-radius: var(--ma-radius);
	flex-wrap: wrap;
}

.prc-dashboard__cart-icon {
	width: 44px;
	height: 44px;
	background: #16a34a;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.prc-dashboard__cart-icon svg {
	width: 22px;
	height: 22px;
	color: #fff;
}

.prc-dashboard__cart-text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: .1em;
	min-width: 160px;
}

.prc-dashboard__cart-text strong {
	font-size: .9em;
	font-weight: 700;
	color: #14532d;
}

.prc-dashboard__cart-text span {
	font-size: .8em;
	color: #166534;
}

.prc-dashboard__cart-btn {
	display: inline-flex;
	align-items: center;
	gap: .4em;
	padding: .6em 1.25em;
	background: #16a34a;
	color: #fff !important;
	font-size: .875em;
	font-weight: 600;
	border-radius: 99px;
	text-decoration: none !important;
	white-space: nowrap;
	transition: background var(--ma-duration) var(--ma-ease),
	            transform  var(--ma-duration) var(--ma-ease);
}

.prc-dashboard__cart-btn:hover {
	background: #15803d;
	transform: translateX(2px);
	color: #fff !important;
}

/* ── Sign-out footer ──────────────────────────────────────────────────────── */

.prc-dashboard__footer {
	margin-top: 2.25em;
	display: flex;
	justify-content: center;
}

.prc-dashboard__logout {
	display: inline-flex;
	align-items: center;
	gap: .4em;
	font-size: .825em;
	font-weight: 500;
	color: var(--ma-muted) !important;
	text-decoration: none !important;
	padding: .5em .85em;
	border: 1px solid var(--ma-border);
	border-radius: 99px;
	transition: color var(--ma-duration) var(--ma-ease),
	            border-color var(--ma-duration) var(--ma-ease),
	            background var(--ma-duration) var(--ma-ease);
}

.prc-dashboard__logout:hover {
	color: #dc2626 !important;
	border-color: #fca5a5;
	background: #fef2f2;
}

/* ── Sidebar nav (non-dashboard pages) ────────────────────────────────────── */

.woocommerce-MyAccount-navigation {
	border-radius: var(--ma-radius) !important;
	overflow: hidden;
	border: 1px solid var(--ma-border) !important;
	background: var(--ma-surface) !important;
	box-shadow: var(--ma-shadow-sm) !important;
	margin-bottom: 1.5em !important;
}

.woocommerce-MyAccount-navigation ul {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

.woocommerce-MyAccount-navigation ul li {
	border-bottom: 1px solid var(--ma-border);
	margin: 0 !important;
}

.woocommerce-MyAccount-navigation ul li:last-child {
	border-bottom: none;
}

.woocommerce-MyAccount-navigation ul li a {
	display: flex !important;
	align-items: center;
	gap: .5em;
	padding: .75em 1.1em !important;
	font-size: .875em !important;
	font-weight: 500 !important;
	color: var(--ma-muted) !important;
	text-decoration: none !important;
	transition: background var(--ma-duration) var(--ma-ease),
	            color var(--ma-duration) var(--ma-ease),
	            padding-left var(--ma-duration) var(--ma-ease) !important;
}

.woocommerce-MyAccount-navigation ul li a:hover {
	background: var(--ma-surface-2) !important;
	color: var(--ma-text) !important;
	padding-left: 1.4em !important;
}

.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--is-active a {
	background: var(--ma-accent-light) !important;
	color: var(--ma-accent) !important;
	font-weight: 700 !important;
	padding-left: 1.1em !important;
}

/* ── Sidebar account-user block ───────────────────────────────────────────── */

.prc-account-user {
	display: flex;
	align-items: center;
	gap: .85em;
	padding: 1.1em 1.1em;
	background: var(--ma-surface);
	border: 1px solid var(--ma-border);
	border-radius: var(--ma-radius);
	box-shadow: var(--ma-shadow-sm);
	margin-bottom: 1em;
}

.prc-account-user__img {
	width: 48px !important;
	height: 48px !important;
	border-radius: 50% !important;
	border: 2px solid var(--ma-accent-mid);
	display: block;
	flex-shrink: 0;
}

.prc-account-user__info {
	display: flex;
	flex-direction: column;
	gap: .1em;
	min-width: 0;
}

.prc-account-user__name {
	font-size: .875em;
	font-weight: 700;
	color: var(--ma-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	display: block;
}

.prc-account-user__sector {
	font-size: .75em;
	color: var(--ma-muted);
	text-transform: capitalize;
}

/* ── Kill Flatsome sidebar column border ──────────────────────────────────── */

.woocommerce-account .col-border {
	border-right: none !important;
	padding-right: 0 !important;
}

/* ── My Account content area ──────────────────────────────────────────────── */

.woocommerce-MyAccount-content {
	background: var(--ma-surface);
	border: 1px solid var(--ma-border);
	border-radius: var(--ma-radius);
	box-shadow: var(--ma-shadow-sm);
	padding: 2em !important;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */

@media ( max-width: 900px ) {
	.prc-dashboard__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media ( max-width: 640px ) {
	.prc-dashboard__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: .75em;
	}

	.prc-dashboard__card {
		padding: 1.4em .75em 1.2em;
	}

	.prc-dashboard__card-icon {
		width: 48px;
		height: 48px;
	}

	.prc-dashboard__card-icon svg {
		width: 22px;
		height: 22px;
	}

	.prc-dashboard__name {
		font-size: 1.3em;
	}

	.woocommerce-MyAccount-content {
		padding: 1.25em !important;
	}
}

/* ── Hide WooCommerce default dashboard heading ───────────────────────────── */

.dashboard-links,
.woocommerce-account .woocommerce > h2:first-of-type,
.woocommerce-MyAccount-content > p:first-child {
	display: none !important;
}

/* ── My Details page ──────────────────────────────────────────────────────── */

.prc-my-details {
	display: flex;
	flex-direction: column;
	gap: 2em;
}

.prc-my-details__section {
	background: var(--ma-surface-2);
	border: 1px solid var(--ma-border);
	border-radius: var(--ma-radius);
	padding: 1.75em 2em;
}

.prc-my-details__section-header {
	display: flex;
	align-items: flex-start;
	gap: 1em;
	margin-bottom: 1.5em;
	padding-bottom: 1.25em;
	border-bottom: 1px solid var(--ma-border);
}

.prc-my-details__section-icon {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--ma-accent) 12%, white);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.prc-my-details__section-icon svg {
	width: 22px;
	height: 22px;
	color: var(--ma-accent);
}

.prc-my-details__section-title {
	font-size: 1em !important;
	font-weight: 700 !important;
	color: var(--ma-text) !important;
	margin: 0 0 .2em !important;
	padding: 0 !important;
	border: none !important;
}

.prc-my-details__section-desc {
	font-size: .8em;
	color: var(--ma-muted);
	margin: 0;
}

/* Two-column row inside forms */
.prc-my-details__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 1em;
}

.prc-my-details__form .form-row {
	margin-bottom: 1em;
}

.prc-my-details__submit {
	display: flex;
	align-items: center;
	gap: 1em;
	margin-top: .25em;
	margin-bottom: 0 !important;
}

.prc-my-details__submit .woocommerce-Button,
.prc-my-details__submit .button {
	display: inline-flex;
	align-items: center;
	gap: .4em;
	padding: .6em 1.4em;
	background: var(--ma-accent);
	color: #fff !important;
	font-size: .875em;
	font-weight: 600;
	border: none;
	border-radius: 99px;
	cursor: pointer;
	text-decoration: none !important;
	transition: background var(--ma-duration) var(--ma-ease),
	            transform  var(--ma-duration) var(--ma-ease);
}

.prc-my-details__submit .woocommerce-Button:hover,
.prc-my-details__submit .button:hover {
	background: color-mix(in srgb, var(--ma-accent) 85%, black);
	transform: translateY(-1px);
}

@media ( max-width: 640px ) {
	.prc-my-details__section {
		padding: 1.25em;
	}

	.prc-my-details__row {
		grid-template-columns: 1fr;
		gap: 0;
	}
}

/* ── Shared account table style ───────────────────────────────────────────── */
/* Applied to Orders, Certificates (and complements My Delegates/Courses).    */

.prc-account-table {
	width: 100%;
	border-collapse: collapse;
}

.prc-account-table th,
.prc-account-table td {
	padding: 0.65em 0.85em;
	text-align: left;
	border-bottom: 1px solid var(--ma-border, #e2e8f0);
	font-size: 0.875em;
	vertical-align: middle;
}

.prc-account-table thead th {
	font-weight: 600;
	background: var(--ma-surface-2, #f7f9fc);
	color: var(--ma-muted, #64748b);
	text-transform: uppercase;
	font-size: 0.75em;
	letter-spacing: 0.04em;
}

.prc-account-table tbody tr:last-child td {
	border-bottom: none;
}

/* ── Orders ───────────────────────────────────────────────────────────────── */

#prc-orders-tab {
	padding: 1.75em 2em;
}

/* Order status pills */
.prc-order-status {
	display: inline-block;
	font-size: 0.75em;
	font-weight: 600;
	padding: 0.2em 0.65em;
	border-radius: 20px;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	white-space: nowrap;
}

.prc-order-status--completed  { background: #dcfce7; color: #15803d; }
.prc-order-status--processing { background: #dbeafe; color: #1d4ed8; }
.prc-order-status--on-hold    { background: #fef9c3; color: #a16207; }
.prc-order-status--failed,
.prc-order-status--cancelled  { background: var(--ma-surface-2, #f7f9fc); color: var(--ma-muted, #64748b); }
.prc-order-status--pending    { background: #fef3c7; color: #92400e; }
.prc-order-status--refunded   { background: #f3e8ff; color: #7e22ce; }

/* Action links — text links to match Delegates section */
.prc-order-actions {
	display: flex;
	flex-direction: column;
	gap: 0.3em;
}

.prc-order-action {
	font-size: 0.85em;
	font-weight: 500;
	color: var(--ma-accent, #1d6fa4);
	text-decoration: none;
	white-space: nowrap;
	transition: color 200ms ease;
}

.prc-order-action:hover {
	text-decoration: underline;
}

.prc-order-action--cancel,
.prc-order-action--cancel:hover { color: #dc2626; }

/* Pagination */
.prc-orders-pagination {
	display: flex;
	gap: 0.75em;
	justify-content: center;
	margin-top: 1.25em;
}

.prc-orders-pagination__btn {
	display: inline-flex;
	align-items: center;
	gap: 0.3em;
	padding: 0.5em 1em;
	font-size: 0.875em;
	font-weight: 500;
	color: var(--ma-accent, #1d6fa4);
	border: 1px solid var(--ma-border, #e2e8f0);
	border-radius: 99px;
	text-decoration: none;
	transition: background 200ms ease, border-color 200ms ease;
}

.prc-orders-pagination__btn:hover {
	background: var(--ma-surface-2, #f7f9fc);
	border-color: var(--ma-accent-mid, #b8d8ef);
}

/* ── Certificates ─────────────────────────────────────────────────────────── */

#prc-certificates-tab {
	padding: 1.75em 2em;
}

/* Style the WatuPRO .widefat table to match the shared account table */
.prc-certificates-content table.widefat {
	width: 100%;
	border-collapse: collapse;
	margin: 0;
}

.prc-certificates-content table.widefat th,
.prc-certificates-content table.widefat td {
	padding: 0.65em 0.85em;
	text-align: left;
	border-bottom: 1px solid var(--ma-border, #e2e8f0);
	font-size: 0.875em;
	vertical-align: middle;
	background: none;
	box-shadow: none;
}

.prc-certificates-content table.widefat thead th {
	font-weight: 600;
	background: var(--ma-surface-2, #f7f9fc) !important;
	color: var(--ma-muted, #64748b);
	text-transform: uppercase;
	font-size: 0.75em;
	letter-spacing: 0.04em;
}

.prc-certificates-content table.widefat tbody tr:last-child td {
	border-bottom: none;
}

/* "Print/View Certificate" link */
.prc-certificates-content table.widefat td a {
	color: var(--ma-accent, #1d6fa4);
	font-weight: 500;
	font-size: 0.875em;
	text-decoration: none;
}

.prc-certificates-content table.widefat td a:hover {
	text-decoration: underline;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */

@media ( max-width: 640px ) {
	#prc-orders-tab,
	#prc-certificates-tab {
		padding: 1.25em;
	}

	.prc-account-table thead {
		display: none;
	}

	.prc-account-table td {
		display: block;
		text-align: right;
		padding: 0.5em 0.85em;
	}

	.prc-account-table td::before {
		content: attr(data-title);
		float: left;
		font-weight: 600;
		font-size: 0.75em;
		text-transform: uppercase;
		letter-spacing: 0.04em;
		color: var(--ma-muted, #64748b);
	}
}


/* WatuPRO — remove bottom margin on empty-state note */
.watupro-note {
	margin-bottom: 0;
}

/* ── AJAX navigation — content loading state ──────────────────────────────── */

.woocommerce-MyAccount-content {
	transition: opacity 80ms ease;
}

/* ── Downloads page ───────────────────────────────────────────────────────── */

#prc-downloads-tab {
	padding: 1.75em 2em;
}

.pcd-downloads-table {
	width: 100%;
	border-collapse: collapse;
}

.pcd-downloads-table th,
.pcd-downloads-table td {
	padding: 0.65em 0.85em;
	text-align: left;
	border-bottom: 1px solid var(--ma-border, #e2e8f0);
	font-size: 0.875em;
	vertical-align: middle;
}

.pcd-downloads-table thead th {
	font-weight: 600;
	background: var(--ma-surface-2, #f7f9fc);
	color: var(--ma-muted, #64748b);
	text-transform: uppercase;
	font-size: 0.75em;
	letter-spacing: 0.04em;
}

.pcd-downloads-table tbody tr:last-child td {
	border-bottom: none;
}

.pcd-downloads-table td:last-child {
	text-align: right;
	white-space: nowrap;
}

@media ( max-width: 640px ) {
	#prc-downloads-tab {
		padding: 1.25em;
	}
}

/* ── CPD summary banner (Certificates page) ──────────────────────────────── */

.prc-cpd-summary-banner {
	display: flex;
	gap: 1.5rem;
	padding: 1.25rem 1.5rem;
	background: var(--ma-accent-light);
	border: 1px solid var(--ma-accent-mid);
	border-radius: 10px;
	margin-bottom: 1.5rem;
}

.prc-cpd-summary-banner__stat {
	display: flex;
	flex-direction: column;
	gap: .1rem;
}

.prc-cpd-summary-banner__value {
	font-size: 1.625rem;
	font-weight: 800;
	color: var(--ma-accent);
	line-height: 1.1;
}

.prc-cpd-summary-banner__label {
	font-size: .75rem;
	font-weight: 500;
	color: var(--ma-muted);
	text-transform: uppercase;
	letter-spacing: .05em;
}

/* ── CPD hours strip (Dashboard) ─────────────────────────────────────────── */

.prc-dashboard__cpd-strip {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem 1.25rem;
	background: var(--ma-accent-light);
	border: 1px solid var(--ma-accent-mid);
	border-radius: 10px;
	margin: 1.25rem 0 0;
	text-decoration: none !important;
	color: inherit;
	transition: box-shadow var(--ma-duration) var(--ma-ease),
	            border-color var(--ma-duration) var(--ma-ease);
}

.prc-dashboard__cpd-strip:hover {
	box-shadow: var(--ma-shadow);
	border-color: var(--ma-accent);
}

.prc-dashboard__cpd-strip__icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--ma-accent);
	border-radius: 8px;
	color: #fff;
}

.prc-dashboard__cpd-strip__icon svg {
	width: 20px;
	height: 20px;
}

.prc-dashboard__cpd-strip__text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: .1rem;
}

.prc-dashboard__cpd-strip__text strong {
	font-size: .9375rem;
	color: #0f172a;
}

.prc-dashboard__cpd-strip__text span {
	font-size: .8rem;
	color: var(--ma-muted);
}

.prc-dashboard__cpd-strip__arrow {
	flex-shrink: 0;
	color: var(--ma-muted);
	transition: color var(--ma-duration) var(--ma-ease),
	            transform var(--ma-duration) var(--ma-ease);
}

.prc-dashboard__cpd-strip:hover .prc-dashboard__cpd-strip__arrow {
	color: var(--ma-accent);
	transform: translateX(3px);
}

/* ── Certificate links ────────────────────────────────────────────────────── */

.pcd-cert-link {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: .5rem;
	text-decoration: none;
	color: inherit;
	padding: .35rem .5rem;
	margin: -.35rem -.5rem;
	border-radius: 6px;
	transition: background var(--ma-duration) var(--ma-ease);
}

.pcd-cert-link:hover {
	background: var(--ma-accent-light);
}

.pcd-cert-view-link {
	flex-shrink: 0;
	font-size: .75rem;
	font-weight: 600;
	color: var(--ma-accent);
}

/* ── Dashboard upcoming events ────────────────────────────────────────────── */

.prc-dashboard__upcoming {
	margin: 2rem 0 0;
	padding-top: 1.75rem;
	border-top: 1px solid var(--ma-border);
}

.prc-dashboard__section-heading {
	font-size: .6875rem;
	font-weight: 800;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--ma-muted);
	margin: 0 0 .875rem;
}

.prc-dashboard__upcoming-list {
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.prc-upcoming-event-card {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: .875rem 1rem;
	background: #fff;
	border: 1px solid var(--ma-border);
	border-radius: 10px;
	text-decoration: none !important;
	color: inherit;
	transition: box-shadow var(--ma-duration) var(--ma-ease),
	            border-color var(--ma-duration) var(--ma-ease);
}

.prc-upcoming-event-card:hover {
	box-shadow: var(--ma-shadow);
	border-color: var(--ma-accent-mid);
}

.prc-upcoming-event-card__date-badge {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	background: var(--ma-accent-light);
	border-radius: 8px;
	line-height: 1;
}

.prc-upcoming-event-card__day {
	font-size: 1.25rem;
	font-weight: 800;
	color: var(--ma-accent);
}

.prc-upcoming-event-card__month {
	font-size: .625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: var(--ma-accent);
}

.prc-upcoming-event-card__year {
	font-size: .5625rem;
	color: var(--ma-muted);
	letter-spacing: .03em;
}

.prc-upcoming-event-card__info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: .15rem;
}

.prc-upcoming-event-card__title {
	font-size: .9rem;
	font-weight: 700;
	color: #0f172a;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.prc-upcoming-event-card:hover .prc-upcoming-event-card__title {
	color: var(--ma-accent);
}

.prc-upcoming-event-card__venue {
	font-size: .775rem;
	color: var(--ma-muted);
}

.prc-upcoming-event-card__attendees {
	font-size: .75rem;
	color: var(--ma-muted);
	font-style: italic;
}

.prc-upcoming-event-card__arrow {
	flex-shrink: 0;
	color: var(--ma-muted);
	transition: color var(--ma-duration) var(--ma-ease),
	            transform var(--ma-duration) var(--ma-ease);
}

.prc-upcoming-event-card:hover .prc-upcoming-event-card__arrow {
	color: var(--ma-accent);
	transform: translateX(3px);
}

/* ── Dashboard upsell section ─────────────────────────────────────────────── */

.prc-dashboard__upsell {
	margin: 2rem 0 0;
	padding-top: 1.75rem;
	border-top: 1px solid var(--ma-border);
}

.prc-dashboard__upsell .prc-dashboard__section-heading {
	margin-bottom: 1rem;
}


.prc-dashboard__upsell-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
}

@media (max-width: 900px) {
	.prc-dashboard__upsell-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
	.prc-dashboard__upsell-grid { grid-template-columns: 1fr; }
}

.prc-upsell-card {
	display: flex;
	flex-direction: column;
	border: 1px solid var(--ma-border);
	border-radius: 10px;
	overflow: hidden;
	text-decoration: none !important;
	color: inherit;
	background: #fff;
	transition: box-shadow var(--ma-duration) var(--ma-ease),
	            transform  var(--ma-duration) var(--ma-ease);
}

.prc-upsell-card:hover {
	box-shadow: var(--ma-shadow-hover);
	transform: translateY(-2px);
}

.prc-upsell-card__image {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #f1f5f9;
}

.prc-upsell-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.prc-upsell-card__image-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #e2e8f0 0%, #f1f5f9 100%);
}

.prc-upsell-card__body {
	padding: .875rem;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: .25rem;
}

.prc-upsell-card__badge {
	font-size: .6875rem;
	font-weight: 700;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: #58b000;
}

.prc-upsell-card__title {
	font-size: .8125rem;
	font-weight: 700;
	color: #0f172a;
	margin: 0;
	line-height: 1.35;
}

.prc-upsell-card:hover .prc-upsell-card__title {
	color: var(--ma-accent);
}

.prc-upsell-card__date {
	font-size: .75rem;
	color: var(--ma-muted);
	margin: 0;
}

.prc-upsell-card__price {
	font-size: .8125rem;
	font-weight: 600;
	color: #0f172a;
	margin: auto 0 0;
	padding-top: .5rem;
}
