/* Homepage — hero composition. */

.home {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 32px;
    gap: 28px;
}

.home-entry {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    text-align: center;
    max-width: 640px;
}

.home-entry-nav {
    display: flex;
    gap: 20px;
    align-items: center;
    justify-content: center;
}

.home-entry-nav a {
    font-size: clamp(13px, 0.5vw + 6px, 14px);
    font-weight: 400;
    color: var(--text-tertiary);
    letter-spacing: 0.02em;
    transition: color var(--dur-hover);
}

.home-entry-nav a:hover {
    color: var(--text);
}

.home-entry-nav a:active {
    color: var(--text);
}

.home-entry-nav a:first-child {
    font-weight: 450;
}

.home-entry-sep {
    width: 1px;
    height: 12px;
    background: var(--border);
}

@media (max-width: 768px) {
    .home {
        padding: 24px 20px;
        gap: 32px;
    }
}

@media (max-width: 640px) {
    .home {
        padding-bottom: 96px;
        gap: 48px;
    }

    .home-entry-nav {
        gap: 14px;
    }

    .home-entry-nav a {
        /* Vertical padding for ≥44px tap height; negative margin
           cancels the layout impact so visual spacing is unchanged. */
        padding: 12px 4px;
        margin: -12px 0;
    }
}
