@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 {
	display: block;
	block-size:100%;
	min-block-size:100%;
	position:relative;

/*	border: 5px solid #000;*/
}

#wrapper #primary {
/*	max-width: 1040px;*/
	position: relative;
	background-color: #dbe2ff;
	border: 1px solid blue;
}
#wrapper #secondary {
	height: 100%;
	width: 400px;

	position: absolute;
	inset-block-start: 0;
	inset-inline-end: -420px;

	transition: all 300ms 0s ease;

	background-color: #ffdbdb;
	border: 1px solid red;
}
#wrapper #secondary .inner {
	position: sticky;
	inset-block-start: 0;
	inset-inline-start: 0;
}
#wrapper #secondary .form_test {
	border: 1px solid #000;
	inline-size: 360px;
	margin-inline: auto;
	background-color: #f5e1f4;
}
#wrapper #secondary #fcheck {
	display: block;
	width: 100px;
	border: 1px solid #fff;
	background-color: #fff;
	padding: 1em 0 1em 1em;

	position: absolute;
	inset-block-start: 100px;
	inset-inline-start: -100px; 
}

#wrapper #secondary:has(#fcheck_ck:checked) {
	inset-inline-end: 0;
}


#wrapper #primary main .row-inner {
	border: 1px solid #000;
}






/* 共通 */
.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: 80px;
	position: relative;
	border: 0px solid;
}
#logo {
	inline-size: 162px;
	position: absolute;
	inset-block-start: 3px;
	inset-inline-start: 10px;

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

header #h_contact {
	display: none;
	inline-size: 180px;
	position: absolute;
	inset-inline-end: 15px;
	inset-block-start: 7px;
}

#css3_nav {
	border-bottom: 1px solid #dcdcdc;
	padding-block: 1em;
}
#css3_nav ul {
	padding-inline-start: .5em;
}
#css3_nav li {
	list-style-type: disc;
}

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


#bg {
	/*background-color:#fff;*/
	padding-block-start: 0;
	padding-block-end: 10em; /* フッタの高さと合わせる */
}
/* フッタ部 */
footer {
	block-size: 10em; /* .bgの高さと合わせる */
	clear:both;
	position:absolute;
	inset-block-end:0;
	inline-size:100%;
	text-align:center;
	background-color:#e5e6d2;
}
footer .inner {
	padding-block-start: 30px;
}


footer small {
	display: inline-block;
	text-align:center;
	font-style:normal;
	font-size:11px;
/*	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: 90px;
	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) {



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


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














/* トップに戻る */
/*#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: 1049px) {

#wrapper {
	display: grid;
	grid-template-columns: auto 400px;
	grid-template-rows: auto;

/*	max-inline-size: 1440px;*/
	block-size:auto;
	min-block-size:100%;
	position:relative;

	border: 5px solid #000;
}

#wrapper #primary {
/*	max-width: 1040px;*/
	
	width: 100%;
	position: relative;
	background-color: #dbe2ff;
	border: 1px solid blue;
}
#wrapper #secondary {
	height: 100%;
	width: 400px;

	position: relative;
	inset-block-start: auto;
	inset-inline-end: auto;




	background-color: #ffdbdb;
	border: 1px solid red;
}
#wrapper #secondary .inner {
	position: sticky;
	inset-block-start: 0;
	inset-inline-start: 0;
}
#wrapper #secondary .form_test {
	border: 1px solid #000;
	inline-size: 360px;
	margin-inline: auto;
	background-color: #f5e1f4;
}
#wrapper #secondary #fcheck {
	display: none;
}


#wrapper #primary main .row-inner {
	border: 1px solid #000;
}


/* end of media query */	
}

