﻿#topVisual {
  position: relative;
  background: #fff;
  margin-bottom: 270px;
}
#topVisual #topVisualImage img {
  width: 100%;
  max-width: none;
}
#topVisual #topVisualTitle {
  background: url(/recruit/internship/osakagasinternship/image/title-bg.png) no-repeat left center;
  width: 590px;
  height: 428px;
  position: absolute;
  left: 0;
  bottom: -38%;
  padding: 55px 120px;
  color: #1C65B6;
}
.kousen #topVisual #topVisualTitle, .pro #topVisual #topVisualTitle {
  padding: 55px 100px;
}
#topVisual #topVisualTitle h1 .sub {
  font-size: 1.6rem;
  display: block;
  line-height: 1;
}
#topVisual #topVisualTitle h1 .main {
  display: block;
  font-size: 4.5rem;
  line-height: 1;
  margin-bottom: 30px;
}
#topVisual #topVisualLogos {
  display: flex;
  flex-wrap: wrap;
}
#topVisual #topVisualLogos div {
  margin: 5px 20px 5px 0;
  line-height: 0;
}
.kousen #topVisual #topVisualLogos div:nth-child(3), .pro #topVisual #topVisualLogos div:nth-child(3) {
  padding-top: 4px;
}
#topVisual #topVisualTitle .titleTarget {
  display: inline-block;
  margin-top: 15px;
  font-size: 1.8rem;
  font-weight: bold;
  border-top: 1px solid #1C65B6;
  border-bottom: 1px solid #1C65B6;
  line-height: 1.5;
  background-color: #F5F7F8;
  padding: 10px 5px;
}
.kousen #topVisual #topVisualTitle .tvtLogo:nth-child(1) img, .pro #topVisual #topVisualTitle .tvtLogo:nth-child(1) img {
  height: auto;
  width: 170px;
  padding-top: 2px;
}
.kousen #topVisual #topVisualTitle .tvtLogo:nth-child(2) img, .pro #topVisual #topVisualTitle .tvtLogo:nth-child(2) img {
  height: auto;
  width: 170px;
}
.kousen #topVisual #topVisualTitle .tvtLogo:nth-child(3) img, .pro #topVisual #topVisualTitle .tvtLogo:nth-child(3) img {
  height: auto;
  width: 130px;
}
.kousen #topVisual #topVisualTitle .tvtLogo:nth-child(4) img, .pro #topVisual #topVisualTitle .tvtLogo:nth-child(4) img {
  height: auto;
  width: 90px;
}
.indentation {
  padding-left: 1em;
  text-indent: -1em;
}
@media screen and (max-width: 768px) {
  #topVisual {
    margin: 0;
  }
  #topVisual #topVisualTitle {
    position: static;
    width: 100%;
    height: auto;
    padding: 30px;
    text-align: center;
    background: none;
    background-color: #fff;
  }
  .kousen #topVisual #topVisualTitle, .pro #topVisual #topVisualTitle {
    padding: 30px;
  }
  #topVisual #topVisualTitle .tvtLogo {}
  #topVisual #topVisualTitle .tvtLogo img {
    height: 30px;
    width: auto;
  }
  #topVisual #topVisualLogos {
    justify-content: center;
  }
  #topVisual #topVisualLogos div {
    margin: 5px 10px;
  }
  .kousen #topVisual #topVisualTitle .tvtLogo:nth-child(1) img, .pro #topVisual #topVisualTitle .tvtLogo:nth-child(1) img {
    height: auto;
    width: 160px;
    padding-top: 2px;
  }
  .kousen #topVisual #topVisualTitle .tvtLogo:nth-child(2) img, .pro #topVisual #topVisualTitle .tvtLogo:nth-child(2) img {
    height: auto;
    width: 160px;
  }
  .kousen #topVisual #topVisualTitle .tvtLogo:nth-child(3) img, .pro #topVisual #topVisualTitle .tvtLogo:nth-child(3) img {
    height: auto;
    width: 130px;
  }
  .kousen #topVisual #topVisualTitle .tvtLogo:nth-child(4) img, .pro #topVisual #topVisualTitle .tvtLogo:nth-child(4) img {
    height: auto;
    width: 90px;
  }
  #topVisual #topVisualTitle .titleTarget {
    font-size: 1.4rem;
  }
}
/* Course
--------------------------------------*/
#index .courseBox {
  margin-bottom: 100px;
}
#index.kousenIndex #seminar.courseBox {
	margin-bottom: 20px;
}
#index .courseBox:not(.courseListBox) .recruitInner {
  position: relative;
  border-radius: 23px;
  box-shadow: 0px 0px 6px #00000029;
  background-color: #fff;
  padding: 60px 80px;
}
#index .courseBox .recruitInner .layout {
  display: flex;
}
#index .courseBox:not(.courseListBox) .recruitInner::before {
  content: "";
  display: block;
  position: absolute;
  width: 13px;
  height: 73px;
  background-color: #1C65B6;
  left: 0;
}
#index .courseBox .courseList .ttl {
  font-weight: bold;
  font-size: 2rem;
}
#index .courseBox .courseList + .courseList {
  margin-top: 30px;
}
#index .courseBox .courseList .ttl::before {
  margin-right: 4px;
  content: '■';
}
#index .courseBox .courseList .tbl {
  margin-top: 16px;
  width: 100%;
}
#index .courseBox .courseList .tbl tr th, #index .courseBox .courseList .tbl tr td {
  padding: 16px;
  border: 1px solid #ccc;
  vertical-align: middle;
}
#index .courseBox .courseList .tbl tr th a, #index .courseBox .courseList .tbl tr td a {
  color: #1C65B6;
  display: block;
  transition: 0.2s;
}
#index .courseBox .courseList .tbl tr th a:hover, #index .courseBox .courseList .tbl tr td a:hover {
  opacity: 0.7;
}
#index .courseBox .courseList .tbl tr th {
  width: 45%;
  font-size: 17px;
  font-weight: bold;
  background: #eee;
}
#index .courseBox .courseList .tbl tr td {
  background: #fff;
}
#index .courseBox .layout .text {
  flex: 1;
  padding-right: 60px;
}
#index .courseBox .layout .text h2 {
  font-size: 3rem;
  color: #1C65B6;
  font-weight: bold;
  margin-bottom: 30px;
  line-height: 1.5;
}
#index .courseBox .layout .text h2 span {
  color: #e00;
  border: solid 3px red;
  padding: 0.1em 0.5em;
  display: inline-block;
  font-size: 80%;
}
#index .courseBox .layout .text p {
  font-size: 1.4rem;
  margin-bottom: 60px;
}
#index .courseBox .layout .text p .anno {
  display: block;
  font-size: 1.2rem;
  line-height: 1.5;
  margin-top: 1rem;
}
#index .courseBox .layout .text a {
  background-color: #1C65B6;
  color: #fff;
  font-weight: bold;
}
#index .courseBox .layout .text a:hover {
  opacity: .8;
}
#index .courseBox .layout .text a.comingsoon {
  background-color: #bbb;
  pointer-events: none;
}
#index .courseBox .layout .text a.comingsoon::after {
  display: none;
}
#index .courseBox .layout .image {
  width: 564px;
}
#index .courseBox .voice {
  position: relative;
  background: #F5F7F8;
  padding: 40px 30px;
  margin-top: 70px;
}
#index .courseBox .voice .voiceTitle {
  position: absolute;
  left: 50px;
  top: -60px;
  transform: rotate(-20deg);
}
#index .courseBox .voice h3 {
  color: #1C65B6;
  font-weight: bold;
  padding-left: 93px;
  margin-bottom: 40px;
}
#index .courseBox .voice .layout .box {
  display: flex;
  width: 50%;
}
#index .courseBox .voice .layout .box .people {
  width: 130px;
}
#index .courseBox .voice .layout .box p {
  flex: 1;
  padding-right: 30px;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  #index .courseBox {
    padding: 1rem;
    margin-bottom: 40px;
  }
  #index .courseBox:not(.courseListBox) .recruitInner {
    padding: 2rem;
  }
  #index .courseBox .recruitInner::before {
    height: 38px;
    width: 7px;
  }
  #index .courseBox .recruitInner .layout {
    display: block;
  }
  #index .courseBox .courseList .tbl tr th, #index .courseBox .courseList .tbl tr td {
    display: block;
    padding: .5em 1em;
    width: 100%;
  }
  #index .courseBox .courseList .tbl tr th {
    font-size: 16px;
  }
  #index .courseBox .courseList .tbl tr td {
    margin-bottom: .5em;
    text-align: center;
  }
  #index .courseBox .layout .text {
    padding: 0 !important;
    width: 100%;
  }
  #index .courseBox .layout .text h2 {
    font-size: 2rem;
    margin-bottom: 20px;
  }
  #index .courseBox .layout .text p {
    margin-top: 1rem;
    margin-bottom: 20px;
  }
  #index .courseBox .layout .text a {
    display: block;
    margin: auto;
  }
  #index .courseBox .voice {
    padding: 20px 30px;
  }
  #index .courseBox .voice .voiceTitle {
    width: 80px;
    left: 15px;
    top: -40px;
  }
  #index .courseBox .voice h3 {
    padding-left: 22px;
    margin-bottom: 20px;
  }
  #index .courseBox .voice .layout .box {
    display: block;
    width: 100%;
  }
  #index .courseBox .voice .layout .box .people {
    margin: 0 auto 15px;
  }
  #index .courseBox .voice .layout .box p {
    padding: 0;
    margin-bottom: 20px;
  }
}
/* Course 01
--------------------------------------*/
#course01 h2 {
  position: relative;
  font-size: 2.4rem;
  background-color: #F5F7F8;
  line-height: 94px;
  font-weight: bold;
  padding-left: 50px;
  margin-bottom: 50px;
}
#course01 h2::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
.flowStep {
  display: flex;
  justify-content: center;
  color: #fff;
  font-weight: bold;
  width: 100%;
  margin-bottom: 50px;
}
.flowStep li {
  position: relative;
  width: 25%;
  height: 72px;
  font-size: 1.4rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1.3;
  padding: 15px 0;
}
.flowStep li.w50 {
  width: 50%;
}
.flowStep.wide li {
  height: 105px;
}
.flowStep li:nth-child(1) {
  background-color: #1C65B6;
}
.flowStep li:nth-child(2) {
  background-color: #4C7DB4;
}
.flowStep li:nth-child(3) {
  background-color: #4CB476;
}
.flowStep li:nth-child(4) {
  background-color: #F7B403;
}
.flowStep li:nth-child(5) {
  background-color: #E04C0F;
}
.flowStep li.w50:last-child {
  background-color: #F7B403;
  width: 50%;
}
.flowStep li::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 72px;
  -webkit-clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
  background-color: #1C65B6;
}
.flowStep.wide li::after {
  height: 105px;
}
.flowStep li:nth-child(2)::after {
  background-color: #1C65B6;
}
.flowStep li:nth-child(3)::after {
  background-color: #4C7DB4;
}
.flowStep li:nth-child(4)::after {
  background-color: #4CB476;
}
.flowStep li:nth-child(5)::after {
  background-color: #F7B403;
}
.flowStep li:nth-child(6)::after {
  background-color: #E04C0F;
}
.flowStep li span {
  font-size: 0.95em;
  line-height: 1.5;
}
#course01 #dateTab {
  display: flex;
  justify-content: space-between;
}
#course01 #dateTab li {
  position: relative;
  width: 49%;
  background-color: #F7F7F7;
  color: #1C65B6;
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  height: 112px;
  line-height: 112px;
  cursor: pointer;
  transition: .2s;
}
#course01 #dateTab li:hover {
  background-color: #1C65B6;
  color: #F7F7F7;
}
#course01 #dateTab li::after {
  content: "";
  display: block;
  position: absolute;
  width: 44px;
  height: 44px;
  background: url(/recruit/internship/image/tab-mark02.svg) no-repeat center center;
  right: 40px;
  top: 50%;
  margin-top: -22px;
}
#course01 #dateTab li:hover::after, #course01 #dateTab li.active::after {
  background: url(/recruit/internship/image/tab-mark01.svg) no-repeat center center;
}
#course01 #dateTab li.active {
  background-color: #1C65B6;
  color: #F7F7F7;
  height: 127px;
	border: none;
}
#course01 #dateTab li:hover a, #course01 #dateTab li.active a {
  color: #fff;
}
#course01 .dateTabContent {
  display: none;
  background-color: #1C65B6;
  padding: 30px 45px;
  margin-bottom: 80px;
}
#course01 .dateTabContent.active {
  display: block;
}
#course01 .dateTabContent .dtcInner {
  padding: 5%;
  background-color: #fff;
}
#course01 .schedule table {
  width: 100%;
  margin-bottom: 50px;
}
#course01 .schedule table thead td {
  background-color: #EFF3F8;
  text-align: center;
  font-weight: bold;
  border: 1px solid #C9C9C9;
  padding: 15px 30px;
}
#course01 .schedule table tbody td {
  border: 1px solid #C9C9C9;
  padding: 15px 30px;
  font-size: 1.4rem;
}
#course01 .schedule table tbody td.date {
  font-weight: bold;
}
#course01 .schedule table tbody td b {
  color: #e00;
  font-weight: bold;
}
#course01 .schedule {
  display: flex;
  align-items: center;
  margin-bottom: 60px;
}
#course01 .schedule .box {
  width: 30%;
  border-radius: 23px;
  box-shadow: 0px 0px 6px #00000029;
  background-color: #fff;
  padding: 24px 30px 30px;
}
#course01 .schedule .box h3 {
  color: #1C65B6;
  font-weight: bold;
}
#course01 .schedule .box .date {
  font-weight: bold;
  display: block;
  margin-bottom: 8px;
}
#course01 .schedule .box .online, #course01 .schedule .box .direct {
  display: inline-block;
  color: #fff;
  font-size: 1.3rem;
  font-weight: bold;
  line-height: 1;
  margin-left: 4px;
  padding: 3px 20px 3px;
  border-radius: 16px;
}
#course01 .schedule .box .online {
  background-color: #E04C0F;
}
#course01 .schedule .box .direct {
  background-color: #4bab0d;
  ;
}
#course01 .schedule .box .blank {
  display: inline-block;
  font-size: 1.3rem;
  font-weight: bold;
  line-height: 1;
  padding: 6px 20px 8px;
}
#course01 .schedule .box .anno {
  display: inline-block;
  font-size: 1.3rem;
  line-height: 1.3;
}
#course01 .schedule .arrow {
  position: relative;
  width: 75px;
}
#course01 .schedule .arrow::after {
  content: "";
  display: block;
  position: absolute;
  left: 28px;
  top: 50%;
  margin-top: -8px;
  width: 14px;
  height: 14px;
  border-top: 2px solid #1C65B6;
  border-right: 2px solid #1C65B6;
  transform: rotate(45deg);
}
#course01 .courseBox {
  margin-bottom: 40px;
}
#course01 .courseBox {
  position: relative;
  border-radius: 23px;
  box-shadow: 0px 0px 6px #00000029;
  background-color: #fff;
  padding: 60px 80px;
}
#course01 .courseBox .layout {
  display: flex;
}
#course01 .courseBox::before {
  content: "";
  display: block;
  position: absolute;
  width: 13px;
  height: 73px;
  background-color: #1C65B6;
  left: 0;
}
#course01 .courseBox .layout .text {
  padding-right: 60px;
  width: 80%;
}
#course01 .courseBox .layout .text h3 {
  font-size: 2.6rem;
  color: #1C65B6;
  font-weight: bold;
  margin-bottom: 30px;
  line-height: 1.1;
}
#course01 .courseBox .layout .text p {
  font-size: 1.4rem;
  max-width: 640px;
}
#course01 .courseBox .layout .button {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-end;
}
#course01 .courseBox .layout .button ul {
  display: flex;
  justify-content: left;
  flex-wrap: wrap;
  width: 100%;
}
#course01 .courseBox .layout .button ul li {
  display: inline-block;
  min-width: 75px;
  color: #fff;
  font-size: 1.2rem;
  font-weight: bold;
  line-height: 1.2;
  padding: 7px 17px;
  margin-left: 5px;
  margin-bottom: 5px;
  border-radius: 5px;
}
#course01 .courseBox .layout .button ul li.kei1 {
  background-color: #4E59D9;
} /*機械*/
#course01 .courseBox .layout .button ul li.kei2 {
  background-color: #E0A521;
} /*化学*/
#course01 .courseBox .layout .button ul li.kei3 {
  background-color: #5CBAA1;
} /*土木*/
#course01 .courseBox .layout .button ul li.kei4 {
  background-color: #28B1EF;
} /*システム*/
#course01 .courseBox .layout .button ul li.kei5 {
  background-color: #D35050;
} /*電気*/
#course01 .courseBox .layout .button ul li.kei6 {
  background-color: #5B9595;
} /*材料系*/
#course01 .courseBox .layout .button ul li.kei7 {
  background-color: #c45d7d;
} /*化学工学系*/
#course01 .courseBox .layout .button ul li.kei8 {
  background-color: #34c4b3;
} /*物理系*/
#course01 .courseBox .layout .button ul li.kei10 {
  background-color: #e97a30;
} /*生化学系*/
#course01 .courseBox .layout .button ul li.kei9 {
  background-color: #575757;
} /*その他*/
#course01 .courseBox .layout .button .target {
  font-size: 1.4rem;
  line-height: 1.8;
  margin-bottom: 20px;
}
#course01 .courseBox .detailView a {
  width: 270px;
  padding: 17px;
  background-color: #1C65B6;
  color: #fff;
  font-weight: bold;
}
#course01 .courseBox .detailView a:hover {
  opacity: .8;
}
#course01 .courseBox .detailView a::after {
  transform: rotate(135deg);
  margin-top: -6px;
}
#course01 .courseBox.open .detailView a::after {
  transform: rotate(-45deg);
  margin-top: -1px;
}
#course01 .courseBox .more {
  display: none;
  padding-top: 45px;
}
#course01 .courseBox .more .layout {
  border-top: 1px dashed #1C65B6;
  padding: 70px 0;
  justify-content: space-between;
  align-items: flex-start;
}
#course01.ogInternship .courseBox .more .layout {
  padding: 70px 0 20px;
}
#course01 .courseBox .more .layout.layoutContent {
  border-top: none;
  padding: 0 0 70px;
}
#course01 .courseBox .layout .info {
  padding-right: 60px;
  width: 60%;
}
#course01 .courseBox .layout .info table {
  width: 100%;
  margin-bottom: 40px;
}
#course01 .courseBox .layout .info table th, #course01 .courseBox .layout .info table td {
  font-size: 1.4rem;
  border-bottom: 1px solid #E0E0E0;
  padding: 4px 0;
}
#course01 .courseBox .layout .info table th {
  width: 108px;
  text-align: left;
}
#course01 .courseBox .layout .info p {
  font-size: 1.4rem;
}
#course01 .courseBox .layout .infoRight {
  width: 38%;
  margin-top: 70px;
}
#course01 .courseBox .layout .infoRight figure:first-child {
  margin-bottom: 30px;
}
#course01 .courseBox .layout .voice {
  width: 38%;
}
#course01.ogInternship .courseBox .layout .voice {
  margin-top: -10px;
}
#course01 .courseBox .layout .infoRight .voice {
  width: 100%;
}
#course01 .courseBox .voice {
  position: relative;
  background: #F5F7F8;
  padding: 18px 30px 40px 30px;
  margin-top: 70px;
  border-radius: 19px;
}
#course01 .courseBox .voice .voiceTitle {
  position: absolute;
  left: 25px;
  top: -38px;
  transform: rotate(-20deg);
  width: 70px;
}
#course01 .courseBox .voice h3 {
  color: #1C65B6;
  font-weight: bold;
  padding-left: 50px;
  margin-bottom: 10px;
  font-size: 1.2rem;
}
#course01 .courseBox .voice {
  font-size: 1.4rem;
}
#course01 .courseBox .voice .prof {
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid #1C65B6;
}
#course01 .courseBox .voice p {}
.membersLinks {
  display: flex;
  justify-content: space-between;
}
#course01 .courseBox .layoutContent .infoContent {
  border: solid 2px #e0e0e0;
  padding: 10px;
  margin-bottom: 30px;
}
#course01 .courseBox .layoutContent .infoContent p {
  font-size: 1.4rem;
}
#course01 .courseBox .layout .infoPic {
  width: 48%;
}
.membersLinks .linkBox {
  position: relative;
  display: block;
  width: 48%;
  text-align: center;
  padding: 33px;
  padding-right: 20px;
  line-height: 1;
  font-size: 1.6rem;
  font-weight: bold;
}
.membersLinks .linkBox:hover {
  opacity: .8;
}
.membersLinks .linkBox1 {
  background-color: #1C65B6;
  color: #fff;
}
.membersLinks .linkBox2 {
  background-color: #FFDF2C;
}
.membersLinks .linkBox::after {
  content: "";
  display: block;
  position: absolute;
  width: 31px;
  height: 31px;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
}
.membersLinks .linkBox1::after {
  background: url(/recruit/internship/image/link_mark_b.svg) no-repeat left center;
  background-size: 31px;
}
.membersLinks .linkBox2::after {
  background: url(/recruit/internship/image/link_mark_y.svg) no-repeat left center;
  background-size: 31px;
}
#course01 .companyBox {
  display: flex;
  justify-content: space-between;
  width: 100%;
}
#course01 .companyBox .box {
  width: 32%;
}
#course01 .companyList h3 {
  color: #1C65B6;
  font-weight: bold;
  margin-top: 40px
}
#course01 .companyList h3:first-child {
  margin-top: 0;
}
#course01 .companyList .courseTitle {
  font-weight: bold;
  margin-bottom: 0.5em;
}
#course01 .companyList .courseDate {
  margin-bottom: 1em;
}
@media screen and (max-width: 1024px) {
  #course01 .courseBox .layoutContent .infoContent p {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  #course01 h2 {
    font-size: 1.8rem;
    line-height: 50px;
    padding-left: 30px;
  }
  #course01 h2::before {
    width: 20px;
    height: 20px;
  }
  .flowStep {
    flex-wrap: wrap;
  }
  .flowStep li {
    width: 100%;
    margin-bottom: 14px;
  }
  .flowStep li::after {
    left: auto;
    top: auto;
    bottom: -10px;
    width: 86px;
    height: 11px !important;
    clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
  }
  .flowStep li:nth-child(1)::after {
    background-color: #1C65B6;
  }
  .flowStep li:nth-child(2)::after {
    background-color: #4C7DB4;
  }
  .flowStep li:nth-child(3)::after {
    background-color: #4CB476;
  }
  .flowStep li:nth-child(4)::after {
    background-color: #F7B403;
  }
  .flowStep li:nth-child(5)::after {
    content: none;
  }
  #course01 .recruitInner {
    padding: 40px 0 0;
  }
  #course01 .joinFlow {
    padding: 0 20px;
  }
  #course01 #dateTab li {
    height: 74px;
    line-height: 74px;
    font-size: 1.6rem;
    text-align: left;
    padding-left: 20px;
  }
  #course01 #dateTab li.active {
    height: 74px;
    line-height: 74px;
  }
  #course01 #dateTab li:hover::after, #course01 #dateTab li.active::after, #course01 #dateTab li::after {
    width: 20px;
    height: 20px;
    background-size: 20px;
    margin-top: -10px;
    right: 14px;
  }
  #course01 .dateTabContent {
    padding: 20px 15px;
    margin-bottom: 0;
  }
  #course01 .schedule {
    margin-bottom: 30px;
    flex-direction: column;
  }
  #course01 .schedule .box {
    width: 100%;
    padding: 20px;
  }
  #course01 .schedule .box .blank {
    display: none;
  }
  #course01 .schedule .arrow {
    width: 100%;
    margin: 15px 0;
  }
  #course01 .schedule .arrow::after {
    transform: rotate(135deg);
    top: -10px;
    margin-top: 0;
    left: 50%;
    margin-left: -8px;
  }
  #course01 .schedule .row {
    border-bottom: 1px solid #1C65B6;
    font-size: 1.2rem;
  }
  #course01 .courseBox {
    padding: 20px;
  }
  #course01.ogInternship .courseBox {
    padding-top: 60px;
  }
  #course01 #topEtcLinks .recruitInner {
    padding: 0 20px;
  }
  #course01 .companyBox {
    flex-direction: column;
  }
  #course01 .companyBox .box {
    width: 100%;
    margin-bottom: 30px;
  }
  #course01 .companyBox .box:last-child {
    margin-bottom: 0;
  }
  #course01.ogInternship .courseBox .layout .info table th, #course01.ogInternship .courseBox .layout .info table td {
    display: block;
    width: 100%;
  }
  #course01.ogInternship .courseBox .layout .info table th {
    border-bottom: none;
  }
}
#course01 .courseCategory .courseViewBtn {
  position: relative;
  display: inline-block;
  line-height: 1;
  text-align: center;
  color: #fff;
  font-weight: bold;
  background-color: #0066B5;
  line-height: 1;
  border-radius: 20px;
  padding: 26px;
  width: 100%;
  transition: 0.2s;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  #course01 .courseCategory .courseViewBtn {
    font-size: 14px;
  }
}
#course01 .courseCategory .courseViewBtn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 8px;
  height: 8px;
  border-right: 1px solid #fff;
  border-top: 1px solid #fff;
  transform: rotate(135deg);
  margin-top: -6px;
}
#course01 .courseCategory.open .courseViewBtn::after {
  transform: rotate(-45deg);
  margin-top: -3px;
}
#course01 .courseCategory .courseViewBtn:hover {
  opacity: 0.8;
}
#course01 .courseCategory .courseView_more {
  display: none;
}
#course01 .courseCategory .courseViewBtn_close {
  position: relative;
  display: inline-block;
  line-height: 1;
  color: #0066B5;
  font-weight: bold;
  text-align: center;
  line-height: 1;
  border-radius: 20px;
  padding: 20px;
  width: 80%;
  transition: 0.2s;
  margin: 0 10% 60px;
  border: 1px solid #B8BEC3;
}
#course01 .courseCategory .courseViewBtn_close::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 8px;
  height: 8px;
  border-right: 1px solid #B8BEC3;
  border-top: 1px solid #B8BEC3;
  margin-top: -3px;
  rotate: -45deg;
}
#course01 .courseCategory .courseViewBtn_close:hover {
  border: 1px solid #0066B5;
  transition: 0.2s;
}
#course01 .courseBox .layout .text p.held {
  display: inline-block;
  position: absolute;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  top: 16px;
  border-radius: 25px;
  width: 150px;
  padding: 7px 0 9px;
}
#course01 .held_green {
  background-color: #4bab0d;
}
#course01 .held_orange {
  background-color: #F7B403;
}
/* course 02
--------------------------------------*/
#course02 h2 {
  position: relative;
  font-size: 2.4rem;
  background-color: #F5F7F8;
  line-height: 94px;
  font-weight: bold;
  padding-left: 50px;
  margin-bottom: 50px;
}
#course02 h2::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
#course02 .flowStep li {
  width: 33.333%;
}
#course02 .lead {
  text-align: center;
  margin-bottom: 80px;
}
.kousen .lead {
  margin-bottom: 40px;
  text-align: center;
}
.kousen .annotation {
  margin-bottom: 20px;
  font-size: 1.2rem;
}
#course02 .infoBox {
  position: relative;
  background-color: #fff;
  border: 1px solid #1C65B6;
  margin-bottom: 40px;
  padding: 30px;
}
#course02 .infoBox::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
#course02 .infoBox h3 {
  font-size: 2.4rem;
  font-weight: bold;
  border-bottom: 1px solid #1C65B6;
  padding: 10px 30px;
}
#course02 .infoBox .ibContent {
  font-size: 1.4rem;
  padding: 30px 30px;
}
#course02 .infoBox .ibContent b {
  font-weight: bold;
}
#course02 .infoBox .ibContent table {
  width: 100%;
  margin-bottom: 20px;
}
#course02 .infoBox .ibContent table th {
  background-color: #F9F9F9;
  padding: 10px;
  font-weight: bold;
  vertical-align: top;
  border: 1px solid #ccc;
  width: 130px;
}
#course02 .infoBox .ibContent table td {
  padding: 10px;
  border: 1px solid #ccc;
}
#course02 .infoBox .ibContent table td b {
  font-weight: bold;
}
/* course 03
--------------------------------------*/
#course03 h2 {
  position: relative;
  font-size: 2.4rem;
  background-color: #F5F7F8;
  line-height: 94px;
  font-weight: bold;
  padding-left: 50px;
  margin-bottom: 50px;
}
#course03 h2::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
#course03 .flowStep li {
  width: 33.333%;
}
#course03 .lead {
  text-align: center;
  margin-bottom: 80px;
}
.kousen .lead {
  margin-bottom: 40px;
}
.kousen .annotation {
  margin-bottom: 20px;
  font-size: 1.2rem;
}
#course03 .infoBox {
  position: relative;
  background-color: #fff;
  border: 1px solid #1C65B6;
  margin-bottom: 40px;
  padding: 30px;
}
#course03 .infoBox::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
#course03 .infoBox h3 {
  font-size: 2.4rem;
  font-weight: bold;
  border-bottom: 1px solid #1C65B6;
  padding: 10px 30px;
}
#course03 .infoBox .ibContent {
  font-size: 1.4rem;
  padding: 30px 30px;
}
#course03 .infoBox .ibContent b {
  font-weight: bold;
}
#course03 .infoBox .ibContent table {
  width: 100%;
  margin-bottom: 20px;
}
#course03 .infoBox .ibContent table th {
  background-color: #F9F9F9;
  padding: 10px;
  font-weight: bold;
  vertical-align: top;
  border: 1px solid #ccc;
  width: 130px;
}
#course03 .infoBox .ibContent table td {
  padding: 10px;
  border: 1px solid #ccc;
}
#course03 .infoBox .ibContent table td b {
  font-weight: bold;
}
/* course 04
--------------------------------------*/
#course04 h2 {
  position: relative;
  font-size: 2.4rem;
  background-color: #F5F7F8;
  line-height: 94px;
  font-weight: bold;
  padding-left: 50px;
  margin-bottom: 50px;
}
#course04 h2::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
#course04 .flowStep li {
  width: 33.333%;
}
#course04 .lead {
  text-align: center;
  margin-bottom: 80px;
}
.kousen .lead {
  margin-bottom: 40px;
}
.kousen .annotation {
  margin-bottom: 20px;
  font-size: 1.2rem;
}
#course04 .infoBox {
  position: relative;
  background-color: #fff;
  border: 1px solid #1C65B6;
  margin-bottom: 40px;
  padding: 30px;
}
#course04 .infoBox::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
#course04 .infoBox h3 {
  font-size: 2.4rem;
  font-weight: bold;
  border-bottom: 1px solid #1C65B6;
  padding: 10px 30px;
}
#course04 .infoBox .ibContent {
  font-size: 1.4rem;
  padding: 30px 30px;
}
#course04 .infoBox .ibContent b {
  font-weight: bold;
}
#course04 .infoBox .ibContent table {
  width: 100%;
  margin-bottom: 20px;
}
#course04 .infoBox .ibContent table th {
  background-color: #F9F9F9;
  padding: 10px;
  font-weight: bold;
  vertical-align: top;
  border: 1px solid #ccc;
  width: 130px;
}
#course04 .infoBox .ibContent table td {
  padding: 10px;
  border: 1px solid #ccc;
}
#course04 .infoBox .ibContent table td b {
  font-weight: bold;
}
/* course 05
--------------------------------------*/
#course05 h2 {
  position: relative;
  font-size: 2.4rem;
  background-color: #F5F7F8;
  line-height: 94px;
  font-weight: bold;
  padding-left: 50px;
  margin-bottom: 50px;
}
#course05 h2::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
#course05 .flowStep li {
  width: 33.333%;
}
#course05 .lead {
  text-align: center;
  margin-bottom: 80px;
}
.kousen .lead {
  margin-bottom: 40px;
}
.kousen .annotation {
  margin-bottom: 20px;
  font-size: 1.2rem;
}
#course05 .infoBox {
  position: relative;
  background-color: #fff;
  border: 1px solid #1C65B6;
  margin-bottom: 40px;
  padding: 30px;
}
#course05 .infoBox::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  height: 40px;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  clip-path: polygon(0% 0%, 100% 0%, 0% 100%);
  background-color: #1C65B6;
}
#course05 .infoBox h3 {
  font-size: 2.4rem;
  font-weight: bold;
  border-bottom: 1px solid #1C65B6;
  padding: 10px 30px;
}
#course05 .infoBox .ibContent {
  font-size: 1.4rem;
  padding: 30px 30px;
}
#course05 .infoBox .ibContent b {
  font-weight: bold;
}
#course05 .infoBox .ibContent table {
  width: 100%;
  margin-bottom: 20px;
}
#course05 .infoBox .ibContent table th {
  background-color: #F9F9F9;
  padding: 10px;
  font-weight: bold;
  vertical-align: top;
  border: 1px solid #ccc;
  width: 130px;
}
#course05 .infoBox .ibContent table td {
  padding: 10px;
  border: 1px solid #ccc;
}
#course05 .infoBox .ibContent table td b {
  font-weight: bold;
}
@media screen and (max-width: 1024px) {
  #course01 .courseBox .layout {
    display: block;
  }
  #course01 .courseBox .layout .text {
    width: 100%;
    padding: 0;
  }
  #course01 .courseBox .layout .text h3 {
    font-size: 1.8rem;
  }
  #course01 .courseBox .layout .text p {
    margin-bottom: 20px;
  }
  #course01 .courseBox::before {
    width: 7px;
    height: 45px;
  }
  #course01 .courseBox .layout .button {
    display: block;
  }
  #course01 .courseBox .layout .button ul {
    margin-bottom: 20px;
  }
  #course01 .courseBox .detailView a {
    width: 100%;
  }
  #course01 .courseBox .more .layout {
    padding: 30px 0;
  }
  #course01 .courseBox .layout .info {
    width: 100%;
    padding: 0;
  }
  #course01 .courseBox .layout .info table th {
    width: 65px;
    line-height: 1.4;
    font-size: 1.2rem;
  }
  #course01 .courseBox .layout .info table td {
    line-height: 1.4;
    font-size: 1.2rem;
  }
  #course01 .courseBox .layout .info p {
    font-size: 1.2rem;
  }
  #course01 .courseBox .layout .infoRight {
    width: 100%;
    margin-top: 30px;
  }
  #course01 .courseBox .layout .voice {
    width: 100%;
    padding: 18px 20px 30px;
  }
  #course01 .courseBox .voice h3 {
    padding-left: 30px;
  }
  #course01 .courseBox .voice .prof {
    font-size: 1.2rem;
    line-height: 1.5;
  }
  #course01 .courseBox .voice p {
    font-size: 1.2rem;
    line-height: 1.5;
  }
  #course01 .courseBox .more .layout.layoutContent {
    padding-bottom: 50px;
  }
  #course01 .courseBox .layout.layoutContent .infoContent, #course01 .courseBox .layout.layoutContent .infoPic {
    width: 100%;
  }
  #course01 .courseBox .layout.layoutContent .infoContent:first-child {
    margin-bottom: 30px;
  }
  #course01 .courseBox .more .layout.layoutContent figure:first-child {
    margin-bottom: 40px;
  }
  .membersLinks {
    display: block;
  }
  .membersLinks .linkBox {
    width: 100%;
    font-size: 1.2rem;
    text-align: left;
    padding: 20px 30px;
    margin-bottom: 15px;
  }
  .membersLinks .linkBox::after {
    width: 20px;
    height: 20px;
    background-size: 20px;
    right: 20px;
  }
  #topEtcLinks .trBlock .linkBox {
    font-size: 1.6rem;
    text-align: left;
  }
  #topEtcLinks .recruitInner .linkBox::after {
    right: 20px;
  }
}
@media screen and (max-width: 768px) {
  #course02 h2 {
    font-size: 1.8rem;
    line-height: 50px;
    padding-left: 30px;
  }
  #course02 h2::before {
    width: 20px;
    height: 20px;
  }
  #course02 .flowStep li {
    width: 100%;
  }
  .flowStep li:last-child::after {
    content: none;
  }
  #course02 .lead {
    margin-bottom: 40px;
  }
  .kousen .lead {
    margin-bottom: 20px;
  }
  .kousen .annotation {
    margin-bottom: 10px;
    font-size: 1.2rem;
  }
  #course02 .infoBox {
    padding: 15px;
  }
  #course02 .infoBox h3 {
    font-size: 1.6rem;
    padding: 10px;
  }
  #course02 .infoBox .ibContent {
    padding: 10px;
    font-size: 1.2rem;
  }
  #course02 .infoBox .ibContent table, #course02 .infoBox .ibContent table tbody, #course02 .infoBox .ibContent table tr, #course02 .infoBox .ibContent table th, #course02 .infoBox .ibContent table td {
    display: block;
    width: 100%;
  }
  #course02 .infoBox .ibContent table {
    border-bottom: 1px solid #ccc;
  }
  #course02 .infoBox .ibContent table th {
    line-height: 1.5;
    text-align: left;
    border-bottom: none;
  }
  #course02 .infoBox .ibContent table td {
    border-bottom: none;
  }
  #course03 h2 {
    font-size: 1.8rem;
    line-height: 50px;
    padding-left: 30px;
  }
  #course03 h2::before {
    width: 20px;
    height: 20px;
  }
  #course03 .flowStep li {
    width: 100%;
  }
  #course03 .lead {
    margin-bottom: 40px;
  }
  #course03 .infoBox {
    padding: 15px;
  }
  #course03 .infoBox h3 {
    font-size: 1.6rem;
    padding: 10px;
  }
  #course03 .infoBox .ibContent {
    padding: 10px;
    font-size: 1.2rem;
  }
  #course03 .infoBox .ibContent table, #course03 .infoBox .ibContent table tbody, #course03 .infoBox .ibContent table tr, #course03 .infoBox .ibContent table th, #course03 .infoBox .ibContent table td {
    display: block;
    width: 100%;
  }
  #course03 .infoBox .ibContent table {
    border-bottom: 1px solid #ccc;
  }
  #course03 .infoBox .ibContent table th {
    line-height: 1.5;
    text-align: left;
    border-bottom: none;
  }
  #course03 .infoBox .ibContent table td {
    border-bottom: none;
  }
  #course04 h2 {
    font-size: 1.8rem;
    line-height: 50px;
    padding-left: 30px;
  }
  #course04 h2::before {
    width: 20px;
    height: 20px;
  }
  #course04 .flowStep li {
    width: 100%;
  }
  #course04 .lead {
    margin-bottom: 40px;
  }
  #course04 .infoBox {
    padding: 15px;
  }
  #course04 .infoBox h3 {
    font-size: 1.6rem;
    padding: 10px;
  }
  #course04 .infoBox .ibContent {
    padding: 10px;
    font-size: 1.2rem;
  }
  #course04 .infoBox .ibContent table, #course04 .infoBox .ibContent table tbody, #course04 .infoBox .ibContent table tr, #course04 .infoBox .ibContent table th, #course04 .infoBox .ibContent table td {
    display: block;
    width: 100%;
  }
  #course04 .infoBox .ibContent table {
    border-bottom: 1px solid #ccc;
  }
  #course04 .infoBox .ibContent table th {
    line-height: 1.5;
    text-align: left;
    border-bottom: none;
  }
  #course04 .infoBox .ibContent table td {
    border-bottom: none;
  }
  #course05 h2 {
    font-size: 1.8rem;
    line-height: 50px;
    padding-left: 30px;
  }
  #course05 h2::before {
    width: 20px;
    height: 20px;
  }
  #course05 .flowStep li {
    width: 100%;
  }
  #course05 .lead {
    margin-bottom: 40px;
  }
  #course05 .infoBox {
    padding: 15px;
  }
  #course05 .infoBox h3 {
    font-size: 1.6rem;
    padding: 10px;
  }
  #course05 .infoBox .ibContent {
    padding: 10px;
    font-size: 1.2rem;
  }
  #course05 .infoBox .ibContent table, #course05 .infoBox .ibContent table tbody, #course05 .infoBox .ibContent table tr, #course05 .infoBox .ibContent table th, #course05 .infoBox .ibContent table td {
    display: block;
    width: 100%;
  }
  #course05 .infoBox .ibContent table {
    border-bottom: 1px solid #ccc;
  }
  #course05 .infoBox .ibContent table th {
    line-height: 1.5;
    text-align: left;
    border-bottom: none;
  }
  #course05 .infoBox .ibContent table td {
    border-bottom: none;
  }
}
/* Course
--------------------------------------*/
#index .courseBox .comingsoonInner {
  position: relative;
  border-radius: 23px;
  box-shadow: 0px 0px 6px #00000029;
  background-color: #fff;
  padding: 60px 80px;
  max-width: 1280px;
  margin: auto;
}
#index .courseBox .comingsoonInner .layout {
  display: flex;
}
#index .courseBox .layout .text {
  flex: 1;
  padding-right: 60px;
}
#index .courseBox .comingsoonInner .layout .text h2 {
  font-size: 3.5rem;
  color: #1C65B6;
  text-align: center;
  font-weight: bold;
  margin: auto;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  #index .courseBox {
    padding: 1rem;
    margin-bottom: 40px;
  }
  #index .courseBox .comingsoonInner {
    padding: 2rem;
  }
  #index .courseBox .comingsoonInner .layout {
    display: block;
  }
  #index .courseBox .comingsoonInner .layout .text {
    padding: 0;
    width: 100%;
  }
  #index .courseBox .comingsoonInner .layout .text h2 {
    font-size: 2rem;
    margin: auto;
  }
}
/* #course01 #dateTab li.fs
--------------------------------------*/
#course01 #dateTab li.fs {
  font-size: 1.8rem;
  line-height: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 33%;
	border: 3px solid #1C65B6;
}
#course01 #dateTab li.fs::after {
  right: 13px;
}
@media screen and (max-width: 900px) {
  #course01 #dateTab li.fs {
    font-size: 1.5rem;
  }
  #course01 #dateTab li.fs::after {
    right: 5px;
  }
}
@media screen and (max-width: 768px) {
  #course01 #dateTab li.fs {
    font-size: 1.2rem;
  }
}
/* 240926 MS-9293
--------------------------------------*/
#course01 #dateTab li.fs::after {
  width: 25px;
  height: 25px;
  margin-top: -15px;
  border-radius: 50%;
}
@media screen and (max-width: 900px) {
  #course01 #dateTab li.fs::after {
    width: 25px;
    height: 25px;
    margin-top: -15px;

    border-radius: 50%;
  }
}
@media screen and (max-width: 900px) {
  #course01 #dateTab {
    flex-direction: column;
    gap: 5px;
  }
  #course01 #dateTab li.fs {
    width: 100%;
    height: 70px;
  }
}
@media screen and (max-width: 500px) {
  #course01 #dateTab li.fs {
    height: 50px;
  }
}