@charset "utf-8";
/*基本*/
body { font-family: "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,  "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; font-weight: normal; color: #231815; }

/*
font-size:1.6remはスマホで大きいので、font-size:1.4remに変更した
全体的に0.2rem程度小さくした
*/

p { font-size: 1.4rem; line-height: 1.5;}

ol, ul{ list-style-type:none; }
li { font-size: 1.4rem; line-height: 1.5;}

a:hover { /*opacity: 0.5; transition: all .5s cubic-bezier(.165,.84,.44,1);*/}
a {text-decoration: none; color: #231815; font-size: 1.6rem;  line-height: 1.5;/*transition: all .5s cubic-bezier(.165,.84,.44,1);*/ text-decoration-color: #00893A;}

table { border-collapse: collapse; }
th { font-size: 1.4rem; line-height: 1.5; font-weight: normal; text-align: center; padding: 10px; border: solid 1px #000;}
td { font-size: 1.4rem; line-height: 1.5; padding: 10px; border: solid 1px #000;}

dt { font-size: 1.4rem; line-height: 1.5;}
dd { font-size: 1.4rem; line-height: 1.5;}

.inner { width: 90%; max-width: 1000px; margin: 0 auto 50px;}

/*headline*/
.headlineGreen { font-size: 2.0rem; font-weight: 700; text-align: center; color: #009844; margin-bottom: 10px;}
.headlineGreenSmall { font-size: 2.0rem; font-weight: 700; text-align: center; color: #009844; margin-top: 20px; margin-bottom: 10px;}
.headlineCenterRed { font-family: "IBM Plex Sans JP", sans-serif; font-size: 1.8rem; font-weight: 700; color: #e50020; text-align: center; margin: 30px 0 20px;}
.headlineCenterSmall { font-family: "IBM Plex Sans JP", sans-serif; font-size: 1.6rem; font-weight: 700; color: #009844; text-align: center; margin: 30px 0 20px;}
.headlineIcon { display: flex; justify-content: flex-start; gap: 5px; font-family: "IBM Plex Sans JP", sans-serif; font-size: 1.8rem; font-weight: 700; background: #ecf5ed; border-left: solid 10px #009844; padding: 5px; padding-left: 15px;}
.headlineIcon .icon { display: flex; width: 35px; border: solid 2px #009844; background: #fff; padding: 1px 3px 0; border-radius: 5px;}
.headlineIcon .icon img { width: 100%; height: auto;}

/*header*/
.headerArea { margin-bottom: 20px; border-top: solid 5px #009844; }
.headerLogoArea { display: flex; justify-content: center; align-items: center; gap: 10px; padding: 20px 0; border-bottom: solid 1px #666;}
.headerLogo { width: 50px;}
.headerTitle { font-family: "IBM Plex Sans JP", sans-serif; font-weight: 700; font-size: 1.8rem; }
.headerTitle span { display: block; font-size: 1.8rem; color: #009844;}

.indicatorNavArea { background: #dddddd; padding: 30px 0 20px; margin-bottom: 30px;}
.indicatorNav { display: flex; justify-content: center; gap: 50px; position: relative; z-index: 0;}
.indicatorNav::before { content: ""; display: block; width: 75%; height: 10px; background: #fff; position: absolute; top: 15px; left: 50%; transform: translateX(-50%); z-index: -1;}
.indicatorBox { width: 100px;}
.indicatorBox p { text-align: center; font-family: "IBM Plex Sans JP", sans-serif; font-size: 1.4rem; font-weight: 700; line-height: 1.2; color: #727171;}
.number { display: block; width: 40px; height: 40px; font-size: 2.0rem; line-height: 1; color: #fff; background: #727171; padding: 10px 0; border-radius: 50px; text-align: center; margin: 0 auto 10px;}
.indicatorBox.now p { color: #009844;}
.indicatorBox.now .number { background-color: #009844;}

/*footer*/
.footerArea { background: #999; padding: 4rem 2rem; }
.footerArea ul { display: flex; justify-content: center; }
.footerArea ul li { margin: 0 2rem; }
.footerArea ul li a { padding: 0.7rem 1.4rem; font-size: 1.6rem; color: #fff; }
.footerArea ul li a:hover { background: rgba(255, 255, 255, 0.3); }


/*error*/
.errMsg { color: #e50020; font-size: 1.4rem;}
.errMsgCenter { color: #e50020; font-size: 1.8rem; text-align: center;}

/*shoplist*/
.shopBox { margin-bottom: 50px;}
.shopBox + .shopBox { border-top: solid 1px #999; padding-top: 80px; margin-top: 100px;}
.shopImgBox { margin-bottom: 50px; }

.shopImgBox { display: flex; justify-content: center; align-items: center; gap: 10px; max-width: 700px; margin: 0 auto 20px;}
.shopImg { width: calc( (100% - 20px) / 3 );}
.noImg { height: 100%; background: #eaf5fc;}

.shopDataBox { display: flex; justify-content: space-between; gap: 10px; margin-bottom: 10px;}
.shopDataBox dt { width: 110px; font-size: 1.3rem; color: #fff; background: #009844; border-radius: 5px; text-align: center; padding: 3px 0 5px; display: flex; align-items: center; justify-content: center; }
.shopDataBox dd { width: calc(100% - 125px); font-size: 1.4rem;}
.googleMap { width: 100%; aspect-ratio: 6 / 3;}
.googleMap iframe { width: 100%; height: 100%;}

.iconBox { display: flex; justify-content: flex-start; gap: 12px; flex-wrap: wrap; margin: 12px auto;}
.iconBox li { width: 75px; }
.iconBox .icon { display: flex; justify-content: center; align-items: center; width: 100%; height: 75px; border: solid 5px #009844; border-radius: 10px; padding: 5px; aspect-ratio: 1 / 1;}
.iconBox .icon img { width: 100%; height: 100%; object-fit: contain;}
.iconBox .text { display: block; font-family: "IBM Plex Sans JP", sans-serif; text-align: center; font-size: 1.2rem; line-height: 1.2; font-weight: 700; margin-top: 5px;}
.iconBox li.grayBox .icon { border-color: #9d9d9d;}

/*予約画面*/
.reservationData { display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; flex-wrap: wrap; border: solid 2px #009844; margin-bottom: 10px; padding: 5px;}
.reservationData dt { display: flex; justify-content: space-between; align-items: center; width: 185px; padding: 5px 10px;}
.reservationData dt .hissu { background: #e50020; padding: 1px 5px 3px; color: #fff; font-size: 1.1rem; border-radius: 5px; margin-left: 10px;}
.reservationData dd { width: calc(100% - 205px); }
.reservationData input { width: 100%; font-size: 1.6rem; border: solid 1px #ccc; padding: 5px 10px;}
.privacyCheckArea { display: flex; justify-content: center; align-items: center; margin-bottom: 30px;}
.privacyCheckArea a { color: #00a0e9; text-decoration: underline;}
.privacyCheckArea a:hover { text-decoration: none;}
@media only screen and (max-width:768px){
    .reservationData { gap: 0; }
    .reservationData dt { width: 100%; justify-content: flex-start; }
    .reservationData dd { width:100%; }
    
}
/*予約作業内容*/
.workItem { display: flex; justify-content: flex-start; gap: 10px; margin: 20px 0 20px 10px;}
.workCheck { width: 40px;}
.workCheck input { width: 30px; height: 30px; margin: 0;}
.workCont { width: calc( 100% - 50px);}
.workName { font-size: 2.0rem; font-weight: 700; border: solid 1px #89c997; padding: 5px 10px;}
.workDetail { border: solid 1px #89c997; padding: 10px; margin-top: 3px; font-size: 1.4rem;}
.workFlex { display: flex; justify-content: flex-start; gap: 3px; margin-top: 3px;}
.workTime { width: 150px; border: solid 1px #89c997; padding: 5px 10px;}
.workTime span { font-size: 1.2rem; color: #009844; padding-right: 10px;}
.workPrice { width: calc( 100% - 153px); border: solid 1px #89c997; padding: 5px 10px;}
.workPrice span { font-size: 1.2rem; color: #009844; padding-right: 10px;}
.reservationBtnArea { margin-top: 50px;}

/*予約日時*/
.tableCalenderHeader { display: flex; justify-content: space-between; background: #ecf5ed; border: solid 2px #5a5858; padding: 10px;}
.reservationCalenderTitle { font-size: 1.8rem; font-family: "IBM Plex Sans JP", sans-serif; font-weight: 700;}
.reservationCalenderBtn { width: 20px; height: 25px; background: #009944;}
.reservationCalenderPrevBtn { clip-path: polygon(0% 50%, 100% 0%, 100% 100%);}
.reservationCalenderNextBtn { clip-path: polygon(0% 0%,100% 50%, 0% 100% );}
.tableCalender { width: 100%; border: solid 2px #5a5858; border-top: none;}
.tableCalender th { border: solid 1px #5a5858; border-top: none; font-weight: bold; }
.tableCalender td { border: solid 1px #5a5858; border-top: none; text-align: center;}
.tableCalender td.selected { background: #fff100;}
.tableCalenderDay th:first-child { color: #e50020;}
.tableCalenderDay td:first-child { color: #e50020;}
.tableCalenderDay td { background-color: #f5f5f5; color: #666; }
.tableCalenderDay td a { width: 100%; height: 100%; display: block; background: #fff; padding: 10px; }
.tableCalenderDay td:has(a) { padding: 0; }
.tableCalender td.selected a { background: #fff100; }
.tableCalenderTime .available { color: #009844; font-weight: 700;}
.tableCalenderTime .unavailable { color: #e50020; font-weight: 700;}
.tableCalenderTime td { font-size: 1.2rem; }

/*予約確認*/
.confirmationBox { margin-bottom: 40px;}
.confirmationItem { display: flex; justify-content: flex-start; align-items: flex-start; gap: 10px; margin-left: 10px; margin: 10px; border-bottom: solid 1px #009844;}
.confirmationItem dt { flex: 0 0 120px; width: 120px; /*font-size: 1.6rem;*/ font-size: 1.4rem; color: #009844; font-weight: 700; padding: 0.5rem; padding-left: 10px; }
.confirmationItem dd { /*font-size: 1.8rem;*/ font-size: 1.6rem; padding: 0.5rem; }

/*キャンセル画面*/
.cancelData { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 20px; border: solid 2px #009844; margin-bottom: 10px; padding: 5px;}
.cancelData dt { display: flex; justify-content: space-between; align-items: center; width: 200px; padding: 5px 10px;}
.cancelData dt .hissu { background: #e50020; padding: 1px 5px 3px; color: #fff; font-size: 1.1rem; border-radius: 5px; margin-left: 10px;}
.cancelData dd { width: calc(100% - 220px); }
.cancelData input { width: 100%; font-size: 1.6rem; border: solid 1px #ccc; padding: 5px 10px;}
.cancelData select { width: 100%; font-size: 1.6rem; border: solid 1px #ccc; padding: 5px 10px;}
@media only screen and (max-width:768px){
    .cancelData { gap: 0; }
    .cancelData dt { width: 100%; }
    .cancelData dd { width: 100%; }


}
.cancelConf { align-items: center;}
.cancelConf dd { padding: 5px 10px; font-size: 2.0rem; font-weight: 700;}

/*ボタン*/
.greenBtn { width: 70%; max-width: 350px; margin: 10px auto;}
.greenBtn a { display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #e50020; color: #fff; padding: 3px 5px; border-radius: 5px; padding: 3px 0 5px; text-align: center;}
.redBtn { width: 70%; max-width: 350px; margin: 10px auto;}
.redBtn a { display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #009844; color: #fff; padding: 3px 5px; border-radius: 5px; padding: 3px 0 5px; text-align: center;}
.yellowBtn { width: 70%; max-width: 350px; margin: 10px auto;}
.yellowBtn a { display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #fff000; color: #231815; padding: 3px 5px; border-radius: 5px; padding: 3px 0 5px; text-align: center;}

button.redBtn { width: 70%; max-width: 350px; margin: 10px auto; display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #e50020; color: #fff; border-radius: 5px; padding: 3px 10px 5px; text-align: center; cursor: pointer;}
button.greenBtn { width: 70%; max-width: 350px; margin: 10px auto; display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #009844; color: #fff; border-radius: 5px; padding: 3px 10px 5px; text-align: center; cursor: pointer;}
button.yellowBtn { width: 70%; max-width: 350px; margin: 10px auto; display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #fff000; color: #231815; border-radius: 5px; padding: 3px 10px 5px; text-align: center; cursor: pointer;}

input[type=submit].redBtn { width: 70%; max-width: 350px; margin: 10px auto; display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #e50020; color: #fff; border-radius: 5px; padding: 3px 10px 5px; text-align: center; cursor: pointer; border: none; }
input[type=submit].greenBtn { width: 70%; max-width: 350px; margin: 10px auto; display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #009844; color: #fff; border-radius: 5px; padding: 3px 10px 5px; text-align: center; cursor: pointer; border: none; }
input[type=submit].yellowBtn { width: 70%; max-width: 350px; margin: 10px auto; display: block; width: 100%; font-family: "IBM Plex Sans JP", sans-serif; font-size: 2.0rem; font-weight: 700; background: #fff000; color: #231815; border-radius: 5px; padding: 3px 10px 5px; text-align: center; cursor: pointer; border: none; }

.btnFlex { display: flex; justify-content: center; gap: 15px; align-items: center; flex-wrap: wrap; }

@media only screen and (max-width:768px){
    .greenBtn { width: 100%; }
    .redBtn { width: 100%; }
    .yellowBtn { width: 100%; }
    button.redBtn { width: 100%; }
    button.greenBtn { width: 100%; }
    button.yellowBtn { width: 100%; }
    input[type=submit].redBtn { width: 100%; }
    input[type=submit].greenBtn { width: 100%; }
    input[type=submit].yellowBtn { width: 100%; }
}


.slider { width: calc(100% - 80px); margin: 0 auto 3rem; overflow: hidden; }
.slides { display: flex; }
.slides img { width: 100%; flex-shrink: 0; display: block; }



/*TOP*/
.homeVisual { width: 100%; height: 50vh; background: url(../images/homeImage.jpg) no-repeat center center; background-size: cover; margin-top: -20px; }
.homeVisual .inner { position: relative; height: 100%; }
.homeVisual h2 { position: absolute; left: 0; top: 20%; font-size: 3.0rem; font-weight: 600; color: #fff; text-shadow: 0px 0px 10px rgba(5, 24, 63, 0.78); font-family: "IBM Plex Sans JP", sans-serif; line-height: 1.8; }
@media only screen and (max-width:768px){
    .homeVisual { height: 40vh; background: url(../images/homeImage.jpg) no-repeat right center; background-size: cover; }
    .homeVisual h2 { left: 0; top: 60%; font-size: 1.4rem; }
}
.homeUse { background: #009944; padding: 4rem 0; }
.homeUse h3 { font-size: 2.0rem; font-weight: 600; color: #fff; text-align: center; margin: 2rem auto 1rem; padding-bottom: 3rem; position: relative; }
.homeUse h3::after { content: ''; border-bottom: solid 3px #fff; position: absolute; bottom: 0; left: calc( 50% - 25px); width: 50px; } 
.homeUse .flex { display: flex; justify-content: center; flex-wrap: wrap; padding: 2rem 3%; }
.homeUse .step { width: calc( 94% / 3 ); padding: 2rem; margin: 1%; font-size: 1.8rem; font-weight: 500; color: #333; background: rgba(255, 255, 255, 0.2); border-radius: 2rem; }
.homeUse .step p { text-align: center; }
.homeUse .step span:nth-of-type(1) { background: #fff000; color: #009944; font-size: 2.0rem; font-weight: 700; padding: 1rem 2rem; border-radius: 50px; margin-right: 2rem; font-family: "IBM Plex Sans JP", sans-serif; display: block; width: 50px; margin: 1rem auto; }
.homeUse .step span:nth-of-type(2) { /*background: #fff000;*/ color: #fff; font-size: 2.2rem; font-weight: 600; padding: 0; }
.homeUse .step img { width: 100%; margin-top: 2rem; }
@media only screen and (max-width:768px){
    .homeUse { padding: 4rem 0 0.5rem; }
    .homeUse .step { font-size: 1.3rem; width: 100%; }
    .homeUse .step span:nth-of-type(1) { padding: 1rem 1.7rem; font-size: 1.5rem; }
    .homeUse .step span:nth-of-type(2) { font-size: 1.5rem; }
    .homeUse .step p { width: 100%; text-align: center; }
    .homeUse .step img { width: 100%; }

}
.homeNavi { padding: 4rem 0; font-family: "IBM Plex Sans JP", sans-serif; }
.homeNavi .inner { display: flex; justify-content: center; align-items: center; }
.homeNavi .inner a { width: 40%; margin: 5%; padding: 3rem 0; text-align: center; font-size: 2.2rem; font-weight: 600; background: #009844; border-radius: 10px; font-family: "IBM Plex Sans JP", sans-serif; }
.homeNavi .inner a:hover { opacity: 0.8; }
.homeNavi .inner a:nth-of-type(1) { background: #00893A; color: #fff; }
.homeNavi .inner a:nth-of-type(2) { background: #fff000; color: #231815; }
@media only screen and (max-width:768px){
    .homeNavi .inner a { font-size: 1.6rem; }
}

/*住所から検索*/
.searchArea { padding: 2rem 0 4rem; }
.searchArea div { max-width: 600px; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; margin: 1rem auto; }
.searchArea input[type=text] { border: solid 2px #009944; padding: 1rem; margin: 0 auto; width: 83%; }
.searchArea label { font-size: 1.6rem; font-weight: 600; color: #333; width: 15%; text-align: right; }
.searchArea input[type=submit] { width: 40%; margin: 5%; padding: 1rem 0; text-align: center; font-size: 1.6rem; font-weight: 600; background: #009844; border-radius: 50px; font-family: "IBM Plex Sans JP", sans-serif; background: #00893A; color: #fff; border: none; }
.searchArea a { width: 40%; margin: 5%; padding: 1rem 0; text-align: center; font-size: 1.6rem; font-weight: 600; background: #009844; border-radius: 50px; font-family: "IBM Plex Sans JP", sans-serif; background: #666; color: #fff; border: none; }
@media only screen and (max-width:768px){
    .searchArea input[type=text] { width: 100%; }
    .searchArea label { width: 100%; text-align: center; }
}
.searchResalt { padding: 2rem; background: #f5f5f5; }
.searchResalt table { width: 100%; margin: 0 auto; border: none; }
.searchResalt table th { border: none; border-bottom: solid 2px #009944; padding: 0.5rem; font-size: 1.6rem; font-weight: 600; text-align: center; color: #00893A; }
.searchResalt table td { border: none; border-bottom: solid 1px #999; padding: 1.4rem 0.5rem; font-size: 1.6rem; font-weight: 500; color: #333; }
.searchResalt table td a { text-decoration: underline; }
.searchResalt table td a:hover { background: #faf4a8; }
.searchResalt .pagination { display: flex; justify-content: center; align-items: center; margin: 2rem auto; font-size: 1.6rem; font-weight: 500; }
.searchResalt a.btn { width: 40%; margin: 2rem auto; padding: 1rem 0; text-align: center; font-size: 1.6rem; font-weight: 600; background: #009844; border-radius: 50px; font-family: "IBM Plex Sans JP", sans-serif; background: #009944; color: #fff; border: none; }
@media only screen and (max-width:768px){
    .searchResalt table th { display: none; }
    .searchResalt table td { width: 100%; display: block; position: relative; padding-left: 25%; font-size: 1.3rem; }
    .searchResalt table td::before { content: attr(data-label); position: absolute; left: 10px; top: 14px; width: 20%; font-weight: bold; }
    .searchResalt table td:nth-of-type(1) { background: #009944; padding-left: 10px; margin-top: 4rem; }
    .searchResalt table td:nth-of-type(1) a { color: #fff; font-size: 1.4rem; text-decoration: none; }
    .searchResalt table td:nth-of-type(1)::before { content: none; }
    .searchResalt table tr { display: block; }
    .searchResalt a.btn { width: 90%; font-size: 1.4rem; }
}

/*地図から検索*/
.mapArea { padding: 2rem 0; }
#map { width: 100%; height: 70vh; margin-bottom: 2rem; }
.mapArea a.btn { width: 40%; margin: 2rem auto; padding: 1rem 0; text-align: center; font-size: 1.6rem; font-weight: 600; background: #009844; border-radius: 50px; font-family: "IBM Plex Sans JP", sans-serif; background: #009944; color: #fff; border: none; }
.gm-style-iw-d a { display: block; width: 100%; margin: 0.5rem auto; padding: 0.5rem; text-align: center; font-size: 1.3rem; font-weight: 600; background: #009844; border-radius: 50px; font-family: "IBM Plex Sans JP", sans-serif; background: #009944; color: #fff; border: none; }
@media only screen and (max-width:768px){
    .mapArea a.btn { width: 90%; }
}

/*各ページ共通*/
.page .pageVisual { background: url(../images/pageVisualBg.jpg) no-repeat top center; background-size: cover; padding: 10rem 0; }
.page .pageVisual h2 { font-size: 3.0rem; font-weight: 600; color: #00893A; letter-spacing: 0.5rem; }
.page .pageContent { font-size: 1.6rem; font-weight: 400; color: #333; line-height: 1.4; }
.page .pageContent h4 { font-size: 1.8rem; font-weight: 500; color: #333; margin-bottom: 1.6rem; }
.page .pageContent h5 { font-size: 1.6rem; font-weight: 500; color: #333; }
.page .pageContent p { font-size: 1.6rem; font-weight: 400; color: #333; margin: 1.6rem 0; }
.page .pageContent h4 + p { padding-left: 2rem; }
.page .pageContent h4 + p + p { padding-left: 2rem; }
.page .pageContent ul { list-style-type: circle; margin: 1.6rem 0; padding-left: 3.2rem; }
.page .pageContent ol { list-style-type: decimal; margin: 1.6rem 0; padding-left: 3.2rem; }
.page .pageContent li { font-size: 1.6rem; font-weight: 400; color: #333; margin: 1.6rem 0; }
.page .pageContent .contWrap { margin: 4.8rem 0 1.6rem; }
.page .pageContent dl { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; margin: 1.4rem auto; padding: 0.7rem 0; border-bottom: dashed 1px #ccc; width: 80%; }
.page .pageContent dl dt { font-weight: 500; color: #333; font-size: 1.6rem; margin-right: 2rem; width: 20%; }
.page .pageContent dl dd { font-weight: 400; color: #333; font-size: 1.6rem; width: 75%; }
@media only screen and (max-width:768px){
    .page .pageVisual h2 { font-size: 2.4rem; }
    .page .pageVisual { padding: 3rem 0 2rem; }
    .page .pageContent dl dt { width: 100%; padding-bottom: 1rem; }
    .page .pageContent dl dd { width: 100%; }
}