@charset "UTF-8";
/* CSS Document */
a,
input,
select,
textarea,
button,
a object,
a > span,
a img,
*:before,
*:after,
button span {
  -webkit-transition: all 300ms ease;
  transition: all 300ms ease;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
@media screen and (max-width: 768px) {
  body,
  main,
  header,
  footer {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }
}
/*-----header-----*/
#header {
  width: 100%;
  height: auto;
  background: var(--C-dark_blue);
}
header .head-logo {
  width: 196px;
  height: auto;
  margin: 0 auto 0 20px;
  padding: 8px 0 4px;
}
header .inner.flex-box {
  align-items: center;
}
header .top-copy {
  color: #fff;
  font-size: 16px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  header .head-logo {
    width: 38%;
    height: auto;
    margin: 0 auto 0 0;
    padding: 2% 0 1%;
  }
}
/*-----共通-----*/
img {
  display: block;
  margin: 0;
  max-width: 100%;
}
.txt_rl {
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
}
.w60p {
  width: 60%;
}
.w40p {
  width: 40%;
}
.w30p {
  width: 30%;
}
.w15p {
  width: 15%;
}
.txt_cRed {
  color: #ac0d22 !important;
}

@media screen and (max-width: 768px) {
  .w100p-sp {
    width: 100% !important;
  }
  .w60p-sp {
    width: 60% !important;
  }
  .w50p-sp {
    width: 50% !important;
  }
  .w40p-sp {
    width: 40% !important;
  }
}

/*-----mv-----*/
#mv img {
  width: 100%;
}

/* point */
#point {
  background-size: 100% 100px;
}
#point .inner {
  padding: 0 0 43px;
}
#point .inner .ttl {
  width: 100%;
  height: 154px;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 0.14em;
  color: #fff;
  text-align: center;
  background: url(../img/point_bg.svg) no-repeat center bottom;
  background-size: cover;
  padding: 43px 0 0;
}
#point .inner .ttl span {
  position: relative;
}
#point .inner .ttl span::after {
  content: "";
  background-color: #f1c042;
  width: 100%;
  height: 4px;
  position: absolute;
  bottom: -3px;
  left: 0;
}
#point .inner .point_list {
  width: 960px;
  max-width: 100%;
  margin: -30px auto 0;
}
#point .inner .point_list .point_item img {
  filter: drop-shadow(2px 7px 5px rgba(155, 155, 155, 0.55));
}
@media screen and (max-width: 960px) {
  #point .inner .point_list .point_item {
    width: 31.979vw;
  }
}
@media screen and (max-width: 768px) {
  #point .inner .ttl {
    height: 24.68vw;
    font-size: 5.7593vw;
    padding: 7.4687vw 0 0;
  }
  #point .inner .ttl span::after {
    height: 0.87031vw;
  }
  #point .inner .point_list {
    justify-content: center;
    gap: 4vw;
    margin: -3vw auto 0;
  }
  #point .inner .point_list .point_item {
    width: 73vw;
  }
  #point .inner .point_list .point_item img {
    margin: auto;
  }
}
/* class */
#class {
  min-height: 769px;
  background: url(../img/bg01.webp) no-repeat center;
  background-size: cover;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: 22px solid #f1c042;
}

#class .class_list {
  width: 870px;
  max-width: 100%;
  margin: auto;
}

@media screen and (max-width: 870px) {
  #class .class_list {
    width: 100%;
    justify-content: space-around;
    gap: 10px;
  }
  #class .class_list .class_item {
    width: calc(50% - 5px);
  }
}
@media screen and (max-width: 768px) {
  #class {
    height: auto;
    background: #f1c042 url(../img/bg01.webp) no-repeat center top;
    background-size: 168% auto;
    padding: 11.35937vw 0;
    border: none;
  }
  #class .class_list {
    width: 82.03125vw;
    justify-content: center;
    gap: 6vw;
  }
  #class .class_list .class_item {
    width: auto;
  }
}

/*-----price-----*/
#price {
  background-image: linear-gradient(#e9ede5 17%, #fbfcfa 61%, #e4eae0);
}
#price .inner {
  padding: 50px 0 100px 0;
}
#price .ttl {
  display: flex;
  justify-content: center;
}
/* .table-wrap {
  overflow-y: auto;
} */
.c-grid--middle {
  width: 790px;
  max-width: 1000px;
  /* max-width: 1140px; */
  text-align: left;
  margin: 0 auto;
}
.c-table {
  border-top: none;
}
.c-table th,
.c-table td {
  font-size: 1.5rem;
}
.note {
  font-size: 1.3rem;
  line-height: 1.6;
  color: #5f5f5f;
  counter-reset: note;
}
.note li {
  display: flex;
  margin-bottom: 0.5em;
  counter-increment: note;
}
.note li::before {
  content: "※" counter(note);
  margin-right: 0.5em;
}
@media screen and (max-width: 768px) {
  #price .inner {
    padding: 10.46875vw 0 10vw 0;
  }
  #price .ttl img {
    width: 64.84375vw;
  }
  .c-grid--middle {
    width: 82.03125vw;
    max-width: none;
  }
  .c-table {
    width: 790px;
  }

  .note li {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 480px) {
  .c-table th,
  .c-table td {
    font-size: 3.5vw;
  }
}
/*-----フッター-----*/
footer {
  width: 100%;
  padding-top: 50px;
  background: #fff;
  border-top: 1px solid #d9d9d9;
}

.footernavi {
  margin: 0 auto 50px;
}
.footernavi li {
  display: inline;
  float: left;
}
.footernavi li a,
.footernavi li a:visited {
  color: #43464b;
}
.footernavi li.logo {
  width: 250px;
  height: auto;
  margin-left: 70px;
  margin-right: 40px;
  text-decoration: none;
}
.footernavi li.navi {
  margin-right: 40px;
  font-size: 14px;
  color: #43464b;
  text-decoration: none;
}

.copyright {
  width: 100%;
  height: auto;
  padding: 20px 0;
  /* box-shadow */
  box-shadow: 0px 0px 20px 4px #dfdfdf;
  -moz-box-shadow: 0px 0px 20px 4px #dfdfdf;
  -webkit-box-shadow: 0px 0px 20px 4px #dfdfdf;
}
.copyright p {
  font-size: 12px;
  color: #43464b;
  text-align: right;
}
@media screen and (max-width: 768px) {
  footer {
    width: 100%;
    padding-top: 10%;
    background: #fff;
    border-top: 1px solid #d9d9d9;
  }

  .footernavi {
    margin: 0 auto 10%;
  }
  .footernavi li {
    display: inline;
    float: left;
  }
  .footernavi li a,
  .footernavi li a:visited {
    color: #43464b;
  }
  .footernavi li.logo {
    width: 65%;
    height: auto;
    margin-left: 0;
    margin-right: 35%;
    margin-bottom: 3%;
    text-decoration: none;
    float: left;
  }
  .footernavi li.navi {
    margin-top: 2%;
    margin-right: 6%;
    font-size: 1.2em;
    color: #43464b;
    text-decoration: none;
  }

  .copyright {
    width: 100%;
    height: auto;
    padding: 20px 0;
    /* box-shadow */
    box-shadow: 0 0 1% 1% #dfdfdf;
    -moz-box-shadow: 0 0 1% 1% #dfdfdf;
    -webkit-box-shadow: 0 0 1% 1% #dfdfdf;
  }
  .copyright p {
    font-size: 1em;
    color: #43464b;
    text-align: right;
  }
}
