/* ================================
  メールフォーム
  MB→PC min-width:768px
================================ */
#mf {
  padding: 30px 0 0;
}
.readTxt h2 {
  font-size: 20px;
}
.ctaddBox {
  margin-bottom: 10px;
  text-align: center;
}
.ctaddBox strong {
  display: block;
  font-size: 24px;
  font-family: "Times New Roman", Times, serif;
}
.ctaddBox h3 span {
  padding-top: 10px;
  font-size: 14px;
}
.ctaTit {
  font-size: 20px;
  text-align: center;
}
.mtTit {
  margin-bottom: 20px;
}
.ctaTit b {
  padding-bottom: 10px;
  border-bottom: 2px dotted #333;
}
.fleBox {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-top: 15px;
}
.fleBox .txt {
  width: 52%;
  text-align: left;
}
.fleBox .txt p:first-child {
  padding-top: 0;
}
.fleBox img {
  width: 46%;
  height: auto;
}
.readBox {
  margin-bottom: 20px;
}
.mkReq {
  font-size: 0.8em;
  font-weight: bold;
  color: #C00;
}
.subTxt {
  font-size: 90%;
}
#mf .readTxt .line {
  display: inline-block;
  position: relative;
  margin: 0 auto;
  padding: 0 0 15px;
  text-align: left;
}
#mf .readTxt .line:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 8px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #000, #000 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #000, #000 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* お問合せ先 アコーディオン */
.ctaddBox input {
  position: absolute;
  opacity: 0;
  z-index: -1;
}
.ctadtabs {
  overflow: hidden;
  border-top: none;
  border-bottom: 0;
}
.ctadtab {
  width: 100%;
  overflow: hidden;
  background-color: #f5f3e9;
}
.ctadtab-content {
  color: #333;
  padding: 0 15px 20px;
}
.ctadtab-content .telBox {
display: block;
}

.txt p {
  padding-top: 0;
  text-align: center;
}
.mfFlex {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.ctadImg {
  width: 200px;
  height: auto;
  margin: 20px auto 15px;
}
.chkPolicy {
  padding: 10px 20px 0;
}
.mBtaC {
  text-align: center;
}
.txt b {
  margin-right: 0.5em;
}
#mf .fSnml {
font-size: 14px;
font-weight: normal;
}

@media screen and (max-width: 767px) {
  .ctadTab-label {
    display: flex;
    position: relative;
    justify-content: space-between;
    padding: 10px 10px 10px 30px;
    font-weight: bold;
    cursor: pointer;
    background-color: #D1C9B2;
  }
  .ctadTab-label::after {
    position: absolute;
    top: 50%;
    left: 2%;
    transform: translateY(-50%);
    content: "\276F";
    width: 1em;
    height: 1em;
    line-height: 1;
    text-align: center;
    transition: all .35s;
  }
  .ctadtab-content {
    max-height: 0;
    padding: 0;
  }
  .ctaddBox input:checked + .ctadTab-label::after {
    transform: rotate(90deg);
    top: 30%;
  }
  .ctaddBox input:checked ~ .ctadtab-content {
    max-height: 100%;
    padding: 0 15px 20px;
  }
}
@media screen and (min-width: 768px), print {
  .mBtaC {
    text-align: left;
  }
  .ctadtab {
    display: flex;
    align-items: center;
  }
  .ctadTab-label {
    width: 140px;
    padding: 20px 0;
    cursor: auto;
    background-color: #f5f3e9;
  }
  .ctadtab-content {
    margin: 20px 0;
    padding: 0 15px;
    border-left: 2px dotted #333;
  }
  .ctadtab-content p:first-child {
    padding-top: 0;
  }
  .ctadtab-content .txt, .ctadtab-content .txt p {
    text-align: left;
  }
  .ctaddBox {
    display: block;
    align-items: stretch;
  }
  .ctaddBox h3 {
    width: 180px;
    margin-right: 20px;
    padding-right: 20px;
    border-right: 2px dotted #333;
  }
  .ctaddBox strong {
    display: inline-block;
    padding-right: 20px;
  }
  .ctaddBox br {
    display: none;
  }
  .ctaddBox h3 span {
    display: block;
    padding-top: 0;
  }
  .mtTit {
    margin-bottom: 30px;
  }
  .fleBox img {
    width: 200px;
    height: auto;
  }
  .ctaTit b {
    font-size: 24px;
  }
  .ctadImg {
    width: 200px;
    height: auto;
    margin: 0 20px 0 0;
  }
  .chkPolicy {
    text-align: center;
    padding: 10px 0 0;
  }
  .ckGrp.iptW li {
  width: 100% !important;
  }
  .ckGrp.iptW li label {
  display: inline-block;
  width: auto;
  }
}
/* お問合せ先 アコーディオンここまで */
/*アコーディオン部分*/
#planSlt .mfTab-label {
  display: block;
  font-size: 16px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  background: #D1C9B2;
  margin: 0;
  padding: 10px 15px 10px 30px;
  text-decoration: none;
  cursor: pointer;
}
#mf input.chckIp {
  position: absolute;
  opacity: 0;
  z-index: -1;
}
.mftabs {
  overflow: hidden;
  border-top: none;
  border-bottom: 0;
}
.mftab {
  width: 100%;
  overflow: hidden;
}
.mfTab-label {
  display: flex;
  position: relative;
  justify-content: space-between;
  padding: 1em;
  font-weight: bold;
  cursor: pointer;
}
.mfTab-label::after {
  position: absolute;
  top: 50%;
  left: 0.5em;
  transform: translateY(-50%);
  content: "\276F";
  width: 1em;
  height: 1em;
  line-height: 1;
  text-align: center;
  transition: all .35s;
}
.mftab-content {
  max-height: 0;
  color: #333;
}
#mf input.chckIp:checked + .mfTab-label::after {
  transform: rotate(90deg);
  top: 30%;
}
#mf input.chckIp:checked ~ .mftab-content {
  max-height: 100%;
}
/* アコーディオンここまで */
/**/
.mfBox {
  margin-bottom: 30px;
  padding-top: 0;
  background-color: #EBE8DF;
}
.noteBox {
  margin: 0 0 20px;
  padding: 10px 5% 15px;
  background-color: #FFBFC4;
  border: none;
}
.noteBox p {
  padding-top: 5px;
}
.mfBox dl {
  margin: 0 10px 5px;
  padding: 10px;
  border-bottom: 1px dotted #FFFFFF;
}
.mfBox dt {
  font-size: 16px;
  font-weight: bold;
  float: none;
  width: auto;
}
.mfBox b {
  color: #C00;
}
.mfBox dd {
  display: block;
  overflow: auto;
  zoom: 1;
}
.mfBox input, .mfBox select, .mfBox textarea {
  margin-bottom: 5px;
  padding: 8px;
  font-size: 16px;
}
/* #planSlt */
#planSlt {
  margin: 0 0 10px;
  padding: 10px 0 0;
}
#planSlt .pricebox {
  margin: 0;
  padding: 10px 0 0;
}
.planSltSec {
  border: 2px solid #D1C9B2;
  margin: 0 0 10px 0;
  padding: 15px 10px;
}
.planSltSecTit {
  color: #756946;
  font-size: 14px;
  margin: 0 0 10px;
  padding: 0;
}
.planSltSecTit b {
  font-size: 18px;
}
.planSltSec table {
  width: 100%;
}
.planSltSec table th, .planSltSec table td {
  display: block;
  text-align: left;
}
.planSltSec table th {
  padding-top: 10px;
}
.planSltSec table td {
  padding-bottom: 10px;
  border-bottom: 1px dotted #FFF;
}
.planSltSec table td p {
  padding-top: 0;
}
.sltBtnTit {
  margin: 15px 0 10px 30px;
  padding: 0;
  color: #C00;
  font-size: 16px;
  font-weight: bold;
}
#sltBtn {
  margin: 0 10px 5px;
  padding: 0;
  list-style: none;
}
#sltBtn li {
  margin-top: 15px;
}
#sltBtn li .sbtn {
  display: block;
  font-size: 18px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: bold;
  background: #D1C9B2;
  margin: 0;
  padding: 8px 12px 8px 28px;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
}
#sltBtn li .sbtn .mfTab-label::before, #sltBtn li .sbtn .mfTab-label::after {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0.6em;
  margin: auto;
  content: "";
  vertical-align: middle;
}
#sltBtn li .sbtn h4 {
  text-align: left;
}
#sltBtn dl {
  margin-top: 0;
  margin-bottom: 5px;
  padding: 10px;
  border-bottom: 1px dotted #FFFFFF;
  margin-left: 0px;
}
#sltBtn .mfBox dt {
  float: left;
  width: 150px;
}
#sltBtn .mfBox b {
  color: #C00;
}
#sltBtn .mfBox dd {
  display: block;
  overflow: auto;
  zoom: 1;
}
#sltBtn .mfBox dd p {
  margin: 0 0 5px 0 !important;
}
#sltBtn .mfBox dd input, #sltBtn .mfBox dd select {
  margin-bottom: 5px;
  padding: 5px;
}
#sltBtn ul.ckGrp, ul.ckGrp {
  padding: 0;
  list-style: none;
}
#sltBtn ul.ckGrp li {
  display: block;
  margin: 1px 10px 0 0;
}
#sltBtn ul.ckGrp input {
  position: static;
  opacity: 100;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .conteSpFix.full {
    padding-left: 0;
    padding-right: 0;
  }
  .sltBtnTit {
    margin: 15px 10px 10px;
  }
  #sltBtn dl {
    margin-right: 0;
    padding: 10px 0 0;
  }
}
@media screen and (min-width: 768px), print {
  #mf {
    padding: 40px 0 0;
  }
  #mf .conteSpFix {
    margin: 0 auto;
  }
  #sltBtn li .sbtn {
    text-align: left;
  }
  .noteBox p {
    padding: 0 0 10px;
  }
  .readTxt h2 {
    font-size: 32px;
  }
  .mfBox {
    margin-bottom: 30px;
    padding-top: 30px;
  }
  .mfBox dl {
    margin: 0 30px 5px;
    padding: 20px 10px 10px;
  }
  .mfBox dt {
    float: left;
    width: 150px;
    font-weight: normal;
  }
  .mfBox dd p:first-child {
    padding-top: 0;
  }
  .planSltSec table th, .planSltSec table td {
    display: table-cell;
  }
  .planSltSec table th {
    width: 150px;
    padding-top: 0;
    border-bottom: 1px dotted #FFF;
  }
  .planSltSec table td {
    padding: 15px 10px 5px;
  }
  .planSltSec table td p {
    margin: 0;
    padding: 0;
  }
  #sltBtn {
    margin: 0 30px;
  }
  #sltBtn ul.ckGrp, ul.ckGrp {
    display: flex;
    flex-wrap: wrap;
  }
  .noteBox {
    border: 1px solid #C00;
    margin: 0 30px 10px;
    padding: 10px 10px 0;
    background-color: transparent;
  }
}
.wL input, .wL textarea {
  width: 98%;
}
/* 複数選択 */
.ckGrp input {
  margin-right: 5px;
}
.ckGrp li {
  margin: 1px 0 0;
  font-size: 16px;
  width: auto;
  float: none;
  font-weight: bold;
}
.ckGrp.col3 li {
  font-size: 16px;
}
.ckGrp li label {
  display: block;
  padding: 5px 0 4px 10px;
  width: 100%;
}
@media screen and (min-width: 768px), print {
  .ckGrp.col3 li {
    width: 33%;
  }
  .ckGrp.col5 li {
    width: 20%;
  }
  #sltBtn ul.ckGrp.col5 li {
    margin-right: 0;
  }
}
/* btnBox */
.btnBox {
  text-align: center;
}
.btnBox input {
  padding: 8px 20px;
  margin: 20px 10px 30px;
  font-size: 14px;
  border-radius: 8px;
  color: #FFF;
  background-color: #333;
  -webkit-appearance: none;
  border: none;
  cursor: pointer;
}
/* 確認画面用
------------------------------ */
#confirm .confBox {
  margin: 0 5%;
}
#confirm h1 {
  padding: 30px 0;
  line-height: 1;
  text-align: center;
}
#confirm h1 img {
  width: 80%;
  height: auto;
}
#confirm .readBox {
  padding-bottom: 20px;
}
#confirm h2 {
  text-align: center;
}
#confirm table {
  width: 100%;
}
#confirm table th, #confirm table td {
  display: block;
  text-align: left;
}
#confirm table th {
  padding: 10px 0 0;
}
#confirm table td {
  padding: 10px 0;
  border-bottom: 1px dotted #333;
}
#confirm .btnbox {
  padding: 30px 0;
}
#confirm #msgbox p {
  text-align: center;
  margin-bottom: 0;
  color: #e50012;
}
#confirm .ft {
  padding-bottom: 20px;
}
@media screen and (min-width: 768px), print {
  #confirm h1 {
    padding: 30px 0 30px;
  }
  #confirm h1 img {
    width: auto;
    height: auto;
  }
  #confirm .confBox {
    width: 860px;
    margin: 0 auto;
  }
  #confirm table th, #confirm table td {
    display: table-cell;
  }
  #confirm table th {
    width: 35%;
    padding: 10px 0;
    border-bottom: 1px dotted #333;
  }
  #confirm table td {
    width: 65%;
  }
}
/* 送信完了画面用
------------------------------ */
@media screen and (max-width: 767px) {
  /* 確認画面用
	------------------------------ */
  .confBox {
    clear: left;
    width: auto;
    margin: 0 auto;
  }
  #readBox {
    margin: 0 10px;
  }
  .confBox #readBox p {
    text-align: left;
  }
}
/* 送信完了画面用
	------------------------------ */
.conpTxt .readBox p {
  text-align: center;
}
.conpTxt p br {
  display: block;
}