<strong></strong>@charset "utf-8";

/* -----------------------------------------------
 * style.css
 * LastUpdate : 18/5/22
----------------------------------------------- */
@import url('https://fonts.googleapis.com/css?family=Montserrat:800');
@font-face {
      font-family: 'Noto Sans JP';
      font-style: normal;
      font-weight: 400;
	    src: local("Noto Sans CJK JP Regular"),
           url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff2) format('woff2'),
           url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff) format('woff'),
           url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.otf) format('opentype');
   }
/* RESET
----------------------------------------------------------------------------------------------------*/
a,article,body,dd,div,dl,dt,form,footer,header,h1,h2,h3,h4,h5,h6,html,i,iframe,img,label,legend,li,nav,ol,p,section,main,span,table,tbody,tfoot,thead,time,tr,th,td,ul,video{font-family:inherit;font-size:100%;font-weight:inherit;font-style:inherit;vertical-align:baseline;white-space:normal;margin:0;padding:0;border:0;outline:0;background:transparent;line-height:1.6;text-align:left}textarea{font-family:inherit;font-size:100%;font-weight:inherit;font-style:inherit;vertical-align:baseline;margin:0;padding:0;border:0;outline:0;background:transparent;line-height:1.6;text-align:left}article,footer,header,nav,section,main{display:block}ol,ul{list-style:none}table{border-collapse:collapse;border-spacing:0}

/* ----------------------------------------------

 * 設定をしなおす

---------------------------------------------- */
body {
  margin: 0 auto;
  padding: 0;
  font-size: 15px;
  line-height: 1.6em;
  font-family: "Noto Sans", "Noto Sans CJK JP", "Noto Sans CJK JP Subset", sans-serif;
  -webkit-text-size-adjust: 100%;
  color: #009a5a;
}
@media only screen and ( max-width : 768px ) {
  body {font-size: 13px;}
}
img {
  vertical-align: bottom;
  border: none;
}
/* ----------------------------------------------

 * アンカータグの設定

---------------------------------------------- */
a {
  outline:none;
  color: #333;
}
a:hover {
  text-decoration: none;
}
a,a:hover,a:hover img,a:after,a:before,img {
  -webkit-transition: 0.5s;
  -moz-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
  text-decoration: none;
}
a:hover {
  filter: alpha(opacity=80);
  -moz-opacity:0.80;
  opacity:0.80;
}
/* ----------------------------------------------

 * 要素を左右中央寄せ

---------------------------------------------- */
.taC {
  text-align: center !important;
}
.taR {
  text-align: right !important;
}
.taL {
  text-align: left !important;
}
.imgR {
  float: right;
  margin-left: 2em;
  margin-bottom: 2em;
}
.imgL {
  float: left;
  margin-right: 2em;
  margin-bottom: 2em;
}
.clr{zoom:1;display:inline-table}.clr:after{content:".";display:block;height:0;clear:both;visibility:hidden;font-size:0;line-height:0}* html .clr{height:1%;display:inline-table;display:block;height:1%}.clr{display:block}

::-webkit-input-placeholder {
  color: #ccc;
}
input,textarea {
    border-radius:0;
    line-height: 1em;
}
input[type="text"],textarea,input[type="tel"],input[type="email"]{
  padding:10px;
  border: 1px solid #99d7bd;
  margin:0;
  display: block;
  background: #f6f6f6;
  width: 100%;
  font-family: inherit;
  -webkit-appearance: none;
  line-height: 2em;
}
input[type="submit"] {
  -webkit-appearance: none;
	color: #red;
}
textarea {
  height: 15em;
}

*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;*behavior:url(/scripts/boxsizing.htc)}.container{margin:0 auto}.clr:after,.col:after,.container:after,.group:after,.row:after{content:"";display:table;clear:both}.row{padding-bottom:0}.col{display:block;float:left;width:100%}@media (min-width:769px),print{.gutters .col{margin-left:2%}.gutters .col:first-child{margin-left:0}.gutters .colR:first-child{margin-right:0}.sp{display:none}}@media(max-width:768px){.sp_none{display:none !important;}}

@media print,screen and (min-width:769px){
  .span_1_full{width:8.33333333333%}
  .span_2_full{width:16.6666666667%}
  .span_3_full{width:25%}
  .span_4_full{width:33.3333333333%}
  .span_5_full{width:41.6666666667%}
  .span_6_full{width:50%}
  .span_7_full{width:58.3333333333%}
  .span_8_full{width:66.6666666667%}
  .span_9_full{width:75%}
  .span_10_full{width:83.3333333333%}
  .span_11_full{width:91.6666666667%}
  .span_12_full{width:100%}

  .span_1{width:6.5%;}
  .span_2{width:15%;}
  .span_3{width:23.5%;}
  .span_4{width:32%;}
  .span_5{width:40%;}
  .span_6{width:49%;}
  .span_7{width:57%;}
  .span_8{width:66%;}
  .span_9{width:74.5%;}
  .span_10{width:83%;}
  .span_11{width:91.5%;}
  .span_12{width:100%;}
}
/* ----------------------------------------------
 * base.css
----------------------------------------------- */
* {box-sizing:border-box;}
main {display: block;}
img {
    max-width: 100%;
    height: auto;
    width /***/:auto;/*IE8のみ適用*/
}
.min {
  font-family:serif;
}
@media only screen and ( max-width : 768px ) {
  .container,.small_container {
    padding: 0 20px;
  }
  .sp_box {
    margin-bottom: 30px;
  }
  .sp_sbox {
    margin-bottom: 10px;
  }
  .sp_inner {
    padding: 0 20px;
  }
  section {
    margin-bottom: 30px;
  }
  .section {
    padding: 30px 0;
    margin-bottom: 0;
  }
  .br_pc {
    display: none;
  }
  .box {
    margin-bottom: 30px;
  }
  .sbox {
    margin-bottom: 20px;
  }
  .ssbox {
    margin-bottom: 10px;
  }
}
@media only screen and ( max-width : 480px ) {
  .container,.small_container {
    padding: 0 15px;
  }
}
@media print, screen and ( min-width : 769px ) {
  .container {
    max-width: 1140px;
    padding: 0 20px;
  }
  .small_container {
    width: 830px;
    padding: 0 15px;
    margin: 0 auto;
  }
  .posL {
    float: left;
  }
  .posR {
    float: right;
  }
  .br_sp {
    display: none;
  }
  section {
    margin-bottom: 50px;
  }
  .section {
    padding: 80px 0;
    margin-bottom: 0;
  }
  .box {
    margin-bottom: 50px;
  }
  .sbox {
    margin-bottom: 25px;
  }
  .ssbox {
    margin-bottom: 15px;
  }
}
@media print, screen and ( min-width : 1100px ) {
	.container {
		width: 1100px;
		padding: 0;
		margin-left: auto;
		margin-right: auto;
	}
	.small_container {
		width: 800px;
		padding: 0;
	}
}
/* ---------------------------------------------------------------------------------------------

　   HEADER

--------------------------------------------------------------------------------------------- */
#header {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	z-index: 99;
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
}
#h_logo,#h_entry {
	position: relative;
	z-index: 10;
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
}
#h_logo2 {
	display: none;
}
@media only screen and ( max-width : 768px ) {
	#header {
		background: url(../img/header-top.png) no-repeat top center / 100% 50%;
		height: 80px;
	}
	#h_logo {
		display: none;
	}
	#h_logo2 {
		display: block;
		width: 100px;
		position: relative;
		z-index: 10;
		-webkit-transition: 0.5s;
		-moz-transition: 0.5s;
		-o-transition: 0.5s;
		transition: 0.5s;
	}
	#h_entry {
		width: 140px;
	}
	#header.is-animation {
		height: 60px;
	}
	.is-animation #h_logo2 {
		width: 80px;
	}
	.is-animation #h_entry {
		width: 120px;
	}
}
@media print, screen and ( min-width : 769px ) {
	#h_logo2 {
		display: none;
	}
  #header {
    background: url(../img/header-top.png) no-repeat top center / 100% 60%;
    height: 160px;
  }
  #header #h_logo {
    width: 160px;
  }
  #header.is-animation {
    height: 100px;
  }
  #header.is-animation #h_logo {
    width: 100px;
  }
 #header.is-animation #h_logo2 {
    width: 100px;
  }
  #h_entry {
    width: 240px;
  }
  .is-animation #h_entry {
    width: 180px;
  }
}
/* ---------------------------------------------------------------------------------------------

　   FOOTER

--------------------------------------------------------------------------------------------- */
#footer {
  background: #343434;
}
.copy {
  text-align: center;
  color: #cdcdcd;
  font-size: 10px;
}
.f_nav {
  background: #404040;
}
.f_nav li a {
  color: #cdcdcd;
}
.f_logo {
  margin-bottom: 1em;
}
@media only screen and ( max-width : 768px ) {
  .f_inner {
    padding: 20px;
  }
  .f_nav li {
    border-bottom: 1px solid #777;
  }
  .f_nav li a {
    display: block;
    text-align: center;
    padding: 10px;
  }
}
@media print, screen and ( min-width : 769px ) {
  .f_inner {
    padding: 20px;
  }
  .f_nav {
    padding: 0.5em 0;
  }
  .f_nav li {
    margin-right: 40px;
    font-size: 14px;
  }
  .f_nav li:last-child {
    margin-right: 0;
  }
}
/* ---------------------------------------------------------------------------------------------

　   FLEX

--------------------------------------------------------------------------------------------- */
.flexbox {
  -js-display : flex;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
.space-between {
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.center {
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
}
.flex-end {
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}
.align-center {
  -webkit-box-align:center;
  -ms-flex-align:center;
  -webkit-align-items:center;
  align-items: center;
}
.align-start {
  -webkit-align-items:flex-start;
  align-items: flex-start;
}
.align-stretch {
  -webkit-align-items:stretch;
  align-items: stretch;
 }
@media only screen and ( max-width : 768px ) {
  .flexbox_sp {
    -js-display : flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
@media print, screen and ( min-width : 769px ) {
  .flexbox_pc {
    -js-display : flex;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .flexbox_pc .span_4 {
    width: 31%;
  }
  .flex_direction_pc {
    flex-direction: row-reverse;
  }
}
/* ---------------------------------------------------------------------------------------------

　   PAGE TOP

--------------------------------------------------------------------------------------------- */
#pageTop {
  position: fixed;
  bottom: 1em;
  right: 1em;
  z-index: 9999;
}
#pageTop a {
  display: block;
  z-index: 999;
  width: 50px;
  height: 50px;
  line-height: 50px;
  background-color: #009a5a;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
  border-radius: 50%;
  font-size: 133.3%;
}
#pageTop a:hover {
  background-position: right center; 
  filter: alpha(opacity=100);
  -moz-opacity:1.0;
  opacity:1.0;
}
/* ---------------------------------------------------------------------------------------------

　   CONTENTS

--------------------------------------------------------------------------------------------- */
h2 {
  position: relative;
  padding-bottom: 1.4em;
  color: #009a5a;
}
h2:after {
  content: "";
  height: 4px;
  width: 20px;
  background: #009a5a;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -10px;
}
h2 .en {
  display: block;
  letter-spacing: 0.1em;
  text-align: center;
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
}
h2 .jp {
	display: block;
	text-align: center;
	letter-spacing: 3px;
	font-size: 18px;
}
h3 {
  font-weight: bold;
}
h3 span {
  font-family: 'Montserrat', sans-serif;
  font-weight: 800;
}
h4 {
  font-weight: bold;
}
@media only screen and ( max-width : 768px ) {
  h2 {
    margin-bottom: 20px;
  }
  h2 .en {
    font-size: 24px;
  }
  h2 .jp {
    font-size: 14px;
  }
  h3 {
    font-size: 20px;
    margin-bottom: 20px;
  }
  h4 {
    font-size: 18px;
  }
}
@media print, screen and ( min-width : 769px ) {
  h2 {
    margin-bottom: 60px;
  }
  h2 .en {
    font-size: 48px;
  }
  h3 {
    font-size: 30px;
    margin-bottom: 30px;
  }
  h4 {
    font-size: 24px;
  }
}
