@charset "utf-8";

/* ++++++++++++++++++++++++++++++++++++++++++++++++ */
@media screen and (min-width: 1025px), print {
/* ++++++++++++++++++++++++++++++++++++++++++++++++ */
/*common================================*/

section h2{
    font-size: 36px;
    font-weight: bold;
    color: #3A3A39;
    border-bottom: 3px solid #A0042F;
    text-align: center;
    padding-bottom: 26px;
    letter-spacing: 0.083em;
}
section h3{
    font-size: 18px;
    font-weight: 500;
    line-height: 1.91;
    margin: 40px 0 0 0;
    letter-spacing: 0.057em;
}
section:not(:first-child){
    margin: 200px auto 0;
    color: #3A3A39;
}
section .pc{display: block;}
section .sp{display: none;}
section .inner{
    width: 1132px;
    margin: 0px auto 100px;
    letter-spacing: 0.078em;
}
section .inner img{
    object-fit: contain;
    width: 100%;
}
section .inner .red{
    color: var(--color-red);
    font-weight: bold;
}
section .inner .kome{
    font-size: 14px;
    text-align: left;
    line-height: 1.7;
    margin: 0 0 10px 0;
}
section .inner a{
    transition : .5s;
}
section .inner a:hover{
    transition : .5s;
}
.anchor-target {
  scroll-margin-top: 230px; 
}
/*================================*/
section.keyvisual {
  /*position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;*/
  width: 100%;
  box-sizing: border-box;
  height: 541px;
  background-image: url(../images/kv_bg.png);
  background-repeat: repeat-x;
}
section.keyvisual>.inner {
    width: 100%;
    max-width: 1417px;
    height: 493px;
    background: url(../images/kv_img_pc.png) no-repeat 0 0;
    background-size: contain;
    display: flex;
    justify-content: center;
    align-items: center;
    background-position: 0px 34px;
}
/*----------------*/

/*================================*/
section.introduction {
    margin: 50px 0 0 0;
}
section.introduction>.inner {
}
section.introduction>.inner .illust{
}
section.introduction>.inner .illust ul{
    width: 1132px;
    display: flex;
    justify-content: space-between;
    gap: 24px;
}
section.introduction>.inner .illust ul li{
    width: 21%;
    margin: 71px auto 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 25px;
}
section.introduction>.inner .illust ul li:nth-child(2) .box-img img{
    width: 260px;
    height: 200px;
    margin: -14px 0 0 -26px;
}
section.introduction>.inner .illust ul li .box-img img{
   display: inline-block;
   width: 181px;
   height: 175px;
   margin: 0 0 11px 0;
   object-fit: contain;
}
section.introduction>.inner .illust ul li p{
    width: 168px;
    height: 84px;
    background: url(../images/bubbles_bg.png) no-repeat 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
section.introduction>.inner .illust ul li span{
    color: var(--color-white);
    font-size: 22px;
    font-weight: bold;
    margin: 0 0 11px 0;
    letter-spacing: 0.18em;
}
section.introduction>.inner .illust ul li .box-comment{
    font-size: 18px;
    font-weight: 500;
    line-height: 1.7;
    text-align: center;
    letter-spacing: 0.05em;
    white-space: nowrap;
}
section.introduction>.inner .introduction-ttl{

}
section.introduction>.inner .introduction-circle{
    background-color: var(--color-red);
    width: 129px;
    height: 129px;
    display: flex;
    justify-content: center;
    align-items: center;
}
section.introduction>.inner .introduction-circle span{
    font-size: 17px;
    color: var(--color-white);
    font-weight: bold;
}
/*----------------*/

/*================================*/
section.service {
}
section.service>.inner {
}
section.service .service-ttl{
    font-size: 22px;
    font-weight: bold;
    text-align: left;
    margin: 92px 0 -30px 0;
    letter-spacing: 0.08em;
}
section.service>.inner .step ul{
    width: 1132px;
    display: flex;
    justify-content: space-between;
    margin: 79px 0 0 0;
}
section.service>.inner .step ul li{
    width: 21%;
    margin: -5px 0;
    flex-grow: 1;
    display: flex;
    align-items: center;
    flex-direction: column;
    position: relative;
}
section.service>.inner .step ul li:not(:last-child):before{
    content: "";
    display: inline-block;
    width: 19px;
    height: 19px;
    background-image: url(../images/service-polygon_pc.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    position: absolute;
    background-size: contain;
    right: 3%;
    top: 6px; 
}
section.service>.inner .step ul li:nth-child(3):before{
    right: -19%;
}

section.service>.inner .step ul li .box-img{
   display: inline-block;
   width: 67%;
   margin: 54px 0 11px 0;
}
section.service>.inner .step ul li:nth-child(1) .box-img{
    margin: 55px 0 0 -81px;
}
section.service>.inner .step ul li:nth-child(2) .box-img{
    width: 88%;
    margin: 55px 0 0 -9px;
}
section.service>.inner .step ul li:nth-child(3) .box-img{
    width: 84%;
    margin: 50px 0 0 78px;
}
section.service>.inner .step ul li:nth-child(4) .box-img{
    width: 60%;
    margin: 75px 0 0 77px;
}
section.service>.inner .step ul li p{
    font-size: 20px;
    letter-spacing: 0.05em;
    font-weight: bold;
}
section.service>.inner .step ul li:nth-child(1) p{
    margin: 0 0 0 -65px;
}
section.service>.inner .step ul li:nth-child(2) p{
    margin: 0 0 0 -16px;
}
section.service>.inner .step ul li:nth-child(3) p{
    margin: 0 0 0 52px;
}
section.service>.inner .step ul li:nth-child(4) p{
    margin: 0 0 0 88px;
}
section.service>.inner .step ul li .box-comment{
    font-size: 18px;
    font-weight: 500;
    color: #3A3A39;
    line-height: 1.7;
    letter-spacing: 0.05em;
    text-align: left;
}
section.service>.inner .step ul li:nth-child(1) .box-comment{
    margin: 94px 0 0 -71px;
}
section.service>.inner .step ul li:nth-child(2) .box-comment{
    margin: 79px 0 0 -3px;
}
section.service>.inner .step ul li:nth-child(3) .box-comment{
    margin: 77px 0 0 42px;
}
section.service>.inner .step ul li:nth-child(4) .box-comment{
    margin: 83px 0 0 51px;
}
section.service>.inner .step ul li .box-comment span{
    font-size: 12px;
    display: block;
    letter-spacing: 0.025em;
}
section.service>.inner .service-txt{
    font-size: 16px;
    font-weight: 500;
    line-height: 1.7;
    margin: 51px 0 0 0;
    display: block;
}
section.service>.inner .service-solution{
    border: 2px solid var(--color-gray-01);
    border-radius: 20px;
    margin: 93px 0 0 0;
    padding-bottom: 11px;
}
section.service>.inner .service-solution .service-solution-ttl{
    background-color: var(--color-red);
    border-radius: 40px;
    display: inline-block;
    padding: 18px 55px;
    margin: -42px 0 0 361px;
}
section.service>.inner .service-solution .service-solution-ttl span{
    color: var(--color-white);
    font-size: 24px;
    font-weight: bold;
    letter-spacing: 0.06em;
    font-weight: 500;
}
section.service>.inner .service-solution ul{
    display: flex;
    justify-content: space-between;
}
section.service>.inner .service-solution ul li{
    flex: 2;
    margin: 57px 0 0px 60px;
}
section.service>.inner .service-solution ul li:first-of-type{
    border-right: 2px solid var(--color-gray-01);
}

section.service>.inner .service-solution ul li:nth-child(1) .box-img{
    background: url(../images/solution_img01.png) no-repeat 0 0;
    width: 347px;
    height: 160px;
    background-size: contain;
}
section.service>.inner .service-solution ul li:nth-child(2) .box-img{
    background: url(../images/solution_img02.png) no-repeat 0 0;
    width: 342px;
    height: 173px;
    margin: -10px 0 0 10px;
    background-size: contain;
}
section.service>.inner .service-solution .service-solution-comment{
    display: flex;
    justify-content: center;
    position: relative;
    margin: 32px 0 112px -59px;
}
section.service>.inner .service-solution .service-solution-comment:after{
    content: "";
    display: inline-block;
    width: 39px;
    height: 31px;
    background-image: url(../images/solution-comment-polygon.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    position: absolute;
    background-size: contain;
    right: 191px;
    top: 210px;
}
section.service>.inner .service-solution .left-box{
    width: 104px;
    height: 100px;
    border-radius: 100%;
    background-color: #F1F0F0;
    display: flex;
    justify-content: center;
    align-items: center;
}
section.service>.inner .service-solution .left-box span{
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.19em;
}
section.service>.inner .service-solution .right-box{
   margin: -2px 0 0 29px;
}
section.service>.inner .service-solution .right-box span{
   font-size: 20px;
   font-weight: bold;
   line-height: 1.51;
   letter-spacing: 0.06em;
}
section.service>.inner .service-solution .right-box p{
   width: 360px;
   font-size: 18px;
   line-height: 1.61;
   font-weight: 500;
   margin: 16px 0 0 0;
}
section.service>.inner .service-solution .bottom .right-box p, section.service>.inner .after-bottom .right-box p{ 
   width: 310px;
}
section.service>.inner .service-solution .after-comment{
    display: flex;
    justify-content: center;
    margin: 0 0 0 -43px;
}
section.service>.inner .service-solution .bottom{
    margin: 32px 0 139px -59px;
}
section.service>.inner .service-solution .after-bottom{
    margin: 0 0 0 -52px;
}
section.service>.inner .service-solution .after-comment .left-box{
    background-color: var(--color-red);
    color: var(--color-white);
}
section.service>.inner .service-solution .after-comment .left-box span{
    letter-spacing: 0.06em;
}
section.service>.inner .service-solution .after-comment .right-box span{
   font-size: 26px;
   line-height: 1.7;
   margin: 9px 0 0 0;
   display: block;
}
section.service>.inner .service-solution .service-solution-answer{
    background-color: #E5E5E5;
    border-radius: 20px;
    text-align: center;
    display: table;
    margin: 53px auto 37px;
    padding: 30px 150px;
}
section.service>.inner .service-solution .service-solution-answer span{
   font-size: 28px;
   font-weight: bold;
   line-height: 1.7;
   letter-spacing: 0.13em;
}
section.service>.inner .kome{
    text-align: right;
    margin: 0 18px 10px 0;
}
/*----------------*/

/*================================*/
section.function {
}
section.function>.inner {
}
section.function>.inner ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 55px 0 0 0;
}
section.function>.inner ul li{
    width: 308px;
    height: 292px;
    border: 1px solid #D9D9D9;
    border-radius: 10px;
    margin: 0 27px 27px 0;
}

section.function>.inner ul li:nth-of-type(3n){
    margin-right: 0px;
}
section.function>.inner ul li .card-ttl{
    background-color: var(--color-red);
    color: var(--color-white);
    padding: 27px 0px;
    text-align: center;
    border-radius: 10px 10px 0px 0px;
}
section.function>.inner ul li .card-ttl span{
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.062em;
}
section.function>.inner ul li .card-txt{
    padding: 28px;
}
section.function>.inner ul li .card-txt span{
    font-size: 16px;
    font-weight: 500;
    line-height: 1.7;
    letter-spacing: 0.09em;
}
section.function>.inner .function-mobile{
    width: 978px;
    background-color: #F6F6F6;
    border-radius: 10px;
    display: flex;
    margin: 20px auto 0;
    padding: 30px;
    justify-content: center;
}
section.function>.inner .function-mobile .mobile-img{
    background: url(../images/function-mobile_logo.png) no-repeat 0 0;
    width: 366px;
    height: 75px;
    background-size: contain;
    margin: 3px 0px 0 0;
}

section.function>.inner .function-mobile p{
    width: 490px;
    font-size: 16px;
    line-height: 1.7;
    letter-spacing: 0.10em;
}
/*----------------*/

/*================================*/
section.method {

}
section.method>.inner {
}
section.method>.inner .method-ttl {
    font-size: 24px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 26px 0 11px -123px;
    gap: 22px;
    letter-spacing: 0.10em;
}
section.method>.inner .method-ttl .method-circle{
    background-color: var(--color-red);
    width: 129px;
    height: 129px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 100%;
    margin: 9px 0 16px 0;
    letter-spacing: 0.022em;
}
section.method>.inner .method-ttl .method-circle span{
    font-size: 18px;
    font-weight: bold;
    color: var(--color-white);
    text-align: center;
    line-height: 1.5;
}
section.method>.inner ul{
    display: flex;
}
section.method>.inner ul li{
    width: 556px;
    border: 1px solid #D9D9D9;
    border-radius: 20px;
    flex: 1;
    padding: 28px 30px 5px 30px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
section.method>.inner ul li:first-of-type{
    margin: 0 22px 0 0;
}
section.method>.inner ul li span{
    font-size: 28px;
    font-weight: bold;
    text-align: center;
    margin: 0 0 15px 0;
    letter-spacing: 0.08em;
}
section.method>.inner ul li p{
    font-size: 16px;
    line-height: 1.7;
    margin: 0 0 23px 0;
}
section.method>.inner ul li .box-img img{
    width: 521px;
    height: 160px;
    object-fit: contain;
}

/*----------------*/

/*================================*/
section.application {
}
section.application>.inner a:hover{
    opacity: 0.6;
}
section.application>.inner ul{
    margin: 63px 0 19px 0;
    display: flex;
}
section.application>.inner ul li{
    border: 1px solid var(--color-gray-01);
    border-radius: 20px;
    padding: 27px 35px;
}
section.application>.inner ul li:nth-child(1){
    width: 460px;
    height: 438px;
    margin: 0 19px 0 0;
}
section.application>.inner ul li:nth-child(2){
    width: 652px;
    height: 438px;
}
section.application>.inner ul li .application-ttl, section.application>.inner .application-card span{
    font-size: 24px;
    text-align: center;
    display: block;
    margin: 0 0 17px 0;
    letter-spacing: 0.11em;
}
section.application>.inner ul li .txt-box{
    display: flex;
    justify-content: space-between;
}
section.application>.inner ul li .txt-box .txt-box-left{
    margin: 0 34px 0 0;
}
section.application>.inner ul li .txt-box .txt{
    font-size: 18px;
    line-height: 1.51;
    padding-right: 10px;
    letter-spacing: 0.09em;
}
section.application>.inner ul li .box-img-left img{
    width: 175px;
    height: 235px;

}
section.application>.inner ul li .txt-box .tag{
    width: 274px;
    height: 114px;
    background-color: #E4E3E3;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 22px;
    margin: 13px 0 13px 0;
    gap: 22px;
}
section.application>.inner ul li .txt-box .tag .qr-img{
    width: 76px;
}
section.application>.inner .application-card{
    width: 100%;
    border: 1px solid var(--color-gray-01);
    border-radius: 10px;
    padding: 28px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 14px;
}
section.application>.inner .application-caution{
    font-size: 12px;
    font-weight: 300;
    line-height: 1.73;
    margin-bottom: 51px;
    letter-spacing: 0.09em;
}
section.application>.inner .transportation-id{
    display: flex;
    justify-content: center;
    gap: 58px;
}

section.application>.inner .transportation-id .transportation-id-left a, section.application>.inner .transportation-id .transportation-id-right a{
    width: 500px;
    display: inline-block;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding: 38px 12px 30px;
}

section.application>.inner .transportation-id .transportation-id-left{
    background-color: #D3E5CB;
    border-radius: 10px;
    position: relative;
}
section.application>.inner .transportation-id .transportation-id-right{
    background-color: #FBE1EC;
    border-radius: 10px;
    position: relative;
}
section.application>.inner .transportation-id .transportation-id-left .box-img{
    width: 309px;
    margin: 8px 0 39px 0;
}
section.application>.inner .transportation-id .transportation-id-right .box-img{
    width: 190px;
    margin: -10px 0 9px 0;
}
section.application>.inner .transportation-id .transportation-id-left:after, section.application>.inner .transportation-id .transportation-id-right:after{
    content: "";
    display: inline-block;
    width: 36px;
    height: 36px;
    background-image: url(../images/transportation-id-icon.svg);
    background-position: center;
    position: absolute;
    background-size: contain;
    right: 20px;
    bottom: 20px;
}
section.application>.inner .transportation-id span{
    font-size: 16px;
    text-align: center;
    line-height: 1.7;
}
/*----------------*/

/*================================*/
section.list {
    margin: 0 0 134px 0;
}
section.list>.inner {
}
section.list>.inner ul{
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: flex-start;
    margin: 50px 0 0 0;
}
section.list>.inner ul li{
    width: 362px;
    height: 154px;
    border: 1px solid var(--color-gray-01);
    border-radius: 10px;
    display: flex;
    flex-wrap: inherit;
    justify-content: center;
    gap: 18px;

}
section.list>.inner ul li a{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding: 33px 0 18px;
}
section.list>.inner ul li a:hover{
    opacity: 0.6;
}
section.list>.inner ul li:nth-child(1) .box-img img{
    width: 58%;
    margin: -6px 0 0px -8px;
}
section.list>.inner ul li:nth-child(2) .box-img img{
    width: 69%;
    margin: 2px 0 9px -4px;
}
section.list>.inner ul li:nth-child(3) .box-img img{
    width: 49%;
    margin: -24px 0 -20px -8px;
}
section.list>.inner ul li:nth-child(4) .box-img img{
    width: 87%;
    margin: -5px 0 2px 12px;
}
section.list>.inner ul li:nth-child(5) .box-img img{
    width: 47%;
    margin: -5px 0 4px -17px;
}
section.list>.inner ul li:nth-child(6) .box-img img{
    width: 45%;
    margin: -12px 0 0 -4px;
}
section.list>.inner ul li:nth-child(7) .box-img img{
    width: 57%;
    margin: 3px 0 0 0px;
}
section.list>.inner ul li:nth-child(8) .box-img img{
    width: 64%;
    margin: -10px 0 8px -26px;
}

section.list>.inner ul li .box-img{
    width: 100%;
    height: 80px;
    text-align: center;
}
section.list>.inner ul li span{
    font-size: 16px;
    text-align: center;
    line-height: 1.4;
}
section.list>.inner ul li:nth-child(3) span, section.list>.inner ul li:nth-child(6) span{
    margin: -14px 0 0 0;
}
/*----------------*/



/* ++++++++++++++++++++++++++++++++++++++++++++++++ */
} /* end of media query */
/* ++++++++++++++++++++++++++++++++++++++++++++++++ */
