/* Forms */
form {
    display: flex;
    flex-direction: column;
    gap: 2rem;

    input, select {
        width: 100%;
        background-color: transparent;
        appearance: none;
        border: 1px solid var(--white);
        border-radius: 0.25rem;
        color: var(--white);
        padding: 0 1rem;
        min-height: 3.5rem;
        outline: none;
        cursor: pointer;
        display: flex;
        align-items: center;
        line-height: 100%;

        &:focus {
            border-color: var(--brown);
        }
    }

    select {
        background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23ffffff%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E");
        background-repeat: no-repeat;
        background-position: right 1rem top 50%;
        background-size: 0.65rem auto;
        padding-right: 2rem;
    }

    .field {
        display: flex;
        flex-direction: column;
        gap: 1rem;
    }

    .nested-fields {
        display: flex;
        flex-direction: column;
        gap: 1rem;

        .field {
            display: grid;
            grid-template-columns: 1fr 2fr auto;
            gap: 0.5rem;
        }
    }

    .file-uploader {
        width: 100%;
        aspect-ratio: 1/1;
        border: 0.1rem solid var(--white);
        border-radius: 0.25rem;
        display: grid;
        place-items: center;
        position: relative;

        .placeholder {
            position: absolute;
        }

        img {
            width: 100%;
        }

        &.is-dragging {
            border: 0.1rem solid var(--brown);
            border-radius: 0.25rem;
        }
    }

    .episode, .file-uploader {
        img {
            position: absolute;
            width: 100%;
            height: 100%;
            object-fit: contain;
            object-position: center;
            z-index: 0;
        }

        img[src=""] {
            display: none;
        }

        &:has(img[src=""]) {
            .placeholder {
                display: grid;
            }
        }

        .placeholder {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            display: none;
            place-items: center;
            background-color: rgba(0,0,0,0.5);
        }
    }

    .episode {
        &.is-dragging {
            .placeholder {
                border: 0.1rem solid var(--brown);
                border-radius: var(--border-radius);
            }
        }
    }

    trix-toolbar {
        .trix-button {
            background-color: var(--white);
        }

        .trix-button-group {
            margin-bottom: 0;
        }
    }

    .toggle-slider {
        position: relative;
        display: flex;
        align-items: center;
        margin-top: 0.25rem;

        .toggle-label {
            display: flex;
            align-items: center;
            gap: 10px;
            cursor: pointer;

            .toggle-checkbox {
                opacity: 0;
                position: absolute;

                &:focus + .slider {
                    outline: 2px solid var(--brown);
                }

                &:checked + .slider:before {
                    background-color: var(--brown);
                }

                &:checked + .slider:before {
                    transform: translateX(20px);
                }
            }

            .slider {
                position: relative;
                width: 42px;
                height: 22px;
                background-color: black;
                border-radius: 20px;
                transition: background-color 0.3s;
                border: 1px solid var(--white);

                &:before {
                    content: '';
                    position: absolute;
                    top: 2px;
                    left: 2px;
                    width: 16px;
                    height: 16px;
                    background-color: var(--white);
                    border-radius: 50%;
                    transition: transform 0.3s;
                    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
                }
            }
        }
    }

}