@charset "utf-8";

/*----------------------------------------------*/
/* mypage
/*----------------------------------------------*/

/* title and text
/*----------------------------------------------*/
.title {
    position: relative;
    margin-bottom: 40px;
    padding: 16px 0;
    color: #005fba;
    font-size: 2.3rem;
    text-align: center;
    border-bottom: 2px solid #005fba;
}
.subtitle {
    position: relative;
    margin-bottom: 24px;
    padding: 8px 40px;
    color: #005fba;
    font-size: 1.8rem;
    border-top-right-radius: 30px;
    border-bottom-right-radius: 30px;
    background: #d8f5fe;
}
.subtitle:before {
    content: '';
    display: block;
    position: absolute;
    top: 50%;
    left: 16px;
    width: 13px;
    height: 13px;
    margin-top: -6px;
    border-radius: 10px;
    background: #FFF;
}
.heading {
    position: relative;
    margin-bottom: 16px;
    padding-left: 15px;
    font-size: 1.5rem;
    font-weight: bold;
    border-left: 5px solid #005fba;
}
.subcatch {
    margin-bottom: 16px;
    color: #555;
    font-size: 1.3rem;
    text-align: center;
}

.text_center,
.text_center td {
    text-align: center !important;
}
.text_right {
    text-align: right !important;
}
.text_left,
.text_left td {
    text-align: left;
}

.text_link {
    color: #005fba;
    text-decoration: underline;
    cursor: pointer;
}
.text_link:hover {
    text-decoration: none;
}


/* box style
/*----------------------------------------------*/
.box {
    position: relative;
    margin-bottom: 64px;
    padding: 0 16px;
}
.box-sub {
    position: relative;
    margin-bottom: 3rem;
}
.box-inner {
    padding: 0 16px;
}

.box p{
    margin-bottom: 2.5rem;
}


/* list style
/*----------------------------------------------*/
.list_free, .list_caution {
    margin-bottom: 2.5rem;
}
.list_free li, .list_caution li {
    position: relative;
    margin-top: 4px;
    padding-left: 25px;
}
.list_free li span {
    position: absolute;
    top: 0;
    left: 0;
}

.s_list{
    font-size: 0.9rem;
}

.has_margin{
    margin-bottom: 2.5rem;
}

.compact_wrapper{
    margin-bottom: 2.5rem;
}

.compact_wrapper p, .compact_wrapper ul{
    margin-bottom: 0;
}

/* button style
/*----------------------------------------------*/
.btn {
    display: inline-block;
    margin-bottom: 8px;
    padding: 13px 40px 11px 16px;
    font-size: 1.3rem;
    border-radius: 7px;
    border: 2px solid #FFF;
    box-shadow: 3px 3px 0 #e2e1e0;
}
.btn_clear {
    display: inline-block;
    width: 450px;
    margin: 0 8px 10px;
    color: #005fba;
    background: #FFF;
    border: 3px solid #e2e1e0;
    box-shadow: 2px 2px 0 #e2e1e0;
    position: relative;
}
.btn_clear:after {
    display: inline-block;
    content: '';
    position: absolute;
    top: 50%;
    right: 15px;
    width: 15px;
    height: 15px;
    margin-top: -9.5px;
    border-top: 2px solid #005fba;
    border-right: 2px solid #005fba;
    transform: rotate(45deg);
}

#btn_submit {
    display: none;
}
.btn_disabled {
    display: inline-block;
    width: 250px;
    padding: 13px 16px 11px;
    color: #FFF;
    border: 2px solid #888;
    background: #999;
}
.btn_send {
    width: 250px;
    padding: 13px 16px 11px;
    color: #FFF;
    border: 2px solid #ff6464;
    -moz-background: linear-gradient(to bottom, #ff9797, #ff4b4b);
    -webkit-background: linear-gradient(to bottom, #ff9797, #ff4b4b);
    background: linear-gradient(to bottom, #ff9797, #ff4b4b);
}
.btn_send:hover {
    opacity: .8;
    color: #FFF;
    text-decoration: none;
    cursor: pointer;
}


/* course info
/*----------------------------------------------*/
.course-title {
    position: relative;
    margin-bottom: 16px;
}
.course-name {
    display: inline-block;
    margin: 0 10px 3px 0;
    padding: 5px 15px;
    color: #FFF;
    font-size: 1.2rem;
    border-radius: 1em;;
    background: #d8f5fe;
}


/*  signup info
/*----------------------------------------------*/
.box_about {
    position: relative;
    overflow: hidden;
    text-align: right;
}
.box_about p {
    display: inline-block;
    position: relative;
    top: 10px;
}
.box_about .btn {
    float: right;
    min-width: 260px;
    padding-top: 8px;
    padding-bottom: 8px;
    font-size: 1rem;
    text-align: center;
    position: relative;
}
.box_about .btn:after {
    display: inline-block;
    content: '';
    position: absolute;
    top: 50%;
    right: 15px;
    width: 10px;
    height: 10px;
    margin-top: -7px;
    border-top: 2px solid #005fba;
    border-right: 2px solid #005fba;
    transform: rotate(45deg);
}

.icon_notice {
    padding-left: 30px;
    font-size: 1.1rem;
    background: url(../images/icon_notice.png) left 0 no-repeat;
    background-size: 20px auto;
}
.icon_question {
    display: inline-block;
    padding-left: 20px;
    background: url(../images/icon_question.png) left 2px no-repeat;
    background-size: 15px auto;
}


/* flow
/*----------------------------------------------*/
.box_bank {
    padding: 16px;
    background: #feefe6;
}
.box_bank th, .box_bank td {
    vertical-align: middle;
}
.box_bank th {
    padding: 0 32px 0 8px;
    color: #eb6e22;
    font-size: 1.3rem;
    border-right: 1px solid #eb6e22;
}
.box_bank td {
    padding-left: 32px;
}

.column4_2 {
    display: flex;
}

.column4_2 .column {
    /*float: left;*/
    position: relative;
    width: calc((100% - 48px) / 3);
    margin-bottom: 12px;
}
.column4_2 .column:nth-child(3n-1), 
.column4_2 .column:nth-child(3n-2) {
    margin-right: 16px;
}

.arrow_long {
    position: absolute;
    top: 30px;
    left: 100%;
    width: 40px;
    height: 32px;
    margin-left: -10px;
    padding: 8px;
    color: #FFF;
    font-size: 0.9rem;
    background: #999;
    box-sizing: border-box;
    z-index: 9;
}
.arrow_long:before {
    content: '';
    position: absolute;
    top: 0;
    left: -10px;
    border-left: 10px solid transparent;
    border-top: 16px solid #999;
    border-bottom: 16px solid #999;
}
.arrow_long:after {
    content: '';
    position: absolute;
    top: 0;
    right: -10px;
    border-left: 10px solid #999;
    border-top: 16px solid transparent;
    border-bottom: 16px solid transparent;
}

.request_step {
    position: relative;
}
.request_step .column {
    position: relative;
    height: 320px;
    padding: 0 16px;
    border: 2px solid #CCC;
}
.request_step .column:last-child {
    border: 2px solid #005fba;
}
.request_step .column:nth-child(3) .arrow_long {
    position: absolute;
    top: 30px;
    left: 100%;
    width: 40px;
    height: 32px;
    margin-left: -10px;
    padding: 8px;
    color: #FFF;
    font-size: 0.9rem;
    background: #ff6464;
    z-index: 9;
}
.request_step .column:nth-child(3) .arrow_long:before {
    content: '';
    position: absolute;
    top: 0;
    left: -10px;
    border-left: 10px solid transparent;
    border-top: 16px solid #ff6464;
    border-bottom: 16px solid #ff6464;
}
.request_step .column:nth-child(3) .arrow_long:after {
    content: '';
    position: absolute;
    top: 0;
    right: -10px;
    border-left: 10px solid #ff6464;
    border-top: 16px solid transparent;
    border-bottom: 16px solid transparent;
}
.request_step .column4_2 .column {
    height: 320px;
    padding: 0 16px;
    border: 2px solid #CCC;
}
.request_step .column4_2 .column:last-child {
    border: 2px solid #005fba;
}
.request_step .column4_2 .column:nth-child(2) .arrow_long {
    position: absolute;
    top: 30px;
    left: 100%;
    width: 40px;
    height: 32px;
    margin-left: -10px;
    padding: 8px;
    color: #FFF;
    font-size: 0.9rem;
    background: #ff6464;
    z-index: 9;
}
.request_step .column4_2 .column:nth-child(2) .arrow_long:before {
    content: '';
    position: absolute;
    top: 0;
    left: -10px;
    border-left: 10px solid transparent;
    border-top: 16px solid #ff6464;
    border-bottom: 16px solid #ff6464;
}
.request_step .column4_2 .column:nth-child(2) .arrow_long:after {
    content: '';
    position: absolute;
    top: 0;
    right: -10px;
    border-left: 10px solid #ff6464;
    border-top: 16px solid transparent;
    border-bottom: 16px solid transparent;
}
.request_step .step {
    width: 150px;
    margin: 0 auto 8px;
    padding: 8px 0;
    color: #FFF;
    font-size: 1.2rem;
    background: #06aee0;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
}
.request_step .step.step_finish {
    background: none;
}
.icon_pdf {
    display: inline-block;
    padding-left: 25px;
    background-position: left 4px;
    background-size: 18px auto;
    background: url(../images/icon_pdf.png) left 4px no-repeat;
    background-size: 1em auto;
}

.request_agree {
    margin-bottom: 8px;
    padding: 24px;
    text-align: center;
    border: 2px solid #DDD;
    background: #f6fdff;
}
.request_agree p {
    margin-bottom: 24px;
    text-align: center;
}
.request_agree .column3 .column {
    padding: 8px 0;
    color: #FFF;
}
.request_agree .column3 .column:after {
    content: '';
    width: 20px;
    height: 20px;
    margin-left: -10px;
    transform: rotate(45deg);
}
.request_agree .column3 .column:first-child {
    width: 478px;
    margin-right: 16px;
    background: #06aee0;
}
.request_agree .column3 .column:first-child:before {
    content: '';
    position: absolute;
    left: 24%;
    bottom: -10px;
    width: 20px;
    height: 20px;
    margin-left: -10px;
    transform: rotate(45deg);
    background: #06aee0;
}
.request_agree .column3 .column:first-child:after {
    position: absolute;
    left: 76%;
    bottom: -10px;
    background: #06aee0;
}
.request_agree .column3 .column:nth-child(2) {
    width: 231px;
    margin-right: 16px;
    background: #ffa02f;
}
.request_agree .column3 .column:nth-child(2):after {
    position: absolute;
    left: 50%;
    bottom: -10px;
    background: #ffa02f;
}
.request_agree .column3 .column:last-child {
    width: 231px;
    background: #daa520;
}
.request_agree .column3 .column:last-child:after {
    position: absolute;
    left: 50%;
    bottom: -10px;
    background: #daa520;
}
.request_agree .column4 .column {
    height: 510px;
    padding: 8px;
    background: #f5f5f5;
    width: calc((100% - 63px) / 4);
}
.request_agree .column4 .column .name:after {
    display: none;
}
.request_agree .column4 .column a {
    position: absolute;
    left: 24px;
    bottom: 8px;
    width: 180px;
}
.request_agree .icon_notice {
    display: none;
    margin-top: 8px;
}

/* check
------------------------------------------------------- */
/*.check-conf {*/
/*    margin-top:20px;*/
/*    padding:10px;*/
/*    border-radius:5px;*/
/*    border:1px solid #DDD;*/
/*    background:#EEE;*/
/*}*/

.check-conf input {
    display:none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.check-conf label {
    display:block;
    width: 70%;
    margin:0 110px 15px;
    padding:8px 5px 5px 35px;
    font-size:1.2em;
    font-weight:normal;
    border:1px solid #999;
    border-radius:8px;
    background:-webkit-gradient(linear, left top, left bottom, from(#FFF), to(#FFB9BB));
    background:-moz-linear-gradient(top, #FFF, #FFB9BB);
    background:-ms-linear-gradient(top, #FFF, #FFB9BB);
}

.check-conf label.checked {
    background:url(../images/check_on.png) no-repeat 5px 5px, -webkit-gradient(linear, left top, left bottom, from(#FFD28E), to(#FFA428));
    background:url(../images/check_on.png) no-repeat 5px 5px, -moz-linear-gradient(top, #FFD28E, #FFA428);
    background:url(../images/check_on.png) no-repeat 5px 5px, -ms-linear-gradient(top, #FFD28E, #FFA428);
    background-size:auto 70%, 100% auto;
    -webkit-background-size:auto 70%, 100% auto;
}

.check-conf label.unchecked {
    border-color:#F60;
    background:url(../images/check_off.png) no-repeat 5px 5px, -webkit-gradient(linear, left top, left bottom, from(#FFF), to(#EEE));
    background:url(../images/check_off.png) no-repeat 5px 5px, -moz-linear-gradient(top, #FFF, #EEE);
    background:url(../images/check_off.png) no-repeat 5px 5px, -ms-linear-gradient(top, #FFF, #EEE);
    background-size:auto 70%, 100% auto;
    -webkit-background-size:auto 70%, 100% auto;
}

#conf-text {
    display:none;
    color:#F30;
}

/* color
/*----------------------------------------------*/
.color-child {
    background: #E88FB2;
}
.color-total1 {
    background: #4270E3;
}
.color-total2 {
    background: #6099F2;
}
.color-senior {
    background: #B789FF;
}

.color_red {
    color: #f00;
}