@charset "utf-8";
/* CSS Document */

/*-----------------------------------------------------------------

	top　トップ

-----------------------------------------------------------------*/


/*------------------------------------------------------------------------------
	h-top
------------------------------------------------------------------------------*/
.h-top {
		width: var(--main-width);
		margin: 0 auto 2rem;
		font-size: 3.6rem;
		font-weight: bold;
}

@media screen and (max-width: 810px) {
	.h-top {
		margin: 1rem auto 2rem;
	}
}

@media screen and (max-width: 480px) {
	.h-top {
		font-size: 3rem;
		margin-bottom: 1rem;
	}
}


/*------------------------------------------------------------------------------
	main-img
------------------------------------------------------------------------------*/
.main-img .swiper-slide {
	width: 800px;
	flex-shrink: 0;
	aspect-ratio: 800 / 520;
}

.main-img .swiper-wrapper {
	height: auto;
	margin-bottom: 6rem;
}

.main-img .main-slider-pagination {
	position: absolute;
	bottom: 3rem;
	width: 100%;
	text-align: center;
	z-index: 10;
}

.main-img .main-slider-pagination .swiper-pagination-bullet {
	width: 1rem;
	height: 1rem;
	background-color: #191919;
	border-radius: 50%;
	margin: 0 .5rem;
	display: inline-block;
	transition: all 0.4s cubic-bezier(0.25, 1, 0.5, 1);
}

.main-img .main-slider-pagination .swiper-pagination-bullet-active {
	width: 4rem;
	height: 1rem;
	background-color: var(--main-color);
	border-radius: 100px;
}


@media screen and (max-width: 810px) {
	.main-img {
		width: calc(100% + 40px);
		margin: 0 -20px;
	}

	.main-img .swiper-slide {
		width: calc(100% - 180px) !important;
		aspect-ratio: auto;
	}
}

@media screen and (max-width: 480px) {
	.main-img .swiper-slide {
		width: 100% !important;
	}
}


.main-img + .lead-text {
	max-width: 900px;
	margin: 0 auto 4rem;
}



/*------------------------------------------------------------------------------
	ranking-cont
------------------------------------------------------------------------------*/
.ranking-cont {
	padding-bottom: 4rem;
	margin-bottom: 4rem;
	border-bottom: 1px dashed #191919;
}

.container .main-contents > section:has(.ranking-cont) {
	margin-bottom: 0;
}

.ranking-cont .h-type1 {
	font-size: 2.6rem;
	padding-bottom: 1.5rem;
}

.ranking-cont .item-list {
	margin-bottom: 0;
}

.ranking-cont .item-list li {
	position: relative;
}
.ranking-cont .item-list li a:before {
	content: "";
	display: block;
	width: 5rem;
	height: 5rem;
	position: absolute;
	top: -.5rem;
	left: -.5rem;
	color: #FFF;
	font-size: 2.2rem;
	display:flex;
	justify-content: center;
	align-items: center;
	border-radius: 50%;
	z-index: 1;
}
.ranking-cont .item-list li:nth-child(1) a:before {
	content: "1";
	background:rgba(255,210,0,0.9);
}
.ranking-cont .item-list li:nth-child(2) a:before {
	content: "2";
	background:rgba(182,182,182,0.9);
}
.ranking-cont .item-list li:nth-child(3) a:before {
	content: "3";
	background:rgba(180,138,37,0.9);
}
.ranking-cont .item-list li:nth-child(4) a:before {
	content: "4";
	background:rgba(96,125,189,0.9);
}



@media screen and (max-width: 810px) {
	.ranking-cont .item-list {
		flex-flow: nowrap;
		overflow-x: scroll;
		width: calc(100% + 40px);
		margin: 0 -20px;
		padding: 10px 20px;
		box-sizing: border-box;
		gap: 4.5rem 2.5rem;
	}

	.ranking-cont .item-list > li {
		flex-shrink: 0;
		width: 200px !important;
	}
}

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

}


/*------------------------------------------------------------------------------
	select-item
------------------------------------------------------------------------------*/

.select-item {
	margin-bottom: 8rem;
}

.select-item dt {
	font-weight: bold;
	font-size: 2rem;
	margin-bottom: 2rem;
}

.select-item dd:not(:last-child) {
	margin-bottom: 3.5rem;
}

.select-item dd ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 1.5rem calc(10% / 4);
}

.select-item dd ul li {
	width: 18%;
}

.select-item dd ul li a {
	display: block;
	color: var(--main-color);
	font-weight: bold;
	font-size: 2rem;
	background: #e9eef9;
	border-radius: .7rem;
	padding: 1.7rem 2.5rem;
	text-align: center;
}

.select-item dd ul li a:hover {
	opacity: 1;
	background: #b5c9f4;
}


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

}

@media screen and (max-width: 480px) {
	.select-item {
		margin-bottom: 5rem;
	}

	.select-item dd ul {
		gap: 1.2rem 5%;
	}

	.select-item dd ul li {
		width: 30%;
	}

	.select-item dd ul li a {
		font-size: 15px;
		padding: 1.7rem 2rem;
	}
}


/*------------------------------------------------------------------------------
	pr-cont
------------------------------------------------------------------------------*/
.pr-cont .h-pr {
	font-weight: bold;
	font-size: 2.8rem;
	margin-bottom: 2rem;
}

.pr-cont .img {
	margin-bottom: 2.5rem;
}



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

}

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

}


/*------------------------------------------------------------------------------
	other-sign
------------------------------------------------------------------------------*/
.other-sign .h-other {
	font-weight: bold;
	font-size: 2.4rem;
	margin-bottom: 2rem;

}

.other-sign .h-other + p {
	margin-bottom: 4rem;
}

.other-sign .other-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 10px;
}

.other-sign .other-list li {
	width: 172px;
	text-align: center;
}

.other-sign .other-list li a {
	display: block;
}

.other-sign .other-list li span {
	font-size: 1.3rem;
	color: #2c2c2c;
	display: block;
	margin-top: 1.5rem;
}

.other-sign .other-list li a:hover {
	opacity: 1;
}

.other-sign .other-list li a:hover .img {
	background: #fffaa6;
	border-radius: 1rem;
}

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

	.other-sign .other-list li {
		width: calc((100% - 30px) / 4);
	}
}

@media screen and (max-width: 480px) {
	.other-sign .other-list li {
		width: calc((100% - 30px) / 3);
	}
}


/*------------------------------------------------------------------------------
	scene-cont
------------------------------------------------------------------------------*/
.scene-cont {
	padding: 5rem 6rem;
	background: #e9eef9;
}

.scene-cont .h-scene {
	font-weight: bold;
	color: var(--main-color);
	margin-bottom: 3rem;
	letter-spacing: .12em;
	font-size: 3.1rem;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem 3rem;
}

.scene-cont .h-scene span {
	color: #FFF;
	font-size: 1.9rem;
	display: inline-block;
	padding: 1.2rem 5rem;
	background: #0738a4;
	border-radius: 1.5rem;
	box-sizing: border-box;
}


@media screen and (max-width: 810px) {
	.scene-cont {
		padding: 4rem 3rem 3rem;
	}
}

@media screen and (max-width: 480px) {
	.scene-cont {
		padding: 4rem 2rem 2rem;
	}

	.scene-cont .h-scene {
		flex-flow: column;
		margin-bottom: 2rem;
		font-size: 2.7rem;
	}

	.scene-cont .h-scene span {
		font-size: 1.7rem;
		padding: 1rem 3rem;
	}

}



/**/
.scene-cont dl {
	border-radius: 1.5rem;
	background: #FFF;
	border: .2rem solid var(--main-color);
	border-radius: 1.5rem;
}

.scene-cont dl:not(:last-child) {
	margin-bottom: 2rem;
}

.scene-cont dl dt {
	text-align: center;
	padding: 2.5rem 3rem 2rem;
	color: var(--main-color);
	font-weight: bold;
	font-size: 2.1rem;
	letter-spacing: .14em;
	border-bottom: .2rem solid var(--main-color);
}

.scene-cont dl dd {
	display:flex;
	flex-flow: row wrap;
	justify-content: space-between;
	align-items: center;
	padding: 2.5rem 4rem 2rem 2rem;
}

.scene-cont dl dd .text {
	width: 300px;
}

.scene-cont dl dd .text p:not(:last-child) {
	margin-bottom: 5px;
}


@media screen and (max-width: 810px) {
	.scene-cont dl dd .img {
		width: 50%;
	}

	.scene-cont dl dd .text {
		width: 45%;
	}

}

@media screen and (max-width: 480px) {
	.scene-cont dl dd {
		padding: 2.5rem;
		row-gap: 15px;
	}

	.scene-cont dl dd .img,
	.scene-cont dl dd .text {
		width: 100%;
	}
}



/*------------------------------------------------------------------------------
  qa-cont
------------------------------------------------------------------------------*/
.qa-cont {
    margin-bottom: 9rem;
}

.qa-cont .qa-list dl {
    border-radius: 1rem;
    box-shadow: 0px 1px 6px 0px rgba(0, 0, 0, 0.15);
    padding: 4rem 5rem;
}

.qa-cont .qa-list dl:not(:last-child) {
    margin-bottom: 2rem;
}

.qa-cont .qa-list dl dt {
    font-weight: bold;
    font-size: 1.6rem;
    letter-spacing: .08em;
    margin-bottom: 2rem;
    line-height: 1.5;
}

.qa-cont .qa-list dl dt,
.qa-cont .qa-list dl dd {
    padding-left: 6rem;
    position: relative;
}

.qa-cont .qa-list dl dt:before,
.qa-cont .qa-list dl dd:before {
    content: "";
    width: 4rem;
    height: 4rem;
    position: absolute;
    left: 0;
    font-weight: bold;
    font-size: 1.9rem;
    display:flex;
	justify-content: center;
	align-items: center;
    border-radius: 50%;
}

.qa-cont .qa-list dl dt:before {
    content: "Q";
    background: #f5f5f5;
    color: #b2b2b2;
    top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
}

.qa-cont .qa-list dl dd:before {
    content: "A";
    background: #ff5723;
    color: #FFF;
    top: .5rem;
}

@media screen and (max-width: 480px) {
    .qa-cont .qa-list dl {
        padding: 3rem;
    }
    
    .qa-cont .qa-list dl dt {
        margin-bottom: 1rem;  
    }
}




/*------------------------------------------------------------------------------
	★
------------------------------------------------------------------------------*/

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

}

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

}


/*------------------------------------------------------------------------------
	★
------------------------------------------------------------------------------*/

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

}

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

}