@charset "utf-8";
/*───────────────────────────────────────────────────────────
	
	header, footer, main 관련 작성 css 파일입니다.

	** 이와 서브페이지 관련 css는 /css/sub.css 에 있습니다.

───────────────────────────────────────────────────────────*/

body::-webkit-scrollbar { display: none; }

/*───────────────────────────────────────────────────────────
	layout common
───────────────────────────────────────────────────────────*/
	#wrap {position:relative;width:100%; box-sizing: border-box; overflow: clip;}
    .w_custom{position: relative; width: calc(100% - 60px); max-width: 1500px; margin-inline: auto; box-sizing: border-box;}
    #container{position: relative; padding-bottom:150px; box-sizing: border-box;}
    #container:has(.fullSec){width: 100%; max-width: 100%;}
    #container:has(.pbZero){padding-bottom: 0;}
	.sr-only{position: absolute;width: 1px; height: 1px;margin: -1px;padding: 0;overflow: hidden; clip: rect(0, 0, 0, 0); border: 0;}
	
	@media (max-width: 1330px) {
		br.for_pc { display: none; }
	}

    @media (max-width:1023px){
        #container{padding-bottom:clamp(100px, 15vw, 150px);}
    }
    @media (max-width:860px){
        .w_custom{width: calc(100% - 30px);}
    }
    @media (max-width:320px){
        .w_custom{width: calc(100% - 20px);}
    }

/*───────────────────────────────────────────────────────────

    HEADER | outline/header.html, outline/nav.html

───────────────────────────────────────────────────────────*/
	/** PC 일반 **/
		#header {position: fixed;top: 0;left: 0;width: 100%;height: 142px;z-index: 100;background: none;transition: all 0.4s;}
        #header .w_custom { max-width: 1720px; height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 30px; }
        #header .logo { height: 100%; padding-bottom: 10px; }
        #header .logo a { display: flex; align-items: center; padding-block: 10px; height: 100%; max-width: 250px; }
        #header .cont { display: flex; align-items: center; gap: clamp(20px, 6.5vw, 100px); height: 100%; }
        #header .gnb { display: flex; height: 100%; gap: clamp(20px, 4.5vw, 61px); font-size: var(--title-20); text-align: center; line-height: 1.3; }
        #header .gnb > li { position: relative; font-size: inherit; font-weight: 500; color: var(--black-color01); height: 100%; transition: all 0.4s; font-family: var(--font-type03); }
        #header .gnb > li > a { display: flex; align-items: center; height: 100%; letter-spacing: -0.03em; }
        #header .gnb .dep02 { position: absolute; top: 80%; left: 50%; translate: -50%; background: var(--point-color01); border-radius: var(--radius-10); padding-block: 20px; opacity: 0; pointer-events: none; transition: all 0.4s; width: 180px; }
        #header .gnb .dep02 > li { font-size: 90%; font-weight: 500; filter: var(--filter-white); transition: all 0.4s; }
        #header .gnb .dep02 > li > a { display: block; padding: 10px 20px; }
        #header .allCate { display: flex; flex-direction: column; justify-content: space-between; width: 24px; aspect-ratio: 1.2; }
        #header .allCate span { width: 100%; height: 2px; background: var(--black-color01); transition: all 0.4s; }

        #header :where(.logo, .gnb > li > a, .allCate){filter: var(--filter-white); transition: all 0.4s;}
		
		body:has(.no_vis) #header{background: var(--point-white); }
		body:has(.no_vis) #header :where(.logo, .gnb > li > a, .allCate){filter: none;}

        @media (hover: hover) and (pointer: fine) {
            #header:hover { background: var(--point-white); box-shadow: 0 -1px 0 inset var(--border-color01); }
            #header:hover :where(.logo, .gnb > li > a, .allCate){filter: none;}
            #header .gnb > li:hover a { color: var(--point-color01); }
            #header .gnb > li:hover .dep02 { opacity: 1; pointer-events: all; }
            #header .gnb .dep02:has(> li:hover) > li:not(:hover){opacity: 0.4;}
            #header .allCate:hover span { background: var(--point-color01); }
        }

        #header.on { background: var(--point-white); box-shadow: 0 -1px 0 inset var(--border-color01); translate: 0 -40px; padding-top: 34px; }
        #header.on :where(.logo, .gnb > li > a, .allCate){filter: none;}

        @media (max-width: 1120px) {
            #header .gnb { display: none; }
        }

        @media (max-width: 1023px) {
            #header{height: clamp(80px, 14vw, 142px);  }
            
            #header .logo a { max-width: clamp(170px, 27vw, 250px); }
            #header.on { translate: 0 clamp(-40px, -2vw, -20px); padding-top: clamp(10px, 3.4vw, 34px); }
        }


/*───────────────────────────────────────────────────────────

    ASIDE | outline/header.html, outline/nav.html

───────────────────────────────────────────────────────────*/
	#aside{position: fixed;top: 0;left:0;width: 100%;height: 100%;z-index: 999;background: rgba(255,255,255,0.8);backdrop-filter:blur(10px);display: flex;flex-direction: column;overflow: hidden;overflow-y: auto; box-sizing: border-box;opacity: 0;transition: all 0.6s;clip-path: inset(0 0 100% 0);}
    #aside.on { opacity: 1; clip-path: inset(0); }
    body:has(#aside.on) { overflow: clip; touch-action: none; }
    #aside .w_custom { flex-shrink: 0; max-width: 1720px; min-height: 100%; padding-block: 100px; }
    #aside .cont { position: relative; width: 100%; display: flex; flex-direction: column; height: 100%; justify-content: center; }
    #aside .gnb { width: 100%; font-size: var(--title-20); letter-spacing: 0; display: grid; align-items: start; justify-content: center; grid-template: auto / repeat(6, 1fr); gap: clamp(15px, 2.2vw, 40px); }
    #aside .gnb > li { color: var(--black-color01); font-size: inherit; text-align: center; }
    #aside .gnb > li > a{position: relative;display: block;font-size: 180%;font-weight: 700;line-height: 1.2;padding-block: 30px;transition: all 0.4s;}
    #aside .gnb > li > a:before{position: absolute;content: '';top: 0;left: 50%;translate: -50%;width:12px;height: 0;opacity:0;border-radius:100%;background: var(--point-color01);transition:all 0.3s;}
    #aside .gnb > li > a em{font-weight: inherit;}
    #aside .gnb > li > a span{font-size: 60%;font-weight: 400;color: rgba(255,255,255,0.6);}
    #aside .gnb .dep02{margin-top: 8px;}
    #aside .gnb .dep02 > li { transition: all 0.4s; }
    #aside .gnb .dep02 > li > a{display: block;font-size:110%;font-weight:400;padding-block: 15px;color: var(--black-color06);transition: all 0.4s;}
    #aside .close_btn{position: absolute; width: 40px;height: 40px;z-index: 9;  top: 40px; right: 0;  }
    #aside .close_btn span{position: absolute;top:50%;left:50%;transform: translate(-50%, -50%) rotate(45deg);width: 100%;height: 2px;background: var(--black-color01);}
    #aside .close_btn span + span{transform: translate(-50%, -50%) rotate(-45deg);}

    @media (hover: hover) and (pointer: fine) {
        #aside .gnb > li:hover > a::before { height: 12px; opacity: 1; }
        #aside .gnb .dep02 > li:hover a{color: var(--point-color01);}
        #aside .gnb .dep02:has(> li:hover) > li:not(:hover) { opacity: 0.4; }
    }

    @media (max-width: 1280px) {
        #aside .gnb { grid-template: auto / repeat(3, 1fr); }
    }

    @media (min-width: 1023px) {
        #aside .gnb > li:hover > a::before { height: 0; opacity: 0; }
        #aside .gnb .dep02 > li:hover a{color: var(--black-color06);}
        #aside .gnb .dep02:has(> li:hover) > li:not(:hover) { opacity: 0; }
    }

    @media (min-width:861px) {
        #aside .gnb > li{opacity:0;translate:0 100px;transition:all 0.8s 0.3s;}
        #aside.on .gnb > li{opacity:1;translate:0;}
        #aside.on .gnb > li:nth-child(2){transition-delay:0.4s;}
        #aside.on .gnb > li:nth-child(3){transition-delay:0.5s;}
        #aside.on .gnb > li:nth-child(4){transition-delay:0.6s;}
        #aside.on .gnb > li:nth-child(5){transition-delay:0.7s;}
        #aside.on .gnb > li:nth-child(6){transition-delay:0.8s;}
    }

    @media (max-width: 1023px) {
        #aside .w_custom { padding-block: clamp(70px, 10vw, 100px);  }
        #aside .close_btn { width: clamp(25px, 4vw, 40px); height: clamp(25px, 4vw, 40px); }
    }

    @media (max-width: 860px) {
        #aside { display: block; }
        #aside .gnb{grid-template: auto / repeat(1, 1fr);gap:0;}
        #aside .gnb > li { display: block; padding: 25px 0; width: 100%; text-align: left; box-sizing: border-box; border-bottom: 1px solid rgba(0, 0, 0, 0.2); }
        #aside .gnb > li > a { padding-block: 0; }
        #aside .gnb > li > a::before { display: none; }
        #aside .gnb .dep02 { display: grid; gap: 0 20px; grid-template: auto / repeat(2, 1fr); margin-top: 15px; justify-content: flex-start; }
        #aside .gnb .dep02 > li > a { padding-block: 12px; }
    }

    @media (max-width: 640px) {
        #aside .gnb > li > a{font-size: 170%;}
        #aside .gnb .dep02 > li > a{padding-block: 7px;font-size:100%;}
    }

    @media (max-width: 479px) {
        #aside .gnb > li > a { font-size: 150%; }
        #aside .gnb > li > a span { width: 100%; }
        #aside .gnb .dep02 { margin-top: 10px; grid-template: auto / repeat(1, 1fr); }
        #aside .gnb .dep02 > li > a { font-size: 95%; }
    }

/*───────────────────────────────────────────────────────────

    FOOTER | outline/footer.html

───────────────────────────────────────────────────────────*/
	#footer { padding-block: 100px 30px; }
    #footer .w_custom { display: flex; flex-direction: column; gap: 80px; }
    #footer .ft_top { display: flex; justify-content: space-between; align-items: flex-start; gap: 40px; flex-wrap: wrap; }
    #footer .ft_left { display: flex; flex-direction: column; gap: 49px; }
    #footer .policy_list { display: flex; gap: 40px;  }
    #footer .policy_list li { font-size: var(--title-17); font-weight: 400; color: var(--black-color06); letter-spacing: 0; }
    #footer .policy_list li:nth-child(1) { color: var(--black-color03); font-weight: 500; }

    #footer .ft_right { max-width: 650px; width: 100%; display: flex; flex-direction: column; gap: 30px; }
    #footer .ft_right .addr_list {  display: flex; flex-wrap: wrap; gap: 30px 100px; width: 100%; }
    #footer .ft_right dl { display: flex; flex-direction: column; gap: 9px; }
    #footer .ft_right dt { color: var(--black-color03); font-size: var(--title-17); font-weight: 400; line-height: 1.4; letter-spacing: 0; font-family: var(--font-type02); }
    #footer .ft_right dd { color: var(--black-color06); font-size: var(--title-16); font-weight: 400; letter-spacing: 0; line-height: 1.4; font-family: var(--font-type02); }

    #footer .ft_bot { display: flex; gap: 20px; flex-wrap: wrap; padding-top: 40px; border-top: 1px solid var(--border-color03); }
    #footer .ft_bot p { color: rgba(102, 102, 102, 0.6); font-size: var(--title-16); font-weight: 400; line-height: 1.62; letter-spacing: 0; font-family: var(--font-type02); }
    #footer .ft_bot p:last-child { font-family: var(--font-type04); }

    .quick_list { position: fixed; right: 40px; bottom: 60px; display: flex; flex-direction: column; gap: 10px; align-items: flex-end; transition: all 0.4s; z-index: 10; opacity: 0; pointer-events: none; }
    .quick_list .item {  position: relative; background: var(--point-color01); border-radius: 50px; box-shadow: var(--shadow-02); width: 50px; display: flex; transition: all 0.4s; justify-content: flex-end; overflow: hidden; }
    .quick_list .desc { position: relative;  }
    .quick_list .desc dt { display: flex; align-items: center; justify-content: center; width: 50px; height: 50px; padding: 10px; }
    .quick_list .desc dd { position: absolute; top: 0; right: 50px; width: max-content; height: 100%; display: flex; align-items: center; font-size: var(--title-17); font-weight: 600; color: var(--point-white); line-height: 1.4; letter-spacing: 0; opacity: 0; transition: all 0.4s; pointer-events: none; }
    .quick_list .scr { background: var(--point-color02); }

    body:has(#header.on:not(.end)) .quick_list{opacity: 1; pointer-events: all;}

    @media (hover:hover) and (pointer:fine) {
        .quick_list > div:has(.desc dd):hover{width: 130px;}
        .quick_list > div:hover .desc dd{opacity: 1;}
    }

    @media (hover:none) and (pointer: coarse) {
        .quick_list > div:has(.desc dd):hover{width: clamp(40px, 5vw, 50px); }
        .quick_list > div:hover .desc dd{opacity: 0;}
    }

    @media (max-width: 1023px) {
        #footer { padding-block: clamp(50px, 10vw, 100px) 30px; }
        #footer .w_custom { gap: clamp(20px, 6vw, 80px); }
        #footer .ft_left { gap: clamp(20px, 4vw, 50px); }
        #footer .ft_logo { max-width: clamp(200px, 30vw, 299px); }
        #footer .ft_top { gap: clamp(30px, 4vw, 40px); }
        #footer .policy_list { gap: clamp(20px, 4vw, 40px); }
        #footer .ft_right { gap: clamp(20px, 3vw, 30px); }
        #footer .ft_right .addr_list { gap: clamp(20px, 3vw, 30px) clamp(40px, 10vw, 100px); }

        #footer .ft_bot { padding-top: clamp(20px, 4vw, 40px); gap: clamp(10px, 2vw, 20px); }

        .quick_list { right: clamp(10px, 4vw, 40px); bottom: clamp(30px, 6vw, 60px); }
        .quick_list .item { width: clamp(40px, 5vw, 50px); }
        .quick_list .desc dt { width: clamp(40px, 5vw, 50px); height: clamp(40px, 5vw, 50px); }

        .quick_list > div:has(.desc dd):hover{width: clamp(40px, 5vw, 50px); }
        .quick_list > div:hover .desc dd{opacity: 0;}
    }

    @media (max-width: 479px) {
        #footer .ft_right .addr_list { flex-direction: column; }
        #footer .ft_right dl { flex-direction: row; }
    }

/*───────────────────────────────────────────────────────────

    MAIN | index.html

───────────────────────────────────────────────────────────*/
	.main_video { position: relative; height: 980px; }
    .main_video::before { content: ''; position: absolute; inset: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.2); z-index: 1; }
    .main_video video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
    .main_video img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
    .main_video .txt_box { height: 100%; font-size: var(--title-20); filter: var(--filter-white); display: flex; flex-direction: column; justify-content: center; gap: 20px; z-index: 2; padding-top: 5px; max-width: 1510px; }
    .main_video .txt_box h2 { font-size: 400%; font-weight: 700; line-height: 1.3; letter-spacing: 0.01em; font-family: var(--font-type02); }
    .main_video .txt_box span { font-size: 130%; font-weight: 600; line-height: 1.3; letter-spacing: -0.03em; }
    .main_video .txt_box p { font-size: 120%; font-weight: 400; line-height: 1.3; letter-spacing: -0.03em; margin-top: 20px; }


    @media (max-width: 1023px) {
        .main_video { height: clamp(540px, 98vw, 980px); }
        .main_video .txt_box { gap: clamp(10px, 2vw, 20px); }
        .main_video .txt_box h2 { font-size: clamp(40px, 8vw, 400%); }
        .main_video .txt_box span { font-size: clamp(105%, 2.6vw, 130%); }
        .main_video .txt_box p { font-size: clamp(100%, 2.4vw, 120%); margin-top: clamp(10px, 2vw, 20px); }
    }


    .main_title { position: relative; font-size: var(--title-20); display: flex; flex-direction: column; gap: 29px; font-family: var(--font-type02); }
    .main_title.hd { padding-block: 142px 50px; }
    .main_title span { color: var(--point-color01); font-weight: 500; font-size: 110%; line-height: 1.4; letter-spacing: 0; }
    .main_title h3 { color: var(--black-color00); font-weight: 600; font-size: 250%; line-height: 1.4; letter-spacing: -0.03em; font-family: var(--font-type01); }

    .line_tab { display: flex; flex-wrap: wrap; gap: 40px; font-size: var(--title-20); margin-bottom: 50px; }
    .line_tab > li { position: relative; font-size: 110%; font-weight: 600; color: var(--black-color10); line-height: 1.4; letter-spacing: 0; text-align: center; padding-bottom: 17px; padding-inline: 10px; cursor: pointer; transition: all 0.4s; }
    .line_tab > li::after { content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 3px; background: var(--border-color01); transition: inherit; }

    .line_tab > li button { font-size: inherit; font-weight: inherit; color: inherit; font-family: inherit; }

    .line_tab > li.on { color: var(--black-color00); }
    .line_tab > li.on::after { background: var(--point-color01); }

    .more_btn { display: inline-flex; justify-content: center; align-items: center; position: relative; padding-block: 16px; padding-inline: 47px; font-size: var(--title-20); border-radius: 60px; background: var(--point-white); transition: all 0.4s; }
    .more_btn > span { color: var(--black-color00); font-weight: 500; font-size: 100%; letter-spacing: 0; line-height: 1.4; transition: inherit; }
    .more_btn > em { position: absolute; top: 46%; right: 30px; translate: 0 -50%; filter: var(--filter-white); opacity: 0; transition: inherit; }

    .rel_box { position: relative; }
    .fadeBox { transition: all 0.6s; position: absolute; opacity: 0; inset: 0; visibility: visible; }
    .fadeBox.on { opacity: 1; visibility: visible; position: relative; z-index: 2; }

    .link { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 2; }
    

    @media (hover: hover) and (pointer: fine) {
        .more_btn:hover { background: var(--point-color01); }
        .more_btn:hover > span { filter: var(--filter-white); translate: -8px; }
        .more_btn:hover > em { opacity: 1; }
    }

    @media (hover: none) and (pointer: coarse) {
        .more_btn:hover { background: var(--point-white); }
        .more_btn:hover > span { filter: none; translate: 0; }
        .more_btn:hover > em { opacity: 0; }
    }

    @media (max-width: 1023px) {
        .main_title { gap: clamp(12px, 3vw, 29px); }
        .main_title.hd { padding-block: clamp(50px, 12vw, 142px) clamp(25px, 5vw, 50px); }
        .main_title h3 { font-size: 230%; }
        
        .line_tab { gap: clamp(10px, 3vw, 30px) clamp(20px, 4vw, 40px); margin-bottom: clamp(30px, 5vw, 50px); }
        .line_tab > li { padding-inline: clamp(5px, 1vw, 10px); padding-bottom: clamp(8px, 1.7vw, 17px); }

        .more_btn { padding-inline: clamp(20px, 5vw, 47px); padding-block: clamp(8px, 1.6vw, 16px); }

        .more_btn:hover { background: var(--point-white); }
        .more_btn:hover > span { filter: none; translate: 0; }
        .more_btn:hover > em { opacity: 0; }

    }

    @media (max-width: 640px) {
        .main_title h3 { font-size: 210%; }
        .more_btn > span { font-size: 90%; }
    }

    @media (max-width: 479px) {
        .main_title h3 { font-size: 190%; }
    }


    /* 메인 서비스 */

    .main_service .service_list { display: flex; gap: 20px; }
    .main_service .service_list > li { position: relative; width: 100%; min-height: 540px; padding: clamp(30px, 3.3vw, 60px); border-radius: var(--radius-20); overflow: clip; transition: all 0.6s; display: flex; flex-direction: column; justify-content: flex-end;  }
    .main_service .service_list > li .link { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 5; }
    
    .main_service .service_list .thumb { position: absolute; inset: 0; overflow: hidden; }
    .main_service .service_list .thumb::after { position: absolute; left: 50%; bottom: 40px; translate: -50%;  content: attr(title); font-size: clamp(20px, 2.2vw, 40px); font-weight: 600; filter: var(--filter-white); line-height: 1.4; letter-spacing: -0.03em; width: 100%; max-width: 177px; min-height: 112px; text-align: center; transition: all 0.4s; display: flex; align-items: center; justify-content: center; }
    .main_service .service_list .thumb img { width: 100%; height: 100%; object-fit: cover; transition: all 0.6s; }

    .main_service .service_list .desc { position: absolute; width: 100%; left: 0; bottom: 0; padding-block: clamp(30px, 3.3vw, 60px); padding-inline: clamp(30px, 3.3vw, 60px) 120px; z-index: 3; font-size: var(--title-20); opacity: 0; transition: all 0.6s; display: flex; flex-direction: column; gap: 20px; white-space: nowrap; }
    .main_service .service_list .desc dt { font-size: 230%; font-weight: 500; line-height: 1.4; letter-spacing: -0.03em; color: var(--point-white); }
    .main_service .service_list .desc dd { font-size: 105%; font-weight: 300; line-height: 1.45; letter-spacing: -0.02em; font-family: var(--font-type02); color: var(--point-white); }
    .main_service .service_list .arw_link { position: absolute; right: 60px; bottom: 60px; display: flex; justify-content: center; align-items: center; width: 54px; height: 54px; border-radius: 100%; background: var(--point-white); padding-bottom: 3px; transition: opacity 0.8s, background 0.4s; opacity: 0; pointer-events: none; z-index: 5; flex-shrink: 0; cursor: pointer; }
    

    .main_service .service_list > li.on { width: 246%; }
    .main_service .service_list > li.on .thumb::after { opacity: 0; }
    .main_service .service_list > li.on .thumb img { transform: scale(1.12); }
    .main_service .service_list > li.on .desc { opacity: 1; }
    .main_service .service_list > li.on .arw_link { pointer-events: all; opacity: 1; }

    .main_service .main_title.hd { padding-block: 120px 50px; }
    

    @media (hover: hover) and (pointer: fine) {
        .main_service .service_list .arw_link:hover { background: var(--point-color01); }
        .main_service .service_list .arw_link:hover > em { filter: var(--filter-white); }
    }

    @media (hover: none) and (pointer: coarse) {
    .main_service .service_list .arw_link:hover { background: var(--point-white); }
    .main_service .service_list .arw_link:hover > em { filter: none; }
    }

    @media (max-width: 1023px) {
    .main_service .service_list { flex-direction: column; gap: clamp(15px, 2vw, 20px); }
    .main_service .service_list > li { width: 100%; min-height: clamp(300px, 43vw, 430px); transition: unset; padding-block: clamp(30px, 6vw, 60px);  padding-inline: clamp(20px, 4vw, 40px); gap: clamp(15px, 3vw, 30px); flex-direction: row; }
    .main_service .service_list .thumb img { transition: unset; }
    .main_service .service_list .thumb::after { display: none; }
    .main_service .service_list .desc { opacity: 1; gap: clamp(10px, 2vw, 20px); position: relative; padding: 0; margin-top: auto; white-space: wrap; }
    .main_service .service_list .desc .arw_link { width: clamp(36px, 5.4vw, 54px); height: clamp(36px, 5.4vw, 54px); padding: 0; }
    .main_service .service_list .desc dt { font-size: 210%; }
    .main_service .service_list .desc dd { position: relative; }

    .main_service .main_title.hd { padding-block: clamp(70px, 12vw, 120px) clamp(25px, 5vw, 50px); }
    .main_service .service_list .arw_link { position: static; width: clamp(34px, 6vw, 54px); height: clamp(34px, 6vw, 54px); opacity: 1; pointer-events: all; margin-top: auto; }

    .main_service .service_list .arw_link:hover { background: var(--point-white); }
    .main_service .service_list .arw_link:hover > em { filter: none; }

    .main_service .service_list > li.on { width: 100%; }
    }

    @media (max-width: 860px) {
    .main_service .service_list .arw_link { padding-left: 2px; padding-bottom: 2px; }
    }

    @media (max-width: 640px) {
    .main_service .service_list .arw_link > em { display: block; width: 7px; }
    .main_service .service_list .desc dt { font-size: 190%; }
    }

    @media (max-width: 420px) {
    .main_service .service_list > li { flex-direction: column; }
    .main_service .service_list .arw_link { margin: 0; display: none; }
    }


    /* 메인 솔루션 */

    
    .main_solution { padding-bottom: 140px; }
    .main_solution .sol_cont > div { border-radius: var(--radius-20); overflow: clip; }
    .main_solution .sol_cont .thumb { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
    .main_solution .sol_cont .thumb img { width: 100%; height: 100%; object-fit: cover; }
    .main_solution .sol_cont .txt_box {  padding-inline: clamp(40px, 6vw, 100px); padding-block: 124px; display: flex; gap: 50px; flex-direction: column; justify-content: center; align-items: flex-start; }
    .main_solution .sol_cont .txt_box dl { font-size: var(--title-20); display: flex; flex-direction: column; gap: 30px; }
    .main_solution .sol_cont .txt_box dt { filter: var(--filter-white); font-size: 200%; font-weight: 700; line-height: 1.4; letter-spacing: 0; }
    .main_solution .sol_cont .txt_box dt:has(img) { width: 100%; max-width: 320px; }
    .main_solution .sol_cont .txt_box dd { filter: var(--filter-white); font-size: 100%; font-weight: 500; line-height: 1.6; letter-spacing: 0; }

    .main_solution .sol_cont > div:nth-child(1) .txt_box { padding-top: 120px; }
    

    @media (max-width: 1023px) {
    .main_solution { padding-bottom: clamp(50px, 12vw, 140px); }
    .main_solution .sol_cont .txt_box { gap: clamp(30px, 5vw, 50px); padding-inline: clamp(20px, 4vw, 40px); padding-block: clamp(40px, 13vw, 124px); }
    .main_solution .sol_cont > div:nth-child(1) .txt_box { padding-top: clamp(40px, 13vw, 120px); }
    .main_solution .sol_cont .txt_box dl { gap: clamp(20px, 3vw, 30px); }
    .main_solution .sol_cont .txt_box dt:has(img) { max-width: clamp(240px, 32vw, 320px); }

    
    }

    @media (max-width: 640px) {
    .main_solution .sol_cont .txt_box dd { text-wrap: balance; }
    .main_solution .sol_cont .txt_box dd br { display: none; }
    }

    
    /* 메인 고객사 */

    .main_clie { background: var(--point-grad01); padding-bottom: 200px; }
    .main_clie .line_tab { gap: 30px; }
    .main_clie .clie_list { display: grid; grid-template: auto / repeat(5, 1fr); gap: 25px;  }
    .main_clie .clie_list > li { box-shadow: inset 0 0 0 1px var(--border-color01); border-radius: var(--radius-10); background: var(--point-white); }

    @media (max-width: 1120px) {
    .main_clie .clie_list { grid-template: auto / repeat(4, 1fr); }
    }

    @media (max-width: 1023px) {
    .main_clie { padding-bottom: clamp(70px, 16vw, 200px); }
    .main_clie .line_tab { gap: clamp(15px, 3vw, 30px) clamp(20px, 3vw, 30px); }
    .main_clie .clie_list { gap: clamp(15px, 2.5vw, 25px); }
    }

    @media (max-width: 860px) {
    .main_clie .clie_list { grid-template: auto / repeat(3, 1fr); }
    }

    @media (max-width: 479px) {
    .main_clie .clie_list { grid-template: auto / repeat(2, 1fr); gap: 10px; }
    }

    @media (max-width: 320px) {
    .main_clie .clie_list { grid-template: auto / repeat(1, 1fr); }
    }

    /* 메인 퍼포먼스 */
    .main_perfor { padding-bottom: 160px; }
    .main_perfor .main_title.hd { padding-block: 0 40px; }
    
    .main_perfor .perforSwiper { clip-path: inset(-300% -300% -300% -20px); }
    .main_perfor .perforSwiper .swiper-slide { position: relative; height: auto; display: flex; flex-direction: column; border-radius: var(--radius-20); overflow: clip; background: var(--point-white); transition: all 0.4s; box-shadow: inset 0 0 0 1px var(--border-color01); z-index: 2; }
    .main_perfor .perforSwiper .swiper-slide .link { border: 1px solid var(--trans-color); border-radius: inherit; transition: all 0.4s; }
    .main_perfor .perforSwiper .thumb { width: 100%; aspect-ratio: auto 1.6; overflow: hidden; flex-shrink: 0; }
    .main_perfor .perforSwiper .thumb img { transition: all 0.4s; }
    .main_perfor .perforSwiper .txt_box { font-size: var(--title-20); display: flex; flex-direction: column; justify-content: space-between; height: 100%; gap: 36px; padding: 30px; }
    .main_perfor .perforSwiper .txt_box dl { display: flex; flex-direction: column; gap: 14px; }
    .main_perfor .perforSwiper .txt_box dt { font-size: 110%; color: var(--black-color03); font-weight: 500; line-height: 1.4; letter-spacing: -0.02em; }
    .main_perfor .perforSwiper .txt_box dd { font-size: 90%; color: var(--black-color06); font-weight: 400; line-height: 1.4; letter-spacing: -0.02em; }
    .main_perfor .perforSwiper .txt_box > span { font-size: 90%; color: var(--black-color09); font-weight: 400; line-height: 1.3; letter-spacing: -0.02em; }
    .main_perfor .rel_box .swiper-pagination{position: relative; inset: auto; width: 100%; max-width: 1500px; height: 3px; margin-top: 40px; background: var(--border-color03); border-radius: var(--radius-10); }
    .main_perfor .rel_box .swiper-pagination span{background: var(--black-color05); border-radius: inherit; }
    

    @media (hover: hover) and (pointer: fine) { 
    .main_perfor .perforSwiper .swiper-slide:hover .link { border-color: var(--point-color01); }
    .main_perfor .perforSwiper .swiper-slide:hover .thumb img { transform: scale(1.08); }
    .main_perfor .perforSwiper .swiper-slide:hover { box-shadow: 0 0 0 1px var(--border-color01), var(--shadow-01); }
    }

    @media (hover: none) and (pointer: fine) { 
    .main_perfor .perforSwiper .swiper-slide:hover .link { border-color: var(--trans-color); }
    .main_perfor .perforSwiper .swiper-slide:hover { box-shadow: 0 0 0 1px var(--border-color01); }
    .main_perfor .perforSwiper .swiper-slide:hover .thumb img { transform: scale(1); }
    }

    @media (max-width: 1600px) { 
    .main_perfor .perforSwiper { margin-left: -60px; padding-left: 60px; }
    }

    @media (max-width: 1023px) {
    .main_perfor { padding-bottom: clamp(70px, 14vw, 160px); }
    .main_perfor .main_title.hd { padding-block: clamp(25px, 4vw, 40px); }
    .main_perfor .perforSwiper .txt_box { gap: clamp(20px, 4vw, 36px); padding: clamp(20px, 3vw, 30px);  }
    .main_perfor .perforSwiper .swiper-slide:hover .thumb img { transform: scale(1); }
    .main_perfor .rel_box .swiper-pagination { margin-top: clamp(30px, 4vw, 40px); }

    .main_perfor .perforSwiper .swiper-slide:hover .link { border-color: var(--trans-color); }
    .main_perfor .perforSwiper .swiper-slide:hover { box-shadow: 0 0 0 1px var(--border-color01); }
    .main_perfor .perforSwiper .swiper-slide:hover .thumb img { transform: scale(1); }
    }


    /* 메인 컨택트 */
    .main_cont .w_custom { max-width: 1840px; border-radius: var(--radius-40); overflow: clip; }
    .main_cont .thumb { position: absolute; inset: 0; width: 100%; height: 100%; }
    .main_cont .thumb img { width: 100%; height: 100%; object-fit: cover; }
    .main_cont .txt_box { width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; gap: 60px; padding-inline: 30px; padding-block: 126px; }
    .main_cont .txt_box dl { display: flex; flex-direction: column; gap: 21px; font-size: var(--title-20); }
    .main_cont .txt_box dt { font-size: 300%; font-weight: 700; line-height: 1.3; text-transform: uppercase; filter: var(--filter-white); font-family: var(--font-type02); letter-spacing: 0.025em; }
    .main_cont .txt_box dd { font-size: 110%; font-weight: 400; line-height: 1.3; filter: var(--filter-white); }
    .main_cont .more_btn { padding-inline: 55px; }

    @media (max-width: 1023px) {
    .main_cont .txt_box { gap: clamp(30px, 6vw, 60px); padding-block: clamp(30px, 7vw, 126px); }
    .main_cont .txt_box dl { gap: clamp(15px, 2vw, 21px); }
    .main_cont .txt_box dt { font-size: 270%; }
    .main_cont .more_btn { padding-inline: clamp(30px, 5.5vw, 55px); }
    }
    
    @media (max-width: 640px) { 
    .main_cont .txt_box dt { font-size: 240%; }
    }