/* =============================================================
 * custom.css  —  Intra v2 커스텀 스타일 (메인/공통/푸터 외)
 *
 * 의존: _tokens.css (색상/폰트/간격/반경/그림자/브레이크포인트 변수)
 * 로드: functions.php → intra_enqueue_global_extra_css()
 *
 * 브레이크포인트 표준 (6단)
 *   ≤ 480px   xs    소형 모바일
 *   ≤ 768px   sm    모바일 (세로)
 *   ≤ 1024px  md    태블릿 가로 / 소형 노트북
 *   ≤ 1280px  lg    노트북 / 데스크톱 기본
 *   ≤ 1400px  xl    데스크톱
 *   ≤ 1920px  ultra 대형 모니터
 *
 * 치환 정책
 *   - 색상(#hex, rgba 주요값) → var(--color-*) / var(--rgb-*)
 *   - font-size / font-weight → var(--fs-*) / var(--fw-*)
 *   - 주석 영역은 원문 보존 (한글 UTF-8)
 *   - !important 는 기존 동작 유지를 위해 그대로 둠
 * ============================================================= */

.logo-area {
  margin: 40px auto 30px;
}

.top-bar {
  right: 10%;
}

.header-login {
  display: none;
}

/* 로고 black, 배경 white */
.logo-header {
  background: var(--color-white);
}

.date-info span {
  color: var(--color-black);
}

.date-info i {
  color: var(--color-black);
}

.login-link,
.profile-link {
  color: var(--color-black);
  background: var(--color-gray-eee);
}

.main-nav {
  background: var(--color-white);
  border-top: 1px solid rgba(var(--rgb-black), .1);
}

.menu-items {
  justify-content: initial;
}

.menu-item {
  flex: 1 0 auto;
  margin-left: initial;
}

.menu-item a {
  color: var(--color-black);
  font-weight: var(--fw-black);
  font-size: var(--fs-xl);
  text-align: center;
  padding: 15px 0;
}

.menu-item a:hover,
.menu-item.current-menu-item a {
  color: var(--color-black);
  background: var(--color-gray-eee);
}

.trendy-magazine-header {
  box-shadow: 0 4px 10px rgba(var(--rgb-black), .1);
}

/* Hub 접기/펼치기 */
.hub-toggle {
  margin-left: auto;
  padding: 4px 12px;
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  color: var(--color-gray-555);
  background: var(--color-gray-f1);
  border: 1px solid #ddd;
  border-radius: 4px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.2s;
}
.hub-toggle:hover {
  background: #e4e4e4;
}
.hub-body {
  overflow: hidden;
  opacity: 1;
  transition: opacity 0.2s ease;
}
.hub-body.is-collapsed {
  display: none;
  opacity: 0;
}

.sub-menu.pop {
  background: var(--color-white);
  border-color: #ccc;
  width: 100%;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
}

/* 2depth 탭 행: 데스크탑에서 완전 숨김 */
.nav-sub-row {
  display: none;
}

/* 2depth 화살표: 데스크탑에서 완전 숨김 (모바일 전용 UI) */
.main-nav .menu-item.has-children > a .nav-arrow {
  display: none;
}

@media (max-width: 1024px) {
  .nav-sub-row {
    display: block;
  }
}

/* 모바일 메뉴 */
.mobile-menu-btn span {
  background: var(--color-black);
  width: 20px;
}

.mobile-menu-header {
  background: var(--color-white);
}

#mobile-menu-btn-box.sticky .mobile-menu-btn span {
  background: var(--color-white);
}

.close-menu {
  color: var(--color-black);
}

.mm-sub-category-list {
  display: none;
  padding-left: 16px;
}

.mm-category-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.mm-category-row a {
  display: block;
  padding: 12px 0;
  flex: 1;
}

.mm-toggle {
  border: none;
  background: none;
  padding: 10px;
  cursor: pointer;
}

.mm-toggle i {
  transition: 0.25s;
}

.mm-category-item.open .mm-toggle i {
  transform: rotate(180deg);
}


/* 메인 페이지 start ------------------------------------------------------------- */
.section-title {
  width: 100%;
}

.content-row {
  gap: 1.5rem;
  height: auto;
  margin-bottom: 1.875rem;
}

.main-text-item>div:first-child {
  width: calc(10% - .4rem);
}

.content-row>div:last-child {
  gap: 4rem;
}

/* 최신뉴스 */
.section-title:after {
  width: 60px;
}

.news-content .excerpt {
  margin-top: 6px;
  font-size: var(--fs-base);
  line-height: 1.5;
  color: var(--color-gray-500);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  /* 2줄 제한 */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news-content .excerpt a {
  color: inherit;
  text-decoration: none;
}

/* 주요뉴스 */
.section-title:after {
  width: 60px;
}

.main-text-item>div:first-child {
  width: initial;
}

.main-text-excerpt {
  margin-top: 4px;
  font-size: var(--fs-base);
  line-height: 1.55;
  color: var(--color-gray-500);

  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.main-text-excerpt a {
  display: block;
  color: inherit;
  text-decoration: none;
}

.main-text-item>div:nth-child(2) {
  width: calc(86% - .5rem);
}


/* 지금 트렌드 */
.section-title:after {
  width: 60px;
}

.trending-section {
  margin-bottom: initial;
}

.trend-excerpt {
  margin-top: 4px;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--color-gray-500);

  display: -webkit-box;
  -webkit-line-clamp: 2;
  /* 모바일에서도 깔끔 */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.trend-excerpt a {
  color: inherit;
  text-decoration: none;
}

.news-content,
.popular-news-content,
.trend-text-content {
  flex: initial;
  width: initial;
}

/* 포토뉴스 */
.pn-header {
  margin: 0 0 1.5rem 0;
}

.pn-container {
  margin: 0 auto 4rem;
}

.pn-title {
  padding-left: initial;

}

.pn-title:before {
  bottom: -10px;
  top: initial;
  transform: initial;
  width: 60px;
  height: 3px;
  border-radius: initial;
}

/* 에디터's 프리뷰 */
.insight-section {
  max-width: 1400px;
  margin: 50px auto;
}

.insight-title {
  font-size: var(--fs-4xl);
  font-weight: var(--fw-bold);
  margin-bottom: 20px;
  position: relative;
  border-bottom: 2px solid #e0e0e0;
  padding-bottom: 8px;
}

.insight-title::before {
  margin-right: 5px;
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 60px;
  height: 3px;
  background-color: var(--color-primary-dark);
}


.insight-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 20px;
}

.insight-col {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.insight-item {
  position: relative;
  border-bottom: 1px solid var(--color-gray-f1);
  min-height: 60px;
  padding-bottom: 16px;
}

.insight-item:first-of-type {
  padding-bottom: 16px;
}

.insight-item::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background-color: #e01e1e;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.35s ease;
}

.insight-item:hover::after {
  transform: scaleX(1);
}

.insight-item.big {
  border-bottom: none;
}

.insight-item .title {
  font-size: var(--fs-xl);
  font-weight: var(--fw-semibold);
  line-height: 1.4;
  color: var(--color-black);
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  word-break: break-word;
}

.insight-item.big .title {
  font-size: var(--fs-3xl);
  margin-top: 12px;
}

.insight-item.small .title {
  margin-top: 8px;
}

.insight-item .thumb {
  display: block;
  overflow: hidden;
}

.insight-item.small .thumb {
  aspect-ratio: 16 / 9;
}

.insight-item.big .thumb {
  aspect-ratio: 16 / 8;
}

.insight-item.big .excerpt {
  margin-top: 8px;
  font-size: var(--fs-md);
  line-height: 1.6;
  color: var(--color-gray-555);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.insight-item .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  contain-intrinsic-size: revert;
  transition: transform 0.35s ease, filter 0.35s ease;
  will-change: transform;
}

.insight-item:hover .thumb img {
  transform: translateY(-8px) scale(1.03);
  filter: brightness(1);
}

/* 많이 본 뉴스 */
.most-viewed-header {
  margin-bottom: 2rem;
}

.most-viewed-wrapper {
  margin-bottom: 5rem;
}

.news-layout-container {
  margin: 3rem auto;
}

.main-text-item {
  padding: .5rem 0;
}

.news-item,
.popular-news-item,
.trend-item {
  padding: .5rem 0;
}

.text-box {
  white-space: initial;
}

.most-viewed-title {
  font-size: var(--fs-4xl);
  font-family: var(--td_default_google_font_2);
  color: #222;
  font-weight: var(--fw-bold);
  padding-bottom: initial
}

.most-viewed-title:after {
  content: none;
}

.most-viewed-title:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: -10px;
  width: 60px;
  height: 3px;
  background-color: var(--color-primary-dark);
}

/* 카테고리 별 (insight.php) */

.news-wrapper.custom-box {
  margin-bottom: 100px;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.category-row {
  display: flex;
  gap: 1.2rem;
}

.category-item {
  flex: 1;
  background: var(--color-white);
  border-radius: 12px;
  padding: 1rem;
}

.category-row.row-3>.category-item {
  flex-basis: calc(33.333% - 0.8rem);
}

.category-row.row-2>.category-item {
  flex-basis: calc(50% - 0.6rem);
}

.articles-container {
  display: flex;
  flex-direction: column;
  padding-top: initial;
  gap: initial;
}

.category-header {
  margin-bottom: 12px;
}

.category-header a::before {
  content: none;
}

/* 많이 본 뉴스 6번째 카드 숨기기 → 5개만 보임 */
.most-viewed-card:nth-child(6) {
  display: none;
}

/* 카테고리 별 레이아웃 */
.news-wrapper {
  margin: 4.5rem auto;
}

.custom-box .category-section {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.category-header h2 {
  font-size: var(--fs-4xl);
  color: #222;
  font-weight: var(--fw-semibold);
  position: relative;
}

.category-header h2::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #eaeaea;
}

.category-header h2::after {
  margin-right: 5px;
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 30px;
  height: 3px;
  background-color: var(--color-primary-dark);
}

.category-header a:after {
  font-weight: var(--fw-bold);
  font-size: 2rem;
}

.category-item {
  width: 100%;
  box-shadow: none;
}

.article-item {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid var(--color-gray-eee);
  border-radius: initial;
  gap: initial;
  padding-bottom: 6px;
}

.article-item:hover {
  background: none;
}

.article-item>div {
  min-height: 48px;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}

.article-item div {
  width: 100%;
}

.article-item:hover .image-container img {
  transform: scale(1.1);
}

.article-text a {
  font-size: var(--fs-xl);
  font-weight: var(--fw-black);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.article-date {
  font-size: .8rem;
  margin-top: 0;
}

.image-container {
  width: 100%;
  height: 200px;
  overflow: hidden;
  border-radius: 6px;
  box-shadow: none;
  margin-bottom: 8px;
}

.image-container img {
  object-fit: cover;
  object-position: center;
}

.articles-container .article-item:not(:first-child) .image-container {
  display: none;
}

.articles-container .article-item:not(:first-child)>div {
  flex: 1;
}


/* mobile-menu */
/* 접근성 */
.mm-sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* body 스크롤 잠금 */
body.mm-lock {
  position: fixed;
  width: 100%;
  overflow: hidden;
}

/* 오버레이 */
.mobile-menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(var(--rgb-black), .45);
  z-index: 9998;
}

/* 메뉴 패널 */
.mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: min(86vw, 360px);
  height: 100dvh;
  overscroll-behavior: contain;
  background: var(--color-white);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  transform: translateX(-100%);
  transition: transform .5s ease;
  box-shadow: 16px 0 40px rgba(var(--rgb-black), .12);
}

/* 열린 상태 */
.mobile-menu.active {
  transform: translateX(0);
}

/* 헤더/푸터 고정 */
.mobile-menu-header,
.mobile-menu-footer {
  flex: 0 0 auto;
  background: var(--color-white);
}

.mobile-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 14px;
  border-bottom: 1px solid rgba(var(--rgb-slate), .08);
}

.close-menu {
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
}

/* 가운데 스크롤 영역 */
.mobile-menu-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding: 14px 14px calc(18px + env(safe-area-inset-bottom));
}

/* 검색 */
.mm-search {
  display: grid;
  grid-template-columns: 1fr 44px;
  gap: 10px;
  margin-top: 4px;
}

.mm-search-input {
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(var(--rgb-slate), .12);
  padding: 0 12px;
  font-size: var(--fs-md);
  outline: none;
}

.mm-search-input:focus {
  border-color: rgba(1, 130, 214, .45);
  box-shadow: 0 0 0 4px rgba(1, 130, 214, .12);
}

.mm-search-button {
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(var(--rgb-slate), .12);
  background: var(--color-white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* 섹션 */
.mm-section {
  margin-top: 14px;
}

.mobile-menu-title {
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  color: rgba(var(--rgb-slate), .70);
  margin: 0 0 10px;
}

/* 추천 태그 */
.mm-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.mm-tag {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(1, 130, 214, .18);
  background: rgba(1, 130, 214, .06);
  color: rgba(var(--rgb-slate), .90);
  font-size: var(--fs-base);
  text-decoration: none;
}

/* 추천검색어 영역 */
.mm-tags-wrap {
  overflow: hidden;
  max-height: calc(36px * 1 + 8px);
  /* 기본적 1줄만 */
  transition: max-height .25s ease;
}

/* 펼쳐진 상태 */
.mm-tags-wrap.is-open {
  max-height: 500px;
  /* 충분히 크게 */
}

/* 펼치기 버튼 */
.mm-tags-toggle {
  margin-top: 8px;
  background: none;
  border: none;
  padding: 6px 0;
  font-size: var(--fs-base);
  color: rgba(var(--rgb-slate), .65);
  display: flex;
  align-items: center;
  gap: 2px;
  cursor: pointer;
}

.mm-tags-toggle i {
  transition: transform .2s ease;
  margin-top: 2px;
}

/* 아이콘 회전 */
.mm-tags-toggle.is-open i {
  /* transform: rotate(180deg); */
}


/* 카테고리 */
.mobile-category-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(var(--rgb-slate), .08);
  border-radius: 14px;
  overflow: hidden;
}

.mobile-category-list li+li {
  border-top: 1px solid rgba(var(--rgb-slate), .08);
}

.mobile-category-list a {
  display: flex;
  align-items: center;
  min-height: 48px;
  padding: 0 14px;
  text-decoration: none;
  color: rgba(var(--rgb-slate), .92);
  font-size: var(--fs-lg);
}

@media (hover: none) and (pointer: coarse) {
  .mobile-category-list a:hover {
    color: inherit !important;
    padding: 0 14px !important;
  }
}

/* 하단 로그인/프로필 */
.mobile-menu-footer {
  border-top: 1px solid rgba(var(--rgb-slate), .08);
  padding: 10px 14px calc(14px + env(safe-area-inset-bottom));
}

.mm-user-link {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 0 12px;
  border-radius: 14px;
  text-decoration: none;
  background: rgba(var(--rgb-slate), .03);
  color: rgba(var(--rgb-slate), .92);
  border: 1px solid rgba(var(--rgb-slate), .06);

  min-height: 52px;

}

/* 메인 페이지 end ------------------------------------------------------------- */

/* footer 디자인 수정 */
.hd-magazine-footer {
  background: var(--color-white);
  padding: 60px 0 0;
}

.hd-magazine-footer::before {
  background: var(--color-gray-333);
}

.hd-magazine-footer .hd-footer-info a {
  color: rgba(var(--rgb-black), .9);
  text-decoration: none;
  transition: color 140ms ease;
}

.hd-magazine-footer .hd-footer-info a:hover,
.hd-magazine-footer .hd-footer-info a:focus-visible {
  color: var(--color-primary, #e53935);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.hd-footer-container {
  text-align: center;
  max-width: 1400px;
}

.hd-footer-top {
  flex-direction: column;
  padding-bottom: 20px;
  margin-bottom: 8px;
}

/* 로고 영역 */
.hd-footer-logo-container {
  margin-bottom: 20px;
}

.hd-footer-logo-container img {
  width: 80%;
  height: initial;
  margin: 0 auto;
}

/*
 * 실제 마크업은 <nav class="hd-footer-nav"> > <ul class="hd-footer-nav__list"> > <li>
 * 이므로 nav 자체가 아닌 __list 에 레이아웃을 적용해야 한다.
 * (부모 newspaper.min.css 의 `.hd-footer-nav a { color:#fff }` 를 덮기 위해
 *  selector 를 충분히 특정화.)
 */
.hd-magazine-footer .hd-footer-nav {
  display: block;
}

.hd-magazine-footer .hd-footer-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 14px 40px;
  justify-content: center;
}

.hd-magazine-footer .hd-footer-nav__list > li {
  position: relative;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hd-magazine-footer .hd-footer-nav__list > li > a {
  display: block;
  color: var(--color-gray-800);
  font-weight: 600;
  text-decoration: none;
  padding: 4px 2px;
  transition: color 140ms ease;
}

/* 서브 카테고리는 푸터에서 숨김 (상위만 노출) */
.hd-magazine-footer .hd-footer-nav__sublist {
  display: none;
}

.hd-magazine-footer .hd-footer-nav a:hover,
.hd-magazine-footer .hd-footer-nav a:focus-visible {
  color: var(--color-primary, #e53935);
}

/* 회사 정보 영역 */
.hd-footer-info {
  color: #777;
  font-size: var(--fs-base);
  line-height: 2;
  margin-top: 0;
  margin-bottom: 40px;
}

.hd-footer-company {
  margin-bottom: 10px;
  display: inline-block;
  width: 100%;
}

.hd-footer-company span {
  position: relative;
  padding: 0 10px;
  white-space: nowrap;
}

.hd-footer-company span:not(:last-child)::after {
  content: '';
  position: absolute;
  right: -2px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 12px;
  background: #ccc;
}

.hd-footer-company span:hover {
  color: var(--color-gray-333);
}

/* DMCA 배지 & 카피라이트 */
.hd-copyright {
  flex-direction: column;
  gap: 10px;
  font-size: var(--fs-base);
  border-top: 1px solid var(--color-gray-eee);
  margin-top: 0;
  color: var(--color-gray-333);
}

.dcma_badge a {
  display: flex;
  justify-content: center;
}

.dcma_badge a img {
  width: 20%;
}

.hd-magazine-footer .hd-footer-info .hd-social-icon {
  background: var(--color-gray-eee);
  color: rgba(var(--rgb-black), .72);
  text-decoration: none;
  transition: background-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.hd-magazine-footer .hd-footer-info .hd-social-icon:hover,
.hd-magazine-footer .hd-footer-info .hd-social-icon:focus-visible {
  background-color: var(--color-primary, #e53935);
  color: #fff;
  text-decoration: none;
  transform: translateY(-1px);
}

/* 반응형(메인/푸터) */
@media (max-width: 1400px) {
  .top-bar {
    right: 10px;
  }

  .news-layout-container {
    width: 95%;
    margin: 2rem auto 2rem;
  }

  .pn-container {
    width: 95%;
  }

  .most-viewed-wrapper {
    width: 95%;
  }

  .news-wrapper {
    width: 95%;
  }

  .news-content .title a,
  .popular-news-content .pop-title a,
  .trend-text a {
    display: -webkit-box;
    word-wrap: break-word;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
    overflow: hidden;
  }

  .insight-section {
    padding: 0 30px;
  }
}

@media (max-width: 1280px) {
  .most-viewed-card:nth-child(6) {
    display: block;
  }
}

@media (max-width: 1024px) {
  .date-info {
    display: none;
  }

  /* 주요뉴스 / 최신뉴스 / 지금 트렌드 순 */
  .content-row>div:nth-child(2) {
    order: 1;
  }

  .content-row>div:first-child {
    order: 2;
  }

  .content-row>div:last-child {
    order: 3;
  }



  /* 최신뉴스, 지금트렌드 */

  .items-wrapper {
    gap: 1rem;
    flex-wrap: wrap;
    flex-direction: row;
  }

  .news-item,
  .popular-news-item,
  .trend-item,
  .trending-section .trend-item {
    width: calc(100% / 2 - .5rem);
  }

  /* 주요뉴스 */
  .main-text-item {
    margin-top: 12px;
  }

  .main-text-item>div:nth-child(2) {
    width: 100%;
  }

  .main-text-item>div:first-child {
    padding: initial;
  }

  .main-text-item>div:last-child {
    width: 100%;
  }

  .main-text-item {
    align-items: center;
    gap: initial;
  }

  .main-text-title a {
    text-align: initial;
  }


  .content-row {
    gap: 2.5rem;
  }

  /* 카테고리 별 (insight.php) */
  .category-row.row-3>.category-item,
  .category-row.row-2>.category-item {
    flex-basis: calc(50% - 0.6rem);
  }

  .insight-section {
    width: 92%;
    padding: initial;
  }

  .insight-grid {
    grid-template-columns: 1fr;
  }

  .insight-col {
    gap: 12px;
  }

  .insight-item.big .title {
    font-size: var(--fs-2xl);
  }

  /* 헤더 카테고리 */

  .main-nav {
    overflow-x: hidden;
  }

  .main-nav .container {
    padding: initial;
  }

  .main-nav .nav-menu {
    overflow-x: hidden;
  }

  /* 모바일 2depth 탭 행 */
  .nav-sub-row {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.22s ease;
    background: #f5f5f5;
    border-top: 1px solid #e8e8e8;
  }

  .nav-sub-row.is-open {
    max-height: 48px;
  }

  .sub-panel {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0 8px;
    align-items: center;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    height: 44px;
  }

  .sub-panel::-webkit-scrollbar {
    display: none;
  }

  .sub-panel.is-active {
    display: flex;
  }

  .sub-panel li {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .sub-panel li a {
    display: flex;
    align-items: center;
    height: 44px;
    padding: 0 12px;
    font-size: var(--fs-base);
    font-weight: var(--fw-medium);
    color: var(--color-gray-555);
    text-decoration: none;
    white-space: nowrap;
    transition: color 0.2s;
  }

  .sub-panel li.current-sub-item a,
  .sub-panel li a:hover {
    color: var(--color-primary-alt);
    font-weight: var(--fw-bold);
  }

  .main-nav .menu-item.sub-open > a {
    color: var(--color-primary-alt) !important;
  }

  /* 2depth 있는 항목 화살표 버튼 */
  .main-nav .menu-item.has-children > a {
    padding-right: 6px;
  }
  .main-nav .menu-item.has-children > a .nav-arrow {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    margin-left: 4px;
    border-radius: 50%;
    color: var(--color-gray-500);
    font-size: var(--fs-xs);
    line-height: 1;
    cursor: pointer;
    transition: background 0.18s ease, color 0.18s ease, transform 0.2s ease;
    -webkit-tap-highlight-color: transparent;
  }
  /* 탭 영역 확장 (시각적 크기는 유지) */
  .main-nav .menu-item.has-children > a .nav-arrow::before {
    content: '';
    position: absolute;
    inset: -8px -6px;
  }
  .main-nav .menu-item.has-children > a .nav-arrow:hover,
  .main-nav .menu-item.has-children > a .nav-arrow:focus-visible {
    color: var(--color-gray-800);
    outline: none;
  }

  .main-nav .menu-item.has-children.sub-open > a .nav-arrow {
    background: #fdecec;
    color: var(--color-primary-alt);
    transform: rotate(180deg);
  }

  .main-nav .menu-items {
    display: flex;
    flex-wrap: nowrap;
    gap: 18px;

    overflow-x: auto;
    overflow-y: hidden;

    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;

    padding: 0 16px;
    margin: 0;

    white-space: nowrap;
    gap: initial;
  }

  .main-nav .menu-items::-webkit-scrollbar {
    display: none;
  }

  .main-nav .menu-items {
    -ms-overflow-style: none;
    scrollbar-width: none;
  }

  .main-nav .menu-item {
    flex: 0 0 auto;
    margin: 0;
  }

  .main-nav .menu-item a {
    display: flex;
    align-items: center;
    height: 48px;

    font-size: var(--fs-lg);
    font-weight: var(--fw-medium);

    white-space: nowrap;
    padding: 0 14px;
  }
}

@media (max-width: 768px) {
  .trendy-magazine-header .logo-header .container {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 12px;
  }

  .trendy-magazine-header .logo-area {
    display: flex;
    justify-content: center;
    align-items: center;
    min-width: 0;
    margin: 30px auto;

  }

  .trendy-magazine-header .logo-area .logo-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* 로고 이미지 크기(원하는 값으로 조절) */
  .trendy-magazine-header .logo-area img {}

  /* 오른쪽 로그인 영역: 아이콘 자리 */
  .trendy-magazine-header .logo-header .container> :last-child {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
  }


  /* 모바일 로그인 버튼 */
  .top-bar.pop {
    display: none;
  }

  .header-login {
    display: flex;
    align-items: center;
  }

  .header-login .login-icon {
    display: inline-flex;
    width: 40px;
    height: 40px;

    align-items: center;
    justify-content: center;

    border-radius: 10px;
    font-size: var(--fs-xl);
    color: var(--text, var(--color-gray-800));
  }

  .header-login .login-icon i {
    pointer-events: none;
  }

  /* 헤더 카테고리 */
  .main-nav {
    display: block;
  }

  /* 주요뉴스 */
  .main-news-excerpt {
    display: -webkit-box;
    font-size: var(--fs-sm);
  }

  .main-news-content {
    padding: 0 14px;
  }

  .main-news-title {
    font-size: var(--fs-xl);
  }

  .main-text-title a {
    font-size: var(--fs-xl);
  }

  .main-text-item>div:nth-child(2) .text-box {
    align-items: center;
  }

  /* 지금 트렌드 */
  .right-column:not(.custom)>div {
    width: initial;
  }

  /* 주간 인기 뉴스 - popular-section 미사용 */
  .popular-section .items-wrapper {
    padding-left: initial;
  }

  .popular-section .popular-news-item {
    padding: .3rem 0;
    justify-content: initial;
  }

  .popular-section .popular-news-item:before {
    content: none;
  }

  /* 카테고리 별 (insight.php) */
  .category-row {
    flex-direction: column;
  }

  .category-item {
    width: 100%;
  }

  .article-item {
    align-items: center;
  }

  .article-date {
    margin-left: auto;
  }

  .category-header a {
    font-size: 1.3rem;
  }

  .category-row.row-3>.category-item,
  .category-row.row-2>.category-item {
    padding: .5rem;
  }

  .hd-magazine-footer .hd-footer-nav__list {
    gap: 14px 28px;
    font-size: 14.5px;
  }

  .hd-footer-company {
    display: flex;
  }

  .hd-footer-company span {
    display: block;
    padding: 4px 0;
    white-space: normal;
    word-break: keep-all;
  }

  .hd-footer-company span:not(:last-child)::after {
    display: none;
  }

  .hd-magazine-footer {
    padding: 40px .5rem 0;
  }

  .hd-footer-top {
    gap: 0;
  }
}



@media (max-width: 768px) {

  .items-wrapper .news-item,
  .news-item,
  .popular-news-item,
  .trend-item,
  .trending-section .trend-item {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .logo-header {
    padding: initial;
  }
}

@media (max-width: 480px) {
  .hd-footer-container {
    padding: 0;
  }

  .hd-footer-logo-container {
    margin-bottom: 0;
  }

  .hd-footer-top {
    padding-bottom: 10px;
  }

  .hd-magazine-footer .hd-footer-nav__list {
    gap: 8px 14px;
    justify-content: space-around;
  }

  .hd-magazine-footer .hd-footer-nav__list > li > a {
    font-size: var(--fs-base);
  }

  .hd-footer-company {
    gap: 0;
    margin-bottom: 0;
  }

  .hd-magazine-footer .hd-footer-container .hd-footer-info .hd-footer-company span {
    padding: 2px 0;
    line-height: 1.4;
    font-size: var(--fs-xs);
  }

  .hd-copyright {
    gap: 0;
    padding-top: 10px;
    border-top: none;
  }

  .dcma_badge a img {
    width: 30%;
    margin-bottom: 8px;
  }

  .hd-footer-warning {
    font-size: .8em;
    word-break: keep-all;
  }

  .hd-social-links {
    gap: 8px;
  }
}

/* 2026-02 unify homepage section titles to 20px */
.section-title,
.pn-title,
.insight-title,
.most-viewed-title,
.news-wrapper .category-header h2,
.news-wrapper .category-header a {
  font-size: var(--fs-3xl) !important;
}

/* ================================================================
   검색 오버레이 v2 (2026-04)
   상단부착형 카드 · 실시간 자동완성 · 모바일 100dvh 풀스크린
   ================================================================ */
.search-overlay {
  position: fixed;
  inset: 0;
  z-index: 1001;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s ease;
  background: transparent;
}
.search-overlay[hidden] { display: none; }
.search-overlay.active { opacity: 1; pointer-events: auto; }

.search-overlay__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 10, 12, 0.62);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  z-index: 0;
}

.search-overlay__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 720px;
  margin: 64px auto 24px;
  background: var(--color-white);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(var(--rgb-black), 0.35);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  max-height: calc(100dvh - 96px);
  transform: translateY(-8px);
  transition: transform 0.22s ease;
}
.search-overlay.active .search-overlay__inner { transform: translateY(0); }

.search-overlay__topbar {
  flex: none;
  border-bottom: 1px solid var(--color-gray-eee);
  background: var(--color-white);
}
.search-overlay__form {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  margin: 0;
}
.search-overlay__back,
.search-overlay__close-mobile {
  flex: none;
  width: 40px;
  height: 40px;
  border: none;
  background: transparent;
  color: var(--color-gray-333);
  font-size: var(--fs-2xl);
  border-radius: 50%;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.18s ease;
}
.search-overlay__back:hover,
.search-overlay__close-mobile:hover { background: rgba(var(--rgb-black), 0.06); }
.search-overlay__close-mobile { display: none; }

.search-overlay__field {
  position: relative;
  flex: 1;
  display: flex;
  align-items: center;
  background: var(--color-gray-100);
  border-radius: 999px;
  padding: 0 6px 0 18px;
  height: 46px;
  transition: box-shadow 0.18s ease, background 0.18s ease;
}
.search-overlay__field:focus-within {
  background: var(--color-white);
  box-shadow: inset 0 0 0 2px var(--primary-color, var(--color-primary));
}
.search-overlay__input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  font-size: var(--fs-xl);
  color: var(--color-gray-800);
  height: 100%;
  padding: 0;
  outline: none;
  font-family: inherit;
  box-shadow: none;
  border-radius: 0;
}
.search-overlay__input::placeholder { color: var(--color-gray-400); }
.search-overlay__input::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
}

.search-overlay__clear,
.search-overlay__mic {
  flex: none;
  width: 34px;
  height: 34px;
  border: none;
  background: transparent;
  color: var(--color-gray-500);
  font-size: var(--fs-xl);
  cursor: pointer;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.18s ease, color 0.18s ease;
}
.search-overlay__clear[hidden],
.search-overlay__mic[hidden] { display: none !important; }
.search-overlay__clear:hover,
.search-overlay__mic:hover { background: rgba(var(--rgb-black), 0.06); color: var(--color-gray-800); }
.search-overlay__mic.is-listening {
  color: var(--primary-color, var(--color-primary));
  animation: soMicPulse 1.2s ease-in-out infinite;
}
@keyframes soMicPulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.12); }
}

.search-overlay__submit {
  flex: none;
  width: 46px;
  height: 46px;
  border: none;
  border-radius: 50%;
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  font-size: var(--fs-xl);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.18s ease;
  padding: 0;
}
.search-overlay__submit:hover { background: #d32f37; }
.search-overlay__submit:disabled,
.search-overlay__submit[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
}

.search-overlay__body {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0 16px;
  -webkit-overflow-scrolling: touch;
}
.search-overlay__section { padding: 14px 20px; }
.search-overlay__section[hidden] { display: none; }
.search-overlay__section + .search-overlay__section { border-top: 1px solid #f1f1f4; }
.search-overlay__section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.search-overlay__section-title {
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray-500);
  letter-spacing: 0.02em;
}
.search-overlay__clear-all {
  background: transparent;
  border: none;
  color: var(--color-gray-400);
  font-size: var(--fs-sm);
  cursor: pointer;
  padding: 4px 6px;
}
.search-overlay__clear-all:hover { color: var(--primary-color, var(--color-primary)); }

.search-overlay__suggest-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.search-overlay__suggest-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 8px;
  border-radius: 10px;
  cursor: pointer;
  color: var(--color-gray-700);
  transition: background 0.12s ease;
  list-style: none;
}
.search-overlay__suggest-item:hover,
.search-overlay__suggest-item.is-active { background: var(--color-gray-100); }
.search-overlay__suggest-thumb {
  flex: none;
  width: 48px;
  height: 48px;
  border-radius: 8px;
  background: var(--color-gray-200) center/cover no-repeat;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.search-overlay__suggest-thumb i { color: var(--color-gray-400); }
.search-overlay__suggest-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.search-overlay__suggest-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  color: var(--color-gray-800);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-overlay__suggest-title mark {
  background: transparent;
  color: var(--primary-color, var(--color-primary));
  font-weight: var(--fw-bold);
}
.search-overlay__suggest-meta { font-size: var(--fs-sm); color: var(--color-gray-400); }

.search-overlay__recent-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.search-overlay__recent-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 6px;
  border-radius: 8px;
  transition: background 0.12s ease;
  list-style: none;
}
.search-overlay__recent-item:hover,
.search-overlay__recent-item.is-active { background: var(--color-gray-100); }
.search-overlay__recent-icon {
  flex: none;
  color: var(--color-gray-400);
  font-size: var(--fs-md);
  width: 20px;
  text-align: center;
}
.search-overlay__recent-link {
  flex: 1;
  min-width: 0;
  color: var(--color-gray-700);
  text-decoration: none;
  font-size: var(--fs-md);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-overlay__recent-remove {
  flex: none;
  background: transparent;
  border: none;
  width: 28px;
  height: 28px;
  color: var(--color-gray-400);
  cursor: pointer;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.search-overlay__recent-remove:hover {
  color: var(--color-gray-800);
  background: rgba(var(--rgb-black), 0.06);
}

.search-overlay__popular-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 20px;
}
.search-overlay__popular-item {
  min-width: 0;
  list-style: none;
}
.search-overlay__popular-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 6px;
  border-radius: 8px;
  color: var(--color-gray-700);
  text-decoration: none;
  transition: background 0.12s ease;
}
.search-overlay__popular-link:hover { background: var(--color-gray-100); }
.search-overlay__popular-rank {
  flex: none;
  width: 22px;
  font-weight: var(--fw-bold);
  font-size: var(--fs-lg);
  color: var(--color-gray-400);
  text-align: center;
}
.search-overlay__popular-rank.is-top { color: var(--primary-color, var(--color-primary)); }
.search-overlay__popular-term {
  flex: 1;
  min-width: 0;
  font-size: var(--fs-md);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.search-overlay__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.search-overlay__tag {
  display: inline-block;
  padding: 7px 14px;
  background: var(--color-gray-100);
  color: var(--color-gray-600);
  text-decoration: none;
  border-radius: 999px;
  font-size: var(--fs-base);
  transition: background 0.18s ease, color 0.18s ease;
}
.search-overlay__tag:hover {
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
}

.search-overlay__empty {
  padding: 28px 20px;
  text-align: center;
  color: var(--color-gray-500);
}
.search-overlay__empty[hidden] { display: none; }
.search-overlay__empty-icon {
  font-size: var(--fs-5xl);
  color: var(--color-gray-300);
  margin-bottom: 10px;
}
.search-overlay__empty-text {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-600);
  margin: 0 0 4px;
}
.search-overlay__empty-sub {
  font-size: var(--fs-base);
  color: var(--color-gray-400);
  margin: 0;
}

@media (max-width: 768px) {
  .search-overlay__inner {
    margin: 0;
    max-width: none;
    border-radius: 0;
    max-height: 100dvh;
    height: 100dvh;
    box-shadow: none;
  }
  .search-overlay__backdrop { display: none; }
  .search-overlay__form { padding: 8px 8px; gap: 4px; }
  .search-overlay__submit { display: none; }
  .search-overlay__close-mobile { display: inline-flex; }
  .search-overlay__popular-list { grid-template-columns: 1fr; }
}

/* ================================================================
   검색 결과 페이지 v2 (2026-04)
   ================================================================ */
.search-page {
  max-width: 1400px;
  margin: 0 auto;
  padding: 32px 24px 80px;
  color: var(--color-gray-700);
}
.search-page__breadcrumb {
  font-size: var(--fs-base);
  color: var(--color-gray-500);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.search-page__breadcrumb a {
  color: var(--color-gray-500);
  text-decoration: none;
}
.search-page__breadcrumb a:hover { color: var(--primary-color, var(--color-primary)); }

.search-page__header {
  margin-bottom: 28px;
}
.search-page__title {
  font-size: var(--fs-5xl);
  font-weight: var(--fw-extrabold);
  line-height: 1.3;
  margin: 0 0 8px;
  color: var(--color-gray-800);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: baseline;
}
.search-page__title-q { color: var(--primary-color, var(--color-primary)); }
.search-page__title-suffix {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-600);
}
.search-page__count {
  font-size: var(--fs-md);
  color: var(--color-gray-500);
  margin: 0 0 18px;
}
.search-page__count strong {
  color: var(--color-gray-800);
  font-weight: var(--fw-bold);
}

.search-page__form {
  display: flex;
  align-items: stretch;
  gap: 8px;
  margin: 0 0 16px;
}
.search-page__field {
  position: relative;
  flex: 1;
  display: flex;
  align-items: center;
  background: var(--color-gray-100);
  border-radius: 999px;
  padding: 0 14px 0 44px;
  height: 48px;
  transition: box-shadow 0.18s ease, background 0.18s ease;
}
.search-page__field:focus-within {
  background: var(--color-white);
  box-shadow: inset 0 0 0 2px var(--primary-color, var(--color-primary));
}
.search-page__field-icon {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-gray-400);
  font-size: var(--fs-lg);
}
.search-page__input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  font-size: var(--fs-lg);
  color: var(--color-gray-800);
  height: 100%;
  padding: 0;
  outline: none;
  font-family: inherit;
}
.search-page__input::placeholder { color: var(--color-gray-400); }
.search-page__input::-webkit-search-cancel-button { -webkit-appearance: none; appearance: none; }
.search-page__clear {
  color: var(--color-gray-400);
  font-size: var(--fs-xl);
  text-decoration: none;
  padding: 0 6px;
  display: inline-flex;
  align-items: center;
  border-radius: 50%;
}
.search-page__clear:hover { color: var(--color-gray-800); }

.search-page__submit {
  flex: 0 0 auto;
  padding: 0 22px;
  height: 48px;
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  border: none;
  border-radius: 999px;
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  cursor: pointer;
  transition: background 0.18s ease;
  white-space: nowrap;
}
.search-page__submit:hover { background: #d32f37; }

/* 필터 바 */
.search-page__filters {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  background: var(--color-gray-fafafa);
  border: 1px solid var(--color-gray-150);
  border-radius: 12px;
}
.search-page__filter-group {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.search-page__filter-label {
  flex: none;
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--color-gray-500);
  width: 60px;
  letter-spacing: 0.02em;
}
.search-page__chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
}
.search-page__chip-row--scroll {
  flex: 1 1 0%;
  min-width: 0;
  max-width: 100%;
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 2px;
  -webkit-overflow-scrolling: touch;
}
.search-page__chip-row--scroll::-webkit-scrollbar { display: none; }
.search-page__chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  background: var(--color-white);
  color: var(--color-gray-600);
  border: 1px solid var(--color-gray-200);
  border-radius: 999px;
  font-size: var(--fs-base);
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.search-page__chip:hover {
  background: var(--color-gray-100);
  border-color: var(--color-gray-300);
  color: var(--color-gray-800);
}
.search-page__chip.is-active {
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  border-color: var(--primary-color, var(--color-primary));
}
.search-page__chip-count {
  background: rgba(var(--rgb-black), 0.08);
  color: inherit;
  border-radius: 999px;
  padding: 1px 6px;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
}
.search-page__chip.is-active .search-page__chip-count {
  background: rgba(var(--rgb-white), 0.25);
}

/* 2단 레이아웃 */
.search-page__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 36px;
  align-items: start;
}
.search-page__hint {
  margin-top: 24px;
  padding: 12px 16px;
  background: var(--color-gray-50);
  border-radius: 8px;
  font-size: var(--fs-base);
  color: var(--color-gray-500);
  text-align: center;
}

/* 결과 카드 */
.search-results-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.search-result-card {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 28px;
  min-width: 0;
}
.search-result-card__thumb {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 4px;
  aspect-ratio: 16 / 10;
  background: var(--color-gray-100);
}
.search-result-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s ease;
}
.search-result-card:hover .search-result-card__thumb img {
  transform: scale(1.04);
}
.search-result-card__badge {
  position: absolute;
  left: 10px;
  top: 10px;
  padding: 4px 10px;
  background: rgba(var(--rgb-black), 0.72);
  color: var(--color-white);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  border-radius: 999px;
  backdrop-filter: blur(4px);
}
.search-result-card__body {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.search-result-card__title {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  line-height: 1.4;
  margin: 0 0 12px;
  color: var(--color-gray-800);
  overflow-wrap: anywhere;
  word-break: break-word;
}
.search-result-card__title a {
  color: inherit;
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.search-result-card__title a:hover { color: var(--primary-color, var(--color-primary)); }
.search-result-card__title mark,
.search-result-card__excerpt mark {
  background: rgba(var(--rgb-primary), 0.12);
  color: var(--primary-color, var(--color-primary));
  font-weight: var(--fw-bold);
  padding: 0 2px;
  border-radius: 3px;
}
.search-result-card__excerpt {
  font-size: var(--fs-md);
  line-height: 1.6;
  color: #4b5563;
  margin: 0 0 16px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.search-result-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: auto;
  font-size: var(--fs-sm);
  color: var(--color-gray-400);
}
.search-result-card__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
/* 페이지네이션 */
.search-pagination {
  margin-top: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.search-pagination .page-numbers {
  min-width: 38px;
  height: 38px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-white);
  color: var(--color-gray-600);
  border: 1px solid var(--color-gray-200);
  border-radius: 8px;
  text-decoration: none;
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}
.search-pagination .page-numbers:hover {
  background: var(--color-gray-50);
  border-color: var(--color-gray-300);
}
.search-pagination .page-numbers.current {
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  border-color: var(--primary-color, var(--color-primary));
}
.search-pagination .page-numbers.dots { border: none; background: transparent; }
.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;
}

/* 빈 상태 */
.search-empty {
  padding: 60px 20px;
  text-align: center;
  background: var(--color-gray-fafafa);
  border-radius: 14px;
}
.search-empty__icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 16px;
  background: var(--color-white);
  color: var(--color-gray-300);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-5xl);
  box-shadow: 0 4px 16px rgba(var(--rgb-black), 0.04);
}
.search-empty__title {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-bold);
  color: var(--color-gray-800);
  margin: 0 0 18px;
}
.search-empty__tips {
  max-width: 420px;
  margin: 0 auto 24px;
  padding: 0 0 0 20px;
  text-align: left;
  font-size: var(--fs-md);
  color: var(--color-gray-500);
  line-height: 1.8;
}
.search-empty__tips li { list-style: disc; }
.search-empty__suggest { margin-top: 24px; }
.search-empty__suggest-label {
  display: block;
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  color: var(--color-gray-500);
  margin-bottom: 10px;
}
.search-empty__suggest-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}
.search-empty__suggest-chip {
  display: inline-block;
  padding: 8px 16px;
  background: var(--color-white);
  color: var(--color-gray-600);
  border: 1px solid var(--color-gray-200);
  border-radius: 999px;
  font-size: var(--fs-base);
  text-decoration: none;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.search-empty__suggest-chip:hover {
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  border-color: var(--primary-color, var(--color-primary));
}

/* 사이드바 */
.search-page__sidebar { min-width: 0; }
.search-aside__section {
  padding: 20px;
  background: var(--color-white);
  border: 1px solid var(--color-gray-150);
  border-radius: 12px;
  margin-bottom: 16px;
}
.search-aside__title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--color-gray-800);
  margin: 0 0 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.search-aside__title i { color: var(--primary-color, var(--color-primary)); font-size: var(--fs-base); }

.search-aside__tag-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.search-aside__tag {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  background: var(--color-gray-50);
  border-radius: 8px;
  color: var(--color-gray-600);
  text-decoration: none;
  font-size: var(--fs-base);
  transition: background 0.18s ease;
}
.search-aside__tag:hover {
  background: var(--color-gray-100);
  color: var(--primary-color, var(--color-primary));
}
.search-aside__tag-count {
  font-size: var(--fs-xs);
  color: var(--color-gray-400);
  background: var(--color-white);
  padding: 1px 8px;
  border-radius: 999px;
}

.search-aside__post-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.search-aside__post-link {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: inherit;
  text-decoration: none;
}
.search-aside__post-thumb {
  flex: none;
  width: 64px;
  height: 64px;
  border-radius: 8px;
  overflow: hidden;
  background: var(--color-gray-100);
}
.search-aside__post-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.search-aside__post-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.search-aside__post-title {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  line-height: 1.4;
  color: var(--color-gray-700);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.search-aside__post-link:hover .search-aside__post-title {
  color: var(--primary-color, var(--color-primary));
}
.search-aside__post-date {
  font-size: var(--fs-xs);
  color: var(--color-gray-400);
}

.search-aside__popular {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.search-aside__popular a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 6px;
  color: var(--color-gray-700);
  text-decoration: none;
  font-size: var(--fs-base);
  border-radius: 6px;
  transition: background 0.12s ease;
}
.search-aside__popular a:hover { background: var(--color-gray-100); }
.search-aside__rank {
  flex: none;
  width: 20px;
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  color: var(--color-gray-400);
  text-align: center;
}
.search-aside__rank.is-top { color: var(--primary-color, var(--color-primary)); }

/* 반응형: 1024 이하 사이드바 아래로 */
@media (max-width: 1024px) {
  .search-page__body {
    grid-template-columns: minmax(0, 1fr);
    gap: 24px;
  }
  .search-page__sidebar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 16px;
  }
  .search-aside__section { margin-bottom: 0; }
}

/* 태블릿: 썸네일 축소 */
@media (max-width: 768px) {
  .search-page { padding: 20px 16px 60px; }
  .search-page__title { font-size: var(--fs-4xl); }
  .search-page__title-suffix { font-size: var(--fs-xl); }
  .search-results-list { gap: 24px; }
  .search-result-card {
    grid-template-columns: 160px minmax(0, 1fr);
    gap: 20px;
  }
  .search-result-card__title { font-size: var(--fs-xl); margin: 0 0 10px; }
  .search-result-card__excerpt { font-size: var(--fs-base); margin: 0 0 14px; }
}

/* 모바일: 카드 세로 배치 */
@media (max-width: 480px) {
  .search-page__form { flex-wrap: nowrap; gap: 6px; }
  .search-page__field { height: 44px; padding: 0 10px 0 38px; }
  .search-page__field-icon { left: 14px; font-size: var(--fs-base); }
  .search-page__input { font-size: var(--fs-md); }
  .search-page__submit { height: 44px; padding: 0 14px; font-size: var(--fs-base); }
  .search-page__filter-group {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .search-page__filter-label { width: auto; }
  .search-page__chip-row--scroll {
    align-self: stretch;
    width: 100%;
  }
  .search-results-list { gap: 20px; }
  .search-result-card {
    grid-template-columns: 120px minmax(0, 1fr);
    gap: 12px;
  }
  .search-result-card__title { font-size: var(--fs-base); margin: 0 0 6px; }
  .search-result-card__excerpt { display: none; }
  .search-result-card__thumb { aspect-ratio: 4 / 3; border-radius: 3px; }
  .search-result-card__badge { left: 5px; top: 5px; padding: 2px 7px; font-size: 10px; }
  .search-result-card__meta { gap: 10px; font-size: 11px; }
  .search-pagination .page-numbers {
    min-width: 34px;
    height: 34px;
    padding: 0 8px;
    font-size: var(--fs-sm);
  }
  .search-page__sidebar {
    grid-template-columns: 1fr;
  }
}

/* ================================================================
   카테고리 허브 v2 (2026-04)
   ================================================================ */

/* style.css 의 전역 "ul li, ol li { margin-left:21px; line-height:24px }"
   가 BEM 카드/리스트에 섞여 들어오는 것을 리셋 */
.cat-list > li,
.cat-hero__subs > li,
.cat-inline__scroll > li,
.search-results-list > li,
.search-overlay__recent-list > li,
.search-overlay__suggest-list > li,
.search-overlay__popular-list > li,
.search-aside__post-list > li,
.search-aside__popular > li {
  margin: 0;
  padding: 0;
  line-height: inherit;
}

.cat-page {
  max-width: 1400px;
  margin: 0 auto;
  padding: 32px 24px 80px;
  color: var(--color-gray-700);
}

/* ---- 헤더 (Option A: 좌측 엑센트 바 + 건수 칩) ---- */
.cat-header {
  position: relative;
  margin-bottom: 24px;
  padding: 4px 0 4px 18px;
}
.cat-header::before {
  content: '';
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 4px;
  border-radius: 999px;
  background: var(--primary-color, var(--color-primary));
}
.cat-header__title-row {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 8px;
}
.cat-header__title {
  font-size: var(--fs-6xl);
  font-weight: var(--fw-extrabold);
  line-height: 1.2;
  margin: 0;
  color: var(--color-gray-800);
  letter-spacing: -0.01em;
}
.cat-header__count-chip {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  padding: 4px 12px;
  background: var(--color-gray-100);
  color: var(--color-gray-600);
  border-radius: 999px;
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  line-height: 1;
}
.cat-header__count-chip strong {
  color: var(--primary-color, var(--color-primary));
  font-weight: var(--fw-extrabold);
  font-size: var(--fs-md);
}
.cat-header__desc {
  font-size: var(--fs-lg);
  line-height: 1.6;
  color: #4b5563;
  margin: 0 0 12px;
  max-width: 760px;
}
.cat-header__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-base);
  color: var(--color-gray-400);
}
.cat-header__meta-sep { color: var(--color-gray-300); }
.cat-header__breadcrumb {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.cat-header__breadcrumb a { color: var(--color-gray-500); text-decoration: none; }
.cat-header__breadcrumb a:hover { color: var(--primary-color, var(--color-primary)); }

/* ---- 자식 카테고리 내비 ---- */
.cat-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid #f1f1f4;
}
.cat-subnav__chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 14px;
  background: var(--color-gray-100);
  color: var(--color-gray-600);
  text-decoration: none;
  border-radius: 999px;
  font-size: var(--fs-base);
  transition: background 0.18s ease, color 0.18s ease;
}
.cat-subnav__chip:hover { background: var(--color-gray-200); color: var(--color-gray-800); }
.cat-subnav__chip.is-active {
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
}
.cat-subnav__count {
  background: rgba(var(--rgb-black), 0.08);
  border-radius: 999px;
  padding: 1px 7px;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
}
.cat-subnav__chip.is-active .cat-subnav__count { background: rgba(var(--rgb-white), 0.25); }

/* ---- 히어로 ---- */
.cat-hero {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 20px;
  margin-bottom: 32px;
}
.cat-hero__main {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 14px;
  background: var(--color-gray-100);
  aspect-ratio: 16 / 9;
  color: var(--color-white);
  text-decoration: none;
}
.cat-hero__main-thumb,
.cat-hero__main-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.cat-hero__main-thumb img {
  object-fit: cover;
  transition: transform 0.5s ease;
}
.cat-hero__main:hover .cat-hero__main-thumb img { transform: scale(1.04); }
.cat-hero__main::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(var(--rgb-black), 0.75) 0%, rgba(var(--rgb-black), 0) 55%);
  pointer-events: none;
}
.cat-hero__main-body {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 1;
}
.cat-hero__badge {
  align-self: flex-start;
  padding: 4px 10px;
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  border-radius: 999px;
  letter-spacing: 0.02em;
}
.cat-hero__main-title {
  font-size: var(--fs-4xl);
  font-weight: var(--fw-extrabold);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cat-hero__main-date { font-size: var(--fs-sm); opacity: 0.85; }

.cat-hero__subs {
  list-style: none;
  margin: 0;
  padding: 0;
  padding-inline-start: 0;
  padding-inline-end: 0;
  margin-inline-start: 0;
  margin-inline-end: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 12px;
  width: 100%;
}
.cat-hero__sub { margin: 0; padding: 0; }
.cat-hero__sub {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  background: var(--color-gray-100);
  aspect-ratio: 1 / 1;
}
.cat-hero__sub a {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-decoration: none;
  color: var(--color-white);
}
.cat-hero__sub-thumb,
.cat-hero__sub-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.cat-hero__sub-thumb img {
  object-fit: cover;
  transition: transform 0.4s ease;
}
.cat-hero__sub a:hover .cat-hero__sub-thumb img { transform: scale(1.06); }
.cat-hero__sub::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(var(--rgb-black), 0.7) 0%, rgba(var(--rgb-black), 0) 60%);
  pointer-events: none;
}
.cat-hero__sub-title {
  position: relative;
  z-index: 1;
  padding: 10px 12px;
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ---- 필터 바 (2026-04-21 여백 최적화 리디자인) ----
 * PC: 두 그룹 한 줄 (정렬 · [chips] | 기간 · [chips]) + 하단 hairline
 * 모바일: 그룹 세로 스택 + chips 가로 스크롤 + 오른쪽 페이드 힌트
 * 박스 chrome 제거 → cat-subnav 와 동일한 hairline 언어 공유
 */
.cat-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px 18px;
  padding: 0 0 14px;
  margin: 0 0 16px;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--color-gray-150);
  border-radius: 0;
  min-width: 0;
}
.cat-filters__group {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.cat-filters__label {
  flex: none;
  width: auto;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-400);
  letter-spacing: -0.01em;
  position: relative;
  padding-right: 10px;
  white-space: nowrap;
}
.cat-filters__label::after {
  content: '·';
  position: absolute;
  right: 2px;
  top: 50%;
  transform: translateY(-55%);
  color: var(--color-gray-300);
  font-weight: var(--fw-normal);
}
.cat-filters__chips {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 2px;
  min-width: 0;
}
.cat-filters__chip {
  padding: 4px 10px;
  background: transparent;
  color: var(--color-gray-600);
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: var(--fs-sm);
  text-decoration: none;
  transition: background-color 0.15s ease, color 0.15s ease;
  white-space: nowrap;
}
.cat-filters__chip:hover {
  background-color: var(--color-gray-100);
  color: var(--color-gray-800);
}
.cat-filters__chip:focus-visible {
  outline: 2px solid var(--primary-color, var(--color-primary));
  outline-offset: 2px;
}
.cat-filters__chip.is-active {
  background-color: var(--color-gray-800);
  color: var(--color-white);
  font-weight: var(--fw-semibold);
}
.cat-filters__chip.is-active:hover {
  background-color: var(--color-gray-700);
  color: var(--color-white);
}

/* ---- 카드 리스트 ---- */
.cat-list {
  list-style: none;
  margin: 0 0 24px;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 40px;
  row-gap: 36px;
}
.cat-card {
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr);
  gap: 20px;
  min-width: 0;
  list-style: none;
}
.cat-card__thumb {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 4px;
  aspect-ratio: 16 / 10;
  background: var(--color-gray-100);
}
.cat-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s ease;
}
.cat-card:hover .cat-card__thumb img { transform: scale(1.04); }
.cat-card__badge {
  position: absolute;
  left: 8px;
  top: 8px;
  padding: 3px 9px;
  background: rgba(var(--rgb-black), 0.72);
  color: var(--color-white);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  border-radius: 999px;
  backdrop-filter: blur(4px);
}
.cat-card__body {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.cat-card__title {
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  line-height: 1.4;
  margin: 0 0 10px;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.cat-card__title a {
  color: var(--color-gray-800);
  text-decoration: none;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cat-card__title a:hover { color: var(--primary-color, var(--color-primary)); }
.cat-card__excerpt {
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--color-gray-500);
  margin: 0 0 14px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.cat-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: auto;
  font-size: var(--fs-xs);
  color: var(--color-gray-400);
}
.cat-card__meta span { display: inline-flex; align-items: center; gap: 4px; }

/* ---- 인라인 위젯 ---- */
.cat-inline {
  grid-column: 1 / -1;
  padding: 40px 0 8px;
  margin: 16px 0 4px;
  border-top: 1px solid var(--color-gray-200);
  list-style: none;
  min-width: 0;
  overflow: hidden;
}
.cat-inline__head {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
  padding-top: 12px;
}
.cat-inline__eyebrow {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--color-gray-800);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.cat-inline__eyebrow i { color: var(--primary-color, var(--color-primary)); }
.cat-inline__sub { font-size: var(--fs-sm); color: var(--color-gray-400); }

.cat-inline__scroll {
  list-style: none;
  margin: 0;
  padding: 4px 0 8px;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(200px, 1fr);
  gap: 20px;
  overflow-x: auto;
  scrollbar-width: thin;
}
.cat-inline__item { list-style: none; min-width: 0; }
.cat-inline__item a {
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: inherit;
  text-decoration: none;
}
.cat-inline__thumb {
  display: block;
  aspect-ratio: 16 / 10;
  border-radius: 4px;
  overflow: hidden;
  background: var(--color-gray-200);
}
.cat-inline__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cat-inline__title {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  line-height: 1.5;
  color: var(--color-gray-800);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  overflow-wrap: anywhere;
  word-break: break-word;
  margin-top: 2px;
}
.cat-inline__date { font-size: var(--fs-xs); color: var(--color-gray-400); margin-top: 2px; }

.cat-inline__tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 4px 0 4px;
}
.cat-inline__tag {
  display: inline-block;
  padding: 8px 16px;
  background: transparent;
  color: var(--color-gray-700);
  border: 1px solid var(--color-gray-200);
  border-radius: 999px;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  text-decoration: none;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.cat-inline__tag:hover {
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  border-color: var(--primary-color, var(--color-primary));
}

/* ---- 페이지네이션 ---- */
.cat-pagination {
  margin-top: 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.cat-pagination .page-numbers {
  min-width: 38px;
  height: 38px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-white);
  color: var(--color-gray-600);
  border: 1px solid var(--color-gray-200);
  border-radius: 8px;
  text-decoration: none;
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}
.cat-pagination .page-numbers:hover { background: var(--color-gray-50); border-color: var(--color-gray-300); }
.cat-pagination .page-numbers.current {
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  border-color: var(--primary-color, var(--color-primary));
}
.cat-pagination .page-numbers.dots { border: none; background: transparent; }

/* ---- 모바일 더보기 버튼 ---- */
.cat-loadmore-wrap {
  display: none;
  margin-top: 20px;
  text-align: center;
}
.cat-loadmore {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 32px;
  background: var(--color-white);
  color: var(--color-gray-800);
  border: 1px solid var(--color-gray-200);
  border-radius: 999px;
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease;
}
.cat-loadmore:hover { background: var(--color-gray-50); border-color: var(--color-gray-300); }
.cat-loadmore:disabled { opacity: 0.6; cursor: wait; }

/* ---- 빈 상태 ---- */
.cat-empty {
  padding: 60px 20px;
  text-align: center;
  background: var(--color-gray-fafafa);
  border-radius: 14px;
}
.cat-empty__icon {
  font-size: var(--fs-6xl);
  color: var(--color-gray-300);
  margin-bottom: 12px;
}
.cat-empty__text {
  font-size: var(--fs-lg);
  color: var(--color-gray-500);
  margin: 0 0 16px;
}
.cat-empty__home {
  display: inline-block;
  padding: 10px 24px;
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
  text-decoration: none;
  border-radius: 999px;
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
}

/* ---- 반응형 ---- */
@media (max-width: 1024px) {
  .cat-list { grid-template-columns: minmax(0, 1fr); }
  .cat-hero { grid-template-columns: minmax(0, 1fr); }
  .cat-hero__subs { grid-template-columns: repeat(4, 1fr); grid-template-rows: 1fr; }
}
@media (max-width: 768px) {
  .cat-page { padding: 20px 16px 60px; }
  .cat-header { padding-left: 14px; }
  .cat-header::before { width: 3px; }
  .cat-header__title { font-size: 26px; }
  .cat-header__count-chip { padding: 3px 10px; font-size: var(--fs-sm); }
  .cat-header__count-chip strong { font-size: var(--fs-base); }
  .cat-list { column-gap: 24px; row-gap: 28px; grid-template-columns: minmax(0, 1fr); }
  .cat-card { grid-template-columns: 140px minmax(0, 1fr); gap: 16px; padding: 0 0 24px; border-bottom: 1px solid var(--color-gray-150); }
  .cat-card:last-child { border-bottom: 0; padding-bottom: 0; }
  .cat-card__title { font-size: var(--fs-lg); margin: 0 0 8px; }
  .cat-card__excerpt { margin: 0 0 12px; }
  .cat-card__meta { gap: 12px; }
  .cat-hero__main-title { font-size: var(--fs-2xl); }
  .cat-hero__subs {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr 1fr;
    padding-left: 0 !important;
    margin-left: 0 !important;
    padding-inline-start: 0 !important;
  }
  .cat-hero__sub { margin-left: 0 !important; padding-left: 0 !important; }
  /* 모바일: 번호 페이지네이션 숨기고 더보기 버튼 노출 */
  .cat-pagination { display: none; }
  .cat-loadmore-wrap { display: block; }

  /* 필터 바 — 모바일: 그룹 세로 스택 + chips 가로 스크롤 */
  .cat-filters {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding-bottom: 12px;
    margin-bottom: 14px;
  }
  .cat-filters__group {
    display: flex;
    width: 100%;
    align-items: center;
    gap: 10px;
    min-width: 0;
  }
  .cat-filters__label {
    flex: 0 0 auto;
    min-width: 32px;
    padding-right: 0;
  }
  .cat-filters__label::after { display: none; }
  .cat-filters__chips {
    flex: 1 1 auto;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
    gap: 4px;
    padding-bottom: 2px;
    -webkit-mask-image: linear-gradient(to right, #000 calc(100% - 20px), transparent);
            mask-image: linear-gradient(to right, #000 calc(100% - 20px), transparent);
  }
  .cat-filters__chips::-webkit-scrollbar { display: none; }
  .cat-filters__chip { flex-shrink: 0; padding: 5px 11px; }
}
@media (max-width: 480px) {
  .cat-card { grid-template-columns: 110px minmax(0, 1fr); gap: 12px; padding: 0 0 18px; }
  .cat-card__thumb { aspect-ratio: 4 / 3; border-radius: 3px; }
  .cat-inline { padding: 32px 0 4px; margin: 12px 0 2px; }
  .cat-inline__head { margin-bottom: 14px; gap: 8px; }
  .cat-inline__eyebrow { font-size: var(--fs-base); }
  .cat-inline__scroll { grid-auto-columns: minmax(160px, 1fr); gap: 14px; }
  .cat-inline__tag-row { gap: 8px; }
  .cat-inline__tag { padding: 7px 13px; font-size: var(--fs-xs); }
  .cat-card__badge { left: 5px; top: 5px; padding: 2px 7px; font-size: 10px; }
  .cat-card__title { font-size: var(--fs-base); margin: 0 0 6px; -webkit-line-clamp: 2; line-clamp: 2; }
  .cat-card__excerpt { display: none; }
  .cat-card__meta { gap: 10px; font-size: 11px; }
  .cat-hero__main-title { font-size: var(--fs-xl); }
  .cat-hero__main-body { left: 14px; right: 14px; bottom: 14px; }
  .cat-hero__subs { grid-template-columns: 1fr; grid-template-rows: none; }
  .cat-hero__sub { aspect-ratio: 16 / 9; }
  .cat-pagination .page-numbers { min-width: 34px; height: 34px; font-size: var(--fs-sm); }
}

/* =========================================================================
 * 공용 breadcrumb (.intra-breadcrumb) — 2026-04-21
 * 사이트 전 영역 단일 구현. cat-header / author-hero / single / search /
 * page / archive / tag / 404 모두 이 컴포넌트를 호출한다.
 *
 * 디자인 원칙:
 *  - 기본 상태는 meta 텍스트와 동급의 무채색 subtle
 *  - 현재 항목만 gray-700 + medium 굵기로 시각 시선 종점 유도
 *  - 홈 링크에 작은 house SVG 아이콘으로 브랜드/엔트리 포인트 인지
 *  - 데스크톱 wrap / 모바일 nowrap + 가로 스크롤 + 가장자리 페이드
 *  - 터치 타겟: 링크 내부 padding 으로 44x28px 확보 (음수 margin 으로 시각 정렬 유지)
 * ========================================================================= */
.intra-breadcrumb {
  font-size: var(--fs-base);
  color: var(--color-gray-500);
  line-height: 1.5;
  /* 부모 컨테이너가 padding 을 조절함 — 컴포넌트 자체는 margin/padding 중립 */
}
.intra-breadcrumb__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px 6px;
}
.intra-breadcrumb__list > li {
  margin: 0;
  padding: 0;
  line-height: inherit;
}

.intra-breadcrumb__item {
  min-width: 0;
  display: inline-flex;
  align-items: center;
}
.intra-breadcrumb__item a {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--color-gray-500);
  text-decoration: none;
  padding: 4px 6px;
  margin: -4px -6px;
  border-radius: 6px;
  transition: color 0.15s ease, background-color 0.15s ease;
}
.intra-breadcrumb__item a:hover {
  color: var(--primary-color, var(--color-primary));
  background-color: rgba(var(--rgb-primary), 0.06);
}
.intra-breadcrumb__item a:focus-visible {
  outline: 2px solid var(--primary-color, var(--color-primary));
  outline-offset: 2px;
}

/* 홈(intramagazine) 링크: 아이콘 + 라벨 */
.intra-breadcrumb__item--home a {
  color: var(--color-gray-700);
  font-weight: var(--fw-medium);
  letter-spacing: -0.005em;
}
.intra-breadcrumb__home-icon {
  display: inline-block;
  flex-shrink: 0;
  width: 14px;
  height: 14px;
  vertical-align: -2px;
  color: var(--primary-color, var(--color-primary));
  transition: transform 0.15s ease;
}
.intra-breadcrumb__item--home a:hover .intra-breadcrumb__home-icon {
  transform: translateY(-1px);
}

/* 현재 페이지: 줄임 처리 + 시선 종점 강조 */
.intra-breadcrumb__item.is-current > span {
  color: var(--color-gray-700);
  font-weight: var(--fw-medium);
  max-width: 40ch;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: inline-block;
  vertical-align: middle;
}

/* 구분자(chevron SVG) */
.intra-breadcrumb__sep {
  display: inline-flex;
  align-items: center;
  color: var(--color-gray-300);
  flex-shrink: 0;
  user-select: none;
  transform: translateY(-0.5px);
}
.intra-breadcrumb__sep svg { display: block; }

/* 모바일: 가로 스크롤 (wrap 해제) + 가장자리 페이드 */
@media (max-width: 768px) {
  .intra-breadcrumb {
    position: relative;
    /* 부모 컨테이너 padding 의 좌/우 에지까지 스크롤이 닿도록, 내부에서 다시 padding 확보 */
  }
  .intra-breadcrumb__list {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
    /* 시각적 스크롤 힌트: 오른쪽 가장자리 페이드 (iOS/Safari 포함) */
    -webkit-mask-image: linear-gradient(to right, #000 calc(100% - 24px), transparent);
            mask-image: linear-gradient(to right, #000 calc(100% - 24px), transparent);
  }
  .intra-breadcrumb__list::-webkit-scrollbar { display: none; }
  .intra-breadcrumb__item,
  .intra-breadcrumb__sep { flex-shrink: 0; }
  .intra-breadcrumb__item.is-current > span {
    max-width: none; /* 스크롤로 전체 노출 */
  }
}

@media (max-width: 480px) {
  .intra-breadcrumb { font-size: var(--fs-sm); }
  .intra-breadcrumb__home-icon { width: 12px; height: 12px; }
}

/* ---- 페이지 컨텍스트별 variant ---- */

/* hero (author, search, 404): 다음 블록과 여백 확보 */
.intra-breadcrumb--hero { margin-bottom: 18px; }

/* article (single post 본문 위): 섹션 라벨이 시각적 강조를 맡으므로 breadcrumb 은 슬림한 내비 보조로 */
.intra-breadcrumb--article {
  margin-bottom: 10px;
  font-size: var(--fs-sm);
  color: var(--color-gray-400);
}
.intra-breadcrumb--article .intra-breadcrumb__item a {
  color: var(--color-gray-400);
}
.intra-breadcrumb--article .intra-breadcrumb__item.is-current > span {
  color: var(--color-gray-500);
  font-weight: var(--fw-normal);
}
.intra-breadcrumb--article .intra-breadcrumb__item--home a {
  color: var(--color-gray-500);
  font-weight: var(--fw-normal);
}
.intra-breadcrumb--article .intra-breadcrumb__sep {
  color: var(--color-gray-200);
}

/* inline (cat-header__meta 내부): 부모가 이미 inline-flex 이므로 추가 장식 없음 */
.intra-breadcrumb--inline { display: inline-flex; }

/* =========================================================================
 * Author archive (/author/{slug}/) — 2026-04-21 리뉴얼
 * 카테고리 페이지(.cat-*)와 동일한 디자인 토큰/리듬을 공유한다.
 * ========================================================================= */
.author-page {
  max-width: 1400px;
  margin: 0 auto;
  padding: 32px 24px 80px;
  color: var(--color-gray-700);
}

/* ---- 헤더(브레드크럼 + 프로필 카드) ---- */
.author-hero { margin-bottom: 28px; }
.author-hero__breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-base);
  color: var(--color-gray-400);
  margin-bottom: 16px;
}
.author-hero__breadcrumb a { color: var(--color-gray-500); text-decoration: none; }
.author-hero__breadcrumb a:hover { color: var(--primary-color, var(--color-primary)); }
.author-hero__crumb-current { color: var(--color-gray-700); font-weight: var(--fw-medium); }

.author-card {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr);
  gap: 28px;
  padding: 28px;
  background: var(--color-white);
  border: 1px solid var(--color-gray-150);
  border-radius: 18px;
  position: relative;
  overflow: hidden;
}
.author-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: var(--primary-color, var(--color-primary));
}

.author-card__avatar {
  width: 128px;
  height: 128px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--color-gray-100);
  border: 3px solid var(--color-white);
  box-shadow: 0 4px 16px rgba(var(--rgb-slate), 0.08);
  justify-self: center;
  align-self: start;
}
.author-card__avatar img,
.author-card__avatar .avatar {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.author-card__body { min-width: 0; }

.author-card__head {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 10px;
}
.author-card__name {
  font-size: var(--fs-5xl);
  font-weight: var(--fw-extrabold);
  line-height: 1.2;
  margin: 0;
  color: var(--color-gray-800);
  letter-spacing: -0.01em;
}
.author-card__role {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  background: rgba(var(--rgb-primary), 0.08);
  color: var(--primary-color, var(--color-primary));
  border-radius: 999px;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  line-height: 1.3;
}

.author-card__desc {
  font-size: var(--fs-lg);
  line-height: 1.6;
  color: var(--color-gray-500);
  margin: 0 0 18px;
  max-width: 720px;
}

/* ---- EEAT 크레덴셜 블록 (Schema.org Person) ---- */
.author-card__credentials {
  list-style: none;
  margin: 0 0 16px;
  padding: 14px 16px;
  background: var(--color-gray-50);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.author-card__credentials > li { margin: 0; padding: 0; line-height: inherit; }
.author-card__cred {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--fs-base);
  color: var(--color-gray-700);
  min-width: 0;
}
.author-card__cred > i {
  flex: none;
  width: 16px;
  text-align: center;
  color: var(--primary-color, var(--color-primary));
  font-size: var(--fs-sm);
}
.author-card__cred-label {
  flex: none;
  width: 56px;
  font-size: var(--fs-sm);
  color: var(--color-gray-400);
  font-weight: var(--fw-medium);
}
.author-card__cred a {
  color: var(--color-gray-700);
  text-decoration: none;
  word-break: break-all;
  transition: color 0.18s ease;
}
.author-card__cred a:hover { color: var(--primary-color, var(--color-primary)); }

/* ---- 링크(RSS 구독 등) ---- */
.author-card__links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.author-card__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--color-gray-100);
  color: var(--color-gray-600);
  text-decoration: none;
  border-radius: 999px;
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  transition: background 0.18s ease, color 0.18s ease;
}
.author-card__link:hover {
  background: var(--color-gray-200);
  color: var(--color-gray-800);
}
.author-card__link i {
  font-size: var(--fs-sm);
  color: var(--primary-color, var(--color-primary));
}
.author-card__link[hidden] { display: none; }

/* ---- 섹션 헤더 ---- */
.author-section-head {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 20px;
  padding: 0 0 14px;
  border-bottom: 2px solid var(--color-gray-800);
}
.author-section-head__title {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-extrabold);
  line-height: 1.3;
  margin: 0;
  color: var(--color-gray-800);
  letter-spacing: -0.01em;
}

/* ---- 반응형 ---- */
@media (max-width: 960px) {
  .author-card { grid-template-columns: 1fr; gap: 18px; padding: 22px; text-align: left; }
  .author-card__avatar { width: 96px; height: 96px; justify-self: start; }
  .author-card__name { font-size: var(--fs-4xl); }
}
@media (max-width: 600px) {
  .author-page { padding: 20px 16px 60px; }
  .author-card { padding: 18px; border-radius: 14px; }
  .author-card__name { font-size: var(--fs-3xl); }
  .author-card__desc { font-size: var(--fs-base); }
  .author-card__credentials { padding: 12px 14px; }
  .author-card__cred { flex-wrap: wrap; gap: 6px 10px; }
  .author-card__cred-label { width: auto; }
  .author-section-head__title { font-size: var(--fs-2xl); }
}

/* =========================================================================
 * 404 페이지 (/?p=...-없음, 존재하지 않는 슬러그) — 2026-04-21 리뉴얼
 * ========================================================================= */
.intra-404 {
  max-width: 1400px;
  margin: 0 auto;
  padding: 32px 24px 80px;
  color: var(--color-gray-700);
}
.intra-404__hero {
  text-align: center;
  padding: 40px 20px 48px;
  border-bottom: 1px solid var(--color-gray-150);
  margin: 24px 0 40px;
}
.intra-404__code {
  font-size: 120px;
  font-weight: var(--fw-black);
  line-height: 1;
  letter-spacing: -0.05em;
  color: var(--primary-color, var(--color-primary));
  margin: 0 0 12px;
}
.intra-404__title {
  font-size: var(--fs-5xl);
  font-weight: var(--fw-extrabold);
  letter-spacing: -0.01em;
  margin: 0 0 14px;
  color: var(--color-gray-800);
}
.intra-404__desc {
  font-size: var(--fs-lg);
  line-height: 1.7;
  color: var(--color-gray-500);
  margin: 0 0 28px;
}
.intra-404__search {
  display: flex;
  gap: 8px;
  max-width: 520px;
  margin: 0 auto 20px;
}
.intra-404__search-field {
  position: relative;
  flex: 1;
  min-width: 0;
}
.intra-404__search-icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-gray-400);
  font-size: var(--fs-base);
}
.intra-404__search-input {
  width: 100%;
  height: 48px;
  padding: 0 16px 0 42px;
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: 999px;
  font-size: var(--fs-lg);
  color: var(--color-gray-800);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.intra-404__search-input:focus {
  outline: none;
  border-color: var(--primary-color, var(--color-primary));
  box-shadow: 0 0 0 3px rgba(var(--rgb-primary), 0.12);
}
.intra-404__search-submit {
  height: 48px;
  padding: 0 24px;
  background: var(--color-gray-800);
  color: var(--color-white);
  border: 0;
  border-radius: 999px;
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  transition: background 0.15s ease;
}
.intra-404__search-submit:hover { background: var(--color-gray-700); }

.intra-404__actions { margin-top: 14px; }
.intra-404__home {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  background: transparent;
  color: var(--color-gray-600);
  text-decoration: none;
  border: 1px solid var(--color-gray-200);
  border-radius: 999px;
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  transition: background 0.15s ease, color 0.15s ease;
}
.intra-404__home:hover {
  background: var(--color-gray-100);
  color: var(--color-gray-800);
}
.intra-404__home i { color: var(--primary-color, var(--color-primary)); }

.intra-404__subtitle {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-extrabold);
  letter-spacing: -0.01em;
  color: var(--color-gray-800);
  margin: 0 0 16px;
  padding: 0 0 10px;
  border-bottom: 2px solid var(--color-gray-800);
}

.intra-404__shortcuts { margin-bottom: 40px; }
.intra-404__chip-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.intra-404__chip-list > li { margin: 0; padding: 0; line-height: inherit; }
.intra-404__chip {
  display: inline-flex;
  padding: 10px 18px;
  background: var(--color-gray-100);
  color: var(--color-gray-700);
  text-decoration: none;
  border-radius: 999px;
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  transition: background 0.15s ease, color 0.15s ease;
}
.intra-404__chip:hover {
  background: var(--primary-color, var(--color-primary));
  color: var(--color-white);
}

.intra-404__recent { margin-bottom: 20px; }

@media (max-width: 600px) {
  .intra-404 { padding: 20px 16px 60px; }
  .intra-404__hero { padding: 28px 12px 36px; margin: 16px 0 28px; }
  .intra-404__code { font-size: 80px; }
  .intra-404__title { font-size: var(--fs-3xl); }
  .intra-404__desc { font-size: var(--fs-base); }
  .intra-404__search { flex-direction: column; }
  .intra-404__search-submit { width: 100%; }
}

/* =========================================================================
 * CLS (레이아웃 이동) 방지 — 2026-04-21 성능 개선
 * 동적 삽입되는 슬롯은 크기를 미리 확보해 CLS 유발을 차단한다.
 * ========================================================================= */

/* 썸네일 컨테이너 aspect-ratio 예약 — 이미지 로드 전 공간 확보 */
.td-module-thumb,
.td-image-wrap { aspect-ratio: 3 / 2; display: block; overflow: hidden; }
.td-module-thumb .entry-thumb,
.td-image-wrap .entry-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Google AdSense 슬롯 — 광고 로드 전 최소 높이 확보 */
.adsbygoogle,
ins.adsbygoogle { min-height: 90px; display: block; }
@media (min-width: 768px) {
  .adsbygoogle,
  ins.adsbygoogle { min-height: 250px; }
}

/* 구독 시트: 반드시 문서 흐름 밖에서 띄워 본문을 밀지 않도록 강제 */
#intra-subscription-sheet,
.intra-subscription-sheet { position: fixed !important; }

/* 검색 오버레이의 동적 자동완성 영역: 최소 높이 예약 (이미 hidden 상태로 시작하지만 안전) */
#so-suggest-list:empty { min-height: 0; }
