@charset "utf-8";
/* Webfont: angle */
@font-face {
    font-family: 'angle';
    src: url('../font/angle.eot'); /* IE9 Compat Modes */
    src: url('../font/angle.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
         url('../font/angle.woff') format('woff'), /* Modern Browsers */
         url('../font/angle.woff2') format('woff2'), /* Modern Browsers */
         url('../font/angle.ttf') format('truetype'); /* Safari, Android, iOS */
             font-style: normal;
    font-weight: normal;
    text-rendering: optimizeLegibility;
}
/* Webfont: angle */@font-face {
    font-family: 'Hannari-min';
    src: url('../font/HannariMincho-Regular.woff') format('woff'), /* Modern Browsers */
         url('../font/HannariMincho-Regular.woff2') format('woff2'), /* Modern Browsers */
         url('../font/HannariMincho-Regular.otf') format('truetype'); /* Safari, Android, iOS */
             font-style: normal;
    font-weight: normal;
}


/* ---------------------------------------------------------------------------------
Copyright maisha. All Rights Reserved.

HTML CSS Selectors common 

$Revision: 1.0 $
--------------------------------------------------------------------------------- */

/*---------------------------------------------------------------------------------
初期設定
--------------------------------------------------------------------------------- */
:root {
  --min-width:1366px;
  --font-min: 'Hannari-min';
  --font-go: 'Noto Sans JP', sans-serif;
  --font-en: 'angle';
}
*, *::before, *::after {
  box-sizing: border-box;
}
body {
  margin: 0px;
  padding: 0px;
  font-family: var(--font-min);
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0.08em;
  color: #3C3B3B;
  -webkit-text-size-adjust: none; /* フォントサイズ自動調整 */
    /*word-break : break-all;
    word-wrap : break-word;
    overflow-wrap : break-word;*/
  font-feature-settings: "palt";
}

h1,h2,h3,h4,h5,h6,
ul,ol,dl,
p,li,dt,dd,th,td,em,strong,blockquote {
  margin: 0px;
  padding: 0px;
  border: 0;
  vertical-align: baseline;
  font-weight: inherit;
}
em {
  font-style: normal;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, main {
  display: block;
  margin: 0px;
  padding: 0px;
}
p,dd,li {
  list-style: none;
}
em,strong {
  font-weight: bold;
}
table {
  border-collapse: collapse;
}

img {
  vertical-align:top;
  max-width: 100%;
  height: auto;
}
.fit-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}
a img {
  border: none;
}
a:link,
a:visited,
a:hover,
a:active {
  color: inherit;
  text-decoration: none;
}
a {
	transition: 0.2s ease-in-out;
}
a:hover {
  opacity: 0.5;
}
.none {
  display: none!important;
}

.nolink {
  pointer-events: none;
}
.anchor {
  display: block;
  height: 0;
  position: relative;
  top: 0px;
}
.js_accordion_head {
  cursor: pointer;
}


/*---------------------------------------------------------------------------------
エフェクト
--------------------------------------------------------------------------------- */
/* 画面外にいる状態 */
.effect {
  opacity : 0;
  transition : all 500ms 300ms ease-out;
  transform: translate(0,50px);
}
.fade {
  transform: translate(0,0);
}
.fade-drop {
  transform: translate(0,-50px);
}
.fade-rize {
  transform: translate(0,50px);
}
.fade-left-in {
  transform: translate(-50px,0);
}
.fade-right-in {
  transform: translate(50px,0);
}
.blur {
  transition : all 300ms 300ms ease-out;
  transform: translate(0,0);
}
.fade-text-up,
.fade-text-leftIn {
  transform: translate(0,0);
  overflow:hidden;
}
.fade-text-up .inner,
.fade-text-leftIn .inner {
  display: inline-block;
}


/* 画面内に入った状態 */
.effect-on {
  opacity: 1.0;
  transform: translate(0,0px); 
}
.loaded .fv-blur,
.blur.effect-on {
	animation-name:blurAnime;
	animation-duration:1s;
	animation-fill-mode:forwards;
  opacity: 0;
}
.fade-text-up.effect-on {
  animation-name:slideTextUpWrap;
  animation-duration:0.8s;
  animation-fill-mode:forwards;
  animation-delay: 0.5s;
  opacity: 0;
}
.fade-text-up.effect-on .inner {
  animation-name:slideTextUpIn;
  animation-duration:0.8s;
  animation-fill-mode:forwards;
  animation-delay: 0.5s;
  opacity: 0;
}
.fade-text-leftIn.effect-on {
  animation-name:slideTextLeftWrap;
  animation-duration:0.8s;
  animation-fill-mode:forwards;
  animation-delay: 0.5s;
  opacity: 0;
}
.fade-text-leftIn.effect-on .inner {
  animation-name:slideTextLeftIn;
  animation-duration:0.8s;
  animation-fill-mode:forwards;
  animation-delay: 0.5s;
  opacity: 0;
}
/*ファーストビューエフェクト*/
.fv-effect {
  transition : all 900ms 1000ms ease-out;
  opacity: 0;
}
.fv-blur {
  opacity: 0;
}

.loaded .fv-effect {
  opacity: 1;
  transform: translate(0,0);
}

/*アニメーション*/
.delay0 {
  transition-delay:0ms;
}
@keyframes blurAnime{
  from {
	filter: blur(10px);
	transform: scale(1.02);
	opacity: 0;
  }

  to {
	filter: blur(0);
	transform: scale(1);
	opacity: 1;
  }
}

@keyframes rotation1{
  0%{ transform:rotate(0);}
  100%{ transform:rotate(-360deg); }
}
@keyframes rotation2{
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}

@keyframes bgLRextendAnime{
	0% {
		transform-origin:left;
		transform:scaleX(0);
	}
	50% {
		transform-origin:left;
		transform:scaleX(1);
	}
	50.001% {
		transform-origin:right;
	}
	100% {
		transform-origin:right;
		transform:scaleX(0);
	}
}
@keyframes bgRLextendAnime{
	0% {
		transform-origin:right;
		transform:scaleX(0);
	}
	50% {
		transform-origin:right;
		transform:scaleX(1);
	}
	50.001% {
		transform-origin:left;
	}
	100% {
		transform-origin:left;
		transform:scaleX(0);
	}
}

@keyframes slideTextUpWrap {
    from {
        transform: translateY(100%);/* 要素を下の枠外に移動*/
        opacity: 0;
    }
    to {
        transform: translateY(0);/* 要素を元の位置に移動*/
        opacity: 1;
    }
}
@keyframes slideTextUpIn {
    from {
        transform: translateY(-100%);/* 要素を下の枠外に移動*/
        opacity: 0;
    }
    to {
        transform: translateY(0);/* 要素を元の位置に移動*/
        opacity: 1;
    }
}
@keyframes slideTextLeftWrap {
  from {
	transform: translateX(-100%); /*要素を左の枠外に移動*/
        opacity: 0;
  }

  to {
	transform: translateX(0);/*要素を元の位置に移動*/
    opacity: 1;
  }
}
@keyframes slideTextLeftIn {
  from {
	transform: translateX(100%);/*要素を右の枠外に移動*/
    opacity: 0;
  }

  to {
	transform: translateX(0);/*要素を元の位置に移動*/
    opacity: 1;
  }
}

/*---------------------------------------------------------------------------------
ヘッダー
--------------------------------------------------------------------------------- */
.site-header {
  width: 100%;
  height: 10px;
  min-width: var(--min-width);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.header-logo {
  width: 166px;
  line-height: 1;
  position: fixed;
  top: 52px;
  left: 40px;
  z-index: 99;
}
#toggle_menu {
  width: 30px;
  height: 25px;
  position: fixed;
  top: 57px;
  right: 42px;
  z-index: 99;
  cursor: pointer;
}
#toggle_menu div {
  width: 100%;
  height: 1px;
  position: absolute;
  background-color: #3C3B3B;
  overflow:hidden;
}
#toggle_menu .menu1 {
  top: 0;
}
#toggle_menu .menu2 {
  top: 12px;
}
#toggle_menu .menu3 {
  top: 24px;
}

#toggle_menu div::before {
  display: block;
  width: 100%;
  height: 100%;
  background-color: #141414;
  position: absolute;
  top: 0;
  left: 0;
  content:"";
}
#toggle_menu .menu1,#toggle_menu .menu2,#toggle_menu .menu3
{ transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out; /* opera */
  -moz-transition: all 0.2s ease-out; /* firefox */
  -webkit-transition: all 0.2s ease-out; /* chrome, safari */
  -ms-transition: all 0.2s ease-out; /* ie */ }
#toggle_menu .menuclick1 {
  top:13px;
  -moz-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg); }
#toggle_menu .menuclick2 {
  opacity:0;
}
#toggle_menu .menuclick3 {
  top:13px;
  -moz-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.open #toggle_menu div::before {
	content:none;
}

.drawer-menu {
  display: flex;
  width: 50%;
  height: 100vh;
  background-color: #DBD9CD;
  z-index: 90;
  position: fixed;
  top: 0;
  right: -50%;
  opacity: 0;
	visibility: hidden;
  overflow:hidden;
  transition : all 300ms ease-out;
}
.open .drawer-menu {
  right: 0;
	opacity: 1;
	visibility: visible;
}
.drawer-menu-img {
  width: 50%;
}
.drawer-menu-inner {
  width: 50%;
  padding: 154px 0 0 72px;
}
.drawer-menu-in {
  width: 460px;
}
.drawer-menu-in li {
  padding-bottom: 26px;
  border-bottom: 1px solid #BCB1AB;
  margin-bottom: 28px;
}
.drawer-menu-in li:last-of-type {
  border-bottom: none;
  margin-bottom: 0;
}
.drawer-menu-in li a {
  font-family: var(--font-en);
  font-size: 20px;
  line-height: 1;
}
.drawer-menu-sns {
  display: flex;
  flex-wrap: wrap;
  padding-top: 42px;
}
.drawer-menu-sns a {
  width: 29px;
  margin-right: 18px;
}

.side-reserve {
  width: 130px;
  height: 130px;
  position: fixed;
  right: 10px;
  top: calc(100vh - 150px);
  z-index: 99;
  transition-delay:1200ms;
  overflow:hidden;
}
.side-reserve-in {
  position: relative;
  width: 100%;height: 100%;
}
.side-reserve a {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
}
.side-reserve img {
  display: block;
  width: 47px;
  position: relative;
  z-index: 3;
}
.side-reserve a::before {
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/common/side_reserve_bg.svg") no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  content:"";
  animation:20s linear infinite rotation1;
}
#side-reserve__bg {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

/*---------------------------------------------------------------------------------
コンテンツ
--------------------------------------------------------------------------------- */
#luxy {
  z-index: 2;
}
#contents-wrapper {
  width: 100%;
  min-width: var(--min-width);
  overflow:hidden;
}

.page-ttl {
  padding-top: 165px;
  font-size: 14px;
  line-height: 1;
  text-align: center;
  position: relative;
  z-index: 5;
}
.page-ttl .en {
  display: block;
  padding-bottom: 15px;
  font-family: var(--font-en);
  font-size: 60px;
}


/*---------------------------------------------------------------------------------
フッター
--------------------------------------------------------------------------------- */
#footer-wrapper {
  width: 100%;
  min-width: var(--min-width);
  padding: 115px 0 125px;
  background-color: #F5F5F2;
  border-top: 1px solid #BCB1AB;
}
.site-footer {
  width: 1066px;
  margin: 0 auto;
  position: relative;
}
.site-footer__logo {
  width: 134px;
  margin-bottom: 65px;
}
.site-footer__add {
  margin-bottom: 23px;
  font-size: 12px;
  line-height: 1;
}
.site-footer__tel {
  margin-bottom: 66px;
  font-size: 12px;
  line-height: 1;
}
.site-footer-nav {
  display: flex;
  flex-wrap: wrap;
}
.site-footer-nav li {
  width: 50%;
  margin-bottom: 35px;
  font-size: 8px;
  line-height: 1;
}
.site-footer-nav li a span {
  display: inline-block;
  margin-right: 20px;
  font-family: var(--font-en);
  font-size: 16px;
}
.site-footer-nav li .sub {
  margin-top: 8px;
}

.site-footer-sns {
  display: flex;
  flex-wrap: wrap;
  position: absolute;
  top: 0;
  right: 0;
}
.site-footer-sns a {
  width: 29px;
  margin-left: 18px;
}

/*---------------------------------------------------------------------------------
JS
--------------------------------------------------------------------------------- */
/* Slider */
.slick-slider
{
    position: relative;

    display: block;
    box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}
.slick-list:focus
{
    outline: none;
}
.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
       -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
         -o-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;

    left: 0;

    display: block;
}
.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}
.slick-track:after
{
    clear: both;
}
.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide
{
    float: right;
}
.slick-slide img
{
    display: block;
}
.slick-slide.slick-loading img
{
    display: none;
}
.slick-slide.dragging img
{
    pointer-events: none;
}
.slick-initialized .slick-slide
{
    display: block;
}
.slick-loading .slick-slide
{
    visibility: hidden;
}
.slick-vertical .slick-slide
{
    display: block;
    height: auto;
    border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
    display: none;
}

.slick-prev {
	background-position: left top;
}
.slick-next {
	background-position: right top;
}
.slick-prev:before,
.slick-next:before {
  display: none !important;
}
.slick-prev:active,
.slick-next:active {
  border: none;
}
.slick-disabled {
  display: none !important;
}
.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  opacity:0.5;

}
/* Dots */
.slick-dotted.slick-slider {
}
.slick-dots {
  position: absolute;
  bottom: -53px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
  z-index: 20;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  width: 12px;
  height: 12px;
  margin: 0 9px;
  padding: 0;
  cursor: pointer;
  text-align: center;
}
.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 12px;
  height: 12px;
  padding: 0px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}
.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
}
.slick-dots li button:before {
  box-sizing: border-box;
  font-family: 'slick';
  font-size: 6px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  content: '';
  text-align: center;
  background-color: #fff;
  border: 1px solid #777777;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  background-color: #777777;
  border: 1px solid #777777;
}
