*, *::before, *::after {
    box-sizing: border-box;
}
:root {
    font-family: sans-serif;
    line-height: 1.6rem;
    scroll-behavior: smooth;
}
body {
    margin: 0;
}

.container {
    max-width: 80rem;
    margin-inline: auto;
    padding-inline: 1rem;
}

header {
    background-color: oklch(0.2518 0.034 233.58);
    nav {
        ul {
            display: flex;
            flex-wrap: wrap;
            list-style: none;
            margin: 0;
            padding: 0;
            margin-inline-start: -1rem;
        }

        a {
            display: inline-block;
            padding-block: 2rem;
            padding-inline: 1rem;
            text-decoration: none;
            color: oklch(1 0 89.876);
        }
    }
}

.cards {
    display: flex;
    flex-wrap: wrap;
    margin-inline-start: -5rem;

    li {
        display: flex;
        flex-direction: column;
        box-shadow: 0 0 .2rem oklch(0 0 0 / .2), 0 0 2rem oklch(0 0 0 / .1);
        flex-basis: 18rem;
        border-radius: 1.25rem;
        list-style: none;
        position: relative;
        margin-inline: 2rem;
        margin-block: 1rem;
        transition: scale .2s ease-in-out, box-shadow .2s ease-in-out;
        overflow: hidden;

        &:hover,
        &:has(:focus-visible) {
            box-shadow: 0 0 .2rem oklch(0 0 0 / .2), 0 0 3rem oklch(0 0 0 / .2);
            scale: 1.05;
        }

        .content {
            padding: 1rem;
        }

        picture {
            order: -1;
        }

        img {
            width: 100%;
        }

    }
}

.overlay-link {
    position: absolute;
    inset: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}


