*,
::before,
::after {
  box-sizing: border-box;
}

html {
  line-height: 160%;
  -webkit-text-size-adjust: 100%;
  font-family: "Noto Sans JP", sans-serif;
  color: #222;
  scroll-behavior: smooth;
}

body {
  margin: 0;
}

hr {
  height: 0;
  color: inherit;
  border-width: 0 0 1px;
  border-style: solid;
  border-color: #ccc;
}

a {
  color: inherit;
  text-decoration: inherit;
}

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  border: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;
  font-size: 1em;
}

table {
  text-indent: 0;
  border-color: inherit;
  border-collapse: collapse;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: inherit;
  color: inherit;
  margin: 0;
  padding: 0;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
  background-color: transparent;
  background-image: none;
  cursor: pointer;
}

:disabled {
  cursor: default;
}

::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

:-moz-focusring {
  outline: 1px dotted ButtonText;
}

:-moz-ui-invalid {
  box-shadow: none;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

textarea {
  resize: vertical;
}

img,
svg,
video,
canvas,
audio,
iframe {
  vertical-align: middle;
}

img,
video {
  max-width: 100%;
  height: auto;
}

em {
  font-style: normal;
}

.wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}
.wrapper main {
  flex-grow: 1;
}

.container {
  width: 100%;
  max-width: 1132px;
  padding: 0 16px;
  margin: 0 auto;
}

.header {
  border-top: 4px solid #006cb6;
  border-bottom: 1px solid #d5d5d5;
  background: #fff;
}

.header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 67px;
}
@media (min-width: 768px) {
  .header-inner {
    height: 83px;
  }
}
@media (max-width: 767px) {
  .header-inner .logo {
    width: auto;
    height: 42px;
  }
}
@media (max-width: 767px) {
  .header-inner .logo-company {
    width: 96px;
  }
}

html {
  color: #232323;
}

.footer {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #999;
  font-size: 0.5625rem;
}
@media (min-width: 768px) {
  .footer {
    align-items: flex-end;
    font-size: 0.75rem;
  }
}
.footer .copyright {
  display: flex;
  align-items: center;
  height: 32px;
}
@media (min-width: 768px) {
  .footer .copyright {
    height: 40px;
  }
}

mark {
  background: linear-gradient(transparent 50%, #ffea63 50%);
}

.external {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #006cb6;
  font-size: 0.875rem;
  line-height: 140%;
}
.external::after {
  content: "";
  width: 20px;
  height: 20px;
  background: url("../img/icon/external.svg");
}
.external:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.main-visual {
  background-image: linear-gradient(to right, #e4f7d3 calc(50% - 63px), #ffeae4 calc(50% - 63px), #ffeae4 calc(50% + 63px), #ebf5fa calc(50% + 63px));
  overflow: hidden;
}
@media (min-width: 768px) {
  .main-visual {
    background-image: linear-gradient(to right, #e4f7d3 calc(50% - 240px), #ffeae4 calc(50% - 240px), #ffeae4 calc(50% + 240px), #ebf5fa calc(50% + 240px));
  }
}
.main-visual .main-visual-inner {
  position: relative;
  height: 409px;
}
@media (min-width: 768px) {
  .main-visual .main-visual-inner {
    display: flex;
    align-items: center;
    height: 480px;
  }
}
@media (max-width: 767px) {
  .main-visual .main-visual-inner {
    padding: 24px 0 0;
  }
}
.main-visual .main-visual-image {
  position: absolute;
  top: 0;
  left: -134px;
  max-width: none;
}
@media (max-width: 767px) {
  .main-visual .main-visual-image {
    left: calc(50% - 199px);
  }
}
.main-visual .main-visual-text {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 24px;
  text-align: center;
  font-weight: 500;
  line-height: 160%;
  white-space: nowrap;
}
@media (min-width: 768px) {
  .main-visual .main-visual-text {
    gap: 40px;
    text-align: left;
  }
}

.service-section {
  position: relative;
}
.service-section.intro {
  padding: 40px 0 112px;
}
@media (min-width: 768px) {
  .service-section.intro {
    padding-bottom: 180px;
  }
}
.service-section.intro::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 0;
  width: 100%;
  height: 20px;
  background: url("../img/wave.svg") no-repeat;
  background-size: 100% 20px;
}
@media (min-width: 768px) {
  .service-section.intro::before {
    top: -40px;
    height: 40px;
    background-size: 100% 40px;
  }
}
.service-section.safety, .service-section.cluboff, .service-section.ksp {
  padding: 64px 0 112px;
}
@media (min-width: 768px) {
  .service-section.safety, .service-section.cluboff, .service-section.ksp {
    padding: 60px 0 180px;
  }
}
.service-section.safety::before, .service-section.cluboff::before, .service-section.ksp::before {
  content: "";
  position: absolute;
  top: -48px;
  left: 0;
  width: 100%;
  height: 48px;
  background-color: inherit;
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
}
@media (min-width: 768px) {
  .service-section.safety::before, .service-section.cluboff::before, .service-section.ksp::before {
    top: -120px;
    height: 120px;
  }
}
.service-section.ksp {
  background-color: #e4f7d3;
}
.service-section.cluboff {
  background-color: #ffeae4;
}
.service-section.safety {
  background-color: #ebf5fa;
}

.intro-heading {
  text-align: center;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 140%;
}
@media (min-width: 768px) {
  .intro-heading {
    font-size: 2.5rem;
  }
}
@media (max-width: 767px) {
  .intro-heading {
    margin-bottom: 24px;
  }
}
.intro-heading em {
  font-size: 2rem;
  line-height: 140%;
}
@media (min-width: 768px) {
  .intro-heading em {
    font-size: 3.75rem;
  }
}
.intro-heading .ksp {
  color: #236e00;
}
.intro-heading .cluboff {
  color: #e3623f;
}
.intro-heading .safety {
  color: #1681bf;
}

.intro-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
@media (min-width: 768px) {
  .intro-text {
    flex-direction: row;
    gap: 16px;
  }
}
.intro-text > dt {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 31px;
  padding: 0 10px 0 16px;
  border-radius: 19px;
  background: #006cb8;
  color: #ffea63;
  font-weight: 700;
}
@media (min-width: 768px) {
  .intro-text > dt {
    height: 39px;
    font-size: 1.25rem;
  }
}
.intro-text > dd {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 110%;
}
@media (min-width: 768px) {
  .intro-text > dd {
    font-size: 2rem;
  }
}
.intro-text > dd em {
  color: #006cb8;
  font-size: 1.75rem;
  line-height: 110%;
}
@media (min-width: 768px) {
  .intro-text > dd em {
    font-size: 2.5rem;
  }
}

.intro-video {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px;
  background: #f1f9ff;
  line-height: 140%;
}
@media (min-width: 768px) {
  .intro-video {
    align-self: auto;
    flex-direction: row;
    align-items: center;
  }
}
.intro-video .thumbnail {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.intro-video-box {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (min-width: 768px) {
  .intro-video-box {
    flex-direction: row;
    flex-wrap: wrap;
  }
}
.intro-video-box .play {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  min-width: 240px;
  padding: 6px 15px;
  border-radius: 8px;
  border: 1px solid #006cb8;
  background: #fff;
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.16);
  color: #006cb8;
}
.intro-video-box .play::after {
  content: "";
  flex-shrink: 0;
  width: 21px;
  height: 20px;
  margin-left: 4px;
  background: url("../img/icon/play.svg");
}

.service-heading {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.service-heading::before {
  content: "";
  position: absolute;
  height: 200px;
  background-size: contain;
}
.ksp .service-heading {
  padding-right: 87px;
}
@media (min-width: 768px) {
  .ksp .service-heading {
    padding-right: 162px;
  }
}
.ksp .service-heading::before {
  top: -49px;
  right: 6px;
  width: 81px;
  background-image: url("../img/ksp-image.png");
}
@media (min-width: 768px) {
  .ksp .service-heading::before {
    top: -78px;
    right: 13px;
    width: 149px;
    height: 367px;
  }
}
.cluboff .service-heading {
  padding-left: 100px;
}
@media (min-width: 768px) {
  .cluboff .service-heading {
    padding-left: 200px;
  }
}
.cluboff .service-heading::before {
  top: -34px;
  left: -6px;
  width: 98px;
  background-image: url("../img/cluboff-image.png");
}
@media (min-width: 768px) {
  .cluboff .service-heading::before {
    top: -90px;
    left: 12px;
    width: 173px;
    height: 354px;
  }
}
.safety .service-heading {
  padding-right: 109px;
}
@media (min-width: 768px) {
  .safety .service-heading {
    padding-right: 201px;
  }
}
.safety .service-heading::before {
  top: -20px;
  right: 6px;
  width: 103px;
  background-image: url("../img/safety-image.png");
}
@media (min-width: 768px) {
  .safety .service-heading::before {
    top: -63px;
    right: 17px;
    width: 184px;
    height: 356px;
  }
}

.service-meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
}
@media (min-width: 768px) {
  .service-meta {
    flex-direction: row;
    align-items: center;
  }
}
.service-meta .badge {
  padding: 5px 8px;
  border-radius: 26px;
  background: #ffea63;
  font-size: 0.75rem;
  line-height: 120%;
}
.service-meta .provider {
  color: #666;
  font-size: 0.8125rem;
  line-height: 120%;
}
@media (min-width: 768px) {
  .service-meta .provider {
    font-size: 0.875rem;
  }
}

.service-lead {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (min-width: 768px) {
  .ksp .service-lead {
    padding-right: 162px;
  }
}
@media (min-width: 768px) {
  .cluboff .service-lead {
    padding-left: 200px;
  }
}
.service-lead h3 {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 160%;
}
@media (min-width: 768px) {
  .service-lead h3 {
    font-size: 2rem;
    line-height: 120%;
  }
}
.ksp .service-lead h3 {
  color: #236e00;
}
.cluboff .service-lead h3 {
  color: #e3623f;
}
.safety .service-lead h3 {
  color: #1681bf;
}

.inquiry-note,
.service-note {
  color: #666;
  font-size: 0.75rem;
}
@media (min-width: 768px) {
  .inquiry-note,
  .service-note {
    font-size: 0.8125rem;
  }
}
.inquiry-note > li,
.service-note > li {
  padding-left: 1em;
  text-indent: -1em;
}
.inquiry-note > li + li,
.service-note > li + li {
  margin-top: 8px;
}

.service-note {
  line-height: 160%;
}

.inquiry-note {
  line-height: 140%;
}
@media (max-width: 767px) {
  .inquiry-note br {
    display: none;
  }
}

.service-video {
  flex-shrink: 0;
  align-self: flex-end;
  position: relative;
  width: 100%;
  max-width: 420px;
  border-radius: 8px;
  border: 2px solid #fff;
  background-color: #fff;
  background-repeat: no-repeat;
  box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.16);
  overflow: hidden;
}
@media (min-width: 768px) {
  .service-video {
    align-self: flex-start;
    width: 420px;
  }
}
.ksp .service-video {
  background-image: url("../img/ksp-thumb.png");
  background-size: 221px auto;
  background-position: left -13px top -45px;
}
@media (min-width: 768px) {
  .ksp .service-video {
    background-size: 271px auto;
    background-position: left -15px top -56px;
  }
}
.cluboff .service-video {
  background-image: url("../img/cluboff-thumb.png");
  background-size: 213px auto;
  background-position: left -2px top -21px;
}
@media (min-width: 768px) {
  .cluboff .service-video {
    background-size: 261px auto;
    background-position: left -1px top -27px;
  }
}
.safety .service-video {
  background-image: url("../img/safety-thumb.png");
  background-size: 252px auto;
  background-position: left -46px top -18px;
}
@media (min-width: 768px) {
  .safety .service-video {
    background-size: 261px auto;
    background-position: left -56px top -20px;
  }
}

.service-video-inner {
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 6px;
  padding-top: 6px;
  padding-bottom: 5px;
  padding-right: 12px;
  background: linear-gradient(to left, #fff, #fff 145px, transparent 206px);
}
@media (min-width: 768px) {
  .service-video-inner {
    gap: 8px;
    padding-top: 6px;
    padding-bottom: 4px;
    padding-right: 14px;
    background: linear-gradient(to left, #fff, #fff 190px, transparent 261px);
  }
}
.service-video-inner::after {
  content: "";
  width: 20px;
  height: 20px;
  background: url("../img/icon/play-red.svg");
  background-size: contain;
}
@media (min-width: 768px) {
  .service-video-inner::after {
    width: 24px;
    height: 24px;
  }
}
.service-video-inner span {
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 120%;
}
@media (min-width: 768px) {
  .service-video-inner span {
    font-size: 1.125rem;
  }
}
.service-video-inner span small {
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 140%;
}
@media (min-width: 768px) {
  .service-video-inner span small {
    font-size: 0.875rem;
  }
}

.service-foot {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (min-width: 768px) {
  .service-foot {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }
}

.ksp-cycle {
  display: flex;
  align-items: flex-start;
  gap: 24px;
}
@media (max-width: 767px) {
  .ksp-cycle {
    flex-direction: column;
    align-items: center;
  }
}

.ksp-cycle-desc {
  flex-grow: 1;
  font-weight: 700;
  counter-reset: number;
}
.ksp-cycle-desc > div {
  counter-increment: number;
}
.ksp-cycle-desc > div + div {
  margin-top: 2px;
}
.ksp-cycle-desc > div > dt {
  display: flex;
  gap: 8px;
  padding: 9px 16px;
}
.ksp-cycle-desc > div > dt::before {
  content: counter(number);
}
.ksp-cycle-desc > div > dd {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 9px 16px;
  background: #fff;
}
@media (max-width: 767px) {
  .ksp-cycle-desc > div > dd {
    font-size: 0.9375rem;
    line-height: 160%;
  }
}
.ksp-cycle-desc > div:first-of-type > dt {
  border-radius: 8px 8px 0px 0px;
  background: #d0f1b1;
  color: #005623;
}
.ksp-cycle-desc > div:nth-of-type(2) > dt {
  background: #a6df6e;
  color: #005623;
}
.ksp-cycle-desc > div:nth-of-type(3) > dt {
  background: #59b91d;
  color: #fff;
}
.ksp-cycle-desc > div:nth-of-type(4) > dt {
  background: #39a20c;
  color: #fff;
}
.ksp-cycle-desc > div:last-of-type > dt {
  background: #2a8d00;
  color: #fff;
}
.ksp-cycle-desc > div:last-of-type > dd {
  border-radius: 0 0 8px 8px;
}

.ksp-checklist {
  display: flex;
  flex-direction: column;
  gap: 8px 16px;
}
@media (min-width: 768px) {
  .ksp-checklist {
    flex-direction: row;
    flex-wrap: wrap;
  }
}
.ksp-checklist > li {
  display: flex;
  gap: 4px;
  align-items: baseline;
  padding-left: 16px;
  color: #236e00;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 140%;
}
.ksp-checklist > li::before {
  content: "";
  flex-shrink: 0;
  width: 12px;
  height: 12px;
  margin-left: -16px;
  background: url("../img/icon/check-circle.svg");
}

.cluboff-desc {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 768px) {
  .cluboff-desc {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 768px) and (max-width: 1131px) {
  .cluboff-desc {
    grid-template-columns: repeat(2, 1fr);
  }
}
.cluboff-desc > div {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0;
}
.cluboff-desc > div > dt {
  padding: 8px 16px;
  border-radius: 8px 8px 0 0;
  background: #f58061;
  color: #fff;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 160%;
  text-align: center;
}
.cluboff-desc > div > dd {
  display: flex;
  gap: 16px;
  justify-content: space-between;
  align-items: flex-start;
  padding: 15px 16px;
  border-radius: 0 0 8px 8px;
  background: #fff;
}
@media (min-width: 768px) {
  .cluboff-desc > div > dd {
    padding: 23px 24px;
  }
}
@media (max-width: 767px) {
  .cluboff-desc > div > dd img {
    width: 75px;
  }
}

.safety-desc {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  counter-reset: safety-no;
}
@media (min-width: 1132px) {
  .safety-desc {
    grid-template-columns: repeat(3, 1fr);
  }
}
.safety-desc > div {
  position: relative;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0;
}
.safety-desc > div + div::before {
  content: "";
  position: absolute;
  top: -40px;
  left: calc(50% - 20px);
  width: 40px;
  height: 40px;
  transform: rotate(90deg);
  background: url("../img/icon/arrow-left.svg") no-repeat center;
}
@media (min-width: 1132px) {
  .safety-desc > div + div::before {
    top: calc(50% - 20px);
    left: -40px;
    transform: none;
  }
}
.safety-desc > div > dt {
  padding: 8px 16px;
  border-radius: 8px 8px 0 0;
  background: #2e98d4;
  color: #fff;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 140%;
  text-align: center;
}
.safety-desc > div > dd {
  display: flex;
  flex-direction: column;
  gap: 11px;
  align-items: center;
  padding: 15px 16px;
  border-radius: 0 0 8px 8px;
  background: #fff;
}
@media (min-width: 768px) {
  .safety-desc > div > dd {
    gap: 18px;
    padding: 23px 18px;
  }
}

.safety-desc-text {
  display: flex;
  flex-direction: column;
  gap: 11px;
  align-items: center;
  counter-increment: safety-no;
}
@media (min-width: 768px) {
  .safety-desc-text {
    gap: 18px;
  }
}
.safety-desc-text > dt {
  display: flex;
  gap: 4px;
  align-items: center;
  color: #1681bf;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 120%;
}
.safety-desc-text > dt::before {
  content: counter(safety-no);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  border-radius: 100%;
  background-color: #2e98d4;
  color: #fff;
}
@media (max-width: 1131px) {
  .safety-desc-text > dd br {
    display: none;
  }
}

@media (max-width: 767px) {
  .safety-desc-image {
    width: 219px;
  }
}

.safety-contact {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 12px;
}
.safety-contact .desc {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  font-size: 0.65625rem;
  font-weight: 700;
  line-height: 120%;
}
@media (min-width: 768px) {
  .safety-contact .desc {
    font-size: 0.875rem;
  }
}
.safety-contact .desc > dt {
  padding: 4px 6px;
  border-radius: 3px;
  background: #2e98d4;
  color: #fff;
}
@media (min-width: 768px) {
  .safety-contact .desc > dt {
    padding: 5px 8px;
  }
}
.safety-contact .list {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.safety-contact .list > li {
  display: flex;
  gap: 4px;
  align-items: center;
}
.safety-contact .list > li::before {
  content: "";
  flex-shrink: 0;
  width: 9px;
  height: 9px;
  background-image: url("../img/icon/check-circle-red.svg");
  background-size: contain;
}
@media (min-width: 768px) {
  .safety-contact .list > li::before {
    width: 12px;
    height: 12px;
  }
}
@media (max-width: 767px) {
  .safety-contact img {
    width: 51px;
  }
}

.apply-section .container {
  display: flex;
  flex-direction: column;
  gap: 40px;
  padding-top: 64px;
  padding-bottom: 64px;
}
@media (min-width: 768px) {
  .apply-section .container {
    padding-top: 120px;
    padding-bottom: 120px;
  }
}
.apply-section h2 {
  display: flex;
  gap: 12px;
  justify-content: center;
  align-items: flex-end;
  text-align: center;
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 120%;
}
@media (min-width: 768px) {
  .apply-section h2 {
    font-size: 2.5rem;
    letter-spacing: 1.6px;
  }
}
@media (max-width: 374px) {
  .apply-section h2 {
    font-size: 1.5rem;
  }
}
.apply-section h2::after, .apply-section h2::before {
  content: "";
  flex-shrink: 0;
  width: 24px;
  height: 39px;
  margin-bottom: 4px;
  background: url("../img/icon/line.svg");
}
.apply-section h2::after {
  transform: scale(-1, 1);
}
.apply-section h2 em {
  color: #006cb8;
  font-size: 2.375rem;
  line-height: 120%;
}
@media (min-width: 768px) {
  .apply-section h2 em {
    font-size: 3.25rem;
    letter-spacing: 2.08px;
  }
}

.apply-meta {
  align-self: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.apply-meta small {
  color: #666;
  font-size: 0.875rem;
  line-height: 140%;
}

.apply-step {
  display: grid;
  grid-template-columns: auto;
  justify-content: center;
  counter-reset: apply-no;
}
@media (min-width: 1132px) {
  .apply-step {
    grid-template-columns: 358px 382px 359px;
  }
}
.apply-step > div {
  display: flex;
  flex-direction: column;
  gap: 16px;
  counter-increment: apply-no;
}
@media (min-width: 768px) {
  .apply-step > div {
    gap: 24px;
  }
}
.apply-step > div:not(:first-of-type) {
  padding-top: 23px;
  border-top: 1px dashed #b0b0b0;
}
.apply-step > div:not(:last-of-type) {
  padding-bottom: 23px;
}
@media (min-width: 1132px) {
  .apply-step > div:not(:first-of-type) {
    padding-top: 0;
    padding-left: 23px;
    border-top: 0;
    border-left: 1px dashed #b0b0b0;
  }
  .apply-step > div:not(:last-of-type) {
    padding-bottom: 0;
    padding-right: 23px;
  }
}
.apply-step > div > dt {
  display: flex;
  gap: 8px;
  align-items: center;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 160%;
}
@media (min-width: 768px) {
  .apply-step > div > dt {
    gap: 16px;
    font-size: 1.375rem;
  }
}
.apply-step > div > dt span {
  padding: 4px 10px;
  border-radius: 8px;
  background: #006cb8;
  color: #fff;
  font-size: 0.875rem;
  line-height: 110%;
}
@media (min-width: 768px) {
  .apply-step > div > dt span {
    font-size: 1.125rem;
  }
}
.apply-step > div > dt span::after {
  content: counter(apply-no);
  font-size: 1.375rem;
  line-height: 110%;
}
@media (min-width: 768px) {
  .apply-step > div > dt span::after {
    font-size: 1.75rem;
  }
}
.apply-step > div > dd {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (min-width: 768px) {
  .apply-step > div > dd {
    gap: 24px;
  }
}
@media (max-width: 1131px) {
  .apply-step > div > dd br {
    display: none;
  }
}

.apply-note {
  padding-left: 1em;
  text-indent: -1em;
  color: #666;
  font-size: 0.75rem;
  line-height: 140%;
}
@media (min-width: 768px) {
  .apply-note {
    font-size: 0.875rem;
  }
}

.apply-after {
  padding: 6px 16px;
  border-radius: 8px;
  border: 2px solid #006cb8;
  background: #fff9cf;
  font-weight: 700;
  line-height: 180%;
  text-align: center;
}
@media (min-width: 768px) {
  .apply-after {
    padding-top: 5px;
    padding-bottom: 5px;
    font-size: 1.5rem;
  }
}
.apply-after em {
  color: #006cb8;
  font-size: 1.25rem;
  line-height: 180%;
}
@media (min-width: 768px) {
  .apply-after em {
    font-size: 2rem;
  }
}
@media (min-width: 425px) {
  .apply-after .hidden-sm {
    display: none;
  }
}
@media (min-width: 1024px) {
  .apply-after .hidden-md {
    display: none;
  }
}

.faq-section {
  background: #f6f6f6;
}
.faq-section .container {
  display: flex;
  flex-direction: column;
  gap: 32px;
  padding-top: 64px;
  padding-bottom: 64px;
}
@media (min-width: 768px) {
  .faq-section .container {
    gap: 64px;
    padding-top: 120px;
    padding-bottom: 120px;
  }
}
.faq-section h2 {
  text-align: center;
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 120%;
  letter-spacing: 1.2px;
}
@media (min-width: 768px) {
  .faq-section h2 {
    font-size: 2.5rem;
    letter-spacing: 1.6px;
  }
}

.faq-list {
  display: flex;
  flex-direction: column;
  padding: 16px;
  border-radius: 8px;
  background: #fff;
}
@media (min-width: 768px) {
  .faq-list {
    padding: 24px;
  }
}
.faq-list > div {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (min-width: 768px) {
  .faq-list > div {
    gap: 16px;
  }
}
.faq-list > div:not(:first-of-type) {
  padding-top: 23px;
  border-top: 1px solid #e4e4e4;
}
.faq-list > div:not(:last-of-type) {
  padding-bottom: 23px;
}
.faq-list > div > dd,
.faq-list > div > dt {
  position: relative;
  min-height: 24px;
  padding-left: 34px;
}
@media (min-width: 768px) {
  .faq-list > div > dd,
  .faq-list > div > dt {
    min-height: 32px;
    padding-left: 42px;
  }
}
.faq-list > div > dd::before,
.faq-list > div > dt::before {
  content: "";
  position: absolute;
  left: 0;
  width: 24px;
  height: 24px;
  background-size: contain;
}
@media (min-width: 768px) {
  .faq-list > div > dd::before,
  .faq-list > div > dt::before {
    width: 32px;
    height: 32px;
  }
}
.faq-list > div > dt {
  padding-top: 1px;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 140%;
}
@media (min-width: 768px) {
  .faq-list > div > dt {
    padding-top: 3px;
    font-size: 1.375rem;
    line-height: 120%;
  }
}
.faq-list > div > dt::before {
  top: 2px;
  background-image: url("../img/faq-q.png");
}
@media (min-width: 768px) {
  .faq-list > div > dt::before {
    top: 0;
  }
}
.faq-list > div > dd {
  padding-top: 2px;
  font-size: 0.875rem;
  line-height: 140%;
}
@media (min-width: 768px) {
  .faq-list > div > dd {
    padding-top: 3px;
    font-size: 1rem;
    line-height: 160%;
  }
}
.faq-list > div > dd::before {
  top: 0;
  background-image: url("../img/faq-a.png");
}
@media (min-width: 768px) {
  .faq-list > div > dd::before {
    top: 0;
  }
}
@media (max-width: 767px) {
  .faq-list > div > dd br {
    display: none;
  }
}

.inquiry-section {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-top: 32px;
  padding-bottom: 32px;
}
@media (min-width: 768px) {
  .inquiry-section {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

.inquiry-box {
  display: flex;
  flex-direction: column;
  border: 1px solid #006cb8;
  font-weight: 700;
  text-align: center;
}
@media (min-width: 1132px) {
  .inquiry-box {
    flex-direction: row;
  }
}
.inquiry-box h2 {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 12px 0 13px;
  background: #006cb8;
  color: #fff;
  line-height: 120%;
}
@media (min-width: 1132px) {
  .inquiry-box h2 {
    width: 400px;
    font-size: 1.25rem;
  }
}
.inquiry-box .inquiry-box-inner {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  padding: 10px 15px;
  background: #eff8ff;
  font-size: 0.875rem;
  line-height: 140%;
}
@media (min-width: 1132px) {
  .inquiry-box .inquiry-box-inner {
    flex-direction: row;
    justify-content: center;
    align-items: center;
  }
}
.inquiry-box .inquiry-box-inner p {
  padding-top: 9px;
}
@media (min-width: 1132px) {
  .inquiry-box .inquiry-box-inner p {
    padding-top: 0;
    padding-left: 39px;
  }
}

.inquiry-tel {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  padding-bottom: 9px;
  border-bottom: 1px solid #006cb8;
}
@media (min-width: 1132px) {
  .inquiry-tel {
    align-items: flex-start;
    padding-bottom: 0;
    padding-right: 39px;
    border-bottom: 0;
    border-right: 1px solid #006cb8;
  }
}
.inquiry-tel > dt {
  line-height: 120%;
}
.inquiry-tel > dd a {
  display: flex;
  gap: 8px;
  align-items: baseline;
  color: #006cb8;
  font-size: 2.25rem;
  line-height: 120%;
  white-space: nowrap;
}
@media (min-width: 768px) {
  .inquiry-tel > dd a {
    font-size: 2.5rem;
  }
}
@media (min-width: 375px) {
  .inquiry-tel > dd a {
    letter-spacing: 2.88px;
  }
}
.inquiry-tel > dd a::before {
  content: "";
  width: 28px;
  height: 29px;
  background: url("../img/icon/tel.svg");
}
@media (min-width: 768px) {
  .inquiry-tel > dd a {
    pointer-events: none;
  }
}

.whitespace-nowrap {
  white-space: nowrap;
}

@media (min-width: 768px) {
  .hidden-pc {
    display: none;
  }
}

.flex {
  display: flex;
}

.flex-col {
  flex-direction: column;
}

.items-center {
  align-items: center;
}

.items-end {
  align-items: flex-end;
}

.gap-8 {
  gap: 8px;
}

.gap-24 {
  gap: 24px;
}

.gap-40-64 {
  gap: 40px;
}
@media (min-width: 768px) {
  .gap-40-64 {
    gap: 64px;
  }
}

.leading-none {
  line-height: 1;
}
