@import "../theme/colors.css";

:root {
    --left-offset: -215px;
}

@font-face {
    font-display: swap;
    font-family: LabGrotesque;
    font-style: normal;
    font-weight: 400;
    src: url('../font/LabGrotesque/LabGrotesqueRegularWeb/LabGrotesque-Regular.woff2') format("woff2"), url('../font/LabGrotesque/LabGrotesqueRegularWeb/LabGrotesque-Regular.woff') format("woff");
}

@font-face {
    font-display: swap;
    font-family: LabGrotesque;
    font-style: italic;
    font-weight: 400;
    src: url('../font/LabGrotesque/LabGrotesqueItalicWeb/LabGrotesque-Italic.woff2') format("woff2"), url('../font/LabGrotesque/LabGrotesqueItalicWeb/LabGrotesque-Italic.woff') format("woff");
}

@font-face {
    font-display: swap;
    font-family: LabGrotesque;
    font-style: normal;
    font-weight: 600;
    src: url('../font/LabGrotesque/LabGrotesqueMediumWeb/LabGrotesque-Medium.woff2') format("woff2"), url('../font/LabGrotesque/LabGrotesqueMediumWeb/LabGrotesque-Medium.woff') format("woff");
}

@font-face {
    font-display: swap;
    font-family: LabGrotesque;
    font-style: normal;
    font-weight: 700;
    src: url('../font/LabGrotesque/LabGrotesqueBlackWeb/LabGrotesque-Black.woff2') format("woff2"), url('../font/LabGrotesque/LabGrotesqueBlackWeb/LabGrotesque-Black.woff') format("woff");
}

@font-face {
    font-display: swap;
    font-family: Ysoft;
    font-style: normal;
    font-weight: 400;
    src: url('../font/YSoft/YSoft-Regular.woff') format("woff");
}

@font-face {
    font-display: swap;
    font-family: Ysoft;
    font-style: normal;
    font-weight: 700;
    src: url('../font/YSoft/YSoft-Bold.woff') format("woff");
}

body {
    background-color: var(--surface-page);
    color: var(--text-on-surface);
    font-family: LabGrotesque, Roboto, Arial, Helvetica, sans-serif;
    font-size: 16px;
    margin: 0;
    padding: 1px;
}

h1 {
    text-align: center;
    font-weight: 700;
    font-size: 2rem;
    text-transform: uppercase;
    font-family: Ysoft, LabGrotesque, Roboto, Arial, Helvetica, sans-serif;
}

@media (min-width: 576px) {
    h1 {
        font-size: 3.8125rem;
    }
}

h2 {
    text-align: center;
    font-weight: 700;
    font-size: 1.5rem;
    text-transform: uppercase;
    font-family: Ysoft, LabGrotesque, Roboto, Arial, Helvetica, sans-serif;
}

h3 {
    text-align: center;
    font-weight: 700;
    font-size: 1.125rem;
    font-family: LabGrotesque, Roboto, Arial, Helvetica, sans-serif;
}

h4 {
    text-align: center;
    text-transform: uppercase;
    font-weight: 700;
    font-family: LabGrotesque, Roboto, Arial, Helvetica, sans-serif;
}

h5 {
    text-align: left;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 1.6rem;
    font-family: Ysoft, LabGrotesque, Roboto, Arial, Helvetica, sans-serif;
    margin: 2rem 0 0 0;
}

p {
    font-size: 1rem;
    color: var(--text-heading);
}

input {
    font-family: inherit;
}

.wizard-input-info {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: 8px;
    margin-bottom: 24px;
    line-height: 135%;
}

.wizard-page__triangle {
    position: fixed;
    right: 0;
    top: 0;
    display: none;
}

.wizard-page__triangle::before {
    content: "";
    display: block;
    height: 100vh;
    aspect-ratio: 1 / 11.4;
    background-color: var(--accent-orange);
    clip-path: polygon(100% 0, 100% 100%, 0 100%);
    position: relative;
    right: -1px;
}

.wizard-page__triangle::after {
    content: "";
    display: block;
    height: 100vh;
    width: 259px;
    background-color: var(--accent-orange);
}

@media (min-width: 1300px) {
    .wizard-page__triangle {
        display: flex;
    }
}

.wizard-page-container {
    width: fit-content;
    margin: 0 auto;
}

@media (min-width: 1300px) {
    .wizard-header {
        position: relative;
        z-index: 2;
    }

    .wizard-page-container {
        padding: 0 300px 0 20px;
        position: relative;
        z-index: 1;
    }
}

@media (max-width: 1299px) {
    .wizard-page-container {
        padding: 0;
    }
}

.wizard-page__progress-bar {
    margin-top: 50px;
    margin-bottom: 120px;
}

.wizard-page__bg-image {
    display: none;
    position: fixed;
    bottom: 0;
    right: 4%;
    width: clamp(200px, 25vw, 400px);
    height: auto;
    z-index: 0;
    pointer-events: none;
}

@media (min-width: 1300px) {
    .wizard-page__bg-image {
        display: block;
    }
}


.signup-checkmark-green {
    color: var(--theme-default-primary);
    margin: 0 0.4rem 0
}

.wizard-signup-container {
    margin: 80px auto 0 auto;
    max-width: 520px;
    padding: 0 10px 0 10px;
    height: 4.125rem;
}

.wizard-signup-container div {
    text-align: left;
    color: var(--text-muted);
    display: inline-flex;
    align-items: baseline;
    font-size: 1rem;
    margin: 0.8rem 0 0;
}

.smartlook-banner {
    background-color: var(--theme-default-primary-background);
    min-width: 500px;
    height: 66px;
    position: absolute;
    bottom: 24px;
    left: 24px;
    border-radius: 90px;
    display: flex;
    align-items: center;
    padding: 0 30px;
}

.smartlook-banner__content {
    position: relative;
    margin-right: 1.5rem;
}

.smartlook-banner__text {
    display: inline-block;
}

.smartlook-banner__text a,
.smartlook-tooltip a {
    color: var(--theme-default-link);
    text-decoration: none;
}

.smartlook-banner__text a:hover,
.smartlook-tooltip a:hover {
    color: var(--theme-default-link-hover);
    text-decoration: none;
}

.smartlook-banner--accept-button {
    border-radius: 0.3rem;
    margin-right: 0.5rem;
    color: var(--theme-default-button-secondary-text);
    background-color: var(--theme-default-button-secondary-background);
    font-size: 0.875rem;
    font-weight: 500;
    text-transform: uppercase;
    padding: 14px 24px 12px;
    cursor: pointer;
    border: 1px solid var(--theme-default-button-secondary-border);
    box-shadow: none;
}

.smartlook-banner--accept-button:hover {
    background-color: var(--theme-default-button-secondary-background-active);
    box-shadow: none;
}

.smartlook-tooltip {
    background-color: var(--theme-default-primary-background);
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.15);
    border-radius: 15px;
    padding: 1rem;
    text-align: left;
    z-index: 100;
    width: 12.5rem;
    position: absolute;
    bottom: calc(100% + 10px);
    left: 50%;
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: space-between;
    font-size: 0.625rem;
}

.smartlook-tooltip > div {
    padding: 0.5rem 0;
}

.smartlook-banner--close-button {
    background: transparent;
    color: var(--theme-default-button-secondary-text);
    border: none;
    cursor: pointer;
    z-index: 10;
    font-size: 1.9rem;
}

.full-width-image {
    margin: 35px auto 35px auto;
    width: 100%;
    display: block;
}

.small-width-image {
    display: block;
    z-index: 1000;
    margin: 35px auto 35px auto;
    width: 100px;
}

[data-title] {
    position: relative;
}

[data-title]:not([data-title=""]):hover:after {
    opacity: 1;
    transition: all 0.1s ease 0.2s;
    visibility: visible;
}

[data-title]:after {
    content: attr(data-title);
    visibility: hidden;
    max-width: 10rem;
    width: max-content;
    background-color: var(--theme-default-text-title);
    color: var(--text-inverse);
    text-align: center;
    line-height: 0.85rem;
    font-size: 0.75rem;
    font-weight: normal;
    padding: 0.25rem 0.5rem 0.15rem 0.5rem;
    border-radius: 0.25rem;
    white-space: normal;
    position: absolute;
    z-index: 99999;
    margin-top: 0.75rem;
    left: 50%;
    transform: translate(-50%, 0);
    top: 100%;
}

.orange {
    color: var(--accent-orange);
}

.wizard-form__heading {
    margin-bottom: 79px;
}

.wizard-form-container {
    margin: 0 auto 0 auto;
    max-width: 345px;
    padding: 0 10px 0 10px;
}

.wizard-form-container--medium {
    max-width: 416px;
}

.wizard-form-container--wide {
    max-width: 450px;
}

.wizard-form-container--wider {
    max-width: 560px;
}

.submit-button {
    text-align: center;
    margin: auto;
}

.submit-button--button {
    background-color: var(--theme-default-primary);
    border: none;
    border-radius: 0.25rem;
    margin: 0 auto 0 auto;
    color: var(--text-inverse);
    font-size: 0.875rem;
    font-weight: 500;
    text-transform: uppercase;
    padding: 14px 24px 12px;
    cursor: pointer;
}

.submit-button--button:hover {
    background-color: var(--theme-default-link-hover);
}

.submit-button--button:disabled {
    cursor: default;
    background-color: var(--theme-default-disabled);
}

.submit-button--button.margin-bottom {
    margin-bottom: 1rem
}

.text-input-printer-info.k-textbox {
    box-sizing: border-box;
    border-radius: 5px;
    background-color: var(--input-bg);
    color: var(--text-on-surface);
    border: 1px solid var(--border-default);
    border-bottom: 1px solid var(--border-default);
    font-size: 16px;
    margin-bottom: 10px;
    font-family: LabGrotesque, Roboto, Arial, Helvetica;
    height: 54px;
    outline: none;
    text-overflow: ellipsis;
}

.text-input-printer-info:focus {
    border-color: var(--theme-default-primary);
    box-shadow: none;
    background-color: var(--input-bg);
}
.text-input-printer-info:hover {
    border-color: var(--theme-default-primary);
    box-shadow: none;
    background-color: var(--input-bg);
}

.text-input-printer-info::placeholder {
    color: var(--input-disabled-text);
}

.text-input-printer-info--label {
    text-align: left;
    display: block;
    color: var(--text-muted);
}

.text-input-edit-info {
    box-sizing: border-box;
    border-radius: 4px;
    background-color: var(--input-bg);
    color: var(--text-on-surface);
    border: 1px solid var(--border-default);
    border-bottom: 1px solid var(--border-default);
    font-size: 16px;
    margin-bottom: 10px;
    font-family: LabGrotesque, Roboto, Arial, Helvetica;
    width: 300px;
    height: 54px;
    outline: none;
}

.text-input-edit-info:focus {
    border-color: var(--theme-default-primary);
    box-shadow: none;
    background-color: var(--input-bg);
}

.text-input-edit-info::placeholder {
    color: var(--input-disabled-text);
}

.text-input-edit-info--label {
    text-align: left;
    display: block;
    color: var(--text-muted);
}

.text-input {
    box-sizing: border-box;
    border-radius: 5px;
    width: 345px;
    height: 54px;
    background-color: var(--input-bg);
    color: var(--text-on-surface);
    border: 0.5px solid var(--border-default);
    font-size: 16px;
    margin-bottom: 10px;
    font-family: LabGrotesque, Roboto, Arial, Helvetica;
    padding-left: 10px;
}

.text-input::placeholder {
    color: var(--input-disabled-text);
}

.text-input--label {
    text-align: left;
    display: block;
    color: var(--text-muted);
}

input.text-input:focus {
    border-color: var(--theme-default-primary);
    box-shadow: none;
    background-color: var(--input-bg);
    outline: none;
}

.error {
    border: 1px solid var(--theme-default-icon-fail);
}

.error-message {
    color: var(--theme-default-text-red);
}

.error-message-placeholder {
    height: 1.25rem;
}

.text-input .password {
    padding-right: 1.8rem;
}

.bi {
    cursor: pointer;
    position: absolute;
    right: 0.3rem;
    bottom: 0.5rem;
}

.os-image {
    margin: 2.2rem auto 2.2rem auto;
    width: 3.4rem;
    display: block;
}

.os-image--small {
    margin: 0;
    width: 16px;
    display: inline;
}

.download-link {
    margin-top: 0.3125rem;
    font-size: 16px;
    color: var(--text-muted);
    cursor: pointer;
    text-decoration: none;
}

.wizard-link {
    color: var(--theme-default-primary) !important;
    text-decoration: none;
    box-shadow: none !important;
}

.wizard-link:focus,
.wizard-link:hover {
    color: var(--theme-default-link-hover) !important;
    text-shadow: 0.03ex 0 0 var(--theme-default-link-hover-opacity)
}

.download-link-container {
    margin: 0.625rem auto 0.625rem auto;
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.625rem;
}

.large-link {
    font-size: 0.875rem;
    font-weight: 500;
    text-transform: uppercase;
    text-align: left;
    cursor: pointer;
    border: none;
    background: none;
    color: var(--theme-default-primary);
    text-decoration: none;
    display: block;
    width: 100%;
    margin-left: var(--left-offset, 3px);
    margin-top: 24px;
}

.large-link-print {
    font-size: 0.875rem;
    font-weight: 500;
    text-transform: uppercase;
    text-align: left;
    cursor: pointer;
    border: none;
    background: none;
    color: var(--theme-default-primary);
    text-decoration: none;
    margin-left: var(--left-offset, 3px);
    margin-top: 24px;
}

.left-aligned {
    text-align: left;
}

.input-wider-width-container {
    width: 55%;
}

.input-narrower-width-container {
    width: 45%;
}

.outer-input-flex-container {
    display: flex;
}

.discovered-printers-checkbox-column {
    width: 27px;
    height: 27px;
    align-content: center;
    padding-left: 4px;
}

.discovered-printers-printer-icon {
    height: 50px;
    width: 50px;
    padding-bottom: 10px;
}

.discovered-printers-ip-column {
    width: 145px;
    height: 54px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
}

.discovered-printers-ip-column label {
    font-size: 12px;
    margin-bottom: 4px;
}

.discovered-printers-ip-column input {
    text-align: left;
    width: 147px;
    height: 54px;
}

.discovered-printers-icon-column {
    width: 15%;
    align-content: center;
}

.discovered-printers-name-column {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
}

.button-secondary.button-secondary--variant2 {
    background-color: var(--theme-default-primary) !important;
    color: var(--text-inverse) !important;
    border: 1px solid var(--theme-default-primary);
}

.button-secondary.button-secondary--variant2:hover {
    background-color: var(--theme-default-link-hover) !important;
    color: var(--text-inverse) !important;
    border: 1px solid var(--theme-default-link-hover);
}

.button-secondary.button-secondary--variant2:active {
    background-color: var(--theme-default-primary) !important;
    color: var(--text-inverse) !important;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.3) !important;
}

.align-center {
    text-align: center;
}

.small-spinner {
    display: block;
    margin: 10px auto 35px auto;
    width: 50px;
}

.small-spinner-discovery {
    display: block;
    width: 50px;
}

.button-delete {
    border: 1px solid var(--theme-default-primary);
    color: var(--theme-default-primary);
    border-radius: 0.3rem;
    background-repeat: no-repeat;
    width: 3.25rem;
    height: 3.25rem;
    background-size: 45% 45%;
    background-position: center;
    box-shadow: none;
    align-items: center;
    background-image: url('../theme/img/eop_icon_remove_primary.svg');
    cursor: pointer;
    background-color: transparent;
}

.feedback-error {
    min-height: 25px;
    color: var(--theme-default-text-red);
    text-align: center;
    margin-top: 10px;
}

.feedback-error.no-placeholder {
    min-height: 0;
}

.feedback-error ul {
    list-style: none;
    padding-left: 0;
    margin: 0 0 10px 0;
}

.feedback-error li {
    list-style: none;
}

.feedback-success {
    min-height: 25px;
    color: var(--theme-default-icon-success);
    text-align: center;
    margin-top: 10px;
}

.feedback-success ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.feedback-success li {
    list-style: none;
}

.clickable, input[type="checkbox"] {
    width: 16px;
    height: 16px;
    transform-origin: center;
    cursor: pointer;
    accent-color: var(--status-info-accent);
    position: relative;
    top: -2px;
}

.checkbox-container {
    display: flex;
    gap: 10px;
    font-size: 1rem;
}

.checkbox-text {
    flex: 1;
}

.checkbox-text label {
    font-size: .95rem;
}

.privacyLegalDocuments--acceptance {
    color: var(--theme-default-primary);
    text-decoration: none;
}

.privacyLegalDocuments--acceptance:hover {
    color: var(--theme-default-link-hover);
}

.remove-icon {
    display: inline-block;
    background-color: var(--surface-primary);
}

.discovered-printers-vendor-column a {
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
    cursor: pointer;
}

.discovered-printers-vendor-column select {
    width: 194px;
    height: 54px;
    font-size: 1rem;
    border-radius: 5px;
    border: 0.5px solid var(--border-default);
    box-sizing: border-box;
}

.discovered-printers-vendor-column a img.remove-icon {
    display: block;
    width: 14px;
    height: 25px;
    position: relative;
}

.printer-entries {
    position: relative;
}

.button-secondary, .button-secondary:focus,
.search-button, .search-button:focus{
    border-radius: 4px;
    background-color: var(--surface-primary);
    color: var(--theme-default-primary);
    text-decoration: none;
    text-transform: uppercase;
    text-align: center;
    font-size: 14px;
    border: 1px solid var(--theme-default-primary);
    box-shadow: none !important;
    cursor: pointer;
}

.button-secondary, .button-secondary:focus {
    display: block;
    padding: 14px 24px 12px;
    margin: 0 auto 0 auto;
}

.search-button, .search-button:focus {
    display: inline-block;
    margin-right: 5px;
    height: 38px;
    padding: 10px 14px;
    min-width: 120px;
}

.button-secondary:hover, .search-button:hover {
    background-color: var(--theme-default-button-secondary-background-active) !important;
    box-shadow: none !important;
    border: 1px solid var(--theme-default-primary) !important;
    color: var(--theme-default-primary);
}

.button-secondary:active, .search-button:active {
    background-color: var(--theme-default-button-secondary-background-active) !important;
    color: var(--theme-default-primary) !important;
    border-color: var(--theme-default-primary);
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

.input-with-label-inside {
    position: relative;
    max-width: 345px;
}

.input-with-label-inside label {
    position: absolute;
    top: 8px;
    left: 15px;
    font-size: 12px;
    font-weight: lighter;
    color: var(--theme-default-text-title);
    pointer-events: none;
    font-family: LabGrotesque, Roboto, Arial, Helvetica;
}

.input-with-label-inside .text-input {
    padding-top: 28px;
}

/* New floating label classes */
.input-with-floating-label {
    position: relative;
    max-width: 345px;
    max-height: 54px;
}

.input-with-floating-label label {
    position: absolute;
    top: calc(50% - 2px);
    left: 20px;
    transform: translateY(-50%);
    font-size: 16px;
    font-weight: lighter;
    color: var(--input-disabled-text);
    pointer-events: none;
    font-family: LabGrotesque, Roboto, Arial, Helvetica;
    transition: all 0.2s ease-in-out;
    padding-top: 7px;
}

.input-with-floating-label .text-input {
    padding: 16px 20px;
    width: 100%;
    text-indent: 0;
}

.input-with-floating-label .text-input:focus,
.input-with-floating-label .text-input:not(:placeholder-shown) {
    padding-top: 28px;
    padding-bottom: 12px;
}

.input-with-floating-label .text-input:focus + label,
.input-with-floating-label .text-input:not(:placeholder-shown) + label {
    top: 0px;
    transform: translateY(0);
    font-size: 12px;
    color: var(--text-muted);
}

.input-with-floating-label .text-input:focus + label {
    color: var(--theme-default-primary);
}

.input-with-label-inside .text-input-printer-info {
    padding-top: 28px;
    padding-right: 10px;
}

.input-with-label-inside .text-input-edit-info {
    padding-top: 28px;
    padding-left: 18px !important;
}

.text-input:disabled {
    background-color: var(--input-bg);
    cursor: not-allowed;
    border-bottom: 0.5px solid var(--border-input);
    color: var(--input-disabled-text);
}

.discovered-printers-vendor-column .text-input:disabled {
    background-color: var(--input-bg);
    cursor: not-allowed;
    border-bottom: 0.5px solid var(--border-input);
    color: var(--input-disabled-text);
}

.text-input-printer-info:disabled,
.text-input-printer-info:read-only {
    background-color: var(--input-bg);
    border: 0.5px solid var(--border-input);
    color: var(--input-disabled-text);
}

.text-input-edit-info:disabled {
    background-color: var(--input-bg);
    cursor: not-allowed;
    border-bottom: 0.5px solid var(--border-input);
}

.input-flex-container {
    background-color: var(--surface-primary);
    width: 790px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding-top: 10px;
    padding-left:47px;
}

.label-inside-input {
    z-index: 1;
}

.discovered-printers-vendor-column select:focus,
.discovered-printers-vendor-column select:valid {
    padding-left: 13px;
    padding-bottom: 5px;
}

/* dropdown colors */
.discovered-printers-vendor-column select {
    color: var(--text-heading);
}

.discovered-printers-vendor-column select:has(option:first-child:checked) {
    color: var(--input-disabled-text);
}

.discovered-printers-vendor-column select option {
    color: var(--text-heading) !important;
}

.discovered-printers-checkbox-column input[type="checkbox"] {
    width: 20px;
    height: 20px;
    transform-origin: center;
    cursor: pointer;
    accent-color: var(--status-info-accent);
    position: relative;
    top: -7px;
}

/* hide remove icon by default during autodiscovery, shows only during hover */
.eop-icon-remove {
    background-image: url('../theme/img/eop_icon_remove_primary.svg');
    width: 14px;
    height: 16px;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    visibility: hidden;
    display: inline-block;
}

#topLoadingBar {
    border-radius: 5px 5px 0px 0px;
    position: absolute;
    top: 0;
    left: 0;
    height: 4px;
    background-color: var(--theme-green-primary);
    width: 0%;
    z-index: 10;
    display: none; /* hidden initially */
}


.info-banner {
    border: 1px solid var(--theme-default-message-info-border);
    background: var(--theme-default-message-info-background);
    border-radius: 4px;
    font-size: 16px;
    margin-left: var(--left-offset, 0px);
    width: 823px;
    height: 50px;
    padding-left: 30px;
    text-align: left;
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
}

.info-icon {
    width: 20px;
    height: 20px;
    position: relative;
    top: -3px;
}

.icon-and-first {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.first-msg {
    margin: 0;
}

.icon-and-text {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-top: 15px;
}

.search-status-label {
    font-family: Ysoft, LabGrotesque, Roboto, Arial, Helvetica, sans-serif;
    font-size: 19px;
    margin-left: -3px;
    font-weight: bold;
}

.printer-separator {
    border-top: 1px solid var(--theme-default-background-selected);
    background-color: var(--surface-primary);
}

.discovered-printers-vendor-column .input-with-label-inside:has(select:disabled) .label-inside-input {
    color: var(--input-disabled-text);
}

.input-with-label-inside:has(input:disabled) .label-inside-input {
    color: var(--input-disabled-text);
}

.vendor-input,
.vendor-input:focus,
.vendor-input:focus-visible,
select:focus,
select:focus-visible {
    outline: none;
    border: 1px solid var(--theme-default-primary);
    box-shadow: none;
}

.bottom-info {
    font-size: 12px;
    color: var(--text-muted);
    text-align: center;
}

.added-printers-container {
    max-height: 180px;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
    scrollbar-color: rgba(0,0,0,0.2) transparent;
}

.printers-overview-button-column {
    visibility: hidden;
}

/* show edit button and grey background only when hovering over an entry */
.list-inner-flex-container:hover .printers-overview-button-column {
    visibility: visible;
}

.list-inner-flex-container:hover {
    background-color: var(--theme-default-background-selected);
}

.wizard-client-page {
    margin-top: 170px;
}

/*otherwise mozilla firefox does not display vendor dropdown properly*/
.k-block, .k-draghandle, .k-inline-block, .k-widget {
    border-style: none;
}

.how_get_ip {
    text-align: center;
    margin-top: 0.5rem;
}

.invitation-link {
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
    direction: ltr;
    padding-left: 15px;
    padding-right: 10px;
    display: flex;
    justify-content: center;
    text-align: center;
    width: 320px;
    margin-left: auto;
    margin-right: auto;
    display: block;
}


/*this part implements the custom dropdown*/
.k-widget.k-dropdown.custom-vendor-dropdown-layout {
    box-sizing: border-box;
    border-radius: 5px;
    background-color: var(--surface-primary);
    border: 1px solid var(--border-default);
    font-size: 16px;
    font-family: LabGrotesque, Roboto, Arial, Helvetica;
    width: 194px;
    height: 54px;
    line-height: 1.5;
    color: var(--text-on-surface);
    outline: none;
    top: 4px;
}

.discovered-printers-name-column .text-input-printer-info.k-textbox {
    width: 347px;
}

.discovered-printers-vendor-column {
    margin-top: -17px;
}

.k-dropdown .k-input, .k-dropdown .k-state-focused .k-input, .k-menu .k-popup {
    background-color: var(--surface-primary);
    color: var(--text-on-surface);
    text-indent: 0px;
    padding-top: 15px;
    line-height: 1.5;
}

.k-state-default>.k-select {
    background-color: var(--surface-primary);
}

.k-widget.k-dropdown.custom-vendor-dropdown-layout .k-input {
    line-height: 0.5;
    color: var(--text-on-surface);
    padding-top: 5px;
}


.k-dropdown .k-state-focused,
.k-dropdown .k-state-active,
.k-dropdown.k-focus {
    box-shadow: none !important;
}

/* Remove the inner border of the dropdown */
.k-widget.k-dropdown.custom-vendor-dropdown-layout .k-dropdown-wrap {
    border: none !important;
    box-shadow: none !important;
    background: transparent;
}

.k-widget.k-dropdown.custom-vendor-dropdown-layout .k-icon, .k-tool-icon {
    vertical-align: top;
}

/*dropdown colors styling*/
.k-list .k-item {
    background-color: var(--surface-primary);
    color: var(--text-on-surface);
    font-family: LabGrotesque, Roboto, Arial, Helvetica;
    font-size: 16px;
}

.k-list .k-item:hover,
.k-list .k-item.k-hover {
    background-color: var(--surface-secondary);
    color: var(--text-heading);
}

.k-list .k-item.k-selected,
.k-list .k-item.k-state-selected {
    background-color: var(--surface-primary);
    color: var(--theme-default-primary);
    font-weight: 500;
}

.k-list .k-item.k-selected:hover,
.k-list .k-item.k-state-selected.k-hover {
    background-color: var(--surface-tertiary);
    color: var(--theme-default-primary);
}

input.k-textbox:focus::placeholder {
    color: transparent;
}

.all-printer-entries {
    max-height: 400px;
    overflow-y: auto;
    overflow-x: hidden;
    background: var(--surface-primary);
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.2) transparent;
}

.discovered-printers-vendor-column .input-with-label-inside:has(input:disabled) .label-inside-input, .input-with-label-inside:has(select:disabled) .label-inside-input {
    top: 15px;
}

.discovered-printers-vendor-column .input-with-label-inside label {
    top: 11px;
}

.message-content > a {
    color: var(--theme-default-primary);
    text-decoration: none;
}

.message-content > a {
    color: var(--theme-default-link-hover);
}

.input-error-message ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.input-error-message li {
    list-style: none;
}

.input-wrapper-error input.text-input,
.input-wrapper-error input.text-input-printer-info.k-textbox {
    border: 1px solid var(--theme-default-icon-fail);
}

.input-wrapper-error input[type="checkbox"] {
    box-shadow: 0 0 0 2px rgba(232, 70, 69, 0.3);
    transition: box-shadow 0.2s ease;
}

.input-wrapper-error input[type="checkbox"]:checked {
    box-shadow: none;
}

.label.error {
    border: none;
}

.input-error-message {
    color: var(--theme-default-icon-fail);
    font-size: 0.75rem;
    margin-top: 4px;
    margin-bottom: 8px;
    line-height: 1.2;
}

.input-error-message:empty {
    margin: 0;
    height: 0;
}
/*
* Warning Tooltip, overrides eop.css
*/
.eop-icon-text-bottom-align {
    vertical-align: text-bottom;
    padding-left: 5px;
}

/*
* Warning Tooltip, overrides eop.css
*/
.tooltip-element:after {
    top: -300%;
    left: 550%;
}

label.label-inside-input.readonly {
    color: var(--input-disabled-text);
}

/* =========================
   AIR LICENSE (KM BRANDING)
   ========================= */
body.air-license {
    /* Brand Colors */
    --km-blue: var(--theme-kmblue-primary);
    --km-blue-hover: var(--theme-kmblue-button-primary-background-dark);
    --km-blue-light: var(--theme-default-palette-button-background);

    /* Common Patterns */
    --km-border: 1px solid var(--km-blue);
    --km-border-hover: 1px solid var(--km-blue-hover);
}

/* Background triangle */
body.air-license .wizard-page__triangle {
    top: 0 !important;
    height: 100vh !important;
}

body.air-license .wizard-page__triangle::before,
body.air-license .wizard-page__triangle::after {
    background-color: var(--km-blue) !important;
}

/* Primary buttons */
body.air-license .submit-button--button,
body.air-license .button-secondary.button-secondary--variant2 {
    background-color: var(--km-blue) !important;
    color: var(--text-inverse) !important;
}

body.air-license .button-secondary.button-secondary--variant2 {
    border: var(--km-border) !important;
}

body.air-license .submit-button--button:hover,
body.air-license .button-secondary.button-secondary--variant2:hover {
    background-color: var(--km-blue-hover) !important;
    color: var(--text-inverse) !important;
}

body.air-license .button-secondary.button-secondary--variant2:hover {
    border: var(--km-border-hover) !important;
}

body.air-license .submit-button--button:active,
body.air-license .button-secondary.button-secondary--variant2:active {
    background-color: var(--km-blue) !important;
    color: var(--text-inverse) !important;
}

/* Secondary/Blue outline buttons */
body.air-license .button-secondary,
body.air-license .search-button,
body.air-license .button-delete {
    border: var(--km-border) !important;
    color: var(--km-blue) !important;
}

body.air-license .button-secondary:hover,
body.air-license .search-button:hover {
    background-color: var(--km-blue-light) !important;
    border: var(--km-border) !important;
    color: var(--km-blue) !important;
}

body.air-license .button-secondary:active,
body.air-license .search-button:active {
    background-color: var(--km-blue-light) !important;
    color: var(--km-blue) !important;
    border-color: var(--km-blue) !important;
}

/* Progress bar */
body.air-license .progress-step.blue {
    background-color: var(--km-blue) !important;
}

/* All elements with KM blue color */
body.air-license .signup-checkmark-green,
body.air-license .wizard-link,
body.air-license .large-link,
body.air-license .large-link-print,
body.air-license .privacyLegalDocuments--acceptance,
body.air-license .wizard-custom-error a,
body.air-license .large-link-skip {
    color: var(--km-blue) !important;
}

/* Hover states for interactive elements */
body.air-license .wizard-link:focus,
body.air-license .wizard-link:hover,
body.air-license .privacyLegalDocuments--acceptance:hover,
body.air-license .wizard-custom-error a:hover,
body.air-license .large-link-skip:hover {
    color: var(--km-blue-hover) !important;
}

body.air-license .wizard-link:focus,
body.air-license .wizard-link:hover {
    text-shadow: 0.03ex 0 0 #004A94c7;
}

/* Input focus states - border color */
body.air-license .text-input-printer-info:focus,
body.air-license .text-input-printer-info:hover,
body.air-license .text-input-edit-info:focus,
body.air-license input.text-input:focus {
    border-color: var(--km-blue) !important;
}

body.air-license .vendor-input:focus,
body.air-license .vendor-input:focus-visible,
body.air-license select:focus,
body.air-license select:focus-visible {
    border: var(--km-border) !important;
}

/* Input labels */
body.air-license .input-with-floating-label .text-input:focus + label {
    color: var(--km-blue) !important;
}

/* Dropdown selections */
body.air-license .k-list .k-item.k-state-selected,
body.air-license .k-list .k-item.k-selected,
body.air-license .k-list .k-item.k-state-selected.k-hover,
body.air-license .k-list .k-item.k-selected:hover {
    color: var(--km-blue) !important;
}

/* Checkboxes and interactive elements */
body.air-license .clickable,
body.air-license input[type="checkbox"],
body.air-license .discovered-printers-checkbox-column input[type="checkbox"] {
    accent-color: var(--km-blue) !important;
}

/* Password policy checkmarks */
body.air-license .password-rule.satisfied:before {
    color: var(--km-blue) !important;
}

/* Mobile-first header layout for better logo contrast */
body.air-license .wizard-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 19px 16px !important;
}

/* Logo styling - always use mobile variant */
body.air-license .wizard-header__logo--mobile {
    max-width: 160px !important;
    margin-left: 10px !important;
}

body.air-license .wizard-header__logo--desktop {
    display: none !important;
}

/* Language selector visibility */
body.air-license .wizard-header__language-selector {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Desktop layout adjustments */
@media (min-width: 1300px) {
    body.air-license .wizard-header {
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        width: calc(100% - 300px) !important;
        z-index: 10 !important;
        padding: 40px 20px 19px 16px !important;
    }

    body.air-license .wizard-header__logo--mobile {
        display: inline !important;
        max-width: 180px !important;
        margin-left: 20px !important;
    }

    body.air-license .wizard-header__language-selector {
        margin-right: 20px !important;
    }

    body.air-license .wizard-page-container {
        padding-top: 100px !important;
        padding-left: 20px !important;
        padding-right: 320px !important;
    }
}

/* Loading spinner color adjustment */
body.air-license .fullscreen-spinner--img {
    filter: hue-rotate(320deg) saturate(2.0) brightness(1.2) !important;
}

/* Air License Info Banner Colors */
body.air-license .info-banner {
    background: #0062C20D !important;
    border: 1px solid #0062C2B2 !important;
}
