@charset "utf-8";

/*********************************************************************
*
*  For ALL
*
*********************************************************************/

/* ---------------------------------------------------- */
/* web font */
/* ---------------------------------------------------- */
/* Google font */
@import url("https://fonts.googleapis.com/css?family=EB+Garamond:400,700&display=swap");
@import url("https://fonts.googleapis.com/css?family=Lato:300,400,700&display=swap");

/* FontAwesome */
@import url("https://use.fontawesome.com/releases/v5.8.2/css/all.css");

/* ---------------------------------------------------- */
/* cs_ff */
/* ---------------------------------------------------- */
.cs_ff_en1 {
  font-family: "EB Garamond", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  letter-spacing: 0.05em;
}

.cs_ff_en2 {
  font-family: "Lato", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
}

.cs_ff_go {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
}

.cs_ff_min {
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}

/* ---------------------------------------------------- */
/* cs_fc */
/* ---------------------------------------------------- */
.cs_fc_1,
.cs_fc_1 a,
a.cs_fc_1 {
  color: #ffffff;
}

.cs_fc_2,
.cs_fc_2 a,
a.cs_fc_2 {
  color: #000000;
}

/* ---------------------------------------------------- */
/* cs_fd */
/* ---------------------------------------------------- */
.cs_fd_bold {
  font-weight: bold;
}

.cs_fd_underline {
  text-decoration: underline;
}

/* ---------------------------------------------------- */
/* cf */
/* ---------------------------------------------------- */
.cf:after {
  content: ".";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}

.cf {
  display: block;
}

/* ---------------------------------------------------- */
/* img */
/* ---------------------------------------------------- */
img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
}

img.cs_img_full {
  width: 100%;
}

/* ---------------------------------------------------- */
/* a */
/* ---------------------------------------------------- */
a {
  color: #2a2b2b;
  text-decoration: none;
  outline: none;
  transition: 0.3s ease-in-out;
}

a:hover {
  color: #2a2b2b;
  text-decoration: none;
}

/* ---------------------------------------------------- */
/* cs_e_op */
/* ---------------------------------------------------- */
@media (min-width: 920px) {
  .cs_e_op {
    transition: opacity 0.3s ease-in-out;
  }

  .cs_e_op:hover {
    opacity: 0.6;
  }
}

/* ---------------------------------------------------- */
/* cs_e_bk */
/* ---------------------------------------------------- */
@media (min-width: 920px) {
  .cs_e_bk {
    transition: color 0.3s ease-in-out;
  }

  .cs_e_bk:hover {
    color: #000;
  }
}

/* ---------------------------------------------------- */
/* cs_ta */
/* ---------------------------------------------------- */
.cs_ta_l {
  text-align: left !important;
}

.cs_ta_r {
  text-align: right !important;
}

.cs_ta_c {
  text-align: center !important;
}

/* ---------------------------------------------------- */
/* cs_mg */
/* ---------------------------------------------------- */
.cs_mg_lr_auto {
  margin-left: auto;
  margin-right: auto;
}

.cs_mg_t_s {
  margin-top: 30px !important;
}

.cs_mg_t_m {
  margin-top: 50px !important;
}

.cs_mg_t_l {
  margin-top: 100px !important;
}

.cs_mg_b_s {
  margin-bottom: 30px !important;
}

.cs_mg_b_m {
  margin-bottom: 50px !important;
}

.cs_mg_b_l {
  margin-bottom: 100px !important;
}

@media (max-width: 919px) {
  .cs_mg_t_s {
    margin-top: 20px !important;
  }

  .cs_mg_t_m {
    margin-top: 35px !important;
  }

  .cs_mg_t_l {
    margin-top: 50px !important;
  }

  .cs_mg_b_s {
    margin-bottom: 20px !important;
  }

  .cs_mg_b_m {
    margin-bottom: 35px !important;
  }

  .cs_mg_b_l {
    margin-bottom: 50px !important;
  }
}

/* ---------------------------------------------------- */
/* cs_pd */
/* ---------------------------------------------------- */
.cs_pd_t_0 {
  padding-top: 0 !important;
}

.cs_pd_t_s {
  padding-top: 30px !important;
}

.cs_pd_t_m {
  padding-top: 50px !important;
}

.cs_pd_t_l {
  padding-top: 100px !important;
}

.cs_pd_b_s {
  padding-bottom: 30px !important;
}

.cs_pd_b_m {
  padding-bottom: 50px !important;
}

.cs_pd_b_l {
  padding-bottom: 100px !important;
}

@media (max-width: 919px) {
  .cs_pd_t_s {
    padding-top: 20px !important;
  }

  .cs_pd_t_m {
    padding-top: 35px !important;
  }

  .cs_pd_t_l {
    padding-top: 50px !important;
  }

  .cs_pd_b_s {
    padding-bottom: 20px !important;
  }

  .cs_pd_b_m {
    padding-bottom: 35px !important;
  }

  .cs_pd_b_l {
    padding-bottom: 50px !important;
  }
}

/* ---------------------------------------------------- */
/* pc/sp */
/* ---------------------------------------------------- */
@media (min-width: 920px) {
  .cs_none_pc {
    display: none !important;
  }
}

@media (max-width: 919px) {
  .cs_none_sp {
    display: none !important;
  }
}

@media screen and (max-width: 374px) {
  .cs_none_sp_old {
    display: none !important;
  }
}

/* ---------------------------------------------------- */
/* cs_border */
/* ---------------------------------------------------- */
.cs_border_1 {
  border-top: 1px solid #dfdedf;
}

/* ---------------------------------------------------- */
/* cs_bg */
/* ---------------------------------------------------- */
.cs_bg_1 {
  background-color: #fff;
}

.cs_bg_2 {
  background-color: #000;
}

.cs_bg_3 {
  background-color: #dcdddd;
}

.cs_bg_4 {
  background-color: #a39c8d;
}

.cs_bg_5 {
  background-color: #f8f8f8;
}

/* ---------------------------------------------------- */
/* cs_sec */
/* ---------------------------------------------------- */
.cs_sec_wrap {
  position: relative;
}

.cs_sec_inner {
  position: relative;
  margin: 0 auto;
}

@media (min-width: 920px) {
  .cs_sec_wrap {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .cs_sec_wrap_2 {
    padding-top: 100px;
    padding-bottom: 100px;
  }

  .cs_sec_inner {
    padding: 0 40px;
    max-width: 1600px;
  }

  .cs_sec_inner_full {
    padding: 0 0;
    max-width: 100%;
  }

  .cs_sec_inner_wide {
    max-width: 1180px;
  }

  .cs_sec_inner_narrow {
    max-width: 880px;
  }

  .cs_sec_inner_full_pc {
    width: 100%;
  }

  .cs_sec_inner_flex {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    max-width: 1200px;
    gap: 40px;
  }

  .cs_sec_inner_flex.gap-70 {
    gap: 70px;
  }

  .cs_sec_inner_flex.max-w-1600 {
    max-width: 1600px;
  }

  .cs_sec_inner_flex .cs_sec_inner_flex_25 {
    order: 1;
    width: 25%;
  }

  .cs_sec_inner_flex .cs_sec_inner_flex_75 {
    order: 2;
    width: 75%;
  }

  .cs_sec_inner_flex .cs_sec_inner_flex_45 {
    position: sticky;
    top: 0;
    width: 45%;
  }

  .cs_sec_inner_flex .cs_sec_inner_flex_55 {
    width: 55%;
  }
}

@media (max-width: 919px) {
  .cs_sec_wrap {
    padding-top: 35px;
    padding-bottom: 35px;
  }

  .cs_sec_wrap_2 {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .cs_sec_inner {
    max-width: calc(100% - 30px);
  }

  .cs_sec_inner_full {
    max-width: 100%;
  }

  .cs_sec_inner_wide {
    max-width: calc(100% - 30px);
  }

  .cs_sec_inner_narrow {
    max-width: calc(100% - 30px);
  }

  .cs_sec_inner_full_sp {
    max-width: 100%;
  }

  .cs_sec_inner_flex .cs_sec_inner_flex_25 {
    display: none;
  }

  .cs_sec_inner_flex .cs_sec_inner_flex_55 {
    margin-top: 50px;
  }
}

/* ---------------------------------------------------- */
/* cs_ttl_1 */
/* ---------------------------------------------------- */
.cs_ttl_1 {
  margin-bottom: 50px;
  color: #2a2b2b;
  font-size: 2.4rem;
  text-align: center;
}

.cs_ttl_1 .sub {
  display: block;
  margin-top: 5px;
  text-align: center;
}

.cs_ttl_1 .sub .sub_1 {
  font-size: 2.4rem;
}

.cs_ttl_1 .sub .sub_2 {
  color: #898989;
  font-size: 1.6rem;
}

.cs_ttl_1:after {
  content: "";
  margin: 20px auto 0;
  display: block;
  width: 24px;
  height: 1px;
  background-color: #2a2b2b;
}

@media (max-width: 919px) {
  .cs_ttl_1 {
    margin-bottom: 30px;
    font-size: 2.1rem;
  }

  .cs_ttl_1 .sub .sub_1 {
    font-size: 2.1rem;
  }

  .cs_ttl_1 .sub .sub_2 {
    color: #898989;
    font-size: 1.4rem;
  }

  .cs_ttl_1:after {
    margin: 18px auto 0;
  }
}

/* ---------------------------------------------------- */
/* cs_ttl_2 */
/* ---------------------------------------------------- */
.cs_ttl_2 {
  margin-bottom: 40px;
  font-size: 2.4rem;
}

@media (max-width: 919px) {
  .cs_ttl_2 {
    margin-bottom: 20px;
    font-size: 2.1rem;
  }
}

/* ---------------------------------------------------- */
/* cs_ttl_3 */
/* ---------------------------------------------------- */
.cs_ttl_3 {
  margin-bottom: 30px;
  font-size: 1.6rem;
}

@media (max-width: 919px) {
  .cs_ttl_3 {
    margin-bottom: 15px;
    font-size: 1.6rem;
  }
}

/* ---------------------------------------------------- */
/* cs_desc_1 */
/* ---------------------------------------------------- */
.cs_desc_1 p {
  line-height: 1.7;
  text-align: left;
}

.cs_desc_1 > * + * {
  margin-top: 30px;
}

@media (max-width: 919px) {
  .cs_desc_1 > * + * {
    margin-top: 15px;
  }
}

/* ---------------------------------------------------- */
/* cs_ul_1 */
/* ---------------------------------------------------- */
.cs_ul_1,
.cs_ul_2 {
  margin-left: 20px;
  line-height: 1.7;
  text-align: left;
}

.cs_ul_1 {
  list-style-type: decimal;
}

.cs_ul_2 {
  list-style-type: disc;
}

.cs_ul_1 li + li,
.cs_ul_2 li + li {
  margin-top: 10px;
}

/* ---------------------------------------------------- */
/* cs_btn_1 */
/* ---------------------------------------------------- */
.cs_btn_1 {
  display: inline-block;
  min-width: 350px;
  height: 55px;
  border: 1px solid #2a2b2b;
  color: #fff;
  font-size: 1.6rem;
  text-align: center;
  text-decoration: none !important;
  background-color: #2a2b2b;
  border-radius: 5px;
}

.cs_btn_1 + .cs_btn_1 {
  margin-left: 20px;
}

.cs_btn_1:hover {
  color: #2a2b2b;
  background-color: #fff;
}

.cs_btn_1 span {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 30px;
  width: 100%;
  height: 100%;
}

.cs_btn_1 span:after {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  width: 14px;
  height: 14px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateY(-50%) rotate(45deg);
  transition: 0.3s ease-in-out;
}

.cs_btn_1:hover span:after {
  border-color: #2a2b2b;
}

.cs_btn_1.cs_btn_toggle span:after {
  transform: translateY(-65%) rotate(135deg);
}

.cs_btn_1.cs_btn_toggle.show span:after {
  transform: translateY(-35%) rotate(-45deg);
}

.cs_btn_1.cs_btn_dl span:after {
  border: none;
  width: 28px;
  height: 28px;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url(../img/ico/dl_2.svg);
  background-size: contain;
  transform: translateY(-50%) rotate(0deg);
}

.cs_btn_1.cs_btn_dl:hover span:after {
  background-image: url(../img/ico/dl_1.svg);
}

/* size */
.cs_btn_1.cs_btn_1_si_s {
  font-size: 1.2rem;
}

@media (max-width: 919px) {
  .cs_btn_1 {
    display: block;
    margin-left: auto;
    margin-right: auto;
    min-width: auto;
    width: calc(100% - 40px);
  }

  .cs_btn_1 + .cs_btn_1 {
    margin-left: auto;
    margin-top: 20px;
  }
}

/* ---------------------------------------------------- */
/* cs_submit_1 */
/* ---------------------------------------------------- */
.cs_submit_1 {
  position: relative;
  display: inline-block;
  min-width: 350px;
}

.cs_submit_1 + .cs_submit_1 {
  margin-left: 20px;
}

.cs_submit_1:after {
  content: "";
  position: absolute;
  right: 15px;
  top: 50%;
  width: 14px;
  height: 14px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateY(-50%) rotate(45deg);
  transition: 0.3s ease-in-out;
}

.cs_submit_1:hover:after {
  border-color: #2a2b2b;
}

.cs_submit_1 input {
  display: block;
  width: 100%;
  color: #fff;
  font-size: 1.6rem;
  line-height: 55px;
  text-decoration: none;
  border-radius: 5px;
  border: 1px solid #2a2b2b;
  background-color: #2a2b2b;
  cursor: pointer;
  outline: none;
  -webkit-appearance: none;
  transition: 0.3s ease;
}

.cs_submit_1 input:hover {
  color: #2a2b2b;
  background-color: #fff;
}

@media (max-width: 919px) {
  .cs_submit_1 {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10px;
    min-width: auto;
    width: calc(100% - 40px);
  }
}

/* ---------------------------------------------------- */
/* cs_sec_breadcrumb_wrap */
/* ---------------------------------------------------- */
.cs_sec_breadcrumb_wrap {
  margin-top: 50px;
  padding: 15px 0;
  border-top: 1px solid #bdbdbe;
}

.cs_sec_breadcrumb_wrap ul {
  display: flex;
}

.cs_sec_breadcrumb_wrap ul li {
  display: flex;
  font-size: 1.2rem;
  line-height: 1;
}

.cs_sec_breadcrumb_wrap ul li + li:before {
  content: ">";
  margin: 0 10px;
}

.cs_sec_breadcrumb_wrap ul li:last-child {
  overflow: hidden;
}

.cs_sec_breadcrumb_wrap ul a,
.cs_sec_breadcrumb_wrap ul span {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.cs_sec_breadcrumb_wrap ul a:hover {
  opacity: 0.6;
}

@media (max-width: 919px) {
  .cs_sec_breadcrumb_wrap {
    margin-top: 35px;
    padding: 10px 0;
  }

  .cs_sec_breadcrumb_wrap ul li {
    font-size: 1.1rem;
  }

  .cs_sec_breadcrumb_wrap ul li + li:before {
    margin: 0 5px;
  }
}

/* ---------------------------------------------------- */
/* cs_sec_populartag_wrap */
/* ---------------------------------------------------- */
.cs_sec_populartag_wrap .list {
  margin-bottom: -20px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.cs_sec_populartag_wrap .list li {
  margin-bottom: 20px;
  margin-left: 5px;
  margin-right: 5px;
}

.cs_sec_populartag_wrap .list a {
  display: block;
  font-size: 1.2rem;
  color: #4f4f4f;
  text-decoration: underline;
  line-height: 1;
}

.cs_sec_populartag_wrap .list a:hover {
  opacity: 0.6;
}

.cs_sec_populartag_wrap .list a:before {
  content: "#";
}

/* ---------------------------------------------------- */
/* cs_sec_alltag_wrap */
/* ---------------------------------------------------- */
.cs_sec_alltag_wrap .list {
  margin-bottom: -40px;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}

.cs_sec_alltag_wrap .list li {
  margin-bottom: 40px;
  margin-right: 40px;
}

.cs_sec_alltag_wrap .list a {
  display: block;
  text-decoration: underline;
  line-height: 1;
}

.cs_sec_alltag_wrap .list a:hover {
  opacity: 0.6;
}

.cs_sec_alltag_wrap .list a:before {
  content: "#";
}

@media (max-width: 919px) {
  .cs_sec_alltag_wrap .list {
    margin-bottom: -20px;
  }

  .cs_sec_alltag_wrap .list li {
    margin-bottom: 20px;
    margin-right: 20px;
  }

  .cs_sec_alltag_wrap .list a {
    font-size: 1.2rem;
  }
}

/* ---------------------------------------------------- */
/* cs_archive_1 */
/* ---------------------------------------------------- */
.cs_archive_1 {
  display: flex;
  flex-wrap: wrap;
}

@media (min-width: 920px) {
  .cs_archive_1 {
    margin-bottom: -40px;
  }

  .cs_archive_1 li {
    margin-bottom: 40px;
  }

  .cs_archive_1.cs_archive_clm_4_pc {
    margin-right: -25px;
  }

  .cs_archive_1.cs_archive_clm_4_pc li {
    margin-right: 25px;
    width: calc(25% - 25px);
  }

  .cs_archive_1.cs_archive_clm_3_pc {
    margin-right: -40px;
  }

  .cs_archive_1.cs_archive_clm_3_pc li {
    margin-right: 40px;
    width: calc(33.33% - 40px);
  }

  .cs_archive_1.cs_archive_clm_2_pc {
    margin-right: -40px;
  }

  .cs_archive_1.cs_archive_clm_2_pc li {
    margin-right: 40px;
    width: calc(50% - 40px);
  }

  .cs_archive_1.cs_archive_clm_rand_1_pc {
    margin-right: -40px;
  }

  .cs_archive_1.cs_archive_clm_rand_1_pc li {
    margin-right: 40px;
    width: calc(33.33% - 40px);
  }

  .cs_archive_1.cs_archive_clm_rand_1_pc li:nth-child(4),
  .cs_archive_1.cs_archive_clm_rand_1_pc li:nth-child(5),
  .cs_archive_1.cs_archive_clm_rand_1_pc li:nth-child(9),
  .cs_archive_1.cs_archive_clm_rand_1_pc li:nth-child(10) {
    width: calc(50% - 40px);
  }
}

@media (max-width: 919px) {
  .cs_archive_1 {
    margin-bottom: -20px;
  }

  .cs_archive_1 li {
    margin-bottom: 20px;
  }

  .cs_archive_1.cs_archive_clm_2_sp {
    margin-right: -15px;
  }

  .cs_archive_1.cs_archive_clm_2_sp li {
    margin-right: 15px;
    width: calc(50% - 15px);
  }

  .cs_archive_1.cs_archive_clm_1_sp li {
    width: 100%;
  }

  .cs_archive_1.cs_archive_clm_rand_1_sp {
    margin-right: -15px;
  }

  .cs_archive_1.cs_archive_clm_rand_1_sp li {
    margin-right: 15px;
    width: calc(50% - 15px);
  }

  .cs_archive_1.cs_archive_clm_rand_1_sp li:nth-child(1) {
    width: calc(100% - 15px);
  }
}

/* ---------------------------------------------------- */
/* cs_archive_2 */
/* ---------------------------------------------------- */
.cs_archive_2 {
  display: flex;
  flex-wrap: wrap;
}

@media (min-width: 920px) {
  .cs_archive_2 {
    margin-bottom: -80px;
  }

  .cs_archive_2 li {
    margin-bottom: 80px;
  }

  .cs_archive_2.cs_archive_clm_1_pc {
  }

  .cs_archive_2.cs_archive_clm_1_pc li {
    width: 100%;
  }
}

@media (max-width: 919px) {
  .cs_archive_2 {
    margin-bottom: -35px;
  }

  .cs_archive_2 li {
    margin-bottom: 35px;
  }

  .cs_archive_2.cs_archive_clm_1_sp {
  }

  .cs_archive_2.cs_archive_clm_1_sp li {
    width: 100%;
  }
}

/* ---------------------------------------------------- */
/* cs_archive_max */
/* ---------------------------------------------------- */
.cs_archive_max_13 > li:nth-child(n + 14) {
  display: none;
}

/* ---------------------------------------------------- */
/* cs_archive_slide_1 */
/* ---------------------------------------------------- */

.cs_archive_slide_1 {
  margin: 0 -12.5px;
}

.cs_archive_slide_1 .cs_archive_item_1 {
  margin: 0 12.5px;
}

.cs_archive_slide_1 .slick-next,
.cs_archive_slide_1 .slick-prev {
  position: absolute;
  top: 43%;
  text-indent: -9999px;
  display: block;
  width: 40px;
  height: 40px;
  border: none;
  padding: 0;
  outline: 0;
  z-index: 10;
  cursor: pointer;
  background-color: rgba(0, 0, 0, 0.3);
  transition: 0.3s ease-in-out;
}

.cs_archive_slide_1 .slick-next:hover,
.cs_archive_slide_1 .slick-prev:hover {
  background-color: rgba(255, 255, 255, 0.3);
}

.cs_archive_slide_1 .slick-prev:before,
.cs_archive_slide_1 .slick-next:before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  height: 14px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translate(-80%, -50%) rotate(45deg);
  transition: 0.3s ease-in-out;
}

.cs_archive_slide_1 .slick-prev:hover:before,
.cs_archive_slide_1 .slick-next:hover:before {
  border-color: #2a2b2b;
}

.cs_archive_slide_1 .slick-next {
  right: 20px;
  transform: translateY(-50%) rotate(0deg);
}

.cs_archive_slide_1 .slick-prev {
  left: 20px;
  transform: translateY(-50%) rotate(-180deg);
}

@media (max-width: 919px) {
  .cs_archive_slide_1 .slick-next,
  .cs_archive_slide_1 .slick-prev {
    width: 30px;
    height: 30px;
  }

  .cs_archive_slide_1 .slick-prev:before,
  .cs_archive_slide_1 .slick-next:before {
    width: 10px;
    height: 10px;
  }
}

/* ---------------------------------------------------- */
/* cs_archive_item_1 */
/* ---------------------------------------------------- */
.cs_archive_item_1 .thumb {
  display: block;
}

.cs_archive_item_1 .thumb span {
  position: relative;
  display: block;
  padding-top: 75%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-image: url(../img/blank_item_1.png);
  transition: 0.3s ease-in-out;
}

.cs_archive_item_1 .thumb.size_contain span {
  background-size: contain;
}

.cs_archive_item_1 .thumb span:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: #2a2b2b;
  transition: 0.3s ease-in-out;
  opacity: 0;
}

.cs_archive_item_1 .thumb:hover span:before {
  opacity: 0.2;
}

.cs_archive_item_1.post_job.event_end .thumb span::after {
  content: "【掲載終了】";
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  color: #fff;
  font-size: 2rem;
  font-family: "Lato", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  background-color: rgba(0, 0, 0, 0.4);
  line-height: 1;
  transition: 0.3s ease-in-out;
}

.cs_archive_item_1 .detail {
  margin-top: 5px;
}

.cs_archive_item_1 .detail a,
.cs_archive_item_1 .detail span {
  display: inline-block;
  font-size: 1rem;
  color: #898989;
  font-weight: 300;
  line-height: 1;
}

.cs_archive_item_1 .detail * + * {
  margin-left: 8px;
  padding-left: 8px;
  border-left: 1px solid #898989;
}

.cs_archive_item_1 .ttl {
  display: block;
}

.cs_archive_item_1 .ttl_1 {
  margin-top: 5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
}

.cs_archive_item_1.event_end .ttl_1::before {
  content: "[Ended]";
}

.cs_archive_item_1 .ttl_2 {
  margin-top: 5px;
  font-size: 1.1rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
  transition: 0.3s ease-in-out;
}

.cs_archive_item_1:hover .ttl_2 {
  color: #2a2b2b;
}

.cs_archive_item_1.event_end .ttl_2::before {
  content: "【終了】";
}

.cs_archive_item_1 .ttl_2 {
  margin-top: 5px;
  font-size: 1.1rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
  transition: 0.3s ease-in-out;
}

.cs_archive_item_1 .term {
  margin-top: 5px;
  font-size: 1rem;
  color: #898989;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cs_archive_item_1 .term span + span {
  margin-left: 5px;
}

.cs_archive_item_1 .term span::before {
  content: "#";
}

.cs_archive_item_1 .refer a {
  font-size: 1rem;
  color: #898989;
}

.cs_archive_item_1 .sponsor {
  margin-top: 5px;
  font-size: 1rem;
  color: #898989;
  text-align: right;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cs_archive_item_1 .sponsor span {
  margin-right: 8px;
}

/* ---------------------------------------------------- */
/* cs_archive_item_2 */
/* ---------------------------------------------------- */
.cs_archive_item_2 .thumb {
  display: block;
}

.cs_archive_item_2 .thumb span {
  position: relative;
  display: block;
  padding-top: 56.25%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-image: url(../img/blank_item_2.png);
  transition: 0.3s ease-in-out;
}

.cs_archive_item_2 .thumb.size_contain span {
  background-size: contain;
}

.cs_archive_item_2 .thumb span:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: #2a2b2b;
  transition: 0.3s ease-in-out;
  opacity: 0;
}

.cs_archive_item_2 .thumb:hover span:before {
  opacity: 0.2;
}

.cs_archive_item_2 .detail {
  margin-top: 20px;
}

.cs_archive_item_2 .detail a,
.cs_archive_item_2 .detail span {
  display: inline-block;
  font-size: 1rem;
  color: #898989;
  font-weight: 300;
  line-height: 1;
}

.cs_archive_item_2 .detail * + * {
  margin-left: 8px;
  padding-left: 8px;
  border-left: 1px solid #898989;
}

.cs_archive_item_2 .ttl {
  margin-top: 20px;
  display: block;
  font-size: 1.8rem;
  line-height: 1.4;
  text-align: left;
}

.cs_archive_item_2 .desc {
  margin-top: 20px;
  line-height: 1.4;
  text-align: left;
}

.cs_archive_item_2 .btn_wrap {
  margin-top: 50px;
  text-align: center;
}

.cs_archive_item_2 .sponsor {
  margin-top: 5px;
  font-size: 1rem;
  color: #898989;
  text-align: right;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cs_archive_item_2 .sponsor span {
  margin-right: 8px;
}

@media (max-width: 919px) {
  .cs_archive_item_2 .detail {
    margin-top: 10px;
  }

  .cs_archive_item_2 .ttl {
    margin-top: 10px;
    font-size: 1.4rem;
  }

  .cs_archive_item_2 .desc {
    margin-top: 10px;
    font-size: 1.1rem;
  }

  .cs_archive_item_2 .btn_wrap {
    margin-top: 20px;
  }
}

/* ---------------------------------------------------- */
/* cs_widget_term_1 */
/* ---------------------------------------------------- */
.cs_widget_term_1 .list {
  padding: 35px 0;
  border-top: 1px solid #bdbdbe;
  border-bottom: 1px solid #bdbdbe;
}

.cs_widget_term_1 .list li.all {
}

.cs_widget_term_1 .list li:nth-child(2) {
  margin-top: 35px;
  padding-top: 35px;
  border-top: 1px solid #bdbdbe;
}

.cs_widget_term_1 .list li + li {
  padding-top: 20px;
}

.cs_widget_term_1 .list li.all + li {
  padding-top: 35px;
}

.cs_widget_term_1 .list a:hover {
  opacity: 0.6;
}

/* ---------------------------------------------------- */
/* cs_widget_search_1 */
/* ---------------------------------------------------- */

.cs_widget_search_1 .block {
  padding: 50px 0;
  border-bottom: 1px solid #bdbdbe;
}

.cs_widget_search_1 .ttl {
  margin-bottom: 20px;
  font-size: 1.1rem;
  line-height: 1;
}

.cs_widget_search_1 * + .ttl {
  margin-bottom: 20px;
  font-size: 1.1rem;
  line-height: 1;
}

.cs_widget_search_1 .keyword {
  padding: 8px;
  margin: 0;
  width: 100%;
  background-color: #fff;
  border: 1px solid #2a2b2b;
  outline: none;
  -webkit-appearance: none;
  border-radius: 5px;
}

.cs_widget_search_1 .keyword::placeholder {
  color: #e4e4e4;
}

.cs_widget_search_1 .keyword::-ms-input-placeholder {
  color: #e4e4e4;
}

.cs_widget_search_1 .list input[type="checkbox"] {
  display: none;
}

.cs_widget_search_1 .list li + li {
  margin-top: 10px;
}

.cs_widget_search_1 .list label {
  position: relative;
  padding-left: 20px;
  display: inline-block;
  line-height: 1.1;
}

.cs_widget_search_1 .list span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 14px;
  height: 14px;
  border: 1px solid #2a2b2b;
  background-color: #fff;
}

.cs_widget_search_1 .list input[type="checkbox"]:checked + span {
}

.cs_widget_search_1 .list input[type="checkbox"]:checked + span::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 4px;
  width: 6px;
  height: 12px;
  transform: rotate(40deg);
  border-bottom: 3px solid #2a2b2b;
  border-right: 3px solid #2a2b2b;
}

.cs_widget_search_1 .btn_submit {
  margin-top: 50px;
  width: 100%;
  min-width: 100%;
}

.cs_widget_search_1 .btn_contact {
  margin-bottom: 30px;
  width: 100%;
  min-width: 100%;
  height: 45px;
}

@media (min-width: 920px) {
  .cs_widget_search_1 .keyword {
    font-size: 1.2rem;
    border-radius: 5px;
  }
}

@media (max-width: 919px) {
  .cs_widget_search_1 .block {
    padding: 25px 0;
  }

  .cs_widget_search_1 .btn_submit {
    margin-top: 25px;
  }
}

/* ---------------------------------------------------- */
/* cs_advanced_wrap */
/* ---------------------------------------------------- */
.cs_advanced_wrap {
  margin-bottom: 40px;
}

.cs_advanced_wrap .toggle_wrap {
  display: none;
  margin: 10px 20px 0;
  padding: 15px;
  border: 1px solid #2a2b2b;
}

/* ---------------------------------------------------- */
/* cs_post_meta */
/* ---------------------------------------------------- */
.cs_post_meta {
  border-top: 1px solid #bdbdbe;
  border-bottom: 1px solid #bdbdbe;
}

.cs_post_meta > div + div {
  border-top: 1px solid #bdbdbe;
}

.cs_post_meta .tag,
.cs_post_meta .share {
  display: flex;
  font-size: 1.2rem;
}

.cs_post_meta .tag {
  padding: 25px 10%;
}

.cs_post_meta .share {
  padding: 10px 10%;
  align-items: center;
}

.cs_post_meta .tag .ttl,
.cs_post_meta .share .ttl {
  flex: none;
  width: 110px;
}

.cs_post_meta .tag .list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: -10px;
}

.cs_post_meta .tag .list li {
  margin-bottom: 10px;
  margin-right: 10px;
}

.cs_post_meta .tag .list a {
  display: block;
}

.cs_post_meta .tag .list a:hover {
  opacity: 0.6;
}

.cs_post_meta .tag .list a:before {
  content: "#";
}

.cs_post_meta .share .list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: -10px;
}

.cs_post_meta .share .list li {
  margin-bottom: 10px;
  margin-right: 10px;
}

.cs_post_meta .share .list a {
  display: block;
  width: 30px;
  height: 30px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.cs_post_meta .share .list .fb {
  background-image: url(../img/ico/share_fb_2.svg);
}

.cs_post_meta .share .list .tw {
  background-image: url(../img/ico/share_tw_2.svg);
}

.cs_post_meta .share .list .ht {
  background-image: url(../img/ico/share_ht_2.svg);
}

.cs_post_meta .share .list .li {
  background-image: url(../img/ico/share_li_2.svg);
}

.cs_post_meta .share .list .wpulike {
  padding: 0;
  width: 31px;
  height: 31px;
  transition: 0.3s ease-in-out;
}

.cs_post_meta .share .list .wpulike:hover {
  opacity: 0.6;
}

.cs_post_meta .share .list .wp_ulike_general_class {
  width: 100% !important;
  height: 100% !important;
  background-image: url(../img/ico/share_fblike_1.svg);
}

.cs_post_meta .share .list .wp_ulike_is_unliked {
  opacity: 0.6;
}

.cs_post_meta .share .list .wpulike .wp_ulike_btn {
  opacity: 0;
  padding: 0;
  min-width: 100%;
  min-height: 100%;
  width: 100% !important;
  height: 100% !important;
}

.cs_post_meta .share .list .count-box {
  display: none;
}

.cs_post_meta .profile {
  display: flex;
  justify-content: space-between;
  padding: 60px 15%;
}

.cs_post_meta .profile .block {
  width: 45%;
}

.cs_post_meta .profile .img * + * {
  margin-top: 10px;
}

.cs_post_meta .profile .block > * + * {
  margin-top: 30px;
}

.cs_post_meta .profile .name {
  font-size: 1.6rem;
  line-height: 1.7;
}

.cs_post_meta .profile .desc {
  font-size: 1.2rem;
  text-align: left;
  line-height: 1.7;
}

.cs_post_meta .profile .name + .desc {
  margin-top: 10px;
}

.cs_post_meta .profile .website li + li {
  margin-top: 5px;
}

.cs_post_meta .profile .website a {
  word-break: break-all;
}

.cs_post_meta .profile .sns {
  display: flex;
}

.cs_post_meta .profile .sns a {
  display: block;
  width: 20px;
  height: 20px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.cs_post_meta .profile .sns a.tw {
  background-image: url(../img/ico/sns_tw_3.svg);
}

.cs_post_meta .profile .sns a.in {
  background-image: url(../img/ico/sns_in_3.svg);
}

.cs_post_meta .profile .sns a.fb {
  background-image: url(../img/ico/sns_fb_3.svg);
}

.cs_post_meta .profile .sns a.yt {
  background-image: url(../img/ico/sns_yt_3.svg);
}

.cs_post_meta .profile .sns a + a {
  margin-left: 10px;
}

@media (max-width: 919px) {
  .cs_post_meta .tag {
    padding: 15px 15px;
  }

  .cs_post_meta .share {
    padding: 15px 15px;
  }

  .cs_post_meta .tag .ttl,
  .cs_post_meta .share .ttl {
    width: 65px;
  }

  .cs_post_meta .profile {
    display: block;
    padding: 30px 0;
  }

  .cs_post_meta .profile .block {
    width: 100%;
  }

  .cs_post_meta .profile .block + .block {
    margin-top: 20px;
  }

  .cs_post_meta .profile .block > * + * {
    margin-top: 25px;
  }

  .cs_post_meta .profile .name + .desc {
    margin-top: 15px;
  }

  .cs_post_meta .profile .website li + li {
    margin-top: 5px;
  }

  .cs_post_meta .profile .sns {
    display: flex;
  }

  .cs_post_meta .profile .sns a {
    display: block;
    width: 20px;
    height: 20px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
  }
}

/* ---------------------------------------------------- */
/* cs_post_contentsblock_1 */
/* ---------------------------------------------------- */
.cs_post_contentsblock_1 {
  margin-bottom: 80px;
}

.cs_post_contentsblock_1 .contentsblock_item + .contentsblock_item {
  margin-top: 80px;
}

/* cs_post_contentsblock_1 type_1 */
.cs_post_contentsblock_1 .type_1 {
  display: flex;
}

.cs_post_contentsblock_1 .type_1 .block {
  flex: auto;
  margin-left: auto;
  margin-right: auto;
  min-width: 47%;
  max-width: 800px;
}

.cs_post_contentsblock_1 .type_1 .block + .block {
  flex: none;
  margin-left: 6%;
  width: 47%;
}

.cs_post_contentsblock_1 .type_1 .block > * + * {
  margin-top: 30px;
}

.cs_post_contentsblock_1 .type_1 .ttl_1 {
  padding-bottom: 10px;
  font-size: 2rem;
  line-height: 1.7;
  text-align: left;
  border-bottom: 1px solid #bdbdbe;
}

/* cs_post_contentsblock_1 type_2 */
.cs_post_contentsblock_1 .type_2 {
  margin-left: auto;
  margin-right: auto;
  max-width: 800px;
}

.cs_post_contentsblock_1 .type_2 .caption {
  margin-top: 10px;
  font-size: 1.2rem;
  line-height: 1.4;
}

/* cs_post_gallery_3 */
.cs_post_contentsblock_1 .type_3 .gallery {
  max-width: 800px;
}

@media (max-width: 919px) {
  .cs_post_contentsblock_1 {
    margin-bottom: 40px;
  }

  .cs_post_contentsblock_1 .contentsblock_item + .contentsblock_item {
    margin-top: 40px;
  }

  .cs_post_contentsblock_1 .type_1 {
    flex-wrap: wrap;
  }

  .cs_post_contentsblock_1 .type_1 .block {
    width: 100%;
    max-width: 100%;
  }

  .cs_post_contentsblock_1 .type_1 .block + .block {
    margin-top: 40px;
    margin-left: 0;
    width: 100%;
  }

  .cs_post_contentsblock_1 .type_1 .block > * + * {
    margin-top: 15px;
  }

  .cs_post_contentsblock_1 .type_1 .ttl_1 {
    font-size: 1.8rem;
  }

  .cs_post_contentsblock_1 .type_2 {
    max-width: 100%;
  }

  .cs_post_contentsblock_1 .type_2 .caption {
    margin-top: 5px;
    font-size: 1.1rem;
  }

  .cs_post_contentsblock_1 .type_3 .gallery {
    max-width: 100%;
  }
}

/* ---------------------------------------------------- */
/* cs_post_contentsblock_2 */
/* ---------------------------------------------------- */
.cs_post_contentsblock_2 .contentsblock_item + .contentsblock_item {
  padding-top: 70px;
  margin-top: 70px;
  border-top: 1px solid #bdbdbe;
}

.cs_post_contentsblock_2 .type_1 .ttl {
  padding-bottom: 10px;
  font-size: 2rem;
  line-height: 1.4;
  border-bottom: 1px solid #bdbdbe;
}

.cs_post_contentsblock_2 .type_1 .ttl + .content {
  margin-top: 25px;
}

.cs_post_contentsblock_2 .type_1 * + .ttl_en,
.cs_post_contentsblock_2 .type_1 .ttl_ja + .content_en,
.cs_post_contentsblock_2 .type_1 .content_ja + .content_en {
  margin-top: 90px;
}

.cs_post_contentsblock_2 .type_2 .ttl {
  font-size: 1.4rem;
  line-height: 1.4;
}

.cs_post_contentsblock_2 .type_2 .ttl + .content {
  margin-top: 10px;
}

.cs_post_contentsblock_2 .type_2 * + .ttl_en,
.cs_post_contentsblock_2 .type_2 .ttl_ja + .content_en,
.cs_post_contentsblock_2 .type_2 .content_ja + .content_en {
  margin-top: 50px;
}

.cs_post_contentsblock_2 .btn_wrap {
  margin-top: 60px;
}

.cs_post_contentsblock_2 .btn_wrap a {
  display: block;
  margin-left: auto;
  margin-right: auto;
  width: 350px;
  max-width: 100%;
}

.cs_post_contentsblock_2 .btn_wrap a + a {
  margin-top: 20px;
}

@media (min-width: 920px) {
  .cs_post_contentsblock_2 .btn_wrap a {
    display: block;
    margin-left: auto;
    margin-right: auto;
    width: 350px;
    max-width: 100%;
  }
}

@media (max-width: 919px) {
  .cs_post_contentsblock_2 .contentsblock_item + .contentsblock_item {
    padding-top: 50px;
    margin-top: 50px;
  }

  .cs_post_contentsblock_2 .type_1 .ttl {
    font-size: 1.9rem;
  }

  .cs_post_contentsblock_2 .type_1 .ttl + .content {
    margin-top: 18px;
  }

  .cs_post_contentsblock_2 .type_1 * + .ttl_en,
  .cs_post_contentsblock_2 .type_1 .ttl_ja + .content_en,
  .cs_post_contentsblock_2 .type_1 .content_ja + .content_en {
    margin-top: 50px;
  }

  .cs_post_contentsblock_2 .type_2 * + .ttl_en,
  .cs_post_contentsblock_2 .type_2 .ttl_ja + .content_en,
  .cs_post_contentsblock_2 .type_2 .content_ja + .content_en {
    margin-top: 50px;
  }

  .cs_post_contentsblock_2 .btn_wrap {
    margin-top: 50px;
  }
}

/* ---------------------------------------------------- */
/* cs_post_gallery_1 */
/* ---------------------------------------------------- */
.cs_post_gallery_1 {
}

.cs_post_gallery_1 .gallery {
  margin: 0 auto;
  padding-bottom: 20px;
}

.cs_post_gallery_1 .gallery .img {
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

.cs_post_gallery_1 .gallery .img {
  padding-top: 75%;
}

.cs_post_gallery_1.ratio_4x3 .gallery .img {
  padding-top: 75%;
}

.cs_post_gallery_1.ratio_16x9 .gallery .img {
  padding-top: 56.25%;
}

.cs_post_gallery_1 .gallery .caption {
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 1.2rem;
  line-height: 1.4;
}

.cs_post_gallery_1 .slick-dots {
  position: absolute;
  bottom: 0;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}

.cs_post_gallery_1 .slick-dots li {
  position: relative;
  display: inline-block;
  width: 12px;
  height: 12px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}

.cs_post_gallery_1 .slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 10px;
  height: 10px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}

.cs_post_gallery_1 .slick-dots li button:hover,
.cs_post_gallery_1.slick-dots li button:focus {
  outline: none;
}

.cs_post_gallery_1 .slick-dots li button:hover:before,
.cs_post_gallery_1 .slick-dots li button:focus:before {
  opacity: 1;
}

.cs_post_gallery_1 .slick-dots li button:before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 100%;
  background-color: #898989;
  opacity: 0.6;
  transition: 0.3s ease-in-out;
}

.cs_post_gallery_1 .slick-dots li.slick-active button:before {
  opacity: 1;
}

.cs_post_gallery_1 .slick-next,
.cs_post_gallery_1 .slick-prev {
  position: absolute;
  top: 50%;
  text-indent: -9999px;
  display: block;
  width: 40px;
  height: 40px;
  border: none;
  padding: 0;
  outline: 0;
  z-index: 10;
  cursor: pointer;
  background-color: rgba(0, 0, 0, 0.3);
  transition: 0.3s ease-in-out;
}

.cs_post_gallery_1 .slick-next:hover,
.cs_post_gallery_1 .slick-prev:hover {
  background-color: rgba(255, 255, 255, 0.3);
}

.cs_post_gallery_1 .slick-prev:before,
.cs_post_gallery_1 .slick-next:before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  height: 14px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translate(-80%, -50%) rotate(45deg);
  transition: 0.3s ease-in-out;
}

.cs_post_gallery_1 .slick-prev:hover:before,
.cs_post_gallery_1 .slick-next:hover:before {
  border-color: #2a2b2b;
}

.cs_post_gallery_1 .slick-next {
  right: 10px;
  transform: translateY(-50%) rotate(0deg);
}

.cs_post_gallery_1 .slick-prev {
  left: 10px;
  transform: translateY(-50%) rotate(-180deg);
}

@media (max-width: 919px) {
  .cs_post_gallery_1 .gallery .caption {
    padding-top: 5px;
    padding-bottom: 5px;
    font-size: 1.1rem;
  }

  .cs_post_gallery_1 .slick-next,
  .cs_post_gallery_1 .slick-prev {
    width: 30px;
    height: 30px;
  }

  .cs_post_gallery_1 .slick-prev:before,
  .cs_post_gallery_1 .slick-next:before {
    width: 10px;
    height: 10px;
  }
}

/* ---------------------------------------------------- */
/* cs_post_gallery_2 */
/* ---------------------------------------------------- */
.cs_post_gallery_2 > .cs_post_item + .cs_post_item {
  margin-top: 40px;
}

.cs_post_gallery_2 > .cs_post_item .caption {
  margin-top: 10px;
  font-size: 1.2rem;
  line-height: 1.4;
}

@media (max-width: 919px) {
  .cs_post_gallery_2 > .cs_post_item + .cs_post_item {
    margin-top: 15px;
  }

  .cs_post_gallery_2 > .cs_post_item .caption {
    margin-top: 5px;
    font-size: 1.1rem;
  }
}

/* ---------------------------------------------------- */
/* cs_post_table_1 */
/* ---------------------------------------------------- */
.cs_post_table_1 table {
  width: 100%;
  border: 1px solid #aeb9c4;
  word-break: break-all;
}

.cs_post_table_1 caption {
  position: relative;
  padding-left: 1.2em;
  margin-bottom: 15px;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.4;
}

.cs_post_table_1 caption:before {
  content: "■";
  position: absolute;
  left: 0;
  top: 0;
}

.cs_post_table_1 th,
.cs_post_table_1 td {
  padding: 15px 20px;
  border: 1px solid #bdbdbe;
  vertical-align: top;
}

@media (max-width: 919px) {
  .cs_post_table_1 caption {
    margin-bottom: 10px;
    font-size: 1.6rem;
  }

  .cs_post_table_scroll_sp {
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
  }

  .cs_post_table_line_sp table,
  .cs_post_table_line_sp caption,
  .cs_post_table_line_sp thead,
  .cs_post_table_line_sp tbody,
  .cs_post_table_line_sp tr,
  .cs_post_table_line_sp th,
  .cs_post_table_line_sp td {
    display: block;
    width: 100%;
  }

  .cs_post_table_line_sp table {
    border: none;
    border-bottom: 1px solid #bdbdbe;
  }

  .cs_post_table_line_sp th,
  .cs_post_table_line_sp td {
    border-bottom: none;
  }

  .cs_post_table_line_sp th {
    padding: 10px 10px;
  }

  .cs_post_table_line_sp td {
    padding: 10px 10px 10px 20px;
    font-size: 1.2rem;
  }
}

/* ---------------------------------------------------- */
/* cs_pagination_archive_wrap */
/* ---------------------------------------------------- */
.cs_pagination_archive .count {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 30px;
}

.cs_pagination_archive .count:before {
  content: "PAGE";
  margin-right: 10px;
}

.cs_pagination_archive .count .total {
  display: none;
}

.cs_pagination_archive .pagination {
  display: flex;
  justify-content: center;
  align-items: center;
}

.cs_pagination_archive .pagination:before {
  content: "PAGE";
  margin-right: 10px;
}

.cs_pagination_archive .pagination .page-numbers {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 4px;
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  background-color: #fff;
  border: 1px solid #2a2b2b;
}

.cs_pagination_archive .pagination .page-numbers:hover,
.cs_pagination_archive .pagination .current {
  color: #fff;
  background-color: #2a2b2b;
}

.cs_pagination_archive .pagination .dots,
.cs_pagination_archive .pagination .dots:hover {
  color: #1a232a;
  background-color: transparent;
  border: 1px solid #fff;
}

@media (max-width: 919px) {
  .cs_pagination_archive .pagination:before {
    content: "";
    margin-right: 0;
  }
}

/* ---------------------------------------------------- */
/* cs_msgblank */
/* ---------------------------------------------------- */
.cs_msgblank {
  padding: 50px 0;
  text-align: center;
}

/* ---------------------------------------------------- */
/* cs_fixed_1_wrap */
/* ---------------------------------------------------- */
.cs_fixed_1_wrap .btn_move {
  /* position: fixed;
    right: 15px;
    bottom: 15px; */
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  background-color: #2a2b2b;
  border-radius: 50%;
  box-shadow: 5px 5px 10px 0px rgba(0, 0, 0, 0.2);
  z-index: 2;
  flex-shrink: 0;
}

.cs_fixed_1_wrap .banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 16px;
  width: 100%;
  /* left: 15px;
  bottom: 15px; */
  display: flex;
  align-items: center;

  transform: translateY(75px);
  transition: 0.3s ease-in-out;
}

.cs_fixed_1_wrap .banner > * + * {
  margin-left: 12px;
}

.page_scroll .cs_fixed_1_wrap .btn_open {
  transform: translateY(0);
}

.cs_fixed_1_wrap .btn_move span::before,
.cs_fixed_1_wrap .btn_move span:after {
  content: "";
  position: absolute;
  left: 50%;
  width: 14px;
  height: 14px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateX(-50%) rotate(-45deg);
  transition: 0.3s ease-in-out;
}

.cs_fixed_1_wrap .btn_open span::before {
  top: 16px;
}

.cs_fixed_1_wrap .btn_open span:after {
  top: 26px;
}

.cs_fixed_1_wrap .btn_close {
  position: absolute;
  right: 15px;
  top: 15px;
  display: block;
  width: 15px;
  height: 15px;
}

.cs_fixed_1_wrap .btn_close > span:before,
.cs_fixed_1_wrap .btn_close > span:after {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  display: block;
  width: 100%;
  height: 2px;
  background-color: #2a2b2b;
  border-radius: 2px;
  transform-origin: center center;
  transition: 0.3s ease-in-out;
}

.cs_fixed_1_wrap .btn_close > span:before {
  transform: translateY(-50%) rotate(-45deg);
}

.cs_fixed_1_wrap .btn_close > span:after {
  bottom: 0;
  transform: translateY(-50%) rotate(45deg);
}

.cs_fixed_1_wrap .toggle_wrap {
  display: none;
  position: fixed;
  left: 0;
  bottom: 0;
  padding: 45px 15px 15px;
  width: 100%;
  background-color: #fff;
  z-index: 3;
}

.cs_fixed_1_wrap .btn_contact {
  display: block;
  height: 30px;
  border: 1px solid #2a2b2b;
  color: #fff;
  font-size: 1.3rem;
  text-align: center;
  text-decoration: none !important;
  background-color: #2a2b2b;
  border-radius: 3px;
}

.cs_fixed_1_wrap .btn_contact span {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 20px;
  width: 100%;
  height: 100%;
}

.cs_fixed_1_wrap .btn_contact span:after {
  content: "";
  position: absolute;
  right: 8px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateY(-50%) rotate(45deg);
  transition: 0.3s ease-in-out;
}

.cs_fixed_1_wrap .share {
  display: flex;
  align-items: center;
  padding-bottom: 15px;
  margin-bottom: 15px;
  border-bottom: 1px solid #bdbdbe;
}

.cs_fixed_1_wrap .share .ttl {
  flex: none;
  width: 65px;
  font-size: 1.2rem;
}

.cs_fixed_1_wrap .share .list {
  flex: auto;
  display: flex;
  justify-content: space-between;
  padding: 0 15px;
  margin-right: -10px;
  margin-bottom: -10px;
  width: auto;
}

.cs_fixed_1_wrap .share .list li {
  margin-bottom: 10px;
  margin-right: 10px;
}

.cs_fixed_1_wrap .share .list a {
  display: block;
  width: 30px;
  height: 30px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.cs_fixed_1_wrap .share .list .fb {
  background-image: url(../img/ico/share_fb_2.svg);
}

.cs_fixed_1_wrap .share .list .tw {
  background-image: url(../img/ico/share_tw_2.svg);
}

.cs_fixed_1_wrap .share .list .ht {
  background-image: url(../img/ico/share_ht_2.svg);
}

.cs_fixed_1_wrap .share .list .li {
  background-image: url(../img/ico/share_li_2.svg);
}

.cs_fixed_1_wrap .freespace_content {
  padding-bottom: 15px;
  margin-bottom: 15px;
  border-bottom: 1px solid #bdbdbe;
}

/* ---------------------------------------------------- */
/* cs_fixed_2_wrap */
/* ---------------------------------------------------- */
.cs_fixed_2_wrap {
  position: fixed;
  right: 0;
  bottom: 0;
  padding: 10px 25px;
  background-color: #dcdddd;
  z-index: 3;
}

.cs_fixed_2_wrap .share {
  display: flex;
  align-items: center;
}

.cs_fixed_2_wrap .share .ttl {
  flex: none;
  width: 50px;
  font-size: 1.2rem;
}

.cs_fixed_2_wrap .share .list {
  flex: auto;
  display: flex;
  justify-content: space-between;
  padding-left: 15px;
  margin-right: -10px;
  margin-bottom: -10px;
  width: auto;
}

.cs_fixed_2_wrap .share .list li {
  margin-bottom: 10px;
  margin-right: 10px;
}

.cs_fixed_2_wrap .share .list a {
  display: block;
  width: 30px;
  height: 30px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.cs_fixed_2_wrap .share .list .fb {
  background-image: url(../img/ico/share_fb_2.svg);
}

.cs_fixed_2_wrap .share .list .tw {
  background-image: url(../img/ico/share_tw_2.svg);
}

.cs_fixed_2_wrap .share .list .ht {
  background-image: url(../img/ico/share_ht_2.svg);
}

.cs_fixed_2_wrap .share .list .li {
  background-image: url(../img/ico/share_li_2.svg);
}

/* ---------------------------------------------------- */
/* cs_fixed_3_wrap */
/* ---------------------------------------------------- */
.cs_fixed_3_wrap {
  position: fixed;
  right: 0;
  bottom: 0;
  padding: 25px 40px;
  width: 100%;
  background-color: #dcdddd;
  z-index: 3;
}

.cs_fixed_3_wrap .btn_close {
  position: absolute;
  right: 15px;
  top: 15px;
  display: block;
  width: 20px;
  height: 20px;
}

.cs_fixed_3_wrap .btn_close > span:before,
.cs_fixed_3_wrap .btn_close > span:after {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  display: block;
  width: 100%;
  height: 2px;
  background-color: #2a2b2b;
  border-radius: 2px;
  transform-origin: center center;
  transition: 0.3s ease-in-out;
}

.cs_fixed_3_wrap .btn_close > span:before {
  transform: translateY(-50%) rotate(-45deg);
}

.cs_fixed_3_wrap .btn_close > span:after {
  bottom: 0;
  transform: translateY(-50%) rotate(45deg);
}

.cs_fixed_3_wrap .freespace_content {
  margin: 0 auto;
  max-width: 920px;
}

@media (max-width: 919px) {
  .cs_fixed_3_wrap {
    padding: 35px 15px 15px;
  }

  .cs_fixed_3_wrap .btn_close {
    position: absolute;
    right: 10px;
    top: 10px;
  }
}

.cs_fixed_4_wrap {
  position: fixed;
  bottom: 12px;
}

.cs_fixed_4_wrap.left {
  left: 12px;
}

.cs_fixed_4_wrap.right {
  right: 12px;
}

.cs_fixed_4_wrap .banner {
  width: 500px;
  height: 70px;
}

/* ---------------------------------------------------- */
/* cs_series_wrap_1 */
/* ---------------------------------------------------- */
.cs_series_wrap_1 {
  padding: 35px;
  background-color: #f0f0f0;
}

.cs_series_wrap_1 {
  margin-bottom: 25px;
}

.cs_series_wrap_1 .series_ttl {
  font-size: 2rem;
  padding-bottom: 25px;
  margin-bottom: 25px;
  border-bottom: 1px solid #2a2b2b;
}

.cs_series_wrap_1 .series_item + .series_item {
  margin-top: 15px;
}

@media (max-width: 919px) {
  .cs_series_wrap_1 {
    padding: 15px;
  }

  .cs_series_wrap_1 {
    margin-bottom: 20px;
  }

  .cs_series_wrap_1 .series_ttl {
    font-size: 1.6rem;
    padding-bottom: 15px;
    margin-bottom: 15px;
  }
}

/* ---------------------------------------------------- */
/* cs_series_item_1 */
/* ---------------------------------------------------- */
.cs_series_item_1 {
  display: flex;
  justify-content: space-between;
  color: #2a2b2b;
}

.cs_series_item_1.is_disable {
  pointer-events: none;
}

.cs_series_item_1 .thumb {
  flex: none;
  width: 36%;
  max-width: 145px;
}

.cs_series_item_1 .thumb span {
  position: relative;
  display: block;
  padding-top: 75%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-image: url(../img/blank_item_1.png);
  transition: 0.3s ease-in-out;
}

.cs_series_item_1 .thumb.size_contain span {
  background-size: contain;
}

.cs_series_item_1.is_disable .thumb span:before {
  content: "COMING SOON";
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  color: #fff;
  font-size: 1.1rem;
  font-family: "Lato", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  background-color: rgba(0, 0, 0, 0.8);
  line-height: 1;
  transition: 0.3s ease-in-out;
}

.cs_series_item_1 .meta {
  flex: auto;
  padding: 5px 0 0 20px;
  width: auto;
}

.cs_series_item_1 .detail {
  padding-bottom: 5px;
}

.cs_series_item_1 .detail span {
  display: inline-block;
  padding: 5px 10px;
  font-size: 1.1rem;
  font-weight: 300;
  line-height: 1;
}

.cs_series_item_1 .detail .cat {
  color: #fff;
  background-color: #2a2b2b;
}

.cs_series_item_1.is_current .detail .cat {
  color: #2a2b2b;
  background-color: #f5cd1e;
}

.cs_series_item_1 .ttl_1 {
  margin-top: 5px;
  font-size: 2rem;
  word-break: break-all;
}

.cs_series_item_1.event_end .ttl_1::before {
  content: "[Ended]";
}

.cs_series_item_1 .ttl_2 {
  margin-top: 5px;
  font-size: 1.7rem;
  word-break: break-all;
}

.cs_series_item_1.event_end .ttl_2::before {
  content: "【終了】";
}

.cs_series_item_1.is_disable .ttl_1,
.cs_series_item_1.is_disable .ttl_2 {
  opacity: 0.6;
}

@media (max-width: 919px) {
  .cs_series_item_1 .meta {
    padding: 0 0 0 15px;
  }

  .cs_series_item_1 .detail span {
    padding: 4px 8px;
    font-size: 1rem;
  }

  .cs_series_item_1 .ttl_1 {
    font-size: 1.4rem;
  }

  .cs_series_item_1 .ttl_2 {
    font-size: 1.2rem;
  }
}

/* ---------------------------------------------------- */
/* cs_freespace_wrap_1 */
/* ---------------------------------------------------- */
.cs_freespace_wrap_1 {
  padding: 35px;
  background-color: #dcdddd;
}

.cs_freespace_wrap_1 {
  margin-bottom: 25px;
}

.cs_freespace_wrap_1 .freespace_ttl {
  font-size: 2rem;
  padding-bottom: 25px;
  margin-bottom: 25px;
  border-bottom: 1px solid #2a2b2b;
}

@media (max-width: 919px) {
  .cs_freespace_wrap_1 {
    padding: 15px;
  }

  .cs_freespace_wrap_1 {
    margin-bottom: 20px;
  }

  .cs_freespace_wrap_1 .freespace_ttl {
    font-size: 1.6rem;
    padding-bottom: 15px;
    margin-bottom: 15px;
  }
}

/* ---------------------------------------------------- */
/* cs_newsletter_1 */
/* ---------------------------------------------------- */
.cs_newsletter_1 form {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}

.cs_newsletter_1 form * {
  margin-top: 0;
}

.cs_newsletter_1 .ttl {
  margin-right: 20px;
}

.cs_newsletter_1 .input {
  margin-right: 20px;
  width: 240px;
}

.cs_newsletter_1 .input input[type="text"] {
  padding: 6px;
  width: 100%;
  background-color: transparent;
  border: none;
  border-bottom: 1px solid #2a2b2b;
  -webkit-appearance: none;
  border-radius: 0;
}

.cs_newsletter_1 .btn_submit {
  position: relative;
  display: block;
  width: 100px;
}

.cs_newsletter_1 .btn_submit::after {
  content: "";
  position: absolute;
  right: 10px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-top: 1px solid #2a2b2b;
  border-right: 1px solid #2a2b2b;
  transform: translateY(-50%) rotate(45deg);
  transition: 0.3s ease-in-out;
}

.cs_newsletter_1 .btn_submit:hover::after {
  border-color: #fff;
}

.cs_newsletter_1 .btn_submit input[type="submit"] {
  display: block;
  width: 100%;
  color: #2a2b2b;
  line-height: 25px;
  text-decoration: none;
  border-radius: 4px;
  border: 1px solid #2a2b2b;
  background-color: transparent;
  cursor: pointer;
  outline: none;
  -webkit-appearance: none;
  transition: 0.3s ease-in-out;
}

.cs_newsletter_1 .btn_submit:hover input[type="submit"] {
  color: #fff;
  background-color: #2a2b2b;
}

@media (max-width: 919px) {
  .cs_newsletter_1 form * {
    margin-top: 0;
  }

  .cs_newsletter_1 .ttl {
    margin-right: 0;
    margin-bottom: 10px;
    width: 100%;
  }

  .cs_newsletter_1 .input {
    flex: none;
    width: calc(100% - 120px);
  }

  .cs_newsletter_1 .input input[type="text"] {
    font-size: 1.6rem;
  }

  .cs_newsletter_1 .btn_submit {
    flex: none;
  }
}

.sec_archive_wrap .banner {
  display: block;
  margin-bottom: 40px;
}

.banner-shadow {
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.5);
}
