@charset "UTF-8";

.l-header__wrapper {
  padding: 10px 32px;
}
.overlay-wrap{padding-top:80px;}
@media (max-width: 1199px) {
  .overlay-wrap{padding-top:75px;}
}
@media (max-width: 991px) {
  .overlay-wrap{padding-top:73px;}
}
@media (max-width: 767px) {
  .overlay-wrap{padding-top:67px;}
}
@media (max-width: 575px) {
  .overlay-wrap{padding-top:54.23px;}
}

.c-button--inq {
  background: #CC023A;
}
.c-button--inq:hover {
  color: #CC023A;
  border: #CC023A 2px solid;
}
.c-button--inq .c-button__icon::after {
  filter: brightness(0) saturate(100%) invert(13%) sepia(93%) saturate(4916%) hue-rotate(337deg) brightness(79%) contrast(105%);;
}

/*-------------------------------------------------------------*/
/* cva */
.cva {
  background: #fff;
  color: #000;
}

/*-------------------------------------------------------------*/
/* main */

/* mv */
.mv {
  background: url('/ai-sol/img/bgi_mv.png') no-repeat left center /cover;
  aspect-ratio: 144 / 55;
}
.mv .container {
  height: 100%;
}
.mv .mv_box {
  justify-content: flex-start;
  padding: 0 0 9% 10%;
  height: 100%;
}
.mv .mv_box.mv_01 {
}
.mv .mv_box_text h1 {
  color: #00334D;
  font-size: 60px;
  font-weight: 900;
  text-align: left;
  text-shadow: 4px 4px 10px #FFF;
}
.mv .mv_box_text h1 span {
  display: block;
  color: #CC023A;
  font-size: 46.1538%;
  font-weight: 700;
  line-height: 2;
}
@media (max-width: 1399px) {
}
@media (max-width: 1199px) {
  .mv .mv_box_text h1 {
    font-size: 50px;
  }
}
@media (max-width: 991px) {
  .mv .mv_box_text h1 {
    font-size: 37px;
  }
}
@media (max-width: 767px) {
  .mv .mv_box_text h1 {
    font-size: 27px;
  }
}
@media (max-width: 575px) {
  .mv {
    aspect-ratio: 2 / 1;
  }
  .mv .mv_box_text h1 {
    font-size: 7vw;
  }
  .mv .mv_box_text h1 span {
    font-size: 4vw;
  }
}

/* news */
.news {
  padding: 40px 0;
  font-size: 18px;
  text-align: center;
}
.news_text {
}
.news_text h2 {
  margin-bottom: 16px;
  color: #CC023A;
  font-weight: bold;
}
.news_text p {
  margin-bottom: 10px;
}
.news_text a {
  color: #000;
  text-decoration: underline;
}
.news_text a:hover {
  opacity: .7;
  text-decoration: none;
}
@media (max-width: 1399px) {
}
@media (max-width: 1199px) {
}
@media (max-width: 991px) {
}
@media (max-width: 767px) {
  .news {
    font-size: 2.5vw;
  }
}
@media (max-width: 575px) {
}

/* lead */
.lead {
  padding: 80px 0;
  background: #000;
  color: #fff;
}
.lead .lead_text {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  margin: auto;
  padding-bottom: 140px;
  max-width: 1040px;
  background: url('/ai-sol/img/bgi_lead.png') no-repeat center bottom /contain;
}
.lead .lead_text > * {
  width: calc(50% - 10px);
  max-width: 500px;
}
.lead .lead_text figure {
  text-align: center;
}
.lead .lead_text figure img {
  max-width: 100%;
}
@media (max-width: 1399px) {
}
@media (max-width: 1199px) {
}
@media (max-width: 991px) {
}
@media (max-width: 767px) {
  .lead .lead_text {
    justify-content: center;
    padding-bottom: 10vw;
  }
  .lead .lead_text > * {
    width: 100%;
  }
}
@media (max-width: 575px) {
}

/* sec01～sec07 */
.sec01 h2, .sec02 h2, .sec03 h2, .sec04 h2, .sec05 h2, .sec06 h2, .sec07 h2, .related h2 {
  font-size: 42px;
  line-height: 1;
}
.sec01 h2::after ,.sec02 h2::after ,.sec03 h2::after ,.sec04 h2::after ,.sec05 h2::after ,.sec06 h2::after ,.sec07 h2::after {
  content: none;
}
.sec01 h2 span ,.sec02 h2 span ,.sec03 h2 span ,.sec04 h2 span ,.sec05 h2 span ,.sec06 h2 span ,.sec07 h2 span {
  display: block;
  margin: 0 auto;
  color: #CC023A;
  font-size: 20px;
}
@media (max-width: 767px) {
  .sec01 h2, .sec02 h2, .sec03 h2, .sec04 h2, .sec05 h2, .sec06 h2, .sec07 h2, .related h2 {
    font-size: 4vw;
  }
  .sec01 h2 span ,.sec02 h2 span ,.sec03 h2 span ,.sec04 h2 span ,.sec05 h2 span ,.sec06 h2 span ,.sec07 h2 span {
    font-size: 2.5vw;
  }
}

/* sec01 */
.sec01 {
  padding: 80px 0;
  background: #000 url('/ai-sol/img/bgi_solution.png') no-repeat left center /cover;
}
.sec01 h2 {
  color: #fff;
}
.sec01 .sec01_lead {
  margin-bottom: 56px;
  color: #fff;
  font-size: 20px;
  text-align: center;
}
.sec01 ul {
}
.sec01 ul li {
  margin-bottom: 32px;
  background: #fff;
}
.sec01 ul li:last-of-type {
  margin-bottom: 0;
}
.sec01 ul li a {
  display: flex;
  flex-wrap: wrap;
}
.sec01 ul li a:hover {
  opacity: .7;
}
.sec01 ul li h3 {
  padding: 8px 16px;
  width: 100%;
  background: #167B85;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
}
.sec01 ul li figure {
  width: 300px;
  text-align: center;
}
.sec01 ul li figure img {
  max-width: 100%;
}
.sec01 ul li div {
  position: relative;
  padding: 32px;
  width: calc(100% - 300px);
  color: #000;
}
.sec01 ul li div h4 {
  margin-bottom: 16px;
  font-size: 20px;
  font-weight: bold;
}
.sec01 ul li div .sec01_detail {
  position: absolute;
  right: 20px;
  bottom: 20px;
}
.sec01 ul li div .sec01_detail strong {
  position: relative;
  padding-right: 20px;
}
.sec01 ul li div .sec01_detail strong::before ,
.sec01 ul li div .sec01_detail strong::after {
  content: "";
  position: absolute;
  top: calc(50% + 1.5px);
  right: 0;
  width: 8px;
  height: 1px;
  border-radius: 9999px;
  background-color: #000000;
  transform-origin: calc(100% - 0.5px) 50%;
}
.sec01 ul li div .sec01_detail strong::before {
  transform: rotate(45deg);
}
.sec01 ul li div .sec01_detail strong::after {
  transform: rotate(-45deg);
}
@media (max-width: 1499px) {
}
@media (max-width: 1399px) {
}
@media (max-width: 1199px) {
  .sec01 ul li div {
    padding: 20px;
  }
}
@media (max-width: 991px) {
  .sec01 ul li figure {
    width: 100%;
  }
  .sec01 ul li div {
    padding: 20px 20px 60px;
    width: 100%;
  }
}
@media (max-width: 767px) {
  .sec01 .sec01_lead {
    font-size: 3vw;
  }
  .sec01 ul li h3 {
    font-size: 4vw;
  }
  .sec01 ul li div {
    padding: 5vw 5vw 10vw;
  }
  .sec01 ul li div h4 {
    font-size: 4vw;
  }
  .sec01 ul li div .sec01_detail {
    right: 8vw;
    bottom: 3vw;
  }
}
@media (max-width: 575px) {
}

/* sec02 */
.sec02 {
  background: #EBECF0;
}
.sec02 .sec02_lead {
  margin-bottom: 56px;
  font-size: 20px;
  text-align: center;
}
.sec02_list {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 24px;
  margin-top: 56px;
  text-align: center;
}
.sec02_list li {
  width: calc((100% - 48px) / 3);
}
.sec02_list li a {
  position: relative;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding: 24px 24px 64px;
  width: 100%;
  height: 100%;
  aspect-ratio: 32 / 28;
  min-height: 280px;
  background: #999 url(/ai-sol/img/bgi_sec02_01.png) no-repeat center top/cover;
  color: #fff;
}
.sec02_list a.bgi01 {
  background-image: url(/ai-sol/img/bgi_sec02_01.png);
}
.sec02_list a.bgi02 {
  background-image: url(/ai-sol/img/bgi_sec02_02.png);
}
.sec02_list a.bgi03 {
  background-image: url(/ai-sol/img/bgi_sec02_03.png);
}
.sec02_list a.bgi04 {
  background-image: url(/ai-sol/img/bgi_sec02_04.png);
}
.sec02_list a.bgi05 {
  background-image: url(/ai-sol/img/bgi_sec02_05.png);
}
.sec02_list a.bgi06 {
  background-image: url(/ai-sol/img/bgi_sec02_06.png);
}
.sec02_list a.bgi07 {
  background-image: url(/ai-sol/img/bgi_sec02_07.png);
}
.sec02_list a.bgi08 {
  background-image: url(/ai-sol/img/bgi_sec02_08.png);
}
.sec02_list a.bgi09 {
  background-image: url(/ai-sol/img/bgi_sec02_09.png);
}
.sec02_list a.bgi10 {
  background-image: url(/ai-sol/img/bgi_sec02_10.png);
}
.sec02_list a:hover {
  opacity: .7;
}
.sec02_list li h3 {
  margin-bottom: 12px;
  width: 100%;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.3;
}
.sec02_list li h3 small {
  display: block;
  font-size: 70%;
  font-weight: normal;
  line-height: 1.3;
}
.sec02_detail {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  background: #000;
  line-height: 40px;
}
.sec02_detail span {
  position: relative;
  padding-right: 20px;
  font-weight: bold;
}
.sec02_detail span::before,
.sec02_detail span::after {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  right: 0;
  width: 10px;
  height: 1px;
  border-radius: 9999px;
  background-color: #fff;
  transform-origin: calc(100% - 0.5px) 50%;
}
.sec02_detail span::before {
  transform: rotate(45deg);
}
.sec02_detail span::after {
  transform: rotate(-45deg);
}

@media (max-width: 1399px) {
}
@media (max-width: 1199px) {
  .sec02_list li {
    width: calc((100% - 24px) / 2);
  }
}
@media (max-width: 991px) {
}
@media (max-width: 767px) {
  .sec02 .sec02_lead {
    font-size: 3vw;
  }
  .sec02_list {
    gap: 15px;
    margin-top: 28px;
  }
  .sec02_list li {
    width: 100%;
  }
  .sec02_list a {
    padding: 15px 15px 55px;
    width: 100%;
  }
  .sec02_list li h3 {
    font-size: 4.3vw;
  }
}
@media (max-width: 575px) {
}

/* sec03 */
.sec03_list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 25px;
}
.sec03_list li {
}
.sec03_list li h3 {
  padding: 16px 24px;
  background: #000;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  border-top: 3px #CC023A solid;
}
@media (max-width: 1399px) {
}
@media (max-width: 1199px) {
}
@media (max-width: 991px) {
}
@media (max-width: 767px) {
  .sec03_list li h3 {
    font-size: 3.5vw;
  }
}
@media (max-width: 575px) {
}

/* bnr */
.bnr {
  padding: 56px 0;
  background: #000;
  text-align: center;
}
.bnr img {
  max-width: 100%;
}
@media (max-width: 1399px) {
}
@media (max-width: 1199px) {
}
@media (max-width: 991px) {
}
@media (max-width: 767px) {
  .bnr {
    padding: 30px 0;
  }
}
@media (max-width: 575px) {
}
