@charset "UTF-8";
.effect-fade {
  opacity: 0;
  transform: translate(0, 45px);
  transition: all 1s;
}
.effect-fade.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}
.effect-fade.stop {
  opacity: 0;
  transform: translate(0, 0);
  transition: all 1s;
}
.effect-fade.stop.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}
.effect-fade.left-in {
  opacity: 0;
  transform: translate(-45px, 0);
  transition: all 1s;
}
.effect-fade.left-in.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}
.effect-fade.right-in {
  opacity: 0;
  transform: translate(45px, 0);
  transition: all 1s;
}
.effect-fade.right-in.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}

@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  src: url("../font/NotoSansJP-Regular.woff2") format("woff2"), url("../font/NotoSansJP-Regular.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  src: url("../font/NotoSansJP-Bold.woff2") format("woff2"), url("../font/NotoSansJP-Bold.woff") format("woff");
  font-display: swap;
}
@font-face {
  font-family: "Darumadrop";
  src: url("../font/DarumadropOne-Regular.ttf") format("truetype");
}
:root {
  --notosansjp: "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Sans",
  	"Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}

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

html {
  scroll-snap-type: y proximity;
  scroll-padding-top: 70px;
  scroll-behavior: smooth;
}

body {
  width: 100%;
  height: 100%;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 16px;
  font-weight: 400;
  font-feature-settings: "palt";
  color: #000000;
  background-color: #ffffff;
}
body.noscroll {
  overflow: hidden;
}

.load-fade {
  visibility: hidden;
  opacity: 0;
  transition: all 1s;
}

.load-fade.is-show {
  visibility: visible;
  opacity: 1;
}

/* ios用の初期化 */
input,
button,
textarea,
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

.pc {
  display: block;
}

.sp,
img.sp {
  display: none;
}

img.pc {
  display: inline-block;
}

a {
  display: block;
}

@media (width <= 600px) {
  .sp {
    display: block;
  }
  .pc,
  img.pc {
    display: none;
  }
  img.sp {
    display: inline-block;
  }
}
.header {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 10;
  width: 100%;
}
.header > .header--inner {
  position: fixed;
  top: 0;
  right: 0;
  width: 123px;
  height: 123px;
  border-radius: 65px;
}
@media (width <= 600px) {
  .header > .header--inner {
    width: 22vw;
    height: 22vw;
    border-radius: 0 0 0 10vw;
  }
}
.header.is-active .header--inner {
  top: 100px;
  left: 100px;
  width: calc(100vw - 200px);
  height: calc(100dvh - 200px);
}
@media (width <= 1024px) {
  .header.is-active .header--inner {
    top: 5vw;
    left: 10%;
    width: 80%;
    height: calc(100dvh - 10vw);
  }
}
@media (width <= 600px) {
  .header.is-active .header--inner {
    top: 15vw;
    left: 0;
    width: 85%;
    height: calc(100dvh - 30vw);
    margin: 0 auto;
  }
}
.header .overlay {
  position: fixed;
  top: 0;
  right: 0;
  visibility: hidden;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: 0.3s all;
  transition-delay: 0.3s;
}
.header.is-active {
  z-index: 100;
  height: 100dvh;
  transition: 0.3s all;
}
.header.is-active .overlay {
  visibility: visible;
  background-color: #c1b0b0;
  opacity: 1;
  transition: 0.3s all;
  transition-delay: 0s;
}
@media (width <= 600px) {
  .header.is-active .overlay {
    background-color: #c1b0b0;
  }
}

.hamburger_wrap {
  position: absolute;
  top: 35px;
  right: 40px;
  z-index: 9998;
  display: block;
  width: 40px;
  height: 48px;
  pointer-events: auto;
  -webkit-user-select: auto;
  -moz-user-select: auto;
  user-select: auto;
}
@media (width <= 600px) {
  .hamburger_wrap {
    top: 5.5vw;
    right: 6vw;
    width: 9.5vw;
  }
}

.hamburger {
  position: relative;
  z-index: 10;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
  outline: none;
  background-color: transparent;
  border: none;
}
.hamburger span {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  backface-visibility: hidden;
}
.hamburger div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  transition: ease-in-out 0.3s;
}
.hamburger div:nth-child(2) {
  top: 10px;
}
.hamburger div:nth-child(2) > span {
  transform: translateX(-25%);
}
.hamburger div:nth-child(3) {
  top: 20px;
}
.hamburger div > span {
  transition-timing-function: ease-in-out;
  transition-duration: 0.3s;
  transition-property: transform;
}
.hamburger div span span {
  background-color: #5e554d;
  border-radius: 5px;
}
.hamburger:hover > div:nth-child(2) > span {
  transform: translateX(0%);
}

.is-active .hamburger > div:nth-child(1) {
  top: 10px;
  transform: rotate(45deg);
}
.is-active .hamburger > div:nth-child(2) {
  opacity: 0;
}
.is-active .hamburger > div:nth-child(2) > span {
  transform: translateX(25%);
}
.is-active .hamburger > div:nth-child(3) {
  top: 10px;
  transform: rotate(-45deg);
}
.is-active .hamburger > div span span {
  background-color: #6b6b6b;
  border-radius: 5px;
}

.header_menu {
  display: flex;
  visibility: hidden;
  flex-flow: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: url(../img/menu_bg.webp) bottom/100% no-repeat, #fff;
  border-radius: 100px;
  opacity: 0;
}
@media (width <= 600px) {
  .header_menu {
    background: url(../img/menu_bg.webp) left -27vw bottom/171% no-repeat, #fff;
    border-radius: 10vw;
  }
}
.is-active .header_menu {
  visibility: visible;
  opacity: 1;
  transition: all 0.8s;
  transition-delay: 0.3s;
}
.is-active .header_menu > a {
  width: 35vw;
  max-width: 400px;
  margin-bottom: 50px;
}
@media (width <= 600px) {
  .is-active .header_menu > a {
    width: 58vw;
    max-width: 400px;
    margin-bottom: 10vw;
  }
}
.header_menu nav ul {
  display: flex;
  flex-direction: column;
  gap: 30px;
  justify-content: center;
  margin: 0 0 100px;
  text-align: center;
}
@media (width <= 1024px) {
  .header_menu nav ul {
    gap: 25px;
  }
}
@media (width <= 600px) {
  .header_menu nav ul {
    gap: 5vw;
    margin: 0 0 10vw;
  }
}
.header_menu nav ul li a {
  font-family: "vdl-penletter", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  color: #666;
  letter-spacing: 0.2em;
}
@media (width <= 1024px) {
  .header_menu nav ul li a {
    gap: 25px;
    font-size: 16px;
  }
}
@media (width <= 600px) {
  .header_menu nav ul li a {
    font-size: 3.6vw;
  }
}
.header_menu nav ul li a:hover {
  color: #df7082;
}
.header_menu nav ul li:last-child a {
  width: 50px;
  margin: 0 auto;
  background-color: #666;
  border-radius: 50%;
  transition: 0.5s all;
}
@media (width <= 600px) {
  .header_menu nav ul li:last-child a {
    width: 10vw;
  }
}
.header_menu nav ul li:last-child a:hover {
  background-color: #df7082;
}

h1 {
  position: absolute;
  top: 10px;
  left: 10px;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 13px;
  color: #666;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  h1 {
    font-size: 2.8vw;
  }
}

.kv {
  position: relative;
  padding: 20vh 0 57px;
}
@media (width <= 1024px) {
  .kv {
    padding-bottom: 49px;
  }
}
@media (width <= 600px) {
  .kv {
    padding: 16vh 0 30vw;
  }
}
.kv > h2 {
  width: 66vw;
  max-width: 400px;
  margin: 0 auto 40px;
}
@media (width <= 1024px) {
  .kv > h2 {
    margin: 0 auto 3vw;
  }
}
@media (width <= 600px) {
  .kv > h2 {
    margin-bottom: 7vh;
  }
}
.kv > h2 img {
  width: 100%;
}
.kv .main_img {
  position: relative;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  overflow: hidden;
}
@media (width <= 600px) {
  .kv .main_img > img:first-child {
    max-width: 206vw;
    margin-left: -49vw;
  }
}
.kv .main_img .cycle {
  position: absolute;
  right: 1200px;
  bottom: 10px;
  z-index: 5;
  width: 84px;
  transform: translateX(1200%);
  animation: animetxt 30s linear infinite;
}
@media (width <= 600px) {
  .kv .main_img .cycle {
    right: 0;
    bottom: 4vw;
    z-index: 5;
    width: 12vw;
    transform: translateX(100%);
    animation: animetxt 20s linear infinite;
  }
}
@keyframes animetxt {
  100% {
    transform: translateX(0%);
  }
}
@media (width <= 600px) {
  @keyframes animetxt {
    100% {
      transform: translateX(-800%);
    }
  }
}
.kv .main_img .woman_dog {
  position: absolute;
  right: 122px;
  bottom: 40px;
  width: 67px;
  transform: translateX(-300%);
  animation: animetxt2 60s linear infinite;
}
@media (width <= 1024px) {
  .kv .main_img .woman_dog {
    width: 4.5vw;
  }
}
@media (width <= 600px) {
  .kv .main_img .woman_dog {
    right: 37vw;
    bottom: 9vw;
    width: 9vw;
  }
}
@keyframes animetxt2 {
  100% {
    transform: translateX(100%);
  }
}
.kv .main_img .musician {
  position: absolute;
  right: 505px;
  bottom: 105px;
  width: 50px;
}
@media (width <= 1024px) {
  .kv .main_img .musician {
    width: 6vw;
  }
}
@media (width <= 600px) {
  .kv .main_img .musician {
    right: calc(50% - 82px);
    bottom: 58px;
    width: 4vw;
  }
}
.kv .main_img .man_woman {
  position: absolute;
  bottom: 24px;
  left: 107px;
  width: 83px;
}
@media (width <= 1024px) {
  .kv .main_img .man_woman {
    width: 6vw;
  }
}
@media (width <= 600px) {
  .kv .main_img .man_woman {
    display: none;
  }
}
.kv .main_img::after {
  position: absolute;
  bottom: 0;
  left: 5%;
  z-index: 1;
  display: block;
  width: 91%;
  height: 150px;
}
.kv nav ul {
  display: flex;
  gap: 40px;
  align-items: center;
  justify-content: center;
  margin: 0 0 100px;
}
@media (width <= 600px) {
  .kv nav ul {
    display: none;
  }
}
.kv nav ul li:not(:last-child) a {
  position: relative;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  color: transparent;
  letter-spacing: 0.2em;
  text-decoration: none;
  background: linear-gradient(to right, #df7082 50%, #666 50%) 100%;
  -webkit-background-clip: text;
  background-clip: text;
  background-size: 200% 100%;
  transition: background-position 0.3s;
}
@media (width <= 600px) {
  .kv nav ul li:not(:last-child) a {
    font-size: 3.8vw;
  }
}
.kv nav ul li:not(:last-child) a:hover {
  background-position: 0 100%;
}
.kv nav ul li:last-child a {
  background-color: #666;
  border-radius: 50%;
  transition: 0.5s all;
}
@media (width <= 600px) {
  .kv nav ul li:last-child a {
    width: 9vw;
    margin-top: 1vw;
  }
}
.kv nav ul li:last-child a:hover {
  background-color: #df7082;
}
.kv #info {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 10px 20px;
  color: #fff;
  background-color: #aa9c9c;
  /* 前への矢印カスタマイズ */
  /* 次への矢印カスタマイズ */
}
@media (width <= 600px) {
  .kv #info {
    padding: 4vw 5vw 10vw;
  }
}
.kv #info > div {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
@media (width <= 600px) {
  .kv #info > div {
    flex-flow: column;
    align-items: flex-start;
  }
}
.kv #info h2 {
  width: 20%;
  max-width: 250px;
  margin-bottom: 9px;
  font-family: "Darumadrop", sans-serif;
  font-size: 30px;
  letter-spacing: 0.05em;
}
@media (width <= 1024px) {
  .kv #info h2 {
    font-size: 20px;
  }
}
@media (width <= 600px) {
  .kv #info h2 {
    width: 100%;
    max-width: none;
    padding-bottom: 3vw;
    margin-bottom: 4vw;
    font-size: 5.5vw;
    border-bottom: dotted 2px #ccc;
  }
}
.kv #info .swiper-horizontal {
  width: 65%;
}
@media (width <= 600px) {
  .kv #info .swiper-horizontal {
    width: 100%;
  }
}
.kv #info .swiper-slide {
  font-size: 16px;
  background-color: #aa9c9c;
  opacity: 1;
  transform: translateY(0px);
  transition: 0.5s;
}
.kv #info .swiper-slide a {
  display: flex;
}
.kv #info .swiper-slide a time {
  margin-right: 2em;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 15px;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .kv #info .swiper-slide a time {
    font-size: 3.4vw;
  }
}
.kv #info .swiper-slide a p {
  width: 100%;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 15px;
  letter-spacing: 0.1em;
  background-color: #aa9c9c;
}
@media (width <= 600px) {
  .kv #info .swiper-slide a p {
    font-size: 3.4vw;
  }
}
.kv #info .viewall {
  position: absolute;
  right: 80px;
  bottom: calc(50% - 7px);
  z-index: 8;
  font-family: "vdl-penletter", sans-serif;
  font-size: 18px;
  color: #f2f2f2;
  letter-spacing: 0.1em;
  transition: 0.5s all;
}
@media (width <= 1024px) {
  .kv #info .viewall {
    right: 5vw;
    font-size: 14px;
  }
}
@media (width <= 600px) {
  .kv #info .viewall {
    right: 8vw;
    bottom: -7vw;
    font-size: 3vw;
    color: #ccc;
  }
}
.kv #info .viewall::after {
  position: absolute;
  right: -68px;
  bottom: 6px;
  display: block;
  width: 34px;
  height: 9px;
  content: "";
  background: url(../img/white_arrow.svg) center/100% no-repeat;
  transition: 0.5s all;
}
@media (width <= 1024px) {
  .kv #info .viewall::after {
    right: -5vw;
    bottom: calc(50% - 0.5vw);
    display: block;
    width: 4vw;
    height: 1vw;
  }
}
@media (width <= 600px) {
  .kv #info .viewall::after {
    right: -9vw;
    bottom: 1.5vw;
    width: 7vw;
    height: 2vw;
  }
}
.kv #info .viewall:hover::after {
  transform: translateX(10px);
}
.kv #info .swiper-button-prev {
  right: 64px;
  left: auto;
}
.kv #info .swiper-button-prev,
.kv #info .swiper-button-next {
  width: 41px;
  height: 41px;
}
.kv #info .swiper-button-prev::after,
.kv #info .swiper-button-next::after {
  width: 41px;
  height: 41px;
  margin: auto;
  content: "";
  background-color: #edf2f7;
  background-repeat: no-repeat;
  background-position: center 16px;
  background-size: 50%;
  border-radius: 50%;
  transition: 0.3s;
}
.kv #info .swiper-button-prev::after {
  background-image: url("../img/news_arrow_left.svg");
}
.kv #info .swiper-button-next::after {
  background-image: url("../img/news_arrow_right.svg");
}
.kv #info .swiper-button-prev:hover::after,
.kv #info .swiper-button-next:hover::after {
  background-color: #999;
  transition: 0.3s;
}
.kv .ppl_01 {
  position: absolute;
  bottom: 50px;
  left: 0;
  width: 100px;
}

.top_001 {
  position: relative;
  padding: 100px 0 300px;
  background-color: #fdefef;
}
@media (width <= 600px) {
  .top_001 {
    padding: 60vw 0 60vw;
    background-color: #fdefef;
    background-image: url(../img/sp_top_about_bg_01.svg), url(../img/sp_top_about_bg_02.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center top 15vw, center bottom 15vw;
    background-size: 122%, 122%;
  }
}
.top_001 > div {
  width: 85%;
  max-width: 1000px;
  height: 1246px;
  padding: 150px 0;
  margin: 0 auto;
  text-align: center;
  background: url(../img/top_about_bg.svg) top/100% no-repeat;
}
@media (width <= 1024px) {
  .top_001 > div {
    width: 96%;
    height: 1128px;
  }
}
@media (width <= 768px) {
  .top_001 > div {
    height: auto;
    padding: 15vw 0;
  }
}
@media (width <= 600px) {
  .top_001 > div {
    width: 100%;
    height: auto;
    padding: 0 0 18vw;
    background: #fff;
  }
}
.top_001 h2 {
  margin: 0 0 60px;
  font-family: "Darumadrop", sans-serif;
  font-size: 30px;
  color: #5e554d;
  letter-spacing: 0.05em;
}
@media (width <= 600px) {
  .top_001 h2 {
    position: absolute;
    top: 38vw;
    left: calc(50% - 2.3em);
    font-size: 8vw;
  }
}
.top_001 h2 span {
  display: block;
  margin: 5px 0 0;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 13px;
}
@media (width <= 600px) {
  .top_001 h2 span {
    font-size: 3vw;
  }
}
.top_001 p {
  margin: 0 0 50px;
  font-family: "vdl-penletter", sans-serif;
  font-size: 18px;
  line-height: 3.2;
  letter-spacing: 0.15em;
}
@media (width <= 1024px) {
  .top_001 p {
    margin: 0 0 5vw;
    font-size: 16px;
    line-height: 2.6;
  }
}
@media (width <= 600px) {
  .top_001 p {
    width: 82%;
    margin: 0 auto 10vw;
    font-size: 4vw;
  }
}
.top_001 dl {
  margin: 0 0 80px;
  font-family: "vdl-penletter", sans-serif;
}
@media (width <= 1024px) {
  .top_001 dl {
    margin: 0 0 8vw;
  }
}
@media (width <= 600px) {
  .top_001 dl {
    margin: 0 auto 14vw;
  }
}
.top_001 dl dt {
  margin: 0 0 30px;
  font-size: 16px;
  letter-spacing: 0.15em;
}
@media (width <= 1024px) {
  .top_001 dl dt {
    margin: 0 0 3vw;
  }
}
@media (width <= 600px) {
  .top_001 dl dt {
    margin: 0 0 4vw;
    font-size: 3vw;
  }
}
.top_001 dl dd {
  font-size: 20px;
}
@media (width <= 600px) {
  .top_001 dl dd {
    font-size: 5vw;
  }
}
.top_001 .view_more {
  display: inline-block;
  padding: 15px 30px;
  letter-spacing: 0.3em;
  background-color: rgba(211, 173, 179, 0.4117647059);
  border: 1px dashed #d3adb3;
  border-radius: 50px;
  transition: all 0.5s;
}
@media (width <= 1024px) {
  .top_001 .view_more {
    height: auto;
  }
}
@media (width <= 600px) {
  .top_001 .view_more {
    padding: 3vw 6vw;
    font-size: 4vw;
    letter-spacing: 0.2em;
  }
}
.top_001 .view_more:hover {
  background-color: #d3adb3;
}
.top_001 .top_about_house {
  position: absolute;
  bottom: 250px;
  left: calc(50% - 270px);
  width: 540px;
}
@media (width <= 1024px) {
  .top_001 .top_about_house {
    bottom: 18vw;
    left: calc(50% - 25vw);
    width: 50vw;
  }
}
@media (width <= 600px) {
  .top_001 .top_about_house {
    position: absolute;
    bottom: 14vw;
    left: calc(50% - 38vw);
    width: 80vw;
  }
}
.top_001 .top_about_stones_01 {
  position: absolute;
  bottom: 190px;
  left: calc(50% - 472px);
  width: 84px;
}
@media (width <= 1024px) {
  .top_001 .top_about_stones_01 {
    bottom: 13vw;
    left: 13vw;
    width: 7.5vw;
  }
}
@media (width <= 600px) {
  .top_001 .top_about_stones_01 {
    display: none;
  }
}
.top_001 .top_about_stones_01 img {
  position: absolute;
  bottom: 0;
  z-index: 2;
}
@media (width <= 1024px) {
  .top_001 .top_about_stones_01 img {
    left: 2vw;
  }
}
.top_001 .top_about_stones_01::after {
  position: absolute;
  bottom: -27px;
  left: -62px;
  z-index: 0;
  display: block;
  width: 232px;
  height: 70px;
  content: "";
  background: url(../img/top_about_stones_01.webp) bottom/100% auto no-repeat;
}
@media (width <= 1024px) {
  .top_001 .top_about_stones_01::after {
    bottom: -3vw;
    left: -6vw;
    width: 24vw;
    height: 8vw;
  }
}
.top_001 .top_about_stones_02 {
  position: absolute;
  right: calc(50% - 472px);
  bottom: 190px;
  width: 110px;
}
@media (width <= 1024px) {
  .top_001 .top_about_stones_02 {
    right: 13vw;
    bottom: 12vw;
    width: 9vw;
  }
}
@media (width <= 600px) {
  .top_001 .top_about_stones_02 {
    display: none;
  }
}
.top_001 .top_about_stones_02 img {
  position: absolute;
  bottom: 0;
  z-index: 2;
  transform: scale(-1, 1);
}
@media (width <= 1024px) {
  .top_001 .top_about_stones_02 img {
    bottom: 1vw;
    left: -1vw;
  }
}
.top_001 .top_about_stones_02::after {
  position: absolute;
  bottom: -27px;
  left: -62px;
  z-index: 0;
  display: block;
  width: 232px;
  height: 70px;
  content: "";
  background: url(../img/top_about_stones_02.webp) bottom/100% auto no-repeat;
}
@media (width <= 1024px) {
  .top_001 .top_about_stones_02::after {
    bottom: -2vw;
    left: -8vw;
    width: 24vw;
    height: 8vw;
  }
}
@media (width <= 600px) {
  .top_001 .top_about_stones_02::after {
    bottom: -5vw;
    left: -10vw;
    width: 40vw;
    height: 12vw;
  }
}

.top_002 {
  padding: 250px 0;
}
@media (width <= 1024px) {
  .top_002 {
    padding: 20vw 0;
  }
}
@media (width <= 600px) {
  .top_002 {
    padding: 25vw 0;
  }
}
.top_002 > div {
  width: 85%;
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}
@media (width <= 1024px) {
  .top_002 > div {
    width: 92%;
  }
}
@media (width <= 600px) {
  .top_002 > div {
    width: 85%;
  }
}
.top_002 > div h2 {
  position: relative;
  display: inline-block;
  margin: 0 0 100px;
  font-family: "Darumadrop", sans-serif;
  font-size: 30px;
  color: #5e554d;
  letter-spacing: 0.05em;
}
@media (width <= 600px) {
  .top_002 > div h2 {
    margin: 0 0 10vw;
    font-size: 8vw;
  }
}
.top_002 > div h2 span {
  display: block;
  margin-top: 5px;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 13px;
}
@media (width <= 600px) {
  .top_002 > div h2 span {
    font-size: 3vw;
  }
}
.top_002 > div h2::before {
  position: absolute;
  bottom: 25px;
  left: -50px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
.top_002 > div h2::after {
  position: absolute;
  right: -50px;
  bottom: 25px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
.top_002 > div ul {
  display: flex;
  gap: 60px;
  justify-content: space-between;
  margin: 0 0 100px;
}
@media (width <= 1024px) {
  .top_002 > div ul {
    gap: 22px;
    justify-content: space-between;
  }
}
@media (width <= 600px) {
  .top_002 > div ul {
    flex-flow: column;
    gap: 0;
    margin: 0 0 5vw;
  }
}
.top_002 > div ul li {
  width: calc(33.33% - 20px);
}
@media (width <= 1024px) {
  .top_002 > div ul li {
    width: calc(33.33% - 15px);
  }
}
@media (width <= 600px) {
  .top_002 > div ul li {
    width: 100%;
    padding: 15vw 0;
  }
  .top_002 > div ul li:not(:last-child) {
    border-bottom: 1px dotted #9e8686;
  }
}
.top_002 > div ul li .img_box {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 35px;
}
@media (width <= 600px) {
  .top_002 > div ul li .img_box {
    margin: 0 0 3vw;
  }
}
.top_002 > div ul li .img_box img {
  height: 150px;
}
@media (width <= 1024px) {
  .top_002 > div ul li .img_box img {
    height: 100px;
  }
}
@media (width <= 600px) {
  .top_002 > div ul li .img_box img {
    height: 16vw;
  }
}
.top_002 > div ul li:last-child img {
  height: 120px;
  margin: 20px 0 10px;
}
@media (width <= 1024px) {
  .top_002 > div ul li:last-child img {
    height: 100px;
    margin: 0;
  }
}
@media (width <= 600px) {
  .top_002 > div ul li:last-child img {
    height: 15vw;
    margin: 2vw 0 1vw;
  }
}
.top_002 > div ul li h3 {
  margin: 0 0 30px;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 20px;
  letter-spacing: 0.2em;
}
@media (width <= 1024px) {
  .top_002 > div ul li h3 {
    margin: 0 0 3vw;
    font-size: 18px;
  }
}
@media (width <= 600px) {
  .top_002 > div ul li h3 {
    margin: 0 0 5vw;
    font-size: 5vw;
  }
}
.top_002 > div ul li h3 span {
  display: block;
  margin: 15px 0 0;
  font-family: "vdl-penletter", sans-serif;
  font-size: 16px;
  color: #9e9a9a;
  letter-spacing: 0.1em;
}
@media (width <= 1024px) {
  .top_002 > div ul li h3 span {
    margin: 1vw 0 0;
    font-size: 15px;
  }
}
@media (width <= 600px) {
  .top_002 > div ul li h3 span {
    font-size: 3.6vw;
  }
}
.top_002 > div ul li p {
  font-size: 17px;
  line-height: 2.5;
  letter-spacing: 0.05em;
}
@media (width <= 1024px) {
  .top_002 > div ul li p {
    font-size: 14px;
    letter-spacing: 0;
  }
}
@media (width <= 600px) {
  .top_002 > div ul li p {
    font-size: 3.6vw;
    line-height: 2;
    letter-spacing: 0.05em;
  }
}

.link_btn {
  position: relative;
  width: 80%;
  max-width: 400px;
  padding: 30px 30px 30px 0;
  margin: 0 auto;
  font-size: 16px;
  color: #fff;
  text-align: center;
  letter-spacing: 0.2em;
  background-color: #c1b0b0;
  border-radius: 50px;
  transition: all 0.5s;
}
@media (width <= 600px) {
  .link_btn {
    padding: 5vw 0;
    margin: 0 auto;
    font-size: 3.8vw;
    letter-spacing: 0.1em;
  }
}
.link_btn span {
  position: absolute;
  top: calc(50% - 18px);
  right: 30px;
  display: block;
  width: 36px;
  height: 36px;
  background: url(../img/link_btn_arrow.svg) center/100% auto no-repeat;
  background-color: #fff;
  border-radius: 50%;
  transition: all 0.5s;
}
@media (width <= 600px) {
  .link_btn span {
    top: calc(50% - 3.5vw);
    right: 5vw;
    width: 7vw;
    height: 7vw;
  }
}
.link_btn:hover {
  background-color: #9e8686;
}
.link_btn:hover span {
  top: calc(50% - 18px);
  transform: scale(1.2);
}

.top_003 {
  position: relative;
  height: 1500px;
  padding: 300px 0;
  background-color: #fdefef;
  /* 前へ次への矢印カスタマイズ */
  /* 前へ次への矢印カスタマイズ */
  /* 画像サイズ調整 */
}
@media (width <= 1024px) {
  .top_003 {
    height: 1400px;
    padding: 200px 0;
  }
}
@media (width <= 768px) {
  .top_003 {
    height: 150vw;
    padding: 25vw 0 0;
  }
}
@media (width <= 600px) {
  .top_003 {
    height: 210vw;
    padding: 20vw 0;
  }
}
.top_003 > div {
  position: relative;
  text-align: center;
}
.top_003 > div h2 {
  position: relative;
  display: inline-block;
  margin: 0 0 100px;
  font-family: "Darumadrop", sans-serif;
  font-size: 30px;
  color: #5e554d;
  letter-spacing: 0.05em;
}
@media (width <= 600px) {
  .top_003 > div h2 {
    margin: 0 0 12vw;
    font-size: 8vw;
  }
}
.top_003 > div h2 span {
  display: block;
  margin: 15px 0 0;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 13px;
}
@media (width <= 600px) {
  .top_003 > div h2 span {
    font-size: 3vw;
  }
}
.top_003 > div h2::before {
  position: absolute;
  bottom: 32px;
  left: -50px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
.top_003 > div h2::after {
  position: absolute;
  right: -50px;
  bottom: 32px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
.top_003 .work_txt {
  padding: 20px;
}
@media (width <= 600px) {
  .top_003 .work_txt {
    padding: 3vw;
  }
}
.top_003 .work_txt .category {
  box-sizing: border-box;
  display: inline-block;
  min-width: 110px;
  padding: 3px 5px 5px 7px;
  margin: 0 0 17px;
  font-size: 12px;
  color: #fff;
  text-align: center;
  letter-spacing: 0.1em;
  background-color: #666;
  border-radius: 15px;
}
@media (width <= 600px) {
  .top_003 .work_txt .category {
    min-width: 7em;
    font-size: 3vw;
    background-color: #999;
  }
}
.top_003 .work_txt h3 {
  margin: 0 0 15px;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .top_003 .work_txt h3 {
    margin: 0 0 1vw;
    font-size: 3.8vw;
  }
}
.top_003 .work_txt p {
  font-size: 15px;
  text-align: right;
}
@media (width <= 600px) {
  .top_003 .work_txt p {
    font-size: 3.4vw;
  }
}
.top_003 .sliders-container {
  position: absolute;
  left: calc(50% - 1000px);
  display: flex;
  gap: 50px;
  align-items: center;
  justify-content: center;
  width: 2000px;
}
@media screen and (max-width: 2000px) {
  .top_003 .sliders-container {
    left: 10%;
    width: 80%;
  }
}
.top_003 .sliders-container .swiper {
  width: 30%;
  max-width: 450px;
  overflow: hidden;
  border-radius: 30px;
}
.top_003 .sliders-container .slider-b-wrap {
  position: relative;
  width: 45%;
  max-width: 800px;
  height: 680px;
}
@media screen and (max-width: 2000px) {
  .top_003 .sliders-container .slider-b-wrap {
    width: 100%;
  }
}
@media (width <= 1024px) {
  .top_003 .sliders-container .slider-b-wrap {
    width: 80%;
    height: 67vw;
  }
}
@media (width <= 600px) {
  .top_003 .sliders-container .slider-b-wrap {
    width: 100%;
    height: 60vw;
  }
}
.top_003 .sliders-container .slider-a,
.top_003 .sliders-container .slider-c {
  margin-bottom: 100px;
}
@media (width <= 1024px) {
  .top_003 .sliders-container .slider-a,
  .top_003 .sliders-container .slider-c {
    display: none;
  }
}
.top_003 .sliders-container .slider-b {
  width: 100%;
  max-width: 800px;
}
.top_003 .sliders-container .swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: -25px;
}
.top_003 .sliders-container .slider-b-txt {
  position: absolute;
  bottom: 50px;
  left: calc(50% - 320px);
  z-index: 5;
  width: 80%;
  max-width: 680px;
  text-align: left;
  background-color: #fff;
  border: 2px solid #999;
  border-radius: 15px;
}
@media (width <= 1024px) {
  .top_003 .sliders-container .slider-b-txt {
    bottom: 55px;
    left: 5%;
    z-index: 5;
    width: 90%;
    border: 2px solid #ccc;
  }
}
@media (width <= 768px) {
  .top_003 .sliders-container .slider-b-txt {
    bottom: 0px;
  }
}
@media (width <= 600px) {
  .top_003 .sliders-container .slider-b-txt {
    bottom: -35vw;
    left: 5%;
    z-index: 5;
    width: 90%;
    border: 2px solid #ccc;
  }
}
.top_003 .sliders-container .slider-b-txt .swiper-slide {
  background-color: #fff;
}
.top_003 .swiper-pagination-bullet {
  width: 11px;
  height: 11px;
  margin: 0 10px;
  background-color: #5e554d;
}
.top_003 .swiper-button-prev,
.top_003 .swiper-button-next {
  display: flex;
  align-items: center;
  width: 80px;
  height: 80px;
  border: 1px solid #5e554d;
  border-radius: 50%;
  transition: all 0.5s;
}
@media screen and (min-width: 601px) {
  .top_003 .swiper-button-prev,
  .top_003 .swiper-button-next {
    display: none;
  }
}
@media (width <= 600px) {
  .top_003 .swiper-button-prev,
  .top_003 .swiper-button-next {
    width: 13vw;
    height: 13vw;
  }
}
.top_003 .swiper-button-prev:hover,
.top_003 .swiper-button-next:hover {
  background-color: #5e554d;
}
.top_003 .swiper-button-prev:hover .cls-1,
.top_003 .swiper-button-next:hover .cls-1 {
  fill: none;
  stroke: #fff;
  stroke-miterlimit: 10;
}
.top_003 .swiper-button-prev svg,
.top_003 .swiper-button-next svg {
  width: 22px;
  height: 22px;
}
@media (width <= 600px) {
  .top_003 .swiper-button-prev svg,
  .top_003 .swiper-button-next svg {
    width: 4vw;
    height: 4vw;
  }
}
.top_003 .swiper-button-prev svg {
  transform: rotate(180deg);
}
.top_003 .cls-1 {
  fill: none;
  stroke: #5e554d;
  stroke-miterlimit: 10;
}
.top_003 .swiper-button-prev {
  top: calc(50% - 90px);
  left: -91px;
}
@media (width <= 600px) {
  .top_003 .swiper-button-prev {
    top: calc(50% - 3vw);
    left: -6vw;
    background-color: #fff;
  }
}
.top_003 .swiper-button-next {
  top: calc(50% - 90px);
  right: -91px;
}
@media (width <= 600px) {
  .top_003 .swiper-button-next {
    top: calc(50% - 3vw);
    right: -6vw;
    background-color: #fff;
  }
}
.top_003 .swiper-button-prev::after,
.top_003 .swiper-button-next::after {
  display: none;
}
.top_003 .slider-a .swiper-slide,
.top_003 .slider-c .swiper-slide {
  height: 300px;
  overflow: hidden;
}
.top_003 .slider-b .swiper-slide {
  height: 540px;
  overflow: hidden;
}
@media (width <= 1024px) {
  .top_003 .slider-b .swiper-slide {
    height: 50vw;
  }
}
@media (width <= 600px) {
  .top_003 .slider-b .swiper-slide {
    height: 60vw;
  }
}
.top_003 .swiper-slide {
  background-color: #fff;
}
.top_003 .swiper-slide img {
  box-sizing: border-box;
  width: 100%;
  height: auto;
}
.top_003 .man_woman {
  position: absolute;
  bottom: 150px;
  left: calc(50% - 450px);
  width: 260px;
  height: 280px;
  background: url(../img/top_004_bg.webp) bottom/100% no-repeat;
}
@media (width <= 1024px) {
  .top_003 .man_woman {
    bottom: 3vw;
    left: 5vw;
    width: 26vw;
    height: 28vw;
  }
}
.top_003 .man_woman img {
  position: absolute;
  bottom: 33px;
  left: 55px;
  width: 140px;
}
@media (width <= 1024px) {
  .top_003 .man_woman img {
    bottom: 3vw;
    left: 6.5vw;
    width: 14vw;
  }
}
.top_003 .tree {
  position: absolute;
  right: calc(50% - 473px);
  bottom: 161px;
  width: 192px;
}
@media screen and (max-width: 2000px) {
  .top_003 .tree {
    right: 5vw;
    bottom: 0;
    width: 21vw;
  }
}
@media (width <= 1024px) {
  .top_003 .tree {
    right: 10vw;
    bottom: 3vw;
    width: 19vw;
  }
}
.top_003 .viewall {
  position: absolute;
  right: calc(50% - 650px);
  bottom: 190px;
  font-family: vdl-penletter, sans-serif;
  font-size: 18px;
  color: #5e554d;
  letter-spacing: 0.1em;
  transition: 0.5s;
}
@media (width <= 1024px) {
  .top_003 .viewall {
    right: 10%;
    bottom: -4px;
    font-size: 16px;
  }
}
@media (width <= 768px) {
  .top_003 .viewall {
    right: -28px;
    bottom: -43px;
    font-size: 16px;
  }
}
@media (width <= 600px) {
  .top_003 .viewall {
    right: 5vw;
    bottom: -52vw;
    font-size: 4vw;
  }
}
.top_003 .viewall img {
  width: 37px;
  margin-left: 1em;
  vertical-align: 5px;
}

.top_004 {
  position: relative;
  padding: 200px 0 200px;
  overflow: hidden;
  background: #fcfaf7;
}
@media (width <= 1024px) {
  .top_004 {
    padding: 200px 0;
  }
}
@media (width <= 600px) {
  .top_004 {
    padding: 30vw 0 30vw;
  }
}
.top_004 .cycle {
  position: absolute;
  top: 100px;
  right: 1200px;
  z-index: 5;
  width: 146px;
  transform: translateX(1000%);
  animation: animetxt3 50s linear infinite;
}
@media (width <= 1024px) {
  .top_004 .cycle {
    top: 120px;
    right: 400px;
    width: 13vw;
    animation: animetxt3 24s linear infinite;
  }
}
@media (width <= 600px) {
  .top_004 .cycle {
    top: 18vw;
    right: 0vw;
    width: 16vw;
    transform: translateX(120%);
    animation: animetxt3 20s linear infinite;
  }
}
@keyframes animetxt3 {
  100% {
    transform: translateX(-900%);
  }
}
@media (width <= 600px) {
  @keyframes animetxt3 {
    100% {
      transform: translateX(-650%);
    }
  }
}
.top_004 h2 {
  position: relative;
  padding: 65px 0 60px;
  margin: 0 0 100px;
  font-family: "Darumadrop", sans-serif;
  font-size: 30px;
  color: #5e554d;
  text-align: center;
  letter-spacing: 0.05em;
  background: url(../img/contact_ttl_Bg.webp) top/cover no-repeat;
}
@media (width <= 600px) {
  .top_004 h2 {
    padding: 6vw 0 7vw;
    margin: 0 0 15vw;
    font-size: 8vw;
  }
}
.top_004 h2 span {
  display: block;
  margin: 10px 0 0;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 15px;
  font-weight: bold;
  color: #000;
  letter-spacing: 0.2em;
}
@media (width <= 600px) {
  .top_004 h2 span {
    font-size: 3vw;
  }
}
.top_004 h2::before {
  position: absolute;
  right: calc(50% - 110px);
  bottom: 71px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
@media (width <= 600px) {
  .top_004 h2::before {
    right: calc(50% - 25vw);
    bottom: 15vw;
    width: 8vw;
    height: 6vw;
  }
}
.top_004 h2::after {
  position: absolute;
  bottom: 71px;
  left: calc(50% - 110px);
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
@media (width <= 600px) {
  .top_004 h2::after {
    bottom: 15vw;
    left: calc(50% - 25vw);
    width: 8vw;
    height: 6vw;
  }
}
.top_004 > div {
  width: 85%;
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
}
.top_004 > div fieldset {
  width: 80%;
  max-width: 800px;
  margin: 0 auto 50px;
  text-align: left;
}
@media (width <= 600px) {
  .top_004 > div fieldset {
    width: 100%;
    margin: 0 auto 8vw;
  }
}
.top_004 > div fieldset legend {
  width: 100%;
  margin: 0 0 10px;
  font-family: "vdl-penletter", sans-serif;
  font-size: 16px;
  color: #4d4d4d;
  text-align: left;
}
@media (width <= 600px) {
  .top_004 > div fieldset legend {
    margin: 0 0 2vw;
    font-size: 4vw;
  }
}
.top_004 > div fieldset legend::after {
  display: inline-block;
  margin-left: 1em;
  font-size: 13px;
  color: #ff2c64;
  content: "*必須";
}
@media (width <= 600px) {
  .top_004 > div fieldset legend::after {
    font-size: 3vw;
  }
}
.top_004 > div fieldset p {
  width: 100%;
}
.top_004 > div fieldset input,
.top_004 > div fieldset textarea {
  box-sizing: border-box;
  width: 100%;
  padding: 15px;
  font-size: 16px;
  background-color: #fff;
  border: 1px solid #666;
  border-radius: 15px;
}
@media (width <= 600px) {
  .top_004 > div fieldset input,
  .top_004 > div fieldset textarea {
    padding: 3vw;
  }
}
.top_004 input[type=submit] {
  width: 80%;
  max-width: 300px;
  padding: 24px;
  font-size: 16px;
  color: #fff;
  letter-spacing: 0.15em;
  background-color: #c1b0b0;
  border-radius: 50px;
  transition: all 0.5s;
}
@media (width <= 600px) {
  .top_004 input[type=submit] {
    padding: 5vw 3vw;
    font-size: 3.6vw;
  }
}
.top_004 input[type=submit]:hover {
  background-color: #5e554d;
}

p.copyright {
  position: absolute;
  width: 100%;
  padding: 14px;
  font-size: 12px;
  color: #fff;
  text-align: right;
  background-color: #5e554d;
}

.common_header {
  position: relative;
  height: 480px;
  padding: 160px 0 280px;
  overflow: hidden;
  background: #efe6e6 url(../img/common_header_bg.webp) bottom/1920px auto repeat-x;
}
@media (width <= 1024px) {
  .common_header {
    height: 300px;
    background-size: 135% auto;
  }
}
@media (width <= 768px) {
  .common_header {
    height: 45vw;
    padding: 15vw 0;
  }
}
@media (width <= 600px) {
  .common_header {
    height: 57vw;
    padding: 18vw 0 13vw;
    overflow: hidden;
    background: #efe6e6 url(../img/common_header_bg.webp) bottom/155% auto repeat-x;
  }
}
.common_header h2 {
  position: absolute;
  left: calc(50% - 500px);
  font-family: "Darumadrop", sans-serif;
  font-size: 50px;
  color: #5e554d;
}
@media (width <= 1024px) {
  .common_header h2 {
    left: 8vw;
  }
}
@media (width <= 768px) {
  .common_header h2 {
    font-size: 5vw;
  }
}
@media (width <= 600px) {
  .common_header h2 {
    left: 10vw;
    font-size: 7vw;
  }
}
.common_header h2 span {
  display: block;
  margin: 10px 0 0;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 16px;
  letter-spacing: 0.3em;
}
@media (width <= 768px) {
  .common_header h2 span {
    margin: 1vw 0 0;
    font-size: 13px;
  }
}
@media (width <= 600px) {
  .common_header h2 span {
    margin-top: 1vw;
    font-size: 3vw;
  }
}
.common_header h2 ::after {
  display: block;
  width: 108%;
  height: 13px;
  margin: 10px 0 0;
  content: "";
  background: url(../img/common_ttl_line.webp) left center/auto 100% no-repeat;
}
@media (width <= 600px) {
  .common_header h2 ::after {
    width: 98%;
    height: 3vw;
    margin: 1vw 0 0;
  }
}
.common_header img {
  position: absolute;
}
.common_header img.people {
  z-index: 5;
}
.common_header img.building {
  right: calc(50% - 500px);
  bottom: 140px;
  z-index: 4;
  width: 300px;
  height: auto;
}
@media (width <= 1024px) {
  .common_header img.building {
    right: 7vw;
    bottom: 110px;
    width: 24vw;
  }
}
@media (width <= 768px) {
  .common_header img.building {
    bottom: 10.5vw;
  }
}
@media (width <= 600px) {
  .common_header img.building {
    right: 9vw;
    bottom: 10vw;
    width: 30vw;
  }
}

/*フローリアウェブデザインについて*/
.page-about .common_header img.people {
  right: 1200px;
  bottom: 105px;
  z-index: 5;
  width: 110px;
  transform: translateX(1200%);
  animation: about_animetxt 25s linear infinite;
}
@media (width <= 1024px) {
  .page-about .common_header img.people {
    right: 100vw;
    bottom: 7vw;
    z-index: 5;
    width: 10vw;
    animation: animetxt 20s linear infinite;
  }
}
@media (width <= 600px) {
  .page-about .common_header img.people {
    right: 0;
    bottom: 4vw;
    z-index: 5;
    width: 12vw;
    transform: translateX(100%);
    animation: animetxt 20s linear infinite;
  }
}
@keyframes about_animetxt {
  100% {
    transform: translateX(-50%);
  }
}

.about_001 {
  position: relative;
  padding: 100px 0 200px;
}
@media (width <= 600px) {
  .about_001 {
    padding: 15vw 0 30vw;
  }
}
.about_001 > div {
  width: 85%;
  max-width: 1000px;
  margin: 0 auto;
  text-align: center;
}
.about_001 > div h2 {
  position: relative;
  display: inline-block;
  margin: 0 0 60px;
  font-family: "Darumadrop", sans-serif;
  font-size: 30px;
  color: #5e554d;
  text-indent: -1em;
  letter-spacing: 0.05em;
}
@media (width <= 600px) {
  .about_001 > div h2 {
    padding: 6vw 0 7vw;
    margin: 0;
    font-size: 7vw;
    text-indent: 0;
  }
}
.about_001 > div h2::before {
  position: absolute;
  bottom: 20px;
  left: -80px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
@media (width <= 600px) {
  .about_001 > div h2::before {
    bottom: 12vw;
    left: calc(50% - 25vw);
    width: 7vw;
    height: 6vw;
  }
}
.about_001 > div h2::after {
  position: absolute;
  right: -50px;
  bottom: 20px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
@media (width <= 600px) {
  .about_001 > div h2::after {
    right: calc(50% - 25vw);
    bottom: 12vw;
    width: 7vw;
    height: 6vw;
  }
}
.about_001 > div h2 span {
  display: block;
  margin: 5px 0 0;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 13px;
}
@media (width <= 600px) {
  .about_001 > div h2 span {
    font-size: 3vw;
  }
}
.about_001 dl {
  margin: 0 0 80px;
  font-family: "vdl-penletter", sans-serif;
}
.about_001 dl dt {
  margin: 0 0 30px;
  font-size: 16px;
  letter-spacing: 0.15em;
}
.about_001 dl dd {
  font-size: 20px;
}
.about_001 p {
  margin: 0 0 50px;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 18px;
  line-height: 3.2;
  letter-spacing: 0.15em;
}
@media (width <= 600px) {
  .about_001 p {
    margin: 0 0 10vw;
    font-family: "fot-tsukuardgothic-std", sans-serif;
    font-size: 4vw;
  }
}
.about_001 .top_about_stones_01 {
  position: absolute;
  bottom: 150px;
  left: calc(50% - 400px);
  width: 84px;
}
@media (width <= 1024px) {
  .about_001 .top_about_stones_01 {
    left: 15vw;
    width: 8vw;
  }
}
@media (width <= 768px) {
  .about_001 .top_about_stones_01 {
    bottom: 15vw;
  }
}
@media (width <= 600px) {
  .about_001 .top_about_stones_01 {
    bottom: 15vw;
    left: 14vw;
    width: 14vw;
  }
}
.about_001 .top_about_stones_01 img {
  position: absolute;
  bottom: 0;
  left: 10px;
  z-index: 2;
}
.about_001 .top_about_stones_01::after {
  position: absolute;
  bottom: -27px;
  left: -62px;
  z-index: 0;
  display: block;
  width: 232px;
  height: 70px;
  content: "";
  background: url(../img/top_about_stones_01.webp) bottom/100% auto no-repeat;
}
@media (width <= 600px) {
  .about_001 .top_about_stones_01::after {
    bottom: -4vw;
    left: -3.5vw;
    width: 30vw;
    height: 8vw;
  }
}
.about_001 .top_about_stones_02 {
  position: absolute;
  right: calc(50% - 400px);
  bottom: 150px;
  width: 110px;
}
@media (width <= 1024px) {
  .about_001 .top_about_stones_02 {
    right: 15vw;
    width: 10vw;
  }
}
@media (width <= 768px) {
  .about_001 .top_about_stones_02 {
    bottom: 15vw;
  }
}
@media (width <= 600px) {
  .about_001 .top_about_stones_02 {
    right: 15vw;
    bottom: 15vw;
    width: 17vw;
  }
}
.about_001 .top_about_stones_02 img {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  transform: scale(-1, 1);
}
.about_001 .top_about_stones_02::after {
  position: absolute;
  bottom: -27px;
  left: -62px;
  z-index: 0;
  display: block;
  width: 232px;
  height: 70px;
  content: "";
  background: url(../img/top_about_stones_02.webp) bottom/100% auto no-repeat;
}
@media (width <= 600px) {
  .about_001 .top_about_stones_02::after {
    bottom: -4vw;
    left: -3.5vw;
    width: 29vw;
    height: 8vw;
  }
}

.about_002 {
  background-color: #eddfdf;
}
.about_002 > div {
  width: 85%;
  max-width: 1000px;
  padding: 100px 0;
  margin: 0 auto;
  text-align: center;
}
@media (width <= 600px) {
  .about_002 > div {
    padding: 20vw 0;
  }
}
.about_002 > div h2 {
  position: relative;
  display: inline-block;
  margin: 0 0 60px;
  font-family: "Darumadrop", sans-serif;
  font-size: 30px;
  color: #5e554d;
  text-indent: -1em;
  letter-spacing: 0.05em;
}
@media (width <= 600px) {
  .about_002 > div h2 {
    padding: 6vw 0 7vw;
    margin: 0 0 10vw;
    font-size: 7vw;
    text-indent: 0;
  }
}
.about_002 > div h2::before {
  position: absolute;
  bottom: 20px;
  left: -80px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
@media (width <= 600px) {
  .about_002 > div h2::before {
    bottom: 12vw;
    left: calc(50% - 25vw);
    width: 7vw;
    height: 6vw;
  }
}
.about_002 > div h2::after {
  position: absolute;
  right: -50px;
  bottom: 20px;
  display: block;
  width: 33px;
  height: 27px;
  content: "";
  background: url(../img/sprout.webp) top/100% no-repeat;
}
@media (width <= 600px) {
  .about_002 > div h2::after {
    right: calc(50% - 25vw);
    bottom: 12vw;
    width: 7vw;
    height: 6vw;
  }
}
.about_002 > div h2 span {
  display: block;
  margin: 5px 0 0;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 13px;
}
.about_002 ul {
  display: flex;
  gap: 50px;
  justify-content: center;
  width: 100%;
  max-width: 950px;
}
@media (width <= 768px) {
  .about_002 ul {
    flex-flow: column;
    gap: 10vw;
  }
}
.about_002 ul li {
  width: 100%;
  max-width: 424px;
  background: #fff;
  border: 10px #fff solid;
  border-radius: 30px;
}
@media (width <= 768px) {
  .about_002 ul li {
    max-width: 80%;
    margin: 0 auto;
  }
}
@media (width <= 600px) {
  .about_002 ul li {
    max-width: 100%;
  }
}
.about_002 ul li > div {
  padding: 50px;
  border: 1px #c6839a dashed;
  border-radius: 25px;
}
@media (width <= 600px) {
  .about_002 ul li > div {
    padding: 8vw;
    border-radius: 5vw;
  }
}
.about_002 ul li img {
  max-width: 150px;
  margin: 0 0 36px;
}
@media (width <= 600px) {
  .about_002 ul li img {
    width: 30vw;
    margin: 0 0 5vw;
  }
}
.about_002 ul li dl dt {
  margin: 0 0 15px;
  font-size: 24px;
  font-weight: normal;
  color: #333;
  letter-spacing: 0.15em;
}
@media (width <= 600px) {
  .about_002 ul li dl dt {
    margin: 0 0 3vw;
    font-size: 6vw;
  }
}
.about_002 ul li dl dd {
  font-size: 15px;
  color: #333;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .about_002 ul li dl dd {
    font-size: 3.2vw;
  }
}
.about_002 ul li dl::after {
  display: block;
  width: 70px;
  height: 15px;
  margin: 30px 0 26px calc(50% - 35px);
  content: "";
  background: url(../img/member_line.svg) center/100% no-repeat;
}
@media (width <= 600px) {
  .about_002 ul li dl::after {
    width: 15vw;
    height: 3vw;
    margin: 6vw 0 4vw calc(50% - 7.5vw);
  }
}
.about_002 ul li p {
  margin: 0 0 30px;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 16px;
  line-height: 2;
  color: #333;
  text-align: left;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .about_002 ul li p {
    margin: 0 0 5vw;
    font-size: 4vw;
  }
}
.about_002 ul li .skill {
  box-sizing: border-box;
  padding: 30px 50px;
  background-color: #f7f7f7;
  border-radius: 30px;
}
@media (width <= 1024px) {
  .about_002 ul li .skill {
    padding: 30px 2vw;
  }
}
@media (width <= 600px) {
  .about_002 ul li .skill {
    padding: 3vw 5vw;
    border-radius: 5vw;
  }
}
.about_002 ul li .skill h3 {
  margin: 0;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 15px;
  line-height: 2;
  color: #333;
  text-align: left;
}
@media (width <= 600px) {
  .about_002 ul li .skill h3 {
    font-size: 3.6vw;
  }
}
.about_002 ul li .skill p {
  margin: 0 0 5px;
  font-size: 14px;
  color: #333;
}
@media (width <= 600px) {
  .about_002 ul li .skill p {
    font-size: 3.6vw;
  }
}

.page-service .common_header img.people {
  right: calc(50% - 168px);
  bottom: 144px;
  z-index: 5;
  width: 71px;
}
@media (width <= 1024px) {
  .page-service .common_header img.people {
    right: 34.5vw;
    bottom: 10vw;
    z-index: 5;
    width: 6vw;
  }
}
@media (width <= 600px) {
  .page-service .common_header img.people {
    right: 42vw;
    bottom: 10vw;
    z-index: 5;
    width: 9vw;
  }
}
.page-service .common_header img.building {
  right: calc(50% - 535px);
  bottom: 139px;
  z-index: 4;
  width: 376px;
  height: auto;
}
@media (width <= 1024px) {
  .page-service .common_header img.building {
    right: 7vw;
    bottom: 10vw;
    z-index: 4;
    width: 34vw;
  }
}
@media (width <= 600px) {
  .page-service .common_header img.building {
    right: 5vw;
    bottom: 10vw;
    z-index: 4;
    width: 45vw;
    height: auto;
  }
}
.page-service .service_nav {
  padding: 100px 0 100px;
  text-align: center;
}
@media (width <= 600px) {
  .page-service .service_nav {
    padding: 15vw 0;
  }
}
.page-service .service_nav p {
  margin: 0 0 50px;
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-size: 18px;
  color: #5e554d;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .page-service .service_nav p {
    margin: 0 0 10vw;
    font-size: 4vw;
    line-height: 1.6;
  }
}
.page-service .service_nav nav {
  width: 85%;
  max-width: 800px;
  margin: 0 auto;
}
.page-service .service_nav nav ul {
  display: flex;
  justify-content: space-between;
}
.page-service .service_nav nav ul li {
  position: relative;
  width: 30%;
  max-width: 250px;
  height: 250px;
  background-color: #f9f2f2;
  border-radius: 30px;
  transition: 0.5s;
}
@media (width <= 600px) {
  .page-service .service_nav nav ul li {
    height: auto;
    border-radius: 5vw;
  }
}
.page-service .service_nav nav ul li:hover {
  background-color: #d6cbce;
}
.page-service .service_nav nav ul li a {
  display: flex;
  flex-flow: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  margin: 16px 0 0;
}
@media (width <= 600px) {
  .page-service .service_nav nav ul li a {
    margin: 3vw 0 0;
  }
}
.page-service .service_nav nav ul li img {
  width: 60%;
}
.page-service .service_nav nav ul li p {
  font-size: 22px;
  color: #5e554d;
}
@media (width <= 600px) {
  .page-service .service_nav nav ul li p {
    margin: 0 0 5vw;
    font-size: 3.6vw;
    line-height: 1.5;
    letter-spacing: 0;
  }
}
.page-service .service_container {
  padding: 200px 0;
  background-color: #ddd6d3;
}
@media (width <= 600px) {
  .page-service .service_container {
    padding: 20vw 0;
  }
}
.page-service .service_container ul {
  display: flex;
  flex-flow: column;
  gap: 100px;
  width: 85%;
  max-width: 1000px;
  margin: 0 auto;
}
.page-service .service_container ul li {
  position: relative;
  background-color: #fff;
  border: 10px solid #fff;
  border-radius: 50px;
}
@media (width <= 600px) {
  .page-service .service_container ul li {
    border-radius: 12vw;
  }
}
.page-service .service_container ul li > div {
  box-sizing: border-box;
  padding: 150px 70px 100px;
  text-align: center;
  border: dashed 1px #5e554d;
  border-radius: 45px;
}
@media (width <= 600px) {
  .page-service .service_container ul li > div {
    padding: 21vw 6vw 12vw;
    border-radius: 10vw;
  }
}
.page-service .service_container ul li > div > img {
  width: 200px;
  margin: 0;
}
@media (width <= 600px) {
  .page-service .service_container ul li > div > img {
    width: 30vw;
  }
}
.page-service .service_container ul li > div .num {
  position: absolute;
  top: -10px;
  left: calc(50% - 58px);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 116px;
  height: 116px;
  background-color: #5e554d;
}
@media (width <= 600px) {
  .page-service .service_container ul li > div .num {
    top: -3.2vw;
    left: calc(50% - 9vw);
    width: 18vw;
    height: 18vw;
  }
}
.page-service .service_container ul li > div .num img {
  width: 60px;
  margin-top: -8px;
}
@media (width <= 600px) {
  .page-service .service_container ul li > div .num img {
    width: 10vw;
    margin-top: -1vw;
  }
}
.page-service .service_container ul li > div h3 {
  margin: 0 0 34px;
  font-size: 24px;
  color: #5e554d;
  text-indent: -0.5em;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .page-service .service_container ul li > div h3 {
    margin: 0 0 5vw;
    font-size: 6vw;
  }
}
.page-service .service_container ul li > div h3::after {
  display: block;
  width: 100%;
  height: 15px;
  margin: 30px 0 0;
  content: "";
  background: url(../img/service_line.svg) center/100% no-repeat;
}
@media (width <= 600px) {
  .page-service .service_container ul li > div h3::after {
    height: 3vw;
    margin: 7vw 0 0;
    background: url(../img/service_line.svg) center/207% no-repeat;
  }
}
.page-service .service_container ul li > div p {
  margin: 0 0 50px;
  font-size: 18px;
  line-height: 3;
  text-align: left;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .page-service .service_container ul li > div p {
    margin: 0 0 6vw;
    font-size: 4vw;
    line-height: 2.5;
  }
}
@media (width <= 600px) {
  .page-service .service_001 .link_btn {
    width: 100%;
  }
}
.page-service .service_002 table,
.page-service .service_003 table {
  box-sizing: border-box;
  display: block;
  width: 100%;
}
.page-service .service_002 table caption,
.page-service .service_003 table caption {
  display: block;
  width: 100%;
  margin: 0 0 20px;
  font-size: 20px;
  color: #5e554d;
  text-align: center;
}
@media (width <= 600px) {
  .page-service .service_002 table caption,
  .page-service .service_003 table caption {
    margin: 0 0 3vw;
    font-size: 4.5vw;
  }
}
.page-service .service_002 table tbody,
.page-service .service_003 table tbody {
  display: table;
  width: 100%;
  margin: 0 0 30px;
  overflow: hidden;
  background-color: #eae4e1;
  border: 15px solid #eae4e1;
  border-right: 20px solid #eae4e1;
  border-left: 20px solid #eae4e1;
  border-radius: 30px;
}
@media (width <= 600px) {
  .page-service .service_002 table tbody,
  .page-service .service_003 table tbody {
    margin: 0 0 3vw;
    background-color: #eae4e1;
    border: 2vw solid #eae4e1;
    border-right: 2vw solid #eae4e1;
    border-left: 2vw solid #eae4e1;
    border-radius: 5vw;
  }
}
.page-service .service_002 table tbody th,
.page-service .service_003 table tbody th {
  width: 30%;
  padding: 20px 0;
  font-size: 18px;
  color: #5e554d;
  text-align: center;
  letter-spacing: 0.2em;
  border-right: 1px dashed #5e554d;
}
@media (width <= 1024px) {
  .page-service .service_002 table tbody th,
  .page-service .service_003 table tbody th {
    width: 40%;
  }
}
@media (width <= 768px) {
  .page-service .service_002 table tbody th,
  .page-service .service_003 table tbody th {
    font-size: 14px;
  }
}
@media (width <= 600px) {
  .page-service .service_002 table tbody th,
  .page-service .service_003 table tbody th {
    padding: 5vw 0;
    font-size: 4vw;
    letter-spacing: 0;
  }
}
.page-service .service_002 table tbody td,
.page-service .service_003 table tbody td {
  width: 70%;
  padding: 20px 0;
  font-size: 20px;
  font-weight: bold;
  color: #5e554d;
  text-align: center;
  letter-spacing: 0.2em;
}
@media (width <= 1024px) {
  .page-service .service_002 table tbody td,
  .page-service .service_003 table tbody td {
    width: 60%;
    font-weight: bold;
    vertical-align: middle;
  }
}
@media (width <= 768px) {
  .page-service .service_002 table tbody td,
  .page-service .service_003 table tbody td {
    font-size: 18px;
  }
}
@media (width <= 600px) {
  .page-service .service_002 table tbody td,
  .page-service .service_003 table tbody td {
    padding: 4vw 0;
    font-size: 4vw;
    letter-spacing: 0;
  }
}
.page-service .service_002 table tbody td span,
.page-service .service_003 table tbody td span {
  margin: 0 2em 0 0;
  font-size: 16px;
  letter-spacing: 0.5em;
}
@media (width <= 600px) {
  .page-service .service_002 table tbody td span,
  .page-service .service_003 table tbody td span {
    margin: 0;
    font-size: 4vw;
  }
}
.page-service .service_002 table tbody tr:first-child,
.page-service .service_003 table tbody tr:first-child {
  border-bottom: 1px dashed #5e554d;
}
.page-service .service_002 .note,
.page-service .service_003 .note {
  display: block;
  margin-left: 2em;
  font-size: 15px;
  line-height: 2;
  color: #5e554d;
  text-align: left;
  text-indent: -2em;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .page-service .service_002 .note,
  .page-service .service_003 .note {
    margin-left: 2.2em;
    font-size: 3.6vw;
    text-indent: -2.2em;
    letter-spacing: 0.1em;
  }
}

/*ウェブサイト制作について*/
.page-production .site_contents {
  background-color: #f7f1ed;
}
.page-production .common_header img.building {
  width: 350px;
}
@media (width <= 1024px) {
  .page-production .common_header img.building {
    width: 37vw;
  }
}
@media (width <= 600px) {
  .page-production .common_header img.building {
    right: 4vw;
    bottom: 10vw;
    width: 39vw;
  }
}
.page-production .common_header img.people {
  right: calc(50% - 150px);
  bottom: 131px;
  z-index: 5;
  width: 86px;
}
@media (width <= 1024px) {
  .page-production .common_header img.people {
    right: 39vw;
    bottom: 8vw;
    width: 8vw;
  }
}
@media (width <= 600px) {
  .page-production .common_header img.people {
    right: 38vw;
    bottom: 8vw;
    width: 9vw;
  }
}
.page-production .common_header h2 ::after {
  width: 101%;
  height: 14px;
}
@media (width <= 1024px) {
  .page-production .common_header h2 ::after {
    width: 105%;
  }
}
@media (width <= 600px) {
  .page-production .common_header h2 ::after {
    width: 97%;
    height: 3vw;
    margin: 1vw 0 0;
  }
}

#production_001 {
  padding: 170px 0;
  text-align: center;
}
@media (width <= 1024px) {
  #production_001 {
    padding: 15vw 0;
  }
}
@media (width <= 600px) {
  #production_001 {
    padding: 20vw 0;
  }
}
#production_001 h3 {
  position: relative;
  width: 85%;
  max-width: 740px;
  padding: 20px 0;
  margin: 0 auto 100px;
  font-size: 24px;
  color: #5e554d;
  letter-spacing: 0.2em;
  background-color: #fff;
}
@media (width <= 1024px) {
  #production_001 h3 {
    padding: 1vw 0;
    margin: 0 auto 6vw;
    font-size: 20px;
  }
}
@media (width <= 600px) {
  #production_001 h3 {
    padding: 2vw 0 1.5vw;
    margin: 0 auto 8vw;
    font-size: 5vw;
  }
}
#production_001 h3::before, #production_001 h3::after {
  position: absolute;
  top: -7px;
  left: 0;
  z-index: 2;
  display: block;
  width: 100%;
  height: 15px;
  content: "";
  background: url(../img/production_ttl_line.svg) center/100% no-repeat;
}
#production_001 h3::after {
  top: auto;
  bottom: -7px;
}
#production_001 h3 img {
  width: 100px;
  height: auto;
  margin-left: 0;
  vertical-align: -36px;
}
@media (width <= 600px) {
  #production_001 h3 img {
    width: 19vw;
    margin-left: 0;
    vertical-align: -7vw;
  }
}
#production_001 ul {
  display: flex;
  justify-content: space-between;
  width: 85%;
  max-width: 1440px;
  margin: 0 auto 80px;
}
@media (width <= 1024px) {
  #production_001 ul {
    flex-flow: column;
    gap: 10vw;
  }
}
@media (width <= 600px) {
  #production_001 ul {
    margin: 0 auto 5vw;
  }
}
#production_001 ul li {
  width: 32%;
  padding: 0 0 50px;
  overflow: hidden;
  background-color: #fff;
  border-radius: 40px;
}
@media (width <= 1024px) {
  #production_001 ul li {
    width: 100%;
  }
}
@media (width <= 600px) {
  #production_001 ul li {
    border-radius: 5vw;
  }
}
#production_001 ul li h4 {
  padding: 30px 0;
  font-size: 20px;
  letter-spacing: 0.15em;
  background-color: #edd7ca;
}
@media (width <= 600px) {
  #production_001 ul li h4 {
    padding: 4vw 0;
    font-size: 4vw;
  }
}
#production_001 ul li:nth-child(2) h4 {
  background-color: #dbbeaf;
}
#production_001 ul li:nth-child(3) h4 {
  background-color: #b59e93;
}
#production_001 ul li dl {
  width: 85%;
  padding: 20px 0 50px;
  margin: 0 auto;
  border-bottom: 1px dashed #5e554d;
}
@media (width <= 600px) {
  #production_001 ul li dl {
    padding: 3vw 0 6vw;
  }
}
#production_001 ul li dl:nth-last-child(2) {
  border: none;
}
#production_001 ul li dl dt {
  margin: 0 0 20px;
  font-size: 15px;
  font-weight: normal;
  text-align: left;
}
@media (width <= 600px) {
  #production_001 ul li dl dt {
    margin: 0 0 2vw;
    font-size: 3vw;
  }
}
#production_001 ul li dl dd {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  #production_001 ul li dl dd {
    font-size: 4.5vw;
  }
}
#production_001 ul li:nth-child(2) h3 {
  background-color: #dbbeaf;
}
#production_001 ul li:nth-child(2) dl:nth-child(2) dd {
  width: 75%;
  margin-left: 13%;
  text-align: left;
}
#production_001 ul li dl:nth-child(2) dd {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 55px;
}
@media (width <= 600px) {
  #production_001 ul li dl:nth-child(2) dd {
    height: auto;
  }
}
#production_001 ul li dl:nth-child(3) dd {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100px;
  font-size: 17px;
  line-height: 1.7;
  text-align: left;
}
@media (width <= 600px) {
  #production_001 ul li dl:nth-child(3) dd {
    height: auto;
    font-size: 4vw;
  }
}
#production_001 .note {
  width: 85%;
  max-width: 1440px;
  padding: 100px;
  margin: 0 auto;
  text-align: left;
  background-color: #fcfaf7;
}
@media (width <= 600px) {
  #production_001 .note {
    padding: 8vw;
  }
}
#production_001 .note p {
  margin-left: 1.3em;
  font-size: 15px;
  line-height: 2;
  text-indent: -1.3em;
}
@media (width <= 600px) {
  #production_001 .note p {
    font-size: 3.6vw;
  }
}

#production_002 {
  padding: 170px 0;
  text-align: center;
}
@media (width <= 600px) {
  #production_002 {
    padding: 10vw 0 25vw;
  }
}
#production_002 h3 {
  position: relative;
  width: 85%;
  max-width: 740px;
  padding: 20px 0;
  margin: 0 auto 100px;
  font-size: 24px;
  color: #5e554d;
  letter-spacing: 0.2em;
  background-color: #fff;
}
@media (width <= 600px) {
  #production_002 h3 {
    padding: 2vw 0 1.5vw;
    margin: 0 auto 8vw;
    font-size: 5vw;
    text-indent: 1em;
  }
}
#production_002 h3::before, #production_002 h3::after {
  position: absolute;
  top: -7px;
  left: 0;
  z-index: 10;
  display: block;
  width: 100%;
  height: 15px;
  content: "";
  background: url(../img/production_ttl_line.svg) center/100% no-repeat;
}
#production_002 h3::after {
  top: auto;
  bottom: -7px;
}
#production_002 h3 img {
  width: 100px;
  height: auto;
  margin-left: 0;
  vertical-align: -36px;
}
@media (width <= 600px) {
  #production_002 h3 img {
    width: 19vw;
    margin-left: 0;
    vertical-align: -7vw;
  }
}
#production_002 ol {
  display: flex;
  flex-flow: column;
  gap: 100px;
  width: 85%;
  max-width: 1200px;
  margin: 0 auto;
}
@media (width <= 600px) {
  #production_002 ol {
    gap: 15vw;
  }
}
#production_002 ol li {
  position: relative;
  display: flex;
  gap: 60px;
  width: 100%;
}
@media (width <= 600px) {
  #production_002 ol li {
    gap: 5vw;
  }
}
#production_002 ol li::before {
  position: absolute;
  top: 130px;
  left: 62px;
  display: block;
  width: 7px;
  height: 100%;
  content: "";
  background-color: #ebe2da;
}
@media (width <= 600px) {
  #production_002 ol li::before {
    top: 15vw;
    left: calc(7.5vw - 2px);
    width: 4px;
  }
}
#production_002 ol li:last-child::before {
  display: none;
}
#production_002 ol li .num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 130px;
  height: 130px;
  background-color: #a08a8a;
  border-radius: 50%;
}
@media (width <= 600px) {
  #production_002 ol li .num {
    width: 15vw;
    height: 15vw;
  }
}
#production_002 ol li .num img {
  width: auto;
  height: 60px;
  margin: 0 0 10px;
}
@media (width <= 600px) {
  #production_002 ol li .num img {
    height: 8vw;
    margin: 0 0 1vw;
  }
}
#production_002 ol li:nth-child(2n) .num {
  background-color: #fff;
}
#production_002 ol li div {
  width: calc(100% - 190px);
  margin: 20px 0 0;
}
@media (width <= 600px) {
  #production_002 ol li div {
    width: calc(100% - 20vw);
    margin: 0;
  }
}
#production_002 ol li div h4 {
  margin: 0 0 30px;
  font-size: 24px;
  text-align: left;
  letter-spacing: 0.2em;
}
@media (width <= 600px) {
  #production_002 ol li div h4 {
    margin: 4vw 0 5vw;
    font-size: 4.5vw;
    line-height: 1.5;
  }
  #production_002 ol li div h4 span {
    display: block;
    font-size: 3.5vw;
  }
}
#production_002 ol li div p {
  font-size: 16px;
  line-height: 2;
  text-align: left;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  #production_002 ol li div p {
    font-size: 4vw;
  }
}
#production_002 ol li div .link_btn {
  max-width: 290px;
  margin: 30px 0 0;
}
@media (width <= 600px) {
  #production_002 ol li div .link_btn {
    width: 100%;
    margin: 4vw 0 0;
  }
}
#production_002 ol li div small {
  display: block;
  margin: 20px 0 0;
  text-align: left;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  #production_002 ol li div small {
    margin: 5vw 0 0;
    line-height: 1.5;
    color: #666;
  }
}
#production_002 ol li:nth-child(7) h4 {
  margin-top: 1vw;
}

.page-archive-work .common_header h2 ::after,
.page-work_category .common_header h2 ::after,
.page-single-works .common_header h2 ::after {
  display: block;
  width: 117%;
}
@media (width <= 600px) {
  .page-archive-work .common_header h2 ::after,
  .page-work_category .common_header h2 ::after,
  .page-single-works .common_header h2 ::after {
    width: 101%;
  }
}
.page-archive-work .common_header img.building,
.page-work_category .common_header img.building,
.page-single-works .common_header img.building {
  width: 350px;
}
@media (width <= 1024px) {
  .page-archive-work .common_header img.building,
  .page-work_category .common_header img.building,
  .page-single-works .common_header img.building {
    width: 34vw;
  }
}
@media (width <= 600px) {
  .page-archive-work .common_header img.building,
  .page-work_category .common_header img.building,
  .page-single-works .common_header img.building {
    width: 39vw;
  }
}
.page-archive-work .common_header img.people,
.page-work_category .common_header img.people,
.page-single-works .common_header img.people {
  right: calc(50% - 150px);
  bottom: 131px;
  z-index: 5;
  width: 72px;
  transform: translateX(-300%);
  animation: animetxt2 60s linear infinite;
}
@media (width <= 1024px) {
  .page-archive-work .common_header img.people,
  .page-work_category .common_header img.people,
  .page-single-works .common_header img.people {
    bottom: 77px;
  }
}
@media (width <= 600px) {
  .page-archive-work .common_header img.people,
  .page-work_category .common_header img.people,
  .page-single-works .common_header img.people {
    right: 43vw;
    bottom: 7vw;
    z-index: 5;
    width: 8vw;
  }
}

.work_wrapper {
  display: flex;
  gap: 4%;
  width: 85%;
  max-width: 1080px;
  padding: 100px 0 200px;
  margin: 0 auto;
}
@media (width <= 1024px) {
  .work_wrapper {
    flex-flow: column;
    gap: 80px;
  }
}
@media (width <= 600px) {
  .work_wrapper {
    gap: 15vw;
    padding: 20vw 0;
  }
}
.work_wrapper .work-navigation {
  width: 18%;
}
@media (width <= 1024px) {
  .work_wrapper .work-navigation {
    width: 100%;
  }
}
.work_wrapper .work-navigation ul {
  display: flex;
  flex-flow: column;
  gap: 10px;
}
@media (width <= 1024px) {
  .work_wrapper .work-navigation ul {
    flex-flow: row;
    flex-wrap: wrap;
    gap: 2vw 2%;
    justify-content: center;
    margin: 0;
  }
}
@media (width <= 600px) {
  .work_wrapper .work-navigation ul {
    flex-flow: wrap;
    margin: 0 0 10vw;
  }
}
@media (width <= 1024px) {
  .work_wrapper .work-navigation li {
    width: 32%;
  }
}
.work_wrapper .work-navigation li a {
  width: 100%;
  padding: 18px 0;
  color: #5e554d;
  text-align: center;
  border: 1px solid #5e554d;
  border-radius: 50px;
  transition: all 0.5s;
}
@media (width <= 600px) {
  .work_wrapper .work-navigation li a {
    padding: 3vw 0;
    font-size: 3.6vw;
  }
}
.work_wrapper .work-navigation li.-actived a, .work_wrapper .work-navigation li:hover a {
  background-color: #efefef;
}
.work_wrapper .work_001 {
  width: 78%;
}
@media (width <= 1024px) {
  .work_wrapper .work_001 {
    width: 100%;
  }
}
.work_wrapper .work_list {
  display: flex;
  flex-flow: column;
}
.work_wrapper .work_list a {
  display: flex;
  gap: 50px;
  padding: 50px 0;
  border-bottom: 2px dotted #9e8686;
}
@media (width <= 600px) {
  .work_wrapper .work_list a {
    flex-flow: column;
    gap: 5vw;
    padding: 13vw 8vw 13vw;
  }
}
.work_wrapper .work_list a:first-child {
  padding-top: 0;
}
.work_wrapper .work_list a .thumbnail_wrapper {
  width: 25%;
  max-width: 300px;
}
@media (width <= 600px) {
  .work_wrapper .work_list a .thumbnail_wrapper {
    width: 100%;
  }
}
.work_wrapper .work_list a .body {
  display: flex;
  flex-flow: column;
  justify-content: center;
  width: calc(75% - 50px);
}
@media (width <= 600px) {
  .work_wrapper .work_list a .body {
    width: 100%;
  }
}
.work_wrapper .work_list a .body h3 {
  margin: 0 0 15px;
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .work_wrapper .work_list a .body h3 {
    margin: 0 0 3vw;
    font-size: 5vw;
    line-height: 2;
  }
}
.work_wrapper .work_list a .body p {
  font-size: 16px;
  line-height: 2;
}
@media (width <= 600px) {
  .work_wrapper .work_list a .body p {
    font-size: 4vw;
  }
}
.work_wrapper .nav-links {
  margin: 100px 0 0;
}
@media (width <= 600px) {
  .work_wrapper .nav-links {
    margin: 8vw 0 0;
  }
}
.work_wrapper .page-numbers {
  display: flex;
  justify-content: center;
}
.work_wrapper .page-numbers li span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: 16px;
  background: #efe6e6;
  border-radius: 50%;
}
@media (width <= 600px) {
  .work_wrapper .page-numbers li span {
    width: 9vw;
    height: 9vw;
    font-size: 4vw;
  }
}
.work_wrapper .page-numbers li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: 16px;
}
@media (width <= 600px) {
  .work_wrapper .page-numbers li a {
    width: 9vw;
    height: 9vw;
    font-size: 4vw;
  }
}

.page-single-works .work_002 {
  width: 85%;
  max-width: 800px;
  margin: 0 auto;
}
.page-single-works .work_002 h2 {
  margin: 0 0 50px;
  font-size: 28px;
  line-height: 1.5;
  color: #4d4d4d;
  text-align: center;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .page-single-works .work_002 h2 {
    font-size: 5vw;
    text-align: left;
  }
}
.page-single-works .work_002 article > img {
  display: block;
  margin: 0 auto 50px;
  overflow: hidden;
  border-radius: 20px;
}
.page-single-works .work_002 span.category {
  display: block;
  width: 130px;
  padding: 4px 0 6px;
  margin: 0 0 30px;
  font-size: 15px;
  color: #9e8686;
  text-align: center;
  letter-spacing: 0.1em;
  border: 1px solid #9e8686;
  border-radius: 15px;
}
@media (width <= 1024px) {
  .page-single-works .work_002 span.category {
    width: 35%;
    padding: 1vw 0;
    margin: 0 0 4vw;
    font-size: 13px;
  }
}
.page-single-works .work_002 .description {
  margin: 0 0 50px;
}
.page-single-works .work_002 .description p {
  font-size: 18px;
  line-height: 2.3;
  color: #4d4d4d;
}
@media (width <= 600px) {
  .page-single-works .work_002 .description p {
    margin: 0 0 5vw;
    font-size: 4vw;
    line-height: 2.5;
    color: #4d4d4d;
  }
}
.page-single-works .work_002 .back_list {
  position: relative;
  width: 100%;
  max-width: 550px;
  padding: 50px 0;
  margin: 0 auto;
  font-size: 20px;
  color: #9e8686;
  text-align: center;
  letter-spacing: 0.1em;
  background-color: #efe6e6;
  transition: 0.5s all;
}
@media (width <= 600px) {
  .page-single-works .work_002 .back_list {
    padding: 8vw;
    font-size: 4vw;
  }
}
.page-single-works .work_002 .back_list svg {
  position: absolute;
  top: calc(50% - 2px);
  right: 50px;
  width: 150px;
  transition: 0.2s all;
}
@media (width <= 600px) {
  .page-single-works .work_002 .back_list svg {
    right: 5vw;
    width: 18vw;
    height: 2vw;
  }
}
.page-single-works .work_002 .back_list polygon {
  fill: #9e8686;
}
.page-single-works .work_002 .back_list:hover {
  color: #fff;
  background-color: #b59e93;
}
.page-single-works .work_002 .back_list:hover svg {
  right: 40px;
}
.page-single-works .work_002 .back_list:hover polygon {
  fill: #fff;
}

/*お知らせ*/
.page-archive-info .common_header h2 ::after,
.page-single-info .common_header h2 ::after {
  display: block;
  width: 119%;
}
@media (width <= 600px) {
  .page-archive-info .common_header h2 ::after,
  .page-single-info .common_header h2 ::after {
    width: 110%;
  }
}
.page-archive-info .common_header img.building,
.page-single-info .common_header img.building {
  width: 350px;
}
@media (width <= 1024px) {
  .page-archive-info .common_header img.building,
  .page-single-info .common_header img.building {
    right: 7vw;
    bottom: 10vw;
    width: 39vw;
  }
}
@media (width <= 600px) {
  .page-archive-info .common_header img.building,
  .page-single-info .common_header img.building {
    right: 4vw;
    width: 42vw;
  }
}
.page-archive-info .common_header img.people,
.page-single-info .common_header img.people {
  right: calc(50% - 150px);
  bottom: 131px;
  z-index: 5;
  width: 85px;
}
@media (width <= 1024px) {
  .page-archive-info .common_header img.people,
  .page-single-info .common_header img.people {
    right: 45vw;
    bottom: 8vw;
    width: 8vw;
  }
}
@media (width <= 600px) {
  .page-archive-info .common_header img.people,
  .page-single-info .common_header img.people {
    right: 45vw;
    bottom: 10vw;
    width: 10vw;
  }
}

.info_wrapper {
  display: flex;
  gap: 4%;
  width: 85%;
  max-width: 1080px;
  padding: 100px 0 200px;
  margin: 0 auto;
}
@media (width <= 600px) {
  .info_wrapper {
    padding: 15vw 0 25vw;
  }
}

.info_001 {
  width: 80%;
  max-width: 1000px;
  padding: 200px 0;
  margin: 0 auto;
}
@media (width <= 600px) {
  .info_001 {
    padding: 15vw 0 25vw;
  }
}
.info_001 .info_list {
  display: flex;
  flex-flow: column;
}
.info_001 .info_list a {
  display: flex;
  gap: 50px;
  padding: 50px 0;
  border-bottom: 2px dotted #9e8686;
}
@media (width <= 600px) {
  .info_001 .info_list a {
    flex-flow: column;
    gap: 5vw;
    padding: 10vw 0;
  }
}
.info_001 .info_list a:first-child {
  border-top: 2px dotted #9e8686;
}
.info_001 .info_list a .thumbnail_wrapper {
  width: 25%;
  max-width: 300px;
}
@media (width <= 600px) {
  .info_001 .info_list a .thumbnail_wrapper {
    width: 65%;
    margin: 0 auto;
  }
}
.info_001 .info_list a .body {
  display: flex;
  flex-flow: column;
  justify-content: center;
  width: calc(75% - 50px);
}
@media (width <= 600px) {
  .info_001 .info_list a .body {
    width: 100%;
  }
}
.info_001 .info_list a .body h3 {
  margin: 0 0 15px;
  font-size: 20px;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .info_001 .info_list a .body h3 {
    margin: 0;
    font-size: 4.5vw;
  }
}
.info_001 .info_list a .body time {
  margin: 0 0 15px;
  font-size: 16px;
  line-height: 2;
  color: #9e8686;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .info_001 .info_list a .body time {
    margin: 0 0 2vw;
    font-size: 4vw;
  }
}
.info_001 .nav-links {
  margin: 100px 0 0;
}
.info_001 .page-numbers {
  display: flex;
  justify-content: center;
}
.info_001 .page-numbers li span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: 16px;
  background: #efe6e6;
  border-radius: 50%;
}
.info_001 .page-numbers li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: 16px;
}

.page-single-info .info_002 {
  width: 85%;
  max-width: 800px;
  margin: 0 auto;
}
@media (width <= 600px) {
  .page-single-info .info_002 {
    width: 100%;
  }
}
.page-single-info .info_002 h2 {
  margin: 0 0 50px;
  font-size: 28px;
  color: #4d4d4d;
  text-align: center;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .page-single-info .info_002 h2 {
    margin: 0 0 8vw;
    font-size: 4.8vw;
    text-align: left;
  }
}
.page-single-info .info_002 article > img {
  margin: 0 0 50px;
  overflow: hidden;
  border-radius: 20px;
}
@media (width <= 600px) {
  .page-single-info .info_002 article > img {
    display: block;
    width: 85%;
    margin: 0 auto 6vw;
    overflow: hidden;
    border-radius: 5vw;
  }
}
.page-single-info .info_002 time {
  display: block;
  margin: 0 0 15px;
  font-size: 16px;
  line-height: 2;
  color: #9e8686;
  letter-spacing: 0.1em;
}
@media (width <= 600px) {
  .page-single-info .info_002 time {
    margin: 0 0 2vw;
    font-size: 3.8vw;
  }
}
.page-single-info .info_002 .description {
  margin: 0 0 50px;
}
@media (width <= 600px) {
  .page-single-info .info_002 .description {
    margin: 0 0 10vw;
  }
}
.page-single-info .info_002 .description p {
  font-size: 18px;
  line-height: 2.3;
  color: #4d4d4d;
}
@media (width <= 600px) {
  .page-single-info .info_002 .description p {
    font-size: 3.8vw;
  }
}
.page-single-info .info_002 .back_list {
  position: relative;
  width: 100%;
  max-width: 550px;
  padding: 50px 0;
  margin: 0 auto;
  font-size: 20px;
  color: #9e8686;
  text-align: center;
  letter-spacing: 0.1em;
  background-color: #efe6e6;
  transition: 0.5s all;
}
@media (width <= 600px) {
  .page-single-info .info_002 .back_list {
    padding: 8vw;
    font-size: 4vw;
  }
}
.page-single-info .info_002 .back_list svg {
  position: absolute;
  top: calc(50% - 2px);
  right: 50px;
  width: 150px;
  transition: 0.2s all;
}
@media (width <= 600px) {
  .page-single-info .info_002 .back_list svg {
    right: 5vw;
    width: 21vw;
    height: 1vw;
  }
}
.page-single-info .info_002 .back_list polygon {
  fill: #9e8686;
}
.page-single-info .info_002 .back_list:hover {
  color: #fff;
  background-color: #b59e93;
}
.page-single-info .info_002 .back_list:hover svg {
  right: 40px;
}
.page-single-info .info_002 .back_list:hover polygon {
  fill: #fff;
}

@media (width <= 1024px) {
  .wpcf7-spinner {
    position: absolute;
  }
}
/*# sourceMappingURL=style.css.map */