@charset "UTF-8";
section p {
  padding: 0;
}

#sec1 .inner1 {
  padding: 26vw 0px 33vw;
  background-image: url(../img/course/sec1_bg.jpg);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
}
#sec1 .inner1 .txt {
  margin-top: 8vw;
}
#sec1 .inner1 .txt li + li {
  border-top: 1px solid;
  padding-top: 8vw;
  margin-top: 8vw;
}
#sec1 .sec1-img {
  margin-top: -15vw;
}
#sec1 .sec1-img li + li {
  margin-top: 3vw;
}
#sec1 .bnr_shared {
  width: auto;
  margin: 12vw 5% 0px;
}
#sec1 .bnr_shared a {
  background: url(../img/shared/bnr_bg.jpg);
  background-position: center top;
  background-repeat: repeat;
  position: relative;
}
#sec1 .bnr_shared a:before {
  content: "";
  position: absolute;
  top: 50%;
  right: 4%;
  background-image: url(../img/shared/shape.png);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 7vw;
  height: 7vw;
  transform: translateY(-50%) rotate(90deg);
}

#sec2 {
  margin-top: 12vw;
  padding-bottom: 22vw;
  background-image: url(../img/course/sec2_bg.jpg);
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
#sec2 h2 {
  position: relative;
  padding-top: 28vw;
  margin: 0px 4%;
}
#sec2 h2:before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  right: 0px;
  background: #fff;
  width: 1px;
  height: 25vw;
  margin: 0px auto;
}
#sec2 .slick_auto {
  margin: 10vw 1% 0px;
}
#sec2 .slick-dots {
  margin-top: 4vw;
}
#sec2 .slick-dots li {
  margin: 0px 5px;
  line-height: 0;
}
#sec2 .slick-dots li button {
  border: 1px solid #fff;
  background: transparent;
  width: 14px;
  height: 14px;
  line-height: 1;
}
#sec2 .slick-dots .slick-active button {
  background: #fff;
}
#sec2 .txt {
  margin-top: 10vw;
}
#sec2 .sec2-map {
  margin-top: 10vw;
}

#sec3 .inner1 {
  color: #000;
  background-image: url(../img/course/sec3_bg1.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 26vw 0px;
}
#sec3 .inner1 h2 {
  position: relative;
  overflow: hidden;
  font-size: 9.33vw;
  line-height: 1.56;
  letter-spacing: 0.18em;
  padding-bottom: 3vw;
}
#sec3 .inner1 h2 small {
  font-size: 8.4vw;
}
#sec3 .inner1 h2:after {
  content: "";
  position: absolute;
  bottom: 0; /* Position at the bottom */
  left: 0;
  width: 100%;
  height: 1px; /* Thickness of your blurred border */
  background: linear-gradient(to right, transparent 0%, rgba(0, 0, 0, 0.7) 20%, rgba(0, 0, 0, 0.9) 50%, rgba(0, 0, 0, 0.7) 80%, transparent 100%);
}
#sec3 .inner1 .note {
  margin-top: 4vw;
}
#sec3 .inner2 {
  position: relative;
  margin-top: 12vw;
}
#sec3 .inner2:before {
  content: "";
  position: absolute;
  top: 20vw;
  left: 0px;
  right: 0px;
  bottom: 15vw;
  background: rgba(0,0,0,0.75);
  z-index: -1;
}
#sec3 .inner2 h3 {
  margin-top: 15vw;
}
#sec3 .inner2 .price-all {
  margin-top: 1vw;
}
#sec3 .inner2 .txt {
  margin-top: 6vw;
}
#sec3 .inner2 .list-all {
  margin: 10vw 9% 0px;
  background-image: url(../img/shared/bg2.jpg);
  background-position: center top;
  background-repeat: repeat;
  color: #000;
  padding: 8vw 6% 14vw;
}
#sec3 .inner2 .list-all .ttl-list {
  margin: 0px -7%;
}
#sec3 .inner2 .list-all ul {
  line-height: 2.15;
}
#sec3 .sec3-img2 {
  position: relative;
  z-index: 1;
  margin-top: -8vw;
}

#sec4 {
  margin-top: 15vw;
}
#sec4 h2 {
  font-size: 7.06vw;
  letter-spacing: 0.18em;
  line-height: 1.39;
  position: relative;
  overflow: hidden;
  padding-bottom: 3vw;
}
#sec4 h2:after {
  content: "";
  position: absolute;
  bottom: 0; /* Position at the bottom */
  left: 0;
  width: 100%;
  height: 1px; /* Thickness of your blurred border */
  background: linear-gradient(to right, transparent 0%, rgba(255, 255, 255, 0.7) 20%, rgba(255, 255, 255, 0.9) 50%, rgba(255, 255, 255, 0.7) 80%, transparent 100%);
}
#sec4 .inner1 {
  margin-top: 12vw;
}
#sec4 .inner1 .box {
  background-image: url(../img/shared/bg2.jpg);
  background-position: center top;
  background-repeat: repeat;
  padding: 8vw 0px;
  color: #000;
  margin-left: 6%;
  margin-right: 6%;
}
#sec4 .inner1 .box + .box {
  margin-top: 8vw;
}
#sec4 .inner1 .ttl-border {
  margin: 0px auto;
}
#sec4 .inner1 .price-all {
  margin-top: 1vw;
}
#sec4 .inner1 .price-all dt {
  font-size: 9.33vw;
}
#sec4 .inner1 .price-all dd {
  color: #890b0a;
}
#sec4 .inner1 .toggle {
  border-top: 1px solid;
  margin-top: 4vw;
  padding: 5vw 4% 0px;
}
#sec4 .inner1 .toggle .toggle-link {
  font-weight: bold;
  text-align: center;
  padding-bottom: 4vw;
}
#sec4 .inner1 .toggle .toggle-link:after {
  content: "▼";
  top: auto;
  left: 0px;
  bottom: 0px;
  margin: 0px auto;
  text-align: center;
  font-size: inherit;
  line-height: 1;
}
#sec4 .inner1 .toggle.active .toggle-link:after {
  transform: rotate(180deg);
}
#sec4 .inner2 {
  margin-top: 10vw;
  padding-bottom: 20vw;
  background-image: url(../img/course/sec4_bg.jpg);
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100% auto;
  position: relative;
}
#sec4 .inner2 .sec4-deco1 {
  position: absolute;
  top: -16vw;
  right: 0px;
  width: 22vw;
}
#sec4 .inner2 .sec4-deco2 {
  position: absolute;
  right: 0px;
  bottom: 0px;
  width: 23vw;
}
#sec4 .inner2 h3 {
  font-size: 8vw;
  letter-spacing: 0.15em;
  line-height: 1.6;
  box-sizing: border-box;
  border-bottom: 1px solid;
  width: fit-content;
  padding: 0px 6% 2vw;
}
#sec4 .inner2 .list {
  margin: 6vw 4% 0px;
  justify-content: space-between;
}
#sec4 .inner2 .list .col {
  width: 48%;
}
#sec4 .inner2 .list ul li {
  letter-spacing: 0;
}
#sec4 .inner2 .list ul + ul {
  margin-top: 5vw;
}

#sec5 {
  background-image: url(../img/course/sec5_bg.jpg);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
  margin-top: 29vw;
  padding-bottom: 25vw;
}
#sec5 h2 {
  position: relative;
  padding-top: 20vw;
  text-align: center;
}
#sec5 h2:before {
  content: "";
  position: absolute;
  top: -17vw;
  left: 0px;
  right: 0px;
  background: #fff;
  width: 1px;
  height: 34vw;
  margin: 0px auto;
}
#sec5 h2 small {
  font-size: 8vw;
}
#sec5 h3 {
  margin-top: 8vw;
}
#sec5 .txt {
  margin-top: 6vw;
}
#sec5 .list-all {
  margin-top: 6vw;
  padding-top: 6vw;
  border-top: 1px solid;
  letter-spacing: 0.05em;
}
#sec5 .list-all .ttl-list {
  border-bottom: 0px;
  padding-bottom: 0px;
  text-align: left;
}
#sec5 .list-all .inner-list {
  margin-top: 4vw;
  column-gap: 4%;
}