/*
Theme Name: 京都天井クレーンワークス			
*/



@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700;800;900&display=swap');

body{

	font-weight:500;
}
.en {
	font-family: source-han-sans-cjk-ja, sans-serif;
}
.sp {
  display: none;
}

:root {	
--main-color: #f6ab00;/*ひまわり色*/
--main-color2: #FF4500;/*オレンジレッド*/
--main-color3:#f6ab00;
--sub-color: #542400;/*茶色*/
--sub-color2:#bc641d;/*ダークオレンジ*/
 }
a.blue{color:var(--main-color)!important;}
/*============ header ============*/

/*固定*/
#header{
	height: 124px;/*高さ指定*/
	width:100%;/*横幅指定*/
	background-color: #fff;
}

/*JSを使いfixedクラスが付与された際の設定*/
#header.fixed{
	position: fixed;/*fixedを設定して固定*/
  z-index: 999;/*最前面へ*/
  top:0;/*位置指定*/
  left:0;/*位置指定*/
}

#head{
	width:100%;
	display:flex;
	justify-content: space-between;
	align-content: flex-end;
}
#head .logo{
	width:28%;
	height:auto;
	padding-top:5px;
}

#head .logo img{
	max-width:100%;
	height:53px;
}
#head-r{
	flex:1;
}
#head-bt{
	display:flex;
	justify-content: flex-end;
	padding-right:10px;
}
#head-bt .h-link{
    display:inline-block;
	width:220px;
	height:50px;
	padding:10px 6px;
	text-align: center;
	color:#fff;
	background-color: var(--main-color2);
	font-size:18px;
	border-radius: 0 0 10px 10px;
	transition: 0.5s;
}
#head-bt .apply{
	background-color: var(--sub-color);
}
#head-bt .tel{
    background-color: #fff;
    color:#333;
    font-size:30px;
    font-weight:700;
    padding: 0 10px;
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	line-height: 100%;
}
#head-bt .tel span{
	display:block;
	font-size:14px;
	padding-left:10px;
	margin-top:-7px;
}
#head-bt .h-link:hover{
	background-color: var(--main-color); 
}
#head-bt .tel img{
    width:250px;
    height:53px;
}
nav ul{
	width:100%;
	display:flex;
	justify-content: space-around;
	margin:0 auto;
    padding:0;
	position: relative;
	background-color: var(--main-color);
	border-bottom:1px solid #fff;
}
nav li{
	font-size:18px;
	color:#fff;
	text-align: center;
    display:inline-block;
    flex-grow: 1;
    margin:0;
	padding:15px 0;
	transition: 0.5s;
}
nav a:link, nav a:visited{
	transition: 0.5s;
	display:block;
	color:#fff;
}
nav li:hover{
	background-color: var(--sub-color);}

nav li + li {
 border-left: 1px solid #fff;
}

/*下の階層を持っているulの指定*/
nav li.has-child ul{
    /*絶対配置で位置を指定*/
	position: absolute;
	left:10px;
	top:55px;
	z-index: 4;
    /*形状を指定*/
	background:var(--main-color);
	width:280px;
    /*はじめは非表示*/
	visibility: hidden;
	opacity: 0;
    /*アニメーション設定*/
	transition: all .3s;
	flex-wrap:wrap;
}

/*hoverしたら表示*/
nav li.has-child:hover > ul,
nav li.has-child ul li:hover > ul,
nav li.has-child:active > ul,
nav li.has-child ul li:active > ul{
  visibility: visible;
  opacity: 1;
}

/*ナビゲーションaタグの形状*/
nav li.has-child ul li{
	color: #333;
	border-bottom:solid 1px rgba(255,255,255,0.6);
	width:280px;
	padding:10px 20px;
	text-align:left;
}

nav li.has-child ul li:last-child > a{
 border-bottom:none;
 }

nav li.has-child ul li:hover,
nav li.has-child ul li:active,
nav li.has-child ul li:visited{
	background:var(--sub-color);
	color:#333;
}



.title{
	margin:0 auto 30px;
}

.title h2{
	font-size:clamp(1.5rem, 0.773rem + 3.64vw, 3.5rem);
	text-align:center;
	font-weight:900;
	color:#333;
	line-height:120%;
	font-style: italic;
}
.title h2 span{
	display:block;
	font-size:18px;
	font-weight:700;
	line-height:120%;
	color:var(--main-color);
}



/*============ slide ============*/

#slide{
	width:100%;
	margin:auto;

}
.slide-inner img{
	width:100%;
	max-width:1200px;
	height:auto;
	margin:0 auto;
}



/*----TOPカタログ--------*/
#catalog{
	text-align:center;
	background:url(../../../../image/top/catalog_bg.webp) no-repeat center  / cover;
	padding:60px 30px;
}

	.top-panf-waku{
		max-width:1200px;
		margin:0 auto;
		padding:20px 0;
		display:flex;
		flex-wrap:wrap;
	}
	.top-panf-waku .box--o{
		width:31%;
		padding:2px;
		margin:7px;
		box-sizing:border-box;
		border: 1px solid #777;
    border-radius: 5px;
	}
	.top-panf-waku .box--o img{
		width:100%;
		height:auto;
	}
ul, li {list-style: none;}


.slick-prev, 
.slick-next {
    position: absolute;/*絶対配置にする*/
    top: 40%;
    cursor: pointer;/*マウスカーソルを指マークに*/
    outline: none;/*クリックをしたら出てくる枠線を消す*/
    height: 40px;
    width: 40px;
	background:url("../../../../image/top/circle-ya.svg") no-repeat center / cover; 
	z-index:1;
}
.slick-prev {/*戻る矢印の位置と形状*/
    left: -3.0%;
	transform: rotate(-180deg);
}

.slick-next {/*次へ矢印の位置と形状*/
    right: -3.0%;

}


/*ドットナビゲーションの設定*/

.slick-dots {
	/*display:none!important;*/
    text-align:center;
	margin:20px 0 0 0;
}

.slick-dots li {
    display:inline-block;
	margin:0 5px;
}

.slick-dots button {
    color: transparent;
    outline: none;
    width:12px;/*ドットボタンのサイズ*/
    height:12px;/*ドットボタンのサイズ*/
    display:block;
    border-radius:50%;
	font-size:0;
	background:#aaa;
}

.slick-dots .slick-active button{
    background:#333;/*ドットボタンの現在地表示の色*/
}
/*============ お悩み ============*/

#nayami{
	background:url(../../../../image/top/nayami-bg.webp) no-repeat center bottom / cover;
	margin: 0;
    padding: 80px 0 200px;
	clip-path: polygon(0 0, 100% 0%, 100% 73%, 50% 100%, 0 73%);
}

#nayami .title h2{color:#fff;}
.title h2 .red{
	display:inline;
	color:#ff0000;
}
.nayami-flex{
	display:flex;
	flex-wrap:wrap;
	max-width:1100px;
	margin-inline:auto;
	margin-top:50px;
}
.nayami-flex p{
	width:25%;
	align-self:center;
}
.nayami-flex p img{
	width:100%;
	height:auto;
}

.nayami-list{
	width:75%;
}

.nayami-list li{
	position:relative;
	padding:10px 0 10px 80px;
	font-size:clamp(1rem, 0.682rem + 1.59vw, 1.5rem);
	font-weight:600;
	border:5px solid var(--sub-color);
	margin-bottom:15px;
	background-color:#fff;
	width:80%;
	text-align:left;
}
.nayami-list li::before{
	position:absolute;
	content:'';
	left:10px;
	top:calc(50% - 27px);
	background:url(../../../../image/top/nayami-check.png) no-repeat center / cover;
	width:54px;
	height:54px;
}
.nayami-list li:nth-child(2){margin-left:30px;}
.nayami-list li:nth-child(3){margin-left:60px;}
.nayami-list li:nth-child(4){margin-left:90px;}

/*============ service ============*/

#service{
	padding:50px 0;
	background:url(../../../../image/top/service-bg.png) repeat-x bottom center ;
}
.service-flex{
	max-width:1200px;
	margin-inline:auto;
	padding:80px 0;
	display:flex;
	flex-wrap:wrap;
	gap:80px 2%;
}
.service-box{
	display:inline-block;
	position:relative;
	width:49%;
	text-align:right;
}
.service-box:hover h3{
	background-color:var(--main-color);
	transition:0.5s;
}
.service-box h3{
	font-size:clamp(1.625rem, 1.307rem + 1.59vw, 2.5rem);
	color:#fff;
	font-weight:600;
	font-style: italic;
	background-color:#000;
	margin:80px 0 0;
	text-align:center;
}
.service-flex .s01{
	background:url(../../../../image/top/se-bg01.png) no-repeat center / cover;
}
.service-flex .s02{
	background:url(../../../../image/top/se-bg02.png) no-repeat center / cover;
}
.service-flex .s03{
	background:url(../../../../image/top/se-bg03.png) no-repeat center / cover;
}
.service-flex .s04{
	background:url(../../../../image/top/se-bg04.png) no-repeat center / cover;
}

.service-box .no{
	position:absolute;
	top:-35px;
	left:0;
}
.service-box .more{
	width:200px;
	display:inline-block;
	background-color:var(--main-color);
	font-size:18px;
	text-align:center;
	color:#fff;
	margin:45px 7px 7px auto;
	padding:5px 0;
}
/*============ 選ばれる理由 ============*/

#reason{
	background:url(../../../../image/top/reason-bg.webp) repeat;
	padding:80px 10px;
}

#reason .title h2{
  text-shadow: 2px 2px 0px rgba(255, 255, 255, 1);
}
.reason-flex{
	max-width:1200px;
	margin-inline:auto;
	padding:50px 0;
}
.reason-flex li{
	max-width:1000px;
	display:flex;
	flex-wrap:wrap;
	background-color:#fff;	
	margin-bottom:30px;
	gap:0 3%;
	padding:10px 0;
}
.reason-flex li:nth-child(2){margin-left:80px;}
.reason-flex li:nth-child(3){margin-left:160px;}
.reason-flex li .img{
	width:30%
}
.reason-flex li .img img{
	width:100%;
	height:auto;
}
.reason-flex li .text{
	width:66%;
	padding-bottom:5px;
}
.reason-flex li .text h3{
	/*background-color:var(--sub-color);*/
	border-bottom:3px solid var(--main-color);
	font-size:30px;
	font-weight:800;
	padding:10px;
	margin-bottom:20px;
	color:#000;
}
.reason-flex li .text h3 span{
	color:red;
	padding-right:20px;
}

/*============ works ============*/
#works{

	padding:80px 0 50px;
}

#works-top{
	max-width:1300px;
	display:flex;
	flex-wrap:wrap;
	margin: 80px auto 80px;
	gap:30px 10px;
}


.works-top-box{
	position: relative;
	width:32.3%;
	background-color: var(--main-color3);
	transition:box-shadow 0.3s, transform 0.3s;
	border-radius: 10px;
}
.works-top-box img{
	width:100%;
	height:auto;
	aspect-ratio: 3 / 2;
	border-radius: 10px 10px 0 0;
	object-fit:cover;
}
.works-top-box:hover{
transform:translate(0, -7px);
}
.works-shurui{
	position: absolute;
	top:0;
	left:10px;
	background-color: var(--sub-color);
	border-radius:0 0 10px 10px;
	width:50%;
	text-align: center;
	padding:7px 10px;
	font-size:16px;
	color:#fff;
}
.works-top-box p{
	text-align: center;
	padding:20px 0;
	font-size: 18px;
}
.works-top-box a{
	color:#fff;
}
.works-bt {
	margin:0 auto;
	width:280px;
}
.works-bt a{
	display: block;
	width:280px;
	padding:20px 10px;
	margin: 50px 0;
	background-color: var(--main-color);
	transition: 0.5s;
	color:#fff;
	text-align: center;
	border-radius: 5px;	
	font-size:20px;
}
.works-bt a:hover{
	background-color: var(--sub-color);
}



/*============ applyset ============*/



#applyset{
	display:flex;
	flex-wrap:wrap;
	margin-top:30px;
	border-top:1px solid #aaa;
}
#applyset .applyset-box{
	width:50%;
	max-height:365px;
	padding:40px 5% 40px;
	gap:20px;
	color:#000;
	display:flex;
	flex-wrap:wrap;
}

#applyset .bg-apply{
	background:var(--main-color2) url(../../../../image/top/set-bg-apply.webp) no-repeat top right;
}
#applyset .bg-tel{
	background:var(--main-color) url(../../../../image/top/set-bg-tel.webp) no-repeat top right;
}
#applyset .bg-panf{
	background:var(--main-color) url(../../../../image/top/set-bg-panf.webp) no-repeat top right;
}
#applyset .applyset-box .text{
	width:100%;
	font-size:18px
}
#applyset .applyset-box h2{
	font-size:clamp(1.875rem, 1.466rem + 2.05vw, 3rem);
	font-weight:900;
	padding-bottom:30px;
}


#applyset .applyset-box .settel{
	display:block;
	width:100%;
	font-weight:900;
	font-size:clamp(1.875rem, 1.648rem + 1.14vw, 2.5rem);
}
#applyset .applyset-box .setbt{
	position: relative;
	display:block;
	align-self: flex-end;
	width:100%;
	max-height: 75px;
	text-align:center;
	padding:20px 0;
	font-size:clamp(1.125rem, 0.989rem + 0.68vw, 1.5rem);
	font-weight:700;
	background-color:#fff;
	color:#333;
	border-radius:15px;
	transition:0.5s;
	box-shadow: 0 6px var(--main-color);
}
#applyset .applyset-box .setbt span{
	color:red;
}
#applyset .setchange .setbt{
	box-shadow: 0 6px var(--sub-color2);
}
#applyset .applyset-box .setbt:hover{
	background-color:#fff;
	top: 2px;
}

#applyset-s{
	display:flex;
	flex-wrap:wrap;
}
#applyset-s .applyset-box{
	width:50%;
	padding:20px 4%;
	display:flex;
	flex-wrap:wrap;
	gap:10px;
	background-color: #009A5B;
    color: #fff;
}
#applyset-s .setchange{
	background-color: #fff;
	color:#333;
	box-shadow: 0 6px #FCC40C;
}
#applyset-s .applyset-box .text{
	width:75%;
	font-size:clamp(0.938rem, 0.869rem + 0.34vw, 1.125rem);
}
#applyset-s .applyset-box .text h2{
	font-size:clamp(1.25rem, 0.841rem + 2.05vw, 2.375rem);
	font-weight:900;
	padding-bottom:20px;
}
#applyset-s .applyset-box figure{
	width: calc(25% - 10px);
}
#applyset-s .applyset-box figure img{
	width:100%;
	height:auto;
}
#applyset-s .applyset-box .settel{
	display:block;
	width:100%;
	font-weight:900;
	font-size:clamp(2.063rem, 1.903rem + 0.8vw, 2.5rem);
}
#applyset-s .applyset-box .setbt{
	display:block;
	width:100%;
	max-height: 75px;
	text-align:center;
	padding:15px 0;
	font-size:clamp(1.125rem, 0.989rem + 0.68vw, 1.5rem);
	background-color:#fff;
	color:#333;
	border-radius:15px;
	transition:0.5s;
}
#applyset-s .applyset-box .setbt2{
	display:block;
	width:100%;
	text-align:center;
	padding:15px 0;
	font-size:clamp(1.125rem, 0.989rem + 0.68vw, 1.5rem);
	background-color:#009A5B;
	color:#fff;
	border-radius:15px;
	transition:0.5s;
}
#applyset-s .applyset-box .setbt:hover{
	background-color:#fff;
	top: 2px;
}
#applyset-s .applyset-box .setbt2:hover{
	background-color:#fff;
	top: 2px;
	color:#333;
}
/*============ contact ============*/
#contact{
	background:url(../../../../image/top/contact-bg.webp) no-repeat left / cover;
	padding:50px 10px;
}
#contact .title {
	width:50%;
	align-self:center;
}
#contact .title h2 {color:#fff;}
.contact-inner{
	max-width:1200px;
	margin-inline:auto;
	display:flex;
	flex-wrap:wrap;
}
.contact-flex{
	width:50%
}
.contact-flex a{
	max-width:500px;
	display:inline-block;
	color:#fff;
	border:solid 1px var(--main-color);
	border-radius:10px;
	display:flex;
	flex-wrap:wrap;
	justify-content:center;
	padding:7px;
	background-color:#555;
	transition:0.5s;
	margin:10px 10px 20px;
	font-size:clamp(1.875rem, 1.739rem + 0.68vw, 2.25rem);
}
.contact-flex a.c-telbox:hover{
	background-color:var(--main-color);
}
#contact .contact-flex a.c-applybox{
	border:solid 1px var(--main-color2);
	font-size:clamp(1.375rem, 1.284rem + 0.45vw, 1.625rem);
	font-weight:700;
	padding:20px 0;
}
.contact-flex a.c-applybox:hover{
	background-color:var(--main-color2);
}
.contact-flex a img{
	width:40px;
	height:auto;
	text-align:right;
	align-self:center;
}
.contact-flex a p{
	width:80%;
	text-align:center;
}
.contact-flex a p span{
	font-size:clamp(0.813rem, 0.767rem + 0.23vw, 0.938rem);
	font-weight:500;
	display:block;
}



/*============ footer ============*/

footer{
	background-color: #e1e1e3;
	color:#555;
	position: relative;
}
#footer-flex{
	display:flex;
	flex-wrap:wrap;
	max-width:1200px;
	padding:50px 0 30px;
	margin:0 auto;
	position: relative;
}

.footer-box{
	width:40%;
	text-align: center;
	font-size:20px;
	padding:0 50px 10px;
	line-height:100%;
}
.footer-box > img{
	width:100%;
	max-width:270px;
	height:auto;
	padding-bottom:10px;
}
.footer-box .f-tel{
	display:block;
	font-size:30px;
	font-weight:900;
	padding:10px 0 0;
}
.footer-box1{
	width:60%;
display:flex;
flex-wrap:wrap;
}
.footer-box2{
	width:50%;
	padding: 0 10px 0;
	text-align: left;
}
.footer-box2 a, .footer-box a{
	color:#333;
}
.footer-box2 a:hover{
	color:var(--main-color);
}
.footer-box2 li{
	position: relative;
	padding-left:20px;
	line-height:200%;
}

/*.footer-box2 li::before{
  content: "";
  margin: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 2px;
  width: 7px;    
  height: 7px;   
  border-top: 2px solid var(--main-color);
  border-right: 2px solid var(--main-color);
  transform: rotate(45deg);  
}*/
.footer-box3{
	width:100%;
	display:flex;
	flex-wrap:wrap;
	text-align: center;
	font-size:20px;
	gap:0 2%;
}
.footer-box3 li{
	width:30%;
	height:50px;
	padding:10px;
	background-color:var(--main-color2);
	border-radius:10px;
	align-self:center;
	transition:0.5s;
}
.footer-box3 a{display:block;color:#fff;}
.footer-box3 li:nth-child(1) a{color:#fff;}
.footer-box3 li:nth-child(1) {background-color:var(--main-color);}
.footer-box3 li:nth-child(3){background-color:var(--sub-color);}
.footer-box3 li:hover{background-color:var(--sub-color2);}


#copy{
	padding:10px;
	font-size:14px;
	text-align: center;
}
.fix-btn {
    position: fixed;
    top: 60%;
    right: 0;
    transform: translateY(-50%);
    z-index: 100;
}
.fix-btn_item a{
	display: block;
	background-color: var(--main-color);
	padding:10px;
	min-height:150px;
	width:50px;
	text-align: center;
	font-size:18px;
	border-bottom:solid #fff 1px;
	border-left:solid #fff 1px;
	transition: 0.5s;
}
.fix-btn_item a:hover, .fix-btn_item:first-child a:hover{
	background-color: var(--sub-color2);
}
.fix-btn_item:first-child a{
	background-color: var(--sub-color);
	border-top:solid 1px #fff;
	color:#fff;
}

.fix-btn_text {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
}

/*============ 下層ページ ============*/


#subtitle{
	width:100%;
	height:220px;
	color:var(--main-color);
	background-color: #fff;
	position:relative;
}
#subtitle::before{
	content:'';
	background:url(../../../image/top/6kaku.png) no-repeat ;
	position:absolute;
	width:80%;
	height:80%;
	background-size: contain;
	z-index:2;
}
/*#subtitle::after{
	content:'';
	position:absolute;
	top:0;
	left:0;
	background-color:#fff;
	border-radius:0 500px 0 0;
    width: 60%;
    height: 100%;
	z-index:1;
}*/
#subtitle-box{
	position:relative;
	padding:4vw 10vw 0 ;
	z-index:2;
}
#subtitle-box h2{
	font-size:clamp(1.5rem, 1.023rem + 2.39vw, 2.813rem);
	font-weight:900;
}
#sublink{
	padding:7px 0;
	text-align: left;
	font-size:14px;
}

#sub-img{
	max-width:1300px;
	height:auto;
	margin:0 auto;
}
#sub-img img{
	width:100%;
	height:auto;
	border-radius:20px;
}

/**************************************************************
company
**************************************************************/
#company{
	max-width:1100px;
	margin:50px auto 80px;
	line-height:180%;
}
.company-shaze img{
	width:100%;
	height:auto;
}

.company-flex{
	display:flex;
	flex-wrap:wrap;
	margin:0 auto 80px;
}
.company-img{
	width:30%;
	margin:2%;
}
.company-img img{
	width:100%;
	height:auto;
}
.company-text{
	width:65%;
	padding:20px;
}
.company-text p{
	padding-bottom:20px;
}
.company-text .name{
	text-align: right;
	font-size:22px;
	font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}
.company-text .name span{font-size:16px;}
#company dl{
	max-width:1000px;
	display:flex;
	flex-wrap:wrap;
	margin: 30px auto 80px;
}
#company dt{
	width:30%;
	font-weight:600;
	padding:15px 10px 15px 20px;
	border-top:2px solid var(--main-color);
	color:var(--main-color);
}
#company dd{
	width:70%;
	padding:15px 10px 15px 20px;
	border-top:2px solid #ccc;
}
#company iframe{
	width:100%;
	height:400px;
}
.company-flex2{
	display:flex;
	flex-wrap:wrap;
}
.company-flex2 a{
	height:60px;
	width:auto;
}
.company-flex2 img{
	width:auto;
	height:60px;
}
/*============ プライバシーポリシー ============*/

#privacy{
	padding:10px;
	max-width:1100px;
	margin-inline:auto;

}
#privacy h3{
	margin:30px 0;
	padding:10px;
	border-bottom:3px solid #555;
	font-weight:600;
	background-color:#f2f2f2;
}
#privacy p{
	padding:20px 0;
}
#privacy ol {
	padding:10px 10px 10px 40px;

}
#privacy ol li{
	padding:10px;
	list-style: auto;
}

/**************************************************************
service
**************************************************************/
#service-s{
	padding:40px 0 80px;
	text-align:center;
}
.service-s{
	max-width:1100px;
	margin-inline:auto;
}
h3.se-midashi{
	border:5px solid var(--main-color);
	padding:20px 10px;
	font-size:clamp(1.125rem, 0.852rem + 1.36vw, 1.875rem);
	font-weight:700;
	color:#333;
	margin:50px 0 30px;
	background-color: #f2f2f2;
}
.common-flex{
	display:flex;
	flex-wrap:wrap;
	gap:20px 2%;
}
.se-flex{
	margin:30px 0 80px;
}
.se-flex-box{
	width:49%;
	background-color: #fff6da;
	padding:30px;
	text-align: left;
}
.se-flex-box h4{
	font-size:clamp(1.125rem, 0.852rem + 1.36vw, 1.875rem);
	font-weight:900;
	color:var(--main-color);
	padding:0 0 10px;
	margin-bottom:10px;
	border-bottom:3px solid var(--main-color);
}

.se-midashi2{
	font-size:clamp(1.125rem, 0.852rem + 1.36vw, 1.5rem);
	font-weight:700;
	margin:20px 0 80px;
	line-height:200%;
	text-align:center;
}
.img100{
	width:100%;
	max-width:921px;
	height:auto;
}
.se-midashi2 span{
	color:#ff4200;
}
.se-list{
	text-align: left;
	font-size:clamp(1rem, 0.864rem + 0.68vw, 1.375rem);
	font-weight:600;
	counter-reset: listnum; 
}
.se-list li{
	padding:10px ;
}
.se-list li::before{
	counter-increment: listnum;
	content: counter(listnum); 
	margin-right: 15px;
	vertical-align: middle;
	background: var(--main-color);
	border-radius: 50%;
	font-size:clamp(1.125rem, 0.852rem + 1.36vw, 1.875rem);
	color:#fff;
	padding:5px 18px;
}
.se-waku{
	background-color: #fff6da;
	padding:30px 80px;
	margin:30px 0;
	text-align: left;	
}
.se-waku h4{
	background: url("../../../../image/service/merit_bg.png") no-repeat center / cover ;
	padding:20px;
	font-size:clamp(1.125rem, 0.852rem + 1.36vw, 1.875rem);
	font-weight:800;
	margin-bottom:30px;
	text-align: center;
}
.se-waku2{
	background-color: #fff6da;
	margin:30px 0;
	text-align: left;
}
.se-flex-box2{
	width:49%;
	padding:30px;
	line-height:180%;
}
.se-flex-box2 h4{
	font-size:clamp(1.125rem, 0.852rem + 1.36vw, 1.875rem);
	font-weight:900;
	color:var(--main-color);
	padding:0 0 10px;
	margin-bottom:10px;
	border-bottom:3px solid var(--main-color);
}
.se-flex-box2 img{
	width:100%;
	height:auto;
}
/*********メンテナンス＆修理************/
.se-line2{
	background: url("../../../../image/service/merit_bg.png") no-repeat center / cover ;
	padding:20px 10px;
	font-weight:800;
	text-align: center;
}
#service-s #nayami{
	background:url(../../../../image/top/nayami-bg-s.webp) no-repeat center bottom / cover;
}

#service-s #nayami .title h2{color:#333;}


.kaiketsu{
	margin:50px 0;
}

.kaiketsu-box{
	width:49%;
	background-color: #fff6da;
	border-radius: 10px;
	display:flex;
	flex-wrap:wrap;
	gap:0 2%;
	padding:20px;
	margin-bottom:20px;
}
.kaiketsu-box figure{
	width:20%;
	align-self: center;
}
.kaiketsu-box figure img{
	width:100%;
	height:auto;
}
.kaiketsu-box .text{
	width:78%;
	text-align: left;
}
.kaiketsu-box .text h4{
	font-size:18px;
	font-weight:600;
	margin-bottom:20px;
	color:var(--main-color);
}
/*********乗せ換え・移設************/
#flow-zu{
	width:100%;
	max-width:1000px;
	margin:50px auto;
	display: flex;
	flex-direction: column;
	align-content: center;
}

#flow-zu .zu{
	margin:10px 30px;
	background-color: #f2f2f2;
	border-radius: 10px;
	display: flex;
	position: relative;
}
#flow-zu .zu-l{
	width:40%;
	height: auto;
	background-color: var(--main-color);
	color:#fff;
	font-size:clamp(1rem, 0.864rem + 0.68vw, 1.375rem);
	padding:5px 0 0 5px;
	align-content: center;
	border-radius: 10px 0 0 10px;
	text-align: center;
}
#flow-zu .zu-l span{
	padding-right:10px;
}

#flow-zu .zu-r{
	width:60%;
	align-content: center;
	border-radius: 0 10px 10px 0;
	background-color: var(--main-color);
}
#flow-zu .zu-r img{
	width:100%;
	height:auto;
	border-radius: 0 10px 10px 0;
}
#flow-zu .zu::before{
    content: '';
    position: absolute;
    top: 100%;
    left: 20%;
    transform: translateX(-50%);
    border-top: 20px solid var(--main-color);
    border-right: 20px solid transparent;
    border-left: 20px solid transparent;
}
#flow-zu .last::before {
	border:none;
}
.koushin{
	gap:20px 4%;
}
.koushin-box{
	width:48%;
}
.koushin-box img{
	width:100%;
	height:auto;
}
.koushin-box h4{
	background: var(--sub-color);
	font-weight:700;
	padding:10px;
	font-size:20px;
	color:#fff;
}


/**************************************************************
強み
**************************************************************/
#flow{
	max-width:1100px;
	margin: 0 auto 80px;	
}

.flow-flex{
	max-width:1100px;
	display:flex;
	flex-wrap:wrap;
	gap:3%;
	margin:50px 0;
	padding:20px;
	border: solid 1px #8d8d8d;
    box-shadow: 10px 10px 0px 0px rgb(85 83 83 / 9%);
}
.flow-flex .text{
	width:62%;
	font-size:17px;
	line-height:180%;
}
.flow-flex .text h4{
	padding-top:30px;
}
.flow-flex .img{
	width:35%;
}
.flow-flex .img img{
	width:100%;
	height:auto;
}
.flow-flex .text h4{
	font-size:clamp(1.188rem, 1.074rem + 0.57vw, 1.5rem);
	font-weight:700;
	margin-bottom:40px;
}
.flow-flex .text h4 .no{
	color:#fff;
	background-color:var(--main-color); 
	padding:10px 12px;
	border-radius: 50%;
	margin-right:10px;
}

/**************************************************************
ABOUT
**************************************************************/

#about{
	max-width:1100px;
	margin: 0 auto 80px;	
}

#about h3.about-midashi{
	border:5px solid var(--main-color);
	padding:20px 10px;
	font-size:clamp(1.125rem, 0.852rem + 1.36vw, 1.875rem);
	font-weight:700;
	color:#333;
	margin:50px 0 30px;
	background-color: #f2f2f2;
	text-align: center;
}
.area{
	gap:20px 4%;
}
.area-box{
	width:48%;
	padding:20px 2%;
	line-height:180%;
	align-self: center;
}
.area-box img{
	width:100%;
	height:auto;
}
.about-midashi2{
	font-size:clamp(1.125rem, 0.852rem + 1.36vw, 1.875rem);
	font-weight:700;
	margin:20px 0 80px;
	line-height:200%;
	text-align: center;
}
.red{color:#ff4200;}
.about-ya{text-align: center;margin-top:20px;}
.arrow {
  display: inline-block;
  width: 73.5px;
  height: 70px;
  background: #ff4200;
  clip-path: polygon(0 47.5%, 31% 47.5%, 31% 0, 69% 0, 69% 47.5%, 100% 47.5%, 50% 100%);
}
.me-logo{
	justify-content: center;
}
.me-logo img{
	width:200px;
	height:auto;
	border:1px solid #aaa;
}

.jissi{
	margin-bottom:50px;
	
}
.jissi-box{
	width:32%;
	border:1px #aaa solid;
	padding:10px;
}

.jissi-box h4{
	font-size:19px;
	font-weight:600;
	padding:10px;
}
.jissi-box h4 span{
	font-size:24px;
	padding-right:10px;
	color:var(--main-color);
}
.jissi-box img{
	width:100%;
	height:auto;
	margin-bottom:10px;
}
.jissi-box .bt-set a{
	display:block;
	width:49%;
	border-radius: 10px;
	padding:10px;
	font-size:15px;
	font-weight:600;
	background-color: var(--sub-color);
	text-align: center;
	margin-top:20px;
	color:#fff;
}
.jissi-box .bt-set a.apply-bt{
	background-color: var(--main-color);
}
.jissi-box .text{
	padding:10px;
}

/*********************************
 お問い合わせ
*********************************/

.apply-mes{
	max-width:700px;
	margin:0 auto 50px;
	padding:20px;
	border:3px solid #000;
	border-radius:10px;
}
.apply-title{
	margin:0 auto;
}

.apply-title .tel-set{
	display:block;
	font-size:clamp(1rem, 0.864rem + 0.68vw, 1.375rem);
	font-weight:700;
	line-height:120%;
	color:var(--main-color);
	text-align:center;
}
.tel-set-flex{
	display:flex;
	flex-wrap:wrap;
	font-size:clamp(1.5rem, 0.773rem + 3.64vw, 3.0rem);
	text-align:center;
	font-weight:900;
	line-height:120%;
	font-style: italic;
	justify-content:center;
}
.tel-set-flex img{width:50px;height:50px;align-self:center;}

.panf-apply{
	max-width:700px;
	margin:0 auto 50px;
}
.panf-apply img{
	width:100%;
	height:auto;
}

#apply{
    max-width:1100px;
    margin:0 auto;
}

#apply .come{
    max-width:800px;
    margin: 20px auto 50px;
    text-align: center;
    padding:10px;
    font-size:20px;
}   
#apply-box{
    max-width:1100px;
    margin: 0 auto 50px;
    display:flex;
    flex-wrap:wrap;
	font-size:18px;
}    
#apply-box .apply-box-l{
    width:35%;
    color:#171c60;
    border-bottom:1px solid var(--main-color);
    padding:20px 10px;
}
#apply-box .apply-box-l span{
    background-color:red;
    color:#fff;
    padding:5px 10px;
    margin-right:10px;
    border-radius: 5px;
    font-size:14px;
}
#apply-box .apply-box-l .nini{
	background-color:#999;
}
#apply-box .apply-box-r{
    width:65%;
    border-bottom:1px solid #ccc;
	padding:20px 10px;
	font-family:  'Noto Sans JP',
	"Helvetica Neue",
    Arial,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    "BIZ UDPGothic",
    Meiryo,
    sans-serif;
}
 /* テキストフォームの設定 */
.wpcf7-datetime{
  padding: 7px;
  width: 260px;
  color: #636063;
  font-size: 13px;
  background-color:#F9F9F9;
  border:solid 1px #CCCCCC;
  }

 /* テキストフォームの設定 */
.wpcf7-text{
  padding: 7px;
  width: 100%;
  color: #636063;
  background-color:#F9F9F9;
  border:solid 1px #CCCCCC;
  }

.kazukazu input{width:30px!important;
margin-left:3px;
margin-right:3px;}
 
  /* テキストフォームのフォーカス時の設定 */
.wpcf7-text:focus{
  background-color:#FFFFCC;
  }
 
  /* テキストエリアの設定 */
.wpcf7-textarea{
  padding: 7px;
  width: 100%;
  height: 100px;
  color: #636063;
  background-color:#F9F9F9;
  border:solid 1px #CCCCCC;
  }
 
 /* テキストエリアのフォーカス時の設定 */
.wpcf7-textarea:focus{
background-color:#FFFFCC;
}
 
  /* 送信ボタンの設定 */
.wpcf7-form-control.wpcf7-submit{
display: block;
width: 260px;
border: none;
padding:20px;
background-color:#ff4200;
color:#fff;
	border-radius:5px;
	font-size:24px;
  }
 
/* 送信ボタンのフォーカス時の設定 */
.wpcf7-form-control.wpcf7-submit:hover{
filter: alpha(opacity=80);
 opacity: .6;
 -moz-transition: all 0.7s ease;
 -webkit-transition: all 0.7s ease;
 }
 
/* リストの縦並び（チェックボックス・ラジオ） */
span.wpcf7-list-item {
display: block!important;
	margin-bottom:10px!important;
}
 
/* セレクト */
select{
padding: 5px;
width:420px;
color: #636063;
font-size: 13px;
background-color:#F9F9F9;
border:solid 1px #CCCCCC;
}
input[type=checkbox] {
	transform: scale(2);
	margin: 0 6px 0 0;
}
.apply-check{
	text-align:center;
	display:block;
	width:100%;
	margin-top:20px;
}
.center{
	text-align:center;
	display:block;
	margin:10px auto;
}
.form-small {
    width: 100px;
}

#thx{
	max-width:800px;
	margin:10px auto 80px;
	padding:10px;
	font-size:20px;
	line-height:180%;}





/**************************************************************
施工事例
**************************************************************/
#works-s{
	max-width:1150px;
	padding:50px 0 80px;
	margin:0 auto;
}


#works-s-flex {
    max-width: 1150px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
	gap:3%;
}
.works-s-img {
	width:60%;
}
.works-s-img img{
	width:100%;
	height:auto;
	padding-bottom:10px;
}
.works-s-text {
	width:37%;
	line-height: 180%;
    font-size: 18px;
}

.works-s-text h2{
	font-size:clamp(1.25rem, 1.159rem + 0.45vw, 1.5rem);
	font-weight:600;
	padding-bottom:10px;
	margin-bottom:30px;
	border-bottom:solid 3px var(--main-color);
}









/**************************************************************
ブログ
**************************************************************/

#blog{
	margin-bottom:100px;
}
.blog-btn {
    display:flex;
	flex-wrap:wrap;
	max-width:800px;
	margin:50px auto;
}
.blog-btn_item{
	width:50%;
}
.blog-btn_item a{
	display: block;
	background-color: var(--main-color);
	color:#fff;
	padding:20px 10px;
	text-align: center;
	font-size:18px;
	border:solid #fff 1px;
	transition: 0.5s;
}
.blog-btn_item a:hover{
	background-color: var(--sub-color);
	
}


.blog-waku{
	max-width:1100px;
	margin:0 auto;
	padding: 0;
	display:flex;
	flex-wrap:wrap;
	border-bottom:dotted 2px var(--main-color);
}
.blog-text{
	font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
	padding:10px;
}

.blog-img{
	width:calc( 30% - 20px );
	margin:10px;
	text-align: center;
}
.blog-img img{
	width:100%;
	max-width:310px;
	height:auto;
	max-height:200px;
	border-radius:10px;
}
.blog-info{
	width:70%;
	padding:10px 20px 10px;
}
.blog-info .midashi{
	text-align: left;
	width:100%;
	margin: 0 auto 20px;
	padding:10px;
	font-size:20px;
	font-weight:600;
	border-bottom:solid 2px var(--main-color);
}

/******ブログシングル******************/

#blog-s{
	max-width:1000px;
	margin:0 auto 80px;
	font-size:18px;
}
#blog-midashi{
	font-size:clamp(16px, 4vw, 24px);
	padding:10px;
	text-align: center;
	border-bottom:solid 3px var(--main-color);
}

.blog-cont{
	max-width:1000px;
	margin:0 auto 80px;
	font-size:18px;
	text-align:left;
	line-height:190%;
	padding:10px 0;
}

.blog-cont li + li {
  border-left: none!important;
}

.blog-cont li{
	margin-left:35px;
	font-size:14px;
	line-height:170%;
	margin-bottom:13px;
}

.blog-cont ol{
	margin-top:25px;
	margin-bottom:25px;
}


.blog-cont p{
	margin-left:0px;
}

.blog-cont .alignright{
	padding-left:15px!important;
	background-color:#fff!important;
	float:right;
}

.blog-cont .alignleft{
	padding-right:15px!important;
	background-color:#fff!important;
	float:left;
}

.blog-cont .aligncenter{
    display: block;
    margin: 0 auto 20px;
    text-align: center;
}

.blog-cont h1{
	font-size:30px;
	color:#000000;
	padding:10px 5px;
	margin-bottom:15px;
	margin-top:30px;
	font-weight: 700;
}

.blog-cont h2{
	font-size:20px;
	color:var(--main-color);
	padding:10px 5px;
	border-bottom:solid 2px var(--main-color);
	margin-bottom:15px;
	margin-top:30px;
	font-weight: 600;
}

.blog-cont h3{
	font-size:16px;
	background-color:#fff3b1;
	padding:7px;
	margin-top:30px;
	margin-bottom:15px;
	font-weight: 600;

}
.blog-cont h4{
	font-size:15px;
	color:#000;
	padding:7px 3px;
	border-bottom:solid 1px #000;
	margin-bottom:15px;
	margin-top:30px;
	font-weight: 600;
}

.blog-cont h5{
	font-size:12px;
	color:#000;
	padding:5px;
	background-color:#ececec;
	margin-bottom:15px;
	margin-top:30px;
	font-weight: 600;
}

.blog-cont p{margin-bottom:15px;}

.blog-cont img{padding-bottom:15px;
padding-top:10px;
max-width:100%;
height:auto;}

.blog-cont iframe{max-width:100%;}

.blog-cont hr{
	margin-bottom:15px;
		margin-top:15px;
	background-color: #fff;
	border-top: 2px dashed #f6be46;
}
.midashi-a{
	font-size:20px;
	padding:10px;
}

