.page-title {
    margin: 0;
    font-size: clamp(1.7rem, 3vw, 2.4rem);
}

.page-intro {
    margin: 0.35rem 0 1.25rem;
    color: var(--text-muted);
}

.project-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem;
}

.project-post {
    background: rgba(33, 16, 23, 0.46);
    border: 1px solid rgba(255, 170, 182, 0.2);
    border-radius: var(--radius-md);
    padding: 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.project-post h2 {
    margin: 0;
    font-size: 1.3rem;
}

.project-post p {
    margin: 0;
    color: var(--text-muted);
}

.project-post .date {
    font-size: 0.86rem;
    color: var(--accent-soft);
    margin-bottom: 0.15rem;
}

.project-post a {
    margin-top: auto;
    align-self: flex-start;
    border: 1px solid rgba(255, 170, 182, 0.2);
    border-radius: 999px;
    padding: 0.4rem 0.75rem;
    color: var(--text);
    background: rgba(35, 16, 23, 0.42);
    backdrop-filter: blur(7px);
    -webkit-backdrop-filter: blur(7px);
    transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.project-post:hover,
.project-post:focus-within {
        background: rgba(45, 20, 30, 0.56);
    border-color: rgba(255, 170, 182, 0.34);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
}

.project-post a:hover,
.project-post a:focus-visible {
    background: rgba(255, 56, 79, 0.24);
    border-color: rgba(255, 108, 123, 0.85);
    transform: translateY(-1px) scale(1.04);
}

@media (prefers-reduced-motion: reduce) {
    .project-post a {
        transition: none;
    }

    .project-post a:hover,
    .project-post a:focus-visible {
        transform: none;
    }
}

