@charset "utf-8";

/* ===============================================
# common
=============================================== */
.box_subttl {
  text-align: center;
  margin: 0 0 20px 0;
  font-weight: bold;
}
.box_subttl .sbimg {
  display: block;
  margin: 0 0 10px 0;
}
.box_subttl .sbimg img {
  width: 73px;
}
.box_subttl .sbtext {
  display: inline-block;
  border-bottom: 1px solid #000000;
  padding: 0 0 2px 0;
}
.ttl01 {
  line-height: 1.3;
  font-size: 26px;
  font-size: 2.6rem;
  text-align: center;
  margin: 70px 0 20px 0;
  font-family: "游明朝体", "Yu Mincho","ヒラギノ明朝Pro", "Hiragino Mincho Pro", YuMincho, serif;
}
.ttl02 {
  line-height: 1.3;
  font-size: 28px;
  font-size: 2.8rem;
  text-align: center;
  margin: 0 0 20px 0;
  font-family: "游明朝体", "Yu Mincho","ヒラギノ明朝Pro", "Hiragino Mincho Pro", YuMincho, serif;
}
.lead_text {
  font-size: 17px;
  font-size: 1.7rem;
  line-height: 1.64;
}
.lead_text.col1 {
  max-width: 670px;
  margin: 0 auto;
}
.circle {
  font-size: 30px;
  font-size: 3rem;
  text-align: center;
  line-height: 1.3;
}
@media screen and (max-width :768px) {
  #story .cmn_ttl07 {
    font-size:23.5px;
    font-size: 2.35rem;
  }  
  .ttl01 {
    font-size: 21.5px;
    font-size: 2.15rem;   
    margin: 32px 0 5px 0;
  }
  .lead_text {
    font-size: 14px;
    font-size: 1.4rem;
  }  
  .box_subttl {
    font-size: 13.5px;
    font-size: 1.35rem;
  }
  .box_subttl .sbimg {
    margin: 0 0 5 px 0;
  }  
  .box_subttl .sbimg img {
    width: 50px;
  }

}


/*swiper_detail------------------*/
.swiper_detail {
    position: relative;
    margin:60px 0 0 0;
}
.swiper_detail.swiper-container-horizontal > .swiper-pagination-bullets{
  position: absolute;
  text-align: center;
  line-height: 1;
  bottom: inherit;
  top: -43px;
}
.swiper_detail .swiper-pagination-bullet{
  width: 14px;
  height: 14px;  
  background: #e7e7e7;
  opacity: 1;
}
.swiper_detail .swiper-pagination-bullet-active{
  background: #df6b70;
  opacity: 1;
}
.swiper_detail dl {
  width: 300px;
}
.swiper_detail dl dt {
  text-align: center;
  position: relative;
}
.swiper_detail dl dt .catch {
  padding: 17px 0 7px 0;
  font-size: 22px;
  font-size: 2.2rem;
  line-height: 1.36;
  display: table;
  width: 100%;
}
.swiper_detail dl dt .catch p {
  display: table-cell;
  vertical-align: middle;
}
.swiper_detail dl dd::before {
  content: '';
  display: block;
  margin: 0 0 9px 0;
  width: 100%;
  height: 7px;
  background : repeating-linear-gradient(315deg,
                                         #000000,
                                         #000000 1px,
                                         rgba(255, 255, 255, 0.1) 0,
                                         rgba(255, 255, 255, 0.1) 4px);
}
.swiper_detail dl dd .dtext {
  font-size: 17px;
  font-size: 1.7rem;
  text-align: left;
  line-height: 1.64;
}
@media screen and (max-width :768px) {
  .swiper_detail {
    margin:35px 0 0 0;
  }  
  .swiper_detail dl dt .catch {
    font-size: 16.5px;
    font-size: 1.65rem;
    padding: 13px 0 3 px 0;
  }
  .swiper_detail dl dd .dtext {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .swiper_detail dl dd::before {
    height: 5px;
  }  
  .swiper_detail.swiper-container-horizontal > .swiper-pagination-bullets {
    bottom: inherit;
    top:-27px;
  }
  .swiper_detail .swiper-pagination-bullet{
    width: 7px;
    height: 7px;  
  }
}

/* ===============================================
#  第二階層タイトル
=============================================== */
.story_ttl {
  position: relative;
  text-align: center;
}
.story_ttl .simpleParallax {
  height: 760px;
}
.story_ttl .box_ttl {
  position: absolute;
  top: 15%;
  left: 50%;
  -webkit-transform: translate(-50%,0);
  transform: translate(-50%,0);
  text-align: center;
  color: #464646;
  white-space: nowrap;
}
.story_ttl .box_ttl .ttl {
  font-size: 36px;
  font-size: 3.6rem;
  line-height: 1.4;
  display: inline-block;
  color: #444444;
  border-bottom: 1px solid #333333;
  margin: 0 0 12px 0;
  padding: 0 0 12px 0;
}
.story_ttl .box_ttl .ttl .num {
  display: block;
  margin: 0 0 15px 0;
}
.story_ttl .box_ttl .ttl .num img {
  width: 86px;
  height: 138px;
}
.story_ttl .box_ttl .text {
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.6;
  color: #333333;
  font-weight: bold;
}
@media screen and (max-width :1800px) {
  .story_ttl .simpleParallax  img {
    max-width: none;
    width: inherit;  
  }
}
@media screen and (max-width :768px) {
  .story_ttl .simpleParallax {
    height: 380px;
  }
  .story_ttl .simpleParallax  img {
    max-width:100%;
    width: 100%;  
  }
  .story_ttl .box_ttl .ttl {
    font-size: 22px;
    font-size: 2.2rem;
    line-height: 1.2;
    margin: 0 0 9px 0;
    padding: 0 0 9px 0;    
  }
  .story_ttl .box_ttl .ttl .num {
    margin: 0 0 9px 0;
  }
  .story_ttl .box_ttl .ttl .num img {
    width: 43px;
    height: 69px;
  }
  .story_ttl .box_ttl .text {
    font-size: 14px;
    font-size: 1.4rem;
    line-height: 1.5;
  }
}
/*scroll*/
.scroll  {
  position: absolute;
  padding-bottom: 90px;
  z-index: 15;
  bottom: -70px;
  left: 0;
  right: 0;
}
.scroll .bdr {
  position: absolute;
  top: 50px;
  left: 50%;
  width: 24px;
  height: 90px;
  border-left: 1px solid #728b7c;
  -webkit-transform: rotate(0);
  transform: rotate(0);
  -webkit-animation: sdb 1.5s infinite;
  animation: sdb 1.5s infinite;
  box-sizing: border-box;
}
.scroll .img {
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  display: inline-block;
}
.scroll .img img {
  width: 24px;
  display: block;
  margin: 0 auto 7px auto;
}
@-webkit-keyframes sdb {
  0% {
    -webkit-transform: rotate(0) translate(0, 0);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    -webkit-transform: rotate(0) translate(0, 20px);
    opacity: 0;
  }
}
@keyframes sdb {
  0% {
    transform: rotate(0) translate(0, 0);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: rotate(0) translate(0, 20px);
    opacity: 0;
  }
}

/* ===============================================
# キャッチ
=============================================== */
.story_catch {
  padding-bottom: 5px;
}
.story_catch.cmn_area_catch .catch_img {
  width: 500px;
  margin: 10px auto;
  position: relative;
}
.story_catch.cmn_area_catch .catch_img .img_ct01 {
  position: absolute;
  top:0;
  left: 0;
  width: 37.61%;
  z-index: 2;  
}
.story_catch.cmn_area_catch .catch_img .img_ct02 {
  position: absolute;
  top:0;
  right: 0;
  width: 37.61%;
  z-index: 2;    
}
.story_catch.cmn_area_catch .catch_img .img_ct03 {
  position: absolute;
  bottom:0;
  left: 0;
  width: 37.61%;
  z-index: 2;    
}
.story_catch.cmn_area_catch .catch_img .img_ct04 {
  position: absolute;
  bottom:0;
  right: 0;
  width: 37.61%;
  z-index: 2;     
}
.story_catch.cmn_area_catch .catch_img .img_ct06 {
  position: relative;
  z-index: -1; 
}
.story_catch.cmn_area_catch .catch_img .img_ct06 {
  position: absolute;
  bottom:0;
  right: 0;
  left: 0;
  margin: 0 auto;
  width: 24.76%;
  z-index: 2;    
}
.story_catch.cmn_area_catch .catch_text {
  font-size: 25px;
  font-size: 2.5rem;
  text-align: center;
}
@media screen and (max-width :768px) {
  .story_catch.cmn_area_catch .catch_text {
    font-size: 17.5px;
    font-size: 1.75rem;
    line-height: 1.28;
  }
  .story_catch.cmn_area_catch .catch_img {
    width: 84%;
  } 
}

/* ===============================================
# 本学の教育/sec_learn
=============================================== */
.sec_learn {
  background: #eff6fa;
  padding: 65px 0 5px 0;
}
.sec_learn .box_img {
  position: relative;
 max-width: 1360px;
 margin: 40px auto 0 auto;
 padding-right: 30px;
 padding-left: 30px;
}
.sec_learn .box_img dt {
  position: relative;
  z-index: 2;
  text-align: center;
  width: 83.5%;
  margin: 0 auto -30px auto;
}
.sec_learn .box_img .box_learn .img_text    {   width: 28.7% }
.sec_learn .box_img .box_learn .img_connect {   width: 6.94% }
.sec_learn .box_img dd img {
  border-radius: 20px;
}
.sec_learn .cmn_ttl07 {
  margin-bottom: 0;
}
.sec_learn .cmn_btn {
  margin-top: 50px ;
}
@media screen and (max-width :768px) {
  .sec_learn {
    padding: 35px 0 20px 0;
  }  
  .sec_learn .box_img {
    max-width: 100%;
    margin: 20px auto 0 auto;
    padding-right: 0;
    padding-left: 0;
  }  
  .sec_learn .box_img dt {
    margin-bottom:-25%;
    width:90%;
  }
  .sec_learn .box_img .box_learn .img_text    {   width: 25.22% }
  .sec_learn .box_img .box_learn .img_connect {   width: 12.15% }  
  .sec_learn .box_img dd img {
    border-radius:0;
  }  
  .sec_learn .cmn_btn {
    margin-top: 30px ;
  }
}

/* ===============================================
# 実践力を磨く充実の実習/sec_measures
=============================================== */
.sec_measures {
  padding: 90px 0 30px 0;
}
.sec_measures .cmn_tableStyle {
  font-size: 17px;
  font-size: 1.7rem;
}
.sec_measures .cmn_tableStyle td.bdrnone,.sec_measures .cmn_tableStyle th.bdrnone {
  color:#E32630; /* 2022-11-15 変更 */
  background-color: #fff;
  width: 6.5em;
  vertical-align: top;
  border-right: none !important;
  padding-right: 0;
  text-align: right;
}
.cmn_tableStyle th, .cmn_tableStyle td, .cmn_tableStyle2 th, .cmn_tableStyle2 td{
  border-left: none;
}
.sec_measures .cmn_tableStyle td.bdrnone + td {
  border-left: none !important;
  padding-left: 0;
}
.sec_measures .ttl01 {
  margin-top: 95px;
}
@media screen and (max-width :768px) {
  .sec_measures {
    padding: 60px 0 0 0;
  }
  .sec_measures .cmn_tableStyle {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .sec_measures .ttl01 {
    margin-top: 50px;
  }
}

/* ===============================================
# 卒業生/sec_voice
=============================================== */
.sec_voice {
  background: #f7f7f7;
  text-align: center;
  padding: 18px 0 80px 0;
}
.sec_voice .box_subttl .sbimg img {
    width: 55px;
}
.sec_voice .cmn_ttl07 {
  margin-bottom: 50px;
}
.sec_voice a {
  position: relative;
  z-index: 1;
  padding-top: 70px;
}
.sec_voice .ttl img {
  width: 190px;
}
.sec_voice .ttl span {
  display:inline-block;
  border-top: 1px solid #80807f;
  font-size: 18px;
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  font-weight: bold;
  margin: -1px 0 0 0;
  padding: 8px 0 0 0;
}
.sec_voice .circle {
  font-size: 30px;
  font-size: 3rem;
  line-height: 1.3;
}
.sec_voice .text { 
  font-size: 22px;
  font-size: 2.2rem;
  letter-spacing: 0.1em;  
  font-weight: bold;
}
.sec_voice .btn {
    display: block;
    width: 242px;
    margin: 15px auto 25px auto;
    padding: 12px 5px;
    border: solid 1px #999999;
    border-radius: 30px;
    line-height: 1.3;
    color: #000;
    text-align: center;
    font-size: 12px;
    font-size: 1.2rem;
    background-color: #fff;
}
.sec_voice .btn span {
  content: "";
  display: inline-block;
  padding: 0 34px;
  background: url(/common/img/ico_arrow_g.svg) no-repeat right center;  
  background-size: 17px 5px;
}
.sec_voice .box_voice_link a {
  display: block;
  height:536px;
  background: url( "/career/img/bg_voice.jpg") no-repeat center center;
  background-size: cover;
}
.sec_voice .box_voice_link a:hover {
  background: url( "/career/img/bg_voice_ov.jpg") no-repeat center center;
  background-size: cover;
}
.sec_voice .swiper-wrapper {
  transition-timing-function: linear;
}
.sec_voice .swiper-wrapper li {
  max-width: 360px;
}
.sec_voice .swiper_voice01,
.sec_voice .swiper_voice02{
  overflow: visible;
  width: 360px;
  margin: auto 0;
}
@media screen and (max-width :768px) {
  .sec_voice {
    padding: 18px 0 43px 0;
  }  
  .sec_voice a {
      padding-top: 35px;
  }
  .sec_voice .box_subttl .sbimg img {
      width: 40px;
  }
  .sec_voice .ttl img {
    width: 120px;
  }
  .sec_voice .ttl span {
    font-size: 12px;
    font-size: 1.2rem;
  }
  .sec_voice .text {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 0 10px;
  }
  .sec_voice .btn {
    width: 200px;
  }  
  .sec_voice .box_voice_link a {
    background-size:auto 269px ;
    height: 269px;
  }  
  .sec_voice .swiper_voice01,
  .sec_voice .swiper_voice02{
    width: 180px;
  }
  .sec_voice .cmn_ttl07 {
    margin-bottom: 30px;
  }  
}

/* ===============================================
# sec_connect
=============================================== */
.sec_connect {
  padding: 80px 0 70px 0;
}
/*リンク*/
.sec_connect .box_link{
  -ms-flex-pack: distribute;
  justify-content: space-around;
  margin: 60px 0 0 0;
}
.sec_connect .box_link li{
  width: 33%;
}
.sec_connect .box_link figure{
  position: relative;
  background-color: #000;
}
.sec_connect .box_link figure img{
  width: 100%;
  opacity: 0.6;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.sec_connect .box_link .ttl{
  padding: 22px 63px;
  text-align: center;
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.1;
  letter-spacing: 0.1em;
}
.sec_connect .box_link .ttl span{
  position: relative;
  display: inline-block;
}
.sec_connect .box_link .ttl span::before{
  content: '';
  display: block;
  position: absolute;
  right: -43px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 17px;
  height: 5px;
  background: url(/common/img/ico_arrow_g.svg) no-repeat center center;
  background-size: 100% auto;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.sec_connect .box_link .ttl span::after{
  content: '';
  display: block;
  position: absolute;
  bottom: -14px;
  left: 0;
  right: 0;
  margin: 0 auto;
  height: 1px;
  width: 87px;
  background-color: #df6b70;
}
.sec_connect .box_link .text {
  font-size: 17px;
  font-size: 1.7rem;
  text-align: center;
  padding: 0 5px;
  line-height: 1.64;
}
@media screen and (min-width :769px){
  .sec_connect .box_link a:hover{
    opacity: 1;
  }
  .sec_connect .box_link a:hover figure img{
    opacity: 0.8;
  }
  .sec_connect .box_link a:hover .ttl span{
    color: #666666;
  }
  .sec_connect .box_link a:hover .ttl span::before{
    right: -63px;
  }
}
@media screen and (max-width :1000px){
  .sec_connect .box_link .ttl{
    font-size: 19px;
    font-size: 1.9rem;
  }
  .sec_connect .box_link .text{
    font-size: 16px;
    font-size: 1.6rem;
  }
}
@media screen and (max-width :768px){
  .sec_connect {
    padding: 55px 0 80px 0;
  }
  .sec_connect .box_link{
    margin: 25px 0 0 0;
  }
  .sec_connect .box_link li{
    width: 96.4%;
    margin: 0 auto;
  }
  .sec_connect .box_link li:nth-child(n+2){
    margin-top: 25px;
  }
  .sec_connect .box_link .ttl{
    padding: 15px 22px;
    font-size: 15px;
    font-size: 1.5rem;
  }
  .sec_connect .box_link .ttl span::before{
    right: -22px;
    top:43%;
    width: 10px;
    height: 3px;
  }
  .sec_connect .box_link .ttl span::after{
    bottom: -6px;
    width: 52px;
  }
  .sec_connect .box_link .text{
    font-size: 14px;
    font-size: 1.4rem;      
  }    
}



/* ===============================================
# sec_movie/MOVIE
=============================================== */
.sec_movie {
  background: #fdf6fa;
  padding: 70px 0 150px 0;
}
.sec_movie .ttl {
  text-align: center;
}
.sec_movie .ttl .en {
  font-size: 39px;
  font-size: 3.9rem;
  border-bottom:1px solid #000000;
  padding: 0 0 5px 0;
}
.sec_movie .ttl .img {
  display: block;
}
.sec_movie .ttl .img img {
    width: 65px;
}
.sec_movie .movie {
  max-width: 910px;
  margin: 28px auto 10px auto;
}
.sec_movie .movie .cmn_movie {
  margin-bottom: 0;
}
.sec_movie .btn {
  overflow: hidden;
}
.sec_movie .btn li {
  float: left;
  width: 50%;
}
.sec_movie .btn a {
  margin: 0 10px;
}
.sec_movie .btn li:first-child a {
  margin-left: auto;
}
@media screen and (max-width :768px) {
  .sec_movie {
   padding: 35px 0 150px 0;
  }
  .sec_movie .ttl {
    margin:0 0 10px 0;
  }
  .sec_movie .movie {
    margin: 10px auto;
  }  
  .sec_movie .ttl .img img {
    width: 40px;
  }
  .sec_movie .ttl .en {
    font-size: 29px;
    font-size: 2.9rem;
  }  
  .sec_movie .btn li {
    float: none;
    width: 100%;
  }  
  .sec_movie .btn a {
    margin: 10px auto !important;
  }
}


/* ===============================================
# アニメーション
=============================================== */
.scroll_item_wrapper{
  overflow: hidden;
}
.scroll_item{
  opacity: 0;
}
.scroll_item.animated{
  opacity: 1;
}
@media screen and (max-width :768px) {
  .scroll_item{
    opacity: 1;
  }
}