@charset "UTF-8";

/* ==============================
Theme Name: career-workshop
============================== */

/* ======================================================
	PC用設定
====================================================== */

/* 日本語フォントなめらかに */
.f_mpo {
  transform: rotateZ(0.03deg);
}

/* プログラム ====================*/
.table_c01 {
  background-color: #ff9900;
}

.table_c02 {
  background-color: #ffcc00;
}

.table_c03 {
  background-color: #0066cc;
}

.table_c04 {
  background-color: #0099ff;
}

.table_c05 {
  background-color: #ff5050;
}

.table_c01::before,
.table_c02::before,
.table_c03::before,
.table_c04::before,
.table_c05::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 100%;
  margin-top: -15px;
  border: 15px solid transparent;
}

.table_c01::before {
  border-left: 15px solid #ff9900;
}

.table_c02::before {
  border-left: 15px solid #ffcc00;
}

.table_c03::before {
  border-left: 15px solid #0066cc;
}

.table_c04::before {
  border-left: 15px solid #0099ff;
}

.table_c05::before {
  border-left: 15px solid #ff5050;
}

.table_c03 .pp_type_name {
  color: #fff;
}

.pp_explanation {
  display: inline-block;
  font-size: 16px;
  background-color: #fff;
  padding: 5px 15px;
  border-radius: 50px;
}

.pp_explanation br {
  display: none;
}

.pp_type_name {
  display: inline-block;
  padding-top: 15px;
}

.pp_type_name br {
  display: none;
}

.pp_parts_name {
  background-color: #e5f8f7;
  padding: 5px 20px;
  border-radius: 15px;
  display: inline-block;
  margin-bottom: 5px;
}

td .fa-plus {
  display: block;
  font-size: 23px;
  color: #03fcfc;
  margin-bottom: 5px;
}

.pp_choice {
  margin-bottom: 5px;
  font-size: 14px;
}

.pp_caption {
  margin-top: 1em;
  margin-bottom: 80px;
  line-height: 1.5em;
  font-weight: 400;
}

.pp_caption span {
  font-weight: 700;
}

.sttl_program {
  font-size: 28px;
  padding-left: 20px;
  margin: 20px 0;
  line-height: 2em;
  border-left: 6px solid #00e4ed;
  font-weight: 800;
  border-image: linear-gradient(to bottom, #04fcfb, #f9f707) 1;
}

.anchor_ttl {
  text-align: center;
  font-size: 28px;
  line-height: 2em;
  margin-top: 20px;
}

.list__anchor_pp {
  display: flex;
  flex-wrap: wrap;
}

.list__anchor_pp li {
  width: 49.057%;
  background: #fff;
}

.list__anchor_pp li a p {
  box-sizing: border-box;
  display: flex;
  align-content: center;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  width: 100%;
  padding: 10px 60px 10px 20px;
  align-items: center;
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 1.2;
  transform: rotateZ(0.03deg);
  border-left: 1px solid #f5f5f5;
}

.list__anchor_pp li a p::before {
  content: "";
  position: absolute;
  top: calc(50% - 18px);
  right: 12px;
  width: 36px;
  height: 36px;
  background: #00e4ed;
  border-radius: 100%;
}

.list__anchor_pp li a p::after {
  content: "";
  position: absolute;
  top: calc(50% - 7px);
  right: 25px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(135deg);
}

.list__anchor_pp li a {
  display: flex;
  width: 100%;
  height: 100%;
  min-height: 60px;
  text-decoration: none;
  color: #000;
}

.list__anchor_pp li:nth-of-type(even) {
  margin-left: 1.886%;
}

.list__anchor_pp {
  display: flex;
  flex-wrap: wrap;
}

.list__anchor_pp li {
  width: 49.057%;
  background: #fff;
}

.list__anchor_pp li a p {
  box-sizing: border-box;
  display: flex;
  align-content: center;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
  width: 100%;
  padding: 10px 60px 10px 20px;
  align-items: center;
  font-size: 2.3rem;
  font-weight: 700;
  line-height: 1.2;
  transform: rotateZ(0.03deg);
  border-left: 1px solid #f5f5f5;
}

.list__anchor_pp li a p::before {
  content: "";
  position: absolute;
  top: calc(50% - 18px);
  right: 12px;
  width: 36px;
  height: 36px;
  background: #00e4ed;
  border-radius: 100%;
}

.list__anchor_pp li a p::after {
  content: "";
  position: absolute;
  top: calc(50% - 7px);
  right: 25px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(135deg);
}

.list__anchor_pp li a {
  display: flex;
  width: 100%;
  height: 100%;
  min-height: 60px;
  text-decoration: none;
  color: #000;
}

.list__anchor_pp li:nth-of-type(even) {
  margin-left: 1.886%;
}

.text__lead {
  text-align: center;
  font-size: 16px;
  padding: 1em 0;
  font-weight: 500;
}

.btn_footer_calender {
  width: 100%;
  text-align: center;
  padding-bottom: 30px;
}

.btn_footer_calender a,
.btn_footer_calender a:link {
  color: #fff;
  font-weight: 800;
  background-color: #00bfb3;
  font-size: 18px;
  padding: 5px;
  min-width: 230px;
  border-radius: 100px;
  text-decoration: none;
  display: inline-block;
}

.btn_footer_calender a:visited {
  color: #fff;
  text-decoration: none;
}

.concept_movie_box {
  text-align: center;
}

.concept_movie_inner {
  max-width: 650px;
  border-radius: 8px;
  background: linear-gradient(to right, #00fcff, #fff600);
  padding: 20px;
  margin: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.concept_movie_left {
  text-align: left;
}

.concept_movie_left h2 {
  font-size: 38px;
  font-weight: 800;
}

.concept_movie_left p {
  font-size: 18px;
  font-weight: 400;
}

.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.youtube iframe {
  width: 100%;
  height: 100%;
}

.modal-open {
  cursor: pointer;
}

/*モーダル本体の指定 + モーダル外側の背景の指定*/
.modal-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 50%);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box;
  z-index: 200;
}

/*モーダル本体の擬似要素の指定*/
.modal-container:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}

/*モーダル本体に「active」クラス付与した時のスタイル*/
.modal-container.active {
  opacity: 1;
  visibility: visible;
}

/*モーダル枠の指定*/
.modal-body {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  width: 90%;
  max-width: 800px;
}

/*モーダルを閉じるボタンの指定*/
.modal-close {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: -40px;
  right: -10px;
  width: 40px;
  height: 40px;
  font-size: 40px;
  color: #fff;
  cursor: pointer;
}

/*モーダル内のコンテンツの指定*/
.modal-content {
  background: #fff;
  text-align: left;
  padding: 30px;
  box-sizing: border-box;
}

.program .btn_contact_form {
  text-align: center;
}

.program .btn_contact_form a {
  color: #fff;
  margin: auto;
  line-height: 1;
  background: #00bfb3;
  border-radius: 100px;
  text-decoration: none;
  display: inline-block;
  padding: 1em 2em;
  font-size: 2.4rem;
  font-weight: 900;
}

/* カレンダー ====================*/
body.calender .titlearea .inner h1.title {
  background-image: url("images/calender/title_bg.jpg");
}

body.calender .contents {
  margin-top: 50px;
}

.calender_wrap {
  text-align: center;
}

.calender_wrap h2 {
  font-size: 34px;
  font-weight: 800;
  border-bottom: 6px solid;
  border-image: linear-gradient(to right, #00fcff, #fff600);
  border-image-slice: 1;
  display: inline-block;
}

.calender_box {
  max-width: 600px;
  margin: 50px auto;
  background: #f5f5f5;
  border-radius: 8px;
  padding: 20px;
}

.calender_box_inner dl {
  display: flex;
  align-items: center;
  width: 100%;
  margin-bottom: 10px;
}

.calender_box_inner dl dt {
  font-size: 28px;
  font-weight: 800;
  background-color: #fff;
  text-align: center;
  width: 20%;
  height: 60px;
  line-height: 60px;
}

.calender_box_inner dl dd {
  display: flex;
  width: 80%;
  height: 60px;
  align-items: center;
}

.congestion_situation {
  font-size: 18px;
  font-weight: 800;
  width: 150px;
}

.situation_setails {
  font-size: 16px;
  font-weight: 500;
  padding: 0 1em;
  text-align: left;
}

.level_01 {
  background-color: #00fcff;
}

.level_02 {
  background-color: #41fabe;
}

.level_03 {
  background-color: #f9ffc3;
}

.level_04 {
  background-color: #e3e3e3;
}

.level_05 {
  background-color: #a5a5a5;
}



@media print,
screen and (min-width: 769px) {

  /* 基本設定 ====================*/
  /*html { overflow-y: scroll; }*/
  body {
    color: #000;
    line-height: 1.5;
  }

  img {
    max-width: 100%;
  }

  .wrapper {
    position: relative;
    padding-top: 87px;
  }

  a:link {
    color: #00bfb3;
    text-decoration: underline;
  }

  a:visited {
    color: #00bfb3;
    text-decoration: underline;
  }

  a:hover {
    color: #00bfb3;
    text-decoration: none;
  }

  a:active {
    color: #00bfb3;
  }

  .sp {
    display: none !important;
  }


  /* header ====================*/
  header.header {
    box-sizing: border-box;
    position: fixed;
    z-index: 100;
    top: 0;
    left: 0;
    width: 100%;
    transition: transform 0.5s ease;
    width: 100%;
    height: 87px;
    padding: 0 60px;
    background: #fff;
  }

  header.header .inner {
    position: relative;
    height: 100%;
  }

  header.header .header__title {
    position: absolute;
    top: 24px;
    left: 0;
  }

  header.header .header__title a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: #000;
    line-height: 1;
  }

  header.header .header__title a span.sub {
    display: block;
    font-size: 1.3rem;
    font-weight: 500;
    transform: rotateZ(0.03deg);
  }

  header.header .header__title a span.main {
    display: block;
    margin-top: 8px;
    font-size: 1.9rem;
    font-weight: 900;
    transform: rotateZ(0.03deg);
  }

  header.header .header__title a span.main span {
    font-weight: 500;
  }

  header.header .header__menu {
    display: none;
  }

  header.header .navigation {
    display: block !important;
  }

  header.header ul.header__link {
    display: flex;
    position: absolute;
    right: 70px;
    top: 37px;
  }

  header.header ul.header__link li {
    display: flex;
    align-items: center;
    margin-left: 28px;
    transform: rotateZ(0.03deg);
    transition: all 0.3s ease;
  }

  header.header ul.header__link li:nth-of-type(2) {
    margin-left: 0;
  }

  header.header ul.header__link li a {
    display: block;
    position: relative;
    padding-bottom: 9px;
    text-decoration: none;
    font-size: 1.4rem;
    font-weight: 700;
    color: #000;
    line-height: 1;
  }

  header.header ul.header__link li a::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 3px;
    background: linear-gradient(to right, #00fcff, #fff600);
    transition: transform 0.3s ease;
    transform: scaleX(0);
    transform-origin: right bottom;
  }

  header.header ul.header__link li a:hover::before {
    transition: transform 0.3s ease;
    transform: scaleX(1);
    transform-origin: left bottom;
  }

  header.header ul.header__link li.top {
    display: none;
  }

  header.header .header__logo--corporate {
    position: absolute;
    top: 20px;
    right: 0;
    width: 38px;
    height: 44px;
    background: url("images/logo_corporate_b.png") center center no-repeat;
  }

  header.header .header__logo--corporate a {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
  }

  header.header.none {
    transform: translateY(-100%);
  }

  body.program header.header ul.header__link li.program a::before {
    transform: scaleX(1);
  }

  body.instructor header.header ul.header__link li.instructor a::before {
    transform: scaleX(1);
  }

  body.message header.header ul.header__link li.message a::before {
    transform: scaleX(1);
  }

  body.voice header.header ul.header__link li.voice a::before {
    transform: scaleX(1);
  }

  body.qa header.header ul.header__link li.qa a::before {
    transform: scaleX(1);
  }

  body.school header.header ul.header__link li.school a::before {
    transform: scaleX(1);
  }

  /* footer ====================*/
  .footer {
    position: relative;
    background: #00bfb3;
  }

  .footer .footer__block:first-child {
    padding: 110px 60px 90px;
    background: url("images/footer_bg.jpg") center center no-repeat;
    background-size: cover;
  }

  .footer .footer__block:last-child {
    padding: 60px 40px;
  }

  .footer .btn__contact {
    max-width: 580px;
    height: 80px;
    margin: 0 auto;
  }

  .footer .btn__contact a {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-decoration: none;
    font-size: 2.4rem;
    font-weight: 900;
    color: #fff;
    line-height: 1;
    background: #00bfb3;
    border-radius: 40px;
    border: 2px solid #fff;
  }

  .footer .group {
    display: flex;
    flex-wrap: wrap;
    max-width: 1120px;
    margin: 60px auto 0;
    padding: 22px 30px 35px;
    background: #fff;
    border-radius: 6px;
  }

  .footer p.title {
    width: 100%;
    margin-bottom: 10px;
    padding-bottom: 20px;
    text-align: center;
    font-size: 18px;
    font-weight: 900;
    color: #00bfb3;
    line-height: 1;
    border-bottom: 1px solid #00bfb3;
  }

  .footer ul.footer__list {
    width: 47.768%;
  }

  .footer ul.footer__list li {
    position: relative;
    padding-left: 1.25em;
    font-size: 1.4rem;
    color: #000;
    line-height: 1.2;
    transform: rotateZ(0.03deg);
  }

  .footer ul.footer__list li span {
    position: absolute;
    top: 0;
    left: 0;
    font-weight: 700;
  }

  .footer ul.footer__list li.position::after {
    content: "（　　　）";
  }

  .footer ul.footer__list li+li {
    margin-top: 12px;
  }

  .footer ul+ul {
    margin-left: 4.464%;
  }

  .footer p.footer__title a {
    display: block;
    width: 100%;
    height: 100%;
    text-align: center;
    text-decoration: none;
    color: #fff;
    line-height: 1;
  }

  .footer p.footer__title a span.sub {
    display: block;
    font-size: 1.6rem;
    font-weight: 500;
    transform: rotateZ(0.03deg);
  }

  .footer p.footer__title a span.main {
    display: block;
    margin-top: 9px;
    font-size: 2.6rem;
    font-weight: 900;
  }

  .footer p.footer__title a span.main span {
    font-weight: 500;
  }

  .footer ul.footer__link {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 20px;
  }

  .footer ul.footer__link li {
    margin: 15px 15px 0;
    transform: rotateZ(0.03deg);
  }

  .footer ul.footer__link li a {
    text-decoration: none;
    font-size: 1.6rem;
    font-weight: 700;
    color: #fff;
    line-height: 1;
  }

  .footer p.footer__logo--corporate {
    /* width: 186px; */
    height: 33px;
    margin: 60px auto 0;
    background: url("images/logo_corporate_w.svg") center center no-repeat;
    background-size:100% 100%;
  }

  .footer p.footer__logo--corporate a {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
  }

  .footer p.footer__copyright {
    margin-top: 25px;
    text-align: center;
    font-size: 1.4rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 400;
    color: #fff;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  .footer .pagetop {
    position: absolute;
    right: 60px;
    bottom: 0;
    width: 38px;
    height: 106px;
    background: url("images/pagetop.svg") center center no-repeat;
    background-size: contain;
  }

  .footer .pagetop a {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
  }

  /* 共通パーツ ====================*/
  .bnr__contact {
    position: fixed;
    z-index: 100;
    top: calc(50% - 160px);
    right: 0;
    width: 40px;
    height: 253px;
    background: #00bfb3 url("images/bnr_contact.svg") center center no-repeat;
    background-size: contain;
    border-radius: 8px 0 0 8px;
  }

  .bnr__contact a {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
  }

  .bnr__calender {
    position: fixed;
    z-index: 100;
    top: calc(50% - -100px);
    right: 0;
    width: 40px;
    height: 40px;
    background: #00bfb3;
    background-size: contain;
    border-radius: 8px 0 0 8px;
    color: #fff;
  }

  .bnr__calender a {
    display: block;
    width: 100%;
    height: 100%;
    color: #fff;
    font-size: 23px;
    text-align: center;
  }

  .bnr__contact02 {
    display: none;
  }

  .btn__arrow {
    max-width: 300px;
    border-bottom: 2px solid #000;
  }

  .btn__arrow a {
    display: block;
    position: relative;
    padding: 15px 60px 30px 0;
    text-decoration: none;
    font-size: 1.8rem;
    font-weight: 700;
    color: #000;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  .btn__arrow a::before {
    content: "";
    box-sizing: border-box;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 50px;
    height: 50px;
    border: 2px solid #000;
    border-radius: 100%;
  }

  .btn__arrow a::after {
    content: "";
    display: block;
    position: absolute;
    top: 19px;
    right: 16px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 0 6px 12px;
    border-color: transparent transparent transparent #000;
  }

  .titlearea {
    padding: 0 60px;
  }

  .titlearea .inner h1.title {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    height: 400px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    border-radius: 8px;
  }

  .titlearea .inner h1.title span.main {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 6rem;
    font-weight: 900;
    color: #fff;
    line-height: 1;
  }

  .titlearea .inner h1.title span.sub {
    display: block;
    margin-top: 22px;
    text-align: center;
    font-size: 2.6rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    line-height: 1;
    background: linear-gradient(to right, #00fcff, #fff600);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .titlearea .inner p.text__lead {
    margin-top: 50px;
    text-align: center;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  .titlearea .inner p.text__lead span.kome {
    font-size: 1.4rem;
  }

  .titlearea .inner p.text {
    margin-top: 50px;
    font-size: 1.4rem;
    color: #666666;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  .contents {
    padding: 0 60px 160px;
  }

  /* TOP ====================*/
  body.top .wrapper {
    padding-top: 0;
  }

  @keyframes fadeIn {
    0% {
      opacity: 0;
    }

    100% {
      opacity: 1;
    }
  }

  body.top .mainvisual.visible {
    animation-name: fadeIn;
    animation-duration: 0.2s;
    animation-delay: 0.2s;
    animation-timing-function: linear;
    animation-fill-mode: forwards;
  }

  body.top .mainvisual {
    box-sizing: border-box;
    height: 100vh;
    padding: 87px 60px 0;
    opacity: 0;
  }

  body.top .mainvisual .inner {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    height: 100%;
    background: #ccc;
    border-radius: 8px 8px 0 0;
    background: url("images/mainvisual_bg.jpg") center center no-repeat;
    background-size: cover;
  }

  body.top .mainvisual .inner::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 50px;
    left: 0;
    width: 8px;
    height: 8px;
    background: url("images/mainvisual_circle_l.png") left bottom no-repeat;
  }

  body.top .mainvisual .inner::after {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    bottom: 50px;
    width: 8px;
    height: 8px;
    background: url("images/mainvisual_circle_r.png") left bottom no-repeat;
  }

  body.top .mainvisual .group {
    margin-top: -132px;
  }

  body.top .mainvisual p.mainvisual_text {
    text-align: center;
    font-size: 4rem;
    font-weight: 900;
    color: #fff;
    line-height: 1;
  }

  body.top .mainvisual p.mainvisual_text br {
    display: none;
  }

  body.top .mainvisual p.mainvisual_title {
    display: table;
    margin: 50px auto 0;
  }

  body.top .mainvisual p.mainvisual_text__sub {
    margin-top: 50px;
    text-align: center;
    font-size: 2rem;
    font-weight: 700;
    color: #fff;
    line-height: 2.5;
    transform: rotateZ(0.03deg);
  }

  body.top .mainvisual .scroll {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 78px;
    background: url("images/mainvisual_scroll.png") center bottom no-repeat;
  }

  body.top .mainvisual .scroll a {
    display: block;
    width: 86px;
    height: 66px;
    margin: 0 auto;
    opacity: 0;
  }

  body.top .contents {
    padding-right: 0;
    padding-left: 0;
  }

  body.top h2.title__border {
    box-sizing: border-box;
    position: relative;
    padding-left: 25px;
  }

  body.top h2.title__border::before {
    content: "";
    display: block;
    position: absolute;
    top: 0.75em;
    left: 0;
    width: 6px;
    height: calc(100% - 0.75em);
    background: linear-gradient(to bottom, #00fcff, #fff600);
  }

  body.top h2.title__border span.main {
    display: block;
    margin-top: -0.15em;
    font-size: 4.6rem;
    font-weight: 900;
    line-height: 1.3;
  }

  body.top h2.title__border span.sub {
    display: block;
    margin-top: 10px;
    font-size: 2rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    line-height: 1;
  }

  body.top .section01 {
    padding: 50px 60px 0;
  }

  body.top .section01 h2.title {
    position: relative;
    z-index: 1;
    width: 140px;
    margin: 10px auto 0;
    padding: 15px 0;
    text-align: center;
    font-size: 2.2rem;
    font-weight: 900;
    color: #00bfb3;
    line-height: 1;
    background: #fff;
    border: 3px solid #e5f8f7;
    border-radius: 8px;
  }

  body.top .section01 .column {
    position: relative;
    z-index: 0;
    display: flex;
    max-width: 1120px;
    margin: -29px auto 0;
  }

  body.top .section01 .column .cell {
    box-sizing: border-box;
    width: calc((100% - 4px) / 3);
    padding: 60px 10px 45px;
    background: #e5f8f7;
    border-radius: 8px;
  }

  body.top .section01 .column .cell+.cell {
    margin-left: 2px;
  }

  body.top .section01 h4.title {
    text-align: center;
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1;
  }

  body.top .section01 figure.img {
    margin-top: 25px;
    text-align: center;
  }

  body.top .section01 p.text__number {
    margin-top: 25px;
    text-align: center;
    color: #00bfb3;
    line-height: 1;
  }

  body.top .section01 p.text__number strong {
    font-size: 7.2rem;
    font-weight: 900;
    transition: font-size 0.2s ease;
  }

  body.top .section01 p.text__number span {
    font-size: 3.4rem;
    font-weight: 700;
  }

  body.top .section01 p.text {
    margin-top: 12px;
    text-align: center;
    font-size: 1.4rem;
    line-height: 1.2;
    transform: rotateZ(0.03deg);
  }

  body.top .section01 p.text br {
    display: none;
  }

  body.top .section01 .btn__arrow {
    margin: 40px auto 0;
  }

  body.top .section02 {
    margin-top: 100px;
    padding: 0 60px;
  }

  body.top .section02 .inner {
    max-width: 1120px;
    margin: 0 auto;
    padding-bottom: 120px;
    background: url("images/section02_bg.png") right bottom no-repeat;
  }

  body.top .section02 .column {
    display: flex;
    margin-top: 45px;
  }

  body.top .section02 .column .cell:first-child {
    width: calc(100% - 286px - 5.357%);
  }

  body.top .section02 .column .cell:last-child {
    width: 286px;
    margin-left: 5.357%;
  }

  body.top .section02 ul.list__news {
    border-top: 1px solid #ebebeb;
  }

  body.top .section02 ul.list__news li {
    padding: 18px 0 15px;
    border-bottom: 1px solid #ebebeb;
  }

  body.top .section02 ul.list__news li p.date {
    margin-bottom: 10px;
    font-size: 1.4rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 400;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.top .section02 ul.list__news li p.text {
    font-size: 1.6rem;
    transform: rotateZ(0.03deg);
  }

  body.top .section03 {
    position: relative;
    padding-top: 78px;
  }

  body.top .section03::before {
    content: "";
    display: block;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 60px;
    width: calc(100% - 120px);
    height: 100%;
    background: #e5f8f7 url("images/bg_common.png") center top no-repeat;
    border-radius: 8px;
  }

  body.top .section03::after {
    content: "";
    display: block;
    position: relative;
    z-index: 1;
    width: calc(100% - 120px);
    height: 98px;
    margin: 70px auto;
    background: url("images/section03_bg.png") center bottom no-repeat;
    border-radius: 8px;
  }

  body.top .section03>.inner {
    position: relative;
    z-index: 1;
    padding: 0 60px;
  }

  body.top .section03 h2.title {
    padding: 0 60px;
    text-align: center;
  }

  body.top .section03 p.text__lead {
    margin-top: 20px;
    padding: 0 60px;
    text-align: center;
    font-size: 1.6rem;
    line-height: 1.75;
    transform: rotateZ(0.03deg);
  }

  body.top .section03 figure.section03__img01 {
    position: relative;
    z-index: 1;
    margin-top: 40px;
  }

  body.top .section03 figure.section03__img01 img {
    width: 100%;
  }

  body.top .section03 .column {
    box-sizing: border-box;
    display: flex;
    position: relative;
    max-width: 1200px;
    margin: 70px auto 0;
    padding: 0 50px;
  }

  body.top .section03 .column .cell:first-child {
    width: 310px;
  }

  body.top .section03 .column .cell:last-child {
    width: calc(100% - 310px - 4.545%);
    margin-left: 4.545%;
  }

  body.top .section03 .column .btn__arrow {
    position: absolute;
    top: 240px;
    left: 50px;
    width: 300px;
  }

  body.top .section03 h3.title {
    margin-top: -0.05em;
    font-size: 4.4rem;
    line-height: 1.4;
    font-weight: 900;
  }

  body.top .section03 p.text {
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.top .section03 .group {
    box-sizing: border-box;
    max-width: 1200px;
    margin: 72px auto 0;
    padding: 0 50px;
  }

  body.top .section03 .group .inner {
    padding: 50px 50px 60px;
    background: #fff;
    border-radius: 8px;
  }

  body.top .section03 h4.title {
    text-align: center;
    font-size: 3rem;
    line-height: 1;
    font-weight: 900;
  }

  body.top .section03 ul.list__features {
    display: flex;
    margin-top: 20px;
  }

  body.top .section03 ul.list__features li {
    position: relative;
    width: 33.3333333333%;
    padding-top: 170px;
  }

  body.top .section03 ul.list__features li figure.img {
    position: absolute;
    top: 0;
    left: 0;
  }

  body.top .section03 ul.list__features li p.text {
    padding: 0 20px;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.top .section04 {
    margin-top: 120px;
  }

  body.top .section04>.inner {
    padding: 0 60px 50px;
    background: url("images/section04_bg.png") right bottom no-repeat;
  }

  body.top .section04>.inner h2.title__border {
    max-width: 1240px;
    margin: 0 auto;
  }

  body.top .section04>.inner>p.text {
    box-sizing: border-box;
    max-width: 1240px;
    margin: 35px auto 0;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.top .section04 ul.slick__program li.slick-slide {
    position: relative;
    margin: 0 0.75vw;
  }

  body.top .section04 ul.slick__program li.slick-slide img {
    position: relative;
    z-index: 0;
    width: 100%;
    border-radius: 8px;
  }

  body.top .section04 ul.slick__program li.slick-slide .inner {
    box-sizing: border-box;
    display: block;
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 2vw 2.272vw 2.272vw;
    text-decoration: none;
    color: #fff;
  }

  body.top .section04 ul.slick__program li.slick-slide .inner::before {
    content: "";
    box-sizing: border-box;
    display: block;
    position: absolute;
    right: 2.272vw;
    bottom: 2.272vw;
    width: 3.78vw;
    height: 3.78vw;
    border: 0.15vw solid #fff;
    border-radius: 100%;
  }

  body.top .section04 ul.slick__program li.slick-slide .inner::after {
    content: "";
    display: block;
    position: absolute;
    right: 3.6vw;
    bottom: 3.7vw;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0.45vw 0 0.45vw 0.9vw;
    border-color: transparent transparent transparent #fff;
  }

  body.top .section04 ul.slick__program li.slick-slide p.number {
    font-size: 2.424vw;
    font-weight: 900;
    line-height: 1;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title {
    margin-top: 4.5vw;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.sub {
    display: block;
    font-size: 1.363vw;
    font-weight: 700;
    line-height: 1;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.main {
    display: flex;
    margin-top: 1.36vw;
    font-size: 3vw;
    font-weight: 900;
    line-height: 1;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.main span {
    display: block;
    padding-top: 0.3em;
    font-size: 1.8vw;
    font-weight: 700;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.main span.logo {
    position: relative;
    padding-top: 0;
    padding-bottom: 1.742vw;
    font-size: 1.6vw;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.main span.logo::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: calc(50% - 2.2725vw);
    width: 4.545vw;
    height: 1.742vw;
    background: url("images/logo_doda_white.svg") center center no-repeat;
    background-size: cover;
  }

  body.top .section04 ul.slick__program li.slick-slide p.text {
    width: 45vw;
    margin-top: 3vw;
    font-size: 1.2vw;
    line-height: 2;
  }

  body.top .section04 ul.slick-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 20px;
  }

  body.top .section04 ul.slick-dots li {
    width: 10px;
    height: 10px;
    margin: 0 10px;
    background-color: #000000;
    border-radius: 50%;
    transition: background-color 0.2s;
  }

  body.top .section04 ul.slick-dots li:hover {
    background-color: #00bfb3;
  }

  body.top .section04 ul.slick-dots li button {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
  }

  body.top .section04 ul.slick-dots li.slick-active {
    background-color: #00bfb3;
  }

  body.top .section04 .btn__arrow {
    margin: 60px auto 0;
  }

  body.top .section05 {
    margin-top: 60px;
    padding: 60px 60px 0;
    background: url("images/section05_bg.png") left 15px top no-repeat;
  }

  body.top .section05 .inner {
    max-width: 1120px;
    margin: 0 auto;
  }

  body.top .section05 .column {
    display: flex;
    position: relative;
  }

  body.top .section05 .column .cell:first-child {
    width: 400px;
    padding: 25px 0 120px;
  }

  body.top .section05 .column .cell:last-child {
    width: calc(100% - 400px - 6.25%);
    margin-left: 6.25%;
  }

  body.top .section05 p.text {
    margin-top: 40px;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.top .section05 figure.section05__img01 img {
    border-radius: 8px;
  }

  body.top .section05 .btn__arrow {
    position: absolute;
    top: 390px;
    left: 0;
    width: 300px;
  }

  body.top .section06 {
    margin-top: 120px;
    padding: 0 60px 120px;
    background: url("images/section06_bg.png") right bottom no-repeat;
  }

  body.top .section06 .inner {
    max-width: 1120px;
    margin: 0 auto;
  }

  body.top .section06 p.text {
    margin-top: 40px;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.top .section06 h4.title {
    margin-top: 50px;
    text-align: center;
    font-size: 2.2rem;
    line-height: 1;
    font-weight: 900;
  }

  body.top .section06 figure.section06__img01 {
    margin-top: 20px;
    text-align: center;
  }

  body.top .section07 {
    position: relative;
    padding: 100px 60px 120px;
    background: #e5f8f7 url("images/bg_common.png") center top no-repeat;
  }

  body.top .section07::before {
    content: "";
    display: block;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("images/section07_bg.png") left center no-repeat;
  }

  body.top .section07 .inner {
    position: relative;
    z-index: 1;
    max-width: 1120px;
    margin: 0 auto;
  }

  body.top .section07 p.text {
    margin-top: 40px;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.top .section07 dl.list__voice {
    max-width: 977px;
    margin: 55px auto 0;
  }

  body.top .section07 dl.list__voice .group {
    display: flex;
    align-items: flex-start;
  }

  body.top .section07 dl.list__voice .group:nth-child(odd) dt {
    margin-right: 30px;
  }

  body.top .section07 dl.list__voice .group:nth-child(odd) dd::before {
    content: "";
    display: block;
    position: absolute;
    top: 26px;
    left: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 11px 20px 11px 0;
    border-color: transparent #fff transparent transparent;
  }

  body.top .section07 dl.list__voice .group:nth-child(even) {
    justify-content: flex-end;
  }

  body.top .section07 dl.list__voice .group:nth-child(even) dt {
    order: 2;
    margin-left: 30px;
  }

  body.top .section07 dl.list__voice .group:nth-child(even) dd {
    order: 1;
  }

  body.top .section07 dl.list__voice .group:nth-child(even) dd::after {
    content: "";
    display: block;
    position: absolute;
    top: 26px;
    right: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 11px 0 11px 20px;
    border-color: transparent transparent transparent #fff;
  }

  body.top .section07 dl.list__voice dt {
    width: 130px;
    height: 130px;
    background: #fff;
    border-radius: 100%;
  }

  body.top .section07 dl.list__voice dd {
    box-sizing: border-box;
    position: relative;
    width: 64.484%;
    padding: 22px 30px 30px;
    font-size: 1.4rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
    background: #fff;
    border-radius: 8px;
  }

  body.top .section07 dl.list__voice dd span {
    display: block;
    margin-top: 12px;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.top .section07 dl.list__voice .group+.group {
    margin-top: 40px;
  }

  body.top .section07 .btn__arrow {
    margin: 60px auto 0;
  }

  body.top .section08 {
    margin-top: 120px;
    padding: 0 60px;
    background: url("images/section08_bg.png") left top 225px no-repeat;
  }

  body.top .section08 .inner {
    max-width: 1120px;
    margin: 0 auto;
  }

  body.top .section08 .column {
    display: flex;
    position: relative;
  }

  body.top .section08 .column .cell:first-child {
    width: 210px;
  }

  body.top .section08 .column .cell:last-child {
    width: calc(100% - 210px - 6.25%);
    margin-left: 6.25%;
  }

  body.top .section08 dl.list__qa .group {
    border-left: 3px solid #00bfb3;
  }

  body.top .section08 dl.list__qa dt {
    position: relative;
    padding: 18px 30px 18px 4em;
    font-size: 1.6rem;
    line-height: 1.75;
    transform: rotateZ(0.03deg);
  }

  body.top .section08 dl.list__qa dt::before {
    content: "Q";
    display: block;
    position: absolute;
    top: 15px;
    left: 24px;
    font-size: 3rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    line-height: 1;
  }

  body.top .section08 dl.list__qa dd {
    position: relative;
    padding: 18px 30px 18px 4em;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.75;
    transform: rotateZ(0.03deg);
    background: #e5f8f7;
  }

  body.top .section08 dl.list__qa dd::before {
    content: "A";
    display: block;
    position: absolute;
    top: 15px;
    left: 24px;
    font-size: 3rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    color: #00bfb3;
    line-height: 1;
  }

  body.top .section08 dl.list__qa .group+.group {
    margin-top: 30px;
  }

  body.top .section08 .btn__arrow {
    position: absolute;
    top: 190px;
    left: 0;
    width: 210px;
  }

  /* プログラム ====================*/
  body.program .titlearea .inner h1.title {
    background-image: url("images/program/title_bg.jpg");
  }

  body.program .contents {
    margin-top: 50px;
  }

  body.program .anchor {
    box-sizing: border-box;
    max-width: 1120px;
    margin: 0 auto 80px;
    padding: 30px;
    background: #f5f5f5;
    border-radius: 8px;
  }

  body.program .anchor ul.list__anchor {
    display: flex;
    flex-wrap: wrap;
  }

  body.program .anchor ul.list__anchor li {
    width: 49.057%;
    background: #fff;
  }

  body.program .anchor ul.list__anchor li:nth-of-type(even) {
    margin-left: 1.886%;
  }

  body.program .anchor ul.list__anchor li:nth-of-type(n+3) {
    margin-top: 1.886%;
  }

  body.program .anchor ul.list__anchor li:nth-of-type(1) a::before {
    content: "01";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(2) a::before {
    content: "02";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(3) a::before {
    content: "03";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(4) a::before {
    content: "04";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(5) a::before {
    content: "05";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(6) a::before {
    content: "06";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(7) a::before {
    content: "07";
  }

  body.program .anchor ul.list__anchor li a {
    display: flex;
    width: 100%;
    height: 100%;
    min-height: 60px;
    text-decoration: none;
    color: #000;
  }

  body.program .anchor ul.list__anchor li a::before {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    text-align: center;
    font-size: 2.6rem;
    font-weight: 900;
    line-height: 1;
  }

  body.program .anchor ul.list__anchor li a p {
    box-sizing: border-box;
    display: flex;
    align-content: center;
    flex-wrap: wrap;
    position: relative;
    width: calc(100% - 80px);
    padding: 10px 60px 10px 20px;
    align-items: center;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.2;
    transform: rotateZ(0.03deg);
    border-left: 1px solid #f5f5f5;
  }

  body.program .anchor ul.list__anchor li a p::before {
    content: "";
    position: absolute;
    top: calc(50% - 18px);
    right: 12px;
    width: 36px;
    height: 36px;
    background: #00e4ed;
    border-radius: 100%;
  }

  body.program .anchor ul.list__anchor li a p::after {
    content: "";
    position: absolute;
    top: calc(50% - 7px);
    right: 25px;
    width: 8px;
    height: 8px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(135deg);
  }

  body.program .anchor ul.list__anchor li a p span {
    display: block;
    width: 100%;
    margin-top: 0.25em;
    font-size: 1.4rem;
  }

  body.program .anchor ul.list__anchor li a p span img.logo {
    width: 47px;
    height: 18px;
  }

  body.program .section {
    max-width: 1120px;
    margin: 0 auto;
    padding-top: 90px;
  }

  body.program .section+.section {
    margin-top: 50px;
  }

  body.program h2.title {
    box-sizing: border-box;
    position: relative;
    min-height: 130px;
    padding-left: 182px;
  }

  body.program h2.title::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 145px;
    width: 6px;
    height: 100%;
    background: linear-gradient(to bottom, #00fcff, #fff600);
  }

  body.program h2.title span.number {
    display: block;
    position: absolute;
    top: -11px;
    left: 0;
    font-size: 9rem;
    font-weight: 900;
    line-height: 1;
  }

  body.program h2.title span.sub {
    display: block;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.program h2.title span.main {
    display: flex;
    flex-wrap: wrap;
    margin-top: 20px;
    font-size: 4rem;
    font-weight: 900;
    line-height: 1;
  }

  body.program h2.title span.main span {
    display: block;
    padding-top: 0.3em;
    font-size: 2.4rem;
    font-weight: 700;
    white-space: nowrap;
  }

  body.program h2.title span.main span.logo {
    position: relative;
    padding-top: 0;
    padding-bottom: 23px;
    font-size: 2.2rem;
  }

  body.program h2.title span.main span.logo::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: calc(50% - 30px);
    width: 60px;
    height: 23px;
    background: url("images/logo_doda_blue.svg") center center no-repeat;
    background-size: cover;
  }

  body.program .mainimg {
    overflow: hidden;
    position: relative;
    height: 400px;
    border-radius: 8px;
  }

  body.program .mainimg dl {
    box-sizing: border-box;
    position: absolute;
    bottom: 20px;
    left: 20px;
    min-width: 400px;
    padding: 30px;
    font-size: 1.6rem;
    line-height: 1;
    transform: rotateZ(0.03deg);
    background: #fff;
    border-radius: 8px;
  }

  body.program .mainimg dl .group {
    display: flex;
  }

  body.program .mainimg dl .group+.group {
    margin-top: 18px;
  }

  body.program .mainimg dl dt {
    width: 110px;
    font-weight: 700;
  }

  body.program .mainimg img {
    max-width: none;
  }

  body.program p.text {
    margin-top: 30px;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.program .recommend {
    display: flex;
    margin-top: 32px;
    padding: 10px 0;
    border-top: 1px solid #ebebeb;
    border-bottom: 1px solid #ebebeb;
  }

  body.program .recommend h3.title {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 190px;
    font-size: 1.8rem;
    background: #e5f8f7;
    border-radius: 8px;
    transform: rotateZ(0.03deg);
  }

  body.program .recommend ul.list__recommend {
    box-sizing: border-box;
    width: calc(100% - 190px);
    padding: 15px 30px;
  }

  body.program .recommend ul.list__recommend li {
    position: relative;
    padding-left: 22px;
    font-size: 1.8rem;
    transform: rotateZ(0.03deg);
  }

  body.program .recommend ul.list__recommend li::before {
    content: "";
    display: block;
    position: absolute;
    top: 0.35em;
    left: 0;
    width: 15px;
    height: 15px;
    background: #03fcfc;
    border-radius: 100%;
  }

  body.program .recommend ul.list__recommend li+li {
    margin-top: 0.5em;
  }

  body.program .column {
    display: flex;
    margin-top: 40px;
  }

  body.program .column .cell {
    width: 48.2145%;
  }

  body.program .column .cell+.cell {
    margin-left: 3.571%;
  }

  body.program .column h3.title {
    padding: 15px 20px;
    font-size: 1.8rem;
    line-height: 1;
    transform: rotateZ(0.03deg);
    background: #e5f8f7;
    border-radius: 8px;
  }

  body.program .column figure {
    margin-top: 20px;
  }

  body.program .column figure figcaption {
    margin-bottom: 0.5em;
    font-size: 1.6rem;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.program .notice {
    font-size: 1.5rem;
    transform: rotateZ(0.03deg);
    padding: 10px 0;
  }

  body.program section.section.program_package {
    padding-top: 60px;
  }

  .program_package_inner {
    padding-top: 60px;
    margin-top: -60px;
  }

  .ttl_program {
    font-size: 40px;
    text-align: center;
    font-weight: 800;
    padding: 1em 0;
  }

  .programp_txt {
    padding: 1em 0;
  }

  .pp_th p,
  .pp_type_name,
  .pp_parts_name,
  .pp_frames {
    font-size: 24px;
    font-weight: 800;
    line-height: 1.2em;
  }

  .programp_txt,
  .pp_breakdown,
  .pp_caption {
    font-size: 16px;
  }

  .pp_table tr th,
  .pp_table tr td {
    width: calc(100%/3);
    border: solid 1px #d9d9d9;
    text-align: center;
    vertical-align: middle;
    padding: 20px 10px;
    box-sizing: border-box;
  }

  .pp_table tr th.no_border {
    border: none;
  }

  .pp_th {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .pp_th img {
    max-width: 100%;
    width: auto;
  }

  .pp_th p {
    padding-left: 0.5em;
  }

  .pp_table tr td.pp_type_box {
    position: relative;
    text-align: center;
    border: none;
  }

  .table_c01 {
    background-color: #ff9900;
  }

  .table_c02 {
    background-color: #ffcc00;
  }

  .table_c03 {
    background-color: #0066cc;
  }

  .table_c04 {
    background-color: #0099ff;
  }

  .table_c05 {
    background-color: #ff5050;
  }

  .table_c01::before,
  .table_c02::before,
  .table_c03::before,
  .table_c04::before,
  .table_c05::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 100%;
    margin-top: -15px;
    border: 15px solid transparent;
  }

  .table_c01::before {
    border-left: 15px solid #ff9900;
  }

  .table_c02::before {
    border-left: 15px solid #ffcc00;
  }

  .table_c03::before {
    border-left: 15px solid #0066cc;
  }

  .table_c04::before {
    border-left: 15px solid #0099ff;
  }

  .table_c05::before {
    border-left: 15px solid #ff5050;
  }

  .table_c03 .pp_type_name {
    color: #fff;
  }

  .pp_explanation {
    display: inline-block;
    font-size: 16px;
    background-color: #fff;
    padding: 5px 15px;
    border-radius: 50px;
  }

  .pp_explanation br {
    display: none;
  }

  .pp_type_name {
    display: inline-block;
    padding-top: 15px;
  }

  .pp_type_name br {
    display: none;
  }

  .pp_parts_name {
    background-color: #e5f8f7;
    padding: 5px 20px;
    border-radius: 15px;
    display: inline-block;
    margin-bottom: 5px;
  }

  td .fa-plus {
    display: block;
    font-size: 23px;
    color: #03fcfc;
    margin-bottom: 5px;
  }

  .pp_choice {
    margin-bottom: 5px;
    font-size: 14px;
  }

  .pp_caption {
    margin-top: 1em;
    margin-bottom: 80px;
    line-height: 1.5em;
    font-weight: 400;
  }

  .pp_caption span {
    font-weight: 700;
  }


  /* 講師プロフィール ====================*/
  body.instructor .titlearea .inner h1.title {
    background-image: url("images/instructor/title_bg.jpg");
  }

  body.instructor .contents {
    margin-top: 50px;
  }

  body.instructor .section {
    max-width: 1120px;
    margin: 0 auto;
    padding-bottom: 60px;
    border-bottom: 1px solid #ebebeb;
  }

  body.instructor .section:first-child {
    padding-top: 60px;
    border-top: 1px solid #ebebeb;
  }

  body.instructor .section+.section {
    margin-top: 60px;
  }

  body.instructor .column {
    display: flex;
  }

  body.instructor .column .cell:first-child {
    width: 250px;
  }

  body.instructor .column .cell:last-child {
    width: calc(100% - 250px - 4.464%);
  }

  body.instructor .column .cell+.cell {
    margin-left: 4.464%;
  }

  body.instructor .column figure {
    overflow: hidden;
    border-radius: 8px;
  }

  body.instructor .column h2.title {
    box-sizing: border-box;
    position: relative;
    padding: 8px 0 10px 25px;
  }

  body.instructor .column h2.title::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 6px;
    height: 100%;
    background: linear-gradient(to bottom, #00fcff, #fff600);
  }

  body.instructor .column h2.title span.main {
    display: flex;
    align-items: center;
    font-size: 2.8rem;
    font-weight: 900;
    line-height: 1;
  }

  body.instructor .column h2.title span.main span {
    display: block;
    margin: 0.15em 0 0 1.25em;
    font-size: 1.6rem;
    font-weight: 700;
    white-space: nowrap;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column h2.title span.sub {
    display: block;
    margin-top: 10px;
    font-size: 1.4rem;
    font-weight: 400;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column p.text {
    margin-top: 30px;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column .career h3.title {
    position: relative;
    margin-top: 20px;
  }

  body.instructor .column .career h3.title::after {
    content: "";
    display: block;
    position: absolute;
    z-index: 0;
    top: 0.65em;
    left: 0;
    width: 100%;
    height: 1px;
    border-top: 1px solid #ebebeb;
  }

  body.instructor .column .career h3.title span {
    display: table;
    position: relative;
    z-index: 1;
    padding-right: 1em;
    font-size: 1.4rem;
    line-height: 1;
    transform: rotateZ(0.03deg);
    background: #fff;
  }

  body.instructor .column .career ul.list__career {
    margin-top: 15px;
    padding-bottom: 20px;
    border-bottom: 1px solid #ebebeb;
  }

  body.instructor .column .career ul.list__career li {
    font-size: 1.4rem;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column .career ul.list__career li+li {
    margin-top: 0.5em;
  }

  body.instructor .column .topics {
    margin-top: 25px;
    padding: 18px 20px;
    background: #f5f5f5;
    border-radius: 8px;
  }

  body.instructor .column .topics h3.title {
    font-size: 1.4rem;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column .topics p.text {
    margin-top: 10px;
    font-size: 1.4rem;
    transform: rotateZ(0.03deg);
  }

  p.text__note {
    max-width: 1120px;
    margin: 60px auto 0;
    font-size: 1.4rem;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  /* 私たちの想い ====================*/
  body.message .titlearea .inner h1.title {
    background-image: url("images/message/title_bg.jpg");
  }

  body.message .contents {
    margin-top: 80px;
  }

  body.message .section {
    max-width: 1120px;
    margin: 0 auto;
  }

  body.message .section+.section {
    margin-top: 70px;
    padding-top: 80px;
    border-top: 1px solid #ebebeb;
  }

  body.message .column {
    display: flex;
  }

  body.message .column .cell:first-child {
    width: 45.536%;
  }

  body.message .column .cell:last-child {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    width: 50%;
    margin-left: 4.464%;
  }

  body.message figure {
    overflow: hidden;
    border-radius: 8px;
  }

  body.message h2.title {
    width: 100%;
    margin-top: -0.5em;
    font-size: 3.2rem;
    line-height: 1.65;
    white-space: nowrap;
  }

  body.message p.name {
    width: 100%;
    margin-top: 35px;
  }

  body.message p.name span.sub {
    display: block;
    font-size: 1.4rem;
    font-weight: 400;
    transform: rotateZ(0.03deg);
  }

  body.message p.name span.main {
    display: flex;
    margin-top: 10px;
    align-items: center;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1;
  }

  body.message p.name span.main span {
    display: block;
    margin: 0.15em 0 0 1.25em;
    font-size: 1.6rem;
    white-space: nowrap;
    transform: rotateZ(0.03deg);
  }

  body.message p.text {
    max-width: 920px;
    margin: 50px auto 0;
    font-size: 1.6rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  /* 参加者の声 ====================*/
  body.voice .titlearea .inner h1.title {
    background-image: url("images/voice/title_bg.jpg");
  }

  body.voice .contents {
    margin-top: 60px;
    padding-top: 100px;
    background: #e5f8f7 url("images/bg_common.png") center center repeat-y;
  }

  body.voice .section {
    max-width: 1120px;
    margin: 0 auto;
  }

  body.voice .section+.section {
    margin-top: 150px;
  }

  body.voice h2.title {
    box-sizing: border-box;
    display: table;
    position: relative;
    margin: 0 auto;
    padding-bottom: 20px;
    font-size: 3.4rem;
    font-weight: 900;
    line-height: 1;
  }

  body.voice h2.title::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 6px;
    background: linear-gradient(to right, #00fcff, #fff600);
  }

  body.voice h3.title {
    display: table;
    margin: 60px auto 0;
    font-size: 2.6rem;
    font-weight: 700;
    line-height: 1;
  }

  body.voice dl.list__voice {
    max-width: 977px;
    margin: 55px auto 0;
  }

  body.voice dl.list__voice dt {
    width: 130px;
    height: 130px;
    background: #fff;
    border-radius: 100%;
  }

  body.voice dl.list__voice dd {
    box-sizing: border-box;
    position: relative;
    width: 64.484%;
    padding: 22px 30px 30px;
    font-size: 1.4rem;
    line-height: 2;
    transform: rotateZ(0.03deg);
    background: #fff;
    border-radius: 8px;
  }

  body.voice dl.list__voice dd span {
    display: block;
    margin-top: 12px;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.voice dl.list__voice .group+.group {
    margin-top: 40px;
  }

  body.voice dl.list__voice01 .group {
    display: flex;
    align-items: flex-start;
  }

  body.voice dl.list__voice01 .group:nth-child(odd) dt {
    margin-right: 30px;
  }

  body.voice dl.list__voice01 .group:nth-child(odd) dd::before {
    content: "";
    display: block;
    position: absolute;
    top: 26px;
    left: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 11px 20px 11px 0;
    border-color: transparent #fff transparent transparent;
  }

  body.voice dl.list__voice01 .group:nth-child(even) {
    justify-content: flex-end;
  }

  body.voice dl.list__voice01 .group:nth-child(even) dt {
    order: 2;
    margin-left: 30px;
  }

  body.voice dl.list__voice01 .group:nth-child(even) dd {
    order: 1;
  }

  body.voice dl.list__voice01 .group:nth-child(even) dd::after {
    content: "";
    display: block;
    position: absolute;
    top: 26px;
    right: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 11px 0 11px 20px;
    border-color: transparent transparent transparent #fff;
  }

  body.voice dl.list__voice02 .group {
    display: flex;
    align-items: flex-start;
  }

  body.voice dl.list__voice02 .group:nth-child(even) dt {
    margin-right: 30px;
  }

  body.voice dl.list__voice02 .group:nth-child(even) dd::before {
    content: "";
    display: block;
    position: absolute;
    top: 26px;
    left: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 11px 20px 11px 0;
    border-color: transparent #fff transparent transparent;
  }

  body.voice dl.list__voice02 .group:nth-child(odd) {
    justify-content: flex-end;
  }

  body.voice dl.list__voice02 .group:nth-child(odd) dt {
    order: 2;
    margin-left: 30px;
  }

  body.voice dl.list__voice02 .group:nth-child(odd) dd {
    order: 1;
  }

  body.voice dl.list__voice02 .group:nth-child(odd) dd::after {
    content: "";
    display: block;
    position: absolute;
    top: 26px;
    right: -20px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 11px 0 11px 20px;
    border-color: transparent transparent transparent #fff;
  }

  body.voice ul.ul-btn {
    max-width: 620px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 40px auto 60px;
  }

  body.voice ul.ul-btn li {
    box-sizing: border-box;
    position: relative;
    width: 300px;
  }

  body.voice ul.ul-btn li a {
    display: block;
    text-decoration: none;
    padding: 20px 50px;
    color: #000;
    border-radius: 30px;
    border: 1px solid #dcdcdc;
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1;
    position: relative;
  }

  body.voice ul.ul-btn li a::before {
    content: "";
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border-radius: 100%;
    background: #00e4ed;
  }

  body.voice ul.ul-btn li a::after {
    content: "";
    position: absolute;
    top: 23px;
    right: 25px;
    width: 8px;
    height: 8px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(135deg);
  }


  /* よくある質問 ====================*/
  body.qa .titlearea .inner h1.title {
    background-image: url("images/qa/title_bg.jpg");
  }

  body.qa .contents {
    margin-top: 80px;
  }

  body.qa .section {
    max-width: 840px;
    margin: 0 auto;
  }

  body.qa dl.list__qa .group {
    border-left: 3px solid #00bfb3;
  }

  body.qa dl.list__qa dt {
    position: relative;
    padding: 18px 30px 18px 4em;
    font-size: 1.6rem;
    line-height: 1.75;
    transform: rotateZ(0.03deg);
  }

  body.qa dl.list__qa dt::before {
    content: "Q";
    display: block;
    position: absolute;
    top: 15px;
    left: 24px;
    font-size: 3rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    line-height: 1;
  }

  body.qa dl.list__qa dd {
    position: relative;
    padding: 18px 30px 18px 4em;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.75;
    transform: rotateZ(0.03deg);
    background: #e5f8f7;
  }

  body.qa dl.list__qa dd::before {
    content: "A";
    display: block;
    position: absolute;
    top: 15px;
    left: 24px;
    font-size: 3rem;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    color: #00bfb3;
    line-height: 1;
  }

  body.qa dl.list__qa .group+.group {
    margin-top: 30px;
  }

  /* 実施校一覧 ====================*/
  body.school .titlearea .inner h1.title {
    background-image: url("images/school/title_bg.jpg");
  }

  body.school .contents {
    margin-top: 50px;
  }

  body.school .maparea {
    max-width: 980px;
    margin: 0 auto 20px;
  }

  body.school .maparea .column {
    display: flex;
  }

  body.school .maparea .column .cell {
    width: 48.98%;
  }

  body.school .maparea .column .cell+.cell {
    display: flex;
    align-items: center;
    margin-left: 2.04%;
  }

  body.school .maparea ul.list__anchor {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
  }

  body.school .maparea ul.list__anchor li {
    box-sizing: border-box;
    position: relative;
    width: 46.875%;
    height: 60px;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(even) {
    margin-left: 6.25%;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(n+3) {
    margin-top: 6.25%;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(1) a::before {
    background: #00e4ed;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(1) a span::before {
    background: #00e4ed;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(2) a::before {
    background: #00edce;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(2) a span::before {
    background: #00edce;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(3) a::before {
    background: #00edce;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(3) a span::before {
    background: #00edce;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(4) a::before {
    background: #00e573;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(4) a span::before {
    background: #00e573;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(5) a::before {
    background: #00e573;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(5) a span::before {
    background: #00e573;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(6) a::before {
    background: #a2e209;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(6) a span::before {
    background: #a2e209;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(7) a::before {
    background: #e7ef00;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(7) a span::before {
    background: #e7ef00;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(8) a::before {
    background: #b7dbd9;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(8) a span::before {
    background: #b7dbd9;
  }

  body.school .maparea ul.list__anchor li a {
    box-sizing: border-box;
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
  }

  body.school .maparea ul.list__anchor li a::before {
    content: "";
    display: block;
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 8px;
    height: 60px;
  }

  body.school .maparea ul.list__anchor li a span {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 0 50px 0 20px;
    font-size: 1.7rem;
    font-weight: 700;
    color: #000;
    line-height: 1.2;
    transform: rotateZ(0.03deg);
    border: 1px solid #dcdcdc;
    border-radius: 0 60px 60px 0;
  }

  body.school .maparea ul.list__anchor li a span::before {
    content: "";
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border-radius: 100%;
  }

  body.school .maparea ul.list__anchor li a span::after {
    content: "";
    position: absolute;
    top: 23px;
    right: 25px;
    width: 8px;
    height: 8px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(135deg);
  }

  body.school .maparea ul.list__anchor li a span br {
    display: none;
  }

  body.school .section {
    max-width: 1120px;
    margin: 20px auto 0;
    padding-top: 40px;
  }

  body.school .section .column {
    display: flex;
    margin-top: 40px;
  }

  body.school .section .column .cell {
    width: 49.1075%;
  }

  body.school .section .column .cell+.cell {
    margin-left: 1.785%;
  }

  body.school h2.title {
    box-sizing: border-box;
    position: relative;
    height: 61px;
    padding: 12px 0 0 24px;
    font-size: 2.4rem;
    font-weight: 900;
    line-height: 1;
    border-bottom: 1px solid #dcdcdc;
  }

  body.school h2.title::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 8px;
    height: 50px;
    background: #ccc;
  }

  body.school h3.title {
    height: 30px;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
    transform: rotateZ(0.03deg);
    background: #fff;
  }

  body.school ul.list__school {
    box-sizing: border-box;
    width: 100%;
    height: calc(100% - 30px);
    padding: 25px 30px;
    background: #f5f5f5;
    border-radius: 8px;
  }

  body.school ul.list__school li {
    font-size: 1.6rem;
    transform: rotateZ(0.03deg);
  }

  body.school ul.list__school li+li {
    margin-top: 6px;
  }

  body.school .section01 h2.title::before {
    background: #00e4ed;
  }

  body.school .section02 h2.title::before {
    background: #00edce;
  }

  body.school .section03 h2.title::before {
    background: #00edce;
  }

  body.school .section04 h2.title::before {
    background: #00e573;
  }

  body.school .section05 h2.title::before {
    background: #00e573;
  }

  body.school .section06 h2.title::before {
    background: #a2e209;
  }

  body.school .section07 h2.title::before {
    background: #e7ef00;
  }

  body.school .section08 h2.title::before {
    background: #b7dbd9;
  }
  body.school .section .school_text {
    text-align: right;
    padding: 1em 0;
    font-size: 1.4rem;
  }
  /* お問い合わせ ====================*/
  body.contact .titlearea .inner h1.title {
    background-image: url("images/contact/title_bg.jpg");
  }

  body.contact .section {
    margin-top: 100px;
  }

  body.contact .list__contact_wrap {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin: auto;
    flex-wrap: wrap;
  }

  body.contact .list__contact_box {
    max-width: 500px;
    border: 1px solid #d9d9d9;
    border-radius: 6px;
    padding: 40px;
    text-align: center;
    display: flex;
    flex-direction: column;
  }

  body.contact h2.title {
    box-sizing: border-box;
    display: table;
    position: relative;
    margin: 0 auto;
    padding-bottom: 20px;
    font-size: 2.6rem;
    font-weight: 900;
    line-height: 1;
  }

  body.contact h2.title::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 6px;
    background: linear-gradient(to right, #00fcff, #fff600);
  }

  body.contact .list__contact_box img {
    margin: 30px auto;
    max-width: 120px;
  }

  body.contact .list__contact_box p {
    font-size: 1.6rem;
    text-align: left;
    margin-bottom: 40px;
  }

  body.contact .btn_contact {
    margin-top: auto;
  }

  body.contact .btn_contact_calender {
    width: 100%;
    text-align: center;
    padding-bottom: 20px;
  }

  body.contact .btn_contact_calender a:link {
    color: #00bfb3;
    font-weight: 700;
    /* background-color: #00bfb3; */
    border: 1px solid #00bfb3;
    font-size: 18px;
    padding: 10px;
    min-width: 280px;
    border-radius: 100px;
    text-decoration: none;
    display: inline-block;
  }

  body.contact .btn_contact_form {
    max-width: 580px;
    height: 80px;
    margin: 0 auto;
  }

  body.contact .btn_contact_form a {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 400px;
    height: 100%;
    text-decoration: none;
    font-size: 2.4rem;
    font-weight: 900;
    color: #fff;
    line-height: 1;
    background: #00bfb3;
    border-radius: 40px;
    border: 2px solid #fff;
    margin: auto;
  }

  /* アウトカム評価 ====================*/
  body.check .titlearea .inner h1.title {
    background-image: url(images/check/title_bg.jpg);
  }

  body.check .anchor {
    box-sizing: border-box;
    max-width: 1120px;
    margin: 0 auto 80px;
    padding: 30px;
    border-radius: 8px;
  }

  .sttl_check {
    text-align: center;
    font-weight: 600;
    font-size: 24px;
    display: block;
  }

  .ttl_check {
    font-size: 40px;
    text-align: center;
    font-weight: 800;
    padding: 1em 0;
  }

  .rubric_images {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .dl_link {
    text-align: center;
  }

  .dl_link a {
    position: relative;
    font-size: 20px;
    text-decoration: none;
    font-weight: 700;
    color: #000;
    margin: auto;
    border: solid 1px #dcdcdc;
    border-radius: 100px;
    padding: 1em 3em 1em 1em;
    display: inline-block;
  }

  .dl_link a:hover {
    background-color: #f9f9f9;
  }

  .dl_link a::before {
    content: "";
    position: absolute;
    top: calc(50% - 18px);
    right: 12px;
    width: 36px;
    height: 36px;
    background: #00e4ed;
    border-radius: 100%;
  }

  .dl_link a::after {
    content: "";
    position: absolute;
    top: calc(50% - 7px);
    right: 25px;
    width: 8px;
    height: 8px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(135deg);
  }

  .rubric_links {
    text-align: center;
  }

  .rubric_links a {
    position: relative;
    display: inline-block;
    text-decoration: none;
    margin: 10px auto;
    border: solid 1px #17bfb3;
    color: #17bfb3;
    font-size: 20px;
    font-weight: 700;
    padding: 1em 2.5em;
    border-radius: 100px;
  }

  .rubric_links a i {
    position: absolute;
    right: 1em;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  }

  .miyake_teacher_box {
    display: flex;
  }

  .miyake_teacher_box img {
    padding-right: 1.5em;
    aspect-ratio: 400 / 225;
    object-fit: contain;
  }

  /* =================================================== */
}

@media (min-width: 769px) and (max-width: 1360px) {
  body.top .section03::after {
    height: 7.205vw;
    margin-top: 5.147vw;
    background-size: contain;
  }
}

@media (min-width: 769px) and (max-width: 1260px) {
  header.header .header__title {
    top: 12px;
    left: 0;
    width: 100%;
    text-align: center;
  }

  header.header .header__title a span.sub {
    font-size: 1.2rem;
    transform: rotateZ(0.03deg);
  }

  header.header .header__title a span.main {
    margin-top: 6px;
    font-size: 1.8rem;
    transform: rotateZ(0.03deg);
  }

  header.header ul.header__link {
    justify-content: center;
    width: 100%;
    right: 0;
    top: 58px;
  }

  header.header .header__logo--corporate {
    top: 10px;
  }
}

@media (min-width: 769px) and (max-width: 1199px) {
  body.message h2.title {
    white-space: normal;
  }

  body.message h2.title br {
    display: none;
  }
}

@media (min-width: 769px) and (max-width: 1130px) {
  body.program h2.title span.main span {
    padding-top: 0;
  }
}

@media (min-width: 769px) and (max-width: 1099px) {
  body.top .section01 {
    margin-top: 20px;
    padding: 0 60px;
  }

  body.top .section01 figure.img {
    text-align: center;
  }

  body.top .section01 p.text__number strong {
    font-size: 5.2rem;
  }

  body.top .section01 p.text__number span {
    display: block;
  }

  body.top .section01 p.text br {
    display: block;
  }

  body.top .section01 .btn__arrow {
    margin: 40px auto 0;
  }
}

@media (min-width: 769px) and (max-width: 899px) {
  header.header ul.header__link li {
    margin-left: 18px;
    transform: rotateZ(0.03deg);
  }

  header.header ul.header__link li a {
    padding-bottom: 7px;
    font-size: 1.3rem;
  }

  body.top .mainvisual p.mainvisual_text {
    line-height: 1.2;
  }

  body.top .mainvisual p.mainvisual_text br {
    display: block;
  }

  body.program .anchor ul.list__anchor {
    display: block;
  }

  body.program .anchor ul.list__anchor li {
    width: 100%;
  }

  body.program .anchor ul.list__anchor li:nth-of-type(even) {
    margin-left: 0;
  }

  body.program .anchor ul.list__anchor li:nth-of-type(n+2) {
    margin-top: 10px;
  }

  body.program .anchor ul.list__anchor li a p {
    padding-right: 50px;
  }

  body.program .anchor ul.list__anchor li a p span {
    display: inline-block;
    width: auto;
    margin-left: 0.5em;
  }

  body.school .maparea ul.list__anchor li a span br {
    display: block;
  }

  body.school .section .column {
    display: block;
    margin-top: 40px;
  }

  body.school .section .column .cell {
    width: 100%;
  }

  body.school .section .column .cell+.cell {
    margin: 20px 0 0;
  }
}

@media (min-width: 769px) and (max-width: 1000px) {
  .pp_explanation {
    font-size: 14px;
    line-height: 1em;
  }

  .programp_txt,
  .pp_breakdown {
    font-size: 14px;
  }

  .pp_explanation br,
  .pp_type_name br {
    display: block;
  }

  .pp_th p,
  .pp_type_name,
  .pp_parts_name,
  .pp_frames {
    font-size: 20px;
  }
}

@media (max-width: 899px) {
  .list__anchor_pp {
    display: block;
  }

  .list__anchor_pp li {
    width: 100%;
  }

  .list__anchor_pp li:nth-of-type(even) {
    margin-left: 0;
  }

  .list__anchor_pp li+li {
    margin-top: 2.66vw;
  }
}


/* ======================================================
	SP用設定
====================================================== */
@media screen and (max-width: 768px) {

  /* 基本設定 ====================*/
  body {
    color: #000;
    line-height: 1.5;
  }

  body.fixed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

  img {
    width: 100%;
  }

  .wrapper {
    overflow: hidden;
    position: relative;
    padding-top: 16vw;
  }

  a:link {
    color: #00bfb3;
    text-decoration: underline;
  }

  a:visited {
    color: #00bfb3;
    text-decoration: underline;
  }

  a:hover {
    color: #00bfb3;
    text-decoration: none;
  }

  a:active {
    color: #00bfb3;
  }

  .pc {
    display: none !important;
  }

  /* header ====================*/
  header.header {
    box-sizing: border-box;
    position: fixed;
    z-index: 100;
    top: 0;
    left: 0;
    width: 100%;
    width: 100%;
    height: 16vw;
    background: #fff;
  }

  header.header .header__title {
    position: absolute;
    top: 3.73vw;
    left: 4.26vw;
  }

  header.header .header__title a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: #000;
    line-height: 1;
  }

  header.header .header__title a span.sub {
    display: block;
    font-size: 2.93vw;
    font-weight: 500;
    transform: rotateZ(0.03deg);
  }

  header.header .header__title a span.main {
    display: block;
    margin-top: 2vw;
    font-size: 4vw;
    font-weight: 900;
    transform: rotateZ(0.03deg);
  }

  header.header .header__title a span.main span {
    font-weight: 500;
  }

  header.header .header__menu {
    display: block;
    position: fixed;
    z-index: 99;
    top: 5.86vw;
    right: 4.26vw;
    width: 8vw;
    height: 4.26vw;
    cursor: pointer;
  }

  header.header .header__menu span {
    display: block;
    position: absolute;
    top: 1.86vw;
    left: 0;
    width: 8vw;
    height: 0.6vw;
    background: #000;
    transition: all 0.2s;
  }

  header.header .header__menu span:nth-child(1) {
    transform: translateY(-1.86vw);
  }

  header.header .header__menu span:nth-child(2) {
    opacity: 1;
  }

  header.header .header__menu span:nth-child(3) {
    transform: translateY(1.86vw);
  }

  header.header .header__menu.open span {
    background: #fff;
  }

  header.header .header__menu.open span:nth-child(1) {
    transform: rotate(-30deg) translateY(0px);
  }

  header.header .header__menu.open span:nth-child(2) {
    opacity: 0;
  }

  header.header .header__menu.open span:nth-child(3) {
    transform: rotate(30deg) translateY(0px);
  }

  header.header .navigation {
    display: none;
    position: fixed;
    z-index: 98;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 191, 179, 0.97);
  }

  header.header .navigation .inner {
    box-sizing: border-box;
    overflow-y: auto;
    height: 100%;
    padding: 16vw 4.26vw;
  }

  header.header ul.header__link {
    border-top: 1px solid #fff;
  }

  header.header ul.header__link li {
    display: flex;
    align-items: center;
    transform: rotateZ(0.03deg);
    transition: all 0.3s ease;
    border-bottom: 1px solid #fff;
  }

  header.header ul.header__link li a {
    box-sizing: border-box;
    display: block;
    width: 100%;
    padding: 5.33vw 0;
    text-decoration: none;
    font-size: 4.26vw;
    font-weight: 700;
    color: #fff;
    line-height: 1;
  }

  header.header .header__logo--corporate {
    position: absolute;
    z-index: 0;
    top: 3.73vw;
    right: 17.6vw;
    width: 7.73vw;
    height: 8.8vw;
    background: url("images/logo_corporate_b.png") center center no-repeat;
    background-size: cover;
  }

  header.header .header__logo--corporate a {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
  }

  /* footer ====================*/
  .footer {
    position: relative;
    background: #00bfb3;
  }

  .footer .footer__block:first-child {
    padding: 16vw 4.26vw;
    background: url("images/footer_bg_sp.jpg") center center no-repeat;
    background-size: cover;
  }

  .footer .footer__block:last-child {
    padding: 13.33vw 4.26vw;
  }

  .footer .btn__contact {
    height: 18.66vw;
    margin: 0 auto;
  }

  .footer .btn__contact a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-align: center;
    text-decoration: none;
    font-size: 4.26vw;
    font-weight: 900;
    color: #fff;
    background: #00bfb3;
    border-radius: 9.33vw;
    border: 2px solid #fff;
  }

  .footer .group {
    margin: 8vw auto 0;
    padding: 6vw 4vw;
    background: #fff;
    border-radius: 1.6vw;
  }

  .footer p.title {
    margin-bottom: 6vw;
    padding-bottom: 4vw;
    text-align: center;
    font-size: 4.26vw;
    font-weight: 700;
    color: #00bfb3;
    line-height: 1.6;
    border-bottom: 1px solid #00bfb3;
  }

  .footer ul.footer__list li {
    position: relative;
    padding-left: 1.25em;
    font-size: 3.73vw;
    color: #000;
    transform: rotateZ(0.03deg);
  }

  .footer ul.footer__list li span {
    position: absolute;
    top: 0;
    left: 0;
    font-weight: 700;
  }

  .footer ul.footer__list li.position::after {
    content: "（ ）";
  }

  .footer ul.footer__list li+li {
    margin-top: 2vw;
  }

  .footer ul+ul {
    margin-top: 2vw;
  }

  .footer p.footer__title a {
    display: block;
    width: 100%;
    height: 100%;
    text-align: center;
    text-decoration: none;
    color: #fff;
    line-height: 1;
  }

  .footer p.footer__title a span.sub {
    display: block;
    font-size: 3.2vw;
    font-weight: 500;
    transform: rotateZ(0.03deg);
  }

  .footer p.footer__title a span.main {
    display: block;
    margin-top: 2vw;
    font-size: 5.06vw;
    font-weight: 900;
  }

  .footer p.footer__title a span.main span {
    font-weight: 500;
  }

  .footer ul.footer__link {
    margin-top: 9.33vw;
    border-top: 1px solid #fff;
  }

  .footer ul.footer__link li {
    border-bottom: 1px solid #fff;
  }

  .footer ul.footer__link li a {
    display: block;
    padding: 4vw 0;
    text-decoration: none;
    font-size: 4.26vw;
    font-weight: 700;
    color: #fff;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  .footer p.footer__logo--corporate {
    /* width: 49.6vw; */
    height: 8.8vw;
    margin: 13.33vw auto 0;
    background: url("images/logo_corporate_w.svg") center center no-repeat;
    background-size:100% 100%;
  }

  .footer p.footer__logo--corporate a {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
  }

  .footer p.footer__copyright {
    margin-top: 4vw;
    text-align: center;
    font-size: 3.2vw;
    font-family: "Montserrat", sans-serif;
    font-weight: 400;
    color: #fff;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  .footer .pagetop {
    width: 9.86vw;
    height: 28vw;
    margin: 0 auto;
    background: url("images/pagetop.svg") center center no-repeat;
    background-size: contain;
  }

  .footer .pagetop a {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
  }

  /* 共通パーツ ====================*/
  .bnr__contact {
    position: fixed;
    z-index: 100;
    top: 16vw;
    right: 0;
    width: 8vw;
    height: 50.66vw;
    background: #00bfb3 url("images/bnr_contact.svg") center center no-repeat;
    background-size: contain;
    border-radius: 0 0 0 1.06vw;
  }

  .bnr__contact a {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
  }

  .bnr__calender {
    position: fixed;
    z-index: 100;
    top: 68vw;
    right: 0;
    width: 8vw;
    height: 8vw;
    background: #00bfb3;
    background-size: contain;
    border-radius: 1.06vw 0 0 1.06vw;
  }

  .bnr__calender a {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 23px;
    color: #fff;
    text-align: center;
    padding-top: 5px;
  }

  .btn__arrow {
    max-width: 60vw;
    border-bottom: 0.66vw solid #000;
  }

  .btn__arrow a {
    display: block;
    position: relative;
    padding: 3vw 12vw 6vw 0;
    text-decoration: none;
    font-size: 4.26vw;
    font-weight: 700;
    color: #000;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  .btn__arrow a::before {
    content: "";
    box-sizing: border-box;
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 10.4vw;
    height: 10.4vw;
    border: 0.66vw solid #000;
    border-radius: 100%;
  }

  .btn__arrow a::after {
    content: "";
    display: block;
    position: absolute;
    top: 4vw;
    right: 3.6vw;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1.5vw 0 1.5vw 2.4vw;
    border-color: transparent transparent transparent #000;
  }

  .titlearea .inner h1.title {
    display: flex;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    height: 66.66vw;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
  }

  .titlearea .inner h1.title span.main {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 8vw;
    font-weight: 900;
    color: #fff;
    line-height: 1;
  }

  .titlearea .inner h1.title span.sub {
    display: block;
    margin-top: 3.33vw;
    text-align: center;
    font-size: 3.73vw;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    line-height: 1;
    background: linear-gradient(to right, #00fcff, #fff600);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .titlearea .inner p.text__lead {
    margin-top: 9vw;
    padding: 0 4.26vw;
    font-size: 4.26vw;
    line-height: 1.6;
    transform: rotateZ(0.03deg);
  }

  .titlearea .inner p.text__lead span.kome {
    font-size: 3.2vw;
  }

  .titlearea .inner p.text {
    margin-top: 9vw;
    padding: 0 4.26vw;
    font-size: 3.2vw;
    color: #666666;
    line-height: 1.6;
    transform: rotateZ(0.03deg);
  }

  .contents {
    padding: 0 4.26vw 16vw;
  }

  /* TOP ====================*/
  body.top .wrapper {
    padding-top: 0;
  }

  @keyframes fadeIn {
    0% {
      opacity: 0;
    }

    100% {
      opacity: 1;
    }
  }

  body.top .mainvisual.visible {
    animation-name: fadeIn;
    animation-duration: 0.2s;
    animation-delay: 0.2s;
    animation-timing-function: linear;
    animation-fill-mode: forwards;
  }

  body.top .mainvisual {
    box-sizing: border-box;
    height: 100vh;
    padding-top: 16vw;
    opacity: 0;
  }

  body.top .mainvisual .inner {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 100%;
    height: 100%;
    background: #fff url("images/mainvisual_bg_sp.png") center bottom no-repeat;
    background-size: cover;
  }

  body.top .mainvisual .group {
    width: 100%;
    margin-top: -20vw;
  }

  body.top .mainvisual p.mainvisual_text {
    text-align: center;
    font-size: 5.6vw;
    font-weight: 900;
    color: #fff;
    line-height: 1.4;
  }

  body.top .mainvisual p.mainvisual_title {
    margin-top: 6.66vw;
    width: 100%;
    height: 28.26vw;
    background: url("images/mainvisual_title_sp.png") center center no-repeat;
    background-size: contain;
  }

  body.top .mainvisual p.mainvisual_title img {
    opacity: 0;
  }

  body.top .mainvisual p.mainvisual_text__sub {
    margin-top: 6.66vw;
    text-align: center;
    font-size: 3.2vw;
    font-weight: 700;
    color: #fff;
    line-height: 2.5;
    transform: rotateZ(0.03deg);
  }

  body.top .mainvisual .scroll {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 21.5vw;
  }

  body.top .mainvisual .scroll a {
    display: block;
    width: 20vw;
    height: 100%;
    margin: 0 auto;
    opacity: 0;
  }

  .concept_movie_box {
    padding: 20px;
  }

  .concept_movie_inner {
    padding: 15px;
  }

  .concept_movie_left h2 {
    font-size: 25px;
  }

  .concept_movie_left p {
    font-size: 15px;
  }

  .concept_movie_right img {
    width: 120px;
  }

  body.top .contents {
    margin-top: -16vw;
    padding: 16vw 0 21.33vw;
  }

  body.top h2.title__border {
    box-sizing: border-box;
    position: relative;
    padding-left: 4.8vw;
  }

  body.top h2.title__border::before {
    content: "";
    display: block;
    position: absolute;
    top: 0.75em;
    left: 0;
    width: 1.2vw;
    height: calc(100% - 0.75em);
    background: linear-gradient(to bottom, #00fcff, #fff600);
  }

  body.top h2.title__border span.main {
    display: block;
    margin-top: -0.15em;
    font-size: 9.06vw;
    font-weight: 900;
    line-height: 1.3;
  }

  body.top h2.title__border span.sub {
    display: block;
    margin-top: 1.5vw;
    font-size: 4vw;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    line-height: 1;
  }

  body.top .section01 {
    margin-top: 10vw;
    padding: 0 4.26vw;
  }

  body.top .section01 h2.title {
    text-align: center;
    font-size: 5.33vw;
    font-weight: 900;
    color: #00bfb3;
    line-height: 1;
  }

  body.top .section01 .column {
    margin-top: 5.33vw;
  }

  body.top .section01 .column .cell {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    background: #e5f8f7;
    border-radius: 1.6vw;
  }

  body.top .section01 .column .cell .group:first-child {
    width: 42vw;
    padding: 6vw 0 4vw;
  }

  body.top .section01 .column .cell .group:last-child {
    width: calc(100% - 42vw);
  }

  body.top .section01 .column .cell+.cell {
    margin-top: 1.33vw;
  }

  body.top .section01 h4.title {
    text-align: center;
    font-size: 5.6vw;
    font-weight: 700;
    line-height: 1;
  }

  body.top .section01 figure.img {
    margin-top: 2vw;
  }

  body.top .section01 p.text__number {
    margin-top: -1.5vw;
    color: #00bfb3;
    line-height: 1;
  }

  body.top .section01 p.text__number strong {
    font-size: 10.66vw;
    font-weight: 900;
  }

  body.top .section01 p.text__number span {
    font-size: 5.33vw;
    font-weight: 700;
  }

  body.top .section01 p.text {
    margin-top: 1.5vw;
    font-size: 2.93vw;
    line-height: 1.2;
    transform: rotateZ(0.03deg);
  }

  body.top .section01 .btn__arrow {
    margin: 8vw auto 0;
  }

  body.top .section02 {
    margin-top: 21.33vw;
    padding: 0 4.26vw 21.33vw;
    background: url("images/section02_bg_sp.png") center bottom no-repeat;
    background-size: contain;
  }

  body.top .section02 .column {
    margin-top: 10.66vw;
  }

  body.top .section02 .column .cell+.cell {
    margin-top: 10.66vw;
    padding: 0 7.46vw;
  }

  body.top .section02 ul.list__news {
    border-top: 1px solid #ebebeb;
  }

  body.top .section02 ul.list__news li {
    padding: 4vw 0 3.2vw;
    border-bottom: 1px solid #ebebeb;
  }

  body.top .section02 ul.list__news li p.date {
    margin-bottom: 3.2vw;
    font-size: 3.2vw;
    font-family: "Montserrat", sans-serif;
    font-weight: 400;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.top .section02 ul.list__news li p.text {
    font-size: 3.73vw;
    transform: rotateZ(0.03deg);
  }

  body.top .section03 {
    position: relative;
    padding: 13.33vw 0 0;
    background: #e5f8f7 url("images/bg_common.png") center top no-repeat;
  }

  body.top .section03::after {
    content: "";
    display: block;
    width: 100vw;
    height: 25.6vw;
    margin-top: 13.33vw;
    background: url("images/section03_bg_sp.png") center bottom no-repeat;
    background-size: contain;
  }

  body.top .section03>.inner {
    padding: 0 4.26vw;
  }

  body.top .section03 p.text__lead {
    margin-top: 5.33vw;
    font-size: 4.26vw;
    line-height: 1.75;
    transform: rotateZ(0.03deg);
  }

  body.top .section03 figure.section03__img01 {
    margin-top: 8vw;
  }

  body.top .section03 h3.title {
    display: table;
    margin: 14.66vw auto 0;
    font-size: 7.2vw;
    line-height: 1.4;
    font-weight: 900;
  }

  body.top .section03 p.text {
    margin-top: 9.33vw;
    font-size: 3.73vw;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
  }

  body.top .section03 .btn__arrow {
    margin: 6.66vw auto 0;
  }

  body.top .section03 .group {
    margin-top: 16vw;
    padding: 8vw 5vw;
    background: #fff;
    border-radius: 2.13vw;
  }

  body.top .section03 h4.title {
    text-align: center;
    font-size: 5.33vw;
    line-height: 1;
    font-weight: 900;
  }

  body.top .section03 ul.list__features {
    margin-top: 6vw;
  }

  body.top .section03 ul.list__features li {
    position: relative;
    padding-top: 27vw;
  }

  body.top .section03 ul.list__features li figure.img {
    position: absolute;
    width: 67.2vw;
    top: 0;
    left: calc(50% - 33.6vw);
  }

  body.top .section03 ul.list__features li p.text {
    font-size: 3.73vw;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
  }

  body.top .section03 ul.list__features li+li {
    margin-top: 8vw;
  }

  body.top .section04 {
    margin-top: 21.33vw;
  }

  body.top .section04>.inner {
    padding: 0 4.26vw 10vw;
    background: url("images/section04_bg_sp.png") center bottom no-repeat;
    background-size: contain;
  }

  body.top .section04 p.text {
    margin-top: 10vw;
    font-size: 4.26vw;
    line-height: 2;
    transform: rotateZ(0.03deg);
  }

  body.top .section04 ul.slick__program li.slick-slide {
    position: relative;
    margin: 0 2vw;
  }

  body.top .section04 ul.slick__program li.slick-slide a {
    display: block;
    position: relative;
    text-decoration: none;
    color: #fff;
  }

  body.top .section04 ul.slick__program li.slick-slide img {
    border-radius: 1.06vw;
  }

  body.top .section04 ul.slick__program li.slick-slide p.number {
    position: absolute;
    top: 4vw;
    left: 4vw;
    font-size: 6.93vw;
    font-weight: 900;
    line-height: 1;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title {
    position: absolute;
    top: 33.5vw;
    left: 4vw;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.sub {
    display: block;
    font-size: 3.2vw;
    font-weight: 700;
    line-height: 1;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.main {
    display: block;
    margin-top: 1.36vw;
    font-size: 6.8vw;
    font-weight: 900;
    line-height: 1.2;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.main span {
    display: block;
    margin-top: 1vw;
    font-size: 3.73vw;
    font-weight: 700;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.main span.logo {
    display: table;
    position: relative;
    padding-bottom: 3.06vw;
  }

  body.top .section04 ul.slick__program li.slick-slide h3.title span.main span.logo::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: calc(50% - 4vw);
    width: 8vw;
    height: 3.06vw;
    background: url("images/logo_doda_white.svg") center center no-repeat;
    background-size: cover;
  }

  body.top .section04 ul.slick__program li.slick-slide p.text {
    margin-top: 2vw;
    font-size: 3.2vw;
    color: #000;
    line-height: 1.6;
  }

  body.top .section04 ul.slick-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 4vw;
  }

  body.top .section04 ul.slick-dots li {
    width: 2.66vw;
    height: 2.66vw;
    margin: 0 2.66vw;
    background: #000000;
    border-radius: 50%;
  }

  body.top .section04 ul.slick-dots li button {
    display: block;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
  }

  body.top .section04 ul.slick-dots li.slick-active {
    background: #00bfb3;
  }

  body.top .section04 .btn__arrow {
    margin: 10vw auto 0;
  }

  body.top .section05 {
    margin-top: 21.33vw;
  }

  body.top .section05 .column .cell {
    padding: 0 4.26vw;
  }

  body.top .section05 .column .cell:first-child {
    padding-bottom: 10vw;
    background: url("images/section05_bg_sp.png") center bottom no-repeat;
    background-size: contain;
  }

  body.top .section05 p.text {
    margin-top: 10vw;
    font-size: 4.26vw;
    line-height: 1.6;
    transform: rotateZ(0.03deg);
  }

  body.top .section05 figure.section05__img01 img {
    border-radius: 1.06vw;
  }

  body.top .section05 .btn__arrow {
    margin: 10vw auto 0;
  }

  body.top .section06 {
    margin-top: 21.33vw;
    padding: 0 4.26vw 21.33vw;
    background: url("images/section06_bg_sp.png") center bottom no-repeat;
    background-size: contain;
  }

  body.top .section06 p.text {
    margin-top: 10vw;
    font-size: 4.26vw;
    line-height: 1.6;
    transform: rotateZ(0.03deg);
  }

  body.top .section06 h4.title {
    margin-top: 10vw;
    text-align: center;
    font-size: 5.33vw;
    line-height: 1;
    font-weight: 900;
  }

  body.top .section06 figure.section06__img01 {
    margin-top: 5.33vw;
  }

  body.top .section07 {
    position: relative;
    padding: 16vw 4.26vw 21.33vw;
    background: #e5f8f7 url("images/bg_common.png") center top no-repeat;
  }

  body.top .section07::before {
    content: "";
    display: block;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url("images/section07_bg_sp.png") center bottom no-repeat;
    background-size: contain;
  }

  body.top .section07 p.text {
    margin-top: 10vw;
    font-size: 4.26vw;
    line-height: 1.6;
    transform: rotateZ(0.03deg);
  }

  body.top .section07 dl.list__voice {
    margin-top: 8vw;
  }

  body.top .section07 dl.list__voice .group {
    display: flex;
    align-items: flex-start;
  }

  body.top .section07 dl.list__voice .group:nth-child(odd) dt {
    margin-right: 4vw;
  }

  body.top .section07 dl.list__voice .group:nth-child(odd) dd::before {
    content: "";
    display: block;
    position: absolute;
    top: 8vw;
    left: -3vw;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1.5vw 3vw 1.5vw 0;
    border-color: transparent #fff transparent transparent;
  }

  body.top .section07 dl.list__voice .group:nth-child(even) {
    justify-content: flex-end;
  }

  body.top .section07 dl.list__voice .group:nth-child(even) dt {
    order: 2;
    margin-left: 4vw;
  }

  body.top .section07 dl.list__voice .group:nth-child(even) dd {
    order: 1;
  }

  body.top .section07 dl.list__voice .group:nth-child(even) dd::after {
    content: "";
    display: block;
    position: absolute;
    top: 8vw;
    right: -3vw;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1.5vw 0 1.5vw 3vw;
    border-color: transparent transparent transparent #fff;
  }

  body.top .section07 dl.list__voice dt {
    width: 17.2vw;
    height: 17.2vw;
    background: #fff;
    border-radius: 100%;
  }

  body.top .section07 dl.list__voice dd {
    box-sizing: border-box;
    position: relative;
    width: calc(100% - 17.2vw - 4vw);
    padding: 5vw 5vw 5.33vw 5.33vw;
    font-size: 3.73vw;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
    background: #fff;
    border-radius: 1.06vw;
  }

  body.top .section07 dl.list__voice dd span {
    display: block;
    margin-top: 2vw;
    font-size: 3.2vw;
    font-weight: 700;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.top .section07 dl.list__voice .group+.group {
    margin-top: 6.66vw;
  }

  body.top .section07 .btn__arrow {
    margin: 10vw auto 0;
  }

  body.top .section08 {
    padding: 16vw 4.26vw 0;
    background: url("images/section08_bg_sp.png") center top no-repeat;
    background-size: contain;
  }

  body.top .section08 dl.list__qa {
    margin-top: 10.66vw;
  }

  body.top .section08 dl.list__qa .group {
    border-left: 0.8vw solid #00bfb3;
  }

  body.top .section08 dl.list__qa dt {
    position: relative;
    padding: 4vw 4vw 4vw 4em;
    font-size: 3.73vw;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
  }

  body.top .section08 dl.list__qa dt::before {
    content: "Q";
    display: block;
    position: absolute;
    top: 4vw;
    left: 6vw;
    font-size: 6.93vw;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    line-height: 1;
  }

  body.top .section08 dl.list__qa dd {
    position: relative;
    padding: 4vw 4vw 4vw 4em;
    font-size: 3.73vw;
    font-weight: 700;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
    background: #e5f8f7;
  }

  body.top .section08 dl.list__qa dd::before {
    content: "A";
    display: block;
    position: absolute;
    top: 4vw;
    left: 6vw;
    font-size: 6.93vw;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    color: #00bfb3;
    line-height: 1;
  }

  body.top .section08 dl.list__qa .group+.group {
    margin-top: 5.33vw;
  }

  body.top .section08 .btn__arrow {
    margin: 10vw auto 0;
  }

  /* プログラム ====================*/
  body.program .titlearea .inner h1.title {
    background-image: url("images/program/title_bg_sp.jpg");
  }

  body.program .contents {
    margin-top: 10vw;
  }

  body.program .anchor {
    box-sizing: border-box;
    position: relative;
    z-index: 0;
    padding: 4vw;
    background: #f5f5f5;
    border-radius: 2.13vw;
  }

  body.program .anchor ul.list__anchor li {
    height: 13vw;
    background: #fff;
  }

  body.program .anchor ul.list__anchor li:nth-of-type(1) a::before {
    content: "01";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(2) a::before {
    content: "02";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(3) a::before {
    content: "03";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(4) a::before {
    content: "04";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(5) a::before {
    content: "05";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(6) a::before {
    content: "06";
  }

  body.program .anchor ul.list__anchor li:nth-of-type(7) a::before {
    content: "07";
  }

  body.program .anchor ul.list__anchor li a {
    display: flex;
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: #000;
  }

  body.program .anchor ul.list__anchor li a::before {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 13vw;
    text-align: center;
    font-size: 5.86vw;
    font-weight: 900;
    line-height: 1;
  }

  body.program .anchor ul.list__anchor li a p {
    box-sizing: border-box;
    display: flex;
    align-content: center;
    flex-wrap: wrap;
    position: relative;
    width: calc(100% - 13vw);
    padding: 2vw 8vw 2vw 3vw;
    align-items: center;
    font-size: 4.26vw;
    font-weight: 700;
    line-height: 1.2;
    transform: rotateZ(0.03deg);
    border-left: 1px solid #f5f5f5;
  }

  body.program .anchor ul.list__anchor li a p::before {
    content: "";
    position: absolute;
    top: 2.8vw;
    right: 2.8vw;
    width: 7.2vw;
    height: 7.2vw;
    background: #00e4ed;
    border-radius: 100%;
  }

  body.program .anchor ul.list__anchor li a p::after {
    content: "";
    position: absolute;
    top: 4.8vw;
    right: 5.33vw;
    width: 2vw;
    height: 2vw;
    border-top: solid 0.6vw #fff;
    border-right: solid 0.6vw #fff;
    transform: rotate(135deg);
  }

  body.program .anchor ul.list__anchor li a p span {
    display: block;
    width: 100%;
    margin-top: 0.25em;
    font-size: 2.4vw;
  }

  body.program .anchor ul.list__anchor li a p span img.logo {
    width: 7.06vw;
    height: 2.66vw;
  }

  body.program .anchor ul.list__anchor li+li {
    margin-top: 2.66vw;
  }

  body.program .section {
    margin-top: -2.66vw;
    padding-top: 16vw;
  }

  body.program h2.title {
    box-sizing: border-box;
    position: relative;
    min-height: 22vw;
    padding-left: 20vw;
  }

  body.program h2.title::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 15.46vw;
    width: 0.8vw;
    height: 100%;
    background: linear-gradient(to bottom, #00fcff, #fff600);
  }

  body.program h2.title span.number {
    display: block;
    position: absolute;
    top: -1vw;
    left: 0;
    font-size: 9.33vw;
    font-weight: 900;
    line-height: 1;
  }

  body.program h2.title span.sub {
    display: block;
    font-size: 2.93vw;
    font-weight: 700;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.program h2.title span.main {
    display: block;
    margin-top: 2vw;
    font-size: 6.4vw;
    font-weight: 900;
    line-height: 1;
  }

  body.program h2.title span.main span {
    display: block;
    margin-top: 2vw;
    font-size: 3.2vw;
    font-weight: 700;
    white-space: nowrap;
  }

  body.program h2.title span.main span.logo {
    display: table;
    position: relative;
    padding-bottom: 3.4vw;
  }

  body.program h2.title span.main span.logo::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: calc(50% - 4vw);
    width: 8vw;
    height: 3.06vw;
    background: url("images/logo_doda_blue.svg") center center no-repeat;
    background-size: cover;
  }

  body.program .mainimg {
    overflow: hidden;
    position: relative;
  }

  body.program .mainimg dl {
    box-sizing: border-box;
    margin-top: 5.33vw;
    padding-bottom: 5.33vw;
    font-size: 3.2vw;
    line-height: 1;
    transform: rotateZ(0.03deg);
    border-bottom: 1px solid #ebebeb;
  }

  body.program .mainimg dl .group {
    display: flex;
  }

  body.program .mainimg dl .group+.group {
    margin-top: 2vw;
  }

  body.program .mainimg dl dt {
    width: 19.2vw;
    font-weight: 700;
  }

  body.program .mainimg img {
    border-radius: 1.06vw;
  }

  body.program p.text {
    margin-top: 6vw;
    font-size: 4.26vw;
    line-height: 1.6;
    transform: rotateZ(0.03deg);
  }

  body.program .recommend {
    margin-top: 7.2vw;
  }

  body.program .recommend h3.title {
    box-sizing: border-box;
    padding: 4vw;
    font-size: 4.26vw;
    line-height: 1;
    background: #e5f8f7;
    border-radius: 1.06vw;
    transform: rotateZ(0.03deg);
  }

  body.program .recommend h3.title br {
    display: none;
  }

  body.program .recommend ul.list__recommend {
    margin-top: 4vw;
  }

  body.program .recommend ul.list__recommend li {
    position: relative;
    padding-left: 5.6vw;
    font-size: 4.26vw;
    transform: rotateZ(0.03deg);
  }

  body.program .recommend ul.list__recommend li::before {
    content: "";
    display: block;
    position: absolute;
    top: 0.35em;
    left: 0;
    width: 4vw;
    height: 4vw;
    background: #03fcfc;
    border-radius: 100%;
  }

  body.program .recommend ul.list__recommend li+li {
    margin-top: 0.5em;
  }

  body.program .column {
    margin-top: 7.2vw;
  }

  body.program .column .cell+.cell {
    margin-top: 7.2vw;
  }

  body.program .column h3.title {
    box-sizing: border-box;
    padding: 4vw;
    font-size: 4.26vw;
    line-height: 1;
    background: #e5f8f7;
    border-radius: 1.06vw;
    transform: rotateZ(0.03deg);
  }

  body.program .column h3.title br {
    display: none;
  }

  body.program .column figure {
    margin-top: 5.33vw;
  }

  body.program .column figure figcaption {
    margin-bottom: 0.5em;
    font-size: 4.26vw;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.program .notice {
    font-size: 1.5rem;
    transform: rotateZ(0.03deg);
    padding: 10px 0;
  }

  .pp_th {
    display: block;
  }

  .pp_table {
    border: solid 1px #d9d9d9;
    width: 100%;
  }

  .pp_table tr th {
    display: none;
  }

  .pp_table tr td {
    display: block;
    width: 100%;
    border: none;
    text-align: center;
    padding: 10px 0;
  }

  .programp_txt,
  .pp_breakdown,
  .pp_caption {
    font-size: 14px;
  }

  .pp_explanation br,
  .pp_type_name br {
    display: block;
  }

  .pp_th p,
  .pp_type_name,
  .pp_parts_name,
  .pp_frames {
    font-size: 20px;
    font-weight: 700;
  }

  .table_c01::before,
  .table_c02::before,
  .table_c03::before,
  .table_c04::before,
  .table_c05::before {
    content: "";
    position: absolute;
    top: 110%;
    left: 50%;
    margin-left: -15px;
    border: 15px solid transparent;
  }

  .table_c01::before {
    border-top: 15px solid #ff9900;
  }

  .table_c02::before {
    border-top: 15px solid #ffcc00;
  }

  .table_c03::before {
    border-top: 15px solid #0066cc;
  }

  .table_c04::before {
    border-top: 15px solid #0099ff;
  }

  .table_c05::before {
    border-top: 15px solid #ff5050;
  }

  .pp_type_name {
    display: block;
  }

  .pp_explanation br,
  .pp_type_name br {
    display: none;
  }

  .ttl_program {
    font-size: 28px;
  }

 .program .btn_contact_form a {
  font-size: 2rem;
 }
 #package_junior_high_school {
  padding-top: 60px;
  margin-top: -60px;
}

  /* 講師プロフィール ====================*/
  body.instructor .titlearea .inner h1.title {
    background-image: url("images/instructor/title_bg_sp.jpg");
  }

  body.instructor .contents {
    margin-top: 9vw;
  }

  body.instructor .section {
    padding-bottom: 10vw;
    border-bottom: 1px solid #ebebeb;
  }

  body.instructor .section:first-child {
    padding-top: 10.66vw;
    border-top: 1px solid #ebebeb;
  }

  body.instructor .section+.section {
    margin-top: 10vw;
  }

  body.instructor .column .cell:first-child {
    width: 42vw;
    margin: 0 auto;
  }

  body.instructor .column .cell+.cell {
    margin-top: 6.66vw;
  }

  body.instructor .column figure {
    overflow: hidden;
    border-radius: 1.06vw;
  }

  body.instructor .column h2.title {
    box-sizing: border-box;
    position: relative;
    padding: 2vw 0 2.6vw 6.4vw;
  }

  body.instructor .column h2.title::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 1.6vw;
    height: 100%;
    background: linear-gradient(to bottom, #00fcff, #fff600);
  }

  body.instructor .column h2.title span.main {
    display: flex;
    align-items: center;
    font-size: 5.33vw;
    font-weight: 900;
    line-height: 1;
  }

  body.instructor .column h2.title span.main span {
    display: block;
    margin: 0.15em 0 0 1.25em;
    font-size: 3.2vw;
    font-weight: 700;
    white-space: nowrap;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column h2.title span.sub {
    display: block;
    margin-top: 3.2vw;
    font-size: 3.2vw;
    font-weight: 400;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column p.text {
    margin-top: 6.66vw;
    font-size: 4.26vw;
    line-height: 1.6;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column .career h3.title {
    position: relative;
    margin-top: 6vw;
  }

  body.instructor .column .career h3.title::after {
    content: "";
    display: block;
    position: absolute;
    z-index: 0;
    top: 0.65em;
    left: 0;
    width: 100%;
    height: 1px;
    border-top: 1px solid #ebebeb;
  }

  body.instructor .column .career h3.title span {
    display: table;
    position: relative;
    z-index: 1;
    padding-right: 1em;
    font-size: 3.73vw;
    line-height: 1;
    transform: rotateZ(0.03deg);
    background: #fff;
  }

  body.instructor .column .career ul.list__career {
    margin-top: 4vw;
    padding-bottom: 6vw;
    border-bottom: 1px solid #ebebeb;
  }

  body.instructor .column .career ul.list__career li {
    font-size: 3.73vw;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column .career ul.list__career li+li {
    margin-top: 0.5em;
  }

  body.instructor .column .topics {
    margin-top: 8vw;
    padding: 4.8vw 5.33vw;
    background: #f5f5f5;
    border-radius: 1.6vw;
  }

  body.instructor .column .topics h3.title {
    font-size: 3.73vw;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.instructor .column .topics p.text {
    margin-top: 3vw;
    font-size: 3.73vw;
    transform: rotateZ(0.03deg);
  }

  p.text__note {
    margin-top: 10vw;
    font-size: 3.2vw;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  /* 私たちの想い ====================*/
  body.message .titlearea .inner h1.title {
    background-image: url("images/message/title_bg_sp.jpg");
  }

  body.message .contents {
    margin-top: 10vw;
  }

  body.message .section+.section {
    margin-top: 12vw;
    padding-top: 13.33vw;
    border-top: 1px solid #ebebeb;
  }

  body.message .column .cell+.cell {
    margin-top: 6vw;
  }

  body.message figure {
    overflow: hidden;
    border-radius: 1.6vw;
  }

  body.message h2.title {
    width: 100%;
    font-size: 5.33vw;
    line-height: 1.5;
  }

  body.message p.name {
    width: 100%;
    margin-top: 4vw;
  }

  body.message p.name span.sub {
    display: block;
    font-size: 3.2vw;
    font-weight: 400;
    transform: rotateZ(0.03deg);
  }

  body.message p.name span.main {
    display: flex;
    margin-top: 3vw;
    align-items: center;
    font-size: 4.53vw;
    font-weight: 700;
    line-height: 1;
  }

  body.message p.name span.main span {
    display: block;
    margin: 0.15em 0 0 1.25em;
    font-size: 3.73vw;
    white-space: nowrap;
    transform: rotateZ(0.03deg);
  }

  body.message p.text {
    margin-top: 8vw;
    font-size: 3.73vw;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
  }

  /* 参加者の声 ====================*/
  body.voice .titlearea .inner h1.title {
    background-image: url("images/voice/title_bg_sp.jpg");
  }

  body.voice .contents {
    margin-top: 13.33vw;
    padding-top: 13.33vw;
    background: #e5f8f7 url("images/bg_common.png") center center repeat-y;
  }

  body.voice .section+.section {
    margin-top: 16vw;
  }

  body.voice h2.title {
    box-sizing: border-box;
    display: table;
    position: relative;
    margin: 0 auto;
    padding-bottom: 5.33vw;
    font-size: 9vw;
    font-weight: 900;
    line-height: 1;
  }

  body.voice h2.title::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 6px;
    background: linear-gradient(to right, #00fcff, #fff600);
  }

  body.voice h3.title {
    margin-top: 16vw;
    padding-top: 16vw;
    text-align: center;
    font-size: 6vw;
    font-weight: 700;
    line-height: 1;
  }

  body.voice dl.list__voice {
    margin-top: 8vw;
  }

  body.voice dl.list__voice dt {
    width: 17.2vw;
    height: 17.2vw;
    background: #fff;
    border-radius: 100%;
  }

  body.voice dl.list__voice dd {
    box-sizing: border-box;
    position: relative;
    width: calc(100% - 17.2vw - 4vw);
    padding: 5vw 5vw 5.33vw 5.33vw;
    font-size: 3.73vw;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
    background: #fff;
    border-radius: 8px;
  }

  body.voice dl.list__voice dd span {
    display: block;
    margin-top: 2vw;
    font-size: 3.2vw;
    font-weight: 700;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.voice dl.list__voice .group+.group {
    margin-top: 6.66vw;
  }

  body.voice dl.list__voice01 .group {
    display: flex;
    align-items: flex-start;
  }

  body.voice dl.list__voice01 .group:nth-child(odd) dt {
    margin-right: 4vw;
  }

  body.voice dl.list__voice01 .group:nth-child(odd) dd::before {
    content: "";
    display: block;
    position: absolute;
    top: 8vw;
    left: -3vw;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1.5vw 3vw 1.5vw 0;
    border-color: transparent #fff transparent transparent;
  }

  body.voice dl.list__voice01 .group:nth-child(even) {
    justify-content: flex-end;
  }

  body.voice dl.list__voice01 .group:nth-child(even) dt {
    order: 2;
    margin-left: 4vw;
  }

  body.voice dl.list__voice01 .group:nth-child(even) dd {
    order: 1;
  }

  body.voice dl.list__voice01 .group:nth-child(even) dd::after {
    content: "";
    display: block;
    position: absolute;
    top: 8vw;
    right: -3vw;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1.5vw 0 1.5vw 3vw;
    border-color: transparent transparent transparent #fff;
  }

  body.voice dl.list__voice02 .group {
    display: flex;
    align-items: flex-start;
  }

  body.voice dl.list__voice02 .group:nth-child(even) dt {
    margin-right: 4vw;
  }

  body.voice dl.list__voice02 .group:nth-child(even) dd::before {
    content: "";
    display: block;
    position: absolute;
    top: 8vw;
    left: -3vw;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1.5vw 3vw 1.5vw 0;
    border-color: transparent #fff transparent transparent;
  }

  body.voice dl.list__voice02 .group:nth-child(odd) {
    justify-content: flex-end;
  }

  body.voice dl.list__voice02 .group:nth-child(odd) dt {
    order: 2;
    margin-left: 4vw;
  }

  body.voice dl.list__voice02 .group:nth-child(odd) dd {
    order: 1;
  }

  body.voice dl.list__voice02 .group:nth-child(odd) dd::after {
    content: "";
    display: block;
    position: absolute;
    top: 8vw;
    right: -3vw;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1.5vw 0 1.5vw 3vw;
    border-color: transparent transparent transparent #fff;
  }

  body.voice h2.anchor {
    margin-bottom: -21vw;
  }

  body.voice h3.anchor {
    margin-top: 0;
  }

  body.voice .list__voice_btn {
    margin: 40px 10px;
  }

  body.voice ul.ul-btn {
    max-width: 300px;
    display: block;
    margin: 40px auto 60px;
  }

  body.voice ul.ul-btn li {
    box-sizing: border-box;
    position: relative;
    max-width: 300px;
    margin-bottom: 30px;
  }

  body.voice ul.ul-btn li a {
    display: block;
    text-decoration: none;
    padding: 20px 50px;
    color: #000;
    border-radius: 30px;
    border: 1px solid #dcdcdc;
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1;
    position: relative;
  }

  body.voice ul.ul-btn li a::before {
    content: "";
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border-radius: 100%;
    background: #00e4ed;
  }

  body.voice ul.ul-btn li a::after {
    content: "";
    position: absolute;
    top: 23px;
    right: 25px;
    width: 8px;
    height: 8px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(135deg);
  }

  /* よくある質問 ====================*/
  body.qa .titlearea .inner h1.title {
    background-image: url("images/qa/title_bg_sp.jpg");
  }

  body.qa .contents {
    margin-top: 13.33vw;
  }

  body.qa dl.list__qa {
    margin-top: 10.66vw;
  }

  body.qa dl.list__qa .group {
    border-left: 3px solid #00bfb3;
  }

  body.qa dl.list__qa dt {
    position: relative;
    padding: 4vw 4vw 4vw 4em;
    font-size: 3.73vw;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
  }

  body.qa dl.list__qa dt::before {
    content: "Q";
    display: block;
    position: absolute;
    top: 4vw;
    left: 6vw;
    font-size: 6.93vw;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    line-height: 1;
  }

  body.qa dl.list__qa dd {
    position: relative;
    padding: 4vw 4vw 4vw 4em;
    font-size: 3.73vw;
    font-weight: 700;
    line-height: 1.7;
    transform: rotateZ(0.03deg);
    background: #e5f8f7;
  }

  body.qa dl.list__qa dd::before {
    content: "A";
    display: block;
    position: absolute;
    top: 4vw;
    left: 6vw;
    font-size: 6.93vw;
    font-family: "Montserrat", sans-serif;
    font-weight: 700;
    color: #00bfb3;
    line-height: 1;
  }

  body.qa dl.list__qa .group+.group {
    margin-top: 5.33vw;
  }

  /* 実施校一覧 ====================*/
  body.school .titlearea .inner h1.title {
    background-image: url("images/school/title_bg_sp.jpg");
  }

  body.school .contents {
    margin-top: 5.33vw;
  }

  body.school .maparea {
    margin-bottom: 2.66vw;
  }

  body.school .maparea .column .cell .img {
    width: 70%;
    margin: auto;
  }

  body.school .maparea .column .cell+.cell {
    display: flex;
    align-items: center;
    margin-top: 5.33vw;
  }

  body.school .maparea ul.list__anchor {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
  }

  body.school .maparea ul.list__anchor li {
    box-sizing: border-box;
    position: relative;
    width: calc((100% - 3.2vw) / 2);
    height: 13vw;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(even) {
    margin-left: 3.199vw;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(n+3) {
    margin-top: 3.199vw;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(1) a::before {
    background: #00e4ed;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(1) a span::before {
    background: #00e4ed;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(2) a::before {
    background: #00edce;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(2) a span::before {
    background: #00edce;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(3) a::before {
    background: #00edce;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(3) a span::before {
    background: #00edce;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(4) a::before {
    background: #00e573;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(4) a span::before {
    background: #00e573;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(5) a::before {
    background: #00e573;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(5) a span::before {
    background: #00e573;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(6) a::before {
    background: #a2e209;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(6) a span::before {
    background: #a2e209;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(7) a::before {
    background: #e7ef00;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(7) a span::before {
    background: #e7ef00;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(8) a::before {
    background: #b7dbd9;
  }

  body.school .maparea ul.list__anchor li:nth-of-type(8) a span::before {
    background: #b7dbd9;
  }

  body.school .maparea ul.list__anchor li a {
    box-sizing: border-box;
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
  }

  body.school .maparea ul.list__anchor li a::before {
    content: "";
    display: block;
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 1.6vw;
    height: 13vw;
  }

  body.school .maparea ul.list__anchor li a span {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 0 12vw 0 4vw;
    font-size: 4.26vw;
    font-weight: 700;
    color: #000;
    line-height: 1.2;
    transform: rotateZ(0.03deg);
    border: 1px solid #dcdcdc;
    border-radius: 0 60px 60px 0;
  }

  body.school .maparea ul.list__anchor li a span::before {
    content: "";
    position: absolute;
    top: 2.8vw;
    right: 2.8vw;
    width: 7.2vw;
    height: 7.2vw;
    border-radius: 100%;
  }

  body.school .maparea ul.list__anchor li a span::after {
    content: "";
    position: absolute;
    top: 4.8vw;
    right: 5.33vw;
    width: 2vw;
    height: 2vw;
    border-top: solid 0.6vw #fff;
    border-right: solid 0.6vw #fff;
    transform: rotate(135deg);
  }

  body.school .maparea ul.list__anchor li a span br {
    display: none;
  }

  body.school .section {
    margin-top: -2.66vw;
    padding-top: 16vw;
  }

  body.school .section .column {
    margin-top: 6.4vw;
  }

  body.school .section .column .cell+.cell {
    margin-top: 5.2vw;
  }

  body.school h2.title {
    box-sizing: border-box;
    position: relative;
    height: 13.6vw;
    padding: 2vw 0 0 5.33vw;
    font-size: 5.86vw;
    font-weight: 900;
    line-height: 1;
    border-bottom: 1px solid #dcdcdc;
  }

  body.school h2.title::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 1.6vw;
    height: 10.66vw;
    background: #ccc;
  }

  body.school h3.title {
    font-size: 4.8vw;
    font-weight: 700;
    line-height: 1;
    transform: rotateZ(0.03deg);
  }

  body.school ul.list__school {
    box-sizing: border-box;
    margin-top: 3vw;
    padding: 4.66vw 5.33vw;
    background: #f5f5f5;
    border-radius: 2.13vw;
  }

  body.school ul.list__school li {
    font-size: 3.73vw;
    transform: rotateZ(0.03deg);
  }

  body.school ul.list__school li+li {
    margin-top: 2vw;
  }

  body.school .section01 h2.title::before {
    background: #00e4ed;
  }

  body.school .section02 h2.title::before {
    background: #00edce;
  }

  body.school .section03 h2.title::before {
    background: #00edce;
  }

  body.school .section04 h2.title::before {
    background: #00e573;
  }

  body.school .section05 h2.title::before {
    background: #00e573;
  }

  body.school .section06 h2.title::before {
    background: #a2e209;
  }

  body.school .section07 h2.title::before {
    background: #e7ef00;
  }

  body.school .section08 h2.title::before {
    background: #b7dbd9;
  }
  body.school .section .school_text {
    text-align: right;
    padding: 1em 0;
    font-size: 1.4rem;
  }
  .calender_box_inner dl dt {
    font-size: 20px;
  }

  .congestion_situation {
    width: 100px;
    font-size: 15px;
  }

  .situation_setails {
    width: calc(100% - 100px);
    font-size: 14px;
    padding: 0 0.5em;
  }

  .bnr__calender a {
    padding-top: 2px;
    font-size: 18px;
  }

  /* お問い合わせ ====================*/
  body.contact .titlearea .inner h1.title {
    background-image: url("images/contact/title_bg_sp.jpg");
  }

  body.contact .section {
    margin-top: 60px;
  }

  body.contact .list__contact_wrap {
    display: block;
  }

  body.contact .list__contact_box {
    border: 1px solid #d9d9d9;
    border-radius: 6px;
    padding: 40px 30px;
    text-align: center;
    display: flex;
    flex-direction: column;
    margin-bottom: 30px;
  }

  body.contact h2.title {
    box-sizing: border-box;
    display: table;
    position: relative;
    margin: 0 auto;
    padding-bottom: 20px;
    font-size: 2rem;
    font-weight: 900;
    line-height: 1;
  }

  body.contact h2.title::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 6px;
    background: linear-gradient(to right, #00fcff, #fff600);
  }

  body.contact .list__contact_box img {
    margin: 30px auto;
    max-width: 120px;
  }

  body.contact .list__contact_box p {
    font-size: 1.6rem;
    text-align: left;
    margin-bottom: 40px;
  }

  body.contact .btn_contact {
    margin-top: auto;
  }

  body.contact .btn_contact_calender {
    width: 100%;
    text-align: center;
    padding-bottom: 20px;
  }

  body.contact .btn_contact_calender a:link {
    color: #00bfb3;
    font-weight: 700;
    border: 1px solid #00bfb3;
    font-size: 18px;
    padding: 10px 40px;
    border-radius: 100px;
    text-decoration: none;
    display: inline-block;
  }

  body.contact .btn_contact_form {
    width: 100%;
    height: 80px;
    margin: 0 auto;
  }

  body.contact .btn_contact_form a {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-decoration: none;
    font-size: 2rem;
    font-weight: 900;
    color: #fff;
    line-height: 1;
    background: #00bfb3;
    border-radius: 40px;
    border: 2px solid #fff;
  }

  /* アウトカム評価 ====================*/
  body.check .titlearea .inner h1.title {
    background-image: url("images/check/title_bg_sp.jpg");
  }

  .ttl_check {
    font-size: 24px;
    font-weight: 800;
    padding: 1em 0;
    text-align: center;
  }

  .sttl_check {
    font-weight: 600;
    font-size: 14px;
    display: block;
  }

  .dl_link a {
    position: relative;
    font-size: 16px;
    line-height: 1.2em;
    text-decoration: none;
    font-weight: 700;
    color: #000;
    margin: auto;
    border: solid 1px #dcdcdc;
    border-radius: 100px;
    padding: 0.5em 3em 0.5em 1.5em;
    display: inline-block;
  }

  .dl_link a::before {
    content: "";
    position: absolute;
    top: calc(50% - 18px);
    right: 12px;
    width: 36px;
    height: 36px;
    background: #00e4ed;
    border-radius: 100%;
  }

  .dl_link a::after {
    content: "";
    position: absolute;
    top: calc(50% - 7px);
    right: 25px;
    width: 8px;
    height: 8px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    transform: rotate(135deg);
  }

  .check .sttl_program {
    line-height: 1.2em;
  }

  .miyake_teacher_box img {
    margin-bottom: 1em;
  }

  .rubric_links {
    text-align: center;
  }

  .rubric_links a {
    position: relative;
    display: inline-block;
    text-decoration: none;
    margin: 10px auto;
    border: solid 1px #17bfb3;
    color: #17bfb3;
    font-size: 16px;
    line-height: 1.1em;
    font-weight: 700;
    padding: 0.5em 2.5em;
    border-radius: 100px;
  }

  .rubric_links a i {
    position: absolute;
    right: 1em;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  }

  /* =================================================== */

}

@media screen and (max-width: 480px) {
  .modal-container {
    padding: 0;
  }

  .modal-content {
    padding: 10px;
  }

  .concept_movie_inner {
    text-align: center;
    display: block;
  }

  .concept_movie_left {
    text-align: center;
  }
}