@charset "utf-8";
@import "anime.css";

/*
------------
company.css
------------
*/
/* page_container */
#page_container {
    background: linear-gradient(180deg, #2C414A 0%, #19333E 25.1%, #000 100%);
    padding: 0 0 125px 0;
}
@media only screen and (max-width: 768px) {
    #page_container {
        padding: 0 0 80px 0;
    }
}
/* figure main */
figure.main {
    width: calc(100vw * 1350 / 1500);
    margin: 95px 0 0 auto;
}
@media only screen and (max-width: 768px) {
    figure.main {
        width: calc(100vw * 335 / 375vw);
        margin: 60px 0 0 auto;
    }
}
/* mvv_area */
#mvv_area {
    margin: 140px 0 0 0;
}
#mvv_area .inner {
    width: calc(100vw * 1200 / 1500);
    max-width: 1200px;
    margin: 0 auto;
    font-feature-settings: "palt";
}
#mvv_area .inner h3.stit {
    color: #fff;
}
#mvv_area .inner h3.stit span.sub {
    color: #BAC1C5;
}
#mvv_area .inner .mvv_list {
    margin: 125px 0 0 0;
}
#mvv_area .inner .mvv_list article:not(:first-child) {
    margin: 120px 0 0 0;
}
#mvv_area .inner .mvv_list article h4 {
    font-family: "Lato", sans-serif;
    font-size: 2.8rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: #BAC1C5;
}
#mvv_area .inner .mvv_list article h4 span {
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    font-weight: 400;
    margin: 10px 0 0 0;
}
#mvv_area .inner .mvv_list article dl {
    color: #fff;
}
#mvv_area .inner .mvv_list article:nth-child(-n + 2) dl {
    margin: 40px 0 0 0;
}
#mvv_area .inner .mvv_list article dl dt {
    font-size: 3.8rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.5;
}
#mvv_area .inner .mvv_list article dl dd {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.8;
    margin: 25px 0 0 0;
}
#mvv_area .inner .mvv_list article .element {
    margin: 40px 0 0 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
}
#mvv_area .inner .mvv_list article .element dl {
    width: calc(100vw * 560 / 1500);
    max-width: 560px;
}
#mvv_area .inner .mvv_list article .element dl:nth-child(n + 3) {
    margin: 65px 0 0 0;
}
#mvv_area .inner .mvv_list article .element dl dt span {
    font-family: "Lato", sans-serif;
    font-size: 2.2rem;
    font-weight: 600;
    display: inline-block;
    margin: 0 0 0 15px;
    letter-spacing: 0.05em;
}
@media only screen and (max-width: 768px) {
    #mvv_area {
        margin: 90px 0 0 0;
    }
    #mvv_area .inner {
        width: 90vw;
        max-width: 90vw;
    }
    #mvv_area .inner .mvv_list {
        margin: 80px 0 0 0;
    }
    #mvv_area .inner .mvv_list article:not(:first-child) {
        margin: 80px 0 0 0;
    }
    #mvv_area .inner .mvv_list article:nth-child(-n + 2) dl {
        margin: 25px 0 0 0;
    }
    #mvv_area .inner .mvv_list article dl dt {
        font-size: 3.2rem;
    }
    #mvv_area .inner .mvv_list article dl dd {
        margin: 15px 0 0 0;
        text-align: justify;
    }
    #mvv_area .inner .mvv_list article .element {
        margin: 25px 0 0 0;
        display: block;
    }
    #mvv_area .inner .mvv_list article .element dl {
        width: 100%;
        max-width: 100%;
    }
    #mvv_area .inner .mvv_list article .element dl:not(:first-child) {
        margin: 40px 0 0 0;
    }
    #mvv_area .inner .mvv_list article .element dl:nth-child(n + 3) {
        margin: 40px 0 0 0;
    }
    #mvv_area .inner .mvv_list article .element dl dt span {
        margin: 0 0 0 10px;
    }
}
/* profile_area */
#profile_area {
    padding: 125px 0 150px 0;
}
#profile_area .inner {
    width: calc(100vw * 1200 / 1500);
    max-width: 1200px;
    margin: 0 auto;
}
#profile_area .inner figure {
    margin: 125px 0 80px 0;
}
#profile_area .inner h4 {
    font-size: 3.8rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: #304751;
}
#profile_area .inner dl.outline {
    margin: 40px 0 0 0;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.7;
    border-bottom: 1px solid #BAC1C5;
}
#profile_area .inner dl.outline dt {
    width: 15em;
    font-weight: 500;
    padding: 15px 20px;
    border-top: 1px solid #BAC1C5;
}
#profile_area .inner dl.outline dd {
    width: calc(100% - 15em);
    border-top: 1px solid #BAC1C5;
    padding: 15px 20px;
}
#profile_area .inner dl.outline dd ul {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
#profile_area .inner dl.outline dd ul:not(:first-child) {
    margin: 10px 0 0 0;
}
#profile_area .inner dl.outline dd ul li:nth-child(1) {
    width: 10em;
}
#profile_area .inner dl.outline dd ul li:nth-child(2) {
    width: calc(100% - 10em);
}
#profile_area .inner .access_header {
    margin: 125px 0 0 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}
#profile_area .inner .access_header p a {
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    padding: 0 20px 0 0;
    text-decoration: underline;
    color: #1900E6;
    position: relative;
    transition: all .3s ease;
}
#profile_area .inner .access_header p a:hover {
    opacity: .6;
}
#profile_area .inner .access_header p a::before {
    content: "";
    width: 13px;
    height: 13px;
    background-image: url(../../images/global/ico_blank_blue.svg);
    background-repeat: no-repeat;
    background-size: 100% auto;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
}
#profile_area .inner .map {
    width: 100%;
    height: 600px;
    margin: 40px 0 0 0;
}
#profile_area .inner .map iframe {
    width: 100%;
    height: 100%;
}
@media only screen and (max-width: 768px) {
    #profile_area {
        padding: 80px 0 100px 0;
    }
    #profile_area .inner {
        width: 90vw;
        max-width: 90vw;
    }
    #profile_area .inner h3 span.sub {
        line-height: 1.5;
    }
    #profile_area .inner figure {
        margin: 65px 0;
    }
    #profile_area .inner h4 {
        font-size: 3.2rem;
    }
    #profile_area .inner dl.outline {
        margin: 30px 0 0 0;
        font-size: 1.4rem;
        letter-spacing: 0.075em;
        line-height: 1.6;
    }
    #profile_area .inner dl.outline dt {
        width: 7em;
        padding: 10px;
    }
    #profile_area .inner dl.outline dd {
        width: calc(100% - 7em);
        padding: 10px;
    }
    #profile_area .inner dl.outline dd ul {
        display: block;
    }
    #profile_area .inner dl.outline dd ul li:nth-child(1) {
        width: 100%;
    }
    #profile_area .inner dl.outline dd ul li:nth-child(2) {
        width: 100%;
    }
    #profile_area .inner .access_header {
        margin: 80px 0 0 0;
    }
    #profile_area .inner .access_header p a {
        font-size: 1.4rem;
    }
    #profile_area .inner .map {
        height: 360px;
        margin: 30px 0 0 0;
    }
}