body, html {
	height: 100%;
	margin: 0;
	width: 100%;
}
body{
	font-family: "游ゴシック体",Yu Gothic,YuGothic,"ヒラギノ角ゴ Pro",Hiragino Kaku Gothic Pro,"メイリオ",Meiryo,sans-serif;
	color: #464646;
	font-size: 14px;
	line-height: 1.8;
	overflow: hidden;
}
@font-face {
  font-family: 'Didot';
  src: url('../fonts/Didot.eot?#iefix') format('embedded-opentype'),  url('../fonts/Didot.woff') format('woff'), url('../fonts/Didot.ttf')  format('truetype'), url('../fonts/Didot.svg#Didot') format('svg');
  font-weight: normal;
  font-style: normal;
}

h1, h2, h3, h4, h5{
	font-family: "Didot", "Playfair Display", "Times New Roman", Times, serif;
	color: #333;
	font-weight: normal;
}
hr{
	border-color: #000;
}
a{
	color: #fff;
	text-decoration:none;
}
a:hover,
a:visited{
	color: #aaa;
	/*color: #000;*/
	text-decoration:underline;
}
a>img{
	transition: all 1s;
}
a:hover>img{
	opacity: 0.75;
	filter: opacity(75);
}
.btn:hover,
a.btn:hover{
	text-decoration:none!important;
}
button:focus{
	outline: 0;
	border: 0;
}
h1{
	font-size: 28px;
	letter-spacing: .5rem;
	margin: 0;
}
h2 {
	font-size: 4rem;
	text-transform: uppercase;
}
h2 .letter{
	transform: translateY(-500%) rotateZ(0deg);
	opacity: 0;
}
.double-line{
	text-align: center;
	background: url(../images/h3_bg.png) repeat-x;
	padding: 15px 0 20px;
	font-size: 24px;
	margin-bottom: 3rem;
}
.serif{
	font-family: "Didot", "Playfair Display", "Times New Roman", Times, serif;
}
.gothic{
	font-family: "游ゴシック体",Yu Gothic,YuGothic,"ヒラギノ角ゴ Pro",Hiragino Kaku Gothic Pro,"メイリオ",Meiryo,sans-serif;
}
.main-text{
	font-size: 1.6rem;
	font-family: "Playfair Display", "Times New Roman", Times, serif;
	color: #000;
}
.letter{
	display: inline-block;
}
.section h2{
	opacity: 0;
}
.wow.animated{
	opacity: 0;
}
.h100vh{
	width: 100%;
	height: 100%;
	height: 100vh;
}
.section-inner{
	width: 100%;
	height: 100%;
}
.row{
	min-width: 100%;
}
/*==============================
=            GLOBAL            =
==============================*/

.loading,
.loading>div{
	width: 100%;
	height: 100%;
}
.loading {
	position: fixed;
	left: 0px;
	top: 0px;
	background-color: #fff;
	font-size: 4rem;
	text-transform: uppercase;
	z-index: 100;
}
.loading .bar{
	width: 0;
	height: 1px;
	background-color: #000;
}
#page{
	width: 100%;
	height: 100%;
	height: 100vh;
}
#open-menu {
	background: transparent;
	border: none;
	transition: all .25s;
}
#open-menu.open{
	z-index: 2;
}
#open-menu.open span{
	background-color: #fff;
}
#open-menu span{
	width: 33px;
	height: 2px;
	background-color: #000;
	display: block;
	transition: all 1s;
}
#open-menu span + span{
	margin-top: 10px;
}
#open-menu span:last-child:after {
	content: 'menu';
	display: block;
	position: relative;
	top: 10px;
	font-weight: bold;
	font-size: 80%;
	text-align: center;
}
#page>header {
	background-color: #fff;
	margin: 0;
	left: 0;
	position: fixed;
	text-align: center;
	width: 100%;
	height: auto;
	padding: .5rem 3rem 1px;
	z-index: 2;
}
header h1 a>img {
	height: 60px;
}
header .side-toggle-menu{
	width: 3rem;
	height: 100%;
	padding: 0;
	position: fixed;
	left: 0;
	top: 0;
	background-color: #fff;
	cursor: pointer;
}
header .head-right ul{
	list-style: none;
	padding: 0;
	margin: 0;
}
header .head-right ul li a.btn{
	color: #fff;
	letter-spacing: 2px;
	background-color: #222;
	border: 2px solid transparent;
	font-size: 11px;
	padding: 7px 20px;
	height: 37px;
}
header .head-right ul li a.btn:focus,
header .head-right ul li a.btn:hover{
	background-color: transparent;
	color: #222;
	border: 2px solid #222;
}
header .btn-shopping{
	display: none;
	position: absolute;
	right: 0;
	top: 0;
	height: 60px;
	border-left: 1px solid rgb(204, 204, 204);
	padding: 16px 15px 10px;
	width: 60px;
}
header .right-side {
	width: 3rem;
	height: 100%;
	padding: 0;
	position: fixed;
	right: 0;
	top: 0;
	writing-mode: tb-rl;
	font-size: 11px;
	letter-spacing: 3px;
	text-transform: uppercase;
	background-color: #fff;
}
footer>.bg-white{
	position: relative;
}
footer #page-top{
	display: block;
	position: relative;
}
footer #page-top .page-top-bg{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 0 130px 160px;
	border-color: transparent transparent #000000 transparent;
	position: absolute;
	right: 0;
	bottom: 0;
}
footer .footer-bar-bottom{
	background-color: #000;
	position: relative;
	font-size: .7rem;
}
footer .footer-bar-bottom ul li a{
	color: #fff;
}
#nav-menu{
	background-color: #333;
	height: 100%;
	clip:rect(0px -360px 2000px 0px);
	transition: all .8s linear;
	overflow: hidden;
	position: fixed;
	left: 0;
	top: 0;
}
.open-menu #nav-menu{
	clip:rect(0px 360px 2000px 0px);
}
#nav-menu ul{
	list-style: none;
	padding: 0;
	margin: 0;
	height: 100%;
}
#nav-menu ul li {
	transition: all .8s;
	opacity: 0;
}
.open-menu #nav-menu ul li:first-child{
	transition-delay: .5s;
}
.open-menu #nav-menu ul li:nth-child(2){
	transition-delay: .6s;
}
.open-menu #nav-menu ul li:nth-child(3){
	transition-delay: .7s;
}
.open-menu #nav-menu ul li:nth-child(4){
	transition-delay: .8s;
}
.open-menu #nav-menu ul li:nth-child(5){
	transition-delay: .9s;
}
.open-menu #nav-menu ul li:nth-child(6){
	transition-delay: 1s;
}
.open-menu #nav-menu ul li:nth-child(7){
	transition-delay: 1.1s;
}
.open-menu #nav-menu ul li:nth-child(8){
	transition-delay: 1.2s;
}
.open-menu #nav-menu ul li:nth-child(9){
	transition-delay: 1.3s;
}
.open-menu #nav-menu ul li:first-child,
.open-menu #nav-menu ul li:nth-child(2),
.open-menu #nav-menu ul li:nth-child(3),
.open-menu #nav-menu ul li:nth-child(4),
.open-menu #nav-menu ul li:nth-child(5),
.open-menu #nav-menu ul li:nth-child(6),
.open-menu #nav-menu ul li:nth-child(7),
.open-menu #nav-menu ul li:nth-child(8),
.open-menu #nav-menu ul li:nth-child(9){
	opacity: 1
}
#nav-menu ul li a{
	color: #fff;
	font-size: .8rem;
	display: block;
	padding: .5rem 6rem;
}
#nav-menu #close-menu{
	position: absolute;
	right: 1rem;
	top: 1rem;
	height: 2rem;
	background: transparent;
	border: none;
	cursor: pointer;
	opacity: 0;
	transition: opacity 1.25s;
}
.open-menu #nav-menu #close-menu{
	opacity: 1;
}
#nav-menu #close-menu span{
	background-color: #fff;
	width: 2.5rem;
	display: block;
	height: 2px;
	transition: all 1s;
}
#nav-menu #close-menu span:first-child{
	transform: rotate(45deg);
}
#nav-menu #close-menu span:last-child{
	transform: rotate(-45deg);
	margin-top: -2px;
}
#nav-menu #close-menu span:last-child:after{
	display: none;
}
#nav-menu #close-menu:hover span{
	transform: rotate(0deg);
}

.section{
	position: relative;
	overflow: hidden; 
}

.sub .fix-bg{
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
.sub .scrollable-content {
	position: relative;
	padding-top: 4.5rem;
}
.sub .scrollable-content .content{
	margin-left: auto;
	margin-right: auto;
	background-color: rgba(255,255,255,0.9)
}

@media (min-width: 769px){
	header .side-toggle-menu:hover #open-menu > span:first-child{
		width: 10px;
	}
	header .side-toggle-menu:hover #open-menu > span:nth-child(2){
		width: 20px;
	}
	header .head-right{
		position: absolute;
		right: 3rem;
		bottom: 13px;
	}
	.sub .scrollable-content {
		padding-top: 6rem;
	}
	.sub .scrollable-content h2{
		font-size: 4.4rem;
	}
	footer #page-top img {
		position: absolute;
		right: 35px;
		top: -50px;
		z-index: 1;
		width: 50px;
	}
}

@media (min-width: 993px){
	h2{
		font-size: 4.4rem;
	}
	.sub .scrollable-content .content{
		width: 840px;
	}
}

@media (min-width: 1200px){
	.sub #page:before{
		content: '';
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 3rem;
		background-color: #fff;
		z-index: 1;
	}
	.sub footer .footer-bar-bottom{
		padding-bottom: 3rem
	}
}

@media (min-width: 1441px){
	
}

@media (min-width: 1600px){
	header .head-right ul li a.btn{
		font-size: 14px;
	}
}

@media(max-width: 1199px){
	
}
@media(min-width: 769px) and (max-width: 1199px){

}
@media(max-width: 992px){
	h2{
		font-size: 3.4rem;
	}
	#nav-menu ul li a{
		padding: .5rem 5rem;
	}
}

@media(max-width: 768px){
	h2{
		font-size: 3rem;
	}
	header .right-side img{
		height: 45vmax;
	}
	#nav-menu{
		top: 0;
		clip: rect(0px -300px 2000px 0px);
		margin-left: 3rem!important;
		width: 300px;
	}
	.open-menu #nav-menu{
		clip: rect(0px, 300px, 2000px, 0px);
	}
	#nav-menu #close-menu {
		right: 10px;
		top: 20px;
	}
	#nav-menu #close-menu span{
		width: 2rem;
	}
	footer .footer-bar-bottom{
		padding-left: 1rem;
		padding-right: 1rem;
	}
}

@media (min-width: 481px) and (max-width: 768px){
	header .logo{
		float: left;
	}
	header h1 a>img{
		height: 45px;
	}
	header .head-right{
		float: right;
	}
	header .head-right ul{
		margin-top: 5px!important;
	}
	#page>header{
		padding: .5rem 3rem;
	}
}

@media (max-width: 667px){
	h3, .h3 {
		font-size: 1.2rem;
		line-height: 1.4;
	}
	header .logo{
		float: none;
	}
	header .side-toggle-menu{
		width: auto;
		height: auto;
		position: absolute;
		top: 12px;
		left: 10px;
	}
	header h1 a>img {
		height: 48px;
	}
	header .right-side,
	header .head-right{
		display: none!important;
	}
	header .btn-shopping{
		display: block;
	}
	#nav-menu{
		top: 60px;
		clip: rect(0px -200px 2000px 0px);
		margin-left: 0!important;
		width: 200px;
	}
	#nav-menu ul{
		height: calc(100% - 60px)
	}
	#nav-menu ul li a{
		font-size: 12px;
		padding: .5rem 3rem;
	}
	#nav-menu #close-menu {
		left: 145px;
		right: auto;
		top: 15px;
	}
	#nav-menu #close-menu span {
		width: 32px;
	}
	.open-menu #nav-menu{
		clip: rect(0px, 200px, 2000px, 0px);
	}
	#open-menu span{
		width: 26px
	}
	#open-menu span + span {
		margin-top: 7px;
	}
	#open-menu span:last-child:after{
		top: 4px;
		font-size: 10px;
		left: -2px;
	}
	#page>header {
		padding: 0;
		border-bottom: 1px solid rgb(204, 204, 204);
		height: 60px;
	}
	#page>header .logo{
		padding: .5rem 0 0
	}
	footer #page-top img{
		position: absolute;
		right: 16px;
		top: -25px;
		z-index: 1;
		width: 30px;
	}
	footer #page-top .page-top-bg{
		border-width: 0 0 70px 90px;
	}
}

@media (min-width: 768px) and (orientation: portrait){
	footer #page-top img {
		position: absolute;
		right: 75px;
		top: -32px;
		z-index: 1;
		width: 40px;
	}
}

@media (max-width: 667px) and (orientation: landscape){
	
}

@media (max-width: 575px){
	body{
		font-size: 13px;
	}
	h2{
		font-size: 10vw;
	}
	header .side-toggle-menu,
	header .right-side{
		width: 2rem
	}
	footer .footer-bar-bottom{
		font-size: .6rem;
	}
	footer .footer-bar-bottom ul{
		margin-bottom: .5rem!important;
	}
}

@media (max-width: 575px) and (orientation: landscape){
	#nav-menu{
		top: 60px;
		clip: rect(0px -220px 2000px 0px);
		margin-left: 0!important;
		width: 200px;
	}
	.open-menu #nav-menu {
		clip: rect(0px, 220px, 2000px, 0px);
	}
	#nav-menu ul li a{
		padding: 2px 2rem;
	}
	#nav-menu #close-menu {
		left: 155px;
		right: auto;
		top: 10px;
	}
	#nav-menu #close-menu span {
		width: 25px;
	}
}

