@charset "utf-8";
/*==================================================
	スマホのみに適用
==================================================*/
@media only screen and (max-width: 640px){
	body { font-size: 85%; }
	.dsp_hp, .dsp_hpt { display: none; }
	#header .contact a {
		font-size: 14px;
	}
	#header .contact .tel a span {
		width: 5px;
		height: 1px;
		margin: 0 2px;
	}
	#header .contact .tel a img {
		width: 16px;
		top: 2px;
	}
	#header .contact .btn a img {
		width: 18px;
	}
	#header h1.title img {
		max-height: none;
		width: 250px;
		position: absolute;
		top: 5px;
		left: 5px;
	}
	/* コンテナ */
	#wrap, #footer {
		min-width: 320px;
	}
	#container h3.sub,#container h3.sub02 {
		margin-bottom: 20px;
		font-size: 18px;
		letter-spacing: normal;
	}
	#container h3.sub span,#container h3.sub02 span {
		font-size: 23px;
		padding: 0;
	}
	#container h3.sub03 {
		text-shadow: rgb(230, 182, 0) 1px 0px 0px, rgb(230, 182, 0) 0.540302px 0.841471px 0px, rgb(230, 182, 0) -0.416147px 0.909297px 0px, rgb(230, 182, 0) -0.989992px 0.14112px 0px, rgb(230, 182, 0) -0.653644px -0.756802px 0px, rgb(230, 182, 0) 0.283662px -0.958924px 0px, rgb(230, 182, 0) 0.96017px -0.279415px 0px;
		margin-bottom: 20px;
	}
	#container h4.sub {
		margin-bottom: 20px;
		font-size: 18px;
		letter-spacing: normal;
	}
	#container h4.sub02 {
		font-size: 16px;
		margin-bottom: 20px;
	}
	#container h4.sub02 span {
		font-size: 20px;
	}
	#container h4.sub03 {
		font-size: 20px;
	}
	/* フッター */
	#footer .contact .tel a {
		font-size: 30px;
	}
	#footer .box dt img {
		width: 130px;
	}
	#copyright {
		height: auto;
		line-height: 1.6;
		padding: 5px 0;
	}
	/* 枠のマージン・パディング */
	.mb { margin-bottom: 30px; }
	.pt { padding-top: 30px; }
	.pb { padding-bottom: 30px; }
	

	/*--------------------------------------------------
		トップページ
	--------------------------------------------------*/
	#top_msg .txt {
		font-size: 16px;
		letter-spacing: normal;
	}
	#top_material::before {
		height: 100%;
		background-position: top center;
	}
	#top_material .material_box .box {
		width: 48%;
		margin-bottom: 30px;
	}
	#top_material .material_box .box .txt_box {
		font-size: 14px;
	}
	#yellow_box .yellow_box .txt {
		background: #EECC4C;
		padding: 10px 0;
	}
	#yellow_box .yellow_box .txt span {
		font-size: 18px;
	}
	@media only screen and (max-width: 320px) {
		#yellow_box .yellow_box  .txt.img {
			padding-left: 50px;
		}
	}
	#yellow_box .yellow_box .txt.img {
		position: relative;
	}
	#yellow_box .yellow_box .txt.img::before {
		content: "";
		background: url("../img/top/bg03-smt.png") no-repeat bottom left/100%;
		width: 90px;
		height: 95px;
		position: absolute;
		bottom: 0;
		left: 20px;
	}
	#top_revenue .box {
		flex-direction: column-reverse;
	}
	#top_revenue .box.reverse {
		flex-direction: column;
	}
	#top_revenue .box .txt_box, #top_revenue .box .img_box, #top_revenue .box.reverse .img_box {
		width: 100%;
	}
	#top_revenue .box .img_box,#top_revenue .box.reverse .img_box {
		position: relative;
	}
	#top_revenue .box .txt_box {
		margin-top: 0;
	}
	#top_revenue .box .txt_box .ttl,#top_revenue .box .txt_box .price {
		font-size: 18px;
	}
	@media only screen and (max-width: 320px) {
		#top_revenue .box .txt_box .txt {
			font-size: 12px;
		}
	}
	#top_revenue .box .txt_box .arrow {
		position: relative;
		top: -5px;
	}
	#top_obi_cha {
		display: block;
		font-size: 18px;
		min-height: auto;
		padding: 15px 0;
	}
	#top_obi_cha span {
		font-size: 25px;
		top: 0;
	}
	#cost_price .cost_price_box .img_box {
		width: 100%;
		text-align: center;
		margin-bottom: 20px;
	}
	#cost_price .cost_price_box .txt_box li {
		font-size: 16px;
		margin-bottom: 10px;
	}
	#cost_price .cost_price_box .txt_box li span {
		border-bottom: 2px solid #E6B600;
		display: inline;
	}
	#cost_price .cost_price_box .txt_box li span::before {
		display: none;
	}
	#top_voice .box {
		display: block;
	}
	#top_voice .box .img_box,#top_voice .box .txt_box {
		width: 100%;
	}
	#top_voice .box .img_box {
		text-align: center;
	}
	#top_voice .box .img_box img {
		width: 100px;
	}
	#top_voice .box .txt_box .txt {
		font-size: 14px;
	}
	#top_voice .box .txt_box .y_line {
		font-size: 18px;
	}
	#top_voice .box .txt_box .name {
		font-size: 12px;
	}
	#top_benefits .benefits_bg::before {
		width: 135px;
		height: 233px;
	}
	#top_benefits .white_box ul:first-of-type {
		margin-right: 50px;
	}
	#top_benefits .white_box li {
		font-size: 14px;
	}
	#top_benefits .white_box li::before {
		top: 5px;
	}
	#top_benefits .white_box {
		padding: 15px;
	}
	#top_flow .flow_box .txt_box .box {
		justify-content: space-between;
	}
	#top_flow .flow_box .txt_box .box .step {
		margin-right: 0;
		font-size: 14px;
	}
	#top_flow .flow_box .txt_box .box .step span {
		font-size: 18px;
		letter-spacing: normal;
	}
	#top_flow .flow_box .txt_box .box .txt {
		width: 68%;
		font-size: 14px;
	}
	#contact .obi {
		padding: 15px;
	}
	#contact .obi .txt {
		font-size: 18px;
	}
	#contact .obi .txt span {
		font-size: 14px;
	}
	#contact .top_sample .txt {
		text-align: left;
	}
	#top_bottom {
		padding-bottom: 50px;
	}
	#top_bottom::before {
		width: 80%;
	}
	#top_bottom .img_box {
		width: 100%;
		text-align: center;
	}
	#top_bottom .img_box img {
		width: 150px;
	}
	#top_bottom .txt_box {
		width: 100%;
	}
	#top_bottom .txt_box .txt {
		font-size: 14px;
		line-height: 1.8em;
	}
	#top_bottom .txt_box .txt span {
		font-size: 16px;
	}
	#top_bottom .txt_box .txt .big {
		font-size: 20px;
	}
	#top_bottom .txt_box .txt .dsp_smt.lh_2 {
		display: block;
		height: 2.0rem;
	}
	#top_bottom_msg p {
		font-size: 18px;
	}
	/*--------------------------------------------------
		サブページ
	--------------------------------------------------*/

	/*--------------------------------------------------
		サブページ
	--------------------------------------------------*/
	
	/*--------------------------------------------------
		サブページ
	--------------------------------------------------*/
	
/*------------------------------------------------*/
	#mailform .btn input {
		font-size: 14px;
		letter-spacing: normal;
		width: 280px;
		line-height: 1.8em;
		line-height: 60px;
		margin: 15px 0;
	}
}
