@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: 314px;
  height: 50px;
}
.button-frame .button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: white;
  font-family: "Zen Old Mincho";
  font-size: 18px;
  background-color: #C9B48C;
  background-image: url(../img/ic_arrow.svg);
  background-position: 83%;
  border-radius: 25px;
  text-decoration: unset;
}
.button-frame .button:hover {
  opacity: 0.7;
}
.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;
}

html * {
  margin: 0;
  padding: 0;
  text-decoration: unset;
  background-repeat: no-repeat;
  color: #464646;
  font-size: 14px;
  font-weight: 400;
}
html p, html a, html dt, html dd, html li {
  line-height: 1.8;
}

body {
  margin: 0;
  background-color: #F4F0EC;
  font-family: "Noto Sans JP";
}

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;
}

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

.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;
}
.pc-wrapper .side {
  display: flex;
  justify-content: center;
  padding-top: 146px;
}
.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: 76px;
  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: 0 auto;
  padding: 36px 70px 50px;
  background-color: #FCF9F6;
  border-radius: 20px;
}
.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: white;
  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%;
}

footer {
  width: 100%;
  min-height: 290px;
  /* aspect-ratio: 393/305; */
  padding: 74px 20px 25px;
  background-image: url(../img/bg_footer.webp);
  background-size: cover;
  box-sizing: border-box;
}
footer div {
  display: flex;
  flex-flow: column;
  align-items: center;
  justify-content: space-between;  
  gap: 16px;
  /* height: 100%; */
  min-height: 190px;
  text-align: center;
}
footer div p {
  color: white;
  font-family: "Zen Old Mincho";
}
footer div p:nth-child(2) {
  margin-top: 0;
  margin-bottom: auto;
}
footer div .copyright {
  font-size: 12px;
}

section#introduction {
  display: flex;
  flex-flow: column;
  gap: 32px;
  padding-top: 24px;
  padding-bottom: 62px;
}
section#introduction h2 {
  padding-right: var(--section-gutter);
  padding-left: var(--section-gutter);
}
section#introduction h2 > img {
  width: 100%;
}
section#introduction > img {
  display: block;
  width: 64%;
  min-width: 252px;
  margin: 0 auto;
}

section#recommend h2 {
  width: max-content;
  padding-bottom: 8px;
  font-family: "Zen Old Mincho";
  font-size: 20px;
  line-height: 1.8;
  background-image: url(../img/h_under_line.png);
  background-position-y: bottom;
  background-size: 100%;
}
section#recommend .problems {
  display: flex;
  flex-flow: column;
  gap: 8px;
  margin-top: 24px;
  margin-bottom: 40px;
  padding-left: 22px;
  padding-right: 22px;
}
section#recommend .problems img {
  width: 70%;
  min-width: 270px;
}
section#recommend .problems img:nth-child(even) {
  align-self: end;
}
section#recommend .problems img:nth-child(odd) {
  align-self: start;
}
section#recommend .problems + p {
  padding-bottom: 32px;
  font-family: "Zen Old Mincho";
  font-size: 20px;
  font-weight: 700;
  line-height: 1.8;
}
section#recommend .advice {
  width: 100%;
  margin-bottom: 64px;
}
section#recommend .market {
  position: relative;
  margin-bottom: 28px;
}
section#recommend .market div {
  display: flex;
  align-items: end;
  justify-content: space-between;
}
section#recommend .market div:nth-child(2) {
  align-items: start;
}
section#recommend .market img {
  object-fit: cover;
}
section#recommend .market img.img-1 {
  width: 58%;
  aspect-ratio: 222/177;
  margin-bottom: 64px;
  margin-left: -2%;
  border-radius: 8px;
}
section#recommend .market img.img-2 {
  width: 38%;
  aspect-ratio: 155/161;
  margin-right: -2%;
  border-radius: 8px;
}
section#recommend .market img.img-3 {
  width: 38%;
  margin-top: 18px;
}
section#recommend .market img.logo {
  width: 50%;
}
section#recommend .market p {
  position: absolute;
  bottom: 8px;
  left: 20px;
  font-family: "Zen Old Mincho";
  font-size: 20px;
  font-weight: 700;
  line-height: 1.6;
}

section#about {
  position: relative;
  padding-top: 40px;
}
section#about .about {
  position: relative;
  display: flex;
  flex-flow: column;
  justify-content: center;
  gap: 32px;
  margin-bottom: 40px;
  padding: 32px;
  background-color: #FCFAF8;
  border: solid 1px rgba(187, 168, 131, 0.3019607843);
  border-radius: 8px;
}
section#about .about img {
  position: absolute;
  top: -22px;
  left: 0;
  width: 87px;
}
section#about .about p {
  font-family: "Zen Old Mincho";
  font-size: 18px;
  font-weight: 700;
  line-height: 1.8;
}
section#about .about dl > div {
  display: flex;
  align-items: center;
  height: 41px;
}
section#about .about dl > div:not(:last-child) {
  border-bottom: solid 1px rgba(187, 168, 131, 0.3019607843);
}
section#about .about dl > div dt {
  flex: 0 0 100px;
  padding-left: 20px;
  font-size: 12px;
}
section#about .about dl > div dd {
  font-weight: 500;
}
section#about .button-frame {
  margin-bottom: 40px;
}

section#problem {
  background-color: #FCFAF8;
}
section#problem .top {
  position: relative;
  margin-bottom: 24px;
  padding-top: 66px;
}
section#problem .top img {
  position: absolute;
  bottom: 54px;
  right: 0;
  width: 205px;
}
section#problem .top p {
  font-family: "Zen Old Mincho";
  font-size: 16px;
  font-weight: 700;
  line-height: 1.8;
}
section#problem .top p span {
  font-size: 20px;
}
section#problem .top p span.pink {
  background-color: #EFE2E2;
}
section#problem .top p span.green {
  background-color: #DCE7DC;
}
section#problem .carousel {
  position: relative;
  margin-bottom: 40px;
  padding-bottom: 40px;
}
section#problem .carousel .slick-track {
  display: flex;
  align-items: stretch;
}
section#problem .carousel .slick-slide {
  height: auto !important;
}
section#problem .carousel .slick-prev,
section#problem .carousel .slick-next,
section#problem .carousel .slick-dots {
  position: absolute;
  bottom: 0;
}
section#problem .carousel .slick-prev,
section#problem .carousel .slick-next {
  width: 8px;
  height: 15px;
  font-size: 0;
  background: none;
  background-image: url(../img/carousel_arrow.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  border: none;
  cursor: pointer;
}
section#problem .carousel .slick-prev:hover,
section#problem .carousel .slick-next:hover {
  opacity: 0.7;
}
section#problem .carousel .slick-prev {
  left: calc(50% - 78px);
}
section#problem .carousel .slick-next {
  right: calc(50% - 78px);
  transform: rotate(180deg);
}
section#problem .carousel .slick-dots {
  list-style: none;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  width: max-content;
  margin: auto;
}
section#problem .carousel .slick-dots button {
  width: 6px;
  height: 6px;
  font-size: 0;
  background-color: #E9E2D5;
  border: none;
  border-radius: 3px;
  cursor: pointer;
}
section#problem .carousel .slick-dots button:hover {
  opacity: 0.7;
}
section#problem .carousel .slick-dots li.slick-active button {
  background-color: #C9B48C;
}
section#problem .carousel .item {
  display: flex;
  flex-flow: column;
  gap: 16px;
  width: 285px;
  margin: 0 8px;
  padding: 24px 16px;
  background-color: white;
  border: solid 1px rgba(187, 168, 131, 0.3019607843);
  border-radius: 8px 24px 8px 24px;
}
section#problem .carousel .item h5 {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 64px;
  font-family: "Zen Old Mincho";
  font-size: 20px;
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
}
section#problem .carousel .item dl {
  padding: 0 8px;
}
section#problem .carousel .item dl dt {
  margin-bottom: 8px;
}
section#problem .carousel .item dl dt img {
  width: 100%;
}
section#problem .carousel .item dl dd ul {
  height: 74px;
  padding-left: 20px;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.8;
}
section#problem .bottom {
  max-width: 320px;
  margin-bottom: 16px;
}
section#problem .bottom h3 {
  width: max-content;
  margin-bottom: 24px;
  padding-bottom: 8px;
  font-family: "Zen Old Mincho";
  font-size: 20px;
  line-height: 1.8;
  background-image: url(../img/h_under_line.png);
  background-position-y: bottom;
  background-size: 100%;
}

section#contents {
  position: relative;
  padding-top: 40px;
}
section#contents h2 {
  margin-bottom: 80px;
  color: #C9B48C;
  font-family: "Marcellus";
  font-size: 40px;
  font-weight: 400;
  letter-spacing: 2px;
}
section#contents .items {
  display: flex;
  flex-flow: column;
  gap: 70px;
  padding-bottom: 40px;
}
section#contents .items .item {
  position: relative;
  width: 100%;
}
section#contents .items .item::before {
  content: "";
  position: absolute;
  top: -46px;
  left: 0;
  right: 0;
  width: 101px;
  height: 104px;
  margin: auto;
  border-radius: 50%;
  z-index: 1;
}
section#contents .items .item::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100px;
  height: 3px;
  margin: auto;
  background-color: #FCF7F7;
  z-index: 3;
}
section#contents .items .item > div {
  z-index: 2;
  position: relative;
  background-color: #FCF7F7;
  padding: 32px 20px 20px;
  border: solid 2px #BF9B9B;
  border-radius: 8px;
}
section#contents .items .item > div .number {
  position: absolute;
  top: -23px;
  left: 0;
  right: 0;
  margin: auto;
}
section#contents .items .item > div h5 {
  margin-bottom: 24px;
  font-family: "Zen Old Mincho";
  font-size: 22px;
  font-weight: 700;
  line-height: 1.8;
  text-align: center;
}
section#contents .items .item > div .img {
  width: 100%;
  aspect-ratio: 2/1;
  object-fit: cover;
  border-radius: 8px;
}
section#contents .items .item > div > p {
  position: relative;
  margin: 16px auto;
  text-align: center;
}
section#contents .items .item > div > p span {
  position: relative;
  padding: 0 12px;
  z-index: 1;
  font-weight: 500;
}
section#contents .items .item > div > p::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  width: 100%;
  height: 1px;
}
section#contents .items .item > div > div {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.8;
}
section#contents .items .item > div ul {
  padding-left: 20px;
}
section#contents .items .item:nth-child(odd)::before, section#contents .items .item:nth-child(odd) > div {
  background-color: #FCF7F7;
  border: solid 2px #BF9B9B;
}
section#contents .items .item:nth-child(odd) > div > p span {
  background-color: #FCF7F7;
}
section#contents .items .item:nth-child(odd) > div > p::before {
  background-color: #BF9B9B;
}
section#contents .items .item:nth-child(even)::before, section#contents .items .item:nth-child(even) > div {
  background-color: #FCFAF8;
  border: solid 2px #C9B48C;
}
section#contents .items .item:nth-child(even) > div > p span {
  background-color: #FCFAF8;
}
section#contents .items .item:nth-child(even) > div > p::before {
  background-color: #C9B48C;
}
section#contents .items .item:nth-child(1) .dec {
  top: -114px;
  width: 77px;
}
section#contents .items .item:nth-child(5) .dec {
  top: -42px;
  right: 20px;
  width: 55px;
}

section#faq {
  position: relative;
  padding-top: 40px;
  padding-bottom: 80px;
  background-color: #FCFAF8;
}
section#faq h2 {
  margin-bottom: 40px;
  color: #C9B48C;
  font-family: "Marcellus";
  font-size: 40px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 2px;
}
section#faq > .dec {
  top: 42px;
  left: 20px;
  width: 82px;
}
section#faq .faq-list {
  display: flex;
  flex-flow: column;
  gap: 16px;
}
section#faq .faq-list .faq-collapse {
  background-color: white;
  border-radius: 8px;
  overflow: hidden;
}
section#faq .faq-list .faq-collapse .collapse-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 58px;
  padding: 0 16px;
  font-size: 14px;
  font-weight: 400;
  text-align: start;
  background-color: rgba(187, 168, 131, 0.3019607843);
  border: none;
  cursor: pointer;
}
section#faq .faq-list .faq-collapse .collapse-trigger:hover {
  opacity: 0.7;
}
section#faq .faq-list .faq-collapse .collapse-trigger img {
  transform: rotate(180deg);
}
section#faq .faq-list .faq-collapse .collapse-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
}
section#faq .faq-list .faq-collapse .collapse-inner {
  padding: 20px 12px;
}
section#faq .faq-list .faq-collapse.show .collapse-trigger img {
  transform: rotate(0deg);
}
section#faq .faq-list .faq-collapse.show .collapse-content {
  max-height: var(--content-height);
}

section#access {
  position: relative;
  padding-bottom: 87px;
  background-color: #FCFAF8;
}
section#access h2 {
  margin-bottom: 24px;
  color: #C9B48C;
  font-family: "Marcellus";
  font-size: 40px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 2px;
}
section#access > .dec {
  top: -16px;
  right: 10px;
  width: 98px;
}
section#access div {
  display: flex;
  flex-flow: column;
  gap: 24px;
  margin-bottom: 64px;
}
section#access div p:first-child {
  position: relative;
  text-align: center;
}
section#access div p:first-child::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  width: 100%;
  height: 1px;
  background-color: #BF9B9B;
}
section#access div p:first-child span {
  position: relative;
  padding: 0 12px;
  background-color: #FCFAF8;
  color: #BF9B9B;
  font-family: "Zen Old Mincho";
  font-size: 18px;
  font-weight: 700;
  z-index: 1;
}
section#access div iframe {
  width: 100%;
  aspect-ratio: 3/2;
}

@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;
}
