@charset "UTF-8";
/* CSS Document */
/*---------------------------- base ----------------------------*/
* {
	margin: 0;
	padding: 0;
}
html {
  font-size: 62.5%;
    -webkit-font-smoothing: antialiased;
}
body {
font-family:"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
	font-size: 1.6rem;
	background: #ffffff;
    color: #727171;
    line-height: 1.8;
    letter-spacing: 0.2rem;;
}
*, *::before, *::after {
  box-sizing: border-box;
}
.clearfix:after {
 content: ".";
 display: block;
 clear: both;
 height: 0;
 visibility: hidden;
}
a:link, a:visited, a:hover, a:active {
  color: #36a4ff;
  text-decoration: none;
}
img {
	border:0;
}

.container{
    width: 100%;
    max-width: 1040px;
    padding-left: 20px;
    padding-right: 20px;
    margin: 0 auto;
}
.txtcenter{
    text-align: center;
}
.imgcenter{
    display: block;
    margin: 0 auto;
}
ul{
    list-style: none;
}
.row{
  -js-display: flex;
  display: flex;
    flex-flow: wrap;
}
::selection
{
    background: #36a4ff;
    color: #ffffff;
}

/* for Firefox */
::-moz-selection
{
    background: #36a4ff;
    color: #ffffff;
}
@media screen and (max-width:769px){
body {
	font-size: 1.5rem;
    line-height: 1.6;
} 
}



/*---------------------------- loader ----------------------------*/
#pageloading-wrap {
   background: #36a4ff;
   width: 100%;
   height: 100%;
   position: fixed;
   top: 0;
   left: 0;
   text-align: center;
   display: table;
   z-index: 1;
}
.loader {
   display: table-cell;
   vertical-align: middle;
}

.mv{
  -js-display: flex;
  display: flex;
    justify-content: center;
    align-items: center;
    background: url("../images/mv.jpg") no-repeat center;
    height: 100vh;
    min-height: 600px;
    background-size: cover;
}
.logo{
    position: relative;
    top:-28px;
}
@media screen and (max-width:769px){
.mv{
    height: 320px;
}

}


/*---------------------------- footer ----------------------------*/
.footer{
    background: #ffffff;
    padding-top: 20px;
    padding-bottom: 20px;
}
.footer_logo{
    padding: 10px 0;
    padding-bottom: 20px;
}


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


}


/*---------------------------- h2_title ----------------------------*/
.h2_title{
    padding-bottom: 15px;
    text-align: center;
}
.h2_title .en{
        border-bottom: 1px solid #727171;
    width: 60%;
     max-width: 216px;
    margin: 0 auto;
    margin-bottom: 8px;
    padding-bottom: 5px;
}

.h2_title h2{
    font-size: 3rem;
    font-weight: normal;
    display: inline-block;
    text-align: center;
}
.h2_title sub{
    font-size: 2.2rem;
    padding-top: 25px;
    text-align: center;
}


.h2_title.wh{color: #fff;}
.h2_title.wh .en{border-bottom: 1px solid #ffffff;
}

.h2_title.bl{color: #36a4ff;}
.h2_title.bl .en{
    border-bottom: 1px solid #36a4ff;
}


/*---------------------------- about ----------------------------*/
.about{
    color: #ffffff;
    background: url("../images/bg_about.jpg") no-repeat center;
    background-size: cover;
    padding: 60px 0;
    width: 100%;
}

.about p{
    line-height: 3;
}

@media screen and (max-width:769px){
.about{
    padding: 80px 0;
}    
    
.about p.text{
    line-height: 2;
    margin-top: 20px;
}
    .about p.text br{
        display: none;
    }
}

/*---------------------------- service ----------------------------*/
.service{
    padding-top:120px; 
}
.service .h2_title{
    margin-bottom:40px;
}

.service_bg{
    background: url("../images/bg_service.jpg") no-repeat center;
   padding: 100px 0;
    background-size: cover;
  -js-display: flex;
  display: flex;
    justify-content: center;
    align-items: center;
}


.service_contents{
    justify-content: space-between;
    padding: 30px 0;
    border-bottom: 6px solid #36a4ff;
    background: #ffffff;
    min-width:800px;
    border-top-right-radius: 6px;
    border-top-left-radius: 6px;
}
.service_contents .clm{
    width: 33.333%;
    border-right: 1px solid #d4d4d4;
}
.service_contents .clm:last-child{
    border-right: 0;
}
.service_contents .clm .wrap{
    width: 86%;
    margin: 0 auto;
    position: relative;
    left: 10px;
}
.h3_title{
    height: 110px;
    margin-top: 10px;
}

.service_contents .clm .wrap h3{
    color: #36a4ff;
    line-height: 1.6;
    font-size: 2.25rem;
    font-weight: normal;
}

.service_contents .clm .wrap ul li{
    padding: 10px 0;
    margin-right: 15px;

}

.service_contents .clm .wrap ul li::before{
    content: '・';
    font-weight: 600;
    color: #36a4ff;
    margin-left: -15px;

}



@media screen and (max-width:769px){
.service_bg{
    background: url("../images/bg_service.jpg") no-repeat center top, #36a4ff;
   padding: 140px 0 40px 0;
    background-size: contain;
  -js-display: flex;
  display: flex;
    justify-content: center;
    align-items: center;
}
 
    
    
.service{
    padding-top:80px; 
}
.service .h2_title{
    margin-bottom:20px;
} 
.service_contents{
    padding: 30px 0;
    border-bottom: none;
    min-width:100%;
    border-radius: 6px;
}
.service_contents .clm{
    width:90%;
    border-right:0;
    border-bottom: 1px solid #d4d4d4;
    margin: 0 auto;
    margin-bottom: 25px;
    padding-bottom: 15px;
}
.service_contents .clm:last-child{
    border-bottom: 0;
    margin-bottom: 0;
    padding-bottom: 0;
}
.service_contents .clm .wrap{
    width: 98%;
    margin: 0 auto;
    position: relative;
    left: 10px;
}
.h3_title{
    height: auto;
    margin-top: 0;
}    
.service_contents .clm .wrap h3{
    line-height: 1.5;
    font-size: 2rem;
    margin-bottom: 20px;
} 
.service_contents .clm .wrap h3 br{
    display: none;
}     
    
}


/*---------------------------- profile ----------------------------*/
.profile{
    padding-top:120px; 
}
.prf_tbl{
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
    padding: 20px 0;   
}
.prf_tbl th,.prf_tbl td{
    padding-top: 20px;
    padding-bottom: 20px;
}
.prf_tbl th{
    color: #36a4ff;
    font-weight: normal;
    text-align: left;
    width: 150px;
    vertical-align: top;
}
.ofiice_ul li:nth-child(1){
    padding-bottom: 15px;
}

@media screen and (max-width:769px){
.profile{
    padding-top:80px; 
}
    .prf_tbl tr{
  -js-display: flex;
  display: flex;
        flex-direction: column;
    }
.prf_tbl th,.prf_tbl td{
    padding-top: 0;
    padding-bottom: 0;
}
.prf_tbl th{
    margin-top: 30px;
    }
.ofiice_ul li:nth-child(1){
    padding-bottom: 10px;
    padding-top: 5px;
}
}



/*---------------------------- contact ----------------------------*/
.contact{
    margin-top:120px;    
    background: url("../images/bg_contact.jpg") no-repeat center;
    background-size: cover;
    padding: 60px 0;
}

.contact .container{
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
    padding: 20px 0;   
}

input[type=text], input[type=tel], input[type=email] {
    padding:4px;
    font-size: 96%;
    color: #273e49;
    display: inline-block;
    background: #ffffff;
    width: 100%;
    border:1px solid #adadad!important;
}
textarea{
    resize: vertical;
    overflow: auto;
    height: 260px!important;
    background: #ffffff;
    border:1px solid #adadad!important;
    min-width: 100%;
    padding:4px;
    font-size: 96%;
    width: 100%;
}

button
{
        background-color: transparent;
        border: none;
        cursor: pointer;
        outline: none;
        padding: 0;
        appearance: none;
}

button.submit {

    padding: 6px 20px;
    font-size: 1.6rem;
    font-weight: 700;
    color: #FFFFFF;
    text-decoration: none;
    cursor: pointer;
    background: #727171;
    transition: .2s;
    margin: 0 auto;
    margin-top: 30px;
}

button.submit:hover{
    background: #36a4ff;
} 
@media screen and (max-width:769px){
.contact{
    margin-top:60px; 
    }
.contact .container{
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding: 20px 20px;   
}
button.submit {
    width: 100%;
}
    
}

/*-----------------thanks-------------------*/
.mv_thanks{height: 82vh;}

.mv_thanks_cont {
    width: 100%;
    max-width: 1040px;
    padding-left: 20px;
    padding-right: 20px;
    margin: 0 auto;
	text-align: center;
}
.mv_thanks_cont .mt-150 {
	margin-top: -140px;
	line-height: 1.8;
}
.btn-flat-border {
  display: inline-block;
  padding: 0.3em 1em;
  text-decoration: none;
  color: #36a4ff;
  border: solid 1px #36a4ff;
  border-radius: 1px;
  transition: .4s;
  margin-top: 30px;
}

.btn-flat-border:hover {
  background: #919597;
  border: solid 1px #919597;
  color: white;
}

@media screen and (max-width:769px){
.mv_thanks{height: 82vh;
min-height: 0px;}
    
.mv_thanks_cont .mt-150 {
	margin-top: -100px;
	line-height: 1em;
}

}