*,::before,::after{box-sizing:border-box}
body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}
ul[role='list'],ol[role='list']{list-style:none}
html:focus-within{scroll-behavior:smooth}
body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5}
a:not([class]){text-decoration-skip-ink:auto}
img,picture{max-width:100%;display:block}
input,button,textarea,select{font:inherit}
@media (prefers-reduced-motion: reduce) {
html:focus-within{scroll-behavior:auto}
*,::before,::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}





/* **************************************** */
/* * Fonts */
/* **************************************** */
/* @import url("https://p.typekit.net/p.css?s=1&k=nmg0fee&ht=tk&f=10326.10327.41110.41111.52628.52633.52634.52635&a=83357123&app=typekit&e=css");

@font-face {
font-family:"alternate-gothic-no-1-d";
src:url("https://use.typekit.net/af/9fa845/000000000000000000010d5b/27/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"),url("https://use.typekit.net/af/9fa845/000000000000000000010d5b/27/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"),url("https://use.typekit.net/af/9fa845/000000000000000000010d5b/27/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
font-display:auto;font-style:normal;font-weight:400;font-stretch:normal;
}

@font-face {
font-family:"alternate-gothic-no-2-d";
src:url("https://use.typekit.net/af/1a70db/000000000000000077359df8/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"),url("https://use.typekit.net/af/1a70db/000000000000000077359df8/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"),url("https://use.typekit.net/af/1a70db/000000000000000077359df8/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
font-display:auto;font-style:normal;font-weight:400;font-stretch:normal;
}

@font-face {
font-family:"roc-grotesk";
src:url("https://use.typekit.net/af/5eb19c/00000000000000007735b7d0/30/l?subset_id=2&fvd=n5&v=3") format("woff2"),url("https://use.typekit.net/af/5eb19c/00000000000000007735b7d0/30/d?subset_id=2&fvd=n5&v=3") format("woff"),url("https://use.typekit.net/af/5eb19c/00000000000000007735b7d0/30/a?subset_id=2&fvd=n5&v=3") format("opentype");
font-display:auto;font-style:normal;font-weight:500;font-stretch:normal;
}

@font-face {
font-family:"roc-grotesk";
src:url("https://use.typekit.net/af/97dd77/00000000000000007735b7d4/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2"),url("https://use.typekit.net/af/97dd77/00000000000000007735b7d4/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff"),url("https://use.typekit.net/af/97dd77/00000000000000007735b7d4/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("opentype");
font-display:auto;font-style:normal;font-weight:400;font-stretch:normal;
}

@font-face {
font-family:"larken";
src:url("https://use.typekit.net/af/e4ca2a/0000000000000000774c4d90/30/l?subset_id=2&fvd=i4&v=3") format("woff2"),url("https://use.typekit.net/af/e4ca2a/0000000000000000774c4d90/30/d?subset_id=2&fvd=i4&v=3") format("woff"),url("https://use.typekit.net/af/e4ca2a/0000000000000000774c4d90/30/a?subset_id=2&fvd=i4&v=3") format("opentype");
font-display:auto;font-style:italic;font-weight:400;font-stretch:normal;
}

@font-face {
font-family:"larken";
src:url("https://use.typekit.net/af/61489c/0000000000000000774c4d91/30/l?subset_id=2&fvd=n4&v=3") format("woff2"),url("https://use.typekit.net/af/61489c/0000000000000000774c4d91/30/d?subset_id=2&fvd=n4&v=3") format("woff"),url("https://use.typekit.net/af/61489c/0000000000000000774c4d91/30/a?subset_id=2&fvd=n4&v=3") format("opentype");
font-display:auto;font-style:normal;font-weight:400;font-stretch:normal;
}

@font-face {
font-family:"larken";
src:url("https://use.typekit.net/af/23a78c/0000000000000000774c4d8d/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n1&v=3") format("woff2"),url("https://use.typekit.net/af/23a78c/0000000000000000774c4d8d/30/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n1&v=3") format("woff"),url("https://use.typekit.net/af/23a78c/0000000000000000774c4d8d/30/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n1&v=3") format("opentype");
font-display:auto;font-style:normal;font-weight:100;font-stretch:normal;
}

@font-face {
font-family:"larken";
src:url("https://use.typekit.net/af/91751c/0000000000000000774c4d8e/30/l?subset_id=2&fvd=i1&v=3") format("woff2"),url("https://use.typekit.net/af/91751c/0000000000000000774c4d8e/30/d?subset_id=2&fvd=i1&v=3") format("woff"),url("https://use.typekit.net/af/91751c/0000000000000000774c4d8e/30/a?subset_id=2&fvd=i1&v=3") format("opentype");
font-display:auto;font-style:italic;font-weight:100;font-stretch:normal;
} */
/* **************************************** */






/* **************************************** */
/* SETUP */
/* **************************************** */
body,
html {
    min-width: 320px;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    overflow: hidden;
    color: #000000;
    font-family: "Work Sans", sans-serif;
    font-variant-numeric: proportional-nums;
}

body.form-body {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    height: 100vh !important;
}

:root {
    --success: #28a745;
    --info: #17a2b8;
    --warning: #ffc107;
    --danger: #e44141;
    --danger-dark: #942b2b;

    --blue: #007bff;
    --red: #dc3545;
    --grey: #c6c6c6;
    --dark-grey: grey;
    --super-light-grey: #f3f3f3;
    --light-grey: lightgray;
    --grey-hover: #f1f3f5;
    --brand-green-light: #E6F5E7;

    --brand-white: #F6F6F3;
    --brand-black: #060400;

    --brand-primary: #2d2e83; 
    --brand-primary-hover: #20215d;
    --brand-secondary: #ff0000;
}

*,
:after,
:before {
    box-sizing: inherit
}

h1,
h2,
h3,
h4 {
    color: var(--brand-black);
}

a {
    text-decoration: none;
}

a.link {
    text-decoration: underline;
    color: var(--brand-primary);
    font-weight: 500;
}

a.link:hover {
    transition: .3s;
    cursor: pointer;
    text-decoration: none;
}

/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.error-input {
    border: 2px solid red !important;
    background: #f1e2e2 !important;
}


/* Firefox */
input[type=number] {-moz-appearance: textfield;}

.clear {
    clear: both
}

.left {
    float: left;
    width: 49%
}

.right {
    float: right;
    width: 49%
}

.third {
    width: 33%;
    float: left;
}

.sample-txt {
    color: var(--brand-white);
    text-align: center;
}

.subtle-hr {
    height: 1.25px;
    width: 100%;
    background: rgba(129, 129, 129, 0.13);
    margin: 10px 0;
}

.sample-txt a {
    color: red;
}

.sample-txt a:hover {
    text-decoration: underline;
}

.uk-modal-dialog h2 {
    font-size: 24px;
    font-weight: 500;
}

.embed-link {
    display: block;
}

.map-tooltip {
    position: absolute;
    background: #fff;
    border: 1px solid #ccc;
    padding: 4px 8px;
    border-radius: 4px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
    pointer-events: none;
    display: none;
    z-index: 1000;
}

.noty_bar {
    font-size: 20px !important;
    box-shadow: 0 2px 15px 0 rgb(0 0 0 / 10%) !important;
}

gmp-internal-camera-control {
    display: none !important;
}


.input-grid {
    display: flex;
    margin-bottom: 12px;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}

.input-grid .field,
.input-grid .form-group {
    flex-basis: 47%;
    flex-grow: 1;
    flex-shrink: 0;
    margin-bottom: 0;
}

.custom-context-menu {
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    display: none;
    z-index: 1000;
}
.custom-context-menu .menu-item {
    padding: 5px 10px;
    cursor: pointer;
}
.custom-context-menu .menu-item:hover {
    background: #f0f0f0;
}

.password-input-outer {
    position: relative;
}

button.password-eye,
button.password-repeat-eye {
    position: absolute;
    top: 1px;
    right: 1px;
    height: 39px;
    width: 40px;
    background: none;
    border: none;
    border-left: 1px solid grey;
    border-radius: 0 6px 6px 0;
}

button.password-eye:hover,
button.password-repeat-eye:hover {
    background: #ddd;
    cursor: pointer;
    transition: .3s;
}

.error-alert {
    position: absolute;
    z-index: 999999999;
    top: 90px;
    left: 50%;
    transform: translateX(-50%);
    background: red;
    padding: 12px 20px;
    max-width: 650px;
    text-align: center;
    font-weight: 500;
    color: white;
    font-size: 18px;
    border-radius: 8px;
    box-shadow: 0 2px 15px 0 rgb(0 0 0 / 10%);
}

.page-header {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    margin-bottom: 12px;
    border-bottom: 2px solid #ccc;
    padding-bottom: 12px;
}

.content-width {
    width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

.content-width-split {
    display: flex;
    gap: 40px;
    align-items: flex-start;
    flex-wrap: wrap;
}

.content-width-split .split-left {
    flex: 1 1 400px; /* can shrink, but not below 400px */
    min-width: 400px;
}

.form-section {
    background: #fff;
    border: 1px solid rgba(0,1,15,.2);
    border-radius: 8px;
    padding: 16px;
    box-shadow: 0 6px 12px rgba(0,0,0,.1);
}

.content-width-split .breakdown-section {
    flex: 0 0 310px;
    max-width: 310px;
    background: #fff;
    border: 1px solid rgba(0,1,15,.2);
    border-radius: 8px;
    padding: 16px;
    box-shadow: 0 6px 12px rgba(0,0,0,.1);
}

.breakdown-section h3 {
    font-size: 22px;
    font-weight: 600;
    line-height: 33px;
}

.cost-split {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
}

.cost-split .cost-grey-title {
    font-size: 14px;
    font-weight: 500;
    line-height: 21px;
    color: #01101e80;
}

.cost-split .cost-grey-figure {
    font-size: 18px;
    font-weight: 700;
    line-height: 27px;
}
/* **************************************** */





/* **************************************** */
/* * Stripe */
/* **************************************** */
#submit {
    background-color: #ff8800;
    color: #ffffff;
    border: 0;
    border-radius: 4px;
    padding: 12px 16px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    width: 100%;
    text-align: center;
    margin-top: 16px;
}

#submit:hover {
    background-color: #c26c0a;
}

#submit:disabled {
    opacity: 0.5;
    cursor: default;
}

#spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid #ffffff;
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

.hidden {
    display: none !important;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}


.payment-wrapper {
    font-family: 'Inter', sans-serif;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
}
.payment-box {
    background: #fff;
    border-radius: 16px;
    padding: 40px 60px;
    text-align: center;
    max-width: 450px;
}
.payment-icon {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    display: inline-block;
    position: relative;
    margin-bottom: 20px;
}
.payment-icon.success {
    border: 4px solid #4BB543;
    animation: payment-pop .5s ease;
}
.payment-icon.fail {
    border: 4px solid #d9534f;
    animation: payment-pop .5s ease;
}
.payment-icon::before, .payment-icon::after {
    content: "";
    position: absolute;
}
.payment-icon.success::before {
    width: 25px;
    height: 50px;
    left: 32px;
    top: 20px;
    border-right: 5px solid #4BB543;
    border-bottom: 5px solid #4BB543;
    transform: rotate(45deg);
}
.payment-icon.fail::before,
.payment-icon.fail::after {
    width: 60px;
    height: 5px;
    background: #d9534f;
    top: 48px;
    left: 20px;
}
.payment-icon.fail::before { transform: rotate(45deg); }
.payment-icon.fail::after { transform: rotate(-45deg); }
@keyframes payment-pop {
    0% { transform: scale(0); opacity: 0; }
    100% { transform: scale(1); opacity: 1; }
}
.payment-details {
    margin-top: 20px;
    color: #333;
}
.payment-details p {
    margin: 6px 0;
    font-size: 15px;
}
.payment-amount {
    font-size: 22px;
    font-weight: 600;
    color: #314868;
    margin-bottom: 10px;
}
.payment-btn {
    display: inline-block;
    margin-top: 25px;
    background: #314868;
    color: #fff;
    text-decoration: none;
    padding: 10px 22px;
    border-radius: 6px;
}

/* **************************************** */





/* **************************************** */
/* * Nice JS Inputs */
/* **************************************** */
.field {
    width: 100%;
    float: left;
    padding: .4285714286em 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.field__input-wrapper {
    position: relative;
}

.field__input-wrapper label {
    line-height: 1.3em;
    word-wrap: break-word;
    word-break: break-word;
    -webkit-font-smoothing: subpixel-antialiased;
    -webkit-box-direction: normal;
    text-align: left;
    margin: 0.5em 0;
    display: block;
    font-size: 11px;
    font-weight: 400;
    position: absolute;
    top: 0;
    width: 90%;
    margin-top: 0.4285714286em;
    margin-left: 1px;
    padding: 0 0.9166666667em;
    z-index: 1;
    user-select: none;
    transform: translateY(3px);
    pointer-events: none;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    box-sizing: border-box;
    opacity: 0;
    transition: all .2s ease-out;
    color: var(--brand-black);
    /* background: #f6f8fa; */
}

.field__input-wrapper select,
.field__input-wrapper textarea,
.field__input-wrapper input,
.field__input-wrapper .StripeElement {
    margin: 0;
    display: block;
    width: 100%;
    padding: 11px 0.7857142857em;
    line-height: inherit;
    border-radius: 5px;
    background-color: var(--light-gray);
    color: var(--brand-black);
    transition: all .2s ease-out;
    border: 1px solid #d6d6d6;
    position: relative;
}

.field--show-floating-label .field__label {
    -webkit-transform: none;
    transform: none;
    opacity: 1
}

.field--show-floating-label .field__input {
    padding-top: 17px;
    padding-bottom: .3571428571em;
}

.field--show-floating-label .field__input::-webkit-input-placeholder {
    color: transparent
}

.field--show-floating-label .field__input:-moz-placeholder {
    color: transparent;
    opacity: 1
}

.field--show-floating-label .field__input::-moz-placeholder {
    color: transparent;
    opacity: 1
}

.field--show-floating-label .field__input:-ms-input-placeholder {
    color: transparent
}

select.field__input {
    -webkit-appearance: none;
    -moz-appearance: none;
    text-indent: 1px;
    text-overflow: '';
}

.field__caret {
    display: block;
    width: 2.1428571429em;
    height: 43%;
    pointer-events: none;
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translate(0%, -50%);
    transform: translate(0%, -50%);
    border-left: 1px rgba(179, 179, 179, 0.5) solid;
}

.field__caret svg {
    color: #919191;
    position: absolute;
    margin-left: -2px;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 10px;
    height: 10px;
    display: inline-block;
    vertical-align: middle;
}

.field--show-floating-label .field__input {
    padding-top: 17px;
    padding-bottom: .3571428571em;
}

.field--show-floating-label .field__input::-webkit-input-placeholder {
    color: transparent
}

.field--show-floating-label .field__input:-moz-placeholder {
    color: transparent;
    opacity: 1
}

.field--show-floating-label .field__input::-moz-placeholder {
    color: transparent;
    opacity: 1
}

.field--show-floating-label .field__input:-ms-input-placeholder {
    color: transparent
}

#payment-form .input-group>.form-control {
    border: 1px transparent solid;
    display: block;
    width: 100%;
    border-radius: 0;
    background-color: #fff;
    color: var(--brand-black);
    border-color: #d9d9d9;
    transition: all .2s ease-out;
    height: 47px;
    padding: .9285714286em .7857142857em;
}

.cvc-icon {
    position: absolute;
    top: 8px;
    right: 14px;
}

.card-icons {
    margin: 0;
    /* justify-content: flex-end; */
    position: absolute;
    top: 14px;
    right: -5px;
    border-color: transparent !important;
    background: none !important;
    box-shadow: none !important;
    outline: none !important;
    pointer-events: none;
    /* display: flex; */
    /* align-items: center; */
    bottom: 0;
    transition: background 0.15s ease, border 0.15s ease, box-shadow 0.15s ease, color 0.15s ease;
}

.card-icons .card-images {
    display: flex;
    justify-content: space-between;
    position: absolute;
    width: 82px;
    top: 0;
    right: 18px;
}

.card-icons .card-images .card-brand-item:nth-child(2) {
    margin: 0 5px;
}

.card-error-icon {
    position: absolute;
    top: 0;
    right: 13px;
    z-index: 999;
    width: 24px;
}

.card-error-icon svg {
    fill: red;
}


.loading-icon {
    display: inline-block;
    position: relative;
    width: 20px;
    height: 20px;
}

.loading-icon div {
    box-sizing: border-box;
    display: block;
    position: absolute;
    width: 12px;
    height: 12px;
    margin: 5px;
    border: 2px solid #fff;
    border-radius: 50%;
    animation: loading-icon 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
    border-color: #fff transparent transparent transparent;
}

.loading-icon div:nth-child(1) {
    animation-delay: -0.45s;
}

.loading-icon div:nth-child(2) {
    animation-delay: -0.3s;
}

.loading-icon div:nth-child(3) {
    animation-delay: -0.15s;
}

@keyframes loading-icon {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}
/* **************************************** */





/* **************************************** */
/* * GOV.uk form */
/* **************************************** */
.form-group {
    color: #0b0c0c;
    overflow-wrap: anywhere;
    word-break: break-word;
    -webkit-font-smoothing: antialiased;
    font-weight: 400;
    font-size: 19px;
    line-height: 1.3157894737;
    text-align: left;
    vertical-align: baseline;
    border: none;
    margin: 0;
    padding: 0;
    margin-top: 0;
    box-sizing: border-box;
    margin-bottom: 20px;
    flex-grow: 1;
    flex-basis: 320px;
    position: relative;
}

.form-group>label {
    overflow-wrap: anywhere;
    word-break: break-word;
    text-align: left;
    border: none;
    margin: 0;
    padding: 0;
    display: block;
    margin-bottom: 0;
    text-transform: none;
    font-size: 17px;
    line-height: 1.75;
    font-weight: normal;
}

.form-group>input,
.form-group>select,
.form-group>textarea,
#envelopeStrapline {
    overflow-wrap: anywhere;
    word-break: break-word;
    -webkit-font-smoothing: antialiased;
    appearance: none;
    border: 2px solid #000000;
    border-radius: 0;
    box-sizing: border-box;
    font-weight: 400;
    height: 45px;
    margin-top: 0;
    padding: 8px 12px;
    font-size: 16px;
    line-height: 20px;
    width: 100%;
    border-radius: 2px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 2px solid #ccc;
    border-radius: 10px;
    padding: 10px 16px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 16px;
    background: white;

}

.form-group>select {
    background: #f2f2f2 url(../images/down-triangle.svg) no-repeat;
    background-position: right;
    background-size: 20px;
    padding-right: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 2px solid #ccc;
    border-radius: 10px;
    padding: 10px 16px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 16px;
    background: white;
}

.form-group>textarea {
    height: 150px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 2px solid #ccc;
    border-radius: 10px;
    padding: 10px 16px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 16px;
    background: white;
}

fieldset#printTypeSelect {
    margin: 0;
}

.form-group p {
    margin: 0 0 10px 0;
    font-size: 14px;
}


.select2 {
    width: 100% !important;
}

.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default .select2-selection--multiple {
    border: solid black 2px !important;
    border-radius: 0 !important;
}

#as_user_accounts .select2 {
    width: 250px !important;
}

#as_user_accounts .form-group {
    margin-left: 10px !important;
}
/* **************************************** */




/* **************************************** */
/* * Nav and footer */
/* **************************************** */
nav.header {
    width: 100vw;
    padding: 12px 15px 12px 8px;
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    gap:12px;
    background-color: white;
    box-shadow: 0 6px 12px rgba(0,0,0,.1);
}

nav.header > .header-left,
nav.header > .header-right {
    display: flex;
    flex-basis: 400px;
    flex-grow: 1;
    flex-shrink: 0;
    justify-content: flex-start;
    align-items: center;
    gap: 20px;
}

nav.header>.header-right {
    justify-content: flex-end !important;
}



footer.site-footer {
    background: white;
    text-align: center;
    padding: 15px 0;
    font-size: 14px;
}

.site-footer a {
    text-decoration: none;
    color: inherit;
    padding: 0 5px;
}

.site-footer span {
    padding: 0 5px;
    color: #666;
}



.header-left img.logo {
    width: 60px;
    max-height: 45px;
    filter: brightness(0);
}

.bg-color-wrapper {
    background: #f7f7f7;
    width: 100vw;
    height: 100vh;
    position: absolute;
    z-index: -99999;
}

input.search-input {
    border-radius: 100px;
    border: 2px solid black;
    background: url(../images/search-icon.svg) no-repeat;
    background-position: 10px center;
    background-size: 20px;
    padding-left: 40px;
    color: black;
    box-sizing: border-box;
    height: 40px;
    /* max-width: 300px; */
    padding-top: 3px;
    margin-right: -6px;
    padding-bottom: 4px;
    width: 100%;;
}

input.search-input::placeholder {
    color: #000;
}

.custom-autocomplete-dropdown {
    position: absolute;
    z-index: 1000;
    background: #fff;
    border: 1px solid #ccc;
    max-height: 250px;
    overflow-y: auto;
    display: none;
    top: 48px;
    width: 100%;
    background: var(--brand-black);
    border: 2px solid white;
    border-radius: 12px;
    scrollbar-color: var(--brand-white) var(--brand-black); /* thumb track */
    scrollbar-width: thin; /* Thin scrollbar */
    padding-right: 8px 
}

.dropdown-item:hover {
    cursor: pointer;
    transition: .3s;
    background: var(--grey);
}

.custom-item {
    position: relative;
}

.enter-icon {
    padding: 0px 3px;
    background-color: var(--brand-black);
    border: 1px solid var(--grey);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    position: absolute;
    right: 7px;
    top: 5px;
    border-radius: 4px;
}

.enter-icon svg {
    width: 15px;
    fill: white;
}


.custom-autocomplete-dropdown::-webkit-scrollbar {
    width: 8px; /* Width of the scrollbar */
}

.custom-autocomplete-dropdown::-webkit-scrollbar-track {
    background: var(--brand-black);
    border-radius: 8px; /* Matches the outer div's border radius */
    margin: 4px; /* Adds space at the top and bottom */
}

.custom-autocomplete-dropdown::-webkit-scrollbar-thumb {
    background: var(--brand-white);
    border-radius: 8px; /* Makes the scrollbar thumb rounded */
}

.custom-autocomplete-dropdown::-webkit-scrollbar-thumb:hover {
    background: #555;
}


.dropdown-item {
    color: var(--brand-white);
    padding: 6px 10px;
    font-size: 14px;
    white-space: nowrap;
    text-overflow: ellipsis;
    max-width: 100%;
    overflow-x: hidden;
    position: relative;
}

.pac-container {
    display: none !important;
}

.header-left >input.search-input::placeholder {
    color: var(--brand-white);
}

.undo-redo-outer {
    display: flex;
    flex-wrap: nowrap;
    gap: 12px;
    justify-content: space-between;
    align-items: center;
}

.undo-redo-outer img {
    width: 35px;
}

.undo-redo-outer img:hover {
    transition: .3s;
    cursor: pointer;
    opacity: 0.5;
}

.map-name-header-outer,
.map-search-header-outer {
    display: flex;
    justify-content: flex-start;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0;
    position: relative;
}

.map-search-header-outer {
    width: 350px;
}

.header-right .map-name {
    border-radius: 100px 0 0 100px;
    border: 2px solid var(--brand-white);
    background: transparent;
    color: var(--brand-white);
    box-sizing: border-box;
    height: 40px;
    padding: 5px 15px;
    text-wrap: nowrap;
    padding-top: 7px;
    width: 220px;
    text-align: center;
    border-right: none;
}

button.save-map-header-btn {
    border-radius: 0 100px 100px 0;
    background: var(--brand-white);
    height: 40px;
    margin: 0;
    border: 2px solid var(--brand-white);
    line-height: normal;
    font-weight: 600;
    padding: 0 12px;
}

button.save-map-header-btn:hover {    
    cursor: pointer;
    transition: .3s;
    opacity: .6;
}

button.save-map-header-btn>svg {
    width: 14px;
    margin: 0 8px;
}

button.header-settings-btn {
    border-radius: 0 !important;
}

#w3w-button svg {
    width: 20px;
    margin: 0 8px 0 5px;
}

button.upload-artwork-btn {
    width: 100%;
    background: black;
    color: white;
    border: 2px solid black;
    fill: white;
    display: flex;
    justify-content: center;
    gap: 15px;
    padding: 10px 15px;
    border-radius: 6px;
    margin-bottom: 12px;
    font-weight: 600;
}

button.upload-artwork-btn:hover {
    background: white;
    color: black;
    fill: black;
    cursor: pointer;
    transition: .3s;
    cursor: pointer;
}

button.upload-artwork-btn svg {
    width: 24px;
}

.artwork-btn {
    font-weight: 400;
    line-height: 20px;
    border: 3px solid var(--brand-primary);
    border-radius: 10px;
    padding: 10px 16px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 16px;
    color: white;
    font-weight: 600;
    background: var(--brand-primary);
}

.artwork-btn:hover {
    background: white;
    color: var(--brand-primary);
}

.artwork-btn-secondary {
    font-weight: 400;
    line-height: 20px;
    border: 3px solid var(--brand-primary);
    border-radius: 10px;
    padding: 10px 16px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 16px;
    background: white;
}

.artwork-btn-secondary:hover {
    background: var(--brand-primary);
    color: white;
}

.notification-hover,
.notification-hover img {
    height: 40px;
}

.notifications>img {
    width: 100%;
    height: 100%;
}

.notifications>.notification-dot {
    background: var(--red);
    color: var(--brand-white);
    font-size: 12px;
    position: absolute;
    top: 0;
    right: -2px;
    border-radius: 100px;
    padding: 0px 8px;
}

.notification-hover:hover {
    transition: .3s;
    cursor: pointer;
    opacity: 0.5;
}

.notifications-dropdown {
    position: absolute;
    right: 8px;
    top: 70px;
    border-radius: 8px;
    background: var(--brand-white);
    padding: 10px 16px;
    box-shadow: 0 2px 15px 0 rgb(0 0 0 / 10%);
    width: 300px;
    max-height: 400px;
    overflow-y: auto;
    z-index: 99;
}

.notifications-dropdown h2 {
    margin: 0px 0 5px 0;
    font-size: 22px;
}

.notifications-list .notifications__el {
    border-top: 1.5px solid var(--grey);
    padding: 10px 0;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: nowrap;
    gap: 16px;
}

.notification__img {
    width: 190px;
    display: block;
}

span.notification__msg {
    flex-grow: 1;
    color: var(--brand-black);
}

.notifications__nameplate {
    background: #4472c4;
    border-radius: 100px;
    text-align: center;
    height: 82px;
    font-size: 35px;
    padding: 18px 0;
}

.notification__img img {
    border-radius: 6px;
    border: 1.5px solid var(--grey);
}

.notifications-list {
    max-height: 250px;
    overflow-y: auto;
}

.header-dashboard-btn {
    color: var(--brand-black);
    background-color: var(--brand-white);
    border-radius: 100px;
    height: 40px;
    font-weight: 600;
    border: none;
    padding: 10px 20px;
    line-height: normal;
    white-space: nowrap;
}

.header-dashboard-btn:hover {
    transition: .3s;
    cursor: pointer;
    opacity: 0.5;
    text-decoration: none;
    color: var(--brand-black);
}


.bar {
    height: 8px;
    width: 100%;
    overflow: hidden;
    border-radius: 100px;
    border: 1px solid lightgrey;
}

.loading-bar {
    height: 100%;
    width: 0%;
    background-color: #6200ea;
    transition: width 0.4s ease;
}
/* **************************************** */





/* **************************************** */
/* * Sidebar */
/* **************************************** */
section.sidebar {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    height: calc(100vh - 65px);
    box-sizing: border-box;
    position: relative;
    width: 480px;
    background: white;
    overflow-y: auto;
}

.hidden-sidebar-section svg {
    max-width: 17px;
}

.sidebar-bottom {
    margin-top: auto;
}

.sidebar-btn {
    margin-bottom: 30px;
    line-height: normal;
}

.sidebar-btn:hover > svg {
    cursor: pointer;
    transition: .3s;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0px 2px 2px 2px rgba(64, 87, 109, 0.25), 0px 2px 4px -1px rgba(64, 87, 109, .25);
}

.sidebar-btn svg {
    height: 41px;
    min-width: 41px;
    display: block;
    margin: 0 auto;
    padding: 9px;
    max-width: 100%;
}

.sidebar-btn span {
    font-weight: 600;
    text-align: center;
    font-size: 12px;
    display: block;
    width: 100%;
}

.sidebar-btn:last-child {
    margin-bottom: 0;
}

.icon-filled>svg {
    fill: var(--brand-primary);
}

svg.icon-filled path {
    fill: var(--brand-primary);
}

.sidebar-right-outer {
    position: absolute;
    right: 10px;
    width: 375px;
    max-width: 100vw;
    max-height: calc(100vh - 155px);
    top: 10px;
    z-index: 9;
    overflow-y: auto;
    border-radius: 12px;
}

.sidebar-right {
    font-size: 16px;
    background: var(--brand-white);
    border: 1.5px solid #d7d7d7;
    padding: 15px;
    box-shadow: rgba(64, 87, 109, 0.25) 0px 0px 0px 1px, rgba(64, 87, 109, 0.25) 0px 6px 20px 7px;
    border-radius: 12px;
}

#sidebarHidden_areas {
    margin-top: 20px;
}

#nextBtnHome {
    bottom: 30px;
    position: absolute;
    right: 10px;
    z-index: 999;
    width: 375px;
}

.sidebar-close {
    width: 30px;
    position: absolute;
    top: 8px;
    right: 8px;
}

.sidebar-close:hover {
    cursor: pointer;
    transition: .3s;
    opacity: 0.6;
}

.hidden-sidebar {
    transition: .4s;
    /* position: absolute; */
    /* left: 10px; */
    /* width: 330px; */
    max-width: 100vw;
    /* max-height: calc(100vh - 235px); */
    /* background: var(--brand-white); */
    top: 10px;
    /* border-left: 1.5px solid #d7d7d7; */
    padding: 12px;
    z-index: 9;
    /* box-shadow: rgba(64, 87, 109, 0.25) 0px 0px 0px 1px, rgba(64, 87, 109, 0.25) 0px 6px 20px 7px; */
    border-radius: 12px;
    /* overflow-y: auto; */
}

.shape-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    font-weight: 600;
    padding: 10px 0;
    border-bottom: 2px solid #d7d7d7;
}

.sidebar h2 {
    font-weight: bold;
    margin: 10px 0 20px 0;
    font-size: 25px;
}

.sidebar h3 {
    font-weight: bold;
    margin: 8px 0 15px 0;
}

.drawing-tools-grid {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    flex-wrap: wrap;
    text-align: center;
    font-weight: bold;
    font-size: 18px;
}

.drawing-tools-grid .tool__el {
    flex-basis: 65px;
    flex-grow: 0;
    flex-shrink: 0;
    font-size: 12px;
    font-weight: 400;
    flex-direction: column;
}

.tool__el img {
    width: 65px;
    margin: 0 auto;
    opacity: .6;
    border: .6px solid var(--light-grey);
    border-radius: 8px;
    padding: 15px;
    height: 65px;
}

.drawing-tools-grid .tool__el img:hover {
    cursor: pointer;
    transition: .3s;
    background: var(--grey-hover);
}

.layer-filters-outer {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}

.layer-filters-outer label {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 5px;
    justify-content: flex-start;
    flex-basis: 50%;
    flex-grow: 1;
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 8px;
    white-space: nowrap;
}

.layer-filters-outer svg {
    width: 20px;
}

#propertyTypesSelect {
    padding: 0;
    border: none;
    border-bottom: .6px solid var(--grey);
    margin: 0 0 16px 0;
    padding-bottom: 16px;
}

.comment__el {
    text-wrap: wrap;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: .6px solid var(--grey);
}

.comment__el p {
    margin: 8px 0 0 0;
}

.two-cols {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    flex-wrap: nowrap;
}

.two-cols .col {
    flex: 50%;
}


section.triple-col-width {
    max-width: 1650px;
    padding: 10px 40px;
    display: flex;
    justify-content: space-between;
    gap: 30px;
    align-items: start;
    flex-wrap: wrap;
    margin: 0 auto;
    margin-top: 40px;
}

.triple-col {flex: 1;}

.triple-col-width h2,
.triple-col-width h3 {
    color: var(--brand-primary);
}

#optionsCol {
    max-width: 300px;
}

#artworkCol {
    flex: 2;
    max-width: 600px;
}

#summaryCol {
    max-width: 380px;
    border: 3px solid #4f51d7;
    border-radius: 10px;
    padding: 20px;
}


.print-needed-radio {
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-family: 'Poppins', sans-serif;
  margin-bottom: 20px;
}

.print-needed-radio label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: 2px solid #ccc;
  border-radius: 10px;
  padding: 10px 16px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 16px;
}

.print-needed-radio input:checked + label {
  border: 3px solid #3e349a;
}

.radio-dot,
.radio-dot-filled {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid #000;
  display: inline-block;
  transition: all 0.2s ease;
}

input:checked + label .radio-dot {
  background: #3e349a;
  border-color: #3e349a;
}

input:checked + label .radio-dot-filled {
  background: #3e349a;
  border-color: #3e349a;
}
/* **************************************** */





/* **************************************** */
/* * Calendar */
/* **************************************** */
.ui-datepicker {
  width: 100%;
  border: none;
  background: transparent;
  font-family: "Poppins", sans-serif;
}

.ui-datepicker-header {
  background: none;
  border: none;
  color: #4a3ea2;
  font-weight: 700;
  text-align: center;
  font-size: 1.1em;
  padding: 10px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.ui-datepicker-prev, .ui-datepicker-next {
  color: white;
  cursor: pointer;
  border: 3px solid #4a3ea2;
  border-radius: 100px;
  width: 68px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  background: #4a3ea2;
}

.ui-datepicker-prev:hover, .ui-datepicker-next:hover {
  background: #4a3ea2;
  color: #fff;
}

.ui-datepicker-calendar {
  width: 100%;
  border-collapse: separate;
  border-spacing: 10px 12px;
  text-align: center;
}

.ui-datepicker-calendar th {
  color: #4a3ea2;
  font-weight: 600;
  padding-bottom: 4px;
}

.ui-datepicker-calendar td {
  padding: 0;
}

.ui-state-default {
  display: block;
  background: #fff;
  color: #000;
  border: 2px solid #000;
  border-radius: 25px;
  padding: 8px 0;
  font-size: 0.9em;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.2s ease;
}

.ui-state-hover {
  border-color: #4a3ea2;
  color: #4a3ea2;
}

.ui-state-active {
  background: #4a3ea2;
  border-color: #4a3ea2;
  color: #fff !important;
  font-weight: 600;
}

.ui-state-disabled {
  opacity: 0.4;
  pointer-events: none;
}
/* **************************************** */





/* **************************************** */
/* * Totals */
/* **************************************** */
section.bottom-bar {
    left: 73px;
    bottom: 0px;
    width: calc(100% - 73px);
    height: 66px;
    background: var(--brand-white);
    border: 1.5px solid #d7d7d7;
    padding: 18px;
    z-index: 99;
    line-height: normal;
    margin-top: auto;
    position: fixed;
}

.totals-box {
    display: flex;
    justify-content: flex-start;
    gap: 20px;
    align-items: center;
    float: right;
}

.total-counts-grid {
    border-top: .6px solid var(--light-gray);
    margin-top: 0;
    padding-top: 4px;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    gap: 25px;
    font-size: 13px;
    border-left: .6px solid var(--grey);
    padding-left: 12px;
}

.total-counts-grid span {}

button.job-summary-btn {
    background-color: var(--brand-primary);
    color: var(--brand-white);
    border: 2px solid var(--brand-primary);
    border-radius: 100px;
    padding: 8px 20px;
    font-weight: bold;
    line-height: normal;
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: nowrap;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 10px;
}

button.job-summary-btn:hover {
    cursor: pointer;
    transition: .3s;
    background: var(--brand-white);
    color: var(--brand-primary);
}

button.job-summary-btn svg {
    fill: white;
    width: 16px;
    margin-top: 5px;
}

button.job-summary-btn:hover svg {
    fill: var(--brand-primary);
}

.job-summary-box {
    position: absolute;
    z-index: 9999;
    background: white;
    padding: 22px;
    border-radius: 8px;
    bottom: 70px;
    left: calc(50% + 50px);
    transform: translateX(-50%);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    border: 1px solid #ccc;
    width: 520px;
}

.job-summary-box ul.summary-list {
    padding-left: 0;
    list-style: none;
    font-size: 18px;
    margin: 10px 0;
}

.job-summary-box ul.summary-list li {
    color: white;
    padding: 4px 14px;
    border-radius: 6px;
    font-weight: 500;
    margin: 10px 0;
}

.summary-split-cols {
    display: flex;
    justify-content: space-between;
    gap: 25px;
    align-items: center;
}

.summary-split-cols .form-group {
    margin-bottom: 0;
}

.job-summary-box h3 {
    text-align: center;
    margin-bottom: 16px;
}

.summary-el h4 {
    text-decoration: underline;
    margin-bottom: 10px;
}

.summary-el {
    margin: 20px 0;
}

.summary-el h4 svg {
    fill: green;
    width: 22px;
    margin-left: 12px;
}

span.summary-total-price {
    font-weight: bold;
    color: #71ad48;
}

textarea#summaryComments {
    width: 100%;
    height: 100px;
}

button#completeBookingBtn {
    margin: 0 auto;
}

button.share-map-details-btn {
    position: absolute;
    top: 20px;
    right: 20px;
}

#summaryList {
    padding-left: 0;
    list-style-type: none;
}
/* **************************************** */






/* **************************************** */
/* * Map and contianer  */
/* **************************************** */
section.sidebar-map-outer {
    width: 100vw;
    height: calc(100vh - 65px);
    display: flex;
    justify-content: flex-start;
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: 0;
    position: relative;
}

#map {
    height: 100%;
    width: 100%;
    display: block;
}
/* **************************************** */





/* **************************************** */
/* * Admin */
/* **************************************** */
body.admin-body {
    background: var(--super-light-grey);
    overflow-y: hidden;
}

.admin-sidebar {
    background: var(--super-light-grey) !important;
    height: 100vh !important;
}

section.admin-secondary-sidebar {
    width: 300px;
    padding: 25px;
    min-width: 300px;
    height: 100vh;
}

.admin-secondary-sidebar img {
    width: 100%;
    margin-bottom: 25px;
}

button.new-project-btn {
    width: 100%;
    border: none;
    background: var(--brand-primary);
    color: var(--brand-white);
    font-weight: bold;
    text-align: center;
    font-size: 22px;
    border-radius: 20px;
    padding: 6px 0;
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: center;
    line-height: normal;
}

button.new-project-btn svg {
    fill: white;
    width: 20px;
}

section.main-admin-area {
    width: calc(100% - 350px);
    height: 100%;
    background: var(--brand-white);
    margin: 20px 20px 20px 0;
    padding: 29px;
    border-radius: 40px;
}

.admin-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    gap: 16px;
    position: relative;
}

.admin-banner {
    width: 100%;
    background: var(--brand-primary);
    color: var(--brand-white);
    font-weight: bold;
    text-align: center;
    font-size: 40px;
    border-radius: 40px;
    padding: 5px 0;
    margin-top: 20px;
}

input.admin-search {
    background: var(--brand-white) url(../images/search-icon-black.svg) no-repeat;
    border-color: var(--brand-black);
    max-width: 400px;
    color: black;
    background-position: 10px center;
    background-size: 20px;
}

input.admin-search::placeholder {
    color: black !important;
}

.admin-top-right {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    gap: 10px;
}

span.user-initials {
    background: var(--brand-primary);
    color: var(--brand-white);
    font-weight: 500;
    text-align: center;
    font-size: 22px;
    border-radius: 100px;
    display: inline-block;
    padding-top: 10px;
    height: 50px;
    width: 50px;
    min-width: 50px;
}

.name-company {
    text-wrap: nowrap;
    text-overflow: ellipsis;
    max-width: 150px;
}

.name-company span {
    display: block;
}

.admin-user-dropdown {
    display: flex;
    gap: 17px;
}

.admin-user-dropdown svg {
    fill: var(--dark-grey);
    width: 30px;
}

.admin-filter-outer,
.admin-filter-right {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    flex-wrap: nowrap;
    height: 60px;
    margin: 20px 0;
}

.project-dropdown {
    border: none;
    background: transparent;
    color: black;
    font-size: 22px;
}

.account-dropdown {
    width: 250px;
    background: white;
    border-radius: 12px;
    border: 1px solid var(--light-gray);
    box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
    position: absolute;
    top: 60px;
    right: 0px;
    z-index: 99999999;
}

.account-dropdown ul {
    padding-left: 0;
    margin: 0;
    list-style: none;
}

.account-dropdown ul li {
    font-size: 18px;
    padding: 12px 20px;
    font-weight: 500;
}

.account-dropdown ul li:hover {
    background: var(--super-light-grey);
    cursor: pointer;
    transition: .3s;
}

.grid-changer {
    border: .6px solid var(--light-grey);
    border-radius: 8px;
    width: 40px;
    padding: 0 2px;
    height: 40px;
}

.filters-box {
    padding: 0 8px !important;
}

.grid-changer:hover {
    background: var(--grey-hover);
    cursor: pointer;
    transition: .3s;
}

.admin-filter-right svg {
    width: 100%;
    height: 100%;
}

.admin-grid,
.projects-grid {
    width: 100%;
    height: calc(100vh - 405px);
    display: flex;
    flex-wrap: wrap;
    gap: 18px; /* This controls both horizontal and vertical gaps */
    overflow-y: auto;
    overflow-x: hidden;
    align-content: flex-start; /* Aligns rows at the top to avoid excess vertical space */
    margin: 0 auto;
}

.grid__el {
    flex-grow: 0;
    flex-shrink: 0;
    height: auto;
    flex-basis: 295px;
    position: relative;
    max-width: 400px;
    padding: 10px 10px 30px 10px;
    border-radius: 50px;
    border: 3px solid var(--brand-white);
    position: relative;
}

.grid__el:hover {
    border-color: var(--grey);
    cursor: pointer;
    transition: .3s;
}

.grid__el:hover .grid-options-btn {
    display: block !important;
}

.grid__el h3 {
    font-size: 25px;
    margin: 0 0 20px 20px;
}

.grid__el-info {
    padding-left: 16px;
    position: relative;
}

.team-icon {
    width: 20px;
    height: 20px;
    position: absolute;
    top: 2px;
    right: 2px;
}

span.shared-group-icon {
    /* position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px; */
    padding: 5px;
    border-radius: 100px;
    background: var(--brand-primary);
    fill: white;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
}

.shared-group-icon svg {
    width: 25px;
    height: 25px;
}

#addTeamLink {
    border: 1px solid black;
    padding: 8px 12px;
    border-radius: 6px;
    white-space: nowrap;
    display: block;
    width: 100%;
    margin-top: 12px;
}

.grid__el img {
    border-radius: 40px;
    border: 2px solid var(--grey);
    margin-bottom: 20px;
    width: 300px;
    height: 230px;
}

.grid__el-info .name {
    font-size: 18px;
    display: block;
    font-weight: 600;
    text-wrap: nowrap;
    text-overflow: clip;
    max-width: 100%;
}

.grid__el-info .address-count, .grid__el-info .shared, .grid__el-info .created {
    display: block;
}

.grid__el-info span.shared-mini-icon {
    background: var(--brand-primary);
    padding: 6px 9px;
    border-radius: 100px;
    color: var(--brand-white);
    font-weight: bold;
    font-size: 12px;
    margin: 0 4px;
}

.grid__row td {
    position: relative;
}

img.grid-options-btn {
    position: absolute;
    top: 15px;
    right: 18px;
    background: var(--brand-white);
    padding: 3px 13px;
    border-radius: 14px !important;
    border: none !important;
    width: 53px;
    height: 30px;
    line-height: normal;
}

td>.grid-options-btn {
    display: block !important;
    position: unset !important;
}

.projects__grid img.grid-options-btn {
    top: 79px !important;
}

img.grid-options-btn:hover {
    cursor: pointer;
    transition: .3s;
    opacity: .6;
}

aside.admin-user-settings {
    position: absolute;
    top: 104px;
    right: 20px;
    background: var(--brand-white);
    padding: 25px;
    height: calc(100vh - 148px);
    border-radius: 0 0 40px 0;
    width: 300px;
    z-index: 99;
}

.admin-user-settings p {
    margin: 20px 0;
}

.admin-user-settings h4 {
    font-weight: bold;
    font-size: 20px;
}

.invite-members-btn {
    display: flex;
    justify-content: flex-start;
    gap: 12px;
    font-size: 18px;
    align-items: center;
    margin: 0px 0 20px 0;
    background: var(--brand-white);
    border: none;
    padding: 10px;
    border-radius: 10px;
}

.invite-members-btn img {width: 30px;}

.invite-members-btn:hover {
    background: var(--super-light-grey);
    cursor: pointer;
    transition: .3s;
}

#shapesList {}

.shapes-list-outer .result {
    width: 100%;
    padding: 10px;
    border-radius: 6px;
    border: 1.25px solid var(--light-grey);
    margin-bottom: 20px;
}

.shapes-list-outer .result img {
    width: 28px;
}

.shapes-list-outer .result .shape-head {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
}

.shape-sidebar-icon {
    width: 40px;
    height: 40px;
    padding: 6px;
    border-radius: 4px;
    box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
    border: .6px solid var(--grey);
}

.shape-sidebar-icon svg {
    mix-blend-mode: difference;
}

.shape-sidebar-icon svg path {
    fill: white !important;
}

.shape-name-outer {
    display: flex;
    justify-content: flex-start;
    flex-wrap: nowrap;
    white-space: nowrap;
}

.cursor-btn>svg {
    height: 20px;
}

.result-shape-txt {
    font-weight: bold;
    border: 1px solid black;
    padding: 4px 12px 4px 5px;
    border-radius: 2px;
    border-style: dashed;
}

.radius-preview {
    display:block;
    color: red;
}

.result-dual-buttons {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: nowrap;
}

.icon-button {
    letter-spacing: .2px;
    text-decoration: none;
    padding: 6px;
    border-radius: 100px;
    outline: none;
    box-sizing: border-box;
    white-space: nowrap;
    transition-property: background-color, opacity;
    justify-self: flex-start;
    font-size: 14px;
    display: flex;
    align-items: center;
    fill: var(--brand-white);
    color: var(--brand-white);
    background: var(--brand-primary);
    border: none;
}

.icon-button:hover {
    cursor: pointer;
    transition: .3s;
    opacity: .6;
}

.icon-button-danger {
    background: var(--danger) !important;
}

.icon-button svg {
    width: 16px;
    height:16px;
}

.shape-total-row {
    /* display: flex; */
    /* justify-content: space-between; */
    /* gap: 16px; */
    align-items: center;
    margin-top: 16px;
    /* flex-wrap: nowrap; */
}

.shape-total-row ul {
    margin: 0;
    padding-left: 0;
    list-style: none;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.shape-total-row ul li {
    flex-basis: 95px;
}

span.shape-total-figure {
    font-size: 24px;
    color: var(--brand-primary);
    font-weight: 500;
}

button.shape-expand {
    background: none;
    border: none;
    border-radius: 6px;
    font-size: 22px;
}

button.shape-expand:hover {
    transition: .3s;
    cursor: pointer;
    background: var(--super-light-grey);
}

ul.result-bullet {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

ul.result-bullet li {
    flex-basis: 50%;
    flex-grow: 1;
}

.admin-page {
    margin-top: 35px;
    height: calc(100vh - 280px);
    overflow-y: auto;
}

.admin-page h2 {
    margin: 10px 0 16px 0;
}

.request-textbox {
    max-width: 100%;
    min-width: 60%;
    margin: 20px auto 10px auto;
    display: block;
}

.request-textbox textarea {
    width: 100%;
    height: 160px;
    background: var(--super-light-grey);
    display: block;
    margin-bottom: 20px;
}

.share-users-save {
    display: block;
    margin-top: 16px;
    border-radius: 5px;
    border: 1px solid var(--light-gray);
}

.home-admin-sidebar,
.advanced-admin-sidebar,
.team-admin-sidebar,
.settings-admin-sidebar {
    width: 100%;
    margin-top: 20px;
}

button.admin-sidebar-btn {
background: var(--white);
    padding: 6px 0 6px 8px;
    margin-bottom: 10px;
    border-radius: 8px;
    font-weight: 600;
    border: none;
    width: 100%;
    text-align: left;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 12px;
}

button.admin-sidebar-btn:hover {
    cursor: pointer;
    transition: .3s;
    background: var(--brand-primary);
    color: white;
}

button.admin-sidebar-btn svg {
    width: 15px;
}

button.admin-sidebar-btn:hover > svg {
    fill: white;
}

.username-search-container {
    display: block;
    width: 250px;
    margin: 0 auto;
}

#radiusBox {
    position: absolute;
    background: rgba(0, 0, 0, 0.7);
    color: white;
    padding: 5px 10px;
    font-size: 14px;
    border-radius: 5px;
    pointer-events: none;
}

.group-list {
    width: 100%;
    border: 2px solid #d8dee4;
    border-radius: 8px;
    padding: 12px 10px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}

.group-list label {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 20px;
}

.current-groups-ul {
    margin: 0;
    padding-left: 15px;
}

.split-heading {
    display: flex;
    justify-content: flex-start;
    gap: 25px;
    align-items: center;
    margin-bottom: 10px;
}

.split-heading h3 {
    margin: 0 !important;
}

.unapproved-tab {
    position: relative;
}

.unapproved-notif-number {
    position: absolute;
    background: red;
    text-align: center;
    padding: 4px 7px;
    border-radius: 100px;
    font-weight: bold;
    color: white;
    box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
    top: -10px;
    right: -22px;
}

.unapproved-tab:hover,
.company-accounts-tab:hover {
    opacity: .6;
    cursor: pointer;
    transition: .3s;
    text-decoration: underline;
}





button.primary-btn-lrg {
    justify-content: center;
    align-items: center;
    border-radius: 4px;
    display: flex;
    gap: 10px;
    height: 48px;
    line-height: 1.2;
    transition: background .2s linear, color .2s linear;
    white-space: nowrap;
    background: var(--brand-primary);
    color: #fff;
    padding: 13px 16px;
    flex-shrink: 0;
    margin-top: 8px;
    /* width: 100%; */
    font-weight: 600;
    font-size: 16px;
    border: 2px solid var(--brand-primary);
}

button.primary-btn-lrg:hover {
    background: var(--brand-primary-hover);
    border-color: var(--brand-primary-hover);
    cursor: pointer;
}

button.primary-btn-lrg svg {
    fill: white;
    height: 25px;
}

button.secondary-btn-lrg {
    justify-content: center;
    align-items: center;
    border-radius: 4px;
    display: flex;
    gap: 10px;
    height: 48px;
    line-height: 1.2;
    transition: background .2s linear, color .2s linear;
    white-space: nowrap;
    background: #fff;
    color: var(--brand-primary);
    border: 2px solid var(--brand-primary);
    padding: 13px 16px;
    flex-shrink: 0;
    margin-top: 8px;
    /* width: 100%; */
    font-weight: 600;
    font-size: 16px;
}

button.secondary-btn-lrg:hover {
    border-color: var(--brand-primary-hover);
    cursor: pointer;
}

button.secondary-btn-lrg svg {
    fill: var(--brand-primary);
    height: 25px;
}
/* **************************************** */





/* **************************************** */
/* * Sidebar delivery */
/* **************************************** */
.delivery-grid {
    width: 100%;
    margin: 10px 0;
    display: flex;
    gap: 12px;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}

.delivery-option {
    background: white;
    padding: 6px 4px;
    width: 115px;
    flex-grow: 0;
    flex-shrink: 0;
    text-align: center;
    height: 100px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    gap: 1px;
    border: 4px solid white;
}

.delivery-option.delivery-selected {border-color: var(--brand-primary);}

.delivery-option.delivery-disabled {
    pointer-events: none;
    opacity: 0.6;
    color: lightgray;
}

.delivery-option:hover {
    background-color: var(--grey-hover);
    transition: .3s;
    cursor: pointer;
    border-color: var(--grey-hover);
}

.delivery-option h5 {
    font-size: 12px;
    margin: 0;
}

.delivery-price {
    font-size: 18px;
}

.disabled-delivery-option {
    opacity: .25 !important;
    cursor: no-drop !important;
    pointer-events: none !important;
}
/* **************************************** */





/* **************************************** */
/* * Autocomplete */
/* **************************************** */
.autocomplete-inner {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: flex-end;
}

#results {
    display: none;
    position: absolute;
    background: white;
    top: 48px;
    left: 0;
    border: 1.5px solid var(--light-grey);
    max-height: 400px;
    overflow-y: auto;
    z-index: 999;
    width: 240px;
    border-radius: 20px;
    box-shadow: 0 2px 15px 0 rgb(0 0 0 / 10%);
}

ul.autocomplete-options {
    list-style-type: none;
    padding-left: 0;
    overflow-x: hidden;
}

ul.autocomplete-options li {
    white-space: nowrap;
    padding: 8px 12px;
    border-bottom: 1px solid black;
}

ul.autocomplete-options li:hover {
    background: gray;
    transition: .3s;
    cursor: pointer;
}

.heatmap-colours {
    display: flex;
    justify-content: space-between;
    margin: 20px 0;
    gap: 12px;
    align-items: center;
    flex-wrap: nowrap;
    width: 150px;
}

.heatmap-colours .colour-box {
    width: 20px;
    height: 20px;
    border-radius: 4px;
}

.heatmap-colours span {
    display: flex;
    align-items: center;
    gap: 5px;
    text-wrap: nowrap;
}

.earliest-delivery-split {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    margin: 16px 0;
}

.earliest-delivery-btn {
    border: 2px solid #ccc;
    border-radius: 10px;
    padding: 5px 16px;
    font-size: 16px;
    background: white;
    font-weight: 700;
}



/* Container */
#autocomplete-list-sidebar,
.custom-autocomplete-dropdown {
    position: absolute;
    top: 60px;
    left: 0;
    width: 100%;
    max-height: 240px;
    overflow-y: auto;
    background: #fff;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 6px;
    box-shadow: 0 4px 14px rgba(0,0,0,0.08);
    padding: 4px 0;
    z-index: 9999;
    display: none;
    font-size: 14px;
    box-sizing: border-box;
}

/* List items */
#autocomplete-list-sidebar li,
.custom-autocomplete-dropdown .dropdown-item {
    padding: 10px 14px;
    line-height: 1.3;
    color: #2a2f45;
    cursor: pointer;
    transition: background 0.13s ease, color 0.13s ease;
    border-radius: 4px;
}

/* Hover / Focus */
#autocomplete-list-sidebar li:hover,
.custom-autocomplete-dropdown .dropdown-item:hover {
    background: #f6f9fc;
}

/* Active item (mouse down) */
#autocomplete-list-sidebar li:active,
.custom-autocomplete-dropdown .dropdown-item:active {
    background: #e9eef5;
}

/* First row (manual / custom search) */
#autocomplete-list-sidebar .custom-item,
.custom-autocomplete-dropdown .custom-item {
    font-weight: 500;
    color: #0a66ff;
}

/* Scrollbar (Stripe-ish) */
#autocomplete-list-sidebar::-webkit-scrollbar,
.custom-autocomplete-dropdown::-webkit-scrollbar {
    width: 8px;
}
#autocomplete-list-sidebar::-webkit-scrollbar-thumb,
.custom-autocomplete-dropdown::-webkit-scrollbar-thumb {
    background: rgba(0,0,0,0.15);
    border-radius: 4px;
}

/* **************************************** */





/* **************************************** */
/* * Tables */
/* **************************************** */
table {
    border-collapse: collapse;
    text-align: left;
}

table.stripe-tbl {
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
    width: 100%;
    margin-bottom: 25px;
}

.stripe-tbl>thead>tr>th {
    font-size: 14px;
    font-weight: 700;
    color: black;
    text-transform: capitalize;
    white-space: nowrap;
    word-wrap: break-word;
    padding: 8px 24px 8px 0;
    box-shadow: inset 0 -1px 0 0 #ebeef1;
}

table.stripe-tbl tr {
    box-shadow: inset 0 -1px 0 0 #ebeef1;
}

.stripe-tbl tr td {
    padding: 8px 26px 8px 0 !important;
    position: relative;
}

table.stripe-tbl tr:hover {
    background: var(--grey-hover) !important;
    transition: .3s;
    cursor: pointer;
}

.stripe-tbl img {
    width: 75px;
    border-radius: 8px;
    border: 1px solid var(--grey);
}

.stripe-tbl .form-group {
    margin-bottom: 0;
}

.cos_name {
    width: 210px;
}

.cos_type {
    width: 120px;
}

.table-options-outer {
    display: flex;
    justify-content: flex-start;
    gap: 0;
}

.table-options-outer a {
    display: flex;
    border: 1px solid #d8dee4;
    justify-content: center;
    align-items: center;
}

.table-options-outer a:first-child {
    border-radius: 4px 0 0 4px;
}

.table-options-outer a:last-child {
    border-radius: 0 4px 4px 0;
    margin-left: -1px;
}

.table-options-outer a:hover {
    border-color: var(--brand-primary);
    cursor: pointer;
    transition: .2s;
}

.table-options-outer a svg {
    fill: var(--brand-black);
    height: 15px;
    margin: 8px 12px;
    max-width: unset;
}

.result-container .table-options-outer {
    margin-left: auto;
}

.result-container .table-options-outer a {flex-basis: 34%;}

.result-container .table-options-outer a:first-child {
    border-top-left-radius: 0;
}

.result-container .table-options-outer a:last-child {
    border-top-right-radius: 0;
}

.table-options-outer a.unique-tbl-btn:first-child {
    margin-right: 8px;
}

.btn-options-thin {
    position: relative;
}

.btn-options-thin>a>svg {
    margin: 0;
}

.btn-options-thin>a {
    border: none;
}

.btn-options-thin {
    gap: 0px;
    width: 80px !important;
    justify-content: flex-end;
}

.unique-tbl-btn {
    border-radius: 4px !important;
}

#liveLogs {
    height: 400px;
    overflow-y: auto;
    border-radius: 8px;
    border: 2px solid var(--grey);
    padding: 8px;
}

#postageCosts {
    width: 100%;
    overflow-x: auto;
}

#companiesGrid {
    width: 100%;
    display: flex;
    align-items: flex-start;
    gap: 20px;
    flex-wrap: wrap;
}

.company-grid {
    flex-basis: 300px;
    flex-grow: 0;
    padding: 10px 15px;
    border: 2px solid #d8dee4;
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: space-between;
}

#companiesTbl svg {
    max-width: 30px;
}

.company-grid h3 {
    margin: 0;
    white-space: nowrap;
}

.view-company-btn:hover, .company-grid:hover {
    background: #d8dee4;
    transition: .3s;
    cursor: pointer;
}

#ordersContainer td img {
    margin-left: 16px !important;
}

.key-sort-split {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.key-sort-split .form-group select, .key-sort-split .form-group label, .key-sort-split .form-group {
    width: 200px !important;
}

th.sortable { cursor: pointer }
th.sortable .arrow { margin-left: 4px }


.shared-with-itm {
    position: relative;
}

.shared-with-hover {
    display: none;
    position: absolute !important;
    font-size: 15px;
    line-height: 1.5;
    word-wrap: break-word;
    list-style-type: none;
    border-color: #d0d7de;
    border-style: solid;
    border-width: 1px;
    border-radius: 6px;
    margin-top: 8px !important;
    padding: 12px !important;
    max-width: 200px;
    margin-right: auto;
    margin-left: 0;
    background-color: #ffffff;
    box-shadow: 0 0 10px 0 rgb(0 0 0 / 15%);
    left: 0;
    top: 15px;
}

.shared-group-icon:hover + .shared-with-hover {
    display: block;
}

.shared-with-hover ul {
    padding-left: 15px;
    margin-bottom: 0;
}
/* **************************************** */





/* **************************************** */
/* * Swatches */
/* **************************************** */
.key-swatches {
    z-index: 999;
    position: absolute;
}

.key-swatches-container {
    font-size: 14px;
    line-height: 1.5;
    word-wrap: break-word;
    list-style-type: none;
    border-color: #d0d7de;
    border-style: solid;
    border-width: 1px;
    border-radius: 6px;
    margin-top: 8px !important;
    padding: 8px !important;
    position: relative;
    width: 210px;
    margin-right: auto;
    left: -9px;
    margin-left: 0;
    background-color: #ffffff;
    box-shadow: 0 0 10px 0 rgb(0 0 0 / 15%);
}

.key-swatches-container::before {
    left: 24px;
    margin-left: 0;
    top: -16px;
    margin-left: -9px;
    border: 8px solid transparent;
    border-bottom-color: #d0d7de;
    position: absolute;
    display: inline-block;
    content: "";
}

.key-swatches-container::after {
    left: 25px;
    left: 24px;
    margin-left: 0;
    top: -13.5px;
    margin-left: -8px;
    border: 7px solid transparent;
    border-bottom-color: #fff;
    position: absolute;
    display: inline-block;
    content: "";
}

.key-swatches-container p {
    line-height: 1.5;
    word-wrap: break-word;
    margin-top: 0;
    margin-bottom: 4px;
    font-size: 12px;
}

.key-swatches-inner.swatch-protected {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 4px;
}

.color-swatch {
    margin: 0;
    overflow: visible;
    /* display: inline-block; */
    padding: 0;
    cursor: pointer;
    border: 0;
    border-radius: 6px;
    width: 27px;
    height: 27px;
}
/* **************************************** */





/* **************************************** */
/* * Global buttons */
/* **************************************** */
.dual-buttons {
    display: flex;
    justify-content: start;
    margin: 0 auto;
    align-items: center;
    gap: 20px;
    margin-top: 20px;
}

.dual-buttons button {
    flex-grow: 1;
}

button.sbtn {
    letter-spacing: .2px;
    text-decoration: none;
    padding: 2px 14px;
    border-radius: 16.5px;
    outline: none;
    box-sizing: border-box;
    white-space: nowrap;
    transition-property: background-color, opacity;
    justify-self: flex-start;
    font-size: 18px;
    display: flex;
    align-items: center;
    fill: var(--brand-white);
    color: var(--brand-white);
    background: var(--brand-primary);
    border: none;
    border: 2px solid var(--brand-primary);
    gap: 10px;
    line-height: normal;
}

button.sbtn svg {
    height: 10px;
    margin-top: 2px;
}

button.sbtn:hover {
    cursor: pointer;
    transition: .3s;
}

button.sbtn-primary:hover {
    background: var(--brand-primary-hover);
}

button.sbtn-danger {
    border-color: var(--danger) !important;
    background: var(--danger) !important;
}

button.sbtn-danger:hover {
    background: var(--danger-dark) !important;
}

button.sbtn-secondary {
    letter-spacing: .2px;
    text-decoration: none;
    display: inline-block;
    padding: 3px 0 6px;
    border-radius: 16.5px;
    color: var(--brand-primary);
    fill: var(--brand-primary);
    outline: none;
    box-sizing: border-box;
    transition-property: color, opacity;
    background: none;
    border: none;
    display: flex;
    align-items: center;
    gap: 8px;
}

button.sbtn-secondary:hover {
    cursor: pointer;
    transition: .3s;
    color: var(--brand-primary-hover);
    fill: var(--brand-primary-hover);
}

button.sbtn-tertiary svg,
button.sbtn-secondary svg {
    height: 10px;
}

button.sbtn-tertiary {
    letter-spacing: .2px;
    text-decoration: none;
    padding: 2px 14px 0 14px;
    border-radius: 100px;
    outline: none;
    box-sizing: border-box;
    white-space: nowrap;
    transition-property: background-color, opacity;
    justify-self: flex-start;
    display: flex;
    align-items: center;
    fill: var(--brand-primary);
    color: var(--brand-primary);
    background: #fff;
    border: 2px solid var(--brand-primary);
    gap: 10px;
}

button.sbtn-tertiary:hover {
    cursor: pointer;
    transition: .3s;
    color: var(--brand-white);
    fill: var(--brand-white);
    background: var(--brand-primary-hover);
    border-color: var(--brand-primary-hover);
}

.user-access-row {
    display: flex;
    justify-content: flex-start;
    gap: 10px;
    align-items: center;
    flex-wrap: nowrap;
}

button.delete-icon-btn {
    border: none;
    background: var(--danger);
    border-radius: 100px;
    padding: 5px;
    font-size: 16px;
    color: white;
    line-height: 0;
}

button.delete-icon-btn:hover {
    background: var(--danger-dark);
    cursor: pointer;
    transition: .3s;
}

.floating-edit-buttons {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    flex-wrap: nowrap;
    margin-bottom: 20px;
}

.floating-edit-buttons button {
    color: var(--brand-white);
    background: var(--brand-black);
    padding: 6px 25px;
    border-radius: 4px;
    font-weight: 500;
    border: 2px solid var(--brand-black);
    flex-grow: 1;
}

.floating-edit-buttons button:hover {
    transition: .3s;
    cursor: pointer;
    background: var(--brand-white);
    color: var(--brand-black);
}

.floating-edit-buttons button:last-child {
    background: var(--brand-white);
    color: var(--brand-black);
    transition: .3s;
    cursor: pointer;
    background: var(--brand-white);
    color: var(--brand-black);
}

.floating-edit-buttons button:last-child:hover {
    background: var(--brand-black);
    color: var(--brand-white);
}

.map-options-list {
    position: absolute;
    display: flex;
    flex-direction: column;
    right: 20px;
    top: 45px;
    background: var(--brand-white);
    border-radius: 8px;
    width: 125px;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    z-index: 1000;
}

button.options-list-btn {
    background: transparent;
    border: none;
    text-align: left;
    padding: 8px 15px;
    border-bottom: 1px solid var(--dark-grey);
}

button.options-list-btn:last-child {
    border: none;
}

button.options-list-btn:hover {
    background: var(--grey);
    transition: .3s;
    cursor: pointer;
}

.add-pin-box {
    position: absolute;
    z-index: 9999;
    right: 10px;
    bottom: 240px;
    background: rgb(255, 255, 255);
    border: 0px;
    margin: 0px;
    padding: 0px;
    box-shadow: rgba(0, 0, 0, 0.3) 0px 1px 4px -1px;
    border-radius: 2px;
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
}

.add-pin-box svg {
    width: 30px;
    margin-left: 6px;
}

.add-pin-box:hover {
    cursor: pointer;
    transition: .3s;
    background: var(--grey-hover);
}

.gm-style-iw-chr {
    display: none;
}

p.label-content {
    margin: 12px 0;
    font-size: 16px;
    font-weight: 400;
}

.strapline-outer {
    display: flex;
    justify-content: flex-start;
    gap: 0;
    align-items: center;
    flex-wrap: nowrap;
}

.strapline-outer input {
    flex-grow: 1;
}

button.strapline-upload-btn {
    background: white;
    border: 2px solid black;
    fill: black;
    width: 40px;
    height: 36px;
    margin-left: -2px;
}

button.strapline-upload-btn:hover {
    background: var(--grey-hover);
    transition: .3s;
    cursor: pointer;
}

.thinner-admin-container {
    max-width: 500px;
    display: block;
    margin: auto;
}


.upload-name {
    background: #e0e0e0;
    padding: 6px 10px;
    border-radius: 6px;
    margin-bottom: 10px;
    display: flex;
    flex-direction: column;
    gap: 0px;
    align-items: flex-start;
    color: #a3a3a3;
    font-size: 13px;
}

.upload-name span:first-child {
    color: black;
    font-weight: 500;
    font-size: 15px;
}

.artwork-uploaded-btn {
    background: blue;
    color: darkblue;
    fill: darkblue;
    padding: 6px 10px;
    border-radius: 6px;
    margin-bottom: 10px;
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
}

.artwork-uploaded-btn {
    background: #c9d4ea;
    color: #3767ea;
    fill: #3767ea;
    padding: 6px 10px;
    border-radius: 6px;
    margin-bottom: 10px;
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
}

.artwork-uploaded-btn:hover {
    background: #3767ea;
    transition: .3s;
    cursor: pointer;
}

.artwork-uploaded-btn button {
    border: none;
    background: none;
    color: #3767ea;
    display: flex;
    gap: 10px;
    align-items: center;
    font-weight: 500;
}

/* hide radios */
.dual-inputs {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    align-items: center;
}

.dual-inputs input[type="radio"] {
    display: none;
}

/* labels now act like the buttons did */
.dual-inputs label.boundary-view-btn {
    cursor: pointer;
    transition: .3s;
    padding: 6px 10px;
    background: white;
    border-radius: 10px;
    margin: 3px;
    border: 2px solid #ccc;
}

/* hover style */
.dual-inputs label.boundary-view-btn:hover {
    background-color: var(--brand-primary);
    color: white;
}

/* selected state when radio is checked */
.dual-inputs input[type="radio"]:checked + label.boundary-view-btn {
    background-color: var(--brand-primary);
    color: white;
}

/* **************************************** */






/* **************************************** */
/* * Loading */
/* **************************************** */
.loading-icon {
    display: inline-block;
    position: relative;
    width: 20px;
    height: 20px;
}

.loading-icon div {
    box-sizing: border-box;
    display: block;
    position: absolute;
    width: 12px;
    height: 12px;
    margin: 5px;
    border: 2px solid #fff;
    border-radius: 50%;
    animation: loading-icon 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
    border-color: #fff transparent transparent transparent;
}

.loading-icon div:nth-child(1) {
    animation-delay: -0.45s;
}

.loading-icon div:nth-child(2) {
    animation-delay: -0.3s;
}

.loading-icon div:nth-child(3) {
    animation-delay: -0.15s;
}

@keyframes loading-icon {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* full-screen overlay */
#loading-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.8);
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

/* spinner */
.spinner {
    width: 50px;
    height: 50px;
    border: 6px solid #ccc;
    border-top-color: #333;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}
/* **************************************** */












/* **************************************** */
/* * Notify */
/* **************************************** */
.noty_layout_mixin,
#noty_layout__topRight {
    position: fixed;
    margin: 0;
    padding: 0;
    z-index: 9999999;
    -webkit-transform: translateZ(0) scale(1, 1);
    transform: translateZ(0) scale(1, 1);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-font-smoothing: subpixel-antialiased;
    filter: blur(0);
    -webkit-filter: blur(0);
    max-width: 90%
}

#noty_layout__topRight {
    top: 70px;
    right: 20px;
    width: 325px;
}

#noty_layout__topRight:hover {
    cursor: pointer;
}

.noty_bar {
    -webkit-backface-visibility: hidden;
    -webkit-transform: translate(0, 0) translateZ(0) scale(1, 1);
    -ms-transform: translate(0, 0) scale(1, 1);
    transform: translate(0, 0) scale(1, 1);
    -webkit-font-smoothing: subpixel-antialiased;
    overflow: hidden
}

.noty_effects_open {
    opacity: 0;
    -webkit-transform: translate(50%);
    -ms-transform: translate(50%);
    transform: translate(50%);
    -webkit-animation: noty_anim_in .5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    animation: noty_anim_in .5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.noty_effects_close {
    -webkit-animation: noty_anim_out .5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    animation: noty_anim_out .5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.noty_fix_effects_height {
    -webkit-animation: noty_anim_height 75ms ease-out;
    animation: noty_anim_height 75ms ease-out
}

.noty_close_button {
    position: absolute;
    top: 2px;
    right: 2px;
    font-weight: 700;
    width: 20px;
    height: 20px;
    text-align: center;
    line-height: 20px;
    background-color: rgba(0, 0, 0, 0.05);
    border-radius: 2px;
    cursor: pointer;
    -webkit-transition: all .2s ease-out;
    transition: all .2s ease-out
}

.noty_close_button:hover {
    background-color: rgba(0, 0, 0, 0.1)
}

.noty_modal {
    position: fixed;
    width: 100%;
    height: 100%;
    background-color: #000;
    z-index: 10000;
    opacity: .3;
    left: 0;
    top: 0
}

.noty_modal.noty_modal_open {
    opacity: 0;
    -webkit-animation: noty_modal_in .3s ease-out;
    animation: noty_modal_in .3s ease-out
}

.noty_modal.noty_modal_close {
    -webkit-animation: noty_modal_out .3s ease-out;
    animation: noty_modal_out .3s ease-out;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards
}

.noty__success {
    background-color: #dff0d8;
    color: #3c763d;
    border-color: #d6e9c6 !important
}

.noty__warning {
    background-color: #fcf8e3;
    color: #8a6d3b;
    border-color: #faebcc !important
}

.noty__error {
    background-color: #f2dede;
    color: #a94442;
    border-color: #ebccd1 !important
}

.noty__info {
    background-color: #d9edf7;
    color: #31708f;
    border-color: #bce8f1 !important
}

.noty_bar {
    margin: 4px 0;
    overflow: hidden;
    position: relative;
    border: 1px solid;
    border-radius: .25rem
}

.noty_bar .noty_body {
    padding: .75rem 1.25rem
}

.noty_progressbar {
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
    width: 100%;
    background-color: #646464;
    opacity: 0.2;
    filter: alpha(opacity=10);
}
/* **************************************** */





/* **************************************** */
/* * Dropdown picker */
/* **************************************** */
.hierarchy-select {position:relative;display:inline-block;width: 100%;}
.hierarchy-select .btn {font-weight: 400;height: 45px;margin-top: 0;line-height: 20px;width: 100%;background-position: right;display: flex;justify-content: space-between;align-items: center;border: 2px solid #ccc;border-radius: 10px;padding: 10px 16px;cursor: pointer;transition: all 0.2s ease;font-size: 16px;background: white;}
.hierarchy-select .dropdown-menu {
  display:none; position:absolute; z-index:100; background:#fff;
  border:1px solid #ccc; border-radius:8px; width:100%;
  max-height:260px; overflow-y:auto; margin-top:6px;
}
.hierarchy-select.open .dropdown-menu { display:block; }
.hs-searchbox { padding:6px; border-bottom:1px solid #ddd; }
.hs-searchbox input { width:100%; padding:6px; border:1px solid #ddd; border-radius:4px; }
.hs-menu-inner .option { padding:6px 12px; cursor:pointer; }
.hs-menu-inner .option[data-level="1"] { font-weight:600; background:#f1f3f4; }
.hs-menu-inner .option[data-level="2"] { padding-left:28px; }
.hs-menu-inner .option:hover { background:#e9ecef; }
/* **************************************** */





/* **************************************** */
/* * Leaflet drop */
/* **************************************** */
.stepper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
}

.step {
    display: flex;
    align-items: center;
    color: #000;
    font-size: 10px;
    font-weight: 600;
}

.step .circle {
    width: 25px;
    height: 26px;
    border-radius: 50%;
    border: 2px solid #e5dfdf;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    transition: all 0.3s ease;
    margin-right: 6px;
}

.step .circle.active {
    background: #f97316;
    color: #fff;
    border-color: #f97316;
    font-weight: 600;
}

.step .circle.done {
    background: #22c55e;
    border-color: #22c55e;
    color: #fff;
}

.line {
    flex: 1;
    height: 2px;
    background: #d1d5db;
}

.step.active span {
    color: #111827;
}

.check {
    font-size: 14px;
    line-height: 1;
}

span.ct-num {
    display: block;
    font-size: 20px;
    font-weight: 700;
    text-align: center;
}

span.ct-title {
    display: block;
    font-size: 14px;
    font-weight: 400;
    text-align: center;
}

div#householdsList {
    border-left: .6px solid var(--light-grey);
    border-right: .6px solid var(--light-grey);
    padding: 0 20px;
}

.selection-counts {
    display: flex;
    justify-content: space-evenly;
    gap: 10px;
    align-items: center;
    flex-wrap: nowrap;
    margin-bottom: 20px;
}

#sectorTooltip {
    position: absolute;
    padding: 4px 8px;
    background: rgba(49, 72, 104, 0.9);
    color: #fff;
    border-radius: 6px;
    pointer-events: none;
    font-size: 13px;
    white-space: nowrap;
    transition: opacity 0.1s;
    opacity: 0;
    z-index: 1000;
}

.selected-sectors-list {
    overflow-y: auto;
    overflow-x: hidden;
}

.unselect-sector-btn svg {
    width: 20px !important;
    min-width: 20px;
}

#sidebarHidden_campaign {
    max-height: calc(100vh - 105px) !important;
    overflow-y: auto !important;
}
/* **************************************** */