From fcd6e159ee09cc4bbe99bbbadc61a6e83b24b5bf Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Mon, 20 Oct 2025 18:01:49 +0000
Subject: [PATCH] =Update Styles from northeh

---
 all.css | 1249 +++++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 915 insertions(+), 334 deletions(-)

diff --git a/all.css b/all.css
index d171c67..6c0aca9 100644
--- a/all.css
+++ b/all.css
@@ -368,6 +368,7 @@
     font-weight: 900;
     src: url('./fonts/montserrat-v31-latin-900italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
 }
+
 /* https://frontendmasters.com/blog/the-coyier-css-starter/ */
 @layer reset {
     html {
@@ -646,10 +647,10 @@
     line-height: 1.4;
     position: relative;
 }
-    body b,
-    body strong {
-        font-weight: var(--bBold);
-    }
+body b,
+body strong {
+    font-weight: var(--bBold);
+}
 
 
 *:target {
@@ -794,47 +795,112 @@
 /******************************************************************
 THEME SWITCHER & TOGGLE
 ******************************************************************/
-.theme-switcher {
-    position: absolute;
+.toggle-switch input {
     opacity: 0;
     width: 0;
     height: 0;
-}
-#theme-switch {
-    z-index: 99;
     position: absolute;
-    display: flex;
-    align-items: center;
-    justify-content: center;
-}
-#theme-switch,
-.toggle-switch {
-    --wrap: nowrap;
-    cursor: pointer;
-}
-#theme-switch,
-.toggle-switch input[type=checkbox] {
-    --h: 2rem;
-    width: calc(var(--h) * 2);
-    height: var(--h);
-    margin: 0 2rem 0 0;
-    left: 0;
-    appearance:none;
-    background: var(--base-200);
-    border: 1px solid var(--base-50);
-    border-radius: var(--h);
-    cursor: pointer;
-    transition: all .3s ease;
-    opacity: 1;
+    left: var(--offScreen);
 }
 
-.toggle-switch input[type=checkbox] {
+.toggle-switch .slider {
     position: relative;
+    width: 2rem;
+    height: 1rem;
+    background-color: var(--base-200);
+    border-radius: .75rem;
+    overflow: hidden;
+    display: flex;
+    justify-content: space-evenly;
+    align-items: center;
+    border: 4px solid transparent;
+    transition: .3s;
+    box-shadow: 0 0 .25rem 0 rgba(var(--contrast-rgb), .125) inset;
+    cursor: pointer;
+    margin: 5px;
 }
-.toggle-switch {
-    position: relative;
+
+.toggle-switch .slider::before {
+    content: '';
+    display: block;
+    width: 100%;
+    height: 100%;
+    position: absolute;
+    top:0;
+    left: 0;
+    background-color: var(--base);
+    transform: translateX(-1rem);
+    border-radius: .75rem;
+    transition: .3s;
+    box-shadow: 0 0 .25rem 3px rgba(var(--contrast-rgb), .125);
 }
 
+.toggle-switch input:checked ~ .slider::before {
+    transform: translateX(1rem);
+    box-shadow: 0 0 .25rem 3px rgb(0, 0, 0, 0.25);
+}
+
+.toggle-switch input:checked ~ .slider {
+    background-color: var(--action-0);
+}
+
+.toggle-switch input:active ~ .slider::before {
+    transform: translate(0);
+}
+
+
+/*.theme-switcher {*/
+/*    position: absolute;*/
+/*    opacity: 0;*/
+/*    width: 0;*/
+/*    height: 0;*/
+/*}*/
+#theme-switch {
+    z-index: 99;
+    margin: 0;
+    --wrap: nowrap;
+    --gap: 1rem;
+}
+#theme-switch .slider {
+    width: 3rem;
+    height: 1.5rem;
+}
+#theme-switch .slider::before {
+    transform: translateX(-1.5rem);
+}
+#theme-switch input:checked ~ .slider::before {
+    transform: translateX(1.5rem);
+}
+
+
+/*#theme-switch,*/
+/*.toggle-switch {*/
+/*    --wrap: nowrap;*/
+/*    cursor: pointer;*/
+/*}*/
+/*#theme-switch,*/
+/*.toggle-switch input[type=checkbox] {*/
+/*    --h: 2rem;*/
+/*    width: calc(var(--h) * 2);*/
+/*    height: var(--h);*/
+/*    margin: 0 2rem 0 0;*/
+/*    left: 0;*/
+/*    appearance:none;*/
+/*    background: var(--base-200);*/
+/*    border: 1px solid var(--base-50);*/
+/*    border-radius: var(--h);*/
+/*    cursor: pointer;*/
+/*    transition: all .3s ease;*/
+/*    opacity: 1;*/
+/*}*/
+
+/*.toggle-switch input[type=checkbox] {*/
+/*    position: relative;*/
+/*}*/
+/*.toggle-switch {*/
+/*    position: relative;*/
+/*}*/
+
 @media (max-width: 600px) {
     #theme-switch {
         left: 1rem;
@@ -845,106 +911,106 @@
 }
 
 /* Icon wrapper styling */
-#theme-switch .icon {
-    --w: 1em;
-    position: relative;
-    top: 0;
-    margin: 0 .25em;
-    color: var(--contrast-200);
-    z-index: 2;
-    transform: translateX(0);
-}
+/*#theme-switch .icon {*/
+/*    --w: 1em;*/
+/*    position: relative;*/
+/*    top: 0;*/
+/*    margin: 0 .25em;*/
+/*    color: var(--contrast-200);*/
+/*    z-index: 2;*/
+/*    transform: translateX(0);*/
+/*}*/
 
 
-#theme-switcher:not(:checked) ~ .sun-dim,
-#theme-switcher:checked ~ .moon {
-    --w: 1.5em;
-    color: var(--contrast);
-}
+/*#theme-switcher:not(:checked) ~ .sun-dim,*/
+/*#theme-switcher:checked ~ .moon {*/
+/*    --w: 1.5em;*/
+/*    color: var(--contrast);*/
+/*}*/
 
-#theme-switcher:not(:checked) ~ .moon,
-#theme-switcher:checked ~ .sun-dim {
-    top: -.17rem;
-}
-    #theme-switcher:not(:checked) ~ .sun-dim {
-        color: var(--secondary-0);
-        transform: translate(-2px, 2px);
-    }
-    #theme-switcher:checked ~ .moon {
-        transform: translate(4px, 4px);
-    }
+/*#theme-switcher:not(:checked) ~ .moon,*/
+/*#theme-switcher:checked ~ .sun-dim {*/
+/*    top: -.17rem;*/
+/*}*/
+/*    #theme-switcher:not(:checked) ~ .sun-dim {*/
+/*        color: var(--secondary-0);*/
+/*        transform: translate(-2px, 2px);*/
+/*    }*/
+/*    #theme-switcher:checked ~ .moon {*/
+/*        transform: translate(4px, 4px);*/
+/*    }*/
 
-#theme-switch span,
-.toggle-switch input[type=checkbox]::before {
-    --m: 2px;
-    content: "";
-    position: absolute;
-    top: var(--m);
-    left: var(--m);
-    width: calc(var(--h) - (var(--m) * 2));
-    height: calc(var(--h) - var(--m) * 2);
-    border: 1px solid rgba(var(--contrast-rgb), .2);
-    border-bottom: 3px solid var(--contrast-200);
-    background: var(--base-50);
-    border-radius: 50%;
-    z-index: 1;
-    transform: rotate(360deg);
-    transition: transform var(--transition-base),
-    left var(--transition-base),
-    top var(--transition-base),
-    height var(--transition-base);
-}
-    #theme-switch input:checked ~ span,
-    .toggle-switch input[type=checkbox]:checked::before {
-        left: calc(100% - (var(--h) - var(--m)));
-        transform: rotate(-180deg);
-        transition: transform var(--transition-base), left var(--transition-base);
-    }
-    .toggle-switch input[type=checkbox]:checked {
-        background: var(--action-0);
-    }
+/*#theme-switch span,*/
+/*.toggle-switch input[type=checkbox]::before {*/
+/*    --m: 2px;*/
+/*    content: "";*/
+/*    position: absolute;*/
+/*    top: var(--m);*/
+/*    left: var(--m);*/
+/*    width: calc(var(--h) - (var(--m) * 2));*/
+/*    height: calc(var(--h) - var(--m) * 2);*/
+/*    border: 1px solid rgba(var(--contrast-rgb), .2);*/
+/*    border-bottom: 3px solid var(--contrast-200);*/
+/*    background: var(--base-50);*/
+/*    border-radius: 50%;*/
+/*    z-index: 1;*/
+/*    transform: rotate(360deg);*/
+/*    transition: transform var(--transition-base),*/
+/*    left var(--transition-base),*/
+/*    top var(--transition-base),*/
+/*    height var(--transition-base);*/
+/*}*/
+/*    #theme-switch input:checked ~ span,*/
+/*    .toggle-switch input[type=checkbox]:checked::before {*/
+/*        left: calc(100% - (var(--h) - var(--m)));*/
+/*        transform: rotate(-180deg);*/
+/*        transition: transform var(--transition-base), left var(--transition-base);*/
+/*    }*/
+/*    .toggle-switch input[type=checkbox]:checked {*/
+/*        background: var(--action-0);*/
+/*    }*/
 
-/* Focus States */
-.theme-switch:focus-visible + label {
-    outline: 2px solid var(--action-0);
-    outline-offset: 2px;
-}
+/*!* Focus States *!*/
+/*.theme-switch:focus-visible + label {*/
+/*    outline: 2px solid var(--action-0);*/
+/*    outline-offset: 2px;*/
+/*}*/
 
-/* Icon Animations */
-#theme-switch .icon {
-    transition:
-            transform var(--transition-base),
-            width var(--transition-base),
-            height var(--transition-base),
-            top var(--transition-base),
-            color var(--transition-base);
-}
+/*!* Icon Animations *!*/
+/*#theme-switch .icon {*/
+/*    transition:*/
+/*            transform var(--transition-base),*/
+/*            width var(--transition-base),*/
+/*            height var(--transition-base),*/
+/*            top var(--transition-base),*/
+/*            color var(--transition-base);*/
+/*}*/
 
-#theme-switcher:not(:checked) ~ .icon.dark,
-#theme-switcher:checked ~ .icon.light {
-    transform: rotate(360deg);
-    color: var(--contrast-200);
-}
-#theme-switcher:not(:checked) ~ .icon.light,
-#theme-switcher:checked ~ .icon.dark {
-    transform: rotate(-360deg);
-    color: var(--contrast);
-}
+/*#theme-switcher:not(:checked) ~ .icon.dark,*/
+/*#theme-switcher:checked ~ .icon.light {*/
+/*    transform: rotate(360deg);*/
+/*    color: var(--contrast-200);*/
+/*}*/
+/*#theme-switcher:not(:checked) ~ .icon.light,*/
+/*#theme-switcher:checked ~ .icon.dark {*/
+/*    transform: rotate(-360deg);*/
+/*    color: var(--contrast);*/
+/*}*/
 
-/* Hover Effects */
-#theme-switch:hover span {
-    background-color: var(--base-100);
-}
+/*!* Hover Effects *!*/
+/*#theme-switch:hover span {*/
+/*    background-color: var(--base-100);*/
+/*}*/
 
 
-#theme-switch:hover .icon {
-    color: var(--action-50);
-}
+/*#theme-switch:hover .icon {*/
+/*    color: var(--action-50);*/
+/*}*/
 
-/* Active State */
-#theme-switch:active span {
-    transform: scale(.97);
-}
+/*!* Active State *!*/
+/*#theme-switch:active span {*/
+/*    transform: scale(.97);*/
+/*}*/
 
 /***********************************************************
 SMOOTH SCROLLING
@@ -1199,6 +1265,7 @@
         margin: 3rem var(--mr) 3rem var(--ml);
     }
 }
+.btn + label,
 [type=submit],
 a.button,
 a.wp-block-button__link,
@@ -1227,6 +1294,9 @@
     transition-property: color, border,background-color;
     position: relative;
 }
+
+.btn + label:hover,
+.btn + label:focus,
 [type=submit]:hover,
 [type=submit]:focus,
 .buttons a:hover,
@@ -1241,6 +1311,9 @@
 }
 
 
+
+.btn:disabled + label,
+.btn:disabled + label:hover,
 [type=submit]:disabled,
 [type=submit]:disabled:hover,
 [type=submit]:disabled:focus,
@@ -1527,19 +1600,19 @@
     transition: background-color var(--transition-base);
     transition-property: background-color, border;
 }
-    textarea:focus,
-    input[type=number]:focus,
-    input[type=text]:focus,
-    input[type=url]:focus,
-    input[type=email]:focus,
-    input[type=textarea]:focus,
-    input[type=tel]:focus,
-    input[type=password]:focus,
-    input[type=search]:focus {
-        outline: var(--action-50);
-        background-color: var(--base-100);
-        color: var(--contrast);
-    }
+textarea:focus,
+input[type=number]:focus,
+input[type=text]:focus,
+input[type=url]:focus,
+input[type=email]:focus,
+input[type=textarea]:focus,
+input[type=tel]:focus,
+input[type=password]:focus,
+input[type=search]:focus {
+    outline: var(--action-50);
+    background-color: var(--base-100);
+    color: var(--contrast);
+}
 textarea::placeholder,
 input::placeholder {
     font-family: var(--body);
@@ -1561,31 +1634,31 @@
     width: 100%;
     transition: var(--transition-color);
 }
-    select:disabled {
-        background-color: var(--base-50);
-        border-color: var(--base-100);
-        color: var(--base-200);
-        cursor: not-allowed;
-    }
+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 {
+    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 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);
@@ -1666,10 +1739,10 @@
     width: 1.5em;
     height: 1.5em;
 }
-    .remove-item .close {
-        width: .5em;
-        height: .5em;
-    }
+.remove-item .close {
+    width: .5em;
+    height: .5em;
+}
 
 .remove-item:hover {
     color: var(--action-0);
@@ -1738,34 +1811,34 @@
     transition: background-color var(--transition-base),
     border-color var(--transition-base);
 }
-    [type=radio]:hover + label::before,
-    [type=checkbox]:hover + label::before,
-    input.ch:hover + label::before {
-        border-color: var(--action-200);
-    }
+[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,
+[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=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=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,
@@ -1782,11 +1855,11 @@
     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]: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,
@@ -1818,9 +1891,9 @@
     color: var(--contrast-200);
     opacity: .8;
 }
-    .radio-options.status label {
-        padding: 0 .5rem;
-    }
+.radio-options.status label {
+    padding: 0 .5rem;
+}
 .btn:checked + label {
     border-color: var(--contrast);
     color: var(--contrast);
@@ -1880,9 +1953,9 @@
     margin: 2rem 0;
     position: relative;
 }
-    .field:has(.has-tooltip) label {
-        margin-left: 2rem;
-    }
+.field:has(.has-tooltip) label {
+    margin-left: 2rem;
+}
 /***************
 TOGGLE TEXT
 ***************/
@@ -1982,13 +2055,13 @@
     margin-top: 1rem;
     width: 100%;
 }
-    .create-new-term .field,
-    .create-new-term[open] summary {
-        margin-bottom: 1rem;
-    }
-    .create-new-term .field {
-        max-width: 100%;
-    }
+.create-new-term .field,
+.create-new-term[open] summary {
+    margin-bottom: 1rem;
+}
+.create-new-term .field {
+    max-width: 100%;
+}
 #jvb-selector > .wrap {
     --gap: nowrap;
 }
@@ -2092,52 +2165,52 @@
     text-transform: lowercase;
 }
 /*.term-list a {*/
-    /*        color: var(--contrast);*/
-    /*        text-decoration: none;*/
-    /*        font-size: var(--small);*/
-    /*    }*/
-    /*        .term-list a:hover {*/
-    /*            color: var(--action-0);*/
-    /*        }*/
-    /*.term-list.shop a::before,*/
-    /*.term-list.style a::before,*/
-    /*.term-list.theme a::before,*/
-    /*.term-list.city a::before,*/
-    /*#by-city::before,*/
-    /*#by-style::before,*/
-    /*#by-theme::before,*/
-    /*.term-list.all a::before{*/
-    /*    content:"";*/
-    /*    display:inline-block;*/
-    /*    mask-repeat: no-repeat;*/
-    /*    mask-size: contain;*/
-    /*    width: 1.2em;*/
-    /*    height: 1.2em;*/
-    /*    margin-right: .5rem;*/
-    /*    vertical-align: middle;*/
-    /*    background-color: currentColor;*/
-    /*}*/
-    /*.term-list a::after {*/
-    /*    display: none;*/
-    /*}*/
+/*        color: var(--contrast);*/
+/*        text-decoration: none;*/
+/*        font-size: var(--small);*/
+/*    }*/
+/*        .term-list a:hover {*/
+/*            color: var(--action-0);*/
+/*        }*/
+/*.term-list.shop a::before,*/
+/*.term-list.style a::before,*/
+/*.term-list.theme a::before,*/
+/*.term-list.city a::before,*/
+/*#by-city::before,*/
+/*#by-style::before,*/
+/*#by-theme::before,*/
+/*.term-list.all a::before{*/
+/*    content:"";*/
+/*    display:inline-block;*/
+/*    mask-repeat: no-repeat;*/
+/*    mask-size: contain;*/
+/*    width: 1.2em;*/
+/*    height: 1.2em;*/
+/*    margin-right: .5rem;*/
+/*    vertical-align: middle;*/
+/*    background-color: currentColor;*/
+/*}*/
+/*.term-list a::after {*/
+/*    display: none;*/
+/*}*/
 
-    /*.term-list.shop a::before {*/
-    /*    mask-image: var(--shop);*/
-    /*}*/
+/*.term-list.shop a::before {*/
+/*    mask-image: var(--shop);*/
+/*}*/
 
-    /*.term-list.city a::before,*/
-    /*#by-city::before {*/
-    /*    mask-image: var(--map);*/
-    /*}*/
-    /*.term-list.style a::before,*/
-    /*#by-style::before,*/
-    /*.term-list.all.styles a::before {*/
-    /*    mask-image: var(--style);*/
-    /*}*/
-    /*.term-list.theme a::before,*/
-    /*#by-theme::before {*/
-    /*    mask-image: var(--theme);*/
-    /*}*/
+/*.term-list.city a::before,*/
+/*#by-city::before {*/
+/*    mask-image: var(--map);*/
+/*}*/
+/*.term-list.style a::before,*/
+/*#by-style::before,*/
+/*.term-list.all.styles a::before {*/
+/*    mask-image: var(--style);*/
+/*}*/
+/*.term-list.theme a::before,*/
+/*#by-theme::before {*/
+/*    mask-image: var(--theme);*/
+/*}*/
 /**************************************************
 MODALS DIALOGUE
 **************************************************/
@@ -2149,12 +2222,12 @@
 dialog[open] {
     z-index:999;
     --padding: 0;
-    top: 0;
+    top: 5vh;
     width: min(500px, 95vw);
     border-radius: 1rem;
     height: fit-content;
-    max-height: 90vh;
     overflow: hidden;
+    max-height: 90vh;
     padding: var(--padding);
     background-color: var(--base-50);
     color: var(--contrast);
@@ -2164,11 +2237,11 @@
 
 dialog > .wrap,
 dialog > form {
-    overflow: hidden auto;
     max-height: 100%;
-    margin: 1.5rem 0 0 1.5rem;
+    overflow: hidden auto;
+    margin: 0 0 0 1.5rem;
     padding-right: 1.2rem;
-    width: calc(100% - 1.5rem - 1.2rem);
+    width: calc(100% - 1.5rem);
 }
 
 dialog label {
@@ -2185,7 +2258,7 @@
     padding-bottom: var(--height);
 }
 .m-actions {
-    --w: 1.5em;
+    --w: 1.15em;
     --justify: flex-end;
     --wrap: nowrap;
     --gap: 0;
@@ -2678,12 +2751,12 @@
     position: relative;
     border: 2px solid var(--action-0);
 }
-    nav.tabs > button:first-of-type {
-        border-top-left-radius: var(--innerRadius);
-    }
-    nav.tabs > button:last-of-type {
-        border-top-right-radius: var(--innerRadius);
-    }
+nav.tabs > button:first-of-type {
+    border-top-left-radius: var(--innerRadius);
+}
+nav.tabs > button:last-of-type {
+    border-top-right-radius: var(--innerRadius);
+}
 .tabs > button:hover,
 .tabs > button:focus {
     background-color: var(--base-200);
@@ -2699,13 +2772,13 @@
     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: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);
@@ -2778,8 +2851,7 @@
 - cart
 - queue
 **************************************************/
-aside#cart,
-aside#queue {
+aside {
     position: fixed;
     top: var(--doubleHeight);
     bottom: var(--offHeight);
@@ -2792,7 +2864,7 @@
 }
 
 .qtoggle,
-.toggle-cart,
+    /*.toggle-cart,*/
 .create-item {
     z-index: var(--z-6);
     position: fixed;
@@ -2804,22 +2876,22 @@
     transition: width var(--transition-base), background-color var(--transition-base), color var(--transition-base), left var(--transition-base);
     box-shadow: var(--shadow);
 }
-.toggle-cart:hover,
+/*.toggle-cart:hover,*/
 .qtoggle:hover,
 .create-item:hover,
-.toggle-cart:focus,
+    /*.toggle-cart:focus,*/
 .qtoggle:focus,
 .create-item:focus {
     background-color: rgba(var(--action-rgb),var(--rgb-heavy));
     color: var(--action-contrast);
 }
-.toggle-cart:disabled,
+/*.toggle-cart:disabled,*/
 .qtoggle:disabled,
 .create-item:disabled,
-.toggle-cart:disabled:hover,
+    /*.toggle-cart:disabled:hover,*/
 .qtoggle:disabled:hover,
 .create-item:disabled:hover,
-.toggle-cart:disabled:focus,
+    /*.toggle-cart:disabled:focus,*/
 .qtoggle:disabled:focus,
 .create-item:disabled:focus {
     opacity: .5;
@@ -2835,24 +2907,13 @@
     border-radius: 4px 4px 4px var(--outerRadius);
 }
 
-body:has(#cart.expanded) .toggle-cart {
-    width: min(500px, calc(100vw - 2rem));
-}
 body:has(#cart.expanded) .toggle-cart .icon {
     display: none;
 }
 
 aside#cart {
-    overflow: hidden;
-    right: var(--offScreen);
-    border-radius: var(--outerRadius) 0 0 var(--outerRadius);
-    transition: right var(--transition-base);
     padding-bottom: 6rem;
 }
-aside#cart.expanded {
-    right: 0;
-    transition: right var(--transition-base);
-}
 #cart form {
     max-height: 100%;
     overflow: hidden auto;
@@ -2922,18 +2983,18 @@
     border-radius: var(--outerRadius);
     padding: 1rem;
 }
-    .restored h3 {
-        font-size: var(--medium);
-        margin: 0;
-    }
-    .restored p {
-        margin: 0;
-    }
-    .restored .row {
-        --gap: 0;
-        --wrap:nowrap;
-        --w: 1em;
-    }
+.restored h3 {
+    font-size: var(--medium);
+    margin: 0;
+}
+.restored p {
+    margin: 0;
+}
+.restored .row {
+    --gap: 0;
+    --wrap:nowrap;
+    --w: 1em;
+}
 /******************
 TOAST
 ******************/
@@ -2998,24 +3059,13 @@
 /******************
 QUEUE
 ******************/
-aside#queue {
-    left: var(--offScreen);
-    border-radius: 0 var(--outerRadius) var(--outerRadius) 0;
-    transition: left var(--transition-base);
-    --wrap: nowrap;
-    --align: stretch;
-}
-aside#queue.expanded {
-    left: 0;
-    overflow: hidden auto;
-}
 
 .qtoggle {
     left: 0;
     border-radius: 4px 4px var(--outerRadius) 4px;
 }
 
-body:has(#queue.expanded) .qtoggle {
+.qtoggle.expanded {
     left: var(--height);
     width: min(calc(500px - var(--height)), calc(100vw - 2rem - var(--height)));
 }
@@ -3167,9 +3217,9 @@
     height: 18px;
     font-size: 10px;
 }
-    .filter .count:empty {
-        display: none;
-    }
+.filter .count:empty {
+    display: none;
+}
 
 /* Empty state */
 .empty-queue {
@@ -3408,6 +3458,187 @@
     animation: shimmer 2.5s infinite linear var(--delay);
 }
 /**************************************************
+ACTIONS
+**************************************************/
+.additional-actions .buttons {
+    position: fixed;
+    bottom: var(--offHeight);
+    right: 1rem;
+    margin: 0;
+    --gap: 1rem;
+    z-index: var(--z-6);
+    width: fit-content;
+}
+.additional-actions .buttons button {
+    height: var(--height);
+    width: var(--height);
+    background-color: var(--overlay-medium);
+    color: var(--contrast);
+    transition: width var(--transition-base), background-color var(--transition-base), color var(--transition-base), left var(--transition-base);
+    box-shadow: var(--shadow);
+}
+.additional-actions .buttons button:hover {
+    background-color: var(--action-0);
+    color: var(--action-contrast);
+}
+.additional-actions .buttons button:disabled,
+.additional-actions .buttons button:disabled:hover,
+.additional-actions .buttons button:disabled:focus {
+    opacity: .5;
+    background-color: var(--overlay-light);
+    color: var(--contrast);
+}
+.additional-actions .buttons button:last-of-type {
+    border-radius: 4px 4px 4px var(--outerRadius);
+}
+aside {
+    position: fixed;
+    top: var(--doubleHeight);
+    bottom: var(--offHeight);
+    width: min(500px, calc(100vw - 2rem));
+    background-color: var(--base);
+    z-index: var(--z-5);
+    box-shadow: var(--shadow);
+    --wrap: nowrap;
+    --align: stretch;
+    overflow: hidden auto;
+    padding: 1rem 1rem var(--height);
+}
+aside.left {
+    left: var(--offScreen);
+    transition: left var(--transition-base);
+    border-radius: 0 var(--outerRadius) var(--outerRadius) 0;
+}
+aside.left.expanded {
+    left: 0;
+}
+
+aside.right {
+    right: var(--offScreen);
+    border-radius: var(--outerRadius) 0 0 var(--outerRadius);
+    transition: right var(--transition-base);
+}
+aside.right.expanded {
+    right: 0;
+}
+aside.right.expanded button.close {
+    position: sticky;
+    bottom: calc(var(--height) * -1);
+    left: 0;
+    border-bottom-left-radius: var(--outerRadius);
+    width: var(--height);
+    height: var(--height);
+
+}
+.additional-actions .buttons:has(.expanded) button:not(.expanded) {
+    display: none;
+}
+.additional-actions .buttons:has(.expanded){
+    right: 0;
+}
+
+.additional-actions .buttons .expanded {
+    width: calc(min(500px, calc(100vw - 2rem)));
+    background-color: var(--base);
+}
+.additional-actions .buttons button:hover,
+.additional-actions .buttons .expanded:hover {
+    background-color: var(--action-0);
+    color: var(--action-contrast);
+}
+
+[type=submit] {
+    width: 100%;
+    height: var(--height);
+    background-color: var(--action-0);
+    color: var(--action-contrast);
+    box-shadow: var(--shadow-none);
+    font-weight: bold;
+}
+[type=submit]:hover {
+    box-shadow: var(--shadow);
+    border: 2px solid var(--action-0);
+    color: var(--action-0);
+    background-color: var(--action-contrast);
+}
+
+aside nav.tabs {
+    position: sticky;
+    bottom: unset;
+    top: 0;
+    left: 0;
+    right: 0;
+}
+.jvb-referral nav.tabs button {
+    width: 50%;
+}
+aside .tab-content.active {
+    padding: 1rem;
+    min-height: 100%;
+}
+
+aside header h3 {
+    font-size: var(--medium);
+    margin: 1rem 0;
+    text-align: center;
+}
+aside header p {
+    margin: .25rem 0;
+    text-align: center;
+}
+aside h4 {
+    font-size: var(--small);
+    margin: 1rem 0 0 0;
+}
+
+code {
+    width: 100%;
+    margin: .5rem;
+    padding: .5rem;
+    user-select: all;
+    text-align: center;
+    border-radius: 4px;
+    background-color: var(--base-200);
+    border: 1px solid var(--contrast-200);
+}
+.restore-form {
+    background-color: rgba(var(--action-rgb), var(--rgb-light));
+    border: 1px solid var(--action-200);
+    padding: .5rem;
+    border-radius: var(--outerRadius);
+    margin: 1rem 2rem;
+}
+.restore-form h3 {
+    text-align: center;
+    margin: 1rem 0 0;
+    font-size: var(--medium);
+}
+.restore-form p {
+    margin: .5rem 0;
+}
+.fstatus {
+    z-index: var(--z-5);
+    background-color: rgba(var(--base-rgb),var(--rgb-heavy));
+    border-radius: 4px;
+    padding: 0 .5rem;
+    position: fixed;
+    bottom: var(--offHeight);
+    right: calc(var(--offHeight) + 1rem);
+    --w: 1em;
+    box-shadow:var(--shadow);
+}
+.fstatus .spinner {
+    display: none;
+}
+.fstatus.loading .spinner {
+    display: inline-block;
+}
+
+.fstatus p {
+    margin: 0;
+    padding: .25rem;
+}
+/**************************************************
 RESPONSES
 **************************************************/
 /*dialog.create-response {*/
@@ -3494,13 +3725,13 @@
 
 @keyframes pulse-color {
     0% {
-        box-shadow: 0 0 0 0 rgba(var(--secondary-rgb), .4);
+        box-shadow: 0 0 0 0 rgba(var(--action-rgb), .4);
     }
-    70% {
-        box-shadow: 0 0 0 6px rgba(var(--secondary-rgb), 0);
+    30% {
+        box-shadow: 0 0 0 .75rem rgba(var(--action-rgb), 0);
     }
     100% {
-        box-shadow: 0 0 0 0 rgba(var(--secondary-rgb), 0);
+        box-shadow: 0 0 0 0 rgba(var(--action-rgb), 0);
     }
 }
 
@@ -3676,21 +3907,21 @@
     gap: 0 1rem;
 }
 .menu-items .menu-item:not(.variable) label {
-        display: none;
-    }
+    display: none;
+}
 .menu-items .menu-item .field {
-        margin: 0;
-        --wrap: nowrap;
-    }
+    margin: 0;
+    --wrap: nowrap;
+}
 .menu-items .menu-item .has-tooltip {
-        position: absolute;
-        right: -2.5rem;
-    }
+    position: absolute;
+    right: -2.5rem;
+}
 .menu-items .menu-item + .menu-item {
-        border-top: 1px solid var(--base-200);
-        margin-top: 2rem;
-        padding-top: 1rem;
-    }
+    border-top: 1px solid var(--base-200);
+    margin-top: 2rem;
+    padding-top: 1rem;
+}
 .menu-items .menu-item .header {
     grid-column: 1/-1;
 }
@@ -3713,7 +3944,7 @@
     vertical-align: super;
     font-size: 12px;
 }
-body.menu_item section h2 {
+body.menu_item section > h2 {
     display: inline-block;
     max-width: var(--maxWidth);
     width: max-content;
@@ -4255,10 +4486,14 @@
     font-size: 14px;
     min-width: 180px;
     background: var(--base);
+    color: var(--contrast);
     cursor: pointer;
     transition: border-color .2s ease;
 }
 
+.field-input-wrapper input[type=time]:focus,
+.field-input-wrapper input[type=datetime-local]:focus,
+.field-input-wrapper input[type=date]:focus,
 .time-wrapper input[type=time]:focus,
 .datetime-wrapper input[type=datetime-local]:focus,
 .date-wrapper input[type=date]:focus {
@@ -4267,12 +4502,13 @@
 }
 
 /* Icon styling in form fields */
+.field-input-wrapper svg,
 .time-wrapper svg,
 .datetime-wrapper svg,
 .date-wrapper svg {
     width: 18px;
     height: 18px;
-    color: #666;
+    color: var(--contrast);
     opacity: .7;
 }
 
@@ -4437,13 +4673,358 @@
 /*    }*/
 /*}*/
 
+legend {
+    padding: 0 1rem;
+}
+.abs {
+    position: absolute;
+}
+.top {
+    top: 0;
+    right: 0;
+    left: 0;
+}
+.top-right {
+    top: 0;
+    right: 0;
+}
+.top-left {
+    top: 0;
+    left: 0;
+}
+
+.btm {
+    bottom: 0;
+    left: 0;
+    right: 0;
+}
+.btm-right {
+    bottom: 0;
+    right: 0;
+}
+.btm-left {
+    bottom: 0;
+    left: 0;
+}
+.edges {
+    top: 0;
+    right: 0;
+    left: 0;
+    bottom: 0;
+}
 
 
 
+/*********************** REFERRAL SYSTEM ***********************/
+.referral-widget {
+    background: #fff;
+    border: 1px solid #ddd;
+    border-radius: 8px;
+    padding: 24px;
+    margin: 20px 0;
+    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
+}
 
+.referral-header {
+    text-align: center;
+    margin-bottom: 20px;
+}
 
+.referral-header h3 {
+    margin: 0 0 8px 0;
+    color: #2271b1;
+}
 
+.referral-header p {
+    margin: 0;
+    color: #666;
+    font-size: 14px;
+}
 
+/* Share Widget Styles */
+.referral-link-section {
+    margin-bottom: 20px;
+}
 
+.referral-link-section label {
+    display: block;
+    font-weight: 600;
+    margin-bottom: 8px;
+    color: #333;
+}
 
+.link-copy-wrapper {
+    display: flex;
+    gap: 8px;
+}
 
+.link-copy-wrapper input {
+    flex: 1;
+    padding: 10px 12px;
+    border: 1px solid #ddd;
+    border-radius: 4px;
+    font-family: monospace;
+    font-size: 13px;
+    background: #f9f9f9;
+}
+
+.copy-link-btn {
+    padding: 10px 20px;
+    background: #2271b1;
+    color: #fff;
+    border: none;
+    border-radius: 4px;
+    cursor: pointer;
+    font-weight: 600;
+    white-space: nowrap;
+    transition: background 0.2s;
+}
+
+.copy-link-btn:hover {
+    background: #135e96;
+}
+
+.referral-code-display {
+    margin: 8px 0 0 0;
+    font-size: 13px;
+    color: #666;
+}
+
+.referral-stats {
+    display: grid;
+    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
+    gap: 16px;
+    margin-bottom: 20px;
+    padding: 16px;
+    background: #f8f9fa;
+    border-radius: 6px;
+}
+
+.stat-item {
+    text-align: center;
+}
+
+.stat-value {
+    display: block;
+    font-size: 24px;
+    font-weight: bold;
+    color: #2271b1;
+}
+
+.stat-label {
+    display: block;
+    font-size: 12px;
+    color: #666;
+    margin-top: 4px;
+}
+
+.share-buttons {
+    display: flex;
+    gap: 10px;
+    justify-content: center;
+    flex-wrap: wrap;
+}
+
+.share-btn {
+    display: inline-flex;
+    align-items: center;
+    gap: 6px;
+    padding: 10px 16px;
+    border: 1px solid #ddd;
+    border-radius: 4px;
+    text-decoration: none;
+    color: #333;
+    font-size: 14px;
+    font-weight: 500;
+    transition: all 0.2s;
+}
+
+.share-btn:hover {
+    background: #f5f5f5;
+    border-color: #999;
+}
+
+/* Validation Widget Styles */
+.form-group {
+    margin-bottom: 16px;
+}
+
+.form-group label {
+    display: block;
+    font-weight: 600;
+    margin-bottom: 8px;
+    color: #333;
+}
+
+.input-button-wrapper {
+    display: flex;
+    gap: 8px;
+}
+
+.input-button-wrapper input {
+    flex: 1;
+    padding: 12px 16px;
+    border: 2px solid #ddd;
+    border-radius: 4px;
+    font-size: 16px;
+    font-family: monospace;
+    font-weight: 600;
+    text-transform: uppercase;
+    transition: border-color 0.2s;
+}
+
+.input-button-wrapper input:focus {
+    outline: none;
+    border-color: #2271b1;
+}
+
+.validate-btn {
+    padding: 12px 24px;
+    background: #2271b1;
+    color: #fff;
+    border: none;
+    border-radius: 4px;
+    cursor: pointer;
+    font-weight: 600;
+    white-space: nowrap;
+    transition: background 0.2s;
+}
+
+.validate-btn:hover {
+    background: #135e96;
+}
+
+.validate-btn:disabled {
+    background: #ccc;
+    cursor: not-allowed;
+}
+
+.helper-text {
+    margin: 8px 0 0 0;
+    font-size: 13px;
+    color: #666;
+}
+
+.helper-text a {
+    color: #2271b1;
+    text-decoration: none;
+}
+
+.helper-text a:hover {
+    text-decoration: underline;
+}
+
+.message {
+    padding: 12px 16px;
+    border-radius: 4px;
+    margin-top: 16px;
+    font-size: 14px;
+}
+
+.message.success {
+    background: #d4edda;
+    color: #155724;
+    border: 1px solid #c3e6cb;
+}
+
+.message.error {
+    background: #f8d7da;
+    color: #721c24;
+    border: 1px solid #f5c6cb;
+}
+
+/* Success State Styles */
+.referral-success-state {
+    text-align: center;
+}
+
+.success-icon {
+    width: 80px;
+    height: 80px;
+    margin: 0 auto 20px;
+    background: #28a745;
+    border-radius: 50%;
+    display: flex;
+    align-items: center;
+    justify-content: center;
+    color: #fff;
+    font-size: 40px;
+}
+
+.success-content h3 {
+    color: #28a745;
+    margin: 0 0 12px 0;
+}
+
+.reward-highlight {
+    background: #e7f5ff;
+    padding: 20px;
+    border-radius: 6px;
+    margin: 20px 0;
+    border-left: 4px solid #2271b1;
+}
+
+.reward-highlight strong {
+    color: #2271b1;
+    font-size: 18px;
+}
+
+.cta-button {
+    display: inline-block;
+    padding: 14px 32px;
+    background: #2271b1;
+    color: #fff;
+    text-decoration: none;
+    border-radius: 4px;
+    font-weight: 600;
+    margin-top: 16px;
+    transition: background 0.2s;
+}
+
+.cta-button:hover {
+    background: #135e96;
+}
+
+.referred-by {
+    margin-top: 16px;
+    padding-top: 16px;
+    border-top: 1px solid #ddd;
+    font-size: 13px;
+    color: #666;
+}
+
+.loading-spinner {
+    display: inline-block;
+    width: 16px;
+    height: 16px;
+    border: 2px solid #f3f3f3;
+    border-top: 2px solid #2271b1;
+    border-radius: 50%;
+    animation: spin 1s linear infinite;
+    margin-left: 8px;
+    vertical-align: middle;
+}
+
+@keyframes spin {
+    0% { transform: rotate(0deg); }
+    100% { transform: rotate(360deg); }
+}
+
+/* Responsive */
+@media (max-width: 600px) {
+    .input-button-wrapper {
+        flex-direction: column;
+    }
+
+    .validate-btn {
+        width: 100%;
+    }
+
+    .link-copy-wrapper {
+        flex-direction: column;
+    }
+
+    .copy-link-btn {
+        width: 100%;
+    }
+}
\ No newline at end of file

--
Gitblit v1.10.0