@charset "UTF-8";

.coupon {
}

.coupon_ttl {
	grid-column: 1 / 5;
	color: var(--c-red);
	font-weight: bold;
	font-size: 25px;
}

body.-coupon-lasora .coupon_ttl {
	color: var(--c-blue);
}

.coupon_cnt {
	grid-column: 5 /13;
	position: relative;
}

.coupon_cnt::before {
	content: "";
	display: block;
	position: absolute;
	top: -45px;
	right: 30px;
	width: 241px;
	height: 91px;
	background-image: url(/assets/img/coupon/coupon-bal-blue@2x.png);
	background-size: contain;
	background-repeat: no-repeat;
}

body.-coupon-lasora .coupon_cnt::before {
	background-image: url(/assets/img/coupon/coupon-bal-red@2x.png);
}

.coupon_flow {
	border-top: 1px solid var(--c-border);
	line-height: 1.6;
}

.coupon_flow_item {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 15px 0;
	border-bottom: 1px solid var(--c-border);
}

.coupon_flow_ttl {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 6px;
	width: 160px;
	min-height: 70px;
	padding: 12px;
	background: var(--c-red);
	color: var(--c-white);
	font-weight: bold;
}

body.-coupon-lasora .coupon_flow_ttl {
	background: var(--c-blue);
}

.coupon_flow_ttl > em {
	font-weight: 500;
	font-size: 38px;
	line-height: 1;
	font-family: var(--font-en);
}

.coupon_flow_cnt {
	flex: 1;
}

.coupon_flow_cnt > small {
}

.coupon_flow_cnt > strong {
	color: var(--c-red);
	font-weight: bold;
	font-size: 25px;
}

body.-coupon-lasora .coupon_flow_cnt > strong {
	color: var(--c-blue);
}

.coupon_flow_cnt > span.-plus {
	font-size: 25px;
}

.coupon_arrow {
	display: flex;
	justify-content: center;
	margin: 25px 0;
}

.coupon_arrow::before {
	content: "";
	display: block;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	width: 33px;
	height: 22px;
	background: var(--c-red);
}

body.-coupon-lasora .coupon_arrow::before {
	background: var(--c-blue);
}

.coupon_card {
}

.coupon_card_box {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	padding: 90px 50px 50px;
	border: 3px solid var(--c-both);
}

.coupon_card_ttl {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	padding: 10px 20px 15px;
	background: var(--c-both);
	color: var(--c-white);
	font-weight: bold;
	font-size: 19px;
	line-height: 1;
}

.coupon_card_wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 24px;
}

.coupon_card_img {
}

.coupon_card_img > img {
	filter: drop-shadow(0px 5px 5px rgba(0, 0, 0, 0.3));
	/* border-radius: 13px; */
}

.coupon_card_cnt {
	line-height: 1.6;
}

.coupon_card_badge {
	margin-bottom: 5px;
}

.coupon_card_badge > span {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	padding: 0 12px;
	border: 1px solid;
}

.coupon_card_text {
	line-height: 2;
}

.coupon_card_text > strong {
	color: var(--c-blue);
	font-weight: bold;
	font-size: 25px;
	line-height: 1;
	font-family: var(--font-en);
}

.coupon_card_text > strong.-off {
	color: var(--c-red);
	font-weight: normal;
	font-size: 62px;
}

.coupon_card_caution {
	margin-top: 6px;
	padding-left: 1em;
	text-indent: -1em;
}

.merit {
	margin-top: 80px;
	padding: 70px 70px 80px;
	border-top: 10px solid var(--c-red);
	background: var(--c-neutral);
}

body.-coupon-lasora .merit {
	border-top: 10px solid var(--c-blue);
}

.merit_hd {
	line-height: 1;
}

.merit_hd_en {
	font-size: 17px;
	font-family: var(--font-en);
}

.merit_hd_ttl {
	margin-top: 10px;
	font-size: 35px;
}

.merit_body {
	margin-top: 70px;
}

.merit_text {
}

.merit_list {
	margin-top: 25px;
	border-top: 1px solid var(--c-border);
}

.merit_item {
	display: grid;
	gap: 10px;
	position: relative;
	padding: 30px 0 30px 240px;
	border-bottom: 1px solid var(--c-border);
	line-height: 1.6;
}

.merit_item_ttl {
	position: absolute;
	top: 30px;
	left: 30px;
	color: var(--c-red);
	font-size: 20px;
	line-height: 1.5;
}

body.-coupon-lasora .merit_item_ttl {
	color: var(--c-blue);
}

.merit_item_off {
	display: flex;
	justify-content: flex-end;
	align-items: baseline;
	gap: 10px;
	text-align: right;
}

.merit_item_off > strong {
	color: var(--c-red);
	font-size: 29px;
	line-height: 1;
}

body.-coupon-lasora .merit_item_off > strong {
	color: var(--c-blue);
}

.both {
	margin-top: 70px;
	line-height: 1;
	text-align: center;
}

.both > a {
	display: inline-flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	max-width: 760px;
	padding: 50px;
	background: var(--c-both);
	color: var(--c-white);
	font-weight: bold;
	font-size: 27px;
}

.both > a::after {
	content: "\e901";
	font-weight: normal;
	font-family: icomoon;
	transition: transform 0.3s;
}

.both > a:hover::after {
	transform: translateX(6px);
}

.common {
}

.common_hd {
	line-height: 1;
	text-align: center;
}

.common_hd_ttl {
	display: inline-flex;
	align-items: center;
	gap: 16px;
	padding-bottom: 16px;
	border-bottom: 2px solid var(--c-both);
	font-size: 35px;
}

.common_hd_ttl > span {
	display: inline-flex;
	align-items: center;
	padding: 10px 20px;
	background: var(--c-both);
	color: var(--c-white);
	font-size: 29px;
}

.common_cnt {
	margin-top: 40px;
	line-height: 1.6;
	text-align: center;
}

.common_lead {
	font-size: 18px;
}

.common_caution {
	margin-top: 20px;
}

.common_caution > strong {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 14px 25px 16px;
	background: var(--c-neutral);
	color: var(--c-red);
	font-weight: bold;
	font-size: 20px;
}

.common_caution > strong::before {
	content: "";
	display: inline-block;
	flex-shrink: 0;
	width: 25px;
	height: 22px;
	background-image: url(/assets/img/coupon/icon-caution.svg);
	background-size: contain;
	background-repeat: no-repeat;
}

.ticket {
	margin-top: 100px;
}

.ticket_ttl {
	line-height: 1;
	text-align: center;
}

.ticket_ttl > span {
	display: inline-flex;
	align-items: center;
	gap: 20px;
	font-size: 25px;
}

.ticket_ttl > span::before,
.ticket_ttl > span::after {
	content: "";
	display: block;
	width: 2px;
	height: 1.3em;
	background: var(--c-both);
}

.ticket_ttl > span::before {
	transform: rotate(-25deg);
}

.ticket_ttl > span::after {
	transform: rotate(25deg);
}

.ticket_card {
	display: flex;
	/* flex-direction: column; */
	margin-top: 24px;
}

.ticket_card_ttl {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 68px;
	border-radius: 12px;
	background: var(--c-both);
	color: var(--c-white);
}

.ticket_card_ttl > span {
	font-size: 27px;
	font-family: var(--font-en);
	writing-mode: vertical-lr;
	transform: rotate(180deg);
}

.ticket_card_main {
	display: flex;
	flex: 1;
	align-items: center;
	padding: 50px 55px;
	border-radius: 12px;
	background: var(--c-neutral-both);
}

.ticket_card_cnt {
	position: relative;
	z-index: 10;
}

.ticket_card_name {
	display: flex;
	justify-content: center;
	align-items: normal;
	gap: 20px;
	font-size: 35px;
	line-height: 1;
	text-align: center;
}

.ticket_card_name > span {
	font-size: 52px;
}

.ticket_card_name > span.icon-pearlv {
	color: var(--c-red);
}

.ticket_card_name > span.icon-lasora {
	color: var(--c-blue);
}

.ticket_card_name > strong {
	display: inline-block;
	position: relative;
	padding-left: 20px;
}

.ticket_card_name > strong::before {
	content: "";
	display: block;
	position: absolute;
	top: 40%;
	left: 0;
	width: 1px;
	height: 36px;
	margin-top: -18px;
	background: var(--c-black);
}

.ticket_card_off {
	margin-top: 25px;
	display: flex;
	justify-content: center;
}

.ticket_card_caution {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 0 24px;
	margin-top: 25px;
}

.ticket_card_caution > li {
	padding-left: 1em;
	text-indent: -1em;
}

.ticket_card_caution > li:first-child {
	flex: 100%;
}

.other {
	margin-top: 100px;
	padding: 80px;
	border-radius: 12px;
	background: var(--c-neutral);
	text-align: center;
}

.other_ttl {
	font-size: 25px;
}

.other_link {
	display: flex;
	justify-content: center;
	gap: 20px;
	margin-top: 35px;
}

@media screen and (max-width: 1239.98px) {
}

@media screen and (max-width: 767.98px) {
	.coupon {
	}

	.coupon_ttl {
		text-align: center;
	}

	body.-coupon-lasora .coupon_ttl {
	}

	.coupon_cnt {
		grid-column: 1/5;
		margin-top: 30px;
	}

	.coupon_cnt::before {
		display: none;
	}

	body.-coupon-lasora .coupon_cnt::before {
	}

	.coupon_flow {
	}

	.coupon_flow_item {
		flex-direction: column;
		align-items: normal;
		gap: 0;
		padding: 0;
	}

	.coupon_flow_ttl {
		width: 100%;
		min-height: 0;
	}

	body.-coupon-lasora .coupon_flow_ttl {
	}

	.coupon_flow_ttl > em {
		font-size: 28px;
	}

	.coupon_flow_cnt {
		display: flex;
		flex-direction: column;
		align-items: center;
		padding: 15px 0;
		text-align: center;
	}

	.coupon_flow_cnt > small {
	}

	.coupon_flow_cnt > strong {
		font-size: 20px;
	}

	body.-coupon-lasora .coupon_flow_cnt > strong {
	}

	.coupon_flow_cnt > span.-plus {
	}

	.coupon_arrow {
	}

	.coupon_arrow::before {
	}

	body.-coupon-lasora .coupon_arrow::before {
	}

	.coupon_card {
	}

	.coupon_card_box {
		display: block;
		padding: 0;
	}

	.coupon_card_ttl {
		position: static;
		width: 100%;
	}

	.coupon_card_wrap {
		flex-direction: column;
		gap: 30px;
		padding: 30px;
	}

	.coupon_card_img {
	}

	.coupon_card_img > img {
	}

	.coupon_card_cnt {
	}

	.coupon_card_badge {
	}

	.coupon_card_badge > span {
	}

	.coupon_card_text {
	}

	.coupon_card_text > strong {
		font-size: 20px;
	}

	.coupon_card_text > strong.-off {
	}

	.coupon_card_caution {
	}

	.merit {
		margin-top: 50px;
		padding: 30px 24px 40px;
		/* margin-inline: var(--margin-offset); */
	}

	body.-coupon-lasora .merit {
	}

	.merit_hd {
	}

	.merit_hd_en {
	}

	.merit_hd_ttl {
		font-size: 25px;
	}

	.merit_body {
		margin-top: 30px;
	}

	.merit_text {
	}

	.merit_list {
	}

	.merit_item {
		gap: 20px;
		padding: 20px 0;
	}

	.merit_item_ttl {
		position: static;
		/* text-align: center; */
		font-weight: bold;
	}

	body.-coupon-lasora .merit_item_ttl {
	}

	.merit_item_off {
		flex-direction: column;
		align-items: flex-start;
		gap: 5px;
		text-align: left;
	}

	.merit_item_off > strong {
		font-size: 20px;
	}

	body.-coupon-lasora .merit_item_off > strong {
	}

	.both {
		margin-top: 50px;
	}

	.both > a {
		padding: 30px 24px;
		font-size: 20px;
	}

	.both > a::after {
	}

	.both > a:hover::after {
	}

	.common {
	}

	.common_hd {
	}

	.common_hd_ttl {
		flex-direction: column;
		font-size: 25px;
	}

	.common_hd_ttl > span {
		font-size: 20px;
	}

	.common_cnt {
	}

	.common_lead {
		font-size: 16px;
		text-align: left;
	}

	.common_caution {
		text-align: left;
	}

	.common_caution > strong {
		flex-direction: column;
		padding: 24px;
		font-size: 18px;
	}

	.common_caution > strong::before {
	}

	.ticket {
		margin-top: 60px;
	}

	.ticket_ttl {
	}

	.ticket_ttl > span {
		font-size: 20px;
	}

	.ticket_ttl > span::before,
	.ticket_ttl > span::after {
	}

	.ticket_ttl > span::before {
	}

	.ticket_ttl > span::after {
	}

	.ticket_card {
	flex-direction: column;
	}

	.ticket_card_ttl {
		width: 100%;
		padding: 10px;
	}

	.ticket_card_ttl > span {
		font-size: 20px;
		transform: none;
		writing-mode: horizontal-tb;
	}

	.ticket_card_main {
		padding: 40px 24px;
	}

	.ticket_card_cnt {
	}

	.ticket_card_name {
		flex-wrap: wrap;
		gap: 15px 20px;
	}

	.ticket_card_name > span {
		font-size: 30px;
	}

	.ticket_card_name > span.icon-pearlv {
	}

	.ticket_card_name > span.icon-lasora {
	}

	.ticket_card_name > strong {
		width: 100%;
		padding-left: 0;
		font-size: 20px;
	}

	.ticket_card_name > strong::before {
		display: none;
	}

	.ticket_card_off {
	}

	.ticket_card_caution {
		font-size: 14px;
	}

	.ticket_card_caution > li {
	}

	.ticket_card_caution > li:first-child {
	}

	.other {
		margin-top: 40px;
		padding: 40px 24px;
	}

	.other_ttl {
		font-size: 20px;
		word-break: auto-phrase;
	}

	.other_link {
		flex-direction: column;
		gap: 10px;
	}
}
