.container { width: min(100% - 32px, var(--max-width)); margin: 0 auto; }
.narrow { max-width: 880px; }
.main { padding: 24px 0 72px; }
.page { padding: 48px 0 72px; }
.layout { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 28px; align-items: start; }
.post-layout { grid-template-columns: minmax(0, 1fr) 330px; }
.section-header { display: flex; justify-content: space-between; align-items: end; gap: 16px; margin-bottom: 18px; }
.section-title { font-size: clamp(1.6rem, 3vw, 2.15rem); line-height: 1.05; letter-spacing: -0.06em; }
.section-subtitle { color: var(--muted); }
.cards { display: grid; gap: 18px; }
.sidebar { display: grid; gap: 18px; position: sticky; top: 126px; }
.footer { background: var(--surface); border-top: 1px solid var(--border); padding: 30px 0; color: var(--muted); }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.footer a { font-weight: 850; color: var(--text); }
