@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;src:url(/assets/fonts/Poppins-SemiBold.woff2) format('woff2')}
@-webkit-keyframes animate-panel {
	0% {
		-webkit-transform-origin: left top;
		transform-origin: left top;
		-webkit-transform: scale(0, 1);
		transform: scale(0, 1)
	}

	49% {
		-webkit-transform-origin: left top;
		transform-origin: left top;
		-webkit-transform: scale(1, 1);
		transform: scale(1, 1)
	}

	50% {
		-webkit-transform-origin: right top;
		transform-origin: right top;
		-webkit-transform: scale(1, 1);
		transform: scale(1, 1)
	}

	100% {
		-webkit-transform-origin: right top;
		transform-origin: right top;
		-webkit-transform: scale(0, 1);
		transform: scale(0, 1)
	}
}

@keyframes animate-panel {
	0% {
		-webkit-transform-origin: left top;
		transform-origin: left top;
		-webkit-transform: scale(0, 1);
		transform: scale(0, 1)
	}

	49% {
		-webkit-transform-origin: left top;
		transform-origin: left top;
		-webkit-transform: scale(1, 1);
		transform: scale(1, 1)
	}

	50% {
		-webkit-transform-origin: right top;
		transform-origin: right top;
		-webkit-transform: scale(1, 1);
		transform: scale(1, 1)
	}

	100% {
		-webkit-transform-origin: right top;
		transform-origin: right top;
		-webkit-transform: scale(0, 1);
		transform: scale(0, 1)
	}
}

@-webkit-keyframes animate-content {
	0% {
		visibility: hidden
	}

	49% {
		visibility: hidden
	}

	50% {
		visibility: visible
	}

	100% {
		visibility: visible
	}
}

@keyframes animate-content {
	0% {
		visibility: hidden
	}

	49% {
		visibility: hidden
	}

	50% {
		visibility: visible
	}

	100% {
		visibility: visible
	}
}

@-webkit-keyframes stickyShow {
	0% {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%)
	}

	100% {
		-webkit-transform: none;
		transform: none
	}
}

@keyframes stickyShow {
	0% {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%)
	}

	100% {
		-webkit-transform: none;
		transform: none
	}
}

@-webkit-keyframes stickyHide {
	0% {
		-webkit-transform: none;
		transform: none
	}

	100% {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%)
	}
}

@keyframes stickyHide {
	0% {
		-webkit-transform: none;
		transform: none
	}

	100% {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%)
	}
}

.content {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "M+ 1p", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-weight: 400;
	font-size: 1.8rem;
	line-height: 1.7;
	max-width: none;
	color: #000;
	padding-bottom: 0;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale
}

.inner {
	max-width: 1090px;
	margin: 0 auto;
	padding: 0 20px
}

@media screen and (max-width: 768px) {
	.inner {
		padding: 0 16px
	}
}

@media screen and (min-width: 769px) {
	.content {
		padding: 0
	}
}

.localnavi p a img {
	width: 104px
}

@media screen and (max-width: 768px) {
	.localnavi {
		display: none
	}

	.content {
		padding: 0;
		line-height: 1.5;
		font-size: 1.4rem
	}

	.side-btn {
		display: none
	}
}

.grid-inner {
	width: 90.625%;
	margin: auto
}

@media screen and (min-width: 769px) {
	.grid-inner {
		width: 100%;
		padding: 0 10px;
		margin: auto;
		max-width: 1170px
	}
}

@media screen and (min-width: 769px) {
	.layout-col2-inner {
		position: relative;
		display: flex;
		width: 100%;
		padding: 0 10px;
		margin: auto;
		max-width: 1170px
	}
}

.layout-col2-contents {
	position: relative
}

@media screen and (min-width: 769px) {
	.layout-col2-contents {
		width: 744px;
		padding-right: 54px
	}
}

@media screen and (min-width: 769px) {
	.layout-col2-aside {
		width: 252px
	}
}

.layout-col2-aside-sticky {
	position: -webkit-sticky;
	position: sticky;
	top: 120px;
	z-index: 1
}

@media screen and (min-width: 769px) {
	.button-wrap {
		display: flex;
		flex-wrap: wrap;
		justify-content: center
	}
}

@media screen and (min-width: 769px) {
	.button-wrap .button-round {
		margin: 0 12px
	}
}

.button-wrap .button-round:not(:last-child) {
	margin-bottom: 5.17241%
}

@media screen and (min-width: 769px) {
	.button-wrap .button-round:not(:last-child) {
		margin-bottom: 0
	}
}

.button-round a {
	position: relative;
	width: 327px;
	margin: auto;
	display: block;
	text-align: center;
	border-radius: 35px;
	background: linear-gradient(90deg, #e4004f 0%, #921f56 100%);
	padding: 27px 37px
}

@media screen and (max-width: 768px) {
	.button-round a {
		width: 75.86207%;
		border-radius: 50px;
		padding: 18px 15px
	}
}

@media (hover: hover) {
	.button-round a {
		transition: opacity .2s ease-in-out
	}

	.button-round a:hover {
		opacity: 0.7
	}
}

.button-round a::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 7px;
	border-color: transparent transparent transparent #fff;
	position: absolute;
	right: 30px;
	top: 0;
	bottom: 0;
	margin: auto
}

@media screen and (max-width: 768px) {
	.button-round a::after {
		right: 14px;
		border-width: 4.5px 0 4.5px 6px
	}
}

.button-round a span {
	color: #fff;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1em;
	letter-spacing: 0em
}

@media screen and (max-width: 768px) {
	.button-round a span {
		font-size: 1.3rem;
		line-height: 1.07692em;
		letter-spacing: 0em
	}
}

@media (hover: hover) {
	.button-round a span {
		transition: color .2s ease-in-out
	}
}

.about {
	padding-top: 100px;
	padding-bottom: 70px
}

@media screen and (max-width: 768px) {
	.about {
		padding: 50px 0
	}
}

.about-wrap {
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	flex-direction: row-reverse;
	margin-bottom: 10px
}

@media screen and (max-width: 768px) {
	.about-wrap {
		padding: 0 15px;
	}
}

@media screen and (max-width: 768px) {
	.about-wrap {
		display: block;
		margin-bottom: 0
	}
}

.about-conts {
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto;
	text-align: center
}

@media screen and (max-width: 768px) {
	.about-conts {
		padding: 0 15px
	}
}

@media screen and (max-width: 768px) {
	.about-conts {
		margin: 0 auto;
		text-align: left
	}
}

.about-img {
	width: 41.71429%;
	max-width: 437px;
	margin-right: 13px;
	margin-top: -13px
}

@media screen and (max-width: 768px) {
	.about-img {
		width: 100%;
		max-width: 100%;
		text-align: center;
		margin-top: 0;
		margin-left: 0;
		margin-right: 0;
		margin-bottom: 20px;
	}
}

@media screen and (max-width: 768px) {
	.about-img img {
		width: 259px
	}
}

.about-heading {
	color: #1951a2;
	margin-bottom: 27px
}

@media screen and (max-width: 768px) {
	.about-heading {
		margin-bottom: 26px;
		text-align: center
	}
}

.about-heading span {
	display: block;
	text-align: center
}

.about-heading span:first-child {
	font-weight: 300;
	font-family: "Poppins", sans-serif;
	font-style: normal;
	font-size: 20px;
	letter-spacing: 0.05em;
	line-height: 1
}

.about-heading span:first-child else {
	font-weight: 500
}

@media screen and (max-width: 768px) {
	.about-heading span:first-child {
		font-size: 15px;
		margin-bottom: 10px
	}
}

.about-heading span:nth-child(2) {
	margin-top: 2px;
	font-weight: bold;
	font-size: 45px;
	letter-spacing: -0.01em;
	position: relative;
	display: inline-block;
	white-space: nowrap
}

@media screen and (max-width: 768px) {
	.about-heading span:nth-child(2) {
		font-size: 27px;
		white-space: none
	}
}

.about-heading span:nth-child(2):before {
	content: "";
	height: 3px;
	width: 100%;
	position: absolute;
	left: 0;
	bottom: 0px;
	background-color: #1951a2;
	margin-bottom: 6px
}

@media screen and (max-width: 768px) {
	.about-heading span:nth-child(2):before {
		height: 2px;
		bottom: -2px
	}
}

.about-lead {
	margin-bottom: 30px;
	margin-left: 50px;
	width: 50%;
}

@media screen and (max-width: 768px) {
	.about-lead {
		font-size: 16px;
		text-align: center;
		line-height: 1.5;
		margin-left: 0;
		margin-bottom: 19px;
		width: 100%;
	}
}

.about-lead span {
	color: #1951a2;
	font-weight: bold;
	font-family: "Poppins", sans-serif;
	font-style: normal
}

.about-lead span else {
	font-weight: 500
}

.about-lead sup {
	font-size: 50%;
	vertical-align: top
}

.about-lead-underline {
	font-weight: bold;
	font-size: 38px;
	font-weight: bold;
	line-height: 1.47368;
	display: inline;
	position: relative
}

.about-lead-underline span {
	font-size: 45px;
	letter-spacing: 0.02em
}

@media screen and (max-width: 768px) {
	.about-lead-underline span {
		font-size: 28px
	}
}

.about-lead-underline sup {
	font-size: 35%;
	-webkit-transform: translate(-4px, 8px);
	transform: translate(-4px, 8px);
	display: inline-block
}

@media screen and (max-width: 768px) {
	.about-lead-underline {
		font-size: 24px;
		text-align: center;
		line-height: 1.53333;
		margin-bottom: 19px
	}
}

.about-lead-underline:after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	background-color: #1951a2;
	height: 3px;
	margin-bottom: -1px
}

.about-sublead {
	font-size: 27px;
	font-weight: bold;
	letter-spacing: 0.02em;
	line-height: 1.59259;
	margin: 5px 0 30px
}

@media screen and (max-width: 768px) {
	.about-sublead {
		font-size: 16px
	}
}

.about-desc {
	font-size: 18px;
	line-height: 1.8125;
	letter-spacing: 0;
	margin-bottom: 107px;
	font-weight: 400
}

@media screen and (max-width: 768px) {
	.about-desc {
		font-size: 13px;
		line-height: 1.69231;
		margin-bottom: 19px
	}
}

.about-desc span {
	font-weight: bold;
	color: #1951a2
}

@media screen and (max-width: 768px) {
	.about-desc span {
		font-size: 13px
	}
}

.about-desc span sup {
	font-size: 50%;
	vertical-align: top
}

.about-note {
	font-size: 11px;
	text-align: left;
	line-height: 1.72727;
	letter-spacing: 0;
	color: #111111
}

@media screen and (max-width: 768px) {
	.about-note {
		font-size: 10px;
		margin-bottom: 0
	}
}

.case {
	padding-top: 110px;
	padding-bottom: 160px;
	background: #f1f4f8
}

@media screen and (max-width: 768px) {
	.case {
		padding: 50px 0 75px
	}
}

.case-wrap {
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto;
	padding: 0
}

@media screen and (max-width: 768px) {
	.case-wrap {
		padding: 0 15px
	}
}

.case-conts {
	width: 100%;
	text-align: center
}

@media screen and (max-width: 768px) {
	.case-conts {
		margin: 0 auto;
		text-align: left
	}
}

.case-heading {
	font-size: 32px;
	font-weight: bold;
	line-height: 1.78125;
	letter-spacing: -0.01em;
	margin-bottom: 50px
}

.case-heading span {
	font-weight: bold;
	color: #1951a2
}

@media screen and (max-width: 768px) {
	.case-heading {
		text-align: center;
		font-size: 18px;
		margin-bottom: 25px
	}
}

.case-list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 56px
}

@media screen and (max-width: 768px) {
	.case-list {
		margin-bottom: 50px
	}
}

.case-item {
	color: #ffffff;
	overflow: hidden;
	margin: .08696%;
	position: relative;
	width: 15.21739%
}

@media screen and (max-width: 768px) {
	.case-item {
		width: 32.75862%;
		margin: .17241%
	}
}

@media screen and (max-width: 768px) {
	.case-btn {
		text-align: center
	}
}

.case-btn a {
	color: #1951a2;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 0;
	padding: 23px 80px 23px 80px;
	border-radius: 40px;
	border: 2px solid #1951a2;
	position: relative;
	transition: all ease-in-out .3s
}

@media screen and (max-width: 768px) {
	.case-btn a {
		font-size: 13px;
		padding: 15px 85px;
		margin: 0 auto
	}
}

.case-btn a:hover {
	background: #1951a2;
	color: #ffffff
}

.case-btn a:hover:before {
	border-color: transparent transparent transparent #ffffff
}

.case-btn a:before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 8px;
	border-color: transparent transparent transparent #1951a2;
	position: absolute;
	display: block;
	right: 26px;
	top: 50%;
	margin-top: -5px;
	transition: all ease-in-out 0.3s
}

@media screen and (max-width: 768px) {
	.case-btn a:before {
		right: 10px;
		margin-top: -4px
	}
}

.info {
	padding: 70px 0;
	background-image: url(../img/info-bg.jpg);
	background-size: cover
}

@media screen and (max-width: 768px) {
	.info {
		padding: 50px 0
	}
}

.info-inner {
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto
}

@media screen and (max-width: 768px) {
	.info-inner {
		padding: 0 15px
	}
}

@media screen and (max-width: 768px) {
	.info-inner {
		padding: 0px 30px 0px 30px
	}
}

.info-conts {
	display: flex;
	justify-content: space-between;
	max-width: 950px;
	margin: 0 auto
}

@media screen and (max-width: 768px) {
	.info-conts {
		display: block
	}
}

.info-conts__item {
	width: 48.42105%;
	padding: 40px 0 50px;
	background-color: #fff;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	border-radius: 10px
}

@media screen and (max-width: 768px) {
	.info-conts__item {
		width: 100%;
		display: block;
		margin-bottom: 20px;
		padding: 20px
	}
}

.info-conts__item .icon {
	text-align: center;
	width: 100%
}

.info-conts__item .icon img {
	height: 53px
}

@media screen and (max-width: 768px) {
	.info-conts__item .icon img {
		height: 40px
	}
}

.info-conts__item .text {
	font-size: 24px;
	text-align: center;
	padding: 32px 0;
	width: 100%
}

@media screen and (max-width: 768px) {
	.info-conts__item .text {
		font-size: 16px;
		padding: 20px 0
	}
}

.info-conts__item .btn {
	width: 325px;
	height: 70px;
	height: 50px;
	width: 275px
}

@media screen and (max-width: 768px) {
	.info-conts__item .btn {
		width: 220px;
		height: 50px
	}
}

.info-conts__item .btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	position: relative;
	background-color: #f5b431;
	border-radius: 36px
}

@media screen and (max-width: 768px) {
	.info-conts__item .btn a {
		border-radius: 25px
	}
}

.info-conts__item .btn a:hover {
	opacity: 0.6;
	transition: all 0.3s
}

.info-conts__item .btn a:before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 8px;
	border-color: transparent transparent transparent #ffffff;
	position: absolute;
	display: block;
	right: 26px;
	top: 50%;
	margin-top: -4px
}

@media screen and (max-width: 768px) {
	.info-conts__item .btn a:before {
		border-width: 3.5px 0 3.5px 5px;
		right: 15px;
		margin-top: -2px
	}
}

.info-conts__item .btn a span {
	line-height: 1;
	color: #fff;
	font-size: 16px;
	font-weight: bold;
	margin-top: -1px
}

@media screen and (max-width: 768px) {
	.info-conts__item .btn a span {
		font-size: 13px
	}
}

.info-conts__item .btn a span {
	font-size: 15px;
	letter-spacing: -0.01em
}

.info-conts__item .btn a:before {
	right: 20px
}

@media screen and (max-width: 768px) {
	.info-conts__item .btn {
		width: 185px;
		height: 30px;
		margin: 0 auto
	}

	.info-conts__item .btn a {
		margin: 0 auto
	}

	.info-conts__item .btn a span {
		font-size: 11px
	}
}

.link {
	padding-top: 158px;
	padding-bottom: 100px
}

@media screen and (max-width: 768px) {
	.link {
		padding: 50px 0 0
	}
}

.link-wrap {
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto;
	padding: 0
}

@media screen and (max-width: 768px) {
	.link-wrap {
		padding: 0 15px
	}
}

.link-conts {
	width: 100%;
	text-align: center
}

@media screen and (max-width: 768px) {
	.link-conts {
		margin: 0 auto;
		text-align: left
	}
}

.svf .link-list {
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	margin-bottom: 56px;
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto
}

@media screen and (max-width: 768px) {
	.svf .link-list {
		padding: 0 15px
	}
}

@media screen and (max-width: 768px) {
	.svf .link-list {
		display: block
	}
}

.link-item {
	color: #ffffff;
	position: relative;
	width: 31%;
	text-align: left
}

@media screen and (max-width: 768px) {
	.link-item {
		margin: 0 auto 40px;
		width: 100%
	}
}

.link-item:nth-of-type(1) {
	margin-right: 4%
}

.link-item:nth-of-type(1) .link-item-lead:before {
	content: '';
	background-image: url(../img/link-icon01.png);
	width: 34px;
	height: 34px;
	margin-top: -49px;
	margin-left: 2px
}

@media screen and (max-width: 768px) {
	.link-item:nth-of-type(1) .link-item-lead:before {
		margin-top: 0;
		width: 26px;
		width: 26px;
		margin-top: 6px
	}
}

.link-item:nth-of-type(2) {
	width: 30%;
	margin-right: 5%
}

@media screen and (max-width: 768px) {
	.link-item:nth-of-type(2) {
		width: 100%
	}
}

.link-item:nth-of-type(2) .link-item-lead:before {
	content: '';
	background-image: url(../img/link-icon02.png);
	width: 31px;
	height: 42px;
	margin-top: -59px;
	margin-left: 1px
}

@media screen and (max-width: 768px) {
	.link-item:nth-of-type(2) .link-item-lead:before {
		margin-top: 0;
		width: 28px;
		height: 40px;
		margin-top: 0px
	}
}

.link-item:nth-of-type(3) {
	width: 30%;
	margin-right: 0
}

@media screen and (max-width: 768px) {
	.link-item:nth-of-type(3) {
		width: 100%
	}
}

.link-item:nth-of-type(3) .link-item-lead:before {
	content: '';
	background-image: url(../img/link-icon03.png);
	width: 36px;
	height: 37px;
	margin-top: -55px;
	margin-left: 1px
}

@media screen and (max-width: 768px) {
	.link-item:nth-of-type(3) .link-item-lead:before {
		margin-top: 0;
		width: 27px;
		height: 28px;
		margin-top: 6px
	}
}

.link-item-lead {
	position: relative;
	font-size: 15px;
	letter-spacing: 0;
	color: #1951a2;
	text-align: left;
	line-height: 1.4
}

.link-item-lead:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	background-size: 100%;
	background-repeat: no-repeat
}

@media screen and (max-width: 768px) {
	.link-item-lead {
		padding-left: 40px;
		font-size: 10px
	}
}

.link-item-title {
	font-size: 21px;
	font-weight: bold;
	letter-spacing: -0.02em;
	color: #1951a2;
	text-align: left;
	margin-bottom: 7px
}

@media screen and (max-width: 768px) {
	.link-item-title {
		padding-left: 40px;
		font-size: 16px
	}
}

.link-item-text {
	font-size: 16px;
	letter-spacing: 0;
	line-height: 2.6875;
	border-bottom: 1px solid #ebebeb;
	padding-bottom: 0px;
	margin-bottom: 0px;
	position: relative;
	transition: opacity ease-in-out .3s
}

@media screen and (max-width: 768px) {
	.link-item-text {
		font-size: 13px
	}
}

.link-item-text:hover {
	opacity: .7
}

.link-item-text a {
	font-weight: 500;
	width: 100%;
	display: block
}

.link-item-text a:before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 8px;
	border-color: transparent transparent transparent #1951a2;
	position: absolute;
	display: block;
	right: 8px;
	top: 50%;
	margin-top: -3px;
	transition: all ease-in-out 0.3s
}

@media screen and (max-width: 768px) {
	.link-item-text a:before {
		right: 10px;
		margin-top: -4px
	}
}

.mainvis {
	overflow: hidden;
	position: relative;
	background-color: #0a357a;
	padding-bottom: 70px
}

.mainvis:before {
	content: "";
	width: 588px;
	height: 617px;
	display: block;
	position: absolute;
	left: 0%;
	background-image: url(../img/mainvis-bg.png);
	background-repeat: no-repeat;
	background-size: contain;
	z-index: 0;
	top: -136px;
	left: 0px
}

@media screen and (max-width: 768px) {
	.mainvis:before {
		max-width: 1150px;
		box-sizing: border-box;
		padding: 0 50px;
		margin: 0 auto;
		height: 312.5px;
		top: 40px;
		left: 0;
		background-image: url(../img/mainvis-bg-sp.png)
	}
}

@media screen and (max-width: 768px) and (max-width: 768px) {
	.mainvis:before {
		padding: 0 15px
	}
}

@media screen and (min-width: 769px) {
	.mainvis {
		min-height: 550px
	}
}

@media screen and (max-width: 768px) {
	.mainvis {
		height: 580px;
		padding-top: 0;
		padding-bottom: 50px
	}
}

.mainvis-inner {
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 0 auto;
	position: relative;
	max-width: 1250px
}

@media screen and (max-width: 768px) {
	.mainvis-inner {
		padding: 0 15px
	}
}

.mainvis-conts {
	padding-top: 158px;
	margin-left: 83px;
	position: relative
}

@media screen and (max-width: 1000px) {
	.mainvis-conts {
		width: auto;
		margin: 0 auto;
		padding-top: 60px
	}
}

@media screen and (max-width: 768px) {
	.mainvis-conts {
		padding-top: 39px;
		display: inline-block
	}
}

.mainvis-conts.has-cta {
	padding-top: 65px;
}

.mainvis-lead {
	font-size: 30px;
	line-height: 1.366;
	letter-spacing: 0.03em;
	font-weight: bold;
	color: #fff;
	margin-bottom: 35px;
	position: relative;
	text-align: center
}

@media screen and (max-width: 768px) {
	.mainvis-lead {
		font-size: 20px;
		line-height: 1.5;
		letter-spacing: 0;
		margin-bottom: 25px
	}
}

.mainvis-lead:after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 108%;
	height: 3px;
	background: #ffffff;
	margin-bottom: -14px;
	margin-left: -3%
}

.mainvis-lead span {
	position: relative;
	display: inline-block
}

.mainvis-lead span:before {
	content: "";
	position: absolute;
	height: 3px;
	width: 100%;
	display: block;
	bottom: -2px;
	background-color: #fff
}

@media screen and (max-width: 768px) {
	.mainvis-lead span:before {
		height: 2px;
		bottom: 0px
	}
}

.mainvis-sublead {
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0.01em;
	color: #ffffff;
	text-align: center;
	margin-bottom: 35px
}

@media screen and (max-width: 768px) {
	.mainvis-sublead {
		font-size: 16px;
		line-height: 1.5;
		letter-spacing: 0;
		margin-bottom: 25px
	}
}

.mainvis-title {
	position: relative;
	width: 207px;
	margin: 0 auto
}

@media screen and (max-width: 1000px) {
	.mainvis-title {
		text-align: center
	}
}

@media screen and (max-width: 768px) {
	.mainvis-title img {
		width: 117.5px
	}
}

.mainvis-cta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	margin-top: 20px;
}

.mainvis-cta a {
	color: #193678;
	width: 217px;
	font-size: 14px;
	font-weight: bold;
	display: block;
	border-radius: 38px;
	text-align: center;
    padding: 11px;
	transition: 0.3s opacity;
}

.mainvis-cta a:hover {
	opacity: 0.7;
}

.mainvis-cta a.btn-yellow {
	background: #F4B331;
}

.mainvis-cta a.btn-white {
	background: #fff;
}

.mainvis-img {
	padding-top: 138px;
	width: 59.56522%;
	margin-right: .08696%;
	position: relative
}

@media screen and (max-width: 1000px) {
	.mainvis-img {
		width: 100%;
		text-align: center;
		margin-right: 0;
		padding-top: 40px
	}

	.mainvis-img img {
		width: 50%
	}
}

@media screen and (max-width: 768px) {
	.mainvis-img {
		width: 100%;
		padding-top: 45px;
		text-align: center
	}

	.mainvis-img img {
		width: 266px
	}
}

.news {
	padding-top: 100px;
	padding-bottom: 100px;
	background: #f1f4f8
}

@media screen and (max-width: 768px) {
	.news {
		padding: 50px 0
	}
}

.news-conts {
	width: 100%;
	text-align: center
}

@media screen and (max-width: 768px) {
	.news-conts {
		margin: 0 auto;
		text-align: left
	}
}

.news-wrap {
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto;
	padding: 0;
	display: flex;
	justify-content: center;
	align-items: center
}

@media screen and (max-width: 768px) {
	.news-wrap {
		padding: 0 15px
	}
}

@media screen and (max-width: 768px) {
	.news-wrap {
		display: block
	}
}

.news-title {
	margin-right: 80px
}

@media screen and (max-width: 768px) {
	.news-title {
		margin: 0 auto 40px
	}
}

.news-heading {
	font-family: "Poppins", sans-serif;
	font-style: normal;
	font-size: 46px;
	font-weight: bold;
	color: #1951a2;
	text-align: left;
	line-height: 1;
	letter-spacing: 0.07em
}

.news-heading else {
	font-weight: 500
}

@media screen and (max-width: 768px) {
	.news-heading {
		font-size: 30px;
		text-align: center
	}
}

.news-subheading {
	font-size: 17px;
	letter-spacing: 0.07em;
	color: #1951a2;
	text-align: left
}

@media screen and (max-width: 768px) {
	.news-subheading {
		font-size: 13px;
		text-align: center
	}
}

.news-list {
	width: 72.17391%
}

@media screen and (max-width: 768px) {
	.news-list {
		width: 100%
	}
}

.news-item {
	position: relative;
	text-align: left;
	padding: 25px 40px;
	background: #ffffff;
	margin-bottom: 4px
}

@media screen and (max-width: 768px) {
	.news-item {
		margin: 0 auto 4px;
		width: 100%;
		padding: 25px 30px
	}
}

.news-item span {
	font-family: "Poppins", sans-serif;
	font-style: normal;
	color: #1951a2;
	opacity: .7;
	margin-right: 25px;
	font-size: 16px
}

.news-item span else {
	font-weight: 500
}

@media screen and (max-width: 768px) {
	.news-item span {
		font-size: 13px;
		display: block
	}
}

.news-item a {
	text-decoration: underline;
	font-size: 16px;
	transition: opacity ease-in-out .3s
}

@media screen and (max-width: 768px) {
	.news-item a {
		font-size: 13px;
		letter-spacing: 0;
		line-height: 1.69231
	}
}

.news-item a:hover {
	opacity: .7
}

.news-item:before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 8px;
	border-color: transparent transparent transparent #1951a2;
	position: absolute;
	display: block;
	right: 15px;
	top: 50%;
	margin-top: -6px;
	transition: all ease-in-out 0.3s
}

@media screen and (max-width: 768px) {
	.news-item:before {
		right: 10px;
		margin-top: -4px
	}
}

.point {
	padding-top: 85px;
	padding-bottom: 120px;
	background: #f1f4f8
}

@media screen and (max-width: 768px) {
	.point {
		padding: 50px 0
	}
}

.point-wrap {
	max-width: 1150px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	margin-bottom: -35px;
	-webkit-transform: translateX(-36px);
	transform: translateX(-36px)
}

@media screen and (max-width: 768px) {
	.point-wrap {
		padding: 0 15px
	}
}

.point-wrap:nth-of-type(even) {
	flex-direction: row-reverse
}

.point-wrap.wrap02 {
	margin-bottom: 0
}

@media screen and (max-width: 768px) {
	.point-wrap.wrap02 {
		margin-bottom: 20px
	}
}

@media screen and (max-width: 768px) {
	.point-wrap {
		display: block;
		margin-bottom: 20px;
		-webkit-transform: translateX(0);
		transform: translateX(0)
	}
}

.point-conts {
	width: 100%;
	text-align: center
}

@media screen and (max-width: 768px) {
	.point-conts {
		margin: 0 auto;
		text-align: left
	}
}

.point-img.img01 {
	width: 45.61905%;
	margin-right: -1.33333%
}

@media screen and (max-width: 768px) {
	.point-img.img01 {
		width: 81.25%;
		margin: 0 auto
	}
}

.point-img.img02 {
	width: 48.7619%;
	max-width: 512px;
	margin-right: -6.66667%;
	margin-top: -15px;
	margin-left: 4.7619%
}

@media screen and (max-width: 768px) {
	.point-img.img02 {
		width: 81.25%;
		margin: 0 auto
	}
}

.point-img.img03 {
	width: 45.61905%
}

@media screen and (max-width: 768px) {
	.point-img.img03 {
		width: 81.25%;
		margin: 0 auto
	}
}

.point-info {
	text-align: left;
	margin-left: 3.80952%;
	width: 48.57143%
}

@media screen and (max-width: 768px) {
	.point-info {
		margin-left: 0;
		width: 100%
	}
}

.point-info.info02 {
	margin-top: 25px;
	width: 44.66667%
}

@media screen and (max-width: 768px) {
	.point-info.info02 {
		width: 100%
	}
}

.point-info.info03 {
	margin-left: 2.85714%
}

@media screen and (max-width: 768px) {
	.point-info.info03 {
		margin-left: auto
	}
}

.point-lead {
	font-size: 32px;
	font-weight: bold;
	line-height: 1.51613;
	letter-spacing: -0.03em;
	margin-bottom: 14px
}

.point-lead span {
	font-weight: bold;
	color: #1951a2;
	background-image: linear-gradient(rgba(0, 0, 0, 0) 70%, rgba(25, 81, 162, 0.14) 70%)
}

@media screen and (max-width: 768px) {
	.point-lead {
		font-size: 20px;
		text-align: center
	}
}

.point-text {
	font-size: 16px;
	margin-bottom: 32px
}

@media screen and (max-width: 768px) {
	.point-text {
		font-size: 13px;
		margin-bottom: 20px
	}

	.point-text br {
		display: none
	}
}

.point-btn {
	width: 100%;
	margin: 0 auto
}

@media screen and (max-width: 768px) {
	.point-btn {
		text-align: center
	}
}

.point-btn.btn03 a {
	padding: 8px 32px 8px 22px
}

@media screen and (max-width: 768px) {
	.point-btn.btn03 a {
		display: inline-block;
		padding: 8px 0
	}
}

.point-btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	position: relative;
	border-radius: 34px;
	font-size: 14px;
	padding: 8px 36px 8px 34px;
	display: inline-block;
	color: #1951a2;
	border: 1px solid #1951a2;
	transition: all ease-in-out 0.3s
}

.point-btn a:before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 4px 0 4px 7px;
	border-color: transparent transparent transparent #1951a2;
	position: absolute;
	display: block;
	right: 15px;
	top: 50%;
	margin-top: -3px;
	transition: all ease-in-out 0.3s
}

.point-btn a:hover {
	color: #ffffff;
	background: #1951a2
}

.point-btn a:hover:before {
	border-color: transparent transparent transparent #ffffff
}

@media screen and (max-width: 768px) {
	.point-btn a {
		width: 260px;
		display: inline-block;
		text-align: center
	}
}

.reason {
	padding-top: 91px;
	padding-bottom: 114px
}

@media screen and (max-width: 768px) {
	.reason {
		padding: 50px 0
	}
}

.reason-wrap {
	max-width: 920px;
	box-sizing: border-box;
	padding: 0 50px;
	margin: 0 auto;
	padding: 0
}

@media screen and (max-width: 768px) {
	.reason-wrap {
		padding: 0 15px
	}
}

.reason-conts {
	width: 100%;
	text-align: center
}

@media screen and (max-width: 768px) {
	.reason-conts {
		margin: 0 auto;
		text-align: left
	}
}

.reason-heading {
	font-size: 32px;
	font-weight: bold;
	line-height: 1.78125;
	letter-spacing: -0.01em;
	margin-bottom: 40px;
}

.reason-heading span {
	font-weight: bold;
	color: #1951a2
}

@media screen and (max-width: 768px) {
	.reason-heading {
		text-align: center;
		font-size: 18px;
		margin-bottom: 25px;
	}
}

.reason-list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 40px;
	counter-reset: number 0;
}

@media screen and (max-width: 768px) {
	.reason-list {
		gap: 20px;
	}
}

.reason-item {
	position: relative;
	width: 280px;
	height: 280px;
	margin-top: calc(75px / 2);
}

@media screen and (max-width: 768px) {
	.reason-item {
		width: 250px;
		height: 250px;
	}
}

.reason-item::after {
	counter-increment: number 1;
	content: counter(number, decimal-leading-zero) " ";
	display: grid;
	place-items: center;
	width: 75px;
	height: 75px;
	color: #fff;
	font-family: "Poppins", sans-serif;
	font-size: 24px;
	background-image: url(../img/reason-bg.png);
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	position: absolute;
    top: 0;
	right: 0;
	left: 0;
	margin: auto;
    transform: translateY(-50%);
}

@media screen and (max-width: 768px) {
	.reason-item::after {
		width: 60px;
		height: 60px;
		font-size: 16px;
	}
}

.reason-item a {
	width: 100%;
	height: 100%;
	display: block;
	cursor: pointer;
	transition: 0.3s opacity;
}

.reason-item a:hover {
	opacity: 0.7;
}

.reason-item-bg,
.reason-item-bg img {
	width: 100%;
	height: 100%;
}

.reason-item-title {
	text-align: center;
}

.reason-item-title h3 {
	font-weight: bold;
	color: #fff;
	font-size: 24px;
	line-height: 1.5;
}
@media screen and (max-width: 768px) {
	.reason-item-title h3 {
		font-size: 16px;
	}
}

.reason-item-title h3 span {
	font-family: "Poppins", sans-serif;
	font-size: 32px;
	font-weight: 600;
}

@media screen and (max-width: 768px) {
	.reason-item-title h3 span {
		font-size: 18px;
	}
}

.reason-item-title img {
	height: 28px;
	width: auto;
}

.reason-item-desc {
	position: absolute;
	inset: 0;
	margin: auto;
	padding: 70px 10px 80px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.reason-item-btn {
	position: absolute;
	bottom: 34px;
	right: 0;
	left: 0;
	margin: auto;
	transition: opacity ease-in-out 0.3s
}

@media screen and (max-width: 768px) {
	.reason-item-btn {
		bottom: 30px;
		text-align: center;
	}
}

.reason-item-btn span {
	color: #ffffff;
	font-size: 13px;
	letter-spacing: -0.04em;
	padding: 5px 27px 7px 22px;
	border-radius: 30px;
	border: 1px solid #ffffff;
	position: relative;
}

@media screen and (max-width: 768px) {
	.reason-item-btn span {
		font-size: 10px;
		padding: 4px 30px 4px 20px
	}
}

.reason-item-btn span:before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 4px 0 4px 7px;
	border-color: transparent transparent transparent #ffffff;
	position: absolute;
	display: block;
	right: 10px;
	top: 45%;
	margin-top: -2px;
	transition: all ease-in-out 0.3s
}

@media screen and (min-width: 769px) {
	br.sp {
		display: inline
	}
}

@media screen and (max-width: 768px) {
	br.sp {
		display: none
	}
}

@media screen and (min-width: 769px) {
	br.sp {
		display: none
	}
}

@media screen and (max-width: 768px) {
	br.sp {
		display: inline
	}
}

/* CTA */
.cta {
	background: #193678;
	padding: 78px 0 92px;
}
@media screen and (max-width: 768px) {
	.cta {
		padding: 19px 0 25px;
	}
}
@media screen and (max-width: 768px) {
	.cta-inner {
		padding: 0 15px;
	}
}
.cta-heading {
	font-size: 32px;
	font-weight: bold;
	color: #fff;
	text-align: center;
	line-height: 1.5;
}
@media screen and (max-width: 768px) {
	.cta-heading {
		font-size: 18px;
	}
}
.cta-btn {
	display: flex;
	justify-content: center;
	margin-top: 36px;
	gap: 34px;
}
@media screen and (max-width: 768px) {
	.cta-btn {
		flex-direction: column;
		align-items: center;
		margin-top: 15px;
		gap: 10px;
	}
}
.cta-btn a {
	color: #193678;
	width: 294px;
	font-size: 20px;
	font-weight: bold;
	display: block;
	border-radius: 38px;
	text-align: center;
    padding: 13px;
	transition: 0.3s opacity;
}
@media screen and (max-width: 768px) {
	.cta-btn a {
		width: 217px;
		font-size: 14px;
	}
}
.cta-btn a:hover {
	opacity: 0.7;
}
.cta-btn a.btn-yellow {
	background: #F4B331;
}
.cta-btn a.btn-white {
	background: #fff;
}

/* hdiバナー */
.quality {
    padding-top: 90px;
	padding-left: 50px;
	padding-right: 50px;
}
@media screen and (max-width: 768px){
    .quality {
        padding-top: 30px;
		padding-left: 15px;
		padding-right: 15px;
    }
}
.quality .quality-banner {
    display: flex;
    align-items: center;
    gap: 20px 38px;
    max-width: 930px;
    width: 100%;
    padding: 40px;
    border: 1px solid #193678;
    margin-inline: auto;
}
@media screen and (max-width: 768px){
    .quality .quality-banner {
        flex-direction: column;
        max-width: none;
        padding: 20px 20px 30px;
    }
}
.quality .quality-banner-img {
    width: 220px;
}
@media screen and (max-width: 768px){
    .quality .quality-banner-img {
        width: 179px;
    }
}
.quality .quality-banner-desc {
    flex: 1;
}
.quality .quality-banner-text {
    font-size: 16px;
    letter-spacing: 0.04em;
    line-height: 1.6;
}
@media screen and (max-width: 768px){
    .quality .quality-banner-text {
        font-size: 14px;
    }
}
.quality .quality-banner-text strong {
    font-weight: bold;
}
.quality .quality-banner-text sup {
    font-size: 0.5em;
    vertical-align: text-top;
}
.quality .quality-banner-note {
    font-size: 10px;
    margin-top: 20px;
    letter-spacing: 0.04em;
    line-height: 1.3;
}
@media screen and (max-width: 768px){
    .quality .quality-banner-note {
        margin-top: 10px;
    }
}