@charset "UTF-8";
.min1200{
    display: none;
}

@media screen and (min-width: 1200px) {
    .min1200{
        display: inherit;
    }
}
/*
 * ページ
 */
.page-index .general-body {
  padding-top: 70px;
  padding-bottom: 50px;
}

@media screen and (min-width: 960px), print {
  .page-index .general-body {
    padding-top: 36px;
  }
}

/*
 * タイトル
 */
.index-title {
  margin-bottom: 16px;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
}

@media screen and (min-width: 960px), print {
  .index-title {
    margin-bottom: 25px;
    text-align: center;
  }
}

/*
 * リード文
 */
.index-lead {
  margin-bottom: 45px;
}

@media screen and (min-width: 960px), print {
  .index-lead {
    margin-bottom: 62px;
    padding: 0 40px;
    text-align: center;
  }
}

/*
 * メニュー
 */
@media screen and (max-width: 549px) {
  .index-menus > .index-menu:not(:last-child) {
    margin-bottom: 20px;
  }
}

@media screen and (min-width: 550px), print {
  .index-menus {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 -1.5% 0;
  }
  .index-menus > .index-menu {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: calc(50% - 3%);
    margin-left: 1.5%;
    margin-right: 1.5%;
  }
  .index-menus > .index-menu:nth-child(n+3) {
    margin-top: 27px;
  }
}

@media screen and (min-width: 1200px) {
  .index-menus {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 -1.5% 0;
  }
  .index-menus > .index-menu {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
    width: calc(33.333333% - 3%);
    margin-left: 1.5%;
    margin-right: 1.5%;
  }
  .index-menus > .index-menu:nth-child(n-3) {
    margin-top: 0;
  }
  .index-menus > .index-menu:nth-child(n+4) {
    margin-top: 27px;
  }
}

.index-menu {
  border: 1px solid #D2D2D2;
}

.index-menu__image img {
  width: 100%;
  aspect-ratio:410/200;
	object-fit: cover;
}

html.has-hover .index-menu__image:hover,
html.has-hover a:hover .index-menu__image,
html.has-hover .bl-hover .index-menu__image {
  opacity: .7;
}

.index-menu__content {
  padding: 20px 42px 30px;
}

.index-menu__title {
  position: relative;
  margin-bottom: 10px;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.72222;
}

.index-menu__title:before {
  content: '';
  display: block;
  position: absolute;
  left: -42px;
  top: 50%;
  border-top: 1px solid #d2d2d2;
  width: 30px;
}

html.has-hover .index-menu__title:hover,
html.has-hover a:hover .index-menu__title,
html.has-hover .bl-hover .index-menu__title {
  color: #DBA24C;
}

@media screen and (min-width: 960px), print {
  .index-menu {
    min-height: 416px;
  }
  .index-menu__content {
    padding: 26px 42px 40px;
  }
}
