@charset "utf-8";
/*=================================
1: reset-CSS
2: setting
3: header
4: footer
5: common-content
6: top page
7: second page
=================================*/


/* 1: reset-CSS
================================== */
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
	font-weight: normal;
}
body {
	line-height:1;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section,main {
	display:block;
}
li {
	list-style:none;
}
blockquote, q {
	quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content:'';
	content:none;
}
a {
	margin:0;
	padding:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

/* change colours to suit your needs */
ins {
	background-color:#ff9;
	color:#000;
	text-decoration:none;
}

/* change colours to suit your needs */
mark {
	background-color:#ff9;
	color:#000;
	font-style:italic;
	font-weight:bold;
}

del {
	text-decoration: line-through;
}
abbr[title], dfn[title] {
	border-bottom:1px dotted;
	cursor:help;
}
table {
	border-collapse:collapse;
	border-spacing:0;
}

/* change border colour to suit your needs */
hr {
	display:block;
	height:1px;
	border:0;
	border-top:1px solid #cccccc;
	margin:1em 0;
	padding:0;
}
input, select {
	vertical-align:middle;
}


	.sp_show {
		display: none !important;
	}

/* 2: setting
================================== */
*, *:before, *:after {
	box-sizing: border-box;
}

/* clearfix*/
.cf:after { content: ""; clear: both; display: block; }
.clear { clear: both;}

html {
	overflow: auto;
	font-size: 62.5%;
}
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700&family=Noto+Serif+JP:wght@400;500;600;700&family=Roboto:wght@400;500;700&display=swap');

body {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	color: #323232;
	font-size: 17px;
	font-size: 1.7rem;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
	min-width:1050px;
	word-wrap: break-word;
	overflow-wrap: break-word;
}
img {
	display: block;
	line-height: 0;
}
input[type="submit"],
input[type="button"] {
border-radius: 0;
-webkit-box-sizing: content-box;
-webkit-appearance: button;
appearance: button;
border: none;
box-sizing: border-box;
cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
outline-offset: -2px;
}

/* link */
a {
	color: #0000cc;
	-webkit-transition: all .2s;
	transition: all .2s;
}
a:hover {
	color: #1ba3f9;
	text-decoration: underline;
}
a img {
	-webkit-transition: all .2s;
	transition: all .2s;
}
a img:hover {
	opacity:.7;
}
a.hovre_line:hover {
	text-decoration: underline;
}

.sp {display:none;}



/* 3: header
================================== */
#wrapper {
	width:100%;
	position:relative;
	overflow: hidden;
}
#header {
	position:relative;
	z-index:999;
	background:url(../images/back.jpg) ;
	background-attachment:fixed;
}
.header_main {
	width: 100%;
	padding: 0;
}
.header_main_inr {
	text-align:center;
}
.header_main_inr img {
	margin:0 auto;
	position:relative;
	max-width:764px;
}

.header_main_inr h1 {
	position:relative;
}

	.catch {
		position:absolute;
		top:-580px;
		right:-60px;
	}

#catch_txt {
	text-align:center;
	font-size:2.8rem;
	font-weight:bold;
	color:white;
	background: rgba(0,0,0,0.6);
	padding:0.5em;
}

	#catch_txt span {
		font-size:1.4rem;
	}

#main .inr {
	width:100%;
	max-width:1200px;
	margin:0 auto;
	padding: 50px 10px;
}

	#main .inr p {
		margin:1em;
	}

/* 4: footer
================================== */
#footer {
	position:relative;
	background:#231815;
}
#footer .inr {
	overflow: hidden;
	padding:30px auto;
	width:100%;
	max-width:1200px;
	margin:0 auto;
	color:white;
	text-align:center;
}

#footer .fB {
	margin-top:1em;
	font-size:2.0rem;
}

#copy {
	clear:both;
	text-align:center;
	padding:20px;
	font-size: 1.4rem;
	color:white;
}

/*スクロールボタン*/
#page-top {
	display:none;
	position: fixed;
	bottom: 0;
	right: 0;
	font-size: 200%;
	z-index: 9999999;
}
#page-top img{
	width: 100px;
	height: 100px;
}
#page-top a:hover {
	text-decoration: none;
	opacity: 0.7;
}

/* 5: common-content
================================== */
.flexbox_wap {/* 折り返しのみ */
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap: wrap;
}
.flexbox_sbwap {/* 折り返し・水平方向端揃え */
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-justify-content: space-between; /* Safari */
	justify-content: space-between;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap: wrap;
}
.flexbox_cwap {/* 折り返し・水平中央揃え */
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-justify-content: center; /* Safari */
	justify-content: center;
	-webkit-flex-wrap: wrap; /* Safari */
	flex-wrap: wrap;
}
.flexbox_end {
	align-items: flex-end;
}
.fL {float:left!important;}
.fR {float:right!important;}
.m0 {margin:0 auto!important;}
.m1em {margin:1em;}
.m2em {margin:2em auto;}
.mR1em {margin-right:1em!important;}
.mL1em {margin-left:1em!important;}
.mT1em {margin-top:1em!important;}
.mT2em {margin-top:2em!important;}
.mB1em {margin-bottom:1em!important;}
.p1em {padding:1em;}
.p2em {padding:2em!important;}
.pT1em {padding-top:1em;}
.pB1em {padding-bottom:1em;}
.tC {text-align:center;}
.tR {text-align:right!important;}
.tL {text-align:left!important;}
.fB {font-weight: bold;}
.fI {font-style: italic;}
.fS {font-size: 80%;}
.score_red {color: #c00000;}
.start_blue {color: #006bbb;}
.white {background:white;}
.gray {background:#eef3fd;}
.Blue {background:#006bbb;}
.LBlue {background:#daeef3;}
.LRed {background:#fbe4d5;}
.fBig {font-size:2.0rem; font-size:20px;}
.underL {border-bottom:solid 1px #000;}
.mauto {margin:auto;}
.mid {vertical-align:middle;}
.red {color:red;}

	.tC img {
		margin:0 auto;
	}

/* 6: top page
================================== */

#main {
	position:relative;
	width:100%;
	clear:both;
}
	#main .inr {
		text-align:center;
	}

#outline {
	background:url(../images/back.png) no-repeat right center;
}

#outline h2,
#howto h2 {
	margin-bottom:60px;
	background: linear-gradient(transparent 70%, #fff100 70%);
	font-size:3.0rem;
	font-weight:bold;
}

h2 img {
	margin:0 auto;
}


#outline h3 {
     position: relative;
     padding-bottom: 0.5em;
     border-bottom: 4px solid #dbdcdd;
     text-align:left;
     font-weight:bold;
	margin-bottom:1em;
}
 
h3::after {
     position: absolute;
     content: " ";
     border-bottom: solid 4px #8fc31f;
     bottom: -4px;
     width:10%;
     display: block;
}

h4 {
     position: relative;
     padding-left: 0.7em;
     font-weight:bold;
}
 
h4::after {
     position: absolute;
     top: 50%;
     left:0;
     transform:translateY(-50%);
     content: '';
     width: 5px;
     height:1em;
     background-color: #446689;
}

h5 {
	font-weight: bold;
	padding: 0.5em 0 0.2em 0;
	margin: 0 0 1em 0;
	position:relative;
}

	h5::before {
    content: '';
    width: 50px;
    height: 4px;
    background-color: #ccc;
    display: block;
    position: absolute;
    left: 0;
    bottom: -6px;
}

.disc li {
	list-style:disc;
	margin-left:2em;
}

.box {
	background:white;
	padding:1em;
	margin:30px auto 0 auto;
	width:90%;
	text-align:left;
}

#main .inr .hako {
	margin:0 auto;
	border:dotted 5px #fff100;
	text-align:left;
	padding:0.5em;
}

.hako table {
	border:0;
}

.hako td {
	border-left:0;
	border-right:0;
}

.hako td:first-child {
	white-space:nowrap;
}

.scroll {
	height:400px;
	overflow:auto;
}

#howto li a {
	display:block;
}


.btn1 a {
	background:#0000cc;
	color:white;
	padding:5px 1em;
	font-size:2.5rem;
	text-decoration:none;
	width:360px;
	border:solid 5px #0000cc;
}

.wpcf7-back {
	background:#eee;
	width:5em;
	padding:10px;
	font-size:2.5rem;
	text-decoration:none;
}

	.btn1 a:hover,
	.wpcf7-back:hover {
		background:white;
		color:#0000cc;
	}

.btn2 a,
.wpcf7-submit,
.wpcf7c-btn-confirm {
	background:#c00;
	color:white;
	padding:10px;
	font-size:2.5rem;
	text-decoration:none;
	width:360px;
	border:solid 5px #c00;
}

.wpcf7-submit,
.wpcf7c-btn-confirm {
	width:5em;
}

	.btn2 a:hover,
	.wpcf7-submit:hover,
	.wpcf7c-btn-confirm:hover {
		background:white;
		color:#2b55b2;
	}

#contact {
background:#85b22e;
}

#contact h3 {
	color:#2b55b2;
	font-size:2.0rem;
	font-weight:bold;
	text-align:center;
}

#contact .inr {
	padding:10px;
}


.step li {
	margin-right:10px;
	margin-bottom:10px;
}

.step li img {
	max-width:100%;
	margin:0 auto;
}

.photo_flame {
	margin:0 auto;
	width:100%;
	max-width:800px;
}

table {
	border:solid 1px #ccc;
}

td,th {
	padding:0.5em;
	line-height:2;
	margin-bottom:1px;
	border:solid 1px #ccc;
	text-align:left;
}

th {
	background:#eee;
	vertical-align:top;
	white-space:nowrap;
}

.photo dt {
	float:left;
	width:15em;
	font-size:2.0rem;
	clear:left;
	text-align:left;
}

.photo dd {
	margin-bottom:0.5em;
	text-align:left;
}

input[type="text"],
input[type="email"], 
textarea {
    width: 100%;
    max-width: 450px;
    padding: 10px;
    border: 1px solid #becad6;
    font-size: 1.6rem;
    transition: box-shadow 250ms cubic-bezier(.27,.01,.38,1.06),border 250ms cubic-bezier(.27,.01,.38,1.06);
    border-radius: 3px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}



/* ウィンドウ幅が～768pxの場合に適用するCSS */
@media only screen and (max-width: 768px) {

/* 1: setting
================================== */
body {
	width: 100%;
	min-width: 100%;
	font-size: 1.5rem;
}

.pc {display:none;}
.sp {display:block;}

.header_main {
	height:auto;
}


#header {
	background:url(../images/back_sp.jpg) top center;
	background-size:cover;
}
.header_main {
}

.header_main_inr img {
	max-width:100%;
	height:auto;
}

#catch_txt {
	text-align:left;
	font-size:1.8rem;
}

.catch {
	top:-500px;
}

#outline h2 {
	text-align:left;
	font-size:1.8rem;
	margin-bottom:0.5em;
}


.flexbox_sbwap li {
	width:49%;
}

#contact img {
	max-width:100%;
}

.tC img {
	max-width:100%;
}


td,th {
	display:block;
	width:100%;
}




}

/* ウィンドウ幅が～400pxの場合に適用するCSS */
@media only screen and (max-width: 400px) {

/* 1: setting
================================== */
body {
	width: 100%;
	min-width: 100%;
	font-size: 1.5rem;
}

.header_main_inr h1 {
	margin-top:0px;
}

h1 img {
	width:300px;
	height:auto;
}


#header {
	background-size:cover;
	padding-bottom:50px;
}
.header_main {
	height:450px;
}

.header_main_inr img {
	max-width:415px;
}


.step li {
	width:99%;
}

	.step li img {
		max-width:100%;
	}
	

#contact h3 {
	font-size:6vw;
}
	
}


