
.pc_br {
    display: block;
}

#sub {
    margin-top: 0px;
}

#sub_top {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}

#sub_top h2 {
    text-align: center;
    font-size: 32px;
    color: #fff;
    padding: 3% 0;
    box-sizing: border-box;
    letter-spacing: 1px;
}

#sub_main {}

.about_s1 {
    background: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2)),url(/theme/basic/img/sub/about_s1_01.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    padding: 20% 0;
    box-sizing: border-box;
    position: relative;
    display: none;
}

.about_s1_text {
    position: absolute;
    width: 100%;
    transform: translateY(-50%);
    top: 50%;
    overflow: hidden;
}

.about_s1 h2 {
    font-size: 100px;
    color: #fff;
    text-align: center;
    line-height: 1.5;
    padding-top: 20px;
}

.about_s1 p {
    font-size: 16px;
    color: #fff;
    text-align: center;
    letter-spacing: 5px;
    line-height: 3;
}

.about_s2 {
    margin-top: 200px;
    text-align: center;
}

.sub_text {
    overflow: hidden;
}

.sub_text h2 {
    font-size: 48px;
    text-align: center;
    margin-bottom: 40px;
}

.sub_text p {
    font-size: 14px;
    color: #797979;
    text-align: center;
}

.about_s2_div1 {
    overflow: hidden;
}

.about_s2_div1 h3 {
    color: #2969b0;
    font-size: 27px;
    margin-bottom: 40px;
}

.about_s2_div1 p {
    font-size: 17px;
    margin-bottom: 20px;
    line-height: 1.7;
    color: #292929;
}

.about_s2_div2 {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4,1fr);
    margin-top: 100px;
    overflow: hidden;
}

.about_s2_div2 > div {
    display: grid;
    justify-items: center;
}

.about_s2_div2 h2 {
    font-size: 14px;
    font-weight: normal;
    margin-top: 50px;
}

.about_s2_div2 p {
    font-size: 18px;
    font-weight: bold;
    margin-top: 30px;
}

.about_s3 {
    margin-top: 200px;
    text-align: center;
}

.about_s3_m {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    grid-gap: 30px;
    max-width: 600px;
    margin: 0 auto;
}

.about_s3_m > div {
    border: 2px solid #2969b0;
    color: #2969b0;
    background-color: #fff;
    border-radius: 10px;
    padding: 5%;
    box-sizing: border-box;
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.5px;
    cursor: pointer;
}

.about_s3_m .about_s3_m_c {
    color: #fff;
    background-color: #2969b0;
}

.about_s3_c {
    margin-top: 50px;
}

.about_s3_c_div {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    display: none;
    justify-content: center;
    overflow: hidden;
}


.about_s3_c_div_c {
    display: flex!important;
}

.about_s3_c_div > div {
    width: 100%;
    max-width: 600px;
}

.about_s3_c_div1 > div:first-child,
.about_s3_c_div2 > div:first-child,
.about_s3_c_div3 > div:first-child {
    transform: translateX(-100%);
    transition: ease-in-out 1.2s all;
    opacity: 0;
}

.about_s3_c_div1 > div:last-child,
.about_s3_c_div2 > div:last-child,
.about_s3_c_div3 > div:last-child {
    transform: translateX(100%);
    transition: ease-in-out 1.2s all;
    opacity: 0;
}

.about_s3_c_div_c > div:first-child,
.about_s3_c_div_c > div:last-child {
    transform: translateX(0);
    opacity: 1;
}


.about_s3_c_text {
    text-align: left;
    display: flex;
    justify-items: start;
    grid-gap: 10%;
    margin-top: 20px;
}

.about_s3_c_text:first-child {
    margin-top: 0;
}

.about_s3_c_text h2 {
    font-size: 16px;
}

.about_s3_c_text p {
    font-size: 14px;
    color: #797979;
    margin-top: 10px;
}

.about_s3_c_text p:first-child {
    margin-top: 0;
}

.about_s3_c_div img {
    width: 100%;
}

.about_s4 {
    margin-top: 200px;
    text-align: center;
}

.about_s4_div1 {
    max-width: 1100px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.about_s4_div1 h2 {
    color: white;
    width: 130px;
    height: 130px;
    line-height: 130px;
    border-radius: 50%;
    margin: 0 auto;
    background-color: #2969b0;
    font-size: 27px;
}

.about_s4_div1 .line {
    width: 2px;
    background-color: #2969b0;
    height: 50px;
}

.about_s4_div1 .line2 {
    width: 75%;
    background-color: #2969b0;
    height: 2px;
    border-right: 1px solid #2969b0;
    border-left: 1px solid #2969b0;
}

.about_s4_div1 .line3 {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4,1fr);
    justify-items: center;
}

.about_s4_div1 .line3 > div {
    background-color: #2969b0;
    width: 2px;
    height: 30px;
}

.about_s4_div1 > .div3 {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4,1fr);
}

.about_s4_div1 > .div3 > div {
    width: 70%;
    position: relative;
    transform: translateX(-50%);
    left: 50%;
    overflow: hidden;
}

.about_s4_div1 p {
    background-color: #2969b0;
    color: #fff;
    padding: 5px 0;
    box-sizing: border-box;
    font-size: 16px;
    border-radius: 10px;
}

.about_s4_div1 .line_2 {
    width: 2px;
    background-color: #2969b0;
    height: 20px;
    position: relative;
    transform: translateX(-50%);
    left: 50%;
}

.about_s4_div1 ul {
    display: grid;
    grid-template-columns: repeat(1,1fr);
    grid-gap: 10px;
    overflow: hidden;
}

.about_s4_div1 li {
    background-color: #eee;
    color: #000;
    padding: 5px 0;
    box-sizing: border-box;
    font-size: 16px;
    border-radius: 10px;
}

.about_s5 {
    margin-top: 200px;
}

.about_s5 ul {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-gap: 20px;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    align-items: center;
    margin-top: 50px;
    overflow: hidden;
}

.about_s5 ul img {
    width: 100%;
    padding: 0 20px;
    box-sizing: border-box;
}

.about_s6 {
    margin-top: 200px;
}

.about_s6 .div1 {
    display: grid;
    grid-template-columns: repeat(2,auto);
    grid-gap: 20px;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    overflow: hidden;
}

.about_s6 .text {
    color: rgb(122, 122, 122);
    font-size: 14px;
    line-height: 1.5;
}

.about_s6 ul {
    display: flex;
    flex-wrap: wrap;
    font-size: 14px;
    color: #565656;
    font-weight: bold;
    margin-top: 20px;
}

.about_s6 li:nth-child(odd) {
    width: 20%;
    margin-top: 10px;
}

.about_s6 li:nth-child(even) {
    width: 80%;
    margin-top: 10px;
}

.business_s1 {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    margin-top: 200px;
}

.business_s1 img {
    width: 100%;
}

.business_s1 > ul {
    display: grid;
    grid-template-columns: repeat(1,1fr);
    overflow: hidden;
}

.business_s1 li {
    display: flex!important;
    align-items: center;
    grid-gap: 50px;
}

.business_s1 > ul li div:first-child {
    width: 60%;
}

.business_s1 > ul li div:last-child {
    width: 40%;
    padding-right: 5%;
}

.business_s1 ul h2 {
    font-size: 32px;
}

.business_s1 p {
    font-size: 14px;
    margin-top: 30px;
}

.business_s1 .slick-dots {
    display: flex;
    justify-content: center;
    width: initial;
    transform: translateX(-65%);
    left: 65%;
}

.business_s2 {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    margin-top: 200px;
}

.business_s2_ul {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    grid-gap: 30px;
    margin-top: 50px;
    overflow: hidden;
}

.business_s2_ul li {
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
    text-align: center;
    padding: 10px 0;
    box-sizing: border-box;
}

.business_s2_ul p {
    font-size: 12px;
    color: red;
    margin-bottom: 10px;
}

.business_s2_ul h2 {
    font-size: 60px;
}

.business_s2_ul span {
    font-size: 22px;
}

.business_s2_div2 {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    margin-top: 50px;
}

.sub_nav {
    display: grid;
    justify-content: center;
    grid-gap: 20px;
    grid-template-columns: repeat(3,1fr);
    max-width: 700px;
    width: 100%;
    margin: 50px auto;
}

.sub_nav > div {
    border: 2px solid #2969b0;
    color: #2969b0;
    background-color: #fff;
    border-radius: 10px;
    padding: 10px;
    box-sizing: border-box;
    font-weight: bold;
    font-size: 18px;
    letter-spacing: 0.5px;
    cursor: pointer;
    text-align: center;
}

.sub_nav > .sub_nav_c {
    color: #fff;
    background-color: #2969b0;
}

.support_s {
    display: none;
    max-width: 1100px;
    width: 100%;
    margin: 0 auto;
    overflow: hidden;
}

.support_s2 {
    max-width: 1100px;
}

.support_s2 table {
    max-width: 800px;
    margin: 0 auto;
    width: 100%;
}

.support_s_c {
    display: flex;
    flex-direction: column;
}

.support_s #subject {
    font-size: 22px;
    font-weight: bold;
}

.support_s > .sub_text,
.support_s > .sub_text,
.support_s > .sub_text {
    transform: translateY(-100%);
    transition: ease-in-out 1.2s all;
    opacity: 0;
}

.support_s > .support_s1_div,
.support_s > .support_s2_div,
.support_s > .support_s3_div {
    transform: translateY(100%);
    transition: ease-in-out 1.2s all;
    opacity: 0;
}

.support_s_c > .support_s1_div,
.support_s_c > .support_s2_div,
.support_s_c > .support_s3_div {
    transform: translateY(0);
    transition: ease-in-out 1.2s all;
    opacity: 1;
}

.support_s_c > .sub_text,
.support_s_c > .sub_text,
.support_s_c > .sub_text {
    transform: translateY(0);
    transition: ease-in-out 1.2s all;
    opacity: 1;
}

.story_s1 {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    margin-top: 200px;
}

.story_s1_ul {
    display: grid;
    grid-template-columns: repeat(2, auto);
    margin-top: 50px;
    justify-content: space-between;
    grid-gap: 50px;
}

.story_s1_ul a {
    display: grid;
    grid-template-columns: repeat(1,1fr);
}

.story_s1_ul .summary {
    display: grid;
    grid-template-columns: repeat(1,1fr);
}

.story_s1_ul .subject {
    font-size: 20px;
    color: #333;
    margin-top: 10px;
    display: inline-block;
}

.story_s1_ul .date {
    font-size: 16px;
    color: #666;
    margin-top: 5px;
    display: inline-block;
} 

.pf {
    margin-top: 150px;
    background-image: url(/theme/basic/img/sub/pf_01.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    height: 200px;
}

.pf_02 {
    background-image: url/theme/basic/img/sub/pf_02.jpg);
}

@media all and (max-width:1100px) {}

@media all and (max-width:900px) {
    #sub {
        margin-top: 121px;
    }
    .about_s2,
    .about_s3,
    .about_s4,
    .about_s6,
    .business_s1,
    .business_s2,
    .story_s1 {
        margin-top: 100px;
    }
    .support_s {
        margin-top: 100px!important;
    }
    .about_s2_div1 h3 {
        font-size: 25px;
    }
    .about_s2_div1 p {
        padding: 0 10px;
        box-sizing: border-box;
    }
    .about_s3_c {
        padding: 0 10px;
        box-sizing: border-box;
    }
    .about_s6 .div1 {
        display: flex;
        flex-direction: column-reverse;
    }
    .map_iframe {
        width: 100%;
        height: 300px;
    }
    .about_s6 .text {
        padding: 0 10px;
        box-sizing: border-box;
    }
    .about_s6 li:nth-child(odd) {
        padding-left: 10px;
        box-sizing: border-box;
    }
    .business_s1 {
        padding: 0 10px;
        box-sizing: border-box;
    }
    .business_s1 li {
        grid-gap: 20px;
    }
    .business_s1 > ul li div:last-child {
        padding-right: 2%;
    }
    .story_s1_ul {
        grid-gap: 10px;
    }
    .story_s1_ul img {
        width: 100%;
    }
}

@media all and (max-width:600px) {
    #sub {
        margin-top: 116px;
    }
    .pc_br {
        display: none;
    }
    .sub_text h2 {
        font-size: 40px;
    }
    .about_s2_div2 {
        margin-top: 50px;
    }
    .about_s2_div2 p {
        font-size: 14px;
    }
    .about_s2_div1 h3 {
        font-size: 20px;
    }
    .about_s2_div1 p {
        font-size: 14px;
        padding: 0 20px;
        box-sizing: border-box;
    }
    .about_s3_m {
        padding: 0 10px;
        box-sizing: border-box;
    }
    .about_s3_m > div {
        font-size: 14px;
    }
    .about_s3_c_div_c {
        flex-direction: column-reverse;
        grid-gap: 10px;
    }
    .about_s3_c_text {
        padding-left: 10px;
        box-sizing: border-box;
    }
    .about_s4_div1 > .div3 > div {
        width: 95%;
    }
    .business_s2_ul h2 {
        font-size: 40px;
    }
    .business_s1 li {
        flex-direction: column;
    }
    .business_s1 > ul li div {
        width: 100%!important;
    }
    .business_s1 > ul li div:last-child {
        padding-right: initial;
        padding: 0 10px;
        box-sizing: border-box;
    }
    .story_s1_ul .subject {
        font-size: 16px;
    }
    .story_s1_ul .date {
        font-size: 14px;
    }
    .pf {
        margin-top: 50px;
        height: 150px;
    }
}