#wrapper {
  max-width: 2000px;
}

#header {
  max-width: 2000px;
  max-height: 2806px;
  background-image: url(../img/img_top.jpg);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
}
#header section {
  max-width: 90%;
  display: block;
  margin: 0 auto 50px;
}
#header h1 {
  position: relative;
}
#header img {
  display: block;
  max-width: 100%;
  height: auto;
}
#header img.overray {
  mix-blend-mode: screen;
  position: absolute;
  top:0;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  /* IE10,11 のみ適用される */
  #header img.overray {
    display: none;
  }
}
@supports (-ms-ime-align:auto) {
  /* Edge のみ適用される */
  #header img.overray {
    display: none;
  }
}
#header h2 {
  font-family: "Sawarabi Mincho";
  font-size: 3rem;
  line-height: 150%;
  text-align: center;
  margin-top: 50px;
}
#header h3 {
  font-family: "Sawarabi Gothic";
  font-size: 1.6rem;
  line-height: 150%;
  text-align: center;
  color:rgba(32,32,32,1);
  text-shadow:2px 2px 1px rgba(255,255,255,0.8);
  margin-top: 50px;
  padding-bottom: 50rem;
}



/* section */
#interior, #charge, #access, #banner {
  max-width: 100%;
  display: block;
  padding: 60px 0 100px;
}
/* inner div */
#interior > div, #charge > div, #access > div {
  margin: 0 auto;
  max-width: 90%;
  display: block;
}



/* slider */
.flexslider {
  margin-bottom: 150px;
}
.slides li {
  position: relative;
}
#interior p.flex-caption {
  font-family: "Sawarabi Gothic";
  font-size: 1.6rem;
  line-height: 150%;
  text-align: center;
  position: absolute;
  font-size: 1rem;
  line-height: 100%;
  width: 96%;
  padding: 2%;
  margin: 0;
  left: 0;
  bottom: 0;
  background: rgba(0,0,0,.5);
  color: #fff;
  text-shadow: 0 -1px 0 rgba(0,0,0,.3);
}
li.css a {
  border-radius: 0;
}

/* midashi */
#interior h1 {
  font-family: "Sawarabi Mincho";
  font-size: 2.8rem;
  line-height: 150%;
  margin: 50px auto 80px;
  color: rgba(122,42,27,1);
  text-align: center;
}
#interior p.sub_text {
  font-family: "Sawarabi Gothic";
  font-size: 1.6rem;
  line-height: 150%;
  color:rgba(32,32,32,1);
  text-align: center;
  width: 63rem;
  margin: 50px auto;
}
#interior h2 {
  font-size: 2rem;
  line-height: 150%;
  font-family: "Sawarabi Gothic";
  margin-bottom: 50px;
  position: relative;
  text-align: center;
  display: block;
}
#interior h2 span {
  position: relative;
  z-index: 2;
  display: inline-block;
  margin: 0 2.5em;
  padding: 0 2em;
  background-color: #fff;
  text-align: center;
}
#interior h2::before {
  position: absolute;
  top: 50%;
  z-index: 1;
  content: '';
  display: block;
  width: 100%;
  height: 1px;

  background-image: -webkit-linear-gradient(left, transparent, #000 45%, #000 45%, transparent);
  background-image: linear-gradient(to right, transparent, #000 45%, #000 45%, transparent);
  background-position: center;
  background-repeat: no-repeat;
}


.lyout_img {
  float: left;
  width: 30%;
}
.lyout_img ul {
  list-style: none;
}
.lyout_img li {
  margin-bottom: 1rem;
}
.lyout_img img {
  display: block;
  margin: auto;
  max-width: 100%;
  height: auto;
}
.using {
  float: right;
  width: 60%;
}

/* 括弧見出し */
.using h3 {
  font-family: "Sawarabi Gothic";
  font-size: 1.6rem;
  line-height: 150%;
  position: relative;
  margin-bottom: 1rem;
  padding:0.25em 1em;
  display: inline-block;
  top:0;
  color: rgba(64,64,64,1);
  color: rgba(115,75,35,1);
}
.using h3:before, .using h3:after{ 
  position: absolute;
  top: 0;
  content:'';
  width: 8px;
  height: 100%;
  display: inline-block;
}
.using h3:before{
/*
  border-left: solid 2px rgba(0,0,0,0.5);
  border-top: solid 2px black;
  border-bottom: solid 2px black;
*/
  border: solid 2px rgba(0,0,0,0.3);
  border-right: none;
  left: 0;
}
.using h3:after{
/*
  border-top: solid 2px black;
  border-right: solid 2px black;
  border-bottom: solid 2px black;
*/
  border: solid 2px rgba(0,0,0,0.3);
  border-left: none;
  right: 0;
}

/* 使用例リスト */
.using_list {
  font-family: "Sawarabi Gothic";
  font-size: 1.4rem;
  line-height: 150%;
/*  margin-left: 40px;*/
  margin-bottom: 7rem;
  display: flex;
  flex-wrap: wrap;
}
.using_list li {
  flex: 1 1 33%;
  list-style: inside;
}
.using p {
  font-family: "Sawarabi Gothic";
  font-size: 1.4rem;
  line-height: 150%;
}
.example:after {
  display: block;
  clear: both;
  content: "";
}


/* 料金表とbannerの背景色 */
#charge, #banner {
  background-color: rgba(158,118,78, 0.2);
}


#charge h1, 
#access h1, 
#banner h1 {
  font-family: "Sawarabi Mincho";
  font-size: 2.4rem;
  line-height: 150%;
  margin: 0px auto 80px;
  color: rgba(32,32,32,1);
  text-align: center;
}
#charge h1 {
/*  color: rgba(255,255,255,1);*/
}
#charge p {
  font-family: "Sawarabi Gothic";
  font-size: 1.4rem;
  line-height: 150%;
  text-align: center;
}
.charge_table {
  font-family: "Sawarabi Gothic";
  font-size: 1.4rem;
  line-height: 150%;
  max-width: 100%;
  width: 80%;
  margin: 30px auto;
  border: 3px solid rgba(0,0,0,1);
  border-collapse: collapse;
}
.charge_table th, .charge_table td {
  padding: 10px;
  vertical-align: middle;
  border-left: 1px solid rgba(0,0,0,1);
  border-right: 1px solid rgba(0,0,0,1);
}
.charge_table tr {
  border: 3px solid rgba(0,0,0,1);
}
.charge_table th {
  background-color: rgba(224,216,209,1);
}
.charge_table td {
  background-color: rgba(246,242,238,1);
}
.charge_table td:nth-child(1) {
  width: 25%;
}
.charge_table td:nth-child(2) {
  width: 15%;
}
.charge_table td:nth-child(3) {
  width: 30%;
}
.charge_table td:nth-child(4) {
  width: 30%;
}
.charge_table th,
.charge_table td:nth-child(1),
.charge_table td:nth-child(2) {
  text-align: center;
}
.charge_table .detail_list {
  padding-left: 0;
  padding-right: 0;
}
.charge_table .detail_list dt {
  float: left;
  padding-left: 10px;
}
.charge_table .detail_list dd {
  text-align: right;
  padding-right: 10px;
  padding-bottom: 10px;
}
.charge_table .detail_list dt:nth-of-type(n+2), 
.charge_table .detail_list dd:nth-of-type(n+2) {
  padding-top: 10px;
}
.charge_table .detail_list dd:nth-of-type(n+2) {
  border-top: 1px dotted rgba(0,0,0,1);
}
.charge_table .detail_list dt:nth-last-of-type(1),
.charge_table .detail_list dd:nth-last-of-type(1) {
  padding-bottom: 0;
}
.charge_table .detail_list dd:after {
  clear: both;
  display: block;
  content: "";
}
.charge_table .detail_block {
  padding: 0;
}
.charge_table .detail_block span {
  display: block;
  padding: 10px;
}
.charge_table .detail_block span:nth-of-type(n+2) {
  border-top: 1px dotted rgba(0,0,0,1);
}
.charge_table .charge {
  text-align: right;
}
.caution_list {
  font-family: "Sawarabi Gothic";
  font-size: 1.4rem;
  line-height: 150%;
  max-width: 100%;
  width: 80%;
  display: block;
  margin: auto;
  padding-left: 1rem;
}
.caution_list li {
}


/* お問い合わせ先 */
/*
.contact_list {
  background-image: url(../img/img_logo.png);
  background-repeat: no-repeat;
  background-position: top left;
  width: calc(230px + 42rem);
  min-height: 180px;
  display: block;
  margin: 0 auto 50px;
}
.contact_list h2 {
  font-family: "Sawarabi Mincho";
  font-size: 1.6rem;
  line-height: 150%;
  margin-left: 230px;
}
.contact_list dl {
  font-family: "Sawarabi Gothic";
  font-size: 1.4rem;
  line-height: 150%;
  margin-left: 230px;
}
.contact_list dl:after {
  display: block;
  clear: both;
  content: "";
  margin-bottom: 60px;
}
.contact_list dt {
  float: left;
}
.contact_list dd {
  padding-left: 5em;
}
*/
.contact_list {
  margin: 0 auto 50px;
}
.contact_list .outline_img {
  float: left;
}
.contact_list .list {
  margin-left: 500px;
}
.contact_list:after {
  display: block;
  content: '';
  clear: both;
}

.contact_list h2 {
  font-family: "Sawarabi Mincho";
  font-size: 1.6rem;
  line-height: 150%;
}
.contact_list dl,
.contact_list p {
  font-family: "Sawarabi Gothic";
  font-size: 1.4rem;
  line-height: 150%;
  margin-bottom: 2rem;
}
.contact_list dt {
  float: left;
}
.contact_list dd {
  padding-left: 5rem;
}

/* マップ */
.gm {
  width: 100%;
  border: none;
}

#banner div {
  text-align: center;
}
.banner_img {
  display: inline-block;
  margin: auto;
  background-color: rgba(255,255,255,1);
}

/* フッター */
#footer {
  background-color: rgba(0,0,0,1);
  text-align: center;
}
.copy {
  font-size: 1rem;
  line-height: 200%;
  color: rgba(255,255,255,1);
}


.page-top {
  margin: 0;
  padding: 0;
}

.page-top p {
  margin: 0;
  padding: 0;
  position: fixed;
  right: 16px;
  bottom: 16px;
}
 
.move-page-top {
  display: block;
  background: #D36015;
  width: 50px;
  height: 50px;

  color: #fff;
  line-height: 50px;
  text-decoration: none;
  text-align: center;

  -webkit-transition:all 0.3s;
  -moz-transition:all 0.3s;
  transition:all 0.3s;
}

.move-page-top:hover {
  opacity: 0.85;
}


/* ipad横 */
@media only screen and (max-width:1024px) {
  #interior h1 br {
    display: none;
  }
  #interior h1, 
  #interior p.sub_text {
    width: 85%;
  }
  .using_list li {
    flex: 1 1 50%;
  }
  .charge_table {
    max-width: 100%;
    width: 100%;
  }
}

/* iphoneX 横 */
@media only screen and (max-width:812px) {
  #header h2 {
    font-size: 2.6rem;
  }
  #interior h1 {
    font-size: 2.4rem;
  }
  #interior h1, #interior p.sub_text {
    width: 100%;
  }

  .lyout_img {
    float: none;
    width: 100%;
  }
  .lyout_img ul {
    display: flex;
  }
  .lyout_img li {
    flex: 1 1 50%;
    margin-bottom: 1rem;
  }
  .using {
    float: none;
    width: 100%;
  }

  .lyout_img p {
    padding-bottom: 3rem;
  }
  .using_list li {
    flex: 1 1 30%;
  }
  .charge_wrapper {
    width: 100%;
    overflow-y: hidden; /* 縦スクロール非表示 */
    overflow-x: scroll; /* 横スクロール */
    -webkit-overflow-scrolling: touch;
  }
  .charge_table {
    font-size: 1.0rem;
    white-space: nowrap;
    width: 660px;
  }
  .charge_table::-webkit-scrollbar{ /*tableにスクロールバーを追加*/
    height: 5px;
  }
  .charge_table::-webkit-scrollbar-track{ /*tableにスクロールバーを追加*/
    background: #F1F1F1;
  }
  .charge_table::-webkit-scrollbar-thumb { /*tableにスクロールバーを追加*/
    background: #BCBCBC;
  }
  .charge_table th:nth-child(1), 
  .charge_table td:nth-child(1) {
    width: 140px;
  }
  .charge_table th:nth-child(2), 
  .charge_table td:nth-child(2) {
    width: 60px;
  }
  .charge_table th:nth-child(3), 
  .charge_table td:nth-child(3) {
    width: 180px;
  }
  .charge_table th:nth-child(4), 
  .charge_table td:nth-child(4) {
    width: 180px;
  }
  /*
  .contact_list {
    width: 95%;
  }
  */
}

/* ipad縦 */
@media only screen and (max-width:768px) {
  .contact_list {
    margin: 0 auto 50px;
  }
  .contact_list .outline_img {
    float: none;
    display: block;
    margin: 0 auto 3rem;
  }
  .contact_list .list {
    margin-left: 0;
  }
  .contact_list:after {
    display: block;
    content: '';
    clear: both;
  }
  .contact_list h2 {
    text-align: center;
  }
  .contact_list dl,
  .contact_list p {
    margin-bottom: 2rem;
  }
}

/* iPhone 6-8Plus系 横 */
@media only screen and (max-width:736px) {
}

/* iPhone 6-8 系 横 */
@media only screen and (max-width:667px) {
}

/* iPhone 5 系 横 */
@media only screen and (max-width:568px) {
  #header {
    background-size: 150% auto;
  }
  #header h2 {
    font-size: 2.2rem;
  }
  #header h3 {
    font-size: 1.3rem;
    padding-bottom: 35rem;
  }
  #interior h1 {
    font-size: 1.8rem;
  }
}

/* iPhone 3-4 系 横 */
@media only screen and (max-width:480px) {
  #header h2 {
    font-size: 1.9rem;
  }
  #header h3 {
    font-size: 1.1rem;
    padding-bottom: 28rem;
  }

  #interior h2 span {
    padding: 0 2em;
  }
}

/* iPhone 6-8Plus系 縦 */
@media only screen and (max-width:414px) {
  #header h2 {
    font-size: 1.6rem;
  }
  #header h3 {
    font-size: 1rem;
    padding-bottom: 23rem;
  }

  #charge h1, #access h1, #banner h1 {
    font-size:1.8rem;
  }

  #interior h2 {
    font-size:1.6rem;
  }
  #interior h2 span {
    padding: 0 1em;
  }
  .lyout_img ul {
    display: block;
  }
  .lyout_img img {
    max-width: 90%;
    height: auto;
  }
  .using h3 {
    font-size:1.3rem;
    padding: 0.25em 1em 0.05em;
  }
  .using_list {
/*    display: block;*/
    font-size: 1.2rem;
  }
  .using_list li {
    flex: 1 1 50%;
  }
  .using p, 
  .contact_list dl, .contact_list p {
    font-size: 1.2rem;
  }
  .contact_list {
    width: 100%;
  }
  .contact_list .outline_img {
    max-width: 90%;
    height: auto;
  }
  .banner_img {
    max-width: 90%;
  }
  .banner_img img {
    max-width: 100%;
    height: auto;
  }
}

/* iPhone 6-8 X 系 縦 */
@media only screen and (max-width:375px) {
  #header h2 {
    font-size: 1.4rem;
    margin-top: 30px;
  }
  #header h3 {
    font-size: 1rem;
    padding-bottom: 21rem;
  }
  #header h3 br {
    display: none;
  }
  #interior h1 {
    font-size: 1.6rem;
  }
  #interior p.sub_text {
    font-size: 1.2rem;
  }
}

/* iPhone 3-5 系 縦 */
@media only screen and (max-width:320px) {
  #interior h2 span {
    margin: 0 1.5em;
  }
  .using_list {
    display: block;
  }
}