/* =====================================================
   基本設定
===================================================== */

:root{
   --mian_color: #164F9E;
}

body{
	background: linear-gradient(180deg, #F2F6F9 0%, #F7F7F7 100%);
}
body.home{
	background: linear-gradient(180deg, #eaf0f5 0%, #f2f2f2 100%);
}
body p{
	line-height: 1.6;
}

body.page-id-57 .site-footer,
body.blog .site-footer,
body.post-template-default .site-footer,
body.archive .site-footer,
body.error404 .site-footer{
	margin-top: 0;
}
body.page-id-57 .footer-widget-area,
body.blog .footer-widget-area,
body.post-template-default .footer-widget-area,
body.archive .footer-widget-area,
body.error404 .footer-widget-area{
   padding-top: 6rem;
}


/* ---------- common ---------- */

.bl_heading{
	font-size:15px;
	color:#4586BF;
}
.bl_heading:after{
	content: attr( data-title );
	display: block;
	color:var(--mian_color);
	font-family: "Roboto", sans-serif;
	font-size:40px;
    letter-spacing: 10%;
    line-height: 1;
}
h2.bl_page_heading{
	position: relative;
	color: var(--mian_color);
	font-size: 2.25rem;
	margin-bottom: 3.85em;
	margin-top: 0;
	padding-top: 4.375rem;
}
h2.bl_page_heading::before{
	position: absolute;
	content: '';
	transform: translateY(-40%) translateX(-60%);
	width: 85px;
	height: 85px;
	background-image:url(../images/bg_logo_head.png);
	background-size: contain;
	background-repeat: no-repeat;
	vertical-align: middle;
	mix-blend-mode: multiply;
}
h2.bl_page_heading:after{
	position: absolute;
	content: '';
	bottom: -24px;
	left: 50%;
	transform: translateX(-50%);
	width: 80px;
	height: 2.5px;
	background-color: #398AD0;
	border-radius: 2.5px;
}

.bl_section{
	margin-top:144px;
}

.wp-block-button__link {
	padding: 0.9em 0;
}
.bl_btn{
    margin-top: 40px;
}
.bl_btn a{
    position: relative;
    z-index: 0;
    background: linear-gradient(180deg, #4586bf 0%, #164f9e 100%);
    border-radius: 8px;
	text-indent: 20px;
	font-size: 18px;
    font-weight: bold;
}
.el_btn_indent a{
	text-indent: 40px;
}
.bl_btn a::before{
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: linear-gradient(180deg, #70b3ee 0%, #2057a3 100%);
    opacity: 0;
    transition: opacity 0.5s;
    margin-right: 0;
    border-radius: 8px;
}
.bl_btn a:hover{
    opacity: 1;
    color: #fff;
}
.bl_btn a:hover::before{
    opacity: 1;
}

.bl_btn a::after{
    content: "";
    position: absolute;
    max-width:35px;
    width:100%;
    height: 100%;
    max-height: 35px;
    left: 15%;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
    background-image:url(../images/icon_btn.png);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
}

.wp-block-buttons .bl_btn{
	width:100%;
	max-width:245px;
}
.wp-block-columns {
    align-items: center !important;
}

.bl_business, .bl_company {
	padding:1.8em;
	border-radius: 10px;
}
body .bl_about .is-layout-flex,
body .bl_recruit .is-layout-flex{
	gap:35px;
	align-items: baseline;
}

.sp_link{
	pointer-events: none !important;
	color: inherit !important;
	text-decoration: none !important;
}
.sp_block{
	display: none;
}

@media screen and (max-width: 1159px) {
	.bl_business, .bl_company {
		padding:clamp(1.563rem, 1.027rem + 2.38vw, 2.813rem) clamp(0.75rem, 3.33vw, 2.5rem);
	}
}
@media screen and (max-width: 980px) {
	.bl_heading{
		font-size:13px;
	}
	.bl_heading:after{
		font-size:32px;
	}
}
@media screen and (max-width: 600px) {
	.bl_company .wp-block-buttons .bl_btn,
	.bl_recruit .wp-block-buttons .bl_btn{
		max-width:190px;
	}
	body .bl_about .is-layout-flex,
	body .bl_recruit .is-layout-flex{
		gap:24px;
	}
	.wp-block-button__link {
		padding: 0.6em 0;
	}
	.bl_btn a{
		font-size: 16px;
	}
	.bl_btn a::after{
		max-width:32px;
		max-height: 32px;
	}
}
@media screen and (max-width: 480px) {
	.sp_block{
		display: block;
	}
}



/* ---------- header ---------- */
.main-header{
	background-color:#fff;
	font-size: 20px;
}
.site-branding{
	display: flex;
    align-items: center;
    gap: 16px;
}
.main-header-content .main-navigation .current_page_item.menu-item-776 > a, 
.main-header-content .main-navigation .current-menu-item.menu-item-776 > a {
    color: #fff;
    font-weight: bold;
}
.menu-item-776 a{
    color: #fff;
    font-weight: bold;
    margin-left: 1em;
    border-radius: 8px;
}
.drawer-navigation ul li {
	font-size: 0.9em;
}
.drawer-navigation .menu-item-776{
	margin-top: 14px;
} 
.drawer-navigation .menu-item-776 a{
	background: linear-gradient(180deg, #4586bf 0%, #164f9e 100%);
	padding: 0.7em;
	margin-left: 0;
	letter-spacing: 0.03em;
	transition: opacity 0.3s ease-in-out;
} 
.drawer-navigation .menu-item-776.current-menu-item a,
.drawer-navigation .menu-item-776 a:hover{
	color: #fff;
	opacity: 0.9;
}  

@media screen and (max-width: 1200px) {
	.main-header-clone .main-header-content{
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}
	.main-header-content .main-navigation .menu{
		display:flex;
	}
	.main-header-content .main-navigation .menu li{
		padding: 0px 0.85em;
	}
	.main-header-content .main-navigation .menu>li:first-child{
		padding-left:0;
	}
	.main-header-content .main-navigation .menu>li:last-child{
		padding-right:0;
	}
	.menu-item-776 a{
		margin-left: 0;
	}
}
@media screen and (min-width: 980px) {
	.main-navigation .menu-item-776 a:hover {
        color: #fff;
    }
    .main-navigation div.menu > ul > li:last-child > a, 
	.main-navigation ul.menu > li:last-child > a {
        padding: 0 0.7em; 
    }
	.menu-item-776 a{
		position: relative;
		z-index: 0;
		background: linear-gradient(180deg, #4586bf 0%, #164f9e 100%);
		border-radius: 8px;
	}
	.menu-item-776 a::before{
		content: "";
        position: absolute;
        inset: 0;
        z-index: -1;
		background: linear-gradient(180deg, #70b3ee 0%, #2057a3 100%);
		opacity: 0;
        transition: opacity 0.5s;
		margin-right: 0;
		border-radius: 8px;
	}
	.menu-item-776 a:hover::before {
		opacity: 1;
    }
}
@media screen and (max-width: 979px) {
	.home-header-content{
		padding: calc(100% - clamp(9.375rem, -1.905rem + 48.78vw, 21.875rem)) 20px;
	}
	.main-header-clone .main-header-content{
		flex-direction: row;
		align-items: center;
		gap: 0;
	}
	.main-header-content .main-navigation .menu{
		display:block;
	}
}
@media screen and (max-width: 480px) {
	.drawer-navigation .menu-item-776 a{
		padding: 0.65em 1.5em;
	}
}

.home-header {
        background-image: url(../images/kv_bg.jpg);
    }
@media screen and (max-width: 600px) {
    .home-header {
        background-image: url(../images/kv_sp_bg.jpg);
    }
}

.home-header-overlay, .jumbotron-overlay{
	background-color: transparent;
}
.home-header-content{
	position:relative;
	padding: clamp(9.375rem, 3.606rem + 15.38vw, 21.875rem) 0px;
}
@media screen and (max-width: 600px) {
	.home-header-content{
		padding: calc(100% - clamp(9.375rem, -1.905rem + 48.78vw, 21.875rem)) 20px;
	}
}

.home-header-text{
	position: absolute;
	bottom:10%;
	left:0;
	margin-top:0;
	padding-left: 1.5em;
}
.mv_heading{
	font-family: "Noto Serif JP", serif;
	font-size: clamp(1.875rem, 1.212rem + 1.77vw, 3.313rem);
	font-weight: bold;
	color: var(--mian_color);
	text-shadow:1px 1px 1px #fff;
	line-height: 1.7;
}
.mv_text{
	background: linear-gradient(to right, rgba(255,255,255,0.75) 90%,  rgba(255,255,255,0.08));
	padding: 0 0.5em;
}
.mv_text_inner{
	color:#2894e8;
}

@media (max-width: 1159px){
	.mv_heading {
        margin-left: 2rem;
    }
}
@media screen and (max-width: 781px) {
	.home-header-text{
		padding-left: 0;
	}
}
@media screen and (max-width: 600px) {
	.mv_heading{
		font-size: 24px;
	}
	.home-header-text{
		bottom:20%;
	}
}
@media screen and (max-width: 480px) {
	.mv_heading{
		font-size: 21px;
		margin-left: 1rem;
	}
}

/* ---------- about ---------- */
.bl_about{
	position:relative;
}
.bl_about:after{
	position:absolute;
	content: '';
    display: inline-block;
	max-width:270px;
	width:100%;
	height: 100%;
    max-height: 270px;
	top:30px;
	right:-16px;
	background-image:url(../images/bg_logo.png);
	background-size: contain;
	background-repeat: no-repeat;
    vertical-align: middle;
    mix-blend-mode: multiply;
}
.bl_about h2{
	margin-bottom: 0;
}
.bl_about h3{
	font-size:24px;
	color: #3F383E;
	margin-top: 2em;
}
.bl_about_btn_area .bl_btn{
    margin-top: 40px;
}

@media screen and (max-width: 1159px) {
    .bl_about:after{
		max-width:240px;
		max-height: 240px;
		top:40px;
		right:-25px;
	}
}
@media screen and (max-width: 980px) {
	.bl_about:after {
        max-width: 180px;
        max-height: 180px;
        top: 60px;
		right:-15px;
    }
	.bl_about h3 {
    	font-size: 20px;
	}
}
@media screen and (max-width: 600px) {
	.bl_about:after{
		max-width:140px;
		max-height:140px;
		top:60px;
		right:0;
	}
	body .bl_about .is-layout-flex{
		flex-direction: column;
		align-items: center;
	}
	.bl_about_btn_area .bl_btn:last-child {
		margin-top: 0;
	}
}

/* ---------- business ---------- */

:where(.wp-block-columns) {
    margin-bottom: 0;
}
.bl_business .bl_heading{
	margin-bottom: 2.8em;
}
.bl_business_box{
	list-style: none; 
	margin-left:0;
	counter-reset: number 0;
}
.bl_business_item{
	position:relative;
	padding: 0.4em 0 0.4em 0.5em;
	color:#082E7C;
	font-weight:bold;
	border-bottom:2px solid #4586BF;
}
.bl_business_item a{
	display:block;
	font-size: 18px;
	text-decoration:none;
	color:#082E7C;
	margin-left:3em;
	transition: opacity 0.3s ease-in-out;
}
.bl_business_item::before{
	position: absolute;
	content:"0"counter(number)"";
	counter-increment:number 1;
	color:#4586BF;
	font-size: 18px;
	font-weight:bold;
}
.bl_business_item a::after{
    content: "";
    position: absolute;
    max-width:30px;
    width:100%;
    height: 100%;
    max-height: 30px;
    right:0;
	top: 50%;
    transform: translateY(-50%) translateX(-50%);
    background-image:url(../images/icon_arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
}
.bl_business_item a:hover{
	opacity: 0.6;
	color:#082E7C;
}

@media screen and (max-width: 781px) {
	.bl_business_item {
		padding: 1em 0 0.4em 1em;
	}
}
@media screen and (max-width: 480px) {
	.bl_business_item .bl_heading:after {
		line-height: 1.1;
	}
}

/* ---------- company ---------- */
.bl_company .bl_heading{
	margin-bottom: 3.2em;
}
@media screen and (max-width: 781px) {
	.bl_company .wp-block-columns{
		flex-wrap: nowrap !important;
		flex-direction: column-reverse;
	}
}

/* ---------- recruit ---------- */
.bl_recruit{
	position:relative;
    background-image:url(../images/bg_recruit.png);
	background-size: cover;
    background-repeat: no-repeat;
	padding-top: clamp(2.5rem, 0.192rem + 6.15vw, 7.5rem);
	margin: 240px 0;
}
.bl_recruit::after{
	position: absolute;
	content: '';
	max-width: 620px;
	width: 40%;
	max-height: 560px;
	height: 100%;
	bottom:0;
	right: 10vw;
	background:url(../images/top_item03.png) no-repeat bottom right / contain;
	vertical-align: middle;
	z-index:1;
}
.bl_recruit_box{
	position:relative;
	padding-left: 1.8em;
	padding-bottom: clamp(2.5rem, -0.385rem + 7.69vw, 8.75rem);
}
.bl_recruit_box .bl_heading{
	margin-bottom: 3em;
}
.bl_recruit_box .bl_heading::before{
	position: absolute;
	content: '';
	top: -40px;
	left: -40px;
	max-width: 120px;
	width: 100%;
	height: 100%;
	max-height: 120px;
	background-image:url(../images/bg_logo_re.png);
	background-size: contain;
	background-repeat: no-repeat;
	vertical-align: middle;
	mix-blend-mode: multiply;
}
.bl_recruit_ttl{
	color:#082E7C;
}
.bl_recruit_txt{
	margin-bottom:0;
}

@media screen and (max-width: 1200px) {
	.bl_recruit::after{
		right: 4vw;
	}
	.bl_recruit_box .bl_heading::before{
		top: -32px;
		left: -16px;
		max-width: 110px;
		max-height: 110px;
	}
}
@media screen and (max-width: 1159px){
	.bl_recruit::after{
		width: 50%;
	}
	body .bl_recruit .is-layout-flex {
		flex-direction: column;
	}
	.bl_recruit_box .bl_about_btn_area .bl_btn:last-child {
        margin-top: 0;
    }
	.bl_recruit_box{
		padding-left: 0;
	}
	.bl_recruit_box .bl_heading::before{
		top: -30px;
		left: -48px;
		max-width: 100px;
		max-height: 100px;
	}
}
@media screen and (max-width: 980px) {
	.bl_recruit_box{
		padding-left: 1em;
	}
	.bl_recruit_box .bl_heading::before{
		top: -40px;
		left: -24px;
	}
}
@media screen and (max-width: 781px) {
	.bl_recruit_box{
		padding-left: 5%;
        padding-right: 5%;
 	}
	.bl_recruit_box .bl_heading::before{
		top: -24px;
		left: 0;
		max-width: 80px;
		max-height: 80px;
	}
	.bl_recruit::after{
		right: 0;
	}
}
@media screen and (max-width: 630px) {
	.bl_recruit{
		padding-top: 56px;
		margin: 144px 0;
	}
}
@media screen and (max-width: 480px) {
	.bl_recruit::after{
		width: 58%;
	}
	.bl_recruit_box{
		padding-bottom: 190px;
 	}
}


/* ---------- news ---------- */
.bl_news_box{
	padding-left: 1.8em;
}
.bl_news .bl_btn{
	margin-top: 64px;
}
.bl_news_box.wp-block-columns{
	align-items: normal !important;
	justify-content: space-between;
}

.smb-tabs__tabs{
	border-bottom: 2px solid #4586BF;
}
.bl_tab_area .smb-tabs__tabs .smb-tabs__tab{
	border-radius: 5px 5px 0 0;
}
.smb-tabs__tab[aria-selected=false] {
    opacity: 1;
	background-color: transparent;
    color: #082E7C;
}
.smb-tabs__tab[aria-selected=true] {
    background-color: #4586BF;
    color: #fff;
}
.smb-tabs[data-orientation=horizontal]>.smb-tabs__tabs {
    gap: 8px;
}
.bl_news_listbox .smb-tabs[data-orientation=horizontal]>.smb-tabs__tabs .smb-tabs__tab {
    padding: 12px 32px;
	border: 2px solid #4586BF;
    border-bottom: transparent;
}
.bl_news button{
	background-color:#fff;
	color:#082E7C;
	font-weight:bold;
}
.smb-tabs__body .smb-tab-panel {
    background-color: transparent;
    border: none;
    padding: 0;
}
.bl_list_area ul{
	margin: 0;
}
.bl_list_area ul li{
	display: flex;
	align-items: center;
	gap: 4em;
	border-bottom: 2px solid #4586BF;
    padding: 1.415em 0 1.415em 0.5em;
}
.bl_list_area .bl_newslist_ttl{
	margin: 0;
	font-weight: normal;
}
.bl_list_area .bl_newslist_ttl a{
	color: inherit;
}
.bl_newslist_time time{
	color: #4586BF;
    font-weight: bold;
}

@media screen and (max-width: 1159px){
	.bl_news_box {
		padding-left: 0;
	}
}
@media screen and (max-width: 980px) {
	.bl_news_ttl {
		flex-basis: 18%;
	}
	.bl_news_listbox {
		flex-basis: 80%;
	}
}
@media screen and (max-width: 600px) {
	.bl_news_listbox .smb-tabs[data-orientation=horizontal]>.smb-tabs__tabs .smb-tabs__tab {
		padding: 8px 16px;
	}
	.bl_list_area ul li{
		flex-direction: column;
		align-items: normal;
        gap: 8px;
	}
	.bl_news_listbox .wp-block-buttons.is-content-justification-right {
		justify-content: flex-start;
	}
	.bl_news_listbox .wp-block-buttons .bl_btn {
		max-width: 190px;
	}
	.bl_news_listbox .bl_btn a {
		text-indent: 40px;
	}
}


/* ---------- contact ---------- */

.bl_contact .bl_contact_img{
	border-radius: 10px;
}
.bl_contact .wp-block-cover.bl_contact_img{
	min-height: auto;
	height: clamp(14.375rem, 8.803rem + 24.1vw, 26.875rem);
}
.bl_contact .bl_heading{
	margin: 0 0 clamp(1rem, -0.071rem + 4.76vw, 3.5rem);
	color: #DEEFFF;
}
.bl_contact .bl_heading::after{
	color: #FFF;
}
.bl_btn_contact{
	width: 340px;
}
.bl_btn_contact a{
	color: #164F9E;
    font-size: 1.8rem;
    font-weight: bold;
    background: #fff;
    border-radius: 10px;
	border:1px solid #4586BF;
    padding: clamp(0.5rem, 0.286rem + 0.95vw, 1rem) clamp(2.5rem, 0.786rem + 7.62vw, 6.5rem);
	transition: all 0.3s;
}
.bl_btn_contact a:hover{
	color: #fff;
    background: linear-gradient(180deg, #70b3ee 0%, #2057a3 100%);
}
@media screen and (max-width: 630px) {
	.bl_btn_contact{
		width: 250px;
	}
	.bl_btn_contact a{
		font-size: 1.65rem;
	}
}

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

.site-footer{
	margin-top: -23rem;
}
.site-footer .footer-widget-area {
	background-color:#082E7C;
    border-top: none;
    padding-bottom: 4rem;
    padding-top: 23rem;
}
.footer-widget-wrapper{
	justify-content: space-between;
	letter-spacing: 0.085em;
	font-size: 18px;
    line-height: 1;
}
.footer-widget-wrapper .footer-widget{
	padding-left: 0;
	padding-right: 0;
}
.footer-widget-wrapper .footer-widget-2{
	display: flex;
	justify-content: flex-end;
	gap: 6.9rem;
	padding-top: 86px;
}
.widget {
    margin-bottom: 0;
}
.footer-widget-2 .widget li a{
    color: #fff;
}
.widget li a:hover{
	color: #DEEFFF;
}
.wp-block-image .alignleft {
    float: left;
    margin: .5em 0em .5em 0;
}
.footer-widget-area .wp-block-image img {
    width: 100%;
}
.bl_footer_ttl{
	font-size: 1.7rem;
	font-weight: bold;
    color: #fff; 
    margin-top: 0;
}
.bl_footer_txt{
    color: #fff;
}
.bl_footer_ttl span{
    text-decoration: underline; 
    text-underline-offset: 0.3em;
}

.site-bottom {
    padding-bottom: 0rem;
    padding-top: 1rem;
}
.site-credit {
    display:none !important;
}
.site-footer .site-info {
    text-align: center;
    float: none;
}


@media screen and (max-width: 1200px) {
	.footer-widget-wrapper {
		flex-direction: column;
        justify-content: space-between;
    }
	.footer-widget-wrapper .footer-widget-1 {
		display: block;
		gap: clamp(1rem, 0.403rem + 2.58vw, 3.5rem);
		margin-left: 60px;
	}
	.footer-widget-area .wp-block-image img {
		max-width: 245px;
	}
	.footer-widget-wrapper .footer-widget-2 {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		padding-top: 24px;
		gap: clamp(1.5rem, 0.665rem + 3.61vw, 5rem);
		margin-left: 60px;
	}
}
@media screen and (min-width: 980px) {
	.footer-widget-wrapper .footer-widget-1 {
        width: 28%;
    }
    .footer-widget-wrapper .footer-widget-2 {
        width: 70%;
    }
}
@media screen and (max-width: 980px) {
	.site-footer .footer-widget-area {
		padding-top: 20rem;
	}
	.footer-widget-wrapper .footer-widget-1,
	.footer-widget-wrapper .footer-widget-2 {
		margin-left: 0;
	}
	.site-footer .footer-widget-content{
		padding-left: 0;
		padding-right: 0;
	}
}
@media screen and (max-width: 781px) {
	.site-footer .footer-widget-content{
		padding-left: 20px;
		padding-right: 20px;
	}
}
@media screen and (max-width: 630px) {
	.site-footer{
		margin-top: -19rem;
	}
	.site-footer .footer-widget-area {
		padding-top: 15.5rem;
	}
	.footer-widget-wrapper .footer-widget-2 {
		justify-content: flex-start;
		padding-top: 0;
	}
	.footer-widget-wrapper .footer-widget-2,
	.bl_footer_txt{
		font-size: 15px;
	}
	.footer-widget-wrapper .footer-widget-2 aside{
		width: 45%;
	}
}


/*  下層 
---------- こだわり ---------- */
.bl_commit_list{
	background-color:#fff;
	border: 1px solid #4586BF;
	border-radius: 10px;
}
.bl_commit_listTtl{
    font-size: 2.185rem;
	color:#fff;
	background: linear-gradient(135deg, #4586bf 0%, #90bfe8 100%);
	border-radius: 10px 10px 0 0;
	padding: 0.2em 0 0.2em clamp(1.5rem, 0.183rem + 5.85vw, 7.5rem);
	margin:0;
}
.bl_commit_list .bl_commit_list_box{
	margin:0;
	padding: 1em 0 1em clamp(1.625rem, -0.076rem + 7.56vw, 9.375rem);
    color: #082E7C;
    letter-spacing: 0.02em;
    line-height: 2;
	font-size:1.65rem;
}
.bl_commit_item{
	line-height: 1.5;
}
.bl_commit_item:not(:last-child){
	margin-bottom: 0.2em;
}
.wp-block-group.bl_commit_conts .bl_commit_txt{
	margin-top: 32px;
}

.bl_commit_detail .wp-block-columns{
	padding: 80px 0;
    border-bottom: 1px solid #4586BF;
}
.bl_commit_ttl{
	display: flex;
    align-items: center;
	font-size: 1.85rem;
	color: var(--mian_color);
	letter-spacing: normal;
	line-height: 1.2;
}
.bl_commit_ttl span{
	color: #4586BF;
    font-size: 2.5rem;
    margin-right: 0.5em;
	line-height: 1;
}
.bl_commit_txt{
	line-height: 1.8;
}
.bl_commit_btn {
	padding-top: 140px;
}
.wp-block-buttons .bl_commit_btn a{
	position: relative;
	background: linear-gradient(180deg, #4586bf 0%, #164f9e 100%);
	color: #fff;
	width: 435px;
    font-size: 1.58rem;
    font-weight: bold;
    padding: 1.7em 0 1.7em 3.5em;
    display: flex;
    flex-direction: column;
    text-align: left;
}
.bl_commit_btn a span{
	font-size: 16px;
	color: #89B3D9;
	line-height: 1.2;
}
.bl_commit_btn a::after{
	content: "";
    position: absolute;
    max-width:67px;
    width:100%;
    height: 100%;
    max-height: 65px;
    right: 0;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
    background-image:url(../images/icon_achievement.png);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: middle;
}

@media screen and (max-width: 980px) {
	.bl_commit_detail .wp-block-columns{
		flex-direction: column;
		align-items: normal !important;
	}
	.bl_commit_detail .wp-block-columns.bl_commit_rev{
		flex-direction: column-reverse;
	}
}
@media screen and (max-width: 600px) {
	.wp-block-buttons .bl_commit_btn a{
	width: 300px;
    padding: 0.9em 0 0.9em 2.3em;
}
.bl_commit_btn a span{
	line-height: 1;
}
.bl_commit_btn a::after{
    max-width:50px;
    max-height: 50px;
}
}
@media screen and (max-width: 480px) {
	.bl_commit_list .bl_commit_list_box{
		padding: 1em 8px 1em 40px;
	}
	.bl_commit_ttl{
		align-items: baseline;
		font-size: 1.7rem;
		letter-spacing: normal;
	}
	.bl_commit_ttl span{
		font-size: 2.1rem;
		margin-right: 0;
		width: 40px;
	}
}

/* ---------- 会社概要 ---------- */
.bl_company_top{
	margin-bottom: 100px;
}
.bl_company_top .wp-block-columns{
	background: #fff;
    padding: 1.5em 1em;
    border-radius: 10px;
}
.bl_company_top figure{
	border-radius: 10px;
	box-shadow: 2px 2px 2px #ccc;
}
p.bl_company_ttl{
	margin-bottom: 0.8em;
}
.bl_company_ttl{
    font-size: 22px;
	font-weight: bold;
}
.bl_company_inner .bl_company_txt{
	font-size: 16px;
	line-height: 1.8;
}

.bl_company_conts table th{
	width: 20%;
	padding: 1em 1.8em;
	color:#082E7C;
	border-bottom: 1px solid #fff;
}
.bl_company_conts table td{
	padding: 1em 2em;
}
.bl_company_conts .bl_company_map{
	align-items: normal !important;
}
.bl_company_map{
	margin-top: 80px;
}
.bl_map_box h3{
	font-size: 1.58rem;
	color:#082E7C;
	background: #fff;
    padding: 0.5em 0 0.5em 1.2em;
	border-left: 5px solid #4586BF;
}
.bl_map_box ul{
	list-style-type: square;
}
.bl_map_box ul li:not(:first-child){
	margin-top: 0.5em;
}


@media screen and (max-width: 980px) {
	.bl_company_conts table th{
		padding: 1em;
	}
}
@media screen and (max-width: 781px) {
	.bl_company_conts table{
		display: flex;
	}
	.bl_company_conts table tbody,
	.bl_company_conts table tr{
		display: flex;
		flex-direction: column;
	}
	.bl_company_conts table th,
	.bl_company_conts table td{
		display: block;
		width: 100%;
	}
	.bl_company_conts table th{
		border-bottom: none;
	}
	.bl_company_conts table td{
		padding: 1em;
	}
	.bl_company_map.bl_columns_rev{
		flex-direction: column-reverse;
	}
}
@media screen and (max-width: 480px) {
	.bl_company_ttl {
		font-size: 18px;
	}
}

/* ---------- 社員紹介 ---------- */
.bl_staff h2.bl_page_heading{
	margin-bottom: 2.85em;
}
.bl_staff_conts {
	gap: 3.77em;
	margin-top: 120px;
}
.wp-block-columns.bl_staff_conts {
	align-items: stretch !important;
}
.bl_staff_item {
	background: #fff;
	border-radius: 10px;
	border: 1px solid #ccc;
}
.bl_staff_topic{
	font-size: 18px;
	color: #fff;
    font-weight: bold;
    margin-bottom: 0;
    padding: 0.4em 0.4em 0.4em 1em;
    background: linear-gradient(180deg, #70b3ee 0%, #2057a3 100%);
	border-radius: 10px 10px 0 0;
}
.bl_staff_topic span{
	font-size: 24px;
	color: #DEEFFF;
	padding-left: 0.2em;
}
.bl_staff_item figure.wp-block-image{
	display: flex;
	width: 60%;
	margin: 1.5em auto;
	border-radius: 10px;
}
.bl_staff_conts h3{
	color:#082E7C;
	margin: 0 0 0.5em;
	padding: 0 1.4em;
}
.bl_staff_txt{
	border-top: 2px solid #70b3ee;
	padding: 1em 0 1.5em;
	margin: 0 1.5em;
}
.bl_member{
	margin-top: 120px;
}
.bl_member h3{
	position: relative;
	font-size: 2.45rem;
	color: var(--mian_color);
}
.bl_member h3::after{
	position: absolute;
    content: '';
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 70px;
    height: 1.5px;
    background-color: #398AD0;
    border-radius: 2.5px;
}
.bl_member_box {
	margin-top: 80px;
}
.bl_member_box .wp-block-group__inner-container{
	display: flex;
    flex-wrap: wrap;
    gap: 24px;
    align-items: center;
    justify-content: center;
}
.bl_member_box .wp-block-group__inner-container .bl_member_item {
	width: 48%;
    gap: 24px;
	padding-top: 24px;
}
.bl_member_box img{
	border: 1px solid #ccc;
}

.bl_staff_footer{
	margin-top: 180px;
}
.bl_staff_footer .wp-block-cover{
	min-height: 90vh;
	margin-bottom: 0;
}
.bl_staff_footer .wp-block-cover__inner-container{
	padding-bottom: 8rem;
}
.bl_staff_footer h3{
	position: relative;
	font-size: 3.75rem;
}
.bl_staff_footer h3::after{
	position: absolute;
    content: '';
    bottom: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 70px;
    height: 1.5px;
    background-color: #fff;
    border-radius: 2.5px;
}
.bl_staff_footer .bl_btn a{
	text-indent: 50px;
}

@media screen and (max-width: 1200px) {
	.bl_staff_footer .wp-block-cover{
		min-height: 75vh;
	}
}
@media screen and (max-width: 980px) {
	.bl_staff_footer .wp-block-cover{
		min-height: 60vh;
	}
	.bl_staff_footer .wp-block-cover__inner-container{
		padding-bottom: 2rem;
	}
}
@media screen and (max-width: 781px) {
	.bl_member_box .wp-block-group__inner-container .bl_member_item {
		width: 100%;
		gap: 16px;
		padding-top: 0;
	}
	.bl_staff_footer h3{
		font-size: 2.95rem;
	}
	.bl_staff_footer .wp-block-cover{
		min-height: 50vh;
	}
}
@media screen and (max-width: 600px) {
	.bl_staff_footer .wp-block-cover{
		min-height: 40vh;
	}
	.bl_staff_footer h3,
	.bl_staff_footer p{
		margin-bottom: 0.8em;
	}
	.bl_staff_footer .bl_btn a {
		text-indent: 45px;
	}
}
@media screen and (max-width: 480px) {
	.bl_staff_footer .wp-block-cover{
		min-height: 28vh;
	}
	.bl_staff_footer h3{
		margin: 0;
		padding-bottom: 4.5em;
	}
	.bl_staff_footer h3::after{
		bottom: 72%;
	}
}

/* ---------- FLOW ---------- */
.bl_flow_box.is-layout-flex{
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
}
.bl_flow_box.is-layout-flex > :is(*, div){
	width: 19%;
	padding: 0.8em;
	border-radius: 10px;
}
.bl_flow_item span{
	display: inline-block;
    color: #164F9E;
    text-align: center;
    font-size: 4.5rem;
    font-family: "Helvetica", "Arial", sans-serif;
    font-weight: bold;
    margin: -4rem 0 0 -1.5rem;
	line-height: 0;
}
.bl_flow_item span.el_circle02{
    color: #216EB1;
}
.bl_flow_item span.el_circle03{
    color: #4586BF;
}
.bl_flow_item span.el_circle04{
    color: #3D95D9;
}
.bl_flow_item span.el_circle05{
    color: #23A4DB;
}
.bl_flow_item h3{
	margin: 1em 0 0.5em;
	text-align: center;
	color: var(--mian_color);
}
.bl_flow_item figure{
	display: flex;
	margin: 0 auto;
	width: 50%;
	margin: 1em auto 1.5em;
}
.bl_flow_box .bl_flow_item p{
	line-height: 1.6;
}

@media screen and (max-width: 1159px){
	.bl_flow_box.is-layout-flex{
		justify-content: center;
		gap: 2em;
	}
	.bl_flow_box.is-layout-flex > :is(*, div){
		width: 28%;
	}
}
@media screen and (max-width: 630px){
	.bl_flow_box.is-layout-flex > :is(*, div){
		width: 100%;
	}
	.bl_flow_box.is-layout-flex > :is(*, div) {
		padding: 0 2em 2em;
	}
	.bl_flow_item span{
		margin: 1rem 0 0 -3.5rem;
	}
	.bl_flow_item figure{
		width: 30%;
	}
}

/* ---------- FAQ ---------- */
.bl_faq .has-white-background-color{
	border: 1px solid #ccc;
}
.bl_faq_item{
	border-bottom: 1px solid #ccc;
}
.bl_faq_item:last-child{
	border-bottom: none;
}
.bl_faq_panel .smb-accordion__item__title,
.bl_faq_panel .smb-accordion__item__body{
	padding: 1.5em 1em 1.5em 4em;
}
.bl_faq_panel .smb-accordion__item__title{
	background-color: transparent;
}
.bl_faq_panel .smb-accordion__item__title span::before {
    content: "Q";
    position: absolute;
    left: 1.2em;
    top: 1.35em;
    transform: translateY(-50%) translateX(-50%);
	font-family: "Helvetica", "Arial", sans-serif;
	font-size: 2.4rem;
	color: var(--mian_color);
}
.bl_faq_panel .smb-accordion__item__body::before {
    content: "A";
    position: absolute;
    left: 1.2em;
    top: 50%;
    transform: translateY(-50%) translateX(-50%);
	font-family: "Helvetica", "Arial", sans-serif;
	font-size: 2.4rem;
	color: #ed3329;
}

/* ---------- 採用情報 ---------- */
.bl_info h2.bl_page_heading{
    margin-bottom: 2.85em;
}
figure.bl_info_kv,
.bl_info_media{
	margin-bottom: 9.375rem;
}
.bl_info_kv figure{
	width: 80%;
}
.bl_info h3{
	font-size: 1.6rem;
	border-left: 5px solid #4586BF;
    padding: 0.5em 0 0.5em 0.8em;
    margin-bottom: 1.67em;
    background: #fff;
}
.bl_info_media .wp-block-columns:not(:last-child){
	padding-bottom: 40px;
    border-bottom: 1px solid #4586BF;
}
.bl_info_media .wp-block-columns:not(:first-of-type){
	padding-top: 40px;
}
.bl_info_item figure{
	margin-bottom: 0;
}
.bl_info_item .wp-block-image img{
	border-radius: 10px;
}
.bl_info_item h4{
	font-size: 1.6rem;
	color: var(--mian_color);
	margin-bottom: 0.8em;
    margin-top: 1em;
	padding-left: 1em;
}
.bl_info_item p{
	padding: 0 1em 1em;
}

.bl_info .bl_info_detail .wp-block-table table{
	border-top: none;
}
.bl_info_detail .wp-block-table td,
.bl_info_detail .wp-block-table th {
    padding: 1.5em 1em;
	border: none;
}
.bl_info_detail .wp-block-table th{
	color: var(--mian_color);
	border-bottom: 1px solid #fff;
}

@media screen and (max-width: 781px) {
	.bl_info_kv figure{
		width: 100%;
	}
	.bl_info_item.bl_columns_rev{
		flex-direction: column-reverse;
	}
	.bl_info_media .wp-block-columns.bl_info_item {
		align-items: normal !important;
	}
	.bl_info_detail table{
		display: flex;
	}
	.bl_info_detail table tbody,
	.bl_info_detail table tr{
		display: flex;
		flex-direction: column;
		width: 100%;
	}
	.bl_info_detail table th,
	.bl_info_detail table td{
		display: block;
		width: 100%;
	}
	.bl_info_detail .wp-block-table td,
	.bl_info_detail .wp-block-table th {
		padding: 1.5em 1em;
	}
}

/* ----------  業務内容  ---------- */

.smb-box p{
	    line-height: 1.25;
	margin: 0;}
.smb-box strong{
	    font-size: 2.185rem;}
.product-box .wp-block-image img {
	    background-color:#cfd7dd;
}
.summary-txt .sp-only{
		display:none;
	}
.summary-txt .pc-only{
		display:block;
	}
.summary-txt span{
    color: #082E7C;
    letter-spacing: 0.02em;
    line-height: 2;
    font-weight: bold;
	font-size: 1.8rem;
}
.product-box .wp-block-columns{
	margin-bottom:2em;
}

@media screen and (max-width: 786px) {
	.summary-txt .sp-only{
		display:block;
	}
	.summary-txt .pc-only{
		display:none;
	}
	.smb-box strong{
	   font-size: 1.8rem;}
	
}

.wp-block-image figcaption {
font-size: 1em!important;
    margin-top: 0.75em;
margin-bottom:0;
	color: #4586BF;
font-weight: bold;
line-height: 1.5;}


.wp-block-image figcaption span{
	    font-size: 0.8em;
	color: initial;
    font-weight: normal;
}

.round-img img{
	border-radius:5px;
}

/* ----------  お知らせ  ---------- */
.blog article,.single-post article{
	border-bottom: 1px solid #c5d1e5;
	padding-bottom: 50px;
}
.widget_recent_entries li a {
		border-bottom:none!important;
}

.sidebar-area h2{
	margin-top:0;
}
/* 投稿下のタグ一覧を非表示にする */
.tags-links {
    display: none !important;
}

/* コメントエリア（入力欄と履歴）を非表示にする */
#comments {
    display: none !important;
}

/* 記事エリア（メイン）の下に余白を追加 */
#primary {
    margin-bottom: 50px !important;
}
.blog .site-footer,.single-post .site-footer{
    clear: both !important;
    margin-top: 50px !important;
}

/* ----------  コンタクトフォーム  ---------- */
.site-content{
	max-width: 1040px;
}
.form-box .summary-text{
text-align: center;
	margin-bottom: 60px;
}

.form-box dl{
	display:flex;
	align-items:center;
	justify-content:space-between;
	margin-bottom:30px;
}
.required{
	color:#164F9E;
	font-size: 1.2em;
  padding-left: 0.15em;
}
.ac-text{
	color:#164F9E;
}
.entry-content dl p{
	margin-bottom:0;
}
.entry-content dt,
.entry-content dd{
	margin:0;
}
.entry-content dt{
font-size: 1.1em;
}
.entry-content p .wpcf7-form-control-wrap input[type="text"],.wpcf7 input[type="email"], .wpcf7 input[type="tel"] ,textarea {
    background-color: #fff;
    border: 1px solid #aebbcf;
    border-radius: 3px;
	padding: 0.6em;
	margin-top:0;
    width: 676px;
	height: 70px;
}
textarea {
	height: auto;
}
.radio-box{
	width: 676px;
}
.wpcf7-form-control .wpcf7-list-item:nth-child(1),.wpcf7-acceptance .wpcf7-list-item{
	margin:0;
}
.submit_btn{
	    text-align: center;
}
.submit_btn li{
	list-style:none;
}

input[type="submit"] {
        background: linear-gradient(180deg, #4586bf 0%, #164f9e 100%);
    }
input[type="submit"]:hover {
	background: linear-gradient(180deg, #70b3ee 0%, #2057a3 100%);
}
.form-box .submit_btn{
		margin:0;
	}
@media screen and (max-width: 980px) {
	.form-box dl {
	    flex-direction: column;
    align-items: start;
}
.entry-content dd,
.entry-content p .wpcf7-form-control-wrap input[type="text"], .wpcf7 input[type="email"], .wpcf7 input[type="tel"], textarea {
	max-width: none;
	width:100%;
}
.wpcf7-spinner{
display:none;
}
}


/* お問い合わせページ(page-id-57)footer--------- */
body.page-id-57 .site-footer{
	margin-top: 0;
}
body.page-id-57 .footer-widget-area{
    padding-top: 4rem;
}