@charset "UTF-8";
/*コース紹介・教育内容----------------------------------------------------------------*/
.container30,
.aim_pc,
.year_detail,
.subject_sp,
.one_year,
.annual_inner,
.container10,
.line_box li,
.line_box_up,
.line_box_bottom,
.row_up,
.row_bottom,
.line_box_wh_up {
  box-sizing: border-box;
}

.breadcrumb_page {
  color: #666666;
  padding: 0 10px;
}

/* ページタイトル ----------*/
.category-title {
  background-color: #b69f72;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 55px;
}

.category-title h2 {
  text-align: center;
  font-weight: bold;
  font-size: 28px;
  height: auto;
}

@media screen and (min-width: 768px) {
  .category-title {
    height: 150px;
  }

  .category-title h3 {
    width: 386px;
  }
}

/* container ----------*/
.container30 {
  margin: 30px 0 0 0;
  width: 100%;
  padding: 0 7%;
}

.gray-container {
  background-color: #eff0f7;
}

.container10 {
  width: 100%;
  padding: 10px 2% 60px 2%;
}

@media screen and (min-width: 1024px) {
  .container30 {
    width: 1020px;
    padding: 20px 10px;
    margin: 0px auto 0 auto;
  }

  .container10 {
    width: 1020px;
    padding: 10px 10px 100px 10px;
    margin: 0 auto;
  }
}

/* コース紹介 ナビゲーションメニュー----------*/
#course_menu {
  display: flex;
  justify-content: space-around;
  width: 877px;
  margin: 0 auto 15px auto;
}

#course_menu a {
  color: #393d46;
  display: block;
  width: 138px;
  line-height: 38px;
  border: solid 1px #393d46;
  text-align: center;
}

#course_menu a:hover,
#course_menu .act_a {
  background-color: #6fc5c2;
  color: #fff;
}

#course_menu_btn {
  text-align: center;
  line-height: 30px;
  border: solid 1px #393d46;
  position: relative;
  display: none;
}

#course_menu_btn img {
  width: 20px;
  height: auto;
  position: absolute;
  top: 5px;
  right: 16px;
}

@media screen and (max-width: 1024px) {
  .container30 {
    margin: 30px 0 0 0;
    width: 100%;
    padding: 0 2%;
  }

  #course_menu_btn {
    display: block;
  }

  #course_menu {
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
  }

  #course_menu li {
    width: calc((100% / 2) - 4px);
    margin-top: 10px;
  }

  #course_menu a {
    width: calc(100% - 2px);
    line-height: 30px;
  }
}

.couse_menu_detail {
  margin-top: 16px;
  display: flex;
  justify-content: space-around;
}

.couse_menu_detail li {
  width: 24.7%;
}

.couse_menu_detail a {
  display: block;
  width: 100%;
}

.couse_menu_detail a:hover,
.aim_pc a:hover {
  opacity: 0.7;
}

.course_name {
  width: 100%;
  line-height: 40px;
  text-align: center;
  color: #fff;
}

.couse_menu_detail li:first-of-type div {
  background-color: #0068b7;
}

.couse_menu_detail li:nth-of-type(2) div {
  background-color: #f39939;
}

.couse_menu_detail li:nth-of-type(3) div {
  background-color: #6cbb5a;
}

.couse_menu_detail li:nth-of-type(4) div {
  background-color: #915da3;
}

.couse_menu_detail img {
  vertical-align: top;
}

@media screen and (max-width: 768px) {
  .container30 {
    margin: 20px 0 0 0;
    padding: 0 7%;
  }

  .container10 {
    padding: 10px 7% 40px 7%;
  }
  .couse_menu_detail {
    margin-top: 20px;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .couse_menu_detail li {
    width: calc((100% / 2) - 3px);
    margin-top: 10px;
  }

  .couse_menu_detail a {
    height: auto;
  }

  .course_name {
    font-size: 0.875rem;
    line-height: 34px;
  }

  .couse_menu_detail img {
    width: 100%;
  }
}

/* コース紹介 横浜学園の3年間----------*/
.title_h3 {
  width: 620px; /*460px*/
  margin: 50px auto 0 auto;
  border-bottom: solid 2px #1c1c1c;
  text-align: center;
  padding-bottom: 18px;
  font-size: 1.75rem;
  font-weight: bold;
}

.title_h3_sub {
  display: block;
  font-size: 1.125rem;
  font-weight: normal;
  margin-bottom: 1rem;
}

.title_h4 {
  margin-top: 50px;
  text-align: center;
  font-size: 1.625rem;
  color: #961367;
  letter-spacing: 0.55rem;
}

.lead {
  font-size: 1.125rem;
  letter-spacing: 0.4rem;
  text-align: center;
  margin-top: 24px;
  font-weight: bolder;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .title_h3 {
    width: 100%;
    font-size: 1.375rem;
    margin: 30px auto 0 auto;
    line-height: 1.4;
    padding-bottom: 10px;
  }

  .title_h4 {
    margin-top: 30px;
    font-size: 1.25rem;
  }

  .lead {
    font-size: 0.875rem;
    margin-top: 14px;
    letter-spacing: 0;
  }
}

.aim {
  margin-top: 40px;
  display: flex;
  justify-content: space-around;
}

.aim div.annual:first-child {
  width: 31%;
}

.aim div.annual:last-child {
  width: 62.8%;
  margin-left: 6.2%;
}

.one_year {
  width: 100%;
  max-width: 310px;
  line-height: 47px;
  text-align: center;
  color: #fff;
  background-color: #393d46;
}

.annual_inner {
  display: flex;
  justify-content: flex-end;
}

.annual_inner p:first-child {
  margin-right: 10px;
}

.year_detail {
  margin: 20px 0 10px 0;
}

.aim_pc {
  margin-bottom: 70px;
}

.create,
.academy {
  display: flex;
  justify-content: space-around;
  border: solid 1px #0068b7;
  border-radius: 9px;
  padding: 10px;
}

.create {
  margin-bottom: 14px;
}

.create a,
.academy a {
  display: block;
  max-width: 610px;
}

.academy a {
  margin-bottom: 10px;
}

.academy div a:last-child {
  margin-bottom: 0;
}

.create_img {
  max-width: 361px;
  height: auto;
}

.aim_sp,
.aim_link_sp {
  display: none;
}

@media screen and (max-width: 1024px) {
  .aim_pc {
    display: none;
  }

  .aim {
    flex-direction: column;
    margin-bottom: 40px;
  }

  .aim div.annual:first-child {
    width: 100%;
    margin-bottom: 10px;
  }

  .aim div.annual:last-child {
    width: 100%;
    margin-left: 0;
  }

  .annual {
    display: flex;
    justify-content: flex-start;
  }

  .annual_inner {
    justify-content: flex-start;
    flex-direction: column;
    background-color: #393d46;
    margin-top: 5px;
    padding-top: 56%;
  }

  .one_year {
    width: 26px;
    line-height: 1.5;
  }

  .year_detail {
    margin: 0 0 1rem 0;
    width: 100%;
  }

  .annual_inner p:first-child {
    margin-right: 0;
    padding-bottom: 1rem;
  }

  .annual:first-of-type .one_year {
    margin-bottom: 6%;
    padding-top: 18%;
  }

  .subject_sp {
    width: calc(100% - 26px);
    padding-left: 1rem;
  }

  .aim_sp {
    width: 100%;
    display: flex;
  }

  .aim_sp img,
  .aim_link_sp a {
    width: calc((100% - 10px) / 2);
    display: block;
  }

  .aim_sp img:first-child {
    padding-right: 10px;
  }

  .aim_link_sp {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 10px;
  }

  .aim_link_sp:last-of-type {
    margin-bottom: 0;
  }

  .aim_link_sp img {
    vertical-align: top;
  }

  .aim_link_sp a:nth-child(2) {
    margin-left: 10px;
  }
}

/* カルーセルslide ----------*/
.slide_area {
  width: 100%;
  overflow: hidden;
}

#course_slide {
  width: 125%;
  display: flex;
  margin-left: 0;
}

#course_slide li {
  width: calc(100% / 5);
}

#course_slide img {
  vertical-align: top;
  max-width: 100%;
}

@media screen and (max-width: 768px) {
  #course_slide {
    width: calc(100% * 5);
    margin-left: 0;
  }
}

/* 協調学習 ----------*/
.line_box {
  display: flex;
  justify-content: space-between;
  margin-top: 60px;
}

.line_box li,
.row_up,
.row_bottom {
  width: calc((100% - 40px) / 2);
  min-height: 196px;
  padding: 18px 0;
  border: solid 1px #393d46;
  overflow: hidden;
}

.line_box_up {
  text-align: center;
  font-weight: bolder;
  background: url(../img/course/line_deco.png) center bottom no-repeat;
  background-size: 768px 12px;
  padding: 0 10px 16px 10px;
  min-height: 90px;
}

.line_box_bottom {
  padding: 20px 10px 0 10px;
  text-align: center;
}

.bold_text,
.line_box_wh_up {
  font-size: 1.375rem;
  font-weight: bold;
  letter-spacing: 0.2rem;
}

.semi_bold_text {
  font-weight: bolder;
  letter-spacing: 0.2rem;
}

.semi_bold_text span {
  font-weight: normal;
  font-size: 0.875rem;
  display: block;
  letter-spacing: 0;
}

.line_box_wh {
  margin-top: 76px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.row_up {
  width: calc((100% - 100px) / 3);
  background-color: #fff;
  min-height: 200px;
  border: none;
  padding-top: 0;
}

.row_bottom {
  background-color: #fff;
  margin-top: 40px;
  min-height: 150px;
  border: none;
  padding-top: 0;
}

.line_box_wh_up {
  font-size: 1.125rem;
  text-align: center;
  padding: 9px;
}

.line_box_wh_bottom {
  background: url(../img/course/line_deco2.png) center top no-repeat;
  background-size: 480px 12px;
  padding: 26px 10px 0 10px;
  text-align: center;
  font-size: 0.937rem;
}

.line_box_wh_bottom p {
  line-height: 1.5;
}

.line_box_wh_bottom p:last-child {
  margin-top: 8px;
}

@media screen and (max-width: 768px) {
  .line_box {
    flex-direction: column;
    margin-top: 40px;
  }

  .line_box li {
    width: 100%;
    padding: 16px 0 8px 0;
    min-height: auto;
    margin-bottom: 18px;
  }

  .line_box_wh_up {
    min-height: 68px;
    font-size: 0.875rem;
  }

  .line_box_wh_up p {
    line-height: 1.6;
  }

  .line_box_bottom {
    padding: 6px 10px 0 10px;
  }

  .bold_text {
    font-size: 1.25rem;
  }

  .semi_bold_text {
    font-size: 0.875rem;
  }

  .semi_bold_text {
    font-size: 0.75rem;
  }

  .line_box_wh {
    margin-top: 22px;
  }

  .row_up,
  .row_bottom {
    width: calc((100% - 7%) / 2);
    min-height: auto;
    margin-bottom: 24px;
  }

  .line_box_wh_up {
    font-size: 0.875rem;
    height: 42px;
    min-height: auto;
    letter-spacing: 0.12rem;
    padding: 9px 0;
  }

  .line_box_wh_bottom {
    padding: 26px 4px 0 4px;
    font-size: 0.75rem;
  }

  .row_bottom {
    margin-top: 0;
  }

  .row_bottom:last-of-type {
    margin-left: 26.75%;
  }
}

/* クリエイティブコース ----------------------------------------------------------------*/
.slide_wrapp {
  width: 100%;
  overflow: hidden;
  position: relative;
  margin-top: 48px;
}

#slide_creative {
  width: calc(1000px * 4);
  display: flex;
  margin-left: calc((1000px - ((100% - 1000px) / 2)) * -1);
}

#slide_creative li {
  width: 1000px;
}

#slide_creative img {
  max-width: 100%;
  vertical-align: top;
}

#creative_title {
  position: absolute;
  width: 547px;
  height: 90px;
  background: url(../img/course/slide_text.png) left top no-repeat;
  bottom: 0;
  left: calc((100% - 1000px) / 2);
  box-sizing: border-box;
  padding: 14px 24px;
}

.slide_title {
  color: #fff;
  font-size: 1.625rem;
  font-weight: bold;
}

.slide_title small {
  font-weight: normal;
  font-size: 1.125rem;
  color: #fff;
}

.slide_sub_title {
  color: #fff;
  font-size: 1.125rem;
  margin-top: 4px;
}

@media screen and (max-width: 1000px) {
  .slide_wrapp {
    margin-top: 30px;
  }

  #slide_creative {
    width: calc(100% * 4);
    margin-left: calc(100% * -1);
  }

  #slide_creative li {
    width: 25%;
  }

  #creative_title {
    position: static;
    width: 100%;
    height: 70px;
    background: rgba(0, 104, 183, 0.8);
    padding: 10px;
    text-align: center;
  }

  .slide_title {
    font-size: 1.25rem;
  }

  .slide_title small {
    font-size: 0.937rem;
  }

  .slide_sub_title {
    font-size: 0.937rem;
    margin-top: 0;
  }
}

.course_intro {
  width: 1020px;
  margin: 40px auto 60px auto;
  padding: 0 10px;
  box-sizing: border-box;
}

.course_lead {
  text-align: center;
  line-height: 1.8;
  margin-top: 30px;
}

.point_left {
  width: 100%;
  background: #eff0f7;
  display: flex;
}

.point_right {
  width: 100%;
  display: flex;
  flex-direction: row-reverse;
}

.point_img img {
  max-width: 100%;
  vertical-align: top;
  height: 360px;
  object-fit: cover;
}

.point_box {
  width: 500px;
  margin: 60px 0;
  box-sizing: border-box;
}

.point_left .point_box {
  margin-left: 50px;
  margin-right: 10px;
}

.point_right .point_box {
  margin-right: 50px;
  margin-left: 10px;
}

.point_title,
.curriculum_title {
  font-size: 1.25rem;
  color: #0067b7;
  letter-spacing: 0.4rem;
  font-weight: bold;
}

.curriculum_title {
  margin-top: 50px;
  margin-bottom: 24px;
}

.curriculum {
  width: 100%;
  border-left: solid 1px #ccc;
  border-bottom: solid 1px #ccc;
  border-collapse: collapse;
}

.curriculum th {
  width: 149px;
  box-sizing: border-box;
  border-top: solid 1px #ccc;
  border-right: solid 1px #ccc;
  font-weight: normal;
  background: #dbebf8;
}

.curriculum td {
  box-sizing: border-box;
  border-top: solid 1px #ccc;
  border-right: solid 1px #ccc;
  padding-top: 4px;
  text-align: center;
  background: #fff;
}

.curriculum td:first-of-type {
  box-sizing: border-box;
  border-top: solid 1px #ccc;
  border-right: solid 1px #ccc;
  min-height: 40px;
  padding-top: 4px;
  text-align: center;
  background: #dbebf8;
}

.table_top th,
.curriculum .table_top td {
  background: #004d99;
  color: #fff;
}

.curriculum .behind {
  width: 119px;
}

.table_top .td_front {
  width: calc(100% - (120px * 5 + 150px));
}

.curriculum .table_border td {
  height: 3px;
  padding: 0;
}

.curriculum .table_bottom td {
  background: #fff;
}

@media screen and (max-width: 768px) {
  .course_intro {
    width: 100%;
    margin: 30px 0;
    padding: 0 7%;
  }

  .course_intro .lead {
    font-size: 0.937rem;
  }

  .course_lead {
    font-size: 0.937rem;
    margin-top: 20px;
    line-height: 1.5;
    text-align: left;
  }

  .point_left,
  .point_right {
    flex-direction: column;
  }

  .point_img img {
    width: 100%;
    height: auto;
    object-fit: fill;
  }

  .point_box {
    width: 100%;
    margin: 30px 0;
    padding: 0 7% 10px 7%;
  }

  .point_left .point_box {
    margin-left: 0;
    margin-right: 0;
  }

  .point_right .point_box {
    margin-right: 0;
    margin-left: 0;
  }

  .point_box .font_bold {
    margin-top: 0;
  }

  .font_bold {
    text-align: center;
    font-size: 1rem;
  }

  .point_title,
  .curriculum_title {
    font-size: 1.125rem;
    text-align: center;
    line-height: 1.5;
  }

  .curriculum_title {
    margin-top: 30px;
    margin-bottom: 30px;
  }

  .curriculum {
    font-size: 0.812rem;
  }

  .curriculum th {
    width: 42px;
  }

  .curriculum .behind {
    width: 38px;
  }

  .table_top .td_front {
    width: calc(100% - 232px);
  }
}

/* アドバンスコース ----------------------------------------------------------------*/
.advance #creative_title {
  background: url(../img/course/slide_text_orange.png) left bottom no-repeat;
}

.advance_box .point_title,
.advance_table .curriculum_title {
  color: #f88b2c;
}

.advance_table .curriculum th,
.advance_table .curriculum td:first-of-type {
  background: #ffe3c6;
}

.advance_table .table_top th,
.advance_table .curriculum .table_top td {
  background: #c15147;
}

.advance_table .curriculum .table_bottom td {
  background: #fff;
}

.advance_tab {
  width: 1000px;
  margin: 0 auto;
  display: flex;
}

.advance_tab li {
  width: 50%;
  height: 50px;
}

.advance_tab li a {
  display: block;
  width: 100%;
  line-height: 50px;
  text-align: center;
  color: #fff;
  font-size: 1.125rem;
  background: #30332c;
}

.advance_tab li a:hover,
.advance_tab .act_advance a {
  background: #6fc5c2;
}

@media screen and (max-width: 768px) {
  .advance #creative_title {
    background: rgba(243, 153, 57, 0.8);
  }

  .advance_tab {
    width: 100%;
  }

  .advance_table .curriculum .sp_td {
    width: 58px;
  }
}
