@charset "utf-8";

.mainCatch { width: 100%; margin: 0 auto; position: relative; }
.mainCatch .mainSlider { width: 100%; margin: 0 auto; }
.mainCatch .mainSlider .slide { width: 100%; height: 55vw; max-height: calc( 100vh - 60px ); margin: 0; }
.mainCatch .mainSlider .slide:first-child { background: url(/images/top/main_slide01.jpg) no-repeat center center; background-size: cover; }
.mainCatch .mainSlider .slide:nth-child(2) { background: url(/images/top/main_slide02.jpg) no-repeat center center; background-size: cover; }
.mainCatch .mainSlider .slide:nth-child(3) { background: url(/images/top/main_slide03.jpg) no-repeat center center; background-size: cover; }
.mainCatch .mainSlider .slide h2 { width: 100%; margin: 0 auto; padding: 0 5vw 10vw; text-align: left; font-family: 'Noto Serif JP', serif; font-size: 48px; line-height: 1.5; font-weight: 700; color: #fff; text-shadow: 0px 3px 6px rgba(0,0,0,0.2); }
.mainCatch .mainSlider .slide .slide_inr { position: absolute; width: 100%; height: 100%; display: flex; align-items: center; z-index: 99; background: rgba(0,78,160,0.4); background: -webkit-linear-gradient(left, rgba(0,78,160,0.4) 0%, rgba(0,160,233,0.4) 100%); background: linear-gradient(90deg, rgba(0,78,160,0.4) 0%, rgba(0,160,233,0.4) 100%); }
.mainCatch .performance { position: absolute; bottom: 3vw; left: 5vw; }
.mainCatch .performance img { width: 470px; height: 175px; }

.topInfo { background: #F2F5FB; padding: 18px 0; font-size: 0; }
.topInfo h3 { float: left; width: 150px; font-family: 'Noto Serif JP', serif; font-size: 16px; line-height: 24px; font-weight: 700; padding: 0; border-right: 1px solid #4B505B; text-align: center; }
.topInfo a { float: left; display: block; width: calc( 100% - 150px ); text-decoration: none; transition: all 0.3s; }
.topInfo a:hover { opacity: 0.8; }
.topInfo a dl { font-size: 0; }
.topInfo a dt { display: inline-block; width: 150px; font-family: 'Noto Serif JP', serif; font-size: 16px; line-height: 24px; font-weight: 700; padding: 0; text-align: center; }
.topInfo a dd { display: inline-block; width: calc( 100% - 150px ); font-size: 16px; line-height: 24px; padding: 0 30px 0 0; }
.topInfo a:hover dt { color: #2E51A3; }
.topInfo a:hover dd { color: #2E51A3; }

.topSeminarCont { margin: 0 auto 60px; }
.topSeminarCont:last-child { margin: 0 auto; }
.topSeminarCont .thumbCont { float: left; width: 50%; padding: 0 20px 0 0; }
.topSeminarCont .thumbCont img { width: 100%; }
.topSeminarCont .courseCont { float: right; width: 50%; padding: 0 0 0 20px; }
.topSeminarCont .partTitle { border-bottom: 1px solid #D5D7DC; }
.topSeminarCont .partTitle dl { padding: 0 0 10px; }
.topSeminarCont .partTitle dt { float: left; width: 60px; background: #4B505B; color: #fff; font-family: 'Noto Serif JP', serif; font-size: 14px; font-weight: 700; line-height: 20px; text-align: center; padding: 20px 0; }
.topSeminarCont .partTitle dd { float: left; width: calc( 100% - 60px ); font-size: 18px; font-weight: 700; line-height: 25px; padding: 5px 10px; }
.topSeminarCont .partTitle dd span { font-size: 18px; font-weight: 700; line-height: 25px; color: #D80C5E; }
.topSeminarCont .schedule02 { padding: 5px 0; border-bottom: 1px solid #D5D7DC; margin: 0 auto 20px; }
.topSeminarCont .schedule01 { padding: 5px 0; margin: 0 auto; }
.topSeminarCont .schedule02 .plan { padding: 5px 0; width: 50%; float: left; }
.topSeminarCont .schedule01 .plan { padding: 5px 0; }
.topSeminarCont .place { display: inline-block; background: #2EA38F; color: #fff; font-size: 14px; font-weight: 700; line-height: 26px; text-align: center; padding: 0 10px; }
.topSeminarCont .date { display: inline-block; font-size: 14px; font-weight: 700; line-height: 26px; padding: 0 10px; }
.topSeminarCont .date span { display: inline-block; font-size: 20px; font-weight: 700; line-height: 26px; padding: 0 5px; }
.topSeminarCont .date.close { background: rgba(0,0,0,0.2); color: #666; }
.topSeminarCont .date.close span { color: #666; }
.topSeminarCont .date.close:before { font-size: 18px; color: #2E2A3D; content:'満員御礼 '; }
.topSeminar .moreBtn { text-align: left; }
.topSeminarCont .message { font-weight: 700; padding: 10px; color: #2E51A3; }

.seminarSlider { width: 100%; border-top: 1px solid #D5D7DC; padding: 60px 0 0; }
.seminarSlider .topSeminarCont { padding: 0 10px; height: 100%; position: relative; }
.seminarSlider .topSeminarCont .thumbCont { float: none; width: 100%; padding: 0; }
.seminarSlider .topSeminarCont .courseCont { float: none; width: 100%; padding: 20px 0 80px; height: 100%; }
.seminarSlider .topSeminarCont .moreBtn { position: absolute; bottom: 0; width: calc( 100% - 20px ); border-top: 1px solid #D5D7DC; padding: 20px 0 0; }
.seminarSlider .slick-track { display: flex; }
.seminarSlider .slick-slide { height: auto !important; }

.topConsulting { background: #F2F5FB; }
.topConsulting .sectionInr { padding: 0 5vw; }
.topConsulting .disc { line-height: 1.75; text-align: center; margin: 0 auto; }
.consultingCont.corporation { padding: 5vw 0; border-bottom: 1px solid #D5D7DC; }
.consultingCont.general { padding: 5vw 0; }
.consultingMenu { font-size: 0; margin: 40px auto 0; }
.corporation .menuCont { display: inline-block; width: calc( 100% / 3 ); padding: 0 10px 30px; }
.general .menuCont { display: inline-block; width: 25%; padding: 0 10px 30px; }
.consultingMenu .menuIcon { width: 100%; height: 175px; padding: 55px 0; text-align: center; background: url(/images/common/bg_consultingmenu.svg) no-repeat center center; background-size: contain; }
.consultingMenu .menuIcon img { height: 65px; }
.consultingMenu .menuCont dt { font-family: 'Noto Serif JP', serif; font-size: 20px; font-weight: 700; line-height: 1.2; text-align: center; padding: 10px 0; }
.consultingMenu .menuCont dd { font-size: 16px; line-height: 1.5; text-align: center; }
.topConsulting .moreBtn { text-align: center; }

.topCompany .sectionInr { padding: 5vw 4vw; }
.topCompany .companyBtn { float: left; width: calc( 100% / 3 ); padding: 0 1vw; }
.topCompany .companyBtn a { display: block; text-decoration: none; position: relative; }
.topCompany .companyBtn .thumb { width: 100%; height: 100%; overflow: hidden; }
.topCompany .companyBtn .thumb img { width: 100%; transition-duration: 0.5s; }
.topCompany .companyBtn a:hover .thumb img { transform: scale(1.1,1.1); }
.topCompany .companyBtn .txt { position: absolute; top: 0; width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; margin: 0 auto; background: rgba(46,42,61,0.25); font-family: 'Noto Serif JP', serif; font-size: 24px; font-weight: 700; color: #fff; }

.topInforList { background: #F2F5FB; }
.topInforList ul { border-top: 1px solid #D5D7DC; margin: 0 auto 40px; }
.topInforList ul li { border-bottom: 1px solid #D5D7DC; }
.topInforList ul li a { display: block; transition: all 0.3s; }
.topInforList ul li a:hover { opacity: 0.8; }
.topInforList ul li dl { padding: 10px; }
.topInforList ul li dt { float: left; width: 150px; font-family: 'Noto Serif JP', serif; font-size: 16px; font-weight: 700; line-height: 20px; padding: 10px 20px; }
.topInforList ul li dd { float: left; width: calc( 100% - 150px ); font-size: 16px; font-weight: 500; line-height: 20px; padding: 10px; }
.topInforList ul li a:hover dt { color: #2E51A3; }
.topInforList ul li a:hover dd { color: #2E51A3; }
.topInforList .moreBtn { text-align: center; }

.topOtherInfo {  }
.topOtherInfo .facebook { float: left; width: 50%; padding: 0 1vw 0 0; }
.topOtherInfo .facebook .fb-page { width: 100%; }
.topOtherInfo .facebook .fb-page span { width: 100% !important; }
.topOtherInfo .facebook .fb-page iframe { width: 100% !important; }
.topOtherInfo .twitter { float: left; width: 50%; padding: 0 0 0 1vw; }
.topOtherInfo .facebook .twitter-timeline { width: 100%; }
.facebook-wrapper { max-width: 500px; margin: 0 auto; }
.facebook-wrapper > .fb-page { width: 100%; }
.facebook-wrapper > .fb-page > span, .facebook-wrapper iframe { width: 100% !important; }


/* ─────────────────────────────────────────────────────────────────────────── */

@media screen and (max-width:1400px){
	.topSeminarCont .schedule02 .plan { width: 100%; float: none; }
}

/* ─────────────────────────────────────────────────────────────────────────── */

@media screen and (max-width:1200px){
	.mainCatch .mainSlider .slide h2 { font-size: 40px; }
	.topSeminarCont .thumbCont { padding: 0 10px 0 0; }
	.topSeminarCont .courseCont { padding: 0 0 0 10px; }
	.topSeminarCont .partTitle dd { font-size: 16px; }
	.topConsulting .sectionInr { padding: 0 2vw; }
	.consultingMenu .menuCont dd { font-size: 14px; }
}

@media screen and (max-width:1023px){
	.mainCatch .mainSlider .slide { height: 75vh; max-height: auto;}
	.sectionInr { padding: 10vw 5vw; }
	.consultingCont.corporation { padding: 10vw 0; }
	.consultingCont.general { padding: 10vw 0; }
	.contactInfo .sectionInr { padding: 5vw 8vw; }
	.contactInfo .telCont dt a { pointer-events: auto; }

}

@media screen and (max-width:767px){
	.mainCatch .mainSlider .slide h2 { font-size: 26px; }
	.mainCatch .mainSlider .slide h2 br { display: none; }
	.mainCatch .performance { bottom: 10vw; }
	.mainCatch .performance img { width: 262.5px; height: 98px; }
	.topInfo { padding: 5vw; }
	.topInfo h3 { float: none; width: 100%; padding: 0 0 10px; border-right: none; text-align: left; font-size: 16px; }
	.topInfo a { float: none; width: 100%; }
	.topInfo a dt { display: block; width: 100%; font-size: 15px; padding: 0 0 10px; text-align: left; }
	.topInfo a dd { display: block; width: 100%; font-size: 15px; padding: 0; text-align: left; }
	.topSeminarCont .thumbCont { float: none; width: 100%; padding: 0 0 10px; }
	.topSeminarCont .courseCont { float: none; width: 100%; padding: 0; }
	.topSeminarCont .message { text-align: center; }
	.topSeminar .moreBtn { text-align: center; }
	.topConsulting .sectionInr { padding: 0 5vw; }
	.topConsulting .disc br { display: none; }
	.corporation .menuCont { width: 50%; padding: 0 5px 30px; }
	.general .menuCont { width: 50%; padding: 0 5px 30px; }
	.consultingMenu { margin: 5vw auto 0; }
	.consultingMenu .menuIcon { height: 140px; padding: 45px 0; }
	.consultingMenu .menuIcon img { height: 50px; }
	.consultingMenu .menuCont dt { font-size: 16px; }
	.topCompany .companyBtn { float: none; width: 100%; padding: 1vw; position: relative; }
	.topCompany .companyBtn .thumb { position: absolute; }
	.topCompany .companyBtn .txt { position: relative; height: 50vw; font-size: 18px; }
	.topInforList ul { margin: 0 auto 5vw; }
	.topInforList ul li dl { padding: 10px 0; }
	.topInforList ul li dt { float: none; width: 100%; font-size: 15px; padding: 0 0 5px; }
	.topInforList ul li dd { float: none; width: 100%; font-size: 15px; padding: 0; }
	.topOtherInfo .facebook { float: none; width: 100%; padding: 1vw 0; }
	.topOtherInfo .twitter { float: none; width: 100%; padding: 1vw 0; }

}
