@charset "Shift-JIS";


@media screen and (min-width : 960px) {

	body:not(.top) #contents{
		padding: 0 0 185px 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 0 0;
		position: relative;
		overflow: hidden;
	}
	#hero::before,
	#hero::after{
		content: '';
		display: block;
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100% auto;
		position: absolute;
		z-index: 0;
	}
	#hero::before{
		width: 413px;
		height: 416px;
		background-image: url('../img/bg_graph_circle.png');
		top: -190px;
		left: -160px;
	}
	#hero::after{
		width: 233px;
		height: 213px;
		background-image: url('../img/bg_square.png');
		top: 335px;
		right: -100px;
	}

	#hero h2 {
		width: 100%;
	}
	#hero h2 picture {
		display: block;
		width: 100%;
		height: auto;
	}

	#hero .hero-inner {
		border-bottom: 1px solid var(--color-blue);
		display: flex;
		justify-content: space-between;
		margin: 0 auto 9px auto;
		padding: 0 0 50px 0;
		position: relative;
		width: 92%;
		max-width: 1380px;
		z-index: 1;
	}

	/*
	#hero .hero-desc {
		display: flex;
		flex-direction: column;
		gap: 33px;
		width: 31.3%;
	}

	#hero .hero-desc h2 {
		width: 100%;
	}
	#hero .hero-desc h2 img {
		display: block;
		width: 100%;
		height: auto;
	}

	#hero .hero-text h2 {
		width: 100%;
	}
	#hero .hero-text h2 img {
		display: block;
		width: 100%;
		height: auto;
	}

	#hero .hero-img {
		width: 64.64%;
	}
	#hero .hero-img img {
		width: 100%;
		height: auto;
	}
*/

	/* -------------------------------------------------------------------------------------------
	*
	* contents
	*
	* ----------------------------------------------------------------------------------------- */

	.contents-body{
		position: relative;
	}
	.contents-body .bg-wrap{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 0;
		pointer-events: none;
	}
	.contents-body .bg-wrap .bg-obj{
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100% auto;
		position: absolute;
		z-index: 0;
	}
	.contents-body .bg-wrap .bg-obj[data-num="1"]{
		width: 453px;
		height: 272px;
		background-image: url('../img/bg_graph_line.png');
		top: 232px;
		left: -254px;
	}
	.contents-body .bg-wrap .bg-obj[data-num="2"]{
		width: 413px;
		height: 416px;
		background-image: url('../img/bg_graph_circle.png');
		top: 888px;
		right: -234px;
	}
	.contents-body .bg-wrap .bg-obj[data-num="3"]{
		width: 233px;
		height: 213px;
		background-image: url('../img/bg_square.png');
		top: 1660px;
		left: -100px;
	}



	.area{
		padding: 80px 0 0 0;
	}

	.area h3{
		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;
	}
	.area h3::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;
	}

	.area h3 a{
		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 h3 a::after{
		content: '';
		display: block;
		width: 1.222rem;
		height: 1.222rem;
		background-image: url('../img/icon_arrow_blue.svg');
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: contain;
		transform: translateX(0);
		transition: transform 0.3s;
	}
	.area h3 a:hover::after{
		transform: translateX(6px);
	}

	.area .area-list{
		display: flex;
		flex-wrap: wrap;
		gap: 9px;
	}

	.area .area-list li{
		width: calc((100% - 27px) / 4);
	}

	.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;
	}


}

@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: 5.64vw 0 0 0;
		position: relative;
	}
	#hero::before,
	#hero::after{
		content: '';
		display: block;
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100% auto;
		position: absolute;
		z-index: 0;
	}
	#hero::before{
		width: 83.33vw;
		height: 83.33vw;
		background-image: url('../img/bg_graph_circle.png');
		top: -45vw;
		left: -44vw;
	}
	#hero::after{
		width: 35.6vw;
		height: 32.8vw;
		background-image: url('../img/bg_square.png');
		top: 215vw;
		right: -18vw;
	}

	#hero h2 {
		width: 100%;
	}
	#hero h2 picture {
		display: block;
		width: 100%;
		height: auto;
	}

	#hero .hero-inner {
		border-bottom: 1px solid var(--color-blue);
		display: flex;
		justify-content: space-between;
		margin: 0 auto;
		padding: 0 0 13.33vw 0;
		position: relative;
		width: 92%;
		max-width: unset;
		z-index: 1;
	}


	/* -------------------------------------------------------------------------------------------
	*
	* contents
	*
	* ----------------------------------------------------------------------------------------- */

	.contents-body{
		position: relative;
	}
	.contents-body .bg-wrap{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 0;
		pointer-events: none;
	}
	.contents-body .bg-wrap .bg-obj{
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100% auto;
		position: absolute;
		z-index: 0;
	}
	.contents-body .bg-wrap .bg-obj[data-num="1"]{
		width: 88.2vw;
		height: 53.1vw;
		background-image: url('../img/bg_graph_line.png');
		top: 193vw;
		left: -22vw;
	}
	.contents-body .bg-wrap .bg-obj[data-num="2"]{
		width: 83.33vw;
		height: 83.33vw;
		background-image: url('../img/bg_graph_circle.png');
		top: 374vw;
		right: -39vw;
	}
	.contents-body .bg-wrap .bg-obj[data-num="3"]{
		width: 35.6vw;
		height: 32.8vw;
		background-image: url('../img/bg_square.png');
		top: 532vw;
		left: -18vw;
	}



	.area{
		padding: 13.33vw 0 0 0;
	}

	.area h3{
		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;
	}
	.area h3::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;
	}

	.area h3 a{
		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 h3 a::after{
		content: '';
		display: block;
		width: 1.222rem;
		height: 1.222rem;
		background-image: url('../img/icon_arrow_blue.svg');
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: contain;
		transform: scale(1, 1);
		transition: transform 0.3s;
	}
	.area h3 a:hover::after{
		transform: scale(1.1, 1.1);
	}

	.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: 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;
	}




}