body { font-family: Georgia, serif; line-height: 1.75; color: #1f2430; margin: 0; background: linear-gradient(180deg, #fffdf9 0%, #fcfcfb 100%); }
a { color: #2457a6; text-decoration: none; }
a:hover { text-decoration: underline; }
.wrap { max-width: 920px; margin: 0 auto; padding: 0 1rem; }
.site-header { border-bottom: 1px solid #ddd; background: rgba(255,255,255,0.96); position: sticky; top: 0; backdrop-filter: blur(8px); }
.header-wrap { display: flex; justify-content: space-between; align-items: center; padding: 1rem 0; }
.site-title { font-size: 1.4rem; font-weight: 700; color: #111; letter-spacing: 0.01em; }
nav a { margin-left: 1rem; }
.hero { padding: 3rem 0 2.2rem; border-bottom: 1px solid #e5e5e5; }
.hero-copy h1 { font-size: clamp(2.4rem, 6vw, 4rem); line-height: 1.02; margin: 0; }
.dek { font-size: 1.12rem; margin: 0.6rem 0 0; max-width: 42rem; color: #313847; }
.eyebrow, .meta { color: #666; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 0.08em; }
.featured { padding: 2rem 0; border-bottom: 1px solid #e5e5e5; }
.featured h2 { font-size: clamp(1.8rem, 3vw, 2.5rem); line-height: 1.1; margin-bottom: 0.4rem; }
.recent-section h2 { margin-top: 1.8rem; }
.post-list { display: grid; gap: 1.5rem; padding: 1.5rem 0 2rem; }
.post-card { padding-bottom: 1.5rem; border-bottom: 1px solid #e5e5e5; }
.post-card h3, .post-card h2 { margin-bottom: 0.35rem; }
.tags { margin-top: 1rem; }
.tag { display: inline-block; padding: 0.2rem 0.55rem; margin: 0 0.35rem 0.35rem 0; background: #eef3fb; border-radius: 999px; font-size: 0.85rem; color: #2457a6; }
.single { padding: 2rem 0; }
.single h1 { font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.06; margin-bottom: 0.3rem; }
.content { font-size: 1.06rem; }
.content img { max-width: 100%; height: auto; border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,0.08); }
.content > p:first-child img { display: block; margin: 0 auto 1.25rem; max-height: 460px; width: auto; }
.content blockquote { margin: 1.5rem 0; padding: 0.1rem 1rem; border-left: 4px solid #d8deeb; color: #495166; background: #f8f9fc; }
.site-footer { border-top: 1px solid #ddd; margin-top: 2rem; background: #fff; }
.footer-wrap { display: flex; justify-content: space-between; gap: 1rem; align-items: center; padding: 1.25rem 1rem 2rem; color: #666; font-size: 0.95rem; }
@media (max-width: 780px) { .header-wrap, .footer-wrap { display: block; } nav { margin-top: 0.75rem; } nav a:first-child { margin-left: 0; } }
