@charset "UTF-8";
.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden
}
.clearfix {
  min-height: 1px
}
* html .clearfix {
  height: 1px
}
@media (max-width:599px) {
  div#sec01 {
    background: url(images/1x/bg-sec01-sp.jpg) no-repeat;
  }
}
@media (min-width:600px) {
  div#sec01 {
    background-image: url(images/2x/bg-sec01@2x.png);
  }
}
div#sec01 {
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  min-height: 730px;
  position: relative;
  padding-top: 480px
}
@media (min-width:1200px) {
  div#sec01.wrapper {
    background-image: url(images/2x/bg-sec01-large@2x.png);
    max-width: 100%;
    background-size: cover;
    padding-top: 520px
  }
}
@media (max-width:1174px) {
  div#sec01 {
    background-size: contain;
    padding-top: 440px
  }
}
@media (max-width:990px) {
  div#sec01 {
    padding-top: 410px;
    min-height: 620px
  }
}
@media (max-width:768px) {
  div#sec01 {
    padding-top: 320px;
    min-height: 470px
  }
}
@media (max-width:599px) {
  div#sec01 {
    padding: 370px 0 0;
    max-width: 100%;
    height: auto;
    background-size: cover
  }
}
@media (min-width:769px) {
  .tab-nomi {
    display: none
  }
}
@media (min-width:600px) and (max-width:768px) {
  .pc-sp {
    display: none
  }
}
.dispoff {
  display: none
}
ul {
  list-style: none;
  margin: 0;
  padding: 0
}
.container-fluid.cf-type2 {
  padding: 0;
  max-width: 100%
}
.wrapper {
  max-width: 1200px;
  margin: 0 auto
}
@media (max-width:1200px) {
  .wrapper {
    max-width: 100%;
    padding: 10px
  }
}
.wrapper-middle {
  max-width: 1150px;
  margin: auto
}
.wrapper-narrow {
  max-width: 980px;
  margin: auto
}
@media (max-width:980px) {
  .wrapper-narrow {
    max-width: 100%;
    padding: 0 1em
  }
}
.wrapper-minimum {
  max-width: 700px;
  margin: auto
}
@media (max-width:599px) {
  .pc, .tab-nomi {
    display: none
  }
  .wrapper-narrow {
    width: 100%;
    padding: 0 3%
  }
}
.col2-half {
  width: 49%
}
@media (max-width:599px) {
  .col2-half {
    width: 100%
  }
}
.price-txt, .sans-serif {
  font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif
}
.bluebox dl dt, .bluetext {
  color: #1c386f
}
p {
  text-align: justify;
  line-height: 1.7
}
div#sec02 h2, h2.consec, ul.casetype, ul.icon-parts {
  text-align: center
}
@media (min-width:600px) {
  .left {
    float: left
  }
  .right {
    float: right
  }
  .sp {
    display: none
  }
  a.bluebanner-whitearrow:before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
    right: 9px;
    margin-top: -4px
  }
}
.arrow1 {
  position: relative;
  display: inline-block;
  padding-right: 16px
}
.arrow1:before {
  content: '';
  width: 0;
  height: 0;
  border: 4px solid transparent;
  border-left: solid 6px #3F51B5;
  position: absolute;
  top: 50%;
  right: 6px;
  margin-top: -4px
}
h2.consec {
  margin-top: 2em
}
h2.consec img {
  max-width: 560px
}
@media (max-width:599px) {
  .accordion1 {
    text-align: center
  }
  .accordion1 h3 {
    padding: 10px 10px 10px 0
  }
  .accordionall .inner {
    display: none
  }
  .aaccordionall h2 {
    cursor: pointer
  }
  #sec05 h2.consec img {
    width: 77%
  }
  div#sec05 h2.consec {
    display: none
  }
}
.cvset01 {
  border: 1px solid #1c386f;
  border-radius: 12px;
  background-image: url(images/1x/cvpoint-bg.png);
  background-repeat: no-repeat;
  background-position: top left;
  background-size: cover;
  padding: 20px 20px 15px 400px;
  max-width: 1100px;
  margin: auto
}
.floor02 div.left, .floor02 div.right {
  width: 48%
}
.floor01 {
  margin-bottom: 1em;
  padding-right: 1em
}
.floor02 a {
  display: block;
  height: auto;
  width: 100%
}
ul.casetype li, ul.icon-parts li {
  display: inline-block;
  vertical-align: top
}
.floor02 a img {
  max-height: 69px
}
@media (max-width:1174px) {
  .cvset01 {
    padding-left: 300px
  }
}
@media (max-width:768px) {
  .cvset01 {
    padding-left: 230px
  }
}
@media (max-width:599px) {
  .cvset01 {
    background-size: 617px;
    padding: 10px;
    background-position-x: -20px;
    background-color: #FFF
  }
  .contents-set .floor01 {
    padding: 0 0 0 37%;
    margin: 0 0 .9em
  }
  .floor02 div.left {
    float: left
  }
  .floor02 div.right {
    float: right
  }
}
div#sec02 h2 {
  font-size: 32px;
  margin-bottom: 1em
}
ul.casetype {
  margin-bottom: 4em
}
ul.casetype li {
  width: 24%;
  margin: 0 0 0 -5px;
  border-left: 1px solid #cdcdcd;
  border-top: 1px solid #cdcdcd;
  border-bottom: 1px solid #cdcdcd;
  min-height: 260px
}
ul.casetype li:last-Child {
  border-right: 1px solid #cdcdcd
}
ul.casetype li img {
  width: 100%
}
.sec2-floset .col2-half.left {
  width: 55%
}
.sec2-floset .col2-half.right {
  width: 41%
}
.sec2-floset .col2-half.left h3 {
  font-size: 23px;
  margin-top: 0;
  line-height: 1.5
}
ul.icon-parts {
  max-width: 800px;
  margin: 3em auto
}
ul.icon-parts li {
  width: 30%
}
ul.icon-parts li img {
  max-width: 110px;
  height: auto
}
ul.icon-parts li span {
  display: block;
  margin-top: .9em;
  line-height: 1.5
}
@media (max-width:768px) {
  .sec2-floset .col2-half.left h3 {
    font-size: 17px
  }
  ul.casetype li {
    min-height: unset
  }
}
@media (max-width:599px) {
  div#sec02 h2 {
    font-size: 20px
  }
  ul.casetype li, ul.casetype li:last-Child {
    min-height: auto;
    width: 49%;
    border: none
  }
  .sec2-floset .col2-half.left, .sec2-floset .col2-half.right {
    width: 100%
  }
  .sec2-floset .col2-half.left h3 {
    font-size: 20px;
    text-align: justify
  }
  ul.icon-parts li span {
    font-size: 12px
  }
  ul.icon-parts {
    margin: 0
  }
}
.rs-copy, .rs-photo-part, .rs-text-part h3, div#sec03 h2 {
  text-align: center
}
div#sec03 h2 {
  background-color: #dac693
}
div#sec03 h2 img {
  max-width: 820px
}
@media (max-width:820px) {
  div#sec03 h2 img {
    max-width: 100%
  }
}
.rs-text-part {
  width: 60%
}
.rs-photo-part {
  width: 40%
}
.rs-photo-part span {
  font-size: 12px;
  line-height: 1
}
img.num-icon {
  width: 110px;
  height: auto
}
.sec3-midashi {
  color: #555
}
.sec3-midashi span {
  display: block
}
span.num-text {
  font-size: 24px
}
span.num-text2 {
  font-size: 12px
}
.rs-copy {
  font-size: 22px
}
ul.reason {
  max-width: 1050px;
  margin: auto
}
ul.reason li {
  margin-bottom: 3em
}
ul.reason li:nth-child(1) .rs-text-part h3 {
  margin-top: 2em
}
ul.reason li:nth-child(2) .rs-text-part h3 {
  margin-top: 1.7em
}
ul.reason li:nth-child(3) .rs-text-part h3 {
  margin-top: 2em
}
ul.reason li:nth-child(6) .rs-text-part h3, ul.reason li:nth-child(7) .rs-text-part h3 {
  width: 30%;
  display: inline-block
}
ul.reason li:nth-child(6) .rs-text-part, ul.reason li:nth-child(7) .rs-text-part {
  width: 70%
}
ul.reason li:nth-child(6) .rs-text-part .rs-copy, ul.reason li:nth-child(7) .rs-text-part .rs-copy {
  width: 60%;
  text-align: left;
  display: inline-block;
  vertical-align: top;
  margin-top: 1em
}
ul.reason li:nth-child(6) .rs-photo-part, ul.reason li:nth-child(7) .rs-photo-part {
  width: 30%
}
ul.reason li:nth-child(2) .rs-photo-part {
  position: relative;
  left: 110px
}
ul.reason li:nth-child(4) .rs-photo-part {
  position: relative;
  left: 90px;
  top: 30px
}
ul.reason li:nth-child(5) {
  background-color: #f5f1e9;
  background-image: url(images/1x/reasonimg-05.jpg);
  background-repeat: no-repeat;
  background-position: right;
  background-size: contain;
  padding: 1.5em 0
}
@media (max-width:768px) {
  .rs-copy {
    font-size: 17px
  }
}
@media (max-width:599px) {
  .sec3-midashi, img.num-icon {
    display: inline-block
  }
  .rs-text-part {
    width: 100%
  }
  ul.reason li:nth-child(1) .rs-text-part h3, ul.reason li:nth-child(2) .rs-text-part h3, ul.reason li:nth-child(3) .rs-text-part h3 {
    margin: 0
  }
  ul.reason li .rs-text-part h3 {
    text-align: left;
    margin: 0
  }
  img.num-icon {
    width: 69px;
    vertical-align: top
  }
  span.num-text {
    font-size: 24px;
    margin-bottom: .1em
  }
  span.num-text2 {
    font-size: 15px
  }
  ul.reason li {
    margin: 0 0 .8em
  }
  .rs-copy {
    font-size: 14px;
    margin-top: 1em
  }
  ul.reason li:nth-child(5) {
    background: 0 0;
    padding: 0
  }
  ul.reason li:nth-child(6) .rs-text-part, ul.reason li:nth-child(7) .rs-text-part {
    width: 100%;
    text-align: left
  }
  ul.reason li:nth-child(6) .rs-text-part .rs-copy, ul.reason li:nth-child(7) .rs-text-part .rs-copy {
    display: none
  }
  ul.reason li:nth-child(6) .inner.sp p.sans-serif.bluetext.rs-copy, ul.reason li:nth-child(7) .inner.sp p.sans-serif.bluetext.rs-copy {
    display: block;
    width: 100%;
    margin-top: 8px;
    text-align: left
  }
  ul.reason li:nth-child(6) .rs-text-part h3, ul.reason li:nth-child(7) .rs-text-part h3 {
    width: 100%;
    display: none
  }
  .accordion1 .inner {
    padding-bottom: 1em;
    display: block
  }
  .accordion1 .inner span {
    font-size: 12px
  }
}
.sec04-flo .text-part {
  width: 56%
}
.sec04-flo .img-part {
  width: 43%;
  position: relative;
  top: -110px
}
.sec04-flo .text-part p {
  line-height: 2.6;
  font-size: 15px;
  margin-top: 1.5em
}
.sec04-vol3 {
  position: relative;
  top: -50px
}
.sec04-vol3 .col3-01, .sec04-vol3 .col3-02, .sec04-vol3 .col3-03 {
  display: inline-block;
  vertical-align: middle
}
.contentpart, ul.feature-list-04, ul.flow, ul.sec5-col3 li {
  vertical-align: top
}
.sec04-vol3 .col3-01 {
  width: 36%
}
.sec04-vol3 .col3-02 {
  width: 22%
}
.sec04-vol3 .col3-03 {
  width: 35%;
  padding-left: 0;
  padding-top: 0
}
.sec04-vol3 .col3-01 h3 {
  font-size: 27px
}
.sec04-vol3 .col3-01 h4, .sec04-vol3 .col3-03 h4 {
  font-size: 20px;
  margin-left: -12px
}
@media (max-width:980px) {
  .sec04-flo .text-part p {
    margin: 0;
    line-height: 1.8
  }
  .sec04-flo .img-part, .sec04-vol3 {
    top: 0
  }
  .sec04-vol3 .col3-01 h3 {
    font-size: 23px
  }
}
@media (max-width:599px) {
  .sec04-flo .text-part, .sec04-vol3 .col3-01 {
    width: 100%
  }
  .sec04-flo .text-part p {
    line-height: 1.6
  }
  .sec04-flo .img-part {
    position: initial;
    top: auto;
    width: 100%
  }
  .sec04-vol3 {
    top: auto
  }
  .sec04-vol3 .col3-02, .sec04-vol3 .col3-03 {
    display: none
  }
  .sec04-vol3 .col3-03 h4, .sec04-vol3 .col3-03 ul {
    text-align: left
  }
  .sec04-vol3 .col3-03 img {
    width: 140px;
    margin-top: 1em
  }
}
ul.sec5-col3 {
  text-align: center
}
ul.sec5-col3 li {
  width: 30%;
  display: table-cell;
  padding: 0 2%;
  border-right: 1px solid #cdcdcd
}
ul.sec5-col3 li h3 {
  font-size: 19px;
  line-height: 1.5
}
ul.sec5-col3 li p {
  text-align: justify;
  line-height: 1.9
}
ul.sec5-col3 li:last-child {
  border: none
}
@media (max-width:768px) {
  ul.sec5-col3 li {
    width: 100%;
    padding: 0;
    display: inline-block;
    text-align: justify;
    border: none
  }
  ul.sec5-col3 li h3 {
    border: 1px solid #1c386f;
    text-align: center;
    font-size: 18px;
    padding: .7em 0
  }
  ul.sec5-col3 li p {
    display: none
  }
}
ul.flow {
  width: 48%;
  display: inline-block
}
@media (min-width:600px) {
  ul.flow li {
    display: flex;
    align-items: center;
    padding: 1em 1em 1em 0;
    background-image: url(images/1x/flow-maru-line.png);
    background-repeat: no-repeat;
    background-size: 1px;
    background-position-x: 27px
  }
  .numpart {
    width: 10%;
    display: flex;
    justify-content: center;
    align-items: center
  }
  .numpart img {
    width: 32px;
    height: auto
  }
  ul.flow.part01 li:first-child {
    background-image: url(images/1x/flow-maru-line-first.png);
    background-position-y: center
  }
  ul.flow.part02 li:last-child {
    background-image: url(images/1x/flow-maru-line-last.png);
    background-position-y: center
  }
}
.contentpart {
  width: 90%
}
.flow-textpart h3 {
  margin: 0;
  font-size: 18px
}
ul.flow li p {
  margin: 0;
  text-align: justify
}
ul.flow.part01 li:nth-child(odd), ul.flow.part02 li:nth-child(even) {
  background-color: #f5f3f2
}
ul.flow.part01 li:nth-child(even), ul.flow.part02 li:nth-child(odd) {
  background-color: #eae5e3
}
.center {
  text-align: center
}
div#sec07 .wrapper-narrow.center p {
  text-align: justify;
  display: inline-block;
  font-size: 13px
}
div#sec07 .wrapper-narrow.center p span {
  font-size: 90%;
  float: right
}
.flow-textpart {
  width: 71%
}
.flow-photopart {
  width: 25%
}
.flow-textpart.textonly {
  width: 100%
}
@media (max-width:768px) {
  ul.flow {
    width: 100%
  }
  ul.flow li {
    background-position-x: 37px
  }
}
@media (max-width:599px) {
  ul.flow {
    width: 100%
  }
  .numpart {
    width: 17%;
    float: left;
    display: unset;
    align-items: unset;
    justify-content: unset
  }
  .numpart img {
    width: 45px;
    height: auto
  }
  ul.flow li {
    background-position-x: 25px;
    padding: .7em unset;
    background-repeat: repeat-y;
    display: block;
    align-items: unset
  }
  .contentpart {
    float: left;
    width: 80%;
    text-align: left
  }
  .flow-textpart {
    width: 60%;
    padding-top: .8em;
    float: left
  }
  .sp-h3-2l {
    padding-top: unset
  }
  ul.flow li p {
    font-size: 13px;
    line-height: 1.8
  }
  .flow-photopart {
    width: 30%;
    margin: auto;
    float: right
  }
}
.sec6-floset-contents {
  width: 58%
}
.sec6-floset-contents p {
  line-height: 2;
  text-align: justify
}
.sec6-floset ul.accordion1 li h3 img, .sec6-floset-part2 ul.accordion1 li h3 img {
  width: 50px;
  height: auto;
  margin-right: 10px
}
.sec6-floset ul.accordion1 li h3 span, .sec6-floset-part2 ul.accordion1 li h3 span {
  font-size: 20px
}
.sec6-floset .img-part {
  width: 42%
}
.text-block {
  display: inline-block
}
@media (max-width:768px) {
  .sec6-floset-contents {
    width: 100%
  }
  .sec6-floset .img-part {
    display: none
  }
}
@media (max-width:599px) {
  .text-block {
    width: 60%
  }
  .sec6-floset-contents {
    width: 100%
  }
  .sec6-floset ul.accordion1 li h3 img, .sec6-floset-part2 ul.accordion1 li h3 img {
    width: 66px;
    vertical-align: top;
    margin-right: 5px
  }
  .sec6-floset ul.accordion1 li h3, ul.accordion1 h3 {
    text-align: left;
    font-size: 12px;
    padding-left: 0;
    border-bottom: 1px solid #cdcdcd;
    margin-bottom: 0;
    background: 0 0
  }
  .sec6-floset ul.accordion1 li h3 span, .sec6-floset-part2 ul.accordion1 li h3 span {
    text-align: left;
    font-size: 18px;
    display: inline-block
  }
}
.flobox .img-parts {
  width: 50%
}
.flobox .text-parts {
  width: 47%
}
.bluebox {
  background-color: rgba(11, 90, 138, .1);
  padding: 1em
}
.bluebox dl {
  margin: 0 0 3px;
  border-bottom: 1px solid #999;
  padding-bottom: 4px
}
.bluebox dl dt {
  width: 13em;
  display: inline-block
}
.bluebox dl dd {
  margin: 0;
  display: inline-block
}
dl.lastchild {
  border: none;
  margin: 0;
  padding: 0
}
.sec6-floset-part2 ul li {
  width: 48%
}
ul.bg-gray {
  background-color: #eaeaea;
  margin: 1em 0;
  padding: 0 2em 2em
}
@media (max-width:768px) {
  ul.bg-gray {
    padding: 0 1em 1em
  }
  .sec6-floset-part2 ul li {
    width: 100%
  }
}
@media (max-width:599px) {
  .flobox .img-parts, .flobox .text-parts, .sec6-floset-part2 ul li {
    width: 100%
  }
  ul.bg-gray {
    padding: 0;
    margin: 0;
    text-align: left;
    background-color: unset
  }
}
.blue-line-square {
  border: 1px solid #3F51B5;
  background-color: #FFF
}
ul.feature-list-04 {
  margin: 3% 3% 0;
  width: 43%;
  display: inline-block
}
ul.feature-list-04 li {
  width: 100%;
  margin-bottom: .5em
}
ul.feature-list-04 li dl, ul.feature-list-04 li dl dd {
  margin: 0
}
.syourei-syashin {
  margin: 2em 0;
  padding: 2em 2em 1.4em
}
.col3box.box01, .col3box.box02, .col3box.box03 {
  display: inline-block;
  vertical-align: middle
}
.col3box.box01 {
  width: 20%;
  text-align: center;
  vertical-align: baseline
}
.col3box.box02 {
  width: 46%
}
.col3box.box03 {
  width: 33%;
  vertical-align: top
}
.col3box.box03 p {
  font-size: 14px;
  text-align: justify;
  line-height: 1.8
}
.col3box.box02 dl.photocaption {
  width: 47%;
  display: inline-block;
  text-align: center;
  margin: 0
}
.col3box.box02 dl.photocaption dd {
  font-size: 18px;
  margin: 0
}
@media (max-width:1010px) {
  .syourei-syashin {
    padding: 1em
  }
  .col3box.box02 {
    width: 40%
  }
  .col3box.box03 {
    width: 37%
  }
}
@media (max-width:768px) {
  .col3box.box01 {
    width: 100%
  }
  .syourei-syashin h3 {
    margin: 0 0 11px;
    font-size: 23px;
    text-align: left;
    border-bottom: 1px solid #cdcdcd
  }
  .col3box.box02, .col3box.box03 {
    width: 48%
  }
}
@media (max-width:599px) {
  .col3box.box01, .col3box.box03 {
    width: 100%
  }
  .syourei-syashin {
    padding: 11px 13px
  }
  .col3box.box02 {
    width: 100%;
    text-align: center;
    margin-bottom: 1em
  }
  .col3box.box02 dl.photocaption dd {
    font-size: 13px
  }
}
.gray-square {
  border: 1px solid #cdcdcd;
  margin: 2em 0;
  padding: 1em 2em
}
.gray-square h3 {
  margin: 0 0 .3em;
  font-size: 24px
}
@media (max-width:599px) {
  .gray-square {
    padding: 1em
  }
  .gray-square h3 {
    font-size: 17px;
    text-align: center;
    margin-bottom: .5em
  }
}
table.pricelist {
  border: none
}
table.pricelist td, table.pricelist th {
  padding: 2px 8px;
  border: none
}
table.pricelist th {
  background-color: #e7eef4;
  font-size: 11px;
  text-align: center;
  color: #1c386f
}
table.pricelist td {
  font-size: 13px
}
table.pricelist td.price {
  text-align: right
}
p.caution {
  font-size: 90%
}
ul.list-basic {
  padding-left: 2em;
  list-style-type: disc
}
h2.consec span {
  display: block;
  font-size: 14px;
  margin-top: 1em;
  margin-bottom: 2em
}
.about-text {
  width: 55%
}
.about-text p {
  font-size: 14px;
  line-height: 1.8;
  text-align: justify
}
img.namesign {
  max-width: 190px
}
div#sec09 .right.col2-half {
  width: 42%
}
@media (max-width:599px) {
  p.caution {
    font-size: 12px;
    line-height: 1.5
  }
  ul.list-basic {
    font-size: 14px;
    text-align: justify;
    padding-left: 1em
  }
  .about-text, div#sec09 .right.col2-half {
    width: 100%
  }
}
.imageline ul {
  text-align: center
}
.imageline ul li {
  width: 18.9%;
  display: inline-block;
  margin: .3%;
  height: auto
}
.maparea iframe {
  width: 100%;
  height: 330px
}
.access-text h3 {
  font-size: 21px;
  margin-bottom: 4px
}
.access-text p {
  margin-bottom: 6px;
  font-size: 17px
}
p.small80 {
  font-size: 90%
}
.iconimg {
  width: 15%;
  height: auto;
  padding-top: 15px
}
.contact-text {
  width: 83%
}
.contact-text h3 {
  margin-bottom: 0
}
div#phone-contact {
  background-color: #ececec;
  margin: 2em 0
}
@media (max-width:599px) {
  .access-text h3 {
    font-size: 18px
  }
  .access-text p {
    font-size: 12px
  }
  div#phone-contact {
    text-align: center;
    margin-bottom: .7em
  }
  .iconimg {
    display: inline-block;
    width: 18%
  }
  .contact-text {
    width: 75%;
    display: inline-block;
    vertical-align: top;
    text-align: justify
  }
  .contact-text .text-red {
    line-height: 1.4;
    font-size: 14px
  }
}
.first-flow {
  width: 55%;
  display: inline-block;
  vertical-align: top;
  margin: 1em
}
.first-flow.second-flow {
  width: 38%
}
p.phone-num-pc {
  font-size: 23px;
  margin-bottom: 1px
}
.text-red {
  color: #F44336;
  font-weight: 700
}
p.mailtext {
  font-size: 18px;
  margin-bottom: 4px
}
p.mailtext span {
  font-size: 80%
}
.first-flow .blue-line-square {
  text-align: center;
  margin: 2em 0;
  padding: .8em
}
.first-flow .blue-line-square p {
  margin: 0;
  font-weight: 700
}
.first-flow.second-flow .blue-line-square {
  text-align: left
}
@media (max-width:768px) {
  .first-flow {
    width: 51%
  }
  .first-flow.second-flow {
    width: 37%
  }
  .first-flow .blue-line-square p {
    font-size: 12px
  }
}
@media (max-width:599px) {
  p.mailtext {
    font-size: 15px
  }
  p.mailtext span {
    display: block
  }
  .first-flow, .first-flow.second-flow {
    width: 100%;
    margin: 0
  }
  .first-flow .blue-line-square {
    padding: 5px;
    margin: 14px
  }
  .first-flow .blue-line-square p {
    text-align: center;
    font-size: 13px;
    line-height: 1.5
  }
}
.ft-callset ul li, .phonenum-left, .uketukejikan-mini {
  display: inline-block
}
.caution-header {
  text-align: center;
  margin-top: 2em
}
.caution-header h3 {
  font-size: 29px;
  font-weight: 700
}
.caution-sec h4 {
  font-size: 23px
}
.caution-sec dd {
  margin-left: 0
}
.footer {
  background-color: #eaeaea;
  padding-top: 1em;
  position: relative
}
p.shoplogo {
  font-size: 38px;
  width: 450px
}
p.shoplogo span {
  font-size: 80%
}
.ft-callset ul li {
  vertical-align: top;
  margin-right: 1em
}
.ft-callset ul li:first-child {
  padding-right: 1em
}
.ft-callset ul li:last-child {
  width: 40%
}
.ft-callset ul li h5 {
  font-size: 17px;
  margin-bottom: -5px
}
p.phone-num {
  font-size: 37px
}
.copyright {
  text-align: center;
  background-color: #163773;
  color: #FFF;
  font-size: 10px
}
.left.ft-main-set {
  width: 60%;
  margin-bottom: 15px
}
.left.ft-main-set p {
  margin-bottom: 0
}
.right.reserve-bn {
  width: 39%;
  position: absolute;
  bottom: 20px;
  right: 1%
}
.footer .wrapper {
  position: relative
}
.uketukejikan-mini {
  padding-left: 4px
}
.uketukejikan-mini span {
  font-size: 15px
}
span.small70 {
  font-size: 12px
}
@media (max-width:1125px) {
  p.phone-num {
    font-size: 27px
  }
  .ft-callset ul li h5, .uketukejikan-mini span {
    font-size: 13px
  }
}
@media (max-width:768px) {
  .left.ft-main-set {
    width: 100%
  }
  .right.reserve-bn {
    width: 100%;
    position: relative;
    bottom: unset;
    right: unset
  }
  .bn-btn {
    max-width: 400px;
    margin: auto
  }
  .ft-callset ul li:first-child {
    width: auto
  }
}
h3.menuh3 {
  font-size: 19px;
  text-align: center
}
h3.menuh3 span {
  display: block;
  font-size: 150%
}
ul.menulist-set li.menulist-setin {
  border: 1px solid #163773;
  border-radius: 1em;
  padding: 1.5em;
  margin-bottom: 1.5em;
  min-height: 290px
}
.menu-imgpart {
  width: 22%
}
.menu-textpart {
  width: 75%
}
.menu-textpart h4 {
  font-size: 21px;
  margin-top: 0;
  margin-bottom: 4px
}
.menu-textpart h4 span {
  font-size: 60%
}
span.caution {
  font-size: 10px !important
}
p.mainlead {
  font-size: 15px;
  margin-bottom: 7px
}
ul.menu-opt {
  font-size: 14px
}
ul.menu-opt li span {
  font-size: 80%
}
ul.menu-opt.in-line-list li {
  display: inline-block
}
.cvbutton a {
  background-color: #1a3b76;
  display: block;
  color: #FFF;
  padding: .8em 1em .8em .7em;
  letter-spacing: .4px;
  font-size: 12px
}
.cvbutton a:hover {
  background-color: #987729
}
.left-sp, .right-sp {
  width: 49%;
  display: inline-block;
  vertical-align: top
}
.pricelist-list .left-sp {
  width: 60%
}
.pricelist-list .right-sp {
  width: 35%;
  float: right
}
p.price-txt {
  font-size: 22px;
  margin-bottom: 8px
}
span.shironuki {
  background-color: #113a7a;
  color: #FFF;
  padding: 3px 5px;
  margin-right: .6em;
  font-size: 12px
}
span.small80 {
  font-size: 50%
}
p.price-txt span.arrow1 {
  font-size: 13px
}
.w-full ul.menulist-set li.menulist-setin {
  width: 49%
}
@media (max-width:1110px) {
  ul.menulist-set li.menulist-setin .left-sp, ul.menulist-set li.menulist-setin .right-sp {
    width: 100%;
    margin-bottom: 3px
  }
  .cvbutton a {
    padding: 7px;
    font-size: 14px
  }
  ul.menulist-set li.menulist-setin {
    min-height: unset
  }
  p.price-txt span.arrow1 {
    display: table-cell
  }
  p.price-txt {
    margin-top: 1em
  }
}
@media (max-width:1060px) {
  .menutypesec, .w-full ul.menulist-set li.menulist-setin {
    width: 100%
  }
  ul.menulist-set li.menulist-setin .left-sp, ul.menulist-set li.menulist-setin .right-sp {
    width: 49%
  }
  p.price-txt span.arrow1 {
    display: inline-block
  }
  p.price-txt {
    font-size: 210%;
    margin-top: .5em
  }
  .menu-imgpart {
    width: 17%
  }
  .menu-textpart {
    width: 80%
  }
}
@media (max-width:599px) {
  h3.menuh3 {
    border: 1px solid #cdcdcd;
    margin-bottom: 0;
    padding: .7em
  }
  .w-full ul.menulist-set li.menulist-setin {
    width: 100%
  }
  ul.menulist-set li.menulist-setin {
    border: 1px solid #cdcdcd;
    border-radius: 0;
    padding: 10px;
    min-height: unset;
    margin-bottom: 0;
    border-top-width: 0
  }
  .menu-imgpart {
    width: 22%;
    float: left
  }
  .menu-textpart {
    width: 75%;
    float: right
  }
  .menu-textpart h4 {
    font-size: 19px
  }
  p.mainlead, ul.menu-opt {
    font-size: 12px
  }
  .menu-textpart h4 span {
    display: block
  }
  p.mainlead {
    line-height: 1.7
  }
  p.price-txt span.arrow1 {
    display: block;
    display: table
  }
  p.price-txt {
    margin-top: .3em;
    font-size: 21px
  }
  .cvbutton {
    display: none
  }
  .sp .cvbutton {
    display: block
  }
  .sp .cvbutton .left-sp, .sp .cvbutton .right-sp {
    width: 49%
  }
  .sp .cvbutton .left-sp a, .sp .cvbutton .right-sp a {
    font-size: 11px;
    display: block;
    padding: 12px 1px;
    letter-spacing: .3px;
    text-align: center
  }
  .left.ft-main-set, p.shoplogo {
    width: 100%
  }
  .right.reserve-bn {
    width: 100%;
    position: initial;
    bottom: auto
  }
  .copyright {
    margin-bottom: 70px
  }
}
.mw_wp_form label {
  display: inline
}
@media (min-width:768px) {
  .table-2 {
    border: none;
    border-top: 1px solid #CCC;
    border-collapse: collapse;
    width: 100%;
    font-size: 14px
  }
  .table-2 td, .table-2 th {
    border: none;
    border-bottom: 1px solid #CCC;
    padding: 15px;
    font-weight: 400
  }
  .table-2 th {
    border: none;
    width: 200px;
    text-align: left;
    border-bottom: 1px solid #CCC;
    border-left-width: 0;
    vertical-align: text-bottom
  }
}
@media (max-width:767px) {
  .table-2, .table-2 tbody, .table-2 td, .table-2 th, .table-2 tr {
    display: block;
    width: 100%
  }
  .table-2 th {
    font-size: 16px;
    font-weight: 700;
    border-bottom: 1px dashed #D4DADB;
    background-color: #f1f7fd;
    padding: 4px 4px 4px 3em;
    text-align: left
  }
  .table-2 td {
    text-align: left;
    padding: 8px
  }
}
.blue-line-square.center p, .btn-part, .center-block, .soushincp.gray-square p {
  text-align: center
}
.form-text, .form-textarea {
  border: 1px solid #CCC;
  width: calc(100% - 16px);
  padding: 7px;
  background-color: #FAFAFB
}
.form-submit {
  position: relative;
  cursor: pointer;
  background-color: #FFF;
  border: 2px solid #3FA9F5;
  padding: 7px 100px;
  font-size: 14px;
  border-radius: 20px;
  color: #3FA9F5;
  -webkit-transition: all .25s linear;
  -moz-transition: all .25s linear;
  -ms-transition: all .25s linear;
  -o-transition: all .25s linear;
  transition: all .25s linear
}
.form-submit i {
  position: absolute;
  top: 50%;
  right: 15px;
  margin-top: -.5em;
  color: #3FA9F5;
  -webkit-transition: all .25s linear;
  -moz-transition: all .25s linear;
  -ms-transition: all .25s linear;
  -o-transition: all .25s linear;
  transition: all .25s linear
}
.form-submit:hover {
  background-color: #3FA9F5;
  color: #FFF
}
.form-submit:hover i {
  color: #FFF
}
.form-require {
  position: relative
}
@media (min-width:768px) {
  .form-require::after {
    position: absolute;
    content: '※';
    color: red;
    right: 10px;
    padding: 0 10px;
    top: 17px
  }
}
@media (max-width:767px) {
  .form-text {
    width: calc(100% - 32px)
  }
  .form-require:after {
    position: absolute;
    content: '※';
    color: red;
    left: 10px;
    top: calc(50% - 10px);
    padding: 0 10px
  }
}
.color-red {
  color: red
}
.pp-box {
  height: 100px;
  overflow: auto;
  border: 1px solid #CCC;
  padding: 0 1.5em 1em
}
.pp-box h4 {
  font-size: 21px;
  margin-bottom: 6px
}
button.form-btn.form-btn-confirm, button.form-btn.form-btn-submit, input.form-btn.form-btn-back {
  background-color: #333;
  padding: .8em 3em;
  font-size: 22px
}
.center-block {
  font-weight: 700;
  font-size: 20px;
  margin-top: 1em
}
.btn-part {
  margin-top: 2em
}
.soushincp.gray-square {
  text-align: center;
  background-color: rgba(255, 255, 255, .3)
}
.contents-set .floor01 img {
  max-height: 78px
}
span.mwform-radio-field.horizontal-item {
  display: inline-block;
  margin-left: 10px
}
ul.pricelist-list li {
  border-bottom: 1px solid #cdcdcd;
  padding-bottom: 4px;
  font-size: 13px;
  margin-top: 4px
}
.right-sp.buikuro {
  background-color: #504c4c;
  color: #FFF;
  font-size: 12px;
  padding: 2px;
  line-height: 1.4
}
.ft-fix-btn {
  background-color: rgba(255, 255, 255, .7);
  position: fixed;
  bottom: 0;
  left: 0;
  height: 70px;
  width: 100%
}
.ft-fix-btn .left, .ft-fix-btn .right {
  width: 48%;
  margin: 1%
}
.ft-fix-btn .left {
  float: left
}
.ft-fix-btn .right {
  float: right
}
.ft-fix-btn .left a, .ft-fix-btn .right a {
  display: block
}
ul.call-btn {
  border-top: 2px solid #FFF
}
ul.call-btn li {
  width: 49%;
  display: inline-block;
  border-right: 2px solid #FFF
}
ul.call-btn li:last-child {
  border: none
}
ul.call-btn li a {
  display: block;
  color: #333;
  line-height: 1.3
}
ul.call-btn li a span {
  font-size: 124%
}
@media (max-width:599px) {
  ul.sp-flow li {
    background-color: #e1eaf9;
    border-bottom: 2px solid #cdcdcd;
    padding: 2px 0 2px 16px;
    font-weight: 700;
    font-size: 14px
  }
  ul.sp-flow li span {
    font-weight: 400;
    font-size: 90%;
    margin-right: 1em
  }
  ul.sp-flow.second-flow-list li {
    background-color: #576d98;
    color: #FFF
  }
}
span.mwform-checkbox-field.horizontal-item {
  display: block;
  margin-left: 10px
}
p.phone-num-pc span.bluetext {
  font-weight: 700
}
td.price {
  text-align: right
}
.sec6-floset-contents p span.bluetext {
  font-weight: 700;
  font-size: inherit
}
.pricelist-sec {
  display: inline-block;
  vertical-align: top
}
.pricelist-sec.left-posi {
  width: 29%;
  margin-right: 1%
}
.pricelist-sec.right-posi {
  width: 69%
}
@media (max-width:768px) {
  .pricelist-sec {
    display: block
  }
  .pricelist-sec.left-posi {
    width: 100%
  }
  .pricelist-sec.left-posi table.pricelist {
    width: 50%;
    float: left;
    margin-right: 1em
  }
  .pricelist-sec.left-posi p.caution {
    font-size: 12px
  }
  .pricelist-sec.right-posi {
    width: 100%
  }
}
.flow-section {
  text-align: center
}
.flow-section .gray-square {
  text-align: left
}
input#FormName, input#FormSex {
  max-width: 30%
}
ul.pricelist-list li.th-type {
  border-bottom: none;
  background-color: #e7eef4;
  font-size: 11px;
  font-weight: 700;
  color: #445b89;
  text-align: center;
  padding-top: 3px
}
@media (max-width:599px) {
  .pricelist-sec.left-posi table.pricelist {
    width: 100%;
    float: unset
  }
  input#FormName, input#FormSex {
    max-width: 45%
  }
}
span.ml-caution {
  font-size: 12px;
  line-height: 1.5;
  display: inline-block;
  margin-top: .5em;
  font-weight: 700
}
dl.inform-tt-02 {
  margin-bottom: .5em
}
dl.inform-tt-02 dd {
  margin: 0;
  padding-left: .8em
}
.rn6-sp {
  text-align: right
}
td.datetime span.error {
  display: initial
}
.center-block span.error {
  font-weight: 400;
  font-size: 15px
}
@media (min-width:600px) {
  span.ml-caution.sp {
    display: none
  }
}
.sec3-spleft {
  text-align: left;
  float: left;
  width: 60%
}
.sec3-spleft img.num-icon {
  width: 52px
}
.sec3-spleft .rs-copy {
  text-align: justify;
  margin-top: 8px;
  line-height: 1.5
}
.sec3-spleft .rs-copy span {
  font-size: 11px
}
.sec3-spright {
  float: right;
  width: 34%
}
.koukanomeyasu {
  background-color: #f7ece8;
  text-align: center;
  padding: 1em 0
}
.koukanomeyasu img {
  max-width: 75%
}
p.koukanomeyasu-pc {
  background-color: #f7f2ed;
  padding: 2em;
  margin-left: 2em
}
/*add 20200609 ek*/
figure.align-center.meso-price {}
@media (min-width:600px) {
  figure.align-center.meso-price {
    max-width: 1200px;
    margin: auto;
    max-height: 200px;
  }
}
span.smalltext-01 {
  font-size: 80% !important;
  margin-left: 0 !important;
  margin-right: 0.5em;
  color: #1C386F !important;
}
span.title-small {
  font-size: 60% !important;
  margin-right: 0.2em;
}
span.smalltext-01 {
  font-size: 14px !important;
}
span.smalltext-02 {
  font-size: 80% !important;
  color: unset !important;
}
span.smalltext-03 {
  font-size: 14px !important;
}
/**/
.mv-text {
  position: absolute;
}
.mv-text h1 {
  margin: 0;
}
.mv-text h1 img {}
.mv-text p {
  font-size: 15px;
  font-family: serif;
  letter-spacing: 1.5px;
}
.mv-text p span {
  font-size: 80%;
}
@media (min-width:769px) {
  .mv-text {
    top: 50%;
    left: 28%;
    -webkit-transform: translate(-50%, -50%); /* Safari用 */
    transform: translate(-50%, -50%);
  }
  .mv-text h1 {
    width: 390px;
  }
  .mv-text h1 img {}
  .mv-text p {}
  .mv-text p span {}
}
@media (max-width:768px) {
  .mv-text {
    bottom: 32px;
    left: 20px;
  }
  .mv-text h1 {
    width: 220px;
  }
  .mv-text h1 img {}
  .mv-text p {
    font-size: 12px;
    letter-spacing: unset;
  }
  .mv-text p span {}
}
@media (max-width:767px) {
  .mv-text {
    bottom: 32px;
    left: 20px;
  }
  .mv-text h1 {
    width: 220px;
  }
  .mv-text h1 img {}
  .mv-text p {
    font-size: 12px;
    letter-spacing: unset;
  }
  .mv-text p span {}
}
/**/
@media (min-width:768px) {
  p.flow-pre-text {
    text-align: center;
  }
}
@media (max-width:767px) {
  p.flow-pre-text {}
}