/*==================================================
	スマホのみに適用
==================================================*/
@media only screen and (max-width: 640px){
	body { font-size: 85%; }
	.dsp_hp, .dsp_ta, .dsp_hpt { display: none; }

	/* ヘッダ */
	#header p.title img {
		max-height: 9.8vw;
		height: 47px;
	}
	#page_title .top_title {
		width: 45%;
		right: 0;
	}
	/* コンテナ */
	#wrap, #footer {
		min-width: 320px;
	}
	#container h3.sub {
		padding-bottom: 13px;
		font-size: 18px;
	}
	/* お問合せ */
	#footer .contact {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		flex-flow: column;
	}
	#footer .contact p+p {
		margin-left: 0;
		margin-top: 15px;
	}
	#footer .contact a {
		display: inline-block;
		width: 240px;
		box-sizing: border-box;
		padding: 9px 0 8px;
	}
	/* フッター */
	#footer .box dl dt {
		margin-bottom: 15px;
	}
	#footer .box dl dt img {
		max-height: 22.5vw;
	}
	#footer .box dl dd .txt {
		font-size: 11px;
		line-height: 1.8em;
	}
	#footer .box dl dd .txt+.txt {
		margin-top: 5px;
		display: block;
	}
	#footer .box .txt_c {
		font-size: 14px;
		margin-bottom: 10px;
	}
	/* コピーライト */
	#copyright {
		font-size: 10px;
		height: auto;
		line-height: normal;
	}
	/* 枠のマージン・パディング */
	.mb { margin-bottom: 30px; }
	.pt { padding-top: 30px; }
	.pb { padding-bottom: 30px; }
	/*--------------------------------------------------
		トップページ
	--------------------------------------------------*/
	/* ごあいさつ */
	#greeting {
		padding-bottom: 40px;
		background-size: 30px, 25px;
		background-position: bottom left 20px, bottom right 20px;
	}
	#greeting h3.sub {
		font-size: 20px;
		padding-bottom: 17px;
		margin-bottom: 10px;
		background-size: 100px;
	}
	#greeting .txt {
		line-height: 2em;
		margin-bottom: 0;
	}
	/* メニューコンテンツ */
	#top_menu .in {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		flex-flow: column;
	}
	#top_menu dl {
		width: 286px;
		margin: auto;
	}
	#top_menu dl+dl {
		margin-top: 40px;
	}
	#top_menu h3.sub {
		padding-bottom: 0;
		margin-bottom: 8px;
	}
	#top_menu dl dd .txt {
		min-height: auto;
	}
	/* お知らせ */
	#top_info h3.sub {
		background-size: 190px;
	}
	#top_info dt {
		float: none;
		width: auto;
	}
	#top_info dd {
		margin-left: 0;
	}
	
	/*--------------------------------------------------
		クラス紹介
	--------------------------------------------------*/
	#class .wrap {
		display: block;
	}
	#class .wrap.w3 {
		margin-bottom: 15px;
	}
	#class .wrap.w3 dl, #class .wrap.w2 dl {
		width: 100%;
		margin-bottom: 15px;
	}
	#class .wrap.w3 dl:last-of-type {
		margin-bottom: 0;
	}
	#class table tr th, #class table tr td {
		padding: 3px;
		font-size: 90%;
	}
	#class .txt{
		margin-bottom: 20px;
	}
	#class dl.radius {
		padding: 10px;
		display: block;
	}
	#class dl.radius dt, #class dl.radius dd {
		display: block;
	}
	#class dl.radius dt {
		margin-bottom: 10px;
	}
	#class dl.radius dd {
		padding-left: 0;
	}
	#class .presentation .bg_white {
		padding: 15px;
		text-align: left;
	}

/*------------------------------------------------*/
}
