@charset "utf-8";

.home #header_wrap {
	background: transparent;
}

.home #header_area {
	/*margin: 10px auto 0;*/
}

.home #header_wrap.smallhead #header_area {
	margin: 0 auto;
}

.home #logo img.logo_black {
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
}

.home .smallhead #logo img.logo_black {
	opacity: 1;
}

.home #header_wrap .menu_link {
	color: #fff !important;
}

.home #header_wrap.smallhead .menu_link {
	color: #222 !important;
}





/*---------------------------------------------------------
	Top 共通
---------------------------------------------------------*/

.top_link_btn{
	display: inline-block;
	text-decoration:none;
}

/*---------------------------------------------------------
	View More ピル型ボタン btn_pill / btn_w / btn_dot
---------------------------------------------------------*/
.btn_pill {
	display: inline-flex;
	align-items: center;
	gap: 70px;
	padding: 12px 24px;
	border: 2px solid #122C48;
	border-radius: 50px;
	text-decoration: none;
	transition: all 0.3s ease;
}
.btn_pill .btn_txt {
	margin-right: 0;
	font-size: 1.6rem;
	font-weight: 500;
	color: #122C48;
	letter-spacing: 0.05em;
}
.btn_pill .btn_txt:before,
.btn_pill .btn_txt:after {
	display: none;
}
.btn_pill .btn_dot {
	width: 10px;
	height: 10px;
	background: #ed1c24;
	border-radius: 50%;
	flex-shrink: 0;
}
.btn_pill:hover {
	opacity: 0.9;
}

/* btn_w: 線色ホワイト（暗い背景用） */
.btn_pill.btn_w {
	border-color: #fff;
	background: transparent;
}
.btn_pill.btn_w .btn_txt {
	color: #fff;
}
.btn_pill.btn_w:hover {
	border-color: rgba(255, 255, 255, 0.9);
}

/*---------------------------------------------------------
	Top
---------------------------------------------------------*/

.home main {
	letter-spacing: 0.12em;
}

#index_wrap {
	position: relative;
	width: 100%;
}

#index_main {
	/*background: #000000;*/
	position: relative;
	overflow: hidden;
}

#index_main .mv_img{
	height:100vh;
}

#index_main img{
	display: block;
    width: 100%;
    height: 100%!important;
	object-fit:cover;
	vertical-align:bottom;
	position: fixed;
	z-index: -1;
}

.mv_copy{
	position:absolute;
	left:11.9%;
	bottom: calc(50% - 176px);
	color:#fff;
}

.mv_copy h1{
	font-size:6.0rem;
	line-height:1.5;
	letter-spacing:0.02em;
}

.mv_copy .mv_copy_en{
	font-family: 'Roboto', sans-serif;
	display:block;
	font-size:2.0rem;
	letter-spacing:0;
	margin-top:20px;
}


.scroll{
	font-family: 'Roboto', sans-serif;
    font-size: 1.5rem;
    letter-spacing: 0;
    line-height: 16px;
    color: #fff;
    writing-mode: vertical-rl;
    position: absolute;
    bottom:110px;
    right: 20px;
    padding-bottom: 153px;
}

.scroll::before,
.scroll::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 1px;
    left: 0;
    width: 1px;
    height: 145px;
    margin: auto;
}

.scroll::before {
    background: #333;
}

.scroll::after {
    background: #fff;
    animation: scroll 3s infinite;
}

@keyframes scroll {
    0% {
        bottom: 145px;
        height: 0;
    }

    20% {
        bottom: 0;
        height:145px;
    }

    100% {
        height: 0;
    }
}

.top_ttl {
	position: relative;
	display: inline-block;
	margin-bottom: 50px;
}


.top_ttl h2 {
	font-size: 1.7rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	color: #ed1c24;
}

.top_ttl h2::before {
	display: block;
	content: attr(data-txt)'';
	font-family: 'Poppins', sans-serif;
	font-size: 6.8rem;
	font-weight: 400;
	letter-spacing: -0.02em;
	line-height:1.3;
	color: #122C48;
	white-space: pre-line;
}

.home .top_catch{
	font-size:2.8rem;
	font-weight:500;
	letter-spacing:0;
	line-height:1.5;
	margin-bottom:45px;
}
.home main p{
	line-height:2.0;
}

/*----------------
	about
--------------------*/

#index_about{
	padding:285px 0 150px 0;
	/*background:#dbdbdb;*/
}

.about_area{
	max-width:1240px;
	display:flex;
	flex-wrap:wrap;
	padding:0 20px;
	margin:0 auto;
	/*color:#fff;*/
}

.about_area .top_ttl{
	margin-bottom:35px;
}

.about_area {
	letter-spacing:0.05em;
}

.about_txt{
	width:50%;
	margin-top:100px;
}

.about_img{
	width:46%;
	margin-left:4%;
}
.about_img img{
	width:100%;
}

.about_area .top_catch,.about_area .top_ttl h2::before,
.business_head .top_catch,.business_head .top_ttl h2::before,
.features_head .top_catch,.features_head .top_ttl h2::before {
	color:#fff;
}
.about_area .top_ttl h2,.features_head .top_ttl h2 {
	color:#ed1c24;
}

.about_area p, .features_head p{
	color:#fff;
	margin-bottom:50px;
}
/*----------------
	Our Business / Our Features
--------------------*/

#index_business {
	padding: 0;
	overflow: hidden;
}

.business_contents {
	display: flex;
	flex-wrap: wrap;
	min-height: 600px;
	padding-top: 160px;
	background: #2750DF;
}

.business_contents .business_img {
	width: 50%;
	height: 100%;
	min-height: 800px;
	position: relative;
	overflow: hidden;
	flex-shrink: 0;
	align-self: flex-start;
}

.business_contents .business_img::before {
	display: none;
}

.business_contents .business_img img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.business_contents .business_head {
	max-width: 675px;
    width: 100%;
    min-height: 600px;
    padding: 30px 0 0 70px;
    display: flex;
    flex-direction: column;
}

.business_item_header {
	display: flex;
	align-items: center;
	gap: 15px;
	cursor: pointer;
	padding: 30px 0;
	border-top: 1px solid rgba(232, 235, 239, 0.5);
}

.business_contents .business_item_area:first-child .business_item_header {
	padding-top: 0;
	border-top: none;
}

.business_contents .business_item_area + .business_item_area .business_item_header {
	padding-top: 40px;
	border-top: 1px solid rgba(232, 235, 239, 0.5);
}

.business_toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	min-width: 36px;
	min-height: 36px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: rgba(176, 176, 208, 0.9);
	color: #122C48;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.3s ease;
	flex-shrink: 0;
}

.business_toggle:hover {
	background: rgba(176, 176, 208, 1);
}

.business_toggle_icon {
	display: block;
	position: relative;
	width: 14px;
	height: 14px;
}

.business_toggle_icon::before,
.business_toggle_icon::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	background: currentColor;
	transition: opacity 0.3s ease;
}

.business_toggle_icon::before {
	width: 14px;
	height: 1px;
	margin: -0.5px 0 0 -7px;
}

.business_toggle_icon::after {
	width: 1px;
	height: 14px;
	margin: -7px 0 0 -0.5px;
}

.business_item_area.is-open .business_toggle_icon::after {
	opacity: 0;
	pointer-events: none;
}

.business_contents .top_catch {
	display: flex;
    align-items: center;
	gap: 30px;
	color: #fff;
	margin: 0;
	padding: 0;
	border: none;
}

.business_contents .top_catch span {
	font-family: 'Poppins', sans-serif;
	font-size: 18px;
	font-weight: 500;
    letter-spacing: 2px;
	line-height: 1.5;
}

.business_item_txt {
	display: none;
	padding-bottom: 35px;
}

.business_item_area.is-open .business_item_txt {
	display: flex;
	flex-direction: column;
}

.business_contents .business_item_txt p {
	color: rgba(255, 255, 255, 0.9);
	line-height: 1.8;
	margin-bottom: 25px;
}

.business_contents .business_item_txt .top_link_btn {
	align-self: flex-end;
}

.business_contents .business_item_btn {
	text-align: right;
}

/* Our Features */
#index_features {
	padding-top: 120px;
	overflow: visible;
	background-color: #2750DF;
	position: relative;
	z-index: 2;
}

.features_contents {
	display: flex;
    min-height: 800px;
    justify-content: flex-end;
}

.features_contents .features_head {
	width: 50%;
	max-width: 675px;
	background: #2750DF;
	padding: 30px 70px 0 0;
	display: flex;
	flex-direction: column;
	order: 1;
	position: relative;
	z-index: 1;
}

.features_contents .features_img {
	width: 45%;
	min-width: 45%;
	position: relative;
	overflow: hidden;
	order: 2;
	align-self: stretch;
	min-height: 500px;
	padding-top: 80px;
	box-sizing: border-box;
	margin-bottom: -120px;
	z-index: 2;
}

.features_contents .features_img img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: left center;
}

.features_contents .top_catch {
	color: #fff;
}

.features_contents .features_item_txt p {
	color: rgba(255, 255, 255, 0.9);
	line-height: 1.8;
	margin-bottom: 25px;
}

.features_contents .features_item_txt {
	display: flex;
	flex-direction: column;
}

.features_contents .features_item_txt .top_link_btn {
	align-self: flex-end;
}

/*----------------
	Works
--------------------*/

#index_works {
	position: relative;
	z-index: 1;
	background: rgba(206, 215, 227, 0.50);
	padding: 135px 0 100px;
}

.works_area {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 20px;
}

.works_head {
	margin-bottom: 40px;
}

.works_head_ttl {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 20px;
}

/* Works カード */
.works_card {
	display: block;
	background: #fff;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	margin-right: 30px;
}

.works_card:hover {
	opacity: .7;
}

.works_card_img {
	width: 100%;
	overflow: hidden;
}

.works_card_img img {
	width: 100%;
	height: 100%;
	padding: 30px 20px 20px;
}

.works_card_body {
	padding: 0 20px 20px;
}

.works_card_tag {
    display: inline-block;
    padding: 3px 8px;
    color: #303B4E;
    font-size: 1.2rem;
    font-weight: 500;
    border: 1px solid #122C48;
}

/* 	
 	swiperここから 	*/

.swiper-wrapper {
	width: 100%;
	/*height: 250px;*/
	height:100%;
}

.swiper-slide {
	width: 100%;
	height: 100%;
}
.all_slide_controls {
	margin-top: 35px;
    position: relative;
    text-align: right;
}
.all_slide_controls ._bar {
    background: rgba(29, 43, 59, 0.08);
    width: calc(100% - 200px);
    height: 2px;
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
/* .all_slide_controls .swiper-scrollbar-drag {
    background: #0E5DA8;
} */

.swiper-scrollbar-drag {
    border-radius: 0 !important;
    background: #122C48 !important;
}

/*ページネーション*/
.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
  color: #000;
}

.swiper-scrollbar-drag{
	cursor:pointer;
}


.swiper-container{
	position: relative;
	width: calc(720px + 50vw);
    /*margin-top: 45px;*/
    padding-right: 60px;
	padding-bottom: 50px;
}
.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    box-sizing: content-box;
}


.home .swiper-container .swiper-scrollbar{
	background: #fff;
	max-width:1350px;
    width: calc(100% - 200px);
    position: absolute;
   left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.swiper-slide .works_card {
	height: 100%;
}

/*----------------
	Blog
--------------------*/
#index_blog {
	padding: 100px 0 110px;
	position: relative;
	z-index: 1;
	background: #fff;
}

.blog_area {
    display: flex;
    flex-direction: row;
    max-width: 1390px;
    margin: 0 auto;
    padding: 0 20px;
    gap: 60px;
    align-items: flex-start;
}

.blog_head {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	gap: 60px;
	align-items: flex-start;
}

.blog_head_l {
	width: 35%;
	min-width: 280px;
}


.blog_desc {
	font-size: 1.5rem;
	line-height: 1.6;
	color: #303B4E;
	margin: 12px 0 24px 0;
}

.blog_viewmore_wrap {
	margin-top: 0;
}

.blog_head_r {
	flex: 1;
	min-width: 0;
}

.blog_list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.blog_item {
	border-bottom: 1px solid #E5E7EB;
		transition: 0.3s ease;
}

.blog_item:first-child {
	border-top: 1px solid #E5E7EB;
}

li.blog_item:hover {
    opacity: .7;
}

.blog_link {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 24px 40px 24px 0;
	text-decoration: none;
	color: #303B4E;
	transition: color 0.3s ease;
	position: relative;
}

.blog_link::after {
	content: '';
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: 12px;
	background: url(../img/arrow_blue.svg) center center / contain no-repeat;
}

.blog_link:hover {
	color: #122C48;
}

.blog_thumb {
	display: block;
    width: 120px;
    min-width: 320px;
    height: 240px;
    overflow: hidden;
    flex-shrink: 0;
}

.blog_thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.blog_thumb_placeholder {
	display: block;
	width: 100%;
	height: 100%;
	background: #122C48;
}

.blog_info {
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
	min-width: 0;
}

.blog_date {
	font-size: 1.4rem;
	color: #122C48;
	letter-spacing: 0.05em;
}

.blog_title {
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: 500;
}









/*----------------
	news
--------------------*/
#index_news {
	padding: 100px 0 110px 0;
	position: relative;
	z-index: 1;
	background:#fff;
}

.news_area {
	display: flex;
	flex-wrap: wrap;
	max-width: 1240px;
	margin: auto;
	padding: 0 20px;
}

.news_head {
	position: relative;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}

.news_head_l {
	width: 21.25%;
}

.news_head_r {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 20px;
}

.news_cat_list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.news_cat_item {
	margin: 0;
	padding: 0;
}

.news_cat_btn {
	display: inline-block;
	width: 160px;
    padding: 8px 0;
	border: none;
	border-radius: 50px;
	background: #F2F5F9;
	color: #122C48;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	transition: all 0.3s ease;
}

.news_cat_btn:hover {
	background: #CCD7E5;
}

.news_cat_btn.active {
	background: #CCD7E5;
	color: #122C48;
}

.news_content {
	position: relative;
	width: 100%;
}

.news_list_wrap {
	display: none;
}

.news_list_wrap.active {
	display: block;
}

.news_item {
	border-bottom: 1px solid #ccc;
}
.news_item:first-child{
	border-top: 1px solid #ccc;
}

.news_viewmore_wrap {
	text-align: right;
	margin-top: 30px;
}

.news_link {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	text-decoration: none;
	color: #122C48;
	padding: 45px 40px 45px 0;
	transition: all 0.3s;
	position: relative;
}

.news_link::after {
	content: '';
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: 12px;
	background: url(../img/arrow_blue.svg) center center / contain no-repeat;
}

.news_link:hover {
	opacity: .7;
}

.news_link .news_meta {
	display: flex;
	align-items: center;
	gap: 15px;
	width: 100%;
	margin-bottom: 25px;
}

.news_link .news_date {
	letter-spacing:0.05em;
	font-size: 1.6rem;
}

.news_link .news_cate {
	font-weight: 500;
    letter-spacing: 0;
    padding: 8px 0;
    font-size: 1.6rem;
    color: #2B5872;
    width: 100px;
    background: #F2F5F9;
    text-align: center;
}

.news_link .news_title {
	width: 100%;
	font-size: 18px;
	letter-spacing:0.05em;
}

/*----------------
	recruit (Join us!)
--------------------*/
#index_recruit {
	position: relative;
	overflow: visible;
}

.recruit_wrap {
	position: relative;
}

.recruit_top {
	position: relative;
	min-height: 1165px;
}

.recruit_bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	background-image: url(../img/index_recruit_bg.jpg);
	background-size: auto;
	background-repeat: no-repeat;
}

.recruit_inner {
	position: relative;
	z-index: 1;
	max-width: 1240px;
	margin: 0 auto;
	padding: 180px 20px 180px;
}

.recruit_ttl {
	font-family: 'Whisper', cursive;
	font-size: 240px;
	font-weight: 400;
	color: #122C48;
	line-height: 1.2;
	margin: 0 0 10px 0;
}

.recruit_ttl::before {
	display: block;
	content: attr(data-txt)'';
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
	color: #345BE0;
}

.recruit_ttl .sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	border: 0;
}

.recruit_sub_wrap {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 90px;
}

.recruit_line {
	flex-shrink: 0;
	width: 100px;
	height: 1px;
	background: #122C48;
}

.recruit_sub {
	font-size: 1.6rem;
	font-weight: 700;
	color: #E53935;
	letter-spacing: 0.05em;
	margin: 0;
}

.recruit_txt {
	font-size: 1.5rem;
	line-height: 1.8;
	color: #303B4E;
	margin: 0 0 65px 0;
}

.recruit_btn {
	border-color: #122C48;
}

/* .recruit_btn .btn_txt {
	color: #122C48;
}
 */
.recruit_bottom {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: #2750DF;
	padding: 0 20px 60px;
	z-index: 2;
}

.recruit_sns {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: flex-start;
	list-style: none;
	padding: 0;
	margin: -105px auto 0;
	max-width: 1240px;
	position: relative;
	z-index: 3;
}

.recruit_sns_item {
	flex: 1;
	min-width: 280px;
	max-width: calc(33.333% - 14px);
}

.recruit_sns_item a {
	display: block;
	text-decoration: none;
	transition: opacity 0.3s ease;
	overflow: hidden;
}

.recruit_sns_item a:hover {
	opacity: 0.9;
}

.recruit_sns_item img {
	width: 100%;
	height: auto;
	display: block;
	vertical-align: top;
}

/*----------------
	footer_contact (home)
--------------------*/
.home .footer_contact {
	background: #2750DF;
	padding: 80px 0 100px;
}

.home .f_contact_in {
	flex-direction: column;
	align-items: stretch;
}

.home .f_contact_head {
	text-align: center;
	margin-bottom: 50px;
}

.f_contact_head.top_ttl h2::before {
	color: #fff !important;
}

.home .f_contact_sub {
	font-size: 1.5rem;
	color: rgba(255,255,255,0.9);
	margin: 0 0 15px 0;
}

.home .f_contact_txt {
	font-size: 1.5rem;
	line-height: 1.8;
	color: rgba(255,255,255,0.85);
	margin: 0;
}

.home .f_contact_body {
	display: flex;
	flex-wrap: wrap;
	gap: 75px;
	max-width: 1240px;
	margin: 0 auto;
	align-items: flex-start;
}

.home .f_contact_col.f_contact_tel {
    border-right: 1px solid rgba(255, 255, 255, 0.5);
    padding-right: 75px;
}

.home .f_contact_col h3 {
	font-size: 1.8rem;
	font-weight: 700;
	color: #fff;
	margin: 0 0 20px 0;
	text-align: center;
}

.f_contact_tel_inner {
    display: flex;
	    gap: 90px;
}

.home .f_tel_num,
.home .f_fax_num {
/* 	display: flex;
	align-items: center; */
	gap: 12px;
	font-size: 3.2rem;
	font-weight: 700;
	color: #fff;
	margin: 0 0 12px 0;
	position: relative;
}

.home .f_tel_icon,
.home .f_fax_icon {
display: inline-block;
    width: 55px;
    /* height: 0px; */
    /* position: relative; */
    opacity: 0.6;
}

.home .f_tel_icon::before,
.home .f_fax_icon::before {
content: '';
    position: absolute;
    top: 10%;
    left: -10%;
    /* transform: translate(15%, 0%); */
    width: 55px;
    height: 55px;
    background-size: contain;
    /* background-position: center; */
    background-repeat: no-repeat;
}

.home .f_tel_icon::before {
	background-image: url(../img/icon_tel.png);
}

.home .f_fax_icon::before {
	background-image: url(../img/icon_fax.png);
}

.home .f_tel_time {
	font-size: 1.3rem;
    color: rgba(255, 255, 255, 0.8);
    /* margin: 15px 0 0 0; */
    text-align: center;
    display: block;
}

.home .f_form_btn {
	display: inline-block;
	padding: 15px 60px;
	background: #ED1C24;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 700;
	text-decoration: none;
	transition: background 0.3s ease;
}

.home .f_form_btn:hover {
	background: #C62828;
}



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

	#toggle a span, #toggle a::before, #toggle a::after{
		background:#fff;
	}

	.home #header_wrap .menu_link {
		        margin: 0 auto;
	}

	.home #header_wrap.smallhead .menu_link {
		color: #fff !important;
	}

	/*----------------
		Top 共通
	-----------------*/
	
	.top_ttl{
		margin-bottom:30px;
	}
	.top_ttl h2{
		font-size:1.4rem;
	}
	.top_ttl h2::before{
		font-size:4.0rem;
	}
	.home .top_catch{
		font-size:2.0rem;
		margin-bottom:20px;
	}
	
	
	
	
	
	#index_main .mv_img{
		
	}
	
	.mv_copy{
		left:30px;
		right:20px;
		bottom:45%;
	}

	.mv_copy h1{
		font-size:3.2rem;
	}
	
	.mv_copy .mv_copy_en{
		font-size:1.4rem;
		margin-top:10px;
	}
	

	.scroll{
		bottom:40px;
	}
	
	
	
	/*----------------
		about
	--------------------*/
	
	#index_about{
		padding:100px 0 70px 0;
	}
	
	.about_txt{
		width:100%;
		margin-top:0;
	}
	.about_img{
		width:100%;
		margin-left:0;
		margin-top:20px;
	}
	
	.about_area p{
		margin-bottom:20px;
	}

	
	/*----------------
		Our Business / Our Features (SP)
	--------------------*/
	
	.business_contents,
	.features_contents {
		flex-direction: column;
		min-height: auto;
		padding-top: 0;
	}
	
	.business_contents .business_img,
	.business_contents .business_head,
	.features_contents .features_head,
	.features_contents .features_img {
		width: 100%;
	}

	.features_contents .features_img {
		margin-left: 0;
		min-width: 100%;
		order: 2;
	}
	
	.business_contents .business_img::before {
		padding-top: 60%;
	}
	
	.features_contents .features_img::before {
		padding-top: 60%;
	}
	
	.business_contents .business_head,
	.features_contents .features_head {
		padding: 50px 20px 0;
		order: 2;
	}
	
	.business_contents .business_img {
		order: 1;
		min-height: 100%;
	}
	
	.business_contents .business_img img {
		position: unset;
	}
	
	.business_contents .business_head {
		max-width: 100%;
		width: 100%;
		min-height: 100%;
	}
	
	#index_features {
		padding-top: 0;
	}
	
	.features_contents .features_head {
		order: 1;
	}
	
	/*----------------
		Works (SP)
	--------------------*/
	
	#index_works {
		padding: 50px 0 80px;
	}
	
	.works_head_ttl {
		flex-direction: column;
		align-items: flex-start;
	}
	
	.swiper-container{
		width: 106.2%;
	}
	.home .swiper-container .swiper-scrollbar{
		width:calc(100% - 20px);
	}
	
	.works_card_body {
		padding: 16px 20px 20px;
	}
	
	.works_card_txt {
		font-size: 1.3rem;
	}

	/*----------------
		Blog (SP)
	--------------------*/
	#index_blog {
		padding: 50px 0 60px;
	}

	.blog_head {
		flex-direction: column;
		gap: 30px;
	}

	.blog_head_l {
		width: 100%;
		min-width: 0;
	}

	.blog_link {
		padding: 20px 30px 20px 0;
		gap: 16px;
	}

	.blog_thumb {
		width: 100px;
		min-width: 100px;
		height: 75px;
	}

	.blog_title {
		font-size: 1.4rem;
	}

	/*----------------
		news
	--------------------*/
	#index_news {
		padding: 50px 0 60px;
	}


	.news_head {
		width: 100%;
		margin-right:0;
		margin-bottom: 30px;
	}

	.news_head_l {
		width: 100%;
		margin-bottom: 20px;
	}

	.news_cat_sp {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 15px;
		margin-bottom: 20px;
	}

	.news_cat_sp .news_cat_list {
		gap: 8px;
	}

	.news_cat_sp .news_cat_btn {
		width: 100%;
		padding: 6px 16px;
		font-size: 1.2rem;
	}

	.news_content {
		width: 100%;
	}

	.news_list{
		margin-bottom:20px;	
	}
	
	.news_link {
		padding: 15px 30px 15px 0;
	}

	.news_link .news_meta {
		gap: 10px;
		margin-bottom: 6px;
	}

	.news_link .news_date {
		font-size: 1.3rem;
	}

	.news_link .news_cate {
		font-size: 1.1rem;
	}

	.news_viewmore_wrap {
		margin-top: 20px;
	}

	.news_content .link_btn {
		text-align: center;
	}

	.news_content .link_btn a {
		margin-bottom: 0;
	}

	/*----------------
		recruit (SP)
	--------------------*/
	.recruit_inner {
		padding: 50px 20px 140px;
	}

	.recruit_ttl {
		font-size: 120px;
	}

	.recruit_txt {
		font-size: 1.4rem;
	}

	.recruit_sns {
		margin: -80px auto 0;
		flex-direction: column;
		gap: 15px;
	}

	.recruit_sns_item {
		max-width: 100%;
		min-width: 100%;
	}

	.recruit_bottom {
		padding: 0 20px 0;
	}

	/*----------------
		footer_contact (SP)
	--------------------*/
	.home .footer_contact {
		padding: 60px 0 80px;
	}

	.home .f_contact_head {
		margin-bottom: 40px;
	}

	.home .f_contact_head h2::before {
		font-size: 4.5rem;
	}

	.home .f_contact_body {
		flex-direction: column;
		gap: 10px;
	}

	.home .f_contact_col {
		min-width: 100%;
	}

	.home .f_contact_col.f_contact_form {
		border-left: none;
		border-top: 1px solid rgba(255, 255, 255, 0.5);
		padding-left: 0;
		padding-top: 30px;
		text-align: center;
	}

	.home .f_tel_num,
	.home .f_fax_num {
		font-size: 1.8rem;
		text-align: center;
	}
	
	.f_contact_tel_inner {
    gap: 0;
    flex-direction: column;
		align-items: center;
	}
	
	.home .f_contact_col.f_contact_tel {
    border-right: none;
    padding-right: 0;
}
	
	.home .f_tel_icon::before, .home .f_fax_icon::before {
		top: 13%;
        left: 12%;
        width: 25px;
        height: 25px;
	}


}