/* 공통 */
.sub-pd { padding: 80px 0;}
.sub-pd.first { padding-bottom: 80px; padding-top: 0; }
.sub-pd.last { padding-top: 80px; padding-bottom: 0; }
.sub-pd.dark { background: #222; color: #fff; }
.subtit { line-height: 1em; margin-bottom: 55px; font-size: 62px; font-weight: 700; color: #2c2c2c; }
.subtit.white { color: #fff;}
.subtit.mg { margin-bottom: 30px; }
.subtit.tc {text-align: center; }
.subtit2 { font-size: 28px; font-weight: 400; line-height: 1.3em; margin-bottom: 30px;}
.subtit.fx { display: flex; align-items: center; gap: 40px;}
.subtit.fx .subtit2 { margin-bottom: 0; font-weight: 700; }
.subtxt { font-size: 18px; line-height: 1.556em; font-weight: 300; }

/* sub1 공통 */
.sub1-bg { height: 100vh; color: #fff; text-align: center; display: flex; align-items: center; justify-content: center; background-repeat: no-repeat; background-position: center; background-size: cover;}
.sub1-bg.bg1 { background-image: url(../images/sub/sub1-1-bg.jpg);}
.sub1-bg.bg2 { background-image: url(../images/sub/sub1-2-bg.jpg);}
.sub1-bg h2 { font-size: 80px; font-weight: 700; line-height: 1.2em; }
.sub1-bg p { font-size: 22px; line-height: 1.7em; margin-top:35px; }
.sub1-bg p strong { font-size: 32px; font-weight: 700; margin-top: 15px; display: block; line-height: 1.5em; } 

/* Introduce */
.piramid { text-align: center; margin-bottom: 60px; }
.vs-list { display: flex; margin-bottom: 60px; }
.vs-list li { width: calc(100%/4); transition: .3s; border-right: 2px solid #fff; color: #fff; background: #222; display: flex; align-items: center; justify-content: center; text-align: center; font-size: 28px; font-weight: 600; line-height: 1.2em; height: 140px; }
.vs-list li:last-child { border-right: none; }
.vs-list li:hover { background: #ededed; color: #222; }
.triangle { text-align: center; }
.vs-list2 { display: flex; flex-wrap: wrap; gap: 40px; }
.vs-list2 li { width: calc(100%/2 - 20px); border: 1px solid #ddd; border-radius: 16px; padding: 35px 50px; height: 220px; position: relative; transition: .3s;}
.vs-list2 li .tit { font-size: 28px; line-height: 1.2em; font-weight: 700; margin-bottom: 15px; display: flex; align-items: center; gap: 10px; transition: .3s;}
.vs-list2 li .tit span { font-size: 18px; line-height: 1em; font-weight: 300; transition: .3s;}
.vs-list2 li .subtxt { transition: .3s;}
.vs-list2 li img { position: absolute; right: 30px; bottom: 35px; }
.vs-list2 li:hover { background: #fff; }
.vs-list2 li:hover .tit { color: #222; }
.vs-list2 li:hover .tit span { color: #505050; }
.vs-list2 li:hover .subtxt { color: #505050; font-weight: 300; }
.vs-list li.active { background: #ededed; color: #222; }
.vs-list2 li.active { background: #fff; }
.vs-list2 li.active .tit { color: #222; }
.vs-list2 li.active .tit span { color: #505050; }
.vs-list2 li.active .subtxt { color: #505050; font-weight: 300; } 
.sl-box { padding: 0 50px; border: 1px solid #ddd; border-radius: 16px; }
.sl-box .group { padding: 35px 0; border-bottom: 1px solid #ddd; display: flex; align-items: flex-start;}
.sl-box .group:last-child { border-bottom: none;}
.sl-box .group .titbox { width: 270px; padding-right: 20px; }
.sl-box .group .titbox h4 { line-height: 1em; font-size: 28px; font-weight: 700; color: #2c2c2c; margin-bottom: 10px; }
.sl-box .group .titbox p { font-size: 18px; color: #505050; font-weight: 400; }
.sl-box .group .info { flex: 1 1 auto; min-width: 0; width: 1%; }
.sl-box .group .info ul { display: flex; gap: 12px 10px; flex-wrap: wrap; }
.sl-box .group .info ul li {font-size: 22px; color: #505050; font-weight: 400; }
.sl-box .group .info ul li.wt1 { width: 37%;}
.sl-box .group .info ul li.wt2 { width: 63%;}
.sl-box .group .info ul li.wt3 { width: 37%;}
.sl-box .group .info h5 { font-size: 22px; font-weight: 600; line-height: 1em; margin-bottom: 15px; color: #2c2c2c;}
.hst { background: url(../images/sub/sub1-1-bg2.jpg) center no-repeat; background-size: cover;}
.hst-swp { position: relative; }
.hst-prev::after, .hst-next::after { display: none; }
.hst-prev, .hst-next { width: 31px; height: 92px; background-repeat: no-repeat; background-position: center; margin-top: -46px; background-size: contain; }
.hst-prev { left: -90px; background-image: url(../images/sub/hst-prev.png);}
.hst-next { right: -90px; background-image: url(../images/sub/hst-next.png);}
.hst-swiper { width: 100%; position: relative; overflow: hidden; color: #fff; }
.hst-swiper::before { width: 100%; height: 1px; background: #ddd; content: ""; position: absolute; top: 56px; left: 0; }
.hst-swiper .item { position: relative; padding-left: 40px; } 
.hst-swiper .item .year { line-height: 1em; font-size: 34px; font-weight: 700; margin-bottom: 45px; }
.hst-swiper .item .txt p { position: relative; padding-left: 10px; font-weight: 300; }
.hst-swiper .item .txt p::before { content: ""; position: absolute; left: 0; width: 2px; height: 2px; border-radius: 2px; top: 11px; background: #fff; }
.hst-swiper .swiper-pagination { position: relative; margin-top: 20px; }
.hst-swiper .swiper-pagination-progressbar { background: #8c8c8c;}
.hst-swiper .swiper-pagination-progressbar-fill { background: #fff; }
.pt-list { display: flex; flex-wrap: wrap; padding-left: 148px; gap: 60px 80px; }
.pt-list li { width: calc(100%/4 - 60px); text-align: center; box-shadow: 0 4px 20px rgba(0,0,0,0.2);}

/* Differentiation */
.dif-sec { height: 100vh; display: flex; align-items: center; background-repeat: no-repeat; background-position: center; background-size: cover;}
#dif1 { background-image: url(../images/sub/sub1-2-bg2.jpg); color: #2c2c2c;}
#dif2 { background-image: url(../images/sub/sub1-2-bg3.jpg); color: #fff; }
#dif3 { background-image: url(../images/sub/sub1-2-bg4.jpg); color: #2c2c2c; }
#dif4 { background-image: url(../images/sub/sub1-2-bg5.jpg); color: #fff; }
#dif5 { background-image: url(../images/sub/sub1-2-bg6.jpg); color: #2c2c2c; }
#dif6 { background-image: url(../images/sub/sub1-2-bg7.jpg); color: #fff; }
#dif7 { background-image: url(../images/sub/sub1-2-bg8.jpg); color: #2c2c2c; }
#dif8 { background-image: url(../images/sub/sub1-2-bg9.jpg); color: #fff; }
#dif9 { background-image: url(../images/sub/sub1-2-bg10.jpg); color: #2c2c2c; }
.dif-fx { display: flex; align-items: center; }
.dif-fx>div { width: calc(100%/2);}
.dif-fx .info { padding-right: 30px; }
.dif-fx .info h5 { font-size: 28px; font-weight: 400; line-height: 1.2em; margin-bottom: 55px; }
.dif-fx .info h5 span { font-weight: 700; }
.dif-fx .info p { font-size: 22px; font-weight: 400; letter-spacing: -.03em; line-height: 1.5em; margin-bottom: 25px;}
.dif-fx .info p:last-child { margin-bottom: 0; }
.dif-fx .info p span { font-weight: 600; font-size: 24px; }
.dif-fx .video-container { background: #222; }
.dif-fx .thumb {padding-bottom: 56.25%; display: block; position: relative; overflow: hidden;}
.dif-fx .thumb img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover;}
.dif-fx.rv { flex-direction: row-reverse; text-align: right;}
.dif-fx.rv .info { padding-right: 0; padding-left: 30px;}

/* price - 리스트 */
.pr h4 { padding: 70px 0 30px; font-size: 28px; font-weight: 400; color: #505050; letter-spacing: 0;}
.pr-list li { border-bottom: 1px solid #ddd;}
.pr-list li a { display: flex; align-items: center; justify-content: space-between; padding: 25px 0; flex-wrap: wrap; gap: 15px; }
.pr-list li a .subtit { line-height: 1em; margin-bottom: 0; position: relative; padding-left: 0px; transition: .2s;}
/* .pr-list li a .subtit::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; margin: auto; width: 63px; height: 36px; background: url(../images/sub/sub3-arrow.png) center no-repeat; background-size: contain; transition: .2s;} */
.pr-list li a .txt { font-size: 22px; font-weight: 400; }
.pr-list li a:hover { color: #f59c25;}
.pr-list li a:hover .subtit { color: #f59c25; }
.pr-list li a:hover .subtit::before { background-image: url(../images/sub/sub3-arrow-c.png); }

/* price - 상세 */
.pr-tbl-wrap { overflow: auto;}
.pr-tbl { width: 100%; border-collapse: collapse; }
.pr-tbl tr { border-bottom: 1px solid #ddd;}
.pr-tbl tr th { background: #222; color: #fff; font-size: 40px; font-weight: 700; line-height: 1em; padding: 45px 10px; }
.pr-tbl tr td { padding: 25px 10px; line-height: 1.5em; font-size: 22px; font-weight: 400; color: #505050; text-align: center; }
.pr-tbl tr td.va { vertical-align: top; }
.pr-tbl tr td.bg { font-size: 28px; font-weight: 600; background: #222; color: #fff; line-height: 1.2em; }
.pr-tbl tr td.bg span { font-size: 22px; font-weight: 400; }
.pr-tbl tr td.fw { font-weight: 600; }
.pr-tbl tr td .group { margin-bottom: 40px; }
.pr-tbl tr td .group:last-child { margin-bottom: 0; }
.pr-tbl tr td .group .fw { font-weight: 700; margin-bottom: 10px; }
.pr-tbl tr td .group .fw2 { font-weight: 600; }
.pr-tbl.white tr th { background: #8a8a8a; color: #fff; font-size: 30px; }
.pr-tbl.white tr td { color: #fff; }
.pr-tbl.white tr td.bg { font-size: 24px; background: #8a8a8a; }
.subtit.space { justify-content: space-between;}
.pr-span { font-size: 20px; font-weight: 400; margin-top: 25px; }
.pr-btn { width: 220px; height: 60px; border-radius: 30px; border: 1px solid #aaa; display: flex; align-items: center; padding-left: 30px; line-height: 1.5em; font-size: 18px; color: #333; font-weight: 300; position: relative; margin: 80px auto 0;}
.pr-btn::after { content: ""; position: absolute; right: 30px; top: 0; bottom: 0; margin: auto; width: 9px; height: 14px; background: url(../images/sub/pf-view-c.png) center no-repeat; background-size: contain; transition: .2s; }
.pr-btn:hover { background: #121212; color: #fff; border-color: #121212;}
.pr-btn:hover::after { background-image: url(../images/sub/pf-view.png); }
.ct-txt { font-size: 20px; line-height: 1.3em; margin-bottom: 35px; }
.pr-ct { display: flex; }
.pr-ct .left { width: 33%; padding-right: 20px; }
.pr-ct .right { width: 67%;}
.pr-ct .left.wt { width: 43%; }
.pr-ct .right.wt { width: 57%;}
.add-box .group { margin-bottom: 30px; }
.add-box .group:last-child { margin-bottom: 0; }
.add-box .group h4 { font-size: 30px; font-weight: 500; line-height: 1em; margin-bottom: 10px; color: #2c2c2c;}
.ct .fx { display: flex; justify-content: space-between; gap: 20px; margin-bottom: 40px; }
.ct .fx .group { width: calc(100%/3); display: flex; align-items: center; }
.ct .fx .group.w100 { width: 100%; }
.ct .fx .group.db { display: block; }
.ct .fx .group.flex {flex: 1 1 auto; min-width: 0; width: 1%; padding-right: 20px; }
.ct .fx .group h5 { line-height: 1em; font-size: 20px; font-weight: 600; color: #2c2c2c; width: 78px; }
.ct .fx .group.flex h5 { width: 90px; }
.ct .fx .group.db h5 { width: 100%; margin-bottom: 12px; }
.ct .required { color: #505050; }
.ct .fx .group .inp { flex: 1 1 auto; min-width: 0; width: 1%; }
.ct .fx .group.db .inp { width: 100%; }
.ct .input { height: 44px; border-radius: 8px; }
.ct .file-upload {display:flex; height:44px; width: 100%; align-items: center;}
.ct .file-button {display:flex; justify-content:center; align-items:center; height:100%; padding:0 21px; border:0; border-radius:8px; background:#555; color:#fff; cursor:pointer;}
.ct .file-button:hover {background:#2c2c2c;}
.ct .file-name {flex:1 1 auto; min-width:0; width:1%; display:flex; align-items:center; height:100%; padding:0 10px; }
.ct .file-name.bg { border: 1px solid #ddd; background: #fff; border-radius: 8px; max-width: 250px; margin-right: 10px; }
.ct .item-fx { display: flex; gap: 10px 30px; flex-wrap: wrap;}
.ct .item-fx .item { font-size: 18px; }
.ct .item-fx .item .radiobox label { cursor: pointer;}
.ct .item-fx .item .radiobox label { cursor: pointer;}
.ct .item-fx .item:hover { font-weight: 700; }
.ct .item-fx .item .radiobox input:checked + label { font-weight: 700 ; }
.ct .memo-txt { padding-left: 15px; font-size: 16px; font-weight: 400; color: #555; line-height: 1.4em; }
.ct .submit-btn { width: 152px; height: 44px; border-radius: 8px; background: #2c2c2c; color: #fff; display: flex; align-items: center; justify-content: center; line-height: 1em; font-size: 16px; font-weight: 600; cursor: pointer;}
.ct-cnt { display: flex; margin-top: 80px; flex-wrap: wrap;}
.ct-cnt>div { width: calc(100%/2); }
.ct-cnt>div .tit { border-right: 1px solid #ddd; text-align: center; background: #222; color: #fff; font-size: 28px; font-weight: 700; line-height: 1em; padding: 26px 10px;}
.ct-cnt>div .cnt {border: 1px solid #ddd; text-align: center; padding: 40px 10px;}
.ct-cnt>div:last-child .cnt { border-left: none;}
.ct-cnt>div .cnt p { font-size: 22px; line-height: 1.4em; font-weight: 400; }
.ct-cnt>div .cnt p.mt { margin-top: 12px; }
.ct-cnt>div .cnt .line { width: 50px; height: 2px; margin: 25px auto; background: #bbb; }

/* 오시는 길 */
.ct-pd { padding: 160px 0 100px;}

/* news */
/* .news-wrap { padding-top: 40px; } */