@charset "utf-8";
/* 공통 */
.sub-pd { padding: 120px 0;}
.sub-pd.pb { padding-bottom: 100px; padding-top: 0;}
.sub-pd.pt { padding-top: 100px; padding-bottom: 0;}
.sub-pd.gray { background: #f9f9f9; }
.subbox { margin-bottom: 70px; }
.subbox.mg { margin-bottom: 0; }
.subtit { position: relative; line-height: 1.2em; font-size: 32px; font-weight: 700; color: #121212; letter-spacing: -.03em; padding-left: 40px; margin-bottom: 35px; }
.subtit::before { content: ""; position: absolute; left: 0; width: 28px; height: 28px; background: url(../images/sub/tit-bf.png) center no-repeat; background-size: contain; top: 5px;}
.sub-mg { padding-left: 40px; }
.subtxt { font-size: 18px; }
.blue-tit { font-size: 40px; font-weight: 700; line-height: 1em; letter-spacing: -.03em; color: #16549f; margin-bottom: 55px; }
.sns-group { display: flex; margin-bottom: 20px; }
.sns-group:last-child { margin-bottom: 0; }
.sns-group .title { display: flex; align-items: center;}
.sns-group .title .icon { width: 30px; margin-right: 10px; }
.sns-group .title .tit { font-size: 18px; font-weight: 700; color: #121212; letter-spacing: -.03em; line-height: 1.2em; }
.sns-group .info { flex: 1 1 auto; min-width: 0; width: 1%; padding-left: 20px; padding-top: 3px;}

/* 시설소개 */
.sub1-tit {text-align: center;  line-height: 1em; font-size: 48px; font-family: 'JalnanGothic'; letter-spacing: -.03em; color: #121212; font-weight: 700; margin-bottom: 65px; }
.fc-tab-wrap {position:sticky; top: 80px; z-index: 99; background: #fff; border-top: 1px solid #ddd;}
.fc-tab-wrap::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; width: 100%; height: 2px; background: #ddd; }
.fc-tab {margin:0 auto; max-width:1400px;}
.fc-tab ul {display:flex;}
.fc-tab ul li {flex:1; text-align:center; position: relative; }
.fc-tab ul li::after { content: ""; position: absolute; right: 0; top: 0; bottom: 0; margin: auto; width: 1px; height: 16px; background: #ddd; }
.fc-tab ul li:last-child::after { display: none;}
.fc-tab ul li a {display:flex; flex-direction:column; justify-content:center; align-items:center; width:100%; height:60px; padding:0 10px; color:#878787; font-size:17px; font-weight:600; line-height:1.2em; letter-spacing:-.03em; position: relative; }
.fc-tab ul li a::after { content: ""; position: absolute; left: 0; bottom: 0px; width: 100%; height: 2px; background: #ea5413; display: none; }
.fc-tab ul li.active a {color:#ea5413;}
.fc-tab ul li.active a::after { display: block; }
.gt { display: flex; }
.gt .img { width: 450px; margin-right: 100px; }
.gt .info { flex: 1 1 auto; min-width: 0; width: 1%; }
.gt .info p { font-size: 18px; line-height: 1.6em; font-weight: 300; margin-top: 25px; }
.gt .info p strong { font-weight: 600; color: #121212; }
.gt .info .sign { display: flex; justify-content: flex-end; align-items: center; gap: 30px; margin-top: 50px;}
.gt .info .sign strong { font-size: 20px; font-weight: 700; color: #121212; letter-spacing: -.03em; }
.gt .info .sign strong span { padding-left: 15px; }
.fc-list { display: flex; gap: 20px; flex-wrap: wrap;}
.fc-list li { width: calc(100%/4 - 15px); border-radius: 24px; border: 1px solid #ddd; text-align: center; padding: 40px 10px; background: #fff; }
.fc-list li .tit { font-size: 16px; font-weight: 600; color: #121212; letter-spacing: -.03em; line-height: 1em; margin: 20px 0 12px;}
.fc-list li .txt { line-height: 1.5em; font-size: 18px; }
.hst-fx { display: flex; align-items: flex-start;}
.hst-fx .left { width: 50%; padding-right: 100px; }
.hst-fx .left .year { font-family: 'JalnanGothic'; font-size: 56px; font-weight: 700; color: #121212; letter-spacing: -.03em; line-height: 1em; margin: 60px 0 15px; }
.hst-fx .left h3 { font-size: 24px; font-weight: 300; line-height: 1.5em; }
.hst-fx .right { position: relative; }
.hst-fx .right::before { content: ""; position: absolute; left: 130px; top: 10px; width: 1px; height: 98%; background: #ddd; }
.hst-fx .right .group { display: flex; margin-bottom: 80px; }
.hst-fx .right .group:last-child { margin-bottom: 0; }
.hst-fx .right .group .year { width: 130px; position: relative; font-size: 24px; font-weight: 700; letter-spacing: -.03em; color: #16549f; }
.hst-fx .right .group .year::after { content: ""; position: absolute; right: -13px; top: 0; width: 24px; height: 24px; border-radius: 100%; background: #16549f; border: 7px solid #a2bbd9;}
.hst-fx .right .group .info { flex: 1 1 auto; min-width: 0; width: 1%; padding-left: 50px; }
.hst-fx .right .group .info ul li { display: flex; margin-bottom: 15px; display: flex; font-size: 18px; }
.hst-fx .right .group .info ul li:last-child { margin-bottom: 0; }
.hst-fx .right .group .info ul li .month { width: 65px; color: #121212; font-weight: 700; letter-spacing: -.03em; }
.hst-fx .right .group .info ul li .txt { flex: 1 1 auto; min-width: 0; width: 1%; font-weight: 300; }
.organ { text-align: center; }
.sub1-tbl-wrap { overflow: auto;}
.sub1-tbl { width: 100%; border-collapse: collapse; border-top: 2px solid #16549f; }
.sub1-tbl tr { border-bottom: 1px solid #ddd;}
.sub1-tbl tr th { border-right: 1px solid #ddd; background: #f4f4f4; color: #121212; line-height: 1em; font-size: 20px; font-weight: 700; letter-spacing: -.03em; padding: 20px 10px; }
.sub1-tbl tr th:last-child { border-right: 0; }
.sub1-tbl tr td { padding: 18px 10px; font-size: 18px; line-height: 1.5em; border-right: 1px solid #ddd; text-align: center;}
.sub1-tbl tr td:last-child { border: none;  }
.mission { background: url(../images/sub/mission-bg.jpg) center no-repeat; background-size: cover; color: #fff; }
.mission .sub1-tit { color: #fff; }
.ms-top { display: flex; gap: 20px; margin-bottom: 120px; flex-wrap: wrap;}
.ms-top>div { width: calc(100%/2 - 10px); border: 1px solid rgba(255,255,255,0.5); background: rgba(255,255,255,0.1); padding: 35px; display: flex; align-items: center; border-radius: 16px; }
.ms-top>div .title { position: relative; padding-right: 35px; display: flex; align-items: center;} 
.ms-top>div .title::after { content: ""; position: absolute; right: 0; top: 0; bottom: 0; margin: auto; width: 1px; background: #fff; height: 40px; }
.ms-top>div .title .icon { margin-right: 15px; }
.ms-top>div .title .tit { flex: 1 1 auto; min-width: 0; width: 1%; font-size: 24px; font-weight: 700; letter-spacing: -.03em; line-height: 1.3em; }
.ms-top>div .title .tit span { display: block; color: rgba(255,255,255,0.5); }
.ms-top>div .info { flex: 1 1 auto; min-width: 0; width: 1%; font-size: 20px; line-height: 1.7em; padding-left: 35px; letter-spacing: -.03em; font-weight: 700; }
.ms-tit { text-align: center; margin-bottom: 35px; line-height: 1em; font-size: 32px; font-weight: 700; }
.ms-list { display: flex; gap: 60px; flex-wrap: wrap; position: relative; }
.ms-list::before { content: ""; position: absolute; left: 0; width: 100%; top: 119px; height: 1px; background: rgba(255,255,255,0.2); }
.ms-list li { width: calc(100%/5 - 48px); text-align: center; position: relative; }
.ms-list li::after { content: ""; position: absolute; right: -34px; width: 8px; height: 8px; border-radius: 8px; background: #fff; top: 115px; }
.ms-list li:last-child::after { display: none; }
.ms-list li .circle { border: 1px solid rgba(255,255,255,0.5); background: rgba(255,255,255,0.1); border-radius: 100%; height: 232px; padding-top: 55px; margin-bottom: 25px; }
.ms-list li .circle .num { line-height: 1em; color: rgba(255,255,255,0.5); font-size: 32px; font-weight: 700; margin-bottom: 35px; }
.ms-list li .circle .tit { font-size: 24px; font-weight: 700; line-height: 1.4em; letter-spacing: -.03em; }
.ms-list li .txt { font-size: 18px; font-weight: 300; line-height: 1.6em; }

/* 직업재활사업 */
.jb-list { display: flex; gap: 40px; flex-wrap: wrap;}
.jb-list li { width: calc(100%/2 - 20px);}
.jb-list li .tit { margin-bottom: 10px; text-align: center; background: #007fc0; color: #fff; font-size: 18px; font-weight: 700; letter-spacing: -.03em; line-height: 1.2em; padding: 15px 10px; border-radius: 8px; }
.jb-list li .tit.clr { background: #16549f; }
.jb-list li .txtbox { background: #f4f4f4; border-radius: 8px; padding: 28px 30px; min-height: 210px;}
.jb-list li .txtbox p { position: relative; padding-left: 7px; margin-bottom: 15px; }
.jb-list li .txtbox p:last-child { margin-bottom: 0; }
.jb-list li .txtbox p::before { content: ""; position: absolute; left: 0; width: 2px; height: 2px; background: #505050; border-radius: 2px; top: 11px; }
.jb-img { border: 1px solid #ddd; text-align: center; border-radius: 8px; padding: 30px 10px;}
.jb-list2 { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 60px;}
.jb-list2 li { width: calc(100%/6 - 15px); text-align: center; background: #fff; border-radius: 24px;  border: 2px solid #16549f; position: relative; }
.jb-list2 li .num { position: absolute; left: 0; right: 0; margin: auto; width: 48px; height: 48px; border-radius: 48px; background: #16549f; color: #fff; line-height: 1em; display: flex; align-items: center; justify-content: center; font-size: 18px; color: #fff; letter-spacing: -.03em; font-weight: 700; top: -24px; }
.jb-list2 li .top { padding: 50px 0 28px; border-bottom: 1px dashed #ddd;}
.jb-list2 li .tit { line-height: 1.2em; font-size: 18px; font-weight: 700; color: #121212; letter-spacing: -.03em; margin-top: 20px; }
.jb-list2 li .btm { padding: 28px 10px; }
.jb-list2 li .btm .txt { line-height: 1.5em; margin-bottom: 12px; }
.jb-list2 li .btm .txt:last-child { margin-bottom: 0; }

/* sub3 공통 */
.sub3-list { display: flex; gap: 60px 100px; flex-wrap: wrap; }
.sub3-list li { width: calc(100%/4 - 75px); border: 1px solid #ddd; background: #fff; text-align: center;  padding: 55px 10px; border-radius: 100%; position: relative;}
.sub3-list li::after { content: ""; position: absolute; right: -70px; top: 0; bottom: 0; margin: auto; width: 40px; height: 40px; background: url(../images/sub/sub3-1-right.png) center no-repeat; background-size: contain;}
.sub3-list li .step { line-height: 1em; font-size: 14px; font-weight: 600; color: #16549f; letter-spacing: -.03em; margin: 18px 0 10px;}
.sub3-list li .tit { font-size: 18px; font-weight: 700; line-height: 1.2em; letter-spacing: -.03em; color: #121212; }
.sub3-list li.clr { background: #16549f; border-color: #16549f; }
.sub3-list li.clr .step { color: #fff; }
.sub3-list li.clr .tit { color: #fff; }
.sub3-list li:nth-of-type(4n)::after { display: none; }

/* 임가공사업 */
.pc-list { display: flex; gap: 40px; flex-wrap: wrap;}
.pc-list li { width: calc(100%/4 - 30px); position: relative; border-radius: 24px; overflow: hidden;}
.pc-list li img { width: 100%; }
.pc-list li .tit { position: absolute; left: 0; width: 100%; bottom: 0; text-align: center; color: #fff; background: rgba(0,0,0,0.7); font-size: 16px; font-weight: 600; line-height: 1.2em; letter-spacing: -.03em; padding: 15px 10px;}

/* 인쇄물사업 */
.print-list { display: flex; flex-wrap: wrap; gap: 20px; }
.print-list li { width: calc(100%/4 - 15px); border-radius: 24px; border: 1px solid #ddd; text-align: center; padding: 35px 10px;}
.print-list.wt { gap: 21px;}
.print-list.wt li { width: calc(100%/3 - 14px);}
.print-list li .tit { font-size: 18px; font-weight: 600; line-height: 1.5em; color: #121212; margin-top: 10px; }
.print-txtfx { display: flex; flex-wrap: wrap; gap: 25px 0; }
.print-txtfx.wt { gap: 15px 0;}
.print-txtfx p { width: calc(100%/6); position: relative; font-size: 20px; line-height: 1.5em; padding-left: 15px; }
.print-txtfx p.wt { width: 100%; font-size: 18px;} 
.print-txtfx p.wt strong { color: #121212; font-weight: 600; }
.print-txtfx p::before { content: ""; position: absolute; left: 0; top: 11px; width: 6px; height: 6px; border-radius: 6px; background: #ccc; }
.print-bg { background: #f3f6fa; }
.print-bg.mg { margin-bottom: 100px; }
.print-bg .contain { position: relative; }
.print-btbox { position: absolute; right: 30px; top: 0; display: flex; gap: 10px; }
.print-prev::after, .print-next::after { display: none;}
.print-prev, .print-next { width: 50px; height: 50px; position: relative; top: auto; margin-top: 0; border: 1px solid #ddd; border-radius: 100%; background-repeat: no-repeat; background-position: center; background-size: 16px; background-color: #fff; transition: .2s;}
.print-prev { left: auto; background-image: url(../images/sub/sub3-2-prev.png);}
.print-prev:hover { background-color: #16549f; border-color: #16549f; background-image: url(../images/sub/sub3-2-prev-w.png);}
.print-next { left: auto; background-image: url(../images/sub/sub3-2-next.png); right: auto;}
.print-next:hover { background-color: #16549f; border-color: #16549f; background-image: url(../images/sub/sub3-2-next-w.png);}
.print-swiper { width: 100%; position: relative; overflow: hidden;}
.print-swiper-slide { position: relative;}
.print-swiper-slide::after { content: ""; position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; border: 1px solid #ddd;}
.print-swiper-slide img { width: 100%;}

/* 인증서현황 */
.certi-list { display: flex; flex-wrap: wrap; gap: 40px; }
.certi-list li { width: calc(100%/4 - 30px); position: relative; }
.certi-list li::after { content: ""; position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; border: 1px solid #ddd;}
.certi-list li img { width: 100%; }

/* 우선구매제도 */
.sub3-tbl-wrap { overflow: auto; }
.sub3-tbl { width: 100%; border-collapse: collapse; border-top: 1px solid #121212;}
.sub3-tbl tr { border-bottom: 1px solid #ddd;}
.sub3-tbl tr th {padding: 25px 10px; font-size: 18px; font-weight: 600; line-height: 1.6em; color: #121212; }
.sub3-tbl tr td { padding: 25px 10px; text-align: left; font-size: 16px; line-height: 1.556em; }
.ph-blue { color: #16549f; font-size: 20px; font-weight: 700; line-height: 1.4em; letter-spacing: -.03em; margin-bottom: 20px; }
.ph-txtbox { padding: 25px 0; padding-left: 20px; }
.ph-txtbox p { margin-bottom: 10px; }
.ph-txtbox p:last-child { margin-bottom: 0; }
.ph-img { text-align: center; }
.ph-list { display: flex; margin-top: 30px; flex-wrap: wrap; gap: 90px; }
.ph-list li { width: calc(100%/3 - 60px); border-top: 2px solid #121212;}
.ph-list li .tit { text-align: center; padding: 28px 10px; font-size: 18px; line-height: 1.6em; color: #121212; letter-spacing: -.03em; font-weight: 600; }
.ph-list li .tit strong { color: #16549f; font-weight: 700; }
.ph-list li .txtbox { background: #f4f4f4; border-radius: 8px; padding: 27px 30px; min-height: 200px;}
.ph-list li .txtbox .txt { position: relative; line-height: 1.556em; padding-left: 9px; margin-bottom: 25px; }
.ph-list li .txtbox .txt:last-child { margin-bottom: 0; }
.ph-list li .txtbox .txt::before { content: ""; position: absolute; left: 0; top: 11px; width: 2px; height:2px; border-radius: 2px; background: #505050; }

/* 후원 자원봉사 */
.vl-fx { display: flex; align-items: center;}
.vl-fx .left { text-align: left; width: 55%; }
.vl-fx .left .group { margin-bottom: 42px; }
.vl-fx .left .group:last-child { margin-bottom: 0; }
.vl-fx .left .group h2 { font-size: 40px; font-weight: 700; color: #121212; letter-spacing: -.03em; line-height: 1.2em; margin-bottom: 20px; }
.vl-fx .left .group h2 span {color: #16549f; }
.vl-fx .left .group strong { font-size: 24px; font-weight: 300; color: #121212; letter-spacing: -.03em;}
.vl-fx .left .group h4 { font-size: 32px; font-weight: 600; letter-spacing: -.03em; line-height: 1.2em; color: #121212; margin-bottom: 15px; }
.vl-fx .left .group p { font-size: 18px; line-height: 1.6em; font-weight: 300; }
.vl-fx .right { width: 46%; text-align: right; }
.vl-list { display: flex; gap: 42px; flex-wrap: wrap; }
.vl-list li { width: calc(100%/3 - 28px); border: 1px solid #ddd; border-radius: 24px; text-align: center; padding: 38px 10px;}
.vl-list li .tit { font-size: 24px; font-weight: 700; line-height: 1em; color: #121212; margin: 20px 0; letter-spacing: -.03em;}
.vl-list li .txt { line-height: 1.556em; font-weight: 300;}
.vl-list2 { display: flex; gap: 30px 96px; flex-wrap: wrap; }
.vl-list2 li { width: calc(100%/6 - 80px); position: relative; text-align: center; }
.vl-list2 li::after { content: ""; position: absolute; right: -68px; top: 50px; width: 40px; height: 40px; background: url(../images/sub/sub3-1-right.png) center no-repeat; background-size: contain;}
.vl-list2 li .step { line-height: 1em; font-size: 14px; font-weight: 600; color: #16549f; letter-spacing: -.03em; margin: 18px 0 10px;}
.vl-list2 li .tit { font-size: 18px; font-weight: 700; line-height: 1.6em; letter-spacing: -.03em; color: #121212; }
.vl-list2 li .tit span { display: block; font-size: 14px; font-weight: 600; }
.vl-list2 li .iconbox { width: 100%; display: flex; align-items: center; justify-content: center; height: 150px; border-radius: 100%; border: 1px solid #ddd;}
.vl-list2 li:last-child::after { display: none; }
.vl-list2 li:nth-of-type(2n) .iconbox { background: #16549f; border-color: #16549f; }
