@charset "UTF-8";
body {
  min-width: fit-content;
}
#suntory_contents h1, #suntory_contents h2, #suntory_contents h3, #suntory_contents h4, #suntory_contents h5, #suntory_contents h6, #suntory_contents p, #suntory_contents ol, #suntory_contents ul, #suntory_contents li, #suntory_contents dl, #suntory_contents dt, #suntory_contents dd, #suntory_contents table, #suntory_contents th, #suntory_contents td, #suntory_contents form, #suntory_contents br, #suntory_contents address, #suntory_contents button, #suntory_contents em, #suntory_contents i {
  font-family: "Noto Sans JP", "Noto Sans Japanese", sans-serif;
  margin: 0;
}
#suntory_contents {
  background: #2E3A54;
  font-size: 90%;
  color: #0f1419;
}
.fs-S {
  font-size: 0.9em;
}
.fs-M {
  font-size: 1.4em;
}
.fs-L {
  font-size: 1.6em;
}
#suntory_contents img {
  vertical-align: top;
  width: 100%;
  height: auto;
}
#mv {
  width: 100%;
  max-width: 768px;
  margin: 0 auto;
}
#mv h1 {
  margin: 0;
  padding: 0;
}
#requirements {
  width: 100%;
  max-width: 738px;
  margin: 0 auto;
  padding: 15px;
  background: #64718B;
  font-size: clamp(1rem, calc(0.75rem + 1vw), 1.5rem);
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  #requirements {
    width: 100%;
    max-width: fit-content;
    margin: 5%;
    padding: calc(10 / 375 * 100vw);
  }
}
#requirementsInner {
  padding: 20px 40px 70px 35px;
  border: double 5px #64718B;
  background: #fff;
}
@media screen and (max-width: 768px) {
  #requirementsInner {
    padding: calc(5 / 375 * 100vw) calc(20 / 375 * 100vw) calc(35 / 375 * 100vw) calc(22 / 375 * 100vw);
  }
}
#requirementsInner h2 {
  font-size: 1.4em;
  line-height: 1.2;
  margin: 30px 0;
  text-align: center;
  color: #2E3A54;
}
#requirementsInner h3 {
  font-size: 1.2em;
  margin-top: 40px;
  color: #2E3A54;
}
#requirementsInner h4 {
  font-size: 1em;
  margin-top: 10px;
}
#requirementsInner a {
  text-decoration: none;
  border-bottom: solid 1px #3C55A6;
  color: #3C55A6;
  transition: 0.3s;
}
#requirementsInner p {
  margin-top: 15px;
}
#requirementsInner ul {
    margin-top: 20px;
}
#requirementsInner li {
  margin-top: 10px;
}
@media screen and (max-width: 768px) {
  #requirementsInner h2 {
    margin-top: calc(30 / 375 * 100vw);
  }
  #requirementsInner h3 {
    margin-top: calc(30 / 375 * 100vw);
  }
  #requirementsInner h4 {
    margin-top: calc(10 / 375 * 100vw);
  }
  #requirementsInner p {
    margin-top: calc(10 / 375 * 100vw);
  }
    #requirementsInner ul {
    margin-top: calc(10 / 375 * 100vw);
}
  #requirementsInner li {
    margin-top: calc(5 / 375 * 100vw);
  }
}
#requirementsInner .list1 {
  list-style: none;
  padding-left: 1em;
  text-indent: -1em;
}
#btn {
  padding: 5% 0 10%;
  margin: 0 auto;
  text-align: center;
}
#requirementsInner .act {
    color: #C60019;
}
#requirementsInner .ctr {
    text-align: center;
}
.btn_apply {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  text-decoration: none;
  color: #0f1419;
  font-size: 24px;
  letter-spacing: 0.05em;
  font-weight: 700;
  border-radius: 5px;
  width: 400px;
  height: 80px;
  position: relative;
  transition: 0.3s;
  background-image: linear-gradient(180deg, rgba(255, 240, 1, 1) 10%, rgba(198, 186, 0, 1) 90%);
  margin: 0 auto;
}
.btn_apply::before, .btn_apply::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 15px;
  transform-origin: 100% 50%;
  height: 3px;
  width: 15px;
  background-color: #2E3A54;
  border-radius: 3px;
  will-change: transform;
  transition: .3s;
}
.btn_apply::before {
  top: 51%;
  transform: translateY(-50%) rotate(35deg);
}
.btn_apply::after {
  transform: translateY(-50%) rotate(-35deg);
}
@media screen and (max-width: 768px) {
  #btn {
    padding: 15% 0 20%;
  }
  .btn_apply {
    font-size: calc(20 / 375 * 100vw);
    width: calc(300 / 375 * 100vw);
    height: calc(80 / 375 * 100vw);
  }
  .btn_apply::before, .btn_apply::after {
    right: calc(17 / 375 * 100vw);
    height: calc(4 / 375 * 100vw);
    width: calc(17 / 375 * 100vw);
  }
  .btn_apply::before {
    top: 52%;
  }
}
@media screen and (min-width: 769px) {
  #requirementsInner a:hover {
    filter: brightness(90%);
    font-weight: 600;
  }
  .btn_apply:hover {
    filter: brightness(140%);
  }
  .btn_apply:hover::before {
    transform: translate(5px, -50%) rotate(30deg);
  }
  .btn_apply:hover::after {
    transform: translate(5px, -50%) rotate(-30deg);
  }
}