@charset "UTF-8";
.wrapper {
  max-width: 1920px;
  margin: 0 auto;
  position: relative; }
  @media screen and (max-width: 900px) {
    .wrapper {
      width: auto;
      margin: 0; } }

.col1 {
  margin-bottom: 0;
  margin-right: 0; }
  .col1:nth-child(1) {
    margin-right: 0; }
  @media screen and (max-width: 768px) {
    .col1 {
      width: 100%;
      margin-right: 0; } }
  .col1 img {
    width: 100%; }

.col2 {
  margin-bottom: 0;
  margin-right: 0; }
  .col2:nth-child(2) {
    margin-right: 0; }
  @media screen and (max-width: 768px) {
    .col2 {
      width: 100%;
      margin-right: 0; } }
  .col2 img {
    width: 100%; }

.col3 {
  margin-bottom: 0;
  margin-right: 0; }
  .col3:nth-child(3) {
    margin-right: 0; }
  @media screen and (max-width: 768px) {
    .col3 {
      width: 100%;
      margin-right: 0; } }
  .col3 img {
    width: 100%; }

.col4 {
  margin-bottom: 0;
  margin-right: 0; }
  .col4:nth-child(4) {
    margin-right: 0; }
  @media screen and (max-width: 768px) {
    .col4 {
      width: 100%;
      margin-right: 0; } }
  .col4 img {
    width: 100%; }

.col5 {
  margin-bottom: 0;
  margin-right: 0; }
  .col5:nth-child(5) {
    margin-right: 0; }
  @media screen and (max-width: 768px) {
    .col5 {
      width: 100%;
      margin-right: 0; } }
  .col5 img {
    width: 100%; }

.col6 {
  margin-bottom: 0;
  margin-right: 0; }
  .col6:nth-child(6) {
    margin-right: 0; }
  @media screen and (max-width: 768px) {
    .col6 {
      width: 100%;
      margin-right: 0; } }
  .col6 img {
    width: 100%; }

@keyframes humb {
  100% {
    background: rgba(0, 0, 0, 0); } }
@keyframes scaleOut {
  100% {
    transform: scale(0);
    opacity: 0; } }
@keyframes pageTransition {
  100% {
    transform: translateX(0); } }
@keyframes pageFadeout {
  0% {
    opacity: 1; }
  100% {
    opacity: 0; } }
@keyframes scaleIn {
  0% {
    transform: scale(0); }
  100% {
    transform: scale(1);
    opacity: 1; } }
@keyframes fadeIn {
  0% {
    opacity: 0; }
  20% {
    opacity: 0.4; }
  80% {
    opacity: 0.6; }
  100% {
    opacity: 1; } }
@keyframes slideIn {
  0% {
    transform: translate(0, 100%); }
  100% {
    transform: translate(0, 0); } }
@keyframes slideOut {
  0% {
    transform: translate(0, 0); }
  2% {
    transform: translate(1%, 1%); }
  10% {
    transform: translate(1%, 1%); }
  50% {
    transform: translate(50%, 50%); }
  100% {
    transform: translate(100%, 70%);
    opacity: 0; } }
@keyframes neon {
  40% {
    opacity: .85; }
  42% {
    opacity: .4; }
  43% {
    opacity: .85; }
  45% {
    opacity: .4; }
  46% {
    opacity: .85; } }
@keyframes PageAnime {
  0% {
    transform-origin: right;
    transform: scaleX(0); }
  50% {
    transform-origin: right;
    transform: scaleX(1); }
  50.001% {
    transform-origin: left; }
  100% {
    transform-origin: left;
    transform: scaleX(0); } }
@keyframes PageAnimeAppear {
  0% {
    opacity: 0; }
  20% {
    opacity: 0.4; }
  80% {
    opacity: 0.6; }
  100% {
    opacity: 1; } }
@keyframes right-move {
  0% {
    transform: scaleX(1); }
  100% {
    transform: scaleX(0);
    visibility: hidden; } }
@keyframes flowing-anim {
  0% {
    width: 0%; }
  100% {
    width: 100%; } }
@keyframes bgLRextendAnime {
  0% {
    transform-origin: right; }
  50% {
    transform-origin: right; }
  50.001% {
    transform-origin: right; }
  100% {
    transform-origin: right;
    transform: scaleX(0); } }
@keyframes bgRLextendAnime {
  0% {
    transform-origin: left; }
  50% {
    transform-origin: left; }
  50.001% {
    transform-origin: left; }
  100% {
    transform-origin: left;
    transform: scaleX(0); } }
.fx {
  opacity: 0;
  -webkit-transform: translate(0, 90px);
  transform: translate(0, 90px);
  backface-visibility: hidden;
  will-change: transform; }
  .fx .fxBox {
    opacity: 0;
    -webkit-transform: translate(0, 90px);
    transform: translate(0, 90px);
    backface-visibility: hidden;
    will-change: transform; }
  .fx .cols {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0); }
    .fx .cols .fxInr {
      opacity: 0;
      -webkit-transform: translate(0, 90px);
      transform: translate(0, 90px);
      backface-visibility: hidden;
      will-change: transform; }
  .fx .left {
    opacity: 0;
    -webkit-transform: translate(-150px, -90px);
    transform: translate(-150px, -90px);
    backface-visibility: hidden;
    will-change: transform; }
  .fx .right {
    opacity: 0;
    -webkit-transform: translate(150px, -90px);
    transform: translate(150px, -90px);
    backface-visibility: hidden;
    will-change: transform; }
  .fx.on {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
    -webkit-transition: ease 1s 0s;
    transition: ease 1s 0s;
    backface-visibility: hidden;
    overflow: hidden;
    will-change: transform; }
    .fx.on .fxBox {
      opacity: 1;
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0);
      -webkit-transition: ease 2s 0s;
      transition: ease 2s 0s;
      backface-visibility: hidden;
      will-change: transform; }
      .fx.on .fxBox:nth-child(1) {
        -webkit-transition: ease-out 0.6s 0.1s;
        transition: ease-out 0.6s 0.1s; }
      .fx.on .fxBox:nth-child(2) {
        -webkit-transition: ease-out 0.6s 0.3s;
        transition: ease-out 0.6s 0.3s; }
      .fx.on .fxBox:nth-child(3) {
        -webkit-transition: ease-out 0.6s 0.5s;
        transition: ease-out 0.6s 0.5s; }
      .fx.on .fxBox:nth-child(4) {
        -webkit-transition: ease-out 0.6s 0.7s;
        transition: ease-out 0.6s 0.7s; }
      .fx.on .fxBox:nth-child(5) {
        -webkit-transition: ease-out 0.6s 0.9s;
        transition: ease-out 0.6s 0.9s; }
      .fx.on .fxBox:nth-child(6) {
        -webkit-transition: ease-out 0.6s 1.1s;
        transition: ease-out 0.6s 1.1s; }
      .fx.on .fxBox:nth-child(7) {
        -webkit-transition: ease-out 0.6s 1.3s;
        transition: ease-out 0.6s 1.3s; }
      .fx.on .fxBox:nth-child(8) {
        -webkit-transition: ease-out 0.6s 1.5s;
        transition: ease-out 0.6s 1.5s; }
      .fx.on .fxBox:nth-child(9) {
        -webkit-transition: ease-out 0.6s 1.7s;
        transition: ease-out 0.6s 1.7s; }
      .fx.on .fxBox:nth-child(10) {
        -webkit-transition: ease-out 0.6s 1.9s;
        transition: ease-out 0.6s 1.9s; }
      .fx.on .fxBox:nth-child(11) {
        -webkit-transition: ease-out 0.6s 2.1s;
        transition: ease-out 0.6s 2.1s; }
      .fx.on .fxBox:nth-child(12) {
        -webkit-transition: ease-out 0.6s 2.3s;
        transition: ease-out 0.6s 2.3s; }
      .fx.on .fxBox:nth-child(13) {
        -webkit-transition: ease-out 0.6s 2.5s;
        transition: ease-out 0.6s 2.5s; }
      .fx.on .fxBox:nth-child(14) {
        -webkit-transition: ease-out 0.6s 2.7s;
        transition: ease-out 0.6s 2.7s; }
      .fx.on .fxBox:nth-child(15) {
        -webkit-transition: ease-out 0.6s 2.9s;
        transition: ease-out 0.6s 2.9s; }
      .fx.on .fxBox:nth-child(16) {
        -webkit-transition: ease-out 0.6s 3.1s;
        transition: ease-out 0.6s 3.1s; }
      .fx.on .fxBox:nth-child(17) {
        -webkit-transition: ease-out 0.6s 3.3s;
        transition: ease-out 0.6s 3.3s; }
      .fx.on .fxBox:nth-child(18) {
        -webkit-transition: ease-out 0.6s 3.5s;
        transition: ease-out 0.6s 3.5s; }
      .fx.on .fxBox:nth-child(19) {
        -webkit-transition: ease-out 0.6s 3.7s;
        transition: ease-out 0.6s 3.7s; }
      .fx.on .fxBox:nth-child(20) {
        -webkit-transition: ease-out 0.6s 3.9s;
        transition: ease-out 0.6s 3.9s; }
      .fx.on .fxBox:nth-child(21) {
        -webkit-transition: ease-out 0.6s 4.1s;
        transition: ease-out 0.6s 4.1s; }
      .fx.on .fxBox:nth-child(22) {
        -webkit-transition: ease-out 0.6s 4.3s;
        transition: ease-out 0.6s 4.3s; }
      .fx.on .fxBox:nth-child(23) {
        -webkit-transition: ease-out 0.6s 4.5s;
        transition: ease-out 0.6s 4.5s; }
      .fx.on .fxBox:nth-child(24) {
        -webkit-transition: ease-out 0.6s 4.7s;
        transition: ease-out 0.6s 4.7s; }
      .fx.on .fxBox:nth-child(25) {
        -webkit-transition: ease-out 0.6s 4.9s;
        transition: ease-out 0.6s 4.9s; }
      .fx.on .fxBox:nth-child(26) {
        -webkit-transition: ease-out 0.6s 5.1s;
        transition: ease-out 0.6s 5.1s; }
      .fx.on .fxBox:nth-child(27) {
        -webkit-transition: ease-out 0.6s 5.3s;
        transition: ease-out 0.6s 5.3s; }
      .fx.on .fxBox:nth-child(28) {
        -webkit-transition: ease-out 0.6s 5.5s;
        transition: ease-out 0.6s 5.5s; }
      .fx.on .fxBox:nth-child(29) {
        -webkit-transition: ease-out 0.6s 5.7s;
        transition: ease-out 0.6s 5.7s; }
      .fx.on .fxBox:nth-child(30) {
        -webkit-transition: ease-out 0.6s 5.9s;
        transition: ease-out 0.6s 5.9s; }
    .fx.on .cols .fxInr {
      opacity: 1;
      backface-visibility: hidden;
      will-change: transform;
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0);
      -webkit-transition: ease 2s 0.6s;
      transition: ease 2s 0.6s; }
      .fx.on .cols .fxInr:nth-child(1) {
        -webkit-transition: ease-out 0.6s 0.1s;
        transition: ease-out 0.6s 0.1s; }
      .fx.on .cols .fxInr:nth-child(2) {
        -webkit-transition: ease-out 0.6s 0.3s;
        transition: ease-out 0.6s 0.3s; }
      .fx.on .cols .fxInr:nth-child(3) {
        -webkit-transition: ease-out 0.6s 0.5s;
        transition: ease-out 0.6s 0.5s; }
      .fx.on .cols .fxInr:nth-child(4) {
        -webkit-transition: ease-out 0.6s 0.7s;
        transition: ease-out 0.6s 0.7s; }
      .fx.on .cols .fxInr:nth-child(5) {
        -webkit-transition: ease-out 0.6s 0.9s;
        transition: ease-out 0.6s 0.9s; }
      .fx.on .cols .fxInr:nth-child(6) {
        -webkit-transition: ease-out 0.6s 1.1s;
        transition: ease-out 0.6s 1.1s; }
      .fx.on .cols .fxInr:nth-child(7) {
        -webkit-transition: ease-out 0.6s 1.3s;
        transition: ease-out 0.6s 1.3s; }
      .fx.on .cols .fxInr:nth-child(8) {
        -webkit-transition: ease-out 0.6s 1.5s;
        transition: ease-out 0.6s 1.5s; }
      .fx.on .cols .fxInr:nth-child(9) {
        -webkit-transition: ease-out 0.6s 1.7s;
        transition: ease-out 0.6s 1.7s; }
      .fx.on .cols .fxInr:nth-child(10) {
        -webkit-transition: ease-out 0.6s 1.9s;
        transition: ease-out 0.6s 1.9s; }
      .fx.on .cols .fxInr:nth-child(11) {
        -webkit-transition: ease-out 0.6s 2.1s;
        transition: ease-out 0.6s 2.1s; }
      .fx.on .cols .fxInr:nth-child(12) {
        -webkit-transition: ease-out 0.6s 2.3s;
        transition: ease-out 0.6s 2.3s; }
      .fx.on .cols .fxInr:nth-child(13) {
        -webkit-transition: ease-out 0.6s 2.5s;
        transition: ease-out 0.6s 2.5s; }
      .fx.on .cols .fxInr:nth-child(14) {
        -webkit-transition: ease-out 0.6s 2.7s;
        transition: ease-out 0.6s 2.7s; }
      .fx.on .cols .fxInr:nth-child(15) {
        -webkit-transition: ease-out 0.6s 2.9s;
        transition: ease-out 0.6s 2.9s; }
      .fx.on .cols .fxInr:nth-child(16) {
        -webkit-transition: ease-out 0.6s 3.1s;
        transition: ease-out 0.6s 3.1s; }
      .fx.on .cols .fxInr:nth-child(17) {
        -webkit-transition: ease-out 0.6s 3.3s;
        transition: ease-out 0.6s 3.3s; }
      .fx.on .cols .fxInr:nth-child(18) {
        -webkit-transition: ease-out 0.6s 3.5s;
        transition: ease-out 0.6s 3.5s; }
      .fx.on .cols .fxInr:nth-child(19) {
        -webkit-transition: ease-out 0.6s 3.7s;
        transition: ease-out 0.6s 3.7s; }
      .fx.on .cols .fxInr:nth-child(20) {
        -webkit-transition: ease-out 0.6s 3.9s;
        transition: ease-out 0.6s 3.9s; }
      .fx.on .cols .fxInr:nth-child(21) {
        -webkit-transition: ease-out 0.6s 4.1s;
        transition: ease-out 0.6s 4.1s; }
      .fx.on .cols .fxInr:nth-child(22) {
        -webkit-transition: ease-out 0.6s 4.3s;
        transition: ease-out 0.6s 4.3s; }
      .fx.on .cols .fxInr:nth-child(23) {
        -webkit-transition: ease-out 0.6s 4.5s;
        transition: ease-out 0.6s 4.5s; }
      .fx.on .cols .fxInr:nth-child(24) {
        -webkit-transition: ease-out 0.6s 4.7s;
        transition: ease-out 0.6s 4.7s; }
      .fx.on .cols .fxInr:nth-child(25) {
        -webkit-transition: ease-out 0.6s 4.9s;
        transition: ease-out 0.6s 4.9s; }
      .fx.on .cols .fxInr:nth-child(26) {
        -webkit-transition: ease-out 0.6s 5.1s;
        transition: ease-out 0.6s 5.1s; }
      .fx.on .cols .fxInr:nth-child(27) {
        -webkit-transition: ease-out 0.6s 5.3s;
        transition: ease-out 0.6s 5.3s; }
      .fx.on .cols .fxInr:nth-child(28) {
        -webkit-transition: ease-out 0.6s 5.5s;
        transition: ease-out 0.6s 5.5s; }
      .fx.on .cols .fxInr:nth-child(29) {
        -webkit-transition: ease-out 0.6s 5.7s;
        transition: ease-out 0.6s 5.7s; }
      .fx.on .cols .fxInr:nth-child(30) {
        -webkit-transition: ease-out 0.6s 5.9s;
        transition: ease-out 0.6s 5.9s; }
    .fx.on .left {
      backface-visibility: hidden;
      opacity: 1;
      will-change: transform;
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0);
      -webkit-transition: ease 1s 0s;
      transition: ease 1s 0s; }
    .fx.on .right {
      backface-visibility: hidden;
      opacity: 1;
      will-change: transform;
      -webkit-transform: translate(0, 0);
      transform: translate(0, 0);
      -webkit-transition: ease 1s 0s;
      transition: ease 1s 0s; }

.fxside .left {
  opacity: 0;
  -webkit-transform: translate(-150px, 0);
  transform: translate(-150px, 0);
  backface-visibility: hidden;
  will-change: transform; }
.fxside .right {
  opacity: 0;
  -webkit-transform: translate(150px, 0);
  transform: translate(150px, 0);
  backface-visibility: hidden;
  will-change: transform; }
.fxside .bgLRextend::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-color: #8e0126;
  z-index: 10;
  transform: scaleX(1); }
.fxside .bgRLextend::before {
  content: "";
  top: 0;
  left: 0;
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #8e0126;
  z-index: 10;
  transform: scaleX(1); }
.fxside.on .left {
  backface-visibility: hidden;
  opacity: 1;
  will-change: transform;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -webkit-transition: ease 1s 0s;
  transition: ease 1s 0s; }
.fxside.on .right {
  backface-visibility: hidden;
  opacity: 1;
  will-change: transform;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -webkit-transition: ease 1s 0s;
  transition: ease 1s 0s; }
.fxside.on .bgLRextend::before {
  animation-name: bgLRextendAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-color: #8e0126;
  z-index: 10;
  transform: scaleX(1); }
.fxside.on .bgRLextend::before {
  animation-name: bgRLextendAnime;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
  content: "";
  top: 0;
  left: 0;
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #8e0126;
  z-index: 10;
  transform: scaleX(1); }

body #splash {
  position: fixed;
  top: 0;
  width: 100%;
  height: 100vh;
  background-color: white;
  z-index: 0;
  text-align: center;
  color: white; }
  body #splash #splash-logo {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    animation-name: fadeIn;
    animation-duration: 2.0s;
    animation-timing-function: ease;
    animation-fill-mode: forwards; }
body .splashbg {
  display: none; }
body #container {
  opacity: 0; }
body.appear #splash {
  animation-name: pageFadeout;
  animation-duration: 2.5s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards; }
  body.appear #splash #splash-logo {
    animation-name: pageFadeout;
    animation-duration: 1.5s;
    animation-timing-function: ease-in-out;
    animation-fill-mode: forwards; }
body.appear .splashbg {
  display: block;
  /*content: "";
  position:fixed;
  z-index: 999;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
  transform: scaleX(0);
  background-color: $keyColor;
  animation-name: PageAnime;
  animation-duration: 1.2s;
  animation-timing-function: ease-in-out;
  animation-fill-mode: forwards;
  animation-delay: 2.5s;*/ }
  body.appear .splashbg::before, body.appear .splashbg::after {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    transform-origin: right; }
  body.appear .splashbg::before {
    background-color: #8e0126;
    z-index: -1;
    animation: right-move 0.8s forwards;
    animation-delay: 1.5s; }
  body.appear .splashbg::after {
    transform-origin: left;
    background-color: black;
    z-index: -2;
    animation: right-move 0.8s forwards;
    animation-delay: 1.5s; }
body.appear #container {
  animation-name: PageAnimeAppear;
  animation-duration: 0.2s;
  animation-delay: 2.4s;
  animation-fill-mode: forwards;
  opacity: 0; }

.flowing {
  overflow: hidden;
  white-space: nowrap;
  animation: flowing-anim 0.3s forwards linear;
  animation-delay: 3.0s;
  width: 0; }

.flowing:nth-child(2) {
  animation-delay: 3.5s; }

.flowing:nth-child(3) {
  animation-delay: 4.0s; }

br.sp {
  display: none; }
  @media screen and (max-width: 375px) {
    br.sp {
      display: block; } }
@media screen and (max-width: 900px) {
  br.pc {
    display: none; } }

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.0;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0; }

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
  text-decoration: none; }

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */ }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.2;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline; }

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none; }

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none; }

/* border-box
   ========================================================================== */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

/* clearfix
   ========================================================================== */
.clearfix::after {
  content: "";
  display: block;
  clear: both; }

ul {
  margin: 0;
  padding: 0;
  list-style: none; }

html body main article {
  /* 1行目：スライド */
  /* 2行目：コントロール（左右ボタン＋中央ドット） */
  /* 中央のドット */
  /* 円リング（36pxで中央に） */
  /* 矢印画像（button内の <img class="arrow"> を1枚） */
  /* 左端=中心 */
  /* 右端=中心 */
  /* ホバー/フォーカスで“外側へ5px”だけ移動（PCホバー端末） */
  /* キーボード操作の視認性（任意） */
  /* 押下時フィードバック（任意） */
  /* 縦位置はもう中央固定なのでscaleのみ */
  /* 動きを抑制設定しているユーザーに配慮 */
  /* モバイル微調整（任意） */ }
  html body main article section .fade-section, html body main article section .fade-section.four {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity 0.8s ease-out, transform 0.8s ease-out; }
    html body main article section .fade-section.is-visible, html body main article section .fade-section.four.is-visible {
      opacity: 1;
      transform: translateY(0); }
    html body main article section .fade-section.posi, html body main article section .fade-section.four.posi {
      position: relative;
      z-index: 3; }
    html body main article section .fade-section.db, html body main article section .fade-section.four.db {
      transition-delay: 0.3s; }
  html body main article section .fade-section.four:nth-child(1) {
    transition-delay: 0.1s; }
  html body main article section .fade-section.four:nth-child(2) {
    transition-delay: 0.3s; }
  html body main article section .fade-section.four:nth-child(3) {
    transition-delay: 0.5s; }
  html body main article section .fade-section.four:nth-child(4) {
    transition-delay: 0.7s; }
  html body main article section#title {
    position: relative;
    padding: 0 0 180px;
    background-color: #8e0126; }
    @media screen and (max-width: 768px) {
      html body main article section#title {
        margin: -1px 0 0 0; } }
    html body main article section#title .snow {
      animation: fall 10s linear infinite;
      z-index: 3;
      color: snow;
      font-size: 10px;
      position: absolute;
      inset: -5% 0 auto 0;
      text-shadow: 5vw  -100px 2px, 10vw -400px 3px, 20vw -500px 4px, 30vw -580px 1px, 39vw  -250px 2px, 42vw -340px 5px, 56vw -150px 2px, 63vw -180px 0px, 78vw  -220px 4px, 86vw -320px 9px, 94vw -170px 7px, 8vw  -300px 3px, 16vw -520px 1px, 24vw -700px 5px, 33vw -260px 2px, 41vw  -640px 4px, 52vw -330px 2px, 67vw -780px 1px, 72vw -430px 4px, 90vw  -590px 2px, 98vw -140px 3px,   2vw  -240px 2px, 11vw -680px 3px, 17vw -360px 1px, 23vw -900px 4px, 27vw  -120px 2px, 34vw -540px 6px, 36vw -260px 2px, 43vw -700px 5px, 48vw  -380px 3px, 50vw -820px 1px, 58vw -460px 4px, 60vw -240px 2px, 66vw  -680px 3px, 73vw -340px 5px, 76vw -760px 2px, 83vw -420px 4px, 88vw  -200px 1px, 92vw -580px 3px, 96vw -300px 2px, 99vw -720px 5px; }
      @media screen and (max-width: 768px) {
        html body main article section#title .snow {
          animation: fall 18s linear infinite; } }
    html body main article section#title .snow2nd {
      animation: fall 15s linear infinite;
      font-size: 8px;
      animation-delay: -3s;
      z-index: 3;
      position: absolute;
      inset: -2% 0 auto 0;
      text-shadow: 7vw -140px 4px, 19vw -300px 3px, 33vw -520px 5px, 47vw -740px 2px, 61vw -260px 6px, 75vw -480px 4px, 89vw -680px 3px, 14vw -360px 5px, 28vw -600px 4px, 52vw -820px 3px, 5vw -200px 5px,  9vw -560px 3px, 15vw -420px 4px, 22vw -780px 2px, 27vw -240px 6px, 35vw -620px 3px, 41vw -320px 5px, 48vw -840px 2px, 55vw -460px 4px, 63vw -140px 3px, 68vw -600px 5px, 74vw -360px 2px, 81vw -740px 4px, 87vw -260px 6px, 93vw -520px 3px; }
      @media screen and (max-width: 768px) {
        html body main article section#title .snow2nd {
          animation: fall 17s linear infinite; } }
    html body main article section#title .snow3rd {
      animation: fall 19s linear infinite;
      font-size: 8px;
      animation-delay: -6s;
      z-index: 3;
      position: absolute;
      inset: -10% 0 auto 0;
      position: absolute;
      text-shadow: 4vw -180px 2px, 12vw -620px 1px, 26vw -340px 3px, 38vw -760px 2px, 45vw -420px 4px, 58vw -210px 1px, 70vw -600px 3px, 82vw -260px 2px, 93vw -520px 1px, 99vw -150px 2px,3vw -220px 1px, 11vw -680px 2px, 18vw -340px 3px, 25vw -760px 1px, 31vw -420px 2px, 44vw -210px 3px, 49vw -600px 1px, 57vw -260px 2px, 64vw -520px 1px, 72vw -150px 2px, 79vw -640px 3px, 85vw -330px 2px, 91vw -740px 1px; }
    html body main article section#title .snow4th {
      z-index: 3;
      color: snow;
      font-size: 11px;
      position: absolute;
      inset: -7% 0 auto 0;
      animation: fall 13s linear infinite;
      animation-delay: -1.6s;
      text-shadow: 6vw -160px 3px, 18vw -360px 4px, 29vw -600px 2px, 41vw -820px 5px, 53vw -280px 3px, 65vw -520px 4px, 77vw -740px 2px, 88vw -200px 4px, 9vw -560px 3px, 24vw -420px 4px, 36vw -900px 2px, 50vw -340px 3px, 62vw -780px 5px, 71vw -260px 2px, 84vw -620px 4px, 96vw -140px 3px, 2vw -700px 2px, 14vw -300px 3px, 27vw -660px 4px, 58vw -430px 3px; }
      @media screen and (max-width: 768px) {
        html body main article section#title .snow4th {
          animation: fall 20s linear infinite; } }
@keyframes fall {
  0% {
    transform: translateY(0); }
  90% {
    opacity: 1; }
  100% {
    transform: translateY(110%);
    top: 100%;
    opacity: 0; } }
@keyframes roll {
  0% {
    transform: translateY(0) rotate(0deg); }
  90% {
    opacity: 1; }
  100% {
    transform: translateY(110%) rotate(20deg);
    top: 100%;
    opacity: 0; } }
@keyframes anim {
  100% {
    color: transparent;
    top: 150%; } }
    html body main article section#title .image-container {
      position: relative;
      display: block; }
      html body main article section#title .image-container .overlay {
        position: absolute;
        inset: 0;
        background-color: rgba(0, 0, 0, 0.5);
        backdrop-filter: blur(3px);
        -webkit-backdrop-filter: blur(3px);
        pointer-events: none;
        z-index: 1; }
      html body main article section#title .image-container .image-wrap {
        position: relative;
        display: block;
        width: 100%; }
        html body main article section#title .image-container .image-wrap::after {
          content: "";
          position: absolute;
          right: 0;
          z-index: 3;
          pointer-events: none;
          background-image: url("../image/star.png");
          background-size: contain;
          background-repeat: no-repeat;
          width: 100%;
          height: calc(100vw * 6 / 16);
          bottom: calc(-100vw * 9 / 45);
          max-height: 720px;
          min-height: 360px; }
          @media screen and (min-width: 1920px) {
            html body main article section#title .image-container .image-wrap::after {
              bottom: calc(-100vw * 9 / 40); } }
          @media screen and (max-width: 768px) {
            html body main article section#title .image-container .image-wrap::after {
              content: none; } }
        html body main article section#title .image-container .image-wrap img {
          display: block;
          width: 100%;
          height: 100vh;
          object-fit: cover;
          position: relative; }
          @media screen and (max-width: 1280px) {
            html body main article section#title .image-container .image-wrap img.imgpc {
              width: 100%; } }
          @media screen and (max-width: 768px) {
            html body main article section#title .image-container .image-wrap img.imgpc {
              display: none; } }
          html body main article section#title .image-container .image-wrap img.imgsp {
            display: none; }
            @media screen and (max-width: 768px) {
              html body main article section#title .image-container .image-wrap img.imgsp {
                display: block;
                height: 100vh; } }
      html body main article section#title .image-container .kv-inner {
        position: absolute;
        top: 0;
        right: 0;
        z-index: 2;
        padding: 170px 70px 0 0;
        margin: 0; }
        @media (max-height: 900px) {
          html body main article section#title .image-container .kv-inner {
            padding-top: clamp(120px, 14svh, 170px); } }
        @media (max-height: 800px) {
          html body main article section#title .image-container .kv-inner {
            padding-top: clamp(90px, 12svh, 170px); } }
        @media (max-height: 700px) {
          html body main article section#title .image-container .kv-inner {
            padding-top: clamp(70px, 11svh, 170px); } }
        @media screen and (min-width: 1280px) {
          html body main article section#title .image-container .kv-inner {
            right: calc(50% - 640px + 70px); } }
        @media screen and (max-width: 1250px) {
          html body main article section#title .image-container .kv-inner {
            padding: 120px 70px 0 0; } }
        @media screen and (max-width: 768px) {
          html body main article section#title .image-container .kv-inner {
            width: 100%;
            padding: 120px 0 0 50px;
            display: flex;
            flex-direction: column; } }
        @media screen and (max-width: 520px) {
          html body main article section#title .image-container .kv-inner {
            padding: 0 0 0 20px;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%); } }
        html body main article section#title .image-container .kv-inner h1 {
          margin: 0 0 30px 0;
          width: 633px;
          position: relative; }
          @media screen and (max-width: 1250px) {
            html body main article section#title .image-container .kv-inner h1 {
              width: 480px; } }
          @media screen and (max-width: 768px) {
            html body main article section#title .image-container .kv-inner h1 {
              width: 345px; } }
          @media screen and (max-width: 520px) {
            html body main article section#title .image-container .kv-inner h1 {
              width: 325px; } }
          html body main article section#title .image-container .kv-inner h1::before {
            content: "";
            position: absolute;
            bottom: -30px;
            left: -116px;
            z-index: 2;
            pointer-events: none;
            background-image: url("../image/title-star01.png");
            background-repeat: no-repeat;
            width: 236px;
            height: 266px;
            transform: scale(0.5); }
            @media screen and (max-width: 1100px) {
              html body main article section#title .image-container .kv-inner h1::before {
                bottom: -50px;
                transform: scale(0.4); } }
            @media screen and (max-width: 768px) {
              html body main article section#title .image-container .kv-inner h1::before {
                bottom: -80px;
                left: -95px;
                transform: scale(0.25); } }
          html body main article section#title .image-container .kv-inner h1::after {
            content: "";
            position: absolute;
            top: 55px;
            right: -80px;
            z-index: 2;
            pointer-events: none;
            background-image: url("../image/title-star03.png");
            background-repeat: no-repeat;
            width: 139px;
            height: 140px;
            transform: scale(0.5); }
            @media screen and (max-width: 1100px) {
              html body main article section#title .image-container .kv-inner h1::after {
                top: 27px;
                right: -100px;
                transform: scale(0.4); } }
            @media screen and (max-width: 768px) {
              html body main article section#title .image-container .kv-inner h1::after {
                top: -15px;
                right: -57px;
                transform: scale(0.3); } }
          html body main article section#title .image-container .kv-inner h1 img {
            width: 100%;
            height: auto;
            display: block;
            margin-inline: auto; }
            @media screen and (max-width: 768px) {
              html body main article section#title .image-container .kv-inner h1 img.imgpc {
                display: none; } }
            html body main article section#title .image-container .kv-inner h1 img.imgsp {
              display: none; }
              @media screen and (max-width: 768px) {
                html body main article section#title .image-container .kv-inner h1 img.imgsp {
                  display: block; } }
        html body main article section#title .image-container .kv-inner .star {
          position: relative; }
          html body main article section#title .image-container .kv-inner .star::before {
            content: "";
            position: absolute;
            top: -320px;
            left: 525px;
            z-index: 2;
            pointer-events: none;
            background-image: url("../image/title-star02.png");
            background-repeat: no-repeat;
            width: 110px;
            height: 110px;
            transform: scale(0.5); }
            @media screen and (max-width: 1100px) {
              html body main article section#title .image-container .kv-inner .star::before {
                top: -245px;
                left: 380px;
                transform: scale(0.4); } }
            @media screen and (max-width: 768px) {
              html body main article section#title .image-container .kv-inner .star::before {
                top: -206px;
                left: 240px;
                transform: scale(0.3); } }
            @media screen and (max-width: 520px) {
              html body main article section#title .image-container .kv-inner .star::before {
                top: -197px;
                left: 222px;
                transform: scale(0.3); } }
        html body main article section#title .image-container .kv-inner p.txt {
          display: inline-block;
          font-size: 1.15625rem;
          font-weight: 600;
          margin: 0;
          color: white;
          line-height: 1.7;
          letter-spacing: 0.06em; }
          @media screen and (max-width: 768px) {
            html body main article section#title .image-container .kv-inner p.txt {
              font-size: 0.9375rem; } }
          html body main article section#title .image-container .kv-inner p.txt .brsp {
            display: none; }
            @media screen and (max-width: 768px) {
              html body main article section#title .image-container .kv-inner p.txt .brsp {
                display: block; } }
    @media screen and (max-width: 768px) {
      html body main article section#title .image-wrap::before, html body main article section#title .image-wrap::after {
        content: none; }
      html body main article section#title .image-container {
        position: relative;
        min-height: 100dvh; }
      html body main article section#title .image-container::before, html body main article section#title .image-container::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: -1px;
        background-repeat: no-repeat;
        background-position: bottom center;
        background-size: contain;
        pointer-events: none; }
      html body main article section#title .image-container::before {
        height: 110px;
        background-image: url("../image/nami-sp.png");
        z-index: 2; }
      html body main article section#title .image-container::after {
        height: 100%;
        background-image: url("../image/star-sp.png");
        z-index: 3; }
      html body main article section#title .image-container .kv-inner {
        z-index: 4; }
      html body main article section#title .image-container .overlay {
        z-index: 1; } }
    html body main article section#title .starbox, html body main article section#title .starbox2 {
      position: relative;
      z-index: 5; }
      html body main article section#title .starbox::before, html body main article section#title .starbox2::before {
        content: "";
        position: absolute;
        top: -230px;
        left: 16%;
        transform: translate(-50%, -200px);
        width: 100px;
        height: 100px;
        background: url("../image/star-kaiten.png") no-repeat center/cover;
        opacity: 0;
        transform: scale(0.8) rotatey(0deg);
        animation: fadeIn 1.5s ease-out forwards, spinY 6s linear infinite; }
      html body main article section#title .starbox::after, html body main article section#title .starbox2::after {
        content: "";
        position: absolute;
        top: -114px;
        right: 12%;
        width: 100px;
        height: 100px;
        background: url("../image/star-kaiten.png") no-repeat center/cover;
        opacity: 0;
        transform: scale(0.8) rotatey(0deg);
        animation: fadeIn 1.5s ease-out forwards, spinY 8s linear infinite; }
    html body main article section#title .starbox2::before {
      top: 253px;
      left: 7%;
      transform: scale(0.8) rotatey(0deg);
      animation: fadeIn 1.5s ease-out forwards, spinY 10s linear infinite; }
      @media screen and (max-width: 768px) {
        html body main article section#title .starbox2::before {
          top: 138px;
          right: 23%; } }
      @media screen and (max-width: 520px) {
        html body main article section#title .starbox2::before {
          width: 50px;
          height: 50px;
          top: 142px;
          right: 52%; } }
    html body main article section#title .starbox2::after {
      top: 169px;
      right: 14%;
      transform: scale(0.8) rotatey(0deg);
      animation: fadeIn 1.5s ease-out forwards, spinY 7s linear infinite; }
      @media screen and (max-width: 768px) {
        html body main article section#title .starbox2::after {
          top: 44px;
          right: 11%; } }
      @media screen and (max-width: 520px) {
        html body main article section#title .starbox2::after {
          width: 50px;
          height: 50px;
          top: 40px;
          right: 20%; } }
    @media screen and (min-width: 1920px) {
      html body main article section#title .starbox::before {
        transform: scale(1) rotatey(0deg); } }
    @media screen and (max-width: 1250px) {
      html body main article section#title .starbox::before {
        top: -180px; } }
    @media screen and (max-width: 768px) {
      html body main article section#title .starbox::before {
        display: none; } }
    @media screen and (max-width: 768px) {
      html body main article section#title .starbox::after {
        top: -176px;
        right: 53%; } }
    @media screen and (max-width: 520px) {
      html body main article section#title .starbox::after {
        top: -109px;
        right: 47%; } }
@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: scale(0.8) rotate(0deg); }
  100% {
    opacity: 1;
    transform: scale(1) rotate(0deg); } }
@keyframes spin {
  from {
    transform: rotate(0deg); }
  to {
    transform: rotate(360deg); } }
@keyframes spinY {
  from {
    transform: rotateY(0deg); }
  to {
    transform: rotateY(360deg); } }
    html body main article section#title .hanging {
      position: absolute;
      top: 100%;
      left: 50%;
      transform: translateX(-50%); }
    html body main article section#title .swing-object {
      width: 50px;
      transform-origin: top center;
      position: absolute; }
      @media screen and (max-width: 900px) {
        html body main article section#title .swing-object.left01, html body main article section#title .swing-object.left02 {
          width: 30px; }
        html body main article section#title .swing-object.right01, html body main article section#title .swing-object.right02 {
          width: 40px; } }
      html body main article section#title .swing-object.left01 {
        left: -50px;
        top: -4px; }
        @media screen and (max-width: 900px) {
          html body main article section#title .swing-object.left01 {
            left: -192px;
            top: 159px; } }
      html body main article section#title .swing-object.left02 {
        left: -84px;
        top: -18px; }
        @media screen and (max-width: 900px) {
          html body main article section#title .swing-object.left02 {
            left: 135px;
            top: -25px; } }
      html body main article section#title .swing-object.right01 {
        left: 34px;
        top: -13px; }
        @media screen and (max-width: 900px) {
          html body main article section#title .swing-object.right01 {
            left: -152px;
            top: 130px; } }
      html body main article section#title .swing-object.right02 {
        left: -6px;
        top: -2px; }
        @media screen and (max-width: 900px) {
          html body main article section#title .swing-object.right02 {
            left: 187px;
            top: -66px; } }
      html body main article section#title .swing-object.swing {
        animation: swingAnim 1.2s ease-in-out; }
      html body main article section#title .swing-object.right.swing {
        animation-delay: 0.2s; }
@keyframes swingAnim {
  0% {
    transform: rotate(0deg); }
  15% {
    transform: rotate(15deg); }
  30% {
    transform: rotate(-12deg); }
  45% {
    transform: rotate(9deg); }
  60% {
    transform: rotate(-6deg); }
  75% {
    transform: rotate(3deg); }
  90% {
    transform: rotate(-1.5deg); }
  100% {
    transform: rotate(0deg); } }
    html body main article section#title .anchor-menu {
      background-image: url("../image/nami05.png");
      padding: 0 0 190px 0;
      position: relative;
      z-index: 2;
      margin: -174px 0 0 0;
      background-size: 100%;
      background-repeat: no-repeat; }
      @media screen and (min-width: 1920px) {
        html body main article section#title .anchor-menu {
          margin: -300px 0 0 0; } }
      @media screen and (max-width: 768px) {
        html body main article section#title .anchor-menu {
          background-image: none;
          margin: 0;
          background-color: #8e0126; } }
      html body main article section#title .anchor-menu::before {
        content: "";
        position: absolute;
        top: 155px;
        left: 40px;
        z-index: 0;
        pointer-events: none;
        background-image: url("../image/anker-bg03.png");
        background-repeat: no-repeat;
        width: 245px;
        height: 70px; }
        @media screen and (max-width: 768px) {
          html body main article section#title .anchor-menu::before {
            top: 21px;
            left: 20px;
            background-image: url("../image/anker-bg-sp01.png");
            width: 94px;
            height: 178px; } }
      html body main article section#title .anchor-menu::after {
        content: "";
        position: absolute;
        top: 280px;
        right: 50px;
        z-index: 0;
        pointer-events: none;
        background-image: url("../image/anker-bg04.png");
        background-repeat: no-repeat;
        width: 118px;
        height: 145px; }
        @media screen and (max-width: 768px) {
          html body main article section#title .anchor-menu::after {
            top: 17px;
            right: 11px;
            background-image: url("../image/anker-bg-sp02.png");
            width: 88px;
            height: 178px; } }
      @media screen and (max-width: 900px) {
        html body main article section#title .anchor-menu {
          padding: 80px 0 180px; } }
      html body main article section#title .anchor-menu .anchor-menu__wrap {
        display: grid;
        grid-template-columns: repeat(5, 239px);
        justify-content: center;
        position: relative;
        z-index: 2;
        padding: 200px 0 0 0; }
        @media screen and (max-width: 900px) {
          html body main article section#title .anchor-menu .anchor-menu__wrap {
            grid-template-columns: repeat(2, 160px);
            gap: 20px 16px;
            justify-content: center;
            justify-items: center; } }
        @media screen and (max-width: 768px) {
          html body main article section#title .anchor-menu .anchor-menu__wrap {
            padding: 0; } }
        html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item {
          position: relative;
          display: grid;
          z-index: 5; }
          @media screen and (max-width: 900px) {
            html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item {
              transform: none !important; } }
          html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item .menu-item__title {
            position: relative;
            display: inline-block;
            margin: 0;
            width: 239px; }
            @media screen and (max-width: 900px) {
              html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item .menu-item__title {
                width: 160px; } }
            html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item .menu-item__title .ank-img {
              display: block;
              width: 100%;
              height: auto; }
            html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item .menu-item__title::after {
              content: "";
              position: absolute;
              inset: 0;
              background: center/contain no-repeat url("../image/cake-hover.png");
              opacity: 0;
              transition: opacity 0.5s ease-in-out;
              pointer-events: none;
              will-change: opacity; }
          html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:hover .menu-item__title::after {
            opacity: 1; }
        html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(1) {
          grid-column: 2;
          grid-row: 1;
          transform: translateX(80px); }
          @media screen and (max-width: 900px) {
            html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(1) {
              grid-column: 1 / span 2;
              grid-row: 1; } }
        html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(2) {
          grid-column: 4;
          grid-row: 1;
          transform: translateX(-80px); }
          @media screen and (max-width: 900px) {
            html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(2) {
              grid-column: 1;
              grid-row: 2; } }
          html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(2) .menu-item__title::after {
            background-image: url("../image/stay-hover.png"); }
        html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(3) {
          grid-column: 1;
          grid-row: 2;
          transform: translate(160px, -16px); }
          @media screen and (max-width: 900px) {
            html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(3) {
              grid-column: 2;
              grid-row: 2; } }
          html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(3) .menu-item__title::after {
            background-image: url("../image/rest-hover.png"); }
        html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(4) {
          grid-column: 3;
          grid-row: 2;
          transform: translateY(-16px); }
          @media screen and (max-width: 900px) {
            html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(4) {
              grid-column: 1;
              grid-row: 3; } }
          html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(4) .menu-item__title::after {
            background-image: url("../image/salon-hover.png"); }
        html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(5) {
          grid-column: 5;
          grid-row: 2;
          transform: translate(-160px, -16px); }
          @media screen and (max-width: 900px) {
            html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(5) {
              grid-column: 2;
              grid-row: 3; } }
          html body main article section#title .anchor-menu .anchor-menu__wrap .menu-item:nth-child(5) .menu-item__title::after {
            background-image: url("../image/show-hover.png"); }
  html body main article section#deco {
    background-color: #8e0126;
    padding: 0 0 180px 0; }
    @media screen and (max-width: 768px) {
      html body main article section#deco {
        margin: -1px 0 0 0; } }
    html body main article section#deco .container.inner {
      display: flex;
      align-items: center;
      gap: 120px;
      max-width: 1080px;
      margin: 0 auto;
      padding: 0 0 60px 0; }
      @media screen and (max-width: 1100px) {
        html body main article section#deco .container.inner {
          flex-direction: column-reverse;
          margin: 0 50px;
          gap: 0; } }
      @media screen and (max-width: 768px) {
        html body main article section#deco .container.inner {
          margin: 0; } }
      html body main article section#deco .container.inner .info {
        flex: 1.0; }
        @media screen and (max-width: 1100px) {
          html body main article section#deco .container.inner .info {
            margin: 56px 50px 0; } }
        @media screen and (max-width: 768px) {
          html body main article section#deco .container.inner .info {
            margin: 0 20px; } }
        html body main article section#deco .container.inner .info h2 {
          font-size: 3rem;
          font-weight: 700;
          margin: 0 0 16px 0;
          letter-spacing: 0.05em;
          color: white; }
          @media screen and (max-width: 768px) {
            html body main article section#deco .container.inner .info h2 {
              font-size: 2.1875rem;
              line-height: 1.2; } }
          html body main article section#deco .container.inner .info h2 .brsp {
            display: none; }
            @media screen and (max-width: 768px) {
              html body main article section#deco .container.inner .info h2 .brsp {
                display: block; } }
        html body main article section#deco .container.inner .info .sub {
          display: block;
          font-family: "Noto Serif JP", serif;
          font-size: 1.25rem;
          font-weight: 700;
          margin: 0 0 56px 0;
          color: white; }
          @media screen and (max-width: 768px) {
            html body main article section#deco .container.inner .info .sub {
              font-size: 1rem;
              margin: 0 0 40px 0; } }
        html body main article section#deco .container.inner .info p {
          font-size: 1.125rem;
          font-weight: 400;
          line-height: 1.5;
          letter-spacing: 0.04em;
          color: white; }
          @media screen and (max-width: 768px) {
            html body main article section#deco .container.inner .info p {
              font-size: 1rem; } }
          html body main article section#deco .container.inner .info p.date {
            margin: 0 0 40px 0; }
            @media screen and (max-width: 768px) {
              html body main article section#deco .container.inner .info p.date {
                margin: 0 0 24px 0; } }
            html body main article section#deco .container.inner .info p.date span {
              margin: 0 16px; }
          html body main article section#deco .container.inner .info p.txt {
            margin: 0 0 56px 0; }
            @media screen and (max-width: 768px) {
              html body main article section#deco .container.inner .info p.txt {
                margin: 0 0 40px 0; } }
        html body main article section#deco .container.inner .info .ig-cta {
          display: flex;
          align-items: center;
          padding: 19px 40px;
          border: 1px solid #8e0126;
          border-radius: 9999px;
          background: white;
          color: #8e0126;
          font-size: 1.25rem;
          font-weight: 700;
          gap: 24px;
          line-height: 1.2;
          letter-spacing: 0.04em;
          transition: background-color 0.4s ease-in-out, color 0.4s ease-in-out,border-color 0.4s ease-in-out; }
          @media screen and (max-width: 768px) {
            html body main article section#deco .container.inner .info .ig-cta {
              font-size: 1rem;
              padding: 16px 32px;
              gap: 16px;
              width: 332px;
              margin: 0 auto; } }
          html body main article section#deco .container.inner .info .ig-cta span {
            margin: 0; }
        html body main article section#deco .container.inner .info .ig-cta, html body main article section#deco .container.inner .info .ig-cta:link, html body main article section#deco .container.inner .info .ig-cta:visited {
          color: #8e0126 !important; }
        html body main article section#deco .container.inner .info .ig-cta * {
          color: inherit; }
        html body main article section#deco .container.inner .info .ig-cta__icon {
          position: relative;
          inline-size: 24px;
          block-size: 24px; }
        html body main article section#deco .container.inner .info .ig-cta__icon img {
          position: absolute;
          inset: 0;
          width: 100%;
          height: 100%;
          object-fit: contain;
          transition: opacity 0.4s ease-in-out;
          will-change: opacity; }
        html body main article section#deco .container.inner .info .ig-cta__icon img.normal {
          opacity: 1; }
        html body main article section#deco .container.inner .info .ig-cta__icon img.hover {
          opacity: 0; }
        html body main article section#deco .container.inner .info .ig-cta__text {
          white-space: nowrap; }
        html body main article section#deco .container.inner .info .ig-cta__text .jp {
          margin: 0; }
          @media screen and (max-width: 768px) {
            html body main article section#deco .container.inner .info .ig-cta__text .jp {
              display: block; } }
        html body main article section#deco .container.inner .info .ig-cta__arrow {
          position: relative;
          margin-left: auto;
          inline-size: 37px;
          block-size: 37px; }
        html body main article section#deco .container.inner .info .ig-cta__arrow img {
          position: absolute;
          inset: 0;
          width: 100%;
          height: 100%;
          object-fit: contain;
          transition: opacity 0.4s ease-in-out;
          will-change: opacity; }
        html body main article section#deco .container.inner .info .ig-cta__arrow img.normal {
          opacity: 1; }
        html body main article section#deco .container.inner .info .ig-cta__arrow img.hover {
          opacity: 0; }
        html body main article section#deco .container.inner .info .ig-cta:is(:hover, :focus-visible) {
          background: #8e0126;
          color: white !important;
          border-color: white; }
        html body main article section#deco .container.inner .info .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
        html body main article section#deco .container.inner .info .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal {
          opacity: 0; }
        html body main article section#deco .container.inner .info .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
        html body main article section#deco .container.inner .info .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
          opacity: 1; }
        html body main article section#deco .container.inner .info .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
          transform: translateX(4px);
          transition: opacity 0.4s ease-in-out, transform 0.3s ease; }
        html body main article section#deco .container.inner .info .ig-cta:focus-visible {
          outline: 2px solid white; }
        @media (max-width: 420px) {
          html body main article section#deco .container.inner .info .ig-cta {
            white-space: normal; } }
      html body main article section#deco .container.inner .photo {
        width: 440px;
        height: 510px; }
        @media screen and (max-width: 1100px) {
          html body main article section#deco .container.inner .photo {
            margin: 0 auto 66px auto; } }
        @media screen and (max-width: 768px) {
          html body main article section#deco .container.inner .photo {
            width: 335px;
            height: 100%; } }
  html body main article section#cake, html body main article section#stay, html body main article section#restaurant {
    position: relative;
    margin: -75px 0 0 0; }
    @media screen and (max-width: 1100px) {
      html body main article section#cake, html body main article section#stay, html body main article section#restaurant {
        margin: -82px 0 0 0; } }
    html body main article section#cake::before, html body main article section#stay::before, html body main article section#restaurant::before {
      content: "";
      display: block;
      position: absolute;
      top: 0;
      left: 50%;
      transform: translateX(-50%);
      width: 100%;
      height: 100%;
      background-image: url(../image/cake-bg.png);
      background-repeat: no-repeat;
      background-size: cover;
      background-size: 100% 100%;
      background-position: top center;
      z-index: 1; }
      @media screen and (max-width: 900px) {
        html body main article section#cake::before, html body main article section#stay::before, html body main article section#restaurant::before {
          background-image: url(../image/cake-bg-sp.png);
          background-position: initial; } }
    html body main article section#cake .col-inner, html body main article section#stay .col-inner, html body main article section#restaurant .col-inner {
      position: relative;
      display: flex;
      justify-content: center;
      align-items: center;
      flex-direction: column;
      padding: 175px 0 160px 0;
      z-index: 2; }
      @media screen and (max-width: 768px) {
        html body main article section#cake .col-inner, html body main article section#stay .col-inner, html body main article section#restaurant .col-inner {
          padding: 175px 20px 160px 20px; } }
      html body main article section#cake .col-inner::before, html body main article section#stay .col-inner::before, html body main article section#restaurant .col-inner::before {
        content: "";
        display: block;
        position: absolute;
        top: 75px;
        left: 0;
        right: 0;
        width: 130px;
        height: 50px;
        margin: 0 auto;
        background-image: url(../image/cake-top.png);
        background-repeat: no-repeat;
        background-size: cover;
        z-index: 2; }
      html body main article section#cake .col-inner h2, html body main article section#stay .col-inner h2, html body main article section#restaurant .col-inner h2 {
        font-family: "Baskervville", serif;
        font-size: 3rem;
        font-weight: 700;
        margin: 0 0 16px 0;
        letter-spacing: 0.05em;
        color: #8e0126;
        text-align: center; }
        @media screen and (max-width: 768px) {
          html body main article section#cake .col-inner h2, html body main article section#stay .col-inner h2, html body main article section#restaurant .col-inner h2 {
            font-size: 2.1875rem;
            line-height: 1.2; } }
        html body main article section#cake .col-inner h2 .brsp, html body main article section#stay .col-inner h2 .brsp, html body main article section#restaurant .col-inner h2 .brsp {
          display: none; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner h2 .brsp, html body main article section#stay .col-inner h2 .brsp, html body main article section#restaurant .col-inner h2 .brsp {
              display: block; } }
      html body main article section#cake .col-inner .sub, html body main article section#stay .col-inner .sub, html body main article section#restaurant .col-inner .sub {
        display: block;
        font-family: "Noto Serif JP", serif;
        font-size: 1.25rem;
        font-weight: 700;
        margin: 0 0 24px 0;
        color: #8e0126;
        letter-spacing: 0.04em;
        text-align: center; }
        @media screen and (max-width: 768px) {
          html body main article section#cake .col-inner .sub, html body main article section#stay .col-inner .sub, html body main article section#restaurant .col-inner .sub {
            font-size: 1rem;
            margin: 0 0 24px 0; } }
      html body main article section#cake .col-inner p.txt, html body main article section#stay .col-inner p.txt, html body main article section#restaurant .col-inner p.txt {
        font-size: 1.125rem;
        font-weight: 500;
        line-height: 1.5;
        letter-spacing: 0.04em;
        color: #62401a;
        margin: 0 0 88px 0;
        text-align: center; }
        @media screen and (max-width: 768px) {
          html body main article section#cake .col-inner p.txt, html body main article section#stay .col-inner p.txt, html body main article section#restaurant .col-inner p.txt {
            font-size: 0.875rem;
            margin: 0 0 40px 0; } }
      html body main article section#cake .col-inner p .brsp, html body main article section#stay .col-inner p .brsp, html body main article section#restaurant .col-inner p .brsp {
        display: none; }
        @media screen and (max-width: 768px) {
          html body main article section#cake .col-inner p .brsp, html body main article section#stay .col-inner p .brsp, html body main article section#restaurant .col-inner p .brsp {
            display: block; } }
      html body main article section#cake .col-inner .cake-container, html body main article section#stay .col-inner .cake-container, html body main article section#restaurant .col-inner .cake-container {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 88px 40px;
        align-items: stretch;
        max-width: none;
        margin: 0 20px 90px 20px;
        height: 100%; }
        @media screen and (max-width: 900px) {
          html body main article section#cake .col-inner .cake-container, html body main article section#stay .col-inner .cake-container, html body main article section#restaurant .col-inner .cake-container {
            grid-template-columns: 1fr;
            gap: 64px; } }
        html body main article section#cake .col-inner .cake-container .cake-card, html body main article section#stay .col-inner .cake-container .cake-card, html body main article section#restaurant .col-inner .cake-container .cake-card {
          max-width: 520px;
          margin: 0;
          height: 100%; }
        html body main article section#cake .col-inner .cake-container .cake-card__head, html body main article section#stay .col-inner .cake-container .cake-card__head, html body main article section#restaurant .col-inner .cake-container .cake-card__head {
          text-align: center;
          margin: 0 0 16px 0; }
        html body main article section#cake .col-inner .cake-container .cake-card__title, html body main article section#stay .col-inner .cake-container .cake-card__title, html body main article section#restaurant .col-inner .cake-container .cake-card__title {
          font-family: "Baskervville", serif;
          font-size: 1.875rem;
          font-weight: 700;
          margin: 0 0 10px;
          color: #8e0126;
          letter-spacing: 0.05em; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__title, html body main article section#stay .col-inner .cake-container .cake-card__title, html body main article section#restaurant .col-inner .cake-container .cake-card__title {
              font-size: 1.5rem; } }
        html body main article section#cake .col-inner .cake-container .cake-card__subtitle, html body main article section#stay .col-inner .cake-container .cake-card__subtitle, html body main article section#restaurant .col-inner .cake-container .cake-card__subtitle {
          font-family: "Noto Serif JP", serif;
          font-size: 1rem;
          font-weight: 700;
          margin: 0;
          color: #8e0126;
          letter-spacing: 0.04em; }
        html body main article section#cake .col-inner .cake-container .cake-card__spec-dl, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl {
          font-family: "Noto Serif JP", serif;
          font-size: 1rem;
          font-weight: 400;
          color: #62401a;
          margin: 0 0 24px;
          letter-spacing: 0.04em;
          padding: 0; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__spec-dl, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl {
              font-size: 0.75rem; } }
        html body main article section#cake .col-inner .cake-container .cake-card__spec-dl .row01, html body main article section#cake .col-inner .cake-container .cake-card__spec-dl .row02, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl .row01, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl .row02, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl .row01, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl .row02 {
          display: grid;
          place-items: center;
          justify-content: center;
          grid-template-columns: 10em 10em;
          margin: 0 0 10px 0;
          gap: 16px; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__spec-dl .row01, html body main article section#cake .col-inner .cake-container .cake-card__spec-dl .row02, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl .row01, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl .row02, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl .row01, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl .row02 {
              grid-template-columns: 10em 11em;
              gap: 5px; } }
        html body main article section#cake .col-inner .cake-container .cake-card__spec-dl .row02, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl .row02, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl .row02 {
          grid-template-columns: 11em 13em;
          margin: 0; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__spec-dl .row02, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl .row02, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl .row02 {
              grid-template-columns: 11em 14em; } }
        html body main article section#cake .col-inner .cake-container .cake-card__spec-dl dt, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl dt, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl dt {
          margin: 0; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__spec-dl dt, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl dt, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl dt {
              display: flex;
              align-items: center; } }
        html body main article section#cake .col-inner .cake-container .cake-card__spec-dl dd, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl dd, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl dd {
          margin: 0;
          white-space: nowrap;
          border-left: 1px solid #62401a;
          padding: 0 0 0 16px; }
          @media screen and (max-width: 1100px) {
            html body main article section#cake .col-inner .cake-container .cake-card__spec-dl dd, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl dd, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl dd {
              white-space: pre-wrap;
              line-height: 1.3; } }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__spec-dl dd, html body main article section#stay .col-inner .cake-container .cake-card__spec-dl dd, html body main article section#restaurant .col-inner .cake-container .cake-card__spec-dl dd {
              padding: 0 0 0 10px; } }
        html body main article section#cake .col-inner .cake-container .cake-card__spec, html body main article section#stay .col-inner .cake-container .cake-card__spec, html body main article section#restaurant .col-inner .cake-container .cake-card__spec {
          font-family: "Noto Serif JP", serif;
          font-size: 1rem;
          font-weight: 400;
          color: #62401a;
          margin: 0 0 24px;
          padding: 0; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__spec, html body main article section#stay .col-inner .cake-container .cake-card__spec, html body main article section#restaurant .col-inner .cake-container .cake-card__spec {
              font-size: 0.75rem; } }
        html body main article section#cake .col-inner .cake-container .cake-card__spec li, html body main article section#stay .col-inner .cake-container .cake-card__spec li, html body main article section#restaurant .col-inner .cake-container .cake-card__spec li {
          display: flex;
          justify-content: center;
          align-items: center;
          column-gap: 10px;
          margin: 0 0 10px; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__spec li, html body main article section#stay .col-inner .cake-container .cake-card__spec li, html body main article section#restaurant .col-inner .cake-container .cake-card__spec li {
              column-gap: 0; } }
          html body main article section#cake .col-inner .cake-container .cake-card__spec li .price2, html body main article section#stay .col-inner .cake-container .cake-card__spec li .price2, html body main article section#restaurant .col-inner .cake-container .cake-card__spec li .price2 {
            display: block;
            height: 42px; }
        html body main article section#cake .col-inner .cake-container .cake-card__photo, html body main article section#stay .col-inner .cake-container .cake-card__photo, html body main article section#restaurant .col-inner .cake-container .cake-card__photo {
          margin: 0 0 24px; }
        html body main article section#cake .col-inner .cake-container .cake-card__photo img, html body main article section#stay .col-inner .cake-container .cake-card__photo img, html body main article section#restaurant .col-inner .cake-container .cake-card__photo img {
          display: block;
          width: 100%;
          height: auto;
          object-fit: cover; }
        html body main article section#cake .col-inner .cake-container .cake-card__desc, html body main article section#stay .col-inner .cake-container .cake-card__desc, html body main article section#restaurant .col-inner .cake-container .cake-card__desc {
          font-family: "Noto Serif JP", serif;
          font-size: 1rem;
          font-weight: 500;
          color: #62401a;
          margin: 0;
          line-height: 1.6;
          letter-spacing: 0.04em; }
          @media screen and (max-width: 768px) {
            html body main article section#cake .col-inner .cake-container .cake-card__desc, html body main article section#stay .col-inner .cake-container .cake-card__desc, html body main article section#restaurant .col-inner .cake-container .cake-card__desc {
              font-size: 0.875rem; } }
          html body main article section#cake .col-inner .cake-container .cake-card__desc .semi, html body main article section#stay .col-inner .cake-container .cake-card__desc .semi, html body main article section#restaurant .col-inner .cake-container .cake-card__desc .semi {
            font-weight: 600;
            display: block; }
        html body main article section#cake .col-inner .cake-container .cake-card__btn, html body main article section#stay .col-inner .cake-container .cake-card__btn, html body main article section#restaurant .col-inner .cake-container .cake-card__btn {
          display: block;
          width: 200px;
          margin: 24px auto 0;
          font-family: "Baskervville", serif;
          font-size: 1.125rem;
          font-weight: 700;
          padding: 10px 0;
          text-align: center;
          border-radius: 10px;
          font-weight: 700;
          letter-spacing: 0.05em;
          color: white;
          background: #b8afa5; }
    html body main article section#cake .reserve-card, html body main article section#stay .reserve-card, html body main article section#restaurant .reserve-card {
      position: relative;
      z-index: 2;
      max-width: 1080px;
      margin: 0 auto; }
    html body main article section#cake .reserve-card__inner, html body main article section#stay .reserve-card__inner, html body main article section#restaurant .reserve-card__inner {
      background: #f7ede4;
      border: 2px solid #62401a;
      border-radius: 10px;
      padding: 62px 66px;
      display: grid;
      grid-template-columns: 1.5fr 1fr;
      gap: 33px; }
      @media screen and (max-width: 1100px) {
        html body main article section#cake .reserve-card__inner, html body main article section#stay .reserve-card__inner, html body main article section#restaurant .reserve-card__inner {
          grid-template-columns: 1fr;
          padding: 40px 20px;
          gap: 40px; } }
    html body main article section#cake .reserve-card__eyebrow, html body main article section#stay .reserve-card__eyebrow, html body main article section#restaurant .reserve-card__eyebrow {
      margin: 0 0 10px;
      font-family: "Baskervville", serif;
      font-size: 1.25rem;
      font-weight: 700;
      letter-spacing: 0.05em; }
      @media screen and (max-width: 768px) {
        html body main article section#cake .reserve-card__eyebrow, html body main article section#stay .reserve-card__eyebrow, html body main article section#restaurant .reserve-card__eyebrow {
          font-size: 0.75rem; } }
    html body main article section#cake .reserve-card__title, html body main article section#stay .reserve-card__title, html body main article section#restaurant .reserve-card__title {
      font-size: 1.5625rem;
      font-weight: 700;
      margin: 0 0 32px;
      letter-spacing: 0.04em; }
      @media screen and (max-width: 768px) {
        html body main article section#cake .reserve-card__title, html body main article section#stay .reserve-card__title, html body main article section#restaurant .reserve-card__title {
          font-size: 1.375rem;
          line-height: 1.5; } }
      html body main article section#cake .reserve-card__title .brsp, html body main article section#stay .reserve-card__title .brsp, html body main article section#restaurant .reserve-card__title .brsp {
        display: none; }
        @media screen and (max-width: 768px) {
          html body main article section#cake .reserve-card__title .brsp, html body main article section#stay .reserve-card__title .brsp, html body main article section#restaurant .reserve-card__title .brsp {
            display: block; } }
    html body main article section#cake .reserve-card__copy, html body main article section#stay .reserve-card__copy, html body main article section#restaurant .reserve-card__copy {
      align-self: center;
      color: #62401a; }
      @media screen and (max-width: 1100px) {
        html body main article section#cake .reserve-card__copy, html body main article section#stay .reserve-card__copy, html body main article section#restaurant .reserve-card__copy {
          order: 2; } }
    html body main article section#cake .reserve-card__list, html body main article section#stay .reserve-card__list, html body main article section#restaurant .reserve-card__list {
      font-size: 1rem;
      font-weight: 400;
      margin: 0 0 32px;
      letter-spacing: 0.04em; }
    html body main article section#cake .reserve-card__list .row, html body main article section#stay .reserve-card__list .row, html body main article section#restaurant .reserve-card__list .row {
      display: grid;
      grid-template-columns: 6em 1fr;
      margin: 0 0 15px 0; }
    html body main article section#cake .reserve-card__list dt, html body main article section#stay .reserve-card__list dt, html body main article section#restaurant .reserve-card__list dt {
      margin: 0; }
      @media screen and (max-width: 768px) {
        html body main article section#cake .reserve-card__list dt, html body main article section#stay .reserve-card__list dt, html body main article section#restaurant .reserve-card__list dt {
          display: flex;
          align-items: center; } }
    html body main article section#cake .reserve-card__list dd, html body main article section#stay .reserve-card__list dd, html body main article section#restaurant .reserve-card__list dd {
      margin: 0;
      white-space: nowrap;
      border-left: 1px solid #62401a;
      padding: 0 0 0 18px; }
      @media screen and (max-width: 1100px) {
        html body main article section#cake .reserve-card__list dd, html body main article section#stay .reserve-card__list dd, html body main article section#restaurant .reserve-card__list dd {
          white-space: pre-wrap;
          line-height: 1.3; } }
    html body main article section#cake .reserve-card__image, html body main article section#stay .reserve-card__image, html body main article section#restaurant .reserve-card__image {
      margin: 0;
      max-width: 307px; }
      @media screen and (max-width: 1100px) {
        html body main article section#cake .reserve-card__image, html body main article section#stay .reserve-card__image, html body main article section#restaurant .reserve-card__image {
          order: 1;
          margin: 0 auto; } }
    html body main article section#cake .reserve-card__image img, html body main article section#stay .reserve-card__image img, html body main article section#restaurant .reserve-card__image img {
      display: block;
      width: 100%;
      height: auto; }
    html body main article section#cake .ig-cta, html body main article section#stay .ig-cta, html body main article section#restaurant .ig-cta {
      display: flex;
      align-items: center;
      padding: 20px 40px;
      border: 1px solid white;
      border-radius: 9999px;
      background: #8e0126;
      color: white;
      font-size: 1.125rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      gap: 24px;
      width: 310px;
      transition: background-color 0.4s ease-in-out,color 0.4s ease-in-out,border-color 0.4s ease-in-out; }
      @media screen and (max-width: 768px) {
        html body main article section#cake .ig-cta, html body main article section#stay .ig-cta, html body main article section#restaurant .ig-cta {
          font-size: 1rem;
          padding: 16px 32px;
          gap: 16px;
          width: 290px;
          margin: 0 auto; } }
      html body main article section#cake .ig-cta span, html body main article section#stay .ig-cta span, html body main article section#restaurant .ig-cta span {
        margin: 0; }
    html body main article section#cake .ig-cta, html body main article section#cake .ig-cta:link, html body main article section#cake .ig-cta:visited, html body main article section#stay .ig-cta, html body main article section#stay .ig-cta:link, html body main article section#stay .ig-cta:visited, html body main article section#restaurant .ig-cta, html body main article section#restaurant .ig-cta:link, html body main article section#restaurant .ig-cta:visited {
      color: white !important; }
    html body main article section#cake .ig-cta *, html body main article section#stay .ig-cta *, html body main article section#restaurant .ig-cta * {
      color: inherit; }
    html body main article section#cake .ig-cta__text, html body main article section#stay .ig-cta__text, html body main article section#restaurant .ig-cta__text {
      white-space: nowrap; }
    html body main article section#cake .ig-cta__text .jp, html body main article section#stay .ig-cta__text .jp, html body main article section#restaurant .ig-cta__text .jp {
      margin: 0; }
      @media screen and (max-width: 768px) {
        html body main article section#cake .ig-cta__text .jp, html body main article section#stay .ig-cta__text .jp, html body main article section#restaurant .ig-cta__text .jp {
          display: block; } }
    html body main article section#cake .ig-cta__arrow, html body main article section#stay .ig-cta__arrow, html body main article section#restaurant .ig-cta__arrow {
      position: relative;
      margin-left: auto;
      inline-size: 37px;
      block-size: 10px; }
    html body main article section#cake .ig-cta__arrow img, html body main article section#stay .ig-cta__arrow img, html body main article section#restaurant .ig-cta__arrow img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: contain;
      transition: opacity 0.4s ease-in-out;
      will-change: opacity; }
    html body main article section#cake .ig-cta__arrow img.normal, html body main article section#stay .ig-cta__arrow img.normal, html body main article section#restaurant .ig-cta__arrow img.normal {
      opacity: 1; }
    html body main article section#cake .ig-cta__arrow img.hover, html body main article section#stay .ig-cta__arrow img.hover, html body main article section#restaurant .ig-cta__arrow img.hover {
      opacity: 0; }
    html body main article section#cake .ig-cta:is(:hover, :focus-visible), html body main article section#stay .ig-cta:is(:hover, :focus-visible), html body main article section#restaurant .ig-cta:is(:hover, :focus-visible) {
      background: white;
      color: #8e0126 !important;
      border-color: #8e0126; }
    html body main article section#cake .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
    html body main article section#cake .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal, html body main article section#stay .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
    html body main article section#stay .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal, html body main article section#restaurant .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
    html body main article section#restaurant .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal {
      opacity: 0; }
    html body main article section#cake .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
    html body main article section#cake .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#stay .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
    html body main article section#stay .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#restaurant .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
    html body main article section#restaurant .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
      opacity: 1; }
    html body main article section#cake .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#stay .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#restaurant .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
      transform: translateX(4px);
      transition: opacity 0.4s ease-in-out, transform 0.3s ease; }
    html body main article section#cake .ig-cta:focus-visible, html body main article section#stay .ig-cta:focus-visible, html body main article section#restaurant .ig-cta:focus-visible {
      outline: 2px solid #8e0126; }
    @media (max-width: 420px) {
      html body main article section#cake .ig-cta, html body main article section#stay .ig-cta, html body main article section#restaurant .ig-cta {
        white-space: normal; } }
  html body main article section#stay, html body main article section#restaurant {
    margin: 0; }
    html body main article section#stay::before, html body main article section#restaurant::before {
      display: none; }
    html body main article section#stay .col-inner, html body main article section#restaurant .col-inner {
      position: relative;
      display: block;
      padding: 0;
      z-index: 2;
      width: 100%; }
      html body main article section#stay .col-inner::before, html body main article section#restaurant .col-inner::before {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        width: 100%;
        height: 100vh;
        margin: 0 auto;
        background-image: url(../image/stay-top.png);
        background-repeat: no-repeat;
        background-position: top center;
        background-size: 100% auto;
        z-index: 2; }
      html body main article section#stay .col-inner .col-top, html body main article section#restaurant .col-inner .col-top {
        padding: 175px 0 100px 0;
        background: linear-gradient(to bottom, #8e0126 0%, #76001f 100%);
        position: relative;
        overflow: hidden; }
        @media screen and (max-width: 1100px) {
          html body main article section#stay .col-inner .col-top, html body main article section#restaurant .col-inner .col-top {
            padding: 175px 0 200px 0; } }
        @media screen and (max-width: 768px) {
          html body main article section#stay .col-inner .col-top, html body main article section#restaurant .col-inner .col-top {
            padding: 175px 20px 200px 20px; } }
        html body main article section#stay .col-inner .col-top h2, html body main article section#restaurant .col-inner .col-top h2 {
          font-family: "Baskervville", serif;
          font-size: 3rem;
          font-weight: 700;
          letter-spacing: 0.05em;
          margin: 0 0 16px 0;
          color: white;
          text-align: center; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .col-top h2, html body main article section#restaurant .col-inner .col-top h2 {
              font-size: 2.375rem; } }
          html body main article section#stay .col-inner .col-top h2 .brsp, html body main article section#restaurant .col-inner .col-top h2 .brsp {
            display: none; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top h2 .brsp, html body main article section#restaurant .col-inner .col-top h2 .brsp {
                display: block; } }
        html body main article section#stay .col-inner .col-top .sub, html body main article section#restaurant .col-inner .col-top .sub {
          display: block;
          font-family: "Noto Serif JP", serif;
          font-size: 1.25rem;
          font-weight: 700;
          margin: 0 0 24px 0;
          letter-spacing: 0.04em;
          color: white;
          text-align: center; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .col-top .sub, html body main article section#restaurant .col-inner .col-top .sub {
              font-size: 1rem; } }
        html body main article section#stay .col-inner .col-top p, html body main article section#restaurant .col-inner .col-top p {
          font-size: 1.125rem;
          font-weight: 500;
          line-height: 1.5;
          letter-spacing: 0.04em;
          color: white;
          text-align: center; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .col-top p, html body main article section#restaurant .col-inner .col-top p {
              font-size: 0.875rem; } }
          html body main article section#stay .col-inner .col-top p .brsp, html body main article section#restaurant .col-inner .col-top p .brsp {
            display: none; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top p .brsp, html body main article section#restaurant .col-inner .col-top p .brsp {
                display: block; } }
        html body main article section#stay .col-inner .col-top .plan01, html body main article section#restaurant .col-inner .col-top .plan01 {
          display: flex;
          justify-content: center;
          text-align: center;
          color: white;
          margin: 0 100px 60px; }
          @media screen and (max-width: 1920px) {
            html body main article section#stay .col-inner .col-top .plan01, html body main article section#restaurant .col-inner .col-top .plan01 {
              margin: 0 50px 70px; } }
          @media screen and (max-width: 1100px) {
            html body main article section#stay .col-inner .col-top .plan01, html body main article section#restaurant .col-inner .col-top .plan01 {
              margin: 0 50px 70px; } }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .col-top .plan01, html body main article section#restaurant .col-inner .col-top .plan01 {
              margin: 0 20px 70px; } }
          html body main article section#stay .col-inner .col-top .plan01 .plan-img, html body main article section#restaurant .col-inner .col-top .plan01 .plan-img {
            width: 315px;
            height: 124px;
            margin: 0 auto 64px; }
            html body main article section#stay .col-inner .col-top .plan01 .plan-img img, html body main article section#restaurant .col-inner .col-top .plan01 .plan-img img {
              width: 100%; }
          html body main article section#stay .col-inner .col-top .plan01 h3, html body main article section#restaurant .col-inner .col-top .plan01 h3 {
            font-family: "Baskervville", serif;
            font-size: 2.5rem;
            font-weight: 700;
            line-height: 1.2;
            letter-spacing: 0.05em;
            margin: 0 0 16px 0; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 h3, html body main article section#restaurant .col-inner .col-top .plan01 h3 {
                font-size: 1.875rem;
                margin: 0 0 24px;
                line-height: 1.2; } }
            html body main article section#stay .col-inner .col-top .plan01 h3 .brsp, html body main article section#restaurant .col-inner .col-top .plan01 h3 .brsp {
              display: none; }
              @media screen and (max-width: 768px) {
                html body main article section#stay .col-inner .col-top .plan01 h3 .brsp, html body main article section#restaurant .col-inner .col-top .plan01 h3 .brsp {
                  display: block; } }
          html body main article section#stay .col-inner .col-top .plan01 .sub, html body main article section#restaurant .col-inner .col-top .plan01 .sub {
            font-size: 1.25rem;
            font-weight: 600;
            letter-spacing: 0.04em;
            line-height: 1.5;
            margin: 0 0 64px 0; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .sub, html body main article section#restaurant .col-inner .col-top .plan01 .sub {
                font-size: 1rem;
                margin: 0 0 40px;
                line-height: 1.5; } }
            html body main article section#stay .col-inner .col-top .plan01 .sub .brsp, html body main article section#restaurant .col-inner .col-top .plan01 .sub .brsp {
              display: none; }
              @media screen and (max-width: 768px) {
                html body main article section#stay .col-inner .col-top .plan01 .sub .brsp, html body main article section#restaurant .col-inner .col-top .plan01 .sub .brsp {
                  display: block; } }
          html body main article section#stay .col-inner .col-top .plan01 .plan, html body main article section#restaurant .col-inner .col-top .plan01 .plan {
            color: white;
            max-width: 1080px; }
          html body main article section#stay .col-inner .col-top .plan01 .plan__inner, html body main article section#restaurant .col-inner .col-top .plan01 .plan__inner {
            display: grid;
            grid-template-columns: 0.7fr 1fr;
            gap: 64px;
            align-items: start; }
            @media screen and (max-width: 1100px) {
              html body main article section#stay .col-inner .col-top .plan01 .plan__inner, html body main article section#restaurant .col-inner .col-top .plan01 .plan__inner {
                grid-template-columns: 1fr;
                gap: 56px; } }
            html body main article section#stay .col-inner .col-top .plan01 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .col-top .plan01 .plan__inner .plan-photo {
              width: 420px;
              height: 420px; }
              @media screen and (max-width: 1100px) {
                html body main article section#stay .col-inner .col-top .plan01 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .col-top .plan01 .plan__inner .plan-photo {
                  margin: 0 auto; } }
              @media screen and (max-width: 768px) {
                html body main article section#stay .col-inner .col-top .plan01 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .col-top .plan01 .plan__inner .plan-photo {
                  width: 280px;
                  height: 280px; } }
              html body main article section#stay .col-inner .col-top .plan01 .plan__inner .plan-photo img, html body main article section#restaurant .col-inner .col-top .plan01 .plan__inner .plan-photo img {
                width: 100%;
                height: 100%; }
          html body main article section#stay .col-inner .col-top .plan01 .plan__lead, html body main article section#restaurant .col-inner .col-top .plan01 .plan__lead {
            margin: 0 0 40px;
            line-height: 1.6;
            letter-spacing: 0.04em;
            text-align: left; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .plan__lead, html body main article section#restaurant .col-inner .col-top .plan01 .plan__lead {
                font-size: 0.875rem; } }
          html body main article section#stay .col-inner .col-top .plan01 .plan__term, html body main article section#restaurant .col-inner .col-top .plan01 .plan__term {
            font-size: 1.125rem;
            font-weight: 400;
            margin: 0 0 40px;
            text-align: left;
            display: flex;
            gap: 16px;
            line-height: 1.5;
            letter-spacing: 0.04em;
            align-items: center; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .plan__term, html body main article section#restaurant .col-inner .col-top .plan01 .plan__term {
                font-size: 0.875rem; } }
            html body main article section#stay .col-inner .col-top .plan01 .plan__term .termR, html body main article section#restaurant .col-inner .col-top .plan01 .plan__term .termR {
              border-left: 1px solid white;
              border-left: 1px solid white;
              padding: 0 0 0 16px; }
            html body main article section#stay .col-inner .col-top .plan01 .plan__term .termL, html body main article section#restaurant .col-inner .col-top .plan01 .plan__term .termL {
              white-space: nowrap; }
          html body main article section#stay .col-inner .col-top .plan01 .plan__sub, html body main article section#restaurant .col-inner .col-top .plan01 .plan__sub {
            margin: 0 0 24px;
            padding: 0 0 16px;
            border-bottom: 1px solid white;
            text-align: left;
            font-size: 1.375rem;
            font-weight: 700;
            letter-spacing: 0.04em; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .plan__sub, html body main article section#restaurant .col-inner .col-top .plan01 .plan__sub {
                font-size: 1.25rem; } }
          html body main article section#stay .col-inner .col-top .plan01 .plan__list, html body main article section#restaurant .col-inner .col-top .plan01 .plan__list {
            margin: 0;
            padding: 0;
            line-height: 1.6;
            letter-spacing: 0.04em;
            text-align: left; }
          html body main article section#stay .col-inner .col-top .plan01 .plan__list li, html body main article section#restaurant .col-inner .col-top .plan01 .plan__list li {
            margin: 0 0 5px;
            position: relative;
            padding: 0 0 0 15px;
            font-size: 1.125rem;
            font-weight: 400; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .plan__list li, html body main article section#restaurant .col-inner .col-top .plan01 .plan__list li {
                font-size: 0.875rem; } }
          html body main article section#stay .col-inner .col-top .plan01 .plan__list li::before, html body main article section#restaurant .col-inner .col-top .plan01 .plan__list li::before {
            content: "";
            position: absolute;
            left: 0;
            top: 10px;
            width: 7px;
            height: 7px;
            border-radius: 50%;
            background: white;
            opacity: 1.0; }
          html body main article section#stay .col-inner .col-top .plan01 .note, html body main article section#restaurant .col-inner .col-top .plan01 .note {
            font-size: 1.125rem;
            font-weight: 400;
            letter-spacing: 0.04em;
            line-height: 1.6;
            text-align: left;
            margin: 0 0 40px; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .note, html body main article section#restaurant .col-inner .col-top .plan01 .note {
                font-size: 0.875rem; } }
          html body main article section#stay .col-inner .col-top .plan01 .plan__benefit, html body main article section#restaurant .col-inner .col-top .plan01 .plan__benefit {
            font-size: 1.125rem;
            font-weight: 500;
            letter-spacing: 0.04em;
            line-height: 1.6;
            margin: 0 0 56px;
            text-align: left; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .plan__benefit, html body main article section#restaurant .col-inner .col-top .plan01 .plan__benefit {
                font-size: 0.875rem; } }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta {
            display: flex;
            align-items: center;
            padding: 20px 40px;
            border: 1px solid #8e0126;
            border-radius: 9999px;
            background: white;
            color: #8e0126;
            font-size: 1.125rem;
            font-weight: 700;
            letter-spacing: 0.04em;
            gap: 24px;
            width: 310px;
            margin: 0 0 0 auto;
            transition: background-color 0.4s ease-in-out,color 0.4s ease-in-out,border-color 0.4s ease-in-out; }
            @media screen and (max-width: 1100px) {
              html body main article section#stay .col-inner .col-top .plan01 .ig-cta, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta {
                margin: 0 auto; } }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .ig-cta, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta {
                font-size: 1rem;
                padding: 16px 32px;
                gap: 16px;
                width: 290px; } }
            html body main article section#stay .col-inner .col-top .plan01 .ig-cta span, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta span {
              margin: 0; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta, html body main article section#stay .col-inner .col-top .plan01 .ig-cta:link, html body main article section#stay .col-inner .col-top .plan01 .ig-cta:visited, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:link, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:visited {
            color: #8e0126 !important; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta *, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta * {
            color: inherit; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta__text, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta__text {
            white-space: nowrap; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta__text .jp, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta__text .jp {
            margin: 0; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .col-top .plan01 .ig-cta__text .jp, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta__text .jp {
                display: block; } }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta__arrow, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta__arrow {
            position: relative;
            margin-left: auto;
            inline-size: 37px;
            block-size: 10px; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta__arrow img, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta__arrow img {
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            object-fit: contain;
            transition: opacity 0.4s ease-in-out;
            will-change: opacity; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta__arrow img.normal, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta__arrow img.normal {
            opacity: 1; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta__arrow img.hover {
            opacity: 0; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible), html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) {
            background: #8e0126;
            color: white !important;
            border-color: white; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
          html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal {
            opacity: 0; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
          html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
            opacity: 1; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
            transform: translateX(4px);
            transition: opacity 0.4s ease-in-out, transform 0.3s ease; }
          html body main article section#stay .col-inner .col-top .plan01 .ig-cta:focus-visible, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta:focus-visible {
            outline: 2px solid white; }
          @media (max-width: 420px) {
            html body main article section#stay .col-inner .col-top .plan01 .ig-cta, html body main article section#restaurant .col-inner .col-top .plan01 .ig-cta {
              white-space: normal; } }
      html body main article section#stay .col-inner .plan02, html body main article section#stay .col-inner .plan03, html body main article section#restaurant .col-inner .plan02, html body main article section#restaurant .col-inner .plan03 {
        text-align: center;
        color: white;
        background: linear-gradient(to bottom, #8e0126 0%, #76001f 100%);
        margin: 0;
        padding: 60px 100px 120px;
        width: 100%;
        position: relative;
        display: flex;
        justify-content: center; }
        @media screen and (max-width: 1100px) {
          html body main article section#stay .col-inner .plan02, html body main article section#stay .col-inner .plan03, html body main article section#restaurant .col-inner .plan02, html body main article section#restaurant .col-inner .plan03 {
            padding: 60px 50px 120px; } }
        @media screen and (max-width: 768px) {
          html body main article section#stay .col-inner .plan02, html body main article section#stay .col-inner .plan03, html body main article section#restaurant .col-inner .plan02, html body main article section#restaurant .col-inner .plan03 {
            padding: 60px 20px 120px; } }
        html body main article section#stay .col-inner .plan02 .plan-img, html body main article section#stay .col-inner .plan03 .plan-img, html body main article section#restaurant .col-inner .plan02 .plan-img, html body main article section#restaurant .col-inner .plan03 .plan-img {
          width: 315px;
          height: 124px;
          margin: 0 auto 64px; }
          html body main article section#stay .col-inner .plan02 .plan-img img, html body main article section#stay .col-inner .plan03 .plan-img img, html body main article section#restaurant .col-inner .plan02 .plan-img img, html body main article section#restaurant .col-inner .plan03 .plan-img img {
            width: 100%; }
        html body main article section#stay .col-inner .plan02 h3, html body main article section#stay .col-inner .plan03 h3, html body main article section#restaurant .col-inner .plan02 h3, html body main article section#restaurant .col-inner .plan03 h3 {
          font-family: "Baskervville", serif;
          font-size: 2.5rem;
          font-weight: 700;
          letter-spacing: 0.05em;
          line-height: 1.2;
          margin: 0 0 16px 0; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 h3, html body main article section#stay .col-inner .plan03 h3, html body main article section#restaurant .col-inner .plan02 h3, html body main article section#restaurant .col-inner .plan03 h3 {
              font-size: 1.875rem;
              margin: 0 0 24px;
              line-height: 1.2; } }
          html body main article section#stay .col-inner .plan02 h3 .brsp, html body main article section#stay .col-inner .plan03 h3 .brsp, html body main article section#restaurant .col-inner .plan02 h3 .brsp, html body main article section#restaurant .col-inner .plan03 h3 .brsp {
            display: none; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .plan02 h3 .brsp, html body main article section#stay .col-inner .plan03 h3 .brsp, html body main article section#restaurant .col-inner .plan02 h3 .brsp, html body main article section#restaurant .col-inner .plan03 h3 .brsp {
                display: block; } }
        html body main article section#stay .col-inner .plan02 .sub, html body main article section#stay .col-inner .plan03 .sub, html body main article section#restaurant .col-inner .plan02 .sub, html body main article section#restaurant .col-inner .plan03 .sub {
          font-size: 1.25rem;
          font-weight: 600;
          line-height: 1.5;
          letter-spacing: 0.04em;
          margin: 0 0 64px 0;
          color: white; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 .sub, html body main article section#stay .col-inner .plan03 .sub, html body main article section#restaurant .col-inner .plan02 .sub, html body main article section#restaurant .col-inner .plan03 .sub {
              font-size: 1rem;
              margin: 0 0 40px;
              line-height: 1.5; } }
          html body main article section#stay .col-inner .plan02 .sub .brsp, html body main article section#stay .col-inner .plan03 .sub .brsp, html body main article section#restaurant .col-inner .plan02 .sub .brsp, html body main article section#restaurant .col-inner .plan03 .sub .brsp {
            display: none; }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .plan02 .sub .brsp, html body main article section#stay .col-inner .plan03 .sub .brsp, html body main article section#restaurant .col-inner .plan02 .sub .brsp, html body main article section#restaurant .col-inner .plan03 .sub .brsp {
                display: block; } }
        html body main article section#stay .col-inner .plan02 .plan, html body main article section#stay .col-inner .plan03 .plan, html body main article section#restaurant .col-inner .plan02 .plan, html body main article section#restaurant .col-inner .plan03 .plan {
          color: white;
          max-width: 1080px; }
        html body main article section#stay .col-inner .plan02 .plan__inner, html body main article section#stay .col-inner .plan03 .plan__inner, html body main article section#restaurant .col-inner .plan02 .plan__inner, html body main article section#restaurant .col-inner .plan03 .plan__inner {
          display: grid;
          grid-template-columns: 0.7fr 1fr;
          gap: 64px;
          align-items: start; }
          @media screen and (max-width: 1100px) {
            html body main article section#stay .col-inner .plan02 .plan__inner, html body main article section#stay .col-inner .plan03 .plan__inner, html body main article section#restaurant .col-inner .plan02 .plan__inner, html body main article section#restaurant .col-inner .plan03 .plan__inner {
              grid-template-columns: 1fr;
              gap: 56px; } }
          html body main article section#stay .col-inner .plan02 .plan__inner .plan-photo, html body main article section#stay .col-inner .plan03 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .plan02 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .plan03 .plan__inner .plan-photo {
            width: 420px;
            height: 420px; }
            @media screen and (max-width: 1100px) {
              html body main article section#stay .col-inner .plan02 .plan__inner .plan-photo, html body main article section#stay .col-inner .plan03 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .plan02 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .plan03 .plan__inner .plan-photo {
                margin: 0 auto; } }
            @media screen and (max-width: 768px) {
              html body main article section#stay .col-inner .plan02 .plan__inner .plan-photo, html body main article section#stay .col-inner .plan03 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .plan02 .plan__inner .plan-photo, html body main article section#restaurant .col-inner .plan03 .plan__inner .plan-photo {
                width: 280px;
                height: 280px; } }
            html body main article section#stay .col-inner .plan02 .plan__inner .plan-photo img, html body main article section#stay .col-inner .plan03 .plan__inner .plan-photo img, html body main article section#restaurant .col-inner .plan02 .plan__inner .plan-photo img, html body main article section#restaurant .col-inner .plan03 .plan__inner .plan-photo img {
              width: 100%;
              height: 100%; }
        html body main article section#stay .col-inner .plan02 .plan__lead, html body main article section#stay .col-inner .plan03 .plan__lead, html body main article section#restaurant .col-inner .plan02 .plan__lead, html body main article section#restaurant .col-inner .plan03 .plan__lead {
          margin: 0 0 40px;
          font-size: 1.125rem;
          font-weight: 500;
          line-height: 1.6;
          letter-spacing: 0.04em;
          text-align: left;
          color: white; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 .plan__lead, html body main article section#stay .col-inner .plan03 .plan__lead, html body main article section#restaurant .col-inner .plan02 .plan__lead, html body main article section#restaurant .col-inner .plan03 .plan__lead {
              font-size: 0.875rem; } }
        html body main article section#stay .col-inner .plan02 .plan__term, html body main article section#stay .col-inner .plan03 .plan__term, html body main article section#restaurant .col-inner .plan02 .plan__term, html body main article section#restaurant .col-inner .plan03 .plan__term {
          font-size: 1.125rem;
          font-weight: 400;
          line-height: 1.5;
          letter-spacing: 0.04em;
          margin: 0 0 40px;
          text-align: left;
          color: white;
          display: flex;
          align-items: center;
          gap: 16px; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 .plan__term, html body main article section#stay .col-inner .plan03 .plan__term, html body main article section#restaurant .col-inner .plan02 .plan__term, html body main article section#restaurant .col-inner .plan03 .plan__term {
              font-size: 0.875rem; } }
          html body main article section#stay .col-inner .plan02 .plan__term .termR, html body main article section#stay .col-inner .plan03 .plan__term .termR, html body main article section#restaurant .col-inner .plan02 .plan__term .termR, html body main article section#restaurant .col-inner .plan03 .plan__term .termR {
            border-left: 1px solid white;
            padding: 0 0 0 16px; }
          html body main article section#stay .col-inner .plan02 .plan__term .termL, html body main article section#stay .col-inner .plan03 .plan__term .termL, html body main article section#restaurant .col-inner .plan02 .plan__term .termL, html body main article section#restaurant .col-inner .plan03 .plan__term .termL {
            white-space: nowrap; }
        html body main article section#stay .col-inner .plan02 .plan__sub, html body main article section#stay .col-inner .plan03 .plan__sub, html body main article section#restaurant .col-inner .plan02 .plan__sub, html body main article section#restaurant .col-inner .plan03 .plan__sub {
          margin: 0 0 24px;
          padding: 0 0 16px;
          border-bottom: 1px solid white;
          text-align: left;
          font-size: 1.375rem;
          font-weight: 700;
          letter-spacing: 0.04em; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 .plan__sub, html body main article section#stay .col-inner .plan03 .plan__sub, html body main article section#restaurant .col-inner .plan02 .plan__sub, html body main article section#restaurant .col-inner .plan03 .plan__sub {
              font-size: 1.25rem; } }
        html body main article section#stay .col-inner .plan02 .plan__list, html body main article section#stay .col-inner .plan03 .plan__list, html body main article section#restaurant .col-inner .plan02 .plan__list, html body main article section#restaurant .col-inner .plan03 .plan__list {
          margin: 0 0 40px;
          padding: 0;
          line-height: 1.6;
          letter-spacing: 0.04em;
          text-align: left; }
        html body main article section#stay .col-inner .plan02 .plan__list li, html body main article section#stay .col-inner .plan03 .plan__list li, html body main article section#restaurant .col-inner .plan02 .plan__list li, html body main article section#restaurant .col-inner .plan03 .plan__list li {
          margin: 0 0 .2em;
          position: relative;
          padding: 0 0 0 15px;
          font-size: 1.125rem;
          font-weight: 400; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 .plan__list li, html body main article section#stay .col-inner .plan03 .plan__list li, html body main article section#restaurant .col-inner .plan02 .plan__list li, html body main article section#restaurant .col-inner .plan03 .plan__list li {
              font-size: 0.875rem; } }
        html body main article section#stay .col-inner .plan02 .plan__list li::before, html body main article section#stay .col-inner .plan03 .plan__list li::before, html body main article section#restaurant .col-inner .plan02 .plan__list li::before, html body main article section#restaurant .col-inner .plan03 .plan__list li::before {
          content: "";
          position: absolute;
          left: 0;
          top: 10px;
          width: 7px;
          height: 7px;
          border-radius: 50%;
          background: white;
          opacity: 1.0; }
        html body main article section#stay .col-inner .plan02 .plan__list .note, html body main article section#stay .col-inner .plan03 .plan__list .note, html body main article section#restaurant .col-inner .plan02 .plan__list .note, html body main article section#restaurant .col-inner .plan03 .plan__list .note {
          list-style: none; }
        html body main article section#stay .col-inner .plan02 .plan__benefit, html body main article section#stay .col-inner .plan03 .plan__benefit, html body main article section#restaurant .col-inner .plan02 .plan__benefit, html body main article section#restaurant .col-inner .plan03 .plan__benefit {
          font-size: 1.125rem;
          font-weight: 500;
          line-height: 1.6;
          letter-spacing: 0.04em;
          margin: 0 0 56px;
          text-align: left;
          color: white; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 .plan__benefit, html body main article section#stay .col-inner .plan03 .plan__benefit, html body main article section#restaurant .col-inner .plan02 .plan__benefit, html body main article section#restaurant .col-inner .plan03 .plan__benefit {
              font-size: 0.875rem; } }
        html body main article section#stay .col-inner .plan02 .ig-cta, html body main article section#stay .col-inner .plan03 .ig-cta, html body main article section#restaurant .col-inner .plan02 .ig-cta, html body main article section#restaurant .col-inner .plan03 .ig-cta {
          display: flex;
          align-items: center;
          padding: 20px 40px;
          border: 1px solid #8e0126;
          border-radius: 9999px;
          background: white;
          color: #8e0126;
          font-size: 1.125rem;
          font-weight: 700;
          letter-spacing: 0.04em;
          gap: 24px;
          width: 310px;
          margin: 0 0 0 auto; }
          @media screen and (max-width: 1100px) {
            html body main article section#stay .col-inner .plan02 .ig-cta, html body main article section#stay .col-inner .plan03 .ig-cta, html body main article section#restaurant .col-inner .plan02 .ig-cta, html body main article section#restaurant .col-inner .plan03 .ig-cta {
              margin: 0 auto; } }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 .ig-cta, html body main article section#stay .col-inner .plan03 .ig-cta, html body main article section#restaurant .col-inner .plan02 .ig-cta, html body main article section#restaurant .col-inner .plan03 .ig-cta {
              font-size: 1rem;
              padding: 16px 32px;
              gap: 16px;
              width: 290px; } }
          html body main article section#stay .col-inner .plan02 .ig-cta span, html body main article section#stay .col-inner .plan03 .ig-cta span, html body main article section#restaurant .col-inner .plan02 .ig-cta span, html body main article section#restaurant .col-inner .plan03 .ig-cta span {
            margin: 0; }
        html body main article section#stay .col-inner .plan02 .ig-cta, html body main article section#stay .col-inner .plan02 .ig-cta:link, html body main article section#stay .col-inner .plan02 .ig-cta:visited, html body main article section#stay .col-inner .plan03 .ig-cta, html body main article section#stay .col-inner .plan03 .ig-cta:link, html body main article section#stay .col-inner .plan03 .ig-cta:visited, html body main article section#restaurant .col-inner .plan02 .ig-cta, html body main article section#restaurant .col-inner .plan02 .ig-cta:link, html body main article section#restaurant .col-inner .plan02 .ig-cta:visited, html body main article section#restaurant .col-inner .plan03 .ig-cta, html body main article section#restaurant .col-inner .plan03 .ig-cta:link, html body main article section#restaurant .col-inner .plan03 .ig-cta:visited {
          color: #8e0126 !important; }
        html body main article section#stay .col-inner .plan02 .ig-cta *, html body main article section#stay .col-inner .plan03 .ig-cta *, html body main article section#restaurant .col-inner .plan02 .ig-cta *, html body main article section#restaurant .col-inner .plan03 .ig-cta * {
          color: inherit; }
        html body main article section#stay .col-inner .plan02 .ig-cta__text, html body main article section#stay .col-inner .plan03 .ig-cta__text, html body main article section#restaurant .col-inner .plan02 .ig-cta__text, html body main article section#restaurant .col-inner .plan03 .ig-cta__text {
          white-space: nowrap; }
        html body main article section#stay .col-inner .plan02 .ig-cta__text .jp, html body main article section#stay .col-inner .plan03 .ig-cta__text .jp, html body main article section#restaurant .col-inner .plan02 .ig-cta__text .jp, html body main article section#restaurant .col-inner .plan03 .ig-cta__text .jp {
          margin: 0; }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02 .ig-cta__text .jp, html body main article section#stay .col-inner .plan03 .ig-cta__text .jp, html body main article section#restaurant .col-inner .plan02 .ig-cta__text .jp, html body main article section#restaurant .col-inner .plan03 .ig-cta__text .jp {
              display: block; } }
        html body main article section#stay .col-inner .plan02 .ig-cta__arrow, html body main article section#stay .col-inner .plan03 .ig-cta__arrow, html body main article section#restaurant .col-inner .plan02 .ig-cta__arrow, html body main article section#restaurant .col-inner .plan03 .ig-cta__arrow {
          position: relative;
          margin-left: auto;
          inline-size: 37px;
          block-size: 10px; }
        html body main article section#stay .col-inner .plan02 .ig-cta__arrow img, html body main article section#stay .col-inner .plan03 .ig-cta__arrow img, html body main article section#restaurant .col-inner .plan02 .ig-cta__arrow img, html body main article section#restaurant .col-inner .plan03 .ig-cta__arrow img {
          position: absolute;
          inset: 0;
          width: 100%;
          height: 100%;
          object-fit: contain;
          transition: opacity .2s ease; }
        html body main article section#stay .col-inner .plan02 .ig-cta__arrow img.normal, html body main article section#stay .col-inner .plan03 .ig-cta__arrow img.normal, html body main article section#restaurant .col-inner .plan02 .ig-cta__arrow img.normal, html body main article section#restaurant .col-inner .plan03 .ig-cta__arrow img.normal {
          opacity: 1; }
        html body main article section#stay .col-inner .plan02 .ig-cta__arrow img.hover, html body main article section#stay .col-inner .plan03 .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .plan02 .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .plan03 .ig-cta__arrow img.hover {
          opacity: 0; }
        html body main article section#stay .col-inner .plan02 .ig-cta:is(:hover, :focus-visible), html body main article section#stay .col-inner .plan03 .ig-cta:is(:hover, :focus-visible), html body main article section#restaurant .col-inner .plan02 .ig-cta:is(:hover, :focus-visible), html body main article section#restaurant .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) {
          background: #8e0126;
          color: white !important;
          border-color: white; }
        html body main article section#stay .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
        html body main article section#stay .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal, html body main article section#stay .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
        html body main article section#stay .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal, html body main article section#restaurant .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
        html body main article section#restaurant .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal, html body main article section#restaurant .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
        html body main article section#restaurant .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal {
          opacity: 0; }
        html body main article section#stay .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
        html body main article section#stay .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#stay .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
        html body main article section#stay .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
        html body main article section#restaurant .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
        html body main article section#restaurant .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
          opacity: 1; }
        html body main article section#stay .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#stay .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .plan02 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover, html body main article section#restaurant .col-inner .plan03 .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
          transform: translateX(4px); }
        html body main article section#stay .col-inner .plan02 .ig-cta:focus-visible, html body main article section#stay .col-inner .plan03 .ig-cta:focus-visible, html body main article section#restaurant .col-inner .plan02 .ig-cta:focus-visible, html body main article section#restaurant .col-inner .plan03 .ig-cta:focus-visible {
          outline: 2px solid white; }
        @media (max-width: 420px) {
          html body main article section#stay .col-inner .plan02 .ig-cta, html body main article section#stay .col-inner .plan03 .ig-cta, html body main article section#restaurant .col-inner .plan02 .ig-cta, html body main article section#restaurant .col-inner .plan03 .ig-cta {
            white-space: normal; } }
      html body main article section#stay .col-inner .plan02, html body main article section#restaurant .col-inner .plan02 {
        padding: 200px 100px 500px;
        margin: -260px 0 0 0; }
        @media screen and (max-width: 1920px) {
          html body main article section#stay .col-inner .plan02, html body main article section#restaurant .col-inner .plan02 {
            padding: 160px 50px 500px; } }
        @media screen and (max-width: 1100px) {
          html body main article section#stay .col-inner .plan02, html body main article section#restaurant .col-inner .plan02 {
            padding: 160px 50px 500px; } }
        @media screen and (max-width: 768px) {
          html body main article section#stay .col-inner .plan02, html body main article section#restaurant .col-inner .plan02 {
            padding: 115px 20px 500px; } }
        @media screen and (max-width: 375px) {
          html body main article section#stay .col-inner .plan02, html body main article section#restaurant .col-inner .plan02 {
            padding: 110px 20px 500px; } }
        html body main article section#stay .col-inner .plan02.top-diagonal, html body main article section#restaurant .col-inner .plan02.top-diagonal {
          background: linear-gradient(to bottom, #8e0126 0%, #76001f 100%);
          /* 上の線：左上→右下 */
          clip-path: polygon(0 0, 100% 15%, 100% 100%, 0 85%); }
          @media screen and (max-width: 1100px) {
            html body main article section#stay .col-inner .plan02.top-diagonal, html body main article section#restaurant .col-inner .plan02.top-diagonal {
              clip-path: polygon(0 0, 100% 10%, 100% 100%, 0 90%); } }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan02.top-diagonal, html body main article section#restaurant .col-inner .plan02.top-diagonal {
              clip-path: polygon(0 0, 100% 6%, 100% 100%, 0 94%); } }
        html body main article section#stay .col-inner .plan02 .plan__inner, html body main article section#restaurant .col-inner .plan02 .plan__inner {
          display: grid !important;
          grid-template-columns: 1fr 0.7fr;
          grid-template-areas: "body media";
          gap: 48px;
          align-items: start !important; }
          @media screen and (max-width: 1100px) {
            html body main article section#stay .col-inner .plan02 .plan__inner, html body main article section#restaurant .col-inner .plan02 .plan__inner {
              display: grid !important;
              grid-template-columns: 1fr !important;
              grid-template-areas: "media" "body";
              gap: 56px;
              align-items: start; } }
        html body main article section#stay .col-inner .plan02 .plan__body, html body main article section#restaurant .col-inner .plan02 .plan__body {
          grid-area: body;
          align-self: start !important; }
        html body main article section#stay .col-inner .plan02 .plan__inner > .slider, html body main article section#restaurant .col-inner .plan02 .plan__inner > .slider {
          grid-area: media;
          align-self: start !important; }
      html body main article section#stay .col-inner .plan03, html body main article section#restaurant .col-inner .plan03 {
        margin: -480px 0 0 0;
        padding: 200px 100px 380px; }
        @media screen and (max-width: 1920px) {
          html body main article section#stay .col-inner .plan03, html body main article section#restaurant .col-inner .plan03 {
            padding: 160px 50px 180px; } }
        @media screen and (max-width: 768px) {
          html body main article section#stay .col-inner .plan03, html body main article section#restaurant .col-inner .plan03 {
            padding: 115px 20px 140px; } }
        @media screen and (max-width: 375px) {
          html body main article section#stay .col-inner .plan03, html body main article section#restaurant .col-inner .plan03 {
            padding: 110px 20px 140px; } }
        html body main article section#stay .col-inner .plan03.bottom-diagonal, html body main article section#restaurant .col-inner .plan03.bottom-diagonal {
          background: linear-gradient(to bottom, #8e0126 0%, #76001f 100%);
          /* 下辺を大きくズラす（例：15%） */
          clip-path: polygon(0 15%, 100% 0, 100% 100%, 0 100%); }
          @media screen and (max-width: 1100px) {
            html body main article section#stay .col-inner .plan03.bottom-diagonal, html body main article section#restaurant .col-inner .plan03.bottom-diagonal {
              clip-path: polygon(0 10%, 100% 0, 100% 100%, 0 100%); } }
          @media screen and (max-width: 768px) {
            html body main article section#stay .col-inner .plan03.bottom-diagonal, html body main article section#restaurant .col-inner .plan03.bottom-diagonal {
              clip-path: polygon(0 6%, 100% 0, 100% 100%, 0 100%); } }
  html body main article section#restaurant {
    margin: 0;
    position: relative;
    background: white;
    padding: 0;
    overflow-x: clip; }
    html body main article section#restaurant::before {
      display: block;
      content: "";
      position: absolute;
      left: 50%;
      top: -10vw;
      transform: translateX(-50%) rotate(10.78deg);
      transform-origin: top center;
      width: 100vw;
      height: 22vw;
      background: white;
      pointer-events: none;
      z-index: 2; }
    html body main article section#restaurant::after {
      display: block;
      content: "";
      position: absolute;
      left: 50%;
      top: -21vw;
      transform: translateX(-50%) rotate(-0.22deg);
      transform-origin: top center;
      width: 100vw;
      height: 23vw;
      background-image: url(../image/gold-band.png);
      background-repeat: no-repeat;
      background-size: cover;
      pointer-events: none;
      z-index: 3; }
      @media screen and (max-width: 768px) {
        html body main article section#restaurant::after {
          background-image: url(../image/gold-band-sp.png);
          left: 49%;
          top: -24vw;
          height: 28vw; } }
      @media screen and (max-width: 520px) {
        html body main article section#restaurant::after {
          width: 106vw; } }
      @media screen and (max-width: 375px) {
        html body main article section#restaurant::after {
          width: 105vw; } }
    html body main article section#restaurant .col-inner {
      position: relative;
      display: flex;
      justify-content: center;
      align-items: center;
      flex-direction: column;
      padding: 0;
      z-index: 3; }
      @media screen and (max-width: 768px) {
        html body main article section#restaurant .col-inner {
          padding: 66px 20px 0 20px; } }
      html body main article section#restaurant .col-inner::before {
        content: "";
        display: block;
        position: absolute;
        top: -3vw;
        left: 0;
        right: 0;
        width: 100%;
        height: 276px;
        margin: 0 auto;
        background-image: url(../image/rest-top.png);
        background-repeat: no-repeat;
        background-size: contain;
        z-index: 3; }
      html body main article section#restaurant .col-inner h2 {
        color: #62401a; }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .col-inner h2 {
            font-size: 2.375rem; } }
      html body main article section#restaurant .col-inner .sub {
        color: #62401a; }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .col-inner .sub {
            font-size: 1rem; } }
      html body main article section#restaurant .col-inner p {
        color: #62401a;
        margin: 0 0 96px;
        text-align: center;
        line-height: 1.5;
        letter-spacing: 0.04em; }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .col-inner p {
            font-size: 0.875rem;
            margin: 0;
            margin: 0 0 32px; } }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .col-inner p .brpc {
            display: none; } }
        html body main article section#restaurant .col-inner p .brsp {
          display: none; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .col-inner p .brsp {
              display: block; } }
    html body main article section#restaurant .tabs {
      margin: 0 auto;
      width: 100%;
      background: linear-gradient(to bottom, white 0%, #e3d4c7 100%);
      contain: layout paint style;
      z-index: 3;
      position: relative;
      /* ---- パネル ---- */ }
      html body main article section#restaurant .tabs .tabs__radio {
        position: absolute;
        inline-size: 1px;
        block-size: 1px;
        margin: -1px;
        padding: 0;
        border: 0;
        clip: rect(0 0 0 0);
        clip-path: inset(50%);
        overflow: hidden;
        white-space: nowrap; }
      html body main article section#restaurant .tabs .tabs__bar {
        position: relative;
        display: flex;
        gap: 0px;
        align-items: center;
        max-width: 1280px;
        margin: 0 auto; }
        @media screen and (max-width: 1100px) {
          html body main article section#restaurant .tabs .tabs__bar {
            flex-wrap: wrap; } }
        @media screen and (max-width: 900px) {
          html body main article section#restaurant .tabs .tabs__bar {
            justify-content: center; } }
        html body main article section#restaurant .tabs .tabs__bar .tabs__tab {
          position: relative;
          display: inline-flex;
          align-items: center;
          justify-content: center;
          white-space: nowrap;
          height: 120px;
          width: 16.66666%;
          cursor: pointer;
          user-select: none;
          border-bottom: 3px solid transparent; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__bar .tabs__tab {
              width: 33.33333%; } }
          @media screen and (max-width: 900px) {
            html body main article section#restaurant .tabs .tabs__bar .tabs__tab {
              width: 33.333333%;
              height: 70px; } }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab img {
            display: block;
            width: auto; }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab span {
            font-size: 1.4375rem;
            font-weight: 500;
            text-align: center;
            color: black; }
            @media screen and (max-width: 1100px) {
              html body main article section#restaurant .tabs .tabs__bar .tabs__tab span {
                font-size: 0.875rem; } }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(1) img {
            height: 52px; }
            @media screen and (max-width: 1100px) {
              html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(1) img {
                height: 39px; } }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(2) img {
            height: 23px; }
            @media screen and (max-width: 1100px) {
              html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(2) img {
                height: 17px; } }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(3) img {
            height: 52px; }
            @media screen and (max-width: 1100px) {
              html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(3) img {
                height: 39px; } }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(4) img {
            height: 44px; }
            @media screen and (max-width: 1100px) {
              html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(4) img {
                height: 33px; } }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(5) img {
            height: 44px; }
            @media screen and (max-width: 1100px) {
              html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(5) img {
                height: 33px; } }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(6) img {
            height: 38px; }
            @media screen and (max-width: 1100px) {
              html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(6) img {
                height: 28px; } }
          html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(7) img {
            height: 52px; }
            @media screen and (max-width: 1100px) {
              html body main article section#restaurant .tabs .tabs__bar .tabs__tab:nth-child(7) img {
                height: 39px; } }
        html body main article section#restaurant .tabs .tabs__bar .tabs__tab:hover {
          opacity: 0.8; }
        html body main article section#restaurant .tabs .tabs__bar .tabs__tab:focus-visible {
          outline: 2px solid #8a0e24;
          outline-offset: 3px; }
      html body main article section#restaurant .tabs .tabs__bar::-webkit-scrollbar {
        display: none; }
      html body main article section#restaurant .tabs .tabs__bar::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        height: 1px;
        background: rgba(0, 0, 0, 0.06);
        pointer-events: none; }
      html body main article section#restaurant .tabs .tabs__arrows.pc {
        display: grid;
        grid-template-columns: 60px 510px 60px;
        justify-content: center;
        align-items: center;
        gap: 10px;
        margin: 0 auto 40px; }
      html body main article section#restaurant .tabs .tabs__arrows.sp .rest-head__logo {
        justify-self: center; }
      html body main article section#restaurant .tabs .tabs__arrows.sp .tab-prev {
        justify-self: start; }
      html body main article section#restaurant .tabs .tabs__arrows.sp .tab-next {
        justify-self: end; }
      html body main article section#restaurant .tabs .tabs__arrows .tab-prev, html body main article section#restaurant .tabs .tabs__arrows .tab-next {
        justify-self: center;
        width: 13px;
        height: 21px;
        border: 0;
        background-repeat: no-repeat;
        background-position: center;
        background-size: 13px 21px;
        background-color: inherit;
        cursor: pointer; }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .tabs .tabs__arrows .tab-prev, html body main article section#restaurant .tabs .tabs__arrows .tab-next {
            width: 9px;
            height: 16px;
            background-size: 9px 16px; } }
      html body main article section#restaurant .tabs .tab-prev, html body main article section#restaurant .tabs .tab-next {
        justify-self: center;
        width: 44px;
        height: 44px;
        border: 0;
        cursor: pointer; }
      html body main article section#restaurant .tabs .tabs__arrows .tab-prev {
        background-image: url("../image/tab-prev.png"); }
      html body main article section#restaurant .tabs .tabs__arrows .tab-next {
        background-image: url("../image/tab-next.png"); }
      html body main article section#restaurant .tabs .tabs__arrows .tab-prev:hover {
        background-image: url("../image/tab-prev-hover.png"); }
      html body main article section#restaurant .tabs .tabs__arrows .tab-next:hover {
        background-image: url("../image/tab-next-hover.png"); }
      @media screen and (max-width: 768px) {
        html body main article section#restaurant .tabs .tabs__arrows.pc {
          display: none; } }
      html body main article section#restaurant .tabs .tabs__arrows.sp {
        display: none; }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .tabs .tabs__arrows.sp {
            display: grid;
            grid-template-columns: 24px 1fr 24px;
            justify-content: center;
            align-items: center;
            gap: 10px;
            margin: 0 auto;
            width: 100%; } }
      html body main article section#restaurant .tabs .tabs__arrows.ptn2, html body main article section#restaurant .tabs .tabs__arrows.ptn3, html body main article section#restaurant .tabs .tabs__arrows.ptn4 {
        display: block;
        margin: 0;
        position: relative; }
        html body main article section#restaurant .tabs .tabs__arrows.ptn2 .tab-prev, html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-prev, html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-prev {
          position: absolute;
          top: 225px;
          left: -3%; }
          @media screen and (max-width: 1280px) {
            html body main article section#restaurant .tabs .tabs__arrows.ptn2 .tab-prev, html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-prev, html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-prev {
              left: 3%; } }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__arrows.ptn2 .tab-prev, html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-prev, html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-prev {
              display: none; } }
        html body main article section#restaurant .tabs .tabs__arrows.ptn2 .tab-next, html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-next, html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-next {
          position: absolute;
          top: 225px;
          right: -3%; }
          @media screen and (max-width: 1280px) {
            html body main article section#restaurant .tabs .tabs__arrows.ptn2 .tab-next, html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-next, html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-next {
              right: 3%; } }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__arrows.ptn2 .tab-next, html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-next, html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-next {
              display: none; } }
      html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-prev {
        position: absolute;
        top: 170px;
        left: -3%; }
        @media screen and (max-width: 1280px) {
          html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-prev {
            left: 3%; } }
      html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-next {
        position: absolute;
        top: 170px;
        right: -3%; }
        @media screen and (max-width: 1280px) {
          html body main article section#restaurant .tabs .tabs__arrows.ptn3 .tab-next {
            right: 3%; } }
      html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-prev {
        position: absolute;
        top: 310px;
        left: -3%; }
        @media screen and (max-width: 1280px) {
          html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-prev {
            left: 3%; } }
      html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-next {
        position: absolute;
        top: 310px;
        right: -3%; }
        @media screen and (max-width: 1280px) {
          html body main article section#restaurant .tabs .tabs__arrows.ptn4 .tab-next {
            right: 3%; } }
      html body main article section#restaurant .tabs .tabs__panels {
        margin-top: 90px;
        max-width: 1080px;
        margin: 88px auto 200px;
        color: #62401a; }
        @media screen and (max-width: 1100px) {
          html body main article section#restaurant .tabs .tabs__panels {
            margin: 88px 20px 200px; } }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .tabs .tabs__panels {
            margin: 48px 20px 160px; } }
      html body main article section#restaurant .tabs .tabs__panel {
        display: none;
        /* セクション全体 */ }
        html body main article section#restaurant .tabs .tabs__panel .photo, html body main article section#restaurant .tabs .tabs__panel .photo.sp {
          margin: 0 auto;
          border-radius: 12px;
          overflow: hidden;
          width: 516px;
          height: 350px; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .photo, html body main article section#restaurant .tabs .tabs__panel .photo.sp {
              margin: 0 auto;
              width: 516px;
              height: 350px; } }
        html body main article section#restaurant .tabs .tabs__panel .photo.sp {
          display: none; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .photo.sp {
              display: block;
              width: 100%;
              height: auto;
              margin: 0 auto 40px; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__photo.long {
          width: 450px;
          height: 630px; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__photo.long {
              width: 335px;
              height: 496px; } }
        html body main article section#restaurant .tabs .tabs__panel .photo img {
          display: block;
          width: 100%;
          height: auto;
          object-fit: cover; }
        html body main article section#restaurant .tabs .tabs__panel .rest-head {
          position: relative;
          margin: 0 0 76px;
          height: 90px; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head {
              height: 140px; } }
          html body main article section#restaurant .tabs .tabs__panel .rest-head::after {
            content: "";
            position: absolute;
            left: 0;
            right: 0;
            bottom: -26px;
            height: 5px;
            background: linear-gradient(#62401a) bottom/100% 0.75px no-repeat, linear-gradient(#62401a) top/100% 1.5px no-repeat;
            opacity: .95;
            pointer-events: none; }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .tabs .tabs__panel .rest-head.page2, html body main article section#restaurant .tabs .tabs__panel .rest-head.page6 {
            height: 173px; } }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .tabs .tabs__panel .rest-head.page7 {
            height: 25px; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__inner {
          max-width: 1080px;
          margin: 0 auto;
          height: 90px; }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__floor {
          display: flex;
          justify-content: center;
          align-items: center;
          margin: 0 auto 16px;
          border: 1px solid #62401a;
          border-radius: 999px;
          width: 75px;
          height: 28px;
          font-size: 1.125rem;
          font-weight: 700;
          letter-spacing: 0.04em; }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__row {
          display: grid;
          grid-template-columns: 1fr auto 1fr;
          align-items: center;
          column-gap: 16px; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__row {
              display: flex;
              justify-content: center;
              align-items: center;
              flex-direction: column;
              gap: 24px; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__title {
          margin: 0;
          text-align: center;
          font-size: 1.875rem;
          font-weight: 700;
          letter-spacing: 0.04em;
          line-height: 1.5;
          grid-column: 2; }
          html body main article section#restaurant .tabs .tabs__panel .rest-head__title .brsp {
            display: none; }
            @media screen and (max-width: 768px) {
              html body main article section#restaurant .tabs .tabs__panel .rest-head__title .brsp {
                display: block; } }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__title {
              font-size: 1.375rem; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__title.ma {
          margin: 44px 0 0 0; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__title.ma {
              margin: 0; } }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .tabs .tabs__panel .rest-head__title.pc {
            display: none; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__logo {
          object-fit: contain;
          height: 52px;
          justify-self: end;
          display: block; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__logo {
              height: 39px; } }
        @media screen and (max-width: 768px) {
          html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.pc {
            display: none; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page2 {
          height: 31.35px; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page2 {
              height: 26px; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page3 {
          height: 52px; }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page4 {
          height: 44px; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page4 {
              height: 32px; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page5 {
          height: 44px; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page5 {
              height: 32px; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page6 {
          height: 38px; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page6 {
              height: 28px; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page7 {
          height: 52px; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .rest-head__logo.page7 {
              height: 39px; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-top {
          font-size: 1.125rem;
          font-weight: 500;
          margin: 0 0 64px;
          text-align: center;
          line-height: 1.5; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-top {
              font-size: 0.875rem; } }
        html body main article section#restaurant .tabs .tabs__panel .course__grid {
          display: grid;
          grid-template-columns: 1fr 1fr;
          gap: 48px; }
          @media screen and (max-width: 1280px) {
            html body main article section#restaurant .tabs .tabs__panel .course__grid {
              grid-template-columns: 1fr;
              gap: 56px; } }
        @media screen and (max-width: 1280px) {
          html body main article section#restaurant .tabs .tabs__panel .course__grid.col01 {
            gap: 0; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__cap {
          font-family: "Baskervville", serif;
          font-size: 1.875rem;
          font-weight: 700;
          letter-spacing: 0.05em;
          margin: 0 0 32px;
          text-align: center; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__cap {
              margin: 0 0 24px; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__cap span {
          position: relative;
          display: inline-block; }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__cap span::before,
        html body main article section#restaurant .tabs .tabs__panel .menu-card__cap span::after {
          position: absolute;
          content: "";
          background-image: url(../image/rest-ten-hosi.png);
          background-repeat: no-repeat;
          background-size: contain;
          width: 25px;
          height: 25px;
          top: 0; }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__cap span::before {
          left: -35px; }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__cap span::after {
          right: -35px; }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__photo {
          margin: 0 0 40px;
          border-radius: 12px;
          overflow: hidden; }
          @media screen and (max-width: 1280px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__photo {
              margin: 0 auto 40px;
              width: 516px;
              height: 350px; } }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__photo {
              width: auto;
              height: auto; } }
        @media screen and (max-width: 1100px) {
          html body main article section#restaurant .tabs .tabs__panel .menu-card__photo.col01 {
            margin: 0 auto 40px; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__photo img {
          display: block;
          width: 100%;
          height: auto;
          object-fit: cover; }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__label {
          margin: 0 0 16px;
          font-size: 1.375rem;
          font-weight: 700;
          letter-spacing: 0.04em;
          padding: 0 0 16px;
          margin: 0 0 24px;
          border-bottom: 1px solid #62401a; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__label {
              font-size: 1.25rem; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__label__time {
          margin: 0 0 40px;
          font-size: 1.125rem;
          font-weight: 400;
          letter-spacing: 0.04em;
          line-height: 1.6; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__label__time {
              font-size: 0.875rem; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__label__time.col01 {
          line-height: 1.5; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__label__time.col01 {
              font-size: 0.875rem; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__list {
          font-size: 1.125rem;
          font-weight: 400;
          letter-spacing: 0.04em;
          margin: 0 0 32px;
          line-height: 1.5; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__list {
              font-size: 0.875rem;
              margin: 0 0 40px; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__list .row {
          display: grid;
          grid-template-columns: 3em 1fr;
          margin: 0 0 10px;
          align-items: center; }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__list dt {
          margin: 0;
          letter-spacing: 0.04em; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__list dt {
              display: flex;
              align-items: center; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__list dd {
          margin: 0;
          white-space: nowrap;
          border-left: 1px solid #62401a;
          padding: 0 0 0 18px;
          letter-spacing: 0.04em;
          line-height: 1.5; }
          @media screen and (max-width: 1100px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__list dd {
              white-space: pre-wrap;
              line-height: 1.3; } }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__list dd.row {
          line-height: 1.5;
          white-space: nowrap; }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__list dd.row-col {
          line-height: 1.5;
          white-space: normal; }
        html body main article section#restaurant .tabs .tabs__panel .menu-card__note {
          margin: 40px 0 0;
          font-size: 1rem;
          line-height: 1.5; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .menu-card__note {
              margin: 10px 0 0;
              font-size: 0.75rem; } }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta {
          display: flex;
          align-items: center;
          padding: 20px 40px;
          border: 1px solid #62401a;
          border-radius: 9999px;
          background: white;
          color: #62401a;
          font-size: 1.125rem;
          font-weight: 700;
          letter-spacing: 0.04em;
          gap: 24px;
          width: 328px;
          height: 58px;
          transition: background-color 0.4s ease-in-out,color 0.4s ease-in-out,border-color 0.4s ease-in-out; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .ig-cta {
              font-size: 1rem;
              padding: 20px 40px;
              gap: 16px;
              width: 307px;
              height: 56px;
              margin: 0 auto; } }
          html body main article section#restaurant .tabs .tabs__panel .ig-cta span {
            margin: 0; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta.col01 {
          width: 253px; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .ig-cta.col01 {
              width: 241px; } }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta, html body main article section#restaurant .tabs .tabs__panel .ig-cta:link, html body main article section#restaurant .tabs .tabs__panel .ig-cta:visited {
          color: #62401a !important; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta * {
          color: inherit; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__icon {
          position: relative;
          inline-size: 24px;
          block-size: 24px; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__icon img {
          position: absolute;
          inset: 0;
          width: 100%;
          height: 100%;
          object-fit: contain;
          transition: opacity 0.4s ease-in-out;
          will-change: opacity; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__icon img.normal {
          opacity: 1; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__icon img.hover {
          opacity: 0; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__text {
          white-space: nowrap; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__text .jp {
          margin: 0; }
          @media screen and (max-width: 768px) {
            html body main article section#restaurant .tabs .tabs__panel .ig-cta__text .jp {
              display: block; } }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__arrow {
          position: relative;
          margin-left: auto;
          inline-size: 37px;
          block-size: 37px; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__arrow img {
          position: absolute;
          inset: 0;
          width: 100%;
          height: 100%;
          object-fit: contain;
          transition: opacity 0.4s ease-in-out;
          will-change: opacity; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__arrow img.normal {
          opacity: 1; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta__arrow img.hover {
          opacity: 0; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta:is(:hover, :focus-visible) {
          background: #8e0126;
          color: white !important;
          border-color: white; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
        html body main article section#restaurant .tabs .tabs__panel .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal {
          opacity: 0; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
        html body main article section#restaurant .tabs .tabs__panel .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
          opacity: 1; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
          transform: translateX(4px);
          transition: opacity 0.4s ease-in-out, transform 0.3s ease; }
        html body main article section#restaurant .tabs .tabs__panel .ig-cta:focus-visible {
          outline: 2px solid white; }
        html body main article section#restaurant .tabs .tabs__panel .reserve-cta {
          margin: 88px 0 0 0; }
        html body main article section#restaurant .tabs .tabs__panel .reserve-cta__btn {
          position: relative;
          display: flex;
          justify-content: center;
          align-items: center;
          gap: 40px;
          border-radius: 10px;
          background: #8e0126;
          width: 826px;
          height: 156px;
          margin: 0 auto;
          z-index: 1; }
          @media screen and (max-width: 900px) {
            html body main article section#restaurant .tabs .tabs__panel .reserve-cta__btn {
              width: 334px;
              height: 206px;
              padding: 42px 30px; } }
          html body main article section#restaurant .tabs .tabs__panel .reserve-cta__btn::after {
            content: "";
            position: absolute;
            inset: 6px;
            border-radius: 7px;
            box-shadow: 0 0 0 1.5px #e2b7a8 inset;
            pointer-events: none; }
        html body main article section#restaurant .tabs .tabs__panel .reserve-cta__text {
          font-size: 2.1875rem;
          font-weight: 700;
          color: white;
          position: relative; }
          @media screen and (max-width: 900px) {
            html body main article section#restaurant .tabs .tabs__panel .reserve-cta__text {
              font-size: 1.75rem; } }
          html body main article section#restaurant .tabs .tabs__panel .reserve-cta__text::before {
            position: absolute;
            content: "";
            background-image: url(../image/rest-bef.png);
            background-repeat: no-repeat;
            background-size: contain;
            width: 72px;
            height: 87px;
            top: -10px;
            left: -110px; }
            @media screen and (max-width: 900px) {
              html body main article section#restaurant .tabs .tabs__panel .reserve-cta__text::before {
                display: none; } }
        html body main article section#restaurant .tabs .tabs__panel .reserve-cta__text strong {
          font-family: "Baskervville", serif;
          padding: 0 0 0 10px;
          letter-spacing: 0.05em; }
          @media screen and (max-width: 900px) {
            html body main article section#restaurant .tabs .tabs__panel .reserve-cta__text strong {
              padding: 0; } }
        html body main article section#restaurant .tabs .tabs__panel .reserve-cta__jp {
          font-size: 1.125rem;
          font-weight: 700;
          letter-spacing: 0.04em; }
          @media screen and (max-width: 900px) {
            html body main article section#restaurant .tabs .tabs__panel .reserve-cta__jp {
              font-size: 1rem;
              display: block;
              margin: 15px 0 0 0; } }
        html body main article section#restaurant .tabs .tabs__panel .reserve-cta__note {
          display: block;
          font-size: 0.875rem;
          font-weight: 500;
          letter-spacing: 0.04em;
          line-height: 1.5;
          margin: 16px 0 0 0; }
          @media screen and (max-width: 900px) {
            html body main article section#restaurant .tabs .tabs__panel .reserve-cta__note {
              font-size: 0.75rem;
              margin: 24px 0 0 0;
              line-height: 1.5; } }
        html body main article section#restaurant .tabs .tabs__panel .rest-arrow {
          display: inline-block;
          position: relative; }
          html body main article section#restaurant .tabs .tabs__panel .rest-arrow::after {
            position: absolute;
            content: "";
            background-image: url(../image/rest-aft.png);
            background-repeat: no-repeat;
            background-size: contain;
            width: 72px;
            height: 87px;
            top: 0px;
            right: -110px; }
            @media screen and (max-width: 900px) {
              html body main article section#restaurant .tabs .tabs__panel .rest-arrow::after {
                display: none; } }
          html body main article section#restaurant .tabs .tabs__panel .rest-arrow img {
            display: block;
            width: 90px;
            transition: opacity 0.3s ease-in-out; }
            @media screen and (max-width: 900px) {
              html body main article section#restaurant .tabs .tabs__panel .rest-arrow img {
                width: 70px; } }
          html body main article section#restaurant .tabs .tabs__panel .rest-arrow .hover {
            position: absolute;
            top: 0;
            left: 0;
            opacity: 0; }
        html body main article section#restaurant .tabs .tabs__panel .reserve-cta__btn:is(:hover, :focus-visible) .rest-arrow .normal {
          opacity: 0; }
        html body main article section#restaurant .tabs .tabs__panel .reserve-cta__btn:is(:hover, :focus-visible) .rest-arrow .hover {
          opacity: 1; }
    html body main article section#restaurant #rest-1:checked ~ .tabs__bar label[for="rest-1"],
    html body main article section#restaurant #rest-2:checked ~ .tabs__bar label[for="rest-2"],
    html body main article section#restaurant #rest-3:checked ~ .tabs__bar label[for="rest-3"],
    html body main article section#restaurant #rest-4:checked ~ .tabs__bar label[for="rest-4"],
    html body main article section#restaurant #rest-5:checked ~ .tabs__bar label[for="rest-5"],
    html body main article section#restaurant #rest-6:checked ~ .tabs__bar label[for="rest-6"],
    html body main article section#restaurant #rest-7:checked ~ .tabs__bar label[for="rest-7"] {
      border-bottom-color: #8a0e24;
      /* 赤い下線 */
      transform: translateY(-1px);
      /* ほんの少し持ち上げる */ }
      html body main article section#restaurant #rest-1:checked ~ .tabs__bar label[for="rest-1"] img,
      html body main article section#restaurant #rest-2:checked ~ .tabs__bar label[for="rest-2"] img,
      html body main article section#restaurant #rest-3:checked ~ .tabs__bar label[for="rest-3"] img,
      html body main article section#restaurant #rest-4:checked ~ .tabs__bar label[for="rest-4"] img,
      html body main article section#restaurant #rest-5:checked ~ .tabs__bar label[for="rest-5"] img,
      html body main article section#restaurant #rest-6:checked ~ .tabs__bar label[for="rest-6"] img,
      html body main article section#restaurant #rest-7:checked ~ .tabs__bar label[for="rest-7"] img {
        filter: none;
        opacity: 1; }
@keyframes tabs-fade {
  from {
    opacity: 0;
    transform: translateY(2px); }
  to {
    opacity: 1;
    transform: translateY(0); } }
    html body main article section#restaurant #rest-1:checked ~ .tabs__panels #panel-1,
    html body main article section#restaurant #rest-2:checked ~ .tabs__panels #panel-2,
    html body main article section#restaurant #rest-3:checked ~ .tabs__panels #panel-3,
    html body main article section#restaurant #rest-4:checked ~ .tabs__panels #panel-4,
    html body main article section#restaurant #rest-5:checked ~ .tabs__panels #panel-5,
    html body main article section#restaurant #rest-6:checked ~ .tabs__panels #panel-6,
    html body main article section#restaurant #rest-7:checked ~ .tabs__panels #panel-7 {
      display: block; }
  html body main article section#salon {
    position: relative;
    background-color: #bfa271;
    padding: 0 0 380px 0;
    display: block;
    width: 100%;
    z-index: 3; }
    @media screen and (max-width: 900px) {
      html body main article section#salon {
        padding: 0 0 330px 0; } }
    html body main article section#salon::before {
      content: "";
      display: block;
      position: absolute;
      top: -100px;
      width: 100%;
      height: 100vh;
      background-image: url(../image/salon-bg.png);
      background-repeat: no-repeat;
      background-size: 100% auto;
      z-index: 0; }
      @media screen and (max-width: 768px) {
        html body main article section#salon::before {
          background-image: url(../image/salon-bg-sp03.png); } }
    html body main article section#salon .salon-inner {
      text-align: center;
      position: relative;
      color: white;
      margin: 0 0 96px 0;
      padding: 136px 0 0 0; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .salon-inner {
          margin: 0 0 56px 0;
          padding: 55px 0 0 0; } }
      html body main article section#salon .salon-inner h2 {
        font-family: "Baskervville", serif;
        font-size: 3rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        margin: 0 0 16px 0; }
        @media screen and (max-width: 768px) {
          html body main article section#salon .salon-inner h2 {
            font-size: 2.1875rem;
            line-height: 1.2; } }
        html body main article section#salon .salon-inner h2 .brsp {
          display: none; }
          @media screen and (max-width: 768px) {
            html body main article section#salon .salon-inner h2 .brsp {
              display: block; } }
      html body main article section#salon .salon-inner .sub {
        display: block;
        font-family: "Noto Serif JP", serif;
        font-size: 1.25rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        margin: 0 0 24px 0; }
        @media screen and (max-width: 768px) {
          html body main article section#salon .salon-inner .sub {
            font-size: 1rem;
            margin: 0 0 24px 0; } }
      html body main article section#salon .salon-inner p {
        font-size: 1.125rem;
        font-weight: 500;
        line-height: 1.5;
        letter-spacing: 0.04em; }
        @media screen and (max-width: 768px) {
          html body main article section#salon .salon-inner p {
            font-size: 0.875rem;
            padding: 0 20px; } }
        html body main article section#salon .salon-inner p.txt {
          margin: 0; }
        @media screen and (max-width: 768px) {
          html body main article section#salon .salon-inner p .brpc {
            display: none; } }
    html body main article section#salon .gold-plan {
      position: relative; }
      html body main article section#salon .gold-plan::before {
        content: "";
        position: absolute;
        left: 0;
        bottom: -140px;
        width: 344px;
        height: 347px;
        background-image: url(../image/salon-leaf.png);
        background-repeat: no-repeat;
        background-size: contain; }
        @media screen and (max-width: 768px) {
          html body main article section#salon .gold-plan::before {
            display: none; } }
    html body main article section#salon .gold-plan__inner {
      max-width: 1080px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 420px 1fr;
      gap: 64px; }
      @media screen and (max-width: 1100px) {
        html body main article section#salon .gold-plan__inner {
          grid-template-columns: 1fr;
          padding: 0 20px; } }
    html body main article section#salon .gold-plan__photo {
      margin: 0; }
      @media screen and (max-width: 1100px) {
        html body main article section#salon .gold-plan__photo {
          width: 420px;
          height: 382px;
          margin: 0 auto; } }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__photo {
          width: 100%;
          height: 100%; } }
    html body main article section#salon .gold-plan__photo img {
      display: block;
      width: 100%;
      height: auto;
      object-fit: cover; }
    html body main article section#salon .gold-plan__body {
      color: white; }
    html body main article section#salon .gold-plan__copy {
      margin: 0 0 10px;
      font-size: 1.375rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      line-height: 1.6; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__copy {
          font-size: 1.0625rem; } }
    html body main article section#salon .gold-plan__time {
      margin: 0 0 40px;
      font-size: 1.125rem;
      font-weight: 400; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__time {
          font-size: 0.875rem; } }
      html body main article section#salon .gold-plan__time .brsp {
        display: none; }
        @media screen and (max-width: 768px) {
          html body main article section#salon .gold-plan__time .brsp {
            display: block; } }
    html body main article section#salon .gold-plan__title {
      position: relative;
      margin: 0 0 24px;
      padding: 0 0 16px;
      font-size: 1.375rem;
      font-weight: 700;
      letter-spacing: 0.04em; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__title {
          font-size: 1.25rem; } }
    html body main article section#salon .gold-plan__title::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 1px;
      background: white; }
    html body main article section#salon .gold-plan__lead {
      font-size: 1.125rem;
      font-weight: 500;
      letter-spacing: 0.04em;
      line-height: 1.6;
      margin: 0 0 24px; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__lead {
          font-size: 0.875rem; } }
    html body main article section#salon .gold-plan__spec {
      font-size: 1.125rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      line-height: 1.5;
      margin: 0 0 40px; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__spec {
          font-size: 0.875rem; } }
    html body main article section#salon .gold-plan__spec .row {
      display: grid;
      grid-template-columns: 44px 1fr;
      margin: 0 0 10px;
      align-items: center;
      gap: 16px; }
    html body main article section#salon .gold-plan__spec dd {
      border-left: 1px solid white;
      margin: 0;
      padding: 0 0 0 16px;
      line-height: 1.5; }
    html body main article section#salon .gold-plan__spec.dinner {
      margin: 0 0 24px; }
    html body main article section#salon .gold-plan__spec.dinner .row {
      grid-template-columns: 44px 1fr; }
    html body main article section#salon .gold-plan__spec.dinner dd .brsp {
      display: none; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__spec.dinner dd .brsp {
          display: block; } }
    html body main article section#salon .gold-plan__sub {
      position: relative;
      margin: 0 0 24px;
      padding: 0 0 16px;
      font-size: 1.375rem;
      font-weight: 700;
      letter-spacing: 0.04em; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__sub {
          font-size: 1.25rem; } }
    html body main article section#salon .gold-plan__sub::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 1px;
      background: white; }
    html body main article section#salon .gold-plan__contact {
      font-size: 1.125rem;
      font-weight: 500;
      margin: 0 0 40px;
      letter-spacing: 0.04em;
      line-height: 1.6;
      color: white; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__contact {
          font-size: 0.875rem; } }
      html body main article section#salon .gold-plan__contact a[href^="tel"] {
        color: white;
        text-decoration: none; }
    html body main article section#salon .gold-plan__note {
      font-size: 1rem;
      font-weight: 500;
      letter-spacing: 0.04em;
      line-height: 1.6;
      margin: 0 0 56px; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .gold-plan__note {
          font-size: 0.75rem; } }
    html body main article section#salon .ig-cta {
      display: flex;
      align-items: center;
      padding: 20px 40px;
      border: 1px solid #bfa271;
      border-radius: 9999px;
      background: white;
      color: #bfa271;
      font-size: 1.25rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      gap: 24px;
      width: 310px;
      height: 58px;
      margin: 0 0 0 auto;
      transition: background-color 0.4s ease-in-out,color 0.4s ease-in-out,border-color 0.4s ease-in-out; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .ig-cta {
          font-size: 1.125rem;
          margin: 0 auto; } }
      html body main article section#salon .ig-cta span {
        margin: 0; }
    html body main article section#salon .ig-cta, html body main article section#salon .ig-cta:link, html body main article section#salon .ig-cta:visited {
      color: #bfa271 !important; }
    html body main article section#salon .ig-cta * {
      color: inherit; }
    html body main article section#salon .ig-cta__icon {
      position: relative;
      inline-size: 24px;
      block-size: 24px; }
    html body main article section#salon .ig-cta__icon img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: contain;
      transition: opacity 0.4s ease-in-out;
      will-change: opacity; }
    html body main article section#salon .ig-cta__icon img.normal {
      opacity: 1; }
    html body main article section#salon .ig-cta__icon img.hover {
      opacity: 0; }
    html body main article section#salon .ig-cta__text {
      white-space: nowrap; }
    html body main article section#salon .ig-cta__text .jp {
      margin: 0; }
      @media screen and (max-width: 768px) {
        html body main article section#salon .ig-cta__text .jp {
          display: block; } }
    html body main article section#salon .ig-cta__arrow {
      position: relative;
      margin-left: auto;
      inline-size: 37px;
      block-size: 37px; }
    html body main article section#salon .ig-cta__arrow img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: contain;
      transition: opacity 0.4s ease-in-out;
      will-change: opacity; }
    html body main article section#salon .ig-cta__arrow img.normal {
      opacity: 1; }
    html body main article section#salon .ig-cta__arrow img.hover {
      opacity: 0; }
    html body main article section#salon .ig-cta:is(:hover, :focus-visible) {
      background: #bfa271;
      color: white !important;
      border-color: white; }
    html body main article section#salon .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
    html body main article section#salon .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal {
      opacity: 0; }
    html body main article section#salon .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
    html body main article section#salon .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
      opacity: 1; }
    html body main article section#salon .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
      transform: translateX(4px);
      transition: opacity 0.4s ease-in-out, transform 0.3s ease; }
    html body main article section#salon .ig-cta:focus-visible {
      outline: 2px solid white; }
    @media (max-width: 420px) {
      html body main article section#salon .ig-cta {
        white-space: normal; } }
  html body main article section#show {
    position: relative;
    color: white;
    background-color: #8e0126;
    padding: 0 0 88px 0;
    z-index: 3;
    display: block;
    width: 100%; }
    html body main article section#show::before {
      content: "";
      display: block;
      position: absolute;
      top: -270px;
      width: 100%;
      height: 100vh;
      background-image: url(../image/show-bg02.png);
      background-repeat: no-repeat;
      background-size: 100% auto;
      z-index: 0; }
      @media screen and (max-width: 900px) {
        html body main article section#show::before {
          top: -200px; } }
      @media screen and (max-width: 768px) {
        html body main article section#show::before {
          height: 100%;
          background-image: url(../image/show-bg-sp.png); } }
    html body main article section#show .show-inner {
      text-align: center;
      position: relative;
      color: white;
      margin: 0 0 88px 0;
      padding: 0;
      z-index: 3; }
      @media screen and (max-width: 768px) {
        html body main article section#show .show-inner {
          margin: 0 0 56px 0; } }
      html body main article section#show .show-inner h2 {
        font-family: "Baskervville", serif;
        font-size: 3rem;
        font-weight: 700;
        margin: 0 0 16px 0;
        position: relative;
        letter-spacing: 0.05em; }
        @media screen and (max-width: 768px) {
          html body main article section#show .show-inner h2 {
            font-size: 2.1875rem;
            line-height: 1.2; } }
        html body main article section#show .show-inner h2 .brsp {
          display: none; }
          @media screen and (max-width: 768px) {
            html body main article section#show .show-inner h2 .brsp {
              display: block; } }
        html body main article section#show .show-inner h2::before {
          content: "";
          position: absolute;
          top: -346px;
          left: -269px;
          z-index: 2;
          pointer-events: none;
          background-image: url("../image/show-left02.png");
          background-repeat: no-repeat;
          width: 1084px;
          height: 482px;
          transform: scale(0.5); }
          @media screen and (max-width: 900px) {
            html body main article section#show .show-inner h2::before {
              left: -324px;
              transform: scale(0.4); } }
          @media screen and (max-width: 768px) {
            html body main article section#show .show-inner h2::before {
              background-image: url("../image/show-left02-sp.png");
              width: 1050px;
              left: -366px;
              transform: scale(0.3); } }
        html body main article section#show .show-inner h2::after {
          content: "";
          position: absolute;
          top: -327px;
          right: -162px;
          z-index: 2;
          pointer-events: none;
          background-image: url("../image/show-right.png");
          background-repeat: no-repeat;
          width: 650px;
          height: 588px;
          transform: scale(0.5); }
          @media screen and (max-width: 1100px) {
            html body main article section#show .show-inner h2::after {
              right: -162px; } }
          @media screen and (max-width: 768px) {
            html body main article section#show .show-inner h2::after {
              display: none; } }
      html body main article section#show .show-inner .sub {
        display: block;
        font-family: "Noto Serif JP", serif;
        font-size: 1.25rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        margin: 0 0 24px 0; }
        @media screen and (max-width: 768px) {
          html body main article section#show .show-inner .sub {
            font-size: 1rem;
            margin: 0 0 24px 0; } }
      html body main article section#show .show-inner p {
        font-size: 1.125rem;
        font-weight: 500;
        letter-spacing: 0.04em;
        line-height: 1.5; }
        @media screen and (max-width: 768px) {
          html body main article section#show .show-inner p {
            font-size: 1rem; } }
        html body main article section#show .show-inner p.txt {
          margin: 0; }
        html body main article section#show .show-inner p .brsp {
          display: none; }
          @media screen and (max-width: 768px) {
            html body main article section#show .show-inner p .brsp {
              display: block; } }
    html body main article section#show .show__inner {
      max-width: 1080px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 88px 40px;
      position: relative;
      z-index: 3; }
      @media screen and (max-width: 1100px) {
        html body main article section#show .show__inner {
          grid-template-columns: 1fr;
          gap: 64px;
          padding: 0 20px; } }
    html body main article section#show .show-card__title {
      margin: 0 0 24px;
      text-align: center;
      font-size: 2.1875rem;
      font-weight: 700;
      letter-spacing: 0.04em; }
      @media screen and (max-width: 768px) {
        html body main article section#show .show-card__title {
          font-size: 1.375rem; } }
    html body main article section#show .show-card__photo {
      margin: 0 0 24px;
      border-radius: 12px;
      overflow: hidden; }
      @media screen and (max-width: 1100px) {
        html body main article section#show .show-card__photo {
          width: 335px;
          height: 210px;
          margin: 0 auto 24px; } }
      @media screen and (max-width: 768px) {
        html body main article section#show .show-card__photo {
          width: auto;
          height: auto; } }
    html body main article section#show .show-card__photo img {
      display: block;
      width: 100%;
      height: auto;
      object-fit: cover; }
    html body main article section#show .show-card__subtitle {
      font-size: 1.375rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      margin: 0 0 24px;
      padding: 16px 0;
      text-align: center;
      border-top: 1px solid white;
      border-bottom: 1px solid white;
      color: #f0c6b1; }
      @media screen and (max-width: 768px) {
        html body main article section#show .show-card__subtitle {
          font-size: 1rem; } }
    html body main article section#show .show-card__spec {
      margin: 0;
      font-size: 1.125rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      line-height: 1.5; }
      @media screen and (max-width: 768px) {
        html body main article section#show .show-card__spec {
          font-size: 0.875rem; } }
    html body main article section#show .show-card__spec .row {
      display: grid;
      grid-template-columns: 38px 1fr;
      align-items: center;
      column-gap: 16px;
      padding: 0 0 16px; }
    html body main article section#show .show-card__spec dd {
      border-left: 1px solid white;
      margin: 0;
      padding: 0 0 0 18px; }
    html body main article section#show .show-card__spec dd.gyou {
      line-height: 1.5;
      white-space: nowrap;
      margin: 0; }
    html body main article section#show .show__note01, html body main article section#show .show__note02 {
      font-size: 1rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      line-height: 1.5;
      text-align: center;
      color: white; }
      html body main article section#show .show__note01 .brsp, html body main article section#show .show__note02 .brsp {
        display: none; }
        @media screen and (max-width: 768px) {
          html body main article section#show .show__note01 .brsp, html body main article section#show .show__note02 .brsp {
            display: block; } }
      @media screen and (max-width: 768px) {
        html body main article section#show .show__note01, html body main article section#show .show__note02 {
          font-size: 0.75rem; } }
    html body main article section#show .show__note01 {
      margin: 32px auto; }
      @media screen and (max-width: 768px) {
        html body main article section#show .show__note01 {
          margin: 32px auto 0; } }
      html body main article section#show .show__note01 a[href^="tel"] {
        color: white;
        text-decoration: none; }
    html body main article section#show .show__note02 {
      margin: 0 auto; }
    html body main article section#show .cake-card__btn {
      display: block;
      width: 200px;
      margin: 24px auto 0;
      font-family: "Baskervville", serif;
      font-size: 1.125rem;
      font-weight: 700;
      padding: 10px 0;
      text-align: center;
      border-radius: 10px;
      font-weight: 700;
      letter-spacing: 0.05em;
      color: white;
      background: #b8afa5; }
    html body main article section#show .ig-cta {
      display: flex;
      align-items: center;
      padding: 20px 40px;
      border: 1px solid #8e0126;
      border-radius: 9999px;
      background: white;
      color: #8e0126;
      font-size: 1.25rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      gap: 24px;
      width: 310px;
      height: 58px;
      margin: 88px auto 0;
      transition: background-color 0.4s ease-in-out,color 0.4s ease-in-out,border-color 0.4s ease-in-out; }
      @media screen and (max-width: 768px) {
        html body main article section#show .ig-cta {
          font-size: 1.125rem;
          gap: 16px;
          margin: 56px auto 0; } }
      html body main article section#show .ig-cta span {
        margin: 0; }
    html body main article section#show .ig-cta, html body main article section#show .ig-cta:link, html body main article section#show .ig-cta:visited {
      color: #8e0126 !important; }
    html body main article section#show .ig-cta * {
      color: inherit; }
    html body main article section#show .ig-cta__icon {
      position: relative;
      inline-size: 24px;
      block-size: 24px; }
    html body main article section#show .ig-cta__icon img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: contain;
      transition: opacity 0.4s ease-in-out;
      will-change: opacity; }
    html body main article section#show .ig-cta__icon img.normal {
      opacity: 1; }
    html body main article section#show .ig-cta__icon img.hover {
      opacity: 0; }
    html body main article section#show .ig-cta__text {
      white-space: nowrap; }
    html body main article section#show .ig-cta__text .jp {
      margin: 0; }
      @media screen and (max-width: 768px) {
        html body main article section#show .ig-cta__text .jp {
          display: block; } }
    html body main article section#show .ig-cta__arrow {
      position: relative;
      margin-left: auto;
      inline-size: 37px;
      block-size: 37px; }
    html body main article section#show .ig-cta__arrow img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: contain;
      transition: opacity 0.4s ease-in-out;
      will-change: opacity; }
    html body main article section#show .ig-cta__arrow img.normal {
      opacity: 1; }
    html body main article section#show .ig-cta__arrow img.hover {
      opacity: 0; }
    html body main article section#show .ig-cta:is(:hover, :focus-visible) {
      background: #8e0126;
      color: white !important;
      border-color: white; }
    html body main article section#show .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.normal,
    html body main article section#show .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.normal {
      opacity: 0; }
    html body main article section#show .ig-cta:is(:hover, :focus-visible) .ig-cta__icon img.hover,
    html body main article section#show .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
      opacity: 1; }
    html body main article section#show .ig-cta:is(:hover, :focus-visible) .ig-cta__arrow img.hover {
      transform: translateX(4px);
      transition: opacity 0.4s ease-in-out, transform 0.3s ease; }
    html body main article section#show .ig-cta:focus-visible {
      outline: 2px solid white; }
    @media (max-width: 420px) {
      html body main article section#show .ig-cta {
        white-space: normal; } }
  html body main article section#access {
    color: #62401a;
    background: #f4f3f1;
    padding: 120px 0; }
    @media screen and (max-width: 768px) {
      html body main article section#access {
        padding: 80px 0; } }
    html body main article section#access .access-inner {
      text-align: center;
      position: relative;
      margin: 0 0 88px 0; }
      @media screen and (max-width: 768px) {
        html body main article section#access .access-inner {
          margin: 0 0 56px 0; } }
      html body main article section#access .access-inner h2 {
        font-family: "Baskervville", serif;
        font-size: 3rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        margin: 0 0 16px 0; }
        @media screen and (max-width: 768px) {
          html body main article section#access .access-inner h2 {
            font-size: 2.1875rem;
            line-height: 1.2; } }
        html body main article section#access .access-inner h2 .brsp {
          display: none; }
          @media screen and (max-width: 768px) {
            html body main article section#access .access-inner h2 .brsp {
              display: block; } }
      html body main article section#access .access-inner .sub {
        display: block;
        font-family: "Noto Serif JP", serif;
        font-size: 1.25rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        margin: 0 0 24px 0; }
        @media screen and (max-width: 768px) {
          html body main article section#access .access-inner .sub {
            font-size: 1rem;
            margin: 0 0 24px 0; } }
      html body main article section#access .access-inner p {
        font-size: 1.125rem;
        font-weight: 500;
        letter-spacing: 0.04em;
        line-height: 1.5; }
        @media screen and (max-width: 768px) {
          html body main article section#access .access-inner p {
            font-size: 1rem; } }
        html body main article section#access .access-inner p.txt {
          margin: 0; }
        html body main article section#access .access-inner p .brsp {
          display: none; }
          @media screen and (max-width: 768px) {
            html body main article section#access .access-inner p .brsp {
              display: block; } }
    html body main article section#access iframe {
      display: block;
      max-width: 800px;
      width: 100%;
      margin: 0 auto 56px; }
      @media screen and (max-width: 900px) {
        html body main article section#access iframe {
          padding: 0 20px; } }
    html body main article section#access .access {
      max-width: 800px;
      margin: 0 auto; }
      @media screen and (max-width: 900px) {
        html body main article section#access .access {
          padding: 0 20px; } }
    html body main article section#access .acc-sec {
      margin-bottom: 48px; }
    html body main article section#access .acc-sec__title {
      font-size: 1.375rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      position: relative;
      padding-bottom: 16px;
      border-bottom: 1px solid #62401a;
      margin: 0 0 24px; }
      @media screen and (max-width: 900px) {
        html body main article section#access .acc-sec__title {
          font-size: 1.25rem; } }
    html body main article section#access .acc-list {
      margin: 0 0 24px;
      padding: 0;
      list-style: none; }
    html body main article section#access .acc-list li {
      position: relative;
      padding-left: 18px;
      font-size: 1.125rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      line-height: 1.6; }
      @media screen and (max-width: 900px) {
        html body main article section#access .acc-list li {
          font-size: 0.875rem; } }
    html body main article section#access .acc-list li::before {
      content: "";
      position: absolute;
      left: 0;
      top: .7em;
      width: 7px;
      height: 7px;
      border-radius: 50%;
      background: #62401a;
      opacity: 1.0; }
    html body main article section#access .acc-box {
      background: white;
      border-radius: 10px;
      padding: 32px 48px; }
      @media screen and (max-width: 900px) {
        html body main article section#access .acc-box {
          padding: 24px 20px; } }
    html body main article section#access .acc-box + .acc-box {
      margin-top: 10px; }
    html body main article section#access .acc-box__title {
      margin: 0 0 16px;
      font-size: 1.25rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      line-height: 1.5; }
      @media screen and (max-width: 900px) {
        html body main article section#access .acc-box__title {
          font-size: 1.125rem; } }
    html body main article section#access .acc-box__lead {
      margin: 0;
      font-size: 1.125rem;
      font-weight: 400;
      line-height: 1.9; }
      @media screen and (max-width: 900px) {
        html body main article section#access .acc-box__lead {
          font-size: 0.875rem; } }
    html body main article section#access .acc-note {
      margin: 0;
      font-size: 1rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      line-height: 1.5; }
      @media screen and (max-width: 900px) {
        html body main article section#access .acc-note {
          font-size: 0.8125rem;
          line-height: 1.5; } }
    html body main article section#access .acc-dl {
      margin: 0 0 16px; }
    html body main article section#access .acc-dl .row {
      display: grid;
      grid-template-columns: 76px 1fr;
      column-gap: 16px;
      padding: 6px 0;
      align-items: center;
      font-size: 1.125rem;
      font-weight: 400;
      letter-spacing: 0.04em;
      line-height: 1.5; }
      @media screen and (max-width: 900px) {
        html body main article section#access .acc-dl .row {
          font-size: 0.8125rem; } }
    html body main article section#access .acc-dl dd {
      border-left: 1px solid #62401a;
      margin: 0;
      padding: 0 0 0 18px; }
    html body main article section#access .acc-dl dd.gyou {
      line-height: 1.5;
      white-space: nowrap;
      margin: 0; }
    html body main article section#access .acc-sec:last-child {
      margin-bottom: 0; }
  html body main article .slider {
    position: relative;
    width: 440px;
    margin: 0 auto;
    display: grid;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr auto 1fr;
    /* 左ボタン | ドット | 右ボタン */
    align-items: center;
    row-gap: 21px;
    font: inherit; }
    @media screen and (max-width: 768px) {
      html body main article .slider {
        width: 100%; } }
  html body main article .slides {
    grid-column: 1 / -1;
    grid-row: 1;
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; }
  html body main article .slides::-webkit-scrollbar {
    display: none; }
  html body main article .slides > figure, html body main article .slides.stay > figure {
    flex: 0 0 100%;
    margin: 0;
    scroll-snap-align: center;
    height: 510px; }
    @media screen and (max-width: 768px) {
      html body main article .slides > figure, html body main article .slides.stay > figure {
        height: 388px; } }
  html body main article .slides.stay > figure {
    height: 420px; }
    @media screen and (max-width: 768px) {
      html body main article .slides.stay > figure {
        height: 100%; } }
  html body main article .slides img {
    display: block;
    width: 100%;
    height: 100%; }
  html body main article .nav {
    grid-row: 2;
    position: relative;
    /* 円::beforeの基準 */
    width: 40px;
    /* 当たり判定 */
    height: 40px;
    padding: 0;
    border: 0;
    background: none !important;
    cursor: pointer;
    z-index: 0;
    /* ::before(リング)=0, 矢印img=1 で重なり制御 */ }
  html body main article .nav.prev {
    grid-column: 1;
    justify-self: end;
    left: -40px; }
  html body main article .nav.next {
    grid-column: 3;
    justify-self: start;
    right: -40px; }
  @media (max-width: 600px) {
    html body main article .nav.prev {
      left: -24px; }
    html body main article .nav.next {
      right: -24px; } }
  html body main article .dots {
    grid-row: 2;
    grid-column: 2;
    position: static;
    /* 以前のabsoluteを解除 */
    transform: none;
    /* 以前のtranslate解除 */
    display: flex;
    gap: 8px;
    margin: 0;
    padding: 0;
    justify-self: center; }
  html body main article .dots button {
    width: 8px !important;
    height: 8px;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.35);
    cursor: pointer; }
  html body main article .dots button[aria-selected="true"] {
    background: #fff; }
  html body main article .nav::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 36px;
    height: 36px;
    transform: translate(-50%, -50%);
    background: center/100% 100% no-repeat url("../image/enn02.png");
    pointer-events: none;
    z-index: 0; }
  html body main article .nav .arrow {
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    height: auto;
    /* 必要に応じて固定幅OK：例）width: 37px; */
    pointer-events: none;
    user-select: none;
    transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out;
    z-index: 1; }
  html body main article .nav.prev .arrow {
    transform: translate(0, -50%); }
  html body main article .nav.next .arrow {
    transform: translate(-100%, -50%); }
  @media (hover: hover) and (pointer: fine) {
    html body main article {
      /* 左へ5px */
      /* 右へ5px */ }
      html body main article .nav.prev:is(:hover, :focus-visible) .arrow {
        margin-left: -5px; }
      html body main article .nav.next:is(:hover, :focus-visible) .arrow {
        margin-left: 5px; } }
  html body main article .nav:focus-visible {
    outline: 2px solid #fff;
    outline-offset: 4px;
    border-radius: 999px; }
  html body main article .nav:active {
    transform: scale(0.96); }
  @media (prefers-reduced-motion: reduce) {
    html body main article .slides {
      scroll-behavior: auto; }
    html body main article .nav .arrow {
      transition: none; } }
  @media (max-width: 600px) {
    html body main article .slider {
      row-gap: 10px; }
    html body main article .nav {
      width: 64px;
      height: 64px; }
    html body main article .nav.prev {
      justify-self: end; }
    html body main article .nav.next {
      justify-self: start; } }
html body .pagetop {
  position: fixed;
  left: calc(50% + 514px);
  bottom: 80px;
  z-index: 50;
  width: 76px;
  height: 76px;
  border-radius: 50%;
  border: 2px solid #f0c6b1;
  background: #850124;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-decoration: none;
  opacity: 0;
  color: #f0c6b1;
  transition: background-color 0.4s ease-in-out,border-color 0.4s ease-in-out,color 0.4s ease-in-out,opacity 0.4s ease-in-out,transform 0.3s ease-in-out; }
  @media screen and (max-width: 1280px) {
    html body .pagetop {
      left: inherit;
      right: 50px; } }
  @media screen and (max-width: 768px) {
    html body .pagetop {
      width: 64px;
      height: 64px;
      right: 20px;
      bottom: 20px; } }
  html body .pagetop:hover {
    border: 2px solid #850124;
    background: #f0c6b1;
    color: #850124; }
html body .pagetop.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto; }
html body .pagetop__arrow, html body .pagetop__text {
  color: inherit; }
html body .pagetop__arrow {
  position: relative;
  width: 0;
  height: 18px;
  border-left: 3px solid currentColor; }
html body .pagetop__arrow::after {
  content: "";
  position: absolute;
  bottom: 5px;
  width: 14px;
  height: 14px;
  border-top: 3px solid currentColor;
  border-left: 3px solid currentColor; }
html body .pagetop__arrow::after {
  transform: translateX(-8.3px) rotate(45deg); }
html body .pagetop__text {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: .06em; }
  @media screen and (max-width: 768px) {
    html body .pagetop__text {
      font-size: 0.875rem; } }

html {
  font-family: "Noto Serif JP", serif;
  scroll-behavior: smooth; }
  html body #header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 96px;
    margin: 0 auto;
    padding: 30px 0 30px 50px;
    z-index: 2; }
    html body #header a {
      display: block;
      width: 206px;
      height: 36px;
      cursor: pointer; }
      html body #header a img {
        width: 100%; }
    @media screen and (max-width: 768px) {
      html body #header {
        height: 60px;
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 16px 0; } }

html body .footer {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 16px;
  background-color: #8e0126;
  color: white;
  z-index: 10;
  height: 235px; }
  html body .footer a {
    display: block;
    width: 206px;
    height: 36px;
    cursor: pointer; }
    html body .footer a img {
      width: 100%; }
  html body .footer p {
    margin: 0;
    display: inline-block; }
    html body .footer p small {
      display: inline-block;
      font-size: 0.875rem;
      font-weight: 400; }
      @media screen and (max-width: 768px) {
        html body .footer p small {
          font-size: 0.75rem; } }
