@charset "utf-8";
.content_girls {
  position: relative;
  padding-bottom: 30px;
}
.count {
  position: absolute;
  top: 30px;
  right: 310px;
}
.count dt,
.count dd {
  font-size: 16px;
  display: inline-block;
}
.count dd {
  color: #ff0000;
  font-weight: bold;
}
/*------------------------------------------------------------
　絞込み
-------------------------------------------------------------*/
.wrap_sort {
  padding: 0 30px;
}
.sort {
  display: flex;
  border: 1px solid #cfcfcf;
  position: relative;
}
.sort:before {
  transform: rotate(45deg);
  content: "";
  aspect-ratio: 1;
  width: 12px;
  border-right: 1px solid #cfcfcf;
  border-bottom: 1px solid #cfcfcf;
  background: #fff;
  position: absolute;
  bottom: -7px;
  inset-inline: 0;
  margin-inline: auto;
}
.sort_l {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 140px;
  font-weight: bold;
  background-color: #f5f5f5;
  border-right: 1px solid #cfcfcf;
}
.sort_on {
  background: #fffceb;
}
.sort_r {
  flex: 1;
}
dl[class^="sort"] {
  display: flex;
  align-items: center;
  border-left: 3px solid #fb489b;
}
.sort1,
.sort3 {
  padding-block: 20px;
}
.sort2 {
  padding-block: 15px;
}
dl[class^="sort"] + dl {
  border-top: 1px solid #cfcfcf;
}
dl[class^="sort"] dt {
  color: #fb489b;
  font-weight: bold;
  width: 160px;
  position: relative;
  padding-left: 20px;
}
dl[class^="sort"] dt:before {
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 20px;
  width: 16px;
  height: 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 {
  position: relative;
  cursor: pointer;
  height: 16px;
  display: inline-block;
  padding-left: 25px;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}
input + label:before {
  position: absolute;
  top: 50%;
  left: 0;
  overflow: hidden;
  width: 18px;
  height: 16px;
  margin-top: -6px;
  background-image: url(../images/girls/sort.png);
  background-repeat: no-repeat;
  content: "";
}
input:checked + label:before {
  background-position: 0 bottom;
}
.sort1 li,
.sort2 li {
  width: 105px;
}
.sort2 ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.sort3 li {
  display: flex;
  column-gap: 10px;
}
input[type="search"] {
  width: 300px;
  height: 28px;
  border: 2px solid #cfcfcf;
  padding-inline: 10px;
}
.btn_search {
  color: #fb489b;
  text-align: center;
  text-decoration: none;
  width: 74px;
  height: 24px;
  line-height: 26px;
  background: #fff;
  border: 2px solid #fb489b;
  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 {
  margin-block: 30px;
  font-size: 18px;
  text-align: center;
}
.result span {
  color: #ff0000;
  font-size: 24px;
  font-weight: bold;
  vertical-align: middle;
  margin-right: 5px;
}
/*------------------------------------------------------------
　キャスト
-------------------------------------------------------------*/
.girls-item_img {
  position: relative;
}
.girls_type {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 10px;
}
.girls_size + .girls_title {
  border-top: 1px solid #999;
  padding-top: 10px;
  margin-top: 10px;
}
/*------------------------------------------------------------
　画像切り替え
-------------------------------------------------------------*/
.display_switch {
  right: 30px;
}
.change-item {
  cursor: pointer;
  width: 220px;
  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;
  padding: 15px;
  background: #000;
}
.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);
}
.girls_name:hover {
  text-decoration: none;
}
.girls-item:hover .c-h-bBorder::before {
  opacity: 1;
}
.change-item_contents {
  padding: 15px 15px 20px;
  background-color: #fff;
}
.schedule_data {
  color: #fff;
  font-size: 12px;
  height: 22px;
  line-height: 22px;
  background-color: #000;
  display: inline-block;
  position: absolute;
  right: 0;
  bottom: 0;
  padding-inline: 10px;
}
