@charset "UTF-8";
html {
  margin: 0 !important;
  padding: 0;
  overflow-x: hidden;
}
html.scroll-prevent {
  position: fixed;
  z-index: -1;
  width: 100%;
  height: 100%;
}

body {
  background-color: #F3EFEB;
  color: #222;
  font-family: "Noto Serif JP", serif;
  font-size: 14px;
  font-weight: 500;
  line-height: normal;
  font-style: normal;
  position: relative;
  overflow-x: hidden;
}

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

.inner {
  padding-right: 20px;
  padding-left: 20px;
  margin: auto;
}
a:hover {
  opacity: 0.7;
  cursor: pointer;
}

@media (min-width: 1100px) {
  .brsp {
    display: none;
  }
}

.brpc {
  display: none;
}
@media (min-width: 768px) {
  .brpc {
    display: block;
  }
}

.heading-en {
  color: #222;
  font-family: "Amatic SC", sans-serif;
  font-size: 40px;
  letter-spacing: 4px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .heading-en {
    font-size: 52px;
    letter-spacing: 10.4px;
  }
}
.heading-ja {
  color: #222;
  font-family: "Noto Serif JP", serif;
  font-size: 12px;
  line-height: normal;
  font-weight: 700;
}
@media (min-width: 768px) {
  .heading-ja {
    font-size: 14px;
  }
}

.page-head {
  position: relative;
  width: 100%;
  height: 120px;
}
@media (min-width: 768px) {
  .page-head {
    height: 320px;
  }
}
.page-head::before, .page-head::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 10;
}
.page-head::before {
  border: 2px solid #FFF;
  height: 108px;
  width: 96.8%;
}
@media (min-width: 768px) {
  .page-head::before {
    height: 300px;
    width: 98.4%;
  }
}
.page-head::after {
  border: 1px solid #FFF;
  height: 98px;
  width: 94.1%;
}
@media (min-width: 768px) {
  .page-head::after {
    height: 288px;
    width: 97.5%;
  }
}
.page-head img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: 1;
}
.page-head__heading {
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 10;
}
.page-head__heading-en {
  color: #FFF;
  font-size: 32px;
  letter-spacing: 6.4px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .page-head__heading-en {
    font-size: 72px;
    letter-spacing: 14.4px;
  }
}
.page-head__heading-ja {
  color: #FFF;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.96px;
}
@media (min-width: 768px) {
  .page-head__heading-ja {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 1.28px;
  }
}
.page-head .mask {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 5;
}

.button a {
  display: inline-block;
  padding: 24px 89px;
  color: #FFFFFF;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  background-color: #222222;
  position: relative;
  z-index: 3;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
@media (min-width: 768px) {
  .button a {
    padding: 25px 84px;
  }
}
.button a:hover {
  -webkit-transform: translate(6px, 6px);
          transform: translate(6px, 6px);
  opacity: 1;
}
.button a:hover::after {
  -webkit-transform: translate(-6px, -6px);
          transform: translate(-6px, -6px);
}
.button a::after {
  content: "";
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  border-bottom: 1px solid black;
  border-right: 1px solid black;
  position: absolute;
  top: 6px;
  right: -6px;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.drawer__button {
  cursor: pointer;
  width: 60px;
  height: 60px;
  background-color: #382620;
  border-radius: 60px;
  z-index: 200;
  position: fixed;
  top: 10px;
  right: 10px;
  right: 3%;
}
@media (min-width: 768px) {
  .drawer__button {
    top: 20px;
    right: 2%;
  }
}
.drawer__button_top {
  top: 10px;
  right: 10px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  opacity: 1;
  visibility: visible;
}
@media (min-width: 1100px) {
  .drawer__button_top {
    opacity: 0;
    visibility: hidden;
  }
}
@media (min-width: 1100px) {
  .drawer__button_top.is-show {
    opacity: 1;
    visibility: visible;
  }
}
.drawer__button_top.is-checked.drawer__button_top {
  opacity: 1;
  visibility: visible;
}
.drawer__button span {
  display: block;
  width: 27px;
  height: 2.25px;
  z-index: 20;
  background-color: #fff;
  border-radius: 3px;
  position: absolute;
  top: 22px;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.drawer__button span:nth-child(2) {
  top: 30px;
}
.drawer__button span:nth-child(3) {
  top: 38px;
}
.drawer__button.is-checked {
  background: #FFF;
  z-index: 9999;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.drawer__button.is-checked span {
  background-color: #382620;
}
.drawer__button.is-checked span:nth-child(1) {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  top: 30px;
  left: 15px;
}
.drawer__button.is-checked span:nth-child(2) {
  display: none;
}
.drawer__button.is-checked span:nth-child(3) {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  top: 30px;
  left: 15px;
}

.drawer-content {
  width: 375px;
  height: 100vh;
  background: #382620;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 999;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: -webkit-transform 0.3s ease-in-out;
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
}
@media (min-width: 768px) {
  .drawer-content {
    bottom: 0;
  }
}
.drawer-content__head {
  margin-bottom: 56px;
  padding-top: 10px;
  padding-left: 15px;
}
.drawer-content__image {
  width: 128px;
}
.drawer-content__list {
  padding-left: 40px;
  margin-bottom: 52px;
}
.drawer-content__link {
  color: #FFF;
  font-family: "Patua One", serif;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.drawer-content__link:not(:last-child) {
  margin-bottom: 32px;
}
.drawer-content__link-en {
  font-size: 24px;
  font-weight: 400;
  letter-spacing: 2.88px;
  padding-right: 11px;
}
.drawer-content__link-ja {
  font-size: 10px;
  font-weight: 500;
  padding-left: 24px;
  position: relative;
}
.drawer-content__link-ja::before {
  content: "／";
  position: absolute;
  top: 0;
  left: 0;
}
.drawer-content__background-cover.is-active {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.7);
  width: 100%;
  height: 100%;
  z-index: 998;
}
.drawer-content.is-active {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}
.drawer-content .menu-item {
  color: #FFF;
  font-family: "Patua One", serif;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.drawer-content .menu-item:not(:last-child) {
  margin-bottom: 32px;
}
.drawer-content .menu-item a {
  font-size: 24px;
  font-weight: 400;
  letter-spacing: 2.88px;
}
.drawer-content .menu-item a span {
  font-size: 10px;
  font-weight: 500;
  padding-left: 24px;
  position: relative;
  padding-left: 33px;
  vertical-align: middle;
}
.drawer-content .menu-item a span::before {
  content: "／";
  position: absolute;
  top: 0;
  left: 11px;
}
.drawer-content .menu-item .sns {
  display: block;
}

.card {
  max-width: 100%;
}
.card__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
}
.card__link:hover .card__image img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.card__image {
  position: relative;
  margin-bottom: 10px;
  overflow: hidden;
}
@media (min-width: 768px) {
  .card__image {
    margin-bottom: 16px;
  }
}
.card__image img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: auto;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.card__category {
  position: absolute;
  top: 19px;
  left: -7px;
  z-index: 100;
}
@media (min-width: 768px) {
  .card__category {
    top: 20px;
    left: -8px;
  }
}
.card__category span {
  color: #FFFFFF;
  background-color: #222222;
  padding: 2px 12px 4px 14px;
  font-family: "Noto Serif JP", serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  position: relative;
  width: 100%;
}
@media (min-width: 768px) {
  .card__category span {
    font-size: 16px;
  }
}
.card__category span::before {
  content: "";
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  border-right: 0;
  border-left: 8px solid transparent;
  border-top: 4px solid #AAA;
}
.card__category span::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: -8px;
  border-right: 8px solid transparent;
  border-top: 11.9px solid #222;
  border-bottom: 12px solid #222;
}
.card__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  grid-column-gap: 19px;
  grid-row-gap: 19px;
}
.card__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #222222;
  font-family: "Noto Serif JP", serif;
  text-align: left;
}
.card__title {
  font-size: 14px;
  font-weight: 700;
  line-height: 24px;
}
@media (min-width: 768px) {
  .card__title {
    font-size: 20px;
    line-height: 32px;
  }
}
.card__text {
  font-size: 12px;
  font-weight: 400;
  line-height: 18px;
}
@media (min-width: 768px) {
  .card__text {
    font-size: 14px;
    line-height: 24px;
  }
}
.card__time {
  font-size: 12px;
  font-weight: 500;
}
@media (min-width: 768px) {
  .card__time {
    font-size: 14px;
  }
}

.sns {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  text-align: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 20px;
}
.sns__item {
  width: 32px;
  height: 32px;
}
@media (min-width: 768px) {
  .sns__item {
    width: 24px;
    height: 24px;
  }
}
.sns__item_drawer {
  width: 40px;
  height: 40px;
}
.sns a {
  display: block;
}

.sidebar {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  width: 100%;
}
@media (min-width: 768px) {
  .sidebar {
    max-width: 300px;
    gap: 60px;
  }
}

.breadcrumb__wrapper {
  max-width: 1110px;
  width: 100%;
  margin: auto;
  padding-top: 2px;
  padding-left: 10px;
}
@media (min-width: 768px) {
  .breadcrumb__wrapper {
    padding-top: 16px;
    padding-left: 6px;
  }
}
.breadcrumb__wrapper .breadcrumb > span {
  margin: 0 5px;
}
@media (min-width: 768px) {
  .breadcrumb__wrapper .breadcrumb > span {
    margin: 0 15px;
  }
}
.breadcrumb__wrapper .breadcrumb > span:first-child {
  margin-left: 0;
  margin-right: 5px;
}
@media (min-width: 768px) {
  .breadcrumb__wrapper .breadcrumb > span:first-child {
    margin-right: 15px;
  }
}
.breadcrumb__wrapper .breadcrumb > span:last-child {
  margin-right: 0;
  margin-left: 5px;
}
@media (min-width: 768px) {
  .breadcrumb__wrapper .breadcrumb > span:last-child {
    margin-left: 15px;
  }
}
.breadcrumb__wrapper .breadcrumb > span > a > span,
.breadcrumb__wrapper .breadcrumb > span > span {
  color: #382620;
  font-size: 12px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .breadcrumb__wrapper .breadcrumb > span > a > span,
  .breadcrumb__wrapper .breadcrumb > span > span {
    font-size: 14px;
  }
}
.breadcrumb__wrapper .breadcrumb > span > a.home > span {
  text-transform: uppercase;
}

.pagination {
  text-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 12px;
}
.pagination .page-numbers {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 40px;
  height: 40px;
  color: #382620;
  font-size: 16px;
  font-weight: 500;
  background-color: #fff;
  border: 1px solid #382620;
  border-radius: 50%;
  position: relative;
}
.pagination .page-numbers.current {
  color: #FFF;
  background-color: #382620;
}
.pagination .fas.fa-angle-right {
  background: url(../img/pagination/arrow-next.png);
}
.pagination .fas.fa-angle-left {
  background: url(../img/pagination/arrow-prev.png);
}
.pagination .fas.fa-angle-right,
.pagination .fas.fa-angle-left {
  display: block;
  width: 8px;
  height: 13px;
  color: #382620;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

.taxonomy-nav {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  margin-bottom: 57px;
  gap: 11px;
}
@media (min-width: 768px) {
  .taxonomy-nav {
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-bottom: 80px;
  }
}
.taxonomy-nav-item {
  position: relative;
  height: 64px;
  width: calc(50% - 14px);
}
@media (min-width: 1100px) {
  .taxonomy-nav-item {
    height: 69px;
    width: 200px;
  }
}
.taxonomy-nav-item a {
  display: block;
  background: #888;
  color: #FFF;
  font-family: "Noto Serif JP", serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 20px;
  height: 100%;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.taxonomy-nav-item a:hover {
  background: #382620;
  opacity: 1;
}
.taxonomy-nav-item a.is-active {
  background: #382620;
}
.taxonomy-nav-item a::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 10;
  border: 1px solid #FFF;
  width: calc(100% - 8px);
  height: 56px;
}
@media (min-width: 1100px) {
  .taxonomy-nav-item a::before {
    height: 61px;
  }
}

.page-category {
  margin-bottom: 40px;
  text-align: left;
}
@media (min-width: 768px) {
  .page-category {
    margin-bottom: 24px;
  }
}
.page-category h2 {
  color: #382620;
  font-size: 20px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .page-category h2 {
    font-size: 24px;
  }
}

.recent-posts {
  background: #F8F8F8;
  padding: 20px;
}
.recent-posts__title {
  font-size: 20px;
  font-weight: 700;
  position: relative;
  padding-bottom: 20px;
  margin-bottom: 20px;
}
.recent-posts__title::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 32px;
  height: 1px;
  background-color: #222222;
}
.recent-posts__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
.recent-posts__item {
  width: 100%;
}
.recent-posts__item-link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 14px;
}
.recent-posts__item-image {
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
  margin-bottom: 0;
}
.recent-posts__item-image img {
  width: 100px;
  height: 100px;
}
.recent-posts__item-body {
  gap: 10px;
}
.recent-posts__item-title {
  font-size: 14px;
  font-weight: 700;
  line-height: 24px;
}
.recent-posts__item-time {
  font-size: 12px;
  font-weight: 500;
}

.related-posts__title {
  color: #382620;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 40px;
  line-height: 40px;
}
@media (min-width: 768px) {
  .related-posts__title {
    margin-bottom: 61px;
    font-size: 28px;
  }
}
.related-posts__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(1, 1fr);
  grid-column-gap: 19px;
  grid-row-gap: 20px;
}
@media (min-width: 768px) {
  .related-posts__list {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(1, 1fr);
    grid-column-gap: 40px;
    grid-row-gap: 40px;
  }
}
.related-posts__card-category {
  top: 10px;
  left: -8px;
}
@media (min-width: 768px) {
  .related-posts__card-category {
    top: 12px;
  }
}
@media (min-width: 768px) {
  .related-posts__card-category span {
    font-size: 12px;
  }
}
.related-posts__card-image {
  margin-bottom: 8px;
  height: 99px;
}
@media (min-width: 768px) {
  .related-posts__card-image {
    height: 125px;
    margin-bottom: 10px;
  }
}
.related-posts__card-body {
  gap: 8px;
}
@media (min-width: 768px) {
  .related-posts__card-body {
    gap: 10px;
  }
}
.related-posts__card-title {
  font-size: 12px;
  line-height: 18px;
}
@media (min-width: 768px) {
  .related-posts__card-title {
    font-size: 14px;
    line-height: 24px;
  }
}

.category__list {
  background: #F8F8F8;
  padding: 20px;
  -webkit-box-flex: 0;
  -webkit-flex-grow: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
}
.category__list-title {
  font-size: 20px;
  font-weight: 700;
  position: relative;
  padding-bottom: 20px;
  margin-bottom: 20px;
}
.category__list-title::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 32px;
  height: 1px;
  background-color: #222222;
}
.category__list-content {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
.category__list-item a {
  color: #382620;
  font-weight: 700;
  padding-left: 14px;
  position: relative;
}
.category__list-item a:hover {
  text-decoration: underline;
}
.category__list-item a::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 6px;
  height: 6px;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  -webkit-transform: rotate(45deg) translateY(-50%);
          transform: rotate(45deg) translateY(-50%);
}

@media (min-width: 768px) {
  .contact {
    padding-bottom: 66px;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  .contact {
    padding-bottom: 0;
  }
}
.contact__inner {
  padding-top: 48px;
}
@media (min-width: 768px) {
  .contact__inner {
    padding-top: 80px;
    max-width: 728px;
  }
}
.contact__heading {
  color: #382620;
  margin-bottom: 60px;
}
@media (min-width: 768px) {
  .contact__heading {
    margin-bottom: 80px;
  }
}
.contact__heading-ja {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 40px;
  margin-bottom: 20px;
}
@media (min-width: 768px) {
  .contact__heading-ja {
    font-size: 28px;
    margin-bottom: 28px;
  }
}
.contact__heading-ja_text {
  text-align: left;
  font-size: 14px;
  font-weight: 500;
  line-height: 24px;
}
@media (min-width: 768px) {
  .contact__heading-ja_text {
    font-size: 16px;
    line-height: normal;
  }
}
.contact__form {
  color: #382620;
}
.contact__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  margin-bottom: 18px;
}
@media (min-width: 768px) {
  .contact__items {
    margin-bottom: 40px;
  }
}
.contact__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8px;
}
.contact__item_radios {
  gap: 21px;
}
@media (min-width: 768px) {
  .contact__item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 28px;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .contact__item_radios, .contact__item_textarea {
    -webkit-box-align: start;
    -webkit-align-items: start;
        -ms-flex-align: start;
            align-items: start;
  }
}
.contact__item-title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
@media (min-width: 768px) {
  .contact__item-title {
    min-width: 170px;
  }
}
.contact__item-label {
  font-size: 16px;
  font-weight: 700;
}
.contact__item-tag {
  border-radius: 2px;
  background: #F07317;
  color: #fff;
  padding: 1px 6px 2px;
  font-weight: 700;
  font-size: 11px;
}
.contact__item [type=radio] {
  width: 1px;
  height: 1px;
  position: absolute;
  clip: rect(0, 0, 0, 0);
  overflow: hidden;
}
.contact__item [type=radio]:checked + .contact__item-radio-text::after {
  opacity: 1;
}
.contact__item [type=text],
.contact__item [type=email],
.contact__item [type=tel],
.contact__item textarea {
  width: 100%;
  padding-top: 11px;
  padding-bottom: 12px;
  padding-left: 15px;
  padding-right: 15px;
  border-radius: 6px;
  border: 1px solid #382620;
  background: #FFF;
}
.contact__item [type=text]::-webkit-input-placeholder, .contact__item [type=email]::-webkit-input-placeholder, .contact__item [type=tel]::-webkit-input-placeholder, .contact__item textarea::-webkit-input-placeholder {
  color: #cccccc;
}
.contact__item [type=text]::-moz-placeholder, .contact__item [type=email]::-moz-placeholder, .contact__item [type=tel]::-moz-placeholder, .contact__item textarea::-moz-placeholder {
  color: #cccccc;
}
.contact__item [type=text]:-ms-input-placeholder, .contact__item [type=email]:-ms-input-placeholder, .contact__item [type=tel]:-ms-input-placeholder, .contact__item textarea:-ms-input-placeholder {
  color: #cccccc;
}
.contact__item [type=text]::-ms-input-placeholder, .contact__item [type=email]::-ms-input-placeholder, .contact__item [type=tel]::-ms-input-placeholder, .contact__item textarea::-ms-input-placeholder {
  color: #cccccc;
}
.contact__item [type=text]::placeholder,
.contact__item [type=email]::placeholder,
.contact__item [type=tel]::placeholder,
.contact__item textarea::placeholder {
  color: #cccccc;
}
@media (min-width: 768px) {
  .contact__item [type=text]::-webkit-input-placeholder, .contact__item [type=email]::-webkit-input-placeholder, .contact__item [type=tel]::-webkit-input-placeholder, .contact__item textarea::-webkit-input-placeholder {
    font-size: 16px;
  }
  .contact__item [type=text]::-moz-placeholder, .contact__item [type=email]::-moz-placeholder, .contact__item [type=tel]::-moz-placeholder, .contact__item textarea::-moz-placeholder {
    font-size: 16px;
  }
  .contact__item [type=text]:-ms-input-placeholder, .contact__item [type=email]:-ms-input-placeholder, .contact__item [type=tel]:-ms-input-placeholder, .contact__item textarea:-ms-input-placeholder {
    font-size: 16px;
  }
  .contact__item [type=text]::-ms-input-placeholder, .contact__item [type=email]::-ms-input-placeholder, .contact__item [type=tel]::-ms-input-placeholder, .contact__item textarea::-ms-input-placeholder {
    font-size: 16px;
  }
  .contact__item [type=text]::placeholder,
  .contact__item [type=email]::placeholder,
  .contact__item [type=tel]::placeholder,
  .contact__item textarea::placeholder {
    font-size: 16px;
  }
}
.contact__item textarea {
  height: 200px;
}
@media (min-width: 768px) {
  .contact__item textarea {
    height: 240px;
  }
}
.contact__item-input, .contact__item-text {
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.contact__item-radios {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 11px;
}
.contact__item-radio {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.contact__item-radio-text {
  font-size: 16px;
  font-weight: 500;
  position: relative;
}
.contact__privacy {
  margin-bottom: 38px;
}
@media (min-width: 768px) {
  .contact__privacy {
    margin-bottom: 40px;
  }
}
.contact__privacy-text {
  color: #382620;
  font-size: 14px;
  font-weight: 500;
  line-height: 24px;
}
@media (min-width: 768px) {
  .contact__privacy-text {
    line-height: normal;
  }
}
.contact__submit {
  text-align: center;
}
.contact__submit input {
  display: inline-block;
  padding: 24px 120px;
  color: #FFFFFF;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  background-color: #222222;
  position: relative;
  z-index: 3;
  -webkit-transition: all 1s;
  transition: all 1s;
}
@media (min-width: 768px) {
  .contact__submit input {
    padding: 24px 116px;
  }
}
.contact__submit input:hover {
  -webkit-transform: translate(5px, 6px);
          transform: translate(5px, 6px);
  opacity: 1;
}
.contact__submit input::after {
  content: "";
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  border-bottom: 1px solid black;
  border-right: 1px solid black;
  position: absolute;
  right: -5px;
  bottom: -6px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.wpcf7-list-item.first {
  margin-left: 0;
}

span.wpcf7-list-item-label {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}

span.wpcf7-list-item-label::before {
  display: block;
  content: "";
  border-radius: 50%;
  border: 1px solid #382620;
  background-color: #fff;
  width: 24px;
  height: 24px;
  margin-right: 10px;
}

span.wpcf7-list-item-label::after {
  position: absolute;
  content: "";
  border-radius: 50%;
  width: 12px;
  height: 12px;
  background-color: #F5810E;
  top: 50%;
  left: 6px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: none;
}

input[type=radio]:checked + span.wpcf7-list-item-label::after {
  display: block;
}

.wpcf7-spinner {
  display: none;
}

.wpcf7-response-output {
  display: none !important;
}

.contact-thanks__inner {
  padding-top: 54px;
  padding-bottom: 60px;
  color: #382620;
}
@media (min-width: 768px) {
  .contact-thanks__inner {
    max-width: 688px;
    padding-top: 80px;
    padding-bottom: 0;
  }
}
.contact-thanks__title {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 26px;
}
@media (min-width: 768px) {
  .contact-thanks__title {
    font-size: 28px;
    line-height: 40px;
  }
}
.contact-thanks__text {
  text-align: left;
  font-size: 14px;
  font-weight: 500;
  line-height: 24px;
}
@media (min-width: 768px) {
  .contact-thanks__text {
    font-size: 16px;
    line-height: normal;
  }
}

.header {
  display: none;
  width: 100%;
  padding-top: 10px;
  padding-left: 15px;
  padding-right: 10px;
}
@media (min-width: 1100px) {
  .header {
    display: block;
    width: 15.625%;
    padding: 27px 18px 0;
    height: auto;
  }
}
.header__inner {
  display: block;
  text-align: center;
}
.header__logo {
  max-width: 120.043px;
  width: 100%;
  height: 63.084px;
  display: inline-block;
}
@media (min-width: 1100px) {
  .header__logo {
    max-width: 166px;
    height: 93px;
    margin-bottom: 53px;
  }
}
.header__logo-link {
  display: block;
}
.header__logo svg {
  fill: #FFF;
  width: 100%;
  height: auto;
}
@media (min-width: 1100px) {
  .header__logo svg {
    fill: #222;
  }
}
.header__nav {
  display: none;
}
@media (min-width: 1100px) {
  .header__nav {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    text-align: center;
    margin-bottom: 60px;
  }
}
.header__link {
  color: #222222;
}
.header__link:not(:last-child) {
  margin-bottom: 30px;
}
.header__link-en {
  font-family: "Patua One", serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 1.92px;
  line-height: normal;
}
.header__link-ja {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 10px;
  font-weight: 500;
  line-height: normal;
}
.header-sp {
  position: absolute;
  top: 0px;
  width: 100%;
}
.header-sp__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 10px 10px 0px 14px;
  position: relative;
}
.header-sp__logo {
  fill: #FFF;
  width: 120px;
  height: auto;
}
@media (min-width: 1100px) {
  .header-sp__logo {
    display: none;
  }
}
.header .menu-item:not(:last-child) {
  margin-bottom: 30px;
}
.header .menu-item a {
  color: #222222;
  font-family: "Patua One", serif;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 1.92px;
  line-height: normal;
}
.header .menu-item span {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 10px;
  font-weight: 500;
  line-height: normal;
  display: block;
  margin-top: 6px;
  letter-spacing: normal;
}

.mv__wrap {
  display: block;
}
@media (min-width: 1100px) {
  .mv__wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}

.mv {
  position: relative;
}
@media (min-width: 1100px) {
  .mv {
    width: 84.375%;
    margin-left: auto;
    z-index: 80;
  }
  .mv::after {
    content: "";
    display: block;
    width: 91%;
    height: 398px;
    position: absolute;
    bottom: -60px;
    right: 0px;
    background: #EAE0D5;
    z-index: -20;
  }
}
.mv__swiper {
  height: 667px;
  z-index: -10;
  position: relative;
}
@media (min-width: 768px) {
  .mv__swiper {
    height: 735px;
  }
}
.mv .swiper__mask {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.2);
  display: block;
  z-index: 999;
}
.mv__swiper-slide {
  height: 100%;
}
@media (min-width: 1100px) {
  .mv__swiper-slide {
    height: 735px;
  }
}
.mv__swiper-slide img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 30% 50%;
     object-position: 30% 50%;
  width: 100%;
  height: 100%;
}
@media (min-width: 768px) {
  .mv__swiper-slide img {
    -o-object-position: 50% 50%;
       object-position: 50% 50%;
  }
}
.mv .swiper-slide-active img,
.mv .swiper-slide-duplicate-active img,
.mv .swiper-slide-prev img {
  -webkit-animation: zoomUp 10s linear 0s 1 normal both;
          animation: zoomUp 10s linear 0s 1 normal both;
}
.mv .swiper-pagination {
  text-align: left;
  padding-left: 20px;
}
.mv .swiper-horizontal > .swiper-pagination-bullets,
.mv .swiper-pagination-bullets.swiper-pagination-horizontal,
.mv .swiper-pagination-custom,
.mv .swiper-pagination-fraction {
  bottom: 12px;
}
.mv .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.mv .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin-left: 0;
  margin-right: 16px;
  background: #FFF;
  opacity: 1;
}
.mv .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet:last-child,
.mv .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet:last-child {
  margin-right: 0px;
}
.mv .swiper-pagination-bullet-active {
  background: #D59B71;
}
.mv__lead {
  position: absolute;
  top: 126px;
  left: 5.3%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media (min-width: 1100px) {
  .mv__lead {
    top: 600px;
    left: 5.185%;
    gap: 16px;
  }
}
.mv__lead p {
  color: #FFFFFF;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 32px;
  letter-spacing: 2.24px;
}
@media (min-width: 768px) {
  .mv__lead p {
    font-size: 18px;
  }
}
@media (min-width: 1100px) {
  .mv__lead p {
    font-size: 20px;
    letter-spacing: 2.8px;
  }
}
.mv-card {
  position: absolute;
  bottom: 32px;
  right: 50%;
  -webkit-transform: translate(50%);
          transform: translate(50%);
  max-width: 325px;
  width: 100%;
}
@media (min-width: 768px) {
  .mv-card {
    max-width: 388px;
    bottom: 23px;
    right: 20px;
    -webkit-transform: none;
            transform: none;
  }
}
.mv-card__link {
  opacity: 0.85;
  background: #FFF;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: start;
  -webkit-align-items: start;
      -ms-flex-align: start;
          align-items: start;
  gap: 16px;
  padding: 12px;
  position: relative;
}
@media (min-width: 768px) {
  .mv-card__link {
    padding: 16px;
  }
}
.mv-card__background-bubble {
  position: absolute;
  top: -39px;
  right: 0;
  max-width: 120px;
  width: 100%;
}
@media (min-width: 768px) {
  .mv-card__background-bubble {
    max-width: 160px;
    top: -74px;
    right: 4px;
  }
}
.mv-card__background-bubble img {
  opacity: 1;
}
.mv-card__image {
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
  margin-bottom: 0;
}
.mv-card__image img {
  width: 100px;
  height: 100px;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 768px) {
  .mv-card__image img {
    width: 120px;
    height: 120px;
  }
}
.mv-card__category {
  top: 9px;
  left: -9px;
}
@media (min-width: 768px) {
  .mv-card__category {
    left: -8px;
  }
}
.mv-card__category span {
  padding: 2px 10px 3px 10px;
}
@media (min-width: 768px) {
  .mv-card__category span {
    font-size: 12px;
    padding: 3px 11px 4px 15px;
  }
}
.mv-card__category span::after {
  border-right: 9px solid transparent;
  border-top: 12px solid #222;
  border-right: 9px solid transparent;
  border-top: 11px solid #222;
  border-bottom: 11px solid #222;
}
.mv-card__time {
  margin-bottom: 10px;
}
@media (min-width: 768px) {
  .mv-card__time {
    font-size: 12px;
  }
}
.mv-card__title {
  font-size: 12px;
  line-height: 18px;
}
@media (min-width: 768px) {
  .mv-card__title {
    font-size: 14px;
    line-height: 24px;
  }
}

@-webkit-keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
}

@keyframes zoomUp {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
}
.top-concept__wrapper {
  position: relative;
}
.top-concept__wrapper::after {
  content: "";
  display: block;
  width: 94.6%;
  height: 100px;
  position: absolute;
  bottom: 1px;
  left: 0px;
  background: #EAE0D5;
  z-index: -100;
}
@media (min-width: 768px) {
  .top-concept__wrapper::after {
    width: 92.9%;
    height: 300px;
    bottom: 140px;
  }
}

.top-concept {
  padding-top: 120px;
  padding-bottom: 73px;
}
@media (min-width: 768px) {
  .top-concept {
    padding-top: 220px;
    padding-bottom: 240px;
    max-width: 1280px;
    margin: auto;
  }
}
.top-concept__inner {
  padding-left: 0;
  margin: 0;
  margin: auto;
}
@media (min-width: 768px) {
  .top-concept__inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    gap: 80px;
  }
}
.top-concept__image {
  width: 84%;
}
@media (min-width: 768px) {
  .top-concept__image {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
    max-width: 600px;
    width: 100%;
  }
}
.top-concept__image img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.top-concept__content {
  padding-left: 20px;
  padding-right: 20px;
  text-align: left;
  margin-bottom: 86px;
}
@media (min-width: 768px) {
  .top-concept__content {
    max-width: 470px;
    width: 100%;
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
        -ms-flex-order: 2;
            order: 2;
    padding-left: 0;
    margin-bottom: 0;
    padding-top: 18px;
  }
}
.top-concept__heading {
  margin-bottom: 38px;
}
@media (min-width: 768px) {
  .top-concept__heading {
    margin-bottom: 48px;
  }
}
@media (min-width: 768px) {
  .top-concept__heading .heading-en {
    margin-bottom: 8px;
  }
}
.top-concept__title {
  font-size: 20px;
  font-weight: 700;
  line-height: 40px;
  margin-bottom: 31px;
}
@media (min-width: 768px) {
  .top-concept__title {
    font-size: 28px;
    line-height: 60px;
    margin-bottom: 48px;
  }
}
.top-concept__text {
  font-size: 14px;
  line-height: 28px;
  margin-bottom: 56px;
  font-weight: 500;
}
.top-concept__text p {
  font-size: 14px;
  font-weight: 500;
  line-height: 28px;
}
@media (min-width: 768px) {
  .top-concept__text {
    margin-bottom: 54px;
  }
}
.top-concept__button {
  text-align: center;
}
@media (min-width: 768px) {
  .top-concept__button {
    text-align: left;
  }
}
.top-concept__img-beans {
  position: absolute;
  top: -26px;
  right: -9px;
  right: 0px;
  z-index: 100;
  width: 145px;
  height: 130px;
}
@media (min-width: 1100px) {
  .top-concept__img-beans {
    top: 16px;
    width: 296px;
    height: 265px;
  }
}

.page-concept__inner {
  position: relative;
  padding-top: 48px;
  padding-bottom: 60px;
  padding-right: 0;
  padding-left: 0;
}
@media (min-width: 768px) {
  .page-concept__inner {
    padding-top: 80px;
    padding-bottom: 0px;
  }
}
.page-concept__box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 36px;
  position: relative;
  padding-right: 20px;
  padding-left: 20px;
}
@media (min-width: 768px) {
  .page-concept__box {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 71px;
    max-width: 1160px;
    padding-right: 30px;
    padding-left: 30px;
    margin: auto;
  }
}
.page-concept__box-wrap {
  position: relative;
}
.page-concept__box-wrap:nth-child(1) {
  padding-bottom: 123px;
}
@media (min-width: 768px) {
  .page-concept__box-wrap:nth-child(1) {
    padding-bottom: 200px;
  }
}
.page-concept__box-wrap:nth-child(1)::after {
  content: "";
  display: block;
  width: 89.6%;
  height: 100px;
  position: absolute;
  bottom: 76px;
  right: 0px;
  background: #EAE0D5;
  z-index: -100;
}
@media (min-width: 768px) {
  .page-concept__box-wrap:nth-child(1)::after {
    width: 76.8%;
    height: 200px;
    bottom: 100px;
  }
}
.page-concept__box-wrap:nth-child(2) {
  padding-bottom: 95px;
}
@media (min-width: 768px) {
  .page-concept__box-wrap:nth-child(2) {
    padding-bottom: 200px;
  }
  .page-concept__box-wrap:nth-child(2) .page-concept__box-image {
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
        -ms-flex-order: 1;
            order: 1;
  }
  .page-concept__box-wrap:nth-child(2) .page-concept__box-content {
    -webkit-box-ordinal-group: 3;
    -webkit-order: 2;
        -ms-flex-order: 2;
            order: 2;
  }
}
.page-concept__box-wrap:nth-child(2)::after {
  content: "";
  display: block;
  width: 75.7%;
  height: 227px;
  position: absolute;
  bottom: 76px;
  left: 0px;
  background: #EAE0D5;
  z-index: -100;
}
@media (min-width: 768px) {
  .page-concept__box-wrap:nth-child(2)::after {
    width: 45.3%;
    height: 437px;
    bottom: 140px;
  }
}
.page-concept__box-wrap:nth-child(3) {
  padding-bottom: 36px;
}
@media (min-width: 768px) {
  .page-concept__box-wrap:nth-child(3) {
    padding-bottom: 74px;
  }
}
.page-concept__box-wrap:nth-child(3)::after {
  content: "";
  display: block;
  width: 49%;
  height: 239px;
  position: absolute;
  bottom: 0px;
  right: 0px;
  background: #EAE0D5;
  z-index: -100;
}
@media (min-width: 768px) {
  .page-concept__box-wrap:nth-child(3)::after {
    width: 31.2%;
    height: 520px;
    bottom: -6px;
  }
}
.page-concept__box-wrap:nth-child(3) .page-concept__box-image {
  width: 87%;
  margin-right: auto;
}
.page-concept__box-image {
  -webkit-box-ordinal-group: 3;
  -webkit-order: 2;
      -ms-flex-order: 2;
          order: 2;
}
@media (min-width: 768px) {
  .page-concept__box-image {
    max-width: 640px;
  }
}
@media (min-width: 768px) {
  .page-concept__box-image img {
    max-width: 100%;
    width: 100%;
    height: auto;
  }
}
.page-concept__box-content {
  -webkit-box-ordinal-group: 2;
  -webkit-order: 1;
      -ms-flex-order: 1;
          order: 1;
}
@media (min-width: 768px) {
  .page-concept__box-content {
    max-width: 389px;
    width: 100%;
    -webkit-flex-shrink: 0;
        -ms-flex-negative: 0;
            flex-shrink: 0;
  }
}
.page-concept__box-title {
  font-size: 20px;
  font-weight: 700;
  line-height: 40px;
  margin-bottom: 32px;
}
@media (min-width: 768px) {
  .page-concept__box-title {
    font-size: 28px;
    line-height: 60px;
    margin-bottom: 26px;
  }
}
.page-concept__box-text p {
  font-size: 14px;
  font-weight: 500;
  line-height: 28px;
}

.top-lunch-set {
  padding-top: 119px;
  position: relative;
}
@media (min-width: 768px) {
  .top-lunch-set {
    padding-top: 100px;
  }
}
.top-lunch-set__inner {
  padding-top: 56px;
  padding-bottom: 63px;
  background-color: #EAE0D5;
  padding-right: 0;
  padding-left: 0;
}
@media (min-width: 768px) {
  .top-lunch-set__inner {
    padding-top: 81px;
    padding-bottom: 80px;
    padding-right: 50px;
    padding-left: 50px;
  }
}
.top-lunch-set__heading {
  text-align: center;
  margin-bottom: 62px;
}
@media (min-width: 768px) {
  .top-lunch-set__heading {
    margin-bottom: 60px;
  }
}
.top-lunch-set__heading .heading-en {
  margin-bottom: 6px;
}
.top-lunch-set__card {
  background-color: #fff;
  padding-top: 39px;
  padding-bottom: 20px;
  padding-right: 20px;
  padding-left: 20px;
  position: relative;
}
@media (min-width: 768px) {
  .top-lunch-set__card {
    padding-top: 60px;
    padding-bottom: 40px;
    padding-right: 40px;
    padding-left: 40px;
    max-width: 1180px;
    width: 100%;
    margin: auto;
  }
}
.top-lunch-set__card-title {
  position: absolute;
  top: -21px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100%;
  max-width: 290px;
}
@media (min-width: 768px) {
  .top-lunch-set__card-title {
    max-width: 352px;
  }
}
.top-lunch-set__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  grid-column-gap: 20px;
  grid-row-gap: 22px;
  margin-bottom: 20px;
}
@media (min-width: 768px) {
  .top-lunch-set__list {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 100%;
    grid-column-gap: 20px;
    grid-row-gap: 0px;
    margin-bottom: 60px;
  }
}
@media (min-width: 768px) {
  .top-lunch-set__item:nth-child(even) {
    margin-top: 40px;
  }
}
.top-lunch-set__item-image {
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .top-lunch-set__item-image {
    margin-bottom: 17px;
    max-width: 260px;
    width: 100%;
  }
}
.top-lunch-set__item-body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 6px;
}
@media (min-width: 1100px) {
  .top-lunch-set__item-body {
    gap: 12px;
  }
}
.top-lunch-set__item-groupe {
  background-color: #222222;
  color: #fff;
  font-family: "Patua One", serif;
  font-size: 19px;
  font-weight: 400;
  height: 24px;
  width: 24px;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
  text-align: center;
}
@media (min-width: 768px) {
  .top-lunch-set__item-groupe {
    font-size: 24px;
  }
}
@media (min-width: 1100px) {
  .top-lunch-set__item-groupe {
    font-size: 32px;
    width: 49px;
    height: 49px;
  }
}
.top-lunch-set__item-text {
  color: #222222;
  font-weight: 700;
}
@media (min-width: 1100px) {
  .top-lunch-set__item-text {
    font-size: 18px;
  }
}
.top-lunch-set__combo {
  border-radius: 8px;
  background: #F7F6F4;
  padding: 20px 7px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (min-width: 768px) {
  .top-lunch-set__combo {
    padding: 10px 70px 14px 70px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 40px;
    max-width: 1100px;
    margin: auto;
  }
}
.top-lunch-set__combo-image {
  width: 100%;
  max-width: 700px;
}
.top-lunch-set__combo-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top-lunch-set__description {
  text-align: center;
  white-space: nowrap;
}
.top-lunch-set__description-text {
  font-size: 16px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .top-lunch-set__description-text {
    text-align: right;
  }
}
@media (min-width: 1100px) {
  .top-lunch-set__description-text {
    font-size: 20px;
  }
}
.top-lunch-set__description-price {
  color: #222;
  font-size: 40px;
  font-weight: 400;
  font-family: "Damion", cursive;
  position: relative;
  display: inline-block;
  background-image: url(../img/top-page/dotted.png);
  background-size: 100% 4px;
  background-repeat: no-repeat;
  background-position: bottom left;
  padding-bottom: 8px;
  margin-bottom: 8px;
  white-space: nowrap;
}
@media (min-width: 1100px) {
  .top-lunch-set__description-price {
    font-size: 60px;
    margin-bottom: 9px;
  }
}
.top-lunch-set__description-time {
  font-size: 12px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .top-lunch-set__description-time {
    text-align: right;
    font-size: 14px;
  }
}
.top-lunch-set__img-bubble {
  position: absolute;
  top: -237px;
  right: -17px;
  width: 100%;
  max-width: 200px;
}
@media (min-width: 768px) {
  .top-lunch-set__img-bubble {
    top: -70px;
    right: -23px;
  }
}
@media (min-width: 1100px) {
  .top-lunch-set__img-bubble {
    max-width: 309px;
  }
}
.top-lunch-set__img-leaves_bottom {
  position: absolute;
  bottom: -100px;
  left: 0;
  max-width: 128.365px;
  width: 100%;
}
@media (min-width: 768px) {
  .top-lunch-set__img-leaves_bottom {
    bottom: -241px;
    max-width: 286px;
  }
}
.top-lunch-set__img-leaves_top {
  position: absolute;
  top: -67px;
  right: -33px;
  width: 119px;
  height: 135px;
}
@media (min-width: 768px) {
  .top-lunch-set__img-leaves_top {
    top: -31px;
    right: 2px;
    width: 201px;
    height: 228px;
  }
}
.top-grand-menu {
  padding-top: 119px;
  padding-bottom: 135px;
  position: relative;
}
@media (min-width: 768px) {
  .top-grand-menu {
    padding-bottom: 156px;
    padding-top: 159px;
  }
}
.top-grand-menu::after {
  content: "";
  display: block;
  width: 73%;
  height: 2755px;
  position: absolute;
  bottom: 63px;
  right: 0;
  background: #EAE0D5;
  z-index: -100;
}
@media (min-width: 768px) {
  .top-grand-menu::after {
    width: 80%;
    height: 81.54%;
    bottom: 70px;
  }
}
.top-grand-menu__inner {
  margin: auto;
}
@media (min-width: 768px) {
  .top-grand-menu__inner {
    max-width: 1140px;
    padding-right: 20px;
    padding-left: 20px;
  }
}
.top-grand-menu__heading {
  text-align: center;
  margin-bottom: 45px;
}
@media (min-width: 768px) {
  .top-grand-menu__heading {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 9px;
  }
}
.top-grand-menu__heading .heading-en {
  margin-bottom: 2px;
}
@media (min-width: 768px) {
  .top-grand-menu__heading .heading-en {
    margin-bottom: 0;
  }
}
.top-grand-menu__boxes {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
.top-grand-menu__list {
  padding-top: 24px;
  padding-bottom: 40px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 20px;
  grid-row-gap: 25px;
}
@media (min-width: 768px) {
  .top-grand-menu__list {
    padding-top: 26px;
    padding-bottom: 106px;
    grid-template-columns: repeat(3, 1fr);
    grid-column-gap: 34px;
    grid-row-gap: 40px;
  }
}
.top-grand-menu__list_drink {
  display: block;
  padding-right: 20px;
  padding-left: 20px;
}
@media (min-width: 1100px) {
  .top-grand-menu__list_drink {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    gap: 5.6%;
    padding-right: 0px;
    padding-left: 0px;
    padding-bottom: 57px;
  }
}
.top-grand-menu__list-title {
  font-size: 20px;
  font-weight: 700;
  border-top: 1px solid #222222;
  border-bottom: 1px solid #222222;
  padding-top: 2px;
  padding-bottom: 3px;
  padding-left: 10px;
  position: relative;
}
@media (min-width: 768px) {
  .top-grand-menu__list-title {
    font-size: 24px;
    padding-top: 5px;
    padding-bottom: 4px;
    padding-left: 21px;
  }
}
.top-grand-menu__list-title::before, .top-grand-menu__list-title::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #222222;
}
.top-grand-menu__list-title::before {
  top: -5px;
}
.top-grand-menu__list-title::after {
  bottom: -5px;
}
.top-grand-menu__item_drink {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media (min-width: 768px) {
  .top-grand-menu__item_drink {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 43px;
  }
}
.top-grand-menu__item-image {
  background-color: #fff;
  padding: 5px;
  margin-bottom: 7px;
}
@media (min-width: 768px) {
  .top-grand-menu__item-image {
    padding: 8px;
    margin-bottom: 12px;
    width: 100%;
  }
}
.top-grand-menu__item-image img {
  width: 100%;
  height: auto;
}
.top-grand-menu__item-image_drink {
  display: none;
  margin-bottom: 0;
}
@media (min-width: 1100px) {
  .top-grand-menu__item-image_drink {
    display: block;
    -webkit-box-flex: 0;
    -webkit-flex-grow: 0;
        -ms-flex-positive: 0;
            flex-grow: 0;
  }
}
.top-grand-menu__item-text {
  font-size: 14px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .top-grand-menu__item-text {
    font-size: 20px;
  }
}
.top-grand-menu__item-price {
  font-family: "Damion", cursive;
  font-size: 24px;
  font-weight: 400;
}
@media (min-width: 768px) {
  .top-grand-menu__item-price {
    font-size: 32px;
  }
}
.top-grand-menu__item .drink-menu {
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  width: 100%;
}
@media (min-width: 768px) {
  .top-grand-menu__item .drink-menu {
    width: 33%;
  }
}
@media (min-width: 1100px) {
  .top-grand-menu__item .drink-menu {
    width: 197px;
  }
}
.top-grand-menu__item .drink-menu__title {
  font-size: 16px;
  font-weight: 700;
  position: relative;
  padding-bottom: 10px;
}
@media (min-width: 768px) {
  .top-grand-menu__item .drink-menu__title {
    padding-bottom: 7px;
    line-height: 2;
  }
}
.top-grand-menu__item .drink-menu__title::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #222222;
}
.top-grand-menu__item .drink-menu__list {
  padding-top: 13px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8px;
}
.top-grand-menu__item .drink-menu__list:not(:last-child) {
  padding-bottom: 43px;
}
@media (min-width: 768px) {
  .top-grand-menu__item .drink-menu__list {
    padding-top: 13px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.top-grand-menu__item .drink-menu__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  white-space: nowrap;
}
.top-grand-menu__item .drink-menu__item-text {
  font-weight: 700;
}
.top-grand-menu__item .drink-menu__item-price {
  font-family: "Damion", cursive;
  font-size: 20px;
  font-weight: 400;
}
.top-grand-menu__button {
  text-align: center;
}
.top-grand-menu__button a {
  padding: 25px 76px 24px;
}
.top-grand-menu__img-beans {
  position: absolute;
  bottom: -30px;
  right: 0;
  z-index: 1;
}
.top-grand-menu__img-beans img {
  height: 142px;
}
@media (min-width: 768px) {
  .top-grand-menu__img-beans img {
    height: 236px;
  }
}
@media (min-width: 1100px) {
  .top-grand-menu__img-beans img {
    height: 330px;
    bottom: -50px;
  }
}

.page-menu__inner {
  padding-top: 60px;
  padding-bottom: 60px;
}
@media (min-width: 768px) {
  .page-menu__inner {
    max-width: 1140px;
    padding-top: 80px;
    padding-bottom: 0;
  }
}
.page-menu__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 19px;
  grid-row-gap: 24px;
}
@media (min-width: 768px) {
  .page-menu__list {
    grid-template-columns: repeat(4, 1fr);
    grid-column-gap: 40px;
    grid-row-gap: 40px;
  }
}
.page-menu__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
.page-menu__item-image {
  margin-bottom: 8px;
  width: 100%;
  height: 100%;
}
@media (min-width: 768px) {
  .page-menu__item-image {
    margin-bottom: 12px;
    max-width: 245px;
    max-height: 245px;
  }
}
.page-menu__item-image img {
  width: 100%;
  height: 100%;
}
.page-menu__item-text {
  font-size: 14px;
  font-weight: 700;
}
.page-menu__item-price {
  font-family: "Damion", cursive;
  font-size: 24px;
  font-weight: 400;
  text-align: center;
}
.top-gallery {
  padding-top: 57px;
  position: relative;
}
@media (min-width: 768px) {
  .top-gallery {
    padding-top: 90px;
  }
}
.top-gallery__inner {
  background: #EAE0D5;
  padding-top: 60px;
  padding-bottom: 106px;
}
@media (min-width: 768px) {
  .top-gallery__inner {
    padding-top: 80px;
    padding-bottom: 86px;
  }
}
.top-gallery__heading {
  text-align: center;
  margin-bottom: 45px;
}
@media (min-width: 768px) {
  .top-gallery__heading .heading-en {
    margin-bottom: 2px;
  }
}
.top-gallery__content {
  margin-bottom: 40px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  grid-column-gap: 19px;
  grid-row-gap: 19px;
}
@media (min-width: 768px) {
  .top-gallery__content {
    max-width: 1100px;
    margin-right: auto;
    margin-left: auto;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 1fr;
    grid-template-rows: 1fr;
    grid-column-gap: 25px;
    margin-bottom: 62px;
  }
}
.top-gallery__button {
  text-align: center;
}
.top-gallery__button a {
  padding: 24px 62px;
}
.top-gallery__background-image-bubble {
  position: absolute;
  top: 0;
  right: 52.5%;
  z-index: 1;
  max-width: 200px;
  width: 100%;
}
@media (min-width: 768px) {
  .top-gallery__background-image-bubble {
    top: 70px;
    left: 23.2%;
    max-width: 225px;
  }
}
@media (min-width: 1100px) {
  .top-gallery__background-image-bubble {
    left: 23.2%;
    max-width: 265px;
  }
}
.top-gallery__background-image-bubble img {
  width: 100%;
}

.top-news {
  padding-top: 116px;
  padding-bottom: 67px;
  position: relative;
}
@media (min-width: 768px) {
  .top-news {
    padding-top: 122px;
    padding-bottom: 0;
  }
}
.top-news__inner {
  max-width: 1140px;
}
.top-news__heading {
  text-align: center;
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .top-news__heading {
    margin-bottom: 44px;
  }
}
.top-news__heading .heading-en {
  margin-bottom: 3px;
}
.top-news__content {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 22px;
  margin-bottom: 39px;
}
@media (min-width: 768px) {
  .top-news__content {
    margin-bottom: 60px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 3.4%;
  }
}
.top-news .card__body {
  color: #222222;
}
.top-news .card__category {
  top: 10px;
}
@media (min-width: 768px) {
  .top-news .card__category {
    top: 12px;
  }
}
@media (min-width: 768px) {
  .top-news .card__category span {
    font-size: 12px;
  }
}
.top-news .card__title {
  font-size: 12px;
  font-weight: 700;
  line-height: 18px;
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .top-news .card__title {
    font-size: 14px;
    line-height: 24px;
  }
}
@media (min-width: 768px) {
  .top-news .card__time {
    font-size: 12px;
    font-weight: 500;
  }
}
@media (min-width: 768px) {
  .top-news__head {
    max-width: 46.3%;
  }
}
@media (min-width: 768px) {
  .top-news__head .card__image {
    max-height: 319px;
    margin-bottom: 16px;
  }
}
.top-news__head .card__category {
  top: 19px;
}
@media (min-width: 768px) {
  .top-news__head .card__category {
    top: 20px;
  }
}
.top-news__head .card__category span {
  font-size: 12px;
}
@media (min-width: 768px) {
  .top-news__head .card__category span {
    font-size: 16px;
  }
}
.top-news__head .card__category span::after {
  border-top: 11px solid #222;
  border-bottom: 12px solid #222;
}
@media (min-width: 768px) {
  .top-news__head .card__category span::after {
    border-top: 15px solid #222;
    border-bottom: 14px solid #222;
  }
}
.top-news__head .card__body {
  color: #222222;
}
.top-news__head .card__title {
  font-size: 14px;
  font-weight: 700;
  line-height: 24px;
  margin-bottom: 10px;
}
@media (min-width: 768px) {
  .top-news__head .card__title {
    font-size: 20px;
    line-height: 32px;
    margin-bottom: 10px;
  }
}
.top-news__head .card p {
  line-height: 18px;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 500;
}
@media (min-width: 768px) {
  .top-news__head .card p {
    font-size: 14px;
    font-weight: 400;
    line-height: 24px;
    margin-bottom: 12px;
  }
}
.top-news__head .card__time {
  font-size: 12px;
  font-weight: 500;
}
@media (min-width: 768px) {
  .top-news__head .card__time {
    font-size: 14px;
  }
}
@media (min-width: 768px) {
  .top-news__body {
    max-width: 50.3%;
  }
}
.top-news__body .card__list {
  grid-column-gap: 19px;
  grid-row-gap: 19px;
}
@media (min-width: 768px) {
  .top-news__body .card__list {
    grid-column-gap: 43px;
    grid-row-gap: 32px;
  }
}
@media (min-width: 768px) {
  .top-news__body .card__item {
    max-width: 255px;
  }
}
.top-news__body .card__item-image {
  height: 100%;
  margin-bottom: 6px;
}
@media (min-width: 768px) {
  .top-news__body .card__item-image {
    max-height: 159px;
    margin-bottom: 10px;
  }
}
.top-news__body .card__item-title {
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .top-news__body .card__item-title {
    margin-bottom: 10px;
  }
}
.top-news__button {
  text-align: center;
}
.top-news__background-salad {
  position: absolute;
  top: -10px;
  left: 0px;
}
@media (min-width: 768px) {
  .top-news__background-salad {
    top: -144px;
  }
}
.top-news__background-salad img {
  width: 100%;
  height: 185px;
}
@media (min-width: 768px) {
  .top-news__background-salad img {
    height: 320px;
  }
}

.page-news__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 60px;
  padding-top: 48px;
}
@media (min-width: 768px) {
  .page-news__inner {
    max-width: 1140px;
    padding-right: 20px;
    padding-left: 27px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    padding-top: 80px;
    gap: 74px;
  }
}
.page-news__content {
  position: relative;
}
@media (min-width: 768px) {
  .page-news__content {
    max-width: 728px;
    width: 100%;
  }
}
.page-news__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 19px;
  grid-row-gap: 24px;
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .page-news__list {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
  }
}
.page-news__item {
  max-width: 340px;
  width: 100%;
}
.page-news__item-link {
  display: block;
}
.page-news__item-image {
  margin-bottom: 8px;
	aspect-ratio: 340 / 213;
}
@media (min-width: 768px) {
  .page-news__item-image {
    margin-bottom: 11px;
    max-width: 340px;
    max-height: 213px;
  }
}
.page-news__item-category {
  top: 10px;
  left: -8px;
}
@media (min-width: 768px) {
  .page-news__item-category {
    top: 16px;
  }
}
.page-news__item-category span {
  font-size: 12px;
}
.page-news__item-category span::after {
  border-right: 8.6px solid transparent;
}
@media (min-width: 768px) {
  .page-news__item-category span::after {
    border-right: 8px solid transparent;
    border-top: 14px solid #222;
    border-bottom: 12px solid #222;
  }
}
@media (min-width: 768px) {
  .page-news__item-category span {
    font-size: 14px;
  }
}
.page-news__item-body {
  gap: 7px;
}
@media (min-width: 768px) {
  .page-news__item-body {
    gap: 12px;
  }
}
.page-news__item-title {
  font-size: 12px;
  line-height: 18px;
}
@media (min-width: 768px) {
  .page-news__item-title {
    font-size: 16px;
    font-weight: 700;
    line-height: 24px;
  }
}
.single-news__inner {
  padding-top: 48px;
  padding-bottom: 60px;
}
@media (min-width: 768px) {
  .single-news__inner {
    max-width: 728px;
    padding-top: 80px;
  }
}
.single-news__content {
  margin-bottom: 104px;
}
@media (min-width: 768px) {
  .single-news__content {
    margin-bottom: 132px;
  }
}
.single-news__head:not(:last-child) {
  margin-bottom: 36px;
}
.single-news__head-image {
  margin-bottom: 24px;
}
.single-news__head-image img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.single-news__head-title {
  font-size: 20px;
  line-height: 28px;
  margin-bottom: 25px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .single-news__head-title {
    font-size: 28px;
    line-height: 40px;
    margin-bottom: 40px;
  }
}
.single-news__head-time {
  font-weight: 700;
  padding-right: 20px;
}
.single-news__head-info {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -webkit-flex-direction: row;
      -ms-flex-direction: row;
          flex-direction: row;
  color: #382620;
  font-size: 14px;
}
.single-news__head-category {
  font-weight: 700;
  padding-left: 20px;
  position: relative;
}
.single-news__head-category::before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 100%;
  background: #382620;
}
.single-news__body {
  color: #382620;
}
.single-news__body h1 {
  font-size: 20px;
  line-height: 28px;
  margin-bottom: 25px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .single-news__body h1 {
    font-size: 28px;
    line-height: 40px;
    margin-bottom: 40px;
  }
}
.single-news__body h2 {
  font-size: 18px;
  line-height: 28px;
  margin-bottom: 18px;
  position: relative;
  padding-left: 16px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .single-news__body h2 {
    font-size: 24px;
    line-height: normal;
  }
}
.single-news__body h2::before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
  background: #382620;
}
.single-news__body h3 {
  font-size: 16px;
  line-height: 24px;
  padding-bottom: 12px;
  margin-bottom: 20px;
  position: relative;
}
@media (min-width: 768px) {
  .single-news__body h3 {
    font-size: 20px;
    font-weight: 700;
    line-height: normal;
  }
}
.single-news__body h3::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  height: 1px;
  width: 100%;
  background: #382620;
}
.single-news__body h4 {
  font-size: 14px;
  line-height: 24px;
  margin-bottom: 14px;
}
@media (min-width: 768px) {
  .single-news__body h4 {
    font-size: 16px;
    font-weight: 700;
    line-height: normal;
  }
}
.single-news__body p {
  color: #222222;
  font-size: 14px;
  font-weight: 500;
  line-height: 28px;
  margin-bottom: 36px;
}
@media (min-width: 768px) {
  .single-news__body p {
    margin-bottom: 56px;
  }
}
.single-news__body a {
  text-decoration: underline;
}
.single-news__body a:hover {
  color: orange;
}
.single-news__body ul {
  margin-top: 28px;
  margin-bottom: 32px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8px;
}
.single-news__body li {
  color: #222222;
  font-size: 14px;
  font-weight: 500;
  position: relative;
  padding-left: 20px;
}
.single-news__body li::before {
  content: "・";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
.single-news__body blockquote {
  padding: 20px 24px 21px;
  background-color: #fff;
  margin: 0;
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .single-news__body blockquote {
    padding: 35px 40px 34px;
    margin-bottom: 43px;
  }
}
.single-news__body blockquote p {
  font-size: 14px;
  font-weight: 500;
  line-height: 28px;
  color: #222222;
  margin: 0;
}
.single-news__body blockquote p:not(:last-child) {
  margin-bottom: 12px;
}
@media (min-width: 768px) {
  .single-news__body blockquote p:not(:last-child) {
    margin-bottom: 9px;
  }
}
@media (min-width: 768px) {
  .single-news__body blockquote p {
    font-size: 16px;
    font-weight: 500;
    line-height: 32px;
  }
}
.single-news__body blockquote a {
  text-align: right;
  color: #222222;
  font-size: 14px;
  font-weight: 500;
  margin-right: 20px;
}
@media (min-width: 768px) {
  .single-news__body blockquote a {
    margin: 0;
  }
}
.single-news .prev_next_buttons {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
.single-news .prev,
.single-news .next {
  background-repeat: no-repeat;
  background-size: 6px auto;
}
.single-news .prev a,
.single-news .next a {
  color: #382620;
  font-size: 16px;
  font-weight: 700;
  line-height: 24px;
}
.single-news .prev {
  background-image: url(../img/news/icon-left.png);
  background-position: center left;
}
.single-news .prev a {
  padding-left: 16px;
}
.single-news .next {
  background-image: url(../img/news/icon-right.png);
  background-position: center right;
}
.single-news .next a {
  padding-right: 16px;
}
.single-news .prev_next_button {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.single-news .prev_next_button a {
  padding: 8px 28px;
  background-color: transparent;
  color: #382620;
  font-weight: 700;
  border: 1px solid #382620;
  font-size: 14px;
}
@media (min-width: 768px) {
  .single-news .prev_next_button a {
    padding: 12px 36px;
    font-size: 16px;
  }
}
.single-news .prev_next_button a::after {
  display: none;
}
.single-news .prev_next_button a:hover {
  color: #FFFFFF;
  background-color: #222222;
  -webkit-transform: none;
          transform: none;
}

.top-access {
  padding-top: 100px;
  position: relative;
}
@media (min-width: 768px) {
  .top-access {
    padding-top: 165px;
  }
}
.top-access__inner {
  background-color: #EAE0D5;
  padding-top: 81px;
  padding-bottom: 83px;
}
.top-access__heading {
  text-align: center;
  margin-bottom: 44px;
}
.top-access__heading .heading-en {
  margin-bottom: 1px;
}
.top-access__content {
  margin: auto;
  max-width: 335px;
  width: 100%;
}
@media (min-width: 768px) {
  .top-access__content {
    max-width: 688px;
  }
}
.top-access__head {
  background: #FFF;
  padding: 5px;
  margin-bottom: 18px;
}
@media (min-width: 768px) {
  .top-access__head {
    padding: 9px;
  }
}
.top-access__map {
  min-width: 325px;
  min-height: 178px;
  width: 100%;
  height: 100%;
}
@media (min-width: 768px) {
  .top-access__map {
    min-width: 668px;
    min-height: 367px;
  }
}
.top-access__information {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media (min-width: 768px) {
  .top-access__information {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 40px;
  }
}
.top-access__table {
  border-collapse: collapse;
}
@media (min-width: 768px) {
  .top-access__table {
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
}
.top-access__table tr {
  border-bottom: 1px solid #222;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 24px;
  padding: 14px 0px 15px;
}
@media (min-width: 768px) {
  .top-access__table tr {
    padding: 19px 0px 14px;
  }
}
.top-access__table th,
.top-access__table td {
  font-size: 14px;
  font-weight: 700;
  line-height: 24px;
}
.top-access__table th {
  width: 56px;
}
.top-access__img-bubble {
  position: absolute;
  top: 58px;
  left: -30px;
}
@media (min-width: 768px) {
  .top-access__img-bubble {
    top: 90px;
    left: 14%;
  }
}
@media (min-width: 1100px) {
  .top-access__img-bubble {
    top: 114px;
    left: 26.2%;
  }
}
.top-access__img-bubble img {
  width: 100%;
  height: 172px;
}
@media (min-width: 768px) {
  .top-access__img-bubble img {
    height: 200.002px;
  }
}
.top-access__img-beans {
  position: absolute;
  bottom: -58px;
  left: -22px;
}
@media (min-width: 768px) {
  .top-access__img-beans {
    bottom: -137px;
    left: 0;
  }
}
.top-access__img-beans img {
  width: 92px;
}
@media (min-width: 1100px) {
  .top-access__img-beans img {
    width: 256px;
  }
}
.top-access__img-toast {
  position: absolute;
  top: 0;
  right: 5px;
}
@media (min-width: 768px) {
  .top-access__img-toast {
    right: 0;
  }
}
.top-access__img-toast img {
  width: auto;
  height: 180px;
}
@media (min-width: 768px) {
  .top-access__img-toast img {
    height: 250px;
  }
}
@media (min-width: 1100px) {
  .top-access__img-toast img {
    height: 359px;
  }
}

.page-shops {
  padding-top: 48px;
}
@media (min-width: 768px) {
  .page-shops {
    padding-top: 80px;
  }
}
.page-shops__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 65px;
}
@media (min-width: 768px) {
  .page-shops__inner {
    gap: 121px;
  }
}
.page-shops__head {
  padding: 3px;
  margin-bottom: 0px;
}
@media (min-width: 768px) {
  .page-shops__head {
    padding: 8px;
  }
}
.page-shops__title {
  color: #382620;
  font-weight: 700;
  font-size: 20px;
  padding-left: 14px;
  margin-bottom: 20px;
  position: relative;
}
@media (min-width: 768px) {
  .page-shops__title {
    font-size: 24px;
    padding-left: 22px;
    margin-bottom: 24px;
  }
}
.page-shops__title::before {
  content: "";
  display: block;
  width: 6px;
  height: 100%;
  background-color: #382620;
  position: absolute;
  top: 0;
  left: 0;
}
.page-shops__table {
  width: 100%;
}
@media (min-width: 768px) {
  .page-shops__table {
    width: calc(50% - 40px);
  }
}
.page-shops__table tr {
  padding-top: 17px;
  padding-bottom: 12px;
}
@media (min-width: 768px) {
  .page-shops__table tr {
    padding-top: 21px;
    padding-bottom: 13px;
  }
}

.page-gift {
  margin-bottom: 60px;
}
@media (min-width: 768px) {
  .page-gift {
    margin-bottom: 0;
  }
}
.page-gift__inner {
  padding-top: 48px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 60px;
}
@media (min-width: 768px) {
  .page-gift__inner {
    max-width: 1140px;
    margin: 0 auto;
    padding-top: 80px;
    gap: 100px;
  }
}
.page-gift__box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
  margin-bottom: 40px;
}
@media (min-width: 768px) {
  .page-gift__box {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.page-gift__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  grid-column-gap: 19px;
  grid-row-gap: 40px;
}
@media (min-width: 768px) {
  .page-gift__list {
    grid-column-gap: 40px;
  }
}
@media (min-width: 768px) {
  .page-gift__list-second {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 40px;
  }
}
@media (min-width: 768px) {
  .page-gift__item-main {
    max-width: 528px;
    width: 100%;
  }
}
.page-gift__item-image {
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .page-gift__item-image {
    margin-bottom: 12px;
  }
}
.page-gift__item-image-main {
  margin-bottom: 12px;
}
@media (min-width: 768px) {
  .page-gift__item-image-main {
    margin-bottom: 13px;
  }
}
.page-gift__item-content {
  color: #222222;
}
.page-gift__item-title {
  font-weight: 700;
  font-size: 14px;
}
.page-gift__item-title-main {
  font-size: 20px;
}
@media (min-width: 768px) {
  .page-gift__item-title-main {
    font-size: 24px;
  }
}
.page-gift__item-price {
  text-align: center;
  font-family: "Damion", cursive;
  font-weight: 400;
  font-size: 24px;
  margin-bottom: 11px;
}
@media (min-width: 768px) {
  .page-gift__item-price {
    margin-bottom: 12px;
  }
}
.page-gift__item-price-main {
  font-size: 28px;
  margin-bottom: 12px;
}
@media (min-width: 768px) {
  .page-gift__item-price-main {
    font-size: 32px;
  }
}
.page-gift__button {
  text-align: center;
}
.page-gift__button a {
  padding-top: 5px;
  padding-bottom: 5px;
  padding-right: 14px;
  padding-left: 14px;
  font-size: 12px;
  border: 1px solid #222222;
}
@media (min-width: 768px) {
  .page-gift__button a {
    padding: 8px 24px;
    padding-top: 7px;
    padding-bottom: 7px;
    padding-right: 23px;
    padding-left: 23px;
    font-size: 14px;
  }
}
.page-gift__button a:hover {
  background-color: transparent;
  color: #222222;
  -webkit-transform: none;
          transform: none;
}
.page-gift__button a:hover::after {
  display: none;
}
.page-gift__button a::after {
  display: none;
}
.page-gift__info {
  border: 4px solid #382620;
  background: #FFF;
  position: relative;
  padding: 37px 40px 40px 40px;
}
@media (min-width: 768px) {
  .page-gift__info {
    padding-top: 76px;
    padding-right: 56px;
    padding-bottom: 76px;
    padding-left: 56px;
  }
}
.page-gift__info::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 94%;
  height: 95.9%;
  border: 1px solid #382620;
}
@media (min-width: 768px) {
  .page-gift__info::before {
    width: 98.1%;
    height: 95.6%;
  }
}
.page-gift__info-inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 34px;
}
@media (min-width: 768px) {
  .page-gift__info-inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 60px;
  }
}
.page-gift__info-content {
  color: #382620;
  max-width: 460px;
  width: 100%;
}
.page-gift__info-content-title {
  font-size: 16px;
  font-weight: 700;
  line-height: 28px;
  padding-bottom: 25px;
  position: relative;
  background: url(../img/gift/page-gift__dotted.png) repeat-x left bottom;
  background-size: 100% auto;
}
@media (min-width: 768px) {
  .page-gift__info-content-title {
    font-size: 24px;
    line-height: 40px;
    padding-bottom: 23px;
  }
}
.page-gift__info-content-text {
  padding-top: 22px;
  font-size: 12px;
  font-weight: 500;
  line-height: 24px;
}
@media (min-width: 768px) {
  .page-gift__info-content-text {
    padding-top: 36px;
    font-size: 16px;
    line-height: 32px;
  }
}
@media (min-width: 768px) {
  .page-gift__info-image {
    max-width: 460px;
    width: 100%;
  }
}

.footer {
  background-color: #382620;
  padding-top: 40px;
  padding-bottom: 14px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 37px;
  text-align: center;
}
@media (min-width: 768px) {
  .footer {
    padding-bottom: 16px;
  }
}
.footer__sns svg .twitter,
.footer__sns svg .instagram,
.footer__sns svg .youtube {
  fill: #FFF;
  height: 24px;
}
.footer .copyright {
  text-align: center;
}
.footer .copyright p {
  color: #FFF;
  font-size: 12px;
  font-weight: 500;
  line-height: 24px;
}