/*css fadeIn Up*/
/*=================================================*/
@keyframes fadeInUp {
    from {
        transform: translate3d(0, 100px, 0);
        -webkit-transform: translate3d(0, 100px, 0);
    }

    to {
        transform: translate3d(0, 0, 0);
        -webkit-transform: translate3d(0, 0, 0);
        opacity: 1;
    }
}

@-webkit-keyframes fadeInUp {
    from {
        transform: translate3d(0, 100px, 0);
        -webkit-transform: translate3d(0, 100px, 0);
    }

    to {
        transform: translate3d(0, 0, 0);
        -webkit-transform: translate3d(0, 0, 0);
        opacity: 1;
    }
}

#company img {
    max-width: 100%;
}

#company .animated {
    animation-duration: 1s;
    animation-fill-mode: both;
    -webkit-animation-duration: 1s;
    -webkit-animation-fill-mode: both
}

#company .animatedFadeInUp {
    opacity: 0;
}

#company .fadeInUp {
    opacity: 0;
    animation-name: fadeInUp;
    -webkit-animation-name: fadeInUp;
}

#company {
    position: relative;
    overflow: hidden;
}

#company .pc_br{
    display: none;
}

#company .inner{
    padding: 0px 12px;
    max-width: 500px;
    margin: auto;
}


/*main-banner*/
/*===============================================*/

#company .main-banner {
    position: relative;
    padding-left: 12px;
}

#company .main-banner .image_wrap{
    padding-left: 12px;
    margin-bottom: 15px;
}

#company .main-banner .image_wrap .main-img {
    display: block;
    width: 100% !important;
}

#company .heading-block{
    font-size: 15px;
    line-height: 16px;
    color: #221815;
    font-weight: 700;
    text-align: center;
    position: relative;
}

#company .heading-block:after{
    content: "";
    position: absolute;
    background-image: url("../images/company/company_icon_01_sp.png");
    background-size: 100%;
    background-repeat: no-repeat;
    width: 24px;
    height: 4px;
    bottom: -13px;
    left: calc(53.2% - 24px);
}


/*company-profile*/
/*=================================*/

#company .company-profile{
    padding-top: 42px;
}

#company .company-profile .heading-block{
    margin-bottom: 48px;
}

#company .company-profile .item-company-profile{
    border-top: 1px solid #DFE1DB;
    padding: 10px 0px 2.5px;
}

#company .company-profile .item-company-profile:last-child{
    border-bottom: 1px solid #DFE1DB;
    padding-bottom: 15px;
}

#company .company-profile .item-company-profile .title{
    font-size: 13px;
    line-height: 17px;
    color: #221815;
    font-weight: 700;
    padding-left: 10px;
    margin-bottom: 4px;
}

#company .company-profile .item-company-profile .text{
    font-size: 13px;
    line-height: 17px;
    color: #221815;
    font-weight: 400;
}

#company .company-profile .item-company-profile  .text-content{
    padding-left: 24px;
}

#company .company-profile .item-company-profile .map{
    margin-top: 13px;
    margin-right: 25px;
}

#company .company-profile .item-company-profile .map img{
    width: 100% !important;
    display: block;
}

#company .company-profile .item-company-profile a {
    display: block;
    font-size: 12px;
    line-height: 15px;
    color: #221815;
    font-weight: 400;
    padding-right: 25px;
    text-align: right;
    margin-top: 3px;
    margin-bottom: 18px;
}

#company .company-profile .item-company-profile a img{
    width: 9px;
    margin-left: 2px;
}


/*major-bases*/
/*============================*/
#company .major-bases{
    background-image: url("../images/company/company_bg01_sp.png");
    background-repeat: no-repeat;
    background-size: 100%;
    margin-top: 53px;
    margin-bottom: 59px;
    padding-top: 51px;
}

#company .major-bases .heading-block{
    margin-bottom: 66px;
}

#company .major-bases .item-major-bases{
    border-top: 1px solid #DFE1DB;
    padding: 19px 26px 12.5px 26px;
}

#company .major-bases .item-major-bases:last-child{
    border-bottom: 1px solid #DFE1DB;
}

#company .major-bases .item-major-bases .ttl {
    font-size: 13px;
    line-height: 21px;
    color: #221815;
    font-weight: 700;
    position: relative;
    margin-bottom: 13px;
}

#company .major-bases .item-major-bases .ttl:after {
    content: "";
    position: absolute;
    width: 15px;
    height: 2px;
    background: #EC1C24;
    bottom: -4px;
    left: 0px;
}

#company .major-bases .item-major-bases .text {
    font-size: 13px;
    line-height: 20px;
    color: #333333;
    font-weight: 400;
    margin-bottom: 20px;
    position: relative;
}

#company .major-bases .item-major-bases .text:last-child{
    margin-bottom: 0px;
}

#company .major-bases .item-major-bases .map-content{
    margin-top: 17px;
}

#company .major-bases .item-major-bases .map img{
    width: 100% !important;
    display: block;
}

#company .major-bases .item-major-bases .link-map{
    text-align: right;
}

#company .major-bases .item-major-bases .lint-text{
    display: inline-block;
    font-size: 12px;
    line-height: 15px;
    color: #221815;
    font-weight: 400;
    padding-right: 30px;
    text-align: right;
    margin-top: 5px;
}

#company .major-bases .item-major-bases .lint-text img{
    width: 8px;
    margin-left: 2px;
    position: relative;
    top: -4px;
}


/*history-block*/
/*=========================*/
#company .history-block{
    background-image: url("../images/company/company_bg02_sp.png");
    background-repeat: no-repeat;
    background-size: 100%;
    padding-top: 50px;
    margin-bottom: 56px;
}

#company .history-block .heading-block{
    margin-bottom: 41px;
}

#company .history-block .item-history{
    border-top: 1px solid #DFE1DB;
    padding: 15px 9px 19px 9px;
}

#company .history-block .item-history:last-child{
    border-bottom: 1px solid #DFE1DB;
    padding-bottom: 12px;
}

#company .history-block .item-history .title{
    font-size: 13px;
    line-height: 15px;
    color: #221815;
    margin-bottom: 9px;
    font-weight: 700;
}

#company .history-block .item-history .text{
    font-size: 13px;
    line-height: 23px;
    color: #221815;
    font-weight: 400;
}



/*privacy-policy*/
/*=======================================*/
#company .privacy-policy{
    background: #F0F0F0;
    padding-top: 43px;
    padding-bottom: 25px;
}

#company .privacy-policy .heading-block{
    margin-bottom: 42px;
}

#company .privacy-policy .txt-btn{
    font-size: 13px;
    line-height: 23px;
    color: #221815;
    font-weight: 700;
}

#company .privacy-policy .txt-btn{
    display: none;
}

#company .privacy-policy .txt-btn.active{
    display: inline-block;
}

#company .privacy-policy .btn-privacyPolicy{
    display: inline-block;
    cursor: pointer;
}

#company .privacy-policy .btn-privacyPolicy img{
    margin-left: 16px;
    transition: .3s;
    top: -1px;
    left: -2px;
}

#company .privacy-policy .toggle-privacyPolicy{
    text-align: center;
}

#company .privacy-policy .privacyPolicy-content{
    display: none;
    max-width: 900px;
    margin: auto;
}

#company .privacy-policy .privacyPolicy-content .text{
    font-size: 13px;
    line-height: 22px;
    color: #221815;
    font-weight: 500;
    margin-bottom: 22px;
}

#company .privacy-policy .btn-privacyPolicy.active img{
    transform: rotate(-180deg);
}

#company .map{
    position: relative;
    padding-bottom: 37%;
}

#company .map iframe{
    border: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
}

#company .item-major-bases .map{
    padding-bottom: 41%;
}

#company .movie-block{
  margin: 50px 0 30px;
}






@media (min-width: 768px) {

    #company .sp_br{
        display: none;
    }

    #company .pc_br{
        display: block;
    }

    #company .main-banner {
        position: relative;
        padding-left: 2%;
    }

    #company .banner-inner{
        position: relative;
    }

    #company .main-banner .image_wrap {
        padding-left: 100px;
        margin-bottom: 0px;
        max-width: 1700px;
        margin-right: 0px;
        margin-left: auto;
    }

    #company .main-banner .heading {
        position: absolute;
        left: 0px;
        bottom: 11%;
        z-index: 1;
    }

    #company .main-banner .heading .t1{
        display: inline-block;
    }

    #company .oneday-content .inner {
        padding: 0px 15px;
        max-width: 800px;
    }

    #company .main-banner .heading img{
        max-width: 55%;
    }

    #company .inner {
        padding: 0px 25px;
        max-width: 800px;
        margin: auto;
    }

    #company .heading-block:after {
        background-image: url("../images/company/company_icon_01_pc.png");
        width: 38px;
        height: 6px;
        bottom: -23px;
        left: calc(52% - 38px);
    }


    #company .heading-block {
        font-size: 20px;
        line-height: 30px;
    }


    /*company-profile*/
    /*===================================*/
    #company .company-profile {
        padding-top: 122px;
    }

    #company .company-profile .heading-block {
        margin-bottom: 63px;
    }

    /*#company .company-profile .list-company-profile{*/
    /*    padding: 0px 10px;*/
    /*}*/

    #company .company-profile .item-company-profile {
        display: flex;
        flex-wrap: wrap;
        border-top: 2px solid #DFE1DB;
        padding: 23px 0px 21.5px;
    }

    #company .company-profile .item-company-profile:last-child {
        border-bottom: 2px solid #DFE1DB;
        padding-bottom: 20px;
    }

    #company .company-profile .item-company-profile .title {
        font-size: 16px;
        line-height: 40px;
        padding-left: 11.5%;
        margin-bottom: 0px;
        width: 33%;
    }

    #company .company-profile .item-company-profile .text-content{
        width: 67%;
    }

    #company .company-profile .item-company-profile .text {
        font-size: 16px;
        line-height: 40px;
    }

    #company .company-profile .item-company-profile .map {
        margin-top: 33px;
        margin-right: 16px;
    }

    #company .company-profile .item-company-profile a img {
        width: auto;
        margin-left: 5px;
        position: relative;
        top: -2px;
    }

    #company .company-profile .item-company-profile a {
        display: block;
        font-size: 13px;
        line-height: 25px;
        color: #221815;
        font-weight: 400;
        padding-right: 25px;
        text-align: right;
        margin-top: 0;
        margin-bottom: -18px;
    }


    /*major-bases*/
    /*============================*/
    #company .major-bases {
        background-image: url("../images/company/company_bg01_pc.png");
        background-repeat: no-repeat;
        background-size: 100%;
        margin-top: 103px;
        margin-bottom: 88px;
        padding-top: 60px;
    }

    #company .major-bases .heading-block {
        margin-bottom: 80px;
    }

    /*#company .major-bases .list-major-bases{*/
    /*    padding: 0px 10px;*/
    /*}*/

    #company .major-bases .item-major-bases {
        border-top: 2px solid #DFE1DB;
        padding: 25px 0px 26px 0px;
        display: flex;
        flex-wrap: wrap;
    }

    #company .major-bases .item-major-bases:last-child {
        border-bottom: 2px solid #DFE1DB;
    }

    #company .major-bases .item-major-bases .ttl {
        font-size: 18px;
        line-height: 28px;
        margin-bottom: 36px;
    }

    #company .major-bases .item-major-bases .text {
        font-size: 14px;
        line-height: 28px;
        margin-bottom: 28px;
    }

    #company .major-bases .item-major-bases .ttl:after {
        width: 20px;
        height: 2px;
        bottom: -9px;
    }

    #company .major-bases .item-major-bases .text-content{
        width: 50%;
        padding-left: 22px;
        padding-right: 20px;
    }

    #company .major-bases .item-major-bases .map-content{
        width: 50%;
        margin-top: 11px;
    }

    #company .major-bases .item-major-bases .lint-text img {
        width: auto;
        margin-left: 5px;
        position: relative;
        top: -4px;
    }

    #company .major-bases .item-major-bases .lint-text {
        font-size: 13px;
        line-height: 25px;
        padding-right: 5px;
        margin-top: 4px;
    }

  #company .movie-block{
    margin: 120px 0 30px;
  }

    /*history-block*/
    /*=============================*/
    #company .history-block {
        background-image: url("../images/company/company_bg02_pc.png");
        background-repeat: no-repeat;
        background-size: 100%;
        padding-top: 60px;
        margin-bottom: 0px;
        padding-bottom: 120px;
    }

    #company .history-block .heading-block {
        margin-bottom: 84px;
    }

    #company .history-block .item-history {
        border-top: 2px solid #DFE1DB;
        padding: 22px 9px 18px 9px;
        display: flex;
        flex-wrap: wrap;
    }

    #company .history-block .item-history:last-child {
        border-bottom: 2px solid #DFE1DB;
        padding-bottom: 25px;
    }

    #company .history-block .item-history .title {
        font-size: 16px;
        line-height: 18px;
        margin-bottom: 0px;
        width: 30%;
        text-align: center;
    }

    #company .history-block .item-history .text {
        font-size: 16px;
        line-height: 40px;
        width: 70%;
        padding-left: 5.1%;
    }


    /*privacy-policy*/
    /*================================*/
    #company .privacy-policy {
        background: #F0F0F0;
        padding-top: 83px;
        padding-bottom: 92px;
    }

    #company .privacy-policy .txt-btn {
        font-size: 16px;
        line-height: 26px;
        color: #221815;
        font-weight: 700;
    }

    #company .privacy-policy .heading-block {
        margin-bottom: 70px;
    }

    #company .privacy-policy .privacyPolicy-content .text {
        font-size: 14px;
        line-height: 28px;
        color: #221815;
        font-weight: 500;
        margin-bottom: 32px;
    }

    #company .map{
        padding-bottom: 39%;
    }

    #company .item-major-bases .map {
        padding-bottom: 50%;
    }










}



@media (min-width: 960px) {

    #company .main-banner .heading img{
        max-width: 61%;
    }

	#company .main-banner .image_wrap {
	    max-width: 100%;
	    width: 93%;
        padding-left: 70px;
	}

    #company .main-banner {
        position: relative;
        padding-left: 2.5%;
    }

    #company .inner {
        padding: 0px 25px;
        max-width: 900px;
        margin: auto;
    }

    #company .heading-block {
        font-size: 22px;
        line-height: 30px;
    }
    
    /*content*/
    /*=======================================*/
    #company .major-bases .item-major-bases .text {
        font-size: 16px;
        line-height: 32px;
        margin-bottom: 32px;
    }

    #company .major-bases .item-major-bases .ttl {
        font-size: 20px;
        line-height: 32px;
        margin-bottom: 43px;
    }

    #company .history-block .item-history .title {
        font-size: 18px;
        line-height: 20px;
    }

    #company .history-block .item-history .text {
        font-size: 18px;
        line-height: 46px;
    }

    #company .privacy-policy .privacyPolicy-content .text {
        font-size: 16px;
        line-height: 32px;
        margin-bottom: 32px;
    }

    #company .major-bases .item-major-bases .lint-text {
        font-size: 15px;
        line-height: 30px;
        padding-right: 5px;
        margin-top: 4px;
    }

    #company .company-profile .item-company-profile .title {
        font-size: 18px;
        line-height: 46px;
    }

    #company .company-profile .item-company-profile .text {
        font-size: 18px;
        line-height: 46px;
    }

    #company .company-profile .item-company-profile a {
        font-size: 15px;
        line-height: 30px;
    }

    #company .company-profile .item-company-profile a img {
        top: -2px;
    }

    #company .major-bases {
        margin-top: 103px;
        margin-bottom: 88px;
        padding-top: 150px;
    }

    #company .major-bases .heading-block {
        margin-bottom: 128px;
    }

    #company .history-block {
        padding-top: 101px;
        margin-bottom: 0px;
        padding-bottom: 174px;
    }

    #company .major-bases .item-major-bases {
        padding: 48px 0px 34.5px 0px;
    }

    

}


@media (min-width: 1280px) {

    #company .main-banner .heading img {
        max-width: 100%;
    }

    #company .main-banner {
        position: relative;
        padding-left: 4.6%;
    }

    #company .main-banner .image_wrap {
        padding-left: 104px;
    }

    #company .inner {
        padding: 0px 25px;
        max-width: 1010px;
        margin: auto;
    }

    #company .heading-block {
        font-size: 24px;
        line-height: 30px;
    }











}


