@charset "UTF-8";
:root {
  --neon-border-color: rgba(0, 227, 255,.5);
}
.ttl__anima {
  width:60px;
  display:flex;
  justify-content:space-between;
  margin-top:20px;
}
.ttl__anima > span {
  display:block;
  width:8px;
  height:8px;
  border-radius:50vh;
  animation: circle-blink 3s ease-in-out infinite alternate-reverse;
}
@keyframes circle-blink {
  0% {
    transform:scale(1);
    opacity:1;
  }
  50% {
    transform:scale(1.2);
    opacity:.6;
  }
  100% {
    transform:scale(1);
    opacity:1;
  }
}
.ttl__anima > span:nth-of-type(1) {
  background:#7ec9d1;
}
.ttl__anima > span:nth-of-type(2) {
  background:#189ead;
  animation-delay:1s;
}
.ttl__anima > span:nth-of-type(3) {
  background:#4eb5c1;
  animation-delay:2s;
}
/*----------------------------------------------------
  .about
----------------------------------------------------*/
.about {
  width:100%;
  height:auto;
  position:relative;
  padding:300px 0 150px 0;
}
.about__body {
  width:90%;
  max-width:1200px;
  margin:0 auto;
  position:relative;
  z-index:1;
}
.about__top {
  width:95%;
  margin:0 auto;
}
.about__ttl {
  width:100%;
  line-height:1.4;
  margin-bottom:30px;
}
.about__ttl > p {
  font-size:1.4rem;
  font-weight:bold;
}
.about__lead {
  width:100%;
  font-size:2.4rem;
  margin-bottom:40px;
}
.about__lead > p {
  font-weight:bold;
}
.about__col {
  width:100%;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  box-sizing:border-box;
  position:relative;
}
.about__item {
  width:49.5%;
  padding:80px 50px;
  box-sizing:border-box;
  position:relative;
  display:flex;
  flex-direction:column;
  color:#fff;
}
.about__item:nth-of-type(1) {
  background:linear-gradient(45deg,rgba(0,102,118,0.9200000166893005),rgba(0,212,231,0.9200000166893005));
  border-radius:80px 0 0 80px;
}
.about__item:nth-of-type(1)::before {
  display: block;
  content:'';
  width:100%;
  height:100%;
  position:absolute;
  top:0;
  left:0;
  background-image:url('../img/top/service-item-bg1.png');
  border-radius:80px 0 0 80px;
  background-size:cover;
}
.about__item:nth-of-type(2) {
  background-image:url('../img/top/service-item-bg2.png');
  background-size:cover;
  background-color: rgba(2, 50, 77, 0.9200000166893005);
  border-radius:0 80px 80px 0;
}
.about_ttl-sub {
  display:flex;
  flex-direction:column-reverse;
  justify-content:center;
  align-items:center;
  line-height:1.4;
  padding-bottom:30px;
  border-bottom:1px solid #f2f2f2;
}
.about_ttl-sub > h3 {
  font-size:1.6rem;
}
.about__item-lead {
  font-size:2.4rem;
  font-weight:bold;
  padding:40px 0;
  text-align:center;
}
.about_ttl-sub > p {
  font-size:5rem;
}
.about__txt {
  margin-bottom:30px;
}
.about__link {
  width:60%;
  margin:auto auto 0 auto;
}
.object__anima2 {
  width:100px;
  position:absolute;
  bottom:140px;
  right:-5%;
  z-index:1;
}
.object__anima2 > img {
  animation: object__anima2 1.6s linear infinite;
  position:absolute;
  top:0;left:0;
}
@keyframes object__anima2 {
  0% {
    opacity: 1;
  }
  54% {
    opacity: 1;
  }
  55% {
    opacity: 0;
  }
}
.object__anima2 > img:nth-of-type(2) {
  animation-delay: 0.8s;
}
.about__bg {
  width:95%;
  height:auto;
  position:absolute;
  top:10%;
  right:0;
  transform:translate(0,0);
}
.about__bg::after {
  display:block;
  content:'';
  width:100%;
  height:0;
  padding-top:52.35%;
}
.about__bg svg {
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  opacity:0;
  stroke-dasharray:6000;
  stroke-dashoffset:0;
}
.is-active svg {
  stroke-dasharray: 6000;
  stroke-dashoffset: 6000;
  animation:line_animation 4s linear 0s 1;
  animation-fill-mode: forwards;
}
@keyframes line_animation {
0% { stroke-dashoffset: 6000;opacity:1; }
100% { stroke-dashoffset: 0;opacity:1; }
}
/*----------------------------------------------------
  .web
----------------------------------------------------*/
.web {
  width:100%;
  height:auto;
  background:#f5fbfc;
  padding:100px 0;
}
.web__body {
  width:90%;
  max-width:1280px;
  margin:0 auto;
  position:relative;
  z-index:1;
}
.web__body .ttl {
  margin-bottom:60px;
}
.web__top {
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items: center;
}
.web__top-item {
  width:55%;
}
.web__top-txt {
  width:100%;
  height:auto;
}
.web__top-txt > p:not(:last-child) {
  margin-bottom:30px;
}
.web__top-txt > ul {
  width:100%;
  height:auto;
  padding:20px 20px 20px 40px;
  box-sizing:border-box;
  margin-bottom:30px;
  font-weight:bold;
  font-size:1.8rem;
  position: relative;
}
.web__top-txt > ul::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 20px;
  border: 3px solid transparent;
  background:linear-gradient(90deg,#01d8eb, #288e9e) border-box border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  -webkit-mask-composite: destination-out;
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  mask-composite: exclude;
}
.web__top-img {
  width:40%;
}
.web__top-img > img {
  border-radius:40px;
}
/*----------------------------------------------------
  .result
----------------------------------------------------*/
.result {
  width:100%;
  height:auto;
  padding:100px 0;
}
.result__body {
  width:90%;
  max-width:1280px;
  margin:0 auto;
  position:relative;
  z-index:1;
}
.result__ttl {
  width:auto;
  height:auto;
  margin:0 auto 60px auto;
  text-align:center;
  position:relative;
  line-height:1.6;
}
.result__ttl > h2 {
  font-size:3.6rem;
  text-align:center;
  margin-bottom:10px;
}
.result__ttl > p {
  font-size:3rem;
  font-weight:bold;
  color: transparent;
  background: linear-gradient(270deg, rgb(0,57,98) 0%, rgb(1, 217, 236) 100%);
  background-clip: text;
}
.web__top-txt > ul::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 20px;
  border: 3px solid transparent;
  background:linear-gradient(90deg,#01d8eb, #288e9e) border-box border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  -webkit-mask-composite: destination-out;
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0) border-box;
  mask-composite: exclude;
}
.result__col {
  width:100%;
  height:auto;
  display:flex;
  justify-content:space-between;
}
.result__item {
  width:55%;
}
.result__item > p {
  font-size:1.8rem;
  margin-bottom:30px;
}
.result__item > ul {
  width:100%;
  height:auto;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  list-style:none;
}
.result__item > ul > li {
  width:32.5%;
  padding:20px 0;
  display:flex;
  justify-content:center;
  align-items:center;
  box-sizing:border-box;
  font-size:1.7rem;
  font-weight:bold;
  background:#E0F8FC;
  border-radius:8px;
} 
.result__item > ul > li:nth-of-type(n+4) {
  margin-top:10px;
}
.result__img {
  width:40%;
}
.result__img > img {
  border-radius:40px;
}
/*----------------------------------------------------
  .detail
----------------------------------------------------*/
.detail {
  width:100%;
  height:auto;
  padding:100px 0;
  margin-bottom:100px;
  position:relative;
}
.detail::after {
  display:block;
  content:'';
  width:85%;
  height:90%;
  position:absolute;
  top:50%;
  right:0;
  transform:translate(0,-50%);
  background:#f5fbfc;
}
.detail__body {
  width:90%;
  max-width:1440px;
  margin:0 auto;
  position:relative;
  z-index:1;
}
.detail .ttl {
  width:80%;
  margin:0 auto;
}
.detail__col {
  width:100%;
  display:flex;
  justify-content:space-around;
  align-items:center;
  margin-bottom:120px;
} 
.detail__img {
  width:55%;
}
.detail__items {
  width:35%;
}
.detail__items-inner {
  display:flex;
  justify-content:flex-end;
  align-items:flex-end;
  margin-bottom:20px;
}
.detail__items-img {
  width:60px;
  margin-left:10px;
}
.detail__item-txt {
  width:auto;
  font-size:2rem;
  text-align:right;
}
.detail__items > ul {
  width:100%;
  height:auto;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  list-style:none;
}
.detail__items > ul > li {
  width:30%;
  height:auto;
}
.detail__items > ul > li:nth-of-type(n+4) {
  margin-top:20px;
}
.detail__link {
  width:75%;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.detail__link > a {
  display:flex;
  justify-content:center;
  align-items:center;
  width:49%;
  height:120px;
  color:#fff;
  border-radius:20px;
}
.detail__link > a:nth-of-type(1) {
  background: linear-gradient(-270deg, #003962 0%, #01d9ec 100%);
}
.detail__link > a:nth-of-type(2) {
  background: linear-gradient(-270deg, #20B2AA 0%, #BCF0AC 100%);
}
.detail__link > a > span {
  width:60px;
  height:60px;
  display:flex;
  justify-content:center;
  align-items:center;
  background:#fff;
  font-size:2.6rem;
  border-radius:50vh;
  margin-right:10px;
}
.detail__link > a:nth-of-type(1) > span {
  color:#003962;
}
.detail__link > a:nth-of-type(2) > span {
  color:#20B2AA;
}
.detail__link-col {
  display:flex;
  flex-direction:column;
  align-items:center;
  line-height:1.6;
}
.detail__link-col > p {
  font-size:2rem;
  font-weight:bold;
}
.detail__link-col > span {
  font-size:1.4rem;
}
@media screen and (max-width:1280px) {
}
@media screen and (max-width:1024px) {
  /*--- service ---*/
  .about {
    padding-top:200px;
  }
  .about__body {
    width:75%;
  }
  .about__col {
    width:100%;
    flex-direction:column;
  }
  .about__item {
    width:100%;
    max-width:initial;
  }
  .about__item:nth-of-type(1),
  .about__item:nth-of-type(1)::before {
    border-radius:80px 80px 0 0;
  }
  .about__item:nth-of-type(2),
  .about__item:nth-of-type(2)::before {
    border-radius:0 0 80px 80px;
  }
  .about__link {
    max-width:360px;
  }
  .about__bg {
    top:5%;
  }
}
@media screen and (max-width:896px) {
   /*--- service ---*/
  .about__body {
    width:80%;
  }
}
@media screen and (max-width:786px) {
  /*--- service ---*/
  .about {
    padding-top:200px;
  }
  .about__body {
    width:85%;
  }
  .about__col {
    width:100%;
    flex-direction:column;
  }
}
@media screen and (max-width:680px) {
}
@media screen and (max-width:480px) {
  /*--- about ---*/
  .about {
    padding:100px 0;
  }
  .about__col {
    width:100%;
    padding:0;
  }
  .about__item {
    padding:40px 20px 50px 20px;
  }
  .about__item:nth-of-type(1),
  .about__item:nth-of-type(1)::before {
    border-radius: 30px 30px 0 0;
  }
  .about__item:nth-of-type(2),
  .about__item:nth-of-type(2)::before {
    border-radius:0 0 30px 30px;
  }
  .about_ttl-sub {
    padding-bottom:20px;
    line-height:1.6;
  }
  .about_ttl-sub > h3 {
    font-size:1.4rem;
  }
  .about_ttl-sub > p {
    font-size:3.6rem;
  }
  .about__lead {
    font-size:1.5rem;
    padding:20px 0 10px 0;
  }
  .about__item-lead {
    font-size:1.6rem;
    padding:24px 0;
  }
  .about__txt {
    font-size:1.3rem;
    margin-bottom:20px;
  }
  .about__link {
    width:85%;
    max-width:360px;
  }
  .about__bg {
    top:2.5%;
  }
  .object__anima2 {
    width:85px;
    bottom:60px;
    right:-5%;
  }
}