/* +++++++++++++++++++++++++++++++ *\
           INPUT, SELECT
\* +++++++++++++++++++++++++++++++ */
.form-group {
    width: 100%;
    position: relative;
    margin-top: 2.5rem;
    height: fit-content;
}
.form-group input, .form-group select {
    width: 100%;
    padding: 0.75rem;
    border-radius: 0.25rem;
    font-size: 24px;

    outline: none;

    border: none;
    border-bottom: 2px solid var(--color-accent);
}

.form-group label {
    font-size: 24px;
    font-weight: 700;

    position: absolute;
    top: 14px;
    left: 20px;
    transition: 0.6s;
}
  
.form-group input.is-invalid, .form-group select.is-invalid {
    border-color: #dc3545;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 1rem;
    color: var(--color_danger);
}
.form-group input.is-valid {
    border-color: #198754;
    background-color: transparent !important;
}

.form-group input.is-invalid ~ label {
    color: var(--color_danger);
}
  
.form-error-message {
    display: inline-block;
    width: 100%;
    max-width: 100%;
    position: relative;
    z-index: 2;
    background-color: #f8d7da;
    color: #842029;
    border: 1px solid #dc3545;
    padding: 0.375rem 0.75rem;
    border-radius: 0.25rem;
    margin-top: 0.25rem;
}

.form-group input:focus ~ label,
.form-group input.is-invalid ~ label,
.form-group input.is-valid ~ label, 
.form-group input[type="date"] ~label
 {
    transform: translateX(-13px) translateY(-36px);
    font-size: 24px;
    padding: 0 0.25rem;
}


/* +++++++++++++++++++++++++++++++ *\
             CHECKBOX
\* +++++++++++++++++++++++++++++++ */
.form-check {
    color: var(--color_white);
    font-size: 16px;
    font-weight: 600;
    align-items: center;
    line-height: 1;
    
    user-select: none;
    cursor: pointer;

    margin: 0 auto 1rem;
    width: calc(100% - 2rem);
}

@media (min-width: 420px) {
    .form-check {
        font-size: 26px;
    }
}

.form-check label {
    position: relative;
    display: block;
    
    padding: 15px;
    background-color: var(--color-accent);
    
    border-radius: 4px;
    cursor: pointer;
    text-align: center;

    transition: all .3s ease-in-out;
}

.form-check label:hover {
    transform: scale(1.1);
    transition: all .3s ease-in-out;
}
.form-check input {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    padding: 0;
    border: 0;
    height: 1px;
    width: 1px;
    overflow: hidden;
}

.form-check input:checked + label {
    color: var(--color_white);
    background-color: #2c2c2c;
}

.row-container .form-check {
    width: 50%;
    max-width: 100px;
    font-size: 18px;

    display: inline-block;
    margin-top: 2.5rem;
    margin-bottom: 0;
}
.row-container .form-check label {
    background: transparent;
    border: 1px solid var(--color-accent);
    color: var(--color-accent);
}
.row-container .form-check input:checked ~ label {
    background: var(--color-accent);
    color: var(--color_white);

}
/* +++++++++++++++++++++++++++++++ *\
             SELECT
\* +++++++++++++++++++++++++++++++ */
select, select::picker(select) {
    appearance: base-select;
}

select::picker-icon {
    display: none;
}

select::picker(select) {
    border: 1px solid #929292;
    border-radius: 0.25rem;
    padding: 0.5rem;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;

    opacity: 0;
    transform: translateX(100px);
    transition: all .5s allow-discrete;
}
select::picker(select):popover-open {
    opacity: 1;
    transform: translateX(0px);  

    @starting-style {
        opacity: 0;
        transform: translateX(100px);
    }
}
select option, select selectedcontent {
    padding: 0.375rem 0.75rem;
    color: var(--color_primary);
}

select option:hover {
    background-color: var(--color_primary);
    color: var(--color_white);
}


.form-group label.label-static {
    font-size: 18.72px;
    font-weight: 700;
    position: static !important;
}

select .picker {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 640px) {
    select .picker {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (min-width: 768px) {
    select .picker {
        display: inherit;
    }
}
@media (min-width: 992px) {
    select .picker {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (min-width: 1280px) {
    select .picker {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
    }
}