@charset "UTF-8";
html,
input,
textarea,
select,
button {
  font-family: "游ゴシック体", yugothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 18px;
  font-weight: 500;
}

html {
  font-size: 18px;
  line-height: 1.75;
  color: #333;
  word-break: break-all;
  background: #fff;
}

body {
  margin: 0;
  background: #fff;
}

.body__inner {
  overflow: hidden;
}

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

img {
  max-width: 100%;
  height: auto;
  margin: 0;
  vertical-align: top;
  border: 0;
}

p {
  padding: 0;
  margin: 0;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

a {
  color: #000;
  text-decoration: none;
}

input,
select,
textarea,
button {
  padding: 0;
  margin: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

select::-ms-expand {
  display: none;
}

textarea {
  resize: vertical;
}

button {
  cursor: pointer;
  border: none;
}

label {
  cursor: pointer;
}

table {
  border-collapse: collapse;
}

ul,
ol {
  padding: 0;
  margin: 0;
  list-style: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  padding: 0;
  margin: 0;
  font-size: 14px;
  font-weight: 500;
}

main {
  display: block;
}

dl,
dt,
dd {
  padding: 0;
  margin: 0;
}

@media only screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) {
  body {
    position: relative;
    font-size: 14px;
    -webkit-appearance: none;
    -webkit-text-size-adjust: 100%;
  }
  input[type=submit] {
    -webkit-text-size-adjust: 100%;
  }
  input,
  select,
  textarea {
    font-size: 16px !important;
  }
  .pc {
    display: none !important;
  }
}
.heading02 {
  margin-top: 20px;
  font-size: 40px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 767px) {
  .heading02 {
    font-size: 24px;
  }
}
.heading02._sub {
  font-size: 30px;
  font-weight: normal;
  text-align: center;
  letter-spacing: 0;
}
@media only screen and (max-width: 767px) {
  .heading02._sub {
    font-size: 21px;
  }
}
.heading02._noMargin {
  margin-top: 0;
}

.heading03 {
  font-size: 33px;
  font-weight: bold;
  text-align: center;
}
.heading03 + .heading03 {
  margin-top: 20px;
}
@media only screen and (max-width: 767px) {
  .heading03 {
    font-size: 20px;
  }
}
.heading03._border {
  position: relative;
  padding-bottom: 5px;
  font-size: 36px;
  font-weight: normal;
}
.heading03._border::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 85px;
  height: 1px;
  content: "";
  background: #fac44c;
  transform: translateX(-50%);
}
.company .heading03._border {
  margin-top: 150px;
}
@media only screen and (max-width: 767px) {
  .heading03._border {
    font-size: 26px;
  }
}
.heading03._left {
  display: inline-block;
  text-align: left;
}
.heading03._left::after {
  left: 0;
  transform: none;
}
.heading03._bold {
  font-size: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .heading03._bold {
    font-size: 28px;
  }
}
.heading03._margin {
  margin-bottom: 40px;
}

.heading04 {
  margin-top: 50px;
  font-size: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .heading04 {
    margin-top: 30px;
    font-size: 18px;
  }
}

.tiles {
  display: grid;
  gap: 30px;
}
.tiles._col-2 {
  gap: 30px;
}
@media only screen and (min-width: 768px) {
  .tiles._col-2 {
    margin: 0 60px;
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
  }
}
.tiles._col-2 .btn {
  margin-right: auto;
  margin-left: auto;
}
.tiles._col-3 {
  grid-template-columns: repeat(3, 1fr);
  gap: 60px;
}
@media only screen and (min-width: 1025px) {
  .tiles._col-3-pc {
    grid-template-columns: repeat(3, 1fr);
    gap: 60px;
  }
}
.tiles._col-4 {
  grid-template-columns: repeat(4, 1fr);
}
@media only screen and (max-width: 1024px) {
  .tiles._col-2-sp {
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }
}

.btn {
  display: flex;
  display: inline-block;
  justify-content: center;
  width: 100%;
  max-width: 400px;
  padding: 24px 20px;
  font-size: 27px;
  font-weight: bold;
  text-align: center;
  border: 1px solid #636363;
  border-radius: 100px;
  transition: all 0.3s ease 0s;
}
.btn:hover {
  opacity: 0.7;
}
.btn._small {
  max-width: 230px;
  padding: 13px;
  font-size: 16px;
}
.btn._small span::before {
  font-size: 18px;
}
.btn._mid {
  max-width: 680px;
}
.btn._wide {
  max-width: 850px;
}
.btn._cat {
  padding: 1px 5px;
  font-size: 18px;
  font-weight: normal;
}
.btn._cat span {
  padding-left: 1em;
}
.btn._cat span::before {
  font-size: 18px;
}
.btn._yellow {
  margin-top: 40px;
  background: #fac44c;
}
.btn._bg {
  background: #f2ece5;
}
@media only screen and (max-width: 767px) {
  .btn {
    padding: 15px 20px;
    font-size: 18px;
  }
}
.btn span {
  position: relative;
  padding-left: 2em;
}
.btn span::before {
  position: absolute;
  top: 50%;
  left: 0;
  font-size: 31px;
  font-weight: bold;
  content: ">";
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .btn span::before {
    font-size: 20px;
  }
}

.btnCenter {
  text-align: center;
}

.textLink {
  transition: all 0.3s ease 0s;
}
.textLink:hover {
  opacity: 0.6;
}
.textLink._underLine {
  text-decoration: underline;
}

.googlemap {
  padding-left: 25px;
  background: url(../img/common/icon_ex.svg) no-repeat center left/contain;
}

.section {
  position: relative;
  padding: 120px 0;
}
@media only screen and (max-width: 767px) {
  .section {
    padding: 60px 0;
  }
}
@media only screen and (min-width: 768px) {
  .section._lower {
    margin-top: 180px;
  }
  .contact .section._lower, .news .section._lower {
    margin-top: 110px;
  }
}
@media only screen and (max-width: 767px) {
  .section._lower {
    margin-top: 193.86px;
  }
}
.section._bg {
  background: #f2ece5;
}
.section._bg02 {
  background: #e8e5e3;
}
.section._bg03 {
  background: #faf7f5;
}
.section._streak {
  padding: 0 0 120px 0;
}
.section._divider {
  padding: 10px;
  margin-bottom: 40px;
  background: #f2ece5;
}
@media only screen and (max-width: 767px) {
  .section._divider {
    padding: 10px;
  }
}
.section__inner {
  position: relative;
  z-index: 2;
  padding-right: 40px;
  padding-left: 40px;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: 768px) {
  .section__inner {
    max-width: 1480px;
  }
}
@media only screen and (max-width: 767px) {
  .section__inner {
    padding-right: 20px;
    padding-left: 20px;
  }
}
.section__inner._wide {
  max-width: 1880px;
}
.section__inner._narrow {
  max-width: 1080px;
}
.section__more {
  text-align: center;
}
.section__more._margin {
  margin-top: 40px;
}

.wp-pagenavi {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 80px;
}
.wp-pagenavi a,
.wp-pagenavi span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  margin: 0 10px;
  text-align: center;
  border: 1px solid #333;
  border-radius: 50px;
}
@media only screen and (max-width: 767px) {
  .wp-pagenavi a,
  .wp-pagenavi span {
    width: 40px;
    height: 40px;
  }
}
.wp-pagenavi a {
  transition: all 0.3s ease 0s;
}
.wp-pagenavi a:hover {
  opacity: 0.6;
}
.wp-pagenavi .current {
  background: #dfdddc;
}

.pagerList {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 200px;
}
@media only screen and (max-width: 767px) {
  .pagerList {
    margin-top: 100px;
  }
}
.pagerList__item {
  margin: 0 15px;
}
@media only screen and (max-width: 767px) {
  .pagerList__item {
    margin: 0 5px;
  }
}
.pagerList__item._small a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  font-size: 18px;
  font-weight: bold;
  border: 0.35px solid #333;
  border-radius: 50%;
}
@media only screen and (max-width: 767px) {
  .pagerList__item._small a {
    width: 50px;
    height: 50px;
    font-size: 16px;
  }
}
.pagerList__item .btn {
  max-width: none;
  padding: 13px 50px;
  font-size: 18px;
  border-width: 0.35px;
}
@media only screen and (max-width: 767px) {
  .pagerList__item .btn {
    padding: 13px 20px;
    font-size: 14px;
  }
}

.js-tabs-list {
  display: flex;
}
@media only screen and (min-width: 1025px) {
  .js-tabs-list {
    width: 45%;
    margin-left: 40px;
  }
}
@media only screen and (max-width: 1024px) {
  .js-tabs-list {
    margin-top: 30px;
  }
}
.js-tabs-listitem {
  width: 50%;
}
.js-tabs-listitem a {
  display: block;
  padding: 27px 20px;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  background: #fff;
  border: 1px solid #b7b7b7;
  border-radius: 8px;
}
@media only screen and (max-width: 1024px) {
  .js-tabs-listitem a {
    padding: 10px 5px;
    font-size: 18px;
  }
}
.js-tabs-listitem.is-active a {
  color: #fff;
  background: #736357;
}
.js-tabs-listitem:nth-child(2) {
  margin-left: 30px;
}
@media only screen and (max-width: 1024px) {
  .js-tabs-listitem:nth-child(2) {
    margin-left: 15px;
  }
}
.js-tabs-content:not(.is-active) {
  display: none;
}

.search {
  padding: 35px 0;
  background: #f2ece5;
}
.search__inner {
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 1024px) {
  .search__inner {
    display: block;
  }
}
.search form {
  position: relative;
  width: 100%;
  background: #fff;
  border: 1px solid #b7b7b7;
}
@media only screen and (min-width: 1025px) {
  .search form {
    width: 55%;
  }
}
.search form ::-moz-placeholder {
  font-size: 20px;
}
.search form ::placeholder {
  font-size: 20px;
}
@media only screen and (max-width: 1024px) {
  .search form ::-moz-placeholder {
    font-size: 16px;
  }
  .search form ::placeholder {
    font-size: 16px;
  }
}
@media only screen and (min-width: 1025px) {
  .search form {
    max-width: 700px;
  }
}
.search form .box {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 20px;
}
.search form .submit {
  position: absolute;
  top: 50%;
  right: 20px;
  width: 35px;
  height: 40px;
  font-size: 0 !important;
  cursor: pointer;
  background: url(../img/common/icon_search.png) no-repeat center center/contain;
  border: none;
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .search form .submit {
    width: 30px;
    height: 30px;
  }
}

.qa {
  display: grid;
}
@media only screen and (min-width: 768px) {
  .qa {
    grid-template-columns: 30% 1fr;
  }
}
@media only screen and (max-width: 767px) {
  .qa {
    gap: 50px;
  }
}
.qa__title span {
  display: block;
  font-size: 40px;
  font-weight: bold;
}
.qaWrap {
  width: 100%;
  padding-top: 40px;
}
@media only screen and (max-width: 767px) {
  .qaWrap {
    padding-top: 20px;
  }
}
.qaWrap._open .q::after {
  transform: translateY(-50%) rotate(180deg);
}
.qaWrap._open .a {
  display: block;
}
.qaList {
  border-top: 1px solid #4d4d4d;
  border-bottom: 1px solid #4d4d4d;
}
.qaList__item {
  display: flex;
}
.qaList__item._exLink a {
  display: flex;
  width: 100%;
}
.qaList__item:not(:first-child) {
  border-top: 1px solid #4d4d4d;
}
.qaList__item .num {
  padding-top: 40px;
  margin-right: 30px;
  font-size: 27px;
  font-weight: bold;
  white-space: nowrap;
}
@media only screen and (max-width: 767px) {
  .qaList__item .num {
    padding-top: 20px;
    margin-right: 20px;
    font-size: 20px;
  }
}
.qaList__item .q {
  position: relative;
  align-items: center;
  padding-right: 40px;
  padding-bottom: 40px;
  font-size: 27px;
  font-weight: bold;
}
.qaList__item .q:hover {
  cursor: pointer;
}
@media only screen and (max-width: 767px) {
  .qaList__item .q {
    padding-right: 40px;
    padding-bottom: 20px;
    font-size: 18px;
  }
}
.qaList__item .q::after {
  position: absolute;
  top: calc(50% - 20px);
  right: 20px;
  font-size: 15px;
  content: "▼";
  transition: all 0.3s ease 0s;
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .qaList__item .q::after {
    top: calc(50% - 10px);
    font-size: 12px;
  }
}
.qaList__item .q._exLink::after {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-weight: bold;
  content: ">";
  border: 0.5px solid #333;
  border-radius: 50%;
}
@media only screen and (max-width: 767px) {
  .qaList__item .q._exLink::after {
    right: 0;
  }
}
.qaList__item .a {
  display: none;
  padding-right: 40px;
}
.qaList__item .a p {
  padding-bottom: 80px;
}
@media only screen and (max-width: 767px) {
  .qaList__item .a p {
    padding-bottom: 40px;
  }
}
@media only screen and (max-width: 767px) {
  .qaList__item .a {
    padding-bottom: 40px;
  }
}
.qaList__item .a a {
  text-decoration: underline;
}

.js-accordion__wrap .js-accordion__contents {
  overflow: hidden;
  transition: height 0.3s ease;
}
.js-accordion__wrap:not(._open) .js-accordion__contents {
  display: none;
}

.borderBox {
  margin-top: 120px;
  overflow: hidden;
  border-radius: 50px;
  box-shadow: 0 0 5px 0 rgba(99, 99, 99, 0.75);
}
.borderBox + .borderBox {
  margin-top: 60px;
}
@media only screen and (max-width: 767px) {
  .borderBox {
    margin-top: 60px;
  }
  .borderBox + .borderBox {
    margin-top: 30px;
  }
}
.borderBox:has(.borderBox__img) .borderBox__body {
  padding: 0;
}
@media only screen and (max-width: 767px) {
  .borderBox:has(.borderBox__img) .borderBox__body {
    padding: 60px 20px;
  }
}
.borderBox:has(.borderBox__img) .borderBox__texts {
  padding: 60px 6.4%;
}
@media only screen and (min-width: 768px) {
  .borderBox:has(.borderBox__img) .borderBox__texts {
    width: 60%;
  }
}
@media only screen and (max-width: 767px) {
  .borderBox:has(.borderBox__img) .borderBox__texts {
    padding: 0;
  }
}
.borderBox__body {
  display: flex;
  padding: 60px 6.4%;
}
@media only screen and (max-width: 767px) {
  .borderBox__body {
    display: block;
  }
}
.borderBox__title {
  font-size: 33px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .borderBox__title {
    font-size: 23px;
  }
}
.borderBox__title._sub {
  position: relative;
  display: inline-block;
  padding-right: 90px;
  margin-bottom: 20px;
  font-size: 22px;
  font-weight: normal;
}
.borderBox__title._sub::after {
  position: absolute;
  top: 50%;
  right: 0;
  width: 85px;
  height: 1px;
  content: "";
  background: #fac44c;
  transform: translateY(-50%);
}
.borderBox__text {
  margin-top: 20px;
}
.borderBox__name {
  display: flex;
  align-items: flex-end;
  justify-content: right;
  margin-top: 30px;
  font-size: 15px;
}
.borderBox__name span {
  width: 135px;
}
@media only screen and (min-width: 768px) {
  .borderBox__name span {
    margin-left: 30px;
  }
}
@media only screen and (max-width: 767px) {
  .borderBox__name span {
    display: block;
    width: 40%;
    margin-top: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .borderBox__name {
    display: block;
  }
}
.borderBox__img {
  position: relative;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .borderBox__img {
    width: 40%;
  }
}
@media only screen and (max-width: 767px) {
  .borderBox__img {
    margin-top: 30px;
  }
}
.borderBox__img::before {
  display: block;
  padding-top: 95%;
  content: "";
}
.borderBox__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.tableBox {
  margin-top: 50px;
  overflow: hidden;
  border-radius: 20px;
  box-shadow: 0 0 5px 0 rgba(99, 99, 99, 0.75);
}
.tableBox._narrow {
  max-width: 820px;
  margin-right: auto;
  margin-left: auto;
}
.tableBox._contact {
  border-radius: 0;
}
.tableBox__dl {
  display: flex;
}
@media only screen and (max-width: 1024px) {
  ._contact .tableBox__dl {
    display: block;
  }
}
.tableBox__dl:not(:first-child) {
  border-top: 1px solid #c3c3c3;
}
.tableBox__dl:first-child .boxTable__dt,
.tableBox__dl:first-child .boxTable__dd {
  padding-top: 30px;
}
.tableBox__dl:last-child .boxTable__dt,
.tableBox__dl:last-child .boxTable__dd {
  padding-bottom: 30px;
}
.tableBox__dt, .tableBox__dd {
  padding: 15px 30px;
}
@media only screen and (max-width: 767px) {
  .tableBox__dt, .tableBox__dd {
    padding: 10px 20px;
  }
}
._contact .tableBox__dt, ._contact .tableBox__dd {
  padding: 40px 30px;
}
@media only screen and (max-width: 1024px) {
  ._contact .tableBox__dt, ._contact .tableBox__dd {
    padding: 30px 20px;
  }
}
._contact .tableBox__dt .error, ._contact .tableBox__dd .error {
  display: block;
  margin-top: 10px;
  font-size: 20px;
  color: #c22033;
}
@media only screen and (max-width: 767px) {
  ._contact .tableBox__dt .error, ._contact .tableBox__dd .error {
    font-size: 16px;
  }
}
.tableBox__dt {
  width: 16%;
  background: #f5f5f5;
}
._contact .tableBox__dt {
  width: 25%;
  font-size: 20px;
  font-weight: bold;
}
@media only screen and (max-width: 1024px) {
  ._contact .tableBox__dt {
    width: 100%;
    font-size: 16px;
  }
}
@media only screen and (max-width: 1024px) {
  ._contact .tableBox__dt {
    position: relative;
  }
  ._contact .tableBox__dt::after {
    position: absolute;
    top: 50%;
    right: 20px;
    font-size: 16px;
    color: #c22033;
    content: "必須";
    transform: translateY(-50%);
  }
}
._confirm .tableBox__dt::after {
  display: none;
}
._narrow .tableBox__dt {
  width: 28%;
}
@media only screen and (max-width: 767px) {
  ._narrow .tableBox__dt {
    width: 35%;
  }
}
@media only screen and (max-width: 767px) {
  .tableBox__dt {
    width: 40%;
  }
}
.tableBox__dd {
  align-items: center;
  width: 84%;
  background: #fff;
}
._contact .tableBox__dd {
  width: 75%;
}
@media only screen and (max-width: 1024px) {
  ._contact .tableBox__dd {
    width: 100%;
  }
}
._narrow .tableBox__dd {
  width: 72%;
}
@media only screen and (max-width: 767px) {
  ._narrow .tableBox__dd {
    width: 65%;
  }
}
@media only screen and (max-width: 767px) {
  .tableBox__dd {
    width: 60%;
  }
}
.tableBox__dd input[type=radio] {
  display: none;
}
.tableBox__dd input[type=text],
.tableBox__dd input[type=tel],
.tableBox__dd input[type=email],
.tableBox__dd textarea {
  width: 100%;
  padding: 14px;
  border: 0.6px solid #333;
}
.tableBox__dd textarea {
  height: 18em;
  line-height: 1.2;
  resize: none;
}
.tableBox__dd .pref {
  position: relative;
  width: 300px;
  padding: 18px 14px;
  color: #333;
  border: 0.5px solid #333;
}
@media only screen and (max-width: 1024px) {
  .tableBox__dd .pref {
    width: 100%;
  }
}
.tableBox__dd .selectWrap {
  position: relative;
  width: 100%;
}
.tableBox__dd .selectWrap::after {
  position: absolute;
  top: 45%;
  right: 20px;
  width: 10px;
  height: 10px;
  content: "";
  border-top: 2px solid #333;
  border-right: 2px solid #333;
  transform: translateY(-50%) rotate(135deg);
}
.tableBox__dd span {
  padding-right: 15px;
  font-size: 20px;
  font-weight: bold;
  white-space: nowrap;
}
@media only screen and (max-width: 1024px) {
  .tableBox__dd span {
    font-size: 16px;
  }
}
.tableBox__dd span._second {
  padding-left: 20px;
}
@media only screen and (max-width: 1024px) {
  .tableBox__dd span {
    padding-right: 4px;
  }
  .tableBox__dd span._second {
    padding-left: 8px;
  }
}
.tableBox__dd__inner {
  display: flex;
  align-items: center;
  width: 70%;
}
@media only screen and (max-width: 1024px) {
  .tableBox__dd__inner {
    width: 100%;
  }
}
.tableBox__dd__inner._name {
  width: 70%;
}
.tableBox__dd__inner._name input[type=text] {
  width: 40%;
}
@media only screen and (max-width: 1024px) {
  .tableBox__dd__inner._name {
    width: 100%;
  }
  .tableBox__dd__inner._name input[type=text] {
    width: 100%;
  }
}
.tableBox__dd__inner._select {
  width: 300px;
}
@media only screen and (max-width: 1024px) {
  .tableBox__dd__inner._select {
    width: 100%;
  }
}
@media only screen and (min-width: 1025px) {
  .tableBox__dd__inner {
    position: relative;
  }
  .tableBox__dd__inner::after {
    position: absolute;
    top: 10px;
    right: -50px;
    font-size: 20px;
    color: #c22033;
    content: "必須";
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1024px) {
  .tableBox__dd__inner::after {
    right: -40px;
    font-size: 16px;
  }
}

.historyBox {
  margin-top: 40px;
}
.historyBox__body {
  display: grid;
  gap: 40px;
  padding: 55px 3.9%;
  background: url(../img/company/bg_history.jpg) no-repeat center center/cover;
}
@media only screen and (min-width: 768px) {
  .historyBox__body {
    grid-template-columns: 1fr 4fr;
  }
}
@media only screen and (max-width: 767px) {
  .historyBox__body {
    gap: 20px;
    padding: 50px 20px;
  }
}
.historyBox__img img:not(:first-child) {
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  .historyBox__img img:not(:first-child) {
    margin-top: 15px;
  }
}
.historyBox__title {
  font-size: 30px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .historyBox__title {
    font-size: 21px;
  }
}
.historyBox__text {
  margin-top: 20px;
}

.shopBox__mainTitle {
  margin-top: 80px;
  font-size: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .shopBox__mainTitle {
    font-size: 28px;
  }
}
.shopBoxList {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 5px;
  margin-top: 70px;
}
@media only screen and (max-width: 1024px) {
  .shopBoxList {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (max-width: 767px) {
  .shopBoxList {
    grid-template-columns: repeat(1, 1fr);
  }
}
.shopBox__body {
  min-height: 242px;
  padding: 30px 30px;
  font-size: 17px;
  border: 1px solid #bebebe;
  border-radius: 20px;
}
.shopBox__title {
  font-size: 25px;
  font-weight: bold;
}
.shopBox__depart {
  font-weight: bold;
}
.shopBox__tel span {
  padding-left: 0.5em;
  font-size: 27px;
}
.qaBox__title {
  font-size: 40px;
  font-weight: bold;
}
.qaBox__title span {
  padding-left: 1em;
  font-size: 18px;
  font-weight: normal;
}
.qaBoxList {
  display: grid;
  gap: 5px;
  margin-top: 30px;
}
@media only screen and (min-width: 1025px) {
  .qaBoxList {
    grid-template-columns: repeat(3, 1fr);
  }
}
.qaBoxList__item {
  background: #fff;
  border: 1px solid #bebebe;
  border-radius: 20px;
}
.qaBoxList__item a {
  display: block;
}
.qaBoxList__title {
  padding: 45px 70px 45px 85px;
  font-size: 25px;
  font-weight: bold;
}
@media only screen and (max-width: 1024px) {
  .qaBoxList__title {
    font-size: 18px;
  }
}
._01 .qaBoxList__title {
  background: url(../img/common/icon_arrow.svg) no-repeat center right 20px/50px 50px, url(../img/qa/qabox01.jpg) no-repeat center left 20px/60px auto;
}
._02 .qaBoxList__title {
  background: url(../img/common/icon_arrow.svg) no-repeat center right 20px/50px 50px, url(../img/qa/qabox02.jpg) no-repeat center left 30px/40px auto;
}
._03 .qaBoxList__title {
  background: url(../img/common/icon_arrow.svg) no-repeat center right 20px/50px 50px, url(../img/qa/qabox03.jpg) no-repeat center left 20px/60px auto;
}
._04 .qaBoxList__title {
  background: url(../img/common/icon_arrow.svg) no-repeat center right 20px/50px 50px, url(../img/qa/qabox04.jpg) no-repeat center left 20px/60px auto;
}
._05 .qaBoxList__title {
  background: url(../img/common/icon_arrow.svg) no-repeat center right 20px/50px 50px, url(../img/qa/qabox05.jpg) no-repeat center left 20px/60px auto;
}
._06 .qaBoxList__title {
  background: url(../img/common/icon_arrow.svg) no-repeat center right 20px/50px 50px, url(../img/qa/qabox06.jpg) no-repeat center left 20px/60px auto;
}

.infoBox {
  margin-top: 50px;
  background: #fff;
  border-radius: 50px;
  box-shadow: 0 0 5px 0 rgba(99, 99, 99, 0.75);
}
.infoBox__body {
  max-width: 1390px;
  padding: 50px 1.2%;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (max-width: 767px) {
  .infoBox__body {
    padding: 50px 20px;
  }
}
.infoBox__top {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 30px;
}
@media only screen and (max-width: 767px) {
  .infoBox__top {
    grid-template-columns: 100px 1fr;
  }
}
._small .infoBox__top {
  display: flex;
  gap: 0;
  align-items: flex-end;
}
@media only screen and (max-width: 767px) {
  ._small .infoBox__top {
    display: block;
  }
}
._small .infoBox__img {
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  ._small .infoBox__img {
    max-width: 354px;
    margin-left: 50px;
  }
}
@media only screen and (max-width: 767px) {
  ._small .infoBox__img {
    margin-top: 30px;
  }
}
.infoBox__name {
  font-size: 30px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .infoBox__name {
    font-size: 21px;
  }
}
.infoBox__name._small {
  font-size: 22px;
}
@media only screen and (max-width: 767px) {
  .infoBox__name._small {
    font-size: 18px;
  }
}
.infoBox__address {
  margin-top: 5px;
}
.infoBox__map {
  margin-top: 5px;
}
.infoBox__tel {
  margin-top: 20px;
}
.infoBoxList {
  display: grid;
  gap: 20px;
  margin-top: 25px;
}
@media only screen and (min-width: 768px) {
  .infoBoxList {
    grid-template-columns: repeat(3, 1fr);
  }
}
.infoBoxList__item {
  padding: 35px 6.8%;
  border: 1px solid #4d4d4d;
  border-radius: 50px;
}
@media only screen and (max-width: 767px) {
  .infoBoxList__item {
    padding: 30px 20px;
  }
}
.infoBoxList__img {
  position: relative;
}
.infoBoxList__img .floor {
  position: absolute;
  top: -20px;
  left: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 75px;
  height: 75px;
  font-size: 22px;
  font-weight: bold;
  background: #fff;
  border: 1px solid #333;
  border-radius: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 767px) {
  .infoBoxList__img .floor {
    width: 50px;
    height: 50px;
    font-size: 18px;
  }
}
.infoBoxList__detail {
  margin-top: 20px;
}
.infoBoxList__name {
  font-size: 21px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .infoBoxList__name {
    font-size: 15px;
  }
}
.infoBoxList__name span {
  font-size: 13px;
  font-weight: normal;
}
.infoBoxList__tel {
  margin-top: 5px;
}
.infoOtherWrap {
  display: grid;
  gap: 70px;
  max-width: 1300px;
  margin-top: 50px;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: 768px) {
  .infoOtherWrap {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media only screen and (max-width: 767px) {
  .infoOtherWrap {
    gap: 30px;
  }
}

.openingBox {
  position: relative;
  z-index: 2;
  display: grid;
  margin-top: -250px;
  margin-bottom: 80px;
  overflow: hidden;
  background: #fff;
  border-radius: 50px;
}
@media only screen and (min-width: 1025px) {
  .openingBox {
    grid-template-columns: 45% auto;
  }
}
@media only screen and (max-width: 1024px) {
  .openingBox {
    margin-top: -50px;
    margin-bottom: 40px;
    border-radius: 20px;
  }
}
.openingBox__detail {
  position: relative;
  padding: 65px 80px;
}
@media only screen and (max-width: 1024px) {
  .openingBox__detail {
    padding: 20px 80px 20px 20px;
  }
}
.openingBox__title {
  margin-top: 10px;
  font-size: 33px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .openingBox__title {
    margin-top: 5px;
    font-size: 22px;
  }
}
.openingBox__title._en {
  position: relative;
  display: inline-block;
  padding-right: calc(85px + 1em);
  font-size: 22px;
  font-weight: normal;
}
@media only screen and (max-width: 767px) {
  .openingBox__title._en {
    font-size: 16px;
  }
}
.openingBox__title._en::after {
  position: absolute;
  top: 50%;
  right: 0;
  width: 85px;
  height: 1px;
  content: "";
  background: #fac44c;
  transform: translateY(-50%);
}
.openingBox__text {
  margin-top: 15px;
  margin-top: 5px;
}
.openingBox__more {
  margin-top: 80px;
}
.openingBox__more a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  font-size: 18px;
  font-weight: bold;
  background: #fff;
  border: 1px solid #e8e5e3;
  border-radius: 50%;
}
@media only screen and (max-width: 1024px) {
  .openingBox__more {
    position: absolute;
    right: 20px;
    bottom: 20px;
    margin-top: 0;
  }
  .openingBox__more a {
    width: 35px;
    height: 35px;
    font-size: 12px;
  }
}
.openingBox__img {
  position: relative;
}
.openingBox__img::before {
  display: block;
  padding-top: 45%;
  content: "";
}
.openingBox__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: left top;
     object-position: left top;
}

.workCard__img {
  position: relative;
  height: 250px;
  overflow: hidden;
  border-radius: 20px;
}
.workCard__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.workCard__depart {
  padding-right: 65px;
  margin-top: 20px;
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .workCard__depart {
    font-size: 14px;
  }
}
.workCard__title {
  padding-right: 65px;
  padding-bottom: 20px;
  font-size: 25px;
  font-weight: bold;
  background: url(../img/common/icon_arrow.svg) no-repeat top 10px right 10px/45px 45px;
}
@media only screen and (min-width: 768px) {
  .workCard__title {
    min-height: 55px;
  }
}
@media only screen and (max-width: 767px) {
  .workCard__title {
    padding-right: 35px;
    font-size: 16px;
    background-position: top 10px right;
    background-size: 25px 25px;
  }
}

.shop__main-title {
  margin-top: 60px;
  font-size: 33px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .shop__main-title {
    font-size: 28px;
  }
}
.shop__sub-title {
  margin-top: 20px;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .shop__sub-title {
    font-size: 18px;
  }
}
.shopCard__img {
  margin-bottom: 20px;
  border-radius: 20px;
}
@media only screen and (max-width: 767px) {
  .shopCard__img {
    margin-bottom: 10px;
  }
}
.shop__title {
  margin-top: 20px;
  font-size: 26px;
  font-weight: bold;
  text-align: center;
}
.shop__title span {
  padding-right: 0.5em;
  font-size: 18px;
  font-weight: normal;
}
@media only screen and (max-width: 767px) {
  .shop__title {
    margin-top: 10px;
    font-size: 22px;
  }
  .shop__title span {
    font-size: 16px;
  }
}

.label {
  text-align: center;
}
.label span {
  display: inline-block;
  padding: 1px 30px;
  font-size: 20px;
  font-weight: bold;
  border: 1px solid #333;
  border-radius: 20px;
}
@media only screen and (max-width: 1024px) {
  .label span {
    padding: 0 20px;
    font-size: 16px;
  }
}

.shopList {
  display: grid;
  gap: 180px;
  padding-bottom: 80px;
  border-bottom: 1px solid #333;
}
@media only screen and (max-width: 767px) {
  .shopList {
    gap: 80px;
  }
}
.shopList__thumbnail {
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  .shopList__thumbnail {
    margin-top: 20px;
  }
}
.shopList__top {
  padding: 40px 0;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
@media only screen and (max-width: 767px) {
  .shopList__top {
    padding: 30px 0;
  }
}
.shopList__detail {
  margin-top: 50px;
}
@media only screen and (max-width: 767px) {
  .shopList__detail {
    margin-top: 20px;
  }
}
.shopList__text {
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .shopList__text {
    font-size: 14px;
  }
}
.shopList__time {
  margin-top: 100px;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .shopList__time {
    margin-top: 50px;
    font-size: 16px;
  }
}
.shopList__others {
  margin-top: 80px;
  font-size: 36px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .shopList__others {
    margin-top: 50px;
    font-size: 20px;
  }
}
.shopList__btn {
  margin-top: 50px;
}

.logoList {
  display: flex;
  gap: 0 60px;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  padding-right: 30px;
}
.logoListWrap {
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .logoList {
    gap: 0 30px;
  }
}
.logoList__item img {
  width: auto;
  max-width: none;
}
@media only screen and (max-width: 767px) {
  .logoList__item img {
    height: 50px;
  }
}

.supportList {
  display: grid;
  gap: 30px;
  margin-top: 50px;
}
@media only screen and (min-width: 1025px) {
  .supportList {
    grid-template-columns: repeat(3, 1fr);
  }
}
.supportList__img {
  position: relative;
  margin-bottom: 20px;
  overflow: hidden;
  border-radius: 20px;
}
.supportList__img::before {
  display: block;
  padding-top: 55%;
  content: "";
}
.supportList__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.supportList__num {
  position: absolute;
  top: 20px;
  left: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 70px;
  height: 70px;
  font-size: 20px;
  background: #fff;
  border: 1px solid #333;
  border-radius: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 767px) {
  .supportList__num {
    width: 50px;
    height: 50px;
    font-size: 18px;
  }
}
.supportList__item {
  position: relative;
  padding: 50px 25px;
  background: #fff;
  border: 1px solid #4d4d4d;
  border-radius: 20px;
}
.supportList__title {
  font-size: 30px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .supportList__title {
    font-size: 21px;
  }
}
.supportList__text {
  margin-top: 20px;
}
.supportList__text span {
  color: #fac44c;
}

.foodProductList {
  display: grid;
  gap: 150px 4%;
}
@media only screen and (min-width: 768px) {
  .foodProductList {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media only screen and (max-width: 767px) {
  .foodProductList {
    gap: 70px;
  }
}
.foodProductList__maker {
  position: relative;
  padding: 10px 20px 10px 0;
}
.foodProductList__maker:hover {
  cursor: pointer;
}
._open .foodProductList__maker::after {
  transform: translateY(-50%) rotate(180deg);
}
.foodProductList__maker::after {
  position: absolute;
  top: 50%;
  right: 10px;
  font-size: 16px;
  content: "▼";
  transition: all 0.3s ease 0s;
  transform: translateY(-50%);
}
.foodProductList__makerList._open .foodMakerList__item {
  display: block;
}
.foodProductList__img {
  position: relative;
  margin-bottom: 20px;
}
.foodProductList__img::before {
  display: block;
  padding-top: 50%;
  content: "";
}
.foodProductList__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.foodProductList__item {
  display: flex;
  flex-direction: column;
}
.foodProductList__title {
  justify-content: center;
  font-size: 23px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .foodProductList__title {
    min-height: 81px;
  }
}
@media only screen and (max-width: 767px) {
  .foodProductList__title {
    font-size: 22px;
  }
}
.foodProductList__text {
  display: flex;
  padding-bottom: 10px;
  margin-top: 10px;
  border-bottom: 1px solid #000;
}
@media only screen and (min-width: 768px) {
  .foodProductList__text {
    min-height: 140px;
  }
}
.foodMakerList__item {
  display: none;
}

.businessProduct__title {
  margin-top: 200px;
  font-size: 27px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .businessProduct__title {
    margin-top: 80px;
    font-size: 22px;
  }
}

.businessProduct__text {
  margin-top: 10px;
}

.machineList {
  display: grid;
  gap: 60px;
  padding-bottom: 100px;
  margin-top: 50px;
}
.machineListWrap {
  margin-bottom: 30px;
  border-bottom: 1px solid #333;
}
.machineListWrap .heading03 {
  padding-top: 100px;
}
.machineListWrap .heading03:not(:first-child) {
  border-top: 0.5px solid #333;
}
@media only screen and (max-width: 767px) {
  .machineListWrap .heading03 {
    padding-top: 50px;
  }
}
@media only screen and (min-width: 768px) {
  .machineList {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media only screen and (max-width: 767px) {
  .machineList {
    padding-bottom: 50px;
  }
}
.machineList__item {
  display: flex;
  flex-direction: column;
}
.machineList__img {
  position: relative;
}
@media only screen and (min-width: 768px) {
  .machineList__img {
    max-height: 250px;
  }
}
@media only screen and (max-width: 767px) {
  .machineList__img {
    max-height: 150px;
  }
}
.machineList__img::before {
  display: block;
  padding-top: 81.9672%;
  content: "";
}
.machineList__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.machineList__title {
  justify-content: center;
  margin-top: 20px;
  font-size: 27px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .machineList__title {
    min-height: 95px;
  }
}
@media only screen and (max-width: 767px) {
  .machineList__title {
    font-size: 22px;
  }
}
.machineList__text {
  display: flex;
  flex: 1 0 auto;
}

.originalMachine__heading {
  margin-top: 100px;
  font-size: 33px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .originalMachine__heading {
    margin-top: 50px;
    font-size: 22px;
  }
}
.originalMachineList {
  display: grid;
  gap: 60px;
  margin-top: 80px;
}
@media only screen and (min-width: 768px) {
  .originalMachineList {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media only screen and (max-width: 767px) {
  .originalMachineList {
    margin-top: 40px;
  }
}
.originalMachineList__img {
  position: relative;
}
@media only screen and (min-width: 768px) {
  .originalMachineList__img {
    height: 300px;
  }
}
.originalMachineList__img::before {
  display: block;
  padding-top: 70%;
  content: "";
}
.originalMachineList__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.originalMachineList__title {
  margin-top: 30px;
  font-size: 27px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .originalMachineList__title {
    margin-top: 10px;
    font-size: 22px;
  }
}
.originalMachineList__text {
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  .originalMachineList__text {
    margin-top: 10px;
  }
}

.serviceList {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
  margin-top: 20px;
  margin-bottom: 120px;
}
@media only screen and (max-width: 1024px) {
  .serviceList {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-bottom: 60px;
  }
}
.serviceList__item {
  padding: 20px;
  background: #fff;
  border-radius: 25px;
  box-shadow: 0 0 5px 0 rgba(99, 99, 99, 0.75);
}
@media only screen and (max-width: 767px) {
  .serviceList__item {
    padding: 20px 15px;
  }
}
.serviceList__item._machine {
  background: #736357;
}
.serviceList__img {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
}
.serviceList__img::before {
  display: block;
  padding-top: 100%;
  content: "";
}
.serviceList__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.serviceList__title {
  margin-top: 20px;
  font-size: 30px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .serviceList__title {
    font-size: 16px;
  }
}
.serviceList__title span {
  padding-right: 0.5em;
  font-size: 22px;
}
@media only screen and (max-width: 767px) {
  .serviceList__title span {
    font-size: 12px;
  }
}
._machine .serviceList__title {
  color: #fff;
}
.serviceList__text {
  margin-top: 20px;
}
._machine .serviceList__text {
  color: #fff;
}

.retailList {
  display: grid;
  gap: 60px;
  margin-top: 20px;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  .retailList {
    grid-template-columns: repeat(3, 1fr);
    padding: 40px;
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 0 5px 0 rgba(99, 99, 99, 0.75);
  }
}
@media only screen and (max-width: 767px) {
  .retailList {
    gap: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .retailList__item {
    padding: 20px;
    background: #fff;
    border-radius: 20px;
  }
}
.retailList__img {
  border-radius: 40px;
}
.retailList__title {
  margin-top: 10px;
  font-size: 30px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .retailList__title {
    font-size: 18px;
    text-align: center;
  }
}
.retailList__title span {
  padding-right: 5px;
  font-size: 22px;
}
@media only screen and (max-width: 767px) {
  .retailList__title span {
    font-size: 12px;
  }
}

.sustainabilityList {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  margin-top: 80px;
}
@media only screen and (max-width: 767px) {
  .sustainabilityList {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}
.sustainabilityList__item {
  padding: 40px 20px;
  border-radius: 20px;
  box-shadow: 0 0 5px 0 rgba(99, 99, 99, 0.75);
}
@media only screen and (max-width: 767px) {
  .sustainabilityList__item {
    padding: 20px 10px;
  }
}
.sustainabilityList__img {
  position: relative;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: 768px) {
  .sustainabilityList__img {
    width: 70%;
    height: 180px;
  }
}
.sustainabilityList__img::before {
  display: block;
  padding-top: 94.736%;
  content: "";
}
.sustainabilityList__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.sustainabilityList__title {
  margin-top: 40px;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sustainabilityList__title {
    font-size: 16px;
  }
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  align-items: flex-end;
  width: 100%;
  background: #fff;
}
.header__inner {
  display: flex;
  align-items: flex-end;
  width: 100%;
  max-width: 1810px;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: 1025px) {
  .header__inner {
    padding-top: 50px;
    padding-right: 20px;
    padding-bottom: 20px;
    padding-left: 20px;
  }
}
@media only screen and (max-width: 1024px) {
  .header__inner {
    display: block;
  }
}
.header__logo {
  width: 28.333%;
  max-width: 510px;
}
@media only screen and (max-width: 1024px) {
  .header__logo {
    width: 100px;
    margin: 10px auto;
  }
}
.headerList {
  display: flex;
  justify-content: right;
  width: 100%;
  margin-left: auto;
}
@media only screen and (max-width: 1024px) {
  .headerList {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid #808080;
    border-bottom: 1px solid #808080;
  }
}
@media only screen and (min-width: 1025px) {
  .headerList._forFooter {
    display: none;
  }
}
.headerList__item {
  position: static;
}
@media only screen and (min-width: 1025px) {
  .headerList__item:not(:first-child) {
    margin-left: 2.5%;
  }
}
@media only screen and (max-width: 1024px) {
  .headerList__item:not(:nth-child(3n+1)) {
    border-left: 1px solid #808080;
  }
}
@media only screen and (max-width: 1024px) {
  .headerList__item:nth-child(n+4) {
    border-top: 1px solid #808080;
  }
}
@media only screen and (min-width: 1025px) {
  .headerList__item._order {
    position: relative;
    margin-left: 40px;
  }
  .headerList__item._order::before {
    position: absolute;
    top: 50%;
    left: -20px;
    width: 1px;
    height: 20px;
    content: "";
    background: #333;
    transform: translateY(-50%);
  }
}
@media only screen and (max-width: 1024px) {
  .headerList__item._order {
    position: absolute;
    top: -40px;
    right: 10px;
    border: 1px solid #808080;
    border-radius: 50px;
  }
  .headerList__item._order a {
    padding: 5px 10px;
    font-size: 10px;
  }
}
.headerList__item a {
  position: relative;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.1em;
  transition: all 0.3s ease 0s;
}
@media only screen and (max-width: 1024px) {
  .headerList__item a {
    display: block;
    padding: 10px 5px;
    font-size: 12px;
    text-align: center;
  }
}
@media only screen and (min-width: 1025px) {
  .headerList__item a::after {
    position: absolute;
    bottom: -10px;
    left: 0;
    width: 100%;
    height: 4px;
    content: "";
    background: #fac44c;
    opacity: 0;
    transition: all 0.3s ease 0s;
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1280px) {
  .headerList__item a {
    font-size: 16px;
  }
}
.headerList__item a:hover {
  opacity: 0.7;
}
.headerList__item a:hover::after {
  opacity: 1;
}
.company .headerList__item._company a::after {
  opacity: 1;
}
.service .headerList__item._service a::after {
  opacity: 1;
}
.contact .headerList__item._contact a::after {
  opacity: 1;
}
.recruit .headerList__item._recruit a::after {
  opacity: 1;
}
.sustainability .headerList__item._sustainability a::after {
  opacity: 1;
}
.news .headerList__item._news a::after {
  opacity: 1;
}
.order .headerList__item._order a::after {
  opacity: 1;
}
.headerSubList {
  display: flex;
  width: 100%;
  max-width: 1850px;
  padding: 20px 20px 10px;
  margin-right: auto;
  margin-left: auto;
  background: #fac44c;
  transition: all 0.3s ease 0s;
}
@media only screen and (min-width: 1025px) {
  .headerSubList.under_tab {
    display: none;
  }
}
.headerSubListWrap {
  display: none;
}
@media only screen and (min-width: 1025px) {
  .company .headerSubListWrap._company {
    display: block;
  }
  .service .headerSubListWrap._service {
    display: block;
  }
  .sustainability .headerSubListWrap._sustainability {
    display: block;
  }
  .recruit .headerSubListWrap._recruit {
    display: block;
  }
}
@media only screen and (max-width: 1024px) {
  .headerSubList {
    position: absolute;
    top: 46px;
    left: 0;
    z-index: 10;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    width: 100vw;
    padding: 0;
    padding: 20px 20px;
    pointer-events: none;
    background: rgba(255, 255, 255, 0.9);
    border-top: 1px solid #fac44c;
    opacity: 0;
    transition: all 0.3s ease 0s;
    transform: none;
  }
  .headerSubList._sustainability, .headerSubList._recruit {
    top: 88px;
  }
}
._clicked .headerSubList {
  pointer-events: auto;
  opacity: 1;
}
@media only screen and (min-width: 1025px) {
  .headerSubList__item:not(:first-child) {
    margin-left: 30px;
  }
}
.headerSubList__item a {
  position: relative;
  display: block;
  padding-bottom: 10px;
  font-size: 16px;
  font-weight: bold;
}
@media only screen and (max-width: 1024px) {
  .headerSubList__item a {
    font-size: 12px;
    border: 1px solid #fac44c;
    border-radius: 50px;
  }
}
@media only screen and (min-width: 1025px) {
  .headerSubList__item a::after {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 4px;
    content: "";
    background: #fff;
    opacity: 0;
    transition: all 0.3s ease 0s;
  }
  .headerSubList__item a:hover::after {
    opacity: 1 !important;
  }
}
@media only screen and (min-width: 1025px) {
  .company .headerSubList._company {
    pointer-events: auto;
    opacity: 1;
  }
  .company .headerSubList._company a::after {
    opacity: 0;
  }
  .service .headerSubList._service {
    pointer-events: auto;
    opacity: 1;
  }
  .service .headerSubList._service a::after {
    opacity: 0;
  }
  .sustainability .headerSubList._sustainability {
    pointer-events: auto;
    opacity: 1;
  }
  .sustainability .headerSubList._sustainability a::after {
    opacity: 0;
  }
  .recruit .headerSubList._recruit {
    pointer-events: auto;
    opacity: 1;
  }
  .recruit .headerSubList._recruit a::after {
    opacity: 0;
  }
}

@media only screen and (max-width: 1024px) {
  .outside {
    position: absolute;
    top: calc(100% - 4px);
    left: 50%;
    z-index: 1001;
    width: 18px;
    height: 10px;
    -webkit-clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
            clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
    background: #fac44c;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
    transform: translateX(-50%);
  }
  ._clicked .outside {
    opacity: 1;
  }
  ._clicked .outside .inside {
    opacity: 1;
  }
  .outside .inside {
    position: absolute;
    top: 1px;
    right: 1px;
    bottom: 0;
    left: 1px;
    -webkit-clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
            clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
    background: #fff;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
  }
}
.footer {
  background: #fdbc59;
}
.footer a {
  transition: all 0.3s ease 0s;
}
.footer a:hover {
  opacity: 0.7;
}
.footer__inner {
  display: flex;
  max-width: 1240px;
  padding: 120px 20px 140px;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (max-width: 1024px) {
  .footer__inner {
    display: block;
    padding: 30px 20px 60px;
  }
}
@media only screen and (max-width: 1024px) {
  .footer__info {
    display: flex;
    flex-direction: column;
    margin-bottom: 30px;
    text-align: center;
  }
}
.footer__logo {
  max-width: 220px;
}
@media only screen and (max-width: 1024px) {
  .footer__logo {
    order: 3;
    margin-top: 20px;
    margin-right: auto;
    margin-left: auto;
  }
}
.footer__address {
  margin-top: 20px;
  font-weight: bold;
}
@media only screen and (max-width: 1024px) {
  .footer__address {
    order: 4;
  }
}
.footerExLink {
  display: flex;
  align-items: center;
  margin-top: 20px;
}
@media only screen and (max-width: 1024px) {
  .footerExLink {
    justify-content: center;
    order: 1;
  }
}
.footerExLink ._line {
  width: 42px;
}
.footerExLink ._youtube {
  width: 37px;
  margin-left: 20px;
}
.footer__privacy {
  margin-top: 30px;
}
@media only screen and (max-width: 1024px) {
  .footer__privacy {
    order: 2;
  }
}
.footer__copy {
  margin-top: 10px;
  font-size: 13px;
}
@media only screen and (max-width: 1024px) {
  .footer__copy {
    order: 5;
  }
}
.footerLinkListWrap {
  display: flex;
}
@media only screen and (max-width: 1024px) {
  .footerLinkListWrap {
    display: none;
  }
}
.footerLinkList:nth-child(1) {
  margin-left: 120px;
}
@media only screen and (max-width: 1024px) {
  .footerLinkList:nth-child(1) {
    margin-left: 0;
  }
}
.footerLinkList:nth-child(2) {
  margin-left: 70px;
}
.footerLinkList:nth-child(3) {
  margin-left: 60px;
}
.footerLinkList__item {
  margin-bottom: 10px;
  font-size: 27px;
  font-weight: bold;
}
.footerLinkList__item:not(._anchor) a {
  position: relative;
  padding-bottom: 5px;
}
.footerLinkList__item:not(._anchor) a::after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  content: "";
  background: #fff;
}
.footerLinkList__item._anchor {
  font-size: 18px;
  font-weight: normal;
}

.policy__main {
  margin-top: 80px;
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .policy__main {
    margin-top: 60px;
    font-size: 14px;
  }
}
.policy__title {
  margin-top: 60px;
  font-size: 20px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .policy__title {
    margin-top: 45px;
    font-size: 16px;
  }
}
.policy__text {
  margin-top: 20px;
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .policy__text {
    font-size: 14px;
  }
}

.newsList {
  margin-top: 80px;
}
@media only screen and (max-width: 767px) {
  .newsList {
    margin-top: 60px;
  }
}
.newsList__item {
  display: flex;
  align-items: flex-start;
  padding: 25px 0;
  border-bottom: 0.25px solid #051d53;
}
@media only screen and (max-width: 767px) {
  .newsList__item {
    display: block;
    padding: 20px 0;
  }
}
.news__date {
  color: #808080;
  white-space: nowrap;
}
@media only screen and (min-width: 768px) {
  .news__title {
    margin-left: 50px;
  }
}
@media only screen and (max-width: 767px) {
  .news__title {
    margin-top: 5px;
  }
}
.newsDetailWrap {
  display: grid;
  gap: 50px;
  margin-top: 100px;
}
@media only screen and (min-width: 768px) {
  .newsDetailWrap {
    grid-template-columns: 4fr 1fr;
  }
}
@media only screen and (max-width: 767px) {
  .newsDetailWrap {
    gap: 100px;
    margin-top: 60px;
  }
}
.newsDetail__thumbnail {
  margin-bottom: 50px;
  text-align: center;
}
.newsDetail__title {
  padding-bottom: 20px;
  font-size: 33px;
  font-weight: bold;
  border-bottom: 1px solid #051d53;
}
.newsDetail__date {
  margin-top: 20px;
  color: #808080;
}
.newsDetail__inner h1 {
  font-size: 32px;
  font-weight: bold;
}
.newsDetail__inner h2 {
  font-size: 28px;
  font-weight: bold;
}
.newsDetail__inner h3 {
  font-size: 24px;
  font-weight: bold;
}
.newsDetail__inner h4 {
  font-size: 20px;
  font-weight: bold;
}
.newsDetail__inner a {
  text-decoration: underline;
}

.newsDetail__inner a:hover {
  color: #fac44c;
  text-decoration: none;
}

.newsDetail__inner p {
  margin-top: 30px;
}
.newsCatList {
  display: flex;
}
@media only screen and (min-width: 768px) {
  .newsCatList {
    width: 80%;
  }
}
.newsCatListWrap {
  display: flex;
  align-items: center;
  margin-top: 70px;
}
@media only screen and (max-width: 767px) {
  .newsCatListWrap {
    display: block;
    margin-top: 40px;
  }
}
@media only screen and (max-width: 767px) {
  .newsCatList {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-top: 10px;
  }
}
.newsCatList__title {
  font-size: 18px;
}
@media only screen and (min-width: 768px) {
  .newsCatList__title {
    width: 20%;
  }
}
@media only screen and (min-width: 768px) {
  .newsCatList__item {
    width: 25%;
  }
}
@media only screen and (min-width: 768px) {
  .newsCatList__item:not(:first-child) {
    margin-left: 10px;
  }
}
.newsCatList__item .btn {
  padding: 4px;
}
.newsCatList__item .btn span {
  font-weight: normal;
  color: #808080;
}

@media only screen and (min-width: 768px) {
  .sidebar__content {
    position: sticky;
    top: 130px;
  }
}
.sidebar__title {
  padding-bottom: 5px;
  margin-bottom: 10px;
  font-weight: bold;
  border-bottom: 1px solid #808080;
}
.sidebar__title:not(:first-child) {
  margin-top: 30px;
}
.sidebarList__item {
  margin-top: 15px;
}
.sidebarList__item a {
  color: #808080;
}
._article .sidebarList__item {
  padding: 10px 0;
  border-bottom: 1px solid #808080;
}

.company__logo {
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  width: 250px;
}

.companySlide__wrap {
  display: flex;
  padding: 10px 0;
  margin-top: 50px;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .companySlide__wrap {
    margin-top: 30px;
  }
}
.companySlideList {
  display: flex;
  animation: infinity-scroll-left 80s infinite linear 0.5s both;
}
.companySlideList__item {
  width: 12.5vw;
  margin: 0 10px;
}
.companySlideList__item:nth-child(odd) {
  animation: upDown01 8s linear infinite;
}
.companySlideList__item:nth-child(even) {
  animation: upDown02 8s linear infinite;
}
@media only screen and (max-width: 767px) {
  .companySlideList__item {
    width: 33.3333333333vw;
  }
}

@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes upDown01 {
  0% {
    transform: translateY(0);
  }
  25% {
    transform: translateY(10px);
  }
  50% {
    transform: translateY(0);
  }
  75% {
    transform: translateY(-10px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes upDown02 {
  0% {
    transform: translateY(0);
  }
  25% {
    transform: translateY(-10px);
  }
  50% {
    transform: translateY(0);
  }
  75% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
.historyBg {
  position: absolute;
  z-index: 1;
}
.historyBg._01 {
  top: 120px;
  left: 0;
  width: 39.4%;
}
@media only screen and (max-width: 767px) {
  .historyBg._01 {
    position: relative;
    top: 0;
    width: 100%;
    margin-bottom: 50px;
  }
}
.historyBg._02 {
  top: 500px;
  right: 0;
  width: 31.227%;
}
@media only screen and (max-width: 767px) {
  .historyBg._02 {
    display: none;
  }
}
.historyBg._03 {
  top: 900px;
  left: 200px;
  width: 20.954%;
}
@media only screen and (max-width: 767px) {
  .historyBg._03 {
    display: none;
  }
}
.historyBg._04 {
  top: 1000px;
  right: 400px;
  width: 8.5%;
}
@media only screen and (max-width: 767px) {
  .historyBg._04 {
    display: none;
  }
}
.historyBg._05 {
  top: 1200px;
  right: 300px;
  width: 8.5%;
}
@media only screen and (max-width: 767px) {
  .historyBg._05 {
    display: none;
  }
}

.sdgsList {
  background: #f2ece5;
}
.sdgs__work__title {
  margin-bottom: 20px;
  font-size: 30px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .sdgs__work__title {
    margin-bottom: 10px;
    font-size: 18px;
  }
}
.sdgsFlow__Toptext {
  margin-top: 70px;
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .sdgsFlow__Toptext {
    margin-top: 40px;
    font-size: 16px;
  }
}
.sdgsFlow__Toptitle {
  margin-top: 80px;
  font-size: 27px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sdgsFlow__Toptitle {
    margin-top: 40px;
    font-size: 22px;
  }
}
.sdgsFlowList {
  margin-top: 80px;
}
.sdgsFlowList__item {
  display: flex;
}
@media only screen and (max-width: 767px) {
  .sdgsFlowList__item {
    display: block;
    padding-top: 25px;
    border-top: 1px solid #4d4d4d;
  }
}
.sdgsFlow__num {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 120px;
  margin-right: 30px;
  font-size: 34px;
  font-weight: bold;
  border: 1px solid #4d4d4d;
  border-radius: 50%;
}
@media only screen and (min-width: 768px) {
  .sdgsFlow__num {
    min-width: 120px;
  }
}
@media only screen and (max-width: 767px) {
  .sdgsFlow__num {
    position: relative;
    width: 60px;
    height: 60px;
    margin-right: auto;
    margin-left: auto;
  }
}
.sdgsFlow__contents {
  display: flex;
  align-items: flex-start;
  padding: 50px 60px 50px 30px;
}
@media only screen and (min-width: 768px) {
  .sdgsFlow__contents:has(.sdgsLogo) .sdgsFlow__detail {
    width: 65%;
  }
}
.sdgsFlow__contents._border {
  border-bottom: 1px solid #4d4d4d;
}
@media only screen and (min-width: 768px) {
  .sdgsFlow__contents {
    border-top: 1px solid #4d4d4d;
  }
}
@media only screen and (max-width: 1024px) {
  .sdgsFlow__contents {
    display: block;
    padding: 25px 20px 25px 20px;
  }
}
.sdgsFlow__title {
  font-size: 27px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .sdgsFlow__title {
    font-size: 22px;
  }
}
.sdgsFlow__text {
  margin-top: 40px;
}
@media only screen and (max-width: 767px) {
  .sdgsFlow__text {
    margin-top: 20px;
  }
}
.sdgsFlow__text .support {
  position: relative;
  display: block;
  padding-left: 45px;
  margin-top: 10px;
  margin-bottom: 10px;
  color: #fac44c;
}
.sdgsFlow__text .support::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 40px;
  height: 35px;
  content: "";
  background: url(../img/common/logo.svg) no-repeat center center/contain;
  transform: translateY(-50%);
}
.sdgsLogo {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
@media only screen and (min-width: 768px) {
  .sdgsLogo {
    margin-left: 30px;
  }
}
@media only screen and (max-width: 1024px) {
  .sdgsLogo {
    margin-top: 30px;
  }
}
.sdgsLogo._col-3 {
  grid-template-columns: repeat(3, 1fr);
}
@media only screen and (min-width: 768px) {
  .sdgsLogo__img {
    width: 120px;
    height: 120px;
  }
}
.sdgsAttemptList__item {
  margin-top: 150px;
}
@media only screen and (max-width: 767px) {
  .sdgsAttemptList__item {
    margin-top: 60px;
  }
}
.sdgsAttemptBox {
  padding: 80px 20px;
  background: #f2ece5;
}
@media only screen and (max-width: 767px) {
  .sdgsAttemptBox {
    padding: 60px 20px;
  }
}
.sdgsAttemptBox__text {
  margin-top: 20px;
  font-size: 27px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sdgsAttemptBox__text {
    font-size: 20px;
  }
}
.sdgsAttempt__title {
  margin-top: 50px;
  font-size: 27px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .sdgsAttempt__title {
    font-size: 20px;
  }
}
.sdgsAttempt__detail {
  display: grid;
  gap: 30px;
}
@media only screen and (min-width: 768px) {
  .sdgsAttempt__detail {
    grid-template-columns: 1fr 1fr;
    margin-top: 30px;
  }
}
@media only screen and (min-width: 768px) {
  .sdgsAttempt__images {
    display: flex;
  }
}
.sdgsAttempt__subImg {
  margin-top: 20px;
}
@media only screen and (min-width: 768px) {
  .sdgsAttempt__subImg:nth-child(2) {
    margin-left: 10px;
  }
}
.sdgsAttempt__subImg p {
  display: block;
  margin-top: 10px;
  font-size: 13px;
}
.sdgsAttempt__img {
  max-width: 400px;
  margin-top: 50px;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (max-width: 767px) {
  .sdgsAttempt__img {
    width: 70%;
    margin-top: 30px;
  }
}
.sdgsAttempt__text:not(:first-child) {
  margin-top: 30px;
}

.contact__title {
  font-size: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .contact__title {
    font-size: 24px;
  }
}
.contact__text {
  margin-top: 50px;
  font-size: 20px;
}
@media only screen and (max-width: 767px) {
  .contact__text {
    font-size: 16px;
  }
}
.contact__text a {
  color: #333;
}
.contact__flow {
  margin-bottom: 30px;
}
.contact__flow span {
  padding-bottom: 5px;
  border-bottom: 4px solid #fac44c;
}
.contact__attention {
  margin-top: 20px;
  font-size: 20px;
  font-weight: bold;
  color: #c22033;
}
@media only screen and (max-width: 767px) {
  .contact__attention {
    font-size: 18px;
  }
}

.sendBox {
  padding: 30px;
  margin-top: 30px;
  font-size: 20px;
  background: #f5f5f5;
}
@media only screen and (max-width: 767px) {
  .sendBox {
    padding: 30px 20px;
    font-size: 16px;
  }
}

.radiolist {
  max-width: 600px;
}
.radiolist + .radiolist {
  margin-top: 30px;
}
.radiolist__title {
  margin-bottom: 15px;
}
.radiolist__link {
  display: block;
  margin-top: 15px;
  font-weight: bold;
}
.radiolist__item {
  line-height: 1;
}
.radiolist__itemWrap {
  display: grid;
  gap: 10px;
}
@media only screen and (min-width: 1025px) {
  .radiolist__itemWrap {
    grid-template-columns: repeat(2, 1fr);
  }
}
.radiolist__item label {
  display: inline-flex;
  align-items: center;
  vertical-align: middle;
  cursor: pointer;
}
@media only screen and (max-width: 767px) {
  .radiolist__item label {
    display: flex;
  }
}
.radiolist__text {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: auto;
  cursor: pointer;
}
.radiolist__text::before {
  width: 20px;
  height: 20px;
  margin-right: 10px;
  content: "";
  border: 1px solid #b4b4b4;
  border-radius: 50%;
}
.radiolist__text::after {
  position: absolute;
  top: 50%;
  left: 5px;
  width: 10px;
  height: 10px;
  content: "";
  background: #c22033;
  border-radius: 50%;
  opacity: 0;
  transform: translateY(-50%);
}
:checked + .radiolist__text::after {
  opacity: 1;
}

.confirmBtn,
.sendBtn {
  margin-top: 80px;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .confirmBtn,
  .sendBtn {
    margin-top: 40px;
  }
}
.confirmBtn button,
.sendBtn button {
  display: flex;
  display: inline-block;
  justify-content: center;
  width: 100%;
  max-width: 400px;
  padding: 27px 20px;
  font-size: 27px;
  font-weight: bold;
  color: #000;
  text-align: center;
  border: 1px solid #636363;
  border-radius: 100px;
}
@media only screen and (max-width: 767px) {
  .confirmBtn button,
  .sendBtn button {
    padding: 10px;
    font-size: 20px;
  }
}
.confirmBtn button span,
.sendBtn button span {
  position: relative;
  padding-left: 2em;
  color: #000;
}
.confirmBtn button span::before,
.sendBtn button span::before {
  position: absolute;
  top: 50%;
  left: 0;
  font-size: 31px;
  font-weight: bold;
  content: ">";
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .confirmBtn button span,
  .sendBtn button span {
    padding-left: 1em;
  }
  .confirmBtn button span::before,
  .sendBtn button span::before {
    font-size: 20px;
  }
}

@media only screen and (max-width: 767px) {
  .sendBtn {
    margin-top: 0;
  }
}
.sendBtn button {
  background: #fac44c;
}

.mv {
  position: relative;
  height: 650px;
  margin: 0 calc(50% - 50vw);
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  .mv {
    height: 300px;
  }
}
.mv._large {
  height: 750px;
}
@media only screen and (max-width: 1024px) {
  .mv._large {
    height: 300px;
  }
}
.mv._top img {
  -o-object-position: top;
     object-position: top;
}
.mv img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.mv__text {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  font-size: 40px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  text-shadow: 0 0 5px #666;
  transform: translate(-50%, -50%);
}
@media only screen and (max-width: 767px) {
  .mv__text {
    font-size: 22px;
  }
}

.work__img {
  overflow: hidden;
  border-radius: 20px;
}
.work__title {
  font-size: 40px;
  font-weight: bold;
  letter-spacing: 0.01em;
}
@media only screen and (max-width: 767px) {
  .work__title {
    font-size: 28px;
  }
}
.work__depart {
  margin-top: 40px;
  font-size: 22px;
}
@media only screen and (max-width: 767px) {
  .work__depart {
    margin-top: 20px;
    font-size: 15px;
  }
}
.work__name {
  margin-top: 10px;
  font-size: 35px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .work__name {
    font-size: 24px;
  }
}
.work__content {
  max-width: 1080px;
  margin-top: 80px;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: 768px) {
  .work__content {
    padding-right: 40px;
    padding-left: 40px;
  }
}
@media only screen and (max-width: 767px) {
  .work__content {
    margin-top: 40px;
  }
}
.workDetail__title {
  font-size: 33px;
  font-weight: bold;
}
.workDetail__title:not(:first-child) {
  margin-top: 60px;
}
@media only screen and (max-width: 767px) {
  .workDetail__title {
    font-size: 23px;
  }
}
.workDetail p {
  margin-top: 25px;
}
@media only screen and (max-width: 767px) {
  .workDetail p {
    margin-top: 20px;
  }
}
.workDetail table {
  margin-top: 25px;
}
@media only screen and (max-width: 767px) {
  .workDetail table {
    margin-top: 20px;
  }
}
.workDetail table tr th {
  font-weight: normal;
  text-align: right;
}
.workDetail table tr td {
  padding-left: 50px;
}
.workDetail img {
  display: block;
  width: 100%;
  max-width: 700px;
  margin: 50px auto 0;
  overflow: hidden;
  border-radius: 20px;
}
@media only screen and (max-width: 767px) {
  .workDetail img {
    margin-top: 25px;
  }
}
.workDetail .boom {
  display: grid;
  gap: 30px;
  align-items: center;
  margin-top: 25px;
}
@media only screen and (min-width: 768px) {
  .workDetail .boom {
    grid-template-columns: 250px 1fr;
  }
}
.workDetail .boom__img {
  position: relative;
  overflow: hidden;
  border-radius: 50%;
}
@media only screen and (max-width: 767px) {
  .workDetail .boom__img {
    width: 70%;
    margin-right: auto;
    margin-left: auto;
  }
}
.workDetail .boom__img::before {
  display: block;
  padding-top: 100%;
  content: "";
}
.workDetail .boom__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  margin: 0;
}
.recruit__title {
  margin-top: 80px;
  font-size: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .recruit__title {
    font-size: 22px;
  }
}
.recruit__text {
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  .recruit__text {
    margin-top: 10px;
  }
}

.searchResult {
  margin-top: 120px;
  margin-bottom: 20px;
  font-size: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .searchResult {
    margin-top: 60px;
    margin-bottom: 10px;
    font-size: 22px;
  }
}

.foodList {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 50px;
}
@media only screen and (max-width: 767px) {
  .foodList {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}
.foodList._search {
  padding: 80px 0;
  border-top: 0.5px solid #4d4d4d;
  border-bottom: 0.5px solid #4d4d4d;
}
.foodList__img {
  position: relative;
  overflow: hidden;
}
.foodList__img._round {
  border-radius: 50%;
}
.foodList__img::before {
  display: block;
  padding-top: 100%;
  content: "";
}
.foodList__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.foodList__name {
  margin-top: 20px;
  font-size: 27px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .foodList__name {
    margin-top: 10px;
    font-size: 18px;
  }
}

.feature {
  background: #f2ece5;
}
.feature__inner {
  display: grid;
  gap: 30px;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .feature__inner {
    grid-template-columns: 30% 1fr;
  }
}
@media only screen and (max-width: 767px) {
  .feature__inner {
    padding: 40px 20px;
  }
}
.feature__text {
  font-size: 22px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .feature__text {
    font-size: 18px;
  }
}

.original__title {
  padding: 40px 20px;
  font-size: 43px;
  font-weight: bold;
  text-align: center;
  background: #f2ece5;
}
@media only screen and (max-width: 767px) {
  .original__title {
    padding: 20px;
    font-size: 22px;
  }
}

.foodLabel {
  font-size: 27px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .foodLabel {
    font-size: 22px;
  }
}
.foodLabelList {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
  align-items: stretch;
  margin-top: 20px;
}
@media only screen and (max-width: 1024px) {
  .foodLabelList {
    grid-template-columns: repeat(3, 1fr);
  }
}
.foodLabelList__item a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 30px 5px;
  font-weight: bold;
  border: 1px solid #b7b7b7;
  border-radius: 10px;
}

.product {
  display: flex;
  gap: 80px;
  padding-bottom: 200px;
  border-bottom: 1px solid #4d4d4d;
}
@media only screen and (max-width: 1024px) {
  .product {
    display: block;
    padding-bottom: 100px;
  }
}
@media only screen and (min-width: 1025px) {
  .product__img-and-video {
    width: 40%;
  }
}
@media only screen and (max-width: 1024px) {
  .product__img-and-video {
    margin-top: 100px;
  }
}
.product__img {
  position: relative;
}
.product__img::before {
  display: block;
  padding-top: 100%;
  content: "";
}
.product__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.product__video {
  position: relative;
  margin-top: 20px;
}
.product__video::before {
  display: block;
  padding-top: 54.314%;
  content: "";
}
.product__video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media only screen and (min-width: 1025px) {
  .product__detail {
    width: 60%;
  }
}
.product__name {
  font-size: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 1024px) {
  .product__name {
    font-size: 24px;
  }
}
.product__text {
  margin-top: 30px;
  font-size: 20px;
}
@media only screen and (max-width: 1024px) {
  .product__text {
    margin-top: 20px;
    font-size: 18px;
  }
}
.productInfoList {
  margin-top: 80px;
  border-top: 0.5px solid #4d4d4d;
  border-bottom: 0.5px solid #4d4d4d;
}
@media only screen and (max-width: 1024px) {
  .productInfoList {
    margin-top: 60px;
  }
}
.productInfoList__item:not(:first-child) {
  border-top: 0.5px solid #4d4d4d;
}
.productInfoList__item dl {
  display: flex;
  font-size: 20px;
}
@media only screen and (max-width: 1024px) {
  .productInfoList__item dl {
    font-size: 16px;
  }
}
.productInfoList__item dl dt {
  width: 20%;
  padding: 40px 0;
  font-weight: bold;
}
@media only screen and (max-width: 1024px) {
  .productInfoList__item dl dt {
    width: 30%;
  }
}
@media only screen and (max-width: 767px) {
  .productInfoList__item dl dt {
    padding: 20px 0;
  }
}
.productInfoList__item dl dd {
  width: 80%;
  padding: 40px 0;
}
@media only screen and (max-width: 1024px) {
  .productInfoList__item dl dd {
    width: 70%;
  }
}
@media only screen and (max-width: 767px) {
  .productInfoList__item dl dd {
    padding: 20px 0;
  }
}

.productInfoList__item dl dd a {
  text-decoration: underline;
}

.productInfoList__item dl dd a:hover {
  color: #fac44c;
  text-decoration: none;
}


.delivery {
  display: grid;
  gap: 80px;
  margin-top: 80px;
}
@media only screen and (min-width: 768px) {
  .delivery {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (min-width: 768px) {
  .delivery__text {
    margin-top: 50px;
  }
}
.delivery__text span {
  color: #fac44c;
}
.delivery__text span a {
  color: #fac44c;
}

.testKitchen {
  margin-top: 50px;
  background: #fff;
  border: 1px solid #4d4d4d;
  border-radius: 20px;
}
.testKitchen__inner {
  padding: 80px 40px;
}
@media only screen and (max-width: 767px) {
  .testKitchen__inner {
    padding: 40px 20px;
  }
}
.testKitchen__title {
  font-size: 33px;
  font-weight: bold;
  text-align: center;
}
.testKitchen__title span {
  padding-left: 1em;
  font-size: 18px;
}
@media only screen and (max-width: 767px) {
  .testKitchen__title {
    font-size: 22px;
  }
}
.testKitchen__text {
  margin-top: 20px;
  text-align: center;
}
.testKitchenList {
  margin-top: 20px;
  margin-bottom: 40px;
}
.testKitchen__name {
  padding-bottom: 10px;
  margin-top: 10px;
  font-size: 20px;
  font-weight: bold;
  border-bottom: 1px solid #333;
}
.testKitchen__machine {
  padding-bottom: 10px;
  margin-top: 10px;
  border-bottom: 1px solid #333;
}
.testKitchen__machine dl dt {
  font-weight: bold;
}
.testKitchen__place {
  margin-top: 10px;
}
.testKitchen__place span {
  font-weight: bold;
}

.instrument__title {
  margin-top: 40px;
  font-size: 40px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .instrument__title {
    font-size: 20px;
  }
}
.instrument__img {
  margin-top: 40px;
}
.instrument__text {
  margin-top: 60px;
  margin-bottom: 60px;
  font-size: 33px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .instrument__text {
    margin-top: 30px;
    margin-bottom: 30px;
    font-size: 20px;
  }
}

.opening__title {
  margin-top: 80px;
  font-size: 33px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .opening__title {
    font-size: 24px;
  }
}
.opening__text {
  margin-top: 30px;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .opening__text {
    font-size: 18px;
  }
}
.openingFlow {
  display: grid;
}
@media only screen and (min-width: 768px) {
  .openingFlow {
    grid-template-columns: 30% 1fr;
    margin-top: 80px;
  }
}
.openingFlow__title {
  margin-top: 45px;
  font-size: 80px;
}
@media only screen and (max-width: 767px) {
  .openingFlow__title {
    font-size: 40px;
  }
}
@media only screen and (min-width: 768px) {
  .opening__btn {
    padding-right: 180px;
  }
}
@media only screen and (max-width: 767px) {
  .opening__btn {
    padding-bottom: 100px;
  }
}
.opening__btn a {
  position: relative;
}
.opening__btn a::after {
  position: absolute;
  top: -50px;
  right: -200px;
  z-index: -1;
  width: 180px;
  height: 180px;
  content: "";
  background: url(../img/common/icon_person.png) no-repeat center center/contain;
}
@media only screen and (max-width: 767px) {
  .opening__btn a::after {
    top: 80px;
    right: 0;
    left: 50%;
    width: 100px;
    height: 100px;
    transform: translateX(-50%);
  }
}

.exampleTop {
  padding: 40px 0;
  border-top: 1px solid #333;
  border-bottom: 1px solid #333;
}
@media only screen and (max-width: 767px) {
  .exampleTop {
    padding: 20px 0;
  }
}
.exampleTop__title {
  font-size: 40px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .exampleTop__title {
    font-size: 24px;
  }
}
.exampleTop__text {
  margin-top: 20px;
  font-size: 33px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .exampleTop__text {
    font-size: 20px;
  }
}
.exampleNum {
  margin-top: 80px;
  font-size: 33px;
  font-weight: bold;
}
.exampleNum span {
  padding-right: 1em;
  font-size: 86px;
  font-weight: normal;
}
@media only screen and (max-width: 767px) {
  .exampleNum {
    margin-top: 60px;
    font-size: 24px;
  }
  .exampleNum span {
    display: block;
    font-size: 36px;
  }
}
.example__img {
  margin-top: 20px;
}
.exampleList {
  margin-top: 120px;
}
@media only screen and (max-width: 767px) {
  .exampleList {
    margin-top: 60px;
  }
}
.exampleList__item {
  display: flex;
  gap: 40px;
}
.exampleList__item:nth-child(odd) {
  flex-direction: row-reverse;
}
.exampleList__item:not(:first-child) {
  margin-top: 60px;
}
@media only screen and (max-width: 767px) {
  .exampleList__item:not(:first-child) {
    margin-top: 40px;
  }
}
@media only screen and (max-width: 767px) {
  .exampleList__item {
    display: block;
  }
}
@media only screen and (min-width: 768px) {
  .exampleList__detail {
    width: 50%;
  }
}
.exampleList__title {
  font-weight: bold;
}
@media only screen and (min-width: 768px) {
  .exampleList__title {
    font-size: 20px;
  }
}
@media only screen and (min-width: 768px) {
  .exampleList__text {
    font-size: 20px;
  }
}
@media only screen and (min-width: 768px) {
  .exampleList__img {
    width: 50%;
  }
}
@media only screen and (max-width: 767px) {
  .exampleList__img {
    margin-top: 20px;
  }
}
.exampleShop {
  margin-top: 80px;
  border-top: 1px solid #333;
  border-bottom: 1px solid #333;
}
.exampleShop__inner {
  display: grid;
  padding: 40px 0;
}
@media only screen and (min-width: 768px) {
  .exampleShop__inner {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media only screen and (max-width: 767px) {
  .exampleShop__inner {
    gap: 20px;
  }
}
.exampleShop__img {
  max-width: 400px;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: 768px) {
  .exampleShop__detail {
    font-size: 20px;
  }
}
.exampleShop__profile {
  margin-bottom: 10px;
  font-weight: bold;
}
.exampleShop__name {
  margin-bottom: 10px;
  font-weight: bold;
}
.machineTabList {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: flex-end;
}
@media only screen and (max-width: 767px) {
  .machineTabList {
    padding: 0;
  }
}
.machineTabListWrap {
  position: relative;
  z-index: 2;
  margin: 100px 0;
}
@media only screen and (max-width: 767px) {
  .machineTabListWrap {
    margin: 50px 0 0 0;
  }
}
.machineTabListWrap::after {
  position: absolute;
  bottom: 0.1px;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 1px;
  content: "";
  background: #000;
}
.machineTabList__item {
  position: relative;
  z-index: 3;
  padding: 30px;
  text-align: center;
  background: #fff;
  border: 1px solid #000;
}
@media only screen and (max-width: 767px) {
  .machineTabList__item {
    padding: 10px 0;
  }
}
.machineTabList__item:nth-child(2), .machineTabList__item:nth-child(3) {
  border-left: none;
}
.machineTabList__item._active {
  padding-top: 40px;
  pointer-events: none;
  border-bottom: none;
}
@media only screen and (max-width: 767px) {
  .machineTabList__item._active {
    padding-top: 20px;
  }
}
.machineTabList__item._active::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: "";
  background: #fac44c;
}
.machineTabList__item a {
  font-size: 27px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .machineTabList__item a {
    font-size: 12px;
  }
}

.machineInfo__topTitle {
  font-size: 33px;
  font-weight: bold;
  text-align: center;
}
.machineInfo__topTitle span {
  display: block;
  font-size: 40px;
}
@media only screen and (max-width: 767px) {
  .machineInfo__topTitle {
    font-size: 22px;
  }
  .machineInfo__topTitle span {
    font-size: 26px;
  }
}
.machineInfo__thumbnail {
  margin-top: 20px;
}
.machineInfo__content {
  margin-top: 80px;
}
@media only screen and (min-width: 768px) {
  .machineInfo__content {
    display: flex;
    gap: 50px;
    align-items: flex-start;
  }
}
@media only screen and (max-width: 767px) {
  .machineInfo__content {
    margin-top: 0;
  }
}
.machineInfo__content._reverse {
  flex-direction: row-reverse;
}
.machineInfo__title {
  font-size: 40px;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .machineInfo__title {
    font-size: 28px;
  }
}
.machineInfo__text {
  margin-top: 20px;
  margin-bottom: 20px;
}
@media only screen and (min-width: 768px) {
  .machineInfo__text {
    font-size: 20px;
  }
}
.machineInfo__movie {
  position: relative;
  margin-top: 20px;
}
.machineInfo__movie::before {
  display: block;
  padding-top: 56%;
  content: "";
}
.machineInfo__movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media only screen and (min-width: 768px) {
  .machineInfo__detail {
    width: 50%;
    font-size: 20px;
  }
}
@media only screen and (max-width: 767px) {
  .machineInfo__detail {
    margin-top: 20px;
  }
}
.machineInfo__detail .dls {
  border-top: 0.5px solid #000;
  border-bottom: 0.5px solid #000;
}
.machineInfo__detail dl {
  display: flex;
  padding: 30px 10px;
}
.machineInfo__detail dl:not(:first-child) {
  border-top: 0.5px solid #000;
}
@media only screen and (max-width: 767px) {
  .machineInfo__detail dl {
    padding: 20px 10px;
  }
}
.machineInfo__detail dt {
  width: 20%;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .machineInfo__detail dt {
    width: 25%;
  }
}
.machineInfo__detail dd {
  width: 80%;
}
@media only screen and (max-width: 767px) {
  .machineInfo__detail dd {
    width: 75%;
  }
}
@media only screen and (min-width: 768px) {
  .machineInfo__img {
    width: 50%;
  }
  .machineInfo__img img {
    display: flex;
    width: 70%;
    margin-right: auto;
    margin-left: auto;
  }
}
@media only screen and (max-width: 767px) {
  .machineInfo__img {
    margin-top: 20px;
  }
}
.machineInfo__note {
  margin-top: 20px;
  font-weight: bold;
}
@media only screen and (min-width: 768px) {
  .machineInfo__note {
    font-size: 20px;
  }
}
.machineInfo__btn {
  margin-top: 200px;
}
@media only screen and (max-width: 767px) {
  .machineInfo__btn {
    margin-top: 100px;
  }
}

.fv {
  position: relative;
  width: 100%;
}
.fv::before {
  display: block;
  padding-top: 65%;
  content: "";
}
@media only screen and (max-width: 767px) {
  .fv::before {
    padding-top: 100%;
  }
}
.fv img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.fvWrap {
  position: relative;
  margin-top: 100px;
}
@media only screen and (max-width: 767px) {
  .fvWrap {
    margin-top: 193.86px;
  }
}
.fv__text {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 100;
  width: 100%;
  font-size: 40px;
  font-weight: bold;
  text-align: center;
  text-shadow: 2px 2px 4px rgb(255, 255, 255);
  transform: translate(-50%, -50%);
}
@media only screen and (max-width: 767px) {
  .fv__text {
    top: 58%;
    font-size: 20px;
  }
}
.fv__copy {
  position: absolute;
  bottom: 50px;
  left: 50%;
  color: #fff;
  transform: translateX(-50%);
}
@media only screen and (max-width: 767px) {
  .fv__copy {
    bottom: 20px;
    font-size: 10px;
    white-space: nowrap;
  }
}

.clipshape01 {
  width: 0;
  height: 0;
}

.p-booth__top {
  position: absolute;
  bottom: -1px;
  width: 100%;
  height: 0;
  padding-top: 8.54545455%;
  -webkit-clip-path: url(#clipshape01);
          clip-path: url(#clipshape01);
  background-color: #fff;
}

.js-productSlider .swiper-slide {
  width: 100% !important;
}
.js-productSlider__thumbnail {
  margin-top: 30px;
}
@media only screen and (max-width: 1024px) {
  .js-productSlider__thumbnail {
    margin-bottom: 30px;
  }
}
.js-productSlider__thumbnail .swiper-wrapper {
  justify-content: center;
}
.js-productSlider__thumbnail .swiper-slide {
  width: calc(25% - 7.5px) !important;
  border: 0.5px solid #e5e4e4;
}
.js-productSlider__thumbnail .swiper-slide:not(:first-child) {
  margin-left: 10px;
}

.js-workerSlider .swiper-button-prev,
.js-workerSlider .swiper-button-next {
  top: 30%;
}
.js-workerSlider .swiper-button-prev::after,
.js-workerSlider .swiper-button-next::after {
  display: none;
}
.js-workerSlider .swiper-button-prev::before,
.js-workerSlider .swiper-button-next::before {
  position: absolute;
  width: 60px;
  height: 60px;
  content: "";
  background: url(../img/common/icon_button.png) no-repeat center center/contain;
}
@media only screen and (max-width: 767px) {
  .js-workerSlider .swiper-button-prev::before,
  .js-workerSlider .swiper-button-next::before {
    top: 20%;
    width: 40px;
    height: 40px;
  }
}
.js-workerSlider .swiper-button-prev::before {
  left: 0;
  transform: scale(-1, -1);
}
.js-workerSlider .swiper-button-next::before {
  right: 0;
}

.js-recruitSlider {
  margin: 0 calc(50% - 50vw);
  margin-top: 80px;
}
@media only screen and (max-width: 767px) {
  .js-recruitSlider {
    margin-top: 40px;
  }
}
.js-recruitSlider .swiper-slide {
  width: 16.6%;
}
@media only screen and (max-width: 767px) {
  .js-recruitSlider .swiper-slide {
    width: 50%;
  }
}
.js-recruitSlider .swiper-slide::nth-child(2n) {
  width: 16.6%;
}
@media only screen and (max-width: 767px) {
  .js-recruitSlider .swiper-slide::nth-child(2n) {
    width: 50%;
  }
}
.js-recruitSlider .swiper-slide:nth-child(3n) {
  width: 16.6%;
}
@media only screen and (max-width: 767px) {
  .js-recruitSlider .swiper-slide:nth-child(3n) {
    width: 50%;
  }
}

.top .aboutMore {
  margin-top: 50px;
}
@media only screen and (max-width: 767px) {
  .top .aboutMore {
    margin-top: 30px;
  }
}
.top .recruitMore {
  position: absolute;
  top: 80px;
  right: 0;
  z-index: 3;
  background: transparent;
}
@media only screen and (max-width: 1024px) {
  .top .recruitMore {
    top: 10px;
    right: 20px;
    width: 100px;
    padding: 1px;
  }
  .top .recruitMore span {
    padding-left: 1em;
    font-size: 12px;
  }
  .top .recruitMore span::before {
    font-size: 12px;
  }
}
.top .newsMore {
  position: absolute;
  top: 10px;
  right: 0;
}
@media only screen and (max-width: 1024px) {
  .top .newsMore {
    top: 10px;
    right: 20px;
    width: 120px;
    padding: 1px;
  }
  .top .newsMore span {
    padding-left: 1em;
    font-size: 12px;
  }
  .top .newsMore span::before {
    font-size: 12px;
  }
}

/* -----------------------------------------------
* リクルートページ改修 _230906
-------------------------------------------------- */

section.newsListRecruit {
  padding: 80px 0 0 0;
}

section.newsListRecruit .section__inner._narrow {
  max-width: 1280px;
}

section.newsListRecruit .section__inner._narrow .newsList {
  margin-top: 30px;
}

/* -----------------------------------------------
* 業務用オリジナル食材 改修 _230907
-------------------------------------------------- */

.btnAllcatalog .tiles .btn.btnSummer {
  background-color: #e2f0ec;
}

.btnAllcatalog .tiles .btn.btnAutumn {
  background-color: #f6e8d1;
}

.product__detail .btnCatalog .btn {
  margin-top: 2em;
  font-size: 24px;
}

.product__detail .btnCatalog .btn span::before {
  font-size: 28px;
}

/* -----------------------------------------------
* サステナビリティ コンテンツ追加 _230907
-------------------------------------------------- */

.sdgsBorderbox {
  margin-bottom: 1.5em;
  padding-bottom: 2em;
  border-bottom: 1px solid #4d4d4d;
}

/* -----------------------------------------------
* 会社案内 YouTube追加 _230907
-------------------------------------------------- */

.section.boxTvcm .section__inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
}

.boxYoutube {
  width: 70%;
  display: flex;
  flex-direction: column;
  aspect-ratio: 16 / 9.38;
  text-align: center;
}

.boxYoutube iframe {
  width: 100%;
  height: 100%;
  margin: 20px auto 0 auto;
  background-color: #ccc;
}

@media only screen and (max-width: 767px) {
  .boxYoutube {
    width: 100%;
  }
}