@charset "utf-8";
/*レイアウト*/
.wrapper { width: 100% ; margin: 0;  }
.contents_wrap { width: 90%; max-width: 1200px; margin: 0 auto; }
.contents_wrap_s { width: 90%; max-width: 900px; margin: 0 auto; }
.base_contents { position: relative;  }
img { max-width: 100%;height: auto; vertical-align: bottom; }
.contsL { float: left; }
.contsR { float: right; }

.column,
.column2,
.column-max2,
.column3,
.column4,
.column-max4,
.column5,
.column6  { display: -webkit-flex; display: flex; -webkit-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: justify; justify-content: space-between; }

.box-section { padding: 8rem 0; }
.box-section-t { padding-top: 8rem; }
.box-section-s-t { padding-top: 4rem; }
.column-max2 > * { width: 47%; }
.column2 > * { width: 47%; }
.column3 > * { width: 32%; }
.column-max4 > * { width: 20.5%; margin-left: 6%; }
.column-max4 > *:nth-child(4n + 1) { margin-left: 0; }
.column-max4 > *:last-child { margin-right: auto; }

.main-column { width: 75%; }
.sub-column { width: 20%; }

@media screen and (max-width: 1300px) {
  .box-section { padding: 7vw 0; }
}

@media screen and (max-width: 900px) {
  .contents_wrap_l { padding: 0 5%; }
  .column-max2 > * { width: 100%; margin-bottom: 2rem; }
  .box-section { padding: 5rem 0; }
  .box-section-t { padding-top: 5rem; }
  
  .main-column { width: 90%; margin: 0 auto 2rem; }
  .sub-column { width: 90%; margin: 0 auto; }
  
  .column-max4 > * { width: 47%; margin-left: 6%; }
  .column-max4 > *:nth-child(odd) { margin-left: 0; }
  
}
@media screen and (max-width: 600px) {
  .box-section { padding: 3rem 0; }
  .box-section-t { padding-top: 3rem; }

  .column_lr > *:nth-child(odd) { width: 100%; }
  .column_lr > *:nth-child(even) { width: 100%; margin-left: 0; margin-top: 1rem; }

  .column_lr2 > *:nth-child(odd) { width: 100%; }
  .column_lr2 > *:nth-child(even) { width: 100%; margin-left: 0; margin-top: 1rem; }
}


/*contents*/
/*ヘッダー*/
.header { width: 100%;  z-index: 99;-ms-transition: all .3s; -webkit-transition: all .3s; transition: all .3s; }
.header-conts { display: flex; justify-content: space-between;  padding: 1rem 0 .5rem; }

.head-logo { max-width: 30vw; height: auto; }
.head-contact {  font-size: 1.1rem; vertical-align: middle; display: inline-block; }
a.btn-contact{ background: linear-gradient(#FAAD00, #FA6A00); color: #FFF; box-shadow: 0 4px 4px rgba(0,0,0,.4); color: #FFF; display: inline-block; padding: 1em; border-radius: 2em; font-weight: bold; }
a.btn-contact:before { content: ''; width: 1.2em; height: 1.2em; display: inline-block; vertical-align: middle; margin-right:.5em; background: url(../img/mail.svg) no-repeat center center/ contain;  }

.head-tel { display: inline-block; vertical-align: middle; margin-right: 1em;  }
.head-tel .en { font-family: 'Montserrat', sans-serif; font-size: 2rem; font-weight: bold; }
.head-tel .en:before { content: ''; width: 1em; height: 1em; display: inline-block; vertical-align: baseline; margin-right: .2em; background: url("../img/tel.svg") no-repeat center center/ contain; }
.head-tel .ja { display: block; font-size: .8rem; font-weight: bold; }


.header-bottom {  background: linear-gradient(#1772E3,#004397); color: #FFF; text-align: center; }
.global-navi { display: block; width: 100%; text-align: center; }

.global-navi > ul > li { display: inline-block; vertical-align: middle; }
.global-navi a { display: block; padding: 1em 2em; font-weight: 900; font-size: 1.1rem; }

/*スマホ用*/
.btn_humberger { display: none; }
.global-navi .sp-menu { display: none; }

@media screen and (max-width: 1100px) {
	a.btn-contact { padding: .5em 1em;}
	
	.head-tel .ja { line-height: 120%; }
	.head-tel .en { font-size: 1.5rem; }
	.global-navi a { font-size: 1rem; padding: 1em; }
}

/*スマホ表示用CSS*/
@media screen and (max-width: 900px) {
  .header { background: #FFF; color: #333; height: 4rem; padding-right: 4rem;}
  /*メニューボタン*/
	.btn_humberger { color: #333; font-family: 'Montserrat', sans-serif; font-weight: 300; position: fixed; width: 4rem; height: 4rem; font-size: .9rem; top: 0; right: 0; display: block; background: #FFF; padding: 2em 0 0; line-height:  100%;  border: 0;  z-index: 9999; }
  .btn_humberger:before,
  .btn_humberger:after { content:''; width: 2rem; height: 3px; background: #333; border-radius: 2px; position: absolute; top: 1.8em; left: 0; right: 0; margin: auto; }
  .btn_humberger:before { -ms-transform: translateY(-.5em); -webkit-transform: translateY(-.5em); transform: translateY(-.5em); box-shadow: 0 .5em #333; }
  .btn_humberger:after { -ms-transform: translateY(.5em); -webkit-transform: translateY(.5em); transform: translateY(.5em); }
  .btn_humberger.open:before { -ms-transform: rotate(45deg); -webkit-transform: rotate(45deg); transform: rotate(45deg); box-shadow: none; }
  .btn_humberger.open:after { -ms-transform: rotate(-45deg); -webkit-transform: rotate(-45deg); transform: rotate(-45deg);}
  
  .header { min-height: 0; text-align: left; }
  
	.head-logo { max-width: none; }
  .head-logo img { height: 2rem; width: auto;  }
  
	a.btn-contact { font-size: .8rem; }
  .head-tel { font-size: .8rem;}
  
	.head-tel .en { font-size: 1.2rem; }
	.global-navi a { font-size: .8rem; padding: 1em; }
	
  
  /*グローバルナビ*/
  .global-navi { display: none; position: fixed; height: 100vh; overflow-y: scroll; top: 0; left: 0; right: 0; margin: auto; z-index: 99; padding: 5em 5%; 
	background: linear-gradient(#1772E3,#004397);}
  .global-navi.open {display: block; }
  .global-navi > ul { display: block; padding: 0;  }
  .global-navi > ul > li { width: 100%; display: block;  }
.global-navi > ul > li + li { margin-left: 0; }
  .global-navi a,
	.global-navi span { font-size: 1.1rem; line-height: 100%; padding: 1em; text-align: left;  }
	.global-navi .submenu { position: relative; top: auto; display: block; background: none; }
	.global-navi .submenu a { color: #000; padding-left: 2em; font-weight: normal; }
	.global-navi .submenu >li + li { border-top: none; }
	
  .global-navi a:before { display: inline-block; margin-right: .5em; } 
  .global-navi a:hover:after { display: none; }
  .global-navi .spmenu { display: block; }
  .global-navi .spmenu.contact a { font-weight: bold;  }
  .global-navi .spmenu.home a:before { content: ''; width: 1em; height: 1em; background: url(../img/icon-home.png) no-repeat center center; background-size: 100% auto; display: inline-block; vertical-align: middle; margin-right: .5em; }
  
.global-navi .sp-menu { display: block; }
}

@media screen and ( max-width: 600px ) {
  .head-contact { display: none;}
  .head-logo img { height: 2.5rem; }
}
/*フッター*/
.footer { background: #002F6A; color: #FFF; padding: 3rem 0; position: relative; font-size: .875rem; }
.footer img { width: 100%;  }
.footer .contents_wrap { display: flex; justify-content: space-around; flex-wrap: wrap; }
.footLeft { width: 66%; display: flex; justify-content: space-between; align-items: flex-start;flex-wrap: wrap; }
.footLeft > * { width: 45%; }

.footRight { width: 30%; text-align: right;  }
.footer-navi { font-size: .875rem; display: flex; flex-wrap: wrap; justify-content: space-between; }
.footer-navi > li { width: 48%; margin-bottom: 1em;  }
.footer-navi > li > a:hover { opacity: .7; }

a.foot-contact { width: 100%; margin: 1em 0 2em; text-align: center; font-size: 1.6rem; padding: .5em 1em; }


.copyright { font-size: .8rem; line-height: 150%; margin-top: 5rem; }

.googlemap { width: 100%; height: 0; padding-bottom: 35%; position: relative; background: #EEE; marign-bottom: .5em; }
.googlemap iframe { width: 100%; height: 100%; position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin:auto; }
@media screen and ( max-width: 1200px ) {
	.googlemap { height: 0; padding-bottom: 40%; }
}
@media screen and ( max-width: 900px ) {
	.googlemap { padding-bottom: 80%; }
  .footer-navi  { margin-bottom: 2rem;}
	.footer-navi > li { width: 48%; }
	.footLeft { width: 100%; margin-bottom: 2em; }
	.footRight { width: 100%; }
}
@media screen and ( max-width: 600px ) {
  .footLeft > * { width: 100%;  }
}
.gotop { position: fixed; width: 3rem; height: 3rem; display: block; border-radius: 50%; text-align: center; background: #3d8aea;  right: 5%;  margin: auto;  line-height: 3rem; bottom: 4rem;  }


