/* ADEC LAB 정식 반응형 CSS */

*,
*:before,
*:after{
box-sizing:border-box;
}

html,
body{
width:100%;
max-width:100%;
overflow-x:hidden;
}

body{
min-width:0 !important;
}

img,
video,
iframe{
max-width:100%;
height:auto;
}

@media screen and (max-width:1200px){
#header_content,
nav#gnb > ul,
#mainvisual .main_txt,
.section1 .quick,
.section2 .gallery,
.section3 .notice,
.section4 .banner,
#subvisual .sub_txt,
#cont{
width:100% !important;
max-width:1180px !important;
padding-left:24px !important;
padding-right:24px !important;
}

nav#gnb{
min-width:0 !important;
}

nav#gnb > ul{
display:flex !important;
justify-content:center !important;
}

nav#gnb > ul > li{
float:none !important;
flex:1 1 auto !important;
min-width:0 !important;
}
}

@media screen and (max-width:1024px){
nav#gnb > ul > li > a{
font-size:15px !important;
}

.section1 .quick > div{
width:48% !important;
margin:0 1% 20px !important;
}

.section2 .gallery ul li{
width:31.5% !important;
margin-left:2.5% !important;
}

.section2 .gallery ul li a span.thumb{
width:100% !important;
height:auto !important;
aspect-ratio:370 / 230;
}
}

@media screen and (max-width:768px){
#header{
height:auto !important;
min-height:0 !important;
}

#header_content{
padding-top:15px !important;
padding-bottom:15px !important;
}

#header_content .logo,
#header .logo{
position:relative !important;
left:auto !important;
top:auto !important;
text-align:center !important;
padding:0 !important;
margin:0 auto 12px !important;
}

#header_content .logo img,
#header .logo img{
max-width:150px !important;
height:auto !important;
}

#home_menu{
position:relative !important;
top:auto !important;
right:auto !important;
text-align:center !important;
margin-bottom:10px !important;
}

#home_menu ul{
display:flex !important;
justify-content:center !important;
flex-wrap:wrap !important;
gap:6px 12px !important;
}

#home_menu ul li{
float:none !important;
padding:0 !important;
background:none !important;
font-size:12px !important;
}

nav#gnb{
position:relative !important;
top:auto !important;
left:auto !important;
width:100% !important;
min-width:0 !important;
}

nav#gnb > ul{
border-top:1px solid #ddd !important;
display:flex !important;
flex-wrap:wrap !important;
gap:8px 14px !important;
padding-top:10px !important;
}

nav#gnb > ul > li{
width:auto !important;
min-width:0 !important;
flex:0 0 auto !important;
}

nav#gnb > ul > li > a{
height:auto !important;
padding:5px 0 !important;
font-size:13px !important;
line-height:1.3 !important;
white-space:nowrap !important;
}

nav#gnb > ul > li .gnb-2dep,
#gnbBg,
#gnbBg_wrap{
display:none !important;
}

#mainvisual{
height:auto !important;
min-height:420px !important;
}

#mainvisual .main_txt{
padding-top:120px !important;
}

#mainvisual .main_txt span{
font-size:16px !important;
padding:3px 24px !important;
}

#mainvisual .main_txt h2{
font-size:38px !important;
line-height:1.15 !important;
}

#mainvisual .main_txt p{
font-size:16px !important;
line-height:1.5 !important;
}

.section1{
padding:55px 0 60px !important;
}

.section1 .quick h3,
.section2 .gallery h3,
.section3 .notice h3{
font-size:26px !important;
line-height:1.3 !important;
margin-bottom:28px !important;
}

.section1 .quick > div{
float:none !important;
width:100% !important;
margin:0 0 16px 0 !important;
}

.section2{
padding:55px 0 !important;
}

.section2 .gallery ul li{
float:none !important;
width:100% !important;
margin:0 0 18px 0 !important;
}

.section2 .gallery ul li a span.thumb{
width:100% !important;
height:auto !important;
aspect-ratio:370 / 230;
}

.section3{
padding:55px 16px !important;
}

.section3 .notice ul li{
padding:22px 20px !important;
}

.section3 .notice ul li p{
width:100% !important;
white-space:normal !important;
line-height:1.45 !important;
font-size:16px !important;
}

.section3 .notice ul li a{
display:none !important;
}

.section4 .banner,
.banner_slide,
.banner_slide .bannerList{
width:100% !important;
}

#quick_menu{
display:none !important;
}

#cont{
padding-top:40px !important;
}

#subvisual .sub_txt{
padding-top:45px !important;
}

.sub_txt h3{
font-size:30px !important;
line-height:1.25 !important;
}

#leftmenu ul{
display:flex !important;
flex-wrap:wrap !important;
justify-content:center !important;
gap:8px !important;
}

#leftmenu ul li{
margin:0 !important;
}

#leftmenu ul li a{
padding:0 18px !important;
font-size:13px !important;
}
}

@media screen and (max-width:480px){
#header_content,
nav#gnb > ul,
#mainvisual .main_txt,
.section1 .quick,
.section2 .gallery,
.section3 .notice,
.section4 .banner,
#subvisual .sub_txt,
#cont{
padding-left:12px !important;
padding-right:12px !important;
}

#header_content .logo img,
#header .logo img{
max-width:130px !important;
}

nav#gnb > ul{
gap:6px 10px !important;
}

nav#gnb > ul > li > a{
font-size:12px !important;
}

#mainvisual{
min-height:360px !important;
}

#mainvisual .main_txt{
padding-top:100px !important;
}

#mainvisual .main_txt h2{
font-size:30px !important;
}

#mainvisual .main_txt p{
font-size:14px !important;
}

.section3{
padding-left:12px !important;
padding-right:12px !important;
}
}

/* =========================================================
   Mobile Hamburger Menu
========================================================= */

.mobile_menu_btn{
display:none;
}

@media screen and (max-width:1024px){
.mobile_menu_btn{
display:block !important;
position:absolute;
top:18px;
right:18px;
width:42px;
height:38px;
border:0;
background:transparent;
z-index:9999;
cursor:pointer;
}

.mobile_menu_btn span{
display:block;
width:28px;
height:3px;
background:#222;
margin:6px auto;
border-radius:3px;
transition:all .25s;
}

#header{
height:auto !important;
overflow:visible !important;
}

#header_content{
height:auto !important;
overflow:visible !important;
padding-top:15px !important;
padding-bottom:15px !important;
}

nav#gnb{
display:none !important;
position:relative !important;
top:auto !important;
left:auto !important;
width:100% !important;
min-width:0 !important;
margin-top:14px !important;
background:#fff !important;
border-top:1px solid #ddd !important;
z-index:9998 !important;
}

body.mobile_menu_open nav#gnb{
display:block !important;
}

nav#gnb > ul{
display:block !important;
width:100% !important;
padding:8px 0 !important;
border-top:0 !important;
}

nav#gnb > ul > li{
float:none !important;
width:100% !important;
min-width:0 !important;
text-align:left !important;
border-bottom:1px solid #eee !important;
}

nav#gnb > ul > li > a{
display:block !important;
height:auto !important;
padding:14px 18px !important;
font-size:15px !important;
line-height:1.35 !important;
color:#222 !important;
white-space:normal !important;
}

nav#gnb > ul > li .gnb-2dep{
display:none !important;
position:relative !important;
top:auto !important;
padding:0 !important;
background:none !important;
}

nav#gnb > ul > li.open .gnb-2dep{
display:block !important;
}

nav#gnb > ul > li .gnb-2dep li{
width:100% !important;
text-align:left !important;
line-height:1.35 !important;
}

nav#gnb > ul > li .gnb-2dep li a{
display:block !important;
padding:10px 28px !important;
font-size:13px !important;
background:#f7f7f7 !important;
color:#555 !important;
}

#gnbBg,
#gnbBg_wrap{
display:none !important;
}

#home_menu{
padding-right:60px !important;
}
}

@media screen and (max-width:480px){
.mobile_menu_btn{
top:14px;
right:12px;
}

nav#gnb > ul > li > a{
font-size:14px !important;
padding:13px 14px !important;
}

nav#gnb > ul > li .gnb-2dep li a{
font-size:12px !important;
padding:9px 24px !important;
}
}

/* =========================================================
   Hamburger final fix
   - logo left
   - remove shadow
   - mobile menu open
========================================================= */

@media screen and (max-width:1024px){
#header,
#header_content,
#gnb,
#gnbBg,
#gnbBg_wrap{
box-shadow:none !important;
text-shadow:none !important;
background-image:none !important;
}

#header_content .logo,
#header .logo{
position:relative !important;
left:auto !important;
top:auto !important;
text-align:left !important;
margin:0 !important;
padding:0 !important;
width:auto !important;
}

#header_content .logo a,
#header .logo a{
display:inline-block !important;
}

#header_content .logo img,
#header .logo img{
max-width:150px !important;
height:auto !important;
margin:0 !important;
}

.mobile_menu_btn{
display:block !important;
position:absolute !important;
top:18px !important;
right:18px !important;
width:42px !important;
height:38px !important;
border:0 !important;
background:transparent !important;
box-shadow:none !important;
z-index:99999 !important;
cursor:pointer !important;
}

.mobile_menu_btn span{
display:block !important;
width:28px !important;
height:3px !important;
background:#222 !important;
margin:6px auto !important;
border-radius:3px !important;
box-shadow:none !important;
}

nav#gnb{
display:none !important;
position:relative !important;
top:auto !important;
left:auto !important;
width:100% !important;
min-width:0 !important;
height:auto !important;
margin-top:15px !important;
background:#fff !important;
box-shadow:none !important;
overflow:visible !important;
}

body.mobile_menu_open nav#gnb{
display:block !important;
}

nav#gnb > ul{
display:block !important;
width:100% !important;
height:auto !important;
padding:0 !important;
margin:0 !important;
border-top:1px solid #ddd !important;
box-shadow:none !important;
}

nav#gnb > ul > li{
float:none !important;
display:block !important;
width:100% !important;
min-width:0 !important;
text-align:left !important;
border-bottom:1px solid #eee !important;
box-shadow:none !important;
}

nav#gnb > ul > li > a{
display:block !important;
height:auto !important;
padding:14px 16px !important;
font-size:15px !important;
line-height:1.35 !important;
color:#222 !important;
background:#fff !important;
box-shadow:none !important;
text-shadow:none !important;
}

nav#gnb > ul > li .gnb-2dep{
display:none !important;
position:relative !important;
top:auto !important;
padding:0 !important;
background:none !important;
box-shadow:none !important;
}

nav#gnb > ul > li.open .gnb-2dep{
display:block !important;
}

#gnbBg,
#gnbBg_wrap{
display:none !important;
}
}

/* =========================================================
   Mobile right side menu final
========================================================= */

@media screen and (max-width:1024px){
#header,
#header_content,
nav#gnb,
#gnbBg,
#gnbBg_wrap{
box-shadow:none !important;
text-shadow:none !important;
}

#header .logo,
#header_content .logo{
text-align:left !important;
margin:0 !important;
padding:0 !important;
}

#header .logo img,
#header_content .logo img{
max-width:150px !important;
height:auto !important;
}

.mobile_menu_btn{
display:block !important;
position:absolute !important;
top:18px !important;
right:18px !important;
width:44px !important;
height:40px !important;
background:transparent !important;
border:0 !important;
box-shadow:none !important;
z-index:99999 !important;
}

.mobile_menu_btn span{
display:block !important;
width:30px !important;
height:3px !important;
background:#111 !important;
margin:6px auto !important;
box-shadow:none !important;
}

#header > nav#gnb,
#header_content > nav#gnb{
display:none !important;
}

.mobile_menu_dim{
display:none;
position:fixed;
left:0;
top:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.45);
z-index:99997;
box-shadow:none !important;
}

body.mobile_menu_open .mobile_menu_dim{
display:block;
}

.mobile_side_menu{
position:fixed;
top:0;
right:-82%;
width:82%;
max-width:360px;
height:100%;
background:#fff;
z-index:99998;
transition:right .28s ease;
box-shadow:none !important;
overflow-y:auto;
}

body.mobile_menu_open .mobile_side_menu{
right:0;
}

.mobile_side_head{
height:76px;
background:#0e0f37;
display:flex;
align-items:center;
justify-content:space-between;
padding:0 18px;
box-shadow:none !important;
}

.mobile_side_logo img{
max-width:150px !important;
height:auto !important;
filter:brightness(0) invert(1);
}

.mobile_side_close{
background:none;
border:0;
color:#fff;
font-size:42px;
line-height:1;
cursor:pointer;
box-shadow:none !important;
}

.mobile_side_body nav#gnb{
display:block !important;
position:relative !important;
top:auto !important;
left:auto !important;
width:100% !important;
min-width:0 !important;
margin:0 !important;
background:#fff !important;
box-shadow:none !important;
}

.mobile_side_body nav#gnb > ul{
display:block !important;
width:100% !important;
margin:0 !important;
padding:18px 0 !important;
border:0 !important;
box-shadow:none !important;
}

.mobile_side_body nav#gnb > ul > li{
float:none !important;
width:100% !important;
min-width:0 !important;
text-align:left !important;
border-bottom:0 !important;
box-shadow:none !important;
}

.mobile_side_body nav#gnb > ul > li > a{
display:block !important;
height:auto !important;
padding:13px 28px !important;
font-size:18px !important;
font-weight:700 !important;
line-height:1.4 !important;
color:#111 !important;
background:#fff !important;
box-shadow:none !important;
text-shadow:none !important;
}

.mobile_side_body nav#gnb .gnb-2dep,
.mobile_side_body #gnbBg,
.mobile_side_body #gnbBg_wrap{
display:none !important;
}
}

/* =========================================================
   REAL FINAL MOBILE SIDE MENU
========================================================= */

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

html,body{
overflow-x:hidden !important;
}

#header{
height:95px !important;
min-height:95px !important;
background:#fff !important;
box-shadow:none !important;
border-bottom:1px solid #ddd !important;
}

#header_content{
width:100% !important;
height:95px !important;
padding:0 18px !important;
margin:0 !important;
position:relative !important;
box-shadow:none !important;
background:#fff !important;
}

#header .logo,
#header_content .logo{
position:absolute !important;
left:18px !important;
top:50% !important;
transform:translateY(-50%) !important;
margin:0 !important;
padding:0 !important;
text-align:left !important;
width:auto !important;
z-index:50 !important;
}

#header .logo img,
#header_content .logo img{
max-width:72px !important;
height:auto !important;
margin:0 !important;
}

#home_menu{
display:none !important;
}

#header nav#gnb,
#header_content nav#gnb,
nav#gnb{
display:none !important;
}

#gnbBg,
#gnbBg_wrap{
display:none !important;
box-shadow:none !important;
}

.mobile_menu_btn{
display:block !important;
position:absolute !important;
right:22px !important;
top:50% !important;
transform:translateY(-50%) !important;
width:52px !important;
height:44px !important;
padding:0 !important;
margin:0 !important;
background:transparent !important;
border:0 !important;
box-shadow:none !important;
z-index:99999 !important;
cursor:pointer !important;
}

.mobile_menu_btn span{
display:block !important;
width:42px !important;
height:4px !important;
background:#111 !important;
margin:7px auto !important;
border-radius:4px !important;
box-shadow:none !important;
}

.mobile_menu_dim{
display:none !important;
position:fixed !important;
left:0 !important;
top:0 !important;
width:100% !important;
height:100% !important;
background:rgba(0,0,0,0.45) !important;
z-index:99997 !important;
box-shadow:none !important;
}

body.mobile_menu_open .mobile_menu_dim{
display:block !important;
}

.mobile_side_menu{
position:fixed !important;
top:0 !important;
right:-82% !important;
width:82% !important;
max-width:360px !important;
height:100% !important;
background:#fff !important;
z-index:99998 !important;
transition:right .28s ease !important;
box-shadow:none !important;
overflow-y:auto !important;
}

body.mobile_menu_open .mobile_side_menu{
right:0 !important;
}

.mobile_side_head{
height:82px !important;
background:#0e0f37 !important;
display:flex !important;
align-items:center !important;
justify-content:space-between !important;
padding:0 20px !important;
box-shadow:none !important;
}

.mobile_side_logo{
color:#fff !important;
font-size:20px !important;
font-weight:700 !important;
letter-spacing:0.03em !important;
}

.mobile_side_close{
background:none !important;
border:0 !important;
color:#fff !important;
font-size:44px !important;
line-height:1 !important;
box-shadow:none !important;
cursor:pointer !important;
}

.mobile_side_list{
padding:26px 28px !important;
background:#fff !important;
}

.mobile_side_list a{
display:block !important;
padding:13px 0 !important;
color:#111 !important;
font-size:18px !important;
font-weight:700 !important;
line-height:1.4 !important;
text-decoration:none !important;
background:#fff !important;
box-shadow:none !important;
text-shadow:none !important;
}

.mobile_side_list hr{
border:0 !important;
border-top:1px solid #ddd !important;
margin:22px 0 !important;
}
}


/* DDRL_RESPONSIVE_LEFTMENU_COLOR_0E0F37_START */
/* 반응형 서브페이지 상단 leftmenu active/hover 색상 통일 */
@media screen and (max-width:1024px){

    body #leftmenu ul li.on,
    body #leftmenu ul li.on > a,
    body #leftmenu ul li.on a,
    body #leftmenu ul li:hover,
    body #leftmenu ul li:hover > a,
    body #leftmenu ul li:hover a,
    body #leftmenu ul li a:hover,
    body #leftmenu ul li a:focus{
        background:#0e0f37 !important;
        background-color:#0e0f37 !important;
        border-color:#0e0f37 !important;
        color:#fff !important;
    }

    body #leftmenu ul li.on a,
    body #leftmenu ul li:hover a,
    body #leftmenu ul li a:hover,
    body #leftmenu ul li a:focus{
        color:#fff !important;
    }
}
/* DDRL_RESPONSIVE_LEFTMENU_COLOR_0E0F37_END */

