@font-face {
  font-family: 'NEXA Light';
  src: url("../fonts/Nexa-Light.woff2") format("opentype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'NEXA Bold';
  src: url("../fonts/Nexa-Bold.woff2") format("opentype");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: 'Noah Regular Italic';
  src: url("../fonts/Noah-RegularItalic.otf") format("opentype"), url("../fonts/Noah-RegularItalic.ttf") format("truetype");
  font-weight: normal;
  font-style: italic;
}
@font-face {
  font-family: 'Noah Bold Italic';
  src: url("../fonts/Noah-BoldItalic.otf") format("opentype"), url("../fonts/Noah-BoldItalic.ttf") format("truetype");
  font-weight: bold;
  font-style: italic;
}
@font-face {
  font-family: 'Noah Regular';
  src: url("../fonts/Noah-Regular.otf") format("opentype"), url("../fonts/Noah-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'Noah Bold';
  src: url("../fonts/Noah-Bold.otf") format("opentype"), url("../fonts/Noah-Bold.ttf") format("truetype");
  font-weight: bold;
  font-style: normal;
}
/* line 2, ../sass/services/services-top.scss */
.header:not(.white) .hLogo, .header:not(.white) .hMenu {
  filter: invert(1) brightness(2);
}
/* line 6, ../sass/services/services-top.scss */
.header:not(.white) .hNav > ul > li > a {
  filter: invert(1) brightness(2);
}
/* line 11, ../sass/services/services-top.scss */
.header:not(.white) .hLang .polylang--list {
  background: transparent;
  border: 1px solid #fff;
  color: #fff;
}

/* line 19, ../sass/services/services-top.scss */
.ServiceTop {
  position: relative;
  color: #fff;
}
/* line 23, ../sass/services/services-top.scss */
.ServiceTop .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/* line 30, ../sass/services/services-top.scss */
.ServiceTop .bg img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* line 37, ../sass/services/services-top.scss */
.ServiceTop .bg:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.65;
}
/* line 50, ../sass/services/services-top.scss */
.ServiceTop .container {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  justify-content: space-between;
  padding-top: var(--header-height);
  min-height: clamp(432px, 100vh, 1080px);
  padding-bottom: clamp(15px, 3.5vw, 65px);
}
@media (orientation: portrait) {
  /* line 50, ../sass/services/services-top.scss */
  .ServiceTop .container {
    min-height: calc(100vw * 11 /16);
  }
}
/* line 71, ../sass/services/services-top.scss */
.ServiceTop .top {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: flex-end;
  padding-top: clamp(15px, 3vw, 85px);
}
/* line 81, ../sass/services/services-top.scss */
.ServiceTop .top .site-text {
  width: 415px;
}
/* line 87, ../sass/services/services-top.scss */
.ServiceTop .mid .site-text {
  margin-top: 20px;
}
/* line 92, ../sass/services/services-top.scss */
.ServiceTop .bot {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  -ms-align-items: flex-end;
  align-items: flex-end;
}
/* line 102, ../sass/services/services-top.scss */
.ServiceTop .bot .desc {
  position: relative;
  width: 415px;
}

@media only screen and (min-width: 1024px) and (max-width: 1299px) {
  /* line 113, ../sass/services/services-top.scss */
  .ServiceTop .top .site-text {
    width: 340px;
  }
  /* line 119, ../sass/services/services-top.scss */
  .ServiceTop .mid .site-text {
    margin-top: 15px;
  }
  /* line 125, ../sass/services/services-top.scss */
  .ServiceTop .bot .desc {
    width: 340px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1023px) {
  /* line 137, ../sass/services/services-top.scss */
  .ServiceTop .top .site-text {
    width: 270px;
  }
  /* line 143, ../sass/services/services-top.scss */
  .ServiceTop .mid .site-text {
    margin-top: 15px;
  }
  /* line 149, ../sass/services/services-top.scss */
  .ServiceTop .bot .desc {
    width: 270px;
  }
}
@media only screen and (min-width: 0px) and (max-width: 767px) {
  /* line 160, ../sass/services/services-top.scss */
  .ServiceTop .container {
    min-height: initial;
    height: calc(var(--vh, 1vh) * 100);
    padding-bottom: 40px;
  }
}
@media only screen and (min-width: 0px) and (max-width: 767px) and (orientation: portrait) {
  /* line 160, ../sass/services/services-top.scss */
  .ServiceTop .container {
    min-height: initial;
  }
}
@media only screen and (min-width: 0px) and (max-width: 767px) {
  /* line 170, ../sass/services/services-top.scss */
  .ServiceTop .top {
    -webkit-order: 2;
    -moz-order: 2;
    -ms-order: 2;
    -o-order: 2;
    order: 2;
    padding-top: 60px;
  }
  /* line 178, ../sass/services/services-top.scss */
  .ServiceTop .top .site-text {
    width: 100%;
  }
  /* line 183, ../sass/services/services-top.scss */
  .ServiceTop .mid {
    -webkit-order: 1;
    -moz-order: 1;
    -ms-order: 1;
    -o-order: 1;
    order: 1;
    padding-top: 40px;
  }
  /* line 191, ../sass/services/services-top.scss */
  .ServiceTop .mid .site-title.fz80 {
    font-size: 40px;
  }
  /* line 195, ../sass/services/services-top.scss */
  .ServiceTop .mid .site-text {
    margin-top: 15px;
  }
  /* line 200, ../sass/services/services-top.scss */
  .ServiceTop .bot {
    -webkit-order: 3;
    -moz-order: 3;
    -ms-order: 3;
    -o-order: 3;
    order: 3;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -o-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  /* line 212, ../sass/services/services-top.scss */
  .ServiceTop .bot .scroll {
    margin-top: 40px;
  }
  /* line 216, ../sass/services/services-top.scss */
  .ServiceTop .bot .desc {
    -webkit-order: -1;
    -moz-order: -1;
    -ms-order: -1;
    -o-order: -1;
    order: -1;
    width: 100%;
    padding-top: 10px;
  }
}
/* line 1, ../sass/services/services-title.scss */
.ServiceTitle {
  position: relative;
}
/* line 4, ../sass/services/services-title.scss */
.ServiceTitle .img {
  display: block;
  position: relative;
}
/* line 8, ../sass/services/services-title.scss */
.ServiceTitle .img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* line 16, ../sass/services/services-title.scss */
.ServiceTitle .top {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  padding-bottom: calc(8.5vw * 16 / 9);
}
/* line 27, ../sass/services/services-title.scss */
.ServiceTitle .top .img:nth-child(1) {
  position: absolute;
  left: 0;
  top: calc(21.1vw * 16 / 9);
  width: calc(10.3vw * 16 / 9);
  height: calc(5.8vw * 16 / 9);
}
/* line 35, ../sass/services/services-title.scss */
.ServiceTitle .top .img:nth-child(2) {
  width: calc(21.1vw * 16 / 9);
  height: calc(21.1vw * 16 / 9);
}
/* line 40, ../sass/services/services-title.scss */
.ServiceTitle .top .img:nth-child(3) {
  position: absolute;
  right: 0;
  top: calc(21.1vw * 16 / 9);
  width: calc(5.63vw * 16 / 9);
  height: calc(8.44vw * 16 / 9);
}
/* line 50, ../sass/services/services-title.scss */
.ServiceTitle .mid {
  position: relative;
}
/* line 53, ../sass/services/services-title.scss */
.ServiceTitle .mid .title {
  line-height: 0.9;
  font-size: clamp(58px, 12vw, 230px);
}
/* line 57, ../sass/services/services-title.scss */
.ServiceTitle .mid .title span {
  display: block;
}
/* line 61, ../sass/services/services-title.scss */
.ServiceTitle .mid .title b {
  display: inline-block;
}
/* line 67, ../sass/services/services-title.scss */
.ServiceTitle .bot {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
  padding-top: calc(10.25vw * 16 / 9);
}
/* line 78, ../sass/services/services-title.scss */
.ServiceTitle .bot .img:nth-child(1) {
  position: absolute;
  left: 0;
  top: 0px;
  width: calc(5.63vw * 16 / 9);
  height: calc(8.44vw * 16 / 9);
}
/* line 86, ../sass/services/services-title.scss */
.ServiceTitle .bot .img:nth-child(2) {
  width: calc(4.7vw * 16 / 9);
  height: calc(4.7vw * 16 / 9);
}
/* line 91, ../sass/services/services-title.scss */
.ServiceTitle .bot .img:nth-child(3) {
  position: absolute;
  right: 0;
  top: calc(0.44vw * 16 / 9);
  width: calc(7.05vw * 16 / 9);
  height: calc(4vw * 16 / 9);
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
  /* line 105, ../sass/services/services-title.scss */
  .ServiceTitle .img {
    transform: none !important;
  }
  /* line 109, ../sass/services/services-title.scss */
  .ServiceTitle .top {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -o-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: flex-start;
    padding-bottom: 0;
    gap: 45px 0;
  }
  /* line 120, ../sass/services/services-title.scss */
  .ServiceTitle .top .img:nth-child(1) {
    -webkit-order: 2;
    -moz-order: 2;
    -ms-order: 2;
    -o-order: 2;
    order: 2;
    position: relative;
    top: 0;
    margin-right: 60vw;
    width: 34vw;
    height: 19vw;
  }
  /* line 133, ../sass/services/services-title.scss */
  .ServiceTitle .top .img:nth-child(2) {
    -webkit-order: 1;
    -moz-order: 1;
    -ms-order: 1;
    -o-order: 1;
    order: 1;
    margin: 0 auto;
    width: 53vw;
    height: 53vw;
  }
  /* line 144, ../sass/services/services-title.scss */
  .ServiceTitle .top .img:nth-child(3) {
    -webkit-order: 3;
    -moz-order: 3;
    -ms-order: 3;
    -o-order: 3;
    order: 3;
    position: relative;
    right: auto;
    margin-left: auto;
    top: auto;
    width: 25vw;
    height: 35vw;
  }
  /* line 160, ../sass/services/services-title.scss */
  .ServiceTitle .mid {
    margin: 45px 0;
  }
  /* line 164, ../sass/services/services-title.scss */
  .ServiceTitle .bot {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -o-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 45px 0;
    padding-top: 0;
  }
  /* line 175, ../sass/services/services-title.scss */
  .ServiceTitle .bot .img:nth-child(1) {
    -webkit-order: 1;
    -moz-order: 1;
    -ms-order: 1;
    -o-order: 1;
    order: 1;
    position: relative;
    width: 15vw;
    height: 23vw;
    margin-right: 75vw;
  }
  /* line 187, ../sass/services/services-title.scss */
  .ServiceTitle .bot .img:nth-child(2) {
    -webkit-order: 3;
    -moz-order: 3;
    -ms-order: 3;
    -o-order: 3;
    order: 3;
    margin: auto;
    width: 25vw;
    height: 25vw;
  }
  /* line 198, ../sass/services/services-title.scss */
  .ServiceTitle .bot .img:nth-child(3) {
    -webkit-order: 2;
    -moz-order: 2;
    -ms-order: 2;
    -o-order: 2;
    order: 2;
    position: relative;
    right: auto;
    margin-left: calc(100vw - 34vw - 30px);
    top: auto;
    width: 34vw;
    height: 20vw;
  }
}
/* line 1, ../sass/services/services-list.scss */
.ServiceListWr {
  position: relative;
}
/* line 5, ../sass/services/services-list.scss */
.ServiceListWr.stick .ServiceListB {
  position: sticky;
  top: 0;
  height: 100vh;
}

/* line 13, ../sass/services/services-list.scss */
.ServiceListB {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  background: #2c3c4c;
  color: #fff;
}
/* line 28, ../sass/services/services-list.scss */
.ServiceListB .top {
  position: relative;
  border-bottom: 1px solid #fff;
  border-top: 1px solid #fff;
  padding-top: calc(1.17vw * 16 / 9);
  padding-bottom: calc(1.17vw * 16 / 9);
}
/* line 35, ../sass/services/services-list.scss */
.ServiceListB .top .container {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  -ms-align-items: flex-end;
  align-items: flex-end;
  gap: 0 15px;
}
/* line 48, ../sass/services/services-list.scss */
.ServiceListB .bot {
  position: relative;
  height: -webkit-fill-available;
  padding-top: calc(1.875vw * 16 / 9);
  padding-bottom: calc(1.875vw * 16 / 9);
}
/* line 54, ../sass/services/services-list.scss */
.ServiceListB .bot .container {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  height: 100%;
}
/* line 69, ../sass/services/services-list.scss */
.ServiceListB .bot .left {
  position: relative;
  width: 12%;
}
/* line 74, ../sass/services/services-list.scss */
.ServiceListB .bot .center {
  position: relative;
  width: 70%;
}
/* line 79, ../sass/services/services-list.scss */
.ServiceListB .bot .right {
  position: relative;
  width: 18%;
}
/* line 84, ../sass/services/services-list.scss */
.ServiceListB .bot .content {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  gap: 25px 0;
  width: 700px;
  max-width: calc(100% - 30px);
  margin: 0 auto;
}
/* line 104, ../sass/services/services-list.scss */
.ServiceListB .bot .include .site-text.fw600 {
  margin-bottom: calc(0.7vw * 16 / 9);
}
/* line 108, ../sass/services/services-list.scss */
.ServiceListB .bot .include .list {
  list-style-type: disc;
  list-style-position: inside;
}
/* line 112, ../sass/services/services-list.scss */
.ServiceListB .bot .include .list li {
  border-bottom: 1px solid #fff;
  padding-bottom: calc(0.3vw * 16 / 9);
  margin-bottom: calc(0.3vw * 16 / 9);
}
/* line 120, ../sass/services/services-list.scss */
.ServiceListB .bot .img {
  display: block;
}
/* line 123, ../sass/services/services-list.scss */
.ServiceListB .bot .img img {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}
@media (orientation: portrait) {
  /* line 13, ../sass/services/services-list.scss */
  .ServiceListB {
    height: auto;
  }
  /* line 136, ../sass/services/services-list.scss */
  .ServiceListB .bot .left {
    width: 100%;
    margin-bottom: 15px;
  }
  /* line 142, ../sass/services/services-list.scss */
  .ServiceListB .bot .center .content {
    margin-left: 0;
  }
  /* line 147, ../sass/services/services-list.scss */
  .ServiceListB .bot .right {
    width: 30%;
  }
}

@media only screen and (min-width: 1480px) and (max-width: 1679px) {
  /* line 157, ../sass/services/services-list.scss */
  .ServiceListB .top .site-title.fz44 {
    font-size: 40px;
  }
}
@media only screen and (min-width: 1300px) and (max-width: 1479px) {
  /* line 167, ../sass/services/services-list.scss */
  .ServiceListB .top .site-title.fz44 {
    font-size: 34px;
  }
}
@media only screen and (min-width: 1024px) and (max-width: 1299px) {
  /* line 177, ../sass/services/services-list.scss */
  .ServiceListB .top .site-title.fz44 {
    font-size: 26px;
  }
}
@media only screen and (min-width: 0px) and (max-width: 767px) {
  /* line 186, ../sass/services/services-list.scss */
  .ServiceListB {
    position: relative;
  }
  /* line 189, ../sass/services/services-list.scss */
  .ServiceListB .top {
    padding-top: 15px;
    padding-bottom: 15px;
  }
  /* line 193, ../sass/services/services-list.scss */
  .ServiceListB .top .site-title.fz44 {
    font-size: 24px;
  }
  /* line 197, ../sass/services/services-list.scss */
  .ServiceListB .top .site-btn {
    display: none;
  }
  /* line 202, ../sass/services/services-list.scss */
  .ServiceListB .bot {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}
@media only screen and (min-width: 0px) and (max-width: 767px) and (orientation: portrait) {
  /* line 209, ../sass/services/services-list.scss */
  .ServiceListB .bot .center {
    width: 100%;
  }
  /* line 211, ../sass/services/services-list.scss */
  .ServiceListB .bot .center .content {
    margin-left: 0;
  }
  /* line 216, ../sass/services/services-list.scss */
  .ServiceListB .bot .right {
    margin-top: 30px;
    width: 100%;
  }
}

/* line 1, ../sass/services/services-process.scss */
.ServiceProcess {
  position: relative;
}
/* line 4, ../sass/services/services-process.scss */
.ServiceProcess .list {
  position: relative;
  counter-reset: section;
  border-top: 1px solid #000;
  margin-top: calc(1.75vw * 16 / 9);
}
/* line 11, ../sass/services/services-process.scss */
.ServiceProcess li {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  border-bottom: 1px solid #000;
  padding: calc(1.3vw * 16 / 9) 0;
}
/* line 23, ../sass/services/services-process.scss */
.ServiceProcess li .global-link {
  cursor: pointer;
}
/* line 27, ../sass/services/services-process.scss */
.ServiceProcess li:before {
  counter-increment: section;
  content: "(" counter(section) ")";
}
/* line 32, ../sass/services/services-process.scss */
.ServiceProcess li:after {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  height: 0;
  width: 100%;
  background: rgba(44, 60, 76, 0.1);
  transition: height 0.5s cubic-bezier(0.25, 1, 0.5, 1);
  z-index: -1;
}
@media (hover: hover) {
  /* line 47, ../sass/services/services-process.scss */
  .ServiceProcess li:hover:after {
    height: 100%;
  }
}
/* line 54, ../sass/services/services-process.scss */
.ServiceProcess .name {
  display: inline-block;
  margin-left: clamp(15px, 3vw, 55px);
  margin-right: 15px;
}
/* line 60, ../sass/services/services-process.scss */
.ServiceProcess .more {
  margin-left: auto;
  min-width: max-content;
}

@media only screen and (min-width: 0px) and (max-width: 767px) {
  /* line 69, ../sass/services/services-process.scss */
  .ServiceProcess .list {
    margin-top: 30px;
  }
  /* line 73, ../sass/services/services-process.scss */
  .ServiceProcess li {
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    -o-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 15px 0;
  }
  /* line 81, ../sass/services/services-process.scss */
  .ServiceProcess li:before {
    -webkit-order: 1;
    -moz-order: 1;
    -ms-order: 1;
    -o-order: 1;
    order: 1;
  }
  /* line 90, ../sass/services/services-process.scss */
  .ServiceProcess .over {
    -webkit-order: 3;
    -moz-order: 3;
    -ms-order: 3;
    -o-order: 3;
    order: 3;
    width: 100%;
  }
  /* line 99, ../sass/services/services-process.scss */
  .ServiceProcess .name {
    margin: 0;
    margin-top: 10px;
  }
  /* line 104, ../sass/services/services-process.scss */
  .ServiceProcess .more {
    -webkit-order: 2;
    -moz-order: 2;
    -ms-order: 2;
    -o-order: 2;
    order: 2;
  }
}
/* line 1, ../sass/services/services-photo-desc.scss */
.ServicePhotoDesc {
  position: relative;
  color: #fff;
}
/* line 5, ../sass/services/services-photo-desc.scss */
.ServicePhotoDesc .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/* line 12, ../sass/services/services-photo-desc.scss */
.ServicePhotoDesc .bg img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* line 19, ../sass/services/services-photo-desc.scss */
.ServicePhotoDesc .bg:after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.65;
}
/* line 32, ../sass/services/services-photo-desc.scss */
.ServicePhotoDesc .container {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  justify-content: space-between;
  height: 100vh;
  max-height: 1080px;
}
@media (orientation: portrait) {
  /* line 32, ../sass/services/services-photo-desc.scss */
  .ServicePhotoDesc .container {
    height: calc(100vw * 10 /16);
    max-height: initial;
  }
}
/* line 53, ../sass/services/services-photo-desc.scss */
.ServicePhotoDesc .site-text {
  margin-left: auto;
  width: 330px;
}

@media only screen and (min-width: 0px) and (max-width: 767px) and (orientation: portrait) {
  /* line 62, ../sass/services/services-photo-desc.scss */
  .ServicePhotoDesc .container {
    height: calc(100vw * 16 /16);
  }
}
@media only screen and (min-width: 0px) and (max-width: 767px) {
  /* line 68, ../sass/services/services-photo-desc.scss */
  .ServicePhotoDesc .site-text {
    margin-left: 0;
    width: 100%;
  }
}
/* line 1, ../sass/index/index-about.scss */
.IndexAbout {
  position: relative;
}
/* line 4, ../sass/index/index-about.scss */
.IndexAbout .container {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
}
/* line 18, ../sass/index/index-about.scss */
.IndexAbout .left {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  justify-content: space-between;
  -ms-align-items: flex-start;
  align-items: flex-start;
  width: 340px;
  max-width: calc(30% - 30px);
}
/* line 36, ../sass/index/index-about.scss */
.IndexAbout .left .top {
  position: relative;
}
/* line 39, ../sass/index/index-about.scss */
.IndexAbout .left .top svg {
  display: inline-block;
  height: 38px;
  width: auto;
  margin-bottom: 3px;
}
/* line 46, ../sass/index/index-about.scss */
.IndexAbout .left .top .fz30 {
  margin-bottom: 8px;
}
/* line 54, ../sass/index/index-about.scss */
.IndexAbout .bot .site-title {
  overflow: hidden;
  position: relative;
}
/* line 60, ../sass/index/index-about.scss */
.IndexAbout .center {
  position: relative;
  display: block;
  width: 40%;
}
/* line 65, ../sass/index/index-about.scss */
.IndexAbout .center .over {
  width: 100%;
}
/* line 69, ../sass/index/index-about.scss */
.IndexAbout .center img {
  display: block;
  width: 100%;
  aspect-ratio: 160/197;
  object-fit: cover;
}
/* line 76, ../sass/index/index-about.scss */
.IndexAbout .center .wow {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  animation-fill-mode: forwards;
}
/* line 87, ../sass/index/index-about.scss */
.IndexAbout .centerpicturewr {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}
/* line 96, ../sass/index/index-about.scss */
.IndexAbout .centerpicture {
  display: block;
  width: 100%;
}
/* line 101, ../sass/index/index-about.scss */
.IndexAbout .right {
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: flex-start;
  align-items: flex-start;
  justify-content: space-between;
  width: 352px;
  max-width: calc(30% - 30px);
}
/* line 119, ../sass/index/index-about.scss */
.IndexAbout .right .site-text {
  max-width: 220px;
  line-height: 1.35;
}
/* line 124, ../sass/index/index-about.scss */
.IndexAbout .right .over:last-child {
  margin-top: 45px;
}
/* line 128, ../sass/index/index-about.scss */
.IndexAbout .right.with-title {
  justify-content: flex-start;
}
/* line 131, ../sass/index/index-about.scss */
.IndexAbout .right.with-title .bot {
  margin-bottom: 50px;
}
/* line 135, ../sass/index/index-about.scss */
.IndexAbout .right.with-title .site-text {
  max-width: 320px;
}
/* line 141, ../sass/index/index-about.scss */
.IndexAbout .img {
  display: block;
  width: 100%;
}
/* line 145, ../sass/index/index-about.scss */
.IndexAbout .img img {
  display: block;
  width: 100%;
}
/* line 150, ../sass/index/index-about.scss */
.IndexAbout .img .wow {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  animation-fill-mode: forwards;
}
/* line 161, ../sass/index/index-about.scss */
.IndexAbout .centerimgwr {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}
/* line 170, ../sass/index/index-about.scss */
.IndexAbout .centerimg {
  display: block;
  width: 100%;
}

/* line 178, ../sass/index/index-about.scss */
.lang-en .IndexAbout .site-title.fz80 {
  font-size: 78px;
}

@media only screen and (min-width: 1680px) and (max-width: 1879px) {
  /* line 188, ../sass/index/index-about.scss */
  .lang-en .IndexAbout .site-title.fz80 {
    font-size: 68px;
  }
}
@media only screen and (min-width: 1480px) and (max-width: 1679px) {
  /* line 199, ../sass/index/index-about.scss */
  .IndexAbout .site-title.fz80 {
    font-size: 68px;
  }

  /* line 206, ../sass/index/index-about.scss */
  .lang-en .IndexAbout .site-title.fz80 {
    font-size: 60px;
  }
}
@media only screen and (min-width: 1300px) and (max-width: 1479px) {
  /* line 217, ../sass/index/index-about.scss */
  .IndexAbout .site-title.fz80 {
    font-size: 56px;
  }
  /* line 221, ../sass/index/index-about.scss */
  .IndexAbout .left2 {
    width: 245px;
  }
  /* line 225, ../sass/index/index-about.scss */
  .IndexAbout .right {
    width: 245px;
  }
  /* line 229, ../sass/index/index-about.scss */
  .IndexAbout .center1 {
    margin-right: auto;
    margin-left: 4%;
  }
  /* line 234, ../sass/index/index-about.scss */
  .IndexAbout .center2 {
    margin-right: 8%;
  }

  /* line 241, ../sass/index/index-about.scss */
  .lang-en .IndexAbout .site-title.fz80 {
    font-size: 54px;
  }
}
@media only screen and (min-width: 1024px) and (max-width: 1299px) {
  /* line 254, ../sass/index/index-about.scss */
  .IndexAbout .site-title.fz80 {
    font-size: 44px;
  }
  /* line 262, ../sass/index/index-about.scss */
  .IndexAbout .left .top svg {
    height: 30px;
  }
  /* line 268, ../sass/index/index-about.scss */
  .IndexAbout .left2 {
    width: 245px;
  }
  /* line 272, ../sass/index/index-about.scss */
  .IndexAbout .right {
    width: 245px;
  }
  /* line 276, ../sass/index/index-about.scss */
  .IndexAbout .center1 {
    margin-right: auto;
    margin-left: 4%;
  }
  /* line 281, ../sass/index/index-about.scss */
  .IndexAbout .center2 {
    margin-right: 2%;
    width: 33%;
  }

  /* line 289, ../sass/index/index-about.scss */
  .lang-en .IndexAbout .site-title.fz80 {
    font-size: 40px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1023px) {
  /* line 303, ../sass/index/index-about.scss */
  .IndexAbout .container {
    gap: 20px;
  }
  /* line 307, ../sass/index/index-about.scss */
  .IndexAbout .left {
    width: 100%;
    max-width: 100%;
  }
  /* line 312, ../sass/index/index-about.scss */
  .IndexAbout .left .top svg {
    height: 30px;
  }
  /* line 317, ../sass/index/index-about.scss */
  .IndexAbout .left .bot {
    margin-top: 30px;
  }
  /* line 322, ../sass/index/index-about.scss */
  .IndexAbout .left2 {
    max-width: 100%;
    width: 100%;
  }
  /* line 326, ../sass/index/index-about.scss */
  .IndexAbout .left2 .top {
    margin-bottom: 20px;
  }
  /* line 331, ../sass/index/index-about.scss */
  .IndexAbout .right {
    max-width: 100%;
    width: 100%;
  }
  /* line 337, ../sass/index/index-about.scss */
  .IndexAbout .right.with-title .bot {
    margin-bottom: 20px;
  }
  /* line 342, ../sass/index/index-about.scss */
  .IndexAbout .right .site-text {
    max-width: 100%;
  }
  /* line 346, ../sass/index/index-about.scss */
  .IndexAbout .right .top {
    display: flex;
    flex-wrap: wrap;
  }
  /* line 353, ../sass/index/index-about.scss */
  .IndexAbout .right .img ~ .top {
    margin-top: 20px;
  }
  /* line 360, ../sass/index/index-about.scss */
  .IndexAbout .right .over:last-child {
    width: 100%;
    margin-right: auto;
    margin-top: 20px;
  }
  /* line 372, ../sass/index/index-about.scss */
  .IndexAbout .bot .site-title {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
  }
  /* line 381, ../sass/index/index-about.scss */
  .IndexAbout .img img {
    aspect-ratio: 16 / 9;
  }
  /* line 386, ../sass/index/index-about.scss */
  .IndexAbout .center {
    width: 100%;
    max-width: 100%;
  }
  /* line 390, ../sass/index/index-about.scss */
  .IndexAbout .center img {
    aspect-ratio: 16 / 9;
  }
  /* line 395, ../sass/index/index-about.scss */
  .IndexAbout .center1 {
    margin-right: auto;
    margin-left: 0;
    margin-right: 0;
  }
  /* line 401, ../sass/index/index-about.scss */
  .IndexAbout .center2 {
    margin-left: 0;
    margin-right: 0;
    width: 100%;
    max-width: 100%;
  }

  /* line 411, ../sass/index/index-about.scss */
  .lang-en .IndexAbout .site-title.fz80 {
    font-size: 50px;
  }
}
@media only screen and (min-width: 0px) and (max-width: 767px) {
  /* line 424, ../sass/index/index-about.scss */
  .IndexAbout .container {
    gap: 35px;
  }
  /* line 428, ../sass/index/index-about.scss */
  .IndexAbout .left {
    width: 100%;
    max-width: 100%;
    align-items: center;
  }
  /* line 435, ../sass/index/index-about.scss */
  .IndexAbout .left .top svg {
    height: 30px;
  }
  /* line 440, ../sass/index/index-about.scss */
  .IndexAbout .left .bot {
    margin-top: 30px;
  }
  /* line 445, ../sass/index/index-about.scss */
  .IndexAbout .left2 {
    max-width: 100%;
    width: 100%;
  }
  /* line 449, ../sass/index/index-about.scss */
  .IndexAbout .left2 .top {
    margin-bottom: 35px;
  }
  /* line 454, ../sass/index/index-about.scss */
  .IndexAbout .right {
    max-width: 100%;
    width: 100%;
  }
  /* line 460, ../sass/index/index-about.scss */
  .IndexAbout .right.with-title .bot {
    margin-bottom: 35px;
  }
  /* line 464, ../sass/index/index-about.scss */
  .IndexAbout .right.with-title .over {
    display: inline-block;
  }
  /* line 468, ../sass/index/index-about.scss */
  .IndexAbout .right.with-title .site-text {
    max-width: initial;
    display: inline;
  }
  /* line 474, ../sass/index/index-about.scss */
  .IndexAbout .right .site-text {
    max-width: 100%;
  }
  /* line 478, ../sass/index/index-about.scss */
  .IndexAbout .right .top {
    display: flex;
    flex-wrap: wrap;
    gap: 0 3px;
  }
  /* line 486, ../sass/index/index-about.scss */
  .IndexAbout .right .img ~ .top {
    margin-top: 35px;
  }
  /* line 493, ../sass/index/index-about.scss */
  .IndexAbout .right .over:last-child {
    width: 100%;
    margin-right: auto;
    margin-top: 35px;
  }
  /* line 505, ../sass/index/index-about.scss */
  .IndexAbout .bot .site-title {
    display: flex;
    flex-wrap: wrap;
    gap: 5px 15px;
    text-align: center;
    justify-content: center;
  }
  /* line 516, ../sass/index/index-about.scss */
  .IndexAbout .img img {
    aspect-ratio: 16 / 9;
  }
  /* line 521, ../sass/index/index-about.scss */
  .IndexAbout .center {
    width: 100%;
    max-width: 100%;
  }
  /* line 525, ../sass/index/index-about.scss */
  .IndexAbout .center img {
    aspect-ratio: 16 / 9;
  }
  /* line 530, ../sass/index/index-about.scss */
  .IndexAbout .center1 {
    margin-right: auto;
    margin-left: 0;
    margin-right: 0;
  }
  /* line 536, ../sass/index/index-about.scss */
  .IndexAbout .center2 {
    margin-left: 0;
    margin-right: 0;
    width: 100%;
    max-width: 100%;
  }

  /* line 546, ../sass/index/index-about.scss */
  .lang-en .IndexAbout .site-title.fz80 {
    font-size: 44px;
  }
}
/* line 15, ../sass/services.scss */
body {
  padding-top: 0;
}
