@charset "UTF-8";

/*---------------------------------------------------------
	全ページ共通スタイル
---------------------------------------------------------*/
html {
	font-size: 62.5%;
}
body,
html {
  min-width: 1040px;
	display: block;
	height: 100%;
}

/* 要素設定*/
body {
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif;
	font-size: 14px;
	font-size: 1.4rem;
	color: #000;
	line-height:1.6;
	letter-spacing: 0px;
	word-break: normal;
	word-wrap:break-word;
}
button,
a {
	color:#000;
}
.ios a:hover {
  opacity: 1;
}
.mincho {
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.sp-block,.sp-inline{
	display: none;
}
.wrapper{
/*	max-width: 1920px;*/
	margin: 0 auto;
}
.inview_box{
	opacity: 0;
	transition: all 1000ms ease;
	-webkit-transition: all 1000ms ease;
	-moz-transition: all 1000ms ease;
	position: relative;
	z-index: 1;
	top:50px;
}
.inview_box_on{
	opacity: 1;
	top:0px;
}

.mainWidth{
  position: relative;
	width: 100%;
	max-width: 990px;
	margin: 0 auto;
}
.mainWidth_880{
  position: relative;
	width: 100%;
	max-width: 880px;
	margin: 0 auto;
}

*{
	box-sizing: border-box;
}

/*　ヘッダー
---------------------------------------------------------*/
#pageHeader {
  position: relative;
  z-index: 3000;
}
/* 高さ指定 */
.header-height {
  height: 60px;
}
.header-lineheight {
  line-height: 60px;
}

/* follow */
/* fix後の高さ維持 */
.headerfix-wrap {
  position: relative;
}
.headerfix {
  position: relative;
  z-index: 1000;
}
.headerfix.follow {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}

/* logo */
.header_top {
  position: absolute;
  left: 50%;
  top: 0;
  /*-webkit-transform: translate(-50%,0);
  -moz-transform: translate(-50%,0);
  -ms-transform: translate(-50%,0);
  -o-transform: translate(-50%,-0);*/
  transform: translate(-50%,0);
}
.header_logo {
  /*width: 190px;*/
  width: 100px;
}
.header_logo img {
  position: relative;
  top: -3px;
  height: 45px;/*ADD*/
}
.header_t {
  /*padding-left: 60px;*/
  padding-right: 30px;
  padding-left: 30px;
}

/* gnav btn */
.menu_btn .btn {
  cursor: pointer;
  background: url(../img/menu_img@2x.png) left center no-repeat;
  -webkit-background-size: 14px auto;
       -o-background-size: 14px auto;
          background-size: 14px auto;
}
.menu_btn .btn.active {
    background: url(../img/menu_close@2x.png) left center no-repeat;
    -webkit-background-size: 14px auto;
         -o-background-size: 14px auto;
            background-size: 14px auto;
}

/* gnav menu */
#head01 nav.nav {
  position: absolute;    
}  
@media screen and (max-width:400px){/*MENU POSITION ADJUST*/
  #head01 nav.nav {
    left: 10px;
  }  
}@media screen and (min-width:401px) and (max-width:680px){/*MENU POSITION ADJUST*/
  #head01 nav.nav {
    left: 10%;
  }  
}
@media screen and (min-width:681px) and (max-width:1040px){
  #head01 nav.nav {
    left: 29px;
  }  
}
@media screen and (min-width:1041px){
  #head01 nav.nav {
    left: 0;
  }  
}

.nav .menu_list_wrap {
  opacity: 0;
  z-index: 3000;
  position: fixed;
  left: 0;
  top: 0;
  margin-top: 60px;
  height: calc(100% - 60px);
  -webkit-overflow-scrolling: touch;
  -ms-overflow-y: auto;
      overflow-y: auto;
  transition: opacity 1s;
  -webkit-transition: opacity 1s;
  -moz-transition: opacity 1s;
}
.nav .menu_list_wrap.active {
  opacity: 1;
  transition: none;
  -webkit-transition: none;
  -moz-transition: none;
}
.nav .menu_list {
  position: relative;
  z-index: 2;
}
.nav .menu_list a {
	display: block;
  white-space: nowrap;
	color: #fff;
	font-weight: 300;
	padding: 20px 0;
}

/* gnav表示の際はその他の要素をマスクする */
.overlay {
  position: fixed;
  z-index: -1;
  width: 100vw;
  height: 100vh;
  left: 0;
  top: 0;
}
.overlay.active {
  z-index: 2000;
}
.overlay_list {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

/* entry */
#pageHeader .entry_btn_wrap {
    position: absolute;
	z-index: 4000;
    top: 0;
    right: 0;
    width: 150px;
    height: 100px;
}
#pageHeader .entry_btn_wrap.r2nd {/*ADD*/
    right: 160px;
}
#pageHeader .entry_btn {
    cursor: pointer;
    height: 100%;
    padding-top: 38px;
    background: url(../img/entry_img@2x.png) center top 60px no-repeat;
    background-size: 9px;
}
#pageHeader .entry_btn span {
    line-height: 1;
    letter-spacing: 0.26em;
    padding-left: 0.13em;
}

/* entry_btn_menu */
.entry_btn_menu {
  display: none;
}
.entry_btn_menu li a {
  display: block;
  padding: 8px 0;
}

/* entry follow */
#pageHeader .headerfix.follow .entry_btn_wrap {
  height: 60px;
}
#pageHeader .headerfix.follow .entry_btn {
  padding-top: 16px;
  background: url(../img/entry_img@2x.png) center top 38px no-repeat;
  background-size: 9px;
}


/*　コンテンツ
---------------------------------------------------------*/
#pageMain{
    min-height: 200px;
}
.contents {
    /*background: linear-gradient(to right, #e9e9ea 30%, #F0F0F0 30%);*/
    background: linear-gradient(to bottom, #ececec 40px, #F0F0F0 40px);
    position: relative;
    z-index:  1;
    overflow: hidden;
}

.contents:before {
  content: '';
  display: block;
  width: 290px;
  height:  100%;
  background-color: #F0F0F0;
  position: absolute;
  top: 40px;
  left: calc(50% - 290px);
  z-index: -1;
}


.contents:after {
	content: '';
	display: block;
/*	width: 290px;*/
  width: 30%;
	height:  100%;
	background: linear-gradient(to bottom, #F0F0F0 0%, #e9e9ea 40%);
	position: absolute;
	top: 40px;
/*	left: calc(50% - 290px);*/
  left: 0;
	z-index: -2;
}

.contents .bread {
    padding: 63px 0 25px;
}
.contents .bread ul {}
.contents .bread ul li {
    display:  inline-block;
    position:  relative;
    font-size:  10px;
    line-height:  12px;
    letter-spacing: 0.24em;
    padding: 0 5px;
}
.contents .bread ul li:first-child {}
.contents .bread ul li:last-child {}
.contents .bread ul li a {
    display:  block;
}
.contents .bread ul li a:hover {}
.contents .bread ul li:before {}
.contents .bread ul li + li {
    padding-left: 15px;
}
.contents .bread ul li + li:before {
	content: '';
	display: block;
	width: 8px;
	height: 12px;
	background: url(../img/bread_img@2x.png)0 center no-repeat;
	background-size: 8px;
	position:  absolute;
	top: 0;
	left:  0;
}

/*　タイトル　*/
.ttl01{}
.h2_01 {}

/*　ボタン　*/
.btn01{}

/*　ヤジルシ　*/
.arw01{}


/*　トップリンク　*/
/*.pagetop {
	display: block;
	background: url(../img/pagetop@2x.png) 0 0 no-repeat;
	background-size: contain;
	width: 60px;
	height: 60px;
	position: fixed;
	bottom: 0;
	right: -60px;
	z-index: 100;
}*/
.pagetop {
  overflow: hidden;
  position: fixed;
  bottom: 0;
  right: -60px;
  display: block;
  width: 60px;
  height: 60px;
  z-index: 200;
  background-color: #a80505;
}
.pagetop span {
  position: absolute;
  display: block;
  opacity: 1;
  left: 0;
  top: 0;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  padding: 1.2em 1.4em;
  text-align: center;
  -webkit-transition: all 0.3s linear;
  transition: all 0.3s linear;
  box-shadow: none;
}
.pagetop span:nth-of-type(1) {
  top: 0px;
}
.pagetop span:nth-of-type(2) {
  top: 58px;
}
.pagetop span:nth-of-type(3) {
  top: 118px;
}
.pagetop span img {
  width: 1.6em;
}
.pagetop:hover > span:nth-of-type(1) {
  top: -58px;
  opacity: .6;
}
.pagetop:hover > span:nth-of-type(2) {
  top: 0;
  opacity: .8;
}
.pagetop:hover > span:nth-of-type(3) {
  top: 58px;
  opacity: 1;
}


/*　フッター
---------------------------------------------------------*/

#pageFooter{}
#pageFooter{
    max-width: 1920px;
    margin: 0 auto;
}
.footer_inner {
    max-width: 990px;
    margin: 0 auto;
    padding: 60px 0 66px;
    text-align: center;
}
.footer_inner .foot_1 {
    margin-bottom: 33px;
}
.footer_inner .foot_1 .nav {}
.footer_inner .foot_1 .nav ul {}
.footer_inner .foot_1 .nav ul li {
    display:  inline-block;
    margin: 0px 36px;
}
.footer_inner .foot_1 .nav ul li:first-child {}
.footer_inner .foot_1 .nav ul li:last-child {}
.footer_inner .foot_1 .nav ul li a {
    display:  block;
    padding: 5px 11px;
    font-size:  15px;
    font-weight: 500;
    letter-spacing: 0.04em;
}
.footer_inner .foot_2 {
    margin-bottom: 33px;
}
.footer_inner .foot_2 .foot_logo {
    width:  146px;
    margin: 0 auto;
}
.footer_inner .foot_2 .foot_logo a {}
.footer_inner .foot_2 .foot_logo img {}



.copyright {
    font-size: 13px;
    font-weight: 300;
    letter-spacing: 0.07em;
    text-align: center;
}
.copyright span{}

/*---------------------------------------------------------
  tab
---------------------------------------------------------*/
  @media screen and (max-width: 1040px) {
  /*---------------------------------------------------------
    全ページ共通スタイル
  ---------------------------------------------------------*/
  html {
    font-size: 62.5%;
  }
  body,
  html {
    min-width: 0;
    display: block;
    height: 100%;
  }

  /* 要素設定*/
  body {
    font-family: 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif;
    font-size: 14px;
    font-size: 1.4rem;
    color: #000;
    line-height:1.6;
    letter-spacing: 0px;
    word-break: normal;
    word-wrap:break-word;
  }
  button,
  a {
    color:#000;
  }
  .ios a:hover {
    opacity: 1;
  }
  .mincho {
    font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  }

  .sp-block,.sp-inline{
    display: none;
  }
  .wrapper{
/*    max-width: 1920px;*/
    margin: 0 auto;
  }
  .inview_box{
    opacity: 0;
    transition: all 1000ms ease;
    -webkit-transition: all 1000ms ease;
    -moz-transition: all 1000ms ease;
    position: relative;
    z-index: 1;
    top:50px;
  }
  .inview_box_on{
    opacity: 1;
    top:0px;
  }

  .mainWidth{
    position: relative;
    width: 100%;
    max-width: 990px;
    margin: 0 auto;
    padding-left: 3% !important;
    padding-right: 3% !important;
  }
  .mainWidth_880{
    position: relative;
    width: 100%;
    max-width: 880px;
    margin: 0 auto;
    padding-left: 3% !important;
    padding-right: 3% !important;
  }

  /*---------------------------------------------------------
    header
  ---------------------------------------------------------*/
  .header_logo {
    /*width: 160px;*/
    width: 100px;
  }
  .header_logo img {
    top: -3px;
  }
  .header_t {
    padding-left: 20px;
    letter-spacing: 0 !important;
    display: block;
  }
}

#head01 {
  padding-left: 9.375%!important;
}

@media screen and (min-width: 681px) and (max-width: 880px) {
  .header_t {
    display: none !important;
  }
  .header_logo {
    width: 140px;
  }
}

@media screen and (min-width: 421px) and (max-width: 680px) {/*special size*/
  .header_top {
    left: 50%;
  }
}
@media screen and (max-width: 399px) {
  #head01 {
    padding-left: 10px!important;
  }
  .header_top {
    left: 36%!important;
  }
}
/*---------------------------------------------------------
	スマホ
---------------------------------------------------------*/

@media screen and (max-width: 680px) ,screen and (max-width: 737px) and (orientation: landscape) {
	body,
	html {
			min-width: 0;
	}
	body {
		font-size: 12px;
		font-size: 1.2rem;
	}

	.sp-none {
		display: none;
	}
	.sp-block {
		display: block;
	}
	.sp-inline {
		display: inline;
	}
	.sp-brNone br{
		display: none;
	}


	.sp-none {
		display: none;
	}
	.sp-block {
		display: block;
	}
	.sp-inline {
		display: inline;
	}
	.sp-brNone br{
		display: none;
	}

	.wrapper{}
	.inview_box{}
	.inview_box_on{}

	.mainWidth{
    padding-left: 9.375% !important;
    padding-right: 9.375% !important;
    max-width: 680px;
}
	.mainWidth_880{
		padding-left: 9.375% !important;
    padding-right: 9.375% !important;
    max-width: 680px;
	}

  /*　ヘッダー
  ---------------------------------------------------------*/
  /* 高さ指定 */
  .header-height {
    height: 40px;
  }
  .header-lineheight {
    line-height: 40px;
  }

  /* follow */
  /* fix後の高さ維持 */
  .headerfix-wrap {
    position: relative;
  }
  .headerfix {
    position: relative;
    z-index: 1000;
  }
  .headerfix.follow {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
  }

  /* logo */
  .header_top {
    width: auto !important;/*30% !important;*/
    position: absolute;
    top: 45%;
    left: 40%;
    /*-webkit-transform: translate(-50%,-50%);
    -moz-transform: translate(-50%,-50%);
    -ms-transform: translate(-50%,-50%);
    -o-transform: translate(-50%,-50%);*/
    transform: translate(-50%,-50%);
  }
  .header_logo {
    width: auto;
  }
  .header_logo img {
    position: static;
    /*width: 100%;*/
    height: 35px;/*ADD*/  
  }
  .header_t {
    display: none !important;
  }

  /* gnav btn */
  .menu_btn .btn {
    background: url(../img/menu_img@2x.png) left center no-repeat;
    -webkit-background-size: 12px auto;
         -o-background-size: 12px auto;
            background-size: 12px auto;
  }
  .menu_btn .btn.active {
      background: url(../img/menu_close@2x.png) left center no-repeat;
      -webkit-background-size: 12px auto;
           -o-background-size: 12px auto;
              background-size: 12px auto;
  }

  /* gnav menu */
  .nav .menu_list_wrap {
    position: fixed;
    left: 0;
    top: 0;
    margin-top: 40px;
    margin-bottom: 40px;
    height: calc(100% - 40px);
    -webkit-overflow-scrolling: touch;
    -ms-overflow-y: auto;
        overflow-y: auto;

  }
  .nav .menu_list a {
    display: block;
    white-space: normal;
    color: #fff;
    font-weight: 300;
    padding: 10px 0;
  }

  /* entry */
  #pageHeader .entry_btn_wrap {
      position: absolute;
      top: 0;
      right: 0;
      width: 80px;
      height: 40px;
  }
  #pageHeader .entry_btn_wrap.r2nd {/*ADD*/
    right: 85px;
  }
  #pageHeader .entry_btn {
      height: 100%;
      padding-top: 9px;
      background: url(../img/entry_img@2x.png) center top 25px no-repeat;
      background-size: 9px;
  }
  #pageHeader .entry_btn span {
      line-height: 1;
      letter-spacing: 0.12em;
      padding-left: 0.06em;
  }

  /* entry follow */
  #pageHeader .headerfix.follow .entry_btn_wrap {
    height: 40px;
  }
  #pageHeader .headerfix.follow .entry_btn {
    padding-top: 9px;
    background: url(../img/entry_img@2x.png) center top 25px no-repeat;
    background-size: 9px;
  }


	/*　コンテンツ
	---------------------------------------------------------*/
	#pageMain{}
	.contents {
    background: #F0F0F0;
  }
	.contents:before {
    width: 95px;
    left: calc(50% - 95px);
}
	.contents .bread {
		display: none;
	}
	.contents .bread ul {}
	.contents .bread ul li {}
	.contents .bread ul li:first-child {}
	.contents .bread ul li:last-child {}
	.contents .bread ul li a {}
	.contents .bread ul li:before {}
	.contents .bread ul li + li {}
	.contents .bread ul li + li:before {}

	/*　タイトル　*/
	.ttl01{}
	.h2_01 {}

	/*　ボタン　*/
	.btn01{}

	/*　ヤジルシ　*/
	.arw01{}


	/*　トップリンク　*/
/*	.pagetop {
		width: 45px;
		height: 45px;
		background-image: url(../img/pagetop_sp@2x.png);
	}*/
  .pagetop {
    width: 33px;
    height: 38px;
  }
  .pagetop span {
    padding: 1.2em 1em;
  }
  .pagetop span img {
    width: 1em;
  }

	/*　フッター
	---------------------------------------------------------*/

	#pageFooter{}
	#pageFooter{}
	.footer_inner {
    padding: 0px 0 62px;
}
	.footer_inner .foot_1 {
    margin-bottom: 35px;
}
	.footer_inner .foot_1 .nav {}
	.footer_inner .foot_1 .nav ul {}
	.footer_inner .foot_1 .nav ul li {
    display:  block;
    width: 100%;
    margin:  0;
    border-bottom: 1px solid #666;
}
	.footer_inner .foot_1 .nav ul li:first-child {}
	.footer_inner .foot_1 .nav ul li:last-child {}
	.footer_inner .foot_1 .nav ul li a {
    padding: 30px 10px;
    font-size:  14px;
    line-height: 20px;
    letter-spacing: 0.1em;
}
	.footer_inner .foot_2 {
    margin-bottom: 28px;
}
	.footer_inner .foot_2 .foot_logo {
    width: 118.5px;
}
	.footer_inner .foot_2 .foot_logo a {}
	.footer_inner .foot_2 .foot_logo img {}

	.copyright {
    font-size:  10px;
    letter-spacing: 0.1em;
		-webkit-transform: scale(0.9);
    transform: scale(0.9);
}
	.copyright span{}

}

