@charset "UTF-8";
/* CSS Document */

html{font-size: 62.5%;
	font-family: 'Noto Sans JP', sans-serif;}

html, body {
	/*height: 100%;*/
	font-family: 'Shippori Mincho B1', serif;
	color: #203744;}

header {
	width: 100%;
	height: 100vh;
	padding: 7% 0 0 7%;
	background-image: url("../img/main_img.jpg");
	background-size:cover;
	background-position: center;
	box-sizing: border-box;
	}

#header_pp {
	padding: 7% 0 0 7%;
	position: fixed;
	z-index: 100;
	}

h1, #header_pp h1 {
	margin: 0;
	padding-left: 13px; 
	}

h1 img, #header_pp h1 img {
	width: 210px;
	/*width: 140px;*/
	}

header nav, #header_pp nav {
	writing-mode: vertical-rl;
	color: #fff;
	padding-top: 3em;
	}

header nav ul, #header_pp nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	}

header nav ul li, #header_pp nav ul li {
	font-size: 1.5rem;
	letter-spacing: 2px;
	margin: 0 10px;
	}

header nav ul li a,
#header_pp nav ul li {color: #fff !important;}

p {margin:0; padding:0;}

a:link,
a:visited,
a:hover,
a:active {color: #203744; text-decoration: none;}


/*  greeting  */

#greeting {
	padding: 15% 10%;
	display: flex;
	height: auto;
	margin-bottom: 20%;
	}

#greeting img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#greeting_box_l {
	width: 100%;
	order: 0;
	}

#greeting_box_r {
	width: 100%;
	order: 1;
	}

#greeting h2 {
	margin-bottom: 2.3em;
	font-size: 1.4rem;
	font-weight: 400;
	}

#greeting h2::after {
	color: #adadad;
	content: ' —';
	font-weight: 400;
	display: block; /*改行するように*/
	padding-top: 0.5em;
}

#greeting h3 {
	padding-right: 10%;
	font-size: 2.3rem;
	letter-spacing: 1px;
	line-height: 140%;
	font-weight: 400;}

#greeting p {
	font-size: 1.4rem;
	line-height: 160%;
	padding-right: 10%;
	}

#greeting_box_l p:first-of-type {margin-bottom:1.5em;}


/*  profile  */

#profile {
	padding: 15% 10% 5% 10%;
	display: flex;
	height: auto;
	}

#profile img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	}

#profile_box_l {
	width: 45%;
	background-color: beige;}

#profile_box_r {
	width: 55%;
	}

#profile h2 {
	text-align: right;
	margin-bottom: 2.3em;
	font-size: 1.4rem;
	font-weight: 400;
	}

#profile h2::after {
	color: #adadad;
	content: ' —';
	font-weight: 400;
	display: block;
	padding-top: 0.5em;
	}

#profile dl {
	font-size: 1.5rem;
	display: flex;
	flex-wrap: wrap;
	width: 70%;
	margin: 0 10% 0 20%;
	}

#profile dl dt {
	width: 40%;
	padding: 1em 0;
	border-bottom: solid 1px #e0e0e0;
	}

#profile dl dd {
	margin: 0;
	padding: 1em 0;
	width: 60%;
	border-bottom: solid 1px #e0e0e0;
	}

#profile_box_r a {text-decoration: underline;}


/*  access  */

#access {
	padding: 10% 10% 5% 10%;
}

#access h2 {
	margin-bottom: 2.3em;
	font-size: 1.4rem;
	font-weight: 400;
	}

#access h2::after {
	color: #adadad;
	content: ' —';
	font-weight: 400;
	display: block; /*改行するように*/
	padding-top: 0.5em;
	}

#access dl {
	font-size: 1.5rem;
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	}

#access dl dt {
	width: 10%;
	margin-bottom: 1em;
	}

#access dl dd {
	margin: 0;
	width: 90%;
	margin-bottom: 1em;
	}

#gmap {
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 75%;
	}

#gmap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	}


/*  instagram  */

#instagram {
	padding: 0 10% 10% 10%;
	display: flex;
		background-color: #F7F6F5;
}

#instagram  h2 {
	margin-bottom: 2.3em;
	font-size: 1.4rem;
	font-weight: 400;
	}

#instagram  h2::after {
	color: #adadad;
	content: ' —';
	font-weight: 400;
	display: block; /*改行するように*/
	padding-top: 0.5em;
	}

#insta_l {
	width: 80%;
	margin-top: -20%;
}

#insta_r {
	width: 20%;
	position: relative;
	}

#insta_r a {text-decoration: underline;}

#instagram p {
	font-size: 1.5rem;
	font-weight: 400;
	margin: 0;
	position: absolute;
	bottom: 0;
	right: 0;
	}


/*  #contact  */

#contact {
	padding: 10% 20%;
	font-size: 1.5rem;
	}

#contact  h2 {
	margin-bottom: 2.3em;
	font-size: 1.4rem;
	font-weight: 400;
	}

#contact  h3 {font-weight: 400;}

#contact  h2::after {
	color: #adadad;
	content: ' —';
	font-weight: 400;
	display: block;
	padding-top: 0.5em;
	}

#tel {
	display: flex;
	margin-bottom: 10%;}

#number {
	margin: 0 7% 0 0;
	font-size: 3rem;
	letter-spacing: 1px;
	width: 30%;
	}

#tel_text {width: 70%;}

#mail_text {margin: 2em 0 3em 0;}
#mail_text span {color:#ee827c;}

#contact i {
	font-size: 2.3rem;
	margin: 0px 5px 0 0;
	vertical-align: bottom;
	}

form#mail_form {
	width: auto;
	margin: 0;
	border: none;
	box-shadow: none;
	line-height: 1.8
	}

form#mail_form dl {
	width: auto;
	border-bottom: none;
	}

form#mail_form dl dt {
	width: 25%;
	padding: 15px 0 15px;
	text-align: left;
		/*background-color: antiquewhite;*/
	}

form#mail_form dl dd {
	width: 75%;
	padding: 9px 0 9px 0%;
		/*background-color: gainsboro;*/
	}

form#mail_form ul li label {
	background: none;
	}

form#mail_form ul li label:hover {
	background: none;
	}

form#mail_form input[type="text"], form#mail_form input[type="email"], form#mail_form input[type="tel"] {
	border: 1px solid #E8ECEF;
	background: #E8ECEF;
	border-radius: 0;
	font-size: 1.5rem;
	}

form#mail_form textarea {
	border: 1px solid #E8ECEF;
	border-radius: 0;
	background: #E8ECEF;
	}

form#mail_form p#form_submit {
	margin-left: 25%;
	}

form#mail_form input[type="button"] {
	margin: 0;
	padding: 15px 60px;
	border: 1px solid #44617B;
	border-radius: 5px;
	background: #44617B;
	}

form#mail_form input[type="button"]:hover {
	cursor: pointer;
	background: #44617B;
	border: 1px solid #44617B;
	}

form#mail_form ul li:first-child label {
	margin-top: 0px;
	padding: 0;
	}

#mail_form a {text-decoration: underline;}

form#mail_form dl dt span.required,
form#mail_form dl dt span.optional {display: none;}


/*  footer  */

footer {
	background-color: #e6eae6;
	}

footer nav {
	display: flex;
	}

footer nav ul {
	margin: 0 auto;
	padding: 2.5em 0;
	font-size: 1.2rem;
	list-style: none;
	display: flex;
	align-items:center;
	}

footer ul li {
	margin: 0 1em;
	}

footer p {
	font-size: 1.2rem;
	margin: 0;
	padding: 0 0 2em 0;
	text-align: center;
	}

/*  policy  */

#privacypolicy {
	font-size: 1.5rem;
	padding: 6% 12% 0 35%;
	margin-bottom: 10%;
	}

#privacypolicy h2 {
	margin-bottom: 2.3em;
	font-size: 1.4rem;
	font-weight: 400;
	}

#privacypolicy h2::after {
	color: #adadad;
	content: ' —';
	font-weight: 400;
	display: block;
	padding-top: 0.5em;
	}

#p_main_r {
	margin-left:auto;
	margin-right:0;
	}

#pp_img {
	width: 18%;
	height: 500px;}

#privacypolicy h3 {
	font-size: 1.5rem;
	margin-top: 3em;
	}

#privacypolicy a {text-decoration: underline;}


/*  thanks  */

#thanks {
	font-size: 1.5rem;
	padding: 6% 12% 0 35%;
	margin-bottom: 10%;}

#thanks_box {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	}

#thanks_box footer {margin-top: auto;}


/* ------------------------------ tab ------------------------------ */

@media screen and (max-width:960px) {
	
	header, #header_pp {padding: 70px 0 0 0;}
	
	header h1, #header_pp h1 {
		padding: 0;
		text-align: center;}
	
	header nav, #header_pp nav {
		width: 100%;
		display: flex;
		align-items: center;
		}
	
	header nav ul {
	}
	
	/*header nav {
		width: 16.5em;
		margin: 0 auto;}*/

	#greeting {
		padding: 0 0 0 7%;
		margin: 15% 0 15% 0;
		}

	#greeting_box_l {width: 60%;}
	#greeting_box_r {width: 40%;}
	
	#profile {padding: 10% 7% 10% 0;}
	
	#profile dl {
		width: 80%;
		margin: 0 0 0 auto;
		}
	
	#access {margin-bottom: 0;}
	
	#instagram {
		display: block;
		padding:10%;}
	
	#insta_l {
		margin-top: 0%;
		width: 100%;}
	
	#insta_r {width: 100%;}
	#insta_r p {
		position: static;
		margin-top: 5%;
		text-align: right;}
	
	#tel {
		display: block;
		margin-bottom: 15%;}
	
	#number {
		font-size: 3.5rem;
		margin: 0.7em 0 0.7em 0;
		width: 100%;}
	
	#tel_text {width: 100%;}
	
	form#mail_form dl dt {font-weight: 400;}
	form#mail_form dl dd {width: 100%;}
	
	form#mail_form p#form_submit {
	padding: 0;
	margin: 10% 0 10% 0;
	width: 100%;
	}
	
	form#mail_form dl dt {
		width: 100%;
		padding-bottom: 0;}
	
	form#mail_form input[name="company"] {width: 95.5%;}
	form#mail_form input[name="name_1"] {width: 95.5%;}
	form#mail_form input[name="phone"] {width: 95.5%;}
	form#mail_form input[name="mail_address"] {width: 95.5%;}
	
	#pp_img {display: none;}
	
	#privacypolicy, #thanks {
		padding: 10% 15%;
		/*margin-top: -500px;*/
	}
	
	#header_pp {position: static;}


}

/* ------------------------------ mob ------------------------------ */

@media screen and (max-width:560px) {

	header {
	display: block;
	height: 100vh;
	margin-top: 0;
	margin-bottom: 0;
	/*width: calc(100vw - 140px);
	height: calc(100vh - 140px);*/
	}

	#main_r {
		width: 100%;
		min-height: 35%;
		margin-top: 8%;
		}
	#main_l {
		width: 100%;
		height: 65%;
		}

	#greeting {
		display: block;
		margin: 0;
		padding:15% 10%;}
	
	#greeting_box_l {
		width: 100%;
		margin-top: 15%;
	}
	
	#greeting_box_r {
		width: 100%;
		margin: 0 auto;
		}
	
	#greeting h3 {padding-right: 0;}
	
	#greeting img { height: 280px;}
	
	#greeting p {padding:0;}
	
	#profile {
		display: block;
		margin: 0;
		padding:15% 10%;}
	
	#profile_box_l {width: 100%;}
	
	#profile img {height: 280px;}
	
	#profile_box_r {
		width: 100%;
		margin-top: 15%;
		}
	
	#profile h2 {text-align: left;}
	
	#profile dl {width: 100%;}
	
	#access {padding:15% 10%;}
	
	#access dl {
		display: block;
		margin: 0 0 5% 0;}
	
	#access dl dt {width: 100%;}
	
	#instagram {padding:15% 10%;}
	
	#contact {padding: 15% 10%;}
	
	#mail_text {margin: 2em 0 1em 0;}
	
	#form_submit {text-align: center;}
	
	footer nav ul {
		display: block;
		text-align: center;}
	
	footer nav ul li {margin: 1em 0;}

	#privacypolicy, #thanks {
		padding: 15% 10%;
		width: 80%;
		}

}
