@charset "UTF-8";
/* weight:400 */
/* weight:300 */
/* weight:400 */
/* weight:R:400,M:500,B:700 */
/* weight:M:500 */
/* structure
----------------------------------------------------------------------*/
html, body {
  overflow-x: hidden;
}

html {
  font-size: 62.5%; /* html入力枠用設定 */
}

body {
  width: 100%;
  color: #454345;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  font-family: ryo-gothic-plusn, sans-serif !important;
  font-weight: 400;
  font-style: normal;
  line-height: 1.7em;
  letter-spacing: 0.1em;
  text-align: left;
}

@media screen and (max-width: 767px) {
  body {
    font-size: 13px;
    line-height: 1.7em;
    letter-spacing: 0.1em;
  }
}
@media print {
  body {
    width: 1200px;
    transform: scale(0.8);
    -moz-transform: scale(0.8);
    -webkit-transform: scale(0.8);
    transform-origin: 0 0;
  }
}
input::-moz-placeholder {
  color: #A0A0A0;
}
input::placeholder {
  color: #A0A0A0;
}

textarea::-moz-placeholder {
  color: #A0A0A0;
}

textarea::placeholder {
  color: #A0A0A0;
}

/* IE */
input:-ms-input-placeholder {
  color: #A0A0A0;
}

textarea:-ms-input-placeholder {
  color: #A0A0A0;
}

/* Edge */
input::-ms-input-placeholder {
  color: #A0A0A0;
}

textarea::-ms-input-placeholder {
  color: #A0A0A0;
}

/* 携帯以外の電話リンク無効 */
@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    cursor: default;
    pointer-events: none;
  }
}
/* Scrollup */
#scrollUp {
  background: url("../images/icon/pagetop.png") left top no-repeat;
  background-size: contain;
  bottom: 40px;
  right: 30px;
  width: 60px;
  height: 60px;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  transition: all 0.3s ease 0s;
}

@media screen and (max-width: 767px) {
  #scrollUp {
    bottom: 30px;
    right: 20px;
    width: 50px;
    height: 50px;
  }
}
/* dl */
dl {
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

/* Object Fit */
.p_of {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  font-family: "object-fit:cover";
}

/* 非表示 */
body h1 {
  display: none;
}

.disno {
  display: none;
}

.sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
}
/*--------------------------------------------------*/
#wrapper {
  width: 100%;
  margin: 0 auto;
  overflow-x: hidden;
}

.headerarea {
  width: 100%;
  height: 100vh;
}
.headerarea .mainphoto {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  z-index: -1;
}

body#sante .mainphoto {
  background: url("../images/sante/titlephoto.jpg") center center no-repeat;
  background-size: cover;
}

body#pharmacy .mainphoto {
  background: url("../images/pharmacy/titlephoto.jpg") center center no-repeat;
  background-size: cover;
}

body#top .headerarea {
  position: relative;
  height: 688px;
  margin-bottom: 30px;
  z-index: 1;
}
body#top .headerarea .slider1 {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 80%;
  height: 580px;
  z-index: 1;
}
body#top .headerarea .slider1 .vegas-timer-progress {
  display: none;
}
body#top .headerarea h3.maincopy {
  position: absolute;
  top: 250px;
  left: 30px;
  width: 431px;
  height: 123px;
  background: url("../images/top/copy.png") left top no-repeat;
  background-size: contain;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  z-index: 2;
}

body#about .headerarea {
  width: 100%;
  height: 368px;
  background-color: #454345;
  padding-top: 30px;
}
body#about .headerarea .mainphoto {
  position: static;
  width: 1131px;
  height: 338px;
  background: url("../images/about/vege.png") center center no-repeat;
  background-size: contain;
  margin: 0 auto;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
}

body#menu .headerarea, body#contact .headerarea {
  width: 100%;
  height: 500px;
}
body#menu .headerarea .mainphoto, body#contact .headerarea .mainphoto {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 500px;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  z-index: -1;
}

body#menu .mainphoto {
  background: url("../images/menu/titlephoto.jpg") center center no-repeat;
  background-size: cover;
}

body#contact .mainphoto {
  background: url("../images/contact/titlephoto.jpg") center center no-repeat;
  background-size: cover;
}

header#basehead {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 135px;
  z-index: 199;
}
header#basehead dl {
  position: absolute;
  top: 0;
  left: 50%;
  width: 1100px;
  height: 135px;
  margin: 0 auto;
  transform: translateX(-50%);
  z-index: 1;
}
header#basehead dl dt {
  position: absolute;
  top: 20px;
  left: 50%;
  width: 464px;
  height: 61px;
  transform: translateX(-50%);
  z-index: 2;
}
header#basehead dl dt h2 {
  display: none;
}
header#basehead dl dt h2 a {
  display: none;
}
header#basehead dl dd.navi {
  position: absolute;
  top: 40px;
  right: 0;
  width: 100px;
  height: 30px;
  z-index: 2;
}
header#basehead dl dd.navi ul {
  display: flex;
  display: -webkit-flex;
  width: 100%;
  margin: 0 auto;
  flex-wrap: wrap;
  justify-content: space-between;
}
header#basehead dl dd.navi ul li.insta {
  width: 30px;
}
header#basehead dl dd.navi ul li.insta a {
  display: block;
  width: 30px;
  height: 30px;
  background: url("../images/header/insta_b.png") center center no-repeat;
  background-size: contain;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
}
header#basehead dl dd.navi ul li.hmenuarea {
  width: 35px;
}

body#top #basehead dl dt h2 {
  display: block;
}
body#top #basehead dl dt h2 a {
  display: block;
  width: 100%;
}

body#about #basehead dl dd.navi ul li.insta a {
  background: url("../images/header/insta_w.png") center center no-repeat;
  background-size: contain;
}

#navi {
  display: block;
  position: fixed;
  z-index: 200;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .headerarea {
    position: relative;
    width: 100%;
    height: 300px;
  }
  .headerarea .mainphoto {
    width: 100%;
    height: 300px;
  }
  body#top .headerarea {
    height: 450px;
    margin-bottom: 20px;
  }
  body#top .headerarea .slider1 {
    width: 100%;
    height: 300px;
  }
  body#top .headerarea h3.maincopy {
    position: absolute;
    top: 70px;
    left: 50%;
    width: 253px;
    height: 72px;
    background: url("../images/top/copy_sp.png") left top no-repeat;
    background-size: contain;
    transform: translateX(-50%);
  }
  body#about .headerarea {
    width: 100%;
    height: 184px;
    padding-top: 40px;
  }
  body#about .headerarea .mainphoto {
    width: 94%;
    height: auto;
    background: url("../images/about/vege.png") center bottom no-repeat;
    background-size: contain;
    margin: 0 auto;
    padding-top: 28.09%;
  }
  body#menu .headerarea, body#contact .headerarea {
    width: 100%;
    height: 250px;
  }
  body#menu .headerarea .mainphoto, body#contact .headerarea .mainphoto {
    width: 100%;
    height: 250px;
  }
  header#basehead {
    width: 100%;
    height: 68px;
  }
  header#basehead dl {
    top: 0;
    left: 50%;
    width: 94%;
    height: 68px;
    margin: 0 auto;
    transform: translateX(-50%);
  }
  header#basehead dl dt {
    position: absolute;
    top: 9px;
    left: 0;
    width: 242px;
    height: auto;
    transform: none;
  }
  header#basehead dl dd.navi {
    position: absolute;
    top: 15px;
    right: 0;
    width: 65px;
    height: 25px;
    z-index: 2;
  }
  header#basehead dl dd.navi ul {
    display: flex;
    display: -webkit-flex;
    width: 100%;
    margin: 0 auto;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  header#basehead dl dd.navi ul li.insta {
    width: 25px;
  }
  header#basehead dl dd.navi ul li.insta a {
    width: 25px;
    height: 25px;
  }
  header#basehead dl dd.navi ul li.hmenuarea {
    width: 25px;
  }
}
@media screen and (max-width: 360px) {
  header#basehead dl dt {
    width: 210px;
  }
}
/* fixhead
--------------------------------------------------*/
#fixhead {
  position: fixed;
  top: -110px;
  left: 0;
  width: 100%;
  height: 75px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 5px 5px -5px rgba(0, 0, 0, 0.1);
  opacity: 0;
  transition: all 1s;
  z-index: 200;
}
#fixhead #basehead dl {
  height: 75px;
}
#fixhead #basehead dl dt {
  top: 12px;
  width: 350px;
}
#fixhead #basehead dl dt h2 {
  display: block;
}
#fixhead #basehead dl dt h2 a {
  display: block;
  width: 100%;
}
#fixhead #basehead dl dd.navi {
  top: 22px;
}

#fixhead.scrolled {
  top: 0;
  opacity: 1;
}

body#about #fixhead .hmenu_btn span.line {
  border-bottom: 2px solid #454345;
}

body#about #fixhead #basehead dl dd.navi ul li.insta a {
  background: url("../images/header/insta_b.png") center center no-repeat;
  background-size: contain;
}

.hmenu_btn {
  display: block;
  position: relative;
  width: 35px;
  height: 30px;
  z-index: 1;
  text-align: center;
}
.hmenu_btn span.line {
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  border-bottom: 2px solid #454345;
  transform-origin: 0 0;
  transition: all 0.2s;
}
.hmenu_btn span.line:nth-child(1) {
  top: 5px;
}
.hmenu_btn span.line:nth-child(2) {
  top: 15px;
  opacity: 1;
}
.hmenu_btn span.line:nth-child(3) {
  top: 25px;
}

body#about .hmenu_btn span.line {
  border-bottom: 2px solid #FFF;
}

.hmenu_btn.active span.line:nth-child(1) {
  top: 3px;
  left: 1px;
  transform: rotate(45deg);
}

.hmenu_btn.active span.line:nth-child(2) {
  opacity: 0;
  transform: rotate(180deg);
}

.hmenu_btn.active span.line:nth-child(3) {
  top: 4px;
  left: 25px;
  transform: rotate(-225deg);
}

.hmenu_close {
  display: block;
  position: relative;
  width: 35px;
  height: 30px;
  z-index: 1000;
  text-align: center;
}

.hmenu_close span.line {
  display: block;
  position: absolute;
  left: 0;
  width: 35px;
  border-bottom: 2px solid #FFF;
  transform-origin: 0 0;
}

.hmenu_close span.line:nth-child(1) {
  top: 3px;
  left: 1px;
  transform: rotate(45deg);
}

.hmenu_close span.line:nth-child(2) {
  top: 4px;
  left: 25px;
  transform: rotate(-225deg);
}

@media screen and (max-width: 767px) {
  #fixhead {
    position: fixed;
    top: -78px;
    left: 0;
    width: 100%;
    height: 52px;
  }
  #fixhead #basehead dl {
    height: 52px;
  }
  #fixhead #basehead dl dt {
    top: 8px;
    width: 242px;
    height: auto;
  }
  #fixhead #basehead dl dd.navi {
    top: 13px;
  }
  .hmenu_btn {
    width: 25px;
    height: 25px;
  }
  .hmenu_btn span.line {
    left: 0;
    width: 100%;
    border-bottom: 2px solid #454345;
  }
  .hmenu_btn span.line:nth-child(1) {
    top: 4px;
  }
  .hmenu_btn span.line:nth-child(2) {
    top: 12px;
    opacity: 1;
  }
  .hmenu_btn span.line:nth-child(3) {
    top: 20px;
  }
  .hmenu_btn.active span.line:nth-child(1) {
    top: 2px;
    left: 3px;
    transform: rotate(45deg);
  }
  .hmenu_btn.active span.line:nth-child(3) {
    top: 3px;
    left: 20px;
    transform: rotate(-225deg);
  }
  .hmenu_close {
    display: block;
    position: relative;
    width: 25px;
    height: 25px;
    z-index: 1000;
    text-align: center;
  }
  .hmenu_close span.line {
    display: block;
    position: absolute;
    left: 0;
    width: 25px;
    border-bottom: 2px solid #FFF;
    transform-origin: 0 0;
  }
  .hmenu_close span.line:nth-child(1) {
    top: 2px;
    left: 3px;
    transform: rotate(45deg);
  }
  .hmenu_close span.line:nth-child(2) {
    top: 3px;
    left: 20px;
    transform: rotate(-225deg);
  }
}
@media screen and (max-width: 360px) {
  #fixhead #basehead dl dt {
    width: 210px;
  }
  #fixhead #basehead dl dd.navi {
    top: 20px;
  }
}
/* グローバルナビ
--------------------------------------------------*/
.hmenu {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  color: #FFF;
  background-color: #454345;
  z-index: 2000;
  transition: all 1s;
  transform: translateX(120%);
  opacity: 0;
}

.hmenu.active {
  opacity: 1;
  transform: translateX(0%);
}

.hmenu_in {
  width: 100%;
  margin: 0 auto;
  padding: 30px 0 18px 0;
  overflow: hidden;
}
.hmenu_in dl {
  position: relative;
  width: 95%;
  height: 135px;
  margin: 0 auto;
}
.hmenu_in dl dt {
  position: absolute;
  top: 0;
  left: 50%;
  width: 480px;
  height: 135px;
  transform: translateX(-50%);
  z-index: 1;
}
.hmenu_in dl dt a {
  display: block;
}
.hmenu_in dl dd {
  position: absolute;
  top: 30px;
  right: 30px;
  width: 35px;
  height: 30px;
  z-index: 1;
}

.hnavi {
  width: 95%;
  margin: 0 auto;
  padding: 20px 0 50px 0;
}
.hnavi ul.hnavi_menu {
  width: 100%;
  text-align: center;
}
.hnavi ul.hnavi_menu .navi_list {
  margin: 50px 0 0 0;
}
.hnavi ul.hnavi_menu .navi_list:first-child {
  margin: 0;
}
.hnavi ul.hnavi_menu .navi_link {
  display: block;
  width: 100%;
  color: #FFF;
  font-family: adobe-text-pro, serif;
  font-size: 30px;
  font-weight: 400;
  line-height: 1.3em;
  cursor: pointer;
}
.hnavi ul.hnavi_menu .navi_link span {
  display: block;
  font-size: 14px;
  font-family: a-otf-ryumin-pr6n, serif;
  font-weight: 300;
  line-height: 1.3em;
  margin-top: 15px;
}

@media screen and (max-width: 767px) {
  .hmenu_in {
    width: 100%;
    margin: 0 auto;
    padding: 9px 0 18px 0;
    overflow: hidden;
  }
  .hmenu_in dl {
    position: relative;
    width: 94%;
    height: 68px;
    margin: 0 auto;
  }
  .hmenu_in dl dt {
    position: absolute;
    top: 0;
    left: 0;
    width: 250px;
    height: auto;
    transform: none;
    z-index: 1;
  }
  .hmenu_in dl dd {
    position: absolute;
    top: 6px;
    right: 0;
    width: 25px;
    height: 25px;
    z-index: 1;
  }
  .hnavi {
    width: 95%;
    margin: 0 auto;
    padding: 20px 0 50px 0;
  }
  .hnavi ul.hnavi_menu .navi_list {
    margin: 30px 0 0 0;
  }
  .hnavi ul.hnavi_menu .navi_link {
    font-size: 24px;
    line-height: 1.3em;
  }
  .hnavi ul.hnavi_menu .navi_link span {
    font-size: 13px;
    line-height: 1.3em;
    margin-top: 7px;
  }
}
/* footer
--------------------------------------------------*/
footer {
  width: 100%;
  color: #FFF;
  background-color: #454345;
  padding: 40px 0 20px 0;
}
footer dl {
  width: 1050px;
  margin: 0 auto 30px auto;
}
footer dl dt, footer dl dd {
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
footer dl dt p.tx_time, footer dl dd p.tx_time {
  font-size: 13px;
  line-height: 1.7em;
  margin-bottom: 8px;
}
footer dl dt p.tel, footer dl dd p.tel {
  font-size: 13px;
  font-family: adobe-text-pro, serif;
  font-weight: 400;
  line-height: 20px;
  margin-bottom: 8px;
}
footer dl dt p.tel a, footer dl dd p.tel a {
  color: #FFF;
  font-size: 20px;
  line-height: 20px;
}
footer dl dt p.link, footer dl dd p.link {
  font-size: 13px;
  font-weight: 700;
  line-height: 25px;
}
footer dl dt p.link a, footer dl dd p.link a {
  display: block;
  color: #FFF;
  padding-left: 35px;
}
footer dl dt {
  width: 420px;
}
footer dl dd {
  width: 560px;
}
footer dl dt .logoarea {
  width: 147px;
}
footer dl dt .textarea {
  width: 230px;
}
footer dl dt .textarea p.link a {
  background: url("../images/footer/web.png") left top no-repeat;
  background-size: 25px 25px;
}
footer dl dd .logoarea {
  width: 196px;
}
footer dl dd .textarea {
  width: 330px;
}
footer dl dd .textarea p.link a {
  background: url("../images/footer/insta_g.png") left top no-repeat;
  background-size: 25px 25px;
}
footer p.tx_address {
  width: 100%;
  height: 40px;
  color: #454345;
  font-size: 13px;
  background-color: #B1B6AF;
  line-height: 40px;
  text-align: center;
  margin-bottom: 20px;
}
footer p.copyright {
  font-size: 11px;
  font-family: adobe-text-pro, serif;
  font-weight: 400;
  line-height: 1.4em;
  text-align: center;
}

@media screen and (max-width: 767px) {
  footer {
    padding: 30px 0 15px 0;
  }
  footer dl {
    width: 90%;
    margin: 0 auto 30px auto;
  }
  footer dl dt p.tx_time, footer dl dd p.tx_time {
    font-size: 12px;
    line-height: 1.7em;
    margin-bottom: 7px;
    text-align: center;
  }
  footer dl dt p.tel, footer dl dd p.tel {
    font-size: 12px;
    line-height: 20px;
    margin-bottom: 7px;
    text-align: center;
  }
  footer dl dt p.tel a, footer dl dd p.tel a {
    color: #FFF;
    font-size: 18px;
    line-height: 20px;
  }
  footer dl dt p.link, footer dl dd p.link {
    font-size: 12px;
    font-weight: 700;
    line-height: 25px;
    text-align: center;
  }
  footer dl dt p.link a, footer dl dd p.link a {
    display: block;
    color: #FFF;
    padding: 35px 0 0 0;
  }
  footer dl dt {
    width: 100%;
    margin-bottom: 40px;
  }
  footer dl dd {
    width: 100%;
  }
  footer dl dt .logoarea {
    width: 40%;
    margin: 0 auto 20px auto;
  }
  footer dl dt .textarea {
    width: 100%;
  }
  footer dl dt .textarea p.link a {
    background: url("../images/footer/web.png") center top no-repeat;
    background-size: 30px 30px;
  }
  footer dl dd .logoarea {
    width: 45%;
    margin: 0 auto 10px auto;
  }
  footer dl dd .textarea {
    width: 100%;
  }
  footer dl dd .textarea p.link a {
    background: url("../images/footer/insta_g.png") center top no-repeat;
    background-size: 30px 30px;
  }
  footer p.tx_address {
    width: 100%;
    height: 30px;
    font-size: 12px;
    line-height: 30px;
    margin-bottom: 15px;
  }
  footer p.copyright {
    font-size: 10px;
    line-height: 1.4em;
    text-align: center;
  }
}
/* カラム共通
----------------------------------------------------------------------*/
/* ボタン */
.btn_arrow {
  display: block;
  position: relative;
  width: 300px;
  height: 60px;
  background-color: #B1B6AF;
  margin: 0 auto;
}
.btn_arrow .tx_eng {
  position: absolute;
  top: 46%;
  left: 8%;
  width: 246px;
  color: #454345;
  font-size: 22px;
  font-family: adobe-text-pro, serif;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.15em;
  text-align: center;
  transform: translateY(-46%);
  z-index: 2;
}
.btn_arrow .tx {
  position: absolute;
  top: 50%;
  left: 8%;
  width: 246px;
  color: #454345;
  font-size: 16px;
  font-family: a-otf-gothic-bbb-pr6n, sans-serif;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.1em;
  text-align: center;
  transform: translateY(-50%);
  z-index: 2;
}
.btn_arrow .line {
  position: absolute;
  top: 26px;
  right: 8%;
  width: 9px;
  height: 9px;
  border-right: 2px solid #454345;
  border-bottom: 2px solid #454345;
  transform-origin: 50% 50%;
  transform: rotate(-45deg);
  z-index: 1;
}

.btn_outlink {
  display: block;
  position: relative;
  width: 345px;
  height: 60px;
  background-color: #B1B6AF;
  margin: 0 auto;
}
.btn_outlink .tx {
  position: absolute;
  top: 50%;
  left: 6%;
  width: 280px;
  color: #454345;
  font-size: 16px;
  font-family: a-otf-gothic-bbb-pr6n, sans-serif;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.1em;
  text-align: center;
  transform: translateY(-50%);
  z-index: 2;
}
.btn_outlink .outlink {
  position: absolute;
  top: 20px;
  right: 6%;
  width: 17px;
  height: 17px;
  background: url("../images/icon/outlink.svg") center top no-repeat;
  background-size: cover;
  z-index: 1;
}

/* ボタンエリア */
.contactbtnarea {
  background-color: #FFF;
  padding: 70px 0 50px 0;
}
.contactbtnarea h4 {
  font-size: 32px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.6em;
  letter-spacing: 0.3em;
  text-align: center;
  margin-bottom: 10px;
}
.contactbtnarea p {
  font-size: 18px;
  line-height: 1.7em;
  text-align: center;
  margin-bottom: 40px;
}
.contactbtnarea dl.btnarea {
  width: 750px;
  margin: 0 auto;
}
.contactbtnarea dl.btnarea .btn_left {
  display: block;
  position: relative;
  width: 345px;
  height: 60px;
  background-color: #FFF;
  border: 1px solid #454345;
  margin-bottom: 10px;
}
.contactbtnarea dl.btnarea .btn_left .tx {
  position: absolute;
  top: 50%;
  left: 6%;
  width: 280px;
  color: #454345;
  font-size: 16px;
  font-family: a-otf-gothic-bbb-pr6n, sans-serif;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.1em;
  text-align: center;
  transform: translateY(-50%);
  z-index: 2;
}
.contactbtnarea dl.btnarea .btn_left .outlink {
  position: absolute;
  top: 20px;
  right: 6%;
  width: 17px;
  height: 17px;
  background: url("../images/icon/outlink.svg") center top no-repeat;
  background-size: cover;
  z-index: 1;
}
.contactbtnarea dl.btnarea .btn_right {
  display: block;
  position: relative;
  width: 345px;
  height: 60px;
  background-color: #FFF;
  border: 1px solid #454345;
}
.contactbtnarea dl.btnarea .btn_right .tx {
  position: absolute;
  top: 50%;
  left: 6%;
  width: 290px;
  color: #454345;
  font-size: 16px;
  font-family: a-otf-gothic-bbb-pr6n, sans-serif;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.1em;
  text-align: center;
  transform: translateY(-50%);
  z-index: 2;
}
.contactbtnarea dl.btnarea .btn_right .line {
  position: absolute;
  top: 26px;
  right: 6%;
  width: 9px;
  height: 9px;
  border-right: 2px solid #454345;
  border-bottom: 2px solid #454345;
  transform-origin: 50% 50%;
  transform: rotate(-45deg);
  z-index: 1;
}
.contactbtnarea dl.btnarea .note {
  font-size: 13px;
  line-height: 1.4em;
  text-align: center;
}

.dlarea {
  width: 1040px;
  margin: 0 auto 80px auto;
  flex-wrap: wrap;
}
.dlarea .txtarea {
  width: 450px;
}
.dlarea .txtarea h4 {
  font-size: 32px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.7em;
  margin-bottom: 20px;
}
.dlarea .txtarea p {
  font-size: 15px;
  line-height: 2.2em;
  letter-spacing: 0.1em;
}
.dlarea .txtarea .smallimg {
  width: 255px;
  margin-top: 25px;
}
.dlarea .txtarea .btn_arrow {
  width: 345px;
  margin: 30px 0 0 0;
}
.dlarea .txtarea .btn_arrow .tx {
  width: 290px;
}
.dlarea .imgarea {
  width: 550px;
}

.bigimg {
  width: 930px;
  margin: 0 auto 80px auto;
}

.txt_c {
  line-height: 2.4em;
  text-align: center;
  margin-bottom: 50px;
}
.txt_c a {
  color: #FFF;
  text-decoration: underline;
}

body#menu .txt_c {
  line-height: 2.4em;
  text-align: center;
  margin-bottom: 30px;
}

h3.tl_ymin {
  font-size: 32px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.6em;
  letter-spacing: 0.3em;
  text-align: center;
  margin-bottom: 30px;
}
h3.tl_ymin span {
  display: block;
  font-size: 20px;
  font-family: a-otf-gothic-bbb-pr6n, sans-serif;
  font-weight: 400;
  line-height: 1.4em;
  letter-spacing: 0.1em;
  margin-bottom: 15px;
}

body#about h3.tl_ymin {
  line-height: 2.4em;
  margin-bottom: 60px;
}

h3.tl_eng {
  font-size: 42px;
  font-family: adobe-text-pro, serif;
  font-weight: 400;
  line-height: 1.4em;
  letter-spacing: 0.4em;
  text-align: center;
  margin-bottom: 30px;
}

h4.drugnabe {
  font-size: 32px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.6em;
  letter-spacing: 0.3em;
  text-align: center;
  background: url("../images/top/drugnabe.png") center top no-repeat;
  background-size: 362px 157px;
  margin-bottom: 30px;
  padding-top: 181px;
}

h4.nabe {
  font-size: 32px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.6em;
  letter-spacing: 0.3em;
  text-align: center;
  background: url("../images/top/nabe.png") center top no-repeat;
  background-size: 192px 176px;
  margin: 90px 0 30px 0;
  padding-top: 200px;
}

/* LightBox */
ul.lightboxarea {
  display: flex;
  display: -webkit-flex;
  width: 1040px;
  margin: 0 auto 80px auto;
  flex-wrap: wrap;
  justify-content: space-between;
}
ul.lightboxarea li {
  width: 320px;
  margin-bottom: 37px;
}

ul.lightboxarea::after {
  content: "";
  width: 320px;
}

body#pharmacy ul.lightboxarea {
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  /* ボタン */
  .btn_arrow {
    width: 280px;
    height: 50px;
  }
  .btn_arrow .tx_eng {
    top: 46%;
    left: 8%;
    width: 228px;
    font-size: 18px;
    line-height: 1em;
    letter-spacing: 0.15em;
    text-align: center;
    transform: translateY(-46%);
  }
  .btn_arrow .tx {
    top: 50%;
    left: 8%;
    width: 228px;
    font-size: 14px;
    line-height: 1em;
    letter-spacing: 0.1em;
    text-align: center;
    transform: translateY(-50%);
  }
  .btn_arrow .line {
    top: 22px;
    right: 8%;
    width: 8px;
    height: 8px;
    transform-origin: 50% 50%;
    transform: rotate(-45deg);
  }
  .btn_outlink {
    width: 280px;
    height: 50px;
  }
  .btn_outlink .tx {
    top: 50%;
    left: 6%;
    width: 228px;
    font-size: 14px;
    line-height: 1em;
    letter-spacing: 0.1em;
    text-align: center;
    transform: translateY(-50%);
  }
  .btn_outlink .outlink {
    top: 20px;
    right: 6%;
    width: 14px;
    height: 14px;
    background: url("../images/icon/outlink.svg") center top no-repeat;
    background-size: cover;
  }
  /* ボタンエリア */
  .contactbtnarea {
    padding: 40px 0;
  }
  .contactbtnarea h4 {
    font-size: 20px;
    line-height: 1.6em;
    letter-spacing: 0.2em;
    text-align: center;
    margin-bottom: 15px;
  }
  .contactbtnarea p {
    font-size: 13px;
    line-height: 1.7em;
    text-align: center;
    margin-bottom: 20px;
  }
  .contactbtnarea dl.btnarea {
    width: 90%;
    margin: 0 auto;
  }
  .contactbtnarea dl.btnarea dt {
    width: 280px;
    margin: 0 auto 15px auto;
  }
  .contactbtnarea dl.btnarea dd {
    width: 280px;
    margin: 0 auto;
  }
  .contactbtnarea dl.btnarea .btn_left {
    display: block;
    width: 280px;
    height: 50px;
    margin-bottom: 10px;
  }
  .contactbtnarea dl.btnarea .btn_left .tx {
    top: 50%;
    left: 6%;
    width: 228px;
    font-size: 14px;
    line-height: 1em;
    letter-spacing: 0.1em;
    text-align: center;
    transform: translateY(-50%);
  }
  .contactbtnarea dl.btnarea .btn_left .outlink {
    top: 20px;
    right: 6%;
    width: 14px;
    height: 14px;
    background: url("../images/icon/outlink.svg") center top no-repeat;
    background-size: cover;
  }
  .contactbtnarea dl.btnarea .btn_right {
    width: 280px;
    height: 50px;
  }
  .contactbtnarea dl.btnarea .btn_right .tx {
    top: 50%;
    left: 6%;
    width: 228px;
    font-size: 14px;
    line-height: 1em;
    letter-spacing: 0.1em;
    text-align: center;
    transform: translateY(-50%);
  }
  .contactbtnarea dl.btnarea .btn_right .line {
    top: 22px;
    right: 6%;
    width: 8px;
    height: 8px;
    transform-origin: 50% 50%;
    transform: rotate(-45deg);
    z-index: 1;
  }
  .contactbtnarea dl.btnarea .note {
    font-size: 11px;
    line-height: 1.4em;
    text-align: center;
  }
  .dlarea {
    width: 90%;
    margin: 0 auto 25px auto;
    flex-wrap: wrap;
  }
  .dlarea dt {
    margin-bottom: 25px;
  }
  .dlarea .txtarea {
    width: 100%;
  }
  .dlarea .txtarea h4 {
    font-size: 20px;
    line-height: 1.7em;
    margin-bottom: 15px;
  }
  .dlarea .txtarea p {
    font-size: 14px;
    line-height: 2em;
    letter-spacing: 0.1em;
  }
  .dlarea .txtarea .smallimg {
    width: 255px;
    margin-top: 15px;
  }
  .dlarea .txtarea .btn_arrow {
    width: 280px;
    margin: 30px auto 0 auto;
  }
  .dlarea .txtarea .btn_arrow .tx {
    width: 228px;
  }
  .dlarea .imgarea {
    width: 100%;
  }
  .bigimg {
    width: 96%;
    margin: 0 auto 40px auto;
  }
  .txt_c {
    line-height: 2em;
    text-align: center;
    margin-bottom: 30px;
  }
  body#pharmacy .txt_c, body#sante .txt_c, body#menu .txt_c {
    width: 90%;
    line-height: 2em;
    text-align: left;
    margin: 0 auto 20px auto;
  }
  body#menu .txt_c {
    width: 90%;
    line-height: 2em;
    text-align: center;
    margin: 0 auto 20px auto;
  }
  body#contact .txt_c {
    width: 96%;
    line-height: 2em;
    text-align: left;
    margin: 0 auto 40px auto;
  }
  h3.tl_ymin {
    font-size: 20px;
    line-height: 1.6em;
    letter-spacing: 0.2em;
    text-align: center;
    margin-bottom: 15px;
  }
  h3.tl_ymin span {
    display: block;
    font-size: 14px;
    line-height: 1.6em;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
  }
  body#about h3.tl_ymin {
    line-height: 2em;
    margin-bottom: 30px;
  }
  h3.tl_eng {
    font-size: 28px;
    line-height: 1.4em;
    letter-spacing: 0.4em;
    text-align: center;
    margin-bottom: 20px;
  }
  h4.drugnabe {
    font-size: 20px;
    line-height: 1.6em;
    letter-spacing: 0.2em;
    background: url("../images/top/drugnabe.png") center top no-repeat;
    background-size: 181px 79px;
    margin-bottom: 15px;
    padding-top: 101px;
  }
  h4.nabe {
    font-size: 20px;
    line-height: 1.6em;
    letter-spacing: 0.2em;
    background: url("../images/top/nabe.png") center top no-repeat;
    background-size: 96px 88px;
    margin: 45px 0 15px 0;
    padding-top: 110px;
  }
  /* LightBox */
  ul.lightboxarea {
    width: 90%;
    margin: 0 auto 40px auto;
  }
  ul.lightboxarea li {
    width: 47.5%;
    margin-bottom: 25px;
  }
  ul.lightboxarea::after {
    content: "";
    width: 47.5%;
  }
  body#pharmacy ul.lightboxarea {
    margin: 0 auto;
  }
}
/* top
----------------------------------------------------------------------*/
h2.tx_open {
  font-size: 36px;
  font-family: a-otf-ryumin-pr6n, serif;
  font-weight: 300;
  line-height: 1.6em;
  letter-spacing: 0.3em;
  text-align: center;
  margin-bottom: 30px;
}

.nakazawaarea {
  width: 100%;
  height: 500px;
}
.nakazawaarea a {
  display: block;
  position: relative;
  width: 100%;
  height: 500px;
  background: url("../images/top/nakazawa1.jpg") center center no-repeat;
  background-size: cover;
}
.nakazawaarea a .grey {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 500px;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 1;
}
.nakazawaarea a h3 {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 262px;
  height: 78px;
  background: url("../images/top/t_nakazawa.png") center center no-repeat;
  background-size: contain;
  transform: translate(-50%, -50%);
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  z-index: 2;
}

.santearea {
  width: 100%;
  height: 500px;
}
.santearea a {
  display: block;
  position: relative;
  width: 100%;
  height: 500px;
  background: url("../images/top/sante1.jpg") center center no-repeat;
  background-size: cover;
}
.santearea a .grey {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 500px;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 1;
}
.santearea a h3 {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 336px;
  height: 83px;
  background: url("../images/top/t_sante.png") center center no-repeat;
  background-size: contain;
  transform: translate(-50%, -50%);
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  z-index: 2;
}

.aboutarea {
  width: 100%;
  color: #FFF;
  background: #454345;
  padding: 50px 0 30px 0;
  text-align: center;
}
.aboutarea .vege {
  width: 100%;
  background: url("../images/top/vege.png") center bottom no-repeat;
  background-size: 1141px 417px;
  padding-bottom: 300px;
}
.aboutarea .vege p.tx_about {
  line-height: 2em;
  margin: 40px 0;
}
.aboutarea .vege .telbox {
  width: 490px;
  color: #454345;
  background-color: #B1B6AF;
  margin: 35px auto;
  padding: 15px 0;
}
.aboutarea .vege .telbox .tl_tel {
  font-size: 24px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.4em;
  margin-bottom: 10px;
}
.aboutarea .vege .telbox .tel {
  font-size: 28px;
  font-family: adobe-text-pro, serif;
  font-weight: 400;
  line-height: 45px;
  letter-spacing: 0.15em;
  margin-bottom: 5px;
}
.aboutarea .vege .telbox .tel a {
  color: #454345;
  font-size: 45px;
  line-height: 45px;
}
.aboutarea .vege .telbox .note {
  font-size: 18px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.4em;
  margin-bottom: 0;
}
.aboutarea .vege a.instalink {
  display: block;
  width: 70px;
  margin: 40px auto 15px auto;
}
.aboutarea .vege .tx_insta {
  font-size: 18px;
  font-weight: 500;
  line-height: 2em;
  margin: 0;
}

.accessarea {
  margin: 50px 0 0 0;
}
.accessarea h4 {
  font-size: 32px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.6em;
  letter-spacing: 0.3em;
  text-align: center;
  margin-bottom: 10px;
}
.accessarea p {
  font-size: 18px;
  line-height: 1.4em;
  text-align: center;
  margin-bottom: 40px;
}
.accessarea .gmap {
  position: relative;
  width: 100%;
  height: 500px;
}
.accessarea .gmap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  h2.tx_open {
    font-size: 24px;
    line-height: 1.6em;
    letter-spacing: 0.2em;
    margin-bottom: 20px;
  }
  .nakazawaarea {
    width: 100%;
    height: 250px;
  }
  .nakazawaarea a {
    width: 100%;
    height: 250px;
    background: url("../images/top/nakazawa1.jpg") center center no-repeat;
    background-size: cover;
  }
  .nakazawaarea a .grey {
    height: 250px;
  }
  .nakazawaarea a h3 {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 202px;
    height: 60px;
    background: url("../images/top/t_nakazawa.png") center center no-repeat;
    background-size: contain;
    transform: translate(-50%, -50%);
    z-index: 2;
  }
  .santearea {
    width: 100%;
    height: 250px;
  }
  .santearea a {
    width: 100%;
    height: 250px;
  }
  .santearea a .grey {
    height: 250px;
  }
  .santearea a h3 {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 262px;
    height: 65px;
    background: url("../images/top/t_sante.png") center center no-repeat;
    background-size: contain;
    transform: translate(-50%, -50%);
    z-index: 2;
  }
  .aboutarea {
    width: 100%;
    padding: 40px 0 30px 0;
    text-align: center;
  }
  .aboutarea .vege {
    width: 95%;
    background: url("../images/top/vege.png") center bottom no-repeat;
    background-size: contain;
    padding-bottom: 35%;
    margin: 0 auto;
  }
  .aboutarea .vege p.tx_about {
    line-height: 2em;
    margin: 20px 0 30px 0;
  }
  .aboutarea .vege .telbox {
    width: 300px;
    margin: 30px auto;
    padding: 15px 0;
  }
  .aboutarea .vege .telbox .tl_tel {
    font-size: 16px;
    line-height: 1.4em;
    margin-bottom: 10px;
  }
  .aboutarea .vege .telbox .tel {
    font-size: 18px;
    line-height: 24px;
    letter-spacing: 0.15em;
    margin-bottom: 5px;
  }
  .aboutarea .vege .telbox .tel a {
    color: #454345;
    font-size: 24px;
    line-height: 24px;
  }
  .aboutarea .vege .telbox .note {
    font-size: 16px;
    line-height: 1.4em;
    margin-bottom: 0;
  }
  .aboutarea .vege a.instalink {
    display: block;
    width: 50px;
    margin: 40px auto 15px auto;
  }
  .aboutarea .vege .tx_insta {
    font-size: 16px;
    font-weight: 500;
    line-height: 2em;
  }
  .accessarea {
    margin: 30px 0 0 0;
  }
  .accessarea h4 {
    font-size: 20px;
    line-height: 1.6em;
    letter-spacing: 0.2em;
    text-align: center;
    margin-bottom: 10px;
  }
  .accessarea p {
    font-size: 13px;
    line-height: 1.4em;
    text-align: center;
    margin-bottom: 20px;
  }
  .accessarea .gmap {
    position: relative;
    width: 100%;
    height: 250px;
  }
}
/* about
----------------------------------------------------------------------*/
.conceptarea {
  color: #FFF;
  background-color: #454345;
  padding: 80px 0;
}
.conceptarea .dl_imgbox {
  width: 100%;
  margin: 48px 0 0 0;
}
.conceptarea .dl_imgbox dt, .conceptarea .dl_imgbox dd {
  width: 47%;
}
.conceptarea .imgbox {
  width: 100%;
  margin: 36px 0 0 0;
}
.conceptarea h2.alogo {
  width: 480px;
  height: 102px;
  background: url("../images/about/logo.png") top left no-repeat;
  background-size: contain;
  margin: 40px auto 0 auto;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
}

@media screen and (max-width: 767px) {
  .conceptarea {
    padding: 20px 0 40px 0;
  }
  .conceptarea .txt_c {
    line-height: 2.4em;
  }
  .conceptarea .dlarea {
    text-align: center;
  }
  .conceptarea .dlarea p {
    line-height: 2.4em;
  }
  .conceptarea .dl_imgbox {
    width: 100%;
    margin: 20px 0 0 0;
  }
  .conceptarea .dl_imgbox dt, .conceptarea .dl_imgbox dd {
    width: 47%;
    margin: 0;
  }
  .conceptarea .imgbox {
    width: 100%;
    margin: 20px 0 0 0;
  }
  .conceptarea h2.alogo {
    width: 85%;
    height: auto;
    background: url("../images/about/logo.png") top left no-repeat;
    background-size: contain;
    margin: 20px auto 0 auto;
    padding-top: 18.04%;
  }
}
/* 中沢薬局 山梨厚生病院前店
----------------------------------------------------------------------*/
.pharmacyarea {
  color: #FFF;
  background-color: #454345;
  padding: 80px 0;
}
.pharmacyarea .fullphoto1 {
  position: relative;
  width: 100%;
  height: 620px;
  margin: 0 0 80px 0;
}
.pharmacyarea dl.facilityarea {
  width: 1040px;
  margin: 0 auto 80px auto;
}
.pharmacyarea dl.facilityarea dt, .pharmacyarea dl.facilityarea dd {
  width: 470px;
}
.pharmacyarea dl.facilityarea dt h4, .pharmacyarea dl.facilityarea dd h4 {
  font-size: 30px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.6em;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}
.pharmacyarea dl.facilityarea dt p, .pharmacyarea dl.facilityarea dd p {
  font-size: 16px;
  line-height: 2.2em;
  margin-bottom: 25px;
}
.pharmacyarea dl.facilityarea dt .imgarea, .pharmacyarea dl.facilityarea dd .imgarea {
  width: 100%;
}
.pharmacyarea dl.servicearea {
  width: 1040px;
  margin: 0 auto 80px auto;
}
.pharmacyarea dl.servicearea dt, .pharmacyarea dl.servicearea dd {
  width: 470px;
}
.pharmacyarea dl.servicearea dt h4.i1, .pharmacyarea dl.servicearea dt h4.i2, .pharmacyarea dl.servicearea dt h4.i3, .pharmacyarea dl.servicearea dd h4.i1, .pharmacyarea dl.servicearea dd h4.i2, .pharmacyarea dl.servicearea dd h4.i3 {
  font-size: 24px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 32px;
  letter-spacing: 0.1em;
  margin-bottom: 15px;
  padding: 0 0 0 48px;
}
.pharmacyarea dl.servicearea dt h4.i1, .pharmacyarea dl.servicearea dd h4.i1 {
  background: url("../images/pharmacy/i1.png") top left no-repeat;
  background-size: 40px 32px;
}
.pharmacyarea dl.servicearea dt h4.i2, .pharmacyarea dl.servicearea dd h4.i2 {
  background: url("../images/pharmacy/i2.png") top left no-repeat;
  background-size: 40px 32px;
}
.pharmacyarea dl.servicearea dt h4.i3, .pharmacyarea dl.servicearea dd h4.i3 {
  background: url("../images/pharmacy/i3.png") top left no-repeat;
  background-size: 40px 32px;
}
.pharmacyarea dl.servicearea dt p.tx_service, .pharmacyarea dl.servicearea dd p.tx_service {
  font-size: 14px;
  line-height: 2.2em;
  margin-bottom: 15px;
}
.pharmacyarea dl.servicearea dt p.smalltxt, .pharmacyarea dl.servicearea dd p.smalltxt {
  font-size: 12px;
  line-height: 1.6em;
}
.pharmacyarea dl.servicearea dt p.smalltxt span, .pharmacyarea dl.servicearea dd p.smalltxt span {
  display: block;
  margin: 5px;
  padding-left: 1em;
  text-indent: -1em;
}
.pharmacyarea dl.servicearea dt .btn_outlink, .pharmacyarea dl.servicearea dd .btn_outlink {
  margin: 30px 0 40px 0;
}
.pharmacyarea dl.servicearea dt .voicebox, .pharmacyarea dl.servicearea dd .voicebox {
  width: 100%;
  color: #454345;
  background-color: #B1B6AF;
  margin-bottom: 10px;
  padding: 15px;
}
.pharmacyarea dl.servicearea dt .voicebox h4, .pharmacyarea dl.servicearea dd .voicebox h4 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 10px;
}
.pharmacyarea dl.servicearea dt .voicebox ul, .pharmacyarea dl.servicearea dd .voicebox ul {
  font-size: 15px;
  line-height: 23px;
}
.pharmacyarea dl.servicearea dt .voicebox ul li, .pharmacyarea dl.servicearea dd .voicebox ul li {
  border-bottom: 1px solid #454345;
  margin-bottom: 10px;
  padding: 0 5px 5px 30px;
}
.pharmacyarea dl.servicearea dt .voicebox ul li.v1, .pharmacyarea dl.servicearea dd .voicebox ul li.v1 {
  background: url("../images/pharmacy/v1.png") top left no-repeat;
  background-size: 25px 23px;
}
.pharmacyarea dl.servicearea dt .voicebox ul li.v2, .pharmacyarea dl.servicearea dd .voicebox ul li.v2 {
  background: url("../images/pharmacy/v2.png") top left no-repeat;
  background-size: 25px 23px;
}
.pharmacyarea dl.servicearea dt .voicebox ul li.v3, .pharmacyarea dl.servicearea dd .voicebox ul li.v3 {
  background: url("../images/pharmacy/v3.png") top left no-repeat;
  background-size: 25px 23px;
}
.pharmacyarea dl.servicearea dt .voicebox ul li:last-child, .pharmacyarea dl.servicearea dd .voicebox ul li:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 767px) {
  .pharmacyarea {
    padding: 40px 0;
  }
  .pharmacyarea .dlarea {
    margin-bottom: 50px;
  }
  .pharmacyarea .dlarea h4 {
    text-align: center;
  }
  .pharmacyarea .dlarea .btn_arrow {
    margin: 20px auto 10px auto;
  }
  .pharmacyarea .fullphoto1 {
    height: 310px;
    margin: 0 0 30px 0;
  }
  .pharmacyarea dl.facilityarea {
    width: 90%;
    margin: 0 auto 40px auto;
  }
  .pharmacyarea dl.facilityarea dt, .pharmacyarea dl.facilityarea dd {
    width: 100%;
  }
  .pharmacyarea dl.facilityarea dt h4, .pharmacyarea dl.facilityarea dd h4 {
    font-size: 20px;
    line-height: 1.6em;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
  }
  .pharmacyarea dl.facilityarea dt p, .pharmacyarea dl.facilityarea dd p {
    font-size: 13px;
    line-height: 2.2em;
    margin-bottom: 20px;
  }
  .pharmacyarea dl.facilityarea dt {
    margin-bottom: 30px;
  }
  .pharmacyarea dl.servicearea {
    width: 90%;
    margin: 30px auto 40px auto;
  }
  .pharmacyarea dl.servicearea dt, .pharmacyarea dl.servicearea dd {
    width: 100%;
  }
  .pharmacyarea dl.servicearea dt h4.i1, .pharmacyarea dl.servicearea dt h4.i2, .pharmacyarea dl.servicearea dt h4.i3, .pharmacyarea dl.servicearea dd h4.i1, .pharmacyarea dl.servicearea dd h4.i2, .pharmacyarea dl.servicearea dd h4.i3 {
    font-size: 20px;
    line-height: 32px;
    letter-spacing: 0.1em;
    margin-bottom: 15px;
    padding: 0 0 0 48px;
  }
  .pharmacyarea dl.servicearea dt p.tx_service, .pharmacyarea dl.servicearea dd p.tx_service {
    font-size: 13px;
    line-height: 2.2em;
    margin-bottom: 15px;
  }
  .pharmacyarea dl.servicearea dt p.smalltxt, .pharmacyarea dl.servicearea dd p.smalltxt {
    font-size: 11px;
    line-height: 1.6em;
  }
  .pharmacyarea dl.servicearea dt p.smalltxt span, .pharmacyarea dl.servicearea dd p.smalltxt span {
    display: block;
    margin: 5px;
    padding-left: 1em;
    text-indent: -1em;
  }
  .pharmacyarea dl.servicearea dt .btn_outlink, .pharmacyarea dl.servicearea dd .btn_outlink {
    margin: 30px auto 40px auto;
  }
  .pharmacyarea dl.servicearea dt .voicebox, .pharmacyarea dl.servicearea dd .voicebox {
    width: 100%;
    margin-bottom: 10px;
    padding: 15px;
  }
  .pharmacyarea dl.servicearea dt .voicebox h4, .pharmacyarea dl.servicearea dd .voicebox h4 {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 15px;
  }
  .pharmacyarea dl.servicearea dt .voicebox ul, .pharmacyarea dl.servicearea dd .voicebox ul {
    font-size: 14px;
    line-height: 23px;
  }
  .pharmacyarea dl.servicearea dt .voicebox ul li, .pharmacyarea dl.servicearea dd .voicebox ul li {
    border-bottom: 1px solid #454345;
    margin-bottom: 10px;
    padding: 0 5px 5px 30px;
  }
  .pharmacyarea dl.servicearea dt {
    margin-bottom: 30px;
  }
}
/* カフェサンテ
----------------------------------------------------------------------*/
.santearea1 {
  color: #FFF;
  background-color: #454345;
  padding: 80px 0;
}
.santearea1 .fullphoto1 {
  position: relative;
  width: 100%;
  height: 620px;
  margin: 0 0 80px 0;
}
.santearea1 .tx_hbanner {
  font-size: 20px;
  font-weight: 500;
  line-height: 2em;
  text-align: center;
  margin: 0 0 30px 0;
}
.santearea1 .hbanner {
  display: block;
  width: 320px;
  margin: 0 auto 80px auto;
}
.santearea1 h4.tl_boxseat {
  font-size: 30px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.6em;
  letter-spacing: 0.1em;
  text-align: center;
  margin-bottom: 20px;
}
.santearea1 .boxphoto {
  width: 1040px;
  margin: 0 auto;
}
.santearea1 .boxphoto dt, .santearea1 .boxphoto dd {
  width: 498px;
}

.fullphoto2 {
  position: relative;
  width: 100%;
  height: 400px;
  margin: 0 0 100px 0;
}
.fullphoto2 .btn_arrow {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 300px;
  height: 60px;
  background-color: #FFF;
  border: 1px solid #454345;
  transform: translate(-50%, -50%);
  margin: 0;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .santearea1 {
    padding: 40px 0;
  }
  .santearea1 .dlarea {
    margin-bottom: 50px;
    flex-wrap: wrap-reverse;
  }
  .santearea1 .dlarea dt {
    margin-bottom: 0;
  }
  .santearea1 .dlarea dd {
    margin-bottom: 20px;
  }
  .santearea1 .dlarea h4 {
    text-align: center;
  }
  .santearea1 .fullphoto1 {
    height: 310px;
    margin: 0 0 40px 0;
  }
  .santearea1 .tx_hbanner {
    font-size: 16px;
    line-height: 2em;
    text-align: center;
    margin: 0 0 20px 0;
  }
  .santearea1 .hbanner {
    display: block;
    width: 90%;
    margin: 0 auto 50px auto;
  }
  .santearea1 h4.tl_boxseat {
    font-size: 20px;
    line-height: 1.6em;
    letter-spacing: 0.1em;
    text-align: center;
    margin-bottom: 10px;
  }
  .santearea1 .boxphoto {
    width: 90%;
    margin: 0 auto;
  }
  .santearea1 .boxphoto dt, .santearea1 .boxphoto dd {
    width: 100%;
  }
  .santearea1 .boxphoto dt {
    margin-bottom: 25px;
  }
  .fullphoto2 {
    position: relative;
    width: 100%;
    height: 250px;
    margin: 0 0 60px 0;
  }
  .fullphoto2 .btn_arrow {
    width: 280px;
    height: 50px;
  }
}
/* カフェサンテメニュー
----------------------------------------------------------------------*/
.santemarea1 {
  color: #FFF;
  background-color: #454345;
  padding: 80px 0;
}
.santemarea1 .menu {
  display: flex;
  display: -webkit-flex;
  width: 700px;
  margin: 0 auto 60px auto;
  flex-wrap: wrap;
  justify-content: space-between;
}
.santemarea1 .menu li {
  width: 313px;
  margin-bottom: 65px;
}
.santemarea1 .curry {
  width: 550px;
  margin: 0 auto 65px auto;
}
.santemarea1 .tsukigawari {
  width: 550px;
  margin: 0 auto;
}

.santemarea2 {
  color: #454345;
  background-color: #FFF;
  padding: 80px 0 30px 0;
}
.santemarea2 ul.menu {
  display: flex;
  display: -webkit-flex;
  width: 700px;
  margin: 0 auto 60px auto;
  flex-wrap: wrap;
  justify-content: space-between;
}
.santemarea2 ul.menu li {
  width: 313px;
  border: 1px solid #454345;
}
.santemarea2 a.btn1 {
  display: block;
  width: 280px;
  height: 60px;
  color: #FFF;
  font-size: 16px;
  font-weight: 700;
  line-height: 60px;
  text-align: center;
  background-color: #94CAC5;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .santemarea1 {
    padding: 40px 0;
  }
  .santemarea1 .menu {
    width: 90%;
    margin: 0 auto 40px auto;
  }
  .santemarea1 .menu li {
    width: 45%;
    margin-bottom: 30px;
  }
  .santemarea1 .curry {
    width: 80%;
    margin: 0 auto 30px auto;
  }
  .santemarea1 .tsukigawari {
    width: 80%;
    margin: 0 auto;
  }
  .santemarea2 {
    padding: 40px 0 20px 0;
  }
  .santemarea2 ul.menu {
    width: 90%;
    margin: 0 auto 40px auto;
  }
  .santemarea2 ul.menu li {
    width: 45%;
  }
}
/* お問い合わせフォーム
----------------------------------------------------------------------*/
.contactarea {
  color: #FFF;
  background-color: #454345;
  padding: 80px 0;
}
.contactarea dl.formarea {
  width: 850px;
  margin: 0 auto 100px auto;
}
.contactarea dl.formarea dt {
  width: 250px;
  margin-bottom: 50px;
}
.contactarea dl.formarea dd {
  width: 600px;
  margin-bottom: 50px;
}
.contactarea dl.formarea label {
  display: block;
  font-size: 18px;
  font-weight: 700;
  line-height: 50px;
}
.contactarea dl.formarea .formitem1 {
  height: 50px;
}
.contactarea dl.formarea .formitem2 {
  height: 250px;
}
.contactarea dl.formarea .text1 {
  width: 100%;
  height: 50px;
  font-size: 16px;
  line-height: 1.6em;
  background-color: #FFF;
  padding: 10px;
}
.contactarea dl.formarea .textarea1 {
  width: 100%;
  height: 250px;
  font-size: 16px;
  line-height: 1.6em;
  background-color: #FFF;
  padding: 10px;
}
.contactarea dl.formarea .check1 {
  width: 20px;
  height: 20px;
  background-color: #FFF;
}
.contactarea dl.formarea select.pull1 {
  width: 40%;
  height: 50px;
  color: #454345;
  font-size: 16px;
  line-height: 1.6em;
  background-color: #FFF;
  border-radius: 0;
  padding: 10px;
}
.contactarea .checkbox {
  font-size: 16px;
  line-height: 1.4em;
  text-align: center;
  margin: 0 auto 40px auto;
}
.contactarea .tl_privacy {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.4em;
  text-align: center;
  margin: 0 0 15px 0;
}
.contactarea .tx_privacy {
  font-size: 16px;
  line-height: 1.4em;
  text-align: center;
  margin: 0 0 30px 0;
}
.contactarea .privacybox {
  width: 850px;
  height: 250px;
  color: #454345;
  background-color: #FFF;
  margin: 0 auto 40px auto;
  padding: 15px;
  overflow: scroll;
}
.contactarea .privacybox h4 {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.7em;
  margin-bottom: 5px;
}
.contactarea .privacybox p {
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6em;
  margin-bottom: 20px;
}
.contactarea .btnarea {
  width: 300px;
  margin: 0 auto;
  text-align: center;
}
.contactarea .btnarea button {
  position: relative;
  width: 100%;
  height: 60px;
  background-color: #B1B6AF;
  transition: opacity 0.3s ease-out;
}
.contactarea .btnarea button .tx {
  position: absolute;
  top: 50%;
  left: 8%;
  width: 246px;
  color: #454345;
  font-size: 16px;
  font-family: a-otf-gothic-bbb-pr6n, sans-serif;
  font-weight: 400;
  line-height: 1em;
  letter-spacing: 0.1em;
  text-align: center;
  transform: translateY(-50%);
  z-index: 2;
}
.contactarea .btnarea button .line {
  position: absolute;
  top: 26px;
  right: 8%;
  width: 9px;
  height: 9px;
  border-right: 2px solid #454345;
  border-bottom: 2px solid #454345;
  transform-origin: 50% 50%;
  transform: rotate(-45deg);
  z-index: 1;
}
.contactarea .btnarea button:hover {
  opacity: 0.6;
  -webkit-opacity: 0.6;
  -moz-opacity: 0.6;
}

@media screen and (max-width: 767px) {
  .contactarea {
    padding: 40px 0;
  }
  .contactarea dl.formarea {
    width: 90%;
    margin: 0 auto 40px auto;
  }
  .contactarea dl.formarea dt {
    width: 100%;
    margin-bottom: 10px;
  }
  .contactarea dl.formarea dd {
    width: 100%;
    margin-bottom: 20px;
  }
  .contactarea dl.formarea label {
    display: block;
    font-size: 16px;
    line-height: 1.6em;
  }
  .contactarea dl.formarea .formitem1 {
    height: 50px;
  }
  .contactarea dl.formarea .formitem2 {
    height: 200px;
  }
  .contactarea dl.formarea .text1 {
    width: 100%;
    height: 40px;
    font-size: 16px;
    line-height: 1.6em;
    padding: 10px;
  }
  .contactarea dl.formarea .textarea1 {
    width: 100%;
    height: 200px;
    font-size: 16px;
    line-height: 1.6em;
    padding: 10px;
  }
  .contactarea dl.formarea .check1 {
    width: 20px;
    height: 20px;
  }
  .contactarea dl.formarea select.pull1 {
    width: 70%;
    height: 40px;
    font-size: 16px;
    line-height: 1.6em;
    padding: 10px;
  }
  .contactarea .checkbox {
    font-size: 14px;
    line-height: 1.4em;
    text-align: center;
    margin: 0 auto 30px auto;
  }
  .contactarea .tl_privacy {
    font-size: 18px;
    line-height: 1.8em;
    text-align: center;
    margin: 0 0 10px 0;
  }
  .contactarea .tx_privacy {
    width: 90%;
    font-size: 13px;
    line-height: 1.7em;
    text-align: left;
    margin: 0 auto 15px auto;
  }
  .contactarea .privacybox {
    width: 90%;
    height: 200px;
    margin: 0 auto 30px auto;
    padding: 10px;
  }
  .contactarea .privacybox h4 {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.7em;
    margin-bottom: 5px;
  }
  .contactarea .privacybox p {
    font-size: 12px;
    font-weight: 400;
    line-height: 1.6em;
    margin-bottom: 20px;
  }
  .contactarea .btnarea {
    width: 280px;
    margin: 0 auto;
    text-align: center;
  }
  .contactarea .btnarea button {
    width: 100%;
    height: 50px;
  }
  .contactarea .btnarea button .tx {
    top: 50%;
    left: 8%;
    width: 228px;
    font-size: 14px;
    line-height: 1em;
    letter-spacing: 0.1em;
    text-align: center;
    transform: translateY(-50%);
  }
  .contactarea .btnarea button .line {
    position: absolute;
    top: 22px;
    right: 8%;
    width: 8px;
    height: 8px;
    transform-origin: 50% 50%;
    transform: rotate(-45deg);
  }
}
/* スクロールトリガー
--------------------------------------------------*/
.visible, .invisible {
  opacity: 0;
  transition: opacity 0.5s ease;
}

.visible {
  opacity: 1;
}

.visible.translateY, .invisible.translateY {
  transform: translateY(100px);
  transition: all 1s cubic-bezier(0.165, 0.5, 0.44, 1);
}

.visible.translateY {
  transform: translateY(0);
}

.visible.translateToLeft, .invisible.translateToLeft {
  transform: translateX(100px);
  transition: all 1s cubic-bezier(0.165, 0.5, 0.44, 1);
}

.visible.translateToLeft {
  transform: translateX(0);
}

.visible.translateToRight, .invisible.translateToRight {
  transform: translateX(-100px);
  transition: all 1s cubic-bezier(0.165, 0.5, 0.44, 1);
}

.visible.translateToRight {
  transform: translateX(0);
}

@media screen and (max-width: 767px) {
  .photoarea_r .visible.translateToLeft, .invisible.translateToLeft {
    transform: translateX(50px);
  }
  .photoarea_r .visible.translateToLeft {
    transform: translateX(-50%);
  }
  .photoarea_r .visible.translateToRight, .invisible.translateToRight {
    transform: translateX(-50px);
  }
  .photoarea_r .visible.translateToRight {
    transform: translateX(-50%);
  }
  .photoarea_l .visible.translateToLeft, .invisible.translateToLeft {
    transform: translateX(50px);
  }
  .photoarea_l .visible.translateToLeft {
    transform: translateX(-50%);
  }
  .photoarea_l .visible.translateToRight, .invisible.translateToRight {
    transform: translateX(-50px);
  }
  .photoarea_l .visible.translateToRight {
    transform: translateX(-50%);
  }
}
/* vegasアニメーション
--------------------------------------------------*/
/*******************************************/
/* customDownLeft animation */
/*******************************************/
.vegas-animation-customDownLeft {
  animation: customDownLeft ease-out;
}
@keyframes customDownLeft {
  0% {
    transform: scale(1.3) translate(5%, -5%);
  }
  100% {
    transform: scale(1) translate(0, 0);
  }
}
/*******************************************/
/* customDownRight animation */
/*******************************************/
.vegas-animation-customDownRight {
  animation: customDownRight ease-out;
}
@keyframes customDownRight {
  0% {
    transform: scale(1.3) translate(-5%, -5%);
  }
  100% {
    transform: scale(1) translate(0, 0);
  }
}
/*******************************************/
/* customDown animation */
/*******************************************/
.vegas-animation-customDown {
  animation: customDown ease-out;
}
@keyframes customDown {
  0% {
    transform: scale(1.3) translate(0, -5%);
  }
  100% {
    transform: scale(1) translate(0, 0);
  }
}
/*******************************************/
/* customLeft animation */
/*******************************************/
.vegas-animation-customLeft {
  animation: customLeft ease-out;
}
@keyframes customLeft {
  0% {
    transform: scale(1.3) translate(5%, 0);
  }
  100% {
    transform: scale(1) translate(0, 0);
  }
}
/*******************************************/
/* customRight animation */
/*******************************************/
.vegas-animation-customRight {
  animation: customRight ease-out;
}
@keyframes customRight {
  0% {
    transform: scale(1.3) translate(-5%, 0);
  }
  100% {
    transform: scale(1) translate(0, 0);
  }
}
/*******************************************/
/* customUpLeft animation */
/*******************************************/
.vegas-animation-customUpLeft {
  animation: customUpLeft ease-out;
}
@keyframes customUpLeft {
  0% {
    transform: scale(1.3) translate(5%, 5%);
  }
  100% {
    transform: scale(1) translate(0, 0);
  }
}
/*******************************************/
/* customUpRight animation */
/*******************************************/
.vegas-animation-customUpRight {
  animation: customUpRight ease-out;
}
@keyframes customUpRight {
  0% {
    transform: scale(1.3) translate(-5%, 5%);
  }
  100% {
    transform: scale(1) translate(0, 0);
  }
}
/*******************************************/
/* customUp animation */
/*******************************************/
.vegas-animation-customUp {
  animation: customUp ease-out;
}
@keyframes customUp {
  0% {
    transform: scale(1.3) translate(0, 5%);
  }
  100% {
    transform: scale(1) translate(0, 0);
  }
}/*# sourceMappingURL=style.css.map */