@import url("reset.css");

.dopc{
	display: none !important;
}


/* 共通項目 */
html { font-size: 62.5%; }

body {
  font-family: "Noto Serif JP", serif;
  color: white;
  font-size: 1.3rem;
  letter-spacing: 0.15rem;
  line-height: 2rem;
  font-weight: 400;
  padding: 0;
  margin: 0;
  display: flex;
  min-height: 100vh;
  flex-direction: column;
}

img{
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  font-style: italic;
  background-repeat: no-repeat;
  background-size: cover;
  shape-margin: 0.75rem;
  vertical-align: top;
  margin: auto;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
  color: #000;
  outline: none;
}

a:hover{
	-webkit-transition: all .3s;
	transition: all .3s;
}

a:visited {
  /* color: #222; */
  text-decoration: none;
}


a {
  opacity: 1;
  transition: opacity 0.5s;
}
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

a:hover {
  /* opacity: 0.7; */
}

/* table{
	margin: 0 auto 20px auto;
	border-collapse: separate;
	border-spacing: 0px 10px;
	box-sizing: border-box;
}
tr{
	box-sizing: border-box;
	filter: drop-shadow(0px 3px 5px rgba(0,0,0,0.2));
}
th{
	padding: 10px;
	color: #111;
	text-align: center;
	background-color: #fff;
	vertical-align: middle;
	box-sizing: border-box;
}
td{
	padding: 10px;
	color: #111;
	text-align: left;
	background-color: #fff;
	vertical-align: middle;
	box-sizing: border-box;
} */


/* input[type="submit"] {
	-webkit-appearance: none;
	border: none;
} */
h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}
.clearfix{
  min-height: 1px;
}

.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

/* input, select {
  vertical-align: middle;
  -webkit-border-radius: 0px;
  border-radius: 0px;
  cursor: pointer;
  margin-top: -2px;
  padding: 5px 10px;
  box-sizing: border-box;
} */


.ft10 {
  font-size: 10px;
}


.v_center {
  display: flex;
  align-items: center;
}
.center {
  text-align: center;
  justify-content: center;
}

.max {
  max-width: 1200px;
  margin: 0 auto;
}

.lt200 {
  letter-spacing: 0.2em;
}

.lt150 {
  letter-spacing: 0.15em;
}

.mm_text {
  font-size: 0.9rem;
  line-height: 1.3;
}


.font_cinzel {
  font-family: "Cinzel Decorative", cursive;
}

.content-box {
  box-sizing: content-box;
}
.bottom {
  display: flex;
  align-items: flex-end;
}
.w {
  padding-left: 150px;
  padding-right: 150px;
}
.max {
  max-width: 1200px;
  margin: 0 auto;
}

.max950 {
  max-width: 950px;
  margin: 0 auto;
}
.pt_m {
  padding-top: 115px;
}

.pt_lm {
  padding-top: 234px;
}
@media screen and (max-width: 767px) {
  .pt_l {
      padding-top: 36.5rem;
  }
}


.first_text {
  margin-bottom: 40px;
}

.fz-spsize {
  text-align: center;
}

.fz-spsize {
  padding-top: 0.2rem;
  font-size: 1.2rem;
  padding-right: 0rem;
}

@media screen and (max-width: 767px) {
  .fz-spsize {
    font-size: 10px;
  }
}


.text.first_text {
  font-size: 1.5rem;
  line-height: 1.6;
}

.text {
  font-size: 1.3rem;
  line-height: 2rem;
}

@media screen and (max-width: 767px) {
  .first_text {
    margin-bottom: 27px;
  }
  .text {
      font-size: 1.2rem;
      line-height: 2rem;
  }
  .pt_lm {
    padding-top: 21.4rem;
  }
}

@media screen and (max-width: 767px) and (max-width: 579px) {
  .text {
      font-size: 2.4vw;
  }
}

.fixed_circle {
  position: fixed;
  right: 127px;
  bottom: 50px;
  width: 9.9rem;
  height: 9.9rem;
  border: solid 1px white;
  border-radius: 9.9rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  z-index: 500;
}

.fixed_circle span {
  font-size: 1.4rem;
  line-height: 1.35rem;
}

.arrow {
  display: inline-block;
  height: 6px;
  width: 22px;
  transition: background-image 0.5s;
  background: url(/img/arrow.svg) center/contain no-repeat;
}

.fixed_circle .arrow {
  transition: all 0.2s;
  position: relative;
  top: 12%;
  width: 29%;
  transform: translateX(0px);
}

.fixed_circle:hover .arrow {
  transform: translateX(5px);
}

.scroll_down {
  position: fixed;
  right: 63px;
  bottom: 60px;
  z-index: 500;
}

.scroll_down span {
  writing-mode: vertical-rl;
  font-size: 1rem;
  line-height: 1.4;
  padding-bottom: 15px;
  display: block;
}


.scroll_down .arrow_bottom {
  position: relative;
  left: 50%;
}


.arrow_bottom {
  display: inline-block;
  width: 7px;
  height: 64px;
  transition: background-image 0.5s;
  background: url(/img/arrow_bottom.svg) center/contain no-repeat;
}


.logo {
  position: fixed;
  top: 33px;
  left: 61px;
  writing-mode: vertical-rl;
  font-size: 1.5rem;
  z-index: 500;
}


/* index.php */
main.index {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
}

body main {
  flex-grow: 1;
}

main {
  background: top/cover no-repeat;
}

main.index .mv_wrap h1 {
  font-size: 6.8rem;
  line-height: 1.32;
}

main.index .mv_wrap h1 > img {
  width: 62.3rem;
  margin-bottom: 1rem;
}

main.index .mv_wrap h2 {
  font-size: 3.1rem;
  line-height: 1.32;
}

main.index .text_wrap .text1 {
  font-size: 1.9rem;
  line-height: 1.36;
  margin-bottom: 16px;
}

main.index .text_wrap .text2 {
  font-size: 1.4rem;
  line-height: 1.35;
  margin-bottom: 85px;
  text-align: left;
}

main.index .indexBtn {
  display: flex;
  justify-content: space-evenly;
  margin-top: 50px;
}

.indexBtn .enterBtn, .indexBtn .leaveBtn {
  display: inline-block;
  padding: 25px;
  border: 1px solid #f2ddae;
  font-size: 2.0rem;
  line-height: 1.35;
  transition: all 0.3s;
  font-family: "Noto Serif JP", serif;
}

.indexBtn a, .leaveBtn a{
  /* padding: 18px 0 18px 0; */
  color: #fff;
  text-align: center;
  display: block;
}

.indexBtn a:hover, .leaveBtn a:hover{
  color: #fff;
  box-shadow: 0 0 10px #fff inset;
}

.warningText{
  margin-top: 20px;
}

main.index .text_wrap .link .contentTitle {
  font-size: 2.4rem;
  padding-bottom: 20px;
}

main.index .text_wrap .link .contentTitle span {
  font-size: 1.4rem;
}


main.index .linkBanner div{
  margin-bottom: 5px;
}


main.index .copyright {
  font-size: 1rem;
  line-height: 1.4;
  margin-bottom: 0px;
}

@media screen and (max-width: 1600px) {
  .fixed_circle {
      right: 30px;
  }
  .scroll_down {
    right: 19px;
    bottom: 117px;
  }
  .scroll_down span {
    padding-bottom: 7px;
  }
  .scroll_down .arrow_bottom {
    width: 6px;
    height: 47px;
  }
}


@media (max-width: 1130px) {
  .logo {
      left: 45px;
  }
}

@media screen and (max-width: 767px) {
  main.index {
    background-repeat: repeat;
    background-size: 100% auto;
    background-image: url("/img/sp/mv.png") !important;
  }
  .logo {
    left: 10px;
  }
  .one_screen {
    height: 611px;
  }
  .max, .w, .wxx {
    padding-left: 30px;
    padding-right: 30px;
  }
  main.index .mv_wrap h1 {
    font-size: 3.8rem;
  }
  main.index .mv_wrap h2 {
    font-size: 1.8rem;
  }
  .fixed_circle {
    bottom: 47px;
    width: 72px;
    height: 72px;
  }
  .fixed_circle span {
    font-size: 1.8vw;
  }
  .max, .w, .wxx {
    padding-left: 30px;
    padding-right: 30px;
  }
  main.index .text_wrap .text1 {
    font-size: 1.6rem;
    margin-bottom: 12px;
  }
  main.index .text_wrap .text2 {
    font-size: 1.2rem;
    line-height: 1.55;
    margin-bottom: 105px;
  }
  main.index .text_wrap .copyright {
    font-size: 0.9rem;
    margin-bottom: 19px;
  }
}

@media screen and (max-width: 767px) and (max-width: 579px) {
  .fixed_circle span {
    font-size: 1.8vw;
  }
  .one_screen {
    height: 100vh;
  }
  main.index .mv_wrap h1 {
    font-size: 7.5vw;
  }
  main.index .mv_wrap h2 {
    font-size: 3.6vw;
  }
  main.index .text_wrap .text1 {
    font-size: 3.2vw;
  }
  main.index .text_wrap .text2 {
    font-size: 2.4vw;
  }
  main.index .text_wrap .copyright {
    font-size: 1.8vw;
  }
  .logo {
    font-size: 3vw;
  }
}

@media screen and (max-width: 579px) {
  main.index .mv_wrap h1 > img {
    width: 64vw;
  }
  .scroll_down span {
    font-size: 2vw;
  }
}

@media screen and (max-width: 399px) {
  .scroll_down {
    right: 8px;
  }
}


/* header.php */
header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

.header {
  display: flex;
  justify-content: center;
  padding-top: 33px;
  padding-left: 30px;
  padding-right: 30px;
  align-items: center;
}

.header {
  -webkit-transition: 0.3s ease-out;
  transition: 0.3s ease-out;
}


@media screen and (min-width: 1200px) {
  .xl_sp {
      display: none !important;
  }
}

@media screen and (max-width: 1199px) {
  .header {
      padding-top: 15px;
      justify-content: flex-end;
  }
}

@media screen and (max-width: 767px) {
  .header {
      margin-top: 0;
  }
}

.header .header_ham {
  z-index: 100;
  display: block;
}

.header .header_ham a {
  position: relative;
  width: 44px;
  height: 44px;
}

.header .header_ham a,
.header .header_ham a span,
.header .header_ham a span::after,
.header .header_ham a span::before {
  display: inline-block;
  transition: all 0.4s;
  box-sizing: border-box;
}
.header .header_ham a span:nth-of-type(1) {
  top: 37%;
  transform: translate(0, 0);
}
.header .header_ham a span:nth-of-type(2) {
  top: 63%;
  transform: translateX(5px) scaleX(0.75);
}


.header .header_ham a span {
  position: absolute;
  right: 0;
  width: 40px;
  height: 2px;
}

.header .header_ham a span::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 50%;
  height: 100%;
  background: white;
}

.header .header_ham a span::after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 50%;
  height: 100%;
  background: white;
}

.header .header_links {
  background: white;
  width: 215px;
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  padding-top: 98px;
  overflow: scroll;
  transform: translateX(105%);
  transition: all 0.2s;
  overflow: hidden;
}


.header .header_links.active {
  transform: translateX(0%);
}



.header .header_links ul {
  flex-direction: column;
}

.header .header_links ul li {
  text-align: center;
  margin: 0 auto 14px auto;
}

@media screen and (max-width: 1199px) {
  .header .header_ham a.active span::after,
  .header .header_ham a.active span::before {
      width: 25%;
      background: #002727;
  }
  .header .header_links ul li {
      text-align: center;
      margin: 0 auto 14px auto;
  }
  .header .header_links ul li a {
    color: #272727;
    font-size: 1.4rem;
  }
  .header .header_ham a.active span:nth-of-type(1) {
    top: 30%;
    transform: translateY(9px) rotate(-45deg);
  }
  .header .header_ham a.active span:nth-of-type(2) {
    top: 70%;
    transform: translateY(-9px) rotate(45deg);
  }
}

@media screen and (max-width: 1199px) and (max-width: 579px) {
  .header .header_links ul li a {
      font-size: 2.8vw;
  }
}



/* footer.php */
footer {
  margin-top: -50px;
}

footer p {
  /* position: fixed; */
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  text-align: center;
  padding: 10px;
}

.footer_fixed {
  position: fixed;
  z-index: 100;
  right: 100px;
  bottom: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

@media screen and (max-width: 1024px) {
  .footer_fixed {
      right: 20px;
      bottom: 10px;
  }
}

@media screen and (max-width: 767px) {
  .footer_fixed {
      margin-bottom: 20px;
      width: 70px;
      right: 0;
  }
}

.footer_fixed a {
  pointer-events: auto;
  height: 60px;
  opacity: 0.5;
}

.footer_fixed_linesp {
  display: block;
  pointer-events: auto;
  text-align: center;
  margin: 5px auto;
}
.footer_fixed_linesp > img {
  width: 60px !important;

}

.footer_fixed_telsp {
  display: block;
  pointer-events: auto;
  opacity: 0.6;
}


.footer_fixed a svg {
  width: 100px;
  height: 100px;
}

/* 電話リンクボタン */
.circular-button {
  width: 60px;
  height: 90px;
  border-radius: 50%;
  background-color: #000;
  border: 1px solid #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #fff;
  text-decoration: none;
  font-family: Helvetica, Arial, sans-serif;
}

.circular-button img {
  width: 70px;
  height: 70px;
  margin-bottom: 5px;
  margin: 0;
}

.circular-button .time {
  font-size: 8px;
  text-align: center;
  letter-spacing: 0.05em;
}



/* top.php */

.top-container .text_wrap .text1 {
  font-size: 1.8rem;
  /* line-height: 1.36; */
  /* margin-bottom: 16px; */
  text-align: center;
  /* background-color: black; */
  color: white;
  padding: 20px;
}

.top-container .text_wrap .text2 {
  font-size: 1.3rem;
  /* line-height: 1.6; */
  /* margin-bottom: 85px; */
  /* text-align: center; */
  padding-bottom: 20px;
}




main.index2 .content_Title{
  margin-bottom: 20px;
  padding: 20px 0;
  text-align: center;
}

main.index2 .content_Title img{
  width: 250px;
}







main.index2 .swiper-container {
  width: 100%;
  /* height: 100vh; */
  overflow: hidden;
  padding-bottom: 50px;
}

main.index2 .swiper-container .bg {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}

main.index2 .swiper-container .bg img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.swiper-pointer-events {
  touch-action: pan-y;
}
.logo > img {
  width: 1.8rem;
}

main.index2 .swiper-container .swiper-wrapper .slide_box {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: flex-end;
}

main.index2 .swiper-container .swiper-button-next,
main.index2 .swiper-container .swiper-button-prev {
  color: #fff;
}

main.index2 .swiper-container .swiper-button-next:after,
main.index2 .swiper-container .swiper-button-prev:after {
  font-size: 3rem;
}


main.index2 .swiper-container .swiper-wrapper .slide_box .mb_set {
  position: relative;
  z-index: 10;
}


main.index2 .content_Title{
  margin-bottom: 20px;
  padding: 20px 0;
  text-align: center;
}

main.index2 .content_Title img{
  width: 250px;
}






.wxx {
  padding-right: 85px;
  padding-left: 85px;
}

.max {
  max-width: 1200px;
  margin: 0 auto;
}

.max_left {
  margin-left: 0;
}

.mb_set .ll_text {
  margin-left: 0px;
}

.mb_set .mb_ss {
  margin-bottom: -1px;
}
.lt200 {
  letter-spacing: 0.2em;
}

.ll_text {
  font-size: 4.8rem;
  line-height: 6.5rem;
}
.mb_set .mb_s {
  margin-bottom: 6px;
}
.l_text {
  font-size: 1.5rem;
  line-height: 2.1rem;
}

.mb_set .mb_m {
  margin-bottom: 8px;
}

.top_btn_in {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0 15px;
}

.rect_button {
  border: solid 1px white;
  display: inline-flex;
  align-items: flex-end;
}
.rect_button span {
  padding: 0.3rem 1.1rem 0.2rem;
  font-size: 1.4rem;
}

.top_btn_in .rect_button .arrow {
  transition: transform 0.5s;
  transform: translateX(0px);
}
.rect_button .arrow {
  background: url(/img/arrow.svg) center/contain no-repeat;
  margin: 1.1rem 2.2rem 0.75rem 0;
}
.mb_set .mb_last {
  margin-bottom: 38px;
}

.moreButton {
  width: 120px !important;
}

.swiper-wrapper .slide_box .prof_bg{
  background-color: #0000001c;
  z-index: 9;
  width: 100%;
}






@media screen and (max-width: 767px) {
  .max, .w, .wxx {
      padding-left: 45px;
      padding-right: 15px;
  }
  .mb_set .ll_text {
    margin-left: 0;
  }
  .mb_set .mb_ss {
    margin-bottom: 5px;
  }
  .ll_text {
    font-size: 3.2rem;
    line-height: 4.3rem;
  }
  .mb_set .mb_last {
    margin-bottom: 110px;
  }
  .m_text {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  footer {
    margin-top: -40px;
  }
  .l_text {
    font-size: 1.4rem;
    line-height: 2rem;
  }
}

@media screen and (max-width: 767px) and (max-width: 579px) {
  .ll_text {
      font-size: 6.4vw;
  }
  .m_text {
    font-size: 2vw;
  }
  footer p {
    font-size: 2vw;
  }
  .l_text {
    font-size: 2.8vw;
}
}


/* howto.php */
.content-box {
  box-sizing: content-box;
}

.steps .step .step_img_wrap {
  position: relative;
}
.steps .step .step_number {
  position: absolute;
  width: 41px;
  height: 41px;
  right: 0;
}

.circle {
  border: solid 1px white;
  border-radius: 100vw;
  display: flex;
  justify-content: center;
  align-items: center;
}


@media screen and (max-width: 1199px) {
  main.howTo .w {
      padding-left: 70px;
      padding-right: 70px;
      padding-top: 21.4rem;
  }
}


@media screen and (max-width: 767px) {
  main.howTo .w {
    padding-left: 45px;
    padding-right: 15px;
    padding-bottom: 30px;
  }
  .pt_m {
    padding-top: 15.4rem !important;
  }
  .steps .step {
    margin-bottom: 42px;
  }
  .steps .step .step_img_wrap {
      position: relative;
      margin-bottom: 15px;
  }
  .steps .step img {
    width: 100%;
    object-fit: contain;
  }
  .steps .step .step_number {
    bottom: 3px;
    right: 3px;
  }
}

/* system.php */

body.system .class {
    padding-bottom: 97px;
}


body.system .lazyloaded {
  background: center/cover no-repeat;
}

body.system .price {
  padding-bottom: 123px;
}
body.system main > div > * {
  max-width: 1040px;
}

body.system .mb_set .mb_ms {
  margin-bottom: 7px;
}

body.system .mb_set .mb_mss {
  margin-bottom: 15px;
}
body.system .mb_set .mb_l {
  margin-bottom: 5px;
}

body.system .mb_set .mb_ll {
  margin-bottom: 25px;
}

body.system .mb_set .mb_xl {
  margin-bottom: 20px;
}

body.system .mb_set .mb_xll {
  margin-bottom: 38px;
}

body.system .mb_set .mb_xslll {
  margin-bottom: 35px;
}

body.system .mb_set .mb_ssll {
  margin-bottom: 17px;
}
body.system .mb_set .mb_xsll {
  margin-bottom: 35px;
}

body.system .mt_20 {
  margin-top: 20px;
}

body.system .red {
  color: #ffffff;
  font-weight: bold;
  font-size: 16px;
}

body.system .cp_ttl{
  font-size: 18px!important;
  line-height: 1.8;
}

body.system .cp_txt {
  font-size: 15px!important;
  line-height: 2.0;
}

/* body.system .cp_txt span{
  display: block;
  border-bottom: 1px solid red;
  padding-bottom: 10px;
  margin-bottom: 10px;
} */

body.system .max583 {
  max-width: 583px;
}


/* .scroll_wrap {
  overflow-x: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
} */

body.system table {
  min-width: 100%;
}


body.system table.nowrap {
  /* white-space: nowrap; */
}

.bgcolor-amber {
  background-color: rgba(79, 53, 42, 0.5);
}

table {
  width: 100%;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

table.mini th,
table.mini td,
table .mini th,
table .mini td {
  padding-top: 10px;
  padding-bottom: 10px;
}

td, th {
  vertical-align: top;
  padding: 0;
}

table th, table td {
  font-weight: inherit;
  text-align: center;
  border-top: solid 1px white;
  border-left: solid 1px white;
  border-bottom: 1px solid;
  /* padding: 4px 4px; */
  font-size: 1.4rem;
  vertical-align: middle;
}

table th:last-child, table td:last-child {
  border-right: solid 1px white;
}

table tr:last-child th, table tr:last-child td {
  border-bottom: solid 1px white;
}


#indexPage table th, #indexPage table td {
  font-weight: inherit;
  text-align: center;
  border-top: none;
  border-left: none;
  padding: 0;
  font-size: 1.4rem;
  vertical-align: middle;
}

#indexPage table th:last-child, #indexPage table td:last-child {
  border-right: none;
}

#indexPage table tr:last-child th,#indexPage table tr:last-child td {
  border-bottom: none;
}


.link table th, .link table td {
  font-weight: inherit;
  text-align: center;
  border-top: none;
  border-left: none;
  padding: 0;
  font-size: 1.4rem;
  vertical-align: middle;
  border-bottom: none;
}

.link table th:last-child, .link table td:last-child {
  border-right: none;
}

.link table tr:last-child th,.link table tr:last-child td {
  border-bottom: none;
}




.fuzokunv_tab .home img{
  margin: 0!important;
}

.fuzokunv_tab .area img {
  width: 65px!important;
}

.pt_s {
  padding-top: 40px;
}
.cp_ttl {
  font-size: 2rem;
  line-height: 1.8;
}
.cp_txt {
  font-size: 1.8rem;
  line-height: 1.8;
}




body.system .class_table_img_wrap img {
  object-fit: contain;
}
@media screen and (max-width: 999px) {
  body.system .class_table_img_wrap img {
      width: 400px;
  }
}
@media screen and (max-width: 767px) {
  body.system .common_img {
      max-width: 100%;
      width: 400px;
      object-fit: contain;
  }
}



.steps .step .step_point {
  position: absolute;
  left: 0;
  bottom: 0;
  background: white;
  color: #272727;
  padding: 4px 15px;
  font-size: 2.3rem;
}

body.system .steps .step .step_content .step_content_inner {
  flex-grow: 1;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}

table th:last-child, table td:last-child {
  border-right: solid 1px white;
}

body.system .f_right {
  display: flex;
  justify-content: flex-end;
}
body.system .right2 {
  margin-right: 2px;
}

.l_arrow {
  display: inline-block;
  height: 6px;
  width: 47px;
  transition: background-image 0.5s;
  background: url(/img/long_arrow.svg) center/contain no-repeat;
}

body.system .mb_set .mb_sll {
  margin-bottom: 15px;
}

.steps .step:last-child {
  margin-bottom: 0;
  box-sizing: content-box;
}

@media screen and (max-width: 767px) {
  body.system .mb_set .mb_l {
    margin-bottom: 5px;
  }
  body.system .price {
      padding-bottom: 96px;
  }
  body.system .mb_set .mb_xl {
    margin-bottom: 5px;
  }
  .scroll_wrap {
    width: 100%;
  }
  body.system table.table_type_a {
    width: fit-content;
    /* table-layout: fixed; */
  }
  body.system table.nowrap {
    /* white-space: nowrap; */
  }
  body.system table {
    min-width: 100%;
  }
  body.system table.table_type_a th,
  body.system table.table_type_a td {
    width: 18rem;
  }

  body.system table.table_type_a th:first-child,
  body.system table.table_type_a td:first-child {
    width: 20rem;
  }
  .cp_ttl {
    font-size: 1.8rem;
    line-height: 1.8;
  }
  body.system .mb_set .mb_ms {
    margin-bottom: 10px;
  }
  .cp_txt {
    font-size: 1.5rem;
    line-height: 1.8;
  }
  body.system .mb_set .mb_slll {
    margin-bottom: 37px;
  }
  body.system .ban .steps .step:last-child {
    padding-bottom: 115px;
  }
}

@media screen and (max-width: 579px) {
  table th, table td {
      font-size: 2.0vw;
  }
}

/* body.system .wxx {
  padding-right: 15px;
  padding-left: 45px;
} */

body.system p:not(:first-child) {
  font-size: 1.1rem;
  line-height: 1.8;
}





/* recruit.php */
main.recruit .recruit_woman_staff .hira_sans {
  font-family: "Hiragino Kaku Gothic ProN";
}

main.recruit .recruit_woman_staff .w_600 {
  font-weight: 600;
}
main.recruit .mb_set .mb_xl {
  margin-bottom: 7px;
}
main.recruit .mb_set .mb_xxl {
  margin-bottom: 50px;
}

main.recruit .recruit_woman_staff .text_mll {
  font-size: 1.9rem;
}

main.recruit .recruit_woman_staff .lh_20 {
  line-height: 1.33;
}

main.recruit .recruit_woman_staff .lh_25 {
  line-height: 1.66;
}
main.recruit .recruit_woman_staff .lh_28 {
  line-height: 1.86;
}
main.recruit .recruit_woman_staff .lh_35 {
  line-height: 2.3;
}

main.recruit .recruit_woman_staff .lh_40 {
  line-height: 2.6;
}

main.recruit .recruit_woman_staff .mb_12 {
  margin-bottom: 1.2rem;
}

main.recruit .recruit_woman_staff .mb_16 {
  margin-bottom: 1.6rem;
}

main.recruit .recruit_woman_staff .mb_35 {
  margin-bottom: 3.5rem;
}

main.recruit .recruit_woman_staff .mb_42 {
  margin-bottom: 4.2rem;
}

main.recruit .recruit_woman_staff .mb_55 {
  margin-bottom: 5.5rem;
}

main.recruit .recruit_woman_staff .mb_62 {
  margin-bottom: 6.2rem;
}
main.recruit .recruit_woman_staff .mb_80 {
  margin-bottom: 8rem;
}

main.recruit .recruit_woman_staff .mb_127 {
  margin-bottom: 12.7rem;
}

main.recruit .recruit_woman_staff .recruit_table th {
  border-color: #272727;
  font-size: 1.8rem;
  font-weight: 400;
  width: 24%;
}

main.recruit .recruit_woman_staff .recruit_table td {
  text-align: left;
  padding: 2.5rem 1rem;
  border-color: #272727;
}




main.recruit .recruit_mv.lazyloaded {
  background: url(/img/recruit/recruit_gradient.png) 100% 100%/100% 100% no-repeat;
}

main.recruit .recruit_mv {
  padding: 133px 136px 75px;
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
}

@media (max-width: 1360px) {
  main.recruit .recruit_mv {
      padding-left: 30px;
      padding-right: 30px;
      padding-top: 100px;
      margin-right: auto;
      margin-left: auto;
  }
}
@media (max-height: 750px) {
  main.recruit .recruit_mv {
      padding-top: 95px;
      padding-bottom: 60px;
  }
}
@media (max-height: 700px) {
  main.recruit .recruit_mv {
      max-height: unset;
      height: auto;
      padding-bottom: 70px;
  }
}



main.recruit .recruit_mv .recruit_mv_inner {
  width: 100%;
  margin: 0 auto 0 auto;
  position: relative;
  max-height: 580px;
}

@media (max-width: 1200px) {
  main.recruit .recruit_mv .recruit_mv_inner {
      background: url(/img/sp/recruit_mv.png) 100% 100% / cover no-repeat;
      height: 100%;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
  }
}

@media (max-width: 1360px) {
  main.recruit .recruit_mv .recruit_mv_inner {
      margin-right: auto;
      margin-left: auto;
  }
}
@media (max-height: 750px) {
  main.recruit .recruit_mv .recruit_mv_inner {
      justify-content: flex-start;
  }
}

@media (max-height: 700px) {
  main.recruit .recruit_mv .recruit_mv_inner {
      max-height: unset;
  }
  main.recruit .recruit_mv .recruit_mv_inner {
    height: auto;
    max-height: unset;
}
}




main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_bg {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  object-fit: cover;
  z-index: -1;
  height: 100%;
}

main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-height: 580px;
}
@media screen and (max-width: 767px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap {
      flex-direction: column;
  }
}
@media (max-height: 700px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap {
      max-height: unset;
  }
}

main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left {
    writing-mode: vertical-rl;
}

@media screen and (max-width: 767px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left {
      writing-mode: horizontal-tb;
  }
}

main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left .recruit_mv_left_ja {
    position: relative;
    font-size: 9rem;
    letter-spacing: 0.5em;
    margin-left: 6rem;
    white-space: nowrap;
    margin-top: -3rem;
    max-height: 580px;
}

@media (max-width: 1360px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left .recruit_mv_left_ja {
      margin-left: 12rem;
  }
}

@media screen and (max-width: 767px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left .recruit_mv_left_ja {
      margin-left: 0;
      margin-top: 6rem;
      letter-spacing: 0.2em;
      font-size: 5.5rem;
      margin-bottom: 6rem;
  }
}

@media (max-height: 700px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left .recruit_mv_left_ja {
      max-height: unset;
  }
}

main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left .recruit_mv_left_en {
    font-size: 1.6rem;
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    letter-spacing: 0.2em;
}

@media screen and (max-width: 767px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left .recruit_mv_left_en {
      top: calc(100% + 4rem);
  }
}



main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right {
    padding-right: 6.8rem;
    padding-bottom: 3rem;
    padding-top: 3rem;
    max-width: 53rem;
    max-height: 100%;
}

@media screen and (max-width: 767px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right {
      padding-left: 1rem;
      padding-right: 1rem;
  }
}


main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_l {
    font-size: 1.6rem;
    line-height: 2.25;
}

@media (max-height: 699px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_l {
      margin-bottom: 1rem;
  }
}


main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_s,
main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_s * {
    -ms-overflow-style: none !important;
    scrollbar-width: none !important;
}

main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_s {
    line-height: 1.9;
    max-height: 22vh;
    overflow-y: auto;
    margin-right: -4rem;
    padding-right: 4rem;
}

@media screen and (max-width: 579px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_s {
      line-height: 1.4;
  }
}

@media (max-height: 699px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_s {
      max-height: 137px;
  }
}

@media screen and (max-width: 767px) {
  main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_s {
      max-height: 18vh;
      margin-right: -0.4rem;
      padding-right: 0.4rem;
  }
}

main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_s .simplebar-track.simplebar-vertical {
    background: #ffffff;
    width: 1px;
}

main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_right .mv_text_s .simplebar-track.simplebar-vertical .simplebar-scrollbar:before {
    opacity: 1;
    border-radius: 0;
    right: 0;
    top: 0;
    left: 0;
    bottom: 0;
    background: #7400b1;
}


main.recruit .recruit_woman_staff {
  color: #272727;
  margin: 0 auto;
  background: #fff;
  position: relative;
}

main.recruit .recruit_woman_staff .woman_wrap {
  padding-top: 10.8rem;
  padding-right: 26rem;
  padding-left: 26rem;
  position: relative;
}

@media screen and (max-width: 999px) {
  main.recruit .recruit_woman_staff .woman_wrap {
      padding-right: 30px;
      padding-left: 30px;
  }
}


main.recruit .recruit_woman_staff .woman_wrap .gray_bg1 {
  position: absolute;
  top: 0;
  left: 0;
  width: 44rem;
  height: 79rem;
  max-width: 60%;
  background: #efefef;
}

main.recruit .recruit_woman_staff .woman_wrap .gray_bg2 {
  position: absolute;
  bottom: 35rem;
  right: 0;
  width: 51rem;
  height: 119rem;
  max-width: 60%;
  background: #efefef;
}

main.recruit .recruit_woman_staff .woman_wrap .img_bg.lazyloaded {
  background: url(/img/recruit/recruit_women.png) center/cover no-repeat;
}

main.recruit .recruit_woman_staff .woman_wrap .img_bg {
  position: absolute;
  bottom: -17rem;
  right: 0;
  width: 35rem;
  height: 76rem;
  max-width: 40%;
}
main.recruit .recruit_woman_staff .wonam_inner {
  position: relative;
  z-index: 1;
}


main.recruit .recruit_woman_staff .recruit_section_title {
  font-size: 2.5rem;
  letter-spacing: 0.1em;
  line-height: 1.32;
  position: relative;
}
@media screen and (max-width: 999px) {
  main.recruit .recruit_woman_staff .recruit_section_title {
      left: 5.5rem;
      display: inline-block;
  }
}



main.recruit .recruit_woman_staff .recruit_section_title .section_label {
  position: absolute;
  left: -15rem;
  transform-origin: 0% 50%;
  transform: rotate(90deg);
  font-size: 4rem;
}

main.recruit .recruit_woman_staff .recruit_section_title::after {
  content: "";
  display: block;
  height: 1px;
  width: 5.8rem;
  background: #272727;
  position: absolute;
  right: calc(100% + 2.3rem);
  top: 50%;
  transform: translateY(-50%);
}

@media screen and (max-width: 999px) {
  main.recruit .recruit_woman_staff .recruit_section_title::after {
      width: 2.6rem;
  }
}

main.recruit .recruit_woman_staff .text_mll > .l_text {
  margin-left: 2rem;
}

main.recruit .recruit_woman_staff .scroll_box {
  max-height: 38.4rem;
  overflow: hidden auto;
  position: relative;
  padding-right: 14rem;
  margin-right: -14rem;
}

@media screen and (max-width: 999px) {
  main.recruit .recruit_woman_staff .scroll_box {
      padding-right: 2rem;
      margin-right: -2rem;
  }
}



main.recruit .recruit_woman_staff .scroll_box::before {
  content: "";
  position: absolute;
  display: block;
  background: url(/img/recruit/recruit_scroll.png) center/contain no-repeat;
  width: 2.7rem;
  height: 1.3rem;
  top: 10.1rem;
  right: 1rem;
  transform-origin: 100% 50%;
  transform: rotate(-90deg) translate(0%, 0%);
}

main.recruit .recruit_woman_staff .scroll_box .simplebar-track.simplebar-vertical {
    background: #808080;
    margin-top: 15.1rem;
    width: 1px;
    transform: translate(0.5px, 0px);
    margin-right: 1rem;
}

main.recruit .recruit_woman_staff .scroll_box::after {
  content: "SCROLL DOWN";
  font-size: 1rem;
  font-weight: 400;
  white-space: nowrap;
  letter-spacing: 0.1em;
  position: absolute;
  transform-origin: 100% 50%;
  right: 1rem;
  top: 0;
  transform: rotate(-90deg) translate(0%, 0);
}

main.recruit .recruit_woman_staff .recruit_table {
  max-width: 77rem;
}

main.recruit .recruit_woman_staff .staff_wrap {
  padding-top: 20rem;
  padding-right: 26rem;
  padding-left: 26rem;
  position: relative;
}

@media screen and (max-width: 999px) {
  main.recruit .recruit_woman_staff .staff_wrap {
      padding-right: 30px;
      padding-left: 30px;
  }
}


main.recruit .recruit_woman_staff .staff_wrap .gray_bg1 {
  position: absolute;
  width: 54rem;
  height: 162rem;
  background: #efefef;
  top: 12rem;
  left: 15rem;
  max-width: 40%;
}

@media screen and (max-width: 999px) {
  main.recruit .recruit_woman_staff .staff_wrap .gray_bg1 {
      left: 10%;
  }
}

main.recruit .recruit_woman_staff .staff_wrap .gray_bg2 {
  position: absolute;
  width: 54rem;
  height: 104rem;
  max-width: 50%;
  right: 10%;
  bottom: 9rem;
  background: #efefef;
}

main.recruit .recruit_woman_staff .staff_wrap .img_bg {
  position: absolute;
  bottom: 90rem;
  right: 0;
  width: 58rem;
  height: 75rem;
  max-width: 50%;
}

main.recruit .recruit_woman_staff .staff_wrap .img_bg.lazyloaded {
  background: url(/img/recruit/recruit_treatment.png) center/cover no-repeat;
}


main.recruit .recruit_woman_staff .staff_wrap .staff_inner {
  position: relative;
  z-index: 1;
}


main.recruit .recruit_qa.lazyloaded {
  background: url(/img/sp/recruit_qa.png) center/cover no-repeat;
}

main.recruit .recruit_qa {
  position: relative;
  padding: 143px 26rem;
}

@media screen and (max-width: 999px) {
  main.recruit .recruit_qa {
      /* padding: 58px 30px 170px 30px; */
    padding: 0px 0 20px;
  }
}

main.recruit .recruit_qa .recruit_qa_title {
  position: absolute;
  left: 90px;
  top: 100px;
  font-size: 40px;
  font-weight: bold;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  writing-mode: vertical-rl;
}

@media screen and (max-width: 999px) {
  main.recruit .recruit_qa .recruit_qa_title {
      position: static;
      writing-mode: horizontal-tb;
      max-width: 800px;
      margin: 0 auto 58px auto;
  }
}
@media screen and (max-width: 767px) and (max-width: 579px) {
  main.recruit .recruit_qa .recruit_qa_title {
    font-size: 6.4vw;
    font-family: "Hiragino Kaku Gothic ProN", sans-serif;
    writing-mode: vertical-rl;
    position: absolute;
    left: 50px;
    top: 90px;
  }
}

main.recruit .recruit_qa .qa_wrap {
  margin: 0 auto;
}

main.recruit .recruit_qa .qa_wrap .title_recruit {
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  main.recruit .title_recruit {
      font-size: 4vw;
  }
}
@media screen and (max-width: 767px) and (max-width: 579px) {
  main.recruit .recruit_qa .qa_wrap .title_recruit {
    font-size: 3.5vw;
  }
}


main.recruit .title_recruit::before {
  content: "";
  display: inline-block;
  width: 58px;
  height: 1px;
  background: white;
  margin-right: 23px;
  bottom: 3px;
  position: relative;
}

main.recruit .recruit_qa .qa_wrap .qa_content {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: 50px;
}

@media screen and (max-width: 999px) {
  main.recruit .recruit_qa .qa_content {
      align-items: flex-start;
  }
}
main.recruit .recruit_qa .qa_wrap .qa_q {
  color: white;
}

main.recruit .recruit_qa .qa_wrap .qa_q_wrap {
  margin-bottom: 20px;
}

main.recruit .recruit_qa .qa_wrap .qa_a,
main.recruit .recruit_qa .qa_wrap .qa_q {
  display: flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: 100vw;
  border: solid white 1px;
  background: transparent;
  font-size: 1.9rem;
  font-weight: 700;
  font-family: "Hiragino Kaku Gothic Std", sans-serif;
  margin-right: 20px;
  flex-shrink: 0;
}

main.recruit .recruit_qa .qa_wrap .qa_m_Text{
  font-size: 1.2rem;
  margin-bottom: 50px;
  line-height: 2.0;
}




@media screen and (max-width: 767px) {
  main.recruit .recruit_qa .qa_wrap .qa_a,
  main.recruit .recruit_qa .qa_wrap .qa_q {
      width: 8vw;
      height: 8vw;
      margin-right: 10px;
  }
}

@media screen and (max-width: 767px) and (max-width: 579px) {
  main.recruit .recruit_qa .qa_wrap .qa_a,
  main.recruit .recruit_qa .qa_wrap .qa_q {
      font-size: 4.2vw;
  }
}


main.recruit .recruit_qa .qa_wrap .qa_text {
  font-size: 1.2rem;
}

main.recruit .recruit_qa .qa_wrap .qa_a_wrap {
  margin-bottom: 50px;
}

main.recruit .recruit_qa .qa_wrap .qa_a {
  color: white;
}
main.recruit .recruit_contact.lazyloaded {
  background: url(/img/recruit/recruit_gradient.png) center/100% 100% no-repeat;
}
main.recruit .recruit_contact {
  padding: 100px 80px;
}
@media screen and (max-width: 767px) {
  main.recruit .recruit_contact {
      padding: 40px 30px;
  }
}


main.recruit .recruit_contact .recruit_contact_wrap.lazyloaded {
  background: url(/img/sp/recruit_contact.png) center/cover no-repeat;
}

main.recruit .recruit_contact .recruit_contact_wrap {
  height: 380px;
  display: flex;
  align-items: center;
  justify-content: space-around;
  padding: 90px 100px;
  position: relative;
}

@media screen and (max-width: 767px) {
  main.recruit .recruit_contact .recruit_contact_wrap {
      padding: 155px 30px 135px 30px;
  }
}

@media screen and (max-width: 767px) {
  main.recruit .recruit_contact .recruit_contact_wrap {
      flex-direction: column;
  }
}


main.recruit .recruit_contact .recruit_contact_wrap .contact_title {
  font-size: 4rem;
  font-family: "Helvetica";
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  main.recruit .recruit_contact .recruit_contact_wrap .contact_title {
      font-size: 6.4vw;
  }
}


main.recruit .circle {
  width: 9.9rem;
  height: 9.9rem;
  border: solid 1px white;
  border-radius: 9.9rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  z-index: 500;
}

@media screen and (max-width: 1600px) {
  main.recruit .circle {
      right: 30px;
  }
}

@media screen and (max-width: 767px) {
  main.recruit .circle {
      bottom: 47px;
      width: 72px;
      height: 72px;
  }
}
@media screen and (max-width: 767px) {
  main.recruit .recruit_contact .recruit_contact_wrap .circle {
      position: absolute;
  }
}


main.recruit .circle span {
  font-size: 1.4rem;
  line-height: 1.35rem;
}

@media screen and (max-width: 767px) {
  main.recruit .circle span {
      font-size: 1.1rem;
      line-height: 1.5;
  }
}

@media screen and (max-width: 767px) and (max-width: 579px) {
  main.recruit .circle span {
      font-size: 1.8vw;
  }
}


main.recruit .circle .arrow {
  position: relative;
  top: 12%;
  width: 29%;
  transform: translateX(0px);
}

@media screen and (max-width: 767px) {
  main.recruit .circle span {
      font-size: 1.1rem;
      line-height: 1.5;
  }
}
@media screen and (max-width: 767px) and (max-width: 579px) {
  main.recruit .circle span {
      font-size: 1.8vw;
  }
}


/* contact.php */
main.contact.lazyloaded {
  background-size: cover;
  background-repeat: no-repeat;
}

@media screen and (max-width: 767px) {
  main.contact.lazyloaded {
      background-repeat: repeat;
      background-size: 100% auto;
      background-image: url(/img/sp/contact_bg.png) !important;
  }
}

main.contact .mb_set .mb_xl {
  margin-bottom: 75px;
}
@media screen and (max-width: 767px) {
  main.contact .mb_set .mb_xl {
      margin-bottom: 42px;
  }
}

main.contact .pd_last {
  padding-bottom: 127px;
}

@media screen and (max-width: 767px) {
  main.contact .pd_last {
      padding-bottom: 120px;
  }
}

main.contact .mb_set .mb_l {
  margin-bottom: 15px;
}

main.contact .mb_set .mb_ll {
  margin-bottom: 25px;
}

.wpcf7-form-control-wrap {
  position: relative;
}

main.contact .contact_form input[type="text"],
main.contact .contact_form input[type="email"] {
  height: 38px;
}


main.contact .contact_form input:not([type="submit"]),
main.contact .contact_form textarea {
  font-size: 16px;
  padding: 5px 15px;
  width: 100%;
}
main.contact .contact_form textarea {
  height: 122px;
}


.wpcf7 input[type="url"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"] {
  direction: ltr;
}

main.contact .contact_form select {
  font-size: 16px;
  padding: 5px 15px;
  width: 100%;
  height: 38px;
  position: relative;
}

main.contact .contact_form .white_border {
  border: solid 1px white;
}

main.contact .contact_form option {
  color: black;
}

main.contact .contact_form .select_wrap::after {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  border-right: solid 2px white;
  border-bottom: solid 2px white;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-75%) rotate(45deg);
}

main.contact .contact_form .submit_wrap {
  text-align: center;
}
.round_button {
  background-color: transparent;
  border: solid white 1px;
  border-radius: 24px;
  min-height: 29px;
  min-width: 157px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 2px 15px;
}

@media screen and (max-width: 767px) {
  .round_button {
      padding: 2px 5px;
      min-width: unset;
  }
}

main.contact .contact_form input[type="submit"] {
  margin-right: auto;
  margin-left: auto;
  min-width: 157px;
  width: 157px;
}

button, input, optgroup, select, textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

*, ::before, ::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

main.contact .contact_form .select_wrap {
  position: relative;
}


/* cast.php */
main.casts.lazyloaded {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
}

@media screen and (max-width: 767px) {
  main.casts.lazyloaded {
      background-repeat: repeat;
      background-size: 100% auto;
      background-image: url(/img/sp/casts_bg.png) !important;
  }
}


@media screen and (max-width: 999px) {
  main.casts .w {
      padding-left: 110px;
      padding-right: 110px;
  }
}

@media screen and (max-width: 767px) {
  main.casts .w {
      padding-left: 90px;
      padding-right: 90px;
  }
}

@media screen and (max-width: 579px) {
  main.casts .w {
      padding-left: 45px;
      padding-right: 30px;
  }
}


.casts_wrap {
  display: flex;
  flex-wrap: wrap;
  width: calc(100% + 30px);
  margin-right: -30px;
  padding-bottom: 98px;
}

.casts_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr 1fr !important;
  margin-right: inherit !important;
  gap: 30px !important;
  width: inherit !important;
}


@media screen and (max-width: 870px) {
  .casts_wrap {
      grid-template-columns: 1fr 1fr !important;
      gap: 3px !important;
  }
}

@media screen and (max-width: 767px) {
  .casts_wrap {
      grid-template-columns: 1fr 1fr !important;
      gap: 3px !important;
  }
}



.casts_wrap .cast {
  display: block;
  margin-right: 30px;
  flex-basis: calc(33% - 30px);
  margin-bottom: 34px;
}

.casts_wrap .cast {
  margin-right: 0 !important;
  flex-basis: inherit;
  flex-direction: column !important;
  gap: 99px !important;
  display: flex !important;
}

@media screen and (max-width: 1199px) {
  .casts_wrap .cast {
      flex-basis: calc(50% - 30px);
  }
}

@media screen and (max-width: 767px) {
  .casts_wrap .cast {
      flex-basis: calc(100% - 30px);
  }
}


.casts_wrap .cast .images_wrap {
  position: relative;
  color: #272727;
  margin-bottom: 38px;
  padding-top: 69%;
}

.casts_wrap .cast .images_wrap {
  padding-top: 165% !important;
  margin-bottom: 0 !important;
}


.casts_wrap .cast .images_wrap {
  padding-top: 0 !important;
}


.casts_wrap .cast img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.casts_wrap .cast img {
  position: relative !important;
  max-height: 355px !important;
  height: 355px !important;
}

@media screen and (max-width: 500px) {
  .casts_wrap .cast img {
      position: relative !important;
      max-height: 240px !important;
      height: 240px !important;
  }
}


main.casts .casts_wrap a .cast-name {
  display: none;
}

.casts_wrap .cast .cast-name {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 1.8rem;
  background-color: white;
  padding: 1.1rem 0.9rem 1.7rem;
  line-height: 1.5;
  letter-spacing: 0.35em;
  transform: translate3d(0, 0);
  box-sizing: content-box;
  width: 1em;
  text-align: center;
  word-break: break-all;
}

@media screen and (max-width: 579px) {
  .casts_wrap .cast .cast-name {
      font-size: 3.6vw;
  }
}


.castDataContainer {
  position: absolute !important;
  bottom: -84px !important;
  left: 0 !important;
  width: 100% !important;
}

.castDataContainer {
  position: relative !important;
  bottom: 0 !important;
}

.castDataInner {
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 0;
}

.casts_wrap .cast .en_age_wrap {
  position: absolute;
  bottom: 0;
  left: 0;
  display: flex;
  align-items: flex-end;
}


.casts_wrap .cast .en_age_wrap {
  grid-template-columns: 2fr 0.7fr !important;
  position: unset !important;
  flex-direction: column;
  bottom: unset !important;
  left: unset !important;
  width: 100% !important;
  align-items: center !important;
  color: #000 !important;
  background: #fff;
  width: 100%;
  padding: 0.2rem;
  gap: 3px;
}

main.casts .casts_wrap a .en_age_wrap .font_cinzel {
  font-family: "Noto Serif JP", serif;
}

.casts_wrap .cast .en_age_wrap .name_en {
  font-size: 2.3rem;
  padding: 0.4rem 2.6rem 0.1rem 1.5rem;
  background-color: white;
  line-height: 1.34;
}
.casts_wrap .cast .en_age_wrap .name_en {
  font-size: 1.85rem !important;
  padding: 0 !important;
}
@media screen and (max-width: 579px) {
  .casts_wrap .cast .en_age_wrap .name_en {
      font-size: 4.6vw;
  }
}



.casts_wrap .cast .en_age_wrap .age {
  font-size: 1.3rem;
  padding: 0.2rem 1rem 0.2rem 0.6rem;
  background-color: white;
  line-height: 1.46;
}

.casts_wrap .cast .en_age_wrap .age {
  padding: 0 !important;
  background-color: inherit !important;
  line-height: inherit !important;
  display: inline-block;
}

@media screen and (max-width: 579px) {
  .casts_wrap .cast .en_age_wrap .age {
      font-size: 3.6vw;
  }
}


.data-wrapper {
  position: inherit !important;
  left: inherit !important;
}

.data-inner {
  transform: translateX(0%);
  white-space: nowrap;
  background-color: white;
  line-height: 1.46;
  font-size: 1.3rem;
  padding: 0 0.2rem 0.4rem 0.2rem !important;
  display: flex;
  flex-direction: column !important;
  justify-content: center;
  align-items: center !important;
  gap: 6px;
}
.data-inner {
  white-space: unset;
}

.data-grade, .data-position {
  padding-right: 10px;
  padding: 0.1rem 1rem;
  text-align: center;
  border-radius: 30px;
  border: 1px solid #000;
  font-size: 1.2rem;
  letter-spacing: 0px;
  line-height: 14px;
}


.images_wrap .rect_button {
  margin-top: 2rem !important;
}
.images_wrap .rect_button span {
  color: white;
}

.casts_wrap .cast .rect_button .arrow {
  transition: transform 0.5s;
  transform: translateX(0px);
}

.data-new {
  position: absolute;
  top: 0;
  left: 0;
  background-color: white;
  border: solid #ffffff 1px;
  color: black;
  padding: 2px 12px;
}


.tax_title {
  margin-bottom: 11px;
}

@media screen and (max-width: 767px) {
  .tax_title {
      margin-bottom: 8px;
  }
}

.time{
  font-size: 1.3rem;
  padding: 0.2rem 0.6rem;
}

main.casts .casts_wrap a .en_age_wrap .time.font_cinzel {
  font-family: "Cinzel Decorative", cursive;
}


/* profile.php */
main.cast {
  position: relative;
}

main.cast .sp-bg {
  background: center/cover no-repeat;
  position: fixed;
  width: 100%;
  height: 100%;
}


main.cast.lazyloaded {
  background-attachment: unset;
}

main.cast.lazyloaded {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
}

main.cast .bg {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background-color: rgba(0, 0, 0, 0.3);
}

main.cast .bg {
  position: fixed;
}

main.cast .wxx {
  position: relative;
}
@media screen and (max-width: 767px) {
  main.cast .wxx {
      padding-left: 40px;
  }
}

main.cast .cast_inner {
  position: relative;
}

@media screen and (max-width: 767px) {
  .gallery {
      position: static;
      display: flex;
      justify-content: flex-start;
      max-width: 100%;
      overflow: scroll;
      height: 107px;
      margin-bottom: 36px;
  }
}

main.cast .castMovie{
  width: 100%;
}

main.cast .castMovie video{
  width: 100%;
  margin-bottom: 50px;
}


main.cast .f_middle_wrap {
  display: flex;
  align-items: center;
}

main.cast .f_middle_wrap .ll_text {
  margin-right: 17px;
}
main.cast .f_middle_wrap .circle {
  width: 41px;
  height: 41px;
}
main.cast .f_middle_wrap .circle span {
  font-size: 0.9rem;
}
main.cast .mb_set .mb_ml {
  margin-bottom: 23px;
}
main.cast .mb_set .mb_ll {
  margin-bottom: 36px;
}

main.cast .mb_set .mb_ms {
  margin-bottom: 14px;
}

main.cast .mb_set .mb_last {
  margin-bottom: 0;
  padding-bottom: 63px;
}

main.cast table.tag {
  width: unset;
}

table.mini th, table.mini td, table .mini th, table .mini td {
  padding-top: 10px;
  padding-bottom: 10px;
}

table .mini td.lt200{
  font-size: 1.6rem;
}

.profile footer p{
  position: unset;
}


.gallery .gallery_item {
  opacity: 1 !important;
  transition: outline 0.5s;
  outline: solid 1px transparent;
}

.gallery .gallery_item img, 
.gallery .gallery_item video {
  object-fit: contain;
}

main.cast .gallery-height {
  position: relative;
  z-index: -10;
  margin-top: -528px;
  opacity: 0;
}

.profile .price-Title{
  font-size: 1.8rem;
  margin-bottom: 10px;
}



.profile .right_Container ul{

}

.profile .right_Container ul li {
  width: 100%;
  /* padding: 0px 5px; */
  margin-bottom: 10px;
  color: rgb(255, 255, 255);
}

.profile .right_Container ul li p.mb_l {
  font-weight: 700;
  font-size: 16px;
  background-color: #c5c5c5;
  color: black;
  display: flex;
  align-items: center;
  /* border: 1px solid #a7a7a7; */

}

.profile .right_Container ul li p span{
  font-weight: 700;
  font-size: 16px;
  color: rgb(255, 255, 255);
  background-color: black;
  margin-right: 10px;
  padding: 10px;
  position: relative;
}

.profile .right_Container ul li p span:after{
  border: solid transparent;
  content:'';
  height:0;
  width:0;
  pointer-events:none;
  position:absolute;
  border-color: rgba(0, 0, 0, 0);
  border-top-width:10px;
  border-bottom-width:10px;
  border-left-width:10px;
  border-right-width:10px;
  margin-left: -10px;
  border-top-color:#000000;
  top:100%;
  left:50%;
}



.profile .right_Container ul li p.answer{
  background-color: rgb(241 241 241);
  margin-bottom: 5px;
  /* border-radius: 10px; */
  padding: 10px 10px 36px;
  color: black;
  font-size: 14px;
}


@media screen and (max-width: 767px) {
  main.cast .gallery-height {
      display: none;
  }
}

@media screen and (max-width: 767px) {
  .gallery .gallery_item {
      height: 100%;
      flex-grow: 0;
      flex-shrink: 0;
      margin-right: 5px;
  }
  main.cast .left10 {
    margin-left: -10px;
  }
  main.cast .mb_set .mb_ms {
    margin-bottom: 12px;
  }
  main.cast .mb_set .mb_last {
    padding-bottom: 125px;
  }
  .gallery .gallery_item img,
  .gallery .gallery_item video {
    height: 100%;
  }
}


@media screen and (min-width: 768px) {
  main.cast .max_l {
    max-width: 688px;
  }
  main.cast .max_m {
    max-width: 387px;
  }
  .pc_gallery {
    position: static;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    max-width: 100%;
    overflow-x: scroll;
    height: 240px;
    margin-bottom: 36px;
  }
  .pc_gallery .pc_gallery_item {
    height: 100%;
    flex-grow: 0;
    flex-shrink: 0;
    margin-right: 2rem;
    opacity: 1 !important;
    transition: outline 0.5s;
    outline: solid 1px transparent;
  }
  .pc_gallery .pc_gallery_item:hover {
    outline: solid 1px white;
    outline-offset: -1px;
  }
  .pc_gallery .pc_gallery_item img,
  .pc_gallery .pc_gallery_item video {
      max-width: 100%;
      max-height: 100%;
      object-fit: cover;
  }
}


@media screen and (max-width: 767px) {
  .pc_gallery {
      /* display: none; */
  }
}


/* 検索BOX */
.search_title {
  margin-bottom: 8px;
}

.search_inputs_wrap {
  margin-bottom: 23px;
  display: inline-flex;
  max-width: 100%;
}

.search_inputs_wrap .search_input {
  padding: 0 15px;
  margin-right: 15px;
  font-size: 16px;
  width: 326px;
}

@media screen and (max-width: 767px) {
  .search_inputs_wrap .search_input {
      margin-right: 5px;
      flex-shrink: 1;
      flex-basis: 61vw;
      width: 61vw;
      flex-grow: 0;
  }
}

.search_inputs_wrap .search_button {
  text-align: center;
}

@media screen and (max-width: 767px) {
  .search_inputs_wrap .search_button {
      width: 157px;
      flex-shrink: 1;
      flex-basis: 20vw;
      width: 20vw;
      flex-grow: 0;
      font-size: 1.5rem;
  }
}
@media screen and (max-width: 767px) and (max-width: 579px) {
  .search_inputs_wrap .search_button {
      font-size: 3vw;
  }
}

.tax_title {
  margin-bottom: 11px;
}

@media screen and (max-width: 767px) {
  .tax_title {
      margin-bottom: 8px;
  }
}

.tax_wrap {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 6px;
  width: calc(100% + 15px);
  margin-right: -15px;
}

@media screen and (max-width: 767px) {
  .tax_wrap {
      margin-bottom: 23px;
  }
}

.tax_wrap.tag_wrap {
  margin-bottom: 23px;
}

.tax_wrap .tag {
  width: unset;
  min-width: unset;
  flex-basis: calc(33% - 15px);
}

.tax_wrap .tag {
  margin-bottom: 13px;
  margin-right: 15px;
}

@media screen and (max-width: 767px) {
  .tax_wrap .tag {
      width: unset;
      min-width: unset;
      flex-basis: calc(33% - 15px);
  }
}
@media screen and (max-width: 579px) {
  .tax_wrap .tag {
      flex-basis: calc(50% - 15px);
  }
}


.tax_wrap .tag.active {
  background-color: white;
  color: #272727;
}



/* schedule.php */
main.casts.schedule.lazyloaded {
  background-position: bottom center;
}

@media screen and (max-width: 767px) {
  main.casts.schedule.lazyloaded {
      background-position: top center;
      background-image: url(/img/sp/schedule_bg.png) !important;
  }
}

.casts_wrap.schedule_wrap {
  padding-bottom: 30px;
}

.rect_back_button {
  border: solid 1px white;
  display: inline-flex;
  align-items: flex-end;
}
.rect_back_button span {
  padding: 0.3rem 1.1rem 0.2rem;
  font-size: 1.4rem;
}

.rect_back_button .arrow {
  background: url(/img/arrow_back.svg) center/contain no-repeat;
  margin: 1.1rem 0rem 0.75rem 2.4rem;
  transition: transform 0.5s;
}



.btn_wrap {
  margin-bottom: 60px;
}

.btn_wrap a {
  display: inline-block;
  border-radius: 100px;
  margin-bottom: 20px;
  padding: 5px 100px;
}

@media screen and (max-width: 579px) {
  .btn_wrap a {
      width: 100%;
      text-align: center;
      padding: 5px 10px;
  }
}



/* news.php */
main.news.lazyloaded {
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-image: url("/img/sp/news_bg.png") !important;
}

@media screen and (max-width: 767px) {
  main.news .w {
      padding-right: 15px;
      padding-left: 45px;
  }
}

main.news .casts_wrap {
  margin-bottom: 30px;
  padding-bottom: 0px;
}



main.news .casts_wrap .cast {
  gap: 0 !important;
}


main.news .casts_wrap .cast img{
  object-fit: fill;
}

main.news .casts_wrap .date {
  margin-bottom: 10px;
  margin-top: 10px;
}
main.news .casts_wrap .news_title {
  margin-bottom: 19px;
  min-height: 40px;
}



/* newsdetail.php */

main.news_single .mb_set .mb_mll {
  margin-bottom: 36px;
}

main.news_single .w_img {
  width: 100%;
  object-fit: contain;
}

main.news_single .mb_set .mb_ml {
  margin-bottom: 14px;
}

main.news_single .mb_set .mb_l {
  margin-bottom: 15px;
}

main.news_single .mb_set .mb_xl {
  margin-bottom: 40px;
}
main.news_single .mb_set .mb_xxl {
  margin-bottom: 127px;
}


/* ranking.php */
main.casts.ranking.lazyloaded {
  background-repeat: repeat;
  background-size: 100% auto;
  background-image: url(/img/sp/ranking_bg.png) !important;
}




.ranking .pt_m {
  padding-bottom: 90px;
}

h2.title {
  font-weight: bold;
  padding: 2% 1%;
  font-size: 1.8rem;
  margin-bottom: 0px;
}

body.ranking main.casts .casts_wrap{
  display: block !important;
  padding-bottom: 20px;
}

main.casts .casts_wrap .castRank{
  background-color: #000000;
  font-size: 2.0rem;
  padding: 5px;
  text-align: center;
  color: white;
}

.ranking main.casts .casts_wrap .castData{
  display: flex;
  background: #ffffff;
  padding: 5px;
}

.ranking .casts_wrap .cast .en_age_wrap {
  background: #ffffff;
}
.ranking .casts_wrap .cast .en_age_wrap .name_en {
  background: #ffffff;
}
.ranking .casts_wrap .cast .en_age_wrap .age {
  background: #ffffff;
}
.ranking .data-inner {
  background: #ffffff;
}

main.casts .casts_wrap .castData .castData_img{
  /* width: 30%; */
}

.ranking .castDataContainer {
  position: relative !important;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 70% !important;
}

.ranking .casts_wrap .cast {
  margin-bottom: 0px;
}

body.ranking main.casts .data-new{
  top: 30px;
}


/* ranking_style2  */
.clearfix {
  display: block;
}

.clearfix:after {
  content: ".";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}


.topRankNo1{
  position: relative;
}

.topRankNo1 .castRank .personal_data_box .personal_data {
  padding: 10px;
  background: rgba(225, 225, 225, 0.8);
  color: #000;
  z-index: 2;
  position: relative;
}

.topRankNo1 .castRank .personal_data_box .personal_data .fs24{
  font-size: 24px;
  text-align: center;
  line-height: 1.3;
}

.castRank {
  /* text-align: center; */
  /* margin-bottom: 1vw; */
}

.topRankNo1 .castRank .rankImg img{
  width: 70px;
  position: absolute;
  z-index: 2;
}


.rank{
  font-size: 8vw;
  font-family: 'Playfair Display SC', serif;
  margin-bottom: 20px;
}

.castRank .underline {
  border-bottom: #B40000 1px solid;
}

.rank .fs80{
  font-size: 26vw;
}

.photo_area {
  width: 100%;
}
.personal_data_box {
  position: absolute;
  bottom: 0;
  left: 0;
  box-sizing: padding-box;
}

.personal_data_box {
  min-width: 41%;
  right: 0;
}

.photo_area {
  position: relative;
  overflow: hidden;
}

.photo_area .personal_data {
  background: rgba(225,225,225,0.8);
  color: #000;
  padding: 0.5vw 1vw;
}

.photo_area .personal_data_box .personal_data .fs24{
  font-size: 6vw;
  text-align: center;
  line-height: 1.3;
}

.photo_area .photo img {
  vertical-align: bottom;
}

#topRanker_area {
  margin-top: 3.3vw;
}

.topRank {
  width: 48%;
  float: left;
  overflow: hidden;
  margin-bottom: 20px;
}

.topRank .castRank {
  margin-bottom: 1vw;
  text-align: center;
  line-height: 1.3;
}

.topRank .rank {
  font-size: 6vw;
  font-family: 'Playfair Display SC', serif;
  line-height: 1.3;
}

.topRank .rank .fs55{
  font-size: 9.3vw;
  line-height: 1.3;
}

.topRank .photo_area{
  max-height: 206px;
}

.topRank .photo_area .personal_data {
  min-width: 87%;
}
.topRank:nth-child(even) {
  float: right;
}


.topRankNo1,
.topRankNo2,
.topRankNo3,
.topRankNo4,
.topRankNo5 {
  /* margin-bottom: 50px; */
  /* margin-top: 50px; */
}



.topRank.rank4,
.topRank.rank5 {
  width: 130px;
  float: left;
  margin-right: 10px;
  margin-bottom: 20px;
  /* overflow: hidden; */
  position: relative;
  height: 270px;
}

.topRank.rank2 .castRank .rankImg img,
.topRank.rank3 .castRank .rankImg img {
  width: 70px;
}


.topRank.rank4 {
  margin-right: 20px;
}

.topRank.rank5 {
  margin-right: 0px;
}


.topRank.rank4 .photo_area .photo,
.topRank.rank5 .photo_area .photo {
  height: 160px;
}

.topRank.rank4 .photo_area .photo img,
.topRank.rank5 .photo_area .photo img {
  object-fit: cover;
  width: 130px;
  height: 200px;
}

.topRank.rank4 .personal_data,
.topRank.rank5 .personal_data {
  width: 130px;
  line-height: 1.3;
  position: absolute;
  bottom: 0;
  padding: 10px;
  font-size: 20px;
  background: rgba(225, 225, 225, 0.8);
  color: black;
  text-align: center;
}



/* 検索BOX */

/* searchBox */


.searchBox select {
  box-sizing: border-box;
  height: 46px;
  font-size: 100%;
  border: 1px solid #ccc;
  padding: 2px 8px;
  border-radius: 6px;
  background: #fff;
  color: #422f10;
  margin: 0 5px;
  font-size: 20px;
}

input[type="checkbox" i] {
  background-color: initial;
  cursor: default;
  appearance: auto;
  box-sizing: border-box;
  margin: 3px 3px 3px 4px;
  padding: initial;
  border: initial;
}





.searchBox {
	margin: 10px 0;
	font-size: 18px;
}

.searchBox .title {
	text-align: center;
	border-bottom: solid 1px #ccc;
}

.searchBox ul {
	display: flex;
	justify-content: center;
}

.searchBox .cup ul{
  flex-wrap: wrap;
}


.searchBox li {
	margin: 2px;
}

.searchBox .cup ul li {
  width: calc(93% / 5);
}

.searchBox .select_Rank ul li {
  width: calc(93% / 2);
}

.searchBox .selector {
	margin: 10px 0;
}
.searchBox .selector.select_Rank{
  font-size: 15px;
}

.searchBox .selector.select_Rank ul{
  justify-content: space-between;
}


.searchBox input[type="text"] {
	width: 100%;
	box-sizing: border-box;
	padding: 5px;
	font-size: 18px;
  height: 46px;
  border: 1px solid #ccc;
  border-radius: 6px;
  background: #fff;
  color: #422f10;
}

.searchBox input[type="submit"] {
  display: inline-block;
  width: calc(48% - 20px);
  text-align: center;
  font-size: 18px;
  margin: 10px;
  border: 0;
  background: rgba(255, 255, 255, 0.20);
  box-shadow: 0 8px 32px 0 rgb(255, 255, 255 / 37%);
  backdrop-filter: blur(10.0px);
  padding: 10px;
  font-family: 'ryumin', "游明朝", "游明朝体", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  box-shadow: 0 2px 13px #fff;
}

.lineAddBtn {
	width: 80%;
	background: #f3e2c7;
	/* Old browsers */
	background: -moz-linear-gradient(-86deg, #f3e2c7 0%, #c19e67 50%, #b68d4c 51%, #e9d4b3 100%);
	/* FF3.6-15 */
	background: -webkit-linear-gradient(-86deg, #f3e2c7 0%, #c19e67 50%, #b68d4c 51%, #e9d4b3 100%);
	/* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(-4deg, #f3e2c7 0%, #c19e67 50%, #b68d4c 51%, #e9d4b3 100%);
	/* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#f3e2c7', endColorstr='#e9d4b3', GradientType=0);
	/* IE6-9 */
	color: #fff !important;
	border-radius: 5px;
	padding: 0 5px;
	font-style: normal;
}


/* link.php */

body.link .linkInner .linkBanner{
  display: flex;
  flex-wrap: wrap;
}

body.link .linkInner .linkBanner table{
  margin: 0 auto;
  padding: 30px 0px;
}

body.link .linkInner .linkBanner div{
  /* margin-bottom: 5px; */
  width: 50%;
  border: 1px solid;
  padding: 5px;
}

.linkBanner div{
  margin-bottom: 5px;
}

div.fuzokunv_exp{
  display: none;
}
.fuzokunv_tab .home a {
  font-size: 13px!important;
  color: rgb(255, 255, 255)!important;
}

.fuzokunv_tab .free_keisai div {
  width:100%!important;
  text-align: center!important;
  border: none!important;
}

#indexPage .linkBanner div{
  margin: auto;
}



/*----- 追加20240927 -----*/
/* recruit.php */

.recruit main.recruit .qa_wrap {
  padding-right: 30px;
  padding-left: 30px;
  padding-top: 10.8rem;
}


.recruit main.recruit .title_recruit::before {
  content: "";
  display: inline-block;
  width: 58px;
  height: 1px;
  background: rgb(0, 0, 0);
  margin-right: 23px;
  bottom: 3px;
  position: relative;
}

.recruit main.recruit .qa_wrap .qa_content {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: 50px;
}

@media screen and (max-width: 999px) {
  .recruit main.recruit .qa_content {
      align-items: flex-start;
  }
}
.recruit main.recruit .qa_wrap .qa_q {
  color: rgb(0, 0, 0);
}

.recruit main.recruit .qa_wrap .qa_q_wrap {
  margin-bottom: 20px;
}

.recruit main.recruit .qa_wrap .qa_a,
.recruit main.recruit .qa_wrap .qa_q {
  display: flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: 100vw;
  border: solid rgb(0, 0, 0) 1px;
  background: transparent;
  font-size: 1.9rem;
  font-weight: 700;
  font-family: "Hiragino Kaku Gothic Std", sans-serif;
  margin-right: 20px;
  flex-shrink: 0;
}

.recruit main.recruit .qa_wrap .qa_m_Text{
  font-size: 1.2rem;
  margin-bottom: 50px;
  line-height: 2.0;
}

@media screen and (max-width: 767px) {
  .recruit main.recruit .qa_wrap .qa_a,
  .recruit main.recruit .qa_wrap .qa_q {
      width: 8vw;
      height: 8vw;
      margin-right: 10px;
  }
}

@media screen and (max-width: 767px) and (max-width: 579px) {
  .recruit main.recruit .qa_wrap .qa_a,
  .recruit main.recruit .qa_wrap .qa_q {
      font-size: 4.2vw;
  }
}

.recruit main.recruit .qa_wrap .qa_text {
  font-size: 1.2rem;
}

.recruit main.recruit .qa_wrap .qa_a_wrap {
  margin-bottom: 50px;
}

.recruit main.recruit .qa_wrap .qa_a {
  color: rgb(0, 0, 0);
}


/* recruit_staff.php */

.recruit_staff main.recruit .recruit_mv .recruit_mv_inner .recruit_mv_text_wrap .recruit_mv_left .recruit_mv_left_ja {
  margin-left: 0;
  margin-top: 6rem;
  letter-spacing: 0.2em;
  font-size: 3.5rem;
  margin-bottom: 6rem;
}


/* system.php */
p.jp{
  font-size: 11px;
  margin-bottom: 10px;
}

p.en{
  font-size: 11px!important;
  margin-bottom: 10px;
}