@charset "UTF-8";
body {
  opacity: 0;
  transition: 0.7s;
}

body.on {
  opacity: 1;
  transition: 0.7s;
}
/* headdeco */
.headdeco {
  position: absolute;
  width: 100vw;
  /* width: var(--content-width); */
  left: 0vw;
  top: 0;
  height: 100vh;
  overflow-x: hidden;
  pointer-events: none;
}

.headdeco li:nth-child(1) {
  position: absolute;
  left: -4.5vw;
  top: 37.5vw;
  width: 14.083333vw;
  z-index: -1;
}

.headdeco li:nth-child(2) {
  position: absolute;
  right: -13vw;
  top: 10vw;
  width: 31.375vw;
}

.breadList {
  display: flex;
  font-size: 0.75rem;
  gap: var(--v8-px);
  justify-content: flex-end;
  margin-top: var(--v8-px);
}
p + .breadList {
  margin-top: var(--v24-px);
}
.breadList li {
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 25vw;
  overflow: hidden;
}

.breadList li.active {
  opacity: 0.3;
}

.breadList li:not(.active):after {
  content: ">";
  padding-left: var(--v8-px);
}

/* common parts */
img {
  max-width: 100%;
}
.headBlock {
  width: var(--content-width);
  margin: 0 auto 0;
  position: relative;
  padding-top: var(--v160-px);
}
.headBlock h2 {
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.5;
}
.headBlock h2.mini {
  font-size: 1.5rem;
}
.headBlock p {
  width: 100%;
  margin-top: var(--v8-px);
}
.headBlock h2 span {
  font-size: 0.9rem;
  display: block;
  margin-left: 0.2rem;
}
.headBlock h2 span.jp {
  margin-bottom: 0.5rem;
}
.headBlock figure {
  margin-top: var(--v32-px);
  width: 103vw;
  overflow: hidden;
  height: 41.6666vw;
  margin-left: -8.888889vw;
  display: flex;
  justify-content: center;
}
.headBlock figure img {
  width: 120%;
  height: 120%;
  object-fit: cover;
}
.stBlock {
  width: var(--content-width);
  margin: 0 auto 0;
}
.stBlock2 {
  width: var(--content-width);
  margin: 0 auto 0;
}
.stBlock3 {
  width: var(--content-width);
  margin: 0 auto;
}
.h3ttl {
  font-size: 1.875rem;
  font-weight: 600;
  line-height: 1.5;
  position: relative;
}
.h3ttl span {
  display: block;
  font-size: 1.125rem;
  margin-bottom: 0.15em;
}
.h3ttl.center {
  text-align: center;
}
.h3ttl.center.line {
  margin-bottom: 8.3666666vw;
}
.h3ttl.center.line:after {
  content: "";
  position: absolute;
  width: 6.4vw;
  left: 50%;
  background: var(--dark-color);
  margin-left: -3.2vw;
  bottom: -3.2vw;
  height: 1px;
}
.h3ttl.left.line {
  margin-bottom: var(--v48-px);
}
.h3ttl.left.line:after {
  content: "";
  position: absolute;
  width: 6.4vw;
  left: 0;
  background: var(--dark-color);
  bottom: -3.2vw;
  height: 1px;
}
.h3ttl2 {
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}
.h3ttl3 {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.5;
}
.h4ttl {
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
  position: relative;
  margin-top: var(--v16-px);
  margin-bottom: var(--v8-px);
}

ul.num li {
  list-style: auto;
  margin-left: var(--v20-px);
}

.backBtn {
  background: var(--dark-color);
  color: var(--white-color);
  position: relative;
  display: flex;
  align-items: center;
  width: max-content;
  height: var(--v48-px);
  line-height: var(--v48-px);
  padding: 0 var(--v32-px);
  margin: 0 auto;
  border-radius: 10vw;
  gap: var(--v16-px);
  font-weight: 600;
}
.backBtn:before {
  content: "";
  background: url("/img/common/arrow_white.svg") no-repeat;
  transform: rotate(180deg);
  /* width: 0.65vw; */
  /* height: 0.56vw; */
  background-size: cover;
  width: 3.2666vw;
  height: 3vw;
}
.btnGhost {
  position: relative;
  display: flex;
  align-items: center;
  width: max-content;
  height: var(--v48-px);
  line-height: var(--v48-px);
  padding: 0 var(--v32-px);
  margin: 0 auto;
  border: 1px solid var(--dark-color);
  border-radius: 10vw;
  gap: var(--v16-px);
  font-weight: 500;
}
.btnGhost:after {
  content: "";
  background: url("/img/common/arrow_dark.svg") no-repeat;
  /* width: 0.65vw; */
  /* height: 0.56vw; */
  background-size: cover;
  width: 3.2666vw;
  height: 3vw;
}

/* about */
.about .area2 {
  margin-top: var(--v64-px);
  margin-bottom: var(--v64-px);
  position: relative;
}
.about .area2:before {
  content: "";
  position: absolute;
  right: -7.5333vw;
  top: 21vw;
  width: 91.33333333vw;
  height: 74.863611vw;
  background: #ededf3;
  border-radius: var(--v8-px) 0 0 var(--v8-px);
}

.about .area2 ul {
  position: relative;
  margin-left: 8.68vw;
}
.about .area2 ul li {
  width: 30.8888vw;
  position: absolute;
  top: 4.44444vw;
}
.about .area2 ul li:nth-child(1) {
  left: -10vw;
  transform: rotate(-5deg);
}
.about .area2 ul li:nth-child(2) {
  left: 19.44444vw;
  transform: rotate(5deg);
  top: 10vw;
}
.about .area2 ul li:nth-child(3) {
  left: 49.88888vw;
  transform: rotate(-5deg);
}
.about .area2 p {
  margin-top: var(--v224-px);
  /* margin-left: 44.4444vw; */
  position: relative;
}
.about .area3 {
  background: var(--dark-color);
}
.about .area3 .inner {
  width: var(--content-width);
  margin: 0 auto;
  padding: 15.22222vw 0;
  color: var(--white-color);
  position: relative;
  backdrop-filter: blur(4px);
}
.about .area3 .inner > p {
  text-align: center;
  font-size: 1.25rem;
  font-weight: 600;
  margin-top: var(--v24-px);
  line-height: 1.65;
}
.about .area3 .inner h3 {
  font-size: 1.875rem;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
}
.about .area3 .form {
  position: relative;
  width: 100%;
  margin-top: var(--v16-px);
}
.about .area3 input.inputForm {
  height: 2.5em;
  width: var(--content-width);
  border-radius: var(--v8-px);
  font-size: 1.25rem;
}
.about .area3 button {
  background: var(--dark-color);
  color: var(--white-color);
  position: absolute;
  right: 0.6666vw;
  top: 0.5vw;
  height: 2.85em;
  border-radius: var(--v8-px);
  padding: 0 var(--v8-px);
  font-weight: 600;
}
.about .area4 h2 {
  font-size: 1.85rem;
  line-height: 1.4;
  font-weight: 600;
}
.about .area4 h2 p {
  margin-top: 0.25rem;
  text-indent: -0.75rem;
}
.about .area4 h2 p span {
  font-weight: 300;
}
.about .area4 h2 p small {
  font-size: 2.5rem;
}
.about .area4 h2 span.sub {
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  position: relative;
}
.about .area4 h2 span.sub:after {
  content: "";
  position: absolute;
  left: calc(var(--content-space2half) - 0.5vw);
  top: 0.7em;
  background: var(--dark-color);
  width: calc(var(--content-spacehalf) + 1vw);
  height: 1px;
  margin-left: -1.5vw;
}
.about .area4 figure {
  text-align: center;
  margin-top: 7.6vw;
}
.about .area4 figure img {
  width: 100%;
}
.about .area4 .pointList {
  display: flex;
  flex-wrap: wrap;
  gap: var(--v24-px) 0;
  margin-top: var(--v32-px);
  /* justify-content: space-between; */
}
.about .area4 .pointList > div {
  width: 23.7vw;
  min-width: 300px;
}
@media screen and (max-width: 1280px) {
  .about .area4 .pointList > div {
    width: 100%;
  }
}
.about .area4 .inner h3 span {
  width: 2vw;
  display: block;
  background: transparent;
  min-width: var(--v16-px);
}
.about .area4 h3 img,
.area3 h3 span small {
  height: 1.25rem;
  /*    margin-top: 0.35rem;*/
  margin-right: 0.2rem;
  filter: drop-shadow(0 0 12px rgba(81, 57, 164, 0));
  animation: rotatenum 4s infinite;
  transform-origin: left bottom 0;
}
.about .area4 h3 p {
  width: 100%;
  /* min-width: 250px; */
}
.about .area4 .pointList > div:nth-child(2) h3 img,
.about .area4 .pointList > div:nth-child(2) h3 small {
  animation-delay: 0.1s;
}
.about .area4 .pointList > div:nth-child(3) h3 img,
.about .area4 .pointList > div:nth-child(3) h3 small {
  animation-delay: 0.2s;
}
.about .area4 .pointList > div:nth-child(4) h3 img,
.about .area4 .pointList > div:nth-child(4) h3 small {
  animation-delay: 0.05s;
}
.about .area4 .pointList > div:nth-child(5) h3 img,
.about .area4 .pointList > div:nth-child(5) h3 small {
  animation-delay: 0.15s;
}
.about .area4 .pointList > div:nth-child(6) h3 img,
.about .area4 .pointList > div:nth-child(6) h3 small {
  animation-delay: 0.25s;
}
.about .area4 h3 img {
  margin-top: 0.35rem;
}
.about .area4 h3 img.key3 {
  position: absolute;
  left: -0.5vw;
  top: 0;
  opacity: 0;
  transition: 0.5s;
  transform: scale(1);
  filter: drop-shadow(0 0 12px rgba(81, 57, 164, 1));
}
.about .area4 h3 img.key3before {
  transform: rotateY(0deg);
}
.about .area4 h3 img.key3before.scaleUp {
  transform-origin: left bottom 0;
  display: inline-block;
  animation: key3scaleup 2s forwards;
}
.about .area4 h3 img.key3.end {
  opacity: 1;
  animation: end 2s infinite;
  transition: 0.5s;
  transform: scale(1);
  cursor: pointer;
}
.about .area4 h3 img:nth-child(1).end {
  opacity: 0;
  transition: 0.4s;
}
.about .area4 h3 img.key3.end svg {
  fill: #f5f5fa;
}
.about .area4 h3 {
  font-size: 1.25rem;
  font-weight: 600;
  display: flex;
  line-height: 1.4;
  /* height: 4.0rem; */
  gap: 4px;
  position: relative;
  -webkit-user-select: none; /* Chrome or Safari */
  -moz-user-select: none; /* FireFox */
  -ms-user-select: none; /* IE */
  -o-user-select: none; /* Opera */
  user-select: none;
}
.about .area4 .pointList > div > p {
  margin-top: 1.1111vw;
}
.about .area5 h2 {
  font-size: 1.85rem;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 2.77777vw;
}
.about .area5 h2 span {
  font-size: 1.25rem;
  font-weight: 600;
  display: block;
  margin-bottom: 0.35rem;
}
.about .area5 dl {
  /* display: flex; */
  justify-content: space-between;
  align-items: center;
  margin-top: var(--v32-px);
  margin-left: var(--v40-px);
}
.about .area5 dl.reverse {
  flex-direction: row-reverse;
  margin-left: 0;
}
.about .area5 dl dt {
  width: var(--v280-px);
}
.about .area5 dl dt img {
  border-radius: var(--v8-px);
  width: 100%;
}
.about .area5 dl dd {
  width: var(--v280-px);
}
.about .area5 dl dd h3 {
  font-size: 2.5rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.3;
  margin-top: var(--v16-px);
}
.about .area5 dl dd h3 span {
  display: block;
  font-size: 1rem;
}
.about .area5 dl dd p {
  margin-top: var(--v16-px);
  width: 100%;
}
.about .area5 dl.reverse dd p,
.about .area5 dl.reverse dd h3 {
  /* margin-left: 25%; */
}
.about .area5 .linkBlock {
  /*    background: var(--white-color);*/
  background: #fff;
  width: 100vw;
  margin: var(--v32-px) auto 0;
  /* border-radius: 1.11111vw; */
  padding: var(--v32-px) 0 var(--v32-px);
  /* display: flex; */
  justify-content: center;
  /* align-items: center; */
  display: flex;
  flex-wrap: wrap;
  margin-left: -6vw;
}
.about .area5 .linkBlock a {
  /* background: var(--dark-color); */
  /* color: var(--white-color); */
  /* height: 5vw; */
  /* width: 27.43vw; */
  /* border-radius: 10vw; */
  /* display: flex; */
  /* justify-content: center; */
  /* align-items: center; */
  /* font-size: 1.125rem; */
  /* font-weight: 500; */
  background: var(--dark-color);
  color: var(--white-color);
  height: 12.8vw;
  width: var(--content-width);
  border-radius: 10vw;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1rem;
  margin-top: 6.4vw;
  font-weight: 600;
}
.about .area4,
.about .area5 {
  margin-top: var(--v64-px);
}

.about .footTop {
  margin-top: 0;
}
/* service */
.service .serviceBlock {
  margin-top: var(--v24-px);
  cursor: pointer;
}
.service .serviceBlock:hover {
}
.service .serviceBlock:nth-of-type(1) {
  margin-top: var(--v32-px);
}
.service .serviceBlock {
  display: flex;
  position: relative;
  /* align-items: stretch; */
  flex-wrap: wrap;
  width: 100vw;
}
.service .serviceBlock .left {
  width: 100vw;
  overflow: hidden;
}
.service .serviceBlock .left figure {
  height: 100%;
  height: var(--v200-px);
}

.service .serviceBlock .left img {
  transform: scale(1);
  transition: 0.4s;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.service .serviceBlock.num2 .left img {
  height: auto;
  object-fit: contain;
  margin-top: -4vw;
}
.service .serviceBlock.num5 .left img {
  height: auto;
  object-fit: contain;
  margin-top: 0vw;
}
.service .serviceBlock:hover .left img {
  transform: scale(1.05);
  transition: 0.4s;
}
.service .serviceBlock .right {
  width: 100vw;
  background: var(--white-color2);
  padding: var(--v32-px) var(--v32-px) var(--v80-px);
  margin: 0 auto;
}
.service .serviceBlock .right .tag {
  display: flex;
  font-size: 0.8rem;
  gap: var(--v4-px);
  margin-left: -0.2rem;
}
.service .serviceBlock .right .tag li {
  background: var(--base-color);
  color: var(--dark-color);
  font-weight: 500;
  padding: var(--v8-px) var(--v16-px);
  line-height: 1;
  border-radius: 5vw;
}
.service .serviceBlock .right h3 {
  font-size: 3rem;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: var(--v16-px);
}
.service .serviceBlock .right h3 span {
  display: block;
  font-size: 1rem;
}
.service .serviceBlock .right .point {
  background: var(--base-color);
  border-radius: var(--border-rad);
  padding: var(--v24-px);
  font-size: 0.9rem;
  margin-top: var(--v16-px);
}
.service .serviceBlock .right .point strong {
  font-weight: 600;
}

.service .serviceBlock .right .point li {
  display: flex;
  gap: var(--v8-px);
}

.service .serviceBlock .right .point li:not(:last-child):before {
  content: "";
  width: var(--v4-px);
  height: var(--v4-px);
  border-radius: 50%;
  background: var(--dark-color);
  margin-top: 0.8em;
}

.service .serviceBlock:hover .linkBtn {
  transform: scale(1.1);
  transition: 0.4s;
}
.service .serviceBlock .linkBtn {
  position: absolute;
  right: 9vw;
  bottom: 6.6666vw;
  width: 12vw;
  height: 12vw;
  background: var(--dark-color);
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  transition: 0.4s;
}
.service .serviceBlock .linkBtn img {
  width: 2.4vw;
}
/* serviceDetail */
.serviceDetail .area3 {
  padding: var(--v32-px) 0;
}
.serviceDetail .area3 dl {
  /* display: flex; */
  gap: 4.44444vw;
  justify-content: center;
}
.serviceDetail .area3 dl dt {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: var(--v8-px);
}
.serviceDetail .area3 li {
  position: relative;
  display: flex;
  margin-bottom: 0.25em;
}
.serviceDetail .area3 li:before {
  content: "";
  margin-top: 1.9vw;
  margin-right: 2vw;
  background: url("/img/servicedetail/checkicon.svg") no-repeat;
  width: 2.79vw;
  height: 2.025vw;
  background-size: cover;
}
.serviceDetail .area4 {
  background: var(--dark-color);
  color: var(--white-color);
  padding: var(--v64-px) 0;
}
.serviceDetail .area4 .serviceList {
  display: flex;
  flex-wrap: wrap;
  gap: var(--v32-px);
  margin-top: var(--v48-px);
}
.serviceDetail .area4 .servBlock {
  display: flex;
  gap: var(--v16-px);
  align-items: flex-start;
}
.serviceDetail .area4 .h3ttl.center.line:after {
  background: var(--white-color);
}
.serviceDetail .area4 .servBlock dt {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.5;
}
.serviceDetail .area4 .servBlock dd {
  /* font-size: 0.9375rem; */
}
.serviceDetail .area4 figure {
  width: 30vw;
}
.serviceDetail .area4 .servBlock dl {
  width: 53vw;
}
.serviceDetail .area4 .inner > p {
  font-size: 1rem;
  text-align: center;
  font-weight: 600;
  margin-top: var(--v32-px);
  line-height: 1.65;
}
.serviceDetail .area5 {
  margin-top: var(--content-space);
}
.serviceDetail .pointBlock {
  /* display: flex; */
  align-items: center;
  gap: 3.3333vw;
}
.serviceDetail .pointBlock:not(:last-child) {
  margin-bottom: var(--v48-px);
}
.serviceDetail .pointBlock figure {
  width: 100%;
}
.serviceDetail .pointBlock dl {
  width: 100%;
}
.serviceDetail .pointBlock dl dt {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.5;
  margin-top: var(--v16-px);
  margin-bottom: var(--v4-px);
}
.serviceDetail .area6 {
  /*    background: var(--dark-color);*/
  width: 100vw;
  padding-top: var(--content-space);
}
.serviceDetail .area6 .inner {
  width: 68.19vw;
  margin: 0 auto;
  /*    padding: calc(var(--content-space) / 2) 0;*/
  position: relative;
}
.serviceDetail .area6 .inner .work {
  display: flex;
  width: 100%;
  /* gap: 6.1111vw; */
  /* align-items: center; */
  position: relative;
  margin-top: var(--v48-px);
  /* height: 45vw; */
}
.serviceDetail .area6 .inner .workInner figure {
  position: relative;
  transition: 1.2s;
}
.serviceDetail .area6 .inner .workInner2 figure:after {
  content: "";
  position: absolute;
  width: 4vw;
  height: 5vw;
  border-radius: 4vw;
  left: 0;
  top: 45%;
  margin-top: -1.9444vw;
  background: #302c3d;
  opacity: 0.65;
  transition: 0.5s;
}
.serviceDetail .area6 .inner .workInner2 figure.last:after {
  opacity: 0;
  transition: 0.5s;
}
.serviceDetail .area6 .inner .workInner2 figure.scaleUp:after {
  background: var(--white-color);
  opacity: 1;
  transition: var(--hold-time);
}
.serviceDetail .area6 .inner .workInner2 figure.end:after {
  background: var(--white-color);
  opacity: 1;
}
.serviceDetail .area6 .inner .workInner2 figure img {
  width: 100%;
  height: 100%;
  border-radius: 4vw;
  object-fit: cover;
}
.serviceDetail .area6 .inner .workInner {
  /* display: flex; */
  gap: 5vw;
  align-items: center;
}
.serviceDetail .area6 h2 {
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.4;
  /*    margin-bottom: 2.77777vw;*/
  text-align: center;
  padding-top: 10vw;
  margin-bottom: 5.5555vw;
}
.serviceDetail .area6 h2 span {
  font-size: 1.25rem;
  font-weight: 500;
  display: block;
  letter-spacing: 0.02em;
  margin-bottom: 0.5rem;
}
.serviceDetail .area6 .work .workInner.active figure {
  /* width: 25.72222vw; */
  /* height: 38.541vw; */
  transform: scale(1) rotate(-5deg);
  opacity: 1;
  margin-top: 0;
  width: 100%;
  height: 87.8vw;
}
.serviceDetail .area6 .work .workInner figure,
.serviceDetail .area6 .work .workInner2 figure {
  border-radius: var(--v8-px);
  overflow: hidden;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  transition: 0.6s;
}
.serviceDetail .area6 .work .workInner2 figure {
  width: 4vw;
  height: 4vw;
  border-radius: 32vw;
  overflow: hidden;
  margin-left: 4vw;
  position: relative;
  transition: 0.4s;
  transform: scale(1);
  opacity: 1;
}
.serviceDetail .area6 .work .workInner2.change figure {
  transform: scale(0.5);
  opacity: 0;
  transition: 0.4s;
}
.serviceDetail .area6 .work .workInner.active.change figure {
  transform: scale(0.9) rotate(0deg);
  margin-top: 5.1111vw;
  opacity: 0;
  transition: 0.4s;
}
.serviceDetail .area6 .work .workInner2 figure.end {
  animation: end2 2s infinite;
  filter: drop-shadow(0 0 4px rgba(106, 214, 47, 0.8));
}
.serviceDetail .area6 .work .workInner figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.serviceDetail .area6 .inner .workInner > div {
  width: 35.41vw;
  opacity: 0;
  transition: 0.4s;
}
.serviceDetail .area6 .inner .workInner.active > div {
  width: 100%;
  transform: scale(1);
  opacity: 1;
  transition: 0.6s;
  margin-top: var(--v24-px);
}
.serviceDetail .area6 .work .workInner.active.change > div {
  opacity: 0;
  margin-top: 3.2vw;
  transition: 0.4s;
}
.serviceDetail .area6 .work > .workInner > div span {
  font-size: 1rem;
  opacity: 0.5;
}
.serviceDetail .area6 .workInner > div strong {
  font-size: 1.25rem;
  font-weight: 600;
  display: block;
  line-height: 1.65;
}
.serviceDetail .area6 .workInner > div > p {
  margin-top: 1.33333vw;
}
.serviceDetail .area6 .workInner > div > a {
  color: var(--color-white);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  line-height: 1;
  letter-spacing: 0.02em;
  margin-top: 1.5rem;
  position: relative;
}
.serviceDetail .area6 .workInner > div > a span:nth-child(1) {
  opacity: 1;
  transition: 0.4s;
}
.serviceDetail .area6 .workInner > div > a span:nth-child(2) {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.4s;
}
.serviceDetail .area6 .workInner > div > a.last span:nth-child(1) {
  opacity: 0;
  transition: 0.4s;
}
.serviceDetail .area6 .workInner > div > a.last span:nth-child(2) {
  position: absolute;
  left: 12px;
  top: 0;
  opacity: 1;
  transition: 0.4s;
}
.serviceDetail .area6 .workInner > div > a:before {
  content: "";
  background: var(--white-color);
  width: 0.555vw;
  height: 0.555vw;
  border-radius: 2vw;
  transition: 0.2s;
}
.serviceDetail .area6 .workInner > div > a:hover:before {
  transform: scale(1.35);
  transition: 0.2s;
}
.serviceDetail .area6 .workInner.active > div > a img {
  width: 0.5555vw;
}
.serviceDetail .area6 p.nextBtn {
  position: absolute;
  left: 74.7vw;
  top: 50%;
  z-index: 20;
  margin-top: -1.66666vw;
  height: 3.3333vw;
  transform: scale(1);
  transition: 0.4s;
  cursor: pointer;
}
.serviceDetail .area6 p.nextBtn:hover {
  transform: scale(1.1);
  transition: 0.4s;
}
.serviceDetail .area6 p.nextBtn img {
  height: 100%;
}
.serviceDetail .area6 p.nextBtn.end {
  animation: end2 2s infinite;
  filter: drop-shadow(0 0 4px rgba(106, 214, 47, 0.8));
}
.serviceDetail .area6 p.backBtn {
  position: absolute;
  left: -11.7vw;
  top: 50%;
  z-index: 20;
  margin-top: -1.66666vw;
  height: 3.3333vw;
  transform: scale(1) rotate(-180deg);
  transition: 0.4s;
  cursor: pointer;
}
.serviceDetail .area6 p.backBtn:hover {
  transform: scale(1.1) rotate(-180deg);
  transition: 0.4s;
}
.serviceDetail .area6 p.backBtn img {
  height: 100%;
}
.points .strongBlock {
  /* display: flex; */
  gap: var(--v56-px);
  align-items: center;
  margin-top: var(--v48-px);
}
.points .strongBlock figcaption {
  font-size: 0.6rem;
  text-align: center;
  opacity: 0.5;
  margin-top: 1em;
}
.points .strongBlock dl dd a {
  text-decoration: underline !important;
  text-underline-offset: var(--v4-px);
}
.points .strongBlock dl dd a:hover {
  text-decoration: none !important;
}
.points .strongBlock.right {
  flex-direction: row-reverse;
}
.points .strongBlock figure {
  width: 92.8vw;
}
.points .strongBlock figure img {
  border-radius: 0 var(--v8-px) var(--v8-px) 0;
  overflow: hidden;
}
.points .strongBlock.right figure {
  margin-left: var(--content-sidespace);
}
.points .strongBlock.right figure img {
  border-radius: var(--v8-px) 0 0 var(--v8-px);
  overflow: hidden;
}
.points .strongBlock dl {
  width: var(--content-width);
  margin-left: var(--content-sidespace);
  margin-top: var(--v16-px);
}
.points .strongBlock dl dt {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.5;
}
.company .area2 {
  display: flex;
  flex-wrap: wrap;
  margin-top: var(--v64-px);
  gap: var(--v24-px);
}
.company .area2 dl {
  width: 100%;
  display: flex;
  font-size: 1.125rem;
  padding-top: var(--v24-px);
  padding-bottom: var(--v24-px);
  border-bottom: 1px solid rgba(51, 50, 56, 0.2);
  gap: var(--v16-px);
}
.company .area2 dl dt {
  width: var(--v80-px);
  font-weight: 600;
}
.company .area2 dl dd {
  width: 60vw;
}
.company .area2 dl.wide {
  width: 100%;
}
.company .area2 dl.wide dd {
  width: 60vw;
}

.company .area2 dl.wide dd li {
  display: flex;
  gap: var(--v8-px);
}
.company .area2 dl.wide dd li:before {
  content: "";
  width: var(--v4-px);
  height: var(--v4-px);
  border-radius: 50%;
  background: var(--dark-color);
  margin-top: 0.8em;
}

.company .area2 dl.wide dd li span {
  display: block;
  width: 56vw;
}
.works .area1 .link,
.plan .area1 .link,
.recruit .area1 .link {
  display: flex;
  gap: var(--v8-px);
  margin-top: var(--v20-px);
  flex-wrap: wrap;
}
.works .area1 .link li,
.plan .area1 .link li,
.recruit .area1 .link li {
  height: var(--v40-px);
  line-height: var(--v40-px);
  padding: 0 var(--v16-px);
  border: 1px solid var(--dark-color);
  border-radius: var(--v24-px);
}
.recruit .area1 .link li a {
  font-size: 0.9em;
}
.works .area1 .link li.active {
  background: var(--dark-color);
  color: var(--white-color);
  font-weight: 600;
}
.works .area1 .link li.active a {
  color: var(--white-color);
}
.works .area2 {
  display: flex;
  flex-wrap: wrap;
  gap: var(--v24-px);
  margin-top: var(--v48-px);
}
.works .area2 .workBlock {
  width: 100%;
  display: block;
}
.works .area2 .workBlock figure {
  width: 100%;
  border-radius: var(--v8-px);
  overflow: hidden;
  height: 51.44444vw;
  display: flex;
  align-items: center;
}
.works .area2 .workBlock .tag {
  display: flex;
  color: var(--light-color);
  font-size: 0.875rem;
  gap: var(--v8-px);
  margin-top: var(--v8-px);
}
.works .area2 .workBlock .tag li:before {
  content: "#";
}
.works .voiceBlock {
  display: flex;
  gap: var(--v16-px);
  align-items: center;
  flex-wrap: wrap;
}
.works .voiceBlock figure {
  width: 100%;
  border-radius: var(--v8-px);
  overflow: hidden;
}
.works .voiceBlock .right {
  width: 100%;
}
.works .voiceBlock .right p.txt {
  margin-top: var(--v4-px);
}
.works .voiceBlock .h3ttl3 {
  font-size: 1.125rem;
}
.workDetail .tag {
  display: flex;
  gap: var(--v8-px);
}
.workDetail .tag li {
  background: var(--white-color2);
  border-radius: 5vw;
  padding: var(--v4-px) var(--v8-px);
  font-size: 0.75rem;
}
.workDetail h2 {
  margin-top: var(--v16-px);
}
.workDetail .area1 p {
  margin-top: 0;
}
.workDetail .area2 figure {
  width: 100%;
  border-radius: var(--v8-px);
  overflow: hidden;
  margin-top: var(--v32-px);
}
.workDetail .area2 figure img {
  width: 100%;
}
.workDetail .area2 p {
  padding: var(--v32-px) 0;
}
.workDetail .summary,
.workDetail #toc_container {
  background: var(--dark-color);
  color: var(--white-color);
  width: 92.8vw;
  border-radius: 0 var(--v8-px) var(--v8-px) 0;
}
.workDetail #toc_container {
  width: 93.33333vw;
  margin-left: var(--content-r_sidespace);
}
.workDetail .summary dl,
.workDetail #toc_container {
  display: flex;
  flex-wrap: wrap;
  padding: var(--v48-px) var(--content-sidespace);
  gap: var(--v8-px);
  font-size: 0.9375rem;
  width: 93.33333vw;
}
.workDetail #toc_container li {
  text-indent: -1em;
  margin-left: 1em;
}
.workDetail #toc_container a {
  color: var(--white-color);
}

.workDetail #toc_container .toc_title {
  width: var(--v96-px);
  font-size: 1.125rem;
  font-weight: 600;
  text-align: left;
}

.workDetail .summary dl dt {
  width: var(--v144-px);
  font-weight: 600;
}

.workDetail .toc_list > li {
  list-style: auto;
  margin-left: var(--v12-px);
  margin-bottom: 0.5em;
}
.workDetail .summary dl dd {
  width: 100%;
  margin-bottom: var(--v16-px);
  margin-left: var(--v12-px);
}
.workDetail .summary dl dd:last-child {
  margin-bottom: 0;
  margin-left: 0;
}
.workDetail .summary dl dd li {
  list-style: disc;
  margin-bottom: 0.25em;
}

.wpcontent {
  margin-top: var(--v64-px);
}

.wpcontent h3,
h3.h3ttl4 {
  font-size: 1.5rem;
  position: relative;
  padding-left: var(--v12-px);
  font-weight: 600;
  line-height: 1.5;
  margin-top: var(--v48-px);
}

.wpcontent .voiceLink {
  height: 51.2vw;
  overflow: hidden;
  display: flex;
  align-items: center;
}

.wpcontent h3:before,
h3.h3ttl4:before {
  position: absolute;
  content: "";
  width: var(--v3-px);
  left: 0;
  top: 0;
  height: 100%;
  background: var(--dark-color);
}

.wpcontent figure {
  max-width: 100%;
  width: max-content;
  border-radius: var(--v8-px);
  overflow: hidden;
}
.wpcontent figure video {
  border-radius: var(--v8-px);
}
.wpcontent > * {
  margin-top: var(--v16-px);
}

.wpcontent h4 {
  margin-top: var(--v32-px);
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.5;
}
.wpcontent h5 {
  margin-top: var(--v24-px);
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}
.wpcontent h6 {
  margin-top: var(--v24-px);
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}

.wpcontent .btnGhost {
  margin-left: 0;
  margin-right: 0;
}

.wpcontent .question {
  font-weight: 600;
}

.wpcontent p + p {
  margin-top: var(--v24-px);
}

.workDetail .area5 {
  margin-top: var(--v48-px);
}

.flow .area2 {
  margin-top: var(--v64-px);
  width: 100vw;
}

.flow .area2 figure {
  border-radius: var(--v8-px);
  overflow: hidden;
  width: 100%;
}

.flow .area3 {
  display: flex;
  margin-top: var(--v48-px);
}

.flow .area3 .left {
  width: 24vw;
  font-size: 0.75rem;
  line-height: 2.5;
}

.flow .area3 .right {
  width: 100%;
  margin-top: var(--v8-px);
}

.flow .area3 .right h3:not(:first-child) {
  margin-top: var(--v48-px);
}

.flow .area3 .right h3 {
  margin-bottom: var(--v4-px);
}

.plan .area2,
.plan .area3 {
  margin-top: var(--v64-px);
}

.plan .area2 .h3ttl,
.plan .area3 .h3ttl {
  margin-bottom: var(--v48-px);
}

.plan .area1 .link li,
.recruit .area1 .link li {
  display: flex;
  align-items: center;
  gap: var(--v8-px);
}
.plan .area1 .link li:after,
.recruit .area1 .link li:after {
  content: "";
  background: url("/img/common/arrow_dark.svg") no-repeat;
  background-size: cover;
  /* width: 0.65vw; */
  /* height: 0.56vw; */
  display: block;
  transform: rotate(90deg);
  width: 2.45vw;
  height: 2.25vw;
}

.plan thead {
  background: #ededf3;
}

.plan .tablewrap {
  width: 92.8vw;
  overflow-x: scroll;
}

.plan table {
  width: max-content;
  text-align: center;
}

.plan table thead {
  height: var(--v88-px);
  line-height: var(--v88-px);
  font-weight: 600;
}

.plan tr {
  border-bottom: 1px solid var(--line-color);
}

.plan tbody th {
  background: #e8e8ed;
  font-weight: 600;
  height: var(--v88-px);
  vertical-align: middle;
}
.plan tbody th,
.plan tbody td {
  width: 25%;
}

.plan tbody td {
  vertical-align: middle;
}

.plan tbody th span,
.plan tbody td span {
  display: block;
  font-size: 0.8125rem;
}
.plan .area2 small,
.plan .area3 small {
  font-size: 0.8125rem;
  display: block;
  margin-top: var(--v8-px);
  text-indent: -1em;
  margin-left: 1em;
}

.plan .area2 h4,
.plan .area3 h4 {
  font-size: 1.5rem;
  font-weight: 600;
  margin-top: var(--v64-px);
}

.plan .table1 th,
.plan .table1 td {
  padding: 0 var(--v8-px);
}

.plan .table2 {
  border-top: 1px solid var(--line-color);
  margin-top: var(--v16-px);
  width: 100%;
}

.plan .table2 th,
.plan .table2 td {
  display: block;
  width: 100%;
}

.plan .table2 th {
  padding: var(--v24-px);
  text-align: left;
  font-size: 1rem;
  height: auto;
}
.plan .table2 th li {
  font-weight: 400;
  font-size: 0.9rem; /* width: 56vw; */
  text-indent: -0.75em;
  margin-left: 1em;
}

.plan .table2 td {
  font-size: 1.25rem;
  font-weight: 600;
  padding: var(--v16-px) 0;
}

.faq .area2 {
  margin-top: var(--v64-px);
}

.faq .area2 dl {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #d4d4d9;
}

.faq .area2 dl dt {
  /* border-bottom : 1px solid #D4D4D9; */
  padding: var(--v24-px) 0 0;
}
.faq .area2 dl dd {
  border-bottom: 1px solid #d4d4d9;
  padding: var(--v4-px) 0 var(--v24-px);
}

.faq .area2 dl dt {
  width: 100%;
  padding-left: var(--v24-px);
  position: relative;
  font-weight: 600;
  /* padding-right: var(--v56-px); */
}
.faq .area2 dl dt:before {
  content: "Q.";
  position: absolute;
  left: 0;
  top: var(--v24-px);
}
.faq .area2 dl dd {
  width: 100%;
  padding-left: var(--v24-px);
  position: relative;
}
.faq .area2 dl dd:before {
  content: "A.";
  position: absolute;
  left: 0;
  top: var(--v4-px);
}
.recruit .breadList {
  margin-top: var(--v24-px);
}

.recruit .area2,
.recruit .area3 {
  margin-top: var(--v64-px);
}

.recruit .area2 h3 {
  font-size: 1.25rem;
  font-weight: 600;
}

.recruit .area2 p {
  margin-top: var(--v4-px);
}
.about .backimage {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  backdrop-filter: blur(7px);
}
.about .backimage:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #2d2c33;
  opacity: 0.92;
  backdrop-filter: blur(100px);
}

.about .backimage img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.recruit .area3 .inner {
  /* display: flex; */
  justify-content: space-between;
}

.recruit .area3 .inner > * {
  width: 100%;
}

.about .area3 .mysteryimg {
  margin-top: var(--v24-px);
  width: 100.5vw;
  margin-left: var(--content-r_sidespace);
  position: relative;
}

.about .area3 .mysteryimg .playbtn {
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--v104-px);
  margin-top: var(--r52-px);
  margin-left: var(--r52-px);
  z-index: 1;
  border-radius: 50%;
  overflow: hidden;
}

.about .area3 .mysteryimg figure {
  width: 100vw;
  height: 14.583333vw;
  overflow: hidden;
}

.about .area3 .mysteryimg:after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 100vw;
  height: 100%;
  background: var(--dark-color);
  opacity: 0.75;
}

.about .area3 p.playbtn:hover {
  transform: scale(1.02);
  transition: 0.4s;
}

.about .area3 p.playbtn:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: var(--white-color);
  opacity: 0.05;
  border-radius: 50%;
}

.about .area3 p.playbtn img {
  width: 100%;
}

.recruit .area3 .inner .right {
  margin-top: var(--v24-px);
}
.recruit .area3 .inner .right > div:nth-child(2) {
  margin-top: var(--v24-px);
}

.recruit .area3 h3 {
  margin-bottom: 0 !important;
}
.recruit .area3 .inner {
  margin-top: var(--v24-px);
}

.recruit .area3 .inner h4 {
  font-weight: 600;
  font-size: 1.125rem;
}

.recruit .area3 .inner .right li {
  list-style: disc;
  margin-left: var(--v16-px);
}

.recruit .area3 .inner .right .outline li {
  list-style: none;
  margin-left: 0;
}
.recruit .area3 .inner .right .outline li dt {
  font-weight: 600;
  margin-top: var(--v8-px);
}

.recruit .area3 .inner .right h4:not(:first-child) {
  margin-top: var(--v16-px);
}

.recruit .recruitBlock {
  margin-top: var(--v64-px);
}

.news .area2 {
  margin-top: var(--v64-px);
}

.news .area2 a {
  display: flex;
  border-top: 1px solid #d4d4d9;
  border-bottom: 1px solid #d4d4d9;
  width: 100%;
  padding: var(--v24-px) 0;
  /* gap: var(--v4-px); */
  flex-wrap: wrap;
}

.news .area2 a p.time {
  width: 100%;
  font-weight: 600;
}

.news .area2 a p.txt {
  width: 100%;
}

.newsDetail .backBtn {
  margin-left: 0;
  margin-top: var(--v48-px);
}

.newsDetail .area2 {
  margin-top: var(--v8-px);
}
.newsDetail h2 {
  margin-bottom: var(--v4-px);
}

.newsDetail .area2 p {
  margin-top: 0;
}

.policy h2 span {
  margin-left: 0.32rem;
}

.policy h3 {
  margin-top: var(--v32-px);
  margin-bottom: var(--v4-px);
}

.policy .area2 {
  margin-top: var(--v24-px);
}

.policy .area3 {
  margin-top: var(--v96-px);
}

.contact .area2 {
  margin-top: var(--v64-px);
}

.contact .area2 select,
.contact .area2 input {
  height: var(--v64-px);
  line-height: var(--v64-px);
  width: 100%;
  padding: 0 var(--v16-px);
  margin-top: var(--v8-px);
  background: var(--white-color2);
  border-radius: var(--v8-px);
  color: var(--dark-color);
}
.contact .area2 textarea {
  width: 100%;
  margin-top: var(--v8-px);
  padding: var(--v16-px);
  background: var(--white-color2);
  border-radius: var(--v8-px);
  font-size: 0.9rem;
}

.contact .area2 div.select {
  position: relative;
}

.contact .area2 .select:after {
  content: "";
  position: absolute;
  right: var(--v20-px);
  top: var(--v32-px);
  background: url(/img/contact/under_arrow.svg) no-repeat;
  width: 3.125vw;
  height: 3.9375vw;
  background-size: contain;
}

.contact .area2 strong {
  display: block;
  margin-top: var(--v32-px);
}
.contact .area2 strong + br,
.contact .area2 span + br {
  display: none;
}
.contact .area2 input[type="checkbox"] {
  width: var(--v24-px);
  height: var(--v24-px);
  background: var(--white-color2);
  padding: 0;
  margin-top: 0;
  border: 2px solid #e8e9ed;
}

.contact .area2 input[type="checkbox"]:checked {
  background: url("/img/contact/check.svg") no-repeat var(--dark-color);
  background-size: 2.37777vw 3.3333vw;
  background-position: center;
  font-size: 0.9rem;
}
.contact .wpcf7-list-item {
  margin-left: 0;
}

.contact div.check label {
  display: flex;
  align-items: center;
  gap: var(--v8-px);
  margin-top: var(--v32-px);
  cursor: pointer;
  opacity: 1;
  transition: 0.4s;
}

.contact button {
  margin-top: var(--v32-px);
}

.contact .wpcf7-not-valid-tip {
  font-size: 0.75rem;
  margin-top: 0.25em;
  color: #69429d;
}

.contact .check a {
  text-decoration: underline !important;
  transition: 0.4s;
  text-underline-offset: var(--v8-px);
}

.contact .check a:hover {
  text-decoration: none !important;
  transition: 0.4s;
}
.contact .wpcf7-form-control-wrap {
  display: grid;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.sent .wpcf7-response-output {
  border: none;
  background: #eadef2;
  color: #69429d;
  border-radius: var(--v8-px);
  padding: 1em 1.5em;
}

.btn1 {
  position: relative;
  display: flex;
  align-items: center;
  width: max-content;
  height: var(--v48-px);
  line-height: var(--v48-px);
  padding: 0 var(--v32-px);
  margin: 0 auto;
  border-radius: 10vw;
  background: var(--dark-color);
  color: var(--white-color);
  gap: var(--v16-px);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: 0.08em;
}
.btn1:after {
  content: "";
  background: url("/img/common/arrow_white.svg") no-repeat;
  background-size: cover;
  width: 3.2666vw;
  height: 3vw;
}
.wp-block-image img {
  border-radius: var(--v8-px);
}

.wp-block-image figcaption {
  text-align: center;
  font-size: 0.8rem;
  margin-top: 0.25em;
}

/* works pagination */
.works .area3 .pagenation {
  display: flex;
  justify-content: center;
  margin-top: var(--v64-px);
}

.works .area3 .pagenation ul {
  display: flex;
  gap: var(--v8-px);
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
}

.works .area3 .pagenation ul li {
  min-width: var(--v32-px);
  height: var(--v32-px);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50vw;
  font-weight: 500;
  transition: 0.3s;
  font-size: 0.9rem;
}

.works .area3 .pagenation ul li a {
  color: var(--dark-color);
  text-decoration: none;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50vw;
  border: 1px solid var(--line-color);
  transition: 0.3s;
}

.works .area3 .pagenation ul li a:hover {
  background: var(--dark-color);
  color: var(--white-color);
  border-color: var(--dark-color);
  opacity: 1;
}

.works .area3 .pagenation ul li.active {
  background: var(--dark-color);
  color: var(--white-color);
  border-radius: 50vw;
  font-weight: 600;
}

.works .area3 .pagenation ul li:not(:has(a)):not(.active) {
  color: var(--light-color);
  font-weight: 400;
}
