@charset 'utf-8';
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-weight: inherit;
  font-style: inherit;
  font-family: inherit;
  font-size: 100%;
  vertical-align: baseline;
}
body {
  line-height: 1;
  color: #000;
  background: #fff;
}
ol,
ul {
  list-style: none;
}
table {
  border-collapse: separate;
  border-spacing: 0;
  vertical-align: middle;
}
caption,
th,
td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}
a img {
  border: none;
}
body {
  font-family: "游明朝", YuMincho, serif;
  -webkit-font-smoothing: antialiased;
  -webkit-overflow-scrolling: touch;
  color: #454545;
  padding-left: 4em;
  -webkit-tap-highlight-color: transparent;
  min-width: 1000px;
}
@media screen and (max-width: 767px) {
  body {
    padding: 4em 0 0;
    min-width: 0;
  }
}
* {
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media all and (-ms-high-contrast: none) {
  .preload * {
    -webkit-transition: none !important;
    -moz-transition: none !important;
    -o-transition: none !important;
    -ms-transition: none !important;
    transition: none !important;
  }
}
@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}
.hidden {
  display: none !important;
}
img {
  vertical-align: bottom;
}
@media screen and (max-width: 767px) {
  img {
    width: 100%;
  }
}
button,
.button {
  display: block;
  outline: none;
  border: none;
  color: inherit;
  background-color: transparent;
  padding: 0;
  line-height: 1;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
button.theme-1,
.button.theme-1 {
  width: 17.5em;
  margin: 0 auto;
  text-decoration: none;
  color: #fff;
  padding: 1.25em;
  background-image: url("../img/_common/arrow-chevron-right-white.png");
  -webkit-background-size: auto 40%;
  -moz-background-size: auto 40%;
  background-size: auto 40%;
  background-position: right 1em center;
}
@media screen and (max-width: 767px) {
  button.theme-1,
  .button.theme-1 {
    width: auto;
    margin: 0 1.5em;
  }
}
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  border: none;
}
div,
p,
section,
ul,
li,
header,
footer,
main,
img,
a,
span,
button,
input,
select {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
a {
  cursor: pointer;
  color: inherit;
  text-decoration: underline;
  -webkit-transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  -moz-transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  -o-transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  -ms-transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-tap-highlight-color: rgba(0,0,0,0.133);
}
a:hover {
  opacity: 0.8;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
  filter: alpha(opacity=80);
}
@media screen and (max-width: 767px) {
  a:hover {
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
}
.flex-wrap {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .flex-wrap {
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -o-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
.flex-wrap.wrap {
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -o-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.flex-wrap.center {
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -o-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
}
.flex-wrap.stretch {
  -webkit-box-align: stretch;
  -moz-box-align: stretch;
  -o-box-align: stretch;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
}
.flex-wrap.space-between {
  -webkit-box-pack: justify;
  -moz-box-pack: justify;
  -o-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.flex-wrap.space-around {
  -webkit-box-pack: distribute;
  -moz-box-pack: distribute;
  -o-box-pack: distribute;
  -ms-flex-pack: distribute;
  -webkit-justify-content: space-around;
  justify-content: space-around;
}
.flex-wrap.flex-start {
  -webkit-box-align: start;
  -moz-box-align: start;
  -o-box-align: start;
  -ms-flex-align: start;
  -webkit-align-items: flex-start;
  align-items: flex-start;
}
.flex-wrap.flex-end {
  -webkit-box-align: end;
  -moz-box-align: end;
  -o-box-align: end;
  -ms-flex-align: end;
  -webkit-align-items: flex-end;
  align-items: flex-end;
}
.inner-wrap {
  width: 1000px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .inner-wrap {
    width: auto;
    padding: 0 1.5em;
  }
}
.washi,
.page-name,
#enkai_hoji-page .panel,
#restaurant-page .panel,
#stay-page .panel,
#wedding-page .panel,
#wedding-page #section-1 .plan-container,
#wedding-page #section-1 .plan-container .container-title,
#wedding-page #section-1 .plan-container .plan,
#wedding-page #sub-section-1-1 .panel,
#wedding-page .meals .price-name {
  background-image: url("../img/_common/bg-washi.png");
}
#navigator {
  position: fixed;
  height: 100%;
  background-color: #2b2b2b;
  -webkit-transition: all 0.75s cubic-bezier(0.19, 1, 0.22, 1);
  -moz-transition: all 0.75s cubic-bezier(0.19, 1, 0.22, 1);
  -o-transition: all 0.75s cubic-bezier(0.19, 1, 0.22, 1);
  -ms-transition: all 0.75s cubic-bezier(0.19, 1, 0.22, 1);
  transition: all 0.75s cubic-bezier(0.19, 1, 0.22, 1);
  top: 0;
  left: 0;
  -webkit-transform: translateX(-20em);
  -moz-transform: translateX(-20em);
  -o-transform: translateX(-20em);
  -ms-transform: translateX(-20em);
  transform: translateX(-20em);
  z-index: 20;
  -webkit-background-size: auto;
  -moz-background-size: auto;
  background-size: auto;
  background-repeat: repeat-x;
}
@media screen and (max-width: 767px) {
  #navigator {
    height: auto;
    width: 100%;
    -webkit-transform: none;
    -moz-transform: none;
    -o-transform: none;
    -ms-transform: none;
    transform: none;
    -webkit-transition: none;
    -moz-transition: none;
    -o-transition: none;
    -ms-transition: none;
    transition: none;
  }
}
#navigator.selected {
  -webkit-transform: translateX(0);
  -moz-transform: translateX(0);
  -o-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
}
@media screen and (max-width: 767px) {
  #navigator.selected {
    -webkit-transform: none;
    -moz-transform: none;
    -o-transform: none;
    -ms-transform: none;
    transform: none;
  }
  #navigator.selected ul.nav-items {
    visibility: visible;
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
}
#navigator.selected #menu-button .open {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}
#navigator.selected #menu-button .close {
  opacity: 1;
  -ms-filter: none;
  filter: none;
}
#navigator .interface {
  width: 4em;
  padding: 1em 0.25em 0;
}
@media screen and (max-width: 767px) {
  #navigator .interface {
    width: 100%;
    -webkit-box-ordinal-group: 1;
    -moz-box-ordinal-group: 1;
    -o-box-ordinal-group: 1;
    -ms-flex-order: 1;
    -webkit-order: 1;
    order: 1;
    -webkit-box-pack: justify;
    -moz-box-pack: justify;
    -o-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    height: 4em;
    padding: 0 1em;
  }
}
#navigator ul.nav-items {
  width: 20em;
  padding-top: 4em;
  padding-right: 4em;
  -webkit-transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -moz-transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -o-transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -ms-transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
@media screen and (max-width: 767px) {
  #navigator ul.nav-items {
    position: absolute;
    top: 4em;
    -webkit-box-ordinal-group: 2;
    -moz-box-ordinal-group: 2;
    -o-box-ordinal-group: 2;
    -ms-flex-order: 2;
    -webkit-order: 2;
    order: 2;
    padding: 6.5em 5em 0;
    width: 100%;
    height: 100vh;
    background-image: url("../img/_common/bg-nav.png");
    background-color: #2b2b2b;
    visibility: hidden;
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    filter: alpha(opacity=0);
  }
}
#navigator ul.nav-items li {
  border-bottom: 1px solid #d4b41d;
}
@media screen and (max-width: 767px) {
  #navigator ul.nav-items li {
    width: 100%;
  }
}
#navigator ul.nav-items li:last-child {
  border-bottom: none;
}
#navigator ul.nav-items a {
  color: #d4b41d;
  text-decoration: none;
  display: block;
  padding: 0.625em 0.25em 0.625em 3em;
  text-align: right;
  font-size: 1.5em;
}
@media screen and (max-width: 767px) {
  #navigator ul.nav-items a {
    padding: 0.875em 0;
    text-align: center;
    font-size: 1.625em;
  }
}
#navigator #menu-button {
  position: relative;
  margin: 1.5em 0 3em;
}
@media screen and (max-width: 767px) {
  #navigator #menu-button {
    -webkit-box-ordinal-group: 1;
    -moz-box-ordinal-group: 1;
    -o-box-ordinal-group: 1;
    -ms-flex-order: 1;
    -webkit-order: 1;
    order: 1;
    width: 2.25em;
    margin: 0;
  }
}
#navigator #menu-button img {
  -webkit-transition: all 1s cubic-bezier(0.19, 1, 0.22, 1);
  -moz-transition: all 1s cubic-bezier(0.19, 1, 0.22, 1);
  -o-transition: all 1s cubic-bezier(0.19, 1, 0.22, 1);
  -ms-transition: all 1s cubic-bezier(0.19, 1, 0.22, 1);
  transition: all 1s cubic-bezier(0.19, 1, 0.22, 1);
}
#navigator #menu-button .open {
  opacity: 1;
  -ms-filter: none;
  filter: none;
}
#navigator #menu-button .close {
  position: absolute;
  top: -0.1em;
  left: 0.075em;
  z-index: 2;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}
@media screen and (max-width: 767px) {
  #navigator #logo-button {
    -webkit-box-ordinal-group: 2;
    -moz-box-ordinal-group: 2;
    -o-box-ordinal-group: 2;
    -ms-flex-order: 2;
    -webkit-order: 2;
    order: 2;
    width: 2.5em;
    margin-left: 4em;
  }
}
@media screen and (max-width: 767px) {
  #navigator #contact-button {
    -webkit-box-ordinal-group: 3;
    -moz-box-ordinal-group: 3;
    -o-box-ordinal-group: 3;
    -ms-flex-order: 3;
    -webkit-order: 3;
    order: 3;
    width: 6em;
  }
}
.page-name {
  width: 240px;
  height: 240px;
  text-align: center;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -o-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -o-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .page-name {
    width: 45vw;
    height: 45vw;
  }
}
.page-name .en {
  font-size: 3em;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .page-name .en {
    font-size: 2.25em;
  }
}
.page-name .ja {
  margin-top: 0.75em;
  display: inline-block;
}
h2.title {
  color: #013145;
  font-size: 1.5em;
  padding-bottom: 1em;
}
h2.title.center {
  text-align: center;
}
#contact-container {
  background-color: #f2f2ee;
  padding: 1em 1.5em;
  color: #013145;
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #contact-container {
    margin: 1.5em;
    padding: 0;
  }
}
#contact-container h2.title {
  padding-bottom: 0.5em;
  border-bottom: 1px solid #ccc;
}
@media screen and (max-width: 767px) {
  #contact-container h2.title {
    padding: 0.75em 0;
  }
}
#contact-container a {
  text-decoration: none;
}
#contact-container .contact-information {
  padding-top: 1em;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  #contact-container .contact-information {
    padding: 0;
  }
}
#contact-container .mail {
  border-style: solid;
  border-color: #ccc;
  border-left-width: 1px;
}
@media screen and (max-width: 767px) {
  #contact-container .mail {
    border-top-width: 1px;
    border-left: none;
  }
}
@media screen and (max-width: 767px) {
  #contact-container .mail .desc {
    font-size: 1.125em;
  }
}
#contact-container .tel-number {
  display: block;
  text-align: center;
}
#contact-container .number {
  font-size: 2.25rem;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  #contact-container .number {
    font-size: 2rem;
  }
}
#contact-container .tel,
#contact-container .mail {
  padding: 0 2.5em;
}
@media screen and (max-width: 767px) {
  #contact-container .tel,
  #contact-container .mail {
    padding: 1.5em 1em;
    width: 100%;
  }
}
#contact-container .reception {
  padding-left: 2.25em;
}
@media screen and (max-width: 767px) {
  #contact-container .reception {
    width: 100%;
    text-align: center;
    padding: 1em 0 0;
  }
}
#contact-container .icon {
  padding-right: 1em;
}
@media screen and (max-width: 767px) {
  #contact-container .icon {
    width: 25%;
  }
}
#contact-container .arrow {
  padding-left: 1em;
}
@media screen and (max-width: 767px) {
  #contact-container .arrow {
    width: 2em;
    margin-left: auto;
  }
}
#map-container {
  padding: 3.5em 0;
}
@media screen and (max-width: 767px) {
  #map-container {
    padding: 0;
    margin: 1.5em;
  }
}
@media screen and (max-width: 767px) {
  #map-container h2.title {
    text-align: center;
    padding: 0.75em 0;
  }
}
@media screen and (max-width: 767px) {
  #map-container .map {
    width: 100%;
  }
}
#map-container iframe {
  width: 500px;
  height: 100%;
}
@media screen and (max-width: 767px) {
  #map-container iframe {
    width: 100%;
    height: 66.66666666666666vw;
  }
}
#map-container .detail {
  margin-left: 1.5em;
}
@media screen and (max-width: 767px) {
  #map-container .detail {
    margin: 0;
  }
}
#map-container .read {
  font-weight: bold;
  font-size: 0.875em;
}
#map-container .address {
  font-size: 0.875em;
  line-height: 1.6;
  margin-bottom: 3em;
}
@media screen and (max-width: 767px) {
  #map-container .address {
    text-align: center;
    margin-bottom: 1.5em;
  }
}
#map-container ul.routes {
  margin-top: 0.75em;
  line-height: 1.6;
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #map-container ul.routes {
    margin-bottom: 1.5em;
  }
}
#map-container ul.routes > li {
  text-indent: -1em;
  padding-left: 1em;
}
#map-container ul.routes > li:before {
  content: '\2010';
}
.contact-read {
  color: #013145;
  margin-bottom: 1.5em;
  text-align: center;
  font-size: 1.125em;
  font-weight: bold;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .contact-read {
    padding: 0 1.5em;
    text-align: left;
  }
}
#footer {
  position: relative;
  background-color: #f2f2ee;
  color: #013145;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #footer .inner-wrap {
    padding: 0 1em;
  }
}
#footer ul.links {
  font-size: 0.875em;
  margin-left: 0;
}
@media screen and (max-width: 767px) {
  #footer ul.links {
    padding-bottom: 1em;
  }
}
@media screen and (max-width: 767px) {
  #footer ul.links > li {
    width: 33.333333333333336%;
    margin: 0.5em 0;
    white-space: nowrap;
  }
}
#footer ul.links > li + li {
  margin-left: 2em;
}
@media screen and (max-width: 767px) {
  #footer ul.links > li + li {
    margin-left: 0;
  }
}
#footer ul.links a {
  text-decoration: none;
}
#footer ul.links a:hover {
  opacity: 1;
  -ms-filter: none;
  filter: none;
  text-decoration: underline;
}
#footer .address-and-link {
  padding: 1em 0;
}
@media screen and (max-width: 767px) {
  #footer .address-and-link {
    text-align: center;
    -webkit-box-pack: center;
    -moz-box-pack: center;
    -o-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    padding: 1.5em 0;
  }
}
#footer .address {
  line-height: 1.6;
  margin: 1.6em 0;
}
@media screen and (max-width: 767px) {
  #footer .address {
    margin: 0 0 1em;
  }
}
#footer a#link-honganji {
  background-color: #013145;
  line-height: 1.6;
  padding: 0.25em 3.5em;
  border-radius: 0.5em;
  -webkit-background-size: auto 50%;
  -moz-background-size: auto 50%;
  background-size: auto 50%;
  background-position: right 1em center;
  text-decoration: none;
  text-align: center;
  color: #c5a682;
}
#footer #copyright {
  background-color: #cacabd;
  text-align: center;
  color: #666;
  padding: 2em 0;
  font-size: 0.625em;
}
@media screen and (max-width: 767px) {
  #footer #copyright {
    padding: 1.5em 0;
  }
}
#pagetop {
  position: absolute;
  bottom: 4em;
  right: 0;
}
@media screen and (max-width: 767px) {
  #pagetop {
    width: 3em;
    bottom: 2.5em;
  }
}
@media screen and (max-width: 767px) {
  .content-container #key-visual {
    position: relative;
  }
}
@media screen and (max-width: 767px) {
  .content-container #key-visual .logo {
    width: 13em;
    padding: 0 0.5em !important;
  }
}
#enkai_hoji-page section {
  padding: 3em 0 1em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page section {
    padding: 2em 0 1em;
  }
}
#enkai_hoji-page .section-title {
  text-align: center;
  margin-bottom: 2em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page .section-title {
    margin-bottom: 1.5em;
  }
}
#enkai_hoji-page .section-title .en {
  font-size: 3em;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page .section-title .en {
    font-size: 2.25em;
  }
}
#enkai_hoji-page .panel {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -o-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
  color: #fff;
  background-color: #7c6c97;
  line-height: 1.4;
}
#enkai_hoji-page #key-visual {
  height: 160px;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #key-visual {
    height: 30vw;
  }
}
#enkai_hoji-page #key-visual .logo {
  padding: 1em;
  text-align: right;
  position: absolute;
  right: 0;
  top: 0;
}
#enkai_hoji-page #section-top {
  position: relative;
  padding-top: 5em;
}
#enkai_hoji-page #section-top .page-name {
  background-color: #7c6c97;
  position: absolute;
  left: 0;
  top: -3em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-top .page-name {
    width: 80%;
    height: auto;
    left: 10%;
    padding: 0.75em 0;
  }
}
#enkai_hoji-page #section-top .title-wrap {
  color: #7c6c97;
  text-align: center;
}
#enkai_hoji-page #section-top .title {
  font-size: 3em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-top .title {
    font-size: 2.25em;
  }
}
#enkai_hoji-page #section-top .sub-title {
  font-size: 1.5em;
  margin: 1em 0;
}
#enkai_hoji-page #section-top .desc {
  line-height: 2;
  padding: 1em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-top .desc {
    padding: 0;
  }
}
#enkai_hoji-page #section-rooms .desc {
  text-align: center;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms .desc {
    text-align: left;
    padding: 0 1.5em;
  }
}
#enkai_hoji-page #section-rooms .panel {
  position: absolute;
  width: 7.5em;
  height: 7.5em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms .panel {
    position: static;
    width: auto;
    height: 4.5em;
  }
}
#enkai_hoji-page #section-rooms .panel .strong {
  font-size: 2.25em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms .panel .strong {
    margin: 0 0.25em;
  }
}
#enkai_hoji-page #section-rooms .panel .em {
  font-size: 1.5em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms .panel .em {
    margin: 0 0.375em;
  }
}
#enkai_hoji-page #section-rooms .rooms-wrap {
  margin-bottom: 2em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms .rooms-wrap {
    margin: 0;
  }
}
#enkai_hoji-page #section-rooms ul.rooms {
  padding: 1em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms ul.rooms {
    padding: 1em 1.5em;
  }
}
#enkai_hoji-page #section-rooms ul.rooms > li:nth-child(n + 3) {
  margin-top: 1.5em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms ul.rooms > li:nth-child(n) {
    margin-top: 1em;
  }
}
#enkai_hoji-page #section-rooms .image {
  width: 450px;
  margin: 1em 0 0 1em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms .image {
    width: auto;
    margin: 0;
  }
}
#enkai_hoji-page #section-rooms .image img {
  width: 100%;
}
#enkai_hoji-page #section-rooms .note {
  text-align: center;
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-rooms .note {
    text-align: left;
    padding: 0 1.5em;
    margin-bottom: 1em;
  }
}
#enkai_hoji-page #section-food {
  background-color: #f4f4f4;
  padding-left: 1.5em;
  padding-right: 1.5em;
  margin-bottom: 4em;
}
#enkai_hoji-page #section-food .sub-section + .sub-section {
  margin-top: 3em;
}
#enkai_hoji-page #section-food .panel {
  width: 7.5em;
  height: 7.5em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-food .panel {
    margin: 0 auto;
  }
}
#enkai_hoji-page #section-food .panel .strong {
  font-size: 2.25em;
}
#enkai_hoji-page #section-food .panel .em {
  font-size: 1.5em;
}
#enkai_hoji-page #section-food .desc {
  line-height: 2.4;
  padding-left: 2em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-food .desc {
    padding: 1em 0 0;
    line-height: 2;
  }
}
#enkai_hoji-page #section-food ul.foods > li {
  background-color: #fff;
  width: 32%;
  margin-top: 1.5em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-food ul.foods > li {
    width: 100%;
  }
}
#enkai_hoji-page #section-food ul.foods .image img {
  width: 100%;
}
#enkai_hoji-page #section-food ul.foods .text {
  padding: 1em;
  line-height: 1.6;
}
#enkai_hoji-page #section-food ul.foods .name {
  font-weight: bold;
  font-size: 1.125em;
  margin-bottom: 0.75em;
}
#enkai_hoji-page #section-food ul.foods .name .size {
  font-size: 0.75em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-food ul.foods .price {
    font-size: 0.875em;
  }
}
#enkai_hoji-page #section-food ul.foods .notes {
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-food ul.foods .notes {
    font-size: 0.75em;
  }
}
#enkai_hoji-page #section-food .food-note {
  margin-top: 1em;
  text-align: center;
  font-size: 0.875em;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-food .food-note {
    font-size: 0.75em;
    text-align: left;
  }
}
#enkai_hoji-page #section-food .kaiseki-wrap ul.foods > li {
  width: 48.75%;
}
@media screen and (max-width: 767px) {
  #enkai_hoji-page #section-food .kaiseki-wrap ul.foods > li {
    width: 100%;
  }
}
#index-page .site-info {
  text-align: center;
  padding: 1.25em 0;
}
@media screen and (max-width: 767px) {
  #index-page .site-info {
    background: -webkit-linear-gradient(rgba(255,255,255,0.733), rgba(255,255,255,0.733)), url("../img/bg-honganji.jpg");
    background: -moz-linear-gradient(rgba(255,255,255,0.733), rgba(255,255,255,0.733)), url("../img/bg-honganji.jpg");
    background: -o-linear-gradient(rgba(255,255,255,0.733), rgba(255,255,255,0.733)), url("../img/bg-honganji.jpg");
    background: -ms-linear-gradient(rgba(255,255,255,0.733), rgba(255,255,255,0.733)), url("../img/bg-honganji.jpg");
    background: linear-gradient(rgba(255,255,255,0.733), rgba(255,255,255,0.733)), url("../img/bg-honganji.jpg");
    -webkit-background-size: 100% auto;
    -moz-background-size: 100% auto;
    background-size: 100% auto;
    background-position: center bottom;
    background-repeat: no-repeat;
    line-height: 1.6;
    padding: 0 0 1em;
    font-size: 1.25em;
    font-weight: bold;
    text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;
    color: #333;
  }
}
@media screen and (max-width: 767px) {
  #index-page .site-info .site-title {
    margin: 0.5em 6em 1.2em;
  }
}
#index-page .site-info .read {
  font-size: 0.75em;
  margin-top: 1em;
}
@media screen and (max-width: 767px) {
  #index-page .site-info .read {
    margin-top: 0;
  }
}
#index-page #key-visual .links {
  position: relative;
  overflow: hidden;
}
#index-page #key-visual .dummy-box {
  position: absolute;
  top: 0;
  width: 33%;
  height: 100%;
  background-color: #fff;
  -webkit-transform-origin: right center;
  -moz-transform-origin: right center;
  -o-transform-origin: right center;
  -ms-transform-origin: right center;
  transform-origin: right center;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .dummy-box {
    height: 40vw;
    width: 66%;
  }
}
#index-page #key-visual .dummy-box#dummy-box-1 {
  left: 0%;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .dummy-box#dummy-box-1 {
    left: 66%;
  }
}
#index-page #key-visual .dummy-box#dummy-box-2 {
  left: 33%;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .dummy-box#dummy-box-2 {
    top: 40vw;
    left: 0;
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -o-transform-origin: left center;
    -ms-transform-origin: left center;
    transform-origin: left center;
  }
}
#index-page #key-visual .dummy-box#dummy-box-3 {
  left: 66%;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .dummy-box#dummy-box-3 {
    top: 80vw;
    left: 66%;
  }
}
#index-page #key-visual .dummy-box#dummy-box-4 {
  left: 100%;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .dummy-box#dummy-box-4 {
    top: 120vw;
    left: 0;
    -webkit-transform-origin: left center;
    -moz-transform-origin: left center;
    -o-transform-origin: left center;
    -ms-transform-origin: left center;
    transform-origin: left center;
  }
}
#index-page #key-visual .link {
  width: 33%;
  height: 510px;
  position: relative;
  -webkit-transform-origin: left center;
  -moz-transform-origin: left center;
  -o-transform-origin: left center;
  -ms-transform-origin: left center;
  transform-origin: left center;
  -webkit-transform: translateX(-100%);
  -moz-transform: translateX(-100%);
  -o-transform: translateX(-100%);
  -ms-transform: translateX(-100%);
  transform: translateX(-100%);
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .link {
    width: 100%;
     height: auto; 
	/* height: 250px;*/
    -webkit-background-size: 60% auto;
    -moz-background-size: 60% auto;
    background-size: 60% auto;
    background-position: right center;
  }
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .link#link-1 {
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}
#index-page #key-visual .link#link-1 .label {
  background-color: #c60034;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .link#link-2 {
    background-position: left center;
    -webkit-transform: translateX(50%);
    -moz-transform: translateX(50%);
    -o-transform: translateX(50%);
    -ms-transform: translateX(50%);
    transform: translateX(50%);
  }
}
#index-page #key-visual .link#link-2 .label {
  background-color: #7c6c97;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .link#link-2 .label {
    margin-left: auto;
  }
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .link#link-3 {
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}
#index-page #key-visual .link#link-3 .label {
  background-color: #d4b41d;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .link#link-4 {
    background-position: left center;
    -webkit-transform: translateX(50%);
    -moz-transform: translateX(50%);
    -o-transform: translateX(50%);
    -ms-transform: translateX(50%);
    transform: translateX(50%);
  }
}
#index-page #key-visual .link#link-4 .label {
  background-color: #8bb869;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .link#link-4 .label {
    margin-left: auto;
  }
}
#index-page #key-visual .link .label {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 150px;
  height: 150px;
  color: #fff;
  text-align: center;
  line-height: 1.2;
  font-size: 1.5em;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .link .label {
    position: static;
    width: 40vw;
    height: 40vw;
    opacity: 1;
    -ms-filter: none;
    filter: none;
  }
}
#index-page #key-visual .link .label .ja {
  font-size: 0.75em;
}
#index-page #key-visual .link.js-hover + .panel {
  opacity: 1;
  -ms-filter: none;
  filter: none;
  visibility: visible;
}
#index-page #key-visual .panel {
  visibility: hidden;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  filter: alpha(opacity=0);
  -webkit-transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -moz-transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -o-transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -ms-transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  color: #fff;
  z-index: 2;
/*  line-height: 1.8; 2023-06-17*/
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .panel {
    display: block;
    padding: 1.5em;
    height: auto;
    font-size: 3.5vw;
  }
}
#index-page #key-visual .panel.js-hover {
  opacity: 1;
  -ms-filter: none;
  filter: none;
  visibility: visible;
}
#index-page #key-visual .panel#panel-1 {
  background-color: rgba(198,0,52,0.9);
}
@media screen and (min-width: 768px) {
  #index-page #key-visual .panel#panel-1 a.button:hover {
    background-color: #c60034;
  }
}
#index-page #key-visual .panel#panel-2 {
  background-color: rgba(124,108,151,0.9);
}
@media screen and (min-width: 768px) {
  #index-page #key-visual .panel#panel-2 a.button:hover {
    background-color: #7c6c97;
  }
}
#index-page #key-visual .panel#panel-3 {
  background-color: rgba(212,180,29,0.9);
}
@media screen and (min-width: 768px) {
  #index-page #key-visual .panel#panel-3 a.button:hover {
    background-color: #d4b41d;
  }
}
#index-page #key-visual .panel#panel-4 {
  background-color: rgba(139,184,105,0.9);
}
@media screen and (min-width: 768px) {
  #index-page #key-visual .panel#panel-4 a.button:hover {
    background-color: #8bb869;
  }
}
#index-page #key-visual .panel .text-wrap {
  width: 50%;
  height: 100%;
  padding: 3em 0;
  -webkit-box-ordinal-group: 1;
  -moz-box-ordinal-group: 1;
  -o-box-ordinal-group: 1;
  -ms-flex-order: 1;
  -webkit-order: 1;
  order: 1;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .panel .text-wrap {
    width: 100%;
    height: auto;
    padding: 1em 0;
  }
}
#index-page #key-visual .panel .text {
  position: relative;
  width: 340px;
  height: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .panel .text {
    width: 100%;
    min-height: 81.25vw;
  }
}
#index-page #key-visual .panel .title {
  font-size: 3em;
  margin-bottom: 0.875em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .panel .title {
    font-size: 2em;
    margin: 0.125em 0 0.5em;
  }
}
#index-page #key-visual .panel .read {
  margin-bottom: 1em;
  font-size: 1.5em;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .panel .read {
    font-size: 1.375em;
    margin-bottom: 0.5em;
  }
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .panel .desc {
    margin-bottom: 5em;
  }
}
#index-page #key-visual .panel a.button {
  position: absolute;
  width: 100%;
  bottom: 0;
  text-decoration: none;
  padding: 1em;
  border: 1px solid #fff;
  background-image: url("../img/_common/arrow-chevron-right-white.png");
  -webkit-background-size: auto 50%;
  -moz-background-size: auto 50%;
  background-size: auto 50%;
  background-position: right 1em center;
}
#index-page #key-visual .panel a.button:hover {
  opacity: 1;
  -ms-filter: none;
  filter: none;
}
#index-page #key-visual .panel .image {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  width: 50%;
  height: 100%;
  -webkit-box-ordinal-group: 2;
  -moz-box-ordinal-group: 2;
  -o-box-ordinal-group: 2;
  -ms-flex-order: 2;
  -webkit-order: 2;
  order: 2;
}
@media screen and (max-width: 767px) {
  #index-page #key-visual .panel .image {
    width: 100%;
    height: 0;
    padding-top: 65%;
  }
}
#index-page .news-container {
  margin: 3em auto;
}
@media screen and (max-width: 767px) {
  #index-page .news-container {
    margin: 0;
    padding: 1.5em;
  }
}
#index-page .news-container ul.news-list {
  width: 600px;
  margin: 0 auto;
  max-height: 11em;
  overflow-y: auto;
}
@media screen and (max-width: 767px) {
  #index-page .news-container ul.news-list {
    width: auto;
  }
}
#index-page .news-container ul.news-list > li {
  margin-bottom: 1em;
}
#index-page .news-container ul.news-list > li:last-child {
  margin-bottom: 0;
}
#index-page .news-container .date {
  width: 8em;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #index-page .news-container .date {
    width: 100%;
    margin-bottom: 0.25em;
  }
}
#index-page .news-container .text {
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #index-page .news-container .text {
    width: 100%;
  }
}
#restaurant-page .theme-1 {
  background-color: #d29b24;
}
#restaurant-page .link-wrap {
  margin: 2em auto 1em;
}
#restaurant-page .link-wrap .button {
  margin: 0 0.75em;
}
@media screen and (max-width: 767px) {
  #restaurant-page .link-wrap .button {
    width: 100%;
    margin: 0.75em 0;
  }
}
#restaurant-page section {
  padding: 3em 0 1em;
}
@media screen and (max-width: 767px) {
  #restaurant-page section {
    padding: 2em 0 1em;
  }
}
#restaurant-page .title-wrap {
  padding-top: 5em;
}
#restaurant-page .restaurant-name {
  font-size: 3em;
  color: #d29b24;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #restaurant-page .restaurant-name {
    font-size: 2.25em;
  }
}
#restaurant-page .panel {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -o-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
  color: #fff;
  background-color: #d29b24;
  line-height: 1.4;
}
#restaurant-page #key-visual {
  height: 160px;
  background-position: center bottom 10%;
}
@media screen and (max-width: 767px) {
  #restaurant-page #key-visual {
    height: 30vw;
  }
}
#restaurant-page #key-visual .logo {
  padding: 1em;
  text-align: right;
  position: absolute;
  right: 0;
  top: 0;
}
#restaurant-page #section-top {
  position: relative;
}
#restaurant-page #section-top .page-name {
  background-color: #d29b24;
  position: absolute;
  left: 0;
  top: -3em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-top .page-name {
    width: 80%;
    height: auto;
    left: 10%;
    padding: 0.75em 0;
  }
}
#restaurant-page #section-top .page-name .en {
  font-size: 2.25em;
}
#restaurant-page #section-top .page-read {
  text-align: center;
  padding: 3em 0;
}
#restaurant-page #section-top .read {
  font-size: 1.125em;
  font-weight: bold;
  text-align: center;
  padding: 1.5em 0 1em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-top .read {
    line-height: 2;
    padding: 1em 0;
  }
}
#restaurant-page #section-top .desc {
  line-height: 1.6;
  padding: 1em;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-top .desc {
    padding: 0;
    text-align: left;
  }
}
#restaurant-page #section-top .images {
  padding: 1em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-top .images {
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-top .images .image {
    margin-top: 1em;
  }
}
#restaurant-page #section-food .grayback {
  background-color: #f4f4f4;
  margin: 0 1em;
  padding: 1.5em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food .grayback {
    margin: 0;
  }
}
#restaurant-page #section-food .panel {
  font-size: 1.5em;
  width: 4.5em;
  height: 4.5em;
  margin: 0.5em auto;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food .panel {
    margin: 0 auto;
  }
}
#restaurant-page #section-food .panel.double {
  width: 10em;
}
#restaurant-page #section-food .panel-note {
  text-align: center;
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food .panel-note {
    margin-top: 0.5em;
  }
}
#restaurant-page #section-food .menu-group + .menu-group {
  padding-top: 2em;
}
#restaurant-page #section-food ul.foods:after {
  content: '';
  display: block;
  width: 32%;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods:after {
    content: default;
  }
}
#restaurant-page #section-food ul.foods > li {
  background-color: #fff;
  width: 32%;
  margin-top: 1.5em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods > li {
    width: 100%;
  }
}
#restaurant-page #section-food ul.foods > li:nth-child(-n + 2) {
  width: 48.75%;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods > li:nth-child(-n + 2) {
    width: 100%;
  }
}
#restaurant-page #section-food ul.foods > li.double {
  width: 100% !important;
}
#restaurant-page #section-food ul.foods > li.double .image {
  width: 48.75%;
  height: 100%;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods > li.double .image {
    width: 100%;
    height: calc((100vw - 3em) * 218 / 327);
  }
}
#restaurant-page #section-food ul.foods > li.double .text {
  width: 51.25%;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods > li.double .text {
    width: 100%;
  }
}
#restaurant-page #section-food ul.foods > li.double .text .desc {
  padding: 4em 0;
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods > li.double .text .desc {
    padding: 0 0 1em;
  }
}
#restaurant-page #section-food ul.foods > li.double .text .price {
  font-size: 1em;
}
#restaurant-page #section-food ul.foods > li.double .lead {
  text-align: center;
  padding: 0 0 1em;
  font-weight: bold;
}
#restaurant-page #section-food ul.foods > li.double ul.partials {
  padding: 0 1em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods > li.double ul.partials {
    padding: 0;
  }
}
#restaurant-page #section-food ul.foods > li.double ul.partials > li:nth-child(2n) .text {
  text-align: right;
}
#restaurant-page #section-food ul.foods > li.double ul.partials .image {
  width: 40%;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods > li.double ul.partials .image {
    height: auto;
  }
}
#restaurant-page #section-food ul.foods > li.double ul.partials .text {
  width: 58.75%;
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods > li.double ul.partials .text {
    font-size: 0.75em;
  }
}
#restaurant-page #section-food ul.foods.all-large > li:nth-child(n) {
  width: 48.75%;
}
#restaurant-page #section-food ul.foods.all-small > li:nth-child(n) {
  width: 32%;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods.all-small > li:nth-child(n) {
    width: 100%;
  }
}
#restaurant-page #section-food ul.foods .image img {
  width: 100%;
}
#restaurant-page #section-food ul.foods .text {
  padding: 1em;
  line-height: 1.6;
}
#restaurant-page #section-food ul.foods .name {
  font-weight: bold;
  margin-bottom: 0.75em;
  font-size: 1.125em;
}
#restaurant-page #section-food ul.foods .name .size {
  font-size: 0.75em;
}
#restaurant-page #section-food ul.foods .detail,
#restaurant-page #section-food ul.foods .price {
  font-size: 0.875em;
}
#restaurant-page #section-food ul.foods .notes {
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food ul.foods .notes {
    font-size: 0.75em;
  }
}
#restaurant-page #section-food .option-menu {
  width: 70%;
  padding: 1em;
  margin: 1em auto 0;
  background-color: #fff;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food .option-menu {
    width: auto;
    margin: 0;
  }
}
#restaurant-page #section-food .option-menu .label {
  color: #d29b24;
  font-size: 1.125em;
  font-weight: bold;
}
#restaurant-page #section-food .option-menu .price {
  padding-left: 3em;
}
@media screen and (max-width: 767px) {
  #restaurant-page #section-food .option-menu .price {
    padding: 0;
    margin-left: auto;
  }
}
#restaurant-page .about-restaurant {
  color: #013145;
  padding: 1em;
  border: 3px solid #d29b24;
  margin: 1.5em 0;
}
@media screen and (max-width: 767px) {
  #restaurant-page .about-restaurant {
    margin: 1.5em;
    padding: 0.75em;
  }
}
@media screen and (max-width: 767px) {
  #restaurant-page .about-restaurant .image {
    width: 100%;
    margin-bottom: 1em;
  }
}
#restaurant-page .about-restaurant .text {
  padding-left: 1em;
}
@media screen and (max-width: 767px) {
  #restaurant-page .about-restaurant .text {
    padding: 0;
  }
}
#restaurant-page .about-restaurant .name {
  font-weight: bold;
  font-size: 1.125em;
}
#restaurant-page .about-restaurant .desc,
#restaurant-page .about-restaurant .detail {
  font-size: 0.875em;
  line-height: 1.6;
  margin-top: 1em;
}
#restaurant-page .about-restaurant span.bold {
  font-weight: bold;
  margin-right: 0.5em;
}
#restaurant-page #section-cafe ul.images {
  margin: 2em 1em 0;
}
#restaurant-page #section-cafe ul.images > li {
  width: 48.75%;
}
#restaurant-page #section-cafe ul.images img {
  width: 100%;
}
#stay-page section {
  padding: 3em 0 1em;
}
@media screen and (max-width: 767px) {
  #stay-page section {
    padding: 2em 0 0;
  }
}
#stay-page .panel {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -o-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
  color: #fff;
  background-color: #8bb869;
  line-height: 1.4;
}
#stay-page .section-title {
  text-align: center;
}
#stay-page .section-title .en {
  font-size: 3em;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  #stay-page .section-title .en {
    font-size: 2.25em;
  }
}
#stay-page #key-visual {
  height: 160px;
}
@media screen and (max-width: 767px) {
  #stay-page #key-visual {
    height: 30vw;
  }
}
#stay-page #key-visual .logo {
  padding: 1em;
  text-align: right;
  position: absolute;
  right: 0;
  top: 0;
}
#stay-page #section-top {
  position: relative;
}
#stay-page #section-top .page-name {
  background-color: #8bb869;
  position: absolute;
  left: 0;
  top: -3em;
  color: #fff;
}
@media screen and (max-width: 767px) {
  #stay-page #section-top .page-name {
    width: 80%;
    height: auto;
    left: 10%;
    padding: 0.75em 0;
  }
}
#stay-page #section-top .page-name .en {
  font-size: 3em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-top .page-name .en {
    font-size: 2.25em;
  }
}
#stay-page #section-top .page-read {
  padding: 1.5em 0;
  line-height: 2;
  margin-left: 27.5%;
}
#stay-page #section-rooms {
  margin-top: 2em;
}
#stay-page #section-rooms .swiper-container {
  margin-top: 2em;
  position: relative;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rooms .swiper-container {
    margin-top: 1em;
  }
}
#stay-page #section-rooms .swiper-slide {
  width: 560px;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rooms .swiper-slide {
    width: 80%;
  }
}
#stay-page #section-rooms .swiper-slide img {
  width: 100%;
}
#stay-page #section-rooms .swiper-button {
  position: absolute;
  width: 2.25em;
  top: calc(50% - 1.125em);
  z-index: 2;
  -webkit-box-shadow: 0 0 5px rgba(0,0,0,0.267);
  box-shadow: 0 0 5px rgba(0,0,0,0.267);
  border-radius: 100%;
}
#stay-page #section-rooms .swiper-button.prev {
  left: calc(50% - 340px);
}
@media screen and (max-width: 767px) {
  #stay-page #section-rooms .swiper-button.prev {
    left: 5%;
  }
}
#stay-page #section-rooms .swiper-button.next {
  right: calc(50% - 340px);
}
@media screen and (max-width: 767px) {
  #stay-page #section-rooms .swiper-button.next {
    right: 5%;
  }
}
#stay-page #section-rooms .swiper-button:hover {
  background-color: rgba(0,0,0,0.667);
  opacity: 1;
  -ms-filter: none;
  filter: none;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rooms .swiper-button:hover {
    background-color: transparent;
  }
}
#stay-page #section-rooms .swiper-button img {
  width: 100%;
}
#stay-page #section-fee ul.fees {
  margin: 1em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee ul.fees {
    margin: 0 1.5em;
  }
}
#stay-page #section-fee ul.fees > li {
  width: 700px;
  -webkit-background-size: auto 100%;
  -moz-background-size: auto 100%;
  background-size: auto 100%;
  background-position: right center;
  margin: 1.5em 0;
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee ul.fees > li {
    width: auto;
    padding-bottom: 75%;
    background-position: center bottom;
    -webkit-background-size: 100% auto;
    -moz-background-size: 100% auto;
    background-size: 100% auto;
  }
}
#stay-page #section-fee .text {
  width: 60%;
  padding: 1.5em 6em 1.5em 1.5em;
}
#stay-page #section-fee .strong {
  font-size: 2.25em;
}
#stay-page #section-fee ul.prices {
  line-height: 1.6;
  white-space: nowrap;
  margin: 1em 0 1.5em;
  font-size: 1.125em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee ul.prices {
    font-size: 1em;
  }
}
#stay-page #section-fee .breaked .border {
  font-size: 1.125em;
  margin-left: 3em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee .breaked .border {
    min-width: 40%;
  }
}
#stay-page #section-fee .border {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  border-bottom: 1px dashed #454545;
  margin: 0 1em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee #fee-1 {
    background-color: #dfddda;
  }
}
#stay-page #section-fee #fee-1 .text {
  background: -webkit-linear-gradient(left, #dfddda 85%, rgba(0,0,0,0));
  background: -moz-linear-gradient(left, #dfddda 85%, rgba(0,0,0,0));
  background: -o-linear-gradient(left, #dfddda 85%, rgba(0,0,0,0));
  background: -ms-linear-gradient(left, #dfddda 85%, rgba(0,0,0,0));
  background: linear-gradient(to right, #dfddda 85%, rgba(0,0,0,0));
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee #fee-1 .text {
    background: #dfddda;
    width: 100%;
    padding: 1em;
  }
}
#stay-page #section-fee #fee-2 {
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee #fee-2 {
    background-color: #e2d1ad;
  }
}
#stay-page #section-fee #fee-2 .text {
  width: 65%;
  padding-right: 7.5em;
  background: -webkit-linear-gradient(left, #e2d1ad 85%, rgba(0,0,0,0));
  background: -moz-linear-gradient(left, #e2d1ad 85%, rgba(0,0,0,0));
  background: -o-linear-gradient(left, #e2d1ad 85%, rgba(0,0,0,0));
  background: -ms-linear-gradient(left, #e2d1ad 85%, rgba(0,0,0,0));
  background: linear-gradient(to right, #e2d1ad 85%, rgba(0,0,0,0));
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee #fee-2 .text {
    background: #e2d1ad;
    width: 100%;
    padding: 1em;
  }
}
#stay-page #section-fee .fee-note {
  text-align: center;
  line-height: 1.6;
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-fee .fee-note {
    padding: 0 1.5em;
  }
}
#stay-page #section-food .grayback {
  background-color: #f4f4f4;
  margin: 0 1em;
  padding: 2.5em 1.5em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-food .grayback {
    margin: 0;
  }
}
#stay-page #section-food ul.foods > li {
  background-color: #fff;
  width: 48.75%;
  margin-top: 1.5em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-food ul.foods > li {
    width: 100%;
  }
}
#stay-page #section-food ul.foods .image img {
  width: 100%;
}
#stay-page #section-food ul.foods .text {
  padding: 1em;
  line-height: 1.6;
}
#stay-page #section-food ul.foods .name {
  font-weight: bold;
  margin-bottom: 0.75em;
  font-size: 1.125em;
}
#stay-page #section-food ul.foods .name .size {
  font-size: 0.75em;
}
#stay-page #section-food ul.foods .detail,
#stay-page #section-food ul.foods .price {
  font-size: 0.875em;
}
#stay-page #section-food ul.foods .notes {
  font-size: 0.875em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-food ul.foods .notes {
    font-size: 0.75em;
  }
}
#stay-page #section-food .food-desc {
  line-height: 1.6;
  margin: 1em 0;
}
@media screen and (max-width: 767px) {
  #stay-page #section-food .food-desc {
    font-size: 0.875em;
  }
}
#stay-page #section-food .food-note {
  font-size: 0.875em;
  margin-top: 1em;
}
#stay-page #section-rules {
  text-align: center;
  line-height: 1.6;
}
#stay-page #section-rules .rule {
  margin: 0 1.5em 3em;
}
#stay-page #section-rules .rule:after {
  content: '';
  display: block;
  width: 5em;
  height: 1px;
  background-color: #454545;
  margin: 0 auto;
  margin-top: 2em;
}
#stay-page #section-rules .rule:last-child:after {
  content: normal;
}
#stay-page #section-rules .time {
  margin-bottom: 1.5em;
  border: 2px solid #013145;
  padding: 1em 0;
  color: #013145;
  font-weight: bold;
  font-size: 1.125em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules .time {
    padding: 0.5em 0;
  }
}
#stay-page #section-rules .important {
  margin-bottom: 2em;
  color: #c60034;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules .important {
    text-align: left;
  }
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules .japanese .important {
    text-indent: -1em;
    padding-left: 1em;
  }
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules .notes {
    font-size: 0.85em;
    text-align: left;
  }
}
#stay-page #section-rules .notes p {
  margin-bottom: 1em;
}
#stay-page #section-rules .amenity-container {
  margin: 1.5em 0;
}
#stay-page #section-rules .amenity-wrap {
  display: inline-block;
  background-color: #eee;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules .amenity-wrap {
    padding: 0 2em;
  }
}
#stay-page #section-rules ul.amenities {
  padding: 1.5em 0.75em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules ul.amenities {
    -webkit-box-pack: justify;
    -moz-box-pack: justify;
    -o-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
}
#stay-page #section-rules ul.amenities > li {
  margin: 0 0.75em;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules ul.amenities > li {
    width: 40%;
    margin: 0.75em 0;
  }
}
#stay-page #section-rules ul.amenities .name {
  font-size: 0.75em;
  line-height: 1.4;
  margin-top: 0.75em;
  font-weight: bold;
}
#stay-page #section-rules ul.amenities .icon {
  width: 96px;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules ul.amenities .icon {
    width: auto;
  }
}
#stay-page #section-rules ul.amenities .icon.special {
  width: 60px;
  margin: 1.125em 0;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules ul.amenities .icon.special {
    width: 65%;
    margin: 1.125em auto;
  }
}
#stay-page #section-rules ul.amenities .icon img {
  width: 100%;
}
#stay-page #section-rules .amenity-note {
  margin-top: 0.5em;
}
#stay-page #section-rules .amenity-note .label {
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules #amenity-2 .amenity-wrap {
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  #stay-page #section-rules #amenity-2 ul.amenities > li {
    width: 30%;
  }
}
#wedding-page .theme {
  color: #c60034;
}
#wedding-page .button.theme-1 {
  background-color: #c60034;
}
#wedding-page .page-name {
  background-color: rgba(198,0,52,0.9);
  position: absolute;
  left: calc(50% - 500px);
  top: 5em;
}
@media screen and (max-width: 767px) {
  #wedding-page .page-name {
    position: static;
    margin-bottom: 17.5em;
  }
}
#wedding-page .panel {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -o-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  text-align: center;
  color: #fff;
  background-color: rgba(198,0,52,0.9);
  line-height: 1.4;
}
#wedding-page section {
  padding: 3em 0;
}
@media screen and (max-width: 767px) {
  #wedding-page section {
    padding: 1em 0;
  }
}
#wedding-page .section-title-wrap .section-title {
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -o-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  font-weight: bold;
  color: #c60034;
  text-align: center;
  font-size: 2.25em;
}
@media screen and (max-width: 767px) {
  #wedding-page .section-title-wrap .section-title {
    font-size: 1.5em;
  }
}
#wedding-page .section-title-wrap .section-title:before,
#wedding-page .section-title-wrap .section-title:after {
  content: '';
  display: block;
  height: 1px;
  border-style: solid;
  border-color: #c60034;
  border-width: 2px 0 1px;
  width: 160px;
}
@media screen and (max-width: 767px) {
  #wedding-page .section-title-wrap .section-title:before,
  #wedding-page .section-title-wrap .section-title:after {
    -webkit-box-flex: 1;
    -moz-box-flex: 1;
    -o-box-flex: 1;
    box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
  }
}
#wedding-page .section-title-wrap .section-title span.text {
  display: block;
  width: 10em;
}
@media screen and (max-width: 767px) {
  #wedding-page .section-title-wrap .section-title span.text {
    width: auto;
    padding: 0 0.25em;
  }
}
#wedding-page .section-title-wrap .read {
  margin-top: 1em;
  text-align: center;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  #wedding-page .section-title-wrap .read {
    margin: 1em 2em 0;
    line-height: 1.4;
  }
}
#wedding-page #key-visual {
  position: relative;
  height: 100vh;
  color: #fff;
  min-height: 620px;
}
@media screen and (max-width: 767px) {
  #wedding-page #key-visual {
    height: calc(100vh - 4em);
    min-height: 0;
  }
}
#wedding-page #key-visual .logo {
  padding: 1em;
  text-align: right;
  position: absolute;
  right: 0;
  top: 0;
}
#wedding-page #key-visual .read {
  text-align: center;
  line-height: 1.6;
  text-shadow: 0 0 5px #000, 0 0 5px #000, 0 0 5px #000;
  margin-top: 6em;
}
#wedding-page #key-visual .read .ja {
  font-size: 2.25em;
}
#wedding-page #key-visual .read .en {
  font-size: 1.125em;
}
#wedding-page #key-visual .button-wrap {
  position: absolute;
  left: 0;
  bottom: 2em;
  text-align: center;
  width: 100%;
}
@media screen and (max-width: 767px) {
  #wedding-page #key-visual .button-wrap {
    width: 2em;
    left: calc(50% - 1em);
  }
}
#wedding-page #section-top .text {
  padding-right: 3.5em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-top .text {
    padding: 0;
  }
}
#wedding-page #section-top .read {
  font-size: 2.25em;
  line-height: 1.4;
  margin-bottom: 0.75em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-top .read {
    font-size: 1.375em;
  }
}
#wedding-page #section-top .desc {
  line-height: 1.6;
}
#wedding-page #section-top .desc p {
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-top .image {
    margin: 0 3.5em;
  }
}
#wedding-page .sub-section {
  position: relative;
  height: 540px;
  margin: 3em 0;
  padding-top: 2.5em;
  -webkit-background-size: 45% auto;
  -moz-background-size: 45% auto;
  background-size: 45% auto;
}
@media screen and (max-width: 767px) {
  #wedding-page .sub-section {
    -webkit-background-size: 100% auto;
    -moz-background-size: 100% auto;
    background-size: 100% auto;
    background-position: center top;
    height: auto;
    padding-top: 100%;
    margin: 1em 0;
  }
}
#wedding-page .sub-section .text {
  width: 52.5%;
}
@media screen and (max-width: 767px) {
  #wedding-page .sub-section .text {
    width: 100%;
  }
}
#wedding-page .sub-section .read {
  font-size: 2.25em;
  color: #c60034;
  line-height: 1.4;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  #wedding-page .sub-section .read {
    font-size: 1.5em;
    margin: 0.75em 0;
  }
}
#wedding-page .sub-section .desc {
  line-height: 1.6;
}
#wedding-page .sub-section .desc p {
  margin-bottom: 1em;
}
#wedding-page .sub-section .plan {
  margin-top: 2em;
}
#wedding-page .sub-section .plan .price-wrap {
  border-bottom: 1px solid #c60034;
  padding-bottom: 0.5em;
}
#wedding-page .sub-section .plan .name {
  font-size: 1.5em;
  color: #c60034;
}
#wedding-page .sub-section .plan .price {
  font-size: 1.5em;
}
#wedding-page .sub-section .plan .tax-note {
  font-size: 0.75em;
}
#wedding-page .sub-section .plan .about {
  margin-top: 0.5em;
  line-height: 1.6;
}
#wedding-page .sub-section .plan .about .label {
  font-weight: bold;
  white-space: nowrap;
}
#wedding-page #section-1 .plan-container {
  position: relative;
  padding: 0.5em;
  background-color: #454545;
  color: #fff;
  margin-top: 2em;
}
#wedding-page #section-1 .plan-container .gold-border {
  border: 1px solid rgba(212,180,29,0.5);
  padding: 2em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .gold-border {
    padding: 1em;
  }
}
#wedding-page #section-1 .plan-container .container-title {
  position: absolute;
  top: -1em;
  font-size: 1.5em;
  text-align: center;
  color: #454545;
  width: 50%;
  left: 25%;
  background-color: #f7f3ee;
  padding: 1em 0;
  border: 0.375em #b96 solid;
  font-weight: bold;
  -webkit-box-shadow: 0 0.125em 0.125em rgba(0,0,0,0.667);
  box-shadow: 0 0.125em 0.125em rgba(0,0,0,0.667);
}
#wedding-page #section-1 .plan-container .image-container,
#wedding-page #section-1 .plan-container .text-container {
  width: 48.75%;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .image-container,
  #wedding-page #section-1 .plan-container .text-container {
    width: 100%;
  }
}
#wedding-page #section-1 .plan-container .plan {
  background-color: #fcf7ee;
  color: #454545;
  padding: 1.5em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan {
    padding: 1em;
  }
}
#wedding-page #section-1 .plan-container .plan + .plan {
  margin-top: 2em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan#wedding-plan-1 {
    background: -webkit-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-1.jpg");
    background: -moz-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-1.jpg");
    background: -o-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-1.jpg");
    background: -ms-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-1.jpg");
    background: linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-1.jpg");
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    background-position: center;
  }
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan#wedding-plan-2 {
    background: -webkit-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-2.jpg");
    background: -moz-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-2.jpg");
    background: -o-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-2.jpg");
    background: -ms-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-2.jpg");
    background: linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-2.jpg");
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    background-position: center;
  }
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan#wedding-plan-3 {
    background: -webkit-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-3.jpg");
    background: -moz-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-3.jpg");
    background: -o-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-3.jpg");
    background: -ms-linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-3.jpg");
    background: linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("../img/wedding/plan-3.jpg");
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    background-position: center;
  }
}
#wedding-page #section-1 .plan-container .plan .name {
  color: #9d8515;
  font-size: 2em;
  margin-bottom: 0.25em;
  font-weight: bold;
  font-feature-settings: 'palt';
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan .name {
    font-size: 1.75em;
  }
}
#wedding-page #section-1 .plan-container .plan .name .small {
  font-size: 0.675em;
  margin-left: 0.5em;
}
#wedding-page #section-1 .plan-container .plan .detail {
  margin-bottom: 0.5em;
}
#wedding-page #section-1 .plan-container .plan .persons {
  font-size: 1.75em;
  margin-right: 1em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan .persons {
    font-size: 1.5em;
  }
}
#wedding-page #section-1 .plan-container .plan .persons .unit {
  font-size: 0.75em;
}
#wedding-page #section-1 .plan-container .plan .price {
  font-size: 1.75em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan .price {
    font-size: 1.5em;
  }
}
#wedding-page #section-1 .plan-container .plan .price .tax-note {
  font-size: 0.5em;
}
#wedding-page #section-1 .plan-container .plan ul.detail {
  padding-top: 1em;
  border-top: 1px solid rgba(0,0,0,0.267);
  font-size: 0.6875em;
  line-height: 1.4;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-orient: vertical;
  -moz-box-orient: vertical;
  -o-box-orient: vertical;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -o-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  height: 18em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan ul.detail {
    padding-top: 1em;
    height: auto;
  }
}
#wedding-page #section-1 .plan-container .plan ul.detail > li {
  width: 48.75%;
  padding-left: 1em;
  text-indent: -1em;
  margin: 0.125em 0;
  margin-right: 1.25%;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-1 .plan-container .plan ul.detail > li {
    width: 100%;
    margin-right: 0;
  }
}
#wedding-page #section-1 .link-wrap {
  margin-top: 2em;
}
#wedding-page #sub-section-1-1 {
  background-position: left top;
}
#wedding-page #sub-section-1-1 .text {
  margin-left: auto;
}
#wedding-page #sub-section-1-1 .panel {
  position: absolute;
  bottom: -1em;
  right: calc(52.5% + 1.5em);
  width: 240px;
  height: 240px;
}
@media screen and (max-width: 767px) {
  #wedding-page #sub-section-1-1 .panel {
    position: static;
    width: auto;
    height: auto;
    padding: 1em 1.5em;
    font-size: 0.875em;
  }
}
#wedding-page #sub-section-1-1 .panel .label {
  margin-bottom: 1em;
  font-weight: bold;
  line-height: 0.5em;
}
@media screen and (max-width: 767px) {
  #wedding-page #sub-section-1-1 .panel .label {
    text-align: left;
  }
}
@media screen and (max-width: 767px) {
  #wedding-page #sub-section-1-1 .panel ul {
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: box;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -o-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 767px) {
  #wedding-page #sub-section-1-1 .panel ul > li {
    margin-right: 0.75em;
  }
}
#wedding-page #sub-section-1-2 {
  background-position: right bottom;
}
@media screen and (max-width: 767px) {
  #wedding-page #sub-section-1-2 {
    background-position: center top;
  }
}
#wedding-page #sub-section-1-2 .text {
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-plan {
    margin-top: 3em;
  }
}
#wedding-page #section-plan .plan {
  padding: 1.5em 1.5em 2em;
  margin-bottom: 2em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-plan .plan {
    margin-bottom: 3em;
    padding: 1.5em;
  }
}
#wedding-page #section-plan .image-container {
  position: relative;
}
#wedding-page #section-plan .panel {
  position: absolute;
  width: 50%;
  padding: 1.5em 0;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-plan .panel {
    width: 75%;
  }
}
#wedding-page #section-plan .title {
  font-size: 2.25em;
  margin-top: 0.5em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-plan .title {
    font-size: 1.75em;
    line-height: 1.4;
  }
}
#wedding-page #section-plan .read {
  margin: 0.5em 0 1.5em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-plan .read {
    line-height: 1.4;
  }
}
#wedding-page #section-plan .read-large {
  font-size: 1.5em;
  line-height: 1.2;
  margin: 2em 0;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-plan .read-large {
    font-size: 1.25em;
    margin: 1em 0;
  }
}
#wedding-page #section-plan .desc {
  line-height: 1.6;
  margin-top: 1em;
}
#wedding-page #section-plan .desc p {
  margin-bottom: 1em;
}
#wedding-page #plan-1 {
  color: #fff;
}
#wedding-page #plan-1 .text-container {
  padding-left: 3em;
}
@media screen and (max-width: 767px) {
  #wedding-page #plan-1 .text-container {
    padding: 0;
  }
}
#wedding-page #plan-1 .panel {
  right: -1em;
  bottom: -1em;
}
@media screen and (max-width: 767px) {
  #wedding-page #plan-1 .panel {
    bottom: auto;
    right: 12.5%;
    top: -3em;
  }
}
#wedding-page #plan-2 .panel {
  left: -1em;
  top: 1em;
}
@media screen and (max-width: 767px) {
  #wedding-page #plan-2 .panel {
    bottom: auto;
    left: 12.5%;
    top: -3em;
  }
}
#wedding-page #plan-2 .text-container {
  padding-right: 3em;
}
@media screen and (max-width: 767px) {
  #wedding-page #plan-2 .text-container {
    -webkit-box-ordinal-group: 2;
    -moz-box-ordinal-group: 2;
    -o-box-ordinal-group: 2;
    -ms-flex-order: 2;
    -webkit-order: 2;
    order: 2;
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  #wedding-page #plan-2 .image-container {
    -webkit-box-ordinal-group: 1;
    -moz-box-ordinal-group: 1;
    -o-box-ordinal-group: 1;
    -ms-flex-order: 1;
    -webkit-order: 1;
    order: 1;
  }
}
@media screen and (max-width: 767px) {
  #wedding-page #plan-2 .image-container .image {
    margin-bottom: 0.5em;
  }
}
#wedding-page .meals {
  -webkit-box-pack: end;
  -moz-box-pack: end;
  -o-box-pack: end;
  -ms-flex-pack: end;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
  font-weight: bold;
  margin-top: 3em;
}
@media screen and (max-width: 767px) {
  #wedding-page .meals {
    margin-top: 0;
  }
}
#wedding-page .meals .image-container {
  width: 50%;
}
@media screen and (max-width: 767px) {
  #wedding-page .meals .image-container {
    width: 100%;
    -webkit-box-ordinal-group: 2;
    -moz-box-ordinal-group: 2;
    -o-box-ordinal-group: 2;
    -ms-flex-order: 2;
    -webkit-order: 2;
    order: 2;
  }
}
#wedding-page .meals .image-container .note {
  font-size: 0.75em;
  margin-top: 0.5em;
}
#wedding-page .meals .prices {
  -webkit-box-flex: 1;
  -moz-box-flex: 1;
  -o-box-flex: 1;
  -ms-box-flex: 1;
  box-flex: 1;
  -webkit-flex-grow: 1;
  flex-grow: 1;
  margin-left: 2em;
}
@media screen and (max-width: 767px) {
  #wedding-page .meals .prices {
    -webkit-box-ordinal-group: 1;
    -moz-box-ordinal-group: 1;
    -o-box-ordinal-group: 1;
    -ms-flex-order: 1;
    -webkit-order: 1;
    order: 1;
    margin-left: 0;
  }
}
#wedding-page .meals .price {
  font-size: 1.375em;
  margin-left: 0.5em;
}
#wedding-page .meals .price-wrap {
  margin: 1em 0;
}
#wedding-page .meals .price-name {
  font-size: 1.675em;
  display: -webkit-box;
  display: -moz-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: box;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -o-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  color: #fff;
  background-color: rgba(198,0,52,0.9);
  width: 5em;
  height: 2em;
  padding-left: 0.75em;
}
#wedding-page .meals .price-name .en {
  font-size: 0.4em;
  margin-left: 0.5em;
}
#wedding-page .meals .tax-note {
  font-size: 0.5em;
  margin-left: 0.5em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-3 {
    margin-top: 2em;
  }
}
#wedding-page #section-3 ul.cakes {
  padding: 2em 0 4em;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-3 ul.cakes {
    padding: 1.5em;
  }
}
#wedding-page #section-3 ul.cakes > li {
  width: 31%;
}
@media screen and (max-width: 767px) {
  #wedding-page #section-3 ul.cakes > li {
    width: 100%;
  }
}
#wedding-page #section-3 ul.cakes img {
  width: 100%;
}
#wedding-page #section-3 ul.cakes .text {
  padding: 1em 0;
}
#wedding-page #section-3 ul.cakes .name {
  color: #c60034;
  margin-bottom: 0.75em;
  font-weight: bold;
}
#wedding-page #section-3 ul.cakes .desc {
  font-size: 0.875em;
  line-height: 1.4;
}


/* 2017-10 BW */
#enkai_hoji-page #section-food .descc {
  text-align: center;
  line-height: 1.6;
}



/* 2021-02-11 BW */	
#stay-page .flex-wrap .tax-note {
  font-size: 1.75em;
}
#restaurant-page #section-food .panel-noteInfo {
  text-align: center;
  font-size: 1.000em;
  color: #c60034;
  margin-top: 0.3em;
}

/* 2023-06-17 BW */	
.price-s {
font-size: 0.8000em;
/*text-decoration:overline;*/
}

#enkai_hoji-page #section-cancel {
  position: relative;
  padding-top: 0em;
line-height: 25px
}

#restaurant-page #section-tea-menu {
  position: relative;
  padding-top: 5em;
line-height: 25px
}

a {
  text-decoration: none;
}

.line {
  border-top: 1px solid black;
/*  width: 110px;*/
  align: left;
	}

.line10000 {
  border-top: 1px solid black;
  width: 110px;
  align: left;
	}

.line1000 {
  border-top: 1px solid black;
  width: 100px;
  align: left;
	}

.line100 {
  border-top: 1px solid black;
  width: 90px;
  align: left;
	}

.DetailBox {
    padding-top: 0.5em;
	padding-bottom: 0.5em;
	padding-left: 1.5em;
	padding-right: 1.5em;
	font-size: 13px;
    border: solid 1px #ffffff;
}

/*ティーラウンジ文修正*/
.tea-raunge-text{
	padding-left:35em;
	text-align: center;
	font-size:0.875em;
}

/*紫水御膳テキスト文修正*/
.sisui {font-size:0.875em;
	padding-left:1em; 
}

/*食事タイトルテキスト文修正*/
.title{
	font-size:45px; 
}

/*宴会タイトルテキスト文修正*/
.enkai-title {font-size:45px;
}

/*結婚式タイトルテキスト文修正*/
.wedding-title {
	font-size:45px;
}
/*div要素全体にリンクをつけるために必要な要素*/

