/* English Prep — pricing cards (checkout shortcode + Elementor widget).
   All colours are CSS variables so the widget's style controls can theme them. */

.ep-pricing {
	--epp-card-bg: #ffffff;
	--epp-card-border: #e7e2d8;
	--epp-radius: 16px;
	--epp-accent: #b45309;
	--epp-accent-hover: #9a4708;
	--epp-accent-text: #ffffff;
	--epp-name: #1f2937;
	--epp-price: #1f2937;
	--epp-feat: #4b5563;
	--epp-check: #b45309;
	--epp-popular: #b45309;
	--epp-silver: #9aa0a6;
	--epp-gold: #c8911a;
	--epp-platinum: #6d5bd0;
}

.ep-pricing-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 20px;
	align-items: stretch;
}

.ep-pricing-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--epp-card-bg);
	border: 1px solid var(--epp-card-border);
	border-radius: var(--epp-radius);
	padding: 28px 22px 24px;
	box-shadow: 0 1px 2px rgba(0, 0, 0, .04);
}
.ep-pricing-card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	border-radius: var(--epp-radius) var(--epp-radius) 0 0;
	background: var(--epp-tier, transparent);
}
.ep-pricing-card--silver   { --epp-tier: var(--epp-silver); }
.ep-pricing-card--gold     { --epp-tier: var(--epp-gold); }
.ep-pricing-card--platinum { --epp-tier: var(--epp-platinum); }

.ep-pricing-card.is-popular {
	border-color: var(--epp-popular);
	border-width: 2px;
	box-shadow: 0 12px 32px rgba(0, 0, 0, .10);
	transform: translateY(-6px);
}
.ep-pricing-card.is-target { outline: 2px solid var(--epp-popular); outline-offset: 3px; }

.ep-pricing-badge {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--epp-popular);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .02em;
	padding: 4px 12px;
	border-radius: 999px;
	white-space: nowrap;
}

.ep-pricing-name { font-size: 20px; font-weight: 700; color: var(--epp-name); }

.ep-pricing-price {
	margin: 10px 0 2px;
	color: var(--epp-price);
	display: flex;
	align-items: baseline;
	gap: 5px;
	flex-wrap: wrap;
}
.ep-pricing-amt { font-size: 38px; font-weight: 800; line-height: 1; }
.ep-pricing-cur { font-size: 16px; font-weight: 700; }
.ep-pricing-per { font-size: 13px; color: #8a8a8a; font-weight: 500; }
.ep-pricing-free { font-size: 30px; font-weight: 800; color: var(--epp-price); }

.ep-pricing-feat {
	list-style: none;
	margin: 18px 0 22px;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1 1 auto;
}
.ep-pricing-feat li {
	position: relative;
	padding-left: 26px;
	color: var(--epp-feat);
	font-size: 14.5px;
	line-height: 1.4;
}
.ep-pricing-feat li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--epp-check);
	font-weight: 800;
}

.ep-pricing-btn {
	display: block;
	width: 100%;
	text-align: center;
	background: var(--epp-accent);
	color: var(--epp-accent-text);
	border: 0;
	border-radius: 10px;
	padding: 13px 18px;
	font-size: 15px;
	font-weight: 700;
	cursor: pointer;
	text-decoration: none;
	transition: background .15s ease;
}
.ep-pricing-btn:hover { background: var(--epp-accent-hover); color: var(--epp-accent-text); }
.ep-pricing-btn[disabled] { background: #e5e7eb; color: #6b7280; cursor: default; }

.ep-pricing-current {
	margin-top: 14px;
	text-align: center;
	font-size: 13px;
	font-weight: 600;
	color: var(--epp-accent);
}

.ep-pricing-note { padding: 12px 16px; border-radius: 10px; margin-bottom: 16px; font-size: 14px; }
.ep-pricing-note--ok  { background: #e3f3e3; color: #1a6b1a; }
.ep-pricing-note--err { background: #fbe7e7; color: #a3261f; }
.ep-pricing-note--info { background: #eef2f7; color: #3b4a5a; }

@media (max-width: 600px) {
	.ep-pricing-card.is-popular { transform: none; }
}
