@charset "UTF-8";
/* Scss Document */
/*=============================================================
 共通
=============================================================*/
.reset ul,
.reset ol,
.reset li,
.reset dl,
.reset dt,
.reset dd,
.reset figure,
.reset figcaption,
.reset table,
.reset address {
  list-style: none;
}
.reset table {
  border-collapse: collapse;
  border-spacing: 0;
}
.reset img {
  width: 100%;
  height: auto;
  border: none;
  margin: 0px;
  padding: 0px;
  vertical-align: bottom;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

@media screen and (max-width: 768.9px) {
  .anchor {
    margin-top: -70px;
    padding-top: 70px;
  }
}
@media screen and (min-width: 768.9px) {
  .anchor {
    margin-top: -90px;
    padding-top: 90px;
  }
}

.com-youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.com-youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.ggmap {
  line-height: 1;
}
@media screen and (max-width: 768.9px) {
  .ggmap {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
  }
}
.ggmap iframe {
  width: 100%;
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
}
@media screen and (max-width: 768.9px) {
  .ggmap iframe,
  .ggmap object,
  .ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}

.js-toggle-tit {
  cursor: pointer;
}

.js-toggle-content {
  display: none;
}

/*=============================================================
 共通【ボタン】
=============================================================*/
.com-btn a {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  line-height: 1;
  box-sizing: border-box;
}
.com-btn a:after {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  opacity: 1;
}
.com-btn a:hover {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  opacity: 1;
}
.com-btn a:hover:after {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  opacity: 1;
}
.com-btn.btn01 a {
  display: inline-block;
  border: 1px solid #DD5B38;
  background-color: #DD5B38;
  border-radius: 90px;
  box-sizing: border-box;
  color: #FFF !important;
  position: relative;
  min-width: 200px;
  letter-spacing: 0.1em;
  line-height: 48px;
}
@media screen and (min-width: 768.9px) {
  .com-btn.btn01 a:hover {
    background-color: #fff;
    color: #DD5B38 !important;
  }
  .com-btn.btn01 a:hover span {
    border-color: transparent #FFF #FFF transparent;
  }
}
.com-btn.pdf a {
  display: flex;
  align-items: center;
  border: 1px solid #000;
  background-color: #000;
  border-radius: 90px;
  color: #fff;
  position: relative;
  box-sizing: border-box;
  font-weight: 400;
  line-height: 48px;
}
.com-btn.pdf a:after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background: url("../image/ico_pdf.svg") no-repeat center center;
  background-size: auto 100%;
  margin-left: 1em;
  margin-bottom: -3px;
}
.com-btn.pdf a:hover {
  opacity: 0.5;
}
/*=============================================================
 共通【お問い合わせ】
=============================================================*/
.com-contact {
  position: relative;
  z-index: 100;
  color: #fff;
  padding: 82px 0;
}
@media screen and (max-width: 768.9px) {
  .com-contact {
    background: url("../image/common/bg_contact_sp.png") no-repeat center center;
    background-size: cover;
  }
}
@media screen and (min-width: 768.9px) {
  .com-contact {
    background: url("../image/common/bg_contact.png") no-repeat center center;
    background-size: cover;
    background-color: #F7F5F2;
    padding: 164px 0;
  }
}
.com-contact .com-sec-tit .en {
  color: #fff !important;
  letter-spacing: 0.1em;
}
.com-contact .lead {
  font-size: clamp(15px, 3vw, 18px);
  margin: 52px 0;
  font-weight: 300;
  line-height: 1.8;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
@media screen and (max-width: 768.9px) {
  .com-contact .lead {
    text-align: left;
    margin: 36px 0;
  }
}
@media screen and (max-width: 768.9px) {
  .com-contact .lead br {
    display: none;
  }
}
.com-contact .col2 {
  border: 1px solid #fff;
  width: 1000px;
  max-width: 100%;
  box-sizing: border-box;
  margin: 0 auto 0 auto;
  position: relative;
  padding: 8px;
}
@media screen and (min-width: 768.9px) {
  .com-contact .col2 {
    display: grid;
    gap: 0 124px;
    grid-template-columns: repeat(2, 1fr);
    padding: 52px 64px;
  }
}
.com-contact .col2:before, .com-contact .col2:after {
  content: "";
  position: absolute;
  border-style: solid;
  border-width: 8px 8px 0 0;
  border-color: #FFF transparent transparent #FFF;
  display: block;
  width: 0;
}
.com-contact .col2:before {
  top: 0;
  left: 0;
}
.com-contact .col2:after {
  top: 0;
  right: 0;
  transform: rotate(90deg);
}
.com-contact .col2 .tit {
  font-size: clamp(18px, 5vw, 21px);
  margin-bottom: 28px;
}
@media screen and (max-width: 768.9px) {
  .com-contact .col2-left {
    border-bottom: 1px solid #fff;
    padding: 25px;
  }
}
.com-contact .col2-left:before, .com-contact .col2-left:after {
  content: "";
  position: absolute;
  border-style: solid;
  border-width: 0 8px 8px 0;
  border-color: transparent transparent #FFF #FFF;
  display: block;
  width: 0;
}
.com-contact .col2-left:before {
  bottom: 0;
  left: 0;
}
.com-contact .col2-left:after {
  bottom: 0;
  right: 0;
  transform: rotate(-90deg);
}
.com-contact .col2-left .tit {
  margin-bottom: 20px;
}
.com-contact .col2-left .tel {
  line-height: 1;
  font-size: clamp(22px, 12vw, 50px);
  margin-bottom: 8px;
}
.com-contact .col2-left .tel a {
  color: #fff;
}
.com-contact .col2-left .open {
  font-family: "Zen Kaku Gothic New", sans-serif;
}
@media screen and (max-width: 768.9px) {
  .com-contact .col2-right {
    padding: 25px;
  }
}
.com-contact .col2-right .com-btn.btn02 {
  display: block;
}
.com-contact .col2-right .com-btn.btn02 a {
  box-sizing: border-box;
  justify-content: center;
  border-radius: 5px;
  height: 68px;
}
/*=============================================================
 共通【ページタイトル】
=============================================================*/
#com-page-tit {
  position: relative;
  overflow: hidden;
}
#com-page-tit:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.2) 0%, rgba(0, 0, 0, 0.4) 100%);
  z-index: 2;
}
#com-page-tit .pic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: none;
  margin: 0px;
  padding: 0px;
  vertical-align: bottom;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
#com-page-tit .inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  color: #fff;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}
#com-page-tit .inner .ja {
  font-size: clamp(23px, 3vw, 36px);
  font-weight: 100;
  letter-spacing: 0.3em;
  line-height: 2;
}
@media screen and (min-width: 768.9px) {
  #com-page-tit .inner .ja {
    margin-top: 40px;
  }
}
#com-page-tit .inner .en {
  font-size: clamp(14px, 3vw, 22px);
  letter-spacing: 0.2em;
  font-weight: 200;
}

.com-sec-tit {
  line-height: 1;
}
.com-sec-tit .jp {
  font-size: clamp(18px, 7vw, 32px);
  margin-bottom: 14px;
  font-weight: 400;
}
@media screen and (min-width: 768.9px) {
  .com-sec-tit .jp {
    margin-bottom: 28px;
  }
}
@media screen and (max-width: 768.9px) {
  .com-sec-tit .jp.vertical {
    writing-mode: horizontal-tb;
  }
}
.com-sec-tit .en {
  font-size: clamp(13px, 3vw, 20px);
  color: #DD5B38;
}
.com-sec-tit .en span {
  writing-mode: vertical-rl;
  text-orientation: mixed;
}
@media screen and (max-width: 768.9px) {
  .com-sec-tit .en span {
    writing-mode: horizontal-tb;
  }
}

.com-sec-tit2 {
  line-height: 1;
  text-align: left;
  border-left: 1px solid #333333;
  padding-left: 22px;
}
@media screen and (min-width: 768.9px) {
  .com-sec-tit2 {
    padding-left: 44px;
  }
}
.com-sec-tit2 .ja {
  font-size: clamp(18px, 6vw, 40px);
  font-weight: 400;
  letter-spacing: 0.1em;
}
.com-sec-tit2 .ja small {
  color: #DD5B38;
  font-size: clamp(14px, 3vw, 20px);
  letter-spacing: 0em;
}
@media screen and (max-width: 768.9px) {
  .com-sec-tit2 .ja small {
    display: block;
    margin-top: 8px;
  }
}
@media screen and (min-width: 768.9px) {
  .com-sec-tit2 .ja small {
    margin-left: 20px;
  }
}
.com-sec-tit2 .lead {
  font-family: "Zen Kaku Gothic New", sans-serif;
  margin-top: 16px;
  font-size: clamp(16px, 3vw, 18px);
  line-height: 2;
}
@media screen and (min-width: 768.9px) {
  .com-sec-tit2 .lead {
    margin-top: 32px;
  }
}

.com-sec-tit3 {
  line-height: 1;
  display: flex;
  align-items: center;
  font-weight: 400;
}
.com-sec-tit3:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  border-top: 1px solid #CECCC2;
}
.com-sec-tit3 span {
  margin-right: 20px;
  white-space: nowrap;
}
@media screen and (min-width: 768.9px) {
  .com-sec-tit3 span {
    margin-right: 40px;
  }
}
.com-sec-tit3.en {
  font-size: clamp(16px, 4vw, 24px);
}

/*=============================================================
 共通【セクション】
=============================================================*/
#com-page-intro {
  font-size: clamp(14px, 3vw, 18px);
  line-height: 2.6;
  padding: 60px 20px;
  text-align: left;
}
@media screen and (min-width: 768.9px) {
  #com-page-intro {
    padding: 120px 0;
    text-align: center;
    line-height: 2.8;
  }
}

/*=============================================================
 共通【下層ページパンくず】
=============================================================*/
.com-pankz {
  display: flex;
  flex-flow: wrap row;
  margin-top: 20px;
}
@media screen and (max-width: 768.9px) {
  .com-pankz {
    margin: 10px 0 0 10px;
  }
}
.com-pankz li a {
  color: #727171;
}
.com-pankz li a:hover {
  color: #DD5B38;
}
.com-pankz li:after {
  content: ">";
  margin: 0 1em;
}
.com-pankz li:last-child:after {
  display: none;
}

/*=============================================================
 共通【投稿一覧記事カセット
=============================================================*/
.com-post-archive .item {
  position: relative;
}
.com-post-archive .item .data {
  margin: 16px 0 12px 0;
}
@media screen and (min-width: 768.9px) {
  .com-post-archive .item .data {
    margin: 32px 0 24px 0;
  }
}
.com-post-archive .item .data .time {
  color: #DD5B38;
  font-size: clamp(14px, 3vw, 18px);
  margin-right: 12px;
}
@media screen and (min-width: 768.9px) {
  .com-post-archive .item .data .time {
    margin-right: 24px;
  }
}
.com-post-archive .item .data .cate {
  display: inline-block;
  border: 1px solid #DD5B38;
  color: #DD5B38;
  border-radius: 50px;
  font-size: clamp(14px, 3vw, 14px);
  line-height: 18px;
  padding: 0 1em;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.com-post-archive .item .tit {
  font-size: clamp(17px, 4vw, 21px);
  font-weight: 400;
}
.com-post-archive .item .txt,
.com-post-archive .item .date {
  margin-top: 28px;
  font-size: clamp(14px, 3vw, 15px);
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.com-post-archive .item .more a {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.com-post-archive .item .more a span {
  display: none;
}/*# sourceMappingURL=common.css.map */