/* right */
.recruit_contact ul {
  width: fit-content;
  min-width: 200px;
  margin: 0 auto;
}

.recruit_contact li a,
.recruit_contact li .tel-box {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  padding: 5px;
  margin: 0;
  width: 100%;
  font-size: 16px;
  border-radius: 5px;
}

.recruit_contact .contact_by_tel {
  border-radius: 5px;
}

.recruit_contact .contact_by_line,
.recruit_contact .tel_num {
  margin-bottom: 30px;
}

.recruit_contact .tel_num {
  margin-top: 5px;
  text-align: center;
  font-size: 20px;
}

.recruit_contact .contact_by_line a {
  background-color: #00B900 !important;
}

/* main */
section.cast-recruit,
section.staff-recruit {
  padding: 100px 0 50px;
}

.recruit__inner {
  width: 90%;
  margin: 0 auto;
}

.recruit__inner h2 {
  font-size: 32px;
  text-align: center;
  letter-spacing: 0.02em;
}

section.recruit_eyecatch a
section.recruit_sub_eyecatch a {
  display: block;
}

section.recruit_eyecatch img,
section.recruit_sub_eyecatch img {
  display: block;
  width: 100%;
  margin: 0 auto;
}

section.recruit_eyecatch video {
  width: 100%;
  margin: 0;
  margin-top: 35px;
  max-width: none;
}

/* section.page_anchor */
section.page_anchor {
  padding: 30px 0;
}

section.page_anchor .page_anchor__inner {
  margin: 0 auto;
  width: 90%;
}

.page_anchor__inner ul .swiper-slide {
  width: fit-content;
}

.page_anchor__inner ul .swiper-slide a {
  display: block;
  padding: 5px 15px;
  border-radius: 8px;
  border-width: 1px;
  border-style: solid;
}

/* section.faq */
section.faq {
  padding: 50px 0;
}

section.faq .faq__inner ul {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-top: 30px;
}

.faq__inner ul li {
  width: 100%;
  margin-bottom: 15px;
  border-style: solid;
  border-width: 1px;
}

.faq__inner ul li:last-child {
  margin-bottom: 0;
}

.faq__inner ul li dl dt,
.faq__inner ul li dl dd {
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: flex-start;
  padding: 10px;
}

.faq__inner ul li dl dd {
  display: none;
}

.faq__inner ul li dl dt span,
.faq__inner ul li dl dd span {
  display: block;
  font-size: 16px;
  flex-shrink: 0;
}

.faq__inner ul li dl dt span {
  font-weight: bold;
}

.faq__inner ul li dl dt h5,
.faq__inner ul li dl dd p {
  min-height: 48px;
  align-self: flex-start;
  flex-grow: 1;
  padding: 0 10px;
  font-size: 16px;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
}

.faq__inner ul li dl dt h5 {
  font-weight: bold;
}

.faq__inner ul li .faq_button {
  width: 34px;
  height: 34px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  cursor: pointer;
  border-radius: 17px;
}

.faq__inner ul li b svg {
  display: none;
  width: 10.6px;
  height: 10.6px;
}

.faq__inner ul li b svg.display-block {
  display: block !important;
}

/* section.shops */
section.shops {
  padding: 50px 0;
}

.shops__inner .shops_container {
  margin-top: 30px;
  width: 100%;
}

.shops__inner .shops_container ul {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 5px;
  width: fit-content;
  height: initial;
  max-width: 70%;
  padding-bottom: 20px;
}

.shops__inner .shops_container ul li.name,
.shops__inner .shops_container ul li.phone_number,
.shops__inner .shops_container ul li.shop_address {
  padding: 0 20px;
}

.shops__inner .shops_container ul li.name {
  padding-top: 20px;
  font-size: 22px;
}

.shops__inner .shops_container ul a {
  display: block;
  min-width: 40%;
  padding: 5px 15px;
  align-self: center;
  margin: 10px auto 0;
  text-align: center;
  height: auto;
  border-width: 1px;
  border-style: solid;
}

/* type_a */
.shops__inner--type_a .shops_wrap {
  flex-direction: row;
}

/* type_b */
.shops__inner--type_b .shops_container ul {
  width: 100%;
  max-width: none;
  margin-bottom: 30px;
}

.shops__inner--type_b .shops_container ul:last-child {
  margin-bottom: 0;
}

/* section.table */
section.table {
  padding: 50px 0;
}

.table__inner table {
  width: 100%;
  margin: 30px auto 0;
  border-collapse: collapse;
}

.table__inner table tr {
  border-width: 1px;
  border-style: solid;
}

.table__inner table tr th,
.table__inner table tr td {
  font-size: 16px;
  padding: 10px;
  text-align: left;
}

.table__inner table tr th {
  text-align: center;
  width: 30%;
}

.table__inner table tr td {
  vertical-align: middle;
}

.table__inner table tr td ul.treatment {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, 1fr);
  padding: 4px 0;
}

.table__inner table tr td ul.treatment li {
  display: none;
}

.table__inner table tr td ul.treatment li.deactive {
  min-height: 40px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  border-width: 1px;
  border-style: solid;
}

.table__inner table tr td ul.treatment li i {
  vertical-align: middle;
  font-size: 14px;
  line-height: 1.2;
  padding: 3px;
}

.table__inner table tr td a.open_the_map {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3px;
  width: fit-content;
  border-radius: 5px;
  padding: 2px 15px;
  margin-top: 3px;
}

.table__inner table tr td a.open_the_map svg {
  display: inline-block;
  vertical-align: middle;
  width: 10px;
  height: 12px;
}

.table__inner table tr td a.open_the_map i {
  display: inline-block;
  vertical-align: middle;
  font-size: 14px;
}

/* type_a */
.table__inner--type_a table tr th,
.table__inner--type_a table tr td {
  border-style: solid;
  border-width: 1px;
}

/* type_b */
.table__inner--type_b table tr {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border: none;
}

.table__inner--type_b table tr th,
.table__inner--type_b table tr td {
  text-align: left;
  width: 100%;
  padding: 0 10px;
}

.table__inner--type_b table tr th {
  padding-top: 10px;
  border-top-width: 1px;
  border-top-style: solid;
}

.table__inner--type_b table tr td {
  padding-bottom: 10px;
  border: none;
}

.table__inner--type_b table tr:last-child td {
  border-bottom-width: 1px;
  border-bottom-style: solid;
}

.table__inner--type_b table tr td ul.treatment {
  grid-template-columns: repeat(3, 1fr);
}

/* type_c */
.table__inner--type_c table tr {
  border: none;
}

.table__inner--type_c table tr th,
.table__inner--type_c table tr td {
  border-collapse: collapse;
  border-style: solid;
  border-width: 1px;
}

.table__inner--type_c table tr th {
  border-left: none;
}

.table__inner--type_c table tr td {
  border-right: none;
}

/* section.free */
section.free {
  padding: 50px 0;
  position: relative;
  overflow: hidden;
  background-size: cover;
}

section.free .free__inner {
  display: flex;
  flex-direction: column;
  gap: 15px 0;
  position: relative;
  z-index: 2;
}

section.free .bg_movie {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%);
  z-index: 1;
}

/* .img-middle */
.img-middle .free__inner a,
.img-middle .free__inner img,
.img-middle .free__inner video {
  order: 2;
}

.img-middle .free__inner h2 {
  order: 1;
}

.img-middle .free__inner h3 {
  order: 3;
}

.img-middle .free__inner p {
  order: 4;
}

/* img-middle-2 */
.img-middle-2 .free__inner a,
.img-middle-2 .free__inner img,
.img-middle-2 .free__inner video {
  order: 3;
}

.img-middle-2 .free__inner h2 {
  order: 1;
}

.img-middle-2 .free__inner h3 {
  order: 2;
}

.img-middle-2 .free__inner p {
  order: 4;
}

/* img-last */
.img-last .free__inner a,
.img-last .free__inner img,
.img-last .free__inner video {
  order: 4;
}

.free__inner a {
  display: block;
}

.free__inner img,
.free__inner video {
  display: block;
  object-fit: cover;
  width: 100%;
}

/* section.column */
section.column {
  padding: 50px 0;
}

.column__inner .column_wrapper {
  justify-content: center;
  align-items: flex-start;
  gap: 30px;
  margin-top: 30px;
}

.column__inner .column_1 {
  display: flex;
  flex-direction: column;
}

.column__inner .column_2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}

.column__inner .column_wrapper .column_item {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 15px;
}

.column__inner .column_item img {
  display: block;
  object-fit: contain;
  width: 100%;
  height: auto;
}

/* section.carousel */
section.carousel {
  padding: 50px 0;
}

.carousel__inner .carousel_wrapper {
  margin-top: 30px;
}

.carousel__inner h3 {
  margin-top: 5px;
}

.carousel__inner .carousel_wrapper .carousel_item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  width: fit-content;
  max-width: 70%;
}

.carousel__inner .carousel_item img {
  display: block;
  object-fit: contain;
  width: 100%;
}

/* #fix_contact */
.fixd_contact ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  width: 90%;
  margin: 0 auto;
}

.fixd_contact ul li {
  min-width: calc((100% - 20px) / 3);
  width: 100%;
  max-width: 80%;
}

.fixd_contact ul li a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  padding: 5px;
  margin: 0;
  width: 100%;
  font-size: clamp(12px, 3.5vw, 16px);
}

/* PC */
@media only screen and (min-width: 1073px) {
  section.cast-recruit,
  section.staff-recruit {
    padding: 50px 0;
  }
}
