/* custom CTA button for Apollo override */
.contact-btn {
    display: inline-block;
    padding: 8px 14px;
    border-radius: 12px;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid currentColor;
    margin-left: 12px;
}

.contact-btn:hover { opacity: 0.9; }

/* hero CTA spacing */
.hero-cta {
    margin-bottom: 40px;
}

.featured-posts { margin-top: 40px; }
.featured-posts h2 { font-size: 1.4rem; margin-bottom: 14px; }
.cards { display:flex; gap:18px; flex-wrap:wrap; }
.card { width: calc(33% - 12px); border-radius:8px; overflow:hidden; border:1px solid #eee; display:flex; flex-direction:column; background:#fff; }
.card-thumb img { width:100%; height:140px; object-fit:cover; display:block; }
.card-body { padding:12px; flex:1; display:flex; flex-direction:column; }
.card-body h3 { margin:0 0 8px 0; font-size:1.05rem; }
.excerpt { flex:1; color:#444; font-size:0.95rem; margin-bottom:10px; }
.meta .tag { display:inline-block; padding:3px 8px; margin-right:6px; border-radius:999px; font-size:0.75rem; background:#f2f2f2; }
.btn.small { padding:8px 12px; border-radius:8px; text-decoration:none; font-weight:600; }
@media (max-width:900px) {
    .card { width: calc(50% - 9px); }
}
@media (max-width:600px) {
    .card { width: 100%; }
}

.site-footer {
    margin-top: 60px;
    padding: 30px 0;
    border-top: 1px solid #ddd;
    text-align: center;
    font-size: 0.9rem;
}

.footer-links {
    display: flex;
    justify-content: center;
    gap: 18px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}

.footer-links a {
    text-decoration: none;
    font-weight: 500;
}

.footer-links a:hover {
    opacity: 0.7;
}

.footer-note {
    color: #777;
}
