.epa-auth-shell {
	position: relative;
	overflow: hidden;
	min-height: 760px;
	display: grid;
	place-items: center;
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding: 72px 18px 86px;
	background: #061226;
	border-radius: 0;
}

.epa-login-stage {
	width: min(100%, 665px);
}

.epa-auth-card {
	position: relative;
	z-index: 1;
	width: 100%;
	padding: 28px 24px 26px;
	border: 0;
	border-radius: 44px;
	background: #84dc3a;
	box-shadow: 0 18px 50px rgba(0, 0, 0, .22);
	color: #061226;
}

.epa-auth-brand {
	display: flex;
	justify-content: center;
	gap: 16px;
	align-items: center;
	margin-bottom: 28px;
}

.epa-auth-logo-fallback {
	display: grid;
	place-items: center;
	width: 82px;
	height: 58px;
	border-radius: 14px;
	background: linear-gradient(135deg, #8be13d, #009bd3);
	color: #fff;
	font-weight: 900;
	font-size: 24px;
}

.epa-auth-brand strong {
	display: block;
	font-size: 39px;
	line-height: 1;
	color: #fff;
	letter-spacing: -.04em;
}

.epa-auth-brand strong span {
	color: #00a5d8;
}

.epa-auth-form label {
	display: block;
	margin: 14px 0 7px;
	color: #102033;
	font-weight: 500;
	font-size: 14px;
}

.epa-auth-form input[type="text"],
.epa-auth-form input[type="password"] {
	width: 100%;
	min-height: 45px;
	padding: 0 14px;
	border: 0;
	border-radius: 0;
	background: #fff;
	color: #061226;
	font-size: 16px;
	box-shadow: none;
}

.epa-remember {
	display: inline-flex !important;
	align-items: center;
	gap: 8px;
	margin: 16px 0 18px !important;
	font-weight: 500 !important;
}

.epa-auth-submit {
	width: 100%;
	min-height: 48px;
	border: 0;
	border-radius: 999px;
	background: #049bd3;
	color: #fff;
	font-size: 16px;
	font-weight: 800;
	cursor: pointer;
	box-shadow: 0 8px 20px rgba(0, 0, 0, .24);
}

.epa-auth-links {
	display: flex;
	justify-content: space-between;
	gap: 18px;
	margin: 22px 0 24px;
	color: #fff;
	font-size: 14px;
	font-weight: 700;
}

.epa-auth-links a,
.epa-auth-back {
	color: #fff;
	text-decoration: none;
}

.epa-auth-back {
	display: block;
	text-align: center;
	font-size: 14px;
	font-weight: 700;
}

.epa-auth-message {
	padding: 16px;
	border-radius: 14px;
	background: #eef8ff;
	color: #07304b;
}

.epa-account-section {
	margin: 0 0 28px;
}

.epa-account-heading {
	margin: 0 0 22px;
	padding: 24px;
	border-radius: 24px;
	background:
		radial-gradient(circle at 10% 0%, rgba(132, 220, 58, .24), transparent 32%),
		linear-gradient(135deg, #061226, #09213b);
	color: #fff;
}

.epa-account-heading h2 {
	margin: 0 0 8px;
	color: #fff;
	font-size: clamp(28px, 4vw, 42px);
	line-height: 1;
}

.epa-account-heading p {
	margin: 0;
	color: rgba(255, 255, 255, .75);
}

.epa-eyebrow {
	margin: 0 0 8px !important;
	color: #84dc3a !important;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: .12em;
	text-transform: uppercase;
}

.epa-empty-state {
	padding: 24px;
	border: 1px solid #dfe5ec;
	border-radius: 20px;
	background: #fff;
	color: #253247;
}

.epa-empty-state strong {
	display: block;
	margin-bottom: 6px;
	font-size: 18px;
}

.epa-ticket-grid,
.epa-access-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 18px;
}

.epa-ticket-card,
.epa-access-card {
	overflow: hidden;
	border: 1px solid #dfe5ec;
	border-radius: 24px;
	background: #fff;
	box-shadow: 0 14px 34px rgba(15, 23, 42, .08);
}

.epa-ticket-card {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 18px;
	padding: 22px;
}

.epa-ticket-card h3,
.epa-access-card h3 {
	margin: 12px 0 6px;
	color: #111827;
	font-size: 21px;
	line-height: 1.2;
}

.epa-muted {
	margin: 0 0 14px;
	color: #64748b;
}

.epa-ticket-badge {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	padding: 6px 10px;
	border-radius: 999px;
	background: #e0f2fe;
	color: #0369a1;
	font-size: 12px;
	font-weight: 800;
}

.epa-ticket-badge-used {
	background: #f1f5f9;
	color: #64748b;
}

.epa-ticket-meta {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	margin: 18px 0;
}

.epa-ticket-meta div {
	padding: 10px;
	border-radius: 14px;
	background: #f8fafc;
}

.epa-ticket-meta dt {
	color: #64748b;
	font-size: 12px;
	font-weight: 700;
}

.epa-ticket-meta dd {
	margin: 2px 0 0;
	color: #0f172a;
	font-weight: 800;
}

.epa-ticket-qr {
	align-self: center;
	padding: 10px;
	border: 1px solid #e2e8f0;
	border-radius: 18px;
	background: #fff;
}

.epa-ticket-qr img {
	display: block;
	width: 120px;
	height: 120px;
}

.epa-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 42px;
	padding: 0 18px;
	border-radius: 999px;
	background: #049bd3;
	color: #fff !important;
	font-weight: 800;
	text-decoration: none !important;
	box-shadow: 0 10px 22px rgba(4, 155, 211, .22);
}

.epa-access-thumb {
	min-height: 170px;
	background-position: center;
	background-size: cover;
}

.epa-access-thumb-empty {
	display: grid;
	place-items: center;
	background: linear-gradient(135deg, #061226, #049bd3);
	color: #fff;
	font-size: 38px;
}

.epa-access-body {
	padding: 22px;
}

@media (max-width: 640px) {
	.epa-auth-shell {
		min-height: 620px;
		padding: 38px 14px 58px;
	}

	.epa-auth-card {
		padding: 24px;
		border-radius: 30px;
	}

	.epa-auth-brand strong {
		font-size: 31px;
	}

	.epa-auth-links {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.epa-ticket-card {
		grid-template-columns: 1fr;
	}

	.epa-ticket-qr {
		width: fit-content;
	}

	.epa-ticket-meta {
		grid-template-columns: 1fr;
	}
}
