@charset "utf-8";

.sub .key .largetext {
    font-size: 110px;
    font-family: "Lora", serif; /* フォントを変える場合はここを変えてください */
    position: absolute;
    bottom: 1vw;
    left: calc(((100vw - 1440px) / 2) + 590px);
}

main > section.sec.sec_lead {
    padding-bottom: 100px;
}

main > section.sec.sec_lead:after   {
    content: "";
    background-color: #fff;
    background-image: url(/common/images/sec_bg.png);
    background-position: center top;
    background-repeat: repeat;
    background-size: 98px auto;
    width: calc(50% - 38px - (124px / 2));
    height: 100px; 
    position: absolute;
    bottom: 0;
    left: 38px;
}

main > section.sec.sec_lead .inner  {
    background-color: #fff;
    position: relative;
}

main > section.sec.sec_lead .inner.bg_gray  {
    padding-top: 55px;
    padding-bottom: 55px;
}

main > section.sec.sec_lead .inner:not(.bg_gray):before,
main > section.sec.sec_lead .inner:not(.bg_gray):after   {
    content: "";
    position: absolute;
    top: 0;
    width: 1px;
    height: 100%;
    background-color: rgba(205, 205, 025, 0.5);
}

main > section.sec.sec_lead .inner:not(.bg_gray):before   {
    left: 62px;
}

main > section.sec.sec_lead .inner:not(.bg_gray):after   {
    right: 62px;
}

main > section.sec.sec_lead .inner .infoarea    {
    max-width: 1080px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

main > section.sec.sec_lead .inner .infoarea p  {
    line-height: 166.66%;
}

main > section.sec.sec_list {
    flex-direction: row-reverse;
    gap: 0 124px;
    align-items: flex-start;
}

main > section.sec.sec_list .seccol {
    width: calc((100% - 124px) / 2);
    position: relative;
    padding: 60px 0;
    background-color: #fff;
    margin-bottom: 100px;
}

main > section.sec.sec_list .seccol:nth-of-type(2n){
    top: 100px;
}

main > section.sec.sec_list .seccol  {
    background-image: url(/common/images/sec_bg.png);
    background-position: right top;
    background-repeat: no-repeat;
    background-size: 99px auto;
}

main > section.sec.sec_list .seccol:before   {
    content: "";
    position: absolute;
    top: 0;
    width: 1px;
    height: 100%;
    background-color: rgba(205, 205, 205, 0.5);
    left: 58px;
}

main > section.sec.sec_list .seccol .col_inner ul   {
    margin-left: 1.75em;
}

main > section.sec.sec_list .seccol .col_inner ul li  {
    padding-right: 65px;
}

main > section.sec.sec_list .seccol .col_inner ul li:not(:last-of-type) {
    margin-bottom: 0.25em;
}

main > section.sec.sec_list .seccol .col_inner ul li::marker {
  content: "・ ";
}


main > section.sec.sec_list .seccol.has_after .col_inner:after   {
    content: "";
    background-color: #fff;
    background-image: url(/common/images/sec_bg.png);
    background-position: center top;
    background-repeat: repeat;
    background-size: 98px auto;
    width: 100%;
    height: 100px; 
    position: absolute;
    bottom: -100px;
    left: 0;
}

.sec.service_nav    {
    gap: 0 124px;
    align-items: flex-start;
    padding-bottom: 100px;
}

.sec.service_nav .col   {
    width: calc((100% - 124px) / 2);
    position: relative;
}

.sec.service_nav .col a   {
    width: 100%;
    display: flex;
    width: 100%;
    height: 100px;
    align-items: center;
    justify-content: center;
    background-size: auto 18px;
    padding: 0 65px;
}

.sec.service_nav .col.nav_left a   {
    justify-content: flex-start;
    background-image: url(/common/images/arrow_l.png);
    background-repeat: no-repeat;
    background-position: left 20px center;
}

.sec.service_nav .col.nav_right a   {
    justify-content: flex-end;
    background-image: url(/common/images/arrow_r.png);
    background-repeat: no-repeat;
    background-position: right 20px center;
}

@media screen and (max-width: 1920px)   {
    .sub .key .largetext {
        font-size: 6.5vw;
        left: 40.5vw;
    }
}

@media screen and (max-width: 834px)    {
    .sub .key .largetext    {
        font-size: 16.29vw;
        left: 2.54vw;
        line-height: 1;
    }
    main > section.sec.sec_lead .inner .infoarea h3    {
        line-height: 150%;
    }
    main > section.sec.sec_lead .inner:not(.bg_gray):before {
        left: 5.08vw;
    }

    main > section.sec.sec_lead .inner:not(.bg_gray):after  {
        display: none;
    }

    main > section.sec.sec_lead {
        padding-bottom: 12.72vw;
    }

    main > section.sec.sec_lead:after   {
        background-size: 12.72vw auto;
        width: 79.64vw;
        height: 12.72vw;
    }
    
    main > section.sec.sec_list .seccol {
        width: 100%;
        margin-bottom: 7.63vw;
    }
    
    main > section.sec.sec_list .seccol:nth-of-type(2n) {
        top: auto;
    }
    main > section.sec.sec_list .seccol:before  {
        left: 5.08vw;
    }
    
    main > section.sec.sec_list .seccol  {
        background-size: 12.72vw auto;
    }
    
    main > section.sec.sec_list .seccol .col_inner ul   {
        margin-left: 6vw;
    }

    main > section.sec.sec_list .seccol .col_inner ul li    {
        padding-right: 5.09vw;
    }
    
    main > section.sec.sec_list .seccol.has_after .col_inner:after   {
        display: none;
    }
    
    .sec.service_nav    {
        flex-direction: column;
        gap: 2.54vw;
        padding-bottom: 12.72vw;
    }
    
    .sec.service_nav .col    {
        width: 100%;
    }
    
    .sec.service_nav .col a   {
        background-size: auto 4.58vw;
        padding: 0 5.08vw;
    }
    
    .sec.service_nav .col.nav_left a   {
        padding-left: 17.3vw;
    }

    .sec.service_nav .col.nav_right a   {
        padding-right: 17.3vw;
    }
    
    main > section.sec.sec_list .seccol.sp_has_after    {
        margin-bottom: 25.44vw;
    }

    main > section.sec.sec_list .seccol.sp_has_after .contentarea   {
        position: static;
    }

    main > section.sec.sec_list .seccol.sp_has_after .contentarea:after   {
        content: "";
        background-color: #fff;
        background-image: url(/common/images/sec_bg.png);
        background-position: center top;
        background-repeat: repeat;
        background-size: 12.72vw auto;
        width: 79.64vw;
        height: 12.72vw;
        position: absolute;
        bottom: -12.72vw;
        left: 0;
    }
}

