@charset "utf-8";
/* CSS Document */
/* 
Reset Stylesheet
*/
 
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, strong, sub, sup, 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%;
    background: transparent;
}
 
body {
    line-height:1;
	overflow-x: hidden;
	background: #FDFBF2;
	width:100vw;
}

main{
	width:100vw;
	overflow-x: hidden;
}
 
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}
 
nav ul {
    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;
	text-decoration:none;
}
 
/* 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;
}

h1, h2, h3, h4, h5, h6, p{
	font-family: "UD Shin Maru Go Regular", "UD Shin Maru Go Medium";
}

img{
	width:100%;
	margin:0 auto;
	padding:0;	
	float: center;
	display: block;
}

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

 /*for smartphone*/
@media only screen and (max-width: 768px) {
	.pc { display: none; }
	.sp { display: block; }
}

.pc1000 { display: block; }
.sp1000 { display: none; }

 /*for smartphone*/
@media only screen and (max-width: 1000px) {
	.pc1000 { display: none; }
	.sp1000 { display: block; }
}

.pc1200 { display: block; }
.sp1200 { display: none; }

 /*for smartphone*/
@media only screen and (max-width: 1200px) {
	.pc1200 { display: none; }
	.sp1200 { display: block; }
}

.anchor {
    display: block;
    padding-top: 70px;
    margin-top: -70px;
}

header{
    height:110px;
	width:100vw;
}

.header_wrap{
	width:100%;
	padding:0;
	display: flex;
	justify-content: space-between;
	background:#FDFBF2;
  z-index: 2000;
	overflow-x: hidden;
}
.header_logo{
	display: flex;
	align-items: center;
	padding:10px;
}
.header__title h2{
    font-family:'Klee One', cursive, YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size:20px;
	padding-bottom:10px;
}

.header__title h2 span{
	font-size:16px;
}

.header__logo img{
	width:100px;
	padding:0;
	margin:0;
}

.header_right{
	text-align: right;
	padding:10px 20px;
}

.header_upper{
	display: flex;
	justify-content: right;
}

.header_upper p{
	font-size:30px;
	color:#00A1FF;
	font-family: 'Kosugi Maru', sans-serif;
	text-align: right;
}

.header_menu ul{
	display: flex;
	list-style: none;
    font-family:'Klee One', cursive, YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
	text-align: left;
}
.header_menu a{
	color:#000000;
}
.header_menu li{
	padding: 10px;
}
.header_menu img{
	width:150px;
}

.btn{
	display:none;
}

@media only screen and (max-width: 1200px) {
	header{
    height:70px;
	padding:0px;
	width:100vw;
}
	.header_wrap{
	display: flex;
	justify-content: space-between;
  	position: fixed;
	padding:0;
}
.header__logo img{
	width:60px;
}
	.header_logo{
	display: flex;
	align-items: center;
}
.header_upper p{
	font-size:20px;
}
	
.header_right{
	display: flex;
	justify-content: right;
	align-items: center;
}
.btn {
  display:flex;
  width: 40px;
  height: 40px;
  z-index: 50;
  background-color: none;  
  border:none;
  color:#000000;
	font-size: 25px;
	justify-content: right;
	align-items: center;
}


.menu {
  	display:none;
	background:#FDFBF2;
	position: fixed;
	top:50px;
	left:0;
	width:100vw;
	height:100vh;
	padding-top:20px;
	text-align: center;
  z-index: 2000;
}
	
.menu.open {
  	display:block;
}

.header_menu ul{
	display: block;
}

.header_r_lower li{
	text-align: center;
	padding:15px 0px ;
    display: block;
    color: #000000;
}
}


.mv{
	position:relative;
  z-index: 20;
	width:100vw;
}

.mv img{
	min-height: 300px;
	object-fit: cover;
	max-height: 100vh;
}

.mv_copy{
	text-align: center;
	background: #F19B91;
	width:50%;
	height:100px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
	border-radius: 20px;
	padding:10px;
}

.mv_copy h1{
    font-size: 34px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
	color:#ffffff;
}

.mv_copy h1 span{
    font-size: 18px;
    font-weight:normal;
}

.to_blog{
	height:50px;
	background: #F19B91;
	width:50vw;
	display: flex;
	justify-content: center;
	align-items: center;
	color:#ffffff;
	font-weight:normal;
}

.to_blog h3{
	font-weight:normal;
}

.contact_float{
	position: fixed;
	right:0;
	top:30%;
	background: #F19B91;
	color:#ffffff;
	z-index:1000!important;
	padding:50px 20px;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
.contact_float:hover{
	padding:52px 22px;
}


@media only screen and (max-width: 768px) {
	.mv_copy{
	width:80%;
	height:70px;
	display: flex;
	border-radius: 15px;
	padding:10px;
}

.mv_copy h1{
    font-size: 24px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
	color:#ffffff;
}

.mv_copy h1 span{
    font-size: 14px;
    font-weight:normal;
}
	.to_blog{
	width:100vw;
}
	.contact_float{
	position: fixed;
	left:0;
	bottom:0;
	right:auto;
	top:auto;
	height:50px;
		width:100vw;
	z-index: 50;
	text-align: center;
  -ms-writing-mode: tb-rl;
	writing-mode: horizontal-tb;
	padding:0;
		display: flex;
		justify-content: center;
		align-items: center;
}
.contact_float:hover{
	padding:0;
}	
}

.section_title{
	position: relative;
	text-align: center;
	padding:100px 0 50px;
	z-index:100;
}

.section_title h3{
	font-size:36px;
	color:#F19B91;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
}

.section_title h4{
	font-size:20px;
	color:#1DB001;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
	padding-top:10px;
}

.omoi_wrap{
	background-image: url("../img/bg.png");
	background-size: cover;
	display: flex;
	justify-content: space-around;
}

.bm_title h3{
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
text-align: center;
padding:30px 0;
font-size:50px;
border-bottom: 1px solid rgba(158,158,158,1.00);
color:#004D80;}

.bm_title span{
font-size:20px;}
.bm_content{
	margin:auto;
	display:flex;
	justify-content:center;
}
.bm_content p{
	height:600px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	line-height:2;
	padding:30px 0;
}

.brandmessage_side_each img{
	max-width:200px;
	height:auto;
	padding:30px 10px;
}
.brandmessage_side_each2 img{
	max-height:300px;
	width:auto;
	padding:30px 10px;
}


@media only screen and (max-width: 1200px) {
	.brandmessage_side{
		display:none;
	}
}


@media only screen and (max-width: 1000px) {
	.bm_content p{
	height:auto;
  -ms-writing-mode: tb-rl;
	writing-mode: horizontal-tb;
	line-height:2;
	padding:30px 10px;
}
	.bm_title h3{
		font-size:36px;
	}

.bm_title span{
		font-size:16px;
	}
}

.section_copy h5{
	text-align: center;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size:20px;
	padding-bottom:50px;
	position: relative;
	z-index:100;
}

.point_content{
	max-width:1000px;
	padding:10px;
	display: flex;
	justify-content: center;
	margin:auto;
	position: relative;
	z-index:100;
}
.each_point{
	padding:0 30px 30px;
	display: flex;
	width:500px;
    align-items: flex-start;
	position: relative;
	z-index:100;
}
.each_point img{
	width:50px;
	height:auto;
	position: relative;
	z-index:100;
}

.each_point h5{
	padding:10px;
	line-height:1.5!important;
}
.each_point p{
	padding:10px;
	line-height:1.5!important;
}


@media only screen and (max-width: 1000px) {
	.point_content{
	display: block;
}
	.point_img{
		max-width: 300px;
		margin:auto;
		padding-bottom:50px;
	}
	
	.each_point{
	width:90%;
	padding:0;
}
}

.heartbg{
	position: relative;
	width:100vw;
	padding-left:0;
	padding-right:0;
	z-index:10;
}
.heartbg img{
	position: absolute;
	bottom:0;
	width:100%;
  z-index: -1;
}

.flow{
	max-width:1000px;
	margin:auto;
	z-index:500;
	padding:20px 0;
	margin-bottom:50px;
}

.flow img{
	z-index:500;
}


.service_content{
	max-width:1000px;
	background: #ffffff;
	margin:auto;
	padding-bottom:100px;
	margin-bottom:100px;
	position: relative;
	z-index:100;
}
.service_logo{
	text-align: right;
	display: flex;
	justify-content: right;
	padding:20px;
	width:100%;
}

.service_logo img{
	width:150px;
	position:absolute;
	padding:0 20px;
}
.each_service:first-child{
	margin-top:150px;
	padding-top:30px;
}
.each_service{
	margin-top:20px;
	padding-top:30px;
}
.each_service h4{
	padding:10px 30px;
}
.each_service p{
	padding:10px 30px 30px;
	line-height: 1.5;
	font-size:15px;
}
.each_service ul{
	padding:10px 30px 30px;
}
.each_service li{
	padding:5px 10px;
	list-style-position:inside;
}

.each_service img{
	width: 100%;
}

@media only screen and (max-width: 1000px) {
	.heartbg img{
	margin:0px;
}
		.service_content{
	padding-bottom:20px;
	margin-bottom:20px;
}
}

@media only screen and (max-width: 500px) {
	.service_logo img{
	width:100px;
}

}

.flow_text{
	text-align: center;
	line-height: 2;
}

.contact_btns{
	max-width:1000px;
	margin:auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	padding:50px 0;
}

.contact_btn_each{
	width:300px;
	padding:30px;
	background:#F19B91;
	color:#ffffff;
	border-radius: 20px;
	box-shadow: 5px 5px 10px 1px rgba(0, 0, 0, 0.2);
	text-align: center;
	margin-bottom:30px;
}

.contact_btn_each:hover{
	box-shadow:none;
	transform: translate(5px,5px);
}


.contact_btn_upper{
	display: flex;
	align-items: center;
}

.contact_btn_upper p{
	font-family: 'Kosugi Maru', sans-serif;
}

.free{
	color:#F19B91;
	background: #ffffff;
	width:50px;
	height:50px;
	border-radius: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.contact_btn_middle P{
	PADDING:15PX 0;
	font-size:28px;
}
.contact_btn_middle2 P{
	PADDING:5PX 0;
	font-size:48px;
}

.contact_btn_lower p{
	font-size:12px;
}

.three_images{
	display: flex;
	justify-content: space-between;
}

.each_img{
	position: relative;}

.each_img p{
	text-align: center;
	color:#ffffff;
	background:rgba(255,149,140,0.9);
		padding:20px;
	position: absolute;
	top:70%;
	width:100%;
	font-size:14px;
}


@media only screen and (max-width: 768px) {
	.three_images{
	display: block;
}

.each_img{
	width:100%;
	margin-bottom:10px;
}
}

.to_blog_btns{
	padding: 50px 0;
	text-align: center;
	padding-bottom:50px;
}

.blog_btn{
	width:300px;
	margin:auto;
	padding:30px 0;
	background:#F19B91;
	color:#ffffff;
	border-radius: 20px;
	box-shadow: 5px 5px 10px 1px rgba(0, 0, 0, 0.2);
	text-align: center;
	font-family: 'Kosugi Maru', sans-serif;
}
.blog_disc{
	padding-top:30px;
}

.to_rashisa_blog{
	padding:50px 0;
}
.footer_upper{
	display: flex;
	justify-content: space-around;
	align-items: flex-end
}

.footer_illust img{
	width:200px;
}

.footer_ttl{
	text-align: center;
}

.footer_ttl h3{
	font-size:36px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", serif;
	padding-bottom:30px;
	color:#004D80;
	
}
.footer_ttl h3 span{
	font-size:16px;
}

.footer_bg{
	background:#F19B91;
	text-align: center;
	padding:30px;
}
.footer_bg img{
    width:100px;
}

.footer_lower{
	display: flex;
	justify-content: space-around;
	padding-bottom:0px;
}
.footer_lower p{
	padding:10px;
	font-size:14px;
}


.footer_lower div{
	display: flex;
	justify-content:left;
	align-items: center;
}


@media only screen and (max-width: 1000px) {
	.footer_lower{
	display: block;
	text-align: center;
	margin:auto;
}
	.footer_lower div{
	display: block;
}
}

@media only screen and (max-width: 1000px) {
		.footer_lower{
	padding-bottom:80px;
}
}

.postbody{
	width:100%;
	padding:80px 10px;
	max-width:1000px;
	margin:auto;
}