@charset "UTF-8";
/*
 *  SiteName : DETAIL ARTIST(ディテールアーティスト)
 *  2025 DETAIL ARTIST
 */
/*==============================================================
  common
==============================================================*/
section {
  margin: 0;
}

details {
  margin: 0 auto;
  padding: 30px 0;
  width: 1200px;
  border-top: 1px solid #d2d2d2;
}
details summary {
  margin: 0;
  width: 100%;
  font-size: 22px;
  font-size: 2.2rem;
  display: block;
  transition: all 0.5s ease;
}
details summary span {
  position: relative;
  margin: 0 17px 0 0;
  width: 43px;
  height: 43px;
  border: 1px solid #fff;
  border-radius: 50%;
  vertical-align: -15px;
  display: inline-block;
}
details summary span::before, details summary span::after {
  position: absolute;
  top: 50%;
  left: 50%;
  margin: auto;
  width: 14px;
  height: 2px;
  content: "";
  background-color: #fff;
  transform: translate(-50%, -50%);
  transition: all 0.5s ease;
}
details summary span::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
details::details-content {
  opacity: 0;
  transition: all 0.5s ease;
}
details[open]::details-content {
  opacity: 1;
}
details[open] summary span::after {
  top: 70%;
  opacity: 0;
}
details .recruit_detail-content {
  margin: 32px auto 0;
}
details .recruit_detail-content .recruit_detail-requirements {
  margin: 50px auto 0;
  width: 1000px;
}
details .recruit_detail-content .recruit_detail-requirements h2 {
  margin: 50px auto 20px;
}
details .recruit_detail-content .recruit_detail-requirements p {
  line-height: 36px;
  font-size: 14px;
  font-size: 1.4rem;
}
details .recruit_detail-content .recruit_detail-requirements table {
  margin: 50px auto 0;
  width: 100%;
}
details .recruit_detail-content .recruit_detail-requirements table tr th,
details .recruit_detail-content .recruit_detail-requirements table tr td {
  padding: 30px 0;
  text-align: left;
  font-size: 15px;
  font-size: 1.5rem;
  border-top: 1px solid #d2d2d2;
  display: table-cell;
}
details .recruit_detail-content .recruit_detail-requirements table tr th {
  width: 185px;
  font-weight: 700;
}
details .recruit_detail-content .recruit_detail-requirements table tr td {
  width: calc(100% - 190px);
  line-height: 24px;
}
details .recruit_detail-content .recruit_detail-requirements .link-button {
  margin: 19px 0 40px;
}

#recruit_marketing details {
  border-bottom: 1px solid #d2d2d2;
}

/*==============================================================
  recruit_title
==============================================================*/
#recruit_title {
  margin: 140px auto 100px;
}
#recruit_title h2 {
  font-size: 20px;
  font-size: 2rem;
}
#recruit_title h3 {
  margin: 23px 0 0;
  font-size: 70px;
  font-size: 7rem;
}
#recruit_title h4 {
  margin: 40px 0 0;
}
#recruit_title .recruit_image {
  margin: 60px 0 0;
  width: 100%;
  height: 400px;
  background-image: url(../img/recruit/title-image.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

/*==============================================================
  recruit_entry-form
==============================================================*/
#recruit_entry-form {
  margin: 140px 0 0;
}
#recruit_entry-form h2 {
  text-align: center;
  font-size: 28px;
  font-size: 2.8rem;
}
#recruit_entry-form table {
  margin: 55px 0 0;
  width: 100%;
  text-align: left;
}
#recruit_entry-form table tr th,
#recruit_entry-form table tr td {
  font-size: 16px;
  font-size: 1.6rem;
  display: table-cell;
}
#recruit_entry-form table tr th {
  padding: 17px 0;
  width: 300px;
}
#recruit_entry-form table tr th span {
  margin: 0 0 0 19px;
  padding: 3px 7px;
  color: #f23ef4;
  font-size: 10px;
  font-size: 1rem;
  border: 1px solid #f23ef4;
  border-radius: 15px;
  display: inline-block;
}
#recruit_entry-form table tr td {
  padding: 0 0 30px;
  width: calc(100% - 300px);
  vertical-align: top;
}
#recruit_entry-form table tr td input,
#recruit_entry-form table tr td textarea,
#recruit_entry-form table tr td select {
  padding: 15px 0 15px 14px;
  width: calc(100% - 1px);
  /*height: 49px;*/
  border: 1px solid #f0f0f0;
  resize: none;
}
#recruit_entry-form table tr td input::-moz-placeholder, #recruit_entry-form table tr td textarea::-moz-placeholder {
  color: #707070;
}

#recruit_entry-form table tr td select option {
  color: #222222;
}

#recruit_entry-form table tr td input::placeholder,
#recruit_entry-form table tr td textarea::placeholder {
  color: #707070;
}
#recruit_entry-form table tr td textarea {
  height: 166px;
}
#recruit_entry-form .link-button {
  position: relative;
  margin: 20px auto 0;
  display: block;
}
#recruit_entry-form .link-button input {
  padding: 16px 0 15px 30px;
  width: calc(100% - 30px);
  text-align: left;
}
#recruit_entry-form .link-button span {
  position: absolute;
  top: 50%;
  right: 47px;
  width: 34px;
  height: 2px;
  border-radius: 9999px;
  background-color: #fff;
  display: inline-block;
  transform: translateX(50%);
  transition: all 0.5s ease;
}
#recruit_entry-form .link-button span::before, #recruit_entry-form .link-button span::after {
  position: absolute;
  top: calc(50% - 1px);
  right: 0;
  width: 9px;
  height: 2px;
  content: "";
  border-radius: 9999px;
  background-color: #fff;
  transform-origin: 100% 50%;
}
#recruit_entry-form .link-button span::before {
  transform: rotate(45deg);
}
#recruit_entry-form .link-button span::after {
  transform: rotate(-45deg);
}
@media only screen and (min-width: 48em){
  #recruit_entry-form .link-button input {
    cursor: pointer;
    transition: all 0.5s ease;
  }
  #recruit_entry-form .link-button input:hover {
    text-decoration: none;
    opacity: 0.6;
  }
  #recruit_entry-form .link-button:hover span {
    right: 32px;
    text-decoration: none;
    opacity: 0.6;
  }
}
@media only screen and (max-width: 48.0625em){
  details {
    padding: 18px 0;
    width: 100%;
  }
  details summary {
    font-size: 18px;
    font-size: 1.8rem;
  }
  details summary span {
    margin: 0 12px 0 0;
    width: 38px;
    height: 38px;
    vertical-align: -13px;
  }
  details summary span::before, details summary span::after {
    width: 9px;
  }
  details .recruit_detail-content {
    margin: 18px auto 0;
  }
  details .recruit_detail-content .recruit_detail-image {
    margin: 0 0 -20px;
  }
  details .recruit_detail-content .recruit_detail-requirements {
    width: 100%;
  }
  details .recruit_detail-content .recruit_detail-requirements h2 {
    margin: 50px auto 10px;
  }
  details .recruit_detail-content .recruit_detail-requirements p {
    line-height: 34px;
  }
  details .recruit_detail-content .recruit_detail-requirements table {
    margin: 30px auto 0;
  }
  details .recruit_detail-content .recruit_detail-requirements table tr th,
  details .recruit_detail-content .recruit_detail-requirements table tr td {
    font-size: 14px;
    font-size: 1.4rem;
    display: block;
  }
  details .recruit_detail-content .recruit_detail-requirements table tr th {
    padding: 30px 0 14px;
    width: 100%;
  }
  details .recruit_detail-content .recruit_detail-requirements table tr td {
    padding: 0 0 30px;
    width: 100%;
    line-height: 20px;
    border-top: none;
  }
  details .recruit_detail-content .recruit_detail-requirements .link-button {
    margin: 0 auto 40px;
  }
  #recruit_title {
    margin: 100px auto 30px;
  }
  #recruit_title h2 {
    font-size: 14px;
    font-size: 1.4rem;
  }
  #recruit_title h3 {
    margin: 14px 0 0;
    font-size: 36px;
    font-size: 3.6rem;
  }
  #recruit_title h4 {
    margin: 20px 0 0;
    font-size: 13px;
    font-size: 1.3rem;
  }
  #recruit_title .recruit_image {
    margin: 40px 0 0;
    height: 160px;
  }
  #recruit_entry-form {
    margin: 80px 0 0;
  }
  #recruit_entry-form {
    font-size: 20px;
    font-size: 2rem;
  }
  #recruit_entry-form table tr th,
  #recruit_entry-form table tr td {
    font-size: 15px;
    font-size: 1.5rem;
    display: block;
  }
  #recruit_entry-form table tr th {
    padding: 0 0 10px;
    width: 100%;
  }
  #recruit_entry-form table tr td {
    width: 100%;
  }
  #recruit_entry-form .link-button {
    margin: 10px auto 0;
  }
  #recruit_entry-form .link-button input {
    width: 100%;
  }
  #recruit_entry-form .link-button span {
    right: 28px;
    width: 16px;
  }
}