@charset "UTF-8";
/* Basic Layout */
html,
body {
	block-size:100%;
}
body {
	background-color:#fff;
}
html.mopen,
html.mopen body {
	/*overflow: auto;*/

	position: fixed;
/*	z-index: -1;*/
	inline-size: 100%;
	block-size: 100%;
}

#wrapper {
	block-size:auto;
	min-block-size:100%;
	position:relative;
}

/* 共通 */
.full {
	inline-size:100%;
}

/* ヘッダー部 */
header {
	padding:0;
	text-align:left;
	background-color: #fff;

	position:fixed;
	inset-inline-start: 0;
	inset-block-start: 0;
	z-index: 99;
	/*border-block-end: 1px solid #dcdcdc;*/
}
header .inner {
	block-size: 40px;
	position: relative;
	border: 0px solid;
}
#logo {
	inline-size: 268px;
	position: absolute;
	inset-block-start: 7px;
	inset-inline-start: 15px;

	font-weight:bold;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
	font-size:12px;
	display: block;
}
header #h_phone {
	display: none;
	position: absolute;
}
header #h_contact {
	display: none;
	position: absolute;
}


/* コンテナー */
main {
	clear:both;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
}


#bg {
	/*background-color:#fff;*/
	padding-block-start: 40px;
	padding-block-end: 24em; /* フッタの高さと合わせる */
}
/* フッタ部 */
footer {
	block-size: 24em; /* .bgの高さと合わせる */
	clear:both;
	position:absolute;
	inset-block-end:0;
	inline-size:100%;
	text-align:center;
	background-color:#fff;
	/*border-block-start: 1px solid #ececec;*/
}
footer .inner {
	padding-block-start: 60px;
}
footer .inner #flogo {
	inline-size: 190px;
	margin-inline: auto;
}


footer small {
	display: inline-block;
	text-align:center;
	font-style:normal;
	font-size:11px;
	color: #a1a1a1;
	/*margin-block-start:4em;*/
}

/* トップに戻る */
#btn_top {
	display: inline-block;
	inline-size: 50px;
	block-size: 50px;
	background-color: rgba(0,0,0,0.6);
	position: fixed;
	inset-inline-end: 5px;
	inset-block-end: 70px;
	border-radius: 100%;
	vertical-align: middle;
	z-index: 4;
}
#btn_top:after {
	content: '';
	inline-size: 12px;
	block-size: 12px;
	border-block-start: 4px solid #fff;
	border-inline-end: 4px solid #fff;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	border-radius: 2px;
	position: absolute;
	inset-block-start: 42%;
	inset-inline-start: 0;
	inset-inline-end: 0;
	margin-inline: auto;
}
#btn_top span {
	visibility: hidden;
}

/* spボタン */
#btn_sp {
	display: block;
	position: fixed;
	left: 0;
	bottom: 0;
	background-color: #fff;
	padding-block: .6em;
	z-index: 2;
}
#btn_sp a {
	display: block;
	width: 90%;
	margin-inline: auto;
}


/* メディア判定 */
.sp {
	display: block;
}
.tbs {
	display: none;
}
.tb {
	display: none;
}
.pc {
	display: none;
}


br.sbr {
	display: inline-block;
}










@media handheld, print, screen and (min-width: 480px) {

/* ヘッダー部 */
header .inner {
	block-size: 50px;
}
#logo {
	inline-size: 300px;
	inset-block-start: 10px;
	inset-inline-start: 20px;
}

#bg {
	padding-block-start: 50px;
	padding-bottom: 16em; /* フッタの高さと合わせる */
}
/* フッタ部 */
footer {
	block-size: 16em; /* .bgの高さと合わせる */
}
footer .inner {
	padding-block-start: 40px;
}
footer .inner #flogo {
	inline-size: 220px;
}


/* トップに戻る */
#btn_top {
	inline-size: 60px;
	block-size: 60px;
	inset-inline-end: 10px;
	inset-block-end: 40px;
}
#btn_top:after {
	inline-size: 16px;
	block-size: 16px;
	border-block-start: 5px solid #fff;
	border-inline-end: 5px solid #fff;
	inset-block-start: 42%;
}

/* spボタン */
#btn_sp {
	padding-block: .6em;
}
#btn_sp a {
	width: 60%;
}

/* メディア判定 */
.sp {
	display: none;
}
.tbs {
	display: block;
}
.tb {
	display: none;
}
.pc {
	display: none;
}

br.sbr {
	display: none;
}

/* end of media query */	
}




@media handheld, print, screen and (min-width: 620px) {
/* iPad */

/* ヘッダー部 */
header .inner {
	block-size: 60px;
}
#logo {
	inline-size: 331px;
	inset-block-start: 15px;
	inset-inline-start: 20px;
}


#bg {
	padding-block-start: 60px;
	padding-block-end: 14em; /* フッタの高さと合わせる */
}
/* フッタ部 */
footer {
	block-size: 14em; /* .bgの高さと合わせる */
}
footer .inner {
	padding-block-start: 50px;
}
footer .inner #flogo {
	inline-size: 258px;
}

/* トップに戻る */
#btn_top {
	inline-size: 60px;
	block-size: 60px;
	inset-inline-end: 10px;
	inset-block-end: 40px;
}
#btn_top:after {
	inline-size: 18px;
	block-size: 18px;
	border-block-start: 5px solid #fff;
	border-inline-end: 5px solid #fff;
	inset-block-start: 42%;
}

/* spボタン */
#btn_sp {
	display: none;	
}

/* メディア判定 */
.sp {
	display: none;
}
.tbs {
	display: none;
}
.tb {
	display: block;
}
.pc {
	display: none;
}



/* end of media query(iPad) */	
}






@media handheld, print, screen and (min-width: 900px) {

/* ヘッダー部 */
header .inner {
	block-size: 70px;
}
#logo {
	inline-size: 414px;
	inset-block-start: 17px;
	inset-inline-start: 20px;
}
header #h_phone {
	display: block;
	inline-size: 205px;
	inset-inline-end: 223px;
	inset-block-start: 18px;
}
header #h_contact {
	display: block;
	inline-size: 181px;
	inset-inline-end: 20px;
	inset-block-start: 12px;
}

#bg {
	padding-block-start: 70px;
	padding-block-end: 20em; /* フッタの高さと合わせる */
}
/* フッタ部 */
footer {
	block-size: 20em; /* .bgの高さと合わせる */
}
footer .inner {
	padding-block-start: 60px;
}
footer .inner #flogo {
	inline-size: 323px;
}


/* トップに戻る */
#btn_top {
	inline-size: 70px;
	block-size: 70px;
	inset-inline-end: 10px;
	inset-block-end: 70px;
}
#btn_top:after {
	inline-size: 18px;
	block-size: 18px;
	border-block-start: 5px solid #fff;
	border-inline-end: 5px solid #fff;
	inset-block-start: 42%;
}


/* メディア判定 */
.sp {
	display: none;
}
.tbs {
	display: none;
}
.tb {
	display: none;
}
.pc {
	display: block;
}



/* end of media query */
}


@media handheld, print, screen and (min-width: 1100px) {

/* ヘッダー部 */
header .inner {
	block-size: 70px;
}
#logo {
	inset-inline-start: 27px;
}
header #h_phone {
	inset-inline-end: 237px;
}
header #h_contact {
	inset-inline-end: 34px;
}

/* end of media query */	
}

