/* CSS Document */

body {	-webkit-text-size-adjust:100%; font-family: 'PT Sans', sans-serif; overflow-x: hidden; position: relative; }
img {	border:0; }

/* Reset ================================================================================= */

a { text-decoration:none; transition: all 0.4s ease-out 0s; }
a:hover { text-decoration:none; }

* { box-sizing: border-box;}

.content-Box { max-width:1200px; margin:0 auto; text-align:left; position:relative; clear:both;}

#content { font-size: 16px; line-height:24px; color: #333; letter-spacing: 0.05rem; font-weight: 400; padding-top: 78px;}
#content p{ margin-bottom: 30px; margin-top: 0; font-size: 16px;line-height:24px;  font-weight: 400;}
p, td, li, label { font-size: 16px;line-height:24px;  font-weight: 400;}

.photo-fit img { object-fit: cover; width: 100%; height: 100%; position: absolute; z-index: 1; left: 0; top: 0;}

.photo {line-height: 0; height: 0; padding-bottom: 40%; overflow: hidden; position: relative; z-index: 1; margin-bottom: 0px;}
.imgCenter {position: absolute; top: 0; left: 0; right: 0; bottom: 0; line-height: 0; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; z-index: 2;}
.imgCenter img {max-height: 100%;}

.banner { }
.banner-mobile { display: none;}
.loop .owl-dots {  display: none;}
.loop .owl-item {position: relative; }
.loop .owl-nav { position: absolute; bottom:17%; right: 2%; width: 95px; z-index: 11;}
.loop .owl-prev, .loop .owl-next { position:absolute; z-index:100;  background:#2a65a3 !important; width: 40px !important; height: 40px !important; border-radius: 0 !important;}
.loop .owl-prev { left:0px; }
.loop .owl-next { right:0px;}
.loop .owl-prev:before, .loop .owl-next:before { font-family: 'Font Awesome 5 Free';font-weight: 900 !important;font-size:70px; color: #fff; opacity: 0.5;transition: all 0.4s ease-out 0s;width: 12px; height: 12px; background-size: contain; display: inline-block; border-width: 2px 2px 0 0; border-style: solid; border-color: #fff;}
.loop .owl-prev:before { content: ""; transform: rotate(-135deg); }
.loop .owl-next:before { content: ""; transform: rotate(45deg);}
.loop .owl-prev:hover:before, .loop .owl-next:hover:before { opacity: 1;}
.loop .owl-stage-outer {z-index: 2;}
.loop .owl-dots { position: absolute; z-index: 100; bottom: 15px; width: 100%; text-align: center !important; padding: 0 50px; }
.loop .owl-dots .owl-dot span, .loop  .owl-dots .owl-dot span { background: #fff !important; width: 14px !important; height: 14px !important;}
.loop .owl-dots .owl-dot.active span, .loop  .owl-dots .owl-dot:hover span { background: #0471bd !important; }

.idx-service-section {padding: 85px 5% 50px 5%;
background-image:url("../images/main-bg-1.png"), url("../images/main-bg-2.png");
background-position: top right, left bottom;
background-repeat: no-repeat, no-repeat;
}

.title01 { text-align: center; font-weight: 700; font-size: 44px; padding-bottom: 60px; margin-bottom: 20px; position: relative; line-height: 110%; }
.title01:after { content:""; position: absolute; width: 2px; height: 45px; background:#333333; bottom: 0; left: calc(50% - 1px);}

.idx-service-list { display: flex ;flex-direction: row; flex-wrap: wrap; justify-content: space-between;}
.idx-service-list > div { width: 30%; padding-bottom: 25px;}
.idx-service-pto { line-height: 0; margin-bottom: 24px; overflow: hidden; display: block;}
.idx-service-title { font-size: 20px; font-weight: 700; line-height: 120%; padding-bottom: 12px;}

.idx-about-section { background:#fafafa; padding: 80px 5%; display: flex; flex-direction: row; flex-wrap: wrap;}
.idx-about-section > div { width: 50%;}
.title02 { padding-bottom: 20px;}
.title02 > h1, .title02 > div { font-size: 40px; font-weight: 700; line-height: 110%; margin: 0; padding: 0;}

.idx-about-list { display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-around; padding-left: 5%;}
.idx-about-list > a { padding: 0 10px; width: 30%; position: relative; text-align: center; display: block; padding-bottom: 65px;}
.idx-about-list > a:hover .idx-about-btn { bottom: 0; opacity: 1;}
.idx-about-list > a:hover .idx-about-pto img { transform: scale(1.05);}
.idx-about-pto { line-height: 0; margin-bottom: 5px; }
.idx-about-pto img { transition: all 0.4s ease-out 0s; }
.idx-about-title { font-size: 20px; font-weight: 700; line-height: 130%;}
.idx-about-btn { position: absolute; left: calc(50% - 15px); bottom: 20px; display: flex; flex-direction: column; flex-wrap: nowrap; align-items: center;transition: all 0.4s ease-out 0s; opacity: 0; }
.idx-about-btn > div:nth-of-type(1) { width: 30px; height: 30px; border-radius: 100%; text-align: center; background: #2a65a3; font-size: 15px; font-weight: 700; color: #fff; line-height: 30px; margin-bottom: 5px;}
.idx-about-btn > div:nth-of-type(2) { width: 10px; height: 10px; border-width: 0 2px 2px 0; border-color: #2a65a3; border-style: solid; transform: rotate(45deg);}

.idx-video-section { background: url("../images/idx-video-bg.jpg") no-repeat bottom right #fff; display: flex; flex-direction: row; flex-wrap: wrap; align-items: center;}
.idx-video-section > div:nth-of-type(1) { width: calc(50% + 50px); position: relative;padding: 70px 0 120px 5%; }
.idx-video-section > div:nth-of-type(2) { width: calc(50% - 50px); padding:0 5%; text-align: center;}

.idx-video-bg-1 { position: absolute; z-index: 1; width: 60%; height: 100%; top: 0;left: 0; background: #efefef;clip-path: polygon(0% 0, 100% 0%, 35% 100%, 0 100%);}
.idx-video-bg-2 { position: absolute; z-index: 2; width: 110%; height: 65%; top: 25%;left: 0; background: #305f9f;clip-path: polygon(0% 0, 100% 0%, 85% 100%, 0 100%);}
.idx-video-content { position: relative; z-index: 3;}
.idx-video-content img { width: 100%;}
.idx-video-play { position: absolute; z-index: 3; width: 100px; height: 100px; border-radius: 100%; background: rgba(255,255,255,.7); line-height: 100px; color: #0d2332;font-family: 'Font Awesome 5 Free';font-weight: 900; text-align: center; top:calc(50% - 50px); left:calc(50% - 50px); font-size: 40px; padding-left: 14px; }

.idx-video-title { font-size: 34px; font-weight: 700; line-height: 110%; padding-bottom: 25px;}

.btn01 { display: inline-block; line-height: 40px; min-width: 120px; position: relative; text-align: center;}
.btn01:hover { transform: scale(0.95);}
.btn01:hover:before, .btn01:hover:after { width: 100%; height: 100%;}
.btn01 span { font-size: 16px; font-weight: 700; position: relative; z-index: 2;}
.btn01:before, .btn01:after { content: ""; position: absolute; width: 20px; height: 20px; border-style: solid; border-color: #333;transition: all 0.4s ease-out 0s; }
.btn01:before { top: 0; left: 0; transform-origin: 0% 0%; border-width: 1px 0 0 1px;}
.btn01:after { bottom: 0; right: 0; transform-origin: 100% 100%; border-width: 0 1px 1px 0;}

.idx-case-section { padding: 60px 5%;}
.idx-case-section .title02 { padding-bottom: 10px;}

.idx-bottom-bg { position: relative; padding-top: 80px; background: #efefef; margin-bottom: 38px;}
.idx-bottom-bg:before { position: absolute; content: ""; background: #305f9f; left:0; top: 0; height: 100%; width: 75%; clip-path: polygon(0% 0, 100% 0%, 85% 100%, 0 100%);}

.idx-bottom-section { position: relative; z-index: 2; padding: 40px 5%;}
.idx-bottom-section:before { position: absolute; content: ""; top: 0; left: 0; width: 90%; height: 100%; background: #fff; clip-path: polygon(0% 0, 100% 0%, 85% 100%, 0 100%);}
.idx-bottom-content { display: flex; flex-direction: row; flex-wrap: wrap; position:relative; z-index: 2;}
.idx-bottom-content > div:nth-of-type(1) { width: 65%; padding-right: 5%;}
.idx-bottom-content > div:nth-of-type(2) { width: 35%;}

.title-type-1 { display: flex; flex-direction: row; flex-wrap: nowrap; justify-content: space-between;}

.idx-event-list { display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-between;}
.idx-event-list > div { width: calc(50% - 17px); background: #efefef; padding: 20px;} 
.idx-event-pto { display:block; padding-bottom: 50%; margin-bottom: 12px;} 
.idx-event-date { font-size: 16px; font-weight: 700; color: #909090; line-height: 100%; padding-bottom: 15px;} 
.idx-event-title {  font-size: 20px; min-height: 90px; font-weight: 700; margin-bottom: 20px; line-height: 140%;
display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;} 
.idx-event-title:hover { color: #305f9f;}
.idx-event-btn { display: inline-block; color: #909090; font-size: 16px; font-weight: 700; position: relative; padding-bottom: 5px;}
.idx-event-btn:hover { color: #305f9f;}
.idx-event-btn:hover:after { width: 100%; left: 0;}
.idx-event-btn:after { content: ""; position: absolute; right: 0; bottom: 0; width: 0%; height: 1px; background: #305f9f;transition: all 0.4s ease-out 0s;}

.idx-news-list { display: flex; flex-direction: row; flex-wrap: wrap;}
.idx-news-list > div { padding-bottom: 20px; margin-bottom: 40px; border-bottom: 2px solid #dedede;}
.idx-news-title { font-size: 20px; font-weight: 700; margin-bottom: 20px; line-height: 140%;
display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
	text-overflow: ellipsis;}
.idx-news-title:hover { color: #305f9f;}

@media only screen and (max-width:  1365px) {
	.idx-about-section { padding: 50px 5%;}
	.title02 > h1, .title02 > div { font-size: 28px; }
	
	.idx-about-title { font-size: 17px;}
	
	.idx-video-title { font-size: 28px;}
}

@media only screen and (max-width:  1200px) {
	#content { padding-top: 60px;}
	
	.idx-service-section { padding: 40px 5% 30px 5%;}
	.title01 { font-size: 30px; padding-bottom: 50px; margin-bottom: 10px;}
	.title01:after { height: 25px;}
	
	.idx-about-section > div { width: 100%;}
	.idx-about-list { padding-left: 0;}
	
	.idx-video-section > div:nth-of-type(1) { width: calc(100% + 0px); order: 2; padding: 40px 5%; }
	.idx-video-section > div:nth-of-type(2) { width: calc(100% - 0px); order: 1; padding-top: 50px;}
	.idx-video-play {  width: 60px; height: 60px; top:calc(50% - 30px); left:calc(50% - 30px); font-size: 20px; line-height: 60px; padding-left: 5px;}

	.idx-case-section { padding: 40px 5%;}
	
	.idx-bottom-content > div:nth-of-type(1) { width: 100%; padding-right: 0%; padding-bottom: 35px;}
	.idx-bottom-content > div:nth-of-type(2) { width: 100%;}
}
@media only screen and (max-width: 980px) {
	.banner { display: none}
	.banner-mobile { display: block;}
	
	.loop .owl-nav { bottom: 5.5%;transform: scale(0.8);}
	
	.idx-service-list > div { width: 31.5%;}
	.idx-service-pto { margin-bottom: 20px; }
	.idx-service-title { font-size: 18px; }
	
	.idx-bottom-bg { margin-bottom: 20px;}
	.idx-news-list > div { margin-bottom: 20px; padding-bottom: 0;}
}
@media only screen and (max-width: 768px) {
	.idx-bottom-section:before { width: 100%; clip-path: polygon(0% 0, 100% 0%, 100% 100%, 0 100%);}
	
}
@media only screen and (max-width: 640px) {
	.idx-service-list > div { width: 100%;}
	
}
@media only screen and (max-width: 570px) {
	.idx-about-list > a { width: 100%; padding-bottom: 30px;}
	.idx-about-btn { bottom: 60%;}
	.idx-about-list > a:hover .idx-about-btn { bottom: 50%;}
	
	.idx-event-list > div { width: calc(100% - 0px); margin-bottom: 20px; } 
}

@media only screen and (max-width: 414px) {
	
	

}

@media only screen and (max-width: 320px) {

}