@charset "UTF-8";
/*-----------------------------
  points
-----------------------------*/
.sec-points {
  max-width: var(--size-content);
  margin: 0 auto;
  padding-block: var(--size-block);
}
.sec-points ol {
  margin-top: 4rem;
}
.sec-points ol li {
  display: grid;
  grid-template-columns: 31.5% 1fr;
  align-items: center;
  gap: 2.4rem 3.2rem;
  padding: 2.4rem;
  background: #fff;
  border: 1px solid var(--color-indigo);
  border-radius: 4rem;
  counter-increment: num;
}
.sec-points ol li + li {
  margin-top: 4rem;
}
.sec-points ol li figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 1.6rem;
}
.sec-points ol li h3 {
  grid-column: 1 / 3;
  display: flex;
  align-items: center;
}
.sec-points ol li h3:before {
  content: counter(num, decimal-leading-zero);
  margin-right: 2.4rem;
  color: var(--color-grey-300);
  line-height: 1;
  font-size: 4rem;
  font-weight: 200;
  background: var(--color-gradient-horizontal);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sec-points ol li .content {
  line-height: 1.8;
}
.sec-points ol li .content p + p {
  margin-top: 1em;
}
@media (max-width: 768px) {
  .sec-points {
    padding-inline: var(--size-inline);
  }
  .sec-points ol li {
    display: block;
    border-radius: 2.4rem;
    padding: 2rem;
  }
  .sec-points ol li figure {
    margin: 1.6rem auto 3.2rem;
  }
  .sec-points ol li figure img {
    border-radius: 1.2rem;
  }
  .sec-points ol li h3 {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.6rem;
    font-size: 2rem;
  }
  .sec-points ol li h3:before {
    font-size: 2.8rem;
  }
  .sec-points ol li .content {
    font-size: 1.4rem;
  }
}
/*-----------------------------
  workstyle
-----------------------------*/
.sec-workstyle {
  max-width: var(--size-content);
  margin: 0 auto;
  padding-block: var(--size-block);
}
.sec-workstyle ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 3.2rem;
  margin-top: 4rem;
}
.sec-workstyle ul li {
  padding: 3.2rem 0 4rem;
  border-radius: 1.6rem;
  border: 1px solid var(--color-indigo);
  background: #fff;
  text-align: center;
}
.sec-workstyle ul li>p:first-of-type {
  padding-bottom: 2.4rem;
  font-size: 1.8rem;
}
.sec-workstyle ul li >p:first-of-type strong:after {
  content: "";
  display: block;
  width: 8rem;
  height: 0.6rem;
  margin: 1.6rem auto 0;
  background: var(--color-gradient-horizontal);
  border-radius: 99rem;
}
.sec-workstyle ul li div {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 12rem;
  font-size: 2.8rem;
}
.sec-workstyle ul li div p em {
  font-style: normal;
  font-size: 10rem;
  font-weight: 200;
  line-height: 0.8;
  display: inline-block;
}
.sec-workstyle ul li div p small {
  display: block;
  font-size: 1.8rem;
}
@media (max-width: 768px) {
  .sec-workstyle {
    padding-inline: var(--size-inline);
  }
  .sec-workstyle ul {
    grid-template-columns: repeat(2, 1fr);
    margin-top: 3.2rem;
    gap: 0.8rem;
  }
  .sec-workstyle ul li {
    line-height: 1.3;
    padding: 2.4rem 0;
  }
  .sec-workstyle ul li >p:first-of-type {
    font-size: 1.6rem;
  }
  .sec-workstyle ul li div {
    font-size: 2.4rem;
    min-height: 6.4rem;
  }
  .sec-workstyle ul li div p em {
    font-size: 4.8rem;
  }
  .sec-workstyle ul li div p small {
    font-size: 1.6rem;
  }
}
/*-----------------------------
  system
-----------------------------*/
.sec-system {
  max-width: var(--size-content);
  margin: 0 auto;
  padding-block: var(--size-block);
}
.sec-system .flexbox {
  display: flex;
  align-items: center;
  gap: 3.2rem 4rem;
  margin-top: 4rem;
}
.sec-system .flexbox figure {
  flex: 0 0 40%;
}
.sec-system .flexbox figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 1.6rem;
}
.sec-system .flexbox .content {
  flex: 1 1 auto;
  line-height: 1.8;
}
.sec-system .flexbox .content h3 {
  margin-bottom: 3.2rem;
}
.sec-system .flexbox .content p + p {
  margin-top: 1.6rem;
}
.sec-system .flexbox .content small {
  display: block;
  text-align: right;
  margin-top: 1.6rem;
  font-size: 1.6rem;
}

@media (max-width: 768px) {
  .sec-system {
    padding-inline: var(--size-inline);
  }
  .sec-system .flexbox {
    display: block;
    margin-top: 3.2rem;
  }
  .sec-system .flexbox .content {
    margin-top: 2.4rem;
  }
  .sec-system .flexbox .content small {
    font-size: 1.4rem;
  }
}
/*-----------------------------
  benefit
-----------------------------*/
.sec-benefit {
  max-width: var(--size-content);
  margin: 0 auto;
  padding-block: var(--size-block);
}
@media (max-width: 768px) {
  .sec-benefit {
    padding-inline: var(--size-inline);
  }
  .sec-benefit table th {
    white-space: nowrap;
  }
}
/*-----------------------------
  candidate
-----------------------------*/
.sec-candidate {
  margin: var(--size-block) 0;
  border-radius: 4rem;
  background: var(--color-indigo);
  box-shadow: var(--deco-dropshadow-area);
}
.sec-candidate .mod-heading-gradient {
  color: #fff;
}
.sec-candidate .inner > p {
  color: #fff;
  line-height: 1.8;
}
.sec-candidate .inner p + p {
  margin-top: 1em;
}
.sec-candidate .mod-heading-gradient span {
  -webkit-text-fill-color: initial;
}
.sec-candidate .inner {
  max-width: var(--size-content);
  margin: 0 auto;
  padding: var(--size-block) 0;
}

.sec-candidate ol {
  margin-top: 4rem;
}
.sec-candidate ol li {
  display: grid;
  grid-template-columns: 31.5% 1fr;
  align-items: center;
  gap: 2.4rem 3.2rem;
  padding: 4rem;
  background: #fff;
  border: 1px solid var(--color-indigo);
  border-radius: 4rem;
  counter-increment: num;
}
.sec-candidate ol li + li {
  margin-top: 4rem;
}
.sec-candidate ol li figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 1.6rem;
}
.sec-candidate ol li h3 {
  grid-column: 1 / 3;
}
.sec-candidate ol li .content {
  line-height: 1.8;
}
@media (max-width: 768px) {
  .sec-candidate {
    border-radius: 2.4rem;
  }
  .sec-candidate .inner {
    padding-inline: var(--size-inline);
  }
  .sec-candidate ol li {
    display: block;
    padding: 3.2rem;
    border-radius: 2.4rem;
  }
  .sec-candidate ol li figure {
    margin: 1.6rem auto 3.2rem;
  }
  .sec-candidate ol li figure img {
    border-radius: 1.2rem;
  }
  .sec-candidate ol li h3 {
    font-size: 2rem;
  }
  .sec-candidate ol li .content {
    font-size: 1.4rem;
  }
}
/*-----------------------------
  intro
-----------------------------*/
.sec-intro {
  max-width: var(--size-content);
  margin: 0 auto;
  padding-block: var(--size-block);
}
.sec-intro .flexbox {
  display: flex;
  gap: 3.2rem 4rem;
  margin-top: 4rem;
  line-height: 1.8;
}
.sec-intro .flexbox figure {
  flex: 0 0 29.5%;
}
.sec-intro .flexbox figure img {
  border-radius: 1.6rem;
}
.sec-intro .flexbox .content {
  flex: 1 1 auto;
}
.sec-intro .flexbox .content h3 {
  margin-bottom: 3.2rem;
}
.sec-intro .flexbox .content p + p {
  margin-top: 1.6rem;
}
.sec-intro .flexbox .content .mod-button-primary {
  margin-top: 4rem;
}
@media (max-width: 768px) {
  .sec-intro {
    padding-inline: var(--size-inline);
  }
  .sec-intro .flexbox {
    display: block;
  }
  .sec-intro .flexbox .content {
    margin-top: 3.2rem;
    font-size: 1.42rem;
  }
  .sec-intro .flexbox .content h3 {
    font-size: 2rem;
    margin-bottom: 2.4rem;
  }
}

/*-----------------------------
  clinic
-----------------------------*/
.sec-clinic {
  max-width: var(--size-content);
  margin: 0 auto;
  padding-block: var(--size-block);
}
.sec-clinic ul {
  margin: 4rem auto;
}
.sec-clinic ul li {
  display: flex;
  align-items: center;
  gap: 4rem;
  padding-bottom: 2.4rem;
  margin-bottom: 2.4rem;
  border-bottom: 1px solid var(--color-grey-200);
  position: relative;
  transition: opacity 0.3s;
}
.sec-clinic ul li:hover {
  opacity: 0.7;
}
.sec-clinic ul figure {
  flex: 0 0 40%;
  aspect-ratio: 448/252;
}
.sec-clinic ul figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 1.6rem;
}
.sec-clinic ul .detail {
  flex: 1 1 auto;
}
.sec-clinic ul .detail p a {
  text-decoration: underline;
  font-size: 1.8rem;
  font-weight: bold;
  opacity: 1 !important;
}
.sec-clinic ul .detail p a:before {
  content: "";
  position: absolute;
  inset: 0;
}
.sec-clinic ul .detail p a:hover {
  text-decoration: none;
}
.sec-clinic ul .detail address {
  margin-top: 1.6rem;
  font-style: normal;
  font-size: 1.6rem;
  line-height: 1.8;
}
.sec-clinic ul + a {
  margin-inline: auto;
}

@media (max-width: 768px) {
  .sec-clinic {
    padding-inline: var(--size-inline);
  }
  .sec-clinic ul li {
    display: block;
    padding-bottom: 2rem;
    margin-bottom: 3.2rem;
  }
  .sec-clinic ul .detail {
    margin-top: 2rem;
  }
}
