@charset "UTF-8";

.section--page {
    padding: 75px var(--contentPadding) 0;
}
    
.page-sub {
    color: var( --font-secondary);
    font-family:'Noto Sans JP', Arial, Helvetica, sans-serif;
    font-size: 1.6rem;
    line-height: 180%; /* 28.8px */
    margin-top: 15px;
}

.page-size {
    font-size: 4rem;
    font-family:'Noto Sans JP', Arial, Helvetica, sans-serif;
    font-weight: 900;
    text-align: left;
    text-shadow: none;

}

@media screen and (min-width: 900px)  {
    
    .section--page {
        padding: 50px 6.25% 0;
    }
    
    .page-sub {
        font-size: 3.0rem;
    }

    .page-size {
        font-size: 12rem;
        font-family:'Noto Sans JP', Arial, Helvetica, sans-serif;
        font-weight: 900;
    }
}

/* history */
.history-content {
    margin-top: 50px;
    padding:0 10px;
}

.history-left {
    margin-top: 50px;
}

.history-block1 {
    border-bottom: 3px solid var(--border-secondary);
    padding: 34px 15px 44px;
    transition: all 0.8s ease;
    position: relative;
    opacity: 0;
    transform: translateY(50px);
    transition: all 0.8s ease;
}


.history-block1:nth-of-type(1) {
    border-top: 3px solid var(--border-secondary);
}

.history-block1.show {
    opacity: 1;
    transform: translateY(0);
}

.history-item {
    display: flex;
    gap: 0 20px;
    align-items: center;
}

.history-number {
    color: var(--border-primary);
    border: solid 1px var(--border-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 6px 20px;
    font-family: "Noto Sans JP";
    font-size: 2rem;
    font-weight: 400;
    line-height: 180%; /* 72px */
}

    .history-topic {
        font-size:2.4rem;
    }

    .history-block {
        margin: 50px 0 0;
    }

    .history-txt {
        font-size: 1.6rem;
    }


@media screen and (min-width: 769px)  {

    .history-content {
        display: flex;
        gap: 0 90px;
        margin-top: 80px;
        align-items: flex-start;
    }

    .history-img {
        width: 428px;
        height: 484px;
    }

    .history-left {
        width: 60%;
        position: relative;
        overflow: hidden;
    }

    .history-left {
        margin-top: 0;
    }

    .history-block1 {
        border-bottom: 3px solid var(--border-secondary);
        padding: 34px 15px 44px;
        transition: all 0.8s ease;
        position: relative;
        opacity: 0;
        transform: translateY(50px);
        transition: all 0.8s ease;
    }


    .history-block1:nth-of-type(1) {
        border-top: 3px solid var(--border-secondary);
    }

    .history-block1.show {
        opacity: 1;
        transform: translateY(0);
    }

    .history-item {
        display: flex;
        gap: 0 60px;
        align-items: center;
    }

    .history-number {
        color: var(--border-primary);
        border: solid 1px var(--border-primary);
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 6px 30px;
        font-family: "Noto Sans JP";
        font-size: 4rem;
        font-weight: 400;
        line-height: 180%; /* 72px */
    }

    .history-topic {
        font-size: 4.0rem;
    }

    .history-block {
        margin: 50px 0 0 54px;
    }

    .history-txt {
        font-size: 1.6rem;
    }




    .strength-box {
    font-size: 1.6rem;
    margin: 25px 0 0  5px;
    }


}
/* about pc */

/* flow strength */

.section--strength {
    background-color: var(--bg-secondary);
}

.flow-example {
    font-size: 1.5rem;
    margin: 50px 0 40px;
}

.box {
    border: 1px solid #e2e2e2;
    padding: 0;
    min-height: 110px; /* ボックス高さの目安 */
}
.flow-number {
    border-bottom: 1px solid #fcfcfc;
    padding-bottom: 15px;
    font-size: 2.4rem;
    padding: 20px 20px 20px 30px;
}

.flow-box {
    padding: 30px 20px 0;
}

.flow-topic {
    margin: 45px 30px 30px;
    font-size: 1.5rem;
    font-style: normal;
    font-weight: 400;
    line-height: 200%; /* 28.8px */
}

.strength {
    border: 1px solid #fcfcfc;
    font-size: 1.5rem;
}

.strength-box1 {
    padding: 30px;
}

.strength-topic {
    font-size: 2.0rem;
    font-weight: 500;
}
.strength-txt {
    margin: 10px 0 0 0px;
}

.strength-box2 {
    padding: 40px;
    border-top: 1px solid #fcfcfc;
}

/* ===== skill PC表示 ===== */
@media screen and (min-width: 900px) {

    .section--strength {
        background-color: var(--bg-secondary);
    }

    .ttitle-option {
        font-size: 2rem;
        margin-top: 15px;
    }

    .flow-example {
        font-size: 1.6rem;
        margin: 75px 0 70px;
    }

    
    .grid {
        display: grid;
        gap: 120px 0; /* ボックス間の余白 */
        grid-template-columns: repeat(2, 1fr); /* PCでは4列 */
        margin-top: 80px;
        border: 1px solid #fcfcfc;

    }
    .box {
        border: 1px solid #e2e2e2;
        padding: 0;
        min-height: 110px; /* ボックス高さの目安 */
    }
    .flow-number {
        border-bottom: 1px solid #fcfcfc;
        padding-bottom: 15px;
        font-size: 2.4rem;
        padding: 20px 20px 20px 30px;
    }

    .flow-box {
        padding: 30px 20px 0;
    }

    .flow-topic {
        margin: 45px 40px 30px;
        font-size: 1.6rem;
        font-style: normal;
        font-weight: 400;
        line-height: 180%; /* 28.8px */
    }

    .strength {
        border: 1px solid #fcfcfc;
        font-size: 1.6rem;
    }

    .strength-box1 {
        padding: 40px;
    }

    .strength-topic {
        font-size: 2.0rem;
        font-weight: 500;
    }
    .strength-txt {
        margin: 10px 0 0 30px;
    }

    .strength-box2 {
         padding: 40px;
         border-top: 1px solid #fcfcfc;
    }


}


.accent1 {
    width: 66px;
}

.future-conten {
    margin: 10px 15px 15px;
}

.future-txt {
    font-size: 1.5rem;
    margin-top: 45px;
}

.accent2 {
    margin-left: auto;
    display: block;
}

@media screen and (min-width: 769px){
    .accent1 {
        width: 166px;
    }

    .future-conten {
        margin: 0 100px 21px;
    }

    .future-txt {
        font-size: 1.6rem;
        margin-top: 65px;
    }

}

