.portraits-page {
    background: var(--bg-color);
    min-height: 100vh;
    min-height: 100svh;
    position: relative;
    display: flex;
    flex-direction: column;
}

.portraits-header {
    position: absolute;
    top: 3vh;
    left: 3vw;
    right: 3vw;
    z-index: 3;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
}

.portraits-name h1 {
    margin: 0;
    font-size: clamp(1rem, 1.5vw, 1.3rem);
    line-height: 1.1;
}

.portraits-name a {
    color: var(--muted-color);
    top: 3vh;
    left: 3vw;
    font-size: clamp(1rem, 1.5vw, 1.3rem);
    font-weight: 700;
}

.portraits-back {
    color: var(--muted-color);
    font-size: clamp(1rem, 1.5vw, 1.3rem);
    font-weight: 700;
    transition: transform 0.35s ease, color 0.35s ease;
}

.portraits-back:hover {
    color: darkred;
    transform: scale(1.08);
}

.portraits-menu {
    position: relative;
    z-index: 2;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 1.8rem;
    padding: 6rem 3rem 3rem;
}

.portraits-link {
    display: inline-block;
    width: fit-content;
    color: var(--secondary-accent);
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 700;
    line-height: 1.05;
    transition: transform 0.45s ease, color 0.45s ease;
    transform-origin: left center;
}

.portraits-link:hover {
    color: var(--text-color);
    transform: skew(-10deg) translateX(18px);
}

.portraits-preview {
    position: fixed;
    inset: 0;
    z-index: 0;
    opacity: 0;
    transition: opacity 0.6s ease;
    pointer-events: none;
}

.portraits-preview img {
    width: 100vw;
    height: 100vh;
    object-fit: cover;
    pointer-events: none;
}

@media (max-width: 768px) {
    .portraits-header {
        top: 2.5vh;
        left: 5vw;
        right: 5vw;
    }

    .portraits-name h1 {
        font-size: clamp(1.1rem, 4.8vw, 1.6rem);
    }

    .portraits-back {
        font-size: clamp(1rem, 4.5vw, 1.4rem);
    }

    .portraits-menu {
        justify-content: flex-start;
        gap: 1.3rem;
        padding: 8rem 1.5rem 2rem;
    }

    .portraits-link {
        font-size: clamp(2rem, 9vw, 3rem);
    }

    .portraits-link:active {
        color: var(--text-color);
    }

    .portraits-preview {
        display: none;
    }
}

.portraits-preview,
.portraits-preview * {
    pointer-events: none;
}