@charset "UTF-8";

@import url(reset.css);



html,body{

    transition: 0.5s;

}

/* ############### header영역 ############### */

#header{

    position: fixed;

    width: 100vw;

    z-index: 9999999;

}

#header .header_logo{

    position: absolute;

    left: 55px;

    top: 55px;

}

#header .header_logo img{}

#header .header_menu{

    position: absolute;

    right: 95px;

}

#header .header_menu .header_menu_btn{

    position: absolute;

    top: 78px;

    z-index: 99999;

}

#header .header_menu .header_menu_btn span{

    display: block;

    width: 25px;

    height: 4px;

    background: #333;

    margin-bottom: 5px;

    transition: 0.3s;

}

#header .header_menu .header_menu_btn:hover span{

    margin-bottom: 4px;

}

#header .header_menu .header_menu_btn span:last-child{

    margin-bottom: 0;

}

#header .header_menu.navOn .header_menu_btn span:nth-child(1){

    transform: rotate(45deg) translateY(11px);

}

#header .header_menu.navOn .header_menu_btn span:nth-child(2){

    opacity: 0;

    margin-left: 5px;

}

#header .header_menu.navOn .header_menu_btn span:nth-child(3){

    transform: rotate(-45deg) translate(2px,-13px);

}

#header .header_menu.navOn .header_menu_btn:hover span{

    margin-bottom: 5px;

}

#header .header_menu .header_menu_list{

    position: absolute;

    top: 0;

    left: -95.6vw;

    width: 100vw;

    height: 100vh;

    background: #fff;

    z-index: 999;

    transition: 0.3s;

    opacity: 0;

    pointer-events: none;

    box-sizing: border-box;

}

#header .header_menu .header_menu_list .menu_wrap{

    position: absolute;

    top: 50%;

    left: 7vw;

    transform: translateY(-50%);

}

#header .header_menu .header_menu_list .menu_list{}

#header .header_menu .header_menu_list .menu_list li{

    margin-bottom: 50px;

    position: relative;

}

#header .header_menu .header_menu_list .menu_list li:nth-child(2) .counting1{

    width: 78px;

    height: 78px;

    background: #ff0b34;

    border-radius: 50%;

    color: #fff;

    font-size: 27px;

    font-weight: 700;

    text-align: center;

    line-height: 78px;

    position: absolute;

    top: -30px;

    right: -25px;

    z-index: -1;

    animation: floating 4s linear infinite;

}



@keyframes floating{

    25%{

        top: -24px;

    }

    50%{

        top: -30px;

    }

    75%{

        top: -24px;

    }

    100%{

        top: -30px;

    }

}



#header .header_menu .header_menu_list .menu_list li a{

    font-weight: 800;

    font-size: 80px;

    color: #333;

    transition: 0.3s;

}

#header .header_menu .header_menu_list .menu_list li:hover a{

    color: #ff0b34;

}

#header .header_menu .header_menu_list .menu_sns{

    display: inline-block;

}

#header .header_menu .header_menu_list .menu_sns li{

    margin-bottom: 20px;

}

#header .header_menu .header_menu_list .menu_sns li a{

    font-size: 20px;

    transition: 0.3s;

}

#header .header_menu .header_menu_list .menu_sns li:hover a{

    color: #ff0b34;

}

#header .header_menu.navOn .header_menu_list{

    opacity: 1;

    pointer-events: all;

}





#header.motion .header_menu .header_menu_list{

    background: #222;

}

#header.motion .header_menu .header_menu_list .menu_list li a{

    color: #fff;

}

#header.motion .header_menu .header_menu_list .menu_list li:hover a{

    color: #ff0b34;

}

#header.motion .header_menu .header_menu_list .menu_sns li a{

    color: #a7a7a7;

}

#header.motion .header_menu .header_menu_list .menu_sns li:hover a{

    color: #ff0b34;

}







/* ############### 영역 추가 230224 ############### */
#add_sec{
	padding-top: 160px;
	cursor: url(/img/scrollDown.png), auto; 
}




#add_sec .wrap{}


#add_sec h3{
	/* font-size: 25px; */
	font-size: 30px;
	line-height: 1.5;
	/* font-weight: 300; */
	font-weight: 500;
	color: #111;

}

#add_sec h3 br:nth-child(1){
	display: none;
}


#add_sec ul{
	/* margin-top: 60px; */
	margin-top: 40px;
	position: relative;
}

#add_sec ul::after{
	/* content: "Scroll \A -Down"; */
	/* content: "SCROLL - \A DOWN"; */
	/* content: "PORT \A FOLIO"; */
/* 	content: "HELLO_O \A HL-STORY"; */
	content: "MADE BY \A HL-STORY";
	
	font-size: 180px;
	font-weight: 700;
	color: #fff;
	text-align: right;
	/* -webkit-text-stroke: 1px #ff0b34; */

	text-shadow:
    -1px -1px 0 #ff0b34,
    1px -1px 0 #ff0b34,
    -1px 1px 0 #ff0b34,
    1px 1px 0 #ff0b34;  

	position: absolute;
	top: 45%; right: 0;
	transform: translateY(-50%);
	z-index: -1;

	white-space: pre;

	opacity: 0;

}


#add_sec.motion ul::after{
	animation: fade-in 1.5s forwards;
}

@keyframes fade-in{
	from{
		top: 58%;
		opacity: 0;
	}

	to{
		top: 45%;
		opacity: 1;
	}
}



#add_sec ul li{
	overflow: hidden;
}

#add_sec ul li a{
	/* font-size: 100px; */
	font-size: 115px;
	font-weight: 700;
	/* color: #111; */
	color: #ff0b34;
	display: inline-block;
	 /* transition: 0.3s; */

	 text-shadow:
    -1px -1px 0 rgba(0,0,0,0),
    1px -1px 0 rgba(0,0,0,0),
    -1px 1px 0 rgba(0,0,0,0),
    1px 1px 0 rgba(0,0,0,0); 
}

#add_sec ul li a:hover{
	color: #fff;

	text-shadow:
    -1px -1px 0 #ff0b34,
    1px -1px 0 #ff0b34,
    -1px 1px 0 #ff0b34,
    1px 1px 0 #ff0b34; 
}

#add_sec ul li:not(:last-child){
	margin-bottom: 40px;
}



@media screen and (max-width: 1024px){
	#add_sec ul::after{
		font-size: 110px;
	}

	#add_sec ul li a{
		font-size: 90px;
	}
}



@media screen and (max-width: 900px){
	#add_sec{
		padding-top: 200px;
	}
}


@media screen and (max-width: 600px){
	#add_sec{
		/* padding-top: 135px; */
		padding-top: 110px;
	}

	#add_sec h3{
		font-size: 19px;
		word-break: keep-all;
	}

	
	#add_sec h3 br:nth-child(1){
		display: block;
	}

	#add_sec ul{
		/* margin-top: 30px; */
		margin-top: 35px;
	}

	#add_sec ul::after {
		/* content: "SCROLL-DOWN"; */
		/* font-size: 50px; */
		font-size: 37px;
		top: auto;
		/* bottom: -175px; */
		/* bottom: -160px; */
		bottom: -210px;
		/* bottom: -190px; */
		/* bottom: -120px; */
		opacity: 0;
	}

	

@keyframes fade-in{
	from{
		bottom: -210px;
		opacity: 0;
	}

	to{
		bottom: -160px;
		opacity: 1;
	}
}



	#add_sec ul li:not(:last-child){
		margin-bottom: 20px;
	}

	#add_sec ul li a{
		/* font-size:	55px; */
		font-size: 75px;
	}
}








/* ############### 첫번째 영역 ############### */

#main_sec1{
/* 	    background: url(../img/portfolio_bottom.png) no-repeat;
    background-position: center top 15%; */
    

}

#main_sec1 .main_title{

	

    padding-top: 220px;

    overflow: hidden;

}

#main_sec1 .main_title .title_left{

    /* color: #333; */
	color: #111;

    font-size: 100px;

    font-weight: 700;

    letter-spacing: -5px;

    position: relative;

    float: left;

    z-index: 2;

}

#main_sec1 .main_title .title_left .count_up{

    background: #ff0b34;

    color: #fff;

    width: 77px;

    height: 77px;

    border-radius: 50%;

    font-size: 26px;

    line-height: 77px;

    font-weight: 700;

    text-align: center;

    display: block;

    position: absolute;

    right: -50px;

    top: -25px;

    z-index: -1;

}


#main_sec1 .main_title .title_left .btn_showreel{
    position: absolute;
    bottom: 20px; right: -7.8vw;
	
    /* top: 50%; right: -6.6vw; */
    font-size: 22px; font-weight: 600;
    transition: 0.3s;
	
}
#main_sec1 .main_title .title_left .btn_showreel:hover{
    color: #ff0b34;
}
#main_sec1 .main_title .title_left .btn_showreel::before{
    content: "";
    width: 8px; height: 2px;
    background: #333;
    border-radius: 5px;
    position: absolute;
    right: -15px;
    top: 46%;
    transform: translateY(-50%) rotate(45deg);
    transition: 0.3s;
    opacity: 0;
}
#main_sec1 .main_title .title_left .btn_showreel::after{
    content: "";
    width: 8px; height: 2px;
    background: #333;
    border-radius: 5px;
    position: absolute;
    right: -15px;
    top: 59%;
    transform: translateY(-50%) rotate(-45deg);
    transition: 0.3s;
    opacity: 0;
}

#main_sec1 .main_title .title_left .btn_showreel:hover::before,
#main_sec1 .main_title .title_left .btn_showreel:hover::after{
    opacity: 1;
    right: -20px;
    background: #ff0b34;
}

#main_sec1 .main_title .title_right{

    color: #333;

    font-size: 20px;

    line-height: 100px;

    font-weight: 600;

    float: right;

}



#main_sec1 .portfolio_box{

    position: relative;

    margin-top: 70px;

}

#main_sec1 .portfolio_box .portfolio_tab{

    position: absolute;

    left: 50%;

    transform: translateX(-50%);

    width: 100%;

    text-align: center;

}

#main_sec1 .portfolio_box .portfolio_tab li{

    display: inline-block;

    margin: 0 32.5px;

}

#main_sec1 .portfolio_box .portfolio_tab li a{

    display: block;

    font-size: 20px;

    color: #888;

    transition: 0.3s;

}

#main_sec1 .portfolio_box .portfolio_tab li a:hover{

    color: #333;

}

#main_sec1 .portfolio_box .portfolio_tab li.tab_active{}

#main_sec1 .portfolio_box .portfolio_tab li.tab_active a{

    color: #333;

    position: relative;

    z-index: 9;

}

#main_sec1 .portfolio_box .portfolio_tab li.tab_active a::after{

    content: "";

    width: 130%;

    height: 5px;

    background: #ff334c;

    position: absolute;

    bottom: 4px;

    left: -50%;

    transform: translateX(28%);

    z-index: -1;

}



#main_sec1 .portfolio_box .portfolio_content{

    /* width: 1000px; */
	width: 100%;

    margin: 0 auto 200px;

    padding-top: 200px;

    display: flex;

    flex-wrap: wrap;

    /* justify-content: space-between; */

    display: none;

    /* position: relative; */

}

#main_sec1 .portfolio_box .portfolio_content .portfolio{

    position: relative;

    margin-bottom: 70px;

    width: 30%;

    margin-right: 3.3%;

	height: auto;

	padding-bottom: 19%;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio:nth-of-type(3n+2){

    margin-top: -90px;

    height: 358px;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_front{

    /* position: relative; */

	position: absolute;

	width: 100%;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%);

}

#main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_front img{

    transition: 0.6s;

	width: 100%;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio:hover .portfolio_front img{

    transform: scale(0.9);

}

#main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_front .portfolio_disc{

    color: #fff;

    text-shadow: 1px 2px 5px rgb(0 0 0 / 70%);

    position: absolute;

    bottom: 25px;

    left: 20px;

    letter-spacing: -1px;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_hover{

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    display: flex;

    justify-content: center;

    align-items: center;

    flex-direction: column;

    background: rgba(255,11,52,0.8);

    opacity: 0;

    transition: 0.6s;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio:hover .portfolio_hover{

    opacity: 1;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_hover .portfolio_hover_logo{

    width: 49px;

    height: 30px;

    box-sizing: border-box;

    border: 3px solid #fff;

    font-size: 24px;

    letter-spacing: -1px;

    color: #fff;

    font-weight: 700;

    line-height: 25px;

    opacity: 0;

    transition: 0.4s;

    transition-delay: 0.3s;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio:hover .portfolio_hover .portfolio_hover_logo{

    opacity: 1;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_hover .portfolio_hover_disc{

    font-size: 14px;

    color: #fff;

    margin: 30px 0;

    letter-spacing: -0.5px;

    opacity: 0;

    transition: 0.4s;

    transition-delay: 0.4s;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio:hover .portfolio_hover .portfolio_hover_disc{

    opacity: 1;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_hover img{

    opacity: 0;

    transition: 0.4s;

    transition-delay: 0.5s;

}

#main_sec1 .portfolio_box .portfolio_content .portfolio:hover .portfolio_hover img{

    opacity: 1;

}



#main_sec1 .portfolio_box .portfolio_content.client ul{

    display: flex;

    flex-wrap: wrap;

    justify-content: center;

}

#main_sec1 .portfolio_box .portfolio_content.client ul li{

    width: 25%;

    margin-bottom: 40px;

}

#main_sec1 .portfolio_box .portfolio_content.client ul li img{}


#main_sec1 .portfolio_box .portfolio_content .writeBtn{
    position: absolute;
    bottom: 0;
    right: 0;
    box-sizing: border-box;
    border: 1px solid #ccc;
    border-radius: 7px;
    padding: 5px 15px;
    text-align: center;
    color: #525252;
    transition: 0.3s;
}

#main_sec1 .portfolio_box .portfolio_content .writeBtn:hover{
    background: #eee;
}

#main_sec1 .portfolio_box .portfolio_content.client span{
    display: inline-block;
    box-sizing: border-box;
    border: 1px solid #ccc;
    border-radius: 7px;
    padding: 5px 15px;
    text-align: center;
    color: #525252;
    margin: 10px 5px 0;
    transition: 0.3s;
}
#main_sec1 .portfolio_box .portfolio_content.client span:hover{
    background: #eee;
}

#main_sec1 .portfolio_box .portfolio_content.client ul{
    width: 100%;
    text-align: center;
}














/* ###########  로그인버튼  ############## */
#header .loginBtn{
    position: absolute;
    bottom: -131px;
}
#header .loginBtn li{
    display: inline-block;
    padding: 5px 10px;
    border: 1px solid #ccc;
    border-radius: 7px;
    transition: 0.3s;
}
#header .loginBtn li:hover{
    background: #eee;
}
#header .loginBtn li:nth-of-type(2){
    margin-left: 20px;
}
#header .loginBtn li a{
    color: #888;
    font-size: 12px;
    letter-spacing: -0.5px;
}

@media screen and (max-width: 600px){
    #header .loginBtn li a{
        font-size: 10px;
    }
    #header .loginBtn li{
        padding: 2px 8px;
    }
    #header .loginBtn li:nth-of-type(2) {
        margin-left: 10px;
    }
}















/* ############### quick menu ############### */

.quick_btn{

    position: absolute;

    top: 40vh;

    right: 0;

    writing-mode: vertical-rl;

    width: 50px;

    height: 180px;

    background: #333;

    color: #fff;

    font-weight: 700;

    line-height: 50px;

    text-align: center;

    letter-spacing: -0.5px;

    cursor: pointer;


}

.quick_btn .accent{

    color: #ff0b34;

    font-weight: 700;

}

.quick_btn img{

    padding-top: 20px;

    padding-right: 20px;

}





/* ############################################

############## 반응형 - mobile #################

############################################### */

@media screen and (max-width: 1024px){
	#main_sec1 .main_title .title_left .btn_showreel{
		right: -16.8vw;
	}
}


@media screen and (max-width: 900px){
	#main_sec1 .main_title .title_left .btn_showreel{
		position: static;
		display: block;
		margin-top : 25px; 
	}
}



@media screen and (max-width: 600px){

    #header .header_logo {

        left: 20px;

        top: 35px;

        width: 40px;

    }

    #header .header_logo img {

        width: 100%;

    }

    #header .header_menu{

        right: 60px;

    }

    #header .header_menu .header_menu_btn{

        top: 44px;

    }

    #header .header_menu .header_menu_list{

        left: -84vw;

        width: 101vw;

    }

    #header .header_menu .header_menu_list .menu_list li a{

        font-size: 50px;

        display: block;

    }

    #header .header_menu .header_menu_list .menu_list li:nth-child(2) .counting1{

        width: 65px;

        height: 65px;

        font-size: 22px;

        line-height: 65px;

    }

    #header .header_menu .header_menu_list .menu_sns li a{

        font-size: 17px;

    }

    

    #main_sec1 .main_title{

        /* padding-top: 150px; */
		padding-top: 320px;

    }

    #main_sec1 .main_title .title_left{

        font-size: 70px;

        float: none;

        display: inline-block;

    }

    #main_sec1 .main_title .title_left .count_up{

        width: 60px;

        height: 60px;

        line-height: 60px;

        font-size: 20px;

        top: -23px;

        right: -43px;

    }

    #main_sec1 .main_title .title_left .btn_showreel{
        right: -39vw; bottom: 15px;
        font-size: 19px;
		margin-top: 15px;
    }
    #main_sec1 .main_title .title_left .btn_showreel::before{
        width: 5px;
    }
    #main_sec1 .main_title .title_left .btn_showreel::after{
        width: 5px;
    }

    #main_sec1 .main_title .title_right{

        float: none;

        display: block;

        /* text-align: right; */
        text-align: left;

        font-size: 18px;

        /* line-height: 60px; */
        line-height: 40px;

    }

    

    #main_sec1 .portfolio_box .portfolio_tab li {

        margin: 0 20px;

        margin-bottom: 15px;

    }

    #main_sec1 .portfolio_box .portfolio_tab li a{

        font-size: 18px;

    }

    #main_sec1 .portfolio_box .portfolio_tab li.tab_active a::after{

        height: 3.5px;

    }

    

    #main_sec1 .portfolio_box .portfolio_content{

        padding-top: 125px;

        width: 100%;

        margin: 0px auto 120px;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio{

        width: 47%;

        margin-right: 3%;

        height: auto;

        margin-bottom: 15px;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio:nth-of-type(3n+2){

        margin-top: 0;

        height: auto;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio:nth-of-type(2n){

        margin-top: -20px;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio:nth-of-type(2n) .portfolio_hover{

        height: 90%;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_front img{

        width: 100%;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_front .portfolio_disc{

        font-size: 14px;

        bottom: 15px;

        left: 10px;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_hover .portfolio_hover_logo{

        width: 37px;

        height: 27px;

        font-size: 17px;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_hover .portfolio_hover_disc{

        text-align: center;

    }

    #main_sec1 .portfolio_box .portfolio_content .portfolio .portfolio_hover img{}

    

    #main_sec1 .portfolio_box .portfolio_content.client ul li{

        width: calc(100% / 3);

        text-align: center;

    }

    #main_sec1 .portfolio_box .portfolio_content.client ul li img{

        width: 90%;

    }

    #main_sec1 .portfolio_box .portfolio_content .writeBtn {

        padding: 3px 12px;

        font-size: 13px;

    }

    

    





    .quick_btn{

        width: 35px;

        height: 135px;

        line-height: 35px;

        font-size: 13px;

        z-index: 10;

    }

    .quick_btn img {

        padding-top: 10px;

        padding-right: 13px;

    }

}

