.elementor-2236 .elementor-element.elementor-element-24098db6{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-24098db6:not(.elementor-motion-effects-element-type-background), .elementor-2236 .elementor-element.elementor-element-24098db6 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://koreacsl.org/wp-content/uploads/2025/06/responsive_big_webp_yO9sYFlYv0-OjhZi3h7C7BpPL_sXRmOZn2S8-LwinfI-1.webp");}.elementor-2236 .elementor-element.elementor-element-36527eec{width:var( --container-widget-width, 1440px );max-width:1440px;--container-widget-width:1440px;--container-widget-flex-grow:0;}.elementor-2236 .elementor-element.elementor-element-36527eec > .elementor-widget-container{margin:050px 0px 0px 025px;padding:090px 64px 048px 064px;}.elementor-2236 .elementor-element.elementor-element-53fd81d6{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-53fd81d6:not(.elementor-motion-effects-element-type-background), .elementor-2236 .elementor-element.elementor-element-53fd81d6 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#8080800F;}.elementor-2236 .elementor-element.elementor-element-60f8a4cd{width:var( --container-widget-width, 1440px );max-width:1440px;--container-widget-width:1440px;--container-widget-flex-grow:0;}.elementor-2236 .elementor-element.elementor-element-60f8a4cd > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 038px 0px 064px;}.elementor-2236 .elementor-element.elementor-element-2c49b798{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-2c49b798:not(.elementor-motion-effects-element-type-background), .elementor-2236 .elementor-element.elementor-element-2c49b798 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#8080800F;}.elementor-2236 .elementor-element.elementor-element-7edb865{width:initial;max-width:initial;}.elementor-2236 .elementor-element.elementor-element-7edb865 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 00400px;}.elementor-2236 .elementor-element.elementor-element-6b4f981{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-53c13002{width:var( --container-widget-width, 1440px );max-width:1440px;--container-widget-width:1440px;--container-widget-flex-grow:0;}.elementor-2236 .elementor-element.elementor-element-53c13002 > .elementor-widget-container{margin:0px 064px 0px 0px;padding:0px 0px 0px 085px;}.elementor-2236 .elementor-element.elementor-element-1cc3e4bd{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-1dff9b08{width:var( --container-widget-width, 1440px );max-width:1440px;--container-widget-width:1440px;--container-widget-flex-grow:0;}.elementor-2236 .elementor-element.elementor-element-1dff9b08 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 062px 0px 75px;}.elementor-2236 .elementor-element.elementor-element-63bef74f{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-2236 .elementor-element.elementor-element-63bef74f:not(.elementor-motion-effects-element-type-background), .elementor-2236 .elementor-element.elementor-element-63bef74f > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#8080800F;}.elementor-2236 .elementor-element.elementor-element-21d7c3a2 > .elementor-widget-container{padding:0px 0px 0px 011px;}.elementor-2236 .elementor-element.elementor-element-4e86ddd6{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-3a134d8e{width:var( --container-widget-width, 1440px );max-width:1440px;--container-widget-width:1440px;--container-widget-flex-grow:0;}.elementor-2236 .elementor-element.elementor-element-3a134d8e > .elementor-widget-container{margin:050px 0px 030px 0px;padding:0px 035px 0px 50px;}.elementor-2236 .elementor-element.elementor-element-2c500098{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 24px;--row-gap:0px;--column-gap:24px;--margin-top:025px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-2c500098:not(.elementor-motion-effects-element-type-background), .elementor-2236 .elementor-element.elementor-element-2c500098 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#80808000;}.elementor-2236 .elementor-element.elementor-element-5daa9bee{width:var( --container-widget-width, 1440px );max-width:1440px;--container-widget-width:1440px;--container-widget-flex-grow:0;}.elementor-2236 .elementor-element.elementor-element-5daa9bee > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 040px 0px 050px;}.elementor-2236 .elementor-element.elementor-element-42965ba3{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-2236 .elementor-element.elementor-element-42965ba3:not(.elementor-motion-effects-element-type-background), .elementor-2236 .elementor-element.elementor-element-42965ba3 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#8080800F;}.elementor-2236 .elementor-element.elementor-element-34df01f6{width:var( --container-widget-width, 1440px );max-width:1440px;--container-widget-width:1440px;--container-widget-flex-grow:0;}.elementor-2236 .elementor-element.elementor-element-34df01f6 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 064px 0px 070px;}.elementor-2236 .elementor-element.elementor-element-86602c3{--display:flex;--min-height:100px;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-86602c3:not(.elementor-motion-effects-element-type-background), .elementor-2236 .elementor-element.elementor-element-86602c3 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF00;}.elementor-2236 .elementor-element.elementor-element-1321148{width:var( --container-widget-width, 1905px );max-width:1905px;--container-widget-width:1905px;--container-widget-flex-grow:0;}.elementor-2236 .elementor-element.elementor-element-1321148 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}body.elementor-page-2236:not(.elementor-motion-effects-element-type-background), body.elementor-page-2236 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#000000;}body.elementor-page-2236{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}@media(max-width:767px){.elementor-2236 .elementor-element.elementor-element-24098db6{--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-36527eec{width:initial;max-width:initial;}.elementor-2236 .elementor-element.elementor-element-36527eec > .elementor-widget-container{margin:035px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-53fd81d6{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-60f8a4cd > .elementor-widget-container{margin:0px 0px -200px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-2c49b798{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-7edb865 > .elementor-widget-container{margin:-40px 0px -30px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-6b4f981{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:016px;--padding-right:016px;}.elementor-2236 .elementor-element.elementor-element-53c13002 > .elementor-widget-container{margin:-20px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-1cc3e4bd{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-1dff9b08 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-21d7c3a2 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-4e86ddd6{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-3a134d8e > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-2c500098{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-5daa9bee > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-42965ba3{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:016px;--padding-right:016px;}.elementor-2236 .elementor-element.elementor-element-34df01f6 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2236 .elementor-element.elementor-element-86602c3{--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2236 .elementor-element.elementor-element-1321148 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}}@media(min-width:768px){.elementor-2236 .elementor-element.elementor-element-24098db6{--content-width:2041px;}.elementor-2236 .elementor-element.elementor-element-53fd81d6{--content-width:2041px;}.elementor-2236 .elementor-element.elementor-element-2c49b798{--width:100%;}.elementor-2236 .elementor-element.elementor-element-6b4f981{--content-width:1905px;}.elementor-2236 .elementor-element.elementor-element-1cc3e4bd{--content-width:1905px;}.elementor-2236 .elementor-element.elementor-element-63bef74f{--content-width:1905px;}.elementor-2236 .elementor-element.elementor-element-4e86ddd6{--content-width:1905px;}.elementor-2236 .elementor-element.elementor-element-2c500098{--content-width:1905px;}.elementor-2236 .elementor-element.elementor-element-42965ba3{--content-width:1905px;}.elementor-2236 .elementor-element.elementor-element-86602c3{--content-width:1905px;}}/* Start custom CSS for html, class: .elementor-element-36527eec */:root {
      --primary: #23406a;
      --blue-900: #0b1c2c;
      --radius-lg: 0.5rem;
    }
    body {
      background: #193047;
      font-family: 'Noto Sans KR', sans-serif;
      margin: 0;
      color: #fff;
    }
   .nkc-feature {
  width: 100vw;      /* 또는 max-width: 100vw; */
  max-width: 100%;
  overflow: visible; /* 중요! */
  /* 필요한 만큼 padding */
  padding-left: 0;   /* 필요에 따라 조정 */
  padding-right: 0;
}

    .nkc-feature-inner {
      display: grid;
      grid-template-columns: 1fr 300px;
      gap: 2.5rem;
      align-items: center;
      margin-bottom: 2.8rem;
    }
    @media (max-width: 900px) {
      .nkc-feature-inner {
        grid-template-columns: 1fr;
        gap: 1.7rem;
        margin-bottom: 2rem;
      }
    }
    .nkc-feature-content {
      text-align: left;
    }
    .nkc-feature-kicker {
      font-size: 1.05rem;
      font-weight: 600;
      color: #c0d4ee;
      margin: 0 0 .2rem;
      letter-spacing: 0.01em;
    }
    .nkc-feature-headline {
      font-size: 2.5rem;
      font-weight: 900;
      margin: .15rem 0 1.4rem;
      color: #fff;
      letter-spacing: -1.2px;
    }
    @media (min-width: 900px) {
      .nkc-feature-headline { font-size: 2.95rem; }
    }
    .nkc-feature-meta {
      display: flex;
      gap: .1rem;
      align-items: center;
      margin-bottom: .7rem;
    }
    .nkc-feature-meta-type {
      font-weight: 700;
      font-size: 14px;
      margin-bottom: 0;
      color: #fff;
    }
    .nkc-feature-btn {
      display: inline-flex;
      align-items: center;
      gap: .5rem;
      border-radius: 999px;
      font-size: 1rem;
      font-weight: 700;
      text-decoration: none;
      transition: .18s cubic-bezier(.4,0,.2,1);
      padding: .7rem 1.5rem;
      border: none;
      cursor: pointer;
      color: #fff;
      background: transparent;
    }
    .nkc-feature-btn svg { width: 1.1em; height: 1.1em; }
    .nkc-feature-btn--ghost {
      margin-bottom: 0;
      font-size: 14px;
      font-weight: 700;
    }
    .nkc-feature-btn--ghost:hover {
      background: rgba(255,255,255,0.22);
      color: #e9edfa;
    }
    .nkc-feature-btn--solid {
      background: var(--primary);
      color: #fff;
      border: none;
    }
    .nkc-feature-btn--solid:hover {
      background: #142d52;
      color: #fff;
    }
    .nkc-feature-btn-report {
      margin-top: 1.2rem;
      font-size: 1.03rem;
      padding: .8rem 1.75rem;
    }
    .nkc-feature-thumb {
      width: 205px;
      max-width: 100%;
      background: #14243a;
      border-radius: var(--radius-lg);
      box-shadow: 0 8px 36px rgba(10,18,32,0.16);
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 294px;
      transform: translateX(-100px);
      margin-top: 0;
      
    }
    .nkc-feature-thumb img {
      width: 100%;
      max-width: 205px;
      min-height: 294px;
      border-radius: var(--radius-lg);
      object-fit: contain;
      display: block;
    }
    @media (max-width: 900px) {
      .nkc-feature-thumb {
        margin: 0 auto 2rem auto;
        width: 220px;
        min-height: 200px;
      }
      .nkc-feature-thumb img {
        max-width: 100%;
      }
    }
    /* 뉴스 카드 슬라이더 */
   .nkc-feature-news-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}

.nkc-feature-news-actions {
  margin-right: 0;  /* 오른쪽으로 이동 */
  position: relative;
  top: -10px;            /* 아래로 살짝 */
}
    .nkc-feature-news-title {
      font-size: 1.3rem;
      font-weight: 800;
      color: #fff;
    }
/* ───────── 공통(데스크톱) ───────── */
.nkc-feature-news-row{
  width:100%;
  max-width:none;
  margin:0 auto;
  overflow:hidden;              /* ← 화살표 클릭 전용 */
  position:relative;
  padding-left:0;
  padding-right:0;
}

.nkc-slider-track{
  display:flex;
  gap:1.5rem;                   /* 카드 간 간격 */
  transition:transform .4s cubic-bezier(.42,1.2,.2,1);
  will-change:transform;
  /* 데스크톱에선 JS로 translateX 이동 */
}
    .nkc-news-card {
  flex: 0 0 310px;
  width: 312px;
  height: 176.38px;
  position: relative;
  border-radius: 12px;
  background: #1a2b44;
  box-shadow: 0 4px 20px rgba(13,25,46,0.15);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
    .nkc-news-card img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: 0;
      transition: transform .19s cubic-bezier(.41,.12,.33,1.22);
    }
    .nkc-news-card:hover img { transform: scale(1.05);}
    .nkc-news-card-info {
      position: relative;
      z-index: 1;
      padding: 1.15rem 1.1rem 0.7rem 1.1rem;
      background: linear-gradient(to top, rgba(8,12,23,0.94) 0, rgba(8,12,23,0.07) 80%);
      border-bottom-left-radius: 0.5rem;
      border-bottom-right-radius: 0.5rem;
      min-height: 90px;
    }
    .nkc-news-card-title {
      font-size: 1.07rem;
      font-weight: 800;
      color: #fff;
      margin-bottom: .5rem;
      overflow: hidden;
      text-overflow: ellipsis;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
    }
    .nkc-news-card-meta {
      display: flex;
      align-items: center;
      gap: .45rem;
      font-size: .93rem;
      color: #d5e5ff;
      opacity: .95;
    }
    .nkc-news-card-meta svg { width: 1em; height: 1em; }
   .nkc-feature-news-arrow {
  background: transparent !important;
}

    .nkc-feature-news-arrow--prev svg {
      transform: rotate(180deg);
    }
    .nkc-feature-news-arrow svg {
      width: 22px;
      height: 18px;
      color: #fff;
    }
 .nkc-feature-news-arrow {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  background: transparent !important;
}

.nkc-feature-news-arrow:hover:not(:disabled) {
  background: rgba(255,255,255,0.13);
  transform: translateY(-2px) scale(1.06);
}

.nkc-feature-news-arrow:disabled,
.nkc-feature-news-arrow[disabled] {
  opacity: 0.38;
  cursor: default;
  pointer-events: none;
 
}
.nkc-feature-news-row, .nkc-slider-track {
  overflow-x: hidden;
  scrollbar-width: none;
}
.nkc-feature-news-row::-webkit-scrollbar,
.nkc-slider-track::-webkit-scrollbar {
  display: none;
}


    @media (max-width: 900px) {
  .nkc-feature-thumb {
    display: none !important;
  }
  .nkc-feature-news-arrow {
    display: none !important;
  }
}
@media (max-width: 900px) {
  .nkc-feature {
    padding: 5rem 0.2rem 3rem 0.2rem; /* 바깥 여백도 더 줄이고 싶으면 */
  }
  .nkc-feature-inner {
    gap: 0.3rem;    /* 텍스트와 카드 간격 최소 */
  }
  /* 부모만 스크롤 담당 */
  .nkc-feature-news-row{
    max-width:100%;
    overflow-x:auto;                 /* 네이티브 스와이프 */
    -webkit-overflow-scrolling:touch;/* iOS 모멘텀 */
    scroll-snap-type:x mandatory;
    padding:0 0 10px 0;
  }

  /* 자식(track)은 ‘움직이는 콘텐츠’만 담당 */
  .nkc-slider-track{
    overflow-x:visible !important;   /* 이중 스크롤 제거 */
    gap:0;                           /* 필요하면 0 유지 */
    transform:none !important;       /* JS 변환 비활성화 */
  }

  .nkc-news-card{
    scroll-snap-align:start;
  }
  .nkc-feature-news-header {
    margin-bottom: 0.5rem; /* 헤더 아래 간격 최소화 */
    gap: 0.5rem;
  }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-24098db6 */.elementor-2236 .elementor-element.elementor-element-24098db6:not(.elementor-motion-effects-element-type-background) {
     position: relative;
  color: #fff;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.00) 38%),
    linear-gradient(0deg, rgba(0,0,0,0.40) 0.01%, rgba(0,0,0,0.00) 61%),
    linear-gradient(0deg, rgba(0,0,0,0.20) 0%, rgba(0,0,0,0.20) 100%),
    url('https://koreacsl.org/wp-content/uploads/2025/06/responsive_big_webp_yO9sYFlYv0-OjhZi3h7C7BpPL_sXRmOZn2S8-LwinfI.webp') center/cover no-repeat;
    padding-left: 16px !important;
    padding-right: 16px !important;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-60f8a4cd */body {
 font-family: 'Noto Sans KR', sans-serif;
}
body, html {
  background: #fff !important;
}
.nkc-our-mission {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 3rem;
  padding: 0 1.5rem 3rem 1.5rem;
  border-radius: 2.5rem;
  max-width: 1440px;
  margin: 3rem auto 0 auto;
}
.nkc-our-mission__content {
  flex: 1 1 380px;
  max-width: 610px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-top: 25px;
}
.nkc-our-mission__label {
  font-size: 1.1rem;
  font-weight: 700;
  color: #0050b8;
  letter-spacing: 0.06em;
  margin-bottom: 1rem;
  text-transform: uppercase;
}
.nkc-our-mission__title {
  font-size: 40px;
  font-weight: 900;
  line-height: 1.25;
  color: #191919;
  margin-bottom: 2.5rem;
  letter-spacing: -0.01em;
}
.nkc-our-mission__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;    /* 내부 콘텐츠 중앙 정렬 */
  gap: 0.32em;                /* 텍스트-아이콘 간격 */
  background: #fff;
  color: #000;
  border: 2px solid #d0deee;
  border-radius: 1.2em;       /* 라운드값 축소 */
  padding: 0.44em 1em;        /* 상하, 좌우 패딩 축소 */
  font-size: 0.98rem;         /* 폰트 소폭 축소 */
  font-weight: 700;
  text-decoration: none;
  transition: background 0.13s, box-shadow 0.13s, color 0.13s, border-color 0.13s;
  box-shadow: 0 1px 5px 0 rgba(80,100,160,.07);
  min-height: 2em;            /* 너무 얇지 않게 */
  min-width: 240px;           /* 최소 너비 */
  width: 1px;               /* 고정 너비(원하는 경우, 유동적이면 삭제) */
}
.nkc-our-mission__button .icon-arrow {
  width: 1.1em;
  height: 0.92em;
  margin-left: 2px;
  vertical-align: middle;
}
.nkc-our-mission__button:hover,
.nkc-our-mission__button:focus {
  color: #000;
  border-color: #0050b8;
  background: #f3f7fa;
}

.nkc-our-mission__button .icon-arrow {
  width: 1.13em;
  height: 0.95em;
  margin-left: 1px;
  vertical-align: middle;
}
.nkc-our-mission__button:hover,
.nkc-our-mission__button:focus {
  color: #000;
  border-color: #0050b8;
}


/* =========== MEDIA =========== */
.nkc-our-mission__media {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.1rem;
  flex: 1 1 320px;
  max-width: 644px;
  min-width: 320px;
  position: relative;
 
}

/* --- 썸네일 비율 & 플레이 버튼 --- */
.nkc-our-mission__video-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  width: 100%;
  cursor: pointer;
  transition: box-shadow 0.18s cubic-bezier(.4,1,.3,1);
  border-radius: 1.3rem;
}
.nkc-our-mission__video-link:hover,
.nkc-our-mission__video-link:focus {
  
  outline: none;
}

.nkc-our-mission__video-ratio {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: #000;
  border-radius: 1.3rem;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.nkc-our-mission__video-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 1.3rem;
  transition: filter 0.22s cubic-bezier(.4,1,.3,1);
}

/* 플레이 버튼 중앙 */
.nkc-our-mission__video-play-btn {
  position: absolute;
  top: 280px; left: 40px;
  transform: translate(-50%, -50%);
  background: rgba(0,0,0,0.06);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none; /* 클릭은 a에만 */
  z-index: 2;
  transition: background 0.18s cubic-bezier(.4,1,.3,1), box-shadow 0.18s cubic-bezier(.4,1,.3,1);
}
.nkc-our-mission__video-link:hover .nkc-our-mission__video-play-btn {
  background: rgba(0,80,184,0.15);
  box-shadow: 0 2px 10px 0 rgba(30,50,130,0.14);
}
.icon-play {
  width: 44px;
  height: 44px;
  display: block;
}

.nkc-our-mission__video-ratio {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: #000;
  border-radius: 1.3rem;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 텍스트가 썸네일 위로 오버레이됨 */
.nkc-our-mission__video-text {
  position: absolute;
  left: 140px;
  top: 280px;                    /* 중앙 약간 아래 */
  transform: translate(-50%, -50%);
  font-size: 1.13rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.01em;
  text-align: center;
  text-shadow: 0 2px 8px rgba(0,0,0,0.35);
  margin: 0;
  pointer-events: none;        /* 클릭은 썸네일(a)에만 전달 */
  z-index: 2;
  transition: color 0.18s cubic-bezier(.4,1,.3,1);
}

.nkc-our-mission__video-link:hover .nkc-our-mission__video-text,
.nkc-our-mission__video-link:focus .nkc-our-mission__video-text {
  text-decoration: underline;
  color:#fff; 
}

/* ========== 태블릿 (950px 이하) ========== */
@media (max-width: 950px) {
  .nkc-our-mission {
    flex-direction: column;
    gap: 2rem;
    border-radius: 1.5rem;
    padding: 2rem 1rem 2.5rem 1rem;
    max-width: 100%;
    margin-top: 1rem;
  }
  .nkc-our-mission__content,
  .nkc-our-mission__media {
    max-width: 100%;
    min-width: 0;
  }
  .nkc-our-mission__media {
    width: 100%;
    align-items: center;
  }
  .nkc-our-mission__video-link {
    border-radius: 1rem;
  }
  .nkc-our-mission__video-ratio,
  .nkc-our-mission__video-thumb {
    border-radius: 1rem;
  }
  .nkc-our-mission__content {
    margin-top: 0;
    margin-bottom: 2rem;
    align-items: flex-start;
    text-align: left;
  }
  .nkc-our-mission__title {
    font-size: 2.1rem;
  }
  .nkc-our-mission__button {
    min-width: 180px;
    font-size: 1rem;
  }
  /* === 플레이 버튼/텍스트 위치: 태블릿에서 미세조정 === */
  .nkc-our-mission__video-play-btn {
    top: 54%;    /* 중앙보다 살짝 아래 */
    left: 8%;    /* 좌측에서 8% */
    transform: translate(0, -50%);
  }
  .nkc-our-mission__video-text {
    top: 72%;    /* 버튼보다 더 아래 */
    left: 8%;
    transform: translate(0, -50%);
    font-size: 1.05rem;
    text-align: left;
  }
}

/* ========== 모바일 (600px 이하) ========== */
@media (max-width: 600px) {
  .nkc-our-mission {
    padding: 1 0.5rem 1.6rem 0.5rem;
    border-radius: 1rem;
    gap: 1.2rem;
    margin-top: -1.5rem;
  }
  .nkc-our-mission__title {
    font-size: 2rem;
    line-height: 1.4;
    margin-bottom: 1.2rem;
  }
  .nkc-our-mission__button {
    font-size: 0.98rem;
    padding: 0.5rem 0.8rem;
    min-width: 310px;
    border-width: 1.5px;
    margin-top: .7rem;
  }
  .nkc-our-mission__content {
    margin-bottom: 1.2rem;
    margin-top: 0;
    align-items: flex-start;
    text-align: left;
  }
  .nkc-our-mission__video-ratio {
    border-radius: 0.7rem;
    margin-top: -2.3rem;
  }
  .nkc-our-mission__video-thumb {
    border-radius: 0.7rem;
  }
  .icon-play {
    width: 32px;
    height: 32px;
  }
  /* === 플레이버튼/텍스트 위치: 모바일에서 미세조정 === */
  .nkc-our-mission__video-play-btn {
    top: 85%;    /* 중앙보다 살짝 아래 */
    left: 7%;    /* 좌측에서 7% */
    transform: translate(0, -50%);
  }
  .nkc-our-mission__video-text {
    top: 40%;    /* 더 아래 */
    left: 20%;
    transform: translate(0, -50%);
    font-size: 0.95rem;
    text-align: left;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-7edb865 */.section_impact .impact_slide_image .impact_slide_img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* 섹션 전체 */
.section_impact {
  padding: 80px 0;
  overflow: visible;
}

/* 헤더 */
.section_impact_header {
  text-align: center;
  margin-bottom: 2rem;
}
.section_impact_title {
  font-size: 40px;
  font-weight: 800;
  color: #000;
  margin: 0;
}

/* 모바일 전용 카드 (데스크탑에선 숨김) */
.impact_card_mobile_wrapper {
  display: none;
}
.impact_card_mobile {
  background: #fff;
  padding: 1.25rem;
  margin: 0 16px 24px;
  border-radius: 1rem;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}

/* 데스크탑용 텍스트 카드 */
.impact_card_pc {
  flex-shrink: 0;
  width: 420px;
  height: 320px;
}
.impact_card_base {
  background: #fff;
  height: 100%;
  padding: 1.25rem;
  border-radius: 1rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}
.mpact_nav_btn impact_nav_leftt {
  transform: scaleX(-1);
}

/* 카드 텍스트 */
.impact_subtitle {
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  color: #666;
  margin-bottom: 0.5rem;
}
.impact_heading {
  font-size: 2rem;
  font-weight: 900;
  margin: 0.5rem 0 1rem;
  color: #000;
}
.impact_text {
  font-size: 1rem;
  line-height: 1.6;
  color: #444;
}

/* 버튼 */
.impact_button {
  display: inline-flex;
  align-items: center;
  font-size: .875rem;
  font-weight: 700;
  color: #333;
  background: rgba(128,128,128,.11);
  border-radius: 9999px;
  padding: 8px 16px;
  margin-top: 1.25rem;
  position: relative;
}
.impact_button::after {
  content: "";
  width: 16px;
  height: 16px;
  background: url("https://koreacsl.org/wp-content/uploads/2025/04/arrow-sm-right-svgrepo-com.png") no-repeat center;
  background-size: contain;
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
}

/* 이미지 카드 */
.impact_slide_image {
  width: 250px;
  height: 320px;
  position: relative;
  overflow: hidden;
  border-radius: 1rem;
  flex-shrink: 0;
}
.impact_slide_image_link {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
}
.impact_slide_img {
  position: absolute;
  inset: 0;
  object-fit: cover;
  object-position: center;
  transition: transform .3s ease;
}
.impact_slide_image:hover .impact_slide_img {
  transform: scale(1.05);
}
.impact_slide_caption {
  position: absolute;
  bottom: 0; left: 0;
  width: 100%;
  padding: 1rem;
  background: linear-gradient(to top, rgba(0,0,0,0.6), transparent);
  z-index: 1;
}
.impact_caption_title {
  margin: 0;
  font-weight: 800;
  line-height: 1.4;
  color: #fff;
}

/* 슬라이더 래퍼 (데스크탑) */
.impact_swiper_container {
  position: relative;
  overflow: visible;
  width: 100%;
}

.impact_swiper_wrapper {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  scroll-behavior: smooth;
  -ms-overflow-style: none;
  scrollbar-width: none;
  padding: 0 32px;
}
.impact_swiper_wrapper::-webkit-scrollbar {
  display: none;
}
/* 데스크탑 첫 카드 여백 */
.impact_swiper_wrapper > *:first-child {
  margin-left: 0;
}

/* 내비게이션 버튼 */
.impact_slider_nav {
  position: absolute;
  top: 113%; right: 480px;
  transform: translateY(-50%);
  display: flex;
  gap: 8px;
  z-index: 10;
}
.impact_nav_btn {
  all: unset;
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  cursor: pointer; background: transparent !important;
}
.impact_nav_btn svg {
  width: 22px;
  height: 18px;
  stroke: #11;
  stroke-width: 2;
  transition: stroke 0.2s ease, opacity 0.2s ease;
}
.rotate-left {
  transform: scaleX(-1);
}

.impact_nav_btn:hover svg {
  stroke: #007bff;
}
.impact_nav_btn:disabled svg {
  stroke: #ccc;
  opacity: 0.4;
  cursor: not-allowed;
}

}
.impact_nav_btn:disabled svg {
  stroke: #ccc; cursor: not-allowed;
}
/*───────────────────────────────
  2. 반응형(모바일 ≤768px) 스타일
───────────────────────────────*/
@media (max-width: 768px) {
  /* 텍스트 카드 전환 */
  .impact_card_pc { display: none !important; }
  .impact_card_mobile_wrapper { display: block; }

  /* 모바일 슬라이드: 스와이프 가능 */
  .impact_swiper_wrapper {
    flex-direction: row;
    overflow-x: auto !important;       /* ← 손가락 스와이프 허용 */
    scroll-snap-type: x mandatory;     /* 스냅 효과 */
    padding: 0 16px 0 32px;
    gap: 10px;
    margin-left: 17px;

    /* 모바일 스크롤바 숨김 */
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .impact_swiper_wrapper::-webkit-scrollbar {
    display: none;
  }

  /* 모바일 카드 사이즈 */
  .impact_slide_image {
    width: 230px;
    height: 320px;
    scroll-snap-align: start;
  }

  .impact_slide_img {
    object-fit: cover;
  }

  /* 네비게이션 버튼 숨김 */
  .impact_slider_nav { display: none; }
  /* 섹션 타이틀 크기 조정 */
  .section_impact_title {
    font-size: 26px;  /* 필요에 따라 원하는 크기로 변경 */
  }

  /* 카드 내 헤딩 크기 조정 */
  .impact_heading {
    font-size: 1.25rem; /* 필요에 따라 원하는 크기로 변경 */
  }
  .impact_button {
      padding: 8px 60px;
  }
  .impact_button::after {
      right: 17px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-53c13002 */.nkc2-section-title {
  font-size: 40px;
  font-weight: 900;
  color: #000;
  margin-top: 3rem;
  margin-bottom: .1rem;
  letter-spacing: -1.5px;
  line-height: 1.18;
  text-align: left;
  padding-left: 0;
  font-family: 'Noto Sans KR';
   transparent 100%);
  border-radius: 0.4em;
  display: inline-block;
  box-decoration-break: clone;
}
.nkc2-section-subtitle {
  font-size: 1rem;
  color: #141414;
  margin: 0.4rem 0 2.4rem 0;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: -0.2px;
  padding-left: 2px;
  font-family: 'Pretendard', 'Noto Sans KR', Arial, sans-serif;
  opacity: 0.84;
}
@media (max-width: 900px) {
  .nkc2-section-title {
    font-size: 1.33rem;
    margin-bottom: 1.2rem;
    padding-left: 0.02em;
  }
}

.nkc2-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  max-width: 1440px;
  margin: 2rem auto;
  padding: 0;
}

.nkc2-visual {
  position: relative;
  width: 100%;
  aspect-ratio: 2/1.15;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #e8e8e8;
}

.nkc2-blur-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.nkc2-blur-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: blur(16px) brightness(0.82);
  transform: scale(1.14);
  pointer-events: none;
}

.nkc2-thumb-fore {
  position: relative;
 width: 340px;
  height: 320px;
  aspect-ratio: 1 / 1;* 
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.nkc2-thumb-link {
  display: block;
  width: 100%;
  height: 100%;
}

.nkc2-thumb-link img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 15px;
}



.nkc2-thumb-fore img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 15px;
  display: block;
}


.nkc2-info {
  padding: 1rem 0 1.3rem 0;
  text-align: left;
}

.nkc2-tag {
  display: block;
  font-size: 1rem;
  color: #979797;
  font-weight: 700;
  letter-spacing: 2.2px;
  text-transform: uppercase;
  margin-bottom: 0.7rem;
}
.nkc2-title {
  display: block;
  font-size: 1.30rem;
  font-weight: 800;
  color: #161616;
  margin-bottom: 0;
  margin-top: 0;
  line-height: 1.18;
  text-decoration: none;
}

/* 반응형 */
@media (max-width: 1080px) {
  .nkc2-row { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 730px) {
  .nkc2-row { grid-template-columns: 1fr; gap: 1.2rem; }
  .nkc2-info { 
      padding: 1.1rem 0.6rem 0.7rem 0.6rem; 
      
  }
  .nkc2-title { font-size: 1.08rem; }
  .nkc2-tag { font-size: 0.98rem; }
  .nkc2-thumb-fore { width: 84vw; max-width: 350px; }
}
.nkc2-thumb-fore {
  position: relative;
}

.nkc2-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media (max-width: 730px) {
  .nkc2-row {
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }
  .nkc2-section-title{
      font-size: 2rem;
  }
  .nkc2-info { 
    padding: 1.1rem 0.6rem 0.7rem 0.6rem; 
  }
  .nkc2-title { font-size: 1.4rem; }
  .nkc2-tag { font-size: 0.98rem; }

  /* 썸네일 사이즈 ↓ 조정 */
  .nkc2-thumb-fore { 
    width: 58vw;     
    max-width: 220px; 
    margin: 0 auto; 
    height: 45vw;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1dff9b08 *//* 배너 섹션 전체 */
.nkc-banner {
  width: 100%;
  max-width: 1312px;
  max-height: 131px;
  margin: 2rem auto;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 40px 0 rgba(10, 30, 90, 0.09);
  position: relative;
  padding: 0;
}

/* 배너 링크 전체 */
.nkc-banner-link {
  display: flex;
  flex-direction: column;
  min-height: 100px;
  background: linear-gradient(10deg, rgba(0,0,0,0.00) 0%, rgba(0,0,0,0.1) 100%),
              url('https://koreacsl.org/wp-content/uploads/2025/09/국가원로회의_심포지엄.avif');
  background-repeat: no-repeat;
  background-position: 50% 100%;
  background-size: 100%;
  position: relative;
  text-decoration: none;
  color: inherit;
  padding: 1.5rem;
  gap: 1.5rem;
  transition: background-size 0.4s cubic-bezier(.6,.4,0,1);
}

/* 데스크톱 2단 */
@media (min-width: 600px) {
  .nkc-banner-link {
    flex-direction: row;
    align-items: stretch;
    min-height: 220px;
    padding: 2.5rem 3rem;
    gap: 2.5rem;
    background-position: left 77%;
    background-size: 130%;
  }
}

/* 이미지 래퍼 (정사각형 유지) */
.nkc-banner-img {
  flex: 0 0 170px;
  width: 72px;
  aspect-ratio: 1/1;
  min-width: 0;
  max-width: 72px;
  height: 72px;
  overflow: hidden;
  border-radius: 12px;
  background: #d4d8e4;
  display: flex;
  align-items: stretch;
  position: relative;
}

.nkc-banner-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  position: absolute;
  inset: 0;
}

/* 정보 텍스트 */
.nkc-banner-info {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.7rem;
  padding-left: 0.5rem;
}

.nkc-banner-title {
  font-size: 1.45rem;
  font-weight: 900;
  margin: -3.5rem 0 0 0;
  color: #fff;
  line-height: 1.25;
}
.nkc-banner-date {
  font-size: 1rem;
  color: #fff;
  font-weight: 500;
  opacity: 0.9;
  margin-bottom: 0.6rem;
}

/* 버튼 (배너 우측 하단, 고정) */
.nkc-banner-btn {
  position: absolute;
  right: 2rem;
  bottom: 8rem;
  background: #1457ca;
  color: #fff;
  border: none;
  border-radius: 999px;
  font-weight: 800;
  font-size: 1.08rem;
  padding: 0.6rem 1.6rem 0.6rem 1.15rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  box-shadow: 0 2px 10px 0 rgba(10,70,200,0.10);
  cursor: pointer;
  z-index: 1;
  transition: background 0.2s;
}

.nkc-banner-btn svg {
  display: inline-block;
  vertical-align: middle;
  margin-left: 0.18rem;
}

.nkc-banner-btn:hover {
  background: #2770df;
}

/* 모바일 반응형 */
@media (max-width: 700px) {
  .nkc-banner {
    max-width: 98vw;
    max-height: none;
    margin: 1rem auto;
    border-radius: 1.1rem;
  }
  .nkc-banner-link {
    flex-direction: column;
    align-items: flex-start;
    padding: 1rem;
    gap: 0.8rem;
    min-height: unset;
    background-size: 140%;
    background-position: 40% 95%;
  }
  .nkc-banner-img {
    width: 92px;
    max-width: 92px;
    min-width: 64px;
    height: 92px;
    margin-bottom: 0.5rem;
    margin-right: 0;
    align-self: flex-start;
  }
  .nkc-banner-info {
    padding-left: 0;
    gap: 0.4rem;
    width: 100%;
  }
  .nkc-banner-title {
    font-size: 1.08rem;
    margin-top: 0;
    margin-bottom: 0.2rem;
    line-height: 1.27;
    word-break: keep-all;
  }
  .nkc-banner-date {
    font-size: 0.92rem;
    margin-bottom: 0.2rem;
  }
  .nkc-banner-btn {
    position: static;
    width: 100%;
    margin-top: 0.65rem;
    font-size: 1rem;
    justify-content: center;
    border-radius: 1.4rem;
    padding: 0.5rem 0.4rem;
    box-shadow: 0 2px 7px 0 rgba(10,70,200,0.10);
  }
}
@media (max-width: 700px) {
    .nkc-banner-link {
        flex-direction: column;
        align-items: flex-start;
        min-height: unset;
        background-size: 190%;
        padding: 1rem;
        gap: 0.8rem;
        background-position: 40% 95%;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-21d7c3a2 */.nkc-card-row {
  display: flex;
  gap: 2rem;
  max-width: 1700px;
  margin: 2.5rem auto;
  justify-content: center;
}

.nkc-main-card {
  background: #fff;
  border-radius: 12px;
  padding: 2.5rem 2rem;
  width: 100%;
  max-width: 644px;
  box-sizing: border-box;
  box-shadow: 0 4px 32px rgba(44,62,80,.10);
  display: flex;
  flex-direction: column;
  font-family: 'Inter', 'Pretendard', sans-serif;
}

.nkc-main-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}
.nkc-main-title {
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -.01em;
  margin: 0;
}
.nkc-main-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-size: 1rem;
  font-weight: 500;
  border: 1.5px solid #e4e6e7;
  background: #f9f9fa;
  border-radius: 999px;
  padding: 0.65em 1.5em;
  color: #1a1a1a;
  text-decoration: none;
  transition: box-shadow .13s;
  box-shadow: 0 1px 4px rgba(44,62,80,0.03);
}
.nkc-main-btn:hover { background: #e4e6e7; }

.nkc-main-img img {
  width: 100%;
  height: 350px;
  display: block;
  border-radius: none;
  margin-bottom: 2rem;
}
.nkc-main-featured {
  margin-bottom: 2.2rem;
}
.nkc-badge {
  font-size: 0.9rem;
  font-weight: 700;
  color: #8b8e94;
  letter-spacing: .08em;
  margin-bottom: 0.4em;
  display: block;
}
.nkc-featured-title {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0;
  color: #161616;
  text-align: left;
  line-height: 1.6;
}

/* 호버 시에만 밑줄 */
.nkc-featured-title .nkc-featured-link {
  color: #161616;              /* 검정색 */
  text-decoration: none;
  transition: color 0.14s, text-decoration 0.14s;
  display: block;
  line-height: 1.6;
}
.nkc-featured-title .nkc-featured-link:hover {
  color: #0657bd;
  text-decoration: underline;
}

.nkc-main-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem 1.3rem;
}
.nkc-main-grid-item .nkc-badge {
  margin-bottom: 0.3em;
  font-size: 0.83rem;
  color: #888d96;
}
.nkc-grid-link {
  font-size: 1.05rem;
  font-weight: 600;
  color: #232527;            /* 검정색 계열 */
  margin: 0;
  line-height: 1.5;
  text-decoration: none;
  display: inline-block;
  transition: color .13s, text-decoration 0.13s;
}
.nkc-grid-link:hover { color: #0657bd; text-decoration: underline; }

/* 반응형 */
@media (max-width: 1200px) {
  .nkc-card-row { flex-direction: column; align-items: center; }
  .nkc-main-card { max-width: 600px; }
}
@media (max-width: 700px) {
  .nkc-main-card { padding: 1.2rem 0.6rem; }
  .nkc-main-title { font-size: 1.28rem; }
  .nkc-main-grid { grid-template-columns: 1fr; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3a134d8e *//* 전체 섹션 컨테이너 */
.nkc-newsletter-section {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 1rem;
  color: #fff;
}

/* ✅ 상단: 로고 + 제목 + 버튼 섹션 */
.nkc-newsletter-header {
  display: flex;
  flex-direction: column;
  padding: 2rem 1rem;
  background: #1A1A1A;
  border-bottom: 1px solid #fff;
  border-radius: 0;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
@media screen and (min-width: 600px) {
  .nkc-newsletter-header {
    flex-direction: row;
    padding: 0.6rem 2.5rem;
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem;
  }
}
@media screen and (max-width: 599px) {
  .nkc-newsletter-header,
  .nkc-follow-section {
    width: 100% !important;
    margin: 0 !important;
    padding-left: 1rem;
    padding-right: 1rem;
    box-sizing: border-box;
  }
  .nkc-newsletter-section {
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  body {
    overflow-x: hidden;
  }
}

/* ✅ 로고 및 텍스트 묶음 */
.nkc-logo-text {
  display: flex;
  align-items: center;
  gap: 1rem;
}

/* ✅ 로고 이미지 */
img.nkc-newsletter-logo {
  height: 80px;
}
@media screen and (min-width: 600px) {
  img.nkc-newsletter-logo {
    height: 124px;
  }
}
@media screen and (min-width: 900px) {
  img.nkc-newsletter-logo {
    height: 80px;
  }
}

/* ✅ 타이틀 */
.nkc-newsletter-title {
  font-weight: 900;
  font-size: 2rem;
  line-height: rem;
  margin: 0;
  color: #ffffff;
}

/* ✅ 부제목 */
.nkc-newsletter-subtitle {
  margin: 0.5rem 0;
  font-weight: 400;
  line-height: 1.5rem;
}

/* ✅ 부제목 (모바일 전용) */
.nkc-newsletter-desc-mobile {
  display: block;
  font-size: 0.875rem;
  margin: 0.5rem 0;
}
@media screen and (min-width: 600px) {
  .nkc-newsletter-desc-mobile {
    display: none;
  }
}

/* ✅ 버튼 전체 스타일 */
.nkc-subscribe-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  border: 1px solid white;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 700;
  padding: 0 1rem;
  height: 2.5rem;
  min-width: 10rem;
  width: 100%;
  text-decoration: none;
  color: white;
  transition: border-color 0.25s ease-in-out;
}
.nkc-subscribe-button:hover {
  border-color: rgba(255, 255, 255, 0.5);
  color: white;
}
.nkc-subscribe-text {
  color: white !important;
  transition: none !important;
}
.nkc-subscribe-icon {
  margin-left: 0.30rem;
  display: inline-flex;
  align-items: center;
}
.nkc-subscribe-icon svg {
  width: 1rem;
  height: 1rem;
  color: white;
  fill: currentColor;
  vertical-align: middle;
  transition: none;
}
@media screen and (min-width: 600px) {
  .nkc-subscribe-button {
    width: auto;
  }
}

/* ✅ 하단 팔로우 영역 */
.nkc-follow-section {
  display: flex;
  flex-direction: column;
  padding: 2rem 1rem;
  background: #1A1A1A;
  border-radius: 0;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
}
@media screen and (min-width: 600px) {
  .nkc-follow-section {
    flex-direction: row;
    padding: 2rem 2.5rem;
    border-bottom-left-radius: 1rem;
    border-bottom-right-radius: 1rem;
  }
}

.nkc-follow-text {
  text-align: center;
  margin: 0;
  font-size: 1.125rem;
  font-weight: 900;
}
@media screen and (min-width: 600px) {
  .nkc-follow-text {
    text-align: left;
    font-size: 1.25rem;
  }
}

.nkc-social-icons {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  align-items: center;
  color: white;
}
@media screen and (min-width: 600px) {
  .nkc-social-icons {
    flex-wrap: nowrap;
    gap: 1.5rem;
  }
}

.nkc-social-link {
  color: inherit;
  text-decoration: none;
  transition: opacity 0.2s ease-out;
}
.nkc-social-link:hover {
  opacity: 0.8;
}

.nkc-icon {
  width: 26px;
  height: 26px;
  fill: currentColor;
  color: white;
}

.nkc-icon-base {
  width: 1rem;
  height: 1rem;
  display: inline-block;
  line-height: 1em;
  flex-shrink: 0;
  color: currentColor;
  fill: currentColor;
  vertical-align: middle;
}

@media screen and (max-width: 599px) {
  .nkc-logo-text {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 0.75rem;
    flex-wrap: nowrap;
  }
  img.nkc-newsletter-logo {
    width: 100px;
    height: 100px;
    object-fit: contain;
    display: block;
    flex-shrink: 0;
  }
  .nkc-logo-text > .nkc-newsletter-title-wrap {
    flex: 1 1 auto;
    min-width: 0;
  }
  .nkc-newsletter-title {
    margin-top: 0.4rem;
    margin-bottom: 0.3rem;
    margin: 1.0rem;
    text-align: left;
  }
  .nkc-newsletter-subtitle {
    margin: 0;
    text-align: left;
  }
  .nkc-newsletter-desc-desktop {
    display: block;
    margin-top: 3rem;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  .nkc-newsletter-desc-mobile {
    display: block;
    font-size: 0.875rem;
    margin-top: 1.5rem;
    margin-bottom: 0.7rem;
  }
  .nkc-follow-text {
    text-align: left;
    margin: 0;
    font-size: 18px;
    font-weight: 800;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-5daa9bee *//* 섹션 래퍼 (최상위) */
.nkc-news-section {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  max-width: 90rem;
  margin: 4rem auto;
  padding: 0 1rem;
}

/* 헤더(타이틀+액션) */
.nkc-news-header {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2rem;
  min-width: 0;
}

.nkc-news-title {
  font-size: 40px;
  font-weight: 900;
  color: #000;
  margin: 0;
  line-height: 1.2;
  word-break: keep-all;
  flex: 1 1 auto;
  min-width: 0;
}

/* 버튼(모바일 아이콘) */
.nkc-btn-icon {
  display: flex;
  align-items: center;
  border: none !important;
  background: none !important;
  box-shadow: none !important;
  outline: none !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  color: #23406a;
  font-size: 1rem;
  min-width: 0 !important;
  width: auto !important;
  height: auto !important;
  text-decoration: none;
  cursor: pointer;
}
.nkc-btn-icon svg {
  width: 1em;
  height: 1em;
  display: block;
}
.nkc-btn-icon:hover,
.nkc-btn-icon:focus {
  background: none !important;
  color: #2d4b87;
  box-shadow: none !important;
  outline: none !important;
}

/* 버튼(PC 박스 스타일) */
.nkc-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  padding: 0.5rem 1.5rem;
  border-radius: 999px;
  font-weight: bold;
  font-size: 1rem;
  border: 1.5px solid #e0e6ef;
  color: #23406a;
  background: transparent;
  transition: background 0.2s, color 0.2s;
  text-decoration: none;
  cursor: pointer;
}
.nkc-btn__text {
  flex: 0 1 auto;
  text-align: center;
  width: 100%;
}
.nkc-btn__icon {
  display: flex;
  align-items: center;
  margin-left: 0.6em;
}
.nkc-btn__icon svg {
  width: 1rem;
  height: auto;
  display: block;
}
.nkc-btn:hover,
.nkc-btn:focus {
  background: #f4f8fc;
  color: #2d4b87;
}

/* 버튼: 모바일/PC 전환 */
.nkc-btn { display: none; }
.nkc-btn-icon { display: flex; }
@media (min-width: 600px) {
  .nkc-btn { display: flex; }
  .nkc-btn-icon { display: none; }
}

/* ======= 뉴스 리스트 ======= */
.nkc-news-list {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);  /* PC: 3단 */
  gap: 2rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.nkc-news-list li {
  border-bottom: 1px solid #e0e6ef;
  padding-bottom: 1.5rem;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.nkc-news-link {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  text-decoration: none;
}

.nkc-news-title-link {
  font-weight: 800;
  font-size: 1.15rem;
  color: #162145;
  margin-bottom: 0.2rem;
  line-height: 1.3;
  transition: color 0.2s;
}
.nkc-news-link:hover .nkc-news-title-link {
  color: #0d58bc;
}

.nkc-news-domain {
  color: #2d7be0;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
  opacity: 0.85;
  margin-top: 0.1rem;
  word-break: break-all;
}

/* ======= 반응형 (태블릿/모바일) ======= */
@media (max-width: 1023px) {
  .nkc-news-section {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }
  .nkc-news-list {
    grid-template-columns: repeat(2, 1fr);  /* 태블릿: 2단 */
    gap: 1.25rem;
  }
  .nkc-news-title { font-size: 2rem; }
}
@media (max-width: 599px) {
  .nkc-news-section {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .nkc-news-list {
    grid-template-columns: 1fr; /* 모바일: 1단 */
    gap: 1rem;
  }
  .nkc-news-title { font-size: 2rem; }
  .nkc-news-header { margin-bottom: 2rem; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-34df01f6 */.site-footer {
  width: 100%;
       /* 연한 회색+투명도 */
  color: #2d3748;             /* 진한 회색 텍스트 */
  font-family: 'Noto Sans KR', sans-serif;
  padding: 4rem 1.5rem 2rem;
  font-size: 1rem;
}

.footer-inner {
  max-width: 1280px;
  margin: 0 auto;
}

.footer-columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 2.5rem;
  margin-bottom: 3rem;
}

.footer-col h3 {
  font-size: 1.13rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: #22304e;      /* 약간 더 진한 네이비/블랙 */
}

.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-col li {
  margin-bottom: 0.4rem;
  line-height: 1.7;
  font-weight: 400;
  font-size: 0.97rem;
}

.footer-col a {
  text-decoration: none;
  color: #23313e;         /* 다크그레이 */
  transition: color 0.18s;
}

.footer-col a:hover {
  color: #000;
  font-weight: 900;/* hover: 진한 파랑 */
}

.footer-social {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}

.footer-social svg {
  width: 1.55rem;
  height: 1.55rem;
  color: #22304e;
  fill: #22304e;
}

.footer-bottom {
  font-size: 0.89rem;
  color: #4c5969;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.footer-bottom a {
  color: #23313e;
  text-decoration: none;
}

.footer-bottom a:hover {
  text-decoration: underline;
  color: #1860bf;
}

/* 반응형 */
@media (max-width: 1024px) {
  .footer-inner {
    max-width: 96vw;
  }
  .footer-columns {
    gap: 1.4rem;
  }
}
@media (max-width: 768px) {
  .site-footer {
    padding: 2.3rem 0.7rem 1.6rem;
  }
  .footer-columns {
    grid-template-columns: 1fr 1fr;
    gap: 1.1rem;
    margin-bottom: 2rem;
  }
  .footer-col h3 {
    font-size: 1.08rem;
    margin-bottom: 0.7rem;
  }
}
@media (max-width: 520px) {
  .footer-columns {
    grid-template-columns: 1fr;
    gap: 0.7rem;
    margin-bottom: 1.2rem;
  }
  .footer-col {
    margin-bottom: 1.3rem;
  }
  .site-footer {
    padding: 1.3rem 0 0.9rem;
    font-size: 0.98rem;
  }
  .footer-bottom {
    font-size: 0.82rem;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1321148 */:root{
  --nkc-black:#000;
  --nkc-black-900:#0f0f0f;
  --nkc-black-800:#1A1A1A;
  --nkc-grey-400:#b3b3b3;
  --nkc-grey-600:rgba(255,255,255,.56);
  --nkc-grey-700:rgba(255,255,255,.35);
  --nkc-border:rgba(255,255,255,.08);

  --gap-sm:16px;
  --gap-md:24px;
  --gap-lg:32px;

  --panel-width:22rem;         /* ≈ 352px */

  --dur-fast:.18s;
  --dur-mid:.25s;
  --half-offset: 200px;
}

#navbar_container {
  position: fixed;
  inset: 0 0 auto 0;
  height: 100px;
  z-index: 100;
  background: transparent;
  box-shadow: none;
  transition:
    background var(--dur-mid),
    box-shadow var(--dur-mid);
}
#navbar_container.is-sticky {
  background: #fff !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
  height: 68px; 
}
/* 기본(투명 헤더) 상태: 아주 옅은 흰색 */


/* ───────── Nav 내부 레이아웃 ───────── */
/* 1️⃣ 공통 정의 – border 존재(연한 흰색), 부드러운 전환 */
.navbar__container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  background: none;

  /* 경계선: 기본은 흰색 6 % 불투명 */
  border-bottom: 1px solid rgba(255,255,255,0.09);
  transition: border-color .25s;  /* 색상만 자연스럽게 바뀌도록 */
}

/* 2️⃣ 스크롤 후(sticky) – 어두운 선으로만 색상 덮어쓰기 */
#navbar_container.is-sticky .navbar__container {
  border-color: rgba(0,0,0,0.08);   /* 검정 8 % 불투명 */
}



/* ───────── 왼쪽 섹션: 햄버거 버튼 ───────── */
.navbar-section--left {
  display: flex;
  align-items: center;
  gap: var(--gap-sm);
  margin-left: var(--gap-lg);
}

/* ───────── 로고 (중앙 정렬) ───────── */
.navbar__logo--link {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
}
.navbar__logo--link img {
  height: 70px;
  width: auto;
  object-fit: contain;
}

/* 듀얼 로고(스크롤 전/후) */
.navbar__logo--link .logo--white {
  display: block;
}
.navbar__logo--link .logo--black {
  display: none;
}
#navbar_container.is-sticky .logo--white {
  display: none;
}
#navbar_container.is-sticky .logo--black {
  display: block;
}
#navbar_container.is-sticky .navbar__logo--link img {
  height: 56px;
}

/* ───────── 햄버거 버튼 ───────── */
.navbar-button--square {
  padding: 10px 8px;
  border: none;
  border-radius: 5px;
  background: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  transition: background var(--dur-fast);
}
/* ───────── 768px 이하(모바일) ───────── */
@media (max-width: 768px) {

  /* 1) 버튼이 들어 있는 래퍼 자체를 왼쪽에 붙이기 */
  .navbar-section--left { margin-left: 20px; }

  /* 2) 버튼과 화면 사이 여백도 0으로 */
  .navbar-button--square { padding-left: 0; }
}

.navbar-button--square:hover {
  background: #efefef;
}

/* 버튼 내부 아이콘 색상 */
.navbar-button--square svg {
  color: #fff;
  transition: color var(--dur-fast);
}
#navbar_container.is-sticky .navbar-button--square svg {
  color: #222;
}

/* =============================================================
   ┃ 2. Mega-menu 컨테이너 & 딤(오버레이)
============================================================= */

/* ───────── Mega-menu 패널 ───────── */
.nav-menu__container {
  position: fixed;
  top: 0;
  left: 0;
  width: clamp(880px, 96vw, 1000px);
  max-width: 100vw;
height: 100dvh;
height: calc(var(--vh, 1vh) * 100);
  background: var(--nkc-black);
  color: #fff;
  border-right: 1px solid var(--nkc-black-800);
  z-index: 102;
  display: flex;
  flex-direction: column;
 overflow-y: hidden;             overscroll-behavior: contain; 
  transform: translateX(-110%);
  transition:
    transform .35s cubic-bezier(.65, .05, .36, 1);
}
.nav-menu__container[aria-hidden="false"] {
  transform: translateX(0);
}

/* ───────── 딤/오버레이 ───────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.64);
  z-index: 101;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-mid);
}
.modal-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

/* =============================================================
   ┃ 3. 메뉴 헤드 (닫기 · 검색)
============================================================= */

/* ───────── 헤더 바 전체 ───────── */
.menu-head {
  position: relative;
  flex-shrink: 0;
  height: 99px;
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--nkc-black);
  background: #000;
  padding: 0 var(--gap-md);
}

/* ───────── 닫기 버튼 패널 ───────── */
.menu-close {
  width: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px solid var(--nkc-black-800);
}
.menu-close__button {
  background: inherit;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  padding: 12px;
  transition: background var(--dur-fast);
}
.menu-close__button:hover {
  background: #222;
}

/* ───────── 검색 패널 ───────── */
.menu-search {
  flex: 1;
  display: flex;
  align-items: center;
}
.menu-search__content {
    flex:1 1 auto;
  display: flex;
  align-items: center;
  gap: .5rem;
  height: 99px;
  margin-left: var(--gap-md);
}
.menu-search__search-button {
  background: inherit;
  border: none;
  border-radius: 5px;
  padding: 10px;
  cursor: pointer;
  transition: background var(--dur-fast);
}
.menu-search__search-button:hover {
  background: #1a1a1a;
}

.menu-search__input,
input[type=search] {
    width:100%; flex:1 1 auto; min-width:0;
       
  max-width: 100vw;
  background: #000 !important;
  color: #fff !important;
  caret-color: #fff !important;
  border: none;
  outline: none;
  box-shadow: none;
  font: 600 1.1rem/1 Pretendard, sans-serif;
  padding: 10px 16px;
  border-radius: 8px;
  box-sizing: border-box;
  transition:
    background var(--dur-fast),
    color var(--dur-fast),
    box-shadow var(--dur-fast);
}
.menu-search__input,
input[type="search"] {
  border: none !important;        /* 크롬·파폭 */
  outline: none !important;       /* 포커스 테두리 */
  box-shadow: none !important;    /* iOS·사파리 테두리 대용 */
  -webkit-appearance: none;       /* 사파리 기본 테두리 제거 */
}
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
  display: none;
}
.menu-search__input::placeholder,
input[type=search]::placeholder {
  color: #b3b3b3;
  opacity: .8;
}
.menu-search__input:not(:focus),
input[type=search]:not(:focus) {
  caret-color: transparent !important;   /* 포커스 안 됐을 때 커서 완전 숨김 */
}

.menu-search__input:focus,
input[type=search]:focus {
  caret-color: #fff !important;          /* 포커스(클릭) 때만 흰색 커서 */
}

.menu-head,
.menu-search,
.menu-search__content {
  background: #000 !important;
}

/* =============================================================
   ┃ 4. 메뉴 바디 (2‑패널)
============================================================= */

/* ───────── 메뉴 바디 전체 (2패널 구조) ───────── */
.menu-body {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  overscroll-behavior: contain;
}

/* ───────── 좌측: 카테고리 패널 ───────── */
.category-panel {
  width: var(--panel-width);
  min-width: 240px;
  max-width: 28rem;
  background: var(--nkc-black-900);
  border-right: 1px solid var(--nkc-border);
  display: flex;
  flex-direction: column;
}
.category-panel__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}
.category-panel__body,
.category-item-panel {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;   /* ← iOS 모멘텀 스크롤 활성 */
  overscroll-behavior: contain;        /* 체인 방지(기존 유지) */
}

/* 카테고리 버튼 */
.category {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 64px;
  padding: 0 var(--gap-md) 0 calc(var(--gap-md) + 8px);
  font: 500 24px/64px Pretendard, sans-serif;
  letter-spacing: .4px;
  color: var(--nkc-grey-400);
  background: transparent;
  transition:
    background var(--dur-fast),
    color var(--dur-fast);
  cursor: pointer;
  user-select: none;
  text-decoration: none !important;
}
.category:hover {
  background: #333;
  color: #fff;
}
.category.active {
  background: #232323;
  color: #fff;
}

/* 카테고리 화살표 */
.category__arrow {
  width: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: -10px;
  opacity: .35;
  transition:
    opacity var(--dur-fast),
    transform var(--dur-fast);
}
.category__arrow svg {
  width: 8px;
  height: 14px;
}
.category:hover .category__arrow {
  opacity: 1;
  transform: translateX(4px);
}
.category.active .category__arrow {
  opacity: 1;
  transform: none;
}

/* 카테고리 타이틀 */
.category__title {
  text-decoration: none !important;
}

/* ───────── 우측: 카테고리 아이템 패널 ───────── */
.category-item-panel {
  flex: 1;
  min-width: 0;
  background: var(--nkc-black);
  padding: 34px var(--gap-lg);
  overflow-y: auto;
  width: 1800px;
  max-width: calc(100vw - var(--panel-width) - 1rem);
  display: none;
}
.category-item-panel.is-active {
  display: block;
}

/* 패널 헤더 및 뒤로가기 */
.panel-header {
  display: none;
  margin-bottom: 32px;
}
.panel-back {
  background: none;
  border: none;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 8px;
  font: 500 16px/1 Pretendard, sans-serif;
  cursor: pointer;
  padding: 0;
  transition: color var(--dur-fast);
}
.panel-back:hover {
  color: #6bc1ff;
}

/* ───────── 카테고리 아이템 리스트 ───────── */
.category-item__listing {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.category-item {
  display: flex;
  align-items: center;
  gap: 24px;
  text-decoration: none;
  border-radius: 7px;
  transition: background var(--dur-fast);
}
.category-item:hover {
  background: #181818;
}

/* 썸네일 */
.category-item__thumbnail {
  width: 120px;
  height: 120px;
  border-radius: 8px;
  overflow: hidden;
  background: #232323;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.category-item__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 컨텐츠(텍스트) */
.category-item__content {
  font: 900 16px/1 Pretendard, sans-serif;
  color: #fff;
}

/* =============================================================
   ┃ 5. 소셜 푸터
============================================================= */

/* ───────── 푸터 전체 ───────── */
.menu-body__footer {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--gap-sm);
  padding: 20px var(--gap-lg);
  border-top: 1px solid var(--nkc-border);
  background: var(--nkc-black);
  min-height: 62px;
}

/* ───────── 소셜 아이콘 버튼 ───────── */
.social-media__item {
  background: none;
  border: none;
  border-radius: 8px;

  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background var(--dur-fast);
}
.social-media__item svg {
  width: 22px !important;
  height: 20px !important;
}
.social-media__item:hover {
  background: #161616;
}
.social-media__item:hover svg {
  fill: #fff;
}

/* =============================================================
   ┃ 6. 반응형 (Tablet · Mobile)
============================================================= */

/* ───────── 1040px 이하 (PC ~ 태블릿) ───────── */
@media (max-width: 1040px) {
  .nav-menu__container {
    width: 100vw !important;
  }
  .category-panel {
    width: clamp(200px, 30vw, 240px);
  }
  .category-item-panel {
    width: calc(100vw - clamp(200px, 30vw, 240px));
    padding: 24px 8px;
  }
  .menu-search__input,
  input[type=search] {
    width: 220px;
  }
}


/* ───────── 1023.98px 이하 (태블릿 이하) ───────── */
@media (max-width: 1023.98px) {
  /* 헤더: 세로 스택 */
  .menu-head {
    flex-direction: column;
    height: auto;
    padding: 0;
  }
  /* 닫기(X) 버튼 라인 */
  .menu-close {
    width: 100%;
    height: 72px;
    border: none;
   justify-content: flex-start;
   margin-left: 20px;
  }
  .menu-close__button {
    padding: 0;
  }
  /* 검색 라인 */
  .menu-search {
    width: 100%;
  }
  .menu-search__content {
    height: 72px;
    margin-left: 0;
    padding: 0 12px;
    border-top: 1px solid var(--nkc-border);
  }
  .menu-search__input {
    width: 100%;
  }
  /* 카테고리 행 크기 */
  .category {
    height: 72px;
    padding: 0 24px;
    font: 400 24px/72px Pretendard, sans-serif;
    letter-spacing: .2px;
  }
  /* Back 헤더 노출 */
  .panel-header {
    display: flex;
    height: 72px;
    align-items: center;
    padding: 0 24px;
    border-bottom: 1px solid var(--nkc-border);
  }
  .panel-back svg {
    width: 22px;
    height: 22px;
    stroke: #fff;
  }
  /* 단열 레이아웃 (세로 쌓기) */
  .menu-body {
    flex-direction: column;
  }
  .category-panel,
  .category-item-panel,
  .menu-body__footer,
  .nav-menu__container {
    width: 100vw !important;
    left: 0 !important;
    max-width: 100vw !important;
  }
  .category-item-panel {
    padding: 20px 10px;
  }
  .menu-search__input,
  input[type=search] {
    width: 90vw;
  }
}

/* ───────── 480px 이하 (모바일) ───────── */
@media (max-width: 480px) {
  .category-item__content {
    font-size: 15px;
  }
  .category-item__thumbnail {
    width: 114px;
    height: 114px;
  }
 input[type=search] {
    width: 290px;
    max-width: 100vw;
  }
  .navbar__logo--link img {
    height: 56px;  
}
}
/* =============================================================
   ┃ 7. 전역 리셋
============================================================= */
html, body {
  width: 100vw;
  min-height: 100vh;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  box-sizing: border-box;
}
body {
  font-family: 'Pretendard', 'Noto Sans KR', Arial, sans-serif;
}
.globalnav-root {
  z-index: 100 !important;
}
.navigation-menu {
  outline: none !important;
}
/* 링크 전역: 밑줄 제거 */
.category,
.category:visited,
.category__title,
.category__title:visited {
  text-decoration: none !important;
}

/* ========================================
   1) WebKit(Chrome · Edge · Safari 등)
======================================== */
.category-panel__body,
.category-item-panel {
  /* 기본값: 얇은 오버레이 느낌 */
  scrollbar-width: thin;                 /* ← Firefox용(아래 2번)도 함께 처리 */
  scrollbar-gutter: stable;              /* 내용 흔들림 방지 */

  /* 색상 변경(선택) */
  --scroll-track:  var(--nkc-black-800); /* 트랙 */
  --scroll-thumb:  #6bc1ff;              /* 엄지(thumb) */
}

/* 세로 스크롤바 공통 */
.category-panel__body::-webkit-scrollbar,
.category-item-panel::-webkit-scrollbar {
  width: 10px;          /* 굵기 */
}
/* 트랙(배경) */
.category-panel__body::-webkit-scrollbar-track,
.category-item-panel::-webkit-scrollbar-track {
  background: var(--scroll-track);
}
/* 엄지(thumb) */
.category-panel__body::-webkit-scrollbar-thumb,
.category-item-panel::-webkit-scrollbar-thumb {
  background-color: var(--scroll-thumb);
  border-radius: 6px;
  border: 2px solid var(--scroll-track); /* padding 효과 */
  transition: background-color .18s;
}
/* 호버 시 강조 */
.category-panel__body:hover::-webkit-scrollbar-thumb,
.category-item-panel:hover::-webkit-scrollbar-thumb {
  background-color: #91d4ff;
}

/* ========================================
   2) Firefox 전용(앞서 지정한 색상을 그대로 사용)
======================================== */
@supports (scrollbar-color: red blue) {
  .category-panel__body,
  .category-item-panel {
    scrollbar-color: var(--scroll-thumb) var(--scroll-track); /* thumb · track */
    scrollbar-width: thin;           /* none | thin | auto  */
  }
}/* End custom CSS */