@charset "UTF-8";
@import url(../fonts/Noto/load.css);
/*header
--------------------------------------------*/
#header {
  padding: 0 20px;
  position: absolute;
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  left: 0;
  right: 0;
  top: 0;
  z-index: 1001;
}
#header h1 {
  font-size: 10px;
  text-align: left;
  color: #6e6e6e;
}
#header .logo {
  -ms-flex-item-align: end;
  align-self: flex-end;
}
#header .h-right {
  width: 860px;
}
#header .info {
  width: 385px;
  margin-left: auto;
  text-align: right;
  margin-right: 15px;
  color: #6e6e6e;
}
#header .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}
#header .tel dt {
  font-size: 16px;
}
#header .tel dt:after {
  content: ":";
  padding: 0 5px;
}
#header .tel dd {
  letter-spacing: 1px;
  font-size: 24px;
}
#header .tel dd a {
  color: #6e6e6e;
}
#header .time,
#header .date {
  font-size: 14px;
  display: inline-block;
  vertical-align: middle;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
#header .time dt,
#header .time dd,
#header .date dt,
#header .date dd {
  display: inline-block;
  vertical-align: middle;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
#header .time {
  margin-right: 5px;
}
#header .mail {
  width: 160px;
  font-size: 16px;
}
#header .mail a {
  border: 1px solid #86afc5;
  padding: 10px 5px 10px 20px;
  color: #fff;
  display: block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  -webkit-box-shadow: 0 0 1px transparent;
  box-shadow: 0 0 1px transparent;
  position: relative;
  background: #86afc5;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
#header .mail a:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  -webkit-transform: scaleY(0);
  transform: scaleY(0);
  -webkit-transform-origin: 50%;
  transform-origin: 50%;
  -webkit-transition-property: transform;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
#header .mail a:hover,
#header .mail a:focus,
#header .mail a:active {
  color: #86afc5;
  filter: alpha(opacity=100);
  opacity: 1;
}
#header .mail a:hover:before,
#header .mail a:focus:before,
#header .mail a:active:before {
  -webkit-transform: scaleY(1);
  transform: scaleY(1);
}
#header .mail a span {
  position: relative;
}
#header .mail a span:before {
  position: absolute;
  content: "";
  background: url("../img/mail01.png?1582011855");
  width: 13px;
  height: 10px;
  top: 0;
  right: auto;
  bottom: 0;
  left: -25px;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  z-index: 10;
}

nav {
  margin-top: 10px;
}
nav ul {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}
nav li {
  font-size: 13px;
}
nav li a {
  padding: 0 24px;
  display: block;
  color: #5a3200;
}
nav li span {
  display: block;
}

/*メインビジュアル
--------------------------------------------*/
#main-visual {
  height: 860px;
  position: relative;
  background: url(../img/mv_bg.jpg) center no-repeat;
  background-size: cover;
}
#main-visual h2 {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 10;
}

/*共通
--------------------------------------------*/
.txt-blc {
  text-align: left;
}
.txt-blc p {
  margin-bottom: 20px;
}
.txt-blc p:last-child {
  margin-bottom: 0;
}

.cmn-btn {
  font-size: 16px;
  text-align: center;
}
.cmn-btn a {
  border: 1px solid #86afc5;
  padding: 10px 0;
  display: block;
  color: #fff;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  background: #86afc5;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  -webkit-box-shadow: 0 0 1px transparent;
  box-shadow: 0 0 1px transparent;
  position: relative;
  -webkit-transition-property: color;
  transition-property: color;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}
.cmn-btn a:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #fff;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 0 50%;
  transform-origin: 0 50%;
  -webkit-transition-property: transform;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
}
.cmn-btn a:hover,
.cmn-btn a:focus,
.cmn-btn a:active {
  color: #86afc5;
  filter: alpha(opacity=100);
  opacity: 1;
}
.cmn-btn a:hover:before,
.cmn-btn a:focus:before,
.cmn-btn a:active:before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
}
.cmn-btn a span {
  position: relative;
}
.cmn-btn a span:after {
  position: absolute;
  content: "";
  background: url("../img/news_arr.png?1582011856");
  width: 21px;
  height: 6px;
  top: 10px;
  right: -30px;
  bottom: 0;
  left: auto;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.cmn-btn a:hover span:after {
  position: absolute;
  content: "";
  background: url("../img/news_arr-hv.png?1582084436");
  width: 21px;
  height: 6px;
  top: 10px;
  right: -30px;
  bottom: 0;
  left: auto;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

/*section01
--------------------------------------------*/
#sec01 {
  padding: 75px 0 180px 0;
}
#sec01 .cont-wrap {
  position: relative;
}
#sec01 h3 {
  text-align: right;
  margin-bottom: 10px;
}
#sec01 .txt-blc {
  width: 670px;
  margin-left: auto;
  padding: 20px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  background: #fff;
  position: relative;
}
#sec01 .txt-blc:before {
  border-top: 1px solid #86afc5;
  width: 43px;
  height: 1px;
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  -webkit-transform: skewX(150deg);
  transform: skewX(150deg);
}
#sec01 .img-blc {
  position: absolute;
  z-index: -1;
  left: 0;
  top: 0;
}
#sec01 .img-blc:before {
  position: absolute;
  content: "";
  z-index: -2;
  width: 470px;
  height: 600px;
  background: rgba(134, 175, 197, 0.2);
  left: -30px;
  top: 30px;
}

/*section02
--------------------------------------------*/
#sec02 {
  padding: 65px 0 55px 0;
  background: url(../img/sec02_bg.jpg) center no-repeat;
  background-size: cover;
}
#sec02 h3 {
  margin-bottom: 30px;
}
#sec02 .check-lists {
  width: 570px;
  margin: 0 auto;
}
#sec02 .check-lists li {
  font-size: 18px;
  color: #5a3200;
  width: 200px;
  text-align: left;
  line-height: 2.5;
}
#sec02 .check-lists li span {
  position: relative;
}
#sec02 .check-lists li span:before {
  position: absolute;
  content: "";
  background: url("../img/sec02_check.png?1582011856");
  width: 18px;
  height: 14px;
  top: 0;
  right: auto;
  bottom: 0;
  left: -30px;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  z-index: 10;
}

/*section03
--------------------------------------------*/
#sec03 {
  padding: 85px 0 100px 0;
}
#sec03 h3 {
  margin-bottom: 90px;
}
#sec03 .cont-inner {
  position: relative;
}
#sec03 .cont-inner h4 {
  position: relative;
  font-size: 36px;
  color: #5a3200;
  margin-bottom: 40px;
}
#sec03 .cont-inner h4 span {
  position: relative;
}
#sec03 .cont-inner h4:after {
  position: absolute;
  content: "";
  background: url("../img/sec03_border.png?1582011856");
  width: 489px;
  height: 24px;
  top: auto;
  right: auto;
  bottom: -10px;
  left: 0;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec03 .cont-inner:first-child {
  margin-bottom: 130px;
}
#sec03 .cont-inner:first-child:before {
  position: absolute;
  content: "";
  background: url("../img/004.jpg");
  background-size: cover;
  width: 780px;
  height: 520px;
  top: 0;
  right: auto;
  bottom: 0;
  left: calc(50% - 800px);
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  z-index: 10;
}
#sec03 .cont-inner:first-child:after {
  position: absolute;
  content: "";
  width: 500px;
  height: 710px;
  background: rgba(134, 175, 197, 0.15);
  left: calc(50% - 870px);
  top: -150px;
}
#sec03 .cont-inner:first-child h4:before {
  position: absolute;
  content: "";
  background: url("../img/sec03_item01.png?1582011856");
  width: 70px;
  height: 69px;
  top: -65px;
  right: auto;
  bottom: auto;
  left: 0;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec03 .cont-inner:first-child h4 span:after {
  position: absolute;
  content: "";
  background: url("../img/sec03_sub01.png?1582011856");
  width: 121px;
  height: 29px;
  top: auto;
  right: -130px;
  bottom: 5px;
  left: auto;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec03 .cont-inner:first-child h4 span:after {
  position: absolute;
  content: "";
  background: url("../img/sec03_sub01.png?1582011856");
  width: 121px;
  height: 29px;
  top: auto;
  right: -130px;
  bottom: 5px;
  left: auto;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec03 .cont-inner:first-child .txt-blc {
  width: 490px;
  margin-left: auto;
}
#sec03 .cont-inner:first-child .cmn-btn {
  width: 330px;
  position: absolute;
  right: 520px;
  bottom: 100px;
  z-index: 10;
}
#sec03 .cont-inner:last-child:before {
  position: absolute;
  content: "";
  background: url("../img/003.jpg");
  background-size: cover;
  width: 780px;
  height: 520px;
  top: 0;
  right: calc(50% - 800px);
  bottom: 0;
  left: auto;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  z-index: 10;
}
#sec03 .cont-inner:last-child:after {
  position: absolute;
  content: "";
  width: 850px;
  height: 500px;
  background: rgba(134, 175, 197, 0.15);
  right: calc(50% - 870px);
  top: -85px;
}
#sec03 .cont-inner:last-child h4:before {
  position: absolute;
  content: "";
  background: url("../img/sec03_item02.png?1582011856");
  width: 97px;
  height: 69px;
  top: -65px;
  right: auto;
  bottom: auto;
  left: 0;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec03 .cont-inner:last-child h4 span:after {
  position: absolute;
  content: "";
  background: url("../img/sec03_sub02.png?1582011856");
  width: 124px;
  height: 21px;
  top: auto;
  right: -130px;
  bottom: 10px;
  left: auto;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec03 .cont-inner:last-child .txt-blc {
  width: 540px;
}

/*section04
--------------------------------------------*/
#sec04 {
  padding: 100px 0 140px 0;
  background: url(../img/sec04_border.png) top center repeat-x,
    url(../img/sec04_bg01.png) no-repeat, url(../img/sec04_bg02.png) no-repeat,
    url(../img/sec04_bg.jpg) center;
  background-position: 50% 0, calc(50% + 650px) 0, calc(50% - 700px) 75%,
    50% 50%;
  background-size: auto, auto, auto, cover;
}
#sec04 h3 {
  margin-bottom: 60px;
}
#sec04 .cont-frame {
  padding: 20px;
  background: url(../img/sec04_frame.png);
  margin-bottom: 70px;
  position: relative;
}
#sec04 .cont-frame:before {
  position: absolute;
  content: "";
  background: url("../img/sec04_leaf01.png?1582011857");
  width: 139px;
  height: 115px;
  top: -20px;
  right: auto;
  bottom: auto;
  left: -20px;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec04 .cont-frame:after {
  position: absolute;
  content: "";
  background: url("../img/sec04_leaf02.png?1582011857");
  width: 78px;
  height: 68px;
  top: auto;
  right: -15px;
  bottom: -15px;
  left: auto;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec04 .cont-frame:last-child {
  margin-bottom: 0;
}
#sec04 .cont-inner {
  background: #fff;
  padding: 25px 70px 45px 70px;
}
#sec04 h4 {
  font-size: 32px;
  color: #5a3200;
  margin-bottom: 30px;
  font-weight: 500;
}
#sec04 h4 span {
  position: relative;
}
#sec04 h4 span:before {
  position: absolute;
  content: "";
  background: url("../img/sec04_illust01.png?1582011857");
  width: 96px;
  height: 33px;
  top: 0;
  right: auto;
  bottom: 0;
  left: -125px;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  z-index: 10;
}
#sec04 h4 span:after {
  position: absolute;
  content: "";
  background: url("../img/sec04_illust02.png?1582011857");
  width: 96px;
  height: 33px;
  top: 0;
  right: -125px;
  bottom: 0;
  left: auto;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  z-index: 10;
}
#sec04 .menu-wrap {
  margin-bottom: 30px;
}
#sec04 .menu-wrap > dt {
  font-size: 21px;
  font-weight: 500;
  border-bottom: 3px double #d2c2a7;
  margin-bottom: 10px;
}
#sec04 .menu-wrap > dd dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
#sec04 .menu-wrap > dd dt {
  text-align: left;
}
#sec04 .menu-wrap > dd dt span {
  font-size: 18px;
  display: block;
}
#sec04 .menu-wrap > dd dd {
  font-size: 18px;
}

/*section05
--------------------------------------------*/
#sec05 {
  padding: 65px 0 85px 0;
  background: url(../img/sec05_bg.jpg);
  background-size: cover;
}
#sec05 h3 {
  margin-bottom: 50px;
}
#sec05 .voice-lists {
  width: 900px;
  margin: 0 auto;
}
#sec05 li {
  border: 1px solid #ccc2b1;
  background: #fff;
  position: relative;
  padding: 25px 35px;
  text-align: left;
  margin-bottom: 55px;
}
#sec05 li dt {
  font-size: 28px;
  border-bottom: 3px double #d2c2a7;
  margin-bottom: 10px;
  color: #5a3200;
}
#sec05 li dd {
  font-size: 16px;
}
#sec05 li:last-child {
  margin-bottom: 0;
}
#sec05 li:before {
  position: absolute;
  content: "";
  background: url("../img/voice_frame01.png?1582011857");
  width: 915px;
  height: 53px;
  top: -8px;
  right: 0;
  bottom: auto;
  left: -10px;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec05 li:after {
  position: absolute;
  content: "";
  background: url("../img/voice_frame02.png?1582011857");
  width: 915px;
  height: 53px;
  top: auto;
  right: 0;
  bottom: -8px;
  left: -10px;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
#sec05 .cmn-btn {
  width: 460px;
  margin: 0 auto;
  margin-top: 65px;
  cursor: pointer;
}

/*section06
--------------------------------------------*/
#sec06 {
  background: url(../img/sec06_bg.jpg);
  background-size: cover;
  padding-top: 75px;
}
#sec06 h3 {
  margin-bottom: 40px;
}
#sec06 .salon-tbl {
  margin-bottom: 60px;
}
#sec06 .map h4 {
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 10px;
}
#sec06 .map h4 span {
  position: relative;
}
#sec06 .map h4 span:before {
  position: absolute;
  content: "";
  background: url("../img/pin.png?1582011856");
  width: 12px;
  height: 16px;
  top: 0;
  right: auto;
  bottom: 0;
  left: -25px;
  background-repeat: no-repeat;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  z-index: 10;
}

/*section07
--------------------------------------------*/
#sec07 {
  padding: 65px 0 110px 0;
  background: url(../img/sec07_bg.jpg);
  background-size: cover;
}
#sec07 h3 {
  margin-bottom: 35px;
}
#sec07 .news-lists li {
  text-align: left;
  border-bottom: 1px dotted #333;
  cursor: pointer;
}
#sec07 .news-lists li:last-child {
  border-bottom: none;
}
#sec07 .news-lists li a {
  padding: 15px 10px;
  display: block;
}
#sec07 .news-lists li time {
  padding-right: 15px;
}
#sec07 .cmn-btn {
  width: 240px;
  margin: 0 auto;
  margin-top: 40px;
  cursor: pointer;
}
#sec07 .sns {
  width: 840px;
  margin: 0 auto;
  margin-top: 110px;
  margin-bottom: 65px;
}
#sec07 .modal-content {
  position: fixed;
  display: none;
  z-index: 100;
  width: 50%;
  margin: 0 auto;
  padding: 10px 20px;
  border: 2px solid #5a3200;
  background: #fff;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-box-shadow: 0 0 8px #ccc;
  box-shadow: 0 0 8px #ccc;
  text-align: left;
  left: 0 !important;
  right: 0;
}
#sec07 .modal-content img {
  max-width: 100%;
  width: auto;
  height: auto;
}
#sec07 .modal-content p {
  margin: 0;
  padding: 0;
}
#sec07 .modal-content .modal-ttl {
  font-size: 24px;
  font-weight: bold;
  color: #5a3200;
  margin-bottom: 15px;
}
#sec07 .modal-content .modal-time {
  display: block;
  text-align: right;
  font-weight: bold;
  font-size: 13px;
  margin-top: 10px;
  background: none;
  color: #5a3200;
}
#sec07 .modal-content .modal-open,
#sec07 .modal-content .modal-close {
  color: #674935;
}
#sec07 .modal-content .modal-open:hover,
#sec07 .modal-content .modal-close:hover {
  cursor: pointer;
  -webkit-box-shadow: none;
  box-shadow: none;
}
#sec07 .modal-content .modal-open a,
#sec07 .modal-content .modal-close a {
  -webkit-box-shadow: none;
  box-shadow: none;
}
#sec07 .modal-content .modal-close {
  background: url(../img/close.png) left center no-repeat;
  padding-left: 25px;
}

/*section08
--------------------------------------------*/
#sec08 {
  padding: 60px 0 90px 0;
  background: url(../img/sec08_bg.jpg) center no-repeat;
  background-size: cover;
}

/*footer
--------------------------------------------*/
#footer {
  background: #fff;
}
#footer .ft-nav {
  font-size: 10px;
  padding: 15px 0;
}
#footer .ft-nav a {
  padding: 0 35px;
  display: block;
  position: relative;
}
#footer .ft-nav a:hover {
  color: #86afc5;
}
#footer .ft-nav a:after {
  content: "|";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  /* Safari用 */
  transform: translateY(-50%);
  z-index: 10;
  right: 0;
}
#footer #copyright {
  font-size: 10px;
}
