@charset "UTF-8";
/* CSS Document */
/*共通 */

@font-face {
  font-family: 'Noto Sans JP';
  src: url(../fonts/NotoSansJP-Regular.ttf) format("300"),
	  url("../font/NotoSansJP-Bold.ttf") format("700");
}



body {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.6;
}

/*===============================================
●style.css 画面の横幅が769px以上
===============================================*/
@media screen and (min-width: 751px){
	
	.sp{
		display: none;
	}
	
/*ヘッダー部分*/
	.header{
		width: 100%;
		border-bottom: hsla(0,0%,90%,1.00) solid 1px;
		padding-bottom: 0px;
		position: fixed;
		top: 0px;
		background-color: rgba(255,255,255,0.70);
		backdrop-filter: blur(10px);
		z-index: 999;
		
	}
	
.Header-site {
  background-color: #003e81;
  padding: 0 10px;
  border-bottom: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 200;
}	
	
	.header_boxs{
		background-color: #003e81;
        padding: 10px 10px;
		color: rgba(255,255,255,1.00);
		overflow: hidden;
	}
	.header_boxs h1{
		color: #FFFFFF;
		font-size: 13px;
		float: left;
	}
	
	.cb-social{
		float: right;
		padding-right: 100px;
	}
	
	
	.header-container{
		max-width: 1400px;
		width: 90%;
		margin: auto;
		display: flex;
		justify-content: space-between;
	}
	
	.logo-container{
		width: 120px;
		padding: 5px 0px;
	}
	
	.logo-container img{
		width: 100%;
	}
	
	.nav {
	}
	
	.nav ul {
		display: flex;
	}
	
	.nav ul li{
		padding: 5px 10px;
	}
	
	.nav ul li a{
		color: #0A0A0A;
		font-size: 14px;
		text-decoration: none;
	}
	
	.nav ul li a:hover{
		color: #DC0723;
		font-size: 14px;
		text-decoration: none;
		transition-duration: 0.5s;
	}
	
	.sab_menu_bt ul {
		display: flex;
	}
	
	.sab_bt_contact a{
		display: block;
		font-size: 14px;
		padding: 6px 15px;
		vertical-align: middle;
		border-radius: 5px;
		text-decoration: none;
		color: #0A0A0A;
		border: 1px solid #e5e7eb;
		display: flex;
		background-color: hsla(0,0%,100%,1.00);
		margin-right: 10px;
	}
	
	.sab_bt_contact a:hover{
		display: block;
		font-size: 14px;
		padding: 6px 15px;
		vertical-align: middle;
		border-radius: 5px;
		text-decoration: none;
		color: #0A0A0A;
		border: 1px solid #e5e7eb;
		display: flex;
		background-color: hsla(0,0%,96%,1.00);
		transition-duration: 0.5s;
		margin-right: 10px;
	}
	
	.sab_bt_search{
		z-index: 10;
		position: absolute;
	}
	
	.sab_bt_search a{
		display: block;
		font-size: 1.4vw;
		padding: 8px 20px;
		vertical-align: middle;
		border-radius: 5px;
		text-decoration: none;
		color: #FFFFFF;
		border: 1px solid #e5e7eb;
		display: flex;
		background-color: #DC0723;
	}
	
	.sab_bt_search a:hover{
		display: block;
		font-size: 1.4vw;
		padding: 8px 20px;
		vertical-align: middle;
		border-radius: 5px;
		text-decoration: none;
		color: #FFFFFF;
		border: 1px solid #e5e7eb;
		display: flex;
		background-color:hsla(352,94%,45%,0.9);
		transition-duration: 0.5s;
	}
	
	
	.icon{
		width: 2.5vw;
		padding-right: 10px;
	}
	
/*メインビジュアル部分*/
	
	#top_visual{
		width: 100%;
		background-image: url("../images/common_backimg.jpg");
		background-position:center;
		padding: 100px 0px 70px 0px;
		position: relative;
		overflow: hidden;
	}
	
	.top_visual_under{
		width: 80%;
	}
	
	.top_visual_under img{
		width: 55%;
		position: absolute;
		bottom:-3px;
		left: 4%;
		z-index: 2!important;
	}
	
	.icon_img01{
		width: 16%;
		position: absolute;
		top: -8vw;
		left:-4vw;
		animation: fuwafuwa 3s ease-in-out infinite alternate;
		transition: 1.5s ease-in-out;
	}
	
@keyframes fuwafuwa {
  0% {
    transform:translate(0, 0) rotate(-7deg);
  }
  50% {
    transform:translate(0, -7px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(7deg);
  }
}
	
	
	.icon_img02{
		width: 21%;
		position: absolute;
		top: -2vw;
		right: -9vw;
		animation: fuwafuwa2 2.5s ease-in-out infinite alternate;
		transition: 1.5s ease-in-out;
	}
	
	
	@keyframes fuwafuwa2 {
  0% {
    transform:translate(0, 0) rotate(-2deg);
  }
  50% {
    transform:translate(0, -8px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(2deg);
  }
}
	
	
	.top_visual-container{
		max-width: 1400px;
		width: 90%;
		display: flex;
		margin: auto;
	}
	
	.top_visual_left h1{
		font-weight: 700;
		font-size: 3.3vw;
		line-height: 1.2;
		color: #003E80;
	}
	
	.top_visual_left{
		width: 55%;
		padding-top: 30px;
		padding-left: 3%;
	}
	
	.top_visual_left p{
		font-size: 1.5vw;
		color: #737373;
		margin-top: 10px;
	}
	
	.top_visual_right{
		width: 45%;
		overflow: hidden;
	}
	
	.top_visual_img img{
		width: 100%;
		        border-radius: 10px;
	}
	
	.top_visual_bt{
		width: 250px;
		margin-top: 10px;
		z-index: 10;
	}
	
/*特徴部分*/	
	
	#features{
		background-color: #003E80;
		width: 100%;
		padding: 10% 0px 15vw 0px;
	}
	
	.features-container{
		width: 90%;
		max-width: 1400px;
		margin: auto;
		position: relative;
	}
	
	
	.features_icon_box{
		position: relative;
		width: 50vw;
		margin: auto;
		height: 10px;
	}
	.title_icon_features{
		position: absolute;
		top:-4vw;
		left: 29%;
		width: 11%;
	}
	
	.features-container h2{
		font-size: 2.5vw;
		color: rgba(255,255,255,1.00);
		font-weight: 700;
		text-align: center;
		z-index: 10;
	}
	
	
	.midasi_left_icon img{
		width: 3%;
		margin-right: 1%;
	}
	
	.midasi_right_icon img{
		width: 3%;
		margin-left: 1%;
	}
	
	.h2_line_01{
		background-color:hsla(359,100%,81%,1.00);
		width: 40vw;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;
	}
	
	.features-grid{
		display: flex;
		justify-content: space-between;
		padding-top: 70px;
	}
	
	.features-grid li{
		border: 1px solid #e5e7eb;
		background-color: rgba(255,255,255,1.00);
		width: 23.5%;
		border-radius: 10px;
		padding-bottom: 40px;
	}
	
	.feature-card {
		text-align: center;
	}
	
	.feature-card h3{
		text-align: center;
		font-size: 18px;
		width: 95%;
		margin: auto;
		color: #003E80;
		font-weight: 700;
	}
	
	.feature-card p{
		font-size: 14px;
		color: #737373;
		width: 85%;
		margin: auto;
		padding: 10px 0px 0px 0px;
	}
	
	.feature-card a{
		color: #003E80;
		
	}
	
	.feature-icon{
		text-align: center;
		padding-top: 30px;
		padding-bottom: 10px;
		width: 80px;
		margin: auto;
	}
	
	.feature-icon img{
		width: 100%;
	}
	
	
	/*サービス部分*/	
	
	#services{
		width: 100%;
		padding: 10vw 0px;
		background-color: #FFFFFF;
		clip-path: polygon(0 10%, 100% 0%, 100% 90%, 0% 100%);
		margin-top: -11vw;
	}
	

	
	.services-container{
		width: 90%;
		max-width: 1400px;
		margin: auto;
		padding: 10vw 0px 10vw 0px;
		position: relative;
	}
	
	
	.icon_img03{
		width: 20%;
		position: absolute;
		top: -1vw;
		left: 75%;
		animation: fuwafuwa2 2.5s ease-in-out infinite alternate;
		transition: 1.5s ease-in-out;
	}
	
	
	@keyframes fuwafuwa2 {
  0% {
    transform:translate(0, 0) rotate(-2deg);
  }
  50% {
    transform:translate(0, -8px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(2deg);
  }
}
	
	.icon_img04{
		width: 17%;
        position: absolute;
        top: -21vw;
        left: 5%;
	}
	
	.icon_img05{
		width: 6%;
        position: absolute;
        top: -12.8vw;
        left: 23%;
	}
	
	.services-container h2{
		font-size: 2.5vw;
		color: #003E80;
		font-weight: 700;
		text-align: center;
		position: relative;
	}
	
	.h2_line_02{
		background-color:hsla(50,100%,87%,1.00);
		width: 62vw;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;
	}
	
	
	
	.midasi_icon_01{
		width:22%;
		position: absolute;
		top: -146%;
		left: 40%;
	}
	
	
	.services-grid{
		display:flex;
		flex-wrap: wrap;
		width: 90%;
		margin: auto;
		margin-top: 70px;
	}
	
	.services-grid li{
		width: 50%;
	}
	.service-item{
		display: flex;
	}
	
	.service-icon{
		width: 80px;
	}
	
	.service-icon img{
		width: 100%;
	}
	
	.service-content{
		padding-left: 3%;
		padding-bottom: 10%;
		width: 80%;
	}
	
	.service-content h3{
		font-size: 20px;
		font-weight: 700;
		padding-top: 10px;
	}
	
	.service-content p{
		font-size: 16px;
		color: #737373;
	}
	
	.service_title01{
		color: #005097;
	}
	
	.service_title02{
		color: #007f55;
	}
	
	.service_title03{
		color: #ff7000;
	}
	
	.service_title04{
		color: #dc0720;
	}
	
	.service_under_img{
		position: relative;
		width: 100%;
	}
	
/*ユーザーの声*/
	#testimonials{
		width: 100%;
		padding: 17vw 0px 15vw 0px;
		background-color: #e4e6f1;
		margin-top: -10vw;
		background-image: url("../images/common_svg_img_16.svg");
		background-position: bottom;
		background-size: 80%;
		background-repeat: no-repeat;
	}
	
	.testimonials-container{
		width: 90%;
		max-width: 1400px;
		margin: auto;
		position: relative;
	}
	
	.title_icon_testimonials{
		position: absolute;
		top: -8vw;
        left: 56%;
        width: 15%;
	}
	
	.h2_line_03{
		background-color:hsla(359,100%,81%,1.00);
		width: 33vw;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;
	}
	
	.icon_img06{
		width: 36vw;
		margin: auto;
		height: 2px;
		position: relative;
	}
	
	.icon_img06 img{
		position: absolute;
		top: -1vw;
        left: -1vw;
        width: 8%;}
	
	
	.testimonials-container h2{
		font-size: 2.5vw;
		color: #003E80;
		font-weight: 700;
		text-align: center;
	}
	
	.testimonials-grid{
		display: flex;
		width: 100%;
		margin: auto;
		justify-content: space-between;
		margin-top: 70px;
	}
	
	.testimonials-grid li{
		border: 1px solid #e5e7eb;
		background-color: #FFFFFF;
		width: 32%;
		border-radius: 10px;
		padding-bottom: 30px;
	}
	
	.testimonial-header{
		display: flex;
		width: 90%;
		margin: auto;
		margin-top: 30px;
	}
	
	.testimonial-avatar{
		width: 27%;
	}
	
	.testimonial-avatar img{
		width: 100%;
	}
	
	.testimonial-person{
		margin-left: 10px;
		padding-top: 23px;
	}
	
	.testimonial-name{
		font-size: 18px;
		color: #0A0A0A;
	}
	
	.testimonial-location{
		font-size: 14px;
		color: #737373;
	}
	
	.testimonial-text{
		font-size: 16px;
		color: #737373;
		width: 90%;
		margin: auto;
		margin-top: 10px;
	}
	
	
/* 地図ボタン */
	
	#map_bts{
		width: 100%;
		padding: 70px 0px;
		background-color: #003E80;
		
	}
	
	.map_bts-container
	{
     max-width: 1400px;
	 width: 90%;
	 margin: auto;
}
	
	.map_bts-container ul{
		display: flex;
		justify-content: space-between;
		width: 70%;
		margin: auto;
		text-align: center;
	}
	
	.map_bts-container ul li{
		width: 31%;
		
	}
	
	.map_bts-container ul li a{
		overflow: hidden;
	}
	
	.map_bt_icon{
		width: 8%;
		padding-top: 2%;
		margin: auto;
	}
	
	.map_bt_icon img{
		width: 135%;
	}
	
	.map_bt_icon_text{
		width: 90%;
		margin: auto;
	}
	
	.map_bt_icon_text img{
		width: 40%;
	}
	
	.map_bts-container ul li a{
		background-color: #DC0723;
		color: #FFFFFF;
		display: block;
		border: 1px solid #e5e7eb;
		border-radius: 10px;
		padding: 20px;
		text-decoration: none;
		font-size: 14px;
		box-shadow: 1px 1px 5px #000000;
	}
	
	
	.map_bts-container ul li a:hover{
		background-color:hsla(352,94%,45%,0.9);
		color: #FFFFFF;
		display: block;
		border: 1px solid #e5e7eb;
		border-radius: 10px;
		padding: 20px;
		font-size: 14px;
		text-decoration: none;
		transition-duration: 0.5s;
		box-shadow: 0px 0px 0px #000000;
	}
	
	
	
	.map_bts-container h2{
		font-size: 2.5vw;
		text-align: center;
		font-weight: 700;
		color: #FFFFFF;
		padding-bottom: 50px;
	}
	
	.h2_line_05{
		background-color:hsla(359,100%,81%,1.00);
		width: 28vw;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;
	}
	
	
	
	
	/* よくある質問セクション */
   #faq {
	   width: 100%;
		padding: 13vw 0px 0vw 0px;
  background-image: linear-gradient(135deg, rgba(239, 255, 252, 1), rgba(228, 230, 241, 1));
		  position: relative;
}

      .faq-container {
     max-width: 1400px;
	 width: 90%;
	 margin: auto;
}
	
	.h2_line_04{
		background-color:hsla(50,100%,87%,1.00);
		width:19vw;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;}
	
	.title_icon_faq{
		width: 10%;
		top: 8vw;
		left: 39%;
		position: absolute;
	}
	
	.icon_img08{
		width: 14%;
		top: 5vw;
		left: 71%;
		position: absolute;
		animation: fuwafuwa2 2.5s ease-in-out infinite alternate;
		transition: 1.5s ease-in-out;
	}
	
	
	@keyframes fuwafuwa2 {
  0% {
    transform:translate(0, 0) rotate(-2deg);
  }
  50% {
    transform:translate(0, -8px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(2deg);
  }
}
	
	
	.faq-container h2{
		font-size: 2.5vw;
		color: #003E80;
		font-weight: 700;
		text-align: center;}

	.accordion-container{
		width: 80%;
		max-width: 800px;
		margin: auto;
		margin-top: 70px;
	}
	
	.accordion-button{
		padding: 10px 20px;
		background-color: hsla(0,0%,100%,1.00);
	}
	
	.accordion-container h3{
		font-size: 18px;
		color: #003E80;
		font-weight: 700;
		padding-bottom: 15px;
	}
	
	.accordion-button h4{
		font-size: 16px;
		color: #003E80;
		padding-top: 5px;
	}
	
	
	.accordion-button h4:hover{
		font-size: 16px;
		color: #003E80;
		text-decoration: underline;
	}
	
	
	.accordion-icon{
		font-size: 18px;
		color: #003E80;

	}
	
	.accordion-content{
		font-size: 14px;
		background-color: #FFF;
	}
	
	
	.accordion-content p{
		margin-top: 10px;
	}
	
	.accordion-content p a{
		color: #C51114;
	}
	
	
.accordion-item {
  overflow: hidden;
	border-bottom: 1px solid #e5e7eb;
}

.accordion-button {
  width: 100%;
  text-align: left;
  border: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 700;
}

.accordion-icon {
  transition: transform 0.3s ease;
}

.accordion-item.active .accordion-icon {
  transform: rotate(45deg);
}

.accordion-content {
  padding: 0 1.5rem;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.accordion-item.active .accordion-content {
   padding: 20px 20px;
  max-height: 500px;
}

	
	
	/* ボタンセクション */
	
	.cta{
		width: 100%;
		padding: 70px 0px;
		margin-top: -1vw;
		background-color: #003E80;
	position: relative;}
	
	.icon_img07 {
		width: 100%;
	}
	
	.cta-container{
		width: 90%;
		max-width: 1400px;
		margin: auto;
	}

	.cta-content h2{
		font-size: 30px;
		color: #FFFFFF;
		font-weight: 700;
		text-align: center;
	}
	.cta-content p{
		text-align: center;
		color: #FFFFFF;
		font-size: 14px;
		margin-top: 20px;
	}
	
	.cta-buttons{
		text-align: center;
		padding: 50px 10px 0px 10px; 
	}
	
	
	.cta-buttons a{
		display: inline-block;
		text-decoration: none;
	}
	
	.cta-buttons_t{
		background-color: hsla(0,0%,96%,1.00);
		padding: 10px 25px;
		margin-right: 5px;
		color: #171717;
		font-size: 14px;
		border: 1px solid hsla(0,0%,96%,1.00);
		border-radius: 5px;
	}
	
	.cta-buttons_t:hover{
		background-color: hsla(0,0%,96%,1.00);
		padding: 10px 25px;
		margin-right: 5px;
		color: #171717;
		font-size: 14px;
		border: 1px solid hsla(0,0%,96%,1.00);
		border-radius: 5px;
		transition-duration: 0.5S;
		opacity: 0.9;
	}
	
	.cta-buttons_online{
		background-color: #DC0723;
		padding: 10px 25px;
		margin-right: 5px;
		color: #FFFFFF;
		font-size: 14px;
		border: 1px solid hsla(0,0%,96%,1.00);
		border-radius: 5px;
	}
	.cta-buttons_online:hover{
		background-color: #EB1E39;
		padding: 10px 25px;
		margin-right: 5px;
		color: #FFFFFF;
		font-size: 14px;
		border: 1px solid hsla(0,0%,96%,1.00);
		border-radius: 5px;
		transition-duration: 0.5S;
		opacity: 0.9;
	}
	
	
	.cta_under_img{
		width: 100%;
		margin: auto;
		margin-top: 10vw;
		margin-bottom: 0px!important;
		padding-bottom: 0px!important;
	}
	
	/* フッター部分*/
	.footer{
		width: 100%;
		margin: auto;
		padding: 70px 0px 30px 0px;
	}
	
	.footer-container{
		width: 90%;
		margin: auto;
		max-width: 1400px;
	}
	
	.footer-grid{
	}
	
	
	.footer-col{
		width: 100%;
		text-align: center;
	}
	
	.footer-col h3{
		font-size: 16px;
		font-weight: 700;
		color: #003E80;
	}
	
	.footer-logo{
		width: 10%;
		padding: 5px 0px;
		margin: auto;
	}
	
	.footer-logo img{
		width: 100%;
	}
	
	.footer-links{
		padding: 10px 0px;
	}
	
	.footer-links li{
		font-size: 14px;
		padding-bottom: 10px;
	}
	
	.footer-links li a{
		color: #737373;
		text-decoration: none;
	}
	
	.footer-col p{
		font-size: 14px;
		color: #737373;
	}
	
	.footer-contact{
		font-size: 20px!important;
		color: #0A0A0A;
	}
	
	.footer-bottom{
		border-top: 1px solid #e5e7eb;
		margin-top: 30px;
		text-align: center;
		color: #737373;
		padding-top: 20px;
		font-size: 14px;
	}
	
	.copyright_p{
		font-size: 10px;
		margin: auto;
		padding: 0px 0px;
		text-align: center;
		color: rgba(255,255,255,1.00);
	}
	
	.footer_logo_box img{
		width: 100%;
	}
	
	.footer_logo_box{
		width: 10%;
		margin: auto;
		margin-bottom: 20px;
	}
	
	.cb-btns{
		display: flex;
		width: 850px;
	margin: auto;
		padding-bottom: 40px;
		padding-top: 50px;
	}
	
	.cb-btns li{
		width: 400px;
		margin: auto;
		background-color: #FFFFFF;
		display: inline-block;
		text-align: center;
	}
	
	
	.cb-btns li a img {
    margin: 0 20px 6px 0;
    width: auto;
    height: 35px;
	display: inline-block;
	vertical-align: bottom;}
	
	.cb-btns li a {
	padding: 0;
    width: 100%;
    height: 50px;
    display: block;
    position: relative;
    cursor: pointer;
    transition: .3s;
    background-image: url(../images/arrow.png);
    background-position: right 15px center;
    background-size: 8px auto;
    background-repeat: no-repeat;
	text-decoration: none;}
	
	.cb-btns li a span{
		font-size: 20px;
    text-align: center;
    font-weight: bold;
    color: #003E81;
    line-height: 50px;
    position: static;
	}
	
	.cb-btns li a:hover {

 -ms-filter: "progid: DXImageTransform.Microsoft.Alpha(Opacity=50)";
 filter: alpha(opacity=50);
 opacity: 0.5;
 text-decoration: none;
}
	
	
	
}
/*===============================================
●smart.css  画面の横幅が640pxまで
===============================================*/
@media screen and (max-width:750px){
	
	.pc{
		display: none;
	}
	
/*ヘッダー部分*/
	.header{
		width: 100%;
		border-bottom: hsla(0,0%,90%,1.00) solid 1px;
		padding-top: 0px;
		padding-bottom: 0px;
		position: fixed;
		top: 0px;
		background-color: rgba(255,255,255,0.70);
		backdrop-filter: blur(10px);
		z-index: 999;
		
	}
	
.Header-site {
  background-color: #003e81;
  padding: 0 10px;
  border-bottom: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 200;
}	
	
	.header_boxs{
		background-color: #003e81;
        padding: 15px 10px 10px 10px;
		color: rgba(255,255,255,1.00);
		margin-bottom: 0px;
		overflow: hidden;
	}
	.header_boxs h1{
		color: #FFFFFF;
		width: 25%;
		float: left;
	}
	.header_boxs h1 img{
		width: 100%;
	}
	
	.cb-social{
		float: right;
		padding-right: 30px;
	}
	
	.header-container{
		width: 90%;
		margin: auto;
		display: flex;
		justify-content: space-between;
	}
	
	.logo-container{
		width: 45%;
		padding: 5px 0px;
	}
	
	.logo-container img{
		width: 85%;
	}
	
	.nav {
		display: none;
	}
	
	
	.sab_menu_bt{
		width: 55%;
	}
	
	.sab_bt_contact a{
		display: none;
	}
	
	
	.sab_bt_search{
		text-align: center;
	}
	
	.sab_bt_search a{
		display: block;
		font-size: 5vw;
		border-radius: 5px;
		text-decoration: none;
		color: #FFFFFF;
		padding: 5% 5%;
		border: 1px solid #e5e7eb;
		background-color: #DC0723;
	}
	
	
	.icon{
		width: 5.3vw;
		padding-right: 3px;
		vertical-align: baseline;
	}
	
	
	/*メインビジュアル部分*/
	
	#top_visual{
		width: 100%;
		background-image:url("../images/common_backimg.jpg");
		padding: 80px 0px 50px 0px;
		position: relative;
		overflow: hidden;
	}
	
	.top_visual-container{
		width: 90%;
		margin: auto;
	}
	
	.top_visual_left h1{
		font-weight: 700;
		font-size: 30px;
		line-height: 1.3;
		color: #003E80;
	}
	
	.top_visual_left{
		width: 100%;
	}
	
	.top_visual_left p{
		font-size: 16px;
		color: #737373;
		margin-top: 10px;
	}
	
	.top_visual_right{
		width: 100%;
		margin-top: 20px;
	}
	
	.top_visual_img{
		overflow: hidden;}
	
	.top_visual_img img{
		width: 100%;
		border-radius: 10px;
	}
	
	.top_visual_bt{
		margin-top: 10px;
	}
	
	
	.top_visual_under{
		width: 100%;
		position: absolute;
		bottom: -10px;
	}
	
	.top_visual_under img{
		width: 100%;
	}
	
	/*特徴部分*/	
	
	#features{
		background-color: #003E80;
		width: 100%;
		padding: 50px 0px 200px 0px;
		overflow: hidden;
	}
	
	.features-container{
		width: 90%;
		margin: auto;
		position: relative;
	}
	
	.features-container h2{
		font-size: 26px;
		color: rgba(255,255,255,1.00);
		font-weight: 700;
		text-align: center;
	}
	
	.feature-card a{
		color: #003E80;
		
	}
	.h2_line_01{
		background-color:hsla(359,100%,81%,1.00);
		width: 80%;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;
	}
	
.icon_img01{
		width: 25%;
		position: absolute;
		top: -1%;
		left: 0%;
		animation: fuwafuwa 3s ease-in-out infinite alternate;
		transition: 1.5s ease-in-out;
	}
	
@keyframes fuwafuwa {
  0% {
    transform:translate(0, 0) rotate(-7deg);
  }
  50% {
    transform:translate(0, -7px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(7deg);
  }
}
	
	
	.icon_img02{
		width: 30%;
		position: absolute;
		top: -0%;
		left: 75%;
		animation: fuwafuwa2 2.5s ease-in-out infinite alternate;
		transition: 1.5s ease-in-out;
	}
	
	
	@keyframes fuwafuwa2 {
  0% {
    transform:translate(0, 0) rotate(-2deg);
  }
  50% {
    transform:translate(0, -8px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(2deg);
  }
}
	
	.features-grid{
		padding-top: 20px;
	}
	
	.features-grid li{
		border: 1px solid #e5e7eb;
		background-color: rgba(255,255,255,1.00);
		width: 100%;
		border-radius: 10px;
		margin-top: 30px;
		padding-bottom: 20px;
	}
	
	.feature-card {
		text-align: center;
	}
	
	.feature-card h3{
		text-align: center;
		font-size: 16px;
		width: 85%;
		margin: auto;
		color: #003E80;
		font-weight: 700;
	}
	
	.feature-card p{
		font-size: 14px;
		color: #737373;
		width: 85%;
		margin: auto;
		padding: 10px 0px 10px 0px;
	}
	
	.feature-icon{
		text-align: center;
		padding-top: 15px;
        padding-bottom: 5px;
        width: 22%;
        margin: auto;
	}
	
	.feature-icon img{
		width: 100%;
	}
	
	.midasi_left_icon{
		width: 3%;
	}
	
	.midasi_left_icon img{
		width: 3%;
	}
	
	.title_icon_features{
		width: 30%;
		padding-left: 25%;
		padding-top: 4%;
	}
	
	/*サービス部分*/	
	
	#services{
		width: 100%;
		padding: 50px 0px 100px 0px;
		background-color: #FFFFFF;
		clip-path: polygon(0 3%, 100% 0%, 100% 97%, 0% 100%);
		margin-top: -40vw;
		overflow: hidden;
	}
	
	.services-container{
		width: 90%;
		margin: auto;
		position: relative;
		padding-bottom: 50px;
	}
	
	.services-container h2{
		font-size: 26px;
		color: #003E80;
		font-weight: 700;
		text-align: center;
		padding-top: 25%;
	}
	
	.h2_line_02{
		background-color:hsla(50,100%,87%,1.00);
		width: 95%;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;
	}
	
	.icon_img03{
		width: 40%;
        position: absolute;
        top: -2%;
        left: 63%;
		animation: fuwafuwa2 2.5s ease-in-out infinite alternate;
		transition: 1.5s ease-in-out;
	}
	
	
	@keyframes fuwafuwa2 {
  0% {
    transform:translate(0, 0) rotate(-2deg);
  }
  50% {
    transform:translate(0, -8px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(2deg);
  }
}
	.midasi_icon_01{
		width: 55%;
        margin: auto;
        position: absolute;
        top: 3%;
        left: 14%;
	}
	
	.midasi_icon_01 img{
		width: 100%;
	}
	
	.services-grid{
		display:flex;
		flex-wrap: wrap;
		width: 90%;
		margin: auto;
		margin-top: 50px;
	}
	
	.services-grid li{
		width: 100%;
		padding-bottom: 30px;
	}
	.service-item{
		display: flex;
	}
	
	.service-icon{
		text-align: center;
		margin-top: 0px;
		width: 26%;
	}
	
	.service-icon img{
		width: 100%;
	}
	
	.service-content{
		padding-left: 3%;
		padding-bottom: 5%;
		width: 75%;
	}
	
	.service-content h3{
		font-size: 18px;
		font-weight: 700;
		padding-top: 5px;
	}
	
	.service-content p{
		font-size: 14px;
		color: #737373;
	}
	
	.service_title01{
		color: #005097;
	}
	
	.service_title02{
		color: #007f55;
	}
	
	.service_title03{
		color: #ff7000;
	}
	
	.service_title04{
		color: #dc0720;
	}
	
/*ユーザーの声*/
	#testimonials{
		width: 100%;
		padding: 50px 0px 50px 0px;
		background-color: #e4e6f1;
        margin-top: -20vw;
        background-image: url(../images/common_svg_img_16.svg);
        background-position:top;
        background-size: 200%;
        background-repeat: no-repeat;

	}
	
	.testimonials-container{
		width: 90%;
		margin: auto;
		position: relative;
		padding-top: 100px;
	}
	
	.h2_line_03{
		background-color:hsla(359,100%,81%,1.00);
		width: 95%;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;
	}
	
.icon_img04 {
	position: absolute;
	top: -28vw;
	width: 43%;
}


.icon_img05 {
	position: absolute;
		top: -7vw;
	width: 16%;
	left: 43%;
}

.title_icon_testimonials{
	position: absolute;
        top: 3%;
        left: 62%;
        width: 35%;
}
.icon_img06 {
	position: absolute;
	top: 8%;
    left: -6%;
    width: 13%;
	}
	
	.service_under_img{
		width: 100%;
		position: relative;
	}


	.testimonials-container h2{
		font-size: 26px;
		color: #003E80;
		font-weight: 700;
		text-align: center;
	}
	
	.testimonials-grid{
		width: 100%;
		margin: auto;
		margin-top: 70px;
	}
	
	.testimonials-grid li{
		border: 1px solid #e5e7eb;
		background-color: #FFFFFF;
		width: 100%;
		border-radius: 10px;
		padding-bottom: 30px;
		margin-bottom: 30px;
	}
	
	.testimonial-header{
		display: flex;
		width: 90%;
		margin: auto;
		margin-top: 20px;
	}
	
	.testimonial-avatar{
		width: 27%;
	}
	
	.testimonial-avatar img{
		width: 100%;
	}
	
	.testimonial-person{
		margin-left: 10px;
		padding-top: 10px;
	}
	
	.testimonial-name{
		font-size: 16px;
		color: #0A0A0A;
	}
	
	.testimonial-location{
		font-size: 14px;
		color: #737373;
	}
	
	.testimonial-text{
		font-size: 14px;
		color: #737373;
		width: 90%;
		margin: auto;
		margin-top: 10px;
	}



/* 地図ボタン */
	
	#map_bts{
		width: 100%;
		padding: 50px 0px;
		background-color: #003E80;
		overflow: hidden;
		
	}
	
	.map_bts-container
	{
	 width: 90%;
	 margin: auto;
}
	
	.map_bts-container ul{
		display: flex;
		justify-content: space-between;
		width: 100%;
		margin: auto;
		text-align: center;
	}
	

	.map_bts-container ul li a{
		background-color: #DC0723;
		color: #FFFFFF;
		display: block;
		border: 1px solid #e5e7eb;
		border-radius: 10px;
		padding: 20px 5px;
		text-decoration: none;
		font-size: 12px;
		box-shadow: 1px 1px 5px #000000;
	}
	
	
	.map_bts-container ul li{
		width: 31%;
		overflow: hidden;
		
	}
	
	.map_bts-container ul li a{
	}
	
	.map_bt_icon{
		width: 8%;
		margin: auto;
		padding-top: 5%;
	}
	
	.map_bt_icon img{
		width: 200%;
	}
	
	.map_bt_icon_text{
		width: 90%;
		margin: auto;
	}
	
	.map_bt_icon_text img{
		width: 65%;
	}
	
	.map_bt_icon_text p{
		font-size: 10px;
	}

	.map_bts-container h2{
		font-size: 26px;
		text-align: center;
		font-weight: 700;
		color: #FFFFFF;
		padding-bottom: 50px;
	}
	
	.h2_line_05{
		background-color:hsla(359,100%,81%,1.00);
		width: 85%;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -13px;
	}
	
	
	
	/* よくある質問セクション */
   #faq {
	   width: 100%;
		padding: 80px 0px 0px 0px;
        background-image: linear-gradient(135deg, rgba(239, 255, 252, 1), rgba(228, 230, 241, 1));
		  position: relative;
		overflow: hidden;
}

      .faq-container {
	 width: 90%;
	 margin: auto;
		  position: relative;
		  padding-bottom: 50px;
}
	
	.faq-container h2{
		font-size: 26px;
		color: #003E80;
		font-weight: 700;
		text-align: center;}
	
	
		.h2_line_04{background-color:hsla(50,100%,87%,1.00);
		width:55%;
		height: 15px;
		display: block;
		margin: auto;
		margin-top: -15px;}
	
	.title_icon_faq{
		position: absolute;
		top: 1%;
        left: 39%;
        width: 29%;
	}

	.icon_img08{
		position: absolute;
		top: 6%;
        left: 70%;
        width: 30%;animation: fuwafuwa2 2.5s ease-in-out infinite alternate;
		transition: 1.5s ease-in-out;
	}
	
	
	@keyframes fuwafuwa2 {
  0% {
    transform:translate(0, 0) rotate(-2deg);
  }
  50% {
    transform:translate(0, -8px) rotate(0deg);
  }
  100% {
    transform:translate(0, 0) rotate(2deg);
  }
	}
	
	.accordion-container{
		width: 95%;
		margin: auto;
		margin-top: 70px;
	}
	
	.accordion-button{
		padding: 10px 20px;
		background-color:hsla(0,0%,96%,0.50);
	}
	
	.accordion-container h3{
		font-size: 18px;
		color: #003E80;
		font-weight: 700;
		padding-bottom: 10px;
	}
	
	.accordion-button h4{
		font-size: 16px;
		color: #003E80;
		padding-top: 5px;
	}
	
	
	.accordion-button h4:hover{
		font-size: 16px;
		color: #003E80;
		text-decoration: underline;
	}
	
	
	.accordion-icon{
		font-size: 18px;
		color: #003E80;

	}
	
	.accordion-content{
		font-size: 14px;
	}
	
	
	.accordion-content p{
		margin-top: 10px;
	}
	
	.accordion-content p a{
		color: #C51114;
	}
	
	
.accordion-item {
  overflow: hidden;
	border-bottom: 1px solid #e5e7eb;
}

.accordion-button {
  width: 100%;
  text-align: left;
  border: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 700;
	background-color: #FFFFFF;
}

.accordion-icon {
  transition: transform 0.3s ease;
}

.accordion-item.active .accordion-icon {
  transform: rotate(45deg);
}

.accordion-content {
  padding: 0 1.5rem;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.accordion-item.active .accordion-content {
  padding: 0 1.5rem 1rem;
  max-height: 500px;
	background-color: #FFFFFF;
}

	
	
	/* よくある質問セクション */
	
	
	.cta_under_img{
		width: 100%;
	}
	

	
	.cta{
		width: 100%;
		padding: 50px 0px;
		background-color: #003E80;
	position: relative;
	margin-top: -2vw;}
	
	.icon_img07{
		width: 100%;
	}
	
	
	
	.icon_img07 img{
		width: 100%;
	}
	
	.cta-container{
		width: 90%;
		margin: auto;
	}

	.cta-content h2{
		font-size: 30px;
		color: #FFFFFF;
		font-weight: 700;
		text-align: center;
	}
	.cta-content p{
		text-align: center;
		color: #FFFFFF;
		font-size: 14px;
		margin-top: 20px;
	}
	
	.cta-buttons{
		text-align: center;
		padding: 50px 10px 0px 10px; 
	}
	
	
	.cta-buttons a{
		display:block;
		text-decoration: none;
	}
	
	.cta-buttons_t{
		background-color: hsla(0,0%,96%,1.00);
		padding: 10px 25px;
		margin-right: 5px;
		color: #171717;
		font-size: 14px;
		border: 1px solid hsla(0,0%,96%,1.00);
		border-radius: 5px;
	}
	
	
	.cta-buttons_online{
		background-color: #DC0723;
		padding: 10px 25px;
		margin-right: 5px;
		color: #FFFFFF;
		font-size: 14px;
		border: 1px solid hsla(0,0%,96%,1.00);
		border-radius: 5px;
		margin-top: 20px;
	}
	
	
	/* フッター部分*/
	.footer{
		width: 100%;
		margin: auto;
		padding: 50px 0px 30px 0px;
	}
	
	.footer-container{
		width: 90%;
		margin: auto;
	}
	
	.footer-grid{
	}
	
	
	.footer-col{
		width: 90%;
		text-align: center;
		margin: auto;
	}
	
	.footer-col h3{
		font-size: 14px;
		font-weight: 700;
		color: #003E80;
	}
	
	.footer-logo{
		width: 50%;
		margin: auto;
		padding: 5px 0px;
	}
	
	.footer-logo img{
		width: 100%;
	}
	
	.footer-links{
		padding: 10px 0px;
	}
	
	.footer-links li{
		font-size: 12px;
		padding-bottom: 10px;
	}
	
	.footer-links li a{
		color: #737373;
		text-decoration: none;
	}
	
	.footer-col p{
		font-size: 12px;
		color: #737373;
	}
	
	.footer-contact{
		font-size: 12px;
		color: #0A0A0A;
	}
	
	.footer-bottom{
		border-top: 1px solid #e5e7eb;
		margin-top: 30px;
		text-align: center;
		color: #737373;
		padding-top: 20px;
		font-size: 12px;
	}
	
	.cb-btns{
		width: 90%;
	margin: auto;
		padding-bottom: 40px;
		padding-top: 50px;
	}
	
	.cb-btns li{
		width: 100%;
		margin: auto;
		background-color: #FFFFFF;
		display: inline-block;
		text-align: center;
		margin-bottom: 10px;
	}
	
	
	.footer_bt_icon_img01 {
    margin: 0px 20px 6px 10px;
    width: auto;
    height: 35px;
	display: inline-block;
	vertical-align: bottom;}
	
	.footer_bt_icon_img02 {
    margin: 0px 10px 6px 0px;
    width: auto;
    height: 35px;
	display: inline-block;
	vertical-align: bottom;}
	
	.cb-btns li a {
	        padding: 2vw 1vw 2vw 4vw;
        height: auto;
        text-align: left;
        display: block;
        position: relative;
        background-color: #ffffff;
        overflow: hidden;
        background-image: url(../images/arrow.png);
        background-position: right 5% center;
        background-size: 2.7vw auto;
        background-repeat: no-repeat;
	text-decoration: none;}
	
	.cb-btns li a span{
		font-size: 20px;
    text-align: center;
    font-weight: bold;
    color: #003E81;
    line-height: 50px;
    position: static;
	}
	
	.copyright_p{
		font-size: 10px;
		margin: auto;
		padding: 0px 0px;
		text-align: center;
		color: rgba(255,255,255,1.00);
	}
	
	.footer_logo_box img{
		width: 100%;
	}
	
	.footer_logo_box{
		width: 45%;
		margin: auto;
		margin-bottom: 20px;
	}
	
	

}