/* ★★外部データ読み込み★★ */

/* アニメーション */
@import url("animate.css");

/* テーマカラーの定義 */

:root{
    --thema-color01:rgb(28,28,28);
}




/* 共通テキスト */

h1 {
	font-family: 'Noto Sans JP', sans-serif;
  	font-size: 7rem;
	font-weight: 400;
	line-height: 1.3;
	color: #rgb(28,28,28);
}

h1 span {
  	font-size: 3rem;
}

h2 {
	font-family: 'Noto Serif JP', serif;
  	font-size: 3.5rem;
	font-weight: 700;
	line-height: 1.3;
	color: #rgb(28,28,28);
}

h2 span {
  	font-size: 1.8rem;
}

h3 {
	font-family: 'Pathway Gothic One', sans-serif;
  	font-size: 6rem;
	font-weight: 400;
	line-height: 1.3;
	color: #1F7B47;
}

h3 span {
	font-family: 'Noto Sans JP', sans-serif;
  	font-size: 1.8rem;
}

h4 {

}

h5 {

}

p {
  	font-size: 1.6rem;
	font-weight: 400;
	line-height: 2;
	color: #000000;
	font-family: 'Noto Sans JP', sans-serif;
}

.cat01 {
  	font-size: 3.6rem;
	font-weight: 700;
	line-height: 1.3;
	color: #000000;
}

h1 + h2 {
	margin-top: 0px;
}

h2 + h3 {
	margin-top: 30px;
}

h3 + p {
	margin-top: 30px;
}

p + p {
	margin-top: 30px;
}

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

h1 {
  	font-size: 5rem;
}
	
h1 span {
  	font-size: 2rem;
}
	
h2 {
  	font-size: 2.5rem;
}
	
h2 span {
  	font-size: 1.6rem;
}

h3 {
  	font-size: 4.5rem;
}
	
h3 span {
  	font-size: 1.6rem;
}
	
.cat01 {
  	font-size: 3rem;
	line-height: 1.3;
}
	
}

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

h1 {
  	font-size: 3rem;
}
	
h1 span {
  	font-size: 1.6rem;
}
	
h2 {
  	font-size: 2rem;
}
	
h2 span {
  	font-size: 1.4rem;
}
	
h3 {
  	font-size: 3.5rem;
}
	
h3 span {
  	font-size: 1.4rem;
}
	
p {
  	font-size: 1.2rem;
}

.cat01 {
  	font-size: 2.5rem;
	line-height: 1.3;
}
	
}

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

h1 {
  	font-size: 3rem;
}
	
h1 span {
  	font-size: 1.6rem;
}
	
h2 {
  	font-size: 2rem;
}
	
h2 span {
  	font-size: 1.4rem;
}
	
h3 {
  	font-size: 3rem;
}
	
h3 span {
  	font-size: 1.4rem;
}
	
.cat01 {
  	font-size: 2rem;
}
	
h3 + p {
	margin-top: 20px;
}

p + p {
	margin-top: 20px;
}
	
}

/* リンク位置調節 */

#s01,
#s02,
#s03,
#s04,
#s05 {
	margin-top:-100px;
	padding-top:100px;
}

@media screen and (max-width:1200px) {
	
#s01,
#s02,
#s03,
#s04,
#s05 {
	margin-top:-140px;
	padding-top:140px;
}
	
}

@media screen and (max-width:1025px) {
	
#s01,
#s02,
#s03,
#s04,
#s05 {
	margin-top:-0px;
	padding-top:0px;
}
	
}






/* 共通画像・パーツ類 */

.tel1 {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 600;
  	font-size: 2rem;
	color:var(--thema-color01);
	line-height: 1.3;
	margin-top: 10px;
	text-align: center;
}

.tel1 span {
  	font-size: 7.3rem;
	line-height: 1.3;
}

.tel1 i {
  	font-size: 5rem;
	transform: scaleX(-1);
	margin-right: 5px;
}

@media screen and (max-width:1200px) {
	
.tel1 span {
  	font-size: 5rem;
}

.tel1 i {
  	font-size: 4rem;
	margin-right: 5px;
}
	
}

@media screen and (max-width:1025px) {
	
.tel1 {
  	font-size: 1.4rem;
	margin-top: 10px;
}

.tel1 span {
  	font-size: 3rem;
}

.tel1 i {
  	font-size: 2.2rem;
	margin-right: 5px;
}
	
}

/* トップ動画部分 */

.top-img{
	position:relative;
	width: 100%;
	height: auto;
	padding-top: 170px;
}






/* 共通エリア */

.ts-back01{
	display: block;
	width: 100%;
	height: auto;
	padding-top: 100px !important;
	padding-bottom: 100px !important;
	background-color: #ffffff;
	text-align: center;
}
.ts-back02{
	display: block;
	width: 100%;
	height: auto;
	padding-top: 100px !important;
	padding-bottom: 100px !important;
	background-color: #1F7B47;
	text-align: center;
}
.ts-back03{
	display: block;
	width: 100%;
	height: auto;
	padding-top: 100px !important;
	padding-bottom: 100px !important;
	background-color: #F3F0E8;
	text-align: center;
}

.aside-back{
	display: block;
	width: 100%;
	height: auto;
	padding-top: 100px !important;
	padding-bottom: 100px !important;
background-image: url(../img/sec_bg04.jpg);
background-repeat: no-repeat;
background-size: cover;
	text-align: center;
}


.bg01{
	width: 100%;
	position: relative;
}
.bg01::before{
content: "";
background-image: url(../img/sec_bg01.jpg);
background-repeat:no-repeat ;
background-size: cover;
top: 2%;
left: 0;
width: 100%;
height: 2000px;
position: absolute;
opacity: 0.6;
}




footer {
	width: 100%;
	background-color: #1d7a40;
	padding-top: 30px !important;
	padding-bottom: 10px !important;

}

.foo-name {
	width: 400px;
	margin-right: auto;
	margin-left: auto;
	margin-top: 5px;
	font-size: 2.4rem;
	color: #fff;
}


.foo-nav2 a:link,
.foo-nav2 a:visited,
.foo-nav2 a:active {
	color: #fff; 
	text-decoration: none;
font-size: 1.6rem;
}

.foo-nav2 a:hover {
	color: #dad7d1; 
	text-decoration: none;
opacity: 0.7;}



.foo2 {
	width: 100%;
	background-color: #1d7a40;
	text-align: center;
	font-size: 1.4rem;
	padding: 10px 0 20px 0;
	color: #fff;

}

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

.ts-back01{
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}

.ts-back02{
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}
	
.ts-back03{
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}
.aside-back{
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}
	
}

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

.ts-back01{
	padding-top: 30px !important;
	padding-bottom: 30px !important;
}

.ts-back02{
	padding-top: 30px !important;
	padding-bottom: 30px !important;
}
	
.ts-back03{
	padding-top: 30px !important;
	padding-bottom: 30px !important;
}
.aside-back{
	padding-top: 30px !important;
	padding-bottom: 30px !important;
}
	
footer {
	padding-top: 15px !important;
	padding-bottom: 15px !important;
}
	
.foo-name {
	width: 100%;
	margin-top: 5px;
	font-size: 1.8rem;
	color: #fff;
}

.foo-nav2 a:link,
.foo-nav2 a:visited,
.foo-nav2 a:active {
	color: #fff; 
	text-decoration: none;
font-size: 1.2rem;
}


.foo2 {
	font-size: 1.2rem;
	padding: 0px 0 20px 0;


}
.bg01::before{
	top: 5%;
	left: 0;
	width: 100%;
	height: 1200px;

	
	}
	
}
@media screen and (max-width:1025px) {
.bg01::before{
	top: 10%;
	left: 0;
	width: 100%;
	height: 1200px;
	opacity: 0.8;

	
	}
}







/* ボタン */

a.btn1 {
	font-family: 'Noto Sans JP', sans-serif;
	display: inline-block;
	color: #ffffff;
	text-decoration: none;
	font-size: 1.6rem;
	position: relative;
	width: 170px;
	padding-top: 15px;
	padding-bottom: 15px;
	text-align: center;
	background-color:var(--thema-color01);
	border-radius: 5px;
}

a.btn2 {
	font-family: 'Noto Sans JP', sans-serif;
	display: inline-block;
	color: #ffffff;
	text-decoration: none;
	font-size: 1.6rem;
	position: relative;
	width: 170px;
	padding-top: 15px;
	padding-bottom: 15px;
	text-align: center;
	background: #eeac26;
	border-radius: 5px;
}

a.btn3 {
	font-family: 'Noto Sans JP', sans-serif;
	display: block;
	color: #ffffff;
	text-decoration: none;
	font-size: 1.8rem;
	position: relative;
	width: 100%;
	padding-top: 10px;
	padding-bottom: 10px;
	text-align: center;
	background-color:var(--thema-color01);
	border-radius: 5px;
	margin-top: 10px;
}

a.btn4 {
	font-family: 'Noto Sans JP', sans-serif;
	display: block;
	color: #ffffff;
	text-decoration: none;
	font-size: 1.8rem;
	position: relative;
	width: 100%;
	padding-top: 10px;
	padding-bottom: 10px;
	text-align: center;
	background: #eeac26;
	border-radius: 5px;
	margin-top: 10px;
}

a.btn1 + a.btn2 {
	margin-left: 10px;
}

a.btn1 i,
a.btn2 i {
	font-size: 2rem;
}

a.btn3 i,
a.btn4 i {
	font-size: 2.5rem;
	margin-right: 3px;
}

a.btn1:hover,
a.btn2:hover,
a.btn5:hover {
    opacity:0.7;
	bottom: -2px;
}

a.btn3:hover,
a.btn4:hover {
    opacity:0.7;
	bottom: -2px;
}

@media screen and (max-width:1025px) {
	
a.btn3 {
	font-size: 1.6rem;
	padding-top: 7px;
	padding-bottom: 7px;
	border-radius: 5px;
	margin-top: 10px;
}

a.btn4 {
	font-size: 1.6rem;
	padding-top: 7px;
	padding-bottom: 7px;
	border-radius: 5px;
	margin-top: 10px;
}
	
a.btn3 i,
a.btn4 i {
	font-size: 2rem;
	margin-right: 3px;
}
	
}




/* 自作アニメーションのまとめ */

.animated {
    opacity: 0;
}

.txt-anime1 {
  /* アニメーションにかける秒数 */
  -webkit-animation-duration: 3s;
  animation-duration: 3s;
  /* アニメcssの名前 */
  animation-name: anime1_txt;
    opacity: 0;
	position: relative;
	animation-timing-function: ease-out;
}

@keyframes anime1_txt {
from {
    opacity: 0;
}
to {
    opacity: 1;
}
}

.area-anime2 {
  /* アニメーションにかける秒数 */
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  /* アニメcssの名前 */
  animation-name: anime2-area;
    opacity: 0;
	position: relative;
	animation-timing-function: ease-out;
}

@keyframes anime2-area {
from {
    opacity: 0;
	top: 100px;
}
to {
    opacity: 1;
	top: 0;
}
}






















/* ファーストビュー */

.top-header {
    width: 100%;
    height: 6rem;
    position: fixed;
    top: 0;
    z-index: 10;
    -webkit-transition: background-color 0.3s;
    transition: background-color 0.3s;
}

.top-header-wrapper{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    flex-basis: 100%;
}
.top-header__logo {
    display: inline;
    width: 15%;
    margin: 0px 0 0 180px;
    padding-top: 5px;
}
.top-header__info {
width: 10%;
margin-right: 60px;
margin-top: 1.5rem;

}

.top-header__info :hover{
opacity: 0.6;
}
.top-header__info a{
    width:100%;
    height: 50px;
    background-color: #FFEB00;
display:flex;
flex-wrap: nowrap;
justify-content: center;
border-bottom-left-radius: 8px;
border-bottom-right-radius: 8px;

}

.info-img{
    width: 35px;
	padding-top: 5px;
	margin-left: 0 0 0 10px;
    }
.info-tit{
width: 60%;
font-weight: 600;
font-size: 1.6rem;
color: rgb(28,28,28);
letter-spacing: 0.2rem;
padding-top: 10px;
font-family: 'Noto Sans JP', sans-serif;
text-align: center;
}


main {
    position: relative;
    overflow-x: hidden;
}
.top-kv {
    position: relative;
}

.top-kv__content{
	width: calc(650 / 750 * 100%);
    margin-left: auto;
    position: relative;
    z-index: 3;
}
.top-kv::before {
    content: "";
    display: block;
    width: 100%;
    height: 1.5rem;
    background-color: #1d7a40;
    z-index: 5;
    position: fixed;
}
.top-kv__inner{
    position: relative;
}
.top-kv__slide-item {
    width: calc(750 / 650 * 100%);
    opacity: 0;
    position: absolute;
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-transform: translateX(0);
    transform: translateX(0);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-transition: opacity 1.5s ease-in-out;
    transition: opacity 1.5s ease-in-out;
    will-change: transform, opacity;
    top: 0;
}
.top-kv__side-content {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: flex-start;
    position: absolute;
    z-index: 2;
    margin-top: 10%;
	width: calc(100 / 750 * 100%);


}

.top-kv__side-text02{
    background-color: #1F7B47;
    color: #fff;
    padding: 10px 0;

}
.aside_desc{
margin: 0 auto;
}
.aside_desc p{
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: 0.1rem;
}

.aside_img{
    width: 15%;
    padding: 0 5px;
    margin: 2rem auto 0 auto;
}
.aside_img img{
    width: 100%;

}

.top-kv__content::before {
    content: "";
    display: block;
    padding-top: calc(400 / 650 * 100%);
}
.top-kv__title-area {
    position: absolute;
    top: calc(200/ 1178 * 100%);
    left:10rem;
	display: flex;
	flex-wrap: nowrap;
	flex-basis: 100%;
	justify-content: space-between;
	width: 1140px;
	margin: 0 auto;
}

.top-kv__heading-wrap{
	width: 48%;
	text-align: center;

}

.top-kv__heading-wrap img{
width: 100%;

}
.top-kv__heading-wrap h1{
font-size:8rem;
color:#fff;

}
span.text-xl{
	font-size: 15rem;
	font-weight: 600;
	font-family: 'Oswald', sans-serif;
	
	}
.top-kv__heading-wrap02{
width: 48%;
display: block;
overflow: hidden:}

span.text-column{
	font-size: 8rem;
	writing-mode: vertical-lr;
}
span.en{
	font-size: 10rem;
	font-weight: 600;
	font-family: 'Oswald', sans-serif;}

h1.top-kv__heading01 {
	width: 100%;
	margin:0 auto;
}

.heading-wrap02__inner02{
	width: 130%;
	margin: 4rem auto 0 1rem;
}




.contact-btn{
	width: 100%;
	height: auto;
	text-align: center;
	border-left: 2px solid #FBB03B;
	border-right: 2px solid #29ABE2;
	border-top: 3px solid;
	border-image: linear-gradient(to right, #FBB03B 0%, transparent 100%);
	border-image-slice: 1;
	padding: 10px 0 0 13px;
	white-space: nowrap;
  }
  .contact-btn:hover{
opacity: 0.8;
  }





  .contact-btn::before,
  .contact-btn::after{
	content: "";
	display: block;
	height: 2px;
  }

  .contact-btn__inner{
	background: linear-gradient(60deg, #FBB03B,#FEDD0E,#94D015, #29ABE2);
	padding: 3rem 3rem 4rem 8rem;
  }


  .heading-wrap02__inner02 .contact-btn__inner{
	  text-align: left;

  }
  .heading-wrap02__inner02 .contact-btn__inner p{
font-size: 2.6rem;
font-weight: 600;

}

.heading-wrap02__inner02 .contact-btn__inner span{
	background: #fff;
	padding: 1rem 2rem ;
	padding-left: 2rem;
	position: relative;
	font-size: 1.8rem;
}
  .heading-wrap02__inner02 .contact-btn__inner span::before{
content: "";
background-image: url(../img/fv_contact.png);
background-repeat: no-repeat;
background-size: contain;
top: 0em;
left: -5rem;
width: 40px;
height: 40px;
position: absolute;

}
.heading-wrap02__inner02 .contact-btn__inner span::after{
	content: "";
	background-image: url(../img/right.png);
	background-repeat: no-repeat;
	background-size: contain;
	top: 0.5em;
	right: -7rem;
	width: 50px;
	height: 40px;
	position: absolute;
	-webkit-animation: torotoro 1.8s linear infinite both;
    animation: torotoro 1.8s linear infinite both;
	
	}
	
@keyframes torotoro {
	0% , 100%{
	-webkit-transform:translateX( 10px); 
	-webkit-transform:translateX(  0px); }
	50%{
		-webkit-transform:translateX( 0px); 
		-webkit-transform:translateX(  10px); 
	}
  }


 




.top-kv__heading02 {
	width: 100%;
	margin: -2rem auto 0 0;
	position: relative;
}
h2.top-kv__heading02  {
	font-size: 5rem;
	font-family: 'Noto Sans JP', sans-serif;
	text-shadow: 
    3px  3px 8px rgb(255, 255, 255),
    3px  0px 8px rgb(255, 255, 255),
    0px  3px 8px rgb(255, 255, 255),
    3px -3px 8px rgb(255, 255, 255),
   -3px  3px 8px rgb(255, 255, 255),
   -3px -3px 8px rgb(255, 255, 255),
   -3px -0px 8px rgb(255, 255, 255),
   -0px -3px 8px rgb(39, 39, 39);
   white-space: nowrap;
	
	}

.top-kv__heading02 span {
font-size: 12rem;
font-family: 'Noto Sans JP', sans-serif;
position: relative;
}
.top-kv__heading02 span::after {
	content: "";
	background: url(../img/aside01.png);
	background-repeat: no-repeat;
	background-size: contain;
    top: 10%;
    right: -80%;
    width: 200px;
    height: 120px;
	position: absolute;

	}
.top-kv__heading02 img{
    width: 100%;
}
.top-kv__text {
    color: #fff;
    font-size: 1.8rem;
    letter-spacing: 0.2em;
    width: calc(650 / 650 * 100%);
    margin: 1rem auto 0 0;
    text-shadow: 
    1px  1px 8px rgb(39, 39, 39),
    1px  0px 8px rgb(39, 39, 39),
    0px  1px 8px rgb(39, 39, 39),
    1px -1px 8px rgb(39, 39, 39),
   -1px  1px 8px rgb(39, 39, 39),
   -1px -1px 8px rgb(39, 39, 39),
   -1px -0px 8px rgb(39, 39, 39),
   -0px -1px 8px rgb(39, 39, 39);
   white-space: nowrap;

}




	/* section開始 */



/* section01*/	
	article{
		margin: 60px 0 0 0;
	  
	  }
	
h3.sec-tit-ja{
	font-size: 3.4rem;
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	}
	h3.sec-tit-en{
		font-size: 1.8rem;
		font-weight: 400;
		font-family: 'Noto Sans JP', sans-serif;
		padding-top: 5px;
		position: relative;
		}
	h3.sec-tit-en::after{
			content: "";
			position: absolute;
			top: 130%;
			left: 45%;
			width: 10%;
			height: 3px;
	border-bottom: 2.5px solid #1d7a40;
	
			}
	
		.sec__desc{
			text-align: left;
			margin: 40px 0 20px 0;
		}
		.sec__desc p{
			letter-spacing: 0.1rem;
			line-height: 1.7;
			font-size: 1.6rem;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 400;
		}
		.sec__desc span
			{background:rgba(0, 0, 0, 0) 
				linear-gradient(transparent 50%, #fff9b1 0%) 
				repeat scroll 0 0;
			}
		
	.sec-img{
		display: flex;
		flex-wrap: nowrap;
		flex-basis: 100%;
		justify-content: center;

	
	}
	#sec01 .sec-img__item{
		width: 30%;
		display: block;
	}
	#sec01 .sec-img__item:first-child{
	margin-right: 30px;
	}
	.sec-img__item p{
		font-weight: 400;
		font-size: 1.6rem;
		padding-top: 5px;
	}

	

/* section02 */
			
#sec02 h3.sec-tit-ja span{
	font-size: 1.6rem;
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	}
	#sec02 .sec__inner{
	 display: flex;
	 flex-wrap: nowrap;
	 flex-basis: 100%;
	 justify-content: space-between;
	 margin-bottom: 3rem;
}

	#sec02 .sec__desc{
		width: 150%;
	}
	#sec02 .sec-img{
		width: 10%;
		display:flex;
		flex-wrap: nowrap;
		flex-basis: 100%;
		justify-content: flex-start;
	}
	#sec02 .sec-img__item{
		width: 60%;
    height: auto;
    margin: 5rem 0 0 3rem;
	}
	#sec02 .sec-img__item p{
		font-size: 1.4rem;
	}

	.sec-iflame{
		width: 60%;
		height: 320px;
		position: relative;
		margin: 0 auto;
	}
	.sec-iflame iframe {
	width: 100%;
	height: 100%;
	}


/* section03 */
#sec03 .sec-img__item{
	width: 40%;
}
#sec03 .sec-img__item:first-child{
margin-right: 20px;
}

/* section04 */
#sec04 h3.sec-tit-ja{
	color: #fff;
	}
#sec04 .sec__desc p{
		color: #fff;
	}
	.sdgs-list p{
font-size: 1.2rem;
	}
	.sdgs-list__inner{
		background-color: #fff;
		padding: 30px;
		display: flex;
		flex-wrap: nowrap;
		flex-basis: 100%;
		justify-content: space-between;
		border-radius: 10px;
	}
	.sdgs-item{
		width: 30%;
	}
/* section05 */
#sec05{
background-image: url(../img/sec_bg05.png);
background-repeat: no-repeat;
background-size: contain;
background-position: 70% 60%;
}


#sec05 .sec-img{
	padding: 80px 200px 20px 200px;
	}

#sec05 .contact-btn{
		width: 50%;
		height: auto;
		text-align: center;
		border: 2px solid #DB3B1A;
		padding: 3px 5px;
		margin: 10rem auto 0 auto;
		position: relative;
	  }

	  
	  #sec05 .contact-btn::before{
		content: "";
		background-image: url(../img/pop.png);
		background-repeat: no-repeat;
		background-size: contain;
		position: absolute;
		top: -4rem;
		left: 2rem;
		width: 200px;
		height: 50px;
		z-index: 2;
	  }

#sec05 .contact-btn__inner{
		background: hsl(10, 79%, 48%);
		padding: 15px 15px 15px 30px;
		text-align: left;
	  }

#sec05 .contact-btn__inner p{
color: #fff;
font-size: 2.3rem;
position: relative;
z-index: 1;
	  }

#sec05 .contact-btn__inner p::after{
content: "";
background-image: url(../img/right.png);
background-repeat: no-repeat;
background-size: contain;
position: absolute;
top: 1rem;
right: 1.5rem;
width: 50px;
height: 30px;
z-index: 2;
-webkit-animation: torotoro 1.8s linear infinite both;
animation: torotoro 1.8s linear infinite both;

  }




.note{
	width: 100%;
	margin: 0 auto;
}
#sec05 .note p{
	border-top: 2px solid #1d7a40;
	border-bottom: 2px solid #1d7a40;
	padding: 10px 0;
	margin-top: 20px;
	font-size: 1.6rem;
}
#sec05 .sec__desc{
	text-align: center;
}
#sec05 .sec-img__item{
	width: 35%;
}
#sec05 .sec-img__item:first-child{
	margin-right: 20px;
}



/* section06 */

.contact-table01{
	margin-top: 50px;
	text-align: left;
}



.faq__quest{
	font-size: 2rem;
	font-weight: 400;
	padding-bottom: 30px;
	position: relative;
	padding-left: 60px;
	position: relative;
	}
	.faq__item{
		margin: 70px 0;
		position: relative;
		width: 100%;
	}
	.faq__item::after{
content: "";
border-bottom: 2px solid #fff;
		position: absolute;
		width: 100%;
		height: 2px;
		bottom: -2rem;
		left: 0;
	}
	
.faq__quest::before{
	content: "Q";
	position: absolute;
	font-family: 'Oswald', sans-serif;
	font-size: 3rem;
	font-weight: 600;
	background: #1d7a40;
		color: #fff;
		padding: -20px 0 0 0;
		top: -8px;
		left: 0px;
		width: 50px;
		height: 50px;
		border-radius: 50%;
		text-align: center;
		position: absolute;
	}
.faq__answer{
	 font-size: 2rem;
	font-weight: 400;
	position: relative;
	padding-left: 60px;
	}
	
.faq__answer::before{
		content: "A";
		position: absolute;
		font-family: 'Oswald', sans-serif;
		font-size: 3rem;
		font-weight: 600;
		background: #fff;
			color: #1d7a40;
			padding: -25px 0 0 0;
			top: -8px;
			left: 0px;
			width: 50px;
			height: 50px;
			border-radius: 50%;
			text-align: center;
			position: absolute;
			border: 2px solid#1d7a40;
		}
/* section07 */
.img-list{
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: 50px 0;
}
.img-list img{
	width: 300px;
	height: auto;
}

/* aside */
#aside01 h3.foo-ad{
	font-size: 4rem;
	color: rgb(28,28,28);
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	display: inline;
	list-style-type:1.7

}
#aside01 span.text-l{
	font-size: 8.5rem;
	color: rgb(28,28,28);
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	display: inline;
	position: relative;
	padding-right: 100px;

}
#aside01 span.text-l::after{
content: "";
background-image: url(../img/aside01.png);
background-size: contain;
background-repeat: no-repeat;
top: 2rem;
right: 1rem;
width: 80px;
height:80px;
position: absolute;

}
#aside01 span.text-s{
	font-size: 3rem;
	color: rgb(28,28,28);
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	display: inline;

}


#aside01 .contact-btn{
	width: 50%;
	height: auto;
	text-align: center;
	border: 2px solid #DB3B1A;
	padding: 3px 5px;
	margin: 8rem auto 0 auto;
	position: relative;
  }
  #aside01 .contact-btn::before{
	content: "";
	background-image: url(../img/pop.png);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: -4rem;
	left: 2rem;
	width: 200px;
	height: 50px;
	z-index: 2;
  }

  #aside01 .contact-btn__inner{
	background: hsl(10, 79%, 48%);
	padding: 15px 15px 15px 30px;
	text-align: left;
  }

  #aside01 .contact-btn__inner p{
color: #fff;
font-size: 2.3rem;
position: relative;
z-index: 1;
  }

#aside01 .contact-btn__inner p::after{
content: "";
background-image: url(../img/right.png);
background-repeat: no-repeat;
background-size: contain;
position: absolute;
top: 1rem;
right: 1.5rem;
width: 50px;
height: 30px;
z-index: 2;
-webkit-animation: torotoro 1.8s linear infinite both;
animation: torotoro 1.8s linear infinite both;}


#aside01 .note p{
border-top: 2px solid #1d7a40;
border-bottom: 2px solid #1d7a40;
padding: 10px 0;
margin-top: 20px;
font-size: 1.6rem;
}

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

	.aside_img{
		width: 20%;
		padding: 0 5px;
		margin: 2rem auto 0 auto;
	}}

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


	/* fv */
	.top-kv__title-area{
		width: 75%;
	}
	.top-kv__content::before {
		content: "";
		display: block;
		padding-top: calc(400 / 650 * 100%);
	}
	span.en {
		font-size: 7rem;
	}
	.top-kv__heading-wrap h1 {
		font-size: 7rem;
	}
	span.text-xl {
		font-size: 13rem;
	}
	span.text-column {
		font-size: 7rem;
	}
	.top-kv__heading02 span {
		font-size: 8rem;
	}
	h2.top-kv__heading02 {
		font-size: 4rem;
	}
	.top-kv__text {
		font-size: 1.6rem;
	}
	.top-kv__heading02 span::after {
		content: "";
		background: url(../img/aside01.png);
		background-repeat: no-repeat;
		background-size: contain;
		top: 5%;
		right: -55%;
		width: 100px;
		height: 120px;
		position: absolute;
	}
	.top-kv__side-content{
		margin-top: 7%;	}
		.top-kv__title-area{
			left: 8rem;
		}
		.top-header__info{
			width: 13%;
		}
		.top-header__info{
			margin-right: 60px;
		}
		.heading-wrap02__inner02{
			width: 150%;
		}
}

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

	.contact-btn__inner{
		padding: 1rem 3rem 2rem 8rem;
	}

}
@media screen and (max-width:1250px){
	/* fv */
	.top-kv__title-area{
		width: 80%;
	}
	.top-kv__content::before {
		content: "";
		display: block;
		padding-top: calc(400 / 650 * 100%);
	}
	.top-kv__side-content{
		margin-top: 5%;
	}
	.aside_desc p{
		font-size: 1.6rem;
	}
	.top-header__info{
		width: 15%;
	}
	.top-header__info{
		margin-right: 30px;
	}
	.heading-wrap02__inner02{
		margin: 3rem auto 0 1rem;
	}
	.contact-btn{
		padding: 5px 0 0 9px;
		}
		  .heading-wrap02__inner02 .contact-btn__inner span {
			background: #fff;
			padding: 0.5rem 0.5rem;
			padding-left: 1rem;
			font-size: 1.6rem;
		}
		.contact-btn__inner {
			padding: 0rem 3rem 1rem 5rem;
		}
		.heading-wrap02__inner02 .contact-btn__inner span::before {
			left: -4rem;
			width: 30px;}
			.heading-wrap02__inner02 .contact-btn__inner span::after {
				top: 0.5em;
				right: -4rem;
				width: 35px;
				height: 40px;
			}
}




@media screen and (max-width:1025px) {
	.heading-wrap02__inner{
		margin-top: 50px;
			}

h3.sec-tit-ja{
font-size: 2.5rem;
font-weight: 600;
font-family: 'Noto Sans JP', sans-serif;
}
h3.sec-tit-en{
	font-size: 1.2rem;
	font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;
	padding-top: 5px;
	position: relative;
	}
.top-kv__content::before{
	content: "";
	display: block;
	padding-top: 110rem!important;
}
.top-kv__side-content {
	margin-top: 20%;
	width: calc(120 / 1024 * 100%);
}
.top-header__logo {
    display: inline;
    width: 30%;
    margin: 0px 0 0 30px;
    padding-top: 5px;
}
.top-header__info {
    width: 20%;
    margin-right: 30px;
    margin-top: 1.5rem;
}
.aside_desc{
	margin: 0 auto;
	width: 40%;
	}
.aside_desc p {
    font-size: 2.2rem;

}
.aside_img {
    width: 40%;
    padding: 0 5px;
    margin: 60px auto 0 auto;
}
.info-tit {
    width: 60%;
    font-size: 1.8rem;
}

.top-kv__title-area {
    left:20rem;
	position: absolute;
    top: calc(160/ 1178 * 100%);
    display: flex;
    flex-wrap: wrap;
    flex-basis: 100%;
    justify-content: space-between;
    margin: 0 auto;
    margin-right: 500px;
	width: 100%;
}

.top-kv__heading-wrap {
	width: 50%;
	text-align: center;
}
.top-kv__heading-wrap02{
	width: 65%;
}
span.en {
    font-size: 7rem;

}
span.text-xl {
    font-size: 13rem;
}
span.text-column {
    font-size: 7rem;
}
.top-kv__text{
	font-size: 1.5rem;
}
.heading-wrap02__inner02{
	display: none;
}
.top-kv__heading02 span {
    font-size: 10rem;
}
.top-kv__heading02 span::after {
    top: 10%;
    right: -45%;
    width: 100px;
    height: 100px;
}



		/* section01 */

		/* section02 */
		.sec-iflame{
			width: 60%;
			height: 200px;
		}
	
		/* section03 */
		/* section04 */
		/* section05 */
		#sec05 .sec__desc{
			text-align: left;
		}
		#sec05{
			background-image: url(../img/sec_bg05_tb.png)!important;
			background-repeat: no-repeat;
			background-size: contain;
			background-position: 70%, 30%;
			}
			#sec05 .inner{
				background-color: rgba(255, 255, 255,0.6);
			}
			#sec05 .sec-img {
				padding:30px 200px 10px 200px;
			}
			#sec05 .contact-btn {
				width:65%;
				padding: 3px 5px;
				margin: 5rem auto 0 auto;}
				#sec05 .contact-btn__inner p {
					color: #fff;
					font-size: 2rem;
					position: relative;
					z-index: 1;}
			#sec05 .note {
				width: 100%;
           text-align:left ;
			}
			#sec05 .sec-img__item {
				width: 45%;
			}
		/* section06 */
		/* section07 */
		/* aside*/
		#aside{
			text-align: left;
		}
#aside01 .contact-btn {
    width: 65%;
    height: auto;
    text-align: center;
    border: 2px solid #DB3B1A;
    padding: 3px 5px;
    margin: 8rem auto 0 auto;
    position: relative;
}
#aside01 h3.foo-ad {
    font-size: 2.6rem;
}
#aside01 span.text-l {
    font-size: 5.5rem;
	padding-right: 80px;
}
#aside01 span.text-l::after {
    content: "";
    background-image: url(../img/aside01.png);
    background-size: contain;
    background-repeat: no-repeat;
    top: 1rem;
    right: 1rem;
    width: 60px;
    height: 60px;
    position: absolute;
}
#aside01 .note p{
	text-align: left;
}
}
@media screen and (max-width:768px) {
.top-kv__heading-wrap {
	width: 65%;
	text-align: center;
}
.top-kv__title-area {
    left:12rem;
}
.aside_img {
    width: 50%;
}
.top-kv__side-content {
	margin-top: 20%;
	width: calc(120 / 768 * 100%);
}
}
	
		
@media screen and (max-width:560px) {
	.top-header {
		width: 100%;
		height: 6rem;
		position: fixed;
		top: 0;
		z-index: 10;
		-webkit-transition: background-color 0.3s;
		transition: background-color 0.3s;
	}
	
	.top-header-wrapper{
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		flex-wrap: nowrap;
		justify-content: space-between;
		flex-basis: 100%;
	}
	.top-header__logo {
		display: inline;
		width: 35%;
		margin: 0px 0 0 10px;
		padding-top: 5px;
	}
	.top-header__info {
	width: 40%;
	margin-right: 8%;
	margin-top: 10px;
	
	}
	.top-header__info a{
		width:100%;
		height: 50px;
		background-color: #FFEB00;
	display:flex;
	flex-wrap: nowrap;
	justify-content: center;
	
	}
	.info-img{
		width: 38%;
		padding-top: 0;
		}
	.info-tit{
	width: 60%;
	font-weight: 600;
	font-size: 1.6rem;
	color: rgb(28,28,28);
	letter-spacing: 0.2rem;
	padding-top: 15px;
	font-family: 'Noto Sans JP', sans-serif;
	}
	
	
	.top-header__info img {
	width: 100%;
	height: auto;
	padding: 5px 10px;
	}
	
	main {
		position: relative;
		overflow-x: hidden;
	}
	.top-kv {
		position: relative;
	}
	.top-kv::before {
		content: "";
		display: block;
		width: 100%;
		height: 1rem;
		background-color: #1d7a40;
		z-index: 3;
		position: fixed;
	}
	.top-kv__inner{
		position: relative;
	}
	.top-kv__slide-item {
		width: calc(750 / 650 * 100%);
		opacity: 0;
		position: absolute;
		overflow: hidden;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		-webkit-transform: translateX(0);
		transform: translateX(0);
		-webkit-transform-origin: top left;
		transform-origin: top left;
		-webkit-transition: opacity 1.5s ease-in-out;
		transition: opacity 1.5s ease-in-out;
		will-change: transform, opacity;
		top: 0;
	}
	.top-kv__side-content {
		height: 100%;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		flex-wrap: wrap;
		flex-direction: column;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: flex-start;
		width: calc(80 / 560 * 100%);
		position: absolute;
		z-index: 2;
		margin-top: 25%;
		left: 0rem;
	}
	
	.top-kv__side-text02{
		background-color: #1F7B47;
		color: #fff;
		padding: 10px 0;
	
	}
	.aside_desc{
	margin: 0 auto;
	width: 60%;
	}
	.aside_desc p{
		writing-mode: vertical-rl;
		text-orientation: upright;
		font-size: 1.7rem;
		font-weight: 600;
		letter-spacing: 0.1rem;
	}
	
	.aside_img{
		width: 60%;
		padding: 0 5px;
		margin: 20px auto 0 auto;
	}
	.aside_img img{
		width: 100%;
	
	}
	
	.top-kv__content::before {
		content: "";
		display: block;
		padding-top: 70rem!important;
	}
	
	
	.top-kv__title-area {
		left:4rem!important;
		position: absolute;
		top: calc(160/ 1178 * 100%);
		display: flex;
		flex-wrap: wrap;
		flex-basis: 100%;
		justify-content: space-between;
		margin: 0 auto;
		margin-right: 500px;
	}
	
	.top-kv__heading-wrap{
		width: 81.5%;
	}
	.top-kv__heading-wrap02{
		width: 100%;
		margin-left: 0;
		margin-top: 1.5rem;
		}
	.top-kv__heading-wrap h1{
		font-size: 4rem;
		color:#fff;
		
		}
		span.text-xl{
			font-size: 8rem;
			font-weight: 600;
			font-family: 'Oswald', sans-serif;
			
			}
	
		span.text-column{
			font-size: 4rem;
			writing-mode: vertical-lr;
		}
		span.en{
			font-size: 5rem;
			font-weight: 600;
			font-family: 'Oswald', sans-serif;}
		
	
	.top-kv__heading01 {
		width:100%;
		margin: 0 25px 0 auto;
	}
	.top-kv__heading02 {
		width: 100%;
		margin: 0;
	}
	.top-kv__heading02 img{
		width: 100%;
	}
	.top-kv__text {
		padding: 0.5em;
		color: #fff;
		font-size: 1.4rem;
		letter-spacing: 0.2em;
		width: calc(650 / 650 * 100%);
		margin: 10px 35px 0 auto;
		white-space:pre-wrap;
	}
	
	
	h1.top-kv__heading01 {
	
	}
	.top-kv__heading02 span {
		font-size: 8rem;
		}
		.top-kv__heading02 span::after {
			top: -5%;
			right: -110px;
			width: 100px;
			height: 70px;
		}
		
			h2.top-kv__heading02  {
				font-size: 3.2rem;
				font-family: 'Noto Sans JP', sans-serif;
				}

	.top-kv__content::before{
		content: "";
		display: block;
		padding-top:70rem!important;
	}
	.heading-wrap02__inner{
		width: 80%;
			}

h3.sec-tit-ja{
font-size: 2.5rem;
font-weight: 600;
font-family: 'Noto Sans JP', sans-serif;
}
h3.sec-tit-en{
	font-size: 1.2rem;
	font-weight: 400;
	font-family: 'Noto Sans JP', sans-serif;
	padding-top: 5px;
	position: relative;
	}


	h3.sec-tit-ja{
	font-size: 2.5rem;
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	}
	h3.sec-tit-en{
		font-size: 1.2rem;
		font-weight: 400;
		font-family: 'Noto Sans JP', sans-serif;
		padding-top: 5px;
		position: relative;
		}
	
		.sec__desc{
			text-align: left;
			margin: 40px 0 20px 0;
		}
		.sec__desc p{
			letter-spacing: 0.1rem;
			line-height: 1.7;
			font-size: 1.6rem;
			font-family: 'Noto Sans JP', sans-serif;
			font-weight: 400;
		}
		.sec__desc span
			{background:rgba(0, 0, 0, 0) 
				linear-gradient(transparent 50%, #fff9b1 0%) 
				repeat scroll 0 0;
			}
		
	.sec-img{
		display: flex;
		flex-wrap: nowrap;
		flex-basis: 100%;
		justify-content: space-between;
	
	}
	.sec-img__item{
		width: 48%;
		display: block;
	}
	.sec-img__item p{
		font-weight: 400;
		font-size: 1.4rem;
		padding-top: 5px;
	}
	span.en {
		font-size: 4rem;
	}
	h1.top-kv__heading01 {

	}
	span.text-xl {
		font-size: 8rem;
	}
	span.text-column {
		font-size: 4rem;
	}
	.top-kv__heading02 span {
		font-size: 5rem;
	}
	.heading-wrap02__inner {
		width: 80%;
		margin-top: 0px;
	}

/* section01 */
	#sec01 .sec-img__item{
		width: 48%;
	}

/* section02 */
.sec-iflame{
	width: 100%;
	height: 200px;
}			
#sec02 h3.sec-tit-ja span{
	font-size: 1.6rem;
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	}
	#sec02 .sec__inner{
	 display: flex;
	 flex-wrap: nowrap;
	 flex-basis: 100%;
	 justify-content: space-between;
}

	#sec02 .sec__desc{
		width: 140%;
	}
	#sec02 .sec-img{
		width: 10%;
		display:block;
	}
	#sec02 .sec-img__item{
		width: 130px;
    height: auto;
    margin: 0px 0 0 auto;
	}
	#sec02 .sec-img__item p{
		font-size: 1.4rem;

	}
	#sec02 .sec-img__item:first-child{
    margin: 0px 0 0 auto;
	}
	#sec02 .sec-img{
		margin-top: 40px;
	}

/* section03 */

	#sec03 .sec-img{
		display: flex;
		flex-wrap: wrap;
		flex-basis: 100%;
		justify-content: space-between;
	}

#sec03 .sec-img__item{
	width: 100%;

}
	
/* section04 */
#sec04 h3.sec-tit-ja{
	color: #fff;
	}
#sec04 .sec__desc p{
		color: #fff;
	}
	.sdgs-list p{
font-size: 1.2rem;
	}
	.sdgs-list__inner{
		background-color: #fff;
		padding: 40px 20px;
		display: flex;
		flex-wrap: wrap;
		flex-basis: 100%;
		justify-content: space-between;
		border-radius: 10px;
		text-align: center;
	}
	.sdgs-item{
		width: 100%;
		margin-bottom: 30px;
	}
	.sdgs-item:first-child{
		width: 100%;
	}
/* section05 */
#sec05{
	background-image: url(../img/sec_bg05.png);
	background-repeat: no-repeat;
background-size: cover;
	background-position: 0%
	}

#sec05 .sec-img{
	padding: 10px 30px;
	}
	#sec05 p{
		font-size: 1.6rem;
	}
	#sec05 p .cap{
		font-size: 1.4rem;
		
	}

	#sec05 .contact-btn{
		width: 100%;
		padding: 3px 3px 1px 3px;
		margin: 10rem auto 0 auto;
	  }
	  #sec05 .contact-btn::before{
		top: -3rem;
		left: 1rem;
		width: 80px;
		height: 50px;
		z-index: 2;
	  }

#sec05 .contact-btn__inner{
		background: hsl(10, 79%, 48%);
		padding: 10px 5px 10px 15px;
		text-align: center;
		padding-right: 20px;
	  }

#sec05 .contact-btn__inner p{
color: #fff;
font-size: 1.4rem;
position: relative;
z-index: 1;
	  }

#sec05 .contact-btn__inner p::after{

top: 1rem;
    right: 0.5rem;
    width: 25px;
    height: 20px;
}



#sec05 .note{
	width: 100%;
	margin: 0 auto;
	text-align: left;
}
#sec05 .note p{
	border-top: 2px solid #1d7a40;
	border-bottom: 2px solid #1d7a40;
	padding: 10px 0;
	margin-top: 20px;
	font-size: 1.4rem;
	line-height: 1.5;
}



/* section06 */	



.faq__quest{
	font-size: 1.6rem;
	font-weight: 400;
	padding-bottom: 30px;
	position: relative;
	padding-left: 60px;
	position: relative;
	}
	.faq__item{
		margin: 70px 0;
		position: relative;
		width: 100%;
	}
	.faq__item::after{
content: "";
border-bottom: 2px solid #fff;
		position: absolute;
		width: 100%;
		height: 2px;
		bottom: -2rem;
		left: 0;
	}
	
.faq__quest::before{
	content: "Q";
	position: absolute;
	font-family: 'Oswald', sans-serif;
	font-size: 3rem;
	font-weight: 600;
	background: #1d7a40;
		color: #fff;
		padding: -20px 0 0 0;
		top: 0px;
		left: 0px;
		width: 50px;
		height: 50px;
		border-radius: 50%;
		text-align: center;
		position: absolute;
	}
.faq__answer{
	 font-size: 1.6rem;
	font-weight: 400;
	position: relative;
	padding-left: 60px;
	}
	
.faq__answer::before{
		content: "A";
		position: absolute;
		font-family: 'Oswald', sans-serif;
		font-size: 3rem;
		font-weight: 600;
		background: #fff;
			color: #1d7a40;
			padding: -25px 0 0 0;
			top: 0px;
			left: 0px;
			width: 50px;
			height: 50px;
			border-radius: 50%;
			text-align: center;
			position: absolute;
			border: 2px solid#1d7a40;
		}



/* aside */
#aside01{
	text-align: left;
}
#aside01 h3.foo-ad{
	font-size: 2.6rem;
	color: rgb(28,28,28);
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	display: inline;

	

}
#aside01 span.text-l{
	font-size: 4rem;
	color: rgb(28,28,28);
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	display: inline;
	position: relative;
	padding-right: 50px;

}
#aside01 span.text-l::after{
top: 0.5rem;
    right: 0rem;
    width: 45px;
    height: 45px;


}
#aside01 span.text-s{
	font-size: 1.8rem;
	color: rgb(28,28,28);
	font-weight: 600;
	font-family: 'Noto Sans JP', sans-serif;
	display: inline;

}


#aside01 .contact-btn{
	width: 50%;
	height: auto;
	text-align: center;
	border: 2px solid #DB3B1A;
	padding: 3px 5px;
	margin: 8rem auto 0 auto;
	position: relative;
  }
  #aside01 .contact-btn::before{
	content: "";
	background-image: url(../img/pop.png);
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: -4rem;
	left: 2rem;
	width: 200px;
	height: 50px;
	z-index: 2;
  }

  #aside01 .contact-btn__inner{
	background: hsl(10, 79%, 48%);
	padding: 15px 15px 15px 30px;


  }

  #aside01 .contact-btn__inner p{
color: #fff;
font-size: 2.3rem;
position: relative;
z-index: 1;
  }

  #aside01 .contact-btn__inner p::after{
content: "";
background-image: url(../img/right.png);
background-repeat: no-repeat;
background-size: contain;
position: absolute;
top: 1rem;
right: 1.5rem;
width: 50px;
height: 30px;
z-index: 2;}


#aside01 .note p{
border-top: 2px solid #1d7a40;
border-bottom: 2px solid #1d7a40;
padding: 10px 0;
margin-top: 20px;
font-size: 1.6rem;
}


#aside01 .contact-btn{
	width: 100%;
	padding: 3px 3px 1px 3px;
	margin: 5rem auto 0 auto;
  }
  #aside01 .contact-btn::before{
	top: -3rem;
	left: 1rem;
	width: 80px;
	height: 50px;
	z-index: 2;
  }

  #aside01 .contact-btn__inner{
	background: hsl(10, 79%, 48%);
	padding: 10px 5px 10px 15px;
	text-align: center;
	padding-right: 20px;
  }

  #aside01 .contact-btn__inner p{
color: #fff;
font-size: 1.4rem;
position: relative;
z-index: 1;
  }

  #aside01 .contact-btn__inner p::after{

top: 1rem;
right: 0.5rem;
width: 25px;
height: 20px;
}



#aside01 .note{
width: 100%;
margin: 0 auto;
text-align: left;
}
#aside01 .note p{
border-top: 2px solid #1d7a40;
border-bottom: 2px solid #1d7a40;
padding: 10px 0;
margin-top: 20px;
font-size: 1.4rem;
line-height: 1.5;
}



	
}

@media screen and (max-width:320px) {
/* fv */
.top-header__info {
	margin-right: 5%;
	
	}
	.top-header__info a{
		height: 40px;
	}
	.info-tit {
		font-size: 1.4rem;
		padding-top: 8px;
		padding-left: 3px;
	}

	.top-kv__heading02 span {
		font-size: 5rem;
		}
		.top-kv__heading02 span::after {
			top: 20%;
			right: -60%;
			width: 60px;
			height:50px;
		}
			
		h2.top-kv__heading02  {
			font-size: 2.6rem;
			}
			.top-kv__text {
				font-size: 1.2rem;
			}

	h3.sec-tit-ja {
		font-size: 2.3rem;
	}
	h1.top-kv__heading01 {
	}

	.top-kv__heading-wrap h1{
		font-size: 3rem;
		color:#fff;
		margin: 0 auto;
		
		}
		span.text-xl{
			font-size: 7rem;
			
			}
			.top-kv__title-area {
				top: calc(130/ 1178 * 100%);
			}
			.top-kv__side-content{
		width: calc(60 / 320 * 100%);
			}


/* section02 */
#sec02 .sec-img{
		margin-top: 40px;		
}
	#sec02 .sec-img__item{
		width: 120px;
    height: auto;
    margin: 0px 0 0 auto;
	}
	#sec02 .sec__desc {
		width: 120%;
	}
	#sec02 .sec-img__item p {
		font-size: 1.3rem;
	}
/* section03 */
/* section04 */
/* section05 */
/* section06 */
/* section07 */
/* section08 */
}


/* thanksPage */

.message__wrapper{
	background: #b6b3b3;
	border-radius: 30px;
	padding: 40px 20px;
	width: 60%;
	margin: 50px auto 0 auto;
}
#thanks .sec-page-subtit P{
font-size: 2rem;
}
#thanks h2{
	font-size: 5rem;
	font-weight: 600;
	color: #fff;
	font-family: 'Montserrat', sans-serif;
}
#thanks .message__wrapper p{
	font-size: 1.6rem;
	font-weight: 400;
	color: #fff;
}

#thanks::before {
    content: "";
    display: block;
    width: 100%;
    height: 1rem;
    background-color: #1d7a40;
    z-index: 3;
    position: fixed;
}
#thanks .top-header__logo {
    display: inline;
    width: 250px;
    height: auto;
    margin: 2rem 0 0 15rem;
    padding-top: 5px;
}
#thanks .ts-back01 {
    background-image: url(../img/sec_bg05.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: 0% 100%;
    padding-top: 180px!important;
	height: 100vh;
}
#thanks .inner-opacity{
	background-color: rgba(255, 255, 255,0.6);
}
.goBack__wrapper{
width: 30%;
margin: 0 auto;
}

#thanks .goBack__wrapper p{
	padding: 50px 0;
	font-size: 1.6rem;
	font-weight: 600;
	color: rgb(28,28,28);
}

#thanks p:hover{
opacity: 0.6;
}


@media screen and (max-width:1025px) {
	#thanks .ts-back01{
		background-image: url(../img/sec_bg05_tb.png);
		background-repeat: no-repeat;
		background-size: contain;
		background-position: 70% 60%;
		padding-top: 200px!important;
	}
	#thanks .top-header__logo {
		display: inline;
		width: 200px;
		margin: 2rem 0 0 6rem;
		padding-top: 5px;
	}
	

}

@media screen and (max-width:768px) {
	#thanks .ts-back01{
		background-image: url(../img/sec_bg05_tb.png);
		background-repeat: no-repeat;
		background-size: contain;
		background-position: 70% 50%;
		padding-top: 150px!important;
	}
	.message__wrapper{
		width: 80%;
	}
}
@media screen and (max-width:560px) {
	#thanks .top-header__logo {
		display: inline;
		width: 150px;
		margin: 0rem 0 0 2rem;
		padding-top: 5px;
	}
	#thanks .ts-back01{
		background-image: url(../img/sec_bg05.png);
		background-repeat: repeat-y;
		background-size: contain;
		background-position: 0% 0%;
		padding-top: 100px!important;
	}
	.message__wrapper{
		width: 90%;
 
	}
	#thanks h2{
		font-size: 3.8rem;
		font-weight: 600;
		color: #fff;
		font-family: 'Montserrat', sans-serif;
	}
	#thanks .message__wrapper p{
		font-size: 1.6rem;
		font-weight: 400;
		color: #fff;
		line-height:1.7;
		padding-top: 20px;
	}
	.goBack__wrapper {
width: 90%;
	}

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


     /* privacyPolicyページ */
	 .privacy01{
		margin-bottom: 60px;
		text-align: left;
		margin: 5rem 0;
	}
	.privacy01 span{
font-size: 1.8rem;
font-weight: 600;

	}
	.privacy01 p{
padding-bottom: 30px;
letter-spacing: 0.1rem;
font-size: 1.6rem;
			}

#privacyPolicy::before{
	content: "";
				display: block;
				width: 100%;
				height: 1.5rem;
				background-color: #1d7a40;
				z-index: 3;
				position: fixed;
			
			}







	

