body{
	background-color:#fff;
	color:#333;
font-family:'Roboto','Hiragino Sans','Meiryo','Hiragino Kaku Gothic ProN',sans-serif;
font-size:16px;font: size 1.2em;rem;line-height:1.8;
}
article{
    padding-bottom: 20px;
}
 h2{
    background-color: #f12535;
    color: #fff;
    text-align: center;
    font-size: 2.0em;
    margin:0 0 30px 0;
    padding: 25px;
    font-weight: bold;
}
section{
    width: 1000px;
    margin: 0 auto 40px;
}
section img{
    width: 100%;
}
#main_title {
    margin: 30px 0 20px;
}
#main_title span{
    color: #f12535;
    background: #fff4f5;
    border-radius: 8px;
    font-weight: bold;
    padding: 8px 15px;
}
#main_title h1{
    font-size: 1.9em;
    font-weight: bold;
}
h3{
    font-size: 1.6em;
    font-weight: bold;
    margin-bottom: 10px;
}

h4.title01 {
border-bottom: solid 4px #f12535; 
position: relative;
color: #f12535;
font-size: 1.8em;
font-weight: bold;
margin-bottom: 25px;
padding-bottom: 5px;
}
h4.title01:after {
position: absolute;
content: " ";
display: block;
border-bottom: solid 4px #ffb5bb;
bottom: -4px;
width: 35%;
}

h4.title02 {
border-bottom: solid 4px #f12535; 
position: relative;
color: #f12535;
font-size: 1.8em;
font-weight: bold;
margin-bottom: 25px;
padding-bottom: 5px;
}
h4.title02:after {
position: absolute;
content: " ";
display: block;
border-bottom: solid 4px #ffb5bb;
bottom: -4px;
width: 13%;
}
h4.title03 {
    border-bottom: solid 4px #f12535; 
    position: relative;
    color: #f12535;
    font-size: 1.8em;
    font-weight: bold;
    margin-bottom: 25px;
    padding-bottom: 5px;
}
h4.title03:after {
    position: absolute;
    content: " ";
    display: block;
    border-bottom: solid 4px #ffb5bb;
    bottom: -4px;
    width: 15%;
}
h4.title04 {
    border-bottom: solid 4px #f12535; 
    position: relative;
    color: #f12535;
    font-size: 1.8em;
    font-weight: bold;
    margin-bottom: 25px;
    padding-bottom: 5px;
}
h4.title04:after {
    position: absolute;
    content: " ";
    display: block;
    border-bottom: solid 4px #ffb5bb;
    bottom: -4px;
    width: 18%;
}

#attention{
	padding:15px;
	border:3px solid #0052a6;
	color:#0052a6;
	font-weight:bold;
	text-align:center;
}
.contents {
    font-weight: bold;
    font-size: 1.1em;
}
.contents span{
    background-color: #ffd6d8;
    padding: 2px 0;
}
.list{
    overflow: hidden;
    margin-top: 15px;
}
.list_left{
    width: 2%;
    float: left;
    color: #f12535;
    font-size: 1.9em;
    padding: 0 10px 0 0;  
}
.list_right{
    width: 96%;
    float: right;
}

.list_main{
    font-weight: bold;
    font-size: 1.4em;
    padding: 5px 0;
}
#teacher{
    overflow: hidden;
}
#teacher_left{
    width: 30%;
    float: left;
}
#teacher_right{
    width: 68%;
    float: right;
}
.teacher_in{
    padding: 10px;
    border-bottom: 1px solid #ccc;
}
.teacher_name{
    font-weight: bold;
    font-size: 1.1em;
    margin-bottom: 10px;
}
.teacher_name span{
    font-size: 1.3em;
}
.teacher_detail{
    font-size: 0.8em;
}
#contact_com{
    font-weight: bold;
    font-size: 1.1em;
}
#contact_com span{
    font-size: 80%;
}

.overview {
    background: #F5F5F5;
    padding: 30px;

}
.overview table{
    border-collapse: collapse;
    table-layout: fixed;
    width: 100%; /* table幅を100%に指定 */
    border: none;
    margin: 0 auto;
    font-size: 1.1em;
}
.overview table th,
.overview table td {
    display: block; /* セルをブロック要素に指定 */
    width: 100%; /* セルを親要素いっぱいの幅に指定 */
    border: none;
    padding: 10px;
    vertical-align: top;
    text-align: left;
    box-sizing: border-box;
}
.overview table th {
    font-weight: 700;
}

a.btn {
	display: block;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	width: 200px;
	margin: 0 auto 30px;
	padding: 1rem 4rem;
	font-weight: bold;
	border: 2px solid #cc3294;
	background: #cc3294;
	color: #fff;
	border-radius: 100vh;
	transition: 0.5s;
    font-size: 1.2em;
}

a.btn:hover {
	color: #cc3294;
	background: #fff;
}


.program{
    font-weight: bold;
}
.program th {
    background: #f12535;
    color: #fff;
    padding: 10px 20px;
    font-weight: bold;
    text-align: center;
    }
.program td {
    padding: 5px 0;
    font-size: 1.2em;
}
.program td span{
    font-weight: normal;
    font-size: 0.8em;
}
table.program {
    border-spacing: 20px 15px;
}

.br-sp {
    display: none;
}


@media screen and (max-width: 640px) {
    .br-sp {
        display: block;
    }
    h2{
        font-size: 1.3em;
    }
    section{
        width: 90%;
    }
    #main_title h1{
        font-size: 1.3em;
    }
    h3{
        font-size: 1.2em;
    }
    h4.title01,h4.title02,h4.title03,h4.title04 {
        font-size: 1.3em;
    }
    #teacher_left {
        width: 50%;
    }
    #teacher_right{
        width: 100%;
    }
    #teacher_name{
        font-size: 0.8em;
        padding-top: 10px;
    }
    #teacher_name span{
        font-size: 1.0em;
    }
    .list_main{
        font-size: 1.2em;
    }
    .list_right{
        width: 86%;
    }
    .last td:last-child {
        width: 100%;
    }
    #teacher_name{
    font-weight: bold;
    font-size: 1.2em;
    margin-bottom: 10px;
}
#teacher_name span{
    font-size: 1.3em;
}
    .program {
        width: 100%;
    }
    .program th,
    .program td {
        border-bottom: none;
        display: block;
    }
    table.program {
        border-spacing: 0 15px;
    }
    a.btn {
        display: block;
        text-align: center;
        vertical-align: middle;
        text-decoration: none;
        width: 200px;
        margin: 0 auto 30px;
        padding: 1rem 2rem;
        font-weight: bold;
        border: 2px solid #f12535;
        background: #f12535;
        color: #fff;
        border-radius: 100vh;
        transition: 0.5s;
        font-size: 1.2em;
    }
}

@media screen and (min-width: 768px) {
    .overview table th,
    .overview table td {
        display: table-cell; /* デフォルト値に指定 */
        border-bottom: 1px solid #ccc;
        color: #000;
    }
    .overview table th {
        color: #000;
    }
    .overview table tr th:first-child {
        width: 150px; /* thの固定幅 */
    }
}