@charset "utf-8";

/*
Theme Name:テンプレート__01
Version: 1.1
Author:エイジェック広報部
Author URI:https://www.agekke.co.jp/
*/
/*============================
固定ページ共通設定
============================*/
/*----- トップ画像 -----*/
.bl_mainVisual {
	text-align: center;
	position: relative;
	overflow: hidden;
	letter-spacing: 0;
}

.bl_mainVisual img {
	height: 400px;
	object-fit: cover;
	width: 100%;
}

.bl_mainVisual::before {
	content: '';
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 2;
	background: #01254538;
}

.bl_mainVisual.hp_filter_none::before,
.co-creation-partner .bl_mainVisual::before {
	content: none;
}

.bl_mainVisual_ttl {
	position: absolute;
	width: 100%;
	top: 50%;
	left: 50%;
	color: #fff;
	z-index: 10;
	transform: translate(-50%, -50%);
	text-align: center;
	letter-spacing: .1em;
}

.bl_mainVisual_ttl .en span {
	font-family: "Akshar", sans-serif;
	font-size: 3.125rem;
	font-weight: 500;
	letter-spacing: .1em;
}

.bl_mainVisual_ttl h1 span {
	font-weight: 500;
	letter-spacing: .15em;
}

.bgextend {
	animation-name: bgextendAnimeBase;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	position: relative;
	overflow: hidden;
	opacity: 0;
	letter-spacing: .1em;
}

@keyframes bgextendAnimeBase {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

.bgappear {
	animation-name: bgextendAnimeSecond;
	animation-duration: 1s;
	animation-delay: 0.6s;
	animation-fill-mode: forwards;
	opacity: 0;
}

@keyframes bgextendAnimeSecond {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

.bgLRextend::before {
	animation-name: bgLRextendAnime;
	animation-duration: 1s;
	animation-fill-mode: forwards;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #fff;
}

@keyframes bgLRextendAnime {
	0% {
		transform-origin: left;
		transform: scaleX(0);
	}

	50% {
		transform-origin: left;
		transform: scaleX(1);
	}

	50.001% {
		transform-origin: right;
	}

	100% {
		transform-origin: right;
		transform: scaleX(0);
	}
}

@media screen and (max-width: 1023px) {
	.bl_mainVisual_ttl h1 span {
		font-size: 1.75rem;
	}
}

@media screen and (max-width: 767px) {
	.bl_mainVisual img {
		height: 100%;
		object-fit: none;
	}

	.bl_mainVisual_ttl .en span {
		font-size: 2rem;
		line-height: 1;
	}

	.bl_mainVisual_ttl .en {
		margin: 10px 0 0;
	}

	.bl_mainVisual_ttl h1 span {
		font-size: 1rem;
	}
}

/*----- パンくず -----*/
.bl_bread {
	padding: 10px 0 3px;
}

.bl_bread ul {
	margin: 0 auto;
	letter-spacing: .1em;
}

.bl_bread li {
	display: inline;
}

.bl_bread li a,
.bl_bread li {
	color: #333;
	letter-spacing: .1em;
	font-size: .875rem;
}

.bl_bread li a {
	border-bottom: 1px solid #0075c4;
}

.bl_bread li a:hover {
	text-decoration: underline;
}

@media screen and (max-width: 767px) {

	.bl_bread li a,
	.bl_bread li {
		font-size: .75rem;
	}
}

/*============================
事業内容
============================*/
.bl_pageNav_box {
	text-align: center;
	padding: 50px 0 70px;
}

.bl_pageNav_box li {
	display: inline-block;
	width: calc(25% - 15px);
	margin: 0 20px 20px 0;
}

.bl_pageNav_box li:nth-child(4),
.bl_pageNav_box li:last-child {
	margin: 0;
}

.bl_pageNav_box li a {
	display: block;
	text-align: center;
	padding: 12px;
	border: 1px solid #0075c4;
	border-radius: 30px;
	color: #0075c4;
	position: relative;
	font-size: .875rem;
}

.bl_pageNav_box li a:hover {
	background: #0075c4;
	color: #fff;
}

.bl_pageNav_box li a:before {
	content: '';
	width: 20px;
	height: 20px;
	background: #0075c4;
	border-radius: 20px;
	position: absolute;
	top: 50%;
	right: 12px;
	transform: translateY(-50%);
}

.bl_pageNav_box li a::after {
	font-family: FontAwesome;
	content: '\f107';
	font-size: .875rem;
	color: #fff;
	position: absolute;
	top: 50%;
	right: 17px;
	transform: translateY(-10px);
	color: #fff;
}

.bl_pageNav_box li a:hover::before {
	background: #fff;
}

.bl_pageNav_box li a:hover::after {
	color: #0075c4;
}

.bl_businessArea_box {
	display: grid;
	grid-template-columns: 56% 1fr;
	gap: 50px;
}

.bl_businessArea_desc {
	line-height: 1.9;
}

.bl_service {
	position: relative;
	background-image: url(images/bg_service.jpg);
	background-position: center center;
	background-repeat: no-repeat;
	-webkit-background-size: cover;
	background-size: cover;
}

.bl_service .el_lv2Heading {
	position: absolute;
	top: -23px;
	left: 50%;
	transform: translateX(-50%);
}

.bl_service_box {
	display: flex;
}

.bl_service_box,
.bl_service_bigBox {
	width: 100%;
	background: #fff;
	padding: 60px;
	margin: 0 0 60px;
}

.bl_service_cont .bl_service_bigBox:last-child {
	margin: 0;
}

.bl_service_box .bl_service_img,
.bl_service_box .bl_service_txt {
	width: calc(50% - 20px);
}

.bl_service_cont .bl_service_box:nth-child(odd) {
	flex-direction: row-reverse;
}

.bl_service_cont .bl_service_box:nth-child(odd) .bl_service_img,
.bl_service_cont .bl_service_box:nth-child(even) .bl_service_txt {
	margin-right: 20px;
}

.bl_service_cont .bl_service_box:nth-child(odd) .bl_service_txt,
.bl_service_cont .bl_service_box:nth-child(even) .bl_service_img {
	margin-left: 20px;
}

.bl_service_ttl_en {
	font-size: .875rem;
	color: #0075c4;
}

.bl_service_txt h3 {
	font-size: 1.75rem;
	color: #0075c4;
	margin: 0 0 34px;
	font-weight: 600;
	position: relative;
}

.bl_service_txt h3:after {
	content: '';
	width: 20px;
	height: 1px;
	position: absolute;
	left: 0;
	bottom: -15px;
	background: #0075c4;
}

.bl_service_desc {
	line-height: 1.7;
}

.bl_service_bigBox_cont {
	margin: 30px 0 0;
}

.bl_elec_merit {
	border: 1px solid #0075c4;
	padding: 50px 40px 40px;
	position: relative;
	z-index: 0;
	margin: 70px 0 0;
}

.bl_elec_merit h4 {
	position: absolute;
	top: -20px;
	left: 0;
	text-align: center;
	width: 100%;
}

.bl_elec_merit h4 span {
	position: relative;
	padding: 0 40px;
	background: #fff;
	color: #0075c4;
	font-weight: 600;
	font-size: 1.5rem;
	display: inline-block;
}

.bl_elec_merit h4 span:before {
	content: '';
	width: 1px;
	height: 28px;
	background: #0075c4;
	transform: rotate(-30deg);
	position: absolute;
	top: 3px;
	left: 20px;
}

.bl_elec_merit h4 span:after {
	content: '';
	width: 1px;
	height: 28px;
	background: #0075c4;
	transform: rotate(30deg);
	position: absolute;
	top: 3px;
	right: 20px;
}

.bl_elec_merit_box {
	text-align: center;
	margin: 10px 0 0;
}

.bl_elec_merit_box li {
	display: inline-block;
	padding: 0 15px;
}

.bl_elec_merit_item p img {
	margin: 0 7px 2px 0;
	width: 20px;
}

.bl_elec_merit_desc {
	text-align: center;
	margin: 40px 0 0;
	color: #0075c4;
	font-weight: 600;
	font-size: 1.25rem;
}

.bl_elec_flow {
	margin: 50px 0 0;
}

.bl_elec_flow h4,
.bl_elec_plan h4 {
	padding: 5px 0 5px 10px;
	border-left: 4px solid #0075c4;
	color: #0075c4;
	7 font-size: 1.25rem;
	font-weight: 600;
}

.bl_elec_flow_box {
	position: relative;
	margin: 50px 0 0;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 30px;
	z-index: 0;
}

.bl_elec_flow_box:after {
	content: '';
	position: absolute;
	top: 50%;
	left: 10%;
	transform: translateY(-50%);
	width: 80%;
	height: 5px;
	background: #0075c4;
	z-index: -1;
}

.bl_elec_flow_box li {
	position: relative;
	border: 1px solid #0075c4;
	border-radius: 20px;
	padding: 45px 20px 20px 20px;
	text-align: center;
	background: #fff;
	z-index: 0;
}

.bl_elec_flow_num {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
}

.bl_elec_flow_num p {
	position: relative;
	text-align: center;
	z-index: 0;
	font-family: "Akshar", sans-serif;
	font-size: .875rem;
	color: #0075c4;
	font-weight: 500;
}

.bl_elec_flow_num p:before {
	content: '';
	width: 70px;
	height: 70px;
	clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
	background: #e8f7ff;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: -1;
}

.bl_elec_flow_num p span {
	display: block;
	font-size: 2.125rem;
	line-height: 1;
	font-weight: 600;
}

.bl_elec_flow_box h5 {
	color: #0075c4;
	font-weight: 600;
	font-size: 1.125rem;
	margin: 0 0 15px;
}

.bl_elec_flow_desc {
	font-size: .9375rem;
	margin: 15px 0 0;
}

.bl_elec_flow_desc.hp_oneLine {
	margin: 28px 0 0;
}

.bl_elec_about {
	background: #f8f8f8;
	padding: 40px;
	margin: 50px 0 0;
}

.bl_elec_solarPower_box {
	display: grid;
	grid-template-columns: 54% 1fr;
	gap: 40px;
}

.bl_elec_solarPower_box h4,
.bl_elec_ppa h4 {
	color: #0075c4;
	font-weight: 600;
	font-size: 1.125rem;
	margin: 0 0 15px;
}

.bl_elec_ppa {
	margin: 50px 0 0;
}

.bl_elec_solarPower_desc,
.bl_elec_ppa_desc {
	line-height: 1.75;
}

.bl_elec_ppa_table {
	margin: 30px 0 0;
}

.bl_elec_ppa_table table tr th,
.bl_elec_ppa_table table tr td {
	padding: 15px;
	vertical-align: middle;
}

.bl_elec_ppa_table table tr th:not(:nth-of-type(1)) {
	color: #fff;
	border-right: #ebe8e8 1px solid;
}

.bl_elec_ppa_table table tr th:nth-of-type(2) {
	background: #0075C499;
}

.bl_elec_ppa_table table tr th:nth-of-type(3) {
	background: #0075C4cc;
}

.bl_elec_ppa_table table tr th:nth-of-type(4) {
	background: #0075C4;
}

.bl_elec_ppa_table table tr td {
	background: #fff;
	border-right: #ebe8e8 1px solid;
	border-bottom: #ebe8e8 1px solid;
}

.bl_elec_ppa_table table tr:nth-of-type(3) td,
.bl_elec_ppa_table table tr:nth-of-type(5) td {
	background: #e5f6ff66;
}

.bl_elec_ppa_table table tr td:last-of-type {
	border-right: none;
}

.bl_elec_ppa_table table.hp_one th:nth-of-type(1) {
	width: 19%;
}

.bl_elec_ppa_table table.hp_one th:nth-of-type(2),
.bl_elec_ppa_table table.hp_one th:nth-of-type(3),
.bl_elec_ppa_table table.hp_one th:nth-of-type(4) {
	width: 27%;
}

.bl_elec_ppa_table table.hp_one {
	text-align: center;
}

.bl_elec_ppa_table table.hp_two {
	margin: 30px 0 0;
}

.bl_elec_ppa_table table.hp_two th:nth-of-type(1) {
	width: 19%;
	text-align: center;
}

.bl_elec_ppa_table table.hp_two th:nth-of-type(2),
.bl_elec_ppa_table table.hp_two th:nth-of-type(3) {
	width: 40.5%;
	text-align: center;
}

.bl_elec_ppa_table table.hp_two tr td:nth-of-type(1) {
	text-align: center;
}

.bl_elec_ppa_table table.hp_two tr td:nth-of-type(2) p,
.bl_elec_ppa_table table.hp_two tr td:nth-of-type(3) p {
	font-size: .9375rem;
	line-height: 1.75;
}

.bl_elec_ppa_table table.hp_two tr:nth-of-type(3) th,
.bl_elec_ppa_table table.hp_two tr:nth-of-type(3) td {
	padding: 28px 15px;
}

.bl_elec_plan {
	margin: 50px 0 0;
}

.bl_elec_plan_box {
	margin: 20px auto 0;
	background: #e8f7ff;
	padding: 40px 60px;
}

.bl_elec_plan_box ul {
	display: grid;
	grid-template-columns: 40% 1fr;
	gap: 20px 0;
}

.bl_elec_plan_box ul li p img {
	margin: 0 7px 2px 0;
	width: 20px;
}

.bl_elec_plan_box ul li p span {
	font-weight: 600;
}

.bl_elec_plan_case {
	margin: 60px 0 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 40px;
}

.bl_elec_plan_caseBox {
	position: relative;
	padding: 40px;
	border: 5px solid #0075c433;
	border-radius: 20px;
	background: #fff;
}

.bl_elec_plan_caseNum {
	position: absolute;
	top: -18px;
	left: 50%;
	transform: translateX(-50%);
	text-align: center;
}

.bl_elec_plan_caseNum span {
	padding: 7px 15px;
	color: #fff;
	background: #0075c4;
	border-radius: 23px;
	line-height: 1;
	display: inline-block;
	font-weight: bold;
}

.bl_businessMatch_cont {
	margin: 50px 0 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 60px;
	padding: 80px;
	border: 1px solid #ebe8e8;
}

.bl_businessMatch_list li img {
  margin: 0 7px 2px 0;
  width: 20px;
}

.bl_businessMatch_list {
	background: #f8f8f8;
	padding: 40px 30px;
}

.bl_businessMatch_list li:not(:last-child){
	margin: 0 0 20px;
}

.bl_businessMatch_list li {
	font-size: .9375rem;
	font-weight: bold;
}

@media screen and (max-width: 1279px) {
	.bl_service_box, .bl_service_bigBox {
  	padding: 40px;
  	margin: 0 0 40px;
	}
	
	.bl_businessMatch_cont {
    margin: 40px 0 0;
    gap: 40px;
    padding: 40px;
	}
}

@media screen and (max-width: 1023px) {
	.bl_service_box, .bl_service_bigBox {
  	display: block;
	}
	
	.bl_service_box .bl_service_img,
	.bl_service_box .bl_service_txt {
    width: 100%;
	}
	
	.bl_service_img {
		margin: 0 !important;
	}
	
	.bl_service_txt {
		margin: 0 0 20px !important;
	}
	
	.bl_elec_merit {
    padding: 40px 30px 30px;
    margin: 50px 0 0;
	}
	
	.bl_elec_merit_desc {
    margin: 24px 0 0;
	}
	
	.bl_service .el_lv2Heading {
  	top: -17px;
	}
	
	.bl_service_box, .bl_service_bigBox {
		padding: 30px 20px;
		margin: 0 0 15px;
   }
	 
	.bl_service_txt h3 {
		font-size: 1.25rem;
    margin: 0 0 30px;
	}
	
	.bl_elec_flow_box h5 {
    font-size: 1rem;
	}
	
	.bl_elec_flow_box {
    margin: 40px 0 0;
    gap: 10px;
	}
	
	.bl_elec_flow_box li {
    padding: 45px 10px 20px 10px;
	}
	
	.bl_elec_flow_desc {
    font-size: .875rem;
	}
	
	.bl_elec_solarPower_box {
    display: block;
	}
	
	.bl_elec_solarPower_item img {
		display: block;
		margin: 30px 0 0;
	}
	
	.bl_elec_plan_box {
    padding: 30px;
	}
	
	.bl_elec_plan_box ul {
    display: block;
	}
	
	.bl_elec_plan_box ul li:not(:last-child){
		margin: 0 0 8px;
	}
	
	.bl_businessMatch_cont {
    margin: 20px 0 0;
    gap: 20px;
    padding: 20px;
	}
	
	.bl_elec_plan_case {
    margin: 40px 0 0;
    gap: 20px;
	}
}

@media screen and (max-width: 767px) {
	.bl_elec_merit h4 span {
    padding: 0 20px 0 24px;
    font-size: 1rem;
	}
	
	.bl_elec_merit h4 span:before {
    left: 9px;
	}
	
	.bl_elec_merit h4 span:after {
    	right: 10px;
	}
	
	.bl_elec_merit_box {
    text-align: left;
	}
	
	.bl_elec_merit {
    padding: 40px 10px 30px;
   	margin: 40px 0 0;
    }
		
	.bl_elec_merit_item p img {
    margin: 0 7px 4px 0;
    width: 16px;
	}
	
	.bl_elec_merit_desc {
    margin: 17px 0 0;
		font-size: 1rem;
   }
	 
	.bl_elec_flow_box {
		display: block;
	}
	
	.bl_elec_flow_img {
		max-width: 120px;
		margin: 0 auto;
	}
	
	.bl_elec_flow_num p:before {
    width: 50px;
    height: 50px;
	}
	
	.bl_elec_flow_num p span {
    font-size: 1.5rem;
	}
	
	.bl_elec_flow_box li {
  	padding: 35px 10px 20px 10px;
		margin: 0 0 40px;
   }
	 
	.bl_elec_flow_box li:last-child {
		margin: 0;
	}
	 
	.bl_elec_flow_box:after {
		top: 10%;
    left: 50%;
    transform: translateX(-50%);
    width: 5px;
    height: 80%;
	}
	
	.bl_elec_about {
    padding: 20px;
    margin: 30px 0 0;
	}
	
	.bl_elec_solarPower_item img {
		margin: 20px 0 0;
	}
	
	.bl_tableWrap {
    overflow-x: scroll;
  }
		
	.bl_tableWrap table {
    min-width: 700px;
  }
	
	.bl_elec_plan {
    margin: 20px 0 0;
	}
	
	.bl_elec_plan_box {
    padding: 14px;
  }
	
	.bl_elec_plan_box ul li p img {
    margin: 0 7px 3px 0;
    width: 16px;
	}
	
	.bl_elec_plan_box ul li p span {
    font-size: .875rem;
	}
	
	.bl_businessMatch_cont {
		display: block;
		padding: 30px 20px;
	}
	
	.bl_businessMatch_list {
    padding: 20px 14px;
    margin: 30px 0 0;
	}
}

/* ----- お問い合わせ -----*/
.bl_topContact_cont {
	max-width: 900px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 60px;
	color: #0075c4;
}

.bl_topContact_desc {
	text-align: center;
	margin: 0 0 40px;
}

.bl_topContact_box {
	text-align: center;
	border: 1px solid #0075c4;
}

.bl_topContact_box p {
	padding: 30px 12px;
}

.bl_topContact_box .num {
	font-size: 2rem;
	font-weight: bold;
}

.bl_topContact_box .txt {
	font-size: 1.375rem;
	font-weight: bold;
}

.bl_topContact_box span {
	display: inline-block;
	vertical-align: middle;
}

.bl_topContact_box.tel .icon {
	width: 30px;
	margin: 4px 15px 0 0;
}

.bl_topContact_box.mail .icon {
	width: 32px;
	margin: 0 15px 0 0;
}

.bl_topContact_box.mail p {
	margin: 8px 0 0;
}

.bl_topContact_box.mail:hover {
	background: #00a1e9;
}

.bl_topContact_box.mail:hover p {
	color: #fff;
}

@media screen and (max-width: 1023px) {
	.bl_topContact_cont {
		gap: 20px;
	}
}


@media screen and (max-width: 767px) {
	.bl_pageNav_box {
		padding: 10px 0 30px;
	}

	.bl_pageNav_box li {
		display: block;
		width: 100%;
		margin: 0 0 10px !important;
	}

	.bl_pageNav_box li a {
		padding: 8px;
		font-size: .9375rem;
	}

	.bl_businessArea_box {
		display: block;
	}

	.bl_businessArea .el_lv2Heading.el_lv2Heading__left {
		text-align: center;
	}

	.bl_businessArea .el_lv2Heading.el_lv2Heading__left .ja {
		margin-left: 0;
	}

	.bl_topContact_cont {
		display: block;
	}

	.bl_topContact_desc {
		text-align: left;
		margin: 0 0 30px;
	}

	.bl_topContact_box.tel {
		margin: 0 0 20px;
		padding: 28.5px 12px;
	}

	.bl_topContact_box.tel .icon {
		width: 25px;
	}

	.bl_topContact_box .num {
		font-size: 1.5rem;
	}
}

/*============================
会社概要
============================*/
.bl_companyInfo table {
	max-width: 900px;
	margin: 0 auto;
}

.bl_companyInfo table th,
.bl_companyInfo table td {
	box-sizing: border-box;
	display: inline-block;
	vertical-align: top;
}

.bl_companyInfo table {
	border-top: 1px solid #e2e2e2;
	line-height: 1.7;
}

.bl_companyInfo table tr {
	border-bottom: 1px solid #e2e2e2;
}


.bl_companyInfo table th {
	width: 25%;
	color: #0075c4;
	font-weight: normal;
	padding: 26px 0;
}

.bl_companyInfo table td {
	width: 75%;
	padding: 26px 0 26px 13px;
}

.bl_companyInfo_map {
	display: grid;
	grid-template-columns: 1fr 150px;
	gap: 26px;
	margin: 26px 0 0;
}

.bl_companyInfo_appearance p {
	font-size: .875rem;
	text-align: center;
	margin: 5px 0 0;
}

.bl_companyInfo_common li:not(:last-child) {
	margin: 0 0 8px;
}

.bl_companyInfo_common a {
	position: relative;
	padding: 0 0 3px;
	margin: 0 0 0 16px;
	border-bottom: #0075c4 1px solid;
	color: #0075c4;
}

.bl_companyInfo_common a:before {
	font-family: FontAwesome;
	content: '\f105';
	color: #0075c4;
	position: absolute;
	top: 0;
	left: -20px;
}

.bl_history {
	background: #f8f8f8;
}

.bl_history_cont {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: 50px;
	max-width: 900px;
	margin: 0 auto;
}

.bl_history_timeline table th,
.bl_history_timeline table td {
	box-sizing: border-box;
	display: inline-block;
	vertical-align: top;
}

.bl_history_timeline table th {
	width: 25%;
	color: #0075c4;
	font-weight: normal;
	padding: 26px 0;
}

.bl_history_timeline table td {
	width: 75%;
	padding: 26px 0 26px 13px;
}

.bl_history_timeline table {
	border-top: 1px solid #e2e2e2;
}

.bl_history_timeline table tr {
	border-bottom: 1px solid #e2e2e2;
}

.bl_history_month {
	display: block;
	color: #0075c4;
	margin: 0 0 3px;
}

.bl_history_timeline table td p:not(:first-of-type) {
	margin: 12px 0 0;
}

.bl_history_img.hp_mo {
	display: none;
}

@media screen and (max-width: 1023px) {
	.bl_companyInfo table th {
		width: 15%;
	}

	.bl_history_timeline table td {
		width: 85%;
	}

	.bl_history_cont {
		grid-template-columns: 1fr 180px;
		gap: 30px;
	}
}

@media screen and (max-width: 767px) {
	.bl_history_cont {
		display: block;
		position: relative;
	}

	.bl_history_img.hp_pc {
		position: absolute;
		max-width: 200px;
		top: 20px;
		right: 20px;
	}

	.bl_history_timeline table th,
	.bl_history_timeline table td,
	.bl_companyInfo table th,
	.bl_companyInfo table td {
		display: block;
		width: 100%;
		padding: 0;
	}

	.bl_companyInfo table th {
		padding: 20px 0 5px;
	}

	.bl_history_timeline table th {
		padding: 20px 0;
		font-size: 1.25rem;
	}

	.bl_companyInfo table td,
	.bl_history_timeline table td {
		padding: 0 0 20px;
	}

	.bl_companyInfo_map {
		display: block;
	}

	.bl_companyInfo_appearance {
		margin: 10px 0 0;
	}

	.bl_companyInfo_appearance p {
		font-size: 1rem;
	}
}

/*============================
お知らせ一覧
============================*/
.bl_archiveNews {
	padding: 60px 0;
}

.bl_newsCont {
	padding: 20px 40px;
 	background: #e8f7ff;
	margin: 0 0 10px;
}

.bl_newsCont_box {
	display: grid;
	grid-template-columns: 120px 1fr;
	align-items: center;
}

.bl_newsCont_ttl h2 {
	font-weight: 600;
	font-size: 1.125rem;
}

.bl_newsCont_date {
	font-family: "Akshar", sans-serif;
	line-height: 1;
	margin: 3px 0 0;
  color: #0075c4;
}

.bl_newsCont_date p {
	letter-spacing: .15em;
}


.bl_archiveNews a:hover h2,
.bl_archiveNews a:hover {
	color: #0075c4;
}

@media screen and (max-width: 767px) {
	.bl_archiveNews {
    	padding: 30px 0;
	}
	
	.bl_newsCont_box {
		display: block;
	}

	.bl_newsCont_date {
		margin: 0 0 2px;
	}
	
	.bl_newsCont {
		padding: 20px 15px 17px;
	}
	
	.bl_newsCont_ttl h2 {
    font-size: 1.0625rem;
	}
}

/*============================
お知らせ　個別ページ
============================*/
.bl_singleNews {
	padding: 60px 0;
}

.bl_singleNews .ly_wrap {
	max-width: 900px;
}

.bl_singleNews_date {
	font-family: "Akshar", sans-serif;
	letter-spacing: .1em;
}

.bl_singleNews_ttl {
	font-size: 1.75rem;
	padding: 0 0 30px;
	font-weight: 600;
}

.bl_paragraph {
	margin: 20px 0 0;
}

.bl_singleNews_txt p {
	line-height: 1.8;
}

.bl_singleNews_nav {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 50px;
	margin: 60px 0 0;
}

.bl_singleNews_nav .el_more {
	text-align: center;
}

.bl_singleNews_nav .el_more a span {
	font-family: "Noto Sans JP", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ",
		sans-serif;
}

@media screen and (max-width: 767px) {
	.bl_singleNews {
		padding: 30px 0 40px;
	}

	.bl_singleNews_ttl {
		font-size: 1.25rem;
		padding: 0 0 10px;
	}

	.bl_singleNews_nav {
		gap: 10px;
		margin: 40px 0 0;
	}

	.bl_singleNews_nav .el_more a span:after,
	.bl_singleNews_nav .el_more a:hover span:after {
		content: none;
	}

	.bl_singleNews_nav .el_more a span {
		background: #0075c4;
		color: #fff;
		padding: 15px 5px;
		display: block;
		text-align: center;
		margin: 0;
		border-radius: 10px;
		font-size: .75rem;
		letter-spacing: .05em;
	}
}

/*============================
実績紹介　個別ページ
============================*/
.el_bg__gray {
	background: #f8f8f8;
}

.el_circle {
	position: relative;
	padding-left: 20px;
	letter-spacing: .05em;
}

.el_circle::before {
	position: absolute;
	z-index: 2;
	content: '';
	width: 8px;
	height: 8px;
	top: 8px;
	left: 0;
	background: #949494;
	border-radius: 5px;
}

.bl_case_top_cont {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 60px;
}

.bl_case_top_ttl h2 {
	margin: 10px 0 40px;
	font-size: 1.5rem;
	font-weight: 700;
	color: #0075c4;
}

.bl_case_top_txt {
	margin: 12px 0 0;
}

.bl_case_top_desc {
	line-height: 1.8;
	letter-spacing: .1em;
}

.bl_case_top_ctgr span {
	display: inline-block;
	line-height: 1;
	padding: 5px 11px 6px 11px;
	background: #f0f0f0;
	font-weight: bold;
	letter-spacing: .1em;
}

.bl_case_top_ctgr span:not(:first-of-type) {
	margin-left: 10px;
}

.bl_case_top_note {
	font-size: .875rem;
	margin: 10px 0 0;
	text-align: center;
}

.bl_works_nav {
	background-image: -webkit-gradient(linear, left top, right top, from(#1799c2), to(#1460D1));
	background-image: linear-gradient(to right, #1799c2 0%, #1460D1 100%);
}

.bl_works_nav_cont {
	max-width: 900px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 60px;
}

@media screen and (max-width: 1023px) {
	.bl_case_top_cont {
    	gap: 30px;
	}
	
	.bl_case_top_ttl h2 {
    margin: 14px 0 10px;
    font-size: 1.375rem;
	}
}

@media screen and (max-width: 767px) {
	.bl_case_top_cont {
    display: block;
	}
	
	.bl_case_top_desc {
		margin: 0 0 20px;
	}
	
	.bl_works_nav_cont {
    gap: 20px;
	}
}
/*----- 物流DX改革プロジェクト -----*/

.bl_LogiPro_task_box {
	display: grid;
	grid-template-columns: 740px 1fr;
	gap: 40px;
}

.bl_LogiPro_task_item h2 {
	display: inline-block;
	padding: 10px 40px;
	font-size: 1.25rem;
	color: #fff;
	margin: 0 0 24px;
	background: #0075c4;
	border-radius: 28px;
	font-weight: 600;
}

.bl_LogiPro_task_item p {
	font-size: .9375rem;
  line-height: 1.7;
}

.bl_LogiPro_task_item p:not(:first-of-type) {
	margin: 10px 0 0;
}

.bl_LogiPro_task_img {
	margin: -20px 0 0;
}

.bl_LogiPro_effect_box {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 40px;
}

.bl_LogiPro_effect_item li {
	display: inline-block;
	vertical-align: middle;
}

.bl_LogiPro_effect_item li:nth-child(1) {
	width: 100px;
}

.bl_LogiPro_effect_item li:nth-child(2) {
	width: calc(60% - 50px);
}

.bl_LogiPro_effect_item li:nth-child(3) {
	width: calc(40% - 50px);
}

.bl_LogiPro_effect {
	background: #fff;
	padding: 80px 40px 40px;
	position: relative;
	margin: 70px 0 0;
}

.bl_LogiPro_effect h2 {
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
	width:100%;
	text-align: center;
}

.bl_LogiPro_effect h2 span {
	position: relative;
	font-size: 1.25rem;
	font-weight: 500;
}

.bl_LogiPro_effect h2 span:before {
	position: absolute;
	top: -20px;
	left: -34px;
	content: '[';
	font-size: 2.5rem;
	font-weight: 100;
}

.bl_LogiPro_effect h2 span:after {
	position: absolute;
	top: -20px;
	right: -34px;
	content: ']';
	font-size: 2.5rem;
	font-weight: 100;
}

.bl_LogiPro_num {
	position: relative;
	text-align: center;
	z-index: 0;
	font-family: "Akshar", sans-serif;
	font-size: .875rem;
	color: #0075c4;
	font-weight: 500;
}

.bl_LogiPro_num span {
	display: block;
	font-size: 2.125rem;
	line-height: 1;
	font-weight: 600;
}

.bl_LogiPro_num:before {
	content: '';
	width: 70px;
	height: 70px;
	clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
	background: #e8f7ff;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: -1;
}

.bl_LogiPro_effect_item li h3 {
	color: #0075c4;
	font-weight: 600;
	line-height: 1.8;
}

.bl_LogiPro_effect_item li .hp_note {
	font-size: .875rem;
	margin: 6px 0 0;
}

.bl_LogiPro_support {
	border: 1px solid #0075c4;
	padding: 50px 40px 40px;
	position: relative;
	z-index: 0;
	margin: 70px 0 0;
}

.bl_LogiPro_support h3 {
	position: absolute;
	top: -20px;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
  text-align: center;
}

.bl_LogiPro_support h3 span {
	position: relative;
	padding: 0 40px;
	background: #fff;
	color: #0075c4;
	font-weight: 600;
	font-size: 1.5rem;
}

.bl_LogiPro_support h3 span:before {
	content: '';
	width: 1px;
	height: 28px;
	background: #0075c4;
	transform: rotate(-30deg);
	position: absolute;
	top: 3px;
	left: 20px;
}

.bl_LogiPro_support h3 span:after {
	content: '';
	width: 1px;
	height: 28px;
	background: #0075c4;
	transform: rotate(30deg);
	position: absolute;
	top: 3px;
	right: 20px;
}

.bl_LogiPro_support h4 {
	color: #0075c4;
	font-weight: 600;
	font-size: 1.125rem;
	margin: 0 0 16px;
}

.bl_LogiPro_support_box {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 40px;
}

.bl_LogiPro_support_item p {
	position: relative;
	padding: 0 0 0 28px;
}

.bl_LogiPro_support_item p:before {
	content: url(images/icon-checkbox.png);
	position: absolute;
	top: 3px;
	left: 0;
}

.bl_LogiPro_after {
	padding: 50px 0;
	text-align: center;
}

.bl_LogiPro_after p span {
	display: inline-block;
}

.bl_LogiPro_after .hp_ttl {
	border: 1px solid #0075c4;
	border-radius: 50px;
	margin: 0 20px 0 0;
	width: 70px;
	height: 70px;
	color: #0075c4;
	line-height: 70px;
	font-size: 1.125rem;
	font-weight: 600;
}

.bl_LogiPro_after .hp_desc {
	position: relative;
	font-weight: 600;
	letter-spacing: .1em;
	z-index: 0;
	font-size: 1.25rem;
}

.bl_LogiPro_after .hp_desc::before {
	height: 15px;
	background: #94fbff80;
	content: "";
	position: absolute;
	top: 14px;
	left: 0;
	width: 100%;
	z-index: -1;
}

.bl_LogiPro_flow {
	background: #fff;
	padding: 40px;
}

.bl_LogiPro_flow_now {
	background: #f8f8f8;
	position: relative;
}

.bl_LogiPro_flow_future {
	background: #e8f7ff;
	position: relative;
	margin: 40px 0 0;
}

.bl_LogiPro_flow_cont {
	position: relative;
	display: grid;
	padding: 30px;
}

.bl_LogiPro_flow_item img {
	display: block;
	margin: 0 auto;
	max-width: 114px;
}

.bl_LogiPro_flow_now .bl_LogiPro_flow_cont {
	grid-template-columns: repeat(6, 1fr);
}

.bl_LogiPro_flow_future .bl_LogiPro_flow_cont {
	grid-template-columns: repeat(5, 1fr);
}

.bl_LogiPro_flow_box h2 {
	display: inline-block;
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
	padding: 5px 15px 5px 15px;
	color: #fff;
	font-weight: 600;
}

.bl_LogiPro_flow_now h2 {
	background: #909090;
}

.bl_LogiPro_flow_future h2 {
	background: #0075c4;
}

.bl_LogiPro_flow_item {
	position: relative;
	text-align: center;
}

.bl_LogiPro_flow_item:after {
	position: absolute;
	content: '';
	width: 12px;
	height: 12px;
	background: #0075c4;
	clip-path: polygon(0 0, 0% 100%, 100% 50%);
	top: 40%;
	right: -7px;
}

.bl_LogiPro_flow_box .bl_LogiPro_flow_item:last-of-type:after {
	content: none !important;
}

.bl_LogiPro_flow_item h3 {
	font-size: .875rem;
}

.bl_LogiPro_flow_future_desc {
	padding: 50px 0 10px;
	text-align: center;
}

.bl_LogiPro_flow_future_desc span {
	color: #0075c4;
}

.hp_postscript {
	position: absolute;
	top: -18px;
	left: 50%;
	transform: translateX(-50%);
}

.bl_LogiPro_flow_item .hp_postscript img {
	max-width: 130px;
}

@media screen and (max-width: 1023px) {
	.bl_LogiPro_effect {
    padding: 50px 20px 30px;
	}
	
	.bl_LogiPro_effect_item li:nth-child(1) {
    width: 80px;
	}
	
	.bl_LogiPro_effect_item li:nth-child(2) {
    width: calc(100% - 100px);
    margin: 0 0 0 20px;
	}
	
	.bl_LogiPro_effect_item li:nth-child(3) {
    display: none;
	}
	
	.bl_LogiPro_support h3 span {
    font-size: 1.25rem;
	}
	
	.bl_LogiPro_support {
    padding: 30px;
    margin: 50px 0 0;
	}
	
	.bl_LogiPro_flow_item img {
    max-width: 100%;
	}
	
	.bl_LogiPro_flow_now .bl_LogiPro_flow_cont,
	.bl_LogiPro_flow_future .bl_LogiPro_flow_cont {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px 70px;
	}
	
	.bl_LogiPro_flow_item:after {
    width: 15px;
    height: 15px;
    right: -40px;
	}
	
	.bl_LogiPro_flow_cont	.bl_LogiPro_flow_item:nth-of-type(3):after {
    right: -23px;	
	}
	
	.bl_LogiPro_after .hp_ttl {
    display: block;
    margin: 0 auto 25px;
    width: 90px;
    height: 90px;
    line-height: 90px;
	}
	
	.bl_LogiPro_after .hp_desc {
		display: block;
	}
}

@media screen and (max-width: 767px) {
	.bl_LogiPro_task_box {
    display: block;
	}
	
	.bl_LogiPro_task_img {
		display: none;
	}
	
	.bl_LogiPro_effect h2 span {
    font-size: 1.125rem;
	}
	
	.bl_LogiPro_effect_box {
    display: block;
	}
	
	.bl_LogiPro_effect {
    padding: 30px 20px 30px;
  }
	
	.bl_LogiPro_effect_box .bl_LogiPro_effect_item:first-of-type {
		margin: 0 0 20px;
	}
	
	.bl_LogiPro_support {
    padding: 24px 16px;
    margin: 45px 0 0;
  }
	
	.bl_LogiPro_support h3 span {
    font-size: 1.0625rem;
		padding: 0 20px;
  }
	
	.bl_LogiPro_support h3 span:before {
    height: 22px;
    top: 5px;
    left: 8px;
	}
	
	.bl_LogiPro_support h3 span:after {
    height: 22px;
    top: 5px;
    right: 8px;
	}
	
	.bl_LogiPro_support h4 {
    font-size: 1rem;
		margin: 0 0 16px;
	}
	
	.bl_LogiPro_support_box {
    display: block;
		font-size: .9375rem;
	}
	
	.bl_LogiPro_support_box .bl_LogiPro_support_item:first-of-type {
		margin: 0 0 12px;
	}
	
	.bl_LogiPro_after .hp_ttl {
    margin: 0 auto 20px;
    width: 60px;
    height: 60px;
    line-height: 60px;
	}
	
	.bl_LogiPro_after .hp_desc {
    font-size: 1.125rem;
	}

	.bl_LogiPro_after .hp_desc::before {
    height: 40px;
    top: 15px;
	}
	
	.bl_LogiPro_flow {
		padding: 10px;
	}
	
	.bl_LogiPro_after {
    padding: 30px 0 50px;
	}
	
	.bl_LogiPro_flow_now .bl_LogiPro_flow_cont,
	.bl_LogiPro_flow_future .bl_LogiPro_flow_cont {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 36px;
  }
	
	.bl_LogiPro_flow_item:after {
		width: 12px;
    height: 12px;
    right: -23px;
  }
	
	.bl_LogiPro_flow_future_desc {
    padding: 40px 20px 0;
    text-align: left;
	}
	
	.bl_LogiPro_task_item h2 {
    display: block;
    padding: 10px 14px;
    font-size: 1rem;
		text-align: center;
	}
}

/*-----食品卸提案・新規導入 -----*/

.bl_realize {
	background: #fff;
	padding: 80px 60px 40px;
	position: relative;
	margin: 70px 0 0;
}

.bl_realize h2 {
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
}

.bl_realize h2 span {
	position: relative;
	font-size: 1.25rem;
	font-weight: 500;
}

.bl_realize .el_circle {
	margin: 0 0 12px;
}

.bl_realize .el_circle::before {
	background: #0075c4;
}

.bl_realize h2 span:before {
	position: absolute;
	top: -20px;
	left: -34px;
	content: '[';
	font-size: 2.5rem;
	font-weight: 100;
}

.bl_realize h2 span:after {
	position: absolute;
	top: -20px;
	right: -34px;
	content: ']';
	font-size: 2.5rem;
	font-weight: 100;
}

.bl_realize_img {
	margin: 30px 0 0;
}

@media screen and (max-width: 767px) {
	.bl_realize {
    padding: 50px 20px 30px;
    margin: 50px 0 0;
	}
}

/*----- 「乾杯王」のセールスプロモーション -----*/
.bl_phase .ly_wrap {
	position: relative;
}

.bl_phase_cont {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 30px;
}

.bl_phase_cont li h3 {
	font-size: 1rem;
	text-align: center;
	position: relative;
	font-weight: bold;
	line-height: 1.5em;
	background: #e5f5fc;
	padding: 8px 0 9px;
}

.bl_phase_cont li:nth-child(2) h3 {
	background: #d4edf9;
}

.bl_phase_cont li:nth-child(3) h3 {
	background: #bbe1f4;
}

.bl_phase_cont li:nth-child(4) h3 {
	background: #8fcdef;
}

.bl_phase_lineBox {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	opacity: .8;
	padding: 0 30px;
}

.bl_phase_step {
	font-family: Cambria;
	position: relative;
	text-align: center;
	margin: 0 0 50px;
}

.bl_phase_box {
	position: relative;
	border: 4px solid #e5f5fc;
}

.bl_phase_inner {
	padding: 20px;
	font-size: .9375rem;
}

.bl_phase_box:before {
	content: '';
	clip-path: polygon(0 100%, 50% 0, 100% 100%);
	background: #e5f5fc;
	height: 40px;
	width: 40px;
	position: absolute;
	top: -40px;
	left: 50%;
	transform: translateX(-50%);
}

.bl_phase_cont li:nth-child(2) .bl_phase_box {
	border: 4px solid #d4edf9;
}

.bl_phase_cont li:nth-child(3) .bl_phase_box {
	border: 4px solid #bbe1f4;
}

.bl_phase_cont li:nth-child(4) .bl_phase_box {
	border: 4px solid #8fcdef;
}

.bl_phase_cont li:nth-child(2) .bl_phase_box:before {
	background: #d4edf9;
}

.bl_phase_cont li:nth-child(3) .bl_phase_box:before {
	background: #bbe1f4;
}

.bl_phase_cont li:nth-child(4) .bl_phase_box:before {
	background: #8fcdef;
}

/* ----- 流れてくるマーカー -----*/
.slide_l {
	opacity: 0;
	transform: translateX(-30px);
	transition: all .5s;
}

.bg .bg_wrap {
	position: relative;
	display: inline-block;
}

.bg.is-animated .bg_wrap::before {
	animation: bg 5s cubic-bezier(0.22, 1, 0.36, 1);
	height: 13px;
	background: rgba(245, 255, 0, .4);
	content: "";
	position: absolute;
	top: 20px;
	left: 0;
	width: 100%;
	transform-origin: left center;
	transform-origin: left center;
}

.bg.is-animated .bg_wrap.white::before {
	background: #fff;
}

.bg.is-animated .bg_wrap.pink::before {
	background: rgba(255, 62, 160, .2);
	height: 14px;
	top: 16px;
}

.bg .bg_wrap .inn {
	display: inline-block;
	position: relative;
	z-index: 1;
}

.bl_phase_lineBox .bg.anim .bg_wrap {
	display: block;
}

.bl_phase_lineBox .bg.is-animated .bg_wrap::before {
	animation: bg 10s cubic-bezier(0.22, 1, 0.36, 1);
	height: 26px;
	background: #90cced;
	background: -webkit-linear-gradient(to right, #f2fcfe, #90cced);
	background: linear-gradient(to right, #f2fcfe, #90cced);
	top: 0;
}

.bl_production_cont {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 50px;
}

.bl_production_img {
	padding: 10px;
	background: #fff;
	box-shadow: 0 5px 10px #3333330d;
}

@media screen and (max-width: 1023px) {
	.bg.is-animated .bg-wrap::before {
		top: 15px;
	}
}

@keyframes bg {
	0% {
		opacity: 0;
		transform: scaleX(0) translateX(-5%);
	}

	30% {
		transform: scaleX(1) translateX(0);
	}

	100% {
		transform: scaleX(1) translateX(0);
	}

	30%,
	100% {
		opacity: 1;
	}
}

@media screen and (max-width: 1023px) {}

@media screen and (max-width: 767px) {
	.bl_phase_cont {
		display: block;
	}
	
	.bl_phase_cont li {
		margin: 0 0 30px;
	}
	
	.bl_phase_lineBox {
		display: none;
	}
	
	.bl_production_cont {
    display: block;
	}
	
	.bl_production_item {
		margin: 0 0 20px;
	}
}

/*============================
会社概要
============================*/
.bl_company table th,
.bl_company table td {
	padding: 26px 20px;
	box-sizing: border-box;
}

.bl_company table th {
	width: 25%;
	font-weight: normal;
	border-bottom: solid 2px #ffa71d;
}

.bl_company table td {
	width: 75%;
	border-bottom: solid 2px #eee;
}

.bl_company table tr:first-of-type th {
	border-top: solid 2px #ffa71d;
}

.bl_company table tr:first-of-type td {
	border-top: 2px solid #eee;
}

@media screen and (max-width: 767px) {

	.bl_company table th,
	.bl_company table td {
		display: block;
		width: 100%;
		padding: 20px 12px;
	}

	.bl_company table th {
		border-bottom: none;
		padding: 16px 0 6px;
		font-weight: bold;
	}

	.bl_company table td {
		border-bottom: 2px solid #ffa71d;
		padding: 0 0 16px;
	}

	.bl_company table tr:first-of-type td {
		border-top: none;
	}
}

/*============================
実績紹介
============================*/
.bl_archiveWorks_box {
	display: flex;
	width: 100%;
	margin: 150px 0 60px;
}

.bl_archiveWorks_img {
	position: relative;
	z-index: 1;
	width: 40%;
	margin: -90px 0 0;
}

.bl_archiveWorks_txt {
	width: calc(60% + 100px);
	background: #f7f7f7;
	position: relative;
	z-index: 0;
	min-height: 300px;

}

.bl_archiveWorks_cont .bl_archiveWorks_box:nth-child(even) .bl_archiveWorks_txt {
	margin-left: -100px;
	padding: 60px 60px 60px 160px;
}

.bl_archiveWorks_cont .bl_archiveWorks_box:nth-child(odd) .bl_archiveWorks_txt {
	margin-right: -100px;
	padding: 60px 160px 60px 60px;
}

.bl_archiveWorks_cont .bl_archiveWorks_box:nth-child(odd) {
	flex-direction: row-reverse;
}

.bl_archiveWorks_txt h2 {
	font-size: 1.25rem;
	color: #0075c4;
	margin: 0 0 20px;
	letter-spacing: .1em;
	font-weight: 600;
}

.bl_archiveWorks_txt .el_more {
	margin: 50px 0 0;
}

@media screen and (max-width: 767px) {
	.bl_archiveWorks_box {
    display: block;
	  margin: 30px 0 0;
	}
	
	.bl_archiveWorks_img {
    width: 100%;
    margin: 0;
	}
	
	.bl_archiveWorks_txt {
    width: 100%;
    min-height: 100%;
	}
	
	.bl_archiveWorks_cont .bl_archiveWorks_box:nth-child(even) .bl_archiveWorks_txt {
    margin-left: 0;
    padding: 30px;
	}
	
	.bl_archiveWorks_cont .bl_archiveWorks_box:nth-child(odd) .bl_archiveWorks_txt {
    margin-right: 0;
    padding: 30px;
	}
	
	.bl_archiveWorks_txt .el_more {
    margin: 30px 0 0;
	}
}

/*============================
お問い合わせ
============================*/
input[type="button"],
input[type="email"],
input[type="text"],
input[type="submit"],
input[type="image"],
input[type="tel"],
textarea,
select,
input[type="number"] {
	outline: none;
	font-family: "Noto Sans JP", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ",
		sans-serif;
	letter-spacing: .1em;
}

.bl_form_ratioBox {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 30px;
	margin: 30px 0 0;
}

.bl_form_box {
	margin: 30px 0 0;
}

.bl_formWrap .wpcf7-form-control.textarea {
	width: 100%;
	padding: 6px 8px;
	font-size: 16px;
	border: none !important;
	border: #707070 solid 1px !important;
}

.bl_recaptcha {
	text-align: center;
	font-size: .875rem;
	margin: 10px 0 0;
}

.bl_recaptcha a {
	margin: 0 5px;
	border-bottom: 1px solid #00a1e9;
	color: #00a1e9;
	padding-bottom: 2px;
}

.bl_recaptcha a:hover {
	border-bottom: 1px solid #005bac;
	color: #005bac;
}

.bl_formWrap .wpcf7-form label {
	border: none !important;
	padding: 6px 10px 8px 8px;
	display: inline-block;
	cursor: pointer;
	background: #fff;
	margin: 0 6px 6px 0;
	border: #707070 solid 1px !important;
}

.bl_formWrap .wpcf7-form label input,
.bl_formWrap .wpcf7-form label span {
	vertical-align: middle;
}

.bl_formWrap .wpcf7-form-control.select {
	background: #fff;
	padding: 5px;
	width: 80%;
	font-size: 1rem;
	border: none;
	border: #9bd9f3 solid 2px !important;
	border-radius: 5px;
}

.bl_formWrap .bl_transmission {
	max-width: 500px;
	text-align: center;
	margin: 60px auto 0;
}

.bl_form_title {
	margin-bottom: 7px;
	letter-spacing: .1em;
	font-weight: bold;
}

.bl_formWrap .bl_transmission .button,
div.wpcf7cp-btns .wpcf7-form-control {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	appearance: none;
	cursor: pointer;
	background: #0075c4;
	display: inline-block;
	width: 46%;
	outline: none;
	border-radius: 5px;
	font-size: 1.125rem;
	font-weight: bold;
	border: none;
	padding: 12px 0;
	margin: 0 2%;
	letter-spacing: .1em;
	transition: .5s;
	color: #fff;
}

.bl_formWrap .bl_transmission .button:hover,
div.wpcf7cp-btns .wpcf7-form-control:hover {
	background: #32acff;
}

.bl_formWrap span.his {
	background: #ff6347;
	padding: 0 2px;
	color: #fff;
	border-radius: 3px;
	margin: 0 0 0 10px;
	font-size: 0.85em;
}

.wpcf7-spinner {
	display: none !important;
}

div#wpcf7cpcnf table {
	width: 100%;
	max-width: 980px;
	margin: 0 auto;
	border: 1px solid #ccc;
	border-bottom: none;
}

div#wpcf7cpcnf table tr {
	border-bottom: 1px solid #ccc;
}

div#wpcf7cpcnf table th,
div#wpcf7cpcnf table td {
	padding: 12px;
}

div#wpcf7cpcnf table th {
	width: 50%;
	border-right: 1px solid #ccc;
	background: #f0f8ff;
}

div.wpcf7cp-btns {
	max-width: 500px;
	margin: 2em auto 0;
}

.apply-title {
	margin: 0 0 30px;
}

.apply-title span {
	font-weight: bold;
}

.apply-title input[type="text"] {
	font-family: "Noto Sans JP", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ",
		sans-serif;
	background: #fff;
	border: none;
	padding: 4px 10px;
	font-size: 1rem;
	width: 50%;
	margin: 0 0 0 10px;
}

input[type="date"] {
	padding: 6px 10px 8px 4px;
	font-size: 1rem;
}

@media screen and (max-width: 767px) {
	.bl_form_ratioBox {
		display: block;
		margin: 0;
	}

	.bl_form_ratioBox li {
		margin: 0 0 30px;
	}

	div#wpcf7cpcnf table th,
	div#wpcf7cpcnf table td {
		display: block;
		width: 100%;
	}
}

/*============================
送信完了
============================*/
.bl_kanryou {
	padding: 100px 0;
	text-align: center;
}

.bl_kanryou .bl_topLink {
	margin: 30px 0 0;
	font-size: 1.125rem;
}

.bl_kanryou .bl_topLink a {
	color: #005bac;
	font-weight: bold;
	transition: .5s;
	letter-spacing: .15em;
}

.bl_kanryou .bl_topLink a:hover {
	color: #a2c2e6;
}

@media screen and (max-width: 767px) {
	.bl_kanryou {
		text-align: left;
	}

	.bl_kanryou .bl_topLink {
		text-align: center;
	}
}

/*============================
個人情報保護方針
============================*/
.bl_policyCont h2 {
	font-weight: bold;
	font-size: 1.25rem;
	letter-spacing: .1em;
	margin: 0 0 8px;
}

.bl_policyCont p {
	line-height: 1.6em;
}

.bl_policy_item {
	padding: 30px 0 0 20px;
}

.bl_policy_item>li {
	list-style-type: decimal;
	margin: 0 0 22px;
}

.bl_policy_seitei {
	margin: 40px 0 0;
}

.bl_policy_seitei p {
	text-align: right;
}

.bl_ppMado_info {
	display: inline-block;
	margin: 20px 0 0;
	padding: 40px;
	border: 1px solid #ddd;
}

@media screen and (max-width: 767px) {
	.bl_policyCont p {
		font-size: .875rem;
	}

	.bl_ppMado_info {
		padding: 20px;
		font-size: .875rem;
	}
}

/*============================
ページネーション
============================*/
.pagenation {
    margin: 60px auto 0;
}
.pagenation:after, .pagenation ul:after {
    clear: both;
    content: ".";
    display: block;
    height: 0;
    visibility: hidden;
}
.pagenation ul {
    margin: 0 auto;
    text-align: center;
}
.pagenation li {
    list-style: none outside none;
    margin-left: 3px;
    display: -moz-inline-box;
  display: inline-block;
  /*display: inline;*/

}
.pagenation li:first-child {
    margin-left: 0;
}
.pagenation li.active {
    background-color: #999999;
    border-radius: 3px;
    color: #FFFFFF;
    cursor: not-allowed;
    padding: 10px 15px;
}
.pagenation li a {
    background: none repeat scroll 0 0 #CCCCCC;
    border-radius: 3px;
    color: #FFFFFF;
    display: block;
    padding: 10px 15px;
    text-decoration: none;
    text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.2);
}
.pagenation li a:hover {
    background-color: #444444;
    color: #FFFFFF;
    opacity: 0.8;
    transition-duration: 500ms;
    transition-property: all;
    transition-timing-function: ease;
}
@media screen and (max-width: 768px) {
	.pagenation {
		margin: 30px auto 0;
	}
}