/*
Theme Name: 平賀浄化槽センター_ver_01_2025
Theme URL:
Author:
Author URI:
Description: 平賀浄化槽センター_のテンプレートver01
Version: 9999
Tags:
License:
License URI:
*/
/* ==========================================================================
   Foundation
   ========================================================================== */
/* Reset
   ----------------------------------------------------------------- */

html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,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,main,menu,nav.gnav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;font-weight:400;}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav.gnav,section{display:block}ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}input,select{vertical-align:middle}
figure{margin-bottom:0;}
/* Base
   ----------------------------------------------------------------- */
.serif{
	font-family:"Noto Serif JP", serif;
	font-weight: 500;
  font-style: normal;
}
body{
	font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
	color:#234461;
	/*max-width:2400px;*/
	margin:0 auto;
	letter-spacing: 1px;
	font-feature-settings: "palt";
	background-color:#fff;
}
@media screen and (max-width: 480px){
	body{letter-spacing:0;}
}
a{
	color:#234461;
	text-decoration:none;
}
a:hover{opacity:0.8;}
img{
	vertical-align:top;
	max-width:100%;
	height:auto;
}
figcaption{
	text-align:center;
	font-size:clamp(13px, 1.5vw, 16px);
	line-height:1.5em;
	margin:5px 0;
}
ol{list-style:none}
strong{font-weight:bold;}
/* ==========================================================================
   共通
========================================================================== */
html{
	font-size:clamp(13px, 1.5vw, 16px);
	scroll-padding-top: 50px;/*追従headerの高さ指定*/
}
main{/*overflow:hidden;*/}

/*文字寄せ*/
.txt-right{text-align:right;}
.txt-center{text-align:center;}
/*一文字空白*/
.indent{text-indent: 1em;}
/*URL改行防止*/
main p{word-break: break-all;}


/*共通ボタン(もっと見る)*/

.btn {text-align:center;}
.btn a{
	font-size:16px;
  box-sizing:border-box;
  line-height:43px;
  padding:0 8px 0 38px;
  width:210px;
  display:inline-block;
  margin:0 auto;
  background-color:#005AA9;
  color:#fff;
  font-weight:bold;
  border-radius:22px;
  text-decoration:none;
  position:relative;
  overflow:hidden; /* はみ出し防止 */
}
.btn a:before{
	content:"";
  width:25px;
  height:25px;
  background:#fff;
  border-radius:50%;
  position:absolute;
  left:8px;
  top:9px;
  z-index:1;

}
.btn a:after{
	content:"";
	width:5px;
	height:7px;
	background:#005AA9;
	z-index:2;
	position:absolute;
	left:18px;
	top:18px;
	clip-path: polygon(0 0, 0% 100%, 100% 50%);
	
}
.btn a:hover{	padding:0 38px 0 8px;background:#0088FF;opacity:1;}
.btn a:hover:after{background:#0088FF;}

/*アニメーション用*/
.btn a::before,
.btn a::after{
  transition: transform .3s ease, background-color .3s ease;
}
/* hover */
.btn a:hover::before{
  transform: translateX(168px);
}

.btn a:hover::after{
  transform: translateX(168px);
}
/*外部リンクボタン*/
.btn-blank {text-align:center;}
.btn-blank a{
	font-size:clamp(13px, 2vw, 14px);
	box-sizing:border-box;
	border-radius:25px;
	line-height:35px;
	padding:0.25rem 1.5rem 0.25rem 1.5rem;
	position: relative;
	background:rgb(252,130,136);
	color:#fff;
	text-align:center;
	min-width:160px;
	display:inline-block;
	flex-wrap:wrap;
	align-items:center;
	justify-content:center;
	margin:0 auto;
}
.btn-blank a:after{
	content:" ";
	display:inline-block;
	width:14px;
	height:14px;
	margin-left:.5rem;
	background-image:url(img/icon-blank.svg);
	bakcground-position:center;
	background-repeat:no-repeat;
	background-size:100%;
}


/*共通テーブル*/
table.tbl100{width: 100%;}

.tbl01{
	margin-bottom: 2rem;
	box-sizing: border-box;
	border-top:solid 1px #ccc;
	border-left:solid 1px #ccc;
}
.tbl01 thead th{
	background:#e1dded;
	font-weight:bold;
	text-align:center;
}
.tbl01 tbody th{
	text-align:center;
}
.tbl01 tbody td{background:#fff;}
.tbl01 tbody td:nth-child(1){
	text-align:center;
}
.tbl01 tbody td.point{
	background:#f4f3f2;
}
.tbl01 tbody td.pr{text-align:center;}
.tbl01 td,
.tbl01 th{
	padding: 1rem ;
	line-height: 1.5rem;
	font-size:clamp(11px, 1.25vw, 15px);
	border-bottom:solid 1px #ccc;
	border-right:solid 1px #ccc;
	vertical-align: middle;
}


@media screen and (max-width: 768px){
.scroll{
	overflow: auto;
	white-space: nowrap;
	margin-bottom: 1em;
}
.scroll table{
	width: 100%;
	margin-bottom: 0.5em;
}
}
@media screen and (max-width: 480px){
.tbl01 td,
.tbl01 th{padding: 1rem 1rem;}
}



/*線なしのミニテーブル*/
.tbl-min{
	margin-bottom: 2rem;
	box-sizing: border-box;
}
.tbl-min td,
.tbl-min th{
	padding: 0.5rem ;
	line-height: 1.5rem;
	font-size:clamp(13px, 1.5vw, 16px);
}
.tbl-min th{
	vertical-align: top;
	text-align: left;
}


/*mapレスポンシブ*/
.gmap {
height: 0;
overflow: hidden;
padding-bottom: 36.25%;
position: relative;
}
.gmap iframe {
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 100%;
}
@media screen and (max-width: 640px){
	.gmap {padding-bottom: 56.25%;}
}

/*tel スマホサイズのみクリック可*/
@media (min-width: 769px) {
a[href*="tel:"] {
pointer-events: none;
cursor: default;
text-decoration: none;
}
}


.sec{padding:6rem 2rem;}
@media screen and (max-width: 768px){.sec{padding:4rem 2rem;}}
@media screen and (max-width: 480px){.sec{padding:3rem 2rem;}}

.inner1650{
	max-width:1650px;
	margin:0 auto;
	box-sizing:border-box;
}
.inner1550{
	max-width:1550px;
	margin:0 auto;
	box-sizing:border-box;
}


.inner{ 
	max-width:1420px;
	margin:0 auto;
	box-sizing:border-box;
}
.inner1050{
	max-width:1050px;
}
.inner840{
	max-width:840px;
	margin:0 auto;
	box-sizing:border-box;
}


/*sp用*/
@media screen and (min-width: 481px){.sp480{display:none;}}
@media screen and (min-width: 381px){.sp380{display:none;}}
/*見出し*/

/*共通の見出しサイズ*/
h1,
h2,
h3,
h4,
h5,
p{line-height:1.75em;}

h1:not(.not){font-size:clamp(28px, 3vw, 50px);}
h2:not(.not){font-size:clamp(25px, 3vw, 50px);}
h3:not(.not){font-size:clamp(22px, 2.5vw, 40px);}
h4:not(.not){font-size:clamp(20px, 2vw, 18px);}
h5:not(.not){font-size:clamp(18px, 1.75vw, 16px);}
h6:not(.not){font-size:clamp(16px, 1.5vw, 16px);}
p,a{font-size:clamp(15px, 1.25vw, 20px);}

h1:not(.not) span,
h2:not(.not) span,
h3:not(.not) span,
h4:not(.not) span,
h5:not(.not) span,
h6:not(.not) span{display:inline-block;}
p span{display:inline-block;}

/*共通の見出し装飾と余白*/
.bold{font-weight: 700;}
h1:not(.not){margin-bottom:2rem;font-weight: 700;}
h2:not(.not){margin-bottom:1rem;font-weight: 700;}
h3:not(.not){margin-bottom:1rem;font-weight: 700;}
h4:not(.not){margin-bottom:1rem;}
h5:not(.not){margin-bottom:1rem;}
h6:not(.not){margin-bottom:1rem;}
p:not(.not){margin-bottom:1rem;}


h2.sq-tit{
	font-size:clamp(15px, 1.5vw, 22px);
	padding:1rem 1rem 1rem 1rem;
	font-weight:bold;
	position:relative;
	background: linear-gradient(180deg, #fff 0%, #fff 50%, #e0ddec 50%, #e0ddec 100%);
	display: flex;
	align-items: center;
}
h2.sq-tit:before{
	content:"";
	width:1.5rem;
	margin-right:1rem;
	aspect-ratio: 1 / 1;
	background:#6c689a;
}
/*共通リスト*/

/*丸ドットのリスト*/
ul.list01{
	margin-left: 0.5rem;
	margin-bottom:1.5rem;
}
ul.list01 > li{
	font-size:clamp(13px, 2vw, 16px);
	line-height: 1.5em;
	padding:0 0 0 26px;
	position:relative;
	margin-bottom:1rem;
}
ul.list01 > li:before{
	content: "";
	position: absolute;
	left: 10px;
	top: calc(1em - 5px);
	width: 5px;
	height: 5px;
	background: #1F2E55;
	display: block;
	border-radius: 5px;
}
/*数字リスト*/
ol.list-num01 {
	margin-left: 0.5rem;
	margin-bottom:1.5rem;
	counter-reset: listnum;
}
ol.list-num01 > li{
	font-size:clamp(14px, 2vw, 16px);
	line-height: 1.5em;
	margin: 0 0 1rem 0;
	padding:0 0 0 26px;
	position:relative;
}
ol.list-num01 > li:before{
	position: absolute;
	left: 0px;
	counter-increment: listnum;
	content: counter(listnum) ".";
	width: 23px;
	text-align: right;
}

/*（）付き数字リスト*/
ol.in-list-num {
	margin-left: 0.5rem;
	margin-bottom:2rem;
	counter-reset: listnum;
}
ol.in-list-num > li{
	font-size:clamp(14px, 2vw, 16px);
	line-height: 2em;
	margin: 0 0 1rem 0;
	padding:0 0 0 26px;
	position:relative;
}
ol.in-list-num > li:before{
	position: absolute;
	left: 0px;
	counter-increment: listnum;
	content: "(" counter(listnum) ")";
	width: 23px;
	text-align: right;
}

/*パンくず*/
#bread{
	padding:.75rem 1rem;
	background:#f4f3f2;
}
#bread ul{
	display:flex;
	flex-wrap:wrap;
	max-width:1140px;
	margin:0 auto;
}
#bread ul li{
	padding:0 .5rem 0 0;
	font-size:.8rem;
	line-height: 1rem;
	font-weight:bold;
}
#bread ul li a{
	font-size:.8rem;
	font-weight:normal;
}
#bread ul li a:after{content:"／";margin-left:.5rem;}

@media screen and (max-width: 769px){
	#bread ul li{padding:0 0.2rem 0 0 ; font-size:0.7rem;}
	#bread ul li a{font-size:0.7rem;}
}



/* ==========================================================================
   Layout
========================================================================== */


/* Header と side
----------------------------------------------------------------- */
header{
	width:100%;
	box-sizing:border-box;
	position:relative;
	min-height:100px;
	padding:20px 20px 30px;
	background:
	linear-gradient(
      to bottom,
      #005AA9 0%,
      #005AA9 70%,
      transparent 70%,
      transparent 100%
    ),
		url(img/wave-bg.svg?3);
	background-repeat: no-repeat, no-repeat;
	background-size:100% 100%,100% auto;
	background-position:top,left bottom;
	
}
.header-in{
	display:flex;
	flex-wrap:wrap;
	align-items: center;
}
.header-in .h-logo{
	position:relative;
	z-index:999;
	margin-right:1rem;
}
.header-in .item{
	flex:1;
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	justify-content: flex-end;
}


/*

.header-in .item .bnr-r18,
.header-in .item .bnr-tel{
	padding:0 1rem;
}
.header-in .item .bnr-line{
	padding-left:1rem;
}

.header-in .item .bnr-tel{
	
	border-right:solid 1px #2f2b26;
}

*/


/*追従*/
header.m_fixed{
	width:100%;
	box-sizing: border-box;
	position:fixed;
	z-index:999;
	left:0;
	top:0;
}
header.m_fixed .h-logo img{

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

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


}


/*h-nav*/

header nav{

}

/*ハンバーガーメニューの高さがはみ出した時のスクロールバー*/
.globalMenuSp-in::-webkit-scrollbar{width: 8px;}
.globalMenuSp-in::-webkit-scrollbar-track{background-color: #ddd;}
.globalMenuSp-in::-webkit-scrollbar-thumb{background-color: #0088FF;}


nav.globalMenuSp {
	/*position: fixed;
	height: 100%;
	z-index: 99999;
	top: 0;
	right: 0;
	background:#005AA9;
	transform: translateX(100%);
	transition: all 0.6s;
	width: 100%;
	margin:0;
	padding-bottom:45px;
	box-sizing:border-box;*/
	position: fixed;
  inset: 0;
  z-index: 1000;
  pointer-events: none;
}
.globalMenuSp-in{
	width: 100%;
  height: 100%;
  background: #005AA9;
	clip-path: circle(0% at 100% 0%);
  transition: clip-path 0.6s ease-in-out;
	overflow-y: auto;
  -webkit-overflow-scrolling: touch;
	    padding: 50px 1rem 1rem;
    box-sizing: border-box;
}
/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
	transform: translateX(0%);
	display:block;
}
.globalMenuSp.is-open {
  pointer-events: auto;
}
.globalMenuSp.is-open .globalMenuSp-in {
  /* 右上から左下へ広がる */
  clip-path: circle(150% at 100% 0%);
}

/*メニューはスクロールするけど、裏のページは動かない*/
body.is-menu-open {
  overflow: hidden;
}

.navToggle {
	display: block;
	position: absolute;
	right: 50px;
	top: 35px;
	width: 30px;
	height: 30px;
	cursor: pointer;
	z-index: 999999;
	text-align: center;
}
.navToggle span {
	display: block;
	position: absolute;    /* .navToggleに対して */
	width: 30px;
	height:3px;
	background:#fff;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
	left: 0;
}
.navToggle span:nth-child(1) {top: 0;}
.navToggle span:nth-child(2) {top: 12px; }
.navToggle span:nth-child(3) {top: 24px;}
.navToggle span:nth-child(4) {
	/*top:54px;
	color:#2f2b26;
	font-size:12px;
	font-weight:bold;
	background:none;*/
	display:none;
}
.navToggle.active{
	position:fixed;
	right: 50px;
	top: 35px;

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


@media screen and (min-width: 769px){
.navToggle{display:none;}
}



/*ハンバーガー内のナビ*/

@media screen and (min-width: 541px){.globalMenuSp-in .sp{display:none;}}
@media screen and (max-width: 540px){.globalMenuSp-in .pc{display:none;}}

.globalMenuSp-in .w1100{
	display: flex;
	flex-wrap:wrap;
	justify-content: center;
	max-width:1100px;
	margin:2rem auto;

}
.globalMenuSp-in .w1100 .pc{width:25%;}
.h_nav_wrap{
	flex:1;
	padding: 0 2rem;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}


.h_nav{}
.h_nav li{margin-bottom:3em;text-align:center;}
.h_nav li a,
.h_nav li a strong,
.h_nav li a span{display:inline-block;}
.h_nav li a strong{
	font-size:40px;
	color:#fff;
	margin-bottom:8px;
	font-weight:500;
}
.h_nav li a span{
	font-size:14px;
	color:#94D1EE;
}

.h_nav_min li{text-align:center;}
.h_nav_min li a{
	display:inline-block;
	color:#fff;
	font-size:13px;
	text-decoration: underline;
}

.h_sns{margin-bottom:2rem;}
.h_sns li{text-align:center;padding:.5rem;}
.h_sns li a{display:inline-block;}



@media screen and (min-width: 541px){
.globalMenuSp-in .w1100{min-height: calc(100vh - 200px);}
}
@media screen and (max-width: 540px){
.globalMenuSp-in .w1100{display: block;}
.h_nav_wrap{margin-bottom:2rem;}
.globalMenuSp-in .sp{text-align:center;}

}

/*----ハンバーガー end----*/

/*pcのheaderナビ*/
.h_nav_pc {
	display:flex;
	flex-wrap:wrap;
}
.h_nav_pc li{
	margin-right:1.5rem;
}
.h_nav_pc li a{
	font-size:clamp(13px, 1.25vw, 16px);
	display:inline-block;
	color:#fff;
	font-weight:bold;

}
.header-in .to-contact{
	margin:0 0px 0 20px;
}
.header-in .to-contact a{
	background:#fff;
	color:#005AA9;
	display:block;
	line-height:54px;
	width:178px;
	box-sizing:border-box;
	border-radius:30px;
	text-align:center;
	font-size:clamp(13px, 1.5vw, 16px);
	font-weight:500;
}



@media screen and (max-width: 1100px){
header{padding: 15px 15px 25px;}
.header-in .h-logo{width: 280px;}
.navToggle{right:20px; top:30px;}

.navToggle.active{right:20px; top:30px;}

.header-in .to-contact{margin:0;}
}
@media screen and (max-width: 980px){
	header{min-height: 80px;}
	.header-in .h-logo{width: 210px;}
	.header-in .to-contact a{width:140px;line-height: 45px;}
	.navToggle{right:20px; top:25px;}
	.navToggle.active{right:20px; top:25px;}
}
@media screen and (max-width: 768px){
header{min-height: 70px;}
.header-in .item{display: none;}
.navToggle{right:20px; top:20px;}
.navToggle.active{right:20px; top:20px;}
}
@media screen and (max-width: 420px){
	header{
		min-height: 60px;
		background:
	linear-gradient(
      to bottom,
      #005AA9 0%,
      #005AA9 80%,
      transparent 80%,
      transparent 100%
    ),
		url(img/wave-bg.svg);
		background-repeat: no-repeat, no-repeat;
	background-size:100% 100%,100% auto;
	background-position:top,left bottom;
	}
	.header-in .h-logo{width:200px;}
	.navToggle{right:15px; top:15px;}
	.navToggle.active{right:15px; top:15px;}
}

/* footer
---------------------------------------------------------------- */

.f-bg{
	position: relative;
	width: 100%;
	aspect-ratio: 1920 / 175;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-image: url(img/wave-footer.svg);
	bottom: -1px;
}
footer{
	background-color:#005AA9;
	padding:4rem 2rem 2rem;
}



@media screen and (min-width: 769px){
	footer{
	background-color:#005AA9;
	background-image:url(img/footer-bg.svg);
	background-position:right calc((100% - 1480px) / 2) bottom 2rem;
	background-repeat:no-repeat;
	background-size:auto;
}
}
@media screen and (min-width: 769px) and (max-width: 1580px){
	footer{background-position:right 2rem bottom 2rem;}
}


footer .f-inner{
	max-width:1420px;
	margin:0 auto;
}
.item-add{
	max-width:420px;
	margin:0 auto;
	color:#fff;
}
.item-add .f-logo{
	margin-bottom:2rem;
}
.item-add .tbl-min{margin-bottom:4rem;}
.item-add .tbl-min th,
.item-add .tbl-min td{
	font-size:clamp(14px, 1.25vw, 17px);
	line-height: 2.5em;
	padding: 0 .5rem;
}

.f_nav{
	text-align: center;
	margin-bottom: 2rem;
}
.f_nav li{
	display:inline-block;
	padding:0 1rem;
	margin-bottom:2rem;
}
.f_nav li:not(:last-child){border-right:solid 1px #fff;}
.f_nav li a{
	display:inline-block;
	color:#fff;
	font-size:clamp(14px, 1.25vw, 18px);
}
@media screen and (max-width: 768px){
	.f_nav{display:none;}
}



.f_sns{
	text-align: center;
	margin-bottom: 2rem;
}
.f_sns li{
	display:inline-block;
	padding:0 1rem;
	margin-bottom:2rem;
}

.f_nav li a{
	display:inline-block;
}



footer .address{
font-size:clamp(12px, 1.15vw, 13px);
color:#fff;
text-align: center;
}

/* カテゴリー
---------------------------------------------------------------- */

.cat_list_wrap{
	background: #f4f3f2;
	padding: 4rem 6rem;
}
@media screen and (max-width: 1140px){
.cat_list_wrap{padding:4rem 2rem;}
}

@media screen and (max-width: 480px){
.cat_list_wrap{padding:2rem 1rem;}
}

.cat_list .cat_txt{
	display:flex;
	flex-wrap:wrap;
	border-bottom: solid 1px #c3bdda;
    padding: 1rem .5rem;
}
.cat_list .cat_txt .date{
	width:6em;
	margin-right:1rem;
	line-height:1.75em;
	
}
@media screen and (max-width: 480px){
	cat_list .cat_txt{
	display:block;
	}
	.cat_list .cat_txt .date{margin-bottom:.5rem;}
}


/*pagenavi*/
.pagenavi{
	color: #fff;
	margin: 20px auto 20px;
	line-height:2em;
	text-align:center;
	clear: both;
	margin-bottom:2em;
}
.pagenavi a{
	text-decoration:none;
	color: #fff;
	background: #4F4F50;
}
.pagenavi a:hover{background:#b39ac4;}
.pagenavi a.page-numbers, .pagenavi .current{
	line-height: 33px;
	display: inline-block;
	padding: 0 12px;
	text-decoration: none;
	font-size: 16px;
	border-radius:30px;
}
.pagenavi .current{
	color: #fff;
	background: #b39ac4;
	font-weight: bold;
}
.pagenavi .prev.page-numbers,
.pagenavi .next.page-numbers{
	background:none;
	color:#1f1f1f;
}
@media screen and (max-width: 480px){
	.pagenavi a.page-numbers, .pagenavi .current{
		font-size:12px;
		padding:0 9px;
		line-height:24px;
	}
	
}



/*次の記事*/
.navigation{
	display: flex;
	flex-wrap:wrap;
	justify-content: space-between;
}
.navigation .alignleft,
.navigation .alignright{
	width:50%;
	box-sizing:border-box;
	position:relative;
}
.navigation .alignleft{padding-right:1rem;}
.navigation .alignright{padding-left:1rem;text-align:right; /*border-left:solid 1px #ddd;*/}

.navigation .next,
.navigation .prev{
	position:absolute;
	z-index:1;
	top:0;
	background:#958bbd;
	padding:3px 6px;
	color:#fff;
	font-size:12px;
}

.navigation .next{right:0;}
.navigation .prev{left:0;}


.navigation .tit{margin-bottom:0;}
.navigation a{
	display:block;
	padding:2rem 0;
	font-weight:bold;
	position:relative;
}
.navigation .date{
	position:absolute;
	bottom:5px;
	font-size:12px;
	color:#666;
}
.navigation .alignleft .date{left:0;}
.navigation .alignright .date{right:0;}

/* ==========================================================================
   main内共通
========================================================================== */

.entry_content{margin-bottom: 10em;}
@media screen and (max-width: 480px){.entry_content{margin-bottom: 4em;}}
.page-top{
	padding:6rem 4rem;
	overflow:hidden;
}
.page-top-in{
	max-width:1480px;
	margin:0 auto;
}
@media screen and (max-width: 480px){
	.page-top{
	padding:6rem 2rem;
	overflow:hidden;
}
}

.page-top-img-wrap{
	min-height: 60vh;/*画像がある場合のみ*/
}


.page-top-in .page-top-txt{
	flex:1;
	max-width:730px;
	position: relative;
	z-index:2;
}
.page-top-in .page-top-img{
	flex:1;
	text-align:right;
	position: relative;
	z-index:2;
	
}
.page-top-in .page-top-img:after{
	content:"";
	position:absolute;
	z-index:-1;
	right:-50%;
	top:-10%;
	width:auto;
	height:120%;
	aspect-ratio:1/1;
	background:#CBEFFF;
	border-radius:50%;
}

@media screen and (min-width: 681px){
	.page-top-in{
	display:flex;
	flex-wrap:wrap;
	}
	.page-top-in .page-top-img{
		display: flex;
	align-items: center;
	justify-content: center;
	padding-left:2rem;
	}
}

@media screen and (max-width: 1280px){
	.page-top-in .page-top-img:after{
		height:100%;
		right:-80%;
		top:0;
	}
}

@media screen and (max-width: 680px){
	.page-top-in .page-top-img{
		width: 70%;
		margin-left: auto;
		margin-top:4rem;
		aspect-ratio: 1 / 1;
		display: flex;
        align-items: center;
	}
	.page-top-in .page-top-img:after{
		height: 120%;
		top: -10%;
		right: calc(-50% - 3rem);
	}
}




.page-top-in .page-top-txt .sub-tit{
	font-size:clamp(10px, 1.25vw, 14px);
	color:#0088FF;
	font-weight:bold;
	letter-spacing:2px;
}
.page-top-in .page-top-txt h1{
	position: relative;
	font-size:clamp(25px, 3vw, 50px);
	padding-bottom:1.5rem;
	margin-bottom:1.5rem;
	font-weight: bold;
	letter-spacing:1px;
}
.page-top-in .page-top-txt h1:after{
	width:20%;
	max-width:250px;
	height:2px;
	background:#005AA9;
	content:"";
	position:absolute;
	z-index:1;
	left:0;
	bottom:0;
}
.page-top-in .page-top-txt .page-hook p{
	font-size:clamp(15px, 2vw, 22px);
	font-weight:bold;
	line-height:2em;
	letter-spacing: 3px;
}

@media screen and (min-width: 681px){
	
}
@media screen and (max-width: 680px){
	
}





/*上下波型の背景*/
.wave-top,
.wave-bottom{
	position:relative;
	width: 100%;
	aspect-ratio:32/1;
	background-repeat: no-repeat;
	background-size: 100% 100%;
}
.wave-top{
	background-image: url("img/wave-top.svg");
	bottom:-1px;
}
.wave-bottom{
	background-image: url("img/wave-bottom.svg");
	top:-1px;
}
@media only screen and (max-width: 768px) {
.wave-top,
.wave-bottom{
	aspect-ratio: 16 / 1;
	background-size: auto 100%;
}
}


/*フォームへボタン*/
.to-form a{
	font-size: clamp(14px, 1.5vw, 18px);
	box-sizing: border-box;
	line-height: 86px;
	padding: 0;
	text-align: center;
	max-width: 334px;
	display: inline-block;
	margin: 0 auto;
	background-color: #0088FF;
	color: #fff;
	font-weight: bold;
	border-radius: 44px;
	text-decoration: none;
	display: flex;
	justify-content: center;
	align-items: center;
}
.to-form a:after{
	content: '';
	width: 48px;
	height: 15px;
	border-bottom: solid 2px #fff;
	border-right: solid 2px #fff;
	transform: skew(45deg);
	margin-bottom: 5px;
	margin-left: 5px;
}
@media screen and (max-width: 480px){
	.to-form a{line-height:46px;max-width: 253px;}
	.to-form a:after{width:28px;height: 9px;}
}


/*共通のタイトル部分*/
.tit-hook .sub-tit{
	color:#0088FF;
	font-size:clamp(10px, 1.25vw, 16px);
	font-weight: bold;
}
.tit-hook h2{
	font-size:clamp(25px, 4vw, 50px);
	position: relative;
}
.tit-hook .hook-text p{
	margin:0;
	font-weight:bold;
	font-size:clamp(16px, 1.75vw, 19px);
}
@media screen and (min-width: 768px){
.tit-hook{
	position:relative;
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	padding:1.5em 1rem 1rem;
}
.tit-hook .sub-tit{
	position: absolute;
	left: 1rem;
	top: 1rem;
}
.tit-hook h2{
	border-right:solid 2px #005AA9;
	padding-right:40px;
	margin-bottom:0;
}
.tit-hook .hook-text{flex:1;padding-left:40px;}
}
@media screen and (max-width: 768px){
.tit-hook h2{padding:.5rem 0;}
.tit-hook h2:after{
	content:"";
	width:70px;
	height:2px;
	background:#005AA9;
	position:absolute;
	left:0;
	bottom:0;
}
}

/*お問い合わせ関連*/
#f-contact{
	background:#E2F6FF;
	padding:6rem 2rem;
	margin-bottom: 8em;
}
#f-contact .f-inner{
	max-width:1480px;
	display: flex;
	flex-wrap: wrap;
	    margin: 0 auto;
}
#f-contact .tit-hook{
	flex-direction:column;
	align-items: unset;
}
#f-contact .tit-hook .hook-text{
	padding-left:0;
}
#f-contact .tit-hook h2{
	border-right:none;
}
#f-contact .inner{flex:1;}
@media screen and (min-width: 769px){
	#f-contact .tit-hook h2{
		padding: 0 40px 10px 0;
		margin-bottom: 20px;
	}
	#f-contact .tit-hook h2:after{
		content: "";
		width: 300px;
		height: 2px;
		background: #005AA9;
		position: absolute;
		left: 0;
		bottom: 0;
    }
}
@media screen and (max-width: 1280px){
	#f-contact .inner{padding:3rem 0;}
}
@media screen and (max-width: 1080px){
	#f-contact .f-inner{
	display: block;
	}
	#f-contact .tit-hook{
		margin-bottom: 2rem;
	}
}


.contact .inner{
	max-width:1020px;
	margin:0 auto;
	background:#fff;
	border-radius:60px;
	padding:4rem 2rem;
	box-sizing:border-box;

}


@media screen and (min-width: 769px){
.contact .inner{
	display:flex;
	flex-wrap:wrap;
}
}
.contact .item-tel,
.contact .item-mail{
	flex:1;
	padding:0 2rem;
	position:relative;
}

.contact .item-tel .in-tit,
.contact .item-mail .in-tit{
	display:flex;
	justify-content:center;
	align-items:center;
	margin-bottom: 2rem;
}

.contact .item-tel .in-tit:before{
	margin-right:.5rem;
	content:"";
	width:47px;
	aspect-ratio: 47 / 61;
  background: url("img/icon-tel.svg") no-repeat center bottom / 100% 100%;
}
.contact .item-mail .in-tit:before{
	margin-right:.5rem;
	content:"";
	width:56px;
	aspect-ratio: 56 / 61;
  background: url("img/icon-mail.svg") no-repeat center bottom / 100% auto;
}

.in-tit h3{
	font-size:clamp(17px, 1.75vw, 20px);
	font-weight:bold;
}
.contact .tel a{
	font-size:clamp(27px, 2.75vw, 50px);
	display: block;
	text-align: center;
	color:#0088FF;
	font-weight: bold;
}
.contact .tel span{
	font-size:clamp(14px, 1.5vw, 17px);
	color:#234461;
}
.contact .time{
	font-size:clamp(14px, 1.5vw, 20px);
	text-align: center;
	font-weight:bold;
}



@media screen and (min-width: 769px){
	.contact .item-tel:after{
		content:"";
		width:2px;
		height:calc(100%);
		background:#005AA9;
		position:absolute;
		right:0;
		top:0;
	}
}
@media screen and (max-width: 768px){
	.contact .item-tel{padding-bottom:2rem;}
	.contact .item-tel:after{
		content:"";
		width:60%;
		height:2px;
		background:#005AA9;
		position:absolute;
		right:20%;
		bottom:0;
	}
	.contact .item-mail{
		padding-top:2rem;
	}
}
@media screen and (max-width: 480px){
	.contact .item-tel,
	.contact .item-mail{
	padding:0;
}
.contact .item-tel{padding-bottom:2rem;}
.contact .item-mail{padding-top:2rem;}
.contact .item-tel .in-tit,
.contact .item-mail .in-tit{
	flex-direction: column;
}
}

/* ==========================================================================
   section別
========================================================================== */

/*index catch*/
#index-catch{
	padding:  1rem 4rem;
	overflow:hidden;
	margin-bottom: 4em;
}
#index-catch .inner1650{
	position:relative;
}
#index-catch .item-txt01,
#index-catch .item-txt02{
	position:absolute;
}
#index-catch .item-txt01{
	left:10px;
	top:50px;
}
#index-catch .item-txt02{
	right:10px;
	bottom:0px;
	text-align:right;
}
#index-catch .item-txt01 p span,
#index-catch .item-txt02 p span{
	display:inline-block;
	font-size:clamp(32px, 4vw, 50px);
	color:#fff;
	padding:1rem;
	margin-bottom:8px;
	background:#005AA9;
	font-weight:bold;
	letter-spacing: 3px;
}
#index-catch .item-img{
	text-align: center;
	max-width: 1200px;
	margin: 0 auto;
}

@media screen and (min-width: 769px) and (max-width: 1580px){
	#index-catch .item-img{width:70%;}
	#index-catch .item-img img{max-height: 80vh;}
}
@media screen and (min-width: 1401px){
	#index-catch .item-img{width:80%;}
}

@media screen and (max-width: 768px){
	#index-catch{padding: 1rem 0rem;margin-bottom:0;}
#index-catch .item-img{
	aspect-ratio: 4 / 5;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom:2rem;
}
#index-catch .item-img img{
	width: 140%;
	max-width: unset;
}
#index-catch .item-txt02{bottom:0;}
#index-catch .item-txt01 p span,
#index-catch .item-txt02 p span{
	font-size:clamp(18px, 4vw, 36px);
}
}
@media screen and (max-width: 480px){
#index-catch .item-img{
	aspect-ratio: 4 / 6;
}
#index-catch .item-txt01{top:10px;}
#index-catch .item-txt02{bottom:-20px;}
}

/*index水まわりでこんなお困りごとはございませんか？*/
#index-soudan{padding:8rem 4rem;}
#index-soudan .tit{margin-bottom:4rem;}
#index-soudan .tit h2{
	font-size:clamp(15px, 2.5vw, 32px);
	text-align:center;
}
#index-soudan h2 strong{
	color:#005AA9;
	font-size:clamp(25px, 3vw, 44px);
	display:inline-block;
	background-image: linear-gradient(0deg, #CDE4F8 0.5em, transparent 0.5em);
}

#index-soudan ul.soudan-list{
	display:flex;
	flex-wrap:wrap;
}
#index-soudan ul.soudan-list li{
	width:calc((100% - 120px) / 4);
	background:#005AA9;
	border-radius:0 50px 0 50px;
	padding:30px;
	box-sizing: border-box;
	margin:15px;
	box-shadow:10px 8px 0 #CDE4F8;
	text-align:center;
	color:#fff;
}
#index-soudan ul.soudan-list li span{
	display:block;
	margin-bottom:30px;
	font-size:clamp(29px, 2.75vw, 39px);
	font-weight:bold;
}
#index-soudan ul.soudan-list li img{
	border-radius:25px;
	margin-bottom:20px;
}
#index-soudan ul.soudan-list li p{
	font-size:clamp(12px, 1.25vw, 14px);
	font-weight:bold;
}
#index-soudan ul.soudan-list li p strong{
	font-size:clamp(15px, 1.5vw, 19px);
	display: inline-block;
}
@media screen and (max-width: 1380px){
	#index-soudan ul.soudan-list li{padding:20px;}
	#index-soudan ul.soudan-list li span{margin-bottom:20px;}
}
@media screen and (max-width: 980px){
#index-soudan ul.soudan-list li{width:calc((100% - 60px) / 2);}
}
@media screen and (max-width: 480px){
#index-soudan{padding:4rem 2rem;}
#index-soudan ul.soudan-list li{
	width:unset;
	max-width:284px;
	margin: 0 auto 4rem;
}
#index-soudan ul.soudan-list li span{margin-bottom:10px;}
}


/*indexご相談・お見積りは無料!まずはご相談ください*/

#index-contact{
	padding:8rem 0;
}
#index-contact .tit{
padding:0 1rem;
}
#index-contact .tit h2{
	text-align:center;
	position:relative;
	font-size:clamp(12px, 2vw, 32px);
	display: flex;
  justify-content: center;
  align-items: flex-end;
}
#index-contact .tit h2 strong{
	font-size:clamp(17px, 2.5vw, 40px);
	color:#0088FF;
}
#index-contact .tit h2:before,
#index-contact .tit h2:after{
	width: 2px;
  height: 1.5em;
  content: "";
  background-color: #0088FF;
}
#index-contact .tit h2::before {
  margin-right: 0.5em;
  transform: rotate(-30deg);
}
#index-contact .tit h2::after {
  margin-left: 0.5em;
  transform: rotate(30deg);
}
#index-contact .cont{
	background:#E2F6FF;
	padding:4rem 2rem;
}
@media screen and (max-width: 480px){
	#index-contact{padding:4rem 0;}
	#index-contact .tit h2{letter-spacing: 0;}
	#index-contact .cont .inner{border-radius: 20px;}
	
}
@media screen and (max-width: 360px){
	#index-contact .tit h2{font-size:11px;}
	#index-contact .tit h2 strong{font-size:15px;}
}


/*index会社概要*/
#index-about .cont{
	background:#E2F6FF;
	padding: 4rem 0;
}
#index-about .cont .inner{
	padding:0 2rem;
}

/*index事業内容*/
#index-contents{padding: 8rem 4rem;}
#index-contents .cont{padding-top:4rem;}
#index-contents .cont ul.col-list > li{margin-bottom:4rem;}
#index-contents .cont ul.col-list > li .num{
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 40px;
	background: #005AA9;
	color: #fff;
	border-radius: 20px;
	position: relative;
	width: 144px;
	font-size:13px;
	margin-bottom:1.5em;
}
#index-contents .cont ul.col-list > li .num span{
	font-size:28px;
	margin-left: 5px;
}

#index-contents .cont ul.col-list > li .num:after{
	content:"";
	width:13px;
	height:15px;
	position:absolute;
	left:60px;
	bottom:-14px;
	background: #005AA9;
	clip-path: polygon(0 0, 50% 100%, 100% 0);
}
#index-contents .cont ul.col-list > li h3{
	font-size:clamp(25px, 2.5vw, 40px);
	color:#0088FF;
}
#index-contents .cont ul.col-list > li h3 span{
	font-size:clamp(16px, 1.5vw, 25px);
	font-weight:bold;
}

@media screen and (min-width: 769px){
	#index-contents .cont ul.col-list{
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
}
#index-contents .cont ul.col-list > li{
	width:calc((100% - 8rem) / 2);
}
}
@media screen and (min-width: 769px) and (max-width: 1400px){
	#index-contents .cont ul.col-list > li{
	width:calc((100% - 4rem) / 2);
}
}

#index-contents .cont ul.col-list > li .col p{
	font-weight:bold;
}

@media screen and (min-width: 481px){
#index-contents .cont ul.col-list > li .col{
	display:flex;
	flex-wrap:wrap;
}
#index-contents .cont ul.col-list > li .col p{
	width:60%;
}
#index-contents .cont ul.col-list > li .col figure{
	width:40%;
	position:relative;
}
#index-contents .cont ul.col-list > li:nth-child(3) .col figure{
	top:-30px;
}
}
@media screen and (max-width: 480px){

#index-contents{padding: 6rem 2rem;}
#index-contents .cont ul.col-list > li{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
#index-contents .cont ul.col-list > li h3,
#index-contents .cont ul.col-list > li p{text-align:center;}
#index-contents .cont ul.col-list > li figure{text-align:center;}

#index-contents .cont ul.col-list > li:nth-child(1) figure img{width:40%;}
#index-contents .cont ul.col-list > li:nth-child(2) figure img{width:50%;}
#index-contents .cont ul.col-list > li:nth-child(3) figure img{width:40%;}
#index-contents .cont ul.col-list > li:nth-child(4) figure img{width:50%;}
}


/*indexグリストラップ*/
#index-gr{padding: 8rem 2rem 12rem;}
#index-gr .inner .cont{
	position: relative;
	text-align:center;
	z-index:2;
	box-sizing:border-box;
}
#index-gr .inner .cont:after{
	content:"";
	width:100%;
	max-width:740px;
	height:auto;
	border-radius:50%;
	aspect-ratio: 1 / 1;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background:#E2F6FF;
	z-index:-1;
}

#index-gr .inner .cont .sub-tit{
	font-size:clamp(18px, 2vw, 23px);
	color:#005AA9;
	font-weight: bold;
	margin-bottom:1rem;
}
#index-gr .inner .cont h2{
	margin-bottom:2rem;
}
#index-gr .inner .cont h2 span{
	display:inline-block;
	background:#fff;
	border-radius:50px;
	font-size:clamp(24px, 3.5vw, 44px);
	color:#0088FF;
	font-weight: bold;
	padding: 0 1em;
}
#index-gr .inner .cont p{
	font-weight: bold;
	font-size:clamp(13px, 2vw, 20px);
	margin-bottom: 3em;
}
#index-gr .inner .gr01,
#index-gr .inner .gr02{position:relative;z-index:3;}




@media screen and (min-width: 769px){
#index-gr .inner{
	display: flex;
	flex-wrap: wrap;
	align-items:center;
}
#index-gr .inner .gr01,
#index-gr .inner .gr02{width:20%;}

#index-gr .inner .cont{
	flex:1;
	margin:0 2rem;
	padding:6rem 2rem;
	}
}

@media screen and (max-width: 982px){
#index-gr .inner .cont{
	flex:1;
	margin:0;
	padding:0;
	}
	#index-gr .inner .cont:after{width:120%;min-width:480px;}
}
@media screen and (max-width: 768px){
#index-gr{overflow: hidden;}
#index-gr .inner .gr01,
#index-gr .inner .gr02{
	width:40%;
	margin:0 auto;
	}
	#index-gr .inner .gr01{margin-bottom:4rem;}
#index-gr .inner .gr02{margin-top:4rem;}
	
}
@media screen and (max-width: 480px){
	#index-gr{padding: 2rem 2rem 4rem;}
}
@media screen and (max-width: 420px){
	#index-gr{padding: 2rem 1rem 4rem;}
}
/*index対応エリア*/

#index-area .inner{
	background:#e2f6ff;
	padding:4rem 4rem;
	max-width:unset;
}
#index-area .tit{
	max-width:1480px;
	margin:0 auto 2rem;
}
#index-area .tit h2{
	position:relative;
	display:flex;
	align-items:center;
}
#index-area .tit h2:before{
	content:"";
	display:block;
	width:40px;
	height:auto;
	margin-right:1rem;
	background-image:url(img/icon-map.svg);
	background-size:100% 100%;
	background-repeat:no-repeat;
	background-position:center;
	aspect-ratio:43/72;
}
#index-area .tit p{
	font-size:clamp(15px, 2vw, 20px);
	font-weight:bold;
}

#index-area .col2{
	max-width:1480px;
	margin:0 auto;
}

#index-area .col2 .item-txt h3{
	font-size:clamp(15px, 2vw, 18px);
	color:#fff;
	text-align:center;
	border-radius:60px;
	padding:1rem;
	margin-bottom:1rem;
	font-weight:bold;
}
#index-area .col2 .item-txt p{
	font-size:clamp(18px, 2.5vw, 30px);
	text-align:center;
	font-weight:bold;
	margin-bottom:2rem;
}
#index-area .col2 .item-txt p span{
	display:inline-block;
	margin-right:1rem;
	font-weight:bold;
}
@media screen and (min-width: 769px){
#index-area .tit{
	display:flex;
	flex-wrap:wrap;
	align-items:center;
}
#index-area .tit h2{margin-right:2rem;}
#index-area .col2{
	display:flex;
	flex-wrap:wrap;
	align-items: center;
}
#index-area .col2 .item-img{flex:1; max-width:600px; margin-right:4rem;}
#index-area .col2 .item-txt{flex:1;}
}

@media screen and (max-width: 768px){
	#index-area .tit h2:before{width:24px;}
	#index-area .col2 .item-img{
		text-align:center;
		width:80%;
		margin:0 auto 2rem;
	}
}

@media screen and (max-width: 480px){
#index-area .inner{padding:4rem 2rem;}
}

/*indexご利用の流れ*/
#index-flow{
	padding:8rem 2rem;
}
#index-flow .tit {margin-bottom:4rem;}
#index-flow .tit h2{
	text-align:center;
	font-size:clamp(18px, 2.5vw, 30px);
	position:relative;
	max-width:565px;
	margin:0 auto;
	padding-bottom:1rem;
}
#index-flow .tit h2 span{
	display:block;
	color: #0088FF;
	font-size: clamp(10px, 1.25vw, 16px);
	font-weight: bold;
}
@media screen and (min-width: 769px){
	#index-flow .tit h2{border-bottom:solid 2px #005AA9;}
}
@media screen and (max-width: 768px){
#index-flow .tit h2:after{
	content:"";
	width:;
	height:;
	position:absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	transform: translate(-50%, -50%);
	width: 70px;
	height: 2px;
	background: #005AA9;
}
}


.flow-list{
	counter-reset: listnum;
	max-width: 650px;
	margin: 0 auto;
}
.flow-list li{
	position: relative;
	margin-bottom: 3rem;
	padding: 0 0 0 5rem;
}
.flow-list li:not(:last-child):after{
	content:"";
	border-left: 18px dotted #CBEFFF;
	position: absolute;
	bottom: -2.5rem;
	top: clamp(40px, 4.75rem, 72px);
	left: clamp(16px, 1.35rem, 30px);
	height: 100%;
	background-position: right top;
	background-repeat: repeat-y;
	background-size: 1px 100%;
}

.flow-list li .num{
	color:#fff;
	font-size:clamp(18px, 2.5vw, 30px);
	font-weight:bold;
	position: absolute;
	left:0;
	top:0;
	width:clamp(40px, 4rem, 64px);
	line-height:clamp(40px, 4rem, 64px);
	text-align:center;
	z-index: 9;
}
.flow-list li .num span{font-weight:bold;}
.flow-list li .num:after{
	content:"";
	width:clamp(40px, 4rem, 64px);
	height: auto;
	border-radius: 50%;
	aspect-ratio: 1 / 1;
	position: absolute;
	top: 0;
	left: 0;
	background: #0088FF;
	z-index: -1;
}
.flow-list li h3{
	font-size:clamp(21px, 2.5vw, 37px);
	font-weight:bold;
	line-height:clamp(40px, 4rem, 64px);
	color:#0088FF;
}
.flow-list li p{
	font-size:clamp(15px, 1.25vw, 20px);
	font-weight:bold;
}

/*会社概要*/
.tbl-about{
	max-width:1220px;
	margin:0 auto 2rem;
}
.tbl-about tbody th,
.tbl-about tbody td{
	padding:2em .5em;
	border-bottom:solid 1px #707070;
	
}

.tbl-about tbody th{
	width:25%;
	max-width:300px;
	font-size: clamp(15px, 1.25vw, 20px);
	line-height: 1.75rem;
	font-weight: bold;
	text-align: left;
}
.tbl-about tbody td,
.tbl-about tbody td p{
	font-size: clamp(15px, 1.125vw, 18px);
	line-height: 1.75rem;
}
.tbl-about tbody td span{
	display:inline-block;
	margin-bottom: 1rem;
}

@media screen and (max-width: 480px){
.tbl-about tbody th,
.tbl-about tbody td{display:block;}
.tbl-about tbody th{
	width: unset;
	max-width: unset;
	border-bottom:none;
	padding-bottom:0;
}
.tbl-about tbody td{
	padding-top:1em;
}
}




/*沿革*/
#history .inner .tit .sub-tit{
	font-size:clamp(10px, 1.25vw, 14px);
	color:#0088FF;
	font-weight:bold;
	letter-spacing:2px;
}
#history .inner .tit h1{
	position: relative;
	font-size:clamp(25px, 3vw, 50px);
	padding-bottom:1.5rem;
	margin-bottom:1.5rem;
	font-weight: bold;
	letter-spacing:1px;
}

@media screen and (min-width: 480px){
#history .inner{display:flex;flex-wrap:wrap;}
#history .inner .tit{max-width:400px;width:25%;}
#history .inner .cont{flex:1;}
}

@media screen and (min-width: 769px){
	.enkaku-list li{
		display: flex;
		flex-wrap:wrap;
		align-items: center;
	}
}

.enkaku-list li{
	position: relative;
	margin-bottom: 3rem;
	padding: 0 0 0 5rem;
	
}
.enkaku-list li:before{
	content:"";
	position: absolute;
	top:1rem;
	left:0;
	width:36px;
	height:auto;
	aspect-ratio: 1 / 1;
	background: #0088FF;
	border-radius: 50%;
}
.enkaku-list li:not(:last-child):after{
	content:"";
	position: absolute;
	bottom: 0;
	top: 1rem;
	left:17px;
	width:3px;
	background:#0088FF;
	height: calc(100% + 3em);
}
.enkaku-list li h3{
	font-size:25px;
	font-weight:bold;
	line-height:clamp(40px, 4rem, 64px);
	width: 6em;
}
.enkaku-list li p{
	font-size:16px;
	flex:1;
}

#history .inner .cont{
	position: relative;
	z-index:2;
}


#history .inner .item-img{
	text-align: right;
}
@media screen and (min-width: 981px){
#history .inner .item-img{
	position: relative;
	z-index: 1;
	bottom: 7em;
	margin-bottom: -7em;
}
}
@media screen and (max-width: 480px){
#history .inner .item-img{
	text-align: center;
	width:50%;
	margin: 0 auto;
}
}

/*事業内容*/


.service-tit{
	text-align:center;
	margin-bottom: 4rem;
}

.service-tit .num{
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 40px;
	background: #005AA9;
	color: #fff;
	border-radius: 20px;
	position: relative;
	width: 144px;
	font-size:13px;
	margin:0 auto 1rem;
}
.service-tit .num span{
	font-size:28px;
	margin-left: 5px;
}
.service-tit .num:after{
	content:"";
	width:13px;
	height:15px;
	position:absolute;
	left:60px;
	bottom:-14px;
	background: #005AA9;
	clip-path: polygon(0 0, 50% 100%, 100% 0);
}
.service-tit h2{
	font-size:clamp(25px, 3vw, 50px);
	color:#0088FF;
}
.service-tit h2 span{
	font-size:clamp(16px, 1.5vw, 33px);
	font-weight:bold;
}

.service-cont .box{
	margin-bottom:2rem;
}
.service-h3 {
	margin-bottom:1rem;
}
.service-h3 span{
	font-size:clamp(20px, 2vw, 24px);
	padding: .5rem 1.5rem;
	background: #0088FF;
	color: #fff;
	font-weight: bold;
	display: inline-block;
	line-height: 1.5em;
	border-radius: 30px;
}
.service-cont .box p{
	font-size:clamp(16px, 1.25vw, 20px);
	font-weight:bold;
	letter-spacing:2px;
}

.service01-1{margin-bottom:3rem;}
.service01-1 .item-img{text-align:center;}

@media screen and (min-width: 769px){
.service01-1{
display:flex;
flex-wrap:wrap;
max-width: 1280px;
margin: 0 auto 3rem;
}
.service01-1 .item-img{
	width:45%;
	padding: 0px 5em;
	box-sizing: border-box;
}

.service01-1 .item-txt{flex:1;}
}
@media screen and (max-width: 768px){
	.service01-1 .item-img{
	padding: 0px 5em;
	box-sizing: border-box;
	width: 70%;
        margin: 0 auto 4rem;
	}
}


.service01-2.col3{
	display:flex;
	flex-wrap:wrap;
	margin-bottom: 6rem;
}


@media screen and (min-width: 481px){
	.service01-2.col3 figure{
	width:calc((100% - 4rem) / 3);
	margin-right:2rem;
}
.service01-2.col3 figure:nth-child(3){margin-right:0;}
}

@media screen and (max-width: 480px){
		.service01-2.col3 figure{
	width:calc((100% - 1rem) / 2);
	margin-right:1rem;
}
.service01-2.col3 figure:nth-child(2){margin-right:0;}
.service01-2.col3 figure:nth-child(3){display:none;}
}



.service01-3{margin-bottom:3rem;}
.service01-3 .item-img{text-align:center;}



.service01-3 .item-img figcaption span{
	font-weight:bold;
	color:#0088FF;
}

@media screen and (min-width: 769px){
.service01-3{
display:flex;
flex-wrap:wrap;
}
.service01-3 .item-img{
	width:60%;
	padding: 0px 3em;
	box-sizing: border-box;
}
.service01-3 .item-img figcaption{
	font-size:clamp(14px, 1.5vw, 24px);
	font-weight:bold;
	margin-top:1rem;
}

.service01-3 .item-txt{flex:1;}
}
@media screen and (max-width: 768px){
	.service01-3 .item-img{
		margin-bottom:4rem;
	padding: 0px 1em;
	box-sizing: border-box;
	}
}



.service02-1{margin-bottom:3rem;}
.service02-1 .item-img{text-align:center;}

@media screen and (min-width: 769px){
.service02-1{
display:flex;
flex-wrap:wrap;
}
.service02-1 .item-img{
	width:60%;
	padding: 0px 5em;
	box-sizing: border-box;
}

.service02-1 .item-txt{flex:1;}
}
@media screen and (max-width: 768px){
	.service02-1 .item-img{
		margin-bottom:4rem;
	padding: 0px 5em;
	box-sizing: border-box;
	}
}



.service03-1{max-width:1100px; margin:0 auto 3rem;}
.service03-1 .item-img{text-align:center;}

@media screen and (min-width: 769px){
.service03-1{
display:flex;
flex-wrap:wrap;
align-items:center;
}
.service03-1 .item-img{
	width:45%;
	padding: 0px 7em;
	box-sizing: border-box;
}

.service03-1 .item-txt{flex:1;}
}
@media screen and (max-width: 768px){
	.service03-1 .item-img{
	padding: 0px 5em;
	box-sizing: border-box;
	width: 70%;
        margin: 0 auto 4rem;
	}
}



.service03-2.col3{
	display:flex;
	flex-wrap:wrap;
	margin-bottom: 6rem;
}
@media screen and (min-width: 481px){
	.service03-2.col3 figure{
	width:calc((100% - 4rem) / 3);
	margin-right:2rem;
}
.service03-2.col3 figure:nth-child(3){margin-right:0;}
}

@media screen and (max-width: 480px){
		.service03-2.col3 figure{
	width:calc((100% - 1rem) / 2);
	margin-right:1rem;
}
.service03-2.col3 figure:nth-child(2){margin-right:0;}
.service03-2.col3 figure:nth-child(3){display:none;}
}



.service04-1{max-width:1100px; margin:0 auto 3rem;}
.service04-1 .item-img{text-align:center;}

@media screen and (min-width: 769px){
.service04-1{
display:flex;
flex-wrap:wrap;
align-items: end;
}
.service04-1 .item-img{
	width:45%;
	box-sizing: border-box;
}

.service04-1 .item-txt{
	flex:1;
	position: relative;
	left: -3rem;
	bottom: -3rem;
	margin-right: -3rem;
}
}
@media screen and (max-width: 768px){
	.service04-1 .item-img{
		margin-bottom:4rem;
	padding: 0px 5em;
	box-sizing: border-box;
	}
}


/*事業内容内のグリス*/
#gr .gr-tit{
	text-align:center;
	margin-bottom:4rem;
}
#gr .gr-tit .sub-tit{
	font-size: clamp(15px, 1.5vw, 23px);
	font-weight: bold;
	margin-bottom:2rem;
}
#gr .gr-tit h2{
	font-size: clamp(25px, 3vw, 50px);
	color: #0088FF;
}
#gr .gr-tit p{
	font-size: clamp(16px, 1.5vw, 20px);
	font-weight: bold;
}
@media screen and (min-width: 769px){
#gr .gr01{
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
	margin-bottom:4rem;
}
#gr .gr01 .item-img{
	width:calc((100% - 4rem) / 2);
}
}

#gr .gr01 .item-img{
	position:relative;
	padding-bottom:14rem;
}
#gr .gr01 .item-img h3{
	width:clamp(104px, 20vw, 134px);
	background:#0088FF;
	color:#fff;
	display:flex;
	align-items:center;
	justify-content:center;
	font-size: clamp(14px, 2vw, 20px);
	position:absolute;
	left:0;
	top:0;
	z-index:2;
	aspect-ratio: 1 / 1;
	box-sizing:border-box;
	text-align: center;
	font-weight: bold;
	border-radius: 50%;
	line-height: 1.35em;
}

#gr .gr01 .item-img figure{
	margin-left:3rem;
}
#gr .gr01 .item-img .ill{
	width:70%;
	position:absolute;
	right:0;
	bottom:0;
}

@media screen and (max-width: 768px){
	#gr .gr01 .item-img{
	padding-bottom:4rem;
}
	#gr .gr01 .item-img {max-width:450px;margin:0 auto 4rem;}
#gr .gr01 .item-img .ill{
	width:50%;
}
#gr .gr01 .item-img figure{margin-bottom:2rem;}
}

@media screen and (max-width: 480px){
	#gr .gr-tit p{text-align:left;}
	#gr .gr-tit p br{display:none;}
}


/*=====グリストラップ=====*/

#gr-top{}

#gr-top .cont{
	padding:6rem 3rem;
	background:#E2F6FF;
}

@media screen and (min-width: 769px){
#gr-top .inner{
	display:flex;
	flex-wrap:wrap;
}
#gr-top .inner .item-img{
	width:40%;
	max-width:450px;
	margin-right:4rem;
}
#gr-top .inner .item-txt{flex:1;}
}

#gr-top .inner .item-img .sub-tit{
	font-size: clamp(20px, 2.5vw, 26px);
	font-weight:bold;
	margin:1rem 0;
	text-align:center;
}

#gr-top .inner .item-txt h2{
	color:#0088FF;
	font-weight:bold;
	display: inline-block;
}

#gr-top .inner .item-txt h2 span{
	font-weight:bold;
	font-size: clamp(30px, 3.5vw, 50px);
	line-height: 1.5em;
	background: rgba(255, 255, 255);
	padding:.5rem 1rem;
	margin-bottom:.5rem;
}
#gr-top .inner .item-txt h2 span.min{
	font-size: clamp(18px, 2vw, 30px);
}
#gr-top .inner .item-txt p{
	font-size: clamp(15px, 1.5vw, 18px);
	font-weight:bold;
}
#gr-top .inner .item-txt .list01{margin-bottom:0;}
#gr-top .inner .item-txt .list01 li{
	font-size: clamp(15px, 1.5vw, 18px);
	font-weight:bold;
}
@media screen and (max-width: 768px){
	#gr-top .inner .item-img{
		max-width:450px;
		margin:0 auto 2rem;
	}
}



#gr01{margin-bottom:3rem;}
.gr-tit2{
	display: flex;
	flex-direction: column;
	align-items: center;
	max-width:800px;
	margin:0 auto 4rem;
}




.gr-tit2 h2{
	display: flex;
	justify-content: center;
	align-items: center;
	
}

.gr-tit2 h2 span{
	line-height: 2.5em;
	background: #005AA9;
	color: #fff;
	border-radius: 50px;
	position: relative;
	font-size: clamp(20px, 2.5vw, 39px);
	margin: 0 auto 1rem;
	font-weight:bold;
	padding:0 1em;
}

.gr-tit2 h2 span:after{
	content: "";
	width: 13px;
	height: 15px;
	position: absolute;
	left: calc(50% - 6px);
	bottom: -14px;
	background: #005AA9;
	clip-path: polygon(0 0, 50% 100%, 100% 0);
}
.gr-tit2 p{
	font-size: clamp(15px, 1.5vw, 18px);
	font-weight:bold;
	margin-bottom: 4rem;
	 text-align: center;
}

.gr-tit2 figure{
	width:80%;
	margin:0 auto;
	text-align: center;
}



#gr01 .col3{
	display:flex;
	flex-wrap:wrap;
	margin-bottom: 6rem;
}


@media screen and (min-width: 481px){
	#gr01 .col3 figure{
	width:calc((100% - 4rem) / 3);
	margin-right:2rem;
}
#gr01 .col3 figure:nth-child(3){margin-right:0;}
}

@media screen and (max-width: 480px){
	#gr01 .col3 figure{
	width:calc((100% - 1rem) / 2);
	margin-right:1rem;
}
#gr01 .col3 figure:nth-child(2){margin-right:0;}
#gr01 .col3 figure:nth-child(3){display:none;}
}




#gr02 .cont{
	max-width:1100px;
	margin:0 auto 4rem;
	display: grid;
  grid-template-columns: 2fr 1fr 2fr;
	grid-template-rows:0 auto auto auto;
  grid-template-areas:
    "tit1      .            tit2"
    "jirei1-1  head-before  jirei2-1"
    "jirei1-2  head-during  jirei2-2"
    "jirei1-3  head-after   jirei2-3";
  row-gap: 4rem;
}

/* 行見出し */
#gr02 .cont .head-before { grid-area: head-before; }
#gr02 .cont .head-during { grid-area: head-during; }
#gr02 .cont .head-after  { grid-area: head-after; }

/* タイトル */
#gr02 .cont .tit1 { grid-area: tit1;}
#gr02 .cont .tit2 { grid-area: tit2;}

/* 事例 */
#gr02 .cont .jirei1-1 { grid-area: jirei1-1; }
#gr02 .cont .jirei1-2 { grid-area: jirei1-2; }
#gr02 .cont .jirei1-3 { grid-area: jirei1-3; }

#gr02 .cont .jirei2-1 { grid-area: jirei2-1; }
#gr02 .cont .jirei2-2 { grid-area: jirei2-2; }
#gr02 .cont .jirei2-3 { grid-area: jirei2-3; }


#gr02 .cont .row-head{
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: clamp(14px, 2vw, 30px);
	color:#0088FF;
	font-weight:bold;
}
#gr02 .cont .row-head:after{
	z-index:-1;
	content:"";
	position: absolute;
	top: -15px;
	width: auto;
	height: calc(100% + 30px);
	aspect-ratio: 1 / 1;
	background: #CBEFFF;
	border-radius: 50%;
}


#gr02 .cont .tit{margin:0;}
#gr02 .cont .tit h3{
	text-align:center;
	font-size: clamp(15px, 2vw, 30px);
	color:#005AA9;
}

#gr02 .cont .box{    position: relative;}
.jirei1-1:after,
.jirei1-2:after,
.jirei2-1:after,
.jirei2-2:after{
	width:1.5rem;
	height:1.5rem;
	content:"";
	position:absolute;
	background:#0088FF;
	clip-path: polygon(0 0, 50% 100%, 100% 0);
	bottom:-2.5rem;
	left:calc(50% - 0.75rem);
}


/*グリストラップ清掃　工法比較表*/
#gr03 h2{
	font-size: clamp(20px, 2vw, 40px);
	color:#0088FF;
}


.compare {
  display: grid;
  grid-template-columns: 1fr 2fr 2fr;
  grid-template-areas:
    ".      tit1   tit2"
    "head-t t1     t2"
    "head-m m1     m2"
    "head-d d1     d2"
    "head-c c1     c2";
  gap: 0;
}

/* 上段タイトル */
.compare .tit1 { grid-area: tit1; }
.compare .tit2 { grid-area: tit2; }

/* 行見出し */
.compare .head-t { grid-area: head-t; }
.compare .head-m { grid-area: head-m; }
.compare .head-d { grid-area: head-d; }
.compare .head-c { grid-area: head-c; }

/* 内容 */
.t1 { grid-area: t1; }
.m1 { grid-area: m1; }
.d1 { grid-area: d1; }
.c1 { grid-area: c1; }

.t2 { grid-area: t2; }
.m2 { grid-area: m2; }
.d2 { grid-area: d2; }
.c2 { grid-area: c2; }

/*デザイン*/
.compare .row-head {
  font-weight: bold;
  padding: 1rem;
  display: flex;
  align-items: center;
}

.compare .box {
  padding: 1rem;
}
@media (min-width: 769px) {
.compare .box {
	display: flex;
	align-items: center;
}
}
.compare .row-head,
.compare .box{border-bottom:solid 2px #AAAAAA;}
.compare .tit1,
.compare .tit2{justify-content: center;}
.compare .tit1 h3,
.compare .tit2 h3{
	padding:1rem;
	background:#0088FF;
	width: 80%;
	margin: 0 auto;
	color:#fff;
	text-align: center;
	font-size: clamp(16px, 1.75vw, 25px);
}
.compare .row-head{font-size: clamp(15px, 1.75vw, 20px);}
.compare .box .list01{margin-bottom:0;margin-top: 1rem;}
.compare .box .list01 li{font-size: clamp(15px, 1.75vw, 20px);font-weight:bold;}

.compare .sp-head {display: none;}
@media (max-width: 768px) {
  .compare {
    display: block; /* ← Gridを完全解除 */
  }
  .compare .row-head {
    display: none;
		
  }

  .compare .sp-head {
    display: block;
		font-weight: bold;
		font-size: clamp(15px, 1.75vw, 20px);
		margin: 1rem 0 0 0;
  }
	#gr03 h2{
	text-align:center;
	
}

}


.gr-bnr .sub-tit{
	text-align:center;
	font-size: clamp(16px, 2vw, 23px);
	font-weight:bold;
	margin-bottom:1rem;
	color:#005AA9;
}
.gr-bnr .bnr{
	text-align:center;
}

/*お問い合わせ*/
#contact{
	background:#E2F6FF;
}
#contact.sec{padding:4rem 2rem;}
#contact .tel-box,
#contact .form-box{
	background:#fff;
	padding:2rem;
	border-radius:25px;
}



#contact .tel-box .tit .icon-tel{background:url(img/icon-tel.svg) no-repeat center / auto 100%;}
#contact .form-box .tit .icon-mail{background:url(img/icon-mail.svg) no-repeat center / auto 100%;}

#contact .tel-box .tit h3,
#contact .form-box .tit h3{
	font-size:clamp(20px, 2.5vw, 31px);
	margin-bottom:0;
}
#contact .tel-box .tit .sub-tit,
#contact .form-box .tit .sub-tit{
	font-size:14px;
	letter-spacing:3px;
	color:#0088FF;
	font-weight:bold;
}



@media screen and (min-width: 769px){
#contact .tel-box .tit ,
#contact .form-box .tit {
	position:relative;
	padding-left:80px;
}
#contact .tel-box .tit .icon-tel,
#contact .form-box .tit .icon-mail{
	position:absolute;
	top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	width:60px;
	height:60px;
}

#contact .tel-box .tit{margin-right:2rem;}

}
@media screen and (max-width: 768px){
	#contact .tel-box .tit .icon-tel,
#contact .form-box .tit .icon-mail{
	width:50px;
	height:50px;
	margin:0 auto 1rem;
}

#contact .tel-box .tit,
#contact .form-box .tit{
	display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
		margin-bottom:2rem;
}
#contact .tel-box .sub-tit,
#contact .form-box .sub-tit{order: 1;margin-bottom:1rem;}
#contact .tel-box .tit .icon-tel,
#contact .form-box .tit .icon-mail{order: 2;}
#contact .tel-box .tit h3,
#contact .form-box .tit h3{order: 3;}

#contact .tel-box .cont{flex-direction: column;}

}





#contact .tel-box{
	margin-bottom:4rem;
}

#contact .tel-box .cont{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	    justify-content: center;
	flex:1;
}

#contact .tel-box .cont .tel a{
	font-size:clamp(38px, 3vw, 63px);
	font-weight:bold;
	color:#0088FF;
}
#contact .tel-box .cont .tel a span{
	font-size:clamp(15px, 1.25vw, 23px);
	font-weight:bold;
	color:#234461;
}
#contact .tel-box .cont .time{
	font-size:clamp(15px, 1.25vw, 20px);
	font-weight:bold;
	margin-bottom: 0;
}

@media screen and (min-width: 769px){
	#contact .tel-box{
	margin-bottom:4rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}

	#contact .tel-box .cont .tel{margin-bottom:0;margin-right:2rem;}
	
}
@media screen and (max-width: 768px){
	
}






#contact .form-box .cont{
	max-width: 1024px;
	margin: 4rem auto;
}


.field{
	margin-bottom:2rem;
}
.field p{margin-bottom:0;}
.field .field-head p{
	margin-bottom:0.5rem;
	font-size:clamp(15px, 1.25vw, 20px);
	font-weight:bold;
	color:#234461;
}
.field-label{font-weight:bold;}



.field input[type="text"],
.field input[type="tel"],
.field input[type="email"],
.field select,
.field textarea{
	padding: 1rem;
	border: solid 1px #234461;
	width: 100%;
	box-sizing: border-box;
	font-size:clamp(15px, 1.25vw, 20px);
	font-weight:bold;
}
.wpcf7 select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
	    color: #234461;
}
.field .wpcf7-form-control-wrap{
	display: block;
}
.field .your-service .wpcf7-list-item{
	display: block;
	margin: 0;
}

.form-submit {text-align:center;}
.form-submit input{
	padding: 10px 2em;
	margin-left: 15px;
	background-color: #0088FF;
	border:none;
	border-radius:30px;
	font-size: clamp(15px, 1.75vw, 18px);
	color: #fff;
	margin-left: 72px;
	box-sizing:border-box;
}


.form-agreement a{
	color:#0088FF;
}
.field input[type="checkbox"]{
	transform: scale(1.4); 
	margin-right: 0.4em;
}


@media screen and (max-width: 768px){
.field{display:block;}
.field .field-head .field-label{font-weight:bold;}
.field .field-body{margin-bottom:1rem;}
}


/*プライバシーポリシー*/
#policy .ppbox{
	margin-bottom:4rem;
}
#policy .ppbox h3{
	font-size: clamp(18px, 2vw, 30px);
	font-weight:bold;
	color:#0088FF;
}
#policy .ppbox p{
	font-size: clamp(15px, 1.5vw, 18px);
	font-weight:bold;
	padding-left:1rem;
	line-height:2.25rem;
}
#policy .ppbox p span{display:inline-block;font-weight:bold;}
#policy .ppbox ul li{font-weight:bold;}

