@charset "UTF-8";
* {
  box-sizing: border-box;
}
body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック",
    "MS PGothic", sans-serif;
  color: #333;
  line-height: 1;
  -webkit-text-size-adjust: 100%;
}
img {
  height: auto;
  border: 0;
  font-size: 0;
  line-height: 0;
  vertical-align: bottom;
}
a {
  color: #333;
  text-decoration: none;
  display: block;
}
.fruid {
  width: 100%;
  height: auto;
}
table {
  table-layout: fixed;
}
.cf:before,
.cf:after {
  display: table;
  content: " ";
}
.cf:after {
  clear: both;
}
.boxLink {
  cursor: pointer;
}
.p-container {
  padding-inline: 15px;
}
.heading1 {
  display: flex;
  align-items: center;
  column-gap: 5px;
  height: 30px;
  padding-inline: 15px;
  background-color: #e9dae0;
  font-size: 16px;
  font-weight: bold;
}

/*======================*/
/*** ドロワーメニュー ***/
/*======================*/
#drawer_wrapper {
  position: relative;
  overflow: hidden;
  width: 100%;
}
.drawer_nav {
  position: absolute;
  top: 0;
  right: -252px;
  height: 100%;
  z-index: 999999;
  width: 252px;
  overflow: auto;
  background-color: #fff;
  color: #483427;
  transform: translate3d(0, 0, 0);
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease-out;
}
#drawer_main {
  position: relative;
  transform: translate3d(0, 0, 0);
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease-out;
}
.drawer_nav.active,
#drawer_main.active {
  transform: translate3d(-252px, 0, 0);
  transition-property: all;
  transition-duration: 0.3s;
  transition-timing-function: ease-out;
}
#lock:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background: rgb(0 0 0 / 0.5);
  z-index: 999999;
}
#lock {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 999999;
}
#lock.none {
  display: none;
}

/*=====ドロワー内=====*/
.drawer_nav {
  padding: 15px;
  z-index: 0;
	line-height: 1.5;
}
.drawer_nav_close {
  padding-block: 8px;
  border: 1px solid #d9d9d9;
  font-size: 14px;
  text-align: center;
}
.drawer_nav_close.-bottom {
	margin-top: 10px;
}
.drawer_nav_discript {
  margin-top: 15px;
	padding-bottom: 15px;
	border-bottom: 2px solid #fe77a7;
  font-size: 10px;
  text-align: center;
}
.drawer_nav_discript img {
  display: block;
  margin-top: 10px;
	margin-inline: auto;
}
.drawer_nav_discript span {
  font-size: 12px;
}
.drawer_nav_ul-01 {
	margin-top: 20px;
	border: 1px solid #d9d9d9;
	font-size: 14px;
}
.drawer_nav_ul-01 li:not(:first-child) {
	border-top: 1px solid #d9d9d9;
}
.drawer_nav_ul-01 li a {
	display: flex;
	align-items: center;
	column-gap: 8px;
	position: relative;
	padding: 8px 10px;
}
.drawer_nav_ul-01 li a::before {
	position: absolute;
	top: 3px;
	right: 3px;
	width: 11px;
	height: 11px;
	background-color: #fe77a7;
	clip-path: polygon(0 0, 100% 0, 100% 100%);
	content: "";
}
.drawer_nav_ul-02 {
  margin-top: 5px;
  border: 1px solid #d9d9d9;
}
.drawer_nav_ul-02 li {
  position: relative;
  height: 40px;
  border-bottom: 1px solid #d9d9d9;
  font-size: 14px;
  line-height: 40px;
}
.drawer_nav_ul-02 li:last-child {
  border-bottom: none;
}
.drawer_nav_ul-02 a {
  position: relative;
  padding-left: 10px;
}
:is(.drawer_nav_ul-02, .footer_nav) a:before {
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 10px;
  aspect-ratio: 1;
  width: 10px;
  margin-top: -6px;
  border-top: 1px solid #9a9a9a;
  border-right: 1px solid #9a9a9a;
  content: "";
}
.drawer_nav_ul-02 img {
  position: absolute;
  top: 10px;
  right: 10px;
}

/*==============*/
/*** ヘッダー ***/
/*==============*/
.header {
  line-height: 1.5;
}
.header .h1 {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px 10px;
  background-color: #fff;
  font-size: 10px;
}
.header_logo {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
  padding: 15px;
  border-top: 1px solid #ccc;
}
.header_logo::before,
.header_logo::after {
	content: "";
}
.header_logo::before {
	rotate: -45deg;
	width: 18px;
	height: 18px;
	border-top: 1px solid #333;
	border-left: 1px solid #333;
}

/*=====営業時間と電話受付=====*/
.header_info {
  display: flex;
  border-top: 1px solid #ccc;
  text-align: center;
}
.header_info_time,
.header_info_tel {
  width: 50%;
}
.header_info_time {
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #fff;
  font-size: 12px;
}
.header_info_time span {
  width: 100%;
  font-size: 11px;
}
.header_info_tel a {
  display: flex;
  flex-direction: column;
  padding-block: 8px 5px;
  background: rgb(254, 108, 177);
  background: linear-gradient(0deg, rgba(254, 108, 177, 1) 0%, rgba(253, 64, 140, 1) 100%);
  color: #fff;
  font-size: 16px;
}
.header_info_tel span {
  font-size: 11px;
}
.h_nav_ul {
  display: flex;
	column-gap: 1px;
  border-bottom: 5px solid #fe77a7;
  background-color: #e5e5e5;
}
.h_nav_ul li {
  list-style: none;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  font-size: 10px;
  text-align: center;
}
.h_nav_ul li:not(.h_nav_toggle) {
	flex: 1;
}
.h_nav_ul li > * {
	display: grid;
	place-content: center;
	height: 58px;
}
.h_nav_ul li a {
	background-color: #fff;
}
.h_nav_ul li img {
	height: fit-content;
}
.h_nav_toggle {
  width: 15%;
  background: rgb(255, 255, 255);
  background: linear-gradient(to bottom, rgb(255, 255, 255) 0%, rgb(243, 243, 243) 100%);
}
/*** パンくず ***/
.pankuzu {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 3px;
  padding: 10px;
  background-color: #fff;
  border-bottom: 1px solid #ccc;
  font-size: 12px;
}
.pankuzu li,
.pankuzu a {
  display: inline;
}
.pankuzu li:last-child:after {
  display: none;
}
.pankuzu li:after {
  margin-inline: 5px;
  content: ">";
}
.pankuzu a {
  color: #369efe;
  text-decoration: underline;
}
/*==============*/
/*** フッター ***/
/*==============*/
footer {
  padding-bottom: 15px;
  border-top: 1px solid #ccc;
  background-color: #f2f2f2;
  font-size: 14px;
  line-height: 1.5;
}
.footer_logo {
  margin-top: 20px;
}
.footer_logo a {
  display: flex;
  align-items: center;
  column-gap: 10px;
  width: fit-content;
  margin-inline: auto;
}
.footer_logo-area {
  font-size: 12px;
  letter-spacing: 0.5em;
}
.footer_areaJob {
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  height: 36px;
  margin-top: 15px;
  margin-inline: auto;
  padding-inline: 3rem;
  background-color: #fff;
  clip-path: polygon(0 0, 100% 0, 93% 50%, 100% 100%, 0 100%, 8% 50%);
}
.footer_add {
  margin-top: 10px;
  text-align: center;
}
.footer_info {
  display: flex;
  align-items: center;
  column-gap: 10px;
  margin-block: 15px;
  padding: 10px;
  border-top: 1px solid #d9d9d9;
  border-bottom: 1px solid #d9d9d9;
  font-size: 12px;
}
.footer_info dt {
  padding: 5px 15px;
  border-radius: 9999px;
  background-color: #333;
  font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho",
    serif;
  color: #fff;
  font-size: 0.625rem;
  line-height: 1;
}
.footer_info dd {
	display: flex;
  flex-wrap: wrap;
  flex: 1;
}
.footer_tel {
  margin-bottom: 15px;
}
.footer_tel a {
  width: fit-content;
  margin-inline: auto;
}
.footer_nav {
  font-size: 12px;
  margin-inline: 10px;
}
.footer_nav-01_ul {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-top: 15px;
  border-top: 1px solid #ccc;
  border-left: 1px solid #ccc;
  box-shadow: -1px -1px 0px #ccc inset;
  background-color: #fff;
}
.footer_nav-02_ul {
  border: 1px solid #ccc;
}
.footer_nav-01_ul li {
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}
.footer_nav-01_ul li a {
  display: flex;
  align-items: center;
  position: relative;
  min-height: 40px;
  height: 100%;
  padding: 8px 26px 8px 10px;
}
.footer_nav-02_ul li {
  position: relative;
  border-bottom: 1px solid #ccc;
}
.footer_nav-02_ul span {
  display: block;
  color: #777;
  font-size: 10px;
}
.footer_nav-02_ul li a {
  padding: 5px;
}
.footer_nav-02_ul li:last-child {
  border-bottom: none;
}
.footer_acMenu {
  margin-top: 10px;
  margin-inline: 10px;
  border: 1px solid #ccc;
  background-color: #fff;
}
.accordion {
  display: block;
  position: relative;
  width: 100%;
  height: 40px;
  line-height: 40px;
  text-align: center;
}
.accordion_btn {
  position: absolute;
  top: 50%;
  right: 12px;
  margin-top: -7px;
}
.accordion_btn span {
  display: block;
  position: relative;
  aspect-ratio: 1;
  width: 14px;
}
.accordion_btn span::before,
.accordion_btn span::after {
  position: absolute;
  top: 50%;
  left: 0;
  width: 14px;
  height: 1px;
  margin-top: -1px;
  background: #9a9a9a;
  content: "";
}
.accordion_btn span::after {
  transform: rotate(-90deg);
  transition: 0.5s ease;
}
.accordion.active .accordion_btn span::after {
  transform: rotate(0deg);
  opacity: 0;
}
.within {
  display: none;
  margin: 0;
  padding-bottom: 10px;
}
.accordion_close {
  height: 40px;
  margin-top: 10px;
  border-top: 1px solid #ccc;
  line-height: 40px;
  text-align: center;
}
.footer_copy {
  display: block;
  margin-top: 10px;
  padding-inline: 10px;
  font-size: 10px;
  text-align: center;
}
.footer_icons {
  display: flex;
  justify-content: center;
  column-gap: 10px;
  margin-block: 20px;
}
.footer_icons a {
  display: flex;
  align-items: center;
  justify-content: center;
}
.icon-x {
  aspect-ratio: 1;
  width: 40px;
  border-radius: 50%;
  background-color: #333;
}
.icon-x img {
  aspect-ratio: 400/409;
  width: 17px;
}
.footer_bottomInfo {
  margin-bottom: 15px;
}
.footer_bottomInfo > * + * {
  margin-top: 15px;
}
#toTop {
  display: block;
  height: 40px;
  background-color: #fff;
  text-align: center;
}
#toTop img {
  padding-top: 12px;
}
.arrow-toTop {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  background-color: #fff;
}
.arrow-toTop span {
  display: block;
  position: relative;
  width: 1px;
  height: 17px;
  background-color: #333;
}
.arrow-toTop span::before,
.arrow-toTop span::after {
  content: "";
  position: absolute;
  top: 0.5px;
  inset-inline: 0;
  width: 1px;
  height: 13px;
  margin-inline: auto;
  background-color: #333;
  transform-origin: 50% 0;
}
.arrow-toTop span::before {
  transform: rotate(45deg);
}
.arrow-toTop span::after {
  transform: rotate(-45deg);
}

/*==============*/
/*** タイトル ***/
/*==============*/
.h-sub {
  margin-left: 10px;
  font-family: Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 12px;
  font-weight: normal;
}
.h-border {
  display: block;
  position: relative;
  padding-inline: 10px;
  color: #4b3c3c;
  font-size: 17px;
  font-weight: bold;
  text-align: center;
}
.h-border::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 8px;
  margin-top: -4px;
  background: url(../images/ttl-border.png);
  background-size: 1px 8px;
  content: "";
}
.h-border_inside {
  display: inline-flex;
  align-items: center;
  position: relative;
  z-index: 1;
  padding-inline: 5px 8px;
  background: #fff;
  font-family: Georgia, 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
}
.ttl-tertiary {
  padding: 5px 10px;
  border: 1px solid #ffc0d6;
  background: #fff1f6;
  background: linear-gradient(135deg, #fff1f6 0%, #fff1f6 62%, #fffeff 63%, #fff1f6 100%);
  color: #fe77a7;
  font-weight: bold;
}

/*=====女の子画像=====*/
.girls_li_time {
  color: #fff;
  font-size: 10px;
  font-weight: bold;
  text-align: center;
  height: 23px;
  line-height: 23px;
  background: #000;
  border-top: 2px solid #fe77a7;
}
.girls_li_data {
  color: #fff;
  font-size: 10px;
  text-align: center;
  line-height: 1.5;
  width: 100%;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.02) 0%, rgba(0, 0, 0, 0.2) 25%, rgba(0, 0, 0, 0.7) 100%);
  position: absolute;
  bottom: 23px;
  padding-block: 10px;
}
.girls_li_name {
  font-weight: bold;
}
.girls_li_name a {
  color: #fff;
  font-size: 12px;
  display: inline;
}
.girls_li .rank_icon {
  position: absolute;
  top: 5px;
  left: 5px;
  z-index: 1;
}


.girl-items {
	display: grid;
}
.girl-items.-column {
	grid-template-columns: repeat(3, 1fr);
	gap: 1px;
}
.girl-item {
	display: grid;
	position: relative;
	background-color: #000;
	color: #fff;
	line-height: 1.5;
}
.girl-item__heading a {
	color: inherit;
	font-size: 12px;
	font-weight: bold;
}
:is(.girl-item__size, .girl-item__date) {
	font-size: 11px;
	text-align: center;
} 
.girl-item__thumbnail {
	display: grid;
	aspect-ratio: 3/4;
}
.girl-item__data {
	display: grid;
	grid-area: 1/1;
	align-self: end;
	justify-items: center;
	row-gap: 3px;
	z-index: 1;
	padding-block: 8px;
	padding-inline: 8px;
	background: RGBA(0, 0, 0, 0.7);
	background: linear-gradient(0deg, rgba(0, 0, 0, 0.83) 0%, rgba(0, 0, 0, 0) 100%);
}
.girl-item__img {
	grid-area: 1/1;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.girl-item__date {
	height: 25px;
	border-top: 2px solid #fe77a7;
	font-weight: bold;
	line-height: 25px;
}
.girl-item .new {
	position: absolute;
	top: 0;
	right: 0;
}
.girl-item .rank_icon {
	top: 5px;
}

/* デリバリー告知 */
.info_delivery_top {
  background: #f4f4f4;
  padding-block: 10px;
}
.info_delivery_top > * {
  font-size: 10px;
}
.info_delivery_bottom {
  width: 100%;
  background: #fff;
  border-bottom: 1px solid #d9d9d9;
  padding-block: 15px;
  line-height: 20px;
}
.info_delivery {
  color: #ff0000;
  font-size: 12px;
  white-space: nowrap;
  text-align: center;
  text-decoration: underline;
}
