.admin, .contact, .user-profile, .series-search, .series-show {
    margin-block: auto;
    margin-inline: auto;
    width: min(60rem, 80%);

    h1 {
        color: var(--ardoise-10);
        font-size: 2rem;
        margin-block: 1rem;
        text-align: center;
    }

    .form {
        display: flex;
        flex-direction: column;
        gap: 1rem;
        margin-block: auto;
        margin-inline: auto;
        width: 100%;

        &:has(.form-col) {
            flex-direction: row;

            .form-row {
                flex-direction: column;

                .form-field {
                    &:has(select) {
                        max-width: unset;
                    }
                }
            }
        }

        .form-row {
            display: flex;
            flex-direction: row;
            gap: 1rem;

            &:has(.form-field.full-width) {
                flex-direction: column;
            }

            .form-field {
                flex-shrink: 0;
                flex-grow: 1;

                &:has(select) {
                    max-width: calc(50% - 0.5rem);
                    flex-shrink: 0;
                    flex-grow: 1;
                }

                &.full-width {
                    width: 100%;

                    &:has(select) {
                        max-width: unset;
                        width: 100%;
                    }
                }

                input[type="date"],
                input[type="email"],
                input[type="number"],
                input[type="search"],
                input[type="text"],
                input[type="url"],
                textarea {
                    appearance: none;
                    background-color: var(--ardoise-80);
                    border: 1px solid var(--ardoise-50);
                    border-radius: .25em;
                    color: var(--ardoise-10);
                    padding-block: .25rem;
                    padding-inline: .5rem;
                    width: 100%;
                }

                textarea {
                    min-height: 10rem;
                    resize: vertical;
                }

                label:has(input[type="date"]),
                label:has(input[type="email"]),
                label:has(input[type="search"]),
                label:has(input[type="text"]),
                label:has(select),
                label:has(textarea) {
                    align-items: flex-start;
                    display: flex;
                    flex-direction: column;
                    gap: .25rem;
                }

                label:has(input[type=file]) {
                    gap: 1rem;
                    width: 100%;

                    &.drop-zone {
                        align-items: flex-start;
                        background-color: var(--ardoise-80);
                        border-radius: 0.5rem;
                        border: 2px dashed;
                        display: flex;
                        justify-content: flex-start;
                        padding: 1rem;

                        &:hover {
                            background-color: var(--ardoise-70);
                            border-color: var(--ardoise-50);
                        }
                    }
                }

                label:has(.keyword-list) {
                    display: flex;
                    flex-direction: column;
                    gap: .25rem;
                    position: relative;
                    width: 100%;

                    .input-group {
                        display: flex;
                        gap: .125rem;
                        width: 100%;

                        .keyword-input {
                            appearance: none;
                            background-color: var(--ardoise-80);
                            border: 1px solid var(--ardoise-50);
                            border-radius: .25em;
                            color: var(--ardoise-10);
                            padding-block: .25rem;
                            padding-inline: .5rem;
                            width: 100%;
                        }

                        .and-or {
                            background-color: var(--ardoise-80);
                            border: 1px solid var(--ardoise-50);
                            border-radius: .25em;
                            color: var(--ardoise-10);
                            display: flex;

                            .and, .or {
                                align-items: center;
                                background-color: var(--ardoise-80);
                                border: none;
                                color: var(--ardoise-10);
                                cursor: pointer;
                                display: flex;
                                justify-content: center;
                                padding-block: .25rem;
                                padding-inline: .5rem;
                                width: 50%;

                                &:hover {
                                    background-color: var(--ardoise-70);
                                    color: var(--ardoise-10);
                                }

                                &.active {
                                    background-color: var(--orange-50);
                                    color: var(--orange-90);
                                }
                            }

                            .and {
                                border-radius: calc(.25rem - 1px) 0 0 calc(.25rem - 1px);
                                border-right: 1px solid var(--ardoise-50);
                            }

                            .or {
                                border-radius: 0 calc(.25rem - 1px) calc(.25rem - 1px) 0;
                            }
                        }
                    }

                    .keyword-list {
                        background-color: var(--ardoise-80);
                        border: 1px solid var(--ardoise-50);
                        display: none;
                        left: 0;
                        max-height: 20rem;
                        overflow-y: auto;
                        position: absolute;
                        top: 3.75rem;
                        width: 100%;
                        z-index: 4;

                        &.show {
                            display: block;
                        }

                        .keyword-item {
                            padding-block: .25rem;
                            padding-inline: .5rem;

                            &:hover {
                                background-color: var(--orange-40);
                                color: var(--orange-90);
                            }
                        }
                    }

                    .form-keywords {
                        background-color: var(--ardoise-80);
                        border-radius: .25em;
                        border: 1px solid var(--ardoise-50);
                        display: none;
                        flex-direction: row;
                        flex-wrap: wrap;
                        gap: .25rem;
                        padding: .25rem;
                        width: 100%;

                        &:has(.keyword) {
                            display: flex;
                        }

                        .keyword {
                            background-color: var(--orange-50);
                            border-radius: .25em;
                            color: var(--orange-90);
                            cursor: pointer;
                            font-weight: 300;
                            padding-block: .125rem;
                            padding-inline: .5rem 1.25rem;
                            position: relative;

                            &:hover {
                                background-color: var(--orange-40);
                                color: var(--orange-90);
                            }

                            .close {
                                font-size: 1rem;
                                font-weight: 900;
                                position: absolute;
                                right: .25rem;
                                top: 0;
                            }
                        }
                    }
                }
            }

            button {
                appearance: none;
                background-color: var(--ardoise-60);
                border: none;
                border-radius: .25em;
                color: var(--ardoise-10);
                cursor: pointer;
                font-size: 1rem;
                font-weight: 300;
                padding-block: .5rem;
                padding-inline: 1rem;
            }

            button[type="submit"] {
                background-color: var(--orange-50);
                color: var(--orange-90);
            }

            &:has(button[type="submit"]) {
                align-items: center;
                justify-content: flex-end;
            }
        }

        .form-col {
            display: flex;
            flex-direction: column;
            gap: 1rem;
            justify-content:  flex-start;
            width: 100%;
        }
    }

}

.user-profile {
    .form-field:has(div[class^="preview"]) {
        border: 2px dashed var(--orange-50);
        border-radius: .5em;
        display: flex;
        flex-wrap: wrap;
        gap: 1rem;
        margin-block: 1rem;
        padding: 1rem;
        width: 100%;

        label {
            flex-grow: 1;
            max-width: 50%;
        }

        .preview-avatar-file, .preview-banner-file {
            align-items: center;
            background-color: hsla(from var(--orange-40) h s l / .5);
            border-radius: .5rem;
            cursor: pointer;
            display: flex;
            flex-direction: column;
            gap: 1rem;
            justify-content: center;
            margin-inline: auto;
            max-width: calc(50% - 1rem);
            padding: 1rem;
            text-align: center;
            text-wrap: balance;
        }

        .preview-avatar-file {
            img {
                aspect-ratio: 1 / 1;
                border-radius: 50%;
                border: 2px solid var(--orange-50);
                height: 10rem;
            }
        }

        .preview-banner-file {

            img {
                aspect-ratio: 16 / 9;
                border-radius: .5em;
                border: 2px solid var(--orange-50);
                height: 10rem;
                object-fit: cover;
            }
        }
    }
}

@media (width <= 36rem) {
    .contact, .user-profile, .series-search {
        margin-block-start: 4rem;
        padding-inline: .25rem;
        width: 100%;

        form {
            max-width: 100%;

            .form-row {
                flex-direction: column !important;

                .form-field {
                    &:has(select) {
                        max-width: 100% !important;
                    }
                }
            }
        }
    }
}