@charset "utf-8";

/*------------------------------------------------------------
	書式設定
------------------------------------------------------------*/
/* フォントの太さ */
.fwNormal {
  font-weight: normal !important;
}
.fwBold {
  font-weight: bold !important;
}

/* フォント設定 */
.lp_header,
main {
  font-family: Times New Roman, "Noto Serif JP", san-serif;
  font-weight: 500;
  line-height: 1.6;
}
.contents_text {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-size: 16px;
  line-height: 2;
  text-align: left;
}
/*------------------------------------------------------------
	微調整用クラス（※多用しないこと）
------------------------------------------------------------*/
.mt0 {
  margin-top: 0 !important;
}
.mb0 {
  margin-bottom: 0 !important;
}

/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* 既存bodyスタイル打ち消し */
body {
  min-width: unset;
}
/* 既存bodyスタイル打ち消しをfooterでは反映させる */
footer {
  min-width: 1200px;
}

/* スムーススクロール */
html {
  scroll-behavior: smooth;
}

* html .clearfix {
  zoom: 1;
}

* + html .clearfix {
  zoom: 1;
}
.clearfix:after {
  height: 0;
  visibility: hidden;
  content: ".";
  display: block;
  clear: both;
}
img {
  height: auto;
  max-width: 100%;
}
video,
img {
  object-fit: cover;
  vertical-align: bottom;
}
* {
  box-sizing: border-box;
}

/*------------------------------------------------------------
	base layout
------------------------------------------------------------*/
.ly_section {
  position: relative;
  transform: translate3d(0, 0, 0);
  width: 100%;
  z-index: 100;
}
.ly_contents {
  margin: 0 auto;
  width: 100%;
}
/*------------------------------------------------------------
	header
------------------------------------------------------------*/
.lp_header {
  align-items: center;
  display: flex;
  position: fixed;
  width: 100%;
  z-index: 900;
}
.lp_header_inner {
  align-items: center;
  display: flex;
  margin: 0 auto;
  width: 100%;
}
.lp_header_logo {
  margin: 0 0 0 20px;
}
.lp_header_logo a {
  display: block;
}
.lp_nav {
  margin: 0 32px 0 0;
}
.lp_nav_list {
  display: flex;
  flex-wrap: wrap;
}
.lp_nav_list li {
  margin: 0 32px 0 0;
}
.lp_nav_list li:last-child {
  margin: 0;
}

/*------------------------------------------------------------
	main visual
------------------------------------------------------------*/
.mv {
  position: sticky;
  top: 0;
  width: auto;
}
.mv_video {
  position: relative;
}
.mv_video::after {
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.mv_video video {
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
  width: 100%;
}
.mv_contents {
  display: flex;
  flex-flow: column;
  left: 50%;
  position: absolute;
  text-align: center;
  transform: translate(-50%, -50%);
}
.mv_logo {
  margin: 0 auto;
  order: 2;
}
.mv_copy {
  order: 1;
}
a.mv_scrollicon {
  display: block;
  font-family: "Arial", sans-serif;
  font-size: 12px;
  left: 50%;
  padding: 0 6px;
  position: absolute;
  transform: translate(-50%, -50%);
  width: 42px;
}
.mv_scrollicon::before {
  border: 2px solid #fff;
  border-bottom: 0;
  border-left: 0;
  content: "";
  display: block;
  transform: translateY(-25%) rotate(135deg);
}

/*------------------------------------------------------------
	ビデオ背景セクション
------------------------------------------------------------*/
.contents_body {
  position: relative;
}
.video {
  object-fit: cover;
}
/*------------------------------------------------------------
	背景画像セクション
------------------------------------------------------------*/
.contents_inner {
  position: relative;
  z-index: 100;
}
/*------------------------------------------------------------
	写真、カードセクション
------------------------------------------------------------*/
.photo_wrapper {
  display: flex;
  flex-wrap: wrap;
}
.photo_img {
  height: auto;
  width: calc(100% / 3);
}
.photo_img:last-child {
  width: 100%;
}
.card_wrapper {
  padding: 0 0 88px;
}
.card:last-child {
  margin-right: 0;
}
.card_img {
  height: auto;
  margin: 0 0 14px;
  width: 100%;
}
.card_p {
  text-align: center;
}
/*------------------------------------------------------------
	ギャラリーセクション
------------------------------------------------------------*/
.gallery_contents.ly_contents {
  max-width: 100%;
  padding: 0;
}
.gallery_img_wrapper {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
/*------------------------------------------------------------
	footer
------------------------------------------------------------*/

footer {
  position: relative;
  transform: translate3d(0, 0, 0);
  width: 100%;
  z-index: 100;
}
#gFooter {
  background-color: #fff;
}

@media (max-width: 767px) {
  /*------------------------------------------------------------
	書式設定
    ------------------------------------------------------------*/
  .contents_text {
    font-feature-settings: "pkna";
  }
  /*------------------------------------------------------------
	headLine3
    ------------------------------------------------------------*/
  .lp h3 {
    font-size: 32px;
    line-height: 1.5;
    margin: 0 0 18px;
  }
  /*------------------------------------------------------------
	base layout
    ------------------------------------------------------------*/
  .ly_section {
    padding: 126px 0 0;
  }
  .ly_contents {
    padding: 0 5%;
  }
  .br_pc {
    display: none;
  }
  /*------------------------------------------------------------
	section copy
    ------------------------------------------------------------*/
  .lp .copy {
    font-size: 20px;
    margin: 0 0 50px;
  }
  /*------------------------------------------------------------
	header
    ------------------------------------------------------------*/
  .lp_nav_list li a {
    font-size: 16px;
  }
  /*------------------------------------------------------------
	main visual
    ------------------------------------------------------------*/
  a.mv_scrollicon {
    bottom: 5%;
  }
  .mv_scrollicon::before {
    height: 20px;
    margin: 0px 4px 8px;
    width: 20px;
  }
  /*------------------------------------------------------------
	ビデオ背景セクション
    ------------------------------------------------------------*/
  .contents_header {
    margin: 0 5% 100px;
  }
  .overlap_text {
    padding: 60px 0;
  }
  /*------------------------------------------------------------
	写真、カードセクション
    ------------------------------------------------------------*/
  .photo_wrapper {
    margin: 0 0 40px;
  }
  .card_wrapper {
    display: block;
  }
  .card {
    margin: 0 0 20px;
    width: 100%;
  }
  .card_img img {
    width: 100%;
  }
  .card_p {
    font-size: 16px;
    text-align: left;
  }
  /*------------------------------------------------------------
	ギャラリーセクション
    ------------------------------------------------------------*/
  .gallery_img {
    width: calc(100% / 3);
  }
  /*------------------------------------------------------------
		footer
	------------------------------------------------------------*/
  footer {
    min-width: unset;
  }
}
@media (min-width: 768px) {
  /*------------------------------------------------------------
	headLine2
    ------------------------------------------------------------*/
  .lp h2 {
    margin: 0 auto 8px;
  }
  /*------------------------------------------------------------
	headLine3
    ------------------------------------------------------------*/
  .lp h3 {
    font-size: 45px;
    margin: 0 0 18px;
    text-align: center;
  }
  /*------------------------------------------------------------
	base layout
    ------------------------------------------------------------*/
  .ly_contents {
    max-width: 1040px;
    padding: 0 20px;
  }
  .br_sp {
    display: none;
  }
  /*------------------------------------------------------------
	section copy
    ------------------------------------------------------------*/
  .lp .copy {
    font-size: 22px;
    margin: 0 0 60px;
    text-align: center;
  }
  /*------------------------------------------------------------
	header
    ------------------------------------------------------------*/
  .lp_header_inner {
    justify-content: space-between;
  }
  .lp_nav_list li a {
    font-size: 20px;
  }
  /*------------------------------------------------------------
	main visual
    ------------------------------------------------------------*/
  .mv_copy {
    font-size: 26px;
  }
  a.mv_scrollicon {
    bottom: 10px;
  }
  .mv_scrollicon::before {
    height: 28px;
    margin: 0 0 14px;
    width: 28px;
  }
  /*------------------------------------------------------------
	ビデオ背景セクション
    ------------------------------------------------------------*/
  .contents_header {
    margin: 0 0 188px;
  }
  .overlap_text {
    padding: 116px 0;
    position: relative;
    z-index: 100;
  }
  /*------------------------------------------------------------
	写真、カードセクション
    ------------------------------------------------------------*/
  .photo_wrapper {
    margin: 0 0 55px;
  }
  .card_wrapper {
    display: flex;
    justify-content: space-between;
    padding: 0 0 92px;
  }
  .card {
    width: 24%;
  }
  .card_p {
    font-size: 18px;
  }
  /*------------------------------------------------------------
	ギャラリーセクション
    ------------------------------------------------------------*/
  .gallery_img_wrapper {
    display: flex;
    flex-wrap: wrap;
  }
  .gallery_img {
    width: 25%;
  }
  /*------------------------------------------------------------
		footer
	------------------------------------------------------------*/
  footer {
    min-width: unset;
  }
  #gFooter .fNavi {
    width: auto;
  }
  #gFooter .copyright {
    width: auto;
  }
}
@media (min-width: 768px) and (max-width: 870px) {
  #gFooter .fNavi li {
    margin-right: 18px;
  }
  #gFooter .fNavi .fLink {
    margin: -6px 0 0 18px;
  }
}
