@import url("https://fonts.googleapis.com/css?family=Material+Icons");
:root {
  --color-a:#c8a242;
  --color-m:#323125;
  --color-t:#222222;
  --color-b:#ffffff;
  --color-s:#f0e8d1;
  --color-i:#ffffff;
}

.has-color-inverted {
  --color-a:#ffe277;
  --color-m:#fff;
  --color-t:#fff;
  --color-b:#000;
  --color-s:#39352d;
  --color-i:#000000;
}

.top-slider {
  position: relative;
  height: min(100vh, 250vw);
}
.top-slider__slides {
  position: absolute;
  top: 0rem;
  right: 0rem;
  bottom: 0rem;
  left: 0rem;
  inset: 0rem;
  z-index: 1;
  overflow: hidden;
}
.top-slider__slides-slide {
  position: absolute;
  top: 0rem;
  right: 0rem;
  bottom: 0rem;
  left: 0rem;
  inset: 0rem;
  overflow: hidden;
  animation: slider-slide 40s calc(var(--index) * 10s - var(--amount) * 10s) linear infinite both;
}
.top-slider__slides-slide-picture-img {
  display: block;
  position: absolute;
  top: 0rem;
  right: 0rem;
  bottom: 0rem;
  left: 0rem;
  inset: 0rem;
  width: 100%;
  height: 100%;
  object-position: center;
  object-fit: cover;
}
.top-slider__text {
  display: block;
  position: absolute;
  top: 0rem;
  right: 0rem;
  bottom: 0rem;
  left: 0rem;
  inset: 0rem;
  margin: auto 8vw;
  align-content: center;
  z-index: 2;
  font-size: 2.25rem;
  line-height: 2em;
  letter-spacing: 0.05em;
  font-family: YuMincho, "Yu Mincho", "Noto Serif JP", serif;
  font-weight: 400;
  color: var(--color-i, #ffffff);
  word-break: keep-all;
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.5333333333), 0 0 4px rgba(0, 0, 0, 0.5333333333), 0 0 6px rgba(0, 0, 0, 0.5333333333);
  animation: slider-text 1s 0.5s both;
  opacity: 0;
}
@media (max-width:960px) {
  .top-slider__text {
    font-size: 1.375rem;
  }
}

@keyframes slider-text {
  0% {
    opacity: 0;
    transform: -webkit- translateX(1em);
    transform: translateX(1em);
  }
  100% {
    opacity: 1;
    transform: -webkit- translateX(0rem);
    transform: translateX(0rem);
  }
}
@keyframes slider-slide {
  0% {
    z-index: 1;
    opacity: 0;
    transform: -webkit- scale(1.25);
    transform: scale(1.25);
  }
  50% {
    z-index: 2;
    opacity: 0;
    transform: -webkit- scale(1.25);
    transform: scale(1.25);
  }
  55% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    z-index: 4;
    opacity: 0;
    transform: -webkit- scale(1);
    transform: scale(1);
  }
}
.top-carousel {
  position: relative;
  margin: auto;
  height: 10rem;
  overflow: hidden;
}
@media (max-width:768px) {
  .top-carousel {
    display: none;
  }
}
.top-carousel__item {
  display: block;
  position: absolute;
  top: 0rem;
  right: 0rem;
  bottom: 0rem;
  left: 0rem;
  inset: 0rem;
  margin: auto;
  width: 18.75rem;
  height: 10rem;
  aspect-ratio: 1.2;
  animation: carousel-item calc(var(--amount) * 8s) calc(var(--index) * -8s) linear infinite both;
}
.top-carousel__item-img {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  object-position: center;
  object-fit: cover;
}

@keyframes carousel-item {
  0% {
    transform: -webkit- translateX(calc(var(--amount) * 50%));
    transform: translateX(calc(var(--amount) * 50%));
  }
  100% {
    transform: -webkit- translateX(calc(var(--amount) * -50%));
    transform: translateX(calc(var(--amount) * -50%));
  }
}
.top-section {
  padding: 6.25rem 0rem;
  background-color: var(--color-b, #ffffff);
  color: var(--color-t, #222222);
  clip-path: inset(0rem);
}
.top-section.has-bg-color {
  background-color: var(--color-s, #f0e8d1);
}
.top-section__header {
  position: relative;
  margin-bottom: 2.5rem;
  z-index: 2;
}
.top-section__header-title {
  text-align: center;
  font-size: 1.5rem;
}
@media (min-width:768px) {
  .top-section__header-title {
    font-size: 2rem;
  }
}
@media (min-width:768px) {
  .top-section__header-title {
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    gap: 0.5em;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: baseline;
    align-items: baseline;
  }
}
.top-section__header-title-en {
  display: block;
  position: relative;
  margin-bottom: 0.5em;
  font-size: 0.8em;
  font-family: "Cormorant Garamond", serif;
}
.top-section__header-title-en::after {
  content: " / ";
}
.top-section__header-title-ja {
  display: block;
  font-size: 1.2em;
  font-family: YuMincho, "Yu Mincho", "Noto Serif JP", serif;
  word-break: keep-all;
}
.top-section__header-lead {
  margin: 2em auto;
  text-align: center;
}
.top-section__body {
  position: relative;
  max-width: 80rem;
  width: auto;
  margin-inline: auto;
  padding: 1.25rem;
  z-index: 2;
}
.top-section__bg {
  display: block;
  position: fixed;
  top: 0rem;
  right: 0rem;
  bottom: 0rem;
  left: 0rem;
  inset: 0rem;
  width: 100%;
  height: 100%;
  object-position: center;
  object-fit: cover;
  z-index: 1;
  opacity: 0.3;
}
.top-section.has-wide-body .top-section__body {
  padding: 1.25rem 0rem;
}

.top-works__form {
  padding: 0.75rem 1.25rem;
  margin-bottom: 1.25rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 1rem;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  background-color: #000;
  color: var(--color-i, #ffffff);
}
.top-works__form-title {
  align-content: center;
  text-align: center;
  font-size: 1.125rem;
  color: var(--color-i, #ffffff);
}
@media (max-width:768px) {
  .top-works__form-title {
    display: none;
  }
}
.top-works__form-selects {
  -webkit-box-flex: 0;
  flex-grow: 0;
  flex-shrink: 1;
  flex-basis: 37.5rem;
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: repeat(4, 1fr);
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 0.5rem;
  align-content: center;
}
@media (max-width:768px) {
  .top-works__form-selects {
    display: -webkit-grid;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: repeat(2, 1fr);
    grid-template-columns: repeat(2, 1fr);
  }
}
.top-works__form-selects-item-select {
  width: 100%;
  background-color: #000;
  border-style: solid;
  border-width: 0.0625rem;
  border-color: rgba(255, 255, 255, 0.5333333333);
  color: var(--color-i, #ffffff);
}
.top-works__form-inputs {
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0.25rem 1rem;
  -webkit-align-items: center;
  align-items: center;
}
.top-works__form-inputs-item-input {
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto auto;
  grid-template-columns: auto auto;
  grid-gap: 0.5rem;
  border-style: solid;
  border-width: 0.0625rem;
  border-color: rgba(255, 255, 255, 0.5333333333);
}
.top-works__form-inputs-item-input-label {
  padding: 0.25em 1em;
  align-content: center;
}
.top-works__form-inputs-item-input-input {
  width: 8em;
}
.top-works__form-buttons {
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  gap: 0.5rem;
  -webkit-align-items: center;
  align-items: center;
}
.top-works__form-buttons-button {
  display: block;
  align-content: center;
  padding: 0.25rem 0.5rem;
  background-color: var(--color-i, #ffffff);
  border-style: none;
  border-radius: 0.5rem;
}
.top-works__form-buttons-button.is-button-send::before {
  content: "search";
  display: block;
  font-size: 2rem;
  line-height: 1em;
  font-family: "Material Icons";
}
.top-works__form-buttons-button.is-button-reset {
  font-size: 1rem;
}
.top-works__count {
  margin: 2.5rem auto 1.25rem;
  max-width: 90vw;
  width: auto;
  text-align: right;
  font-size: 0.875rem;
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-thickness: 0.0625rem;
  text-underline-offset: 0.5rem;
}
.top-works__count-number {
  font-size: 1.5em;
  font-family: "Cormorant Garamond", serif;
}
.top-works__items {
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(15rem, 100%), 1fr));
  grid-gap: 1rem;
}
@media (max-width:768px) {
  .top-works__items {
    width: 100%;
    overflow-x: auto;
    padding: 1.25rem 10vw;
    scroll-snap-type: x mandatory;
    display: -webkit-grid;
    display: -ms-grid;
    display: grid;
    grid-auto-flow: column;
    -ms-grid-rows: 1fr;
    grid-template-rows: 1fr;
    grid-template-columns: repeat(auto-fill, minmax(min(80vw, 100%), 1fr));
  }
}
.top-works__items-item {
  display: block;
  scroll-snap-align: center;
}
@media (max-width:768px) {
  .top-works__items-item {
    width: 80vw;
  }
}
.top-works__items-item-image {
  margin-bottom: 0.5em;
}
.top-works__items-item-image-img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1.5;
  object-position: center;
  object-fit: cover;
}
.top-works__items-item-title {
  padding: 0rem;
  margin: 0rem;
  font-size: 0.75rem;
  line-height: 1.5em;
  color: var(--color-t, #222222);
}

.top-button {
  display: block;
  padding: 0.8em 2em 0.8em 1em;
  max-width: 30rem;
  width: 80vw;
  margin: 2.5rem auto;
  background-color: var(--color-m, #323125);
  text-align: center;
  font-size: 1.125rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--color-i, #ffffff);
  clip-path: polygon(0% 0%, calc(100% - 1em) 0%, 100% 50%, calc(100% - 1em) 100%, 0% 100%);
}
.top-button:hover {
  color: var(--color-i, #ffffff);
}

@media (min-width:768px) {
  .top-shop {
    display: -webkit-grid;
    display: -ms-grid;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(15rem, 100%), 1fr));
    grid-gap: 0.5rem;
  }
}
.top-shop__title {
  display: block;
  padding: 0.5rem;
  margin-bottom: 0.25rem;
  align-content: center;
  background-color: var(--color-s, #f0e8d1);
  text-align: center;
  font-size: 0.875rem;
  font-family: YuMincho, "Yu Mincho", "Noto Serif JP", serif;
  color: var(--color-m, #323125);
}
@media (min-width:768px) {
  .top-shop__title {
    display: none;
  }
}
.top-shop__items {
  margin-bottom: 0.75rem;
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
  grid-gap: 0.125rem;
}
@media (min-width:768px) {
  .top-shop__items {
    display: contents;
  }
}
.top-shop__items-item {
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
}
@media (min-width:768px) {
  .top-shop__items-item {
    display: block;
  }
}
.top-shop__items-item-link {
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
}
.top-shop__items-item-link-image {
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width:768px) {
  .top-shop__items-item-link-image {
    display: none;
  }
}
.top-shop__items-item-link-name {
  padding: 0.2em;
  align-content: center;
  background-color: var(--color-t, #222222);
  text-align: center;
  font-size: 0.75rem;
  color: var(--color-i, #ffffff);
}
@media (min-width:768px) {
  .top-shop__items-item-link-name {
    font-size: 0.875rem;
  }
}
.top-shop__items-item-tel-link {
  display: block;
  padding: 0.5em;
  background-color: var(--color-m, #323125);
  text-align: center;
  color: var(--color-i, #ffffff);
}
.top-shop__items-item-tel-link:hover {
  color: var(--color-i, #ffffff);
}
@media (min-width:768px) {
  .top-shop__items-item-tel-link {
    background-color: transparent;
    color: var(--color-m, #323125);
  }
  .top-shop__items-item-tel-link:hover {
    color: var(--color-m, #323125);
  }
}
.top-shop__items-item-tel-link-icon {
  display: inline-block;
  margin-right: 0.25em;
}

.top-selected-menu {
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(25rem, 100%), 1fr));
  grid-gap: 1rem;
}
.top-selected-menu__item {
  position: relative;
  background-color: var(--color-b, #ffffff);
  color: var(--color-t, #222222);
  border-style: solid;
  border-width: 0.0625rem;
  border-color: rgba(255, 255, 255, 0.5333333333);
}
.top-selected-menu__item:hover {
  color: var(--color-t, #222222);
  opacity: 1;
}
.top-selected-menu__item-images {
  display: none;
}
.top-selected-menu__item-images-img {
  display: block;
  width: 100%;
  height: 100%;
  object-position: center;
  object-fit: cover;
}
.top-selected-menu__item-texts {
  position: relative;
  z-index: 2;
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: 1fr auto;
  grid-template-rows: 1fr auto;
  background-color: rgba(0, 0, 0, 0.2666666667);
  font-size: 0.8125rem;
}
@media (min-width:768px) {
  .top-selected-menu__item-texts {
    font-size: 0.875rem;
  }
}
.top-selected-menu__item-texts-header {
  padding: 0.5rem 1rem;
  align-content: center;
  background-color: rgba(0, 0, 0, 0.5333333333);
  letter-spacing: 0.05em;
  word-break: keep-all;
}
@media (min-width:768px) {
  .top-selected-menu__item-texts-header {
    padding: 0.75rem 1.25rem;
  }
}
.top-selected-menu__item-texts-header-title {
  margin-bottom: 0.25rem;
  font-size: 0.8em;
  font-family: "Cormorant Garamond", serif;
  color: var(--color-a, #E0B64A);
}
.top-selected-menu__item-texts-header-title::after {
  content: "";
  display: block;
  width: 100%;
  height: 0.0625rem;
  margin-top: 0.125rem;
  background-image: -webkit-linear-gradient(left, var(--color-a, #E0B64A), transparent);
  background-image: -moz-linear-gradient(left, var(--color-a, #E0B64A), transparent);
  background-image: -ms-linear-gradient(left, var(--color-a, #E0B64A), transparent);
  background-image: -o-linear-gradient(left, var(--color-a, #E0B64A), transparent);
  background-image: linear-gradient(90deg, var(--color-a, #E0B64A), transparent);
}
.top-selected-menu__item-texts-header-caption {
  margin: 0rem;
  font-size: 1em;
  line-height: 1.5em;
  font-family: YuMincho, "Yu Mincho", "Noto Serif JP", serif;
}
.top-selected-menu__item-texts-desc {
  padding: 0.5rem 1rem;
  background-color: var(--color-m, #323125);
  font-size: 0.8em;
  line-height: 1.5em;
  color: var(--color-i, #ffffff);
}
@media (min-width:768px) {
  .top-selected-menu__item-texts-desc {
    padding: 0.75rem 1.25rem;
  }
}
@media (min-width:768px) {
  .top-selected-menu__item {
    position: relative;
    min-height: 6.25rem;
    height: auto;
    display: -webkit-grid;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 2fr 5fr;
    grid-template-columns: 2fr 5fr;
  }
  .top-selected-menu__item-images {
    display: block;
  }
}

.top-concept {
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: repeat(2, 1fr);
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 1.25rem;
}
@media (min-width:768px) {
  .top-concept {
    display: -webkit-grid;
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: repeat(4, 1fr);
    grid-template-columns: repeat(4, 1fr);
  }
}
.top-concept__item {
  display: -webkit-grid;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: auto 1fr;
  grid-template-rows: auto 1fr;
}
.top-concept__item-image {
  display: block;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}
.top-concept__item-image-img {
  display: block;
  width: 100%;
  height: auto;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  transform: -webkit- scale(1);
  transform: scale(1);
}
.top-concept__item-image:hover {
  opacity: 1;
}
.top-concept__item-image:hover .top-concept__item-image-img {
  -webkit-transition: 3s;
  transition: 3s;
  transform: -webkit- scale(1.2);
  transform: scale(1.2);
}
.top-concept__item-image-title {
  display: block;
  position: absolute;
  top: 0rem;
  right: 0rem;
  bottom: 0rem;
  left: 0rem;
  inset: 0rem;
  margin: auto;
  align-content: center;
  text-align: center;
  font-size: 1.125rem;
  line-height: 1.5em;
  font-family: YuMincho, "Yu Mincho", "Noto Serif JP", serif;
  color: var(--color-i, #ffffff);
  text-shadow: 0 4px 4px hsla(0, 0%, 0%, 0.2);
}
@media (min-width:768px) {
  .top-concept__item-image-title {
    font-size: 1.75rem;
  }
}
.top-concept__item-desc {
  padding: 1em;
  margin: 0rem;
  background-color: black;
  text-align: justify;
  font-size: 0.75rem;
  line-height: 1.5em;
  color: var(--color-i, #ffffff);
}
/*# sourceMappingURL=frontpage.css.map */