﻿.form-column {
    display: flex;
    flex-direction: column;
    row-gap: 1em;
}

.form-column-compact {
    row-gap: 0.5em;
}

.form-label {
    font-size: 1em;
    margin-bottom: 1.25em;
    color: var(--black);
    font-weight: 700;
}

.form-control {
    margin-top: 0.5em;
    height: 2.5em;
    font-weight: 500;
    color: var(--color);
    border-radius: 0.5em;
    border: 1px solid var(--light-grey2);
    padding: 0 1em;
    font-size: 1em;
}

.form-control::placeholder {
    color: var(--light-grey3);
}

.form-control:focus {
    color: var(--color);
    border-color: var(--dark-grey);
    box-shadow: var(--box-shadow);
}

.form-control:disabled {
    background-color: var(--light-grey1);
}

.date-picker {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 2em 2em;
    column-gap: var(--column-gap, 0.625em);
    align-items: center;
}

.date-picker > .icon-button-close {
    display: flex;
    justify-self: flex-end;
}

.date-picker .clear-picker {
    background-color: var(--light-grey2);
    border-radius: 100%;
}

.date-picker-placeholder {
    font-weight: 500;
    color: var(--light-grey2);
    left: 1.1em;
    user-select: none;
    cursor: default;
    pointer-events: none;
}

.date-picker.date-picker-borderless .date-picker-placeholder {
    left: 0;
}

.date-picker.hide-placeholder .date-picker-placeholder {
    display: none;
}

/*.date-picker:not(.hide-placeholder) input {
    color: transparent !important;
}
*/
.date-picker.date-picker-borderless .form-control {
    border: none;
    padding: 0;
    padding-right: 0.3em;
}

.date-picker.date-picker-borderless .form-control:focus {
    box-shadow: none;
}

.date-picker .form-control[value=""] {
    color: transparent;
}

.form-search {
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 0.25em;
    border: 1px solid var(--light-grey2);
    height: 2.5em;
    width: 11.25em;
}

.form-search .form-control {
    border: none;
    height: 100%;
    font-weight: 400;
}

.form-search button {
    height: 100%;
    width: 2.375em;
    flex-shrink: 0;
    border-left: 1px solid var(--light-grey2);
    border-radius: 0 0.25em 0.25em 0;
    background-color: #fff;
    background-image: url("../../img/search.svg");
    background-size: 65%;
    background-position: center;
    background-repeat: no-repeat;
    color: transparent;
}

.form-check-input {
    border: 1px solid var(--light-grey2);
    margin-top: 0;
}

.form-check-input[type=checkbox]:indeterminate {
    background-color: var(--dark-grey);
    border-color: var(--dark-grey);
}

.form-check-input:checked {
    background-color: #000;
    border-color: #000;
}

.form-check-input:focus:not(:checked) {
    border-color: var(--light-grey2);
}

.form-check-input:focus {
    box-shadow: var(--box-shadow);
}

.form-switch .form-check-input {
    user-select: none;
    width: 2.125em;
    height: 1.3125em;
    background-color: var(--dark-grey);
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%28255, 255, 255, 100%29'/%3e%3c/svg%3e");
}

.form-switch .form-check-input:focus {
    box-shadow: var(--box-shadow);
}
/*
.form-switch .form-check-input:focus:not(:checked) {
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%28255, 255, 255, 100%29'/%3e%3c/svg%3e");
}
*/
.form-switch .form-check-input:checked {
    background-color: var(--switch-green);
    border-color: var(--switch-green);
}

.form-select:disabled {
    background-image: none;
}

textarea {
    padding: 0.5em 1em !important;  
    min-height: auto !important;
    height: auto !important;
}

.form-control[type=file] {
    height: auto;
    padding: .375rem .75rem;
}

/* Custom Radio Button Selector */

input[type="radio"]:focus {
    outline: none;
    box-shadow: none; /* For browsers that use shadow instead of outline */
}

input[type="radio"].radio-button {
    appearance: none;
    background-color: var(--white);
    margin: 0;
    font: inherit;
    color: var(--light-blue);
    width: 1.15em;
    height: 1.15em;
    border: 0.15em solid var(--light-grey2);
    border-radius: 50%;
    display: grid;
    place-content: center;
}

/* Scale 0 to hide for now! */
input[type="radio"].radio-button::before {
    content: "";
    width: 0.3em;
    height: 0.3em;
    border-radius: 50%;
    transform: scale(0);
    transition: 120ms transform ease-in-out;
    box-shadow: inset 1em 1em var(--white);
}

input[type="radio"].radio-button:checked {
    background-color: var(--light-blue);
}

input[type="radio"].radio-button:checked::before {
    transform: scale(1);
}

/* Draggable Lists*/

.drag-handle {
    cursor: pointer;
}

.drag-item-grid {
    display: grid;
    grid-template-columns: 2em 1fr 2em 2em 2em;
    justify-items: center;
    align-items: center;
    column-gap: 0.5em;
    width: 100%;
}

.drag-item-grid img {
    width: 1.5em;
    height: 1.5em;
}

.fade-text {
    color: var(--light-grey2);
}

.validation-message {
    font-weight: var(--font-weight);
}

.site-row {
    color: #000;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-left: 30px;
}

.site-row label {
    display: flex;
    column-gap: 1em;
}