body{
/*font-family: "Noto Sans JP", sans-serif;*/
    font-family: Arial, "Hiragino Sans", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif; font-weight:500;
    background-color: #ffffff;
    color:rgba(61,61,61,1.00);
        overflow-x: hidden;
}

.fm01 { font-family: Arial, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif; }
.fm02 { font-family: Arial, "Hiragino Sans", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif; font-weight:500; }
.fmc03 { font-family: "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif; font-weight:500; 
}

/*a {
    color: #EF9619;
        letter-spacing: 1px;
}*/
a:hover{
    color: #919191;
    text-decoration: none;
}

.opalink{
    color: rgba(61,61,61,1.00);
}


.opalink:hover{
    opacity: 0.7
}


.toph3 {
  border-bottom: solid 3px #CFCFCF;
  position: relative;
}

.toph3:after {
  position: absolute;
  content: " ";
  display: block;
  border-bottom: solid 3px #035b2d;;
  bottom: -3px;
  width: 20%;
}

.toph4 {
  position: relative;
  padding: 0 30px;
  text-align: center;
}


.toph4:before {
  position: absolute;
  top: calc(50% - 1px);
  left: 0;
  width: 100%;
  height: 2px;
  content: '';
  background: #000;
}

.toph4 span {
  position: relative;
  padding: 0 1em;
  background: #fff;
	font-size: 1.5rem;
}

@media screen and (max-width:991px){
	.toph4 span {
		font-size: 1.1rem;
	}
	
	.toph3{
		font-size: 1.2rem;
	}
}

/*p , .divnum{
    line-height: 2.3rem;
    letter-spacing: 1px;
}*/

/*p1{
color: #272BDD	
}*/

.bold{
	font-weight: bold;
}

.ft20{
    font-size: 24px;
}

.rectborder{
    border: 2px solid #ffffff;
}

/*h1{
	color: #0923EF
}*/

.h1cus{
    font-weight: bold;
    letter-spacing: 2px;
	font-size: 30px;
}

@media screen and (max-width:767px){
	.h1cus{
		font-size: 20px;
	}
}

.h1small{
    font-size: 18px;
	border-bottom: 1px solid  #A6A6A6;
}

/*h2 {
  padding: 1rem 2rem;
  background: #1B4B8D;
  color: #FFFFFF	
}*/

  .nav-link.active,
  .nav-item.show .nav-link {
    border-bottom: 3px solid ;
	opacity: none;
  }

/*h3 {
	border-bottom: 1px solid  #4689AF;
	color: #1F2AEB
		
}

th{
color: #1B4B8D;	
}*/

/*.class-under-top {
  width: 1147px;
  height: 250px;
  object-fit: cover; 
}*/

.class-under-top {
  height: 300px;
background: url("../images/outline/01.jpg");
background-size: cover;
background-position: center;
}

.class-under-top02 {
  height: 300px;
background: url("../images/concept/01.jpg");
background-size: cover;
background-position: center;
}


.class-under-top03 {
  height: 300px;
background: url("../images/Introduction/bg_01.jpg");
background-size: cover;
background-position: center;
}

.class-under-top04 {
  height: 300px;
background: url("../images/contact/contact01.jpg");
background-size: cover;
background-position: center;
}


.topbgareasub{
    min-height: 80vh;
    /*background-color: rgba(0,0,0,0.50);*/
}

  

.navbar{padding-bottom: 0;}

@media screen and (max-width:767px) {
	.navbar{padding-bottom: 10px;}
}

.sono3 { 
    background-color: #ffffff;
    box-shadow: 0px 10px 10px -5px rgba(0,0,0,0.3);
}
.sono3 .navbar-nav .nav-link { 

    font-size: 16px;
}

@media screen and (max-width:990px) {
    .sono3 .navbar-nav .nav-link {
        /*text-align: right;*/
       /* border-top: 1px solid #ffffff;*/
        padding-top: 15px;
        padding-bottom: 15px;
    }
    .hmt-6{
        margin-top: 65px;
    }
}


.nav-item a {
color: white;
  position: relative;
  display: inline-block;
  text-decoration: none;
}
.nav-item a::after {
  position: absolute;
  bottom: -8px;
  left: 0;
  content: '';
  width: 100%;
  height: 3px;
  background: #FFFFFF;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
}
.nav-item a:hover::after {
  bottom: -3px;
  opacity: 1;
  visibility: visible;
}


.sono3 .navbar-nav .active > .nav-link { 
    color: #C94221;
}
.sono3 .navbar-toggler {
    border-color: #C94221;
    background-color: #ffffff;
    width: 110px;
	margin-bottom: 10px;
}
.navbar-toggler-icon{
    width: auto;
}

.sono3 button>.navbar-toggler-icon {
    color: #C94221;
    border-color: #C94221;
    padding-top:3px;
}


/*.ftbg{
    background-color:#EF9619;
    color: #ffffff;
    font-weight: bold;
	background-position: center
}*/

.footer_bg{
	background-image: url("../images/footer_bg.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: bottom;
}
.ftbg_p a{
	color: #035b2d;
}

.ftbg_p a:hover{
	color: #049549;
	text-decoration: none;
}

@media screen and (max-width:450px) {
    .tplogo{
        width: 175px;
    }
}


.mainvh100{
    height: 100vh;
}



h2.h2title {
    font-weight: bold;
    font-size: 40px;
    position: relative;
    padding: 1.5rem;
    text-align: center;

}

h2.h2title:before {
  position: absolute;
  bottom: -5px;
  left: calc(50% - 40px);
  width: 80px;
  height: 4px;
  content: '';
  border-radius: 3px;
  background: #311300;
}

h2.h2small{
    color: #311300;
    font-size: 22px;
    padding-top: 46px;
}



@media screen and (max-width:767px) {
    .navbar-toggler{
        font-size: 14px;
        padding-left: 6px;
        padding-right: 6px;
    }
    .sono3 .navbar-toggler{
        width: 80px;
    }
}


#page_top{
  width: 50px;
  height: 80px;
  position: fixed;
  right: 0;
  bottom: 30px;
/*  opacity: 0.6;*/
}
#page_top a{
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
    background-color: #C94221;
    /*background-image: linear-gradient(rgb(3, 91, 45), rgb(3, 66, 32));*/
	border: 1px solid rgba(255,255,255,0.40);
}

#page_top a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f102';
  font-size: 20px;
  color: #ffffff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -20px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}

#page_top a::after{
  content: 'TOP';
  font-size: 12px;
  color: #ffffff;
  position: absolute;
  top: 30px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;

}




@media screen and (max-width:991px) {
	.topbgmovie{
		display:none !important;
	}
	.topbgstatic{
		display:block;
	}
}

.toph1sub{
	font-size: 18px;
	line-height: 1.5em;
}

.dropdown{
	padding-top: 8px;
	font-size: 18px;
}

.dropdown a{
	color: #035b2d;
}

.dropdown a:hover{
	color: #A6A6A6;
}


.dropdown-menu{
	padding-left: 8px;
	padding-right: 8px;
}

.dropdown-menu li{
	padding-top: 5px;
	padding-bottom: 5px;
}

.nav-item{
	padding-left: 8px!important;
	padding-right: 8px;
	margin-top: 4px;
	/*background-image: linear-gradient(rgb(3, 91, 45), rgb(3, 66, 32));*/
}

/*.navbar-nav li{
	border-left: solid rgba(255,255,255,0.70) 1px;
}
.navbar-nav li:last-child{
	border-right: solid rgba(255,255,255,0.70) 1px;
}*/

@media screen and (max-width:767px){
	.navbar-nav li{
	border-left: none;
	}
	.navbar-nav li:last-child{
		border-right: none;
	}
}


/*.nav-item a {
	color: #FFFFFF;
}*/

.nav_bg{
	/*background-image: linear-gradient(rgb(3, 91, 45), rgb(3, 66, 32));*/
	background-color: #C94221;
	padding-bottom: 10px;
}

@media screen and (max-width:991px) {
	.dropdown{
	padding-top: 16px;
}
	
	.nav-item{
	padding-left: 5px;
	padding-right: 5px;
	/*border-top: #034220 solid 1px;*/
}

}

@media screen and (max-width:767px) {
	.dropdown{
	text-align: right;
	}
	
	.dropdown-menu{
	border: none;
	}
	
	.dropdown-menu li{
	text-align: right;
	}
	
	.nav-item{
	padding-left: 8px;
	padding-right: 8px;
}
}

.top_letter_space{
	letter-spacing: 3px;
}

.top_letter_space p{
	letter-spacing: 3px;
}

.fs_10{
	font-size: 10px;
}

.fs_12{
	font-size: 12px;
}

.fs_14{
	font-size: 14px;
}

.fs_16{
	font-size: 16px;
}





.bg_company{
	background:url("../images/company/bgcompany_mv_pc.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 80vh;
}

.bg_contact{
	background:url("../images/contact/bgcontact_mv_pc.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
}

.bg_service{
	background:url("../images/service/service_top.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 30vh;
}

.bg_service02{
	background:url("../images/service/service01.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 30vh;
}

.bg_service03{
	background:#405D9D;
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 30vh;
}

.bg_service04{
	background:#559657;
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 30vh;
}

.bg_service05{
	background:#559657;
}

.bg_device{
	background:url("../images/device/device_top.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 30vh;
}

.bg_qa{
	background:url("../images/qa/qa_top.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 30vh;
}

.bg_portfolio{
	background:url("../images/portfolio/portfolio_top.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 30vh;
}

.bg_contact{
	background:url("../images/contact/contact_top.jpg");
	background-position: center;
	background-repeat: no-repeat;
	background-size:cover;
	height: 30vh;
}

@media screen and (max-width:575px) {
	.intabyu_p{
	font-size: 1.4rem!important;
}
}

.gnav {
  flex-direction: column;
}


@media screen and (max-width:757px){
	.fixed-top{
		position: static;
	}
}



.menu_w{
	width: 80%;
}


* {
  margin:0; padding:0;
}
/*header {
  width: 100%;
  padding: 15px 0;
  margin: 0 auto;
  text-align: center;
}
header .headline{
  font-size: 32px;
}*/
.nav-list {
  text-align: center;
  padding: 10px 0;
  margin: 0 auto;
}
.nav-list-item {
  list-style: none;
  display: inline-block;
  margin: 0 20px;
}
footer {
  width: 100%;
  /*height: 120px;*/ 
  /*text-align: center;*/
  padding: 50px 0;
  background-color: #C94221;
}
.footer-text {
  color: #FFFFFF;
}

.footer-text:hover{
  color: #FFFFFF;
  text-decoration: none;
}

@media screen and (max-width:992px){
	.menu_w{
	width: 100%;
	}
}

/*.menu_bana{
	
	height: 70px;
	width: auto;
}*/
@media screen and (max-width:450px){
	.menu_bana{
	
	height: auto;
	width: 100%;
}
}

section table { width: 100%; }
section th, section td  { padding: 10px; border-bottom: 2px solid #ddd; }
section th  { background: #FFFFFF; }
 
/*----------------------------------------------------
  .rspt
----------------------------------------------------*/
  .rspt th  { width: 30%; text-align: left; }
 
@media only screen and (max-width:480px){

  .rspt th,
  .rspt td{
    width: 100%;
    display: block;
    border-top: none;
    }
  .rspt tr:first-child th { border-top: 1px solid #ddd; }
}
	
/*.swiper-container {
  position: relative;
  overflow: hidden;
  padding: 20px 0;
  height: 40vw;
  max-height: 600px; 
  min-height: 400px; 
}
  .swiper-slide {
    text-align: center;
    line-height: 1;
    display: flex;
    align-items: flex-start; 
    justify-content: center; 
}
    .swiper-slide img {
      display: inline; 
      width: auto; 
      max-width: 100%;
      max-height: 100%;
      align-self: center; 
    }
  
 

  .swiper-button-prev {
    left: 25px;
  }
  .swiper-button-next {
    right: 25px;
  }
*/

.slide_under_m{
	margin-top: 10%;
}


.slide_top_m{
	margin-top: 10%;
}

@media only screen and (max-width:1500px){
	.slide_under_m{
	margin-top: 15%;
}
	
	.slide_top_m{
	margin-top: 15%;
}
	
	
}

@media only screen and (max-width:1115px){
	.slide_under_m{
	margin-top: 20%;
}
	
	.slide_top_m{
	margin-top:20%;
}
	
	
}


@media only screen and (max-width:991px){
	.slide_top_m{
	margin-top: 25%;
	}
	
	.slide_under_m{
	margin-top: 25%;
	}
}

@media only screen and (max-width:757px){
	.slide_top_m{
	margin-top: 10%;
}
	
	.slide_under_m{
	margin-top: 10%;
}
}

.privacy-textarea{
	overflow-y: scroll;
	max-height: 150px;
    min-height: 100px;
    padding: 10px;
    border: 1px solid #ccc;
    border-right: 1px solid #fff;
    border-bottom: 1px solid rgba(53,63,255,.325) 5;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    resize: vertical;
}


.under_top_bg{
	background-image: url("../images/under_top.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: left;
}

.slide_under_m h1{
	font-size: 22px;
	padding-top: 10px;
	padding-bottom: 10px;
}

.fa_color{
	color: #035B2D;
}

.fa_menu{
	color: #0A9104;
}

.bx-wrapper .bx-controls-direction a {
    z-index: 1;
}
.menu-top-p{
	padding-top: 30px;
	margin-bottom: 0;
}

@media only screen and (max-width:767px){
	.menu-top-p{
	padding-top: 10px;
	margin-bottom: 0;
}
}

@media only screen and (max-width:404px){
	.menu-top-p{
	font-size: 14px;
}
}

.ft-border-bottom{
	border-bottom: white solid 4px;
}

.bg_orange{
	background-color:#C94221; 
}

.border_news {
 /* font-size: 30px;
  font-size: 3rem;*/
  position: relative;
 /* padding: 1.5rem;*/
  text-align: center;
}

.border_news span {
  display: block;
}

.border_news:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 40px);
  width: 80px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background: #FFFFFF;
}

.border_news02 {
 /* font-size: 30px;
  font-size: 3rem;*/
  position: relative;
 /* padding: 1.5rem;*/
  text-align: center;
}

.border_news02 span {
  display: block;
}

.border_news02:before {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 40px);
  width: 80px;
  height: 5px;
  content: '';
  border-radius: 3px;
  background: #C94221;
}

.news-list{
  list-style: none outside;
  margin: 0;
  padding: 0;
}
.news-list .item div{
  display: flex;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  text-decoration: none;
  color: #FFFFFF;
  /*border-bottom: 1px solid #CCC;*/
  padding: 20px 20px;
}
/*.news-list .item:first-child a{
  border-top: 1px solid #CCC;
}*/
.news-list .item .date{
  margin: 0;
  min-width: 120px;
  font-size: 16px;
  color: #FFFFFF;
  padding: 0 20px 0 0;
}
.news-list .item .category{
  margin: 0;
  min-width: 140px;
  /*padding: 0 20px 0 0;*/
}
.news-list .item .category span{
  background: #FFFFFF;
  color: #C94221;
	font-weight: bold;
  text-align: center;
  display: inline-block;
  padding: 8px 20px;
  font-size: 12px;
  line-height: 1;
}
.news-list .item .title{
  margin: 0;
  width: 100%;
}
/*.news-list .item a:hover .title{
  color: #00F;
}*/

@media screen and (max-width: 767px){
.news-list .item .a{
  flex-wrap: wrap;
}
.news-list .item .date{
  min-width: 100px;
}
.news-list .item .title{
  margin-top: 10px;
}
}

.btn_news{
	border: solid #FFFFFF 2px;
	border-radius: 30px;
	width: 100%;
	font-weight: bold;
	color: white!important;
}

.btn_news:hover{
	/*border: solid #FFFFFF 2px;*/
	/*border-radius: 30px;*/
	/*width: 100%;
	font-weight: bold;*/
	background: rgba(255,255,255,0.20);
}

.btn_sekou{
	/*border: solid #C94221 2px;
	border-radius: 30px;*/
	width: 100%;
	font-weight: bold;
	color: white!important;
	background: #C94221;
}

.btn_kiiro{
	/*border: solid #C94221 2px;
	border-radius: 30px;*/
	width: 100%;
	font-weight: bold;
	color: white!important;
	background: #E29226;
}

.btn_orange{
	/*border: solid #C94221 2px;
	border-radius: 30px;*/
	width: 100%;
	font-weight: bold;
	color: white!important;
	background: #CE5436;
}

.btn_blue{
	/*border: solid #C94221 2px;
	border-radius: 30px;*/
	width: 100%;
	font-weight: bold;
	color: white!important;
	background: #405D9D;
}

.btn_green{
	/*border: solid #C94221 2px;
	border-radius: 30px;*/
	width: 100%;
	font-weight: bold;
	color: white!important;
	background: #559657;
}

.btn_white{
	/*border: solid #C94221 2px;
	border-radius: 30px;*/
	width: 100%;
	font-weight: bold;
	color: #559657!important;
	background: #FFFFFF;
}

.btn_grey{
	/*border: solid #C94221 2px;
	border-radius: 30px;*/
	width: 100%;
	font-weight: bold;
	color: #000000!important;
	background: #EFEFEF;
}

.text_orange{
	color: #C94221;
}

.text_blue{
	color: #405D9D;
}

.text_green{
	color: #559657;
}

.btnarrow1::after{
    content: '';
    /*絶対配置で矢印の位置を決める*/
  position: absolute;
    top:40%;
    right: 40px;
    /*矢印の形状*/
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
    /*アニメーションの指定*/
    transition: all .3s;
}

/*hoverした際の移動*/
.btnarrow1:hover::after{
    right: 25px;
}

.btnarrow2::after{
    content: '';
    /*絶対配置で矢印の位置を決める*/
  position: absolute;
    top:40%;
    right: 40px;
    /*矢印の形状*/
    width: 10px;
    height: 10px;
    border-top: 2px solid #559657;
    border-right: 2px solid #559657;
    transform: rotate(45deg);
    /*アニメーションの指定*/
    transition: all .3s;
}

/*hoverした際の移動*/
.btnarrow2:hover::after{
    right: 25px;
}

.btnarrow3::after{
    content: '';
    /*絶対配置で矢印の位置を決める*/
  position: absolute;
    top:40%;
    right: 40px;
    /*矢印の形状*/
    width: 10px;
    height: 10px;
    border-top: 2px solid #000000;
    border-right: 2px solid #000000;
    transform: rotate(45deg);
    /*アニメーションの指定*/
    transition: all .3s;
}

/*hoverした際の移動*/
.btnarrow3:hover::after{
    right: 25px;
}

.under-ma{
	margin-top: 130px;
}

@media screen and (max-width:757px){
	.under-ma{
	margin-top: 0px;
}
}

ul.bread_list {
    display: flex;
	list-style: none;
}

.bread_list li:not(:last-child):after {
    content: " > ";
}

ul.bread_list {
    display: flex;
    margin: 1rem;
}
.bread_list li:not(:last-child):after {
    content: " > ";
    margin: 0 1rem;
}

.bread_list li a {
    color: #C94221; 
}

@media screen and (max-width: 768px) {
	ul.bread_list {
    display: block;
}
}


.bg_grey{
	background: #F7F7F7;
}


@media screen and (min-width: 768px) {
  .ps-br{
    display: block; /* PCを改行して */
  }

  .sp-br{
    display: none; /* SPの改行を隠す */
  }
}


@media screen and (max-width: 767px) {
  .ps-br{
    display: none; /* PCの改行を隠して */
  }

  .sp-br{
    display: block; /* SPを改行する */
  }
}

.device_h{
	height: 2rem;
}

.title_qa {
  position: relative;
  padding: 0 0 0 45px;

}

.title_qa::before {
  position: absolute;
  top: 0;
  left: 0;
  content: url("../images/qa/qa.png");
}

.title_qa02 {
  position: relative;
  padding: 0 0px;
  /*text-align: center;*/
}

.title_qa02:before {
  position: absolute;
  top: calc(50% - 1px);
  left: 0;
  width: 100%;
  height: 1px;
  content: '';
  background: #000;
}

.title_qa02 span {
  position: relative;
  padding: 0 1em;
  background: #fff;
 font-weight: bold;
}

.border_orange{
	border: solid 2px #CE5436;
	padding-top: 20px;
	padding-bottom: 20px;
}