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

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

───────────────────────────────────────────────────────────*/
/*───────────────────────────────────────────────────────────
	layout common
───────────────────────────────────────────────────────────*/
	#wrap {position:relative;width:100%; box-sizing: border-box; overflow: clip;}
    .w_custom{position: relative; width: calc(100% - 60px); max-width: 1240px; margin-inline: auto; box-sizing: border-box;}
    #container{position: relative; padding-bottom:150px; box-sizing: border-box;}

    .no_data{padding-block: 50px; font-size: var(--title-18); font-weight: 400; color: var(--black-color06); text-align: center;}

    @media (max-width:1240px){
        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

───────────────────────────────────────────────────────────*/
    #header{position: fixed; top:0; left:0; width: 100%; height: 100px; z-index: 100; 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%;}
    #header .logo a{display: flex;align-items: center;max-width: 214px;height: 100%;padding-block: 15px;}
    #header .gnb{position: absolute;width: calc(100% - 430px);height: 100%;top:0;left:50%;translate: -50%;display: flex;justify-content: center;text-align: center;font-size: var(--title-20);color: var(--black-color01);}
    #header .gnb > li{position: relative; height: 100%; font-size: 95%; font-weight: 600;}
    #header .gnb > li > a{display: flex;align-items: center;justify-content: center;height: 100%;padding-inline: clamp(15px, 3.125vw, 60px); transition: all 0.4s;}
    #header .gnb .dep02{position: absolute;top:85%;left: 50%;width: 180px;translate: -50%;background: var(--point-color01);padding-block: 20px;opacity: 0;pointer-events: none;transition: all 0.4s;}
    #header .gnb .dep02 > li{font-size: 85%;font-weight: 500; transition: inherit;}
    #header .gnb .dep02 > li > a{display: block;padding: 8px 20px;filter: var(--filter-white);}
    #header .utility{display: flex; align-items: center; gap: 25px;}
    #header .allCate{display: flex; flex-direction: column; justify-content: space-between; width: 40px; aspect-ratio: auto 1.6;}
    #header .allCate span{width: 100%; height: 3px; background: var(--black-color01);}
        #header .allCate span:nth-child(1){width: 50%;margin-left: auto;}
        #header .allCate span:nth-child(3){width: 50%;}


        /* color */
            #header :where(.gnb > li > a, .utility, .allCate){filter: var(--filter-white);}
            
        /* over */
            @media (hover:hover) and (pointer:fine) {
                #header:hover{background: rgba(0,0,0,0.6); backdrop-filter: blur(5px);}
                #header .gnb > li:hover .dep02{opacity: 1; pointer-events: all;}
                #header .gnb:has(:hover) > li:not(:hover) > a{opacity: 0.6;}
                #header .gnb .dep02:has(:hover) > li:not(:hover){opacity: 0.6;}
            }

        /* on */
            #header.on{background: rgba(0,0,0,0.6); backdrop-filter: blur(5px);}

    @media (max-width:1023px) {
        #header{height: clamp(65px, 10vw, 100px);}
        #header .logo a{max-width: clamp(156px, 25vw, 214px);}
        #header .gnb{display: none;}
        #header .allCate{width: clamp(33px, 4.5vw, 40px);}
    }
    @media (max-width:479px) {
        #header .allCate span{height: 2px;}
    }

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

	Aside | outline/nav.html

───────────────────────────────────────────────────────────*/
    #aside{position: fixed;top: 0;left:0;width: 100%;height: 100%;z-index: 999;background: rgba(0,0,0,0.8);backdrop-filter:blur(10px);display: flex;flex-direction: column;overflow: hidden;overflow-y: auto;padding-block: 10vh;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: 1800px;min-height: 100%;display: flex;align-items: 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(4, 1fr);gap: clamp(15px, 2.2vw, 40px);}
    #aside .gnb > li{color: var(--point-white);font-size: inherit;text-align: center;}
        
        @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;}
        }
    #aside .gnb > li > a{position: relative;display: block;font-size: 180%;color:inherit;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 > a{display: block;font-size:110%;font-weight:400;padding-block: 15px;color: var(--black-color08);transition: all 0.4s;}
    #aside .utility{position: absolute;top: clamp(30px, 2.8vw, 50px);right: clamp(30px, 2.8vw, 50px);display: flex;align-items: center;gap: 30px; z-index:2;}
    #aside .close_btn{position: relative;width: 40px;height: 40px;z-index: 9;}
    #aside .close_btn span{position: absolute; top:50%; left:50%; transform: translate(-50%, -50%) rotate(45deg); width: 100%; height: 2px; background: var(--point-white);}
    #aside .close_btn span + span{transform: translate(-50%, -50%) rotate(-45deg);}
    
        /* over */
            @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-white);}
            }

    @media (max-width:1600px){
        #aside .gnb{grid-template: auto / repeat(3, 1fr)}
    }
    @media (max-width:1023px){
        #aside{padding-block: clamp(80px, 12vw, 120px);}
        #aside .close_btn{width: clamp(30px, 4vw, 40px);height: clamp(30px, 4vw, 40px);}
		#aside .utility{gap:20px;}
    }
    @media (max-width:860px){
		#aside{display: block;}
		#aside .w_custom{align-items:flex-start;}
		#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(255,255,255,0.5);}
        #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;}
		#aside .utility{top:15px; right: 15px;}
    }
    @media (max-width:640px){
        #aside .gnb > li > a{font-size: 200%;}
        #aside .gnb .dep02 > li > a{padding-block: 7px;font-size:100%;}
    }
    @media (max-width:479px){
        #aside .gnb > li > a{font-size: 170%;}
        #aside .gnb > li > a span{width: 100%;}
        #aside .gnb .dep02{margin-top: 10px;grid-template: auto / repeat(1, 1fr);}
        #aside .gnb .dep02 li{width: 100%;}
        #aside .gnb .dep02 > li > a{font-size: 95%;}
    }

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

    MAIN | index.html

───────────────────────────────────────────────────────────*/
    /* 비주얼*/
        .main_visual{position: relative; background: var(--black-color01); overflow: hidden;}
        .main_visual .slick-slide{position: relative; height: 980px; overflow: hidden;}
        .main_visual .link{position: absolute; inset: 0; z-index: 3;}
        .main_visual .thumb{display: block; width: 100%; height: 100%; background: no-repeat center / cover;}
            .main_visual .active .thumb{scale: 1.05; transition: all 5s;}
        .main_visual .txt_box{position: absolute;font-size: var(--title-20);color: var(--point-white);top: 36.8%;left: 50%;translate: -50%;display: grid;gap: 40px; text-wrap: balance;}
        .main_visual .txt_box h2{font-size: 64px;font-weight: 600;line-height: 1.3;letter-spacing: -0.03em;}
        .main_visual .txt_box h6{font-size: 110%;font-weight: 400;line-height: 1.6;letter-spacing: -0.03em;}
        .main_visual .txtAni{opacity: 0; translate: 70px;}
            .main_visual .active .txtAni{opacity: 1; translate: 0; transition: all 1.2s 0.2s;}
            .main_visual .active .txtAni:nth-child(2){transition-delay: 0.4s;}
        .main_visual .controller{position: absolute;top: 30.6%;left: 50%;translate: -50%;z-index: 5;}
        .main_visual .slick-dots{display: flex;flex-wrap: wrap;gap: 20px;font-size: 0;}
        .main_visual .slick-dots button{display: block;width: 10px;aspect-ratio: auto  1;border: 1px solid var(--point-white);transition: all 0.4s;}
        .main_visual .slick-dots .slick-active button{background:var(--point-color01); border-color:var(--point-color01);}
        .main_visual .scr_dwn{position: absolute;left:50%;bottom: 14%;translate: -50%;z-index: 5;display: flex;justify-content: flex-end;pointer-events: none; padding-right: 2px;}
        .main_visual .scr_dwn .desc{display: inline-flex;align-items: center;justify-content: flex-end;gap: 21px;font-size: var(--title-20);pointer-events: all; cursor: pointer;}
        .main_visual .scr_dwn .desc dt{font-size: 90%; font-weight: 400; filter: var(--filter-white); opacity: 0.8; font-family: var(--font-type02); letter-spacing: 0;}
        .main_visual .scr_dwn .desc dd{display: flex;flex-direction: column;width: 11px;translate: 0 -2px;}
        .main_visual .scr_dwn .desc dd span{width: 100%;aspect-ratio: auto 1;border: 2px solid var(--point-white);clip-path: var(--clip-poly01);rotate: 45deg;border-radius: 1px; opacity: 0;}

            .main_visual .scr_dwn .desc dd span{animation-name: scrDwn01; animation-duration:2s; animation-iteration-count:infinite; transition-timing-function:linear;}
            .main_visual .scr_dwn .desc dd span:nth-child(2){animation-name: scrDwn02; }
            .main_visual .scr_dwn .desc dd span:nth-child(3){animation-name: scrDwn03; }
            @keyframes scrDwn01 {0% {opacity: 0;} 90% {opacity: 0.3;} 100% {opacity: 0;}}
            @keyframes scrDwn02 {30% {opacity: 0;} 90% {opacity: 0.5;} 100% {opacity: 0;}}
            @keyframes scrDwn03 {50% {opacity: 0;} 90% {opacity: 1;} 100% {opacity: 0;}}

        @media (max-width:1023px) {
            .main_visual .slick-slide {height: clamp(580px, 98vw, 980px);}
            .main_visual .txt_box{gap: clamp(20px, 4vw, 40px);}
            .main_visual .txt_box h2{font-size: clamp(36px, 6.4vw, 64px);}
            .main_visual .slick-dots{gap: clamp(12px, 2.5vw, 20px);}
            .main_visual .slick-dots button{width: clamp(8px, 1.5vw, 10px);}
            .main_visual .scr_dwn{bottom: clamp(55px, 13.7vw, 137px);}
            .main_visual .scr_dwn .desc{gap: clamp(15px, 2.6vw, 21px);}
        }
        @media (max-width:479px) {
            .main_visual .txt_box h6{font-size: 100%;}
            .main_visual .scr_dwn .desc dd{width: 9px;}
        }

    /* 공통 */
        .main_title{position: relative;font-size: var(--title-20);display: flex;flex-direction: column;gap: 10px;text-wrap: balance;}
            .main_title.cen{text-align: center;}
            .main_title.hd{padding-block: 140px 70px;}
        .main_title h2{font-size: 270%;font-weight: 500;color: var(--black-color01);line-height: 1.3;letter-spacing: -0.03em;}
			.main_title h2 + h5{margin-top: 41px;}
        .main_title h2 strong{font-weight: 700;}
        .main_title h5{font-size: 120%;font-weight: 500;color: var(--black-color03);line-height: 1.6;letter-spacing: -0.03em;}
        .main_title h6{font-size: 110%; font-weight: 500; color: var(--black-color03); line-height: 1.3;}
			.main_title h6 + h2{margin-top: 13px;}
        .main_title h6 em{font-weight: 600;color: var(--point-color01);font-family: var(--font-type02);letter-spacing: 0;}
        .main_title p{font-size: 90%;font-weight: 400;color: var(--black-color06);line-height: 1.62;text-wrap: pretty;letter-spacing: -0.03em;}
        .main_title .more_arw{margin-top: 70px;}

        .more_arw{position: relative;display: flex;align-items: center;justify-content: space-between;gap: 30px;width: fit-content;min-width: 200px;padding: 16px 24px;font-size: var(--title-20);font-weight: 600;color: var(--point-color01);line-height: 1.45;letter-spacing: -0.03em;border: 1px solid rgba(255, 255, 255, 0.4);background: rgba(255, 255, 255, 0.1);backdrop-filter: blur(2px);transition: all 0.4s;overflow: hidden;}
            .more_arw:before{position: absolute;content:'';width: calc(100% + 2px);height: calc(100% + 2px);background: var(--point-white);top: -1px;left: -1px;z-index: -1;clip-path: inset(0 100% 0 0);transition: inherit;}
            .more_arw:after{display: inline-flex;content:'';width: 14px;aspect-ratio: auto 1.16;background: url('../images/skin/more_arw.svg') no-repeat center / 100% auto; filter: var(--filter-white); transition: inherit;}
        .more_arw span{position: relative; font-size: 90%;filter: var(--filter-white); transition: inherit;}

        .more_arw.bd_dn{border:0;background: none;padding: 0;min-width: auto;gap: 10px;overflow: visible;}
        .more_arw.bd_dn:before{display: none;}
        .more_arw.bd_dn:after{filter: none;}
        .more_arw.bd_dn span{filter: none;}

            /* over */
            @media (hover:hover) and (pointer:fine) {
                .more_arw:hover{border-color: var(--point-white);}
                .more_arw:hover:before{clip-path: inset(0);}
                .more_arw:hover:after{filter: none;}
                .more_arw:hover span{filter: none;}
                .more_arw.bd_dn:hover:after{translate: 5px;}
            }

        @media (max-width:1023px) {
            .main_title.hd{padding-block: clamp(80px, 14vw, 140px) clamp(25px, 7vw, 70px);}
            .main_title h2{font-size: 250%;}
            .main_title h2 + h5{margin-top: clamp(15px, 4.1vw, 40px);}
            .main_title h6 + h2{margin-top: clamp(7px, 1.3vw, 13px);}
            .main_title .more_arw{margin-top: clamp(35px, 7vw, 70px);}

            .more_arw{min-width: clamp(150px, 21vw, 200px); padding: clamp(12px, 2.1vw, 16px) clamp(20px, 2.9vw, 24px);}
        }
        @media (max-width:640px) {
            .main_title h2{font-size: 230%;}
        }
        @media (max-width:479px) {
            .main_title h2{font-size: 210%;}
            .main_title h5{font-size: 110%;}
            .main_title h6{font-size: 100%;}
        }

    /* Our Technology */
        .main_tech{position: relative;padding-block: 140px 200px;}
        .main_tech:before{position: absolute;content:'';width: clamp(250px, 32vw, 560px);aspect-ratio: auto 1.4;background: url('../images/skin/ci.svg') no-repeat center / 100% auto;filter: var(--filter-black);opacity: 0.05;left: -5.6%;bottom: -5.8%;}
        .main_tech .w_custom{display: flex;gap: 50px 80px;}
        .main_tech .main_title{width: 100%;padding-top: 80px;}
        .main_tech .exp_list{width: 570px; display: grid; grid-template: auto / repeat(2, 1fr); gap: clamp(15px, 1.6vw, 30px); flex-shrink: 0;}
        .main_tech .exp_list > li{position: relative;background: var(--point-color01);padding: 30px;padding-bottom: 32px;display: grid;gap: 46px;}
            .main_tech .exp_list > :is(li:nth-child(2),  li:nth-child(3n)){background: var(--black-color01);}
			.main_tech .exp_list > li:nth-child(2n){translate: 0 60px;}
        .main_tech .exp_list .icon{display: flex; align-items: flex-start; width: 50px; aspect-ratio: auto 1;}
        .main_tech .exp_list .desc{font-size: var(--title-20);filter: var(--filter-white);display: grid;gap: 9px;text-wrap: balance;}
        .main_tech .exp_list .desc dt{font-size: 120%;font-weight: 700;line-height: 1.2;letter-spacing: -0.03em;}
        .main_tech .exp_list .desc dd{font-size: 90%;font-weight: 400;line-height: 1.5;letter-spacing: -0.04em;}

        @media (max-width:1023px) {
            .main_tech{padding-block: clamp(80px, 14vw, 140px) clamp(80px, 20vw, 200px);}
            .main_tech:before{inset: auto;top: 30px;right: -75px;}
            .main_tech .w_custom{flex-wrap: wrap;gap: clamp(25px, 5vw, 50px);}
            .main_tech .main_title{padding-top: 0;}
            .main_tech .exp_list{width: 100%;}
            .main_tech .exp_list .icon{width: clamp(40px, 6vw, 50px);}
            .main_tech .exp_list > li{gap: clamp(28px, 4.6vw, 46px);}
            .main_tech .exp_list > li:nth-child(2n){translate: 0 clamp(30px, 7vw, 60px);}
        }
        @media (max-width:479px) {
            .main_tech .exp_list{grid-template:auto / repeat(1, 1fr)}
            .main_tech .exp_list > li{padding: 25px;}
            .main_tech .exp_list > li:nth-child(1n){background: var(--point-color01);}
            .main_tech .exp_list > li:nth-child(2n){background: var(--black-color01);}
            .main_tech .exp_list > li:nth-child(2n){translate: 0;}
        }

    /* 제품 */
        .main_prod{position: relative; background:no-repeat center / cover; background-image: url('../images/skin/main_prod01.jpg'), url('../images/skin/main_prod02.jpg'), url('../images/skin/main_prod03.jpg'), url('../images/skin/main_prod04.jpg'), url('../images/skin/main_prod05.jpg'); padding-block: 160px 90px; transition: all 0.4s;}
            .main_prod:has([data-swiper-slide-index="1"].swiper-slide-active){background-image: url('../images/skin/main_prod05.jpg');}
            .main_prod:has([data-swiper-slide-index="2"].swiper-slide-active){background-image: url('../images/skin/main_prod04.jpg');}
            .main_prod:has([data-swiper-slide-index="3"].swiper-slide-active){background-image: url('../images/skin/main_prod03.jpg');}
            .main_prod:has([data-swiper-slide-index="4"].swiper-slide-active){background-image: url('../images/skin/main_prod02.jpg');}
        .main_prod .wareSwiper{position: relative; clip-path: inset(0 -200% 0 0);}
        .main_prod .wareSwiper .swiper-slide{display: flex; align-items: center; gap: clamp(50px, 5.3vw, 100px); width: 100%; height: auto;}
        .main_prod .wareSwiper .swiper-slide:not(:last-child){margin-right: clamp(15px, 9.4vw, 180px);}
        .main_prod .wareSwiper .thumb{display: inline-flex;width: 45.95%;height: 640px;flex-shrink: 0; overflow: hidden;}
        .main_prod .wareSwiper .thumb img{width: 100%; height: 100%; object-fit: cover;}
        .main_prod .wareSwiper .main_title{width: 100%;}
        .main_prod .wareSwiper .main_title :where(h2, h5, p){filter: var(--filter-white); white-space:normal; overflow:hidden; text-overflow:ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;}
        .main_prod .wareSwiper .main_title p{opacity: 0.8;text-wrap: balance;}
        .main_prod .wareSwiper .swiper-pagination{position: relative;inset: auto;display: flex;justify-content: center;gap: 20px;width: 100%;margin: 60px 0 0;}
        .main_prod .wareSwiper .swiper-pagination span{width: 10px;height: auto;aspect-ratio: auto 1;border-radius: 0;border: 1px solid var(--point-white);background: none;transition: all 0.4s;margin: 0;opacity: 1;}
        .main_prod .wareSwiper .swiper-pagination .swiper-pagination-bullet-active{background: var(--point-color01);border-color: var(--point-color01);}

        @media (max-width:1240px) {
            .main_prod .wareSwiper .main_title br{display:none;}
        }
        @media (max-width:1023px) {
            .main_prod{padding-block: clamp(80px, 16vw, 160px) clamp(80px, 10vw, 90px);}
            .main_prod .wareSwiper{clip-path: none;}
            .main_prod .wareSwiper .swiper-slide{flex-wrap: wrap;gap: clamp(25px, 5vw, 50px);align-items: flex-start;}
            .main_prod .wareSwiper .thumb{width: 100%;max-width: 570px;height: auto;aspect-ratio: auto 0.89;}
            .main_prod .wareSwiper .swiper-pagination{margin-top: clamp(40px, 6vw, 60px);gap: clamp(12px, 2.5vw, 20px);}
            .main_prod .wareSwiper .swiper-pagination span{width: clamp(8px, 1.5vw, 10px);}
        }

    /* 믿음과 신뢰의 기업 */ 
        .main_biz{padding-bottom: 160px;}
        .main_biz .info_list{display: grid; grid-template:auto / repeat(3, 1fr); gap: clamp(15px, 1.7vw, 32px);}
        .main_biz .info_list > li{position: relative;border: 1px solid var(--border-color01);padding: 50px 40px 48px;display: flex;flex-direction: column;gap: 48px;justify-content: space-between; transition: all 0.4s;}
        .main_biz .link{position: absolute; inset: 0; z-index: 3;}
        .main_biz .desc{font-size: var(--title-20);display: grid;gap: 18px;text-wrap: balance;}
        .main_biz .desc dt{font-size: 140%;font-weight: 600;color: var(--black-color03);line-height: 1.2;letter-spacing: -0.03em;}
        .main_biz .desc dd{font-size: 90%;font-weight: 400;color: var(--black-color06);line-height: 1.5;letter-spacing: -0.03em;}
        .main_biz .icon{display: inline-flex;align-items: flex-end;justify-content: flex-end;width: 70px;position: absolute;right: 39px;bottom: 30px;z-index: -1;}

            /* over */
            @media (hover:hover) and (pointer:fine) {
                .main_biz .info_list > li:hover{border-color: var(--point-color01);}
                .main_biz .info_list > li:hover .more_arw.bd_dn:after{translate: 5px;}
            }

        @media (max-width:1023px) {
            .main_biz{padding-bottom: clamp(80px, 16vw, 160px);}
            .main_biz .info_list > li{padding: clamp(30px, 5vw, 48px) clamp(25px, 4vw, 40px);gap: clamp(30px, 4.8vw, 48px);}
            .main_biz .desc{gap: clamp(15px, 1.8vw, 18px);}
            .main_biz .icon{width: clamp(40px, 7vw, 70px);right: clamp(25px, 4vw, 39px);bottom: clamp(25px, 3vw, 30px);}
        }
        @media (max-width:860px) {
            .main_biz .info_list{grid-template: auto / repeat(2, 1fr);}
        }
        @media (max-width:479px) {
            .main_biz .info_list{grid-template: auto / repeat(1, 1fr);}
        }

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

    FOOTER | outline/footer.html

───────────────────────────────────────────────────────────*/
    #footer{position: relative; background: var(--black-color01); font-size: var(--title-20); color: var(--black-color10); font-weight: 300; line-height: 1.6;}
    #footer .en{font-family: var(--font-type02);}
    #footer .cont{font-size: 85%;padding-block: 60px 56px;}
    #footer .cont .w_custom{display: grid; gap: 40px;}
    #footer .top_sec{display: flex;align-items: center;justify-content: space-between;gap: 25px 30px;flex-wrap: wrap;}
    #footer .logo{display: flex;align-items: center;max-width: 214px;}
    #footer .link_list{display: flex; flex-wrap: wrap;}
    #footer .link_list > li{display: flex; align-items: center;}
        #footer .link_list > li:not(:last-child):after{display: inline-flex; content:''; width: 4px; aspect-ratio: auto 1; background: rgba(255,255,255,0.4); margin-inline: 18px;}
        #footer .link_list > li strong{font-weight: inherit; color: var(--point-white);}
    #footer address{display: grid; gap: 6px;}
    #footer address section{display: flex;align-items: center;flex-wrap: wrap;gap: 3px 24px;}
    #footer address h6{font-size: 106%; font-weight: 400; color: var(--point-white);}
    #footer address .item{display: flex;flex-wrap: wrap;gap: 2px 42px;}
    #footer address .desc{display: flex; align-items: baseline; gap: 10px;}
    #footer address .desc dt{color: rgba(255,255,255,0.8);flex-shrink: 0;}
    #footer .btm_sec{background: var(--black-color00);font-size: 75%;font-weight: 400;color: var(--black-color08);padding-block: 16px 15px;}
    #footer .copy{display: flex;justify-content: center;text-align: center;flex-wrap: wrap;gap: 4px 6px;letter-spacing: 0; text-wrap: balance;}

    .scr_top{position: fixed;right: clamp(30px, 2.1vw, 40px);bottom: 31px;display: flex;align-items: center;justify-content: center;width: 60px;height: 60px;padding: 11px;background: var(--point-white);box-shadow: var(--shadow-01);opacity: 0;pointer-events: none;transition: all 0.4s;z-index: 50;}
    body:has(#header.on:not(.end)) .scr_top{opacity: 1; pointer-events: all;}
    
    @media (max-width:1023px) {
        #footer .cont{padding-block: clamp(40px, 6vw, 60px) clamp(40px, 5.6vw, 56px);}
        #footer .cont .w_custom{gap: clamp(25px, 4vw, 40px);}
        #footer .logo{max-width: clamp(156px, 25vw, 214px);}
        #footer .link_list > li:not(:last-child):after{margin-inline: clamp(15px, 2.3vw, 18px);}
        #footer address section{column-gap: clamp(20px, 3vw, 24px);}
        #footer address .item{column-gap: clamp(25px, 4.2vw, 42px);}

        .scr_top{width: clamp(36px, 6vw, 60px);height: clamp(36px, 6vw, 60px);}
    }
    @media (max-width:860px) {
        .scr_top{right:15px;bottom: 20px;}
    }
    @media (max-width:479px) {
		#footer .link_list{width:100%;}
        #footer .link_list > li:not(:last-child):after{width: 3px;}
    }
