@charset "UTF-8";

/*==============================
トップページ
===============================*/

#TopCont .ObjLeft,
#TopCont .ObjRight {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 40px;
    position: relative;
}
#TopCont .ObjRight {
    flex-direction: row-reverse;
}
@media (max-width: 900px) {
    #TopCont .ObjLeft,
    #TopCont .ObjRight {
        flex-direction: column;
    }
}
#TopCont .ObjLeft:after,
#TopCont .ObjRight:after {
    content: "";
    background-color: #e2e9f7;
    position: absolute;
    padding: 100px;
    width: 70%;
    height: 100%;
    z-index: -1;
}
#TopCont .ObjLeft:after {
    right: 0;
}
#TopCont .ObjRight:after {
    left: 0;
}

@media (max-width: 900px) {
    #TopCont .ObjLeft:after,
    #TopCont .ObjRight:after {
        right: 0;
        top: 10px;
        width: 100%;
    }
}

#TopCont .ObjLeft .Obj,
#TopCont .ObjRight .Obj {
    width: 43%;
}
@media (max-width: 900px) {
    #TopCont .ObjLeft .Obj,
    #TopCont .ObjRight .Obj {
        width: 80%;
    }
}

#TopCont .ObjLeft .Text,
#TopCont .ObjRight .Text {
    width: 52%;
    text-align: justify;
    letter-spacing: -.1px;
}
#TopCont .ObjLeft .Text {
    padding: clamp(60px, 8vw, 100px) 6% clamp(60px, 8vw, 100px) 0;
}
#TopCont .ObjRight .Text {
    padding: clamp(60px, 8vw, 100px) 0 clamp(60px, 8vw, 110px) 6%;
}
@media (max-width: 900px) {
    #TopCont .ObjLeft .Text,
    #TopCont .ObjRight .Text {
        width: 100%;
        padding: 40px 6vw;
    }
}
#TopCont .ObjRight .Text .Button {
    font-size: 1.3em;
    font-weight: bold;
}

#TopCont .ObjLeft .Text .Detail,
#TopCont .ObjRight .Text .Detail {
    font-weight: bold;
    margin-top: 40px;
}
#TopCont .ObjLeft .Text .Detail a,
#TopCont .ObjRight .Text .Detail a {
    color: #000;
    position: relative;
}

#TopCont .ObjLeft .Text .Detail a::before,
#TopCont .ObjLeft .Text .Detail a::after,
#TopCont .ObjRight .Text .Detail a::before,
#TopCont .ObjRight .Text .Detail a::after {
  content: "";
  position: absolute;
  right: -1em;
  width: 12px;
  height: 2px;
  border-radius: 9999px;
  background-color: #000;
  transform-origin: calc(100% - 2px) 50%;
}

#TopCont .ObjLeft .Text .Detail a::before,
#TopCont .ObjRight .Text .Detail a::before {
  transform: rotate(30deg);
  top: calc(50% - 1px);
}

#TopCont .ObjLeft .Text .Detail a::after,
#TopCont .ObjRight .Text .Detail a::after {
  transform: rotate(-30deg);
  top: calc(50% - 0px);
}

#TopCont .ObjLeft .Text .Button a
#TopCont .ObjRight .Text .Button a {
    font-weight: bold;
    font-size: 1.1em;
}


#TopNews .TopNewsTitle {
    background-image: url(../img/top/bg_news.jpg);
    background-position: top center;
    height: 300px;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    margin-bottom: 90px;
}
#TopNews .TopNewsTitle h2 {
    background-color: #fff;
    width: 500px;
    height: 80px;
    margin:0 auto -.3em;
    text-align: center;
    padding-top: .7em;
    font-size: 3.2em;
    color: #3a3a3a;
    font-family: "Viga", sans-serif;
}
@media (max-width: 900px) {
    #TopNews .TopNewsTitle h2 {
        font-size: 2em;
    }
}
#TopNews .NewsBox {
    padding: 30px 50px;
    border: 1px solid #a8a8a8;
    height: 320px;
    overflow-y: scroll;
    margin-bottom: 60px;
}
#TopNews .NewsBox dl {
    padding: 1.1em 0;
    display: flex;
    flex-wrap: nowrap;
    border-bottom: 1px solid #a8a8a8;
}
@media (max-width: 900px) {
    #TopNews .NewsBox dl {
        flex-direction: column;
    }
}
#TopNews .NewsBox dl dt {
    width: 8em;
}
#TopNews .NewsBox dl dd {
    width: calc(100% - 8em);
    line-height: 1.6;
}
@media (max-width: 900px) {
    #TopNews .NewsBox dl dd {
        width: 100%;
    }
}
