@charset "Shift-JIS";


@media screen and (min-width : 960px) {

	body:not(.top) #contents{
		padding: 0 0 80px 0;
		background-image: url('../img/bg_pattern.png');
		background-repeat: repeat;
		background-position: 0 0;
		background-size: auto auto;
		overflow-x: hidden;
	}
	body:not(.top) #contents::before,
	body:not(.top) #contents::after{
		display: none;
	}


	/* -------------------------------------------------------------------------------------------
	*
	* hero
	*
	* ----------------------------------------------------------------------------------------- */
	#hero {
		padding: 36px 0 39px 0;
	}

	/* -------------------------------------------------------------------------------------------
	*
	* contents
	*
	* ----------------------------------------------------------------------------------------- */

	#contents{
		position: relative;
	}
	#contents .bg-wrap{
		overflow: hidden;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 0;
		pointer-events: none;
	}
	#contents .bg-wrap .bg-obj{
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100% auto;
		position: absolute;
		z-index: 0;
	}
	#contents .bg-wrap .bg-obj[data-num="1"]{
		width: 413px;
		height: 416px;
		background-image: url('../img/bg_graph_circle.png');
		top: 70px;
		left: -230px;
		transform: rotate(125deg);
	}
	#contents .bg-wrap .bg-obj[data-num="2"]{
		width: 453px;
		height: 272px;
		background-image: url('../img/bg_graph_line.png');
		top: 610px;
		right: -254px;
	}
	#contents .bg-wrap .bg-obj[data-num="3"]{
		width: 233px;
		height: 213px;
		background-image: url('../img/bg_square.png');
		top: 1360px;
		left: -100px;
	}
	#contents .bg-wrap .bg-obj[data-num="4"]{
		width: 413px;
		height: 416px;
		background-image: url('../img/bg_graph_circle.png');
		top: 1730px;
		right: -234px;
		transform: rotate(30deg);
	}
	#contents .bg-wrap .bg-obj[data-num="5"]{
		width: 453px;
		height: 272px;
		background-image: url('../img/bg_graph_line.png');
		top: 3280px;
		left: -290px;
	}
	#contents .bg-wrap .bg-obj[data-num="6"]{
		width: 233px;
		height: 213px;
		background-image: url('../img/bg_square.png');
		top: 4650px;
		right: -100px;
	}



	.contents-body h4{
		box-sizing: border-box;
		border-left: 1px solid var(--color-blue);
		border-bottom: 1px solid var(--color-blue);
		margin: 0 0 22px 0;
		padding: 0 18px 12px 18px;
		position: relative;
	}
	.contents-body h4::before{
		content: '';
		display: block;
		width: 2.278rem;
		height: 1.889rem;
		background-image: url('../img/icon_flag.svg');
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: contain;
		position: absolute;
		top: 2px;
		left: 18px;
	}

	.contents-body h4 span{
		color: var(--color-blue);
		font-size: 1.33rem;
		font-weight: 700;
		letter-spacing: 0.05em;
		line-height: 1.6;
		display: flex;
		align-items: center;
		gap: 0.667rem;
		padding: 0 0 0 2.947rem;
	}

	.area .area-list{
		display: flex;
		flex-wrap: wrap;
		gap: 9px;
	}

	.area .area-list li{
		width: calc((100% - 36px) / 5);
	}

	.area .area-list li a{
		background-color: #fff;
		box-sizing: border-box;
		border-radius: 100px;
		color: #087ADF;
		font-size: 1rem;
		font-weight: 700;
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 12px 15px;
	}
	.area .area-list li a:hover{
		background-color: var(--color-blue);
		color: #fff;
	}

	.area .area-list li a::after{
		content: '';
		display: block;
		width: 1.222rem;
		height: 1.222rem;
		background-image: url('../img/icon_arrow_grad.svg');
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: contain;
		transform: rotate(90deg);
	}


	/* -------------------------------------------------------------------------------------------
	*
	* rank
	*
	* ----------------------------------------------------------------------------------------- */

	.rank {
		padding: 68px 0 32px 0;
	}
	.rank h4 {
		margin: 0 0 40px 0;
	}

	.rank .rank-container {
		display: flex;
		justify-content: center;
		gap: 34px;
	}
	.rank ul.rank-list {
		display: flex;
		flex-direction: column;
		gap: 28px;
	}
	.rank ul.rank-list li {
		display: flex;
		align-items: center;
		gap: 14px;
	}
	.rank ul.rank-list li p.rank-num {
		background-color: var(--color-blue);
		border-radius: 10rem;
		color: #fff;
		font-size: 0.889rem;
		font-weight: 700;
		display: flex;
		align-items: center;
		justify-content: center;
		text-align: center;
		width: 3.167rem;
		height: 1.5rem;
	}
	.rank ul.rank-list:nth-of-type(1) li:nth-child(-n+3) p.rank-num {
		background-color: #A01500;
	}
	.rank ul.rank-list li p.rank-name {
		color: var(--color-blue);
		font-size: 0.889rem;
		font-weight: 700;
	}
	.rank ul.rank-list:nth-of-type(1) li:nth-child(-n+3) p.rank-name {
		color: #A01500;
	}
	

	.rank ul.rank-img {
		display: flex;
		justify-content: center;
		gap: 15px;
		margin: 34px 0 0 0;
	}
	.rank ul.rank-img li {
		max-width: 258px;
	}
	.rank ul.rank-img li figure {
		width: 100%;
	}
	.rank ul.rank-img li figure img {
		width: auto;
		height: 175px;
		display: block;
	}

	.rank div.rank-note {
		max-width: 850px;
		margin: 34px auto 0 auto;
	}
	.rank div.rank-note div.rank-note-wrap {
		display: flex;
		width: 100%;
	}
	.rank div.rank-note div.rank-note-wrap .rank-note-img {
		box-sizing: border-box;
		width: 278px;
		padding: 0 20px 0 0;
	}
	.rank div.rank-note div.rank-note-wrap .rank-note-text {
		font-size: 0.889rem;
		line-height: 1.6;
		letter-spacing: 0.05em;
	}
	.rank div.rank-note div.rank-note-wrap .rank-note-img + .rank-note-text {
		width: calc(100% - 278px);
	}
	.rank div.rank-note div.rank-note-wrap .rank-note-text {
		width: 100%;
	}

	.rank figure figcaption {
		font-size: 0.667rem;
		line-height: 1.4;
		letter-spacing: 0.05em;
		margin: 7px 0 0 0;
	}



	/* -------------------------------------------------------------------------------------------
	*
	* area-link
	*
	* ----------------------------------------------------------------------------------------- */

	.area-link{
		background-color: var(--color-blue);
		background-image: url('../img/bg_area-link_pc.png');
		background-repeat: no-repeat;
		background-position: center top;
		background-size: auto 100%;
		padding: 60px 0 80px 0;
		text-align: center;
	}

	.area-link p{
		color: #fff;
		font-size: 1.11rem;
		line-height: 1.6;
		letter-spacing: 0.05em;
		margin: 0 0 24px 0;
	}

	.area-link .area-list{
		display: flex;
		flex-wrap: wrap;
		gap: 9px;
		width: 625px;
		margin: 0 auto;
	}

	.area-link .area-list li{
		width: calc((100% - 18px) / 3);
	}

	.area-link .area-list li a{
		background-color: #fff;
		box-sizing: border-box;
		border: 1px solid #fff;
		border-radius: 100px;
		color: #087ADF;
		font-size: 1rem;
		font-weight: 700;
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 12px 15px;
	}
	.area-link .area-list li a:hover{
		background-color: var(--color-blue);
		color: #fff;
	}


	.area-link .area-list li a::after{
		content: '';
		display: block;
		width: 1.222rem;
		height: 1.222rem;
		background-image: url('../img/icon_arrow_grad.svg');
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: contain;
	}






}

@media screen and (max-width : 959px) {

	body:not(.top) #contents{
		padding: 0 0 12.82vw 0;
		background-image: url('../img/bg_pattern.png');
		background-repeat: repeat;
		background-position: 0 0;
		background-size: auto auto;
		overflow-x: hidden;
	}
	body:not(.top) #contents::before,
	body:not(.top) #contents::after{
		display: none;
	}

	main{
		overflow-x: hidden;
	}


	/* -------------------------------------------------------------------------------------------
	*
	* hero
	*
	* ----------------------------------------------------------------------------------------- */
	#hero {
		padding: 7.7vw 0 12.3vw 0;
		position: relative;
	}


	/* -------------------------------------------------------------------------------------------
	*
	* contents
	*
	* ----------------------------------------------------------------------------------------- */

	#contents{
		position: relative;
	}
	#contents .bg-wrap{
		overflow: hidden;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 0;
		pointer-events: none;
	}
	#contents .bg-wrap .bg-obj{
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100% auto;
		position: absolute;
		z-index: 0;
	}
	#contents .bg-wrap .bg-obj[data-num="1"]{
		width: 120vw;
		height: 120vw;
		background-image: url('../img/bg_graph_circle.png');
		top: -72vw;
		left: -66vw;
		transform: rotate(7deg);
	}
	#contents .bg-wrap .bg-obj[data-num="2"]{
		width: 88.2vw;
		height: 53.1vw;
		background-image: url('../img/bg_graph_line.png');
		top: 130vw;
		right: -47vw;
	}
	#contents .bg-wrap .bg-obj[data-num="3"]{
		width: 35.6vw;
		height: 32.8vw;
		background-image: url('../img/bg_square.png');
		top: 532vw;
		left: -18vw;
		display: none;
	}
	#contents .bg-wrap .bg-obj[data-num="4"]{
		width: 83.33vw;
		height: 83.33vw;
		background-image: url('../img/bg_graph_circle.png');
		top: 374vw;
		right: -39vw;
		display: none;
	}
	#contents .bg-wrap .bg-obj[data-num="5"]{
		width: 88.2vw;
		height: 53.1vw;
		background-image: url('../img/bg_graph_line.png');
		top: 193vw;
		left: -22vw;
		display: none;
	}
	#contents .bg-wrap .bg-obj[data-num="6"]{
		width: 35.6vw;
		height: 32.8vw;
		background-image: url('../img/bg_square.png');
		top: 532vw;
		left: -18vw;
		display: none;
	}



	.contents-body h4{
		box-sizing: border-box;
		border-left: 1px solid var(--color-blue);
		border-bottom: 1px solid var(--color-blue);
		margin: 0 0 22px 0;
		padding: 0 18px 12px 18px;
		position: relative;
	}
	.contents-body h4::before{
		content: '';
		display: block;
		width: 2.278rem;
		height: 1.889rem;
		background-image: url('../img/icon_flag.svg');
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: contain;
		position: absolute;
		top: 2px;
		left: 18px;
	}

	.contents-body h4 span{
		color: var(--color-blue);
		font-size: 1.33rem;
		font-weight: 700;
		letter-spacing: 0.05em;
		line-height: 1.6;
		display: flex;
		align-items: center;
		gap: 0.667rem;
		padding: 0 0 0 2.947rem;
	}


	.area .area-list{
		display: flex;
		flex-wrap: wrap;
		gap: 2.3vw;
	}
	.area .area-list li{
		width: calc((100% - 2.3vw) / 2);
	}

	.area .area-list li a{
		background-color: #fff;
		box-sizing: border-box;
		border-radius: 100px;
		color: #087ADF;
		font-size: 1rem;
		font-weight: 700;
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 3vw 3.85vw;
	}
	.area .area-list li a:hover{
		background-color: var(--color-blue);
		color: #fff;
	}


	.area .area-list li a::after{
		content: '';
		display: block;
		width: 1.222rem;
		height: 1.222rem;
		background-image: url('../img/icon_arrow_grad.svg');
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: contain;
		transform: rotate(90deg);
	}


	/* -------------------------------------------------------------------------------------------
	*
	* rank
	*
	* ----------------------------------------------------------------------------------------- */

	.rank {
		padding: 12.3vw 0 3vw 0;
	}
	.rank h4 {
		margin: 0 0 6.15vw 0;
	}

	.rank ul.rank-list {
		display: flex;
		flex-direction: column;
		gap: 3vw;
	}
	.rank ul.rank-list + .rank-list {
		margin: 3vw 0 0 0;
	}

	.rank ul.rank-list li {
		display: flex;
		align-items: center;
		gap: 3.6vw;
	}
	.rank ul.rank-list li p.rank-num {
		background-color: var(--color-blue);
		border-radius: 10rem;
		color: #fff;
		font-size: 0.889rem;
		font-weight: 700;
		display: flex;
		align-items: center;
		justify-content: center;
		text-align: center;
		width: 3.167rem;
		height: 1.5rem;
	}
	.rank ul.rank-list:nth-of-type(1) li:nth-child(-n+3) p.rank-num {
		background-color: #A01500;
	}
	.rank ul.rank-list li p.rank-name {
		color: var(--color-blue);
		font-size: 0.889rem;
		font-weight: 700;
	}
	.rank ul.rank-list:nth-of-type(1) li:nth-child(-n+3) p.rank-name {
		color: #A01500;
	}

	.rank ul.rank-img {
		display: flex;
		justify-content: center;
		gap: 3.85vw;
		margin: 6.4vw 0 0 0;
	}
	.rank ul.rank-img li {
		max-width: calc((100% - 3.85vw) / 2);
	}
	.rank ul.rank-img li figure {
		width: 100%;
	}
	.rank ul.rank-img li figure img {
		width: auto;
		height: 29.23vw;
		display: block;
	}

	.rank div.rank-note {
		margin: 6.4vw 0 0 0;
	}
	.rank div.rank-note div.rank-note-wrap {
		display: flex;
		flex-direction: column;
		width: 100%;
	}
	.rank div.rank-note div.rank-note-wrap .rank-note-img {
		box-sizing: border-box;
		padding: 0 0 6.4vw 0;
		text-align: center;
	}
	.rank div.rank-note div.rank-note-wrap .rank-note-img img{
		width: 41vw;
		margin: 0 auto;
	}
	.rank div.rank-note div.rank-note-wrap .rank-note-text {
		font-size: 0.889rem;
		line-height: 1.6;
		letter-spacing: 0.05em;
	}

	.rank figure figcaption {
		font-size: 0.667rem;
		line-height: 1.4;
		letter-spacing: 0.05em;
		margin: 0.6em 0 0 0;
		white-space: nowrap;
	}


	/* -------------------------------------------------------------------------------------------
	*
	* area-link
	*
	* ----------------------------------------------------------------------------------------- */

	.area-link{
		background-color: var(--color-blue);
		background-image: url('../img/bg_area-link_sp.png');
		background-repeat: no-repeat;
		background-position: center top;
		background-size: auto 100%;
		padding: 15.38vw 0 20.51vw 0;
		text-align: center;
	}

	.area-link p{
		color: #fff;
		font-size: 1.11rem;
		line-height: 1.6;
		letter-spacing: 0.05em;
		margin: 0 0 6.4vw 0;
	}

	.area-link .area-list{
		display: flex;
		flex-wrap: wrap;
		gap: 2.3vw;
	}

	.area-link .area-list li{
		width: calc((100% - 2.3vw) / 2);
	}

	.area-link .area-list li a{
		background-color: #fff;
		box-sizing: border-box;
		border: 1px solid #fff;
		border-radius: 100px;
		color: #087ADF;
		font-size: 1rem;
		font-weight: 700;
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 3vw 3.85vw;
	}
	.area-link .area-list li a:hover{
		background-color: var(--color-blue);
		color: #fff;
	}


	.area-link .area-list li a::after{
		content: '';
		display: block;
		width: 1.222rem;
		height: 1.222rem;
		background-image: url('../img/icon_arrow_grad.svg');
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: contain;
	}


}