/*
Theme Name: Astra Child
Theme URI: https://wpastra.com/
Description: Astra 자식 테마 — 전면 시각 리디자인(폰트/색/헤더 브랜드/히어로/카드형 글) + 훅. 부모(Astra) 업데이트와 무관하게 안전 유지. 전부 파일 기반이라 파일매니저로 100% 이전됩니다.
Author: PWD Techhub
Template: astra
Version: 2.11.0
Text Domain: astra-child
*/

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700;800&display=swap');

/* =====================================================================
   변수 — 기존 Astra 빨강 브랜드(#DD183B)에 맞춰 통일
   ===================================================================== */
:root {
	--ac-accent:       #DD183B;   /* 브랜드 레드 (Astra global-color-0와 동일) */
	--ac-accent-dark:  #B0122F;
	--ac-accent-soft:  #FFEDE6;   /* 연한 배경 (global-color-4) */
	--ac-ink:          #0F172A;   /* 짙은 배경/히어로 */
	--ac-text:         #2B2B2B;
	--ac-text-soft:    #6B7280;
	--ac-surface:      #FFFFFF;
	--ac-bg:           #FBFAFA;
	--ac-line:         rgba(15, 23, 42, .08);
	--ac-radius:       16px;
	--ac-radius-sm:    10px;
	--ac-shadow:       0 4px 18px rgba(15, 23, 42, .06);
	--ac-shadow-hover: 0 16px 40px rgba(221, 24, 59, .14);
	--ac-ease:         .28s cubic-bezier(.4, 0, .2, 1);
	--ac-content-max:  72ch;
	--ac-font: 'Noto Sans KR', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* =====================================================================
   1) 기본 타이포그래피 — 폰트 즉시 교체(가장 큰 체감)
   ===================================================================== */
body,
button, input, select, textarea,
.ast-container, .entry-title, .site-title,
.main-header-menu, .menu-item, p, li, h1, h2, h3, h4, h5, h6 {
	font-family: var(--ac-font);
}

body {
	color: var(--ac-text);
	background: var(--ac-bg);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	letter-spacing: -0.01em;
}

h1, h2, h3, h4 { line-height: 1.25; letter-spacing: -0.025em; color: var(--ac-ink); font-weight: 800; }
h1 { font-size: clamp(2rem, 4vw, 2.75rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2rem); }
h3 { font-size: 1.35rem; font-weight: 700; }

.entry-content { line-height: 1.8; font-size: 1.02rem; }
.entry-content p { margin-bottom: 1.4em; }
.single .entry-content > p,
.single .entry-content > ul,
.single .entry-content > ol,
.single .entry-content > h2,
.single .entry-content > h3 { max-width: var(--ac-content-max); }
.entry-content h2 { margin-top: 2em; }
.entry-content h3 { margin-top: 1.6em; }

::selection { background: var(--ac-accent); color: #fff; }
img { max-width: 100%; height: auto; }

/* =====================================================================
   2) 링크 & 버튼 — 브랜드 레드, 호버 모션
   ===================================================================== */
a { color: var(--ac-accent); transition: color var(--ac-ease); }
a:hover { color: var(--ac-accent-dark); }

.ast-button, .wp-block-button__link, button, input[type="submit"],
.ast-custom-button, .menu-toggle, .ast-search-submit {
	background: var(--ac-accent) !important;
	color: #fff !important;
	border: none !important;
	border-radius: var(--ac-radius-sm) !important;
	padding: .7em 1.6em !important;
	font-weight: 600 !important;
	transition: transform var(--ac-ease), box-shadow var(--ac-ease), background-color var(--ac-ease) !important;
}
.ast-button:hover, .wp-block-button__link:hover, input[type="submit"]:hover,
.ast-custom-button:hover {
	background: var(--ac-accent-dark) !important;
	transform: translateY(-2px);
	box-shadow: var(--ac-shadow-hover);
}

/* =====================================================================
   3) 헤더 — 브랜드 텍스트 "PWD Techhub" (훅으로 출력) + 메뉴 폴리시
   ===================================================================== */
.site-header { transition: box-shadow var(--ac-ease), background-color var(--ac-ease); }
.ac-scrolled .site-header,
.ac-scrolled .ast-primary-header-bar { box-shadow: 0 2px 18px rgba(15, 23, 42, .09); }

/* 브랜드 텍스트 로고 */
.ac-brand {
	display: inline-flex; align-items: baseline; gap: .12em;
	font-weight: 800; font-size: 1.6rem; letter-spacing: -0.03em;
	color: var(--ac-ink) !important; text-decoration: none; line-height: 1;
}
.ac-brand .ac-brand-accent { color: var(--ac-accent) !important; }
.ac-brand:hover { opacity: .9; }

/* 헤더 메뉴 글자색: 블랙 */
.ast-builder-menu .menu-item > a,
.main-header-menu .menu-item > a,
.main-header-menu .menu-link,
.ast-builder-menu .menu-link { color: #000 !important; }

/* 메뉴 hover 밑줄 슬라이드 */
.main-header-menu .menu-item > a { position: relative; transition: color var(--ac-ease); }
.main-header-menu .menu-item > a::after {
	content: ''; position: absolute; left: 0; bottom: 4px; height: 2px; width: 0;
	background: var(--ac-accent); transition: width var(--ac-ease);
}
.main-header-menu .menu-item:hover > a::after,
.main-header-menu .current-menu-item > a::after { width: 100%; }
.main-header-menu .menu-item:hover > a { color: var(--ac-accent); }

/* =====================================================================
   4) 히어로 (훅 astra_header_after 로 첫 화면에만 출력)
   ===================================================================== */
.ac-hero {
	background:
		radial-gradient(1200px 400px at 80% -10%, rgba(221,24,59,.35), transparent 60%),
		linear-gradient(135deg, #1a0a12 0%, var(--ac-ink) 55%, #1e0c16 100%);
	color: #fff;
	padding: clamp(3.5rem, 9vw, 7rem) 1.5rem;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.ac-hero-inner { max-width: 820px; margin: 0 auto; position: relative; z-index: 1; }
.ac-hero-badge {
	display: inline-block; font-size: .8rem; font-weight: 700; letter-spacing: .08em;
	text-transform: uppercase; color: #fff;
	background: rgba(221, 24, 59, .9); padding: .4em 1em; border-radius: 999px; margin-bottom: 1.4rem;
}
.ac-hero h1 {
	color: #fff; font-size: clamp(2.2rem, 6vw, 4rem); font-weight: 800;
	margin: 0 0 1rem; letter-spacing: -0.04em; line-height: 1.1;
}
.ac-hero h1 .ac-hero-accent {
	background: linear-gradient(90deg, #ff5c7a, var(--ac-accent));
	-webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.ac-hero p { font-size: clamp(1rem, 2.2vw, 1.25rem); color: rgba(255,255,255,.82); margin: 0 auto 2.2rem; max-width: 600px; line-height: 1.7; }
.ac-hero-cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.ac-hero-cta .ac-btn {
	display: inline-flex; align-items: center; gap: .5em;
	padding: .9em 2em; border-radius: var(--ac-radius-sm); font-weight: 700; text-decoration: none;
	transition: transform var(--ac-ease), box-shadow var(--ac-ease), background-color var(--ac-ease);
}
.ac-hero-cta .ac-btn-primary { background: var(--ac-accent); color: #fff; box-shadow: 0 10px 30px rgba(221,24,59,.4); }
.ac-hero-cta .ac-btn-primary:hover { background: #fff; color: var(--ac-accent); transform: translateY(-3px); }
.ac-hero-cta .ac-btn-ghost { background: rgba(255,255,255,.08); color: #fff; border: 1px solid rgba(255,255,255,.25); }
.ac-hero-cta .ac-btn-ghost:hover { background: rgba(255,255,255,.16); transform: translateY(-3px); }

/* 스크롤 앵커 (히어로 버튼 → 글 목록), 스티키 헤더 가림 방지 */
.ac-anchor { display: block; height: 0; scroll-margin-top: 110px; }

/* =====================================================================
   5) 블로그 — 카드형 리스트 (글 하나하나가 전체폭 카드)
   ===================================================================== */
.blog .ast-article-post,
.archive .ast-article-post,
.search-results .ast-article-post,
.ast-separate-container .ast-article-post {
	background: var(--ac-surface) !important;
	border: 1px solid var(--ac-line);
	border-radius: var(--ac-radius) !important;
	box-shadow: var(--ac-shadow);
	padding: 2.25rem !important;
	margin-bottom: 2rem !important;
	position: relative;
	overflow: hidden;
	transition: transform var(--ac-ease), box-shadow var(--ac-ease), border-color var(--ac-ease);
}

.ast-article-post .post-content {
	width: 100% !important;
	max-width: 100% !important;
	padding-left: 0 !important;
}
/* Astra 기본 featured 영역은 숨기고, 훅으로 만든 .ac-card-media 사용 */
.ast-article-post .ast-blog-featured-section { display: none !important; }

/* === 카드 상단 미디어 (대표이미지 / 본문 첫 이미지 / 플레이스홀더) === */
.ac-card-media {
	display: block;
	margin: 0 0 1.4rem;
	border-radius: var(--ac-radius-sm);
	overflow: hidden;
	line-height: 0;
}
.ac-card-media img {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	transition: transform .5s var(--ac-ease);
}
.ac-card-media:hover img { transform: scale(1.05); }

/* 이미지가 전혀 없는 글: 그라데이션 플레이스홀더 */
.ac-card-media--ph {
	display: flex; align-items: center; justify-content: center;
	aspect-ratio: 16 / 9; min-height: 180px;
	background: linear-gradient(135deg, var(--ac-accent), #ff5c7a 55%, var(--ac-ink));
	position: relative;
}
.ac-card-media--ph span { color: rgba(255, 255, 255, .92); font-weight: 800; font-size: 1.2rem; letter-spacing: .02em; z-index: 1; }
.ast-article-post:nth-of-type(3n+2) .ac-card-media--ph { background: linear-gradient(135deg, var(--ac-ink), var(--ac-accent) 80%); }
.ast-article-post:nth-of-type(3n) .ac-card-media--ph { background: linear-gradient(135deg, #ff5c7a, var(--ac-accent-dark) 65%, var(--ac-ink)); }

/* === 카드 1열 리스트 (글 하나하나 전체폭 카드) — 2열 그리드 제거 === */

/* === Recent Comments · Categories(메뉴 위젯) 숨김 === */
.widget_recent_comments,
.widget_categories,
.widget_block:has(.wp-block-latest-comments),
.widget:has(.wp-block-latest-comments),
.widget:has(nav[aria-label="Categories"]) { display: none !important; }
#secondary .wp-block-latest-comments { display: none !important; }

/* === 사이드바 커스텀 위젯 === */
/* 1) 브랜드 소개 카드 */
#secondary .ac-brand-card {
	background: linear-gradient(135deg, var(--ac-ink), var(--ac-accent) 130%);
	color: #fff;
	text-align: center;
}
#secondary .ac-brand-card-logo { font-size: 1.4rem; font-weight: 800; letter-spacing: -0.03em; margin-bottom: .6rem; }
#secondary .ac-brand-card-logo span { color: #ff8fa3; }
#secondary .ac-brand-card p { color: rgba(255,255,255,.82); font-size: .92rem; line-height: 1.65; margin: 0 0 1.1rem; }
#secondary .ac-brand-card-btn {
	display: inline-flex; align-items: center; gap: .4em;
	background: #fff; color: var(--ac-accent) !important;
	padding: .55em 1.3em; border-radius: 999px; font-weight: 700; text-decoration: none;
	transition: transform var(--ac-ease);
}
#secondary .ac-brand-card-btn:hover { transform: translateY(-2px); }

/* 2) 인기 글 (번호 뱃지 + 미니 썸네일) */
#secondary .ac-popular-list { list-style: none; margin: 0; padding: 0; counter-reset: pop; }
#secondary .ac-popular-list li { padding: 0; border: none; margin-bottom: .9rem; }
#secondary .ac-popular-list li:last-child { margin-bottom: 0; }
#secondary .ac-popular-list a { display: flex; align-items: center; gap: .7rem; text-decoration: none; padding: 0; }
#secondary .ac-pop-num {
	flex: 0 0 auto; width: 26px; height: 26px; border-radius: 50%;
	background: var(--ac-accent-soft); color: var(--ac-accent);
	font-weight: 800; font-size: .85rem; display: flex; align-items: center; justify-content: center;
}
#secondary .ac-popular-list a:hover .ac-pop-num { background: var(--ac-accent); color: #fff; }
#secondary .ac-pop-thumb { flex: 0 0 auto; width: 52px; height: 52px; border-radius: 8px; overflow: hidden; }
#secondary .ac-pop-thumb img { width: 100%; height: 100%; object-fit: cover; }
#secondary .ac-pop-thumb--ph { background: linear-gradient(135deg, var(--ac-accent), var(--ac-ink)); }
#secondary .ac-pop-title {
	flex: 1; font-size: .9rem; font-weight: 600; color: var(--ac-text); line-height: 1.4;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
#secondary .ac-popular-list a:hover .ac-pop-title { color: var(--ac-accent); }

/* 3) 태그 클라우드 (알약형) */
#secondary .ac-tags { display: flex; flex-wrap: wrap; gap: .5rem; }
#secondary .ac-tag {
	display: inline-block; font-size: .82rem; font-weight: 600;
	padding: .35em .9em; border-radius: 999px;
	background: var(--ac-accent-soft); color: var(--ac-accent); text-decoration: none;
	transition: background-color var(--ac-ease), color var(--ac-ease), transform var(--ac-ease);
}
#secondary .ac-tag:hover { background: var(--ac-accent); color: #fff; transform: translateY(-2px); }

/* 내용(발췌)을 5줄로 제한 */
.ast-article-post .ast-excerpt-container {
	display: -webkit-box;
	-webkit-line-clamp: 5;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.ast-article-post .ast-excerpt-container p { margin-bottom: 0; }

/* "전체 읽기" 버튼 */
.ac-readmore-wrap { margin-top: 1.9rem; }
.ac-readmore {
	display: inline-flex; align-items: center; gap: .45em;
	background: var(--ac-accent); color: #fff !important;
	padding: .6em 1.4em; border-radius: var(--ac-radius-sm);
	font-weight: 700; text-decoration: none;
	transition: transform var(--ac-ease), box-shadow var(--ac-ease), background-color var(--ac-ease);
}
.ac-readmore:hover {
	background: var(--ac-accent-dark);
	transform: translateY(-2px);
	box-shadow: var(--ac-shadow-hover);
}
.ac-readmore span { transition: transform var(--ac-ease); }
.ac-readmore:hover span { transform: translateX(3px); }
/* 카드 상단 액센트 바 */
.ast-separate-container .ast-article-post::before {
	content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
	background: linear-gradient(90deg, var(--ac-accent), #ff5c7a);
	transform: scaleX(0); transform-origin: left; transition: transform var(--ac-ease);
}
.ast-separate-container .ast-article-post:hover {
	transform: translateY(-6px);
	box-shadow: var(--ac-shadow-hover);
	border-color: transparent;
}
.ast-separate-container .ast-article-post:hover::before { transform: scaleX(1); }

/* 카드 제목 */
.ast-article-post .entry-title { font-size: 1.5rem; font-weight: 800; margin-bottom: .6rem; }
.ast-article-post .entry-title a { color: var(--ac-ink); transition: color var(--ac-ease); }
.ast-article-post .entry-title a:hover { color: var(--ac-accent); }

/* 카테고리 배지 */
.ast-taxonomy-container.cat-links a, .cat-links a {
	display: inline-block; font-size: .72rem; font-weight: 700; letter-spacing: .03em;
	text-transform: uppercase; color: var(--ac-accent) !important;
	background: var(--ac-accent-soft); padding: .28em .8em; border-radius: 999px;
	text-decoration: none; margin: 0 .3em .4em 0; transition: all var(--ac-ease);
}
.ast-taxonomy-container.cat-links a:hover { background: var(--ac-accent); color: #fff !important; }

/* 발췌 & 메타 */
.ast-excerpt-container { color: var(--ac-text-soft); line-height: 1.7; }
.entry-meta, .ast-blog-meta-container .posted-on, .post-meta { color: var(--ac-text-soft); font-size: .85rem; }
.entry-meta a { color: var(--ac-text-soft); }
.entry-meta a:hover { color: var(--ac-accent); }

/* 더보기 버튼 */
.ast-button-wrap .read-more, .ast-button-wrap a {
	display: inline-flex; align-items: center; gap: .4em;
	color: var(--ac-accent) !important; font-weight: 700; text-decoration: none;
	transition: gap var(--ac-ease);
}
.ast-button-wrap a:hover { gap: .8em; }
.ast-button-wrap a::after { content: '→'; }

/* =====================================================================
   6) 단일 글 — featured 이미지 / 인용구
   ===================================================================== */
.single .post-thumb img { border-radius: var(--ac-radius); box-shadow: var(--ac-shadow); }
.entry-content img { border-radius: var(--ac-radius-sm); }
.entry-content blockquote {
	border-left: 4px solid var(--ac-accent);
	background: var(--ac-accent-soft);
	padding: 1.1rem 1.5rem; border-radius: 0 var(--ac-radius-sm) var(--ac-radius-sm) 0;
	font-style: normal; margin: 1.8rem 0;
}

/* =====================================================================
   7) 폼 / 페이지네이션
   ===================================================================== */
input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]), textarea, select {
	border-radius: var(--ac-radius-sm) !important;
	border: 1px solid var(--ac-line);
	transition: border-color var(--ac-ease), box-shadow var(--ac-ease);
}
input:focus, textarea:focus, select:focus {
	outline: none; border-color: var(--ac-accent) !important;
	box-shadow: 0 0 0 3px rgba(221, 24, 59, .15) !important;
}
.ast-pagination a, .page-numbers {
	border-radius: var(--ac-radius-sm); transition: background-color var(--ac-ease), color var(--ac-ease);
}
.page-numbers.current { background: var(--ac-accent); color: #fff; border-color: var(--ac-accent); }

/* =====================================================================
   8) 푸터 폴리시
   ===================================================================== */
.site-footer, .ast-small-footer { border-top: 1px solid var(--ac-line); }
.site-footer a:hover { color: var(--ac-accent); }

/* =====================================================================
   9) 스크롤 등장 효과
   ===================================================================== */
.ac-reveal { opacity: 0; transform: translateY(18px); transition: opacity .55s var(--ac-ease), transform .55s var(--ac-ease); }
.ac-reveal.ac-revealed { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .ac-reveal { opacity: 1; transform: none; transition: none; } html { scroll-behavior: auto; } }

/* =====================================================================
   10) 자동 목차(TOC)
   ===================================================================== */
#ac-toc { background: var(--ac-surface); border: 1px solid var(--ac-line); border-radius: var(--ac-radius); padding: 1.2rem 1.5rem; margin: 0 0 2rem; max-width: var(--ac-content-max); box-shadow: var(--ac-shadow); }
#ac-toc .ac-toc-title { font-weight: 800; margin: 0 0 .6rem; color: var(--ac-ink); }
#ac-toc ul { list-style: none; margin: 0; padding: 0; }
#ac-toc li { margin: .3rem 0; }
#ac-toc .ac-toc-h3 { padding-left: 1rem; font-size: .95em; }
#ac-toc a { text-decoration: none; color: var(--ac-text); }
#ac-toc a:hover { color: var(--ac-accent); text-decoration: underline; }
html { scroll-behavior: smooth; }

/* =====================================================================
   11) 읽기 진행 바 / 맨 위로 / 다크모드 토글
   ===================================================================== */
#ac-reading-bar { position: fixed; top: 0; left: 0; height: 3px; width: 0%; background: linear-gradient(90deg, var(--ac-accent), #ff5c7a); z-index: 99999; transition: width .1s linear; }

#ac-to-top {
	position: fixed; bottom: 24px; right: 24px; width: 46px; height: 46px; border: none; border-radius: 50%;
	cursor: pointer; z-index: 9998; box-shadow: var(--ac-shadow-hover);
	display: flex; align-items: center; justify-content: center; font-size: 18px; line-height: 1;
	background: var(--ac-accent); color: #fff; opacity: 0; pointer-events: none;
	transition: transform var(--ac-ease), opacity var(--ac-ease), background-color var(--ac-ease);
}
#ac-to-top.ac-show { opacity: 1; pointer-events: auto; }
#ac-to-top:hover { transform: translateY(-3px); background: var(--ac-accent-dark); }

/* =====================================================================
   12) 404 도움 링크
   ===================================================================== */
.ac-404-links { text-align: center; margin: 2rem auto; max-width: 520px; }
.ac-404-btns { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; margin-top: 1rem; }

/* =====================================================================
   13) FAQ 아코디언 (<details>) — 자주 묻는 질문 페이지
   ===================================================================== */
.ac-faq details {
	background: var(--ac-surface); border: 1px solid var(--ac-line);
	border-radius: var(--ac-radius-sm); margin-bottom: .9rem; padding: 0 1.3rem;
	box-shadow: var(--ac-shadow); transition: box-shadow var(--ac-ease);
}
.ac-faq details[open] { box-shadow: var(--ac-shadow-hover); }
.ac-faq summary {
	list-style: none; cursor: pointer; font-weight: 700; color: var(--ac-ink);
	padding: 1.1rem 2rem 1.1rem 0; position: relative; font-size: 1.05rem;
}
.ac-faq summary::-webkit-details-marker { display: none; }
.ac-faq summary::after {
	content: '+'; position: absolute; right: 0; top: 50%; transform: translateY(-50%);
	font-size: 1.5rem; color: var(--ac-accent); transition: transform var(--ac-ease);
}
.ac-faq details[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.ac-faq details > p { padding: 0 0 1.2rem; margin: 0; color: var(--ac-text-soft); line-height: 1.75; }

/* 콘텐츠 페이지 보조 스타일 */
.ac-lead { font-size: 1.15rem; color: var(--ac-text-soft); line-height: 1.7; margin-bottom: 1.8rem; }
.ac-cta-row { display: flex; gap: .8rem; flex-wrap: wrap; margin: 2rem 0 .5rem; }

/* =====================================================================
   14) 섹션 여백 / 리듬 (겹침·답답함 해소)
   ===================================================================== */
/* 본문 영역 상하 여백 확보 */
#content.site-content { padding-top: clamp(2rem, 4vw, 3.25rem); padding-bottom: clamp(2.5rem, 5vw, 4rem); }
/* 히어로와 글 목록 사이 간격 */
.ac-hero + #content .ac-anchor { margin-top: .5rem; }
/* 콘텐츠와 사이드바 사이 간격 */
@media (min-width: 922px) {
	#primary { padding-right: 2.5rem; }
}
/* 제목과 본문 사이 호흡 */
.entry-content > :first-child { margin-top: 0; }
.entry-content h2 + p, .entry-content h3 + p { margin-top: .4rem; }

/* =====================================================================
   15) 페이지 본문 — 흰 카드로 박싱 (단색 배경 위 입체감)
   적용 대상: 소개/문의/FAQ 등 일반 페이지(plain container)
   ===================================================================== */
body.page.ast-plain-container .ast-article-single,
body.page.ast-plain-container .entry-content.clear {
	background: var(--ac-surface);
}
body.page.ast-plain-container .ast-article-single {
	max-width: 880px;
	margin: 0 auto;
	padding: clamp(1.8rem, 4vw, 3.5rem);
	border: 1px solid var(--ac-line);
	border-radius: var(--ac-radius);
	box-shadow: var(--ac-shadow);
}
body.page.ast-plain-container .entry-title { margin-bottom: 1.2rem; }
/* 페이지 본문 내부 리스트 가독성 */
body.page .entry-content ul { padding-left: 1.2rem; }
body.page .entry-content li { margin-bottom: .5rem; line-height: 1.7; }
body.page .entry-content h2 { margin-top: 2.2rem; }

/* =====================================================================
   16) 사이드바 — 위젯을 카드로
   ===================================================================== */
/* 위젯 순서 제어 + 검색창 맨 위로 */
#secondary .sidebar-main { display: flex; flex-direction: column; }
#secondary .widget_search { order: -1; }
#secondary .widget {
	background: var(--ac-surface);
	border: 1px solid var(--ac-line);
	border-radius: var(--ac-radius);
	box-shadow: var(--ac-shadow);
	padding: 1.5rem 1.5rem 1.6rem;
	margin-bottom: 1.75rem;
}
#secondary .widget-title,
#secondary .widget .wp-block-heading {
	font-size: 1.05rem; font-weight: 800; color: var(--ac-ink);
	margin: 0 0 1rem; padding-bottom: .6rem; position: relative;
}
#secondary .widget-title::after,
#secondary .widget .wp-block-heading::after {
	content: ''; position: absolute; left: 0; bottom: 0; width: 36px; height: 3px;
	background: var(--ac-accent); border-radius: 3px;
}
#secondary .widget ul { list-style: none; margin: 0; padding: 0; }
#secondary .widget li { padding: .45rem 0; border-bottom: 1px solid var(--ac-line); }
#secondary .widget li:last-child { border-bottom: none; }
#secondary .widget a { color: var(--ac-text); text-decoration: none; transition: color var(--ac-ease), padding-left var(--ac-ease); }
#secondary .widget a:hover { color: var(--ac-accent); padding-left: 4px; }
/* 사이드바 검색 — 라벨/버튼 글자 제거, 돋보기 아이콘 버튼 */
#secondary .wp-block-search__label { display: none !important; }
#secondary .wp-block-search__inside-wrapper { display: flex !important; gap: .5rem; align-items: stretch; }
#secondary .wp-block-search__input {
	flex: 1 1 auto;
	border: 1px solid var(--ac-line) !important;
	border-radius: var(--ac-radius-sm) !important;
	padding: .6em .9em;
}
#secondary .wp-block-search__button {
	flex: 0 0 auto;
	width: 46px !important; min-width: 46px; height: auto; padding: 0 !important;
	font-size: 0 !important; line-height: 0 !important;
	border: none !important;
	border-radius: var(--ac-radius-sm) !important;
	background-color: var(--ac-accent) !important;
	background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='20'%20height='20'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23ffffff'%20stroke-width='2.2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='11'%20cy='11'%20r='7'/%3E%3Cline%20x1='21'%20y1='21'%20x2='16.65'%20y2='16.65'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	cursor: pointer;
	transition: background-color var(--ac-ease), transform var(--ac-ease);
}
#secondary .wp-block-search__button:hover {
	background-color: var(--ac-accent-dark) !important;
	transform: translateY(-1px);
}
/* 버튼 안에 들어갈 수 있는 기존 svg/텍스트 숨김 */
#secondary .wp-block-search__button svg,
#secondary .wp-block-search__button .wp-block-search__button-text { display: none !important; }

/* =====================================================================
   17) 반응형
   ===================================================================== */
@media (max-width: 921px) {
	#primary { padding-right: 0; }
	#secondary { margin-top: 2.5rem; }
}
@media (max-width: 768px) {
	.ast-separate-container .ast-article-post { padding: 1.4rem !important; }
	.ast-article-post .entry-title { font-size: 1.3rem; }
	.entry-content { line-height: 1.72; }
	#ac-to-top { width: 42px; height: 42px; }
	body.page.ast-plain-container .ast-article-single { padding: 1.5rem; }
}
