@charset "UTF-8";
/* =========================================================
reset
========================================================= */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@900&family=Poppins:wght@800&display=swap");
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,500,700,900&display=swap&subset=japanese");
@import url("https://fonts.googleapis.com/css?family=Roboto:500&display=swap");
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a,
abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike,
strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figure, figcaption,
footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

a {
  -webkit-text-decoration: normal;
          text-decoration: normal;
  cursor: pointer;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

input, select {
  vertical-align: middle;
}

input[type="submit"] {
  -webkit-appearance: none;
  border-radius: 0;
}

/* =========================================================
Web fonts
========================================================= */
/* =========================================================
base
========================================================= */
html {
  font-size: 62.5%;
}

html, body {
  width: 100%;
  height: auto;
}

body {
  letter-spacing: 0;
  -webkit-text-size-adjust: 100%;
  background: #fff;
  font-family: "Noto Sans JP", sans-serif, "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #2c2c2c;
  line-height: 1.625;
  min-width: 1200px;
}
@media screen and (max-width: 767px) {
  body {
    font-size: calc(26/750 * 100vw);
    line-height: 1.53;
    min-width: 100%;
  }
}

.tac {
  text-align: center;
}

.ttl-item {
  font-size: 0;
}

.pink-txt {
  color: #e65e5e;
  font-weight: 700;
}

/* =========================================================
common-box
========================================================= */
.common-box {
  width: 900px;
  display: flex;
  padding-bottom: 62px;
}
@media screen and (max-width: 767px) {
  .common-box {
    width: 100%;
    flex-direction: column;
    padding-bottom: calc(66/750 * 100vw);
  }
}

.common-box-txt {
  margin-right: 25px;
  width: 495px;
}
@media screen and (max-width: 767px) {
  .common-box-txt {
    width: 100%;
    margin-right: 0;
    padding-bottom: calc(50/750 * 100vw);
  }
}

.common-box-img {
  width: 380px;
  font-size: 0;
}
@media screen and (max-width: 767px) {
  .common-box-img {
    width: calc(541/750 * 100vw);
    margin: 0 auto;
    padding-left: calc(20/750 * 100vw);
  }
}

.common-box-ttl {
  font-size: 22px;
  font-weight: 600;
  line-height: 1.72;
  padding-bottom: 30px;
}
.common-box-ttl::before {
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 1.72) * .5em);
  content: "";
}
.common-box-ttl::after {
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 1.72) * .5em);
  content: "";
}
@media screen and (max-width: 767px) {
  .common-box-ttl {
    font-size: calc(32/750 * 100vw);
    line-height: 1.25;
    padding-bottom: calc(36/750 * 100vw);
  }
  .common-box-ttl::before {
    display: block;
    width: 0;
    height: 0;
    margin-top: calc((1 - 1.25) * .5em);
    content: "";
  }
  .common-box-ttl::after {
    display: block;
    width: 0;
    height: 0;
    margin-bottom: calc((1 - 1.25) * .5em);
    content: "";
  }
}

@media screen and (max-width: 767px) {
  .service-in-list-item .common-box-ttl {
    text-align: center;
  }
}

.common-box-txt-contents {
  padding-bottom: 20px;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767px) {
  .common-box-txt-contents {
    font-size: calc(26/750 * 100vw);
    padding-bottom: calc(15/750 * 100vw);
  }
}

.common-box-txt-notes {
  font-size: 13px;
}
@media screen and (max-width: 767px) {
  .common-box-txt-notes {
    font-size: calc(18/750 * 100vw);
  }
}

/* =========================================================
target-box
========================================================= */
.target-box {
  border: 2px #4e90c0 solid;
  border-radius: 12px;
  width: 730px;
  margin: 0 auto;
  position: relative;
  padding: 58px 160px 30px 36px;
}
@media screen and (max-width: 767px) {
  .target-box {
    padding: calc(70/750 * 100vw) calc(25/750 * 100vw) calc(245/750 * 100vw);
    width: calc(670/750 * 100vw);
    border: calc(2/750 * 100vw) #4e90c0 solid;
  }
}

@media screen and (max-width: 767px) {
  .service-in-list-wrap .target-box {
    width: calc(630/750 * 100vw);
  }
}

.target-ttl {
  display: block;
  font-size: 0;
  width: 265px;
  height: 68px;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
  .target-ttl {
    width: calc(363/750 * 100vw);
    height: calc(93/750 * 100vw);
  }
}

.target-list-item {
  line-height: 1.375;
  margin-bottom: 12px;
  display: flex;
}
.target-list-item::before {
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 1.375) * .5em);
  content: "";
}
.target-list-item::after {
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 1.375) * .5em);
  content: "";
}
@media screen and (max-width: 767px) {
  .target-list-item {
    font-size: calc(26/750 * 100vw);
    margin-bottom: calc(30/750 * 100vw);
  }
}
.target-list-item:before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 26px;
  margin-right: 10px;
  background: url(../img/target-list-item-icon.png) top 5px left/18px 19px no-repeat;
}
@media screen and (max-width: 767px) {
  .target-list-item:before {
    background: url(../img/target-list-item-icon.png) top calc(14/750 * 100vw) left/calc(18/750 * 100vw) calc(19/750 * 100vw) no-repeat;
    width: calc(18/750 * 100vw);
    height: calc(32/750 * 100vw);
    margin-right: calc(10/750 * 100vw);
  }
}
.target-list-item p {
  width: 500px;
}
@media screen and (max-width: 767px) {
  .target-list-item p {
    width: calc(580/750 * 100vw);
  }
}

.target-list-item-notes p {
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .target-list-item-notes p {
    font-size: calc(18/750 * 100vw);
  }
}

/* =========================================================
service-in-list
========================================================= */
.service-in-list-wrap {
  background: #e1f1fc;
  width: 100%;
  padding: 56px 0 90px;
}
@media screen and (max-width: 767px) {
  .service-in-list-wrap {
    padding: calc(50/750 * 100vw) 0 calc(80/750 * 100vw);
  }
}

.service-in-list {
  width: 980px;
  margin: 0 auto;
  border-radius: 10px;
  border-top: 10px solid #4e90c0;
}
@media screen and (max-width: 767px) {
  .service-in-list {
    border-top: calc(10/750 * 100vw) solid #4e90c0;
    width: calc(670/750 * 100vw);
    border-radius: calc(10/750 * 100vw);
  }
}

.service-in-list-item {
  padding-bottom: 100px;
  background: url(../img/bg_stripe.jpg) center bottom/12px 10px repeat-x, #fff;
}
.service-in-list-item:last-child {
  background: #fff;
  border-radius: 0 0 10px 10px;
}
@media screen and (max-width: 767px) {
  .service-in-list-item:last-child {
    border-radius: 0 0 calc(10/750 * 100vw) calc(10/750 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .service-in-list-item {
    padding-bottom: calc(60/750 * 100vw);
  }
}

.service-in-list-item-inner {
  padding: 32px 40px 0;
}
@media screen and (max-width: 767px) {
  .service-in-list-item-inner {
    padding: calc(32/750 * 100vw) calc(20/750 * 100vw);
  }
}

.service-in-list-ttl-wrap {
  text-align: center;
  padding-bottom: 32px;
  background: url(../img/short_dot.png) center bottom/38px 6px no-repeat;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .service-in-list-ttl-wrap {
    padding-bottom: calc(32/750 * 100vw);
    margin-bottom: calc(50/750 * 100vw);
    background: url(../img/short_dot.png) center bottom/calc(60/750 * 100vw) calc(10/750 * 100vw) no-repeat;
  }
}

.service-in-list-ttl-num {
  width: 109px;
  height: 53px;
  background: url(../img/nom_balloon.png) center center/cover no-repeat;
  margin: 0 auto;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .service-in-list-ttl-num {
    width: calc(143/750 * 100vw);
    height: calc(70/750 * 100vw);
    background: url(../img/nom_balloon_sp.png) center center/cover no-repeat;
  }
}
.service-in-list-ttl-num p {
  font-size: 26px;
  font-weight: 600;
  color: #fff;
  padding-top: 2px;
}
@media screen and (max-width: 767px) {
  .service-in-list-ttl-num p {
    font-size: calc(34/750 * 100vw);
    padding-top: calc(4/750 * 100vw);
  }
}

.service-in-list-ttl {
  color: #4e90c0;
  font-size: 42px;
  font-weight: 600;
  display: inline-block;
  background: linear-gradient(transparent 70%, #ffefb0 70%);
  line-height: 1.2;
  margin-bottom: 14px;
}
@media screen and (max-width: 767px) {
  .service-in-list-ttl {
    font-size: calc(42/750 * 100vw);
    margin-bottom: calc(20/750 * 100vw);
  }
}

.service-in-list-ttl-notes {
  color: #e65e5e;
  font-size: 13px;
  line-height: 1;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .service-in-list-ttl-notes {
    font-size: calc(18/750 * 100vw);
  }
}

.service-in-contents-wrap-ttl {
  text-align: center;
  margin-bottom: 50px;
  background: url(../img/ttl_bg_dbldot.jpg) center center/16px 7px repeat-x;
}
@media screen and (max-width: 767px) {
  .service-in-contents-wrap-ttl {
    margin-bottom: calc(50/750 * 100vw);
    background: url(../img/ttl_bg_dbldot.jpg) center center/calc(16/750 * 100vw) calc(7/750 * 100vw) repeat-x;
  }
}
.service-in-contents-wrap-ttl span {
  font-size: 28px;
  font-weight: bold;
  display: inline-block;
  line-height: 1;
  padding: 0 15px;
  background: #fff;
}
.service-in-contents-wrap-ttl span::before {
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 1) * .5em);
  content: "";
}
.service-in-contents-wrap-ttl span::after {
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 1) * .5em);
  content: "";
}
@media screen and (max-width: 767px) {
  .service-in-contents-wrap-ttl span {
    padding: 0 calc(15/750 * 100vw);
    font-size: calc(32/750 * 100vw);
  }
}

.service-in-contents-list {
  display: flex;
  justify-content: center;
  width: 900px;
  margin: 0 auto;
  padding-bottom: 56px;
}
@media screen and (max-width: 767px) {
  .service-in-contents-list {
    width: calc(592/750 * 100vw);
    flex-direction: column;
    padding-bottom: calc(106/750 * 100vw);
    margin: 0 auto;
  }
}

.service-in-contents-list-item {
  width: 298px;
  position: relative;
  padding: 42px 29px 24px 24px;
  background: url(../img/service_list_bg_top.jpg) center top/298px auto no-repeat, url(../img/service_list_bg_bottom.jpg) center bottom/298px auto no-repeat, url(../img/service_list_bg_center.jpg) center top/298px auto repeat-y;
}
@media screen and (max-width: 767px) {
  .service-in-contents-list-item {
    width: 100%;
    padding: calc(62/750 * 100vw) calc(52/750 * 100vw) calc(43/750 * 100vw) calc(43/750 * 100vw);
    margin-bottom: calc(50/750 * 100vw);
    background: url(../img/service_list_bg_top_sp.jpg) center top/calc(592/750 * 100vw) auto no-repeat, url(../img/service_list_bg_bottom_sp.jpg) center bottom/calc(592/750 * 100vw) auto no-repeat, url(../img/service_list_bg_center_sp.jpg) center top/calc(592/750 * 100vw) auto repeat-y;
  }
}
@media screen and (max-width: 767px) {
  .service-in-contents-list-item:last-child {
    margin-bottom: 0;
  }
}

.online-contents-list-item, .course-contents-list-item {
  margin-right: 24px;
}
.online-contents-list-item:last-child, .course-contents-list-item:last-child {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  .online-contents-list-item, .course-contents-list-item {
    margin-right: 0;
  }
}

.parent-contents-list-item, .high-contents-list-item {
  margin-right: 5px;
}
.parent-contents-list-item:last-child, .high-contents-list-item:last-child {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  .parent-contents-list-item, .high-contents-list-item {
    margin-right: 0;
  }
}

.service-in-contents-list-item-ttl-num {
  width: 52px;
  height: 52px;
  position: absolute;
  background: url(../img/service_list_round.png) center center/cover no-repeat;
  left: 50%;
  transform: translate(-50%, -50%);
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .service-in-contents-list-item-ttl-num {
    width: calc(75/750 * 100vw);
    height: calc(75/750 * 100vw);
    background: url(../img/service_list_round_sp.png) center center/cover no-repeat;
  }
}
.service-in-contents-list-item-ttl-num p {
  font-size: 22px;
  font-weight: 600;
  color: #4e90c0;
}
@media screen and (max-width: 767px) {
  .service-in-contents-list-item-ttl-num p {
    font-size: calc(32/750 * 100vw);
  }
}

.service-in-contents-list-item-ttl-wrap {
  text-align: center;
  padding-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .service-in-contents-list-item-ttl-wrap {
    padding-bottom: calc(20/750 * 100vw);
  }
}

.service-in-contents-list-item-ttl {
  color: #4e90c0;
  font-size: 20px;
  font-weight: 600;
  display: inline-block;
  background: linear-gradient(transparent 70%, #ffefb0 70%);
  line-height: 1;
  margin-bottom: 0px;
}
@media screen and (max-width: 767px) {
  .service-in-contents-list-item-ttl {
    font-size: calc(42/750 * 100vw);
    margin-bottom: calc(10/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .service-in-contents-list-item-ttl-notes {
    font-size: calc(26/750 * 100vw);
  }
}

.service-in-contents-list-item-img {
  font-size: 0;
  padding-bottom: 14px;
  width: 240px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .service-in-contents-list-item-img {
    width: calc(439/750 * 100vw);
    padding-bottom: calc(14/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .service-in-contents-list-item-txt {
    font-size: calc(26/750 * 100vw);
  }
}

.service-in-contents-list-item-txt-notes {
  font-size: 12px;
  padding-top: 20px;
}
@media screen and (max-width: 767px) {
  .service-in-contents-list-item-txt-notes {
    font-size: calc(18/750 * 100vw);
    padding-top: calc(20/750 * 100vw);
  }
}

/* =========================================================
price-box
========================================================= */
.price-box {
  width: 792px;
  margin: 0 auto;
  background: url(../img/price_box_bg_top.jpg) center top/100% auto no-repeat, url(../img/price_box_bg_bottom.jpg) center bottom/100% auto no-repeat, url(../img/price_box_bg_center.jpg) center bottom/100% auto repeat-y;
}
@media screen and (max-width: 767px) {
  .price-box {
    width: calc(630/750 * 100vw);
    background: url(../img/price_box_bg_top_sp.jpg) center top/100% auto no-repeat, url(../img/price_box_bg_bottom_sp.jpg) center bottom/100% auto no-repeat, url(../img/price_box_bg_center_sp.jpg) center bottom/100% auto repeat-y;
  }
}

.price-box-inner {
  padding: 22px 74px;
}
@media screen and (max-width: 767px) {
  .price-box-inner {
    padding: calc(20/750 * 100vw) calc(36/750 * 100vw);
  }
}

.price-box-ttl-wrap {
  text-align: center;
  border-radius: 23px;
  margin-bottom: 30px;
  background: url(../img/sub_ttl_bg.jpg) center top/6px 6px repeat;
}
@media screen and (max-width: 767px) {
  .price-box-ttl-wrap {
    margin-bottom: calc(20/750 * 100vw);
  }
}

.price-box-ttl {
  display: inline-block;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
  padding: 3px 0;
}
@media screen and (max-width: 767px) {
  .price-box-ttl {
    font-size: calc(28/750 * 100vw);
  }
}

.price-container {
  background: url(../img/price_box_line.jpg) center bottom/16px 2px repeat-x;
  padding: 0 36px 10px;
}
@media screen and (max-width: 767px) {
  .price-container {
    padding: 0 0 calc(10/750 * 100vw);
    background: url(../img/price_box_line_sp.jpg) center bottom/calc(20/750 * 100vw) calc(2/750 * 100vw) repeat-x;
  }
}

.price-container-list-item {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding-bottom: 14px;
}
@media screen and (max-width: 767px) {
  .price-container-list-item {
    padding-bottom: calc(14/750 * 100vw);
  }
}

.price-container-list-item-cont {
  background: url(../img/price-container-list-dot.jpg) center center/7px 1px repeat-x;
  width: 345px;
}
@media screen and (max-width: 767px) {
  .price-container-list-item-cont {
    width: calc(360/750 * 100vw);
  }
}
.price-container-list-item-cont p {
  font-size: 18px;
  padding-right: 8px;
  display: inline-block;
  font-weight: bold;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .price-container-list-item-cont p {
    padding-right: calc(8/750 * 100vw);
    font-size: calc(26/750 * 100vw);
  }
}

.price-container-list-item-price {
  width: 220px;
}
@media screen and (max-width: 767px) {
  .price-container-list-item-price {
    width: calc(190/750 * 100vw);
  }
}
.price-container-list-item-price .price-container-list-item-price-txt {
  font-size: 22px;
  display: inline-block;
  font-weight: bold;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .price-container-list-item-price .price-container-list-item-price-txt {
    white-space: nowrap;
    font-size: calc(30/750 * 100vw);
  }
}
.price-container-list-item-price .price-container-list-item-price-txt2 {
  font-size: 22px;
  display: inline-block;
  font-weight: bold;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .price-container-list-item-price .price-container-list-item-price-txt2 {
    white-space: nowrap;
    font-size: calc(24/750 * 100vw);
  }
}

.small-txt {
  font-size: 16px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .small-txt {
    font-size: calc(22/750 * 100vw);
  }
}

.price-container-list-item-price-notes {
  font-size: 15px;
  line-height: 1;
  font-feature-settings: "palt";
  font-weight: 400;
  display: block;
}
@media screen and (max-width: 767px) {
  .price-container-list-item-price-notes {
    width: 100%;
    text-align: right;
    font-size: calc(18/750 * 100vw);
  }
}

.price-container-list-notes {
  padding: 20px 36px 0;
  font-size: 11px;
  line-height: 1.8;
}
.price-container-list-notes::before {
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 1.8) * .5em);
  content: "";
}
.price-container-list-notes::after {
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 1.8) * .5em);
  content: "";
}
@media screen and (max-width: 767px) {
  .price-container-list-notes {
    font-feature-settings: "palt";
    padding: calc(20/750 * 100vw) 0 0;
    font-size: calc(18/750 * 100vw);
  }
}

div {
  font-size: 0;
}

li {
  font-size: 0;
}

img {
  max-width: 100%;
  height: auto;
  font-size: 0;
}

a {
  color: #333;
  text-decoration: none;
}

figure {
  line-height: 0;
}

.bold {
  font-weight: bold;
}

.ta-c {
  text-align: center;
}

.ta-l {
  text-align: left;
}

.ta-r {
  text-align: right;
}

.d-ib {
  display: inline-block;
}

.d-b {
  display: block;
}

.d-i {
  display: inline;
}

.boxshadow-bl {
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.1);
}

.bg-gray {
  background-color: #F7F7F7;
}

.bg-blue {
  background-color: #EBF7FF;
}

@media screen and (min-width: 768px) {
  .fs-pc14 {
    font-size: 14px;
  }
}

@media screen and (min-width: 768px) {
  .fs-pc18 {
    font-size: 18px;
  }
}

@media screen and (min-width: 768px) {
  .fs-pc20 {
    font-size: 20px;
  }
}

@media screen and (max-width: 767px) {
  .fs-sp20 {
    font-size: calc(20/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .fs-sp24 {
    font-size: calc(24/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .fs-sp26 {
    font-size: calc(26/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .fs-sp28 {
    font-size: calc(28/750 * 100vw);
  }
}

.w1000 {
  width: 1000px;
}
@media screen and (max-width: 767px) {
  .w1000 {
    width: 100%;
  }
}

.w1024 {
  width: 1024px;
}
@media screen and (max-width: 767px) {
  .w1024 {
    width: 100%;
  }
}

.w1080 {
  width: 1080px;
}
@media screen and (max-width: 767px) {
  .w1080 {
    width: 100%;
  }
}

.w1100 {
  width: 1100px;
}
@media screen and (max-width: 767px) {
  .w1100 {
    width: 100%;
  }
}

.w1200 {
  width: 1200px;
}
@media screen and (max-width: 767px) {
  .w1200 {
    width: 100%;
  }
}

.w1300 {
  width: 1300px;
}
@media screen and (max-width: 767px) {
  .w1300 {
    width: 100%;
  }
}

.w1400 {
  width: 1400px;
}
@media screen and (max-width: 767px) {
  .w1400 {
    width: 100%;
  }
}

.w1600 {
  width: 1600px;
}
@media screen and (max-width: 767px) {
  .w1600 {
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  .w-pc45per {
    width: 45%;
  }
}

@media screen and (min-width: 768px) {
  .w-pc50per {
    width: 50%;
  }
}

@media screen and (min-width: 768px) {
  .w-pc100per {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .w-sp45per {
    width: 45%;
  }
}

@media screen and (max-width: 767px) {
  .w-sp50per {
    width: 50%;
  }
}

@media screen and (max-width: 767px) {
  .w-sp85per {
    width: 85%;
  }
}

@media screen and (max-width: 767px) {
  .w-sp100per {
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  .h-pc50 {
    height: 50px;
  }
}

@media screen and (min-width: 768px) {
  .h-pc100 {
    height: 100px;
  }
}

@media screen and (min-width: 768px) {
  .pt-pc10 {
    padding-top: 10px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp10 {
    padding-top: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc20 {
    padding-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp20 {
    padding-top: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc30 {
    padding-top: 30px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp30 {
    padding-top: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc40 {
    padding-top: 40px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp40 {
    padding-top: calc(40/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc50 {
    padding-top: 50px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp50 {
    padding-top: calc(50/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc60 {
    padding-top: 60px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp60 {
    padding-top: calc(60/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc70 {
    padding-top: 70px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp70 {
    padding-top: calc(70/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc80 {
    padding-top: 80px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp80 {
    padding-top: calc(80/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc90 {
    padding-top: 90px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp90 {
    padding-top: calc(90/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc100 {
    padding-top: 100px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp100 {
    padding-top: calc(100/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc110 {
    padding-top: 110px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp110 {
    padding-top: calc(110/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc120 {
    padding-top: 120px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp120 {
    padding-top: calc(120/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc130 {
    padding-top: 130px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp130 {
    padding-top: calc(130/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc140 {
    padding-top: 40px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp140 {
    padding-top: calc(140/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc150 {
    padding-top: 150px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp150 {
    padding-top: calc(150/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc160 {
    padding-top: 160px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp160 {
    padding-top: calc(160/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc170 {
    padding-top: 170px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp170 {
    padding-top: calc(170/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc180 {
    padding-top: 180px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp180 {
    padding-top: calc(180/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc190 {
    padding-top: 190px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp190 {
    padding-top: calc(190/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pt-pc200 {
    padding-top: 200px;
  }
}

@media screen and (max-width: 767px) {
  .pt-sp200 {
    padding-top: calc(200/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc10 {
    padding-bottom: 10px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp10 {
    padding-bottom: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc20 {
    padding-bottom: 20px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp20 {
    padding-bottom: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc30 {
    padding-bottom: 30px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp30 {
    padding-bottom: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc40 {
    padding-bottom: 40px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp40 {
    padding-bottom: calc(40/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc50 {
    padding-bottom: 50px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp50 {
    padding-bottom: calc(50/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc60 {
    padding-bottom: 60px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp60 {
    padding-bottom: calc(60/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc70 {
    padding-bottom: 70px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp70 {
    padding-bottom: calc(70/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc80 {
    padding-bottom: 80px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp80 {
    padding-bottom: calc(80/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc90 {
    padding-bottom: 90px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp90 {
    padding-bottom: calc(90/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc100 {
    padding-bottom: 100px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp100 {
    padding-bottom: calc(100/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc110 {
    padding-bottom: 110px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp110 {
    padding-bottom: calc(110/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc120 {
    padding-bottom: 120px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp120 {
    padding-bottom: calc(120/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc130 {
    padding-bottom: 130px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp130 {
    padding-bottom: calc(130/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc140 {
    padding-bottom: 40px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp140 {
    padding-bottom: calc(140/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc150 {
    padding-bottom: 150px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp150 {
    padding-bottom: calc(150/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc160 {
    padding-bottom: 160px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp160 {
    padding-bottom: calc(160/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc170 {
    padding-bottom: 170px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp170 {
    padding-bottom: calc(170/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc180 {
    padding-bottom: 180px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp180 {
    padding-bottom: calc(180/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc190 {
    padding-bottom: 190px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp190 {
    padding-bottom: calc(190/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pb-pc200 {
    padding-bottom: 200px;
  }
}

@media screen and (max-width: 767px) {
  .pb-sp200 {
    padding-bottom: calc(200/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc10 {
    padding-left: 10px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp10 {
    padding-left: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc20 {
    padding-left: 20px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp20 {
    padding-left: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc30 {
    padding-left: 30px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp30 {
    padding-left: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc40 {
    padding-left: 40px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp40 {
    padding-left: calc(40/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc50 {
    padding-left: 50px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp50 {
    padding-left: calc(50/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc60 {
    padding-left: 60px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp60 {
    padding-left: calc(60/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc70 {
    padding-left: 70px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp70 {
    padding-left: calc(70/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc80 {
    padding-left: 80px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp80 {
    padding-left: calc(80/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc90 {
    padding-left: 90px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp90 {
    padding-left: calc(90/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pl-pc100 {
    padding-left: 100px;
  }
}

@media screen and (max-width: 767px) {
  .pl-sp100 {
    padding-left: calc(100/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc10 {
    padding-right: 10px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp10 {
    padding-right: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc20 {
    padding-right: 20px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp20 {
    padding-right: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc30 {
    padding-right: 30px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp30 {
    padding-right: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc40 {
    padding-right: 40px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp40 {
    padding-right: calc(40/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc50 {
    padding-right: 50px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp50 {
    padding-right: calc(50/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc60 {
    padding-right: 60px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp60 {
    padding-right: calc(60/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc70 {
    padding-right: 70px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp70 {
    padding-right: calc(70/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc80 {
    padding-right: 80px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp80 {
    padding-right: calc(80/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc90 {
    padding-right: 90px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp90 {
    padding-right: calc(90/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .pr-pc100 {
    padding-right: 100px;
  }
}

@media screen and (max-width: 767px) {
  .pr-sp100 {
    padding-right: calc(100/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ptb-pc10 {
    padding-top: 10px;
    padding-bottom: 10px;
  }
}

@media screen and (max-width: 767px) {
  .ptb-sp10 {
    padding-top: calc(10/750 * 100vw);
    padding-bottom: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ptb-pc20 {
    padding-top: 20px;
    padding-bottom: 20px;
  }
}

@media screen and (max-width: 767px) {
  .ptb-sp20 {
    padding-top: calc(20/750 * 100vw);
    padding-bottom: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ptb-pc30 {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

@media screen and (max-width: 767px) {
  .ptb-sp30 {
    padding-top: calc(30/750 * 100vw);
    padding-bottom: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .plr-pc10 {
    padding-left: 10px;
    padding-right: 10px;
  }
}

@media screen and (min-width: 768px) {
  .plr-pc20 {
    padding-left: 20px;
    padding-right: 20px;
  }
}

@media screen and (min-width: 768px) {
  .plr-pc30 {
    padding-left: 30px;
    padding-right: 30px;
  }
}

@media screen and (max-width: 767px) {
  .plr-sp10 {
    padding-left: calc(10/750 * 100vw);
    padding-right: calc(10/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .plr-sp20 {
    padding-left: calc(20/750 * 100vw);
    padding-right: calc(20/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .plr-sp30 {
    padding-left: calc(30/750 * 100vw);
    padding-right: calc(30/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .p-sp10 {
    padding: calc(10/750 * 100vw);
  }
}

.m0a {
  margin: 0 auto;
}

.mla {
  margin-left: auto;
}

.mra {
  margin-right: auto;
}

.mta {
  margin-top: auto;
}

.mta {
  margin-bottom: auto;
}

@media screen and (min-width: 768px) {
  .mt-pc10 {
    margin-top: 10px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp10 {
    margin-top: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc20 {
    margin-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp20 {
    margin-top: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc30 {
    margin-top: 30px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp30 {
    margin-top: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc40 {
    margin-top: 40px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp40 {
    margin-top: calc(40/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc50 {
    margin-top: 50px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp50 {
    margin-top: calc(50/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc60 {
    margin-top: 60px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp60 {
    margin-top: calc(60/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc70 {
    margin-top: 70px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp70 {
    margin-top: calc(70/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc80 {
    margin-top: 80px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp80 {
    margin-top: calc(80/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc90 {
    margin-top: 90px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp90 {
    margin-top: calc(90/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc100 {
    margin-top: 100px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp100 {
    margin-top: calc(100/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc110 {
    margin-top: 110px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp110 {
    margin-top: calc(110/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc120 {
    margin-top: 120px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp120 {
    margin-top: calc(120/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc130 {
    margin-top: 130px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp130 {
    margin-top: calc(130/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc140 {
    margin-top: 40px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp140 {
    margin-top: calc(140/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc150 {
    margin-top: 150px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp150 {
    margin-top: calc(150/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc160 {
    margin-top: 160px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp160 {
    margin-top: calc(160/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc170 {
    margin-top: 170px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp170 {
    margin-top: calc(170/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc180 {
    margin-top: 180px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp180 {
    margin-top: calc(180/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc190 {
    margin-top: 190px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp190 {
    margin-top: calc(190/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mt-pc200 {
    margin-top: 200px;
  }
}

@media screen and (max-width: 767px) {
  .mt-sp200 {
    margin-top: calc(200/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc10 {
    margin-bottom: 10px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp10 {
    margin-bottom: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc20 {
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp20 {
    margin-bottom: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc30 {
    margin-bottom: 30px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp30 {
    margin-bottom: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc40 {
    margin-bottom: 40px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp40 {
    margin-bottom: calc(40/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc50 {
    margin-bottom: 50px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp50 {
    margin-bottom: calc(50/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc60 {
    margin-bottom: 60px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp60 {
    margin-bottom: calc(60/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc70 {
    margin-bottom: 70px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp70 {
    margin-bottom: calc(70/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc80 {
    margin-bottom: 80px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp80 {
    margin-bottom: calc(80/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc90 {
    margin-bottom: 90px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp90 {
    margin-bottom: calc(90/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc100 {
    margin-bottom: 100px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp100 {
    margin-bottom: calc(100/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc110 {
    margin-bottom: 110px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp110 {
    margin-bottom: calc(110/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc120 {
    margin-bottom: 120px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp120 {
    margin-bottom: calc(120/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc130 {
    margin-bottom: 130px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp130 {
    margin-bottom: calc(130/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc140 {
    margin-bottom: 40px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp140 {
    margin-bottom: calc(140/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc150 {
    margin-bottom: 150px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp150 {
    margin-bottom: calc(150/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc160 {
    margin-bottom: 160px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp160 {
    margin-bottom: calc(160/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc170 {
    margin-bottom: 170px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp170 {
    margin-bottom: calc(170/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc180 {
    margin-bottom: 180px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp180 {
    margin-bottom: calc(180/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc190 {
    margin-bottom: 190px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp190 {
    margin-bottom: calc(190/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mb-pc200 {
    margin-bottom: 200px;
  }
}

@media screen and (max-width: 767px) {
  .mb-sp200 {
    margin-bottom: calc(200/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc10 {
    margin-left: 10px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp10 {
    margin-left: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc20 {
    margin-left: 20px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp20 {
    margin-left: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc30 {
    margin-left: 30px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp30 {
    margin-left: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc40 {
    margin-left: 40px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp40 {
    margin-left: calc(40/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc50 {
    margin-left: 50px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp50 {
    margin-left: calc(50/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc60 {
    margin-left: 60px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp60 {
    margin-left: calc(60/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc70 {
    margin-left: 70px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp70 {
    margin-left: calc(70/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc80 {
    margin-left: 80px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp80 {
    margin-left: calc(80/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc90 {
    margin-left: 90px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp90 {
    margin-left: calc(90/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .ml-pc100 {
    margin-left: 100px;
  }
}

@media screen and (max-width: 767px) {
  .ml-sp100 {
    margin-left: calc(100/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc10 {
    margin-right: 10px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp10 {
    margin-right: calc(10/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc20 {
    margin-right: 20px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp20 {
    margin-right: calc(20/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc30 {
    margin-right: 30px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp30 {
    margin-right: calc(30/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc40 {
    margin-right: 40px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp40 {
    margin-right: calc(40/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc50 {
    margin-right: 50px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp50 {
    margin-right: calc(50/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc60 {
    margin-right: 60px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp60 {
    margin-right: calc(60/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc70 {
    margin-right: 70px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp70 {
    margin-right: calc(70/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc80 {
    margin-right: 80px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp80 {
    margin-right: calc(80/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc90 {
    margin-right: 90px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp90 {
    margin-right: calc(90/750 * 100vw);
  }
}

@media screen and (min-width: 768px) {
  .mr-pc100 {
    margin-right: 100px;
  }
}

@media screen and (max-width: 767px) {
  .mr-sp100 {
    margin-right: calc(100/750 * 100vw);
  }
}

.flex-list {
  display: flex;
}

.flex-wrap {
  flex-wrap: wrap;
}

.flex-j-c {
  justify-content: center;
}

.flex-wr-list {
  display: flex;
  flex-wrap: wrap;
}

.flex-al-c {
  align-items: center;
}

.flex-alsl-c {
  align-self: center;
}

@media screen and (max-width: 767px) {
  .flex-sp-clm {
    flex-direction: column;
  }
}

.three-column-list-item {
  width: 29.9%;
  margin-right: 1.5%;
}
.three-column-list-item:nth-child(3n) {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  .three-column-list-item {
    width: 100%;
  }
}

.four-column-list-item {
  width: 23.875%;
  margin-right: 1.5%;
}
.four-column-list-item:nth-child(4n) {
  margin-right: 0;
}

/* =========================================================
utility
========================================================= */
.pc-ui {
  display: block;
}
@media only screen and (max-width: 767px) {
  .pc-ui {
    display: none;
  }
}

.tab-ui {
  display: none;
}
@media only screen and (max-width: 990px) {
  .tab-ui {
    display: block;
  }
}

.sp-ui {
  display: none;
}
@media only screen and (max-width: 767px) {
  .sp-ui {
    display: block;
  }
}

.pc-in {
  display: inline;
}
@media only screen and (max-width: 767px) {
  .pc-in {
    display: none;
  }
}

.tab-in {
  display: none;
}
@media only screen and (max-width: 990px) {
  .tab-in {
    display: inline;
  }
}

.sp-in {
  display: none;
}
@media only screen and (max-width: 767px) {
  .sp-in {
    display: inline;
  }
}

/* clearfix
--------------------------------------------------------- */
.clearfix {
  *zoom: 1;
}
.clearfix:after {
  content: "";
  display: table;
  clear: both;
}

/* border-box
--------------------------------------------------------- */
* {
  box-sizing: border-box;
}


/* =========================================================
link
========================================================= */

.link{
  color: #4991c2;
  text-decoration: underline;
}


/* =========================================================
title
========================================================= */
.heading-area {
  text-align: center;
}

.h-alpha {
  font-weight: 700;
  letter-spacing: 0.102em;
}
@media only screen and (max-width: 767px) {
  .h-alpha {
    font-size: calc(36/750 * 100vw);
    line-height: 1.4;
  }
}

.heading-ttl-sub-c {
  font-size: 20px;
  font-family: "Poppins", sans-serif;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .heading-ttl-sub-c {
    font-size: calc(24/750 * 100vw);
    font-family: "Poppins", sans-serif;
    font-weight: bold;
  }
}

.heading-ttl-c::after {
  width: 114px;
  height: 3px;
  margin: 15px auto 0;
}

.heading-ttl-c {
  font-size: 26px;
  font-weight: bold;
  padding-bottom: 40px;
}
@media only screen and (max-width: 767px) {
  .heading-ttl-c {
    font-size: calc(36/750 * 100vw);
    padding-bottom: calc(80/750 * 100vw);
  }
}

/* =========================================================
btn
========================================================= */
/* ------------------ ↓ header-btn-link ------------------ */
.header-btn-link-c {
  position: relative;
  border-radius: 4px;
  background: #CC2424;
  transition: 0.4s;
  width: 276px;
  height: 56px;
  padding: 7px 20px;
  margin-left: auto;
}
.header-btn-link-c:hover {
  background: #E93D3D;
}

.header-btn-link-c::after {
  right: 8px;
  box-sizing: border-box;
  width: 8px;
  height: 8px;
  border: 8px solid transparent;
  border-left: 10px solid #fff;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  background: url(../img/info_material_cursor.png) center no-repeat;
  background-size: contain;
}

@media screen and (max-width: 767px) {
  .header-btn-link-c {
    width: 100%;
    height: auto;
  }

  .header-btn-link-c::after {
    right: 0.5vw;
    box-sizing: border-box;
    width: 1vw;
    height: 1vw;
    border: 1.8vw solid transparent;
    border-left: 1.52vw solid #fff;
  }

  .header-btn-link-c::before {
    left: 2vw;
    width: 3vw;
    height: 3vw;
  }
}
/* ------------------ ↓ header-tel-number ------------------ */
.header-tel-number-B {
  display: inline-flex;
  color: #333333;
  font-size: 30px;
}

.header-tel-number-B::before {
  content: "";
  display: inline-block;
  width: 43px;
  height: 43px;
  padding-right: 8px;
  background: url(../img/freedial.png) center no-repeat;
  background-size: contain;
}

@media screen and (max-width: 767px) {
  .header-tel-number-B {
    height: 0;
    margin: 0 auto;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
  }
}
/* --------------------- ↓ header-tel --------------------- */
@media screen and (max-width: 767px) {
  .header-tel-link-B {
    display: block;
    width: 100%;
    height: 8.7vw;
  }

  .header-tel-link-B::before {
    content: "";
    display: block;
    width: 100%;
    height: 8.7vw;
    background: url(../img/tel_sp.png) center no-repeat;
    background-size: contain;
  }
}
* {
  box-sizing: border-box;
}

div {
  font-size: 16px;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

a {
  display: block;
  text-decoration: none;
}

li {
  font-size: 16px;
}

.b-clear {
  background-color: rgba(255, 255, 255, 0.7);
}

.font-roboto {
  font-family: "Roboto";
}

.clearfix:before,
.clearfix:after {
  content: "";
  display: table;
}

.clearfix:after {
  clear: both;
}

.clearfix * {
  zoom: 1;
}

@media screen and (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
  }
}
/* ============================
Z B-TOL （人材）
===================================================*/
body {
  letter-spacing: 0;
  -webkit-text-size-adjust: 100%;
  background: #fff;
  font-family: "Noto Sans JP", sans-serif, "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #2c2c2c;
  line-height: 1.625;
  min-width: 1200px;
}
@media screen and (max-width: 767px) {
  body {
    font-size: calc(26/750 * 100vw);
    line-height: 1.53;
    min-width: 100%;
  }
}

/* ============================
zのタイトルエリア
===================================================*/
.z-heading-area {
  text-align: center;
}

.z-heading-ttl {
  text-indent: -9999px;
}

/*Floating
******************************************************/
.z-floating {
  position: fixed;
  bottom: 0;
  width: 100%;
  height: 0;
  opacity: 0;
  background: #fff;
  z-index: 999;
  transition: 0.4s;
  box-shadow: 2px 4px 5px 5px rgba(72, 72, 72, 0.2);
}

.z-floating.show {
  height: auto;
  opacity: 1;
  transition: 0.4s;
}

.z-floating-container {
  margin: auto;
}
@media screen and (max-width: 767px) {
  .z-floating-container {
    display: block;
    width: 100%;
  }
}

.z-floating-btn-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 100%;
  list-style: none;
}
@media screen and (max-width: 767px) {
  .z-floating-btn-list {
    display: inline-flex;
    flex-wrap: nowrap;
  }
}

.z-floating-btn {
  margin: auto;
}
@media screen and (min-width: 768px) {
  .z-floating-btn {
    width: 510px;
    padding: 5px 0;
  }
}
@media screen and (max-width: 767px) {
  .z-floating-btn {
    width: calc(550/750 * 100vw);
    padding: calc(5/750 * 100vw) 0;
  }
}

@media screen and (min-width: 768px) {
  .z-floating-btn-list li {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .z-floating-btn-list li {
    width: 100%;
  }
}

.z-flo-list-btn {
  position: relative;
  text-align: center;
  transition: 0.4s;
  position: relative;
  transition: 0.4s;
}
.z-flo-list-btn:hover {
  opacity: 0.7;
}
@media screen and (min-width: 768px) {
  .z-flo-list-btn {
    width: 100%;
    height: 80px;
  }
}
@media screen and (max-width: 767px) {
  .z-flo-list-btn {
    width: 100%;
    height: calc(90/750 * 100vw);
  }
}

.z-flo-list-btn-img {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .z-flo-list-btn-img {
    width: 466px;
    height: 80px;
  }
}
@media screen and (max-width: 767px) {
  .z-flo-list-btn-img {
    width: calc(550/750 * 100vw);
    height: calc(90/750 * 100vw);
  }
}

/* ============================
z-mv
===================================================*/
.z-mv {
  width: 100%;
  background: url(../img/mv_bg.jpg) top left/auto 555px repeat-x;
}
@media screen and (max-width: 767px) {
  .z-mv {
    background: none;
  }
}

.z-mv-inner {
  width: 1280px;
  height: 555px;
  margin: 0 auto;
  background: url(../img/mv.jpg) top center/1280px 555px no-repeat;
}
@media screen and (max-width: 767px) {
  .z-mv-inner {
    width: 100%;
    height: calc(715/750 * 100vw);
    background: url(../img/mv_sp.jpg) top center/calc(750/750 * 100vw) calc(715/750 * 100vw) no-repeat;
  }
}

.z-mv-heading {
  font-size: 0;
}

/* ============================
news
===================================================*/
.news-wrap {
  background: #fff;
}

.news-inner {
  width: 940px;
  margin: 0 auto;
  padding: 40px 0 46px;
}
@media screen and (max-width: 767px) {
  .news-inner {
    width: calc(670/750 * 100vw);
    padding: calc(40/750 * 100vw) 0 calc(56/750 * 100vw);
  }
}

.news-ttl-wrap {
  text-align: center;
  position: relative;
  background: #ffd65e;
  width: 300px;
  height: 55px;
  border-radius: 6px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .news-ttl-wrap {
    width: calc(324/750 * 100vw);
    height: calc(64/750 * 100vw);
    margin: 0 auto calc(20/750 * 100vw);
  }
}

.news-sub-ttl-txt {
  font-size: 18px;
  color: #4991c2;
  font-weight: bold;
  font-feature-settings: "palt";
  position: absolute;
  display: inline-block;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
  .news-sub-ttl-txt {
    font-size: calc(24/750 * 100vw);
  }
}

.news-ttl-txt {
  font-size: 26px;
  font-weight: bold;
  text-align: center;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .news-ttl-txt {
    font-size: calc(32/750 * 100vw);
  }
}

.news-list-item-inner {
  display: flex;
  width: 100%;
  padding: 19px 0;
  background: url(../img/news_dot.jpg) bottom left/8px 2px repeat-x;
}
@media screen and (max-width: 767px) {
  .news-list-item-inner {
    padding: calc(21/750 * 100vw) 0;
    background: url(../img/news_dot_sp.jpg) bottom left/calc(14/750 * 100vw) calc(2/750 * 100vw) repeat-x;
  }
}

.news-list-item-day {
  width: 165px;
  height: auto;
  border-right: 2px solid #d4d4d4;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .news-list-item-day {
    width: calc(168/750 * 100vw);
    border-right: calc(2/750 * 100vw) solid #7d7d7d;
  }
}
.news-list-item-day p {
  font-size: 18px;
  padding-left: 28px;
}
@media screen and (max-width: 767px) {
  .news-list-item-day p {
    font-size: calc(26/750 * 100vw);
    padding-left: 0;
  }
}

.news-list-item-txt {
  width: 773px;
  height: auto;
}
@media screen and (max-width: 767px) {
  .news-list-item-txt {
    width: calc(498/750 * 100vw);
  }
}
.news-list-item-txt p {
  padding-left: 38px;
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .news-list-item-txt p {
    padding-left: calc(38/750 * 100vw);
    font-size: calc(26/750 * 100vw);
  }
}

/* ============================
about
===================================================*/
.about-wrap {
  width: 100%;
  padding: 45px 0 72px;
  background: url(../img/dot_bg.jpg) top left/20px 30px repeat;
}
@media screen and (max-width: 767px) {
  .about-wrap {
    padding: calc(45/750 * 100vw) 0 calc(72/750 * 100vw);
  }
}

.round-inner {
  background: #fff;
  border-radius: 6px;
  width: 980px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .round-inner {
    width: calc(710/750 * 100vw);
  }
}

.about-inner {
  padding: 27px 40px 54px;
}
@media screen and (max-width: 767px) {
  .about-inner {
    padding: calc(28/750 * 100vw) calc(20/750 * 100vw) calc(58/750 * 100vw);
  }
}

.about-ttl {
  padding-bottom: 70px;
}
@media screen and (max-width: 767px) {
  .about-ttl {
    width: calc(541/750 * 100vw);
    margin: 0 auto;
    padding-bottom: calc(60/750 * 100vw);
  }
}

.about-common-box {
  padding-bottom: 62px;
  align-items: flex-end;
}
@media screen and (max-width: 767px) {
  .about-common-box {
    padding-bottom: calc(86/750 * 100vw);
  }
}
@media screen and (min-width: 768px) {
  .about-common-box .common-box-txt {
    padding-bottom: 62px;
  }
}

.about-target-box {
  background: url(../img/about_target_bg.png) center right 25px/127px 122px no-repeat, #fffcf4;
}
@media screen and (max-width: 767px) {
  .about-target-box {
    background: url(../img/about_target_bg.png) bottom calc(28/750 * 100vw) center/calc(202/750 * 100vw) calc(196/750 * 100vw) no-repeat, #fffcf4;
  }
}

.online-target-box {
  margin-bottom: 56px;
  background: url(../img/online_target_bg.png) center right 50px/71px 127px no-repeat, #fffcf4;
}
@media screen and (max-width: 767px) {
  .online-target-box {
    margin-bottom: calc(50/750 * 100vw);
    background: url(../img/online_target_bg.png) bottom calc(33/750 * 100vw) center/calc(107/750 * 100vw) calc(190/750 * 100vw) no-repeat, #fffcf4;
  }
}

.parent-target-box {
  margin-bottom: 56px;
  background: url(../img/parent_target_bg.png) center right 54px/90px 90px no-repeat, #fffcf4;
}
@media screen and (max-width: 767px) {
  .parent-target-box {
    margin-bottom: calc(50/750 * 100vw);
    background: url(../img/parent_target_bg.png) bottom calc(38/750 * 100vw) center/calc(155/750 * 100vw) calc(155/750 * 100vw) no-repeat, #fffcf4;
  }
}

.course-target-box {
  margin-bottom: 56px;
  background: url(../img/course_target_bg.png) center right 48px/95px 79px no-repeat, #fffcf4;
}
@media screen and (max-width: 767px) {
  .course-target-box {
    margin-bottom: calc(50/750 * 100vw);
    background: url(../img/course_target_bg.png) bottom calc(27/750 * 100vw) center/calc(171/750 * 100vw) calc(142/750 * 100vw) no-repeat, #fffcf4;
  }
}

.high-target-box {
  margin-bottom: 56px;
  background: url(../img/high_target_bg.png) center right 76px/50px 102px no-repeat, #fffcf4;
}
@media screen and (max-width: 767px) {
  .high-target-box {
    margin-bottom: calc(50/750 * 100vw);
    background: url(../img/high_target_bg.png) bottom calc(18/750 * 100vw) center/calc(77/750 * 100vw) calc(155/750 * 100vw) no-repeat, #fffcf4;
  }
}

/* ============================
service-top
===================================================*/
.service-top-wrap {
  background: url(../img/service-top_bottom_bg2.jpg) left bottom/2px 142px repeat-x, #fff;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .service-top-wrap {
    background: #fff;
  }
}

.service-top-inner {
  width: 1280px;
  margin: 0 auto;
  padding-top: 33px;
  background: url(../img/service-top_bottom_bg.jpg) center bottom/1280px 142px no-repeat, #fff;
}
@media screen and (max-width: 767px) {
  .service-top-inner {
    width: 100%;
    padding-top: calc(72/750 * 100vw);
    background: url(../img/service-top_bottom_bg_sp.jpg) center bottom/100% auto no-repeat, #fff;
  }
}

.servicetop-ttl {
  padding-bottom: 70px;
}
@media screen and (max-width: 767px) {
  .servicetop-ttl {
    width: calc(578/750 * 100vw);
    margin: 0 auto;
    padding-bottom: calc(60/750 * 100vw);
  }
}

.service-top-list {
  width: 948px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  padding-bottom: 90px;
  background: url(../img/service_top_list_bg.png) center/322px 420px no-repeat;
}
@media screen and (max-width: 767px) {
  .service-top-list {
    flex-direction: column;
    background: none;
    width: 100%;
    padding-bottom: calc(110/750 * 100vw);
  }
}

.service-top-list-item {
  width: 454px;
  margin-right: 40px;
  padding-top: 10px;
  text-align: center;
  border-left: #4e90c0 solid 4px;
  border-right: #4e90c0 solid 4px;
  border-bottom: #4e90c0 solid 4px;
  border-top: #4e90c0 solid 30px;
  border-radius: 6px;
  position: relative;
  background: rgba(255, 255, 255, 0.6);
  margin-bottom: 50px;
}
.service-top-list-item:nth-child(2n) {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  .service-top-list-item {
    margin: 0 auto calc(60/750 * 100vw);
    width: calc(596/750 * 100vw);
    border-left: #4e90c0 solid calc(5/750 * 100vw);
    border-right: #4e90c0 solid calc(5/750 * 100vw);
    border-bottom: #4e90c0 solid calc(5/750 * 100vw);
    border-top: #4e90c0 solid calc(40/750 * 100vw);
  }
  .service-top-list-item:nth-child(2n) {
    margin: 0 auto calc(60/750 * 100vw);
  }
}

.service-top-list-item-num {
  width: 109px;
  height: 53px;
  position: absolute;
  background: url(../img/nom_balloon.png) center center/cover no-repeat;
  left: 8px;
  top: -54px;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .service-top-list-item-num {
    width: calc(143/750 * 100vw);
    height: calc(70/750 * 100vw);
    left: calc(10/750 * 100vw);
    top: calc(-71/750 * 100vw);
    background: url(../img/nom_balloon_sp.png) center center/cover no-repeat;
  }
}
.service-top-list-item-num p {
  font-size: 26px;
  font-weight: 600;
  color: #fff;
  padding-top: 2px;
}
@media screen and (max-width: 767px) {
  .service-top-list-item-num p {
    font-size: calc(34/750 * 100vw);
    padding-top: calc(4/750 * 100vw);
  }
}

.service-top-list-item-img {
  width: 94px;
  height: 92px;
  font-size: 0;
  margin: 0 auto 15px;
}
@media screen and (max-width: 767px) {
  .service-top-list-item-img {
    width: calc(124/750 * 100vw);
    height: calc(120/750 * 100vw);
    margin: 0 auto calc(20/750 * 100vw);
  }
}

.service-top-sub-ttl {
  font-size: 20px;
  line-height: 1.3;
  display: inline-block;
  text-align: center;
  padding-bottom: 15px;
  margin-bottom: 18px;
  font-weight: 600;
  background: url(../img/short_dot.png) center bottom/38px 6px no-repeat;
}
.service-top-sub-ttl::before {
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 1.3) * .5em);
  content: "";
}
.service-top-sub-ttl::after {
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 1.3) * .5em);
  content: "";
}
@media screen and (max-width: 767px) {
  .service-top-sub-ttl {
    font-size: calc(26/750 * 100vw);
    padding-bottom: calc(20/750 * 100vw);
    margin-bottom: calc(22/750 * 100vw);
    background: url(../img/short_dot.png) center bottom/calc(60/750 * 100vw) calc(10/750 * 100vw) no-repeat;
  }
}

.service-top-ttl {
  font-size: 30px;
  font-weight: 900;
  color: #4e90c0;
  padding-bottom: 25px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .service-top-ttl {
    font-size: calc(40/750 * 100vw);
    padding-bottom: calc(30/750 * 100vw);
  }
}

/* ============================
online
===================================================*/
.online-contents-list-item, .course-contents-list-item {
  margin-right: 24px;
}
.online-contents-list-item:last-child, .course-contents-list-item:last-child {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  .online-contents-list-item, .course-contents-list-item {
    margin-right: 0;
  }
}

.parent-contents-list-item, .high-contents-list-item {
  margin-right: 5px;
}
.parent-contents-list-item:last-child, .high-contents-list-item:last-child {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  .parent-contents-list-item, .high-contents-list-item {
    margin-right: 0;
  }
}

.online-inner {
  background: url(../img/service_list01_bg.png) center top 57px/760px 67px no-repeat;
}
@media screen and (max-width: 767px) {
  .online-inner {
    padding: calc(32/750 * 100vw) calc(20/750 * 100vw) calc(60/750 * 100vw);
    background: url(../img/service_list01_bg_sp.png) center top calc(32/750 * 100vw)/calc(596/750 * 100vw) calc(183/750 * 100vw) no-repeat;
  }
}

.parent-inner {
  background: url(../img/service_list02_bg.png) center top 68px/715px 97px no-repeat;
}
@media screen and (max-width: 767px) {
  .parent-inner {
    padding: calc(52/750 * 100vw) calc(20/750 * 100vw) calc(60/750 * 100vw);
    background: url(../img/service_list02_bg_sp.png) center top calc(50/750 * 100vw)/calc(596/750 * 100vw) calc(183/750 * 100vw) no-repeat;
  }
}

.course-inner {
  background: url(../img/service_list03_bg.png) center top 84px/680px 67px no-repeat;
}
@media screen and (max-width: 767px) {
  .course-inner {
    padding: calc(52/750 * 100vw) calc(20/750 * 100vw) calc(60/750 * 100vw);
    background: url(../img/service_list03_bg_sp.png) center top calc(42/750 * 100vw)/calc(606/750 * 100vw) calc(208/750 * 100vw) no-repeat;
  }
}

.high-inner {
  background: url(../img/service_list04_bg.png) center top 42px/719px 73px no-repeat;
}
@media screen and (max-width: 767px) {
  .high-inner {
    padding: calc(52/750 * 100vw) calc(20/750 * 100vw) calc(60/750 * 100vw);
    background: url(../img/service_list04_bg_sp.png) center top calc(44/750 * 100vw)/calc(595/750 * 100vw) calc(217/750 * 100vw) no-repeat;
  }
}

.parent-target-box .price-container-list-item {
  display: flex;
  align-items: center;
  padding-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .parent-target-box .price-container-list-item {
    padding-bottom: calc(18/750 * 100vw);
  }
}

/* ============================
curriculum
===================================================*/
.curriculum-box {
  width: 730px;
  margin: 0 auto 80px;
  background: #fdf1f1;
  padding: 30px 50px;
}
@media screen and (max-width: 767px) {
  .curriculum-box {
    margin: 0 auto calc(106/750 * 100vw);
    width: calc(630/750 * 100vw);
    padding: calc(40/750 * 100vw) 0;
  }
}

.curriculum-ttl-wrap {
  text-align: center;
  background: url(../img/curriculum_dot.jpg) center bottom/30px 6px repeat-x;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .curriculum-ttl-wrap {
    margin: 0 calc(20/750 * 100vw) calc(22/750 * 100vw);
    background: url(../img/curriculum_dot.jpg) center bottom/calc(30/750 * 100vw) calc(6/750 * 100vw) repeat-x;
  }
}

.curriculum-ttl {
  font-size: 22px;
  font-weight: bold;
  color: #e65e5e;
  display: inline-block;
  padding: 5px 42px 22px;
  line-height: 1;
  background: url(../img/curriculum_bg_l.png) top left/20px 26px no-repeat, url(../img/curriculum_bg_r.png) top right/20px 26px no-repeat;
}
@media screen and (max-width: 767px) {
  .curriculum-ttl {
    font-size: calc(32/750 * 100vw);
    padding: calc(5/750 * 100vw) calc(42/750 * 100vw) calc(22/750 * 100vw);
    background: url(../img/curriculum_bg_l.png) top left/calc(28/750 * 100vw) calc(37/750 * 100vw) no-repeat, url(../img/curriculum_bg_r.png) top right/calc(28/750 * 100vw) calc(37/750 * 100vw) no-repeat;
  }
}

.curriculum-sub-ttl {
  font-size: 18px;
  padding: 0px 23px 0;
  display: inline-block;
  margin-bottom: 10px;
  font-weight: bold;
  background: url(../img/yamacacco_l.png) top left/12px 28px no-repeat, url(../img/yamacacco_r.png) top right/12px 28px no-repeat;
}
@media screen and (max-width: 767px) {
  .curriculum-sub-ttl {
    margin-bottom: calc(10/750 * 100vw);
    margin-left: calc(20/750 * 100vw);
    font-size: calc(26/750 * 100vw);
    line-height: 1;
    background: url(../img/yamacacco_l.png) top left/calc(12/750 * 100vw) calc(28/750 * 100vw) no-repeat, url(../img/yamacacco_r.png) top right/calc(12/750 * 100vw) calc(28/750 * 100vw) no-repeat;
    padding: 0 calc(23/750 * 100vw) 0;
  }
}

.curriculum-table {
  padding-bottom: 25px;
  font-size: 0;
}
@media screen and (max-width: 767px) {
  .curriculum-table {
    margin-left: calc(20/750 * 100vw);
    padding-bottom: calc(30/750 * 100vw);
  }
}

.curriculum-txt {
  padding-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .curriculum-txt {
    padding-bottom: calc(36/750 * 100vw);
    font-size: calc(26/750 * 100vw);
  }
}

.curriculum-txt-notes {
  font-size: 12px;
  line-height: 1.6;
}
.curriculum-txt-notes::before {
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 1.6) * .5em);
  content: "";
}
.curriculum-txt-notes::after {
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 1.6) * .5em);
  content: "";
}
@media screen and (max-width: 767px) {
  .curriculum-txt-notes {
    font-size: calc(26/750 * 100vw);
    line-height: 1.5;
  }
  .curriculum-txt-notes::before {
    display: block;
    width: 0;
    height: 0;
    margin-top: calc((1 - 1.5) * .5em);
    content: "";
  }
  .curriculum-txt-notes::after {
    display: block;
    width: 0;
    height: 0;
    margin-bottom: calc((1 - 1.5) * .5em);
    content: "";
  }
}

/* ============================
flow
===================================================*/
.flow-wrap {
  background-color: #fff;
  position: relative;
  max-width: 100%;
  margin-right: auto;
  margin-left: auto;
  overflow: initial;
}
@media screen and (min-width: 768px) {
  .flow-wrap {
    min-width: 940px;
  }
}
@media screen and (max-width: 767px) {
  .flow-wrap {
    position: relative;
    max-width: 100%;
    margin-right: auto;
    margin-left: auto;
    overflow: initial;
  }
}

.flow-inner {
  width: 932px;
  margin: 0 auto;
  padding-top: 80px;
  padding-bottom: 130px;
}
@media screen and (max-width: 767px) {
  .flow-inner {
    padding-top: calc(90/750 * 100vw);
    padding-bottom: calc(80/750 * 100vw);
    width: calc(670/750 * 100vw);
  }
}

.flow-ttl {
  padding-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .flow-ttl {
    width: calc(696/750 * 100vw);
    margin: 0 auto;
    padding-bottom: calc(30/750 * 100vw);
  }
}

.z-9-area {
  display: flex;
  -ms-flex-pack: distribute;
  padding-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .z-9-area {
    display: flex;
    flex-direction: column;
    -ms-flex-pack: distribute;
    padding-bottom: calc(20/750 * 100vw);
  }
}

.z-9-intro-txt {
  text-align: center;
  padding-top: 20px;
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .z-9-intro-txt {
    padding-top: calc(30/750 * 100vw);
    font-size: calc(26/750 * 100vw);
  }
}

.z-9-block {
  width: 212px;
  background-color: #fff;
  position: relative;
  margin-right: 28px;
}
.z-9-block:last-child {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  .z-9-block {
    width: auto;
    margin: 0 calc(35/750 * 100vw) calc(40/750 * 100vw);
    padding-top: calc(20/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .z-9-block:last-child {
    margin: 0 calc(35/750 * 100vw) calc(0/750 * 100vw);
  }
}

.z-9-block::before {
  position: absolute;
  content: "";
  display: block;
  width: 30px;
  height: 20px;
  background: url(../img/flow_arrow.png) center center/contain no-repeat;
  top: 96px;
  transform: rotateZ(-90deg);
  right: -29px;
}
@media screen and (max-width: 767px) {
  .z-9-block::before {
    position: absolute;
    width: calc(59/750 * 100vw);
    height: calc(41/750 * 100vw);
    background: url(../img/flow_arrow.png) center center/contain no-repeat;
    top: calc(-52/750 * 100vw);
    right: auto;
    left: 50%;
    transform: translate(-50%, 0%);
  }
}

.z-9-block:last-child:before {
  background: none;
}
@media screen and (max-width: 767px) {
  .z-9-block:last-child:before {
    background: url(../img/flow_arrow.png) center center/contain no-repeat;
  }
}

.z-9-ttl span {
  background: #fff;
  font-size: 16px;
  font-family: Arial, Helvetica, sans-serif;
  display: inline;
  padding: 0 8px;
}
@media screen and (max-width: 767px) {
  .z-9-ttl span {
    font-size: calc(30/750 * 100vw);
  }
}

.z-9-sub-ttl {
  font-size: 20px;
  color: #4e90c0;
  text-align: center;
  font-weight: bold;
  padding-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .z-9-sub-ttl {
    font-size: calc(32/750 * 100vw);
    padding-bottom: calc(10/750 * 100vw);
  }
}

.z-9-img-box {
  width: 212px;
  height: auto;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .z-9-img-box {
    width: calc(353/750 * 100vw);
    margin: 0 auto calc(20/750 * 100vw);
  }
}

.z-9-img {
  margin: 0 auto;
  display: block;
}

.z-9-txt {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .z-9-txt {
    text-align: left;
    font-size: calc(26/750 * 100vw);
    width: calc(520/750 * 100vw);
    margin: 0 auto calc(40/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .z-9-block:first-child:before {
    background: none;
  }
}

.flow-demand-box {
  width: 932px;
  margin: 0 auto;
  padding: 20px 50px;
  background: #e1f1fc;
}
@media screen and (max-width: 767px) {
  .flow-demand-box {
    width: calc(630/750 * 100vw);
    padding: calc(20/750 * 100vw) calc(30/750 * 100vw);
  }
}

.flow-demand-box-ttl {
  color: #4e90c0;
  font-weight: bold;
  font-size: 18px;
  width: 100%;
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: solid 1px #4e90c0;
}
@media screen and (max-width: 767px) {
  .flow-demand-box-ttl {
    font-size: calc(32/750 * 100vw);
    padding-bottom: calc(15/750 * 100vw);
    margin-bottom: calc(20/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .flow-demand-box-txt {
    font-size: calc(26/750 * 100vw);
  }
}

/* ============================
message
===================================================*/
.message-wrap {
  width: 100%;
  padding: 45px 0 44px;
  background: url(../img/dot_bg.jpg) top left/20px 30px repeat;
}
@media screen and (max-width: 767px) {
  .message-wrap {
    padding: calc(45/750 * 100vw) 0 calc(55/750 * 100vw);
  }
}

.message-ttl {
  padding-bottom: 70px;
}
@media screen and (max-width: 767px) {
  .message-ttl {
    width: calc(541/750 * 100vw);
    margin: 0 auto;
    padding-bottom: calc(50/750 * 100vw);
  }
}

.message-sub-ttl {
  font-weight: bold;
  font-size: 24px;
  text-align: center;
  padding-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .message-sub-ttl {
    font-size: calc(32/750 * 100vw);
    padding-bottom: calc(40/750 * 100vw);
  }
}

.message-inner {
  padding: 27px 40px 54px;
}
@media screen and (max-width: 767px) {
  .message-inner {
    padding: calc(28/750 * 100vw) calc(20/750 * 100vw) calc(64/750 * 100vw);
  }
}
.message-inner .common-box-txt {
  margin-right: 0;
  margin-left: 25px;
}
@media screen and (max-width: 767px) {
  .message-inner .common-box-txt {
    margin-left: 0;
    padding-bottom: 0;
  }
}
.message-inner .common-box-txt-contents {
  padding-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .message-inner .common-box-txt-contents {
    padding-bottom: calc(40/750 * 100vw);
  }
}
.message-inner .common-box-img {
  padding-top: 30px;
}
@media screen and (max-width: 767px) {
  .message-inner .common-box-img {
    padding-top: 0;
  }
}

.message-common-box {
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .message-common-box {
    flex-direction: column;
  }
}

.massege-pro {
  display: flex;
  width: 900px;
  margin: 0 auto;
  padding: 30px 50px;
  background: #fffcf4;
}
@media screen and (max-width: 767px) {
  .massege-pro {
    width: calc(630/750 * 100vw);
    flex-direction: column-reverse;
    padding: calc(40/750 * 100vw) calc(35/750 * 100vw) calc(50/750 * 100vw);
  }
}

.massege-pro-txt-box {
  width: 550px;
  margin-right: 30px;
}
@media screen and (max-width: 767px) {
  .massege-pro-txt-box {
    width: 100%;
  }
}

.massege-pro-ttl-img {
  width: 224px;
  font-size: 0;
}
@media screen and (max-width: 767px) {
  .massege-pro-ttl-img {
    margin: 0 auto;
    width: calc(300/750 * 100vw);
    margin-bottom: calc(30/750 * 100vw);
  }
}

.massege-pro-ttl-wrap {
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .massege-pro-ttl-wrap {
    text-align: center;
    margin-bottom: calc(20/750 * 100vw);
  }
}

.massege-pro-ttl {
  color: #669fc8;
  font-size: 20px;
  font-weight: bold;
  background: url(../img/sumicacco_l.png) top left/13px 33px no-repeat, url(../img/sumicacco_r.png) top right/13px 33px no-repeat;
  padding: 8px 26px;
  display: inline-block;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .massege-pro-ttl {
    line-height: 1.43;
    font-size: calc(32/750 * 100vw);
    background: url(../img/sumicacco_l.png) top left/calc(32/750 * 100vw) calc(82/750 * 100vw) no-repeat, url(../img/sumicacco_r.png) top right/calc(32/750 * 100vw) calc(82/750 * 100vw) no-repeat;
    padding: 0 calc(53/750 * 100vw);
  }
  .massege-pro-ttl::before {
    display: block;
    width: 0;
    height: 0;
    margin-top: calc((1 - 1.43) * .5em);
    content: "";
  }
  .massege-pro-ttl::after {
    display: block;
    width: 0;
    height: 0;
    margin-bottom: calc((1 - 1.43) * .5em);
    content: "";
  }
}

.massege-pro-txt {
  font-size: 16px;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .massege-pro-txt {
    line-height: 1.5;
    font-size: calc(26/750 * 100vw);
  }
  .massege-pro-txt::before {
    display: block;
    width: 0;
    height: 0;
    margin-top: calc((1 - 1.5) * .5em);
    content: "";
  }
  .massege-pro-txt::after {
    display: block;
    width: 0;
    height: 0;
    margin-bottom: calc((1 - 1.5) * .5em);
    content: "";
  }
}

/* ============================
form
===================================================*/
.form-wrap {
  width: 100%;
  background: #fff;
}

.form-inner {
  width: 730px;
  margin: 0 auto;
  padding: 45px 0 80px;
}
@media screen and (max-width: 767px) {
  .form-inner {
    width: 100%;
    padding: calc(45/750 * 100vw) 0 calc(120/750 * 100vw);
  }
}

.form-ttl {
  padding-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .form-ttl {
    width: calc(537/750 * 100vw);
    margin: 0 auto;
    padding-bottom: calc(50/750 * 100vw);
  }
}

.form-txt {
  width: 560px;
  margin: 0 auto 80px;
}
@media screen and (max-width: 767px) {
  .form-txt {
    width: calc(640/750 * 100vw);
    font-size: calc(26/750 * 100vw);
    margin: 0 auto calc(70/750 * 100vw);
  }
}

.form-mail {
  width: 70%;
  margin: auto;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .form-mail {
    width: 90%;
    
  }
}

.form-mail dl dt{
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 5px 0;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .form-mail dl dt{
    font-size: 100%;
    font-weight: bold;
  }
}

.form-mail dl dd{
  margin: 0 0 15px 0;
  text-align: left;
}

.form-mail dl dd.dd_check{
  margin: 10px 0 25px 15px;
  font-size: 18px;
  line-height: 150%;
}

.form-mail dl dd input[type='checkbox']{
  margin: 0 10px 0 0;
}

.form-mail dl dd input[type='text'],
.form-mail dl dd input[type='email'],
.form-mail dl dd input[type='tel']{
  width:100%;
  height: 50px;
  font-size: 18px;
  border: solid 2px #b5d2e4;
  background-color: #f8fcff;
  border-radius: 6px;
}

@media screen and (max-width: 767px) {
  .form-mail dl dd input[type='text'],
  .form-mail dl dd input[type='email'],
  .form-mail dl dd input[type='tel']{
    border: solid 1px #b5d2e4;
    border-radius: 4px;
  }
}

.form-mail dl dd textarea{
  width:100%;
  height: 100px;
  font-size: 18px;
  border: solid 2px #b5d2e4;
  background-color: #f8fcff;
  border-radius: 6px;
}

.form-mail input[type='submit']{

 
 -webkit-appearance: none;
 
  font-size: 140%;
  font-weight: bold;
  letter-spacing: 0.1em;
  width: 248px;
  height: 65px;
  color: #fff;
  background: #e65e5e;
  border:2px solid #bf4949;
  border-radius: 15px;
  margin: 10px auto;
}



.form-mail input[type='submit']:hover{
  cursor: pointer;
}

/* .form-kari {
  width: 513px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .form-kari {
    width: calc(631/750 * 100vw);
  }
} */

/* ============================
z-12
===================================================*/
.z-12 {
  margin: 0 auto;
  background: #e1f1fc;
}

.z-12-main {
  margin: auto;
}
@media screen and (min-width: 768px) {
  .z-12-main {
    width: 600px;
    margin: auto;
    padding: 25px 0 0;
  }
}
@media screen and (max-width: 767px) {
  .z-12-main {
    width: 100%;
    margin: auto;
    padding: calc(30/750 * 100vw) calc(40/750 * 100vw);
  }
}

.z-12-block {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .z-12-block {
    text-align: left;
  }
}

.footer-txt {
  font-size: 16px;
  padding-bottom: 25px;
}
@media screen and (max-width: 767px) {
  .footer-txt {
    border-bottom: 1px solid #000;
    font-size: calc(26/750 * 100vw);
    padding-bottom: calc(25/750 * 100vw);
  }
}

.footer-list {
  display: flex;
  justify-content: center;
  margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .footer-list {
    flex-direction: column;
    padding: calc(30/750 * 100vw) calc(20/750 * 100vw) 0;
    margin-bottom: 0;
  }
}

.footer-list-item {
  border-right: #81898e 2px solid;
}
.footer-list-item:last-child {
  border-right: none;
}
@media screen and (max-width: 767px) {
  .footer-list-item {
    border-right: none;
    padding-bottom: calc(20/750 * 100vw);
  }
}

.footer-list-item a {
  padding: 0 30px;
  display: block;
  font-size: 16px;
  transition: 0.2s;
}
@media screen and (max-width: 767px) {
  .footer-list-item a {
    border-right: 0;
    font-size: calc(26/750 * 100vw);
    padding: 0;
  }
}
.footer-list-item a:hover {
  opacity: 0.7;
}

.z-12-p-icon-box {
  padding-left: 10px;
}
@media screen and (max-width: 767px) {
  .z-12-p-icon-box {
    width: calc(120/750 * 100vw);
  }
}

.z-12-bottom {
  width: 100%;
  color: #fff;
  background: #669fc8;
}



@media screen and (min-width: 768px) {
  .z-12-bottom {
    padding-bottom: 100px;
  }
}


@media screen and (max-width: 767px) {
  .z-12-bottom {
    padding-bottom: 15vw;
  }
}

.z-12-main__copyright {
  text-align: center;
  color: #fff;
  letter-spacing: 0.079em;
}
@media screen and (min-width: 768px) {
  .z-12-main__copyright {
    padding: 40px 0 20px;
    font-size: 11px;
  }
}
@media screen and (max-width: 767px) {
  .z-12-main__copyright {
    padding: 20px;
    font-size: calc(18/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .z-12-box-left {
    width: auto;
    text-align: center;
  }
}

.z-13-bottom {
  width: 100%;
  color: #fff;
  background: #669fc8;
}

.z-13-main__copyright {
  text-align: center;
  color: #fff;
  letter-spacing: 0.079em;
}

@media screen and (min-width: 768px) {
  .z-13-main__copyright {
    padding: 10px 0;
    font-size: 11px;
  }
}

@media screen and (max-width: 767px) {
  .z-13-main__copyright {
    padding: 10px 0;
    font-size: calc(18/750 * 100vw);
  }
}

@media screen and (max-width: 767px) {
  .z-13-box-left {
    width: auto;
    text-align: center;
  }
}


/* ============================
child_page
===================================================*/


.child_page{
  
}

.child_page .logo{
  width: 100%;
  height: 60px;
  margin: 20px auto;
  text-align: center;
  
}

.child_page .logo img{
  width: 300px;
  height: auto;
}

.child_page h1{
  width: 100%;
  height: 90px;
  line-height: 90px;
  margin:0 0 30px 0;
  text-align: center;
  font-size: 30px;
  font-weight: bold;
  background: #e1f1fc;
}

@media screen and (max-width: 767px) {
  .child_page h1{
    font-size: 20px;
  }
}



.child_page_inner{
  width: 60%;
  margin:0 auto 30px;
  min-height: 200px;
}

@media screen and (max-width: 767px) {
  ..child_page_inner {
    width: 90%;
    
  }
}


.child_page .dl_info {
  width: 60%;
  margin:50px auto 50px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .child_page .dl_info {
    width: 90%;
    
  }
}

.child_page .dl_info dt{
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 5px 0;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .child_page .dl_info dt{
    font-size: 100%;
    font-weight: bold;
  }
}

.child_page .dl_info dd{
  margin: 0 0 15px 0;
  text-align: left;
}

.child_page .dl_info dd ol li{
  margin: 0 0 0 20px;
  list-style-type: decimal;
}

.child_page a{
  color: #2072ac;
  text-decoration: underline;
  display: inline-block;
}

.child_page_inner table{
width: 100%;
margin: 30px auto;
border-top: 1px solid #669fc8;
}

.child_page_inner table tr{
  border-bottom: 1px solid #669fc8;
  border-left: 1px solid #669fc8;
  border-right: 1px solid #669fc8;
}

.child_page_inner table tr th{
  width: 30%;
  background: #e1f1fc;
}

.child_page_inner table tr td{

}

.child_page_inner table tr th,
.child_page_inner table tr td{
  padding: 10px;
  text-align: left;
}

