@charset "UTF-8";
/* ------------------------------
	レスポンシブ
------------------------------ */
/* ------------------------------
	フォント
------------------------------ */
@import url("https://fonts.googleapis.com/css2?family=Wix+Madefor+Text:ital,wght@0,400..800;1,400..800&display=swap");
/* ------------------------------
	カラー
------------------------------ */
/* ------------------------------
	.culture
------------------------------ */
@media screen and (min-width: 769px) {
  .content_wrap {
    z-index: 1;
  }
}

.page_head {
  z-index: 2;
}

.culture {
  position: relative;
  padding: 68px 0 30px;
  min-height: 1500px;
}
@media screen and (max-width: 768px) {
  .culture {
    min-height: 0;
    padding: 30px 0 30px;
  }
}
.culture .culture_bg {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 635px;
}
@media screen and (max-width: 768px) {
  .culture .culture_bg {
    display: none;
  }
}
.culture .culture_bg svg {
  width: 100%;
  height: auto;
}
.culture .culture_bg .line01 svg .svg-elem-1 {
  stroke-dashoffset: 318.5px;
  stroke-dasharray: 318.5px;
  transition: stroke-dashoffset 0.4s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
  transition-delay: 0.4s;
}
.culture .culture_bg .line02 svg .svg-elem-1 {
  stroke-dashoffset: 1082.04296875px;
  stroke-dasharray: 1082.04296875px;
  transition: stroke-dashoffset 0.6s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
  transition-delay: 0.4s;
}
.culture .culture_bg .line03 svg .svg-elem-1 {
  stroke-dashoffset: 917.713684082px;
  stroke-dasharray: 917.713684082px;
  transition: stroke-dashoffset 0.6s cubic-bezier(0.47, 0, 0.745, 0.715) 0s;
  transition-delay: 0.4s;
}
.culture.culture01_active .culture_bg .line01 svg .svg-elem-1 {
  stroke-dashoffset: 0;
}
.culture.culture02_active .culture_bg .line01 svg .svg-elem-1,
.culture.culture02_active .culture_bg .line02 svg .svg-elem-1 {
  stroke-dashoffset: 0;
}
.culture.culture03_active .culture_bg .line01 svg .svg-elem-1,
.culture.culture03_active .culture_bg .line02 svg .svg-elem-1,
.culture.culture03_active .culture_bg .line03 svg .svg-elem-1 {
  stroke-dashoffset: 0;
}
.culture .culture_box {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .culture .culture_box {
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }
}
@media screen and (max-width: 768px) {
  .culture .culture_box + .culture_box {
    margin-top: 60px;
  }
}
@media screen and (min-width: 769px) {
  .culture .culture_box:nth-child(odd) .img {
    order: 2;
  }
}
@media screen and (min-width: 769px) {
  .culture .culture_box:nth-child(odd) .txt_box {
    order: 1;
  }
}
@media screen and (min-width: 769px) {
  .culture .culture_box:nth-child(1) {
    align-items: center;
    padding-bottom: 118px;
    height: 690px;
  }
}
@media screen and (min-width: 769px) {
  .culture .culture_box:nth-child(2) {
    align-items: center;
    height: 433px;
  }
}
@media screen and (min-width: 769px) {
  .culture .culture_box:nth-child(3) {
    padding-top: 334px;
    height: 740px;
  }
}
.culture .culture_box .img {
  max-width: 480px;
  width: 48%;
}
@media screen and (max-width: 768px) {
  .culture .culture_box .img {
    width: 100%;
    max-width: 100%;
  }
}
.culture .culture_box .txt_box {
  position: relative;
  max-width: 480px;
  width: 48%;
}
@media screen and (max-width: 768px) {
  .culture .culture_box .txt_box {
    width: 100%;
    max-width: 100%;
  }
}
.culture .culture_box .txt_box .en_ttl {
  font-size: 5rem;
  font-weight: 900;
  color: #0077C3;
  font-feature-settings: "palt";
}
@media screen and (min-width: 769px) {
  .culture .culture_box .txt_box .en_ttl {
    position: absolute;
    left: 0;
    top: -80px;
    white-space: nowrap;
  }
}
@media screen and (max-width: 1050px) {
  .culture .culture_box .txt_box .en_ttl {
    font-size: 4.5rem;
  }
}
@media screen and (max-width: 768px) {
  .culture .culture_box .txt_box .en_ttl {
    margin-bottom: 10px;
    font-size: 3rem;
    line-height: 1.3;
  }
}
.culture .culture_box .txt_box .ttl {
  margin-bottom: 30px;
  font-size: 3.2rem;
  font-weight: 900;
  line-height: 1.8;
}
@media screen and (max-width: 1050px) {
  .culture .culture_box .txt_box .ttl {
    margin-bottom: 20px;
    line-height: 1.5;
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 768px) {
  .culture .culture_box .txt_box .ttl {
    margin-bottom: 10px;
    font-size: 2rem;
  }
}
.culture .culture_box .txt_box .txt {
  line-height: 2;
}
@media screen and (max-width: 1000px) {
  .culture .culture_box .txt_box .txt {
    line-height: 1.8;
  }
}