/**
 * setting
 */
section .section-inner {
  min-width: 345px;
  max-width: 600px;
  margin: 0 auto;
  padding: 20px 15px 40px;
}
section.bg-blue {
  background-color: #EFF9FD;
}
section.bg-blue h2 span {
  color: #29BCFF;
}
@media (min-width: 768px) {
  section .section-inner {
    padding: 30px 15px 60px;
  }
}

h2 {
  font-size: 23px;
  text-align: center;
  margin-bottom: 20px;
  font-weight: bold;
  line-height: normal;
}
h2 span {
  z-index: -1;
  display: block;
  font-family: "adobe-handwriting-ernie", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 29px;
  color: #FFE802;
  transform: rotate(-5deg);
  z-index: 0;
  transform: translate(-70px, 20px) rotate(-5deg);
}
h2 div {
  position: relative;
  z-index: 5;
}
h2 div strong {
  padding: 0 2px 4px;
  background: linear-gradient(transparent 50%, #FFE802 50%);
}

body {
  background-image: url("../img/bg-border.svg");
  background-size: 400px;
  background-repeat: repeat;
}

/**
 * parts
 */
.mail-button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 160px;
  color: #FFFFFF;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  line-height: 1.8;
  cursor: pointer;
}
.mail-button:before {
  content: "";
  position: absolute;
  width: 160px;
  height: 160px;
  background: url("../img/icon-circle.svg");
  background-size: 160px 160px;
  z-index: -1;
}
.mail-button:after {
  content: "";
  position: absolute;
  bottom: 24px;
  width: 20px;
  height: 20px;
  background: url("../img/icon-feather-arrow-right-circle.svg");
  background-size: 20px 20px;
  z-index: 3;
}
.mail-button:before {
  filter: invert(56%) sepia(74%) saturate(591%) hue-rotate(10deg) brightness(105%) contrast(103%);
}

.line-button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 160px;
  color: #FFFFFF;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  line-height: 1.8;
  cursor: pointer;
}
.line-button:before {
  content: "";
  position: absolute;
  width: 160px;
  height: 160px;
  background: url("../img/icon-circle.svg");
  background-size: 160px 160px;
  z-index: -1;
}
.line-button:after {
  content: "";
  position: absolute;
  bottom: 24px;
  width: 20px;
  height: 20px;
  background: url("../img/icon-feather-arrow-right-circle.svg");
  background-size: 20px 20px;
  z-index: 3;
}
.line-button:before {
  filter: invert(75%) sepia(47%) saturate(5856%) hue-rotate(100deg) brightness(93%) contrast(98%);
}

.consultation-button {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 160px;
  color: #FFFFFF;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  line-height: 1.8;
  cursor: pointer;
}
.consultation-button:before {
  content: "";
  position: absolute;
  width: 160px;
  height: 160px;
  background: url("../img/icon-circle.svg");
  background-size: 160px 160px;
  z-index: -1;
}
.consultation-button:after {
  content: "";
  position: absolute;
  bottom: 24px;
  width: 20px;
  height: 20px;
  background: url("../img/icon-feather-arrow-right-circle.svg");
  background-size: 20px 20px;
  z-index: 3;
}
.consultation-button:before {
  filter: invert(19%) sepia(94%) saturate(1656%) hue-rotate(188deg) brightness(104%) contrast(103%);
}

.square-button {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin: 12.5px auto;
  background-color: #00A0E9;
  padding: 17.5px 0;
  border-radius: 3.5px;
  color: white;
  text-align: center;
  font-weight: bold;
  font-size: 17px;
  max-width: 316px;
  box-shadow: 0 2px 3px rgba(0, 0, 0, 0.2);
  cursor: pointer;
}
.square-button .icon {
  width: 20px;
  height: 20px;
}

/**
 * particular
 */
section.kv {
  max-width: 1200px;
  padding: 0;
  margin: 0 auto;
}
@media (min-width: 768px) {
  section.kv .kv_sp {
    display: none;
  }
}
@media (max-width: 767px) {
  section.kv .kv_pc {
    display: none;
  }
}

.start-early {
  position: relative;
  width: 100%;
  margin-bottom: 120px;
}
@media (min-width: 768px) {
  .start-early {
    max-width: 600px;
    margin: 80px auto 120px;
    position: relative;
    color: #FFFFFF;
  }
}

.start-early-image {
  position: relative;
}

.start-early-box {
  color: #FFFFFF;
  position: absolute;
  top: calc(50% - 106px);
  left: calc(50% - 106px);
  width: 212px;
  height: 212px;
  border: 4px solid #FFFFFF;
  background: linear-gradient(135deg, #00559B 0%, #29BCFF 100%);
  font-weight: bold;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 10px;
  font-size: 16px;
}
.start-early-box ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 5px;
}
.start-early-box ul li img {
  width: 57px;
}
.start-early-box strong {
  font-size: 23px;
}

.handwriting {
  font-family: "adobe-handwriting-ernie", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 29px;
  color: #FFE802;
  transform: rotate(-5deg);
  z-index: 0;
  color: #29BCFF;
  position: absolute;
  top: -32px;
  left: -27px;
}

.start-early-buttons {
  position: absolute;
  bottom: -120px;
  left: calc(50% - 167px);
  display: flex;
  justify-content: center;
  gap: 14px;
  z-index: 3;
}
@media (min-width: 768px) {
  .start-early-buttons {
    gap: 28px;
    left: calc(50% - 174px);
  }
}

.icon-list {
  margin-top: 40px;
  display: flex;
  justify-content: center;
  gap: 5px;
  align-items: center;
}
.icon-list div {
  background: #FFFFFF;
  border: 4px solid #EFF9FD;
  width: 122px;
  height: 122px;
  text-align: center;
  font-size: 13px;
}
.icon-list div img {
  margin: 20px auto;
  display: block;
  width: 64px;
}

.apply {
  margin: 12px auto 0;
}

.merit-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
}
.merit-list li {
  width: 50%;
  padding: 20px 10px;
  text-align: center;
  font-weight: bold;
}
.merit-list li img {
  width: 40px;
}
.merit-list li span {
  position: relative;
  padding-top: 10px;
  display: block;
  font-size: 26px;
  color: #00559B;
  font-family: "roboto", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.merit-list li span:before {
  content: "Point";
  position: absolute;
  top: 0px;
  left: calc(50% - 12px);
  font-size: 10px;
}
.merit-list li span:after {
  position: absolute;
  top: -10px;
  left: calc(50% - 34px);
  content: "";
  width: 68px;
  height: 34px;
  background: transparent;
  border-top-left-radius: 68px;
  border-top-right-radius: 68px;
  border: 1px solid #00559B;
  border-bottom: none;
}

.point-list {
  list-style: none;
  padding-left: 20px;
}
.point-list li {
  margin-bottom: 20px;
  position: relative;
  padding-left: 10px;
  line-height: 1.8;
}
.point-list li span {
  padding: 0 2px 4px;
  background: linear-gradient(transparent 50%, #FFE802 50%);
  font-weight: bold;
}
.point-list li:before {
  display: block;
  position: absolute;
  left: -25px;
  content: "";
  width: 25px;
  height: 25px;
  background-color: #FFFFFF;
  border: 1px solid #E6E6E6;
  border-radius: 2px;
}
.point-list li:after {
  display: block;
  position: absolute;
  content: "";
  border-right: 6px solid #00A0E9;
  border-bottom: 6px solid #00A0E9;
  margin-top: -14px;
  top: 10px;
  left: -13px;
  width: 12px;
  height: 24px;
  transform: rotate(45deg);
}

section.followup {
  position: relative;
  margin-bottom: 120px;
  background: darkblue;
  color: #FFFFFF;
  background-image: url("../img/bg-followup.png");
  background-size: cover;
  font-size: 15px;
}
section.followup h2 strong {
  padding: 0 2px 4px;
  background: linear-gradient(transparent 50%, #29BCFF 50%);
}
section.followup ol {
  padding: 10px;
  list-style: none;
}
section.followup ol li {
  line-height: 1.8;
}
section.followup ol li h3 {
  display: block;
  position: relative;
  padding: 40px 0 0 55px;
  font-size: 17px;
  font-weight: bold;
}
section.followup ol li h3 .point-circle {
  position: absolute;
  top: 0;
  left: 0;
  width: 70px;
  height: 70px;
}
section.followup ol {
  margin-top: 0;
}
section.followup ol li {
  margin-bottom: 12.5px;
}
section.followup ol li h3 {
  font-size: 17px;
}
section.followup ol li div {
  line-height: 1.8;
}
section.followup .button_area {
  position: absolute;
  bottom: -120px;
  left: calc(50% - 165px);
  display: flex;
  justify-content: center;
  z-index: 10;
  gap: 14px;
}
@media (min-width: 768px) {
  section.followup .button_area {
    gap: 28px;
    left: calc(50% - 174px);
  }
}

section.observation ol {
  padding: 10px;
  list-style: none;
}
section.observation ol li {
  line-height: 1.8;
}
section.observation ol li h3 {
  display: block;
  position: relative;
  padding: 40px 0 0 55px;
  font-size: 17px;
  font-weight: bold;
}
section.observation ol li h3 .point-circle {
  position: absolute;
  top: 0;
  left: 0;
  width: 70px;
  height: 70px;
}
section.observation ol {
  margin-top: 0;
}
section.observation ol li {
  margin-bottom: 12.5px;
}
section.observation ol li h3 {
  font-size: 17px;
}
section.observation ol li div {
  line-height: 1.8;
}
section.observation .textlink {
  color: #00A0E9;
  text-decoration: underline;
}

h3.subheading {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  margin-top: 24px;
}
h3.subheading span {
  display: block;
  color: #00A0E9;
  font-size: 13px;
}

section.information .button_area {
  height: 180px;
}
section.information .button_area div {
  z-index: 10;
}

section.information .section-inner {
  padding-bottom: 0;
}
section.information .information-inner {
  padding: 10px;
}
section.information .consultation-button {
  z-index: 10;
}

section.closing {
  position: relative;
  margin-bottom: 80px;
  padding: 0;
  background: #EFF9FD;
}
section.closing .section-inner {
  padding: 0;
}
section.closing .triangle-container {
  position: relative;
  padding: 10px 20px;
}
section.closing .triangle {
  margin: 15px 0;
  background: #FFFFFF;
  height: calc(tan(60deg) * 90px / 2);
  width: 100%;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
section.closing .closing-text {
  width: 260px;
  position: absolute;
  bottom: -20px;
  left: calc(50% - 125px);
  text-align: center;
  font-weight: bold;
  color: #00559B;
  line-height: 1.8;
  z-index: 10;
}
section.closing .button_area {
  position: absolute;
  bottom: -80px;
  left: calc(50% - 165px);
  display: flex;
  justify-content: center;
  z-index: 10;
  gap: 14px;
}
@media (min-width: 768px) {
  section.closing .button_area {
    gap: 28px;
    left: calc(50% - 174px);
  }
}

section.job-offers ul.job-list {
  list-style: none;
  margin-bottom: 20px;
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}
section.job-offers ul.job-list li {
  padding: 15px;
  background-color: #FFFFFF;
  border-radius: 4px;
  border: 1px solid #00559B;
}
section.job-offers ul.job-list li img {
  width: 100%;
}
section.job-offers ul.job-list li .heading {
  display: flex;
  align-items: center;
  gap: 16px;
}
section.job-offers ul.job-list li .heading img {
  width: 57px;
  height: 57px;
}
section.job-offers ul.job-list li .heading h3 {
  font-size: 17px;
  font-weight: bold;
  margin: 0;
}
section.job-offers ul.job-list li p {
  font-size: 14px;
  margin-top: 10px;
}
section.job-offers ul.job-list li dl {
  width: 100%;
  margin: 0 auto;
  display: inline-block;
  font-size: 14px;
  font-weight: bold;
  line-height: 2;
}
section.job-offers ul.job-list li dl dd {
  margin: 0;
  display: inline;
  background-color: #00559B;
  color: #FFFFFF;
  border-radius: 4px;
  padding: 4px;
}
section.job-offers ul.job-list li dl dt {
  display: inline;
  font-size: 18px;
}
section.job-offers ul.job-list li dl dt span {
  font-size: 37px;
  font-family: "roboto", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-weight: bold;
}
section.job-offers ul.feature-list {
  list-style: none;
  margin: 10px 0;
  padding: 0;
  display: flex;
  justify-content: center;
  gap: 7px;
}
section.job-offers ul.feature-list li {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  width: 100px;
  height: 100px;
  padding: 7px;
  background-color: #EFF9FD;
  border: none;
  color: #00559B;
  border-radius: 50%;
  font-size: 14px;
}
section.job-offers .advisor-comment {
  display: flex;
  gap: 10px;
  align-items: center;
}
section.job-offers .advisor-comment img.advisor {
  margin-top: 20px;
  display: block;
  width: 93px;
  height: 187.5px;
}
section.job-offers .button_area {
  margin-top: 8px;
  display: flex;
  justify-content: center;
  gap: 14px;
}
@media (min-width: 768px) {
  section.job-offers .button_area {
    gap: 28px;
  }
}

dl.faq {
  padding: 20px;
  padding-left: 52px;
  background-color: #FFFFFF;
  border-radius: 4px;
  border: 1px solid #00559B;
}
dl.faq + dl {
  margin-top: 10px;
}
dl.faq dt {
  position: relative;
  font-size: 17px;
  font-weight: bold;
  margin-bottom: 20px;
}
dl.faq dt:before {
  position: absolute;
  left: -40px;
  top: -5px;
  content: "Q";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background-color: #00559B;
  color: #FFFFFF;
  font-size: 21px;
  font-weight: normal;
}
dl.faq dd {
  position: relative;
  margin: 0;
  font-size: 15px;
  line-height: 1.8;
}
dl.faq dd:before {
  position: absolute;
  left: -40px;
  top: -5px;
  content: "A";
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 21px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background-color: #00A0E9;
  color: #FFFFFF;
  font-weight: normal;
}

.article-list {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/*# sourceMappingURL=style.css.map */
