/* reset CSS */
*,*::before,*::after{box-sizing:border-box}*{margin:0}html,body{height:100%}body{line-height:1.5;-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}#root,#__next{isolation:isolate}
dl,ol,ul{margin-bottom:0;}

.pc{
    display: block;
}
.sp{
    display: none;
}
p{
    margin: 0;
}
header{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
header a img{
    width: 5rem;
}
.header_address{
    display: flex;
    font-size: 0.7rem;
    text-align: right;
    gap: 0.2rem;
}
.businessHour{
    color: #2C979E;
    font-size: 0.7rem;
    text-align: right;
    margin: 0 1rem;
}

.firstViewSection{
    background-image: url("../img/fvBg.png");
    background-size: 100%;
    padding: 2rem;
}
.firstViewContent{
    position: relative;
    border-radius: 8px;
    background-color: #fff;
    width: 65%;
    margin: auto;
    padding: 2rem;
}
.firstViewContent .fvLogo{
    margin: 1.5rem 0;
    width: 7rem;
    height: auto;
}
.firstViewContent .fvIcon{
    position: absolute;
    width: 15dvw;
    right: 1rem;
    top: 1rem;
}
.firstViewContent p{
    margin-bottom: 1rem;
}

.centerContent{
    width: 56%;
    margin: auto;
}
.secondContent p{
    font-size: 0.98rem;
    margin-bottom: 2rem;
}

h1{
    color: #30A2AB;
    font-size: 2.5rem;
}

h2{
    margin-top: 2rem;
    color: #fff;
    border-radius: 8px;
    background: #30A2AB;
    padding: 1rem;
}

.bgwhite{
    background-color: #fff;
}
.bggray{
    background: #F8F8FA;
    padding: 2rem 0;
}
.bggray2{
    background: #F1F5F8;
}

.toggleBox{
    background: #fff;
    border-radius: 8px;
}
.toggleList{
    display: flex;
    color: #344243;
    justify-content: space-around;
}

.toggleList li{
    width: auto;
    padding: 1rem;
}
.toggleList li:hover{
    opacity: 0.3;
}

.toggleList li.active{
    color: #2C979E;
    border-bottom: 3px solid #2C979E;
}

.toggleData{
    padding: 1rem;
}
.toggleData p{
    display: none;
    font-size: 0.9rem;
}

.toggleData p.active{
    display: block;
}

h3{
    font-weight: 700;
    border-left:4px solid #2C979E;
    padding-left: 1rem;
    font-size: 1.4rem;
}
.menu1{
    white-space: nowrap;
}
.menu1 li {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    font-weight:600;
    align-items:baseline;
}
.menu1 li p{
    font-size: 1.0dvw;
    color: #344243;
}
.line{
    width: 100%;
    padding: 0.4rem 0;
}
.line div{
    height: 2px;
    background: #DCE7E8;
}

.menu1 li p.price{
    /* font-size: 1.4rem; */
    font-size: 1.7dvw;
    color: #2C979E;
    font-weight:700;
}
.menu1 li p.price span{
    font-size: 0.8rem;
}
.caution{
    color: #597072;
    font-size: 0.8rem;
}
h4{
    margin-top: 2rem;
    color: #fff;
    border-radius: 8px;
    background: #30A2AB;
    padding: 1rem;
}

.accessContent{
    display: flex;
    justify-content: space-between;
    /* gap: 3rem; */
}

.accessContent .map{
    width: 60%;
}

h5{
    font-size: 1.5rem;
    font-weight: 900;
}

.accessContent div p{
    color: #597072;
    font-size: 12px;
    font-weight: 500;
}
.map iframe{
    width: 100%;
}

.ourContent{
    padding: 3.8rem 0;
    background-image: url("../img/our.png");
    background-repeat: no-repeat;
    background-position: right;
    background-size: auto;
    font-size: 2dvw;
}
h6{
    font-size: 1.3rem;
    font-weight: 900;
}
.desc{
    color: #597072;
    font-size: 1rem;
}
footer{
    align-items: center;
    padding: 1.2rem;
    color: #597072;
    font-weight: 500;
    text-align: center;
    font-size: 0.9rem;
}
footer p{
    margin: 0;
}
@media screen and (max-width: 980px) {
    .pc{
        display: none;
    }
    .sp{
        display: block;
    }

    .firstViewSection{
        padding: 1rem 0;
    }
    .firstViewContent, .centerContent{
        /* padding: 0; */
        width: 90%;
        margin: auto;
    }
    .firstViewContent{
        background-color: rgb(255, 255, 255, 0.7)
    }
    .firstViewContent p{
        font-size: 3dvw;
    }

    h1{
        font-size: 5.1dvw;
        text-align: center;
    }
    h2{
        font-size: 1.3rem;
    }
    p{
        margin: 0;
    }
    .toggleList{
        font-size: 1.7dvw;
    }
    .menu1 li{
        align-items: center;
        gap: 0.3rem;
        margin-bottom: 1rem;
    }
    .menu1 li{
        align-items: center;
        gap: 0.3rem;
        margin-bottom: 1rem;
    }
    .menu1 li p{
        width: 280dvw;
        font-size: 4dvw;
        white-space:break-spaces;
    }
    .menu1 li p.price{
        width: auto;
        white-space: nowrap;
        font-size: 4dvw;
    }
    .accessContent{
        display: block;
    }
    .accessContent div{
        margin-bottom: 1rem;
    }
    .accessContent .map{
        width: 100%;
    }
    .ourContent{
        font-size: 3.5dvw;
        background-color: rgb(255, 255, 255, 0.7);
    }
    h6{
        font-size: 3.3dvw;
    }
    .desc{
        font-size: 2.5dvw;
    }
    .ourContent p{
        background-color: rgb(255, 255, 255, 0.7);
    }
}
