@charset "UTF-8";
/* 
font-family: "Noto Sans JP", sans-serif;
font-family: "Noto Serif JP", serif;
*/
body {
  font-size: 4vw;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-weight: 400;
  margin: 0 auto;
  position: relative;
  color: #111111;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
  background: url(/img/common/pat01.png) repeat center center/auto;
}

.fixed {
  width: 20%;
  position: fixed;
  z-index: 10;
  bottom: 1%;
  right: 1%;
  transform: translate(0%, 0%);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 2.6666666667vw;
}
.fixed_line {
  width: 100%;
}
.fixed_contact {
  width: 60%;
}

/*--------------------cmn--------------------*/
.cmn_tel_main {
  font-size: 8vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
  padding-left: 1.225em;
  position: relative;
  z-index: 1;
  font-family: "Shippori Mincho", serif;
  display: inline-block;
}
.cmn_tel_main::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 0.9875em;
  height: 0.9875em;
  transform: translate(0%, -50%);
  background: url(/img/company/tel-icon.png) no-repeat center center/contain;
}
.cmn_tel_txt {
  font-size: 3.7333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  padding: 1.3333333333vw;
  background: #fff6c9;
  display: inline-block;
  margin-bottom: 1.3333333333vw;
}
.cmn_tel_txt span {
  font-weight: 700;
  color: #ff8a00;
}

.cmn_ttl {
  font-size: 7.4666666667vw;
  line-height: 1;
  letter-spacing: 0.14em;
  font-weight: 600;
  color: #111111;
  font-family: "Shippori Mincho", serif;
  text-align: center;
  margin-bottom: 12vw;
}

.cmn_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 2.6666666667vw;
}
.cmn_dl_box:not(:last-child) {
  margin-bottom: 5.3333333333vw;
}
.cmn_dl_box dt {
  font-size: 4.8vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
  width: 100%;
  background: #5aa63c;
  border-radius: 2.6666666667vw;
  padding: 4vw 2.6666666667vw;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
.cmn_dl_box dd {
  font-size: 4.2666666667vw;
  line-height: 1.3888888889em;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}
.cmn_dl_box dd span {
  font-size: 3.7333333333vw;
}

.cmn_txt {
  font-size: 4vw;
  line-height: 2.2222222222em;
  letter-spacing: 0.06em;
  font-weight: 400;
  color: #111111;
}

/*--------------------cmn--------------------*/
/*--------------------header--------------------*/
.header {
  width: 100%;
  padding: 4vw 5.3333333333vw;
}
.header_logo {
  width: 20%;
}
.header_logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.header_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.header_info {
  display: none;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 20px;
  margin-bottom: 20px;
}
.header_dl {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 10px;
}
.header_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 7px;
}
.header_dl_box dt {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #442800;
  background: #ffdd33;
  padding: 12px 6px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  border-radius: 1.6vw;
}
.header_dl_box dd {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}
.header_dl_box dd span {
  font-size: 12px;
  display: block;
  margin-top: 5px;
}
.header_nav {
  display: none;
}
.header_nav_list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 30px;
}
.header_nav_item {
  font-size: 18px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
}
.header_nav_item:not(:last-child) {
  position: relative;
  z-index: 1;
}
.header_nav_item:not(:last-child)::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 0.3333333333em;
  height: 0.3333333333em;
  transform: translate(300%, -50%);
  background: #5aa63c;
  border-radius: 50%;
}

/*--------------------header--------------------*/
/*--------------------footer--------------------*/
.footer {
  width: 100%;
  padding: 13.3333333333vw 0;
  background: #5aa63c;
}
.footer_inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 8vw;
  border-radius: 8vw;
  background: #fff;
  padding: 8vw 4vw;
}
.footer_logo {
  width: 20%;
  margin: 0 auto 8vw;
  text-align: center;
}
.footer_info {
  width: 100%;
}
.footer_box {
  width: 100%;
  background: #f4ffde;
  border-radius: 2.6666666667vw;
  padding: 5.3333333333vw 4vw;
}
.footer_tel {
  margin-bottom: 2.6666666667vw;
  text-align: center;
}
.footer_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 2.6666666667vw;
}
.footer_right {
  width: 100%;
}
.footer_dl {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  padding-left: 9.3333333333vw;
  gap: 2.6666666667vw;
  margin-bottom: 4vw;
}
.footer_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 1.8666666667vw;
}
.footer_dl_box dt {
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #442800;
  background: #ffdd33;
  padding: 2.6666666667vw 1.6vw;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  border-radius: 1.6vw;
}
.footer_dl_box dd {
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}
.footer_dl_box dd span {
  font-size: 3.2vw;
  display: block;
  margin-top: 1.3333333333vw;
}
.footer_map {
  width: 100%;
  height: 57.7333333333vw;
  margin: 0 0 8vw auto;
}
.footer_map img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.footer_contact {
  width: 11.2vw;
  height: 11.2vw;
}
.footer_contact img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.footer_nav {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 4vw;
  margin-bottom: 8vw;
}
.footer_nav_list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4vw;
}
.footer_nav_item {
  font-size: 3.2vw;
  line-height: 1;
  letter-spacing: 0.03em;
  font-weight: 500;
  color: #111111;
}
.footer_nav_item:not(:last-child) {
  position: relative;
  z-index: 1;
}
.footer_nav_item:not(:last-child)::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 0.25em;
  height: 0.25em;
  transform: translate(290%, -50%);
  background: #5aa63c;
  border-radius: 50%;
}
.footer_nav_item a {
  color: #111111;
}

.line_btn {
  width: 60vw;
  background: #fff;
  border: 0.2666666667vw solid #5aa63c;
  border-radius: 999px;
  text-align: center;
  padding: 3.4666666667vw 2.6666666667vw 3.7333333333vw;
}
.line_btn p {
  display: inline-block;
  font-size: 3.7333333333vw;
  line-height: 1;
  letter-spacing: 0em;
  font-weight: 500;
  color: #111111;
  position: relative;
  z-index: 1;
  padding-left: 2.8125em;
}
.line_btn p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 1.875em;
  height: 1.875em;
  transform: translate(0%, -50%);
  background: url(/img/company/line.png) no-repeat center center/contain;
}

.copy_right {
  font-size: 3.2vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
  display: block;
  text-align: center;
}
.copy_right a {
  color: #111111;
}

/*--------------------footer--------------------*/
/*--------------------mv--------------------*/
.mv {
  width: 100%;
  position: relative;
  z-index: 1;
  height: 138.6666666667vw;
}
.mv_img {
  position: absolute;
  z-index: -2;
  top: 0%;
  left: 50%;
  transform: translate(-50%, 0%);
  width: 95%;
  height: 106.6666666667vw;
  border-radius: 13.3333333333vw;
  overflow: hidden;
  margin: 0 auto;
}
.mv_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 70% 0;
     object-position: 70% 0;
}
.mv_catch {
  position: absolute;
  z-index: -1;
  left: 50%;
  bottom: 0%;
  transform: translate(-50%, 0%);
  width: 90%;
  background: #fff;
  border-radius: 5.3333333333vw;
  border: 2.6666666667vw solid #fffbe6;
  padding: 10.6666666667vw 0 9.3333333333vw;
}
.mv_catch::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 38.0555555556%;
  height: 10.6666666667vw;
  background: url(/img/top/illustmv01.png) no-repeat center center/contain;
  transform: translate(-50%, -62%);
}
.mv_catch::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 0%;
  width: 21.1111111111%;
  height: 44.3804034582%;
  background: url(/img/top/illustmv02.png) no-repeat center center/contain;
  transform: translate(-30%, 30%);
}
.mv_catch img {
  display: block;
  width: 94%;
  margin: 0 auto;
}

/*--------------------mv--------------------*/
/*--------------------sv--------------------*/
.not_found_page .sub_ttl {
  font-size: 6.9333333333vw;
}

.sv_privacy .sv_catch span {
  font-size: 6.6666666667vw;
}

.sv_not_found .sv_catch span {
  font-size: 6.1333333333vw;
}

.sv {
  width: 100%;
  height: 66.6666666667vw;
  position: relative;
  z-index: 1;
  border-radius: 8vw;
  overflow: hidden;
}
.sv_img {
  padding: 0 5.3333333333vw;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -2;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.sv_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 8vw;
  overflow: hidden;
}
.sv .inner {
  width: 80%;
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.sv_catch {
  width: 100%;
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 5.3333333333vw 2.6666666667vw;
  background: #fff;
  border-radius: 2.6666666667vw;
  border: 1.3333333333vw solid #fffbe6;
  text-align: center;
}
.sv_catch span {
  width: 100%;
  display: inline-block;
  font-size: 7.2vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 600;
  color: #111111;
  font-family: "Shippori Mincho", serif;
  padding: 5.3333333333vw 0vw;
  border-top: 0.5333333333vw solid #5aa63c;
  border-bottom: 0.5333333333vw solid #5aa63c;
  position: relative;
  z-index: 1;
}
.sv_catch span::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 3.15em;
  height: 1em;
  transform: translate(-50%, -55%);
  background: url(/img/sv/illustsv.png) no-repeat center center/contain;
}

/*--------------------sv--------------------*/
/*--------------------company--------------------*/
.company {
  width: 100%;
  background: url(/img/company/right-deco01.png) no-repeat right top 48%/11.09375%, url(/img/company/left-deco01.png) no-repeat left top 6%/10.3645833333%;
}
.company_dl {
  margin-bottom: 13.3333333333vw;
}
.company_subttl {
  text-align: center;
  margin-bottom: 8vw;
}
.company_subttl span {
  font-size: 5.3333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #442800;
  background: #ffdd33;
  border-radius: 999px;
  padding: 3.2vw 4vw;
  display: inline-block;
}
.company_box {
  margin-bottom: 13.3333333333vw;
}
.company_img {
  width: 100%;
  height: 80vw;
}
.company_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.googlemap {
  width: 100%;
  height: 80vw;
}
.googlemap iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border: none;
}

.owner {
  width: 100%;
  background: url(/img/company/bgowner.png) no-repeat center center/cover;
}
.owner_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 8vw;
}
.owner_box {
  width: 100%;
}
.owner_img {
  width: 100%;
  height: 80vw;
}
.owner_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 0 0;
     object-position: 0 0;
}
.owner_name {
  margin-bottom: 4vw;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 2.6666666667vw;
}
.owner_name span:first-child {
  font-size: 4.8vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  background: #ffae00;
  padding: 1.0666666667vw 4vw;
}
.owner_name span:last-child {
  font-size: 5.8666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 900;
  color: #111111;
}

.googlemap_bot {
  width: 100%;
  height: 80vw;
}
.googlemap_bot iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border: none;
}

/*--------------------company--------------------*/
/*--------------------voice--------------------*/
.voice {
  width: 100%;
}
.voice_flex {
  width: 100%;
  background: #fff;
  border: 2.6666666667vw solid #f4ffde;
  border-radius: 8vw;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 4vw;
  padding: 8vw 4vw;
  position: relative;
  z-index: 1;
}
.voice_flex::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  right: 0%;
  width: 21.3333333333vw;
  height: 18.6666666667vw;
  transform: translate(15%, 20%);
  background: url(/img/voice/decovoice.png) no-repeat center center/contain;
}
.voice_flex:not(:last-child) {
  margin-bottom: 13.3333333333vw;
}
.voice_img {
  width: 32vw;
  height: 32vw;
  margin: 0 auto;
  border-radius: 50%;
  overflow: hidden;
}
.voice_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.voice_box {
  width: 100%;
}
.voice_star {
  font-size: 4.8vw;
  line-height: 1;
  letter-spacing: 0em;
  color: #ffdd33;
  margin-bottom: 1.8666666667vw;
}
.voice_name {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
  gap: 1.3333333333vw;
  width: 100%;
  margin-bottom: 4vw;
}
.voice_old {
  padding: 1.3333333333vw 2.6666666667vw;
  background: #ffae00;
  font-size: 4.5333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  display: inline-block;
}
.voice_namae {
  font-size: 5.3333333333vw;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
}
.voice_ttl {
  font-size: 5.3333333333vw;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #5aa63c;
  border-bottom: 0.2666666667vw dotted #111111;
  padding-bottom: 2.6666666667vw;
  margin-bottom: 2.6666666667vw;
}

/*--------------------voice--------------------*/
/*--------------------menu--------------------*/
.menu {
  width: 100%;
}
.menu_wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16vw;
  flex-direction: column-reverse;
}
.menu_box {
  width: 100%;
  position: relative;
  z-index: 1;
}
.menu_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: -6.6666666667vw;
  width: 20%;
  height: 16vw;
  transform: translate(0%, -60%);
  background: url(/img/company/left-deco01.png) no-repeat center center/contain;
}
.menu_box::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  right: -6.6666666667vw;
  width: 20%;
  height: 16vw;
  transform: translate(0%, 60%);
  background: url(/img/company/right-deco01.png) no-repeat center center/contain;
}
.menu_box_ttl {
  font-size: 5.8666666667vw;
  text-align: center;
  line-height: 1.5;
  letter-spacing: 0.14em;
  font-weight: 600;
  color: #fff;
  font-family: "Shippori Mincho", serif;
  background: #5aa63c;
  padding: 1.3333333333vw 4vw;
  margin-bottom: 2.6666666667vw;
}
.menu_box_img {
  width: 100%;
  height: 53.3333333333vw;
  margin-bottom: 4vw;
}
.menu_box_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.menu_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 8vw;
}
.menu_right {
  width: 100%;
  height: 66.6666666667vw;
  border-radius: 5.3333333333vw;
  overflow: hidden;
}
.menu_right img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.menu_left {
  width: 100%;
}
.menu_txt {
  width: 100%;
}
.menu_dl {
  width: 100%;
  margin-top: 5.3333333333vw;
}
.menu_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding-bottom: 1.3333333333vw;
  font-size: 4vw;
  line-height: 2.1111111111em;
  letter-spacing: 0.06em;
  font-weight: 400;
  border-bottom: 0.2666666667vw solid #111111;
}
.menu_dl_box:not(:first-child) {
  padding-top: 1.3333333333vw;
}
.menu_dl_box dt {
  width: 80%;
  padding-right: 4vw;
}
.menu_dl_box dd {
  width: 20%;
  text-align: right;
}
.menu_sub {
  width: 100%;
  margin-top: 5.3333333333vw;
  background: #fffbe6;
  font-size: 4vw;
  line-height: 1.5625em;
  letter-spacing: 0.06em;
  font-weight: 400;
  color: #111111;
  padding: 4vw;
}

/*--------------------menu--------------------*/
/*--------------------about--------------------*/
.about_link {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 4vw;
  padding-top: 20vw;
}
.about_link a {
  margin: 0 auto;
  width: 90%;
  background: #5aa63c;
  border-radius: 999px;
  padding: 5.3333333333vw 4vw;
}
.about_link a p {
  text-align: center;
  font-size: 4.8vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
  position: relative;
  z-index: 1;
}
.about_link a p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 1.6666666667em;
  height: 1.6666666667em;
  transform: translate(0%, -50%);
  background: url(/img/about/btnicon.png) no-repeat center center/contain;
}

.about {
  background: url(/img/company/right-deco01.png) no-repeat right top 5%/11.09375%, url(/img/company/left-deco01.png) no-repeat left top 51%/10.3645833333%;
  width: 100%;
  /* 幅 */
  /* 幅（Firefox用） */
  scrollbar-width: auto;
  /* 背景色 */
  /* 背景色（Firefox用） */
  scrollbar-track: #f0f0f0;
  /* スライダー部分の色 */
}
.about_img {
  width: 100%;
  height: 54.9333333333vw;
  margin: 0 auto 8vw;
}
.about_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.about_subttl {
  text-align: center;
  margin-bottom: 4vw;
}
.about_subttl span {
  font-size: 5.3333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #442800;
  background: #ffdd33;
  border-radius: 999px;
  padding: 3.2vw 4vw;
  display: inline-block;
}
.about_txt {
  margin-bottom: 8vw;
}
.about_box {
  padding: 8vw 4vw;
  background: #fff;
}
.about_box_ttl {
  text-align: center;
  margin-bottom: 8vw;
}
.about_box_ttl span {
  font-size: 5.3333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #442800;
  display: inline-block;
  padding-left: 1.48em;
  padding-right: 1.48em;
  position: relative;
  z-index: 1;
}
.about_box_ttl span::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 0.88em;
  height: 0.8em;
  transform: translate(0%, -50%);
  background: url(/img/about/decottl.png) no-repeat center center/contain;
}
.about_box_ttl span::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 0.88em;
  height: 0.8em;
  transform: translate(0%, -50%);
  background: url(/img/about/decottl.png) no-repeat center center/contain;
}
.about ::-webkit-scrollbar {
  width: 1.8666666667vw;
  height: 0;
}
.about ::-webkit-scrollbar-track {
  background-color: #f0f0f0;
}
.about ::-webkit-scrollbar-thumb {
  border-radius: 0;
  background-color: #cdcdcd;
}
.about_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  overflow: scroll;
  width: 100%;
  height: 132.8vw;
  gap: 8vw;
}
.about_item {
  width: 95%;
}
.about_item_ttl {
  font-size: 4.8vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 400;
  color: #111111;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.about_item_img {
  width: 100%;
  height: 53.3333333333vw;
  border-radius: 5.3333333333vw;
  border: 1.3333333333vw solid #fffbe6;
  overflow: hidden;
  margin-bottom: 4vw;
}
.about_item_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.reason {
  width: 100%;
  background: url(/img/about/bgreason.png) no-repeat center center/cover;
}
.reason_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8vw;
  margin-bottom: 8vw;
}
.reason_box {
  width: 80%;
  height: 72vw;
  background: #fff;
  border-radius: 50%;
  border: 0.2666666667vw solid #5aa63c;
  overflow: hidden;
  position: relative;
  z-index: 1;
  text-align: center;
  padding-top: 28vw;
}
.reason_box:nth-child(1) {
  padding-top: 32vw;
}
.reason_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 8vw;
  left: 50%;
  width: 40vw;
  height: 12.8vw;
  transform: translate(-50%, 0%);
  background: url(/img/about/illustreason.png) no-repeat center center/contain;
}
.reason_txt {
  line-height: 1.6666666667em;
  font-size: 4.8vw;
  font-weight: 500;
}
.reason_txtsub {
  margin-top: 0.5333333333vw;
}
.reason_txtsub span {
  display: inline-block;
  font-size: 3.7333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  background: #ffae00;
  padding: 1.0666666667vw 2.6666666667vw;
}
.flow {
  width: 100%;
  background: url(/img/about/bgflow.png) no-repeat center center/cover;
}
.flow_ttl {
  font-size: 7.0666666667vw;
}
.flow_dl {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4vw;
  justify-content: center;
  margin-bottom: 6.6666666667vw;
}
.flow_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.3333333333vw;
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
}
.flow_dl_box dt {
  color: #fff;
  background: #5aa63c;
  padding: 1.0666666667vw 1.3333333333vw;
}
.flow_box {
  width: 100%;
  padding: 8vw 4vw;
  background: #fff;
  border-radius: 5.3333333333vw;
  position: relative;
  z-index: 1;
}
.flow_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -2.1333333333vw;
  right: -2.6666666667vw;
  width: 16vw;
  height: 14.6666666667vw;
  transform: translate(0%, 0%);
  background: url(/img/about/decoflow.png) no-repeat center center/contain;
}
.flow_box:not(:last-child) {
  margin-bottom: 13.3333333333vw;
}
.flow_box:not(:last-child)::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -4vw;
  left: 50%;
  width: 10.6666666667vw;
  height: 5.3333333333vw;
  transform: translate(-50%, 100%);
  background: url(/img/about/sankaku.png) no-repeat center center/contain;
}
.flow_box_ttl {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2.1333333333vw;
  padding-bottom: 2.1333333333vw;
  border-bottom: 0.2666666667vw dotted #111111;
  margin-bottom: 1.3333333333vw;
}
.flow_box_ttl span:first-child {
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  background: #ffae00;
  width: 18.6666666667vw;
  display: block;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5333333333vw;
}
.flow_box_ttl span:first-child .flow_box_ttl_color {
  width: 2.6666666667vw;
  display: block;
  font-size: 5.3333333333vw;
  padding-bottom: 0.5333333333vw;
  color: #fff;
}
.flow_box_ttl span:last-child {
  width: calc(100% - 20.8vw);
  font-size: 5.3333333333vw;
  line-height: 1.3;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #5aa63c;
}
.flow_box_txt {
  line-height: 1.6666666667em;
}
.flow_con:not(:last-child) {
  margin-bottom: 20vw;
}

.in_about {
  width: 100%;
}
.in_about_img {
  width: 80%;
  margin: 0 auto 8vw;
  height: 80vw;
}
.in_about_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.in_about_ttl {
  width: 80%;
  margin: 0 auto 13.3333333333vw;
}

/*--------------------about--------------------*/
/*--------------------top--------------------*/
.diet_flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 8vw;
}
.diet_img {
  width: 100%;
  height: 86.1333333333vw;
}
.diet_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.diet_box {
  width: 100%;
}
.diet_box_ttl {
  width: 78%;
  text-align: center;
  margin: 0 auto;
  margin-bottom: 5.3333333333vw;
  position: relative;
  z-index: 1;
}
.diet_box_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 10.6666666667vw;
  height: 9.6vw;
  transform: translate(-90%, -60%);
  background: url(/img/top/left-decod.png) no-repeat center center/contain;
}
.diet_box_ttl::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  right: 0%;
  width: 16vw;
  height: 4.2666666667vw;
  transform: translate(40%, -30%);
  background: url(/img/top/right-decod.png) no-repeat center center/contain;
}

.top_tubo {
  width: 100%;
  padding-bottom: 0;
  background: url(/img/top/bgtubo.png) no-repeat center center/cover;
  position: relative;
  z-index: 1;
}
.top_tubo::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  left: 50%;
  width: 100%;
  height: 133.3333333333vw;
  background: url(/img/top/wave.png) no-repeat top -4% center/780px, url(/img/common/pat01.png) repeat center center/auto;
  transform: translate(-50%, 0%);
}
.top_tubo_ttl {
  width: 95%;
  margin: 0 auto 5.3333333333vw;
  text-align: center;
}
.top_tubo_txt {
  margin-bottom: 8vw;
}
.top_tubo_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8vw;
  margin-bottom: 13.3333333333vw;
}
.top_tubo_left {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4vw;
}
.top_tubo_box {
  width: 100%;
  padding: 5.3333333333vw;
  background: #fff;
  border-radius: 2.6666666667vw;
  border: 0.2666666667vw solid #5aa63c;
  text-align: center;
}
.top_tubo_box_ttl {
  border-bottom: 0.2666666667vw dotted #5aa63c;
  padding-bottom: 1.3333333333vw;
  margin-bottom: 2.6666666667vw;
}
.top_tubo_box_ttl span {
  font-size: 5.3333333333vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #5aa63c;
  position: relative;
  z-index: 1;
  padding-left: 1.25em;
  display: inline-block;
}
.top_tubo_box_ttl span::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 0.8em;
  height: 0.8em;
  transform: translate(0%, -50%);
  background: url(/img/top/peke.png) no-repeat center center/contain;
}
.top_tubo_box_txt {
  font-size: 4.5333333333vw;
  line-height: 1.3333333333em;
  letter-spacing: 0.06em;
  font-weight: 400;
  color: #111111;
}
.top_tubo_img {
  width: 100%;
  height: 83.2vw;
}
.top_tubo_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top_tubo_list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 13.3333333333vw;
  width: 100%;
  margin: 0 auto;
}
.top_tubo_item {
  width: 86%;
  padding: 8vw 5.3333333333vw 5.3333333333vw;
  border-radius: 5.3333333333vw;
  background: url(/img/top/bgiiiii.png) no-repeat center center/cover;
  position: relative;
  z-index: 1;
}
.top_tubo_item:nth-child(1) .top_tubo_item_ttl {
  transform: translate(-50%, -45%);
}
.top_tubo_item:nth-child(3) .top_tubo_item_ttl {
  transform: translate(-50%, -45%);
}
.top_tubo_item_ttl {
  width: 110%;
  position: absolute;
  z-index: 2;
  top: 0%;
  left: 50%;
  transform: translate(-50%, -31%);
}
.top_tubo_item_ttl img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top_tubo_item_img {
  width: 100%;
  height: 53.3333333333vw;
  border: 1.3333333333vw solid #fff;
  border-radius: 5.3333333333vw;
  overflow: hidden;
  position: relative;
  z-index: 1;
  margin-bottom: 5.3333333333vw;
}
.top_tubo_item_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top_tubo_item_txt {
  font-size: 5.3333333333vw;
  line-height: 1.4;
  letter-spacing: 0.1em;
  font-weight: 600;
  color: #111111;
  font-family: "Shippori Mincho", serif;
  position: relative;
  z-index: 1;
  text-align: center;
}
.top_tubo_item_txt::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 1.2em;
  height: 1.2em;
  transform: translate(0%, -50%);
  background: url(/img/top/infoarw.png) no-repeat center center/contain;
}

.con {
  width: 100%;
  padding-bottom: 0;
}
.con_cont {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10.6666666667vw;
  padding: 8vw 4vw;
  background: #fffbe6;
  border: 1.0666666667vw dotted #5aa63c;
  border-radius: 8vw;
  position: relative;
  z-index: 1;
}
.con_cont::before {
  content: "";
  position: absolute;
  z-index: 3;
  bottom: -10%;
  left: -7%;
  width: 18.6666666667vw;
  height: 30.6666666667vw;
  background: url(/img/top/illcon.png) no-repeat center center/contain;
  transform: translate(0%, 0%);
}
.con_box {
  width: 100%;
  padding-bottom: 8vw;
  padding-top: 10.6666666667vw;
  border-top: 0.5333333333vw solid #5aa63c;
  border-bottom: 0.5333333333vw solid #5aa63c;
  position: relative;
  z-index: 1;
}
.con_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 42.6666666667vw;
  height: 10.6666666667vw;
  background: url(/img/top/decocon.png) no-repeat center center/contain;
  transform: translate(-50%, -50%);
}
.con_ttl {
  width: 100%;
}
.con_tel {
  margin-bottom: 2.6666666667vw;
  text-align: center;
}
.con_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8vw;
}
.con_dl {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  gap: 2.6666666667vw;
  margin-bottom: 5.3333333333vw;
}
.con_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 1.8666666667vw;
}
.con_dl_box dt {
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #442800;
  background: #ffdd33;
  padding: 3.2vw 1.6vw;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  border-radius: 1.6vw;
}
.con_dl_box dd {
  font-size: 4vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}
.con_dl_box dd span {
  font-size: 3.2vw;
  display: block;
  margin-top: 1.3333333333vw;
}

.top_info {
  width: 100%;
  padding: 20vw 0;
  background: url(/img/top/bginfo.png) no-repeat center center/cover;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8vw;
}
.top_info_link {
  width: 85%;
  padding: 10.6666666667vw 8vw;
  border: 2.1333333333vw solid #fff;
  border-radius: 5.3333333333vw;
  background: url(/img/top/bgiinfo.png) no-repeat center center/cover;
  text-align: center;
  position: relative;
  z-index: 1;
}
.top_info_link:nth-child(1)::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -4.2666666667vw;
  left: -5.8666666667vw;
  width: 15.7333333333vw;
  height: 28vw;
  transform: translate(0%, 0%);
  background: url(/img/top/iill01.png) no-repeat center center/contain;
}
.top_info_link:nth-child(2)::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -4.2666666667vw;
  left: -5.3333333333vw;
  width: 18.1333333333vw;
  height: 24vw;
  transform: translate(0%, 0%);
  background: url(/img/top/iill02.png) no-repeat center center/contain;
}
.top_info_link:nth-child(3)::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -4.2666666667vw;
  left: -5.8666666667vw;
  width: 21.3333333333vw;
  height: 25.3333333333vw;
  transform: translate(0%, 0%);
  background: url(/img/top/iill03.png) no-repeat center center/contain;
}
.top_info_ttl {
  font-size: 6.6666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 600;
  color: #111111;
  font-family: "Shippori Mincho", serif;
  display: inline-block;
  padding-bottom: 1.8666666667vw;
  border-bottom: 0.2666666667vw dotted #111111;
  margin-bottom: 6.6666666667vw;
}
.top_info_txt {
  font-size: 4.2666666667vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
  position: relative;
  z-index: 1;
  padding-right: 2.1875em;
  display: inline-block;
}
.top_info_txt::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 1.6875em;
  height: 1.6875em;
  transform: translate(0%, -50%);
  background: url(/img/top/arwi.png) no-repeat center center/contain;
}

.top_news {
  width: 100%;
  background: url(/img/company/right-deco01.png) no-repeat right top 6%/11.09375%, url(/img/company/left-deco01.png) no-repeat left bottom 8%/10.3645833333%;
}
.top_news_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-bottom: 8vw;
}
.top_news_ttl {
  margin: 0;
}
.top_news_btn {
  text-align: center;
  margin-top: 8vw;
}
.top_news_btn p {
  font-size: 4.8vw;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
  position: relative;
  z-index: 1;
  display: inline-block;
  padding-right: 2.2222222222em;
}
.top_news_btn p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 1.6666666667em;
  height: 1.6666666667em;
  background: url(/img/top/arwnews.png) no-repeat center center/contain;
  transform: translate(0%, -50%);
}

/*--------------------top--------------------*/