@charset "UTF-8";
/* CSS Document */
.common_sub_contents .column {
    background-color: #f8f8f8;
}
.intro{
    padding-top: 12rem;
    margin-bottom: 12rem;
}
.intro .inner{
    width: min(80%,1400px);
    margin: 0 auto;
}
.intro .inner h3{
    font-size: clamp(22px,3rem,32px);
    font-weight: 600;
    padding-bottom: 4rem;
}
.intro .inner h3 .green{
    color: #01d765;
}
.intro .inner h3>span{
    display: block;
}
.intro .inner h3>span:first-of-type{
    margin-bottom: 1.8rem;
}
.intro .inner .text{
    font-size: clamp(14px,2rem,18px);
}
.intro .inner .text p{
    padding-bottom: 2.2rem;
}
.location{
    background-color: #f8f8f8;
    border-radius: 120px 0 0 0;
    padding: 12rem 0 14rem;
}
.location .inner{
    width: min(80%,1400px);
    margin: 0 auto;
}
.location .inner .column{
    display: flex;
}
.location .inner .column .section_title{
    width: 28%;
}
.location .inner .column .container{
    width: 72%;
}
.location .inner .column .container .image{
    width: 100%;
    margin-bottom: 3rem;
    border-radius: 20px;
    overflow: hidden;
}
.location .inner .column .container .place_name{
    padding-bottom: 1.7rem;
    font-size: clamp(20px,2.6rem,22px);
    font-weight: 600;
    line-height: 1.4;
}
.location .inner .column .container .info{
    width: 100%;
}
.location .inner .column .container .info tr th,
.location .inner .column .container .info tr td{
    font-size: clamp(15px,1.5rem,17px);
    padding: 1.8rem 0;
    text-align: left;
    border-top: solid 1px #DBDBDB;
}
.location .inner .column .container .info tr:last-of-type th,
.location .inner .column .container .info tr:last-of-type td{
    border-bottom: solid 1px #DBDBDB;
}
.location .inner .column .container .info tr th{
    width: 25%;
    font-weight: 600;
}
.location .inner .column .container .info tr td{
    width: 75%;
    padding: 1.8rem 0 1.8rem 1.8rem;
}
.location .inner .column .container .info .address{
    display: flex;
    align-items: center;
}
.location .inner .column .container .info .address .map{
    display: block;
    height: 16px;
    width: auto;
    padding-left: 5px;
}
.location .inner .column .container .info .address .map:hover{
    opacity: .7;
}
.location .inner .column .container .info .address .map img{
    height: 100%;
    width: auto;
}
.location .inner .column .container .info .official_site{
    color: #01d765;
    display: inline-block;
    padding-right: 22px;
    padding-bottom: 2px;
    border-bottom: solid 1px #01d765;
    background: url("../img/common/external.png")right center/14px auto no-repeat;
}
.location .inner .column .container .info .official_site:hover{
    opacity: .6;
}


@media print, screen and (max-width: 1024px){
    .location .inner .column{
        display: block;
    }
    .location .inner .column .section_title{
        margin-bottom: 7rem;
        width: 100%;
    }
    .location .inner .column .container{
        width: 100%;
    }
    
}


@media print, screen and (max-width: 760px){
    .intro{
        padding-top: 14rem;
        margin-bottom: 14rem;
    }
    .intro .inner{
        width: 100%;
        padding: 0 5rem;
    }
    .intro .inner h3{
        font-size: 4rem;
        padding-bottom: 5rem;
    }
    .intro .inner .text{
        font-size: 3.2rem;
    }
    .intro .inner .text p{
        padding-bottom: 3rem;
    }
    .intro .inner .text p:last-of-type{
        padding-bottom: 0;
    }
    .intro .inner .text p br{
        display: none;
    }
    .location{
        border-radius: 12rem 0 0 0;
        padding: 14rem 0 14rem;
    }
    .location .inner{
        width: 100%;
        padding: 0 5rem;
    }
    .location .inner .column .container .image{
        margin-bottom: 4rem;
        border-radius: 10px;
    }
    .location .inner .column .container .place_name {
        padding-bottom: 3rem;
        font-size: 3.8rem;
    }
    .location .inner .column .container .info tr th,
    .location .inner .column .container .info tr td{
        display: block;
        width: 100%;
    }
    .location .inner .column .container .info tr th{
        padding: 4rem 0 1.5rem;
        font-size: 2.8rem;
        line-height: 1;
    }
    .location .inner .column .container .info tr td{
        border-top: none;
        padding: 1.5rem 0 4rem;
        font-size: 3.2rem;
        line-height: 1;
    }
    .location .inner .column .container .info tr:last-of-type th{
        border-bottom: none;
    }
    .location .inner .column .container .info .official_site{
        line-height: 1.8;
        display: inline;
        padding-bottom: 0;
        padding-right: 4rem;
        background: url(../img/common/external.png)right center/3rem auto no-repeat;
    }
}