/* CSS Document */
div.contact{
  box-sizing: border-box;
}
body[wc-view-type="sp"] div.contact{
  padding: var(--headerHeight) 7vw calc(var(--headerHeight) + 16vw) 7vw;
}
body[wc-view-type="tb"] div.contact{
  padding: var(--headerHeight) 8vw calc(var(--headerHeight) + 13vw) 8vw;
}
body[wc-view-type="tb-l"] div.contact{
  padding: var(--headerHeight) 8vw calc(var(--headerHeight) + 13vw) 8vw;
}
body[wc-view-type="pc"] div.contact{
  padding: var(--headerHeight) calc((100vw - 1100px) / 2) calc(var(--headerHeight) + 128px) calc((100vw - 1100px) / 2);
}
div.contact p.c_top_text{
  line-height: 1.8rem;
  font-weight: 300;
}
body:not([wc-view-type="sp"]) div.contact p.c_top_text{
  text-align: center;
}
div.contact div.contact_tel{
  border: solid 1px #2fb2cf;
  padding: 1rem;
  box-sizing: border-box;
  margin: 1rem 0;
}
body:not([wc-view-type="sp"]) div.contact div.contact_tel{
  width: 400px;
  margin: 1rem auto 1rem auto;
}
div.contact div.contact_tel p.contact_title{
  text-align: center;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #2fb2cf;
  font-size: 1.2rem;
}
div.contact div.contact_tel p.tel_text{
  font-weight: 300;
  padding: 0.5rem 1rem;
  box-sizing: border-box;
}
div.contact div.contact_tel div.tel_btn{
  padding: 0 1rem;
  box-sizing: border-box;
}
div.contact div.contact_tel div.tel_inner{
}
div.contact div.contact_tel div.tel_inner a{
  display: table;
  padding-left: 2.5rem;
  position: relative;
  z-index: 1;
  margin: 0 auto;
  text-decoration: none;
  font-size: 1.5rem;
  color: #333;
  font-family: "Number";
  font-weight: 700;
}
div.contact div.contact_tel div.tel_inner a::before{
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  -webkit-mask-image: var(--wciconsrc);
  mask-image: var(--wciconsrc);
  -webkit-mask-position: center center;
  mask-position: center center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: cover;
  mask-size: cover;
  width: 2.5rem;
  height: 2.5rem;
  background-color: #333;
}
div.contact div.contact_tel div.tel_time{
  display: flex;
  flex-direction: column;
  align-items: center;
}
div.contact div.contact_tel div.tel_time > p{
  display: flex;
  align-items: center;
}
div.contact div.contact_tel div.tel_time > p::before{
  content: "営業時間";
  font-size: 0.85rem;
  border: solid 1px #2fb2cf;
  color: #2fb2cf;
  width: 4.6rem;
  margin-right: 0.5rem;
  box-sizing: border-box;
  padding: 0 0.5rem;
  flex: none;
  height: 20px;
}
form{
  margin-top: 2rem;
}
body[wc-view-type="tb"] form{
  margin-top: 3rem;
}
body[wc-view-type="tb-l"] form,
body[wc-view-type="pc"] form{
  width: 750px;
  margin: 3rem auto 0 auto;
}
form > dl{
  display: flex;
  margin-bottom: 1rem;
}
form > dl:last-of-type{
  margin-bottom: 0;
}
body[wc-view-type="sp"] form > dl{
  flex-direction: column;
}
form > dl dt{
  font-size: 0.9rem;
}
body[wc-view-type="sp"] form > dl dt{
  margin-bottom: 0.5rem;
}
body[wc-view-type="tb"] form > dl dt{
  width: 150px;
}
body[wc-view-type="tb-l"] form > dl dt,
body[wc-view-type="pc"] form > dl dt{
  width: 200px;
}
form > dl dd{
}
body[wc-view-type="sp"] form > dl dd{
}
body[wc-view-type="tb"] form > dl dd{
  width: calc(100% - 150px);
}
body[wc-view-type="tb-l"] form > dl dd,
body[wc-view-type="pc"] form > dl dd{
  width: calc(100% - 200px);
}
form dl dd select,
form dl dd input,
form dl dd div.textareawrap textarea{
  background-color: #fff !important;
  width: 100% !important;
  border: solid 1px #c3c3c3 !important;
  font-weight: 300 !important;
  font-size: 0.9rem !important;
}
form dl dd select,
form dl dd input{
  height: 40px;
}
form dl dd.select{
  position: relative;
  z-index: 1;
}
form dl dd.select select{
  text-indent: 0.35em;
}
form dl dd.select::after{
  content: "";
  width: 40px;
  height: 40px;
  -webkit-mask-image: var(--wciconsrc);
  mask-image: var(--wciconsrc);
  -webkit-mask-position: center center;
  mask-position: center center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: cover;
  mask-size: cover;
  background-color: #333;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 2;
}
div.soushin{
  display: table;
  margin: 1rem auto 0 auto;
  position: relative;
  z-index: 1;
}
div.soushin::after{
  content: "";
  width: 1.5rem;
  height: 1.5rem;
  -webkit-mask-image: var(--wciconsrc);
  mask-image: var(--wciconsrc);
  -webkit-mask-position: center center;
  mask-position: center center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: cover;
  mask-size: cover;
  background-color: #fff;
  position: absolute;
  right: 1rem;
  top: 50%;
  z-index: 2;
  transform: translateY(-50%);
}
div.soushin button{
  background-color: #2fb2cf;
  color: #fff;
  padding: 0.65rem 3.5rem 0.5rem 1.25rem;
  display: flex;
  align-items: center;
  font-size: 1.25rem;
  font-weight: 500;
}
::placeholder{
  color: rgba(47,178,207,1);
}