@charset "UTF-8";
/*------------------------------------------------------------------------------
    config
------------------------------------------------------------------------------*/
/***  media ***/
/***  color ***/
/*** font ***/
.mv {
  position: relative;
  color: #ffffff;
  background: #E6E6DF;
}
.mv .scroll {
  position: absolute;
  right: 30px;
  bottom: -10px;
  z-index: 50;
}
.mv .scroll p {
  writing-mode: vertical-lr;
  color: #ffffff;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.01;
  letter-spacing: 0.5em;
}
.mv .scroll span {
  display: block;
  height: 93px;
  width: 0.5px;
  background: #ffffff;
  margin-top: 10px;
  margin-left: 2px;
}
.mv .scroll .single-scroll-down-animation {
  margin-right: 20px;
  width: calc(25% - 20px);
  margin-bottom: 50px;
}
.mv .scroll .scroll-down4 {
  width: 0.5px;
  height: 93px;
  background: #ffffff;
  animation: scrollDown4 2s ease infinite;
  margin: 0 auto;
}
@keyframes scrollDown4 {
  0% {
    transform-origin: top;
    transform: scaleY(0);
  }
  45% {
    transform-origin: top;
    transform: scaleY(1);
  }
  55% {
    transform-origin: bottom;
    transform: scaleY(1);
  }
  100% {
    transform-origin: bottom;
    transform: scaleY(0);
  }
}
.mv .mv_txt {
  z-index: 50;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding-top: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mv .mv_txt .mv_logo {
  max-width: 146px;
  margin: auto;
}
.mv .mv_txt .ttl {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.18em;
  line-height: 1.714;
  text-align: center;
  margin-bottom: 24px;
}
.mv .mv_txt .sub {
  font-size: 15px;
  font-weight: 400;
  writing-mode: vertical-rl;
  width: fit-content;
  letter-spacing: 0.36em;
  margin: auto;
  margin-top: 24px;
}
.mv .mv_bg {
  position: relative;
}
.concept {
  background: #E6E6DF;
}
.concept .inner {
  padding-top: 40px;
  padding-bottom: 70px;
}
.concept ul {
  margin-top: 30px;
}
.concept ul li {
  padding: 0 24px;
  position: relative;
}
.concept ul li + li {
  margin-top: 40px;
  padding-top: 45px;
}
.concept ul li:nth-child(2) .ttl_item {
  flex-direction: row-reverse;
}
.concept ul li:nth-child(2) .ttl_item .img {
  padding-right: 0;
  padding-left: 23px;
}
.concept ul li:nth-child(2) .list_ttl {
  position: relative;
}
.concept ul li:nth-child(2) .list_ttl::after {
  position: absolute;
  content: "";
  width: 29px;
  height: 29px;
  right: calc(50% - 14.5px);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  top: 46%;
  z-index: 1;
  background: url(../img/top/concept_list_after.webp) no-repeat bottom;
  background-size: 100% 100%;
  transition: 0.3s ease-in-out;
}
.concept ul li:nth-child(2) .icon {
  right: auto;
  left: -64px;
  top: -55px;
}
.concept ul li:nth-child(1) .icon {
  right: -37px;
  top: -52px;
}
.concept ul li:nth-child(3) .icon {
  right: -51px;
  top: -52px;
}
.concept ul li .icon {
  z-index: 5;
  position: absolute;
  font-weight: 100;
  font-family: "Jost", sans-serif;
  font-size: 200px;
  letter-spacing: 0.05em;
  color: #ffffff;
  line-height: 1.01;
  margin: auto;
  width: fit-content;
}
.concept ul li .ttl_item {
  position: relative;
  z-index: 10;
  display: flex;
  justify-content: space-between;
}
.concept ul li .ttl_item .list_ttl {
  line-height: 2.1;
  font-size: 14px;
  font-weight: 500;
  writing-mode: vertical-rl;
  width: fit-content;
  letter-spacing: 0.32em;
  margin: auto;
  text-align: left;
  margin-top: 14px;
}
.concept ul li .ttl_item .list_ttl span {
  padding-top: 25px;
  white-space: nowrap !important;
}
.concept ul li .ttl_item .img {
  max-width: 246px;
  padding-right: 26px;
}
.concept ul li p {
  text-align: left;
  margin-top: 20px;
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 2.083;
}
.about {
  background: #F2F2ED;
}
.about .inner {
  padding-top: 40px;
  padding-bottom: 64px;
}
.about .sub_txt {
  text-align: left;
  width: fit-content;
  margin: auto;
  margin-top: 30px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5625;
}
.about .img {
  margin-top: 52px;
  padding-left: 13px;
  padding-right: 23px;
}
.about p {
  text-align: left;
  font-size: 12px;
  padding: 45px 18px;
  font-weight: 400;
}
.artist {
  background: url(../img/top/artist_bg.webp) no-repeat bottom;
  background-size: cover;
  background-position: center top;
  color: #E6E6DF;
}
.artist .inner {
  padding-top: 40px;
  padding-bottom: 60px;
}
.artist ul {
  margin-top: 20px;
}
.artist ul li + li {
  padding-top: 40px;
  margin-top: 40px;
  border-top: 0.5px solid #E6E6DF;
}
.artist ul li .img {
  max-width: 220px;
  margin: auto;
}
.artist ul li .txt_item {
  padding: 15px 10px 30px 18px;
  text-align: left;
}
.artist ul li .txt_item .sub {
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 1.384;
}
.artist ul li .txt_item .ttl {
  font-size: 25px;
  font-weight: 400;
  letter-spacing: 0.08em;
  line-height: 1.01;
  position: relative;
  margin-top: 20px;
}
.artist ul li .txt_item .ttl .icon {
  font-family: "EB Garamond", serif;
  font-size: 35px;
  font-weight: 400;
  letter-spacing: 0.05em;
  right: -10px;
  bottom: 0;
  position: absolute;
  writing-mode: vertical-rl;
  white-space: nowrap;
  color: #5D7C6D;
  line-height: 1.01;
}
.artist ul li .txt_item p {
  margin-top: 24px;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.666;
}
.reasons {
  background: #E6E6DF;
}
.reasons .inner {
  padding-left: 0;
  padding-right: 0;
  padding-top: 40px;
  padding-bottom: 50px;
}
.reasons .h2_ttl {
  padding-left: 26px;
}
.reasons ul {
  margin-top: 23px;
}
.reasons ul li {
  background: #fff;
  border-radius: 0 100px 0 100px;
  padding: 15px 38px 40px 38px;
}
.reasons ul li + li {
  margin-top: 10px;
}
.reasons ul li .icon {
  font-family: "Jost", sans-serif;
  font-size: 50px;
  font-weight: 100;
  letter-spacing: 0.05em;
  line-height: 1.21;
  text-align: left;
  color: #214634;
}
.reasons ul li .h3_ttl {
  color: #214634;
  text-align: left;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.5625;
  border-bottom: 0.5px solid #214634;
  padding-bottom: 13px;
  margin-bottom: 15px;
}
.reasons ul li p {
  font-size: 12px;
  font-weight: 400;
  line-height: 1.6666;
  text-align: left;
}
.faq {
  background: #F2F2ED;
}
.faq .inner {
  padding-top: 40px;
  padding-bottom: 60px;
}
.faq .faq_item {
  position: relative;
  z-index: 10;
  margin-top: 30px;
}
.faq .faq_item .list li {
  padding-bottom: 15px;
  background-image: linear-gradient(to right, #214634 1px, transparent 1px);
  background-size: 4px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
.faq .faq_item .list li + li {
  margin-top: 12px;
}
.faq .faq_item .list li:last-child .a_txt {
  margin-bottom: 0;
}
.faq .faq_item .list li .q_txt {
  position: relative;
  font-family: "EB Garamond", serif;
  color: #214634;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  line-height: 1.92;
  align-items: flex-start;
  display: flex;
}
.faq .faq_item .list li .q_txt:after {
  content: "";
  display: inline-block;
  position: absolute;
  background: url(../img/common/add.webp) no-repeat center / contain;
  width: 12px;
  height: 12px;
  right: 0;
  top: 10px;
  transition: 0.3s;
}
.faq .faq_item .list li .q_txt p {
  padding-top: 6px;
  width: calc(100% - 36px);
  text-align: left;
}
.faq .faq_item .list li .q_txt span {
  font-size: 25px;
  font-weight: 400;
  font-family: "EB Garamond", serif;
  color: #DEDED4;
  width: 36px;
  text-align: left;
  padding-left: 5px;
  display: block;
  line-height: 1.01;
}
.faq .faq_item .list li .faqactive:after {
  content: "";
  display: inline-block;
  position: absolute;
  background: url(../img/common/mai.webp) no-repeat center / contain;
  background-size: 100% 100%;
  width: 12px;
  height: 12px;
  right: 0;
  top: 10px;
  transition: 0.3s;
}
.faq .faq_item .list li .a_txt {
  display: none;
  position: relative;
  font-size: 12px;
  font-weight: 400;
  padding: 10px 10px 10px 18px;
  text-align: left;
  line-height: 1.66;
  width: 100%;
  margin-top: 10px;
  background: #ffffff;
  border-radius: 10px;
}
.faq .faq_item .list li .a_txt .a_list {
  display: flex;
}
.faq .faq_item .list li .a_txt:after {
  display: none;
}
.faq .faq_item .list li .a_txt a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
}
.faq .faq_item .list li .a_txt p {
  text-align: left;
  width: calc(100% - 78px);
}
.faq .faq_item .list li .a_txt span {
  font-size: 28px;
  text-align: left;
  font-weight: 400;
  font-family: "EB Garamond", serif;
  color: #C1A06B;
  display: block;
  width: 78px;
  line-height: 1.51;
}
.column .inner {
  padding-top: 30px;
}
.column ul {
  margin-top: 23px;
  margin-bottom: 40px;
}
.column ul li {
  display: block;
}
.column ul li + li {
  margin-top: 20px;
}
.column ul li dl {
  display: flex;
}
.column ul li dl dt {
  width: 112px;
  padding-right: 12px;
  height: 100px;
}
.column ul li dl dt img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.column ul li dl dd {
  width: calc(100% - 112px);
  display: flex;
  align-items: flex-end;
  text-align: left;
}
.column ul li dl dd .data {
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.5;
  font-family: "EB Garamond", serif;
}
.column ul li dl dd .ttl {
  font-size: 12px;
  font-weight: 400;
  margin-top: 10px;
  line-height: 1.666;
}
.media .inner {
  padding-bottom: 60px;
  padding-top: 60px;
}
.media ul {
  margin-top: 20px;
  margin-bottom: 24px;
  padding-left: 13px;
  padding-right: 23px;
  display: block;
}
.media ul li + li {
  margin-top: 30px;
}
.media ul li a {
  display: block;
  text-align: left;
}
.media ul li a .img {
  width: 100%;
}
.media ul li a .data {
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.5;
  margin-top: 3px;
}
.media ul li a .ttl {
  font-size: 12px;
  font-weight: 400;
  margin-top: 5px;
  line-height: 1.666;
}
.youtube {
  background: #214634;
  color: #E6E6DF;
}
.youtube .inner {
  padding-top: 30px;
  padding-bottom: 60px;
}
.youtube ul {
  padding: 30px 15px;
}
.youtube ul li {
  aspect-ratio: 16 / 9;
}
.youtube ul li iframe {
  height: 100% !important;
  width: 100% !important;
}
.youtube ul li + li {
  margin-top: 12px;
}
.youtube ul li a {
  display: block;
}
.info {
  background: #ffffff;
}
.info .inner {
  padding-top: 30px;
  padding-bottom: 50px;
}
.info ul {
  margin-top: 21px;
}
.info ul li {
  padding: 0 22px 10px 13px;
  background-image: linear-gradient(to right, #214634 1px, transparent 1px);
  background-size: 3px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}
.info ul li + li {
  margin-top: 10px;
}
.info ul li .map {
  margin-bottom: 10px;
}
.info ul li .map iframe {
  width: 100%;
  height: 180px;
  border: none;
}
.info ul li .ttl {
  width: fit-content;
  background: #214634;
  padding: 0 14px;
  line-height: 20px;
  color: #F2F2ED;
  font-size: 12px;
  letter-spacing: 0.08em;
  font-weight: 400;
  margin-bottom: 6px;
  text-align: left;
}
.info ul li p {
  text-align: left;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.666;
}
.contact {
  background: #214634;
  color: #ffffff;
}
.contact .inner {
  padding-top: 30px;
  padding-bottom: 45px;
}
.contact .btn_o {
  background: #6A8D73;
}
.contact .btn_o span {
  color: #6A8D73;
}
.contact .btn_ug {
  background: #B56E5E;
}
.contact .form {
  margin-top: 50px;
}
@media screen and (max-width: 818px) {
  .contact .form {
    margin-top: 25px;
  }
}
.contact .form .hishu {
  color: #C4242B;
  margin-left: 4px;
}
@media screen and (max-width: 818px) {
  .contact .form .hishu {
    margin-left: 5px;
  }
}
.contact .form .c_form input,
.contact .form .c_form textarea {
  font-size: 16px !important;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 818px) {
  .contact .form .c_form input,
  .contact .form .c_form textarea {
    font-size: 14px !important;
  }
}
.contact .form .c_form .wpcf7-spinner {
  display: none !important;
}
.contact .form .c_form .send_box {
  margin-top: 25px;
}
.contact .form .c_form .sendok {
  position: relative;
  overflow: hidden;
}
.contact .form .c_form .sendok #send,
.contact .form .c_form .sendok .wpcf7-submit {
  background: #239A9F !important;
  cursor: pointer !important;
}
.contact .form .c_form .sendok #send:hover,
.contact .form .c_form .sendok .wpcf7-submit:hover {
  -webkit-transition: all 0.8s;
  transition: all 0.8s;
  background: #889026 !important;
  color: #ffffff !important;
  opacity: 1 !important;
  cursor: pointer;
}
.contact .form .c_form .sendok::before {
  content: '';
  width: 40px;
  height: 0.5px;
  background-color: #ffffff;
  position: absolute;
  right: 0;
  bottom: 50%;
  transition: 0.8s;
  z-index: 2;
}
.contact .form .c_form .sendok:hover {
  opacity: 1;
}
.contact .form .c_form .sendok:hover::before {
  right: -40px;
}
.contact .form .c_form .sendok::after {
  content: '';
  width: 40px;
  height: 0.5px;
  background-color: #ffffff;
  position: absolute;
  left: -40px;
  bottom: 50%;
  transition: 0.8s;
  z-index: 2;
}
.contact .form .c_form .sendok:hover::after {
  transition-delay: 0.2s;
  left: 0;
}
.contact .form .c_form #send,
.contact .form .c_form .wpcf7-submit {
  -webkit-transition: all 0.8s;
  border: none;
  transition: all 0.8s;
  cursor: no-drop;
  background: #b5b5b5;
  position: relative;
  width: 100%;
  line-height: 60px;
  border-radius: 100px;
  color: #ffffff !important;
  font-size: 13px;
  font-weight: 500;
  text-align: center;
  display: block;
}
.contact .form .c_form .check_list {
  text-align: center;
  font-size: 14px;
}
.contact .form .c_form .check_list .sub {
  font-size: 16px;
}
@media screen and (max-width: 818px) {
  .contact .form .c_form .check_list .sub {
    font-size: 14px;
  }
}
.contact .form .c_form .check_list .sub,
.contact .form .c_form .check_list .form-acceptance {
  margin-top: 15px;
}
.contact .form .c_form .check_list .sub a,
.contact .form .c_form .check_list .form-acceptance a {
  color: #208556;
  text-decoration: underline;
}
.contact .form .c_form .form-acceptance input[type=checkbox] {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  z-index: 1;
  margin: 0;
  width: 20px;
  height: 20px;
  cursor: pointer;
  opacity: 0;
}
.contact .form .c_form .wpcf7-list-item {
  margin: 0;
}
.contact .form .c_form .form-acceptance .wpcf7-list-item-label::before {
  content: "";
  position: absolute;
  top: 52%;
  left: -1.2em;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  cursor: pointer;
  transition: all 0.3s;
  border: 1px solid #fff;
}
.contact .form .c_form .wpcf7-list-item-label {
  position: relative;
}
.contact .form .c_form .form-acceptance .wpcf7-list-item-label::after {
  content: "";
  position: absolute;
  top: 52%;
  left: -1.8em;
  transform: translateY(-50%);
  width: 26px;
  height: 13px;
  background: url(../img/common/check_icon.webp) no-repeat center / contain;
  cursor: pointer;
  transition: all 0.3s;
  opacity: 0;
}
.contact .form .c_form input[type=checkbox]:checked + .wpcf7-list-item-label::after {
  opacity: 1;
}
.contact .form .c_form input[type=checkbox]:checked + .wpcf7-list-item-label::before {
  opacity: 1;
}
.contact .form .c_form ul {
  display: block;
}
.contact .form .c_form ul li + li {
  margin-top: 20px;
}
.contact .form .c_form ul li dl {
  width: 100%;
  display: block;
}
.contact .form .c_form ul li dl dt {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0;
  text-align: left;
  width: 100%;
  line-height: 1.83;
}
.contact .form .c_form ul li dl dd {
  width: 100%;
  margin-top: 12px;
}
.contact .form .c_form ul li dl dd p {
  width: 100%;
  text-align: left;
  padding-bottom: 0;
}
.contact .form .c_form ul li dl dd input[type="button"],
.contact .form .c_form ul li dl dd input[type="submit"],
.contact .form .c_form ul li dl dd input[type="reset"] {
  -webkit-appearance: none;
}
.contact .form .c_form ul li dl dd p,
.contact .form .c_form ul li dl dd span {
  width: 100%;
  align-items: left;
  display: block !important;
  text-align: left;
}
.contact .form .c_form ul li dl dd .sub_txt {
  margin-top: 15px;
}
@media screen and (max-width: 818px) {
  .contact .form .c_form ul li dl dd .sub_txt {
    margin-top: 10px;
  }
}
.contact .form .c_form ul li dl dd .wpcf7-radio {
  display: block !important;
  flex-wrap: wrap;
}
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item label {
  line-height: 1.88 !important;
}
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item {
  width: fit-content;
  margin-right: 40px;
  margin-left: 0;
  align-items: center;
}
@media screen and (max-width: 818px) {
  .contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item {
    margin-right: 20px;
  }
}
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item label {
  display: flex !important;
  align-items: center;
  text-wrap: nowrap;
  margin-right: 15px;
  line-height: 32px;
}
@media screen and (max-width: 818px) {
  .contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item label {
    margin-right: 10px;
  }
}
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item div:first-of-type {
  display: flex;
  align-items: flex-start;
  margin-bottom: 5px;
}
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item input[type="text"]:checked {
  box-sizing: border-box;
  outline: 7px solid #CCCCCC;
  outline-offset: -7px;
}
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item button,
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item legend {
  color: white;
  background-color: #CCCCCC;
  padding: 5px 5px;
  border-radius: 0;
  border: 0;
  font-size: 12px;
}
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item button:hover,
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item button:focus {
  color: #CCCCCC;
}
.contact .form .c_form ul li dl dd .wpcf7-radio .wpcf7-list-item button:active {
  background-color: white;
  color: #CCCCCC;
  outline: 1px solid #CCCCCC;
}
.contact .form .c_form ul li dl dd input[type="text"],
.contact .form .c_form ul li dl dd input[type="tel"],
.contact .form .c_form ul li dl dd input[type="email"] {
  font-size: 12px;
  border: none !important;
  font-weight: 400;
  padding: 8px 10px;
  width: 100%;
  background: #ffffff;
  letter-spacing: 0;
  border-radius: 5px;
}
.contact .form .c_form ul li dl dd textarea {
  font-size: 12px;
  font-weight: 400;
  padding: 8px 10px;
  width: 100%;
  background: #ffffff;
  letter-spacing: 0;
  border-radius: 5px;
  height: 140px;
  border: none !important;
}
@media screen and (max-width: 818px) {
  .contact .form .c_form ul li dl dd select {
    font-size: 14px !important;
    border-radius: 5px;
  }
}
.contact .form .c_form ul li dl dd .wpcf7-not-valid-tip {
  color: #cc6715 !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  display: block !important;
  line-height: 160%;
  text-align: left;
}
.contact .form .c_form ul li dl dd input:focus,
.contact .form .c_form ul li dl dd textarea:focus,
.contact .form .c_form ul li dl dd select:focus {
  color: #000000 !important;
}
.contact .form .c_form ul li dl dd input:valid,
.contact .form .c_form ul li dl dd textarea:valid,
.contact .form .c_form ul li dl dd select:valid {
  color: #000000 !important;
}
.contact .form .c_form ul li dl dd input:invalid,
.contact .form .c_form ul li dl dd textarea:invalid,
.contact .form .c_form ul li dl dd select:invalid {
  color: #000000 !important;
}
.contact .form .c_form ul li dl dd input[type="radio"] {
  appearance: none;
  border-radius: 50%;
  width: 11px;
  height: 11px;
  border: 0.5px solid #fff;
  transition: 0.3s all linear;
  margin-right: 4px;
  padding: 6px;
  position: relative;
  font-size: 12px;
  margin-top: 0;
}
.contact .form .c_form ul li dl dd input[type="radio"]:checked {
  box-sizing: border-box;
  outline: 5px solid #fff;
  outline-offset: -5px;
}
.contact .form .form_check {
  font-size: 12px !important;
  display: flex;
  align-items: center;
  justify-content: center;
}
.contact .form .form_check p {
  display: inline-block;
}
.contact .form .check_list_txt {
  padding-top: 8px;
  margin-left: 2px;
}
.contact .form .check_list_txt a {
  color: #ffffff !important;
  display: inline-block;
  align-items: center;
  font-size: 12px;
}
.rotate-num {
  padding-top: 0 !important;
  writing-mode: lr !important;
  letter-spacing: 0 !important;
}
.c02_h {
  justify-content: flex-start !important;
  align-content: flex-start !important;
}
.c02_h .list_ttl {
  min-height: 356px !important;
}
.c02_h .list_ttl {
  height: fit-content;
  width: fit-content;
  margin-top: 14px !important;
}
