:root {
  --site-sticky-h: 88px;
  --ink: #1a2332;
  --ink-soft: #2f3845;
  --brand: #14365d;
  --brand-hover: #1e4976;
  --brand-muted: #4a6f96;
  --surface: #ffffff;
  --page-bg: #f4f6f8;
  --surface-subtle: #f0f3f7;
  --border: #dfe3ea;
  --border-strong: #c5ccd6;
  --muted: #4a5360;
  --accent-warm: #c45c26;
  --shadow-sm: 0 1px 2px rgba(26, 35, 50, 0.06);
  --shadow-md: 0 8px 24px rgba(26, 35, 50, 0.08);
  --radius: 10px;
  --font-sans:
    Pretendard, 'Noto Sans KR', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-serif:
    'Noto Serif KR', Pretendard, 'Nanum Myeongjo', Batang, serif;
  --font-display:
    Pretendard, 'Noto Sans KR', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --admin-canvas: #dde3ec;
  --admin-hint-bg: #eef2f8;
  --admin-hint-accent: rgba(20, 54, 93, 0.28);
  --admin-input-fill: #f4f6fb;
}

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

html {
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-synthesis: none;
  font-kerning: normal;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  background: var(--page-bg);
  color: var(--ink);
  line-height: 1.65;
  font-size: 16px;
}

button,
input,
select,
textarea {
  font-family: inherit;
}

@media (max-width: 767px) {
  html {
    font-size: 17px;
  }
}

a {
  color: var(--brand-hover);
  transition: color 0.15s ease, opacity 0.15s ease;
}

a:hover {
  color: var(--brand);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

.skip-link {
  position: absolute;
  left: -999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.skip-link:focus {
  left: 16px;
  top: calc(16px + var(--site-sticky-h));
  width: auto;
  height: auto;
  padding: 10px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  z-index: 1000;
  border-radius: 6px;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.container {
  width: min(1260px, 100% - 32px);
  margin: 0 auto;
}

@media (max-width: 767px) {
  .container {
    width: min(1260px, 100% - 16px);
  }
}

.site-top-sticky {
  position: sticky;
  top: 0;
  z-index: 500;
}

.site-top-sticky.is-scrolled .site-header {
  box-shadow: 0 4px 14px rgba(26, 35, 50, 0.1);
}

.header-util {
  background: var(--brand);
  color: rgba(255, 255, 255, 0.92);
  font-size: 12px;
  letter-spacing: 0.02em;
}

.header-util-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  flex-wrap: wrap;
}

.header-util-primary {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1 1 auto;
  min-width: 0;
}

.header-site-desc {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  padding: 0;
  font-size: inherit;
  line-height: 1.35;
  font-weight: 500;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  opacity: 0.95;
}

.header-util-links {
  flex-shrink: 0;
  display: flex;
  gap: 16px;
}

.header-util a {
  color: rgba(255, 255, 255, 0.95);
  text-decoration: none;
  font-weight: 500;
}

.header-util a:hover {
  color: #fff;
  text-decoration: underline;
}

.site-header {
  background: var(--surface);
  border-bottom: 3px solid var(--brand);
  box-shadow: var(--shadow-sm);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 0 14px;
}

.logo {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.55rem, 3vw, 2rem);
  color: var(--brand);
  text-decoration: none;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.logo:hover {
  color: var(--brand-hover);
}

.logo.logo--has-image {
  font-size: 0;
  line-height: 0;
}

.logo.logo--has-image:hover .site-header-logo-img {
  opacity: 0.92;
}

.site-header-logo-img {
  display: block;
  max-height: clamp(52px, 9.5vw, 62px);
  width: auto;
  height: auto;
}

.nav-toggle {
  display: none;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  padding: 0;
  border-radius: 10px;
  font-weight: 600;
  color: var(--ink);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}

.nav-toggle-lines {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 20px;
  height: 16px;
  margin: auto;
}

.nav-toggle-line {
  display: block;
  height: 2px;
  border-radius: 1px;
  background: var(--brand);
  transition:
    transform 0.22s ease,
    opacity 0.18s ease;
  transform-origin: center;
}

.nav-toggle.is-open .nav-toggle-line:nth-child(1) {
  transform:
    translateY(7px)
    rotate(45deg);
}

.nav-toggle.is-open .nav-toggle-line:nth-child(2) {
  opacity: 0;
}

.nav-toggle.is-open .nav-toggle-line:nth-child(3) {
  transform:
    translateY(-7px)
    rotate(-45deg);
}

.nav-toggle:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

.site-nav-backdrop {
  display: none;
}

.site-nav ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 6px;
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;
}

.site-nav a {
  text-decoration: none;
  color: var(--ink);
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: -0.02em;
  padding: 8px 12px;
  border-radius: 6px;
}

.site-nav a:hover {
  background: var(--surface-subtle);
  color: var(--brand);
}

.site-nav li:first-child a {
  color: var(--brand);
  font-weight: 700;
}

.main-home {
  padding: 22px 0 44px;
  --radius: 0;
  /* 가로·박스 구분선 (제목 좌측 accent 막대는 별도) */
  --home-line-color: var(--border-strong);
  --home-line: 1px solid var(--home-line-color);
}

/* 홈: 밴드 배경 전체 폭, 구분선은 .container 너비만(보이는 콘텐츠 폭) */
.main-home.main-home--bands {
  padding: 0;
  background: var(--page-bg);
  --home-band-divider: var(--home-line-color);
  --home-band-bg: var(--page-bg);
  --home-band-pad-block: 22px;
  /* 밴드 사이 체감 간격 = 상·하 pad + 구분선 1px */
  --home-band-gap: calc(var(--home-band-pad-block) * 2 + 1px);
  --home-section-inner-gap: 28px;
}

.main-home.main-home--bands > .home-band {
  width: 100%;
  margin: 0;
  padding-top: var(--home-band-pad-block);
  padding-bottom: var(--home-band-pad-block);
  box-sizing: border-box;
  background: var(--home-band-bg);
  border-top: none;
}

.main-home.main-home--bands .home-band > .container {
  border-top: var(--home-line);
}

/* 첫 밴드(히어로): 상단 구분선 없음 */
.main-home.main-home--bands > .container + .home-band > .container {
  border-top: none;
}

.main-home.main-home--bands .section-block-head,
.main-home.main-home--bands .home-side-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
  padding-block: 12px;
  padding-inline: 0;
  border-bottom: var(--home-line);
}

.main-home.main-home--bands .home-band--hero .home-masthead {
  margin-bottom: 0;
}

.main-home.main-home--bands .home-band--hero .home-masthead.home-masthead--has-hero {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

.home-band--pair .home-sections {
  margin: 0;
  gap: 0;
}

/* 2열 묶음: 상단 구분선을 섹션 제목마다 (container 한 줄 연결 제거) */
.main-home.main-home--bands .home-band--pair > .container {
  border-top: none;
}

.main-home.main-home--bands
  .home-band--pair
  .section-block--pe-half
  .section-block-head {
  border-top: var(--home-line);
}

/* 2열 묶음: 모바일·세로 스택 시 단일 밴드 섹션 간격 = 다른 밴드 사이와 동일 */
.main-home.main-home--bands .home-band--pair .home-pe-row {
  gap: var(--home-band-gap);
}

@media (min-width: 960px) {
  .main-home.main-home--bands .home-band--pair .home-pe-row {
    gap: var(--home-section-inner-gap);
  }
}

/* 히어로 아래 배너: ad-slot 래퍼·「광고」 라벨 없이 본문만 */
.main-home.main-home--bands .home-band--masthead-ad .home-masthead-ad-band {
  padding-inline: 0;
  display: flex;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
}

/* 메인 섹션 광고: ad-slot 래퍼·「광고」 라벨 없이 그리드만 */
.main-home.main-home--bands .home-band--section-ad .home-section-ad-band {
  padding-inline: 0;
}

.main-home .home-section-ad-inner {
  display: grid;
  gap: 14px;
  width: 100%;
}

.main-home .home-section-ad-inner--cols-1 {
  grid-template-columns: minmax(0, 1fr);
}

.main-home .home-section-ad-inner--cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.main-home .home-section-ad-inner--cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 640px) {
  .main-home .home-section-ad-inner--cols-1,
  .main-home .home-section-ad-inner--cols-2,
  .main-home .home-section-ad-inner--cols-3 {
    grid-template-columns: 1fr;
  }
}

.main-home .home-section-ad-cell {
  min-width: 0;
}

.main-home .home-section-ad-link {
  display: block;
}

.main-home .home-band--section-ad .home-section-ad-img {
  margin: 0 auto;
}

.main-home.main-home--bands .home-band .section-block {
  margin-top: 0;
}

.main-home.main-home--bands .home-band .section-block--home-society {
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  border-radius: 0;
}

.main-home.main-home--bands .home-band--opinion .opinion-block {
  margin-top: 0;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  border-radius: 0;
}

/*
 * 덩어리 간 --home-band-gap (= pad×2 + 구분선 1px)
 * 갤러리~푸터 = 마지막 밴드 pad + footer mt
 */
body:has(main.main-home--bands) .site-footer {
  margin-top: 24px;
}

/* 홈 메인: 제목 위 일시·섹션 줄 비표시 (더 읽을 거리는 우측 상단 라벨) */
.main-home .hero-card-meta,
.main-home .card-meta {
  display: none;
}

/* 홈: 히어로는 사진 아래 본문만 테두리, 사이드·배경은 page-bg */
.main-home .home-masthead-inner {
  border: none;
  border-radius: 0;
  box-shadow: none;
  background: var(--page-bg);
  padding-block: clamp(12px, 2vw, 18px);
  padding-inline: 0;
  gap: clamp(14px, 1.9vw, 18px);
}

.main-home .home-masthead-inner .hero-card {
  border: none;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}

.main-home .hero-carousel__stage {
  border: var(--home-line);
  border-bottom: none;
  box-sizing: border-box;
}

.main-home .hero-carousel__body-shell {
  border: var(--home-line);
  border-top: none;
  background: var(--page-bg);
  border-radius: 0;
}

.main-home .hero-carousel__body-shell .hero-card-body {
  border: none;
  background: transparent;
  border-radius: 0;
}

.main-home .home-side-rail {
  border: var(--home-line);
  border-radius: 0;
  box-shadow: none;
  background: var(--page-bg);
}

.main-home .home-side-inner {
  padding-inline: 0;
  padding-bottom: 10px;
}

.main-home .side-story {
  position: relative;
  border-radius: 0;
}

.main-home .side-story-section-label {
  position: absolute;
  top: 5px;
  right: 7px;
  z-index: 1;
  max-width: 46%;
  padding: 1px 6px;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: var(--brand-hover);
  background: rgba(20, 54, 93, 0.08);
  border-radius: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  pointer-events: none;
}

.main-home .side-story:has(.side-story-section-label) .side-story-body {
  padding-top: 16px;
  padding-right: 4px;
}

.main-home .side-story:hover,
.main-home .side-story:focus-within {
  border-color: var(--home-line-color);
}

.main-home .side-story-thumb-inner {
  border-radius: 0;
}

.main-home .home-side-sub-inner {
  border-radius: 0;
}

.main-home .side-story-media-fallback {
  border-radius: 0;
}

.main-home .article-card {
  border: var(--home-line);
}

.main-home .ad-slot {
  border: var(--home-line);
  border-radius: 0;
}

.main-home .ad-slot--empty .ad-placeholder {
  border: 1px dashed var(--home-line-color);
  border-radius: 0;
}

.main-home .home-empty-state:not(.home-empty-state--hero) {
  border: 1px dashed var(--home-line-color);
}

body:has(main#main.main-home--bands) .home-quick-banner-inner {
  border-radius: 0;
}

/* ---------- 홈 최상단: 히어로 + 사이드 레일 ---------- */
.home-masthead {
  margin-bottom: 28px;
}

.home-masthead.home-masthead--has-hero {
  margin-bottom: 36px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--border-strong);
}

.home-masthead-inner {
  display: grid;
  gap: 18px;
  align-items: start;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 4px);
  box-shadow:
    var(--shadow-sm),
    0 10px 34px rgba(20, 54, 93, 0.07);
  padding: clamp(14px, 2.4vw, 22px);
}

.home-masthead-inner .hero-card {
  box-shadow: var(--shadow-sm);
}

.home-masthead-inner .home-side-rail {
  box-shadow:
    var(--shadow-sm),
    0 6px 22px rgba(20, 54, 93, 0.07);
}

.main-home .home-masthead-inner .home-side-rail {
  box-shadow: none;
  background: var(--page-bg);
}

@media (max-width: 767px) {
  .home-masthead.home-masthead--has-hero {
    margin-bottom: 28px;
    padding-bottom: 22px;
  }

  .home-masthead-inner {
    padding: 14px 12px;
    gap: 16px;
  }
}

@media (min-width: 960px) {
  .home-masthead-inner {
    grid-template-columns: 1fr minmax(280px, 340px);
    gap: 22px;
    align-items: stretch;
  }

  .home-hero-slot {
    display: flex;
    flex-direction: column;
    align-self: stretch;
    min-height: 0;
  }

  .home-hero-slot .hero-carousel,
  .home-hero-slot .hero-carousel__frame {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 0;
  }

  .home-hero-slot .hero-carousel__stage {
    flex: 1 1 auto;
    min-height: 0;
  }

  .home-hero-slot .hero-card {
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
  }

  .home-hero-slot .hero-carousel__body-shell {
    flex: 0 0 auto;
  }

  .home-side-rail {
    align-self: stretch;
    height: 100%;
    min-height: 0;
    display: flex;
    flex-direction: column;
  }

  .home-side-inner {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
    padding-bottom: 12px;
  }

  .home-side-list {
    flex: 1 1 auto;
  }
}

@media (min-width: 960px) {
  .main-home .home-masthead-inner {
    /* 히어로 : 더 읽을 거리 = 60 : 40 */
    grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
    gap: 20px;
    align-items: stretch;
  }

  .main-home .hero-card-media {
    aspect-ratio: 16 / 8.9;
  }

  .main-home .home-side-list {
    flex: 1 1 auto;
    min-height: 0;
    gap: 5px;
    padding-top: 4px;
  }

  .main-home .home-side-list > .side-story {
    flex: 0 0 auto;
    min-height: 0;
    padding: 5px 7px;
    gap: 10px;
    align-items: flex-start;
  }

  .main-home .side-story-thumb {
    width: 128px;
    height: auto;
    align-self: flex-start;
    aspect-ratio: 16 / 10;
    min-height: 0;
    margin: 0;
    display: block;
  }

  .main-home .side-story-thumb-inner {
    height: auto;
    aspect-ratio: 16 / 10;
  }

  .main-home .side-story-thumb img {
    height: auto;
    aspect-ratio: 16 / 10;
    object-fit: cover;
  }

  .main-home .side-story-media-fallback {
    width: 128px;
    min-height: 58px;
    height: auto;
    margin: 0;
    align-self: flex-start;
  }

  .main-home .side-story:has(.side-story-section-label) .side-story-body {
    align-self: flex-start;
    padding-top: 18px;
    padding-right: 4px;
  }
}

@media (max-width: 959px) {
  .main-home .hero-card-media {
    aspect-ratio: 16 / 9.1;
  }
}

.hero-card {
  background: var(--surface);
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
}

.hero-card-media {
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: linear-gradient(145deg, #1a3354 0%, #243d5f 45%, #14365d 100%);
}

.hero-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s ease;
}

.hero-card:hover .hero-card-media img {
  transform: scale(1.02);
}

.hero-card-placeholder {
  width: 100%;
  height: 100%;
  min-height: 120px;
  display: flex;
  align-items: flex-end;
  padding: 20px;
}

.hero-card-ph-label {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
}

.hero-card-body {
  padding: 22px 24px 26px;
}

.hero-card-meta {
  margin: 0 0 10px;
  font-size: 13px;
  color: var(--muted);
  font-weight: 600;
}

.hero-card-section {
  color: var(--brand);
}

.hero-card-title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(1.45rem, 2.8vw, 2rem);
  font-weight: 700;
  line-height: 1.28;
  letter-spacing: -0.02em;
}

.hero-card-title a {
  color: var(--ink);
  text-decoration: none;
}

.hero-card-title a:hover {
  color: var(--brand-hover);
}

.hero-card-deck {
  margin: 14px 0 0;
  font-size: calc(14px + 2pt);
  font-weight: 700;
  color: var(--ink-soft);
  line-height: 1.55;
}

.hero-card-excerpt {
  margin: 14px 0 0;
  font-size: 14px;
  line-height: 1.58;
  color: var(--muted);
  font-weight: 400;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  overflow: hidden;
  word-break: break-word;
}

/* ---------- 홈 양쪽 퀵 배너(넓은 화면) ---------- */
/* 본문 폭·중앙 = .container 와 동일, 레일은 본문 바깥 여백에 고정 */
.home-page-layout--rails {
  --home-rail-content-w: min(1260px, calc(100% - 32px));
  /* 본문과 퀵배너 사이(좌·우 동일) */
  --home-rail-gap: clamp(6px, 0.75vw, 12px);
  --home-rail-half: min(630px, calc(50% - 16px));
  --home-rail-w: 140px;
  --home-rail-slot-max-h: 520px;
  /* 메인 히어로 밴드·masthead-inner 상단과 동일 기준 */
  --home-band-pad-block: 22px;
  --home-hero-pad-block: clamp(12px, 2vw, 18px);
  --home-quick-rail-top: calc(
    var(--site-sticky-h, 88px)
    + var(--home-band-pad-block)
    + var(--home-hero-pad-block)
  );
  --home-rail-img-max-h: min(
    var(--home-rail-slot-max-h),
    calc(100vh - var(--home-quick-rail-top) - 24px)
  );
  position: relative;
  box-sizing: border-box;
  width: 100%;
}

/* 서브(섹션·기사·정적): 히어로 없음 — 헤더 아래 여백만 */
.home-page-layout--rails.home-page-layout--rails-sub {
  --home-quick-rail-top: calc(var(--site-sticky-h, 88px) + 16px);
  --home-rail-img-max-h: min(
    var(--home-rail-slot-max-h),
    calc(100vh - var(--home-quick-rail-top) - 24px)
  );
}

/* 서브: main.container 이중 폭 제한 해제 → 홈과 동일 본문·레일 간격 */
.home-page-layout--rails-sub .home-page-layout__primary > .container {
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

.home-page-layout__primary {
  width: var(--home-rail-content-w);
  max-width: 100%;
  margin-inline: auto;
  min-width: 0;
}

.home-quick-rail {
  position: fixed;
  top: var(--home-quick-rail-top);
  z-index: 40;
  width: var(--home-rail-w);
  max-width: var(--home-rail-w);
  height: auto;
  max-height: calc(100vh - var(--home-quick-rail-top) - 24px);
  box-sizing: border-box;
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
}

.home-quick-rail--left {
  left: max(
    16px,
    calc(
      50% - var(--home-rail-half) - var(--home-rail-gap) - var(--home-rail-w)
    )
  );
  right: auto;
}

/* 본문 오른쪽 + gap (좌측 레일과 대칭) */
.home-quick-rail--right {
  left: min(
    calc(100% - 16px - var(--home-rail-w)),
    calc(50% + var(--home-rail-half) + var(--home-rail-gap))
  );
  right: auto;
}

/* 사각 박스만 표시(상·하 빈 늘림 없음) */
.home-quick-rail .home-quick-banner-inner {
  display: block;
  padding: 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  text-align: center;
  width: 100%;
  box-sizing: border-box;
  line-height: 0;
  overflow: hidden;
}

.home-quick-rail .home-quick-banner-link {
  display: block;
  line-height: 0;
  font-size: 0;
}

.home-quick-rail .home-quick-banner-img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: var(--home-rail-img-max-h);
  margin-inline: auto;
  vertical-align: top;
}

.home-quick-banner-admin-preview {
  margin-top: 12px;
}

@media (max-width: 1319px) {
  .home-quick-rail {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .home-page-layout--rails {
    --home-rail-content-w: min(1260px, calc(100% - 16px));
    --home-rail-half: min(630px, calc(50% - 8px));
  }
}

/* ---------- 홈 히어로 캐러셀 ---------- */
.hero-carousel {
  outline: none;
}

.hero-carousel__frame {
  position: relative;
  /* 캐러셀 버튼 위치 계산 시 프레임 너비(cqw)·이미지 16∶9 사용 */
  container-type: inline-size;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__btn {
  position: absolute;
  /* cqw 미지원·무효 시 대안 (아래 @supports 블록이 유효할 때에는 덮어씀) */
  top: clamp(104px, 22vw, 180px);
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  margin: 0;
  padding: 10px 8px;
  border: none;
  border-radius: 0;
  cursor: pointer;
  background: transparent;
  box-shadow: none;
  color: rgba(255, 255, 255, 0.92);
  transition:
    color 0.2s ease,
    opacity 0.2s ease;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__btn:hover {
  color: #fff;
  opacity: 0.94;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__btn:active {
  opacity: 0.78;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__btn:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.92);
  outline-offset: 4px;
  border-radius: 2px;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__btn--prev {
  left: 10px;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__btn--next {
  right: 10px;
}

.hero-carousel__btn-icon {
  display: block;
  width: 14px;
  height: 14px;
  box-sizing: border-box;
  transform: rotate(45deg);
  border: solid currentColor;
  border-width: 0 2px 2px 0;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.5));
}

.hero-carousel__btn-icon--prev {
  margin-left: 4px;
  transform: rotate(135deg);
}

.hero-carousel__btn-icon--next {
  margin-right: 3px;
  transform: rotate(-45deg);
}

.hero-carousel--single .hero-carousel__btn {
  display: none;
}

.hero-carousel__body-shell {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  min-width: 0;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__body-pane {
  grid-area: 1 / 1;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity var(--hero-carousel-transition-ms, 380ms) ease,
    visibility var(--hero-carousel-transition-ms, 380ms);
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__body-pane:not(.is-active) {
  position: absolute;
  width: 100%;
  height: 0;
  overflow: hidden;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__body-pane.is-active {
  position: relative;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/*
 * 슬라이드별 본문 높이 측정(hero-carousel.js): is-measuring pane만 레이아웃에 포함.
 */
.hero-carousel--measuring:not(.hero-carousel--single)
  .hero-carousel__body-pane.is-measuring {
  position: relative;
  width: 100%;
  height: auto;
  overflow: visible;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: none;
}

.hero-card--media-only {
  display: block;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__stage {
  display: flex;
  flex-flow: column nowrap;
  overflow: hidden;
  min-height: 0;
}

.hero-carousel:not(.hero-carousel--single) .hero-carousel__track {
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
}

.hero-carousel--fade:not(.hero-carousel--single) .hero-carousel__track {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
}

.hero-carousel--fade:not(.hero-carousel--single) .hero-carousel__pane {
  grid-area: 1 / 1;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity var(--hero-carousel-transition-ms, 380ms) ease,
    visibility var(--hero-carousel-transition-ms, 380ms);
}

.hero-carousel--fade:not(.hero-carousel--single) .hero-carousel__pane.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.hero-carousel--slide:not(.hero-carousel--single) .hero-carousel__track {
  display: flex;
  flex-flow: row nowrap;
  transform: translateX(0%);
  transition: transform var(--hero-carousel-transition-ms, 380ms) ease;
  will-change: transform;
}

.hero-carousel--slide:not(.hero-carousel--single) .hero-carousel__pane {
  flex: 0 0 100%;
  min-width: 0;
  box-sizing: border-box;
  opacity: 1;
  visibility: visible;
  pointer-events: none;
}

.hero-carousel--slide:not(.hero-carousel--single) .hero-carousel__pane.is-active {
  pointer-events: auto;
}

@supports (width: 1cqw) {
  /* .hero-card-media 와 동일 비율(16∶9) 이미지 영역 높이의 절반 = 프레임너비×9÷32 */
  .hero-carousel:not(.hero-carousel--single) .hero-carousel__btn {
    top: calc(100cqw * 9 / 32);
    transform: translateY(-50%);
  }
}

@media (max-width: 520px) {
  .hero-carousel:not(.hero-carousel--single) .hero-carousel__btn {
    padding: 10px 6px;
  }

  .hero-carousel:not(.hero-carousel--single) .hero-carousel__btn--prev {
    left: 4px;
  }

  .hero-carousel:not(.hero-carousel--single) .hero-carousel__btn--next {
    right: 4px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-carousel--fade:not(.hero-carousel--single) .hero-carousel__pane {
    transition-duration: 0.01ms;
  }

  .hero-carousel:not(.hero-carousel--single) .hero-carousel__body-pane {
    transition-duration: 0.01ms;
  }

  .hero-carousel--slide:not(.hero-carousel--single) .hero-carousel__track {
    transition-duration: 0.01ms;
  }
}

.home-side-rail {
  position: sticky;
  top: calc(var(--site-sticky-h) + 8px);
  overflow: hidden;
  background:
    radial-gradient(
      ellipse 130% 90% at 100% -30%,
      rgba(20, 54, 93, 0.07),
      transparent 52%
    ),
    var(--surface);
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 2px);
  box-shadow:
    var(--shadow-sm),
    0 14px 36px rgba(20, 54, 93, 0.08);
}

@media (max-width: 959px) {
  .home-side-rail {
    position: static;
  }
}

.home-side-accent {
  display: block;
  height: 5px;
  background: linear-gradient(
    90deg,
    #0f2944 0%,
    var(--brand) 34%,
    #3971b8 70%,
    rgba(196, 92, 38, 0.78) 100%
  );
}

.home-side-inner {
  padding: 0 12px 10px;
}

.home-side-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 14px 4px 12px;
  margin-bottom: 2px;
  border-bottom: 1px solid rgba(223, 227, 234, 0.95);
}

.home-side-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.06rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.22;
}

.home-side-sub {
  display: inline-flex;
}

.home-side-sub-inner {
  display: inline-flex;
  align-items: center;
  padding: 4px 11px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--brand);
  text-transform: uppercase;
  background: rgba(20, 54, 93, 0.07);
  border: 1px solid rgba(20, 54, 93, 0.14);
  border-radius: 999px;
}

.home-side-list {
  list-style: none;
  margin: 0;
  padding: 6px 0 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.home-empty-state {
  margin: 0;
  padding: 20px 14px;
  text-align: center;
  color: var(--muted);
  font-size: 14px;
  font-weight: 600;
  line-height: 1.45;
  border: 1px dashed var(--border);
  background: var(--surface);
  border-radius: 0;
}

.main-home .home-empty-state {
  border-radius: 0;
}

.home-empty-state--hero {
  border: none;
  background: transparent;
  padding: 8px 0 4px;
}

.home-empty-state--side {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 120px;
  margin: 4px 12px 8px;
}

.main-home .home-side-list--empty {
  flex: 1 1 auto;
  min-height: 0;
}

.home-side-list__empty-item {
  flex: 1 1 auto;
  display: flex;
  min-height: 0;
  list-style: none;
}

.home-empty-state--section-lead,
.home-empty-state--section-rail,
.home-empty-state--section-grid,
.home-empty-state--opinion {
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.main-home .home-empty-state--section-grid,
.main-home .home-empty-state--opinion {
  grid-column: 1 / -1;
}

.main-home .opinion-grid--empty {
  min-height: 140px;
}

.hero-carousel--empty .hero-carousel__stage {
  min-height: clamp(160px, 28vw, 280px);
}

.hero-carousel--empty .hero-card-media--empty {
  display: block;
  pointer-events: none;
}

.hero-carousel--empty .hero-card-body--empty {
  padding: 14px 16px 18px;
}

@media (max-width: 767px) {
  .home-side-list > li:nth-child(n + 6) {
    display: none;
  }

  .home-side-inner {
    padding: 0 12px 10px;
  }

  .home-side-head {
    padding-inline: 0;
    padding-block: 14px 12px;
  }

  .main-home.main-home--bands .home-side-head {
    padding-block: 12px;
  }

  .hero-card-body {
    padding: 18px 12px 20px;
  }

  .main-home .hero-carousel__body-shell .hero-card-body {
    padding: 14px 12px 14px;
  }

  .main-home .hero-card-deck {
    margin-top: 10px;
  }

  .main-home .hero-card-excerpt {
    margin-top: 10px;
    -webkit-line-clamp: 2;
    line-clamp: 2;
  }
}

.side-story {
  display: flex;
  gap: 12px;
  align-items: stretch;
  padding: 9px;
  margin: 0;
  border-radius: 11px;
  border: 1px solid transparent;
  background: rgba(240, 243, 247, 0.45);
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    transform 0.18s ease;
}

.side-story:hover {
  border-color: rgba(20, 54, 93, 0.14);
  background: var(--surface);
  box-shadow: 0 5px 18px rgba(20, 54, 93, 0.1);
  transform: translateY(-1px);
}

.side-story:focus-within {
  border-color: rgba(20, 54, 93, 0.14);
  background: var(--surface);
  box-shadow: 0 5px 18px rgba(20, 54, 93, 0.1);
}

.side-story-thumb {
  flex-shrink: 0;
  width: 108px;
  height: 69px;
  align-self: center;
  margin: 1px 0;
}

.side-story-thumb-inner {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 8px;
  background: var(--surface-subtle);
  box-shadow:
    inset 0 0 0 1px rgba(20, 54, 93, 0.09),
    0 1px 5px rgba(26, 35, 50, 0.07);
}

.side-story-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease;
}

.side-story:hover .side-story-thumb img {
  transform: scale(1.06);
}

.side-story-thumb:focus-visible .side-story-thumb-inner {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

.side-story-media-fallback {
  flex-shrink: 0;
  align-self: stretch;
  width: 5px;
  min-height: 46px;
  margin: 6px 0 6px 3px;
  border-radius: 999px;
  background: linear-gradient(
    180deg,
    var(--brand),
    rgba(196, 92, 38, 0.55)
  );
  box-shadow: 0 0 0 1px rgba(20, 54, 93, 0.12);
}

.side-story-body {
  min-width: 0;
  flex: 1;
  align-self: center;
}

.side-story-meta {
  margin: 0 0 7px;
  display: inline-block;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.07em;
  color: var(--brand-hover);
  text-transform: uppercase;
  line-height: 1.35;
  background: rgba(20, 54, 93, 0.08);
  border-radius: 5px;
}

.side-story-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.43;
  letter-spacing: -0.015em;
}

.side-story-title a {
  color: var(--ink);
  text-decoration: none;
  transition: color 0.15s ease;
}

.side-story-title a:hover {
  color: var(--brand-hover);
}

@media (prefers-reduced-motion: reduce) {
  .side-story {
    transition: none;
  }

  .side-story:hover {
    transform: none;
  }

  .side-story-thumb img {
    transition: none;
  }

  .side-story:hover .side-story-thumb img {
    transform: none;
  }
}

.home-sections {
  display: flex;
  flex-direction: column;
  gap: var(--home-section-inner-gap, 28px);
}

@media (max-width: 767px) {
  .main-home.main-home--bands {
    --home-band-pad-block: 18px;
    --home-section-inner-gap: 24px;
  }
}

.home-sections > .section-block {
  margin-top: 0;
}

.home-sections > .home-pe-row {
  margin-top: 0;
}

/* 홈 사회: 왼쪽 리드 1건, 오른쪽 3건 수직 목록 */
.home-society-split {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

@media (min-width: 960px) {
  .home-society-split {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
  }

  .home-society-split--visit {
    grid-template-columns: minmax(0, 45fr) minmax(0, 55fr);
    align-items: stretch;
  }
}

.home-society-split--visit .home-society-rail-grid.article-grid--home {
  gap: 10px;
}

/* 업체탐방 리드: 썸네일 전체 노출(잘림 없음)·제목만 */
.home-society-split--visit
  .home-society-lead-grid.article-grid--home
  .article-card--lead:has(.card-thumb)
  .card-thumb {
  flex: 0 0 auto;
  height: auto;
  min-height: 0;
  position: static;
}

.home-society-split--visit
  .home-society-lead-grid.article-grid--home
  .article-card--lead:has(.card-thumb)
  .card-thumb
  img {
  position: static;
  display: block;
  width: 100%;
  height: auto;
  min-height: 0;
  aspect-ratio: unset;
  object-fit: contain;
}

.home-society-split--visit
  .home-society-lead-grid
  .article-card--lead
  .card-deck,
.home-society-split--visit
  .home-society-lead-grid
  .article-card--lead
  .card-excerpt {
  display: none;
}

/* 조합뉴스·지역뉴스: 홈 카드 제목만 */
.article-grid--pe-news .card-deck,
.article-grid--pe-news .card-excerpt,
.article-grid--pe-localnews .card-deck,
.article-grid--pe-localnews .card-excerpt,
.article-grid--news-home .card-meta,
.article-grid--news-home .card-deck,
.article-grid--news-home .card-excerpt,
.article-grid--localnews-home .card-deck,
.article-grid--localnews-home .card-excerpt {
  display: none;
}

/* 모바일 업체탐방: 리드 1건 + 랠 3건만 노출 */
@media (max-width: 959px) {
  .home-society-split--visit
    .home-society-rail-grid.article-grid--home
    > .article-card:nth-child(n + 4) {
    display: none;
  }
}

@media (min-width: 960px) {
  .home-society-split--visit .home-society-split__lead,
  .home-society-split--visit .home-society-split__rail {
    display: flex;
    flex-direction: column;
    min-height: 0;
  }

  .home-society-split--visit .home-society-split__lead .home-society-lead-grid {
    flex: 1 1 auto;
    min-height: 0;
    height: 100%;
  }

  .home-society-split--visit .home-society-split__rail .home-society-rail-grid {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 10px;
    min-height: 0;
    height: 100%;
  }

  .home-society-split--visit
    .home-society-lead-grid.article-grid--home
    .article-card--lead {
    height: 100%;
    min-height: 0;
    display: flex;
    flex-direction: column;
  }

  .home-society-split--visit
    .home-society-lead-grid
    .article-card--lead
    .card-body {
    flex: 0 0 auto;
  }
}

.home-society-rail-grid.article-grid--home {
  grid-template-columns: 1fr;
  gap: 12px;
}

/* 홈 3번째 섹션 오른쪽 랠: 썸네일 숨김 · 텍스트만 */
.home-society-rail-grid.article-grid--home .article-card .card-thumb {
  display: none;
}

.home-society-rail-grid.article-grid--home .article-card,
.home-society-rail-grid.article-grid--home .article-card:has(.card-thumb) {
  grid-template-columns: 1fr;
}

.home-pe-row {
  display: grid;
  gap: var(--home-section-inner-gap, 28px);
  grid-template-columns: 1fr;
}

@media (min-width: 960px) {
  .home-pe-row {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: stretch;
  }

  .home-pe-row .section-block--pe-half {
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%;
  }

  .home-pe-row .section-block--pe-half .section-block-head {
    flex: 0 0 auto;
  }

  .home-pe-row .section-block--pe-half .article-grid.article-grid--home {
    flex: 1 1 auto;
    min-height: 0;
  }
}

.home-pe-row .section-block--pe-half {
  margin-top: 0;
}

.article-grid--vertical-stack {
  grid-template-columns: 1fr;
  gap: 14px;
}

.article-grid--vertical-stack .article-card--lead {
  grid-column: auto;
}

@media (min-width: 640px) {
  .article-grid--vertical-stack .article-card,
  .article-grid--vertical-stack .article-card:has(.card-thumb),
  .article-grid--vertical-stack .article-card--lead,
  .article-grid--vertical-stack .article-card--lead:has(.card-thumb) {
    grid-template-columns: 1fr;
  }

  .article-grid--vertical-stack .article-card:has(.card-thumb) .card-thumb {
    height: auto;
    min-height: 0;
  }

  .article-grid--vertical-stack .article-card:has(.card-thumb) .card-thumb img {
    width: 100%;
    height: auto;
    min-height: 140px;
    aspect-ratio: 16 / 10;
    object-fit: cover;
  }
}

/*
 * 홈 전폭 뉴스형(news-home): 1행 4열(4건) · 썸네일 위 · 제목 아래.
 * 반칸 PE는 article-grid--pe-news 규칙 사용.
 */
.main-home .article-grid--economy.article-grid--news-home:not(.article-grid--pe-news) {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

@media (min-width: 960px) {
  .main-home .article-grid--economy.article-grid--news-home:not(.article-grid--pe-news) {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
  }
}

.main-home
  .article-grid--economy.article-grid--news-home:not(.article-grid--pe-news)
  .article-card:has(.card-thumb)
  .card-thumb
  img {
  aspect-ratio: 16 / 10;
  min-height: 112px;
}

.main-home
  .article-grid--economy.article-grid--news-home:not(.article-grid--pe-news)
  .article-card
  .card-body {
  padding: 12px 14px 14px;
}

/* 홈 PE 2열: 조합·지역 동일 economy 2칸(기사 2건) */
@media (min-width: 960px) {
  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--economy {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
    gap: 8px;
  }

  .home-pe-row
    .article-grid--home.article-grid--economy
    > .article-card {
    height: 100%;
  }

  .home-pe-row
    .article-grid--home.article-grid--economy
    .article-card:has(.card-thumb)
    .card-thumb {
    height: auto;
    min-height: 0;
    overflow: hidden;
  }

  .home-pe-row
    .article-grid--home.article-grid--economy
    .article-card:has(.card-thumb)
    .card-thumb
    img {
    display: block;
    width: 100%;
    height: auto;
    min-height: 102px;
    aspect-ratio: 3 / 2;
    object-fit: cover;
  }

  .home-pe-row
    .article-grid--home.article-grid--economy
    .article-card
    .card-body {
    padding: 8px 10px 10px;
  }
}

/* 경제만: 카드 내부 세로(이미지 상단) · 카드 목록 2열 그리드(홈) */
.article-grid--economy {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.article-grid--economy .article-card--lead {
  grid-column: auto;
}

@media (max-width: 360px) {
  .article-grid--economy:not(.article-grid--news-home):not(.article-grid--pe-news) {
    grid-template-columns: 1fr;
  }

  .article-grid--economy.article-grid--news-home,
  .article-grid--economy.article-grid--pe-news {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
}

@media (min-width: 640px) {
  .article-grid--economy .article-card,
  .article-grid--economy .article-card:has(.card-thumb),
  .article-grid--economy .article-card--lead,
  .article-grid--economy .article-card--lead:has(.card-thumb) {
    grid-template-columns: 1fr;
  }

  .article-grid--economy .article-card:has(.card-thumb) .card-thumb {
    height: auto;
    min-height: 0;
  }

  .article-grid--economy .article-card:has(.card-thumb) .card-thumb img {
    width: 100%;
    height: auto;
    min-height: 120px;
    aspect-ratio: 3 / 2;
    object-fit: cover;
  }
}

.main-home .section-block-head {
  margin-bottom: 14px;
}

.main-home .section-block-head h2 {
  font-size: 1.34rem;
  font-weight: 900;
  color: #000000;
}

.main-home .section-block-head h2 a {
  color: #000000;
}

.main-home .section-block-head h2 a:hover {
  color: #000000;
  opacity: 0.88;
}

.article-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr;
  box-shadow: var(--shadow-sm);
  transition:
    box-shadow 0.2s ease,
    transform 0.2s ease,
    border-color 0.2s ease;
}

.article-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
  border-color: var(--border-strong);
}

.article-page .public-admin-edit {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
  padding: 7px 14px;
  border-radius: 7px;
  background: var(--brand);
  color: #fff !important;
  text-decoration: none;
  box-shadow: var(--shadow-md);
  letter-spacing: 0.02em;
}

.article-page .public-admin-edit:hover {
  color: #fff !important;
  background: var(--brand-hover);
}

.article-page .public-admin-edit:focus-visible {
  outline: 3px solid var(--brand);
  outline-offset: 2px;
}

.article-admin-edit-row {
  margin: 12px 0 0;
}

.article-share-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px 16px;
}

.article-share-main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  flex: 1 1 auto;
  min-width: 0;
}

.article-share-admin {
  flex: 0 0 auto;
  margin-left: auto;
}

.article-page .public-admin-edit--article {
  display: inline-flex;
  align-items: center;
}

@media (min-width: 640px) {
  .article-grid:not(.article-grid--home) .article-card,
  .article-list .article-card {
    grid-template-columns: 148px 1fr;
  }
}

.article-grid--home .article-card {
  grid-template-columns: 1fr;
}

.article-grid--home .card-thumb img {
  aspect-ratio: 16 / 10;
  min-height: 140px;
}

.article-grid--home.article-grid--economy .card-thumb img {
  aspect-ratio: 3 / 2;
  min-height: 132px;
}

@media (min-width: 640px) {
  .article-grid--home:not(.article-grid--news-home):not(.article-grid--pe-news)
    .article-card:has(.card-thumb) {
    grid-template-columns: 148px 1fr;
    align-items: stretch;
  }

  .article-grid--home .article-card--lead:has(.card-thumb) {
    grid-template-columns: minmax(200px, 38%) 1fr;
  }

  .article-grid--home .article-card:has(.card-thumb) .card-thumb {
    display: block;
    height: 100%;
    min-height: 112px;
  }

  /* 홈 사회 오른쪽 랠: 640px+ 에서 위 display:block 보다 우선(텍스트 전용) */
  .home-society-rail-grid.article-grid--home .article-card:has(.card-thumb) {
    grid-template-columns: 1fr;
  }

  .home-society-rail-grid.article-grid--home .article-card:has(.card-thumb) .card-thumb {
    display: none;
  }

  .article-grid--home .article-card:has(.card-thumb) .card-thumb img {
    width: 100%;
    height: 100%;
    min-height: 112px;
    aspect-ratio: unset;
    object-fit: cover;
  }

  .article-grid--home .article-card--lead:has(.card-thumb) .card-thumb img {
    min-height: 132px;
  }

  /* 홈 경제: 이미지 위·텍스트 아래(일반 홈 카드의 가형 레이아웃 무효) */
  .article-grid--home.article-grid--economy .article-card:has(.card-thumb),
  .article-grid--home.article-grid--economy .article-card--lead:has(.card-thumb) {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .article-grid--home.article-grid--economy .article-card:has(.card-thumb) .card-thumb {
    height: auto;
    min-height: 0;
  }

  .article-grid--home.article-grid--economy .article-card:has(.card-thumb) .card-thumb img {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    min-height: 124px;
  }

  .home-pe-row .section-block--pe-half .article-grid--home.article-grid--economy .card-body {
    padding: 12px 14px 14px;
  }

  .home-pe-row .section-block--pe-half .article-grid--home.article-grid--economy .card-meta {
    font-size: 11px;
  }

  .home-pe-row .section-block--pe-half .article-grid--home.article-grid--economy .card-deck {
    font-size: calc(12px + 2pt);
    font-weight: 700;
    color: var(--ink-soft);
  }

  .home-pe-row .section-block--pe-half .article-grid--home.article-grid--economy .card-excerpt {
    font-size: 12px;
    margin-top: 8px;
    font-weight: 400;
  }

  .home-pe-row .section-block--pe-half .article-grid--home.article-grid--economy
    .article-card:has(.card-thumb)
    .card-thumb
    img {
    min-height: 102px;
  }

  .home-sections > .section-block .article-grid--home.article-grid--economy
    .article-card:has(.card-thumb)
    .card-thumb
    img {
    min-height: 128px;
  }

  /* 홈 사회 리드: 썸네일 상단·본문 하단·이미지 강조 */
  .home-society-lead-grid.article-grid--home .article-card--lead:has(.card-thumb) {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .home-society-lead-grid.article-grid--home
    .article-card--lead:has(.card-thumb)
    .card-thumb {
    height: auto;
    min-height: 0;
  }

  .home-society-lead-grid.article-grid--home
    .article-card--lead:has(.card-thumb)
    .card-thumb
    img {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    min-height: 168px;
    object-fit: cover;
  }

  .home-society-rail-grid .card-body {
    padding: 12px 14px 13px;
  }

  .home-society-rail-grid .card-deck {
    font-size: calc(12.5px + 2pt);
    font-weight: 700;
    color: var(--ink-soft);
    line-height: 1.5;
  }

  .home-society-rail-grid .card-excerpt {
    -webkit-line-clamp: 2;
    line-clamp: 2;
    margin-top: 8px;
    font-size: 12.5px;
    font-weight: 400;
  }
}

@media (min-width: 960px) {
  .home-pe-row .section-block--pe-half .article-grid--home.article-grid--economy
    .article-card:has(.card-thumb)
    .card-thumb
    img {
    min-height: 0;
  }

  .home-society-lead-grid.article-grid--home
    .article-card--lead:has(.card-thumb)
    .card-thumb
    img {
    min-height: 198px;
  }
}

@media (max-width: 767px) {
  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--pe-news {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--pe-news
    .article-card,
  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--pe-news
    .article-card:has(.card-thumb) {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--pe-news
    .article-card:has(.card-thumb)
    .card-thumb {
    height: auto;
    min-height: 0;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--pe-news
    .article-card:has(.card-thumb)
    .card-thumb
    img {
    width: 100%;
    height: auto;
    min-height: 104px;
    aspect-ratio: 16 / 10;
    object-fit: cover;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--pe-news
    .card-body {
    padding: 10px 10px 12px;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--pe-news
    .card-title {
    font-size: 1.08rem;
    line-height: 1.35;
  }
}

@media (max-width: 639px) {
  .article-grid--home .article-card--lead .card-thumb img {
    aspect-ratio: 16 / 9;
    min-height: 168px;
  }

  .home-society-lead-grid.article-grid--home .article-card--lead .card-thumb img {
    min-height: 152px;
  }

  /* 홈 정치·경제 줄: 카드별 썸네일 좌·본문 우, 경제는 나란히 2칸 해제 후 세로 목록 */
  .home-pe-row
    .section-block--pe-half
    .article-grid--economy.article-grid--home:not(.article-grid--pe-news) {
    grid-template-columns: 1fr;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--vertical-stack:not(.article-grid--news-home):not(
      .article-grid--pe-news
    )
    .article-card:has(.card-thumb),
  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--economy:not(.article-grid--pe-news)
    .article-card:has(.card-thumb) {
    grid-template-columns: minmax(102px, 32%) minmax(0, 1fr);
    align-items: stretch;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home:not(.article-grid--pe-news)
    .article-card:has(.card-thumb)
    .card-thumb {
    display: block;
    height: 100%;
    min-height: 104px;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home:not(.article-grid--pe-news)
    .article-card:has(.card-thumb)
    .card-thumb
    img {
    width: 100%;
    height: 100%;
    min-height: 104px;
    aspect-ratio: unset;
    object-fit: cover;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--economy:not(.article-grid--pe-news)
    .card-body {
    padding: 10px 12px;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--vertical-stack
    .article-card
    .card-body {
    padding: 11px 12px 13px;
  }

  /*
   * 조합뉴스(news-home): PE 모바일에서만 썸네일 좌·본문 우 규칙을 쓰지 않고
   * 이미지 위·내용 아래(홈 vertical-stack 기본)로 맞춤.
   */
  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--vertical-stack.article-grid--news-home
    .article-card,
  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--vertical-stack.article-grid--news-home
    .article-card:has(.card-thumb) {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--vertical-stack.article-grid--news-home
    .article-card:has(.card-thumb)
    .card-thumb {
    height: auto;
    min-height: 0;
  }

  .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--vertical-stack.article-grid--news-home
    .article-card:has(.card-thumb)
    .card-thumb
    img {
    width: 100%;
    height: auto;
    min-height: 120px;
    aspect-ratio: 16 / 10;
    object-fit: cover;
  }
}

.card-thumb {
  background: var(--surface-subtle);
}

.card-thumb img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  object-fit: cover;
  display: block;
}

.card-body {
  padding: 16px 18px;
}

.card-meta {
  margin: 0 0 8px;
  font-size: 12px;
  color: var(--muted);
  font-weight: 500;
}

.card-title {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 700;
  line-height: 1.45;
}

.card-title a {
  color: inherit;
  text-decoration: none;
}

.card-title a:hover {
  color: var(--brand-hover);
}

.card-deck {
  margin: 10px 0 0;
  font-size: calc(14px + 1pt);
  font-weight: 600;
  color: var(--muted);
  line-height: 1.5;
}

.article-grid--home .card-deck {
  margin: 10px 0 0;
  font-size: calc(13px + 2pt);
  font-weight: 700;
  color: var(--ink-soft);
  line-height: 1.52;
}

.article-grid--home .card-excerpt {
  margin: 10px 0 0;
  font-size: 13px;
  line-height: 1.5;
  font-weight: 400;
  color: var(--muted);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  line-clamp: 4;
  overflow: hidden;
  word-break: break-word;
}

.section-block {
  margin-top: 36px;
}

.section-block-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-strong);
}

.section-block-head h2 {
  margin: 0;
  padding: 0 0 0 14px;
  border-left: 4px solid var(--brand);
  font-size: 1.22rem;
  font-weight: 800;
  color: var(--ink);
  line-height: 1.3;
}

.section-more::after {
  content: " +";
  font-weight: 800;
}

.section-more {
  flex-shrink: 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--brand-muted);
  text-decoration: none;
  padding: 6px 4px;
}

.section-more:hover {
  color: var(--brand);
}

.section-block-head a.section-more {
  border-left: none;
  padding-left: 4px;
}

.section-block-head h2 a {
  color: inherit;
  text-decoration: none;
}

.section-block-head h2 a:hover {
  color: var(--brand-hover);
}

.article-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.article-grid--home {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

/* 홈 세로 목록: 항상 1열(.article-grid--home auto-fit에 덮이지 않게) */
.article-grid--home.article-grid--vertical-stack:not(.article-grid--news-home) {
  grid-template-columns: 1fr;
}

@media (max-width: 767px) {
  .main-home .home-pe-row .article-grid--home.article-grid--pe-news {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
}

/* 홈 문화: 기본 한 줄 2건(매우 좁은 폭만 1열) */
.article-grid--home.article-grid--home-culture {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 399px) {
  .article-grid--home.article-grid--home-culture {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 1100px) {
  .article-grid--home {
    grid-template-columns: repeat(4, 1fr);
  }

  .article-grid--home .article-card--lead {
    grid-column: span 2;
  }

  .article-grid--home.article-grid--vertical-stack:not(.article-grid--news-home) {
    grid-template-columns: 1fr;
  }

  .main-home .article-grid--economy.article-grid--news-home:not(.article-grid--pe-news) {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .article-grid--home.article-grid--vertical-stack .article-card--lead {
    grid-column: auto;
  }

  .article-grid--home.article-grid--economy {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .article-grid--home.article-grid--economy .article-card--lead {
    grid-column: auto;
  }

  .article-grid--home.article-grid--home-culture {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .article-grid--home.article-grid--home-culture .article-card--lead {
    grid-column: auto;
  }

  .home-society-lead-grid.article-grid--home {
    grid-template-columns: 1fr;
  }

  .home-society-lead-grid.article-grid--home .article-card--lead {
    grid-column: auto;
  }
}

.article-grid--home .article-card--lead {
  box-shadow: var(--shadow-md);
}

@media (min-width: 768px) {
  .article-grid--home .article-card--lead .card-title {
    font-size: 1.22rem;
  }
}

@media (min-width: 1100px) {
  .article-grid--home .article-card--lead .card-title {
    font-size: 1.38rem;
    line-height: 1.35;
  }

  .article-grid--home .article-card--lead .card-body {
    padding: 20px 22px 22px;
  }
}

/* 오피니언 홈: 모바일 1열 · 680px+ 가로 3열(부모 선택자로 일반 홈 4열 덮음) */
.opinion-block .article-grid.article-grid--home.opinion-grid {
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (min-width: 680px) {
  .opinion-block .article-grid.article-grid--home.opinion-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1100px) {
  .opinion-block .article-grid.article-grid--home.opinion-grid {
    gap: 18px;
  }
}

/* 갤러리형 홈 그리드 열 수: 파일 하단 .section-block--home-gallery 규칙 참고 */

/* 홈 오피니언: 바깥은 가로 최대 3열, 카드 안은 이미지 위 · 본문 아래(썸네일 4:3) */
.opinion-block .article-grid.article-grid--home.opinion-grid
  .article-card:has(.card-thumb)
  .card-thumb
  img {
  width: 100%;
  height: auto;
  min-height: 0;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

@media (min-width: 640px) {
  .opinion-block .article-grid.article-grid--home.opinion-grid .article-card,
  .opinion-block .article-grid.article-grid--home.opinion-grid .article-card:has(.card-thumb),
  .opinion-block .article-grid.article-grid--home.opinion-grid .article-card--lead,
  .opinion-block .article-grid.article-grid--home.opinion-grid .article-card--lead:has(.card-thumb) {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .opinion-block .article-grid.article-grid--home.opinion-grid
    .article-card:has(.card-thumb)
    .card-thumb {
    height: auto;
    min-height: 0;
  }
}

.opinion-block .article-grid.article-grid--home.opinion-grid .card-body {
  padding: 8px 11px 10px;
  min-width: 0;
}

.opinion-block .article-grid.article-grid--home.opinion-grid .card-title {
  font-size: 0.92rem;
  line-height: 1.38;
}

.opinion-block .article-grid.article-grid--home.opinion-grid .card-meta {
  margin: 0 0 5px;
  font-size: 11px;
}

.opinion-block .article-grid.article-grid--home.opinion-grid .card-deck {
  margin-top: 5px;
  font-size: calc(11px + 2pt);
  font-weight: 700;
  color: var(--ink-soft);
  line-height: 1.42;
}

/* 홈 메인(.main-home): 기사 제목·부제·요약(본문 미리보기) 한 단계 크기·진하게 */
.main-home .hero-card-title {
  font-size: clamp(1.6rem, 3.12vw, 2.28rem);
  font-weight: 700;
}

.main-home .hero-card-title a {
  color: #000000;
}

.main-home .hero-card-title a:hover {
  color: #000000;
  opacity: 0.88;
}

.main-home .hero-card-deck {
  font-size: calc(18px + 2pt);
  font-weight: 800;
  line-height: 1.5;
  color: var(--ink-soft);
}

.main-home .hero-card-excerpt {
  font-size: 15px;
  font-weight: 500;
  line-height: 1.55;
  color: var(--ink-soft);
}

.main-home .side-story-title {
  font-family: var(--font-sans);
  font-size: 1.08rem;
  font-weight: 700;
  line-height: 1.35;
}

/* 홈 섹션 블록: 섹션 목록(section.php)과 동일한 기사 제목 서체 */
.main-home .section-block .card-title,
.main-home .opinion-block .card-title {
  font-family: var(--font-sans);
  font-size: 1.08rem;
  font-weight: 700;
  line-height: 1.35;
}

/* 홈 메인: 기사 제목 2줄 말줄임 */
.main-home .hero-card-title,
.main-home .side-story-title,
.main-home .section-block .card-title,
.main-home .opinion-block .card-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  word-break: break-word;
}

.main-home .article-grid--home .card-body {
  min-width: 0;
}

.main-home .article-grid--home .card-deck {
  font-size: calc(14px + 2pt);
  font-weight: 800;
  color: var(--ink-soft);
}

.main-home .article-grid--home .card-excerpt {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-soft);
}

@media (max-width: 767px) {
  /*
   * 홈 각 섹션 카드: 모바일은 제목만 노출(섹션·날짜·부제·본문 발췌 숨김).
   * 메인 히어로(.hero-card)는 별도 규칙 — 변경 없음.
   */
  .main-home
    .section-block
    .article-grid--home
    .article-card
    .card-meta,
  .main-home
    .section-block
    .article-grid--home
    .article-card
    .card-deck,
  .main-home
    .section-block
    .article-grid--home
    .article-card
    .card-excerpt {
    display: none;
  }
}

@media (min-width: 768px) {
  .main-home .article-grid--home .article-card--lead .card-title {
    font-size: 1.08rem;
    line-height: 1.35;
  }
}

@media (min-width: 1100px) {
  .main-home .article-grid--home .article-card--lead .card-title {
    font-size: 1.08rem;
    line-height: 1.35;
  }
}

@media (min-width: 640px) {
  .main-home
    .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--economy
    .card-deck {
    font-size: calc(13px + 2pt);
    font-weight: 800;
  }

  .main-home
    .home-pe-row
    .section-block--pe-half
    .article-grid--home.article-grid--economy
    .card-excerpt {
    font-size: 13px;
    font-weight: 500;
    color: var(--ink-soft);
  }

  .main-home .home-society-rail-grid .card-deck {
    font-size: calc(13.5px + 2pt);
    font-weight: 800;
  }

  .main-home .home-society-rail-grid .card-excerpt {
    font-size: 13.5px;
    font-weight: 500;
    color: var(--ink-soft);
  }
}

.main-home
  .opinion-block
  .article-grid.article-grid--home.opinion-grid
  .card-deck {
  font-size: calc(12px + 2pt);
  font-weight: 800;
}

/* 홈 오피니언(설정 슬러그) 카드: 640px+ 에서 일반 홈 가로썸네일 규칙보다 우선 — 이미지 위·텍스트 아래 */
@media (min-width: 640px) {
  .main-home .opinion-block .article-grid.article-grid--home.opinion-grid .article-card,
  .main-home .opinion-block .article-grid.article-grid--home.opinion-grid .article-card:has(.card-thumb),
  .main-home .opinion-block .article-grid.article-grid--home.opinion-grid .article-card--lead,
  .main-home
    .opinion-block
    .article-grid.article-grid--home.opinion-grid
    .article-card--lead:has(.card-thumb) {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .main-home .opinion-block .article-grid.article-grid--home.opinion-grid
    .article-card:has(.card-thumb)
    .card-thumb {
    display: block;
    width: 100%;
    height: auto;
    min-height: 0;
  }

  .main-home .opinion-block .article-grid.article-grid--home.opinion-grid
    .article-card:has(.card-thumb)
    .card-thumb
    img {
    width: 100%;
    height: auto;
    min-height: 132px;
    aspect-ratio: 4 / 3;
    object-fit: cover;
  }
}

.opinion-block {
  padding: 28px 24px 32px;
  background: linear-gradient(180deg, rgba(240, 243, 247, 0.85) 0%, var(--surface) 42%);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}

.opinion-block .section-block-head {
  border-bottom-color: var(--border-strong);
}

.opinion-block .section-block-head h2 {
  border-left-color: var(--accent-warm);
}

/* 홈 사회: 오피니언 블록과 비슷한 박스 톤, 바깥 여백·반경은 더 크게 */
.main-home .section-block--home-society {
  padding: 36px 30px 40px;
  background: linear-gradient(
    180deg,
    rgba(240, 243, 247, 0.95) 0%,
    var(--surface) 50%
  );
  border: 1px solid var(--border-strong);
  border-radius: 0;
  box-shadow: var(--shadow-md);
}

.main-home .section-block--home-society .section-block-head {
  border-bottom-color: var(--border-strong);
}

.ad-slot {
  margin: 6px 0 22px;
  padding: 18px 20px;
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}

.ad-slot--empty .ad-placeholder {
  margin-top: 4px;
  padding: 20px 16px;
  min-height: 90px;
  border: 1px dashed var(--border-strong);
  border-radius: 8px;
  background: var(--surface-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.ad-slot--empty .ad-placeholder p {
  margin: 0;
  max-width: 42rem;
}

.ad-slot:not(.ad-slot--empty) .ad-placeholder {
  min-height: 0;
}

/* 메인 히어로 아래 배너(관리자: 히어로 아래 광고 설정) */
.main-home .home-band--masthead-ad .home-masthead-ad-inner {
  display: flex;
  justify-content: center;
  margin: 0;
  max-width: 100%;
  min-width: 0;
}

.main-home .home-masthead-ad-link {
  display: inline-block;
  max-width: 100%;
}

.main-home .home-masthead-ad-img {
  display: block;
  margin-inline: auto;
  max-width: 100%;
  height: auto;
}

.article-page .article-page-ad-band,
.article-page .article-page-ad-inner {
  max-width: 100%;
  min-width: 0;
}

.article-page .article-page-ad-band {
  margin: 28px 0 0;
  padding: 0;
  width: 100%;
}

.article-page .article-page-ad-inner {
  display: flex;
  justify-content: flex-start;
  width: 100%;
}

.article-page .article-page-ad-link {
  display: inline-block;
  max-width: 100%;
}

.article-page .article-page-ad-img {
  display: block;
  margin-inline: 0;
  max-width: 100%;
  height: auto;
}

.home-masthead-ad-preview-shell {
  min-height: 40px;
}

.ad-label {
  display: inline-block;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: 10px;
}

.ad-placeholder {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.5;
}

@media (max-width: 767px) {
  .ad-slot {
    padding: 16px 12px;
    margin: 4px 0 16px;
    margin-inline: 0;
  }

  .ad-slot--empty .ad-placeholder {
    padding: 16px 12px;
  }

  .opinion-block {
    padding: 22px 12px 26px;
  }

  .main-home .section-block--home-society {
    padding: 28px 14px 32px;
  }
}

@media (max-width: 639px) {
  .opinion-block {
    padding: 20px 12px 22px;
  }

  .main-home .section-block--home-society {
    padding: 26px 12px 28px;
  }
}

.site-footer {
  margin-top: 56px;
  padding: 36px 0 28px;
  background: var(--ink);
  color: rgba(255, 255, 255, 0.82);
  border-top: 4px solid var(--brand);
}

.footer-links-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 18px;
  margin-bottom: 18px;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
  margin-bottom: 0;
}

.footer-brand {
  margin: 14px 0 6px;
}

.footer-brand-row {
  margin: 14px 0 6px;
}

.footer-brand-row .footer-brand {
  margin: 0;
}

.footer-brand-link {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.95);
}

.footer-brand-link:hover {
  color: #fff;
}

.footer-brand-logo-img {
  display: block;
  max-height: clamp(44px, 10vw, 56px);
  width: auto;
  height: auto;
}

.footer-brand-text {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.08rem, 2.2vw, 1.32rem);
  letter-spacing: -0.02em;
}

.site-footer.site-footer--light-bg .footer-brand-link {
  color: var(--ink);
}

.site-footer.site-footer--light-bg .footer-brand-link:hover {
  color: var(--brand);
}

.footer-links a {
  color: rgba(255, 255, 255, 0.78);
  text-decoration: none;
  font-size: 14px;
}

.footer-links a:hover {
  color: #fff;
  text-decoration: underline;
}

.site-footer.site-footer--light-bg {
  color: var(--ink);
  border-top-color: var(--brand);
}

.site-footer.site-footer--light-bg .footer-links a {
  color: var(--brand);
}

.site-footer.site-footer--light-bg .footer-links a:hover {
  color: var(--brand-hover);
}

.footer-business-meta {
  margin: 14px 0 6px;
  font-size: 13px;
  line-height: 1.55;
  color: inherit;
}

.footer-business-meta-row {
  display: grid;
  grid-template-columns: minmax(92px, 8.5rem) minmax(0, 1fr);
  gap: 4px 14px;
  margin: 0 0 6px;
}

.footer-business-meta-row:last-child {
  margin-bottom: 0;
}

.footer-business-meta-row dt {
  margin: 0;
  padding: 0;
  font-weight: 700;
}

.footer-business-meta-row dd {
  margin: 0;
  padding: 0;
  color: inherit;
}

.footer-business-meta-row dd a {
  color: inherit;
  text-decoration: underline;
  font-weight: 500;
}

.site-footer.site-footer--light-bg .footer-business-meta-row dd a {
  color: var(--brand);
}

.footer-daily-visitors {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.06);
  font-size: 13px;
  line-height: 1.3;
  color: rgba(255, 255, 255, 0.82);
  vertical-align: middle;
}

.footer-daily-visitors-label {
  font-weight: 600;
  letter-spacing: 0.02em;
}

.footer-daily-visitors-count {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #fff;
}

.site-footer.site-footer--light-bg .footer-daily-visitors {
  border-color: rgba(20, 54, 93, 0.18);
  background: rgba(20, 54, 93, 0.06);
  color: var(--ink-soft);
}

.site-footer.site-footer--light-bg .footer-daily-visitors-count {
  color: var(--brand);
}

.copyright {
  margin: 14px 0 0;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.55);
}

.site-footer.site-footer--light-bg .copyright {
  color: rgba(26, 35, 50, 0.62);
}

.footer-inner {
  display: grid;
  gap: 28px;
}

.footer-inner--with-partners {
  gap: 28px 32px;
}

@media (min-width: 768px) {
  .footer-inner--with-partners {
    grid-template-columns: minmax(0, 1fr) minmax(200px, 260px);
    align-items: start;
  }
}

.footer-partner-links {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.footer-partner-link {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px 10px;
  padding: 10px 0 10px 14px;
  border-left: 3px solid var(--brand);
  text-decoration: none;
  color: inherit;
  transition: color 0.15s ease;
}

.footer-partner-link:hover {
  color: #fff;
}

.footer-partner-link__label {
  grid-column: 1;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--brand);
}

.footer-partner-link__title {
  grid-column: 1;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.35;
}

.footer-partner-link__desc {
  grid-column: 1;
  font-size: 12px;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.65);
}

.footer-partner-link__go {
  grid-column: 2;
  grid-row: 1 / -1;
  align-self: center;
  font-size: 14px;
  opacity: 0.75;
}

.site-footer.site-footer--light-bg .footer-partner-link:hover {
  color: var(--brand-hover);
}

.site-footer.site-footer--light-bg .footer-partner-link__desc {
  color: rgba(26, 35, 50, 0.62);
}

.footer-daily-visitors-label-short {
  display: none;
}

.footer-business-details__summary {
  display: none;
  list-style: none;
  cursor: pointer;
  font-size: 13px;
  font-weight: 700;
  color: inherit;
  margin: 0;
  padding: 0;
}

.footer-business-details__summary::-webkit-details-marker {
  display: none;
}

.footer-business-details__summary::after {
  content: " ▾";
  font-size: 11px;
  opacity: 0.72;
}

.footer-business-details[open] .footer-business-details__summary::after {
  content: " ▴";
}

@media (max-width: 767px) {
  .footer-business-details[open]:not(.footer-business-details--mobile-synced)
    > .footer-business-meta {
    display: none;
  }
}

@media (max-width: 767px) and (scripting: none) {
  .footer-business-details[open] > .footer-business-meta {
    display: block;
  }

  .footer-business-details__summary {
    display: none;
  }
}

@media (max-width: 767px) {
  .site-footer {
    margin-top: 32px;
    padding: 22px 0 18px;
  }

  body:has(main.main-home--bands) .site-footer {
    margin-top: 20px;
  }

  .footer-inner,
  .footer-inner--with-partners {
    gap: 14px;
  }

  .footer-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "links links"
      "brand counter"
      "business business"
      "copy copy";
    gap: 14px;
  }

  .footer-links-row {
    display: contents;
  }

  .footer-links {
    grid-area: links;
    order: unset;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px 6px;
    margin-bottom: 0;
  }

  .footer-links a {
    font-size: 12px;
    line-height: 1.35;
    text-align: center;
  }

  .footer-daily-visitors {
    grid-area: counter;
    align-self: center;
    justify-self: end;
    padding: 3px 8px;
    font-size: 12px;
    gap: 6px;
  }

  .footer-brand-row {
    grid-area: brand;
    order: unset;
    margin: 0;
  }

  .footer-brand {
    order: unset;
    margin: 0;
  }

  .footer-brand-logo-img {
    max-height: 36px;
  }

  .footer-brand-text {
    font-size: 1rem;
  }

  .footer-business-details {
    grid-area: business;
    order: unset;
  }

  .footer-business-details__summary {
    display: block;
    padding: 8px 0 6px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  .site-footer.site-footer--light-bg .footer-business-details__summary {
    border-top-color: rgba(20, 54, 93, 0.12);
  }

  .footer-business-meta {
    margin: 0 0 2px;
    padding-top: 4px;
    font-size: 12px;
    line-height: 1.45;
  }

  .footer-business-meta-row {
    gap: 0;
    margin-bottom: 4px;
  }

  .footer-business-meta-row:not(.footer-business-meta-row--stack) {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0 4px;
  }

  .footer-business-meta-row:not(.footer-business-meta-row--stack) dt {
    display: inline;
    flex-shrink: 0;
    font-weight: 600;
    font-size: 11px;
    opacity: 0.88;
  }

  .footer-business-meta-row:not(.footer-business-meta-row--stack) dt::after {
    content: ':';
  }

  .footer-business-meta-row:not(.footer-business-meta-row--stack) dd {
    display: inline;
    min-width: 0;
  }

  .footer-business-meta-row--stack {
    display: block;
  }

  .footer-business-meta-row--stack dt {
    display: block;
    font-weight: 600;
    font-size: 11px;
    margin-bottom: 2px;
    opacity: 0.88;
  }

  .footer-business-meta-row--stack dd {
    display: block;
  }

  .footer-business-meta-row--mobile-hide {
    display: none;
  }

  .footer-partner-links {
    order: 4;
    flex-flow: row wrap;
    gap: 8px;
    padding-top: 2px;
  }

  .footer-partner-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    grid-template-columns: none;
    grid-template-rows: none;
    padding: 5px 10px;
    border-left: none;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    font-size: 12px;
    line-height: 1.25;
  }

  .site-footer.site-footer--light-bg .footer-partner-link {
    border-color: rgba(20, 54, 93, 0.16);
  }

  .footer-partner-link__label,
  .footer-partner-link__desc {
    display: none;
  }

  .footer-partner-link__title {
    font-size: 12px;
    font-weight: 600;
  }

  .footer-partner-link__go {
    grid-column: auto;
    grid-row: auto;
    align-self: auto;
    font-size: 11px;
    opacity: 0.65;
  }

  .copyright {
    grid-area: copy;
    order: unset;
    margin: 0;
    font-size: 11px;
    line-height: 1.45;
  }

  .copyright-extra {
    display: none;
  }

  .footer-daily-visitors-label-full {
    display: none;
  }

  .footer-daily-visitors-label-short {
    display: inline;
  }
}

@media (min-width: 768px) {
  .footer-business-details__summary {
    display: none;
  }
}

.breadcrumb {
  font-size: 14px;
  color: var(--muted);
  margin: 18px 0;
}

.breadcrumb a {
  color: var(--brand-muted);
  text-decoration: none;
}

.breadcrumb a:hover {
  color: var(--brand-hover);
}

.section-landing {
  padding: 12px 0 56px;
}

.section-landing-breadcrumb {
  margin: 0 0 18px;
}

.breadcrumb-sep {
  margin: 0 0.35em;
  opacity: 0.45;
}

.breadcrumb-current {
  font-weight: 600;
  color: var(--ink-soft);
}

.section-masthead {
  position: relative;
  overflow: hidden;
  margin: 0 0 28px;
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 4px);
  box-shadow: var(--shadow-sm);
  background: var(--surface);
}

.section-masthead-accent {
  display: block;
  height: 5px;
  background: var(--brand);
}

.section-masthead-body {
  padding: 22px 22px 24px;
}

.section-masthead-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 3.2vw, 2.05rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.22;
}

.section-masthead-meta {
  margin: 12px 0 0;
  font-size: 14px;
  color: var(--muted);
  font-weight: 500;
  line-height: 1.5;
}

.section-masthead-meta strong {
  color: var(--brand);
  font-weight: 700;
}

.section-masthead-intro {
  margin: 18px 0 0;
  max-width: 52rem;
  font-size: calc(15px + 2pt);
  line-height: 1.7;
  color: var(--ink);
  font-weight: 600;
  white-space: pre-wrap;
}

.section-masthead-inner {
  display: flex;
  flex-direction: column;
}

.section-masthead-inner--with-view {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px 18px;
}

.section-masthead-main {
  flex: 1 1 12rem;
  min-width: 0;
  padding: 22px 0 24px 22px;
}

.section-view-switcher {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  gap: 6px;
  padding: 16px 18px 0 0;
}

.section-view-switcher__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: var(--surface-subtle);
  color: var(--brand-muted);
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    background 0.15s ease,
    color 0.15s ease,
    box-shadow 0.15s ease;
}

.section-view-switcher__btn:hover {
  border-color: var(--brand-muted);
  color: var(--brand);
  background: var(--surface);
}

.section-view-switcher__btn.is-active {
  border-color: var(--brand);
  background: var(--brand);
  color: #fff;
  box-shadow: var(--shadow-sm);
}

.section-view-switcher__btn:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

.section-view-switcher__icon {
  display: block;
}

.section-list-views {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.section-list-view[hidden] {
  display: none !important;
}

.section-masthead--has-visual .section-masthead-inner {
  display: grid;
  grid-template-columns: 1fr;
}

.section-masthead-thumb {
  display: block;
  flex-shrink: 0;
  line-height: 0;
  text-decoration: none;
  color: inherit;
  background: var(--surface-subtle);
  border-bottom: 1px solid var(--border);
}

.section-masthead-thumb:focus-visible {
  outline: 3px solid var(--brand);
  outline-offset: 2px;
}

.section-masthead-thumb img {
  width: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 16 / 10;
  min-height: 120px;
}

@media (min-width: 640px) {
  .section-masthead--has-visual .section-masthead-inner {
    grid-template-columns: 148px 1fr;
    align-items: stretch;
  }

  .section-masthead--has-visual .section-masthead-thumb {
    border-bottom: none;
    border-right: 1px solid var(--border);
    align-self: stretch;
    height: auto;
    min-height: 0;
  }

  .section-masthead--has-visual .section-masthead-thumb img {
    width: 100%;
    height: 100%;
    min-height: 120px;
    aspect-ratio: unset;
    object-fit: cover;
  }
}

@media (max-width: 639px) {
  .section-masthead-inner--with-view {
    flex-direction: column;
  }

  .section-masthead-main {
    padding: 18px 18px 0;
  }

  .section-view-switcher {
    align-self: flex-end;
    padding: 0 18px 16px;
  }
}

.section-list-panel {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  padding: 16px 16px 20px;
}

.section-list-panel--empty {
  padding: 36px 24px;
  text-align: center;
}

.section-empty {
  margin: 0;
  font-size: 15px;
  color: var(--muted);
  line-height: 1.6;
}

.article-list--section {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.article-list--section .article-card {
  margin-bottom: 0;
}

/* 섹션 랜딩: 4열×5행(20건) 그리드, 썸네일 위 · 텍스트 아래 */
.article-list--section.article-list--section-4x5 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 640px) {
  .article-list--section.article-list--section-4x5 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 960px) {
  .article-list--section.article-list--section-4x5 {
    grid-template-columns: repeat(4, 1fr);
  }
}

.article-list--section.article-list--section-4x5 .article-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  transform: none;
}

.article-list--section.article-list--section-4x5 .article-card:hover {
  transform: none;
}

.article-list--section.article-list--section-4x5 .card-thumb {
  display: block;
  width: 100%;
  flex-shrink: 0;
  line-height: 0;
}

.article-list--section.article-list--section-4x5 .card-thumb img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 16 / 10;
  min-height: 112px;
}

.article-list--section.article-list--section-4x5 .card-body {
  flex: 1 1 auto;
  min-width: 0;
  padding: 12px 14px 14px;
  display: flex;
  flex-direction: column;
}

.article-list--section.article-list--section-4x5 .card-meta {
  font-size: 12px;
  margin: 0 0 6px;
}

.article-list--section.article-list--section-4x5 .card-title {
  font-size: 1.08rem;
  line-height: 1.35;
  font-weight: 800;
  margin: 0 0 8px;
}

.article-list--section.article-list--section-4x5 .card-deck {
  font-size: calc(13px + 1pt);
  margin: 0 0 0;
  line-height: 1.45;
  color: var(--ink-soft);
  font-weight: 400;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.article-list--section.article-list--section-4x5 .card-excerpt {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* 섹션 서브: 3종 보기 — 뉴스 4열·갤러리 2열(PC)×20건 */
.article-list--section.article-list--section-3col {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

/* 모바일: 섹션 뉴스형 보기 = 2열 (리스트·갤러리는 1열) */
@media (max-width: 639px) {
  .article-list--section.article-list--section-3col.article-list--section-news {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .article-list--section-news .card-body {
    padding: 10px 10px 12px;
  }

  .article-list--section-news .card-thumb img {
    min-height: 88px;
  }

  .article-list--section-news .card-title {
    font-size: 0.92rem;
    line-height: 1.32;
  }
}

@media (min-width: 640px) {
  .article-list--section.article-list--section-3col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 960px) {
  .article-list--section.article-list--section-3col {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
  }

  .article-list--section.article-list--section-3col.article-list--section-news {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .article-list--section.article-list--section-3col.article-list--section-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.article-list--section.article-list--section-3col .article-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  transform: none;
}

.article-list--section.article-list--section-3col .article-card:hover {
  transform: none;
}

.article-list--section.article-list--section-3col .card-thumb {
  display: block;
  width: 100%;
  flex-shrink: 0;
  line-height: 0;
}

.article-list--section.article-list--section-3col .card-thumb img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.article-list--section.article-list--section-3col .card-body {
  flex: 1 1 auto;
  min-width: 0;
  padding: 12px 14px 14px;
}

.article-list--section.article-list--section-3col .card-title {
  font-family: var(--font-sans);
  font-size: 1.08rem;
  line-height: 1.35;
  font-weight: 800;
  margin: 0;
}

.article-list--section-news .card-meta,
.article-list--section-news .card-deck,
.article-list--section-news .card-excerpt {
  display: none;
}

.article-list--section-news .card-thumb img {
  aspect-ratio: 16 / 10;
  min-height: 112px;
}

.article-list--section-gallery .card-meta,
.article-list--section-gallery .card-deck,
.article-list--section-gallery .card-excerpt {
  display: none;
}

.article-list--section-gallery .card-thumb img {
  aspect-ratio: 4 / 3;
  min-height: 128px;
}

.article-list--section-gallery .card-body {
  padding: 10px 12px 12px;
}

.section-title-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--border);
}

.section-title-list__item {
  border-bottom: 1px solid var(--border);
}

.section-title-list__link {
  display: flex;
  align-items: flex-start;
  gap: 0.45em;
  padding: 12px 4px;
  color: var(--ink);
  text-decoration: none;
  font-family: var(--font-sans);
  font-size: 1.08rem;
  line-height: 1.35;
  font-weight: 800;
}

.section-title-list__link::before {
  content: "";
  flex-shrink: 0;
  width: 5px;
  height: 5px;
  margin-top: 0.45em;
  border-radius: 50%;
  background: var(--brand);
}

.section-title-list__link:hover {
  color: var(--brand);
}

.section-title-list__link:hover::before {
  background: var(--brand-hover);
}

@media (min-width: 640px) {
  .article-list--section.article-list--section-4x5 .article-card,
  .article-list--section.article-list--section-4x5 .article-card:has(.card-thumb),
  .article-list--section.article-list--section-4x5 .article-card--lead,
  .article-list--section.article-list--section-4x5 .article-card--lead:has(.card-thumb) {
    display: flex;
    flex-direction: column;
    grid-template-columns: 1fr;
  }
}

.article-list--section .card-excerpt {
  margin: 10px 0 0;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.article-list--section .article-card--lead .card-title {
  font-size: 1.17rem;
  font-weight: 800;
  line-height: 1.35;
}

@media (min-width: 640px) {
  .article-list--section:not(.article-list--economy-section)
    .article-card--lead:has(.card-thumb) {
    grid-template-columns: minmax(200px, 40%) 1fr;
    align-items: stretch;
  }

  .article-list--section:not(.article-list--economy-section)
    .article-card--lead:has(.card-thumb)
    .card-thumb {
    display: block;
    height: 100%;
    min-height: 128px;
  }

  .article-list--section:not(.article-list--economy-section)
    .article-card--lead:has(.card-thumb)
    .card-thumb
    img {
    width: 100%;
    height: 100%;
    min-height: 128px;
    aspect-ratio: unset;
    object-fit: cover;
  }

  .article-list--section .article-card--lead .card-title {
    font-size: 1.28rem;
  }

  .article-list--section .article-card--lead .card-excerpt {
    -webkit-line-clamp: 5;
  }
}

/*
 * 설치 갤러리(홈 하단 슬롯·동일 슬러그 섹션 목록): 이미지 위 · 제목·내용 아래.
 * flex 열로 고정(grid 148px+텍스트 덮어쓰기 방지).
 */
.section-landing--gallery-card-stack .article-list.article-list--section .article-card,
.section-landing--gallery-card-stack
  .article-list.article-list--section
  .article-card:has(.card-thumb),
.main-home
  .section-block--home-gallery
  .article-grid.article-grid--home.opinion-grid
  .article-card,
.main-home
  .section-block--home-gallery
  .article-grid.article-grid--home.opinion-grid
  .article-card:has(.card-thumb),
.main-home
  .opinion-block--gallery-card-stack
  .article-grid.article-grid--home.opinion-grid
  .article-card,
.main-home
  .opinion-block--gallery-card-stack
  .article-grid.article-grid--home.opinion-grid
  .article-card:has(.card-thumb) {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.section-landing--gallery-card-stack
  .article-list.article-list--section
  .article-card
  .card-thumb,
.main-home
  .section-block--home-gallery
  .article-grid.article-grid--home.opinion-grid
  .article-card
  .card-thumb,
.main-home
  .opinion-block--gallery-card-stack
  .article-grid.article-grid--home.opinion-grid
  .article-card
  .card-thumb {
  display: block;
  width: 100%;
  height: auto;
  min-height: 0;
  flex-shrink: 0;
}

.section-landing--gallery-card-stack
  .article-list.article-list--section
  .article-card
  .card-thumb
  img,
.main-home
  .section-block--home-gallery
  .article-grid.article-grid--home.opinion-grid
  .article-card
  .card-thumb
  img,
.main-home
  .opinion-block--gallery-card-stack
  .article-grid.article-grid--home.opinion-grid
  .article-card
  .card-thumb
  img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  min-height: 140px;
}

.section-landing--gallery-card-stack
  .article-list.article-list--section
  .article-card
  .card-body,
.main-home
  .section-block--home-gallery
  .article-grid.article-grid--home.opinion-grid
  .article-card
  .card-body,
.main-home
  .opinion-block--gallery-card-stack
  .article-grid.article-grid--home.opinion-grid
  .article-card
  .card-body {
  flex: 1 1 auto;
  min-width: 0;
}

.article-list.article-list--section.article-list--economy-section {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(248px, 1fr));
  gap: 18px;
}

@media (min-width: 640px) {
  .article-list--economy-section .article-card,
  .article-list--economy-section .article-card:has(.card-thumb),
  .article-list--economy-section .article-card--lead,
  .article-list--economy-section .article-card--lead:has(.card-thumb) {
    grid-template-columns: 1fr;
  }

  .article-list--economy-section .article-card:has(.card-thumb) .card-thumb {
    height: auto;
    min-height: 0;
  }

  .article-list--economy-section .article-card:has(.card-thumb) .card-thumb img {
    width: 100%;
    height: auto;
    min-height: 140px;
    aspect-ratio: 16 / 10;
    object-fit: cover;
  }
}

.pagination {
  display: flex;
  gap: 14px;
  align-items: center;
  margin: 28px 0;
}

.pagination a {
  font-weight: 600;
}

.pagination--section {
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin: 32px 0 8px;
}

.pagination--section-numbered {
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.section-pagination-meta {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink-soft);
}

.section-pagination-meta strong {
  color: var(--brand);
  font-weight: 800;
}

.section-pagination-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px 12px;
}

.pagination-page-nums {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 6px;
  max-width: 100%;
}

.pagination-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  min-height: 40px;
  padding: 0 8px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  color: var(--brand);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  box-shadow: var(--shadow-sm);
  box-sizing: border-box;
}

a.pagination-num:hover {
  color: #fff;
  background: var(--brand);
  border-color: var(--brand);
}

.pagination-num.is-current {
  background: rgba(34, 139, 92, 0.14);
  border-color: var(--brand);
  color: var(--brand);
  font-weight: 800;
}

.pagination-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  padding: 10px 18px;
  font-size: 14px;
  font-weight: 700;
  color: var(--brand);
  text-decoration: none;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  box-shadow: var(--shadow-sm);
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease,
    box-shadow 0.15s ease;
}

.pagination-btn:hover {
  color: #fff;
  background: var(--brand);
  border-color: var(--brand);
  box-shadow: var(--shadow-md);
}

.pagination-btn--disabled {
  opacity: 0.38;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
}

.pagination-status {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  padding: 8px 16px;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink-soft);
  background: var(--surface-subtle);
  border: 1px solid var(--border);
  border-radius: 999px;
}

.pagination-current {
  font-size: 1.1em;
  color: var(--brand);
}

.pagination-slash {
  opacity: 0.5;
  font-weight: 500;
}

.article-page .article-head h1 {
  margin: 0 0 10px;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 3vw, 2.15rem);
  font-weight: 700;
  line-height: 1.3;
  color: var(--ink);
}

.subtitle {
  margin: 0 0 14px;
  color: var(--muted);
  font-size: calc(1.05rem + 1pt);
  font-weight: 500;
}

.byline {
  margin: 0 0 20px;
  font-size: 14px;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}

.article-share {
  margin: 0 0 22px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}

.article-share-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.article-share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none;
  color: #fff;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition:
    filter 0.15s ease,
    box-shadow 0.15s ease,
    transform 0.1s ease;
}

.article-share-btn:hover {
  filter: brightness(1.06);
  box-shadow: var(--shadow-md);
}

.article-share-btn:active {
  transform: translateY(1px);
}

.article-share-btn__glyph {
  display: block;
  flex-shrink: 0;
  width: auto;
}

.article-share-btn--kakao.article-share-btn {
  gap: 8px;
  justify-content: flex-start;
  padding: 8px 12px;
  background: #fee500;
  color: #191919;
  flex-wrap: wrap;
}

.article-share-btn__label {
  letter-spacing: -0.02em;
}

.article-share-btn--kakao .article-share-btn__glyph {
  height: 19px;
  flex-shrink: 0;
  width: auto;
}

.article-share-btn--facebook {
  background: #1877f2;
}

.article-share-btn--copy {
  background: var(--surface);
  color: var(--ink);
  border: 1px solid var(--border-strong);
  box-shadow: none;
}

.article-share-btn--copy:hover {
  border-color: var(--brand);
  color: var(--brand);
}

.article-hero {
  margin: 0 0 24px;
}

.article-hero img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius);
}

.article-hero figcaption {
  font-size: 13px;
  color: var(--muted);
  margin-top: 10px;
  text-align: center;
}

.article-body {
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.75;
  font-weight: 400;
  text-rendering: optimizeLegibility;
  color: var(--ink);
}

.article-body :first-child {
  margin-top: 0;
}

.article-body :last-child {
  margin-bottom: 0;
}

.article-body p {
  margin: 0 0 1em;
}

.article-body h2,
.article-body h3,
.article-body h4 {
  margin: 1.35em 0 0.55em;
  line-height: 1.35;
  font-weight: 800;
}

.article-body ul,
.article-body ol {
  margin: 0 0 1em;
  padding-left: 1.35em;
}

.article-body blockquote {
  margin: 1em 0;
  padding: 12px 18px;
  border-left: 4px solid var(--brand-muted);
  background: var(--surface-subtle);
}

.article-body img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 1em 0;
  border-radius: 8px;
}

/* 본문 외부 동영상(YouTube·Vimeo embed) */
.article-body .article-embed {
  position: relative;
  width: 100%;
  max-width: 100%;
  margin: 1.25em 0;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 8px;
  background: #111;
}

.article-body .article-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* 에디터(text-align)와 저장된 margin:auto — 블록 img는 부모만으로는 가운데 정렬 안 됨 */
.article-body
  :is(p, div, figure, tr, th, td)[style*="text-align: center"]
  img,
.article-body :is(p, div, figure, tr, th, td)[style*="text-align:center"] img,
.article-body :is(p, div, figure, tr, th, td)[style*="align: center"] img,
.article-body :is(p, div, figure, tr, th, td)[style*="align:center"] img {
  margin-left: auto;
  margin-right: auto;
}

.article-body
  :is(p, div, figure, tr, th, td)[style*="text-align: right"]
  img,
.article-body :is(p, div, figure, tr, th, td)[style*="text-align:right"] img,
.article-body :is(p, div, figure, tr, th, td)[style*="align: right"] img,
.article-body :is(p, div, figure, tr, th, td)[style*="align:right"] img {
  margin-left: auto;
  margin-right: 0;
}

.article-body
  :is(p, div, figure, tr, th, td)[style*="text-align: left"]
  img,
.article-body :is(p, div, figure, tr, th, td)[style*="text-align:left"] img,
.article-body :is(p, div, figure, tr, th, td)[style*="align: left"] img,
.article-body :is(p, div, figure, tr, th, td)[style*="align:left"] img {
  margin-left: 0;
  margin-right: auto;
}

/* TinyMCE figure.image — align-* 클래스(캡션 그림 등) */
.article-body figure.align-center {
  text-align: center;
}

.article-body figure.align-center img {
  margin-left: auto;
  margin-right: auto;
}

.article-body figure.align-left {
  float: left;
  margin: 0 1em 1em 0;
}

.article-body figure.align-right {
  float: right;
  margin: 0 0 1em 1em;
}

.article-body img.align-center {
  margin-left: auto;
  margin-right: auto;
}

.article-body img.align-left {
  float: left;
  margin: 0 1em 1em 0;
}

.article-body img.align-right {
  float: right;
  margin: 0 0 1em 1em;
}

.article-body::after {
  content: "";
  display: table;
  clear: both;
}

.article-body figure {
  margin: 1.25em 0;
}

.article-body figcaption {
  font-size: 13px;
  color: var(--muted);
  margin-top: 8px;
  text-align: center;
}

.article-body figcaption:empty {
  display: none;
}

.article-body .article-image-duo {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: clamp(12px, 2vw, 18px);
  margin: 1.25em 0;
}

.article-body .article-image-duo figure {
  margin: 0;
}

.article-body .article-image-duo img {
  margin: 0;
  width: 100%;
}

.article-body .article-image-duo figcaption:empty {
  display: none;
}

.article-body .article-image-duo figure.article-image-duo-pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(12px, 2vw, 18px);
  margin: 0;
}

.article-body .article-image-duo figure.article-image-duo-pair figcaption {
  grid-column: 1 / -1;
  text-align: center;
}

@media (max-width: 767px) {
  .article-body .article-image-duo figure.article-image-duo-pair {
    grid-template-columns: 1fr;
  }
}

.article-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 1em 0;
  font-size: 0.96rem;
}

.article-body th,
.article-body td {
  border: 1px solid var(--border);
  padding: 8px 10px;
  text-align: left;
}

.article-body pre {
  overflow-x: auto;
  padding: 14px;
  background: var(--surface-subtle);
  border-radius: 8px;
  font-size: 0.9rem;
}

@media (max-width: 767px) {
  .article-body-shell {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
  }

  .article-body {
    font-size: 20px;
    line-height: 1.78;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }

  .article-body table {
    width: max-content;
    min-width: 100%;
  }
}

.correction-box {
  border: 1px solid #e8d4c4;
  background: linear-gradient(180deg, #fdf8f4 0%, #faf5ef 100%);
  padding: 16px 18px;
  margin-bottom: 20px;
  border-radius: var(--radius);
  border-left: 4px solid var(--accent-warm);
}

.correction-title {
  margin: 0 0 10px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
}

.correction-box ul {
  margin: 0;
  padding-left: 18px;
  color: var(--ink-soft);
}

.article-sources,
.related {
  margin-top: 32px;
  max-width: 42rem;
}

.article-sources h2,
.related h2 {
  font-size: 1.1rem;
  font-weight: 700;
  border-bottom: 2px solid var(--brand);
  padding-bottom: 8px;
  margin-bottom: 12px;
}

.related ul {
  padding-left: 18px;
}

.related a {
  font-weight: 500;
}

.article-list .article-card {
  margin-bottom: 4px;
}

.static-page {
  padding: 28px 0 56px;
}

.site-renewal-body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(
      circle at 20% 12%,
      rgba(20, 54, 93, 0.08),
      transparent 42%
    ),
    var(--admin-canvas, #f4f6f8);
  color: var(--ink, #1a1a1a);
  font-family: var(--font-body, system-ui, sans-serif);
}

.site-renewal-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 32px 20px;
  box-sizing: border-box;
}

.site-renewal-card {
  width: min(100%, 520px);
  padding: 36px 28px;
  border: 1px solid var(--border, #d8dee6);
  border-radius: calc(var(--radius, 8px) + 4px);
  background: var(--surface, #fff);
  box-shadow: var(--shadow-sm, 0 2px 8px rgba(0, 0, 0, 0.06));
  text-align: center;
}

.site-renewal-brand {
  margin: 0 0 18px;
}

.site-renewal-logo {
  display: inline-block;
  max-width: min(100%, 220px);
  max-height: 72px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.site-renewal-brand-text {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--brand, #14365d);
}

.site-renewal-title {
  margin: 0 0 12px;
  font-family: var(--font-display, Georgia, serif);
  font-size: clamp(1.35rem, 4vw, 1.75rem);
  font-weight: 800;
  line-height: 1.35;
  color: var(--brand, #14365d);
}

.site-renewal-lead {
  margin: 0;
  font-size: 15px;
  line-height: 1.65;
  color: var(--muted, #5c6670);
}

.admin-settings-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--ink-soft);
}

.admin-settings-check input {
  width: 16px;
  height: 16px;
  margin: 0;
}

.admin-daily-uv-min-input {
  width: 6.5rem;
  max-width: 100%;
  margin-right: 8px;
}

.admin-settings-renewal-on {
  color: #b45309;
}

.static-page h1 {
  margin-top: 0;
  font-family: var(--font-display);
  color: var(--brand);
}

.contact-form label {
  display: block;
  margin-top: 14px;
  font-weight: 600;
  color: var(--ink-soft);
}

.contact-form input,
.contact-form textarea {
  width: min(520px, 100%);
  margin-top: 8px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-family: inherit;
}

.contact-form button {
  margin-top: 18px;
  padding: 12px 22px;
  background: var(--brand);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
}

.contact-form button:hover {
  background: var(--brand-hover);
}

.contact-form-section {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}

.contact-form-heading {
  margin: 0 0 14px;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--ink);
}

.contact-form-notice {
  margin: 0 0 16px;
  padding: 12px 14px;
  border-radius: 8px;
  font-weight: 600;
  line-height: 1.5;
}

.contact-form-notice--success {
  color: #0d5c36;
  background: rgba(34, 139, 92, 0.12);
  border: 1px solid rgba(34, 139, 92, 0.25);
}

.contact-form-notice--error {
  color: #b00020;
  background: rgba(176, 0, 32, 0.08);
  border: 1px solid rgba(176, 0, 32, 0.2);
}

.contact-form-hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

.contact-form-captcha-prompt {
  display: inline-block;
  margin-left: 4px;
  padding: 2px 8px;
  font-family: ui-monospace, monospace;
  letter-spacing: 0.04em;
  color: var(--brand);
  background: rgba(0, 0, 0, 0.04);
  border-radius: 6px;
}

.contact-form-captcha-hint {
  margin: 6px 0 0;
  font-size: 0.875rem;
  color: var(--ink-soft);
}

.static-page-body {
  margin-top: 12px;
}

@media (max-width: 767px) {
  body.site-nav-drawer-active {
    overflow: hidden;
    touch-action: none;
  }

  .site-nav-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 480;
    background: rgba(26, 35, 50, 0.28);
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transition:
      opacity 0.2s ease,
      visibility 0.2s ease;
  }

  .site-nav-backdrop.is-visible {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }

  .main-home {
    padding: 8px 0 44px;
  }

  .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    border-color: var(--border);
    background: var(--surface);
    box-shadow: none;
  }

  .header-inner {
    flex-wrap: wrap;
    align-items: center;
    gap: 4px 20px;
    padding: 16px 0 8px;
    position: relative;
    z-index: 520;
  }

  .site-nav {
    flex: 1 1 100%;
    align-self: stretch;
    max-width: none;
    width: 100%;
    order: 3;
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    visibility: hidden;
    transform: none;
    pointer-events: none;
    transition:
      max-height 0.28s ease,
      opacity 0.2s ease,
      visibility 0.2s ease;
    margin-top: 4px;
    padding: 0;
    background: var(--surface);
    border: 1px solid var(--border);
    border-top: 2px solid var(--brand);
    border-radius: 0 0 var(--radius) var(--radius);
    box-shadow: var(--shadow-sm);
  }

  .site-nav.is-open {
    max-height: min(640px, 85vh);
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .site-nav ul {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 4px 0 10px;
    margin: 0;
    border: none;
  }

  .site-nav li {
    border-bottom: 1px solid rgba(223, 227, 234, 0.85);
  }

  .site-nav li:last-child {
    border-bottom: none;
  }

  .site-nav a {
    display: block;
    padding: 14px 20px;
    min-height: 48px;
    border-left: 3px solid transparent;
    border-radius: 0;
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1.45;
    letter-spacing: -0.01em;
    color: var(--ink);
    transition:
      background 0.15s ease,
      color 0.15s ease,
      border-color 0.15s ease;
  }

  .site-nav a::before {
    content: none;
  }

  .site-nav a:hover {
    background: var(--surface-subtle);
    color: var(--brand);
    border-left-color: rgba(20, 54, 93, 0.35);
  }

  .site-nav a:active {
    background: var(--surface-subtle);
  }

  .site-nav a[aria-current='page'] {
    font-weight: 700;
    color: var(--brand);
    background: rgba(20, 54, 93, 0.05);
    border-left-color: var(--brand);
  }
}

.admin-body {
  background: var(--surface-subtle);
}

.admin-body--app {
  margin: 0;
  min-height: 100vh;
  --admin-content-max: 1280px;
}

.admin-app {
  display: flex;
  min-height: 100vh;
  align-items: stretch;
}

.admin-sidebar {
  width: 252px;
  flex-shrink: 0;
  background: linear-gradient(180deg, #122945 0%, #1a3354 52%, #163556 100%);
  color: rgba(255, 255, 255, 0.92);
  display: flex;
  flex-direction: column;
  padding: 26px 0 18px;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.admin-sidebar-brand {
  padding: 0 22px 22px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  margin-bottom: 14px;
}

.admin-sidebar-logo {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
  letter-spacing: -0.02em;
}

.admin-sidebar-logo:hover {
  color: rgba(255, 255, 255, 0.9);
}

.admin-sidebar-site {
  display: block;
  margin-top: 8px;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.52);
  line-height: 1.4;
}

.admin-sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 0 14px;
  flex: 1;
}

.admin-sidebar-link {
  display: block;
  padding: 11px 14px;
  border-radius: 8px;
  color: rgba(255, 255, 255, 0.88);
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  transition:
    background 0.15s ease,
    color 0.15s ease;
}

.admin-sidebar-link:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.admin-sidebar-link.is-active {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  border-left: 3px solid var(--accent-warm);
  padding-left: 11px;
}

.admin-sidebar-footer {
  padding: 16px 22px 0;
  margin-top: auto;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.admin-sidebar-secondary {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
}

.admin-sidebar-nav .admin-sidebar-secondary {
  display: block;
  padding: 11px 14px;
  border-radius: 8px;
  transition:
    background 0.15s ease,
    color 0.15s ease;
}

.admin-sidebar-nav .admin-sidebar-secondary:hover {
  background: rgba(255, 255, 255, 0.08);
}

.admin-sidebar-secondary:hover {
  color: #fff;
}

.admin-sidebar-logout {
  font-size: 13px;
  font-weight: 700;
  color: rgba(255, 210, 190, 0.98);
  text-decoration: none;
}

.admin-sidebar-logout:hover {
  color: #fff;
}

.admin-sidebar-group {
  margin-top: 4px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  width: 100%;
}

.admin-sidebar-group:not([open]) > .admin-sidebar-toggle {
  border-radius: 8px;
}

.admin-sidebar-group[open] > .admin-sidebar-toggle {
  border-radius: 8px 8px 0 0;
}

.admin-sidebar-group.has-active-submenu > .admin-sidebar-toggle {
  color: rgba(255, 255, 255, 0.96);
}

.admin-sidebar-group.has-active-submenu > .admin-sidebar-toggle::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 3px;
  height: 1.35em;
  margin-top: -0.675em;
  border-radius: 0 2px 2px 0;
  background: rgba(251, 192, 90, 0.85);
  pointer-events: none;
}

.admin-sidebar-toggle {
  position: relative;
  box-sizing: border-box;
  display: flex;
  list-style: none;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: 100%;
  padding: 11px 14px;
  margin: 0;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: rgba(255, 255, 255, 0.88);
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
  text-align: left;
  cursor: pointer;
  transition:
    background 0.15s ease,
    color 0.15s ease;
}

.admin-sidebar-toggle:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.admin-sidebar-toggle::-webkit-details-marker {
  display: none;
}

.admin-sidebar-toggle:focus-visible {
  outline: 2px solid var(--accent-warm);
  outline-offset: 2px;
}

.admin-sidebar-toggle::after {
  content: '';
  display: inline-block;
  width: 0.45rem;
  height: 0.45rem;
  margin-left: auto;
  flex-shrink: 0;
  border-right: 2px solid rgba(255, 255, 255, 0.55);
  border-bottom: 2px solid rgba(255, 255, 255, 0.55);
  transform: rotate(-135deg);
  transition: transform 0.18s ease;
  pointer-events: none;
}

.admin-sidebar-group[open] > .admin-sidebar-toggle::after {
  transform: rotate(45deg);
}

.admin-sidebar-group .admin-sidebar-subnav {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 8px 6px 10px 14px;
  margin: 2px 0 0;
  border-radius: 0 0 10px 10px;
  background: rgba(0, 10, 24, 0.22);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.admin-sidebar-link.admin-sidebar-link--sub {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin: 0;
  padding: 8px 12px !important;
  padding-left: 12px !important;
  border: none !important;
  border-left: none !important;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.82);
  text-decoration: none;
  transition:
    background 0.15s ease,
    color 0.15s ease,
    box-shadow 0.15s ease;
}

.admin-sidebar-link.admin-sidebar-link--sub:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.admin-sidebar-link.admin-sidebar-link--sub.is-active {
  background: rgba(251, 192, 90, 0.18);
  color: #fff;
  font-weight: 700;
  box-shadow: none !important;
  outline: 1px solid rgba(251, 192, 90, 0.45);
}

.admin-sidebar-link.admin-sidebar-link--sub.is-active::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-right: 8px;
  border-radius: 50%;
  background: rgba(251, 192, 90, 0.95);
  flex-shrink: 0;
}

.admin-settings-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  margin: 0 0 22px;
  padding: 0 0 18px;
  border-bottom: 1px solid var(--border);
}

.admin-settings-subnav-link {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--ink-soft);
  text-decoration: none;
  background: var(--surface);
  border: 1px solid var(--border);
}

.admin-settings-subnav-link:hover {
  border-color: var(--brand);
  color: var(--brand);
}

.admin-settings-subnav-link.is-active {
  background: rgba(34, 139, 92, 0.12);
  border-color: var(--brand);
  color: var(--brand);
}

.admin-stats-controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
}

.admin-stats-cards {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  margin-bottom: 24px;
}

.admin-stats-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  box-shadow: var(--shadow-sm);
}

.admin-stats-card-label {
  display: block;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--muted);
}

.admin-stats-card-num {
  display: block;
  margin: 6px 0 4px;
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--ink);
}

.admin-stats-charts {
  display: flex;
  flex-wrap: wrap;
  gap: 22px;
  margin-bottom: 28px;
}

.admin-stats-chartbox {
  flex: 1;
  min-width: 260px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  box-shadow: var(--shadow-sm);
}

.admin-stats-chartbox canvas {
  width: 100% !important;
  max-height: 280px;
}

.admin-stats-chartbox--compact {
  flex: 0 1 300px;
  max-width: 420px;
}

.admin-stats-chartbox--compact canvas {
  max-height: 240px;
}

.admin-stats-chartbox--full {
  flex: 1 1 100%;
}

.admin-stats-chartbox--full canvas {
  max-height: 320px;
}

.admin-stats-h2 {
  margin: 0 0 14px;
  font-size: 1.06rem;
  font-weight: 800;
}

.admin-stats-tables {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.admin-stats-tablewrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  box-shadow: var(--shadow-sm);
}

.admin-stats-table {
  margin: 0;
  width: 100%;
}

.admin-stats-notes {
  margin-top: 28px;
}

.admin-dashboard-quick {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
}

.admin-dashboard-quick .admin-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.admin-dashboard-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  padding: 0 6px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.4;
  border-radius: 999px;
  background: #c64600;
  color: #fff;
}

.admin-dashboard-cards {
  margin-bottom: 22px;
}

.admin-dashboard-warnings {
  margin: 0 0 22px;
  padding: 14px 16px;
  border-radius: var(--radius);
  border: 1px solid rgba(198, 70, 0, 0.35);
  background: rgba(198, 70, 0, 0.06);
}

.admin-dashboard-h2 {
  margin: 0 0 10px;
  font-size: 1rem;
  font-weight: 800;
  color: var(--ink);
}

.admin-dashboard-warn-list {
  margin: 0;
  padding-left: 1.2rem;
  color: var(--ink-soft);
  line-height: 1.55;
}

.admin-dashboard-warn-list li + li {
  margin-top: 6px;
}

.admin-dashboard-chart {
  margin-bottom: 24px;
}

.admin-dashboard-chart-link {
  margin: 12px 0 0;
}

.admin-dashboard-panels {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}

.admin-dashboard-panel {
  min-width: 0;
}

.admin-dashboard-table-wrap {
  margin: 0;
  overflow-x: auto;
}

.admin-dashboard-more {
  margin: 12px 0 0;
}

.admin-dashboard-lead {
  margin-top: 8px;
}

.admin-body--dashboard .admin-dashboard-chart canvas {
  max-height: 220px;
}

@media (max-width: 767px) {
  .admin-body--dashboard .admin-dashboard-cards,
  .admin-body--stats .admin-stats-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 18px;
  }

  .admin-body--dashboard .admin-stats-card,
  .admin-body--stats .admin-stats-card {
    padding: 12px 14px;
  }

  .admin-body--dashboard .admin-stats-card-label,
  .admin-body--stats .admin-stats-card-label {
    font-size: 0.78rem;
    line-height: 1.35;
  }

  .admin-body--dashboard .admin-stats-card-num,
  .admin-body--stats .admin-stats-card-num {
    margin: 4px 0 2px;
    font-size: 1.35rem;
  }

  .admin-body--dashboard .admin-stats-card .admin-muted,
  .admin-body--stats .admin-stats-card .admin-muted {
    font-size: 0.72rem;
    line-height: 1.35;
  }
}

.admin-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  background: var(--admin-canvas);
}

.admin-main-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 22px 32px 18px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  width: 100%;
  max-width: var(--admin-content-max, 1280px);
  margin-inline: auto;
}

.admin-main-title {
  margin: 0;
  flex: 1;
  min-width: 0;
  font-size: 1.48rem;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.02em;
}

.admin-content {
  padding: 28px 32px 56px;
  flex: 1;
  width: 100%;
  max-width: var(--admin-content-max, 1280px);
  margin-inline: auto;
}

.admin-sidebar-backdrop {
  display: none;
}

.admin-mobile-nav-toggle {
  display: none;
}

/* 기사 작성: 페이지 전체는 고정 높이, 본문은 admin-content 하나만 세로 스크롤 */
.admin-body--article-write {
  overflow: hidden;
  height: 100vh;
}

.admin-body--article-write .admin-app {
  height: 100vh;
  min-height: 0;
  max-height: 100vh;
}

.admin-body--article-write .admin-main-head {
  flex-shrink: 0;
}

.admin-body--article-write .admin-main {
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
}

.admin-body--article-write .admin-content {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
  padding-bottom: 40px;
}

@media (max-width: 768px) {
  .admin-body--article-write {
    height: auto;
    min-height: 100vh;
    max-height: none;
    overflow: visible;
  }

  .admin-body--article-write .admin-app {
    height: auto;
    max-height: none;
    min-height: 100vh;
  }

  .admin-body--article-write .admin-main {
    overflow: visible;
  }

  .admin-body--article-write .admin-content {
    overflow: visible;
  }
}

.admin-panel-subtitle {
  font-size: 1.05rem;
  font-weight: 800;
  margin: 28px 0 8px;
  color: var(--ink);
}


.admin-toolbar {
  margin-bottom: 18px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.admin-pagination {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
}

.admin-pagination-meta {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink-soft);
}

.admin-pagination-meta strong {
  color: var(--ink);
  font-weight: 800;
}

.admin-pagination-pages {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.admin-pagination-step,
.admin-pagination-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  min-height: 40px;
  padding: 0 12px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  border-radius: 8px;
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--brand);
  box-sizing: border-box;
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease;
}

.admin-pagination-step {
  min-width: 64px;
}

a.admin-pagination-step:hover,
a.admin-pagination-num:hover {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
}

.admin-pagination-step--disabled {
  opacity: 0.42;
  cursor: not-allowed;
  pointer-events: none;
  color: var(--muted);
  border-color: var(--border);
  background: var(--surface-subtle);
}

.admin-pagination-num.is-current {
  background: rgba(34, 139, 92, 0.14);
  border-color: var(--brand);
  color: var(--brand);
  font-weight: 800;
}

.admin-inline-sync-form {
  display: inline-flex;
  margin: 0;
}

.admin-toolbar-like {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-top: 16px;
}

.admin-section-sort-input {
  width: 6rem;
  max-width: 100%;
}

.sections-menu-order-cell {
  white-space: nowrap;
  vertical-align: middle;
}

.sections-menu-order-display {
  display: inline-block;
  min-width: 1.4rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  text-align: center;
  color: var(--brand);
}

.sections-menu-order-actions {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  margin-left: 8px;
  vertical-align: middle;
}

.sections-menu-order-move {
  width: 28px;
  height: 24px;
  padding: 0;
  border: 1px solid var(--border-strong);
  border-radius: 6px;
  background: var(--surface);
  color: var(--ink-soft);
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
}

.sections-menu-order-move:hover {
  border-color: var(--brand);
  color: var(--brand);
}

.sections-menu-json-form .admin-section-intro-input {
  display: block;
  width: 100%;
  min-width: 12rem;
  max-width: 48rem;
  margin-top: 4px;
  padding: 8px 10px;
  font-family: inherit;
  font-size: 13px;
  line-height: 1.45;
  resize: vertical;
}

.sections-menu-intro-hint {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.35;
}

.sections-menu-scroll-hint {
  display: none;
  margin: -8px 0 16px;
  font-size: 12px;
}

.admin-body--sections-menu .admin-table-wrap {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}

.admin-body--sections-menu .admin-table {
  min-width: 760px;
}

.admin-body--sections-menu .sections-menu-edit-table {
  min-width: 920px;
}

.admin-body--sections-menu .sections-menu-edit-table th:nth-child(1),
.admin-body--sections-menu .sections-menu-edit-table td:nth-child(1) {
  width: 6.5rem;
  min-width: 6.5rem;
}

.admin-body--sections-menu .sections-menu-edit-table th:nth-child(2),
.admin-body--sections-menu .sections-menu-edit-table td:nth-child(2) {
  min-width: 7.5rem;
}

.admin-body--sections-menu .sections-menu-edit-table th:nth-child(3),
.admin-body--sections-menu .sections-menu-edit-table td:nth-child(3) {
  min-width: 8.5rem;
}

.admin-body--sections-menu .sections-menu-edit-table th:nth-child(4),
.admin-body--sections-menu .sections-menu-edit-table td:nth-child(4) {
  min-width: 14rem;
}

.admin-body--sections-menu .sections-menu-edit-table th:nth-child(5),
.admin-body--sections-menu .sections-menu-edit-table td:nth-child(5) {
  min-width: 11rem;
}

.admin-body--sections-menu .sections-menu-edit-table th:nth-child(6),
.admin-body--sections-menu .sections-menu-edit-table td:nth-child(6) {
  min-width: 5.5rem;
}

.admin-body--sections-menu .sections-menu-db-table th:nth-child(1),
.admin-body--sections-menu .sections-menu-db-table td:nth-child(1) {
  width: 6.5rem;
  min-width: 6.5rem;
}

.admin-body--sections-menu .sections-menu-db-table th:nth-child(2),
.admin-body--sections-menu .sections-menu-db-table td:nth-child(2) {
  min-width: 7.5rem;
}

.admin-body--sections-menu .sections-menu-db-table th:nth-child(3),
.admin-body--sections-menu .sections-menu-db-table td:nth-child(3) {
  min-width: 8.5rem;
}

.admin-body--sections-menu .sections-menu-db-table th:nth-child(4),
.admin-body--sections-menu .sections-menu-db-table td:nth-child(4) {
  min-width: 14rem;
}

.admin-body--sections-menu .sections-menu-db-table th:nth-child(5),
.admin-body--sections-menu .sections-menu-db-table td:nth-child(5) {
  min-width: 4.5rem;
}

.admin-body--sections-menu .sections-menu-db-table th:nth-child(6),
.admin-body--sections-menu .sections-menu-db-table td:nth-child(6) {
  min-width: 11rem;
}

.admin-body--sections-menu .sections-menu-db-table th:nth-child(7),
.admin-body--sections-menu .sections-menu-db-table td:nth-child(7) {
  min-width: 7rem;
}

.sections-menu-home-layout-select {
  width: 100%;
  min-width: 10rem;
  max-width: 16rem;
  font-size: 13px;
}

.sections-menu-layout-cell {
  vertical-align: top;
}

.admin-body--sections-menu .admin-table-actions-cell {
  display: table-cell;
  white-space: nowrap;
}

@media (max-width: 768px) {
  .admin-body--sections-menu .sections-menu-scroll-hint {
    display: block;
  }

  .admin-body--sections-menu .admin-content {
    overflow-x: visible;
  }

  .admin-body--sections-menu .admin-table-wrap {
    max-width: 100%;
  }

  .admin-body--sections-menu .sections-menu-json-form .admin-section-intro-input {
    min-width: 12rem;
    max-width: none;
  }

  .admin-body--sections-menu .sections-menu-home-layout-select {
    min-width: 9rem;
    max-width: none;
  }
}

.sections-db-intro-cell {
  max-width: 18rem;
  vertical-align: top;
}

span.sections-db-intro {
  display: block;
  font-size: 13px;
  line-height: 1.35;
}

.admin-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 20px;
  border-radius: 8px;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  transition:
    background 0.15s ease,
    transform 0.15s ease;
}

.admin-btn-primary {
  background: var(--brand);
  color: #fff;
}

.admin-btn-primary:hover {
  background: var(--brand-hover);
  color: #fff;
}

.admin-btn-danger {
  background: #b00020;
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 11px 18px;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
}

.admin-btn-danger:hover {
  background: #8f001a;
  color: #fff;
}

.admin-static-pages {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr;
}

@media (min-width: 900px) {
  .admin-static-pages {
    grid-template-columns: 220px minmax(0, 1fr);
    align-items: start;
    gap: 24px;
  }
}

.admin-static-pages-sidebar {
  padding: 16px 14px;
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 2px);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.admin-static-pages-sidebar-label {
  margin: 0 0 12px;
  padding: 0 4px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.admin-static-pages-nav {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.admin-static-pages-nav-link {
  display: block;
  padding: 11px 13px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 14px;
  color: var(--ink-soft);
  text-decoration: none;
  border: 1px solid transparent;
  background: var(--admin-canvas);
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease;
}

.admin-static-pages-nav-link:hover {
  border-color: var(--border-strong);
  color: var(--brand);
  background: var(--surface);
}

.admin-static-pages-nav-link.is-active {
  border-color: var(--brand);
  background: rgba(20, 54, 93, 0.1);
  color: var(--brand);
  box-shadow: inset 3px 0 0 var(--brand);
}

.admin-static-pages-sidebar-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px 10px;
  margin-bottom: 12px;
}

.admin-static-pages-sidebar-head .admin-static-pages-sidebar-label {
  margin: 0;
}

.admin-static-pages-menu-toggle {
  padding: 6px 10px;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: var(--admin-canvas);
  color: var(--ink-soft);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.admin-static-pages-menu-toggle:hover {
  border-color: var(--brand);
  color: var(--brand);
}

.admin-static-pages-nav-link.is-muted {
  opacity: 0.72;
}

.admin-static-pages-nav-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.08);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.02em;
  vertical-align: middle;
}

.admin-static-pages-menu-panel {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.admin-static-pages-menu-intro {
  margin: 0 0 12px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--muted);
}

.admin-static-pages-menu-list {
  list-style: none;
  margin: 0 0 12px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.admin-static-pages-menu-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 10px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--admin-canvas);
}

.admin-static-pages-menu-title-label {
  grid-column: 1;
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
}

.admin-static-pages-menu-title {
  grid-column: 1;
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  font-size: 13px;
}

.admin-static-pages-menu-enabled {
  grid-column: 1;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-soft);
}

.admin-static-pages-menu-order {
  grid-column: 2;
  grid-row: 1 / span 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
}

.admin-static-pages-menu-move {
  width: 28px;
  height: 24px;
  padding: 0;
  border: 1px solid var(--border-strong);
  border-radius: 6px;
  background: var(--surface);
  color: var(--ink-soft);
  font-size: 12px;
  line-height: 1;
  cursor: pointer;
}

.admin-static-pages-menu-move:hover {
  border-color: var(--brand);
  color: var(--brand);
}

.admin-static-pages-menu-slug {
  grid-column: 1 / -1;
  font-size: 11px;
  color: var(--muted);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

.admin-static-pages-menu-save {
  width: 100%;
}

.admin-static-pages-main {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

.admin-static-pages-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px 18px;
  padding: 18px 20px;
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 2px);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.admin-static-pages-toolbar-text {
  flex: 1 1 240px;
  min-width: 0;
}

.admin-static-pages-title {
  margin: 0 0 6px;
  font-size: 1.28rem;
  font-weight: 800;
  color: var(--ink);
  line-height: 1.3;
}

.admin-static-pages-note {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--muted);
}

.admin-static-pages-note a {
  color: var(--brand);
  font-weight: 700;
  text-decoration: none;
}

.admin-static-pages-note a:hover {
  color: var(--brand-hover);
  text-decoration: underline;
}

.admin-static-pages-toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.admin-static-pages-card {
  padding: 18px 18px 16px;
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 2px);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.admin-static-pages-form {
  margin: 0;
}

.admin-static-page-tabs {
  display: inline-flex;
  gap: 0;
  margin: 0 0 14px;
  padding: 4px;
  border-radius: 12px;
  background: var(--admin-canvas);
  border: 1px solid var(--border);
}

.admin-static-page-tab {
  min-width: 112px;
  padding: 10px 18px;
  border: none;
  border-radius: 9px;
  background: transparent;
  font: inherit;
  font-size: 14px;
  font-weight: 800;
  color: var(--muted);
  cursor: pointer;
  transition:
    background 0.15s ease,
    color 0.15s ease,
    box-shadow 0.15s ease;
}

.admin-static-page-tab:hover {
  color: var(--brand);
}

.admin-static-page-tab.is-active {
  color: var(--brand);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.admin-static-page-panels {
  min-width: 0;
}

.admin-static-page-panel label {
  display: block;
  margin: 0 0 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--muted);
}

.admin-static-page-editor-mount {
  min-height: 620px;
}

.admin-static-page-editor-mount .tox-tinymce {
  border-radius: 10px !important;
  border-color: var(--border-strong) !important;
  overflow: hidden;
}

.admin-static-page-code {
  width: 100%;
  min-height: 620px;
  padding: 14px 16px;
  border: 1px solid var(--border-strong);
  border-radius: 10px;
  background: #f8fafc;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 13px;
  line-height: 1.55;
  resize: vertical;
}

.admin-static-pages-footnote {
  margin: 14px 0 0;
}

@media (max-width: 899px) {
  .admin-static-pages-sidebar {
    padding: 12px;
  }

  .admin-static-pages-nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .admin-static-pages-nav-link.is-active {
    box-shadow: none;
  }

  .admin-static-page-editor-mount {
    min-height: 480px;
  }

  .admin-static-page-code {
    min-height: 480px;
  }
}

.admin-table-row--highlight td {
  background: rgba(20, 54, 93, 0.06);
  font-weight: 600;
}

.admin-detail-list {
  margin: 0 0 24px;
  padding: 0;
}

.admin-detail-row {
  display: grid;
  gap: 6px 16px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}

@media (min-width: 640px) {
  .admin-detail-row {
    grid-template-columns: 120px minmax(0, 1fr);
    align-items: start;
  }
}

.admin-detail-row dt {
  margin: 0;
  font-weight: 700;
  color: var(--muted);
}

.admin-detail-row dd {
  margin: 0;
  color: var(--ink);
  line-height: 1.6;
}

.admin-detail-message {
  white-space: normal;
  word-break: break-word;
}

.admin-form-inline-actions {
  margin-top: 8px;
}

.admin-btn-secondary {
  flex-shrink: 0;
  padding: 11px 18px;
  background: var(--surface);
  color: var(--brand);
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
}

.admin-btn-secondary:hover {
  border-color: var(--brand-muted);
  background: var(--surface-subtle);
}

label.admin-btn {
  cursor: pointer;
}

.admin-field-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: stretch;
  margin-top: 8px;
}

.admin-grow {
  flex: 1;
  min-width: 200px;
}

.admin-hero-preview {
  margin-top: 12px;
}

.admin-hero-preview img {
  max-height: 140px;
  max-width: 100%;
  border-radius: 8px;
  border: 1px solid var(--border);
  object-fit: contain;
  background: var(--surface-subtle);
}

.article-editor-mount {
  margin-top: 10px;
}

body.article-image-modal-open {
  overflow: hidden;
}

.article-image-modal {
  position: fixed;
  inset: 0;
  z-index: 200000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.article-image-modal[hidden] {
  display: none;
}

.article-image-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
}

.article-image-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 520px);
  max-height: min(92vh, 720px);
  overflow: auto;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.22);
  padding: 22px 22px 18px;
}

.article-image-modal__title {
  margin: 0 0 16px;
  font-size: 1.15rem;
  font-weight: 700;
}

.article-image-modal__mode {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin: 0 0 18px;
  padding: 0;
  border: 0;
}

.article-image-modal__mode-opt {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
}

.article-image-modal__slots {
  display: grid;
  gap: 16px;
}

.article-image-modal__slot {
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-subtle);
}

.article-image-modal__slot-title {
  margin: 0 0 10px;
  font-size: 0.92rem;
  font-weight: 700;
}

.article-image-modal__slot-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.article-image-modal__pick {
  padding: 8px 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
}

.article-image-modal__pick:hover {
  border-color: var(--brand);
}

.article-image-modal__status {
  font-size: 0.85rem;
  color: var(--muted);
}

.article-image-modal__preview {
  margin-bottom: 10px;
}

.article-image-modal__preview img {
  display: block;
  max-width: 100%;
  max-height: 180px;
  margin: 0 auto;
  border-radius: 8px;
  object-fit: contain;
  background: #fff;
}

.article-image-modal__caption-label {
  display: block;
  font-size: 0.88rem;
  font-weight: 600;
}

.article-image-modal__caption {
  display: block;
  width: 100%;
  margin-top: 8px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 0.92rem;
}

.article-image-modal__hint {
  margin: 14px 0 0;
}

.article-image-modal__shared-caption {
  margin-top: 14px;
}

.article-image-modal__shared-caption + .article-image-modal__hint {
  margin-top: 24px;
}

.article-image-modal__shared-caption[hidden],
.article-image-modal__caption-wrap[hidden] {
  display: none;
}

.article-image-modal__actions {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.article-image-modal__cancel {
  padding: 9px 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  font-weight: 600;
  cursor: pointer;
}

.article-image-modal__insert {
  padding: 9px 18px;
  border: 0;
  border-radius: 8px;
  background: var(--brand);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.article-image-modal__insert:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.article-image-modal__insert:not(:disabled):hover {
  filter: brightness(0.95);
}

/* TinyMCE 편집 영역·툴바 줄바꿈(좁은 화면) */
.article-edit-form .article-editor-mount .tox-tinymce {
  border-radius: 10px;
  border-width: 1px;
}

.article-edit-form .article-editor-mount .tox .tox-toolbar--primary {
  flex-wrap: wrap;
  row-gap: 4px;
}

.article-edit-form .tox .tox-toolbar__group {
  flex-wrap: wrap;
  padding: 4px 6px;
}

.article-edit-form .tox .tox-tbtn {
  margin: 0;
}

.admin-body-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* ---------- 기사 편집 폼: 2열 그리드 ---------- */
.article-edit-form > .admin-form-field {
  margin-top: 20px;
}

.article-edit-form > .admin-form-row:first-of-type {
  margin-top: 0;
}

.article-edit-form .admin-form-field > label {
  margin-top: 0;
  margin-bottom: 6px;
}

.article-edit-form .admin-form-row {
  display: grid;
  gap: 16px 24px;
  margin-top: 20px;
}

.article-edit-form .admin-form-row--2 {
  grid-template-columns: 1fr;
}

.article-edit-form .admin-form-row--3 {
  grid-template-columns: 1fr;
}

.article-edit-form .admin-form-row--5 {
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .article-edit-form .admin-form-row--2 {
    grid-template-columns: 1fr 1fr;
  }

  .article-edit-form .admin-form-row--3 {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 0.85fr) minmax(0, 0.9fr);
  }

  .article-edit-form .admin-form-row--media-line {
    grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
    gap: 16px 14px;
    align-items: stretch;
  }
}

@media (min-width: 960px) {
  .article-edit-form .admin-form-row--meta-line {
    grid-template-columns:
      minmax(0, 1fr)
      minmax(0, 1fr)
      minmax(0, 1.35fr)
      minmax(0, 0.85fr)
      minmax(0, 0.85fr);
    gap: 16px 14px;
    align-items: stretch;
  }

  .article-edit-form .admin-form-row--media-line {
    grid-template-columns:
      minmax(0, 1fr)
      minmax(0, 1fr)
      minmax(0, 1.35fr)
      minmax(0, 0.85fr)
      minmax(0, 0.85fr);
    gap: 16px 14px;
    align-items: stretch;
  }

  .article-edit-form
    .admin-form-row--media-line
    .admin-form-field--hero-inline {
    grid-column: 1;
  }

  .article-edit-form
    .admin-form-row--media-line
    .admin-form-field:not(.admin-form-field--hero-inline) {
    grid-column: 2 / 4;
  }
}

@media (max-width: 767px) {
  .article-edit-form .admin-form-row--section-slug {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 10px;
  }

  .article-edit-form .admin-form-row--meta-line {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 10px;
  }

  .article-edit-form
    .admin-form-row--meta-line
    .admin-form-field:nth-child(5) {
    grid-column: 1 / -1;
  }

  .article-edit-form .admin-form-row--media-line {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .article-edit-form .admin-form-row--section-slug .admin-form-field > label,
  .article-edit-form .admin-form-row--meta-line .admin-form-field > label,
  .article-edit-form .admin-form-row--media-line .admin-form-field > label,
  .article-edit-form .admin-form-field-check-title {
    font-size: 0.82rem;
    margin-bottom: 4px;
  }

  .article-edit-form .admin-form-row--section-slug .admin-form-field select,
  .article-edit-form .admin-form-row--section-slug .admin-form-field input[type='text'],
  .article-edit-form .admin-form-row--meta-line .admin-form-field select,
  .article-edit-form
    .admin-form-row--meta-line
    .admin-form-field
    input[type='datetime-local'],
  .article-edit-form
    .admin-form-row--meta-line
    .admin-form-field
    input[type='text'],
  .article-edit-form
    .admin-form-row--media-line
    .admin-form-field
    input[type='text'] {
    min-height: 40px;
    margin-top: 0;
    font-size: 0.92rem;
  }

  .article-edit-form .admin-form-slug-hint {
    font-size: 0.78rem;
    line-height: 1.4;
  }
}

.article-edit-form .admin-form-row .admin-form-field {
  margin-top: 0;
  min-width: 0;
}

.article-edit-form .admin-form-row--section-slug {
  align-items: stretch;
}

.article-edit-form .admin-form-row--section-slug .admin-form-field {
  display: flex;
  flex-direction: column;
}

.article-edit-form .admin-form-row--section-slug .admin-form-field select,
.article-edit-form .admin-form-row--section-slug .admin-form-field input[type='text'] {
  flex: 1 1 auto;
  min-height: 42px;
  margin-top: 8px;
}

.article-edit-form .admin-form-slug-hint {
  margin-top: 10px;
  margin-bottom: 0;
}

.article-edit-form .admin-form-field input,
.article-edit-form .admin-form-field select,
.article-edit-form .admin-form-field textarea {
  max-width: none;
  width: 100%;
}

.article-edit-form .admin-form-row--checks {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  align-items: center;
  margin-top: 20px;
  padding: 14px 16px;
  background: var(--surface-subtle);
  border: 1px solid var(--border);
  border-radius: 8px;
}

.article-edit-form .admin-form-row--meta-line {
  align-items: stretch;
}

.article-edit-form .admin-form-row--meta-line .admin-form-field {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.article-edit-form .admin-form-row--meta-line .admin-form-field > label,
.article-edit-form .admin-form-row--meta-line .admin-form-field-check-title {
  flex: 0 0 auto;
  margin-bottom: 6px;
}

.article-edit-form .admin-form-row--meta-line .admin-form-field input[type='text'],
.article-edit-form .admin-form-row--meta-line .admin-form-field input[type='datetime-local'],
.article-edit-form .admin-form-row--meta-line .admin-form-field select,
.article-edit-form .admin-form-row--meta-line .admin-form-status-fixed,
.article-edit-form .admin-form-row--meta-line .admin-form-check-row {
  flex: 1 1 auto;
  min-height: 42px;
  margin-top: 0;
  box-sizing: border-box;
}

.article-edit-form .admin-form-status-fixed {
  margin: 0;
  min-height: 42px;
  padding: 10px 12px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--text);
  background: var(--surface-subtle);
  border: 1px solid var(--border);
  border-radius: 6px;
}

.article-edit-form .admin-form-field--inline-check {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.article-edit-form .admin-form-field-check-title {
  display: block;
  margin-top: 0;
  margin-bottom: 6px;
  font-weight: 600;
  font-size: 0.9rem;
  line-height: 1.35;
  color: var(--text);
}

.article-edit-form .admin-form-check-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  margin: 0;
  padding: 10px 12px;
  font-weight: 600;
  line-height: 1.35;
  background: var(--surface-subtle);
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
}

.article-edit-form .admin-form-check-row input {
  width: auto;
  margin: 0;
  flex-shrink: 0;
}

@media (min-width: 720px) {
  .article-edit-form .admin-form-row--checks {
    flex-wrap: nowrap;
    gap: 12px 24px;
    justify-content: flex-start;
  }
}

.article-edit-form .admin-form-row--checks label {
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  flex: 0 0 auto;
  white-space: nowrap;
}

.article-edit-form .admin-form-hint-after-checks {
  margin-top: 8px;
  margin-bottom: 0;
}

.article-edit-form .admin-form-row--media-line {
  align-items: stretch;
}

.article-edit-form .admin-form-row--media-line .admin-form-field {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.article-edit-form .admin-form-row--media-line .admin-form-field > label {
  flex: 0 0 auto;
  margin-bottom: 6px;
}

.article-edit-form .admin-form-field--hero-inline > label {
  white-space: nowrap;
}

.article-edit-form .admin-hero-path-input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.article-edit-form .admin-form-row--media-line #caption_credit {
  flex: 0 0 36px;
  width: 100%;
  max-width: 100%;
  height: 36px;
  min-height: 36px;
  margin-top: auto;
  box-sizing: border-box;
}

.article-edit-form .admin-form-row--media-line .admin-field-row--hero-inline {
  flex: 0 0 auto;
  height: auto;
  margin-top: auto;
  align-items: stretch;
  min-height: 42px;
}

.article-edit-form .admin-form-row--media-line .admin-field-row--hero-inline .admin-grow {
  flex: 0 0 auto;
  min-width: 0;
  width: 1px;
  height: 1px;
  min-height: 0;
  box-sizing: border-box;
}

.article-edit-form
  .admin-form-row--media-line
  .admin-field-row--hero-inline
  .admin-btn-secondary,
.article-edit-form
  .admin-form-row--media-line
  .admin-field-row--hero-inline
  .admin-hero-clear-btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  margin: 0;
  box-sizing: border-box;
}

.article-edit-form
  .admin-form-row--media-line
  .admin-field-row--hero-inline
  .admin-hero-clear-btn {
  color: #b42318;
  border-color: rgba(180, 35, 24, 0.35);
}

.article-edit-form
  .admin-form-row--media-line
  .admin-field-row--hero-inline
  .admin-hero-clear-btn:hover {
  color: #8c1f1f;
  border-color: rgba(180, 35, 24, 0.55);
  background: rgba(180, 35, 24, 0.06);
}

.article-edit-form
  .admin-form-row--media-line
  .admin-field-row--hero-inline
  .admin-hero-clear-btn[hidden] {
  display: none;
}

.article-edit-form .admin-hero-preview--after-media-line {
  margin-top: 10px;
  margin-bottom: 0;
}

.article-edit-form .admin-form-field--editor {
  margin-top: 24px;
}

.article-edit-form .admin-form-field--editor .article-editor-mount {
  margin-top: 8px;
}

.article-edit-form .admin-form-field--editor textarea#article-body-field {
  max-width: none;
  width: 100%;
  min-height: 400px;
}

@media (min-width: 769px) {
  .article-edit-form .admin-form-field--editor textarea#article-body-field {
    min-height: 800px;
  }
}

.article-edit-form .admin-form-row--textarea-pair textarea {
  min-height: 120px;
}

.article-edit-form .admin-form-actions {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid var(--border);
}

.article-edit-form .admin-form-actions button[type="submit"] {
  margin-top: 0;
}

.admin-table-wrap {
  overflow-x: auto;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  background: var(--surface);
}

.admin-table-scroll-hint {
  display: none;
  margin: 0 0 12px;
  font-size: 12px;
}

.admin-body--articles-list .admin-table-wrap {
  max-width: 100%;
  overflow: hidden;
}

.admin-body--articles-list .admin-content {
  min-width: 0;
  box-sizing: border-box;
  overflow-x: hidden;
}

.admin-body--articles-list .admin-table-scroll {
  display: block;
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  overflow-y: hidden;
}

.admin-body--articles-list .admin-table {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  table-layout: fixed;
}

.admin-body--articles-list .admin-table th,
.admin-body--articles-list .admin-table td {
  box-sizing: border-box;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.admin-body--articles-list .admin-table th:nth-child(1),
.admin-body--articles-list .admin-table td:nth-child(1) {
  width: 3.25rem;
}

.admin-body--articles-list .admin-table th:nth-child(2),
.admin-body--articles-list .admin-table td:nth-child(2) {
  width: auto;
  max-width: 0;
  min-width: 0;
}

.admin-body--articles-list .admin-table th:nth-child(3),
.admin-body--articles-list .admin-table td:nth-child(3) {
  width: 6.5rem;
}

.admin-body--articles-list .admin-table th:nth-child(4),
.admin-body--articles-list .admin-table td:nth-child(4) {
  width: 3.5rem;
  overflow: visible;
  text-overflow: clip;
}

.admin-body--articles-list .admin-table th:nth-child(5),
.admin-body--articles-list .admin-table td:nth-child(5) {
  width: 11rem;
}

.admin-body--articles-list .admin-table th:nth-child(6),
.admin-body--articles-list .admin-table td:nth-child(6) {
  width: 10rem;
  overflow: visible;
  text-overflow: clip;
}

.admin-body--articles-list .admin-table-actions-cell {
  display: table-cell;
  white-space: nowrap;
  vertical-align: middle;
  padding-inline: 10px;
}

.admin-body--articles-list .admin-table-actions-cell .admin-inline-delete-form {
  display: inline;
  margin-inline-start: 12px;
}

@media (max-width: 768px) {
  .admin-body--articles-list .admin-table-scroll-hint {
    display: block;
  }

  .admin-body--articles-list .admin-main {
    min-width: 0;
    max-width: 100%;
    overflow-x: hidden;
  }

  .admin-body--articles-list .admin-content {
    min-width: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: visible;
  }

  .admin-body--articles-list .admin-table-wrap {
    overflow: hidden;
  }

  .admin-body--articles-list .admin-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    touch-action: pan-x pan-y;
    scrollbar-width: thin;
  }

  .admin-body--articles-list .admin-table {
    width: auto;
    min-width: 760px;
    max-width: none;
    table-layout: fixed;
  }

  .admin-body--articles-list .admin-table th:nth-child(2),
  .admin-body--articles-list .admin-table td:nth-child(2) {
    width: 12rem;
    max-width: 12rem;
  }

  .admin-body--articles-list .admin-table th:nth-child(3),
  .admin-body--articles-list .admin-table td:nth-child(3) {
    width: 6.5rem;
  }

  .admin-body--articles-list .admin-table th:nth-child(4),
  .admin-body--articles-list .admin-table td:nth-child(4) {
    width: 3.5rem;
    overflow: visible;
    text-overflow: clip;
  }

  .admin-body--articles-list .admin-table th:nth-child(5),
  .admin-body--articles-list .admin-table td:nth-child(5) {
    width: 11rem;
  }

  .admin-body--articles-list .admin-table th:nth-child(6),
  .admin-body--articles-list .admin-table td:nth-child(6) {
    width: 10rem;
  }

  .admin-body--articles-list .admin-table-actions-cell {
    display: table-cell;
  }

  .admin-body--articles-list .admin-table-actions-cell .admin-inline-delete-form {
    display: inline;
  }
}

.admin-body--contact-submissions-list .admin-table-actions-cell {
  min-width: 7.5rem;
  white-space: nowrap;
}

@media (max-width: 767px) {
  .admin-body--contact-submissions-list .admin-table-actions-cell {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-body--contact-submissions-list .admin-table-actions-cell .admin-inline-delete-form {
    display: inline;
  }
}

.admin-table-action {
  font-weight: 700;
  text-decoration: none;
}

.admin-table-actions-cell {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  vertical-align: middle;
}

.admin-inline-delete-form {
  display: inline;
  margin: 0;
}

.admin-inline-delete-form button {
  margin: 0;
  padding: 0;
  font: inherit;
  background: none;
  border: none;
  cursor: pointer;
}

.admin-table-action-danger {
  color: #b42318;
  font-weight: 700;
  text-decoration: underline;
}

.admin-table-action-danger:hover {
  color: #8c1f1f;
}

.admin-muted {
  font-size: 13px;
  color: var(--muted);
}

.admin-delete-row {
  margin-bottom: 1.25rem;
}

.admin-login-body {
  min-height: 100vh;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;
  background:
    radial-gradient(ellipse 85% 65% at 50% -25%, rgba(20, 54, 93, 0.38), transparent),
    var(--surface-subtle);
}

.admin-login-shell {
  width: min(440px, 100%);
}

.admin-login-kicker {
  margin: 0 0 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--brand-muted);
  letter-spacing: 0.02em;
}

.admin-login-wrap {
  margin: 0 auto;
  padding: 32px 28px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-md);
}

.admin-login-wrap h1 {
  font-family: var(--font-display);
  font-size: 1.42rem;
  color: var(--brand);
  margin: 0 0 8px;
}

.admin-login-notice {
  margin: 0 0 14px;
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.5;
  color: var(--brand);
  background: rgba(20, 54, 93, 0.08);
  border: 1px solid rgba(20, 54, 93, 0.18);
}

.admin-login-back {
  text-align: center;
  margin-top: 18px;
  font-size: 14px;
}

.admin-login-back a {
  color: var(--muted);
  font-weight: 600;
}

.admin-login-back a:hover {
  color: var(--brand-hover);
}

@media (max-width: 768px) {
  body.admin-nav-open {
    overflow: hidden;
  }

  .admin-sidebar-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 200;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    background: rgba(7, 16, 28, 0.48);
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    -webkit-tap-highlight-color: transparent;
  }

  body.admin-nav-open .admin-sidebar-backdrop {
    display: block;
  }

  .admin-mobile-nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    flex-shrink: 0;
    min-width: 44px;
    min-height: 44px;
    margin: 0;
    padding: 0 11px;
    border: 1px solid var(--border-strong);
    border-radius: 10px;
    background: var(--surface);
    color: var(--ink);
    font-family: inherit;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: var(--shadow-sm);
    -webkit-tap-highlight-color: transparent;
  }

  .admin-mobile-nav-toggle:focus-visible {
    outline: 2px solid var(--brand-muted);
    outline-offset: 2px;
  }

  .admin-mobile-nav-toggle-bars {
    display: block;
    width: 17px;
    height: 2px;
    border-radius: 1px;
    background: currentColor;
    box-shadow: 0 -6px 0 currentColor, 0 6px 0 currentColor;
  }

  .admin-mobile-nav-toggle-text {
    flex-shrink: 0;
  }

  .admin-app {
    display: block;
    position: relative;
    min-height: 100vh;
  }

  .admin-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(302px, calc(100vw - 48px));
    max-width: 100%;
    flex-shrink: 0;
    flex-direction: column;
    padding: 20px 0 16px;
    z-index: 210;
    transform: translateX(-102%);
    transition: transform 0.22s ease;
    box-shadow: 6px 0 28px rgba(0, 0, 0, 0.2);
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    border-right: 1px solid rgba(255, 255, 255, 0.12);
  }

  body.admin-nav-open .admin-sidebar {
    transform: translateX(0);
  }

  .admin-sidebar-brand {
    padding: 0 18px 16px;
    margin-bottom: 10px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  }

  .admin-sidebar-nav {
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 5px;
    padding: 0 12px;
  }

  .admin-sidebar-link {
    flex: 0 0 auto;
    text-align: left;
    min-height: 44px;
    display: flex;
    align-items: center;
    padding: 10px 14px;
    font-size: 14px;
    box-sizing: border-box;
  }

  .admin-sidebar-link.is-active {
    border-left: 3px solid var(--accent-warm);
    padding-left: 11px;
    box-shadow: none;
  }

  .admin-sidebar-nav .admin-sidebar-secondary {
    flex: 0 0 auto;
    text-align: left;
    min-height: 44px;
    display: flex;
    align-items: center;
    padding: 10px 14px;
    font-size: 14px;
    margin-top: 6px;
    border-radius: 8px;
    box-sizing: border-box;
  }

  .admin-sidebar-group {
    flex: 0 0 auto;
    width: 100%;
    padding-top: 10px;
    margin-top: 8px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  .admin-sidebar-toggle {
    flex: 0 0 auto;
    width: 100%;
    box-sizing: border-box;
    position: relative;
    min-height: 44px;
    justify-content: flex-start;
    padding: 10px 30px 10px 14px;
    font-size: 14px;
    text-align: left;
  }

  .admin-sidebar-toggle::after {
    position: absolute;
    right: 12px;
    top: 50%;
    margin-top: -4px;
  }

  .admin-sidebar-subnav {
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 5px;
    align-items: stretch;
    padding: 8px 6px 12px 14px !important;
    margin-left: 0 !important;
  }

  .admin-sidebar-link.admin-sidebar-link--sub {
    flex: 0 0 auto;
    min-width: 0;
    justify-content: flex-start;
    text-align: left;
    min-height: 42px;
    padding: 9px 12px !important;
    padding-left: 12px !important;
    font-size: 13px;
  }

  .admin-sidebar-link.admin-sidebar-link--sub.is-active {
    border-left: none !important;
    box-shadow: inset 0 0 0 1px rgba(251, 192, 90, 0.55) !important;
  }

  .admin-sidebar-link.admin-sidebar-link--sub.is-active::before {
    display: inline-block;
  }

  .admin-sidebar-footer {
    flex-direction: column;
    align-items: stretch;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 10px;
    padding: 14px 18px 0;
    margin-top: auto;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  .admin-sidebar-logout {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 14px;
    border-radius: 8px;
    box-sizing: border-box;
  }

  .admin-main {
    width: 100%;
    min-height: 100vh;
  }

  .admin-main-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 18px 14px;
  }

  .admin-main-title {
    flex: 1;
    min-width: 0;
    font-size: 1.22rem;
  }

  .admin-content {
    padding: 20px 16px 40px;
  }

  .admin-settings-subnav-link {
    min-height: 44px;
    padding: 11px 14px;
    align-items: center;
    box-sizing: border-box;
  }

  .admin-body--app .admin-form input:not([type='checkbox']):not([type='radio']),
  .admin-body--app .admin-form select,
  .admin-body--app .admin-form textarea {
    font-size: 16px;
    line-height: 1.45;
  }

  .admin-field-row .admin-grow {
    min-width: 0;
  }

  .article-edit-form .article-editor-mount .tox-tinymce {
    min-height: 240px;
  }
}

@media (max-width: 768px) and (prefers-reduced-motion: reduce) {
  .admin-sidebar {
    transition: none;
  }
}

.admin-error {
  color: #b00020;
}

.admin-settings-flash {
  margin: 0 0 16px;
  padding: 12px 14px;
  border-radius: 8px;
  background: rgba(34, 139, 92, 0.12);
  color: var(--ink-soft);
  font-weight: 600;
}

.admin-settings-banner {
  margin: 0 0 18px;
  padding: 14px 16px;
  border: 1px solid var(--accent-warm);
  border-radius: 10px;
  background: rgba(240, 180, 72, 0.1);
}

.admin-settings-banner strong {
  color: var(--ink);
}

.admin-settings-banner code {
  font-size: 0.92em;
}

.admin-settings-fieldset {
  margin: 0;
  padding: 22px 20px 26px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.admin-settings-fieldset legend {
  padding: 0 8px;
  font-weight: 800;
  font-size: 1.05rem;
}

.admin-settings-hint {
  margin: 12px 0 24px !important;
  line-height: 1.65;
  color: var(--muted);
}

.admin-body--app
  .admin-settings-fieldset
  p.field-hint:not(.admin-settings-inline-check-wrap) {
  margin: 10px 0 14px !important;
  padding: 10px 12px 10px 14px;
  max-width: 42rem;
  border-radius: 8px;
  background: var(--admin-hint-bg);
  border: 1px solid rgba(223, 227, 234, 0.95);
  border-left: 3px solid var(--admin-hint-accent);
  color: var(--ink-soft);
  line-height: 1.55;
}

.admin-body--app .admin-settings-form .admin-lead {
  margin: 0 0 14px;
  padding: 11px 14px;
  border-radius: 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  color: var(--ink-soft);
  line-height: 1.55;
}

.admin-body--app .admin-settings-live {
  margin: 16px 0 18px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.65);
  border: 1px solid var(--border);
  color: var(--ink-soft);
}

.admin-body--app .admin-form input:not([type='checkbox']):not([type='radio']),
.admin-body--app .admin-form select,
.admin-body--app .admin-form textarea {
  background: var(--admin-input-fill);
  border-color: var(--border-strong);
}

.admin-body--app .admin-form input:not([type='checkbox']):not([type='radio']):focus,
.admin-body--app .admin-form select:focus,
.admin-body--app .admin-form textarea:focus {
  background: var(--surface);
  border-color: var(--brand-muted);
  outline: none;
  box-shadow: 0 0 0 3px rgba(20, 54, 93, 0.12);
}

.admin-settings-more {
  margin: 0 0 20px;
  padding: 12px 16px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--admin-hint-bg);
  border-left: 3px solid var(--admin-hint-accent);
}

.admin-settings-more summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--ink-soft);
}

.admin-settings-more p {
  margin: 12px 0 0;
  font-size: 13px;
  line-height: 1.55;
}

.admin-settings-upload-btn {
  margin-top: 10px;
  display: inline-flex;
}

.admin-settings-inline-check-wrap {
  margin-top: 14px !important;
  margin-bottom: 0 !important;
}

.admin-settings-inline-check {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  font-weight: 600;
  cursor: pointer;
}

.admin-settings-form label.admin-settings-inline-check {
  margin-top: 0;
}

.admin-settings-live {
  margin: 24px 0 0;
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.62;
}

.admin-settings-form .admin-settings-fieldset + .admin-settings-fieldset {
  margin-top: 26px;
}

/* 사이트 기본설정(레거시 보조): 행 페어 필드 — 다른 화면에서 재사용 가능 */
.admin-body--settings-site-brand .admin-content {
  padding-top: 20px;
  padding-bottom: 36px;
}

.admin-body--settings-site-brand .admin-lead {
  margin: 0 0 6px;
  font-size: 0.94rem;
  line-height: 1.45;
}

.admin-body--settings-site-brand .admin-settings-more {
  margin: 0 0 8px;
  padding: 8px 12px;
}

.admin-body--settings-site-brand .admin-settings-live {
  margin: 0 0 14px;
  font-size: 13px;
  line-height: 1.45;
}

.admin-body--settings-site-brand .admin-settings-flash {
  margin-bottom: 10px;
}

.admin-body--settings-site-brand .admin-settings-banner {
  margin-bottom: 12px;
}

/* 사이트 기본설정: 기본정보 표 + 로고 그리드 */
.admin-body--settings-site-brand .admin-settings-form--site-brand {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.admin-body--settings-site-brand .admin-site-basic-h2 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--ink);
}

.admin-body--settings-site-brand .admin-site-basic-h2-icon {
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  background: #3b82f6;
  border-radius: 2px;
}

.admin-body--settings-site-brand .admin-site-basic-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.admin-body--settings-site-brand .admin-site-basic-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.94rem;
}

.admin-body--settings-site-brand .admin-site-basic-table th,
.admin-body--settings-site-brand .admin-site-basic-table td {
  padding: 12px 14px;
  vertical-align: top;
  border-bottom: 1px solid var(--border);
}

.admin-body--settings-site-brand .admin-site-basic-table tr:last-child th,
.admin-body--settings-site-brand .admin-site-basic-table tr:last-child td {
  border-bottom: none;
}

.admin-body--settings-site-brand .admin-site-basic-table th {
  width: 220px;
  max-width: 40%;
  text-align: right;
  font-weight: 600;
  background: rgba(230, 234, 242, 0.82);
  color: var(--ink-soft);
}

.admin-body--settings-site-brand .admin-site-basic-table th label {
  cursor: pointer;
  margin: 0;
}

.admin-body--settings-site-brand .admin-site-basic-table td .admin-grow {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.admin-body--settings-site-brand .admin-site-basic-hint {
  margin: 8px 0 0 !important;
  font-size: 12px;
  color: var(--muted);
}

.admin-body--settings-site-brand .admin-site-brand-extras-grid {
  display: grid;
  gap: 14px 18px;
}

@media (min-width: 920px) {
  .admin-body--settings-site-brand .admin-site-brand-extras-grid {
    grid-template-columns: 1fr 1fr;
  }

  .admin-body--settings-site-brand
    .admin-site-brand-extras-grid
    > .admin-settings-fieldset--site-brand-span {
    grid-column: 1 / -1;
  }
}

@media (max-width: 639px) {
  .admin-body--settings-site-brand .admin-site-basic-table th,
  .admin-body--settings-site-brand .admin-site-basic-table td {
    display: block;
    width: 100%;
    max-width: none;
    text-align: left;
    border-bottom: 1px solid var(--border);
  }

  .admin-body--settings-site-brand .admin-site-basic-table th {
    padding-bottom: 4px;
    background: rgba(230, 234, 242, 0.65);
  }

  .admin-body--settings-site-brand .admin-site-basic-table td {
    padding-top: 8px;
  }

  .admin-body--settings-site-brand
    .admin-site-basic-table
    tr:last-child
    td {
    border-bottom: none;
  }
}

.admin-body--settings-site-brand
  .admin-settings-form--site-brand
  .admin-settings-fieldset
  + .admin-settings-fieldset {
  margin-top: 0;
}

.admin-body--settings-site-brand
  .admin-settings-form--site-brand
  .admin-settings-fieldset {
  padding: 14px 16px 16px;
}

.admin-body--settings-site-brand
  .admin-settings-form--site-brand
  .admin-settings-fieldset
  legend {
  font-size: 1rem;
}

.admin-body--settings-site-brand
  .admin-site-brand-logo-preview.admin-hero-preview {
  margin-top: 8px;
}

.admin-body--settings-site-brand
  .admin-site-brand-logo-preview.admin-hero-preview
  img {
  max-height: 88px;
}

.admin-body--settings-site-brand .admin-settings-upload-btn {
  margin-top: 8px;
}

.admin-body--settings-site-brand .admin-settings-inline-check-wrap {
  margin-top: 10px !important;
}

.admin-body--settings-site-brand .admin-toolbar-like--site-brand-footer {
  margin-top: 0;
}

.admin-body--settings-site-brand .admin-footer-partner-hint {
  margin: 0 0 10px;
}

.admin-body--settings-site-brand .admin-footer-partner-table-wrap {
  overflow-x: auto;
  margin-top: 4px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.72);
}

.admin-body--settings-site-brand .admin-footer-partner-table {
  width: 100%;
  min-width: 640px;
  border-collapse: collapse;
  font-size: 13px;
}

.admin-body--settings-site-brand .admin-footer-partner-table th,
.admin-body--settings-site-brand .admin-footer-partner-table td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.admin-body--settings-site-brand .admin-footer-partner-table thead th {
  padding-top: 10px;
  padding-bottom: 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--ink-soft);
  text-align: left;
  background: rgba(230, 234, 242, 0.55);
}

.admin-body--settings-site-brand .admin-footer-partner-table tbody tr:last-child th,
.admin-body--settings-site-brand .admin-footer-partner-table tbody tr:last-child td {
  border-bottom: none;
}

.admin-body--settings-site-brand .admin-footer-partner-table__num {
  width: 2.2rem;
  min-width: 2.2rem;
  padding-left: 12px;
  padding-right: 6px;
  font-weight: 800;
  color: var(--ink-soft);
  text-align: center;
}

.admin-body--settings-site-brand .admin-footer-partner-table tbody th {
  font-weight: 800;
}

.admin-body--settings-site-brand .admin-footer-partner-input {
  width: 100%;
  min-width: 0;
  padding: 6px 8px;
  font-size: 13px;
}

.admin-body--settings-site-brand .admin-footer-partner-table td:nth-child(2) {
  min-width: 11rem;
}

.admin-body--settings-site-brand .admin-footer-partner-table td:nth-child(3) {
  min-width: 7rem;
}

.admin-body--settings-site-brand .admin-footer-partner-table td:nth-child(4) {
  min-width: 5.5rem;
}

.admin-body--settings-site-brand .admin-footer-partner-table td:nth-child(5) {
  min-width: 7rem;
}

@media (min-width: 960px) {
  .admin-body--settings-site-brand .admin-footer-partner-table {
    min-width: 0;
  }

  .admin-body--settings-site-brand .admin-footer-partner-table td:nth-child(2) {
    width: 34%;
  }

  .admin-body--settings-site-brand .admin-footer-partner-table td:nth-child(3) {
    width: 22%;
  }

  .admin-body--settings-site-brand .admin-footer-partner-table td:nth-child(4) {
    width: 14%;
  }

  .admin-body--settings-site-brand .admin-footer-partner-table td:nth-child(5) {
    width: 26%;
  }
}

.admin-settings-site-brand-pair-row {
  display: grid;
  gap: 8px 16px;
  margin-top: 12px;
}

.admin-settings-fieldset--site-brand-span
  > .admin-settings-site-brand-pair-row:first-of-type {
  margin-top: 0;
}

@media (min-width: 640px) {
  .admin-settings-site-brand-pair-row {
    grid-template-columns: 1fr 1fr;
  }
}

.admin-settings-site-brand-field {
  min-width: 0;
}

.admin-body--settings-site-brand
  .admin-settings-site-brand-field
  > label {
  margin-top: 0;
}

@media (max-width: 639px) {
  .admin-settings-site-brand-pair-row
    .admin-settings-site-brand-field
    + .admin-settings-site-brand-field
    > label {
    margin-top: 10px;
  }
}

/* 히어로 아래 광고 · 기사 하단 광고: 동일 폼 격자 */
.admin-body--home-masthead-ad .admin-content,
.admin-body--article-page-ad .admin-content {
  padding-top: 20px;
  padding-bottom: 36px;
}

.admin-body--home-masthead-ad .admin-lead,
.admin-body--article-page-ad .admin-lead {
  margin: 0 0 6px;
  font-size: 0.94rem;
  line-height: 1.45;
}

.admin-body--home-masthead-ad .admin-ad-zone-size,
.admin-body--article-page-ad .admin-ad-zone-size,
.admin-body--home-section-ads .admin-ad-zone-size,
.admin-body--quick-banner-ad .admin-ad-zone-size {
  margin: 0 0 12px;
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink);
  background: rgba(0, 0, 0, 0.04);
  border: 1px solid var(--border);
  border-radius: 8px;
}

.admin-body--home-masthead-ad .admin-ad-zone-enabled-row,
.admin-body--article-page-ad .admin-ad-zone-enabled-row,
.admin-body--home-section-ads .admin-ad-zone-enabled-row,
.admin-body--quick-banner-ad .admin-ad-zone-enabled-row {
  margin: 0 0 16px;
  padding: 12px 14px;
  background: var(--surface-subtle);
  border: 1px solid var(--border);
  border-radius: 8px;
}

.admin-body--home-masthead-ad
  .admin-settings-form--home-masthead-ad
  > .admin-ad-zone-enabled-row,
.admin-body--article-page-ad
  .admin-settings-form--article-page-ad
  > .admin-ad-zone-enabled-row {
  grid-column: 1 / -1;
}

.admin-body--home-masthead-ad .admin-ad-zone-size__px,
.admin-body--article-page-ad .admin-ad-zone-size__px,
.admin-body--home-section-ads .admin-ad-zone-size__px,
.admin-body--quick-banner-ad .admin-ad-zone-size__px {
  font-weight: 700;
  color: var(--brand);
}

.admin-body--home-masthead-ad .admin-settings-more,
.admin-body--article-page-ad .admin-settings-more {
  margin: 0 0 8px;
  padding: 8px 12px;
}

.admin-body--home-masthead-ad .admin-masthead-ad-banner-link,
.admin-body--article-page-ad .admin-masthead-ad-banner-link {
  margin: 0 0 12px;
  font-size: 13px;
  line-height: 1.45;
}

.admin-body--home-masthead-ad .admin-settings-flash,
.admin-body--article-page-ad .admin-settings-flash {
  margin-bottom: 10px;
}

.admin-body--home-masthead-ad .admin-settings-banner,
.admin-body--article-page-ad .admin-settings-banner {
  margin-bottom: 12px;
}

.admin-body--home-masthead-ad .admin-settings-hint,
.admin-body--article-page-ad .admin-settings-hint {
  margin: 6px 0 10px !important;
  font-size: 13px;
  line-height: 1.5;
}

.admin-body--home-masthead-ad .admin-settings-form--home-masthead-ad,
.admin-body--article-page-ad .admin-settings-form--article-page-ad {
  display: grid;
  gap: 14px 18px;
}

@media (min-width: 920px) {
  .admin-body--home-masthead-ad .admin-settings-form--home-masthead-ad,
  .admin-body--article-page-ad .admin-settings-form--article-page-ad {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }

  .admin-body--home-masthead-ad
    .admin-settings-form--home-masthead-ad
    > .admin-toolbar-like--masthead-footer,
  .admin-body--article-page-ad
    .admin-settings-form--article-page-ad
    > .admin-toolbar-like--article-page-footer {
    grid-column: 1 / -1;
  }

  /* 좌: 배너 이미지 · 우: 링크·기간·alt */
  .admin-body--home-masthead-ad
    .admin-settings-form--home-masthead-ad
    > .admin-settings-fieldset:nth-of-type(1),
  .admin-body--article-page-ad
    .admin-settings-form--article-page-ad
    > .admin-settings-fieldset:nth-of-type(1) {
    grid-column: 1;
    grid-row: 2 / span 3;
    align-self: start;
  }

  .admin-body--home-masthead-ad
    .admin-settings-form--home-masthead-ad
    > .admin-settings-fieldset:nth-of-type(2),
  .admin-body--article-page-ad
    .admin-settings-form--article-page-ad
    > .admin-settings-fieldset:nth-of-type(2) {
    grid-column: 2;
    grid-row: 2;
  }

  .admin-body--home-masthead-ad
    .admin-settings-form--home-masthead-ad
    > .admin-settings-fieldset:nth-of-type(3),
  .admin-body--article-page-ad
    .admin-settings-form--article-page-ad
    > .admin-settings-fieldset:nth-of-type(3) {
    grid-column: 2;
    grid-row: 3;
  }

  .admin-body--home-masthead-ad
    .admin-settings-form--home-masthead-ad
    > .admin-settings-fieldset:nth-of-type(4),
  .admin-body--article-page-ad
    .admin-settings-form--article-page-ad
    > .admin-settings-fieldset:nth-of-type(4) {
    grid-column: 2;
    grid-row: 4;
  }
}

.admin-body--home-masthead-ad
  .admin-settings-form--home-masthead-ad
  .admin-settings-fieldset
  + .admin-settings-fieldset,
.admin-body--article-page-ad
  .admin-settings-form--article-page-ad
  .admin-settings-fieldset
  + .admin-settings-fieldset {
  margin-top: 0;
}

.admin-body--home-masthead-ad
  .admin-settings-form--home-masthead-ad
  .admin-settings-fieldset,
.admin-body--article-page-ad
  .admin-settings-form--article-page-ad
  .admin-settings-fieldset {
  padding: 14px 16px 16px;
}

.admin-body--home-masthead-ad
  .admin-settings-form--home-masthead-ad
  .admin-settings-fieldset
  legend,
.admin-body--article-page-ad
  .admin-settings-form--article-page-ad
  .admin-settings-fieldset
  legend {
  font-size: 1rem;
}

.admin-body--home-masthead-ad
  .home-masthead-ad-preview-shell.admin-hero-preview,
.admin-body--article-page-ad
  .article-page-ad-preview-shell.admin-hero-preview {
  margin-top: 8px;
}

.admin-body--home-masthead-ad
  .home-masthead-ad-preview-shell.admin-hero-preview
  img,
.admin-body--article-page-ad
  .article-page-ad-preview-shell.admin-hero-preview
  img {
  max-height: 88px;
}

.admin-body--home-masthead-ad .admin-settings-upload-btn,
.admin-body--article-page-ad .admin-settings-upload-btn {
  margin-top: 8px;
}

.admin-body--home-masthead-ad .admin-toolbar-like--masthead-footer,
.admin-body--article-page-ad .admin-toolbar-like--article-page-footer {
  margin-top: 0;
}

/* 메인 섹션 광고: 노출 위치 탭 */
.admin-body--home-section-ads .admin-content {
  padding-top: 20px;
  padding-bottom: 36px;
}

.admin-body--home-section-ads .admin-home-section-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 8px;
  margin: 0 0 14px;
  padding: 0 0 10px;
  border-bottom: 1px solid var(--border);
}

.admin-body--home-section-ads .admin-home-section-tab {
  margin: 0;
  padding: 10px 14px;
  font: inherit;
  font-size: 0.94rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--muted);
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px 8px 0 0;
  cursor: pointer;
  text-align: left;
  max-width: 100%;
}

.admin-body--home-section-ads .admin-home-section-tab:hover {
  color: var(--ink);
  background: rgba(255, 255, 255, 0.45);
}

.admin-body--home-section-ads
  .admin-home-section-tab[aria-selected='true'] {
  color: var(--ink);
  background: var(--surface);
  border-color: var(--border);
  border-bottom-color: var(--surface);
  margin-bottom: -1px;
  padding-bottom: 11px;
  box-shadow: var(--shadow-sm);
}

.admin-body--home-section-ads .admin-home-section-tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.admin-body--home-section-ads .admin-home-section-tab-panel[hidden] {
  display: none !important;
}

.admin-body--home-section-ads .admin-settings-form--home-section-ads {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.admin-body--home-section-ads .admin-settings-form--home-section-ads
  > .admin-toolbar-like {
  margin-top: 18px;
}

/* 퀵배너 광고: 좌·우 2열·압축 */
.admin-body--quick-banner-ad .admin-content {
  padding-top: 20px;
  padding-bottom: 36px;
}

.admin-body--quick-banner-ad .admin-lead {
  margin: 0 0 6px;
  font-size: 0.94rem;
  line-height: 1.45;
}

.admin-body--quick-banner-ad .admin-settings-more {
  margin: 0 0 10px;
  padding: 8px 12px;
}

.admin-body--quick-banner-ad .admin-quick-banner-side-link {
  margin: 0 0 8px;
  font-size: 13px;
  line-height: 1.45;
}

.admin-body--quick-banner-ad .admin-settings-flash {
  margin-bottom: 10px;
}

.admin-body--quick-banner-ad .admin-settings-banner {
  margin-bottom: 12px;
}

.admin-body--quick-banner-ad .admin-settings-hint {
  margin: 6px 0 10px !important;
  font-size: 13px;
  line-height: 1.5;
}

.admin-body--quick-banner-ad .admin-settings-hint--compact {
  margin: 4px 0 8px !important;
}

.admin-body--quick-banner-ad .admin-settings-form--quick-banner-ad {
  display: grid;
  gap: 14px 18px;
}

.admin-body--quick-banner-ad .admin-settings-fieldset--quick-scope {
  grid-column: 1 / -1;
}

@media (min-width: 920px) {
  .admin-body--quick-banner-ad .admin-settings-form--quick-banner-ad {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }

  .admin-body--quick-banner-ad
    .admin-settings-form--quick-banner-ad
    > .admin-toolbar-like--quick-banner-footer {
    grid-column: 1 / -1;
  }

  .admin-body--quick-banner-ad .admin-settings-fieldset--quick-scope {
    grid-column: 1 / -1;
  }
}

.admin-body--quick-banner-ad
  .admin-settings-form--quick-banner-ad
  .admin-settings-fieldset
  + .admin-settings-fieldset {
  margin-top: 0;
}

.admin-body--quick-banner-ad
  .admin-settings-form--quick-banner-ad
  .admin-settings-fieldset {
  padding: 14px 16px 16px;
}

.admin-body--quick-banner-ad
  .admin-settings-form--quick-banner-ad
  .admin-settings-fieldset
  legend {
  font-size: 1rem;
}

.admin-body--quick-banner-ad
  .home-quick-banner-admin-preview.admin-hero-preview {
  margin-top: 8px;
}

.admin-body--quick-banner-ad
  .home-quick-banner-admin-preview.admin-hero-preview
  img {
  width: 100%;
  max-width: 140px;
  height: auto;
  max-height: 160px;
}

.admin-body--quick-banner-ad .admin-settings-upload-btn {
  margin-top: 8px;
}

.admin-body--quick-banner-ad .admin-settings-quick-banner-dims {
  margin-top: 12px;
}

.admin-body--quick-banner-ad .admin-toolbar-like--quick-banner-footer {
  margin-top: 0;
}

.admin-body--quick-banner-ad .admin-settings-inline-check-wrap {
  margin-top: 10px !important;
  margin-bottom: 0 !important;
}

.admin-settings-form .admin-form-field {
  margin-bottom: 22px;
}

.admin-settings-form .admin-settings-fieldset > .admin-form-field:last-child,
.admin-settings-form .admin-settings-fieldset > .admin-settings-submit {
  margin-bottom: 0;
}

.admin-settings-form .admin-form-row {
  margin-bottom: 8px;
}

.admin-settings-form .admin-form-row--2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 16px;
  margin-bottom: 0;
}

@media (max-width: 640px) {
  .admin-settings-form .admin-form-row--2 {
    grid-template-columns: 1fr;
  }
}

.admin-settings-form .admin-form-row--2 .admin-form-field {
  margin: 0;
}

.admin-settings-form .admin-form-row--2 .admin-form-field > label {
  margin-top: 0;
}

.admin-settings-form .admin-form-field .field-hint {
  margin-top: 12px;
  margin-bottom: 0;
  line-height: 1.62;
}

.admin-settings-form .admin-settings-submit {
  margin-top: 22px !important;
  margin-bottom: 0 !important;
}

.admin-settings-form .admin-settings-submit button[type='submit'] {
  margin-top: 0;
}

.admin-form label {
  display: block;
  margin-top: 14px;
  font-weight: 600;
  color: var(--ink-soft);
}

.field-hint {
  margin: -6px 0 8px;
  font-size: 13px;
  font-weight: 400;
  color: var(--muted);
  line-height: 1.45;
}

.admin-form input,
.admin-form select,
.admin-form textarea {
  width: 100%;
  max-width: 42rem;
  margin-top: 8px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-family: inherit;
}

.admin-form input[type='checkbox'],
.admin-form input[type='radio'] {
  width: 1.125rem;
  height: 1.125rem;
  max-width: none;
  margin-top: 0;
  margin-right: 0;
  padding: 0;
  border-radius: 4px;
  vertical-align: middle;
  flex-shrink: 0;
  cursor: pointer;
}

.admin-form input[type='radio'] {
  border-radius: 50%;
}

.admin-form button[type="submit"]:not(.btn-danger) {
  margin-top: 18px;
  padding: 12px 22px;
  background: var(--brand);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
}

.admin-form button[type="submit"]:not(.btn-danger):hover {
  background: var(--brand-hover);
}

.admin-form button[type="submit"].btn-danger {
  margin-top: 18px;
  padding: 12px 22px;
}

.btn-danger {
  background: #a62626;
  color: #fff;
  border: none;
  border-radius: 8px;
}

.btn-danger:hover {
  background: #8c1f1f;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 0;
  background: var(--surface);
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
}

.admin-table th,
.admin-table td {
  border: 1px solid var(--border);
  padding: 10px 12px;
  text-align: left;
}

.admin-table th {
  background: var(--surface-subtle);
  color: var(--brand);
  font-weight: 700;
}

/* 홈 메인 — 제목 리스트형 섹션 */
.main-home .home-title-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--border);
}

.main-home .home-title-list__item {
  border-bottom: 1px solid var(--border);
}

.main-home .home-title-list__link {
  position: relative;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  word-break: break-word;
  padding: 12px 4px 12px calc(5px + 0.55em);
  color: var(--text);
  text-decoration: none;
  font-family: var(--font-sans);
  font-size: 1.08rem;
  line-height: 1.35;
  font-weight: 700;
}

.main-home .home-title-list__link::before {
  content: "";
  position: absolute;
  left: 4px;
  top: calc(12px + 0.45em);
  width: 5px;
  height: 5px;
  margin-top: 0;
  border-radius: 50%;
  background: var(--brand);
}

.main-home .home-title-list__link:hover {
  color: var(--brand);
}

.main-home .home-title-list__link:hover::before {
  background: var(--brand-hover);
}

.main-home .home-title-list__empty {
  list-style: none;
  padding: 8px 0;
}

.main-home .section-block--home-title-list .section-block-head {
  margin-bottom: 8px;
}

.main-home .section-block--home-gallery .opinion-grid {
  margin-top: 0;
}

/* 갤러리형 홈: 모바일 1열×2건 · 680px+ 3×2(6건) */
.main-home .section-block--home-gallery .article-grid.article-grid--home.opinion-grid,
.main-home
  .opinion-block--gallery-card-stack
  .article-grid.article-grid--home.opinion-grid {
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (max-width: 679px) {
  .main-home .section-block--home-gallery .article-grid.article-grid--home.opinion-grid
    .article-card:nth-child(n + 3),
  .main-home
    .opinion-block--gallery-card-stack
    .article-grid.article-grid--home.opinion-grid
    .article-card:nth-child(n + 3) {
    display: none;
  }
}

@media (min-width: 680px) {
  .main-home .section-block--home-gallery .article-grid.article-grid--home.opinion-grid,
  .main-home
    .opinion-block--gallery-card-stack
    .article-grid.article-grid--home.opinion-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
  }

  .main-home .section-block--home-gallery .article-grid.article-grid--home.opinion-grid
    .article-card:nth-child(n + 3),
  .main-home
    .opinion-block--gallery-card-stack
    .article-grid.article-grid--home.opinion-grid
    .article-card:nth-child(n + 3) {
    display: grid;
  }
}

@media (min-width: 1100px) {
  .main-home .section-block--home-gallery .article-grid.article-grid--home.opinion-grid,
  .main-home
    .opinion-block--gallery-card-stack
    .article-grid.article-grid--home.opinion-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
  }

  .main-home .section-block--home-gallery .article-grid--home.opinion-grid .article-card--lead,
  .main-home
    .opinion-block--gallery-card-stack
    .article-grid--home.opinion-grid
    .article-card--lead {
    grid-column: auto;
  }
}

/* 가로 카드형: 2열×2행 · 카드 안 썸네일 왼쪽·제목 오른쪽 */
.main-home .article-grid--home-thumb-side {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.main-home .article-grid--home-thumb-side .article-card:has(.card-thumb) {
  grid-template-columns: 112px 1fr;
  align-items: stretch;
}

.main-home .article-grid--home-thumb-side .article-card:has(.card-thumb) .card-thumb {
  display: block;
  height: 100%;
  min-height: 72px;
}

.main-home .article-grid--home-thumb-side .article-card:has(.card-thumb) .card-thumb img {
  width: 100%;
  height: 100%;
  min-height: 72px;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.main-home .article-grid--home-thumb-side .article-card .card-body {
  padding: 8px 10px 10px;
  min-width: 0;
}

.main-home .article-grid--home-thumb-side .article-card .card-meta {
  margin: 0 0 4px;
  font-size: 10px;
}

@media (min-width: 640px) {
  .main-home .article-grid--home-thumb-side .article-card:has(.card-thumb) {
    grid-template-columns: 148px 1fr;
  }

  .main-home .article-grid--home-thumb-side .article-card:has(.card-thumb) .card-thumb {
    min-height: 96px;
  }

  .main-home .article-grid--home-thumb-side .article-card:has(.card-thumb) .card-thumb img {
    min-height: 96px;
  }
}

@media (max-width: 479px) {
  .main-home .article-grid--home-thumb-side {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 1100px) {
  .main-home .article-grid--home-thumb-side {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }

  .main-home .article-grid--home-thumb-side .article-card--lead {
    grid-column: auto;
  }
}

