@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__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;
}
/*----------------------------------------------------
  .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-ttl {
  width:100%;
  height:auto;
  margin-bottom:15px;
  position:relative;
}
.web__top-ttl > h3 {
  font-size:3rem;
  position:relative;
  z-index:1;
}
.web__top-bg {
  width:60%;
  height:auto;
  position:absolute;
  bottom:-5px;left:0;
}
.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__item-txt br:nth-of-type(2) {
  display:none;
}
.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) {
  /*--- web ---*/
  .web__body {
    width:70%;
  }
  .web__top {
    flex-direction:column;
    align-items:flex-start;
  }
  .web__top-img {
    width:80%;
    margin-bottom:100px;
  }
  .web__top-item {
    width:100%;
  }
  /*--- result ---*/
  .result__body {
    width:70%;
  }
  .result__col {
    flex-direction:column-reverse;
  }
  .result__img {
    width:100%;
    margin-bottom:60px;
  }
  .result__item {
    width:100%;
  }
  /*--- detail ---*/
  .detail__link {
    width:90%;
  }
}
@media screen and (max-width:896px) {
  /*--- detail ---*/
   .detail__body {
    width:75%;
  }
  .detail__col {
    flex-direction:column;
    margin-bottom:60px;
  }
  .detail__items-inner {
    margin-bottom:40px;
  }
  .detail__img {
    width:100%;
    margin-bottom:60px;
  }
  .detail__items {
    width:80%;
    margin:0 auto;
  }
  .detail__link {
    width:70%;
    flex-direction:column;
  }
  .detail__link > a {
    width:100%;
  }
  .detail__link > a:nth-of-type(2) {
    margin-top:14px;
  }
}
@media screen and (max-width:786px) {
  /*--- web ---*/
  .web__body {
    width:80%;
  }
  /*--- result ---*/
  .result__body {
    width:80%;
  }
  /*--- detail ---*/
  .detail__body {
    width:80%;
  }
}
@media screen and (max-width:680px) {
  /*--- web ---*/
  .web__body {
    width:85%;
  }
  /*--- result ---*/
  .result__body {
    width:85%;
  }
  /*--- detail ---*/
  .detail__body {
    width:85%;
  }
  .detail__link {
    width:80%;
  }
}
@media screen and (max-width:480px) {
  /*--- about ---*/
  .about_ttl-sub {
    padding-bottom:20px;
  }
  .about_ttl-sub > h3 {
    font-size:1.4rem;
  }
  .about_ttl-sub > p {
    font-size:3.6rem;
  }
  /*--- web ---*/
  .web__body .ttl {
    margin-bottom:40px;
  }
  .web__top-img {
    width:100%;
    margin-bottom:20px;
  }
  .web__top-ttl {
    padding-top:30px;
  }
  .web__top-ttl > h3 {
    font-size:2rem;
    text-align:center;
  }
  .web__top-bg {
    width:90%;
    left:50%;
    transform:translate(-50%,0);
  }
  .web__top-txt > ul {
    font-size:1.4rem;
  }
  .web__top-txt > ul > li {
    line-height:1.6;
  }
  .web__top-txt > ul > li:nth-of-type(n+2) {
    margin-top:10px;
  }
  /*--- result ---*/
  .result {
    padding-bottom:50px;
  }
  .result__ttl {
    margin-bottom:30px;
  }
  .result__ttl > h2 {
    font-size:2rem;
  }
  .result__ttl > p {
    font-size:1.4rem;
  }
  .result__img {
    margin-bottom:30px;
  }
  .result__item > p {
    font-size:1.4rem;
  }
  .result__item > ul > li {
    width:49%;
    font-size:1.4rem;
  }
  .result__item > ul > li:nth-of-type(n+3) {
    margin-top:5px;
  }
  /*--- detail ---*/
  .detail {
    margin-bottom:0;
  }
  .detail .ttl {
    width:100%;
  }
  .detail .ttl > h2 {
    font-size:5rem;
  }
  .detail__items-inner {
    margin-bottom:30px;
  }
  .detail__items-img {
    width:48px;
  }
  .detail__item-txt {
    font-size:1.4rem;
  }
  .detail__item-txt br:nth-of-type(2) {
    display:block;
  }
  .detail__img {
    width:105%;
    margin-bottom:30px;
  }
  .detail__items {
    width:100%;
  }
  .detail__col {
    margin-bottom:30px;
  }
  .detail__link {
    width:100%;
  }
  .detail__link > a {
    height:80px;
    border-radius:8px;
  }
  .detail__link > a:nth-of-type(2) {
    margin-top:5px;
  }
  .detail__link > a > span {
    width:48px;
    height:48px;
    font-size:2rem;
  }
  .detail__link-col > p {
    font-size:1.8rem;
  }
}