@charset "Shift_JIS";

html{ color: #333;}
main{ font-size: 10px;}

a{ color: #666;}

a[href^="tel:"]{ pointer-events: none;}

p{
  text-align: justify;
  text-justify: inter-ideograph;
}

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

button{ outline: 0;}

optgroup{ display: none;}

.bg-beige{ background: #f3f3f2;}
.bg-school{ background-color: rgba(94, 118, 167, .2);}

.mark {
  margin: 0 2px;
  background: #fff100;
}
.mark01 {
  margin: 0 2px;
  text-decoration: underline;
  background: none;
  color: #1C246D;
}
.mark02 {
  margin: 0 2px;
  background: none;
  color: #1C246D;
}

.marker {
  background: linear-gradient( rgba(255, 242, 160, 0)20%, rgba(215, 186, 65, 0.3)20%);
  padding: 2px;
}

.txt_red{ color: red;}
.txt_orange{ color: #EA5520;}
.txt_bold{ font-weight: bold;}

.txt_s{ font-size: .85em;}
.txt_l{ font-size: 1.5em;}

#page {
  width: 100%;
  margin: 0;
  padding: 0;
  background: #fff;
  text-align: center;
  overflow: hidden;
}

section {
  position: relative;
  width: 100%;
  padding: 0;
  margin: 0;
}
section article,
section .inner,
.kitei .inner{
  width: 100%;
  max-width: 1000px;
  padding: 65px 150px;
  margin: 0 auto;
}

section h2 {
  font-size: 27px;
  font-size: 2.7em;
  letter-spacing: .13em;
  font-weight: normal;
  line-height: 1.7;
  position: relative;
}
section h2::after {
  content: "";
  display: block;
  border-bottom: 3px solid #5E76A7;
  width: 100px;
  margin: 20px auto 30px;
}
section h2.bd_none::after{ content: none;}

section h2 .sub {
  display: block;
  font-size: .7em;
}
section h2 .sub::before {
  content: "\2572";
}
section h2 .sub::after {
  content: "\2571";
}

section h3 {
  font-size: 27px;
  font-size: 2.7em;
  letter-spacing: .15em;
  font-weight: normal;
  line-height: 1.7;
}
section h4 {
  font-size: 20px;
  font-size: 2.0em;
  letter-spacing: .15em;
  font-weight: normal;
  line-height: 1.7;
}

section p {
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: .05em;
}
.lead{ font-size: 1.2rem;}

.btn a,
.btn input, .btn button{
  display: block;
  color: #fff;
  font-size: 1.2rem;
  width: 100%;
  max-width: 465px;
  padding: 10px 40px;
  margin: 0 auto;
  position: relative;
  border-radius: 2.8px;
  background: #EA5520;
  box-shadow: 0 1.5px 0 #CBCBCB;
  letter-spacing: .11em;
}
.btn a:hover,
.btn input:hover { text-decoration: none;}
.btn .red {
  background: #C6272D;
  box-shadow: 0 1.5px 0 #A02C03;
}
.btn .arrow01::after {
  content: '';
  padding: 9px;
  background: url(/images/common/arrow02.svg) left center/contain no-repeat;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 12px;
}
.btn input {
  border: none;
}
.btn input:hover {
  opacity: 0.7;
  cursor: pointer;
}

.btn .baloon{
  display: inline-block;
  font-size: 16px;
  color: #1c236d;
  background: #fff;
  border: 1px solid;
  padding: 5px 1.5em;
  border-radius: 4px;
  margin-bottom: 1.5em;
  position: relative;
}
.btn .baloon::before{
  content: "";
  border: 8px solid transparent;
  border-top: 10px solid #1c236d;
  position: absolute;
  bottom: -19px;
  left: 50%;
  transform: translateX(-50%);
}
.btn .baloon::after{
  content: "";
  border: 8px solid transparent;
  border-top: 10px solid #fff;
  position: absolute;
  bottom: -18px;
  left: 50%;
  transform: translateX(-50%);
}

.box_border {
  background: #fff;
  border-right: 1.5px solid #1C246D;
  border-bottom: 1.5px solid #1C246D;
  padding: 25px 30px;
}

.note-box {
  background-color: #fff;
  border: 1px solid #EA5520;
  margin-top: 80px;
  margin-bottom: 50px;
  padding: 30px 40px;
}
.note-box .ttl,
.note-box .txt {
  font-size: 16px;
  border: 0;
}
.note-box .txt {
  margin: 30px 0;
}

@media screen and (min-width: 1025px) {
  .pc { display: block !important;}
  .tab { display: none;}
  .sp { display: none;}
}

@media screen and (min-width: 600px) and (max-width: 1024px) {
  .pc{ display: none;}
  .tab{ display: block !important;}
  .sp{ display: none;}
}

@media screen and (max-width: 799px) {
  .fancybox-content {
    height: 35% !important;
  }
}

@media screen and (max-width: 1024px) {
  section article,
  section .inner,
  .kitei .inner{ padding: 65px 10%;}
}

@media screen and (max-width: 599px) {
  .pc{ display: none;}
  .tab{ display: none;}
  .sp{ display: block !important;}

  main{ font-size: 8px;}

  a[href^="tel:"] {
    pointer-events: visible;
  }

  section article,
  section .inner,
  .kitei .inner{ padding: 50px 5%;}
  section article.pt_auto{ padding-top: 25px;}

  section h2 {
    font-size: 19px;
  }
  section h2::after {
    width: 50px;
    margin: 15px auto 30px;
  }
  section h3 {
    font-size: 21px;
    font-size: 2.1em;
  }
  section h4 {
    font-size: 15px;
    font-size: 1.5em;
  }

  section p {
    font-size: 13px;
    line-height: 1.5;
  }

  section p.lead{ font-size: 16px;}
  section p.lead_sp{
    font-size: 14px;
    line-height: 2;
  }

  .btn a,
  .btn input,
  .btn1ck p input {
    width: 100%;
    padding: 10px;
    letter-spacing: normal;
    font-size: 15px;
  }
  .btn a.arrow01::after { padding: 6px;}
  
  .btn .baloon{ font-size: 14px;}

  .box_border{ padding: 20px 15px;}

  .note-box {
    margin-top: 40px;
    margin-bottom: 20px;
    padding: 20px;
  }
  .note-box .ttl,
  .note-box .txt {
    font-size: 14px;
  }
  .note-box .txt {
    margin: 20px 0;
  }

  .courseInfo select{
    font-size: 16px;
    transform: scale(0.75) translateX(-15%);
    width: 130%;
  }
}





/* ----------------------
#intro
---------------------- */
#intro{
  background: url(/school/image/shareholder/mv.png)center top/cover no-repeat;
  padding-bottom: 60px;
}
#intro .mv {
  max-width: 1000px;
  margin: 0 auto;
}
.mv .logo {
  text-align: left;
  padding-top: 15px;
  width: 90%;
  margin: 0 auto 70px;
}
.mv .logo img {
  max-width: 273px;
  width: 54%;
}
#intro .mv .title {
  width: 95%;
  max-width: 765px;
  margin: 0 auto;
  padding-bottom: 30px;
  position: relative;
}
#intro .mv h1{
  color: #1c236d;
  font-family: "������", YuMincho, "Hiragino Mincho ProN W3", "�q���M�m���� ProN W3", "Hiragino Mincho ProN", "HG����E", "�l�r �o����", "�l�r ����", serif;
  font-size: 3em;
  font-weight: bold;
}
#intro .mv h1 .txt_l{
  font-size: 2.5em;
  line-height: 1.5;
  letter-spacing: .06em;
}
#intro .mv .circle{
  width: 102px;
  height: 102px;
  background: #fff;
  font-size: 28px;
  color: #1c236d;
  border: 1px solid;
  border-radius: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  right: -110px;
}
#intro .mv .btn a{
  width: 55%;
  max-width: 318px;
  letter-spacing: 0;
  line-height: 1.3;
  background: #1c236d;
  padding: 15px;
  border-radius: 7px;
  box-sizing: border-box;
}

@media screen and (max-width: 930px) {
  #intro .mv .circle{
    right: 10px;
    top: -105px;
  }
}
@media screen and (max-width: 800px) {
  #intro .mv h1{ font-size: 2.25em;}
}
@media screen and (max-width: 599px) {
  #intro{ padding-bottom: 1rem;}
  .mv .logo{ margin-bottom: 35px;}
  #intro .mv .title{ padding-bottom: 1rem;}
  #intro .mv h1{ font-size: 1.35em;}
  #intro .mv .circle{
    font-size: 14px;
    width: 50px;
    height: 50px;
    top: -55px;
  }
  #intro .mv .btn a{ padding: 10px;}
}


/* ----------------------
.top
---------------------- */
.ttl_top{
  font-size: 30px;
  color: #1c236d;
  margin-bottom: 1em;
}
.top p{
  text-align: center;
  line-height: 2;
  margin-bottom: 4em;
}

@media screen and (min-width: 600px) {
  .top .inner{ padding: 65px 15px;}
  .ttl_top,
  .top p{ text-align: center}
}
@media screen and (max-width: 599px) {
  .ttl_top{
    font-size: 18px;
    text-align: left;
  }
  .top p{ text-align: left;}
}


/* ----------------------
.osusume
---------------------- */
.osusume .box{
  background: #fff;
  width: 80%;
  max-width: 820px;
  margin: 0 auto 40px;
  padding: 35px;
  position: relative;
}
.osusume .box > *{
  max-width: 570px;
  margin: 0 auto;
}
.osusume .ttl_list{
  font-size: 22px;
  color: #1c236d;
  background: #f3f3f2;
  text-align: center;
  line-height: 1.3;
  padding: 10px;
  border-radius: 3em;
  margin-bottom: 1em;
}
.osusume .check_list{ width: 73%;}
.osusume .check_list li{
  text-align: left;
  font-size: 16px;
  padding-left: 2em;
  background: url(/school/image/shareholder/icn_check.svg) left top/1.3em no-repeat;
}
.osusume .check_list li + li{ margin-top: 1em;}

@media screen and (min-width: 600px){
  .osusume .inner{ padding: 65px 15px;}
  .osusume .box{ position: relative;}
  .osusume .box.man::before{
    content: "";
    padding:  138px;
    background: url(/school/image/shareholder/img_man.svg) left bottom/contain no-repeat;
    position: absolute;
    left: -78px;
    bottom: 0;
  }
  .osusume .box.woman::before{
    content: "";
    padding: 130px;
    background: url(/school/image/shareholder/img_woman.svg) right bottom/contain no-repeat;
    position: absolute;
    right: -72px;
    bottom: 0;
  }
}
@media screen and (max-width: 599px){
  .osusume .box{
    padding: 15px;
    width: 100%;
  }
  .osusume .check_list{ width: 100%;}
  .osusume .ttl_list{
    font-size: 16px;
    text-align: left;
    position: relative;
  }
  .osusume .box.man{ margin-top: 110px;}
  .osusume .box.man .ttl_list{ padding-left: 105px;}
  .osusume .box.man .ttl_list::before{
    content: "";
    padding:  88px;
    background: url(/school/image/shareholder/img_man.svg) left bottom/contain no-repeat;
    position: absolute;
    left: -20px;
    bottom: 0;
  }
  .osusume .box.woman{ margin-top: 90px;}
  .osusume .box.woman .ttl_list{ padding-left: 20px;}
  .osusume .box.woman .ttl_list::before{
    content: "";
    padding: 80px;
    background: url(/school/image/shareholder/img_woman.svg) right bottom/contain no-repeat;
    position: absolute;
    right: -15px;
    bottom: 0;
  }
}


/* ----------------------
.learn_list02
---------------------- */
.learn_list02{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  margin-top: 80px;
}
.learn_list02 > li{
  width: 28%;
  margin-bottom: 3em;
}
.learn_list02 > li img{ width: 100%;}
.learn_list02 h3{
  font-size: 1rem;
  color: #1c236d;
  margin-top: 1em;
}
.learn_list02 h3::after{
  content: "";
  display: block;
  width: 3em;
  height: 2px;
  background: #1c236d;
  margin: 1em auto 2em;
}
.learn_list02 p{ font-size: 14px;}

@media screen and (max-width: 599px) {
  .learn_list02{
    justify-content: space-between;
    margin-top: 30px;
  }
  .learn_list02 li {
    width: 45%;
    margin-bottom: 2em;
    font-size: 10px;
  }
  .learn_list02 h3 { font-size: 1.5em;}
  .learn_list02 h3::after{ margin-bottom: 1em;}
}



/* ----------------------
.mokuji
---------------------- */
.mokuji{
  max-width:1000px;
  background: #F2F9FF;
  border:1px dashed #1c236d;
  border-left:none;
  border-right:none;
  margin:50px auto;
  padding:50px;
}
.mokuji h3,
.mokuji h4,
.mokuji ul{
  width:65%;
  text-align: left;
  margin-left:auto;
  margin-right:auto;
}
.mokuji h3{
  color:#1c236d;
  font-size:18px;
  margin-top:30px;
  margin-bottom: 10px;
}
.mokuji h4{
  font-size: 16px;
  font-weight: bold;
  margin: 5px auto;
}
.mokuji ul li{
  line-height: 2em;
  font-size:14px;
}
.conts_hide{
  /*    display:none;*/
  max-height: 380px;
  transition: max-height 0.3s;
  overflow: hidden;
}
.conts_hide.active {
  max-height: 9999px;
}
#open,#close{
  cursor: pointer;
  color:#1c236d;
  width:50%;
  margin:40px auto;
  border:1px solid #1c236d;
  border-radius: 25px;
  padding: 10px 0;
  background: #F2F9FF;
  text-align: center;
  position: relative;
}
#open::after,
#close::after{
  content: '';
  width: 8px;
  height: 8px;
  border-left: 1px solid;
  border-bottom: 1px solid;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 15px;
  margin: auto;
}
#open::after{ transform: rotate(-45deg);}
#close::after{ transform: rotate(135deg);}
.is-hide{ display: none;}

@media screen and (max-width: 1000px) {
  .mokuji{
    width:75%;
  }

  .mokuji h3,
  .mokuji h4,
  .mokuji ul{
    width:85%;
  }

  #open,#close{
    width:85%;
  }
}
@media screen and (max-width: 599px) {
  .mokuji{
    width:95%;
    padding:20px 0;
  }

  .mokuji h3,
  .mokuji h4,
  .mokuji ul{
    width:90%;
  }

  #open,#close{
    width:90%;
  }

  .conts_hide{ max-height: 440px;}

  #mokuji_area .btn a{
    width: 90%;
  }
}


/* ----------
.dream
---------- */
.dream{
  background: #FFF4E5;
  position: relative;
}

.dream .inner{
  padding-top: 100px;
  position: relative;
  z-index: 1;
}
.dream h2{
  position: relative;
  z-index: 1;
  margin-bottom: 2em;
}
.dream h2::before{
  content: "Q";
  color: #fff;
  font-size: 3em;
  line-height: 1;
  position: absolute;
  left: 0;
  right: 0;
  top: -.5em;
  z-index: -1;
}
.dream h2 span{ background: linear-gradient(rgba(255, 242, 160, 0)75%, rgba(208, 155, 4, 0.7)75%);}

.dream h3{
  font-size:2.5em;
  margin:50px auto 30px auto;
}

.dream_list{
  margin: 0 auto 120px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.dream_list li{
  width: 48%;
  border-radius: 10px;
  background: #fff;
  margin: 10px .5%;
  overflow: hidden;
}

.dream_list li p{
  text-align: center;
  padding: 10px;
  line-height: 1.5;
}

.dream_list + .wrapper_circle::before{
  content: "";
  width: 1px;
  height: 120px;
  background: #707070;
  position: absolute;
  left: 0;
  right: 0;
  top: -100px;
  margin: auto;
  z-index: 2;
}
.dream_list + .wrapper_circle::after{
  content: "";
  border: 5px solid transparent;
  border-top: 8px solid #707070;
  background: transparent;
  position: absolute;
  top: 15px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}
.wrapper_circle{
  position: relative;
  border-top:1px dashed #EA5520;
  border-bottom: 2px solid #EA5520;
}

.wrapper_circle h3 .baloon{
  background: url(/school/image/goichi/bg_baloon.png) center center/contain no-repeat;
  padding: 10px 25px 30px;
  font-size: .8em;
  color: #fff;
  font-weight: bold;
  position: absolute;
  top: 75px;
  left: 7%;
}

.support_wrap{
  border:1px solid #000;
  width:100%;
  height: 175px;
  margin-bottom:50px;
}

.support{
  font-size:23px !important;
  background:#fff;
  padding:20px 0;
  width:90%;
  margin:0 auto;
  height: 180px;
  position: relative;
  top:-2px;
}

@media screen and (min-width: 600px) {
  .wrapper_circle{
    width: 100%;
    padding-top: 120%;
    background: #fff;
  }
  .wrapper_circle .inner{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
  }
  .wrapper_circle p{
    text-align: center;
    font-size:13px;
    line-height: 2.5em;;
  }
}

@media screen and (max-width: 599px) {
  .wrapper_circle{
    border:none;
  }

  .dream .inner{ padding-top: 60px;}
  .dream h2{ margin-bottom: 20px;}

  .wrapper_circle{ margin-bottom: 50px;}
  .dream .wrapper_circle .inner::after{
    content: "";
    width: 300%;
    padding-top: 100%;
    background: #fff;
    border-top: 1px dashed #eb5520;
    border-bottom: 2px solid #eb5520;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
    bottom: 0;
    z-index: -1;
  }
  .wrapper_circle h3{
    font-size: 1.1rem;
    margin-bottom: 1em;
  }
  .wrapper_circle h3 .baloon{
    left: 0;
    top: 15px;
  }

  .support_wrap{
    height: 100px;
    margin-bottom: 0;
  }

  .support {
    font-size: 18px !important;
    height: 102px;
    text-align: center;
  }
}


/* ----------
.seika
---------- */
.seika .lead{ text-align: center;}
.seika .lead .color {
  font-size: 1.35em;
  color: #5e76a7;
}
@media screen and (min-width: 600px) {
  .seika .inner{ padding: 65px 15px;}
}

.chart-wrap {
  margin-top: 50px;
}
.chart-wrap > .ttl {
  margin-top: 0;
  font-size: 18px;
}
.chart-inner {
  display: flex;
  justify-content: flex-end;
  margin-top: 40px;
}
.chart-inner .fig {
  width: 30%;
  max-width: 300px;
}
.chart-inner .fig img {
  width: 100%;
}
.chart-inner .summary {
  width: 50%;
  padding-left: 40px;
}
.chart-inner .summary ul {
  padding-top: 20px;
}
.chart-inner .summary li {
  display: flex;
  align-items: center;
  margin-top: 15px;
}
.chart-inner .summary li span  {
  display: block;
  width: 35px;
  height: 23px;
  margin-right: 20px;
}
.chart-inner .summary li .color1 {
  background-color: #95A1CC;
}
.chart-inner .summary li .color2 {
  background-color: #6070B2;
}
.chart-inner .summary li .color3 {
  background-color: #5e76a7;
}
.chart-inner .summary li p {
  font-size: 18px;
}
.chart-inner .summary .detail {
  text-align: left;
  padding-top: 30px;
  padding-left: 80px;
  background: url(/school/image/kabu/chart-line.svg) 12px 0 no-repeat;
  background-size: 60px;
}
.chart-inner .summary .detail .txt {
  font-size: 18px;
  line-height: 1.6;
}
.chart-inner .summary .detail .txt strong {
  display: block;
  color: #5e76a7;
  font-size: 28px;
}
.chart-wrap + small {
  display: block;
  text-align: center;
  margin-top: 40px;
  font-size: 11px;
}
@media screen and (max-width: 599px) {
  .chart-wrap {
    margin-top: 20px;
  }
  .chart-wrap > .ttl,
  .chart-inner .summary li p,
  .chart-inner .summary .detail .txt {
    font-size: 16px;
  }
  .chart-inner {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    margin-top: 20px;
  }
  .chart-inner .fig {
    width: 100%;
    max-width: 200px;
    text-align: center;
  }
  .chart-inner .summary {
    width: 100%;
    padding-left: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 0;
  }
  .chart-inner .summary li {
    margin-top: 8px;
  }
  .chart-inner .summary li span {
    margin-right: 15px;
  }
  .chart-inner .summary .detail {
    margin-bottom: 10px;
    background-position: 18px 0;
    background-size: 56px;
  }
  .chart-inner .summary .detail .txt strong {
    font-size: 24px;
  }
  .chart-wrap + small {
    margin-top: 0;
    text-align: left;
  }
}

/* ==========================================================================
advisory
========================================================================== */
.advisory .lead {
  font-size: 16px;
  margin: 20px 0 30px;
  line-height: 1.7;
}
.advisory-list {
  display: flex;
  justify-content: space-around;
  margin-top: 50px;
}
.advisory-list .item {
  max-width: 212px;
  width: 21%;
  margin: 0 15px;
  text-align: left;
  line-height: 1.7;
}
.advisory-list .photo {
  width: 100%;
  height: 0;
  position: relative;
  padding-top: 100%;
}
.advisory-list .photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: auto;
}
.advisory-list .name {
  font-size: 20px;
  margin: 5px 0;
  padding-top: 15px;
}
.advisory-list .post {
  font-size: 14px;
  letter-spacing: .01em;
}
@media screen and (max-width: 599px) {
  .advisory .lead {
    font-size: 14px;
  }
  .advisory-list {
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 30px;
  }
  .advisory-list .item {
    max-width: none;
    width: 48%;
    margin: 0;
  }
  .advisory-list .item:nth-child(n+3) {
    margin-top: 30px;
  }
  .advisory-list .name {
    font-size: 16px;
    padding-top: 0;
  }
}



/* ----------------
#taiken
.course
---------------- */
.course{ background: #FFF4E5;}
.course h2 { position: relative;}
.course h2 .txt_s{ font-size: .7em;}

.course h2 .free {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  color: #1C246D;
  font-size: 42px;
  border: 2px solid #1C246D;
  width: 147px;
  height: 147px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100%;
  margin: auto;
}

.course .tab_content {
  border-style: solid;
  border-width: 1px;
  padding-bottom: 30px;
  display: block;
}

.course .tab_content .seminar_ttl {
  font-size: 18px;
  font-weight: bold;
  color: #1C246D;
}

.courseInfo th,
.courseInfo td {
  font-size: 15px;
}
.courseInfo td {
  text-align: left;
}

.courseInfo td .free {
  color: #1C246D;
  font-size: 1.2em;
}
.courseInfo tbody th {
  width: 155px;
}

.course .tab_content p {
  font-size: 13px;
  margin-bottom: 20px;
  letter-spacing: .05em;
}
.kyPlus {
  font-size: 1.3em;
  text-align: left;
}

ul.kyPlus li{
  text-indent: -1.25em;
  margin-left: 1.25em;
}
ul.kyPlus li::before{
  content: "\25cf";
  padding-right: .25em;
}

.kyPlus ul li {
  line-height: 150%;
  letter-spacing: 1px;
}

ol.kyPlus li {
  padding: 1px 0px 1px 0px;
  line-height: 130%;
  letter-spacing: 1px;
}

ol.kyPlus span {
  font-weight: bold;
}

@media screen and (max-width: 599px){
  #taiken h2 .free {
    font-size: 20px;
    border: 2px solid #1C246D;
    width: 68px;
    height: 68px;
  }
  .course_link .kabu a,
  .course .sp-tab-title.kabu {
    background-color: #5e76a7;
  }
  .course_link .fudo a,
  .course .sp-tab-title.fudo {
    background-color: #44a1c5;
  }
  .course .btn a,
  .course .btn input {
    letter-spacing: 0;
  }
  .course .tab_content {
    padding: 30px 5%;
  }
  .courseInfo tbody th,
  .courseInfo tbody td{
    display: block;
    width: 100%;
  }
  .courseInfo tbody th{
    border-right: 1px solid #b6b6b6;
    background-image: none;
  }
}

.content-plus .corona_emg .ttl{ color: #1C246D;}
.content-plus .corona_emg .ttl .icn path{ fill: #1C246D;}

.content-mutual .corona_emg .ttl{ color: #8a9f55;}
.content-mutual .corona_emg .ttl .icn path{ fill: #8a9f55;}

.content-fudo .corona_emg .ttl{ color: #44a1c5;}
.content-fudo .corona_emg .ttl .icn path{ fill: #44a1c5;}

.course .tab_content.content-plus {
  border: 1px solid #1C246D !important;
}

.ttl-semi{
  border:1px dotted #EA5520 !important;
  border-left:none !important;
  border-right:none !important;
  color: #EA5520 !important
}

@media screen and (max-width: 599px) {
  .courseInfo tbody th{
    width:auto !important;
    background:#fafafa !important;
    border-right: 1px solid #999 !important;
  }
}

/* ------------------------------
faq
------------------------------ */
.faq dl {
  font-size: 16px;
  background: #fff;
  border: 1px solid #ddd;
  padding: 20px;
  margin-bottom: 30px;
  text-align: left;
}
.faq dt {
  padding-left: 3em;
  padding-bottom: .8em;
  margin-bottom: .8em;
  border-bottom: 1px solid #ddd;
  color: #1c236d;
  position: relative;
}
.faq dt::before {
  content: "Q";
  color: #fff;
  background: #1c236d;
  width: 1.3em;
  height: 1.3em;
  border-radius: 100%;
  margin-right: 10px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 1.6em;
  position: absolute;
  left: 0;
  top: 0;
}
.faq dd {
  padding-left: 3em;
  position: relative;
}
.faq dd::before {
  content: "A";
  color: #fff;
  background: #ea5520;
  width: 1.3em;
  height: 1.3em;
  border-radius: 100%;
  margin-right: 10px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 1.6em;
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (max-width: 599px) {
  .faq dl {
    font-size: 14px;
  }
}

/* entry_btn */
.btn_wrap {
  margin-top: 35px;
  text-align: center;
}
.entry_btn_txt {
  display: inline-block;
  position: relative;
  padding: 0.5em 3em 0.1em;
  color: #e16f4e;
  line-height: 1;
}
.course .tab_content p.entry_btn_txt {
  margin-bottom: 0;
  font-size: 14px;
}
.entry_btn_txt::before,
.entry_btn_txt::after {
  position: absolute;
  bottom: 10px;
  width: 25px;
  border-top: 1px dashed #1c236d;
  content: '';
}
.entry_btn_txt::before {
  left: 0;
  transform: rotate(45deg);
}
.entry_btn_txt::after {
  right: 0;
  transform: rotate(-45deg);
}
.btn_entry {
  display: block;
  position: relative;
  width: 100%;
  max-width: 324px;
  margin: 10px auto 0;
  background-color: #e60012;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2236.04%22%20height%3D%2234.839%22%20viewBox%3D%220%200%2036.04%2034.839%22%3E%3Cg%20transform%3D%22translate(-16%20-40)%22%3E%3Cpath%20d%3D%22M51.439%2C41.8h-1.8V40.6a.6.6%2C0%2C0%2C0-.6-.6H36.423a3%2C3%2C0%2C0%2C0-2.4%2C1.2%2C3%2C3%2C0%2C0%2C0-2.4-1.2H19a.6.6%2C0%2C0%2C0-.6.6v1.2H16.6a.6.6%2C0%2C0%2C0-.6.6V65.829a.6.6%2C0%2C0%2C0%2C.6.6H41.228v6.607a1.8%2C1.8%2C0%2C0%2C0%2C1.8%2C1.8h2.4a1.8%2C1.8%2C0%2C0%2C0%2C1.8-1.8V66.429h4.2a.6.6%2C0%2C0%2C0%2C.6-.6V42.4A.6.6%2C0%2C0%2C0%2C51.439%2C41.8ZM19.6%2C61.624H31.617a1.8%2C1.8%2C0%2C0%2C1%2C1.7%2C1.2H19.6Zm23.842-9.611h1.571l.788%2C2.4H42.658Zm.394-1.2.392-1.195.392%2C1.195ZM41.228%2C62.825h-6.5a1.8%2C1.8%2C0%2C0%2C1%2C1.7-1.2h4.805Zm1.2-7.208h1.2V67.631h-1.2Zm0%2C13.215h3.6v1.2h-3.6Zm3.6-1.2h-1.2V55.617h1.2Zm1.2-6.007h1.2v1.2h-1.2ZM36.423%2C41.2H48.436V60.423h-1.2V55.017c0-.01%2C0-.02%2C0-.031s0-.015%2C0-.023a.6.6%2C0%2C0%2C0-.009-.062.006.006%2C0%2C0%2C0%2C0%2C0%2C.586.586%2C0%2C0%2C0-.018-.067v0L45.372%2C49.24a1.2%2C1.2%2C0%2C0%2C0-2.281%2C0l-1.833%2C5.589v0a.583.583%2C0%2C0%2C0-.018.067.006.006%2C0%2C0%2C1%2C0%2C0%2C.6.6%2C0%2C0%2C0-.009.062c0%2C.008%2C0%2C.015%2C0%2C.023s0%2C.02%2C0%2C.031v5.406H36.423a2.987%2C2.987%2C0%2C0%2C0-1.8.6V43A1.8%2C1.8%2C0%2C0%2C1%2C36.423%2C41.2ZM19.6%2C41.2H31.617a1.8%2C1.8%2C0%2C0%2C1%2C1.8%2C1.8V61.025a2.988%2C2.988%2C0%2C0%2C0-1.8-.6H19.6ZM17.2%2C65.228V43h1.2V63.426a.6.6%2C0%2C0%2C0%2C.6.6H41.228v1.2Zm28.832%2C7.809a.6.6%2C0%2C0%2C1-.6.6h-2.4a.6.6%2C0%2C0%2C1-.6-.6v-1.8h3.6Zm4.805-7.809h-3.6v-1.2h1.8a.6.6%2C0%2C0%2C0%2C.6-.6V43h1.2Z%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M80.6%2C209.2h6.007a.6.6%2C0%2C0%2C0%2C0-1.2H80.6a.6.6%2C0%2C0%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-59.195%20-155.386)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M194.4%2C208h-1.8a.6.6%2C0%2C0%2C0%2C0%2C1.2h1.8a.6.6%2C0%2C1%2C0%2C0-1.2Z%22%20transform%3D%22translate(-162.785%20-155.386)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M143.208%2C272.6a.6.6%2C0%2C0%2C0-.6-.6H136.6a.6.6%2C0%2C1%2C0%2C0%2C1.2h6.007A.6.6%2C0%2C0%2C0%2C143.208%2C272.6Z%22%20transform%3D%22translate(-110.99%20-214.581)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M82.4%2C272H80.6a.6.6%2C0%2C1%2C0%2C0%2C1.2h1.8a.6.6%2C0%2C1%2C0%2C0-1.2Z%22%20transform%3D%22translate(-59.195%20-214.581)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M80.6%2C241.2H90.812a.6.6%2C0%2C0%2C0%2C0-1.2H80.6a.6.6%2C0%2C1%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-59.195%20-184.983)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M144.6%2C177.2h5.406a.6.6%2C0%2C1%2C0%2C0-1.2H144.6a.6.6%2C0%2C1%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-118.389%20-125.789)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M144.6%2C145.2h5.406a.6.6%2C0%2C0%2C0%2C0-1.2H144.6a.6.6%2C0%2C1%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-118.389%20-96.191)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M336.6%2C81.2h6.007a.6.6%2C0%2C1%2C0%2C0-1.2H336.6a.6.6%2C0%2C1%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-295.973%20-36.997)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M280.6%2C81.2h1.8a.6.6%2C0%2C1%2C0%2C0-1.2h-1.8a.6.6%2C0%2C0%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-244.178%20-36.997)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M280.6%2C145.2h4.805a.6.6%2C0%2C0%2C0%2C0-1.2H280.6a.6.6%2C0%2C0%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-244.178%20-96.191)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M280.6%2C113.2h10.211a.6.6%2C0%2C0%2C0%2C0-1.2H280.6a.6.6%2C0%2C0%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-244.178%20-66.594)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M280.6%2C209.2h3a.6.6%2C0%2C0%2C0%2C0-1.2h-3a.6.6%2C0%2C0%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-244.178%20-155.386)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M280.6%2C273.2h3a.6.6%2C0%2C0%2C0%2C0-1.2h-3a.6.6%2C0%2C0%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-244.178%20-214.581)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M280.6%2C241.2h3a.6.6%2C0%2C0%2C0%2C0-1.2h-3a.6.6%2C0%2C0%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-244.178%20-184.983)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M280.6%2C177.2h4.2a.6.6%2C0%2C0%2C0%2C0-1.2h-4.2a.6.6%2C0%2C0%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-244.178%20-125.789)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M80.6%2C83.6H83a.6.6%2C0%2C0%2C0%2C.6-.6V80.6A.6.6%2C0%2C0%2C0%2C83%2C80H80.6a.6.6%2C0%2C0%2C0-.6.6V83A.6.6%2C0%2C0%2C0%2C80.6%2C83.6Zm.6-2.4h1.2v1.2H81.2Z%22%20transform%3D%22translate(-59.195%20-36.997)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M80.6%2C147.6H83a.6.6%2C0%2C0%2C0%2C.6-.6v-2.4a.6.6%2C0%2C0%2C0-.6-.6H80.6a.6.6%2C0%2C0%2C0-.6.6V147A.6.6%2C0%2C0%2C0%2C80.6%2C147.6Zm.6-2.4h1.2v1.2H81.2Z%22%20transform%3D%22translate(-59.195%20-96.191)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M144.6%2C113.2h5.406a.6.6%2C0%2C0%2C0%2C0-1.2H144.6a.6.6%2C0%2C1%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-118.389%20-66.594)%22%20fill%3D%22%23fff%22%2F%3E%3Cpath%20d%3D%22M144.6%2C81.2h5.406a.6.6%2C0%2C0%2C0%2C0-1.2H144.6a.6.6%2C0%2C1%2C0%2C0%2C1.2Z%22%20transform%3D%22translate(-118.389%20-36.997)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E');
  background-repeat: no-repeat;
  background-position: 20px 19px;
  border-radius: 5px;
  box-shadow: 0 3px 0 #d7d7d7;
  color: #fff;
  font-size: 18px;
  line-height: 1.4;
  overflow: hidden;
}
.btn_entry span {
  display: block;
  position: relative;
  width: 100%;
  padding: 1em 40px 1em 60px;
}
.btn_entry span::before {
  position: absolute;
  top: 50%;
  right: 18px;
  transform: translateY(-50%);
  width: 26px;
  height: 26px;
  border: 1px solid #fff;
  border-radius: 50%;
  content: '';
}
.btn_entry span::after {
  position: absolute;
  top: 50%;
  right: 26px;
  transform: translateY(-50%);
  border-left: 8px solid #fff;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  content: '';
}
.btn_entry:hover {
  opacity: 0.8;
  text-decoration: none;
}
.btn_entry::before {
  position: absolute;
  content: '';
  display: inline-block;
  top: -180px;
  left: 0;
  width: 30px;
  height: 100%;
  background-color: #fff;
  animation: btn_shiny 3s ease-in-out infinite;
}
@-webkit-keyframes btn_shiny {
  0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
  80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
  81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
  100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}

.web_seminar_img {
  max-width: 560px;
  margin: 0 auto 30px;
}

/* ------------------------------
teacher
------------------------------ */
.teacher .profile_box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.teacher .profile_box dt {
  max-width: 200px;
}
.teacher .profile_box .name {
  font-size: 24px;
}
.teacher .profile_box .name span {
  margin-left: 0.5em;
  font-size: 20px;
}
.teacher .profile_box .career_pc {
  font-size: 14px;
}
@media screen and (min-width: 600px) {
  .teacher .profile_box .career_sp {
    display: none;
  }
  .teacher .profile_box dt {
    width: 20%;
    max-width: 200px;
  }
  .teacher .profile_box dd {
    width: 75%;
  }
  .teacher .btn_profile {
    display: none;
  }
}
@media screen and (max-width: 599px) {
  .teacher .profile_outer {
    display: flex;
    justify-content: space-between;
  }
  .teacher .profile_box dt {
    width: 45%;
  }
  .teacher .profile_box dd {
    width: 53%;
  }
  .teacher .profile_box .name {
    margin-top: 1em;
    font-size: 16px;
    text-align: center;
    line-height: 1.4;
  }
  .teacher .profile_box .name span {
    display: block;
    margin-left: 0;
    font-size: 14px;
  }
  .teacher .profile_box .career_pc {
    display: none;
  }
  .teacher .profile_box .career_sp {
    margin-top: 1em;
    font-size: 12px;
    text-align: center;
  }
  .teacher .sp_non {
    display: none;
  }
  .teacher .btn_profile {
    position: relative;
    margin: 10px auto 0;
    width: 26px;
    height: 26px;
    border: 2px solid #5e76a7;
    border-radius: 50%;
    text-align: center;
  }
  .teacher .btn_profile::before {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 16px;
    height: 3px;
    border-radius: 9999px;
    background: #5e76a7;
    content: '';
  }
  .teacher .btn_profile::after {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    height: 16px;
    width: 3px;
    border-radius: 9999px;
    background: #5e76a7;
    content: '';
  }
  .teacher .teacher_detail {
    display: block;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1000;
    width: 90%;
    padding: 30px 5% 20px;
    border-radius: 15px;
    background: #fff;
  }
  .teacher .teacher_detail .btn_close {
    position: absolute;
    right: 13px;
    top: 13px;
    width: 34px;
    height: 34px;
    border: 2px solid #5e76a7;
    border-radius: 50%;
  }
  .teacher .teacher_detail .btn_close span {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
  }
  .teacher .teacher_detail .btn_close span::before,
  .teacher .teacher_detail .btn_close span::after {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 3px;
    border-radius: 9999px;
    background: #5e76a7;
    content: '';
  }
  .teacher .teacher_detail .btn_close span::before {
    transform: translate(-50%, -50%) rotate(45deg);
  }
  .teacher .teacher_detail .btn_close span::after {
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  .teacher .teacher_detail figure {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .teacher .teacher_detail figure img {
    width: 50%;
  }
  .teacher .teacher_detail figure figcaption {
    width: 40%;
    font-size: 16px;
    text-align: left;
    line-height: 1.4;
  }
  .teacher .teacher_detail figure figcaption span {
    display: block;
    font-size: 14px;
  }
  .teacher .teacher_detail .profile {
    margin-top: 1em;
    font-size: 14px;
    line-height: 1.8;
  }
}

/* ------------------------------
modal
------------------------------ */
.modal_wrap {
  display: none;
}
@media screen and (max-width: 599px) {
  .modal_wrap {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1000;
    width: 100%;
    height: 100vh;
  }
  .modal_wrap .modal_bg {
    position: absolute;
    width: 100%;
    height: 100vh;
    background: rgba(94, 118, 167, 0.5);
  }
}
