@charset 'UTF-8';
/*リキャプチャ*/
.grecaptcha-badge {
  display: none !important;
}
.reCAPTCHA_p {
  text-align: center;
  line-height: 1.5;
  font-size: 0.8rem;
  margin: 2rem 0 0;
  color: #b1b1b1;
}
.reCAPTCHA_p a {
  color: #b1b1b1;
  text-decoration: underline;
}
/*ふわっと表示*/
.fade-up {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease, transform 0.6s ease;
}
.fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}
/* 404
--------------------------- */
.p404_txt {
  margin-bottom: 0;
  margin-top: 1rem;
}
/* 各メディアごとのマージン設定
--------------------------- */
/* 768px以上用の記述 */
@media screen and (min-width: 768px) {
  .col-md-m20-bottom {
    margin-bottom: 20px;
  }
  .col-md-none {
    display: none;
  }
}
/* 991px以下用の記述 */
@media screen and (max-width: 991px) {
  .col-md-m40-bottom {
    margin-bottom: 40px;
  }
}
/* 991px以下用の記述 */
@media screen and (max-width: 991px) {
  .col-md-m40-bottom {
    margin-bottom: 40px;
  }
}
/* 767px以下用の記述 */
@media screen and (max-width: 767px) {
  .col-sm-m20-bottom {
    margin-bottom: 20px;
  }
  .col-sm-none {
    display: none;
  }
}
/* 576px以下用の記述 */
@media screen and (max-width: 576px) {
  .col-xs-m40-bottom {
    margin-bottom: 40px;
  }
  .col-xs-m20-bottom {
    margin-bottom: 20px;
  }
  .col-xs-none {
    display: none;
  }
}
/*テキストカラー*/
.txt505050 {
  color: #505050;
}
/*******************************
PC/SP切り替え
*******************************/
.pc-none {
  display: block;
}
.sp-none {
  display: none;
}
@media screen and (min-width: 768px) {
  .pc-none {
    display: none;
  }
  .sp-none {
    display: block;
  }
}
/*******************************
container
*******************************/
.container_1300, .container_1400, .container_1500, .container_1600, .container_960, .container_800, .container_1560 {
  width: 90%;
  margin-right: auto;
  margin-left: auto;
}
.container_800 {
  max-width: 800px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .container_1300 {
    width: 76.47%;
  }
  .container_1400 {
    width: 82.35%;
  }
  .container_1500 {
    width: 88.23%;
  }
  .container_1600 {
    width: 94.11%;
  }
  .container_960, .container_800 {
    width: 82.35%;
  }
  .container_1560 {
    width: 91.76%;
  }
}
@media screen and (min-width: 992px) {
  .container_960 {
    width: 66.66%;
  }
  .container_800 {
    width: 60%;
  }
}
@media screen and (min-width: 1400px) {
  .container_960, .container_800 {
    width: 53.33%;
  }
}
/*******************************
見出し
*******************************/
/* c-title1 */
.c-title1 {
  font-size: 0.92rem;
  margin-bottom: 2.51rem;
}
.c-title1 .f-eng {
  display: block;
  font-size: 2.33rem;
  font-weight: 400;
  margin-bottom: 0.88rem;
}
@media screen and (min-width: 768px) {
  .c-title1 {
    margin-bottom: 3.15rem;
  }
}
@media screen and (min-width: 992px) {
  .c-title1 {
    margin-bottom: 3.79rem;
  }
}
@media screen and (min-width: 1200px) {
  .c-title1 {
    font-size: 0.86rem;
    margin-bottom: 4.43rem;
  }
  .c-title1 .f-eng {
    margin-bottom: 0.93rem;
  }
}
/*******************************
text
*******************************/
.txt_block p {
  margin-bottom: 0;
}
/*******************************
TOP BUTTON
*******************************/
/* vm */
.vm {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 258px;
  height: 60px;
  border: 1px solid #c8c8c8;
  border-radius: 70px;
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  color: #000;
  overflow: hidden;
  text-decoration: none;
  transition: color 0.4s ease;
}
.vm::before {
  content: "";
  position: absolute;
  right: 17px;
  width: 30px;
  height: 30px;
  background: #bce2e8;
  border-radius: 50%;
  z-index: 0;
  transform: scale(1);
  transition: transform 0.6s ease;
}
.vm:hover::before {
  transform: scale(15); /* 拡大率を調整 */
}
.vm .vm_txt {
  position: relative;
  z-index: 1;
}
.vm .arrow {
  position: absolute;
  z-index: 1;
  width: 30px;
  height: 30px;
  background: #bce2e8;
  border-radius: 50%;
  top: 50%;
  right: 17px;
  transform: translateY(-50%);
  transition: background 0.3s ease;
}
.vm .arrow::after {
  position: absolute;
  content: "";
  width: 9px;
  height: 7px;
  background-image: url("../images/arrow_w.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: .3s;
}
.vm:hover {
  color: #fff;
  text-decoration: none;
}
.vm:hover .arrow {
  background: transparent;
}
.vm:hover .arrow::after {
  left: calc(50% + 10px);
}
@media screen and (min-width: 1200px) {
  .vm {
    width: 300px;
    height: 70px;
    font-size: 0.93rem;
  }
  .vm::before {
    width: 35px;
    height: 35px;
    right: 20px;
  }
  .vm .arrow {
    width: 35px;
    height: 35px;
    right: 20px;
  }
  .vm .arrow::after {
    width: 10px;
    height: 8px;
  }
}
/* vm2 */
.vm2 {
  display: inline-flex;
  align-items: center;
  color: #000;
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  transition: .3s;
}
.vm2 .arrow {
  position: relative;
  width: 30px;
  height: 30px;
  background: #bce2e8;
  border-radius: 50%;
  margin-left: 15px;
}
.vm2 .arrow::after {
  position: absolute;
  content: "";
  width: 9px;
  height: 7px;
  background-image: url("../images/arrow_w.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.vm2:hover {
  color: #000;
  text-decoration: none;
  opacity: 0.7;
}
@media screen and (min-width: 1200px) {
  .vm2 {
    font-size: 0.93rem;
  }
  .vm2 .arrow {
    width: 35px;
    height: 35px;
    margin-left: 20px;
  }
  .vm2 .arrow::after {
    width: 10px;
    height: 8px;
  }
}
/*******************************
パンクズ
*******************************/
#pls {
  padding-top: 5.84rem;
  margin-bottom: -3.5rem;
}
#pan {
  font-size: 0.8rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  color: #8c8c8c;
  line-height: 1.5;
  letter-spacing: 0.03rem;
}
#pan a {
  color: #8c8c8c;
  text-decoration: none;
}
#pan .current-item {
  color: #505050;
}
.pan_line {
  position: relative;
  width: 10px;
  display: block;
  margin: 0 7px;
  height: 5px;
}
.pan_line::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  display: block;
  background-color: #8c8c8c;
  top: 2px;
  left: 0;
  transform: rotate(-55deg);
}
@media screen and (min-width: 768px) {
  #pls {
    width: 91.76%;
    padding-top: 7.27rem;
    margin-bottom: -4rem;
  }
  #pan {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
  }
  .pan_line::after {
    top: 2px;
  }
}
@media screen and (min-width: 992px) {
  #pls {
    padding-top: 8.7rem;
  }
}
@media screen and (min-width: 1400px) {
  #pls {
    padding-top: 10.13rem;
    margin-bottom: -6rem;
  }
}
/*******************************
/* フォーム/テーブル
*******************************/
.wpcf7-submit {
  font-size: 1.2em;
  background-color: #000;
  color: #fff;
  border-style: none;
  width: 60%;
  margin-bottom: 30px;
  padding-top: 15px;
  padding-right: 40px;
  padding-bottom: 15px;
  padding-left: 40px;
}
#form {
  max-width: 100%;
}
#form th span {
  font-size: 0.8em;
  color: #FFF;
  background-color: #C00;
  padding: 3px;
}
#form th, #form td {
  font-size: 1rem;
  line-height: 1.7;
  letter-spacing: 0.05em;
  padding: 40px 0;
  border-bottom: 1px solid #c8c8c8;
  color: #000;
  font-weight: 500;
}
#form tr:first-child th, #form tr:first-child td {
  border-top: 1px solid #c8c8c8;
}
#form th {
  width: 30%;
}
#form td {
  text-align: left;
  color: #505050;
}
#form2 {
  max-width: 100%;
  margin-bottom: 40px;
  background-color: #FFF;
}
#form2 th span {
  font-size: 0.8em;
  color: #FFF;
  background-color: #C00;
  padding: 3px;
}
#form2 th {
  padding: 10px;
  width: 30%;
  border-bottom: 1px solid #1a1a1a;
  text-align: center;
}
#form2 td {
  padding: 10px;
  border-bottom: 1px solid #eee;
  vertical-align: middle;
  font-weight: normal;
  text-align: center;
}
#form3 {
  max-width: 100%;
  margin-bottom: 40px;
  background-color: #FFF;
}
#form3 tr {
  border-bottom: 1px dotted #bfbfbf;
  margin-bottom: 3rem;
  padding-bottom: 2rem;
  display: flex;
}
#form3 th {
  width: 150px;
  color: #FFF;
  text-align: center;
  padding-top: 10px;
}
#form3 th span {
  background-color: #808080;
  display: inline-block;
  width: 150px;
}
#form3 td {
  padding: 10px;
  vertical-align: middle;
  font-weight: normal;
  padding-left: 4rem;
}
#form3 td .tel_txt1 {
  font-size: 1.2rem;
  margin-bottom: 0;
}
#form3 td .tel_txt2 {
  font-size: 2.4rem;
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1;
  display: block;
}
/* テキストエリアの設定 */
input[type="text"], input[type="email"], input[type="tel"], textarea, select {
  width: 100%;
  color: #000;
  padding: 10px 0 10px 10px;
  margin: 10px 0;
}
input[type="text"]:focus, input[type="email"]:focus, input[type="tel"]:focus, textarea:focus, select:focus {
  background-color: #fff;
}
@media only screen and (max-width:479px) {
  /* 479px以下用（スマートフォン用）の記述 */
  #form {
    max-width: 100%;
  }
  #form th {
    width: 100%;
    display: block;
    border-top: none;
    padding: 16px 0 0;
    border-bottom: none;
  }
  #form tr:first-child td {
    border-top: none;
  }
  #form td {
    width: 100%;
    display: block;
    border-top: none;
    padding: 5px 0 15px;
  }
  #form2 {
    max-width: 100%;
    margin-bottom: 40px;
  }
  #form2 th {
    width: 50%;
    border-top: none;
    text-align: center;
  }
  #form2 td {
    width: 100%;
    display: block;
    border-top: none;
    text-align: center;
  }
  #form3 {
    max-width: 100%;
    margin-bottom: 40px;
  }
  #form3 tr {
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    flex-direction: column;
  }
  #form3 th {
    width: 50%;
    display: block;
    border-top: none;
  }
  #form3 td {
    width: 100%;
    display: block;
    border-top: none;
    margin-bottom: 0;
    padding-left: 10px;
  }
  #form3 tr:first-child th {
    /*	border-top: 1px solid #ddd;*/
  }
  /* テキストエリアの設定 */
  input[type="text"], input[type="email"], input[type="tel"], textarea, select {
    width: 100%;
    padding: 10px 0px 0px 0px;
    margin: 10px 0;
  }
  .wpcf7-submit {
    font-size: 1.2em;
    border-style: none;
    width: 100%;
    padding-top: 15px;
    padding-bottom: 15px;
  }
}
/*--------------------------------------
archiveページャー
--------------------------------------*/
.pagenation {
  text-align: center;
}
.pagenation ul {
  margin: 0;
  display: flex;
  justify-content: center;
  margin-top: 4.5rem;
}
.archive_works_con .pagenation ul {
  margin-top: 3rem;
}
.pagenation li {
  list-style: none outside none;
}
.pagenation li.pn-first {
  margin-left: 0;
}
.pagenation li.pn-last {
  margin-right: 0;
}
.pagenation li.active {
  color: #000;
  cursor: not-allowed;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 0.8rem;
  padding-left: 0.8rem;
  text-decoration: underline;
  text-underline-offset: 0.4rem;
}
.pagenation li a {
  position: relative;
  text-decoration: none;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #8c8c8c;
  padding-right: 0.8rem;
  padding-left: 0.8rem;
}
.pagenation li a:hover {
  text-decoration: none;
  opacity: 0.8;
  transition-duration: 500ms;
  transition-property: all;
  transition-timing-function: ease;
}
.pagenation li.prev a, .pagenation li.next a {
  display: none;
}
.pagenation li.ellipsis {
  color: #999;
  padding-right: 0.65rem;
  padding-left: 0.65rem;
}
.info_page_container .pagenation ul {
  margin-top: 3rem;
}
.pagenation li {
  font-size: 1.05rem;
}
@media screen and (min-width: 768px) {
  .archive_blog_con .pagenation ul, .archive_event_con .pagenation ul, .archive_voice_con .pagenation ul, .archive_works_con .pagenation ul, .archive_youtube_con .pagenation ul {
    margin-top: 1.5rem;
  }
}
@media screen and (min-width: 1400px) {
  .pagenation li.active, .pagenation li a, .pagenation li.ellipsis {
    padding-right: 1rem;
    padding-left: 1rem;
  }
  .pagenation ul {
    margin-top: 6rem;
  }
  .archive_blog_con .pagenation ul, .archive_event_con .pagenation ul, .archive_voice_con .pagenation ul, .archive_works_con .pagenation ul, .archive_youtube_con .pagenation ul {
    margin-top: 2.875rem;
  }
}
/*******************************
/* single.php　アイキャッチ
***************************/
.sgl {
  margin-bottom: 30px;
  text-align: center;
}
/*************************
/* single.php 日付
*************************/
#date span {
  color: #878787;
  font-size: 1rem;
  font-family: "Poppins", sans-serif;
  letter-spacing: 0;
}
/* single.php ページ送り
----------------------------------------------------------------------------------------------------*/
#next {
  background-color: #efefef;
  padding: 10px;
  margin-top: 30px;
}
.nx_left {
  width: 100%;
  text-align: left;
}
.nx_left a {
  background-color: #FFF;
  color: #000;
  text-decoration: none;
  display: block;
  padding-top: 10px;
  padding-bottom: 10px;
  background-image: url(../images/left.png);
  background-repeat: no-repeat;
  background-position: left center;
  padding-left: 35px;
}
.nx_left a:hover {
  background-color: #828282;
  color: #FFF;
  text-decoration: none;
  display: block;
  padding-top: 10px;
  padding-bottom: 10px;
  background-image: url(../images/left2.png);
  background-repeat: no-repeat;
  background-position: left center;
}
.nx_right {
  width: 100%;
  text-align: right;
}
.nx_right a {
  background-color: #FFF;
  color: #000;
  text-decoration: none;
  display: block;
  padding-top: 10px;
  padding-bottom: 10px;
  background-image: url(../images/right.png);
  background-repeat: no-repeat;
  background-position: right center;
  padding-right: 35px;
}
.nx_right a:hover {
  background-color: #828282;
  color: #FFF;
  text-decoration: none;
  display: block;
  padding-top: 10px;
  padding-bottom: 10px;
  background-image: url(../images/right2.png);
  background-repeat: no-repeat;
  background-position: right center;
}
/*--------------------------------
PREV NEXT
---------------------------------*/
#prev_next {
  width: 100%;
  margin: 36px 0 24px;
  padding: 0;
  display: table;
}
#prev_next #prev, #prev_next #next {
  width: 50%;
  padding: 30px 10px 10px;
  border-top: #000 1px solid;
  border-bottom: #000 1px solid;
  display: table-cell;
  position: relative;
  text-decoration: none;
}
#prev_next #next {
  text-align: right;
}
#prev_next #prev p, #prev_next #next p {
  font-size: 90%;
  line-height: 1.5;
  margin-top: 0.5rem;
  color: #000;
}
#prev_next #prev:hover, #prev_next #next:hover {
  background-color: #f7f7f5;
}
#prev_next #prev {
  border-right: #000 1px solid;
}
#prev_next #prev_title, #prev_next #next_title {
  font-size: 90%;
  top: -1em;
  position: absolute;
  border: 1px #000 solid;
  background: #fff;
  text-align: center;
  padding: 3px;
  color: #000;
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
}
#prev_next #next_title {
  right: 10px;
}
#prev_next #prev img, #prev_next #next img {
  margin: 0 auto;
  width: auto;
}
#prev_next #prev_no, #prev_next #next_no {
  width: 50%;
  height: 140px;
  padding: 0 10px;
  display: table-cell;
}
#prev_next #prev_no {
  border-right: #000 1px solid;
}
#prev_next_home {
  margin: 0 auto;
  background-color: #000;
  border: solid 9px #fff;
  width: 100px;
  height: 100px;
  border-radius: 100px;
  box-shadow: 0 0 0 3px #000;
  -webkit-box-shadow: 0 0 0 3px #000;
  -moz-box-shadow: 0 0 0 3px #000;
  text-align: center;
}
#prev_next_home:hover {
  opacity: 0.7;
}
#prev_next_home i {
  color: #FFF;
  margin: 10px auto;
  font-size: 60px;
}
@media screen and (min-width: 768px) {
  #prev_next #prev, #prev_next #next {
    padding: 40px 10px 20px;
  }
}
/*media Queries PCサイズ
----------------------------------------------------*/
@media only screen and (min-width: 780px) {
  /*-- ここから --*/
  /*--------------------------------------
768px PREV NEXT
--------------------------------------*/
  #prev_next #prev, #prev_next #prev::before, #prev_next #prev::after, #prev_next #next, #prev_next #next::before, #prev_next #next::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
  #prev_next #prev_title, #prev_next #next_title {
    padding: 3px 10px;
  }
  #prev_next #next_title {
    right: 10px;
  }
  #prev_next #prev img {
    float: left;
    margin-right: 10px
  }
  #prev_next #next img {
    float: right;
    margin-left: 10px;
  }
  /*-- ここまで --*/
}
/*************
/* 投稿ギャラリー
*************/
.wp-caption-text {
  font-size: 12px;
  color: #999999;
  text-align: center;
}
.gallery {
  margin: 0 -5px;
  display: flex;
  flex-wrap: wrap;
}
.gallery .gallery-item {
  float: left;
  text-align: center;
  width: 25%;
  padding: 5px;
  margin: 0;
}
.gallery .gallery-caption {
  margin-left: 0;
  margin-bottom: 35px;
  padding-right: 20px;
  padding-left: 20px;
}
.gallery-columns-4 br {
  display: none;
}
.gallery-columns-4 {
  display: flex;
  flex-wrap: wrap;
}
.gallery.gallery-columns-2 .gallery-item {
  width: 50%;
}
.gallery.gallery-columns-3 .gallery-item {
  width: 33.33%;
}
.gallery.gallery-columns-4 .gallery-item {
  width: 25%;
}
@media screen and (max-width: 640px) {
  #gallery-1 {
    display: flex;
    flex-wrap: wrap;
  }
  .gallery .gallery-item {
    float: none;
    width: 100%;
  }
  .gallery.gallery-columns-2 .gallery-item, .gallery.gallery-columns-3 .gallery-item {
    width: 100%;
  }
  .gallery.gallery-columns-4 .gallery-item {
    float: left;
    width: 50%;
  }
}
/*******************************
/* youtube　gmapレスポンシブ対応
***************************/
.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
.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%;
}
/*******************************
/* レスポンシブ改行
***************************/
@media screen and (min-width: 576px) {
  .br-pc {
    display: block;
  }
  .br-sp {
    display: none;
  }
}
@media screen and (max-width: 567px) {
  .br-pc {
    display: none;
  }
  .br-sp {
    display: block;
  }
}
.br_768-991 {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .br_768-991 {
    display: block;
  }
}
/*****************************
/* form_customize
*****************************/
.form_intro {
  margin-bottom: 2.3rem;
  text-align: left;
}
.form_intro p {
  font-size: 0.9375rem;
  letter-spacing: 0.05em;
  line-height: 1.8;
  color: #000000;
  margin-bottom: 0;
}
.datetime-none {
  font-size: 0.85rem;
  margin: 0.4rem 0 0;
}
.form_intro p + p {
  margin-top: 0.6rem;
}
.form_intro p span {
  font-weight: bold;
  color: #bce2e8;
  margin-right: 0.2rem;
}
#form_customize input, #form_customize select, #form_customize textarea, #form_customize input[type="date"] {
  background-color: #f5f5f5;
  border: none;
  padding: 1.17rem 1rem;
  font-size: 1rem;
  margin: 0;
  width: 100%;
  border-radius: 0;
  line-height: 1.7;
  letter-spacing: 0.05em;
  outline: none;
  resize: none;
}
#form_customize input[type="text"], #form_customize input[type="email"], #form_customize input[type="tel"], #form_customize textarea, #form_customize select {
  color: #000;
}
#form_customize input:focus, #form_customize select:focus, #form_customize textarea:focus {
  outline: none;
}
#form_customize .form_block {
  margin-bottom: 17px;
}
#form_customize .form_block.mb0 {
  margin-bottom: 0;
}
/* プレースホルダー */
#form_customize .wpcf7-form-control::placeholder {
  color: #d1d1d1;
  opacity: 1;
}
/* ラベル */
#form_customize .form_c_label {
  display: flex;
  align-items: center;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.03rem;
  margin-bottom: 0.5rem;
  line-height: 1.9;
  color: #000000;
}
/* 必須 */
.form_label_req {
  color: #bce2e8;
  letter-spacing: 0.1em;
  margin-left: 3px;
}
/* 入力してください */
#form_customize .wpcf7-not-valid-tip {
  font-size: 0.88rem;
  color: #c31a00;
}
/* 個人情報 */
#form_customize .form_c_agree {
  border-bottom: none;
  margin-top: 1.5rem;
  margin-bottom: 2.7rem;
  text-align: center;
}
#form_customize .form_c_agree .form_check_box {
  margin-bottom: 0.86rem;
}
#form_customize .form_c_agree .form_check_box .wpcf7-list-item {
  width: 100%;
}
.f_note {
  font-size: 0.93rem;
  line-height: 1.6;
  letter-spacing: 0.05em;
  margin-bottom: 1rem;
  color: #505050;
}
.f_note a {
  color: #505050;
  text-decoration: underline;
  transition: .3s;
  text-decoration-color: #505050;
}
.f_note a:hover {
  opacity: 0.7;
  transition: .3s;
}
/* 送信ボタン */
#form_customize .form_c_submit {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
  position: relative;
  text-align: center;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}
#form_customize .form_c_submit input {
  width: 100%;
  width: 270px;
  height: 60px;
  font-size: 1.1rem;
  font-weight: 400;
  border: 1px solid #000000;
  background-color: #000000;
  color: #fff;
  line-height: 60px;
  border-radius: 80px;
  margin-bottom: 0;
  padding: 0;
  transition: .3s;
}
#form_customize .form_c_submit input:hover {
  background-color: #fff;
  color: #000;
  transition: .3s;
}
#form_customize .form_c_submit .wpcf7-spinner {
  position: absolute;
  margin: 0;
  top: 0;
  left: calc((50% + 100px) + 30px);
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .form_intro {
    margin-bottom: 3.75rem;
  }
  .form_intro p {
    text-align: center;
  }
  #form_customize .form_block {
    margin-bottom: 3rem;
    margin-top: 2.5rem;
  }
  /* 入力欄 */
  #form_customize input, #form_customize select, #form_customize textarea, #form_customize input[type="date"] {
    padding: 1.55rem 1.5rem;
  }
  /* 入力欄 */
  #form_customize .form_c_item {
    margin-top: 0;
    margin-left: auto;
    text-align: left;
  }
  /* 個人情報 */
  #form_customize .form_c_agree .form_check_box .wpcf7-form-control {
    justify-content: flex-start;
  }
  #form_customize .form_c_agree .form_check_box .wpcf7-list-item {
    margin-right: 0;
  }
  /* 送信ボタン */
  #form_customize .form_block.form_c_submit {
    width: 100%;
    margin-right: 0;
    margin-bottom: 0;
    padding-bottom: 0;
  }
  #form_customize .form_c_submit input {
    width: 300px;
    height: 70px;
    line-height: 70px;
  }
}
@media screen and (min-width: 992px) {
  /* 個人情報 */
  #form_customize .form_block.form_c_agree {
    margin-bottom: 3.4rem;
    margin-top: 3.1rem;
  }
  /* 送信ボタン */
  #form_customize .form_c_submit {
    padding-bottom: 0;
  }
}
@media screen and (min-width: 1200px) {
  #form_customize input, #form_customize select, #form_customize textarea, #form_customize input[type="date"] {
    padding: 1.66rem 2rem;
  }
  /* ラベル */
  #form_customize .form_c_label {
    font-size: 1.06rem;
    margin-bottom: 0.83rem;
  }
}
/* CUSTOM SELECTBOX */
#form_customize select {
  color: #595757;
  -webkit-appearance: none;
  appearance: none;
}
#form_customize select.selected {
  color: #595757;
}
/* CUSTOM CHECKBOX */
#form_customize .form_check_box .wpcf7-form-control {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: -0.5rem;
}
#form_customize .form_check_box .wpcf7-list-item {
  display: inline-block;
  width: auto;
  margin: 0 1.5rem 0.5rem 0;
}
#form_customize .form_check_box label {
  cursor: pointer;
  margin-bottom: 0;
}
#form_customize .form_check_box input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}
#form_customize .form_check_box .wpcf7-list-item-label {
  position: relative;
  display: flex;
  align-items: center;
  margin-bottom: 0;
  font-size: 1rem;
  color: #000;
  letter-spacing: 0.05em;
  line-height: 1.9;
}
#form_customize .form_check_box .wpcf7-list-item-label::before, #form_customize .form_check_box .wpcf7-list-item-label::after {
  content: "";
  border-radius: inherit;
  transition: .2s;
}
#form_customize .form_check_box .wpcf7-list-item-label::before {
  left: 0;
  display: block;
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  margin-right: 10px;
  background-color: #f5f5f5;
  border: none;
}
.bk_g #form_customize .form_check_box .wpcf7-list-item-label::before {
  background-color: #fff;
}
#form_customize .form_check_box .wpcf7-list-item-label::after {
  position: absolute;
  left: 14px;
  width: 12px;
  height: 12px;
  background-color: #000;
  opacity: 0;
}
#form_customize .form_check_box input:checked ~ .wpcf7-list-item-label::after {
  opacity: 1;
}
@media screen and (min-width: 768px) {
  #form_customize .form_check_box .wpcf7-list-item-label::before {
    width: 35px;
    height: 35px;
    min-width: 35px;
    min-height: 35px;
  }
  #form_customize .form_check_box .wpcf7-list-item-label::after {
    top: 11px;
    left: 12px;
    width: 12px;
    height: 12px;
  }
  #form_customize .form_check_box .wpcf7-list-item {
    width: auto;
    margin-right: 2.3rem;
  }
}
@media screen and (min-width: 992px) {
  #form_customize .form_check_box .wpcf7-form-control-wrap {
    width: 100%;
  }
}
@media screen and (min-width: 1200px) {
  #form_customize .form_check_box .wpcf7-list-item-label {
    font-size: 1.06rem;
  }
}
/* CUSTOM RADIO */
#form_customize .form_check_box.radio .wpcf7-list-item-label::before {
  border-radius: 50%;
}
#form_customize .form_check_box.radio .wpcf7-list-item-label::after {
  border-radius: 50%;
}
/* 来場希望日時 */
#form_customize .datetime {
  display: flex;
  justify-content: space-between;
}
#form_customize .datetime .select_item {
  width: calc((100% - 7px)/2);
}
#form_customize .datetime select {
  padding: 1.17rem 1rem;
  -webkit-padding-start: 1.17rem 1rem;
  padding-start: 1.17rem 1rem;
  font-size: 1rem;
  -webkit-appearance: none;
  appearance: none;
  color: #d1d1d1;
}
#form_customize .datetime select option {
  color: #000 !important;
}
#form_customize .datetime select.selected {
  color: #000;
}
@media screen and (min-width: 768px) {
  #form_customize .datetime .select_item {
    width: calc((100% - 15px) / 2);
  }
  #form_customize .datetime select {
    padding: 1.55rem 1.5rem;
  }
}
@media screen and (min-width: 992px) {
  #form_customize .datetime .select_item {
    width: calc((100% - 20px)/2);
  }
  #form_customize .datetime select {
    padding: 1.55rem 1.5rem;
  }
}
@media screen and (min-width: 1200px) {
  #form_customize .datetime select {
    padding: 1.66rem 2rem;
  }
}
/* 住所 */
#form_customize .add .form-input__small300 {
  width: 50%;
  margin-bottom: 7px;
}
#form_customize #autozip {
  display: none;
}
@media screen and (min-width: 1200px) {
  #form_customize .add .form-input__small300 {
    margin-bottom: 14px;
  }
}
/* 2column */
.form_column:first-child {
  margin-bottom: 17px;
}
@media screen and (min-width: 768px) {
  .form_column2 {
    display: flex;
    justify-content: space-between;
  }
  .form_column {
    width: calc((100% - 15px)/2);
  }
  .form_column:first-child {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 992px) {
  .form_column {
    width: calc((100% - 20px)/2);
  }
}
/* 資料請求 */
#form_customize .form_block.catalog {
  margin-bottom: 32px;
}
#form_customize .catalog_list {
  margin-bottom: 0;
}
#form_customize .catalog_list li {
  list-style: none;
}
#form_customize .catalog_list .form_check_box .wpcf7-list-item {
  text-align: center;
}
#form_customize .catalog_list .form_check_box label {
  margin: 0;
  display: block;
}
#form_customize .catalog_list .form_check_box input {
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
  display: none;
}
#form_customize .catalog_list .form_check_box .wpcf7-list-item-label {
  position: relative;
  display: inline-block;
  align-items: center;
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0;
  width: 183px;
  height: 43px;
  color: #fff;
  text-align: center;
  border-radius: 4px;
  margin: 0;
}
#form_customize .catalog_list .form_check_box .wpcf7-list-item-label::before {
  content: "資料を選択";
  position: absolute;
  background-color: #f9f1e7;
  color: #f84519;
  border: 1px solid rgba(248, 69, 25, 0.4);
  height: 43px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  border-radius: 50px;
  top: 0;
  font-weight: 400;
  left: 0;
  width: 100%;
  transition: .3s;
}
#form_customize .catalog_list .form_check_box .wpcf7-list-item-label::after {
  position: absolute;
  top: 0;
  height: 43px;
  opacity: 0;
  background-color: #f84519;
  content: "選択中";
  font-size: 0.9rem;
  font-weight: 400;
  color: #f9f1e7;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
  left: 0;
  width: 100%;
  transition: .3s;
}
#form_customize .form_block.catalog .wpcf7-not-valid-tip {
  text-align: center;
}
@media screen and (min-width: 768px) {
  #form_customize .catalog_list {
    display: flex;
  }
  #form_customize .catalog_list li {
    width: 50%;
  }
  #form_customize .catalog_list .form_check_box .wpcf7-list-item {
    margin-right: auto;
    margin-left: auto;
  }
}
@media screen and (min-width: 992px) {
  #form_customize .form_block.catalog {
    margin-bottom: 42px;
  }
}
@media screen and (min-width: 1200px) {
  #form_customize .catalog_list .form_check_box .wpcf7-list-item-label::before, #form_customize .catalog_list .form_check_box .wpcf7-list-item-label::after {
    font-size: 0.8rem;
  }
}
/* 面接希望日 */
.date_block:first-child {
  margin-bottom: 12px;
}
.date_block p {
  font-size: 0.94rem;
  letter-spacing: 0.05em;
  margin-bottom: 5px;
  line-height: 1.9;
  color: #000;
}
.date_content {
  position: relative;
  width: 100%;
  height: 55px;
  display: block;
}
.date_content.mb {
  margin-bottom: 7px;
}
.wpcf7-date-placeholder {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  transition: opacity 0.2s;
  width: 100%;
  height: 55px;
  display: flex;
  top: 0;
  left: 0;
  background-color: #fff;
  color: #595757;
  line-height: 1.9;
  letter-spacing: 0.05em;
  outline: none;
  resize: none;
  border: none;
  border-radius: 0.66rem;
  padding: 1.17rem 1rem;
  font-size: 1rem;
  align-items: center;
}
input[type="date"]:focus + .wpcf7-date-placeholder {
  opacity: 0;
}
.date_content .wpcf7-form-control-wrap {
  width: 100%;
  display: block;
}
.date_sample {
  width: 100%;
  color: #989898;
}
#form_customize input[type="date"] {
  min-width: 0; /* 必要に応じて最小幅を解除 */
  width: 100% !important;
  -webkit-appearance: none;
  appearance: none;
}
#form_customize input[type="date"]::-webkit-date-and-time-value {
  text-align: left;
}
#form_customize .date_block input[type="date"], #form_customize .date_block select {
  height: 55px;
}
@media screen and (min-width: 768px) {
  #form_customize .date_item {
    padding-top: 1.15rem;
  }
  #form_customize .date_sample {
    margin-bottom: 0;
  }
  .date_block {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .date_block p {
    width: 100%;
  }
  .date_content {
    width: calc((100% - 15px)/2);
    height: 59px;
  }
  .wpcf7-date-placeholder {
    height: 59px;
    padding: 1.3rem 1.5rem;
  }
  #form_customize input[type="date"] {
    margin-bottom: 0;
  }
  .date_content.mb {
    margin-bottom: 0;
  }
  #form_customize .date_block input[type="date"], #form_customize .date_block select {
    height: 65px;
  }
}
@media screen and (min-width: 992px) {
  .date_content {
    width: calc((100% - 20px)/2);
  }
}
@media screen and (min-width: 1200px) {
  .date_content {
    height: 80px;
  }
  .wpcf7-date-placeholder {
    height: 80px;
    font-size: 1rem;
  }
  #form_customize .date_block input[type="date"], #form_customize .date_block select {
    height: 80px;
  }
  .wpcf7-date-placeholder {
    padding: 1.66rem 2rem;
  }
}
/* ============================ */
/* POST INDEX */
.c-post-index {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 4rem;
  padding-top: 2.5rem;
  border-top: 1px solid #c8c8c8;
}
.c-post-index__link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  transition: .3s;
  position: relative;
  background: #000;
  width: 40px;
  height: 28px;
  border-radius: 50px;
  justify-content: center;
  align-items: center;
}
.c-post-index__link img {
  display: block;
  width: 12px;
  opacity: 1;
  transition: .3s;
}
.c-post-index__link.link-prev img {
  -webkit-transform: rotateY(180deg);
  transform: rotateY(180deg);
  width: 12px;
}
.c-post-index__link::before {
  position: absolute;
  content: "";
  background-image: url("../images/arrow.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 100%;
  display: block;
  opacity: 0;
}
.c-post-index__link.link-prev::before {
  -webkit-transform: rotateY(180deg);
  transform: rotateY(180deg);
}
.c-post-index__link:hover img {
  opacity: 1;
}
.c-post-index__link:hover::before {
  opacity: 1;
}
a.is-disable {
  opacity: 0.3;
  pointer-events: none;
}
.c-post-index__link:hover {
  text-decoration: none;
  opacity: 1;
  transition: .3s;
}
.c-post-index__text {
  line-height: 1;
  text-align: center;
  color: #000;
  font-size: 1.1rem;
  text-decoration-line: none;
}
.c-post-index__text:hover {
  opacity: 1;
  color: #e31e23;
  text-decoration-line: none;
  transition: .3s;
}
.c-post-index--tab {
  display: none;
}
.c-post-index a {
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
  color: #000;
  font-size: 0.9rem;
}
.c-post-index a.link-next-a {
  flex-direction: row;
}
.c-post-index a.link-prev-a .mb-0 {
  margin-left: 1rem;
}
.c-post-index a.link-next-a .mb-0 {
  margin-right: 1rem;
}
.c-post-index a:hover {
  text-decoration: none;
  opacity: 1;
  color: #000;
}
@media screen and (min-width: 768px) {
  .c-post-index {
    margin-top: 7.5rem;
    padding-top: 3.75rem;
  }
}
@media screen and (min-width: 1200px) {
  .c-post-index__text {
    font-size: 1rem;
  }
  .c-post-index__link {
    font-size: 1rem;
  }
}
/**************************
/* 404
**************************/
@media screen and (min-width: 768px) {
  .block404 {
    text-align: center;
  }
}
/**************************
/* works一覧
**************************/
.works_block {
  margin-bottom: 0;
  display: flex;
  flex-wrap: wrap;
}
.works_block li {
  list-style: none;
  width: calc((100% - 20px)/2);
  margin-top: 2.29rem;
  margin-right: 20px;
}
.works_block li:first-child, .works_block li:nth-child(2) {
  margin-top: 0;
}
.works_block li:nth-child(2n) {
  margin-right: 0;
}
.works_block li a {
  display: block;
}
.works_block li a:hover {
  text-decoration: none;
}
.works_block .zoom {
  margin-bottom: 1.09rem;
  aspect-ratio: 1 / 0.72;
}
.works_block a .zoom img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.works_tit {
  font-size: 1rem;
  color: #000;
  letter-spacing: 0.06em;
  line-height: 1.3;
  margin-bottom: 0.45rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.works_menseki {
  font-size: 0.76rem;
  color: #8c8c8c;
  margin-bottom: 0;
}
.works_menseki span.slash {
  display: none;
}
.works_menseki br {
  display: block;
}
.works_block li .works_tags a{
	background-color: #ffffff;
    color: #505050;
    text-decoration: none;
    font-size: 0.84rem;
    display: inline-block;
    padding: 2px 10px;
    border: 1px solid #c8c8c8;
    transition: .3s;
	margin: 2px 5px 2px 0;
}
.works_block li .works_tags a:hover {
    background-color: #c8c8c8;
    color: #fff;
    transition: .3s;
}
.works_block li .works_tags {
        margin: 0.5rem -5px 0 0;
}
@media screen and (min-width: 768px) {
  .works_block li {
    width: calc((100% - 40px)/2);
    margin-right: 40px;
  }
  .works_tit {
    font-size: 1.15rem;
    line-height: 1.5;
  }
  .works_menseki {
    font-size: 0.84rem;
  }
	.works_block li .works_tags {
    margin: 0.8rem -5px 0 0;
}
}
@media screen and (min-width: 992px) {
  .works_block li {
    width: calc((100% - 80px)/3);
  }
  .works_block li:nth-child(3) {
    margin-top: 0;
  }
  .works_block li:nth-child(2n) {
    margin-right: 40px;
  }
  .works_block li:nth-child(3n) {
    margin-right: 0;
  }
}
@media screen and (min-width: 1200px) {
  .works_block .zoom {
    margin-bottom: 1.4rem;
  }
  .works_tit {
    font-size: 1.2rem;
    margin-bottom: 0.866rem;
  }
  .works_menseki {
    font-size: 0.86rem;
  }
	    .works_block li .works_tags a {
        font-size: 0.82rem;
        padding: 4px 10px;
    }
}
@media screen and (min-width: 1400px) {
  .works_block li {
    width: calc((100% - 100px)/3);
    margin-top: 4.16rem;
  }
  .works_block li:nth-child(2n) {
    margin-right: 50px;
  }
  .works_block li:nth-child(3n) {
    margin-right: 0;
  }
}
@media screen and (min-width: 1420px) {
  .works_menseki span.slash {
    display: inline;
  }
  .works_menseki br {
    display: none;
  }
}
/*archiveのみ*/
.archive_works_con .works_block {
  margin: 0 -0.8rem 0;
}
.archive_works_con .works_block li {
  padding: 0 0.8rem;
  width: 50%;
  margin: 0 0 1.5rem;
}
.archive_works_con .detail_accordion {
    margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .archive_works_con .works_block {
    margin: 0 -1.3rem 0;
  }
  .archive_works_con .works_block li {
    padding: 0 1.3rem;
    margin: 0 0 2.5rem;
  }
	.archive_works_con .detail_accordion {
    margin-bottom: 3.75rem;
}
}
@media screen and (min-width: 992px) {
  .archive_works_con .works_block li {
    width: 33.33%;
  }
	.archive_works_con .detail_accordion {
    margin-bottom: 4.05rem;
}
}
@media screen and (min-width: 1400px) {
  .archive_works_con .works_block {
    margin: 0 -1.78rem 0;
  }
  .archive_works_con .works_block li {
    padding: 0 1.78rem;
    margin: 0 0 4rem;
  }
}
/*******************************
WORKS　詳細ページ
*******************************/
.works_main_img {
  margin-bottom: 6px;
  margin-top: 2rem;
}
.works_main_img img{
	width: 100%;
}
.single_works_comment {
    margin: 2.5rem 0 3rem;
}
.single_works_movie {
      margin-top: 4rem;
}
.youtube-inner {
  width: 100%;
  margin: 0 auto;
}
.single_inner .single_works_movie .c-title1 {
        margin-bottom: 2rem;
    }
  .page_works_con .works_menseki span.slash {
    display: inline;
  }
  .page_works_con .works_menseki br {
    display: none;
  }
@media screen and (min-width: 768px) {
  .single_works_movie {
    margin-top: 5rem;
  }
  .works_main_img {
    margin-top: 2.5rem;
  }
	.single_inner .single_works_movie .c-title1 {
        margin-bottom: 3rem;
    }
}
@media screen and (min-width: 992px) {
	    .single_works_movie {
        width: 80%;
        max-width: 960px;
        margin: 5rem auto 0;
    }
	.page_voice_con .single_works_movie{
		width: 100%;
		max-width: unset;
	}
}
@media screen and (min-width: 1400px) {
	  .single_works_movie {
    margin-top: 6.5rem;
  }
  .single_works_comment {
    margin: 2.7rem 0 3.5rem;
  }
  .works_main_img {
    margin-top: 3rem;
  }
	    .single_inner .single_works_movie .c-title1 {
        margin-bottom: 3.2rem;
    }
}
/*タグ*/
.single_works_tag {
    margin: 0.7rem 0 0;
}
.tag-item {
    margin: 2px 5px 2px 0;
}
.tag-item a{
	    background-color: #ffffff;
    color: #505050;
    text-decoration: none;
    font-size: 0.84rem;
    display: inline-block;
    padding: 2px 10px;
    border: 1px solid #c8c8c8;
    transition: .3s;
}
.tag-item a:hover {
    background-color: #c8c8c8;
    color: #fff;
    transition: .3s;
}
@media screen and (min-width: 1200px) {
    .tag-item a {
        font-size: 0.82rem;
        padding: 4px 10px;
    }
}
@media screen and (min-width: 1400px) {
    .single_works_tag {
        margin: 1rem 0 0;
    }
}
/*その他の施工事例*/
.other .works_block li {
    margin-top: 0;
    margin-right: 0;
	padding: 0 1rem;
}
@media screen and (min-width: 768px) {
	.other .works_block li {
    padding: 0 1rem;
    width: 33.33%;
}
	.other .works_block {
    margin: 0 auto 3rem;
    width: calc(91.76% + 2rem);
}
}
@media screen and (min-width: 1400px) {
	.other .works_block li {
    padding: 0 1.78rem;
}
	.other .works_block {
    margin: 0 auto 3rem;
    width: calc(91.76% + 3.56rem);
}
}
/*タイルギャラリー*/
.masonry-gallery {
  display: flex;
  margin: -3px;
  flex-wrap: wrap;
}
.masonry-item {
  width: 33.33%;
  padding: 3px;
}
.masonry-item img {
  width: 100%;
  height: auto;
  display: block;
  transition: .3s;
}
.masonry-item img:hover {
  opacity: 0.8;
  transition: .3s;
}
@media (max-width: 768px) {
  .masonry-item {
    width: 50%;
  }
}
/**************************
/* スタッフ紹介一覧
**************************/
.top_stafftxt .yaku {
  color: #000;
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  margin-bottom: 0.15rem;
}
.top_stafftxt .name {
  color: #000;
  font-size: 1.23rem;
  letter-spacing: 0.06em;
  line-height: 1.9;
  margin-bottom: 0;
}
.top_stafftxt .name .f-eng {
  display: block;
  color: #969696;
  font-size: 0.769rem;
  font-weight: 400;
}
@media screen and (min-width: 1200px) {
  .top_stafftxt .yaku {
    font-size: 0.93rem;
    margin-bottom: 0.23rem;
  }
  .top_stafftxt .name {
    font-size: 1.33rem;
  }
  .top_stafftxt .name .f-eng {
    font-size: 0.8rem;
  }
}
/**************************
/* EVENT一覧 トップ共通
**************************/
.event_block {
  margin-bottom: 0;
}
.event_block > li {
  list-style: none;
  margin-top: 1rem;
}
.event_block > li:first-child {
  margin-top: 0;
}
.event_block > li a {
  display: block;
}
.event_block > li a:hover {
  text-decoration: none;
}
.event_block .zoom {
  position: relative;
  margin-bottom: 1.2rem;
    aspect-ratio: 1 / 1.415;
}
.event_block .zoom img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.event_block .zoom .ev_type {
  position: absolute;
  top: 0;
  left: 0;
  font-size: 0.8rem;
  background-color: #000;
  color: #fff;
  padding: 0.26rem 1.26rem;
}
.ev_tit {
  color: #000;
  font-size: 1.15rem;
  letter-spacing: 0.06em;
  line-height: 1.75;
  margin-bottom: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ev_d {
  position: relative;
  margin-top: 0.42rem;
  padding-top: 0.65rem;
}
.ev_d::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  top: 0;
  left: 0;
  background-color: rgba(200, 200, 200, 0.5);
}
.ev_d ul {
  margin-bottom: 0;
}
.ev_d ul li {
  list-style: none;
  color: #8c8c8c;
  font-size: 0.84rem;
  display: flex;
}
.ev_d ul li .ev_d_tit {
  list-style: none;
  width: 34px;
  text-align: justify;
  text-align-last: justify;
  margin-right: 20px;
  flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .event_block {
    display: flex;
    flex-wrap: wrap;
  }
  .event_block > li {
    width: calc((100% - 30px)/3);
    margin-right: 15px;
  }
  .event_block > li:nth-child(2), .event_block > li:nth-child(3) {
    margin-top: 0;
  }
  .event_block > li:nth-child(3n) {
    margin-right: 0;
  }
}
@media screen and (min-width: 1200px) {
  .event_block > li {
    width: calc((100% - 60px)/3);
    margin-right: 30px;
  }
  .event_block .zoom {
    margin-bottom: 1.5rem;
  }
  .event_block .zoom .ev_type {
    font-size: 0.8rem;
  }
  .ev_d {
    margin-top: 1.1rem;
    padding-top: 1.33rem;
  }
  .ev_d ul li {
    font-size: 0.86rem;
  }
  .ev_d ul li .ev_d_tit {
    width: 41px;
    margin-right: 25px;
  }
  .ev_tit {
    font-size: 1.2rem;
  }
}
/**************************
/* EVENT一覧
**************************/
.archive_event_con .event_block > li {
  margin-bottom: 2.5rem;
  margin-top: 0;
}
/*終了しました表示*/
.event_img {
  position: relative;
}
.event_img_end {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  background-color: rgba(26, 26, 26, 0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  z-index: 9;
}
.event_img_end_txt {
  position: relative;
  z-index: 10;
  color: #fff;
  text-align: center;
  margin-bottom: 0;
  font-size: 1.1rem;
}
@media screen and (min-width: 768px) {
  .archive_event_con .event_block {
    margin: 0 -1.2rem;
  }
  .archive_event_con .event_block > li {
    margin-bottom: 3rem;
    width: 50%;
    margin-right: 0;
    padding: 0 1.2rem;
  }
}
@media screen and (min-width: 992px) {
  .archive_event_con .event_block > li {
    width: 33.33%;
  }
}
@media screen and (min-width: 1400px) {
  .archive_event_con .event_block > li {
    margin-bottom: 4rem;
    width: 25%;
  }
}
/**************************
/* EVENT 詳細
**************************/
h1.single_main_title {
  font-size: 1.3rem;
  margin-bottom: 1rem;
  line-height: 1.7;
}
.event_note {
  display: flex;
  align-items: center;
  margin-bottom: 2rem;
}
.event_note .ev_type {
  font-size: 0.8rem;
  background-color: #000;
  color: #fff;
  padding: 0.26rem 1.26rem;
  display: inline-block;
}
.event_note .event_day, .event_note .event_time {
  margin-bottom: 0;
  margin-left: 1rem;
  color: #8c8c8c;
  font-size: 0.8rem;
}
.event_note .event_time {
  margin-left: 0.3rem;
}
.event_main_img {
  margin-bottom: 4rem;
}
.event_contents_wrap {
  margin-bottom: 5rem;
}
#main2 .ev_contents {
  margin-bottom: 5rem;
  margin-top: 0;
}
#main2 .event_contents_wrap a{
	    color: #408fb6;
}
.event_contents_wrap p{
	    color: #505050;
}
.single_inner .c-title1 .f-eng {
  font-size: 1.9rem;
}
.ev_map {
  margin-top: 2.5rem;
}
#form th.ev-day {
  letter-spacing: 0.55rem;
}
#form th.ev-biko {
  letter-spacing: 2rem;
}
.page_form {
  margin-top: 5rem;
}
.event_main_img img {
  width: 100%;
}
.event_end-txt {
  color: red;
  font-size: 0.85rem;
}
.voice_interview_wrap .item.img-top .unit {
  display: flex;
  flex-direction: column-reverse;
}
.voice_interview_wrap .item.img-top .voice_interview_img {
  margin-top: 0;
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  #main2 .ev_contents {
    margin-bottom: 6.25rem;
  }
  .event_contents_wrap {
    margin-bottom: 6.25rem;
  }
  .page_form {
    margin-top: 6.25rem;
  }
  .event_detail #form th, #form td {
    padding: 20px 0;
  }
  .event_detail #form th {
    width: 25%;
  }
  .event_detail #form td {
    width: 75%;
  }
  .ev_map {
    margin-top: 3.125rem;
  }
  .single_inner .c-title1 {
    margin-bottom: 2.8rem;
  }
  .single_inner .c-title1 .f-eng {
    font-size: 2rem;
  }
  h1.single_main_title {
    font-size: 1.4375rem;
    margin-bottom: 1.05rem;
  }
  .event_note {
    margin-bottom: 3rem;
  }
  .voice_interview_wrap .item.img-top .voice_interview_img {
    margin-bottom: 1.5rem;
  }
}
/********************
/* NEWS
********************/
#top_news {
  width: 100%;
  position: relative;
  padding-top: 4.23rem;
  margin-top: 4.61rem;
}
#top_news::before {
  position: absolute;
  content: "";
  width: 90%;
  height: 1px;
  background-color: rgba(180, 180, 180, 0.5);
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.top_news_inner {
  width: 90%;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  #top_news {
    padding-top: 5.57rem;
    margin-top: 5.74rem;
  }
  #top_news::before {
    width: 94.11%;
  }
  .top_news_inner {
    width: 76.47%;
  }
}
@media screen and (min-width: 992px) {
  #top_news {
    padding-top: 6.91rem;
    margin-top: 6.87rem;
  }
}
@media screen and (min-width: 1200px) {
  #top_news {}
  .top_news_inner {
    display: flex;
    justify-content: space-between;
  }
  #top_news .top_blog_tit .c-title1 {
    margin-bottom: 15rem;
  }
  #top_news .news_block, #top_news .no-post_wrap {
    width: 73.84%;
  }
  #top_news .news_dc {
    flex-shrink: 0;
  }
}
@media screen and (min-width: 1400px) {
  #top_news {
    padding-top: 8.26rem;
    margin-top: 8rem;
  }
}
/**************************
/* NEWS一覧
**************************/
.news_block {
  margin-bottom: 0;
}
.news_block li {
  list-style: none;
  position: relative;
}
.news_block li:first-child::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(170, 170, 170, 0.5);
  top: 0;
  left: 0;
}
.news_block li::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(170, 170, 170, 0.5);
  bottom: 0;
  left: 0;
}
.news_block li a {
  display: block;
  padding: 1.4rem 0;
}
.news_block li a:hover {
  text-decoration: none;
}
.news_dc {
  display: flex;
  align-items: center;
  margin-bottom: 0.85rem;
}
.news_dc .news_cat {
  background-color: #000;
  color: #fff;
  font-size: 0.76rem;
  letter-spacing: 0.03em;
  padding: 0.24rem 1.5rem;
  margin-right: 15px;
}
.news_dc .news_date {
  color: #737477;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0;
  margin-bottom: 0;
}
.news_tit {
  color: #000;
  font-size: 1rem;
  letter-spacing: 0.05em;
  line-height: 1.66;
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .news_block li a {
    display: flex;
    align-items: center;
    padding: 2.1rem 0;
  }
  .news_dc {
    margin-right: 37px;
    margin-bottom: 0;
  }
  .news_dc .news_cat {
    margin-right: 20px;
  }
}
@media screen and (min-width: 1200px) {
  .news_block li a {
    padding: 2.8rem 0;
  }
  .news_dc {
    margin-right: 75px;
  }
  .news_dc .news_cat {
    font-size: 0.73rem;
    margin-right: 30px;
  }
}
/**************************
/* 投稿ページ 共通
**************************/
#main2 h1.single_main_title {
  font-size: 1.3rem;
  font-weight: 500;
  margin-bottom: 0.4rem;
  letter-spacing: 0.06rem;
  line-height: 1.7;
}
.info_cont {
  color: #737477;
  font-size: 0.76rem;
  margin-bottom: 1.5rem;
}
.single_main_img {
  margin-bottom: 3rem;
}
#main2 .single_inner img {
  width: 100%;
}
.single_content p {
  color: #505050;
}
@media screen and (min-width: 768px) {
  #main2 h1.single_main_title {
    font-size: 1.4375rem;
    margin-bottom: 0.65rem;
  }
  .info_cont {
    font-size: 0.95rem;
    margin-bottom: 2.5rem;
  }
  .single_main_img {
    margin-bottom: 4.5rem;
  }
}
/**************************
/* BLOG一覧
**************************/
.blog_tit {
  color: #000;
  font-size: 1rem;
  letter-spacing: 0.06em;
  line-height: 1.75;
  margin-bottom: 0.04rem;
}
.blog_date {
  font-size: 0.76rem;
  font-weight: 400;
  color: #8c8c8c;
  margin-bottom: 0;
}
.top_blog_con.archive_blog_con {
  padding-left: 0;
  width: 100%;
}
.archive_blog_con .blog_slider .item {
  padding-right: 0;
  margin-bottom: 2.2rem;
}
@media screen and (min-width: 768px) {
  .archive_blog_con .blog_slider {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -1.2rem;
  }
  .archive_blog_con .blog_slider .item {
    width: 50%;
    padding: 0 1.2rem;
    margin-bottom: 3rem;
  }
}
@media screen and (min-width: 992px) {
  .archive_blog_con .blog_slider .item {
    width: 33.33%;
  }
}
@media screen and (min-width: 1200px) {
  .blog_tit {
    margin-bottom: 0.6rem;
  }
  .blog_date {
    font-size: 0.73rem;
  }
}
/********************
/* BLOG トップ・archive共通
********************/
#top_blog {
  width: 100%;
  position: relative;
  padding-top: 4.23rem;
  margin-top: 4.61rem;
  overflow: hidden;
}
#top_blog::before {
  position: absolute;
  content: "";
  width: 90%;
  height: 1px;
  background-color: rgba(180, 180, 180, 0.5);
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
#top_blog .c-title1{
	margin-bottom: 1.2rem;
}
.top_blog_tit {
  width: 90%;
  margin: 0 auto;
  text-align: center;
}
.top_blog_tit .vm2 {
  display: none;
}
.top_blog_con {
  padding-left: 5%;
}
.blog_slider .slick-list {
  padding-right: calc(5% - 10px);
}
.blog_slider .item {
  padding-right: 10px;
}
.blog_slider .item a {
  display: block;
}
.blog_slider .item a:hover {
  text-decoration: none;
}
.blog_slider .zoom {
  position: relative;
  margin-bottom: 1.2rem;
  aspect-ratio: 1 / 0.735;
}
.blog_slider .zoom img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.blog_slider .zoom .ev_type {
  position: absolute;
  top: 0;
  left: 0;
  font-size: 0.8rem;
  background-color: #000;
  color: #fff;
  padding: 0.26rem 1.26rem;
}
.blog_arrow_outer {
  width: 95%;
  margin-right: auto;
  display: flex;
  justify-content: flex-end;
  margin-bottom: 22px;
}
.blog_arrow {
  display: inline-flex;
  justify-content: space-between;
}
.blog_arrow .blog-prev, .blog_arrow .blog-next,
.blog_arrow .column-prev, .blog_arrow .column-next {
  width: 40px;
  height: 28px;
  border-radius: 30px;
  cursor: pointer;
  background: #000;
  position: relative;
}
.blog_arrow .blog-prev,
.blog_arrow .column-prev{
  margin-right: 10px;
}
.blog_arrow .blog-prev::after, .blog_arrow .blog-next::after,
.blog_arrow .column-prev::after, .blog_arrow .column-next::after{
  position: absolute;
  content: "";
  width: 12px;
  height: 9px;
  background-image: url("../images/arrow_w.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.blog_arrow .blog-prev::after,
.blog_arrow .column-prev::after{
  transform: translate(-50%, -50%) rotate(180deg);
}
#top_blog .no-post_wrap {
  width: 95%;
  margin-right: auto;
}
@media screen and (min-width: 768px) {
  #top_blog {
    padding-top: 5.57rem;
    margin-top: 5.74rem;
  }
  #top_blog::before {
    width: 94.11%;
  }
  .top_blog_con {
    padding-left: 11.765%;
  }
  .blog_arrow_outer {
    width: 88.235%;
    margin-bottom: 33px;
  }
  .blog_slider .slick-list {
    padding-right: calc(11.765% - 10px);
  }
  #top_blog .no-post_wrap {
    width: 88.235%;
  }
}
@media screen and (min-width: 992px) {
  #top_blog {
    padding-top: 6.91rem;
    margin-top: 6.87rem;
  }
}
@media screen and (min-width: 1200px) {
  #top_blog {}
  .top_blog_inner {
    padding-left: 11.765%;
    display: flex;
    justify-content: space-between;
  }
  .top_blog_tit {
    width: auto;
    margin: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: left;
  }
  .top_blog_tit .c-title1 {
    margin-top: -0.6rem;
    margin-bottom: 11rem;
  }
  .top_blog_tit .vm2 {
    display: inline-flex;
  }
  .top_blog_con {
    width: 77.33%;
    padding-left: 0;
  }
  .blog_arrow_outer {
    width: 82.76%;
    margin-bottom: 45px;
  }
  .blog_slider .slick-list {
    padding-right: 9.48%;
  }
  .blog_slider .item {
    padding-right: 20px;
  }
  .blog_slider .zoom {
    margin-bottom: 1.26rem;
  }
  .blog_slider .zoom .ev_type {
    font-size: 0.8rem;
  }
  #top_blog .no-post_wrap {
    width: 82.76%;
  }
}
@media screen and (min-width: 1400px) {
  #top_blog {
    padding-top: 8.26rem;
    margin-top: 8rem;
  }
  .archive_blog_con .blog_slider .item {
    width: 25%;
    margin-bottom: 3.125rem;
  }
}
/********************
/* VOICE　トップ・アーカイブ共通
********************/
#top_voice {
  margin-top: 5.16rem;
}
.top_voice_main {
  margin-bottom: 3.21rem;
}
#top_voice .c-title1 {
  margin-bottom: 1.63rem;
}
#top_voice .txt_block {
  color: #505050;
  font-size: 0.84rem;
  line-height: 1.8;
}
.voice_slider .item {
  padding: 0 20px;
  position: relative;
}
.voice_slider .item .f-eng {
  position: absolute;
  top: 0;
  left: 0;
  writing-mode: vertical-rl;
  font-size: 0.84rem;
  font-weight: 400;
  margin: 0;
}
.voice_slider .item .zoom {
  position: relative;
}
.voice_slider .item .zoom::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: rgba(255, 255, 255, 0.08)
}
.voice_slider .item .zoom .voice_slide_txt {
  position: absolute;
  color: #fff;
  font-size: 1.3rem;
  line-height: 1.7;
  letter-spacing: 0.06em;
  width: 80%;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0;
  transition: .3s;
}
.voice_slider .item a:hover .zoom .voice_slide_txt {
  opacity: 1;
}
#top_voice .vm {
  margin-top: 3.26rem;
}
@media screen and (min-width: 768px) {
  #top_voice {
    margin-top: 6.57rem;
  }
  .top_voice_main {
    margin-bottom: 4.14rem;
  }
  #top_voice .c-title1 {
    margin-bottom: 2.44rem;
  }
  #top_voice .vm {
    margin-top: 4.06rem;
  }
}
@media screen and (min-width: 992px) {
  #top_voice {
    margin-top: 7.98rem;
  }
  .top_voice_main {
    margin-bottom: 5.02rem;
  }
  #top_voice .vm {
    margin-top: 4.86rem;
  }
}
@media screen and (min-width: 1200px) {
  #top_voice .c-title1 {
    margin-bottom: 3.26rem;
  }
  #top_voice .txt_block {
    font-size: 0.86rem;
  }
  .voice_slider .item {
    padding: 0 40px;
  }
  .voice_slider .item .f-eng {
    font-size: 0.86rem;
  }
  .voice_slider .item .zoom .voice_slide_txt {
    font-size: 1.46rem;
    bottom: 7.83%;
  }
}
@media screen and (min-width: 1400px) {
  #top_voice {
    margin-top: 9.4rem;
  }
  .top_voice_main {
    margin-bottom: 5.86rem;
  }
  #top_voice .vm {
    margin-top: 5.66rem;
  }
}
/********************
/* VOICE　アーカイブ
********************/
.archive_voice_con .voice_slider .item {
  margin-bottom: 3rem;
  padding: 0 0 0 20px;
}
.archive_voice_con a:hover {
  color: #000;
  text-decoration: none;
}
.archive_voice_con .voice_slide_txt {
  color: #000;
  font-size: 1.15rem;
  letter-spacing: 0.06em;
  line-height: 1.75;
  margin-bottom: 0;
}
.archive_voice_con .voice_slider .item .zoom {
  margin-bottom: 1.2rem;
  aspect-ratio: 1 / 1.5;
}
.archive_voice_con .voice_slider .item a .zoom img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.voice_data_wrap {
  position: relative;
  margin-top: 0.42rem;
  padding-top: 0.65rem;
}
.voice_data_wrap::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  top: 0;
  left: 0;
  background-color: rgba(200, 200, 200, 0.5);
}
.voice_data_wrap .mb-0 {
  color: #8c8c8c;
  font-size: 0.84rem;
  display: flex;
  align-items: center;
}
.voice_data_wrap .voice_place span.icon {
  background-image: url("../images/icon_map.svg");
  background-repeat: no-repeat;
  width: 17px;
  height: 15px;
  display: block;
  background-size: contain;
}
.voice_data_wrap .voice_couple span.icon {
  background-image: url("../images/icon_person.svg");
  background-repeat: no-repeat;
  width: 17px;
  height: 15px;
  display: block;
  background-size: contain;
  background-position: 0.1rem 0;
}
@media screen and (min-width: 768px) {
  .archive_voice_con .voice_slider {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
  }
  .archive_voice_con .voice_slider .item {
    margin-bottom: 3rem;
    padding: 0 2rem;
    width: 50%;
  }
}
@media screen and (min-width: 992px) {
  .archive_voice_con .voice_slider .item {
    width: 33.33%;
  }
}
@media screen and (min-width: 1200px) {
  .archive_voice_con .voice_slide_txt {
    font-size: 1.2rem;
  }
  .voice_data_wrap {
    margin-top: 1.1rem;
    padding-top: 1.33rem;
  }
  .voice_data_wrap .mb-0 {
    font-size: 0.86rem;
  }
  .voice_data_wrap .mb-0.voice_couple {
    ;
    margin-top: 0.2rem;
  }
  .voice_data_wrap .voice_place span.icon {
    width: 22px;
    height: 17px;
  }
  .voice_data_wrap .voice_couple span.icon {
    width: 21px;
    height: 18px;
    background-position: 1px 0;
  }
}
@media screen and (min-width: 1400px) {
  .archive_voice_con .voice_slider .item {
    margin-bottom: 4rem;
    width: 25%;
  }
}
/********************
/* VOICE　詳細
********************/
.page_voice_con .voice_data_wrap {
  position: relative;
  margin-top: 0;
  padding-top: 0;
  margin-bottom: 2rem;
}
.page_voice_con .voice_data_wrap::before {
  display: none;
}
.page_voice_con .voice_data_wrap .mb-0.voice_couple {
  margin-top: 0;
}
@media screen and (min-width: 768px) {
  .page_voice_con .voice_data_wrap {
    display: flex;
    align-items: center;
    margin-bottom: 2.5rem;
  }
  .page_voice_con .voice_data_wrap .mb-0.voice_couple {
    margin-left: 1rem;
  }
}
@media screen and (min-width: 1200px) {
  .page_voice_con #main2 h1.single_main_title {
    margin-bottom: 1rem;
  }
}
@media screen and (min-width: 1400px) {
  .page_voice_con .voice_data_wrap {
    margin-bottom: 2.75rem;
  }
}
/*インタビュー*/
.voice_interview_wrap .item .voice_interview_q {
  font-size: 1.15rem;
  padding-left: 3rem;
  line-height: 1.7;
  position: relative;
}
.voice_interview_wrap .item .voice_interview_q::before {
  content: "";
  height: 1px;
  width: 2.2rem;
  top: 12px;
  left: 0;
  background: #c8c8c8;
  display: block;
  position: absolute;
}
.voice_interview_wrap .item {
  margin-bottom: 3rem;
}
.voice_interview_wrap .item:last-child {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .voice_interview_wrap .item {
    margin-bottom: 3.5rem;
  }
  .voice_interview_wrap .item .voice_interview_q {
    font-size: 1.18rem;
    padding-left: 5rem;
  }
  .voice_interview_wrap .item .voice_interview_q::before {
    width: 3.75rem;
  }
}
@media screen and (min-width: 1200px) {
  .voice_interview_wrap .item .voice_interview_q::before {
    top: 14px;
  }
}
/*施工事例へのリンク*/
.voice_galleryLink {
  text-align: center;
  margin-top: 4rem;
}
.voice_galleryLink p {
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .voice_galleryLink {
    margin-top: 5rem;
  }
}
@media screen and (min-width: 1400px) {
  .voice_galleryLink {
    margin-top: 6.8rem;
  }
  .voice_galleryLink p {
    margin-bottom: 2.2rem;
  }
}
/*ギャラリー*/
.voice_interview_img {
  display: flex;
  flex-wrap: wrap;
  margin: 1.5rem -3px 0;
}
#main2 .single_inner .voice_interview_img img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.voice_interview_img a {
  padding: 3px;
  margin-bottom: 0;
  display: block;
}
.img-count-2 a, .img-count-3 a {
  width: 100%;
}
.img-count-4 a {
  width: 50%;
}
@media screen and (min-width: 768px) {
  .img-count-2 a {
    width: 50%;
  }
  .img-count-3 a {
    width: 33.33%;
  }
  .img-count-4 a {
    width: 25%;
  }
  .voice_interview_img {
    margin: 1.5rem -3px 0;
  }
}
/*その他のお客様の声*/
.other {
  margin-top: 5rem;
  padding-top: 4rem;
  position: relative;
}
.other::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  background: #b4b4b4;
  height: 1px;
}
.other .c-title1 .f-eng {
  font-size: 1.9rem;
}
.other .voice_slider a {
  color: #000;
}
.other .voice_slider a:hover {
  text-decoration: none;
  color: #000;
}
.other .voice_slider .item .zoom {
  margin-bottom: 1rem;
}
.other-btn {
  text-align: center;
  margin-top: 3rem;
}
@media screen and (min-width: 768px) {
  .other {
    margin-top: 7rem;
    padding-top: 6rem;
  }
  .other .c-title1 {
    margin-bottom: 2.8rem;
  }
  .other .c-title1 .f-eng {
    font-size: 2rem;
  }
  .other::before {
    width: 91.76%;
  }
  .other .voice_slider {
    display: flex;
    width: 91.76%;
    margin: 0 auto;
    flex-wrap: wrap;
  }
  .other .voice_slider .item {
    width: 50%;
    margin-bottom: 2.5rem;
  }
  .other-btn {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 992px) {
  .other .voice_slider .item {
    width: 25%;
    margin-bottom: 0;
  }
  .other-btn {
    margin-top: 4rem;
  }
}
@media screen and (min-width: 1400px) {
  .other {
    margin-top: 9.37rem;
    padding-top: 7.5rem;
  }
  .other .c-title1 {
    margin-bottom: 3.75rem;
  }
  .other .voice_slider .item .zoom {
    margin-bottom: 1.7rem;
  }
  .other-btn {
    margin-top: 4.3rem;
  }
}
/********************
/* STAFF　アーカイブ
********************/
.archive_staff_con .staff_slider a:hover {
  text-decoration: none;
}
.archive_staff_con .staff_slider {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.5rem 2rem;
}
.archive_staff_con .staff_slider .item {
  width: 50%;
  padding: 0 0.5rem;
  margin-bottom: 2rem;
}
.staff_category_title {
  font-size: 1.35rem;
  margin-bottom: 1.5rem;
}
.archive_staff_con .staff_slider .item .zoom {
  margin-bottom: 1rem;
}
.staff_category_block > div:last-child .staff_slider {
  margin-bottom: 0;
}
.staff_slider .zoom {
  aspect-ratio: 1 / 1.5;
}
.staff_slider .zoom img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
@media screen and (min-width: 768px) {
  .staff_category_title {
    font-size: 1.35rem;
    margin-bottom: 2.5rem;
  }
  .archive_staff_con .staff_slider {
    margin: 0 -1.25rem 2.5rem;
  }
  .archive_staff_con .staff_slider .item {
    width: 33.33%;
    padding: 0 1.25rem;
    margin-bottom: 2.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .archive_staff_con .staff_slider .item {
    width: 25%;
    margin-bottom: 2.8rem;
  }
  .archive_staff_con .staff_slider .item .zoom {
    margin-bottom: 1.3rem;
  }
  .archive_staff_con .staff_slider {
    margin: 0 -1.25rem 3.45rem;
  }
}
/*リンク*/
.staff_index {
  display: flex;
  justify-content: center;
  width: 100%;
  max-width: 400px;
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 3.5rem;
}
.staff_index li {
  list-style: none;
  position: relative;
  padding-top: 11px;
  margin: 0 1rem;
}
.staff_index li a {
  color: #000;
}
.staff_index li a:hover {
  text-decoration: none;
}
.staff_index li.select::before {
  position: absolute;
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background-color: #bce2e8;
}
@media screen and (min-width: 768px) {
  .archive_staff_con {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .staff_index {
    width: 180px;
    max-width: unset;
    margin: 0;
    display: block;
    position: sticky;
    top: 120px;
  }
  .staff_index li {
    padding-top: 0;
    padding-left: 15px;
    margin: 0 0 1rem;
  }
  .staff_index li a {
    color: #8c8c8c;
  }
  .staff_index li.select a {
    color: #000;
  }
  .staff_index li.select::before {
    top: 48%;
    left: 0;
    transform: translateY(-50%);
  }
  .staff_category_block {
    width: calc(100% - 200px);
  }
}
@media screen and (min-width: 1200px) {
  .staff_index {
    width: 260px;
  }
  .staff_category_block {
    width: calc(100% - 260px);
  }
}
@media screen and (min-width: 1400px) {
  .staff_index {
    top: 200px;
  }
  .staff_index li.select::before {
    top: 47%;
  }
}
/*タクソノミーページ*/
.archive_staff_con.taxonomy_staff_con {
  display: block;
}
/********************
/* STAFF　詳細ページ
********************/
.page_staff_con .s_note {
  margin-top: 2rem;
}
.page_staff_con .s_name span {
  color: #969696;
  font-size: 0.8rem;
  display: block;
  margin-top: 0.4rem;
  letter-spacing: 0.03rem;
}
.page_staff_con .s_profile {
  margin-top: 2rem;
}
.s_note .yaku {
  font-size: 0.9rem;
  margin-bottom: 0.7rem;
}
.page_staff_con .s_profile table {
  width: 100%;
  margin-bottom: 1.7rem;
}
.page_staff_con .s_profile table tr {
  border-top: 1px solid #c8c8c8;
  font-size: 0.9rem;
}
.page_staff_con .s_profile table tr:last-child {
  border-bottom: 1px solid #c8c8c8;
}
.page_staff_con .s_profile table tr th {
  font-weight: 400;
  padding: 1rem 0;
  color: #000;
  width: 35%;
}
.page_staff_con .s_profile table tr td {
  color: #505050;
  width: 65%;
  padding: 1rem 0;
}
.s_profile .title {
  letter-spacing: 0.03rem;
  margin-bottom: 0.7rem;
  font-size: 0.8rem;
}
@media screen and (min-width: 768px) {
  .page_staff_con .single_inner {
    display: flex;
    justify-content: space-between;
  }
  .s_img_wrap {
    width: 46%;
  }
  .page_staff_con .s_note {
    margin-top: 0;
    width: 46%;
  }
}
@media screen and (min-width: 1200px) {
  .page_staff_con .s_note {
    width: 29.3%;
  }
  .s_img_wrap {
    width: 60%;
  }
  .s_note .yaku {
    margin-bottom: 1rem;
  }
  #main2 h1.s_name {
    font-size: 2.06rem;
    margin-bottom: 2rem;
  }
  .page_staff_con .s_name span {
    margin-top: 0.5rem;
  }
  .page_staff_con .s_profile {
    margin-top: 3rem;
  }
  .page_staff_con .s_profile table tr th, .page_staff_con .s_profile table tr td {
    padding: 1.4rem 0;
  }
  .page_staff_con .s_profile table {
    margin-bottom: 2.8rem;
  }
  .s_profile .title {
    margin-bottom: 1rem;
  }
}
@media screen and (min-width: 1600px) {
  .page_staff_con .s_note {
    margin-top: 5rem;
  }
}
/*その他のスタッフ*/
.other .staff_slider a:hover {
  text-decoration: none;
}
.other .staff_slider .zoom {
  margin-bottom: 1.5rem;
}
.other .staff_slider .item {
  padding: 0 1rem;
}
@media screen and (min-width: 768px) {
  .other.other-staff {
    width: 91.76%;
    margin-right: auto;
    margin-left: auto;
  }
  .other.other-staff::before {
    width: 100%;
  }
  .other .staff_slider {
    display: flex;
    margin: 0 -1rem;
  }
  .other .staff_slider .item {
    padding: 0 1rem;
    width: 25%;
  }
  .other.other-staff .other-btn {
    margin-top: 4.37rem;
  }
}
@media screen and (min-width: 1200px) {
  .other .staff_slider {
    margin: 0 -1.56rem;
  }
  .other .staff_slider .item {
    padding: 0 1.56rem;
  }
}
/********************
/* 部分別ギャラリー
********************/
.detail_container {
  width: 90%;
  margin-right: auto;
  margin-left: auto;
}
.detail_accordion {
  position: relative;
}
.detail_accordion .js-accordion-title {
  position: relative;
  cursor: pointer;
  display: inline-block;
}
.detail_accordion .js-accordion-title .txt {
  display: flex;
  align-items: center;
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.03rem;
  margin-bottom: 0;
}
.detail_accordion .js-accordion-title .txt .plus {
  position: relative;
  width: 26px;
  height: 26px;
  display: block;
  border-radius: 50%;
  background-color: #bce2e8;
  margin-left: 7px;
  top: -2px;
}
.detail_accordion .js-accordion-title .plus::before {
  position: absolute;
  content: "";
  background: url(../images/arrow_w.svg);
  background-repeat: no-repeat;
  width: 9px;
  height: 7px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
  transition: .3s;
}
.detail_accordion .js-accordion-title.open .plus::before {
  transform: translate(-50%, -50%) rotate(270deg);
  transition: .3s;
}
.detail_accordion .accordion-content {
  display: none;
  margin-top: 0.5rem;
  background-color: #f5f5f5;
  padding: 1.5rem 2rem 2rem;
  position: absolute;
  z-index: 10;
  width: 90%;
  max-width: 540px;
  left: 0;
}
a.accordion-content_txt {
  font-size: 0.88rem;
  text-decoration: underline;
  text-underline-offset: 5px;
  text-decoration-color: #b0b0b0;
  font-weight: 500;
  display: block;
  margin-bottom: 0.8rem;
  color: #000;
}
.detail_accordion .accordion-content_inner ul {
  display: flex;
  flex-wrap: wrap;
  margin: -2px 0;
}
.detail_accordion .accordion-content_inner ul li {
  list-style: none;
  margin: 2px 5px 2px 0;
}
.detail_accordion .accordion-content_inner ul li a {
  color: #000;
  text-decoration: none;
  font-size: 0.84rem;
  display: block;
  transition: .3s;
}
.detail_gallery {
  margin-top: 2rem;
}
.detail_gallery > ul {
  margin: -9px -8px -0.8rem;
  column-count: 2;
  column-gap: 0;
}
.detail_gallery > ul > li {
  list-style: none;
  width: 100%;
  padding: 9px 8px 0.8rem;
  -webkit-page-break-inside: avoid;
  -moz-page-break-inside: avoid;
  -ms-page-break-inside: avoid;
  page-break-inside: avoid;
}
.detail_gallery > ul > li > a {
  width: 100%;
  display: block;
  margin: 0 auto;
}
.detail_tag {
  margin-top: 1rem;
}
.detail_tag ul {
  display: flex;
  flex-wrap: wrap;
  margin: -2px 0;
}
.detail_tag ul li {
  list-style: none;
  margin: 2px 5px 2px 0;
}
.detail_tag ul li a {
  background-color: #ffffff;
  color: #505050;
  text-decoration: none;
  font-size: 0.84rem;
  display: block;
  padding: 2px 10px;
  border: 1px solid #c8c8c8;
  transition: .3s;
}
.detail_tag ul li a:hover {
  background-color: #c8c8c8;
  color: #fff;
  transition: .3s;
}
.detail_accordion .accordion-content_inner ul li a:hover {
  opacity: 0.6;
  transition: .3s;
}
@media screen and (min-width: 768px) {
  .detail_container {
    width: 91.76%;
  }
  .detail_accordion .accordion-content {
    margin-top: 1.5rem;
    padding: 2.1rem 4.68rem 2.6rem;
  }
  .detail_gallery {
    margin-top: 3.75rem;
  }
  .detail_gallery > ul {
    margin: -10px -16px -1.2rem;
  }
  .detail_gallery > ul > li {
    padding: 10px 16px 1.2rem;
  }
  .detail_accordion .js-accordion-title .txt {
    font-size: 1rem;
  }
  .detail_accordion .js-accordion-title .txt .plus {
    margin-left: 9px;
    top: 0;
    width: 30px;
    height: 30px;
  }
  .detail_accordion .js-accordion-title .plus::before {
    width: 11px;
    height: 9px;
  }
}
@media screen and (min-width: 992px) {
  .detail_gallery {
    margin-top: 4.05rem;
  }
  .detail_gallery > ul {
    column-count: 3;
    margin: 0 -20px -30px;
  }
  .detail_gallery > ul > li {
    padding: 0 20px 30px;
  }
}
@media screen and (min-width: 1200px) {
  .detail_accordion .accordion-content_inner ul li a {
    font-size: 0.95rem;
    padding: 0 10px 0px 0;
  }
  a.accordion-content_txt {
    font-size: 0.95rem;
  }
  .detail_tag {
    margin-top: 1.2rem;
  }
  .detail_tag ul {
    margin: -7px 0;
  }
  .detail_tag ul li {
    margin: 7px 7px 7px 0;
  }
  .detail_tag ul li a {
    font-size: 0.82rem;
    padding: 4px 10px;
  }
}
@media screen and (min-width: 1400px) {
  .detail_gallery > ul {
    margin: -15px -20px -40px;
  }
  .detail_gallery > ul > li {
    padding: 15px 20px 40px;
  }
}
/********************
/* 部分別ギャラリーsingle
********************/
.detail_single {
  width: 90%;
  margin-right: auto;
  margin-left: auto;
}
.detail_eye {
  margin-bottom: 2.17rem;
}
.detail_eye a {
  display: block;
  width: 100%;
  height: 100%;
}
.detail_single h1 {
  font-size: 1.3rem;
  line-height: 1.8;
  margin-bottom: 0;
}
.detail_single .detail_single_content .detail_tag {
  margin: 0.7rem 0 1.5rem;
}
.material_list {
  margin-top: 1.6rem;
  margin-bottom: 0;
}
.material_list li {
  list-style: none;
  padding-left: 1em;
  text-indent: -1em;
  font-size: 0.86rem;
  letter-spacing: 0.1em;
  margin-bottom: 0.23rem;
}
.material_list li:last-child {
  margin-bottom: 0;
}
.detail_single .detail_gallery {
  position: relative;
  margin-top: 3rem;
  padding-top: 3.5rem;
}
.detail_single .detail_gallery::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background: #b4b4b4;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .detail_single {
    width: 91.76%;
  }
}
@media screen and (min-width: 992px) {
  .detail_single {
    display: flex;
    align-items: flex-start;
  }
  .detail_single_content {
    position: sticky;
    top: 120px;
    width: 40.47%;
    height: calc(100% - 120px);
    overflow: scroll;
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE 10+ */
  }
  .detail_single_content::-webkit-scrollbar {
    display: none; /* Chrome, Safari */
  }
  .detail_eye {
    margin-bottom: 1.6rem;
  }
  .detail_eye a {
    aspect-ratio: 426 / 287;
  }
  .detail_eye img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
  .detail_single .detail_tag {
    margin-top: 1.2rem;
  }
  .detail_single .detail_gallery {
    margin-top: 0;
    padding-top: 0;
  }
  .detail_single .detail_gallery::after {
    width: 1px;
    height: 100%;
  }
  .detail_single .detail_gallery {
    width: calc(59.53% - 30px);
    padding-left: 30px;
    margin-left: 30px;
  }
  .detail_single .detail_gallery > ul {
    column-count: 2;
  }
}
@media screen and (min-width: 1200px) {
  .detail_single_content {
    width: 37.47%;
  }
  .detail_single .detail_gallery {
    width: calc(62.53% - 70px);
    padding-left: 70px;
    margin-left: 70px;
  }
  .detail_single h1 {
    font-size: 1.43rem;
  }
  .detail_single .detail_single_content .detail_tag {
    margin: 1rem 0 2rem;
  }
}
/*******************************
/* youtube動画 アーカイブ
***************************/
.archive_youtube_con .item {
  margin-bottom: 2rem;
}
.youtube_tit {
  font-size: 1.2rem;
  margin: 1rem 0 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.youtube_date {
  font-size: 0.76rem;
  font-weight: 400;
  color: #8c8c8c;
  margin-bottom: 0;
  margin-top: 0.2rem;
}
@media screen and (min-width: 768px) {
  .archive_youtube_con .yt_slider {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -1rem;
  }
  .archive_youtube_con .item {
    margin-bottom: 2rem;
    width: 33.33%;
    padding: 0 1rem 0;
  }
}
@media screen and (min-width: 1400px) {
  .archive_youtube_con .yt_slider {
    margin: 0 -1.78rem;
  }
  .archive_youtube_con .item {
    margin-bottom: 4rem;
    padding: 0 1.78rem 0;
  }
  .youtube_tit {
    margin: 1.2rem 0 0;
  }
}
/*******************************
/* DAIYA STYLE
***************************/
/*施工事例*/
.daiyastyle-works {
  margin-top: 3.75rem;
}
.daiyastyle-works-btn {
  margin-top: 3rem;
}
@media screen and (min-width: 768px) {
  .daiyastyle-works {
    margin-top: 7.5rem;
  }
  .daiyastyle-works-btn {
    margin-top: 4.3rem;
  }
}
@media screen and (min-width: 1400px) {
  .daiyastyle-works {
    margin-top: 9.06rem;
  }
}
/*-- modal --*/
.modal_open {
  display: inline-flex;
}
.modal_box {
  position: fixed;
  z-index: 7777;
  display: none;
  width: 80%;
  max-height: 60vh;
  margin: 0;
  box-sizing: border-box;
}
.modal_box--inner {
  background: #fff;
  width: 100%;
  height: 100%;
  max-height: 60vh;
  overflow-y: scroll;
  padding: 2rem;
}
.modal_bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 6666;
  display: none;
  width: 100%;
  height: 120%;
  background-color: rgba(0, 0, 0, 0.7);
}
.modal_prev {
  position: absolute;
  bottom: -7.5rem;
  left: calc(50% - 2.5rem);
  transform: translateX(-50%);
}
.modal_next {
  position: absolute;
  bottom: -7.5rem;
  left: calc(50% + 2.5rem);
  transform: translateX(-50%);
}
.modal_prev .modal_switch, .modal_next .modal_switch {
  display: inline-block;
  text-align: center;
  cursor: pointer;
  width: 3.52rem;
  padding-top: 3.52rem;
  text-transform: uppercase;
}
.modal_prev .modal_switch:hover, .modal_next .modal_switch:hover {
  text-decoration: none;
}
.modal_prev .modal_switch::before, .modal_next .modal_switch::before {
  position: absolute;
  content: "";
  width: 3.52rem;
  height: 3.52rem;
  display: block;
  border: 1px solid #fff;
  border-radius: 50%;
  top: 0;
}
.modal_prev .modal_switch::after, .modal_next .modal_switch::after {
  position: absolute;
  content: "";
  width: 18px;
  height: 11px;
  top: 33%;
  left: 50%;
  background-image: url("../images/arrow_w.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.modal_prev .modal_switch::after {
  transform: translate(-50%, -50%) rotate(-180deg);
}
.modal_next .modal_switch::after {
  transform: translate(-50%, -50%);
}
.modal_link a {
  color: #fff;
}
.modal_close {
  position: absolute;
  bottom: -4.423rem;
  left: 50%;
  color: #fff;
  font-weight: 400;
  font-style: normal;
  cursor: pointer;
  text-transform: uppercase;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
}
#page-main .modal_close img {
  width: 34px;
  margin-left: 0.8rem;
}
.modal_close:hover {
  text-decoration: none;
  color: #fff;
}
/*モーダル内*/
#modal1 .title {
  font-size: 1.15rem;
  margin-bottom: 1.5rem;
}
#modal1 .img {
  margin-bottom: 0.7rem;
}
#modal1 ul.joken, #modal1 ul.note {
  list-style: none;
  margin: 0;
}
#modal1 ul.note {
  font-size: 0.85rem;
  color: #505050;
}
#modal1 ul.joken li {
  border-top: 1px solid #c8c8c8;
  padding: 1.5rem 0;
}
#modal1 ul.joken li:last-child {
  border-bottom: 1px solid #c8c8c8;
}
#modal1 ul.joken li .txt1 {
  background: #505050;
  display: inline-block;
  color: #fff;
  font-size: 0.8rem;
  padding: 0.2rem 0.8rem;
}
#modal1 ul.joken li .txt2 {
  margin-top: 0.5rem;
}
#modal1 .txt3 {
  margin: 2rem 0;
}
@media screen and (min-width: 768px) {
  .modal_box {
    width: 80%;
  }
  .modal_box--inner {
    padding: 4rem 5rem;
  }
  #modal1 ul.joken li .txt1 {
    min-width: 65px;
    text-align: center;
  }
  #modal1 ul.joken li {
    padding: 1.8rem 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  #modal1 ul.joken li .txt2 {
    margin-top: 0;
    position: relative;
    top: 1px;
    width: calc(100% - 85px);
  }
  #modal1 .txt3 {
    margin: 3rem 0;
  }
  #modal1 ul.note {
    text-align: center;
  }
}
@media screen and (min-width: 992px) {
  .modal_box {
    width: 47.05%;
    max-height: 70vh;
    max-width: 800px;
  }
  .modal_box--inner {
    max-height: 70vh;
  }
}
@media screen and (min-width: 1200px) {
  #modal1 .title {
    font-size: 1.25rem;
  }
  #modal1 .img {
    margin-bottom: 1rem;
  }
  .modal_box--inner {
    padding: 5rem 6.25rem 6rem;
  }
}
/*******************************
/* フォーム　アンケート
***************************/
.form-anka {
  margin: 3rem 0 2rem;
  overflow: hidden;
}
.form-anka .wpcf7-form-control-wrap, .form-anka .wpcf7-form-control {
  display: block;
}
#form_customize .form-anka input {
  display: none;
}
.form-anka .wpcf7-list-item {
  margin-left: 0;
  display: block;
}
.form-anka-label label {
  color: #fff;
  background-color: #000000;
  width: 100%;
  margin-bottom: 0;
  text-align: left;
  position: relative;
  z-index: 1;
  cursor: pointer;
  padding: 0.8em;
  transition: .3s;
}
.form-anka-label .wpcf7-list-item-label::after {
  content: "よろしければアンケートにご協力ください（任意）";
  background: #000;
  width: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  padding: 0.9rem 4rem 0.9rem 0.9rem;
  line-height: 1.6;
}
.form-anka-label .plus {
  display: inline-block;
  width: 18px;
  height: 18px;
  margin-left: 0;
  position: absolute;
  z-index: 2;
  right: 1rem;
  top: 15px;
  cursor: pointer;
}
.form-anka-label .plus::before, .form-anka-label .plus::after {
  content: '';
  position: absolute;
  background-color: #fff;
  transition: 0.3s;
}
/* 横棒 */
.form-anka-label .plus::before {
  top: 50%;
  left: 0;
  width: 100%;
  height: 2px;
  transform: translateY(-50%);
}
/* 縦棒（これが消えるとマイナス） */
.form-anka-label .plus::after {
  top: 0;
  left: 50%;
  width: 2px;
  height: 100%;
  transform: translateX(-50%);
}
.plus.checked::after {
  opacity: 0;
}
.form-anka .form-survey-inner {
  height: auto !important;
  opacity: 1 !important;
}
#form-model .form-anka-label input {
  display: none;
}
.form-anka-label {
  margin-bottom: 3rem;
  position: relative;
}
.form-anka-label label {
  padding: 0.9rem;
  font-size: 1.05rem;
}
.fb-txt {
  font-size: 0.8rem;
  margin-top: 0.8rem;
}
@media screen and (min-width: 992px) {
  .form-anka-label .wpcf7-list-item-label::after {
    padding: 1rem 4rem 1rem 1rem;
  }
  .form-anka {
    margin: 3rem 0 -2rem;
  }
}
@media screen and (min-width: 1200px) {
  .form-anka-label .plus {
    right: 1.5rem;
    top: 21px;
  }
  .form-anka-label .wpcf7-list-item-label::after {
    padding: 1.2rem 4rem 1.2rem 1.5rem;
  }
}