/*
Theme Name: Cadenhub Child
Template: generatepress
Version: 2.0.0
*/

:root {
    --bg: #ffffff;
    --fg: #191f28;
    --muted: #8b95a1;
    --border: #f0f0f0;
    --accent: #3182f6;
    --surface: #f9fafb;
}

/* ── Base ── */
body, button, input, select, textarea {
    font-family: 'Pretendard Variable', -apple-system, BlinkMacSystemFont, system-ui, sans-serif !important;
    font-size: 16px !important;
    line-height: 1.7 !important;
    color: var(--fg) !important;
    -webkit-font-smoothing: antialiased;
}
body { background: var(--bg) !important; }

/* ── Headings ── */
h1 { font-size: 36px !important; font-weight: 700 !important; line-height: 1.3 !important; letter-spacing: -0.02em !important; }
h2 { font-size: 28px !important; font-weight: 700 !important; line-height: 1.35 !important; letter-spacing: -0.02em !important; }
h3 { font-size: 22px !important; font-weight: 600 !important; }
h4 { font-size: 18px !important; font-weight: 600 !important; }
h1, h2, h3, h4, h5, h6 { color: var(--fg) !important; }

/* ── Header ── */
.site-header {
    background: var(--bg) !important;
    border-bottom: 1px solid var(--border) !important;
    box-shadow: none !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 999 !important;
}
.inside-header { padding: 12px 40px !important; max-width: 1200px !important; margin: 0 auto !important; }
.main-title { font-size: 20px !important; font-weight: 700 !important; }
.main-title a { color: var(--fg) !important; text-decoration: none !important; }
.main-navigation, .main-navigation ul ul { background: transparent !important; }
.main-navigation a { font-size: 15px !important; font-weight: 600 !important; color: var(--fg) !important; text-decoration: none !important; }
.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li[class*="current-menu-"] > a { color: var(--accent) !important; background: transparent !important; }

/* ── 검색 버튼 ── */
.ch-search-menu-item { list-style: none !important; display: flex !important; align-items: center !important; }
.ch-search-menu-item .ch-search-toggle,
button.ch-search-toggle {
    background: transparent !important; border: none !important; color: var(--fg) !important;
    padding: 8px !important; cursor: pointer !important; display: flex !important; align-items: center !important;
    border-radius: 0 !important; box-shadow: none !important; width: auto !important; height: auto !important;
}
.ch-search-toggle:hover { color: var(--accent) !important; }

/* ── 검색 오버레이 ── */
#ch-search-overlay {
    display: none !important; position: fixed !important; inset: 0 !important;
    background: rgba(0,0,0,0.5) !important; z-index: 99999 !important;
    justify-content: center !important; align-items: flex-start !important; padding-top: 140px !important;
}
#ch-search-overlay.active { display: flex !important; }
.ch-search-box {
    background: #fff !important; border-radius: 16px !important;
    width: 560px !important; max-width: 90vw !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.2) !important; overflow: hidden !important;
}
.ch-search-box form { display: flex !important; align-items: center !important; padding: 0 !important; margin: 0 !important; }
.ch-search-box input[type="search"] {
    flex: 1 !important; border: none !important; background: transparent !important;
    font-size: 17px !important; padding: 18px 20px !important; outline: none !important; box-shadow: none !important; color: var(--fg) !important;
}
button.ch-close {
    background: transparent !important; border: none !important; color: var(--muted) !important;
    font-size: 28px !important; line-height: 1 !important; padding: 16px 20px !important; cursor: pointer !important; box-shadow: none !important;
}
button.ch-close:hover { color: var(--fg) !important; }
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration { -webkit-appearance: none !important; display: none !important; }

/* ── Layout ── */
.site-content { background: var(--bg) !important; }
.separate-containers .site-main { max-width: 1200px !important; margin: 0 auto !important; padding: 40px 40px !important; }
.sidebar { display: none !important; }

/* ── 섹션 제목 ── */
.ch-section-title { font-size: 24px !important; font-weight: 700 !important; color: var(--fg) !important; margin: 0 0 24px 0 !important; letter-spacing: -0.02em !important; }

/* ── Article Cards ── */
.separate-containers .inside-article, .inside-article {
    background: var(--bg) !important; border: 1px solid var(--border) !important;
    border-radius: 12px !important; padding: 32px 36px !important; margin-bottom: 16px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
}
.inside-article:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.06) !important; border-color: #e4e4e7 !important; }

/* ── Entry Title ── */
h2.entry-title { margin-bottom: 4px !important; }
h2.entry-title a { font-size: 22px !important; font-weight: 700 !important; color: var(--fg) !important; text-decoration: none !important; line-height: 1.4 !important; letter-spacing: -0.01em !important; }
h2.entry-title a:hover { color: var(--accent) !important; }

/* ── Entry Meta ── */
.entry-meta { font-size: 13px !important; color: var(--muted) !important; margin-bottom: 12px !important; }
.entry-meta a { color: var(--muted) !important; text-decoration: none !important; }

/* ── Content ── */
.entry-content, .entry-summary { font-size: 15px !important; line-height: 1.65 !important; color: #4e5968 !important; }
.archive .entry-content > p:first-of-type,
.blog .entry-content > p:first-of-type,
.home .entry-content > p:first-of-type {
    display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important;
}

/* ── Read More ── */
a.read-more { font-size: 14px !important; font-weight: 600 !important; color: var(--accent) !important; text-decoration: none !important; }
a.read-more:hover { text-decoration: underline !important; }

/* ── Category Badge ── */
.cat-links a, .tag-links a {
    background: transparent !important; color: var(--accent) !important; border: 1px solid var(--accent) !important;
    padding: 2px 10px !important; border-radius: 100px !important; font-size: 12px !important; font-weight: 600 !important;
    text-decoration: none !important; display: inline-block !important; margin: 2px 4px 2px 0 !important;
}
.cat-links a:hover, .tag-links a:hover { background: var(--accent) !important; color: #fff !important; }

/* ── Post Footer Meta ── */
footer.entry-meta { font-size: 13px !important; color: var(--muted) !important; padding-top: 12px !important; margin-top: 12px !important; border-top: none !important; }

/* ── Links ── */
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.entry-content a { text-decoration: underline; text-underline-offset: 3px; }

/* ── 댓글 제거 ── */
.comments-area, #comments, .comments-link, footer.entry-meta .comments-link { display: none !important; }

/* ── Single Post ── */
.single .inside-article { border: none !important; box-shadow: none !important; padding: 40px 0 !important; }
.single .entry-content { max-width: 720px !important; font-size: 17px !important; line-height: 1.8 !important; color: var(--fg) !important; }
.single .entry-content p { margin-bottom: 1.5em !important; }
.single .entry-header h1.entry-title { font-size: 36px !important; font-weight: 700 !important; line-height: 1.3 !important; letter-spacing: -0.02em !important; margin-bottom: 12px !important; }
.single .entry-header .entry-meta { margin-bottom: 40px !important; }

/* ── TOC ── */
#ez-toc-container { background: var(--surface) !important; border: none !important; border-radius: 12px !important; padding: 20px 24px !important; margin-bottom: 32px !important; box-shadow: none !important; }
#ez-toc-container .ez-toc-title { font-size: 15px !important; font-weight: 700 !important; color: var(--fg) !important; }
#ez-toc-container a { color: var(--muted) !important; text-decoration: none !important; font-size: 14px !important; }
#ez-toc-container a:hover { color: var(--fg) !important; }

/* ── 인기 있는 글 ── */
.ch-popular-section { background: var(--surface) !important; border-radius: 16px !important; padding: 28px 24px !important; margin-top: 40px !important; }
.ch-popular-heading { font-size: 20px !important; font-weight: 700 !important; color: var(--fg) !important; margin: 0 0 20px 0 !important; }
.ch-popular-list { display: flex !important; flex-direction: column !important; gap: 0 !important; }
a.ch-popular-item { display: flex !important; align-items: center !important; gap: 16px !important; text-decoration: none !important; padding: 12px 0 !important; border-bottom: 1px solid var(--border) !important; }
a.ch-popular-item:last-child { border-bottom: none !important; }
a.ch-popular-item:hover .ch-popular-title { color: var(--accent) !important; }
span.ch-popular-num { font-size: 15px !important; font-weight: 700 !important; color: var(--accent) !important; min-width: 24px !important; text-align: center !important; }
.ch-popular-info { display: flex !important; flex-direction: column !important; gap: 2px !important; }
span.ch-popular-title { font-size: 15px !important; font-weight: 600 !important; color: var(--fg) !important; line-height: 1.4 !important; }
span.ch-popular-cat { font-size: 12px !important; color: var(--muted) !important; }

/* ── Footer ── */
.site-footer, .footer-widgets, .site-info { background: var(--bg) !important; border: none !important; box-shadow: none !important; }
.site-info { color: var(--muted) !important; font-size: 13px !important; padding: 20px 0 !important; text-align: center !important; border-top: 1px solid var(--border) !important; }
.site-info a { color: var(--muted) !important; }

/* ── Pagination ── */
.paging-navigation { background: transparent !important; border: none !important; box-shadow: none !important; padding: 24px 0 !important; }
.nav-links .page-numbers { background: transparent !important; color: var(--muted) !important; border: none !important; border-radius: 8px !important; padding: 8px 14px !important; font-size: 15px !important; font-weight: 500 !important; }
.nav-links .page-numbers.current { background: var(--fg) !important; color: #fff !important; }
.nav-links .page-numbers:hover:not(.current) { background: var(--surface) !important; }

/* ── Back to Top ── */
a.generate-back-to-top { background: var(--fg) !important; color: #fff !important; border-radius: 50% !important; width: 44px !important; height: 44px !important; line-height: 44px !important; box-shadow: 0 4px 12px rgba(0,0,0,0.12) !important; border: none !important; }

/* ── Forms ── */
input[type="text"], input[type="email"], input[type="search"], input[type="url"], textarea, select {
    background: var(--surface) !important; color: var(--fg) !important; border: 1px solid var(--border) !important;
    border-radius: 8px !important; font-size: 15px !important; padding: 12px 16px !important;
}
input:focus, textarea:focus { border-color: var(--accent) !important; outline: none !important; box-shadow: 0 0 0 3px rgba(49,130,246,0.1) !important; }
button, input[type="submit"] {
    background: var(--accent) !important; color: #fff !important; border-radius: 8px !important;
    font-weight: 600 !important; font-size: 15px !important; padding: 12px 24px !important; border: none !important;
}

/* ── Mobile ── */
@media (max-width: 768px) {
    body { font-size: 15px !important; }
    .inside-header { padding: 10px 20px !important; }
    h2.entry-title a { font-size: 20px !important; }
    .single .entry-header h1.entry-title { font-size: 28px !important; }
    .separate-containers .site-main { padding: 24px 20px !important; }
    .separate-containers .inside-article, .inside-article { padding: 24px !important; }
    .entry-content, .entry-summary { font-size: 14px !important; }
    .single .entry-content { font-size: 16px !important; }
    .site-info { padding: 16px 0 !important; }
}

/* ════════════════════════════
   카테고리 드롭다운 메뉴 v2.1
   ════════════════════════════ */
.ch-nav { display: flex; align-items: center; }
.ch-nav-list {
    display: flex !important;
    align-items: center !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
}
.ch-nav-item {
    position: relative !important;
    list-style: none !important;
}
a.ch-nav-link {
    display: block !important;
    padding: 8px 16px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--fg) !important;
    text-decoration: none !important;
    border-radius: 6px !important;
    transition: background 0.15s !important;
}
a.ch-nav-link:hover, a.ch-nav-link.ch-active {
    color: var(--accent) !important;
    background: transparent !important;
    text-decoration: none !important;
}

/* 드롭다운 */
.ch-nav-dropdown {
    display: none !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    background: #fff !important;
    border: 1px solid var(--border) !important;
    border-radius: 12px !important;
    padding: 8px !important;
    min-width: 160px !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.1) !important;
    z-index: 9999 !important;
    list-style: none !important;
    margin: 4px 0 0 0 !important;
}
.ch-nav-item:hover > .ch-nav-dropdown {
    display: block !important;
}
a.ch-nav-drop-link {
    display: block !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #4e5968 !important;
    text-decoration: none !important;
    border-radius: 6px !important;
    transition: background 0.15s !important;
}
a.ch-nav-drop-link:hover, a.ch-nav-drop-link.ch-active {
    background: var(--surface) !important;
    color: var(--accent) !important;
    text-decoration: none !important;
}

/* ════════════════════════════
   드롭다운 메뉴 v2.2
   ════════════════════════════ */
nav.ch-nav {
    display: flex !important;
    justify-content: flex-end !important;
}
ul.ch-nav-list {
    display: flex !important;
    align-items: center !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
li.ch-nav-item {
    position: relative !important;
    list-style: none !important;
}
li.ch-nav-item > a.ch-nav-link {
    display: block !important;
    padding: 8px 16px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--fg) !important;
    text-decoration: none !important;
}
li.ch-nav-item > a.ch-nav-link:hover,
li.ch-nav-item > a.ch-nav-link.ch-active {
    color: var(--accent) !important;
}

/* 서브메뉴 (기본 숨김) */
ul.ch-sub {
    display: none;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 8px;
    min-width: 160px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
    z-index: 99999;
    list-style: none;
    margin: 4px 0 0 0;
}

/* hover로 서브메뉴 표시 */
li.ch-has-sub:hover > ul.ch-sub {
    display: block;
}

ul.ch-sub li a {
    display: block;
    padding: 8px 14px;
    font-size: 14px;
    font-weight: 500;
    color: #4e5968;
    text-decoration: none;
    border-radius: 6px;
    white-space: nowrap;
}
ul.ch-sub li a:hover {
    background: var(--surface);
    color: var(--accent);
    text-decoration: none;
}

/* 드롭다운 왼쪽 정렬 (중앙 대신) */
ul.ch-sub {
    left: 0 !important;
    transform: none !important;
}

/* 빈 카테고리 페이지 */
.ch-empty-category .page-title {
    font-size: 32px !important;
    font-weight: 700 !important;
    margin-bottom: 16px !important;
}
.ch-empty-category .taxonomy-description p {
    font-size: 16px !important;
    color: #4e5968 !important;
    line-height: 1.7 !important;
    margin-bottom: 24px !important;
}
.ch-empty-msg {
    color: var(--muted) !important;
    font-size: 15px !important;
    padding: 40px 0 !important;
    border-top: 1px solid var(--border) !important;
}

/* 푸터 네비 */
.ch-footer-nav {
    margin-bottom: 12px !important;
}
.ch-footer-nav a {
    color: var(--fg) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
}
.ch-footer-nav a:hover {
    color: var(--accent) !important;
}
.ch-footer-copy {
    font-size: 13px !important;
    color: var(--muted) !important;
}

/* 목차 글씨 크기 축소 */
#ez-toc-container .ez-toc-title {
    font-size: 14px !important;
}
#ez-toc-container ul li a {
    font-size: 13px !important;
    line-height: 1.5 !important;
}
#ez-toc-container ul ul li a {
    font-size: 12px !important;
}
#ez-toc-container ul {
    margin: 4px 0 !important;
}
#ez-toc-container li {
    margin-bottom: 2px !important;
}

/* 목차 최종 override */
div#ez-toc-container {
    padding: 16px 20px !important;
    margin-bottom: 24px !important;
}
div#ez-toc-container p.ez-toc-title {
    font-size: 14px !important;
    margin-bottom: 8px !important;
}
div#ez-toc-container nav ul li a {
    font-size: 13px !important;
    line-height: 1.4 !important;
    padding: 2px 0 !important;
}
div#ez-toc-container nav ul ul li a {
    font-size: 12px !important;
}
div#ez-toc-container nav ul {
    margin: 2px 0 !important;
}
div#ez-toc-container nav ul li {
    margin-bottom: 1px !important;
    padding: 0 !important;
}

/* 본문 내 목차 (wp-block 기반) 스타일 */
h2#목차,
h2[id="목차"] {
    font-size: 16px !important;
    font-weight: 700 !important;
    margin-bottom: 8px !important;
    padding-bottom: 8px !important;
    border-bottom: 1px solid var(--border) !important;
}
/* 목차 바로 다음 ul */
h2#목차 + .wp-block-list,
h2[id="목차"] + .wp-block-list,
h2#목차 ~ .wp-block-list:first-of-type {
    font-size: 13px !important;
    line-height: 1.6 !important;
    margin-bottom: 32px !important;
    padding: 16px 20px !important;
    background: var(--surface) !important;
    border-radius: 12px !important;
}
h2#목차 + .wp-block-list li,
h2[id="목차"] + .wp-block-list li {
    margin-bottom: 2px !important;
    padding: 1px 0 !important;
}
h2#목차 + .wp-block-list a,
h2[id="목차"] + .wp-block-list a {
    font-size: 13px !important;
    color: var(--muted) !important;
    text-decoration: none !important;
}
h2#목차 + .wp-block-list a:hover,
h2[id="목차"] + .wp-block-list a:hover {
    color: var(--accent) !important;
}
h2#목차 + .wp-block-list ul a {
    font-size: 12px !important;
}

/* 목차 최종 수정 */
h2#목차 + .wp-block-list,
h2[id="목차"] + .wp-block-list {
    padding: 20px 24px 20px 40px !important;
    font-size: 14px !important;
}
h2#목차 + .wp-block-list a,
h2[id="목차"] + .wp-block-list a {
    font-size: 14px !important;
    color: #4e5968 !important;
}
h2#목차 + .wp-block-list a:hover,
h2[id="목차"] + .wp-block-list a:hover {
    color: #3182f6 !important;
}
h2#목차 + .wp-block-list ul a {
    font-size: 13px !important;
    color: #8b95a1 !important;
}

/* 목차 박스 왼쪽 여백 제거 */
h2#목차 + .wp-block-list,
h2[id="목차"] + .wp-block-list {
    margin-left: 0 !important;
    padding-left: 24px !important;
}
