@charset "UTF-8";
/**
 * Common Styles
 *
 * 01. Reset
 * 02. Base
 * 03. Layout
 * 04. Parts
 * 05. Project
 *
 */
/* ==========================================================================
   01. Reset
   ========================================================================== */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

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

ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

/* ==========================================================================
   02. Base
   ========================================================================== */
@font-face {
  font-family: 'Shelley Script';
  font-style: normal;
  font-weight: normal;
  src: url(fonts/ShelleyLTStd-Script.woff2) format("woff2"), url(fonts/ShelleyLTStd-Script.woff) format("woff"), url(fonts/ShelleyLTStd-Script.otf) format("opentype");
}

html {
  color: #5a5129;
  font-size: 62.5%;
}

@media screen and (min-width: 768px), print {
  html {
    font-size: 0.67vw;
  }
}

@media screen and (min-width: 1501px) {
  html {
    font-size: 10px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  html {
    font-size: 8px;
  }
}

@media screen and (max-width: 767px) {
  html {
    font-size: 10px;
    font-size: 2.67vw;
  }
}

body {
  background-color: #f3f2ea;
  font-family: "adobe-garamond-pro", "source-han-serif-japanese", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  -webkit-font-feature-settings: 'palt';
          font-feature-settings: 'palt';
  line-height: 2;
  -webkit-text-size-adjust: 100%;
  font-size: 14px;
  font-size: 1.4rem;
}

@media screen and (min-width: 1501px) {
  body {
    font-size: 140%;
  }
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  body {
    font-size: 11px;
  }
}

@media screen and (max-width: 767px) {
  body {
    font-size: 12px;
    font-size: 3.2vw;
  }
}

body * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#main {
  display: block;
}

/* hX
   ========================================================================== */
h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

/* link
   ========================================================================== */
a {
  color: #5a5129;
  text-decoration: none;
  -webkit-transition: color 0.5s ease;
  transition: color 0.5s ease;
}

a:visited {
  color: #5a5129;
}

@media screen and (min-width: 768px), print {
  a:hover {
    color: #b49531;
  }
}

/* image
   ========================================================================== */
img {
  height: auto;
  line-height: 1;
  max-width: 100%;
  vertical-align: top;
}

table th img,
table td img {
  vertical-align: middle;
}

/* ClearFix
   ========================================================================== */
.clear {
  clear: both;
}

.clearfix,
.fbox,
#contents {
  display: block;
}

.clearfix:after,
.fbox:after,
#contents:after {
  content: "";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

/* float
   ========================================================================== */
.fr {
  float: right;
}

.fl {
  float: left;
}

ul.fbox li {
  float: left;
  display: inline;
}

/* form label
   ========================================================================== */
input,
textarea,
label {
  vertical-align: middle;
}

/* text-align
   ========================================================================== */
.text-r {
  text-align: right !important;
}

.text-c {
  text-align: center !important;
}

.text-l {
  text-align: left !important;
}

/* margin
   ========================================================================== */
.mb0 {
  margin-bottom: 0 !important;
}

/* ==========================================================================
   03. Layout
   ========================================================================== */
/* html, body
   ========================================================================== */
html, body {
  height: 100%;
}

/* body-overlay */
#body-overlay {
  background-color: #f3f2ea;
  height: 100vh;
  width: 100vw;
  position: fixed;
  left: 0;
  top: 0;
}

/* wrapper
   ========================================================================== */
@media screen and (min-width: 768px), print {
  #wrapper {
    overflow: hidden;
    padding-top: 129px;
  }
}

@media screen and (max-width: 767px) {
  #wrapper {
    padding-bottom: 62px;
    padding-bottom: 16.53vw;
  }
}

@media screen and (min-width: 768px), print {
  body.cattop #wrapper {
    padding-top: 178px;
  }
}

/* header
   ========================================================================== */
/* ヘッダー全体 */
#head {
  background-color: #f3f2ea;
  width: 100%;
}

@media screen and (min-width: 768px), print {
  #head {
    height: 129px;
    position: fixed;
    top: 0;
    left: 0;
    -webkit-transition: height 0.5s ease;
    transition: height 0.5s ease;
  }
}

@media screen and (max-width: 767px) {
  #head {
    position: relative;
    height: 62px;
    height: 16.53vw;
    padding-left: 10px;
    padding-left: 2.67vw;
    padding-right: 10px;
    padding-right: 2.67vw;
  }
}

/* ヘッダートップ */
.head-top {
  background-color: #f3f2ea;
  width: 100%;
  position: relative;
  -webkit-transition: height 0.5s ease;
  transition: height 0.5s ease;
}

@media screen and (min-width: 768px), print {
  .head-top {
    height: 129px;
    margin: 0 1.33vw;
    width: calc(100% - 2.67vw);
  }
  .head-top:before {
    background-color: #e6e6d2;
    content: '';
    display: block;
    height: 1px;
    width: 100%;
    position: absolute;
    left: 0;
    bottom: 0;
  }
}

/* ヘッダートップ（SP） */
@media screen and (max-width: 767px) {
  .head-top-sp {
    background-color: #f3f2ea;
    height: 62px;
    height: 16.53vw;
    position: fixed;
    left: 0;
    top: 0;
    overflow: hidden;
    -webkit-transition: -webkit-transform 0.25s ease;
    transition: -webkit-transform 0.25s ease;
    transition: transform 0.25s ease;
    transition: transform 0.25s ease, -webkit-transform 0.25s ease;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
    width: 100%;
  }
  .head-top-sp:after {
    background-color: #e6e6d2;
    content: '';
    display: block;
    height: 1px;
    width: calc(100% - 20px);
    width: calc(100% - 5.34vw);
    position: absolute;
    left: 10px;
    left: 2.67vw;
    bottom: 0;
  }
}

@media screen and (max-width: 767px) {
  body:not(.js-menu-open) #head.headroom--unpinned .head-top-sp {
    -webkit-transition-duration: 0.5s;
            transition-duration: 0.5s;
    -webkit-transform: translate3d(0, -76px, 0);
            transform: translate3d(0, -76px, 0);
    -webkit-transform: translate3d(0, -20.27vw, 0);
            transform: translate3d(0, -20.27vw, 0);
  }
}

/* ヘッダーボトム（SP） */
@media screen and (max-width: 767px) {
  .head-btm-sp {
    background-color: #f3f2ea;
    border-top: 2px solid #b49531;
    padding: 10px;
    padding: 2.67vw;
    position: fixed;
    left: 0;
    bottom: 0;
    height: 62px;
    height: 16.53vw;
    width: 100%;
  }
}

/* ロゴ */
.head-logo {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 190px;
  height: 80px;
  text-align: center;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transform-origin: center center;
          transform-origin: center center;
  -webkit-transition: height 0.5s ease, width 0.5s ease, opacity 1s ease, top 1s ease;
  transition: height 0.5s ease, width 0.5s ease, opacity 1s ease, top 1s ease;
}

.head-logo a {
  color: transparent !important;
  height: 100%;
  display: block;
  position: relative;
}

.head-logo img {
  width: 100%;
  height: auto;
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .head-logo {
    width: 160px;
    height: 68px;
  }
}

@media screen and (max-width: 767px) {
  .head-logo {
    -webkit-transition: opacity 0.5s ease, top 1s ease;
    transition: opacity 0.5s ease, top 1s ease;
    width: 100px;
    width: 26.67vw;
    height: 44px;
    height: 11.73vw;
  }
}

/* メニューボタン */
@media screen and (min-width: 768px), print {
  .head-menu {
    width: 90px;
    height: 90px;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .head-menu a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    height: 100%;
    width: 100%;
  }
  .head-menu a:hover span {
    -webkit-transition: all 0.25s ease;
    transition: all 0.25s ease;
    background-color: #b49531;
  }
  .head-menu a:hover span:after, .head-menu a:hover span:before {
    -webkit-transition: all 0.25s ease;
    transition: all 0.25s ease;
    background-color: #b49531;
  }
  .head-menu span {
    background-color: #5a5129;
    width: 40px;
    height: 1px;
    position: relative;
  }
  .head-menu span:after, .head-menu span:before {
    background-color: #5a5129;
    content: '';
    display: block;
    width: 40px;
    height: 1px;
    position: absolute;
    left: 0;
  }
  .head-menu span:before {
    top: -13px;
  }
  .head-menu span:after {
    top: 13px;
  }
}

@media screen and (max-width: 767px) {
  .head-menu {
    background-color: #fff;
    position: absolute;
    right: 10px;
    right: 2.67vw;
    top: 10px;
    top: 2.67vw;
    width: 40px;
    width: 10.67vw;
    height: 40px;
    height: 10.67vw;
    border-radius: 4px;
    border-radius: 1.07vw;
  }
  .head-menu a {
    display: block;
    height: 100%;
    width: 100%;
  }
  .head-menu span {
    background-color: #ccccba;
    display: block;
    position: absolute;
    right: 10px;
    right: 2.67vw;
    top: 10px;
    top: 2.67vw;
    width: 20px;
    width: 5.33vw;
    height: 1px;
  }
  .head-menu span:after, .head-menu span:before {
    background-color: #ccccba;
    content: '';
    display: block;
    height: 1px;
    position: absolute;
  }
  .head-menu span:before {
    width: 18px;
    width: 4.8vw;
    top: 8px;
    top: 2.13vw;
  }
  .head-menu span:after {
    width: 16px;
    width: 4.27vw;
    top: 16px;
    top: 4.27vw;
  }
}

@media screen and (max-width: 767px) {
  body.js-gnav-open .head-menu span {
    background-color: transparent;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  body.js-gnav-open .head-menu span:after, body.js-gnav-open .head-menu span:before {
    width: 20px;
    width: 5.33vw;
    left: 50%;
    top: 50%;
  }
  body.js-gnav-open .head-menu span:before {
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
            transform: translate(-50%, -50%) rotate(45deg);
  }
  body.js-gnav-open .head-menu span:after {
    -webkit-transform: translate(-50%, -50%) rotate(-45deg);
            transform: translate(-50%, -50%) rotate(-45deg);
  }
}

/* コントロール（カテゴリー名 + ページトップ）※動的追加 */
#head-ctrl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  position: absolute;
  left: 90px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media screen and (max-width: 767px) {
  #head-ctrl {
    left: auto;
    right: 66px;
    right: 17.6vw;
  }
}

/* カテゴリー名 */
#head-cat-wrap {
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
}

@media screen and (min-width: 768px), print {
  #head-cat-wrap {
    padding-right: 25px;
  }
  #head-cat-wrap:hover #head-cnav-wrap {
    opacity: 1;
    visibility: visible;
  }
  #head-cat-wrap:hover .head-cat:before {
    opacity: 1;
  }
}

@media screen and (max-width: 767px) {
  #head-cat-wrap {
    text-align: right;
  }
}

.head-cat {
  position: relative;
  line-height: 1.2;
}

.head-cat a {
  display: block;
}

.head-cat-sub {
  color: #b49531;
  margin-bottom: 3px;
  font-size: 12px;
  font-size: 1.2rem;
}

.head-cat-ttl {
  font-size: 16px;
  font-size: 1.6rem;
}

@media screen and (min-width: 768px), print {
  .head-cat a {
    position: relative;
    width: 9.33vw;
    height: 40px;
    padding-top: 5px;
    text-align: center;
  }
  .head-cat:before {
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease;
    opacity: 0;
    top: -15px;
    height: 74px;
    position: absolute;
    display: block;
    content: '';
    background-color: #f9f9f4;
    border: 1px solid #e6e6d2;
    border-bottom: none;
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .head-cat {
    text-align: center;
    border: 1px solid #e6e6d2;
    width: 120px;
    width: 32vw;
    border-radius: 4px;
    border-radius: 1.07vw;
    height: 40px;
    height: 10.67vw;
    padding-top: 7px;
    padding-top: 1.87vw;
    padding-left: 16px;
    padding-left: 4.27vw;
    padding-right: 16px;
    padding-right: 4.27vw;
  }
  .head-cat-sub {
    font-size: 10px;
    font-size: 2.67vw;
    margin-bottom: 1px;
    margin-bottom: 0.27vw;
  }
  .head-cat-ttl {
    font-size: 12px;
    font-size: 3.2vw;
  }
}

/* カテゴリーナビ */
#head-cnav-wrap {
  background-color: #f9f9f4;
  position: absolute;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  border: 1px solid #e6e6d2;
}

@media screen and (min-width: 768px), print {
  #head-cnav-wrap {
    left: -70px;
    top: calc(100% - 82px);
    margin-top: 56px;
    width: calc(70px + 9.33vw + 70px);
    padding: 0.67vw 1.6vw;
    -webkit-box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
            box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
  }
}

@media screen and (max-width: 767px) {
  #head-cnav-wrap {
    right: -63px;
    right: -16.8vw;
    bottom: calc(100% - 12px);
    width: 55vw;
    margin-left: 20px;
    margin-left: 5.33vw;
    margin-right: 20px;
    margin-right: 5.33vw;
    padding-top: 10px;
    padding-top: 2.67vw;
    padding-bottom: 10px;
    padding-bottom: 2.67vw;
    padding-left: 20px;
    padding-left: 5.33vw;
    padding-right: 20px;
    padding-right: 5.33vw;
    -webkit-box-shadow: 0 -16px 44px -12px rgba(0, 0, 0, 0.16);
            box-shadow: 0 -16px 44px -12px rgba(0, 0, 0, 0.16);
  }
}

.js-active #head-cnav-wrap {
  opacity: 1;
  visibility: visible;
}

.js-active .head-cat {
  border-radius: 0;
  background: #f9f9f4;
  border-top-color: #f9f9f4;
  position: relative;
  z-index: 1001;
}

.js-fixed .head-cat:before {
  top: -7px;
  height: 58px;
}

@media screen and (min-width: 768px), print {
  .js-fixed #head-cnav-wrap {
    top: calc(100% - 85px + 25px);
  }
}

#head-cnav li {
  border-top: 1px solid #e6e6d2;
}

#head-cnav li.active {
  color: #b49531;
}

#head-cnav li.active span {
  display: block;
  padding: 0.53vw 0;
}

#head-cnav li.activeParent a {
  color: #b49531;
}

#head-cnav li:first-child {
  border-top: none;
}

#head-cnav a {
  display: block;
  padding: 0.53vw 0;
}

@media screen and (max-width: 767px) {
  #head-cnav {
    background: transparent;
    display: block;
  }
  #head-cnav li {
    border-left: none;
    text-align: center;
    width: 100%;
    font-size: 11px;
    font-size: 1.1rem;
  }
  #head-cnav li.active span {
    padding-top: 8px;
    padding-top: 2.13vw;
    padding-bottom: 8px;
    padding-bottom: 2.13vw;
  }
  #head-cnav li.activeParent a {
    color: #b49531;
  }
  #head-cnav li.sp-item a {
    color: rgba(90, 81, 41, 0.5);
  }
  #head-cnav a {
    padding-top: 8px;
    padding-top: 2.13vw;
    padding-bottom: 8px;
    padding-bottom: 2.13vw;
  }
}

/* SHARE */
.head-share {
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 1;
}

@media screen and (min-width: 768px), print {
  .head-share {
    position: absolute;
    right: 326px;
    top: 50%;
    -webkit-transition: top 0.5s ease;
    transition: top 0.5s ease;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .head-share {
    right: 176px;
  }
}

.head-share.js-opened .head-share-list {
  opacity: 1;
  visibility: visible;
  width: 158px;
}

@media screen and (max-width: 767px) {
  .head-share.js-opened {
    background-color: #f3f2ea;
    height: calc(100% - 1px);
    width: 100%;
    position: absolute;
    left: 0;
    top: 0;
    -webkit-transform: none;
            transform: none;
  }
  .head-share.js-opened .head-share-list {
    opacity: 1;
    visibility: visible;
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .head-share-btn {
    position: absolute;
    right: 20px;
    right: 5.33vw;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}

.head-share-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  line-height: 1;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
  position: absolute;
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
}

.head-share-list li {
  margin-right: 4px;
  font-size: 28px;
}

.head-share-list li:last-child {
  margin-right: 0;
}

.head-share-list a {
  display: block;
}

.head-share-list a:before {
  color: #888163;
  padding-right: 0;
  -webkit-transition: color 0.5s ease;
  transition: color 0.5s ease;
}

.head-share-list a:hover:before {
  color: #b49531;
}

@media screen and (min-width: 768px), print {
  .head-share-list {
    background: #f9f9f4;
    border: 1px solid #e6e6d2;
    padding: 8px 16px;
    right: 50%;
    top: 170%;
  }
  .head-share-list:before {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 3px 7px 3px;
    border-color: transparent transparent #e6e6d2 transparent;
    position: absolute;
    left: 50%;
    top: -8px;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .head-share-list:after {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 3px 6px 3px;
    border-color: transparent transparent #f9f9f4 transparent;
    position: absolute;
    left: 50%;
    top: -6px;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .head-share-list li {
    height: 28px;
  }
}

@media screen and (max-width: 767px) {
  .head-share-list {
    height: 28px;
    height: 7.47vw;
    right: 0;
    width: 100%;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .head-share-list li {
    font-size: 28px;
    font-size: 7.47vw;
    margin-right: 13px;
    margin-right: 3.47vw;
  }
}

/* ONLINE SHOP */
@media screen and (min-width: 768px), print {
  .head-online-shop {
    line-height: 1.2;
    position: absolute;
    right: 180px;
    top: 50%;
    -webkit-transition: top 0.5s ease;
    transition: top 0.5s ease;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    font-size: 13px;
    font-size: 1.3rem;
  }
  .head-online-shop br {
    display: none;
  }
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .head-online-shop {
    right: 104px;
  }
  .head-online-shop br {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .head-online-shop {
    display: none;
  }
}

/* レストラン予約、宿泊予約 */
.head-reserve {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 1.2;
}

.head-reserve .head-reserve-restaurant a {
  display: block;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.head-reserve button {
  background: none;
  border: none;
  color: #b49531;
  cursor: pointer;
  display: block;
  font-family: inherit;
  outline: none;
  text-align: left;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.head-reserve button span {
  display: block;
}

.head-reserve-sub {
  color: #b49531;
  margin-bottom: 3px;
  font-size: 12px;
  font-size: 1.2rem;
}

.head-reserve-ttl {
  font-size: 15px;
  font-size: 1.5rem;
}

@media screen and (min-width: 768px), print {
  .head-reserve {
    position: absolute;
    top: 50%;
    right: 1.33vw;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .head-reserve .head-reserve-restaurant {
    margin-right: 10px;
  }
  .head-reserve .head-reserve-restaurant br {
    display: none;
  }
  .head-reserve .head-reserve-restaurant a {
    border: 1px solid #b49531;
    border-radius: 4px;
    color: #b49531;
    padding: 12px 13px 8px 35px;
    height: 40px;
  }
  .head-reserve .head-reserve-restaurant a:before {
    content: "";
    display: block;
    position: absolute;
    left: 15px;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 13px;
    font-size: 1.3rem;
  }
  .head-reserve .head-reserve-restaurant a:after {
    display: none;
  }
  .head-reserve .head-reserve-restaurant a:hover {
    color: #f3f2ea;
    background: #b49531;
    -webkit-box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
            box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
    -webkit-transform: translateY(-0.3rem);
            transform: translateY(-0.3rem);
  }
  .head-reserve .head-reserve-restaurant a:hover span:before {
    color: #f3f2ea;
  }
  .head-reserve .head-reserve-restaurant a:hover span:after {
    color: #f3f2ea;
  }
  .head-reserve button {
    border: 1px solid #b49531;
    border-radius: 4px;
    padding: 8px 13px 8px 35px;
    position: relative;
    height: 40px;
    width: 115px;
  }
  .head-reserve button:before {
    content: "";
    display: block;
    position: absolute;
    left: 15px;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 13px;
    font-size: 1.3rem;
  }
  .head-reserve button:hover {
    color: #f3f2ea;
    background: #b49531;
    -webkit-box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
            box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
    -webkit-transform: translateY(-0.3rem);
            transform: translateY(-0.3rem);
  }
  .head-reserve button:hover span:before {
    color: #f3f2ea;
  }
  .head-reserve button:hover span:after {
    color: #f3f2ea;
  }
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .head-reserve {
    right: 0;
  }
  .head-reserve .head-reserve-restaurant br {
    display: block;
  }
  .head-reserve .head-reserve-restaurant a {
    padding: 6px 13px 8px;
  }
  .head-reserve .head-reserve-restaurant a:before {
    display: none;
  }
  .head-reserve button {
    padding: 8px 13px;
    width: 76px;
    white-space: nowrap;
  }
  .head-reserve button:before {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .head-reserve {
    height: 100%;
  }
  .head-reserve .head-reserve-restaurant {
    margin-right: 20px;
    margin-right: 5.33vw;
  }
  .head-reserve .head-reserve-restaurant br {
    display: none;
  }
  .head-reserve .head-reserve-restaurant a {
    width: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    height: 100%;
  }
  .head-reserve .head-reserve-restaurant a:after {
    display: none;
  }
  .head-reserve form {
    height: 100%;
  }
  .head-reserve button {
    border-right: 1px solid #e6e6d2;
    color: #5a5129;
    width: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
    height: 100%;
    padding-right: 19px;
    padding-right: 5.07vw;
  }
  .head-reserve button:before {
    display: none;
  }
  .head-reserve-ttl {
    font-size: 14px;
    font-size: 3.73vw;
    padding-left: 20px;
    padding-left: 5.33vw;
  }
  .head-reserve-ttl:before {
    color: #b49531;
    content: "";
    display: block;
    position: absolute;
    left: 10px;
    left: 2.67vw;
    top: 48%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
}

/* SLH */
.head-slh {
  position: absolute;
  right: 24px;
  top: 50%;
  width: 47px;
  height: 51px;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.head-slh:hover {
  opacity: .8;
}

.head-slh img {
  width: 100%;
  height: auto;
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .head-slh {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .head-slh {
    display: none;
  }
}

/* ローカルナビ */
.head-lnav-wrap {
  background: none;
  position: relative;
  top: -49px;
  -webkit-transition: top 1s ease;
  transition: top 1s ease;
}

#head-lnav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  line-height: 1;
}

#head-lnav li {
  height: 49px;
}

#head-lnav li.js-active span:before {
  opacity: 1;
}

#head-lnav a {
  display: block;
  height: 100%;
  padding: 0 20px;
}

#head-lnav a[target=_blank] span:after {
  color: #b49531;
  content: "";
  display: inline-block;
  margin-left: 4px;
  position: relative;
  top: -1px;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#head-lnav span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  position: relative;
}

#head-lnav span:before {
  background-color: #b49531;
  content: '';
  display: block;
  height: 3px;
  width: 100%;
  opacity: 0;
  position: absolute;
  left: 0;
  top: -1px;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
}

@media screen and (max-width: 767px) {
  #head-lnav {
    display: none;
  }
}

/* SP用ローカルナビ */
@media screen and (max-width: 767px) {
  #sp-lnav-wrap {
    margin-bottom: 0;
    position: relative;
    text-align: center;
    margin-left: 10px;
    margin-left: 2.67vw;
    margin-right: 10px;
    margin-right: 2.67vw;
  }
  #sp-lnav-btn {
    line-height: 1;
  }
  #sp-lnav-btn a {
    color: #b49531;
    display: block;
    font-size: 12px;
    font-size: 3.2vw;
    padding-top: 27px;
    padding-top: 7.2vw;
    padding-bottom: 27px;
    padding-bottom: 7.2vw;
  }
  #sp-lnav-btn span {
    display: inline-block;
    padding-left: 18px;
    padding-left: 4.8vw;
    padding-right: 18px;
    padding-right: 4.8vw;
    position: relative;
  }
  #sp-lnav-btn span:before {
    background: url("img/icon_sp_lnav.svg") no-repeat left top;
    background-size: contain;
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    height: 10px;
    height: 2.67vw;
    width: 12px;
    width: 3.2vw;
  }
  #sp-lnav {
    background-color: #f9f9f4;
    display: none;
    position: absolute;
    left: 0;
    top: calc(100% - 1px);
    width: 100%;
    font-size: 12px;
    font-size: 3.2vw;
  }
  #sp-lnav li {
    border-bottom: 1px solid #e6e6d2;
  }
  #sp-lnav a {
    display: block;
    padding-top: 13px;
    padding-top: 3.47vw;
    padding-bottom: 10px;
    padding-bottom: 2.67vw;
  }
  #sp-lnav a[target=_blank] span:after {
    color: #b49531;
    content: "";
    display: inline-block;
    margin-left: 4px;
    position: relative;
    top: 1px;
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  body.js-lnav-open {
    height: 100vh;
    overflow: hidden;
  }
}

/* ページタイトル */
.head-page-ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-weight: normal;
  font-size: 22px;
  font-size: 2.2rem;
  opacity: 0;
  position: absolute;
  left: 50%;
  top: 50%;
  height: 69px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  -webkit-transition: opacity 0.5s ease, top 0.75s ease 0.1s;
  transition: opacity 0.5s ease, top 0.75s ease 0.1s;
}

.head-page-ttl span {
  display: block;
  text-align: center;
}

.head-page-ttl span.head-page-ttl-img {
  height: 69px;
  padding-top: 8px;
  padding-bottom: 8px;
}

.head-page-ttl span.head-page-ttl-img.logo2 {
  width: 116px;
  height: 69px;
  padding: 10px 0;
}

.head-page-ttl span.head-page-ttl-img.logo2 img {
  -webkit-backface-visibility: inherit;
}

.head-page-ttl span.head-page-ttl-img#lachere-logo {
  padding-top: 6px;
  padding-bottom: 6px;
}

.head-page-ttl span.head-page-ttl-img#grandblue-logo {
  padding-top: 14px;
  padding-bottom: 14px;
}

.head-page-ttl img {
  display: block;
  -webkit-backface-visibility: hidden;
  height: 100%;
  width: auto;
}

@media screen and (max-width: 767px) {
  .head-page-ttl {
    line-height: 1.2;
    font-size: 16px;
    font-size: 1.6rem;
  }
  .head-page-ttl span.head-page-ttl-img {
    height: 100%;
    padding-top: 8px;
    padding-top: 2.13vw;
    padding-bottom: 8px;
    padding-bottom: 2.13vw;
  }
  .head-page-ttl span.head-page-ttl-img.logo2 {
    width: 100px;
    width: 26.67vw;
    height: 44px;
    height: 11.73vw;
    padding: 0;
  }
}

.head-btm-sp .head-page-ttl {
  display: none;
}

/* ページトップ */
.pagetop {
  opacity: 0;
  height: 40px;
  width: 40px;
  -webkit-transition: opacity 1s ease;
  transition: opacity 1s ease;
}

.pagetop a {
  -webkit-transition: border 0.5s ease;
  transition: border 0.5s ease;
  border: 1px solid #e6e6d2;
  border-radius: 5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  width: 100%;
  position: relative;
}

.pagetop a:hover {
  border: 1px solid rgba(180, 149, 49, 0.6);
}

.pagetop span {
  border-top: 1px solid #b49531;
  border-right: 1px solid #b49531;
  display: block;
  height: 8px;
  width: 8px;
  margin-top: 5px;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

@media screen and (max-width: 767px) {
  .pagetop {
    opacity: 1;
    position: absolute;
    left: 20px;
    left: 5.33vw;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    height: 30px;
    height: 8vw;
    width: 30px;
    width: 8vw;
  }
  .pagetop a {
    border: none;
    border-radius: 0;
  }
  .pagetop a:hover {
    border: none;
  }
  .pagetop span {
    height: 7px;
    height: 1.87vw;
    width: 7px;
    width: 1.87vw;
  }
}

/* アニメーション */
@media screen and (min-width: 768px), print {
  #head.js-fixed {
    height: 69px;
  }
  #head.js-fixed .head-top {
    height: 69px;
  }
  #head.js-fixed .head-logo {
    top: 20%;
    opacity: 0;
    width: 190px;
    height: 80px;
  }
  #head.js-fixed .head-logo a {
    pointer-events: none;
  }
  #head.js-fixed .head-page-ttl {
    opacity: 1;
    top: 0;
  }
  #head.js-fixed .head-menu {
    height: 69px;
  }
  #head.js-fixed .pagetop {
    opacity: 1;
  }
  body.js-lnav-open #head {
    height: 118px;
  }
  body.js-lnav-open #head .head-lnav-wrap {
    top: 0;
  }
  body.cattop #head.js-fixed {
    height: 118px;
  }
  body.cattop .head-lnav-wrap {
    top: 0;
  }
}

@media screen and (max-width: 767px) {
  #head.js-fixed .head-logo {
    top: -100%;
    opacity: 0;
  }
  #head.js-fixed .head-page-ttl {
    height: 100%;
    opacity: 1;
    top: 0;
  }
  #head.js-fixed .pagetop {
    opacity: 1;
  }
  #head .head-logo.ls-logo {
    top: 50%;
    opacity: 1;
  }
  #head .logo2 {
    display: none;
  }
}

/* navigation
   ========================================================================== */
@media screen and (min-width: 768px), print {
  #gnav {
    background-color: rgba(3, 0, 0, 0.9);
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    -webkit-overflow-scrolling: touch;
    overflow: scroll;
    overflow-x: hidden;
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: opacity 0.5s ease;
    transition: opacity 0.5s ease;
  }
  .gnav-inner {
    position: absolute;
    left: 0;
    top: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    min-height: 100%;
  }
  .gnav-menu {
    background-color: #fff;
    padding: 40px 0 40px 117px;
    width: 375px;
  }
  .gnav-menu-ttl {
    color: #5a5129;
    letter-spacing: .5em;
    line-height: 1;
    font-size: 12px;
    font-size: 1.2rem;
    margin-bottom: 72px;
  }
  .gnav-menu-list {
    margin-bottom: 48px;
  }
  .gnav-menu-list li {
    line-height: 1;
    font-size: 15px;
    font-size: 1.5rem;
    margin-bottom: 32px;
  }
  .gnav-menu-list li:last-child {
    margin-bottom: 0;
  }
  .gnav-menu-list a {
    display: inline-block;
  }
  .gnav-menu-list .en {
    color: #b49531;
    display: block;
    font-size: 10px;
    font-size: 1rem;
    letter-spacing: .1em;
    margin-bottom: 4px;
  }
  .gnav-menu-list li.active,
  .gnav-menu-list li.activeParent {
    color: #b49531;
  }
  .gnav-menu-item-child {
    display: none !important;
  }
  .gnav-menu-utility-list li {
    font-size: 12px;
    font-size: 1.2rem;
    margin-bottom: 10px;
  }
  .gnav-menu-utility-list li:last-child {
    margin-bottom: 0;
  }
  .gnav-floor {
    color: #fff;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-top: 40px;
    position: relative;
  }
  .gnav-floor-ttl {
    letter-spacing: .5em;
    line-height: 1;
    text-align: center;
    font-size: 12px;
    font-size: 1.2rem;
  }
  .gnav-floor-box-wrap {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    padding-left: 16.6vw;
    padding-top: 55px;
    width: 100%;
  }
  .gnav-floor-box a {
    color: #fff;
    display: inline-block;
  }
  .gnav-floor-box a:hover .item-sub {
    color: #b49531;
  }
  .gnav-floor-box a:hover .item-ttl {
    opacity: .7;
  }
  .gnav-floor-box-inner {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    border-left: 1px solid rgba(255, 255, 255, 0.2);
    min-height: 100px;
    padding: 35px 0;
    position: relative;
  }
  .gnav-floor-box-f {
    color: rgba(255, 255, 255, 0.5);
    line-height: 1;
    position: absolute;
    right: calc(100% + 1.2vw);
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    white-space: nowrap;
    font-size: 13px;
    font-size: 1.3rem;
  }
  .gnav-floor-box-item-wrap {
    overflow: hidden;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .gnav-floor-box-item {
    line-height: 1;
    padding: 0 2.67vw;
  }
  .gnav-floor-box-item .item-sub {
    -webkit-transition: color .4s;
    transition: color .4s;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 5px;
    font-size: 12px;
    font-size: 1.2rem;
  }
  .gnav-floor-box-item .item-ttl {
    -webkit-transition: opacity .4s;
    transition: opacity .4s;
    font-size: 16px;
    font-size: 1.6rem;
  }
  .gnav-floor-box-item .item-ttl img {
    margin-top: 0.27vw;
  }
  .floor-9 {
    padding-left: 25vw;
  }
  .floor-7 {
    padding-left: 16.67vw;
  }
  .floor-7 .gnav-floor-box-inner {
    padding-left: 8.33vw;
  }
  .floor-4 {
    padding-left: 8.33vw;
  }
  .floor-4 .gnav-floor-box-inner {
    padding-left: 16.67vw;
  }
  .floor-3 .gnav-floor-box-inner {
    padding-left: 25vw;
    position: relative;
  }
  .floor-3 .gnav-floor-box-inner:before {
    background: url(img/gnav_floor_door.png) no-repeat left top;
    background-size: 100% 100%;
    content: '';
    display: block;
    height: 63px;
    width: 45px;
    position: absolute;
    left: 11vw;
    bottom: 0;
  }
  .floor-3 .gnav-floor-box-item:nth-of-type(1) {
    width: 15.33vw;
  }
  .floor-3 .gnav-floor-box-item:nth-of-type(2) {
    padding-left: 4vw;
  }
  .floor-2 .gnav-floor-box-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding-left: 8.33vw;
  }
  .floor-2 .gnav-floor-box-f {
    top: 47px;
  }
  .floor-2 .gnav-floor-box-front {
    position: absolute;
    left: 2.67vw;
    top: 37px;
  }
  .floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) {
    border-right: 1px solid rgba(255, 255, 255, 0.2);
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: 32vw;
  }
  .floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) .gnav-floor-box-item {
    margin-bottom: 45px;
  }
  .floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) .gnav-floor-box-item:nth-child(1), .floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) .gnav-floor-box-item:nth-child(3) {
    width: 16.67vw;
  }
  .floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) .gnav-floor-box-item:nth-child(3), .floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) .gnav-floor-box-item:nth-child(4) {
    margin-bottom: 0;
  }
  .floor-2 .gnav-floor-box-item-wrap:nth-of-type(2) {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  .floor-2 .gnav-floor-box-item-wrap:nth-of-type(2) .gnav-floor-box-item {
    padding-left: 4vw;
  }
  .floor-1 .gnav-floor-box-f {
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .floor-1 .gnav-floor-box-parking {
    position: absolute;
    left: 2.67vw;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  #gnav-close {
    cursor: pointer;
    width: 90px;
    height: 90px;
    position: fixed;
    left: 20px;
    top: 20px;
  }
  #gnav-close:before, #gnav-close:after {
    background-color: #5a5129;
    content: '';
    display: block;
    height: 1px;
    width: 40px;
    position: absolute;
    left: 50%;
    top: 50%;
  }
  #gnav-close:before {
    -webkit-transform: translate(-50%, -50%) rotate(45deg);
            transform: translate(-50%, -50%) rotate(45deg);
  }
  #gnav-close:after {
    -webkit-transform: translate(-50%, -50%) rotate(-45deg);
            transform: translate(-50%, -50%) rotate(-45deg);
  }
  #head.js-fixed #gnav-close {
    height: 69px;
    top: 0;
  }
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .gnav-menu {
    padding-left: 56px;
    width: 260px;
  }
  .gnav-menu-ttl {
    padding-right: 56px;
    text-align: center;
  }
  .gnav-floor-box-wrap {
    padding-left: 9.93vw;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) .gnav-floor-box-item {
    width: 50%;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-item img {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
    -webkit-transform-origin: left top;
            transform-origin: left top;
  }
  #gnav-close {
    left: 0;
  }
}

@media screen and (max-width: 767px) {
  #gnav {
    background-color: transparent;
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    padding-bottom: 62px;
    padding-bottom: 16.53vw;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: opacity 0.5s ease;
    transition: opacity 0.5s ease;
    -webkit-overflow-scrolling: touch;
    overflow: scroll;
    visibility: hidden;
  }
  .gnav-inner {
    background-color: #030000;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
  }
  .gnav-menu {
    background-color: #fff;
    padding-top: 30px;
    padding-top: 8vw;
  }
  .gnav-menu-ttl {
    color: #5a5129;
    letter-spacing: .5em;
    line-height: 1;
    font-size: 12px;
    font-size: 1.2rem;
    margin-bottom: 36px;
    margin-bottom: 9.6vw;
    padding-left: 20px;
    padding-left: 5.33vw;
  }
  .gnav-menu-list {
    padding-bottom: 22px;
    padding-bottom: 5.87vw;
    padding-left: 34px;
    padding-left: 9.07vw;
    padding-right: 34px;
    padding-right: 9.07vw;
  }
  .gnav-menu-list > li {
    line-height: 1;
    font-size: 14px;
    font-size: 1.4rem;
    border-bottom: 1px solid rgba(230, 230, 210, 0.3);
  }
  .gnav-menu-list a {
    display: block;
  }
  .gnav-menu-list a[target="_blank"]:after {
    display: none;
  }
  .gnav-menu-list a[target="_blank"] .gnav-menu-item-inner:after {
    color: #b49531;
    content: "";
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .gnav-menu-list .gnav-menu-item-inner {
    display: block;
    padding-top: 16px;
    padding-top: 4.27vw;
    padding-bottom: 16px;
    padding-bottom: 4.27vw;
    padding-left: 16px;
    padding-left: 4.27vw;
    padding-right: 32px;
    padding-right: 8.53vw;
  }
  .gnav-menu-list .en {
    color: #b49531;
    display: block;
    letter-spacing: .1em;
    font-size: 11px;
    font-size: 1.1rem;
    margin-bottom: 4px;
    margin-bottom: 1.07vw;
  }
  .gnav-menu-list li.active,
  .gnav-menu-list li.activeParent {
    color: #b49531;
  }
  .gnav-menu-item-parent {
    position: relative;
  }
  .gnav-menu-item-parent::before, .gnav-menu-item-parent::after {
    background-color: #ccccba;
    content: '';
    display: block;
    height: 1px;
    width: 9px;
    width: 2.4vw;
    position: absolute;
    top: 50%;
    right: 12px;
    right: 3.2vw;
    -webkit-transition: opacity .3s ease, -webkit-transform .3s ease;
    transition: opacity .3s ease, -webkit-transform .3s ease;
    transition: opacity .3s ease, transform .3s ease;
    transition: opacity .3s ease, transform .3s ease, -webkit-transform .3s ease;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .gnav-menu-item-parent::after {
    -webkit-transform: translateY(-50%) rotate(90deg);
            transform: translateY(-50%) rotate(90deg);
  }
  .gnav-menu-item-parent.-open::before {
    opacity: 0;
    -webkit-transform: translateY(-50%) rotate(90deg);
            transform: translateY(-50%) rotate(90deg);
  }
  .gnav-menu-item-parent.-open::after {
    -webkit-transform: translateY(-50%) rotate(180deg);
            transform: translateY(-50%) rotate(180deg);
  }
  .gnav-menu-item-child {
    display: none;
    padding-bottom: 20px;
    padding-bottom: 5.33vw;
  }
  .gnav-menu-item-child span {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
    padding-top: 10px;
    padding-top: 2.67vw;
    padding-bottom: 10px;
    padding-bottom: 2.67vw;
    padding-left: 32px;
    padding-left: 8.53vw;
    padding-right: 32px;
    padding-right: 8.53vw;
  }
  .gnav-menu-utility-list {
    padding-bottom: 48px;
    padding-bottom: 12.8vw;
    padding-left: 40px;
    padding-left: 10.67vw;
    padding-right: 40px;
    padding-right: 10.67vw;
  }
  .gnav-menu-utility-list li {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .gnav-menu-utility-list .gnav-menu-item-inner {
    display: inline-block;
    padding: 10px;
    padding: 2.67vw;
  }
  .gnav-menu-utility-list li.active {
    color: #b49531;
  }
  .gnav-floor {
    color: #fff;
    padding-top: 30px;
    padding-top: 8vw;
    padding-bottom: 160px;
    padding-bottom: 42.67vw;
  }
  .gnav-floor-ttl {
    letter-spacing: .5em;
    line-height: 1;
    margin-bottom: 57px;
    margin-bottom: 15.2vw;
    padding-left: 20px;
    padding-left: 5.33vw;
    font-size: 12px;
    font-size: 1.2rem;
  }
  .gnav-floor-box-wrap {
    padding-left: 10px;
    padding-left: 2.67vw;
    padding-right: 10px;
    padding-right: 2.67vw;
  }
  .gnav-floor-box {
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    position: relative;
  }
  .gnav-floor-box a {
    color: #fff;
  }
  .gnav-floor-box-inner {
    padding-left: 55px;
    padding-left: 14.67vw;
    padding-top: 22px;
    padding-top: 5.87vw;
    padding-bottom: 22px;
    padding-bottom: 5.87vw;
  }
  .gnav-floor-box-f {
    line-height: 1;
    color: rgba(255, 255, 255, 0.5);
    font-size: 13px;
    font-size: 3.47vw;
    position: absolute;
    left: 10px;
    left: 2.67vw;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .gnav-floor-box-item {
    line-height: 1;
  }
  .gnav-floor-box-item a {
    display: inline-block;
    padding: 10px;
    padding: 2.67vw;
  }
  .gnav-floor-box-item .item-sub {
    font-size: 11px;
    font-size: 2.93vw;
    margin-bottom: 7px;
    margin-bottom: 1.87vw;
  }
  .gnav-floor-box-item .item-ttl {
    font-size: 15px;
    font-size: 4vw;
  }
  .gnav-floor-box.floor-3 .gnav-floor-box-item-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .gnav-floor-box.floor-3 .gnav-floor-box-item {
    width: 50%;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-inner {
    padding-left: 0;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-f {
    top: 46px;
    top: 12.27vw;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-front {
    padding-top: 10px;
    padding-top: 2.67vw;
    padding-left: 65px;
    padding-left: 17.33vw;
    font-size: 15px;
    font-size: 4vw;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-item-wrap {
    letter-spacing: -.4em;
    padding-left: 65px;
    padding-left: 17.33vw;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) {
    border-bottom: 1px dotted rgba(255, 255, 255, 0.2);
    padding-bottom: 35px;
    padding-bottom: 9.33vw;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-item-wrap:nth-of-type(1) .gnav-floor-box-item:nth-child(2) {
    padding-left: 25px;
    padding-left: 6.67vw;
  }
  .gnav-floor-box.floor-2 .gnav-floor-box-item {
    display: inline-block;
    letter-spacing: normal;
    width: 50%;
    margin-top: 35px;
    margin-top: 9.33vw;
  }
  .gnav-floor-box.floor-1 {
    font-size: 16px;
    font-size: 4.27vw;
  }
}

body.js-gnav-open {
  height: 100vh;
  overflow: hidden;
}

body.js-gnav-open #gnav {
  opacity: 1;
  visibility: visible;
}

/* ローカルナビラベル */
.lnav-label.hidden {
  display: none;
}

/* main
   ========================================================================== */
#main {
  margin-bottom: 5.33vw;
  position: relative;
}

@media screen and (max-width: 767px) {
  #main {
    margin-bottom: 80px;
    margin-bottom: 21.33vw;
  }
}

/* Main Header */
.main-head .ttl01-wrap {
  margin-bottom: 0;
  text-align: center;
}

@media screen and (min-width: 768px), print {
  .main-head {
    margin: 2.67vw 0 !important;
  }
  .main-head .ttl01-sub {
    margin-bottom: 0.83vw;
  }
}

@media screen and (max-width: 767px) {
  .main-head {
    margin-top: 30px !important;
    margin-top: 8vw !important;
    margin-bottom: 5px !important;
    margin-bottom: 1.33vw !important;
  }
  .main-head .ttl01-wrap {
    margin-bottom: 0;
  }
  .main-head .ttl01-sub {
    margin-bottom: 7.5px;
    margin-bottom: 2vw;
  }
}

/* Main Visual */
@media screen and (min-width: 768px) and (max-width: 1139px) {
  .main-visual .visual-data [class^="col"]:nth-child(1) {
    width: 100%;
    margin-bottom: 2.67vw;
  }
  .main-visual .visual-data [class^="col"]:nth-child(2) {
    width: 50%;
    padding-right: 2vw;
  }
  .main-visual .visual-data [class^="col"]:nth-child(3) {
    width: 50%;
    padding-left: 2vw;
  }
}

@media screen and (max-width: 767px) {
  .main-visual .box-rds {
    background-color: transparent;
    border-radius: 0;
  }
  .main-visual .visual-data {
    background-color: #f9f9f4;
    border-radius: 4px;
    border-radius: 1.07vw;
  }
}

/* footer
   ========================================================================== */
@media screen and (min-width: 768px), print {
  #foot {
    padding: 0 1.33vw;
  }
}

/* BROWSE OTHER CATEGORIES（ページ下部のローカルナビ） */
.foot-lnav-area {
  position: relative;
}

.foot-lnav-area:before {
  background-color: #e6e6d2;
  content: '';
  display: block;
  height: 1px;
  position: absolute;
  top: 0;
}

.foot-lnav-area.bdr-none {
  padding-top: 0;
}

.foot-lnav-area.bdr-none:before {
  display: none;
}

@media screen and (min-width: 768px), print {
  .foot-lnav-area {
    margin-top: 16vw;
    margin-bottom: 16vw !important;
    padding-top: 16vw;
  }
  .foot-lnav-area:before {
    width: calc(100% - 2.67vw);
    left: 1.33vw;
  }
}

@media screen and (max-width: 767px) {
  .foot-lnav-area {
    margin-top: 80px;
    margin-top: 21.33vw;
    margin-bottom: 80px;
    margin-bottom: 21.33vw;
    padding-top: 80px;
    padding-top: 21.33vw;
    padding-right: 20px;
    padding-right: 5.33vw;
    padding-left: 20px;
    padding-left: 5.33vw;
  }
  .foot-lnav-area:before {
    width: calc(100% - 20px);
    width: calc(100% - 5.34vw);
    left: 10px;
    left: 2.67vw;
  }
}

.foot-lnav-ttl {
  letter-spacing: 0.5em;
  line-height: 1.2;
  margin-bottom: 5.33vw;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .foot-lnav-ttl {
    margin-bottom: 63px;
    margin-bottom: 16.8vw;
  }
}

#foot-lnav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  text-align: center;
  width: 100%;
}

#foot-lnav li {
  border-bottom: 1px solid #e6e6d2;
  border-right: 1px solid #e6e6d2;
  height: 11.38vw;
}

#foot-lnav li:first-child {
  border-left: 1px solid #e6e6d2;
}

@media screen and (min-width: 768px), print {
  #foot-lnav li:nth-last-child(-n+5):first-child,
  #foot-lnav li:nth-last-child(-n+5):first-child ~ li {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  #foot-lnav li:nth-last-child(n+6),
  #foot-lnav li:nth-last-child(n+6) ~ li {
    width: 20%;
  }
}

#foot-lnav li.active,
#foot-lnav li.activeParent {
  position: relative;
}

#foot-lnav li.active:before,
#foot-lnav li.activeParent:before {
  background-color: #b49531;
  content: '';
  display: block;
  height: 0.33vw;
  width: 3.5vw;
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

#foot-lnav li.active .foot-lnav-item-inner,
#foot-lnav li.activeParent .foot-lnav-item-inner {
  background: #fff;
}

#foot-lnav a {
  -webkit-transition: none;
  transition: none;
}

#foot-lnav a[target=_blank] span:after {
  color: #b49531;
  content: "";
  display: inline-block;
  margin-left: 4px;
  position: relative;
  top: 1px;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#foot-lnav a:hover .foot-lnav-item-inner {
  background-color: #fff;
}

#foot-lnav .foot-lnav-item-inner {
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  background-color: #f9f9f4;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  font-size: 15px;
  font-size: 1.5rem;
}

@media screen and (max-width: 767px) {
  #foot-lnav {
    display: block;
  }
  #foot-lnav li {
    border-left: 1px solid #e6e6d2;
    height: auto;
    line-height: 1;
    width: 100%;
  }
  #foot-lnav li.active:before,
  #foot-lnav li.activeParent:before {
    height: 5px;
    height: 1.33vw;
    width: 52.5px;
    width: 14vw;
  }
  #foot-lnav .foot-lnav-item-inner {
    padding-top: 32px;
    padding-top: 8.53vw;
    padding-right: 30px;
    padding-right: 8vw;
    padding-bottom: 28px;
    padding-bottom: 7.47vw;
    padding-left: 30px;
    padding-left: 8vw;
    font-size: 13px;
    font-size: 1.3rem;
  }
}

/* フッター */
#foot {
  position: relative;
}

/* フッターバナー */
.foot-bnr-area {
  margin-bottom: 5.33vw;
}

.foot-bnr-area .grid .col4 {
  margin-bottom: 10px;
  margin-bottom: 2.67vw;
}

.foot-bnr {
  background-color: #f9f9f4;
  border-radius: 0.2vw;
  height: 8vw;
  line-height: 1.2;
  overflow: hidden;
}

.foot-bnr-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  padding: 0 2.27vw;
}

.foot-bnr-icon img {
  width: 100%;
  height: auto;
  -webkit-backface-visibility: hidden;
}

.foot-bnr-ttl {
  color: #b49531;
  font-family: "adobe-garamond-pro", serif;
  font-size: 20px;
  font-size: 2rem;
  margin-bottom: 0.67vw;
}

.foot-bnr-lead {
  font-size: 11px;
  font-size: 1.1rem;
}

.foot-bnr-text {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding-left: 1.33vw;
}

.foot-bnr-online .foot-bnr-icon {
  width: 1.6vw;
}

.foot-bnr-email .foot-bnr-icon {
  width: 2.13vw;
}

.foot-bnr-slh .foot-bnr-icon {
  width: 2.6vw;
}

@media screen and (min-width: 768px), print {
  .foot-bnr {
    height: 91px;
  }
}

@media screen and (max-width: 767px) {
  .foot-bnr {
    height: auto;
    margin-bottom: 12px;
    margin-bottom: 3.2vw;
  }
  .foot-bnr:last-child {
    margin-bottom: 0;
  }
  .foot-bnr-area {
    padding-left: 20px;
    padding-left: 5.33vw;
    padding-right: 20px;
    padding-right: 5.33vw;
    margin-bottom: 80px;
    margin-bottom: 21.33vw;
  }
  .foot-bnr-inner {
    padding-left: 15px;
    padding-left: 4vw;
    padding-right: 15px;
    padding-right: 4vw;
    padding-top: 28px;
    padding-top: 7.47vw;
    padding-bottom: 28px;
    padding-bottom: 7.47vw;
  }
  .foot-bnr-ttl {
    margin-bottom: 5px;
    margin-bottom: 1.33vw;
  }
  .foot-bnr-text {
    padding-left: 14px;
    padding-left: 3.73vw;
  }
  .foot-bnr-icon {
    text-align: center;
  }
  .foot-bnr-online .foot-bnr-icon {
    width: 36px;
    width: 9.6vw;
  }
  .foot-bnr-online .foot-bnr-icon img {
    width: 66.7%;
  }
  .foot-bnr-email .foot-bnr-icon {
    width: 36px;
    width: 9.6vw;
  }
  .foot-bnr-email .foot-bnr-icon img {
    width: 88.9%;
  }
  .foot-bnr-slh .foot-bnr-icon {
    width: 36px;
    width: 9.6vw;
  }
}

/* フッターナビ */
.foot-nav-area {
  border-top: 1px solid #e6e6d2;
  padding: 3.83vw 0 6.83vw;
}

.foot-nav-area-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 0 auto;
  width: 91vw;
}

.foot-nav-box a[target="_blank"]:after {
  display: none;
}

.foot-nav-ttl {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.125;
}

.foot-nav-ttl-sub {
  color: #b49531;
  font-size: 12px;
  font-size: 1.2rem;
}

.foot-nav {
  margin-top: 1.93vw;
}

.foot-nav li {
  font-size: 12px;
  font-size: 1.2rem;
  margin-bottom: 0.17vw;
}

.foot-nav li:last-child {
  margin-bottom: 0;
}

.foot-nav li.active {
  color: #2f2a15 !important;
}

.foot-nav li.activeParent:not(.sp-item) a {
  color: #2f2a15 !important;
}

.foot-nav a,
.foot-nav a:visited {
  color: rgba(90, 81, 41, 0.3);
}

.foot-nav-box:hover .foot-nav a {
  color: #5a5129;
}

.foot-nav-box:hover .foot-nav a:hover {
  color: #2f2a15;
}

.foot-nav-box.active .foot-nav a {
  color: #5a5129;
}

.foot-nav-box.active .foot-nav a:hover {
  color: #b49531;
}

.foot-nav-current.foot-nav a {
  color: #5a5129;
}

.foot-nav-current.foot-nav a:hover {
  color: #b49531;
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .foot-nav-area {
    padding: 5.33vw 0;
  }
  .foot-nav-area-inner {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: 85.33vw;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: -40px;
  }
  .foot-nav-box {
    border-left: 1px solid #e6e6d2;
    margin-bottom: 40px;
    padding-left: 2.67vw;
    padding-top: 5px;
    width: 25%;
  }
  .foot-nav-box:nth-child(4n) {
    border-right: 1px solid #e6e6d2;
  }
}

@media screen and (max-width: 767px) {
  .foot-nav-area {
    background-color: #efede2;
    border-top: none;
    padding-bottom: 0;
    padding-top: 0;
  }
  .foot-nav-area-inner {
    border-bottom: 1px solid #e6e6d2;
    display: block;
  }
  .foot-nav-ttl-wrap {
    border-top: 1px solid #e6e6d2;
    position: relative;
    padding-bottom: 10px;
    padding-bottom: 2.67vw;
    padding-top: 10px;
    padding-top: 2.67vw;
  }
  .foot-nav-ttl-wrap:before, .foot-nav-ttl-wrap:after {
    background-color: #b49531;
    content: '';
    display: block;
    position: absolute;
  }
  .foot-nav-ttl-wrap:before {
    height: 1px;
    height: 0.27vw;
    right: 5px;
    right: 1.33vw;
    top: 33px;
    top: 8.8vw;
    width: 11px;
    width: 2.93vw;
  }
  .foot-nav-ttl-wrap:after {
    -webkit-transition: -webkit-transform .4s;
    transition: -webkit-transform .4s;
    transition: transform .4s;
    transition: transform .4s, -webkit-transform .4s;
    height: 10px;
    height: 2.67vw;
    right: 10px;
    right: 2.67vw;
    top: 29px;
    top: 7.73vw;
    width: 1px;
    width: 0.27vw;
  }
  .foot-nav-ttl-wrap.foot-nav-ttl-open:before {
    display: none;
  }
  .foot-nav-ttl-wrap.foot-nav-ttl-open:after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .foot-nav-ttl-wrap.foot-nav-ttl-open + .foot-nav {
    height: auto;
  }
  .foot-nav-box {
    overflow: hidden;
  }
  .foot-nav-box:first-child .foot-nav-ttl-wrap {
    border-top: none;
  }
  .foot-nav {
    border-top: 1px dotted #e6e6d2;
    display: none;
    margin-bottom: -1px;
    margin-top: 0;
    letter-spacing: -.40em;
  }
  .foot-nav li {
    border-bottom: 1px dotted #e6e6d2;
    line-height: 1.1;
    width: 50%;
    display: inline-block;
    letter-spacing: normal;
    vertical-align: middle;
    vertical-align: top;
  }
  .foot-nav a,
  .foot-nav a:visited {
    color: #5a5129;
  }
  .foot-nav a,
  .foot-nav span {
    display: block;
  }
  .foot-nav span {
    position: relative;
    padding-bottom: 13.5px;
    padding-bottom: 3.6vw;
    padding-top: 16px;
    padding-top: 4.27vw;
  }
  .foot-nav span:after {
    content: "";
    color: #b49531;
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: block;
    position: absolute;
    top: 16.5px;
    top: 4.4vw;
  }
  .foot-nav li:nth-child(odd) span {
    padding-right: 31.5px;
    padding-right: 8.4vw;
  }
  .foot-nav li:nth-child(odd) span:after {
    right: 15px;
    right: 4vw;
  }
  .foot-nav li:nth-child(even) span {
    padding-right: 21.5px;
    padding-right: 5.73vw;
  }
  .foot-nav li:nth-child(even) span:after {
    right: 5px;
    right: 1.33vw;
  }
  .foot-nav-event .foot-nav li {
    width: 100%;
  }
  .foot-nav-event .foot-nav li span {
    padding-right: 21.5px !important;
    padding-right: 5.73vw !important;
  }
  .foot-nav-event .foot-nav li span:after {
    right: 5px;
    right: 1.33vw;
  }
}

/* フッターボトム */
.foot-btm-area {
  border-top: 1px solid #e6e6d2;
  border-bottom: 1px solid #e6e6d2;
  padding: 4.33vw 0;
}

.foot-btm-area-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 0 auto;
  position: relative;
  width: 91vw;
}

.foot-btm-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

.foot-btm-info .foot-btm-logo {
  padding-right: 3.23vw;
  width: 17.77vw;
}

.foot-btm-info .foot-btm-logo img {
  height: auto;
  width: 100%;
}

.foot-btm-info dd {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.625;
}

.foot-btm-share {
  bottom: 0;
  left: 17.77vw;
  position: absolute;
}

.foot-btm-share-ttl {
  font-size: 10px;
  font-size: 1rem;
  position: relative;
}

.foot-btm-share-ttl:after {
  background-color: #e6e6d2;
  content: '';
  display: block;
  height: 1px;
  position: absolute;
  right: 0;
  top: 0.53vw;
  width: 7.8vw;
}

.foot-btm-share-ttl span {
  background-color: #f3f2ea;
  display: inline-block;
  padding-right: 0.8vw;
  position: relative;
}

.foot-btm-share-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.foot-btm-share-list li {
  margin-right: 1.2vw;
}

.foot-btm-share-list li:last-child {
  margin-right: 0;
}

.foot-btm-share-list a {
  display: block;
  outline: none;
  text-decoration: none;
}

.foot-btm-share-list a:before {
  color: #888163;
  display: block;
  font-size: 25px;
  font-size: 2.5rem;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.foot-btm-share-instagram a:before {
  content: "";
}

.foot-btm-share-twitter a:before {
  content: "";
}

.foot-btm-share-facebook a:before {
  content: "";
}

.foot-btm-share-googleplus a:before {
  content: "";
}

.foot-btm-share-tripadvisor a:before {
  content: "";
}

.foot-btm-share-youtube a:before {
  content: "";
  position: relative;
  top: 0.13vw;
  font-size: 20px;
  font-size: 2rem;
}

.foot-btm-utility {
  width: 33.33vw;
  margin-bottom: -1.07vw;
}

.foot-btm-utility li {
  display: inline-block;
  margin-left: 2.67vw;
  width: 8vw;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.5;
  margin-bottom: 1.07vw;
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .foot-btm-area-inner {
    width: 85.33vw;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (max-width: 767px) {
  .foot-btm-area {
    background-color: #efede2;
    border-bottom: none;
    border-top: none;
    padding-bottom: 27px;
    padding-bottom: 7.2vw;
    padding-top: 59px;
    padding-top: 15.73vw;
    padding-right: 20px;
    padding-right: 5.33vw;
    padding-left: 20px;
    padding-left: 5.33vw;
  }
  .foot-btm-area-inner {
    display: block;
    width: 100%;
  }
  .foot-btm-info {
    border-bottom: 1px solid #e6e6d2;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding-bottom: 33px;
    padding-bottom: 8.8vw;
  }
  .foot-btm-info .foot-btm-logo {
    padding-right: 17px;
    padding-right: 4.53vw;
    width: 150px;
    width: 40vw;
  }
  .foot-btm-share {
    left: auto;
    position: relative;
    padding-top: 28px;
    padding-top: 7.47vw;
  }
  .foot-btm-share-ttl:after {
    width: 100%;
    top: 9px;
    top: 2.4vw;
  }
  .foot-btm-share-ttl span {
    background-color: #efede2;
    padding-right: 12px;
    padding-right: 3.2vw;
  }
  .foot-btm-share-list li {
    margin-right: 18px;
    margin-right: 4.8vw;
  }
  .foot-btm-utility {
    border-bottom: 1px solid #e6e6d2;
    -webkit-column-count: inherit;
            column-count: inherit;
    overflow: hidden;
    width: 100%;
    letter-spacing: -.40em;
  }
  .foot-btm-utility li {
    border-bottom: 1px solid #e6e6d2;
    line-height: 1;
    margin-bottom: -1px;
    margin-left: 0;
    width: 50%;
    display: inline-block;
    letter-spacing: normal;
    vertical-align: middle;
    vertical-align: top;
  }
  .foot-btm-utility li:nth-child(3n) {
    margin-bottom: -1px;
  }
  .foot-btm-utility a[target=_blank]:after {
    display: none;
  }
  .foot-btm-utility a[target=_blank] span:after {
    content: "";
  }
  .foot-btm-utility a,
  .foot-btm-utility span {
    display: block;
  }
  .foot-btm-utility span {
    position: relative;
    padding-bottom: 13px;
    padding-bottom: 3.47vw;
    padding-top: 17px;
    padding-top: 4.53vw;
  }
  .foot-btm-utility span:after {
    content: "";
    color: #b49531;
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    display: block;
    position: absolute;
    top: 16.5px;
    top: 4.4vw;
  }
  .foot-btm-utility li:nth-child(odd) span {
    padding-right: 31.5px;
    padding-right: 8.4vw;
  }
  .foot-btm-utility li:nth-child(odd) span:after {
    right: 15px;
    right: 4vw;
  }
  .foot-btm-utility li:nth-child(even) span {
    padding-right: 21.5px;
    padding-right: 5.73vw;
  }
  .foot-btm-utility li:nth-child(even) span:after {
    right: 5px;
    right: 1.33vw;
  }
}

/* コピーライト */
.foot-copyright {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
  padding: 4.67vw 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .foot-copyright {
    background-color: #efede2;
    text-align: left;
    line-height: 2;
    padding-top: 0;
    padding-left: 20px;
    padding-left: 5.33vw;
    padding-right: 20px;
    padding-right: 5.33vw;
  }
}

/* z-index
   ========================================================================== */
#body-overlay {
  z-index: 10000;
}

#head {
  z-index: 1000;
}

.head-top {
  z-index: 200;
}

.head-logo {
  z-index: 11;
}

.head-share {
  z-index: 11;
}

.head-lnav-wrap {
  z-index: 100;
}

#head-cat-wrap {
  z-index: 1000;
}

#head-cnav-wrap {
  z-index: 1000;
}

.foot-btm-share-ttl span {
  z-index: 5;
}

@media screen and (min-width: 768px), print {
  #head.js-fixed .head-page-ttl {
    z-index: 20;
  }
  .head-cat a {
    z-index: 1002;
  }
  .head-cat:before {
    z-index: 1001;
  }
  #gnav {
    z-index: 2000;
  }
}

@media screen and (max-width: 767px) {
  .head-share.js-opened {
    z-index: 20;
  }
  .head-top {
    z-index: 2200;
  }
  .head-top-sp {
    z-index: 2000;
  }
  .head-btm-sp {
    z-index: 2300;
  }
  #gnav {
    z-index: 2100;
  }
  #sp-lnav-wrap {
    z-index: 100;
  }
}

/* ==========================================================================
   04. Parts
   ========================================================================== */
/* box
   ========================================================================== */
/* 左右余白を確保（PC） */
@media screen and (min-width: 768px), print {
  .pc-pdg {
    padding-left: 1.33vw;
    padding-right: 1.33vw;
  }
}

/* 左右余白を確保（SP） */
@media screen and (max-width: 767px) {
  .sp-pdg {
    padding-left: 10px;
    padding-left: 2.67vw;
    padding-right: 10px;
    padding-right: 2.67vw;
  }
}

@media screen and (max-width: 767px) {
  .sp-pdg2x {
    padding-left: 20px;
    padding-left: 5.33vw;
    padding-right: 20px;
    padding-right: 5.33vw;
  }
}

/* メインエリア内の下余白確保用 */
.main-block-l > *:last-child,
.main-block-m > *:last-child,
.main-block-s > *:last-child {
  margin-bottom: 0;
}

.main-block-l > *:after,
.main-block-m > *:after,
.main-block-s > *:after {
  content: '';
  display: block;
  overflow: hidden;
}

.main-block-l > * {
  margin-bottom: 10.67vw;
}

@media screen and (max-width: 767px) {
  .main-block-l > * {
    margin-bottom: 80px;
    margin-bottom: 21.33vw;
  }
}

.main-block-m > * {
  margin-bottom: 5.33vw;
}

@media screen and (max-width: 767px) {
  .main-block-m > * {
    margin-bottom: 80px;
    margin-bottom: 21.33vw;
  }
}

.main-block-s > * {
  margin-bottom: 2.67vw;
}

@media screen and (max-width: 767px) {
  .main-block-s > * {
    margin-bottom: 24px;
    margin-bottom: 6.4vw;
  }
}

/* コンテンツを中央に配置 */
@media screen and (min-width: 768px), print {
  .box-center {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    width: 85.33vw;
    position: relative;
  }
}

@media screen and (max-width: 767px) {
  .box-center {
    position: relative;
  }
}

/* 角丸ボックス */
.box-rds {
  background-color: #f9f9f4;
  border-radius: 0.27vw;
  overflow: hidden;
}

.box-rds-inner {
  padding-top: 3.33vw;
  padding-bottom: 3.33vw;
}

@media screen and (max-width: 767px) {
  .box-rds-inner {
    padding-top: 30px;
    padding-top: 8vw;
    padding-right: 20px;
    padding-right: 5.33vw;
    padding-bottom: 30px;
    padding-bottom: 8vw;
    padding-left: 20px;
    padding-left: 5.33vw;
  }
}

/* 角丸ボックス（小） */
.box-rds-s {
  background-color: #f9f9f4;
  border-radius: 0.27vw;
  overflow: hidden;
  height: 20vw;
}

.box-rds-s-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
}

.box-rds-s-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  line-height: 1;
}

.box-rds-s-text-inner {
  padding-left: 2.1vw;
}

.box-rds-s-text-inner .ttl03-wrap {
  margin-bottom: 0;
}

.box-rds-s-img {
  height: 100%;
  width: 26vw;
  overflow: hidden;
}

.box-rds-s-img img {
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  width: 100%;
  height: 100%;
}

.row .box-rds-s {
  height: 20vw;
}

.row .box-rds-s a {
  display: block;
  height: 100%;
}

.row .box-rds-s-inner {
  display: block;
  height: auto;
}

.row .box-rds-s-text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 100%;
  line-height: 1;
}

.row .box-rds-s-text-inner {
  padding: 1.87vw 2.13vw;
}

.row .box-rds-s-img {
  height: 100%;
  width: 100%;
}

.row .box-rds-s-img img {
  width: 100%;
  height: 100%;
}

/* グリッドに沿わない2カラムボックス ex)ご宴会/宴会プラン */
.sct-fullbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: -2.67vw;
}

.sct-fullbox-set {
  background-color: #f9f9f4;
  margin-top: 2.67vw;
  position: relative;
  width: 48%;
  margin-right: 2%;
}

.sct-fullbox-set:nth-child(2n) {
  margin-left: 2%;
  margin-right: 0;
}

.sct-fullbox-set:after {
  background-color: #b49531;
  content: '';
  display: block;
  height: 2px;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
}

.sct-fullbox-set a:hover .btn04 {
  color: #b49531;
}

.fullbox-set-inner {
  padding: 2.67vw 3.2vw 3.73vw;
}

.fullbox-set-img {
  height: 23.33vw;
  width: 100%;
  background: #e6e6e6;
}

.fullbox-set-ttl {
  margin-bottom: 1.73vw;
  padding: 0;
}

.fullbox-set-ttl.btn04 {
  border: none;
  padding: 0 0 0 1.73vw;
  font-weight: 400;
  line-height: 1.6;
}

.fullbox-set-ttl.btn04 span {
  position: relative;
  font-size: 24px;
  font-size: 2.4rem;
}

.fullbox-set-ttl.btn04 span:before {
  position: absolute;
  left: -1.6vw;
  top: 0.33vw;
  font-size: 16px;
  font-size: 1.6rem;
}

.fullbox-set-tag {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 0.27vw;
}

.fullbox-set-tag li {
  line-height: 1;
  margin-bottom: 0.53vw;
  margin-right: 0.53vw;
}

.fullbox-set-tag li span {
  background-color: #e6e6d2;
  border-radius: 0.8vw;
  color: #5a5129;
  display: inline-block;
  padding: 0.47vw 0.93vw 0.2vw;
}

.fullbox-set-summary {
  color: #5a5129;
}

@media screen and (max-width: 767px) {
  .box-rds {
    border-radius: 4px;
    border-radius: 1.07vw;
  }
  .box-rds-s {
    height: auto;
    text-align: center;
    border-radius: 4px;
    border-radius: 1.07vw;
  }
  .box-rds-s a {
    border-radius: 4px;
    border-radius: 1.07vw;
  }
  .box-rds-s-inner {
    display: block;
  }
  .box-rds-s-text {
    display: block;
  }
  .box-rds-s-text-inner {
    padding-left: 0;
    padding-top: 20px;
    padding-top: 5.33vw;
    padding-bottom: 18px;
    padding-bottom: 4.8vw;
  }
  .box-rds-s-text-inner .ttl03-wrap {
    margin-bottom: 0;
  }
  .box-rds-s-sub {
    font-size: 12px;
    font-size: 3.2vw;
    margin-bottom: 10px;
    margin-bottom: 2.67vw;
  }
  .box-rds-s-ttl {
    font-size: 14px;
    font-size: 3.73vw;
  }
  .box-rds-s-img {
    width: 335px;
    width: 89.33vw;
    height: 205px;
    height: 54.67vw;
  }
  .box-rds-s + .box-rds-s {
    margin-top: 20px;
    margin-top: 5.33vw;
  }
  .row .box-rds-s {
    border-radius: 4px;
    border-radius: 1.07vw;
    height: auto;
    text-align: center;
  }
  .row .box-rds-s-inner {
    display: block;
  }
  .row .box-rds-s-text {
    display: block;
  }
  .row .box-rds-s-text-inner {
    padding-left: 0;
    padding-right: 0;
    padding-top: 20px;
    padding-top: 5.33vw;
    padding-bottom: 18px;
    padding-bottom: 4.8vw;
  }
  .row .box-rds-s-sub {
    font-size: 12px;
    font-size: 3.2vw;
    margin-bottom: 10px;
    margin-bottom: 2.67vw;
  }
  .row .box-rds-s-ttl {
    font-size: 14px;
    font-size: 3.73vw;
  }
  .row .box-rds-s-img {
    width: 335px;
    width: 89.33vw;
    height: 205px;
    height: 54.67vw;
  }
  .row .box-rds-s + .box-rds-s {
    margin-top: 20px;
    margin-top: 5.33vw;
  }
  .sct-fullbox {
    display: block;
    margin-top: 0;
  }
  .sct-fullbox-set {
    margin-top: 40px;
    margin-top: 10.67vw;
    margin-right: 0px;
    margin-right: 0vw;
    margin-bottom: 0px;
    margin-bottom: 0vw;
    margin-left: 0px;
    margin-left: 0vw;
    width: 100%;
  }
  .sct-fullbox-set:nth-child(2n) {
    margin-left: 0px;
    margin-left: 0vw;
  }
  .fullbox-set-inner {
    padding-top: 31px;
    padding-top: 8.27vw;
    padding-right: 20px;
    padding-right: 5.33vw;
    padding-bottom: 44px;
    padding-bottom: 11.73vw;
    padding-left: 20px;
    padding-left: 5.33vw;
  }
  .fullbox-set-img {
    width: 100%;
    height: 211px;
    height: 56.27vw;
  }
  .fullbox-set-ttl {
    padding: 0;
    margin-bottom: 26px;
    margin-bottom: 6.93vw;
  }
  .fullbox-set-ttl.btn04 {
    border: none;
    padding: 0;
    padding-left: 26px;
    padding-left: 6.93vw;
    text-align: left;
  }
  .fullbox-set-ttl.btn04 span {
    font-size: 16px;
    font-size: 1.6rem;
  }
  .fullbox-set-ttl.btn04 span:before {
    left: -20px;
    left: -5.33vw;
    top: 3px;
    top: 0.8vw;
    font-size: 12px;
    font-size: 1.2rem;
  }
  .fullbox-set-tag {
    display: block;
    margin-bottom: 4px;
    margin-bottom: 1.07vw;
    letter-spacing: -.40em;
  }
  .fullbox-set-tag li {
    line-height: 1;
    margin-bottom: 8px;
    margin-bottom: 2.13vw;
    margin-right: 8px;
    margin-right: 2.13vw;
    display: inline-block;
    letter-spacing: normal;
    vertical-align: middle;
  }
  .fullbox-set-tag li span {
    border-radius: 10px;
    border-radius: 2.67vw;
    padding-top: 5px;
    padding-top: 1.33vw;
    padding-right: 14px;
    padding-right: 3.73vw;
    padding-bottom: 3px;
    padding-bottom: 0.8vw;
    padding-left: 14px;
    padding-left: 3.73vw;
  }
  .fullbox-set-summary {
    font-size: 12px;
    font-size: 1.2rem;
  }
}

.visual-data {
  background: #f9f9f4;
  width: 100% !important;
  padding: 0 2.67vw;
}

@media screen and (max-width: 767px) {
  .visual-data {
    padding: 0;
  }
}

/* button
   ========================================================================== */
.btn01, .btn02, .btn03, .btn04 {
  cursor: pointer;
  display: inline-block;
  line-height: 1.2;
  outline: none;
  text-align: center;
  text-decoration: none !important;
  font-weight: 500;
}

.btn01 span, .btn02 span, .btn03 span, .btn04 span {
  font-size: 16px;
  font-size: 1.6rem;
}

.btn01 span:before, .btn02 span:before, .btn03 span:before, .btn04 span:before {
  color: #b49531;
  content: "";
  padding-right: 0.53vw;
  position: relative;
  top: 0.13vw;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media screen and (max-width: 767px) {
  .btn01 span, .btn02 span, .btn03 span, .btn04 span {
    font-size: 14px;
    font-size: 3.73vw;
  }
  .btn01 span:before, .btn02 span:before, .btn03 span:before, .btn04 span:before {
    padding-right: 8px;
    padding-right: 2.13vw;
  }
}

.btn01 span {
  display: inline-block;
  padding: 0.53vw 0.27vw 0.53vw 0;
  position: relative;
  border-bottom: 1px solid #b49531;
}

.btn01 span:after {
  -webkit-transition: -webkit-transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
  transition: -webkit-transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
  transition: transform 0.7s cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 0.7s cubic-bezier(0.19, 1, 0.22, 1);
  background-color: #f3f2ea;
  content: '';
  display: block;
  height: 1px;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: -1px;
  -webkit-transform-origin: right;
          transform-origin: right;
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
}

.btn01:hover span:after {
  background-color: #f3f2ea;
  content: '';
  display: block;
  height: 2px;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: -1px;
  -webkit-transform-origin: left;
          transform-origin: left;
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
}

.btn01[target=_blank]:after {
  display: none;
}

.btn01[target=_blank] span:before {
  content: "";
}

.btn01[href$=".pdf"]:after {
  display: none;
}

.btn01[href$=".pdf"] span:before {
  content: "";
}

.btn01.btn01-back span {
  padding: 0 0 0 0.53vw;
  border-bottom: none;
}

.btn01.btn01-back span:before {
  display: inline-block;
  padding-right: 0;
  padding-left: 0.53vw;
  -webkit-transform: rotateY(-180deg);
          transform: rotateY(-180deg);
}

.btn01.btn01-back span:after {
  display: none;
}

@media screen and (max-width: 767px) {
  .btn01 span {
    padding-top: 12px;
    padding-top: 3.2vw;
    padding-right: 2px;
    padding-right: 0.53vw;
    padding-bottom: 12px;
    padding-bottom: 3.2vw;
  }
}

a:hover .btn01 span:after {
  background-color: #f3f2ea;
  content: '';
  display: block;
  height: 2px;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: -1px;
  -webkit-transform-origin: left;
          transform-origin: left;
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
}

.btn02 {
  border: 2px solid #b49531;
  border-radius: 0.4vw;
  color: #b49531;
  padding: 0.8vw 3.2vw 0.8vw;
  text-align: center;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.btn02 span {
  padding-right: 0.53vw;
}

.btn02[target=_blank]:after {
  display: none;
}

.btn02[target=_blank] span:before {
  content: "";
}

.btn02[href$=".pdf"]:after {
  display: none;
}

.btn02[href$=".pdf"] span:before {
  content: "";
}

.btn02:visited {
  color: #b49531;
}

.btn02:hover {
  color: #f3f2ea;
  background: #b49531;
  -webkit-box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
          box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
  -webkit-transform: translateY(-0.3rem);
          transform: translateY(-0.3rem);
}

.btn02:hover span:before {
  color: #f3f2ea;
}

.btn02:hover span:after {
  color: #f3f2ea;
}

.btn02:active {
  -webkit-transition: all 0.25s ease;
  transition: all 0.25s ease;
  border-color: #947a28;
  background: #9c812a;
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.24);
          box-shadow: 0 0 8px rgba(0, 0, 0, 0.24);
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

@media screen and (max-width: 767px) {
  .btn02 {
    width: 100%;
    border-radius: 6px;
    border-radius: 1.6vw;
    padding: 16px;
    padding: 4.27vw;
  }
  .btn02 span {
    padding-right: 10px;
    padding-right: 2.67vw;
  }
}

.btn03 {
  border: 2px solid #b49531;
  border-radius: 0.4vw;
  color: #f9f9f4;
  padding: 0.8vw 3.2vw 0.8vw;
  text-align: center;
  background: #b49531;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.btn03 span {
  padding-right: 0.53vw;
}

.btn03 span:before {
  color: #f9f9f4;
}

.btn03[target=_blank]:after {
  display: none;
}

.btn03[target=_blank] span:before {
  content: "";
}

.btn03:visited {
  color: #f9f9f4;
}

.btn03:hover {
  color: #8c7426;
  background: #fff;
  -webkit-box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
          box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
  -webkit-transform: translateY(-0.3rem);
          transform: translateY(-0.3rem);
}

.btn03:hover span:before {
  color: #b49531;
}

.btn03:active {
  -webkit-transition: all 0.25s ease;
  transition: all 0.25s ease;
  border-color: #947a28;
  background: whitesmoke;
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.24);
          box-shadow: 0 0 8px rgba(0, 0, 0, 0.24);
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

@media screen and (max-width: 767px) {
  .btn03 {
    width: 100%;
    border-radius: 6px;
    border-radius: 1.6vw;
    padding-top: 16px;
    padding-top: 4.27vw;
    padding-right: 48px;
    padding-right: 12.8vw;
    padding-bottom: 16px;
    padding-bottom: 4.27vw;
    padding-left: 48px;
    padding-left: 12.8vw;
  }
  .btn03 span {
    padding-right: 12px;
    padding-right: 3.2vw;
  }
}

.btn04 {
  border: 1px solid #e6e6d2;
  border-radius: 0.4vw;
  color: #5a5129;
  padding: 0.8vw 2.67vw 0.8vw;
  text-align: left;
  display: block;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.btn04 span {
  padding-right: 0.53vw;
}

.btn04[target=_blank]:after {
  display: none;
}

.btn04[target=_blank] span:before {
  content: "";
}

.btn04:hover {
  border-color: rgba(180, 149, 49, 0.6);
}

@media screen and (max-width: 767px) {
  .btn04 {
    text-align: center;
    width: 100%;
    border-radius: 6px;
    border-radius: 1.6vw;
    padding-top: 16px;
    padding-top: 4.27vw;
    padding-right: 48px;
    padding-right: 12.8vw;
    padding-bottom: 16px;
    padding-bottom: 4.27vw;
    padding-left: 48px;
    padding-left: 12.8vw;
  }
  .btn04 span {
    padding-right: 12px;
    padding-right: 3.2vw;
  }
}

.btn-list {
  letter-spacing: -.4em;
  margin: 5.33vw 0;
  text-align: center;
}

.btn-list li {
  display: inline-block;
  letter-spacing: normal;
  padding: 0 1.07vw;
  width: 40%;
}

.btn-list li .btn01, .btn-list li .btn02, .btn-list li .btn03, .btn-list li .btn04 {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .btn-list {
    margin-top: 80px;
    margin-top: 21.33vw;
    margin-bottom: 80px;
    margin-bottom: 21.33vw;
  }
  .btn-list li {
    display: block;
    padding: 0;
    width: 100%;
    margin-bottom: 10px;
    margin-bottom: 2.67vw;
  }
  .btn-list li:last-child {
    margin-bottom: 0;
  }
}

.sct-reserve .box-center {
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  background-color: #f9f9f4;
  border-radius: 0.27vw;
  padding: 3.33vw 5.33vw 3.53vw;
  text-align: center;
}

.sct-reserve .box-center:hover {
  background: #f9f9f4;
}

.sct-reserve .box-center p {
  letter-spacing: .3em;
  color: #b49531;
  font-size: 12px;
  font-size: 1.2rem;
}

.sct-reserve .box-center strong {
  display: block;
  margin-top: 0.53vw;
  margin-bottom: 1.07vw;
  font-weight: 400;
  line-height: 1.6;
  font-size: 16px;
  font-size: 1.6rem;
}

.sct-reserve .box-center strong.pc-item {
  display: block;
}

.sct-reserve .box-center strong.sp-item {
  display: none;
}

.sct-reserve .box-center a span {
  font-weight: 500;
  font-size: 20px;
  font-size: 2rem;
}

@media screen and (min-width: 768px), print {
  .sct-reserve .box-center a {
    padding: 0.8vw 5.33vw 0.8vw;
  }
}

@media screen and (max-width: 767px) {
  .sct-reserve .box-center {
    background: #f9f9f4;
    border-radius: 4px;
    border-radius: 1.07vw;
    padding: 24px;
    padding: 6.4vw;
    padding-top: 32px;
    padding-top: 8.53vw;
    padding-bottom: 48px;
    padding-bottom: 12.8vw;
  }
  .sct-reserve .box-center p {
    font-size: 11px;
    font-size: 1.1rem;
  }
  .sct-reserve .box-center strong {
    display: block;
    margin-top: 8px;
    margin-top: 2.13vw;
    margin-bottom: 8px;
    margin-bottom: 2.13vw;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .sct-reserve .box-center strong.pc-item {
    display: none;
  }
  .sct-reserve .box-center strong.sp-item {
    display: block;
  }
  .sct-reserve .box-center a span {
    font-weight: 500;
    padding-right: 0;
    font-size: 16px;
    font-size: 1.6rem;
  }
}

/* display
   ========================================================================== */
.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.block {
  display: block;
}

.sp-item {
  display: none;
}

.pc-block {
  display: block;
}

@media screen and (max-width: 767px) {
  .sp-item {
    display: block;
  }
  .pc-item {
    display: none !important;
  }
  .pc-block {
    display: inline;
  }
  .sp-block {
    display: block;
  }
}

/* font
   ========================================================================== */
.font-noto-l {
  font-family: "source-han-serif-japanese";
  font-weight: 200;
}

.font-noto-m {
  font-family: "source-han-serif-japanese";
  font-weight: 500;
}

.font-garamond {
  font-family: "adobe-garamond-pro", serif;
}

.font-shelley {
  font-family: "Shelley Script", serif;
}

/* form
   ========================================================================== */
.tbl-form {
  width: 100%;
}

.tbl-form tr th, .tbl-form tr td {
  padding: 1.33vw 0;
  border-bottom: 1px solid #e6e6d2;
  vertical-align: middle;
}

.tbl-form tr th {
  position: relative;
  width: 25%;
  text-align: left;
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: normal;
  vertical-align: top;
  padding-left: 2vw;
}

.tbl-form tr th:after {
  z-index: 0;
  content: '';
  display: block;
  background: #f9f9f4;
  border: 1px solid #e6e6d2;
  border-radius: 0.13vw;
  height: 0.8vw;
  width: 0.8vw;
  position: absolute;
  top: 1.6vw;
  left: 0;
}

.tbl-form tr th .notes {
  display: block;
  font-size: 10px;
  font-size: 1rem;
  padding-right: 2.67vw;
}

.tbl-form tr th.icon-check:before {
  position: absolute;
  top: 1.4vw;
  left: 0.27vw;
  z-index: 15;
}

.tbl-form tr td {
  width: 75%;
}

.tbl-form tr td .tbl-in {
  width: 100%;
  margin: -1.07vw 0;
}

.tbl-form tr td .tbl-in tr th, .tbl-form tr td .tbl-in tr td {
  padding: 0.53vw 0;
  vertical-align: middle;
  border-bottom: 1px dotted #ddddc2;
}

.tbl-form tr td .tbl-in tr th:after {
  display: none;
}

.tbl-form tr td .tbl-in tr:last-child th, .tbl-form tr td .tbl-in tr:last-child td {
  border-bottom: none;
}

@media screen and (max-width: 767px) {
  .tbl-form {
    margin-top: 48px;
    margin-top: 12.8vw;
    width: 100%;
  }
  .tbl-form tr th, .tbl-form tr td {
    display: block;
    width: 100%;
  }
  .tbl-form tr th {
    border-bottom: none;
    padding-bottom: 0;
    font-size: 13px;
    font-size: 1.3rem;
    padding-top: 16px;
    padding-top: 4.27vw;
    padding-left: 24px;
    padding-left: 6.4vw;
  }
  .tbl-form tr th:after {
    border-radius: 2px;
    border-radius: 0.53vw;
    height: 10px;
    height: 2.67vw;
    width: 10px;
    width: 2.67vw;
    top: 21px;
    top: 5.6vw;
  }
  .tbl-form tr th .notes {
    display: inline-block;
    font-size: 10px;
    font-size: 1rem;
    padding-right: 0;
    margin-left: 8px;
  }
  .tbl-form tr th .notes:before {
    content: '※';
  }
  .tbl-form tr th.icon-check:before {
    top: 19px;
    top: 5.07vw;
    left: 3px;
    left: 0.8vw;
  }
  .tbl-form tr td {
    padding-top: 0;
    padding-bottom: 16px;
    padding-bottom: 4.27vw;
  }
  .tbl-form tr td .tbl-in {
    width: 100%;
    margin-top: 16px;
    margin-top: 4.27vw;
    margin-bottom: 8px;
    margin-bottom: 2.13vw;
  }
  .tbl-form tr td .tbl-in tr th, .tbl-form tr td .tbl-in tr td {
    padding: 0;
    border-bottom: none;
  }
  .tbl-form tr td .tbl-in tr td {
    padding-bottom: 16px;
    padding-bottom: 4.27vw;
  }
  .tbl-form tr td .tbl-in tr:last-child td {
    border-bottom: none;
    padding-bottom: 0;
  }
}

/* 入力項目 */
.tbl-form #privacy-txt {
  margin-bottom: 1.07vw;
}

.tbl-form input + .btn01 {
  margin-left: 1.07vw;
}

.tbl-form .btn01 span {
  font-size: 15px;
  font-size: 1.5rem;
}

.tbl-form input[type="text"],
.tbl-form input[type="email"],
.tbl-form input[type="tel"],
.tbl-form textarea {
  color: #5a5129;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
  vertical-align: middle;
  font-family: "adobe-garamond-pro", "source-han-serif-japanese", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  font-size: 15px;
  font-size: 1.5rem;
  background-color: #fff;
  border: 1px solid #e6e6d2;
  border-radius: 0.27vw;
  padding: 0.53vw 0.8vw 0.4vw;
}

.tbl-form input[type="text"].mini,
.tbl-form input[type="email"].mini,
.tbl-form input[type="tel"].mini,
.tbl-form textarea.mini {
  width: 10%;
}

.tbl-form input[type="text"].full,
.tbl-form input[type="email"].full,
.tbl-form input[type="tel"].full,
.tbl-form textarea.full {
  width: 100%;
}

.tbl-form label {
  font-size: 15px;
  font-size: 1.5rem;
  vertical-align: middle;
}

.tbl-form .drop {
  background: #fff;
  font-family: "adobe-garamond-pro", "source-han-serif-japanese", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  font-size: 15px;
  font-size: 1.5rem;
  padding: 0.27vw;
  border: 1px solid #e6e6d2;
  border-radius: 0.27vw;
}

.tbl-form .drop.mini {
  margin-right: 0.27vw;
}

.tbl-form input[type="text"]:focus,
.tbl-form input[type="email"]:focus,
.tbl-form input[type="tel"]:focus,
.tbl-form textarea:focus {
  outline: none;
  background-color: #f9f9f4;
  border-color: #ccccba;
}

.tbl-form input[type="radio"] {
  vertical-align: baseline;
  margin-right: 0.53vw;
}

.set-btn {
  text-align: center;
  margin-top: 2.67vw;
}

.set-btn .btn02, .set-btn .btn03 {
  font-family: "adobe-garamond-pro", "source-han-serif-japanese", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  font-size: 16px;
  font-size: 1.6rem;
}

.set-btn .btn02 {
  background: #fff;
  margin-right: 1.6vw;
}

.set-btn .form-flow {
  margin-top: 2.67vw;
  text-align: center;
  letter-spacing: -.40em;
}

.set-btn .form-flow li {
  display: inline-block;
  letter-spacing: normal;
  vertical-align: middle;
}

.set-btn .form-flow li:after {
  border-right: 1px solid #b49531;
  border-top: 1px solid #b49531;
  content: '';
  display: inline-block;
  height: 0.33vw;
  width: 0.33vw;
  margin-left: 1.47vw;
  margin-right: 1.47vw;
  position: relative;
  top: -3px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.set-btn .form-flow li.active {
  color: #b49531;
}

.set-btn .form-flow li:last-child:after {
  display: none;
}

@media screen and (max-width: 767px) {
  .tbl-form .btn01 span {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .tbl-form input[type="text"],
  .tbl-form input[type="email"],
  .tbl-form input[type="tel"],
  .tbl-form textarea {
    font-size: 16px;
    font-size: 1.6rem;
    border-radius: 4px;
    border-radius: 1.07vw;
    padding: 8px;
    padding: 2.13vw;
    width: 100%;
  }
  .tbl-form input[type="radio"] {
    vertical-align: middle;
  }
  .tbl-form label {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .tbl-form .drop {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 4px;
    padding: 1.07vw;
    border-radius: 4px;
    border-radius: 1.07vw;
    width: 100%;
  }
  .tbl-form .drop.mini {
    width: auto;
  }
  .set-btn {
    margin-top: 24px;
    margin-top: 6.4vw;
  }
  .set-btn .btn02 {
    display: inline-block;
    width: 40%;
    padding-left: 0px;
    padding-left: 0vw;
    padding-right: 0px;
    padding-right: 0vw;
  }
  .set-btn .btn03 {
    display: inline-block;
    width: 55%;
  }
  .set-btn .form-flow {
    margin-top: 24px;
    margin-top: 6.4vw;
  }
  .set-btn .form-flow li:after {
    border-right: 1px solid #b49531;
    border-top: 1px solid #b49531;
    content: '';
    display: inline-block;
    height: 4px;
    height: 1.07vw;
    width: 4px;
    width: 1.07vw;
    margin-left: 16px;
    margin-left: 4.27vw;
    margin-right: 16px;
    margin-right: 4.27vw;
    top: -2px;
  }
  input[type="button"], input[type="submit"] {
    -webkit-appearance: none;
  }
}

ul.error {
  margin-bottom: 2.67vw;
  background-color: #f9f9f4;
  border: 1px solid #e6e6d2;
  border-radius: 0.27vw;
  padding: 2.67vw 5.33vw;
}

ul.error li a {
  color: #b49531;
}

@media screen and (max-width: 767px) {
  ul.error {
    border-radius: 4px;
    border-radius: 1.07vw;
    padding: 24px;
    padding: 6.4vw;
    margin-top: 40px;
    margin-top: 10.67vw;
  }
}

/* 各フィールドのエラーメッセージ */
span.error {
  color: #b49531;
  display: block;
  margin-top: 0.27vw;
  font-size: 12px;
  font-size: 1.2rem;
}

tr.error input[type="text"],
tr.error input[type="email"],
tr.error input[type="tel"],
tr.error textarea,
tr.error .drop {
  border-color: #b49531;
  background-color: rgba(180, 149, 49, 0.1);
}

#send {
  text-align: center;
  margin-bottom: 5.33vw;
}

#send .btn02 {
  margin-top: 2.67vw;
}

@media screen and (max-width: 767px) {
  #send {
    text-align: left;
    margin-bottom: 40px;
    margin-bottom: 10.67vw;
  }
  #send br {
    display: none;
  }
  #send .btn02 {
    margin-top: 24px;
    margin-top: 6.4vw;
  }
}

#banquet-type {
  margin-bottom: -1.6vw;
}

#banquet-type li {
  width: 33.3333%;
  margin-bottom: 1.6vw;
}

#banquet-type li img {
  width: 4.27vw;
  height: auto;
  display: block;
}

@media screen and (max-width: 767px) {
  #banquet-type {
    margin-bottom: -16px;
    margin-bottom: -4.27vw;
  }
  #banquet-type li {
    width: 33.3333%;
    margin-bottom: 16px;
    margin-bottom: 4.27vw;
  }
  #banquet-type li img {
    width: 64px;
    width: 17.07vw;
  }
}

.event-attention {
  margin-bottom: 2.67vw;
  padding: 1.6vw;
  text-align: center;
  background: #b49531;
  border-radius: 0.27vw;
}

.event-attention p {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 500;
  color: #f3f2ea;
}

/* grid
   ========================================================================== */
@media screen and (min-width: 768px), print {
  .grid .col1 {
    width: 8.3333333333%;
  }
  .grid .col2 {
    width: 16.6666666667%;
  }
  .grid .col3 {
    width: 25%;
  }
  .grid .col4 {
    width: 33.3333333333%;
  }
  .grid .col5 {
    width: 41.6666666667%;
  }
  .grid .col6 {
    width: 50%;
  }
  .grid .col7 {
    width: 58.3333333333%;
  }
  .grid .col8 {
    width: 66.6666666667%;
  }
  .grid .col9 {
    width: 75%;
  }
  .grid .col10 {
    width: 83.3333333333%;
  }
  .grid .col11 {
    width: 91.6666666667%;
  }
  .grid .col12 {
    width: 100%;
  }
  .grid .row1 {
    height: 50%;
  }
}

@media screen and (min-width: 768px), print {
  .grid-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

@media screen and (max-width: 767px) {
  .grid-inner {
    overflow: hidden;
  }
}

/* col margin bottom */
@media screen and (min-width: 768px), print {
  .grid {
    margin-bottom: -5.33vw;
  }
  .grid [class*=" col"],
  .grid [class^="col"] {
    margin-bottom: 5.33vw;
  }
}

@media screen and (max-width: 767px) {
  .grid [class*=" col"],
  .grid [class^="col"] {
    margin-bottom: 48px;
    margin-bottom: 12.8vw;
  }
  .grid [class*=" col"]:last-child,
  .grid [class^="col"]:last-child {
    margin-bottom: 0;
  }
}

.grid.col-mb0 {
  margin-bottom: 0;
}

.grid.col-mb0 [class*=" col"],
.grid.col-mb0 [class^="col"] {
  margin-bottom: 0 !important;
}

/* col margin/padding left/right */
@media screen and (min-width: 768px), print {
  .grid .ml-col1 {
    margin-left: 8.3333333333%;
  }
  .grid .ml-col2 {
    margin-left: 16.6666666667%;
  }
  .grid .ml-col3 {
    margin-left: 25%;
  }
  .grid .ml-col4 {
    margin-left: 33.3333333333%;
  }
  .grid .mr-col1 {
    margin-right: 8.3333333333%;
  }
  .grid .mr-col2 {
    margin-right: 16.6666666667%;
  }
  .grid .mr-col3 {
    margin-right: 25%;
  }
  .grid .mr-col4 {
    margin-right: 33.3333333333%;
  }
  .grid .pl-col1 {
    padding-left: 8.3333333333%;
  }
  .grid .pl-col2 {
    padding-left: 16.6666666667%;
  }
  .grid .pl-col3 {
    padding-left: 25%;
  }
  .grid .pl-col4 {
    padding-left: 33.3333333333%;
  }
  .grid .pr-col1 {
    padding-right: 8.3333333333%;
  }
  .grid .pr-col2 {
    padding-right: 16.6666666667%;
  }
  .grid .pr-col3 {
    padding-right: 25%;
  }
  .grid .pr-col4 {
    padding-right: 33.3333333333%;
  }
}

@media screen and (min-width: 768px), print {
  .box-center .grid .ml-col1, .box-center.grid .ml-col1 {
    margin-left: 7.11vw;
  }
  .box-center .grid .ml-col2, .box-center.grid .ml-col2 {
    margin-left: 14.22vw;
  }
  .box-center .grid .ml-col3, .box-center.grid .ml-col3 {
    margin-left: 21.33vw;
  }
  .box-center .grid .mr-col1, .box-center.grid .mr-col1 {
    margin-right: 7.11vw;
  }
  .box-center .grid .mr-col2, .box-center.grid .mr-col2 {
    margin-right: 14.22vw;
  }
  .box-center .grid .mr-col3, .box-center.grid .mr-col3 {
    margin-right: 21.33vw;
  }
  .box-center .grid .pl-col1, .box-center.grid .pl-col1 {
    padding-left: 7.11vw;
  }
  .box-center .grid .pl-col2, .box-center.grid .pl-col2 {
    padding-left: 14.22vw;
  }
  .box-center .grid .pl-col3, .box-center.grid .pl-col3 {
    padding-left: 21.33vw;
  }
  .box-center .grid .pr-col1, .box-center.grid .pr-col1 {
    padding-right: 7.11vw;
  }
  .box-center .grid .pr-col2, .box-center.grid .pr-col2 {
    padding-right: 14.22vw;
  }
  .box-center .grid .pr-col3, .box-center.grid .pr-col3 {
    padding-right: 21.33vw;
  }
}

/* gutter */
@media screen and (min-width: 768px), print {
  .grid.gutter40 .grid-inner {
    margin-left: -1.33vw;
    margin-right: -1.33vw;
  }
  .grid.gutter40 .grid-inner > * {
    padding-left: 1.33vw;
    padding-right: 1.33vw;
  }
  .grid.gutter80 .grid-inner {
    margin-left: -2.67vw;
    margin-right: -2.67vw;
  }
  .grid.gutter80 .grid-inner > * {
    padding-left: 2.67vw;
    padding-right: 2.67vw;
  }
}

/* icon
   ========================================================================== */
@font-face {
  font-family: 'icomoon';
  font-style: normal;
  font-weight: normal;
  src: url("fonts/icomoon.eot?f7ychr");
  src: url("fonts/icomoon.eot?f7ychr#iefix") format("embedded-opentype"), url("fonts/icomoon.ttf?f7ychr") format("truetype"), url("fonts/icomoon.woff?f7ychr") format("woff"), url("fonts/icomoon.svg?f7ychr#icomoon") format("svg");
}

[class*=" icon-"]:before,
[class^="icon-"]:before {
  color: #b49531;
  display: inline-block;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding-right: 0.53vw;
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  [class*=" icon-"]:before,
  [class^="icon-"]:before {
    padding-right: 6px;
  }
}

.icon-pdf:before {
  content: "";
}

.icon-check:before {
  content: "";
}

.icon-youtube:before {
  content: "";
}

.icon-floor:before {
  content: "";
}

.icon-blank:before {
  content: "";
}

.icon-calendar:before {
  content: "";
}

.icon-category:before {
  content: "";
}

.icon-arr-r:before {
  content: "";
}

.icon-facebook:before {
  content: "";
}

.icon-googleplus:before {
  content: "";
}

.icon-hatena:before {
  content: "";
}

.icon-instagram:before {
  content: "";
}

.icon-line:before {
  content: "";
}

.icon-tripadvisor:before {
  content: "";
}

.icon-twitter:before {
  content: "";
}

/* image
   ========================================================================== */
img.img-full {
  max-width: 100%;
  width: 100%;
  height: auto;
}

img.img-ofi {
  -o-object-fit: cover;
     object-fit: cover;
  font-family: 'object-fit: cover;';
  height: 100%;
  width: 100%;
}

img.js-loaded {
  opacity: 0;
  -webkit-animation: imgFadeIn 1s ease both;
  animation: imgFadeIn 1s ease both;
}

@-webkit-keyframes imgFadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes imgFadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* link
   ========================================================================== */
/* アイコンを表示しない（a要素に付与） */
.no-icon:after {
  display: none !important;
}

/* 新規ウィンドウ */
a[target="_blank"]:after {
  color: #b49531;
  content: "";
  display: inline-block;
  margin-left: 0.33vw;
  position: relative;
  top: 0.13vw;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* MOREボタンを表示するリンク */
@media screen and (min-width: 768px), print {
  .link-more {
    display: block;
    height: 100%;
    position: relative;
  }
  .link-more .more-overlay {
    background-color: rgba(0, 0, 0, 0.5);
    content: '';
    display: block;
    height: 100%;
    width: 100%;
    opacity: 0;
    position: absolute;
    left: 0;
    top: 0;
    -webkit-transition: opacity 0.5s ease;
    transition: opacity 0.5s ease;
  }
  .link-more:hover .more-overlay {
    opacity: 1;
  }
  .link-more:hover .more {
    opacity: 1;
  }
  .link-more .more {
    opacity: 0;
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transition: opacity 0.5s ease;
    transition: opacity 0.5s ease;
    -webkit-transform: translate(-50%, -50%) rotate(0.0001deg);
            transform: translate(-50%, -50%) rotate(0.0001deg);
    width: 9.93vw;
    height: 3.33vw;
  }
  .link-more .more img {
    -webkit-backface-visibility: hidden;
  }
}

@media screen and (max-width: 767px) {
  .link-more .more {
    display: none;
  }
}

/* box-shadowを表示するリンク */
@media screen and (min-width: 768px), print {
  .link-shadow {
    display: block;
    -webkit-transition: background-color 0.5s ease, color 0.5s ease, background-color 0.5s ease, -webkit-box-shadow 0.5s ease, -webkit-transform 0.5s ease;
    transition: background-color 0.5s ease, color 0.5s ease, background-color 0.5s ease, -webkit-box-shadow 0.5s ease, -webkit-transform 0.5s ease;
    transition: background-color 0.5s ease, box-shadow 0.5s ease, color 0.5s ease, transform 0.5s ease, background-color 0.5s ease;
    transition: background-color 0.5s ease, box-shadow 0.5s ease, color 0.5s ease, transform 0.5s ease, background-color 0.5s ease, -webkit-box-shadow 0.5s ease, -webkit-transform 0.5s ease;
    background-color: #f9f9f4;
  }
  .link-shadow:hover {
    background-color: white;
    -webkit-box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
            box-shadow: 0 16px 44px -12px rgba(0, 0, 0, 0.16);
    -webkit-transform: translateY(-0.3rem);
            transform: translateY(-0.3rem);
  }
  .link-shadow:active {
    -webkit-transition: background-color 0.25s ease, color 0.25s ease, background-color 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-transform 0.25s ease;
    transition: background-color 0.25s ease, color 0.25s ease, background-color 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-transform 0.25s ease;
    transition: background-color 0.25s ease, box-shadow 0.25s ease, color 0.25s ease, transform 0.25s ease, background-color 0.25s ease;
    transition: background-color 0.25s ease, box-shadow 0.25s ease, color 0.25s ease, transform 0.25s ease, background-color 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-transform 0.25s ease;
    -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.16);
            box-shadow: 0 0 8px rgba(0, 0, 0, 0.16);
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

/* list
   ========================================================================== */
.list-disc {
  margin-left: 1.5em;
}

.list-disc li {
  list-style-type: disc;
  margin-bottom: 0.53vw;
}

.list-disc li:last-child {
  margin-bottom: 0;
}

.list-decimal {
  margin-left: 1.5em;
}

.list-decimal li {
  list-style-type: decimal;
  margin-bottom: 0.53vw;
}

.list-decimal li:last-child {
  margin-bottom: 0;
}

.list-hyphen li {
  padding-left: 12px;
  position: relative;
  margin-bottom: 0.53vw;
}

.list-hyphen li:last-child {
  margin-bottom: 0;
}

.list-hyphen li:before {
  background-color: #5a5129;
  content: '';
  display: block;
  height: 1px;
  width: 4px;
  position: absolute;
  left: 0;
  top: 0.8vw;
}

@media screen and (max-width: 767px) {
  .list-hyphen li:before {
    top: 10px;
    top: 2.67vw;
  }
}

.list-link {
  border-top: 1px solid #e6e6d2;
  border-bottom: 1px solid #e6e6d2;
}

.list-link li {
  border-bottom: 1px dashed #e6e6d2;
}

.list-link li:last-child {
  border-bottom: none;
}

.list-link a {
  display: block;
  position: relative;
  padding: 1.07vw 7.33vw 0.8vw 2.4vw;
}

.list-link a:before {
  color: #b49531;
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 1.43vw;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.list-link a:hover .link-note:before, .list-link a:hover .link-note:after {
  border-color: rgba(180, 149, 49, 0.7);
}

.list-link a[target=_blank]:after {
  display: none;
}

.list-link .link-note {
  padding: 0 0.33vw;
}

.list-link .link-note:before, .list-link .link-note:after {
  content: '';
  display: inline-block;
  height: 0.4vw;
  width: 0.4vw;
  position: relative;
  top: -0.07vw;
  -webkit-transition: border-color 0.5s ease;
  transition: border-color 0.5s ease;
}

.list-link .link-note:before {
  border-top: 1px solid rgba(90, 81, 41, 0.7);
  border-left: 1px solid rgba(90, 81, 41, 0.7);
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  margin-right: 0.13vw;
}

.list-link .link-note:after {
  border-top: 1px solid rgba(90, 81, 41, 0.7);
  border-right: 1px solid rgba(90, 81, 41, 0.7);
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  margin-left: 0.27vw;
}

.list-link .link-size {
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .list-link a {
    padding: 12px 84px 9px 27px;
  }
  .list-link .link-note {
    padding: 0 4px;
  }
  .list-link .link-note:before, .list-link .link-note:after {
    height: 5px;
    width: 5px;
    top: -1px;
  }
  .list-link .link-note:before {
    margin-right: 1px;
  }
  .list-link .link-note:after {
    margin-left: 3px;
  }
}

@media screen and (max-width: 767px) {
  .list-link a {
    font-size: 12px;
    font-size: 3.2vw;
    padding-top: 16px;
    padding-top: 4.27vw;
    padding-right: 100px;
    padding-right: 26.67vw;
    padding-bottom: 14px;
    padding-bottom: 3.73vw;
    padding-left: 20px;
    padding-left: 5.33vw;
  }
  .list-link a:before {
    top: 21px;
    top: 5.6vw;
  }
  .list-link .link-note {
    display: block;
    padding: 0;
  }
  .list-link .link-note:before, .list-link .link-note:after {
    height: 6px;
    height: 1.6vw;
    width: 6px;
    width: 1.6vw;
    top: -1px;
    top: -0.27vw;
  }
  .list-link .link-note:before {
    margin-right: 2px;
    margin-right: 0.53vw;
  }
  .list-link .link-note:after {
    margin-left: 4px;
    margin-left: 1.07vw;
  }
}

/* notes
   ========================================================================== */
/* 文中に使用する注釈番号 */
.notes {
  font-size: 12px;
  font-size: 1.2rem;
}

@media screen and (max-width: 767px) {
  .notes {
    font-size: 11px;
    font-size: 2.93vw;
  }
}

.notes span {
  color: #b49531;
}

a.notes {
  color: #b49531;
  display: inline-block;
  font-size: 11px;
  font-size: 1.1rem;
  padding: 0 0.27vw;
  text-decoration: underline;
}

/* ページ下部に表示する注釈文 */
.notes-area {
  margin-top: 5.33vw;
  padding: 0 1.33vw;
}

@media screen and (max-width: 767px) {
  .notes-area {
    margin-top: 48px;
    margin-top: 12.8vw;
    margin-right: 10px;
    margin-right: 2.67vw;
    margin-left: 10px;
    margin-left: 2.67vw;
    padding-right: 10px;
    padding-right: 2.67vw;
    padding-left: 10px;
    padding-left: 2.67vw;
  }
}

.notes-inner {
  border-top: 1px solid #e6e6d2;
  padding-top: 5.33vw;
}

@media screen and (max-width: 767px) {
  .notes-inner {
    padding-top: 80px;
    padding-top: 21.33vw;
  }
}

.notes-list {
  margin: -0.4vw 0;
}

.notes-list li {
  font-size: 12px;
  font-size: 1.2rem;
  padding-left: 1.87vw;
  position: relative;
}

.notes-list li span {
  color: #b49531;
  display: inline-block;
  padding-right: 0.47vw;
  position: absolute;
  left: 0;
  top: 0;
}

@media screen and (max-width: 767px) {
  .notes-list {
    margin-top: -5px;
    margin-top: -1.33vw;
    margin-bottom: -5px;
    margin-bottom: -1.33vw;
  }
  .notes-list li {
    font-size: 10px;
    font-size: 2.67vw;
    padding-left: 25px;
    padding-left: 6.67vw;
  }
  .notes-list li span {
    color: #b49531;
    display: inline-block;
    padding-right: 0.47vw;
    position: absolute;
    left: 0;
    top: 0;
  }
}

/* Other
   ========================================================================== */
span.img-wrap {
  display: block;
}

sup {
  font-size: 10px;
  font-size: 1rem;
  position: relative;
  top: -0.2vw;
}

sub {
  font-size: 10px;
  font-size: 1rem;
}

/* 上境界線 */
.bdr-top {
  border-top: 1px solid #e6e6d2;
  padding-top: 6.67vw;
}

@media screen and (max-width: 767px) {
  .bdr-top {
    padding-top: 80px;
    padding-top: 21.33vw;
  }
}

/* 電話番号リンク */
@media screen and (max-width: 767px) {
  .sp-tel-linktext a {
    text-decoration: underline;
  }
}

/* pager
   ========================================================================== */
/* table
   ========================================================================== */
/* テーブル01 */
.tbl01 {
  width: 100%;
}

.tbl01 tr {
  background: url(img/bg_tbl01_row.png) repeat-x left 0.87vw;
  background-size: 4px 1px;
}

.tbl01 th, .tbl01 td {
  font-weight: normal;
  vertical-align: top;
}

.tbl01 th {
  text-align: left;
  font-size: 15px;
  font-size: 1.5rem;
}

.tbl01 .th-inner {
  background-color: #f3f2ea;
  display: inline;
  padding-right: 0.73vw;
}

.tbl01 td {
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 2.2;
  text-align: right;
}

.tbl01 .td-inner {
  background-color: #f3f2ea;
  display: inline;
  padding-left: 0.73vw;
}

@media screen and (min-width: 768px), print {
  .tbl01 .text-l {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

@media screen and (min-width: 768px) and (max-width: 1139px) {
  .tbl01 tr {
    background-position: left 10px;
  }
}

@media screen and (max-width: 767px) {
  .tbl01 tr {
    background-position-y: 13px;
    background-position-y: 3.47vw;
  }
  .tbl01 th, .tbl01 td {
    padding-top: 2px;
    padding-top: 0.53vw;
    padding-bottom: 2px;
    padding-bottom: 0.53vw;
  }
  .tbl01 th {
    font-size: 12px;
    font-size: 3.2vw;
  }
  .tbl01 .th-inner {
    padding-right: 15px;
    padding-right: 4vw;
  }
  .tbl01 td {
    font-size: 12px;
    font-size: 3.2vw;
  }
  .tbl01 .td-inner {
    padding-left: 15px;
    padding-left: 4vw;
  }
}

.box-rds .tbl01 .th-inner,
.box-rds .tbl01 .td-inner {
  background-color: #f9f9f4;
}

/* テーブル02 */
.tbl02 {
  width: 100%;
}

.tbl02 tr {
  background: url(img/bg_tbl01_row.png) repeat-x left 0.87vw;
  background-size: 4px 1px;
}

.tbl02 tr:last-child th, .tbl02 tr:last-child td {
  padding-bottom: 0;
}

.tbl02 th, .tbl02 td {
  font-weight: normal;
  padding-bottom: 1.33vw;
  text-align: left;
  vertical-align: top;
}

.tbl02 th {
  font-size: 14px;
  font-size: 1.4rem;
  width: 16vw;
  padding-right: 5.33vw;
}

.tbl02 .th-inner {
  background-color: #f3f2ea;
  display: inline;
  padding-right: 0.73vw;
}

.tbl02 td {
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 2.2;
}

.tbl02 .td-inner {
  background-color: #f3f2ea;
  display: block;
  padding-left: 0.73vw;
}

@media screen and (min-width: 768px), print {
  .tbl02 .text-l {
    font-size: 15px;
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 767px) {
  .tbl02 tr {
    background-position-y: 13px;
    background-position-y: 3.47vw;
  }
  .tbl02 th, .tbl02 td {
    padding-top: 2px;
    padding-top: 0.53vw;
    padding-bottom: 2px;
    padding-bottom: 0.53vw;
  }
  .tbl02 th {
    font-size: 12px;
    font-size: 3.2vw;
    width: 122px;
    width: 32.53vw;
  }
  .tbl02 .th-inner {
    padding-right: 15px;
    padding-right: 4vw;
  }
  .tbl02 td {
    font-size: 12px;
    font-size: 3.2vw;
  }
  .tbl02 .td-inner {
    padding-left: 15px;
    padding-left: 4vw;
  }
}

/* SP時に横スクロール */
@media screen and (min-width: 768px), print {
  .tbl-scroll-guide {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  .tbl-scroll-wrap {
    overflow-x: auto;
  }
  .tbl-scroll-wrap table {
    min-width: 500px;
    width: 150%;
  }
  .tbl-scroll-wrap::-webkit-scrollbar {
    height: 8px;
  }
  .tbl-scroll-wrap::-webkit-scrollbar-track {
    border-radius: 4px;
    background: #eee;
  }
  .tbl-scroll-wrap::-webkit-scrollbar-thumb {
    border-radius: 4px;
    background: #b49531;
  }
  .tbl-scroll-guide {
    color: #b49531;
    margin-bottom: 10px;
    margin-bottom: 2.67vw;
    text-align: center;
    font-size: 12px;
    font-size: 1.2rem;
  }
}

/* テーブル03 良くある表テーブル*/
.tbl03 {
  width: 100%;
  border-top: 1px solid #e6e6d2;
  border-left: 1px solid #e6e6d2;
}

.tbl03 tr th, .tbl03 tr td {
  vertical-align: middle;
  border-bottom: 1px solid #e6e6d2;
  border-right: 1px solid #e6e6d2;
  padding: 0.67vw 1.07vw 0.53vw 1.07vw;
  line-height: 1.4;
}

.tbl03 tr th {
  border-right-color: #fff;
  border-bottom-color: #fff;
  background: #efefe2;
  font-weight: normal;
}

.tbl03 tr th:last-child {
  border-right-color: #e6e6d2;
}

.tbl03 tr td {
  background: #f9f9f4;
}

@media screen and (max-width: 767px) {
  .tbl03 tr th, .tbl03 tr td {
    padding: 8px;
    padding: 2.13vw;
    padding-top: 10px;
    padding-top: 2.67vw;
  }
}

/* tab
   ========================================================================== */
.tab-btn {
  border-top: 1px solid #e6e6d2;
  border-bottom: 1px solid #e6e6d2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.tab-btn li {
  line-height: 1;
}

.tab-btn li.js-active a {
  color: #b49531;
  pointer-events: none;
}

.tab-btn li.js-active span:before {
  opacity: 1;
}

.tab-btn a {
  display: block;
}

.tab-btn span {
  display: block;
  padding: 1vw 2vw;
  position: relative;
}

.tab-btn span:before {
  background-color: #b49531;
  content: '';
  display: block;
  height: 2px;
  opacity: 0;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: -1px;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
}

.tab-body {
  position: relative;
}

.tab-body-item {
  display: none;
}

.tab-body-item:nth-of-type(1) {
  display: block;
}

@media screen and (max-width: 767px) {
  .tab-btn li {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .tab-btn span {
    width: 100%;
    padding: 12px;
    padding: 3.2vw;
  }
}

/* title
   ========================================================================== */
/* ttl01 */
.ttl01-wrap {
  margin-bottom: 2.67vw;
  line-height: 1.2;
  text-align: center;
}

.ttl01-sub {
  color: #b49531;
  font-family: "adobe-garamond-pro", serif;
  font-size: 12px;
  font-size: 1.2rem;
  letter-spacing: .5em;
  margin-bottom: 1.67vw;
}

.ttl01-lead {
  line-height: 2;
  margin-top: 1.6vw;
}

.ttl01 {
  font-weight: 300;
  font-size: 36px;
  font-size: 3.6rem;
  letter-spacing: .05em;
}

@media screen and (max-width: 767px) {
  .ttl01-wrap {
    margin-bottom: 40px;
    margin-bottom: 10.67vw;
  }
  .ttl01-sub {
    font-size: 12px;
    font-size: 3.2vw;
    margin-bottom: 10px;
    margin-bottom: 2.67vw;
  }
  .ttl01 {
    font-size: 20px;
    font-size: 5.33vw;
  }
  .ttl01-lead {
    line-height: 2;
    margin-top: 36px;
    margin-top: 9.6vw;
  }
}

/* ttl02 */
.ttl02-wrap {
  line-height: 1.1;
  position: relative;
  margin-bottom: 4.27vw;
}

.ttl02-wrap:before {
  background-color: #a6a189;
  content: '';
  display: block;
  height: 1px;
  width: 100vw;
  position: absolute;
  left: -102.67vw;
  top: 1.67vw;
}

.ttl02-sub {
  color: #b49531;
  font-family: "Shelley Script", serif;
  font-size: 52px;
  font-size: 5.2rem;
  margin-bottom: 0.53vw;
}

@media screen and (max-width: 767px) {
  .ttl02-wrap {
    margin-bottom: 32px;
    margin-bottom: 8.53vw;
  }
  .ttl02-wrap:before {
    width: 10px;
    width: 2.67vw;
    left: -20px;
    left: -5.33vw;
    top: 15px;
    top: 4vw;
  }
  .ttl02-sub {
    font-size: 40px;
    font-size: 10.67vw;
    margin-bottom: 8px;
    margin-bottom: 2.13vw;
  }
  .ttl02 {
    font-size: 12px;
    font-size: 3.2vw;
  }
}

/* ttl03 */
.ttl03-wrap {
  line-height: 1;
  margin-bottom: 2.67vw;
}

.ttl03-sub {
  color: #b49531;
  margin-bottom: 9px;
  font-size: 12px;
  font-size: 1.2rem;
}

.ttl03 {
  font-weight: 300;
  font-size: 24px;
  font-size: 2.4rem;
}

.ttl03-s {
  font-size: 16px;
  font-size: 1.6rem;
}

@media screen and (max-width: 767px) {
  .ttl03-wrap {
    margin-bottom: 32px;
    margin-bottom: 8.53vw;
  }
  .ttl03-sub {
    font-size: 12px;
    font-size: 3.2vw;
    margin-bottom: 7.5px;
    margin-bottom: 2vw;
  }
  .ttl03 {
    font-size: 16px;
    font-size: 4.27vw;
  }
  .ttl03-s {
    font-size: 14px;
    font-size: 3.73vw;
  }
}

/* ttl04 */
.ttl04 {
  color: #b49531;
  font-size: 19px;
  font-size: 1.9rem;
  font-weight: 400;
  line-height: 1.6;
  margin-top: 2.13vw;
  margin-bottom: 1.07vw;
}

.ttl04 span {
  font-size: 14px;
  font-size: 1.4rem;
}

@media screen and (max-width: 767px) {
  .ttl04 {
    font-size: 16px;
    font-size: 4.27vw;
    margin-top: 24px;
    margin-top: 6.4vw;
    margin-bottom: 16px;
    margin-bottom: 4.27vw;
  }
}

/* DATA Title */
.ttl-data {
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .ttl-data {
    font-size: 16px;
    font-size: 4.27vw;
    margin-bottom: 15px;
    margin-bottom: 4vw;
  }
}

.note-text {
  margin-top: 0.53vw;
  font-size: 10px;
  font-size: 1rem;
}

/* topicpath
   ========================================================================== */
.topicpath {
  border: 1px solid #e6e6d2;
  padding: 1.33vw 2.2vw;
}

.topicpath li {
  display: inline;
  font-size: 12px;
  font-size: 1.2rem;
  list-style-type: none;
  padding-left: 1.47vw;
}

.topicpath li:before {
  border-right: 1px solid #b49531;
  border-top: 1px solid #b49531;
  content: '';
  display: inline-block;
  height: 0.33vw;
  width: 0.33vw;
  margin-right: 1.47vw;
  position: relative;
  top: -1px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.topicpath li:first-child {
  padding-left: 0;
}

.topicpath li:first-child:before {
  display: none;
}

.topicpath li:last-child a {
  pointer-events: none;
  text-decoration: none;
}

@media screen and (max-width: 767px) {
  .topicpath {
    padding-top: 20px;
    padding-top: 5.33vw;
    padding-right: 32.5px;
    padding-right: 8.67vw;
    padding-bottom: 20px;
    padding-bottom: 5.33vw;
    padding-left: 32.5px;
    padding-left: 8.67vw;
  }
  .topicpath li {
    font-size: 10px;
    font-size: 2.67vw;
    padding-left: 15px;
    padding-left: 4vw;
  }
  .topicpath li:before {
    height: 5px;
    height: 1.33vw;
    width: 5px;
    width: 1.33vw;
    margin-right: 15px;
    margin-right: 4vw;
  }
}

/* ページ上部のパンくず
   ----------------------------------------------------------------------- */
.main-head-topicpath {
  border: none;
  margin-bottom: 12px;
  padding: 12px calc(25px + 1.33vw) 0;
}

@media screen and (max-width: 767px) {
  .main-head-topicpath {
    display: none;
  }
}

/* Article Editor
   ========================================================================== */
.ve {
  line-height: 2;
  margin-top: 2.07vw;
  padding-bottom: 1.83vw;
}

.ve > * {
  margin-bottom: 1.13vw;
}

.ve > *:first-child {
  margin-top: 0;
}

.ve > *:last-child {
  margin-bottom: 0;
}

.ve h2 {
  line-height: 2;
  font-size: 18px;
  font-size: 1.8rem;
}

.ve h3 {
  margin: 1.83vw 0 0.33vw;
  font-size: 16px;
  font-size: 1.6rem;
}

.ve h4 {
  margin: 1.17vw 0 0.17vw;
  font-size: 14px;
  font-size: 1.4rem;
}

.ve h3,
.ve h4 {
  line-height: 1.55;
}

.ve ul li {
  padding-left: 0.67vw;
  position: relative;
}

.ve ul li:before {
  background-color: #b49531;
  border-radius: 2px;
  content: '';
  display: block;
  height: 4px;
  position: absolute;
  left: 0;
  top: 0.67vw;
  width: 4px;
}

.ve .image-wrap {
  display: block;
}

.ve .image-wrap:after {
  content: "";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.ve .image-wrap .img {
  border-radius: 0.27vw;
  margin-bottom: 3.47vw;
  overflow: hidden;
  text-align: center;
}

.ve .image-wrap .img img {
  max-width: 100%;
  height: auto;
  width: 100%;
}

.ve .image-wrap .img-left {
  float: left;
  margin-right: 3.47vw;
}

.ve .image-wrap .img-right {
  float: right;
  margin-left: 3.47vw;
}

.ve .image-wrap .img-left,
.ve .image-wrap .img-right {
  max-width: 80%;
}

.ve .image-wrap .img-center.img-large, .ve .image-wrap .img-center.img-medium, .ve .image-wrap .img-center.img-small {
  margin: 0 auto 1.13vw;
}

.ve .image-wrap .img-center.img-large {
  width: 100%;
}

.ve .image-wrap .img-center.img-medium {
  width: 49.8vw;
}

.ve .image-wrap .img-center.img-small {
  width: 35.57vw;
}

.ve .image-wrap .img-left.img-large,
.ve .image-wrap .img-right.img-large {
  width: 35.57vw;
}

.ve .image-wrap .img-left.img-medium,
.ve .image-wrap .img-right.img-medium {
  width: 28.47vw;
}

.ve .image-wrap .img-left.img-small,
.ve .image-wrap .img-right.img-small {
  width: 21.33vw;
}

.ve .image-wrap.img-center-float .img-center.img-large, .ve .image-wrap.img-center-float .img-center.img-medium, .ve .image-wrap.img-center-float .img-center.img-small {
  margin: 0 auto 1.13vw;
}

.ve .image-wrap.img-center-float .img-center.img-large {
  width: 35.57vw;
}

.ve .image-wrap.img-center-float .img-center.img-medium {
  width: 28.47vw;
}

.ve .image-wrap.img-center-float .img-center.img-small {
  width: 21.33vw;
}

.ve .link-wrap a {
  text-decoration: underline;
}

.ve .link-wrap a:hover {
  text-decoration: none;
}

.ve .movie-wrap {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}

.ve .movie-wrap iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

.ve .table-wrap {
  margin-bottom: 3.87vw;
}

.ve .table-wrap table {
  width: 100%;
}

.ve .table-wrap table th,
.ve .table-wrap table td {
  padding: 0.53vw 2.13vw 0.4vw;
}

.ve .table-wrap table th {
  border-top: 1px solid #ccccba;
  color: #b49531;
  font-weight: normal;
  text-align: left;
}

.ve .table-wrap table td {
  border-top: 1px solid #e6e6d2;
}

.ve .table-wrap table tr:last-child th {
  border-bottom: 1px solid #ccccba;
}

.ve .table-wrap table tr:last-child td {
  border-bottom: 1px solid #e6e6d2;
}

.ve .btn-online {
  border: 2px solid #b49531;
  color: #b49531;
  padding: 0.8vw 2.27vw;
}

.ve .btn-online:hover, .ve .btn-online:visited {
  color: #b49531;
}

.ve .btn-online[target="_blank"]:after {
  display: none;
}

.ve .btn-online[target="_blank"]:before {
  color: #b49531;
  content: "";
  display: inline-block;
  margin-right: 0.8vw;
  position: relative;
  top: 0.13vw;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 16px;
  font-size: 1.6rem;
}

@media screen and (max-width: 767px) {
  .ve {
    margin-top: 25px;
    margin-top: 6.67vw;
    padding-bottom: 60px;
    padding-bottom: 16vw;
  }
  .ve > * + * {
    margin-bottom: 30px;
    margin-bottom: 8vw;
  }
  .ve h2 {
    font-size: 14px;
    font-size: 3.73vw;
    margin-top: 60px;
    margin-top: 16vw;
  }
  .ve h3 {
    font-size: 13px;
    font-size: 3.47vw;
    margin-bottom: 15px;
    margin-bottom: 4vw;
    margin-top: 30px;
    margin-top: 8vw;
  }
  .ve h4 {
    font-size: 12px;
    font-size: 3.2vw;
    margin-bottom: 15px;
    margin-bottom: 4vw;
    margin-top: 30px;
    margin-top: 8vw;
  }
  .ve h5 {
    font-size: 12px;
    font-size: 3.2vw;
    margin-bottom: 15px;
    margin-bottom: 4vw;
    margin-top: 30px;
    margin-top: 8vw;
  }
  .ve p {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .ve ul li {
    position: relative;
    padding-left: 10px;
    padding-left: 2.67vw;
  }
  .ve ul li:before {
    top: 10px;
    top: 2.67vw;
  }
  .ve .image-wrap .img {
    margin-bottom: 30px;
    margin-bottom: 8vw;
    width: 100% !important;
  }
  .ve .image-wrap .img-left {
    float: none;
    margin-right: 0;
  }
  .ve .image-wrap .img-right {
    float: none;
    margin-left: 0;
  }
  .ve .image-wrap .img-left,
  .ve .image-wrap .img-right {
    max-width: none;
  }
  .ve .table-wrap {
    margin-bottom: 29px;
    margin-bottom: 7.73vw;
  }
  .ve .table-wrap table {
    width: 100%;
  }
  .ve .table-wrap table th,
  .ve .table-wrap table td {
    display: block;
    font-size: 12px;
    font-size: 1.2rem;
    padding-top: 8px;
    padding-top: 2.13vw;
    padding-right: 10px;
    padding-right: 2.67vw;
    padding-bottom: 6px;
    padding-bottom: 1.6vw;
    padding-left: 10px;
    padding-left: 2.67vw;
  }
  .ve .table-wrap table tr:last-child th {
    border-bottom: none;
  }
  .ve .table-wrap table tr:last-child td {
    border-bottom: 1px solid #ccccba;
  }
  .ve .btn-online {
    display: block;
    text-align: center;
    font-size: 14px;
    font-size: 1.4rem;
    padding-top: 8px;
    padding-top: 2.13vw;
    padding-right: 10px;
    padding-right: 2.67vw;
    padding-bottom: 8px;
    padding-bottom: 2.13vw;
    padding-left: 10px;
    padding-left: 2.67vw;
  }
  .ve .btn-online[target="_blank"]:after {
    display: none;
  }
  .ve .btn-online[target="_blank"]:before {
    color: #b49531;
    content: "";
    display: inline-block;
    margin-right: 0.8vw;
    position: relative;
    top: 0.13vw;
    font-family: 'icomoon' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 16px;
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 768px), print {
  .ve .ve-btn-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-top: 20px;
    margin-bottom: 20px;
    text-align: center;
  }
  .ve .ve-btn-list li {
    padding-left: 0;
  }
  .ve .ve-btn-list li:before {
    display: none;
  }
  .ve .ve-btn-list li .btn02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    height: 100%;
  }
  .ve .ve-btn-list.-col1 {
    display: block;
  }
  .ve .ve-btn-list.-col1 li {
    display: inline-block !important;
  }
  .ve .ve-btn-list.-col2 {
    width: 66.66%;
    margin-left: auto;
    margin-right: auto;
    padding-right: 30px;
  }
  .ve .ve-btn-list.-col2 li {
    margin-right: 30px;
    margin-top: 20px;
    width: 50%;
  }
  .ve .ve-btn-list.-col2 li:nth-child(-n+2) {
    margin-top: 0;
  }
  .ve .ve-btn-list.-col2 li:nth-child(2n) {
    margin-right: -30px;
  }
  .ve .ve-btn-list.-col2 li .btn02 {
    padding: 0.8vw;
  }
  .ve .ve-btn-list.-col3 {
    padding-right: 60px;
  }
  .ve .ve-btn-list.-col3 li {
    margin-top: 20px;
    margin-right: 30px;
    width: 33.33%;
  }
  .ve .ve-btn-list.-col3 li:nth-child(-n+3) {
    margin-top: 0;
  }
  .ve .ve-btn-list.-col3 li:nth-child(3n) {
    margin-right: -60px;
  }
  .ve .ve-btn-list.-col3 li .btn02 {
    padding: 0.8vw;
  }
}

@media screen and (max-width: 767px) {
  .ve .ve-btn-list {
    margin-top: 30px;
    margin-top: 8vw;
    margin-bottom: 30px;
    margin-bottom: 8vw;
  }
  .ve .ve-btn-list li {
    padding-left: 0;
    margin-bottom: 15px;
    margin-bottom: 4vw;
  }
  .ve .ve-btn-list li:last-child {
    margin-bottom: 0;
  }
  .ve .ve-btn-list li:before {
    display: none;
  }
}

/* ==========================================================================
   05. Project
   ========================================================================== */
/* NEWS
   ========================================================================== */
.sct-news {
  margin: 10.67vw 0;
}

.sct-news .ttl01-sub {
  letter-spacing: .2em;
  font-size: 32px;
  font-size: 3.2rem;
}

.sct-news .ttl01 {
  font-size: 14px;
  font-size: 1.4rem;
}

@media screen and (max-width: 767px) {
  .sct-news {
    margin-top: 80px;
    margin-top: 21.33vw;
    margin-bottom: 80px;
    margin-bottom: 21.33vw;
  }
  .sct-news .ttl01-wrap {
    margin-bottom: 40px;
    margin-bottom: 10.67vw;
  }
  .sct-news .ttl01-sub {
    margin-bottom: 16px;
    margin-bottom: 4.27vw;
    font-size: 20px;
    font-size: 2rem;
  }
  .sct-news .ttl01 {
    font-size: 12px;
    font-size: 1.2rem;
  }
}

/* 一覧 */
.news-list li {
  border-bottom: 1px dashed #e6e6d2;
}

.news-list li:last-child {
  border-bottom: none;
}

.news-list a {
  display: block;
  position: relative;
}

.news-list a:after {
  color: #b49531;
  content: "";
  display: block;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: absolute;
  top: 50%;
  right: 2.53vw;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.news-list a[target=_blank]:after {
  content: "";
}

.news-list .news-item-inner {
  padding: 1.07vw 6vw 0.8vw 12vw;
  position: relative;
}

.news-list .news-date {
  color: #b49531;
  display: inline-block;
  letter-spacing: .13em;
  line-height: 1.2;
  position: absolute;
  left: 2.67vw;
  top: 1.33vw;
  font-size: 16px;
  font-size: 1.6rem;
}

.news-list .news-cat {
  background-color: #f9f9f4;
  border-radius: 0.27vw;
  color: #5a5129;
  display: inline-block;
  line-height: 1.2;
  padding: 0.4vw 0.13vw 0.13vw;
  position: absolute;
  left: 10.4vw;
  top: 1.73vw;
  width: 7.67vw;
  text-align: center;
  font-size: 13px;
  font-size: 1.3rem;
}

.news-list .news-ttl {
  display: block;
  font-size: 14px;
  font-size: 1.4rem;
}

.news-list.no-result {
  text-align: center;
}

.news-list.no-result .news-item-inner {
  padding: 1.6vw 6vw;
}

@media screen and (max-width: 767px) {
  .news-list .news-item-inner {
    padding-top: 20px;
    padding-top: 5.33vw;
    padding-bottom: 20px;
    padding-bottom: 5.33vw;
    padding-right: 30px;
    padding-right: 8vw;
    padding-left: 0;
  }
  .news-list .news-date {
    position: static;
    margin-right: 16px;
    margin-right: 4.27vw;
    top: 23px;
    top: 6.13vw;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .news-list .news-cat {
    position: static;
    padding: 2px;
    padding: 0.53vw;
    padding-top: 4px;
    padding-top: 1.07vw;
    top: 13px;
    top: 3.47vw;
    left: 100px;
    left: 26.67vw;
    width: 85px;
    width: 22.67vw;
    font-size: 11px;
    font-size: 1.1rem;
  }
  .news-list .news-ttl {
    font-size: 12px;
    font-size: 1.2rem;
  }
}

/**
 * イベント（共通のスライドショー設定）
 * 一覧、詳細のスタイルは /event/css/style.scss で設定
 *
 */
/* イベント一覧　リスト
   ========================================================================== */
.sct-event {
  margin: 10.67vw 0;
}

.sct-event .ttl01-wrap {
  margin-bottom: 3.2vw;
}

.sct-event .ttl01-sub {
  letter-spacing: .3em;
  margin-bottom: 1.07vw;
  position: relative;
  left: .15em;
  font-size: 32px;
  font-size: 3.2rem;
}

.sct-event .ttl01 {
  font-size: 14px;
  font-size: 1.4rem;
}

@media screen and (max-width: 767px) {
  .sct-event {
    margin-top: 80px;
    margin-top: 21.33vw;
    margin-bottom: 80px;
    margin-bottom: 21.33vw;
  }
  .sct-event .ttl01-wrap {
    margin-bottom: 40px;
    margin-bottom: 10.67vw;
  }
  .sct-event .ttl01-sub {
    margin-bottom: 16px;
    margin-bottom: 4.27vw;
    font-size: 20px;
    font-size: 2rem;
  }
  .sct-event .ttl01 {
    font-size: 12px;
    font-size: 1.2rem;
  }
}

.event-slider-list .btn01 span {
  border-bottom: none;
}

.draggable {
  cursor: -webkit-grab;
  cursor: grab;
}

.draggable:active {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}

.event-list-wrap.js-slide-list {
  padding-left: 0;
  width: 200%;
}

.event-list-wrap .slick-list {
  padding-left: 2.8vw;
}

#event-slide-arrows {
  background: none;
  border: 1px solid #e6e6d2;
  padding: 0.47vw 2.67vw;
  position: relative;
}

#event-slide-arrows .btn01 span:after {
  display: none;
}

#event-slide-arrows button {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  border: none;
  outline: none;
}

#event-slide-arrows .slick-prev,
#event-slide-arrows .slick-next {
  background: none;
  cursor: pointer;
  font-weight: normal;
  padding: 0;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  font-size: 16px;
  font-size: 1.6rem;
}

#event-slide-arrows .slick-prev:before,
#event-slide-arrows .slick-next:before {
  color: #b49531;
  content: "";
  display: inline-block;
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding: 0;
}

#event-slide-arrows .slick-prev.slick-disabled,
#event-slide-arrows .slick-next.slick-disabled {
  cursor: auto;
}

#event-slide-arrows .slick-prev.slick-disabled:before,
#event-slide-arrows .slick-next.slick-disabled:before {
  color: #ccccba;
}

#event-slide-arrows .slick-prev:before {
  -webkit-transform: rotateY(-180deg);
          transform: rotateY(-180deg);
}

#event-slide-arrows .slick-prev {
  right: 5vw;
}

#event-slide-arrows .slick-next {
  right: 2.67vw;
}

.event-list-wrap {
  padding-left: 0.33vw;
}

.event-list-col {
  margin-bottom: 3.87vw;
  margin-left: 2.8vw;
}

.event-list-col .event-list-img {
  overflow: hidden;
}

.event-list-col .event-list-img img {
  height: 100%;
  width: 100%;
}

.event-list-large {
  text-align: center;
  width: 34.67vw;
}

.event-list-large .event-list-img {
  height: 35.67vw;
  width: 34.67vw;
}

.event-list-small {
  width: 15.93vw;
}

.event-list-small .event-list-img {
  height: 16.33vw;
  width: 15.93vw;
}

.event-list-small .event-list-set {
  margin-bottom: 3.87vw;
}

.event-list-small .event-list-set:last-child {
  margin-bottom: 0;
}

.event-tag {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: -0.6vw;
}

.event-tag li {
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
  margin-bottom: 0.6vw;
}

.event-tag li:after {
  content: '/';
  display: inline-block;
  margin: 0 0.53vw;
}

.event-tag li:last-child {
  margin-right: 0;
}

.event-tag li:last-child:after {
  display: none;
}

.event-tag span {
  position: relative;
}

.event-tag span:after {
  background-color: rgba(180, 149, 49, 0.8);
  bottom: 0;
  content: '';
  display: block;
  height: 1px;
  position: absolute;
  left: 0;
  width: 100%;
}

.event-list-large .event-tag {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 2vw;
}

.event-list-small .event-tag {
  margin-top: 1.33vw;
}

.event-list-date {
  color: #b49531;
  line-height: 1;
}

.event-list-large .event-list-img {
  margin-bottom: 4.4vw;
}

.event-list-large .event-list-date {
  font-size: 23px;
  font-size: 2.3rem;
}

.event-list-large .event-list-date span {
  font-size: 15px;
  font-size: 1.5rem;
}

.event-list-small .event-list-img {
  margin-bottom: 1.93vw;
}

.event-list-small .event-list-date {
  font-size: 14px;
  font-size: 1.4rem;
}

.event-list-small .event-list-date span {
  font-size: 10px;
  font-size: 1rem;
}

.event-list-ttl {
  line-height: 1.8;
}

.event-list-large .event-list-ttl {
  font-size: 24px;
  font-size: 2.4rem;
  margin: 1.33vw 2.13vw 0;
}

.event-list-small .event-list-ttl {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 0.53vw;
}

.event-list-large .event-list-lead {
  margin-top: 0.93vw;
}

@media screen and (max-width: 767px) {
  .event {
    margin-top: 80px;
    margin-top: 21.33vw;
    padding-top: 77px;
    padding-top: 20.53vw;
    padding-bottom: 82px;
    padding-bottom: 21.87vw;
  }
  .sct-event {
    overflow: hidden;
  }
  #event-slide-arrows {
    text-align: center;
    padding: 0;
    margin-left: 20px;
    margin-left: 5.33vw;
    margin-right: 20px;
    margin-right: 5.33vw;
  }
  .event-slider-list {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .event-slider-list a {
    display: block;
    padding-top: 5px;
    padding-top: 1.33vw;
    padding-bottom: 5px;
    padding-bottom: 1.33vw;
  }
  .event-list-wrap.js-slide-list {
    padding-left: 0;
    width: 100%;
  }
  .event-list-wrap .slick-list {
    padding-left: 0;
  }
  .slick-track {
    position: relative;
    margin-left: 30px;
    margin-left: 8vw;
  }
  .event-list-wrap {
    padding-left: 0;
  }
  .event-list-col {
    margin-left: 0;
    margin-bottom: 40px;
    margin-bottom: 10.67vw;
    padding-right: 10px;
    padding-right: 2.67vw;
  }
  .event-list-large {
    width: auto;
  }
  .event-list-large .event-list-set {
    margin-right: 0;
    display: inline-block;
    letter-spacing: normal;
    vertical-align: middle;
    vertical-align: top;
    width: 152px;
    width: 40.53vw;
  }
  .event-list-large .event-list-img {
    height: 152px;
    height: 40.53vw;
    width: 152px;
    width: 40.53vw;
  }
  .event-list-small {
    width: auto;
    letter-spacing: -.40em;
  }
  .event-list-small .event-list-set {
    height: auto !important;
    display: inline-block;
    letter-spacing: normal;
    vertical-align: middle;
    vertical-align: top;
    margin-right: 10px;
    margin-right: 2.67vw;
    width: 152px;
    width: 40.53vw;
  }
  .event-list-small .event-list-set:nth-child(2n) {
    margin-right: 0;
  }
  .event-list-small .event-list-img {
    height: 152px;
    height: 40.53vw;
    width: 152px;
    width: 40.53vw;
  }
  .event-list-small .event-list-set {
    margin-bottom: 0;
  }
  .event-list-small .event-list-set:last-child {
    margin-bottom: 0;
  }
  .event-tag li {
    margin-bottom: 10px;
    margin-bottom: 2.67vw;
  }
  .event-list-large .event-tag {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    margin-top: 18px;
    margin-top: 4.8vw;
  }
  .event-list-large .event-tag li {
    font-size: 12px;
    font-size: 1.2rem;
    margin-right: 7px;
    margin-right: 1.87vw;
  }
  .event-list-small .event-tag {
    margin-top: 18px;
    margin-top: 4.8vw;
  }
  .event-list-small .event-tag li {
    font-size: 12px;
    font-size: 1.2rem;
    margin-right: 7px;
    margin-right: 1.87vw;
  }
  .event-list-large .event-list-img {
    margin-bottom: 34px;
    margin-bottom: 9.07vw;
  }
  .event-list-large .event-list-date {
    text-align: left;
    font-size: 12px;
    font-size: 1.2rem;
  }
  .event-list-large .event-list-date span {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .event-list-small .event-list-img {
    margin-bottom: 34px;
    margin-bottom: 9.07vw;
  }
  .event-list-small .event-list-date {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .event-list-ttl {
    padding-right: 5px;
    padding-right: 1.33vw;
  }
  .event-list-large .event-list-ttl {
    font-size: 16px;
    font-size: 1.6rem;
    text-align: left;
    margin-top: 8px;
    margin-top: 2.13vw;
    margin-left: 0px;
    margin-left: 0vw;
    margin-right: 0px;
    margin-right: 0vw;
  }
  .event-list-small .event-list-ttl {
    font-size: 12px;
    font-size: 1.2rem;
    margin-top: 7px;
    margin-top: 1.87vw;
  }
  .event-list-large .event-list-lead {
    margin-top: 0.93vw;
  }
  .draggable .event-list-large .event-list-ttl {
    font-size: 12px;
    font-size: 1.2rem;
  }
}

/* カレンダースタイル
   ========================================================================== */
.event-day-cal-head {
  margin-bottom: 0.67vw;
  position: relative;
}

.event-day-cal-wrap {
  margin: 0 auto;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
}

.event-day-ttl {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  line-height: 1;
  position: relative;
  font-size: 16px;
  font-size: 1.6rem;
}

.event-day-ttl .event-day-ttl-month {
  display: block;
  left: 0;
  top: 0;
}

.event-day-ttl-month {
  color: #b49531;
  padding-right: 0.67vw;
  font-size: 40px;
  font-size: 4rem;
}

.event-day-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  right: 0;
  bottom: 0;
}

.event-day-nav .btn01 span:before {
  display: block;
  padding-right: 0;
  position: absolute;
  top: 0.2vw;
}

.event-day-nav .btn01 span:after {
  display: none;
}

.event-day-nav .btn-prev.btn01 span {
  border-bottom: none;
}

.event-day-nav .btn-prev.btn01 span:before {
  left: 0;
  -webkit-transform: rotate(-180deg);
          transform: rotate(-180deg);
}

.event-day-nav .btn-next.btn01 span {
  border-bottom: none;
}

.event-day-nav .btn-next.btn01 span:before {
  right: 0;
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}

.event-day-nav-prev {
  text-align: right;
}

.event-day-nav-prev span {
  padding-left: 1.6vw;
}

.event-day-nav-current {
  text-align: center;
}

.event-day-next span {
  padding-right: 1.6vw;
}

.event-header-cal {
  border-right: 1px solid #e6e6d2;
  border-bottom: 1px solid #e6e6d2;
  width: 100%;
}

.event-header-cal th {
  color: #b49531;
}

.event-header-cal th,
.event-header-cal td {
  border-left: 1px solid #e6e6d2;
  border-top: 1px solid #e6e6d2;
}

.event-header-cal td span {
  display: block;
  padding: 1vw 1.33vw;
  text-align: right;
}

.event-header-cal .sat span {
  background-color: #f2f7fa;
}

.event-header-cal .sun span {
  background-color: #faf3f2;
}

.event-header-cal .holiday span {
  background-color: #faf3f2;
}

.event-header-cal .today span {
  background-color: #fbf7dc;
}

.sct-inquiry .inquiry-inner {
  border-bottom: 1px solid #e6e6d2;
  border-top: 1px solid #ccccba;
  padding: 4vw 0;
}

.sct-inquiry .inquiry-btn {
  margin-top: 0.67vw;
  text-align: right;
}

@media screen and (max-width: 767px) {
  .sct-inquiry .inquiry-inner {
    padding-top: 24px;
    padding-top: 6.4vw;
    padding-bottom: 24px;
    padding-bottom: 6.4vw;
  }
  .sct-inquiry .inquiry-inner .grid > :nth-child(2) {
    margin-bottom: 8px;
    margin-bottom: 2.13vw;
  }
  .sct-inquiry .inquiry-btn {
    margin-top: 16px;
    margin-top: 4.27vw;
  }
}

/*# sourceMappingURL=common.css.map */
