@charset "utf-8";
/* CSS Document */


#page_ttl::before {
    content: '';
    display: block;
    width: 70rem;
    height: 70rem;
    border-radius: 50%;
    background-color: #d1e8e6;
    position: absolute;
    top: 16rem;
    left: 56%;
    transform: translate(-50%,0);
    z-index: -2;
}

#page_ttl .bg {
    position: absolute;
    z-index: -1;
}
#page_ttl .img01 {
    width: 46.2rem;
    bottom: -20rem;
    left: 50%;
    transform: translate(-70rem, 0);
    z-index: -1;
}
#page_ttl .img02 {
    width: 33.6rem;
    top: 10rem;
    left: 50%;
    transform: translate(38rem, 0);
    z-index: -1;
}

@media screen and (max-width: 768px) {
#page_ttl::before {
    width: 30rem;
    height: 30rem;
    top: -4rem;
    left: 62%;
    z-index: -2;
}
#page_ttl .img01 {
    width: 18rem;
    bottom: -20rem;
    left: 50%;
    transform: translate(-20rem, 0);
    z-index: -1;
}
#page_ttl .img02 {
    width: 16rem;
    top: auto;
    bottom: -16rem;
    left: 50%;
    transform: translate(2rem, 0);
    z-index: -1;
}
}


/* #environment_con
----------------------------------------- */
#environment_con {
}
#environment_con .inner {
    padding-top: 20rem;
}
#environment_con .environment_list {
    display: flex;
    flex-flow: column;
    grid-gap: 10rem 0;
}
#environment_con .environment_list li h2 {
    font-size: 5rem;
    line-height: 1;
    font-weight: 700;
    color: #529dd1;
    text-align: center;
}
#environment_con .environment_list li h2 .number {
    font-size: 7.4rem;
    line-height: 1;
    font-weight: 600;
    margin-right: 1rem;
}

#environment_con .environment_list li .txt_wrap {
    font-size: 2.4rem;
    line-height: calc(42/24);
    letter-spacing: 0.1em;
    padding-top: 8rem;
}

#environment_con .layout {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 3rem;
}
#environment_con .environment_list li:nth-child(even) .layout {
    flex-flow: row-reverse;
}
#environment_con .layout .txt_wrap {
    width: calc(555 / 1200 * 100%);
}
#environment_con .layout .img_wrap {
    width: calc(605 / 1200 * 100%);
}
#environment_con .environment_list li:nth-child(odd) .layout .img_wrap {
    margin-right: -8rem;
}
#environment_con .environment_list li:nth-child(even) .layout .img_wrap {
    margin-left: -8rem;
}

@media screen and (max-width: 768px) {
#environment_con .inner {
    padding-top: 26rem;
}
#environment_con .environment_list {
    display: flex;
    flex-flow: column;
    grid-gap: 6rem 0;
}
#environment_con .environment_list li h2 {
    font-size: 2.5rem;
}
#environment_con .environment_list li h2 .number {
    font-size: 3.4rem;
    margin-right: 0.5rem;
}

#environment_con .environment_list li .txt_wrap {
    font-size: 1.6rem;
    padding-top: 2rem;
}

#environment_con .layout {
    margin-top: 1rem;
}
#environment_con .environment_list li:nth-child(even) .layout {
    flex-flow: column;
}
#environment_con .layout .txt_wrap {
    width: 100%;
}
#environment_con .layout .img_wrap {
    width: 100%;
    margin-top: 2rem;
}
#environment_con .environment_list li:nth-child(odd) .layout .img_wrap {
    margin-right: -4rem;
}
#environment_con .environment_list li:nth-child(even) .layout .img_wrap {
    margin-left: -4rem;
}
}


/* #atmosphere
----------------------------------------- */
#atmosphere {
}
#atmosphere .inner {
    padding-top: 6rem;
}

#atmosphere .atmosphere_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
#atmosphere .atmosphere_list > li {
    width: calc(372 / 1200 * 100%);
}
#atmosphere .atmosphere_list > li .img_wrap {
    overflow: hidden;
    border-radius: 1rem;
}

#atmosphere .sns_link {
    margin-top: 10rem;
}
#atmosphere .sns_link a {
    width: calc(100% - 9rem);
    height: 21.6rem;
    background: url("../images/environment_sns.jpg") no-repeat center center;
    background-size: cover;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin: auto;
}
#atmosphere .sns_link a .icon {
}
#atmosphere .sns_link a .txt_wrap {
    font-size: 2.7rem;
    margin: 0 4rem;
}
#atmosphere .sns_link a .btn_wrap {
    margin: 0;
}

@media screen and (max-width: 768px) {
#atmosphere .inner {
    padding-top: 6rem;
}

#atmosphere .atmosphere_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    grid-gap: 2rem 0;
}
#atmosphere .atmosphere_list > li {
    width: 100%;
}
#atmosphere .atmosphere_list > li .img_wrap {
    overflow: hidden;
    border-radius: 1rem;
}

#atmosphere .sns_link {
    margin-top: 5rem;
}
#atmosphere .sns_link a {
    width: 100%;
    height: auto;
    padding: 1.5rem 0.5rem;
    background: url("../images/environment_sns.jpg") no-repeat center center;
    background-size: cover;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin: auto;
}
#atmosphere .sns_link a .icon {
    width: 3rem;
}
#atmosphere .sns_link a .txt_wrap {
    font-size: 1.2rem;
    margin: 0 1rem;
}
#atmosphere .sns_link a .btn_wrap {
    width: 100%;
    display: flex;
    justify-content: center;
    margin: 0;
}
}


