@charset "UTF-8";
/* 
font-family: "Zen Kaku Gothic New", sans-serif;
font-family: "Shippori Mincho", serif;

*/
body {
  font-size: 16px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1.5;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: #111111;
  min-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
  background: url(/img/common/pat01.png) repeat center center/auto;
}

.fixed {
  position: fixed;
  z-index: 10;
  bottom: 2%;
  right: 1%;
  transform: translate(0%, 0%);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 20px;
}

/*--------------------cmn--------------------*/
.cmn_tel_main {
  font-size: 40px;
  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: 14px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  padding: 5px;
  background: #fff6c9;
  display: inline-block;
  margin-bottom: 5px;
}
.cmn_tel_txt span {
  font-weight: 700;
  color: #ff8a00;
}

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

.cmn_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 15px;
}
.cmn_dl_box:not(:last-child) {
  margin-bottom: 10px;
}
.cmn_dl_box dt {
  font-size: 18px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #fff;
  width: 150px;
  background: #5aa63c;
  border-radius: 10px;
  padding: 15px 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
.cmn_dl_box dd {
  font-size: 18px;
  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: 16px;
}

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

/*--------------------cmn--------------------*/
/*--------------------header--------------------*/
.header {
  width: 100%;
  padding: 15px 60px;
}
.header_tel {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  flex-direction: column;
}
.header_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}
.header_info {
  display: flex;
  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: 6px;
}
.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_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_inner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 50px;
}
.footer_logo {
  margin-bottom: 20px;
  text-align: center;
}
.footer_info {
  width: 460px;
}
.footer_box {
  width: 100%;
  background: #f4ffde;
  border-radius: 10px;
  padding: 20px 40px;
}
.footer_tel {
  margin-bottom: 10px;
}
.footer_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 30px;
}
.footer_right {
  width: calc(100% - 510px);
}
.footer_dl {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 10px;
  margin-bottom: 20px;
}
.footer_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 7px;
}
.footer_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: 6px;
}
.footer_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;
}
.footer_dl_box dd span {
  font-size: 12px;
  display: block;
  margin-top: 5px;
}
.footer_map {
  width: 340px;
  height: 240px;
  margin: 0 0 60px auto;
}
.footer_map img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.footer_contact {
  width: 60px;
  height: 60px;
}
.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: 15px;
  margin-bottom: 40px;
}
.footer_nav_list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 13px;
}
.footer_nav_item {
  font-size: 12px;
  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(270%, -50%);
  background: #5aa63c;
  border-radius: 50%;
}
.footer_nav_item a {
  color: #111111;
}

.line_btn {
  width: 280px;
  background: #fff;
  border: 1px solid #5aa63c;
  border-radius: 999px;
  text-align: center;
  padding: 17px 15px;
}
.line_btn p {
  display: inline-block;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  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: 12px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
  display: block;
  text-align: right;
}
.copy_right a {
  color: #111111;
}

/*--------------------footer--------------------*/
/*--------------------mv--------------------*/
.mv {
  width: 100%;
  position: relative;
  z-index: 1;
  height: clamp(520px, 40.625vw, 780px);
}
.mv_img {
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  transform: translate(-50%, 0%);
  width: 93.75%;
  height: 100%;
  border-radius: 60px;
  overflow: hidden;
  margin: 0 auto;
}
.mv_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.mv_catch {
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 13.3333333333%;
  transform: translate(0%, -50%);
  width: 37.5%;
  background: #fff;
  border-radius: 20px;
  border: 10px solid #fffbe6;
  padding: 70px 0 50px;
  position: relative;
  z-index: 1;
}
.mv_catch::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 40%;
  height: 87px;
  background: url(/img/top/illustmv01.png) no-repeat center center/contain;
  transform: translate(-50%, -52%);
}
.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%, 10%);
}
.mv_catch img {
  display: block;
  width: 72.7777777778%;
  margin: 0 auto;
}

/*--------------------mv--------------------*/
/*--------------------sv--------------------*/
.sv {
  width: 100%;
  height: 400px;
  position: relative;
  z-index: 1;
  border-radius: 30px;
  overflow: hidden;
}
.sv_img {
  padding: 0 60px;
  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: 30px;
  overflow: hidden;
}
.sv .inner {
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.sv_catch {
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  transform: translate(0%, -50%);
  padding: 8px 20px;
  background: #fff;
  border-radius: 10px;
  border: 5px solid #fffbe6;
}
.sv_catch span {
  display: inline-block;
  font-size: 40px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 600;
  color: #111111;
  font-family: "Shippori Mincho", serif;
  padding: 30px 20px;
  border-top: 2px solid #5aa63c;
  border-bottom: 2px 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 320px/11.09375%, url(/img/company/left-deco01.png) no-repeat left top 290px/10.3645833333%;
}
.company_dl {
  margin-bottom: 80px;
}
.company_subttl {
  text-align: center;
  margin-bottom: 30px;
}
.company_subttl span {
  font-size: 30px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #442800;
  background: #ffdd33;
  border-radius: 999px;
  padding: 15px 40px;
  display: inline-block;
}
.company_box {
  margin-bottom: 60px;
}
.company_img {
  width: 100%;
  height: 400px;
}
.company_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.googlemap {
  width: 100%;
  height: 400px;
}
.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: 40px;
}
.owner_box {
  width: calc(100% - 340px);
}
.owner_img {
  width: 300px;
  height: 400px;
}
.owner_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.owner_name {
  margin-bottom: 19px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.owner_name span:first-child {
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  background: #ffae00;
  padding: 5px 18px;
}
.owner_name span:last-child {
  font-size: 25px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 900;
  color: #111111;
}

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

.footer {
  width: 100%;
  padding: 60px 0;
  background: #5aa63c;
}
.footer_inner {
  border-radius: 30px;
  background: #fff;
  padding: 40px 60px;
}

/*--------------------company--------------------*/
/*--------------------voice--------------------*/
.voice {
  width: 100%;
}
.voice_flex {
  width: 100%;
  background: #fff;
  border: 10px solid #f4ffde;
  border-radius: 30px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 30px;
  padding: 60px;
  position: relative;
  z-index: 1;
}
.voice_flex::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: 0%;
  right: 0%;
  width: 134px;
  height: 118px;
  transform: translate(15%, 20%);
  background: url(/img/voice/decovoice.png) no-repeat center center/contain;
}
.voice_flex:not(:last-child) {
  margin-bottom: 60px;
}
.voice_img {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  overflow: hidden;
}
.voice_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.voice_box {
  width: calc(100% - 150px);
}
.voice_star {
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0em;
  color: #ffdd33;
  margin-bottom: 7px;
}
.voice_name {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  width: 100%;
  margin-bottom: 15px;
}
.voice_old {
  padding: 5px 10px;
  background: #ffae00;
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  display: inline-block;
}
.voice_namae {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
}
.voice_ttl {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #5aa63c;
  border-bottom: 1px dotted #111111;
  margin-bottom: 20px;
}

/*--------------------voice--------------------*/
/*--------------------menu--------------------*/
.menu {
  width: 100%;
  background: url(/img/common/right-deco.png) repeat-y right top 195px/11%, url(/img/common/left-deco.png) repeat-y left top 300px/10%;
}
.menu_wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 60px;
  flex-direction: column-reverse;
}
.menu_box {
  width: 100%;
}
.menu_box_ttl {
  font-size: 30px;
  line-height: 1.5;
  letter-spacing: 0.14em;
  font-weight: 600;
  color: #fff;
  font-family: "Shippori Mincho", serif;
  background: #5aa63c;
  padding: 7.5px 30px;
  margin-bottom: 40px;
}
.menu_box_img {
  width: 100%;
  height: 500px;
  margin-bottom: 40px;
}
.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: 30px;
}
.menu_right {
  width: 380px;
  height: 300px;
  border-radius: 20px;
  overflow: hidden;
}
.menu_right img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.menu_left {
  width: calc(100% - 410px);
}
.menu_txt {
  width: 100%;
}
.menu_dl {
  width: 100%;
  margin-top: 25px;
}
.menu_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding-bottom: 5px;
  font-size: 18px;
  line-height: 2.1111111111em;
  letter-spacing: 0.06em;
  font-weight: 400;
  border-bottom: 1px solid #111111;
}
.menu_dl_box:not(:first-child) {
  padding-top: 5px;
}
.menu_dl_box dt {
  width: 70%;
  padding-right: 15px;
}
.menu_dl_box dd {
  width: 30%;
  text-align: right;
}
.menu_sub {
  width: 100%;
  margin-top: 20px;
  background: #fffbe6;
  font-size: 16px;
  line-height: 1.5625em;
  letter-spacing: 0.06em;
  font-weight: 400;
  color: #111111;
  padding: 15px;
}

/*--------------------menu--------------------*/
/*--------------------about--------------------*/
.about_link {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 20px;
  padding-top: 100px;
}
.about_link a {
  width: 300px;
  background: #5aa63c;
  border-radius: 999px;
  padding: 21px 15px;
}
.about_link a p {
  text-align: center;
  font-size: 18px;
  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 455px/11.09375%, url(/img/company/left-deco01.png) no-repeat left top 490px/10.3645833333%;
  width: 100%;
  /* 幅 */
  /* 幅（Firefox用） */
  scrollbar-width: auto;
  /* 背景色 */
  /* 背景色（Firefox用） */
  scrollbar-track: #f0f0f0;
  /* スライダー部分の色 */
}
.about_img {
  width: 826px;
  height: 503px;
  margin: 0 auto 15px;
}
.about_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.about_subttl {
  text-align: center;
  margin-bottom: 30px;
}
.about_subttl span {
  font-size: 30px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #442800;
  background: #ffdd33;
  border-radius: 999px;
  padding: 15px 40px;
  display: inline-block;
}
.about_txt {
  text-align: center;
  margin-bottom: 70px;
}
.about_box {
  padding: 60px;
  background: #fff;
}
.about_box_ttl {
  text-align: center;
  margin-bottom: 40px;
}
.about_box_ttl span {
  font-size: 25px;
  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: 30px;
  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: stretch;
  overflow: scroll;
  width: 100%;
  height: 574px;
  gap: 40px 30px;
}
.about_item {
  width: 280px;
}
.about_item_ttl {
  font-size: 18px;
  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: 230px;
  border-radius: 20px;
  border: 5px solid #fffbe6;
  overflow: hidden;
  margin-bottom: 20px;
}
.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: 40px;
  margin-bottom: 50px;
}
.reason_box {
  width: 260px;
  height: 260px;
  background: #fff;
  border-radius: 50%;
  border: 1px solid #5aa63c;
  overflow: hidden;
  position: relative;
  z-index: 1;
  text-align: center;
  padding-top: 100px;
}
.reason_box:nth-child(1) {
  padding-top: 115px;
}
.reason_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 30px;
  left: 50%;
  width: 149px;
  height: 47px;
  transform: translate(-50%, 0%);
  background: url(/img/about/illustreason.png) no-repeat center center/contain;
}
.reason_txt {
  line-height: 1.6666666667em;
}
.reason_txtsub {
  margin-top: 2px;
}
.reason_txtsub span {
  display: inline-block;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  background: #ffae00;
  padding: 4px 8px;
}
.reason_subtxt {
  text-align: center;
}

.flow {
  width: 100%;
  background: url(/img/about/bgflow.png) no-repeat center center/cover;
}
.flow_dl {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
  justify-content: center;
  margin-bottom: 40px;
}
.flow_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
}
.flow_dl_box dt {
  color: #fff;
  background: #5aa63c;
  padding: 4.5px 5px;
}
.flow_box {
  width: 100%;
  padding: 40px;
  background: #fff;
  border-radius: 20px;
  position: relative;
  z-index: 1;
}
.flow_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -8px;
  right: -10px;
  width: 88px;
  height: 78px;
  transform: translate(0%, 0%);
  background: url(/img/about/decoflow.png) no-repeat center center/contain;
}
.flow_box:not(:last-child) {
  margin-bottom: 60px;
}
.flow_box:not(:last-child)::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -20px;
  left: 50%;
  width: 40px;
  height: 20px;
  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: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dotted #111111;
  margin-bottom: 10px;
}
.flow_box_ttl span:first-child {
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #fff;
  background: #ffae00;
  width: 90px;
  display: block;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 3px;
}
.flow_box_ttl span:first-child .flow_box_ttl_color {
  width: 15px;
  display: block;
  font-size: 25px;
  padding-bottom: 5px;
  color: #fff;
}
.flow_box_ttl span:last-child {
  width: calc(100% - 100px);
  font-size: 25px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #5aa63c;
}
.flow_box_txt {
  line-height: 1.6666666667em;
}
.flow_con:not(:last-child) {
  margin-bottom: 80px;
}

.in_about {
  width: 100%;
}
.in_about_img {
  width: 80%;
  margin: 0 auto 30px;
  height: 500px;
}
.in_about_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.in_about_ttl {
  width: 80%;
  margin: 0 auto 50px;
}

/*--------------------about--------------------*/
/*--------------------top--------------------*/
.diet_flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.diet_img {
  width: 527px;
  height: 505px;
  margin-right: -42px;
}
.diet_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.diet_box {
  width: calc(100% - 570px);
}
.diet_box_ttl {
  margin-left: -25px;
  margin-bottom: 45px;
  position: relative;
  z-index: 1;
}
.diet_box_ttl::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 0%;
  width: 73px;
  height: 62px;
  transform: translate(-120%, -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: 123px;
  height: 33px;
  transform: translate(-40%, 0%);
  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: 240px;
  background: url(/img/top/wave.png) no-repeat top -23px center/contain, url(/img/common/pat01.png) repeat center center/auto;
  transform: translate(-50%, 0%);
}
.top_tubo_ttl {
  text-align: center;
  margin-bottom: 50px;
}
.top_tubo_txt {
  text-align: center;
  margin-bottom: 30px;
}
.top_tubo_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 60px;
  margin-bottom: 85px;
}
.top_tubo_left {
  width: 700px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
}
.top_tubo_box {
  width: 340px;
  padding: 20px;
  background: #fff;
  border-radius: 10px;
  border: 1px solid #5aa63c;
  text-align: center;
}
.top_tubo_box_ttl {
  border-bottom: 1px dotted #5aa63c;
  padding-bottom: 5px;
  margin-bottom: 10px;
}
.top_tubo_box_ttl span {
  font-size: 20px;
  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: 18px;
  line-height: 1.2222222222em;
  letter-spacing: 0.06em;
  font-weight: 400;
  color: #111111;
}
.top_tubo_img {
  width: calc(100% - 760px);
  height: 297px;
}
.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;
  gap: 30px;
  width: 1100px;
  margin: 0 auto;
}
.top_tubo_item {
  width: 340px;
  padding: 30px 20px;
  border-radius: 20px;
  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%, -34%);
  margin-left: -5px;
}
.top_tubo_item:nth-child(3) {
  padding: 30px 20px 14px;
}
.top_tubo_item:nth-child(3) .top_tubo_item_ttl {
  transform: translate(-50%, -34%);
  margin-right: -5px;
}
.top_tubo_item:nth-child(3) .top_tubo_item_txt {
  font-size: 20px;
  line-height: 1.4;
}
.top_tubo_item:nth-child(3) .top_tubo_item_img {
  margin-bottom: 15px;
}
.top_tubo_item_ttl {
  width: 365px;
  position: absolute;
  z-index: 2;
  top: 0%;
  left: 50%;
  transform: translate(-50%, -20%);
}
.top_tubo_item_ttl img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top_tubo_item_img {
  width: 100%;
  height: 230px;
  border: 5px solid #fff;
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  z-index: 1;
  margin-bottom: 30px;
}
.top_tubo_item_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top_tubo_item_txt {
  font-size: 25px;
  line-height: 1;
  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: 30px;
  padding: 50px 60px 50px 100px;
  background: #fffbe6;
  border: 4px dotted #5aa63c;
  border-radius: 30px;
  position: relative;
  z-index: 1;
}
.con_cont::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -10px;
  left: -60px;
  width: 152px;
  height: 244px;
  background: url(/img/top/illcon.png) no-repeat center center/contain;
  transform: translate(0%, 0%);
}
.con_box {
  width: 480px;
  padding-bottom: 30px;
  padding-top: 40px;
  border-top: 2px solid #5aa63c;
  border-bottom: 2px solid #5aa63c;
  position: relative;
  z-index: 1;
}
.con_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0%;
  left: 50%;
  width: 228px;
  height: 64px;
  background: url(/img/top/decocon.png) no-repeat center center/contain;
  transform: translate(-50%, -50%);
}
.con_ttl {
  width: calc(100% - 510px);
}
.con_tel {
  margin-bottom: 10px;
  text-align: center;
}
.con_flex {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 30px;
}
.con_dl {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  gap: 10px;
  margin-bottom: 20px;
}
.con_dl_box {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 7px;
}
.con_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: 6px;
}
.con_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;
}
.con_dl_box dd span {
  font-size: 12px;
  display: block;
  margin-top: 5px;
}

.top_info {
  width: 100%;
  padding: 100px 0;
  background: url(/img/top/bginfo.png) no-repeat center center/cover;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 45px;
}
.top_info_link {
  width: 330px;
  padding: 40px 35px;
  border: 10px solid #fff;
  border-radius: 20px;
  background: url(/img/top/bgiinfo.png) repeat center center/auto;
  text-align: center;
  position: relative;
  z-index: 1;
}
.top_info_link:nth-child(1)::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -16px;
  left: -22px;
  width: 59px;
  height: 105px;
  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: -16px;
  left: -36px;
  width: 78px;
  height: 105px;
  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: -16px;
  left: -32px;
  width: 95px;
  height: 105px;
  transform: translate(0%, 0%);
  background: url(/img/top/iill03.png) no-repeat center center/contain;
}
.top_info_ttl {
  font-size: 25px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 600;
  color: #111111;
  font-family: "Shippori Mincho", serif;
  display: inline-block;
  padding-bottom: 7px;
  border-bottom: 1px dotted #111111;
  margin-bottom: 25px;
}
.top_info_txt {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
  position: relative;
  z-index: 1;
  padding-right: 2.375em;
  display: inline-block;
}
.top_info_txt::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 1.875em;
  height: 1.875em;
  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/11.09375%, url(/img/company/left-deco01.png) no-repeat left top/10.3645833333%;
}
.top_news_box {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 60px;
}
.top_news_ttl {
  margin: 0;
}
.top_news_btn p {
  font-size: 18px;
  line-height: 1;
  letter-spacing: 0.06em;
  font-weight: 500;
  color: #111111;
  position: relative;
  z-index: 1;
  display: inline-block;
  padding-right: 2.7777777778em;
}
.top_news_btn p::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  right: 0%;
  width: 2.2222222222em;
  height: 2.2222222222em;
  background: url(/img/top/arwnews.png) no-repeat center center/contain;
  transform: translate(0%, -50%);
}

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