html,body{
  font-family: "Zen Old Mincho", serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #3b2113;
  line-height: 1.7;
  letter-spacing: 0.01em;
}
a{
  color: #3b2113;
  transition: opacity 0.3s, color 0.3s;
}
a:hover{ opacity: 0.7; }
a svg path{
  transition: fill 0.3s, stroke 0.3s;
}
img,picture{
	max-width: 100%;
	display: block;
}
.overflow{ overflow: hidden; }

#wrapper{
  width: 48rem;
  max-width: 100%;
  margin: 0 auto;
}


.w100{
  width: 100%;
}
section{
  position: relative;
}
a.cta-btn{
  display: block;
  width: 80%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.sec-2 a.cta-btn{
  top: 28%;
}
.sec-3 a.cta-btn{
  bottom: 1.5%;
}
.sec-10 a.cta-btn{
  bottom: 7%;
}


.form{
  background-color: #f0ece6;
  padding: 6rem 0;
}
.form .content{
  padding: 0 10%;
}
.form .h2-top{
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.2;
  color: #cfc0ad;
  text-align: center;
}
.form h2{
  text-align: center;
  font-size: 3.6rem;
  letter-spacing: 0.03em;
  margin-bottom: 4rem;
}
.form h3{
  display: flex;
  align-items: center;
  font-size: 2.4rem;
  font-weight: 400;
  letter-spacing: 0.03em;
  margin-bottom: 4rem;
}
.form h3::before{
  content: "";
  display: block;
  width: 1.1em;
  height: 0;
  border-top: 0.3rem solid;
  margin-right: 0.4em;
}
.form .label{
  display: flex;
  align-items: center;
  font-size: 2rem;
  font-weight: 700;
  margin: 2.4rem 0 0.4rem;
}
.form h4.label{
  margin-top: 4rem;
}
.form .label span{
  display: inline-block;
  font-size: 80%;
  line-height: 1.3em;
  border-radius: 0.65em;
  padding: 0 1em;
  background-color: #3b2113;
  color: #fff;
  margin-left: 1em;
}
.form .label .note{
  font-size: 1.6rem;
  font-weight: 400;
  margin-left: auto;
}
.form input[type=text],
.form input[type=tel],
.form input[type=email],
.form textarea{
  display: block;
  width: 100%;
  border-radius: 0.5rem;
  padding: 1em 0.8em;
  background: #fff;
  border: 1px solid #e9e3da;
  font-size: 2rem;
}
.form textarea{
  height: 20rem;
  resize: none;
}
.term-box{
  background: #fff;
  border: 1px solid #e9e3da;
  border-radius: 0.5rem;
  height: 20rem;
  overflow-y: scroll;
}
.term-box .inner{
  padding: 1em 1.2em;
}
.form button[type=submit]{
  display: block;
  width: 100%;
  background: none;
  border: none;
  margin: 4rem auto 0;
  transition: opacity 0.3s;
}
.form button[type=submit]:hover{
  opacity: 0.7;
}
.form .attention{
  text-align: center;
  font-weight: 700;
  margin-top: 0.5em;
}


.form.thanks{
  min-height: 100vh;
}




/* ボタン用アニメーション */
.pulse{ animation: pulse 1s infinite; }

@keyframes pulse {
  0%,100% { transform: scale3d(1, 1, 1); }
  50% { transform: scale3d(1.05, 1.05, 1.05); }
}


/* ページトップ */
#pagetop {
  display: none;
  position: fixed;
  bottom: 1.6rem;
  right: 1.6rem;
  z-index: 997;
}
#pagetop a {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100%;
  width: 4rem;
  height: 4rem;
  background-color: #e08d12;
}
#pagetop a img {
  width: 40%;
  margin-top: -5%;
}

/*　PC */
@media screen and (min-width: 801px){
.sp{ display: none !important; }

html{ font-size: 10px; }
body{ font-size: 1.4rem; }
}

/*　SP */
@media screen and (max-width: 800px){
.pc{ display: none !important; }

html{ font-size: 1.8vw; }
body{ font-size: 1.6rem; }

#wrapper{
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}

.form .content{
  padding: 0 6%;
}

#pagetop a {
  width: 5rem;
  height: 5rem;
}
}
