
/* ボディ
------------------------------------------------- */
html {
  font-size: 62.5%;
		overflow-x: hidden;
}
body {
	background: #fff;
	font-family: 'A1ゴシック B', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
	font-size: 1.6rem;
	color: #222222;
	line-height: 1.6;
	letter-spacing: 1px;
	margin: 0 auto;
	box-sizing:border-box;
	}

.section-warp{
	width: 100%;
	padding: 0 6%;
	clear:both;
	box-sizing: border-box;
}
.bg-container {
	position: relative;
	height: 100%;
}
.c-section{
	margin-right: 3.8%;
	margin-left: 3.8%;
}
.sp_only {
  display: none;
}
@media screen and (max-width:1200px) {
  body {
	width: 100%;
	min-width: 100%;
		overflow-x: hidden;
  }
	.bg-container {
		width: 100%;
	}
	.sp_none {
		display: none;
	}
}
@media screen and (max-width:767px) {
	.sp_only {
		display: block;
	}
	.pc_only {
		display: none!important;
	}
}

/* イメージ
------------------------------------------------- */

  img {
	/*width:100%;*/
	max-width: 100% !important;
  }
  img.img-text {
	  width:auto;
  }

/* ヘッダー
------------------------------------------------- */

#header {
	margin: 15px 0;
	/*background: #e7e7e7;*/
}

#header .inner {
	width: 960px;
	height: 80px;
	margin: 0 auto;
	position: relative;
}

#header address {
	position: absolute;
	top: 5px;
	right: 0;
}

#header nav {
	position: absolute;
	bottom: 0;
	left: 0;
}

#header nav ul { display: table; }

#header nav ul li { display: table-cell; }



/* サイドメニュー
------------------------------------------------- */
.side-ttl-label{
	position: fixed;
	top: calc(50% - 159px);
	left: calc(3% - 12px);
	z-index:999;
}
@media screen and (max-width:767px){
	.side-ttl-label {
		padding: 0 0 0 4px;
	}
	.side-ttl-label img {
		width: 11px;
	}
}

.side-sns-label{
	position: fixed;
	top: 70%;
	right: calc(3% - 8px);
	z-index:999;
}
.side-sns-label li{
	width:16px;
	height:16px;
	margin-bottom:24px;
	transition:0.2s;
}
.side-sns-label li img{
	width:100%;
	height:100%;
}
@media screen and (min-width:768px) {
  .side-sns-label li:hover{
    transform:scale(1.5);
    transition:0.4s;
  }
}
.side-navi{
	position: fixed;
	top: 20%;
	right: calc(3% - 8px);
	z-index:999;
}
.side-navi ul li{
	margin-bottom:10px;
	font-size:80%;
}
.side-navi ul li.navi-cardboard{
	margin-top: 40px;
}
.side-navi li .page-link {
	display: block;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	border: solid 1px #222;
	box-sizing: border-box;
	position: relative;
}
.side-navi li.navi-cardboard .page-link {
	width: 22px;
	height: 24px;
	background-image: url(../img/common/side/cardboard.png);
	background-repeat: round;
	border-radius: 0;
	border: none;
	margin: 0 0 0 -5px;
}
.side-navi li.current:not(.navi-cardboard) .page-link,
.side-navi li:not(.navi-cardboard) .page-link:hover {
	background: #000;
}
.side-navi li.current.navi-cardboard .page-link,
.side-navi li.navi-cardboard .page-link:hover {
	background-image: url(../img/common/side/cardboard_hover.png);
}
.side-navi li .page-link > span {
	display: none;
	opacity: 0;
	width: auto;
	position: absolute;
	/*top: -8px;*/
	right: 30px;
	/*transform: translate(10px, 0);*/
	white-space: nowrap;
	border-radius: 15px;
	line-height: 15px;
	background-color: #444;
	color: white;
	font-weight: bold;
	font-family: 'Playfair Display', serif;
}
@media screen and (min-width:768px) {
  .side-navi li .page-link:hover > span {
    display: inline-block;
    opacity: 1;
    padding: 5px 8px;
  }
}
@media screen and (max-width:767px) {
  .sp_navi_wrap {
    display: block;
    position: fixed;
    right: 4%;
    top: 19px;
    height: 52px;
    width: 52px;
    cursor: pointer;
    z-index: 9999;
    background: #EB1F33;
    border-radius: 30px;
  }
  #sp_menu_btn {
    display: block;
    position: absolute;
    top: 15px;
    left: 15px;
    z-index: 0;
    height: 20px;
    width: 22px;
    margin: 0 auto;
    cursor: pointer;
    text-align: center;
  }
  #sp_menu_btn span,
  #sp_menu_btn::before,
  #sp_menu_btn::after {
    display: inline-block;
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 3px;
    margin: auto;
    background: #FFF;
  }
  #sp_menu_btn span {
    opacity: 1;
    transition: opacity 150ms 50ms;
  }
  #sp_menu_btn::before {
    z-index: 2;
    transform: translate(0, -8px);
    content: "";
  }
  #sp_menu_btn::after {
    z-index: 2;
    transform: translate(0, 8px);
    content: "";
  }
  #sp_menu_btn::before,
  #sp_menu_btn::after {
    transition: transform 200ms;
  }
  #sp_menu_btn.active span {
    opacity: 0;
    transition: opacity 150ms;
  }
  #sp_menu_btn.active::after {
    transform: rotate(-45deg);
  }
  #sp_menu_btn.active::before {
    transform: rotate(45deg);
  }

  .side-right {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    z-index: 1000;
    height: calc(100% - 50px);
    background: #ea1f32;
    overflow: scroll;
    padding-bottom: 51px;
    -webkit-overflow-scrolling: touch;
  }
  .side-navi {
    top: auto;
    right: auto;
    position: relative;
  }
  .side-navi ul {
    padding-top: 75px;
  }
  .side-navi ul li {
    width: 100%;
    margin-bottom: 0;
    font-size: 100%;
  }
  .side-navi li .page-link {
    width: 100%;
    border-radius: 0px;
    border: none;
    background: none;
    height: auto;
    color: transparent;
  }
  .side-navi li.current .page-link {
    background: #A81902!important;
  }
  .side-navi li .page-link:hover {
    background: none!important;
  }
  .side-navi li .page-link > span {
    position: relative;
    opacity: 1!important;
    color: #FFF;
    display: block;
    background: none;
    text-align: center;
    font-size: 15px;
    letter-spacing: 0.14em;
    width: 100%;
    right: auto;
    top: auto;
    padding: 18px 0;
  }
  .side-navi ul li.navi-cardboard {
    margin-top: 0;
  }
  .side-navi li.navi-cardboard .page-link {
    width: auto;
    height: auto;
    background: none;
  }
  .side-sns {
    margin-top: 25px;
  }
  .side-sns-label {
    position: relative;
    top: auto;
    right: auto;
    display: flex;
    justify-content: center;
    width: 100%;
  }
  .side-sns-label li {
    margin: 0 7px 0;
    background: #FFF;
    border-radius: 50px;
    width: 50px;
    height: 50px;
  }
  .side-sns-label li a {
    width: 50px;
    height: 50px;
    display: block;
  }
  .side-sns-label li img {
    margin: 0 auto;
    display: block;
  }
  .side-sns-label li.side-sns-label-insta img { width: 24px; }
  .side-sns-label li.side-sns-label-facebook img { width: 10px; }
  .side-sns-label li.side-sns-label-twitter img { width: 25px; }
}


/* ビジュアル・ページタイトル
------------------------------------------------- */

#visual {
	width: 960px;
	margin: 0 auto;
}

#pageTitle {
	width: 960px;
	margin: 0 auto;
}



/* コンテンツ
------------------------------------------------- */

#contents {
	width: 960px;
	margin: 0 auto 30px;
	/*background: #fff;*/
	overflow: hidden;
}


/* パンくずリスト */

#bread {
	width: 960px;
	margin: 0 auto 15px;
	text-align: left;
}

#bread li {
	margin-right: 8px;
	padding-left: 17px;
	display: inline-block;
	background: url(../img/common/parts/icon_bread.png) left center no-repeat;
	font-size: 11px;
}

#bread li:first-child {
	padding-left: 0;
	background: none;
}

/* フォント
------------------------------------------------- */


.font-payfair{
	font-family: 'Playfair Display', serif;

}

/* メイン
------------------------------------------------- */

main {
	width: 720px;
	float: left;
}



/* 見出し
------------------------------------------------- */

h2 { margin-bottom: 24px; }

h3 { margin-bottom: 20px; }



/* サイド
------------------------------------------------- */

#side {
	width: 220px;
	float: left;
}



/* フッター
------------------------------------------------- */

#footer {
	background: #e7e7e7;
    text-align: center;
    padding: 22px;
    box-sizing: border-box;
    font-size: 1.1rem;
    background-color: #f7f7f7;
}

#footer .footer_logo {
	margin:0 0 20px;
}
#footer .footer_logo img{
	width:48px;
}

/* 共通設定
------------------------------------------------- */

/* リンク */

a {
	color: #09c;
	text-decoration: none;
}

a:hover { text-decoration: underline; }


/* 左寄せリンク */

.linkL { text-align: left; }

.linkL a {
	padding-left: 10px;
	background: url(../img/common/parts/icon_arrow_01.png) left center no-repeat;
}


/* 右寄せリンク */

.linkR {
	text-align: right;
	margin-right: 10px;
}

.linkR a {
	padding-left: 10px;
	background: url(../img/common/parts/icon_arrow_01.png) left center no-repeat;
}


/* ページトップ */

#pageTop {
	width: 40px;
	height: 40px;
	text-indent: -400px;
	overflow: hidden;
	border-radius:3px;
	border:1px solid #333;
	position:relative;
  cursor: pointer;
}
#pageTop:before{
	content: "";
    position: absolute;
    left: 14px;
    top: 17px;
    width: 10px;
    height: 10px;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
    transform: rotate(-45deg);
	transition: 0.3s;
}
#pageTop:hover:before{
    top: 14px;
	transition: 0.3s;
}
#topcontrol {
	z-index: 99999;
}

#pageTop.sp_only_pagetop {
	display: none;
}
@media screen and (max-width:767px){
	#topcontrol {
		display: none !important
	}
	#pageTop.sp_only_pagetop {
		display: block;
		text-align: center;
		margin: 0 auto 40px auto;
    position: absolute;
    right: 10px;
    width: 30px;
    height: 30px;
	}
  #pageTop.sp_only_pagetop:before{
    left: 11px;
    top: 13px;
    width: 6px;
    height: 6px;
  }
}



.fadein {
  opacity: 0;
  transform: translate(0,50px);
  -webkit-transform: translate(0,50px);
  transition : all 1200ms ease;

}

.fadein.scrollin {
  opacity: 1.0;
  transform: translate(0,0);
  -webkit-transform: translate(0,0);
  transition : all 1200ms ease;
}




.ps-re{
	position:relative;
}

.ps-ab{
	position:absolute;
}


/* アニメーション
------------------------------------------------- */

.anime,
.anime_child{
	opacity: 0;
	transition: 0.3s all;
}


.show {
	opacity: 1;
}

/* ← */
.slide_to_left,
.slide_to_right {
	opacity: 0;
}
.show.slide_to_left{
	animation: slide_to_left 800ms cubic-bezier(.37,.09,0,.98) ;
	animation-fill-mode: both;
	animation-delay: 0.8s;
}
/* → */
.show.slide_to_right{
	animation: slide_to_right 800ms cubic-bezier(.37,.09,0,.98) ;
	animation-fill-mode: both;
	animation-delay: 0.8s;
}

@keyframes slide_to_left {
	0% {
		transform: translateX(50px);
		opacity: 0;
	}
	100% {
		transform: translateX(0px);
		opacity: 1;
	}
}

@keyframes slide_to_right {
	0% {
		transform: translateX(-50px);
		opacity: 0;
	}
	100% {
		transform: translateX(0px);
		opacity: 1;
	}
}


.footer_supplement_txt {
	width: 100%;
	margin: 1px auto 20px;
}
.footer_supplement_txt p {
	text-align: center;
	font-size: 12px;
	font-weight: bold;
}