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

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

───────────────────────────────────────────────────────────*/
@media (max-width: 1350px) {
    br.for_pc { 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: 1600px; 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%;}

    @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

───────────────────────────────────────────────────────────*/
        #header {position: fixed; top: 0;  left: 0; background: none; width: 100%; height: 100px; z-index: 100; transition: all 0.4s; box-shadow:inset 0 -1px 0 rgb(255 255 255 / 20%);}
        #header .w_custom { height: 100%; display: flex; align-items: center; justify-content: space-between; gap: 30px; }
        #header .logo { height: 100%; display: flex; align-items: center; }
        #header .logo a { position: relative; display: flex; align-items: center; padding-block: 10px; width: 167px; aspect-ratio: auto 5.2; }
        #header .logo a::before {content: '';position: absolute;width: 100%;height: 100%;background: url('../images/skin/logo.png') no-repeat center / contain;transition: all 0.4s;}
        #header .cont { display: flex; align-items: center; gap: clamp(20px, 4.5vw, 61px); height: 100%; padding-top: 4px; }
        #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: 95%; font-weight: 500; color: var(--black-color01); height: 100%; transition: all 0.4s; }
        #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: 28px; aspect-ratio: 1.55; }
        #header .allCate span { width: 100%; height: 2px; background: var(--black-color01); transition: all 0.4s; }

        #header :where(.gnb > li > a, .allCate){filter: var(--filter-white); transition: all 0.4s;}
        #header .logo a::before { background-image: url('../images/skin/logo_on.png'); }


        @media (hover: hover) and (pointer: fine) {
            #header:hover {background: var(--point-white); box-shadow:inset 0 -1px 0 var(--border-color01);}
            #header:hover :where(.gnb > li > a, .allCate){filter: none;}
            #header:hover .logo a::before { background-image: url('../images/skin/logo.png'); }
            #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:inset 0 -1px 0 var(--border-color01);}
        #header.on :where(.gnb > li > a, .allCate){filter: none;}
        #header.on .logo a::before { background-image: url('../images/skin/logo.png'); }

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

        @media (max-width: 1023px) {
            #header{height: clamp(60px, 10vw, 100px);  }
            
            #header .logo a { width: clamp(110px, 17vw, 167px); }
            #header .allCate { width: clamp(26px, 3vw, 28px); }
        }
		

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

    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(5, 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 (max-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: 1; }
    }

    @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: 69px 71px; border-radius: var(--radius-30) var(--radius-30) 0 0; border-top: 1px solid var(--border-color01); }
    #footer .ft_logo { max-width: 167px; }
    #footer .ft_top { display: flex; justify-content: space-between; gap: 30px; align-items: center; flex-wrap: wrap; }
    #footer .policy_list { display: flex; align-items: center; }
    #footer .policy_list li { position: relative; font-size: var(--title-20); font-family: var(--font-type02); }
    #footer .policy_list li a { font-size: 90%; color: var(--black-color03); font-weight: 400; letter-spacing: -0.03em; }
    #footer .policy_list li:nth-child(2) a { color: var(--black-color01); font-weight: 500; }
    #footer .policy_list li + li { margin-left: 33px; padding-left: 32px; }
    #footer .policy_list li + li::before { content: ''; position: absolute; left: 0; top: 50%; translate: -50% -50%; width: 4px; aspect-ratio: auto 1; background: var(--border-color01); }

    #footer .ft_acc { font-size: var(--title-20); margin-top: 25px; }
    #footer .ft_acc h4 { font-size: 170%; font-weight: 600; font-family: var(--font-type02); line-height: 1.4; letter-spacing: -0.03em; color: var(--black-color01); }

    #footer .ft_addr { margin-top: 40px; display: flex; flex-direction: column; gap: 8px; }
    #footer .ft_addr li { display: flex; gap: 10px 41px; flex-wrap: wrap; }
    #footer .ft_addr li dl { display: flex; font-size: var(--title-20); gap: 21px; }
    #footer .ft_addr li dt { font-size: 90%; color: var(--black-color03); font-weight: 500; line-height: 1.6; letter-spacing: -0.03em; flex-shrink: 0; }
    #footer .ft_addr li dd { color: var(--black-color05); font-size: 90%; font-weight: 400; line-height: 1.6; letter-spacing: -0.03em; }
    #footer .ft_addr li dd:has(span) { display: flex; flex-wrap: wrap; }
    #footer .ft_addr li dd:has(span) span { position: relative; display: block; }
    #footer .ft_addr li dd:has(span) span + span { margin-left: 21px; padding-left: 21px; }
    #footer .ft_addr li dd:has(span) span + span::before { content: ''; position: absolute; left: 0; top: 50%; translate: 0 -50%; width: 1px; height: 12px; background: var(--border-color01); }

    #footer .ft_bot { margin-top: 62px; display: flex; gap: 15px; flex-wrap: wrap; }
    #footer .ft_bot p { font-size: var(--title-16); font-weight: 400; color: var(--black-color08); letter-spacing: -0.03em; }
    #footer .ft_bot p em { color: var(--black-color06); font-weight: 500; }

    .quick_list { position: fixed; right: 45px; bottom: 39px; 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: var(--radius-10); box-shadow: var(--shadow-03); width: 70px; aspect-ratio: auto 1; transition: all 0.4s;  }
    .quick_list .desc { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; width: 100%; height: 100%;}
    .quick_list .desc dt { display: flex; justify-content: center; align-items: center; }
    .quick_list .desc dd {  font-size: var(--title-14); font-weight: 500; filter: var(--filter-white); line-height: 1; letter-spacing: -0.03em; }
    .quick_list .scr { background: var(--point-color02); }

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

    @media (max-width: 1023px) {
        #footer { padding-block: clamp(35px, 7vw, 69px) clamp(35px, 7vw, 71px); }
        #footer .policy_list li + li { margin-left: clamp(15px, 3vw, 32px); padding-left: clamp(15px, 3vw, 32px); }
        #footer .ft_top { gap: clamp(15px, 3vw, 30px); }
        #footer .ft_logo { max-width: clamp(110px, 17vw, 167px); }
        #footer .ft_acc { margin-top: clamp(20px, 2.5vw, 25px); }
        #footer .ft_addr { margin-top: clamp(20px, 4vw, 40px); }
        #footer .ft_addr li { gap: 10px clamp(20px, 4vw, 41px); }
        #footer .ft_addr li dl { gap: clamp(12px, 2vw, 21px); }
        #footer .ft_addr li dd:has(span) span + span { margin-left: clamp(10px, 2vw, 21px); padding-left: clamp(10px, 2vw, 21px); }
        #footer .ft_addr li dd:has(span) span + span::before { height: clamp(8px, 1.2vw, 12px); }
        #footer .ft_bot { margin-top: clamp(30px, 6vw, 62px); gap: clamp(7px, 1.5vw, 15px); }

        .quick_list { right: clamp(10px, 4.5vw, 45px); bottom: clamp(20px, 4vw, 40px); }
        .quick_list .item { width: clamp(45px, 7vw, 70px); }
        .quick_list .desc { gap: clamp(5px, 1vw, 10px); }
    }

    @media (max-width: 860px) {
        #footer .ft_acc h4 { font-size: 150%; }

        .quick_list { right: 15px; }
        .quick_list .item { width: clamp(45px, 5vw, 50px); }
        .quick_list .desc dd { display: none; }
    }

    @media (max-width: 640px) {
        #footer .ft_acc h4 { font-size: 140%; }
        #footer .ft_addr li { flex-direction: column; }
    }

    @media (max-width: 370px) {
        #footer .ft_addr li dl { flex-direction: column; gap: 3px; }
    }

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

    MAIN | index.html

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

    .link { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 5; }
    .main_index .rel_box { background: var(--point-grad03); }
	.main_video { position: relative; height: 980px; }
    .main_video::before { content: ''; position: absolute; inset: 0; width: 100%; height: 100%; background: var(--point-grad01); 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 { position: relative; z-index: 2; height: 100%; font-size: var(--title-20); filter: var(--filter-white); display: flex; flex-direction: column; justify-content: flex-end; gap: 30px; padding-bottom: 140px; }
    .main_video .txt_box h2 { font-size: 400%; font-weight: 600; line-height: 1.3; letter-spacing: -0.03em; }
    .main_video .txt_box p { font-size: 110%; font-weight: 500; line-height: 1.6; letter-spacing: -0.03em; font-family: var(--font-type02); }

    @media (max-width: 1023px) {
        .main_video { height: clamp(540px, 98vw, 980px); }
        .main_video .txt_box { gap: clamp(15px, 3vw, 30px); padding-bottom: clamp(70px, 14vw, 140px); }
        .main_video .txt_box h2 { font-size: 360%; }
    }

    @media (max-width: 860px) {
        .main_video .txt_box h2 { font-size: 320%; }
        .main_video .txt_box p { font-size: 105%; }
    }

    @media (max-width: 640px) {
        .main_video .txt_box h2 { font-size: 280%; }
        .main_video .txt_box p { font-size: 100%; }
    }

    @media (max-width: 479px) {
        .main_video .txt_box h2 { font-size: 240%; }
    }

    .main_title { font-size: var(--title-20); display: flex; flex-direction: column; gap: 24px; }
    .main_title.hd { padding-block: 160px 60px; }
    .main_title h3 { font-size: 300%; font-weight: 600; line-height: 1.4; letter-spacing: -0.03em; color: var(--black-color01); }
    .main_title p { font-size: 110%; font-weight: 400; font-family: var(--font-type02); line-height: 1.4; letter-spacing: -0.03em; color: var(--black-color03); }

    @media (max-width: 1023px) {
        .main_title { gap: clamp(12px, 2.4vw, 24px); }
        .main_title.hd { padding-block: clamp(80px, 16vw, 160px) clamp(30px, 6vw, 60px); }
        .main_title h3 { font-size: 280%; }
    }

    @media (max-width: 860px) {
        .main_title h3 { font-size: 260%; }
        .main_title p { font-size: 105%; }
    }

    @media (max-width: 640px) {
        .main_title h3 { font-size: 240%; }
        .main_title p { font-size: 100%; }
    }

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


    /* 메인 에어리어 */
    .main_area .main_title.hd { padding-block: 140px 60px; }
    .main_area .area_list { display: grid; grid-template: auto / repeat(3, 1fr); gap: clamp(20px, 3vw, 50px); }
    .main_area .area_list li { position: relative; border-radius: var(--radius-20); overflow: clip; min-height: 440px; transition: all 0.4s; }
    .main_area .area_list li::before { content: ''; position: absolute; width: 100%; height: 50%; left: 0; bottom: 0; background: var(--point-grad02); z-index: 1; }
    .main_area .area_list .thumb { position: absolute; inset: 0; width: 100%; height: 100%; }
    .main_area .area_list .thumb img { width: 100%; height: 100%; object-fit: cover; }
    .main_area .area_list dl { position: relative; width: 100%; height: 100%; font-size: var(--title-20); display: flex; flex-direction: column; justify-content: flex-end; align-items: center; gap: 11px; z-index: 2; text-align: center; padding-inline: 40px; padding-block: 80px 40px; filter: var(--filter-white); }
    .main_area .area_list dt { font-size: 160%; font-weight: 700; line-height: 1.4; letter-spacing: -0.03em; }
    .main_area .area_list dd { font-size: 100%; font-weight: 400; line-height: 1.4; letter-spacing: -0.03em; }
    .main_area .area_list .arw { position: absolute; right: 30px; top: 30px; display: flex; justify-content: center; align-items: center; width: 50px; aspect-ratio: auto 1; border-radius: var(--radius-05); border: 1px solid rgba(255, 255, 255, 0.20); background: rgba(255, 255, 255, 0.10); backdrop-filter: blur(6px); transition: all 0.4s;}
    .main_area .area_list .arw em { filter: var(--filter-white); transition: all 0.4s; translate: 0 -1px; display: block; width: 16px; height: 12px; }
    .main_area .area_list .arw em img { display: block; }

    @media (hover: hover) and (pointer: fine) {
        .main_area .area_list li:hover { box-shadow: var(--shadow-01); }
        .main_area .area_list li:hover .arw { background: var(--point-white); }
        .main_area .area_list li:hover .arw em { filter: none; }
    }

    @media (max-width: 1023px) {
        .main_area .main_title.hd { padding-block: clamp(70px, 14vw, 140px) clamp(30px, 6vw, 60px); }
        .main_area .area_list { grid-template: auto / repeat(2, 1fr); gap: clamp(15px, 3vw, 30px); }
        .main_area .area_list li { min-height: clamp(280px, 48vw, 440px); }
        .main_area .area_list dl { gap: clamp(7px, 1.1vw, 11px); padding-block: clamp(60px, 8vw, 80px) clamp(20px, 4vw, 40px); padding-inline: clamp(20px, 4vw, 40px); }
        .main_area .area_list .arw { width: clamp(36px, 5vw, 50px);  }
        .main_area .area_list li:hover { box-shadow: none; }
        .main_area .area_list li:hover .arw { background: var(--point-white); }
        .main_area .area_list li:hover .arw em { filter: none; }

        .main_area .area_list li .arw { background: var(--point-white); right: clamp(15px, 3vw, 30px); top: clamp(15px, 3vw, 30px); }
        .main_area .area_list li .arw em { filter: none; translate: 0; }
    }

    @media (max-width: 640px) {
        .main_area .area_list dt { font-size: 140%; }
        .main_area .area_list .arw em { width: 14px; height: 11px; }
    }

    @media (max-width: 479px) {
        .main_area .area_list { grid-template: auto / repeat(1, 1fr); }
    }



    /* 메인 후 위 아 */

    .main_who .who_list { counter-reset: who 0; }
    .main_who .who_list > li { position: relative; cursor: pointer; }
    .main_who .who_list > li.on { padding-bottom: 80px; }
    .main_who .who_list .who_title { font-size: var(--title-20); position: relative; padding-top: 40px; padding-bottom: 40px;  }
    .main_who .who_list .who_title::before {  border: 1px solid var(--point-color01); border-radius: var(--radius-20); content: ''; position: absolute; inset: 0; width: 100%; height: 100%; clip-path: inset(0 0 75%);  }
    .main_who .who_list .who_title .num::before { position: absolute; left: 44px; top: 40px; content: '( 'counter(who, decimal-leading-zero)' )'; counter-increment: who 1; color: var(--point-color01); text-align: center; font-size: var(--title-18); font-weight: 600; line-height: 1.4; letter-spacing: -0.03em; }
    .main_who .who_list .who_title h4 { color: var(--point-color01); font-weight: 500; font-size: 250%; line-height: 1.6; letter-spacing: -0.03em; width: 65.7%; margin-left: auto; padding-right: 70px; }
    .main_who .who_list .who_title .ico { position: absolute; width: 24px; aspect-ratio: auto 1; right: 40px; top: 40px; }
    .main_who .who_list .who_title .ico::before { position: absolute; content: ''; width: 100%; height: 2px; background: var(--point-color01); top: 50%; left: 0; translate: 0 -50%; }
    .main_who .who_list .who_title .ico::after { position: absolute; content: ''; width: 2px; height: 100%; left: 50%; top: 0; background: var(--point-color01); translate: -50%; opacity: 1; transition: all 0.4s; }
    .main_who .who_list .who_cont { display: none; font-size: var(--title-20); width: 65.7%; margin-left: auto; }
    .main_who .who_list .who_cont p { font-size: 100%; color: var(--black-color03); font-weight: 400; line-height: 1.6; letter-spacing: -0.03em; }
    .main_who .who_list .who_cont .img_box { margin-top: 40px; border-radius: var(--radius-20); overflow: clip; }
    

    .main_who .who_list > li.on .ico::after { top: 50%; opacity: 0; }

    @media (max-width: 1023px) {
        .main_who .who_list .who_title { padding-top: clamp(20px, 4vw, 40px); padding-bottom: clamp(20px, 4vw, 40px); padding-inline: clamp(20px, 4vw, 40px); }
        .main_who .who_list .who_title h4 { width: 100%; margin-inline: auto; font-size: 230%; margin-top: clamp(10px, 1.2vw, 12px); padding-right: 0; }
        .main_who .who_list .who_title .num::before { position: static; }
        .main_who .who_list .who_title .ico { right: clamp(20px, 4vw, 40px); top: clamp(20px, 4vw, 40px); width: clamp(18px, 2.4vw, 24px); }
        .main_who .who_list .who_cont { width: 100%; margin-inline: auto; padding-inline: clamp(20px, 4vw, 40px); }
        .main_who .who_list .who_cont .img_box { margin-top: clamp(20px, 4vw, 40px); min-height: 250px; display: flex; }
        .main_who .who_list .who_cont .img_box img { width: 100%;  object-fit: cover; }
        .main_who .who_list > li.on { padding-bottom: clamp(40px, 8vw, 80px); }
        .main_who .who_list > li:last-child { padding-bottom: 0; }
    }

    @media (max-width: 860px) {
        .main_who .who_list .who_title h4 { font-size: 210%; }
    }

    @media (max-width: 640px) {
        .main_who .who_list .who_title h4 { font-size: 180%; }
    }


    /* 메인 필로소피 */
    .main_philo { padding-bottom: 160px; }
    .main_philo .philo_list { display: grid; grid-template: auto / repeat(3, 1fr); gap: clamp(30px, 3.3vw, 50px); }
    .main_philo .philo_list li { display: flex; flex-direction: column; align-items: center; gap: 41px; background: var(--point-white); padding-block: 60px; padding-inline: 40px; text-align: center; border-radius: var(--radius-20); overflow: clip; box-shadow: var(--shadow-02); }
    .main_philo .philo_list li .img_box { max-width: 160px; }
    .main_philo .philo_list li:nth-child(3) .img_box { max-width: 173px; }
    .main_philo .philo_list dl { font-size: var(--title-20); width: 100%; }
    .main_philo .philo_list dt { display: flex; flex-direction: column; align-items: center; gap: 7px; font-size: 150%; font-weight: 600; line-height: 1.4; letter-spacing: -0.03em; color: var(--black-color01); }
    .main_philo .philo_list dt small { font-size: 66.67%; font-weight: 500; letter-spacing: -0.03em; color: var(--point-color01); }
    .main_philo .philo_list dd { margin-top: 40px; padding-top: 40px; border-top: 1px solid var(--border-color01); color: var(--black-color05); font-weight: 400; font-size: 100%; line-height: 1.6; letter-spacing: -0.03em; text-wrap: balance; }

    @media (max-width: 1023px) {
        .main_philo { padding-bottom: clamp(80px, 16vw, 160px); }
        .main_philo .philo_list { grid-template: auto / repeat(1, 1fr); gap: clamp(15px, 3vw, 30px); }
        .main_philo .philo_list li { gap: clamp(25px, 5vw, 41px); padding-block: clamp(30px, 6vw, 60px); padding-inline: clamp(25px, 5vw, 40px); flex-direction: row; justify-content: flex-start; text-align: left; }
        .main_philo .philo_list li .img_box { max-width: clamp(120px, 16vw, 160px); }
        .main_philo .philo_list li:nth-child(3) .img_box { max-width: clamp(133px, 17.3vw, 173px); }
        .main_philo .philo_list dt { gap: clamp(3px, 0.7vw, 7px); flex-direction: row; text-align: left; justify-content: flex-start; }
        .main_philo .philo_list dd { margin-top: clamp(20px, 3vw, 40px); padding-top: clamp(20px, 3vw, 40px); }
    }

    @media (max-width: 640px) {
        .main_philo .philo_list li { flex-direction: column; justify-content: center; text-align: center; }
        .main_philo .philo_list dt { flex-direction: column; justify-content: center; text-align: center; }
    }


    /* 메인 파트너스 */
    .main_part .part_list { display: grid; grid-template: auto / repeat(4, 1fr); gap: clamp(20px, 2.2vw, 24px); }
    .main_part .part_list li { padding-inline: 20px; padding-block: 20px 28px; box-shadow: inset 0 0 0 1px var(--border-color01); border-radius: var(--radius-20); overflow: clip; position: relative; height: auto; display: flex; flex-direction: column; gap: 24px; transition: all 0.4s; z-index: 2; }
    .main_part .part_list dl { font-size: var(--title-20); display: grid; gap: 9px; padding-inline: 10px; font-family: var(--font-type02); }
    .main_part .part_list dt { color: var(--black-color01); color: var(--black-color01); font-weight: 600; font-size: 125%; line-height: 1.4; letter-spacing: -0.03em; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; width: 100%; transition: all 0.4s; }
    .main_part .part_list dd { color: var(--black-color03); font-size: 95%; font-weight: 400; line-height: 1.6; letter-spacing: -0.03em; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; }
    .main_part .part_list .thumb { border-radius: var(--radius-10); overflow: clip; position: relative; }
    .main_part .part_list .preface { position: absolute; left: 0; top: 0; padding-inline: 14px 15px; padding-block: 9px 6px; display: flex; justify-content: center; align-items: center; border-radius: var(--radius-10) 0; }
    .main_part .part_list .preface span { font-size: var(--title-16); font-weight: 500; letter-spacing: -0.03em; font-family: var(--font-type02); filter: var(--filter-white); }
    .main_part .part_list .preface[title="단독 대리점"] { background: var(--point-grad04); }
    .main_part .part_list .preface[title="파트너사"] { background: var(--point-grad05); }

    @media (hover: hover) and (pointer: fine) {
        .main_part .part_list li:hover { box-shadow: inset 0 0 0 2px var(--point-color01); }
        .main_part .part_list li:hover dt { color: var(--point-color01); }
    }

    @media (max-width: 1200px) {
        .main_part .part_list { grid-template: auto / repeat(2, 1fr); }
    }

    @media (max-width: 1023px) {
        .main_part .part_list { gap: clamp(15px, 2.4vw, 24px); }
        .main_part .part_list li { padding-inline: clamp(15px, 2vw, 20px); padding-block: clamp(15px, 2vw, 20px) clamp(18px, 2.8vw, 28px); gap: clamp(15px, 2.5vw, 24px); }
        .main_part .part_list .preface { padding-block: clamp(5px, 0.9vw, 9px) clamp(5px, 0.6vw, 6px); padding-inline: clamp(10px, 1.5vw, 14px) clamp(10px, 1.5vw, 15px); }
        .main_part .part_list dl { padding-inline: clamp(5px, 0.1vw, 10px); gap: clamp(4px, 0.9vw, 9px); }
        .main_part .part_list li:hover dt { color: var(--black-color01); }

        .main_part .part_list li:hover { box-shadow: inset 0 0 0 1px var(--border-color01); }
    }

    @media (max-width: 860px) {
        .main_part .part_list { grid-template: auto / repeat(2, 1fr); }
    }

    @media (max-width: 640px) {
        .main_part .part_list dt { font-size: 115%; }
    }

    @media (max-width: 479px) {
        .main_part .part_list { grid-template: auto / repeat(1, 1fr); }
    }

    .main_clie { padding-bottom: 160px; }
    .main_clie .clieSwiper { position: relative; }
    .main_clie .clieSwiper::before { content: ''; position: absolute; left: 0; top: 0; width: 210px; height: 100%; background: linear-gradient(270deg, rgba(255, 255, 255, 0.00) 0%, #FFF 100%); z-index: 2; }
    .main_clie .clieSwiper::after { content: ''; position: absolute; right: 0; top: 0; width: 210px; height: 100%; background: linear-gradient(270deg, rgba(255, 255, 255, 0.00) 0%, #FFF 100%); z-index: 2; transform: rotate(180deg); }
    .main_clie .clieSwiper .swiper-wrapper { transition-timing-function: linear; }
    .main_clie .clieSwiper .swiper-slide { border-radius: var(--radius-08); background: var(--gray-bg01);display: flex; align-items: center; justify-content: center; height: auto; overflow: hidden; width: 304px; aspect-ratio: auto 3.8; }
    .main_clie .clieSwiper .swiper-slide img { mix-blend-mode: multiply; }

    @media (max-width: 1023px) {
        .main_clie { padding-bottom: clamp(100px, 16vw, 160px); }
        .main_clie .clieSwiper .swiper-slide { width: clamp(184px, 31vw, 307px); }
        .main_clie .clieSwiper::before,
        .main_clie .clieSwiper::after { width: clamp(105px, 21vw, 210px); }
    }