@charset "utf-8";

/* reset
----------------------------------------------------------*/
*, *:before, *:after { box-sizing:border-box; }

html, body, h1, h2, h3, h4, h5, h6,
ul, ol, li, dl, dt, dd,
figure, figcaption, form, textarea,
blockquote, fieldset, legend {
  margin: 0;
  padding: 0;
  border: none;
}

h1, h2, h3, h4, h5, h6 { font-size:100%; font-weight:normal; }

article, aside, details, figcaption, figure,
footer, header, hgroup, main, menu, nav, section, summary { display: block; }

table { border-collapse:collapse; border-spacing:0; }

img { max-width:100%; height:auto; font-size:0; line-height:0; vertical-align:bottom; border-width:0; image-rendering:-webkit-optimize-contrast; }

ul , ol { padding:0; list-style:none; }

input , button , textarea , select { font:inherit; }
button { margin:0; padding:0; border:none; border-radius:0; background:none; -webkit-appearance:none; cursor:pointer; }
button:focus { outline:none; }

input[type="submit"],
input[type="button"],
input[type="reset"] {
  cursor: pointer;
}

/* base
----------------------------------------------------------*/
html, body { height: 100%; }

html {
  font-family: 'Noto Serif JP', "游明朝", "Yu Mincho", YuMincho,
  "ヒラギノ明朝 ProN W6", "HiraMinProN-W6",
  "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
  font-size: 16px;
  letter-spacing: .05em;
  line-height: 1.7;
}
body {
  color: #fff;
  background: #000;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  -webkit-font-variant-ligatures: none;
  font-variant-ligatures: none;
}

.font-en {
  font-family:
  'Century Gothic', Futura, "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,
  "メイリオ", "Meiryo","ヒラギノ角ゴ Pro W3",
  "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
}
.font-sans {
  font-family:
  "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,
  "メイリオ", "Meiryo","ヒラギノ角ゴ Pro W3",
  "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
  font-weight: 500;
}

a { color:#fff; }
a:not([class]) { text-decoration:underline; }
a:not(.fade), .anime { -webkit-transition:all .5s; transition:all .5s; }
a:not([class]):hover, a:not([class]):focus { text-decoration:none; }

.clearfix:after { content:""; display:block; clear:both; }

.fl-l { float:left; }
.fl-r { float:right; }

.txt-l { text-align:left; }
.txt-c { text-align:center; }
.txt-r { text-align:right; }
.txt-j { text-align:justify; }

.va-top  { vertical-align:top; }
.va-mid  { vertical-align:middle; }
.va-btm  { vertical-align:bottom; }
.va-base { vertical-align:baseline; }

.fw-mid { font-weight:500; }
.fw-b   { font-weight:bold; }

.fz-small { font-size:.85em; }
.fz-big { font-size:1.2em; }

.fs-italic { font-style:italic; }
.ws-nowrap { white-space: nowrap; }
.marker { background:linear-gradient(transparent 45%, #fcf5bb 0%); }
.indent { padding-left:1em; text-indent:-1em; }

.wide   { width: 100%; }

.pos-r { position:relative; }

.iblock { display:inline-block; }
.block  { display:block; }
.hide   { display:none; }

.li-disc, .li-decimal { padding-left:1.5em; }
.li-disc { list-style:disc; }
.li-decimal { list-style:decimal; }

.flex         { display:-webkit-flex; display:flex; -webkit-flex-wrap:wrap; flex-wrap:wrap; }
.flex-between { -webkit-justify-content:space-between;  justify-content:space-between;  }
.flex-center  { -webkit-justify-content:center; justify-content:center; }
.flex-align-center { -webkit-box-align:center; -webkit-align-items:center; align-items:center; }

.shadow { box-shadow:0 0 3px rgba(0,0,0,0.3); }

.txt-underline { text-decoration:underline; }
.link-txt { font-weight:bold; text-decoration:underline; }
.link-txt:hover { text-decoration: none; }

.is-fixed { position:fixed; top:0; right:0; bottom:0; left:0; }

.link-disabled { cursor:default; pointer-events:none; opacity:0.6; }

/* 1025px 以上  */
@media screen and (min-width: 1025px) {
  /* hover scale */
  a .hv-scale { -webkit-transition:all .5s ease-out; transition:all .5s ease-out; }
  a:hover .hv-scale  { -webkit-transform: scale(1.05); transform: scale(1.05); }
}
/* 600px 以上  */
@media screen and (min-width: 768px) {
  .txt-v {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
}


/* layout ------ */
#wrapper { position:relative; min-height:100%; }
.inner { max-width:1060px; width:100%; margin:0 auto; padding-left:40px; padding-right:40px; }
.narrow-inner { max-width:820px; width:100%; margin:0 auto; padding-left:40px; padding-right:40px; }

header {
  position: relative;
  z-index: 9999;
}

#main { display:block; }

/* 960px 以上 (PC・タブレット横) */
@media screen and (min-width: 960px) {
  .pc-none { display: none; }

}
/* 600px 以上 (PC・タブレット) */
@media screen and (min-width: 600px) {
  .sp-only { display: none; }
}

/* 1024px 以下 (タブレット横以下) */
@media screen and (max-width: 1024px) {
}

/* 959px 以下 (タブレット縦以下) */
@media screen and (max-width: 959px) {
  .pc-only { display:none; }

}

/* 599px 以下 (スマホ)  */
@media screen and (max-width: 599px) {
  html { font-size:13px; }
  .inner, .narrow-inner { padding-left:20px; padding-right:20px; }

  .sp-none { display:none; }
  .sp-only { display:block; }
}

/* loading */
#loading { position:fixed; top:0; bottom:0; left:0; right:0; z-index:9999; width:100%; height:100%;
  background:url(../img/common/bg-yel.jpg) no-repeat center top / cover;}
.loader { position:absolute; top:0; bottom:0; left:0; right:0; width:40px; height:40px; margin:auto;
 -webkit-animation:sk-scaleout .8s infinite ease-in-out;
  animation:sk-scaleout .8s infinite ease-in-out;border-radius:100%; background-color:#fff;  }
@-webkit-keyframes sk-scaleout {
  0% { -webkit-transform: scale(0) }
  100% {
    -webkit-transform: scale(1.0);
    opacity: 0;
  }
}

@keyframes sk-scaleout {
  0% {
    -webkit-transform: scale(0);
    transform: scale(0);
  } 100% {
    -webkit-transform: scale(1.0);
    transform: scale(1.0);
    opacity: 0;
  }
}


/* common
----------------------------------------------------------*/
/* tel */
.g-tel {
  margin: 0;
  line-height: 1.4;
  font-size: 1.1429rem;
  text-align: center;
}
.g-tel-num {
  color: #e1b109;
  text-decoration: none;
  font-size: 1.125em;
  vertical-align: .05em;
}
.g-tel-num .num {
  font-size: 1.333em;
}

/* button */
.ct-btn {
  position: relative;
  display: inline-block;
  min-width: 0;
  text-align: center;
  margin: .55em 13px 0;
  padding: .55em 3.2em .5em;
  text-align: center;
  text-decoration: none;
  font-weight: bold;
  line-height: 1.4;
  color: #fff;
  background: #e1b109;
  border-radius: 1.4em;
}
.ct-btn .en {
  position: absolute;
  top: -.9em;
  left: 0;
  right: 0;
  line-height: 1;
  font-size: .8571rem;
  letter-spacing: .05em;
  color: #e1b109;
}
.ct-btn .ja:after {
  content: "";
  position: absolute;
  top: .55em;
  right: 1.2em;
  width: 1.3571em;
  height: 1.3571em;
  background: url(../img/common/icon-arrow-wht.svg) no-repeat center / 100%;
}
.ct-btn:before, .ct-btn:after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 13px;
  background: url(../img/common/deco-brackets-yel.svg) no-repeat center / auto 100%;
  -webkit-transition:all .3s ease-out; transition:all .3s ease-out;
}
.ct-btn:before {
  left: -13px;
}
.ct-btn:after {
  right: -13px;
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1);
}

.ct-btn:hover:before {
  left: -20px;
}
.ct-btn:hover:after {
  right: -20px;
}

.ct-btn.st-wht {
  color: #000;
  background: #fff;
}
.ct-btn.st-wht:before, .ct-btn.st-wht:after {
  background-image: url(../img/common/deco-brackets-wht.svg);
}
.ct-btn.st-wht .ja:before {
  background-image: url(../img/common/icon-arrow-yel.svg);
}
.ct-btn.st-wht .en {
  color: #fff;
}

.ct-btn.type-submit {
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  -webkit-appearance: none;
  letter-spacing: .05em;
}

.ct-btn.type-submit.type-back:hover:before {
  margin-left: -3em;
}
.ct-btn.type-submit:focus {
  outline: none;
}

/* contact-btn */
.g-reserve-btn {
  min-width: 184px;
  font-size: 1.2857rem;
  letter-spacing: .2em;
}

/* header
----------------------------------------------------------*/
.g-header {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 999;
  padding:20px 30px 8px;
}
.sitename {
  margin-top: 2px;
}
.sitename a {
  color: #000;
  text-decoration: none;
}
.sitename a:focus {
  outline: none;
  opacity: .7;
}
.sitename span {
  margin-left: 1em;
  font-size: 1.4286rem;
  vertical-align: text-bottom;
}

.g-header-info {
  margin-bottom: 18px;
  -webkit-box-pack: end;
  justify-content: flex-end;
}
.g-header-info .tel {
  margin: 4px 50px 0 0;
}

/* .menu-btn */
.menu-btn {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 9999;
  text-align: center;
  cursor: pointer;
  width: 72px;
  padding: 15px 15px 12px;
  background: #777;
}
.menu-btn,
.menu-btn span {
  display: block;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.menu-bar {
  position: relative;
  width: 40px;
  height: 20px;
  margin: 0 auto;
}
.menu-bar:before,
.menu-bar:after,
.menu-bar > span {
  position: absolute;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  content: "";
  -webkit-transition: all 0.5s ease-out;
  transition: all 0.5s ease-out;
  background: #fff;
}

.menu-bar:before {
  top: 0;
}
.menu-bar > span {
  top: 9px;
}
.menu-bar:after {
  bottom: 0;
}

.menu-btn.is-open .menu-bar:before {
  -webkit-transform: translateY(9px) rotate(-45deg);
  transform: translateY(9px) rotate(-35deg);
}
.menu-btn.is-open .menu-bar > span {
  opacity: 0;
}
.menu-btn.is-open .menu-bar:after {
  -webkit-transform: translateY(-9px) rotate(45deg);
  transform: translateY(-9px) rotate(35deg);
}
.menu-btn .label {
  width: auto;
  height: auto;
  margin: 11px 0 0;
  color: #fff;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.05em;
}

.g-spnav-modal {
  position: relative;
  z-index: 9999;
  display: none;
}
.g-spnav-modal.for-top {
  display: block;
}

/* spnav */
.g-spnav {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 999;
  display: none;
  width: 100%;
  height: 100vh;
  padding: 110px 0 80px;
  background: rgba(0,0,0,.7);

}
.g-spnav-inner {
  overflow-x: auto;
  height: 100%;
  -webkit-overflow-scrolling: touch;
}
.g-spnav li {
  width: 32%;
  margin-bottom: 15px;
}
.g-spnav li a {
  display: block;
  padding: .6em .5em;
  text-decoration: none;
  border-bottom: 1px solid #666;
}
.g-spnav li a:hover {
  border-bottom-color: #fff;
}
body.is-fixed #wrapper {
  -webkit-filter: blur(10px);
  filter: blur(10px);
}

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

}

/* footer
----------------------------------------------------------*/
.g-footer {
  position: relative;
  padding-bottom: 40px;
  text-align: center;
  color: #333;
  background: #fff;
}
.g-footer-nav {
  position: relative;
  z-index: 2;
  margin-bottom: 55px;
  padding-top: 70px;
  padding-bottom: 60px;
  background: #000;
}
.g-footer-nav:after {
  content: "";
  position: absolute;
  bottom: -6%;
  left: 0;
  right: 0;
  z-index: -1;
  padding-top: 5%;
  background: url(../img/common/bg-bottom.png) no-repeat center bottom / 100%;
}
.g-footer-nav > .inner {
  max-width: 800px;
}
.g-footer-nav li {
  margin-left: 1.04em;
  margin-right: 1.04em;
  margin-bottom: 1.2em;
  font-size: 0.75rem;
}
.g-footer-nav li a {
  color: #fff;
  text-decoration: none;
}
.g-footer-nav a::before {
  content: "/";
}
.g-footer-nav a::after {
  content: "/";
}
.g-footer-nav a:hover {
  text-decoration: none;
  opacity: .7;
}

.g-footer-logo {
  margin-bottom: 24px;
}
.g-footer-logo .tagline {
  margin-bottom: 1.4em;
  font-size: 1.25rem;
  font-weight: bold;
}
.g-footer-grouplogo {
  margin-bottom: 24px;
}
.g-copyright {
  margin: 35px 0 0;
  font-size: 12px;
}

/* レスポンシブ
----------------------------------------------------------*/
/* 959px 以下 (タブレット縦以下) */
@media screen and (max-width: 959px) {
  .ct-btn .en {
    top: -.8em;
  }

  /* header ----- */
  .g-header {
    padding: 15px 30px 5px;
  }
  .g-header-info {
    display: none;
  }
  .sitename img {
    width: 160px;
  }
  .sitename span {
    font-size: 1.1rem;
    vertical-align: baseline;
  }

  /* gnav */
  .g-spnav li {
    width:48%;
  }

  /* fadein */
  .g-nav-list li,
  .g-nav .g-header-info {
    opacity: 0;
    -webkit-transition: all .5s ease-out;
    transition: all .5s ease-out;
    -webkit-transform: translateY(-1.2em);
    transform: translateY(-1.2em);
  }

  .g-nav.is-open li,
  .g-nav.is-open .g-header-info {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
  .g-nav-list li:nth-child(1) { -webkit-transition-delay:.1s; transition-delay:.1s; }
  .g-nav-list li:nth-child(2) { -webkit-transition-delay:.2s; transition-delay:.2s; }
  .g-nav-list li:nth-child(3) { -webkit-transition-delay:.3s; transition-delay:.3s; }
  .g-nav-list li:nth-child(4) { -webkit-transition-delay:.4s; transition-delay:.4s; }
  .g-nav-list li:nth-child(5) { -webkit-transition-delay:.5s; transition-delay:.5s; }
  .g-nav .g-header-info { -webkit-transition-delay:.6s; transition-delay:.6s;}

  /* footer */
  .g-footer-nav:after {
    background-size: 960px;
    bottom: -4%;
  }
}

/* 599x 以下 (スマホ)  */
@media screen and (max-width: 599px) {

  /* header ----- */
  .g-header {
    padding: 10px 15px 2px;
  }
  .g-header-contact {
    max-width: 290px;
  }
  .sitename img {
    width: 120px;
  }
  .sitename span {
    font-size: .9em;
  }

  /* gnav ------------ */
  .menu-btn {
    width: auto;
    padding: 14px 15px 10px;
  }
  .menu-bar {
    width: 32px;
  }
  .menu-btn .label {
    font-size: 11px;
    margin-top: 8px;
  }
  .g-spnav {
    padding: 80px 0 30px;
  }
  .g-spnav li {
    width: 100%;
    margin-bottom: 0;
  }
  .g-spnav li a {
    padding: 1em .5em;
  }
  .g-spnav-list {
    margin-bottom: 130px;
  }

  /* footer ------------ */
  .g-footer {
    padding-bottom: 25px;
  }
  .g-footer-nav:after {
    background-size: 1500px;
  }
  .g-footer-nav {
    padding-bottom: 20px;
  }
  .g-footer-nav li {
    font-size: .85em;
  }
  .g-footer-nav:after {
    bottom: -3%;
    background-size: 600px;
  }

  .g-footer-logo .tagline {
    margin-bottom: 1em  ;
    font-size: 1.15rem;
  }
  .g-footer-logo .logo {
    max-width: 230px;
    margin: 0 auto;
  }
  .g-footer-grouplogo {
    max-width: 120px;
    margin-left: auto;
    margin-right: auto;
  }

  .g-copyright {
    font-size: 11px;
  }
}
