/*共通*/
body {
    font-size: 16px;
}

/*------------------会社案内(pc)------------------*/

.br-1200 {
    display: none;
}

.company-nav-sp {
    display: none;
}

.company-nav a:nth-of-type(1) {
    color: #00428B;
}

.company-nav span {
    display: inline-block;
    border-bottom: solid 1px #00428B;
}

.company-title h2:nth-child(2) {
    display: none;
}

.company-title h2 {
    color: #00428B;
    font-size: 120px;
    font-style: italic;
    font-weight: bold;
    font-family: 'Crimson Text', serif;
}

.company-title h2 span {
    font-size: 24px;
    font-family: 'Noto Sans JP', sans-serif;
    padding: 0 5px;
}

.company-title h2 span:nth-of-type(2) {
    color: #000;
}

.company h3,
.company h4,
.company h5 {
    font-weight: bold;
    margin-top: 24px;
}

.company h3 {
    font-size: 48px;
    color: #00428B;
    margin-top: 140px;
}

.company h3>span {
    font-family: 'Crimson Text', serif;
}

.company h3::before {
    content: "";
    border-left: 6px solid #DEEEFF;
    margin-right: 3px;
}


.company h3:nth-of-type(1) {
    font-family: 'Crimson Text', serif;
    margin-top: 40px;
}


.company h4 {
    font-size: 24px;

}

.company h5 {
    font-size: 20px;
}

.company p {
    font-size: 16px;
    margin-top: 24px;
}

.border {
    border-bottom: 1px solid #E7E7E7;
}

table {
    margin: 0 auto;
}

table tr {
    text-align: left;
    vertical-align: middle;
    border-bottom: 1px solid #E7E7E7;
    height: 74px;
}

table th {
    color: #aaa;
    padding-right: 30px;
    padding: 20px 150px 20px 0;

}

table td,
table td span {
    padding: 20px 0;
}


table th,
table td {
    vertical-align: middle;
}

/*------------------会社案内(sp)------------------*/

@media screen and (max-width:1200px) {

    .br-1200 {
        display: block;
    }

    .company-nav {
        margin-top: 30px;
    }

    .company-title h2:nth-child(1) {
        display: none;
    }

    .company-title h2:nth-child(2) {
        display: block;
        margin-top: 40px;
        line-height: 50px;
        font-size: 68px;
    }

    .company h3 {
        font-size: 32px;
        margin-top: 80px;
    }

    .company h4 {
        font-size: 20px;
    }

    .company p {
        font-size: 14px;
        margin-top: 15px;
    }

    table br {
        display: block;
    }

    table span {
        display: none;
    }

    table tr {
        height: 55px;
    }


    table th {
        font-size: 14px;
        width: 80px;
        padding: 10px 50px 10px 0;
    }

    table td {
        font-size: 14px;
        padding: 10px 0;
    }

}

/*------------------サービス(㍶)------------------*/

.service-nav span {
    display: inline-block;
    border-bottom: solid 1px #00428B;
}

.service-nav a:nth-of-type(1) {
    color: #00428B;
}

.service-title h2 {
    color: #00428B;
    font-size: 120px;
    font-style: italic;
    font-weight: bold;
    font-family: 'Crimson Text', serif;
    margin-top: 50px;
}

.service-title h2 span {
    font-size: 24px;
    font-family: 'Noto Sans JP', sans-serif;
    padding: 0 10px;
}



.service-title h2 span:nth-of-type(2) {
    color: #000;
}

.service-title h2:nth-child(2) {
    display: none;
}

.service-form-sp {
    display: none;
    position: relative;
}

.service-form {
    position: relative;
    background-color: #F2F8FF;
    border-radius: 20px 20px;
    text-align: center;
    padding: 60px 0;
    margin-top: 120px;
}

.service-form h3 {
    font-weight: bold;
    font-size: 32px;
}

.service-form p {
    font-size: 20px;
    margin-top: 30px;
    line-height: 50px;
}

.service-form p span {
    font-weight: bold;
    font-size: 32px;
    color: #00428B;
}

.service-form img {
    width: 1121px;
}

.arrow-up-service{
    right: 42%;
    bottom: 22%;
    position: absolute;
    display: flex;
    align-items: center;
}

.arrow-up-service > a{
    text-decoration: underline;
    font-weight: bolder;
    font-size: 0.8rem;
}

.arrow-up-service > img{
    width: 20px !important;
}

.arrow-up-service-sp{
    right: 2%;
    bottom: 1%;
    position: absolute;
    display: flex;
    align-items: center;
}

.arrow-up-service-sp > a{
    text-decoration: underline;
    font-weight: bolder;
    font-size: 0.8rem;
}

.arrow-up-service-sp > img{
    width: 20px !important;
}

.service-list {
    display: flex;
    position: relative;
    justify-content: space-around;
    margin: 200px 0 120px;
    gap: 3rem;
}

.service-list::before {
    content: "Service Line-up";
    font-size: 140px;
    position: absolute;
    top: -160px;
    font-family: 'Crimson Text', serif;
    font-weight: bold;
    color: #DEEEFF;
    z-index: -999;
}

.service-list div:nth-of-type(1) {
    content: "";
    position: relative;
    color: #333333;
    font-size: 30px;
    width: 360px;
    height: 450px;
    border-radius: 15px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.13);
    overflow: hidden;
}

.service-list div:nth-of-type(1):after {
    content: "";
    position: absolute;
    background-color: #E83E3E;
    z-index: -1;
    width: 434px;
    height: 190px;
    top: -40px;
    left: -30px;
    border-radius: 48%;
    z-index: -2;
}

.service-list div:nth-of-type(1):before {
    content: "01";
    position: absolute;
    opacity: 0.2;
    top: -30px;
    left: 140px;
    font-size: 80px;
    font-family: 'Crimson Text', serif;
    font-weight: bold;
    z-index: -1;
    color: #fff;
}

.service-list div:nth-of-type(2) {
    content: "";
    position: relative;
    color: #333333;
    font-size: 30px;
    width: 360px;
    height: 450px;
    border-radius: 15px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.13);
    overflow: hidden;
}

.service-list div:nth-of-type(2):after {
    content: "";
    position: absolute;
    background-color: #FFE114;
    z-index: -1;
    width: 434px;
    height: 190px;
    top: -40px;
    left: -30px;
    border-radius: 48%;
    z-index: -2;
}

.service-list div:nth-of-type(2):before {
    content: "02";
    position: absolute;
    opacity: 0.2;
    top: -30px;
    left: 140px;
    font-size: 80px;
    font-family: 'Crimson Text', serif;
    font-weight: bold;
    z-index: -1;
    color: #fff;
}

.service-list div:nth-of-type(3) {
    content: "";
    position: relative;
    color: #333333;
    font-size: 30px;
    width: 360px;
    height: 450px;
    border-radius: 15px;
    box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.13);
    overflow: hidden;
}

.service-list div:nth-of-type(3):after {
    content: "";
    position: absolute;
    background-color: #00A472;
    z-index: -1;
    width: 434px;
    height: 190px;
    top: -40px;
    left: -30px;
    border-radius: 48%;
    z-index: -2;
}

.service-list div:nth-of-type(3):before {
    content: "03";
    position: absolute;
    opacity: 0.2;
    top: -30px;
    left: 140px;
    font-size: 80px;
    font-family: 'Crimson Text', serif;
    font-weight: bold;
    z-index: -1;
    color: #fff;
}

.service-list p {
    font-size: 16px;
    width: 90%;
    margin: 0 auto;
    
}

.service-list a {
    font-size: 16px;
    color: #00428B;
    float: right;
    margin: 20px 15px 0 0;
}

.service-list a span {
    border-bottom: #00428B solid 1px;
}

.service-list h4 {
    font-size: 28px;
    height: 40%;
    font-weight: bold;
    display: flex;
    align-items: center;
    flex-direction: column;
    text-align: center;
    line-height: 35px;
    justify-content: center;
    color: #fff;
    z-index: 999;
}

.service-list h4 span {
    font-size: 19px;
    font-weight: bold;
    letter-spacing: 0px;

}

#feature-main h2 {
    color: #00428B;
    font-size: 120px;
    font-style: italic;
    font-weight: bold;
    font-family: 'Crimson Text', serif;
}

#feature-main h2 span {
    font-size: 24px;
    font-family: 'Noto Sans JP', sans-serif;
    padding: 0 10px;
}

#feature-main h2 span:nth-of-type(2) {
    color: #000;

}

/*------------------サービス(sp)------------------*/

@media screen and (max-width:1200px) {

    .service-nav {
        margin-top: 30px;
    }

    .service-title h2:nth-child(1) {
        display: none;
    }

    .service-title h2:nth-child(2) {
        display: block;
        margin-top: 60px;
        line-height: 50px;
        font-size: 68px;
    }

    .service h3 {
        font-size: 32px;
        margin-top: 80px;
    }

    .service-form {
        display: none;
        background-color: #F2F8FF;
        border-radius: 20px 20px;
    }

    .service-form-sp {
        display: block;
        margin: 60px auto 0;
        background-color: #F2F8FF;
        border-radius: 20px 20px;
        padding: 30px 0 0;
    }

    .service-form-sp h3 {
        font-size: 20px;
        text-align: center;
        font-weight: bold;
    }

    .service-form-sp p {
        font-size: 14px;
        line-height: 30px;
        width: 90%;
        margin: 30px auto;
        text-align: center;
    }

    .service-form-sp p span {
        font-size: 18px;
        font-weight: bold;
        color: #00428B;
    }

    .service-form-sp img {
        display: block;
        margin: 0 auto;
    }

    .service-list {
        flex-direction: column;
        align-items: center;
        margin: 180px 0 120px;
    }

    .service-list::before {
        top: -100px;
        font-size: 90px;
    }

    .service-list div {
        margin-bottom: 40px;
    }
}

@media screen and (max-width: 768px) {
    .service-list {
        margin: 140px 0 120px;
    }

    .service-list::before {
        top: -70px;
        font-size: 60px;
    }
}


@media screen and (max-width: 498px) {
    .service-list {
        margin: 120px 0 120px;
    }

    .service-list::before {
        top: -60px;
        font-size: 44px;
    }
}

/* ------------------ feature (sp) ------------------ */

#feature-main h2 {
    display: block;
    margin-top: 60px;
    line-height: 50px;
    font-size: 68px;
}

#feature-main h2 span {
    font-size: 16px;
    padding: 0 3px;
}

#feature-main h2 span:nth-of-type(2) {
    color: #000;
}

.feature-box {
    margin-top: 10px;
}

#feature-main .feature-box {
    overflow-x: auto;
}

#feature-main img {
    max-width: 100%;
    min-width: 600px;
}


/*------------------プライバシー(pc)------------------*/
.privacy-nav {
    margin: 20px auto 80px;
}

.privacy-nav a:nth-of-type(1) {
    color: #00428B;
}

.privacy-nav span {
    display: inline-block;
    border-bottom: solid 1px #00428B;
}

.privacy-nav span {
    display: inline-block;
    border-bottom: solid 1px #000;
}

.privacy {
    margin: 80px 0;
}

#privacy-main h2 {
    font-size: 40px;
    font-weight: 700;
    text-align: center;
}

#privacy-main h3 {
    font-size: 24px;
    font-weight: 700;
    margin-top: 20px;
}

#privacy-main h3:first-of-type {
    margin-top: 50px;
}

#privacy-main ul {
    margin-left: 18px;
}

#privacy-main ul li {
    list-style-type: disc;
    margin-top: 10px;
}

#privacy-main span p {
    font-weight: bold;
}

/*------------------プライバシー(sp)------------------*/

@media screen and (max-width:1200px) {

    .privacy-nav {
        margin: 20px auto 40px;
    }

    .privacy {
        margin: 40px 0 60px;
    }

    .privacy p:nth-of-type(2) {
        font-size: 14px;
    }

    #privacy-main h2 {
        font-size: 20px;
        text-align: left;
    }

    #privacy-main h3 {
        font-size: 18px;
        margin-top: 32px;
    }

    #privacy-main h3:first-of-type {
        margin-top: 32px;
    }

    #privacy-main ul li {
        font-size: 16px;
    }
}

/*------------------セキュリティー(pc)------------------*/
.security-nav {
    margin: 20px auto 80px;
}

.security-nav a:nth-of-type(1) {
    color: #00428B;
}

.security-nav span {
    display: inline-block;
    border-bottom: solid 1px #00428B;
}

.security {
    margin: 80px 0;
}

#security-main h2 {
    font-size: 40px;
    font-weight: 700;
    text-align: center;
}

#security-main h3 {
    font-size: 24px;
    font-weight: 700;
    margin-top: 20px;
}

#security-main h3:first-of-type {
    margin-top: 50px;
}

#security-main ul {
    margin-left: 18px;
}

/*------------------セキュリティー(sp)------------------*/

@media screen and (max-width:1200px) {

    .security-nav {
        margin: 20px auto 40px;
    }

    .security {
        margin: 40px 0;
    }

    #security-main h2 {
        font-size: 20px;
        text-align: left;
    }

    #security-main h3 {
        font-size: 18px;
        margin-top: 25px;
    }

    #security-main h3:first-child {
        margin-top: 30px;
    }

    #security-main ul li {
        font-size: 14px;
    }
}




/*------------------アーカイブセミナー(pc)------------------*/

/* .a-seminar-nav span {
    display: inline-block;
    border-bottom: solid 1px #00428B;
}

.a-seminar-title h2 {
    color: #00428B;
    font-size: 120px;
    font-style: italic;
    font-weight: bold;
    font-family: 'crimson';
    margin-top: 50px;
}

.a-seminar-title h2 span {
    font-size: 24px;
    font-family: 'notosans';
    padding: 0 10px;
}

.a-seminar-title h2 span:nth-of-type(2) {
    color: #000;
}
*/

#a-seminar .sp-seminar-cate {
    display: none;
}

#a-seminar .a-seminar-list {
    margin-bottom: 40px;
}

#a-seminar .a-seminar-list .post-hoverlink {
    display: flex;
    gap: 40px;
}

#a-seminar .a-seminar-list .post-hoverlink .post-thumbnail {
    width: 40%;
    overflow: hidden;
}

#a-seminar .a-seminar-list .post-hoverlink .post-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 284/160;
}

#a-seminar .a-seminar-list .post-hoverlink:hover .post-thumbnail img {
    transform: scale(1.2, 1.2);
    /* 画像が縦横1.2倍 */
    transition-duration: 0.5s;
    /* 表示を0.5秒かけて行う */
}

#a-seminar .a-seminar-list .post-hoverlink .post-thumbnail img {
    transition-duration: 0.5s;
    /* 表示を0.5秒かけて行う */
}

#a-seminar .a-seminar-list .post-hoverlink .seminar-content-right {
    width: 100%;
}

#a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-date {
    margin-bottom: 10px;
}

#a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-date p {
    color: #aaa;
    font-size: 14px;
}

#a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-title {
    font-size: 20px;
    margin-bottom: 10px;
}

#a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-cate p {
    color: #fff;
    padding: 4px 20px;
    font-size: 14px;
    background-color: #00428B;
    display: inline-block;
    margin-right: 6px;
    margin-bottom: 6px;
}

/* #a-seminar .a-seminar-list p {
    font-size: 14px;
    color: #374752;
    opacity: 0.6;
}

#a-seminar .a-seminar-list h3 {
    font-size: 20px;
    color: #374752;
    font-weight: bold;
    margin-top: 5px;
}

#a-seminar .a-seminar-list h4 {
    font-size: 12px;
    background-color: #00428B;
    color: #fff;
    display: inline-block;
    padding: 5px 15px;
    margin-top: 5px;
}

#a-seminar .a-seminar-list a {
    float: right;
    color: #00428B;
    margin-top: 45px;
}

#a-seminar .a-seminar-list a span {
    border-bottom: 1px solid #00428B;
} */

/*------------------アーカイブセミナー(sp)------------------*/

@media screen and (max-width:1200px) {

    /* .a-seminar-nav {
        margin-top: 30px;
    } */

    /* .a-seminar-title h2:nth-child(1) {
        display: none;
    } */

    /* .a-seminar-title h2:nth-child(2) {
        display: block;
        margin-top: 60px;
        line-height: 50px;
        font-size: 68px;
    } */

    /* .a-seminar-title h2 span {
        font-size: 16px;
    } */
    /* 
    .a-seminar-list {
        display: flex;
        align-items: flex-start;
        margin-top: 50px;
    }

    .a-seminar-list p {
        font-size: 14px;

    }

    .a-seminar-list h3 {
        font-size: 18px;
    }

    .a-seminar-list h4 {
        font-size: 12px;
    }

    .a-seminar-list a {
        font-size: 12px
    }

    .a-seminar-list img {
        width: 240px;
    } */
}

@media screen and (max-width: 768px) {
    /* .a-seminar-list h3 {
        font-size: 14px;
    }

    .a-seminar-list h4 {
        font-size: 8px;
    }

    .a-seminar-list p {
        font-size: 10px;
    }

    .a-seminar-list img {
        width: 160px;
    } */

    #a-seminar .pc-seminar-cate {
        display: none;
    }

    #a-seminar .sp-seminar-cate {
        display: block;
    }

    #a-seminar .sp-seminar-flex {
        display: flex;
        align-items: baseline;
    }

    #a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-date {
        margin-bottom: 6px;
        margin-right: 4px;
    }

    #a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-cate p {
        font-size: 12px;
        padding: 2px 10px;
        margin-right: 0px;
        margin-bottom: 6px;
        margin-left: 6px;
    }
}




@media screen and (max-width: 498px) {
    #a-seminar .a-seminar-list {
        margin-bottom: 60px;
    }

    #a-seminar .a-seminar-list .post-hoverlink {
        gap: 20px;
    }

    #a-seminar .a-seminar-list .post-hoverlink .seminar-content-right {
        width: 60%;
    }

    #a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-date p {
        font-size: 12px;
    }

    #a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-title {
        font-size: 14px;
    }

    #a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-cate {
        margin-bottom: 10px;
    }

    #a-seminar .a-seminar-list .post-hoverlink .seminar-content-right .seminar-cate p {
        font-size: 10px;
        margin-bottom: 0px;
    }
}

/*------------------シングルセミナー(sp)------------------*/

.s-seminar-nav span {
    display: inline-block;
    border-bottom: solid 1px #00428B;
}

.s-seminar-nav a:nth-of-type(1),
.s-seminar-nav a:nth-of-type(2) {
    color: #00428B;
}

.s-seminar-content1 {
    display: flex;
    align-items: center;
    margin-top: 50px;
}

.s-seminar-content1 p {
    color: #777;
    font-size: 14px;
}

.s-seminar-content1 .cate {
    background-color: #00428B;
    color: #fff;
    display: inline-block;
    padding: 5px 15px;
    margin-left: 8px;
    margin-bottom: 8px;
    font-size: 12px;
}

.s-seminar-content h3 {
    font-size: 40px;
    font-weight: bold;
    margin-top: 10px;
}

.s-seminar-inner {
    max-width: 1000px;
    margin: 0 auto;
}

/* .s-seminar-inner div {
    width: 1000px;
    height: 400px;
    text-align: center;
} */

.s-seminar-inner img {
    width: auto;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 284/160;
    margin: 40px 0;
}

.s-seminar-inner p {
    margin-bottom: 20px;
}

.s-seminar-title {
    display: flex;
    margin-top: 120px;
    justify-content: space-between;
    align-items: center;
}

.s-seminar-title h2 {
    color: #00428B;
    font-size: 120px;
    font-style: italic;
    font-weight: bold;
    font-family: 'crimson';
}

.s-seminar-title h2 span {
    font-size: 24px;
    font-family: 'notosans';
    padding: 0 10px;
    letter-spacing: 0;
}

.s-seminar-title h2 span:nth-of-type(2) {
    color: #000;
}

.s-seminar-title a {
    background-color: #00428B;
    border-radius: 40px;
    color: #fff;
    padding: 20px 20px 20px 70px;
    position: relative;
}

.s-seminar-title a::before {
    content: "";
    position: absolute;
    background-image: url(../img/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    text-align: center;
    width: 36px;
    height: 36px;
    top: 16px;
    left: 20px;

}

.s-seminar-list {
    display: flex;
    align-items: center;
    margin-top: 60px;
}

.s-seminar-list img {
    width: 287px;
}

.s-seminar-list p {
    font-size: 14px;
    color: #374752;
    opacity: 0.6;
}

.s-seminar-list h3 {
    font-size: 20px;
    color: #374752;
    font-weight: bold;
    margin-top: 5px;
}

.s-seminar-list h4 {
    font-size: 12px;
    background-color: #00428B;
    color: #fff;
    display: inline-block;
    padding: 5px 15px;
    margin-top: 5px;
}

.s-seminar-list a {
    float: right;
    color: #00428B;
    margin-top: 45px;
}

.s-seminar-list a span {
    border-bottom: 1px solid #00428B;
}

.s-seminar-title-sp {
    display: none;
}





/*------------------シングルセミナー(sp)------------------*/

@media screen and (max-width:1200px) {

    .s-seminar-nav {
        margin-top: 40px;
        font-size: 14px;
    }

    .s-seminar-content1 h4 {
        margin-left: 15px;
    }

    .s-seminar-content1 p {
        font-size: 12px;
    }

    .s-seminar-content h3 {
        font-size: 18px;
    }

    .s-seminar-inner {
        margin-top: 40px;
    }

    .s-seminar-inner div {
        height: auto;
        text-align: center;
    }

    .s-seminar-title {
        margin-top: 70px;
    }

    .s-seminar-title h2 {
        display: block;
        margin-top: 60px;
        line-height: 50px;
        font-size: 68px;
    }

    .s-seminar-title h2 span {
        font-size: 16px;
        padding: 0 3px;
    }

    .s-seminar-title a {
        display: none;
    }

    .s-seminar-title-sp {
        display: block;
    }

    .s-seminar-title-sp a {
        background-color: #00428B;
        border-radius: 40px;
        color: #fff;
        padding: 20px 20px 20px 70px;
        position: relative;
    }

    .s-seminar-title-sp a::before {
        content: "";
        position: absolute;
        background-image: url(../img/arrow.png);
        background-size: contain;
        background-repeat: no-repeat;
        text-align: center;
        width: 36px;
        height: 36px;
        top: 16px;
        left: 20px;

    }

    .s-seminar-list {
        display: flex;
        align-items: flex-start;
        margin-top: 50px;
    }

    .s-seminar-list p {
        font-size: 10px;
        color: #374752;
        opacity: 0.6;
    }

    .s-seminar-list h3 {
        font-size: 12px;
    }

    .s-seminar-list h4 {
        font-size: 8px;
    }

    .s-seminar-list a {
        font-size: 12px
    }

    .s-seminar-list img {
        width: 120px;
    }

    .QnA {
        margin: 50px auto 30px;
    }

    .s-seminar-title-sp {
        margin: 0 auto;
    }

    .s-seminar-title-sp a {
        margin: 0 50px 70px;
        text-align: center;
        display: block;
    }
}

@media screen and (max-width: 498px) {
    #a-seminar .a-seminar-list .post-hoverlink .post-thumbnail img {
        height: 50%;
    }
}