/*font*/
/*$base_font: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, Verdana, Meiryo, sans-serif;*/
@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 100; }

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 200; }

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 300; }

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Medium"); font-weight: 400; }

@font-face { font-family: "Yu Gothic"; src: local("Yu Gothic Bold"); font-weight: bold; }

@font-face { font-family: "Helvetica Neue"; src: local("Helvetica Neue Regular"); font-weight: 100; }

@font-face { font-family: "Helvetica Neue"; src: local("Helvetica Neue Regular"); font-weight: 200; }

/*! based on html5doctor.com Reset Stylesheet v1.6.1 Author: Richard Clark - http://richclarkdesign.com */
html { box-sizing: border-box; }

*, ::before, ::after { box-sizing: inherit; }

body { background: transparent; color: #000; line-height: 1; -webkit-text-size-adjust: 100%; }

html[lang="ja"] body { font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, Verdana, Meiryo, sans-serif; }

/* main elements group */
audio, canvas, progress, video { display: -moz-inline-stack; display: inline-block; vertical-align: middle; *vertical-align: auto; zoom: 1; *display: inline; vertical-align: baseline; }

audio:not([controls]) { display: none; height: 0; }

/* a */
/*#main_area{
	height: 100%;
}*/
#tit_area { position: relative; height: 60%; }

#tit_area::before { content: ""; display: block; position: absolute; height: 80%; background: #000943; width: 100%; z-index: 0; left: 0; top: 0; }

#tit_area #tit_area_in { padding-top: 82px; display: -ms-flexbox; display: flex; -ms-flex-align: stretch; align-items: stretch; -ms-flex-pack: start; justify-content: flex-start; height: 100%; width: 100%; position: relative; z-index: 10; padding-left: 5%; }

#tit_area #tit_area_in #tit_area_l { display: -ms-flexbox; display: flex; -ms-flex-align: start; align-items: flex-start; -ms-flex-pack: center; justify-content: center; -ms-flex-direction: column; flex-direction: column; position: relative; z-index: 11; }

#tit_area #tit_area_in #tit_area_l #tit002 { font-size: 1.5rem; font-weight: 900; color: #fff; }

#tit_area #tit_area_in #tit_area_l #tit001 img { height: 90px; }

#tit_area #tit_area_in #tit_area_r { position: absolute; right: 0; top: 82px; height: calc(100% - 82px); width: 92%; background-position: center center; background-repeat: no-repeat; background-size: cover; }

#pan_list { display: -ms-flexbox; display: flex; -ms-flex-align: center; align-items: center; -ms-flex-pack: start; justify-content: flex-start; width: 92%; padding: 20px 0; max-width: 1500px; margin: 0 auto; }

#pan_list h1 { font-size: 0.9375rem; font-weight: bold; color: #000943; }

#pan_list p { position: relative; padding-right: 14px; margin-right: 10px; }

#pan_list p a { font-size: 0.9375rem; font-weight: bold; text-decoration: underline; }

#pan_list p a:hover { text-decoration: none; }

#pan_list p::before { content: ""; display: block; position: absolute; right: 0; top: 50%; margin-top: -2px; width: 6px; height: 6px; border-top: 2px solid #000; border-right: 2px solid #000; transform: rotate(45deg); }

.box { width: 92%; max-width: 1200px; margin: 0 auto 80px; }

.w20_t { width: 15%; }

.com_md001 { text-align: center; color: #000943; font-size: 2.25rem; font-weight: 900; margin-bottom: 40px; }

.gr_box { background: #f0f1f3; padding: 75px 0; }

.gr_box .box { display: -ms-flexbox; display: flex; -ms-flex-align: start; align-items: flex-start; -ms-flex-pack: start; justify-content: flex-start; margin-bottom: 0; }

.gr_box .box .gr_box_r .gr_name { text-align: right; color: #000943; font-size: 1.125rem; font-weight: 900; padding-top: 20px; }

.gr_box .box .gr_box_l { width: 30%; margin-right: 30px; }

.gr_box .box .gr_box_l h2 { color: #000943; font-size: 2.25rem; font-weight: 900; }

.reg_box { background-image: url("/image/company/bg_reg.jpg"); background-position: center top; background-size: cover; background-attachment: fixed; padding: 60px 0; }

.reg_box .reg_box_in { width: 92%; max-width: 1200px; padding: 60px 5%; margin: 0 auto; background: #fff; }

.reg_list { padding: 40px 0 40px 0; position: relative; }

.reg_list::before { content: ""; display: block; position: absolute; width: 3px; height: 100%; background: #ddd; left: 14px; top: 0; }

.reg_list li { padding-left: 40px; position: relative; margin-bottom: 20px; }

.reg_list li .reg_time { font-size: 0.9375rem; font-weight: bold; color: #000943; }

.reg_list li:last-child { margin-bottom: 0; }

.reg_list li::before { content: ""; display: block; position: absolute; left: 10px; top: 8px; width: 12px; height: 12px; background: #000943; z-index: 3; border-radius: 6px; }

#tec_box001 { /*margin-top: 40px; padding-top: 40px;*/ position: relative; padding-top: 100px; }

#tec_box001 .tec_dep .tec_txt001 { max-width: 960px; width: 64vw; }

#tec_box001::before { content: ""; display: block; position: absolute; width: 74vw; height: 70%; background-image: url("/image/technique/bg_con001.jpg"); background-position: center center; background-repeat: no-repeat; background-size: cover; top: 0; right: 0; z-index: -1; }

#tec_box002 { position: relative; padding-top: 100px; }

#tec_box002 .tec_dep .tec_md001 { color: #fff; }

#tec_box002 .tec_dep .tec_txt001 { color: #fff; max-width: 960px; width: 64vw; }

#tec_box002::before { content: ""; display: block; position: absolute; width: 74vw; height: 70%; background-image: url("/image/technique/bg_con002.jpg"); background-position: center center; background-repeat: no-repeat; background-size: cover; top: 0; left: 0; z-index: -1; }

.tec_dep { width: 92%; max-width: 1200px; margin: 0 auto 80px; }

.tec_dep .tec_md001 { color: #000943; font-size: 2.125rem; font-weight: 900; }

.tec_dep .tec_txt001 { padding-top: 24px; padding-bottom: 40px; line-height: 2; }

.tec_list { display: -ms-flexbox; display: flex; -ms-flex-align: start; align-items: flex-start; -ms-flex-pack: start; justify-content: flex-start; }

.tec_list li { width: 32%; margin-right: 2%; margin-bottom: 20px; }

.tec_list li .tec_md002 { position: relative; padding-left: 20px; font-size: 1.125rem; font-weight: 900; color: #000943; line-height: 1.4; }

.tec_list li .tec_md002::before { content: ""; display: block; position: absolute; left: 0; top: 0; width: 6px; height: 100%; background: #000943; }

.tec_list li .tec_ph { margin-bottom: 20px; }

.tec_list li .tec_ph img { width: 100%; }

.tec_list li:nth-child(3n) { margin-right: 0; }

#tec_box003 .tec_box003_in { display: -ms-flexbox; display: flex; -ms-flex-align: stretch; align-items: stretch; -ms-flex-pack: start; justify-content: flex-start; }

#tec_box003 .tec_box003_in .tec_box003_l { width: 50%; background-image: url("/image/technique/bg_con003.jpg"); background-position: center center; background-repeat: no-repeat; background-size: cover; }

#tec_box003 .tec_box003_in .tec_box003_r { display: -ms-flexbox; display: flex; -ms-flex-align: start; align-items: flex-start; -ms-flex-pack: center; justify-content: center; -ms-flex-direction: column; flex-direction: column; background: #f7f7f7; width: 50%; padding: 140px 3vw; }

#tec_box003 .tec_box003_in .tec_box003_r h3 { font-size: 2.125rem; color: #000943; font-weight: 900; }

#tec_box003 .tec_box003_in .tec_box003_r p { padding-top: 20px; line-height: 2; }

.qua_area { position: relative; z-index: 2; }

.qua_nav { width: 92%; max-width: 1200px; margin: 0 auto; position: relative; }

.qua_list { display: -ms-flexbox; display: flex; -ms-flex-align: start; align-items: flex-start; -ms-flex-pack: center; justify-content: center; }

.qua_list .qua_list_in { width: calc(100% * 3); background-position: center center; background-repeat: no-repeat; background-size: cover; }

.qua_list .qua_list_in .qua_box002 { width: 100%; padding: 20px; background: rgba(0, 0, 0, 0.4); font-size: 0.9375rem; }

.qua_list .qua_list_in .qua_box002 .qua_txt001 { color: #fff; }

.qua_list .qua_list_in .qua_box001 { padding: 120px 30px 100px; text-align: center; }

.qua_list .qua_list_in .qua_box001 .qua_md001 { color: #fff; font-weight: 900; font-size: 1.5rem; padding-top: 10px; }

.qua_list .qua_list_in .qua_box001 .qua_ph001 img { height: 34px; }

#qua_all { width: 100%; position: relative; z-index: 1; padding-top: 60px; }

#qua_all::before { content: ""; display: block; position: absolute; width: 100%; height: 110%; top: -10%; left: 0; background: #f7f7f7; z-index: -1; }

.qua001 { width: 92%; max-width: 1400px; margin: 0 auto; padding-bottom: 100px; display: -ms-flexbox; display: flex; -ms-flex-align: stretch; align-items: stretch; -ms-flex-pack: start; justify-content: flex-start; }

.qua001 .qua001_l { width: 50%; position: relative; z-index: 2; padding-top: 100px; margin-bottom: -40px; }

.qua001 .qua_r { width: 65%; margin-left: -15%; transform: translate(5%, 0); position: relative; z-index: 1; background-position: center center; background-repeat: no-repeat; background-size: cover; }

.qua_d002 { background: #fff; padding: 40px; }

.qua_d002 .qua_d_txt { line-height: 2; }

.qua_d001 { margin-bottom: 100px; }

.qua_d001 h2 { font-weight: 900; color: #000943; font-size: 1.5rem; padding-top: 30px; }

.qua_d001 .qua001_svg img { height: 84px; }

.qua002 { width: 92%; max-width: 1400px; margin: 0 auto; padding-bottom: 100px; display: -ms-flexbox; display: flex; -ms-flex-align: stretch; align-items: stretch; -ms-flex-pack: start; justify-content: flex-start; -ms-flex-direction: row-reverse; flex-direction: row-reverse; overflow-x: hidden; }

.qua002 .qua001_l { width: 35%; position: relative; z-index: 2; padding-top: 100px; margin-bottom: -40px; padding-left: 5%; }

.qua002 .qua001_l .qua_d002 { margin-left: -60%; }

.qua002 .qua_r { width: 65%; position: relative; z-index: 1; background-position: center center; background-repeat: no-repeat; background-size: cover; }

#ko_area { position: relative; z-index: 2; width: 100%; padding: 90px 0; }

#ko_area::before { content: ""; display: block; position: absolute; top: 0; left: 0; background-position: center center; background-repeat: no-repeat; background-size: cover; background-image: url("/image/quality/bg_ph007.jpg"); width: 30%; height: 100%; z-index: 1; }

#ko_area #ko_area_in { width: 92%; max-width: 1200px; margin: 0 auto; position: relative; z-index: 4; display: -ms-flexbox; display: flex; -ms-flex-align: center; align-items: center; -ms-flex-pack: start; justify-content: flex-start; }

#ko_area #ko_area_in #ko_area_r { width: 53%; padding-left: 5%; }

#ko_area #ko_area_in #ko_area_r .ko_ph001 { font-weight: 900; color: #000943; font-size: 1.875rem; }

#ko_area #ko_area_in #ko_area_r .ko_txt001 { line-height: 2; padding-top: 30px; margin-bottom: 30px; }

#ko_area #ko_area_in #ko_area_r .top_btn001 { padding-top: 15px; margin-bottom: 30px; }

#ko_area #ko_area_in #ko_area_r .top_btn001 a { display: block; margin: 0 auto 0 0; }

#ko_area #ko_area_in #ko_area_l { width: 42%; }

#ko_area #ko_area_in #ko_area_l img { width: 100%; }

@media all and (-ms-high-contrast: none) {
 body { font-family: Verdana, Meiryo, sans-serif; } }

@media screen and (max-width: 1000px) {
 #tit_area { height: 300px; }
 #tit_area #tit_area_in { padding-top: 70px; }
 #tit_area #tit_area_in #tit_area_l #tit001 img { height: 30px; }
 #tit_area #tit_area_in #tit_area_r { height: calc(100% - 70px); top: 70px; }
 .com_md001 { margin-bottom: 20px; font-size: 1.625rem; }
 .gr_box { padding: 40px 0; }
 .gr_box .box { -ms-flex-direction: column; flex-direction: column; }
 .gr_box .box .gr_box_l { width: 100%; }
 .gr_box .box .gr_box_l h2 { font-size: 1.625rem; margin-bottom: 20px; }
 .reg_box { padding: 30px 0; }
 .reg_box .reg_box_in { padding: 30px 5%; }
 #tec_box001 { padding-top: 40px; }
 #tec_box001 .tec_dep .tec_txt001 { width: 100%; }
 #tec_box001 .tec_dep .tec_txt001 br { display: none; }
 #tec_box001::before { height: 40%; }
 #tec_box002 { padding-top: 40px; }
 #tec_box002 .tec_dep .tec_txt001 { width: 100%; }
 #tec_box002::before { width: 100%; height: 40%; }
 .tec_dep { margin: 0 auto 40px; }
 .tec_list { -ms-flex-direction: column; flex-direction: column; }
 .tec_list li { width: 100%; margin-bottom: 20px; margin-right: 0; }
 .tec_list li:last-child { margin-bottom: 0; }
 .tec_list li .tec_ph { margin-bottom: 10px; overflow: hidden; height: 160px; position: relative; width: 100%; }
 .tec_list li .tec_ph img { position: absolute; width: 100%; top: 50%; left: 50%; transform: translate(-50%, -50%); }
 #tec_box003 .tec_box003_in { -ms-flex-direction: column; flex-direction: column; }
 #tec_box003 .tec_box003_in .tec_box003_l { width: 100%; height: 240px; }
 #tec_box003 .tec_box003_in .tec_box003_r { width: 100%; padding: 30px 3vw 40px; }
 .qua_list { -ms-flex-direction: column; flex-direction: column; }
 .qua_list .qua_list_in { width: 100%; }
 .qua_list .qua_list_in .qua_box001 { padding: 80px 20px 60px; }
 .qua001 .qua001_l { padding-top: 0; width: 100%; margin-bottom: -70px; }
 .qua001 .qua_r { width: 100%; margin-left: -90%; margin-top: 160px; }
 .qua_d001 { margin-bottom: 260px; }
 .qua_d001 h2 { padding-top: 15px; }
 .qua002 { -ms-flex-direction: row; flex-direction: row; overflow-x: visible; }
 .qua002 .qua001_l { width: 50%; position: relative; z-index: 2; padding-left: 0; padding-top: 0; width: 100%; margin-bottom: -70px; }
 .qua002 .qua001_l .qua_d002 { margin-left: 0; background: #fff; padding: 40px; }
 .qua002 .qua_r { width: 65%; margin-left: -15%; transform: translate(5%, 0); width: 100%; margin-left: -90%; margin-top: 160px; }
 #ko_area { padding: 20px 0; }
 #ko_area::before { width: 50%; height: 100%; opacity: .5; top: 0; left: 50%; }
 #ko_area #ko_area_in { width: 100%; -ms-flex-direction: column; flex-direction: column; }
 #ko_area #ko_area_in #ko_area_r { width: 92%; margin: 0 auto; padding-left: 0; }
 #ko_area #ko_area_in #ko_area_r .ko_txt001 { padding-top: 15px; margin-bottom: 0; }
 #ko_area #ko_area_in #ko_area_r .top_btn001 a { width: 100%; }
 #ko_area #ko_area_in #ko_area_l { width: 92%; margin: 0 auto 20px; }
 #ko_area #ko_area_in #ko_area_l .ko_l_in { height: 260px; position: relative; overflow: hidden; width: 100%; }
 #ko_area #ko_area_in #ko_area_l .ko_l_in img { position: absolute; top: 100%; left: 50%; transform: translate(-50%, -100%); } }
