/*
Theme Name: onokensetsu
*/


@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@300;400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600;700&family=Zen+Antique&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap');


html {
 margin-top: 0px !important;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, pre,
abbr, address, cite, code,
del, dfn, img, ins, kbd, q, samp,
small, 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 {
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	background: transparent;
	font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.6em;
	margin-top: 0;
	margin-right: 0;
	margin-bottom: 0;
	margin-left: 0;
	color: #333;
	font-size: 15px;
	font-weight: 400;
	letter-spacing: 1px;
}

em {
	font-family: "M PLUS 1p", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #333;
	font-size: 15px;
	font-style: italic;	
}

body {
    line-height:1;
	-webkit-text-size-adjust: 100%;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}
nav ul {
    list-style:none;
}

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
	text-decoration: none;
	color: #333;
}
/* 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;
}

li {
	list-style: none;	
}

img {
	vertical-align: bottom;
	max-width: 100%;
	height: auto;
}

/*end reset*/

/* ----------------------------------------------------
    text
---------------------------------------------------- */

.serif {
	font-family: "M PLUS 1p", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝","ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.sans-serif {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.lato {
	font-family: 'Lato', sans-serif;
}

.futura {font-family: "futura-pt", sans-serif;}



.tc {text-align: center !important;}
.tr {text-align: right !important;}
.tl {text-align: left !important;}

.bold {font-weight:bold;}
 
.font10{font-size:10px !important;}
.font11{font-size:11px !important;}
.font12{font-size:12px !important;}
.font13{font-size:13px !important;}
.font14{font-size:14px !important;}
.font15{font-size:15px !important;}
.font16{font-size:16px !important;}
.font17{font-size:17px !important;}
.font18{font-size:18px !important;}
.font19{font-size:19px !important;}
.font20{font-size:20px !important;}
.font21{font-size:21px !important;}
.font22{font-size:22px !important;}
.font23{font-size:23px !important;}
.font24{font-size:24px !important;}
.font25{font-size:25px !important;}
.font26{font-size:26px !important;}
.font27{font-size:27px !important;}
.font28{font-size:28px !important;}
.font29{font-size:29px !important;}
.font30{font-size:30px !important;}
.font32{font-size:32px !important;}
.font34{font-size:34px !important;}
.font36{font-size:36px !important;}
.font40{font-size:40px !important;}
 
/* ----------------------------------------------------
    float
---------------------------------------------------- */
.fr {float: right !important;}
.fl {float: left !important;}
 
.clear {clear: both;}
 
.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
 
.clearfix {
  min-height: 1px;
}
 
* html .clearfix {
  height: 1px;
  /*¥*//*/
  height: auto;
  overflow: hidden;
  /**/
}
 

/* ----------------------------------------------------
    margin
---------------------------------------------------- */
 
.mt00 { margin-top:  0px !important; }
.mt05 { margin-top:  5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt50 { margin-top: 50px !important; }
.mt60 { margin-top: 60px !important; }
.mt80 { margin-top: 80px !important; }
 
.mr00 { margin-right:  0px !important; }
.mr05 { 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; }
.mr35 { margin-right: 35px !important; }
.mr40 { margin-right: 40px !important; }
.mr50 { margin-right: 50px !important; }
.mr60 { margin-right: 60px !important; }
.mr65 { margin-right: 65px !important; }
 
.mb00 { margin-bottom:  0px !important; }
.mb05 { 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; }
.mb50 { margin-bottom: 50px !important; }
.mb55 { margin-bottom: 55px !important; }
.mb60 { margin-bottom: 60px !important; }
.mb70 { margin-bottom: 70px !important; }
.mb76 { margin-bottom: 76px !important; }
.mb80 { margin-bottom: 80px !important; }
.mb90 { margin-bottom: 90px !important; }
.mb100 { margin-bottom: 100px !important; }
 
.ml00 { margin-left:  0px !important; }
.ml05 { margin-left:  5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.ml35 { margin-left: 35px !important; }
.ml40 { margin-left: 40px !important; }
 
/* ----------------------------------------------------
    padding
---------------------------------------------------- */
 
.pt00 { padding-top:  0px !important; }
.pt05 { 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; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt80 { padding-top: 80px !important; }
 
.pr00 { padding-right:  0px !important; }
.pr05 { padding-right:  5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }
.pr25 { padding-right: 25px !important; }
.pr30 { padding-right: 30px !important; }
.pr35 { padding-right: 35px !important; }
.pr40 { padding-right: 40px !important; }
 
.pb00 { padding-bottom:  0px !important; }
.pb05 { padding-bottom:  5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
 
.pl00 { padding-left:  0px !important; }
.pl05 { padding-left:  5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }
.pl25 { padding-left: 25px !important; }
.pl30 { padding-left: 30px !important; }
.pl35 { padding-left: 35px !important; }
.pl40 { padding-left: 40px !important; }






/* ----------------------------------------------------

    common

---------------------------------------------------- */


/* IE10以前でのみ有効 */
html {
height: 100%\9;
overflow: hidden\9;
}
body {
height: 100%\9;
overflow: scroll\9;
}
/* IE10以降でのみ有効 */
@media all and (-ms-high-contrast: none) {
	html {
		height: 100%;
		overflow: hidden;
	}
	body {
		height: 100%;
		overflow-y: scroll;
		overflow-x: hidden;
	}
}

.sec_in1000 {
	max-width: 1000px;
	width: 90%;
	margin: auto;
	position: relative;
	overflow: hidden;
}



.sec_in1200 {
	max-width: 1200px;
	width: 90%;
	margin: auto;
	position: relative;
	overflow: hidden;
}

.sec_in1300 {
	max-width: 1300px;
	width: 90%;
	margin: auto;
	position: relative;
}

.sec_in1400 {
	max-width: 1400px;
	width: 90%;
	margin: auto;
	position: relative;
	overflow: hidden;
}

.overflow-h {overflow: hidden;}

.object-fit-img {
  object-fit: contain;
  font-family: 'object-fit: contain;';
}

body {
	overflow-x: hidden;
	transition: .3s;
	position: relative;
	background-image: url("images/common/main_bg.png");
	background-repeat: repeat;
	background-position: left top;
	background-size: 240px;
}

.vegas-overlay {display: none;}

#b_slider {height: 100%;}




.page_wrap01 {padding: 220px 0 120px;}


.page_title01 {
	text-align: center;
	padding: 100px 5%;
	box-sizing: border-box;
	border-top: solid 1px #ddd;
}

.page_title01 p {
	font-size: 56px;
	font-weight: 400;
	letter-spacing: 4px;
	line-height: 1.1;
	margin-bottom: 13px;
}

.page_title01 h2 {
	font-size: 20px;
	letter-spacing: 3px;
	font-weight: 300;
	line-height: 1.2;
}



.error404 .page-title {
	font-size: 20px;
	font-weight: bold;
	color: #59452c
;
	text-align: center;
	margin-bottom: 30px;
}

.error404 .page-content {
	text-align: center;
}

.error404 .page-content p {
	margin-bottom: 20px;
}


.search .page-content p {
	margin-bottom: 20px;
}

.page_wrap01 input[type="search"] {
	font-size: 16px;
	box-sizing: border-box;
	padding: 10px;
	border: solid 1px #ccc;
	width: 86%;
}

.page_wrap01 input[type="submit"] {
	box-sizing: border-box;
	padding: 9px;
	font-size: 16px;
	text-align: center;
	color: #fff;
	background: #e38313;
	border: none;
	width: 13%;
	cursor: pointer;
}

.search .page-title {
	font-size: 22px;
	font-weight: bold;
	color: #e38313;
	text-align: center;
	margin-bottom: 30px;
}

.search article {
	padding-bottom: 30px;
	margin-bottom: 30px;
	border-bottom: solid 1px #ddd;
}

.search article .entry-title a {
	display: block;
	font-size: 20px;
	font-weight: bold;
	color: #e38313;
	margin-bottom: 10px;
}

.search article .entry-meta {display: none;}

.search article .entry-summary p {
	color: #999;
}

.page-template-default .site-content {
	padding: 90px 0;
}

.page-template-default .entry-header {
	display: none;
}

.page-template-default .edit-link {
	display: none;
}



.blog_pages {
	text-align: center;
	min-height: 30px;
	margin-bottom: 30px;
}

.blog_pages .page-numbers {
    border: solid 1px #222;
    padding: 4px 10px 4px;
    font-size: 15px;
    margin-right: 1px;
    color: #222;
	box-sizing: border-box;
}

.blog_pages .prev {
	padding: 4px 8px 4px;
}

.blog_pages .next {
	padding: 4px 8px 4px;
}

.blog_pages .current {
    border: solid 1px #222;
    padding: 4px 10px 4px;
    font-size: 15px;
    margin-right: 1px;
    color: #fff;
	background: #222;
	box-sizing: border-box;
}

a.page-numbers:hover {
	color: #fff;
	background: #222;
}

.main-content {padding-top: 140px;}
.home .main-content {padding-top: 0;}
.breadcrumbs {
	width: 50%;
	position: absolute;
	right: 0;
	bottom: 10px;
	z-index: 20;
	box-sizing: border-box;
	text-align: right;
	
}



.breadcrumbs p {
	font-size: 15px;
	letter-spacing: 1px;
	color: #666;
	line-height: 1.3;
	background: #ffe35f;
	display: inline-block;
	padding: 6px 20px;
	box-sizing: border-box;
	border-radius: 20px;
}

.breadcrumbs span {
	font-size: 15px;
	letter-spacing: 1px;
	color: #666;
	line-height: 1.3;
}

.breadcrumbs span a {
	font-size: 15px;
	letter-spacing: 1px;
	color: #666;
	line-height: 1.3;
	text-decoration: underline;
}

.breadcrumbs span a:hover {
	text-decoration: none;
	color: #e38313;
}

.page-header {padding-top: 0 !important;}


@media screen and ( max-width:991px ){
	.breadcrumbs {width: 100%;}
	.breadcrumbs p {font-size: 12px; letter-spacing: 0;}
	.breadcrumbs span {font-size: 12px; letter-spacing: 0;}
	.breadcrumbs span a {font-size: 12px; letter-spacing: 0;}
	.page_wrap01 {padding: 160px 0 100px;}
}

@media screen and ( max-width:767px ){
	.breadcrumbs {width: 80%; bottom: auto; top: 10px; right: 10px;}
	.page_wrap01 input[type="search"] {width: 76%;}
	.page_wrap01 input[type="submit"] {width: 23%;}
}

@media screen and ( max-width:567px ){
	.page_wrap01 input[type="search"] {width: 68%;}
	.page_wrap01 input[type="submit"] {width: 30%;}
	.page_wrap01 {padding: 170px 0 100px;}
	.blog_pages {margin-bottom: 20px;}
	.breadcrumbs p {font-size: 11px; padding: 4px 15px;}
	.breadcrumbs span {font-size: 11px;}
	.breadcrumbs span a {font-size: 11px;}
	.breadcrumbs2 {padding-top: 80px;}
}


.page_main {
	width: 86.46%;
	margin: 20px auto;
	height: 430px;
	position: relative;
}

.page_img {
	height: 370px;
	width: 100%;
	margin: auto;
	background-repeat: no-repeat;
	background-position: 100% 80px;
	background-attachment: fixed;
	background-size: contain;
	position: relative;
	border-radius: 20px;
	overflow: hidden;
}

/*お問い合わせ*/
.page-id-9 .page_img {background-image: url("images/contact/page_img.jpg");}

/*新築・リフォーム*/
.page-id-33 .page_img {background-image: url("images/service/page_img.jpg");}

/*外構・その他*/
.page-id-56 .page_img {background-image: url("images/service02/page_img.jpg");}



.page_main_title {
	position: absolute;
	bottom: 0;
	left: 6%;
	z-index: 10;
	max-width: 330px;
	width: 40%;
}





@media screen and ( max-width:1920px ){
	.page_img {background-size: 1920px;}
}

@media screen and ( max-width:1680px ){
	.page_main {height: 380px;}
	.page_img {background-size: 1680px; height: 320px;}
	.page_title01 {padding: 80px 5%;}
}

@media screen and ( max-width:1536px ){
	.main-content {padding-top: 114px;}
	.page_main {width: 92%;}
	.page_main_title {max-width: 280px;}
}

@media screen and ( max-width:1366px ){
	.page_main {height: 360px;}
	.page_img {background-size: 1366px; height: 300px;}
	.page_title01 {padding: 60px 5%;}
}

@media screen and ( max-width:991px ){
	.page_main {height: 320px;}
	.page_img {width: 100%; height: 270px; background-attachment: inherit; background-position: center center !important; background-size: cover; border-radius: 10px;}

	.main-content {padding-top: 90px;}
	.page_main_title {max-width: 250px;}
}

@media screen and ( max-width:767px ){ 
	.main-content {padding-top: 70px;}
	.page_title01 p {font-size: 46px; letter-spacing: 3px;}
	.page_title01 h2 {font-size: 17px; letter-spacing: 2px;}
	.page_main {height: 290px;}
	.page_img {height: 240px;}
	.page_main_title {width: 60%; left: 10%;}
}

@media screen and ( max-width:450px ){
	.page_main {height: 250px;}
	.page_img {height: 210px;}
	.page_title01 {padding: 50px 5%;}
	.page_title01 p {font-size: 40px; letter-spacing: 2px;}
	.page_title01 h2 {font-size: 16px; letter-spacing: 1px;}
	
}


#page {overflow-x: hidden;}











/* ----------------------------------------------------

    header

---------------------------------------------------- */

header {
	position: relative;
	
}

.header_top {
	overflow: hidden;
	padding:0;
	box-sizing: border-box;
	width: 100%;
	min-height: 80px;
	position: absolute;
	top: 0;
	z-index: 9500;
}

.header_top h1 {
	font-size: 14px;
	text-shadow: 2px 2px 8px #fff;
	transition: .3s;
	padding-bottom: 7px;
}

.header_top h1.hidden {opacity: 0;}

.header_left {
	float: left;
	max-width: 320px;
	width: 27%;
	opacity: 1;
	visibility: visible;
	transition: .3s;
	padding-top: 28px;
	padding-left: 2.5%;
}
.header_left.hidden {opacity: 0;}

.header_right {
	float: right;
	max-width: 790px;
	width: 70%;
	box-sizing: border-box;
	overflow: hidden;
	padding: 0 30px 0 10px;
}

.header_right01 {
	float: right;
}

.header_right02 {
	float: left;
	max-width: 470px;
	width: 62%;
}
.header_right03 {
	float: right;
	max-width: 260px;
	width: 35%;
}

.header_right_contact {
	width: 100%;
	background-image: url("images/header/h_contact_bg.png");
	background-repeat: no-repeat;
	background-position: center top;
	background-size: contain;
	box-sizing: border-box;
	padding: 66px 15px 24px 10px;
}

.header_right_contact a {
	display: block;
	width: 80%;
	margin: auto;
	max-width: 200px;
	box-sizing: border-box;
	padding: 14px;
	background: #59452c;
	font-size: 17px;
	line-height: 1.2;
	color: #fff;
	text-align: center;
	border-radius: 5px;
	transition: .3s;
}

.header_right_contact a img {
	padding-right: 8px;
}

.header_right_contact a:hover {
	background: #e38313;
}

.header_right02 {padding-top: 40px;}

.header_right02-01 {padding-bottom: 15px; overflow: hidden;}
.h_tel a {
	font-size: 28px;
	color: #e38313;
	line-height: 1.2;
	float: right;
}
.h_tel a img {padding-right: 5px; position: relative; bottom: 4px;}


.header_right02-02 nav {
	
	
}

.header_right02-02 nav ul {overflow: hidden; float: right; width: 100%; max-width: 452px;}

.header_right02-02 nav li {
	float: left;
	margin-right: 12%;
}
.header_right02-02 nav li:last-of-type {margin-right: 0;}
.header_right02-02 nav li a {
	font-size: 18px;
	color: #59452c;
	letter-spacing: 2px;
	line-height: 1.3;
	transition: .3s;
}
.header_right02-02 nav li a:hover {color: #e38313;}



.nav02 {
	width: 80px;
    height: 80px;
	border-radius: 50%;
    background: #59452c;
    position: fixed;
    right: 30px;
    top: 30px;
	box-sizing: border-box;
	z-index: 99999;
	padding: 11px 0 19px;
	cursor: pointer;
}

.main_img {
	position: relative;
	width: 100%;
	overflow: hidden;
}

.main_img_text01 {
	position: absolute;
	top: 15%;
	left: 16%;
	max-width: 234px;
	width: 12.2%;
	z-index: 10;
	animation: fluffy1 4s ease infinite;
	opacity: 0;
	transition: 1s;
}
.main_img_text01.load {
	opacity: 1;
}

.main_img_text02 {
	position: absolute;
	top: 54%;
	left: 14%;
	max-width: 278px;
	width: 14.5%;
	z-index: 10;
	animation: fluffy1 5.5s ease infinite;
	opacity: 0;
	transition: 1s;
}
.main_img_text02.load {
	opacity: 1;
	transform: translateY(0);
}

.main_img_text03 {
	position: absolute;
	top: 23%;
	right: 31%;
	max-width: 330px;
	width: 17.2%;
	z-index: 10;
	animation: fluffy1 7s ease infinite;
	opacity: 0;
	transition: 1s;
}
.main_img_text03.load {
	opacity: 1;
	transform: translateY(0);
}

.main_img_text04 {
	position: absolute;
	top: 21%;
	left: 33%;
	max-width: 125px;
	width: 6.52%;
	z-index: 10;
	opacity: 0;
	transform: translateY(80px);
	transition: 1.6s;
}
.main_img_text04.load {
	transform: translateY(0);
	opacity: 1;
}



@keyframes fluffy1 {
	0% { transform:translateY(0) }
	5% { transform:translateY(0) }
	10% { transform:translateY(0) }
	20% { transform:translateY(-14px) }
	25% { transform:translateY(0) }
	30% { transform:translateY(-14px) }
	50% { transform:translateY(0) }
	100% { transform:translateY(0) }
}



.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 100%;
    height: 100%;
	
	box-sizing: border-box;
}
.menu-trigger span {
	position: absolute;
	left: 0;
    right: 0;
    margin: auto;
	width: 30px;
	height: 1px;
	background-color: #fff;
	border-radius: 0;
}
.menu-trigger span:nth-of-type(1) {
	top: 20px;
	transform: translateY(-3px);
	transition: .2s;
}
.menu-trigger span:nth-of-type(2) {
	top: 24px;
}
.menu-trigger span:nth-of-type(3) {
	bottom: 21px;
	transform: translateY(3px);
	transition: .2s;
}

/*.nav02:hover span:nth-of-type(1) {
	transform: translateY(0);
}

.nav02:hover span:nth-of-type(3) {
	transform: translateY(0);
}*/

.menu-trigger.active {
	transition: .3s;
}

.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(4px) rotate(-45deg);
	transform: translateY(4px) rotate(-45deg);
	width: 30px;
}
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-4px) rotate(45deg);
	transform: translateY(-4px) rotate(45deg);
	width: 30px;
}

.menu-trigger p {
	text-align: center;
    font-size: 10px;
    color: #fff;
    letter-spacing: 0;
	position: absolute;
	bottom: 0;
	width: 30px;
	left: 0;
	right: 0;
	margin: auto;
}











.sp_menu_wrap {
	overflow: scroll;
    position: fixed;
    top: 0;
    z-index: 8000;
	margin: auto;
    color: #111;
    text-align: center;
	width: 100%;
    height: 100vh;
    /*padding: 10vh 10px 10vh;*/
	box-sizing: border-box;
	transition: .3s;
	opacity: 0;
	visibility: hidden;
	margin-right: 110px;
	background: #fff;
}

.sp_menu_wrap.open {
	opacity: 1;
	visibility: visible
}



.sp_menu_box {
	box-sizing: border-box;
	/*float: right;*/
	width: 100%;
	padding-top: 14vh;
	padding-bottom: 14vh
}

.sp_menu_in {
	max-width: 400px;
	width: 90%;
	margin: auto;
}

.sp_menu_in h2 {text-align: center; margin-bottom: 80px;}
.sp_menu_in ul {margin-bottom: 80px;}
.sp_menu_in li {margin-bottom: 40px;}
.sp_menu_in li a {
	font-size: 25px;
	letter-spacing: 5px;
	line-height: 1.3;
	color: #59452c;
}

.sp_menu_in li a span {
	text-align: center;
	display: block;
	font-size: 12px;
	color: #e38313;
}

.sp_menu_in li a:hover {
	color: #e38313;
}

.sp_menu_in li a:hover span {
	color: #e38313;
}

.sp_menu_info p {
	font-size: 15px;
	line-height: 2em;
	text-align: center;
	margin-bottom: 40px;
}

.sp_copy {
	text-align: center;
	font-size: 12px;
	letter-spacing: 2px;
	line-height: 1.3;
}

.sp_menu_btn {margin-bottom: 40px;}

.sp_menu_btn a {
	display: block;
	max-width: 400px;
	width: 100%;
	margin: auto;
	box-sizing: border-box;
	background: #dccd59;
	padding: 20px 10px;
	text-align: center;
	font-size: 16px;
	color: #222;
	transition: .3s;
}

.sp_menu_btn a img {
	padding-right: 10px;
	transition: .3s;
}

.sp_menu_btn a:hover {
	background: #b20000;
	color: #fff;
}

.sp_menu_btn a:hover img {
	filter: invert(100%);
}

.sp_menu_sns {margin: 30px 0 40px;}

.sp_menu_sns h4 a {
	display: block;
	width: 30px;
	margin: auto;
}




/* ----------------------------------------------------

    top

---------------------------------------------------- */


.top01 {padding: 140px 0 60px;}

.top01_in {
	max-width: 1460px;
	width: 90%;
	margin: auto;
}

.top01_left {
	float: left;
	max-width: 624px;
	width: 42%;
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(100px);
	opacity: 0;
	transition-delay: .5s;
}

.top01.show .top01_left {
	transform: translateY(0);
	opacity: 1;
}

.top01_right {
	float: right;
	max-width: 760px;
	width: 55%;
	padding-top: 40px;
}

.top01_title {
	display: block;
	box-sizing: border-box;
	padding: 70px 0 0 90px;
	background-image: url("images/top/title_icon01.png");
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 194px;
	font-size: 27px;
	letter-spacing: 2px;
	line-height: 1.5;
	color: #e38313;
	margin-bottom: 30px;
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(100px);
	opacity: 0;
	transition-delay: .6s;
}
.top01.show .top01_title {
	transform: translateY(0);
	opacity: 1;
}

.top01_right p {
	font-size: 16px;
	line-height: 1.8;
	letter-spacing: 2px;
	display: block;
	padding-left: 90px;
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(100px);
	opacity: 0;
	transition-delay: .7s;
}

.top01.show .top01_right p {
	transform: translateY(0);
	opacity: 1;
}

.top02 {padding-bottom: 150px;}
.top02_in {max-width: 1640px; width: 90%; margin: auto;}


.top02 .sec_title01 {
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(70px);
	opacity: 0;
	transition-delay: .4s;
}

.top02.show .sec_title01 {
	transform: translateY(0);
	opacity: 1;
}


.top02_bnr {
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(70px);
	opacity: 0;
	transition-delay: .5s;
}
.top02_bnr:nth-of-type(2) {transition-delay: .6s;}

.top02.show .top02_bnr {
	transform: translateY(0);
	opacity: 1;
}

.top02_bnr a {
	display: block;
	float: left;
	max-width: 750px;
	width: 45.74%;
	margin: 0 2.13%;
	background: #fff;
	transition: .5s;
}

.top02_bnr a:hover {background: #e38313;}

.top02_bnr a dl {display: table; width: 100%; box-sizing: border-box; padding: 14px; border: solid 1px #59452c; position: relative;}
.top02_bnr a dt {display: table-cell; width: 38%; max-width: 274px; vertical-align: top;}
.top02_bnr a dt img {object-fit: cover; width: 100%; height: 220px;}
.top02_bnr a dd {
	display: table-cell;
	box-sizing: border-box;
	padding: 0 10px 15px;
	text-align: center;
	vertical-align: middle;
}
.top02_bnr_no {
	display: block;
	max-width: 120px;
	width: 90%;
	margin: 0 auto 5px;
	font-size: 36px;
	color: #59452c;
	line-height: 1;
	letter-spacing: 0;
	padding-top: 45px;
	background-image: url("images/top/title_icon02.png");
	background-repeat: no-repeat;
	background-position: center top;
	background-size: 110px;
}

.top02_bnr a dd h3 {
	font-size: 32px;
	line-height: 1.2;
	letter-spacing: 3px;
	color: #e38313;
	display: block;
	margin-bottom: 6px;
	transition: .5s;
}

.top02_bnr a:hover dd h3 {
	color: #fff;
}

.top02_bnr_text {
	font-size: 14px;
	color: #59452c;
	line-height: 1.3;
	letter-spacing: 2px;
	text-align: center;
}

.top02_bnr_btn {
	max-width: 150px;
	width: 25%;
	position: absolute;
	right: 0;
	bottom: 0;
}


.top03 {
	padding-bottom: 90px;
	padding-top: calc(360 / 3840 * 100%);
	background-color: #bae6c3;
	background-image: url("images/top/top03_bg.png");
	background-repeat: no-repeat;
	background-position: center top;
	background-size: contain;
}

.top03_in {
	max-width: 1400px;
	width: 90%;
	margin: auto;
}

.top03_img {
	float: right;
	max-width: 718px;
	width: 52%;
	padding-top: 20px;
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(100px);
	opacity: 0;
	transition-delay: .3s;
}

.top03.show .top03_img {
	transform: translateY(0);
	opacity: 1;
}

.top03_text {
	float: left;
	max-width: 610px;
	width: 44%;
}

.sec_title02 {
	display: block;
	box-sizing: border-box;
	padding: 60px 0 0 80px;
	background-image: url("images/top/title_icon03.png");
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 193px;
	font-size: 32px;
	letter-spacing: 2px;
	line-height: 1.5;
	color: #59452c;
	margin-bottom: 30px;
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(70px);
	opacity: 0;
	transition-delay: .5s;
}

.top03.show .top03_text .sec_title02 {
	transform: translateY(0);
	opacity: 1;
}

.top03_text_in {
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(70px);
	opacity: 0;
	transition-delay: .6s;
}

.top03.show .top03_text_in {
	transform: translateY(0);
	opacity: 1;
}

.top03_text p {
	font-size: 16px;
	letter-spacing: 2px;
	line-height: 1.6;
}

.top03_text h3 {
	display: block;
	font-size: 22px;
	color: #b20000;
	letter-spacing: 2px;
	line-height: 1.3;
	padding: 4px 0 8px;
}

.top03_text h3 span {
	font-size: 1.5em;
	color: #b20000;
	letter-spacing: 1px;
	line-height: 1;
}

.top04 {
	padding-bottom:  calc(340 / 3840 * 100%);
	padding-top: calc(340 / 3840 * 100%);
	background-color: #fff;
	background-image: url("images/top/top04_bg01.png"), url("images/top/top04_bg02.png");
	background-repeat: no-repeat, no-repeat;
	background-position: center top, center bottom;
	background-size: contain, contain;
}

.top04_img {
	float: left;
	max-width: 723px;
	width: 53%;
}

.top04_text {
	float: right;
	max-width: 560px;
	width: 43%;
	padding-top: 30px;
}

.top04_text .sec_title01 {
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(70px);
	opacity: 0;
	transition-delay: .5s;
}

.top04.show .top04_text .sec_title01 {
	transform: translateY(0);
	opacity: 1;
}

.top04_text p {
	line-height: 1.8;
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(70px);
	opacity: 0;
	transition-delay: .6s;
}

.top04.show .top04_text p {
	transform: translateY(0);
	opacity: 1;
}

.top05 {padding: 90px 0; background: none;}

.top05_img {
	max-width: 754px;
	width: 54%;
}

.top05_text {
	max-width: 560px;
	width: 42%;
	padding-top: 30px;
}

.top05_text .sec_title01 {
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(70px);
	opacity: 0;
	transition-delay: .5s;
}

.top05.show .top05_text .sec_title01 {
	transform: translateY(0);
	opacity: 1;
}

.top05_text p {
	line-height: 1.8;
	transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
	transform: translateY(70px);
	opacity: 0;
	transition-delay: .6s;
}

.top05.show .top05_text p {
	transform: translateY(0);
	opacity: 1;
}





.sec_title01 {margin-bottom: 40px; text-align: center;}
.sec_title01 h2 {
	font-size: 34px;
	letter-spacing: 3px;
	line-height: 1.2;
	color: #e38313;
}
.sec_title01_icon {padding-bottom: 10px;}








.b_tel a {
	font-size: 33px;
	color: #f07b03;
	line-height: 1;
	font-weight: 600;
}

.b_tel a img {
	padding-right: 10px;
	position: relative;
	bottom: 4px;
}


.b_contact_btn a {
	display: block;
	box-sizing: border-box;
	padding: 16px 8px;
	text-align: center;
	color: #fff;
	font-size: 14px;
	line-height: 1.2;
	font-weight: 500;
	background: #f07b03;
	transition: .3s;
}

.b_contact_btn a img {
	padding-right: 8px;
}

.b_contact_btn a:hover {
	background: #c0c928;
	transform: scale(1);
}







.b_contact {
	position: relative;
	padding-top: calc(160 / 3840 * 100%);
	padding-bottom: 70px;
	background: #fff;
	background-image: url("images/top/b_contact_bg.png");
	background-repeat: no-repeat;
	background-position: center top;
	background-size: contain;
	
}

.b_contact_in {
	max-width: 940px;
	width: 90%;
	margin: auto;
}




.b_contact_text {
	font-size: 17px;
	letter-spacing: 2px;
	line-height: 1.6;
	text-align: center;
	margin-bottom: 35px;

}

.b_contact_left a {
	display: block;
	float: left;
	max-width: 520px;
	width: 47%;
	margin: 0 1%;
	box-sizing: border-box;
	text-align: center;
	padding: 18px 10px 10px;
	background: #fff;
	border: solid 1px #7d6056;
	border-radius: 60px;
	min-height: 112px;
	transform: translateY(200px);
	opacity: 0;
	transition: all 1s;
	transition-delay: .5s;
}

.b_contact.show .b_contact_left a {
	transform: translateY(0);
	opacity: 1;
}

.b_contact_left a h3 {
	font-size: 16px;
	line-height: 1.3;
}

.b_contact_left a h4 {
	font-size: 30px;
	line-height: 1.3;
	color: #e38313;
}

.b_contact_left a h4 img {
	padding-right: 7px;
	position: relative;
	bottom: 6px;
}

.b_contact_left a p {
	font-size: 13px;
}

.b_contact_right {
	transform: translateY(200px);
	opacity: 0;
	transition: all 1s;
	transition-delay: .7s;
}

.b_contact.show .b_contact_right {
	transform: translateY(0);
	opacity: 1;
}

.b_contact_right a {
	display: block;
	float: right;
	max-width: 520px;
	width: 47%;
	margin: 0 1%;
	box-sizing: border-box;
	text-align: center;
	padding: 45px 10px 20px;
	min-height: 112px;
	background: #47aab3;
	border-radius: 60px;
	color: #fff;
	font-size: 18px;
	transition: .3s;
	
}

.b_contact_right a img {
	padding-right: 15px;
	position: relative;
	bottom: 2px;
}

.b_contact_right a:hover {
	background: #e38313;
}










/* ----------------------------------------------------

    footer

---------------------------------------------------- */

footer {
	box-sizing: border-box;
	padding-top: calc(360 / 3840 * 100%);
	background: #bae6c3;
	position: relative;
	background-image: url("images/footer/f_bg01.png");
	background-repeat: no-repeat;
	background-position: center top;
	background-size: contain;
}


.footer_in {
	width: 88%;
	margin: auto;
	overflow: hidden;
	padding-bottom: 60px;
	padding-top: 40px;
}

.footer_left {
	max-width: 500px;
	width: 48%;
	float: left;
}

.footer_right {
	max-width: 400px;
	width: 49%;
	float: right;
	overflow: hidden;
}

.footer_left h2 {
	margin-bottom: 20px;
}

.footer_left h3 {
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 3px;
	line-height: 1.2;
	margin-bottom: 6px;
}

.footer_left p {
	font-size: 17px;
	font-weight: 400;
	letter-spacing: 1px;
	line-height: 1.7;
}

.footer_left p a {
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 2px;
	line-height: 1.7;
}

.footer_left p a:hover {
	text-decoration: underline;
}

.f_nav {
	margin-bottom: 30px;
	overflow: hidden;
}

.f_nav_left {
	float: left;
	max-width: 200px;
	width: 50%;
}

.f_nav_right {
	float: right;
	max-width: 200px;
	width: 48%;
}

.f_nav h3 {
	font-size: 20px;
	font-weight: 400;
	color: #59452c;
	line-height: 1.3;
	margin-bottom: 20px;
	letter-spacing: 2px;
}

.f_nav li {
	list-style: none;
	margin-bottom: 25px;
}



.f_nav li a {
	font-size: 16px;
	font-weight: 400;
	letter-spacing: 2px;
	line-height: 1.3;
	padding-left: 28px;
	display: block;
	position: relative;
	background-image: url("images/footer/f_nav_icon.png");
	background-repeat: no-repeat;
	background-size: 20px;
	background-position: left center;
}

.f_nav li a:hover {
	color: #e38313;
	text-decoration: underline;
}

.f_bnr a {
	display: block;
	float: right;
}

.f_bnr a:hover {opacity: 0.8;}


.footer_right_bottom {
	float: right;
	width: 100%;
}

.footer_qr {
	float: left;
	max-width: 274px;
	width: 70%;
}



.f_insta {padding-top: 20px;}

.footer_bottom {
	width: 100%;
	box-sizing: border-box;
	padding: 25px;
}

.f_copy {
	font-size: 12px;
	line-height: 1.4;
	letter-spacing: 2px;
	text-align: center;
}

.page_top a {
	display: block;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background: #47aab3;
	transition: .3s;
	box-sizing: border-box;
	padding: 4px 10px;
	text-align: center;
	position: absolute;
	bottom: 40px;
	right: 2%;
	z-index: 10;
}

.page_top a:hover {background: #e38313;}











/* ----------------------------------------------------

    contact

---------------------------------------------------- */

.page-id-9 footer {background-image: url(images/footer/f_bg02.png);}

.grecaptcha-badge { visibility: hidden; }
.contact01 {padding: 40px 0 20px;}

.contact01_text {font-size: 16px; text-align: center; margin-bottom: 50px; line-height: 1.7; letter-spacing: 2px;}

.contact01_box01 {max-width: 470px; width: 100%; margin: 0 auto 30px; box-sizing: border-box; padding: 17px 10px; border: solid 1px #7d6056; border-radius: 60px; background: #fff;}
.contact01_box01_text01 {text-align: center; font-size: 16px; font-weight: 500;}
.contact01_box01 .bottom_info_tel {opacity: 1; transform: translateY(0); text-align: center;}
.contact01_box01 .bottom_info_tel a {font-size: 30px; line-height: 1; color: #e38313;}
.contact01_box01 .bottom_info_tel a img {padding-right: 5px; position: relative; bottom: 5px;}
.contact01_box01 .bottom_info_right_text {opacity: 1; transform: translateY(0); margin-bottom: 0; text-align: center; font-size: 14px;}


.contact02 {padding: 0 0 130px;}
.contact02_title {
	font-size: 28px;
	letter-spacing: 2px;
	line-height: 1.3;
	color: #1258c3;
	text-align: center;
	margin-bottom: 40px;
}
.contact02 dl {
	display:table;
	width:100%;
	padding: 10px 0;
	margin-bottom: 10px;
}

.contact02 dl dt {
	display:table-cell;
	width:26%;
	box-sizing:border-box;
	vertical-align:top;
	font-weight: 500;
	font-size: 15px;
	padding-top: 5px;
}

.contact02 dl dt p {font-size: 16px;}

.contact02 dl dd {
	display:table-cell;
	width:74%;
	box-sizing:border-box;
}

.input_dummy {
	width:500px;
	height:36px;
	box-sizing:border-box;
	background-color:#fff;
}

.textarea_dummy {
	width:500px;
	height:165px;
	box-sizing:border-box;
	background-color:#fff;
}

#zip {
    width: 200px;
}

.contact02 .contact02_in p {
	margin-bottom: 0;
}

.contact02 .contact02_in .required {
	color:#fff;
	background-color:#b20000;
	margin: 0 10px 0 0;
	letter-spacing: 1px;
	font-size: 11px;
	padding: 2px 5px 2px;
}

.contact02 .contact02_in .required02 {
	display:block;
	padding-left: 31%;
	font-size:12px;
	color:#999;
    margin-bottom: -30px;
    margin-top: 10px;
	letter-spacing: 0;
	text-align: left;
}
.contact02 .contact02_in .required02 {
	padding-left: 0;
	margin-bottom: 3px;
}
.required2 {
    color: #fff;
    background-color: #aaa;
    font-size: 11px;
    padding: 2px 5px;
	margin: 0 10px 0 0;
	letter-spacing: 1px;
}

.yuubin .required02 {
    padding-left: 3%;
    display: inline;
}

.contact02 input[type="text"] {
	font-size: 16px;
    padding: 14px;
	width: 100%;
	background: #fff;
	box-sizing: border-box;
	border: solid 1px #ccc;
}

.contact02 input[type="email"] {
	font-size: 16px;
    padding: 14px;
	width: 100%;
	border: solid 1px #ccc;
	background: #fff;
	box-sizing: border-box;
}

.contact02 input[type="tel"] {
	font-size: 16px;
    padding: 14px;
	width: 100%;
	border: solid 1px #ccc;
	background: #fff;
	box-sizing: border-box;
}

.contact02 input[type="radio"] {
	margin-top: 0;
	transform: scale(1.3);
}

.contact02 input[type="number"] {
	font-size: 16px;
    padding: 14px;
	width: 100px;
	border: solid 1px #ccc;
	background: #fff;
	box-sizing: border-box;
	margin: 0 5px 5px;
}

.contact02 textarea {
	font-size: 16px;
    padding: 14px;
    width: 100%;
	border: solid 1px #ccc;
	background: #fff;
	box-sizing: border-box;
}

.contact02 input[type="submit"] {
	max-width:400px;
	width: 80%;
	margin: 30px auto 0;
	box-sizing:border-box;
	display:block;
	text-align:center;
	background-color:#47aab3;
	color:#fff;
    padding: 18px 0;
	font-size: 17px;
	letter-spacing: 1px;
	cursor: pointer;
	border: none;
	border-radius: 40px;
	-webkit-appearance: none;
	transition: .3s;
}

.contact02 input[type="submit"]:hover {
	background-color:#e38313;
	transition: .3s;
}

.wpcf7-list-item {
	margin-left: 0;
	margin-right: 3em;
}

.wpcf7-list-item span {
	font-size: 16px;
}


#zip_txt {
    font-size: 12px;
    padding-left: 7px;
    color: #999;
    line-height: 1.3em;
	letter-spacing: 0;
}





@media screen and ( max-width:991px ){
	.contact01_text {font-size: 15px;}
	
}

@media screen and ( max-width:767px ){
	.contact01 {padding: 0 0 70px;}
	.contact01_text {margin-bottom: 30px; text-align: left;}
	.contact01_box01_text01 {font-size: 16px;}
	
	.contact02 dl {display: block;width: 100%;}
	.contact02 dl dt {display: block;width: 100%;font-size: 14px;}
	.contact02 dl dd {display: block;width: 100%;padding: 10px 0;}
	.wpcf7-list-item {display: block;width: 100%;margin-bottom: 4px;margin-right: 0;}
	.contact02_in p.tc {text-align: left !important;}
	.contact02 input[type="submit"] {font-size: 15px;}
}

@media screen and ( max-width:567px ){
	.contact01 {padding: 0 0 20px;}
	.contact01_text br {display: none;}
	.contact01_box01 .bottom_info_tel a {font-size: 26px;}
	.contact01_box01 .bottom_info_right_text {font-size: 12px;}
	.contact01_box01 {padding: 12px 15px;}
	.contact01_box01_text01 {font-size: 15px;}
	.contact02 {padding-bottom: 60px;}
	.contact02_in {padding-bottom: 10px;}
	.contact02 dl dt p {font-size: 15px;}
	.contact02 input[type="number"] {width: 70px; padding: 14px 8px;}
	.recruit03_text {font-size: 15px; letter-spacing: 1px; text-align: left; margin-bottom: 20px;}
}

@media screen and ( max-width:450px ){
	.contact01_text {font-size: 14px;}
	.contact01_box01 {margin-bottom: 20px;}
	.contact02 {padding-bottom: 70px;}
	.contact02 dl {margin-bottom: 0;}
	
}




/* ----------------------------------------------------

    build

---------------------------------------------------- */


.build01 {padding-bottom: 100px;}

.build01_in {max-width: 1480px; width: 90%; margin: auto;}

.service01_in {padding-top: 30px;}
.service01_in dl {display: table; width: 100%;}
.service01_in dt {
	display: table-cell;
	max-width: 620px;
	width: 45%;
}

.service01_in dt img {
	object-fit: cover;
	width: 100%;
	height: 400px;
	border-radius: 16px;
}

.service01_in dd {
	display: table-cell;
	vertical-align: middle;
	padding-left: 5%;
	box-sizing: border-box;
}

.service01_in dd h3 {
	font-size: 26px;
	letter-spacing: 2px;
	line-height: 1.4;
	display: block;
	margin-bottom: 25px;
	color: #e38313;
}

.service01_in dd p {
	font-size: 16px;
	letter-spacing: 1px;
	line-height: 1.7;
}

.sec_title_text {
	font-size: 14px;
	color: #59452c;
	letter-spacing: 1px;
	padding-top: 10px;
}

.works_wrap01 {padding-bottom: 70px;}

.works_wrap01_in {max-width: 1380px; width: 100%; margin: auto;}

.works_box a {
	display: block;
	width: 30.3%;
	float: left;
	margin: 0 1.5% 35px;
	box-sizing: border-box;
	border: solid 1px #59452c;
	background: #fff;
	padding: 10px;
	transition: .5s;
	min-height: 460px;
}

.works_box a:hover {background: #59452c}

.works_box_img {position: relative;}

.works_box_img img {
	object-fit: cover;
	width: 100%;
	height: 280px;
	transition: .5s;
}
.works_box a:hover .works_box_img img {filter: brightness(0.3);}

.works_box_img span {
	display: block;
	width: 100px;
	text-align: center;
	font-size: 14px;
	line-height: 1.1;
	color: #fff;
	position: absolute;
	top: 49%;
	left: 0;
	right: 0;
	margin: auto;
	opacity: 0;
	transition: .5s;
}

.works_box a:hover .works_box_img span {opacity: 1;}

.works_box_text {padding: 15px 10px 5px;}

.works_cat {
	display: inline-block;
	box-sizing: border-box;
	padding: 5px 15px;
	font-size: 16px;
	line-height: 1;
	letter-spacing: 1px;
	color: #59452c;
	background: #ffe35f;
}

.works_title {
	display: block;
	padding: 10px 0 10px;
	font-size: 22px;
	color: #e38313;
	letter-spacing: 2px;
	line-height: 1.3;
}

.works_area {
	font-size: 16px;
	display: block;
	line-height: 1.3;
	transition: .5s;
}
.works_box a:hover .works_area {color: #fff;}



@media screen and ( max-width:1366px ){
	.works_box_img img {height: 220px;}
	.works_box a {min-height: 420px;}
}

@media screen and ( max-width:991px ){
	.service01_in dt {display: block; width: 100%; margin: 0 auto 30px;}
	.service01_in dd {display: block; width: 100%; margin: 0 auto; padding-left: 0;}
	
	.works_box_img img {height: 160px;}
	.works_box a {min-height: 340px;}
	.works_title {font-size: 20px; letter-spacing: 1px;}
	.works_cat {font-size: 15px;}
	.works_area {font-size: 15px;}
	.works_box_text {padding: 15px 0 5px;}
}

@media screen and ( max-width:767px ){
	.works_box a {width: 46%; margin: 0 2% 30px;}
}

@media screen and ( max-width:567px ){
	.service01_in dt img {height: 280px; border-radius: 10px;}
	.service01_in dd h3 {font-size: 24px;}
	.service01_in dd p {font-size: 15px;}
	.build01 {padding-bottom: 70px;}
	
}

@media screen and ( max-width:500px ){
	.works_box a {float: none;  width: 100%; margin: 0 auto 20px; min-height: inherit;}
	.works_cat {padding: 3px 13px; font-size: 14px;}
	.works_box_img img {height: 200px;}
	.works_wrap01_in {width: 90%;}
	.page-id-56 .works_wrap01_in {width: 100%;}
}

@media screen and ( max-width:450px ){
	.service01_in dt img {height: 210px;}
	.works_box_img img {height: 180px;}
}













/* ----------------------------------------------------

    service_single

---------------------------------------------------- */



.page_main_service {height: 50px !important; width: 90% !important;}

.service_single_slide {background: #fff; box-sizing: border-box; padding: 30px 0 20px; margin-bottom: 40px;}

.service_single_slide .slick-img img {
	width: 100%;
	object-fit: cover;
	height: 550px;
}

.single_slider {max-width: 900px; width: 85%; margin: auto;}

.single_thumbnail {max-width: 660px; width: 85%; margin: auto;}
.thumbnail-img {margin: 0 3px;}

.single_thumbnail {padding-top: 10px;}
.single_thumbnail .slick-track {
  transform: unset !important;
}

.single_thumbnail .slick-current {opacity: 0.7;}

.single_thumbnail .thumbnail-img:hover {opacity: 0.7;}

.single_thumbnail .thumbnail-img img {
	object-fit: cover;
	width: 100%;
	height: 76px;
}

.slide-arrow {
  background-color: #333;
  bottom: 0;
  height: 0;
  margin: auto;
  position: absolute;
  top: 0;
  width: 0;
}

.prev-arrow {left: -28px;}
.next-arrow {right: -15px;}
.prev-arrow i {
  font-size: 38px;
  color: #888;
  
}
.next-arrow i {
  font-size: 38px;
  color: #888;
}

.works_cat02 span {
	display: inline-block;
	box-sizing: border-box;
	padding: 5px 15px;
	font-size: 16px;
	line-height: 1;
	letter-spacing: 1px;
	color: #59452c;
	background: #ffe35f;
	margin-right: 10px;
}

.works_cat02 {
	font-size: 16px;
	line-height: 1.3;
}

.point_wrap {padding-top: 25px; padding-bottom: 35px; border-bottom: solid 1px #ccc; margin-bottom: 50px;}

.point_wrap p {font-size: 16px; line-height: 1.7;}

.single_btn {margin-bottom: 100px;}
.single_btn a {
	display: block;
	max-width: 260px;
	width: 100%;
	margin: auto;
	box-sizing: border-box;
	padding: 13px;
	background: #59452c;
	font-size: 17px;
	color: #fff;
	line-height: 1.2;
	text-align: center;
	border-radius: 30px;
	transition: .3s;
}

.single_btn a:hover {background: #e38313;}





@media screen and ( max-width:991px ){
	.works_cat02 span {font-size: 15px;}
	.service_single_slide .slick-img img {height: 460px;}
}

@media screen and ( max-width:767px ){
	.service_single_slide .slick-img img {height: 350px;}
	.single_thumbnail .thumbnail-img img {height: 60px;}
	.service_single_slide {margin-bottom: 20px;}
	.point_wrap {padding: 10px 0 25px; margin-bottom: 40px;}
	.single_btn {margin-bottom: 60px;}
}

@media screen and ( max-width:567px ){
	.service_single_slide .slick-img img {height: 280px;}
	.single_thumbnail .thumbnail-img img {height: 45px;}
	.prev-arrow i {font-size: 30px;}
	.next-arrow i {font-size: 30px;}
	.single_btn a {font-size: 15px;}
}


@media screen and ( max-width:500px ){
	.works_cat02 span {padding: 3px 13px; font-size: 14px;}
	.prev-arrow {left: -24px;}
	.next-arrow {right: -13px;}
	.service_single_slide .slick-img img {height: 240px;}
	.single_thumbnail .thumbnail-img img {height: 40px;}
}

@media screen and ( max-width:450px ){
	.prev-arrow {left: -20px;}
	.next-arrow {right: -9px;}
	.service_single_slide .slick-img img {height: 200px;}
	.single_thumbnail .thumbnail-img img {height: 30px;}
	.thumbnail-img {margin: 0 2px;}
	.prev-arrow i {font-size: 26px;}
	.next-arrow i {font-size: 26px;}
	.page_main_service {margin: 10px auto;}
	.single_wrap .sec_title01 img {width: 120px;}
}







/* ----------------------------------------------------

    service02

---------------------------------------------------- */

.service02_nav_wrap {
	max-width: 720px;
	width: 100%;
	margin: 0 auto;
}

.service02_nav a {
	display: block;
	box-sizing: border-box;
	width: 30.3%;
	float: left;
	margin: 0 1.5%;
	padding: 11px;
	text-align: center;
	font-size: 18px;
	color: #59452c;
	border: solid 1px #59452c;
	line-height: 1.2;
	transition: .3s;
}
.service01_nav a:hover {
	background: #59452c;
	color: #fff;
}

.other01 {padding: 90px 0; background: #fff;}

.other_sec .service01_in {margin-bottom: 100px;}

.other02 {padding: 90px 0;}

#store {margin-bottom: 100px;}





@media screen and ( max-width:1366px ){
	.other01 {padding: 70px 0;}
	.other_sec .service01_in {margin-bottom: 70px;}
	.other02 {padding: 70px 0;}
}

@media screen and ( max-width:767px ){
	.other_sec .sec_title01 {margin-bottom: 20px;}
}

@media screen and ( max-width:567px ){
	.other01 {padding: 50px 0;}
	.other_sec .service01_in {margin-bottom: 50px;}
	.other02 {padding: 50px 0;}
	.other_sec .sec_title01 {margin-bottom: 0;}
	.other_sec .service01_in dd h3 {font-size: 21px;}
	.service02_nav a {font-size: 15px; padding: 10px;}
	.page-id-56 .build01 {padding-bottom: 50px;}
	.service02_nav_wrap {padding-top: 20px;}
	.other_sec .sec_title01 img {width: 120px;}
	#store {margin-bottom: 60px;}
}





/* ----------------------------------------------------

    メディアクエリ

---------------------------------------------------- */



.max1366 {display: none !important;}
.min1367 {display: block !important;}
.max1279 {display: none !important;}
.min1280 {display: block !important;}
.max1199 {display: none !important;}
.min1200 {display: block !important;}
.max991 {display: none !important;}
.min992 {display: block !important;}
.max850 {display: none !important;}
.min851 {display: block !important;}
.max767 {display: none !important;}
.min768 {display: block !important;}
.max567 {display: none !important;}
.min568 {display: block !important;}
.max450 {display: none !important;}
.min451 {display: block !important;}



@media screen and ( min-width:1921px ){
	
}


@media screen and ( max-width:1680px ){
	.main_img_text01 {top: 18%;}
	.top01 {padding: 110px 0 60px;}
}

@media screen and ( max-width:1536px ){
	.header_left {max-width: 240px; padding-top: 20px;}
	.header_right02 {padding-top: 25px; width: 64%; max-width: 390px;}
	.header_right03 {max-width: 220px; width: 32%;}
	.header_right_contact {padding: 53px 15px 22px 10px;}
	.header_right_contact a {width: 90%; font-size: 16px;}
	.header_right_contact a img {width: 18px; position: relative; bottom: 1px;}
	.header_right {max-width: 660px;}
	.header_right02-02 nav li {margin-right: 10%;}
	.header_right02-02 nav li:last-of-type {margin-right: 0;}
	.header_right02-02 nav li a {font-size: 17px; letter-spacing: 1px;}
	.header_right02-01 {padding-bottom: 8px;}
	.h_tel a {font-size: 24px;}
	
	.sp_menu {padding-top: 10vh;}
	.header_top h1 {font-size: 13px;}
	
	.top01_right {padding-top: 0;}
	.top01_title {background-size: 160px; padding: 55px 0 0 70px; margin-bottom: 25px;}
	.top01_right p {padding-left: 70px;}
	
	.sec_title02 {background-size: 160px; padding: 55px 0 0 70px; margin-bottom: 25px;}
	
}

@media screen and ( max-width:1366px ){
	.max1366 {display: block !important;}
	.min1367 {display: none !important;}

	.header_left {padding-top: 20px; max-width: 220px;}
	.main_img {padding-top: 30px;}
	
	.nav02 {width: 70px; height: 70px; padding: 6px 0 14px; right: 20px; top: 20px;}
	
	
	
	.top01_title {font-size: 24px;}
	.top01_right p {font-size: 15px; letter-spacing: 1px; line-height: 1.7;}
	
	.top02 {padding-bottom: 120px;}
	.top02_bnr_no {font-size: 28px; background-size: 90px; padding-top: 38px;}
	.top02_bnr a dd h3 {font-size: 26px; letter-spacing: 1px;}
	.top02_bnr_text {font-size: 12px; letter-spacing: 1px;}

	
	.sec_title02 {background-size: 140px; padding: 45px 0 0 60px; font-size: 28px; letter-spacing: 1px;}
	.top03_text p {font-size: 15px; letter-spacing: 1px;}
	.top03_text h3 {font-size: 18px;}
	
	
	
	.b_contact {background-position: center top;}


	.footer_left {width: 36%;}
	.footer_right {width: 62%;}
	.footer_left h3 {font-size: 18px; margin-bottom: 10px;}
	.footer_left p {font-size: 15px; letter-spacing: 1px; line-height: 1.5;}
	.f_nav li a {letter-spacing: 1px; font-size: 15px; background-size: 18px;}
}

@media screen and ( max-width:1279px ){
	.max1279 {display: block !important;}
	.min1280 {display: none !important;}
	

	.b_tel a {font-size: 26px;}
	.b_tel a img {width: 20px;}
	.b_contact_btn a {font-size: 12px;}
}

@media screen and ( max-width:1199px ){
	.max1199 {display: block !important;}
	.min1200 {display: none !important;}
	
	.header_left {max-width: 180px; padding-top: 26px;}
	.main_img {padding-top: 10px;}
	.main_img_text01 {top: 22%;}
	.main_img_text04 {top: 27%;}
	
	.top01 {padding: 80px 0 60px;}

	.b_contact {padding: 70px 0;}
	.b_contact_in {max-width: 760px;}
	.b_contact_in .sec_title01 {margin-bottom: 60px;}
	.b_contact_left a h4 {font-size: 24px;}
	.b_contact_left a h4 img {width: 20px;}
	.b_contact_left a p {letter-spacing: 0; font-size: 12px;}
	.b_contact_right a {font-size: 15px; min-height: 100px;padding: 37px 10px 20px;}
	.b_contact_right a img {padding-right: 8px; width: 18px; bottom: 3px;}
	.b_contact_left a h3 {font-size: 15px;}
	.b_contact_left a {min-height: 100px; padding: 16px 10px 10px;}
	.b_contact_text {font-size: 18px; margin-bottom: 20px;}
}

@media screen and ( max-width:991px ){
	.max991 {display: block !important;}
	.min992 {display: none !important;}

	
	.sp_menu_in {max-width: 350px;}
	.sp_menu_in h2 img {width: 200px;}
	.sp_menu_in h2 {margin-bottom: 60px;}
	.sp_menu_in li {margin-bottom: 30px;}
	.sp_menu_in li a {font-size: 20px; letter-spacing: 3px;}
	.sp_menu_in li a span {font-size: 13px;}
	.sp_menu_info p {font-size: 12px; line-height: 1.8;}
	.sp_copy {font-size: 10px; letter-spacing: 1px; color: #999;}
	
	
	.sp_bottom_btn a {display: block; width: 100%; box-sizing: border-box; position: fixed; bottom: 0; left: 0; padding: 20px; text-align: center; font-size: 16px; line-height: 1.3; color: #fff; background: #47aab3; z-index: 9999;}
	.sp_bottom_btn a img {padding-right: 8px; position: relative; bottom: 1px;}
	
	
	.top01 {padding: 80px 0 60px;}
	
	.top01_left {float: none; width: 80%; margin: 0 auto 30px;}
	.top01_right {float: none; width: 100%; margin: 0 auto;}
	.top01_title {background-size: 130px; padding: 65px 0 0 0; margin-bottom: 20px;}
	.top01_right p {padding-left: 0;}
	
	.top02 {padding-bottom: 90px;}
	.top02_bnr a {float: none; width: 100%; margin: 0 auto 20px;}
	.top02_bnr_btn {max-width: 120px;}
	.top02_bnr a dt img {height: 180px;}
	
	.top03 {background-size: 1000px;}
	.top03_img {float: none; width: 90%; margin: 0 auto 10px; max-width: 600px;}
	.top03_text {float: none; width: 100%; margin: 0 auto;}
	.top04 {background-size: 1000px, 1000px; padding: 80px 0 100px;}
	.top04_text {padding-top: 0;}
	
	.top05 {padding: 50px 0 70px;}
	.top05_text {padding-top: 0;}
	
	.b_contact {background-size: 1000px;}
	.b_contact_in {max-width: 660px;}

	footer {margin-bottom: 60px; padding-bottom: 30px; background-size: 1000px;}
	.footer_left {float: none; width: 100%; margin: 0 auto 60px; max-width: 300px; text-align: center;}
	.footer_right {float: none; width: 100%; margin: 0 auto; max-width: 330px;}
	.footer_right_bottom {float: none; margin: auto;}
	.f_nav_left {width: 40%;}
	.f_nav_right {width: 54%;}
	.f_copy {font-size: 11px; letter-spacing: 1px;}
	
	.footer_left h2 img {width: 200px;}
	.f_nav h3 {font-size: 17px;}
	
	.footer_in {padding-bottom: 20px;}
}

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

}

@media screen and ( max-width:767px ){
	.max767 {display: block !important;}
	.min768 {display: none !important;}
	
	
	.header_left {max-width: 150px; padding-top: 5px;}
	.sp_menu {padding-bottom: 15vh;}
	
	.nav02 {width: 60px; height: 60px; padding: 4px 0 6px; right: 15px; top: 15px;}
	
	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}
	.menu-trigger {
		position: relative;
		width: 100%;
		height: 100%;
	}
	.menu-trigger span {
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		width: 30px;
		height: 1px;
		background-color: #fff;
		border-radius: 0;
	}
	
	.menu-trigger span:nth-of-type(1) {top: 16px;}
	.menu-trigger span:nth-of-type(2) {top: 19px;}
	.menu-trigger span:nth-of-type(3) {bottom: 27px;}
	.menu-trigger.active span:nth-of-type(1) {transform: translateY(3px) rotate(-45deg);}
	.menu-trigger.active span:nth-of-type(3) {transform: translateY(-3px) rotate(45deg);}

	.menu-trigger p {
		text-align: center;
		font-size: 10px;
		color: #fff;
		position: absolute;
		bottom: 5px;
		left: 0;
		right: 0;
		letter-spacing: 0;
	}
	
	.header_right {max-width: 180px; padding: 10px 30px 0 10px;}
	.header_top {padding-top: 15px;}
	.header_left {width: 43%;}
	.header_right {width: 52%;}
	
	
	
	.news_box {width: 48%; margin: 0 1% 30px;}
	.news_list {margin-bottom: 10px;}
	.news_list_cat {margin-bottom: 5px;}
	
	
	
	.news_box02 dt {display: block; width: 100%; margin-bottom: 2px;}
	.news_box02 dt span {float: none; padding: 3px 8px; font-size: 12px; width: 90px;}
	.news_box02 dd {display: block; padding-left: 0; width: 100%;}
	.news_box02 dl {padding: 15px 10px;}
	
	.b_contact_in {max-width: 400px;}
	.b_contact_text {font-size: 16px;}
	.b_contact_left a {float: none; width: 100%; margin: 0 auto 15px;}
	.b_contact_right a {float: none; width: 100%; margin: 0 auto; min-height: 72px; padding: 23px 10px 20px;}
	
	
	footer {padding-top: 70px;}
	.footer_in {padding-bottom: 0;}

}

@media screen and ( max-width:567px ){	
	.max567 {display: block !important;}
	.min568 {display: none !important;}
	
	.main_img {padding-top: 0;}
	.header_left {max-width: 180px; padding-top: 10px;}
	
	.main_img_text01 {width: 30%; top: 10%; left: 22%;}
	.main_img_text02 {width: 35%; top: 32%; left: 15%;}
	.main_img_text03 {width: 42%; top: 72%; right: auto; left: 5%;}
	.main_img_text04 {width: 18%; left: auto; right: 25%; top: 22%;}
	
	.sp_menu_in li {margin-bottom: 30px;}
	.sp_menu_in li a {font-size: 19px; letter-spacing: 3px;}
	.sp_menu_in li a span {font-size: 10px;}
	.sp_menu_info p {font-size: 13px;}
	
	.top01 {padding: 60px 0 40px;}
	.top01_left {width: 90%;}
	.top01_title {background-position: center top; font-size: 22px;}
	
	.top02 {padding-bottom: 60px;}
	.top02_bnr a dt {display: block; width: 100%; max-width: 100%;}
	.top02_bnr a dd {display: block; width: 100%; padding: 16px;}
	.top02_bnr a dd h3 {font-size: 24px;}
	
	.top03 {background-size: 700px; padding-top: 80px; padding-bottom: 60px;}
	.top03_img {margin-bottom: 30px; width: 100%;}
	.top04_img {margin-bottom: 10px;}
	.top05_img {margin-bottom: 10px;}
	
	.sec_title01 {margin-bottom: 25px;}
	.sec_title01_icon {padding-bottom: 0;}
	.sec_title01_icon img {width: 120px;}
	.sec_title01 h2 {font-size: 28px; letter-spacing: 2px; padding-top: 6px;}
	
	.sec_title02 {background-position: center top; font-size: 25px; padding: 65px 0 0 0; margin-bottom: 20px; text-align: center;}
	.top03_text p {line-height: 1.5;}
	
	.top04 {padding-bottom: 90px; padding-top: 60px;}
	
	.top05 {padding: 50px 0;}
	
	.news_box02 dd span {display: none;}
	
	.b_contact {background-size: 700px;}
	.b_contact_in .sec_title01 {margin-bottom: 30px;}
	.b_contact_text {font-size: 15px; padding-bottom: 20px;}

	footer {background-size: 700px;}
	.f_nav {width: 100%; margin: 0 auto 20px; min-height: inherit; max-width: 150px; float: none;}
	.footer01 {padding: 50px 0;}
	.f_nav li a {font-size: 14px;}
	.f-scroll {right: 1.5rem;}
	.f_info {width: 100%; margin: 0 auto 30px; float: none;}
	.f_btn01 {padding-top: 10px;}
	.footer03_in h3 {width: 48%; margin: 0 1% 10px; max-width: inherit;}
	.footer03_in h3 img {width: 100%;}
	.f_insta a img {width: 26px;}
	.f_nav_left {float: none; width: 100%;}
	.f_nav_right {float: none; width: 100%;}
	.footer_right {max-width: 250px; width: 90%;}
}

@media screen and ( max-width:450px ){
	.max450 {display: block !important;}
	.min451 {display: none !important;}
	
	.main_img {padding-top: 30px;}
	.main_img_text01 {top: 13%;}
	.main_img_text02 {top: 35%;}
	.main_img_text03 {top: 74%;}
	.main_img_text04 {top: 25%;}
	
	.header_left {padding-left: 4.5%;}
	.header_right {max-width: 160px;}
	
	.sec_title01 h2 {font-size: 25px; letter-spacing: 1px; padding-top: 6px;}

	.top02_bnr a dt img {height: 160px;}
	.top02_bnr a dl {padding-bottom: 20px}
	.top02_bnr_btn {width: 35%;}	
	
	.f_copy {font-size: 10px;}
	.footer_left h2 img {width: 200px;}
	.footer_left h3 {font-size: 16px; letter-spacing: 1px;}
	
	.sp_copy {font-size: 10px; letter-spacing: 1px;}
}

@media screen and ( max-width:360px ){
	.header_left {width: 42%;}
	
}

@media screen and ( max-width:325px ){
	
	.sp_menu_in li a {font-size: 20px; letter-spacing: 3px;}
	.sp_menu_wrap {padding: 18vh 10px 15vh;}
	
	.copy {letter-spacing: 1px;}
}



















