/* =======================================
 base style
======================================= */
html {
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, dl, dt, dd, ul, ol, li {
  font-size: 100%;
  line-height: 1;
  margin: 0;
  padding: 0;
}

p {
  margin: 0;
  padding: 0;
}

ul, ol, li {
  list-style: none;
}

body {
  background: #fff;
  line-height: 1;
  margin: auto;
  width: 100%;
}
@media only screen and (min-width: 769px) {
  body {
    font-size: 1.481vw;
  }
}
@media only screen and (min-width: 1080px) {
  body {
    font-size: 16px;
    min-width: 1080px;
  }
}
@media only screen and (max-width: 768px) {
  body {
    font-size: 3.467vw;
    overflow-x: hidden;
  }
}

img {
  width: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

a {
  text-decoration: none;
  animation: all 1s ease-in-out;
}
a:hover {
  opacity: 0.9;
  animation: all 1s ease-in-out;
}

.main_ctx {
  position: relative;
}

.inner_ctx {
  margin: auto;
  position: relative;
}
@media only screen and (min-width: 769px) {
  .inner_ctx {
    width: 100vw;
    max-width: 1080px;
  }
}
@media only screen and (max-width: 768px) {
  .inner_ctx {
    padding: 0 5.333%;
  }
}

@media only screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
}

@media only screen and (min-width: 769px) {
  .sp {
    display: none !important;
  }
}

@media only screen and (min-width: 769px) {
  .sec02 {
    background: url("../img/sec02_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 22.125em;
  }
}
@media only screen and (max-width: 768px) {
  .sec02 {
    background: url("../img/sec02_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    height: 88vw;
  }
}
.sec02 ul {
  display: flex;
  align-items: center;
  position: relative;
}
@media only screen and (min-width: 769px) {
  .sec02 ul {
    padding-left: 7.625em;
    gap: 3em;
  }
}
@media only screen and (max-width: 768px) {
  .sec02 ul {
    flex-direction: column;
    align-items: center;
    gap: 5.867vw;
  }
}
@media only screen and (min-width: 769px) {
  .sec02 ul li:nth-child(1) {
    width: 20em;
  }
}
@media only screen and (max-width: 768px) {
  .sec02 ul li:nth-child(1) {
    width: 59.733vw;
  }
}
@media only screen and (min-width: 769px) {
  .sec02 ul li:nth-child(2) {
    width: 30.25em;
  }
}
@media only screen and (max-width: 768px) {
  .sec02 ul li:nth-child(2) {
    width: 80.533vw;
  }
}

.sec04 {
  background-color: #dfeefa;
}

@media only screen and (min-width: 769px) {
  .sec05 {
    background: url("../img/sec05_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 72.5em;
  }
}

@media only screen and (min-width: 769px) {
  .sec06 {
    background: url("../img/sec06_bg.jpg") no-repeat 50% 0%;
    background-size: 125em auto;
    height: 75em;
  }
}
@media only screen and (max-width: 768px) {
  .sec06 {
    background: url("../img/sec06_bg_sp.jpg") no-repeat 50% 0;
    background-size: 100vw auto;
    height: 536vw;
  }
}

.sec08 {
  background-color: #f3f9fe;
}

@media only screen and (min-width: 769px) {
  .sec09 {
    padding-bottom: 4.375em;
  }
}
@media only screen and (max-width: 768px) {
  .sec09 {
    padding-bottom: 8vw;
  }
}
.sec09 .form {
  margin: auto;
  background-color: #a0a0a0;
}
@media only screen and (min-width: 769px) {
  .sec09 .form {
    width: 56.25em;
    height: 62.5em;
  }
}
@media only screen and (max-width: 768px) {
  .sec09 .form {
    width: 81.333vw;
    height: 386.667vw;
  }
}

@media only screen and (min-width: 769px) {
  .sec10 {
    padding: 4.375em 0 5em;
  }
}
@media only screen and (max-width: 768px) {
  .sec10 {
    padding: 8vw 0 17.333vw;
  }
}
.sec10 .inner_ctx {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.sec10 a {
  display: inline-block;
  margin: auto;
}
@media only screen and (min-width: 769px) {
  .sec10 a {
    width: 29.813em;
  }
}
@media only screen and (max-width: 768px) {
  .sec10 a {
    width: 81.867vw;
  }
}

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