/***************************************
style.css
***************************************/

:root {
  --RouteG_Red:#841617;
  --RouteG_Brown:#89252f;
  --RouteG_Gray:#e9e7e7;
}

.f_bold {font-weight: bold;}

.f_ss {font-size: 80%;}
.f_s {font-size: 90%;}
.f_m {font-size: 110%;}

.f_lh_m {line-height: 2rem;}

.bg_red {background-color: #c91d3d; color: #fff;}
.bg_sblue {background-color: #4DA6D1; color: #fff;}

.tbg_pink {background-color: #ff1493;}
.tbg_rpurple {background-color: #7f1184;}
.tbg_cblue {background-color: #0068b7;}
.tbg_pgreen {background-color: #37a34a;}
.tbg_red {background-color: #ff0000;}
.tbg_dred {background-color: #9E1A1D;}

.bg_01 {background-color: #1e2a42; color: #fff;}
.bg_02 {background-color: #1e2a42; color: #fff; border-bottom: 1px solid #fff;}
.bg_03 {background-color: #32405c; color: #fff; border-bottom: 1px solid #fff;}
.bg_04 {background-color: #3f4d69; color: #fff; border-bottom: 1px solid #fff;}
.bg_05 {background-color: #4c5a75; color: #fff;}
.bg_06 {background-color: #5b6882; color: #fff; border-bottom: 1px solid #fff;}
.bg_07 {background-color: #6b778f; color: #fff; border-bottom: 1px solid #fff;}
.bg_08 {background-color: #7c879c; color: #fff;}

.asta {font-size: 90%; text-indent: -1.4rem; margin-left: 1.5rem;}
.asta::before {content: "※"; margin-right: .5rem;}

.space_01 {margin: 3rem 0;}
.space_02 {margin: 5rem 0;}

.h1ttl {
  display: none;
}
.regi {
  font-size: 80%;
  vertical-align: super;
}

.normal_class {
	display: flex;
	justify-content: center;
	font-size: 22px;
	margin: 1.2rem 1.5rem;
}
.normal_class a {
	background-color: #00bfff;
	text-decoration: underline;
	padding: 10px 20px;
	color: #fff;
	text-align: center;
	width: 320px;
}
.normal_class a:hover {
	opacity: .7;
}

.class_link {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: 2rem;
}

.class_link2 {
	display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-top: 2rem;
}

.class_link2 a {
    display: flex; 
    justify-content: center;
    align-items: center;
    background-color: #841617;
    color: #fff;
    padding: .5rem;
    text-align: center;
    text-decoration: none;
}

.class_link2 a:hover {
    opacity: .5;
}

.br_sp {display: none;}
.br_pc {display: block;}


@media screen and (orientation: portrait) and (max-width: 767px){
    
    .f_lh_m {line-height: 1.8rem;}
    
    .normal_class {
	margin: .5rem 1.5rem;
}
    
    .class_link2 {
	grid-template-columns: repeat(2, 1fr);
    margin: 2rem 1rem 0rem;
}
    
    .class_link2 a {
        font-size: 90%;
    }
    
    .br_sp {display: block;}
    .br_pc {display: none;}
    
}


/* fade_in
============================ */

.fade_in {
  opacity : 0;
  visibility: hidden;
  transition: 1.2s;
  transform: translateY(60px);
}

.fade_in.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}



/* marker
============================ */

span.marker {
  background-image: -webkit-linear-gradient(left, transparent 50%, rgb(255,250,153) 50%);
  background-image: -moz-linear-gradient(left, transparent 50%, rgb(255,250,153) 50%);
  background-image: -ms-linear-gradient(left, transparent 50%, rgb(255,250,153) 50%);
  background-image: -o-linear-gradient(left, transparent 50%, rgb(255,250,153) 50%);
  background-image: linear-gradient(left, transparent 50%, rgb(255,250,153) 50%);
  background-repeat: repeat-x;
  background-size: 200% .8em;
  background-position: .2em .5em;
  transition: all 2.5s ease;
  font-weight: bold;
}

span.marker.active {
  background-position: -100% .5em;
}



/* section
============================ */

#main_content > section {
  margin: 4rem auto;
}

#main_content > section h2 {
  font-weight: 900;
  font-size: 2rem;
  font-family: var(--Font_Weight_Bold);
}

#main_content > section h2 span {
  color: var(--RouteG_Red);
  font-weight: 900;
  font-family: var(--Font_Weight_Bold);
}


@media screen and (orientation: portrait) and (max-width: 767px){

  #main_content > section {
      margin: 2rem auto;
    width: 96%;
  }

  #main_content > section h2 {
    font-size: 1.6rem;
  }

}


/* section#rg
============================ */

.rg_box {
    padding: 1rem 0rem 0rem;
    letter-spacing: .1rem;
}

.rg_box h3 {
    font-size: 1.4rem;
    font-weight: bold;
    margin-bottom: 2rem;
    border-left: 5px solid #841617;
    padding-left: 1rem;
}

.rg_box > dl dd ul.l2_01_ul p {
    font-weight: 600;
}

.rg_box > dl dd ul.l2_01_ul li {
    text-indent: -1rem;
    margin-left: 1rem;
}

.rg_box > dl {
    display: flex;
}

.rg_box > dl dt {
    width: 25%;
    margin: 0 2rem 1rem 0; 
}

.rg_box > dl dt img {
    width: 100%;
}

.rg_box > dl dd {
    width: 75%;
}

.rg_box > dl dd p {
    margin: 0 0 1rem;
    text-align: justify;
    
}

.rg_box > dl dd p.p_asta {
    font-size: .9rem;
    text-indent: -1rem;
    margin-left: 1rem;
}

.rg_box > dl dd p.p_asta::before {
    content: "※";
}

#l2_07 dl dd ul {
    margin-bottom: 1rem;
}

.rg_box ul.school_locations li {
    margin: 1rem 0 0 1rem;
    text-indent: -1rem;
}

.rg_box ul.school_locations li::before {
    content: "●";
    
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    .rg_box {
        padding: 3rem .5rem 0rem;
    } 
    
    .rg_box > dl {
    display: block;
}

.rg_box > dl dt {
    width: 100%;
    margin: 0 2rem 1rem 0; 
    text-align: center;
}

.rg_box > dl dt img {
    width: 80%;
}

.rg_box > dl dd {
    width: 100%;
}
    
    
    
}


/* features3
============================ */

figure.features3 {
    background-image: url("/kaigai/common/imgs/bg01_map.png");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: #fff;
    text-align: center;
    padding: 3rem 0;
    margin-top: 4rem;
}

figure.features3 h4 {
    font-size: 1.3rem;
    margin-bottom: 1rem;
}

figure.features3 h2 {
    font-size: 2.8rem;
    font-weight: normal;
    margin-bottom: 2rem;
    text-indent: -2rem;
}

figure.features3 img {
    width: 50%;
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    figure.features3 {
    background-size: cover;
    background-position: -720px 0px;
    padding: 2rem 0;
    margin-top: 3rem;
}
    
    figure.features3 h4 {
    font-size: 1rem;
    margin-bottom: 1rem;
}
    
    figure.features3 h2 {
        font-size: 1.8rem;
    text-indent: -1rem;
}
    
    figure.features3 img {
    width: 60%;
}
    
}

/* pass_record
============================ */

#main_content .pass_record {
    background-color: var(--RouteG_Gray);
    margin: 0rem auto;
    padding: 2rem 2rem;
}

#main_content .pass_record .col2_box:has(figure) {
    display: flex;
}

#main_content .pass_record .col2_box {
    display: block;
}

#main_content .pass_record .col2_box:has(figure) dl {
    width: 50%;
}

#main_content .pass_record .col2_box dl {
    width: 100%;
}

#main_content .pass_record .col2_box dl dt {
    margin-bottom: 1rem;
    display: flex;
    align-items: baseline;
}

#main_content .pass_record .col2_box dl dt img {
    width: 60px;
    margin-right: 1rem;
}

#main_content .pass_record .col2_box dl dt h4 {
    font-size: 1.1rem;
}

#main_content .pass_record .col2_box dl dd {
    border-left: 1px solid #841617;
    padding: 1rem 0rem 1rem 1.5rem;
    margin-left: 2.1rem;
    letter-spacing: .05rem;
}

#main_content .pass_record .col2_box dl dd h5 {
    font-size: 2rem;
}

#main_content .pass_record .col2_box dl dd h5 span {
    color: #841617;
}

#main_content .pass_record .col2_box dl dd p {
    font-size: .9rem;
}

#main_content .pass_record .col2_box figure {
    width: 50%;
    text-align: right;
}

#main_content .pass_record .col2_box figure img {
    width: 85%;
}

#main_content .overseas_wrap {
    box-sizing: border-box;
    margin-top: 3rem;
    padding: 1.5rem 1.2rem;
    background-color: #0a557e;
    background-image: url("/success/common/img/overseas_bg.png");
    background-repeat: no-repeat;
    background-position: center center;
    color: #fff;
}

#main_content .overseas_wrap h2 {
    font-size: 2rem;
    font-weight: 400;
    margin-bottom: 1rem;
}

#main_content .overseas_wrap h2 span {
    font-weight: 400;
    display: block;
    color: #f5ff00;
}

#main_content .overseas_wrap .list_box {
    display: flex;
    justify-content: space-between;
}

#main_content .overseas_wrap .list_box > div {
    width: 48%;
    margin: 0 auto;
}

#main_content .overseas_wrap .list_box p {
    box-sizing: border-box;
    width: 100%;
    margin-bottom: 10px;
    padding: 8px 13px;
    background: #2394D1;
    font-size: 18px;
}

#main_content .overseas_wrap .list_box ul li {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    border-bottom: 1px solid #fff;
    font-size: 1rem;
    line-height: 1.5;
    padding: 8px 5px 0 2px;
}

#main_content .pass_record h4.supplement_t {
    font-size: 1.1rem;
    font-weight: bold;
    margin: 2rem 0 1rem;;
}

#main_content .pass_record p.supplement_p {
    font-size: 1rem;
    margin: 0;  
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    #main_content .pass_record {
    width: 100%;
    padding: 2rem 1.5rem;
}
    
    #main_content .pass_record .col2_box:has(figure) {
    display: block;
}
    
    #main_content .pass_record .col2_box:has(figure) dl {
    width: 100%;
}
    
    #main_content .pass_record .col2_box dl dt {
    margin-bottom: .2rem;
}
    
    #main_content .pass_record .col2_box dl dt h4 {
    font-size: 1.2rem;
}
    
    #main_content .pass_record .col2_box dl dt img {
    width: 40px;
    margin-right: 1rem;
}
    
    #main_content .pass_record .col2_box dl dd {
    padding: 1rem 0rem 1rem 1.5rem;
    margin-left: 1.4rem;
    letter-spacing: .05rem;
}
    
    #main_content .pass_record .col2_box dl dd h5 {
    font-size: 1.5rem;
}
    
    #main_content .pass_record .col2_box figure {
    width: 100%;
    text-align: center;
}
    
    #main_content .pass_record .col2_box figure img {
    width: 90%;
}
    
    #main_content .overseas_wrap h2 {
    font-size: 1.4rem;
}
    
    #main_content .overseas_wrap .list_box {
    display: block;
}
    
  #main_content .overseas_wrap .list_box > div {
    width: 100%;
    margin: 1.3rem auto;
}  
    
}

/* teaching_method
============================ */

#main_content .teaching_method {
    margin-top: 3rem;
}

#main_content .teaching_method h5 {
    font-size: 1.1rem;
    margin-bottom: .5rem;
}

#main_content .teaching_method h4 {
    font-size: 1.6rem;
    color: #841617;
    margin-bottom: 1.5rem;
}

#main_content .teaching_method img {
    width: 90%;
    margin: 0 2rem 3rem;
}

@media screen and (orientation: portrait) and (max-width: 767px){
    

#main_content .teaching_method h4 {
    font-size: 1.4rem;
    margin-bottom: 1rem;
}

#main_content .teaching_method img {
    width: 100%;
    margin: 0 auto;
}
    
}

/* teacher_profiles
============================ */

#main_content .teacher_profiles {
    margin-top: 2rem;
}

#main_content .teacher_profiles > p {
    font-size: 1.1rem;
    color: #841617;
}

#main_content .teacher_profiles .teacher {
    display: flex;
    column-gap: 3rem;
    flex-wrap: wrap;
}

#main_content .teacher_profiles .teacher > dl {
    /*display: flex;*/
    width: calc(50% - 1.5rem);
    margin-bottom: 2rem;
} 

#main_content .teacher_profiles .teacher > dl dt {
    float: left;
    width: 40%;
    margin-right: 1rem;
    margin-bottom: .2rem;
}

#main_content .teacher_profiles .teacher > dl dt img {
    width: 100%;
    margin: 0;
}

#main_content .teacher_profiles .teacher > dl dd {
   /* width: 50%;*/
}

#main_content .teacher_profiles .teacher > dl dd p {
    margin: 0 ;
}

#main_content .teacher_profiles .teacher > dl dd p:nth-child(1) {
    font-size: 1.1rem;
    font-weight: 600;
    color: #841617;
    margin-bottom: .5rem;
}

#main_content .teacher_profiles .teacher > dl dd p:nth-child(2) {
    font-size: .9rem;
    letter-spacing: 0rem;
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    #main_content .teacher_profiles .teacher {
    display: block;
}
    
    #main_content .teacher_profiles .teacher > dl {
    width: 100%;
} 
    
    #main_content .teacher_profiles .teacher > dl dt {
    width: 35%;
}
    
    #main_content .teacher_profiles .teacher > dl dd {
    width: 100%;
}
    
    #main_content .teacher_profiles .teacher > dl dt {
    margin-right: 1rem;
}
    
}


/* regular_course
============================ */

.regular_course {
    overflow-x: scroll;
    display: block;
    max-width: 960px;
    -webkit-overflow-scrolling: touch;
}

.regular_course table {
    font-size: .7rem;
    width: 250%;
}

.regular_course table th,
.regular_course table td {
    padding: .1rem .3rem;
    text-align: left;
    vertical-align: middle;  
    border: 1px solid #555;
}

.regular_course table th:nth-of-type(2),
.regular_course table th:nth-of-type(4) {
    white-space: nowrap;
}

.regular_course table th:nth-of-type(1) {
    width: 20px;
}

.regular_course table th:nth-of-type(3) {
    width: 380px;
}

.regular_course table th:nth-of-type(4) {
    width: 200px;
}

.regular_course table th:nth-of-type(9) {
    width: 700px;
}

.regular_course table th:nth-of-type(10) {
    width: 300px;
}

@media screen and (orientation: portrait) and (max-width: 767px){

    
   .regular_course {
    overflow-x: scroll;
       max-width: 1200px;
}
    
    .regular_course table {
    font-size: .8rem;
    width: 400%;
}
    
    }


/* regular_course_2
============================ */

.regular_course_2 table {
    font-size: .8rem;
    width: 100%;
    background-color: #fff;
}

.regular_course_2 table th,
.regular_course_2 table td {
    padding: .3rem .3rem;
    text-align: left;
    vertical-align: middle;  
    border: 1px solid #555;
}

.regular_course_2 table th {
    text-align: center;
}

.regular_course_2 table tr td:nth-of-type(1) {
    writing-mode: vertical-rl;
    text-orientation: upright;
    color: #fff;
    text-align: center;
    width: 5px;
}

.regular_course_2 table td ul {
    margin: 0 1rem;
}

.regular_course_2 table td ul li {
    margin: .5rem 0;
    text-indent: -1.5rem;
    margin-left: 1.5rem;
}

.regular_course_2 table td ul li:first-child {
    font-size: 1.2rem;
}

.regular_course_2 table td ul li:not(:first-child)::before {
    content: "■";
    margin-right: .5rem;
}


@media screen and (orientation: portrait) and (max-width: 767px){
    
    }


/* summer_aplink
============================ */

.summer_aplink {
    display: flex;
    justify-content: center;
    column-gap: 4rem;
    margin-top: 2rem;
}

.summer_aplink a {
    height: 3rem;
    background: #ef717c;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 100%;
    border-radius: 1.8rem;
    color: #fff;
    font-weight: 900;
    font-family: var(--Font_Weight_Bold);
    font-size: 1.2rem;
    text-align: center;
    line-height: 1;
}

.summer_aplink a:hover {
    opacity: .5;
}

.summer_aplink a::after {
    position: absolute;
    top: calc(50% - .6rem);
    right: 1rem;
    width: auto;
    height: auto;
    border: none;
    line-height: 1;
    font-weight: 900;
    font-family: var(--Font_Awesome);
    content: var(--Arrow_Right);
}


@media screen and (orientation: portrait) and (max-width: 767px){
    .summer_aplink {
    display: block;
}
    
    .summer_aplink a {
        margin-bottom: 1rem;
    }
    
    }


/* よくあるご質問 q_a
============================ */

.q_a h1 {
    display: flex;
    justify-content: center;
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 2rem;
}

.q_a .accordion .acd_group {
    margin: 1.5rem 0;
}

.q_a .accordion .acd_header {
    display: flex;
    justify-content: space-between;
    cursor: pointer;
    border-bottom: 1px solid #dcdcdc;
    padding-bottom: 1rem;
}

.q_a .accordion .acd_header .op_cl::before {
    font-weight: 900;
    font-family: var(--Font_Awesome);
    content: "\f067";
    color: #841617;
    font-size: 1.4rem;
    margin-right: 1rem;
    margin-left: 1rem;
}

.q_a .accordion .acd_active .acd_header .op_cl::before{
    font-weight: 900;
    font-family: var(--Font_Awesome);
    content: "\f068";
    color: #841617;
    font-size: 1.4rem;
    margin-right: 1rem;
    margin-left: 1rem;
}

.q_a .accordion .acd_header .head_t {
    font-size: 1.1rem;
    display: flex;
}

.q_a .accordion .acd_header .head_t span.maru_q {
    display: inline-block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #841617;
    text-align:center;
    line-height: 30px;
    color: #fff;
    margin-right: 1rem;
}

.q_a .accordion .acd_header .head_t span.q_title {
    font-weight: 700;
    display: inline-block;
    flex: 1;
}

.q_a .accordion .acd_contents {
    background-color: #f5f5f5;
    padding: .5rem 2rem;
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    
}


/* event
============================ */

.event {
    background-color: #f2f6fa;
    padding: 1rem 2rem 2rem;
}

.event figure {
    text-align: center;
    margin-bottom: 1.5rem;
}

.event figure img {
    width: 500px;
}

.event > h3 {
    font-size: 1.8rem;
    display: flex;
    justify-content: center;
    margin: 1.5rem 0 3rem;
    color: #841617;
    font-weight: normal;
}

.event > p.event_asta {
    font-size: .9rem;
    display: flex;
    justify-content: center;
    margin: 0rem 0 3rem;
    color: #841617;
}

.event .event_conte {
    display: flex;
    flex-wrap: wrap;
    column-gap: 2rem;
}

.event .event_conte dl {
    width: calc(100% / 3 - 1.5rem);
    margin-bottom: 2rem;
    padding: 0 0 .5rem 0;
    background-color: #fff;
    border-radius: 10px 0 0 0;
    display: flex;
    flex-direction: column;
}

.event .event_conte dl dt {
    background-color: #841617;
    color: #fff;
    border-radius: 10px 0 0 0;
    width: fit-content;
    font-size: .8rem;
    padding: .2rem .5rem;
    margin-bottom: 1rem;
}

.event .event_conte dl ul {
    margin: 0 1rem;
    flex: 1;
}

.event .event_conte dl dd {
    text-align: center;
    margin: 2rem 0 1rem;
}

.event .event_conte dl dd a {
    font-size: .9rem;
}

.event .event_conte dl dd a::after {
    font-weight: 900;
    font-family: var(--Font_Awesome);
    content: "\f002";
    margin-left: .5rem;
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    .event {
    padding: 1rem 1rem .5rem;
}
    
    .event figure img {
    width: 100%;
}
    
    .event .event_conte {
    display: block;
}
    
    .event .event_conte dl {
    width: 100%;
}
    

    
}


/* course_table
============================ */

.gcourse_table {
    margin-top: 2rem;
}

.gcourse_table table {
    width: 98%;
    margin: 0 auto;
}

.gcourse_table table th,
.gcourse_table table td {
    padding: .5rem;
    text-align: center;
    vertical-align: middle;
}

.gcourse_table table td {
    border-right: 1px solid #555;
    border-bottom: 1px solid #555;
}

.gcourse_table table tr.bg_01 th:not(:last-child) {
    border-right: 1px solid #fff;
}

.gcourse_table h5 {
    font-size: 1.1rem;
    margin-bottom: .5rem;   
}

.gcourse_table h4 {
    font-size: 1.6rem;
    color: #841617;
    margin-bottom: 1.5rem;  
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
   .gcourse_table {
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch; 
}
    
}

/* step3_level7
============================ */
.step3_level7 {
    margin-top: 3rem;
}

.step3_level7 h5 {
    font-size: 1.1rem;
    margin-bottom: .5rem;   
}

.step3_level7 h4 {
    font-size: 1.6rem;
    color: #841617;
    margin-bottom: 1.5rem;  
}

.step3_level7 a:hover {
    opacity: .5;
}

.step3_level7 .col3_box {
    display: flex;
    column-gap: 1.8rem;
}

.step3_level7 .col3_box .term {
    width: calc(100% / 3 - .9rem);
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.step3_level7 .col3_box .term .arrow_t {
    display: flex;
    align-items: center;
    background-color: #841617;
    color: #fff;
    font-size: .8rem;
    height: 34px;
    padding-left: 1rem;
    position: relative;
    margin-right: 20px;
}

.step3_level7 .col3_box .term .arrow_t::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -1.2rem;
    transform: translate(-1%, -50%);
    width:0;
    height:0;
    border-style:solid;
    border-width: 17px 0 17px 20px;
    border-color: transparent transparent transparent #841617;
}

.step3_level7 .col3_box .term > dl {
    margin-top: 1rem;
    padding: .7rem;
    border-top: 3px solid #841617;
    background-color: #fff;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.step3_level7 .col3_box .term > dl dt {
    display: flex;
    flex-direction: column;
    border-bottom: 2px dotted #841617;
    font-size: .8rem;
    letter-spacing: 0rem;
    color: #841617;
}

.step3_level7 .col3_box .term > dl dt > span {
    font-size: 1.6rem;
    letter-spacing: .08rem;
}

.step3_level7 .col3_box .term > dl .goal {
    display: flex;
    align-items: flex-start;
    letter-spacing: 0rem;
    color: #841617;
    padding-top: 1rem;
}

.step3_level7 .col3_box .term > dl .goal p {
    font-size: .9rem;
    width: 30%;
    margin: 0;
}

.step3_level7 .col3_box .term > dl .goal > ul {
    display: flex;
    flex-wrap: wrap; 
    width: 70%;
}

.step3_level7 .col3_box .term > dl .goal > ul li {
    background-color: #841617;
    color: #fff;
    border-radius: 1rem;
    padding: .05rem .5rem;
    margin-right: .3rem;
    margin-bottom: .3rem;
    font-size: .8rem;   
}

.step3_level7 .col3_box .term > dl dd {
    margin-top: 1rem;
    text-align: center;
}

.step3_level7 .col3_box .term > dl dd a {
    color: #841617;
    text-decoration: underline;
    font-size: .9rem;
    cursor: pointer;
}

.step3_level7 .col3_box .term > dl dd a::after {
    content: '\f002';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
}

.step3_level7 .col3_box .term > dl dd p {
    text-align: left;
    margin: 1rem 0 0 1.5rem;
    font-size: .8rem;
    color: #841617;
}

.step3_level7 > ul.u_supplement {
    margin-top: 1rem;
}

.step3_level7 > ul.u_supplement li {
    font-size: .9rem;
    text-indent: -1rem;
    margin-left: 1rem;
}

.step3_level7 > ul.u_supplement li:last-child {
    color: #841617;
    margin-top: 1rem;
}

.step3_level7 > ul.u_supplement li:last-child a {
    color: #841617;
    text-decoration: underline;
}

.step3_level7 > ul.u_supplement li::before {
    content: "※";
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    .step3_level7 .col3_box {
    display: block;
}
    
    .step3_level7 .col3_box .term {
    width: 100%;
    display: flex;
        flex-direction: row;
        margin-bottom: 3rem;
}
    
    .step3_level7 .col3_box .term .arrow_t {
    display: flex;
    align-items: center;
    font-size: .9rem;
        width: 24px;
    height: auto;
    padding: .5rem .5rem;
    margin-right: 20px;
    writing-mode: vertical-rl;
    text-orientation: upright;
}

.step3_level7 .col3_box .term .arrow_t::after {
    content: "";
    position: absolute;
    top: 96%;
    right: .1rem;
    transform: rotate(90deg);
    width:0;
    height:0;
    border-style:solid;
    border-width: 17px 0 17px 20px;;
    border-color: transparent transparent transparent #841617;
}
    
    .step3_level7 .col3_box .term > dl {
        margin-top: 0rem;
    }
    
}


/* reason
============================ */

.reason section {
  position: relative;
  margin: 2rem 0;
  padding: 2rem;
  background: var(--RouteG_Gray);
  border-radius: 2rem;
}

.reason section::before {
  position: absolute;
  top: 0;
  left: 2rem;
  color: #fff;
  font-family: var(--Font_Awesome);
  font-weight: 900;
  font-size: 4rem;
  z-index: -1;
}

.reason section:nth-of-type(1)::before {
  content: "\e473";
}

.reason section:nth-of-type(2)::before {
  content: "\f19d";
}

.reason section:nth-of-type(3)::before {
  content: "\f573";
}

.reason section h3 {
  margin-bottom: 3rem;
  font-weight: 900;
  font-size: 1.6rem;
  font-family: var(--Font_Weight_Bold);
  z-index: 1;
}

.reason section:nth-of-type(1) div div {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 1rem;
}

.reason section:nth-of-type(1) div div figure {
  width: 16rem;
}

.reason section:nth-of-type(1) div div figure img {
  width: 100%;
}

.reason section:nth-of-type(1) div div p {
  flex: 1;
  color: var(--RouteG_Red);
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
}

.reason section:nth-of-type(2) li {
  padding-left: 1.8rem;
  color: var(--RouteG_Red);
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
  text-indent: -1.8rem;
}

.reason section:nth-of-type(2) li::before {
  padding-right: .6rem;
  font-family: var(--Font_Awesome);
  font-weight: 900;
  content: "\f14a";
}

.reason section:nth-of-type(3) .merit {
  color: var(--RouteG_Red);
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
}

.reason section:nth-of-type(3) .graduate p {
  margin-top: 0;
  font-weight: 900;
  font-size: 1.1rem;
  font-family: var(--Font_Weight_Bold);
}

.reason section:nth-of-type(3) .graduate > div {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  margin: 1rem auto;
}

.reason section:nth-of-type(3) .graduate div div {
  flex: 1;
}

.reason section:nth-of-type(3) .graduate figure {
  width: 180px;
}

.reason section:nth-of-type(3) .graduate figure img {
  width: 100%;
}

.reason section:nth-of-type(3) .graduate dl {
  flex: 1;
}

.reason section:nth-of-type(3) .graduate dl dt {
  font-weight: 900;
  font-family: var(--Font_Weight_Bold);
}

.reason section:nth-of-type(3) .graduate dl dd {
  padding-top: .2rem;
  color: var(--RouteG_Red);
}


@media screen and (orientation: portrait) and (max-width: 767px){

  .reason section {
    padding: 2rem 1rem;
    border-radius: 1rem;
  }

  .reason section::before {
    left: 1rem;
    font-size: 5rem;
  }

  .reason section h3 {
    margin-bottom: 2rem;
    font-size: 1.4rem;
  }

  .reason section:nth-of-type(1) div div {
    flex-direction: column;
  }

  .reason section:nth-of-type(1) div div figure {
    width: 60%;
  }

  .reason section:nth-of-type(3) .graduate p {
    margin-top: 1rem;
    margin-bottom: 0;
    font-size: 1.1rem;
  }

  .reason section:nth-of-type(3) .graduate > div {
    margin-bottom: 0;
  }

  .reason section:nth-of-type(3) .graduate figure {
    width: 100px;
  }

  .reason section:nth-of-type(3) .graduate dd {
    font-size: .8rem;
  }

}



/* recommend
============================ */

.recommend section {
  margin: 2rem 0;
}

.recommend .beginning {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 760px;
  margin: 2rem auto;
  padding: 2rem;
  background: var(--RouteG_Brown);
  color: #fff;
  font-size: 2rem;
}

.recommend .beginning h3 {
  margin: 0 auto 2rem auto;
  font-weight: 900;
  font-size: 4rem;
  font-family: var(--Font_Weight_Bold);
}

.recommend .beginning h3 ruby {
  font-size: 6rem;
  ruby-position: under;
}

.recommend .content h3 {
  border-bottom: 2px solid var(--RouteG_Brown);
  font-weight: 900;
  font-size: 1.6rem;
  font-family: var(--Font_Weight_Bold);
}

.recommend .content h3 span {
  color: var(--RouteG_Red);
  font-weight: 900;
  font-family: var(--Font_Weight_Bold);
}

.recommend section:nth-of-type(2) .note li {
  font-weight: 900;
  font-size: 1rem;
  font-family: var(--Font_Weight_Bold);
}

.recommend section:nth-of-type(2) dl {
  max-width: 900px;
  min-height: 100px;
  margin: 1rem auto;
  padding-left: 120px;
  background-repeat: no-repeat;
  background-size:100px 100px;
  background-position: left top;
}

.recommend section:nth-of-type(2) dl:nth-of-type(1) {
  background-image: url('/kaigai/common/imgs/icon_1.png');
}

.recommend section:nth-of-type(2) dl:nth-of-type(2) {
  background-image: url('/kaigai/common/imgs/icon_2.png');
}

.recommend section:nth-of-type(2) dl:nth-of-type(3) {
  background-image: url('/kaigai/common/imgs/icon_3.png');
}

.recommend section:nth-of-type(2) dl dt {
  color: var(--RouteG_Red);
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
}

.recommend section:nth-of-type(3) figure {
  max-width: 600px;
  width: 100%;
  margin: 2rem auto 0;
}

.recommend section:nth-of-type(3) figure img {
  width: 100%;
}

.recommend section:nth-of-type(4) div {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 800px;
  min-height: 160px;
  margin: 1rem auto;
  background-repeat: no-repeat;
  background-size:160px 160px;
  background-position: right center;
  background-image: url('/kaigai/common/imgs/surpport.png');
}

.recommend section:nth-of-type(4) ul {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 600px;
  gap: 1rem;
}

.recommend section:nth-of-type(4) ul li {
  padding: .5rem 1rem;
  border-radius: 1rem;
  background: #666;
  color: #fff;
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
}

.recommend section:nth-of-type(5) ul {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 800px;
  min-height: 140px;
  margin: 1rem auto;
  background-repeat: no-repeat;
  background-size:200px 140px;
  background-position: right center;
  background-image: url('/kaigai/common/imgs/offer.jpg');
}

.recommend section:nth-of-type(5) li {
  padding-left: 1.8rem;
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
  text-indent: -1.8rem;
}

.recommend section:nth-of-type(5) li::before {
  padding-right: .6rem;
  color: var(--RouteG_Red);
  font-family: var(--Font_Awesome);
  font-weight: 900;
  content: "\f14a";
}


@media screen and (orientation: portrait) and (max-width: 767px){

  .recommend .beginning {
    width: 100%;
    padding: 1rem;
    font-size: 1rem;
  }

  .recommend .beginning h3 {
    margin: 0 auto 1rem auto;
    font-size: 2rem;
  }
  
  .recommend .beginning h3 ruby {
    font-size: 3rem;
  }

  .recommend .content h3 {
    font-size: 1.2rem;
  }

  .recommend section:nth-of-type(2) dl {
    min-height: 50px;
    padding-left: 60px;
    background-size:50px 50px;
    background-position: left .5rem;
  }

  .recommend section:nth-of-type(2) dl dt {
    font-size: 1.1rem;
  }

  .recommend section:nth-of-type(4) div {
    width: 100%;
    background-size:100px 100px;
  }
  
  .recommend section:nth-of-type(4) ul {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 70%;
    gap: .5rem;
  }
  
  .recommend section:nth-of-type(4) ul li {
    padding: .4rem .8rem;
    border-radius: .8rem;
    font-size: .8rem;
  }

  .recommend section:nth-of-type(5) ul {
    width: 100%;
    background-color: rgba(255, 255, 255, .8);
    background-blend-mode: lighten;
  }

  .recommend section:nth-of-type(5) li {
    padding-left: 1.2rem;
    font-size: 1rem;
    text-indent: -1.2rem;
    text-shadow:
      1px 0 1px #fff,
      1px 1px 1px #fff,
      0 1px 1px #fff,
      -1px 1px 1px #fff,
      -1px 0 1px #fff,
      -1px -1px 1px #fff,
      0 -1px 1px #fff,
      1px -1px 1px #fff;
  }

  .recommend section:nth-of-type(5) li::before {
    padding-right: .2rem;
  }

}



/* sec_image
============================ */

.achievement {
  padding: 2rem;
  background-color: #666;
}

.achievement h2 {
  padding-bottom: 1rem;
  font-size: 1.4rem;
  color: #fff;
}

.achievement section {
  width: 100%;
  margin: 0 auto;
}

.achievement section h3 {
  padding: .5rem;
  background-color: #000;
  color: #fff;
  font-size: 1.4rem;
}

.achievement section div {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem;
  background: #fff;
}

.achievement section dl {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.achievement section dl:nth-of-type(1) dd {
  color: #e41619;
}

.achievement section dl:nth-of-type(2) dd {
  color: #313194;
}

.achievement section dl:nth-of-type(3) dd {
  color: #47b570;
}

.achievement section p {
  display: none;
}

.achievement section dl dt figure {
  width: 80px;
}

.achievement section > figure {
  width: 100%;
}

.achievement section figure img {
  width: 100%;
}

.achievement section .note {
  padding: 1rem;
  background: #fff;
}


@media screen and (orientation: portrait) and (max-width: 767px){

  .achievement {
    width: 100% !important;
    padding: 1rem .5rem;
  }

  .achievement h2 {
    padding: .5rem 0;
    font-size: 1.2rem !important;
  }

  .achievement section h3 {
    font-size: .9rem;
    text-align: center;
  }

  .achievement section dl dd {
    font-size: .8rem;
  }

  .achievement section p {
    display: block;
    margin: 0;
    background: #fff;
    font-size: .8rem;
    text-align: center;
  }

  .achievement section dl dt figure {
    width: 50px;
  }

  .achievement section > figure {
    display: flex;
    flex-direction: column-reverse;
    width: 100%;
    overflow-x:scroll;
  }

  .achievement section > figure img {
    width: 600px;
    border: 1px solid #ccc;
  }

}



/* lecture
============================ */

.lecture {
  padding: 2rem;
  background: var(--RouteG_Gray);
}

.lecture h2 {
  border-bottom: 2px solid var(--RouteG_Red);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.lecture h2 a {
    width: 11rem;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    height: 50px;
    padding-right: 15px;
    border-radius: 25px;
    background: var(--Gradation_Red);
    color: #fff;
    font-weight: 900;
    font-family: var(--Font_Weight_Bold);
    font-size: 20px;
    line-height: 150%;
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.1);
    margin-left: 1rem;
}

.lecture h2 a::after {
    position: absolute;
    top: calc(50% - 10px);
    right: 15px;
    width: auto;
    height: auto;
    border: none;
    line-height: 1;
    font-weight: 900;
    font-family: var(--Font_Awesome);
    content: var(--Arrow_Right);
}

.lecture h2 a:hover {
    opacity: .5;
}

.lecture h2 span {
  display: block;
  font-size: 1rem;
  line-height: 1.2;
}

.lecture section {
  max-width: 800px;
  margin: 2rem auto;
  border: 2px solid var(--RouteG_Brown);
}

.lecture section h3 {
  padding: .5rem;
  background: var(--RouteG_Brown);
  color: #fff;
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
}

.lecture section div {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 1rem;
  padding: 1rem;
  background: #fff;
}

.lecture section dl:first-of-type {
  width: 63%;
}

.lecture section dl:nth-of-type(2) {
  width: 33%;
}

.lecture section dl:last-of-type {
  width: 100%;
}

.lecture section dt {
  color: var(--RouteG_Red);
  font-weight: 900;
  font-family: var(--Font_Weight_Bold);
}

.lecture section dt::before {
  content: "■";
}

.lecture section dd {
  padding-left: 1rem;
}

.lecture .course_list {
    margin-top: 2rem;
}

.lecture .course_list table {
    width: 100%;
    font-size: .9rem;
}

.lecture .course_list table th,
.lecture .course_list table td {
    padding: .5rem;
    border: 1px solid #555;
    vertical-align: middle;
}

.lecture .course_list table th {
    white-space: nowrap;
    background-color: #841617;
    color: #fff;
}

.lecture .course_list table th:last-of-type {
    width: 40%; 
}

.lecture .course_list table tr td:nth-of-type(7) {
    font-size: .8rem;
}

.lecture .course_list table tr td:nth-of-type(1),
.lecture .course_list table tr td:nth-of-type(2),
.lecture .course_list table tr td:nth-of-type(3),
.lecture .course_list table tr td:nth-of-type(4) {
    white-space: nowrap;
}


@media screen and (orientation: portrait) and (max-width: 767px){

  .lecture {
    width: 100% !important;
    padding: 1rem;
  }

  .lecture h2 {
    font-size: 1.2rem !important;
      display: block;
  }
    
    .lecture h2 a {
        margin: 1rem 0;
    }

  .lecture section div {
    flex-direction: colomn;
  }
  
  .lecture section dl {
    width: 100% !important;
  }
    
    
    .lecture .course_list {
        display: block;
    width: 100%;
    overflow-x: auto;
    }
    
    .lecture .course_list table {
    width: 260%;
    table-layout: auto;
}
    

}

/* 講座及び開講日一覧 class_date
============================ */

section.class_date {
	border: 0px solid transparent;
	font-size: .8rem;
}

section.class_date p {
	font-size: .9rem;
}

section.class_date table {
	width: 100%;
}

section.class_date table.rg_fee tr td:nth-child(4) {
	text-align: center;
}

section.class_date table.rg_fee tr td:nth-child(5) {
	text-align: right;
}

section.class_date table.rg_day tr td:nth-child(n+4) {
	width: 8%;
}

section.class_date table.rg_day tr td:nth-child(3) {
	text-align: center;
}

section.class_date table tr,
section.class_date table th,
section.class_date table td  {
	border: 1px solid #e9e7e7;
	padding: .3rem .6rem;
	vertical-align: middle;
}

section.class_date table th {
	background-color: #00578a;
	color: #fff;
	text-align: center;
}

section.class_date table tr,
section.class_date table td  {
	background-color: #fff;
}

@media screen and (orientation: portrait) and (max-width: 767px){
	
	section.class_date {
	overflow-x: scroll;
	}
	
	section.class_date table.rg_fee {
		min-width: 680px;
	}
	
	section.class_date table.rg_day {
		min-width: 750px;
	}
	
}


/* RouteG(お茶ゼミ√＋)年間予定 annual_schedule
============================ */

.annual_schedule {
    display: flex;
    column-gap: 3rem;
}

.annual_schedule table {
    font-size: .8rem;
}

.annual_schedule table th,
.annual_schedule table td {
    border: 1px solid #555;
    padding: .2rem .5rem;
}

.annual_schedule table th {
    background-color: #841617;
    color: #fff;
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    .annual_schedule {
    display: block;
}
    
}


/* 夏期講習のご案内 summer_course
============================ */
#main_content > .summer_area {
    background-color: #FFF7D8;
    padding: 1rem 2rem 2rem;
}

#main_content > .summer_area > h3 {
    margin-bottom: 0rem;
}

.summer_course {
    margin: 0;
}

.summer_course .summer_ctable table {
    background-color: #fff;
    width: 100%;
    font-size: .7rem;
}

.summer_course .summer_ctable table th,
.summer_course .summer_ctable table td {
    border: 1px solid #555;
    padding: .2rem .5rem;
    vertical-align: middle;
}

.summer_course .summer_ctable table tr td:nth-last-child(3) {
    text-align: center;
}

.summer_course .summer_ctable table tr td:nth-of-type(1) {
    width: 20px;
}

.summer_course .summer_ctable table tr td:nth-of-type(2) {
    white-space: nowrap;    
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    #main_content > .summer_area {
    padding: 1rem 1rem 1rem;
}
    
    .summer_course {
        overflow-x: scroll;
    }
    
    .summer_course .summer_ctable table {
        width: 900px;
    }
}


/* 夏期講習のご案内 summer_course_2
============================ */

.summer_course_2 {
    margin: 0;
    overflow-x: scroll;
    display: block;
    max-width: 960px;
    -webkit-overflow-scrolling: touch;
}

.summer_course_2 .summer_ctable table {
    background-color: #fff;
    font-size: .7rem;
    width: 300%;
}

.summer_course_2 .summer_ctable table th,
.summer_course_2 .summer_ctable table td {
    border: 1px solid #555;
    padding: .1rem .3rem;
    vertical-align: middle;
}

.summer_course_2 .summer_ctable table tr th:nth-of-type(1) {
    width: 20px;
}

.summer_course_2 .summer_ctable table tr th:nth-of-type(2) {
     white-space: nowrap; 
    width: 170px;
}

.summer_course_2 .summer_ctable table tr th:nth-of-type(3) {
    width: 700px;
}

.summer_course_2 .summer_ctable table tr th:nth-of-type(8) {
    width: 850px;
}



@media screen and (orientation: portrait) and (max-width: 767px){
    
    .summer_course_2 .summer_ctable table {
    width: 400%;
}
    
    .summer_course_2 .summer_ctable table tr th:nth-of-type(3) {
    width: 500px;
}

.summer_course_2 .summer_ctable table tr th:nth-of-type(8) {
    width: 500px;
}
    

}



/* school_link
============================ */
.school_link .sl_t {
    text-align: center;
    margin-bottom: 3rem;
}

.school_link .sl_t h4 {
    font-size: 2.2rem;
    margin-bottom: 1rem;
}

.school_link .sl_t h4 span {
    color: #841617;
}

.school_link .sl_t h6 {
    font-size: 1.2rem;
    margin-bottom: 1rem;
}

.school_link .sl_t h5 {
    font-size: 2rem;
    margin-bottom: 1rem;
}


.school_link .sl_bt {
    display: flex;
    justify-content: center;
    column-gap: 4rem;
    margin-bottom: 4rem;
}

.school_link .sl_bt dl {
    width: 35%;
    text-align: center;
}

.school_link .sl_bt dl figure {
    margin-bottom: 1rem;
}

.school_link .sl_bt dl figure img {
    height: 30px;
}

.school_link .sl_bt dl dd a {
    height: 4rem;
    background: #ef717c;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 100%;
    border-radius: 1.8rem;
    color: #fff;
    font-weight: 900;
    font-family: var(--Font_Weight_Bold);
    font-size: 1.2rem;
    text-align: center;
    line-height: 1;
}

.school_link .sl_bt dl dd a::after {
    position: absolute;
    top: calc(50% - 10px);
    right: 15px;
    width: auto;
    height: auto;
    border: none;
    line-height: 1;
    font-weight: 900;
    font-family: var(--Font_Awesome);
    content: var(--Arrow_Right);
}

.school_link .sl_bt dl dd a:hover {
    opacity: .5;
}

.school_link .sl_t_2 {
    text-align: center;
}

.school_link .sl_t_2 h6 {
    font-size: 1.1rem;
    margin-bottom: .5rem;
}

.school_link .sl_t_2 h4 {
    font-size: 2rem;
    margin-bottom: 2rem;
}

.school_link .sl_t_2 figure a:hover {
    opacity: .5;
}

.school_link .sl_t_2 figure img {
    width: 350px;
}

.school_link .sl_t_2 figure p {
    font-size: 1.2rem;
    font-weight: bold;
    letter-spacing: .1rem;
}

@media screen and (orientation: portrait) and (max-width: 767px){
    

    .school_link .sl_bt {
    display: block;
    margin-bottom: 3rem;
}
    
    .school_link .sl_bt dl {
    width: 80%;
        margin: 0 auto 2rem;
}
    
    .school_link .sl_bt dl dt {
        font-size: .9rem;
    }
    
.school_link .sl_bt dl figure img {
    height: 22px;
}
    
    .school_link .sl_bt dl dd a {
    height: 3rem;
    font-size: 1rem;
    line-height: 1;
}
    
}


/* other_link
============================ */

.other_link {
    display: flex;
    justify-content: center;
    width: 80%;
    margin: 2rem auto;
    column-gap: 1rem;
}

.other_link a {
    width: 22%;
    text-align: center;
}

.other_link a img {
    height: 50px;
}

@media screen and (orientation: portrait) and (max-width: 767px){
    
    .other_link {
        flex-wrap:wrap;
    width: 98%;
    margin: 2rem auto;
}

.other_link a {
    width: 46%;
    margin-bottom: 1rem;
}
    
    .other_link a img {
    height: 42px;
}
    
}



/* contact
============================ */

.contact {
  padding: 2rem;
  background: var(--RouteG_Gray);
}

.contact h2 {
  border-bottom: 2px solid var(--RouteG_Red);
}

.contact ul {
  padding: 1rem 0;
}

.contact li {
  padding: .5rem 0 .5rem 1.8rem;
  padding-left: 1.8rem;
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
  text-indent: -1.8rem;
}

.contact li::before {
  padding-right: .6rem;
  color: var(--RouteG_Red);
  font-family: var(--Font_Awesome);
  font-weight: 900;
  content: "\f14a";
}

.contact div {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 1rem;
}

.contact div figure {
  width: 16rem;
}

.contact div figure img {
  width: 100%;
}

.contact div p {
  flex: 1;
  color: var(--RouteG_Red);
  font-weight: 900;
  font-size: 1.2rem;
  font-family: var(--Font_Weight_Bold);
}


@media screen and (orientation: portrait) and (max-width: 767px){

  .contact {
    width: 100% !important;
    padding: 1rem;
  }

  .contact h2 {
    font-size: 1.4rem !important;
  }

  .contact div {
    flex-direction: column;
    gap: 0;
    padding-top: 1rem;
  }

  .contact div figure {
    width: 60%;
  }

  .contact div p {
    font-size: 1rem;
  }

}



/* timetable_area
============================ */

.modaal_inner.link_wrap {
  border: none;
}

.modaal_inner.link_wrap h2 {
  color: var(--RouteG_Red);
  font-weight: 900;
  font-size: 1.6rem;
  font-family: var(--Font_Weight_Bold);
}


@media screen and (orientation: portrait) and (max-width: 767px){

  .modaal_inner.link_wrap h2 {
    font-size: 1.2rem;
  }

}



/* contact_banner
============================ */

.contact_banner.online:not(.floating_appli) .timetable_popup {
  display: none;
}

.contact_banner .phone_num li.phone_kichijoji {
    display: none;
}

.contact_banner.online .inner p.note {
  padding: 0 4% 2rem;
  font-size: 1rem;
}


@media screen and (orientation: portrait) and (max-width: 767px){

  .contact_banner.online .inner p {
    padding: 2rem 0 0;
    font-size: 1.3rem;
  }
  
  .contact_banner.online .inner p.note {
    font-size: .8rem;
  }

}