
.sec_ttl { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }
.sec_ttl .ttl_wrap { position: relative; }
.sec_ttl .ttl_wrap h2 { font-size: 49px; font-weight: 800; letter-spacing: .2em; margin-top: 20px; color: #003384; padding-bottom: 10px; }
.sec_ttl .ttl_wrap h2::before { content: ""; width: calc(50% - 7px); height: 1px; background: #003384; position: absolute; bottom: 0; left: 0; }
.sec_ttl .ttl_wrap h2::after { content: ""; width: calc(50% - 7px); height: 1px; background: #003384; position: absolute; bottom: 0; right: 0; }
.sec_ttl .ttl_wrap h2 .circle-top { position: relative; }
.sec_ttl .ttl_wrap h2 .circle-top::before { content: ""; width: 6px; height: 6px; border-radius: 50%; border: 1px solid #003384; position: absolute; top: -10px; left: 0; right: 0; margin: 0 auto; }
.sec_ttl .ttl_wrap .vertical-dotted { width: 15px; height: 20px; position: absolute; bottom: -18px; left: 0; right: 0; margin: 0 auto; }
.sec_ttl .ttl_wrap .vertical-dotted span { display: block; width: 7.5px; height: 20px; background-image: radial-gradient(circle, #003384 0.75px, transparent 0.75px); background-position: right top; background-repeat: repeat-y; background-size: 1.5px 3.5px; }

.section-hero { height: 310px; display: flex; align-items: center; justify-content: center; padding: 30px; margin-top: 97px; }
.hero-title { text-align: center; }
.hero-title .icon { display: block; margin-left: auto; margin-right: auto; }
.hero-title .jp { display: inline-block; position: relative; font-size: 49px; font-weight: 800; letter-spacing: .2em; margin-top: 20px; color: #003384; padding-bottom: 10px; }
.hero-title .jp:before { content: ""; width: calc(50% - 7px); height: 1px; background: #003384; position: absolute; bottom: 0; left: 0; }
.hero-title .jp:after { content: ""; width: calc(50% - 7px); height: 1px; background: #003384; position: absolute; bottom: 0; right: 0; }
.hero-title .en { text-align: center; font-size: 15px; letter-spacing: .2em; line-height: 1.28533; padding-top: 30px; color: #003384; position: relative; }
.hero-title .en:before { content: ""; width: 3px; height: 20px; top: 0; position: absolute; left: -1px; right: 0; margin: 0 auto; background-image: radial-gradient(circle, #003384 0.75px, transparent 0.75px); background-position: right top; background-repeat: repeat-y; background-size: 1.5px 3.5px; }
.bg-dots { background-image: radial-gradient(circle, #00338440 1px, transparent 1px), radial-gradient(circle, #00338440 1px, transparent 1px); background-position: 0 0, 2.25px 4.5px; background-size: 4.5px 9px; background-attachment: fixed; position: relative; }
.bg-musk { mask-image: url(../images/top/bg_mask.png); -webkit-mask-image: url(../images/top/bg_mask.png); mask-size: cover; -webkit-mask-size: cover; mask-repeat: no-repeat; -webkit-mask-repeat: no-repeat; position: relative; }
.over-right { max-width: none; width: 130%; }
.over-left { max-width: none; width: 130%; float: right; }
.img-radius { border-radius: 1em; }
.title-comment { display: inline-block; font-size: 15px; letter-spacing: .2em; padding: 5px 40px; background: #fff; color: #003384; border: 1px solid #003384; border-radius: 5px; position: relative; margin-bottom: 20px; }
.title-comment:before { content: ""; background-image: url(../images/common/comment_arrow.svg); width: 15.59px; height: 14.23px; position: absolute; bottom: -12px; left: 20px; }
.title-comment.center:before { left: 0; right: 0; margin: 0 auto;}
.title-bold { font-size: 20px; font-weight: bold; letter-spacing: .2em; color: #003384; }
.over-text-image img { max-width: none; width: auto; position: relative; z-index: 1; }
.shogakukin { margin-top: 145px; margin-bottom: 100px; border-left: 10px solid #0e358e; border-right: 10px solid #0e358e; padding: 40px 15px; background: #f2f2f2; width: 910px; max-width: 100%; margin-left: auto; margin-right: auto; }
.shogakukin dt { color: #0e358e; font-size: 35px; letter-spacing: .1em; text-align: center; font-weight: 700; margin-bottom: 30px; }
.shogakukin dd { text-align: center; font-size: 20px; letter-spacing: .075em; max-width: 840px; margin-left: auto; margin-right: auto; }
.shogakukin .title { font-weight: 500; margin-bottom: 20px; color: #093181; }
.shogakukin .details { letter-spacing: 0; line-height: 2; }
hr.short { width: 30px; height: 1px; margin: 20px 0; margin-left: auto; margin-right: auto; border-top: 1px solid #231815; }
hr.dots { background-image: radial-gradient(circle, #093181 0.75px, transparent 0.75px); background-position: left top; background-repeat: repeat-x; background-size: 3.7px 1.5px; border: none; height: 1.5px; width: 100%; margin: 40px 0; }
.voice-slider { overflow: visible!important; }
.voice-slider * { overflow: visible!important; }
.voice-card { padding: 0 22px; text-align: center; }
.voice-card .message { height: 150px; display: flex; align-items: center; justify-content: center; }
.voice-card .photo { margin-bottom: 15px; }
.bosyuyoukou-banner { background-image: url(../images/recruit/recruit_img12.png); background-size: cover; background-position: center; height: 430px; display: flex; align-items: center; justify-content: center; }
.bosyuyoukou-banner .title { text-align: center; text-align: center; font-size: 55px; color: #fff; font-weight: 700; letter-spacing: .2em; }
.bosyuyoukou-banner .blue_btn a { border-color: #fff; }
.bosyuyoukou-banner .blue_btn a .btn_flex p { color: #fff!important; }
.bosyuyoukou-banner .blue_btn a span { border-color: #fff; }
.blue-tabs { border: 1px solid #0e358e; border-top: none; background-color: #fff; }
.blue-tabs .tabs-title { background-color: #0e358e; color: #fff; text-align: center; font-weight: 700; font-size: 26px; padding: 5px 15px; letter-spacing: .1em; }
.blue-tabs .tabs-contents { width: 960px; max-width: 100%; margin-left: auto; margin-right: auto; padding: 50px 15px 60px; }
.number-lists li { margin-bottom: 50px; }
.number-lists li:last-child { margin-bottom: 0; }
.number-lists-title { border-bottom: 1px solid #0e358e; padding-bottom: 10px; margin-bottom: 20px; display: flex; align-items: center; }
.number-lists-title .number { width: 30px; height: 30px; margin-right: 10px; background-color: #053681; color: #fff; font-weight: 700; display: flex; align-items: center; justify-content: center; line-height: 1; padding-bottom: 2px; letter-spacing: 0; }
.number-lists-title .title { width: calc(100% - 40px); font-size: 23px; letter-spacing: .075em; font-weight: 400; }
.dots-table { width: 100%; font-size: 18px; letter-spacing: .1em; color: #003384; }
.dots-table th { padding: 15px 12px; background-image: radial-gradient(circle, #00338440 1px, transparent 1px), radial-gradient(circle, #00338440 1px, transparent 1px); background-position: 0 0, 2.25px 4.5px; background-size: 4.5px 9px; background-attachment: fixed; color: #003384; letter-spacing: 0; }
.dots-table tr { background-image: radial-gradient(circle, #093181 0.75px, transparent 0.75px), radial-gradient(circle, #093181 0.75px, transparent 0.75px); background-position: left top, left bottom; background-repeat: repeat-x, repeat-x; background-size: 3.7px 1.5px, 3.7px 1.5px; }
.dots-table tr + tr { background-image: radial-gradient(circle, #093181 0.75px, transparent 0.75px); background-position: left bottom; background-repeat: repeat-x; background-size: 3.7px 1.5px; }
.dots-table td { padding: 15px 30px; }
.dots-table.vertical-top td,
.dots-table.vertical-top th { vertical-align: top; }
.map-table { width: 100%; font-size: 17px; letter-spacing: .075em; background-color: #fff; }
.map-table th { background-color: #0e358e; color: #fff; font-weight: 600; text-align: center; padding: 8px 10px; border: 1px solid #fff; }
.map-table td { padding: 20px; text-align: left; border: 1px solid #093181; letter-spacing: .05em; }
.map-table tr th:first-child { border-left: none; }
.map-table tr th:last-child { border-right: none; }
.iv-number-pc { position: absolute; left: 0; top: 0; }
.iv-catch { border-bottom: 1px solid #003396; margin-bottom: 35px; width: 100%; }
.interview-hero .contents { width: 100%; }
.interview-hero .contents .details { font-size: 18px; }
.interview-hero .contents dl { display: flex; align-items: center; margin-top: 5px; }
.interview-hero .contents dl dt { margin-right: 20px; padding-right: 20px; font-weight: bold; font-size: 17px; letter-spacing: .1em; border-right: 1px solid #333; line-height: 1; }
.interview-hero .contents dl dd { font-size: 15px; letter-spacing: .1em; }
.interview-faq li { padding-bottom: 80px; margin-bottom: 80px; border-bottom: 1px solid #003396; }
.interview-faq li:last-child { margin-bottom: 0; }
.interview-faq .question { display: flex; flex-wrap: wrap; padding-bottom: 45px; margin-bottom: 40px; background-image: radial-gradient(circle, #093181 0.75px, transparent 0.75px); background-position: left bottom; background-repeat: repeat-x; background-size: 3.7px 1.5px; }
.interview-faq .question .icon { width: 75px; }
.interview-faq .question .contents { width: calc(100% - 75px); padding-top: 4px; font-weight: bold; font-size: 17px; letter-spacing: .1em; }
.interview-faq .answer { display: flex; flex-wrap: wrap; }
.interview-faq .answer .icon { width: 75px; }
.interview-faq .answer .contents { width: calc(100% - 75px); padding-top: 4px; font-size: 17px; letter-spacing: .075em; color: #003086; }
.interview-schedule li { display: flex; align-items: flex-start; margin-bottom: 40px; position: relative; }
.interview-schedule li:before { content: ""; height: calc(100% + 40px); width: 1.5px; background-color: #09328f; position: absolute; bottom: -40px; left: 74px; }
.interview-schedule li:last-child { margin-bottom: 0; }
.interview-schedule li:last-child:before { display: none; }
.interview-schedule .time { width: 150px; color: #fff; background-color: #09328f; text-align: center; font-weight: bold; font-size: 16px; letter-spacing: .1em; line-height: 1.2; padding: 3px 0 6px; position: relative; }
.interview-schedule .detail { width: calc(100% - 150px); padding-left: 25px; font-weight: bold; font-size: 17px; letter-spacing: .1em; }
.orb_position { position: absolute; z-index: 1; }
.orb_position1 { top: 7%; left: -3%; }
.orb_position2 { bottom: 7%; right: -8%; }
.orb_position3 { top: 7%; left: 0; z-index: 0; }
.orb_position4 { bottom: -56%; right: -20%; }
.orb_position5 { top: 0; left: -10%; z-index: 0; }
.orb_position6 { top: 10%; right: 0; z-index: 0;}
.orb_position7 { top: 22%; right: -4%; }
@media (max-width: 767px) {
	.section-hero { margin-top: 0; height: 150px; }
	.hero-title .icon { width: 15px; }
	.hero-title .jp { font-size: 28px; letter-spacing: .18em; margin-top: 13px; }
	.hero-title .en { font-size: 0; }
	.bg-dots { background-image: radial-gradient(circle, #00338440 0.6px, transparent 0.6px), radial-gradient(circle, #00338440 0.6px, transparent 0.6px) !important; }
	.map-table { font-size: 13px; }
	.map-table th { font-size: 17px; }
	.map-table td { padding: 10px 10px; }
	.blue-tabs .tabs-contents { padding: 20px 15px 30px; }
	.blue-tabs .tabs-title { font-size: 20px; }
	.number-lists li { margin-bottom: 35px; }
	.number-lists-title { margin-bottom: 15px; }
	.number-lists-title .title { font-size: 18px; }
	.number-lists-title .number { width: 21px; height: 21px; font-size: 16px; }
	.dots-table { font-size: 14px; }
	.dots-table th { padding: 10px 12px 12px; }
	.dots-table td { padding: 10px 12px 12px; }
	.dots-table th[width="90"] { width: 60px!important; }
	.dots-table th[width="280"] { width: 120px!important; }
	#recruit + footer { margin-top: 45px; }
	.shogakukin { margin-top: 60px; margin-bottom: 60px; border-left: 3px solid #0e358e; border-right: 3px solid #0e358e; padding: 20px 15px; }
	.shogakukin .title { margin-bottom: 15px; }
	.shogakukin .details { font-size: 14.4px; }
	.shogakukin dt { font-size: 28px; line-height: 1.2; } 
	.shogakukin dd { font-size: 14px; }
	hr.dots { margin: 30px 0;}
	.scroll-table { overflow: auto; }
	.scroll-table table { width: 740px; }
	.over-right { width: calc(100% + 30px); border-radius: 0 0 0 0 !important; }
	.over-left { width: calc(100% + 30px); margin: 0 auto; border-radius: 0 0 0 0 !important; }
	.title-bold { font-size: 16px; }
	.title-comment { font-size: 10px; }
	.over-text-image img { max-width: 100%; }
	.voice-card .message { height: 120px; }
	.voice-card .message img { transform: scale(0.8); transform-origin: center center; display: block; margin-left: auto; margin-right: auto; }
	.bosyuyoukou-banner { background-image: url(../images/recruit/recruit_img12_sp.png); height: 180px; }
	.bosyuyoukou-banner .title { font-size: 28px; }

	.iv-number img { height: 17px; }
	.iv-catch { margin-left: -30px; margin-top: -3px; padding-left: 50px; position: relative; border: none; }
	.iv-catch img { height: 90px; }
	.iv-catch:before { content: ""; background-color: #003396; width: 80%; height: 1px; position: absolute; bottom: 0; left: 0; }
	.interview-hero .contents .details { font-size: 15px; }
	.interview-hero .contents dl dt { font-size: 17px; margin-right: 15px; padding-right: 15px; white-space: nowrap; }
	.interview-hero .contents dl dd { font-size: 13px; }
	.interview-faq li { margin-bottom: 45px; padding-bottom: 45px; }
	.interview-faq .icon { width: 60px!important; }
	.interview-faq .contents { width: calc(100% - 60px)!important; }
	.interview-faq .icon img { width: 32px; }
	.interview-faq .question { margin-bottom: 35px; padding-bottom: 45px; }
	.interview-faq .question .contents { font-size: 14px; }
	.interview-faq .answer .contents { font-size: 14px; padding-top: 0; }
	.interview-flow .title img { height: 41px; }
	.interview-schedule .time { width: 110px; font-size: 14px; }
	.interview-schedule li:before { left: 55px; width: 1px; }
	.interview-schedule .detail { width: calc(100% - 110px); padding-left: 13px; font-size: 14px; }
	#recruit .recruit-list h2 img { height: 14px; }
	.orb_position1 { display: none; }
	.orb_position2 { display: none; }
	.orb_position3 { display: none; }
	.orb_position4 { display: none; }
	.orb_position5 { display: none; }
	.orb_position6 { display: none; }
	.orb_position7 { display: none; }
}