.color-option {
    display: inline-block; /* Ensure elements wrap */
    margin: 5px 8px 15px 0; /* Adjust as needed */
    vertical-align: top; /* Ensures proper alignment */
}


.tooltip-image {
    max-width: 100px;
    margin-top: 5px;
    border-radius: 4px;
}

.second-line-indent {
    padding-left: 2em;
    display: block;
}

.logo-img {
    width: 125px;

}

.grecaptcha-badge {
    visibility: hidden;
}

#myDropzone {
    border: 2px dashed #ccc;
    background-color: rgba(255, 255, 255, 0.2);
    border-radius: 10px;
    min-height: 164px;
    max-height: 164px;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    display: block; /* ← not flex! */
    position: relative;
}


.dz-drag-hover {
    border: 2px dashed #ef3f6e!important;
}

.dropzone .dz-preview {
    display: inline-block;
    vertical-align: top;
}


.dropzone .dz-preview .dz-image, .dropzone .dz-preview .dz-image img {
    border-radius: 5px;
}

.dropzone .dz-message {
    position: absolute;
    inset: 0; /* shorthand for top: 0; left: 0; right: 0; bottom: 0 */
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none; /* So it doesn't block drop/click */
    text-align: center;
    padding: 1rem; /* optional: prevent clipping on very small screens */
    white-space: normal;
    word-break: break-word;
}

.dz-message-content {
    display: block; /* fallback */
}



.dz-size {
    display: none;
}

.dropzone .dz-preview.dz-file-preview .dz-image {
    background: rgba(244, 215, 247, 0.3);
    border-radius: 5px;
}
.dropzone .dz-preview .dz-details {
    line-height: 500%;
}
.dropzone .dz-preview .dz-progress {
    top: 80%;
}
.dropzone .dz-preview .dz-details .dz-filename {
    color: #747ed1;
}
.dropzone .dz-preview .dz-progress .dz-upload {
    background: #747ed1;
}

.dz-error-message {
    margin-top: 10px;
    margin-left: 13px;
}

.dropzone .dz-preview .dz-error-message:after {
    border-bottom: 6px solid transparent;
}

.dropzone .dz-preview .dz-error-message {
    background: transparent;
}

.dropzone .dz-preview .dz-details .dz-filename:hover span {
    border: 1px solid transparent;
    background-color: rgba(255,255,255,.4);
}
.stlviewer {
    width: 100%;
    height: 100%;
}
@media (max-width: 991.98px) {
    .stlviewer-column {
        height: 200px; /* Set the fixed height for small screens */
    }
}
.picker label[for*=material]>span {
    font-size: 0.7rem;
    line-height: 1;
    display: grid;
    place-items: center;
    padding: 0.5rem;
    background: rgba(164, 174, 198, 0.2);
    border-radius: 0.4rem;
}
.picker label[for*=material]>input:checked~span {
    background-color: #605dba;
    color: #fff;
}
.picker label {
    position: relative;
    inline-size: 3rem;
    block-size: 2rem;
    margin-right: 0.5rem;
    isolation: isolate;
    display: grid;
    place-items: center;
    cursor: pointer;
}
.picker label[for*=colour]>span {
    font-size: 1px;
    display: grid;
    place-items: center;
    background: var(--color, rgba(164, 174, 198, 0.2));
    border-radius: 100%;
    color: transparent;
}

.picker label>span {
    position: absolute;
    inset: 0;
    block-size: 100%;
    inline-size: 100%;
}
.picker label[for*=colour] {
    inline-size: 1.5rem;
    block-size: 1.5rem;
}
.picker label[for*=colour]>input:checked~span:not(.white-colour) {
    box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--color);
}

.picker label[for*=colour]>input:checked~span.white-colour {
    box-shadow: 0 0 0 2px #fff, 0 0 0 4px #c7c7c7;
}

.picker label[for*=colour].white-colour {
    border: #c7c7c7 1px solid;
    border-radius: 100%;
}

.picker label[for*=colour]>span.galaxy {
    background-image: url("/img/galaxy.png");
    background-position: center; /* Center the image */
    background-repeat: no-repeat; /* Do not repeat the image */
    background-size: cover;
    border-radius: 100%;
}


.tooltip-inner {
    color: #60697b;
    background-color: #eceef2;
    font-weight: normal;
}

.bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow::before, .bs-tooltip-bottom .tooltip-arrow::before {
    border-bottom-color: #eceef2;
}


html#ecwid_html body#ecwid_body .ec-minicart__icon .icon-default path[stroke], html#ecwid_html body#ecwid_body .ec-minicart__icon .icon-default circle[stroke] {
    stroke: #343f52!important;
}

.ec-cart.ec-cart--empty .form-control__button {
    display: none!important;
}
html#ecwid_html body#ecwid_body .ec-minicart__icon .icon-default circle[fill].cart-not-empty {
    fill: #605dba!important;
}
@media (min-width: 992px) {
    .visible-lg-only {
        visibility: visible;
    }
    body {
        padding-top: 79px;
    }
    .ecwid-cart-width {
        width: 160px;
    }

    .ecwid-cart-position {
        margin-top: 13px;
    }
}
@media (max-width: 991px) {
    .visible-lg-only {
     visibility: hidden;
    }
    body {
        padding-top: 103px;
    }
    html#ecwid_html body#ecwid_body .white-on-small .ec-minicart__icon .icon-default path[stroke],
    html#ecwid_html body#ecwid_body .white-on-small .ec-minicart__icon .icon-default circle[stroke] {
        stroke: #ffffff !important;
    }

    @media (max-width: 991px) {
        html#ecwid_html body#ecwid_body .white-on-small .ec-minicart__title,
        html#ecwid_html body#ecwid_body .white-on-small .ec-minicart__count {
            color: #fff !important;
        }
    }

    .ecwid-cart-width {
        width: 100%;
        padding-left: 1.5rem;
    }
}
.fixed-top.scrolled {
    box-shadow: 0 0 0 0.05rem rgba(8, 60, 130, 0.06), 0rem 0rem 1.25rem rgba(30, 34, 40, 0.04);
    background: #fff!important;
}
.fixed-top {
    transition: box-shadow 0.3s, background 0.3s; /* Add transition for smooth animation */
}
.dropzone .dz-preview .dz-error-message {
    opacity: 1!important;
    color: #fff!important;
    margin-top: -130px;
    width: 120px;
    text-wrap: pretty;
    text-align: center;
    background: #e2626b;
    padding: 38px 0;
    margin-left: 10px;
    border-radius: 6px;
}
.small-disclaimer {
    font-size: 0.6rem;
    line-height: 1.2;
    display: block;
    max-width: 100%;
    white-space: normal;
    word-wrap: break-word;
    margin-top: 10px;
}

.uk-flag {
    background-image: url('/img/Flag_of_the_United_Kingdom.svg');
    background-size: cover;
    background-position: left center;
    background-repeat: no-repeat;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
    display: inline-block;
    font-weight: bold;
    -webkit-text-stroke: 0.5px black;
    text-stroke: 0.51px black;
}
