.ds-ticket-plan {
	--ds-ticket-plan-active-bg: #f8f4f0;
	--ds-ticket-plan-active-color: #8f0f1d;
	--ds-ticket-plan-inactive-border: rgba(248, 244, 240, 0.76);
	--ds-ticket-plan-inactive-color: #f8f4f0;
	--ds-ticket-plan-radius: 20px;
	--ds-ticket-plan-gap: 16px;
	--ds-ticket-plan-padding: 22px 58px 24px 28px;
	--ds-ticket-plan-border-width: 1px;
	--ds-ticket-plan-radio-size: 22px;
	--ds-ticket-plan-section-title-color: #f8f4f0;
	--ds-ticket-plan-price-color: currentColor;
	--ds-ticket-plan-title-color: currentColor;
	--ds-ticket-plan-description-color: currentColor;
	--ds-ticket-plan-benefits-color: currentColor;
	color: var(--ds-ticket-plan-inactive-color);
	width: 100%;
}

.ds-ticket-plan__section-title {
	margin: 0 0 20px;
	color: var(--ds-ticket-plan-section-title-color);
	font-size: 48px;
	font-style: italic;
	font-weight: 700;
	line-height: 1.1;
}

.ds-ticket-plan,
.ds-ticket-plan * {
	box-sizing: border-box;
	letter-spacing: 0;
}

.ds-ticket-plan__options {
	display: grid;
	gap: var(--ds-ticket-plan-gap);
}

.ds-ticket-plan__card {
	position: relative;
	min-height: 128px;
	padding: var(--ds-ticket-plan-padding);
	border: var(--ds-ticket-plan-border-width) solid var(--ds-ticket-plan-inactive-border);
	border-radius: var(--ds-ticket-plan-radius);
	background: transparent;
	color: var(--ds-ticket-plan-inactive-color);
	isolation: isolate;
	cursor: pointer;
	transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.ds-ticket-plan__card:hover {
	transform: translateY(-1px);
}

.ds-ticket-plan__card--active {
	border-color: transparent;
	background: var(--ds-ticket-plan-active-bg);
	color: var(--ds-ticket-plan-active-color);
}

.ds-ticket-plan__card:focus-within {
	outline: 2px solid currentColor;
	outline-offset: 4px;
}

.ds-ticket-plan__input {
	position: absolute;
	top: 18px;
	right: 18px;
	z-index: 3;
	width: var(--ds-ticket-plan-radio-size);
	height: var(--ds-ticket-plan-radio-size);
	margin: 0;
	opacity: 0;
}

.ds-ticket-plan__radio {
	position: absolute;
	top: 18px;
	right: 18px;
	z-index: 2;
	width: var(--ds-ticket-plan-radio-size);
	height: var(--ds-ticket-plan-radio-size);
	border: 1.5px solid currentColor;
	border-radius: 999px;
	pointer-events: none;
}

.ds-ticket-plan__radio::after {
	position: absolute;
	inset: calc(var(--ds-ticket-plan-radio-size) * 0.18);
	border-radius: inherit;
	background: currentColor;
	content: "";
	opacity: 0;
	transform: scale(0.5);
	transition: opacity 160ms ease, transform 160ms ease;
}

.ds-ticket-plan__card--active .ds-ticket-plan__radio::after {
	opacity: 1;
	transform: scale(1);
}

.ds-ticket-plan__input:focus-visible ~ .ds-ticket-plan__radio {
	box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.28);
}

.ds-ticket-plan__label {
	display: grid;
	gap: 8px;
	width: 100%;
	cursor: pointer;
}

.ds-ticket-plan__price {
	display: block;
	color: var(--ds-ticket-plan-price-color);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 16px;
	font-style: italic;
	font-weight: 600;
	line-height: 1.2;
}

.ds-ticket-plan__price--member {
	display: block;
}

.ds-ticket-plan__event-price,
.ds-ticket-plan__price-note {
	display: inline;
	margin-left: 4px;
}

.ds-ticket-plan__old-price {
	opacity: 0.72;
	text-decoration: line-through;
	text-decoration-thickness: 1px;
}

.ds-ticket-plan__title {
	display: block;
	color: var(--ds-ticket-plan-title-color);
	font-size: 20px;
	font-weight: 800;
	line-height: 1.2;
}

.ds-ticket-plan__description {
	display: block;
	max-width: 40rem;
	color: var(--ds-ticket-plan-description-color);
	font-family: Georgia, "Times New Roman", serif;
	font-size: 15px;
	line-height: 1.35;
	white-space: pre-line;
}

.ds-ticket-plan__benefits-toggle {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 14px 0 0;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--ds-ticket-plan-benefits-color);
	cursor: pointer;
	font: inherit;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.2;
	text-align: left;
}

.ds-ticket-plan__benefits-toggle:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 4px;
}

.ds-ticket-plan__chevron {
	width: 9px;
	height: 9px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	transition: transform 160ms ease;
}

.ds-ticket-plan__benefits-toggle[aria-expanded="true"] .ds-ticket-plan__chevron {
	transform: translateY(2px) rotate(225deg);
}

.ds-ticket-plan__benefits {
	display: grid;
	gap: 7px;
	margin: 14px 0 0;
	padding: 0 0 0 18px;
	color: var(--ds-ticket-plan-benefits-color);
	font-size: 14px;
	line-height: 1.35;
}

.ds-ticket-plan__benefits[hidden] {
	display: none;
}

.ds-ticket-plan__admin-note {
	margin-top: 12px;
	padding: 10px 12px;
	border: 1px solid rgba(143, 15, 29, 0.24);
	border-radius: 8px;
	background: rgba(248, 244, 240, 0.92);
	color: #8f0f1d;
	font-size: 13px;
	line-height: 1.35;
}

.ds-ticket-plan__admin-note p {
	margin: 0;
}

.ds-ticket-plan__admin-note p + p {
	margin-top: 6px;
}

.dst-event-cta__button[data-dst-event-cta-dynamic] {
	text-decoration: none;
}

.dst-event-cta__button[data-dst-event-cta-dynamic]:hover,
.dst-event-cta__button[data-dst-event-cta-dynamic]:focus {
	text-decoration: none;
}

.dst-event-cta__button[data-dst-event-cta-dynamic].is-disabled {
	cursor: not-allowed;
	opacity: 0.55;
	pointer-events: auto;
}

.dst-event-cta__button[data-dst-event-cta-dynamic]:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 4px;
}

@media (max-width: 600px) {
	.ds-ticket-plan__card {
		min-height: 0;
		padding-right: max(48px, calc(var(--ds-ticket-plan-radio-size) + 26px));
	}

	.ds-ticket-plan__title {
		font-size: 18px;
	}

	.ds-ticket-plan__description {
		font-size: 14px;
	}
}
