@charset "utf-8";
/*
Theme Name: nakao_themes_2026_v1
Theme URI:
Description: nakao_themes_2026_v1
Version: 1.0
Author: Cloud template
Author URI:
Tags: simple
*/

/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
	-webkit-text-size-adjust: none;
}

:focus {
	outline: 0;
}

ol,
ul {
	list-style: none;
}

table {
	border-collapse: separate;
	border-spacing: 0;
}

caption,
th,
td {
	font-weight: normal;
	text-align: left;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
}

blockquote,
q {
	quotes: "" "";
}

a img {
	border: 0;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

body {
	color: #333333;
	line-height: 1.6;
	font-size: 93.75%;
	font-family: "メイリオ", Meiryo, Osaka, " ヒラギノ角ゴ ProW3", "Hiragino Kaku Gothic Pro", " ＭＳ Ｐゴシック", "MSPGothic", sans-serif;
	text-align: justify;
}

/* リンク設定
------------------------------------------------------------*/
a {
	margin: 0;
	padding: 0;
	text-decoration: none;
	outline: 0;
	vertical-align: baseline;
	background: transparent;
	font-size: 100%;
	color: #333333;
}

a:hover,
a:active {
	-webkit-transition: opacity 0.1s;
	-moz-transition: opacity 0.1s;
	-o-transition: opacity 0.1s;
	outline: none;
	color: #666666;
}

/**** Clearfix ****/
nav .panel:after,
nav#mainNav:after,
.newsTitle:after,
.bg:after,
.post:after {
	content: "";
	display: table;
	clear: both;
}

nav .panel,
nav#mainNav,
.newsTitle,
.bg,
.post {
	zoom: 1;
}


/*
=========================================
	02.Utilities
=========================================
*/
/* フォントサイズ%指定16px基準
 10px = 62.50%    11px = 68.75%     12px = 75.00%     13px = 81.25%
 14px = 87.50%    15px = 93.75%    	16px = 100.01%  	17px = 106.25%
 18px = 112.50%  	19px = 118.75%  	20px = 125.00%  	21px = 131.25%
 22px = 137.50%   23px = 143.75%    24px = 150.00%    25px = 156.25%
 26px = 162.50% 	27px = 162.50% 		28px = 175.00% 		29px = 181.25%
 30px = 187.50%		31px = 193.75%	 	31px = 200.00%
*/
---------------------------------*/ .text10 {
	font-size: 62.50% !important;
}

.text11 {
	font-size: 68.75% !important;
}

.text12 {
	font-size: 75.00% !important;
}

.text13 {
	font-size: 81.25% !important;
}

.text14 {
	font-size: 87.50% !important;
}

.text15 {
	font-size: 93.75% !important;
}

.text16 {
	font-size: 100.00% !important;
}

.text17 {
	font-size: 106.25% !important;
}

.text18 {
	font-size: 112.50% !important;
}

.text19 {
	font-size: 118.75% !important;
}

.text20 {
	font-size: 125.00% !important;
}

.text21 {
	font-size: 131.25% !important;
}

.text22 {
	font-size: 137.50% !important;
}

.text23 {
	font-size: 143.75% !important;
}

.text24 {
	font-size: 150.00% !important;
}

.text25 {
	font-size: 156.25% !important;
}

.text26 {
	font-size: 162.50% !important;
}

.text27 {
	font-size: 162.50% !important;
}

/* マージン
---------------------------------*/
.mb0 {
	margin-bottom: 0 !important;
}

.mb5 {
	margin-bottom: 5px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb15 {
	margin-bottom: 15px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb25 {
	margin-bottom: 25px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb35 {
	margin-bottom: 35px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb45 {
	margin-bottom: 45px !important;
}

.mb50 {
	margin-bottom: 50px !important;
}

.ml0 {
	margin-left: 0 !important;
}

.ml5 {
	margin-left: 5px !important;
}

.ml10 {
	margin-left: 10px !important;
}

.ml15 {
	margin-left: 15px !important;
}

.ml20 {
	margin-left: 20px !important;
}

.ml25 {
	margin-left: 20px !important;
}

.ml30 {
	margin-left: 30px !important;
}

.mr0 {
	margin-right: 0 !important;
}

.mr5 {
	margin-right: 5px !important;
}

.mr10 {
	margin-right: 10px !important;
}

.mr15 {
	margin-right: 15px !important;
}

.mr20 {
	margin-right: 20px !important;
}

.mr25 {
	margin-right: 25px !important;
}

.mr30 {
	margin-right: 30px !important;
}

/* パディング
---------------------------------*/
.pt0 {
	padding-top: 0 !important;
}

.pt5 {
	padding-top: 5px !important;
}

.pt10 {
	padding-top: 10px !important;
}

.pt15 {
	padding-top: 15px !important;
}

.pt20 {
	padding-top: 20px !important;
}

.pt25 {
	padding-top: 25px !important;
}

.pt30 {
	padding-top: 30px !important;
}

/* 左右行揃え
---------------------------------*/
.ta-l {
	text-align: left;
}

.ta-r {
	text-align: right;
}

.ta-c {
	text-align: center;
}

/* フロート／フロート解除
---------------------------------*/
.fl {
	float: left;
}

.fr {
	float: right;
}

.fl-img {
	float: left;
	margin-right: 10px;
	margin-bottom: 10px;
}

.fr-img {
	float: right;
	margin-left: 10px;
	margin-bottom: 10px;
}

.clear {
	clear: both;
}

/* clearfix */
.cf:before,
.cf:after {
	content: " ";
	display: table;
}

.cf:after {
	clear: both;
}

.cf {
	*zoom: 1;
}

/* 表示非表示切り替え／
---------------------------------*/
/* スマホ表示 */
.sp {
	display: inline-block !important;
}

.pc {
	display: none !important;
}

/* PC表示 */
@media screen and (min-width: 640px) {
	.sp {
		display: none !important;
	}

	.pc {
		display: inline-block !important;
	}
}

.ib {
	display: inline-block;
}

@font-face {
	font-family: "din";
	src: url("font/din1451alt_G.eot") format('eot'),
		url("font/din1451alt_G.woff2") format('woff2'),
		url("font/din1451alt_G.woff") format('woff');
}

/* H4 H5 H6
---------------------------------*/
h5 {
	width: 100%;
	margin: 0 0 20px;
	padding: 0;
	text-align: left;
	vertical-align: bottom;
	height: 60px;
}

h5#ttlRepair {
	background-color: #b1deed;
}

h5#ttlconstruction {
	background-color: #f5ca80;
}

h5#ttlhouse {
	background-color: #cfe398;
}

h5#ttlKaden {
	background-color: #80b8dd;
}

h6 {
	width: 100%;
	margin: 0 0 10px;
	padding: 7px 0 6px;
	background-color: #c80028;
	font-size: 113.3333%;
	color: #ffffff;
	text-align: center;
	line-height: 1;
	letter-spacing: 2px;
	box-sizing: border-box;
}

/* ポスト
*****************************************************/
h2.title {
	clear: both;
	padding: 16px 0 6px 6px;
	margin: 0 0 10px;
	font-size: 133.3333%;
	font-weight:
		border: 0px solid #dadada;
	border-bottom: 5px solid #dc0028;
	background: #ffffff;
}

.post {
	margin: 0 0 60px 0;
	padding: 0;
}

.postLine {
	margin: 0 0 60px 0;
	padding: 0 0 40px;
	border-bottom: 1px solid #dadada;
}

.post p {
	padding-bottom: 15px;
}

.postLine p {
	padding-bottom: 15px;
}

.post ul {
	margin: 0 0 10px 10px;
}

.post>ul>li {
	margin-bottom: 5px;
	padding-left: 15px;
	background: url(images/com/bullet.png) no-repeat 0 8px;
}

.post ol {
	margin: 0 0 10px 30px;
}

.post ol li {
	list-style: decimal;
}

.post h1 {
	margin: 20px 0;
	padding: 5px 0;
	font-size: 150%;
	color: #000;
	border-bottom: 3px solid #000;
}

.post h2 {
	margin: 10px 0;
	padding-bottom: 2px;
	font-size: 130%;
	font-weight: normal;
	color: #333;
	border-bottom: 2px solid #515151;
}

.post h3 {
	margin: 10px 0;
	font-size: 120%;
	font-weight: normal;
	color: #214a78;
	border-bottom: 1px solid #515151;
}

h4.title {
	clear: both;
	padding: 12px 0 10px 10px;
	margin: 0 0 10px;
	font-size: 118.75%;
	background: #ffffff;
	border: solid 1px #dadada;
}

.post blockquote {
	clear: both;
	padding: 10px 0 10px 15px;
	margin: 10px 0 25px 30px;
	border-left: 5px solid #ccc;
}

.post blockquote p {
	padding: 5px 0;
}

.post dt {
	font-weight: bold;
}

.post dd {
	padding-bottom: 10px;
}

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

img.aligncenter {
	display: block;
	margin: 10px auto;
}

img.alignright {
	margin: 0 0 5px 10px;
	display: inline;
}

img.alignleft {
	margin: 0 10px 5px 0;
	display: inline;
}

.alignright {
	float: right;
}

.alignleft {
	float: left;
}

strong {
	font-weight: bold;
}

em {
	font-style: italic;
}

blockquote {
	display: block;
	-webkit-margin-before: 1em;
	-webkit-margin-after: 1em;
	-webkit-margin-start: 40px;
	-webkit-margin-end: 40px;
}

@media all and (max-width: 640px) {
	img.aligncenter {
		display: block;
		margin: 10px auto;
		width: 100%;
	}

	img.alignright {
		margin: 0 0 5px 10px;
		display: inline;
		width: 100%;
	}

	img.alignleft {
		margin: 0 10px 5px 0;
		display: inline;
		width: 100%;
	}

	.alignright {
		float: right;
	}

	.alignleft {
		float: left;
	}
}

/* カスタムフィールド
---------------------------------*/
.caseDitail {
	width: 100%;
	margin: 0;
	padding: 0;
}

.caseDitail .imageTop {
	max-width: 520px;
	margin: 0 auto 10px;
	padding: 0;
	display: block;
	text-align: center;
}

.caseDitail .caseImgArea {
	margin: 0 0 30px;
	padding: 20px 0 10px;
	border-top: 2px solid #eeeeee;
	border-bottom: 2px solid #eeeeee;
}

.caseDitail .caseTtl {
	font-size: 120%;
	margin: 0 auto 10px;
	padding: 0;
	text-align: left;
	color: #39b54a;
	font-weight: bold;
	letter-spacing: 1px;
}

.caseDitail .description {
	margin: 0 auto 30px;
	padding: 0;
}

.caseDitail .box {
	width: 100%;
	margin: 0;
	padding: 0;
}

.caseDitail .box .iconArea {
	width: 15.625%;
	margin: 0;
	padding: 0;
	float: left;
}

.caseDitail .box .textArea {
	width: 79.6875%;
	margin: 0;
	padding: 0;
	float: right;
}

.caseDitail .box .textArea .comment {
	width: 100%;
	margin: 0;
	padding: 0;
	font-weight: bold;
	text-align: left;
}

.caseDitail .box .textArea .text {
	width: 100%;
	margin: 0;
	padding: 0;
	text-align: left;
}

.thumbWrap {
	width: 100%;
	margin: 0 auto;
	padding: 0;
	box-sizing: border-box;
}

.caseDitail .thumbWrap ul {
	margin: 0;
}

.caseDitail .thumbWrap li {
	float: left;
	width: 31.1111%;
	margin: 0 3.125% 3.125% 0;
	padding: 0;
	background: none;
	border-bottom: none;
}

.caseDitail .thumbWrap li:nth-child(3n) {
	float: left;
	width: 31.1111%;
	margin: 0 0 3.125% 0;
	padding: 0;
	background: none;
}

.caseDitail .thumbWrap li img {
	width: 100%;
	margin: 0 0 5px;
	padding: 0;
	height: auto;
}

.caseDitail ul.thumb .caption {
	margin-top: 2px;
	font-weight: normal;
	font-size: 93.3333%;
	text-align: left;
	line-height: 1.5;
	border: 0px solid #dadada;
}

.caseDitail ul.thumb h3 span {
	display: block;
	padding: 0px;
}

.caseDitail ul.thumb h3 a {
	color: #252525;
}

.caseDitail ul.thumb h3:hover span {
	background: none;
}

@media only screen and (max-width: 640px) {
	.thumbWrap {
		width: 100%;
		margin: 0 auto;
		padding: 0;
		box-sizing: border-box;
	}

	.caseDitail .thumbWrap ul {
		margin: 0;
	}

	.caseDitail .thumbWrap ul.thumb li {
		width: 100%;
		float: none;
		margin: 0 auto 20px;
	}

	.caseDitail .thumbWrap ul.thumb li:last-child {
		width: 100%;
		float: none;
		margin: 0 auto;
	}

	.caseDitail .thumbWrap img {
		width: 100%;
		height: auto;
	}
}

/*thumbWrap end*/
/* レイアウト
---------------------------------*/
#wrapper,
.inner {
	margin: 0 auto;
	width: 980px;
}

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

	#wrapper,
	#header,
	.inner {
		width: 100%;
	}
}

/* ヘッダー
*****************************************************/
#header {
	width: 100%;
	margin: 0;
	padding: 0;
}

#header .bg {
	background-image: url(images/com/com_bg_02.gif);
	background-repeat: repeat-x;
	height: 5px;
}

.fixed {
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 10000;
}

#header h2 {
	float: left;
	margin: 0;
	padding: 30px 0 0 30px;
}

#header h2 img {
	max-width: 260px;
}

#header .headerImg {
	float: right;
	margin: 0;
	padding: 30px 0 0 0;
}

#header .headerImg img {
	max-width: 253px;
}

#header .contact {
	float: right;
	margin: 0;
	padding: 40px 0 0 0;
}

#header .contact img {
	max-width: 290px;
}

@media only screen and (max-width:640px) {
	#header {
		text-align: center;
	}

	#header h2 {
		float: none;
		margin: 0 auto 10px;
		padding: 10px 0 0;
	}

	#header .contact {
		float: none;
		margin: 0 auto 10px;
		padding: 0;
	}
}

@media only screen and (max-width:870px) {
	#header .headerImg {
		display: none;
	}
}

/* トップページ　メイン画像
*****************************************************/
#mainImg {
	clear: both;
	margin: 0;
	width: 100%;
	line-height: 0;
	text-align: center;
	z-index: 0;
	position: relative;
}

#mainImg .inner {
	max-width: 980px;
	height: auto;
	margin: 0 auto 0;
}

#mainImg .inner img {
	width: 100%;
	height: auto;
}

@media only screen and (max-width:640px) {
	#mainImg .inner {
		width: 100%;
		height: auto;
		margin: 0 auto 0;
	}

	#mainImg .inner img {
		width: 100%;
		height: auto;
	}
}

/* メイン
*****************************************************/
/* メインメニュー　PC用
---------------------------------*/
@media all and (min-width: 640px) {

	/* ナビゲーション */
	#menu {
		display: block !important
	}

	.panel {
		margin: 0 0 20px;
		width: 980px;
	}

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

	.menu li a {
		display: block;
		padding: 10px 15px;
		color: #000000;
		font-size: 14px;
		text-decoration: none
	}

	.menu li a:hover {
		background-color: #eeeeee
	}

	.menu ul:after {
		content: "";
		display: block;
		clear: both
	}

	.menu li {
		float: left;
		width: auto
	}

	#mainNav {
		clear: both;
	}

	#mainNav ul {
		height: 50px;
	}

	#mainNav ul li.greeting.menu-item a {
		padding: 0;
		display: block;
		width: 195px;
		height: 50px;
		line-height: 50px;
		border-right: 1px solid #ffffff;
		background: url(images/com/nav_01.png) no-repeat left top;
	}

	#mainNav ul li.service.menu-item a {
		padding: 0;
		display: block;
		width: 195px;
		height: 50px;
		line-height: 50px;
		border-right: 1px solid #ffffff;
		background: url(images/com/nav_02.png) no-repeat left top;
	}

	#mainNav ul li.case.menu-item a {
		padding: 0;
		display: block;
		width: 195px;
		height: 50px;
		line-height: 50px;
		border-right: 1px solid #ffffff;
		background: url(images/com/nav_03.png) no-repeat left top;
	}

	#mainNav ul li.generation.menu-item a {
		padding: 0;
		display: block;
		width: 195px;
		height: 50px;
		line-height: 50px;
		border-right: 1px solid #ffffff;
		background: url(images/com/nav_04.png) no-repeat left top;
	}

	#mainNav ul li.contact.menu-item a {
		padding: 0;
		display: block;
		width: 195px;
		height: 50px;
		line-height: 50px;
		background: url(images/com/nav_05.png) no-repeat left top;
	}

	nav#mainNav ul li a strong {
		display: block;
		font-size: 90%;
		line-height: 1.4;
		text-indent: -9999px;
	}


	nav#mainNav ul li a span,
	nav#mainNav ul li a strong {
		display: block;
		font-size: 90%;
		line-height: 1.4;
	}

	nav#mainNav ul li a span {
		font-size: 68.75%;
		color: #333333;
	}

	#mainNav ul li.greeting.menu-item a:hover,
	#mainNav ul li.greeting.current-menu-item a,
	#mainNav ul li.greeting.current-menu-parent a,
	#mainNav ul li.home.current-post-ancestor a {
		background: url(images/com/nav_01.png) no-repeat left -50px;
	}

	#mainNav ul li.service.menu-item a:hover,
	#mainNav ul li.service.current-menu-item a,
	#mainNav ul li.service.current-menu-parent a,
	#mainNav ul li.service.current-post-ancestor a {
		background: url(images/com/nav_02.png) no-repeat left -50px;
	}

	#mainNav ul li.case.menu-item a:hover,
	#mainNav ul li.case.current-menu-item a,
	#mainNav ul li.case.current-menu-parent a,
	#mainNav ul li.case.current-post-ancestor a {
		background: url(images/com/nav_03.png) no-repeat left -50px;
	}

	#mainNav ul li.generation.menu-item a:hover,
	#mainNav ul li.generation.current-menu-item a,
	#mainNav ul li.generation.current-menu-parent a,
	#mainNav ul li.generation.current-post-ancestor a {
		background: url(images/com/nav_04.png) no-repeat left -50px;
	}

	#mainNav ul li.contact.menu-item a:hover,
	#mainNav ul li.contact.current-menu-item a,
	#mainNav ul li.contact.current-menu-parent a,
	#mainNav ul li.contact.current-post-ancestor a {
		background: url(images/com/nav_05.png) no-repeat left -50px;
	}

	#mainNav ul li {
		position: relative;
		z-index: 1;
		float: left;
	}

	#mainNav ul li ul.sub-menu {
		display: none;
		position: absolute;
		top: 50px;
		left: 0;
	}

	#mainNav ul li:hover ul.sub-menu {
		display: block;
	}

	#mainNav ul li ul.sub-menu li {
		float: none;
	}

	#mainNav ul li.greeting ul.sub-menu li a {
		width: 192px;
		border: 1px solid #fff;
		border-top: none;
		background: #f39626;
		color: #fff;
		text-align: center;
		font-size: 100%;
	}

	#mainNav ul li.service ul.sub-menu li a {
		width: 192px;
		border: 1px solid #fff;
		border-top: none;
		background: #f39626;
		color: #fff;
		text-align: center;
		font-size: 100%;
	}

	#mainNav ul li.case ul.sub-menu li a {
		width: 192px;
		border: 1px solid #fff;
		border-top: none;
		background: #5cb02a;
		color: #fff;
		text-align: center;
		font-size: 100%;
	}

	#mainNav ul li.generation ul.sub-menu li a {
		width: 192px;
		border: 1px solid #fff;
		border-top: none;
		background: #2b75d1;
		color: #fff;
		text-align: center;
		font-size: 100%;
	}

	#mainNav ul li.contact ul.sub-menu li a {
		width: 192px;
		border: 1px solid #fff;
		border-top: none;
		background: #f39626;
		color: #fff;
		text-align: center;
		font-size: 100%;
	}

	#mainNav ul li.greeting ul.sub-menu li a:hover,
	#mainNav ul li.greeting ul.sub-menu li.current-menu-item a,
	#mainNav ul li.greeting ul.sub-menu li.current-menu-parent a {
		background: #ebebeb;
		text-align: center;
		color: #333333;
	}

	#mainNav ul li.service ul.sub-menu li a:hover,
	#mainNav ul li.service ul.sub-menu li.current-menu-item a,
	#mainNav ul li.service ul.sub-menu li.current-menu-parent a {
		background: #ebebeb;
		text-align: center;
		color: #333333;
	}

	#mainNav ul li.case ul.sub-menu li a:hover,
	#mainNav ul li.case ul.sub-menu li.current-menu-item a,
	#mainNav ul li.case ul.sub-menu li.current-menu-parent a {
		background: #ebebeb;
		text-align: center;
		color: #333333;
	}

	#mainNav ul li.generation ul.sub-menu li a:hover,
	#mainNav ul li.generation ul.sub-menu li.current-menu-item a,
	#mainNav ul li.generation ul.sub-menu li.current-menu-parent a {
		background: #ebebeb;
		text-align: center;
		color: #333333;
	}

	#mainNav ul li.contact ul.sub-menu li a:hover,
	#mainNav ul li.contact ul.sub-menu li.current-menu-item a,
	#mainNav ul li.contact ul.sub-menu li.current-menu-parent a {
		background: #ebebeb;
		text-align: center;
		color: #333333;
	}

	#globalToggleNav {
		display: none;
	}
}

/* メインメニュー スマホサイズ以下から
---------------------------------*/
@media only screen and (max-width:639px) {
	#mainNav {
		display: none;
	}
}

.drawer-nav ul li {
	width: 100%;
	margin: 0;
	color: #333333;
	border-bottom: 1px dotted #333333;
	font-size: 93.3333%;
}

.drawer-nav ul li a {
	margin: 0;
	padding: 6px 8px 6px 19px;
	background: url(images/com/com_arrow_01.gif) no-repeat;
	background-position: 3px 50%;
	display: block;
	background-color: #f0fbff;
}

.drawer-nav ul li.child a {
	margin: 0;
	padding: 8px 8px 8px 29px;
	background: url(images/com/com_arrow_01.gif) no-repeat;
	background-position: 13px 50%;
	display: block;
	background-color: #faffff;
}

.drawer-nav ul li a:hover {
	background-position: 6px 50%;
}

.drawer-nav ul li.child a:hover {
	background-position: 16px 50%;
}

/* メインコンテンツ
*****************************************************/
#content {
	float: right;
	width: 76.53061%;
	padding: 0 0 12px 0;
}

section.slider {
	width: 100%;
	margin: 0 auto 0;
	padding: 0;
}

section.contentsArea {
	width: 100%;
	margin: 0 auto 35px;
	padding: 0;
	text-align: center;
}

section.contentsArea #contentsAreaTtl {
	background-color: #C80028;
	width: 100%;
	text-align: center;
	margin: 0 0 20px;
	padding: 3px 0 0;
}

section.contentsArea img {
	max-width: 100%;
}

section.contentsArea ul {
	margin: 0 auto 0;
	width: 100%;
	text-align: center;
}

section.contentsArea ul li {
	margin: 0 2.6666% 0 0;
	width: 22.9333%;
	height: auto;
	float: left;
	display: block;
}

section.contentsArea ul li:last-child {
	margin: 0;
	width: 22.9333%;
	height: auto;
	float: left;
	display: block;
}

.sec {
	margin: 0 auto 30px;
	padding: 0;
}

@media screen and (max-width: 640px) {
	section.contentsArea ul {
		margin: 0 auto 0;
		width: 100%;
		text-align: center;
	}

	section.contentsArea ul li {
		margin: 3%;
		width: 44%;
		height: auto;
		float: left;
		display: block;
	}

	section.contentsArea ul li:last-child {
		margin: 3%;
		width: 44%;
		height: auto;
		float: left;
		display: block;
	}

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

	.sec {
		margin: 0 auto 15px;
		padding: 0;
	}
}

/*caseArea*/
section.caseArea {
	width: 100%;
	margin: 0 auto 10px;
	padding: 0;
}

.thumbWrap li {
	float: left;
	width: 22.9333%;
	margin: 0 2.6666% 10px 0;
	padding: 0 0 6px 0;
	background: none;
	border-bottom: 1px dotted #cccccc;
}

.thumbWrap li:last-child {
	float: left;
	width: 22.9333%;
	margin: 0;
	padding: 0 0 6px 0;
	background: none;
}

.thumbWrap li a:hover {
	opacity: 0.5;
}

.thumbWrap li img {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}

.dateLabel {
	margin: 0;
	padding: 0;
}

.dateTime {
	display: inline-block;
	font-family: Quicksand;
	font-weight: bold;
	color: #333333;
	width: 100%;
	margin-bottom: 0px;
	font-size: 12px;
	text-align: right;
}

ul.thumb h3 {
	margin: 0;
	padding: 0;
	font-weight: normal;
	text-align: left;
}

ul.thumb h3 span {
	display: block;
	padding: 0px;
	font-size: 93.3333%;
}

ul.thumb h3 a {
	color: #333333;
}

ul.thumb h3:hover span {
	background: none;
}

.electric,
.reform,
.construction,
.repair,
.construction-lite {
	font-weight: normal;
	display: inline-block;
	padding: 4px 14px 2px;
	margin: 4px 12px 7px 0;
	font-size: 12px;
	line-height: 1;
	text-align: center;
	color: #ffffff;
	background-color: #A0C832;
}

.thumbWrap ul li .generation {
	font-weight: normal;
	display: inline-block;
	padding: 4px 14px 2px;
	margin: 4px 12px 7px 0;
	font-size: 12px;
	line-height: 1;
	text-align: center;
	color: #ffffff;
	background-color: #A0C832;
}

@media only screen and (max-width: 640px) {
	.thumbWrap li {
		float: none;
		width: 90%;
		margin: 0 auto 2.6666%;
		padding: 0;
		background: none;
	}

	.thumbWrap li:last-child {
		float: none;
		width: 90%;
		margin: 0 auto 2.6666%;
		padding: 0;
		background: none;
	}

	.thumbWrap img {
		width: 100%;
		height: auto;
	}
}

/*caseArea end*/
/*newsArea*/
section.newsArea {
	width: 100%;
	margin: 0 auto 35px;
	padding: 0;
}

#infoTtl {
	margin-bottom: 15px;
	padding: 0 0 1px;
	border-bottom: #C80028 2px solid;
	font-size: 113.3333%;
	font-weight: normal;
	position: relative;
	letter-spacing: 1px;
}

#infoTtl .sub {
	font-size: 86.6666%;
	font-weight: normal;
	position: relative;
	color: #C80028;
	letter-spacing: 1px;
}

#infoTtl .more {
	font-size: 80%;
	float: right;
	display: inline-block;
	padding: 5px 5px 5px 10px;
}

#infoTtl .more:after {
	content: url(images/com/arrow_01.gif);
	margin: 0 5px 0;
	position: relative;
	top: 1px;
}

#infoTtl .more:hover {
	opacity: 0.7;
}

.newsArea .blog01 {
	float: left;
	width: 100%;
	margin-bottom: 10px;
	position: relative;
	display: block;
	border-bottom: 1px dotted #666666;
	padding-bottom: 10px;
}

.newsArea .blog01:last-child {
	margin-bottom: 0px;
}

.newsArea .blog01:hover {
	opacity: 0.5;
}

.newsArea .blog01 dl {
	float: left;
	width: 100%;
	box-sizing: border-box;
}

.newsArea .blog01 dt {
	font-family: Quicksand;
	font-weight: bold;
	color: #333333;
	float: left;
	width: 100%;
	margin-bottom: 0px;
	font-size: 12px;
}

.newsArea .blog01 dd {
	float: left;
	width: 100%;
	color: #333333;
}

.newsArea .blog01 dd .ttl {
	font-size: 93.3333%;
}

/*newsArea end*/
/*voice_bnr_area*/

.voice_bnr_area {
	width: 100%;
	padding: 0;
	margin: 0 0 30px;
}

.voice_bnr_area figure {
	margin: 0;
}

.voice_bnr_area img {
	width: 100%;
}

/*voice_bnr_area end*/
/*contactArea*/
.contact_area {
	width: 100%;
	padding: 0;
	margin: 0;
}

.contact_area .inner_base {
	width: 100%;
	margin: 0 0 1px 0;
	padding: 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	flex-wrap: wrap;
}

.contact_area .inner_base .tel_set {
	width: 44%;
	margin: 0;
	padding: 0;
}

.contact_area .inner_base .tel_set .tel {
	display: block;
	text-align: center;
}

.contact_area .inner_base .tel_set .tel a {
	font-family: "din";
	color: #c80028;
	font-size: 42px;
	line-height: 1;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 auto 6px auto;

}

@media screen and (min-width:641px) and (max-width:960px) {
	.contact_area .inner_base .tel_set .tel a {
		font-size: 4.6vw;
	}
}

@media all and (max-width: 460px) {
	.contact_area .inner_base .tel_set .tel a {
		font-size: 10.6vw;
	}
}

/*
.contact_area .inner_base .tel_set .tel a::before{
	position: absolute;
	top: 10px;
	left: 0;
  display: inline-block;
  width: 36px;
	height: 36px;
  content: '';
  background-image: url(images/home/ico_tel.png);
  background-size: contain;
  vertical-align: middle;
}
@media all and (max-width: 768px) {
.contact_area .inner_base .tel_set .tel a::before{
	top: 5px;
}
}
*/
.contact_area .inner_base .tel_set .time {
	font-size: 14px;
	text-align: left;
}

.contact_area .fukidashi {
	font-size: 14px;
	line-height: 1.4;
	text-align: center;
	position: relative;
	padding: 0 15px;
	margin: 0 0 6px 0;
	box-sizing: border-box;
}

.contact_area .fukidashi::before {
	content: "";
	left: 10px;
	top: 0;
	width: 0;
	height: 40px;
	position: absolute;
	border-left: 2px dotted #000;
	transform: skewX(15deg);
}

.contact_area .fukidashi::after {
	content: "";
	right: 10px;
	top: 0;
	width: 0;
	height: 40px;
	position: absolute;
	border-left: 2px dotted #000;
	transform: skewX(-15deg);
}

section.contact_area>div.inner_base>figure {
	width: 10%;
	margin: 0;
	padding: 0;
}

.contact_area .inner_base .mail_set {
	width: 44%;
	margin: 0;
	padding: 0;
}

.contact_area .inner_base .mail_set .btn {
	width: 100%;
	margin: 0;
	padding: 0;
	text-align: center;
}

.contact_area .inner_base .mail_set .btn img {
	width: 96%;
	margin: auto;
}

.contact_area .inner_base .mail_set .text {
	width: 100%;
	font-size: 19px;
	color: #93c824;
	text-align: center;
	line-height: 1.4;
}

section.contact_area>div.inner_base>figure>img {
	width: 100%;
}

@media all and (max-width: 640px) {
	.contact_area .inner_base {
		width: 100%;
		margin: 0 0 0 0;
		padding: 0;
		flex-direction: column;
	}

	.contact_area .inner_base .tel_set {
		width: 100%;
		margin: 0 0 30px 0;
		padding: 0;
	}

	.contact_area .inner_base .mail_set {
		width: 100%;
		margin: 0;
		padding: 0;
	}

	section.contact_area>div.inner_base>figure {
		display: none;
	}

	.contact_area .inner_base .tel_set .time {
		font-size: 14px;
		text-align: center;
	}

	.contact_area .inner_base .mail_set .btn img {
		width: 80%;
		margin: 0 auto;
	}
}


/*contactArea end*/
/* サイドバー　ウィジェット
*****************************************************/
#sidebar {
	position: relative;
	float: left;
	width: 20.4081632653%;
	padding: 0 0 30px;
	margin: 0;
}

#sidebar .ttl {
	display: block;
	padding: 0;
	margin: 0 0 0;
}

#sidebar .nav ul {
	margin: 0 0 20px;
	padding: 0;
}

#sidebar .nav ul li {
	width: 100%;
	height: auto;
	line-height: 1;
	display: block;
}

#sidebar .nav ul li.sub {
	width: 100%;
	height: auto;
	display: block;
}

#sidebar .bnr ul li {
	display: block;
	width: 100%;
	height: auto;
}

#sidebar .bnr ul li:last-child {
	display: block;
	width: 100%;
	height: auto;
	margin-bottom: 20px;
}

#sidebar .bnr ul li a:hover {
	opacity: 0.6;
}

#sidebar img {
	width: 100%;
	vertical-align: bottom;
}

@media all and (max-width: 640px) {
	#sidebar {
		display: none;
	}
}

/* ポストページ
*****************************************************/
#contentPost {
	float: left;
	width: 76.6%;
	padding: 30px 0;
}

#sidebarPost {
	position: relative;
	float: right;
	width: 20.0%;
	padding: 30px 0;
	margin: 0;
	font-size: 93.3333%;
}

#sidebarPost img {
	width: 100%;
	margin: 0;
	padding: 0;
}

section.widget,
.widgetInfo {
	margin: 0 0 20px;
	padding: 10px 10px;
	border: 1px solid #dadada;
	background: #fff;
}

section.widget h3 {
	clear: both;
	margin: 0 0 10px;
	padding: 6px 0;
	font-size: 100%;
	font-weight: normal;
	color: #333;
	border-bottom: 5px solid #97cff6;
}

section.widget {
	font-size: 100%;
	line-height: 1.3;
	color: #333333;
}

section.widget a {
	display: block;
	padding: 5px 0 5px 13px;
	id text-decoration: none;
	background: url(images/com/com_arrow_02.gif) no-repeat 0 50%;
}

section.widget a:hover {
	text-decoration: none;
	background-position: 3px 50%;
}

#sidebarPost .post-date {
	padding: 0 0 0 16px;
	font-size: 80%;
}

#searchform input[type="text"] {
	line-height: 1.7;
	height: 24px;
	width: 100px;
	vertical-align: bottom;
}

.dateLabelPost {
	font-family: Quicksand;
	font-weight: bold;
	color: #333333;
	width: 100%;
	margin-bottom: 20px;
	font-size: 12px;
	text-align: right;
}

.dateLabelPost span {
	font-weight: normal;
	display: inline-block;
	padding: 3px 14px 2px;
	margin: 0;
	font-size: 12px;
	line-height: 1;
	text-align: center;
	color: #ffffff;
	background-color: #A0C832;
}

.dateLabelPost span a {
	color: #ffffff;
}

/* 640px以下から 1カラム表示
---------------------------------*/
@media only screen and (max-width: 640px) {

	#wrapper,
	#header,
	.inner {
		width: 100%;
	}

	nav#mainNav ul {
		margin: 0 auto;
	}

	nav#mainNav ul ul {
		padding: 0;
	}

	nav div.panel {
		float: none;
	}

	#mainImg img {
		width: 98%;
		height: auto;
	}

	#content,
	#contentPost,
	#sidebarPost {
		clear: both;
		width: 96%;
		float: none;
		margin: 0 auto;
		padding: 10px 0;
	}

	section.widget_search {
		text-align: center;
	}
}

/* フッター
*****************************************************/
#footer {
	width: 100%;
	margin: 0 0 16px 0;
	padding: 0;
	clear: both;
}

#footer .footerBg {
	background: url(images/com/footer_bg.gif);
	background-repeat: repeat-x;
	background-position: center top;
}

#footer .inner {
	max-width: 980px;
	margin: 0 auto 0;
	padding: 80px 0 0 0;
}

#footer ul {
	padding: 10px 0 0 0;
	text-align: center;
}

#footer ul li {
	display: inline;
	margin: 0;
	padding: 0 10px;
	font-size: 86.6666%;
	border-right: 1px solid #C80028;
	line-height: 2.2;
}

#copyright {
	clear: both;
	padding: 10px;
	text-align: center;
	font-size: 86.6666%;
	zoom: 1;
	color: #333333;
	background: #f2f2f2;
}

@media all and (max-width: 640px) {
	#copyright {
		padding: 10px 10px 60px;
	}
}

.footer_fix {
	display: flex;
	position: fixed;
	bottom: 0;
	z-index: 10;
	width: 100%;
}

#footer .footer_fix ul {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
}

#footer .footer_fix ul li:first-child {
	background-color: #c80028;
	width: 50%;
	border-right: 0px;
	font-family: "din";
	font-size: 120%;
}

#footer .footer_fix ul li:last-child {
	background-color: #eb9600;
	width: 50%;
	border-right: 0px;
}

#footer .footer_fix ul li {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 50%;
	border-right: 0px;
	padding: 0 0;
	font-size: 120%;
}

#footer .footer_fix ul li a.btn-flat {
	position: relative;
	display: block;
	font-weight: normal;
	padding: 15px 0.5em;
	text-decoration: none;
	color: #ffffff;
	transition: .4s;
	line-height: 1.0;
	width: 100%;
}

.footer_fix_recruit {
	display: flex;
	position: fixed;
	bottom: 0;
	z-index: 10;
	width: 100%;
}

#footer .footer_fix_recruit ul {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
}

#footer .footer_fix_recruit ul li {
	background-color: #C1272D;
	width: 100%;
	border-right: 0px;
}

#footer .footer_fix_recruit ul li {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	border-right: 0px;
	padding: 0 0;
	font-size: 120%;
}

#footer .footer_fix_recruit ul li a.btn-flat span {
	position: relative;
	display: block;
	font-weight: bold;
	padding: 15px 0.5em;
	text-decoration: none;
	color: #ffffff;
	transition: .4s;
	line-height: 1.0;
	width: 100%;
}

#footer .footer_fix_recruit ul li a.btn-flat span:after {
	content: "▶︎";
	right: 0;
	top: 34%;
	position: absolute;
}




/* page navigation
---------------------------------*/
.pagenav {
	clear: both;
	width: 100%;
	height: 30px;
	margin: 5px 0 20px;
}

.prev {
	float: left
}

.next {
	float: right;
}

#pageLinks {
	clear: both;
	color: #2a588b;
	text-align: center;
}

.pagetop {
	width: 60px;
	min-width: 45px;
	position: fixed;
	right: 0%;
	bottom: 7%;
}

@media only screen and (max-width: 640px) {
	.pagetop {
		width: 60px;
		min-width: 45px;
		position: fixed;
		right: 1%;
		bottom: 8%;
	}
}

/* post voice
---------------------------------*/
.voice_ditail {
	width: 100%;
	padding: 0;
	margin: 0;
	border-bottom: 1px solid #cccccc;
}

ul.voice_set {
	width: 100%;
	margin: 0 0 30px 0 !important;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	flex-wrap: wrap;
}

ul.voice_set>li {
	margin-bottom: 0;
	padding-left: 0;
}

ul.voice_set>li:first-child {
	width: 63%;
	margin: 0;
	padding: 0;
}

ul.voice_set>li:last-child {
	width: 32%;
	margin: 0;
	padding: 0;
}

ul.voice_set>li:last-child figure {
	width: 100%;
	margin: 0;
	padding: 0;
	border: 5px solid #FFDC67;
	box-sizing: border-box;
}

ul.voice_set>li:last-child figure img {
	vertical-align: top;
}

@media only screen and (max-width: 640px) {
	ul.voice_set {
		width: 100%;
		margin: 0 0 30px 0 !important;
		flex-direction: column;
	}

	ul.voice_set>li:first-child {
		width: 100%;
		margin: 0;
		padding: 0;
	}

	ul.voice_set>li:last-child {
		width: 100%;
		margin: 0;
		padding: 0;
	}

	ul.voice_set>li:last-child figure img {
		width: 100%;
		margin: 0;
		padding: 0;
	}
}

ul.voice_set>li:first-child>ul.voice_sub_set {
	width: 100%;
	margin: 0 0 20px 0 !important;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	flex-wrap: wrap;
}

ul.voice_set>li:first-child>ul.voice_sub_set>li:first-child {
	width: 20%;
	margin: 0;
	padding: 0;
}

ul.voice_set>li:first-child>ul.voice_sub_set>li:first-child figure {
	margin: 0;
	padding: 0;
	text-align: center;
}

ul.voice_set>li:first-child>ul.voice_sub_set>li:first-child figure img {
	width: 80%;
	max-width: 100%;
	margin: auto;
	text-align: center;
}

ul.voice_set>li:first-child>ul.voice_sub_set>li:first-child p {
	text-align: center;
	font-size: 14px;
}

ul.voice_set>li:first-child>ul.voice_sub_set>li:last-child {
	width: 72%;
	margin: 0;
	padding: 15px;
	background-color: #FFFAD6;
	font-size: 14px;
	box-sizing: border-box;
	border-radius: 3px;
	position: relative;
}

ul.voice_set>li:first-child>ul.voice_sub_set>li:last-child::before {
	content: "";
	position: absolute;
	top: 30%;
	left: -25px;
	margin-top: -10px;
	border: 10px solid transparent;
	border-right: 15px solid #FFFAD6;
}

ul.voice_set>li:first-child>ul.voice_sub_set>li:last-child p {
	text-align: left;
	padding: 0;
	margin: 0;
}

ul.voice_set>li>p.comment {
	text-align: left;
	font-size: 14px;
	padding: 10px;
	background-color: #e0e0e0;
	margin-bottom: 20px;
}

.item-new {
	width: 110px;
	margin: 0 5px;
	padding: 4px 10px;
	text-align: center;
	background-color: #f92507;
	font-size: 1.0rem;
	color: #ffffff;
	font-weight: 500;
	line-height: 1.9;
	display: inline;
}

.item.jyosei {
	width: 100px;
	height: 100px;
	display: block;
	margin: 0 0 10px;
	background-image: url(images/ico_jyosei.png);
	background-repeat: no-repeat;
	background-size: contain;
	text-indent: -9999px;
	background-position: center center;
}

.item.dansei {
	width: 100px;
	height: 100px;
	display: block;
	margin: 0 0 10px;
	background-image: url(images/ico_dansei.png);
	background-repeat: no-repeat;
	background-size: contain;
	text-indent: -9999px;
	background-position: center center;
}

form#form {
	position: relative;
}

form#form #s-box {
	height: 30px;
	padding: 0 2px;
	border-radius: 2px;
	border: solid 1px #878787;
	outline: 0;
	width: calc(100% - 60px);
}

form#form #s-btn-area {
	height: 30px;
	position: absolute;
	right: 0;
	top: 1px;
	background: none;
	color: #666;
	border: none;
	outline: 0;
	padding: 0;
}

form#form #s-btn {
	background-color: #72bde5;
	width: 50px;
	height: 30px;
	position: relative;
	right: 0;
	bottom: 0;
	border-radius: 3px;
	font-size: 14px;
	color: #fff;
	line-height: 30px;
}



nav.drawer-nav>div>form#form {
	padding: 20px 10px;
}

nav.drawer-nav>div>form#form #s-box {
	height: 30px;
	padding: 0 2px;
	border-radius: 2px;
	border: solid 1px #878787;
	outline: 0;
	width: 170px;
}

nav.drawer-nav>div>form#form #s-btn-area {
	height: 30px;
	position: absolute;
	right: 10px;
	top: 21px;
	background: none;
	color: #666;
	border: none;
	outline: 0;
	padding: 0;
}

nav.drawer-nav>div>form#form #s-btn {
	background-color: #72bde5;
	width: 50px;
	height: 30px;
	position: relative;
	right: 0;
	bottom: 0;
	border-radius: 3px;
	font-size: 14px;
	color: #fff;
	line-height: 30px;
}

/* recaptcha */
.grecaptcha-badge {
	visibility: hidden;
}

.grecaptcha-note {
	display: block;
	padding-top: 5px;
}

.swiper img {
  width: 100%;
  height: auto;
  display: block;
}
/* スライダーの画像下に出る謎の余白対策 */
.slider .swiper-slide img {
  display: block;
  width: 100%;
  height: auto;
}
/* PCサイズの比率に合わせて数値は調整してください */
.slider .swiper {
  aspect-ratio: 750 / 320;
}

@media only screen and (max-width: 767px) {
.slider .swiper {
  aspect-ratio: 500 / 320;
}
}

.slider .swiper-slide,
.slider .swiper-slide a,
.slider picture,
.slider img {
  width: 100%;
  height: 100%;
}

.slider img {
  object-fit: cover;  /* 全面に表示（余白を作らない） */
  display: block;
}

.slider .swiper-slide {
  line-height: 0;
}
.slider .swiper,
.slider .swiper-wrapper,
.slider .swiper-slide {
  padding: 0;
  margin: 0;
}
.slider picture {
  display: block;
}
.swiper {
  position: relative !important;
  padding-bottom: 40px !important;
}
.swiper-pagination {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 10px !important;
  z-index: 10 !important;
}

.swiper-pagination-bullet {
  background: #cccccc !important;
  opacity: 1 !important;
}

.swiper-pagination-bullet-active {
  background: #c7000b !important;
}