@charset "UTF-8";
/*
Theme Name: 611-1515.jp-sp
Version: 1.0.0
*/

/****************************************
General Setting
*****************************************/
.sp { display: inline-block; }
.pconly { display: none; }
.pc { display: none; }
.spimgblock { float: none!important; display: block; margin: 0px auto 10px; }
.pr_br {
	display: inline;
}
.spbr {
	display: block;
}

html, body {
	margin: 0 auto!important;
}

#header #tlogo img {
	max-width: 85px;
}

body {
	text-align: center;
	font-size: 14px;
	background-position: bottom;
	background-repeat: repeat-x;
	min-width: 100%;
	word-wrap: break-word;
}

img {
	border-style:none;
	height: auto;
}
.subHeader { 
	padding: 10px 0px 10px;
}
.mBttl{
	font-size: 1.3em;
	line-height: 1.8em;
	margin-bottom: 1em;
}

footer,
#header .wrapper,
#container,
.topwrapper,
.wrapper03,
.wrapper02,
.wrapper {
	padding-left: 0px !important;
	padding-right: 0px !important;
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	overflow: hidden;
	min-width: 100%;
}
.mslider {
}

.kizi { padding: 0px 10px; }
#main,
#sidepage {
	width:100%;
	float:  none;
}

#maincon { padding-top: 0px; padding-bottom: 50px; }
.breadcrumbs { padding-left: 10px; }
#gnavi {
	position: fixed;
	top: 70px;
	z-index: 999;
	width: 100%;
	float: none;
	display: block; }

#header { height: 58px; padding-top: 1px; min-width: 100%;}
#headerL.fixed #header { position: fixed; }
#header h1 { display: none; }

#sp_menu_btn {
	position: absolute;
	display: block;
	cursor: pointer;
	width:47px;
	height:47px;
	right:0px;
	margin-top:3px;
	margin-right:10px;
	background: #fff;
	z-index: 100;
	filter: invert(100%) brightness(79%);
}

.menu {
	display: none;
	margin-top: 0px;
	margin-left: auto;
	margin-right: auto;
	padding: 0;
	width: 100%;
	height: 100%;
	box-sizing: border-box;
	background: #fff;
	padding-top: 20px;
}

.menu ul{
	list-style-type: none;
	margin: 0px 0px 20px 0px;
	padding: 0 2px;
	display: block;
	padding-bottom: 50px;
}

.menu ul li {
	width: 98%;
	text-indent: initial;
	height: auto;
	display: block;
	padding: 0px;
	margin: 0px;
}
.menu span.wrap,
.menu ul li a{
	overflow:visible;
	display: block;
	border-bottom: 1px #dddddd solid;
	padding: 10px 0px 10px 20px;
	margin: 0 0 0px 0;
	text-align: left;
	width:auto;
	height: auto;
	line-height: 2em;
	border-left: 0px;
	color: #000 !important;
	text-shadow: 0px 0px 0px #fff !important;
	font-size: 15px;
}
.menu a:hover{
	background-image: none;
	background-repeat: no-repeat;
	background-repeat: no-repeat;
	background-color: initial;
}
.menu ul li span.wrap:before,
.menu a:before {
	content: " ";
	border: 0px;
	height: 0px;
	background: #fff;
}
.menu ul li span.wrap:after,
.menu a:after{
	content: "＞";
	position: absolute;
	right: 20px;
	top: 10px;
	height: auto;
	background: #fff;
	opacity: 1;
	width: auto;
}
.menu .child {
	position: relative;
	width: auto;
	background: #eee;
	padding-bottom: 0px;
}
.menu .child a { background: #eee; color: #000; padding-left: 20px; font-weight: 300; }
.menu .child a:after { background: none; }
.menu li.has_child:hover .child { display: none; }
.menu li.sns { display: inline-block; width: 21%; padding: 10px 0px; margin: 10px 0.8% 10px 1.5%; }
.menu li.sns img { background: #000; margin: 0px auto; }
.menu li.menu0 a img,
.menu.pagemenu li.sns a img {
	filter: brightness(1) invert(0);
}
.menu li.sns a{ border: 0px; }
.menu li.sns a:after {
	content: "";
	position: absolute;
	right: 0px;	
}
.menu ul:after {
	clear: both;
	display: block;
	content: "";
	margin-bottom: 10px;
}

body.home .menu li.menu0 a img {
	filter: brightness(1) invert(1);
}

/* ------- メニュー部分 ------- */



/******************* SP menu ***************/
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: fixed;
	right: 0px;
	top: 0px;
	width: 50px;
	height: 44px;
	background: #060606;
	z-index: 100050;
}
.menu-trigger span {
	position: absolute;
	left: 5px;
	width: 40px;
	height: 3px;
	background-color: #fff;
}
.menu-trigger span:nth-of-type(1) {
	top: 10px;
}
.menu-trigger span:nth-of-type(2) {
	top: 20px;
}
.menu-trigger span:nth-of-type(3) {
	top: 30px;
}

.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 20px;
}
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}

.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
	top: 20px;
}
/******************* SP menu ***************/


/**************************** form  ****************************/
.contactform th,
.contactform td { display: block; width: auto; padding: 10px 0px 10px 10px; }
.wpcf7-form textarea { width: 95%; }
.contactform .spw { width: auto; padding-right: 0px !important; }
.contactform div { margin-left: 0px !important; }
span.wpcf7-list-item { margin-left: 0px !important; }


.contactform #books .wpcf7-list-item.first label:after {
	content: "　";
	display: inline-block;
	padding-bottom: 20px;
	max-width: 100%;
	background: url(/wp/wp-content/uploads/sassi-sumai-no-mori.png) no-repeat left center;
	background-size: contain;
	height: 106px;
	width: 300px;
	margin-bottom: 20px;
}
.contactform #books .wpcf7-list-item.last label:after {
	content: "　";
	display: inline-block;
	padding-bottom: 20px;
	max-width: 100%;
	background: url(/wp/wp-content/uploads/sassi-LIXIL-REFORM.png) no-repeat left center;
	background-size: contain;
	height: 106px;
	margin-bottom: 20px;
	width: 300px;
}
/**************************** form  ****************************/

.gaiyou {
	margin:10px 0px 20px 0px;
	border: solid 0px #c99269;
	border-collapse:collapse;
	text-align: left;
	line-height: 1.5em;
	width: 100%;
}

.gaiyou th,
.gaiyou td {
	width: auto;
	display: block;
}

.gaiyou th {
	border-bottom: 0px;
}

.history {
	margin:10px 0px 20px 0px;
	border: solid 0px #c99269;
	border-collapse:collapse;
	text-align: left;
	line-height: 1.5em;
	width: 100%;
}
.history th,
.history td {
	width: auto;
	display: block;
}

.history th {
	border-bottom: 0px;
}

.fixed #gnavi { z-index: 11; top: 58px; }
#gnavi.menu_open { height: 100%; }
#footer_fixed { z-index: 5; opacity: 100%; height: auto; padding: 0px; width: 100%; bottom: 0px; }
.morebottun-g { padding: 1.7em 2.5em 1.7em 2.5em;
	background: url(/images/yaji-w.png) no-repeat right center;
	background-position-x: 95%;
}
.morebottun-g:hover {
	color: #fff;
	background: url(/images/yaji-w.png) no-repeat right center;
	background-position-x: 95%;
}
#top-concept02 .concept-card { max-width: 90%; margin: auto; }
#top-work ul li { width: 48%; margin-bottom: 20px; }
#top-work ul li span.img {
	height: 45vw;
	overflow: hidden;
	width: 100%;
	border: 3px solid #E9E9E9;
	display: block;
	box-sizing: border-box;
}
#top-work ul li h2 { font-size: 14px; }

#top-reform ul li { width: 48%; margin-bottom: 20px; }
#top-reform ul li span.img {
	height: 45vw;
	overflow: hidden;
	width: 100%;
	border: 3px solid #E9E9E9;
	display: block;
	box-sizing: border-box;
}
#top-reform ul li h2 { font-size: 14px; }
#top-exterior ul li { width: 48%; margin-bottom: 20px; }
#top-exterior ul li span.img {
	height: 45vw;
	overflow: hidden;
	width: 100%;
	border: 3px solid #E9E9E9;
	display: block;
	box-sizing: border-box;
}
#top-exterior ul li h2 { font-size: 14px; }
#top-event ul.eventpickup { 
	display: flex;
	flex-wrap: wrap;
	gap: 2%;
	justify-content: center;
	padding-top: 0px;
	margin-bottom: 50px;
}
#top-event ul.eventpickup li { width: 48%; margin: 0px 0px 20px; }
#top-event ul.eventpickup li span.img {
	height: 45vw;
	overflow: hidden;
	width: 100%;
	border: 3px solid #E9E9E9;
	display: block;
	box-sizing: border-box;
}
#top-event ul.eventpickup li h2 { font-size: 14px; }
#top-company .com01 li a::after, #top-company02 .com02 li a::after {
	content: url(/images/yaji-gr.png);
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	color: #89c3c3;
	font-size: 0.8rem;
}
.topconwrap {
	width: 94%;
	margin: auto;
	padding-right: 0px;
}
.topconwrap h2 {
	font-size: 17px;
	line-height: 1.7em;
	font-weight: 500;
	margin: 0px 0px 1.5em;
}
#top01 {
	padding-top: 50px;
	padding-bottom: 0px;
	background: linear-gradient(180deg, #fff 0%, #fff 20%, #f4f9f9 20%, #f4f9f9 100%);
}
#top-concept {
	background: url(/images/concept-bg.png) no-repeat bottom left;
	background-size: 100%;
	position: relative;
	position: sticky;
}
.morebottun {
	position: relative;
	display: inline-block;
	padding: 1.7em 3em 1.7em 2em;

}
.topconwrap .more {
	margin-left: auto;
}
#top-company .topttl02 {
	font-size: 2em;
	font-weight: 500;
	color: #000;
	letter-spacing: 0.1em;
	line-height: 1.2;
	margin-bottom: 0.5em;
}
#toptel { position: absolute; right: 60px; }
#toptel .headtel { display: none; }
#top-reform {
	background: #f4f9f9;
	padding: 50px 0px 30px;
	position: sticky;
}

.section-title img { max-height: 30px; }
.mB { font-size: 18px; }
.midashi-d {
    position: relative;
    margin-top: 2.5em;
    margin-bottom: .5em;
    padding-bottom: 10px;
    color: #222;
    font-size: 15px;
    border-bottom: 1px solid #333;
}
.bukendata dl { width: 90%;}
.kanren ul.list02 li,
.kanren ul.list li { width: 98%; margin: 10px auto; height: auto; }
.kanren .list li img { width: 80px; height: 80px; }
br.sponly { display: block; }
