/*title*/
.cnt-txt { z-index:2; position: relative; width: 100%; height: 100%; text-align: center; display: flex; align-items: center; justify-content: center; padding: 20px 0 0; }
.cnt-txt>p { color:#000000; }
.cnt-txt>p b { display: block; font-size: 35px; margin: 30px 0; margin-top:0; opacity:0.4; font-weight: 400; }
.cnt-txt>p strong { display: block; font-size: 54px; margin-bottom:30px; margin-top: 0; text-shadow: 0 2px 8px black; color:#fff }
.cnt-txt>p span { font-size: 35px; display: block; margin-top: 0; opacity:0.8; font-weight: 400; }
.h-tit { font-size:5rem; margin:30px 0 20px 0; font-weight: 600; }

/* breadcrumb */
.krds-breadcrumb-wrap .breadcrumb li { font-size:15px; }
.krds-breadcrumb-wrap .breadcrumb li a.txt { font-size:15px; }

/*개인정보 처리방침*/
.head-tit { font-size:2.5rem; font-weight: 600; }
.txt_box { border-color: var(--krds-light-color-border-secondary-light); background-color: var(--krds-light-color-surface-secondary-subtler); display: flex; align-items: flex-start; justify-content: flex-start; flex-direction: column; gap: var(--krds-gap-5); --txt-box-width-border: var(--krds-light-border-width-static-regular); --txt-box-color-border: var(--krds-light-color-border-gray); --txt-box-color-background: var(--krds-light-color-surface-gray-subtler); padding: var(--krds-pc-padding-card-large); border: var(--txt-box-width-border) solid var(--txt-box-color-border); border-radius: var(--krds-radius-xlarge1); }
.out-line-tit { display: flex; align-items: center; justify-content: flex-start; flex-direction: row; gap: var(--krds-gap-2); font-size: var(--krds-pc-font-size-heading-medium); font-weight: var(--krds-font-weight-bold); }
.txt_box ol li { margin-bottom:10px; }
.txt_box p { color:#525252 }

/* 반응형 */
*, *::before, *::after { box-sizing: border-box; }

.cnt-title { min-height: 100svh; }

/* ----- Tablet (<= 1024px) ----- */
@media (max-width: 1024px) { header { height: 88px; }
  .menu-wrap { height: 88px; }

  .logo { left: 20px; width: 160px; }
  .logo > img { height: 54px; }

  .menu > li a { font-size: 18px; margin: 0 16px; }
  .menu-right { right: 24px; }
}

/* ----- Mobile (<= 768px) ----- */
@media (max-width: 768px) { header { height: 64px; }
  .menu-wrap { height: 64px; }

  .logo { left: 16px; width: 140px; top: 50%; }
  .logo > img { height: 40px; }

  .menu-right { right: 12px; }
  .gnb-btn-box { width: 44px; height: 44px; }

  .menu { display: none; }

  .menu-wrap nav { position: fixed; left: 0; right: 0; top: 64px; background: #fff; max-height: calc(100svh - 64px); overflow: auto; display: none; box-shadow: 0 10px 24px rgba(0,0,0,.12); z-index: 30; }

  .menu-wrap.is-open nav { display: block; }
  .menu-wrap.is-open .menu { display: block; width: 100%; }

  .menu > li { display: block; }
  .menu > li a { display: block; margin: 0; padding: 14px 16px; font-size: 18px; text-align: left; }

  .menu > li:hover .submenu { display: none; }
  .submenu { position: static; left: auto; top: auto; transform: none; display: none; opacity: 1; background: #f3f8ff; border-radius: 0; box-shadow: none; padding: 6px 0; }
  .menu > li.is-open .submenu { display: block; }

  .submenu > li { padding: 0; }
  .submenu > li > a { padding: 10px 16px; font-size: 15px; }

  footer { width: 100%; margin: 0; padding: 16px 16px; height: auto; }
  footer > div { width: 100%; max-width: 1400px; margin: 0 auto; }
  footer span { padding: 0 8px; }
  .footer_txt, footer ul>li { font-size: 13px; }
}


/*all-menu*/
header .all_menu { position: fixed; inset: 0; width: 100%; height: 100svh; z-index: 9999; background: #fff; color: #111; opacity: 0; visibility: hidden; pointer-events: none; transform: translateY(-10px); transition: opacity .25s ease, transform .25s ease, visibility 0s linear .25s; }

header .allmenu_top { position: fixed; top: 0; left: 0; width: 100%;
  height: 90px; padding: 0 40px;
  display: flex; align-items: center; justify-content: space-between;
  background: #fff; z-index: 10001;
  border-bottom: 1px solid #eee; backdrop-filter: blur(6px); }

header .allmenu_logo img { height: 70px; display: block; }

body.is-all-open header .all_menu { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); transition: opacity .25s ease, transform .25s ease, visibility 0s; }

header .all_menu_inner { width: min(1240px, calc(100% - 64px)); margin: 0 auto; height: 100%; padding: 140px 0 60px; box-sizing: border-box; overflow: auto; }
header .allmenu-close { position: static; width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 0; background: transparent; padding: 0; cursor: pointer; }

header .allmenu-close.gnb-btn { width: 34px; height: 22px; position:static; }

header .all_menu .allmenu-close.gnb-btn { background-size: 0 2px; }
header .all_menu .allmenu-close.gnb-btn::before { top: 10px; transform: rotate(45deg); }
header .all_menu .allmenu-close.gnb-btn::after { top: 10px; transform: rotate(-45deg); }

header .allmenu-close:hover { background: #f7f7f7; }

/* 2단 레이아웃 */
header .allmenu_wrap { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 40px; align-items: start; }

/* LEFT */
header .sitemap_grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 34px 32px; }
header .sitemap_col { padding-top: 14px; border-top: 1px solid #eee; }
header .sitemap_tit { margin: 12px 0 16px; font-size: 32px; font-weight: 800; letter-spacing: -0.02em; color: #111; }
header .sitemap_col ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 15px; }
header .sitemap_col ul a { font-size: 18px; font-weight: 500; color: #444; text-decoration: none; line-height: 1.7; }
header .sitemap_col ul a:hover { color: #111; text-decoration: underline; text-underline-offset: 5px; }

/* RIGHT */
header .allmenu_aside_box { position: sticky; top: 110px; padding-left: 24px; border-left: 1px solid #eee; }
header .allmenu_brand_tit { display: block; font-size: 32px; font-weight: 800; color: #111; margin-bottom: 10px; }
header .allmenu_brand_desc { margin: 0 0 22px; font-size: 18px; line-height: 1.7; color: #555; }
header .allmenu_quick_tit { margin: 0 0 12px; font-size: 32px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: #111; }
header .allmenu_quick_list { margin: 0 0 22px; padding: 0; list-style: none; display: grid; gap: 15px; }
header .allmenu_quick_list a { color: #111; text-decoration: none; font-size: 18px; font-weight: 600; }
header .allmenu_quick_list a:hover { text-decoration: underline; text-underline-offset: 5px; }
header .allmenu_contact_dl { margin: 0; display: grid; gap: 15px; }
header .allmenu_contact_dl > div { display: grid; grid-template-columns: 60px 1fr; gap: 15px; }
header .allmenu_contact_dl dt { font-size: 18px; font-weight: 800; color: #111; }
header .allmenu_contact_dl dd { margin: 0; font-size: 18px; color: #555; }

header .gnb-btn { position: relative; width: 34px; height: 22px; display: inline-block; }

header .gnb-btn::before,
header .gnb-btn::after { content: ""; position: absolute; left: 0; width: 100%; height: 2px; background: #111; transition: transform .25s ease, top .25s ease, opacity .2s ease; }

header .gnb-btn::before { top: 0; }
header .gnb-btn::after { top: 20px; }

header .gnb-btn { background:
        linear-gradient(#111,#111) 0 50% / 100% 2px no-repeat; transition: background-size .2s ease, background-position .2s ease; }

body.is-all-open header .gnb-btn { background-size: 0 2px; }
body.is-all-open header .gnb-btn::before { top: 10px; transform: rotate(45deg); }
body.is-all-open header .gnb-btn::after { top: 10px; transform: rotate(-45deg); }

header .gnb-btn-box { cursor: pointer; }


/* 메뉴 애니메이션 */

header .sitemap_col,
header .allmenu_aside_box { opacity: 0; transform: translateY(14px); transition: opacity .35s ease, transform .35s ease; will-change: opacity, transform; }

body.is-all-open header .sitemap_col,
body.is-all-open header .allmenu_aside_box { opacity: 1; transform: translateY(0); }


body.is-all-open header .sitemap_col:nth-child(1) { transition-delay: .04s; }
body.is-all-open header .sitemap_col:nth-child(2) { transition-delay: .08s; }
body.is-all-open header .sitemap_col:nth-child(3) { transition-delay: .12s; }
body.is-all-open header .sitemap_col:nth-child(4) { transition-delay: .16s; }
body.is-all-open header .sitemap_col:nth-child(5) { transition-delay: .20s; }
body.is-all-open header .sitemap_col:nth-child(6) { transition-delay: .24s; }

body.is-all-open header .allmenu_aside_box { transition-delay: .18s; }

header .sitemap_tit { position: relative; }

header .sitemap_col ul a,
header .allmenu_quick_list a { position: relative; display: inline-block; padding-bottom: 2px; }

header .sitemap_col ul a::after,
header .allmenu_quick_list a::after { content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 2px; background: #111;
  transform: scaleX(0); transform-origin: left; transition: transform .25s ease; opacity: .85; }

header .sitemap_col ul a:hover::after,
header .allmenu_quick_list a:hover::after { transform: scaleX(1); }

header .sitemap_col ul a:hover,
header .allmenu_quick_list a:hover { color: #111; }

/* 반응형 */
@media (max-width: 1100px) { header .allmenu_wrap { grid-template-columns: 1fr; }
  header .allmenu_aside_box { position: static; top: auto; padding-left: 0; border-left: 0; border-top: 1px solid #eee; padding-top: 22px; }
  header .sitemap_grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) { header .all_menu_inner { width: calc(100% - 32px); padding: 92px 0 40px; }
  header .allmenu_logo img { height:40px; }
  header .sitemap_grid { grid-template-columns: 1fr; }
  header .sitemap_tit { font-size: 32px; }
}

@media (max-width: 480px){
  .menu > li a { font-size: 16px; padding: 12px 14px; }
  .submenu > li > a { padding: 10px 14px; }
  .logo { width: 120px; }
}


/* ---- Tablet (<= 1024px) ---- */
@media (max-width: 1024px) { header .allmenu_top { height: 76px; padding: 0 20px; }
  header .allmenu_logo img { height: 44px; }

  header .all_menu_inner { width: calc(100% - 40px); padding: 110px 0 40px; }

  header .allmenu_wrap { grid-template-columns: minmax(0, 1fr) 280px; gap: 28px; }
  header .sitemap_grid { gap: 24px 22px; }

  header .sitemap_tit { font-size: 26px; }
  header .sitemap_col ul a { font-size: 16px; gap: 12px; }

  header .allmenu_brand_tit { font-size: 22px; }
  header .allmenu_brand_desc { font-size: 15px; }
  header .allmenu_quick_tit { font-size: 16px; }
  header .allmenu_quick_list a { font-size: 15px; }
  header .allmenu_contact_dl dt,
  header .allmenu_contact_dl dd { font-size: 15px; }

  header .allmenu_aside_box { top: 96px; }
}

/* ---- Mobile (<= 768px) ---- */
@media (max-width: 768px) { header .allmenu_top { height: 64px; padding: 0 16px; }
  header .allmenu_logo img { height: 34px; }

  header .allmenu-close { width: 44px; height: 44px; }
  header .allmenu-close.gnb-btn { width: 28px; height: 18px; }

  header .all_menu_inner { width: calc(100% - 32px); padding: 96px 0 32px; }

  header .allmenu_wrap { grid-template-columns: 1fr; gap: 22px; }

  /* sitemap grid: 2열 -> 1열 */
  header .sitemap_grid { grid-template-columns: 1fr; gap: 20px; }

  header .sitemap_col { padding-top: 12px; }

  header .sitemap_tit { font-size: 22px; margin: 10px 0 12px; }
  header .sitemap_col ul { gap: 10px; }
  header .sitemap_col ul a { font-size: 15px; line-height: 1.6; }

  header .allmenu_aside_box { position: static; top: auto; padding-left: 0; border-left: 0; border-top: 1px solid #eee; padding-top: 18px; }

  header .allmenu_brand_tit { font-size: 18px; }
  header .allmenu_brand_desc { font-size: 14px; margin-bottom: 16px; }
  header .allmenu_quick_tit { font-size: 14px; }
  header .allmenu_quick_list { gap: 10px; }
  header .allmenu_quick_list a { font-size: 14px; }
  header .allmenu_contact_dl { gap: 10px; }
  header .allmenu_contact_dl > div { grid-template-columns: 52px 1fr; gap: 10px; }
  header .allmenu_contact_dl dt,
  header .allmenu_contact_dl dd { font-size: 14px; }

  footer .inner { position: relative; }

  .inc_down { position: static !important; inset: auto !important; margin-top: 18px; width: 100%; }

  .inc_down_btn { width: 100%; min-width: 0; min-height: 52px; padding: 12px 16px; border-radius: 14px; font-size: 14px; line-height: 1.35; box-shadow: none; flex-direction:row; justify-content: left; }
  .inc_down_btn:before { margin:0; margin-right:15px; }
}

/* ---- Small Mobile (<= 480px) ---- */
@media (max-width: 480px) { header .allmenu_top { padding: 0 12px; }
  header .allmenu_logo img { height: 30px; }

  header .all_menu_inner { padding: 90px 0 28px; }

  header .sitemap_tit { font-size: 20px; }
  header .sitemap_col ul a { font-size: 14px; }

  .inc_down { margin-top: 14px; }

  .inc_down_btn { min-height: 48px; padding: 11px 14px; border-radius: 12px; font-size: 13px; }
}
