.purple {
 color: #BC79BC;
}
.bg_purple {
 background: #DCCCE3;
 }
#main .detail_link {
    float: right;
    background-image: url(../images/main_icn_arrow2.gif);
    background-repeat: no-repeat;
    padding-left: 17px;
    background-position: left center;
} 
#main h4 {
 font-size: 115%;
 background-image: url(../../course_senior/images/icon_purplecube.gif);
 background-repeat: no-repeat;
 background-position: left top;
 border-bottom: 1px dotted #999999;
 padding-left: 25px;
 padding-bottom: 5px;
 vertical-align: middle;
 line-height: 1.3em;
 margin-bottom: 10px;
}
#sidebar ul#sub li {
 margin: 0px;
 padding: 0px 0px 5px;
}
#top_menu {
 margin-bottom: 20px;
}

#charmlist {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#charmlist li {
	border: solid 1px #555;
	float: left;
	font-weight: bolder;
	margin: 10px 0;
	padding: 0;
	width: 48.5%;
}

.charm_ttl p {
	background-color: #ffcc33;
	padding: 8px 5px 8px 0;
	min-height: 3.5em;
}
.ch_number {
	line-height: 1em;
	float: left;
	padding-top: 8px;
	margin-right: 5px;
	text-align: center;
	width: 25px;
	height: 25px;
	display: inline-block;
	vertical-align: middle;
	font-size: 18px;
	background-color: #FFFFFF;
	margin-top: 5px;
}
.charm2 p {
	margin: 10px;
	font-weight: 100;
	font-size: 90%;
}
.charm2 img {
	width: 94%;
	margin: 3% 3% 0;
}



.ch_message img {
 float: left;
 padding-right: 10px;
 padding-bottom: 10px;
 clear: both;
}

.ch_message {
 margin-bottom: 15px;
 clear: both;
 }
.border {
 border-bottom: 1px solid #999999;
 padding-bottom: 14px;
 }
#request th {
 border-right: 1px solid #999999;
 border-bottom: 1px solid #999999;
 padding: 10px;
 font-size: 90%;
}
#request th.sub {
 text-align: left;

}
#request th.sub img {
 float: left;
 margin-right: 5px;
 width: 20px;
 vertical-align: middle;
 }
.teacher_text {
 clear: both;
 margin-bottom: 14px;
 padding-bottom: 15px;
 border-bottom: 1px solid #ccc;
}
.teacher_text .pctb_float_left{
 margin-top: 0;
 margin-bottom: 0;
 width: 200px;
 }
.flowbox {
 clear: both;
 border: 3px solid #006;
 border-radius: 10px;        /* CSS3草案 */
 -webkit-border-radius: 10px;    /* Safari,Google Chrome用 */
 -moz-border-radius: 10px;   /* Firefox用 */
 padding: 10px;
 margin-top: 10px;
 margin-bottom: 10px;
 }
.flowbox p {
 margin-bottom: 10px;
 }
.flow_right {
 float: right;
 width: 296px;
 background: #FFFDE5;
 padding: 5px;
 margin-bottom: 10px;
 }
.flowbox ul li {
 padding-left: 2px;
 font-size: 92%;
 }
.flowbox ul li:before {
 content: "●";
 padding-left: 5px;
 color: #F8B62D;
 padding-right: 5px;
 }
.last {
 content: none;
}
.center {
 text-align: center;
 margin-bottom: 10px;
}
#main ul.pageNav01 {
	margin: 0 0 10px;
	padding: 12px;
	text-align: center;
}

#main ul.pageNav01 li {
	display: inline;
	margin: 0 1px;
	padding: 0;
}

#main ul.pageNav01 li span,
#main ul.pageNav01 li a {
	display: inline-block;
	padding: 1px 8px;
	background: #fff;
	border: 1px solid #ccc;
	vertical-align: middle;
	text-decoration: none;
}

#main ul.pageNav01 li a:hover {
	background: #efefef;
}
#main ul.pageNav01 li span.current {
 background: #CCFFFF;
 }


@media screen and (max-width:600px){
#charmlist {
	display: block;
}
#charmlist li {
	margin-bottom: 15px;
	width: 100%;
}
.charm_ttl p {
	padding: 8px 8px 8px 0;
	min-height: inherit;
}
.ch_number {
	margin-top:0;
	padding: 3px;
	height:auto;
}
.charm2 img {
	width: 100%;
	margin: 0;
}

#main .flowbox .pht_left {
 width: 35%;
 }
#main .flowbox .pht_left img{
 width: 100%;
}
.flow_right {
 float: right;
 width: 60%;
 margin-bottom: 10px;
}
 }
