From 623a61edebdb63a6f93aad7f3e233911624cf24b Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Mon, 20 Oct 2025 18:13:31 +0000
Subject: [PATCH] =Merging

---
 forms.css | 1485 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 1,473 insertions(+), 12 deletions(-)

diff --git a/forms.css b/forms.css
index 0e4962c..3e57890 100644
--- a/forms.css
+++ b/forms.css
@@ -8,6 +8,10 @@
         max-width: var(--maxWidth);
     }
 }
+/*.field.upload .item-grid,*/
+/*.field.upload [data-upload-id] {*/
+/*    touch-action: none;*/
+/*}*/
 
 .file-upload-wrapper {
     border: 2px dashed var(--action-0);
@@ -15,7 +19,7 @@
     padding: 2rem;
     text-align: center;
     transition: all .3s ease;
-    background: var(--action-rgb-subtle);
+    background: rgba(var(--action-rgb),var(--rgb-subtle));
     position: relative;
     cursor: pointer;
 }
@@ -26,7 +30,7 @@
 
 .file-upload-wrapper:hover,
 .dragover {
-    background: var(--action-rgb-subtle-hover);
+    background: rgba(var(--action-rgb),var(--rgb-subtle-hover));
     border-color: var(--action-0)!important;
 }
 
@@ -51,21 +55,521 @@
     text-decoration: underline;
 }
 
-.field.image:has(.upload-item) .file-upload-container {
+.field.upload:has(.upload-item) .file-upload-container {
     display: none;
 }
 
-.field.image {
+.field.upload {
     position: relative;
 }
-.field.image:not(.uploading) .progress {
+.field.upload:not(.uploading) .progress {
     display: none;
 }
-.field.image .actions {
+.field.upload .actions {
     position: absolute;
     top: 0;
     right: 0;
 }
+.item-grid.restore,
+.item-grid.group,
+.item-grid.preview {
+    grid-template-columns: repeat(3, 1fr)
+}
+.item-grid.restore .item,
+.item-grid.group .item,
+.item-grid.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 {
+    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 {
+    position: absolute;
+    top: 0;
+    right: 0;
+}
+.item-grid.restore summary,
+.item-grid.preview summary,
+.item-grid.group 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(--rgb-subtle));
+}
+.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) {
+    padding: .5rem;
+    background-color: rgba(var(--action-rgb), var(--rgb-medium));
+    opacity: 1;
+}
+
+.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 .star,
+[type=radio].featured + label .star + .star {
+    display: none;
+}
+
+[type=radio].featured + label .star,
+[type=radio].featured:checked + label .star + .star {
+    display: inline-block;
+}
+.restore.item,
+.upload.item {
+    border-radius: var(--innerRadius);
+    overflow: hidden;
+    background: var(--base);
+    border: 1px solid var(--base-200);
+}
+.restore.item img,
+.upload.item img {
+    transition: transform var(--transition-base);
+}
+
+.restore.item:hover img,
+.upload.item:hover img {
+    transform: scale(1.02);
+    transition: transform var(--transition-base);
+}
+
+.upload-group {
+    background-image: var(--dashed-action);
+    padding: 5px;
+    border-radius: var(--innerRadius);
+    background-color: rgba(var(--action-rgb), var(--rgb-subtle));
+}
+
+.submit-uploads {
+    position: fixed;
+    bottom: var(--offHeight);
+    right: var(--offHeight);
+    z-index: var(--z-6);
+    height: var(--height);
+    box-shadow: var(--shadow);
+    border-radius: var(--innerRadius);
+    animation: pulse-color 5s infinite;
+    animation-delay: 1s;
+    background-color: var(--action-0);
+    color: var(--action-contrast);
+}
+.submit-uploads:hover {
+    background-color: var(--base-200);
+    color: var(--contrast-200);
+}
+
+.empty-group {
+    grid-column: 1 / -1;
+    padding: 20px;
+    background-image: var(--dashed-action);
+    border-radius: var(--innerRadius);
+    margin: 10px 0;
+    cursor: pointer;
+    transition: all var(--transition-base);
+    text-align: center;
+    background-color: rgba(var(--action-rgb), var(--rgb-subtle));
+}
+
+.group-display:not([hidden]) ~ .file-upload-container {
+    display: none;
+}
+
+.upload.item.dragging,
+.dragging {
+    opacity: .7;
+    transform: scale(.95) rotate(3deg);
+    z-index: var(--z-top);
+    box-shadow: 0 8px 25px rgba(0,0,0,.3);
+}
+
+.dragover {
+    background: rgba(var(--action-rgb),var(--rgb-light))!important;
+    border-color: var(--action-0) !important;
+    transform: scale(1.05);
+    animation: drop-pulse .8s infinite ease-in-out;
+}
+
+.drag-preview {
+    position: fixed;
+    z-index: var(--zz-top);
+    width: fit-content;
+    overflow: visible;
+    pointer-events: none;
+    opacity: 0.9;
+    transform: scale(1.05);
+    transition: transform 0.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(--outerRadius);
+    box-shadow: var(--shadow);
+}
+
+.drag-preview .drag-items .drag-item:nth-child(1) {
+    transform: rotate(-3deg);
+    z-index: 3;
+}
+
+.drag-preview .drag-items .drag-item:nth-child(2) {
+    left: 8px;
+    top: -4px;
+    transform: rotate(4deg);
+    z-index: 2;
+    transition-delay: 0.03s;
+}
+
+.drag-preview .drag-items .drag-item:nth-child(3) {
+    left: -6px;
+    top: -8px;
+    transform: rotate(-5deg);
+    z-index: 1;
+    transition-delay: 0.06s;
+}
+
+.drag-preview .drag-items .drag-item:nth-child(4) {
+    left: 12px;
+    top: -12px;
+    transform: rotate(3deg);
+    z-index: 0;
+    transition-delay: 0.09s;
+}
+
+/* Additional items follow the pattern */
+.drag-preview .drag-items .drag-item:nth-child(n+5) {
+    left: -10px;
+    top: -16px;
+    transform: rotate(-4deg);
+    z-index: 0;
+    opacity: 0.8;
+}
+
+/* The actual image/video inside fills the wrapper */
+.drag-preview .drag-items img,
+.drag-preview .drag-items video {
+    width: 100%;
+    height: 100%;
+    object-fit: cover;
+    display: block;
+}
+
+.drag-preview .drag-count {
+    position: absolute;
+    top: -8px;
+    right: -8px;
+    background: var(--base-200);
+    color: var(--contrast);
+    border-radius: 50%;
+    width: 24px;
+    height: 24px;
+    display: flex;
+    align-items: center;
+    justify-content: center;
+    font-size: 12px;
+    font-weight: bold;
+    box-shadow: var(--shadow);
+    z-index: var(--z-3);
+}
+
+/* Touch-specific offset positioning handled via transform in JS */
+.drag-preview[data-source="touch"] {
+    /* JS will apply appropriate offset transforms */
+}
+
+/* Items being dragged - reduce opacity on originals */
+.item.dragging {
+    opacity: 0.5;
+    transform: scale(0.95);
+    filter: grayscale(50%);
+    transition: opacity 0.2s ease, transform 0.2s ease, filter 0.2s ease;
+}
+
+@keyframes drop-pulse {
+    0%, 100% {
+        background-color: rgba(var(--action-rgb),var(--rgb-light));
+        transform: scale(1.02);
+    }
+    50% {
+        background-color: var(rgba(var(--action-rgb),var(--rgb-medium)));
+        transform: scale(1.04);
+    }
+}
+
+/******
+Upload grouping
+******/
+.group-actions {
+    display: flex;
+    gap: .25rem;
+}
+@media (max-width: 767px) {
+    body:not(.uploading):has(.group-display:not([hidden])){
+        overflow:hidden;
+    }
+    body:not(.uploading):has(.group-display:not([hidden])) .qtoggle {
+        z-index: var(--z-1);
+    }
+
+    .group-display.group-display {
+        position: fixed;
+        top: var(--height);
+        bottom: var(--height);
+        left: 0;
+        right: 0;
+        max-height: var(--maxHeight);
+        overflow: hidden;
+        z-index: var(--z-6);
+        width: calc(100% - 1rem);
+        height: calc(100% - 1rem);
+        padding: 0 0 3rem;
+        --justify: flex-start;
+        --align: flex-start;
+        --gap: 0;
+    }
+    .group-display::before {
+        content: '';
+        display: block;
+        z-index: -1;
+        top: -.5rem;
+        bottom: -.5rem;
+        left: -.5rem;
+        right: -.5rem;
+        position: absolute;
+        background-color: rgba(var(--base-rgb), var(--rgb-heavy));
+        filter: blur(5px);
+    }
+
+    .group-display .preview-wrap,
+    .group-display .sidebar {
+        height: 50%;
+        overflow:hidden auto;
+        position: relative;
+        padding: .5rem;
+    }
+    .group-display .preview-wrap {
+        top: 0;
+    }
+    .group-display .preview-wrap .selected {
+        display: flex;
+        justify-content: space-between;
+        align-items: center;
+    }
+    .group-display .sidebar {
+        bottom: 0;
+        flex-wrap: nowrap;
+        overflow: hidden auto;
+        background-color: var(--contrast-200);
+        color: var(--base);
+    }
+    .group-display .sidebar > .hint {
+        color: var(--contrast);
+    }
+    .group-display .sidebar .header {
+        display: none;
+    }
+
+    .group-display .preview-actions {
+        top: 0;
+        flex-shrink:0;
+    }
+    .group-display .preview-wrap > .hint,
+    .group-display .sidebar > .hint {
+        bottom: 0;
+        margin: 0;
+        text-align: center;
+    }
+    .group-display .preview-wrap > .hint,
+    .group-display .sidebar > .hint,
+    .group-display .preview-actions {
+        position: absolute;
+        left: 0;
+        right: 0;
+        background-color: rgba(var(--base-rgb), var(--rgb-heavy));
+        z-index: var(--z-3);
+        box-shadow: var(--shadow);
+    }
+    .group-display .item-grid {
+        height: 100%;
+        overflow: hidden auto;
+        grid-template-columns: repeat(3, 1fr);
+        padding: 2rem 0;
+    }
+    .group-display .sidebar > .item-grid {
+        grid-template-columns: repeat(1, 1fr);
+        gap: 1rem;
+        padding: 0;
+    }
+    .group-display .sidebar .empty-group {
+        order: 0;
+        position: sticky;
+        height: fit-content;
+        top: 0;
+        z-index: var(--z-3);
+        background-color: rgba(var(--action-rgb), var(--rgb-heavy));
+    }
+    .group-display .sidebar .upload-group {
+        order: 1;
+    }
+    .group-display .sidebar .empty-group p {
+        margin: 0;
+    }
+
+
+    .group-display .field label,
+    .group-display .field {
+        margin: 0;
+        padding: 0;
+    }
+
+    .group-display .sidebar h4 {
+        margin: .25rem;
+    }
+
+    .group-display .item {
+        width:100%;
+        height: max-content;
+    }
+
+    .submit-uploads {
+        bottom: var(--height);
+        left: 0;
+        right: 0;
+        width: 100%;
+        height: 3rem;
+    }
+
+    body.uploading .group-display.group-display {
+        position: relative;
+        top: unset;
+        bottom: unset;
+        right: unset;
+        left: unset;
+    }
+}
+@media (min-width: 768px) {
+    .group-display.group-display {
+        --wrap: nowrap;
+        --dir: row;
+        --gap: 1rem;
+        --align: flex-start;
+    }
+    .group-display .preview-wrap,
+    .group-display .sidebar {
+        --justify: flex-start;
+        max-height: calc(100vh - var(--doubleHeight));
+        overflow: hidden auto;
+    }
+    .group-display .preview-wrap,
+    .group-display .sidebar {
+        width: 50%;
+    }
+
+    .preview-actions,
+    .preview-wrap .hint {
+        position: sticky;
+        z-index: var(--z-3);
+        box-shadow: var(--shadow);
+        background-color: var(--base);
+        width: 100%;
+    }
+    .preview-actions {
+        top: 0;
+        left: 0;
+        right: 0;
+    }
+    .preview-actions .field {
+        margin: 0;
+    }
+    .sidebar > .hint,
+    .preview-wrap .hint {
+        bottom: -1rem;
+        padding-bottom: 1rem;
+        margin: 0;
+        left: 0;
+        right: 0;
+        text-align: center;
+    }
+}
+
+.restore-uploads {
+    position: fixed;
+    top: var(--offHeight);
+    bottom: var(--offHeight);
+    left: 1rem;
+    right: 1rem;
+    border-radius: var(--outerRadius);
+    padding: 1rem;
+    z-index: var(--z-top);
+    box-shadow: var(--shadow);
+    background-color: var(--base-200);
+    overflow: hidden auto;
+}
+
+/*************************************************************
+Tabs in dialog elements
+************************************************************/
 
 dialog nav.tabs {
     position: sticky;
@@ -105,8 +609,8 @@
 }
 .editor-container .ql-container .ql-editor {
     padding: var(--padding);
-    width: calc(100% - (var(--padding) * 2.5));
-    height: calc(100% - (var(--padding) * 2));
+    width: 100%;
+    height: 100%;
 }
 .ql-editor img {
     max-width: 50%;
@@ -137,9 +641,7 @@
 /******************************************************
 FIELDS
 ******************************************************/
-[data-type=single] [for=select-item] {
-    display: none;
-}
+
 [data-type=single] .item-grid {
     display: flex;
 }
@@ -152,4 +654,963 @@
 }
 .repeater-row details summary button {
     margin-left: auto;
-}
\ No newline at end of file
+}
+
+
+/*******************************************************
+UPLOADER
+*******************************************************/
+/*!* Group actions buttons - more visible *!*/
+/*.group-actions {*/
+/*    display: flex;*/
+/*    gap: 0.5rem;*/
+/*}*/
+
+/*.group-actions button {*/
+/*    padding: 0.5rem 0.75rem;*/
+/*    border-radius: var(--innerRadius);*/
+/*    background: rgba(var(--action-rgb), 0.1);*/
+/*    border: 1px solid rgba(var(--action-rgb), 0.3);*/
+/*    color: var(--action-0);*/
+/*    font-size: var(--small);*/
+/*    transition: all var(--transition-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(--innerRadius);*/
+/*    padding: 0.75rem;*/
+/*    min-height: 100px;*/
+/*}*/
+
+/*!* Group count hint *!*/
+/*.group-count {*/
+/*    margin-top: 0.5rem;*/
+/*    font-size: var(--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(--innerRadius);*/
+/*    margin: 1rem 0;*/
+/*    animation: slideDown var(--transition-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(--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(--innerRadius);*/
+/*    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(--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(--transition-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(--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(--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(--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(--innerRadius);*/
+/*    overflow: hidden;*/
+/*    cursor: pointer;*/
+/*    transition: all var(--transition-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(--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(--small);*/
+/*    border: 1px solid var(--border);*/
+/*    background: var(--base);*/
+/*    color: var(--contrast);*/
+/*    border-radius: var(--innerRadius);*/
+/*    cursor: pointer;*/
+/*    transition: all var(--transition-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(--innerRadius);*/
+/*    cursor: pointer;*/
+/*    transition: all var(--transition-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;
+}
+
+/* Progress Bar Styling */
+.form-progress {
+    padding: 0 1rem;
+}
+
+.form-progress .progress {
+    background: var(--base-100);
+    border-radius: var(--innerRadius);
+    padding: 1rem;
+}
+
+.form-progress .bar {
+    height: 6px;
+    background: var(--base-200);
+    border-radius: 3px;
+    overflow: hidden;
+    margin-bottom: 0.5rem;
+}
+
+.form-progress .fill {
+    height: 100%;
+    background: linear-gradient(90deg, var(--action-0), var(--action-200));
+    width: 0%;
+    transition: width 0.4s ease;
+    border-radius: 3px;
+}
+
+.form-progress .step-text {
+    font-size: var(--small);
+    font-weight: 600;
+    color: var(--contrast-200);
+}
+
+/* Stepped Tabs Styling */
+form nav.tabs {
+    position: relative;
+    top: 0;
+    left: 0;
+    right: 0;
+    padding: 1rem 0;
+    gap: 0;
+    z-index: 0;
+}
+
+form nav.tabs button {
+    position: relative;
+    background: transparent;
+    border: none;
+    padding: 0.5rem 1rem .5rem 3rem;
+    z-index: 1;
+}
+
+/* Step Number Circle */
+form nav.tabs .step-number {
+    width: 2.5rem;
+    height: 100%;
+    border-radius: 50% 0 0 50%;
+    position: absolute;
+    left: 0;
+    top: 0;
+    background: var(--base-200);
+    color: var(--contrast-50);
+    display: flex;
+    align-items: center;
+    justify-content: center;
+    font-weight: 700;
+    font-size: var(--small);
+    border: 3px solid var(--base);
+}
+
+/* Pending Step */
+form nav.tabs button.pending .step-number {
+    background: var(--base-100);
+    color: 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);
+}
+
+/* Completed Step */
+form nav.tabs button.completed .step-number {
+    background: var(--successBack);
+    color: var(--successBack);
+    border-color: var(--successText);
+}
+
+form nav.tabs button.completed .step-number::before {
+    content: '✓';
+    font-size: 1.2rem;
+    color: var(--successText);
+    position: absolute;
+}
+
+form nav.tabs button.completed h2 {
+    color: var(--contrast-200);
+}
+
+/* Step Navigation Buttons */
+.step-navigation {
+    margin-top: 2rem;
+    padding-top: 2rem;
+    border-top: 1px solid var(--base-200);
+    gap: 1rem;
+}
+
+.step-navigation .prev-step {
+    background: 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(--small);
+    margin-top: 0.25rem;
+    display: block;
+}
+
+/* Mobile responsiveness */
+@media (max-width: 768px) {
+    form nav.tabs button {
+        min-width: 80px;
+        font-size: var(--small);
+    }
+
+    form nav.tabs button h2 {
+        font-size: var(--small);
+    }
+
+    form {
+        --step-size: 2rem;
+    }
+}
+
+/**** VALIDATION ******/
+/* Field Input Wrapper - for positioning icon */
+.field-input-wrapper {
+    position: relative;
+    display: flex;
+    align-items: center;
+    gap: 0.5rem;
+}
+
+.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);
+    font-size: var(--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;
+}
+
+/*************************************************************
+ Form Summary
+ ************************************************************/
+.form-summary {
+    padding: 2rem;
+    border-radius: 8px;
+    margin-top: 2rem;
+    border: 2px dashed var(--contrast-200);
+}
+
+.form-summary .message {
+    margin-bottom: 2rem;
+}
+.form-summary .result + .result {
+    position: relative;
+    margin-top: 1.5rem;
+    padding-top: 1.5rem;
+}
+.form-summary .result + .result::before {
+    position: absolute;
+    top: 0;
+    left: 16.5%;
+    content: '';
+    width: 67%;
+    height: 1px;
+    border-bottom: 1px solid var(--base-200);
+}
+
+.form-summary h2 {
+    margin: 1rem 0;
+}
+
+.form-summary h4 {
+    background-color: var(--base-100);
+    padding: .5rem 2rem;
+    position: relative;
+    left: -2rem;
+    color: var(--contrast-200);
+    font-size: 0.875rem;
+    text-transform: uppercase;
+    letter-spacing: 0.05em;
+    margin-bottom: 0.75rem;
+}
+
+.form-summary p {
+    color: var(--text);
+    margin: 0;
+}
+
+.repeater-summary,
+.group-summary {
+    background: var(--base-100);
+    padding: 1rem;
+    border-radius: 4px;
+    margin-top: 0.5rem;
+}
+
+.repeater-row {
+    margin-bottom: 1rem;
+}
+
+.repeater-row:last-child {
+    margin-bottom: 0;
+}

--
Gitblit v1.10.0