@charset "utf-8";
.content_girls {
  padding-block: 20px 30px;
}
.content_girls_data {
  display: flex;
  justify-content: flex-end;
  column-gap: 20px;
  margin-top: 10px;
  padding-right: 30px;
}
.content_girls_data dl {
  display: flex;
  align-items: center;
}
.count {
  font-size: 16px;
}
.count dd {
  color: #ff0000;
  font-weight: bold;
}
/*------------------------------------------------------------
　絞込み
-------------------------------------------------------------*/
.wrap_sort {
  margin-top: 20px;
  padding-inline: 30px;
}
.sort {
  display: flex;
  position: relative;
}
.sort:before {
  transform: rotate(45deg);
  content: "";
  width: 12px;
  height: 12px;
  border-right: 1px solid #cfcfcf;
  border-bottom: 1px solid #cfcfcf;
  background: #fff;
  position: absolute;
  top: 100%;
  left: 50%;
  margin: -6px 0 0 -6px;
}
.sort_l {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: bold;
  width: 140px;
  background: #4c3630 url(../images/girls/bg_sort_l.png) no-repeat;
  position: relative;
}
.sort_l:before {
  content: "";
  width: 100%;
  height: 100%;
  border: 5px solid transparent;
  box-shadow: 0 1px 0 rgba(221, 205, 150, 0.5) inset, -1px 0 0 rgba(221, 205, 150, 0.5) inset,
    0 -1px 0 rgba(221, 205, 150, 0.5) inset, 1px 0 0 rgba(221, 205, 150, 0.5) inset;
  position: absolute;
  top: 0;
  left: 0;
  box-sizing: border-box;
}
.sort_r {
  flex: 1;
  border-top: 1px solid #cfcfcf;
  border-right: 1px solid #cfcfcf;
  border-bottom: 1px solid #cfcfcf;
}
.sort_on {
  background: #fffceb;
}
dl[class^="sort"] {
  display: flex;
  align-items: center;
}
.sort1,
.sort3 {
  padding-block: 20px;
}
.sort2 {
  padding-block: 15px;
}
dl[class^="sort"] + dl {
  border-top: 1px solid #cfcfcf;
}
dl[class^="sort"] dt {
  color: #894d45;
  font-weight: bold;
  width: 160px;
  position: relative;
  padding-left: 20px;
}
dl[class^="sort"] dt:before {
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 20px;
  aspect-ratio: 1;
  width: 16px;
  margin-top: -8px;
  border-top: 1px solid #666;
  border-right: 1px solid #666;
  content: "";
}
dl[class^="sort"] dd {
  flex: 1;
}
input[type="checkbox"] {
  display: none;
}
input + label {
  height: 16px;
  line-height: 16px;
  background-image: url(../images/girls/checkbox.png);
  background-repeat: no-repeat;
  display: inline-block;
  padding-left: 25px;
}
input:checked + label {
  background-position: 0 bottom;
}
.sort1 li,
.sort2 li {
  width: 105px;
  height: 16px;
  line-height: 16px;
}
.sort2 ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.sort3 li {
  display: flex;
  align-items: center;
  column-gap: 10px;
}
input[type="search"] {
  width: 300px;
  height: 28px;
  border: 2px solid #cfcfcf;
  display: inline-block;
  vertical-align: middle;
  padding: 0 10px;
}
.btn_search {
  color: #894d45;
  text-align: center;
  text-decoration: none;
  width: 74px;
  height: 24px;
  line-height: 26px;
  background: #fff;
  border: 2px solid #ddcd96;
  display: inline-block;
  vertical-align: middle;
  border-radius: 5px;
}
.btn_search:before {
  content: "";
  aspect-ratio: 1;
  width: 17px;
  background: url(../images/girls/icon_freeSearch.png) no-repeat;
  display: inline-block;
  vertical-align: middle;
  margin: -3px 5px 0 0;
}
.result {
  font-size: 18px;
  text-align: center;
  padding-block: 30px;
}
.result span {
  color: #ff0000;
  font-size: 24px;
  font-weight: bold;
  vertical-align: middle;
  margin-right: 5px;
}
/*------------------------------------------------------------
　キャスト
-------------------------------------------------------------*/
.girls_type {
  margin-top: 10px;
}
/*------------------------------------------------------------
　画像切り替え
-------------------------------------------------------------*/
.change-item {
  width: calc(100% + 2px);
  height: 100%;
  background: #fff;
  border-bottom: 2px solid #fff;
  opacity: 0;
  transition: opacity 0.5s ease-out;
  position: absolute;
  top: -1px;
  left: -1px;
  z-index: 1;
}
.change-item_img {
  aspect-ratio: 3/4;
  background: #000;
  padding: 15px;
}
.change-item_img img {
  transform: scale(1.2);
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease-out;
}
[data-item="normal"] .girls-item:hover .change-item {
  opacity: 1;
}
[data-item="normal"] .girls-item:hover .change-item_img img {
  transform: scale(1);
}
[data-item="normal"] .girls_name:hover {
  text-decoration: none;
}
[data-item="normal"] .girls-item:hover .c-h-bBorder::before {
  opacity: 1;
}
.change-item_contents {
  padding: 15px;
}
.schedule_data {
  color: #fff;
  font-size: 12px;
  height: 22px;
  line-height: 22px;
  background: #000;
  display: inline-block;
  position: absolute;
  right: 0;
  bottom: 0;
  padding-inline: 10px;
}

/*------------------------------------------------------------
　表示切替
-------------------------------------------------------------*/
.display_switch {
  display: flex;
  column-gap: 10px;
  margin-left: 10px;
}
.display_switch div {
  cursor: pointer;
  color: #894d45;
  height: 35px;
  line-height: 35px;
  border: 2px solid #ddcd96;
  border-radius: 5px;
  transition: background-color 0.5s ease-out;
  padding-inline: 35px 15px;
}
.display_switch div:hover {
  background-color: #fffceb;
}
.display_switch .switch_on {
  color: #0caf73;
  border: 2px solid #26b480;
}
.switch1.switch_on {
  background-position: 10px 8px;
}
.switch2.switch_on {
  background-position: -115px 8px;
}
.switch1,
.switch2 {
  background: url(../images/girls/display_switch.png) no-repeat;
}
.switch1 {
  background-position: 10px -33px;
}
.switch2 {
  background-position: -115px -33px;
}
.switch_off {
  display: none;
}
