/* ===== 루나플 블로그 공통 스타일 ===== */
.blog-post { padding: 100px 18px 60px; max-width: 720px; margin: 0 auto; line-height: 1.85; }
.blog-breadcrumb { font-size: 12.5px; color: var(--text-primary, #1a1428); opacity: 0.7; margin-bottom: 14px; }
.blog-breadcrumb a { color: var(--text-accent, #7C3AED); text-decoration: none; }
.blog-post h1 { font-family: 'Noto Serif KR', serif; font-size: 28px; font-weight: 700; line-height: 1.4; margin-bottom: 10px; color: var(--text-primary, #1a1428); }
.blog-meta { font-size: 12.5px; color: var(--text-primary, #1a1428); opacity: 0.65; margin-bottom: 28px; padding-bottom: 18px; border-bottom: 1px solid rgba(124,58,237,0.15); }
.blog-lead { font-size: 16px; line-height: 1.85; color: var(--text-primary, #1a1428); opacity: 0.9; margin-bottom: 28px; padding: 16px 18px; background: rgba(124,58,237,0.06); border-left: 3px solid #A78BFA; border-radius: 8px; }
[data-theme="dark"] .blog-lead { background: rgba(167,139,250,0.10); }
.blog-post h2 { font-family: 'Noto Serif KR', serif; font-size: 20px; font-weight: 700; line-height: 1.5; margin-top: 36px; margin-bottom: 14px; color: var(--text-primary, #1a1428); }
.blog-post h3 { font-size: 17px; font-weight: 700; margin-top: 24px; margin-bottom: 10px; color: var(--text-primary, #1a1428); }
.blog-post p { font-size: 15px; color: var(--text-primary, #1a1428); opacity: 0.9; margin-bottom: 18px; }
.blog-post ul, .blog-post ol { padding-left: 22px; margin-bottom: 22px; }
.blog-post li { font-size: 15px; color: var(--text-primary, #1a1428); opacity: 0.9; margin-bottom: 8px; line-height: 1.8; }
.blog-post strong { color: var(--text-primary, #1a1428); font-weight: 700; }
.blog-post a { color: var(--text-accent, #7C3AED); }
.blog-cta { margin: 40px 0 24px; padding: 24px; background: linear-gradient(135deg, rgba(124,58,237,0.10), rgba(236,72,153,0.06)); border: 1px solid rgba(124,58,237,0.25); border-radius: 16px; text-align: center; }
.blog-cta h3 { font-size: 17px; margin-bottom: 14px; }
.blog-cta-btn { display: inline-block; padding: 13px 28px; background: linear-gradient(135deg,#A78BFA,#7C3AED); color: white; text-decoration: none; border-radius: 12px; font-size: 14.5px; font-weight: 700; box-shadow: 0 6px 20px rgba(124,58,237,0.35); }
.blog-related { margin-top: 36px; padding-top: 22px; border-top: 1px solid rgba(124,58,237,0.15); }
.blog-related h3 { font-size: 16px; margin-bottom: 14px; }
.blog-related a { display: block; padding: 12px 16px; background: var(--bg-card-solid, #FFFFFF); border: 1px solid rgba(124,58,237,0.18); border-radius: 12px; text-decoration: none; color: var(--text-primary, #1a1428); margin-bottom: 8px; font-size: 14px; }
.blog-related a:hover { border-color: rgba(124,58,237,0.4); }
[data-theme="dark"] .blog-related a { background: #1F1A2E; border-color: rgba(167,139,250,0.25); }
