@charset "utf-8";

/* 創業100周年
-------------------------------*/
html {scroll-behavior: smooth;}

.anv01{
    width: 100%;
    padding-top: 100px;
    padding-bottom: 450px;
    background: url(../images/anniv/anv_02.jpg) center bottom no-repeat;
}
.anv01 .img{
    width: 100%;
    height: 350px;
    background: url(../images/anniv/anv_01.png) center center no-repeat;
    margin-bottom: 30px;
}

@keyframes fade-in {
    0% {
        transform: scale(0.8);
        opacity: 0;
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.anv01 p{
    width: 100%;
    padding-left: 5%;
    padding-right: 5%;

    text-align: center;
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: 20px;
    line-height: 2em;
    color: #00a0e9;
}

@media screen and (min-width:1921px){
    .anv01{
        background-position:  center 350px;
        background-size: cover;
    }
}

@media screen and (max-width:1100px){
    .anv01{
        padding-top: 9vw;
        padding-bottom: 40vw;
        background-size: auto 56vw;
    }
    .anv01 .img{
        height: 31.8vw;
        background-size: cover;
    }
}

@media screen and (max-width:777px){
    
    .anv01 p{
        font-size: 16px;
        line-height: 1.8em;
    }

}






.anv02{
    margin-top: -200px;
    width: 100%;
    background-color: #e5f6fd;
    border-radius: 100px 100px 0 0;
}
.anv02 .inner{
    width: 100%;
    max-width: 1920px;
    margin: auto;
}

#side{
    width:670px;
    position: sticky;
    position: -webkit-sticky;
    top: 10px;
    float: left;
}
.anv02_cont{
    width: 910px;
    background-color: #fff;
    padding: 80px 60px;
    margin-left: 670px;
    position: relative;
}
.anv02_cont .lead{
    width: 470px;
    margin-bottom: 80px;
}
.anv02_cont .ttl1{
    color: #00a0e9;
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: 70px;
    line-height: 1.3em;
    margin-bottom: 10px;
}
.anv02_cont .ttl2{
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: 32px;
    line-height: 1.3;
    margin-bottom: 20px;
}
.anv02_cont .ttl2 span{
    color: #00a0e9;
    font-size: 156%;
    margin-left: 5px;
    margin-right: 5px;
}

.anv02_cont .img_sub{
    position: absolute;
    right: 0;
    top: 100px;
    width: 360px;
}
.anv02_cont .btn{
    margin-top: 40px;
    margin-bottom: 100px;
}

.anv02_cont .btn a{
    width: 100%;
    max-width: 620px;
    margin: auto;
    display: block;
    padding: 20px 40px;
    background-color: #246ac1;
    background-image: url(../images/anniv/maru_ya.png);
    background-position: calc(100% - 40px) center;
    background-repeat: no-repeat;
    border-radius: 50px;
    color: #fff;
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: 30px;
    line-height: 1;
}
.anv02_cont dl{
    margin-bottom: 70px;
}
.anv02_cont dt{
    color: #246ac1;
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: 22px;
    line-height: 1.6;
    margin-bottom: 20px;
}
.anv02_cont dd{
    padding-left: 60px;
    background: url(../images/anniv/kei.png) left 10px no-repeat;
    font-size: 18px;
    line-height: 1.8;
}
.anv02_cont .cap1{
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    color: #246ac1;
}
.anv02_cont .cap2{
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    margin-top: 10px;
    color: #246ac1;
    text-align: right;
}

@media screen and (max-width:1900px){
    #side{
        width:35.26vw;
    }
    .anv02_cont{
        margin-left: 35.26vw;
    }
}

@media (min-width:911px)and (max-width:1450px){
    .anv02_cont{
        width: 62vw;
        padding: 60px 5%;
        margin-left: auto;
    }
    .anv02_cont .lead{
        width: 32vw;
    }
    .anv02_cont .ttl1{
        font-size: 4.8vw;
        line-height: 1.3;
    }
    .anv02_cont .ttl2{
        font-size: 2.2vw;
        line-height: 1.3;
    }
    .anv02_cont .img_sub{
        top: 80px;
        width: 24.8vw;
    }

    
    
}
@media screen and (max-width:910px){

    .anv02{
        margin-top: -50px;
        border-radius: 50px 50px 0 0;
    }

    #side{
        width:100%;
        position: static;
        position: -webkit-static;
        float: none;
        text-align: center;
    }
    #side img{
        width: 100%;
        max-width: 500px;
        height: auto;
    }
    .anv02_cont{
        margin-top: -100px;
        width: 100%;
        padding: 30px 30px 100px 30px;
        margin-left: 0;
    }
    .anv02_cont .lead{
        width: 100%;
        margin-bottom: 0;
    }
    .anv02_cont .ttl1{
        font-size: 70px;
        line-height: 1.3em;
        margin-bottom: 10px;
    }
    .anv02_cont .ttl2{
        font-size: 32px;
        line-height: 1.3;
        margin-bottom: 20px;
    }

    .anv02_cont .img_sub{
        position: static;
        width: 100%;
        margin-top: 30px;
        margin-bottom: 30px;
        text-align: center;
    }
    .anv02_cont .btn{
        display: none;
    }

    .anv02_cont dl{
        margin-bottom: 50px;
    }
    .anv02_cont dt{
        font-size: 20px;
        line-height: 1.6;
        margin-bottom: 10px;
    }
    .anv02_cont dd{
        font-size: 16px;
        line-height: 1.8;
    }

}


@media screen and (max-width:640px){
    .anv02_cont{
        padding-bottom: 70px;
    }

    
    .anv02_cont .ttl1{
        font-size: 50px;
        line-height: 1.3em;
    }
    .anv02_cont .ttl2{
        font-size: 24px;
        line-height: 1.3;
        margin-bottom: 20px;
    }
    .anv02_cont dl{
        margin-bottom: 30px;
    }
    .anv02_cont dt{
        font-size: 18px;
        line-height: 1.5;
        margin-bottom: 6px;
    }
    .anv02_cont dd{
        padding-left: 20px;
        background-size: 14px 8px;

        font-size: 15px;
        line-height: 1.8;
    }
    
    
}




.anv03 {
    margin-bottom:50px;
}
.anv03 .img{
    width: 100%;
    height: 642px;
    background: url(../images/anniv/anv_05.png) center center no-repeat;
}

@media screen and (max-width:1400px){
    .anv03 .img{
        height: 45.87vw;
        background-size: cover;
    }
}
@media screen and (max-width:640px){
    .anv03 {
        margin-bottom:20px;
    }
    .anv03 .img{
        height: 55vw;
    }

}





.anv04{
    background-color: #fafaf9;
    padding: 90px 3% 1px;
}

.anv04 .bg_img{
    width: 100%;
    max-width: 1720px;
    margin: auto;
    background: url(../images/anniv/anv_06.png) center top no-repeat;
    background-size: 100% auto;
    background-attachment: fixed;
    padding-bottom: 300px;
}

.his_cont{
    width: 100%;
    max-width: 1190px;
    margin: auto;
    padding-top: 210px;
}
.his_cont .ttl{
    text-align: center;
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    margin-bottom: 100px;
}
.his_cont .ttl .en{
    color: #00a0e9;
    font-size: 70px;
    line-height: 1.2;
    margin-bottom: 10px;
}
.his_cont .ttl .ja{
    font-size: 32px;
    line-height: 1.2;
}

.his_item{
    width: 100%;
    display: flex;
    justify-content: flex-start;
    min-height: 300px;
}

.his_item .nen{
    width: 215px;
    text-align: right;
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: 82px;
    line-height: 1.2;
}
.his_item .nen.gold{
    font-size: 90px;
    line-height: 1.2;
    color: #d2af78;
}
.his_item .maru{
    width: 120px;
    padding-top: 35px;
    text-align: center;
    color: #00a0e9;
    font-size: 18px;
}
.his_item .maru .show{
    position: relative;
}

.his_item .maru .show:after{
    position: absolute;
    left: calc(50% - 3.8px);
    top: 50%;
    width: 7.65px;
    height: 0;
    background-color: #00a0e9;
    transition: 0.8s;
    content: "";
}
.his_item .maru .show.active:after{
    height: 300px;
    transition-delay: 0.8s;
}


.his_item .cont{
    padding-top: 35px;
}
.his_item .p1{
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: 28px;
    line-height: 1.4;
    margin-bottom: 30px;
}
.his_item .p2{
    font-size: 25px;
    line-height: 1.4;
    color: #666;
    margin-bottom: 8px;
}
.his_item .p3{
    font-size: 18px;
    line-height: 1.4;
}

.his_item .p2.pin{
    margin-top: 65px;
    position: relative;
}
.his_item .p2.pin:before{
    position: absolute;
    left: -68px;
    top: 10px;
    font-size: 16px;
    color: #246ac1;
    content: "●";
}





.his_cont .svg{
    width: 648px;
    margin: auto;
    text-align: center;
}
.kei1.svg{
    text-align: left;
    margin-bottom: -55px;
}
.kei2.svg{
    margin-top: 50px;
    margin-bottom: -55px;
}
.kei3.svg{
    margin-top: -10px;
    margin-bottom: -55px;
}
.kei4{
    width: 648px;
    margin: auto;
    text-align: center;
    margin-bottom: -55px;
}
.his_cont .svg.kei4-1{
    text-align: left;
}
.his_cont .svg.kei4-2{
    text-align: right;
}

.his_end_txt{
    text-align: center;
    margin-top: 100px;
    margin-bottom: 60px;
}
.his_end_txt p{
    margin-top: 30px;
    font-size: 20px;
    line-height: 1.8;
}

@media screen and (min-width:641px){

    .his_item.rev{
        flex-flow: row-reverse;
    }
    .his_item.rev .nen{
        text-align: left;
    }
    .his_item.rev .cont{
        text-align: right;
    }

    .his_item.rev .p2.pin:before{
        right: -68px;
        left: auto;
    }
}
@media (min-width:641px) and (max-width:1270px){

    .anv04{
        padding-top: 7vw;
    }

    .anv04 .bg_img{
        padding-bottom: 23vw;
    }

    .his_cont{
        padding-top: 16.5vw;
    }
    .his_cont .ttl{
        margin-bottom: 7.87vw;
    }
    .his_cont .ttl .en{
        font-size: 5.1vw;
        line-height: 1.2;
        margin-bottom: 0.7vwx;
    }
    .his_cont .ttl .ja{
        font-size: 2.5vw;
        line-height: 1.2;
    }

    .his_item{
        min-height: 23.622vw;
    }

    .his_item .nen{
        width: 16.9vw;
        font-size: 6.37vw;
        line-height: 1.2;
    }
    .his_item .nen.gold{
        font-size: 7.08vw;
        line-height: 1.2;
    }
    .his_item .maru{
        width: 9.44vw;
        padding-top: 2.75vw;
        font-size: 1.8vw;
    }
    .his_item .maru .show:after{
        left: calc(50% - 0.299vw);
        width: 0.6vw;
    }
    .his_item .maru .show.active:after{
        height: 23.622vw;
    }

    .his_item .cont{
        padding-top: 2.75vw;
    }
    .his_item .p1{
        font-size: 2.2vw;
        line-height: 1.4;
        margin-bottom: 2.3vw;
    }
    .his_item .p2{
        font-size: 1.968vw;
        line-height: 1.4;
        margin-bottom: 0.629vw;
    }
    .his_item .p3{
        font-size: 1.4vw;
        line-height: 1.4;
    }

    .his_item .p2.pin{
        margin-top: 5.11;
    }
    .his_item .p2.pin:before{
        left: -5.35vw;
        top: 0.78vw;
        font-size: 1.25vw;
    }
    .his_item.rev .p2.pin:before{
        right: -5.35vw;
        left: auto;
    }

    .his_cont .svg{
        width: 51vw;
    }
    .his_cont .svg svg{
        width: auto;
        max-width: 100%;
        height: auto;
    }
    .kei1.svg{
        margin-bottom: -4.33vw;
    }
    .kei1.svg svg{
        width: 24.011vw;
        height: auto;
    }
    .kei2.svg{
        margin-top: 3.93vw;
        margin-bottom: -4.5vw;
    }
    .kei3.svg{
        margin-top: -0.78vw;
        margin-bottom: -4.5vw;
    }
    .kei4{
        width: 51vw;
        margin-bottom: -4.5vw;
    }
    .his_cont .svg.kei4-1{
        width: 46.9%;
        margin-left: 0;
    }
    .his_cont .svg.kei4-2{
        width: 46.9%;
        margin-right: 0;
    }
    .his_end_txt{
        margin-top: 7.87vw;
        margin-bottom: 4.72vw;
    }
    .his_end_txt p{
        margin-top: 2.36vw;
        font-size: 1.57vw;
        line-height: 1.8;
    }

}

@media screen and (max-width:640px){
    .anv04{
        padding-top: 40px;
    }

    .anv04 .bg_img{
        background-attachment: scroll;
        padding-bottom: 80px;
    }

    .his_cont{
        padding-top: 50px;
    }
    .his_cont .ttl{
        margin-bottom: 60px;
    }
    .his_cont .ttl .en{
        font-size: 50px;
        line-height: 1.2;
        margin-bottom: 8px;
    }
    .his_cont .ttl .ja{
        font-size: 24px;
        line-height: 1.2;
    }

    .his_item{
        min-height: initial;
        min-height: auto;
        margin-bottom: 30px;
    }

    .his_item .nen{
        width: 65px;
        font-size: 22px;
        line-height: 1.2;
    }
    .his_item .nen.gold{
        font-size: 22px;
        line-height: 1.2;
    }
    .his_item .maru{
        width: 35px;
        padding-top: 5px;
        font-size: 14px;
    }
    .his_item .maru .show:after{
        position: absolute;
        left: calc(50% - 1px);
        top: 50%;
        width: 2px;
        height:160px;
    }
    .his_item .maru .show.active:after{
        height: 160px;
        transition-delay: 0;
    }


    .his_item .cont{
        width: calc(100% - (65px + 40px));
        padding-top: 5px;
    }
    .his_item .p1{
        font-size: 16px;
        line-height: 1.4;
        margin-bottom: 20px;
    }
    .his_item .p1 br.pc{
        display: none;
    }
    .his_item .p2{
        font-size: 14px;
        line-height: 1.4;
        margin-bottom: 8px;
    }
    .his_item .p3{
        font-size: 13px;
        line-height: 1.4;
    }

    .his_item .p2.pin{
        margin-top: 20px;
        position: relative;
    }
    .his_item .p2.pin:before{
        position: absolute;
        left: -23px;
        top: 0px;
        font-size: 10px;
    }

    .his_cont .svg{
        display: none;
        height: 0;
        overflow: hidden;
    }
    .kei4{
        display: none;
        height: 0;
        overflow: hidden;
    }
    .his_end_txt p {
        margin-top: 20px;
        font-size: 16px;
        line-height: 1.8;
    }
    .his_end_txt span{
        display: inline-block;
    }
}













@media screen and (max-width:777px){

}


@media screen and (max-width:640px){

}





/* kei1 */
svg .svg-elem-1-1 {
    stroke-dashoffset: 543.5123901367188px;
    stroke-dasharray: 543.5123901367188px;
    -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
    transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}

.active svg .svg-elem-1-1 {
    stroke-dashoffset: 0;
}


/* kei2 */
svg .svg-elem-2-1 {
    stroke-dashoffset: 1673.97998046875px;
    stroke-dasharray: 1673.97998046875px;
    -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
    transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}

.active svg .svg-elem-2-1 {
    stroke-dashoffset: 0;
}


/* kei3 */

svg .svg-elem-3-1 {
    stroke-dashoffset: 1034.6102294921875px;
    stroke-dasharray: 1034.6102294921875px;
    -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
    transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}

.active svg .svg-elem-3-1 {
    stroke-dashoffset: 0;
}





/* kei4-1 */
svg .svg-elem-4-1-1 {
    stroke-dashoffset: 134.9995837896228px;
    stroke-dasharray: 134.9995837896228px;
    fill: rgb(151, 137, 137);
    -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
        fill 0s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
    transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
        fill 0s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}

.active svg .svg-elem-4-1-1 {
    stroke-dashoffset: 269.9991675792456px;
    fill: rgb(151, 137, 137);
}

svg .svg-elem-4-1-2 {
    stroke-dashoffset: 462.19793701171875px;
    stroke-dasharray: 462.19793701171875px;
    -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.12s,
        fill 0s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
    transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.12s,
        fill 0s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}

.active svg .svg-elem-4-1-2 {
    stroke-dashoffset: 924.3958740234375px;
}

/* kei4-2 */
svg .svg-elem-4-2-1 {
    stroke-dashoffset: 134.9995837896228px;
    stroke-dasharray: 134.9995837896228px;
    fill: rgb(151, 137, 137);
    -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
        fill 0s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
    transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s,
        fill 0s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}

.active svg .svg-elem-4-2-1 {
    stroke-dashoffset: 0;
    fill: rgb(151, 137, 137);
}

svg .svg-elem-4-2-2 {
    stroke-dashoffset: 489.4873962402344px;
    stroke-dasharray: 489.4873962402344px;
    -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.12s,
        fill 0s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
    transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.12s,
        fill 0s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}

.active svg .svg-elem-4-2-2 {
    stroke-dashoffset: 0;
    transition-delay: 0.5s;
}




/* kei5 */
svg .svg-elem-5-1 {
    stroke-dashoffset: 627.6724243164062px;
    stroke-dasharray: 627.6724243164062px;
    -webkit-transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
    transition: stroke-dashoffset 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
}

.active svg .svg-elem-5-1 {
    stroke-dashoffset: 0;
}



@media print{
    
    [data-aos^="fade"][data-aos^="fade"]{
        opacity: 1;
        transform: translateZ(0);
    }

    .his_item .maru .show:after{
        height: 300px;
    }


    svg .svg-elem-1-1,
    svg .svg-elem-2-1,
    svg .svg-elem-3-1,
    svg .svg-elem-4-1-1,
    svg .svg-elem-4-1-2,
    svg .svg-elem-4-2-1,
    svg .svg-elem-4-2-2,
    svg .svg-elem-5-1 {
        stroke-dashoffset: 0;
    }

}









