

* {
  margin: 0;
  padding: 0;
}
html{
	margin:0px;
	padding:0px;
}
body{
	background:#ffffff;
	text-align:center;
	color:#222;
	font-size: 14px;
	line-height:1.5;
	letter-spacing:1px;
	font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}
img{
	border-style:none;
	display:block;
	padding:0px 0px 0px 0px;
	margin:0px 0px 0px 0px;
}

a {
	color:#000;
	text-decoration:none;
}
a:hover {
	text-decoration: none;
}

li{list-style:none;}


.bg_box_edf0f2{
background-color: #edf0f2;
border-radius: 20px;
overflow: hidden;
width:94%;
max-width:3000px;
box-sizing: border-box;
margin:3% auto 0 auto;
text-align:center;
}

.box_in{
width:90%;
padding:0;
margin:30px auto 30px auto;
text-align:center;
}

/* ---Header----*/


.s-fade-wrap{
margin:0px 0 0 0;
padding:0px 0 0px 0;
width:100%;
}

#header {
text-align:left;
width:100%;
background-color:#fff;
height:70px;
position:fixed;
top:0;
z-index:999;
}

.header_top{
height: 70px;
display: flex;
justify-content: space-between;
align-items: center;
}

.h_logo{
height:30px;
margin:5px 0px 0px 20px ;
}
.h_logo a{
display:inline-block;
height:30px;
margin:0px;
}
.h_logo img{
height:30px;
margin:0px 0 0px 0px;
}



/* ここから下がハンバーガーメニューに関するCSS */
  
/* チェックボックスを非表示にする */
.drawer_hidden {
  display: none;
}

/* ハンバーガーアイコンの設置スペース */
.drawer_open {
  display: flex;
  height: 70px;
  width: 70px;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 100;/* 重なり順を一番上にする */
  cursor: pointer;
}

/* ハンバーガーメニューのアイコン */
.drawer_open span,
.drawer_open span:before,
.drawer_open span:after {
  content: '';
  display: block;
  height: 3px;
  width: 25px;
  border-radius: 3px;
  background: #7cc8df;
  transition: 0.5s;
  position: absolute;
}

/* 三本線の一番上の棒の位置調整 */
.drawer_open span:before {
  bottom: 8px;
}
/* 三本線の一番下の棒の位置調整 */
.drawer_open span:after {
  top: 8px;
}
/* アイコンがクリックされたら真ん中の線を透明にする */
#drawer_input:checked ~ .drawer_open span {
  background: rgba(255, 255, 255, 0);
}
/* アイコンがクリックされたらアイコンが×印になように上下の線を回転 */
#drawer_input:checked ~ .drawer_open span::before {
  bottom: 0;
  transform: rotate(45deg);
}
#drawer_input:checked ~ .drawer_open span::after {
  top: 0;
  transform: rotate(-45deg);
}
  
/* メニューのデザイン*/
.nav_content {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 70px;
  left: 100%; /* メニューを画面の外に飛ばす */
  z-index: 99;
  background: #edf0f2;
  transition: .5s;
}

/* メニュー黒ポチを消す */
.nav_list {
padding:10% 10% 0 10%;
list-style: none;
margin:0% 0 0 0;
}

.nav_list li{
border-bottom:1px solid #888;
color:#222;
font-size:15px;
font-weight: 500;
text-align:left;
margin:0 0 20px 0;
padding:0 0 20px 0;
letter-spacing:3px;
}
.nav_list li a{color:#222;display: block;}
.nav_list li:last-child{
border-bottom:none;
}

/* アイコンがクリックされたらメニューを表示 */
#drawer_input:checked ~ .nav_content {
  left: 0;/* メニューを画面に入れる */
}


.h_content02{
padding:0 10% 0% 10% ;
}

.h_links01{
text-align: center;
margin: 20px 0px 0px 0px;
}
.h_links01 a{
width: 100%;
display: block;
text-align: center;
padding:12px 15px;
border: 2px solid #888;
box-sizing: border-box;
border-radius: 100px;
color:#333;
font-size: 16px;
letter-spacing: 1px;
}

.h_links01 div{
text-align: center;
margin: 0 auto;
}


.h_links02{
margin:20px 0px 0px 0px;
text-align: center;
}
.h_links02 button{
width: 100%;
display: block;
text-align: center;
padding:12px 15px;
background-color: #00b900;
border: 2px solid #00b900;
box-sizing: border-box;
border-radius: 100px;
color:#fff;
font-size: 16px;
letter-spacing: 1px;
}

.h_links02 div{
display:flex;
align-items:center;
justify-content:center;
margin: 0 auto;
}
.h_links02 div img{
width: 28px;
margin: 0 10px 0 0;
}

.mv_view{
margin:70px auto 0 auto;
width:94%;
border-radius: 20px;
overflow: hidden;
padding:0px 0 0px 0;
background-image:url("../images/mv_bg.jpg");
background-repeat:no-repeat;
background-size:cover;
background-position:left 20% top;
}
@media screen and (min-width: 620px) {
.mv_view{
margin:70px auto 0 auto;
width:94%;
border-radius: 20px;
overflow: hidden;
padding:0px 0 0px 0;
background-image:url("../images/mv_bg.jpg");
background-repeat:no-repeat;
background-size:cover;
background-position:left 40% top;
}
}

.mv_view_in{
display: flex;
align-items: center;
flex-direction:row-reverse;
}
.mv_view-01{
margin:10%;
}
.mv_text01{
text-align:center;
margin: 0 0 70% 0;
}
@media screen and (min-width: 620px) {
.mv_text01{
text-align:center;
margin: 0 0 40% 0;
}
}

.mv_text01 h1{
font-weight:400;
font-style: normal;
letter-spacing:4px;
font-size:4vw;
line-height:2;
text-align:center;
color: #111;
margin:0 0 0 0px ;
}
.mv_text01 h1 span{
font-weight:500;
font-style: normal;
letter-spacing:10px;
font-size:8vw;
line-height:1.5;
text-align:center;
color: #111;
}
@media screen and (min-width: 620px) {
.mv_text01 h1{
font-weight:400;
font-style: normal;
letter-spacing:4px;
font-size:24px;
line-height:2;
text-align:center;
color: #111;
margin:0 0 0 0px ;
}
.mv_text01 h1 span{
font-weight:500;
font-style: normal;
letter-spacing:10px;
font-size:46px;
line-height:1.5;
text-align:center;
color: #111;
}
}

.mv_view-01 img{
max-width: 420px;
width:100%;
margin: 0 auto 15px auto;
}

.mv_view-01 p{
font-weight:400;
font-style: normal;
letter-spacing:3px;
font-size:3vw;
line-height:2;
text-align:center;
color: #fff;
}
@media screen and (min-width: 620px) {
.mv_view-01 p{
font-weight:400;
font-style: normal;
letter-spacing:3px;
font-size:18px;
line-height:2;
text-align:center;
color: #fff;
}
}

.mv_none{
height: 70px;
margin: -3% 0 0 0;
padding: 0;
}



/* ---title---*/
.title_text_c{
width: 100%;
padding: 0px 0 30px 0;
text-align:center;
}
.title_text_c h2 {
font-weight:500;
font-style: normal;
letter-spacing:5px;
font-size:24px;
line-height:24px;
text-align:center;
color: #111;
padding:20px 0 20px 0 ;
}
.title_text_c p{width:10%;max-width:60px; margin:0 auto;}
.title_text_c p img{width:100%;margin: 0 auto;}

/* ---t_cv---*/

.bg_box_cv{
margin:3% auto 0 auto;
padding:0;
width:94%;
max-width:3000px;
background-image:url("../images/cv_bg.jpg");
border-radius: 20px;
overflow: hidden;
background-repeat:no-repeat;
background-size:cover;
background-position: center center;
}
.box_in_c{
width:90%;
padding:0;
margin:10% auto 10% auto;
text-align:center;
}
.bg_box_cv h2{
font-weight:600;
font-style: normal;
letter-spacing:2px;
font-size:16px;
line-height:16px;
text-align:center;
color: #111;
padding:0px 0 0px 0 ;
}
.cv_btn{
margin:20px auto 0px auto;
height: 100%;
display:flex;
align-items:center;
}
.cv_btn button{
display:flex;
align-items:center;
margin: 0px auto;
padding:12px 40px 12px 20px;
background-color: #00b900;
border: 2px solid #00b900;
box-sizing: border-box;
border-radius: 100px;
font-weight:600;
color:#fff;
font-size: 18px;
line-height: 18px;
letter-spacing:3px;
-webkit-transition: 0.3s ease-in-out;
-moz-transition: 0.3s ease-in-out;
-o-transition: 0.3s ease-in-out;
transition: 0.3s ease-in-out;
}
.cv_btn button:hover{
color:#fff;
background-color: #029702;
border: 2px solid #029702;
}
.cv_btn div{
display:flex;
align-items:center;
}
.cv_btn div img{
height:30px;
margin: 0 10px 0 0;
}


/* ---t_one---*/


.t_one{
width:100%;
padding:0px 0 0 0;
margin:0px auto;
text-align:center;
}

.t_one_text01{
font-weight:500;
font-size:14px;
line-height: 1.8;
letter-spacing:1px;
text-align:left;
margin:0px auto 0px auto;
}
.t_one_text01 span{font-size:14px;}

.t_one_box{
width:100%;
display:flex;
align-items:top;
justify-content:space-between;
flex-wrap: wrap;
margin:0px auto;
}
.t_one_box_in{width:100%;max-width:375px; margin:20px auto 0px auto;}
.t_one_view{width:100%;}
.t_one_view img{width:100%;}

.t_one_text02{
font-weight:500;
font-size:14px;
line-height: 1.8;
letter-spacing:1px;
text-align:left;
margin:20px auto 0px auto;
}

/* ---t_two---*/


.t_two{
width:100%;
padding:0px 0px 0px 0px;
margin:0 auto;
}


.t_two_text{
width:100%;
margin:0 auto;
}

.t_two_text p{
font-weight:500;
font-size: 14px;
line-height:1.7;
text-align:left;
margin:0 0 20px 0;
}
.t_two_text_g{
font-weight:600;
color:#00b900;
}
.t_two_text_s{
font-size:12px;
line-height:0;
line-height:1.7;
display: block;
}

.t_two_view{
width: 100%;
margin:0 auto;
}
.t_two_view img{
width: 100%;
max-width:620px;
margin:0 auto;
}

/* ---t_three---*/

.t_three{
text-align:left;
padding:0px 0px 0px 0px;
margin:0 auto;
display:flex;
align-items:top;
justify-content:space-between;
flex-wrap: wrap;
}
.t_three img{width:100%;max-width: 375px; margin:0px auto 20px;}


/* ---t_four---*/
.t_four{
padding:0px 0px 0px 0px;
margin:0 auto;
display:flex;
align-items:top;
justify-content:space-between;
flex-wrap: wrap;
}
.t_four_in{
width:100%;
max-width: 620px;
background-color: #fff;
border-radius:20px;
padding:0px;
box-sizing: border-box;
margin: 0 auto 20px auto;
}
.t_four_in h3{
padding:30px 20px 20px 20px;
text-align: center;
letter-spacing:2px;
font-size:18px;
line-height:1.5;
color:#111;
font-weight:600;
}

.t_four_box{
padding:0 0px;
}
.t_four_view{
width: 100%;

overflow: hidden;
}
.t_four_view img{
width: 100%;
margin: 0px 0 0px 0;
}

.t_four_in h4{
padding:30px 20px 0px 20px;
text-align: center;
letter-spacing:2px;
font-size:16px;
line-height:1.5;
color:#111;
font-weight:600;
}

.t_four_box p{
text-align:left;
letter-spacing:0px;
font-size:14px;
line-height:1.7;
padding:20px 20px 30px 20px;
}
.t_four_box p span{
color:#2a5883;
font-weight: 500;
}

/* ---t_five---*/
.t_five{
	padding:0px 0px 0px 0px;
	margin:0 auto;
	list-style:none;
}
.t_five li{
border-bottom: 2px solid #fff;
padding:15px 0px 15px 0px;
}
.t_five li:last-child{
border-bottom:none;
}
.t_five li div{
display:flex;
align-items:center;
padding:5px 0;
}
.t_five li div img{
width:20px;
margin: 0 15px 0 0;
}
.t_five h3{
letter-spacing:2px;
font-size:14px;
line-height:1.5;
color:#023e73;
text-align:left;
font-weight:500;
}
.t_five p{
letter-spacing:1px;
font-size:14px;
text-align:left;
}

/* ---t_six---*/
.t_six{
	width:100%;
	padding:0px 0px 30px 0px;
	margin:0 auto;
	list-style:none;
}
.t_six h3{
font-size:18px; 
font-weight: 600;
letter-spacing: 3px;
margin: 0px 0 15px 0;
padding: 0px 0;
text-align: center;
display: flex;
align-items: center;
}
.t_six h3::before,
.t_six h3::after {
  content: '';
  flex-grow: 1;/* 余白を分け与える */
  height: 1px;
  background:#fff;
}
.t_six h3::before {margin-right: 30px;}
.t_six h3::after {margin-left: 30px;}

.t_six img{
width: 100%;
max-width: 375px;
margin: 0 auto;
}
.t_six_text{
letter-spacing:1px;
font-size:14px;
text-align:left;
margin:0 auto;
padding:20px 0px 0px 0px ;
}



/* ---pp---*/
.pp{
	width:100%;
	padding:0px 0px 0px 0px;
	margin:0 auto;
	list-style:none;
}
.pp h3{
text-align: left;
font-size:16px;
line-height:16px;
color:#333;
font-weight:600;
border-bottom:2px solid #ccc;
padding:5px 15px 15px 0px;
margin:10px 0 20px 0;
}
.pp p{
text-align: left;
font-size:14px;
line-height:1.5;
padding:0px 0px 20px 0px ;
}


/* ---service---*/

.service{
	width:100%;
	padding:0px 0px 0px 0px;
	margin:0 auto;
	list-style:none;
}

.service　ul{
list-style:none;
	padding:0px 0px 0px 0px;
	margin:0 auto;
}
.service li{
background-color: #fff;
border-radius:10px;
padding:0px 0px 0px 0px;
margin: 0 0 20px 0;
overflow: hidden;
box-sizing: border-box;
}

.service li h3{
background-color: #7cc9df;
font-size:16px;
line-height:16px;
color:#fff;
text-align:left;
font-weight:500;
padding: 15px;
box-sizing: border-box;
}
.service li p{
letter-spacing:1px;
font-size:14px;
line-height:1.5;
text-align:left;
padding: 15px;
color:#222;
box-sizing: border-box;
}
/* ---company---*/
.company{
	width:100%;
	padding:0px 0px 0px 0px;
	margin:0 auto;
	list-style:none;
}
.company li{
border-bottom: 3px solid #7cc9df;
padding:20px 0px 20px 0px;
}
.company li h3{
font-size:16px;
line-height:16px;
color:#111;
text-align:left;
font-weight:500;
padding: 0 0 10px 0;
}
.company li p{
padding: 0 0 0px 0;
text-align:left;
}
.company li:last-child{
border-bottom:none;
}

/* ---footer---*/


.footer{
background-color:#023e73;
border-radius: 20px;
overflow: hidden;
width:94%;
max-width:3000px;
box-sizing: border-box;
margin:3% auto 3% auto;
text-align:center;
}
.footer_in{
text-align:center;
margin:0 auto;
padding:50px 0px ;
}

.footer_in_left{
padding:0px 0px 20px 0px ;
}
.footer_in_left p{
text-align:center;
font-size:14px;
color:#fff;
font-weight:500;
margin:0px;
padding:0px 0;
}
.f_logo{
margin:0 auto;
padding:0px 0 0px 0;
}
.f_logo a{
width:50%;
max-width: 200px;
display:block;
margin:10px auto;
}
.f_logo img{
width: 100%;
margin:0 auto;
}

.footer_in_right{
text-align:center;
margin:0 0px 0 0;

}
.f_navi{
text-align:center;
font-size:12px;
color:#fff;
font-weight:500;
margin:0px;
padding:0px 0;
}

.f_navi a:hover{color:#ccc;}
.f_navi a {
-webkit-transition: 0.3s ease-in-out;
-moz-transition: 0.3s ease-in-out;
-o-transition: 0.3s ease-in-out;
transition: 0.3s ease-in-out;
color:#fff;
}


.f_copy{
text-align:center;
padding:0px 0 0 0 ;
}
.f_copy_in{

}
.copy{
text-align:center;
font-size:12px;
color:#fff;
margin:0px 0;
}

    #pageTop {
	position:fixed;
	bottom:20px;
	right:20px;
	width:50px;	
	margin:0px auto 0px auto;
		border-radius: 5px;
	overflow: hidden;
    }
    #pageTop a img {
width:100%;
margin:0px auto 0px auto;
	-webkit-transition: 0.3s ease-in-out;
	   -moz-transition: 0.3s ease-in-out;
	     -o-transition: 0.3s ease-in-out;
	        transition: 0.3s ease-in-out;
    }
    #pageTop a img:hover {
      opacity: 1;
    }



.fuwatAnime {
 -webkit-animation-fill-mode:both;
 -ms-animation-fill-mode:both;
 animation-fill-mode:both;
 -webkit-animation-duration:1.5s;
 -ms-animation-duration:1.5s;
 animation-duration:1.5s;
 -webkit-animation-name: fuwatAnime;
 -ms-animation-name: fuwatAnime;
 animation-name: fuwatAnime;
 visibility: visible !important;
}
@-webkit-keyframes fuwatAnime {
 0% { opacity: 0; -webkit-transform: translateY(-20px); }
 100% { opacity: 1; -webkit-transform: translateY(0); }
}
@keyframes fuwatAnime {
 0% { opacity: 0; -webkit-transform: translateY(-20px); -ms-transform: translateY(-20px); transform: translateY(-20px); }
 100% { opacity: 1; -webkit-transform: translateY(0); -ms-transform: translateY(0); transform: translateY(0); }
}


.sp-none{
display:none !important;
}
.pc-br{
display:none !important;
}
.link_pc{
display:none !important;
}
.contact_btn02{
display:none !important;
}

.mt80{margin-top:80px;}





.fade-in {
  opacity: 0;
  transition-duration: 500ms;
  transition-property: opacity, transform;
}

.fade-in-up {
  transform: translate(0, 50px);
}

.fade-in-down {
  transform: translate(0, -50px);
}

.fade-in-left {
  transform: translate(-50px, 0);
}

.fade-in-right {
  transform: translate(50px, 0);
}

.scroll-in {
  opacity: 1;
  transform: translate(0, 0);
}

.animation{
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  animation-duration: 1.5s;
}

.keyframe6 {
  animation-name: poyopoyo;
}

@keyframes poyopoyo {
  0%, 40%, 60%, 80% {
    transform: scale(1.0);
  }
  50%, 70% {
    transform: scale(0.95);
  }
}


/* モーダルウィンドウ */
.modal-window {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width:90%;
	box-sizing:border-box;
	z-index: 1002;
	padding: 10% 10%;
	overflow-y: scroll;
	background-color: rgba( 255, 255, 255, 0.8 );
	border-radius: 20px;
}
/* 閉じるボタン */
.button-close {
border: none;
cursor: pointer;
outline: none;
appearance: none;
max-width: 250px;
min-width: 200px;
padding:10px 20px;
background:#013c71;
font-size:14px;
color: #fff;
font-weight:500;
border-radius:100px;
cursor: pointer;
margin:35px auto 0px auto;
}
/* オーバーレイ */
.overlay {
display: none;
position: fixed;
top: 0;
left: 0;
background-image:url("../images/cv_bg.jpg");
overflow: hidden;
background-repeat:no-repeat;
background-size:cover;
background-position: center center;
width: 100%;
height: 100%;
z-index: 1001;
}

.modal-window h2{
width:60%;
text-align:center;
margin:0px auto;
}

.modal-window h2 img{width: 100%;margin:0px 0px 0px -20px;}

.modal-window h3{
text-align:center;
margin:10px 0 30px 0;
}
.modal-window h3 span{
color:#00b900;
font-size:20px;
line-height:1.5;
}
.modal-window h4{
text-align:left;
color:#4b9536;
font-size:16px;
margin:0 0 20px 0;
}
.modal-window p{
text-align:left;
line-height:1.5;
margin:0 0 10px 0;
}

.modal_in_box{
width:80%;
text-align:center;
margin:20px auto 10px auto;
}
.modal_in_box img{
width: 100%;
}
.modal_in_box a{
display:inline-block
}

.modal-window p span{
font-size:14px;
}


/* ---コンテンツ表示アニメーション---*/
.animate {
  opacity: 0;
  transition: opacity 0.8s ease 0.2s, transform 0.8s ease 0.2s; /* 0.5秒の遅延 */
  will-change: opacity, transform;
}

.fade-in-from-bottom {
  transform: translateY(30px); /* 下から */
}

.fade-in-from-top {
  transform: translateY(-30px); /* 上から */
}

.fade-in-from-left {
  transform: translateX(-15px); /* 左から */
}

.fade-in-from-right {
  transform: translateX(15px); /* 右から */
}

.animate.visible {
  opacity: 1;
  transform: translateY(0) translateX(0); /* 元の位置に */
}

.t_cv_btn{
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-ms-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
	cursor: pointer;
  animation: bounce 2s ease-in-out forwards;
  animation-iteration-count: infinite;
}

@keyframes bounce {
  0% {
    transform: scale(1);
    -webkit-transform: scale(1);
  }
  50% {
    transform: scale(1.1);
    -webkit-transform: scale(1.1);
  }
}
