@charset "UTF-8";


/* ------------------------------------------------------------------
	1. Base styles
-------------------------------------------------------------------*/
body {
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
	font-size: 22px;
	line-height: 1.3;
	color: #000;
	background: #fff;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
}

/*--------- Structure styles ----------- */
.container {
	max-width: 640px;
  margin: 0 auto 120px auto;

}

/*--------- Block styles ----------- */
.block {
	padding: 5% 3%;
}

/*--------- header styles ----------- */
header{
	position: relative;
	height: 80px;
	background: #eee;
}
.header_logo{
	font-size: 0.9em;
	letter-spacing: -0.03em;
	padding-left: 15px;
	padding-top: 14px;
}
.header_logo a{
	color: #000;
	text-decoration: none;
}
.header_logo span{
	font-size: 1.3em;
	font-weight: bold;
}

/*--------- footer styles ----------- */
footer{
	padding-top: 6%;
}
.footer_nav{
	border-bottom: 1px solid #666666;
}
.footer_nav li {
	float: left;
	box-sizing: border-box;
	border-right: 1px solid #666666;
	border-top: 1px solid #666666;
	width: 50%;
}
.footer_nav li:nth-child(2n) {
	border-right: none;
}
.footer_nav li a {
	color: #000000;
	text-decoration: none;
	padding: 4% 2% 4% 4%;
	display: block;
}
.footer_nav li a:before {
	font-family: FontAwesome;
	content: "\f054";
	margin-right: 5px;
}


.footer_add_area{
	background: #eee;
	padding: 3% 5%;
}
.footer_add_title{
	padding-bottom: 2%;
	font-size: 1.2em;
	line-height: 1.2;
	font-weight: bold;
}
.footer_add_title span{
	font-size: 0.8em;
}
.footer_add{ }

.copyright{
	background: #555;
	text-align: center;
	padding: 3% 0;
	font-size: 0.9em;
	color: #FFF;
}

/*--------- nav styles ----------- */
/*ハンバーガーボタン*/
.hamburger {
  display : block;
  position: absolute;
  z-index : 3;
  right : 20px;
  top   : 23px;
  width : 40px;
  height: 40px;
  cursor: pointer;
  text-align: center;
}
.hamburger span {
  display : block;
  position: absolute;
  width   : 32px;
  height  : 3px ;
  left    : 4px;
  background : #000;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition   : 0.3s ease-in-out;
  transition        : 0.3s ease-in-out;
}
.hamburger span:nth-child(1) {
  top: 8px;
}
.hamburger span:nth-child(2) {
  top: 20px;
}
.hamburger span:nth-child(3) {
  top: 32px;
}

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1) {
  top : 20px;
  left: 3px;
  background :#000;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 20px;
  background :#000;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
}

nav.globalMenuSp {
	display: none;
  position: fixed;
	-webkit-overflow-scrolling: auto;
  overflow-scrolling: auto;
	overflow-y: scroll;
  z-index : 201;
	top: 80px;
	left: 0;
	right: 0;
	margin: auto;
  color: #fff;
  background: rgba(0,0,0,0.7);
  text-align: center;
  width: 640px;
	height: 100%;
}

nav.globalMenuSp ul {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

nav.globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  transition: .4s all;
}
nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp ul li:hover{
  background :#ddd;
}

nav.globalMenuSp ul li a {
  display: block;
  color: #fff;
  padding: 4% 0;
  text-decoration :none;
	font-size: 1.2em;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {}

html.is-fixed,
html.is-fixed body {
    height: 100%;
    overflow: hidden;
}
/* ------------------------------------------------------------------
	2. page styles
-------------------------------------------------------------------*/
/* ページタイトル */
.page_ttl {
	background: #8c0000;
	margin-bottom: 2%;
	padding: 2%;
	color: #FFF;
}
.page_ttl h2 {
	font-size: 1.45em;
	line-height: 1.6;
	font-weight: bold;
}

.section {
	margin-bottom: 5%;
	line-height: 1.8;
}
.section_inner {
	padding: 0 2%;
}

.section_box { }
.section_thm {
	width: 30%;
}
.section_thm_left {
	float: left;
	margin: 0 3% 3% 0;
}
.section_thm_right {
	float: right;
	margin: 0 0 3% 3%;
}
.section_body { }
.section_body_hidden {
	overflow: hidden;
}

/*
.section_thm {
width: 100%;
text-align: center;
}
.section_thm_left {
float: none;
margin: 0 auto 3% auto;
}
.section_thm_right {
float: none;
margin: 0 auto 3% auto;
}
*/






/*--------- topページスタイルここから ----------- */

/* mv */
.mv_intro{
	font-size: 0.86em;
	padding: 2%;
	letter-spacing: -0.08em;
	line-height: 1.6;
}
.mv{
	position: relative;
}
.mv_item{
	position: absolute;
}
.mv_caption{
	top: 3%;
	left: 0;
	right: 0;
	margin: auto;
	text-align: center;
	font-size: 1.5em;
	font-weight: bold;
	color: #f00;
}
.mv_st{
	width: 21%;
}
.mv_st1{
	top: 10%;
	left: 5%;
}
.mv_st2{
	top: 10%;
	left: 28%;
}
.mv_st3{
	top: 10%;
	right: 28%;
}
.mv_st4{
	top: 10%;
	right: 5%;
}
.mv_title{
	width: 92%;
	top: 27%;
	left: 0;
	right: 0;
	margin: auto;
}
.mv_voice{
	width: 46%;
	top: 48%;
	right: 12%;
}
.mv_human{
	width: 56%;
	bottom: 0;
	left: 0;
}
.mv_price{
	width: 50%;
	bottom: 2%;
	right: 1%;
}

/* catch */
.top_catch {
	background: #ccc;
	padding: 3%;
}
.top_catch_inr {
	background: #FFF;
	border-radius: 5px;
	padding: 3% 2%;
}
.top_catch_title {
	text-align: center;
	margin-bottom: 4%;
}
.top_catch_title h3 {
	font-size: 1.4em;
	font-weight: bold;
	margin-bottom: 2%;
	background: linear-gradient(transparent 50%, #ffff00 0%);
	display: inline;
}
.top_catch_text {
	/*font-weight: bold;*/
}

/* soudan */
.top_soudan_inr{
	overflow: hidden;
	padding-bottom: 3%;
}
.top_soudan_img{
	float: right;
	width: 30%;
}
.top_soudan_title{
	float: right;
	width: 68%;
	text-align: center;
	font-weight: bold;
	font-size: 1.3em;
	line-height: 1.6;
	margin-left: -7%;
}
.top_soudan_list{
	width: 72%;
	margin: 0 auto;
}
.top_soudan_text{
	text-align: center;
	padding: 2% 0;
	font-size: 1.2em;
	font-weight: bold;
	color: #f00;
	border-top: solid 1px #f00;
}
.top_soudan_text:last-of-type{
	border-bottom: solid 1px #f00;
}

/* 作業の流れ */
.work_flow_inr{
	position: relative;
	margin-bottom: 5%;
}
.work_flow_title_img{
	position: absolute;
	width: 39%;
	top: -30%;
	right: -3%;
}
.work_flow_title{
	padding-left: 2%;
	font-size: 1.45em;
	font-weight: bold;
	color: #0031be;
	line-height: 1.5;
}
.work_flow_title img{
	width: 60%;
}
.work_flow_item{
	padding-bottom: 4%;
}
.work_flow_item_title{
	vertical-align: middle;
	background: #ffd42b;
	padding: 2% 3%;
	margin-bottom: 2%;
	font-size: 1.3em;
	font-weight: bold;
	color: #0031be;
	border-radius: 5px;
}
.work_flow_item_text{
	padding: 0 8%;
}
.work_flow_numbering{
  margin: 0;
  counter-reset: number;
}
.work_flow_numbering h4::before {
	vertical-align: middle;
  counter-increment: number;
  content: counter(number);
	padding-right: 2%;
	font-size: 1.5em;
	color: #fff;
	line-height: 0;
}

.work_flow_ng{
	background: #fff;
	padding: 5% 8%;
	border-radius: 10px
}
.work_flow_ng_caption{
	padding-bottom: 2%;
	font-size: 1.15em;
	font-weight: bold;
	color: #8c0000;
}
.work_flow_ng_list{
	padding: 0 2%;
}
.work_flow_ng_list li{
	font-size: 1.15em;
	padding-bottom: 1%;
}

/* customer_voice */
.customer_voice_title{
	width: 84%;
	margin: 0 auto;
	padding-bottom: 4%;
}
.customer_voice_item{
	width: 84%;
	margin: 0 auto 3% auto;
	background: #fff2c1;
	padding: 5%;
	font-size: 1.15em;
	border-radius: 10px;
}
.customer_voice_item:last-of-type{
	margin-bottom: 0;
}

/* top_qa */
.block_top_qa{
	margin-top: 5%;
}
.top_qa_inr{
	position: relative;
	text-align: right;
}
.top_qa_img{
	position: absolute;
	width: 36%;
	top: -44%;
	left: 0;
}
.top_qa_title{
	position: relative;
	width: 70%;
	margin: 0 2% 5% auto;
	font-size: 1.1em;
	font-weight: bold;
	color: #0031be;
}
.top_qa_title img{
  padding-bottom: 4%;
}
.top_qa_list{}
.top_qa_item{
	padding-bottom: 4%;
}
.qa_q{
	background: #79afe7;
	vertical-align: middle;
	padding: 2% 3%;
	margin-bottom: 2%;
	font-size: 1.3em;
	font-weight: bold;
	color: #fff;
	border-radius: 5px;
}
.qa_a{
	padding: 0 3% 0 9%;
	text-indent: -1.6em;
}
.qa_q::before{
  content: 'Q';
	vertical-align: middle;
	padding-right: 2%;
	font-size: 1.2em;
	font-weight: bold;
	color: #fff;
	line-height: 0;
}
.qa_a::before{
  content: 'A';
	vertical-align: middle;
	padding-right: 2%;
	font-size: 1.7em;
	font-weight: bold;
	color: #79afe7;
	line-height: 0;
}
/* sales_area */
.sales_area_title{
	padding-bottom: 4%;
	text-align: center;
	font-size: 1.9em;
	font-weight: bold;
}
.sales_area_list{
	text-align: center;
	padding: 0 4%;
}
.sales_area_list li{
	padding-bottom: 5%;
}
.sales_area_detail{
	font-size: 0.9em;
}
.sales_area_img{
	width: 80%;
	margin: 0 auto;
}

/* map */
#map {
	width: 100%;
	height: 400px;
	background-color: grey;
}

/*--------- topページスタイルここまで ----------- */







/*--------- flowページスタイルここから ----------- */
.work_flow_item_detail {
	position: relative;
	margin-bottom: 8%;
}
.work_flow_item_detail::before {
	font-family: FontAwesome;
	content: '\f0dd';
	position: absolute;
	left: 0;
	right: 0;
	bottom: -4vw;
	text-align: center;
	font-size: 5vw;
	color: #ed1b24;
}
.work_flow_item_detail:last-child::before {
	content: '';
}
@media only screen and (max-width: 640px) {
	.work_flow_item_detail::before {
    bottom: -12vw;
    font-size: 15vw;
	}
}
/*--------- flowページスタイルここまで ----------- */





/*--------- priceページスタイルここから ----------- */
.price_list { }
.price_item {
	margin-bottom: 3%;
}
.price_thm {
	width: 80%;
	margin: 0 auto;
}
.price_body { }
.price_info {
	letter-spacing: -1em;
  white-space: nowrap;
	text-align: center;
}
.price_info dt {
	background: #ed1b24;
	display: inline-block;
	vertical-align: middle;
	width: 20%;
	letter-spacing: normal;
	white-space: normal;
	color: #FFF;
	font-weight: bold;
}
.price_info dd {
	display: inline-block;
	vertical-align: middle;
	letter-spacing: normal;
	white-space: normal;
	color: #ed1b24;
	font-size: 2em;
	font-weight: bold;
	padding: 0 2%;
}
.price_text { }



/*--------- priceページスタイルここまで ----------- */








/*==================================================================
	99. SP
===================================================================*/
@media only screen and (max-width: 640px) {
	/* ------------------------------------------------------------------
		1. Base styles
	-------------------------------------------------------------------*/
	body {
		font-size: 3.44vw;
	}

	/*--------- Structure styles ----------- */
	.container {
		max-width: 100%;
		margin: 0 auto 20% auto;
	}

	/*--------- Block styles ----------- */
	.block {}

	/*--------- header styles ----------- */
	header{
		position: relative;
		height: 70px;
	}
	.header_logo{
		font-size: 13px;
		letter-spacing: -0.05em;
		padding-left: 10px;
		padding-top: 18px;
	}
	.header_logo span{
		font-size: 1.3em;
		font-weight: bold;
	}

	/*--------- footer styles ----------- */

	/*--------- nav styles ----------- */
	/*ハンバーガーボタン*/
	.hamburger {
	  top: 14px;
	  right: 10px;
	}
	nav.globalMenuSp {
		top: 70px;
		left: 0;
		right: 0;
		margin: auto;
	  width: 100%;
	}

	/* ------------------------------------------------------------------
		2. page styles
	-------------------------------------------------------------------*/

}


/*==================================================================
	WP style
===================================================================*/
.alignleft {
	display: inline;
	float: left;
	margin-right: 1.5em;
}

.alignright {
	display: inline;
	float: right;
	margin-left: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
}

img.alignleft,
img.alignright {
	float: none;
	margin: 0;
}
@media screen and (min-width: 30em) {
	/* Fix image alignment */
	img.alignleft {
		float: left;
		margin-right: 1.5em;
	}

	img.alignright {
		float: right;
		margin-left: 1.5em;
	}
}
