body {
    background-color: #ebe9d2;
    font-family: dnp-shuei-gothic-kin-std, sans-serif;
    font-style: normal;
    font-weight: 400;
}
.pc { display: block !important; }
.sp { display: none !important; }

/* スクロール */
.sa {
    opacity: 0;
    transition: all .5s ease;
}
.sa.show {
    opacity: 1;
    transform: none;
}
.sa--up {
    transform: translate(0, 100px);
}

/* ページ先頭の余白 */
.my-top-margin-100 {
    margin-top: 100px;
}
.my-top-margin-200 {
    margin-top: 200px;
}

/* 大見出し */
.heading-text {
    text-align: center;
}
.main-title {
    position: relative;
    padding: 5px;
    display: inline-block;
    text-align: center;
    font-size: 50px;
    font-family: mrs-eaves-roman-lining, sans-serif;
    font-weight: 400;
    font-style: normal;
}
.main-sub-title {
    display: block;
    font-size: 14px;
}

/* Olive合同会社とは */
#top-title {
    font-size: 25px;
}
.top-setumei {
    font-size: large;
    text-align: center;
    font-size: 20px;
}
.sample {
    line-height: 2em;
    max-width: 700px;
    text-align: center;
    margin: 0 auto;
    padding: 10px 30px;
}
.sample p {
    display: inline-block;
    text-align: left;
    font-size: 16px;
}

/* 企業概要 */
.system:first-letter {
    font-size: 130%;
    color: #C1272D;
}
.event:first-letter {
    font-size: 130%;
    color: #D9E021;
}
.education:first-letter {
    font-size: 130%;
    color: #189F95;
}
.kigyougaiyou-heading {
    color: black;
    margin-bottom: 5px;
    font-family: mrs-eaves-roman-lining, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 35px;
}
.kigyougaiyou-contents {
    line-height: 2.5em;
    font-size: 16px;
}
.kigyougaiyou-middle {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.photo {
    width: 60%;
}
.zoom-in-img img {
    transform: scale(1);
    transition: .3s ease-in-out;
}
.zoom-in-img:hover img {
    transform: scale(1.1);
}

/* システム開発実績 */
#faststream-service-whitebox {
    font-weight: bold;
    background-image: linear-gradient(transparent 60%, lightgreen 0%);
    font-size: 1.25rem;
}
#faststream-service-compass {
    font-weight: bold;
    background-image: linear-gradient(transparent 60%, lightpink 0%);
    font-size: 1.25rem;
}
#faststream-service-faststream {
    font-weight: bold;
    background-image: linear-gradient(transparent 60%, lightblue 0%);
    font-size: 1.25rem;
}
.system-mt {
    margin-top: 10em;
}

/* From uiverse.io by @alexmaracinaru */
.cta a {
    text-decoration: none;
}
.cta span {
    padding-bottom: 7px;
    letter-spacing: 4px;
    font-size: 18px;
    padding-right: 15px;
    text-transform: uppercase;
}
   
.cta svg {
    transform: translateX(-8px);
    transition: all 0.3s ease;
}
   
.cta:hover svg {
    transform: translateX(0);
}
   
.cta:active svg {
    transform: scale(0.9);
}
   
.hover-underline-animation {
    position: relative;
    color: black;
    padding-bottom: 20px;
}
   
.hover-underline-animation:after {
    content: "";
    position: absolute;
    width: 100%;
    transform: scaleX(0);
    height: 1.5px;
    bottom: 0;
    left: 0;
    background-color: #000000;
    transform-origin: bottom right;
    transition: transform 0.25s ease-out;
}
   
.cta:hover .hover-underline-animation:after {
    transform: scaleX(1);
    transform-origin: bottom left;
}
.system-table th {
    white-space: nowrap;
}

/* Instagram */ 
#instagram-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.instagram-item {
    flex-basis: 250px;
    padding: 5px;
}
.instagram-picture {
    width: 100%;
    height: 250px;
    object-fit: cover;  /* 中央でトリミング */
}

/* イベント内容 */
.event-middle {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.event-contents-01 {
    line-height: 2;
}
.event-foto-size {
    width: 25vw;
}
.event-foto-size2 {
    width:20vw;
}
#usagi {
    margin-top: -30px;
}
#event-usagisize {
    width: 280px;
}
#mixsand-boder {
    background: linear-gradient(transparent 65%, #f1f390bb 65%);
}
#paradiso-boder {
    background: linear-gradient(transparent 65%, #fdcfcfbb 65%);
}
#concert-boder-01 {
    background: linear-gradient(transparent 65%, #FFC081bb 65%);
}
#concert-boder-02 {
    background: linear-gradient(transparent 65%, #ACEBFFbb 65%);
}
#hyakaryouran-boder {
    background: linear-gradient(transparent 65%, #addb41bb 65%);
}

#event-top {
    display: flex;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 15em;
}
#event-top-item-01 {
    flex-basis: 45%;
    margin-top: 30px;
    margin-left: 100px;
}
#event-top-item-02 {
    flex-basis: 35%;
}

#event-mixsand {
    display: flex;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 10em;
}
#event-mixsand-item-01 {
    flex-basis: 40%;
    text-align: center;
}
#event-mixsand-item-02 {
    flex-basis: 40%;
    text-align: center;
}
#event-mixsand-logo {
    background-color: white;
    width: 150px;
	height: 150px;
	object-fit: cover;
	border-radius: 50%;
	object-position: 0px 15px;
}

#event-paradiso {
    display: flex;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 10em;
}
#event-paradiso-item-01 {
    flex-basis: 40%;
    text-align: center;
}
#event-paradiso-item-02 {
    flex-basis: 40%;
    text-align: center;
}

#event-concert {
    display: flex;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 10em;
}
#event-concert-item-01 {
    flex-basis: 40%;
    text-align: center;
}
#event-concert-item-02 {
    flex-basis: 40%;
    text-align: center;
}

#event-hyakaryouran {
    display: flex;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 10em;
}
#event-hyakaryouran-item-01 {
    flex-basis: 40%;
    text-align: center;
}
#event-hyakaryouran-item-02 {
    flex-basis: 40%;
    text-align: center;
}

.event-bold {
    font-size: 20px;
}

/* 教育事業 */
#education-title:first-letter {
    font-size: 130%;
    color: #00A99D;
}
.education-sub-title h2{
    font-size: 18px;
    line-height: 2em;
}
#education-pckatekyo-logo {
    width: auto;
}
#education-keyboard-logo {
    width: auto;
}

/* 会社概要 */
.overview:first-letter {
    font-size: 130%;
    color: #9e52a5;
}
.overview-privacy-policy-title {
    font-size: 1.25rem;
}

/* フッタ */
footer {
    margin-top: 200px;
    background-color:#464e2e;
}
#footer-sns-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding-top: 50px;
}
.footer-sns-item {
    text-align: center;
    width: 120px;
}
#footer-contact-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    color: white;
    padding-top: 50px;
    padding-bottom: 50px;
}
#footer-contact-item-mail {
    padding-right: 20px;
}
#footer-contact-item-mail a {
    color: white;
    text-decoration: none;
}
#footer-contact-item-tel {
    padding-left: 20px;
}
#footer-contact-icon-mail {
    width: 118px;
    padding-right: 20px;
    float: left;
}
#footer-contact-icon-tel {
    width: 118px;
    padding-right: 20px;
    float: left;
}
#footer-copyright {
    color: white;
    text-align: center;
    padding: 50px 20px;
}

.responsive-br {
    display: none;
}


/*-------  スマホサイズ  ---------*/
@media screen and (max-width : 768px) {

    .photo {
        width: 250px;
    }
    .pc { display: none !important; }
    .sp { display: block !important; }

    /* トップページ */
    .kigyougaiyou-middle {
        padding-top: 20px;
    }

    /* ページ先頭の余白 */
    .my-top-margin-200 {
        margin-top: 100px;
    }

    /*教育事業*/
    .education-sub-title h2{
        font-size: 13px;
    }

    /* Instagram */ 
    #instagram-grid {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
    }
    .instagram-item {
        flex-basis: 150px;
        padding: 5px;
    }
    .instagram-picture {
        width: 100%;
        height: 150px;
        object-fit: cover;
    }

    /* フッタ */
    #footer-contact-grid {
        flex-direction: column;
    }
    #footer-contact-item-mail {
        padding: 0px 20px;
        margin: 0 auto;
    }
    #footer-contact-item-tel {
        padding: 20px 20px 0px 20px;
        margin: 0 auto;
    }

    /* イベント */
    #event-top-item-01 {
        flex-basis: 100%;
        margin-top: 0px;
        margin-left: 0px;
    }
    #event-top-item-02 {
        flex-basis: 100%;
        text-align: center;
        margin-top: 30px;
    }
    #event-usagisize {
        width: 300px;
    }
    #event-mixsand-item-01 {
        flex-basis: 100%;
        text-align: left;
    }
    #event-mixsand-item-02 {
        flex-basis: 100%;
        text-align: left;
    }
    #event-paradiso-item-01 {
        flex-basis: 100%;
        text-align: left;
        order: 2;
    }
    #event-paradiso-item-02 {
        flex-basis: 100%;
        text-align: left;
        order: 1;
    }
    #event-concert-item-01 {
        flex-basis: 100%;
        text-align: left;
    }
    #event-concert-item-02 {
        flex-basis: 100%;
        text-align: left;
    }
    #event-hyakaryouran-item-01 {
        flex-basis: 100%;
        text-align: left;
        order: 2;
    }
    #event-hyakaryouran-item-02 {
        flex-basis: 100%;
        text-align: left;
        order: 1;
    }
    .event-foto-size {
        width: 90vw;
    }
    .event-foto-size2 {
        width: 85vw;
    }

    /* 教育事業 */
    #education-pckatekyo-logo {
        width: 90%;
    }
    #education-keyboard-logo {
        width: 90%;
    }

    .responsive-br {
        display: block;
    }

}
