@charset "utf-8";

:root {
  --kuk-white: #fff;
  --kuk-black: #111;
  --kuk-ink: #222;
  --kuk-muted: #666;
  --kuk-light: #f6f6f6;
  --kuk-line: #e5e5e5;
  --kuk-orange: #f28c22;
  --kuk-orange-dark: #dd7410;
  --kuk-red: #d62222;
  --kuk-container: 1200px;
  --kuk-side: 300px;
  --kuk-gap: 20px;
  --kuk-font: "Noto Sans KR", "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
}

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

html { min-width: 320px; scroll-behavior: smooth; }
body {
  min-width: 320px;
  margin: 0;
  background: var(--kuk-white);
  color: var(--kuk-ink);
  font-family: var(--kuk-font);
  font-size: 15px;
  line-height: 1.55;
  letter-spacing: -0.03em;
  word-break: keep-all;
  overflow-wrap: anywhere;
}

main { width: 100%; padding: 16px 0 40px; }
article, aside, footer, header, main, nav, section { display: block; }
h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd, ul, ol { margin: 0; padding: 0; }
ul, ol { list-style: none; }
img, video, iframe { max-width: 100%; }
img { display: block; height: auto; border: 0; }
iframe { border: 0; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { border: 0; background: transparent; cursor: pointer; }
input, select, textarea { min-width: 0; }
:focus-visible { outline: 2px solid var(--kuk-orange); outline-offset: 3px; }

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.skip-link {
  position: absolute;
  left: 16px;
  top: -60px;
  z-index: 2000;
  padding: 10px 14px;
  background: var(--kuk-black);
  color: var(--kuk-white);
}
.skip-link:focus { top: 16px; }
.container, .inner, .wrap { width: min(calc(100% - 32px), var(--kuk-container)); margin-inline: auto; }

/* Layout editor grid */
.din {
  position: relative;
  clear: both;
  display: grid;
  width: min(100%, var(--kuk-container));
  max-width: 100%;
  margin: 0 auto;
  padding: 0;
  gap: var(--kuk-gap);
}
.din.din100 { width: 100%; }
.din > [data-dinnum], .ui-sortable, .box { min-width: 0; }
.din > [data-dinnum] > .din { width: 100%; }
.din1 { grid-template-columns: minmax(0, 1fr); }
.din2-11 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.din2-21 { grid-template-columns: minmax(0, 1fr) var(--kuk-side); }
.din2-12 { grid-template-columns: var(--kuk-side) minmax(0, 1fr); }
.din3-111 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.din3-121 { grid-template-columns: minmax(0, 1fr) minmax(0, 2fr) minmax(0, 1fr); }
.din4-1111 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.din5-11111 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.banner li {display: flex;justify-content: center;}
box.banner img,.banner img {width: fit-content;max-width: 100%;cursor: pointer;}
.bg_black { width: 100%; max-width: none; background: #000; }
.border-top { border-top: 1px solid var(--kuk-line); }
.border-bottom { border-bottom: 1px solid var(--kuk-line); }
.border-right { border-right: 1px solid var(--kuk-line); }
.border-left { border-left: 1px solid var(--kuk-line); }
.border-top-2 { border-top: 2px solid var(--kuk-black); }
.mg-bt-20 { margin-bottom: 20px; }
.mg-bt-30 { margin-bottom: 30px; }
.mg-bt-40 { margin-bottom: 40px; }
.mg-tp-20 { margin-top: 20px; }
.mg-tp-30 { margin-top: 30px; }
.mg-tp-40 { margin-top: 40px; }
.pd-tp-20 { padding-top: 20px; }
.pd-tp-30 { padding-top: 30px; }
.pd-tp-40 { padding-top: 40px; }
.pd-bt-20 { padding-bottom: 20px; }
.pd-bt-30 { padding-bottom: 30px; }
.pd-bt-40 { padding-bottom: 40px; }

.fullWidth{width:100%}
.bg-black{background-color:#000}
.bg-white{background-color:#fff}
.bg-gray{background-color:#f5f5f5}

.bd-b-2 { border-bottom: 2px solid #000; }
.pd-b-1-5 { padding-bottom: 1.5rem; }
.pd-t-1-5 { padding-top: 1.5rem; }
.pd-l-1-5 { padding-left: 1.5rem; }
.pd-r-1-5 { padding-right: 1.5rem; }

/* Header */
header {
  position: relative;
  z-index: 100;
  width: min(100%, var(--kuk-container));
  margin: 0 auto;
  padding-top: 28px;
  background: var(--kuk-white);
}
header > .din:first-child {
  gap: 0;
  padding-top: 0;
}
header .din4-1111 {
  grid-template-columns: 278px minmax(0, 1fr) auto 300px;
  align-items: center;
  gap: 18px;
  min-height: 92px;
  padding-bottom: 24px;
}
.td-logo { line-height: 1; }
.td-logo a {
  display: inline-flex;
  align-items: center;
}
.img-logo {
  width: 241px;
  max-height: 75px;
  object-fit: contain;
}
.mobile-header-actions { display: none; }
.mobile-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  color: var(--kuk-black);
}
.mobile-icon-btn--menu { flex-direction: column; gap: 4px; }
.mobile-icon-btn--menu span { display: block; width: 20px; height: 2px; border-radius: 999px; background: currentColor; }
.other-content {
  padding-top: 0;
}
.other-content__list, .header-member-links__list, .header-quick-links__list, .site-nav__list { display: flex; align-items: center; }
.other-content__list li + li::before, .header-member-links__list li + li::before {
  content: "|";
  display: inline-block;
  margin: 0 12px;
  color: #cfcfcf;
  font-size: 27px;
  font-weight: 300;
  line-height: 1;
}
.other-content__list li:first-child a {
  color: var(--kuk-orange);
}
.other-content a {
  color: #b8b8b8;
  font-size: 27px;
  font-weight: 400;
  letter-spacing: -0.05em;
}
.other-content .oven-other-header__tagline {
  display: none;
  margin-left: 4px;
  color: var(--kuk-orange);
  font-size: 1rem;
  font-weight: 500;
}
.other-content a:hover .oven-other-header__tagline,
.other-content a:focus-visible .oven-other-header__tagline,
.other-content__list li:hover .oven-other-header__tagline,
.other-content__list li:focus-within .oven-other-header__tagline {
  display: inline;
}

.header-member-links {
  justify-self: end;
  padding-top: 0;
  white-space: nowrap;
}
.header-member-links a {
  color: var(--kuk-black);
  font-size: 15px;
  font-weight: 500;
}
.header-member-links__list li + li::before {
  margin: 0 8px;
  color: #777;
  font-size: 15px;
}
.header-ad, header .box.banner {
  align-self: center;
  justify-self: end;
  width: 300px;
  min-height: 70px;
}
header .box.banner img {
  width: 300px;
  height: 70px;
  object-fit: cover;
}
header .din2-21 {
  grid-template-columns: minmax(0, 1fr) 334px;
  align-items: center;
  gap: 22px;
  padding: 0;
  border-bottom: 1px solid var(--kuk-black);
}
header .din2-21 > [data-dinnum="2"] {
  justify-self: end;
  white-space: nowrap;
}
.site-nav { min-width: 0; overflow: hidden; }
.site-nav__list {
  justify-content: space-between;
  gap: 0;
  min-height: 62px;
  white-space: nowrap;
}
.site-nav__list a {
  display: inline-flex;
  align-items: center;
  min-height: 62px;
  color: var(--kuk-black);
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.04em;
}
.site-nav__list a:hover, .other-content a:hover, .header-member-links a:hover, .header-quick-links a:hover { color: var(--kuk-orange-dark); }
.header-search {
  display: inline-block;
  width: 178px;
  vertical-align: middle;
}
.header-search form {
  display: flex;
  align-items: center;
  height: 29px;
  border: 1px solid #e5e5e5;
  border-radius: 999px;
  overflow: hidden;
  background: var(--kuk-white);
}
.input_search { flex: 1; width: 100%; height: 100%; padding: 0 10px; border: 0; background: transparent; color: var(--kuk-ink); }
.input_search::placeholder { color: #999; }
.btn_search {
  flex: 0 0 26px;
  height: 100%;
  padding: 0;
  color: var(--kuk-black);
  font-size: 18px;
}
.today-date {
  display: inline-block;
  margin-top: 0;
  margin-left: 6px;
  color: #777;
  font-size: 14px;
  line-height: 29px;
  vertical-align: middle;
  white-space: nowrap;
}
.header-quick-links {
  border-bottom: 1px solid var(--kuk-black);
  padding: 0;
}
.header-quick-links__list {
  justify-content: space-around;
  gap: 20px;
  min-height: 47px;
  overflow-x: auto;
  white-space: nowrap;
}
.header-quick-links__list::-webkit-scrollbar, .site-nav__list::-webkit-scrollbar { display: none; }
.header-quick-links__list li {
  position: relative;
  color: var(--kuk-black);
}
.header-quick-links__list li::before {
  content: "";
  display: inline-block;
  width: 5px;
  height: 5px;
  margin-right: 14px;
  border-radius: 50%;
  background: var(--kuk-black);
  vertical-align: 2px;
}
.header-quick-links a { color: #555; font-size: 15px; }
#region-sub {
  display: none;
  border-top: 1px solid var(--kuk-black);
  border-bottom: 1px solid var(--kuk-black);
}
#region-sub ul {
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 0;
  min-height: 47px;
  margin: 0;
  padding: 0;
  overflow-x: auto;
  white-space: nowrap;
}
#region-sub ul::-webkit-scrollbar { display: none; }
#region-sub li {
  flex: 1 0 auto;
  position: relative;
  color: var(--kuk-black);
  text-align: center;
}
#region-sub li::before { content: none; }
#region-sub a {
  display: block;
  padding: 14px 16px;
  color: var(--kuk-ink);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.25;
}

/* Footer */
footer {
  width: min(100%, var(--kuk-container));
  margin: 0 auto;
  padding: 34px 0 44px;
  border-top: 1px solid #bdbdbd;
  color: #777;
  font-size: 13px;
}
footer a { color: #555; }
.site-footer__brandline { display: grid; grid-template-columns: auto 1fr; gap: 20px; align-items: start; }
.site-footer__logo { color: var(--kuk-black); font-size: 26px; font-weight: 900; }
.site-footer__links { display: flex; flex-wrap: wrap; gap: 6px 16px; margin-bottom: 10px; }
.site-footer__info, .site-footer__copy { color: #777; font-size: 12px; line-height: 1.7; }
#scroll_layer_Left, #scroll_layer_Right, .scroll_layer_left, .scroll_layer_right { max-width: 150px; }
.popup.layer { z-index: 1000; border: 1px solid var(--kuk-black); background: var(--kuk-white); }
.popup img { max-width: 100%; }
.popup .popup_footer { min-height: 30px; padding: 5px 8px; color: var(--kuk-ink); font-size: 12px; }

footer:has(.copyright_v2),
.footer-wrap {
  width: min(100%, var(--kuk-container));
  margin: 46px auto 0;
  padding: 0;
  border-top: 2px solid #111;
  color: #8d8d8d;
  font-size: 12px;
  line-height: 1.7;
}

footer:has(.copyright_v2) > .din,
footer:has(.copyright_v2) > .din > [data-dinnum] {
  width: 100%;
  padding: 0;
}

footer:has(.copyright_v2) .td-container,
.footer-wrap .td-container {
  border-top: 1px solid #ddd;
  width: 100%;
  margin: 0 auto;
}

.copyright_v2 {
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr);
  gap: 26px;
  align-items: center;
  min-height: 116px;
  padding: 22px 0 26px;
}

.logo_v2 a,
.logo_v2 img {
  display: block;
}

.logo_v2 img {
  width: 150px;
  height: auto;
}

.menu_v2 {
  position: relative;
  min-width: 0;
  padding-right: 20px;
}

.menu_v2 ul {
  display: grid;
  gap: 3px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.menu_v2 li {
  color: #9a9a9a;
  font-size: 0.9rem;
  line-height: 1.75;
  letter-spacing: -0.03em;
}

.menu_v2 a {
  color: #7f7f7f;
}

.menu_v2 a:hover,
.menu_v2 a:focus-visible {
  color: var(--kuk-orange-dark);
}

.footer-cert {
  position: absolute;
  right: 0;
  top: 0;
  width: 180px;
  height: auto;
}

.footer-mobile {
  display: none;
}

@media (max-width: 1240px) {
  :root { --kuk-container: calc(100vw - 32px); }
  #scroll_layer_Left, #scroll_layer_Right, .scroll_layer_left, .scroll_layer_right { display: none !important; }
}

@media (max-width: 1024px) {
  :root { --kuk-side: 280px; --kuk-gap: 18px; }
  header .din4-1111 { grid-template-columns: 150px minmax(0, 1fr) auto 220px; gap: 14px; }
  header .din2-21 { grid-template-columns: minmax(0, 1fr) 220px; }
  .site-nav__list { gap: 24px; overflow-x: auto; }
  .din5-11111 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .din4-1111 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 768px) {
  :root { --kuk-container: 100%; --kuk-gap: 14px; }
  body { font-size: 14px; word-break: normal; }
  main { padding: 10px 0 28px; }
  .container, .inner, .wrap, .din { width: 100%; }
  .din { padding-inline: 12px; }
  header { width: 100%; padding: 0 10px; border-bottom: 0; }
  header > .din:first-child { padding: 7px 0 0; }
  header .din { padding-inline: 0; }
  header .din4-1111 { display: flex; align-items: center; justify-content: space-between; gap: 8px; min-height: 38px; padding-bottom: 4px; }
  header .din4-1111 > [data-dinnum="1"] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
    min-width: 0;
  }
  header .din4-1111 > [data-dinnum="2"], header .din4-1111 > [data-dinnum="4"], .header-search, .today-date, .header-quick-links { display: none; }
  header .din4-1111 > [data-dinnum="3"] { width: 70px; }
  .td-logo { flex: 1 1 auto; }
  .td-logo a { align-items: center; }
  .img-logo { width: 100%; max-height: 30px; }
  .mobile-header-actions { display: inline-flex; flex: 0 0 auto; align-items: center; gap: 5px; }
  .mobile-icon-btn {
    width: 24px;
    height: 28px;
    padding: 0;
    border: 0;
    background: transparent;
    font-size: 20px;
  }
  .mobile-icon-btn--search i {
    display: none;
  }
  .mobile-icon-btn--search::before {
    content: "\f002";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    line-height: 1;
  }
  .mobile-icon-btn--menu { gap: 5px; }
  .mobile-icon-btn--menu span { width: 18px; height: 1.5px; border-radius: 0; }
  header .din2-21 { display: block; padding: 2px 0 0; border-bottom: 2px solid var(--kuk-black); }
  header .din2-21 > [data-dinnum="2"] { display: none; }
  .site-nav { overflow: hidden; }
  .site-nav__list { justify-content: flex-start; gap: 27px; min-height: 40px; overflow-x: auto; padding: 0; }
  .site-nav__list a { min-height: 40px; font-size: 1.1rem; font-weight: 800; }
  .site-nav__list a[href="/feed"],
  .site-nav__list a[href="/oven"] {
    font-size: 0;
  }
  .site-nav__list a[href="/feed"]::before,
  .site-nav__list a[href="/oven"]::before {
    font-size: 1.1rem;
  }
  .site-nav__list a[href="/feed"]::before {
    content: "피드";
  }
  .site-nav__list a[href="/oven"]::before {
    content: "오븐";
  }
  header.is-mobile-search-open .din2-21 > [data-dinnum="2"] {
    display: block;
    padding-bottom: 8px;
  }
  header.is-mobile-search-open .header-search {
    display: block;
    width: 100%;
  }
  header.is-mobile-search-open .header-search form {
    height: 36px;
    border-color: #d7d7d7;
    border-radius: 0;
  }
  header.is-mobile-search-open .input_search {
    padding: 0 12px;
    font-size: 15px;
  }
  header.is-mobile-search-open .btn_search {
    flex-basis: 42px;
    font-size: 17px;
  }
  .din2-11, .din2-12, .din2-21, .din3-111, .din3-121, .din4-1111, .din5-11111 { grid-template-columns: minmax(0, 1fr); }
  footer { width: 100%; padding: 26px 12px 34px; font-size: 12px; }
  .site-footer__brandline { grid-template-columns: 1fr; }

  footer:has(.copyright_v2),
  .footer-wrap {
    width: 100%;
    margin-top: 34px;
    padding: 0;
    border-top: 0;
    margin-bottom: 50px;
  }

  footer:has(.copyright_v2) > .din,
  footer:has(.copyright_v2) > .din > [data-dinnum] {
    padding: 0;
  }

  footer:has(.copyright_v2) .td-container,
  .footer-wrap .td-container {
    width: 100%;
  }

  .copyright_v2 {
    display: block;
    min-height: 0;
    padding: 0;
  }

  .logo_v2,
  .menu_v2 {
    display: none;
  }

  .footer-mobile {
    display: block;
    color: #777;
    font-size: 13px;
    line-height: 1.6;
    padding: 1rem;
  }

  .footer-mobile__copy {
    margin: 0 0 22px;
  }

  .footer-mobile__pc {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 78px;
    height: 34px;
    margin-left: auto;
    padding: 0 10px;
    border: 1px solid #cfcfcf;
    background: #fff;
    color: #555;
    font-size: 13px;
  }

  .footer-mobile__actions {
    text-align: right;
  }
}

@media (max-width: 480px) {
  .din { padding-inline: 10px; }
  header { padding-inline: 10px; }
  .site-nav__list { gap: 27px; }
  .site-nav__list a { font-size: 1.1rem; }
}

/* 디바이스별 박스/배너 표시 제어 */
@media (max-width: 768px) {
  [data-show-device="pc"] { display: none !important; }
}
@media (min-width: 769px) {
  [data-show-device="mobile"] { display: none !important; }
}

.scroll_layer_left {
  z-index: 1000;
  position: fixed;
  top: 300px;
  right: 50%;
  width: 150px !important;
  max-width: max-content;
  margin-right: 620px;
}

.scroll_layer_right {
  z-index: 1000;
  position: fixed;
  top: 300px;
  left: 50%;
  width: 150px !important;
  max-width: max-content;
  margin-left: 620px;
}