
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,500,700,900&display=swap&subset=japanese');

/*# ★★paddingあふれ防止★★ */
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}

html {
	font-family: 'Noto Sans JP', sans-serif;
  	max-width: 100%;
  	color: #000000;
  	-webkit-text-size-adjust: 100%;
  	-ms-text-size-adjust: 100%;
  	text-size-adjust: 100%;
  	font-size: 62.5%;
  	overflow-x: hidden;
}

body {
  	font-size: 1.3rem;
	line-height: 1.7;
	font-weight: 300;
}

h1, h2, h3, h4, h5, h6, th {
	font-family: 'Noto Sans JP', sans-serif;
  	font-weight: 400;
  	line-height: 1.7;
}

/*# 横スクロールバー表示禁止 */
@media screen and (max-width:768px) {

html {
	overflow: auto;
}
body {
	overflow: hidden;
	min-width: 100%;
}

}

.inner1140{
	width: 1140px;
	margin-right: auto;
	margin-left: auto;
}

.inner1140-r{
	width: 1140px;
	margin-right: auto;
	margin-left: auto;
	position:relative;
}

.inner800{
	width: 800px;
	margin-right: auto;
	margin-left: auto;
}

.inner500{
	width: 500px;
	margin-right: auto;
	margin-left: auto;
}

@media screen and (max-width:1200px) {
.inner1140,
.inner1140-r{
	width: 95%;
}
}

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

@media screen and (max-width:568px) {
	
.inner500{
	width: 95%;
}
	
}

h1 {
	font-size: 5rem;
	color: #ffffff;
	font-weight: 400;
	line-height: 1.5;
}

h2 {
  	font-size: 3rem;
	color: #000000;
  	position: relative;
    z-index: 10; 
}

.h2-aria {
  	position: relative;
}

.h2-aria span {
	font-family: 'Noto Sans JP', sans-serif;
  	font-size: 8rem;
  	font-weight: 400;
  	line-height: 1.7;
	color: #ffffff;
  	position: absolute;
  	top: 50%;
  	left: 50%;
  	transform: translateY(-50%) translateX(-50%);
  	-webkit- transform: translateY(-50%) translateX(-50%);
    z-index: 1; 
}

h3 {
  	font-size: 2rem;
	position: relative;
	text-align: center;
	width: 100%;
}

h4 {
  	font-size: 3.5rem;
	position: relative;
	text-align: center;
	width: 100%;
	margin-top: 50px;
}

p {
	font-family: 'Noto Sans JP', sans-serif;
	line-height: 1.3;
  	font-weight: 300;
	color: #000000;
}

@media screen and (max-width:1200px) {
	
h1 {
	font-size: 3rem;
}
	
h4 {
  	font-size: 3rem;
}
	
}

@media screen and (max-width:768px) {
	
h1 {
	font-size: 2.5rem;
}
	
h2 {
  	font-size: 1.6rem;
}
	
.h2-aria span {
  	font-size: 4rem;
}
	
h3 {
  	font-size: 1.6rem;
}
	
h4 {
  	font-size: 2rem;
	margin-top: 30px;
}
	
}

span {
	line-height: 1.3;
}

.red {
	color: #ff0000;
}

.t-c {
	text-align: center;
}

.t-l {
	text-align: left;
}

.t-r {
	text-align: right;
}

a {
  text-decoration: none;
}

a:hover, a:active, a:focus {
  text-decoration: none;
}

/*# ★★汎用設定★★ */

/*# ★★画像100％★★ */

.img100{
	width: 100%;
	height: auto;
}

/*# ★★PC、スマホの表示非表示★★ */

/*# 1200以上は表示 */
.x-pc { display:inline; }
/*# 992以上は表示 */
.x-note { display:inline; }
/*# 768以上は表示 */
.x-tb { display:inline; }
/*# 568以上は表示 */
.x-sp { display:inline; }

/*# 992以下は表示 */
.pc-0 { display:none; }
/*# 992以下は表示 */
.note-0 { display:none; }
/*# 768以下は表示 */
.tb-0 { display:none; }
/*# 568以下は表示 */
.sp-0 { display:none; }

@media screen and (max-width:1200px) {
	
.x-pc { display:none; }
.pc-0 { display:inline; }
	
}

@media screen and (max-width:992px) {
	
.x-note { display:none; }
.note-0 { display:inline; }
	
}

@media screen and (max-width:768px) {
	
.x-tb { display:none; }	
.tb-0 { display:inline; }

}

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

.x-sp { display:none; }
.sp-0 { display:inline; }
	
}

/*# 左右均等配置 */

.justify,
.justify-pc,
.justify-pc2{
	display:flex;
	display:-moz-flex;
	display:-o-flex;
	display:-webkit-flex;
	display:-ms-flex;
	justify-content:space-between;
	-moz-justify-content:space-between;
	-o-justify-content:space-between;
	-webkit-justify-content:space-between;
	-ms-justify-content:space-between;
}

@media screen and (max-width:768px) {
	
.justify-pc{
	display:initial;
	display:-moz-initial;
	display:-o-initial;
	display:-webkit-initial;
	display:-ms-initial;
	justify-content:space-between;
	-moz-justify-content:space-between;
	-o-justify-content:space-between;
	-webkit-justify-content:space-between;
	-ms-justify-content:space-between;
}
	
}

@media screen and (max-width:568px) {
	
.justify-pc2{
	display:initial;
	display:-moz-initial;
	display:-o-initial;
	display:-webkit-initial;
	display:-ms-initial;
	justify-content:space-between;
	-moz-justify-content:space-between;
	-o-justify-content:space-between;
	-webkit-justify-content:space-between;
	-ms-justify-content:space-between;
}
	
}


/*# ロールオーバーでイメージ半透明 */
.alpha a:hover img {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
}

/*# clearfix */
.clearfix:after {
	clear: both;
	content:".";
	display:block;
	height:0;
	visibility:hidden;
}
.clearfix { display:inline-block; }
* html .clearfix { height:1%; }
.clearfix { display:block; }

/*# 文字関係 */

.bold {
	font-weight: bold;
}

.cen {
	text-align: center;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

.f10 {
	font-size: 10px;
}

.fb {
	color: #333333;
}

.fr {
	color: #D0121B;
}

.fw {
	color: #ffffff;
}

.lh130 {
	line-height: 130%;
}

.lh140 {
	line-height: 140%;
}

.lh150 {
	line-height: 150%;
}

.lh170 {
	line-height: 170%;
}

.t-cen {
	text-align: center;
}

.t-lef {
	text-align: left;
}

.t-rig {
	text-align: right;
}

/*# 空き、マージントップ */

.mt5 {
	margin-top: 5px !important;
}

.mt10 {
	margin-top: 10px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mt30 {
	margin-top: 30px !important;
}

.mt40 {
	margin-top: 40px !important;
}

.mt50 {
	margin-top: 50px !important;
}

.mt60 {
	margin-top: 60px !important;
}

.mt70 {
	margin-top: 70px !important;
}

.mt80 {
	margin-top: 80px !important;
}

.mt90 {
	margin-top: 90px !important;
}

.mt100 {
	margin-top: 100px !important;
}

/*# 空き、マージンボトム */

.mb10 {
	margin-bottom: 10px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb50 {
	margin-bottom: 50px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb70 {
	margin-bottom: 70px !important;
}

.mb80 {
	margin-bottom: 80px !important;
}

.mb90 {
	margin-bottom: 90px !important;
}

.mb100 {
	margin-bottom: 100px !important;
}

/*# 空き、パディングトップ */

.pt10 {
	padding-top: 10px !important;
}

.pt20 {
	padding-top: 20px !important;
}

.pt30 {
	padding-top: 30px !important;
}

.pt40 {
	padding-top: 40px !important;
}

.pt50 {
	padding-top: 50px !important;
}

.pt60 {
	padding-top: 60px !important;
}

.pt70 {
	padding-top: 70px !important;
}

.pt80 {
	padding-top: 80px !important;
}

.pt90 {
	padding-top: 90px !important;
}

.pt100 {
	padding-top: 100px !important;
}

/*# 空き、パディングボトム */

.pb10 {
	padding-bottom: 10px !important;
}

.pb20 {
	padding-bottom: 20px !important;
}

.pb30 {
	padding-bottom: 30px !important;
}

.pb40 {
	padding-bottom: 40px !important;
}

.pb50 {
	padding-bottom: 50px !important;
}

.pb60 {
	padding-bottom: 60px !important;
}

.pb70 {
	padding-bottom: 70px !important;
}

.pb80 {
	padding-bottom: 80px !important;
}

.pb90 {
	padding-bottom: 90px !important;
}

.pb100 {
	padding-bottom: 100px !important;
}

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

.mt30,
.mt40,
.mt50,
.mt60,
.mt70 {
	margin-top: 30px !important;
}

}

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

.mt30,
.mt40,
.mt50,
.mt60,
.mt70 {
	margin-top: 20px !important;
}

}


/* Topへ戻るボタン */
#page-top {
  position: fixed;
  bottom: 50px;
  right: 50px;
  width: 42px;
  height: 42px;
	z-index: 10000;
}

.arrow{
  position: relative;
  display: inline-block;
  color: #000;
  vertical-align: middle;
  text-decoration: none;
  width: 42px;
  height: 42px;
}

.arrow::before{
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  box-sizing: border-box;
  width: 42px;
  height: 42px;
  border: 1px solid #999999;
  background: #ffffff;
}

.arrow::after{
  content: '';
  width: 26px;
  height: 26px;
  border: 0px;
  border-top: solid 1px #999999;
  border-left: solid 1px #999999;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  left: 8px;
  margin-top: -4px;
}

.arrow a{
    position:absolute;
    top:0;
    left:0;
    width: 100%;
    height: 100%;
    text-indent:-999px;
}

.arrow:hover::after{
  border-top: solid 1px #B4B4B4;
  border-left: solid 1px #B4B4B4;
}

.arrow a:hover{
	border: 1px solid #B4B4B4;
}

@media screen and (max-width: 640px) {
#page-top {
  right: 10px;
}
}





