@import url("https://fonts.googleapis.com/css2?family=Marcellus&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Zen+Old+Mincho&display=swap");

.button-frame {
  position: relative;
  width: 200px;
  height: 40px;
}

.button-frame .button {
  font-family: Noto Sans JP;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 400;
  width: 100%;
  height: 100%;
  color: #B89679;
  font-size: 1.4rem;
  background-color: #3D3A3A;
  background-image: url(../img/ic_arrow.webp);
  background-position: 85%;
  border: 1px solid #C8B4A0;
  text-decoration: unset;
  background-size: 7px;
}

.button-frame .button:not(.submit):hover {
  opacity: 0.7 !important;
}

.button-frame .dec {
  bottom: -22px;
  left: -16px;
  width: 50px;
}

.slide-menu,
.overlay {
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  flex-flow: row;
  width: 100%;
}

.slide-menu {
  z-index: 995;
  transform: translateY(-100%);
  transition: transform 0.4s ease-out;
  overflow: hidden;
}

.slide-menu nav {
  container-type: inline-size;
  width: 100%;
  height: 83vh;
  max-height: 704px;
  background-image: url(../img/bg_slide_menu.webp);
  background-size: 100% 100%;
}

.slide-menu nav .content {
  display: flex;
  flex-flow: column;
  justify-content: space-between;
  height: -webkit-fill-available;
  padding: 64px 40px 50px;
}

.slide-menu nav .content .top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 0 0 auto;
  margin-bottom: 32px;
}

.slide-menu nav .content .top .close-button {
  cursor: pointer;
}

.slide-menu nav .content .top .close-button:hover {
  transform: scale(1.05);
}

.slide-menu nav ul {
  list-style: none;
  flex: 1 1 auto;
  padding-bottom: 32px;
  font-family: "Noto Serif JP";
  overflow-y: scroll;
}

.slide-menu nav ul li,
.slide-menu nav ul a {
  line-height: 1;
}

.slide-menu nav ul li:not(:last-child) {
  margin-bottom: 32px;
}

.slide-menu nav .button-frame {
  flex: 0 0 50px;
}

.slide-menu.is-open {
  transform: translateY(0);
}

.slide-menu::before,
.slide-menu::after {
  content: "";
  flex: 1 1 calc(100vw - 600px);
}

.overlay {
  height: 100%;
  z-index: 990;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.overlay div {
  container-type: inline-size;
  width: 100%;
  background-color: rgba(70, 70, 70, 0.8);
}

.overlay::before,
.overlay::after {
  content: "";
  flex: 1 1 calc(100vw - 600px);
}

@media (min-width: 768px) {

  .slide-menu nav,
  .overlay div {
    max-width: 480px;
  }

  .slide-menu nav {
    max-height: unset;
  }
}

:root {
  --section-gutter: 28px;
  --font-zen: 'Zen Kaku Gothic New';
  --font-serif: 'Noto Serif JP';
  --font-bodoni: 'Libre Bodoni';
}

html {
  font-size: 10px;
}

html * {
  margin: 0;
  padding: 0;
  text-decoration: unset;
  background-repeat: no-repeat;
  color: #464646;
  font-size: 1.4rem;
  font-weight: 400;
}

html p,
html a,
html dt,
html dd,
html li {
  line-height: 1.8;
}

body {
  margin: 0;
  background-size: cover;
  font-family: "Zen Kaku Gothic New", "Noto Sans JP";
}

.input_err {
  display: none;
  color: #E696AA;
  font-size: 12px;
  line-height: 1.6;
  margin: 0 0 10px 0;
}

section {
  font-size: 0;
}

nav a:not(.button):hover {
  opacity: 0.7;
}

.gutter-x {
  padding-right: 20px;
  padding-left: 20px;
}

.mx-auto {
  margin-right: auto;
  margin-left: auto;
}

.text-center {
  text-align: center;
}

.dec {
  position: absolute;
  z-index: 4;
}

.section-bottom-shape {
  width: 100%;
  object-fit: cover;
}

.section-bottom-shape.bg-white {
  background-color: white;
}

.section-bottom-shape.bg-gold {
  background-color: #FCFAF8;
}

.pc-wrapper {
  display: flex;
  flex-flow: row;
  height: 100vh;
  background-color: #5F5F5F;
}

.pc-wrapper .side {
  display: flex;
  justify-content: center;
  padding-top: 90px;
}

.pc-wrapper .side>div {
  display: none;
  padding: 10px var(--section-gutter);
}

.pc-wrapper .side.side-left img.logo {
  display: block;
  margin-bottom: 48px;
}

.pc-wrapper .side.side-left .anchor-list {
  list-style: none;
  margin-bottom: 66px;
  padding: 0;
}

.pc-wrapper .side.side-left .anchor-list li {
  margin-bottom: 20px;
}

.pc-wrapper .side.side-left .anchor-list li a {
  color: #454545;
  font-family: "Noto Serif JP";
  font-size: 16px;
}

.pc-wrapper .side.side-right>div {
  width: -webkit-fill-available;
  max-width: calc(300px + var(--section-gutter) * 2);
}

.pc-wrapper .side.side-right .qr-code {
  display: flex;
  flex-flow: column;
  justify-content: center;
  gap: 38px;
  align-items: center;
  width: max-content;
  margin: 20% auto 0;
  padding: 36px 70px 50px;
  background-color: #FCF9F6;
  border-radius: 20px;
}

.qr-code {
  background-color: #FFFFFF !important;

  p {
    color: #3D3A3A !important;
    font-size: 1.6rem;
  }
}

.pc-wrapper .side.side-right .qr-code p {
  margin: 0;
  font-family: "Noto Serif JP";
  font-size: 16px;
  line-height: 1;
}

.pc-wrapper .side.side-right .qr-code img {
  width: 160px;
  aspect-ratio: 1/1;
}

.sp-wrapper {
  container-type: inline-size;
  width: 100%;
  background-color: #F8F8F7;
  scroll-behavior: smooth;
  scrollbar-width: none;
  overflow-y: auto;
  overflow-x: hidden;
}

.sp-wrapper .sp-container {
  max-width: 600px;
}

header {
  position: relative;
}

header>div {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: end;
  width: auto;
  padding: 24px 20px;
  z-index: 100;
}

header>div .hamburger-button {
  display: block;
  cursor: pointer;
}

header>div .hamburger-button:hover {
  transform: scale(1.05);
}

header>div .hamburger-button img {
  width: 44px;
}

header>img {
  width: 100%;
}

a {
  cursor: pointer;
}

.side-left {
  h3 {
    font-family: Noto Serif JP;
    font-weight: 500;
    font-size: 2rem;
    color: #B89679;
  }

  p {
    font-family: Noto Serif JP;
    color: #C8B4A0;
    font-size: 2rem;
    font-weight: 500;
    margin-bottom: 60px;
  }

  .anchor-list {
    li {
      margin-bottom: 11px !important;

      a {
        color: #C8B4A0 !important;
      }
    }
  }
  .anchor-list-btn{
    margin: 0 !important;
    width: 100%;
  }
}



/* モーダル */

.modal-header {
  border-bottom: none;
  justify-content: flex-end;

  .recommendModal-close {
    background-image: url(../img/modal-close.webp);
    background-repeat: no-repeat;
    background-size: contain;
    width: 24px;
    height: 24px;
    border: none;
    margin: 12px;
    background-color: unset;
  }
}

*,
*::before,
*::after {
  box-sizing: content-box;
}

section#introduction {
  padding: 0 var(--section-gutter) 20px;

  h2 {
    text-align: center;
    padding: 16px 0;
    margin-top: 43px;
    color: #2A2A2A;
    font-size: 1.4rem;
    font-family: 'Noto Serif JP';
    line-height: 1.7;
  }


  .event-container {
    padding: 0px 12px 40px;
    margin-top: 40px;
    margin-bottom: 40px;
    background-image: url(../img/event_bg_img.webp);
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;

    h3 {
      text-align: center;
      padding: 27px 0 20px;
      font-size: 1.6rem;
      font-weight: 600;
      line-height: 2;
      font-family: 'Noto Serif JP';
      color: #A58D74;
    }

    table {
      table-layout: fixed;
      border-collapse: collapse;
      font-size: 13.5px;
      line-height: 1.5;
      margin: 0 auto;
      width: 90%;

      td {
        padding: 15px 0;
        border-bottom: 0.5px solid #C8B4A0;
        border-top: 0.5px solid #C8B4A0;
      }

      .label {
        padding-left: 5px;
        font-weight: 500;
        font-size: 1.1rem;
        color: #2A2A2ACC;
      }

      .value {
        width: 70%;
        font-weight: 400;
        font-size: 1.4rem;
        line-height: 1;
        font-family: var(--font-zen);
        color: #2A2A2ACC;

        span {
          padding-top: 8px;
          color: #2A2A2ACC;
          display: block;
          color: #2A2A2ACC;
        }
      }
    }
  }
}

/* section title */
section#about,
section#voice,
section#flow {
  .section-title {
    background-image: url(../img/section_title_gold.webp);
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    width: 100%;
    height: 60px;
    position: relative;

    img {
      position: absolute;
      top: -15px;
      width: 106px;
    }

    h2 {
      position: absolute;
      top: 33%;
      left: 0;
      width: 100%;

      transform: translate(-50%, -50%);
      font-family: var(--font-serif);
      font-weight: 700;
      font-size: 1.6rem;
      text-align: center;
      letter-spacing: 0.1em;
    }
  }
}

section#contents,
section#presents,
section#gallery,
section#faq,
section#reservation {

  .section-title {
    text-align: center;

    h2 {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      width: 100%;
      padding: 16px 0 0;
      margin-top: 60px;

      color: #2A2A2A;
      font-size: 2.8rem;
      font-family: var(--font-bodoni);
      line-height: 1.7;
      white-space: nowrap;

      &::before,
      &::after {
        content: "";
        display: block;
        width: 100%;

        height: 5px;
        flex: 1;
        background-image: url(../img/section_title_black.webp);
        background-repeat: no-repeat;
        background-size: cover;
        flex-shrink: 0;
        height: 10px;
      }
    }

    span {
      display: block;
      margin-top: -8px;
      font-size: 1.4rem;
      color: #2A2A2A;
      font-family: var(--font-zen);
    }
  }
}

section#about {
  padding: 7rem var(--section-gutter);
  background-color: #FFFFFF;

  .section-title {
    margin-bottom: 45px;
  }

  .about-content {
    .flex {
      padding-bottom: 25px;
      display: flex;
      gap: 24px;
      margin-top: 26px;

      .about-img {
        flex: 0 0 calc(140 / 343 * 100%);
        aspect-ratio: 1 / 1;
        min-width: 0;

        img {
          width: 100%;
          height: 100%;
          object-fit: cover;
          display: block;
        }
      }

      .collapse-trigger {
        flex: 1;
        position: relative;
        display: block;
        min-width: 0;

        &::before,
        &::after {
          content: "";
          position: absolute;
          height: 0.5px;
          left: 0;
          background-color: #A58D74;
        }

        &::before {
          top: 26px;
          width: 100%;
        }

        &::after {
          bottom: 0;
          width: calc(100% - 52%);
        }

        img {
          position: absolute;
          width: 50px;
          height: 50px;
          display: block;
        }

        p {
          position: absolute;
          top: 40%;
          left: 10px;
          font-family: var(--font-serif);
          letter-spacing: 0.03em;
          font-size: 1.4rem;
        }
      }
    }
  }


  .detail-text {
    background-color: #F8F8F7;

    p {
      padding: 20px 17px;
      font-size: 1.2rem;
      line-height: 1.7;
      font-weight: 400;
    }
  }
}

.more-button {
  position: absolute;
  bottom: -10px;
  right: 0;
  width: 70px;
  height: 22px;
  padding: 0 10px;
  font-family: var(--font-bodoni);
  background-color: #2A2A2A;
  text-align: left;
  color: #fff;
  z-index: 100;
  border: none;
  outline: none;

  &::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 5px;
    width: 10px;
    height: 5px;
    transform: translateY(-50%) rotate(180deg);
    background-image: url(../img/open.webp);
    background-repeat: no-repeat;
    background-size: contain;
    transition: transform 0.3s ease;
  }
}

.collapse-trigger.collapsed .more-button::after {
  transform: translateY(-50%) rotate(0);
}

.collapse-trigger .more-button span::before {
  content: attr(data-open);
  color: #FFFFFF;
}

.collapse-trigger.collapsed .more-button span::before {
  content: attr(data-close);
  color: #FFFFFF;
}

section#contents {
  padding: 0 var(--section-gutter) 50px;

  .section-title {
    padding-bottom: 10px;
  }

  .contents {
    margin-top: 25px;
    text-align: center;

    a {
      position: relative;
      display: block;
      margin: 30px 0;
      width: calc(100% - 8px);
      margin-left: 4px;
      margin-top: 4px;
      box-sizing: border-box;
      z-index: 1;

      &:hover {
        opacity: 0.8;
      }
    }

    a::before {
      content: "";
      position: absolute;
      top: -2px;
      left: -2px;
      width: 100%;
      height: 100%;
      border: 0.5px solid #2A2A2A;
      pointer-events: none;
      z-index: 3;
    }

    .wrapper {
      position: relative;
      width: 100%;
      aspect-ratio: 363 / 162;
      overflow: visible;
    }

    img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transform: translate(2px, 2px);
    }

    p {
      font-family: var(--font-serif);
      font-weight: 600;
      font-size: 1.4rem;
      line-height: 1.7;
      color: #A58D74;
      padding: 0 0 15px;
    }

    .contents-custom-p {
      width: 102%;
    }

    .detail-text {
      background-color: #FFFFFF;

      p {
        font-size: 1.2rem;
        color: #2A2A2A;
        font-family: var(--font-zen);
        font-weight: 400;
        text-align: left;
        padding: 15px;
      }
    }
  }

  .flex {
    display: flex;
    gap: 0 20px;
    flex-wrap: wrap;

    >* {
      flex: 0 0 calc((100% - 20px) / 2);
    }

    .contents {
      .wrapper {
        aspect-ratio: 1/1;
      }
    }
  }

  .grooms {
    position: relative;
    margin: 55px 0 20px;
    border-top: 2px solid #A58D74;
    border-bottom: 2px solid #A58D74;
    padding: 20px;
    background-color: #FFFFFF;

    &::before,
    &::after {
      content: "";
      position: absolute;
      left: 0;
      width: 100%;
      height: 0.5px;
      background-color: #A58D74;
    }

    &::before {
      top: -5px;
    }

    &::after {
      top: auto;
      bottom: -5px;
    }

    h3 {
      font-family: var(--font-serif);
      font-weight: 500;
      font-size: 1.4rem;
      margin: 4px 0 19px;
      text-align: center;
    }

    ul {
      padding-left: 20px;

      li {
        margin-top: 13px;
        list-style: url(../img/check.svg);
        font-size: 1.2rem;
        color: #A58D74;
      }
    }
  }

}

section#recommend {
  padding: 0 0 50px;
  background-image: url(../img/recommend_bg.webp);
  margin-left: calc(-1 * var(--section-gutter));
  margin-right: calc(-1 * var(--section-gutter));
  background-size: 100% 100%;
  top: -50px;
  padding: 50px calc(var(--section-gutter));
  text-align: center;

  h2 {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    font-size: 1.6rem;
    margin-bottom: 25px;
    text-align: center;
    gap: 12px;
    font-family: var(--font-serif);
    color: #2A2A2A;

    &::after,
    &::before {
      content: "";
      width: 23px;
      height: 17px;
      background-size: contain;
      background-repeat: no-repeat;
      background-position: center;
      display: block;
    }

    &::after {
      background-image: url(../img/recommend_right.webp);
    }

    &::before {
      background-image: url(../img/recommend_left.webp);
    }
  }

  .recommend-content {
    background-color: #ffffff;
    margin: 10px 9px;
    width: 100%;
    display: flex;
    box-shadow: 1px 1px 3.1px 1px #0000001A;
    border-radius: 15px 30px 30px 0;
    justify-content: center;

    p {
      text-align: left;
      font-size: 1.1rem;
      padding: 10px 17px;
      color: #A58D74;

      strong {
        color: #A58D74;
        font-weight: 500;
      }
    }
  }

  ul {
    padding: 0 var(--section-gutter);

    li {
      display: flex;
      align-items: center;
    }

    li:nth-child(odd)::before {
      background-image: url(../img/recommend_icon.webp);
      content: '';
      width: 33px;
      height: 33px;
      background-size: contain;
      background-repeat: no-repeat;
    }

    li:nth-child(even)::after {
      background-image: url(../img/recommend_icon.webp);
      content: '';
      width: 33px;
      height: 33px;
      background-size: contain;
      background-repeat: no-repeat;
    }


    li:nth-child(even) {
      .recommend-content {
        border-radius: 30px 15px 0 30px;
      }
    }
  }
}

section#flow {
  padding: 70px var(--section-gutter) 0;
  background-color: #FFFFFF;

  .flow {
    display: flex;
    margin-top: 40px;
    gap: 10px;
    align-items: stretch;

    .time {
      display: inline-flex;
      align-items: center;
      justify-content: flex-start;
      gap: 4px;
      padding: 4px;
      text-align: left;
      white-space: nowrap;
      width: fit-content;
      margin: 0 auto;

      img {
        width: 30px;
        height: auto;
      }

      p {
        font-family: var(--font-serif);
        font-weight: 600;
        font-size: 1.4rem;
        color: #464646;
      }

      span {
        font-family: var(--font-serif);
        font-weight: 600;
        font-size: 1.4rem;
        color: #A58D74;
      }
    }

    .me {
      width: 58%;
      text-align: center;
      display: flex;
      flex-direction: column;

      .me-flow {
        background-color: #F8F8F7;
        position: relative;
        padding: 25px 15px;
        flex: 1;
        display: flex;
        flex-direction: column;

        &::before {
          content: "";
          position: absolute;
          inset: 6px;
          border: 0.5px solid #A58D74;
          pointer-events: none;
        }

        h3 {
          font-family: var(--font-serif);
          font-weight: 700;
          font-size: 1.6rem;
          padding: 10px 0 20px;
        }

        /* arrowのスタイル追加 */
        >img.arrow {
          flex-shrink: 0;
          width: 12px;
          height: 5px;
          margin: 8px auto;
        }

        div {
          width: 100%;
          margin-top: 5px 0;
          background-color: #FFFFFF;
          border: 0.5px solid #A58D74;
          flex: 1;
          display: flex;
          align-items: center;
          justify-content: center;

          img {
            width: 100%;
            height: auto;
            object-fit: fill;
          }
        }

        p {
          padding: 5px 0;
          width: 100%;
          background-color: #C8B4A0;
          color: #FFFFFF;
          font-weight: 500;
          font-family: var(--font-zen);
          margin: 0;
        }
      }

      .time {
        background-color: #F8F8F7;
      }
    }

    .other {
      flex: 1;
      text-align: center;
      display: flex;
      flex-direction: column;

      .other-flow {
        padding: 0;
        background-color: #F8F8F7;
        flex: 1;
        display: flex;
        flex-direction: column;

        p {
          font-family: var(--font-serif);
          font-size: 1.4rem;
          font-weight: 600;
          padding: 10px;
          color: #46464699;
        }

        ul {
          list-style: none;
          padding: 0 10px;
          flex: 1;
          display: flex;
          flex-direction: column;
          justify-content: space-evenly;

          li {
            width: 100%;
            padding: 3px 0;
            background-color: #FFFFFF;
            color: #46464699;
            font-weight: 500;
            font-family: var(--font-zen);
            margin: 1px 0;
          }

          /* arrowのスタイル追加 */
          >img.arrow {
            flex-shrink: 0;
            width: 12px;
            height: 5px;
            margin: 3px auto;
          }
        }
      }
    }
  }


  .flow-time-arrow {
    width: 26px;
    height: auto;
    margin: 16px 0;
  }

  .end-text {
    background: linear-gradient(179.34deg, rgb(255 255 255) -1.55%, rgb(238 238 238) 91.42%);
    margin-left: calc(-1 * var(--section-gutter));
    padding-right: calc(2 * var(--section-gutter));
    width: 100%;
    text-align: center;
    padding-bottom: 50px;
    font-family: var(--font-serif);
    font-size: 1.4rem;
    margin-top: 60px;

    p {
      margin-left: calc(2 * var(--section-gutter));
    }
  }

}

section#presents {
  background-image: url(../img/presents_bg.webp);
  background-size: 100% 100%;
  text-align: center;
  padding: 60px 0;

  >div {
    padding: 0 var(--section-gutter);

    .section-title {
      h2 {
        margin-top: -5px;
      }
    }

    .presents {
      margin-top: 40px;
      padding: 0 10px;

      img {
        width: 100%;
        height: auto;
        display: block;
        object-fit: cover;
      }
    }
  }
}

section#gallery {
  padding: 60px var(--section-gutter) 50px;
  background-color: #FFFFFF;

  .section-title {
    padding: 0 0 30px;
  }

  h2 {
    margin-top: 0px !important;
    margin-bottom: -7px;
  }

  .gallery {
    display: flex;
    flex-flow: wrap;
    gap: 23px;
    margin-bottom: 30px;

    a {
      width: calc((100% - 46px) / 3);
      height: auto;

      &:hover {
        opacity: 0.8;
        cursor: pointer;
      }

      img {
        width: 100%;
        aspect-ratio: 1 / 1;
        object-fit: cover;
      }

      img.position-left-top {
        object-position: left top;
      }

      img.position-right-bottom {
        object-position: right bottom;
      }
    }
  }
}

section#voice {
  padding: 70px var(--section-gutter) 0;

  ul {
    list-style: none;

    li {
      position: relative;
      background-color: #FFFFFF;
      margin: 40px 0;

      &:nth-child(odd) {
        margin-right: calc(-1 * var(--section-gutter));
      }

      &:nth-child(even) {
        margin-left: calc(-1 * var(--section-gutter));
      }

      &::before {
        content: "";
        position: absolute;
        pointer-events: none;
      }

      &:nth-child(odd)::before {
        top: -4px;
        left: -4px;
        right: 0;
        bottom: 4px;
        border-top: 0.5px solid #A58D74;
        border-left: 0.5px solid #A58D74;
        border-bottom: 0.5px solid #A58D74;
      }

      &:nth-child(even)::before {
        top: -4px;
        right: -4px;
        left: 0;
        bottom: 4px;
        border-top: 0.5px solid #A58D74;
        border-right: 0.5px solid #A58D74;
        border-bottom: 0.5px solid #A58D74;
      }

      p {
        font-family: var(--font-zen);
        font-size: 1.4rem;
        line-height: 1.7;
        letter-spacing: 0;
      }

      &:nth-child(odd) p {
        padding: 25px var(--section-gutter) 26px calc(72px + 20px);
      }

      &:nth-child(even) p {
        padding: 25px calc(72px + 20px) 26px var(--section-gutter);
      }

      img {
        position: absolute;
        width: 72px;
        height: auto;
        top: 50%;
        transform: translateY(-50%);
      }

      &:nth-child(odd) img {
        left: -10px;
      }

      &:nth-child(even) img {
        right: -10px;
      }
    }
  }
}

section#faq {
  padding: 0 var(--section-gutter);
  margin-bottom: 20px;

  .faq-list {

    .accordion-item {
      margin-top: 24px;

      a {
        font-family: var(--font-zen);
        font-size: 1.4rem;
        font-weight: 500;
        color: #464646;
        display: block;
        padding: 15px;
        border-bottom: 0.5px solid #464646;
        background-color: #AEAEAE1A;

        &:hover {
          opacity: 0.8;
          cursor: pointer;
        }

        &::after {
          content: "";
          float: right;
          width: 24px;
          height: 24px;
          background-image: url(../img/faq_arrow.webp);
          background-size: contain;
          background-repeat: no-repeat;
          transition: transform 0.3s ease;
          transform: rotate(180deg);
        }
      }

      a.collapsed::after {
        transform: rotate(0deg);
      }

      .answer {
        font-family: var(--font-zen);
        font-size: 1.4rem;
        line-height: 1.8;
        padding: 20px 15px;
        color: #464646;
        background-color: #FFFFFF;
      }
    }
  }
}

section#access {
  padding: 60px var(--section-gutter) 40px;
  margin-top: 40px;
  margin-bottom: 40px;

  >div {
    background-image: url(../img/event_bg_img.webp);
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;

    >div {
      padding: 20px;

      h2 {
        text-align: center;
        font-size: 2.8rem;
        font-weight: 700;
        line-height: 2;
        font-family: var(--font-bodoni);
        color: #464646;
      }

      h3 {
        display: flex;
        gap: 6px;
        align-items: center;

        &::before {
          background-image: url(../img/map_icon.webp);
          content: '';
          width: 15px;
          height: 17px;
          background-size: contain;
          background-repeat: no-repeat;
        }
      }

      p {
        font-size: 1.3rem;
      }

      .map {
        margin: 20px 0 10px;
        width: 100%;
        aspect-ratio: 7 / 5;
        overflow: hidden;
        border: 0.5px solid #A58D74;

        iframe {
          width: 100%;
          height: 100%;
          border: none;
        }
      }
    }
  }
}

section#getback {
  padding: 31px var(--section-gutter) 43px;
  background-image: url(../img/getback_back.webp);
  background-size: cover;

  &>div {
    position: relative;

    h3 {
      color: #A58D74;
      font-family: Noto Sans JP;
      font-size: 2.2rem;
      line-height: 38px;
      padding: 10% 0 30px;
    }

    img {
      width: calc(100% + var(--section-gutter) * 2.1);
      position: absolute;
      right: -32px;
      top: 0px;
    }
  }

  .getback-wrapper {
    position: relative;
    z-index: 1;
    padding: 17px 0 0;
    text-align: center;

    span {
      color: #A58D74;
      font-size: 1.2rem;
    }

    div {
      background-color: #ffffff;
      border: 1px solid #C8B4A0;
      border-radius: 22px;
      height: 35px;
      display: flex;
      align-items: center;
      padding-right: 92px;
      padding-left: 27px;
      margin: 10px 0;
      position: relative;
      justify-content: center;

      p {
        color: #A58D74;
        font-size: 1.6rem;
        font-weight: 500;
      }

      img {
        object-fit: contain;
        height: 32px;
        display: block;
        width: auto;
        position: absolute;
        right: 2px;
        top: 1px;
      }
    }
  }
}



section#reservation {
  padding: 50px var(--section-gutter) 75px;
  background-color: #FFFFFF;

  >p {
    color: #464646;
    text-align: center;
    text-align: center;
    display: block;
    margin-top: 110px;
  }

  .reservation_restart {
    font-family: Noto Serif JP;
    color: #2A2A2A;
    border: 1px solid #C8B4A0;
    margin-top: 50px;
    padding: 10px 0;
    font-size: 1.6rem;
  }

  >img {
    width: 35px;
    margin: 100px auto;
    display: block;
  }

  form {
    margin-top: 20px;

    dl {
      margin: 34px 0 63px;

      dt {
        margin: 16px 0 3px;
        font-size: 1.5rem;
      }

      dd {

        input {
          width: 100%;
          height: 40px !important;
          height: 45px;
          padding-left: 8px;
          background-color: #F8F8F7;
          border: 1px solid #D9D9D9;
        }

        .checkbox-group {
          label {
            display: flex;
            align-items: center;
            gap: 12px;
            font-size: 1.4rem;
            height: 32px;
            font-weight: 500;
            color: #46464666;

            &:has(input:checked) {
              color: #464646;
            }

            input[type="checkbox"] {
              width: 13px;
              background-color: unset;
              appearance: none;
              background-image: url(../img/not_checked_icon.webp);
              background-size: contain;
              background-repeat: no-repeat;
              background-position: center;
              vertical-align: middle;
              cursor: pointer;
              border: none;
              outline: none;

              &:checked {
                background-image: url(../img/checked_icon.webp);
              }
            }
          }
        }

        p:has(+ #email) {
          color: #E696AA;
          font-size: 1.2rem;
        }
      }

      .note {
        font-size: 1.1rem;
        margin-top: -6px;
        display: block;
        margin-bottom: 8px;
      }

      .description {
        color: #A63F3F;

        &:first-child {
          margin-top: 8px;
        }

        &:last-of-type {
          margin-bottom: 8px;
        }
      }
    }

    label {
      width: 100%;

      select {
        width: calc(100% - 20px);
        border: none;
        height: 45px;
        border-radius: 25px;
        padding-left: 20px;
        outline: none;
        appearance: none;

        background-image: url(../img/reservation_arrow.webp);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: right 21px center;
        background-size: 12px auto;
        background-color: #F8F8F7;
        border: 1px solid #D9D9D9;
      }
    }

    option {
      &:nth-child(1) {
        color: #00000099;

      }
    }

    .button-frame .button.submit:not(.btn-on) {
      opacity: 0.5;
      pointer-events: none;
    }

    .button-frame .button.submit.btn-on:hover {
      opacity: 0.7;
      cursor: pointer;
    }
  }
}

footer {
  text-align: center;
  padding: 12px 0;
  font-size: 1.2rem;
  background-color: #A58D74;

  p {
    color: #FFFFFF;
    font-family: var(--font-serif);
  }
}

.hover-anim {
  &:hover {
    opacity: 0.8;
    cursor: pointer;
  }
}

@media (min-width: 600px) {
  :root {
    --section-gutter: 32px;
  }

  .pc-wrapper .side {
    position: relative;
    flex: 1 1 calc(100vw - 600px);
    overflow: hidden;
  }
}

@media (min-width: 768px) {
  .sp-wrapper {
    max-width: 480px;
  }
}

@media (min-width: 1200px) {
  .hamburger-button {
    display: none !important;
  }

  .side>div {
    display: block !important;
  }
}

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

/* アニメーションの定義 */
@keyframes fadeInFromBottom {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.anim {
  opacity: 0;
}

.anim.is-animated {
  animation: fadeInFromBottom 0.8s ease-out forwards;
}