@charset "utf-8";
/* CSS Document */
/* ALL */
body {
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
  width: 100%;
  font-size: 18px;
  color: #54361E;
  background-color: #F9F3EA;
}
b, strong, .bold {
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI semibold", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic", "Segoe UI", Verdana, Meiryo, sans-serif;
}
/*-------------  IEだけに適応 -------------*/
_:lang(x)::-ms-backdrop, .selector {
  font-family: "Segoe UI", Meiryo, sans-serif;
}
.container {
  width: 1000px;
  margin: 0 auto;
  padding: 80px 0;
  text-align: center;
  line-height: 1.5rem;
}
.flex {
  display: flex;
}
p, ul, li, th, td, h2 {
  line-height: 1.5rem;
}
/*------------- header -------------*/
header {
 background: url("/img/header_back.jpg") repeat-x center 0;
 color: #fff;
}
.header_box {
 width: 1000px;
 margin: 0 auto;
 justify-content: space-between;
 padding-top: 20px;
}
.head_text {
  font-size: 18px;
}
.head_text2 {
  font-size: 14px;
}
.logo_text {
  margin-bottom: 15px;
}
.tel_cont {
  flex-direction: column;
  align-content: center;
  align-items: center;
  margin: 10px 0 39px 0;
}
.tel_cont a {
  color: #fff;
}
.tel_cont a:hover {
  color: #D1BF21;
}
.tel {
 font-size: 45px;
 margin-bottom: 10px
}
.tel_text {
 font-size: 10px;
 margin-bottom: 10px;
}
.contact_cont {
  flex-direction: column;
  margin: 10px 0 0;
}
.contact_link a {
  font-size: 16px;
  color: #54361E;
  background: #fff;
  padding: 10px 20px;
  border-radius: 5px;
}
.contact_link {
  flex-direction: row;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 20px;
}
.contact_link a:hover {
  color: #fff;
  background: #D1BF21;
}

.line a {
  margin: 0 20px 0 0;
}
/*------------- background color -------------*/
section#worries {
  background-color: #F9F3EA;
}
section#fee {
  background-color: #F5ECDE;
}
section#shop {
  background-color: #F0E1CA;
}
/*------------- section1 -------------*/
h1{
	text-align: center;
	background: url("/img/main_back.png") no-repeat center 0;
	background-color: #F2E7D4;
}
.conta_01 {
  margin: auto;
  text-align: center;
}
div.treatment {
  width: 100%;
  text-align: center;
  background: url("/img/section1_back.png") no-repeat center 0;
  padding: 66px 85px;
}
.section1_text {
  padding-bottom: 46px;
}
.section1_p {
  text-align: left;

}
.reservation {
  background: url("/img/section1_3back.png") no-repeat center 0;
  margin: 25px 0 52px;
  text-align: center;
  padding: 30px 0 40px;
}
.reservation img {
  max-width: 506px;
  text-align: center;
  margin: 0 auto;
}
.section1_3 {
  justify-content: center;
}
.section1_3 div {
  width: 325px;
  text-align: center;
  margin: 0 20px;
}
.worries_link a {
  font-size: 20px;
  color: #fff;
  background: #D1BF21;
  padding: 15px 40px;
  border-radius: 8px;
}
p.worries_link {
  margin-bottom: 40px;
}
.worries_text {
  text-align: left;
  font-size: 14px;
}
/*------------- section2 -------------*/
.section2 {
  text-align: center;
}
.section2_cont {
  text-align: left;
  flex-wrap: wrap;
  justify-content: space-around;
}
.section2_cont div {
  width: 38%;
  margin: 0;
}
.section2_cont02 {
  margin-top: 50px;
}
.section2_cont div {
  margin-bottom: 30px;
  vertical-align: top;
}
.section2 ul {
  padding: 10px 0;
}
.section2 li {
  margin: 0 0 10px;
}
.section2 h2 {
  margin-bottom: 60px;
}
.section2 h3 {
  text-align: center;
  font-size: 25px;
  color: #D1BF21;

  padding-bottom: 30px;
  line-height: 1.8rem;
}
.gran_cont {
  justify-content: space-between;
  margin-bottom: 50px;
}
p.granpro_text {
  text-align: left;
}
.menu_cont {
  margin-bottom: 50px;
}
.section2_p {
  margin-bottom: 20px;
  font-size: 25px;
  line-height: 2.3rem;
  text-align: center;
}
.menu_p {
  margin-bottom: 20px;
}
.menu_p2 {
  margin-bottom: 20px;
  text-align: left;
}
.p2_cont {
  margin: 0 auto;
  text-align: center;
  width: 800px;
}
.p3_cont {
  margin: 0 auto;
  text-align: center;
  width: 650px;
}
.menu_p {
  text-align: left;
}
/*------------- section3 -------------*/
div.section3 {
  text-align: center;
}
.section3 h2 {
  margin: 0 0 40px;
}
.section3_p {
  margin-bottom: 40px;
  font-size: 25px;
  line-height: 2.3rem;
}
.shop_cont {
  justify-content: space-around;
  margin-bottom: 50px;
}
.map {
  margin-bottom: 50px;
}
/*------------- contact ------------- */
.conta_title h2, .conta_title span {
  line-height: 1.5rem;
}
#contact h2 img {
  margin-bottom: 60px;
}
.ta_wrap tr {
  text-align: left;
  background: #fff;
}
table.ta_wrap {
  margin: 3% auto;
  border: 1px solid #D1BF21;
}
.ta_wrap td {
  padding: 1.5% 3%;
  border-bottom: 1px solid #D1BF21;
}
td.ta_l {
  width: 30%;
  background: #F9F6DC;
  font-weight: 600;
}
.ta_c {
  width: 20%;
  border-right: 1px solid #D1BF21;
}
.con_ta {
  width: 100%;
  height: 200px;
}
.va_top {
  vertical-align: top;
}
input, textarea {
  border: solid 1px #ccc;
  padding: 2%;
}
.w380 {
  width: 100%;
}
a.btn_contact {
  width: 320px;
  padding: 15px;
  display: block;
  margin: 0 auto;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  background: #D1BF21;
  color: #fff !important;
  -moz-transition: -moz-transform 0.5s linear;
  -webkit-transition: -webkit-transform 0.5s linear;
  -o-transition: -o-transform 0.5s linear;
  -ms-transition: -ms-transform 0.5s linear;
  transition: transform 0.5s linear;
}
.btn_blue:hover {
  -webkit-transform: scale(1.1);
  -moz-transform: scale(1.1);
  -o-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}
.btn_gray {
  color: #D1BF21;
  line-height: 47px;
  width: 320px;
  display: block;
  margin: 0 auto;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  background: #eee;
}
.btn_gray:hover {
  background: #ccc;
}
.btn_gray a {
  color: #5C5C5C !important;
  display: block;
}
/*    other
*************************** */
.bg_red {
  color: #D90000;
  font-size: 140%;
  width: 60%;
  padding: 15px 50px;
  margin: 0 auto;
  text-align: center;
  border: 2px solid #D90000;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
}
.bg_red02 {
  color: #fff;
  font-size: 100%;
  padding: 5px;
  margin-bottom: 5px;
  background-color: #D90000;
  border-radius: 3px;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
}
/*------------- complete footer ------------- */
.ttl_wrap {
  min-height: calc(90vh - 90px);
}
/*------------- footer ------------- */
footer {
  background-color: #54361E;
  padding: 12px 0 15px;
 color: #fff;
}
footer p {
  text-align: center;
}
/* ====================================================================

                          spメニュー

==================================================================== */
/* ----------------------------500px以下---------------------------- */
@media (max-width: 500px) {
	.container {
   width: 100%;
   margin: 0 auto;
   padding: 10% 3%;
  }
 h1 img{
    width: 100%;
  }
  .container img {
    width: 100%;
  }
  header {
    width: 100%;
  }
  /*------------------------- header -------------------------*/
  header {
    background: url("/img/header_spback.jpg") repeat-x center 0;
   background-color: #54361E;
  }
  .header_box {
   width: 100%;
    flex-direction: column;
    padding: 10px 0 10px;
  }
  .logo_cont {
    width: 70%;
    margin: 0 auto 10px;
    text-align: center;
  }
  .logo_cont img {
    max-width: 255px;
  }
  .tel_cont {
    margin: 0 0 20px 0;
  }
  div.treatment {
    width: 100%;
    text-align: center;
    background: url(/img/section1_back.png) no-repeat center 0;
    padding: 10px;
  }
  .contact_cont {
    flex-direction: column;
    justify-content: center;
   margin-bottom: 20px;
  }
  header .contact_link {
    flex-direction: row;
    justify-content: center;
  }
  .logo_text,.head_text,.head_text2 {
    text-align: center;
  }
  /*------------------------- section1 -------------------------*/
  .section1_3 {
    margin: 0 auto;
    text-align: center;
    flex-direction: column;
    align-items: center;
  }
  .section1_3 div {
    margin: 0 0 30px;
  }
  .section1_textsp {
    padding-bottom: 30px;
    text-align: center;
  }
  .section1_textsp img {
    width: 100%;
  }
  div.treatment {
    background: url("/img/section1_backsp.png") no-repeat center 0;
  }
  .reservation {
    background: none;
    margin: 0;
    text-align: center;
    padding: 30px 10px 40px;
  }
  .reservation img {
    max-width: 506px;
    text-align: center;
    margin: 0 auto;
  }
  /*------------------------- section2 -------------------------*/
  .section2 h2 img {
    max-width: 300px;
  }
  .section2_cont {
    flex-direction: column;
  }
  .section2_cont div {
    width: 100%;
    margin-bottom: 30px;
  }
  .section2_cont02 {
    padding: 0 10px;
  }
  .gran_cont {
    flex-direction: column;
    margin-bottom: 0;
  }
  .gran_cont div {
    margin: 0 auto 20px;
  }
  .gran_cont div:nth-child(2) {
    max-width: 315px;
  }
  .granpro {
    text-align: center;
  }
  .section2 h3 {
    padding-bottom: 15px;
  }
  .p2_cont {
    text-align: left;
    width: 100%;
  }
  .p3_cont {
    text-align: left;
    width: 100%;
  }
  /*------------- section3 -------------*/
  #shop .container {
    padding: 10% 3%;
  }
  div.section3 {
    text-align: center;
  }
  .section3 h2 {
    margin: 0 0 40px;
  }
  .shop_img img {
    margin-bottom: 30px;
  }
  .section3_p {
    text-align: left;
    margin-bottom: 20px;
    font-size: 16px;
    line-height: 1.5rem;
  }
  .shop_cont {
    flex-direction: column;
    justify-content: center;
    margin-bottom: 40px;
  }
  .shop_cont div:nth-child(1) {
    margin-bottom: 30px;
  }
  .shop_cont img {
    max-width: 417px;
  }
  .map {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    margin-bottom: 15%;
  }
  .map_iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .map_bottom {
    margin-bottom: 20px;
  }
  /*------------- contact ------------- */
  #contact .container {
    width: 100%;
  }
  #contact h2, #contact span {
    line-height: 1.5rem;
  }
  #contact h2 img {
    margin-bottom: 50px;
  }
  table.ta_wrap {
    margin: 10% auto;
  }
  .contact_p {
    text-align: left;
    margin-bottom: 20px;
  }
  .btn_cont {
    justify-content: space-around;
  }
  .conta_title p {
    text-align: left;
  }
  /*------------- footer ------------- */
  .fs {
    font-size: 12px;
  }
  footer p {
    font-size: 12px;
  }
}