:root {
  --colorD42A54: var(--colotEE6811);
  --header-h: 8rem;
  --submenu-h: 24rem;
}
/* header */
#header.header.new-header {
  background: var(--colorfff);
  max-height: var(--header-h);
  /* border-bottom: 1px solid var(--colorEAEAEA); */
  position: relative;
   /* overflow: hidden;  */
  border-bottom: 1px solid var(--line);
  transition: max-height .28s ease, box-shadow .2s ease;
  top: 0;
  z-index: 999;
}
#header.header.new-header.is-open{
  max-height: calc(var(--header-h) + var(--submenu-h));
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
}
.home__wrap #header.header.new-header  #user{    color: #FFF;}
.home__wrap #header.header.new-header.is-open #user{    color: var(--color303030);}
#header.header.new-header > nav{
  display: flex;
  width: 100%;
  /* max-width: 150rem; */
  /* margin: 0 auto; */
  padding: 0 11rem;
  justify-content: space-between;
  align-items: center;
  position: relative;
  z-index: 3; 

}
#header.header.new-header:hover > nav{
  border-bottom: 1px solid var(--line);

}
.sns_area ul{
  display: flex;
  gap: 2rem;
  align-items: center;
}
#header.header.new-header:hover .gnb__bg{
  border-bottom: 1px solid var(--line);
  pointer-events: none;   
}

.header .util{
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
  gap: 2rem;
}
.header .util .btnWrap{position: relative;}
/* gnb */
.gnb_wrap{
  position: relative;
}
/* .gnb__bg{
  position: absolute;
  left: 0; right: 0;
  top: var(--header-h);
  width: 100vw;
  background-color: var(--colorfff);
  z-index: 1; 
  transform-origin: top; 
  transform: scaleY(0); 
  opacity: 0; 
  transition: transform .22s ease, opacity .22s ease; 
  height: var(--submenu-h); 
  pointer-events: none;   
} */
.gnb__bg{
  position:absolute; left:0; right:0; top:var(--header-h);
  width:100vw; height:var(--submenu-h);
  background:var(--colorfff);
  z-index:1;
  transform-origin:top;
  transform:scaleY(0);
  opacity:0;
  transition:transform .22s ease, opacity .22s ease;
  pointer-events:none; /* 기본은 클릭 안 잡음 */
}

/* ✅ is-open일 때만 열림 */
#header.header.new-header.is-open .gnb__bg {
  transform: scaleY(1);
  opacity: 1;
  pointer-events: auto;
}
/* #header.header.new-header.is-open .gnb__bg{
  transform: scaleY(1);
  opacity:0;
  pointer-events: auto;  
}
#header.header.new-header.is-open.active .gnb__bg{
  transform: scaleY(1);
  opacity: 1;
} */
.gnb_wrap #gnb  .depth1{
  display: flex;
  height: 100%;
  font-size: 1.8rem ;
}
.gnb_wrap #gnb  .depth1 a{
  display: inline-flex;
  width: 100%;
  text-align: center;
  color: #303031;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 100%; /* 18px */
  letter-spacing: -0.72px;
    transition: color 0.1s ease, font-weight 0.1s ease;
}
.gnb_wrap #gnb  .depth1 a:hover{
  color: var(--colotEE6811);
  font-weight: 600;
}
.gnb_wrap #gnb{
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 8rem;
 position: relative !important; 
}

.gnb_wrap #gnb > li{
  display: flex;
  /* width: 100%; */
  width: clamp(12rem, 18vw, 18rem);
  justify-content: center;
  align-items: center;
  flex-direction: column;
  text-align: center;
    max-height: 8rem;
  height: 100%;

} 
.gnb_wrap #gnb > li > ul{
  position: absolute;
  top: var(--header-h);
  max-width: 18rem;
  width: 100%;
  height: var(--submenu-h);
  padding: 2rem 0;
  border-right: 1px solid #EAEAEA;
  z-index: 2;
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
  transition: 
  opacity .2s ease,
  transform .2s ease,;

  border-right: 1px solid transparent;
}

.gnb_wrap #gnb > li:first-child > ul{
  border-left: 0px solid #EAEAEA;
}
.gnb_wrap #gnb > li > ul > li{
  padding: 1rem 0;
}
.gnb_wrap #gnb  .depth2 a {
  font-size: 1.6rem;
}
.gnb_wrap #gnb > li > ul > li a:hover{
  color: var(--colotEE6811);
}
#header.header.new-header:hover .gnb_wrap #gnb > li > ul{
  opacity: 1;
  transform: translateY(0);
  border-right-color: #EAEAEA;
  transition:
    opacity .2s ease,
    transform .2s ease,
    border-color .2s ease 0.2s;
}
#header.header.new-header.is-open .gnb_wrap #gnb > li:hover > ul,
#header.header.new-header.is-open .gnb_wrap #gnb > li:focus-within > ul{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.gnb_wrap #gnb > li a{
  display: flex;
  align-items: center;
  justify-content: center;
  color: #303030;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 100%; /* 16px */
  letter-spacing: -0.64px;
  text-align: center;
}

.m_gnb{
  display: none;
}
/* HEADER 수정 0923 */
#header.header.new-header:hover,
#header.header.new-header:focus-within{
  /* max-height: calc(var(--header-h) + var(--submenu-h)); */
  /* box-shadow: 0 8px 20px rgba(0,0,0,.06); */
}
#header.header.new-header:hover .gnb__bg,
#header.header.new-header:focus-within .gnb__bg{
  /* transform: scaleY(1);
  opacity: 1; */
}
#header.header.new-header:hover .gnb_wrap #gnb > li > ul,
#header.header.new-header:focus-within .gnb_wrap #gnb > li > ul{
  /* opacity: 1;
  transform: translateY(0);
  pointer-events: auto; */
}

@media (max-width:960px) {
  .m_gnb{
  display: flex;
}
.sitemap{
  /* display: flex; */
}
.gnb_wrap{
  display: none;
}
#header.header.new-header > nav{
  height: 8rem;
  padding: 0 2rem;
}
.header .util {
  display: none;
}
#header.header.new-header{ max-height: var(--header-h); box-shadow:none;overflow: hidden; }
}
/* @media (max-width:768px) */

/* 모바일 메뉴 */
.sitemap{
  width: 100vw;
  height: 120vh;
  position: fixed;
  top: 0;
  z-index: 9999  ;
  background: rgba(0,0,0,.3);
  display: none;
  flex-flow: row-reverse;
}
.sitemap__bg{
  width: 20vw;
  background: rgba(0,0,0,.3);
  height: 120vh;

}
.sitemap_menu_m{
    width: 80vw;
    height: 120vh;
    background: var(--colorfff);
    padding: 2rem;
    display: flex;
    flex-direction: column;
    gap: 4rem;
}
.menu_top_m .menu_left{
  display: flex;
  gap: 2rem;
}
.menu_top_m .menu_left a{
  color: var(--color303030);
  font-size: 16px;
  font-weight: 600;
  line-height: 100%; /* 16px */
  letter-spacing: -0.64px;
}
.menu_inner{
      display: flex;
    flex-direction: column;
    gap: 4rem;
}

/* 모바일 아코디언 기본 레이아웃 */
.menu_box_m { display: grid; gap: 10px;}

/* 트리거 버튼(지금은 a)을 버튼처럼 보이게 */
.menu_tit_m {
  display:flex; align-items:center; justify-content:space-between;
  width:100%;
  padding:16px 14px;
  background:#fff; color:#303030; text-decoration:none;
  font-size:16px; font-weight:600; letter-spacing:-0.02em;
  transition: border-color .15s ease, background-color .15s ease;
}
.menu_tit_m:hover { background:#F9FAFB; border-color:#EEE; }

/* 우측 화살표 (CSS로 생성) */
.menu_tit_m::after{
  content:"";
  width:10px; height:10px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform: rotate(45deg);
  transition: transform .2s ease;
}

/* 패널: grid-rows 아코디언 */
.menu_list_m{
  display:grid !important;
  grid-template-rows: 0fr;          /* 닫힘 */
  transition: grid-template-rows .26s ease;
}
.menu_list_m > ul{
  overflow:hidden;                  /* 내용 잘림 방지 */
  padding: 0 6px;                   /* 좌우 살짝 여백 */
}

/* 열림 상태 */
.menu_box_m > li.is-open .menu_list_m{
  grid-template-rows: 1fr;      
}
.menu_box_m > li.is-open .menu_tit_m{
  color: var(--colotEE6811);

}
.menu_box_m > li.is-open .menu_tit_m::after{
  transform: rotate(-135deg);    
  color: var(--colotEE6811);
}

/* 패널 안 리스트 스타일 */
.menu_list_m li a{
  display:block;
  padding:12px 10px;
  border-radius:10px;
  color:#303030; font-size:15px; letter-spacing:-0.02em;
  text-decoration:none;
}
/* .menu_list_m li a:hover{ background:#F3F4F6; } */

.sitemap.is-open { display: flex; }
body.no-scroll { overflow: hidden; }


/* ===== Mobile accordion override (FINAL) ===== */
@media (max-width:960px){

  .sitemap .menu_box_m .menu_list_m{
    display: grid !important;
    grid-template-rows: 0fr;
    overflow: hidden;
    transition: grid-template-rows .26s ease;
    padding: 0; 
  }
  .sitemap .menu_box_m .menu_list_m > ul{
    overflow: hidden;
    padding: 0 6px 8px;
    margin: 0;
  }
  /* 열림 상태: 부모 li.is-open */
  .sitemap .menu_box_m > li.is-open > .menu_list_m{
    grid-template-rows: 1fr;
  }

  /* 메뉴 오버레이 열림 */
  .sitemap.is-open{ display: flex !important; }
  body.no-scroll{ overflow: hidden; }
}




/* 헤더 투명 */

#header.header.new-header#header.header.new-header--transparent{
    background: none;
    position: absolute;
    top: 0;
    z-index: 100;
    width: 100%;
    border-bottom: 0;
}
#header.header.new-header#header.header.new-header--transparent:hover{
  background: var(--colorfff) !important;
}
#header.header.new-header#header.header.new-header--transparent:hover .svg_logo-wh{
  display: none;
}
#header.header.new-header#header.header.new-header--transparent .svg_logo img{
  content: url('/img/house/logo-wh.svg') !important;
}
#header.header.new-header#header.header.new-header--transparent:hover .svg_logo img{
  content: url('/img/house/logo.svg') !important;
}
#header.header.new-header--transparent .gnb_wrap .depth1_title.depth_01{
  color: #FFF !important;
}
#header.header.new-header--transparent:hover .gnb_wrap .depth1_title.depth_01{
  color: var(--color303030) !important;
}
#header.header.new-header--transparent:hover .gnb_wrap .depth_01 span{
  color: var(--color303030);
}
#header.header.new-header#header.header.new-header--transparent:hover .gnb_wrap .depth_01 span:hover{
  color: var(--colotEE6811);
}
#header.header.new-header--transparent .sns-instar img
#header.header.new-header--transparent .sns-youtube img
#header.header.new-header--transparent .sns-blog img
#header.header.new-header--transparent .icon__add__user img{
  content: url("/img/house/user-profile-add-01.svg");
}
r#header.header.new-header--transparent .icon__mypage img{
  content: url('/img/house/user-profile-02.svg');
}
#header.header.new-header#header.header.new-header--transparent:hover .icon__add__user img{
  content: url("/img/house/user-profile-add-01.png");
}
#header.header.new-header#header.header.new-header--transparent:hover .icon__mypage img{
  content: url('/img/house/user-profile-02.png');
}

#header.header.new-header#header.header.new-header--transparent:hover .icon__add__user svg path {
  fill: #000;
}
#header.header.new-header#header.header.new-header--transparent .icon__add__user svg path {
  fill: #fff;
}
#header.header.new-header#header.header.new-header--transparent:hover .icon__mypage svg path {
  stroke: #000;
}

/* .sns-instar , .sns-youtube , .sns-blog {
  opacity: 1;
}
#header.header.new-header:hover .sns-instar , #header.header.new-header:hover .sns-youtube , #header.header.new-header:hover .sns-blog {
  opacity: 1;
} */
.home__wrap #header.header .sns_area a img{
  filter: brightness(0) saturate(100%) invert(1);
}
#header.header .sns_area a img{
  filter: brightness(0) saturate(100%) invert(0.2);
}

#header.header.is-open .sns_area a img{
  filter: brightness(0) saturate(100%) invert(0.2);
}

/* 메인 헤더 */
.home__wrap #header.header{
  background: none;
  position: absolute;
  top: 0;
  z-index: 100;
  width: 100%;
  border-bottom: 0;
}
.home__wrap #header.header:hover{
  background: var(--colorfff) !important;
}
.home__wrap #header.header .btnWrap .textBtn svg path {
  stroke: #fff !important;
}
.home__wrap #header.header:hover .btnWrap .textBtn svg path {
  stroke: #000 !important;
}
.home__wrap #header.header:hover .icon__add__user svg path {
  fill: #000 !important;
}
.home__wrap #header.header .icon__add__user svg path {
  fill: #fff !important;
}
.home__wrap #header.header .gnb_wrap .depth1_title.depth_01{
  color: #FFF !important;
}
.home__wrap #header.header:hover .gnb_wrap .depth1_title.depth_01{
  color: var(--color303030) !important;
}
.home__wrap #header.header .logo_area .logo img{
  width: 100%;
  content: url('/img/house/logo-wh.svg') !important;
}
.home__wrap #header.header:hover .logo_area .logo img{
  content: url('/img/house/logo.svg') !important;
}
.home__wrap #header.header .m_menu .top_sitemap svg line{ 
   stroke: #FFF !important;
}
.home__wrap #header.header:hover .m_menu .top_sitemap.on svg line{ 
  stroke: #303030 !important;
}
.home__wrap #header.header:hover .sitemap_menu_m .logo_area .logo img{
  content: url('/img/house/logo.svg') !important;
}

/* ===================== Mega Dropdown – CSS only patch ===================== */

/* 0) 배경이 이벤트 가로채지 않게 */
#header.header.new-header .gnb__bg { pointer-events: none !important; }

/* 1) 기존: 헤더 hover 시 전체 보이지만 pointer-events 문제/깜박임 유발 → 무력화 */
#header.header.new-header:hover .gnb_wrap #gnb > li > ul {
  opacity: 0 !important;
  transform: translateY(-8px) !important;
  pointer-events: none !important;
  border-right-color: transparent !important;
}

/* 2) 메가드롭: 헤더가 열렸으면(=is-open) 전체 컬럼 동시 노출 + 인터랙션 허용 */
#header.header.new-header.is-open .gnb_wrap #gnb > li > ul {
  display: block !important;        /* display 토글 금지 */
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) !important;
  pointer-events: auto !important;
  border-right-color: #EAEAEA !important;
}

/* 3) 레이아웃 안정: 잘리지 않게 & 위계 정리 */
#header.header.new-header,
#header.header.new-header nav,
#header.header.new-header .gnb_wrap,
#header.header.new-header .gnb_inner,
#header.header.new-header #gnb {
  overflow: visible !important;
  z-index: 999;
}
#header.header.new-header .gnb__bg { z-index: 1; } /* 서브 뒤 배경 */

/* 4) 각 컬럼(=li) 기준점 & 간극 브리지(커서 이동 중 끊김 방지) */
#gnb > li { position: relative; }
#gnb > li::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 100%;
  height: 12px;               /* 8~16px 사이로 조절해도 됨 */
  pointer-events: none;       /* 브리지는 시각적 간극만 메움 */
}

/* 5) 서브 위치: 현 구조 유지(top: var(--header-h)) 그대로 쓰되, 인터랙션만 보장 */
.gnb_wrap #gnb > li > ul {
  position: absolute;
  top: var(--header-h);
  /* left 값은 현 구조에서 각 li의 '정적 위치'를 따라가므로 생략 유지 */
  opacity: 0;                 /* 기본은 닫힘 */
  transform: translateY(-8px);
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
  z-index: 2;
}

/* 6) 헤더 열림 시 전체 컬럼 펼침(중복 보강) */
#header.header.new-header.is-open .gnb_wrap #gnb > li > ul {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}


