/********************
cases
********************/
/*
hero
*/
.bsp.cases #hero {
  font-size: min(1.25vw, 18px);
}
.bsp.cases #hero .hero_wrap {
  position: relative;
  margin-top: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bsp.cases #hero .hero_wrap .bg_img {
  width: 100%;
}
.bsp.cases #hero .hero_wrap .hero_txt {
  position: absolute;
  text-align: center;
}
.bsp.cases #hero .hero_wrap .hero_txt .hero_lead {
  width: 2.39em;
  max-width: 43.08px;
  margin: 0 auto;
}
.bsp.cases #hero .hero_wrap .hero_txt h1 {
  font-size: min(2.78vw, 40px);
  line-height: 2.125;
  margin-top: 0.8em;
  color: #fff;
}

@media screen and (max-width: 1023px) {
  .bsp.cases #hero .hero_wrap {
    margin-top: 85px;
  }
}
@media screen and (max-width: 767px) {
  .bsp.cases #hero .hero_wrap {
    margin-top: calc(60px + 6.67vw);
  }
  .bsp.cases #hero .hero_wrap .hero_txt .hero_lead {
    width: 8.21vw;
    max-width: 8.21vw;
  }
  .bsp.cases #hero .hero_wrap .hero_txt h1 {
    font-size: 5.33vw;
    margin-top: 0.8em;
  }
}
/*
contents
*/
.bsp.cases #contents {
  font-size: min(1.25vw, 18px);
  margin-top: 4.4em;
}
.bsp.cases #contents > .ly_df {
  justify-content: space-between;
}
.bsp.cases #contents .main_column {
  width: 74.6%;
}
.bsp.cases #contents .main_column .bl_case_list {
  flex-wrap: wrap;
  margin: -1.67em auto 0;
  position: relative;
}
.bsp.cases #contents .main_column .bl_case_list .case_item {
  display: flex;
  flex-direction: column;
  width: 31.89%;
  text-align: left;
  background: #E5E2D9;
  margin-top: 1.67em;
}
.bsp.cases #contents .main_column .bl_case_list .case_item + .case_item {
  margin-left: 2.1622%;
}
.bsp.cases #contents .main_column .bl_case_list .case_item:nth-child(3n+1) {
  margin-left: 0;
}
.bsp.cases #contents .main_column .bl_case_list .case_item > a {
  display: block;
  align-self: start;
  overflow: hidden;
}
.bsp.cases #contents .main_column .bl_case_list .case_item > a img {
  transition: all 0.3s;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 1.39em 1.11em 1.94em;
  min-height: 11.44em;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt a.tag {
  display: flex;
  font-size: min(0.76vw, 11px);
  padding: 0 1.67em;
  height: 1.82em;
  background: #fff;
  border-radius: 2em;
  text-align: center;
  align-items: center;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt a.tag:hover {
  opacity: 0.7;
  transition: all 0.3s;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt a.tag + a.tag {
  margin-left: 0.42em;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt a.txt {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt p.ttl {
  font-size: min(1.11vw, 16px);
  line-height: 1.81;
  margin: 1.25em 0;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .term-description {
  font-size: min(0.83vw, 12px);
  line-height: 1.58;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt span.date {
  font-size: min(0.83vw, 12px);
  position: absolute;
  bottom: 2.5em;
  color: #808080;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more {
  display: block;
  position: relative;
  padding-right: 2em;
  margin-top: auto;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more:before {
  content: "";
  position: absolute;
  width: 7.91%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 91%;
  z-index: 1;
  transition: all 0.3s;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more:after {
  content: "";
  position: absolute;
  width: 2.5%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 96.2%;
  z-index: 1;
  transform: rotate(45deg);
  transform-origin: bottom right;
  transition: all 0.3s;
}
.bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more img {
  width: 4.96em;
  max-width: 89.33px;
  padding-top: 1.94em;
  margin: auto 0 0 auto;
}
.bsp.cases #contents .main_column .bl_case_list .case_item:hover > a img {
  transform: scale(1.1);
}
.bsp.cases #contents .main_column .bl_case_list .case_item:hover .case_item_txt .more:before {
  content: "";
  position: absolute;
  width: 9.91%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 91%;
  z-index: 1;
}
.bsp.cases #contents .main_column .bl_case_list .case_item:hover .case_item_txt .more:after {
  content: "";
  position: absolute;
  width: 2.5%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 98%;
  z-index: 1;
  transform: rotate(45deg);
  transform-origin: bottom right;
}
.bsp.cases #contents .sub_column {
  width: 20.16%;
  padding-top: 1.89em;
}
.bsp.cases #contents .sub_column .btn_modal {
  display: none;
}
.bsp.cases #contents .sub_column .sub_column_inner {
  display: block;
}
.bsp.cases #contents .sub_column .sub_column_lead {
  width: 100%;
  border-bottom: 1px solid #CBC3AC;
  padding: 1.39em 0;
}
.bsp.cases #contents .sub_column .sub_column_lead img {
  width: 7.33em;
  max-width: 131.96px;
}
.bsp.cases #contents .sub_column ul {
  list-style-type: none;
  width: 100%;
}
.bsp.cases #contents .sub_column ul li {
  border-bottom: 1px solid #CBC3AC;
  position: relative;
}
.bsp.cases #contents .sub_column ul li a {
  display: block;
  padding: 0.6em 0;
  font-size: min(0.97vw, 14px);
}
.bsp.cases #contents .sub_column ul li a:hover {
  opacity: 0.6;
  transition: all 0.3s;
}
.bsp.cases #contents .sub_column ul li span.btn_open {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 2.86em;
  height: 2.86em;
  font-size: min(0.97vw, 14px);
}
.bsp.cases #contents .sub_column ul li span.btn_open:before {
  content: "";
  display: block;
  width: 0.56em;
  height: 1px;
  background-color: #000;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.bsp.cases #contents .sub_column ul li span.btn_open:after {
  content: "";
  display: block;
  width: 0.56em;
  height: 1px;
  background-color: #000;
  position: absolute;
  top: 50%;
  left: 50%;
  opacity: 1;
  transform: translate(-50%, -50%) rotate(90deg);
  transition: transform 0.25s ease;
}
.bsp.cases #contents .sub_column ul li .header_btm {
  position: static;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  min-width: 100%;
  visibility: hidden;
  transition: 1s ease;
  background-color: transparent;
  transition: all 0.6s;
}
.bsp.cases #contents .sub_column ul li .header_btm .header_btm_ul {
  display: block;
  height: auto;
  margin-bottom: 10px;
}
.bsp.cases #contents .sub_column ul li .header_btm .header_btm_li {
  border: none;
}
.bsp.cases #contents .sub_column ul li .header_btm .header_btm_li a {
  padding: 1em 0;
  display: block;
}
.bsp.cases #contents .sub_column ul li.has_layer a {
  width: calc(100% - 2.13em);
}
.bsp.cases #contents .sub_column ul li.active span.btn_open:after {
  opacity: 0;
}
.bsp.cases #contents .sub_column ul li.active span.btn_open + .header_btm {
  /*max-height: calc( var(--vh) * 100 );*/
  max-height: fit-content;
  opacity: 1;
  visibility: visible;
}
.bsp.cases #contents .sub_column ul li.active span.btn_open + .header_btm .header_btm_ul {
  display: block;
  height: auto;
  margin-bottom: 1.22em;
}
.bsp.cases #contents .sub_column ul li.active span.btn_open + .header_btm .header_btm_li {
  border: none;
}
.bsp.cases #contents .sub_column ul li.active span.btn_open + .header_btm .header_btm_li a {
  padding: 0.71em 0;
  display: block;
  color: #000;
}
.bsp.cases #contents .sub_column .sub_column_box:nth-child(2) .sub_column_lead img {
  width: 4.03em;
  max-width: 72.52px;
}
.bsp.cases #contents .sub_column .sub_column_box + .sub_column_box {
  margin-top: 1.39em;
}
.bsp.cases #contents .btn_wrap {
  margin: 5.56em auto 0;
}
.bsp.cases #contents .btn_wrap .btn {
  display: block;
  width: 12.06em;
  margin: 0 auto;
  position: relative;
  padding-bottom: 1em;
}
.bsp.cases #contents .btn_wrap .btn img {
  width: 2.13em;
  max-width: 38.29px;
  margin: auto;
}
.bsp.cases #contents .btn_wrap .btn:before {
  content: "";
  position: absolute;
  width: 96%;
  height: 1px;
  background: #000;
  bottom: 0;
  right: 0;
  z-index: 1;
  transition: all 0.3s;
}
.bsp.cases #contents .btn_wrap .btn:after {
  content: "";
  position: absolute;
  width: 3%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 4%;
  z-index: 1;
  transform: rotate(-35deg);
  transition: all 0.3s;
  transform-origin: bottom left;
}
.bsp.cases #contents .btn_wrap .btn:hover:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background: #000;
  bottom: 0;
  right: 0;
  z-index: 1;
}
.bsp.cases #contents .btn_wrap .btn:hover:after {
  content: "";
  position: absolute;
  width: 3%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 0;
  z-index: 1;
  transform: rotate(-35deg);
}

@media screen and (max-width: 1023px) {
  .bsp.cases #contents {
    margin-top: 4.4em;
  }
  .bsp.cases #contents > .ly_df {
    flex-direction: column-reverse;
  }
  .bsp.cases #contents .main_column {
    width: 100%;
    margin-top: 2.33em;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more {
    padding-right: 2.5em;
  }
  .bsp.cases #contents .sub_column {
    width: fit-content;
    padding-top: 0;
    display: flex;
    margin-left: auto;
  }
  .bsp.cases #contents .sub_column .btn_modal {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 1.5em;
    height: 3.33em;
    border: 1px solid #000;
    border-radius: 4vw;
    margin-left: auto;
  }
  .bsp.cases #contents .sub_column .btn_modal img {
    width: 8.64em;
  }
  .bsp.cases #contents .sub_column .sub_column_inner {
    display: none;
  }
  .bsp.cases #contents .sub_column .sub_column_box:nth-child(2) .btn_modal {
    margin-left: 0.5em;
  }
  .bsp.cases #contents .sub_column .sub_column_box:nth-child(2) .btn_modal img {
    width: 4.84em;
  }
  .bsp.cases #contents .sub_column .sub_column_box + .sub_column_box {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .bsp.cases #contents {
    margin-top: 16.8vw;
  }
  .bsp.cases #contents .main_column {
    width: 100%;
    margin-top: 2.67vw;
  }
  .bsp.cases #contents .main_column .bl_case_list {
    padding-bottom: 13.33vw;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item {
    width: 100%;
    margin-top: 6.67vw;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item + .case_item {
    margin-left: 0;
    margin-top: 6.67vw;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item:nth-child(3n+1) {
    margin-left: 0;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt {
    padding: 5.33vw 5.33vw 8vw;
    min-height: 54.67vw;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt a.tag {
    font-size: 2.93vw;
    height: 5.33vw;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt p.ttl {
    font-size: 4.26vw;
    margin-top: 4vw;
    line-height: 1.81;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .term-description {
    font-size: 3.2vw;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt span.date {
    font-size: 3.2vw;
    bottom: 7vw;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more {
    padding-right: 8vw;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more:before {
    width: 5.33vw;
    left: 92%;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more:after {
    width: 1.5vw;
    left: 97%;
  }
  .bsp.cases #contents .main_column .bl_case_list .case_item .case_item_txt .more img {
    width: 23.82vw;
    max-width: 23.82vw;
    padding-top: 9.33vw;
    margin: auto 0 0 auto;
  }
  .bsp.cases #contents .sub_column .btn_modal {
    height: 8vw;
    border-radius: 4vw;
    padding: 0 3em;
  }
  .bsp.cases #contents .sub_column .btn_modal img {
    width: 21.11vw;
  }
  .bsp.cases #contents .sub_column .sub_column_box:nth-child(2) .btn_modal {
    margin-left: 1.5em;
  }
  .bsp.cases #contents .sub_column .sub_column_box:nth-child(2) .btn_modal img {
    width: 11.67vw;
  }
  .bsp.cases #contents .btn_wrap {
    margin-top: 16.8vw;
  }
  .bsp.cases #contents .btn_wrap .btn {
    width: 56vw;
    max-width: 56vw;
    padding-bottom: 4vw;
  }
  .bsp.cases #contents .btn_wrap .btn img {
    width: 10.21vw;
    max-width: 10.21vw;
  }
  .bsp.cases #contents .btn_wrap .btn:before {
    width: 100%;
  }
  .bsp.cases #contents .btn_wrap .btn:after {
    left: 0;
  }
}
/*
contact
*/
.bsp.cases #contact {
  font-size: min(1.25vw, 18px);
  margin-top: 11.11em;
  position: relative;
}
.bsp.cases #contact .bl_bg {
  position: absolute;
  width: 100%;
  padding-top: 4.17em;
}
.bsp.cases #contact .bl_contact_txt {
  padding: 4.17em 0 5.28em;
  width: 91.93%;
  max-width: 1140px;
  background: #0F2743;
  text-align: center;
  color: #fff;
  margin: auto;
}
.bsp.cases #contact .bl_contact_txt .contact_lead {
  width: 4.44em;
  max-width: 79.93px;
  margin: 0 auto;
}
.bsp.cases #contact .bl_contact_txt h2 {
  font-size: min(2.43vw, 35px);
  line-height: 1.86;
  margin-top: 0.8em;
}
.bsp.cases #contact .bl_contact_txt p {
  font-size: min(1.74vw, 25px);
  margin-top: 1.07em;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data {
  width: 47.91vw;
  max-width: 690px;
  margin: 2.94em auto 0;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt {
  width: 100%;
  white-space: nowrap;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt p {
  font-size: min(2.78vw, 40px);
  margin: 0;
  white-space: nowrap;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt p span {
  font-size: min(1.39vw, 20px);
  margin-right: 0.5em;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt p a.bl_tel {
  color: #fff;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt > span {
  font-size: min(0.97vw, 14px);
  letter-spacing: 0.05em;
  white-space: nowrap;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt > span + span {
  margin-left: 2em;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn {
  margin-top: 0.8em;
  margin-left: 3.89em;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn {
  position: relative;
  display: block;
  width: 100%;
  border: solid 1px #fff;
  font-size: min(1.11vw, 16px);
  padding: 1.51em 0;
  text-align: center;
  color: #fff;
  width: 20.75em;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn:before {
  content: "";
  position: absolute;
  width: 7.91%;
  height: 1px;
  background: #fff;
  top: 50%;
  left: 84%;
  transform: translateY(-50%);
  z-index: 1;
  transition: all 0.3s;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn:after {
  content: "";
  position: absolute;
  width: 2.3%;
  height: 1px;
  background: #fff;
  top: 49.5%;
  left: 89.2%;
  z-index: 1;
  transform: translateY(-50%) rotate(35deg);
  transform-origin: bottom right;
  transition: all 0.3s;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn:hover:before {
  content: "";
  position: absolute;
  width: 9.91%;
  height: 1px;
  background: #fff;
  top: 50%;
  left: 84%;
  z-index: 1;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn:hover:after {
  content: "";
  position: absolute;
  width: 2.3%;
  height: 1px;
  background: #fff;
  top: 49%;
  left: 91.5%;
  z-index: 1;
  transform: rotate(35deg);
  transform-origin: bottom right;
}
.bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn span {
  margin-left: -2em;
  letter-spacing: -0.03em;
}
.bsp.cases #contact .btn_wrap {
  margin: 8.61em auto 0;
}
.bsp.cases #contact .btn_wrap .btn {
  display: block;
  width: 12.06em;
  margin: 0 auto;
  position: relative;
  padding-bottom: 1em;
}
.bsp.cases #contact .btn_wrap .btn img {
  width: 2.13em;
  max-width: 38.29px;
  margin: auto;
}
.bsp.cases #contact .btn_wrap .btn:before {
  content: "";
  position: absolute;
  width: 96%;
  height: 1px;
  background: #000;
  bottom: 0;
  right: 0;
  z-index: 1;
  transition: all 0.3s;
}
.bsp.cases #contact .btn_wrap .btn:after {
  content: "";
  position: absolute;
  width: 3%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 4%;
  z-index: 1;
  transform: rotate(-35deg);
  transition: all 0.3s;
  transform-origin: bottom left;
}
.bsp.cases #contact .btn_wrap .btn:hover:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background: #000;
  bottom: 0;
  right: 0;
  z-index: 1;
}
.bsp.cases #contact .btn_wrap .btn:hover:after {
  content: "";
  position: absolute;
  width: 3%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 0;
  z-index: 1;
  transform: rotate(-35deg);
}

@media screen and (max-width: 767px) {
  .bsp.cases #contact {
    margin-top: 26.67vw;
  }
  .bsp.cases #contact .bl_bg {
    padding-top: 17.33vw;
  }
  .bsp.cases #contact .bl_inner {
    padding: 0 5.33vw;
  }
  .bsp.cases #contact .bl_contact_txt {
    padding: 16.53vw 0 16vw;
    width: 100%;
    max-width: 1140px;
    background: #0F2743;
    text-align: center;
    color: #fff;
    margin: auto;
  }
  .bsp.cases #contact .bl_contact_txt .contact_lead {
    width: 15.22vw;
    max-width: 15.22vw;
  }
  .bsp.cases #contact .bl_contact_txt h2 {
    font-size: 4.8vw;
    line-height: 2;
    margin-top: 5.33vw;
  }
  .bsp.cases #contact .bl_contact_txt p {
    font-size: 3.73vw;
    margin-top: 5.33vw;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data {
    width: 100%;
    max-width: 100%;
    margin: 6.67vw auto 0;
    flex-direction: column;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt {
    width: 100%;
    white-space: nowrap;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt p {
    font-size: 8.8vw;
    margin: 0;
    white-space: nowrap;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt p span {
    font-size: 5.33vw;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt > span {
    font-size: 3.2vw;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_txt > span + span {
    margin-left: 1.5em;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn {
    margin-top: 8vw;
    margin-left: 0;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn {
    font-size: 3.73vw;
    padding: 1em 0;
    width: 73.87vw;
    margin: auto;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn:before {
    width: 5.33vw;
    left: 60vw;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn:after {
    width: 1.5vw;
    left: 63.66vw;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn:hover:before {
    width: 5.33vw;
    left: 60vw;
  }
  .bsp.cases #contact .bl_contact_txt .bl_contact_data .bl_contact_data_btn .btn:hover:after {
    width: 1.5vw;
    left: 63.66vw;
  }
  .bsp.cases #contact .btn_wrap {
    margin: 29.33vw auto 0;
  }
  .bsp.cases #contact .btn_wrap .btn {
    width: 56vw;
    max-width: 56vw;
    padding-bottom: 4vw;
  }
  .bsp.cases #contact .btn_wrap .btn img {
    width: 10.21vw;
    max-width: 10.21vw;
  }
  .bsp.cases #contact .btn_wrap .btn:before {
    width: 100%;
  }
  .bsp.cases #contact .btn_wrap .btn:after {
    left: 0;
  }
}
/********************
case_detail
********************/
/*
contents
*/
.bsp.case_detail #contents {
  font-size: min(1.25vw, 18px);
  margin-top: calc(110px + 5em);
}
.bsp.case_detail #contents .ly_df {
  justify-content: space-between;
}
.bsp.case_detail #contents .main_column {
  width: 74.6%;
}
.bsp.case_detail #contents .main_column .bl_case_data {
  justify-content: flex-start;
}
.bsp.case_detail #contents .main_column .bl_case_data .date {
  font-size: min(0.83vw, 12px);
  color: #808080;
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs {
  display: flex;
  list-style: none;
  margin-left: 0.83em;
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li {
  position: relative;
  display: flex;
  font-size: min(0.76vw, 11px);
  padding: 0 1.67em;
  height: 1.82em;
  background: #fff;
  border-radius: 2em;
  text-align: center;
  align-items: center;
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li:hover {
  opacity: 0.7;
  transition: all 0.3s;
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li + li {
  margin-left: 3em;
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li + li:before, .bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li + li:after {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  left: -2em;
  width: 0.6em;
  height: 1px;
  border-radius: 9999px;
  background-color: #cbc3ac;
  transform-origin: calc(100% - 0.5px) 50%;
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li + li:before {
  transform: rotate(40deg);
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li + li:after {
  transform: rotate(-40deg);
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li + li span, .bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li + li a {
  display: block;
  color: #002146;
  white-space: nowrap;
}
.bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li + li span {
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  white-space: normal;
  overflow: hidden;
}
.bsp.case_detail #contents .main_column .bl_case_detail_ttl {
  margin-top: 1.39em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_ttl h1 {
  font-size: min(1.74vw, 25px);
  margin: 0.84em 0;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img {
  margin-top: 1.39em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .case_list_wrap .case_list_main .splide__slide {
  width: 100%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .case_list_wrap .case_list_main .splide__slide img {
  width: 100%;
  max-width: 100%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .case_list_wrap .case_list_thumb {
  margin-top: 1.11em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .case_list_wrap .case_list_thumb .splide__slide {
  width: 10.81%;
  opacity: 0.5;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .case_list_wrap .case_list_thumb .splide__slide img {
  width: 100%;
  max-width: 100%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .case_list_wrap .case_list_thumb .splide__slide.is-active {
  border: none !important;
  opacity: 1;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .splide__arrow {
  top: 50%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .splide__arrow--prev {
  left: -1.38em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_img .splide__arrow--next {
  right: -1.38em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_data {
  margin-top: 5.56em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_data dl {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: auto;
  border-top: 1px solid #CBC3AC;
}
.bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner {
  display: flex;
  align-items: center;
  line-height: 0.5;
  border-bottom: 1px solid #CBC3AC;
  width: 100%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner.size_s {
  width: 31.35%;
  justify-content: space-between;
  padding: 0 2.5em 0 0;
}
.bsp.case_detail #contents .main_column .bl_case_detail_data dl dt, .bsp.case_detail #contents .main_column .bl_case_detail_data dl dd {
  font-size: min(1.11vw, 16px);
  line-height: 2;
  padding: 1.88em 0;
}
.bsp.case_detail #contents .main_column .bl_case_detail_data dl dt .note, .bsp.case_detail #contents .main_column .bl_case_detail_data dl dd .note {
  font-size: min(0.83vw, 12px);
  margin-top: 1em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_data dl dt a, .bsp.case_detail #contents .main_column .bl_case_detail_data dl dd a {
  color: #0089FF;
  text-decoration: underline;
}
.bsp.case_detail #contents .main_column .bl_case_detail_data dl dt {
  width: 10.31em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor {
  margin-top: 5.83em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_ttl {
  display: flex;
  align-items: center;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_ttl img {
  width: 19.17em;
  max-width: 306.65px;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_ttl span {
  font-size: min(1.11em, 16px);
  margin-left: 1em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-top: 3.33em;
  text-align: left;
  width: 100%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img {
  width: 19.35%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img .doctor_item_img_data span {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: min(0.76vw, 11px);
  height: 2.27em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img .doctor_item_img_data .branch {
  background: #0F2743;
  color: #fff;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img .doctor_item_img_data .department {
  display: flex;
  border: 1px solid #002146;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img .doctor_item_img_data .department span {
  width: 50%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img .doctor_item_img_data .department span + span {
  border-left: 1px solid #002146;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt {
  width: 76.76%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .shoulder {
  display: block;
  font-size: min(1.11em, 16px);
  line-height: 2;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .name_wrap {
  display: flex;
  justify-content: flex-start;
  align-items: baseline;
  margin-top: 0.2em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .name_wrap > img {
  height: 3.11vw;
  max-height: 11.65px;
  margin-left: 1.22em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .name_wrap p {
  font-size: min(1.74vw, 25px);
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .name_wrap a {
  width: 1.67em;
  max-width: 30px;
  margin-left: 1.22em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt > p {
  font-size: min(0.97vw, 14px);
  margin-top: 1.57em;
  line-height: 1.86;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap {
  justify-content: flex-start;
  margin-top: 1.67em;
  font-size: min(1.25vw, 18px);
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn {
  display: block;
  width: 12.33em;
  position: relative;
  padding-bottom: 1em;
  margin: 0;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn img {
  width: 8.87em;
  max-width: 159.6px;
  margin: 0;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:before {
  content: "";
  position: absolute;
  width: 96%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 0;
  z-index: 1;
  transition: all 0.3s;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:after {
  content: "";
  position: absolute;
  width: 3%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 93%;
  z-index: 1;
  transform: rotate(35deg);
  transition: all 0.3s;
  transform-origin: bottom right;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:hover:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 0;
  z-index: 1;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:hover:after {
  content: "";
  position: absolute;
  width: 3%;
  height: 1px;
  background: #000;
  bottom: 0;
  left: 97%;
  z-index: 1;
  transform: rotate(35deg);
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn + .btn {
  margin-left: 1.67em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:nth-child(2) img {
  width: 10.27em;
  max-width: 184.8px;
  margin: 0;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn {
  margin-top: 1.56em;
  width: 64.63%;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span {
  position: relative;
  display: block;
  width: 100%;
  border: solid 1px #000;
  font-size: min(1.11vw, 16px);
  padding: 1.03em 0;
  text-align: center;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a:before, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span:before {
  content: "";
  position: absolute;
  width: 7.91%;
  height: 1px;
  background: #000;
  top: 50%;
  left: 84%;
  transform: translateY(-50%);
  z-index: 1;
  transition: all 0.3s;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a:after, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span:after {
  content: "";
  position: absolute;
  width: 2.3%;
  height: 1px;
  background: #000;
  top: 49.5%;
  left: 89.2%;
  z-index: 1;
  transform: translateY(-50%) rotate(35deg);
  transform-origin: bottom right;
  transition: all 0.3s;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a:hover:before, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span:hover:before {
  content: "";
  position: absolute;
  width: 9.91%;
  height: 1px;
  background: #000;
  top: 50%;
  left: 84%;
  z-index: 1;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a:hover:after, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span:hover:after {
  content: "";
  position: absolute;
  width: 2.3%;
  height: 1px;
  background: #000;
  top: 49%;
  left: 91.5%;
  z-index: 1;
  transform: rotate(35deg);
  transform-origin: bottom right;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a + a, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span + a {
  margin-top: 0.8em;
}
.bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a span, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span span {
  margin-left: -2em;
  letter-spacing: 0.03em;
}

@media screen and (max-width: 1023px) {
  .bsp.case_detail #contents {
    margin-top: calc(85px + 4.4em);
  }
  .bsp.case_detail #contents .ly_df {
    flex-direction: column-reverse;
  }
  .bsp.case_detail #contents .main_column {
    width: 100%;
  }
  .bsp.case_detail #contents .main_column .bl_case_data {
    flex-direction: row;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap {
    flex-direction: row;
  }
}
@media screen and (max-width: 767px) {
  .bsp.case_detail #contents {
    margin-top: calc(60px + 20vw);
  }
  .bsp.case_detail #contents .main_column {
    width: 100%;
    margin-top: 8vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_data {
    flex-direction: column;
  }
  .bsp.case_detail #contents .main_column .bl_case_data .date {
    font-size: 3.2vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs {
    margin: 3.2vw 0 0 0;
    overflow: auto;
    padding-bottom: 2em;
  }
  .bsp.case_detail #contents .main_column .bl_case_data .case_breadcrumbs li {
    font-size: 2.93vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_ttl {
    margin-top: 6.67vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_ttl h1 {
    font-size: 4.27vw;
    line-height: 1.81;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_img {
    margin-top: 6.67vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_img .case_list_wrap .case_list_thumb {
    margin-top: 5.33vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_img .case_list_wrap .case_list_thumb .splide__slide {
    width: 16.8vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_img .splide__arrow--prev {
    left: -5.33vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_img .splide__arrow--next {
    right: -5.33vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data {
    margin-top: 16vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner.size_s {
    width: 41.33vw;
    padding: 0 12vw 0 0;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner.size_l_sp {
    width: 100%;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner.size_l {
    flex-wrap: wrap;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner.size_l dt, .bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner.size_l dd {
    width: 100%;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner.size_l dt {
    padding-bottom: 4vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl .dl_inner.size_l dt + dd {
    padding-top: 0;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl dt, .bsp.case_detail #contents .main_column .bl_case_detail_data dl dd {
    font-size: 3.73vw;
    line-height: 1.86;
    padding: 8vw 0;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl dt .note, .bsp.case_detail #contents .main_column .bl_case_detail_data dl dd .note {
    font-size: 3.2vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_data dl dt {
    width: auto;
    min-width: 20vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor {
    margin-top: 17.33vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_ttl {
    flex-wrap: wrap;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_ttl img {
    width: 65.42vw;
    max-width: 65.42vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_ttl span {
    font-size: 3.73vw;
    margin: 1em 0 0;
    width: 100%;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item {
    flex-direction: column;
    margin-top: 8vw;
    position: relative;
    margin-bottom: -45.33vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img img {
    width: 34.67vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img .doctor_item_img_data {
    width: 47.73vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_img .doctor_item_img_data span {
    font-size: 2.93vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt {
    width: 100%;
    position: relative;
    top: -45.33vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .shoulder {
    font-size: 3.2vw;
    left: 38.93vw;
    position: relative;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .name_wrap {
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
    margin-top: 0.2em;
    flex-wrap: wrap;
    left: 38.93vw;
    position: relative;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .name_wrap > img {
    height: 3.11vw;
    max-height: 3.11vw;
    margin-left: 0;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .name_wrap p {
    font-size: 4.8vw;
    width: 100%;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .name_wrap a {
    width: 5.33vw;
    max-width: 5.33vw;
    margin-left: 4.27vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt > p {
    font-size: 3.2vw;
    margin-top: 30.67vw;
    line-height: 1.86;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap {
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-top: 8vw;
    flex-direction: column;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn {
    display: block;
    width: 52.54vw;
    max-width: 52.54vw;
    margin: 9.33vw 0 0;
    padding-bottom: 4vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn img {
    width: 42.56vw;
    max-width: 42.56vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:before {
    width: 100%;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:after {
    left: 97%;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:nth-child(2) {
    width: 59.23vw;
    max-width: 59.23vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn:nth-child(2) img {
    width: 49.28vw;
    max-width: 49.28vw;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .doctor_item_txt .btn_wrap .btn + .btn {
    margin-left: 0;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn {
    margin-top: 1.56em;
    width: 64.63%;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span {
    position: relative;
    display: block;
    width: 100%;
    border: solid 1px #000;
    font-size: min(1.11vw, 16px);
    padding: 1.03em 0;
    text-align: center;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a:before, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span:before {
    content: "";
    position: absolute;
    width: 7.91%;
    height: 1px;
    background: #000;
    top: 50%;
    left: 84%;
    transform: translateY(-50%);
    z-index: 1;
    transition: all 0.3s;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a:after, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span:after {
    content: "";
    position: absolute;
    width: 2.3%;
    height: 1px;
    background: #000;
    top: 49.5%;
    left: 89.2%;
    z-index: 1;
    transform: translateY(-50%) rotate(35deg);
    transform-origin: bottom right;
    transition: all 0.3s;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a:hover:before, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span:hover:before {
    content: "";
    position: absolute;
    width: 9.91%;
    height: 1px;
    background: #000;
    top: 50%;
    left: 84%;
    z-index: 1;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a:hover:after, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span:hover:after {
    content: "";
    position: absolute;
    width: 2.3%;
    height: 1px;
    background: #000;
    top: 49%;
    left: 91.5%;
    z-index: 1;
    transform: rotate(35deg);
    transform-origin: bottom right;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a + a, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span + a {
    margin-top: 0.8em;
  }
  .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn a span, .bsp.case_detail #contents .main_column .bl_case_detail_doctor .doctor_item .item_btn > span span {
    margin-left: -2em;
    letter-spacing: 0.03em;
  }
}
/*
sns
*/
.bsp.cases #sns {
  font-size: min(1.25vw, 18px);
  margin: 8.33em 0 11.11em;
}
.bsp.cases #sns .sns_txt .sns_lead {
  width: 1.46em;
  max-width: 26.21px;
  margin: auto;
}
.bsp.cases #sns .sns_txt h2 {
  font-size: min(2.78vw, 40px);
  line-height: 1.2;
  letter-spacing: 0.1em;
  margin-top: 1.2em;
  text-align: center;
}
.bsp.cases #sns .sns_wrap {
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 4.13em;
}
.bsp.cases #sns .sns_wrap .btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: min(0.97em, 14px);
  border: 1px solid #000;
  width: 23.79%;
  height: 4.29em;
  margin-top: 1.43em;
  padding: 0;
}
.bsp.cases #sns .sns_wrap .btn img {
  position: absolute;
  left: 1.84em;
  width: 2.14em;
  margin-right: auto;
}
.bsp.cases #sns .sns_wrap .btn span {
  margin-left: 3em;
  letter-spacing: 0.05em;
}
.bsp.cases #sns .sns_wrap .btn:nth-child(5), .bsp.cases #sns .sns_wrap .btn:nth-child(6), .bsp.cases #sns .sns_wrap .btn:nth-child(7), .bsp.cases #sns .sns_wrap .btn:nth-child(8), .bsp.cases #sns .sns_wrap .btn:nth-child(9) {
  height: 9.36em;
  text-align: center;
  flex-direction: column;
  align-items: center;
  /*width: 18.71%;*/
}
.bsp.cases #sns .sns_wrap .btn:nth-child(5) img, .bsp.cases #sns .sns_wrap .btn:nth-child(6) img, .bsp.cases #sns .sns_wrap .btn:nth-child(7) img, .bsp.cases #sns .sns_wrap .btn:nth-child(8) img, .bsp.cases #sns .sns_wrap .btn:nth-child(9) img {
  position: relative;
  top: unset;
  left: unset;
  margin: 0;
}
.bsp.cases #sns .sns_wrap .btn:nth-child(5) span, .bsp.cases #sns .sns_wrap .btn:nth-child(6) span, .bsp.cases #sns .sns_wrap .btn:nth-child(7) span, .bsp.cases #sns .sns_wrap .btn:nth-child(8) span, .bsp.cases #sns .sns_wrap .btn:nth-child(9) span {
  margin: 1em 0 0;
}
.bsp.cases #sns .sns_wrap .btn:nth-child(3) {
  padding: 0;
}
.bsp.cases #sns .sns_wrap .btn:nth-child(3) img {
  width: 1.43em;
  left: 2.13em;
}

@media screen and (max-width: 767px) {
  .bsp.cases #sns {
    margin: 26.67vw 0;
  }
  .bsp.cases #sns .sns_txt .sns_lead {
    width: 5.82vw;
    max-width: 5.82vw;
  }
  .bsp.cases #sns .sns_txt h2 {
    font-size: 5.33vw;
    margin-top: 5.33vw;
  }
  .bsp.cases #sns .sns_wrap {
    margin-top: 10.67vw;
    flex-wrap: wrap;
  }
  .bsp.cases #sns .sns_wrap .btn {
    font-size: 3.2vw;
    width: 42.13vw;
    height: 10.67vw;
    margin-top: 2.67vw;
  }
  .bsp.cases #sns .sns_wrap .btn img {
    position: absolute;
    left: 5.33vw;
    width: 5.33vw;
  }
  .bsp.cases #sns .sns_wrap .btn span {
    margin-left: 2em;
  }
  .bsp.cases #sns .sns_wrap .btn:nth-child(5), .bsp.cases #sns .sns_wrap .btn:nth-child(6), .bsp.cases #sns .sns_wrap .btn:nth-child(7), .bsp.cases #sns .sns_wrap .btn:nth-child(8), .bsp.cases #sns .sns_wrap .btn:nth-child(9) {
    height: 13.33vw;
    flex-direction: row;
    align-items: center;
    width: 100%;
  }
  .bsp.cases #sns .sns_wrap .btn:nth-child(5) img, .bsp.cases #sns .sns_wrap .btn:nth-child(6) img, .bsp.cases #sns .sns_wrap .btn:nth-child(7) img, .bsp.cases #sns .sns_wrap .btn:nth-child(8) img, .bsp.cases #sns .sns_wrap .btn:nth-child(9) img {
    position: absolute;
    left: 5.33vw;
    width: 5.33vw;
  }
  .bsp.cases #sns .sns_wrap .btn:nth-child(5) span, .bsp.cases #sns .sns_wrap .btn:nth-child(6) span, .bsp.cases #sns .sns_wrap .btn:nth-child(7) span, .bsp.cases #sns .sns_wrap .btn:nth-child(8) span, .bsp.cases #sns .sns_wrap .btn:nth-child(9) span {
    margin: 0 0 0 1em;
  }
  .bsp.cases #sns .sns_wrap .btn:nth-child(3) {
    padding: 0;
  }
  .bsp.cases #sns .sns_wrap .btn:nth-child(3) img {
    width: 4vw;
    left: 5.33vw;
  }
}

/********************
サイドカラムをSPでモーダル起動するページ
********************/
@media screen and (max-width: 1023px) {
  .side_modal .modaal-content-container, .post-type-archive-news .modaal-content-container, .post-type-archive-column .modaal-content-container, .post-type-archive-cases .modaal-content-container {
    height: auto;
    padding: 5.33vw;
  }
  .side_modal .modaal-content-container .sub_column_lead, .post-type-archive-news .modaal-content-container .sub_column_lead, .post-type-archive-column .modaal-content-container .sub_column_lead, .post-type-archive-cases .modaal-content-container .sub_column_lead {
    width: 100%;
    border-bottom: 1px solid #CBC3AC;
    padding: 0 0 1.8em;
  }
  .side_modal .modaal-content-container .sub_column_lead img, .post-type-archive-news .modaal-content-container .sub_column_lead img, .post-type-archive-column .modaal-content-container .sub_column_lead img, .post-type-archive-cases .modaal-content-container .sub_column_lead img {
    width: 13.64em;
    max-width: 13.64em;
    font-size: min(1.25vw, 18px);
  }
  .side_modal .modaal-content-container .sub_column_lead.staff img, .post-type-archive-news .modaal-content-container .sub_column_lead.staff img, .post-type-archive-column .modaal-content-container .sub_column_lead.staff img, .post-type-archive-cases .modaal-content-container .sub_column_lead.staff img {
    width: 7.54em;
    max-width: 7.54em;
  }
  .side_modal .modaal-content-container ul, .post-type-archive-news .modaal-content-container ul, .post-type-archive-column .modaal-content-container ul, .post-type-archive-cases .modaal-content-container ul {
    list-style-type: none;
    width: 100%;
    flex-direction: column;
  }
  .side_modal .modaal-content-container ul li, .post-type-archive-news .modaal-content-container ul li, .post-type-archive-column .modaal-content-container ul li, .post-type-archive-cases .modaal-content-container ul li {
    border-bottom: 1px solid #CBC3AC;
    position: relative;
    display: block;
  }
  .side_modal .modaal-content-container ul li a, .post-type-archive-news .modaal-content-container ul li a, .post-type-archive-column .modaal-content-container ul li a, .post-type-archive-cases .modaal-content-container ul li a {
    display: block;
    padding: 0.8em 0;
    font-size: 13.5px;
    text-align: left;
  }
  .side_modal .modaal-content-container ul li a:hover, .post-type-archive-news .modaal-content-container ul li a:hover, .post-type-archive-column .modaal-content-container ul li a:hover, .post-type-archive-cases .modaal-content-container ul li a:hover {
    opacity: 0.6;
    transition: all 0.3s;
  }
  .side_modal .modaal-content-container ul li span.btn_open, .post-type-archive-news .modaal-content-container ul li span.btn_open, .post-type-archive-column .modaal-content-container ul li span.btn_open, .post-type-archive-cases .modaal-content-container ul li span.btn_open {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 3.16em;
    height: 3.16em;
    font-size: 14px;
  }
  .side_modal .modaal-content-container ul li span.btn_open:before, .post-type-archive-news .modaal-content-container ul li span.btn_open:before, .post-type-archive-column .modaal-content-container ul li span.btn_open:before, .post-type-archive-cases .modaal-content-container ul li span.btn_open:before {
    content: "";
    display: block;
    width: 0.86em;
    height: 1px;
    background-color: #000;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .side_modal .modaal-content-container ul li span.btn_open:after, .post-type-archive-news .modaal-content-container ul li span.btn_open:after, .post-type-archive-column .modaal-content-container ul li span.btn_open:after, .post-type-archive-cases .modaal-content-container ul li span.btn_open:after {
    content: "";
    display: block;
    width: 0.86em;
    height: 1px;
    background-color: #000;
    position: absolute;
    top: 50%;
    left: 50%;
    opacity: 1;
    transform: translate(-50%, -50%) rotate(90deg);
    transition: transform 0.25s ease;
  }
  .side_modal .modaal-content-container ul li .header_btm, .post-type-archive-news .modaal-content-container ul li .header_btm, .post-type-archive-column .modaal-content-container ul li .header_btm, .post-type-archive-cases .modaal-content-container ul li .header_btm {
    position: static;
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    min-width: 100%;
    visibility: hidden;
    transition: 1s ease;
    background-color: transparent;
    transition: none;
    transition: all 0.6s;
  }
  .side_modal .modaal-content-container ul li .header_btm .header_btm_ul, .post-type-archive-news .modaal-content-container ul li .header_btm .header_btm_ul, .post-type-archive-column .modaal-content-container ul li .header_btm .header_btm_ul, .post-type-archive-cases .modaal-content-container ul li .header_btm .header_btm_ul {
    display: block;
    height: auto;
    margin-bottom: 10px;
    margin-left: 0;
  }
  .side_modal .modaal-content-container ul li .header_btm .header_btm_li, .post-type-archive-news .modaal-content-container ul li .header_btm .header_btm_li, .post-type-archive-column .modaal-content-container ul li .header_btm .header_btm_li, .post-type-archive-cases .modaal-content-container ul li .header_btm .header_btm_li {
    border: none;
  }
  .side_modal .modaal-content-container ul li .header_btm .header_btm_li a, .post-type-archive-news .modaal-content-container ul li .header_btm .header_btm_li a, .post-type-archive-column .modaal-content-container ul li .header_btm .header_btm_li a, .post-type-archive-cases .modaal-content-container ul li .header_btm .header_btm_li a {
    padding: 1em 0;
    display: block;
  }
  .side_modal .modaal-content-container ul li.has_layer a, .post-type-archive-news .modaal-content-container ul li.has_layer a, .post-type-archive-column .modaal-content-container ul li.has_layer a, .post-type-archive-cases .modaal-content-container ul li.has_layer a {
    width: calc(100% - 2.13em);
  }
  .side_modal .modaal-content-container ul li.active span.btn_open:after, .post-type-archive-news .modaal-content-container ul li.active span.btn_open:after, .post-type-archive-column .modaal-content-container ul li.active span.btn_open:after, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open:after {
    opacity: 0;
  }
  .side_modal .modaal-content-container ul li.active span.btn_open + .header_btm, .post-type-archive-news .modaal-content-container ul li.active span.btn_open + .header_btm, .post-type-archive-column .modaal-content-container ul li.active span.btn_open + .header_btm, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open + .header_btm {
    /*max-height: calc( var(--vh) * 100 );*/
    max-height: fit-content;
    opacity: 1;
    visibility: visible;
  }
  .side_modal .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_ul, .post-type-archive-news .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_ul, .post-type-archive-column .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_ul, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_ul {
    display: block;
    height: auto;
    margin-bottom: 1.22em;
  }
  .side_modal .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li, .post-type-archive-news .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li, .post-type-archive-column .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li {
    border: none;
  }
  .side_modal .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li a, .post-type-archive-news .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li a, .post-type-archive-column .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li a, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li a {
    padding: 0.71em 0;
    display: block;
    color: #000;
  }
}
@media screen and (max-width: 767px) {
  .side_modal .modaal-content-container, .post-type-archive-news .modaal-content-container, .post-type-archive-column .modaal-content-container, .post-type-archive-cases .modaal-content-container {
    padding: 9.33vw 6.67vw 8vw;
  }
  .side_modal .modaal-content-container .sub_column_lead, .post-type-archive-news .modaal-content-container .sub_column_lead, .post-type-archive-column .modaal-content-container .sub_column_lead, .post-type-archive-cases .modaal-content-container .sub_column_lead {
    width: 100%;
    border-bottom: 1px solid #CBC3AC;
    padding: 0 0 6.4vw;
  }
  .side_modal .modaal-content-container .sub_column_lead img, .post-type-archive-news .modaal-content-container .sub_column_lead img, .post-type-archive-column .modaal-content-container .sub_column_lead img, .post-type-archive-cases .modaal-content-container .sub_column_lead img {
    width: 28.15vw;
    max-width: 28.15vw;
  }
  .side_modal .modaal-content-container .sub_column_lead.staff img, .post-type-archive-news .modaal-content-container .sub_column_lead.staff img, .post-type-archive-column .modaal-content-container .sub_column_lead.staff img, .post-type-archive-cases .modaal-content-container .sub_column_lead.staff img {
    width: 15.57vw;
    max-width: 15.57vw;
  }
  .side_modal .modaal-content-container ul, .post-type-archive-news .modaal-content-container ul, .post-type-archive-column .modaal-content-container ul, .post-type-archive-cases .modaal-content-container ul {
    list-style-type: none;
    width: 100%;
  }
  .side_modal .modaal-content-container ul li, .post-type-archive-news .modaal-content-container ul li, .post-type-archive-column .modaal-content-container ul li, .post-type-archive-cases .modaal-content-container ul li {
    border-bottom: 1px solid #CBC3AC;
  }
  .side_modal .modaal-content-container ul li a, .post-type-archive-news .modaal-content-container ul li a, .post-type-archive-column .modaal-content-container ul li a, .post-type-archive-cases .modaal-content-container ul li a {
    display: block;
    padding: 0.8em 0;
    font-size: 3.2vw;
    text-align: left;
  }
  .side_modal .modaal-content-container ul li a:hover, .post-type-archive-news .modaal-content-container ul li a:hover, .post-type-archive-column .modaal-content-container ul li a:hover, .post-type-archive-cases .modaal-content-container ul li a:hover {
    opacity: 0.6;
    transition: all 0.3s;
  }
  .side_modal .modaal-content-container ul li span.btn_open, .post-type-archive-news .modaal-content-container ul li span.btn_open, .post-type-archive-column .modaal-content-container ul li span.btn_open, .post-type-archive-cases .modaal-content-container ul li span.btn_open {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 3.26em;
    height: 3.26em;
    font-size: 3.2vw;
  }
  .side_modal .modaal-content-container ul li span.btn_open:before, .post-type-archive-news .modaal-content-container ul li span.btn_open:before, .post-type-archive-column .modaal-content-container ul li span.btn_open:before, .post-type-archive-cases .modaal-content-container ul li span.btn_open:before {
    content: "";
    display: block;
    width: 0.76em;
    height: 1px;
    background-color: #000;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .side_modal .modaal-content-container ul li span.btn_open:after, .post-type-archive-news .modaal-content-container ul li span.btn_open:after, .post-type-archive-column .modaal-content-container ul li span.btn_open:after, .post-type-archive-cases .modaal-content-container ul li span.btn_open:after {
    content: "";
    display: block;
    width: 0.76em;
    height: 1px;
    background-color: #000;
    position: absolute;
    top: 50%;
    left: 50%;
    opacity: 1;
    transform: translate(-50%, -50%) rotate(90deg);
    transition: transform 0.25s ease;
  }
  .side_modal .modaal-content-container ul li .header_btm, .post-type-archive-news .modaal-content-container ul li .header_btm, .post-type-archive-column .modaal-content-container ul li .header_btm, .post-type-archive-cases .modaal-content-container ul li .header_btm {
    position: static;
    opacity: 0;
    max-height: 0;
    overflow: hidden;
    min-width: 100%;
    visibility: hidden;
    transition: 1s ease;
    background-color: transparent;
    transition: none;
    transition: all 0.6s;
  }
  .side_modal .modaal-content-container ul li .header_btm .header_btm_ul, .post-type-archive-news .modaal-content-container ul li .header_btm .header_btm_ul, .post-type-archive-column .modaal-content-container ul li .header_btm .header_btm_ul, .post-type-archive-cases .modaal-content-container ul li .header_btm .header_btm_ul {
    display: block;
    height: auto;
    margin-bottom: 10px;
    margin-left: 0;
  }
  .side_modal .modaal-content-container ul li .header_btm .header_btm_li, .post-type-archive-news .modaal-content-container ul li .header_btm .header_btm_li, .post-type-archive-column .modaal-content-container ul li .header_btm .header_btm_li, .post-type-archive-cases .modaal-content-container ul li .header_btm .header_btm_li {
    border: none;
  }
  .side_modal .modaal-content-container ul li .header_btm .header_btm_li a, .post-type-archive-news .modaal-content-container ul li .header_btm .header_btm_li a, .post-type-archive-column .modaal-content-container ul li .header_btm .header_btm_li a, .post-type-archive-cases .modaal-content-container ul li .header_btm .header_btm_li a {
    padding: 1em 0;
    display: block;
  }
  .side_modal .modaal-content-container ul li.has_layer a, .post-type-archive-news .modaal-content-container ul li.has_layer a, .post-type-archive-column .modaal-content-container ul li.has_layer a, .post-type-archive-cases .modaal-content-container ul li.has_layer a {
    width: calc(100% - 2.13em);
  }
  .side_modal .modaal-content-container ul li.active span.btn_open:after, .post-type-archive-news .modaal-content-container ul li.active span.btn_open:after, .post-type-archive-column .modaal-content-container ul li.active span.btn_open:after, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open:after {
    opacity: 0;
  }
  .side_modal .modaal-content-container ul li.active span.btn_open + .header_btm, .post-type-archive-news .modaal-content-container ul li.active span.btn_open + .header_btm, .post-type-archive-column .modaal-content-container ul li.active span.btn_open + .header_btm, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open + .header_btm {
    /*max-height: calc( var(--vh) * 100 );*/
    max-height: fit-content;
    opacity: 1;
    visibility: visible;
  }
  .side_modal .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_ul, .post-type-archive-news .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_ul, .post-type-archive-column .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_ul, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_ul {
    display: block;
    height: auto;
    margin-bottom: 1.22em;
  }
  .side_modal .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li, .post-type-archive-news .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li, .post-type-archive-column .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li {
    border: none;
  }
  .side_modal .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li a, .post-type-archive-news .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li a, .post-type-archive-column .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li a, .post-type-archive-cases .modaal-content-container ul li.active span.btn_open + .header_btm .header_btm_li a {
    padding: 0.71em 0;
    display: block;
    color: #000;
  }
  .side_modal .modaal-content-container .sub_column_box:nth-child(2) .sub_column_lead img, .post-type-archive-news .modaal-content-container .sub_column_box:nth-child(2) .sub_column_lead img, .post-type-archive-column .modaal-content-container .sub_column_box:nth-child(2) .sub_column_lead img, .post-type-archive-cases .modaal-content-container .sub_column_box:nth-child(2) .sub_column_lead img {
    width: 4.03em;
    max-width: 72.52px;
  }
  .side_modal .modaal-content-container .sub_column_box + .sub_column_box, .post-type-archive-news .modaal-content-container .sub_column_box + .sub_column_box, .post-type-archive-column .modaal-content-container .sub_column_box + .sub_column_box, .post-type-archive-cases .modaal-content-container .sub_column_box + .sub_column_box {
    margin-top: 1.39em;
  }
}
