@charset "UTF-8";

.p-content-benefit {
	border-top: 10px solid #960027;
	background-color: #e68432;
	padding-top: 0px;
	padding-bottom: 1px;
}
@media screen and (max-width: 46.875em) {
	.p-content-benefit {
		padding-top: 0px;
		padding-bottom: 40px;
	}
}

.p-benefit {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 22px;
	margin: 70px 0 29px 0;
}
@media screen and (max-width: 750px) {
	.p-benefit {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		margin: 50px 0;
	}
}

.p-benefit > div {
	width: 100%;
	max-width: 335px;
}

.p-text-main {
	font-size: 2rem;
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 2;
	text-align: center;
}
@media screen and (max-width: 46.875em) {
	.p-text-main {
		font-size: 1.6rem;
		text-align: left;
	}
}

.p-top {
	padding: 60px 0;
}
@media screen and (max-width: 46.875em) {
	.p-top {
		font-size: 6rem;
		padding: 1px 0;
	}
}

.p-top__wrapper {
	width: 100%;
	max-width: 1415px;
	margin-right: auto;
	margin-left: auto;
	padding-right: 40px;
	padding-left: 40px;
}
@media screen and (max-width: 46.875em) {
	.p-top__wrapper {
		padding-top: 60px;
		padding-right: 25px;
		padding-left: 25px;
	}
}

.p-section {
	padding: 80px 0;
}
@media screen and (max-width: 46.875em) {
	.p-section {
		padding: 0px 0px;
	}
}

.p-wrapper {
	width: 100%;
	max-width: 1415px;
	margin-right: auto;
	margin-left: auto;
	padding-right: 40px;
	padding-left: 40px;
}
@media print, screen and (min-width: 46.9375em) {
	.p-wrapper.p-wrapper-fluid-pc {
		padding-right: 0;
		padding-left: 0;
	}
}
@media screen and (max-width: 46.875em) {
	.p-wrapper {
		padding-right: 20px;
		padding-left: 20px;
		padding-top: 1px;
		padding-bottom: 30px;
	}
}
.p-wrapper.--lg {
	max-width: 1440px;
	padding-right: 60px;
	padding-left: 60px;
}
.p-wrapper.--lg.p-wrapper-fluid {
	max-width: 1320px;
}
@media screen and (max-width: 46.875em) {
	.p-wrapper.--lg {
		padding-right: 20px;
		padding-left: 20px;
	}
}
.p-wrapper.--md {
	max-width: 1360px;
}
.p-wrapper.--md.p-wrapper-fluid {
	max-width: 1120px;
}
.p-wrapper.--sm {
	max-width: 984px;
}
.p-wrapper.--sm.p-wrapper-fluid {
	max-width: 904px;
}

.p-benefit__circle {
	position: relative;
	color: #fff;
	font-size: 2rem;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
	border: 2px solid #fff;
	border-radius: 100px;
	width: 200px;
	height: 200px;
	background-color: #fff;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-negative: 0;
	flex-shrink: 0;
}
@media screen and (max-width: 46.875em) {
	.p-benefit__circle {
		width: 110px;
		height: 110px;
	}
}
@media print, screen and (min-width: 46.9375em) {
	.p-benefit__circle:hover {
		color: #fff;
		background-color: #d66a30;
	}
	.p-benefit__circle:hover .p-benefit__txt {
		-webkit-transition: all 0.3s;
		transition: all 0.3s;
		font-size: 25px;
		font-weight: 800;
		color: #fff;
	}
}

.p-benefit__txt {
	font-size: 25px;
	font-weight: 600;
	color: #d66a30;
	line-height: 1.4;
	letter-spacing: 0.1em;
	position: relative;
	text-align: center;
	margin-bottom: 8px;
	display: inline-block;
	-webkit-transition: color 0.6s ease;
	transition: color 0.6s ease;
}
@media screen and (max-width: 46.875em) {
	.p-benefit__txt {
		font-size: 17px;
	}
}

.p-benefit__circle:hover .p-benefit__txt::after {
	border-color: #fff;
}

.p-benefit-grid {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 1fr;
	grid-template-columns: 1fr;
	justify-items: center;
	gap: 30px;
}
@media screen and (max-width: 46.875em) {
	.p-benefit-grid {
		gap: 20px;
	}
}

.p-box {
	background-color: #fff;
	border-radius: 10px;
	padding: 50px 40px;
	width: 100%;
}
@media screen and (max-width: 46.875em) {
	.p-box {
		width: 100%;
		padding: 40px 20px;
	}
}

.p-box__text {
	margin-top: 25px;
	font-size: 2rem;
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 2;
	text-align: justify;
}
@media screen and (max-width: 46.875em) {
	.p-box__text {
		font-size: 1.6rem;
	}
}

.p-box__text-sub {
	margin-top: 25px;
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 2;
	text-align: justify;
}
@media screen and (max-width: 46.875em) {
	.p-box__text-sub {
		font-size: 1.3rem;
	}
}

.p-title-lv2 {
	text-align: center;
	color: #fff;
	font-weight: 700;
	font-size: 5rem;
	line-height: 1.5;
	letter-spacing: 0.05em;
}
@media screen and (max-width: 46.875em) {
	.p-title-lv2 {
		font-size: 2.8rem;
		margin-top: 40px;
		margin-bottom: 40px;
	}
}

.p-icon-arrow {
	position: absolute;
	left: 48%;
	top: 100%;
	-webkit-transform: translateX(-50%) rotate(-270deg);
	transform: translateX(-50%) rotate(-270deg);
	margin-top: 20px;
	pointer-events: none;
	-webkit-transition: color 0.3s ease;
	transition: color 0.3s ease;
}
@media screen and (max-width: 46.875em) {
	.p-icon-arrow {
		margin-top: 9px;
	}
}

.p-icon-arrow::before {
	font-family: "icomoon";
	content: "\e900";
	font-size: 24px;
	color: #d66a30;
	-webkit-transition: color 0.3s;
	transition: color 0.3s;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	line-height: 1;
	letter-spacing: 0;
	text-transform: none;
	-webkit-font-smoothing: antialiased;
	-webkit-font-feature-settings: "liga";
	font-feature-settings: "liga";
	-webkit-font-variant-ligatures: discretionary-ligatures;
}
@media screen and (max-width: 46.875em) {
	.p-icon-arrow::before {
		font-size: 20px;
	}
}

.p-benefit__circle:hover .p-icon-arrow::before {
	color: #fff;
}

.p-button.p-button__link {
	background-color: #fff;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#e68432), to(#e68432));
	background-image: linear-gradient(#e68432, #e68432);
	background-repeat: no-repeat;
	background-size: 0% 100%;
	background-position: left bottom;
	-webkit-transition: background-size 0.5s cubic-bezier(0.77, 0, 0.175, 1), color 0.3s ease;
	transition: background-size 0.5s cubic-bezier(0.77, 0, 0.175, 1), color 0.3s ease;
	max-width: 335px;
	width: 100%;
	min-height: 70px;
	border-radius: 100vh;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	border: 2px solid #fff;
	font-size: 2rem;
	color: #e68432;
	position: relative;
	font-weight: 600;
	padding: 20px 50px;
}
.p-button.p-button__link::after {
	content: "\e900";
	font-weight: normal;
	font-family: "icomoon";
	font-style: normal;
	font-variant: normal;
	line-height: 1;
	text-transform: none;
	speak: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-size: 2.5rem;
	color: #e68432;
	-webkit-transition: color 0.3s ease;
	transition: color 0.3s ease;
	position: absolute;
	top: 50%;
	right: 32px;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.p-button.p-button__link[target$=_blank]:not(.p-button.p-button__link[href$=".pdf"])::after {
	content: "\e901";
	font-size: 2rem;
}
.p-button.p-button__link.--wht::after {
	-webkit-transform: translateY(-50%) rotate(90deg);
	transform: translateY(-50%) rotate(90deg);
}
@media screen and (max-width: 46.875em) {
	.p-button.p-button__link.--wht::after {
		right: 51px;
	}
}
@media screen and (max-width: 46.875em) {
	.p-button.p-button__link.--wht {
		font-size: 1.6rem !important;
	}
	.p-button.p-button__link.--wht::after {
		font-size: 2.5rem !important;
	}
}
.p-button.p-button__link.--org {
	background-color: #e68432;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#fff));
	background-image: linear-gradient(#fff, #fff);
	color: #fff;
	border-color: #e68432;
}
.p-button.p-button__link.--org::after {
	color: #fff;
}
@media print, screen and (min-width: 46.9375em) {
	.p-button.p-button__link.--org:hover {
		color: #e68432 !important;
	}
	.p-button.p-button__link.--org:hover::after {
		color: #e68432 !important;
	}
}
@media screen and (max-width: 46.875em) {
	.p-button.p-button__link.--org {
		font-size: 1.6rem !important;
	}
	.p-button.p-button__link.--org::after {
		font-size: 1.7rem !important;
	}
}
.p-button.p-button__link.--blue {
	background-color: #00AAEB;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#fff));
	background-image: linear-gradient(#fff, #fff);
	color: #fff;
	border-color: #00AAEB;
	font-family: "Noto Sans JP", sans-serif;
}
.p-button.p-button__link.--blue::after {
	color: #fff;
}
@media print, screen and (min-width: 46.9375em) {
	.p-button.p-button__link.--blue:hover {
		color: #00AAEB !important;
	}
	.p-button.p-button__link.--blue:hover::after {
		color: #00AAEB !important;
	}
}
@media screen and (max-width: 46.875em) {
	.p-button.p-button__link.--blue {
		font-size: 1.6rem !important;
	}
	.p-button.p-button__link.--blue::after {
		font-size: 1.7rem !important;
	}
}
.p-button.p-button__link.--blk {
	background-color: #1a1a1a;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#fff));
	background-image: linear-gradient(#fff, #fff);
	color: #fff;
	border-color: #1a1a1a;
}
.p-button.p-button__link.--blk::after {
	color: #fff;
}
@media print, screen and (min-width: 46.9375em) {
	.p-button.p-button__link.--blk:hover {
		color: #1a1a1a !important;
	}
	.p-button.p-button__link.--blk:hover::after {
		color: #1a1a1a !important;
	}
}
@media screen and (max-width: 46.875em) {
	.p-button.p-button__link.--blk {
		font-size: 1.6rem !important;
	}
	.p-button.p-button__link.--blk::after {
		font-size: 1.7rem !important;
	}
}
.p-button.p-button__link.--red {
	background-color: #960027;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#fff));
	background-image: linear-gradient(#fff, #fff);
	color: #fff;
	border-color: #960027;
	font-family: "Noto Sans JP", sans-serif;
}
.p-button.p-button__link.--red::after {
	color: #fff;
}
@media print, screen and (min-width: 46.9375em) {
	.p-button.p-button__link.--red:hover {
		color: #960027 !important;
	}
	.p-button.p-button__link.--red:hover::after {
		color: #960027 !important;
	}
}
@media screen and (max-width: 46.875em) {
	.p-button.p-button__link.--red {
		font-size: 1.6rem !important;
	}
	.p-button.p-button__link.--red::after {
		font-size: 1.7rem !important;
	}
}
@media print, screen and (min-width: 46.9375em) {
	.p-button.p-button__link:hover {
		background-size: 100% 100%;
		color: #fff;
	}
	.p-button.p-button__link:hover::after {
		color: #fff;
	}
}
@media screen and (max-width: 46.875em) {
	.p-button.p-button__link {
		font-size: 1.6rem;
	}
}
.p-button.p-button__primary {
	background-color: #e68432;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#fff));
	background-image: linear-gradient(#fff, #fff);
	background-repeat: no-repeat;
	background-size: 0% 100%;
	background-position: left bottom;
	-webkit-transition: background-size 0.5s cubic-bezier(0.77, 0, 0.175, 1), color 0.3s ease;
	transition: background-size 0.5s cubic-bezier(0.77, 0, 0.175, 1), color 0.3s ease;
	max-width: 335px;
	width: 100%;
	min-height: 70px;
	border-radius: 100vh;
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	border: 2px solid #e68432;
	font-size: 2rem;
	font-weight: 700;
	color: #fff;
}
@media print, screen and (min-width: 46.9375em) {
	.p-button.p-button__primary:hover {
		background-size: 100% 100%;
		color: #e68432;
	}
}
.p-button.p-button__anchor {
	background-color: #fff;
	background-image: -webkit-gradient(linear, left top, left bottom, from(#e68432), to(#e68432));
	background-image: linear-gradient(#e68432, #e68432);
	background-repeat: no-repeat;
	background-size: 0% 100%;
	background-position: left bottom;
	-webkit-transition: background-size 0.5s cubic-bezier(0.77, 0, 0.175, 1), color 0.3s ease;
	transition: background-size 0.5s cubic-bezier(0.77, 0, 0.175, 1), color 0.3s ease;
	max-width: 335px;
	width: 100%;
	min-height: 70px;
	border-radius: 100vh;
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	border: 2px solid #fff;
	font-size: 2rem;
	color: #e68432;
	position: relative;
	font-weight: 600;
	padding: 20px 50px;
}
.p-button.p-button__anchor::after {
	content: "\e900";
	font-weight: normal;
	font-family: "icomoon";
	font-style: normal;
	font-variant: normal;
	line-height: 1;
	text-transform: none;
	speak: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-size: 2.5rem;
	color: #e68432;
	-webkit-transition: color 0.3s ease;
	transition: color 0.3s ease;
	position: absolute;
	top: 50%;
	right: 27px;
	-webkit-transform: translateY(-50%) rotate(90deg);
	transform: translateY(-50%) rotate(90deg);
}
@media print, screen and (min-width: 46.9375em) {
	.p-button.p-button__anchor:hover {
		background-size: 100% 100%;
		color: #fff;
	}
	.p-button.p-button__anchor:hover::after {
		color: #fff;
	}
}
@media screen and (max-width: 46.875em) {
	.p-button.p-button__anchor {
		font-size: 1.6rem;
	}
	.p-button.p-button__anchor::after {
		font-size: 1.8rem;
	}
}

.p-benefit__item {
	max-width: 335px;
}

.p-anchor {
	padding: 60px 0;
}