@charset "utf-8";


#english .h1-area {						
	position: absolute;
	top: 391px;
	right: 50px;
}
@media screen and (max-width: 768px) {
	 #english .pagetitle-area .mv-area {
        margin-top: 60px;
        margin-bottom: 45px;
    }
	#english .h1-area {
		top: 190px;
		right: 0;
		padding: 7px 10px;
		line-height: 1.4;
		background-color: #fff;
		width: 100%;
		z-index: 1;
	}
}

/* -----------------------------------------------------------
    アンカーリンクのずれ調整
-------------------------------------------------------------- */
.en-link {
    /*margin-top: -180px;
    padding-top: 180px;*/
	margin-top: -100px;
    padding-top: 100px;
}

@media screen and (max-width: 768px) {
	.en-link {
		margin-top: -70px;
		padding-top: 70px;
	}
}

/* -----------------------------------------------------------
    英語ページ header
-------------------------------------------------------------- */
/*多言語*/
#pc-head .gnav-lang {
	margin: 15px 210px 0 auto;
}
#pc-head .gnav {
	margin: 0 190px 0 auto;
}

.megamenu-wrap li .txt-area {
    line-height: 1.2;
}
@media screen and (max-width: 768px) {
	.sp-head-btn {
        right: 0;
		font-weight: 500;
    }
	.sp-head-btn a {
        background: linear-gradient(37deg, var(--main-brown), var(--light-brown));
		color: #fff;
    }
}

/* -----------------------------------------------------------
    英語ページ contact-en-block
-------------------------------------------------------------- */
.contact-en-block .contact-cmn-en-area {
	background-color: var(--main-blue);
	color: #fff;
	position: relative;
	height: 480px;
	padding: 65px 0;
}
.contact-en-block .contact-cmn-en-area::before {
    content: "";
    display: inline-block;
    left: 0;
    top: 0;
    background: url(../img/foot-contact-img.jpg) center/cover, no-repeat;
    position: absolute;
    width: 36%;
    height: 480px;
    aspect-ratio: 144 / 119;
	-webkit-clip-path: polygon(0% 0%, 100% 0%, 45% 100%, 0% 100%);
	clip-path: polygon(0% 0%, 100% 0%, 50% 100%, 0% 100%);
}

.contact-en-block.block02 .contact-cmn-en-area {
	height: 410px;
}
.contact-en-block.block02 .contact-cmn-en-area::before {
    height: 410px;
}

.contact-en-block .contact-cmn-en-txtbox {
	margin: 0 auto 0 38%;
}
.contact-en-block .contact-cmn-en-title {
	font-size: 3.5rem;
	/*font-weight: bold;*/
	line-height: 1.8;
	letter-spacing: .08em;
	margin-bottom: 30px;
	font-family: var(--main-en);
}
.contact-en-block .contact-cmn-en-txt {
	font-size: 2rem;
	margin-bottom: 30px;
	line-height: 1.8;
}
.contact-en-block a.contact-cv {
	display: flex;
    justify-content: center;
	align-items: center;
    text-align: center;
    width: 220px;
    height: 60px;
    padding: 10px 12px;
    position: relative;
	font-size: 1.8rem;
    font-weight: bold;
    white-space: nowrap;
    letter-spacing: .08em;
    overflow: hidden;
    line-height: 1;
	color: #fff;
	background: linear-gradient(37deg, var(--main-brown), var(--light-brown));
}
.contact-en-block a.contact-cv:hover {
	opacity: 0.8;
}

.contact-en-block.block02 a.contact-cv {
	display: none;
}

@media screen and (max-width: 768px){
	.contact-en-block .contact-cmn-en-area,
	.contact-en-block.block02 .contact-cmn-en-area {
		padding: 50px 20px;
		height: auto;
	}	
	.contact-en-block .contact-cmn-en-title {
		font-size: 2.4rem;
		text-align: center;
		margin-bottom: 20px;
	}
	.contact-en-block .contact-cmn-en-txt {
		font-size: 1.7rem;
		line-height: 1.7;
		text-align: left;
		margin-bottom: 0;
	}	
	.contact-en-block .contact-cmn-en-area::before {
		display: none;
	}	
	.contact-en-block .contact-cmn-en-txtbox {
		margin: 0;
	}
	
	.contact-en-block a.contact-cv {
		width: 100%;
		height: 60px;
		margin: 30px 0 0;
	}
}	


/* -----------------------------------------------------------
    英語ページ footer
-------------------------------------------------------------- */
.footer {
    padding: 30px 20px 30px;
}
.f-copy {
	margin-top: 0;
}
/*.f-sitemap-area {
    gap: 65px;
}
.f-sitemap-wrap .foot-wide {
    width: 100px;
}
.f-sitemap-wrap li {
    width: 185px;
}*/
@media screen and (max-width: 768px) {
	.footer {
		padding: 30px 20px 70px;
	}
	.fixed-btn .wrap li.cv {
        display: block;
        width: 100%;
    }
}

/* -----------------------------------------------------------
    menu-box
-------------------------------------------------------------- */
#menu-box {
	display: none;
}

@media screen and (max-width: 768px) {
	#menu-box {
		display: block;
		position: absolute;
		width: 100%;
		z-index: 5;
	}

	#menu-box.menu-fix {
		position: fixed;
		top: 0;
		left: 0;
		z-index: 16;
		width: 100%;
	}
	
	#menu-box .menu-inner {
		display: block;
		min-width: unset;
		max-width: unset;
		margin: 0 auto;
	}

	#menu-box .menu-nav {
		display: none;
		height: auto;
		position: relative;
		z-index: 16;
		/*background: #F3F4F5;*/
		background: #fff;
	}

	#menu-box .menu-nav ul {
		padding: 5px 20px 0;
		display: block;
	}

	#menu-box .menu-nav ul li {
		display: block;
		margin: 0;
		text-align: left;
		width: 100%;
		font-size: 1.6rem;
		max-width: unset;
	}
	
	#menu-box .menu-nav ul .top {
		display: block;
	}
	
	#menu-box .menu-list a {
		font-size: 1.6rem;
		font-weight: 500;
		height: auto;
		display: block;
		border-bottom: #ccc solid 1px;
		position: relative;
		padding: 13px 0;
	}
	
	#menu-box .menu-nav ul li:last-child a {
		border-bottom: none;
	}
	
	#menu-box .menu-list span {
		padding: 0 0 0 25px;
		position: relative;
		transition: .3s;
		line-height: 1.4;
		letter-spacing: .05em;
		color: #333;
	}
	
	#menu-box .menu-list span::before {
		position: absolute;
		content: "\f078";
		display: block;
		top: 52%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		left: 0px;
		font-family: "FontAwesome";
		font-size: 1.4rem;
		color: var(--main-blue);
		transition: .5s;
	}
	
	#menu-box .menu-nav ul .menu-form a {
		height: 60px;
		padding: 15px 20px 15px 10px;
		width: 100%;
	}

	#menu-box .menu-nav ul li a:hover, #menu-box .menu-nav ul .menu-form a:hover {
		color: #231815;
	}
	
	#menu-box .menu-nav ul .menu-form img {
		margin: 0;
		width: 22px;
	}
}

/* -----------------------------------------------------------
    more_btn
-------------------------------------------------------------- */
.more_btn_en {
	display: none;
}

@media screen and (max-width:768px) {
	.more_btn_en {
		padding: 15px 20px;
		display: flex;
		justify-content: flex-end;
		width: 100%;
		background: #F3F4F5;
	}
	
	.menu-fix#menu-box {
		box-shadow: 0px 3px 10px -5px rgba(0, 0, 0, .3);
	}
	
	.btn02-txt-wrap {
		display: flex;
		align-items: center;
		gap: 10px;
	}

	.more_btn_en .more-btn02-txt {
		position: relative;
		font-size: 2rem;
        font-family: var(--main-en);
	}
	
	.more_btn_en .cmn-more-deco {
		background: var(--main-blue);
		height: 24px;
		width: 24px;
		position: relative;
		display: inline-block;
	}

	.more_btn_en .cmn-more-deco::after, .cmn-more-deco::before {
		background: #fff;
		border-radius: 1px;
		content: "";
		position: absolute;
		transition: all .3s;
	}

	.more_btn_en .cmn-more-deco::before {
		height: 2px;
		right: 5px;
		width: 14px;
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
	}

	.more_btn_en .cmn-more-deco::after {
		height: 14px;
		right: 11px;
		top: 5px;
		width: 2px;
	}
	
	.more_btn_en.open .cmn-more-deco::after {
		transform: rotate(90deg);
	}
	
	.menu-nav {
		z-index: 5;
		overflow-y: scroll;
		width: 100%;
		height: 100%;
		-webkit-overflow-scrolling: touch;
		padding: 0 0 10px;
	}
	
	.more_btn_en ul {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		gap: 20px;
	}
}

/* -----------------------------------------------------------
    common.cssから調整分
-------------------------------------------------------------- */
.sec-title {
	font-family: var(--main-en);
	letter-spacing: .07em;
	font-weight: 500;
}
.pagetitle-area .section-title-en {
	line-height: 1.3;
}

/* -----------------------------------------------------------
    en-about-area
-------------------------------------------------------------- */
.en-about-area .en-about-title {
	font-weight: 500;
	font-size: 3.1rem;
	font-family: var(--main-en);
	color: var(--main-blue);
	line-height: 1.8;
	letter-spacing: .07em;
	margin-bottom: 30px;
}
.en-about-area {
	position: relative;
	/*padding: 200px 0 25px;*/
	padding: 200px 0 135px;
}
.en-about-area::after {
    content: "";
    display: inline-block;
    right: 0;
    top: 80px;
    background: url(../img/about-us-intro-en.jpg) center/cover, no-repeat;
    border-radius: 10px 0 0 10px;
    position: absolute;
    width: 40%;
    height: 445px;
    aspect-ratio: 65 / 46;
    z-index: 0;
}
.en-about-area::before {
    content: "";
    display: inline-block;
    left: 0;
    top: 130px;
    background: var(--recruit-bg-blue);
    border-radius: 0 10px 10px 0;
    position: absolute;
    width: 40%;
    height: 290px;
    aspect-ratio: 65 / 46;
    z-index: -1;
}
.en-about-area .en-about-box {
	width: 635px;
	position: relative;
}
.en-about-area .en-about-box::before {
    content: "";
    display: inline-block;
    right: -400px;
    bottom: -95px;
    background: #E2EDFF;
    border-radius: 10px;
    position: absolute;
    width: 345px;
    height: 208px;
    z-index: -1;
}
.en-about-area .en-about-txt {
	line-height: 2;
	margin-bottom: 30px;
	font-size: 1.7rem;
}
.en-about-area .en-about-txt:last-of-type {
    margin-bottom: 0;
}

/* スライド部分 */
.about-slide {
    display: flex;
    overflow: hidden;
	margin-top: 210px;
}
.about-slide ul {
    display: flex;
    animation: about-slide-img 40s infinite linear .8s both;
    flex-shrink: 0;
}
.about-slide li {
    width: 370px;
    height: 100%;
    flex-shrink: 0;
}
.about-slide li img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@keyframes about-slide-img {
	0% {
		transform: translateX(0);
	}

	100% {
		transform: translateX(-100%);
	}
}
@media screen and (max-width: 768px){
    .en-about-area::after {
        display: none;
    }    
    .en-about-area .en-about-box {
        width: 100%;
        padding: 0 20px 30px;
    }    
    .en-about-area .en-about-title {
        font-size: 2.1rem;
        margin-bottom: 20px;
    } 
    .en-about-area::before {
        left: 0;
        top: 28px;
        border-radius: 0 5px 5px 0;
        width: 40%;
        height: 104px;
    }   
    .en-about-area {
        /*padding: 90px 0 25px;*/
		padding: 90px 0 0;
    } 
    .en-about-area .en-about-box::before {
        right: 0px;
        bottom: 27px;
        border-radius: 5px 0 0 5px;
        width: 228px;
        height: 122px;
    }  
	.en-about-area .en-about-txt {
		font-size: 1.6rem;
	}
    .about-slide {
        margin-top: 30px;
    } 
    .about-slide li {
        width: 215px
    }    

}    

/* -----------------------------------------------------------
    飯山特殊硝子の4つの強み
-------------------------------------------------------------- */
.en-strong-area .about-title-en {
    font-family: var(--main-en);
    color: var(--main-blue);
    font-weight: 500;
    font-size: 4.3rem;
    letter-spacing: .07em;
    margin-bottom: 15px;
}
.en-strong-area .about-title {
    font-size: 3.2rem;
    font-weight: 500;
	font-family: var(--main-en);
    color: var(--main-blue);
    letter-spacing: .07em;
    margin-bottom: 30px;
} 
.en-strong-area .about-title-num {
    font-size: 5rem;
    font-family: var(--main-en);
    font-weight: 500;
    color: #5788DE;
}    
.en-strong-area .about-lead {
    font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: .07em;
    margin-bottom: 50px;
    line-height: 1.6;
}    
.en-strong-area .about-title-area {
    text-align: center;
}       

.en-strong-area {
    background: url(../img/about-bg.jpg)center/cover no-repeat;
	/*padding: 125px;*/
	padding: 100px 125px;
    position: relative;
}
.en-strong-area .en-strong-box {
	display: flex;
	margin-bottom: 50px;
    align-items: stretch;
}
.en-strong-area .en-strong-box:last-of-type {
	margin-bottom: 0;
}
.en-strong-area .en-strong-img {
	width: 40%;
}
.en-strong-area .en-strong-img img {
	width: 100%;
    border-radius: 10px 0 0 10px;
}
.en-strong-area .reverse .en-strong-img img {
    border-radius: 0 10px 10px 0;
}    
.en-strong-area .en-strong-title {
	color: var(--main-blue);
	font-weight: 500;
	font-family: var(--main-en);
	letter-spacing: .07em;
	font-size: 2.3rem;
	position: relative;
	border-bottom: 2px solid var(--main-blue);
	padding-bottom: 20px;
	margin-bottom: 15px;
    padding-left: 60px;
}
.en-strong-area .en-strong-title::before {
    content: "";
    position: absolute;
    background: url(../img/strong1.png)center/contain no-repeat;
    width: 53px;
    height: 47px;
    top: 11px;
    left: 20px;
    transform: translate(-50%,-50%);
}
.en-strong-area .st-title2::before {
    background: url(../img/strong4.png)center/contain no-repeat;
    width: 43px;
    height: 39px;
}
.en-strong-area .st-title3::before {
    background: url(../img/strong3.png)center/contain no-repeat;
    width: 63px;
    height: 56px;    
}
.en-strong-area .st-title4::before {
    background: url(../img/strong2.png)center/contain no-repeat;
    width: 59px;
    height: 40px;    
}

.en-strong-area .en-strong-txtbox {
	background-color: #fff;
	width: 70%;
    border-radius: 0 10px 10px 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 20px 50px;
}
.en-strong-area .en-strong-txt {
	line-height: 1.8;
	margin-bottom: 30px;
	font-size: 1.6rem;
}
.en-strong-area .en-strong-txt:last-of-type {
    margin-bottom: 0;
}
.en-strong-area .reverse {
    flex-direction: row-reverse;
}
.en-strong-area .reverse .en-strong-txtbox {
    border-radius: 10px 0 0 10px;
}  
.en-strong-area::after {
    content: "STRONG POINT";
    color:rgba(255, 255, 255, 0.5);
    font-family: var(--main-en);
    font-size: 19rem;
    writing-mode: vertical-rl;
    font-weight: 500;
    position: absolute;
    letter-spacing: .07em;
    left: 0;
    bottom: 0;
    z-index: 0;
}  
@media screen and (max-width: 768px){
    .en-strong-area {
        padding: 50px 20px;
    }  
    .en-strong-area .en-strong-box {
        flex-direction: column;
        margin-bottom: 30px;
    }
    .en-strong-area .en-strong-img {
        width: 100%;
        height: 250px;
        overflow: hidden;
        display: flex;
        justify-content: center;
        align-items: center;
        border-radius: 10px 10px 0 0;
    }      
    .en-strong-area .en-strong-txtbox {
        width: 100%;
        padding: 30px 15px;
        border-radius: 0 0 10px 10px;
    }    
	.en-strong-area .en-strong-txt {
		font-size: 1.6rem;
	}
	.en-strong-area .about-title-en {
        font-size: 3.9rem;
        margin-bottom: 7px;
    }    
    .en-strong-area .about-title {
        font-size: 2.2rem;
        margin-bottom: 25px;
    }   
    .en-strong-area .about-lead {
        font-size: 1.7rem;
        text-align: left;
        line-height: 1.8;
        margin-bottom: 40px;
    }    
    .en-strong-area .en-strong-img img {
        border-radius: 10px 10px 0 0;
    }   
    .en-strong-area .reverse .en-strong-img img {
        border-radius: 10px 10px 0 0;
    }  
    .en-strong-area .reverse .en-strong-txtbox {
        border-radius: 0 0 10px 10px;
    }  
    .en-strong-area::after {
        font-size: 5.7rem;
        writing-mode: horizontal-tb; 
        font-weight: 500;
        position: absolute;
        letter-spacing: .07em;
        left: 0;
        bottom: 0;
        z-index: 0;
    }  
    .en-strong-area .en-strong-title {
        font-size: 2rem;
        padding-bottom: 10px;
        padding-left: 55px;
        line-height: 1.3;
    }  
    .en-strong-area .en-strong-title::before {
        width: 34px;
        height: 30px;
        transform: translateY(-50%);
        top: 30%;
        left: 7px;
    }   
    .en-strong-area .st-title2::before {
        width: 30px;
        height: 27px;
        transform: translateY(-50%);
        top: 30%;
        left: 7px;
    }     
    .en-strong-area .st-title3::before {
        width: 42px;
        height: 37px;
        transform: translateY(-50%);
        top: 30%;
        left: 7px;
    }  
    .en-strong-area .st-title4::before {
        width: 45px;
        height: 24px;
        transform: translateY(-50%);
        top: 40%;
        left: 7px;
    }       
}

/* -----------------------------------------------------------
    業界別・分野別に見る（共通箇所）
-------------------------------------------------------------- */
.en-industry-area {
	position: relative;
}
.en-industry-area::before {
	content: "";
    position: absolute;
    background-color: var(--main-black);
	width: 100%;
	height: 100%;
	z-index: -100;
}
.sec-catch-box {
	display: flex;
	justify-content: space-between;
	gap: 120px;
	padding-top: 100px;
}
.sec-catch-box2 {
	gap: 120px;
	padding-top: 130px;
}
.sec-lead-title {
    font-size: 3.2rem;
	font-family: var(--main-en);
	font-weight: 500;
	letter-spacing: .07em;
}
@media screen and (max-width: 768px){
	.sec-catch-box {
		flex-direction: column;
		gap: 25px;
		text-align: center;
		padding-top: 85px;
	}
	.sec-catch-box2 {
		gap: 25px;
		padding-top: 85px;
	}
	.sec-lead-title {
		font-size: 2rem;
		padding: 0 20px;
	}
}

/* 業界＆技術の流れる文字 */
.slide-txt-area {
	position: relative;
	/*padding-bottom: 100px;*/
	padding-bottom: 50px;
}
.slide-txt-area .slide-industry {
	display: block;
	position: absolute;
	width: 100%;
	overflow: hidden;
	z-index: -1;
	top: 20px;
	background: url("../img/slide-industry.png") repeat-x 0 0;
	background-size: 2411px auto;
	height: 174px;
	-moz-animation: loop_industry 40s linear infinite;
	animation: loop_industry 40s linear infinite;
}
@keyframes loop_industry {
	0% {
		background-position: -2411px 0;
		}

	100% {
		background-position: 0 0;
		}
}
.slide-txt-area .slide-technology {
	display: block;
	position: absolute;
	width: 100%;
	overflow: hidden;
	z-index: -1;
	top: 58px;
	background: url("../img/slide-technology.png") repeat-x 0 0;
	background-size: 2988px auto;
	height: 175px;
	-moz-animation: technology 40s linear infinite;
	animation: technology 40s linear infinite;
}
@keyframes technology {
	0% {
		background-position: 2988px 0;
		}

	100% {
		background-position: 0 0;
		}
}
@media screen and (max-width: 768px){
	.slide-txt-area .slide-industry {
		height: 73px;
		background-size: 1000px auto;
		top: 48px;
	}
	.slide-txt-area .slide-technology {
		height: 73px;
		background-size: 1300px auto;
		top: 48px;
	}
	.slide-txt-area {
		padding-bottom: 0;
	}		

}	

/* -----------------------------------------------------------
    業界別に見る
-------------------------------------------------------------- */
/*.industry-list {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin-top: 70px;
}	
.industry-box {
	width: calc((100% - 40px) / 3);
	border-radius: 10px;
	height: 330px;
	position: relative;
	overflow: hidden;	
}*/

.industry-txtbox {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	height: 330px;
	
}
.industry-box .industry-num {
	font-family: var(--main-en);
	font-size: 4rem;
	font-weight: 500;
	margin-bottom: 18px;
	letter-spacing: .09em;
}
.industry-box .industry-title {
	font-size: 3.3rem;
	font-family: var(--main-en);
	letter-spacing: .07em;
	font-weight: 500;
	margin-bottom: 25px;
	text-align: center;
}
.industry-box .industry-txt {
	font-size: 1.4rem;
	font-family: var(--main-en);
	letter-spacing: .07em;
	font-weight: 500;
	line-height: 1.5;
	/*background: var(--main-blue);*/
	background: linear-gradient(to right, var(--btn-blue), var(--btn-light-blue));
    color: var(--main-black);
	padding: 7px 30px;
	border-radius: 100px;
	letter-spacing: .09em;
	position: relative;
}
.industry-box .industry-txt::after {
    font-family: "FontAwesome";
    content: "\f105";
    font-size: 1.6rem;
    color: var(--main-black);
    transition: 0.3s;
    position: absolute;
    top: 6px;
    right: 15px;
    z-index: 200;
}

/* 背景画像 */
.industry-box::after {
	background-size: cover;
	transition: all .3s ease-out;
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	top: 0;
	z-index: -1;
}
.industry-box:hover::after {
	transform: scale(1.1);
}
.industry01::after {
    background-image: url(../img/top-semicon.jpg);
}
.industry02::after {
    background-image: url(../img/top-commu.jpg);
}
.industry03::after {
    background-image: url(../img/top-medical.jpg);
}
.industry04::after {
    background-image: url(../img/top-aerospace.jpg);
}
.industry05::after {
    background-image: url(../img/top-car.jpg);
}
.industry06::after {
    background-image: url(../img/top-measuring.jpg);
}

@media screen and (max-width: 768px){
	/*.industry-list {
		flex-direction: column;
		margin-top: 55px;
		padding-bottom: 55px;
	}	
	.industry-box {
		width: 100%;
		border-radius: 0;
		height: 150px;
	}*/	
	
	.industry-box .industry-num {
		font-size: 2.7rem;
		margin-bottom: 15px;
	}
	.industry-txtbox {
		height: 150px;
	}	
	.industry-box .industry-title {
		font-size: 2.2rem;
		margin-bottom: 0;
	}	
	.industry-box::after {
		background-position: center;
	}
	.industry-box .industry-txt {
		padding: 5px 30px;
		margin: 15px 0 0 0;
	}
	.industry-box .industry-txt::after {
		font-size: 1.5rem;
		top: 5px;
	}
	
	.slide-txt-area .slide-industry {
		height: 73px;
		background-size: 1000px auto;
		top: 48px;
	}
	.slide-txt-area .slide-technology {
		height: 73px;
		background-size: 1300px auto;
		top: 48px;
	}
	.slide-txt-area {
		padding-bottom: 0;
	}		

}	

/* -----------------------------------------------------------
    技術ごとに見る
-------------------------------------------------------------- */
.en-technology-area {
	padding-bottom: 140px;
	position: relative;
}
.en-technology-area::before {
	content: "";
    position: absolute;
    background-color: var(--main-black);
	width: 100%;
	height: 100%;
	z-index: -100;
}
.technology-list {
	display: flex;
	flex-wrap: wrap;
	gap: 80px 30px;
	margin-top: 70px;
}
.technology-list-box {
	width: calc((100% - 90px) / 4);
	position: relative;
	height: 200px;
	border-radius: 100px;
}
.technology-txtbox {
	position: absolute;
	bottom: -45px;
	right: 0;
	left: 0;
}
.technology-title {
	font-size: 2rem;
	color: #fff;
	background: linear-gradient(to right, var(--main-blue), var(--middle-blue));
	width: 175px;
	text-align: center;
	margin: 10px auto 10px;
	font-family: var(--main-en);
	letter-spacing: .07em;
	font-weight: 500;
	padding: 5px 0 7px;
	line-height: 1.1;
	position: relative;
}

.technology-txt {
	font-size: 1.6rem;
	line-height: 1.3;
	text-align: center;
	color: #fff;
	font-family: var(--main-en);
	letter-spacing: .07em;
	padding: 0px 30px;
	position: relative;
}
.technology-txt::after {
    font-family: "FontAwesome";
    content: "\f105";
    font-size: 1.5rem;
    color: #fff;
    transition: 0.3s;
    position: absolute;
    top: 0;
	margin: 0 0 0 10px;
    z-index: 200;
}

.technology-img {
	transition: all .3s ease-out;
}
.technology-img:hover {
	transform: scale(1.07);
}
.technology-img img {
	width: 100%;
	border-radius: 150px;
}

@media screen and (max-width: 768px){
	.technology-list {
		padding: 0 20px;
		gap: 90px 15px;
		margin-top: 55px;
	}	
	.technology-list-box {
		width: calc((100% - 15px) / 2);
		height: auto;
	}
	.technology-txtbox {
		bottom: -50px;
	}	
	.technology-title {
		font-size: 1.5rem;
		width: 90%;
		margin: 5px auto 5px;
	}
	.technology-txt {
		font-size: 1.3rem;
	}
	.technology-txt::after {
		font-size: 1.4rem;
	}
	.slide-txt-area .slide-technology {
		height: 73px;
		background-size: 1300px auto;
		top: 48px;
	}
	.en-technology-area {
		padding-bottom: 100px;
	}		
}	

/* -----------------------------------------------------------
    依頼の流れについて
-------------------------------------------------------------- */
.en-request-area {
	padding: 100px 0;
}
.flow-area {
	display: flex;
	gap: 25px;
	margin-top: 80px;
}
.flow-box {
	background-color: var(--recruit-bg-blue);
	border-radius: 10px;
	padding: 60px 15px 30px;
	width: calc((100% - 100px) / 5);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	position: relative;
}
.flow-box::before {
	content: "";
    position: absolute;
    background: url(../img/step1.png)center/contain no-repeat;
    width: 78px;
    height: 78px;
	top: -40px;
	left: -20px;
}
.flow-box2::before {
    background: url(../img/step2.png)center/contain no-repeat;
}
.flow-box3::before {
    background: url(../img/step3.png)center/contain no-repeat;
}
.flow-box4::before {
    background: url(../img/step4.png)center/contain no-repeat;
}
.flow-box5::before {
    background: url(../img/step5.png)center/contain no-repeat;
}
.flow-title {
	font-size: 2rem;
	/*font-family: var(--main-en);
	letter-spacing: .07em;
	font-weight: 500;*/
	font-weight: 700;
	color: var(--main-blue);
	margin-bottom: 15px;
}
.flow-txt {
	line-height: 1.7;
}
.flow-img {
	width: 98px;
	margin: 0 auto;
}
.flow-img img {
	width: 100%;
}
@media screen and (max-width: 768px){
	.en-request-area {
		padding: 50px 20px;
	}
	.flow-area {
		flex-direction: column;
		margin: 45px auto 0;
		max-width: 500px;
	}	
	.flow-box {
		width: 100%;
		padding: 30px 15px 10px;
	}	
	.flow-box::before {
		width: 70px;
		height: 70px;
		left: -8px;
		top: -15px;
	}	
	.request-title {
		text-align: center;
	}
	.flow-title {
		font-size: 1.8rem;
		text-align: center;
	}	
}

/* -----------------------------------------------------------
    会社概要
-------------------------------------------------------------- */
.en-company-area {
	width: 100%;
	padding: 100px 0 80px;
	margin: 0 auto;
	/*background-color: var(--recruit-bg-blue);*/
}
.inner02 {
	width: 1000px;
	margin: 0 auto;
}
.en-company-area .access-map {
	margin: 30px 0 0 0;
}
.en-company-area .access-map iframe {
	width: 100%;
	height: 450px;
}
.en-company-area .access-note {
	margin: 20px 0 0 0;
	font-size: 1.5rem;	
}
.en-company-area .access-note .access-title {
	color: var(--main-blue);
	font-weight: 700;
	letter-spacing: .07em;
}
.access-txt {
	display: flex;
	justify-content: space-between;
}

/* キャッチ */
.en-company-area .cmn-catch {
	font-size: 4rem;
	font-weight: 600;
	line-height: 1.6;
	letter-spacing: .07em;
	padding: 25px 0 20px;
}

/* テキスト */
.en-company-area .cmn-txt {
	font-size: 1.7rem;
	font-weight: 400;
	line-height: 2.8;
	margin: 40px 0 0 0;
}

/* テーブル */
.en-company-area table{
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid var(--line-gray);
	line-height: 1.6;
	margin: 40px 0 0;
}

.en-company-area table tr{
	border-bottom: 1px solid var(--line-gray);
}
.en-company-area table tr:last-of-type {
	border-bottom: none;
}

.en-company-area table th{
	text-align: left;
	vertical-align: top;
	font-weight: 500;
	padding: 25px 0;
	width: 175px;
	letter-spacing: .07em;
}

.en-company-area table td{
	padding: 25px;
}

/* リスト */
.en-company-area ul.cmn-list{
	padding: 0 0 0 30px;
}

.en-company-area ul.cmn-list li {
    line-height: 1.6;
	position: relative;
	padding: 10px 0 0 20px;
}

.en-company-area ul.cmn-list li::before {
    content: "";
	position: absolute;
	top: 22px;
	left: 5px;
	width: 5px;
	height: 5px;
	border-radius: 50px;
	background: var(--main-blue);
}

/*company-wrap*/
.en-company-area .company-wrap {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}

.en-company-area .company-contents {
	width: 850px;
}

/*pc only*/
@media screen and (min-width: 769px) {

	/*js*/
	.en-company-area .is-fix {
		position: fixed;
		top: 120px;
	}
	
	.en-company-area .is-opacity {
		opacity: 0;
		display: none;
	}
	
	.en-company-area .company-nav-item.current a {
		color: #10a758;
	}

	.en-company-area .company-nav-item.current a::before {
		background-color: #10a758!important;
	}
}

@media screen and (max-width: 768px){
	.en-company-area {
		width: 100%;
		padding: 50px 0 50px;
		margin: 0 0;
	}
	.inner02 {
		width: 100%;
		margin: 0 0;
		padding: 0 30px;
	}
	.en-company-area .access-map {
		margin: 15px 0 0 0;
		height: 200px;
	}
	.en-company-area .access-map iframe {
		height: 200px;
	}
	.access-txt {
		flex-direction: column;
	}	
	.en-company-area .access-note {
		margin: 15px 0 0 0;
	}
	
	.en-company-area .cmn-catch {
		font-size: 2.4rem;
		letter-spacing: .05em;
		padding: 15px 0 15px;
	}
	
	.en-company-area .cmn-txt {
		font-size: 1.6rem;
		margin: 15px 0 0 0;
		line-height: 2;
	}
	
	.en-company-area table{
		display: block;
		margin: 20px 0 0;
	}
	
	.en-company-area tbody {
		display: block;
	}
	
	.en-company-area tr {
		display: block;
	}
	
	.en-company-area table th{
		padding: 15px 0 8px 0;
		display: block;
		width: auto;
		color: var(--main-blue);
		font-weight: 700;
	}
	
	.en-company-area table td{
		padding: 15px;
		padding: 0 15px 15px 15px;
		display: block;
	}
	
	.en-company-area ul.cmn-list{
		padding: 0;
	}
	
	.en-company-area ul.cmn-list li {
		padding: 10px 0 0 20px;
	}
	
	.en-company-area ul.cmn-list li::before {
		top: 22px;
		left: 5px;
	}
	
	
}

/* -----------------------------------------------------------
    
-------------------------------------------------------------- */
@media screen and (max-width: 768px) {
	
}

