@charset "UTF-8";
.btn {
  position: relative;
  display: inline-block;
  background-color: white;
  border: 1px solid black;
  font-weight: 600;
  padding: 10px 40px;
  margin: 10px auto;
  cursor: pointer;
  transition: all 0.3s;
  color: black;
  text-decoration: none !important;
}
.btn.float:hover {
  background-color: black;
  color: white;
  box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, 0.5);
}
.btn.filled {
  background-color: black;
  color: white;
  box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, 0.5);
}
.btn.filled:hover {
  background-color: white;
  color: black;
  box-shadow: none;
}
.btn.letter-spacing:hover {
  background-color: black;
  letter-spacing: 3px;
  color: white;
}
.btn.shadow {
  box-shadow: none;
}
.btn.shadow:hover {
  transform: translate(-2.5px, -2.5px);
  box-shadow: 5px 5px 0 0 black;
}
.btn.solid {
  box-shadow: 2px 2px 0 0 black;
  border-radius: 7px;
}
.btn.solid:hover {
  transform: translate(2px, 2px);
  box-shadow: none;
}
.btn.slide-bg {
  position: relative;
  overflow: hidden;
  z-index: 1;
}
.btn.slide-bg::before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 100%;
  background-color: black;
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(-100%);
  transition: transform 0.3s;
  z-index: -1;
}
.btn.slide-bg:hover {
  color: white;
}
.btn.slide-bg:hover::before {
  transform: none;
}
.btn.cover-3d {
  position: relative;
  z-index: 1;
  transform-style: preserve-3d;
  perspective: 300px;
}
.btn.cover-3d span {
  display: inline-block;
  transform: translateZ(20px);
}
.btn.cover-3d::before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 100%;
  background-color: black;
  position: absolute;
  top: 0;
  left: 0;
  transform: rotateX(90deg);
  transition: all 0.3s;
  transform-origin: top center;
  opacity: 0;
}
.btn.cover-3d:hover {
  color: white;
}
.btn.cover-3d:hover::before {
  transform: none;
  opacity: 1;
}

.btn-cubic {
  position: relative;
  display: inline-block;
  transform-style: preserve-3d;
  perspective: 300px;
  width: 150px;
  height: 50px;
  margin: 0 auto;
  cursor: pointer;
  font-weight: 600;
}
.btn-cubic span {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 1px solid black;
  box-sizing: border-box;
  line-height: 48px;
  text-align: center;
  transition: all 0.3s;
  transform-origin: center center -25px;
  color: black;
}
.btn-cubic .hovering {
  background-color: black;
  color: white;
  transform: rotateX(90deg);
}
.btn-cubic .default {
  background-color: white;
  color: black;
  transform: rotateX(0);
}
.btn-cubic:hover .hovering {
  transform: rotateX(0);
}
.btn-cubic:hover .default {
  transform: rotateX(-90deg);
}

body {
  font-family: "Noto Sans JP", "Roboto", sans-serif;
  text-align: left;
  color: black;
  text-align: justify; /* 両端揃え */
  overflow-x: hidden;
  line-height: 1.8rem;
  font-weight: 500;
}

/*=====================
  レイアウト
======================*/
@media screen and (max-width: 640px) {
  .content-width {
    width: 90%;
    margin: 0 auto;
  }
}
@media screen and (min-width: 641px) {
  .container {
    margin: 0 auto;
  }
}
@media screen and (min-width: 641px) {
  .contWrap {
    max-width: 1000px;
    margin: 0 auto;
  }
}
.br-sp {
  display: block;
}

@media screen and (min-width: 641px) {
  .br-sp {
    display: none;
  }
}
.br-pc {
  display: block;
}

@media screen and (max-width: 640px) {
  .br-pc {
    display: none;
  }
}
.spacer-sm {
  display: block;
  height: 0.5rem;
}

@media screen and (min-width: 641px) {
  .spacer-sm {
    display: block;
    height: 10px;
  }
}
.spacer {
  display: block;
  height: 1rem;
}

body .pc-item {
  display: none !important;
}

body .sp-item {
  display: block !important;
}

@media screen and (min-width: 641px) {
  body .pc-item {
    display: block !important;
  }
  body .sp-item {
    display: none !important;
  }
}
.contact {
  display: block;
  padding-top: 30px;
  margin-top: -30px;
}

/*=====================
  マージン・パディング
======================*/
.mb-sm, .cta__fixed .text, .sugosa__item .sugosa__text dd:nth-of-type(1) {
  margin-bottom: 0.5rem !important;
}

.mb-md, .anata, .anata .text, .nayami__item__text dd:nth-of-type(1), .nayami__item__text dd:nth-of-type(2), .chance__inner02__title, .instructor__item__inner__img, .instructor__item__inner__text01, .instructor__item02__inner__text01, .shikumi__item01__text01, .osusume .item-02__img, .last .item-03 dd:nth-of-type(2), .last .item-03 dd:nth-of-type(3), .circle, .triangle {
  margin-bottom: 1rem !important;
}

.mb-lr, .nayami__image img, .sugosa__item, .chance__inner02__img, .shikumi__item02 .inner__wrap, .osusume, .last .text dd:nth-of-type(1) {
  margin-bottom: 2rem !important;
}

.mb-lg, .fukuri, .fukuri__text, .chance, .chance__inner, .shikumi__textbox-green, .main-title {
  margin-bottom: 3rem !important;
}
@media screen and (min-width: 641px) {
  .mb-lg, .fukuri, .fukuri__text, .chance, .chance__inner, .shikumi__textbox-green, .main-title {
    margin-bottom: 40px !important;
  }
}

.pb-sm {
  padding-bottom: 16px !important;
}

.pb-lg {
  padding-bottom: 80px !important;
}
@media screen and (min-width: 641px) {
  .pb-lg {
    padding-bottom: 50px !important;
  }
}

/*=====================
  フォント
======================*/
@media screen and (max-width: 640px) {
  html {
    font-size: 3.4667vw;
  }
}
html {
  scroll-behavior: smooth;
}

.font-ss {
  font-size: 0.7rem;
  line-height: 1.8rem;
}
@media screen and (min-width: 641px) {
  .font-ss {
    font-size: 14px;
  }
}

.font-sm, .header .wrap .head-btn, .anata__ul li, .nayami .nayami__text p, .fukuri__text, .sugosa__item .sugosa__text dd:nth-of-type(2), .chance__inner02__text dd, .shikumi__item01__text01 dd:nth-of-type(1), .shikumi__item02 .inner ul li, .shikumi__item02 .inner .cont_03 dd:nth-of-type(2), .shikumi__item02 .inner .cont_03 dd:nth-of-type(3), .shikumi__item02 .inner .cont_04 dd:nth-of-type(2), .shikumi__item02 .inner .cont_04 dd:nth-of-type(3), .shikumi__item02 .inner .cont_05 dd:nth-of-type(1), .shikumi__item02 .inner .cont_05 dd:nth-of-type(2), .shikumi__item02 .inner .cont_06 dd:nth-of-type(1), .shikumi .bottom__text dd:nth-of-type(2), .contact .form_input_label, .contact .form_input_radio_label, .contact .checkbox_label {
  font-size: 0.9rem;
  line-height: 2rem;
  font-weight: 500;
}
@media screen and (min-width: 641px) {
  .font-sm, .header .wrap .head-btn, .anata__ul li, .nayami .nayami__text p, .fukuri__text, .sugosa__item .sugosa__text dd:nth-of-type(2), .chance__inner02__text dd, .shikumi__item01__text01 dd:nth-of-type(1), .shikumi__item02 .inner ul li, .shikumi__item02 .inner .cont_03 dd:nth-of-type(2), .shikumi__item02 .inner .cont_03 dd:nth-of-type(3), .shikumi__item02 .inner .cont_04 dd:nth-of-type(2), .shikumi__item02 .inner .cont_04 dd:nth-of-type(3), .shikumi__item02 .inner .cont_05 dd:nth-of-type(1), .shikumi__item02 .inner .cont_05 dd:nth-of-type(2), .shikumi__item02 .inner .cont_06 dd:nth-of-type(1), .shikumi .bottom__text dd:nth-of-type(2), .contact .form_input_label, .contact .form_input_radio_label, .contact .checkbox_label {
    font-size: 16px;
  }
}

.font-md, .cta__fixed .text, .fv__cta p, .anata .textbox-green, .chance__inner dd, .chance__inner02__text dd:nth-of-type(2), .instructor__item__inner__text01 dd:nth-of-type(1), .instructor__item02__inner__text01 dd:nth-of-type(1), .shikumi__item01__text01 dd:nth-of-type(n + 2), .shikumi__textbox-green, .shikumi__item02 .inner .cont_03 dd:nth-of-type(1), .shikumi__item02 .inner .cont_04 dd:nth-of-type(1), .osusume .item-02__text dd:nth-of-type(n + 1):nth-of-type(-n + 3), .osusume .item-02__text02 dd:nth-of-type(1), .circle p, .str-green p {
  font-size: 1.2rem;
}
@media screen and (min-width: 641px) {
  .font-md, .cta__fixed .text, .fv__cta p, .anata .textbox-green, .chance__inner dd, .chance__inner02__text dd:nth-of-type(2), .instructor__item__inner__text01 dd:nth-of-type(1), .instructor__item02__inner__text01 dd:nth-of-type(1), .shikumi__item01__text01 dd:nth-of-type(n + 2), .shikumi__textbox-green, .shikumi__item02 .inner .cont_03 dd:nth-of-type(1), .shikumi__item02 .inner .cont_04 dd:nth-of-type(1), .osusume .item-02__text dd:nth-of-type(n + 1):nth-of-type(-n + 3), .osusume .item-02__text02 dd:nth-of-type(1), .circle p, .str-green p {
    font-size: 20px;
  }
}

.font-lr, .cta__fixed .btn-fix, .chance__inner02__title, .shikumi .bottom__text dd:nth-of-type(1), .osusume .box30 .box-title, .osusume .item-02__text02 dd:nth-of-type(2), .contact .content_title, .str-green04 {
  font-size: 1.5rem;
}
@media screen and (min-width: 641px) {
  .font-lr, .cta__fixed .btn-fix, .chance__inner02__title, .shikumi .bottom__text dd:nth-of-type(1), .osusume .box30 .box-title, .osusume .item-02__text02 dd:nth-of-type(2), .contact .content_title, .str-green04 {
    font-size: 22px;
  }
}

.font-lg, .sugosa__item .sugosa__text dd:nth-of-type(1), .sub-title {
  font-size: 1.8rem;
}
@media screen and (min-width: 641px) {
  .font-lg, .sugosa__item .sugosa__text dd:nth-of-type(1), .sub-title {
    font-size: 26px;
  }
}

.yellow {
  color: #ffed5a;
}

.yellow-bold {
  color: #ffed5a;
  font-weight: bold;
  font-size: 1.4rem;
}
@media screen and (min-width: 641px) {
  .yellow-bold {
    font-size: 22px;
  }
}

.yellow-bold-02, .nayami__item__text dd:nth-of-type(2) {
  color: #ffed5a;
  font-weight: bold;
  font-size: 1.3rem;
}

.bold14-white {
  color: white;
  font-weight: bold;
  font-size: 1.4rem;
}
@media screen and (min-width: 641px) {
  .bold14-white {
    font-size: 22px;
  }
}

.main-title {
  position: relative;
  font-size: 2rem;
  font-weight: 600;
  text-align: center;
  line-height: 2.8rem;
}
.main-title :before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -1.2rem; /*線の上下位置*/
  display: inline-block;
  width: 5rem; /*線の長さ*/
  height: 2px; /*線の太さ*/
  transform: translateX(-50%); /*位置調整*/
  background-color: #208180; /*線の色*/
  border-radius: 0px; /*線の丸み*/
}

.main-title-str {
  font-size: 2.5rem;
  font-weight: 600;
  text-align: center;
  color: #208180;
}

.str-green p {
  font-weight: 600;
  text-align: left;
  color: #208180;
  margin-bottom: 0.5rem;
}

.sub-title {
  margin-bottom: 1rem;
}

.str-green02 {
  color: #208180;
  font-weight: bold;
  background-color: #a8d2d1;
}

.str-green03 {
  color: #208180;
}

.str-green04 {
  color: #208180;
  font-weight: bold;
}

.yellow-underline {
  background: linear-gradient(transparent 90%, #ffed5a 90%);
  display: inline-block;
}

.dot {
  background-position: top left 0px;
  background-repeat: repeat-x;
  background-size: 1em 0.3em;
  background-image: radial-gradient(0.15em 0.15em at center center, #208180, #208180 100%, transparent, transparent);
  padding-top: 0.6em;
}

/*=====================
  other
======================*/
a.rollover:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha( opacity=70 )";
}

.rollover:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha( opacity=70 )";
}

a {
  text-decoration: none;
}

.flex, .sugosa__item .sugosa__wtrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.hr-dotted {
  border: none;
  border-top: 2px dotted black;
}

.hr-dashed {
  border: none;
  border-top: 2px dashed #208180;
}

.triangle {
  background: #208180;
  height: 17.3205080757px;
  width: 20px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  margin: 0 auto;
  top: 0;
}

.circle {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: #ffebad;
  margin: 0 auto;
}
.circle p {
  text-align: center;
  line-height: 100px;
}

.circle-02 {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: #208180;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.2rem;
  font-weight: bold;
  margin: 0 auto 2rem;
}

.header .wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header .wrap .logo {
  width: 40%;
}
.header .wrap .head-btn {
  background-image: linear-gradient(#729d96, #208080);
  padding: 1rem;
  color: white;
  font-weight: bold;
}
@media screen and (min-width: 641px) {
  .header .wrap {
    max-width: 1440px;
    margin: 0 auto;
  }
  .header .wrap .head-btn {
    padding: 10px 20px;
  }
}

/* スマホ（デフォルト） */
.cta__fixed {
  position: fixed;
  width: 100%;
  bottom: 0;
  right: 0;
  display: inline-block;
  padding: 1rem 1.5rem;
  background-color: rgba(255, 255, 255, 0.9);
  color: #fff;
  z-index: 10;
  text-align: center;
  line-height: 1.5rem;
}
.cta__fixed .text {
  color: black;
}
.cta__fixed .btn-fix {
  color: white;
  font-weight: bold;
  background-image: linear-gradient(#ff9900, #ff7c0a);
  border: none;
  border-radius: 3rem;
  padding: 1.5rem;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
}
.cta__fixed .btn-fix a {
  color: white !important;
}
@media screen and (min-width: 641px) {
  .cta__fixed {
    position: fixed;
    bottom: 2rem;
    right: 0;
    display: inline-block;
    padding: 20px 25px;
    background-color: white;
    color: #fff;
    font-size: 0.8rem;
    text-decoration: none;
    border-radius: 1rem 0px 0px 1rem;
    border: 4px solid #208180;
    border-right: none; /* 右側だけ消す */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
    z-index: 10;
    text-align: center;
    line-height: 1.5rem;
    width: 250px;
  }
  .cta__fixed .text {
    font-size: 16px;
    line-height: 1.1rem;
  }
  .cta__fixed .btn-fix {
    font-size: 18px;
    background-image: linear-gradient(#ff9900, #ff7c0a);
    border-radius: 10px;
    padding: 10px;
    line-height: 1.2rem;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
  }
}

.fv {
  text-align: center;
}
@media screen and (min-width: 641px) {
  .fv__cta {
    padding-top: px;
    padding-bottom: 10px;
  }
}
.fv__cta p {
  margin: 1rem 0 0.5rem 0;
  font-weight: bold;
}
.fv__cta img {
  margin: 0 auto;
}
@media screen and (min-width: 641px) {
  .fv__cta img {
    width: 380px;
  }
}
@media screen and (min-width: 641px) {
  .fv .top {
    position: relative;
    width: 100%;
    aspect-ratio: 16/5;
    max-height: 450px;
    background: url(../images/fv-bg.jpg) no-repeat center/cover;
    overflow: hidden;
    height: 50%;
  }
  .fv .top .inner {
    position: relative;
    width: 100%;
    height: 100%;
    max-width: 1440px;
    margin: 0 auto;
    /* 左の画像 */
    /* 右の画像 */
  }
  .fv .top .inner .fv__img {
    position: absolute;
    max-width: 40%; /* 画面幅に対する割合で拡縮 */
    height: auto;
  }
  .fv .top .inner .fv__img--left {
    top: 10%;
    left: 10%;
  }
  .fv .top .inner .fv__img--right {
    top: 8%;
    right: 8%;
  }
}

.test img {
  margin: 0 auto;
}

.anata {
  position: relative;
}
.anata__ul {
  position: absolute;
  z-index: 1;
  top: 23%;
  left: 5%;
}
@media screen and (min-width: 641px) {
  .anata__ul {
    top: 26%;
    left: 17%;
  }
}
.anata__ul li {
  line-height: 1.3rem;
  background: url("../images/cm.png") no-repeat left top -0.5rem/1.462rem;
  padding-left: 1.846rem;
  padding-right: 1rem;
  padding-bottom: 1.2rem;
  list-style: none;
}
.anata .textbox-green {
  background-color: #208180;
  width: 93%;
  height: 14%;
  position: absolute;
  bottom: 12%;
  left: 3.5%;
  padding: 0.5rem;
  color: white;
  text-align: center;
  line-height: 1.7rem;
}
@media screen and (min-width: 641px) {
  .anata {
    position: static;
    background: url(../images/img-1-bg.jpg) no-repeat center/cover;
    background-position: bottom;
    height: 430px;
    padding-bottom: 80px;
  }
  .anata .img-title {
    margin-bottom: 20px;
  }
  .anata .img-title img {
    margin: 0 auto;
    width: 250px;
    padding-top: 25px;
  }
  .anata .wrap {
    display: flex;
    justify-content: center;
    flex-direction: row-reverse;
    margin: 0 auto 10px;
  }
  .anata .right {
    width: 300px;
    margin-top: -20px;
  }
  .anata__ul {
    position: static;
    width: 535px;
  }
  .anata__ul li {
    padding-bottom: 17px;
  }
  .anata .textbox-green {
    position: static;
    margin: 0 auto;
    width: 630px;
    padding: 10px;
  }
}

.nayami {
  margin-bottom: 5rem;
  position: relative;
  margin-bottom: 5rem;
}
.nayami::after {
  content: "";
  position: absolute;
  display: block;
  top: 69%;
  right: 0;
  width: 100%;
  height: 33%;
  background-color: #208180;
  z-index: -1;
}
@media screen and (min-width: 641px) {
  .nayami::after {
    top: 550px;
    height: 450px;
  }
}
.nayami__image img {
  margin: 0 auto;
  width: 50%;
}
.nayami__item__text dd:nth-of-type(1) {
  color: white;
}
.nayami__item__text dd:nth-of-type(3) {
  color: white;
}
@media screen and (min-width: 641px) {
  .nayami .wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
  }
  .nayami .nayami__image img {
    width: 230px;
    margin-right: 40px;
  }
  .nayami .nayami__text p {
    line-height: 1.5em;
  }
  .nayami .nayami__image02 img {
    width: 800px;
    margin: 0 auto;
  }
  .nayami .nayami__text {
    width: 600px;
  }
  .nayami .nayami__item__text {
    width: 760px;
    text-align: center;
    margin: 0 auto;
  }
  .nayami .nayami__image03 img {
    width: 600px;
    margin: 0 auto;
  }
}

@media screen and (min-width: 641px) {
  .fukuri__text {
    text-align: center;
  }
}

.sugosa {
  margin-bottom: 3rem;
  background: url("../images/bg-s1.jpg") no-repeat;
  padding: 3rem 0 2rem;
}
.sugosa__item {
  background-color: white;
  box-shadow: 0px 0px 15px 0px rgba(255, 155, 0, 0.3);
}
.sugosa__item .sugosa__wtrap {
  padding: 1rem;
}
.sugosa__item .sugosa__img {
  flex-basis: 40%;
}
.sugosa__item .sugosa__text {
  flex-basis: 60%;
  text-align: center;
}
.sugosa__item .sugosa__text dd:nth-of-type(1) {
  color: #208180;
  font-weight: bold;
}
.sugosa__item .sugosa__text dd:nth-of-type(2) {
  line-height: 1.4rem;
}
@media screen and (min-width: 641px) {
  .sugosa {
    background: url("../images/bg-1.jpg") no-repeat center/cover;
  }
  .sugosa__inner {
    display: flex;
    justify-content: center; /* 両端は固定、間は均等 */
    gap: 40px; /* 要素同士の隙間を指定 */
  }
  .sugosa__inner .sugosa__wtrap {
    display: block;
    padding: 30px;
  }
  .sugosa__inner .sugosa__wtrap img {
    width: 150px;
    margin: 0 auto 10px;
  }
}

.chance {
  text-align: center;
  position: relative;
}
.chance hr {
  margin: 1rem 0;
}
.chance__inner02::after {
  content: "";
  position: absolute;
  display: block;
  top: 60%;
  right: 0;
  width: 100%;
  height: 44%;
  background-color: #ffffff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='12' viewBox='0 0 20 12'%3E%3Cg fill-rule='evenodd'%3E%3Cg id='charlie-brown' fill='%23e0e0e0' fill-opacity='0.4'%3E%3Cpath d='M9.8 12L0 2.2V.8l10 10 10-10v1.4L10.2 12h-.4zm-4 0L0 6.2V4.8L7.2 12H5.8zm8.4 0L20 6.2V4.8L12.8 12h1.4zM9.8 0l.2.2.2-.2h-.4zm-4 0L10 4.2 14.2 0h-1.4L10 2.8 7.2 0H5.8z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  z-index: -1;
  -webkit-mask-image: linear-gradient(to top, rgb(0, 0, 0), rgba(0, 0, 0, 0));
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: cover;
}
.chance__inner02__title {
  color: #208180;
  font-weight: bold;
}
.chance .hr-dashed {
  margin-bottom: 1.5rem;
}
.chance__inner02__text {
  text-align: left;
  text-align: justify;
}
.chance__inner02__text dd:nth-of-type(2) {
  color: #ff7c0a;
  margin: 1rem 0;
}
@media screen and (min-width: 641px) {
  .chance .hr-dotted {
    display: none;
  }
  .chance__inner {
    /* 区切り線（二重線を擬似要素で描画） */
    /* 2本目の線（少し内側にずらす） */
  }
  .chance__inner .splits {
    display: flex;
    justify-content: space-between;
    align-items: stretch; /* 高さをそろえる */
  }
  .chance__inner .item {
    flex: 1;
    padding: 1rem;
    position: relative;
    text-align: center;
    box-sizing: border-box;
  }
  .chance__inner .item:not(:last-child)::after,
  .chance__inner .item:not(:last-child)::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0; /* 親要素の高さに追従して縦いっぱい */
    right: 0;
    width: 2px; /* 線の太さ */
    background: #333;
  }
  .chance__inner .item:not(:last-child)::before {
    right: 6px; /* ← 線の間隔を調整できる */
  }
  .chance__inner02__title {
    display: none;
  }
  .chance__inner02__img img {
    margin: 0 auto;
  }
  .chance__inner02__text {
    text-align: center;
  }
}

.instructor {
  padding: 3rem 0;
  background: url("../images/bg-s3.jpg") no-repeat center/cover;
}
.instructor .first {
  margin-bottom: 2rem;
}
@media screen and (min-width: 641px) {
  .instructor {
    background: url("../images/bg-3.jpg") no-repeat center/cover;
  }
}

.instructor__item {
  background-color: #208180;
  width: 90%;
  margin: 0 auto;
  border-radius: 1rem;
  padding-bottom: 2rem;
}
.instructor__item__inner {
  margin: 0 auto;
  padding: 2rem;
}
.instructor__item__inner__text01 {
  position: relative;
}
.instructor__item__inner__text01 dd:nth-of-type(1) {
  color: white;
  position: absolute;
  z-index: 1;
  top: 14%;
  left: 8%;
  font-weight: bold;
}
.instructor__item__inner__text01 dd:nth-of-type(2) {
  position: absolute;
  z-index: 1;
  bottom: 8%;
  left: 7%;
  color: #208180;
}
.instructor__item__inner__text02 {
  color: white;
}
@media screen and (min-width: 641px) {
  .instructor__item {
    width: 100%;
  }
  .instructor__item__inner .wrap {
    display: flex;
    justify-content: left;
    gap: 30px;
  }
  .instructor__item__inner .wrap .instructor__item__inner__img {
    width: 400px;
  }
  .instructor__item__inner .wrap .instructor__item__inner__img02 {
    width: 350px;
  }
  .instructor__item__inner .wrap dd:nth-of-type(1) {
    top: 24px;
    left: 32px;
  }
  .instructor__item__inner .wrap dd:nth-of-type(2) {
    top: 60px;
    left: 29px;
  }
}

.instructor__item02__inner__text01 {
  position: relative;
}
.instructor__item02__inner__text01 dd:nth-of-type(1) {
  color: white;
  position: absolute;
  z-index: 1;
  top: 22%;
  left: 8%;
  font-weight: bold;
}
.instructor__item02__inner__text01 dd:nth-of-type(2) {
  position: absolute;
  z-index: 1;
  bottom: 12%;
  left: 7%;
  color: #208180;
}

.shikumi {
  margin: 0 auto 2rem;
  background: url("../images/bg-s2.jpg") no-repeat;
  padding: 3rem 0;
}
.shikumi__item01__text01 {
  text-align: center;
  line-height: 2.5rem;
}
.shikumi__item01__text01 dd:nth-of-type(n + 2) {
  font-weight: bold;
}
.shikumi__textbox-green {
  background-color: #208180;
  width: 90%;
  margin: 0 auto;
  height: 14%;
  padding: 0.5rem;
  color: white;
  text-align: center;
  line-height: 1.7rem;
}
@media screen and (min-width: 641px) {
  .shikumi__textbox-green {
    width: 700px;
  }
}
@media screen and (min-width: 641px) {
  .shikumi {
    background: url("../images/bg-2.jpg") no-repeat center;
    background-position: top;
  }
}

.shikumi__item02 .inner {
  background-color: white;
  outline: 3px solid #208180; /* 線の太さ・線状・色 */
  outline-offset: -1rem; /* どれだけ内側に線を表示したいかを負の値で指定 */
  margin: 0 auto;
  width: 90%;
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner {
    width: 760px;
  }
}
.shikumi__item02 .inner .wrapper {
  position: relative;
  width: 100%;
}
.shikumi__item02 .inner .wrapper .bg {
  width: 10rem;
  right: 0;
  left: 0;
  margin: 0 auto;
  border-top: 2.5rem solid #208180;
  border-left: 1rem solid transparent;
  border-right: 1rem solid transparent;
}
.shikumi__item02 .inner .wrapper .image {
  position: absolute;
  top: 10%;
  left: 40%;
  width: 100%;
  height: auto;
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner .wrapper .image {
    width: 450px;
    top: 5px;
    left: 333px;
  }
}
.shikumi__item02 .inner .wrapper .image img {
  display: block;
  width: 20%;
  height: auto;
}
.shikumi__item02 .inner__wrap {
  padding: 2rem;
}
.shikumi__item02 .inner .cont_02 {
  position: relative;
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner .cont_02 dd:nth-of-type(2) {
    margin: 0 auto;
    width: 400px;
  }
}
.shikumi__item02 .inner ul {
  position: absolute;
  z-index: 1;
  bottom: 15%;
  left: 3%;
}
.shikumi__item02 .inner ul li {
  line-height: 1.3rem;
  background: url("../images/cm02.png") no-repeat left top -0.4rem/1.462rem;
  padding-left: 1.846rem;
  padding-right: 0.5rem;
  padding-bottom: 0.6rem;
  list-style: none;
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner ul {
    bottom: 83px;
    left: 59px;
  }
}
.shikumi__item02 .inner .cont_03 {
  position: relative;
}
.shikumi__item02 .inner .cont_03 dd:nth-of-type(1) {
  position: absolute;
  padding: 1.5rem;
  color: #ffed5a;
  line-height: 1.5rem;
  font-weight: bold;
  text-align: center;
  z-index: 1;
  top: 29%;
  right: 0;
  left: 0;
  margin: 0 auto;
}
.shikumi__item02 .inner .cont_03 dd:nth-of-type(2) {
  position: absolute;
  color: #208180;
  z-index: 1;
  bottom: 28%;
  left: 45%;
}
.shikumi__item02 .inner .cont_03 dd:nth-of-type(3) {
  position: absolute;
  padding: 1.5rem;
  color: white;
  line-height: 1.5rem;
  text-align: center;
  z-index: 1;
  bottom: 1%;
  right: 0;
  left: 0;
  margin: 0 auto;
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner .cont_03 dd:nth-of-type(1) {
    top: 74px;
  }
  .shikumi__item02 .inner .cont_03 dd:nth-of-type(2) {
    top: 172px;
    left: 326px;
  }
  .shikumi__item02 .inner .cont_03 dd:nth-of-type(3) {
    top: 197px;
    left: 0px;
  }
}
.shikumi__item02 .inner .cont_04 {
  position: relative;
}
.shikumi__item02 .inner .cont_04 dd:nth-of-type(1) {
  position: absolute;
  padding: 1.5rem;
  color: #ffed5a;
  line-height: 1.5rem;
  font-weight: bold;
  text-align: center;
  z-index: 1;
  top: 24%;
  right: 0;
  left: 0;
  margin: 0 auto;
}
.shikumi__item02 .inner .cont_04 dd:nth-of-type(2) {
  position: absolute;
  color: #208180;
  z-index: 1;
  bottom: 35%;
  left: 45%;
}
.shikumi__item02 .inner .cont_04 dd:nth-of-type(3) {
  position: absolute;
  padding: 1.5rem;
  color: white;
  line-height: 1.5rem;
  text-align: center;
  z-index: 1;
  bottom: 18%;
  right: 0;
  left: 0;
  margin: 0 auto;
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner .cont_04 dd:nth-of-type(1) {
    top: 65px;
  }
  .shikumi__item02 .inner .cont_04 dd:nth-of-type(2) {
    top: 166px;
    left: 325px;
  }
  .shikumi__item02 .inner .cont_04 dd:nth-of-type(3) {
    top: 193px;
    left: 0px;
  }
  .shikumi__item02 .inner .cont_04 dd:nth-of-type(4) {
    margin: 0 auto;
    width: 400px;
  }
}
.shikumi__item02 .inner .cont_05 {
  position: relative;
}
.shikumi__item02 .inner .cont_05 dd:nth-of-type(1) {
  position: absolute;
  padding: 2rem;
  line-height: 1.5rem;
  z-index: 1;
  top: 23%;
  right: 0;
  left: 0;
  margin: 0 auto;
}
.shikumi__item02 .inner .cont_05 dd:nth-of-type(2) {
  position: absolute;
  padding: 2rem;
  line-height: 1.5rem;
  z-index: 1;
  bottom: 2.8%;
  right: 0;
  left: 0;
  margin: 0 auto;
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner .cont_05 dd:nth-of-type(1) {
    top: 125px;
    left: -338px;
    width: 300px;
  }
  .shikumi__item02 .inner .cont_05 dd:nth-of-type(2) {
    top: 125px;
    right: -338px;
    width: 300px;
  }
}
.shikumi__item02 .inner .cont_06 {
  position: relative;
}
.shikumi__item02 .inner .cont_06 dd:nth-of-type(1) {
  position: absolute;
  padding: 1rem;
  line-height: 1.5rem;
  z-index: 1;
  top: 50%;
  right: 0;
  left: 0;
  margin: 0 auto;
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner .cont_06 dd:nth-of-type(1) {
    top: 170px;
  }
}
@media screen and (min-width: 641px) {
  .shikumi__item02 .inner .ratio:before {
    content: "";
    display: block;
    padding-top: 40%; /* 1:1 */
  }
  .shikumi__item02 .inner .ratio-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}

.shikumi .bottom__text dd:nth-of-type(1) {
  background-color: #208180;
  width: 60%;
  padding: 1rem;
  color: white;
  text-align: center;
  line-height: 1.7rem;
  margin: 0 auto;
  font-weight: bold;
}
@media screen and (min-width: 641px) {
  .shikumi .bottom__text dd:nth-of-type(1) {
    width: 300px;
  }
}
.shikumi .bottom__text dd:nth-of-type(2) {
  text-align: center;
  margin: 0 auto;
}

.osusume .item-01 {
  position: relative;
  margin-bottom: 6rem;
}
.osusume .item-01::after {
  content: "";
  position: absolute;
  bottom: -52%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  background: url("../images/arrow-s1.png") no-repeat center/contain;
  z-index: -1;
}
@media screen and (min-width: 641px) {
  .osusume .item-01::after {
    width: 500px;
  }
}
.osusume .box30 {
  margin: 2em 0;
  background: white;
  box-shadow: 0 0 10px 0.3px rgba(12, 71, 71, 0.3);
  border: 2px solid #208180;
  border-radius: 1rem;
  text-align: center;
}
.osusume .box30 ul {
  display: inline-block;
  text-align: left;
  line-height: 2rem;
  padding: 1rem 0;
  list-style: none;
}
.osusume .box30 li {
  border-bottom: 2px dotted black;
  padding: 0.5em 0; /* テキストと線の間に余白 */
}
.osusume .box30 li:last-child {
  border-bottom: none;
}
.osusume .box30 .box-title {
  background: #208180;
  padding: 1rem 0;
  text-align: center;
  color: #fff;
  font-weight: bold;
  letter-spacing: 0.05em;
  border-radius: 0.7rem 0.7rem 0 0;
}
.osusume .item-02__text dd:nth-of-type(n + 1):nth-of-type(-n + 3) {
  padding: 1rem 0;
  font-weight: bold;
}
.osusume .item-02__text02 dd:nth-of-type(1) {
  color: #208180;
  font-weight: bold;
  text-align: center;
  padding: 1rem 0;
}
.osusume .item-02__text02 dd:nth-of-type(2) {
  background-color: #208180;
  width: 90%;
  padding: 1rem;
  color: white;
  text-align: center;
  line-height: 2rem;
  margin: 0 auto;
  font-weight: bold;
}
@media screen and (min-width: 641px) {
  .osusume .item-02__text02 dd:nth-of-type(2) {
    width: 750px;
  }
}
@media screen and (min-width: 641px) {
  .osusume .wrap {
    display: flex;
    justify-content: center;
    gap: 40px;
  }
  .osusume .wrap .box30 {
    width: 500px;
    margin: 0 auto;
  }
  .osusume .wrap .box30 ul {
    width: 360px;
    margin: 0 auto;
    padding: 20px 0;
  }
}

@media screen and (min-width: 641px) {
  .item02__img02 {
    margin: 0 auto 40px;
    width: 500px;
  }
}
.last {
  position: relative;
  margin-bottom: 5rem;
}
@media screen and (min-width: 641px) {
  .last {
    margin-bottom: 50px;
  }
}
.last::after {
  content: "";
  position: absolute;
  bottom: -2%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  background: url("../images/bg-s4.jpg") no-repeat center/cover;
  z-index: -1;
}
@media screen and (min-width: 641px) {
  .last::after {
    background: url("../images/bg-4.jpg") no-repeat center/cover;
  }
}
.last .item-02 dd {
  width: 90%;
  margin: 2rem auto;
  box-shadow: 0px 0px 15px 0px rgba(12, 71, 71, 0.3);
  border-radius: 20px;
  overflow: hidden;
  padding: 1.2rem;
  background-color: white;
}
@media screen and (min-width: 641px) {
  .last .item-02 dd {
    margin: 20px auto;
  }
}
@media screen and (min-width: 641px) {
  .last .item-02 {
    margin: 20px auto;
  }
}
@media screen and (min-width: 641px) {
  .last .inner {
    width: 1000px;
    margin: 0 auto;
  }
  .last .text {
    text-align: center;
    margin: 0 auto;
  }
  .last .wrap {
    display: flex;
    justify-content: center;
    gap: 40px;
  }
  .last .wrap__item__left {
    width: 550px;
  }
  .last .wrap__item__right {
    width: 350px;
  }
}

.contact {
  background-color: #f5f8fa;
  padding-bottom: 2rem;
  /* フォーム全体を枠で囲む */
  /* ラベル部分 */
  /* フォーカス時 */
  /* ラジオ・チェックボックスの間隔 */
  /* 送信ボタン */
  /* テキスト入力欄 */
  /* 上段のチェックボックスをカスタムデザイン */
  /* 下段のチェックボックスをカスタムデザイン */
  /* チェックのマーク（白丸を中央に出す） */
}
.contact .content_title {
  background-color: #208180;
  width: 95%;
  padding: 1rem;
  color: white;
  text-align: center;
  line-height: 2rem;
  margin: 0 auto;
  font-weight: bold;
}
@media screen and (min-width: 641px) {
  .contact .content_title {
    width: 450px;
    margin: 40px auto;
  }
}
.contact .content_form {
  max-width: 760px; /* 適度な横幅に制限 */
  margin: 2rem auto 0;
  padding: 1.5rem;
  border-radius: 8px;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
  background-color: white;
}
@media screen and (min-width: 641px) {
  .contact .content_form {
    padding: 40px;
  }
}
.contact .form_input_label {
  color: black;
  margin-bottom: 0rem;
  display: inline-block;
  margin-right: 20px;
}
.contact .my_column {
  padding-bottom: 0 !important;
}
.contact input[type=text]:focus,
.contact input[type=email]:focus,
.contact input[type=tel]:focus,
.contact textarea:focus {
  outline: none;
  border-color: #4caf50;
  background: #ffffff;
}
.contact .radiobutton_frame,
.contact .checkbox_frame {
  margin-bottom: 0.5rem;
}
.contact .required_color {
  background-color: white !important;
  border: 0px solid #ededed !important;
}
.contact .form_input_radio_label {
  line-height: 1.5rem;
}
.contact .form.myForm input[type=radio] {
  top: 5rem;
}
.contact .form_input_submit input[type=submit] {
  display: block;
  width: 50%;
  background: #ff7c0a;
  color: #fff;
  border: none;
  padding: 0.8rem;
  font-size: 1.1rem;
  font-weight: bold;
  border-radius: 50px;
  cursor: pointer;
  transition: background 0.3s;
}
.contact .form_input_submit input[type=submit]:hover {
  background: white;
  border: 2px solid #ff7c0a;
  color: #ff7c0a;
}
.contact input[type=text],
.contact input[type=email],
.contact input[type=tel],
.contact textarea {
  background-color: white !important;
  border: 1px solid #ededed !important;
  padding: 0.5rem !important;
  border-radius: 4px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.contact input[type=radio] {
  vertical-align: middle;
}
.contact input[type=checkbox] {
  appearance: none; /* デフォルトの見た目を消す */
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 20px;
  height: 20px;
  border: 1px solid black;
  border-radius: 50%; /* 丸型にする */
  background-color: white;
  cursor: pointer;
  display: inline-block;
  vertical-align: middle;
  position: relative;
}
.contact input[type=checkbox]:checked::after {
  content: "";
  position: absolute;
  width: 65%;
  height: 65%;
  padding: 0;
  background: #006fff;
  border-radius: 50%;
  top: 17.5%;
  left: 17.6%;
}

.footer {
  text-align: center;
  padding: 2rem 0 11rem 0;
  margin-top: 0px;
  background-color: #f5f8fa;
}
@media screen and (min-width: 641px) {
  .footer {
    padding: 2rem 0 2rem 0;
  }
}
.footer a {
  color: #000;
  text-decoration: none;
}
.footer a:hover {
  text-decoration: underline;
}
.footer .menu {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
.footer .menu li {
  margin: 0;
  padding: 0 20px;
}
.footer .copyright {
  margin: 0;
  padding: 20px 0 0 0;
}

.menu li {
  padding: 0 20px;
  font-size: 16px;
}

.menu li:nth-child(2) {
  border-left: 1px solid #000;
}

.menu li:nth-child(3) {
  border-left: 1px solid #000;
}

.copyright {
  text-align: center;
}/*# sourceMappingURL=style.css.map */