@charset "utf-8";

*{
	font-family: 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif
}

.line{
	border-bottom: 1px solid black;
}

.wrapper{
	margin:0 auto;
	text-align: center;
	margin:0 auto;
}
.width{
	width: 50%;
    margin: 0 auto;
}
#mainvisual{
	background-color: #08A597;
	padding: 40px 0;
}
#mainvisual p{
	text-align: center;
	font-size: 35px;
	color:white;
	font-weight: lighter;
}
#mainvisual span{
	color:white;
	font-weight: bold;
	font-size: 85px;
}

#mainvisual img {
	display: block;
	margin: 0 auto;
}

/*introduction*/

#introduction p.title{
	color:#08A597;
	font-size: 30px;
	margin-top: 50px;
}
p.title span{
	color:#08A597;
	font-size: 45px;
}
#introduction .text{
	font-size: 20px;
	line-height: 1.7;
}

#btn_top_1{
	width: 800px;
	margin: 0 auto;
}
.btn_top{
	float:left;
	margin: 0 38px;
}

.btn_top,.btn_bottom p {
	color:#08A597;
	font-size: 14px;
}

.intro-message{
	width: 920px;
	margin: 0 auto;
	padding: 10px 0 10px 20px;
	font-size: 18px;
	font-weight: bold;
	position: relative;
	background: #fff;
  	padding: 8px 5px 8px 0px;
  	color: #474747;
  	border-radius: 0 10px 10px 0;
}

.intro-message p{
	margin: 0 0 0 70px;
}

.intro-message > p span{
	display: inline-block;
	margin: 10px 0;
}

.intro-message:before {
  content: "";
  background-image: url('../img/icon-pencile.png');
  background-size: 45px;
  background-position: center;
  background-repeat: no-repeat;
  display: inline-block;
  line-height: 40px;
  position: absolute;
  padding: 0em;
  color: white;
  background-color: #f57a12;
  font-weight: normal;
  width: 80px;
  text-align: center;
  height: 80px;
  line-height: 40px;
  left: -1.35em;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  border-radius: 50%;
  box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.29);
}

/*lesson*/

#lesson{
	margin-top: 30px;
}
.subvisual_1{
	background-color: #F57A00;
	padding: 1px 0;
}
.subvisual_1 p{
	font-size: 25px;
	color:white;
	font-weight: lighter;
}

.subvisual_1 span{
	color:white;
	font-size: 40px;
}

.subvisual_2{
	background-color: #6B81CB;
	padding: 1px 0;
}
.subvisual_2 p{
	font-size: 25px;
	color:white;
	font-weight: lighter;
}

.subvisual_2 span{
	color:white;
	font-size: 40px;
}

.subvisual_3{
	background-color: #EA9DAB;
	padding: 1px 0;
}
.subvisual_3 p{
	font-size: 25px;
	color:white;
	font-weight: lighter;
}

.subvisual_3 span{
	color:white;
	font-size: 40px;
}

.subvisual_4{
	background-color: #F14B4B;
	padding: 1px 0;
}
.subvisual_4 p{
	font-size: 25px;
	color:white;
	font-weight: lighter;
}

.subvisual_4 span{
	color:white;
	font-size: 40px;
}

#pageTop {
  position: fixed;
  bottom: 20px;
  right: 100px;
  width: 0px;
  z-index: 200000;
}

#pageTop a {
  display: block;
  z-index: 999;
  border-radius: 45px;
  width: 70px;
  height: 70px;
  background-color: #08A597;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
}

#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}

.top {
	position: relative;
	top: 22px;
}

/*title*/
#lesson .title{
	color:#F57A00;
	font-size: 28px;
	margin-top: 50px;
}
#lesson .title span{
    color:#F57A00;
	font-size: 40px;
}

#teacher,#system,#pos{
	margin-top: 30px;
}
#teacher .title{
	color:#6B81CB;
	font-size: 28px;
	margin-top: 50px;
}
#teacher .title span{
    color:#6B81CB;
	font-size: 40px;
}

.cf:after{
	display:block;
	clear:both;
	content:"";
}
#system .title{
	color:#EA9DAB;
	font-size: 28px;
	margin-top: 50px;
}
#system .title span{
    color:#EA9DAB;
	font-size: 40px;
}


#pos .title{
	color:#F14B4B;
	font-size: 28px;
	margin-top: 50px;
}
#pos .title span{
    color:black;
	font-size: 40px;
}
.pos_bottom{
	font-size: 50px;
	color:#F14B4B;
	margin-top: -20px;
}

.explain{
	float:left;
	font-size: 20px;
	text-align: left;
	color:#333333;
	width: 48%;
	margin: 0 1%;
	line-height: 1.7;
}
.explain_new {
    float: left;
    font-size: 20px;
    text-align: left;
    color: #333333;
    width: 100%;
    margin: 4% 1%;
    line-height: 1.7;
}

.pic{
	float:left;
	width: 48%;
	margin: 0 1%;
}

.pic > img {
	width: 100%;
}
span.line{
	font-size:25px;
	border-bottom:solid 1px #08A597;
}

/*サイドメニュー*/
.side_menu {
	position:fixed;
	top:114px;
	right:0;
	z-index: 200000;
}
.side_menu img {
	width:100%;
}

.fixed {
	position: fixed;
	width: 100%;
	height: 100%;
}

.button-link{
	color: #00f;
	text-decoration: underline;
}
.button-link:hover{
	cursor: pointer;
	color: #f00;
}
#modal-overlay{
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 120%;
	background-color: rgba(0,0,0,0.75);
}
#modal-content{
	width: calc(100% - 44px);
	padding: 10px 20px;
	border: 2px solid #aaa;
	background: #fff;
	display: none;
	z-index: 1;
	position: relative;
}
#modal-wrapper{
	width: 100%;
}


.menu-subtitle {
	color: #fff;
}

.side_box {
	box-sizing:border-box;
	background-color: white;
}

.jugyo td {
	color: #F05D27;
	border: 1px solid #F05D27;
}

.instructor td {
	color: #6B81CB;
	border: 1px solid #6B81CB;
}

.system td {
	color: #E78D9D;
	border: 1px solid #E78D9D;
}

.pos td {
	color: #F14B4B;
	border: 1px solid #F14B4B;
}

.jugyo a {
	color: #F05D27;
}

.instructor a {
	color: #6B81CB;
}

.system a {
	color: #E78D9D;
}

.pos a {
	color: #F14B4B;
}

.home .menu-title {
	background-color: #08A597;
}

.jugyo .menu-title {
	background-color: #F05D27;
}

.instructor .menu-title {
	background-color: #6B81CB;
}

.system .menu-title {
	background-color: #E78D9D;
}

.pos .menu-title {
	background-color: #F14B4B;
}

.side_box td {
	border-bottom: none;
	border-right: none;
	font-size: 18px;
	width: 50%;
}

.menu-title {
	color: #fff;
	text-align: left;
	font-size: 23px;
}

.side_box table {
	height: 100%;
	width: 100%;
	text-align: center;
}

.menu-title img {
	max-width: 33px;
}

.menu-title p {
	float: left;
	width: 18%;
	text-align: center;
}

.menu-title .center {
	width: 63%;
	text-align: center;
}

.num {
	border-bottom: 3px solid #fff;
}

.icon {
	width: 20%;
	text-align: left;
}

#side {
	width: 400px;
	height: 100%;
	position:fixed;
	top: 0;
	right: 0;
	z-index: 100000;
	margin-right: -400px;
	transition: 0.5s;
}

.side_box {

}

#side a {
	text-decoration: none;
	display: block;
	width: 100%;
}

.side_close img {
}

.side_close:hover,
.side_menu:hover {
	cursor: pointer;
}

table {
	border-spacing: 0;
}

th p {
	margin: 0;
}

/*サイドメニュー*/

#fixed_footer{
	    position: fixed;
    width: 100%;
    bottom: 0px;
    background-color: white;
    margin: 0 auto;
    text-align: center;
}
#fixed_footer img{
width: 270px;
    box-shadow: 0 1px 1px #666666;
    margin: 10px 10px 0;
}

#Footer{
	text-align: center;
}

  /*____________________________________
  Button
____________________________________*/

a {
         -o-transition: all .3s;
    -webkit-transition: all .3s;
       -moz-transition: all .3s;
            transition: all .3s;
    -webkit-font-smoothing: antialiased;
}
a:link {
    text-decoration: none;
}

a:visited {
    text-decoration: none;
}

a:hover {
    text-decoration: none;
}

a:active {
    text-decoration: none;
}
a {
    cursor: pointer;
}

.col_flex{
	    display: flex;
    min-height: 1px;
    flex-wrap: wrap;
    justify-content: center;
}
.col_4 {
    max-width: 33.333333%;
    flex: 0 0 30%;
    padding-right: 15px;
    padding-left: 15px;
    text-align: center;
}
.btn_basic {
    font-size: 2.4rem;
    display: block;
    margin-bottom: 20px;
    padding: 0.3em 0em;
    transition: none;
    text-align: center;
    color: #fff;
    border-radius: 4px;
    text-shadow: 0 1px 1px rgba(0, 0, 0, .3);
    font-weight: bold;
    box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.29);
}

.btn_basic span{
	font-size: 14px;
}

.fa_angle_right {
    line-height: 1.5;
    float: right;
}
/* btn_basicApplication_type01 */
.btn_basicApplication_type01 {
    border: 1px solid #cc1338;
    background-color: #dc143c;
    background-image: linear-gradient(to bottom, #dc143c, #cc1338);
    border-bottom: solid 3px #94112b;
}

.btn_basicApplication_type01:hover {
    border: 1px solid #bd1134;
    background-color: #ad102f;
    background-image: linear-gradient(to bottom, #cc1338, #ad102f);
    border-bottom: solid 3px #94112b;
}

/* btn_basicRequest_type01 */
.btn_basicRequest_type01 {
    border: 1px solid #009380;
    background-color: #008271;
    background-image: linear-gradient(to bottom, #009380, #008271);
    border-bottom: solid 3px #04675b;
}

.btn_basicRequest_type01:hover {
    border: 1px solid #008271;
    background-color: #008271;
    background-image: linear-gradient(to bottom, #008271, #008271);
    border-bottom: solid 3px #04675b;
}
/* btn_basicMeeting__type01 */
.btn_basicMeeting__type01 {
    border: 1px solid #002d71;
    background-color: #0041a4;
    background-image: linear-gradient(to bottom, #165dc7, #0f4da9);
    border-bottom: solid 3px #073984;
}

.btn_basicMeeting__type01:hover {
    border: 1px solid #0041a4;
    background-color: #00193e;
    background-image: linear-gradient(to bottom, #0e4eaf, #103b7b);
    border-bottom: solid 3px #073984;
}

.btn_row_three .btn_basic {
    font-size: 20px;
}
.btn_wide .btn_basic {
    width: 50%;
    margin: 0 auto calc(40px + 50px) auto;
}
.btn_bottom_wrap {
	width: 1000px;
    padding: 20px 0;
	background-color: #f5f5f5;
	border: 1px solid #ccc;
	margin: 40px auto;
}
.btn_bottom_wrap h3 {
    text-align: center;
    border-bottom: none;
}
.soon .container{
    position: relative;
}
.btn_wide .soon_circle{
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    top: _15px;
    right: 270px;
    background-color: #fff;
    color: #d8143b;
    border:1px solid #d8143b;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.2;
    width: 90px;
    height: 90px;
    padding:.4em;
    border-radius: 50%;
}

.btn-copy-type01 {
    padding: 0 10px;
    text-shadow: none;
    border-bottom: 1px solid;
}

.btn-copy-type02{
    padding: 0 10px;
    text-shadow: none;
    border-bottom: 1px solid;
}

.btn-copy-type03{
    padding: 0 10px;
    text-shadow: none;
    border-bottom: 1px solid;
}

@media screen and (max-width:600px) {
    .btn_wide .btn_basic {
        width: 90%;
        margin: 0 auto calc(20px + 30px) auto;
    }
    .btn_basic {
        font-size: 1.8rem;
        margin-bottom: 15px;
    }
    .btn_row_three .btn_basic {
        font-size: 1.8rem;
    }
    .col_flex.btn_row_two,
    .col_flex.btn_row_three {
        display: block;
    }
    .btn_row_two .col_6,
    .btn_row_three .col_4 {
        max-width: 90%;
        margin: 0 auto;
    }
    .btn_basic {
        padding: .7em 1em;
    }
}