@charset "UTF-8";
/* =============================================================
    font
============================================================= */
/* Craft明朝 */
@font-face {
  font-family: "クラフト明朝";
  src: url("../font/craftmincho.otf") format("opentype");
}
/* 全角ゴシック */
@font-face {
  font-family: "Zen Kaku Gothic New";
  src: url("../font/ZenKakuGothicNew-Light.ttf") format("truetype");
  src: url("../font/ZenKakuGothicNew-Medium.ttf") format("truetype");
  src: url("../font/ZenKakuGothicNew-Medium.ttf") format("truetype");
  src: url("../font/ZenKakuGothicNew-Regular.ttf") format("truetype");
}
/* ペンレター */
/* しろくまフォント */
@font-face {
  font-family: "しろくまフォント";
  src: url("../font/001Shirokuma-Regular.otf") format("opentype");
}
.emoji {
  font-family: "Noto Emoji", sans-serif;
  font-weight: 400;
}

.strong {
  font-weight: 500;
}

/* =============================================================
    共通
============================================================= */
html {
  font-size: 62.5%;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
  font-weight: 500;
  visibility: hidden;
  font-style: normal;
  border: 0px solid purple;
}

html.wf-active,
html.loading-delay {
  visibility: visible;
}

body {
  font-size: 1.6rem;
  margin: 0;
  background: #f2f2f2;
}
@media screen and (max-width: 1024px) {
  body {
    border: 0x solid red;
  }
}
@media screen and (max-width: 767px) {
  body {
    border: 0px solid blue;
  }
}

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

::-moz-selection {
  color: #fff;
  background: #90b184;
}

::selection {
  color: #fff;
  background: #90b184;
}

img {
  border: 0;
  margin: 0;
}

img::-moz-selection {
  background: #fff;
}

img::selection {
  background: #fff;
}

figure {
  margin: 0;
}

p {
  margin: 0;
  padding: 0;
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 1.6rem;
  margin: 0;
  padding: 0;
}

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

.left {
  display: block;
  text-align: left;
}

.right {
  display: block;
  text-align: right;
}

.arrow1 {
  display: inline-block;
  animation: slide1 1s ease-in-out infinite;
  margin-right: 1rem;
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  .arrow1 {
    margin-right: auto;
  }
}

/* =============================================================
    共通 : 非表示設定
============================================================= */
@media only screen and (max-width: 1024.9px) {
  .pc {
    display: none !important;
  }
}
@media only screen and (max-width: 767.9px) {
  .pc-tab {
    display: none !important;
  }
}
@media only screen and (min-width: 1025px) {
  .tab-sp {
    display: none !important;
  }
}
@media only screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
/* =============================================================
    front-page : header
============================================================= */
#header {
  position: relative; /*h1の中央寄せ配置の起点とするためのrelative*/
  height: 100vh; /*高さを全画面にあわせる*/
}
@media screen and (max-width: 767px) {
  #header {
    height: 70vh;
  }
}
#header #g-nav li a {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-weight: 500;
}

#video-area {
  position: absolute;
  z-index: -1; /*最背面に設定*/
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  overflow: hidden;
  border: 0px solid green;
}

#video {
  /*天地中央配置*/
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 177.77777778vh; /* 16:9 の幅→16 ÷ 9＝ 177.77% */
  height: 56.25vw; /* 16:9の幅 → 9 ÷ 16 = 56.25% */
  min-height: 100%;
  min-width: 100%;
}
@media screen and (max-width: 767px) {
  #video {
    top: 35vh;
    min-height: 70vh;
    height: 70vh;
  }
}

.custom-shape-divider-bottom-1699493953 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  overflow: hidden;
  line-height: 0;
  transform: rotate(180deg);
}

.custom-shape-divider-bottom-1699493953 svg {
  position: relative;
  display: block;
  width: calc(156% + 1.3px);
  height: 36px;
  transform: rotateY(180deg);
}

.custom-shape-divider-bottom-1699493953 .shape-fill {
  fill: #fafafa;
}

/* =============================================================
    front-page : main
============================================================= */
#lead {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  margin-top: 0;
  padding-bottom: 10%;
  overflow: hidden;
  background: #fafafa;
}
#lead .lead_title {
  font-size: 4rem;
  color: #573017;
  line-height: 4.8rem;
  text-align: center;
  margin-top: 11.2rem;
  margin-left: 75px;
}
#lead .lead_title::after {
  content: "";
  display: inline-block;
  width: 120px;
  height: 68px;
  background-image: url(../img/sakuragarden_birds.png);
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin-right: 0;
}
@media screen and (max-width: 1024.9px) {
  #lead .lead_title {
    font-size: 3.2rem;
    text-align: center;
    line-height: 3.2rem;
    margin-top: 4.8rem;
    margin-left: 70px;
  }
  #lead .lead_title::before {
    content: "";
    width: 120px;
    height: 70.4px;
  }
}
@media screen and (max-width: 767.9px) {
  #lead .lead_title {
    font-size: 2.4rem;
    text-align: center;
    margin-top: 3.2rem;
    margin-left: 0;
  }
  #lead .lead_title::before {
    content: "";
    width: 75px;
    height: 44px;
  }
}
#lead .lead_wrapper {
  border: 0px solid orange;
  margin-top: 8rem;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  background: url(../img/sakuragarden_mainBg.png) no-repeat;
  background-size: contain;
  background-position: top right;
}
@media screen and (max-width: 1024px) {
  #lead .lead_wrapper {
    margin-top: 4.8rem;
  }
}
@media screen and (max-width: 767.9px) {
  #lead .lead_wrapper {
    margin-top: 3.2rem;
  }
}
#lead .lead_left {
  flex-basis: 23%;
  align-self: flex-start;
}
#lead .lead_left img {
  width: 100%;
}
@media screen and (max-width: 1024.9px) {
  #lead .lead_left {
    flex-basis: 30%;
  }
}
@media screen and (max-width: 767.9px) {
  #lead .lead_left {
    display: none;
  }
}
@keyframes slide1 {
  0%, 100% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(5px, 0);
  }
}
#lead .lead_center {
  flex-basis: 54%;
  color: #573017;
  font-size: 1.84rem;
  line-height: 4.8rem;
  margin-top: 0;
  padding: 0 0 0 6%;
  border: 0px solid red;
  position: relative;
}
#lead .lead_center img.SubImg {
  width: 55%;
  margin-left: 5%;
}
#lead .lead_center .signature {
  margin-top: 6.4rem;
  margin-bottom: 6.4rem;
  text-align: center;
}
#lead .lead_center p {
  margin-bottom: 2.4rem;
}
@media screen and (max-width: 1024.9px) {
  #lead .lead_center {
    flex-basis: 70%;
    font-size: 1.8rem;
    line-height: 3.2rem;
    padding: 2% 2% 0 2%;
  }
}
@media screen and (max-width: 767.9px) {
  #lead .lead_center {
    font-size: 1.6rem;
    line-height: 2.56rem;
    flex-basis: 100%;
    padding: 0 4% 0 6%;
  }
}

.lead_right {
  border: 0px solid red;
  flex-basis: 23%;
  align-self: flex-end;
  justify-self: flex-end;
}
.lead_right img.leadImg {
  display: block;
  width: 100%;
  max-width: 500px;
  margin-left: auto;
  margin-right: 0;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .lead_right {
    display: flex;
    flex-basis: 100%;
    flex-direction: row-reverse;
    position: relative;
  }
  .lead_right img.leadImg {
    max-width: 35%;
    margin-top: 3.2rem;
  }
  .lead_right img.SubImg {
    width: 35%;
    position: absolute;
    bottom: 0;
    left: 28%;
    -o-object-fit: contain;
       object-fit: contain;
  }
}
@media screen and (max-width: 767.9px) {
  .lead_right {
    display: block;
    flex-basis: 100%;
    text-align: left;
  }
  .lead_right img.leadImg {
    width: 60%;
  }
  .lead_right img.SubImg {
    margin: 5rem 5% 5rem 5%;
    width: 60%;
  }
}

.baloon-lead {
  margin-left: 0;
  width: 32rem;
  height: 9rem;
  border-radius: 168px 80px 169px 105px/76px 56px 72px 72px;
  background-color: rgba(120, 116, 47, 0.2);
  padding: 2rem 2rem 2rem 4rem;
  position: absolute;
  bottom: 0rem;
  left: -6rem;
}
@media screen and (max-width: 1024px) {
  .baloon-lead {
    width: 30rem;
    height: 7rem;
    bottom: 0;
    left: 8rem;
    padding: 2rem 2rem 2rem 2rem;
  }
}
@media screen and (max-width: 767px) {
  .baloon-lead {
    margin: 5rem auto;
    width: 29rem;
    height: 6rem;
    bottom: -2rem;
    left: 10rem;
    padding: 2rem 2rem 2rem 4rem;
  }
}

.tooltip4 {
  position: relative;
  cursor: pointer;
  display: inline-block;
  color: #573017;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .tooltip4 {
    margin-left: 3rem;
  }
}

.description4 {
  display: none;
  position: absolute;
  line-height: 1.6em;
  color: #fff;
  border-radius: 169px 126px 186px 124px/100px 97px 13px 100px;
  background: #000;
  width: 28rem;
  height: 15rem;
  transform: rotateZ(0deg);
}
@media screen and (max-width: 1024px) {
  .description4 {
    width: 22rem;
  }
}
@media screen and (max-width: 767px) {
  .description4 {
    width: 24rem;
    border-radius: 186px 124px 169px 13px/124px 100px 126px 100px;
  }
}

.tooltip4:hover .description4 {
  padding-top: 3.2rem;
  padding-left: 2.4rem;
  padding-right: 2.4rem;
  display: inline-block;
  font-size: 1.6rem;
  top: -15rem;
  left: -20rem;
  text-indent: 0.8rem;
}
@media screen and (max-width: 1024px) {
  .tooltip4:hover .description4 {
    top: -22rem;
    left: -8rem;
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .tooltip4:hover .description4 {
    font-size: 1.5rem;
    top: -20rem;
    left: -2rem;
  }
}

.description5 {
  display: none;
  position: absolute;
  line-height: 1.6em;
  color: #fff;
  border-radius: 137px 163px 169px 183px/131px 174px 111px 133px;
  width: 300px;
  height: 250px;
  transform: rotateZ(0deg);
  background: radial-gradient(rgba(255, 255, 255, 0) 60%, rgb(255, 255, 255)), url(../img/sakuragarden_soil.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  border: 2px dashed #000;
}
@media screen and (max-width: 767px) {
  .description5 {
    border-radius: 137px 163px 169px 183px/131px 174px 111px 133px;
  }
}

.tooltip4:hover .description5 {
  padding-top: 3.2rem;
  padding-left: 2.4rem;
  padding-right: 2.4rem;
  display: block;
  font-size: 1.6rem;
  top: -38rem;
  left: -12rem;
  text-indent: 0.8rem;
}
@media screen and (max-width: 1024px) {
  .tooltip4:hover .description5 {
    top: -42rem;
    left: 7rem;
  }
}
@media screen and (max-width: 767px) {
  .tooltip4:hover .description5 {
    font-size: 1.5rem;
    top: -43rem;
    left: -10rem;
  }
}

#introduction {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
  font-weight: 500;
  margin: 0;
  padding-top: 5%;
  background: rgba(144, 177, 132, 0.1333333333);
  background-position: bottom left;
  background-repeat: no-repeat;
}
#introduction h2 {
  font-size: 3rem;
  text-align: center;
  line-height: 4rem;
  padding-top: 5%;
}
#introduction .profile {
  margin: 5% auto;
  padding-bottom: 5%;
  display: flex;
  justify-content: center;
  font-size: 1.3rem;
}
#introduction .name {
  padding: 0;
}
#introduction .image {
  justify-self: stretch;
}
#introduction .circle {
  width: 250px;
  height: 250px;
  border-radius: 50%;
  background-image: url(../img/sakuragarden_profile.jpg);
  background-repeat: no-repeat;
  background-position: center center;
}
#introduction .career {
  margin-left: 5%;
  line-height: 3rem;
}
@media screen and (max-width: 767px) {
  #introduction #introduction {
    padding-top: 10%;
    padding-bottom: 20%;
  }
  #introduction .profile {
    display: block;
    margin: 5% auto;
  }
  #introduction .image {
    margin: 0 auto;
  }
  #introduction .circle {
    width: 220px;
    height: 220px;
    margin: 0 auto;
  }
  #introduction .name {
    padding: 3%;
    text-align: center;
  }
  #introduction .career {
    line-height: 2.5rem;
    width: 68%;
    margin: 10% 16%;
  }
}
#introduction .youtube_wrapper {
  width: 100%;
  border: 1px solid #ccc;
  background: rgba(144, 177, 132, 0.3333333333);
  padding-bottom: 5%;
  text-align: center;
}
@media screen and (max-width: 767px) {
  #introduction .youtube_wrapper {
    padding-bottom: 10%;
  }
}
#introduction .youtube {
  padding: 5%;
  display: flex;
  justify-content: space-around;
  position: relative;
}
@media screen and (max-width: 767px) {
  #introduction .youtube {
    display: block;
    text-align: center;
  }
}
#introduction .title {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 2rem;
  position: absolute;
  left: 8rem;
  top: 1.6rem;
}
#introduction .ribbon {
  font-size: 28px;
  font-weight: bold;
  color: #fff;
}
#introduction .ribbon {
  --f: 0.5em;
  --r: 0.8em;
  position: absolute;
  left: 1.6rem;
  top: calc(-1 * var(--f));
  padding: 0.2em;
  background: #b3df5c;
  border-right: var(--f) solid rgba(0, 0, 0, 0.3333333333);
  border-bottom: var(--r) solid rgba(0, 0, 0, 0);
  -webkit-clip-path: polygon(calc(100% - var(--f)) 0, 0 0, 0 calc(100% - var(--r)), calc(50% - var(--f) / 2) 100%, calc(100% - var(--f)) calc(100% - var(--r)), calc(100% - var(--f)) var(--f), 100% var(--f));
          clip-path: polygon(calc(100% - var(--f)) 0, 0 0, 0 calc(100% - var(--r)), calc(50% - var(--f) / 2) 100%, calc(100% - var(--f)) calc(100% - var(--r)), calc(100% - var(--f)) var(--f), 100% var(--f));
}
#introduction .ribbon .emoji {
  font-weight: 300;
}
#introduction iframe {
  border-radius: 10px;
}
@media screen and (min-width: 1025px) {
  #introduction iframe {
    width: 420px;
    height: 236px;
  }
}
@media screen and (max-width: 1024px) {
  #introduction iframe {
    width: 300px;
    height: 169px;
    margin: 6rem auto 1.5rem auto;
  }
}
#introduction .comment {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.8rem;
}

/* =============================================================
 front-page : works/garden共通
============================================================= */
section {
  width: 100%;
  margin: 0;
  padding: 0;
}

.about {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #826841;
  font-size: 1.8rem;
  line-height: 4.8rem;
  text-align: center;
  margin-top: 4.8rem;
  margin-right: 4.8rem;
}
@media screen and (max-width: 767.9px) {
  .about {
    font-size: 1.6rem;
    line-height: 3.2rem;
    margin-right: auto;
    text-align: center;
  }
}

.viewmore {
  text-align: center;
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  margin-right: 4.8rem;
  color: #826841;
  font-size: 1.6rem;
  line-height: 3.2rem;
}
@media screen and (max-width: 767px) {
  .viewmore {
    margin-right: auto;
    text-align: center;
  }
}

.viewmore_link {
  position: relative;
  font-style: normal;
  padding: 0 4.8rem;
  color: #826841;
  font-size: 3.2rem;
}
@media screen and (max-width: 767px) {
  .viewmore_link .viewmore_link {
    font-size: 2.56rem;
    line-height: 4.8rem;
  }
}

/* =============================================================
 front-page : title/ separator
============================================================= */
#landscaping,
#landscaping-list,
#works-list,
#maintenance-list,
#planting-list,
#woodworking-list {
  position: relative;
  margin-top: 5%;
  padding-top: 10%;
  padding-bottom: 8%;
  background: #f2f2f2;
}
@media screen and (max-width: 767px) {
  #landscaping,
  #landscaping-list,
  #works-list,
  #maintenance-list,
  #planting-list,
  #woodworking-list {
    padding-bottom: 4.8rem;
  }
}
#landscaping h2,
#landscaping-list h2,
#works-list h2,
#maintenance-list h2,
#planting-list h2,
#woodworking-list h2 {
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  display: block;
  position: relative;
  text-align: center;
  font-style: normal;
  font-size: 6.4rem;
  line-height: 9.6rem;
  padding: 0 4.8rem;
  color: #573017;
}
@media screen and (max-width: 1024.9px) {
  #landscaping h2,
  #landscaping-list h2,
  #works-list h2,
  #maintenance-list h2,
  #planting-list h2,
  #woodworking-list h2 {
    font-size: 4.8rem;
    line-height: 9.6rem;
    margin-left: 28%;
  }
}
@media screen and (max-width: 767px) {
  #landscaping h2,
  #landscaping-list h2,
  #works-list h2,
  #maintenance-list h2,
  #planting-list h2,
  #woodworking-list h2 {
    font-size: 3.2rem;
    line-height: 4.8rem;
    margin-left: 10%;
  }
}
#landscaping h2::after,
#landscaping-list h2::after,
#works-list h2::after,
#maintenance-list h2::after,
#planting-list h2::after,
#woodworking-list h2::after {
  position: absolute;
  top: 0;
  left: 70%;
  transform: scale(0.6);
}
@media screen and (max-width: 767px) {
  #landscaping h2::after,
  #landscaping-list h2::after,
  #works-list h2::after,
  #maintenance-list h2::after,
  #planting-list h2::after,
  #woodworking-list h2::after {
    top: 15%;
    left: 40%;
    transform: scale(0.3);
  }
}
#landscaping h4,
#landscaping-list h4,
#works-list h4,
#maintenance-list h4,
#planting-list h4,
#woodworking-list h4 {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  display: block;
  position: relative;
  font-style: normal;
  text-align: center;
  font-size: 1.8rem;
  color: #573017;
  line-height: 3rem;
}
@media screen and (max-width: 767px) {
  #landscaping h4,
  #landscaping-list h4,
  #works-list h4,
  #maintenance-list h4,
  #planting-list h4,
  #woodworking-list h4 {
    font-size: 1.6rem;
  }
}
#landscaping .separator-right,
#landscaping .separator-left,
#landscaping-list .separator-right,
#landscaping-list .separator-left,
#works-list .separator-right,
#works-list .separator-left,
#maintenance-list .separator-right,
#maintenance-list .separator-left,
#planting-list .separator-right,
#planting-list .separator-left,
#woodworking-list .separator-right,
#woodworking-list .separator-left {
  position: relative;
}
#landscaping .separator-left::before,
#landscaping-list .separator-left::before,
#works-list .separator-left::before,
#maintenance-list .separator-left::before,
#planting-list .separator-left::before,
#woodworking-list .separator-left::before {
  content: "";
  position: absolute;
  background-repeat: repeat;
  right: 72%;
  top: 1.6rem;
  width: 28%;
  height: 3.2rem;
}
#landscaping .separator-right::before,
#landscaping-list .separator-right::before,
#works-list .separator-right::before,
#maintenance-list .separator-right::before,
#planting-list .separator-right::before,
#woodworking-list .separator-right::before {
  content: "";
  position: absolute;
  background-repeat: repeat;
  left: 75%;
  top: 0;
  width: 25%;
  height: 3.2rem;
}

#landscaping h2,
#landscaping-list h2,
#planting-list h2 {
  font-size: 6rem;
}
@media screen and (max-width: 767.9px) {
  #landscaping h2,
  #landscaping-list h2,
  #planting-list h2 {
    font-size: 3rem;
  }
  #landscaping h4,
  #landscaping-list h4,
  #planting-list h4 {
    font-size: 1.5rem;
  }
}

#works-list .separator-left::before {
  background: url(../img/sakuragarden_Bgworks.png);
}
#works-list .separator-right::before {
  background: url(../img/sakuragarden_Bgworks.png);
}

#landscaping .separator-left::before,
#landscaping-list .separator-left::before {
  background: url(../img/sakuragarden_Bglandscaping.png);
}
#landscaping .separator-right::before,
#landscaping-list .separator-right::before {
  background: url(../img/sakuragarden_Bglandscaping.png);
}

#maintenance-list h2::after {
  content: url(../img/service_maintenance_title.png);
}
#maintenance-list .separator-left::before {
  background: url(../img/sakuragarden_Bgmaintenance.png);
}
#maintenance-list .separator-right::before {
  background: url(../img/sakuragarden_Bgmaintenance.png);
}

#planting-list h2::after {
  content: url(../img/service_planting_title.png);
}
#planting-list .separator-left::before {
  background: url(../img/sakuragarden_Bgplanting.png);
}
#planting-list .separator-right::before {
  background: url(../img/sakuragarden_Bgplanting.png);
}

#woodworking-list h2::after {
  content: url(../img/service_woodworking_title.png);
}
#woodworking-list .separator-left::before {
  background: url(../img/sakuragarden_Bgwoodworking.png);
  opacity: 0.5;
}
#woodworking-list .separator-right::before {
  background: url(../img/sakuragarden_Bgwoodworking.png);
  opacity: 0.5;
}

.gallery {
  margin-top: 12.8rem;
  margin-left: 10%;
  margin-right: 10%;
  -moz-columns: 3;
       columns: 3;
  padding: 0 15px;
}
.gallery li {
  margin-bottom: 20px;
}
.gallery img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
@media screen and (max-width: 1024px) {
  .gallery {
    -moz-columns: 3;
         columns: 3;
    width: 96%;
    margin-left: 2%;
    margin-right: 2%;
  }
}
@media screen and (max-width: 767px) {
  .gallery {
    width: 96%;
    margin-left: 2%;
    margin-right: 2%;
    padding: 0 5px;
    -moz-columns: 2;
         columns: 2;
  }
}

/* =============================================================
 front-page : garden
============================================================= */
#gardening {
  position: relative;
  padding-top: 8%;
  padding-bottom: 8%;
  background: rgba(219, 216, 206, 0.4);
}
@media screen and (max-width: 767px) {
  #gardening {
    padding-top: 15%;
  }
}
#gardening::before {
  content: "";
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  z-index: 10;
  display: block;
  height: 4px;
  background-size: 4px 100%;
  background-image: linear-gradient(135deg, #f2f2f2 25%, transparent 25%), linear-gradient(225deg, #f2f2f2 25%, transparent 25%);
  background-position: 0 0;
}
#gardening::after {
  content: "";
  position: absolute;
  right: 0;
  left: 0;
  bottom: -4px;
  z-index: 10;
  display: block;
  height: 4px;
  background-size: 4px 4px;
  background-image: linear-gradient(135deg, #f3ead8 25%, transparent 25%), linear-gradient(225deg, #f3ead8 25%, transparent 25%);
  background-position: 0 0;
}

#gardening h2, #gardening-list h2 {
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  position: relative;
  font-size: 2.6rem;
  color: #573017;
  text-align: center;
  display: block;
}
#gardening .fukidashi span, #gardening-list .fukidashi span {
  position: relative;
}
#gardening .fukidashi span::before,
#gardening .fukidashi span::after, #gardening-list .fukidashi span::before,
#gardening-list .fukidashi span::after {
  content: "";
  display: inline-block;
  background: #573017;
  width: 3px;
  position: absolute;
}
#gardening .fukidashi span::before, #gardening-list .fukidashi span::before {
  left: -30px;
  top: 20px;
}
#gardening .fukidashi span::after, #gardening-list .fukidashi span::after {
  right: -30px;
  top: 20px;
}
@media screen and (min-width: 768px) {
  #gardening .fukidashi span, #gardening-list .fukidashi span {
    padding: 0 30px;
  }
  #gardening .fukidashi span::before,
  #gardening .fukidashi span::after, #gardening-list .fukidashi span::before,
  #gardening-list .fukidashi span::after {
    height: 50px;
    bottom: -20px;
  }
  #gardening .fukidashi span::before, #gardening-list .fukidashi span::before {
    transform: rotate(-30deg);
  }
  #gardening .fukidashi span::after, #gardening-list .fukidashi span::after {
    transform: rotate(30deg);
  }
}
@media screen and (max-width: 767px) {
  #gardening .fukidashi span, #gardening-list .fukidashi span {
    display: inline-block;
    padding: 0 20px;
  }
  #gardening .fukidashi span::before,
  #gardening .fukidashi span::after, #gardening-list .fukidashi span::before,
  #gardening-list .fukidashi span::after {
    height: 60px;
    bottom: -5px;
  }
  #gardening .fukidashi span::before, #gardening-list .fukidashi span::before {
    transform: rotate(-20deg);
  }
  #gardening .fukidashi span::after, #gardening-list .fukidashi span::after {
    transform: rotate(20deg);
  }
}

.group-slider {
  margin-top: 7rem;
  height: 80vh;
  width: 80%;
}
@media screen and (max-width: 767px) {
  .group-slider {
    margin-top: 5rem;
    height: 130.5vw;
    width: 90%;
  }
}
.group-slider .swiper-slide {
  height: 80vh;
}
@media screen and (max-width: 767px) {
  .group-slider .swiper-slide {
    height: 50%;
  }
}
.group-slider .swiper-slide img {
  height: 80vh;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 767px) {
  .group-slider .swiper-slide img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.group-slider .img-cover {
  width: 100%;
  height: 100%;
}
.group-slider .img-cover img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom center;
     object-position: bottom center;
}
.group-slider .left-img img {
  border-radius: 10px 0 0 5px;
  border-right: 2px solid white;
}
@media screen and (max-width: 767px) {
  .group-slider .left-img img {
    border-radius: 0px;
    border-right: 0px;
    border-bottom: 2px solid white;
  }
}
.group-slider .right-img img {
  border-radius: 0 5px 5px 0;
}
@media screen and (max-width: 767px) {
  .group-slider .right-img img {
    border-radius: 0px;
  }
}
.group-slider .swiper-title {
  line-height: 2.5rem;
  text-align: center;
}
.group-slider .swiper-button-prev, .group-slider .swiper-button-next {
  position: absolute;
  z-index: 1;
  top: 0;
  bottom: 0;
  margin: auto;
}
.group-slider .swiper-button-prev, .group-slider .swiper-button-next {
  display: grid;
  width: 5rem;
  height: 5rem;
  cursor: pointer;
  transition: 0.8s cubic-bezier(0.2, 1, 0.2, 1);
}
.group-slider .swiper-button-prev::before, .group-slider .swiper-button-next::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
  border-radius: 50%;
  background-color: rgba(0, 0, 0, 0.4);
  box-shadow: 0.8rem 0.8rem 1.2rem rgba(0, 0, 0, 0.1), -0.8rem -0.8rem 1.2rem rgba(255, 255, 255, 0.2);
  transition: 0.8s cubic-bezier(0.2, 1, 0.2, 1);
}
.group-slider .swiper-button-prev:hover::before, .group-slider .swiper-button-next:hover::before {
  transform: scale(1.2);
}
.group-slider .swiper-button-prev::after, .group-slider .swiper-button-next::after {
  width: 1.5rem;
  height: 1.5rem;
  content: "";
  border: solid #ddd;
  border-width: 3px 3px 0 0;
  border-color: #fff;
}
.group-slider .swiper-button-prev::after {
  margin-left: 0.8rem;
  transform: rotate(-135deg);
}
.group-slider .swiper-button-next::after {
  margin-right: 0.8rem;
  transform: rotate(45deg);
}
.group-slider .swiper-button-disabled {
  pointer-events: none;
  opacity: 0;
}
.group-slider .swiper-slide:not(.swiper-slide-visible) .slide {
  pointer-events: none;
  opacity: 0.3;
}
.group-slider .swiper-pagination {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 0 0.8rem;
  justify-content: center;
}
@media only screen and (min-width: 769px) {
  .group-slider .swiper-slide:first-child {
    transition: transform 100ms;
  }
  .group-slider .swiper-slide:first-child img {
    transition: box-shadow 500ms;
  }
  .group-slider .swiper-slide.swiper-slide-active:first-child {
    transform: translateX(50%);
    z-index: 2;
  }
  .group-slider .swiper-slide.swiper-slide-active:first-child img {
    box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 1px;
  }
  .group-slider .swiper-slide:nth-child(2) {
    transition: transform 100ms;
  }
  .group-slider .swiper-slide.swiper-slide-next:nth-child(2) {
    transform: translateX(55%);
    z-index: 1;
  }
  .group-slider .swiper[dir=rtl] .swiper-slide.swiper-slide-active:first-child {
    transform: translateX(-50%);
  }
  .group-slider .swiper[dir=rtl] .swiper-slide.swiper-slide-next:nth-child(2) {
    transform: translateX(-55%);
  }
}

/* =============================================================
    front-page : parallax
============================================================= */
.parallax {
  margin: 0;
  padding: 0;
}

.parallax .panel {
  height: 100%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .parallax .panel {
    height: 20%;
  }
}

.parallax .panel figure {
  margin: 0;
  padding: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 85%, rgba(255, 255, 255, 0.8) 90%, rgb(255, 255, 255) 100%), url(../img/sakuragarden_parallax.jpg);
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .parallax .panel figure {
    height: 40%;
  }
}

/* =============================================================
    front-page : services
============================================================= */
#services {
  margin-top: 0;
  padding-top: 40%;
}
@media screen and (max-width: 767px) {
  #services {
    padding-top: 80%;
  }
}
#services h2 {
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-weight: 500;
  font-style: normal;
  position: relative;
  font-style: normal;
  line-height: 6.4rem;
  color: #f2f2f2;
  font-size: 4.8rem;
  text-align: center;
  margin: 5% 0;
}
@media screen and (max-width: 1024px) {
  #services h2 {
    font-size: 3.2rem;
  }
}
#services img {
  width: 100%;
}
#services .wrapper {
  width: 100%;
  padding-bottom: 9.6rem;
  background: #3c6450;
  position: relative;
}
@media screen and (max-width: 767px) {
  #services .wrapper {
    padding-bottom: 15%;
  }
}
#services .wrapper::before {
  content: "";
  padding-top: -8px;
  right: 0;
  left: 0;
  top: -4px;
  position: absolute;
  background: linear-gradient(45deg, #fff 50%, transparent 52%), linear-gradient(315deg, #fff 50%, transparent 52%);
  background-size: 30px 30px;
  height: 4px;
  background-size: 4px 100%;
  z-index: 10;
}
#services .services-wrapper {
  width: 80%;
  margin: 5% 10% 0 10%;
  display: flex;
  justify-content: space-between;
  flex: 1;
}
@media screen and (max-width: 1024px) {
  #services .services-wrapper {
    width: 100%;
    margin: 0;
  }
}
@media screen and (max-width: 767px) {
  #services .services-wrapper {
    display: block;
    width: 90%;
    margin: 0 5%;
  }
}
#services .services-wrapper .item-wrapper {
  width: 33.3%;
  justify-self: center;
  background-color: none;
  position: relative;
  margin: 0;
  padding: 0 5%;
  border-right: 2px dashed #f2f2f2;
}
@media screen and (max-width: 1024px) {
  #services .services-wrapper .item-wrapper {
    padding: 0 2%;
  }
}
@media screen and (max-width: 767px) {
  #services .services-wrapper .item-wrapper {
    width: 100%;
    border-right: 0px dashed #f2f2f2;
    border-bottom: 2px dashed #f2f2f2;
    padding: 5% 0% 10% 0;
  }
}
#services .services-wrapper .item-wrapper:last-of-type {
  border-right: 0px solid #ffffff;
  border-bottom: 0px solid #ffffff;
  padding-bottom: 0;
}
#services .services-wrapper .item-wrapper .text {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  margin-top: 3.2rem;
  font-size: 1.6rem;
  color: #fff;
}
@media screen and (max-width: 767px) {
  #services .services-wrapper .item-wrapper .text {
    text-align: center;
  }
}
#services .services-wrapper .item-wrapper img {
  display: block;
  width: 100%;
  text-align: center;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #services .services-wrapper .item-wrapper img {
    width: 50%;
  }
}
#services .services-wrapper .item-wrapper h3 {
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  position: relative;
  display: inline-block;
  margin-top: 2rem;
  margin-bottom: 1rem;
  width: 100%;
  font-size: 2.4rem;
  line-height: 3rem;
  text-align: center;
  color: #ffffff;
}

.c-underline--gradient {
  padding: 1rem 0;
  margin-bottom: 1.6rem;
  background-image: linear-gradient(90deg, #b2d5de 0 25%, #ddcfb3 25% 50%, #b3ddb4 50% 75%, #ddbab3 75%);
  background-repeat: no-repeat;
  background-size: 50% 0.3rem;
  background-position: bottom;
  text-align: center;
}

.c-underline--stripe {
  padding: 1rem;
  background-image: repeating-linear-gradient(-45deg, #e778a5, #e778a5 4px, transparent 4px, transparent 8px);
  background-position: center bottom;
  background-repeat: repeat-x;
  background-size: auto 4px;
}

.button-052 {
  display: flex;
  align-items: center;
  position: relative;
  min-width: 17.6rem;
  margin: 1.6rem auto 0 auto;
  padding: 0.5rem 1rem;
  border: none;
  border-radius: 25px;
  background-color: #f2f2f2;
  font-weight: 600;
}

.button-052 span:first-child {
  margin: 0;
  padding: 0.5rem;
  border-radius: 50%;
  color: #573017;
  font-size: 1.2rem;
}

.button-052 span:last-child {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #573017;
  font-size: 1.6rem;
}

.button-052::after {
  position: absolute;
  right: 1rem;
  transform: rotate(45deg);
  width: 5px;
  height: 5px;
  border-top: 2px solid #573017;
  border-right: 2px solid #573017;
  content: "";
}

.button-052:hover {
  background-color: #b6b6b6;
}

/* =============================================================
    front-page : instagram
============================================================= */
#instagram {
  background-color: #fafafa;
  padding-bottom: 4.8rem;
}

#instagram h2 {
  font-family: "Caveat", cursive;
  position: relative;
  font-style: normal;
  font-size: 3.2rem;
  padding: 4.8rem;
  margin-left: 0;
  text-align: left;
  line-height: 4.8rem;
  color: #573017;
  background-image: url(../img/sakuragarden_leaves.png);
  background-repeat: no-repeat;
  background-size: 25%;
  background-position: bottom left;
}
@media screen and (max-width: 767px) {
  #instagram h2 {
    padding: 4.8rem 0 3.2rem 0;
    background-size: 65%;
    margin-bottom: 3.2rem;
  }
}

#instagram .fa-instagram {
  margin-right: 1rem;
}

/* =============================================================
   共通 : contact
============================================================= */
#contact {
  display: grid;
  grid-template-columns: 0.6fr 0.5fr 2fr 0.5fr 0.6fr;
  grid-template-rows: 0.2fr repeat(2, 1fr) 0.5fr 1fr;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  background: #fafafa;
  padding-bottom: 8%;
}
#contact .wrapper {
  grid-area: 2/2/5/5;
  align-self: start;
  width: 100%;
  justify-self: stretch;
  margin: 0;
  background: repeating-linear-gradient(315deg, #c8cf8d, #61875f 3px, #fafafa 0, #fafafa 6px);
  padding: 15px;
}

#contact .baloon-1 {
  grid-area: 1/1/3/3;
  align-self: end;
  justify-self: center;
  background: url(../img/baloon-1.png) no-repeat;
  position: relative;
}

#contact .baloon-1 {
  background-size: 95%;
  width: 265px;
  height: 151px;
  font-size: 2rem;
  border: 0px solid orange;
}

#contact .baloon-1 .bl1 {
  position: absolute;
  top: 4.48rem;
  left: 2.24rem;
}

#contact .baloon-2 {
  grid-area: 4/1/5/3;
  align-self: flex-end;
  justify-self: center;
  border: 0px solid blue;
  background: url(../img/baloon-2.png) no-repeat;
  position: relative;
}

#contact .baloon-2 {
  background-size: 95%;
  width: 221px;
  height: 65px;
  font-size: 1.6rem;
}

#contact .baloon-2 .bl2 {
  position: absolute;
  top: 1.28rem;
  left: 1.92rem;
}

#contact .baloon-3 {
  grid-area: 4/3/6/5;
  align-self: end;
  justify-self: center;
  background: url(../img/baloon-3.png) no-repeat;
  position: relative;
}

#contact .baloon-3 {
  background-size: 90%;
  width: 367px;
  height: 170px;
  border: 0px solid red;
}

#contact .baloon-3 .bl3 {
  position: absolute;
  font-size: 2rem;
  top: 6.08rem;
  left: 2.4rem;
}

#contact .baloon-4 {
  grid-area: 3/4/4/6;
  align-self: end;
  justify-self: center;
  position: relative;
  background: url(../img/baloon-4.png) no-repeat;
  border: 0px solid yellow;
}

#contact .baloon-4 {
  background-size: 95%;
  width: 228px;
  height: 83px;
  font-size: 1.92rem;
}

#contact .baloon-4 .bl4 {
  position: absolute;
  top: 1.92rem;
  left: 4rem;
}

#contact .baloon-5 {
  grid-area: 1/4/3/6;
  align-self: end;
  justify-self: center;
  position: relative;
  background: url(../img/baloon-5.png) no-repeat;
  border: 0px solid purple;
}

#contact .baloon-5 {
  background-size: 90%;
  width: 251px;
  height: 146px;
  font-size: 1.8rem;
}

#contact .baloon-5 .bl5 {
  position: absolute;
  top: 4rem;
  left: 3.2rem;
}

#contact .inner {
  background: #fafafa;
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.8rem;
  padding: 5rem;
  line-height: 4.8rem;
  text-align: center;
  background: url(../img/sakuragarden_mole2.png) #fafafa no-repeat;
  background-size: 20%;
  background-position: bottom right;
}

#contact .mitsumori {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 3rem;
  text-shadow: 1px 1px 2px rgb(206, 206, 206);
}

.marker {
  background: linear-gradient(transparent 50%, rgba(255, 102, 204, 0.4274509804) 50%);
  display: inline;
  background-repeat: no-repeat;
  background-size: 0% 100%;
  transition: background-size 1.5s;
}
@media screen and (max-width: 1024px) {
  .marker {
    font-size: 1.5rem;
  }
}

.marker.on {
  background-size: 100% 100%;
}

.button_wrapper {
  margin: 0;
  display: flex;
}

.button {
  padding-right: 0.8rem;
  margin: 5rem auto 4rem auto;
  background: #52a140;
  box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 2.6px;
  border-radius: 5px;
  color: white;
  cursor: pointer;
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 1.8rem;
  height: 65px;
  letter-spacing: 0.2px;
  line-height: 65px;
  text-align: center;
  text-transform: uppercase;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  width: 32.4rem;
  transition: all 0.3s ease-in;
}

.button .emoji {
  padding: 0 0.8rem;
}

.button:hover {
  background: #559048;
}

.button:active {
  box-shadow: inset 0px 4px 8px -1px #3a6e2e;
}

.fancy-button {
  margin: auto;
  position: relative;
}

.frills, .frills:after, .frills:before {
  position: absolute;
  background: #559048;
  border-radius: 3px;
  height: 3px;
}

.frills:after, .frills:before {
  content: "";
  display: block;
}

.frills:before {
  bottom: 45px;
}

.frills:after {
  top: 45px;
}

.left-frills {
  right: 314px;
  top: 28.5px;
  margin: 5rem auto;
}

.active .left-frills {
  animation: move-left 0.38s ease-out, width-to-zero 0.38s ease-out;
}

.left-frills:before, .left-frills:after {
  left: 15px;
}

.active .left-frills:before {
  animation: width-to-zero 0.38s ease-out, move-up 0.38s ease-out;
}

.active .left-frills:after {
  animation: width-to-zero 0.38s ease-out, move-down 0.38s ease-out;
}

.right-frills {
  left: 314px;
  top: 28.5px;
  margin: 4rem auto;
}

.active .right-frills {
  animation: move-right 0.38s ease-out, width-to-zero 0.38s ease-out;
}

.right-frills:before, .right-frills:after {
  right: 15px;
}

.active .right-frills:before {
  animation: width-to-zero 0.38s ease-out, move-up 0.38s ease-out;
}

.active .right-frills:after {
  animation: width-to-zero 0.38s ease-out, move-down 0.38s ease-out;
}

.left-frills:before, .right-frills:after {
  transform: rotate(45deg);
}

.left-frills:after, .right-frills:before {
  transform: rotate(-45deg);
}

@keyframes move-left {
  0% {
    transform: none;
  }
  65% {
    transform: translateX(-50px);
  }
  100% {
    transform: translateX(-50px);
  }
}
@keyframes move-right {
  0% {
    transform: none;
  }
  65% {
    transform: translateX(50px);
  }
  100% {
    transform: translateX(50px);
  }
}
@keyframes width-to-zero {
  0% {
    width: 38px;
  }
  100% {
    width: 8px;
  }
}
@keyframes move-up {
  100% {
    bottom: 69.75px;
  }
}
@keyframes move-down {
  100% {
    top: 69.75px;
  }
} 
@media screen and (max-width: 1024px) {
  #contact {
    display: grid;
    grid-template-columns: 0.2fr 0.5fr 2fr 0.5fr 0.3fr;
    grid-template-rows: 0.6fr repeat(2, 1fr) 0.6fr 0.6fr;
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    font-family: "vdl-penletter", sans-serif;
    font-style: normal;
    font-weight: 500;
  }
  #contact .wrapper {
    grid-area: 2/2/5/5;
    align-self: start;
    width: 100%;
    justify-self: stretch;
    margin: 0;
  }
  #contact .baloon-1 {
    grid-area: 1/1/3/3;
    align-self: start;
  }
  #contact .baloon-1 {
    width: 212px;
    height: 120px;
    font-size: 1.6rem;
  }
  #contact .baloon-1 .bl1 {
    top: 2.7rem;
    left: 2rem;
  }
  #contact .baloon-2 {
    grid-area: 4/1/5/3;
    justify-self: stretch;
    background-size: 95%;
    margin-left: 10%;
    font-size: 1.6rem;
  }
  #contact .baloon-2 .bl2 {
    position: absolute;
    top: 1.28rem;
    left: 1.92rem;
  }
  #contact .baloon-3 {
    align-self: flex-end;
    width: 275px;
    height: 128px;
  }
  #contact .baloon-3 .bl3 {
    position: absolute;
    font-size: 1.6rem;
    top: 4.5rem;
    left: 2.4rem;
  }
  #contact .baloon-4 {
    grid-area: 4/4/3/6;
    font-size: 1.6rem;
    margin-left: auto;
    justify-self: stretch;
    align-self: flex-end;
    width: 182px;
    height: 66px;
  }
  #contact .baloon-4 .bl4 {
    position: absolute;
    top: 1.6rem;
    left: 4rem;
  }
  #contact .baloon-5 {
    grid-area: 1/4/3/6;
    font-size: 1.6rem;
    width: 220px;
    height: 128px;
  }
  #contact .baloon-5 .bl5 {
    position: absolute;
    top: 4rem;
    left: 3.2rem;
  }
  .button-2 {
    margin-top: 2.4rem;
    line-height: 6rem;
    font-size: 2.2rem;
  }
  .button-2 img {
    width: 6rem;
  }
}
@media screen and (max-width: 767px) {
  #contact {
    display: block;
    width: 100%;
    margin: 0;
  }
  #contact .wrapper {
    width: 94%;
    margin: 0 auto;
    font-size: 2rem;
    background: repeating-linear-gradient(315deg, #cec887, #cec887 3px, #fafafa 0, #fafafa 6px);
    padding: 10px;
  }
  #contact .mitsumori {
    font-size: 2.4rem;
    line-height: 5rem;
  }
  #contact .inner {
    background: #fafafa;
    font-size: 1.6rem;
    padding: 2.4rem 1.4rem 1.6rem 1.4rem;
    line-height: 2.4rem;
  }
  #contact .baloon-1 {
    margin-top: 2.4rem;
  }
  #contact .baloon-1,
  #contact .baloon-2,
  #contact .baloon-3,
  #contact .baloon-4,
  #contact .baloon-5 {
    background: none;
    margin-left: 0;
    width: auto;
    height: auto;
    border: 0;
    text-align: left;
    text-indent: -1.2rem;
    padding-left: 1.2rem;
  }
  #contact .baloon-1 .bl1,
  #contact .baloon-2 .bl2,
  #contact .baloon-3 .bl3,
  #contact .baloon-4 .bl4,
  #contact .baloon-5 .bl5 {
    position: relative;
    top: 0;
    left: 0;
    font-size: 1.6rem;
  }
  #contact .baloon-1 .bl1::before,
  #contact .baloon-2 .bl2::before,
  #contact .baloon-3 .bl3::before,
  #contact .baloon-4 .bl4::before,
  #contact .baloon-5 .bl5::before {
    content: "☑️";
    font-family: "Noto Emoji", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.2rem;
  }
}
/* =============================================================
   共通 : footer
============================================================= */
footer {
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.6rem;
  position: relative;
  background-color: rgba(169, 193, 154, 0.6);
}

footer .custom-shape-divider-top-1692599638 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  overflow: hidden;
  line-height: 0;
  transform: rotate(180deg);
}

footer .custom-shape-divider-top-1692599638 svg {
  position: relative;
  display: block;
  width: calc(190% + 1.3px);
  height: 68px;
  transform: rotateY(180deg);
}

footer .custom-shape-divider-top-1692599638 .shape-fill {
  fill: #fafafa;
}

footer .information {
  display: flex;
  justify-content: center;
  align-items: stretch;
}
@media screen and (max-width: 1024px) {
  footer .information {
    display: block;
  }
}
footer .information .info-img {
  justify-self: center;
}
footer .information .info-img img {
  width: 100%;
}
footer .information .info-txt {
  min-width: 50%;
  padding-left: 5%;
  padding-top: 0;
  align-self: stretch;
  justify-self: stretch;
}
footer .information .info-txt h1 {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  margin-top: 5%;
  color: #573017;
  font-size: 2.4rem;
  line-height: 3.2rem;
}
@media screen and (max-width: 767px) {
  footer .information .info-txt h1 {
    font-size: 1.8rem;
    line-height: 2.4rem;
  }
}
footer .information .info-txt h2 {
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #573017;
  font-size: 4.8rem;
  line-height: 5rem;
}
@media screen and (max-width: 767px) {
  footer .information .info-txt h2 {
    font-size: 2.4rem;
    line-height: 3rem;
  }
}
footer .information .info-txt h3 {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #573017;
  font-size: 1.4rem;
  line-height: 3rem;
}
footer .information .info-txt .bussiness-area,
footer .information .info-txt .copy {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
  font-weight: 500;
  color: #573017;
  margin-top: 1.6rem;
  margin-left: 1.6rem;
  line-height: 2.4rem;
}
@media screen and (max-width: 767px) {
  footer .information .info-txt .bussiness-area,
  footer .information .info-txt .copy {
    font-size: 1.4rem;
    margin-top: 1.6rem;
    margin-left: 0;
    line-height: 1.8rem;
  }
}

footer .footer-nav {
  padding-top: 9rem;
  padding-bottom: 3.2rem;
  color: #573017;
}

footer .footer-nav ul {
  flex-wrap: wrap;
  flex-direction: row;
  font-size: 1.4rem;
  line-height: 3.2rem;
  font-weight: 500;
  display: flex;
  justify-content: end;
  margin-right: 9rem;
}
@media screen and (max-width: 767px) {
  footer .footer-nav ul {
    margin: 0 2%;
    line-height: 1.6rem;
    font-size: 1.3rem;
  }
}

footer .footer-nav li::before {
  font-size: 1.6rem;
  content: "■";
  color: #90b184;
  margin-left: 0.8rem;
  margin-right: 0.8rem;
}
@media screen and (max-width: 767px) {
  footer .footer-nav li::before {
    font-size: 1.2rem;
    margin-left: 0.8rem;
    margin-right: 0;
  }
}

footer .footer-nav li:first-of-type::before,
footer .footer-nav li:nth-of-type(2)::before {
  font-size: 1.6rem;
  content: none;
  color: #90b184;
  margin-left: 0.8rem;
  margin-right: 0.8rem;
}

footer .footer-nav li:first-of-type::after {
  font-size: 1.6rem;
  content: "▶";
  color: #90b184;
  margin-left: 1.6rem;
  margin-right: 1.6rem;
}
@media screen and (max-width: 767px) {
  footer .footer-nav li:first-of-type::after {
    margin-left: 0;
    margin-right: 0;
  }
}

footer .footer-nav ul a {
  color: #573017;
}

/* =============================================================
   固定 : single header
============================================================= */
/*top 波型*/
.shapedividers_com-1776 {
  overflow: hidden;
  position: relative;
}

.shapedividers_com-1776::before {
  content: "";
  font-family: "shape divider from ShapeDividers.com";
  position: absolute;
  z-index: 3;
  pointer-events: none;
  background-repeat: no-repeat;
  bottom: -0.1vw;
  left: -0.1vw;
  right: -0.1vw;
  top: -0.1vw;
  background-size: 400% 14px;
  background-position: 43% 0%;
  transform: rotateY(180deg);
  background-image: url('data:image/svg+xml;charset=utf8, <svg preserveAspectRatio="none" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2224 79"><g fill="%23c3d8b6"><path d="M1286 63a29 29 0 01-12 7c-12 3-24 0-36-5l-25-11a77 77 0 00-9-3 61 61 0 00-8-2 52 52 0 00-6 0 64 64 0 00-37 11l-10 8c-5 3-10 6-15 6-6 0-12-3-17-7l-8-5a94 94 0 00-37-16 104 104 0 00-36 0h-3l-2 1a94 94 0 00-35 15l-18 13c-7 4-14 5-21 3-6-1-11-6-12-12-1 6-6 11-12 12-8 2-15 0-22-3s-12-9-18-13a90 90 0 00-15-9 97 97 0 00-21-7 102 102 0 00-57 5 93 93 0 00-14 7l-6 4c-7 5-15 12-24 12-10 0-18-8-26-14a61 61 0 00-10-5 65 65 0 00-14-5 63 63 0 00-10-1 62 62 0 00-17 2l-6 2a159 159 0 00-17 7l-11 5c-11 5-24 8-36 5a29 29 0 01-13-8 24 24 0 01-7-13 18 18 0 010-6c1-7 4-14 8-23l10-20h660a885 885 0 0123 27c6 7 9 12 10 16 1 8-2 15-8 20z" style="isolation:isolate" opacity=".5"/><path d="M1461 46l-1 2a33 33 0 01-16 17c-12 5-25 5-38 1a84 84 0 01-19-9l-10-6-18-10a133 133 0 00-16-7 138 138 0 00-30-7 142 142 0 00-29 0 137 137 0 00-52 15l-6 4-13 8-19 11c-13 6-28 10-42 7a36 36 0 01-9-4c-10-5-17-15-17-25 0 10-7 19-15 24a37 37 0 01-11 5c-14 3-29-1-42-7l-31-19-7-4a138 138 0 00-59-15 141 141 0 00-46 5 132 132 0 00-21 9l-15 8-7 4a173 173 0 01-19 10c-10 4-21 7-32 6a40 40 0 01-13-4 33 33 0 01-14-14c-4-7-5-16-1-24a76 76 0 014-7 91 91 0 0118-20h622a91 91 0 0121 25l2 2a24 24 0 011 19z" style="isolation:isolate" opacity=".6"/><path d="M659 39l-4-9-25-30H0v43a97 97 0 0138-1 89 89 0 0136 15l17 12c6 4 13 5 20 3 6-1 11-6 11-12 1 6 6 11 12 12 6 2 14 0 20-3s11-8 17-12a83 83 0 0110-7 93 93 0 0143-10 93 93 0 0143 10 83 83 0 0110 7l17 12c6 4 13 5 20 3 6-1 11-6 11-12 1 6 6 11 12 12 7 2 14 0 20-3s11-8 17-12a89 89 0 0136-15c24-5 50 0 70 15 6 4 13 10 20 11a18 18 0 003 0c7 0 13-5 19-9l5-3a61 61 0 0148-9 73 73 0 018 2l16 7 8 4a55 55 0 0034 5 27 27 0 009-5 25 25 0 009-11 18 18 0 000-10z" style="isolation:isolate" opacity=".5"/><path d="M852 33a21 21 0 00-2-6 91 91 0 00-23-27H0v64c13-6 24-15 37-22h1l9-4a141 141 0 01109-1 130 130 0 0125 13l23 13a74 74 0 0020 5 74 74 0 0020-5l23-13 17-9 8-4a141 141 0 01109 1l9 4h1l37 23c13 7 28 10 42 7a36 36 0 0010-4c8-5 14-12 16-21a23 23 0 000-4 23 23 0 001 3 28 28 0 005 13 37 37 0 0021 13c14 3 29-1 42-8a124 124 0 0014-8l23-14a132 132 0 0117-7 138 138 0 0116-5c29-7 61-4 89 8l5 3 31 17 9 5c10 4 22 7 32 6a40 40 0 0013-4 33 33 0 0017-19 26 26 0 001-13z" style="isolation:isolate" opacity=".6"/><path d="M0 38a12 12 0 010 3 12 12 0 010-3zM2031 64c-12 3-23 0-34-4-7-3-13-7-20-9a78 78 0 00-12-4 60 60 0 00-48 8l-11 8c-4 3-8 5-13 5s-9-1-13-4l-10-7a85 85 0 00-14-8l-7-3a96 96 0 00-53-4 89 89 0 00-32 15l-17 12c-6 4-14 5-20 3-6-1-11-6-12-12-1 6-6 11-11 12-7 2-14 0-20-3s-12-8-17-12a85 85 0 00-13-8 95 95 0 00-68-5 89 89 0 00-13 5 83 83 0 00-9 6l-3 2-13 8a22 22 0 01-11 3c-9 0-16-7-24-13a60 60 0 00-48-9 54 54 0 00-5 2l-27 12c-8 3-17 6-27 5v1a33 33 0 01-6-1 27 27 0 01-13-8 23 23 0 01-6-11 18 18 0 010-7 57 57 0 014-12l12-27h622a417 417 0 0130 39 16 16 0 010 2c1 11-8 21-18 23z" style="isolation:isolate" opacity=".5"/><path d="M0 41a12 12 0 010-3 12 12 0 010 3zM2224 45V0H1039v1l-1-1H345v1l-1-1H0v26a65 65 0 0115 5 64 64 0 0142-5 83 83 0 0112 4l14 7 8 4c9 3 19 6 28 6 10 0 20-3 29-6l8-4c8-4 17-8 26-10a64 64 0 0142 4 64 64 0 0142-4c9 2 18 6 26 10l8 3c11 5 24 9 36 6a29 29 0 0011-7 29 29 0 0012 7c12 3 24-1 36-6l6-2c9-5 18-9 28-12a64 64 0 0151 10c8 6 16 13 25 14a23 23 0 0011-3l1-1c5-2 9-6 13-9 18-12 40-18 61-17a97 97 0 0148 15l4 2 16 12 2 1a40 40 0 006 3c5 2 10 2 15 1a18 18 0 008-5 15 15 0 004-8 15 15 0 006 9 17 17 0 007 4 22 22 0 007 1 34 34 0 0014-5l16-11 2-2a97 97 0 0151-17 99 99 0 0155 13l7 4c6 5 12 10 20 12a19 19 0 004 1c10-1 18-8 26-14a62 62 0 016-4 65 65 0 0145-5c12 3 23 9 34 14 10 4 21 7 31 6l2-1h3a28 28 0 009-4 28 28 0 005 2 27 27 0 003 2 42 42 0 0019 0 81 81 0 0017-5c11-5 22-12 34-14a64 64 0 0151 9c7 5 14 12 22 13a19 19 0 004 1 18 18 0 002-1 28 28 0 0012-4l10-8 7-4a101 101 0 0189-6 92 92 0 0117 10l2 1c5 4 10 9 16 12 7 4 14 6 22 4a18 18 0 0010-8 14 14 0 002-5c1 6 6 11 12 13 7 2 15 0 21-4l18-13 4-2a92 92 0 0120-10c30-10 64-6 89 12l13 9 1 1a23 23 0 0011 3 7 7 0 001-1c5 0 9-2 13-5l11-8a64 64 0 0151-10c10 3 19 7 28 12l6 2c11 5 23 8 34 6 11 2 23-1 34-6l19-8a90 90 0 0115-6 64 64 0 0151 10l14 10a27 27 0 007 3 20 20 0 004 1c10 0 18-7 25-13l7-4 4-2a100 100 0 01104 7c5 4 10 9 16 12 7 4 14 6 21 4 6-2 11-7 12-13a3 3 0 011 0c0 6 6 11 12 13 7 2 15 0 21-4l18-13 4-2c32-21 77-20 109 2l10 8z"/><path d="M1894 49a33 33 0 01-14 15l-2 1c-14 7-30 4-44-2-13-6-25-14-38-21l-3-1a133 133 0 00-24-9 140 140 0 00-31-5 142 142 0 00-42 4 137 137 0 00-20 7l-10 4-12 7-25 16c-13 6-28 10-42 7-10-2-19-9-23-17a27 27 0 01-3-8 23 23 0 010-4 24 24 0 01-1 3c-1 8-6 15-12 19a37 37 0 01-14 7c-14 3-29-1-42-7l-29-18-2-1-6-4a131 131 0 00-17-7 142 142 0 00-95-1 135 135 0 00-15 7c-14 7-26 16-40 22l-2 1c-14 5-30 7-43 1a33 33 0 01-17-19 26 26 0 01-1-13 21 21 0 012-6 91 91 0 0123-27h622a91 91 0 0122 27 22 22 0 012 4 26 26 0 01-2 18z" style="isolation:isolate" opacity=".6"/><path d="M2201 72c-14 3-29-1-42-8l-38-22a131 131 0 00-16-7 142 142 0 00-63-8 138 138 0 00-42 11l-5 3-18 10-23 12c-14 6-30 9-44 2a28 28 0 01-4-2 33 33 0 01-12-14 27 27 0 01-2-16 21 21 0 012-6 91 91 0 0123-27h307v54c-4 9-13 16-23 18z" style="isolation:isolate" opacity=".6"/></g></svg>');
}

@media (min-width: 2100px) {
  .shapedividers_com-1776::before {
    background-size: 400% calc(2vw + 14px);
  }
}
/*bottom　波型*/
.shapedividers_com-3780 {
  overflow: hidden;
  position: relative;
}

.shapedividers_com-3780::before {
  content: "";
  font-family: "shape divider from ShapeDividers.com";
  position: absolute;
  z-index: 3;
  pointer-events: none;
  background-repeat: no-repeat;
  bottom: -0.1vw;
  left: -0.1vw;
  right: -0.1vw;
  top: -0.1vw;
  background-size: 100% 44px;
  background-position: 50% 100%;
  background-image: url('data:image/svg+xml;charset=utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 35.28 2.17" preserveAspectRatio="none"><path d="M35.28 1.67c-3.07-.55-9.27.41-16.15 0-6.87-.4-13.74-.58-19.13.1v.4h35.28z" fill="%23c3d8b6"/><path d="M35.28 1.16c-3.17-.8-7.3.4-10.04.56-2.76.17-9.25-1.47-12.68-1.3-3.42.16-4.64.84-7.04.86C3.12 1.31 0 .4 0 .4v1.77h35.28z" opacity=".5" fill="%23c3d8b6"/><path d="M35.28.31c-2.57.84-7.68.3-11.8.43-4.1.12-6.85.61-9.57.28C11.18.69 8.3-.16 5.3.02 2.3.22.57.85 0 .87v1.2h35.28z" opacity=".5" fill="%23c3d8b6"/></svg>');
}

@media (min-width: 2100px) {
  .shapedividers_com-3780::before {
    background-size: 100% calc(2vw + 44px);
  }
}
.single-header h1 {
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: 3rem;
  margin-top: 3rem;
  margin-left: 3rem;
  color: #573017;
}
.single-header h3 {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.4rem;
  margin-bottom: 2rem;
  margin-left: 3rem;
  color: #573017;
}

.breadcrumbs {
  margin-left: 3rem;
  font-size: 1.4rem;
}

.single-footer {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
  font-weight: 500;
  height: 3.2rem;
}

/* =============================================================
   beforeafter
============================================================= */
#beforeafter-list-planting .wrapper,
#beforeafter-list-maintenance .wrapper,
#beforeafter-list .wrapper {
  width: 70%;
  margin: 0 auto;
}
#beforeafter-list-planting .title-img,
#beforeafter-list-maintenance .title-img,
#beforeafter-list .title-img {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  text-align: center;
  line-height: 4rem;
}
#beforeafter-list-planting .title-img img,
#beforeafter-list-maintenance .title-img img,
#beforeafter-list .title-img img {
  width: 100%;
}
@media screen and (max-width: 1024px) {
  #beforeafter-list-planting .wrapper,
  #beforeafter-list-maintenance .wrapper,
  #beforeafter-list .wrapper {
    width: 80%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  #beforeafter-list-planting .wrapper,
  #beforeafter-list-maintenance .wrapper,
  #beforeafter-list .wrapper {
    width: 96%;
    margin: 0 auto;
  }
  #beforeafter-list-planting .title-img img,
  #beforeafter-list-maintenance .title-img img,
  #beforeafter-list .title-img img {
    width: 90%;
  }
}

.beforeafter-wrapper .item-wrapper {
  margin-top: 0;
  padding-top: 2rem;
  padding-bottom: 4rem;
  border-bottom: 1px dashed #666;
}
.beforeafter-wrapper .item-wrapper:first-of-type {
  margin-top: 7rem;
}
.beforeafter-wrapper .item-wrapper:last-of-type {
  border-bottom: 0;
}
.beforeafter-wrapper .img-box {
  display: flex;
  gap: 10px;
  border: 0px solid hotpink;
  height: 27.5vw;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .img-box {
    gap: 5px;
    height: 50vw;
  }
}
.beforeafter-wrapper .item-img {
  position: relative;
  padding: 0;
  flex: 1;
  height: 27.5vw;
  -o-object-fit: cover;
     object-fit: cover;
  box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 2.6px;
  margin-bottom: 1.6rem;
}
.beforeafter-wrapper img {
  width: 100%;
  height: 27.5vw;
  -o-object-fit: cover;
     object-fit: cover;
  margin-top: 0;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper img {
    height: 50vw;
  }
}
.beforeafter-wrapper .before,
.beforeafter-wrapper .after {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  margin: 10px;
  padding: 0.5rem 2rem;
  border: 1px solid #90b184;
  font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .before,
  .beforeafter-wrapper .after {
    margin: 2px;
    padding: 2px 10px;
  }
}
.beforeafter-wrapper .before {
  background: #fff;
  color: #5b923c;
}
.beforeafter-wrapper .after {
  background: #90b184;
  color: #fff;
}
.beforeafter-wrapper .before span,
.beforeafter-wrapper .after span {
  display: inline-block;
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .before span,
  .beforeafter-wrapper .after span {
    font-size: 1.5rem;
  }
}
.beforeafter-wrapper .item-body {
  margin: 5rem auto 10rem auto;
  display: flex;
  height: -moz-max-content;
  height: max-content;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .item-body {
    display: block;
    margin: 1.6rem 2%;
  }
}
.beforeafter-wrapper .item-body-cat {
  margin: 2rem auto 3rem auto;
  display: block;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .item-body-cat {
    display: block;
    margin: 1.6rem 2%;
  }
}
.beforeafter-wrapper .item-title {
  flex-basis: 20%;
  display: inline-block;
  font-family: "vdl-penletter", sans-serif;
}
.beforeafter-wrapper .item-title h3 {
  display: block;
  width: 18rem;
  display: inline-block;
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  padding: 2rem 0;
  font-size: 2rem;
  position: relative;
  text-align: center;
  padding: 0.2rem 1.5rem calc(1rem + 10px);
  margin: 0 0 0 2rem;
  background: rgba(187, 217, 135, 0.4666666667);
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .item-title h3 {
    width: -moz-max-content;
    width: max-content;
    padding: 0.2rem 2.5rem 1rem 1.8rem;
    font-size: 1.6rem;
    margin: 0;
  }
}
.beforeafter-wrapper .item-title h3:before {
  position: absolute;
  top: -7px;
  left: -7px;
  width: 100%;
  height: 100%;
  content: "";
  border: 1px solid #666;
  box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 2.6px;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .item-title h3:before {
    top: -4px;
    left: -4px;
  }
}
.beforeafter-wrapper .item-outline {
  align-self: stretch;
  flex-basis: 60%;
  line-height: 3.7rem;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .item-outline {
    font-size: 1.4rem;
  }
}
.beforeafter-wrapper .item-link {
  justify-self: flex-end;
  flex-basis: 15%;
  padding-top: 2rem;
}
.beforeafter-wrapper .item-link a {
  background: #333;
  border-radius: 5px;
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  margin: 0;
  max-width: 280px;
  line-height: 2.5rem;
  padding: 0.5rem;
  color: #fff;
  transition: 0.3s ease-in-out;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .beforeafter-wrapper .item-link a {
    font-size: 1.4rem;
    max-width: 13rem;
    text-align: center;
    margin: 0 auto;
  }
}
.beforeafter-wrapper .item-link a:after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: 0;
  right: 1.6rem;
  font-size: 90%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: right 0.3s;
  width: 6px;
  height: 6px;
  border-top: solid 2px currentColor;
  border-right: solid 2px currentColor;
  transform: translateY(-50%) rotate(45deg);
}
.beforeafter-wrapper .item-link a:hover {
  background: #888;
  color: #FFF;
}
.beforeafter-wrapper .item-link a:hover:after {
  right: 1.4rem;
}

#beforeafter-list-maintenance .before {
  background: #fff;
  color: #ab8069;
  border: #ab8069;
}
#beforeafter-list-maintenance .after {
  background: #6b4c3b;
  border: #6b4c3b;
  color: #fff;
}
#beforeafter-list-maintenance .item-title {
  margin-top: 2rem;
}
#beforeafter-list-maintenance .item-img {
  margin-bottom: 1.6rem;
}

#beforeafter-list-planting .before {
  background: #fff;
  color: #79ca4a;
  border: #79ca4a;
}
#beforeafter-list-planting .after {
  background: #79ca4a;
  border: #79ca4a;
  color: #fff;
}
#beforeafter-list-planting .item-title {
  margin-top: 2rem;
}
#beforeafter-list-planting .item-img {
  margin-bottom: 1.6rem;
}

/* =============================================================
   固定 : flow
============================================================= */
#process, #faq {
  width: 80%;
  margin: 0 auto;
  display: block;
}
#process h1, #faq h1 {
  font-family: "vdl-penletter", sans-serif;
  font-size: 4rem;
  text-align: center;
  margin-bottom: 4rem;
}
#process h3, #faq h3 {
  display: inline-block;
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  padding: 2rem 0;
  font-size: 2.5rem;
  position: relative;
  padding: 0.5rem 3rem calc(1rem + 10px);
  margin-bottom: 2rem;
  background: rgba(166, 226, 152, 0.4666666667);
}
#process h3:before, #faq h3:before {
  position: absolute;
  top: -7px;
  left: -7px;
  width: 100%;
  height: 100%;
  content: "";
  border: 2px solid #666;
  box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 2.6px;
}
#process .steps, #faq .steps {
  display: flex;
  border-bottom: 1px dashed #666;
  padding-bottom: 5rem;
  margin-bottom: 5rem;
}
#process .step-num, #faq .step-num {
  margin-left: 2rem;
}
#process .img-box, #faq .img-box {
  width: 30%;
}
#process .img-box img, #faq .img-box img {
  width: 100%;
}
#process .txt-box, #faq .txt-box {
  font-size: 1.5rem;
  line-height: 2.5rem;
  width: 70%;
  padding-left: 5%;
}
#process .txt-box P, #faq .txt-box P {
  margin: 1.6rem 0;
}
#process .flow_li, #faq .flow_li {
  padding: 2rem 0;
}
@media screen and (max-width: 767px) {
  #process, #faq {
    width: 94%;
  }
  #process h1, #faq h1 {
    font-family: "vdl-penletter", sans-serif;
    font-size: 2.4rem;
    text-align: center;
    margin-bottom: 3.2rem;
  }
  #process .steps, #faq .steps {
    display: block;
  }
  #process .img-box, #faq .img-box {
    width: 100%;
  }
  #process .txt-box, #faq .txt-box {
    font-size: 1.5rem;
    line-height: 2rem;
    width: 100%;
    padding-left: 0;
  }
  #process h3, #faq h3 {
    padding: 1.5rem 0;
    font-size: 1.8rem;
    position: relative;
    padding: 0.5rem 3rem calc(0.5rem + 10px);
    margin-bottom: 2rem;
    background: rgba(166, 226, 152, 0.4666666667);
  }
  #process h3:before, #faq h3:before {
    position: absolute;
    top: -7px;
    left: -7px;
    width: 100%;
    height: 100%;
    content: "";
    border: 2px solid #666;
    box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 2.6px;
  }
}

/* =============================================================
   faq
============================================================= */
#faq {
  margin-top: 10rem;
  margin-bottom: 10rem;
}

.faq_questionNo {
  font-family: "クラフト明朝", sans-serif;
  font-weight: 500;
  font-style: normal;
  color: #2a5e00;
  font-weight: 300;
  font-size: 2.5rem;
  margin: 0 1rem;
}
@media (max-width: 1079.9px) {
  .faq_questionNo {
    font-size: 2rem;
  }
}

.faq_question {
  display: inline-block;
  width: 92%;
  padding-right: 15px;
  line-height: 2.5rem;
  padding-right: 8%;
  font-size: 1.5rem;
  font-weight: 200;
}
@media screen and (max-width: 767px) {
  .faq_question {
    font-size: 1.5rem;
  }
}

.detail {
  font-size: 1.5rem;
  line-height: 2.2rem;
  font-weight: 200;
}
@media screen and (max-width: 767px) {
  .detail {
    font-size: 1.4rem;
    line-height: 2rem;
  }
}

/*アコーディオンメニュー--------------------*/
#ac-menu li {
  list-style: none;
  margin: 0;
  padding: 0;
}

#ac-menu .label {
  display: flex;
  flex-flow: row wrap;
  align-items: flex-start;
  cursor: pointer;
  padding: 30px 0;
  margin: 30px 0 0 0;
  position: relative;
  transition: 0.5s;
  border-top: solid 1px #ac987d;
  list-style: none;
  border-bottom: solid 1px #ac987d;
  list-style: none;
  background: rgba(235, 231, 225, 0.3843137255);
  background-image: radial-gradient(#fafafa 20%, transparent 20%), radial-gradient(#fafafa 20%, transparent 20%);
  background-size: 6px 6px;
  background-position: 0 0, 3px 3px;
}

#ac-menu .label:hover {
  background: #ebe7e1;
  background-image: radial-gradient(#fafafa 20%, transparent 20%), radial-gradient(#fafafa 20%, transparent 20%);
  background-size: 6px 6px;
  background-position: 0 0, 3px 3px;
}

#ac-menu li:last-child {
  border-bottom: solid 0px #ac987d;
}

#ac-menu .label::before,
#ac-menu .label::after {
  content: "";
  width: 20px;
  height: 2px;
  background: #000;
  position: absolute;
  top: 50%;
  right: 2%;
  transform: translateY(-50%);
}

#ac-menu .label::after {
  transform: translateY(-50%) rotate(90deg);
  transition: 0.5s;
}

#ac-menu .label.open {
  background: #ebe7e1;
}

#ac-menu .label.open::before {
  opacity: 0;
}

#ac-menu .label.open::after {
  transform: rotate(180deg);
}

#ac-menu .detail {
  border-top: solid 0px #ccc;
  margin: 0;
  padding: 20px 30px 10px 30px;
  display: none;
}

@media (max-width: 1079.9px) {
  #ac-menu .label {
    display: block;
    padding: 10px;
    margin: 20px 0 0 0;
  }
  #ac-menu .detail {
    padding: 15px 15px 0 15px;
  }
}
/* =============================================================
   単一ページ
============================================================= */
#works-list,
#landscaping-list,
#maintenance-list,
#gardening-list,
#planting-list {
  border: 0px solid red;
  width: 100%;
  background-color: #f2f2f2;
  padding: 2% 0 0 0;
  margin: 0;
}
@media screen and (max-width: 767px) {
  #works-list,
  #landscaping-list,
  #maintenance-list,
  #gardening-list,
  #planting-list {
    margin-top: 10%;
  }
}
#works-list .wrapper,
#landscaping-list .wrapper,
#maintenance-list .wrapper,
#gardening-list .wrapper,
#planting-list .wrapper {
  width: 94%;
  border: 0px solid blue;
  margin: 8% auto 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  #works-list .wrapper,
  #landscaping-list .wrapper,
  #maintenance-list .wrapper,
  #gardening-list .wrapper,
  #planting-list .wrapper {
    margin-top: 10rem;
    width: 94%;
    display: block;
  }
}
#works-list .item-wrapper,
#landscaping-list .item-wrapper,
#maintenance-list .item-wrapper,
#gardening-list .item-wrapper,
#planting-list .item-wrapper {
  width: 30%;
  height: 30vw;
  align-self: start;
  margin: 2% 1.5%;
  display: block;
  padding: 5px;
  background: #fff;
  border: 1px solid #eee;
  text-align: center;
  border-radius: 2px;
  box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}
@media screen and (max-width: 1024px) {
  #works-list .item-wrapper,
  #landscaping-list .item-wrapper,
  #maintenance-list .item-wrapper,
  #gardening-list .item-wrapper,
  #planting-list .item-wrapper {
    border: 0px solid red;
    width: 45%;
    height: auto;
    margin-bottom: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #works-list .item-wrapper,
  #landscaping-list .item-wrapper,
  #maintenance-list .item-wrapper,
  #gardening-list .item-wrapper,
  #planting-list .item-wrapper {
    width: auto;
    height: 100%;
  }
}
#works-list .item-link,
#landscaping-list .item-link,
#maintenance-list .item-link,
#gardening-list .item-link,
#planting-list .item-link {
  width: 100%;
  height: auto;
  position: relative;
}
#works-list .item-img,
#landscaping-list .item-img,
#maintenance-list .item-img,
#gardening-list .item-img,
#planting-list .item-img {
  display: block;
  position: relative;
  margin: 2%;
  overflow: hidden;
  border-radius: 2px;
  height: 26vw;
}
@media screen and (max-width: 767px) {
  #works-list .item-img,
  #landscaping-list .item-img,
  #maintenance-list .item-img,
  #gardening-list .item-img,
  #planting-list .item-img {
    height: auto;
  }
}
#works-list .item-img img,
#landscaping-list .item-img img,
#maintenance-list .item-img img,
#gardening-list .item-img img,
#planting-list .item-img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
  transition: 1s all;
}
@media screen and (max-width: 767px) {
  #works-list .item-img img,
  #landscaping-list .item-img img,
  #maintenance-list .item-img img,
  #gardening-list .item-img img,
  #planting-list .item-img img {
    height: auto;
  }
}
#works-list .item-img img:hover,
#landscaping-list .item-img img:hover,
#maintenance-list .item-img img:hover,
#gardening-list .item-img img:hover,
#planting-list .item-img img:hover {
  transform: scale(1.05, 1.05);
  transition: 1s all;
}
#works-list .item-title,
#landscaping-list .item-title,
#maintenance-list .item-title,
#gardening-list .item-title,
#planting-list .item-title {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.6rem;
  line-height: 2.5rem;
  display: block;
  text-align: left;
  margin-left: 1.6rem;
}
#works-list .item-no,
#landscaping-list .item-no,
#maintenance-list .item-no,
#gardening-list .item-no,
#planting-list .item-no {
  font-size: 1.2rem;
  display: inline-block;
  padding: 1px 3px;
  background: #492d1d;
  color: #fff;
  margin-right: 10px;
}

#gardening-list .wrapper {
  margin-top: 5rem;
}

#woodworking-list {
  border: 0px solid red;
  width: 100%;
  background-color: #f2f2f2;
  padding: 2% 0 0 0;
  margin: 0;
}
@media screen and (max-width: 767px) {
  #woodworking-list {
    margin-top: 10%;
  }
}
#woodworking-list .wrapper {
  width: 94%;
  border: 0px solid blue;
  margin: 8% auto 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  #woodworking-list .wrapper {
    margin-top: 10rem;
    width: 84%;
    display: block;
  }
}
#woodworking-list .item-wrapper {
  width: 23%;
  height: 25vw;
  align-self: start;
  margin: 1%;
  display: block;
  padding: 5px;
  background: #fff;
  border: 1px solid #eee;
  text-align: center;
  border-radius: 2px;
  box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}
@media screen and (max-width: 1024px) {
  #woodworking-list .item-wrapper {
    border: 0px solid red;
    width: 45%;
    height: auto;
    margin-bottom: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #woodworking-list .item-wrapper {
    width: auto;
    height: 100%;
  }
}
#woodworking-list .item-link {
  width: 100%;
  height: auto;
  position: relative;
}
#woodworking-list .item-img {
  display: block;
  position: relative;
  margin: 2%;
  overflow: hidden;
  border-radius: 2px;
  height: 23.5vw;
}
@media screen and (max-width: 767px) {
  #woodworking-list .item-img {
    height: auto;
  }
}
#woodworking-list .item-img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
  transition: 1s all;
}
@media screen and (max-width: 767px) {
  #woodworking-list .item-img img {
    height: auto;
  }
}
#woodworking-list .item-img img:hover {
  transform: scale(1.05, 1.05);
  transition: 1s all;
}
#woodworking-list .item-title {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.6rem;
  line-height: 2.5rem;
  display: block;
  text-align: left;
  margin-left: 1.6rem;
}
#woodworking-list .item-no {
  font-size: 1.2rem;
  display: inline-block;
  padding: 1px 3px;
  background: #492d1d;
  color: #fff;
  margin-right: 10px;
}

/* =============================================================
single : 
============================================================= */
#single-wrapper {
  margin: auto;
  padding: 0;
}
#single-wrapper .single-main {
  width: 60vw;
  height: 70vh;
  border: 0px solid blue;
  margin: 5rem auto 0 auto;
}
@media screen and (max-width: 1024px) {
  #single-wrapper .single-main {
    width: 95%;
    height: auto;
    margin: 1.6rem auto 0 auto;
  }
}
@media screen and (max-width: 767px) {
  #single-wrapper .single-main {
    width: 95%;
    height: auto;
    margin: 1.6rem auto 0 auto;
  }
}
#single-wrapper .single-main img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#single-wrapper .single-title {
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  margin-top: 1.6rem;
  margin-left: 0.8rem;
  font-size: 2.4rem;
  line-height: 5rem;
  text-align: center;
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  #single-wrapper .single-title {
    font-size: 1.8rem;
    margin-bottom: 1.6rem;
  }
}

.s-data-wrapper {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
  font-weight: 500;
  width: 55%;
  margin: 3rem auto 10rem auto;
  padding: 0;
}
@media screen and (max-width: 1024px) {
  .s-data-wrapper {
    width: 96%;
    margin: 1rem auto 5rem auto;
  }
}
@media screen and (max-width: 767px) {
  .s-data-wrapper {
    width: 96%;
  }
}

.works-data-wrap {
  display: flex;
  padding: 0;
  margin-bottom: 1.6rem;
  margin-top: 1.6rem;
}
@media screen and (max-width: 1024px) {
  .works-data-wrap {
    display: block;
  }
}
.works-data-wrap h3 {
  display: block;
  width: 16rem;
  text-align: center;
  height: -moz-max-content;
  height: max-content;
  font-family: "vdl-penletter", sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 1.8rem;
  position: relative;
  padding: 3px;
  margin-bottom: 1rem;
  background: rgba(187, 217, 135, 0.4666666667);
}
@media screen and (max-width: 1024px) {
  .works-data-wrap h3 {
    font-size: 1.8rem;
  }
}
.works-data-wrap .works-data {
  width: 70%;
  margin-left: 5%;
  font-size: 1.5rem;
}
@media screen and (max-width: 1024px) {
  .works-data-wrap .works-data {
    width: 94%;
    margin: 0 3%;
  }
}

.works-beforeafter {
  width: 70%;
  margin: 0 auto;
  padding: 0;
  display: flex;
  border: 0 solid red;
  padding-top: 5rem;
  padding-bottom: 5rem;
  border-bottom: 1px dotted #90b184;
}
@media screen and (max-width: 1024px) {
  .works-beforeafter {
    width: 80%;
  }
}
@media screen and (max-width: 1024px) {
  .works-beforeafter {
    width: 94%;
  }
}
.works-beforeafter .works-before {
  width: 30%;
  margin-top: 55px;
}
@media screen and (max-width: 767px) {
  .works-beforeafter .works-before {
    margin-top: 50px;
  }
}
.works-beforeafter .works-before .before {
  text-align: center;
}
.works-beforeafter .works-before img {
  width: 100%;
  position: relative;
}
.works-beforeafter .works-arrow {
  background-image: url(../img/single_arrow.png);
  background-position: right bottom;
  height: 75px;
  background-repeat: no-repeat;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .works-beforeafter .works-arrow {
    background-size: 80%;
    margin-bottom: 0;
    height: 80px;
  }
}
.works-beforeafter .works-after {
  border: 0px solid orange;
  width: 70%;
  margin-left: 0;
}
.works-beforeafter .works-after .after {
  text-align: center;
}
.works-beforeafter .works-after img {
  width: 100%;
  max-height: 90vh;
  text-align: left;
  -o-object-fit: contain;
     object-fit: contain;
  margin: 5px;
}
@media screen and (max-width: 1024px) {
  .works-beforeafter .works-after img {
    height: -moz-fit-content;
    height: fit-content;
  }
}

.works-detail-wrap {
  width: 60%;
  margin: 0 auto;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .works-detail-wrap {
    width: 80%;
  }
}
@media screen and (max-width: 767px) {
  .works-detail-wrap {
    width: 94%;
  }
}

.works-detail {
  width: 70%;
  margin: 0 auto;
}
@media screen and (max-width: 1024px) {
  .works-detail {
    width: 80%;
  }
}
@media screen and (max-width: 767px) {
  .works-detail {
    width: 90%;
  }
}
.works-detail img {
  width: 100%;
  margin-bottom: 5rem;
}
.works-detail h3 {
  display: block;
  font-size: 1.6rem;
  line-height: 3.2rem;
  padding: 0.25em 0.5em;
  color: #494949;
  background: transparent;
  border-left: solid 5px #90e67d;
  text-align: left;
}
@media screen and (max-width: 1024px) {
  .works-detail h3 {
    font-size: 1.6rem;
    line-height: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .works-detail h3 {
    font-size: 1.4rem;
  }
}/*# sourceMappingURL=layout.css.map */