Jake Vanderwerf
3 hours ago 748c931c827c09bc59b776e41d27643af9cac332
forms.css
@@ -1,169 +1,65 @@
/******************************************************************
FORM INPUTS - BASE
******************************************************************/
textarea,
input:is([type=date], [type=number], [type=text], [type=url],
         [type=email], [type=tel], [type=password], [type=search],
         [type=datetime-local], [type=time]) {
    font-family: var(--body);
    font-size: var(--txt-medium);
    color: var(--contrast);
    padding: var(--p-y) var(--p-x);
    border-radius: var(--radius);
    background-color: var(--base);
    outline: 0;
    border: 1px solid var(--base-100);
    border-bottom: 2px solid var(--contrast-200);
    width: 100%;
    max-width: 100%;
    margin: 0 4px;
}
/******************************************************************
FORM INPUTS - STATES
******************************************************************/
textarea:focus,
input:is([type=date], [type=number], [type=text], [type=url],
         [type=email], [type=tel], [type=password], [type=search],
         [type=datetime-local], [type=time]):focus {
    outline: var(--action-50);
    background-color: var(--base-100);
    color: var(--contrast);
}
textarea::placeholder,
input::placeholder {
    font-family: var(--body);
    color: var(--base-200);
}
@media (min-width: 768px) {
    :root {
        --p-y: 1rem;
    }
}
/******************************************************************
SELECT
******************************************************************/
select {
    background: var(--base);
    border: 2px solid var(--base-100);
    border-radius: var(--radius);
    color: var(--contrast);
    cursor: pointer;
    font-family: var(--body);
    font-size: var(--txt-small);
    padding: .5rem 1rem;
    width: 100%;
}
select:disabled {
    background-color: var(--base-50);
    border-color: var(--base-100);
    color: var(--base-200);
    cursor: not-allowed;
}
select option {
    background: var(--base);
    color: var(--contrast);
    padding: .5rem;
}
select option:hover,
select option:focus,
select option:active,
select option:checked {
    background: var(--action-0);
    color: var(--base);
    box-shadow: 0 0 0 100px var(--action-0) inset;
}
select option:checked {
    background: var(--action-0) linear-gradient(0deg, var(--action-0) 0%, var(--action-0) 100%);
    color: var(--base);
}
select:hover {
    border-color: var(--action-0);
}
select:focus {
    border-color: var(--action-0);
}
/******************************************************************
SEARCH & SPECIAL INPUTS
******************************************************************/
input[type=search]:focus + .clear-search {
    opacity: 1;
    cursor: pointer;
}
.search-container .clear-search {
    opacity: 0;
    cursor: default;
}
.search-container .icon.search {
    padding: 4px 8px;
    color: var(--contrast-200);
    --w: 3rem;
}
input[type="search"]::-moz-search-clear-button,
input[type="search"]::-ms-clear,
input[type="search"]::-ms-reveal,
input[type="search"]::search-cancel-button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    display: none;
    visibility: hidden;
}
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
    -webkit-appearance:none;
}
input[type=url] {
    background: var(--linkIcon);
    background-position: .5em;
    background-size: 1em;
    background-repeat: no-repeat;
    padding-left: 2em;
}
/******************************************************************
LABELS & FIELDS
******************************************************************/
.integration .label,
label {
    text-transform: uppercase;
    font-weight: bold;
    margin-bottom: .5rem;
    display: block;
}
.field {
    padding: 2rem 0;
    border: 2px solid var(--base);
    border-left: 0;
    border-right: 0;
    position: relative;
    width: 100%;
    margin: .5em 0;
    padding: .5em 0;
}
    .field + .field {
        border-top: 1px solid rgb(var(--base-200));
    }
.field:has(.has-tooltip) label {
    margin-left: 2rem;
}
    .field .wrapper {
        width: 100%;
        position: relative;
    }
        .field .validation {
            flex-shrink: 0;
            max-width: 0;
            transition: var(--trans-size);
        }
        .field.has-error .validation.error,
        .field.has-success .validation.success {
            max-width: var(--btn);
        }
        .field.has-error .error {
            color: rgb(var(--error));
        }
            .field.has-error input,
            .field.has-error textarea,
            .field.has-error select {
                border-color: rgb(var(--error));
                background-color: var(--errorBack);
            }
                .field.has-error input:focus,
                .field.has-error textarea:focus,
                .field.has-error select:focus {
                    outline-color: rgb(var(--error));
                    box-shadow: rgba(var(--error), .2) var(--shdw);
                }
        .field.has-success .success {
            color: var(--success);
        }
legend {
    padding: 0 1rem;
        .validation-message {
            color: var(--errorText);
            font-size: var(--txt-small);
            margin-top: .25rem;
            display: block;
        }
.field[data-field=post_status] .wrapper {
    --justify: flex-start;
}
.field[data-field=post_status] .btn + label {
    width: var(--chipchip);
    min-height: var(--chipchip);
    padding: 0;
}
    .field[data-field=post_status] .btn:focus + label,
    .field[data-field=post_status] .btn + label:hover {
        color: rgb(var(--action-contrast));
    }
/**********************
DATE & TIME FIELDS
@@ -199,255 +95,33 @@
input:is([type=time], [type=datetime-local], [type=date]) {
    padding: .5rem;
    border: 1px solid var(--contrast-200);
    border: 1px solid rgb(var(--contrast-200));
    border-radius: 4px;
    font-size: 14px;
    min-width: 180px;
    background: var(--base);
    color: var(--contrast);
    background: rgb(var(--base));
    color: rgb(var(--contrast));
    cursor: pointer;
}
.field-input-wrapper input:is([type=time], [type=datetime-local], [type=date]):focus,
.wrapper input:is([type=time], [type=datetime-local], [type=date]):focus,
.time-wrapper input[type=time]:focus,
.datetime-wrapper input[type=datetime-local]:focus,
.date-wrapper input[type=date]:focus {
    border-color: var(--action-0);
    box-shadow: 0 0 0 2px rgba(var(--action-rgb), .1);
    border-color: rgb(var(--action-0));
    box-shadow: 0 0 0 2px rgba(var(--action-0), .1);
}
.field-input-wrapper .icon,
.wrapper .icon,
.time-wrapper .icon,
.datetime-wrapper .icon,
.date-wrapper .icon {
    width: 18px;
    height: 18px;
    background-color: var(--contrast);
    background-color: rgb(var(--contrast));
    opacity: .7;
}
/**********************
SPECIAL FIELDS
**********************/
/*.remove-item {*/
/*    background: none;*/
/*    border: none;*/
/*    padding: .25rem;*/
/*    cursor: pointer;*/
/*    color: #666;*/
/*    border-radius: var(--radius);*/
/*    width: 1.5em;*/
/*    height: 1.5em;*/
/*}*/
/*.remove-item .close {*/
/*    width: .5em;*/
/*    height: .5em;*/
/*}*/
/*.remove-item:hover {*/
/*    color: var(--action-0);*/
/*    background: #fee;*/
/*}*/
/******************************************************************
CHECKBOXES & RADIOS
******************************************************************/
[type=radio],
[type=checkbox],
input.ch {
    position: absolute;
    opacity: 0;
    left: -200vw;
}
[type=radio] + label,
[type=checkbox] + label,
input.ch + label {
    position: relative;
    cursor: pointer;
}
[type=radio] + label:hover,
[type=checkbox] + label:hover {
    color: var(--action-0);
}
[type=radio] + label::before,
[type=checkbox] + label::before,
input.ch + label::before,
[type=radio] + label::after,
[type=checkbox] + label::after,
input.ch + label::after {
    content: '';
    position: absolute;
    top: 50%;
}
[type=radio] + label::after,
[type=checkbox] + label::after,
input.ch + label::after {
    left: 5px;
    transform: translateY(-70%) rotate(45deg);
    width: 5px;
    height: 10px;
    border: solid var(--light-0);
    border-width: 0 2px 2px 0;
    display: none;
}
[type=radio] + label::before,
[type=checkbox] + label::before,
input.ch + label::before {
    left: 0;
    transform: translateY(-50%);
    width: 1rem;
    height: 1rem;
    border: 2px solid var(--contrast-200);
    background-color: var(--base);
    border-radius: var(--radius);
}
[type=radio]:hover + label::before,
[type=checkbox]:hover + label::before,
input.ch:hover + label::before {
    border-color: var(--action-200);
}
[type=radio]:checked + label::before,
[type=checkbox]:checked + label::before,
input.ch:checked + label::before {
    background-color: var(--action-0);
    border-color: var(--action-100);
}
[type=radio]:checked + label::before {
    border-radius: 50%;
}
[type=checkbox]:checked + label::after,
input.ch:checked + label::after {
    display: block;
    left: 5px;
    top: 50%;
    transform: translateY(-70%) rotate(45deg);
    width: .35rem;
    height: .66rem;
    border: solid var(--light-0);
    border-width: 0 2px 2px 0;
}
[type=radio]:disabled + label,
[type=checkbox]:disabled + label,
input.ch:disabled + label {
    cursor: not-allowed;
    background-color: var(--base-50);
    color: var(--base-200);
    border-color: var(--base-200);
}
[type=radio]:disabled + label:hover,
[type=checkbox]:disabled + label:hover,
input.ch:disabled + label:hover {
    background-color: var(--base-50);
    color: var(--base-200);
    border-color: var(--base-200);
}
[type=radio]:disabled + label::before,
[type=checkbox]:disabled + label::before,
input.ch:disabled + label::before {
    border-color: var(--base-200);
}
[type=radio]:not(.btn) + label,
[type=checkbox]:not(.btn) + label,
input.ch + label {
    flex: 1;
    padding-left: 2rem;
    transform-origin: top center;
    will-change: transform;
}
/* Button-style checkboxes/radios */
.btn + label::before,
.btn + label::after {
    display: none;
}
.btn + label {
    --w: 1.2em;
    border: 1px solid var(--base-200);
    border-radius: var(--radius);
    min-width: 2rem;
    min-height: 2rem;
    margin: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
    gap: .5rem;
    color: var(--contrast-200);
    opacity: .8;
}
.radio-options[data-field="post_status"] fieldset {
    display: flex;
    width: 100%;
}
.radio-options[data-field="post_status"] label {
    padding: 0 .5rem;
}
.btn:checked + label {
    border-color: var(--contrast);
    color: var(--contrast);
    opacity: 1;
}
.btn + label:hover {
    color: var(--action-50);
    border-color: var(--action-50);
}
input[hidden] + label,
.btn[hidden] + label {
    display: none!important;
}
.checkbox-options {
    --gap: .5rem 2rem;
}
.checkbox-options label {
    flex: unset!important;
}
.radio-options {
    --gap: .125rem .5rem;
}
.radio-options input:not(.ch) + label::before {
    display: none!important;
}
.radio-options input:not(.ch) + label {
    flex: unset!important;
    padding: .25rem!important;
    border-radius: 4px;
    border: 1px solid var(--base-100);
    color: var(--contrast-200);
    font-weight: normal;
    text-align: center;
}
.radio-options input:not(.ch) + label:hover,
.radio-options input:not(.ch):checked + label {
    border-color: var(--action-0);
    color: var(--action-0);
}
/******************************************************************
QUANTITY FIELD
@@ -464,7 +138,7 @@
}
.quantity:focus-within {
    border-color: var(--action-0);
    border-color: rgb(var(--action-0));
}
.quantity label {
@@ -473,26 +147,26 @@
}
.quantity button {
    background: var(--base);
    background: rgb(var(--base));
    padding: 0;
    width: var(--chip_);
    height: var(--chip_);
    min-height: 0;
    z-index: 0;
    position: relative;
    border: 1px solid var(--base-200);
    color: var(--contrast-200);
    border: 1px solid rgb(var(--base-200));
    color: rgb(var(--contrast-200));
}
.quantity button:hover:not(:disabled) {
    color: var(--action-0);
    border-color: var(--action-0);
    background-color: var(--base);
    color: rgb(var(--action-0));
    border-color: rgb(var(--action-0));
    background-color: rgb(var(--base));
}
.quantity button:active:not(:disabled) {
    background-color: var(--action-0);
    color: var(--light-0);
    background-color: rgb(var(--action-0));
    color: rgb(var(--light-0));
    transform: scale(.95);
}
@@ -503,8 +177,8 @@
.quantity input[type=number] {
    z-index: 1;
    border: 1px solid var(--base-200);
    background: var(--base);
    border: 1px solid rgb(var(--base-200));
    background: rgb(var(--base));
    text-align: center;
    font-size: 1.1rem;
    width: 60px;
@@ -521,7 +195,7 @@
}
.quantity input[type=number]:focus {
    background-color: var(--base-50);
    background-color: rgb(var(--base-50));
}
.quantity button.increase {
@@ -534,142 +208,73 @@
    border-radius: 4px 0 0  4px;
}
/******************************
TABS
******************************/
.tab-content[hidden] {
    display: block!important;
    transform: scaleY(0);
    height: 0;
    overflow: hidden;
}
.tab-content[hidden]:focus-within {
    transform: scaleY(1);
    height:auto;
}
nav.tabs h2 {
    margin: 0!important;
    line-height: 1;
    font-size: var(--txt-medium);
    display: flex;
    color: var(--contrast);
    white-space: nowrap;
    gap: 1rem;
}
nav.tabs .active h2 {
    color: var(--action-contrast);
}
nav.tabs button {
    padding: .75rem 1.5rem;
    border-radius: 0;
    position: relative;
    border: 2px solid var(--action-0);
}
nav.tabs > button:first-of-type {
    border-top-left-radius: var(--radius);
}
nav.tabs > button:last-of-type {
    border-top-right-radius: var(--radius);
}
.tabs > button:hover,
.tabs > button:focus {
    background-color: var(--base-200);
}
.tabs > button::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 3px;
    background-color: var(--action-50);
    transition: width .3s;
}
.tabs > button:hover::after,
.tabs > button.active::after {
    width: 100%;
}
.tabs > button.active::after {
    background-color: var(--action-200);
}
.tabs > button.active {
    background-color: var(--action-0);
    color: var(--action-contrast);
}
.tabs > button.active:hover,
.tabs > button.active:focus {
    background-color: var(--action-100);
}
.tab-content h2 {
    display: none;
}
/************* DONE TO HERE *****/
/** UPLOADER **/
details.uploader .file-upload-container {
    margin: 1rem 0;
    max-width: 100%;
}
@media (min-width: 768px) {
    details.uploader .file-upload-container {
        margin: 1rem var(--mr) 1rem var(--ml);
        max-width: var(--content);
    }
.field.upload {
    position: relative;
}
/*.field.upload .item-grid,*/
/*.field.upload [data-upload-id] {*/
/*    touch-action: none;*/
/*}*/
    .field.upload .progress {
        display: none;
    }
    .field.upload.uploading .progress {
        display: block;
    }
    .field.upload .actions {
        position: absolute;
        top: 0;
        right: 0;
    }
.preview-wrap .item-grid,
.empty-group,
.file-upload-wrapper {
    border: 2px dashed var(--action-0);
    border: 2px dashed rgb(var(--action-0));
    border-radius: 4px;
    padding: 2rem;
    text-align: center;
    transition: all .3s ease;
    background: rgba(var(--action-rgb),var(--op-1));
    background: rgba(var(--action-0),var(--op-1));
    position: relative;
    cursor: pointer;
    user-select: none;
}
.file-upload-wrapper h2 {
    margin: 0!important;
    font-size: var(--txt-large);
}
.empty-group,
.file-upload-wrapper:hover,
.dragover {
    background: rgba(var(--action-rgb),var(--op-2));
    border-color: var(--action-0)!important;
}
    .file-upload-wrapper {
        max-width: var(--content);
        margin: 1rem auto;
    }
    .file-upload-wrapper h2 {
        margin: 0;
        font-size: var(--txt-large);
    }
.file-upload-wrapper input[type="file"] {
    .preview-wrap .item-grid:hover,
    .empty-group:hover,
    .file-upload-wrapper:hover,
    .dragover {
        background: rgba(var(--action-0),var(--op-2));
        border-color: rgb(var(--action-0));
    }
.preview-wrap:has(.item-grid:empty) .selection-controls {
    display: none;
}
.preview-wrap .item-grid {
    min-height: 20vh;
}
    .preview-wrap .item-grid:empty::before {
        content: 'Unsorted images become their own posts.';
        display: block;
    }
.file-upload-wrapper input[type=file] {
    position: absolute;
    left: 0;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
@@ -677,199 +282,145 @@
}
.empty-group p,
.file-upload-text {
    color: var(--contrast);
    margin: 0;
}
.empty-group p strong,
.file-upload-text strong {
    color: var(--action-0);
    text-decoration: underline;
}
.field.upload {
    position: relative;
}
.field.upload:not(.uploading) .progress {
    display: none;
}
.field.upload .actions {
    position: absolute;
    top: 0;
    right: 0;
}
    .empty-group p strong,
    .file-upload-text strong {
        color: rgb(var(--action-0));
        text-decoration: underline;
    }
/** UPLOAD GROUPS **/
.item-grid.groups {
    grid-template-columns: repeat(1, 1fr);
}
.item-grid.group {
    margin-bottom: 0;
}
.item-grid.restore .item,
.item-grid.group .item,
.item-grid.preview .item {
.item-grid:is(.restore,.group,.preview) .item {
    display: block;
}
.item-grid.restore button,
.item-grid.group button,
.item-grid.preview button {
    padding: .25rem .5rem;
}
.item-grid.restore button .icon,
.item-grid.group button .icon,
.item-grid.preview button .icon {
    --w: 1.1em;
}
.item-grid.restore .item .preview > input[type=checkbox]:not(.label-button) + label,
.item-grid.preview .item .preview > input[type=checkbox]:not(.label-button) + label,
.item-grid.group .item .preview > input[type=checkbox]:not(.label-button) + label {
.item-grid:is(.restore,.group,.preview) button {
    padding: .25rem .5rem;
}
.item-grid:is(.restore,.group,.preview) .preview > input[type=checkbox]:not(.label-button) + label {
    padding-left: 0;
    margin: 0;
}
.item-grid.restore .item .preview > input[type=checkbox] + label:before,
.item-grid.preview .item .preview > input[type=checkbox] + label:before,
.item-grid.group .item .preview > input[type=checkbox] + label:before {
    transform: unset;
    top: .5rem;
    left: .5rem;
}
.item-grid.restore .item .preview > input[type=checkbox] + label::after,
.item-grid.preview .item .preview > input[type=checkbox] + label::after,
.item-grid.group .item .preview > input[type=checkbox] + label::after {
    top: .5rem;
    left: .75rem;
    transform: translateY(20%) rotate(45deg);
}
.item-grid.restore .item .item-actions,
.item-grid.preview .item .item-actions,
.item-grid.group .item .item-actions {
    /*.item-grid:is(.restore,.group,.preview) .preview > input[type=checkbox] + label::before {*/
    /*    transform: unset;*/
    /*    top: .5rem;*/
    /*    left: .5rem;*/
    /*}*/
    /*.item-grid:is(.restore,.group,.preview) .preview > input[type=checkbox] + label::after {*/
    /*    top: .5rem;*/
    /*    left: .75rem;*/
    /*    transform: translateY(20%) rotate(45deg);*/
    /*}*/
.item-grid:is(.restore,.group,.preview) .item .item-actions {
    position: absolute;
    top: 0;
    right: 0;
    padding-left: var(--chipchip);
    left: var(--chipchip);
}
.item-grid.restore summary,
.item-grid.preview summary,
.item-grid.group summary {
.item-grid:is(.restore,.group,.preview) summary {
    padding: .5rem;
}
.item-grid.restore:has([type=checkbox]:checked),
.item-grid.preview:has([type=checkbox]:checked),
.item-grid.group:has([type=checkbox]:checked) {
    padding: 1rem;
    background-color: rgba(var(--contrast-rgb),var(--op-1));
}
.item-grid.restore:has([type=checkbox]:checked) .item,
.item-grid.preview:has([type=checkbox]:checked) .item,
.item-grid.group:has([type=checkbox]:checked) .item {
    padding: .75rem;
    opacity: .8;
}
.item-grid.restore:has([type=checkbox]:checked) .item img,
.item-grid.preview:has([type=checkbox]:checked) .item img,
.item-grid.group:has([type=checkbox]:checked) .item img {
    filter: var(--filter);
}
.item-grid.restore:has([type=checkbox]:checked) details,
.item-grid.preview:has([type=checkbox]:checked) details,
.item-grid.group:has([type=checkbox]:checked) details {
    display: none;
}
.item-grid.restore .item:has([type=checkbox]:checked),
.item-grid.preview .item:has([type=checkbox]:checked),
.item-grid.group .item:has([type=checkbox]:checked) {
.item-grid:is(.restore,.group,.preview):has([type=checkbox]:checked){
    padding: .5rem;
    background-color: rgba(var(--action-rgb), var(--op-4));
    background-color: rgba(var(--action-0), var(--op-4));
    opacity: 1;
}
.item-grid:is(.restore,.group,.preview):has([type=checkbox]:checked) img {
    filter: none;
}
    .item-grid:is(.restore,.group,.preview):has([type=checkbox]:checked) .item img {
        filter: var(--filter);
    }
.item-grid:is(.restore,.group,.preview):has([type=checkbox]:checked) details,
.item-grid.preview summary span {
    display: none;
}
.item-grid.restore .item:has([type=checkbox]:checked) img,
.item-grid.preview .item:has([type=checkbox]:checked) img,
.item-grid.group .item:has([type=checkbox]:checked) img {
    filter: none;
}
[type=radio].featured:checked + label .icon-star,
[type=radio].featured + label .icon-star-fi {
[type=radio].featured:not(:checked) + label .icon-star-fi {
    display: none;
}
[type=radio].featured + label .icon-star,
[type=radio].featured:checked + label .icon-star-fi {
    display: inline-block;
}
.restore.restore.item,
.upload.upload.item {
    [type=radio].featured:not(:checked) + label .icon-star,
    [type=radio].featured:checked + label .icon-star-fi {
        display: inline-block;
    }
.item:is(.restore,.upload) {
    border-radius: var(--radius);
    aspect-ratio: unset;
    overflow: hidden;
    background: var(--base);
    border: 1px solid var(--base-200);
    background: rgb(var(--base));
    border: 1px solid rgb(var(--base-200));
}
.restore-item [for="select-item"],
.upload.item [for="select-item"] {
.item:is(.restore,.upload) [for="select-item"] {
    aspect-ratio: 1;
}
.upload.item:has(details[open]) {
.item.upload:has(details[open]) {
    grid-column: 1 / -1;
    padding: .5rem 10%;
    margin: 1rem 0;
    background-color: transparent;
    border: 2px dashed rgb(var(--action-200));
}
.restore.item img,
.upload.item img {
    .item.upload:has(details[open]) details[open] {
        background-color:transparent;
    }
.item:is(.restore,.upload) img {
    transform: scale(1);
    transition: transform var(--trans-base);
}
.restore.item:hover img,
.upload.item:hover img {
    transform: scale(1.02);
    transition: transform var(--trans-base);
}
    .item:is(.upload,.restore):hover img {
        transform: scale(1.02);
    }
.upload-group {
    background-image: var(--dashed-action);
    padding: 5px;
    border-radius: var(--radius);
    background-color: rgba(var(--action-rgb), var(--op-1));
    border-radius:var(--radius);
    background-color: rgba(var(--action-0), var(--op-1));
}
.upload-group .selected .field {
    margin: 0;
}
.upload-group .selection-actions button {
    aspect-ratio: unset;
}
    .upload-group .selected .field {
        margin: 0;
    }
    .upload-group .selection-actions button {
        aspect-ratio: unset;
    }
.submit-uploads {
    position: fixed;
    bottom: 0;
    right: var(--btn_);
    left: var(--btn_);
    z-index: var(--z-6);
    height: var(--btn);
    box-shadow: rgba(var(--base-rgb),var(--op-45)) var(--shdw);
    box-shadow:rgba(var(--base),var(--op-45)) var(--shdw);
    border-radius: var(--radius);
    animation: pulse-color 5s infinite;
    animation-delay: 1s;
    background-color: var(--action-0);
    color: var(--action-contrast);
    background-color: rgb(var(--action-0));
    color: rgb(var(--action-contrast));
}
.submit-uploads:hover {
    background-color: var(--base-200);
    color: var(--contrast-200);
}
    .submit-uploads:hover {
        background-color: rgb(var(--base-200));
        color: rgb(var(--contrast-200));
    }
.empty-group {
    order: -1;
    grid-column: 1 / -1;
    padding: 20px;
    background-image: var(--dashed-action);
    border-radius: var(--radius);
    margin: 10px 0;
    cursor: pointer;
    transition: all var(--trans-base);
    text-align: center;
    background-color: rgba(var(--action-rgb), var(--op-1));
    background-color: rgba(var(--action-0), var(--op-1));
}
.group-display:not([hidden]) ~ .file-upload-container {
@@ -881,42 +432,40 @@
    opacity: .7;
    transform: scale(.95) rotate(3deg);
    z-index: var(--z-7);
    box-shadow: 0 8px 25px rgba(0,0,0,.3);
    box-shadow: 0 8px 25px rgba(var(--contrast), var(--op-2));
}
.dragover {
    background: rgba(var(--action-rgb),var(--op-3))!important;
    border-color: var(--action-0) !important;
    background: rgba(var(--action-0), var(--op-3))!important;
    border-color: rgb(var(--action-0))!important;
    transform: scale(1.05);
    animation: drop-pulse .8s infinite ease-in-out;
}
.drag-preview {
    position: fixed;
    z-index: var(--z-9);
    width: fit-content;
    overflow: visible;
    pointer-events: none;
    opacity: 0.9;
    opacity: .9;
    transform: scale(1.05);
    transition: transform 0.2s ease;
    transition: transform .2s ease;
}
.drag-preview .drag-items {
    width: max-content;
    height: max-content;
    position: relative;
}
.drag-preview .drag-items .drag-item {
    width: 120px;
    height: 120px;
    position: absolute;
    top: 0;
    left: 0;
    background: var(--base);
    border-radius: var(--radius-outer);
    box-shadow: rgba(var(--base-rgb),var(--op-45)) var(--shdw);
}
    .drag-preview .drag-items {
        width: max-content;
        height: max-content;
        position: relative;
    }
    .drag-preview .drag-items .dragi-item {
        width: 120px;
        height: 120px;
        position: absolute;
        top: 0;
        left: 0;
        background: rgb(var(--base));
        border-radius: var(--radius-outer);
        box-shadow: rgba(var(--base),var(--op-45)) var(--shdw);
    }
.drag-preview .drag-items .drag-item:nth-child(1) {
    transform: rotate(-3deg);
@@ -969,8 +518,8 @@
    position: absolute;
    top: -8px;
    right: -8px;
    background: var(--base-200);
    color: var(--contrast);
    background: rgb(var(--base-200));
    color: rgb(var(--contrast));
    border-radius: 50%;
    width: 24px;
    height: 24px;
@@ -979,7 +528,7 @@
    justify-content: center;
    font-size: 12px;
    font-weight: bold;
    box-shadow: rgba(var(--base-rgb),var(--op-45)) var(--shdw);
    box-shadow: rgba(var(--base),var(--op-45)) var(--shdw);
    z-index: var(--z-3);
}
@@ -998,11 +547,11 @@
@keyframes drop-pulse {
    0%, 100% {
        background-color: rgba(var(--action-rgb),var(--op-3));
        background-color: rgba(var(--action-0),var(--op-3));
        transform: scale(1.02);
    }
    50% {
        background-color: var(rgba(var(--action-rgb),var(--op-4)));
        background-color: var(rgba(var(--action-0),var(--op-4)));
        transform: scale(1.04);
    }
}
@@ -1047,7 +596,7 @@
        left: -.5rem;
        right: -.5rem;
        position: absolute;
        background-color: rgba(var(--base-rgb), var(--op-6));
        background-color: rgba(var(--base), var(--op-6));
        filter: blur(5px);
    }
@@ -1071,11 +620,11 @@
        bottom: 0;
        flex-wrap: nowrap;
        overflow: hidden auto;
        background-color: var(--contrast-200);
        color: var(--base);
        background-color: rgb(var(--contrast-200));
        color: rgb(var(--base));
    }
    .group-display .sidebar > .hint {
        color: var(--contrast);
        color: rgb(var(--contrast));
    }
    .group-display .sidebar .header {
        display: none;
@@ -1097,9 +646,9 @@
        position: absolute;
        left: 0;
        right: 0;
        background-color: rgba(var(--base-rgb), var(--op-6));
        background-color: rgba(var(--base), var(--op-6));
        z-index: var(--z-3);
        box-shadow: rgba(var(--base-rgb),var(--op-45)) var(--shdw);
        box-shadow: rgba(var(--base),var(--op-45)) var(--shdw);
    }
    .group-display .item-grid {
        height: 100%;
@@ -1118,7 +667,7 @@
        height: fit-content;
        top: 0;
        z-index: var(--z-3);
        background-color: rgba(var(--action-rgb), var(--op-6));
        background-color: rgba(var(--action-0), var(--op-6));
    }
    .group-display .sidebar .upload-group {
        order: 1;
@@ -1182,8 +731,8 @@
    .preview-wrap .hint {
        position: sticky;
        z-index: var(--z-3);
        box-shadow: rgba(var(--base-rgb),var(--op-45)) var(--shdw);
        background-color: var(--base);
        box-shadow: rgba(var(--base),var(--op-45)) var(--shdw);
        background-color: rgb(var(--base));
        width: 100%;
    }
    .preview-actions {
@@ -1209,50 +758,44 @@
    grid-template-columns: repeat(1, 1fr);
}
/*************************************************************
Tabs in dialog elements
************************************************************/
dialog nav.tabs {
    position: sticky;
    top: 0;
    background-color: var(--base-50);
    z-index: var(--z-6);
    box-shadow: rgba(var(--base-rgb),var(--op-45)) var(--shdw-down);
    margin-bottom: 2rem;
}
/************************************************************
QUILL
************************************************************/
.editor-container .ql-toolbar {
    display: flex;
    background-color: var(--base-50);
    background-color: rgb(var(--base-50));
    justify-content: flex-start;
    flex-wrap: wrap;
    padding: .25rem;
    gap: .5rem 1rem;
    border-top-left-radius: var(--radius);
    border-top-right-radius: var(--radius);
    border-bottom: 4px solid var(--base-50);
    border-bottom: 4px solid rgb(var(--base-50));
}
    .ql-toolbar button {
        min-height: 0;
        padding: .5rem;
    }
.ql-toolbar .ql-formats {
    display: flex;
    gap: .25rem;
}
.editor-container .ql-container {
    --padding: 1rem;
    background-color: var(--base);
    background-color: rgb(var(--base));
    border-bottom-left-radius: var(--radius);
    border-bottom-right-radius: var(--radius);
    height: fit-content;
    padding: 2px;
    border: 1px solid var(--base-200);
    border: 1px solid rgb(var(--base-200));
}
.editor-container .ql-container .ql-editor {
    padding: var(--padding);
    width: 100%;
    height: 100%;
    max-width: 90vw;
}
.ql-editor img {
    max-width: 50%;
@@ -1272,10 +815,10 @@
.ql-tooltip {
    position: absolute;
    transform: translateY(10px);
    background-color: var(--base-100);
    border: 1px solid var(--base);
    box-shadow: 0px 0px 5px rgba(var(--base-rgb),var(--op-6));
    color: var(--contrast);
    background-color: rgb(var(--base-100));
    border: 1px solid rgb(var(--base));
    box-shadow: 0px 0px 5px rgba(var(--base),var(--op-6));
    color: rgb(var(--contrast));
    padding: 5px 12px;
    white-space: nowrap;
}
@@ -1311,677 +854,93 @@
    margin-left: auto;
    min-height: 0;
    height: var(--chipchip);
    background-color: var(--action-0);
    background-color: rgb(var(--action-0));
}
/******************************************************
TAGLIST TAG LIST
******************************************************/
.field.tag-list .row {
    margin-bottom: 1rem;
}
/*******************************************************
UPLOADER
*******************************************************/
/*!* Group actions buttons - more visible *!*/
/*.group-actions {*/
/*    display: flex;*/
/*    gap: 0.5rem;*/
/*}*/
/*.group-actions button {*/
/*    padding: 0.5rem 0.75rem;*/
/*    border-radius: var(--radius);*/
/*    background: rgba(var(--action-rgb), 0.1);*/
/*    border: 1px solid rgba(var(--action-rgb), 0.3);*/
/*    color: var(--action-0);*/
/*    font-size: var(--txt-small);*/
/*    transition: all var(--trans-base);*/
/*    cursor: pointer;*/
/*}*/
/*.group-actions button:hover {*/
/*    background: rgba(var(--action-rgb), 0.2);*/
/*    border-color: var(--action-0);*/
/*    transform: translateY(-1px);*/
/*}*/
/*!* Group item grid - distinct from preview grid *!*/
/*.item-grid.group {*/
/*    background: rgba(255, 255, 255, 0.5);*/
/*    border: 1px solid rgba(var(--action-rgb), 0.15);*/
/*    border-radius: var(--radius);*/
/*    padding: 0.75rem;*/
/*    min-height: 100px;*/
/*}*/
/*!* Group count hint *!*/
/*.group-count {*/
/*    margin-top: 0.5rem;*/
/*    font-size: var(--txt-small);*/
/*    color: var(--contrast-70);*/
/*    font-style: italic;*/
/*}*/
/*!* ============================================================================*/
/*   FIX #2: Improve drag preview styling*/
/*   ============================================================================ *!*/
/*!* Base drag preview *!*/
/*.drag-preview {*/
/*    pointer-events: none;*/
/*    z-index: 10000;*/
/*    position: fixed;*/
/*}*/
/*!* Single item drag preview *!*/
/*.drag-preview:not(.multi-item) {*/
/*    opacity: 0.9;*/
/*    transform: scale(1.05);*/
/*    border-radius: 4px;*/
/*    box-shadow: 0 8px 24px rgba(0,0,0,0.3);*/
/*    border: 2px solid var(--action-0);*/
/*}*/
/*!* Multi-item drag preview container *!*/
/*.drag-preview.multi-item {*/
/*    width: 120px;*/
/*    height: 120px;*/
/*    opacity: 0.95;*/
/*}*/
/*!* Items being dragged - reduce opacity on originals *!*/
/*.upload.item.dragging {*/
/*    opacity: 0.5;*/
/*    transform: scale(0.95);*/
/*    filter: grayscale(50%);*/
/*}*/
/*!* Count badge on multi-item preview *!*/
/*.selection-count-badge {*/
/*    position: absolute;*/
/*    top: -8px;*/
/*    right: -8px;*/
/*    background: var(--action-0);*/
/*    color: white;*/
/*    border-radius: 50%;*/
/*    width: 28px;*/
/*    height: 28px;*/
/*    display: flex;*/
/*    align-items: center;*/
/*    justify-content: center;*/
/*    font-size: 13px;*/
/*    font-weight: bold;*/
/*    box-shadow: 0 3px 12px rgba(0,0,0,0.4);*/
/*    z-index: 20;*/
/*    border: 2px solid white;*/
/*}*/
/*!* ============================================================================*/
/*   FIX #3: Progress bar visibility and styling*/
/*   ============================================================================ *!*/
/*!* Ensure progress bar is visible when needed *!*/
/*.field.upload .progress {*/
/*    display: flex;*/
/*    flex-direction: column;*/
/*    gap: 0.5rem;*/
/*    padding: 1rem;*/
/*    background: rgba(var(--action-rgb), 0.05);*/
/*    border: 1px solid rgba(var(--action-rgb), 0.2);*/
/*    border-radius: var(--radius);*/
/*    margin: 1rem 0;*/
/*    animation: slideDown var(--trans-base);*/
/*}*/
/*.field.upload .progress[hidden] {*/
/*    display: none !important;*/
/*}*/
/*!* Progress bar track *!*/
/*.progress .bar {*/
/*    width: 100%;*/
/*    height: 8px;*/
/*    background: rgba(var(--action-rgb), 0.15);*/
/*    border-radius: 4px;*/
/*    overflow: hidden;*/
/*    position: relative;*/
/*}*/
/*!* Progress bar fill *!*/
/*.progress .fill {*/
/*    height: 100%;*/
/*    background: linear-gradient(90deg,*/
/*    var(--action-0) 0%,*/
/*    var(--action-200) 100%);*/
/*    border-radius: 4px;*/
/*    transition: width 0.3s ease;*/
/*    box-shadow: 0 0 8px rgba(var(--action-rgb), 0.4);*/
/*}*/
/*!* Progress details - styled for row layout with text and count *!*/
/*.progress > .details {*/
/*    font-size: var(--txt-small);*/
/*    color: var(--contrast);*/
/*    display: flex;*/
/*    justify-content: space-between;*/
/*    align-items: center;*/
/*    gap: 1rem;*/
/*}*/
/*.progress > .details .text {*/
/*    font-weight: 500;*/
/*    flex: 1;*/
/*}*/
/*.progress > .details .count {*/
/*    font-weight: 600;*/
/*    color: var(--contrast-70);*/
/*    white-space: nowrap;*/
/*}*/
/*!* Individual item progress - overlay style *!*/
/*.upload.item .progress {*/
/*    position: absolute;*/
/*    top: 0;*/
/*    left: 0;*/
/*    right: 0;*/
/*    bottom: 0;*/
/*    background: rgba(0, 0, 0, 0.75);*/
/*    display: flex;*/
/*    align-items: center;*/
/*    justify-content: center;*/
/*    flex-direction: column;*/
/*    gap: 0.5rem;*/
/*    z-index: var(--z-2);*/
/*    color: white;*/
/*    border-radius: var(--radius);*/
/*    backdrop-filter: blur(2px);*/
/*}*/
/*.upload.item .progress .bar {*/
/*    width: 80%;*/
/*    max-width: 200px;*/
/*}*/
/*.upload.item .progress .fill {*/
/*    background: linear-gradient(90deg, white 0%, rgba(255,255,255,0.8) 100%);*/
/*}*/
/*!* Item progress icon and status text *!*/
/*.upload.item .progress span.icon {*/
/*    font-size: 2rem;*/
/*    display: flex;*/
/*    align-items: center;*/
/*    justify-content: center;*/
/*}*/
/*.upload.item .progress span.details {*/
/*    color: white;*/
/*    font-size: var(--txt-small);*/
/*    font-weight: 500;*/
/*}*/
/*!* ============================================================================*/
/*   FIX #4: Ensure file upload container hides when items exist*/
/*   ============================================================================ *!*/
/*!* Hide uploader when we have uploads *!*/
/*.field.upload:has(.upload.item) .file-upload-container,*/
/*.field.upload[data-has-uploads="true"] .file-upload-container {*/
/*    display: none !important;*/
/*}*/
/*!* Show group display when we have uploads *!*/
/*.field.upload:has(.upload.item) .group-display {*/
/*    display: flex !important;*/
/*}*/
/*!* ============================================================================*/
/*   FIX #5: Improve selection visual feedback*/
/*   ============================================================================ *!*/
/*!* Selected items - more obvious *!*/
/*.upload.item:has(.upload-select:checked) {*/
/*    outline: 3px solid var(--action-0);*/
/*    outline-offset: -3px;*/
/*    box-shadow: 0 0 0 3px rgba(var(--action-rgb), 0.2);*/
/*}*/
/*!* Selection checkbox - always visible on hover or when checked *!*/
/*.upload.item .upload-select + label::before {*/
/*    opacity: 0.7;*/
/*    transition: all var(--trans-base);*/
/*}*/
/*.upload.item:hover .upload-select + label::before,*/
/*.upload.item .upload-select:checked + label::before {*/
/*    opacity: 1;*/
/*    background: rgba(255, 255, 255, 0.9);*/
/*}*/
/*!* Selection controls - more prominent *!*/
/*.selection-actions {*/
/*    display: flex;*/
/*    gap: 1rem;*/
/*    padding: 1rem;*/
/*    background: rgba(var(--action-rgb), 0.1);*/
/*    border: 2px solid rgba(var(--action-rgb), 0.3);*/
/*    border-radius: var(--radius);*/
/*    margin: 1rem 0;*/
/*    align-items: center;*/
/*    justify-content: space-between;*/
/*}*/
/*.selection-info {*/
/*    font-weight: 600;*/
/*    color: var(--action-0);*/
/*}*/
/*.selection-count {*/
/*    font-size: var(--txt-large);*/
/*    color: var(--action-0);*/
/*}*/
/*!* ============================================================================*/
/*   FIX #6: Animations*/
/*   ============================================================================ *!*/
/*@keyframes slideDown {*/
/*    from {*/
/*        opacity: 0;*/
/*        transform: translateY(-10px);*/
/*    }*/
/*    to {*/
/*        opacity: 1;*/
/*        transform: translateY(0);*/
/*    }*/
/*}*/
/*@keyframes fadeOut {*/
/*    from {*/
/*        opacity: 1;*/
/*    }*/
/*    to {*/
/*        opacity: 0;*/
/*    }*/
/*}*/
/*!* Smooth dragover animation *!*/
/*@keyframes drop-pulse {*/
/*    0%, 100% {*/
/*        background-color: rgba(var(--action-rgb), 0.15);*/
/*        transform: scale(1.02);*/
/*    }*/
/*    50% {*/
/*        background-color: rgba(var(--action-rgb), 0.25);*/
/*        transform: scale(1.04);*/
/*    }*/
/*}*/
/*!* ============================================================================*/
/*   FIX #7: Touch-friendly improvements*/
/*   ============================================================================ *!*/
/*@media (hover: none) and (pointer: coarse) {*/
/*    !* Larger touch targets on mobile *!*/
/*    .group-actions button {*/
/*        padding: 0.75rem 1rem;*/
/*        font-size: var(--base);*/
/*    }*/
/*    !* More obvious empty group on touch devices *!*/
/*    .empty-group {*/
/*        padding: 4rem 2rem;*/
/*        min-height: 200px;*/
/*    }*/
/*    !* Selection checkbox always visible on touch *!*/
/*    .upload.item .upload-select + label::before {*/
/*        opacity: 1;*/
/*    }*/
/*}*/
/*!* ============================================================================*/
/*   RESTORATION NOTIFICATION STYLES*/
/*   Add these to forms.css or dash.css*/
/*   ============================================================================ *!*/
/*!* Notification container - fixed overlay *!*/
/*.restore-notification {*/
/*    position: fixed;*/
/*    top: 0;*/
/*    left: 0;*/
/*    right: 0;*/
/*    bottom: 0;*/
/*    background: rgba(0, 0, 0, 0.7);*/
/*    backdrop-filter: blur(4px);*/
/*    z-index: 10000;*/
/*    display: flex;*/
/*    align-items: center;*/
/*    justify-content: center;*/
/*    padding: 2rem;*/
/*    animation: fadeIn 0.3s ease;*/
/*}*/
/*!* Content card *!*/
/*.restore-content {*/
/*    background: var(--base);*/
/*    border-radius: var(--radius);*/
/*    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);*/
/*    max-width: 800px;*/
/*    max-height: 90vh;*/
/*    width: 100%;*/
/*    display: flex;*/
/*    flex-direction: column;*/
/*    overflow: hidden;*/
/*}*/
/*!* Message section *!*/
/*.restore-message {*/
/*    padding: 2rem;*/
/*    border-bottom: 1px solid var(--border);*/
/*}*/
/*.restore-message h4 {*/
/*    margin: 0 0 0.5rem 0;*/
/*    color: var(--action-0);*/
/*    font-size: var(--txt-large);*/
/*}*/
/*.restore-message .restore-details {*/
/*    margin: 0.5rem 0;*/
/*    font-weight: 600;*/
/*    color: var(--contrast);*/
/*}*/
/*.restore-message .hint {*/
/*    margin: 0.5rem 0 0 0;*/
/*    font-size: var(--txt-small);*/
/*    color: var(--contrast-70);*/
/*}*/
/*!* Scrollable field list *!*/
/*.restore-notification .restore-field {*/
/*    padding: 1rem 2rem;*/
/*    border-bottom: 1px solid var(--border);*/
/*    max-height: 400px;*/
/*    overflow-y: auto;*/
/*}*/
/*.restore-notification .restore-field:last-of-type {*/
/*    border-bottom: none;*/
/*}*/
/*.restore-notification .restore-field h3 {*/
/*    margin: 0 0 1rem 0;*/
/*    font-size: var(--base);*/
/*    color: var(--contrast);*/
/*    display: flex;*/
/*    align-items: center;*/
/*    gap: 0.5rem;*/
/*}*/
/*!* Item grid for restore preview *!*/
/*.item-grid.restore {*/
/*    display: grid;*/
/*    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));*/
/*    gap: 1rem;*/
/*    padding: 0;*/
/*}*/
/*!* Restore item *!*/
/*.restore-item {*/
/*    display: flex;*/
/*    flex-direction: column;*/
/*    border: 2px solid var(--border);*/
/*    border-radius: var(--radius);*/
/*    overflow: hidden;*/
/*    cursor: pointer;*/
/*    transition: all var(--trans-base);*/
/*    position: relative;*/
/*}*/
/*.restore-item:hover {*/
/*    border-color: var(--action-0);*/
/*    box-shadow: 0 2px 8px rgba(var(--action-rgb), 0.2);*/
/*}*/
/*!* Checked state *!*/
/*.restore-item:has(.restore-checkbox:checked) {*/
/*    border-color: var(--action-0);*/
/*    background: rgba(var(--action-rgb), 0.05);*/
/*}*/
/*!* Preview section *!*/
/*.restore-item .preview {*/
/*    position: relative;*/
/*    aspect-ratio: 1;*/
/*    background: var(--subtle);*/
/*    display: flex;*/
/*    align-items: center;*/
/*    justify-content: center;*/
/*    overflow: hidden;*/
/*}*/
/*.restore-item .preview img {*/
/*    width: 100%;*/
/*    height: 100%;*/
/*    object-fit: cover;*/
/*}*/
/*.restore-item .preview .image-placeholder {*/
/*    color: var(--contrast-50);*/
/*    display: flex;*/
/*    align-items: center;*/
/*    justify-content: center;*/
/*}*/
/*!* Item info *!*/
/*.restore-item-info {*/
/*    padding: 0.75rem;*/
/*    flex: 1;*/
/*    display: flex;*/
/*    flex-direction: column;*/
/*    gap: 0.25rem;*/
/*}*/
/*.restore-item-info .name {*/
/*    font-size: var(--txt-small);*/
/*    font-weight: 600;*/
/*    color: var(--contrast);*/
/*    overflow: hidden;*/
/*    text-overflow: ellipsis;*/
/*    white-space: nowrap;*/
/*}*/
/*.restore-item-info .restore-item-meta {*/
/*    font-size: var(--tiny);*/
/*    color: var(--contrast-70);*/
/*}*/
/*!* Checkbox controls *!*/
/*.restore-item-controls {*/
/*    position: absolute;*/
/*    top: 0.5rem;*/
/*    right: 0.5rem;*/
/*    z-index: 2;*/
/*}*/
/*.restore-checkbox {*/
/*    width: 24px;*/
/*    height: 24px;*/
/*    cursor: pointer;*/
/*    accent-color: var(--action-0);*/
/*}*/
/*!* Actions section *!*/
/*.restore-actions {*/
/*    padding: 1.5rem 2rem;*/
/*    background: var(--subtle);*/
/*    display: flex;*/
/*    flex-direction: column;*/
/*    gap: 1rem;*/
/*}*/
/*!* Selection controls *!*/
/*.selection-controls {*/
/*    display: flex;*/
/*    gap: 0.5rem;*/
/*    justify-content: flex-start;*/
/*}*/
/*.selection-controls button {*/
/*    padding: 0.5rem 1rem;*/
/*    font-size: var(--txt-small);*/
/*    border: 1px solid var(--border);*/
/*    background: var(--base);*/
/*    color: var(--contrast);*/
/*    border-radius: var(--radius);*/
/*    cursor: pointer;*/
/*    transition: all var(--trans-base);*/
/*}*/
/*.selection-controls button:hover {*/
/*    background: var(--action-0);*/
/*    color: white;*/
/*    border-color: var(--action-0);*/
/*}*/
/*!* Action buttons *!*/
/*.action-buttons {*/
/*    display: flex;*/
/*    gap: 0.75rem;*/
/*    justify-content: flex-end;*/
/*    flex-wrap: wrap;*/
/*}*/
/*.action-buttons button {*/
/*    padding: 0.75rem 1.5rem;*/
/*    font-size: var(--base);*/
/*    font-weight: 600;*/
/*    border: none;*/
/*    border-radius: var(--radius);*/
/*    cursor: pointer;*/
/*    transition: all var(--trans-base);*/
/*    display: flex;*/
/*    align-items: center;*/
/*    gap: 0.5rem;*/
/*}*/
/*!* Restore button - primary action *!*/
/*.restore-selected {*/
/*    background: var(--action-0);*/
/*    color: white;*/
/*}*/
/*.restore-selected:hover {*/
/*    background: var(--action-200);*/
/*    transform: translateY(-1px);*/
/*    box-shadow: 0 4px 12px rgba(var(--action-rgb), 0.3);*/
/*}*/
/*!* Scrap cache button - destructive action *!*/
/*.restart-uploads {*/
/*    background: var(--danger);*/
/*    color: white;*/
/*}*/
/*.restart-uploads:hover {*/
/*    background: var(--danger-dark);*/
/*    transform: translateY(-1px);*/
/*}*/
/*!* Dismiss button - secondary action *!*/
/*.dismiss-cache-check {*/
/*    background: transparent;*/
/*    color: var(--contrast);*/
/*    border: 1px solid var(--border);*/
/*}*/
/*.dismiss-cache-check:hover {*/
/*    background: var(--subtle);*/
/*}*/
/*!* Mobile responsive *!*/
/*@media (max-width: 768px) {*/
/*    .restore-notification {*/
/*        padding: 1rem;*/
/*    }*/
/*    .restore-content {*/
/*        max-height: 95vh;*/
/*    }*/
/*    .restore-message {*/
/*        padding: 1.5rem;*/
/*    }*/
/*    .restore-notification .restore-field {*/
/*        padding: 1rem;*/
/*    }*/
/*    .item-grid.restore {*/
/*        grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));*/
/*        gap: 0.75rem;*/
/*    }*/
/*    .action-buttons {*/
/*        flex-direction: column;*/
/*    }*/
/*    .action-buttons button {*/
/*        width: 100%;*/
/*        justify-content: center;*/
/*    }*/
/*}*/
/*!* Animation *!*/
/*@keyframes fadeIn {*/
/*    from {*/
/*        opacity: 0;*/
/*    }*/
/*    to {*/
/*        opacity: 1;*/
/*    }*/
/*}*/
/*!* Scrollbar styling for restore field list *!*/
/*.restore-notification .restore-field::-webkit-scrollbar {*/
/*    width: 8px;*/
/*}*/
/*.restore-notification .restore-field::-webkit-scrollbar-track {*/
/*    background: var(--subtle);*/
/*}*/
/*.restore-notification .restore-field::-webkit-scrollbar-thumb {*/
/*    background: var(--border);*/
/*    border-radius: 4px;*/
/*}*/
/*.restore-notification .restore-field::-webkit-scrollbar-thumb:hover {*/
/*    background: var(--contrast-50);*/
/*}*/
/***************************
FORMS
 */
/* Stepped Form Container */
form {
    --step-size: 2.5rem;
.field.tag-list .row .field {
    flex: 1;
    min-width: 150px;
    margin: 0;
}
.field.tag-list .tag .add-tag-item {
    flex-shrink: 0;
    white-space: nowrap;
    margin-top: calc(var(--txt-medium) + 1rem);
}
.field.tag-list .tag-items {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
    min-height: 2rem;
}
.field.tag-list .tag-item {
    background: rgb(var(--base-200));
    padding: 0.4rem 0.75rem;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    line-height: 1.2;
}
.field.tag-list .tag-item:hover {
    background: rgb(var(--base-100));
}
.field.tag-list .tag-label {
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.field.tag-list .remove-tag {
    min-height: 0;
    padding: .25rem;
    color: rgb(var(--contrast));
    transition: transform 0.2s;
    box-shadow: none;
}
.field.tag-list .remove-tag:hover {
    transform: scale(1.2);
}
@media (max-width: 768px) {
    .field.tag-list .tag {
        flex-direction: column;
        align-items: stretch;
    }
    .field.tag-list .tag .field {
        min-width: 100%;
    }
}
/* Progress Bar Styling */
.form-progress {
    padding: 0 1rem;
}
.form-progress .progress {
    background: var(--base-100);
    background: rgb(var(--base-100));
    border-radius: var(--radius);
    padding: 1rem;
}
.form-progress .bar {
    height: 6px;
    background: var(--base-200);
    background: rgb(var(--base-200));
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 0.5rem;
@@ -1989,7 +948,7 @@
.form-progress .fill {
    height: 100%;
    background: linear-gradient(90deg, var(--action-0), var(--action-200));
    background: linear-gradient(90deg, rgb(var(--action-0)), rgb(var(--action-200)));
    width: 0%;
    transition: width 0.4s ease;
    border-radius: 3px;
@@ -1998,7 +957,7 @@
.form-progress .step-text {
    font-size: var(--txt-small);
    font-weight: 600;
    color: var(--contrast-200);
    color: rgb(var(--contrast-200));
}
/* Stepped Tabs Styling */
@@ -2028,28 +987,28 @@
    position: absolute;
    left: 0;
    top: 0;
    background: var(--base-200);
    color: var(--contrast-50);
    background: rgb(var(--base-200));
    color: rgb(var(--contrast-50));
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: var(--txt-small);
    border: 3px solid var(--base);
    border: 3px solid rgb(var(--base));
}
/* Pending Step */
form nav.tabs button.pending .step-number {
    background: var(--base-100);
    color: var(--contrast-200);
    background: rgb(var(--base-100));
    color: rgb(var(--contrast-200));
}
/* Current Step */
form nav.tabs button.current .step-number,
form nav.tabs button.active .step-number {
    background: var(--action-0);
    color: var(--action-contrast);
    border-color: var(--action-200);
    background: rgb(var(--action-0));
    color: rgb(var(--action-contrast));
    border-color: rgb(var(--action-200));
}
/* Completed Step */
@@ -2067,41 +1026,25 @@
}
form nav.tabs button.completed h2 {
    color: var(--contrast-200);
    color: rgb(var(--contrast-200));
}
/* Step Navigation Buttons */
.step-navigation {
    margin-top: 2rem;
    padding-top: 2rem;
    border-top: 1px solid var(--base-200);
    border-top: 1px solid rgb(var(--base-200));
    gap: 1rem;
}
.step-navigation .prev-step {
    background: var(--base-100);
    background: rgb(var(--base-100));
}
.step-navigation .next-step,
.step-navigation button[type="submit"] {
    margin-left: auto;
}
/* Error state for required fields */
.field input.error,
.field textarea.error,
.field select.error {
    border-color: var(--errorBack);
}
.error-message {
    color: var(--errorText);
    font-size: var(--txt-small);
    margin-top: 0.25rem;
    display: block;
}
/* Mobile responsiveness */
@media (max-width: 768px) {
    form nav.tabs button {
        min-width: 80px;
@@ -2116,96 +1059,20 @@
        --step-size: 2rem;
    }
}
/**** VALIDATION ******/
/* Field Input Wrapper - for positioning icon */
.field-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.5rem;
/************************************************
FEEDBACK ERROR SUCCESS STATE
************************************************/
.field input.error,
.field textarea.error,
.field select.error {
    border-color: var(--errorBack);
}
.field-input-wrapper input,
.field-input-wrapper textarea,
.field-input-wrapper select {
    flex: 1;
}
/* Validation Icon */
.validation-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    animation: scaleIn 0.3s ease;
    --w: 1.25rem;
}
.validation-icon.error {
    color: var(--error);
}
.validation-icon.success {
    color: var(--success);
}
@keyframes scaleIn {
    from {
        transform: scale(0);
        opacity: 0;
    }
    to {
        transform: scale(1);
        opacity: 1;
    }
}
/* Validation Message */
.validation-message {
    color: var(--error-0);
.error-message {
    color: var(--errorText);
    font-size: var(--txt-small);
    margin-top: 0.25rem;
    display: block;
    animation: slideDown 0.2s ease;
}
@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-4px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
/* Error State */
.field.has-error input,
.field.has-error textarea,
.field.has-error select {
    border-color: var(--error);
    background-color: var(--errorBack)
}
.field.has-error input:focus,
.field.has-error textarea:focus,
.field.has-error select:focus {
    outline-color: var(--error);
    box-shadow: 0 0 0 3px rgba(var(--error-rgb), 0.2);
}
/* Success State */
.field.has-success input,
.field.has-success textarea,
.field.has-success select {
    border-color: var(--success);
}
/* Required Asterisk */
.field label .required {
    color: var(--error);
    margin-left: 0.25rem;
}
/*************************************************************
@@ -2215,7 +1082,7 @@
    padding: 2rem;
    border-radius: 8px;
    margin-top: 2rem;
    border: 2px dashed var(--contrast-200);
    border: 2px dashed rgb(var(--contrast-200));
}
.form-summary .message {
@@ -2233,7 +1100,7 @@
    content: '';
    width: 67%;
    height: 1px;
    border-bottom: 1px solid var(--base-200);
    border-bottom: 1px solid rgb(var(--base-200));
}
.form-summary h2 {
@@ -2241,11 +1108,11 @@
}
.form-summary h4 {
    background-color: var(--base-100);
    background-color: rgb(var(--base-100));
    padding: .5rem 2rem;
    position: relative;
    left: -2rem;
    color: var(--contrast-200);
    color: rgb(var(--contrast-200));
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
@@ -2259,7 +1126,7 @@
.repeater-summary,
.group-summary {
    background: var(--base-100);
    background: rgb(var(--base-100));
    padding: 1rem;
    border-radius: 4px;
    margin-top: 0.5rem;
@@ -2273,204 +1140,107 @@
    margin-bottom: 0;
}
.ql-toolbar button {
    min-height: 0;
    padding: .5rem;
}
.success-message {
    color: var(--success);
    background-color: var(--successBack);
    border: 1px solid var(--success);
    padding: 0.75rem 1rem;
.selected-item {
    border: 1px solid rgb(var(--base-200));
    border-radius: var(--radius);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: var(--txt-x-small);
    background-color: rgb(var(--base));
    padding: .25rem .5rem;
}
    .selected-item button {
        --w: .5em;
        min-height: 1em;
        width: 1em;
        padding: 0;
    }
.selector .selected-items,
.selector .auto-wrapper {
    flex: 1;
    width: 100%;
}
.success-message .success-icon {
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
/** STATUS **/
.fstatus {
    z-index: var(--z-5);
    background-color: rgba(var(--base), var(--op-6));
    border-radius: var(--radius);
    padding: 0 .5rem;
    position: fixed;
    right: .5rem;
    top: var(--btnbtn);
    --w: 1em;
    box-shadow: rgba(var(--base),var(--op-6)) var(--shdw);
    --wrap: nowrap;
    --gap: 1rem;
}
    .fstatus .spinner {
        display: none;
    }
    .fstatus.loading .spinner {
        display: inline-block;
    }
    .fstatus p {
        margin: 0;
        padding: .25rem;
    }
.success-box {
    background-color: var(--successBack);
    border: 2px solid var(--success);
    padding: 1.5rem;
    border-radius: var(--radius-outer);
    margin-bottom: 1rem;
    text-align: center;
}
.success-box h3 {
    color: var(--success);
    margin-bottom: 0.5rem;
}
.success-box p {
    margin: 0.5rem 0;
}
/* Form success state */
.form-success {
    opacity: 0.9;
}
/* Hide form fields after success (optional) */
.form-success .field:not(.form-success-message):not(.success-box) {
/** RESTORE UPLOADS **/
.restore-uploads .item-grid.group .field.group,
.restore-uploads .upload-group .selection-actions {
    display: none;
}
/* Keep submit button visible but disabled */
.form-success button[type="submit"] {
    opacity: 0.6;
    pointer-events: none;
.upload-group .item-grid.group {
    grid-template-columns: repeat(2, 1fr);
}
.restore-uploads .item-grid.group {
    grid-template-columns: repeat(3, 1fr);
}
/* Error states */
.field-error input,
.field-error textarea,
.field-error select {
    border-color: var(--error);
fieldset {
    width: 100%;
    border-color: rgb(var(--base-200));
}
.error-message {
    color: var(--error);
    font-size: var(--txt-small);
    margin-top: 0.25rem;
    display: block;
}
.form-error {
    background-color: var(--errorBack);
    border: 1px solid var(--error);
    padding: 0.75rem;
    border-radius: var(--radius);
    margin-bottom: 1rem;
}
/* Success states */
.has-success input,
.has-success textarea,
.has-success select {
    border-color: var(--success);
}
.form-error {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.form-error .error-icon {
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
}
.invite details {
    margin-bottom: 1.5rem;
}
/*******************************
Tag Field
 */
/* Tag List Field */
.field.tag-list .row {
    margin-bottom: 1rem;
}
.field.tag-list .row .field {
    flex: 1;
    min-width: 150px;
    margin: 0;
}
.field.tag-list .tag .add-tag-item {
    flex-shrink: 0;
    white-space: nowrap;
    margin-top: calc(var(--txt-medium) + 1rem);
}
.field.tag-list .tag-items {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
    min-height: 2rem;
}
.field.tag-list .tag-item {
    background: var(--base-200);
    padding: 0.4rem 0.75rem;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    line-height: 1.2;
}
.field.tag-list .tag-item:hover {
    background: var(--base-100);
}
.field.tag-list .tag-label {
    max-width: 300px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.field.tag-list .remove-tag {
    min-height: 0;
    padding: .25rem;
    color: var(--contrast);
    transition: transform 0.2s;
    box-shadow: none;
}
.field.tag-list .remove-tag:hover {
    transform: scale(1.2);
}
@media (max-width: 768px) {
    .field.tag-list .tag {
        flex-direction: column;
        align-items: stretch;
    }
    .field.tag-list .tag .field {
        min-width: 100%;
    }
}
.pendingChanges {
/** RESTORE FORM **/
.restore-form.restore-form[hidden] {
    display: block!important;
    position: fixed;
    bottom: var(--btn);
    right: var(--btn_);
    margin-right: 1rem;
    padding: 1rem;
    border-radius: var(--radius);
    background-color: rgba(var(--base-rgb),var(--op-6));
    z-index: var(--z-6);
    width: 50vw;
    animation: fadeInSlideUp 0.5s ease-out forwards;
    bottom: var(--offScreen);
    right: var(--btnbtn);
    transition: bottom var(--trans-base);
    transition-duration: 2s;
}
    .pendingChanges button {
        min-height: 0;
        width: calc(50% - .7rem);
        padding: .35rem;
    .restore-form.restore-form:not([hidden]) {
        width: 50vw;
        padding: 1rem;
        z-index: var(--z-7);
        background-color: rgba(var(--base), var(--op-6));
        border-radius: var(--radius);
        box-shadow: rgba(var(--action-0), var(--op-6)) var(--shdw);
        position: fixed;
        right: var(--btnbtn);
        bottom: 0;
        transition: bottom var(--trans-base);
    }
@keyframes fadeInSlideUp {
    from {
        opacity: 0;
        transform: translateY(20px); /* Start 20px below its final position */
    .restore-form h3 {
        font-size: var(--txt-medium);
    }
    to {
        opacity: 1;
        transform: translateY(0); /* End at its normal position */
        body:has(nav.fixed.bottom) .restore-form.restore-form:not([hidden]) {
            bottom: var(--btn);
        }
    .restore-form .actions {
        display: flex;
        width: 100%;
    }
}
    .restore-form .actions button {
        min-height: var(--chip);
        font-size: var(--txt-x-small);
        width: 100%;
    }