@charset "UTF-8";
@import url('https://fonts.googleapis.com/css?family=Cormorant+Garamond');
@import url('https://fonts.googleapis.com/css?family=Noto+Serif+JP:500,600&subset=japanese');

/*使用カラー
color01:#94af43;
color02:#52671b;
color03:#af7143;
*/

/*common*/

* {
  box-sizing: border-box;
}
.preload * {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -ms-transition: none !important;
  -o-transition: none !important;
  transition: none !important;
}
body {
  font-family: '游ゴシック体', 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro',
    'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, Osaka, 'ＭＳ Ｐゴシック',
    'MS PGothic', sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 1.6rem;
  line-break: normal;
  line-height: 1.7;
  color: #333;
  background: #fff;
  width: 100%;
  overflow-x: hidden;
  min-width: 1000px;
}
input::-webkit-input-placeholder,
input::-moz-placeholder,
input::-ms-input-placeholder {
  color: #aaa;
}
input:-ms-input-placeholder {
  color: #aaa;
}
.en {
  font-family: 'Cormorant Garamond', 'Noto Serif JP', '游明朝体', 'YuMincho',
    '游明朝', 'Yu Mincho', 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN W3',
    HiraMinProN-W3, 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN',
    'ヒラギノ明朝 Pro', 'Hiragino Mincho Pro', 'HGS明朝E', 'ＭＳ Ｐ明朝',
    'MS PMincho', serif;
}
.jpSerifM {
  font-family: 'Noto Serif JP', '游明朝体', 'YuMincho', '游明朝', 'Yu Mincho',
    'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN W3', HiraMinProN-W3,
    'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'ヒラギノ明朝 Pro',
    'Hiragino Mincho Pro', 'HGS明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
  font-weight: 500;
}
.jpSerifB {
  font-family: 'Noto Serif JP', '游明朝体', 'YuMincho', '游明朝', 'Yu Mincho',
    'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN W3', HiraMinProN-W3,
    'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'ヒラギノ明朝 Pro',
    'Hiragino Mincho Pro', 'HGS明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
  font-weight: 600;
}
a {
  text-decoration: none;
  color: #515151;
}
a.links {
  text-decoration: underline;
}

.single strong {
  font-weight: bold;
  background: -moz-linear-gradient(transparent 50%, #ffcd59 50%);
  background: -webkit-linear-gradient(transparent 50%, #ffcd59 50%);
  background: -webkit-gradient(
    linear,
    0 0,
    0 100%,
    color-stop(0.5, transparent),
    color-stop(0.5, #ffcd59)
  );
  background: -o-linear-gradient(transparent 50%, #ffcd59 50%);
  background: linear-gradient(transparent 50%, #ffcd59 50%);
}

@media screen and (min-width: 768px) {
  a.links:hover {
    text-decoration: none;
    color: var(--color02);
  }
}
img {
  vertical-align: top;
}
.bold {
  font-weight: bold;
}
.reImg {
  width: 100%;
  height: auto;
}

/*header*/

.home .siteHeader {
  position: absolute;
  bottom: 0;
  left: 0;
}
.siteHeader {
  width: 100%;
}
.siteHeaderInner {
  width: 100%;
  height: 100px;
  background: rgba(255, 255, 255, 0.8);
  z-index: 3;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  padding-left: 50px;
}
#pageMain {
  position: relative;
}
.leadBox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 2;
  position: absolute;
  width: 100%;
  height: calc(100% - 100px);
}
.leadBox .en {
  display: block;
  font-size: 1.8rem;
}
.leadBox .lead {
  font-size: 4rem;
  text-align: center;
  letter-spacing: 0.1em;
}
.mainNav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}
.mainNav li {
  height: 100px;
  padding-right: 20px;
  position: relative;
}
.mainNav li.current:after {
  content: '';
  display: block;
  background: transparent;
  height: 3px;
  width: calc(100% - 20px);
  position: absolute;
  bottom: 25px;
  left: 0;
}
.mainNav li.current:after {
  background: var(--color01);
}
.mainNav li:last-child {
  padding-right: 0;
}
.mainNav li.navContactBtn {
  padding-left: 20px;
}
.mainNav li:last-child a {
  background: var(--color01);
  padding: 0 20px;
  color: #fff;
}
.mainNav li:last-child a i {
  margin-right: 5px;
}
.mainNav li a {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
  font-size: 1.5rem;
  line-height: 1.3;
  text-align: center;
}

@media screen and (max-width: 1285px) {
  .mainNav li {
    padding-right: 10px;
  }
  .mainNav li a {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 1150px) {
  .mainNav li {
    padding-right: 5px;
  }
  .mainNav li a {
    font-size: 1.3rem;
  }
  .mainNav li.navContactBtn {
    padding-left: 5px;
  }
  .mainNav li:last-child a {
    padding: 0 5px;
  }
}
.mainNav li.navHome,
.mainNav li.navContact,
.mainNav li.navPrivacy {
  display: none;
}
@media screen and (min-width: 768px) {
  .mainNav li a:hover {
    opacity: 0.7;
  }
  .mainNav li:last-child a:hover {
    background: var(--color02);
    opacity: 1;
  }
  .logo a:hover img {
    opacity: 0.7;
  }
}
.headInfo {
  background: #fff;
  width: 310px;
  position: absolute;
  right: 30px;
  top: 30px;
  z-index: 3;
  padding: 30px 30px 20px 30px;
}
.headInfo a {
  display: inline-block;
  vertical-align: top;
  font-size: 2.4rem;
  line-height: 40px;
  padding-left: 10px;
  letter-spacing: 0.1em;
}
.headInfo dt {
  background: var(--color01);
  text-align: center;
  font-size: 1.4rem;
  color: #fff;
  margin: 10px 0;
}
.headInfo dd {
  text-align: center;
  font-size: 1.4rem;
}
.headInfo .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}
.circleBg {
  border-radius: 50%;
  background: var(--color01);
  color: #fff;
  width: 40px;
  height: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
}
.headInfo .tel .telNum {
  flex: 1;
}

/*twoRow*/

.twoRow {
  padding-right: 5%;
}
.twoRow + .twoRow {
  margin-top: 100px;
}
.twoRowInner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.ttlWrap .ttlA {
  font-size: 3rem;
  line-height: 1.5;
  letter-spacing: 0.1em;
  z-index: 2;
  position: relative;
}
.ttlWrap .ttlA .en {
  font-size: 1.8rem;
  display: block;
}
.ttlWrap .decoration {
  color: #f2f2f2;
  font-size: 20rem;
  position: absolute;
  bottom: -0.3em;
  line-height: 1;
  left: 0;
}
.ttlWrap {
  width: 40%;
  border-top: 2px solid #333;
  padding-left: calc(5% + 30px);
  padding-top: 20px;
  position: relative;
}
.twoRow .imgBox {
  width: 55%;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.twoRow .imgBox .line {
  width: 1px;
  height: 130%;
  background: #333;
  display: block;
  position: absolute;
  left: 10%;
  top: -25%;
}
.twoRow .txtBox {
  font-size: 1.5rem;
  width: 45%;
  background: #f2f2f2;
}
.twoRow .txtOuter {
  padding: 20px;
  width: 100%;
  height: 100%;
}
.twoRow .txtInner {
  border: 1px solid #333;
  padding: 20px;
  width: 100%;
  height: calc(100% + 80px);
  margin-top: -40px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
}
.twoRow .txtInnerIn {
  width: 100%;
  padding: 30px;
  position: relative;
}
.twoRow .txtInnerIn .line {
  width: 80px;
  height: 1px;
  position: absolute;
  top: 50%;
  left: -65px;
  display: block;
  background: #333;
}

/*threeCnt*/

.threeCnt {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
  padding: 0 5% 60px 5%;
  background: #ebebeb;
}
.threeCnt li {
  width: 32%;
  background: #fff;
  border: 1px solid #333;
  margin-top: -60px;
  padding: 30px 0;
}
.threeCnt li:first-child {
	margin-right: 60px;
}
/*top blog*/

.blogList {
  padding: 0 5%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-evenly;
  justify-content: space-evenly;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.blogList::before {
  content: '';
  display: none;
  width: 24%;
  order: 1;
}
.blogList::after {
  content: '';
  display: none;
  width: 24%;
}
.blogList li {
  width: 24%;
  font-size: 1.4rem;
}
.blogList li a {
  display: block;
}
@media screen and (min-width: 768px) {
  .blogList a:hover img {
    opacity: 0.7;
  }
}
.blogList .imgWrap {
  width: 100%;
  padding-top: 66%;
  position: relative;
  display: block;
  margin-bottom: 10px;
}
.blogList .imgWrap img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}
.blogList figcaption .category {
  background: var(--color01);
  font-style: normal;
  color: #fff;
  padding: 5px;
  display: inline-block;
  font-size: 1.2rem;
}
.blogList figcaption .date {
  display: inline-block;
  padding-left: 5px;
}
.blogList figcaption .ttl {
  margin-top: 10px;
  font-size: 1.8rem;
}

/*footer*/

.siteFooter {
  background: #ebebeb;
}
.footLogo {
  text-align: center;
  border-bottom: 1px solid #bbb;
  padding: 30px 0;
}
.footLogo a {
  display: block;
}
@media screen and (min-width: 768px) {
  .footLogo a:hover img {
    opacity: 0.7;
  }
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
.tblA {
  width: 490px;
  font-size: 1.4rem;
  margin-bottom: 10px;
}
.tblA tr {
  border-left: 1px solid var(--color01);
  border-bottom: 1px solid var(--color01);
}
.tblA th,
.tblA td {
  border-right: 1px solid var(--color01);
  text-align: center;
}
.footBottomWrap {
  display: -webkit-flex;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 900px;
  margin: 40px auto;
}
.footBottomWrap .footLeft {
  -webkit-flex: 1;
  flex: 1;
  text-align: center;
  padding-right: 10px;
}
.footBottomWrap .footLeft address {
  font-size: 1.5rem;
  margin-bottom: 10px;
}
.footBottomWrap .footRight {
  -webkit-flex: 1;
  flex: 1;
}
.footBottomWrap .footRight .memo {
  font-size: 1.2rem;
  text-align: right;
}
.tblA .head {
  background: var(--color01);
  color: #fff;
}
.footContactWrap {
  border-top: 1px solid #bbb;
}
.contactWrap {
  width: 1000px;
  display: table;
  background: #fff;
  margin: 30px auto;
  padding: 10px;
}
.contactWrap li {
  display: table-cell;
  text-align: center;
  width: 50%;
  padding: 10px;
}
.contactWrap li dt {
  background: var(--color01);
  color: #fff;
  text-align: center;
  margin-bottom: 20px;
}
.contactWrap dd .ib {
  display: inline-block;
}
.contactWrap dd .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
}
.contactWrap dd .tel .jpSerifM {
  font-size: 2.6rem;
  padding-left: 10px;
  line-height: 40px;
}
.contactWrap dd small {
  display: block;
}
.footNav li {
  display: table-cell;
  padding-right: 20px;
}
.footNav {
  display: table;
  margin: 0 auto;
  padding-bottom: 30px;
}
.footNav li a {
  font-size: 1.4rem;
}
.social {
  margin: 0 0 30px;
}
.social .bgCircle {
  display: block;
  background: #454545;
  border-radius: 50%;
  height: 50px;
  width: 50px;
  text-align: center;
  line-height: 50px;
  color: #fff;
  font-size: 1.6rem;
}
.social .bgCircle:first-child {
  margin-right: 20px;
}
.social .bgCircle a {
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  width: 50px;
  height: 50px;
  font-size: 18px;
}
.banner {
  margin-bottom: 30px;
}
.banner li{
  margin:0 15px;
}
@media screen and (min-width: 768px) {
  .footNav li a:hover {
    text-decoration: underline;
  }
}
.footNav li.navAccess,
.footNav li.navContact,
.footNav li.navContactBtn {
  display: none;
}
footer .copy {
  background: #fff;
  text-align: center;
  padding: 10px 0;
  display: block;
}
@media screen and (max-width: 770px) {
  .banner {
    flex-wrap: wrap;
    text-align: center;
    margin-bottom: 0;
  }
  .banner li{
  margin:0 0 30px;
  width: 100%;
  }
}
/*pgTop*/

.pageTop {
  display: none;
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 7;
}
.pageTop a {
  background: var(--color01);
  width: 40px;
  height: 40px;
  display: block;
  text-align: center;
  line-height: 40px;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .pageTop a:hover {
    background: var(--color02);
  }
}

/*ttl*/

.ttlB {
  color: var(--color01);
  font-size: 2.5rem;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 1200px) {
  .twoRow .ttlB {
    font-size: 2.2rem;
  }
}

.ttlC {
  font-size: 2.5rem;
  color: #333;
  letter-spacing: 0.1em;
}
.ttlC .en {
  font-size: 1.8rem;
  display: block;
}
.ttlD {
  font-size: 2rem;
  padding: 0 20px;
  letter-spacing: 0.1em;
}
.ttlE {
  font-size: 3rem;
  letter-spacing: 0.1em;
  line-height: 1.5;
}
.ttlE .en {
  font-size: 1.8rem;
  display: block;
}
.ttlF {
  color: var(--color01);
  font-size: 2.5rem;
  letter-spacing: 0.1em;
}

/*btn*/

.btnA a {
  border: 1px solid var(--color01);
  color: var(--color01);
  display: block;
  text-align: center;
  width: 250px;
  height: 60px;
  line-height: 60px;
  margin: 0 auto;
  position: relative;
}
@media screen and (min-width: 768px) {
  .btnA a:hover {
    background: var(--color01);
    color: #fff;
  }
}
.arrowWrap {
  position: absolute;
  right: 40px;
  top: 30px;
}
.arrow {
  position: relative;
  display: inline-block;
  vertical-align: top;
}
.arrow::before,
.arrow::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: '';
  vertical-align: middle;
}
.arrow::before {
  left: 4px;
  width: 70px;
  height: 1px;
  background: var(--color01);
}
.arrow::after {
  left: 55px;
  width: 16px;
  height: 16px;
  border-top: 1px solid var(--color01);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

/*****form*******/

.formWrapOuter .ttlC {
  text-align: center;
}
.modPCenter {
  text-align: center;
}
.formWrap {
  background: #f5f5f5;
  width: 800px;
  margin: 50px auto 100px;
  padding: 50px 0;
}
.formWrap dl {
  width: 600px;
  margin: 0 auto;
}
.formWrap dt {
  font-weight: bold;
}
.formWrap dd {
  margin: 15px 0 30px 0;
  word-break: break-all;
}
.formWrap .required {
  background: var(--color01);
  font-size: 1.2rem;
  color: #fff;
  font-weight: normal;
  height: 25px;
  line-height: 25px;
  display: inline-block;
  padding: 0 15px;
  margin-right: 10px;
  position: relative;
  top: -2px;
}
.formWrap .any {
  background: #999;
  font-size: 1.2rem;
  color: #fff;
  font-weight: normal;
  height: 25px;
  line-height: 25px;
  display: inline-block;
  padding: 0 15px;
  margin-right: 10px;
  position: relative;
  top: -2px;
}
.formWrap textarea,
.formWrap input {
  border-radius: 0;
  box-shadow: none;
  -webkit-appearance: none;
}
.formWrap textarea,
.formWrap input[type='email'],
.formWrap input[type='text'] {
  border: 1px solid #ddd;
  background: #fff;
  height: 40px;
  padding-left: 15px;
  width: 100%;
}
.formWrap textarea {
  height: 15em;
  padding-top: 15px;
}
.formWrap .formBtn {
  position: relative;
  display: block;
  color: var(--color01);
  text-align: center;
  border: 1px solid var(--color01);
  width: 300px;
  height: 60px;
  line-height: 60px;
  cursor: pointer;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .formWrap .formBtn:hover {
    background: var(--color01);
    color: #fff;
  }
}
.mwform-checkbox-field label,
.mwform-radio-field label {
  white-space: nowrap;
}
.mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: auto !important;
  margin-right: 10px !important;
}
dl.formWrapDl select.date,
.formWrap input[type='text'].hasDatepicker {
  width: auto;
}
input[type='radio'] {
  position: relative;
  -webkit-appearance: button;
  appearance: button;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 24px;
  height: 24px;
  content: '';
  background-color: #ffffff;
  border: 1px solid #999999;
  -webkit-border-radius: 24px;
  border-radius: 24px;
  vertical-align: middle;
  cursor: pointer;
}
input[type='radio']:checked:after {
  display: block;
  position: absolute;
  top: 5px;
  left: 5px;
  content: '';
  width: 12px;
  height: 12px;
  background: #de0029;
  -webkit-border-radius: 12px;
  border-radius: 12px;
}
input[type='checkbox'] {
  display: none;
}
.mwform-checkbox-field-text {
  box-sizing: border-box;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  cursor: pointer;
  padding: 0 0 0 24px;
}
.mwform-checkbox-field-text:after {
  position: absolute;
  top: 50%;
  left: 6px;
  display: block;
  margin-top: -7px;
  width: 5px;
  height: 9px;
  border-right: 3px solid #de0029;
  border-bottom: 3px solid #de0029;
  content: '';
  opacity: 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.mwform-checkbox-field-text:before {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  margin-top: -9px;
  width: 18px;
  height: 18px;
  border: 1px solid #999999;
  background-color: #fff;
  content: '';
}
input[type='checkbox']:checked + .mwform-checkbox-field-text:after {
  opacity: 1;
}
.mw_wp_form .formWrap .horizontal-item {
  margin-left: 0;
  margin-right: 10px;
}
.mw_wp_form .formWrap .horizontal-item + .horizontal-item {
  margin-left: 0;
}
.formWrap .backBtn {
  margin-top: 30px;
}
.mw_wp_form_input .formMessage01,
.mw_wp_form_confirm .formMessage02 {
  display: block;
}
.mw_wp_form_confirm .formMessage01,
.mw_wp_form_input .formMessage02 {
  display: none;
}

/*blog*/

.tableContents {
  background: #fff !important;
  border: 1px solid #e3e3e3 !important;
}
.singleContent {
  width: 100%;
}
.blogSingle .image img,
.singleContent img {
  max-width: 100%;
  height: auto;
  margin-bottom: 1em;
}
.blogCnt .cntW1000 {
  width: 1000px;
}

/*map*/
.access .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
}
.ggmapSize {
  width: 100%;
  margin: 0 auto 20px auto;
}
.ggmap {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}
.ggmap iframe,
.ggmap object,
.ggmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*page*/

.pageMv {
  position: relative;
}
.leadPageBox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 2;
  position: absolute;
  width: 100%;
  height: 100%;
  text-align: center;
}
.pageTtl {
  position: relative;
  z-index: 3;
  line-height: 1.4;
}
.pageTtl .jpSerifB {
  font-size: 3rem;
  letter-spacing: 0.1em;
}
.pageTtl .en {
  display: block;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
}
.leadPageBox .decoration {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 100%;
  color: #fff;
  opacity: 0.6;
  font-size: 20rem;
  position: absolute;
  top: 0;
  left: 0;
  line-height: 1;
  z-index: 2;
}

@media screen and (max-width: 1200px) {
  .leadPageBox .decoration.privacyEn {
    font-size: 15rem;
  }
}

.bread {
  padding: 10px 5%;
  font-size: 1.5rem;
  border-bottom: 1px solid #ddd;
  border-top: 1px solid #ddd;
}
@media screen and (min-width: 768px) {
  .bread a:hover {
    text-decoration: underline;
  }
}
.cntWraper .twoRow {
  padding-left: 5%;
}
.centerText {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.smallTxtBox {
  font-size: 1.3rem;
  border: 1px solid var(--color01);
  padding: 10px;
}
.freeText,
.smallTxtBox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  margin-bottom: 20px;
}
.freeText:last-child,
.smallTxtBox:last-child {
  margin-bottom: 0;
}
.freeText p,
.smallTxtBox p {
  margin-bottom: 20px;
}
.freeText p:last-child,
.smallTxtBox p:last-child {
  margin-bottom: 0;
}
.cntW1000 {
  width: 1000px;
  margin: 0 auto;
}
.cntW1000 .jpSerifM {
  font-size: 2.7rem;
  padding-left: 10px;
  line-height: 1.5;
}
.cntW1000 .tblA {
  margin-left: auto;
  margin-right: auto;
}
.cntW800 {
  width: 800px;
  margin: 0 auto;
}
.oneRowTxt .imgBox .line {
  width: 1px;
  height: 130%;
  background: #333;
  display: block;
  position: absolute;
  left: 10%;
  top: -25%;
}
.oneRowTxt .txtBox {
  display: block;
  font-size: 1.5rem;
  margin: -60px auto 0 auto;
  width: 800px;
  background: #f2f2f2;
  position: relative;
  z-index: 2;
}
.oneRowTxt .txtOuter {
  padding: 20px;
  width: 100%;
  height: 100%;
}
.oneRowTxt .txtInner {
  border: 1px solid #333;
  padding: 20px;
  width: 100%;
  height: calc(100% + 160px);
  margin-top: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: center;
  justify-content: center;
}
.oneRowTxt .txtInnerIn {
  width: 100%;
  padding: 30px;
  position: relative;
}
.oneRowTxt .txtInnerIn .line {
  width: 1px;
  height: 80px;
  position: absolute;
  left: 50%;
  top: -65px;
  display: block;
  background: #333;
}

/*アコーディオン*/

.accWrap > li {
  margin-bottom: 20px;
}
.accWrap .inner {
  display: none;
  background: #f2f2f2;
  padding: 30px 30px 10px 30px;
}
.accWrap .inner.open {
  display: block;
}
.accWrap .accDt {
  background: var(--color01);
  cursor: pointer;
  position: relative;
  color: #fff;
  padding: 20px 80px 20px 20px;
}
@media screen and (min-width: 768px) {
  .accWrap .accDt:hover {
    background: var(--color02);
  }
}
.accWrap .accDt:after {
  content: '';
  display: block;
  background: url(../img/ico_down_01.png);
  background-size: cover;
  width: 43px;
  height: 23px;
  position: absolute;
  top: 30px;
  right: 30px;
}
.accWrap .accDt.isActive:after {
  background: url(../img/ico_up_01.png);
  background-size: cover;
}
.innTtl {
  font-weight: bold;
  border-bottom: 1px solid #333;
  padding-bottom: 5px;
  margin-bottom: 20px;
  font-size: 1.8rem;
}
.special .innDl + .innTtl {
  margin-top: 40px;
}
.innDl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.innDl dt {
  background: var(--color01);
  font-weight: bold;
  padding: 8px 5px 7px 5px;
  display: inline-block;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 20px;
}
.innDl dd {
  display: inline-block;
  margin-left: 10px;
  margin-right: 15px;
  margin-bottom: 20px;
}
.innDl dd:last-child {
  margin-right: 0;
}
.badge {
  border: 1px solid #fff;
  padding: 5px;
  color: #fff;
  display: inline-block;
  font-size: 1.4rem;
  line-height: 1;
  position: relative;
  margin-right: 10px;
  margin-top: 5px;
  margin-bottom: 5px;
  top: -3px;
}
/* menu */
.menu .inner .catch,
.menu .inner p {
  margin-bottom: 20px;
}
/* flow */
.flow .cntWraper .twoRow .txtOuter:after {
  content: '';
  display: inline-block;
  background: url(../img/arrow_down_01.png);
  background-size: cover;
  width: 43px;
  height: 91px;
  position: relative;
  top: -50px;
}
.flow .cntWraper .twoRow:last-child .txtOuter:after {
  display: none;
}
/* special */
.special .cntW800 p {
  margin-bottom: 20px;
}
/*blog*/

.blogInner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
.blogInner .blogListWrap {
  width: calc(70% - 20px);
}
.blogInner .blogListWrap .blogArticleList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.blogInner .blogListWrap .blogArticleList li {
  width: calc(50% - 10px);
  margin-bottom: 30px;
}
.blogArticleList .imgWrap {
  width: 100%;
  padding-top: 66%;
  position: relative;
  display: block;
  margin-bottom: 10px;
}
.blogArticleList .imgWrap img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}
@media screen and (min-width: 768px) {
  .blogArticleList li a:hover {
    opacity: 0.7;
  }
}
.blogArticleList .meta {
  margin-bottom: 5px;
}
.blogArticleList .category a {
  background: var(--color01);
  font-style: normal;
  color: #fff;
  padding: 5px;
  display: inline-block;
  font-size: 1.2rem;
}
@media screen and (min-width: 768px) {
  .blogArticleList .category a:hover {
    background: var(--color02);
    opacity: 1;
  }
}
.blogArticleList .category a {
  color: #fff;
}
.blogArticleList time {
  margin-left: 10px;
  font-size: 1.4rem;
}
.blogInner .subWrap {
  width: calc(30% - 20px);
}
.blogArticleList .blogTtl {
  font-size: 1.8rem;
}
.latest time {
  display: block;
  font-size: 1.3rem;
  color: var(--color01);
}
.latest li a {
  display: block;
  border-bottom: 1px solid #ddd;
  padding-bottom: 10px;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) {
  .latest li a:hover .jpSerifB {
    text-decoration: underline;
  }
}
.seoTtl02 {
  font-size: 1.8rem;
}
.blogSingle .subWrap {
  margin: 80px 0 100px 0;
}
.blogSingle .subWrap .subTtls {
  font-size: 2rem;
  letter-spacing: 0.1em;
}
.blogSingle .category a {
  background: var(--color01);
  font-style: normal;
  color: #fff;
  padding: 5px;
  display: inline-block;
  font-size: 1.2rem;
  margin-right: 10px;
}
@media screen and (min-width: 768px) {
  .blogSingle .category a:hover {
    background: var(--color02);
  }
}
.blogSingle .singleTtl {
  font-size: 2.6rem;
  letter-spacing: 0.1em;
}
.snsWrap {
  background: #f2f2f2;
  padding: 20px;
  margin: 40px 0;
}
.addtoany_shortcode {
  text-align: center;
}

/*ページャー*/

.pagination .page-of {
  display: none;
}
.pagination-box {
  text-align: center;
  margin-bottom: 50px;
}
.pagination-box span {
  display: inline-block;
  width: 30px;
  height: 30px;
  line-height: 30px;
  margin-right: 10px;
  background: var(--color01);
  color: #fff;
  font-size: 1.4rem;
}
.pagination-box span:last-child {
  margin-right: 0;
}
.pagination-box span.link {
  background: none;
}
.pagination-box a {
  color: var(--color01);
  display: inline-block;
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-decoration: none;
}
@media screen and (min-width: 768px) {
  .pagination-box span.link:hover {
    background: var(--color01);
    color: #fff;
  }
  .pagination-box span.link:hover a {
    color: #fff;
  }
}

/*dl*/

.dlA dt i {
  font-style: normal;
  font-size: 3rem;
  background: var(--color01);
  color: #fff;
  /*display: inline-block;*/
  width: 50px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  display: none;
}
.dlA dt {
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: 1px solid #333;
  padding-bottom: 10px;
  margin-bottom: 20px;
}
.dlA dt span {
  flex: 1;
  padding-left: 15px;
}
.subWrap .subTtls {
  border-bottom: 1px solid #333;
  margin-bottom: 10px;
}
.subWrap .categoryDl {
  margin-bottom: 30px;
}
.subWrap .categoryDl a {
  background: var(--color01);
  font-style: normal;
  color: #fff;
  padding: 5px;
  display: inline-block;
  font-size: 1.2rem;
}
@media screen and (min-width: 768px) {
  .subWrap .categoryDl a:hover {
    background: var(--color02);
  }
}
.subWrap .categoryDl ul {
  margin-bottom: -10px;
}
.subWrap .categoryDl li {
  display: inline-block;
  margin-right: 10px;
  margin-bottom: 10px;
}
.dlB {
  margin-bottom: 40px;
}
.dlB dt {
  font-size: 1.8rem;
  font-weight: bold;
  border-bottom: 1px solid #e3e3e3;
  padding-bottom: 10px;
  margin-bottom: 15px;
}
.dlB li {
  margin-bottom: 15px;
  padding-left: 2em;
  text-indent: -2em;
}
.dlB li li {
  margin: 15px 0 15px 1.5em;
}
.dlB .number {
  font-style: normal;
  font-weight: bold;
  width: 2em;
  white-space: nowrap;
  display: inline-block;
  text-indent: 0;
  vertical-align: top;
}
.dlB .content {
  width: 100%;
  display: inline-block;
  text-indent: 0;
  vertical-align: top;
}
.dlB .one {
  margin-bottom: 15px;
  display: block;
}

/*汎用*/

.alignC {
  text-align: center;
}
.alignL {
  text-align: left;
}
.alignR {
  text-align: right;
}
.mt20 {
  margin-top: 20px;
}
.mb20 {
  margin-bottom: 20px;
}
.mb30 {
  margin-bottom: 30px;
}
.mb40 {
  margin-bottom: 40px;
}
.mb50 {
  margin-bottom: 50px;
}
.mb70 {
  margin-bottom: 70px;
}
.mb80 {
  margin-bottom: 80px;
}
.mb90 {
  margin-bottom: 90px;
}
.mb100 {
  margin-bottom: 100px;
}
.mb120 {
  margin-bottom: 120px;
}
.mb150 {
  margin-bottom: 150px;
}

/********横幅調整***************/

@media screen and (max-width: 1500px) {
  .headInfo {
    width: auto;
    right: 0;
    top: 0;
    display: flex;
    padding: 15px;
    background: #f5f5f5;
  }

  .headInfo dl {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .headInfo dt {
    margin: 0 10px;
    height: 100%;
    padding: 12px 10px;
  }
}
@media screen and (min-width: 768px) {
  /* for Tablet and PC */
  .f_res {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .w10 {
    width: 10%;
    min-width: 10%;
  }
  .w15 {
    width: 15%;
    min-width: 15%;
  }
  .w20 {
    width: 20%;
    min-width: 20%;
  }
  .w20s {
    width: calc(20% - 1em);
    min-width: calc(20% - 1em);
  }
  .w20l {
    width: calc(20% + 1em);
    min-width: calc(20% + 1em);
  }
  .w25 {
    width: 25%;
    min-width: 25%;
  }
  .w25s {
    width: calc(25% - 1em);
  }
  .w33 {
    width: calc(100% / 3);
  }
  .w33s {
    width: calc(100% / 3 - 0.5em);
  }
  .w30 {
    width: 30%;
    min-width: 30%;
  }
  .w30s {
    width: calc(30% - 1em);
    min-width: calc(30% - 1em);
  }
  .w30l {
    width: calc(30% + 1em);
  }
  .w35 {
    width: 35%;
    min-width: 35%;
  }
  .w35s {
    width: calc(35% - 1em);
    min-width: calc(35% - 1em);
  }
  .w40 {
    width: 40%;
    min-width: 40%;
  }
  .w40s {
    width: calc(40% - 1em);
    min-width: calc(40% - 1em);
  }
  .w45 {
    width: 45%;
  }
  .w45s {
    width: calc(45% - 1em);
    min-width: calc(45% - 1em);
  }
  .w45l {
    width: calc(45% + 1em);
    min-width: calc(45% + 1em);
  }
  .w60 {
    width: 60%;
    min-width: 60%;
  }
  .w60s {
    width: calc(60% - 1em);
  }
  .w60l {
    width: calc(60% + 1em);
  }
  .w66 {
    width: 66%;
  }
  .w50s {
    width: calc(50% - 1em);
  }
  .w50 {
    width: 50%;
    min-width: 50%;
  }
  .w50l {
    width: calc(50% + 1em);
  }
  .w55 {
    width: calc(55%);
    min-width: calc(55%);
  }
  .w55s {
    width: calc(55% - 1em);
    min-width: calc(55% - 1em);
  }
  .w65 {
    width: 65%;
    min-width: 65%;
  }
  .w65s {
    width: calc(65% - 1em);
    min-width: calc(65% - 1em);
  }
  .w75 {
    width: 75%;
  }
  .w75s {
    width: calc(75% - 1em);
  }
  .w70 {
    width: 70%;
  }
  .w70s {
    width: calc(70% - 1em);
  }
  .w70l {
    width: calc(70% + 1em);
  }
  .w80 {
    width: 80%;
  }
  .w80s {
    width: calc(80% - 1em);
  }
  .w80l {
    width: calc(80% + 1em);
  }
  .w85 {
    width: 85%;
  }
  .w90 {
    width: 90%;
  }
  .w95 {
    width: 95%;
  }
}
/********pc***************/
@media screen and (min-width: 771px) {
  .sp {
    display: none;
  }
}
/********sp***************/
@media screen and (max-width: 770px) {
  /*common*/
  body {
    font-size: 1.5rem;
    padding-top: 0px;
    min-width: 320px;
  }
  .pc {
    display: none;
  }
  .pattern:before {
    background-size: 3px auto;
  }
  .f_res {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  /*header*/
  .headInfo {
    display: none;
  }

  .spSiteHeader {
    width: 100%;
    height: 50px;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    background: rgba(255, 255, 255, 0.8);
  }
  .spSiteHeader .logo {
    position: absolute;
    left: 0;
    top: 0;
    line-height: 1;
  }
  .spSiteHeader .logo a {
    display: block;
    height: 50px;
    padding-left: 5%;
  }
  .spSiteHeader .logo a img {
    position: relative;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .spSiteHeader .hum {
    position: absolute;
    right: 0;
    top: 0;
  }
  .spSiteHeader .hum a {
    width: 50px;
    height: 50px;
    text-align: center;
    display: block;
  }
  .spSiteHeader .hum a img {
    position: relative;
    top: 50%;
    -webkit-transform: translateY(-50%);
    /* Safari用 */
    transform: translateY(-50%);
  }
  /*hamburger*/
  .closeBT {
    width: 50px;
    height: 50px;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 99;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
  }
  .humNavi {
    padding-top: 10%;
  }
  .humNavi .fas {
    margin-right: 5px;
  }
  .humNavi li a {
    display: block;
    padding: 10px 0;
    color: #333;
  }
  .humNavi li.navContactBtn {
    display: none;
  }
  #humTel,
  #hum {
    display: none;
  }
  .modaal-inline.modaal-fullscreen .modaal-container {
    background: rgba(255, 255, 255, 0.7);
    -webkit-overflow-scrolling: touch;
  }
  .telWrap {
    margin-top: 50px;
    text-align: center;
    border-top: 1px solid #b8b8b8;
    border-bottom: 1px solid #b8b8b8;
  }
  .telWrap .tel {
    padding: 10px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
  }
  .telWrap .telNum {
    font-size: 2rem;
    margin-left: 10px;
    line-height: 30px;
    display: inline-block;
    vertical-align: top;
  }
  .circleBg {
    width: 30px;
    height: 30px;
    line-height: 30px;
    vertical-align: top;
  }
  /*top*/
  .leadBox {
    height: 100%;
    width: 90%;
    left: 5%;
  }
  .leadBox .lead {
    font-size: 1.8rem;
  }
  .leadBox .en {
    font-size: 1.2rem;
  }
  .twoRow {
    padding-right: 0;
  }
  .ttlWrap {
    width: 100%;
    padding-left: 0%;
    padding-top: 15px;
    border-top: 1px solid #333;
  }
  .ttlWrap .ttlA {
    font-size: 2rem;
    text-align: center;
  }
  .ttlWrap .ttlA .en {
    font-size: 1.4rem;
  }
  .twoRow .imgBox .line {
    display: none;
  }
  .ttlWrap .decoration {
    display: none;
  }
  .twoRow .imgBox {
    display: block;
    width: 100%;
  }
  .twoRow .txtBox {
    display: block;
    width: 100%;
  }
  .twoRow .txtInner {
    height: 100%;
    display: block;
    margin-top: 0;
    padding: 10px;
  }
  .twoRow .txtInnerIn .line {
    left: 50%;
    top: -40px;
    width: 1px;
    height: 50px;
  }
  .twoRow .txtInnerIn {
    display: block;
    padding: 15px 10px 10px 10px;
    text-align: left;
  }
  .threeCnt {
    display: block;
  }
  .threeCnt li {
    margin-top: 20px;
    display: block;
    width: 100%;
    margin-right: 0;
    font-size: 1.5rem;
    padding: 15px 0;
  }
  .threeCnt li:nth-child(1) {
    margin-top: -20px;
    z-index: 2;
    position: relative;
  }
	.threeCnt li:first-child {
		margin-right: 0;
	}
  .blogList {
    display: block;
  }
  .blogList::before,
  .blogList::after {
    display: none;
  }
  .blogList li {
    width: 100%;
    margin-right: 0;
    display: block;
    margin-bottom: 20px;
  }
  .blogList li figure {
    display: flex;
  }
  .blogList li .imgWrap {
    width: 40%;
    padding-top: 28%;
  }
  .blogList li figcaption {
    width: 60%;
    padding-left: 10px;
  }
  .blogList figcaption .ttl {
    font-size: 1.4rem;
    margin-top: 5px;
  }
  .blogWrapCnt .btnA a {
    width: 80%;
  }
  .footLogo {
    padding: 15px 0;
  }
  .footBottomWrap {
    width: 100%;
    display: block;
    margin: 20px auto;
  }
  .footBottomWrap .footLeft {
    padding-right: 0;
  }
  .footBottomWrap .footRight {
    width: 90%;
    margin: 0 auto;
  }
  table {
    width: 100%;
  }
  .tblA {
    /* width: 400px; */
    width: 100%;
  }
  .scroll {
    overflow: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }
  .footBottomWrap .btnA a {
    width: 80%;
    margin-bottom: 20px;
  }
  .contactWrap {
    width: 80%;
  }
  .contactWrap li {
    display: block;
    width: 100%;
  }
  .contactWrap li dt {
    margin-bottom: 10px;
  }
  footer .copy {
    margin-bottom: 50px;
  }
  /*pgTop*/
  .pageTop {
    right: 10px;
    bottom: 60px;
  }
  /*ttl*/
  .ttlB {
    font-size: 1.8rem;
  }
  .ttlC {
    font-size: 1.8rem;
  }
  .ttlC .en {
    font-size: 1.4rem;
  }
  .ttlD {
    font-size: 1.6rem;
  }
  .ttlE {
    font-size: 2rem;
  }
  .ttlE .en {
    font-size: 1.4rem;
  }
  .ttlF {
    font-size: 1.8rem;
  }
  /*btn*/
  .btnA a {
    width: 100%;
    height: 50px;
    line-height: 50px;
    background: #fff;
    font-weight: bold;
    font-size: 1.5rem;
  }
  .arrowWrap {
    display: none;
  }
  .threeCnt li .btnA a {
    width: 80%;
  }
  /*fix bottom*/
  .fixBottom {
    width: 100%;
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 10;
  }
  .fixBottomUl {
    display: table;
    width: 100%;
  }
  .fixBottomUl li {
    display: table-cell;
    width: 50%;
    text-align: center;
    vertical-align: middle;
    height: 50px;
  }
  .fixBottomUl li a {
    color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  .fixBottomUl li .circleBg {
    background: #fff;
    margin-right: 5px;
  }
  .fixBottomUl li .jpSerifM {
    display: inline-block;
    line-height: 30px;
  }
  .fixBottomUl li.tel {
    background: var(--color01);
  }
  .fixBottomUl li.tel .fas {
    color: var(--color01);
  }
  .fixBottomUl li.contact {
    background: var(--color03);
  }
  .fixBottomUl li.contact .fas {
    color: var(--color03);
  }
  /*page*/
  .leadPageBox .decoration {
    display: none;
  }
  .pageTtl {
    color: #fff;
  }
  .pageMv {
    background: var(--color01);
  }
  .pageMv img {
    opacity: 0.25;
  }
  .pageTtl .jpSerifB {
    font-size: 2rem;
  }
  .pageTtl .en {
    font-size: 1.4rem;
  }
  .bread {
    font-size: 1.4rem;
  }
  .centerText {
    width: 80%;
  }
  .cntWraper .twoRow {
    padding-left: 0;
  }
  .twoRow + .twoRow {
    margin-top: 50px;
  }
  .twoRowInner {
    display: block;
  }
  .smallTxtBoxIn {
    width: 100%;
  }
  .flow .cntWraper.hasArrow {
    margin-bottom: 70px;
  }
  .flow .cntWraper .twoRow {
    position: relative;
  }
  .flow .cntWraper .twoRow .txtOuter:after {
    position: absolute;
    top: auto;
    bottom: -50px;
    left: calc(50% - 20px);
  }
  .cntW1000 {
    width: 100%;
    padding: 0 5%;
  }
  .dlA dt i {
    width: 30px;
    height: 30px;
    line-height: 30px;
    font-size: 1.6rem;
  }
  .dlA dt span {
    width: calc(100% - 30px);
  }
  .accWrap .accDt {
    padding: 10px 40px 10px 10px;
    font-size: 1.6rem;
    line-height: 1.2;
  }
  .accWrap .accDt:after {
    width: 30px;
    height: 16px;
    right: 10px;
    top: 50%;
    margin-top: -8px;
  }
  .accWrap .inner {
    padding: 5%;
  }
  .innDl {
    display: block;
    margin-bottom: 10px;
  }
  .innDl dt {
    display: block;
    margin-top: 10px;
    margin-bottom: 10px;
  }
  .innDl dt:first-child {
    margin-top: 0;
  }
  .innDl dd {
    margin: 10px;
  }
  .badge {
    /* display: inline; */
    top: 0;
    margin-left: 0;
    /* line-height: 2.4; */
    margin-right: 10px;
    margin-top: 5px;
    margin-bottom: 5px;
  }
  .special .cntW1000 {
    padding: 0;
  }
  .oneRowTxt .txtBox {
    width: 90%;
    margin: -20px auto 0 auto;
  }
  .oneRowTxt .txtInnerIn {
    padding: 30px 0 0 0;
    text-align: left;
  }
  .cntW800 {
    width: 100%;
    padding: 0 5%;
  }
  /* menu */
  .menu .inner .catch,
  .menu .inner p {
    margin-bottom: 10px;
  }
  /* special */
  .special .cntW800 p {
    margin-bottom: 10px;
  }
  .blogInner {
    display: block;
    width: 100%;
  }
  .blogInner .blogListWrap {
    display: block;
    width: 100%;
  }
  .blogArticleList time {
    margin-left: 0;
    display: block;
    margin-top: 5px;
  }
  .blogArticleList .blogTtl {
    font-size: 1.6rem;
  }
  .blogInner .subWrap {
    width: 100%;
    padding-left: 0;
    display: block;
  }
  .mw_wp_form_input .formMessage01,
  .mw_wp_form_confirm .formMessage02 {
    text-align: left;
  }
  .mw_wp_form_confirm .formMessage01,
  .mw_wp_form_input .formMessage02 {
    text-align: left;
  }
  .formWrapOuter {
    width: 100%;
    padding: 0 5%;
  }
  .formWrap {
    width: 100%;
    margin: 30px auto 50px;
    padding: 20px;
  }
  .formWrap dl {
    width: 100%;
  }
  .formWrap .formBtn {
    width: 100%;
  }
  .formWrap .backBtn {
    margin-top: 15px;
  }
  .mwform-radio-field.horizontal-item {
    display: block;
    width: 100%;
  }
  .privacy .modPCenter {
    text-align: left;
  }
  /*margin*/
  .mb20 {
    margin-bottom: 10px;
  }
  .mb30 {
    margin-bottom: 15px;
  }
  .mb40 {
    margin-bottom: 20px;
  }
  .mb50 {
    margin-bottom: 25px;
  }
  .mb70 {
    margin-bottom: 35px;
  }
  .mb80 {
    margin-bottom: 40px;
  }
  .mb90 {
    margin-bottom: 45px;
  }
  .mb100 {
    margin-bottom: 50px;
  }
  .mb120 {
    margin-bottom: 60px;
  }
  .mb150 {
    margin-bottom: 75px;
  }
}
/********youtube***************/
.video {
  position: relative;
  height: 0;
  padding: 30px 0 56.25%;
  overflow: hidden;
}

.video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
