@charset "utf-8";

body {
    margin: 0;
    padding: 0;
	font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}

img{
	vertical-align: 0;
	border:0;
	width:100%;
}

ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

p,dl,dt,dd,h1,h2,h3,h4,h5,h6 {
  margin: 0;
}

.clearfix{
	clear:both;
}

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


header{
	width:100%;
}

.title_box{
	width:100%;
	text-align:center;
	margin:0 auto;
}

.title_logo,
.title_box_tel{
	margin:0;
	padding:0;
}

/*★パンくず指定★*/
.breadcrumb { 
	margin: 0 auto;
	padding: 10px 2.5%;
	list-style: none;
	width:100%;
	border-bottom:solid #ccc 1px;
	box-sizing:border-box;
	font-size:12px;
}

.breadcrumb li {
	display: inline;
	list-style: none;
	font-weight: bold;
}

.breadcrumb li:after {
	content: '>';
	padding: 0 0.2em;
	color: #000;
}

.breadcrumb li:last-child:after {
	content: '';
}

#wrap{
	width:100%;
	margin:0 auto;	
}

.main{
	width:100%;
	text-align:center;
	margin:0 auto 30px;
	font-size:15px;
}

.container,
.s_container,
.container_left,
.container_right{
	width:90%;
	text-align:left;
	margin:20px auto 30px;
	padding:0;	
}

/* ★img 横並び★ */
ul.info_box,
ul.list_box,
ul.list_box3{
	width:100%;
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:10px auto 0;
}
div.list_box2_inner{
	text-align:center;
	margin:0 auto;
}

ul.info_box li
div.list_box2_inner{
	width:100%;
	box-sizing: border-box;
	padding:5px;
	text-align:center;
}

ul.list_box li,ul.list_box3 li{
	width:50%;
	box-sizing: border-box;
	padding:5px;
	text-align:center;
}
ul.list_box li img{
	width:100%;
}

div.list_box2_inner img{
	width:90%;
}

ul.list_box3 li{
	width:100%;
}
ul.list_box3 li img{
	width:100%;
}

/* ★グルーバルメニュー★ */
nav.globalMenuSp {
    position: fixed;
	overflow-y: scroll;
    z-index: 2;
    top: 0;
    left: 0;
    background: #fff;
    color: #000;
    text-align: center;
    transform: translateY(-100%);
    transition: all 0.6s;
    width: 100%;
	height:100%;
}
 
nav.globalMenuSp ul {
    background: #ccc;
    margin: 0 auto;
    padding: 0;
    width: 100%;
}
 
nav.globalMenuSp ul li {
    font-size: 1.1em;
    list-style-type: none;
    padding: 0;
    width: 100%;
    border-bottom: 1px dotted #333;
}
 
/* 最後はラインを描かない */
nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
    border-bottom: none;
}
 
nav.globalMenuSp ul li a {
    display: block;
    color: #000;
    padding: 1em;
	text-align:left;
}
 
/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
    transform: translateY(0%);
}

/* ★ハンバーガーメニュー★ */
.navToggle {
    display: block;
    position: fixed;    /* bodyに対しての絶対位置指定 */
    right: 13px;
    top: 12px;
    width: 42px;
    height: 51px;
    cursor: pointer;
    z-index: 3;
    background: #666;
    text-align: center;
}
 
.navToggle span {
    display: block;
    position: absolute;    /* .navToggleに対して */
    width: 30px;
    border-bottom: solid 3px #eee;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 6px;
}
 
.navToggle span:nth-child(1) {
    top: 9px;
}
 
.navToggle span:nth-child(2) {
    top: 18px;
}
 
.navToggle span:nth-child(3) {
    top: 27px;
}
 
.navToggle span:nth-child(4) {
    border: none;
    color: #eee;
    font-size: 9px;
    font-weight: bold;
    top: 34px;
}

/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
    top: 18px;
    left: 6px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
 
/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2),
.navToggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* ★リンク指定★ */
a{
	color:#11389c;
}
a:hover{
	opacity: 0.8;
	text-decoration:none;
}

.breadcrumb li a {
	text-decoration: underline;
	color: #666;

}
.breadcrumb li a:hover {
	text-decoration: none;
}

a.btn_red{
	width:96%;
	max-width:700px;
	background-color:#cc1237;
	color:#ffffff;
	padding:4% 2%;
	margin:10px auto 0;
	text-align:center;
	text-decoration:none;
	display:block;
	border-radius:30px;
}

a.btn_orange{
	width:96%;
	max-width:700px;
	background-color:#ff7534;
	color:#ffffff;
	padding:4% 2%;
	margin:10px auto 0;
	text-align:center;
	text-decoration:none;
	display:block;
	border-radius:30px;
}

a.btn_green{
	width:96%;
	max-width:700px;
	background-color:#01af70;
	color:#ffffff;
	padding:4% 2%;
	margin:10px auto 0;
	text-align:center;
	text-decoration:none;
	display:block;
	border-radius:30px;
}

a.white_underline{
	text-decoration:underline;
	color:#ffffff;
}
a.white_underline:hover{
	text-decoration:none;
	color:#ffffff;
}

ul.info_box a{
	color:#000;
	font-size:14px;
	font-weight:bold;
	text-decoration:underline;
}
ul.info_box a:hover{
	text-decoration:none;
}

.price_other ul li a{
	color:#000;
	text-decoration:underline;
}


.dli-chevron-down { /*下矢印 白*/
	display: inline-block;
	vertical-align: middle;
	color: #fff;
	line-height: 1;
	width:1em;
	height: 1em;
	border: 1px solid currentColor;
	border-left: 0;
	border-bottom: 0;
	box-sizing: border-box;
	transform: translateY(-25%) rotate(135deg);
}

.dli-chevron-down2 { /*下矢印 色指定なし*/
	display: inline-block;
	vertical-align: middle;
	line-height: 1;
	width:1em;
	height: 1em;
	border: 1px solid currentColor;
	border-left: 0;
	border-bottom: 0;
	box-sizing: border-box;
	transform: translateY(-25%) rotate(135deg);
}

ul.price_page_link{
	width:100%;
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:20px auto 0;
}
ul.price_page_link li{
	width:33.3%;
	box-sizing: border-box;
	padding:7px;
	border:solid 1px #fff;
	text-align:center;
	background:#2f8ff2;
}

ul.price_page_link li p{
	line-height:1.3em;
}

ul.price_page_link a{
	display:block;
	color:#fff;
	font-weight:bold;
	text-decoration:none;
	font-size:12px;
}

.sitemap_wrap ul li a{
	color:#000;
	text-decoration:underline;
}

a.footer_tel{
	color:#cc1237;
	font-size:9vw;
	font-weight:bold;
	text-decoration:none;
	display:block;
	margin:10px 0 -10px 0;
}
a.footer_tel:hover{
	text-decoration:underline;
}

a.footer_tel_white{
	color:#ffffff;
	font-size:6vw;
	font-weight:bold;
	text-decoration:none;
	display:block;
	margin:0;
	padding:0;
}

.footer_wrap li a{
	display:block;
	color:#fbfabe;
	padding-top:10px;
}

ul.footer_menu li a{
	text-decoration:underline;
	color:#fff;
	padding:0;
	margin:0;
	font-size:13px;
}

/* ★テキスト指定★ */
.yellow_box{
	width:100%;
	background-color:#f7f8e4;
	border:1px solid #dfe0c7;
	text-align:left;
	padding:3%;
	box-sizing:border-box;
}

.yellow_box p{
	margin-top:15px;
}
.yellow_box p.top{
	margin-top:0;
}

.white_box{
	width:100%;
	background-color:#fff;
	text-align:left;
	padding:5%;
	box-sizing:border-box;
}

.normal_box{
	width:100%;
	text-align:left;
	padding:0;
	box-sizing:border-box;
}

.normal_box p{
	margin-top:20px;
}

p.info_small{
	border-top:1px dotted #999;
	font-size:13px;
	margin-top:15px;
	padding:15px 0 0;
}

.radius_red_box{
	box-sizing:border-box;
	width:100%;
	max-width:800px;
	background-color:#cc1237;
	text-align:center;
	margin:10px auto;
	padding:2%;
	border-radius:10px;
	color:#ffffff;
	font-size:16px;
}

.yellow_box_red{
	padding:10px;
	background:#f2fb01;
	color:#fd0819;
	font-weight:bold;
	font-size:20px;
}

.category_sub{
	font-size:20px;
	padding: 0.25em 0.5em;
	margin:30px 0 10px;
	border-left: solid 5px #cc1237;
	line-height:1.5em;
}

.camp_box{
	margin:20px 0 0;
	padding:0;
}

.camp_box p{
	padding-bottom:20px;
}

.camp_box p:last-child{
	padding-bottom:0;
}


.sub_txt{
	text-align:left;
	margin:10px auto 20px;
	padding:0;
}

.bk_bold{
	font-weight:bold;
}

.bk_bold_xl{
	font-weight:bold;
	font-size:20px;
	margin:10px auto;
	text-align:center;
	line-height:1.3;
}

ul.dotted_yoko{
	margin-bottom:10px;
}

ul.dotted_yoko li{
	display: inline;
	padding-right:5px;
	line-height:1;
}

ul.dotted_yoko_br li{
	padding-right:5px;
	line-height:1.2;
}

ul.dotted_yoko li:before{
	content:'●';
	color: #cc1237;
	font-size:140%;
}

ul.dotted_yoko_br li:before{
	content:'●';
	color: #cc1237;
	font-size:140%;
}


.txt_small{
	font-size:12px;
}

.txt_small_sp{
	font-size:12px;
}

.txt_white_s{
	font-size:12px;
	color:#ffffff;
}

span.tax{
	font-size:15px;
}

span.tax_s{
	font-size:9px;
}

/* ★margin指定★ */
.mt5{
	margin-top:5px;
}
.mt10{
	margin-top:10px;
}
.mt20{
	margin-top:20px;
}
.mt30{
	margin-top:30px;
}
.mb5{
	margin-bottom:5px;
}
.mb10{
	margin-bottom:10px;
}
.mb20{
	margin-bottom:20px;
}
.mb30{
	margin-bottom:30px;
}
.mb40{
	margin-bottom:40px;
}
.mb50{
	margin-bottom:50px;
}

.center{
	text-align:center;
	margin:0 auto;
}
.right{
	text-align:right;
	margin:0 auto;
}

/* ★見出し指定 h1～h4★ */
h1{
	font-weight:normal;
	font-size: 8vw;
	margin:12px 0 12px 13px;
	text-align:left;
}
h1 a{
	background:none;
	text-decoration:none;
	color:#000000;
}
h1 a:hover{
	background:none;
	text-decoration:underline;
	color:#000000;
	opacity: 1;
}
h1.footer_address{
	font-weight:normal;
	font-size:6vw;
	color:#ffffff;
	margin:0;
	padding:0;
}
h1.footer_address a{
	background:none;
	text-decoration:underline;
	color:#ffffff;
}
h1.footer_address a:hover{
	background:none;
	text-decoration:none;
	color:#ffffff;
	opacity: 1;
}

h2 {
	font-size:26px;
	font-weight:bold;
	padding:0;
	margin:0;
	line-height:1.3em;
}

h2.category_name {
	font-size:14px;
	font-weight:bold;
	padding:0;
	margin:0;
	line-height:1.3em;
}

h2.category_name_w {
	font-size:25px;
	font-weight:bold;
	padding:0;
	margin:0;
	line-height:1.3em;
	color:#ffffff;
}

h3{
	border-top:3px solid #cc1237;
	border-bottom:1px solid #cccccc;
	margin:20px auto 10px;
	padding:10px 0;
	font-size:25px;
	font-weight:normal;
	line-height:1.3em;
}

h3.kakko_simple {
	position: relative;
	line-height: 1.4;
	padding:0.25em 4em;
	display: inline-block;
	top:0;
	border:none;
}

h3.kakko_simple:before, h3.kakko_simple:after { 
  position: absolute;
  top: 0;
  content:'';
  width: 8px;
  height: 100%;
  display: inline-block;
}
h3.kakko_simple:before {
  border-left: solid 1px black;
  border-top: solid 1px black;
  border-bottom: solid 1px black;
  left: 0;
}
h3.kakko_simple:after {
  content: '';
  border-top: solid 1px black;
  border-right: solid 1px black;
  border-bottom: solid 1px black;
  right: 0;
}

h3.marker_s{
	border-top:none;
	border-bottom:2px solid #cccccc;
	position: relative;	
	margin:0 auto;
	padding:0 0 10px;
	font-size:23px;
	font-weight:normal;
	line-height:1.3em;
}
h3.marker_s:after{
	position: absolute;
	content: " ";
	display: block;
	border-bottom: solid 2px #cc1237;
	bottom: -2px;
	width: 30%;
}

h4{
	font-size:16px;
	padding: 0.5em 0 0 0;
	font-weight:bold;
	line-height:1.3em;
}

h4.footer_title{
	font-weight:normal;
	font-size:6vw;
	color:#ffffff;
	margin:30px 0 0 0;
	padding:0;
}

h5.kakko{
	position: relative;
	padding:0.25em 1em;
	display: inline-block;
	font-size:18px;
	margin-bottom:10px;
	color:#000;
}
h5.kakko:before, h5.kakko:after { 
	content:'';
	width: 15px;
	height: 20px;
	position: absolute;
	display: inline-block;
}
h5.kakko:before {
	border-left: solid 4px #cc1237;
	border-top: solid 4px #cc1237;
	top:0;
	left: 0;
}
h5.kakko:after {
	border-right: solid 4px #cc1237;
	border-bottom: solid 4px #cc1237;
	bottom:0;
	right: 0;
}

h5.marker{
	background: linear-gradient(transparent 60%, #ffff66 60%);
}

h5.dotted_underline{
	border-bottom:dotted 1px #cccccd;
	font-size:20px;
	font-weight:normal;
	margin-bottom:10px;
}

/* ☆会社概要☆ */
/* ★テーブル★ */
table, th, td {
	width:100%;
	border-collapse: collapse;
	border: 1px solid #ccc;
	line-height: 1.5em;
}

table.type01 th {
	width: 20%;
	padding: 10px;
	font-weight: bold;
	vertical-align: top;
}
table.type01 td {
	width: 80%;
	padding: 10px;
	vertical-align: middle;
}

tr:nth-child(even) {
	background:#d9d9d9;
}

table.type01 td dt{
	text-decoration:underline;
}

table.type01 td dd{
	margin-bottom:20px;
}

table.type02 caption,
table.type03 caption {
	padding: 10px;
	font-weight: bold;
	background-color:#666666;
	color:#FFF;
}

table.type02 th {
	width: 30%;
	padding: 10px;
	font-weight: bold;
	vertical-align: top;
	background-color:#fff;
}
table.type02 td {
	width: 70%;
	padding: 10px;
	vertical-align: middle;
	background-color:#fff;
}

table.type03 th {
	width: 50%;
	padding: 10px;
	font-weight: bold;
	vertical-align: top;
	background-color:#fff;
}
table.type03 td {
	width: 50%;
	padding: 10px;
	vertical-align: middle;
	background-color:#fff;
}

/* ★Google map★ */
.map {
	text-align:center;
	margin:0 auto;
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 60%;
}

.map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* ☆施工までの流れ☆ */
.flow_box{
	border:3px solid #ccc;
	box-sizing:border-box;
	padding:4%;
	margin:20px auto 0;
	width:100%;
}

.flow_box dt{
	border-bottom:1px solid #ccc;
	box-sizing:border-box;
	margin:0 auto 10px;
	padding:0 0 5px 0;
	width:100%;
	font-weight:bold;
	font-size:20px;
	display:block;
	line-height:1.3em;
}

.img_flow{
	margin:10px auto 0;
	width:80%;
}

.triangle{ /*▼*/
	width: 0;
	height: 0;
	border-left: 20px solid transparent;
	border-right: 20px solid transparent;
	border-top: 20px solid #ccc;
	text-align:center;
	margin:20px auto;
}

.oneArea { /*吹き出し*/
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	max-width: 1024px;
	margin: 30px auto;
	padding: 0 10px;
}
.oneArea .onebox {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}
.oneArea .onebox:nth-child(even) {
	flex-direction: row-reverse;
	margin-top: 20px;
}
.oneArea .onebox .imgArea {
	width: 16%;
	position: relative;
}
.oneArea .onebox .imgArea img {
	width: 100%;
	max-width: 90px;
	position: absolute;
	top: 0;
}
.oneArea .onebox:nth-child(odd) .imgArea img {
	left: 0;
	padding-right: 30px;
}
.oneArea .onebox:nth-child(even) .imgArea img {
	right: 0;
	padding-left: 30px;
}
.oneArea .onebox .fukiArea {
	width: 82%;
}
.oneArea .onebox .fukidasi {
	width: 100%;
	position: relative;
	padding: 25px;
	background-color: #f2f3f7;
	color: #231815;
	border-radius: 12px;
	box-sizing: border-box;
}
.oneArea .onebox .fukidasi::before {
	content: '';
	position: absolute;
	display: block;
	top: 22px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 15px 30px 15px 0;
	border-color: transparent #f2f3f7 transparent transparent;
}
.oneArea .onebox:nth-child(odd) .fukidasi::before {
	left: -15px;
}
.oneArea .onebox:nth-child(even) .fukidasi {
	background-color: #fde5e5;
}
.oneArea .onebox:nth-child(even) .fukidasi::before {
	right: -15px;
	border-color: transparent #fde5e5 transparent transparent;
	transform: rotate(180deg);
}



/* ☆FAQ☆ */
.faq dt{
	padding-bottom: 20px;
	border-bottom: 1px dotted #dddddd;
	font-weight: bold;
	font-size:17px;
}
.faq dt:before{
	content: "Q";
	font-weight: normal;
	background: #cc0000;
	color: #fff;
	width: 1.5em;
	height: 1.5em;
	line-height: 1.6;
	text-align: center;
	display: inline-block;
	border-radius: 1em;
	margin-right: .5em;
}
.faq dd{
	margin-bottom: 20px;
	padding-top:20px;
	padding-bottom:20px;
	border-bottom: 1px solid #666666;
	font-size:17px;
}
.faq dd:before{
	content: "A";
	font-weight: normal;
	background: #097cb7;
	color: #fff;
	width: 1.5em;
	height: 1.5em;
	line-height: 1.6;
	text-align: center;
	display: inline-block;
	border-radius: 1em;
	margin-right: .5em;
}
.faq dd:last-child{
	margin-bottom: 0;
}

/* ☆料金設定☆ */
.price_box_flex{
	width:100%;
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:20px auto 0;
	text-align:center;
}
.price_box_wrap,
.price_box_wrap_l{
	width:100%;
	margin-bottom:20px;
	box-sizing: border-box;
	background:#f7f8e4;
	border:3px solid #cc1237;
	text-align:center;
}

dl.price_title{
	background-color:#cc1237;
	padding:10px;
}

dl.price_title dd{
	font-size:10vw;
	font-weight:bold;
	color:#f2fb01;
}

.price_box_inner{
	padding:3% 5% 5%;
	margin:0 auto;
	text-align:left;
}

ul.list_worry{
	padding:0;
	margin:0 auto;
	text-align:left;
	font-size:17px;
}

ul.list_worry li{
    position: relative;
    padding-left: 20px;
}
 
ul.list_worry li:before {
    content: "";
    position: absolute;
    top: .1em;
    left: 0;
    -webkit-transform: rotate(50deg);
    -ms-transform: rotate(50deg);
    transform: rotate(50deg);
    width: 5px;
    height: 10px;
    border-right: 3px solid #cc1237;
    border-bottom: 3px solid #cc1237;
}

dl.price_type{
	padding:0;
	margin:5% 0;
	border-top:solid 1px #cc1237;
}

dl.price_type dt{
	float:left;
	padding:10px 0;
	width:75%;
}

dl.price_type dd{
	float:right;
	padding:10px 0;
	width:25%;
	text-align:right;

}

.red_underline{
	height:1px;
	background-color:#cc1237;
	clear:both;
	display:block;
}

.price_other{
	width:100%;
	margin:0;
	padding:20px 0 10px;
	box-sizing:border-box;
}

.price_other ul li{
	padding:15px 0;
	border-bottom:1px solid #ccc;
}

.price_other ul li.now{
	background: #f5f5f5;
}

/* ☆トップページ☆ */
/* ★メインビジュアル★ */
.main_visual_wrap {
	width: 100%;
	height: auto;
	margin: 0 auto;
	position: relative;
}
.main_visual {
	width: 100%;
	height: 100%;
	margin: 0 auto;
}
.sub_title {
	width:100%;
	text-align:center;
	font-size: 7vw;
	font-weight:normal;
	color: #fff;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	text-shadow: 1px 2px 3px #000000;
}
.sub_title p{
	font-size:14px;
	line-height:1.5em;
}

.header_title{
	width:100%;
	text-align:center;
	margin:0 auto;
	padding:30px 0;
	background-color:#cc1237;
	color:#ffffff;
	font-size:20px;
}


/* ★カテゴリ★ */
.category_box_flex{
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.category_box_flex > div.bg_category_wrap{
	width: 50%;
	height: auto;
	box-sizing: border-box;
	padding:5px;
	position: relative;
}

.bg_category_wrap img{
	border-radius: 10px;
}

.bg_category {
	width: 100%;
	margin: 0 auto;
}
.sub_price {
	width:100%;
	text-align:center;
	font-size: 6vw;
	font-weight:bold;
	color: #f2fb01;
	position: absolute;
	top: 40%;
	left: 50%;
	transform: translate(-50%,-50%);
	text-shadow: 1px 2px 3px #000000;
}

ul.list_txt{
	padding-left:16px;
	list-style-type:disc;
	line-height:2em;
}

/* ☆サイトマップ☆ */
.sitemap_wrap {
    padding: 0px;
    margin: 0px;
    list-style: none;
	line-height:2.5em;
	width:100%;
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.sitemap_wrap ul{
	width:100%;
}

.sitemap_wrap ul li {
    position: relative;
    padding: 0px 0px 0px 1em;
}
.sitemap_wrap ul li::before {
    position: absolute;
    top: 50%;
    left: 0px;
    transform: translateY(-50%);
    width: 0px;
    height: 0px;
    border: 0.3em solid transparent;
    border-left: 0.4em solid #2f8ff2;
    content: "";
}

.sitemap_wrap ul li.s2{
    position: relative;
    padding: 0px 0px 0px 2.5em;
}
.sitemap_wrap ul li.s2::before {
    position: absolute;
    top: 50%;
    left: 1.5em;
    transform: translateY(-50%);
    width: 0px;
    height: 0px;
    border: 0.3em solid transparent;
    border-left: 0.4em solid #2f8ff2;
    content: "";
}

.sitemap_wrap ul li.s3{
    position: relative;
    padding: 0px 0px 0px 4em;
}
.sitemap_wrap ul li.s3::before {
    position: absolute;
    top: 50%;
    left: 3em;
    transform: translateY(-50%);
    width: 0px;
    height: 0px;
    border: 0.3em solid transparent;
    border-left: 0.4em solid #2f8ff2;
    content: "";
}

.sitemap_wrap ul li.s4{
    position: relative;
    padding: 0px 0px 0px 5.5em;
}
.sitemap_wrap ul li.s4::before {
    position: absolute;
    top: 50%;
    left: 4.5em;
    transform: translateY(-50%);
    width: 0px;
    height: 0px;
    border: 0.3em solid transparent;
    border-left: 0.4em solid #2f8ff2;
    content: "";
}

/* ★フッター★ */
footer{
	background-color:#3a3732;
	width:100%;
	margin:0 auto;
	padding:0;
}

.footer_wrap{
	width:95%;
	margin:0 auto;
	padding:10px 0;
	color:#ffffff;
}

.footer_tel_box{
	text-align:center;
}

ul.footer_sns{
	display: flex;
	text-align:center;
	margin:10px auto;
	width:60%;
}
ul.footer_sns li img{
	width:80%;
}


.footer_menu_wrap{
	text-align: center;
	padding: 10px 0 0 0;
}

ul.footer_menu {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}
ul.footer_menu li {
	width: 50%;
	margin: 0;
	padding: 0 20px;
	box-sizing: border-box;
	border: none;
	line-height:1.8em;
}
ul.footer_menu li:nth-child(odd) {
	border-right: 1px #808080 solid;
}

address{
	width:100%;
	background-color:#000000;
	color:#ffffff;
	text-align:center;
	margin:0 auto;
	padding:20px 0 150px;
	font-size:12px;
	font-style:normal;
}

/* ★フッター追従する連絡先★ */
.foot_info{
	position: fixed;
	display: flex;
	left: 0;
	bottom: 0;
	width: 100%;
	padding:5px 0;
	/* 1. メニューを画面下へ隠す */
	transform: translateY(100%);
	/* 2. 0.3秒かけて表示する */
	transition: .3s;
	background-color:#cc1237;
	background-repeat:no-repeat;
	box-shadow: 0 -5px 5px 0px rgb(0 0 0 / 60%);
}
.active{
	/* 3. メニューを定位置へ戻す */
	transform: translate(0);
}

.foot_h{
	width:100%;
	position:absolute;
	top:0;
	background-color:#000000;
	border-top:solid #ffffff 1px;
	color:#fff;
	font-size:12px;
	text-align:center;
	padding:2% 0;
	margin:0;
	
}
.foot_info ul{
	width:100%;
	position:relative;
	padding:10% 0 0%; 
}
.foot_info ul li.tel{
	width:50%;
	margin:0 0 0 2%;
	padding:0;
	float:left;
}
.foot_info ul li.mail{
	width:15%;
	float:right;
	margin:0 1% 0 0;
	padding:0;
}
.foot_info ul li.mail img{
	width:100%;
}

/* ★ツイッター表示★ */
.twitter{
	margin-top:20px;
}
.timeline-Widget {
	padding: 20px;
	background-size: auto auto;
	background-color: #3c3c3c;
	background-image: repeating-linear-gradient(45deg, transparent, transparent 10px, #323232 10px, #323232 20px)
}
.timeline-TweetList-tweet {
	color: #fff
}
.SandboxRoot.env-bp-660 .timeline-Header-byline, .SandboxRoot.env-bp-660 .timeline-Header-subtitle, .SandboxRoot.env-bp-820 .timeline-Header-byline, .SandboxRoot.env-bp-820 .timeline-Header-subtitle, .SandboxRoot.env-bp-970 .timeline-Header-byline, .SandboxRoot.env-bp-970 .timeline-Header-subtitle {
	color: #fff !important
}
.timeline-Header-title {
	color: #fff !important;
	font-size: 20px !important
}
.timeline-Header-title a {
	color: #fff !important
}
.timeline-Tweet {
	transition: background-color .3s
}
.timeline-Tweet:hover {
	background-color: rgba(0, 0, 0, .2)
}
.TwitterCard-container--clickable:hover {
	background-color: rgba(0, 0, 0, .2)
}



/*じもと券用横並びbox */
#jimoto_box{
	display:flex;
	align-items: center;
	}
	
	#jimoto_box .box01{
	width:60%;
	}
#jimoto_box .box02{
	width:40%;
	}


.red_box {
	border: 2px double #CC0000;
	margin: 1%;
	padding: 1%;
}

.fnt24{
	
	font-weight:bold;}











@media screen and (min-width: 960px) { /* ↓↓ PCここから ↓↓ */

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

.br-sp {display: none; } /* ★スマホだけ改行★ */

.pc_center{
	text-align:center;
}

#wrap{
	max-width:1000px;
	width:100%;
	margin:0 auto;	
}

 /* ★ヘッダー★ */
.title_box{
	width:1000px;
	text-align:center;
	margin:0 auto;
}

.title_logo{
	width:600px;
	float:left;
}

.title_box_tel{
	width:400px;
	text-align:right;
	float:right;
	font-size:36px;
	font-weight:bold;
	text-decoration:none;
	margin:10px 0 0 0;
	padding:0;
}
p.tel_small{
	font-size:16px;
	font-weight:normal;
	margin-top:-8px;
}


.container{
	width:100%;
	font-size:18px;
	margin-bottom:50px;
}

.s_container{
	width:100%;
	max-width:800px;
	font-size:18px;
	margin-bottom:50px;
	line-height:1.8em;
}

.radius_red_box{
	padding:1%;
	font-size:18px;
}

/*★パンくず指定★*/
.breadcrumb { 
	padding:10px 0;
	list-style: none;
	width:1000px;
}

/* ★img 2列横並び★ */
.list_box2{
	width:100%;
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:20px auto 0;
}
.list_box2_inner{
	width:50%;
	box-sizing: border-box;
	padding:5px;
	text-align:center;
}

ul.list_box3 li{
	width:50%;
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:20px auto 0;
}

ul.list_box li img{
	width:80%;
}

.list_box2_inner img{
	width:70%;
}

.list_box3 li img{
	width:100%;
}

/* ★img 3列横並び★ */
ul.info_box{
	width:100%;
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:20px auto 0;
}
ul.info_box li{
	width:33.3%;
	box-sizing: border-box;
	padding:5px;
}
ul.info_box li p{
	font-size:17px;
}

/* ★見出し指定 h1～h4★ */
h1{
	font-weight:normal;
	font-size: 38px;
	margin:12px 0 12px;
	text-align:left;
}

h1.footer_address{
	font-weight:normal;
	font-size:30px;
	color:#ffffff;
	margin:0;
	padding:0;
}
h1.footer_address a{
	background:none;
	text-decoration:underline;
	color:#ffffff;
}
h1.footer_address a:hover{
	background:none;
	text-decoration:none;
	color:#ffffff;
	opacity: 1;
}

h2 {
	font-size:35px;
	font-weight:bold;
	padding:0;
	margin:0;
	line-height:1.3em;
}

h2.category_name {
	font-size:18px;
	font-weight:bold;
	padding:0;
	margin:0;
	line-height:1.3em;
}

h3{
	border-top:3px solid #cc1237;
	border-bottom:1px solid #cccccc;
	margin:20px auto 10px;
	padding:20px 0;
	font-size:35px;
	font-weight:normal;
	line-height:1.3em;
}

h3.kakko_simple {
	padding:0.25em 9em;
	margin-bottom:30px;
}

h3.marker_s{
	border-top:none;
	border-bottom:2px solid #cccccc;
	position: relative;	
	margin:0 auto;
	padding:0 0 10px;
	font-size:20px;
	font-weight:normal;
	line-height:1.3em;
}
h3.marker_s:after{
	position: absolute;
	content: " ";
	display: block;
	border-bottom: solid 2px #cc1237;
	bottom: -2px;
	width: 30%;
}

h4{
	font-size:20px;
	padding: 0.5em 0 0 0;
	font-weight:bold;
	line-height:1.5em;
}

h4.footer_title{
	font-weight:normal;
	font-size:40px;
	color:#ffffff;
	margin:0;
	padding:0;
}


/* ★リンク指定★ */
.breadcrumb li a {
	text-decoration: none;
	color: #666;

}
.breadcrumb li a:hover {
	text-decoration: underline;
}

.price_other ul li a{
	color:#000;
	text-decoration:none;
}
.price_other ul li a:hover{
	color:#000;
	text-decoration:underline;
	opacity: 1;
}

a.footer_tel{
	color:#cc1237;
	font-size:30px;
	font-weight:bold;
	text-decoration:none;
	display:block;
	margin:10px 0 0 0;
}
a.footer_tel:hover{
	text-decoration:underline;
}

a.btn_red{
	width:96%;
	max-width:700px;
	padding:2%;
}
a.btn_orange{
	width:96%;
	max-width:700px;
	padding:2%;
}
a.btn_green{
	width:96%;
	max-width:700px;
	padding:2%;
}

.sitemap_wrap ul li a{
	color:#000;
	text-decoration:none;
}
.sitemap_wrap ul li a:hover{
	color:#11389c;
	text-decoration:underline;
	opacity: 1;
}

ul.footer_menu li a{
	text-decoration:none;
	font-size:14px;
}
ul.footer_menu li a:hover{
	text-decoration:underline;
}


/* ★テキスト指定★ */
.sub_txt{
	text-align:center;
	margin:30px auto 40px;
	padding:0;
}

.normal_box p{
	margin-top:30px;
}

.txt_small_sp{
	font-size:18px;
}

.bk_bold_xl{
	font-weight:bold;
	font-size:28px;
	margin:20px auto 10px;
	text-align:center;
}

ul.dotted_yoko li{
	display: inline;
	padding-right:10px;
	line-height:0;
}
ul.dotted_yoko_br li{
	padding-right:10px;
	line-height:1.3;
}

ul.dotted_yoko li:before{
	content:'●';
	color: #cc1237;
	font-size:180%;
}

/* ★テーブル★ */
table, th, td {
	width:100%;
	border-collapse: collapse;
	border: 1px solid #ccc;
	line-height: 1.8em;
}

table.type01 th {
	width: 20%;
	padding: 20px;
	font-weight: bold;
	vertical-align: top;
}
table.type01 td {
	width: 80%;
	padding: 20px;
	vertical-align: middle;
}

/* ★Google map★ */
.map {
	text-align:center;
	margin:0 auto;
	position: relative;
	width: 80%;
	height: 0;
	padding-top: 50%;
}

/* ☆施工までの流れ☆ */
.flow_box dt{
	font-size:23px;
}

.img_flow{
	margin:10px auto 0;
	width:50%;
}

.oneArea { /*吹き出し*/
	margin: 50px auto;
}
.oneArea .onebox .fukiArea {
	width: 72%;
}
.oneArea .onebox:nth-child(odd) .fukidasi::before {
	left: -20px;
}
.oneArea .onebox:nth-child(even) .fukidasi::before {
	right: -20px;
}

.oneArea .onebox .imgArea {
	width: 12%;
}

/* ☆FAQ☆ */
.faq dt{
	font-size:20px;
}
.faq dd{
	font-size:20px;
}

/* ☆料金設定☆ */
.price_box_wrap{
	width:48%;
	margin:1%;
	box-sizing:border-box;
}

dl.price_title dd{
	font-size:55px;
}

.price_box_wrap_l{
	width:66%;
	margin:0;
	box-sizing:border-box;
	float:left;
	text-align:center;
}

.price_other{
	width:30%;
	margin:0 auto;
	padding:10px 0 0 0;
	box-sizing:border-box;
	float:right;
	font-size:15px;
}

.price_other ul li{
	padding:15px 0;
	border-bottom:1px solid #ccc;
}

ul.price_page_link li{
	width:25%;
}

ul.price_page_link a{
	font-size:14px;
}

.white_box{
	width:100%;
	background-color:#fff;
	text-align:left;
	padding:3%;
	box-sizing:border-box;
	line-height:1.7em;
}
p.info_small{
	border-top:1px dotted #999;
	font-size:14px;
	margin-top:15px;
	padding:15px 0 0;
	line-height:1.6em;
}

/* ★メインビジュアル★ */
.sub_title {
	width:100%;
	text-align:center;
	font-size: 45px;
}
.sub_title p{
	font-size:25px;
	line-height:1.5em;
}

/* ★カテゴリ★ */
.category_sub{
	font-size:25px;
	padding: 0.25em 0.5em;
	margin:30px 0 10px;
	border-left: solid 5px #cc1237;
}

.category_box_flex > div.bg_category_wrap{
	width: 33.3%;
	height: auto;
	box-sizing: border-box;
	padding:10px;
	position: relative;
}

.sub_price {
	width:100%;
	text-align:center;
	font-size: 50px;
	font-weight:bold;
	color: #f2fb01;
	position: absolute;
	top: 48%;
	left: 50%;
	transform: translate(-50%,-50%);
	text-shadow: 1px 2px 3px #000000;
}

/* ☆サイトマップ☆ */
.sitemap_wrap {
	font-size:15px;
}

.sitemap_wrap ul{
	width:50%;
}

/* ★フッター★ */
footer{
	width:100%;
	margin:0 auto;
	text-align:center;
	padding:0;
}

.footer_wrap{
	max-width:1000px;
	width:100%;
	margin:0 auto;
	padding:40px 0 10px;
	color:#ffffff;
}

.footer_tel_box{
	text-align:left;
	margin-bottom:40px;
}

.container_left{
	width:45%;
	float:left;
	font-size:18px;
}
.container_right{
	width:45%;
	float:right;
}

ul.footer_sns{
	display: flex;
	text-align:center;
	margin:10px auto;
	width:60%;
}
ul.footer_sns li img{
	width:80%;
}

.footer_menu_wrap{
	text-align: center;
	padding: 30px 0 0 0;
}

ul.footer_menu {
	width:100%;
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
ul.footer_menu li {
	width:16.6%;
	margin: 0;
	padding: 0 10px;
	border-right: 1px #808080 solid;
	box-sizing:border-box;
}
ul.footer_menu li:last-child {
	border: none;
}

address{
	width:100%;
	background-color:#000000;
	color:#ffffff;
	text-align:center;
	margin:0 auto;
	padding:30px 0;
	font-size:12px;
	font-style:normal;
}




/*++++++++++++++++++++++++++++++++++++++++++++++*/
/* blog style                                   */
/*++++++++++++++++++++++++++++++++++++++++++++++*/




#feed {
	width: 100%;
	height: 500px;
	margin: 0;
	overflow-y: scroll;
	font-size: medium;
	}
#feed img {
	width: 150px !important;
	height: auto !important;
	margin: 0;
	}
#feed ul li {
	line-height:1.8em;
	margin:0 0 10px -40px;
	padding-bottom:10px;
	list-style: none;
	border-width: 0 0 1px 0;
	border-bottom: dotted;
	border-color: #cccccc;
		overflow: hidden;
	}
	#feed ul li a {
	text-align: left !important;
	}
#feed ul li p.wp {
	font-weight: bold;
	margin-bottom: 6px;

	}
#feed ul li div {
	float:left;
	margin-right:8px;
	}
#feed ul li p.day {
	text-align:right;
	margin:6px 6px 0 0;
	}



/*じもと券用横並びbox */
#jimoto_box{
	display:flex;
	align-items: center;
	}
	
	#jimoto_box .box01{
	width:50%;
	}
#jimoto_box .box02{
	width:45%;
	}
	.fnt24{
		font-size:24px;
	font-weight:bold;}

}.fnt16 {
	font-size: 16px;
}
