@charset "UTF-8";
/*---------------------------------------------------------
Theme Name: タカハロック2025
Author URI: 
Version: 1.2
Description: 
---------------------------------------------------------*/


article,
header,
canvas,
details,
figcaption,
figure, footer,
nav,
section,
summary {
	display: block;
}

ul{ list-style-type:none; margin:0; padding:0; }
li{ margin:0; } 
p{ line-height:2em; text-align:left; }

@keyframes fade-in {
  0% {
	display: none;
	opacity: 0;
  }
  1% {
	display: block;
	opacity: 0;
  }
  100% {
	display: block;
	opacity: 1;
  }
}
@-moz-keyframes fade-in {
  0% {
	display: none;
	opacity: 0;
  }
  1% {
	display: block;
	opacity: 0;
  }
  100% {
	display: block;
	opacity: 1;
  }
}
@-webkit-keyframes fade-in {
  0% {
	display: none;
	opacity: 0;
  }
  1% {
	display: block;
	opacity: 0;
  }
  100% {
	display: block;
	opacity: 1;
  }
}

@-webkit-keyframes dropdown {
  100% {
	-webkit-transform: translateY(0);
	transform: translateY(0);
	opacity: 1
  }
}

@keyframes dropdown {
  100% {
	-webkit-transform: translateY(0);
	transform: translateY(0);
	opacity: 1
  }
}

.fadein {
  opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}


html{
	height: 100%;
	scroll-behavior: smooth;
	line-height: 2em;
}

body{
	height: 100%;
	min-width: 320px;
	word-wrap: break-word;
	color: #333;
	font-size: 1em;
	font-family: 'Noto Sans JP', sans-serif;
}


.pcnon{
	display: block;
}
.spnon{
	display: none;
}

@media screen and (min-width: 1050px) {
	.pcnon{
		display: none;
	}
	.spnon{
		display: block;
	}
	a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}
a[href*="tel:"] {
	text-decoration: none;
}


/* リンクの色 */
a{
	color: #333333;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
}

/* リンクにマウスオーバーした時の色 */
a:hover{
	color: #054e5a;
	text-decoration: underline;
}

/* ボタン */
.buttonlink{
	margin: 50px auto 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  text-decoration: none;
	color: #577b3d;
	font-size: 1.1em;
  width: 200px;
  height: 50px;
  border: 3px solid #577b3d;
  position: relative;
  transition: 0.3s;
  background-color: #acbfe100;
}
.buttonlink::before, .buttonlink::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 15px;
  transform-origin: 100% 50%;
  height: 1px;
  width: 11px;
  background-color: #577b3d;
  border-radius: 2px;
  will-change: transform;
  transition: .3s;
}
.buttonlink::before {
  transform: translateY(-50%) rotate(30deg);
}
.buttonlink::after {
  transform: translateY(-50%) rotate(-30deg);
}
.buttonlink:hover::before {
  transform: translate(5px, -50%) rotate(30deg);
}
.buttonlink:hover::after {
  transform: translate(5px, -50%) rotate(-30deg);
}
.buttonlink:hover{
	background: #577b3d;
		-webkit-transition: all 0.5s ease;
		-moz-transition: all 0.5s ease;
		-o-transition: all 0.5s ease;
		transition: all  0.5s ease;
	color: #fff;
	text-decoration: none;
}




/* clearfix */
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}

.clearfix:before {
　　　　content: "";
	display: block;
	clear: both;
}

.clearfix {
	display: block;
}

/*画像 */
img.alignright {
	display: block;
	margin:0 auto 10px;
}
img.alignleft {
	display: block;
	margin:0 auto 10px;
}
img.aligncenter {
	display: block;
	margin:0 auto 10px;
}
img.float-left {
	float: left;
}
img.float-right {
	float: right;
}
.wp-caption {
	text-align: center;
}
.aligncenter {
	clear: both;
	display: block;
	margin:0 auto 10px;
}

.wp-block-image.alignfull {
  margin-left: calc((100vw - 100%) / 2 * -1);
  margin-right: calc((100vw - 100%) / 2 * -1);
	background: #dcdce0;
  text-align: center;
 }
.wp-block-image.alignfull img{
	max-width: 1300px;
}



/* 画像リンクのマウスオーバーに透かし */
a:hover img{
	-moz-opacity: 0.8;
	opacity: 0.8;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all  0.3s ease;
}

#wrapper{
	margin: 0 auto;
	overflow:hidden;
	text-align: center;
}

.wid650{
	margin: 0 auto;
	width: 100%;
	max-width: 670px;
	padding: 0 10px;
	box-sizing: border-box;
}
.wid1100{
	margin: 0 auto;
	width: 100%;
	max-width: 1120px;
	padding: 0 10px;
	box-sizing: border-box;
}
.wid1200{
	margin: 0 auto;
	width: 100%;
	max-width: 1220px;
	padding: 0 10px;
	box-sizing: border-box;
}
.wid1300{
	margin: 0 auto;
	width: 100%;
	max-width: 1320px;
	padding: 0 10px;
	box-sizing: border-box;
}


.mt10{ margin-top: 10px; }
.mt20{ margin-top: 20px; }
.mt50{ margin-top: 50px; }
.mt70{ margin-top: 70px; }
.mt100{ margin-top: 100px; }
.mt200{ margin-top: 200px; }
.mb20{ margin-bottom: 20px; }
.fs08{ font-size:0.8em; }
.fs12{ font-size:1.2em; }
.fs15{ font-size:1.5em; }
.fs20{ font-size:2.0em; }
.fcr{ color: #ff0000; }
.fcwhite{ color: #fff; }


ul.wp-block-list{
	margin-top: -10px;
	padding-left: 30px;
	list-style-type: disc;
}
ul.wp-block-list li{
	line-height: 1.4em;
	margin-bottom: 8px;
}


/* ギャラリー調整 */
.wp-block-gallery.has-nested-images figure.wp-block-image {
	flex-grow: 0;
}
@media screen and (max-width:600px) {
	.wp-block-gallery {
		display: block !important;
	}
	.wp-block-gallery .wp-block-image {
		width: 100% !important;
		margin-bottom: 10px !important; /* 画像の間に余白を追加 */
	}
}


/*---------------------------------------------------------*/
/* ヘッダー */
/*---------------------------------------------------------*/

header{
	text-align: center;
}
#headbox{
	height: 140px;
	margin:0;
	padding-top: 10px;
	width: 100%;
	top: 0;
	background-color: #4cc1d4;
	border-bottom: 6px solid #1a97ab;
}
.hlogo{
	margin-top: 10px;
	float: left;
}
.hlogoanima{
	margin-top: 10px;
	margin-left: 0px;
	float: left;
}
.translate{
	float: right;
	margin-top: -20px;
	padding: 10px;
}
.gtranslate_wrapper{
	font-size: 0.8em;
}
.clogo{
	float: right;
	margin-top: -20px;
	background: #fff;
	padding: 15px;
	border-radius: 0 0 8px 8px;
}

@media screen and (min-width: 600px) {
	#headbox{
		z-index: 5;
		position:fixed;
		transition:background-color 1s;
	}
}


/*--------------------------------
アコーディオンメニュー
---------------------------------*/

.menu-navigation-container {
	overflow: hidden;
}

nav li a:hover {
	text-decoration: underline;
}

#si {
	margin:0 -10px;
}

#s-navi ul.sub-menu {
	display:none;
}

.trigger .fa:not(.fa-bars) {
	font-size:14px;
}

/*アコーディオンメニューボタン*/

#s-navi:after {
	content: "";
	display: block;
	clear: both;
	margin-bottom:5px;
}

.acordion_tree ul.menu li {
	float: none;
	font-size: 16px;
	padding: 8px 10px;
	list-style:none;
	border-bottom:dotted 1px #fff;
}

.acordion_tree ul.menu li .fa {
	min-width: 1em;
	color: #fff;
}

.acordion_tree ul.menu li:last-child {
	border:none;
	padding-bottom:0px;
}

.acordion_tree ul.menu li a {
	text-decoration: none;
	color: #fff;
	font-size: 16px;
}

.acordion_tree ul.menu li li{
	line-height: 1.4em;
	margin: 0;
	padding: 0 0 10px;
}

.menu-close {
	padding:10px;
}

/*   ハンバーガーボタン3本線   */
button {
	display: inline;
	background: none;
	border: none;
	padding: 0;
	width: 42px;
	color: #fff;
	letter-spacing: 0.1em;
	cursor: pointer;
	top: 10px;
	margin-right: 20px;
	z-index: 100;
	text-align: center;
	outline: none;
	float: right;
}
/*   ハンバーガーボタン3本線   */
button span.bar {
	display: block;
	height: 2px;
	background-color:#fff;
	margin: 10px 0;
	transition: all 0.2s;
	transform-origin: 0 0;
}
button .close {
	font-size: 11px;
	letter-spacing: 0.05em;
	display: none;
}
button .menu {
	font-size: 11px;
	display: block;
}
/*  メニューアクティブ時  */
button.active span.bar {
	width: 49px;
}
button.active .bar1 {
	transform: rotate(30deg);
}
button.active .bar2 {
	opacity: 0;
}
button.active .bar3 {
	transform: rotate(-30deg);
}
button.active .menu {
	display: none;
}
button.active .close {
	display: block;
}
/* ナビ */
nav#s-navi {
	width: 300px;
	height: 100%;
	transition: all 0.2s;
	transform: translate(-301px);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
	background: rgba(31,178,201,0.8);
	padding-top: 30px;
	text-align: left;
}
nav#s-navi.open {
	transform: translate(0); 
}
nav#s-navi ul{
	margin-top: 10px;
	margin-left: 15px;
}
nav#s-navi ul li{
	margin-bottom: 10px;
}

/* メニューst5 未設定 */

nav.st5,
#menuwide div.menu,
#menuwide nav.menu
 {
	display:none;
}


/*--------------------------------
メニュー
---------------------------------*/

@media print, screen and (min-width: 1050px) {
	
	#menubox {
		margin: 0px 0px 0px auto;
		padding: 60px 0 10px;
		text-align: right;
		max-width: 800px;
	}
	#menuwide {
		padding: 0px;
		margin: 0px 0px 0px auto;
		text-align: right;
	}
	nav.spnon {
		max-width:1100px;
		margin:0 auto;
	}
	header .spnon ul.menu{
		text-align: right;
	}
	header .spnon ul.menu li{
		box-sizing:border-box;
		list-style-type:none;
		float: left;
		padding: 10px 15px;
		height: 40px;
		text-align:center;
		position:relative;
		color: #333;
	}
	header .spnon ul.menu>li:last-child {
		border:none;
	}
	header .spnon ul.menu li a{
		display:block;
		font-size: 16px;
		overflow:hidden;
		width:100%;
		height:100%;
		line-height:20px;
		color: #333;
		text-decoration:none;
		position:relative;
		z-index:1;
	}
	header .spnon ul.menu li:hover{
		background: #107686;
		-webkit-transition: all 0.5s ease;
		-moz-transition: all 0.5s ease;
		-o-transition: all 0.5s ease;
		transition: all  0.5s ease;
		color: #fff;
	}
	header .spnon ul.menu li a:hover{
		color: #fff;
	}

	header .spnon ul.menu li li{
		margin: 10px 0;
		padding: 0px 0;
		height: auto;
		border-right: none;
		border-left: none;
		float: none;
		width: 100%;
	}
	header .spnon ul.menu li li a{
		background:#107686; /*ドロップダウンメニューの背景色*/
		padding: 15px 10px;
		border-top:#fff dotted 1px;
		margin-bottom: -10px;
		text-align: left;
		color: #fff;
		z-index:2;
	}
	header .spnon ul.menu li li:last-child a {
		border-bottom:#fff solid 1px;
	}
	header .spnon ul.menu li li a:hover{
		background:#054e5a; /*ドロップダウンメニューの背景色*/
	}


	header .spnon ul.sub-menu li ul.sub-menu{
		position:absolute;
		left:182px;
		top:0;
		margin: 0;
	}

	header .spnon ul.sub-menu{
		margin: 0;
		width: max-content;
		display:none;
	}

	header .spone ul.sub-menu li{
		margin-bottom: 0;
		margin-top: 0;
		width: max-content;
	}

	nav {
		display: block;
	}

	.gnav100{ width: 100px;}
	.gnav110{ width: 110px;}
	.gnav120{ width: 120px;}
	.gnav130{ width: 130px;}
	.gnav140{ width: 140px;}
	.gnav150{ width: 150px;}
	.gnav160{ width: 160px;}

}



/*---------------------------------------------------------*/
/* フッター */
/*---------------------------------------------------------*/
footer{
	padding: 20px 0 40px;
	margin-top:30px;
}

#footbox{
	background: #333433;
	margin: 0 auto;
	padding: 0 10px 80px;
	font-size: 0.9em;
	color: #fff;
}
.ft_left{
	float: left;
	text-align: left;
	width: 100%;
	max-width: 470px;
}
.flogo{
	background: #fff;
	width: 180px;
	padding: 20px 30px 15px;
	border-radius: 0 0 10px 10px;
	font-size: 0.8em;
	color: #888;
	line-height: 1.2em;
}
.flogo img{
	margin-bottom: 10px;
}
.flogo a{
	text-decoration: none;
}

.address{
	margin-top: 10px;
}
@media screen and (max-width: 767px) {
	.ft_left{
		float: none;
		text-align: center;
		margin-bottom: 20px;
	}
}

#menu-footer{
	padding-top: 20px;
	float: right;
	color: #fff;
}
#menu-footer li{
	display: inline;
	margin-left: 10px;
	white-space: nowrap;
}
#menu-footer li a{
	text-decoration: none;
	color: #fff;
}
#menu-footer li a:hover{
	text-decoration: underline;
}
.sns{
	margin-top: 15px;
	text-align: right;
}

.copyright{
	clear: both;
	margin-top: 10px;
	padding: 20px auto;
	background: #fff;
	text-align: center;
	font-size: 0.9em;
	color: #333;
}

.cart{
	position: fixed;
	z-index: 88;
	right: 0;
	top: 150px;
}


#page_top{
	width: 50px;
	height: 50px;
	position: fixed;
	right: 30px;
	bottom: 30px;
	background: #1fb2c9;
	opacity: 0.6;
	border-radius: 15%;
}
#page_top a{
	position: relative;
	display: block;
	width: 50px;
	height: 50px;
	text-decoration: none;
}
#page_top a::before{
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	content: '\f062';
	font-size: 25px;
	color: #fff;
	position: absolute;
	width: 25px;
	height: 25px;
	top: 0;
	bottom: 10px;
	right: 0;
	left: 0;
	margin: auto;
	text-align: center;
}



/*---------------------------------------------------------*/
/* フロントページ */
/*---------------------------------------------------------*/

h3{
	margin-top: 10px;
	line-height: 1.4em;
	font-size: 1.4em;
}
h3 span{
	font-size: 0.7em;
	color: #bd9d64;
}

.contents_wh{
	clear: both;
	padding: 20px 0;
	text-align: center;
	background: #fff;
}
.contents_gray{
	clear: both;
	padding: 20px 0;
	text-align: center;
	background: #dcdce0;
}
.contents_tur{
	clear: both;
	padding: 20px 0;
	text-align: center;
	background: #1fb2c9;
}

.top_ttl h2{
	margin: 50px auto 20px;
	font-size: 1.8em;
	letter-spacing: 0.1em;
}
@media screen and (max-width: 599px) {
	.top_ttl h2{
		font-size: 1.4em;
		letter-spacing: 0;
	}
}


/* スライド */
#top-slide{
	width: 100%;
	margin-top: 140px;
	background: #fff url("images/index/hero-bg.jpg") repeat-x;
/*		background: #dcdce0; */
	text-align: center;
}
#top-slide img{
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}
@media screen and (max-width: 599px) {
	#top-slide{
		margin-top: 0px;
	}
}


.esp{
	border: 1px solid #238b9f;
	border-radius: 10px;
	padding: 15px 20px;
	margin: 10px 0;
	background: #f8feff;
}
.esp h2{
	color: #238b9f;
}


/* point */
.pointttl{
	float: left;
	margin-bottom: 10px;
}
.point-flex{
	display: flex;
	justify-content: space-around;
	flex-wrap: wrap;
}
.point-box{
	position:relative;
	background: #fff;
	padding-top:50px;
	padding-bottom:50px;
	width: 30%;
	max-width: 240px;
	border: 5px solid #000;
	border-bottom: 8px solid #000;
	border-radius: 10px;
	box-sizing: border-box;
	text-align: center;
}
.point-box img{
	width: 95%;
	max-width: 117px;
}

@media screen and (max-width: 767px) {
	.pointttl{
		float: none;
		text-align: center;
		width: 100%;
	}
	.pointttl img{
		width: 180px;
		height: auto;
		margin-left: auto;
		margin-right: auto;
	}
	.point-flex{
		clear: both;
	}
	.point-box{
		border: 3px solid #000;
		border-bottom: 5px solid #000;
		padding-top: 10px;
		padding-bottom: 10px;
	}
	.point-box img{
		width: 80%;
	}
}


/* 製品情報 */
h3.taxonomy-title{
	border-bottom: 1px dashed #4ab8cc;
	text-align: left;
}

.products-grid{
	margin: 30px auto 10px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	justify-items: center;
}
.products-grid .products-box{
	text-align: center;
	padding: 12px;
	line-height: 1.2em;
	max-width: 300px;
	margin-bottom: 30px;
}
.products-grid .products-box a{
	text-decoration: none;
}
.products-grid .products-box img{
	width: 100%;
	height: auto;
	border: 2px solid #4ab8cc;
	border-radius: 10px;
}
.products-grid .products-box .products-ttl{
	margin: 10px 0 10px;
	font-size: 1.2em;
}
.products-grid .products-box .products-copy{
	text-align: left;
}


/* 製品情報 比較表　*/
.hikaku table{
	font-size: 0.9em;
	border: 1px solid #cacaca !important;
}
.hikaku th{
	border: 1px solid #cacaca !important;
	background: #29a8bf !important;
	color: #fff;
}
.hikaku td{
	border: 1px solid #cacaca !important;
}
.hikaku th a{
	color: #fff;
}

/* 機能を見る */
.func-flex{
	margin: 20px 0 80px;
	display: flex;
	flex-wrap:wrap;
	gap: 6px;
	justify-content: space-between;
}
.func-box{
	position: relative;
	width: calc(50% - 3px);
	gap: 6px;
}
.func-box img{
	width: 100%;
}
.func-box p{
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
	color: #333;
	font-size: 1.2em;
	letter-spacing: 0.1em;
	text-shadow:1px 1px 2px #fff, -1px -1px 2px #fff,
 							-1px 1px 2px #fff, 1px -1px 2px #fff,
              0px 1px 2px #fff,  0-1px 2px #fff,
              -1px 0 2px #fff, 1px 0 2px #fff;
}
.func-box .arrow{
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translate(0,-50%);
}

@media screen and (max-width: 599px) {
	.func-flex{
		flex-direction: column;
	}
	.func-box{
		width: 100%;
	}
}



/* topics */
.contents_topics{
	clear: both;
	padding: 20px 0;
	text-align: center;
	background: #e3e3e5;
}

.topics_itiran{
	float: right;
	padding: 5px 20px;
	background: #fff;
	border: 5px solid #000;
	border-radius: 30px;
}
.topics_itiran a{
	text-decoration: none;
}


.topics{
	margin-top: 50px;
}
.topics table{
	width: 100%;
	border-collapse: separate;
	border-spacing: 8px;
}
.topics table td{
	border-radius: 10px;
	background: #1fb2c9;
	color: #fff;
	padding: 20px 10px;
	width: 130px;
	box-shadow: 0 5px 5px 0 rgba(0, 0, 0, .6);
}
.topics table th{
	border-radius: 10px;
	background: #fff;
	padding: 20px;
	text-align:left;
	text-decoration: normal;
	box-shadow: 0 5px 5px 0 rgba(0, 0, 0, .6);
}
@media screen and (min-width: 600px) {
	.topics table td{
		padding: 20px;
		width: 250px;
	}
}


/* 事例紹介 */
.case-grid{
	margin: 40px auto 20px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(272px, 1fr));
	justify-items: center;
}
.case-grid .case-box{
	text-align: center;
	padding: 2px;
	line-height: 1.2em;
	max-width: 300px;
	margin-bottom: 30px;
}
.case-grid .case-box a{
	text-decoration: none;
}
.case-grid .case-box .case-img{
	border: 5px solid #000;
	border-bottom: 8px solid #000;
	border-radius: 10px;
	overflow:hidden;
	position: relative;
	z-index: 1;
}
.case-grid .case-box .case-img img{
	width: 100%;
	height: auto;
	aspect-ratio: 6 / 5;
	object-fit: cover;
	transition:1s all;
	position: relative;
	z-index: 0;
}
.case-grid .case-box .case-img img:hover{
	transform:scale(1.2,1.2);
}
.case-grid .case-box .case-ttl{
	margin: 10px 0 10px;
	font-size: 1.2em;
}
.case-date{
	font-size: 0.9em;
}



/* 事業内容 */
.p-hover-effect--type1 { overflow: hidden; }
.p-hover-effect--type1:hover img { -webkit-transform: scale(1.2); transform: scale(1.2); }
.p-hover-effect--type1 img { transform: scale(1); transition-duration: 0.75s; vertical-align: middle; }



.formlink {
	margin: 30px auto 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  text-decoration: none;
  color: #ffffff;
	font-size: 1.1em;
  border-radius: 30px;
  width: 250px;
  height: 50px;
  border: 3px solid #ffffff;
  position: relative;
  transition: 0.3s;
  background-color: #ffffff00;
}
.formlink::before, .formlink::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 15px;
  transform-origin: 100% 50%;
  height: 1px;
  width: 11px;
  background-color: #ffffff;
  border-radius: 2px;
  will-change: transform;
  transition: .3s;
}
.formlink::before {
  transform: translateY(-50%) rotate(30deg);
}
.formlink::after {
  transform: translateY(-50%) rotate(-30deg);
}
.formlink:hover::before {
  transform: translate(5px, -50%) rotate(30deg);
}
.formlink:hover::after {
  transform: translate(5px, -50%) rotate(-30deg);
}
.formlink:hover{
	background: #ffffff6e;
		-webkit-transition: all 0.5s ease;
		-moz-transition: all 0.5s ease;
		-o-transition: all 0.5s ease;
		transition: all  0.5s ease;
	color: #fff;
	text-decoration: none;
}



/*---------------------------------------------------------*/
/* コンテンツページ */
/*---------------------------------------------------------*/

.contents_pg{
	margin-top: 50px;
	padding: 90px 0 20px;
	text-align: left;
}

#conh1{
	width: 100%;
	padding: 30px 0;
	background: #e0e1e5;
}
.contents_pg h1{
	max-width: 1100px;
	width: 95%;
	margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
	.contents_pg h1{
		font-size: 1.8em;
	}
}
@media screen and (max-width: 599px) {
	.contents_pg{
		margin-top: -90px;
	}
}

.contents_pg h2{
	clear: both;
	position: relative;
	border-bottom: 3px solid #ddd;
	padding: 10px 0;
	font-size: 1.8em;
	margin-bottom: 20px;
}
.contents_pg h2:before{
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 20%;
	height: 3px;
	content: '';
	background: #4cc1d4;
}
.contents_pg h3{
	position: relative;
	color: white;
	background: #4cc1d4 !important;
	line-height: 1.4;
	padding: 0.5em 0.5em 0.5em 1.8em;
}

.contents_pg h3:before{
	font-family: "Font Awesome 5 Free";
	content: "\f14a";
	font-weight: 900;
	position: absolute;
	left : 0.5em; /*左端からのアイコンまでの距離*/
}

.update{
	font-size: 0.9em;
	color: #888;
	margin-bottom: 10px;
}


.contents-base{
	margin: 50px 0 50px;
	line-height: 2em;
}

.contents-base h4{
	text-align: center;
	color: #0b4392;
	font-weight: bold;
	border: 1px solid #0b4392;
	padding: 8px 5px;
}
.contents-base h5{
	margin-bottom: 20px;
	font-weight: bold;
	border-bottom: 1px dashed #238b9f;
}


/* ボタン */
a.btn-detail {
	background: #4ab8cc;
	border-radius: 3px;
	position: relative;
	display: flex;
	justify-content: space-around;
	align-items: center;
	margin: 5px auto;
	max-width: 280px;
	padding: 10px 20px;
	color: #fff;
	transition: 0.3s ease-in-out;
	text-decoration: none;
}
a.btn-detail:after {
	content: "";
	position: absolute;
	top: 50%;
	bottom: 0;
	right: 2rem;
	font-size: 90%;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: right 0.3s;
	width: 6px;
	height: 6px;
	border-top: solid 2px currentColor;
	border-right: solid 2px currentColor;
	transform: translateY(-50%) rotate(45deg);
}
a.btn-detail:hover {
	background: #eee;
	color: #4ab8cc;
}
a.btn-detail:hover:after {
	right: 1.4rem;
}


a.btn-download {
	background: #eee;
	position: relative;
	display: flex;
	justify-content: space-around;
	align-items: center;
	margin: 10px auto;
	max-width: 500px;
	padding: 10px 20px;
	color: #333;
	transition: 0.3s ease-in-out;
	text-decoration: none;
	border: 1px solid #c4c4c4;
}
a.btn-download:after {
	content: "";
	position: absolute;
	top: 50%;
	bottom: 0;
	right: 2rem;
	font-size: 90%;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: right 0.3s;
	width: 6px;
	height: 6px;
	border-top: solid 2px currentColor;
	border-right: solid 2px currentColor;
	transform: translateY(-50%) rotate(45deg);
}
a.btn-download:hover {
	background: #f4f4f4;
}
a.btn-download:hover:after {
	right: 1.4rem;
}


a.btn-buy {
	background: #264c8e;
	border-radius: 3px;
	position: relative;
	display: flex;
	justify-content: space-around;
	align-items: center;
	margin: 5px 0 5px auto;
	max-width: 280px;
	padding: 10px 20px;
	color: #fff;
	transition: 0.3s ease-in-out;
	text-decoration: none;
}
a.btn-buy:after {
	content: "";
	position: absolute;
	top: 50%;
	bottom: 0;
	right: 2rem;
	font-size: 90%;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: right 0.3s;
	width: 6px;
	height: 6px;
	border-top: solid 2px currentColor;
	border-right: solid 2px currentColor;
	transform: translateY(-50%) rotate(45deg);
}
a.btn-buy:hover {
	background: #eee;
	color: #264c8e;
}
a.btn-buy:hover:after {
	right: 1.4rem;
}


a.btn-con {
	background: #ffffff;
	border-radius: 3px;
	position: relative;
	display: flex;
	justify-content: space-around;
	align-items: center;
	margin: 5px auto 5px;
	max-width: 130px;
	padding: 5px 5px;
	color: #333;
	transition: 0.3s ease-in-out;
	text-decoration: none;
}
a.btn-con:hover {
	background: #29a8bf;
	color: #fff;
}



/* パンくず */
.breadcrumb{
	margin-bottom: 0px;
	font-size: 0.9em;
}
.breadcrumb a{
	text-decoration: none;
}
.breadcrumb span{
	margin-left: 2px;
	margin-right: 2px;
}




/*---------------------------------------------------------*/
/* 事例動画 */
/*---------------------------------------------------------*/

.movie-grid{
	margin: 40px auto 20px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.movie-grid .movie-box{
	text-align: left;
	padding: 12px;
	line-height: 1.4em;
	max-width: 500px;
	border: solid 1px #4ab8cc;
	margin:2px;
}
.movie-box .ttl{
	margin: 8px auto 10px;
	font-size: 1.1em;
}
.movie-box a{
	text-decoration:none;
}
.movie-box img{
	width:100%;
	height: auto;
}
.movie-box .moviecomm{
	margin-top:5px;
	font-size:0.9em;
	line-height:1.2em;
}





/* お問合せ */
.wpcf7-form input, .wpcf7-formt textarea {
  width: 100%;
}
.wpcf7-form {
  font-size: 0.95em;
}
.wpcf7-form br {
  margin-bottom: 5px;
}
.wpcf7-form label {
  width: 100%;
}

div.wpcf7-validation-errors {
  margin: 20px 0px;
  padding: 15px;
}

div.wpcf7-response-output {
  margin: 20px 0px;
}

.hissu{
	color: #ff0000;
	font-size: 0.9em;
	margin-left: 10px;
}
.submit-wrap p{
	margin-top: 50px;
	text-align: center; 
}

.wpcf7-form label {
	width: 100%;
	font-size: 1.2em;
	font-weight: normal;
}

input[type="text"], input[type="email"], input[type="tel"], textarea {
	width: 100%;
	outline:solid 1px #e4e4e4;
}
input[type="submit"] {
	width: 300px;
}

input.brth{
	width: 100px;
}
input.adrs{
	width: 300px;
}

input[type="reset"], input[type="submit"] {
  cursor: pointer;
  background: #4ab8cc;
  border: none;
  display: inline-block;
  color: #FFFFFF;
  letter-spacing: 1px;
  line-height: 1;
  text-align: center;
  padding: 15px 23px 15px 23px;
  box-shadow: 0 -1px 0 0 rgba(0, 0, 0, 0.1) inset;
  margin: 3px 0;
  text-decoration: none;
}

input[type="reset"]:hover, input[type="submit"]:hover{
	opacity: 0.8;
	background: #eee;
	color: #4ab8cc;
	border: none;
}

input[type="button"]:hover, input[type="button"]:focus, input[type="reset"]:hover,
input[type="reset"]:focus, input[type="submit"]:hover, input[type="submit"]:focus,
button:hover, button:focus {
  cursor: pointer;
}

textarea {
  resize: vertical;
}

select {
  max-width: 100%;
  overflow: auto;
  vertical-align: top;
  outline: none;
  border: 1px solid #c7d3ea;
  padding: 10px;
}

textarea:not(.editor-post-title__input),
input[type="date"],
input[type="datetime"],
input[type="datetime-local"],
input[type="email"],
input[type="month"],
input[type="number"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="text"],
input[type="time"],
input[type="url"],
input[type="week"] {
  padding: 10px;
  max-width: 100%;
  border: 0px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  background-color: #fff;
  border-bottom: 1px solid #fff;
  box-sizing: border-box;
}
textarea:not(.editor-post-title__input):focus,
input[type="date"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="email"]:focus,
input[type="month"]:focus,
input[type="number"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="text"]:focus,
input[type="time"]:focus,
input[type="url"]:focus,
input[type="week"]:focus {
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -moz-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  -o-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.12) inset;
  transition: all 0.2s linear;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  border-color: #EBEBEB;
  border-bottom: 1px solid #fff !important;
  background: #fff;
}

button::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input[type="radio"], input[type="checkbox"] {
  margin: 0 ;
}

.wpcf7-spinner {display: block;}
.btn_submit{
	text-align: center;
}

.fmsz100 input[type="text"]{
	width: 100px !important;
}
.fmsz250 input[type="text"]{
	max-width: 250px !important;
}

.wpcf7-list-item input{
	width: 20px;
}
.wpcf7-list-item-label{
	margin-right: 10px;
}

.recap{
	margin-top: 50px;
	text-align: left;
	font-size: 0.8em;
}
.grecaptcha-badge { visibility: hidden; }



/* 個人情報保護方針 */
.privacy_reed{
	padding-bottom: 30px;
}
.privacy_tit{
	padding: 0 0 5px 0;
	font-weight: bold;
  color: #577b3d;
	border-bottom: 1px dotted #999;
}
.privacy_dt{
	padding: 5px 10px 30px 10px;
}




/*---------------------------------------------------------*/
/* 製品情報ページ*/
/*---------------------------------------------------------*/
#products{
}



/*---------------------------------------------------------*/
/* アーカイブページ */
/*---------------------------------------------------------*/

.archive-base{
	text-align: left;
}
.archive-base h1{
  border-bottom: solid 1px black;
}

.acv-cate{
	margin-top: 10px;
	background: #fff;
	line-height: 2em;
}

.archive-grid{
	margin: 80px auto 20px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.archive-grid .archive-box{
	text-align: left;
	padding: 12px;
	line-height: 1.2em;
	max-width: 500px;
	margin-bottom: 30px;
}
.archive-grid .archive-box a{
	text-decoration: none;
}
.archive-grid .archive-box .arc-img{
	overflow:hidden;
	margin-bottom: 10px;
	text-align: center;
	background: #eeeeee;
	padding: 0;
}
.archive-grid .archive-box .arc-img img{
	width: 100%;
	height: 280px;
	object-fit: cover;
	padding: 0;
	transition:1s all;
}
.archive-grid .archive-box .arc-img img:hover{
	transform:scale(1.2,1.2);
}

.archive-txt{
	border-left: 1px solid #8e8e8e;
	padding-left: 10px;
}
.archive-txt .date{
	font-size: 0.8em;
	color: #4e4e4e;
	margin-right: 20px;
}
.archive-txt .category{
	font-size: 0.7em;
	padding: 2px 5px;
	color: #fff;
	background: #4ab8cc;
}
.archives-txt .arcttl{
	margin: 5px 0 5px;
}


nav.navigation{

}
.nav-previous{
	float:left;
}
.nav-next{
	float:right;
}


/*---------------------------------------------------------*/
/* 投稿ページ*/
/*---------------------------------------------------------*/
#main{
	display: flex;
	flex-direction: column;
}

.single-base{
	width: 100%;
	max-width: 800px;
	text-align: left;
}

.single-base h3{
	margin-top: 30px;
	margin-bottom: 15px;
	font-size: 1.2em;
  position: relative;
  padding: 0.6em;
  background: #e6effd;
  border: none;
  border-radius: 7px;
}
.single-base h3:after {
  position: absolute;
  content: '';
  top: 100%;
  left: 30px;
  border: 15px solid transparent;
  border-top: 15px solid #e6effd;
  width: 0;
  height: 0;
}


/*---------------------------------------------------------*/
/* サイドバー */
/*---------------------------------------------------------*/

#side .st-aside {
	padding: 0;
}
@media print, screen and (min-width: 768px) {
	#main{
		display: flex;
		flex-direction: row;
	}
	#side .st-aside {
		margin-left: 20px;
		margin-top: 60px;
		width: 280px;
		padding: 0px;
	}
}


#side .st-aside h2 {
	font-size: 1em;
	color: #27acd9;
	border-bottom: solid 3px #27acd9;
	padding: 10px 0;
}

#side .st-aside li{
	list-style-type:none; margin:0; padding:0;
}
#side .st-aside ul li {
	list-style-type: disc;
	margin: 0px;
	padding: 0px;
	margin-left: 25px;
}
#side .st-aside ul li a{
	text-decoration: none;
}
#side .st-aside .children li {
	padding-left: 10px;
}

#side .st-aside ul li ul li{
	list-style-type: none;
	margin: 0px;

}

#side .st-aside .sub-menu {
	padding-left: 10px;
}

#side .st-aside .side-t {
	font-size: 14px;
	font-weight: bold;
	line-height: 24px;
	margin: 0px;
	padding-top: 10px;
	padding-right: 10px;
	padding-bottom: 10px;
	padding-left: 0px;
}

#side .st-aside #mybox ul li ul li {
	font-size: 14px;
	line-height: 24px;
}



/*media Queries スマートフォンとタブレットサイズ（959px以下）で適応したいCSS - スマホ・タブレット
---------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 959px) {


/*-- ここまで --*/
}

/*media Queries タブレットサイズ（600px～959px）のみで適応したいCSS -タブレットのみ
---------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 600px) and (max-width: 959px) {


/*-- ここまで --*/
}


/*media Queries タブレット（600px）以上で適応したいCSS -タブレット・PC
---------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 600px) {

	.hlogo img{
		width: 328px;
		height: 95px;
	}
	img.alignright {
		float: right;
		margin: 0 0 5px 10px;
	}

	img.alignleft {
		float: left;
		margin: 0 10px 5px 0;
	}

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

	.ft_left{
		float: left;
	}
	.ft_left dl{
		margin-top: 20px;
	}
	.ft_left dt{
		width: 140px;
		float: left;
	}
	.ft_left dd{
		text-align: left;
		margin-left: 170px;
		line-height: 1.8em;
	}

	a.btn-con {
		margin: 5px auto 5px 5px;
	}
	.cart{
		top: 300px;
	}

	.top_ttl h2{
		font-size: 2.5em;
	}

	.contents_topics{
		background: #e3e3e5 url("images/index/topics_bg.jpg") no-repeat top left;
	}

	/*-- ここまで --*/
}

/*media Queries PCサイズ（960px）以上で適応したいCSS - PCのみ
---------------------------------------------------------------------------------------------------*/
@media print, screen and (min-width: 960px) {

	#wrapper {
		overflow:visible; /*グローバルメニューの下層リンクを表示する為*/
		padding:0;
		width:100%;
	}

	.products-grid{
		grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
		justify-items: start;
	}

	.archive-grid .archive-box .rel-img img{
		width: 100%;
		height: auto;
		max-height: 215px;
		object-fit: cover;
		padding: 0;
		transition:1s all;
	}
}



/* ブロックエディタ対策 */
.wp-block-media-text.has-media-on-the-right .wp-block-media-text__content{
	padding-left: 0;
}
.wp-block-gallery.has-nested-images figure.wp-block-image {
  flex-grow: 0;
}

/* ギャラリー */
.wp-block-gallery::after {
    content: "";
    width: calc(50% - var(--wp--style--unstable-gallery-gap, 16px)*0.5);
}
@media (min-width: 600px) {
    .wp-block-gallery::after {
       content: "";
       width: calc(33.33% - var(--wp--style--unstable-gallery-gap, 16px)*0.66667);
    }
}  

