/* =========================
   KBEAUTYODM HEADER - FINAL FIX
========================= */

/* ===== basic ===== */
html, body{
  margin:0 !important;
  padding:0 !important;
}

body{
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  padding-top:86px !important; /* fixed header height */
}

/* 페이지 타이틀 숨김 */
#container_title{
  display:none !important;
  height:0 !important;
  margin:0 !important;
  padding:0 !important;
  overflow:hidden !important;
  font-size:0 !important;
  line-height:0 !important;
}

/* 상단 붙는 현상/여백 꼬임 최소화 */
#container_wr,
#container,
#contents_wrap,
.shop-content{
  margin-top:0 !important;
  padding-top:0 !important;
}

/* ===== reset ===== */
.kbodm-header,
.kbodm-header *,
.kbodm-mobile-dim,
.kbodm-mobile-drawer,
.kbodm-mobile-drawer *{
  box-sizing:border-box;
  font-family:'Inter', sans-serif !important;
  letter-spacing:0 !important;
}

.kbodm-header ul,
.kbodm-header li,
.kbodm-mobile-drawer ul,
.kbodm-mobile-drawer li{
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
}

.kbodm-header a,
.kbodm-header button,
.kbodm-mobile-drawer a,
.kbodm-mobile-drawer button{
  text-decoration:none !important;
  border:0;
  outline:none;
  background:none;
}

/* ===== header fixed ===== */
.kbodm-header{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  z-index:99999 !important;
  width:100% !important;
  background:#fff !important;
  border-bottom:1px solid #ececec !important;
}

.kbodm-header__inner{
  position:relative !important;
  max-width:1280px !important;
  margin:0 auto !important;
  padding:0 28px !important;
  height:86px !important;
  min-height:86px !important;

  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
}

/* ===== logo ===== */
.kbodm-header__logo{
  position:relative !important;
  z-index:3 !important;
  flex:0 0 auto !important;
  margin:0 !important;
  display:flex !important;
  align-items:center !important;
}

.kbodm-header__logo a{
  display:flex !important;
  align-items:center !important;
  height:86px !important;
}

.kbodm-header__logo img{
  display:block !important;
  width:auto !important;
  height:26px !important;
  max-height:26px !important;
}

/* ===== centered nav ===== */
.kbodm-header__nav--pc{
  position:absolute !important;
  left:50% !important;
  top:50% !important;
  transform:translate(-50%, -50%) !important;
  z-index:2 !important;

  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:max-content !important;
}

.kbodm-header__menu{
  display:flex !important;
  align-items:center !important;
  gap:26px !important;
}

.kbodm-header__item{
  display:flex !important;
  align-items:center !important;
}

.kbodm-header__link{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  height:34px !important;
  padding:0 15px !important;
  border-radius:999px !important;
  background:transparent !important;
  color:#111 !important;
  font-size:15px !important;
  font-weight:700 !important;
  line-height:1 !important;
  white-space:nowrap !important;
  transition:background .18s ease, color .18s ease !important;
}

.kbodm-header__link:hover,
.kbodm-header__link:focus,
.kbodm-header__link.is-current{
  background:#efefef !important;
  color:#111 !important;
}

/* ===== actions ===== */
.kbodm-header__actions--pc{
  position:relative !important;
  z-index:3 !important;
  flex:0 0 auto !important;
  margin-left:auto !important;

  display:flex !important;
  align-items:center !important;
  gap:10px !important;
}

.kbodm-btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  height:40px !important;
  padding:0 20px !important;
  border-radius:999px !important;
  font-size:14px !important;
  font-weight:700 !important;
  line-height:1 !important;
  letter-spacing:0 !important;
  white-space:nowrap !important;
  transition:all .18s ease !important;
}

.kbodm-btn--dark{
  min-width:168px !important;
  background:#111 !important;
  color:#fff !important;
  border:1px solid #111 !important;
}

.kbodm-btn--dark:hover{
  background:#000 !important;
  border-color:#000 !important;
  color:#fff !important;
}

.kbodm-btn--line{
  min-width:78px !important;
  background:#fff !important;
  color:#111 !important;
  border:1px solid #111 !important;
}

.kbodm-btn--line:hover{
  background:#f7f7f7 !important;
  color:#111 !important;
}

/* ===== mobile toggle ===== */
.kbodm-header__toggle{
  display:none !important;
  width:42px !important;
  height:42px !important;
  padding:0 !important;
  background:transparent !important;
  cursor:pointer !important;
}

.kbodm-header__toggle span{
  display:block !important;
  width:22px !important;
  height:2px !important;
  margin:5px auto !important;
  background:#111 !important;
}

/* ===== mobile dim ===== */
.kbodm-mobile-dim{
  position:fixed !important;
  inset:0 !important;
  background:rgba(0,0,0,.35) !important;
  opacity:0 !important;
  visibility:hidden !important;
  transition:all .25s ease !important;
  z-index:99997 !important;
}

/* ===== mobile drawer ===== */
.kbodm-mobile-drawer{
  position:fixed !important;
  top:0 !important;
  right:0 !important;
  width:88% !important;
  max-width:420px !important;
  height:100vh !important;
  background:#fff !important;
  transform:translateX(100%) !important;
  transition:transform .3s ease !important;
  z-index:99998 !important;
  overflow-y:auto !important;
  padding:22px 20px 34px !important;
}

.kbodm-mobile-drawer__head{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  padding-bottom:18px !important;
  border-bottom:1px solid #ececec !important;
}

.kbodm-mobile-drawer__head strong{
  font-size:14px !important;
  font-weight:700 !important;
  color:#111 !important;
}

.kbodm-mobile-drawer__close{
  width:34px !important;
  height:34px !important;
  background:transparent !important;
  position:relative !important;
  padding:0 !important;
  cursor:pointer !important;
}

.kbodm-mobile-drawer__close span{
  position:absolute !important;
  top:50% !important;
  left:50% !important;
  width:22px !important;
  height:2px !important;
  background:#111 !important;
}

.kbodm-mobile-drawer__close span:first-child{
  transform:translate(-50%,-50%) rotate(45deg) !important;
}

.kbodm-mobile-drawer__close span:last-child{
  transform:translate(-50%,-50%) rotate(-45deg) !important;
}

.kbodm-mobile-nav{
  padding-top:14px !important;
}

.kbodm-mobile-nav__menu > li{
  border-bottom:1px solid #f0f0f0 !important;
}

.kbodm-mobile-nav__menu > li > a{
  display:block !important;
  padding:18px 0 !important;
  font-size:16px !important;
  font-weight:700 !important;
  color:#111 !important;
}

body.kbodm-menu-open .kbodm-mobile-dim{
  opacity:1 !important;
  visibility:visible !important;
}

body.kbodm-menu-open .kbodm-mobile-drawer{
  transform:translateX(0) !important;
}

/* ===== tablet / mobile ===== */
@media (max-width:1024px){
  body{
    padding-top:64px !important;
  }

  .kbodm-header__inner{
    height:64px !important;
    min-height:64px !important;
    padding:0 16px !important;
  }

  .kbodm-header__logo a{
    height:64px !important;
  }

  .kbodm-header__logo img{
    height:26px !important;
    max-height:26px !important;
  }

  .kbodm-header__nav--pc,
  .kbodm-header__actions--pc{
    display:none !important;
  }

  .kbodm-header__toggle{
    display:block !important;
    margin-left:auto !important;
  }
}

/* =========================
   PC MEGA MENU - FIXED FULL WIDTH
========================= */

.kbodm-header__item--ouritems{
  position:relative !important;
}

.kbodm-mega{
  position:absolute !important;
  top:100% !important;
  left:0 !important;
  width:100% !important;
  background:#fff !important;
  border-top:1px solid #ececec !important;
  border-bottom:1px solid #ececec !important;
  box-shadow:0 18px 40px rgba(0,0,0,.04) !important;
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
  transform:translateY(8px) !important;
  transition:opacity .2s ease, transform .2s ease, visibility .2s ease !important;
  z-index:20 !important;
}

.kbodm-header:hover .kbodm-mega,
.kbodm-header__item--ouritems:hover ~ .kbodm-mega,
.kbodm-header__item--ouritems:hover .kbodm-mega,
.kbodm-header__item--ouritems:focus-within ~ .kbodm-mega,
.kbodm-header__item--ouritems.is-open ~ .kbodm-mega,
.kbodm-mega:hover{
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transform:translateY(0) !important;
}

.kbodm-header__item--ouritems:hover + .kbodm-mega{
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transform:translateY(0) !important;
}

.kbodm-mega__inner{
  max-width:1280px !important;
  margin:0 auto !important;
  padding:34px 28px 36px !important;
  display:grid !important;
  grid-template-columns:240px 1fr !important;
  gap:52px !important;
}

.kbodm-mega__side{
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
}

.kbodm-mega__tab{
  width:100% !important;
  min-height:54px !important;
  padding:0 22px !important;
  border-radius:16px !important;
  border:0 !important;
  background:transparent !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  cursor:pointer !important;
}

.kbodm-mega__tab span{
  color:#979797 !important;
  font-size:18px !important;
  font-weight:700 !important;
}

.kbodm-mega__tab em{
  font-style:normal !important;
  font-size:28px !important;
  color:#111 !important;
  opacity:0 !important;
  transform:translateX(-6px) !important;
  transition:all .18s ease !important;
}

.kbodm-mega__tab.is-active,
.kbodm-mega__tab:hover{
  background:#f3f3f3 !important;
}

.kbodm-mega__tab.is-active span,
.kbodm-mega__tab:hover span{
  color:#111 !important;
}

.kbodm-mega__tab.is-active em,
.kbodm-mega__tab:hover em{
  opacity:1 !important;
  transform:translateX(0) !important;
}

.kbodm-mega__panel{
  display:none !important;
}

.kbodm-mega__panel.is-active{
  display:block !important;
}

.kbodm-mega__cols{
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:30px 42px !important;
}

.kbodm-mega__group h4{
  margin:0 0 14px !important;
  color:#111 !important;
  font-size:18px !important;
  font-weight:700 !important;
  line-height:1.3 !important;
}

.kbodm-mega__group ul{
  display:flex !important;
  flex-direction:column !important;
  gap:11px !important;
}

.kbodm-mega__group a{
  display:block !important;
  color:#9a9a9a !important;
  font-size:15px !important;
  font-weight:500 !important;
  line-height:1.45 !important;
}

.kbodm-mega__group a:hover{
  color:#111 !important;
}

/* mega 숨김 유지용 */
.kbodm-header:not(.is-mega-open) .kbodm-mega{
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
  transform:translateY(8px) !important;
}

.kbodm-header.is-mega-open .kbodm-mega{
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  transform:translateY(0) !important;
}

@media (max-width:1024px){
  .kbodm-mega{
    display:none !important;
  }
}

/* =========================
   MOBILE OUR ITEMS ACCORDION
========================= */

.kbodm-mobile-nav__has-sub{
  border-bottom:1px solid #f0f0f0 !important;
}

.kbodm-mobile-nav__row{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:10px !important;
}

.kbodm-mobile-nav__main{
  flex:1 1 auto !important;
  display:block !important;
  padding:18px 0 !important;
  font-size:16px !important;
  font-weight:700 !important;
  color:#111 !important;
}

.kbodm-mobile-nav__arrow{
  flex:0 0 36px !important;
  width:36px !important;
  height:36px !important;
  border:0 !important;
  background:transparent !important;
  color:#111 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  cursor:pointer !important;
}

.kbodm-mobile-nav__arrow i{
  font-size:18px !important;
  transition:transform .18s ease !important;
}

.kbodm-mobile-nav__has-sub.is-open .kbodm-mobile-nav__arrow i{
  transform:rotate(180deg) !important;
}

.kbodm-mobile-sub{
  display:none !important;
  padding:2px 0 14px !important;
}

.kbodm-mobile-nav__has-sub.is-open .kbodm-mobile-sub{
  display:block !important;
}

.kbodm-mobile-sub__tab{
  width:100% !important;
  text-align:left !important;
  padding:12px 0 !important;
  border:0 !important;
  background:transparent !important;
  color:#111 !important;
  font-size:14px !important;
  font-weight:700 !important;
  cursor:pointer !important;
}

.kbodm-mobile-sub__panel{
  display:none !important;
  padding:0 0 6px 0 !important;
}

.kbodm-mobile-sub__panel.is-active{
  display:block !important;
}

.kbodm-mobile-sub__panel ul{
  display:flex !important;
  flex-direction:column !important;
  gap:8px !important;
}

.kbodm-mobile-sub__panel li{
  border:0 !important;
}

.kbodm-mobile-sub__panel a{
  display:block !important;
  padding:0 0 0 10px !important;
  color:#7f7f7f !important;
  font-size:13px !important;
  font-weight:500 !important;
  line-height:1.45 !important;
}

/* =========================
   MOBILE ARROW FIX
========================= */

.kbodm-mobile-nav__arrow{
  flex:0 0 36px !important;
  width:36px !important;
  height:36px !important;
  border:0 !important;
  background:transparent !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  cursor:pointer !important;
  padding:0 !important;
}

.kbodm-mobile-nav__arrow span,
.kbodm-mobile-subcat__head span{
  display:block !important;
  width:9px !important;
  height:9px !important;
  border-right:1.5px solid #111 !important;
  border-bottom:1.5px solid #111 !important;
  transform:rotate(45deg) !important;
  transition:transform .18s ease !important;
}

.kbodm-mobile-nav__has-sub.is-open .kbodm-mobile-nav__arrow span{
  transform:rotate(225deg) !important;
}

.kbodm-mobile-subcat{
  border-bottom:1px solid #f3f3f3 !important;
}

.kbodm-mobile-subcat__head{
  width:100% !important;
  padding:12px 0 !important;
  border:0 !important;
  background:transparent !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  cursor:pointer !important;
}

.kbodm-mobile-subcat__head strong{
  color:#111 !important;
  font-size:14px !important;
  font-weight:700 !important;
  line-height:1.4 !important;
}

.kbodm-mobile-subcat__body{
  display:none !important;
  padding:0 0 10px 0 !important;
}

.kbodm-mobile-subcat.is-open .kbodm-mobile-subcat__body{
  display:block !important;
}

.kbodm-mobile-subcat.is-open .kbodm-mobile-subcat__head span{
  transform:rotate(225deg) !important;
}

.kbodm-mobile-sub__panel ul{
  display:flex !important;
  flex-direction:column !important;
  gap:8px !important;
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
}

.kbodm-mobile-sub__panel li{
  border:0 !important;
}

.kbodm-mobile-sub__panel a{
  display:block !important;
  padding:0 0 0 10px !important;
  color:#7f7f7f !important;
  font-size:13px !important;
  font-weight:500 !important;
  line-height:1.45 !important;
}
/* =========================
   MOBILE MENU ARROW FIX
========================= */
.kbodm-mobile-nav__arrow{
  width:36px !important;
  height:36px !important;
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  cursor:pointer !important;
}

.kbodm-mobile-nav__arrow span{
  display:block !important;
  width:10px !important;
  height:10px !important;
  border-right:2px solid #111 !important;
  border-bottom:2px solid #111 !important;
  transform:rotate(45deg) translateY(-1px) !important;
  transition:transform .2s ease !important;
}

.kbodm-mobile-nav__has-sub.is-open .kbodm-mobile-nav__arrow span{
  transform:rotate(225deg) translateY(-1px) !important;
}
/* =========================
   MOBILE OUR ITEMS 2DEPTH ACCORDION UPGRADE
========================= */
@media (max-width:1024px){

  .kbodm-mobile-sub{
    padding:6px 0 14px !important;
  }

  .kbodm-mobile-sub__tab{
    position:relative !important;
    width:100% !important;
    padding:14px 0 !important;
    font-size:14px !important;
    font-weight:700 !important;
    color:#111 !important;
    border-bottom:1px solid #ededed !important;
  }

  .kbodm-mobile-sub__tab.is-active{
    color:#111 !important;
  }

  .kbodm-mobile-sub__panel{
    padding:8px 0 10px !important;
  }

  .kbodm-mobile-subcat{
    border-bottom:1px solid #f1f1f1 !important;
  }

  .kbodm-mobile-subcat:first-child{
    border-top:0 !important;
  }

  .kbodm-mobile-subcat__head{
    width:100% !important;
    padding:14px 0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    background:transparent !important;
    border:0 !important;
    cursor:pointer !important;
  }

  .kbodm-mobile-subcat__head strong{
    display:block !important;
    color:#111 !important;
    font-size:14px !important;
    font-weight:600 !important;
    line-height:1.45 !important;
    letter-spacing:0 !important;
  }

  .kbodm-mobile-subcat__head span{
    flex:0 0 9px !important;
    width:9px !important;
    height:9px !important;
    border-right:1.5px solid #111 !important;
    border-bottom:1.5px solid #111 !important;
    transform:rotate(45deg) !important;
    transition:transform .2s ease !important;
    margin-right:2px !important;
  }

  .kbodm-mobile-subcat.is-open .kbodm-mobile-subcat__head span{
    transform:rotate(225deg) !important;
  }

  .kbodm-mobile-subcat__body{
    display:none !important;
    padding:0 0 12px 0 !important;
  }

  .kbodm-mobile-subcat.is-open .kbodm-mobile-subcat__body{
    display:block !important;
  }

  .kbodm-mobile-subcat__body ul{
    margin:0 !important;
    padding:0 0 0 12px !important;
    display:flex !important;
    flex-direction:column !important;
    gap:8px !important;
    list-style:none !important;
  }

  .kbodm-mobile-subcat__body li{
    margin:0 !important;
    padding:0 !important;
    border:0 !important;
  }

  .kbodm-mobile-subcat__body a{
    display:block !important;
    color:#7f7f7f !important;
    font-size:13px !important;
    font-weight:500 !important;
    line-height:1.5 !important;
    padding:0 !important;
  }

  .kbodm-mobile-subcat__body a:hover,
  .kbodm-mobile-subcat__body a:focus{
    color:#111 !important;
  }
}

/* =========================
   HEADER CTA FINAL OVERRIDE
========================= */

.kbodm-header .kbodm-btn--dark{
  background:#2b2422 !important;
  border-color:#2b2422 !important;
  color:#fff !important;
  border-radius:999px !important;
  height:40px !important;
  padding:0 22px !important;
  gap:8px !important;
  text-transform:none !important;
}

.kbodm-header .kbodm-btn--dark span{
  font-size:14px !important;
  font-weight:700 !important;
}

.kbodm-header .kbodm-btn--dark i{
  font-size:12px !important;
  transform:translateX(0);
  transition:transform .25s ease;
}

.kbodm-header .kbodm-btn--dark:hover{
  background:#111 !important;
  border-color:#111 !important;
  transform:translateY(-1px);
}

.kbodm-header .kbodm-btn--dark:hover i{
  transform:translateX(5px);
}

/* =========================
   FONT AWESOME FIX
========================= */
.fa,
.fas,
.far,
.fab,
.fa-solid,
.fa-regular,
.fa-brands,
[class^="fa-"],
[class*=" fa-"]{
  font-family:"Font Awesome 6 Free","Font Awesome 6 Brands" !important;
}