@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: transparent;

	position:fixed;
	inset-inline-start: 0;
	inset-block-start: 0;
	z-index: 99;
	transition: all 300ms 0s ease;
	/*border-block-end: 1px solid red;*/
}
header.scr {
	background-color: #fff;
}
header .inner {
	block-size: 54px;
	position: relative;
	border: 0px solid;
}
#logo {
	inline-size: 170px;
	position: absolute;
	inset-block-start: 3px;
	/*inset-inline-start: 10px;*/
	inset-inline-start: 10px;

	font-weight:bold;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
	font-size:12px;
	display: block;
}

header #h_contact {
	display: none;
	inline-size: 250px;
	position: absolute;
	inset-inline-end: 20px;
	inset-block-start: 14px;
}

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


#bg {
	/*background-color:#fff;*/
	padding-block-start: 54px;
	padding-block-end: 12em; /* フッタの高さと合わせる */
}
/* フッタ部 */
footer {
	block-size: 12em; /* .bgの高さと合わせる */
	clear:both;
	position:absolute;
	inset-block-end:0;
	inline-size:100%;
	text-align:center;
	background-color:#1f1f1f;
	color: #fff;
	/*border-block-start: 1px solid #ececec;*/
}
footer .inner {
	padding-block-start: 30px;
}
footer #flogo {
	font-size: 14px;
	font-weight: normal;
	line-height: 1.4;
	color: #fff;
	text-align: center;
}

footer small {
	display: inline-block;
	text-align:center;
	font-style:normal;
	font-size:11px;
	margin-block-start:2em;
}

/* トップに戻る */
#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: 60px;
	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: grid;
	place-items: center;
	inline-size: 100%;
	position: fixed;
	inset: auto auto 0 0;
	background-color: #173185;
	padding-block: .9em;
	z-index: 2;
    transition: all 0.3s ease;
}
#btn_sp a {
	display: block;
	inline-size: 240px;
}


/* メディア判定 */
.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 */
header .inner {
	block-size: 56px;
}
#logo {
	inline-size: 175px;
	inset-block-start: 3px;
	inset-inline-start: 10px;
}

#bg {
	padding-block-start: 0px;
	padding-bottom: 13em; /* フッタの高さと合わせる */
}
/* フッタ部 */
footer {
	block-size: 13em; /* .bgの高さと合わせる */
}

footer .inner {
	padding-block-start: 40px;
}
footer #flogo {
	font-size: 16px;
}

footer small {
	font-size:12px;
}

/* トップに戻る */
#btn_top {
	inline-size: 60px;
	block-size: 60px;
	inset-inline-end: 10px;
	inset-block-end: 60px;
}
#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ボタン */


/* メディア判定 */
.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 */
header .inner {
	block-size: 68px;
}
#logo {
	inline-size: 212px;
	inset-block-start: 3px;
	inset-inline-start: 10px;
}
header #h_contact {
	display: block;
	inline-size: 200px;
	position: absolute;
	inset-inline-end: 20px;
	inset-block-start: 10px;
}

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

/* トップに戻る */
#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 */
header .inner {
	block-size: 86px;
}
#logo {
	inline-size: 265px;
	inset-block-start: 5px;
	inset-inline-start: 10px;
}
header #h_contact {
	display: block;
	inline-size: 250px;
	position: absolute;
	inset-inline-end: 20px;
	inset-block-start: 14px;
}


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

/* トップに戻る */
#btn_top {
	inline-size: 70px;
	block-size: 70px;
	inset-inline-end: 10px;
	inset-block-end: 50px;
}
#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: 1220px) {

#logo {
	inset-inline-start: calc((100vw / 2) - 600px);
}


/* end of media query */	
}

