@charset "UTF-8";
body {
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.06em;
  font-weight: bold;
  text-align: justify;
  text-justify: inter-ideograph;
  font-family: "Noto Sans JP", sans-serif;
  word-wrap: break-all;
  word-wrap: break-word;
  width: 100%;
  min-width: 1260px;
  color: #282f32;
  scroll-behavior: smooth;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  body {
    font-size: 16.4705882353px;
  }
}

.col-wht {
  color: #fff !important;
}
.col-blk {
  color: #282f32 !important;
}
.col-gry1 {
  color: #dde3e5 !important;
}
.col-gry2 {
  color: #f1f4f5 !important;
}
.col-ylw1 {
  color: #eec729 !important;
}
.col-ylw2 {
  color: #f9de59 !important;
}
.col-ylw3 {
  color: #fff2b8 !important;
}
.col-blu1 {
  color: #53b2d9 !important;
}
.col-blu2 {
  color: #7fcae9 !important;
}
.col-blu3 {
  color: #d6f4fc !important;
}

.bg-wht {
  background-color: #fff !important;
}
.bg-blk {
  background-color: #282f32 !important;
}
.bg-gry1 {
  background-color: #dde3e5 !important;
}
.bg-gry2 {
  background-color: #f1f4f5 !important;
}
.bg-ylw1 {
  background-color: #eec729 !important;
}
.bg-ylw2 {
  background-color: #f9de59 !important;
}
.bg-ylw3 {
  background-color: #fff2b8 !important;
}
.bg-blu1 {
  background-color: #53b2d9 !important;
}
.bg-blu2 {
  background-color: #7fcae9 !important;
}
.bg-blu3 {
  background-color: #d6f4fc !important;
}

.ptn-bdr-blu {
  background-image: linear-gradient(-45deg, #f9fdff 25%, #f0fbfe 25%, #f0fbfe 50%, #f9fdff 50%, #f9fdff 75%, #f0fbfe 75%, #f0fbfe);
  background-size: 30px 30px;
  background-attachment: fixed;
}

.btn-ptn1 .btn-link {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 23px;
  font-size: 2.3rem;
  line-height: 1;
  font-weight: 500;
  color: #fff;
  border-radius: 6px;
}
@media screen and (max-width: 768px) {
  .btn-ptn1 .btn-link {
    font-size: 33px;
    font-size: 4.296875vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .btn-ptn1 .btn-link {
    font-size: 19.4117647059px;
  }
}
.btn-ptn1 .btn-link.bg-blu1 {
  box-shadow: -8px 8px #d6f4fc;
}
.btn-ptn1 .btn-link.bg-ylw1 {
  box-shadow: -8px 8px #fff2b8;
}
.btn-ptn1 .btn-link:hover {
  color: rgba(255, 255, 255, 0.8);
  transform: translate(-2px, 2px);
}
.btn-ptn1 .btn-link:hover.bg-blu1 {
  box-shadow: 0 0 #d6f4fc;
}
.btn-ptn1 .btn-link:hover.bg-ylw1 {
  box-shadow: 0 0 #fff2b8;
}

.ic-tel {
  display: flex;
  align-items: center;
}
.ic-tel::before {
  content: "";
  display: block;
  width: 34px;
  aspect-ratio: 34/35;
  background-image: url("/img/common/ic-tel.png");
  background-size: 100%;
  margin-right: 10px;
}
.ic-mail::before, .ic-line::before {
  content: "";
  display: block;
  width: 28px;
  aspect-ratio: 28/22;
  background-image: url("/img/common/ic-mail.png");
  background-size: 100%;
  margin-right: 10px;
}
.ic-line::before {
  width: 30px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/ic-line.png");
  background-size: 100%;
}

.arw-wht-15, .arw-wht-33 {
  position: relative;
}
.arw-wht-15::after, .arw-wht-33::after {
  content: "";
  display: block;
  width: 33px;
  aspect-ratio: 33/35;
  background-image: url("/img/common/arw-wht.png");
  background-size: 100%;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translate(0, -50%);
  transition: 0.3s;
}
.arw-wht-15:hover::after, .arw-wht-33:hover::after {
  transform: translate(-2px, -50%);
}
.arw-wht-15::after {
  width: 15px;
}
.arw-blu {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.arw-blu::after {
  content: "";
  display: block;
  width: 21px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/arw-blu.png");
  background-size: 100%;
  transition: 0.3s;
}

.com-obj-staff {
  position: relative;
}
.com-obj-staff::before {
  content: "";
  display: block;
  width: 109px;
  aspect-ratio: 109/144;
  background-image: url("/img/common/illust-staff.png");
  background-size: 100%;
  position: absolute;
}

.hov-opa a:hover {
  opacity: 0.8;
}
.hov-img a:hover img {
  opacity: 0.8;
}
.hov-scale a img, .hov-up a img {
  backface-visibility: hidden;
  -webkit-transform: translateZ(0) scale(1, 1);
}
.hov-scale a:hover img, .hov-up a:hover img {
  transform: scale(0.98);
}
.hov-up a:hover img {
  transform: translateY(-3px);
}

.tbl {
  width: 100%;
}
.tbl td {
  overflow-wrap: anywhere; /* 収まらない場合に折り返す */
  word-break: normal; /* 単語の分割はデフォルトに依存 */
  line-break: strict; /* 禁則処理を厳格に適用 */
}
.tbl-ptn1 th, .tbl-ptn1 td {
  padding: 22px 0;
  vertical-align: middle;
  font-weight: 600;
  border-bottom: solid 2px #dde3e5;
}
.tbl-ptn1 th {
  width: 20%;
}
.tbl-ptn1 td {
  padding-left: 2%;
}
.tbl-ptn2 th, .tbl-ptn2 td {
  font-weight: 600;
  vertical-align: middle;
  padding: 24px 4%;
}
.tbl-ptn2 th {
  width: 30%;
  font-size: 20px;
  font-size: 2rem;
  background: #53b2d9;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .tbl-ptn2 th {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tbl-ptn2 th {
    font-size: 17.6470588235px;
  }
}
.tbl-ptn2 td {
  white-space: pre-wrap;
}
.tbl-ptn2 tr:not(:first-child) th {
  border-top: solid 2px #fff;
}
.tbl-ptn2 tr:not(:first-child) td {
  border-top: solid 2px #53b2d9;
}

.cts-1080 {
  width: 1080px;
  margin: 0 auto;
}

.list-clm-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px;
}
.list-clm-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 52.5px;
}
.list-clm-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px 45px;
}
.list-clm-5 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px 25px;
}
.list-nav .nav-item {
  line-height: 1;
}
.list-news time {
  display: block;
  line-height: 1;
  margin-right: 10px;
}
.list-news .list-item {
  border-bottom: solid 2px #dde3e5;
  padding-bottom: 20px;
}
.list-news .list-inner {
  display: flex;
  align-items: flex-start;
}
.list-news .list-ttl {
  margin-top: 10px;
}
.list-service-btn {
  padding: 80px 0;
  position: relative;
  z-index: 2;
}
.list-service-btn .list-item {
  aspect-ratio: 235/200;
}
.list-service-btn .list-link, .list-service-btn .list-ic {
  display: grid;
  place-content: center;
  place-items: center;
  text-align: center;
}
.list-service-btn .list-link {
  width: 100%;
  height: 100%;
  background: #53b2d9;
  gap: 10px 0;
  border-radius: 12px;
  box-shadow: -10px 10px #7fcae9;
}
.list-service-btn .list-link:hover {
  box-shadow: 0 0 #7fcae9;
  transform: translateY(2px);
}
.list-service-btn .list-link:hover .list-ttl {
  color: rgba(255, 255, 255, 0.8);
}
.list-service-btn .list-link:hover img {
  opacity: 0.8;
}
.list-service-btn .list-ic {
  min-height: 97px;
}
.list-service-btn .list-ttl {
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.25;
  color: #fff;
  transition: 0.3s;
}
@media screen and (max-width: 768px) {
  .list-service-btn .list-ttl {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-service-btn .list-ttl {
    font-size: 20px;
  }
}
.list-service-btn .obj-frame {
  width: 640px;
  height: 50%;
  border: dashed 2px #7fcae9;
  border-radius: 20px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(2);
  z-index: -2;
}
.list-service-btn.obj-air::before {
  content: "";
  display: block;
  width: 219px;
  aspect-ratio: 219/97;
  background-image: url("/img/common/service-obj-01.png");
  background-size: 100%;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(165px, -145px);
  z-index: -1;
}
.list-service-btn.obj-staff::after {
  content: "";
  display: block;
  width: 154px;
  aspect-ratio: 154/214;
  background-image: url("/img/common/service-obj-02.png");
  background-size: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translate(-170px, 120px);
  z-index: -1;
}
.list-case .list-link:hover img {
  opacity: 0.8;
}
.list-case .list-link:hover .list-ttl span {
  opacity: 0.8;
}
.list-case .list-link:hover .arw-blu::after {
  transform: translateX(-2px);
}
.list-case .list-img {
  width: 100%;
  aspect-ratio: 325/290;
  border-radius: 15px;
  overflow: hidden;
}
.list-case .list-ttl {
  font-size: 27px;
  font-size: 2.7rem;
  font-weight: 600;
  color: #53b2d9;
  margin-top: 20px;
  border-bottom: solid 2px #53b2d9;
  padding-bottom: 10px;
}
@media screen and (max-width: 768px) {
  .list-case .list-ttl {
    font-size: 37px;
    font-size: 4.8177083333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-case .list-ttl {
    font-size: 21.7647058824px;
  }
}
.list-case .list-ttl span {
  max-width: calc(100% - 30px);
}
.list-case-lower .list-tag {
  font-size: 25px;
  font-size: 2.5rem;
  background: #53b2d9;
  color: #fff;
  text-align: center;
  padding: 18px 30px;
  border-radius: 10px;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .list-case-lower .list-tag {
    font-size: 35px;
    font-size: 4.5572916667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-case-lower .list-tag {
    font-size: 20.5882352941px;
  }
}
.list-case-lower .list-tag span {
  text-align: center;
}
.list-case-lower .list-img {
  width: 100%;
  aspect-ratio: 510/380;
  border-radius: 15px;
  overflow: hidden;
}
.list-case-lower .list-ttl {
  font-size: 20px;
  font-size: 2rem;
  margin-top: 25px;
}
@media screen and (max-width: 768px) {
  .list-case-lower .list-ttl {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-case-lower .list-ttl {
    font-size: 17.6470588235px;
  }
}
.list-works {
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .list-works {
    font-size: 26px;
    font-size: 3.3854166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-works {
    font-size: 15.2941176471px;
  }
}
.list-works .list-inner {
  display: flex;
  align-items: flex-start;
}
.list-works .list-inner::before {
  content: "";
  display: block;
  width: 5px;
  min-width: 5px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  background: #53b2d9;
  margin-right: 10px;
  transform: translateY(200%);
}
.list-works-sub {
  font-size: 15px;
  font-size: 1.5rem;
  font-weight: normal;
  margin-top: 10px;
  display: grid;
  gap: 8px 0;
}
@media screen and (max-width: 768px) {
  .list-works-sub {
    font-size: 25px;
    font-size: 3.2552083333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-works-sub {
    font-size: 14.7058823529px;
  }
}
.list-works-sub .list-inner::before {
  width: 4px;
  min-width: 4px;
  background: #a7b0b3;
  transform: translateY(250%);
}
.list-faq .list-item {
  width: 100%;
  border-bottom: solid 2px #dde3e5;
  padding-bottom: 30px;
}
.list-faq dt, .list-faq dd {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.list-faq dt span, .list-faq dd span {
  width: 1030px;
  max-width: 100%;
}
.list-faq dt::before, .list-faq dd::before {
  content: "Q";
  display: block;
  font-size: 40px;
  font-size: 4rem;
  line-height: 1;
  font-weight: bold;
  color: #53b2d9;
  margin-right: 10px;
  transform: translateY(-15%);
}
@media screen and (max-width: 768px) {
  .list-faq dt::before, .list-faq dd::before {
    font-size: 50px;
    font-size: 6.5104166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dt::before, .list-faq dd::before {
    font-size: 29.4117647059px;
  }
}
.list-faq dt {
  font-size: 22px;
  font-size: 2.2rem;
  color: #53b2d9;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .list-faq dt {
    font-size: 32px;
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dt {
    font-size: 18.8235294118px;
  }
}
.list-faq dd {
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5625;
  white-space: pre-wrap;
  font-weight: 600;
  margin-top: 15px;
}
@media screen and (max-width: 768px) {
  .list-faq dd {
    font-size: 26px;
    font-size: 3.3854166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-faq dd {
    font-size: 15.2941176471px;
  }
}
.list-faq dd::before {
  content: "A";
  color: #f9de59;
}
.list-ba .list-item {
  text-align: center;
}
.list-ba .list-item img {
  border-radius: 10px;
}

.com-tag-main .list-tag {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5px;
}
.com-tag-main .tag-link {
  display: block;
  background: #f9de59;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: 600;
  padding: 10px 20px;
  border-radius: 4px;
}
@media screen and (max-width: 768px) {
  .com-tag-main .tag-link {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .com-tag-main .tag-link {
    font-size: 16.4705882353px;
  }
}
.com-tag-main .tag-link:hover {
  opacity: 0.8;
}
.com-tag-sub .list-tag {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.com-tag-sub .tag-item {
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 1;
  background: #f9de59;
  font-weight: 600;
  padding: 3px 8px 5px 8px;
  border-radius: 3px;
}
@media screen and (max-width: 768px) {
  .com-tag-sub .tag-item {
    font-size: 23px;
    font-size: 2.9947916667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .com-tag-sub .tag-item {
    font-size: 13.5294117647px;
  }
}
.com-gmap {
  max-width: 100%;
}
.com-gmap iframe {
  display: block;
  width: 100%;
  max-width: 100%;
  height: 100%;
}
.com-layout {
  display: flex;
}
.com-tel .tel {
  line-height: 1;
}

.ttl-main {
  font-weight: bold;
}
.ttl-main::after {
  content: "";
  display: block;
  width: 47px;
  aspect-ratio: 47/10;
  background-image: url("/img/common/obj-dot.png");
  background-size: 100%;
  margin: 18px 0 0;
}
.ttl-main.txt-aln-c::after {
  margin: 18px auto 0 auto;
}
.ttl-sub {
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: 600;
  border-left: solid #53b2d9 6px;
  border-bottom: solid 1px #dde3e5;
  background: #f1f4f5;
  color: #282f32;
  padding: 10px 0 15px 20px;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .ttl-sub {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-sub {
    font-size: 20px;
  }
}
.ttl-bar {
  font-size: 28px;
  font-size: 2.8rem;
  color: #53b2d9;
  text-align: center;
  background: #f1f4f5;
  padding: 18px 4%;
  border-radius: 10px;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .ttl-bar {
    font-size: 38px;
    font-size: 4.9479166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-bar {
    font-size: 22.3529411765px;
  }
}
.ttl-bar-min {
  font-size: 23px;
  font-size: 2.3rem;
  font-weight: 600;
  color: #53b2d9;
  text-align: center;
  background: #fff;
  padding: 18px 4%;
  border-radius: 8px;
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .ttl-bar-min {
    font-size: 33px;
    font-size: 4.296875vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-bar-min {
    font-size: 19.4117647059px;
  }
}

.txt-plain {
  font-weight: 600;
  line-height: 2.2222222222;
}
.txt-plain.ft-16 {
  line-height: 1.8;
}
.txt-plain.ft-20 {
  line-height: 1.9;
}

#com-contact {
  padding: 160px 0;
  background: url("/img/common/contact-bg.png") center bottom no-repeat;
  background-size: cover;
}
#com-contact .ttl-main {
  font-size: 55px;
  font-size: 5.5rem;
  text-align: center;
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  #com-contact .ttl-main {
    font-size: 65px;
    font-size: 8.4635416667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  #com-contact .ttl-main {
    font-size: 38.2352941176px;
  }
}
#com-contact .wrp-info {
  border-top: solid 2px #53b2d9;
  border-bottom: solid 2px #53b2d9;
  padding: 25px 0;
}
#com-contact .wrp-btn {
  margin-top: 50px;
}
#com-contact .txt-worktime {
  margin-top: 15px;
}
#com-contact .com-obj-staff::before {
  left: 0;
  top: 0;
  transform: translate(105px, -100%);
}
#com-contact .obj-house::after {
  content: "";
  display: block;
  width: 118px;
  aspect-ratio: 118/111;
  background-image: url("/img/common/contact-obj.png");
  background-size: 100%;
  position: absolute;
  right: 0;
  top: 0;
  transform: translate(-85px, -100%);
}

.hd-bar {
  padding: 45px 6.25% 0 6.25%;
}

#hd-nav .nav-item {
  position: relative;
}
#hd-nav .nav-item:not(:first-child)::before {
  content: "";
  display: block;
  width: 8px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  background: #53b2d9;
  position: absolute;
  left: -26.5px;
  top: 50%;
  transform: translate(0, -50%);
}
#hd-nav .nav-link:hover {
  color: #53b2d9;
}

.mv, .sv {
  margin-top: 55px;
  position: relative;
}
.mv img, .sv img {
  display: block;
  width: 100%;
}

.mv {
  padding-bottom: 2vw;
}
.mv-cc {
  width: 830px;
  max-width: 43.2291666667%;
  position: absolute;
  right: 6.25%;
  bottom: 0;
  z-index: 1;
}
.mv-cc-txt {
  font-size: 50px;
  font-size: 2.6041666667vw;
  background: #d6f4fc;
  border-radius: 9px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}
@media screen and (max-width: 1120px) {
  .mv-cc-txt {
    font-size: 29.4117647059px;
  }
}
@media screen and (min-width: 1920px) {
  .mv-cc-txt {
    font-size: 50px;
  }
}
.mv-cc-txt:first-child {
  width: 100%;
  aspect-ratio: 830/105;
}
.mv-cc-txt:last-child {
  width: 89.16%;
  aspect-ratio: 740/105;
  margin-top: 1.5vw;
}
.mv .com-obj-staff::before {
  width: 13.13%;
  left: 0;
  bottom: 0;
  transform: translate(-85%, 0);
}

.sv {
  width: 1675px;
  max-width: 87.2395833333%;
  aspect-ratio: 1682/556;
  margin: 55px auto 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
}
.sv-ttl {
  font-size: 50px;
  font-size: 2.6041666667vw;
  width: 47.76%;
  aspect-ratio: 800/105;
  border-radius: 9px;
  background: #d6f4fc;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 1120px) {
  .sv-ttl {
    font-size: 29.4117647059px;
  }
}
@media screen and (min-width: 1920px) {
  .sv-ttl {
    font-size: 50px;
  }
}
.sv-ttl::before {
  content: "";
  display: block;
  width: 11.5%;
  aspect-ratio: 92/68;
  background-image: url("/img/common/sv-obj.png");
  background-size: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  transform: translate(-50%, 20%);
  z-index: 1;
}
.sv-service {
  background: url("/img/service/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-case {
  background: url("/img/case/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-faq {
  background: url("/img/faq/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-company {
  background: url("/img/company/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-contact {
  background: url("/img/contact/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-blog {
  background: url("/img/blog/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-privacy {
  background: url("/img/privacy/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-complete {
  background: url("/img/complete/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-sitemap {
  background: url("/img/sitemap/sv.png") center center no-repeat;
  background-size: cover;
}
.sv-e404 {
  background: url("/img/e404/sv.png") center center no-repeat;
  background-size: cover;
}

#side-bar {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 88;
}

.top-news {
  padding: 150px 0;
}
.top-news .list-news {
  min-height: 240px;
}
.top-news .btn {
  position: absolute;
  left: 0;
  bottom: 0;
}

.top-greeting {
  padding: 120px 0;
}
.top-greeting .ttl-main {
  margin-bottom: 30px;
}
.top-greeting::after {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 1920/208;
  background-image: url("/img/top/greeting-bg.png");
  background-size: 100%;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 0);
  z-index: -1;
}

.top-service {
  padding: 150px 0;
}
.top-service .ttl-main {
  margin-bottom: 50px;
}

.top-case {
  padding: 130px 0;
}
.top-case .ttl-main {
  margin-bottom: 60px;
}
.top-case .btn {
  position: absolute;
  top: 0;
  right: 0;
}

.top-faq {
  padding: 130px 0;
}
.top-faq .faq-ttl {
  padding: 20px 40px;
}
.top-faq .faq-link {
  width: 100%;
  aspect-ratio: 1080/350;
  border: solid 5px #53b2d9;
  background: url("/img/top/faq-bg.png") center center no-repeat;
  background-size: cover;
  overflow: hidden;
  z-index: 1;
}
.top-faq .faq-link::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(214, 244, 252, 0.85);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transition: 0.2s;
}
.top-faq .faq-link:hover::before {
  background: rgba(214, 244, 252, 0.5);
}
.top-faq .arw-wht-33::after {
  right: 8px;
}
.top-faq .obj-circle {
  width: 130px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  background: #53b2d9;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(50%, -50%);
  z-index: -1;
}
.top-faq .obj-point::before {
  content: "";
  display: block;
  width: 42px;
  aspect-ratio: 42/30;
  background-image: url("/img/top/faq-obj-01.png");
  background-size: 100%;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(80%, -90%);
}
.top-faq .obj-men::after {
  content: "";
  display: block;
  width: 93px;
  aspect-ratio: 93/103;
  background-image: url("/img/top/faq-obj-02.png");
  background-size: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
  transform: translate(-70%, 15%);
}

.top-company {
  padding: 130px 0;
}
.top-company .layout-item {
  width: 100%;
}
.top-company .com-map {
  min-width: 500px;
}
.top-company .ttl-main {
  margin-bottom: 35px;
}
.top-company .btn {
  margin-top: 60px;
}

#ctn-lower article {
  padding: 150px 0;
}
#ctn-lower .ttl-main {
  font-size: 50px;
  font-size: 5rem;
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  #ctn-lower .ttl-main {
    font-size: 60px;
    font-size: 7.8125vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  #ctn-lower .ttl-main {
    font-size: 35.2941176471px;
  }
}
#ctn-lower .list-service-btn.obj-air::before {
  transform: translate(165px, -50%);
}
#ctn-lower .list-service-btn.obj-staff::after {
  transform: translate(-170px, 10%);
}

.service-cont .wrp-service,
.service-cont .list-case-lower,
.case-cont .wrp-service,
.case-cont .list-case-lower {
  margin-top: 100px;
}

.service-cont .service-item {
  width: 100%;
}
.service-cont .com-layout {
  justify-content: center;
  align-items: flex-start;
  gap: 0 80px;
}
.service-cont .layout-item {
  width: 500px;
  max-width: 100%;
}
.service-cont .img img {
  border-radius: 20px;
}
.service-cont .wrp-works {
  padding: 50px 70px;
  border-radius: 20px;
  margin-top: 50px;
}
.service-cont .btn {
  margin-top: 50px;
}

.case-dtl .wrp-ba-img {
  padding: 40px;
}

.company-greeting .obj-staff::after {
  content: "";
  display: block;
  width: 154px;
  aspect-ratio: 154/214;
  background-image: url("/img/common/service-obj-02.png");
  background-size: 100%;
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(70px, 5px) scaleX(-1) rotate(8deg);
  z-index: 1;
}

#footer {
  padding: 130px 0 120px 0;
}
#footer .list-sns {
  margin-top: 80px;
}

#ft-nav .nav-link {
  color: #fff;
}

.ft-copy {
  position: absolute;
  left: 0;
  bottom: 0;
  max-width: 500px;
}