.w_cus {
  width: calc(85% / 3);
}
#recruit .mainvisual > .container {
  background: url(../../images/previous/under_main_contact.jpg) center no-repeat;
  background-size: cover;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 500px;
  padding: 0 3%;
  overflow: hidden;
}
.line_txt {
  text-decoration: underline;
}
h4.sty_h4 {
  text-align: center;
  color: #910101;
  padding-left: 0;
}
.under h4.sty_h4::before {
  display: none;
  /* bottom: 0;
  top: inherit;
  left: 50%;
  transform: translate(-50% , 0);
  height: 2px;
  width: 40px; */
}
.d-flex {
  display: flex;
  justify-content: space-between;
}
ul.d-flex li {
  width: 23%;
}
.tag_txt {
  /* background-image: linear-gradient(135deg, #edddc9 16.67%, #d4b091ed 16.67%, #d4b091eb 50%, #edddc9 50%, #edddc9 66.67%, #d4b091e8 66.67%, #d4b091 100%);
  background-size: 4.24px 4.24px; */
  background: url(../../images/previous/box07_bg_modal01.png), #e5c8ae;
  padding: 40px 0;
  margin-bottom: 56px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.tag_txt ul {}
.tag_txt ul li {
  font-size: 20px;
  font-family: 'Noto Serif JP', serif;
  font-weight: 500;
}
.tag_txt ul li:not(:last-child) {
  margin-bottom: 10px;
}
.tag_txt ul li a {
  text-decoration: none;
  color: #595959;
  border-left: #434343 1px solid;
  padding-left: 10px;
}
.tag_txt ul li a:before {
  display: none;
}
a.no-anchor:hover {
  text-decoration: underline !important;
}
.tag_txt ul li a:hover {
  text-decoration: underline;
}
.under #content p.tag_tit {
  margin-right: 50px;
  margin-bottom: 0;
  color: #651015;
  font-size: 38px;
  position: relative;
  z-index: 1;
  font-family: 'Noto Serif JP', serif;
}
.tag_tit span {
  position: absolute;
  z-index: -1;
  opacity: 0.3;
  bottom: 50%;
  right: 30%;
  width: 140px;
  line-height: 1;
  display: block;
  font-size: 42px;
  font-weight: bold;
}
h4.sty_h4_01 {
  color: #fff;
  background: #651015;
  padding: 0px 0 3px 60px;
}
h4.sty_h4_01::before {
  content: '';
  position: absolute;
  background: #fff;
  left: 20px;
  top: 50%;
  transform: translate(0, -50%);
  width: 20px;
  height: 2px;
}
h5.sty_h5 {
  color: #651015;
  padding-bottom: 2px;
  border-bottom: #ccc 1px solid;
  padding-left: 0;
  font-size: 22px;
  margin-bottom: 30px;
}
h5.sty_h5 span:last-child {
  text-decoration: underline;
}
h5.sty_h5 span:first-child {
  background: #e97132;
  color: #fff;
  padding: 5px 7px;
  text-decoration: none !important;
  margin-right: 10px;
}
h5.sty_h5_01 {
  display: flex;
  align-items: center;
  font-size: 22px;
}
h5.sty_h5_01::before {
  display: block;
  height: 15px;
  width: 15px;
  margin-right: 10px;
  background: #651015;
  position: unset;
}
h5.sty_h5_01::after {
  display: none;
}
h5.sty_h5::before, h5.sty_h5::after, h3.sty_h3::after, .under h5.sty_h5_02:before, .under h5.sty_h5_02:after {
  display: none;
}
h3.sty_h3 {
  background: url(../../images/previous/box07_bg_modal01.png), #e5c8ae;
  padding: 40px 10px;
  color: #e97132;
  color: #80350e;
}
.under h5.sty_h5_02 {
  text-align: center;
  color: #651015;
  font-size: 22px;
  padding: 0;
}
.dental {
  background: url(../../images/previous/background_img.jpg), #e5c8ae;
  padding: 40px 0;
  margin-bottom: 56px;
  background-repeat: no-repeat;
  background-size: cover;
}
.dental section {
  margin-bottom: 0;
}
.txt_bg {
  background: url(../../images/previous/box07_bg_modal01.png), #e5c8ae;
  padding: 20px;
  max-width: 550px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.bg_w {
  background: #fff;
  padding: 20px;
  margin: 0 auto;
}
p.ttl_txt {
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 20px !important;
}
.ttl_upsize {
  font-size: 22px;
  font-weight: 600;
}
.dot {
  position: relative;
  display: flex;
  font-weight: bold;
  /* align-items: center; */
}
.dot::before {
  display: block;
  content: '';
  width: 10px;
  height: 10px;
  margin-right: 10px;
  background: #651015;
  border-radius: 50%;
  margin-top: 10px;
}
.w_ul {
  display: flex;
  justify-content: center;
  flex-direction: column;
  width: fit-content;
  margin: 0 auto;
}
table.bg_tb {}
table.bg_tb th {
  background: #e97132;
  color: #fff;
  font-size: 18px;
  font-weight: 500;
}
table.bg_tb th {
  border-bottom: 1px solid #fff;
}
table.bg_tb tr:last-child th {
  border-bottom: none;
}
table.bg_tb td {
  border: 1px solid #f09a6c;
}
.under-tbl .bg01 {
  background: #FFF4E4;
  text-align: center;
  font-weight: bold;
}
.bnt_contact {
  width: 48%;
}
.bnt_contact a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px 5px;
  width: 100%;
  height: 100%;
  font-size: 18px;
  line-height: 1.5;
  color: #fff;
  background: #651015;
  font-family: 'Noto Serif JP', serif;
}
.bnt_contact a::before {
  display: block;
  content: "";
  background: url(../../images/previous/ico_letter.png) no-repeat;
  background-size: contain;
  width: 47px;
  height: 35px;
  margin-right: 25px;
}
.bnt_tell a::before {
  background: url(../../images/previous/icon_tell.png) no-repeat;
  width: 30px;
  height: 50px;
}
.bnt_contact a:hover {
  text-decoration: none;
  opacity: 0.9;
}
.bnt_tell a:hover {
  opacity: 1;
}
.txt_big {
  font-size: 30px;
}
.bg_tb tr:first-child td {
  /* text-align: center; */
  font-size: 18px;
  font-weight: 500;
}
.recruit_frame01 {
  padding: 30px;
  background: #eaeaea;
}
.under #content p.tit_frame01 {
  font-size: 22px;
  padding-left: 15px;
  border-left: #ccc 2px solid;
  font-family: 'Noto Serif JP', serif;
  margin-bottom: 25px;
}
.under .tbl-scroll:not(:last-child) {
  margin-bottom: 25px;
}
.under #content p.spec_txt01 {
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}
.under #content p.txt_big02 {
  font-size: 18px;
}
.under #fmail_thankspage, .under #fmail_thankspage p {
    font-size: 14px;
}
@media screen and (max-width: 640px) {
  #recruit .mainvisual > .container {
    background: url(../../images/previous/under_main_contactsp.jpg) center right -40px no-repeat;
    background-size: cover;
    height: 300px;
  }
  ul.d-flex li {
    width: 42%;
  }
  /* ul.d-flex li:nth-child(n + 3) {
    margin-top: 15px;
  } */
  .dental .d-flex {
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px;
  }
  .tag_txt ul {
    width: 100%;
  }
  .tag_txt ul li {
    font-size: 16px;
  }
  h4.sty_h4_01 {
    margin: 0 auto 20px;
  }
  h4.sty_h4_01::before {
    width: 15px;
  }
  .person .d-flex {
    flex-direction: column;
  }
  .person .d-flex .txt_bg {
    margin: 2em auto 0;
  }
  .txt_bg {
    margin: 0 auto;
  }
  h5.sty_h5 {
    font-size: 18px;
    margin-bottom: 20px;
  }
  .person .d-flex p.mb0 {
    text-align: center;
  }
  .fmail .d-flex {
    flex-direction: column;
    justify-content: center;
  }
  .bnt_contact {
    width: 92%;
    margin: 0 auto;
  }
  .bnt_contact:first-child {
    margin-bottom: 20px;
  }
  .bnt_contact a::before {
    width: 35px;
    height: 28px;
    margin-right: 15px;
  }
  .dot span {
    width: calc(100% - 20px);
  }
  .bnt_tell a::before {
    background: url(../../images/previous/icon_tell.png) no-repeat;
    background-size: contain;
    width: 25px;
    height: 40px;
  }
  .bnt_contact a {
    font-size: 16px;
  }
  .txt_big {
    font-size: 25px;
  }
  .dot::before {
    margin-top: 7px;
  }
  table.bg_tb th {
    font-size: 16px;
    padding: 5px;
  }
  .bg_tb tr:first-child td {
    font-size: 16px;
  }
  section .d-flex {
    flex-wrap: wrap;
  }
  .tag_txt {
    flex-direction: column;
    padding: 20px;
  }
  .under #content p.tag_tit {
    font-size: 24px;
    margin: 0 auto 10px;
  }
  .under #content p.tag_tit span {
    font-size: 28px;
    width: 82px;
  }
  .recruit_frame01 {
    padding: 20px;
  }
  .recruit_frame01 img {
    max-width: 200px;
  }
  .under #content p.tit_frame01, .under h5.sty_h5_02 {
    font-size: 20px;
  }
  .under #content p.spec_txt01 {
    font-size: 18px;
  }
    .under #content p.txt_big02 {
  font-size: 16px;
}
}
@media screen and (max-width: 390px) {
  .bnt_contact a::before {
    width: 25px;
    height: 20px;
  }
  .bnt_tell a::before {
    width: 19px;
    height: 30px;
  }
  .bnt_contact a {
    font-size: 14px;
  }
}

@media screen and (max-width: 360px) {
#recruit .mainvisual > .container {
    background-position: center right -80px;
}
}