.plan-option__title {
	font-size: 35px;
}

.plan_campaign {
	max-width: 463px;
	margin-left: auto;
	margin-right: auto;
}

.plan_campaign.blank,
.plan_campaign.blue {
	max-width: 395px;
}

.plan_campaign.blank .button::after,
.plan_campaign.blank .button::before {
	display: none;
}

.plan_campaign.blank .button__label {
	position: relative;
}

.plan_campaign.blank .button__label::after {
	position: relative;
	content: "";
	right: -5px;
	background-image: url(/assets/img/campaign/icon_blank_l.png);
	width: 21px;
	height: 21px;
	background-size: contain;
	display: inline-block;
}

.button {
	padding: 21px 45px;
}

.blue .button {
	background-color: #1da1f2;
}

.button__label {
	font-size: 22px;
}

.fixed {
	position: fixed;
	width: 100%;
}

.hide-pc {
	display: none;
}

.hide-sp {
	display: block;
}

.w-half {
	width: 50%;
}

.pointer {
	cursor: pointer;
}

.hover {
	transition: opacity .3s ease;
}

.hover:hover {
	opacity: .7
}

.pl-60 {
	padding-left: 60px;
}

.pr-60 {
	padding-right: 60px;
}

.campaign_text {
	font-size: 16px;
	line-height: 1.85;
}

.detail_table {
	font-size: 16px;
	text-align: left;
	line-height: 1;
}

.detail_table th {
	padding: 2px 0;
	font-weight: bold;
	vertical-align: top;
	white-space: nowrap;
}

.detail_table th div {
	padding-right: 25px;
	border-right: 1px solid #c4c4c4;
}

.detail_table td {
	padding: 2px 0 2px 25px;
	line-height: 20px;
}

.detail_table tr:first-of-type td {
	color: #d00f31;
}

.detail_pb {
	padding-bottom: 15px;
}

.accordion {
	width: 100%;
	border: 1px solid #d00f31;
}

.accordion_header {
	text-align: center;
	font-size: 20px;
	line-height: 58px;
	color: #d00f31;
	cursor: pointer;
	position: relative;
}

.accordion_header::after {
	position: absolute;
	display: inline-block;
	content: '＋';
	width: 28px;
	height: 28px;
	line-height: 28px;
	font-size: 26px;
	text-align: center;
	background-color: #d00f31;
	color: #fff;
	top: 15px;
	right: 15px;
}

.hide_accordion {
	display: none;
}

.accordion_close_mark {
	position: relative;
	width: 28px;
	height: 28px;
	margin: 15px 15px 0 auto;
	cursor: pointer;
}

.accordion_close_mark::after {
	position: relative;
	display: inline-block;
	content: 'ー';
	width: 28px;
	height: 28px;
	line-height: 30px;
	font-size: 22px;
	text-align: center;
	background-color: #bababa;
	color: #fff;
}

.accordion_contents {
	margin: 0 100px;
}

.accordion_contents_text {
	font-size: 16px;
	line-height: 1.7;
}

.accordion_contents_text .note {
	font-size: 14px;
}

.accordion_contents_ul {
	font-size: 16px;
	line-height: 1.9;
}

.accordion_contents_ul li {
	padding-left: 16px;
	position: relative;
}

.accordion_contents_ul li::before {
	position: absolute;
	content: "・";
	left: 0;
}

.accordion_contents_ul a {
	color: #d00f31;
	text-decoration: underline;
}

.accordion_close {
	width: 70px;
	font-size: 15px;
	text-align: right;
	margin-left: auto;
	margin-right: auto;
	cursor: pointer;
	position: relative;
}

.accordion_close::before {
	position: relative;
	display: inline-block;
	content: 'ー';
	width: 16px;
	height: 16px;
	line-height: 16px;
	font-size: 12px;
	text-align: center;
	background-color: #bababa;
	color: #fff;
	left: -3px;
}

.gray_area {
	align-items: center;
	background-color: #f3f3f3;
	padding: 24px 40px;
	font-size: 16px;
	line-height: 1.7;
}

.gray_area_img {
	width: 223px;
	height: 198px;
}

.gray_area_text {
	padding-left: 40px;
	flex: 1;
}

.gray_area_text .plan_campaign {
	margin-left: 0;
}

.gray_area_text .plan_campaign .button {
	padding: 19px 45px;
}

/* モーダルここから */
.modal {
	display: none;
	min-height: 100vh;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 1000;
}

.modal_bg {
	background: #0008;
	min-height: 100vh;
	position: absolute;
	width: 100%;
}

.modal_content {
	width: 970px;
	background: #fff;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	padding: 15px;
}

.modal_close_mark {
	display: inline-block;
	font-size: 39px;
	color: #fff;
	position: absolute;
	top: -47px;
	right: -9px;
	cursor: pointer;
	transform: rotate(-45deg);
}

.modal_border {
	width: 100%;
	height: 100%;
	padding: 4px;
	background: rgb(229, 163, 40);
	background: linear-gradient(90deg, rgba(229, 163, 40, 1) 0%, rgba(255, 228, 103, 1) 20%, rgba(253, 223, 98, 1) 80%, rgba(229, 163, 40, 1) 100%);
}

.modal_question_area {
	width: 100%;
	height: 100%;
	background-color: #fff;
	position: relative;
}

.modal_question_header {
	width: 400px;
	background-color: #fddf62;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	color: #9e6b00;
	padding: 1px 0 5px;
	border-radius: 0 0 10px 10px;
	display: inline-flex;
	justify-content: center;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	top: -1px;
}

.result.result_lost,
.result.result_right,
.question.no4,
.question.no3,
.question.no2 {
	display: none;
}

.question_text_flex {
	display: flex;
	justify-content: center;
	max-width: 690px;
	margin: 0 auto;
}

.question_number {
	width: 65px;
	min-width: 65px;
	height: 65px;
	line-height: 63px;
	text-align: center;
	background-color: #fff8d5;
	font-size: 28px;
	font-weight: bold;
	color: #d49000;
	border-radius: 50%;
}

.question.no1 .question_number {
	padding-left: 5px;
}

.question_text {
	font-size: 22px;
	font-weight: bold;
	padding-top: 17px;
}

.answer_flex {
	display: flex;
	justify-content: center;
}

.answer_select {
	overflow: hidden;
	position: relative;
	flex: 1;
	max-width: 320px;
	max-height: 85px;
	margin: 0 25px;
}

input {
	width: 100%;
	height: 85px;
}

label {
	position: absolute;
	top: 0;
	left: 0;
	color: #b6b6b6;
	width: 100%;
	height: 100%;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
	border: 1px solid #000;
	border-radius: 10px;
	font-size: 30px;
	font-weight: bold;
	color: #000;
	padding: 0 10px 0 80px;
}

label::before {
	position: absolute;
	display: inline-block;
	content: "A";
	width: 46px;
	line-height: 46px;
	background-color: #000;
	font-size: 32px;
	font-weight: bold;
	color: #fff;
	text-align: center;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	left: 25px;
	z-index: 1;
}

.answer_flex .answer_select:last-of-type label:before {
	content: "B";
}

label .en {
	font-size: 22px;
	padding: 3px 0 0 5px;
}

input:checked + label {
	background: #ffecec;
	color: #d40e2f;
	border: 3px solid #d40e2f;
}

input:checked + label::before {
	background-color: #d40e2f;
	left: 23px;
}

.result_button,
.answer_button {
	width: 350px;
	line-height: 70px;
	background-color: #d0d0d0;
	text-align: center;
	font-size: 26px;
	font-weight: bold;
	color: #fff;
	margin: 0 auto;
	position: relative;
	display: block;
}

.result_right .result_button {
	width: 410px;
}

.result_button::after,
.answer_button::after {
	position: absolute;
	content: "";
	display: inline-block;
	background-size: contain;
	background-image: url(/assets/img/campaign/answer_button_arrow.png);
	width: 16px;
	height: 26px;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	right: 20px;
}

.result_button.checked,
.answer_button.checked {
	background-color: #d40e2f;
	cursor: pointer;
}

.result_header {
	font-size: 16px;
	color: #000;
	font-weight: bold;
	text-align: center;
}

.result_header span {
	font-size: 22px;
	color: #d40e2f;
}

.result_lost4,
.result_lost3,
.result_lost2,
.result_lost1 {
	position: relative;
}

.result_lost4::before,
.result_lost3::before,
.result_lost2::before,
.result_lost1::before {
	position: relative;
	font-size: 22px;
	color: #d40e2f;
}

.result_lost1::before {
	content: "A";
}

.result_lost2::before {
	content: "A";
}

.result_lost3::before {
	content: "A";
}

.result_lost4::before {
	content: "B";
}

.result_text {
	max-width: 690px;
	font-size: 16px;
	line-height: 1.7;
}

#result_lost_text4,
#result_lost_text3,
#result_lost_text2,
#result_lost_text1 {
	display: none;
}

.result_right .result_text {
	width: 395px;
}

/* モーダルここまで */


@media only screen and (max-width: 767px) {
	.plan-option__title {
		font-size: 20px;
	}

	.button__label {
		font-size: 16px;
	}

	.button {
		padding: 19px 0;
	}

	.gray_area_text .plan_campaign .button {
		padding: 16px 0;
	}

	.plan_campaign.blank .button__label::after {
		width: 17px;
		height: 17px;
	}

	.hide-pc {
		display: block;
	}

	.hide-sp {
		display: none;
	}

	.w-full-sp {
		width: 100%;
	}

	.px-30-sp {
		padding-left: 15px;
		padding-right: 15px;
	}

	.px-70-sp {
		padding-left: 35px;
		padding-right: 35px;
	}

	.px-90-sp {
		padding-left: 45px;
		padding-right: 45px;
	}

	.pl-0-sp {
		padding-left: 0;
	}

	.pr-0-sp {
		padding-right: 0;
	}

	.pr-40-sp {
		padding-right: 20px;
	}

	.mx-60-sp {
		margin-left: 30px;
		margin-right: 30px;
	}

	.mx-60-sp {
		margin-left: 30px;
		margin-right: 30px;
	}

	.mv {
		margin-top: 0;
	}

	.campaign_text {
		font-size: 13px;
	}

	.detail_table {
		font-size: 14px;
		line-height: 1.3;
		letter-spacing: -0.6px;
	}

	.detail_table th {
		text-align: right;
	}

	.detail_table th div {
		padding-right: 10px;
	}

	.detail_table td {
		padding-left: 10px;
	}

	.detail_pb {
		padding-bottom: 9px;
	}

	.accordion {
		border: 2px solid #d00f31;
		padding: 10px 0;
	}

	.accordion_header {
		font-size: 14px;
		line-height: 1.6;
		padding: 6px 0;
	}

	.accordion_header::after {
		width: 20px;
		height: 20px;
		line-height: 20px;
		font-size: 20px;
		top: 18px;
		right: 10px;
	}

	.accordion_close_mark {
		width: 20px;
		height: 20px;
		margin: 18px 10px 0 auto;
	}

	.accordion_close_mark::after {
		width: 20px;
		height: 20px;
		line-height: 22px;
		font-size: 18px;
	}

	.accordion_contents {
		margin: 0 15px;
	}

	.accordion_contents_ul,
	.accordion_contents_text {
		font-size: 11px;
		line-height: 20px;
	}

	.accordion_contents_text .note {
		font-size: 10px;
	}

	.accordion_contents_ul li {
		padding-left: 10px;
	}

	.accordion_close {
		width: 60px;
		font-size: 12px;
	}

	.gray_area {
		padding: 30px 20px;
		font-size: 13px;
		line-height: 1.9;
	}

	.gray_area_text {
		padding-left: 0;
	}

	.gray_area_img {
		width: 100%;
		height: auto;
		padding-left: 55px;
		padding-right: 55px;
	}


	.modal {
		min-height: 100%;
	}

	.modal_content {
		width: 90%;
		min-height: auto;
		padding: 10px;
	}

	.modal_border {
		padding: 2px;
	}

	.modal_question_header {
		width: 230px;
		font-size: 10px;
		border-radius: 0 0 5px 5px;
		padding: 2px 0 3px;
	}


	.question_number {
		width: 42px;
		min-width: 42px;
		height: 42px;
		line-height: 40px;
		font-size: 18px;
	}

	.question_text {
		width: 80%;
		font-size: 15px;
		padding-top: 10px;
	}

	.answer_flex {
		flex-direction: column;
		padding: 0 40px;
	}

	.answer_select {
		width: 100%;
		max-width: none;
		max-height: 50px;
		margin: 0;
	}

	label {
		border-radius: 5px;
		font-size: 18px;
		padding: 0 10px 0 50px;
	}

	label::before {
		width: 25px;
		line-height: 25px;
		font-size: 18px;
		left: 15px;
	}

	label .en {
		font-size: 14px;
		padding: 3px 0 0 5px;
	}

	.result_button,
	.answer_button {
		width: calc(100% - 100px);
		line-height: 45px;
		font-size: 17px;
	}

	.result_button {
		width: calc(100% - 80px);
	}

	.result_right .result_button {
		width: calc(100% - 30px);
	}

	.result_button::after,
	.answer_button::after {
		width: 10px;
		height: 16px;
		right: 10px;
		background-image: url(/assets/img/campaign/answer_button_arrow-sp.png);
	}

	input:checked + label {
		border: 2px solid #d40e2f;
	}

	input:checked + label::before {
		left: 14px;
	}

	.modal_question .result {
		padding: 40px 13px 35px !important;
	}

	.result_header {
		font-size: 13px;
	}

	.result_header span {
		font-size: 18px;
	}

	.result_text {
		max-width: none;
		font-size: 13px;
		line-height: 1.8;
	}

	.result_right .result_text {
		width: 100%;
	}
}

.bg-pink {
	background-color: #ffeaef;
}

.accordion-comingsoon,
.accordion {
	border-radius: 10px;
	border: 3px solid #d00f31;
	background-color: #fff;
}

.title-2 {
	color: #0094af !important;
}

.accordion-2 {
	border: 3px solid #0094af !important;
}

.title-3 {
	color: #b97205 !important;
}

.accordion-3 {
	border: 3px solid #b97205 !important;
}

.title-4 {
	color: #1a72e3 !important;
}

.accordion-4 {
	border: 3px solid #1a72e3 !important;
}

.accordion-comingsoon {
	border-color: #ccc;
}

.accordion-comingsoon-header,
.accordion-header {
	height: 100px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	cursor: pointer;
	position: relative;
	transition: opacity .3s ease;
	font-size: 35px;
	font-weight: bold;
	color: #d00f31;
	text-align: center;
}

.accordion-comingsoon-header {
	font-size: 30px;
	color: #333;
	cursor: default;
	height: 75px;
}

.accordion-header::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 25px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	display: block;
	background-image: url(/assets/img/campaign/11th_accordion-open_finished.png);
	background-size: contain;
	width: 34px;
	height: 34px;
}

.accordion-header-3 {
	height: auto;
}

.accordion-header-4::after {
	background-image: url(/assets/img/campaign/11th_accordion-open_4.png);
}

.accordion-header-2::after,
.accordion-header-3::after {
	background-image: url(/assets/img/campaign/11th_accordion-open_finished.png);
}

.accordion-header._active::after {
	background-image: url(/assets/img/campaign/11th_accordion-close.png);
}

.accordion-contents {
	display: none;
}

.w-940 {
	width: 940px;
	margin-left: auto;
	margin-right: auto;
}

.border-t {
	border-top: 1px solid #c4c4c4;
}

.pt-35 {
	padding-top: 35px !important;
}

.pl-10 {
	padding-left: 10px;
}

.button_default {
	width: 420px;
	border: 2px solid #333;
	border-radius: 50px;
	font-size: 20px;
	color: #333;
	font-weight: bold;
	text-align: center;
	position: relative;
	display: block;
	margin-left: auto;
	margin-right: auto;
	padding: 14px 0;
	background-color: #fff;
}

.button_default::after {
	content: "";
	position: absolute;
	right: 30px;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	background-image: url(/assets/img/campaign/11th_button-arrow.png);
	background-size: contain;
	display: block;
	width: 13px;
	height: 21px;
}

.button_default[target="_blank"]::after {
	background-image: url(/assets/img/campaign/11th_button-blank.png);
	width: 20px;
	height: 20px;
}

.X-follow-button {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 5px;
	padding: 13px 0;
}

.X-follow-button::after {
	background-image: url(/assets/img/campaign/11th_button-arrow.png) !important;
}

.flex .button_default {
	margin: 0;
	width: 100%;
}

.bg-cream {
	background-color: #fffee3;
}

.area-gradation {
	padding: 3px;
	border-radius: 20px;
	background: rgb(196, 135, 28);
	background: linear-gradient(135deg, rgba(196, 135, 28, 1) 0%, rgba(174, 109, 16, 1) 10%, rgba(255, 186, 65, 1) 25%, rgba(244, 245, 123, 1) 55%, rgba(239, 163, 65, 1) 100%);
}

.gradation-contents {
	width: 100%;
	background-color: #fff;
	border-radius: 17px;
	font-size: 18px;
	font-weight: bold;
	line-height: 40px;
	color: #b97205;
	text-align: center;
	padding: 25px 0;
}

.gradation-text-flex {
	display: flex;
	gap: 50px;
}

.inline-block {
	display: inline-block;
}

.text-event {
	font-size: 16px;
	line-height: 30px;
	text-align: center;
}

.note-event {
	font-size: 14px;
	line-height: 36px;
}

.gap-40 {
	gap: 40px;
}

.whitespace-nowrap {
	white-space: nowrap;
}

.line-wide {
	margin-top: 10px;
}

.x-note {
	margin-top: 10px;
	color: #333;
}

.video-embed {
	aspect-ratio: 16 / 9;
	height: auto;
	width: 100%;
}

.button-gap {
	column-gap: 40px;
	padding-left: 30px;
	padding-right: 30px;
	justify-content: space-around;
}

.detail_table th > div,
.detail_table td > div {
	margin: 5px 0;
}

._finished {
	border-color: #b9b9b9 !important;
	padding: 30px 0;
}

._finished .accordion-header {
	color: #b9b9b9 !important;
}

._finished_text {
	color: #333;
	font-size: 24px;
	margin-top: 10px;
}

@media only screen and (max-width: 767px) {
	.page-outline {
		font-size: 14px;
	}

	.area-movietext img {
		max-width: 305px;
	}

	.px-10-sp {
		padding-left: 5px;
		padding-right: 5px;
	}

	.px-50-sp {
		padding-left: 25px;
		padding-right: 25px;
	}

	.px-60-sp {
		padding-left: 30px;
		padding-right: 30px;
	}

	.px-110-sp {
		padding-left: 55px;
		padding-right: 55px;
	}

	.w-940 {
		width: 100%;
	}

	.accordion {
		border: 2px solid #d00f31;
	}

	.accordion-comingsoon {
		border-width: 2px;
	}

	.accordion-header {
		height: 70px;
		font-size: 18px;
	}

	.accordion-comingsoon-header {
		height: 45px;
		font-size: 18px;
	}

	.accordion-header::after {
		right: 13px;
		background-image: url(/assets/img/campaign/11th_accordion-open_finished.png);
		width: 18px;
		height: 18px;
	}

	.accordion-header-2::after {
		background-image: url(/assets/img/campaign/11th_accordion-open_finished.png);
	}

	.accordion-header-3::after {
		background-image: url(/assets/img/campaign/11th_accordion-open_finished.png);
	}

	.accordion-header-4::after {
		background-image: url(/assets/img/campaign/11th_accordion-open_4.png);
	}

	.button_default {
		width: 100%;
		font-size: 15px;
		gap: 5px;
		border: 2px solid #333;
		padding: 12px 0;
	}

	.button_default::after {
		right: 15px;
		width: 10px;
		height: 15px;
	}

	.button_default[target="_blank"]::after {
		width: 15px;
		height: 15px;
	}

	.X-follow-button img {
		width: 19px;
	}

	.pl-0-sp {
		padding-left: 0;
	}

	.mb-90-sp {
		margin-bottom: 45px !important;
	}

	.text-event {
		font-size: 13px;
		line-height: 24px;
		text-align: left;
	}

	.note-event {
		font-size: 14px;
		line-height: 36px;
	}

	.area-gradation {
		border-radius: 10px;
		padding: 2px;
	}

	.gradation-contents {
		border-radius: 8px;
		font-size: 14px;
		line-height: 28px;
		padding: 13px 19px;
	}

	.gradation-text-flex {
		gap: 25px;
		text-align: left;
	}

	.gap-30-sp {
		gap: 15px;
	}

	.flex .button_default {
		width: 100%;
	}

	.margin-center-sp {
		margin-left: auto;
		margin-right: auto;
	}

	.detail_table th,
	.detail_table td {
		line-height: 20px;
	}

	.detail_table th > div,
	.detail_table td > div {
		margin: 3px 0;
	}

	.button-sp {
		display: block !important;
	}

	.button-sp > div {
		margin: 15px 0;
	}

	.button-gap {
		padding-left: 15px;
		padding-right: 15px;
	}

	.accordion-2 {
		border: 2px solid #0094af !important;
	}

	.accordion-3 {
		border: 2px solid #b97205 !important;
	}

	._finished {
		border-color: #b9b9b9 !important;
		padding: 20px 0;
	}

	._finished .accordion-header {
		color: #b9b9b9 !important;
	}

	._finished_text {
		color: #333;
		font-size: 16px;
	}
}

.text-red {
    color: #d00f31;
}

.text-left {
    text-align: left;
}

.h2-slash {
    display: inline-block;
    font-size: 30px;
    font-weight: bold;
    position: relative;
}

.h2-slash::before {
    content: "＼";
    position: absolute;
    top: 0;
    left: -50px;
    transform: rotate(15deg);
}

.h2-slash::after {
    content: "／";
    position: absolute;
    top: 0;
    right: -40px;
    transform: rotate(-15deg);
}

.h3-pink {
    font-size: 35px;
    font-weight: bold;
    color: #ff4a5b;
}

.border-pink {
    border: 3px solid #ff959f;
    border-radius: 10px;
}

.pr-40 {
    padding-right: 40px;
}

.pl-40 {
    padding-left: 40px;
}

.pt-30 {
    padding-top: 30px;
}

.pb-40 {
    padding-bottom: 40px;
}

.gap-60 {
    gap: 60px;
}

@media only screen and (max-width: 767px) {
    .h2-slash {
        font-size: 17px;
    }

    .h2-slash::before {
        left: -30px;
    }

    .h2-slash::after {
        right: -20px;
    }

    .h3-pink {
        font-size: 20px;
        line-height: 27px;
    }

    .border-pink {
        border: 1px solid #ff959f;
        border-radius: 10px;
    }

    .simtan_7th {
        max-width: 265px;
        margin-left: auto;
        margin-right: auto;
    }

    .simtan_7th_comingsoon {
        max-width: 195px;
        margin-left: auto;
        margin-right: auto;
    }

    .accordion_contents_ul {
        font-size: 13px;
        line-height: 24px;
    }

    .accordion_contents_ul li {
        padding-left: 13px;
    }

    .pl-0-sp {
        padding-left: 0;
    }

    .pr-0-sp {
        padding-right: 0;
    }

    .gap-30-sp {
        gap: 15px;
    }
}