@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');

html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: #0071c1;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 20vh auto 1rem auto;
}

    .loading-progress circle {
        fill: none;
        stroke: #e0e0e0;
        stroke-width: 0.6rem;
        transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

        .loading-progress circle:last-child {
            stroke: #1b6ec2;
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    inset: calc(20vh + 3.25rem) 0 auto 0.2rem;
}

    .loading-progress-text:after {
        content: var(--blazor-load-percentage-text, "Loading");
    }

/*
! tailwindcss v3.2.1 | MIT License | https://tailwindcss.com
*/ /*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
    box-sizing: border-box; /* 1 */
    border-width: 0; /* 2 */
    border-style: solid; /* 2 */
    border-color: #e5e7eb; /* 2 */
}

::before,
::after {
    --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
*/

html {
    line-height: 1.5; /* 1 */
    -webkit-text-size-adjust: 100%; /* 2 */
    -moz-tab-size: 4; /* 3 */
    -o-tab-size: 4;
    tab-size: 4; /* 3 */
    font-family: Roboto; /* 4 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
    margin: 0; /* 1 */
    line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
    height: 0; /* 1 */
    color: inherit; /* 2 */
    border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: inherit;
    font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
    color: inherit;
    text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
    font-weight: bolder;
}

/*
1. Use the user's configured `mono` font family by default.
2. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
    font-size: 1em; /* 2 */
}

/*
Add the correct font size in all browsers.
*/

small {
    font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
    text-indent: 0; /* 1 */
    border-color: inherit; /* 2 */
    border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
    font-family: inherit; /* 1 */
    font-size: 100%; /* 1 */
    font-weight: inherit; /* 1 */
    line-height: inherit; /* 1 */
    color: inherit; /* 1 */
    margin: 0; /* 2 */
    padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
    text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
[type='button'],
[type='reset'],
[type='submit'] {
    -webkit-appearance: button; /* 1 */
    background-color: transparent; /* 2 */
    background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
    outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
    box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
    vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
    height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
    -webkit-appearance: textfield; /* 1 */
    outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
    -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
    -webkit-appearance: button; /* 1 */
    font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
    display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
    margin: 0;
}

fieldset {
    margin: 0;
    padding: 0;
}

legend {
    padding: 0;
}

ol,
ul,
menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
    resize: vertical;
}

    /*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

    input::-moz-placeholder, textarea::-moz-placeholder {
        opacity: 1; /* 1 */
        color: #9ca3af; /* 2 */
    }

    input::placeholder,
    textarea::placeholder {
        opacity: 1; /* 1 */
        color: #9ca3af; /* 2 */
    }

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
    cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
    cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
    display: block; /* 1 */
    vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
    max-width: 100%;
    height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden] {
    display: none;
}

*, ::before, ::after {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x:;
    --tw-pan-y:;
    --tw-pinch-zoom:;
    --tw-scroll-snap-strictness: proximity;
    --tw-ordinal:;
    --tw-slashed-zero:;
    --tw-numeric-figure:;
    --tw-numeric-spacing:;
    --tw-numeric-fraction:;
    --tw-ring-inset:;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / 0.5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur:;
    --tw-brightness:;
    --tw-contrast:;
    --tw-grayscale:;
    --tw-hue-rotate:;
    --tw-invert:;
    --tw-saturate:;
    --tw-sepia:;
    --tw-drop-shadow:;
    --tw-backdrop-blur:;
    --tw-backdrop-brightness:;
    --tw-backdrop-contrast:;
    --tw-backdrop-grayscale:;
    --tw-backdrop-hue-rotate:;
    --tw-backdrop-invert:;
    --tw-backdrop-opacity:;
    --tw-backdrop-saturate:;
    --tw-backdrop-sepia:;
}

::backdrop {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x:;
    --tw-pan-y:;
    --tw-pinch-zoom:;
    --tw-scroll-snap-strictness: proximity;
    --tw-ordinal:;
    --tw-slashed-zero:;
    --tw-numeric-figure:;
    --tw-numeric-spacing:;
    --tw-numeric-fraction:;
    --tw-ring-inset:;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgb(59 130 246 / 0.5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur:;
    --tw-brightness:;
    --tw-contrast:;
    --tw-grayscale:;
    --tw-hue-rotate:;
    --tw-invert:;
    --tw-saturate:;
    --tw-sepia:;
    --tw-drop-shadow:;
    --tw-backdrop-blur:;
    --tw-backdrop-brightness:;
    --tw-backdrop-contrast:;
    --tw-backdrop-grayscale:;
    --tw-backdrop-hue-rotate:;
    --tw-backdrop-invert:;
    --tw-backdrop-opacity:;
    --tw-backdrop-saturate:;
    --tw-backdrop-sepia:;
}

.container {
    width: 100%;
}

@media (min-width: 640px) {

    .container {
        max-width: 640px;
    }
}

@media (min-width: 768px) {

    .container {
        max-width: 768px;
    }
}

@media (min-width: 1024px) {

    .container {
        max-width: 1024px;
    }
}

@media (min-width: 1280px) {

    .container {
        max-width: 1280px;
    }
}

@media (min-width: 1536px) {

    .container {
        max-width: 1536px;
    }
}

.form-input, .form-textarea, .form-select, .form-multiselect {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: #fff;
    border-color: #6b7280;
    border-width: 1px;
    border-radius: 0px;
    padding-top: 0.5rem;
    padding-right: 0.75rem;
    padding-bottom: 0.5rem;
    padding-left: 0.75rem;
    font-size: 1rem;
    line-height: 1.5rem;
    --tw-shadow: 0 0 #0000;
}

    .form-input:focus, .form-textarea:focus, .form-select:focus, .form-multiselect:focus {
        outline: 2px solid transparent;
        outline-offset: 2px;
        --tw-ring-inset: var(--tw-empty, /*!*/ /*!*/ );
        --tw-ring-offset-width: 0px;
        --tw-ring-offset-color: #fff;
        --tw-ring-color: #2563eb;
        --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
        --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
        box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
        border-color: #2563eb;
    }

    .form-input::-moz-placeholder, .form-textarea::-moz-placeholder {
        color: #6b7280;
        opacity: 1;
    }

    .form-input::placeholder, .form-textarea::placeholder {
        color: #6b7280;
        opacity: 1;
    }

    .form-input::-webkit-datetime-edit-fields-wrapper {
        padding: 0;
    }

    .form-input::-webkit-date-and-time-value {
        min-height: 1.5em;
    }

    .form-input::-webkit-datetime-edit, .form-input::-webkit-datetime-edit-year-field, .form-input::-webkit-datetime-edit-month-field, .form-input::-webkit-datetime-edit-day-field, .form-input::-webkit-datetime-edit-hour-field, .form-input::-webkit-datetime-edit-minute-field, .form-input::-webkit-datetime-edit-second-field, .form-input::-webkit-datetime-edit-millisecond-field, .form-input::-webkit-datetime-edit-meridiem-field {
        padding-top: 0;
        padding-bottom: 0;
    }

.form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2.5rem;
    -webkit-print-color-adjust: exact;
    color-adjust: exact;
}

.pointer-events-none {
    pointer-events: none;
}

.absolute {
    position: absolute;
}

.relative {
    position: relative;
}

.top-0 {
    top: 0px;
}

.top-1\/2 {
    top: 50%;
}

.bottom-0 {
    bottom: 0px;
}

.isolate {
    isolation: isolate;
}

.z-40 {
    z-index: 40;
}

.col-span-1 {
    grid-column: span 1 / span 1;
}

.col-span-2 {
    grid-column: span 2 / span 2;
}

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.my-8 {
    margin-top: 2rem;
    margin-bottom: 2rem;
}

.mx-5 {
    margin-left: 1.25rem;
    margin-right: 1.25rem;
}

.mb-5 {
    margin-bottom: 1.25rem;
}

.-mt-5 {
    margin-top: -1.25rem;
}

.mt-3 {
    margin-top: 0.75rem;
}

.ml-2 {
    margin-left: 0.5rem;
}

.mb-3 {
    margin-bottom: 0.75rem;
}

.mt-1 {
    margin-top: 0.25rem;
}

.mb-2 {
    margin-bottom: 0.5rem;
}

.ml-16 {
    margin-left: 4rem;
}

.mt-6 {
    margin-top: 1.5rem;
}

.mb-20 {
    margin-bottom: 5rem;
}

.mb-24 {
    margin-bottom: 6rem;
}

.mt-16 {
    margin-top: 4rem;
}

.mb-6 {
    margin-bottom: 1.5rem;
}

.mt-12 {
    margin-top: 3rem;
}

.mb-12 {
    margin-bottom: 3rem;
}

.mt-8 {
    margin-top: 2rem;
}

.mb-8 {
    margin-bottom: 2rem;
}

.mb-10 {
    margin-bottom: 2.5rem;
}

.\!mt-0 {
    margin-top: 0px !important;
}

.mt-20 {
    margin-top: 5rem;
}

.mt-4 {
    margin-top: 1rem;
}

.mt-5 {
    margin-top: 1.25rem;
}

.-mt-8 {
    margin-top: -2rem;
}

.-mt-9 {
    margin-top: -2.25rem;
}

.block {
    display: block;
}

.flex {
    display: flex;
}

.table {
    display: table;
}

.grid {
    display: grid;
}

.contents {
    display: contents;
}

.hidden {
    display: none;
}

.h-full {
    height: 100%;
}

.h-12 {
    height: 3rem;
}

.h-40 {
    height: 10rem;
}

.h-48 {
    height: 12rem;
}

.max-h-\[400px\] {
    max-height: 400px;
}

.max-h-\[240px\] {
    max-height: 240px;
}

.min-h-screen {
    min-height: 100vh;
}

.min-h-\[300px\] {
    min-height: 300px;
}

.w-full {
    width: 100%;
}

.w-0 {
    width: 0px;
}

.w-12 {
    width: 3rem;
}

.w-80 {
    width: 20rem;
}

.w-60 {
    width: 15rem;
}

.w-\[170px\] {
    width: 170px;
}

.w-20 {
    width: 5rem;
}

.\!w-auto {
    width: auto !important;
}

.max-w-7xl {
    max-width: 80rem;
}

.max-w-xl {
    max-width: 36rem;
}

.max-w-\[130px\] {
    max-width: 130px;
}

.flex-1 {
    flex: 1 1 0%;
}

.shrink-0 {
    flex-shrink: 0;
}

.grow {
    flex-grow: 1;
}

.basis-2\/3 {
    flex-basis: 66.666667%;
}

.basis-0 {
    flex-basis: 0px;
}

.basis-1\/2 {
    flex-basis: 50%;
}

.table-fixed {
    table-layout: fixed;
}

.-translate-y-1\/2 {
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-90 {
    --tw-rotate: 90deg;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

@keyframes spin {

    to {
        transform: rotate(360deg);
    }
}

.animate-spin {
    animation: spin 1s linear infinite;
}

.snap-y {
    scroll-snap-type: y var(--tw-scroll-snap-strictness);
}

.snap-mandatory {
    --tw-scroll-snap-strictness: mandatory;
}

.list-inside {
    list-style-position: inside;
}

.list-disc {
    list-style-type: disc;
}

.grid-flow-row-dense {
    grid-auto-flow: row dense;
}

.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

.grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.flex-col {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.place-items-center {
    place-items: center;
}

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

.items-stretch {
    align-items: stretch;
}

.justify-center {
    justify-content: center;
}

.justify-between {
    justify-content: space-between;
}

.justify-around {
    justify-content: space-around;
}

.justify-items-stretch {
    justify-items: stretch;
}

.gap-3 {
    gap: 0.75rem;
}

.gap-6 {
    gap: 1.5rem;
}

.gap-1 {
    gap: 0.25rem;
}

.gap-12 {
    gap: 3rem;
}

.gap-2 {
    gap: 0.5rem;
}

.gap-16 {
    gap: 4rem;
}

.gap-y-4 {
    row-gap: 1rem;
}

.overflow-hidden {
    overflow: hidden;
}

.overflow-x-scroll {
    overflow-x: scroll;
}

.overflow-y-scroll {
    overflow-y: scroll;
}

.truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.rounded-lg {
    border-radius: 0.5rem;
}

.rounded-xl {
    border-radius: 0.75rem;
}

.rounded-sm {
    border-radius: 0.125rem;
}

.border-x-\[3px\] {
    border-left-width: 3px;
    border-right-width: 3px;
}

.border-t {
    border-top-width: 1px;
}

.border-b {
    border-bottom-width: 1px;
}

.border-r {
    border-right-width: 1px;
}

.border-b-\[5px\] {
    border-bottom-width: 5px;
}

.border-l {
    border-left-width: 1px;
}

.border-b-\[1px\] {
    border-bottom-width: 1px;
}

.border-b-\[3px\] {
    border-bottom-width: 3px;
}

.border-\[\#F3F3F3\] {
    --tw-border-opacity: 1;
    border-color: rgb(243 243 243 / var(--tw-border-opacity));
}

.border-mel-dark-blue {
    --tw-border-opacity: 1;
    border-color: rgb(32 63 104 / var(--tw-border-opacity));
}

.border-white {
    --tw-border-opacity: 1;
    border-color: rgb(255 255 255 / var(--tw-border-opacity));
}

.border-mel-light-gray {
    border-color: rgba(173,182,195,0.25);
}

.bg-mel-light-blue {
    --tw-bg-opacity: 1;
    background-color: rgb(231 240 244 / var(--tw-bg-opacity));
}

.bg-mel-dark-gray {
    --tw-bg-opacity: 1;
    background-color: rgb(127 126 131 / var(--tw-bg-opacity));
}

.bg-mel-red {
    --tw-bg-opacity: 1;
    background-color: rgb(237 28 36 / var(--tw-bg-opacity));
}

.bg-mel-orange {
    --tw-bg-opacity: 1;
    background-color: rgb(246 159 58 / var(--tw-bg-opacity));
}

.bg-mel-green {
    --tw-bg-opacity: 1;
    background-color: rgb(61 223 119 / var(--tw-bg-opacity));
}

.bg-mel-dark-blue {
    --tw-bg-opacity: 1;
    background-color: rgb(32 63 104 / var(--tw-bg-opacity));
}

.bg-red-500 {
    --tw-bg-opacity: 1;
    background-color: rgb(239 68 68 / var(--tw-bg-opacity));
}

.bg-green-500 {
    --tw-bg-opacity: 1;
    background-color: rgb(34 197 94 / var(--tw-bg-opacity));
}

.bg-white {
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

.bg-mel-darkish-blue {
    --tw-bg-opacity: 1;
    background-color: rgb(152 193 214 / var(--tw-bg-opacity));
}

.bg-\[\#353A50\] {
    --tw-bg-opacity: 1;
    background-color: rgb(53 58 80 / var(--tw-bg-opacity));
}

.bg-\[rgba\(234\2c 237\2c 240\2c \.5\)\] {
    background-color: rgba(234,237,240,.5);
}

.bg-mel-darker-blue {
    --tw-bg-opacity: 1;
    background-color: rgb(136 173 192 / var(--tw-bg-opacity));
}

.bg-gradient-to-b {
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}

.bg-gradient-to-t {
    background-image: linear-gradient(to top, var(--tw-gradient-stops));
}

.from-mel-orange-start {
    --tw-gradient-from: #F0712A;
    --tw-gradient-to: rgb(240 113 42 / 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-mel-cold-start {
    --tw-gradient-from: #4394f7;
    --tw-gradient-to: rgb(67 148 247 / 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-\[\#F9F9FB\] {
    --tw-gradient-from: #F9F9FB;
    --tw-gradient-to: rgb(249 249 251 / 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-white {
    --tw-gradient-from: #fff;
    --tw-gradient-to: rgb(255 255 255 / 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.via-white {
    --tw-gradient-to: rgb(255 255 255 / 0);
    --tw-gradient-stops: var(--tw-gradient-from), #fff, var(--tw-gradient-to);
}

.to-mel-orange-end {
    --tw-gradient-to: #FCCB4A;
}

.to-mel-cold-end {
    --tw-gradient-to: #a5d1fa;
}

.object-cover {
    -o-object-fit: cover;
    object-fit: cover;
}

.p-2 {
    padding: 0.5rem;
}

.p-3 {
    padding: 0.75rem;
}

.px-3 {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.py-4 {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.px-2 {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.px-5 {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.py-3 {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.px-1 {
    padding-left: 0.25rem;
    padding-right: 0.25rem;
}

.py-8 {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.py-2 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.\!px-5 {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
}

.py-6 {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
}

.py-10 {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
}

.px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
}

.pt-\[50px\] {
    padding-top: 50px;
}

.pb-5 {
    padding-bottom: 1.25rem;
}

.pb-2 {
    padding-bottom: 0.5rem;
}

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

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

.text-\[16px\] {
    font-size: 16px;
}

.text-\[12px\] {
    font-size: 12px;
}

.text-\[28px\] {
    font-size: 28px;
}

.text-\[21px\] {
    font-size: 21px;
}

.text-2xs {
    font-size: .65rem;
}

.text-\[18px\] {
    font-size: 18px;
}

.text-\[43px\] {
    font-size: 43px;
}

.text-\[48px\] {
    font-size: 48px;
}

.text-\[24px\] {
    font-size: 24px;
}

.text-xs {
    font-size: 0.75rem;
    line-height: 1rem;
}

.text-\[14px\] {
    font-size: 14px;
}

.text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
}

.text-\[13px\] {
    font-size: 13px;
}

.text-\[152px\] {
    font-size: 152px;
}

.text-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
}

.text-\[45px\] {
    font-size: 45px;
}

.text-\[52px\] {
    font-size: 52px;
}

.text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
}

.font-medium {
    font-weight: 500;
}

.font-bold {
    font-weight: 700;
}

.font-thin {
    font-weight: 100;
}

.uppercase {
    text-transform: uppercase;
}

.lowercase {
    text-transform: lowercase;
}

.\!leading-6 {
    line-height: 1.5rem !important;
}

.\!leading-7 {
    line-height: 1.75rem !important;
}

.leading-\[17px\] {
    line-height: 17px;
}

.leading-\[14px\] {
    line-height: 14px;
}

.leading-\[55px\] {
    line-height: 55px;
}

.leading-\[16px\] {
    line-height: 16px;
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

.text-mel-mid-gray {
    --tw-text-opacity: 1;
    color: rgb(173 182 195 / var(--tw-text-opacity));
}

.text-mel-mid-blue {
    --tw-text-opacity: 1;
    color: rgb(4 186 255 / var(--tw-text-opacity));
}

.text-mel-dark-gray {
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.text-mel-dark-blue {
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.text-mel-red {
    --tw-text-opacity: 1;
    color: rgb(237 28 36 / var(--tw-text-opacity));
}

.text-mel-green {
    --tw-text-opacity: 1;
    color: rgb(61 223 119 / var(--tw-text-opacity));
}

.underline {
    -webkit-text-decoration-line: underline;
    text-decoration-line: underline;
}

.opacity-40 {
    opacity: 0.4;
}

.opacity-60 {
    opacity: 0.6;
}

.shadow-lg {
    --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-xl {
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.transition {
    transition-property: color, background-color, border-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-text-decoration-color, -webkit-backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-text-decoration-color, -webkit-backdrop-filter;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}
/* roboto-100 - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 100;
    font-display: swap;
    src: url('/assets/fonts/roboto/roboto-v29-latin-100.eot'); /* IE9 Compat Modes */
    src: local(''), url('/assets/fonts/roboto/roboto-v29-latin-100.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('/assets/fonts/roboto/roboto-v29-latin-100.woff2') format('woff2'), /* Super Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-100.woff') format('woff'), /* Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-100.ttf') format('truetype'), /* Safari, Android, iOS */
    url('/assets/fonts/roboto/roboto-v29-latin-100.svg#Roboto') format('svg'); /* Legacy iOS */
}
/* roboto-300 - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url('/assets/fonts/roboto/roboto-v29-latin-300.eot'); /* IE9 Compat Modes */
    src: local(''), url('/assets/fonts/roboto/roboto-v29-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('/assets/fonts/roboto/roboto-v29-latin-300.woff2') format('woff2'), /* Super Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-300.woff') format('woff'), /* Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-300.ttf') format('truetype'), /* Safari, Android, iOS */
    url('/assets/fonts/roboto/roboto-v29-latin-300.svg#Roboto') format('svg'); /* Legacy iOS */
}
/* roboto-regular - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('/assets/fonts/roboto/roboto-v29-latin-regular.eot'); /* IE9 Compat Modes */
    src: local(''), url('/assets/fonts/roboto/roboto-v29-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('/assets/fonts/roboto/roboto-v29-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-regular.woff') format('woff'), /* Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
    url('/assets/fonts/roboto/roboto-v29-latin-regular.svg#Roboto') format('svg'); /* Legacy iOS */
}
/* roboto-500 - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url('/assets/fonts/roboto/roboto-v29-latin-500.eot'); /* IE9 Compat Modes */
    src: local(''), url('/assets/fonts/roboto/roboto-v29-latin-500.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('/assets/fonts/roboto/roboto-v29-latin-500.woff2') format('woff2'), /* Super Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-500.woff') format('woff'), /* Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-500.ttf') format('truetype'), /* Safari, Android, iOS */
    url('/assets/fonts/roboto/roboto-v29-latin-500.svg#Roboto') format('svg'); /* Legacy iOS */
}
/* roboto-700 - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url('/assets/fonts/roboto/roboto-v29-latin-700.eot'); /* IE9 Compat Modes */
    src: local(''), url('/assets/fonts/roboto/roboto-v29-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('/assets/fonts/roboto/roboto-v29-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-700.woff') format('woff'), /* Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
    url('/assets/fonts/roboto/roboto-v29-latin-700.svg#Roboto') format('svg'); /* Legacy iOS */
}
/* roboto-900 - latin */
@font-face {
    font-family: 'Roboto';
    font-style: normal;
    font-weight: 900;
    font-display: swap;
    src: url('/assets/fonts/roboto/roboto-v29-latin-900.eot'); /* IE9 Compat Modes */
    src: local(''), url('/assets/fonts/roboto/roboto-v29-latin-900.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('/assets/fonts/roboto/roboto-v29-latin-900.woff2') format('woff2'), /* Super Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-900.woff') format('woff'), /* Modern Browsers */
    url('/assets/fonts/roboto/roboto-v29-latin-900.ttf') format('truetype'), /* Safari, Android, iOS */
    url('/assets/fonts/roboto/roboto-v29-latin-900.svg#Roboto') format('svg'); /* Legacy iOS */
}

@font-face {
    font-family: 'icomoon';
    src: url('/assets/fonts/icomoon.eot?xv5l1w');
    src: url('/assets/fonts/icomoon.eot?xv5l1w#iefix') format('embedded-opentype'), url('/assets/fonts/icomoon.ttf?xv5l1w') format('truetype'), url('/assets/fonts/icomoon.woff?xv5l1w') format('woff'), url('/assets/fonts/icomoon.svg?xv5l1w#icomoon') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: block;
}

i[class^="icon-"], i[class*=" icon-"] {
    /* use !important to prevent issues with browser extensions that change fonts */
    font-family: 'icomoon' !important;
    speak: never;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.icon-iconsarrowleft:before {
    content: "\e90f";
    color: #7f7e83;
}

.icon-heat:before {
    content: "\e907";
    color: #ff9d2d;
}

.icon-cool:before {
    content: "\e909";
    color: #04baff;
}

.icon-cross-1:before {
    content: "\e91d";
    color: #203f68;
}

.icon-geoholiday:before {
    content: "\e900";
    color: #04baff;
}

.icon-bypass:before {
    content: "\e901";
    color: #ff9d2d;
}

.icon-coremaintenance:before {
    content: "\e902";
    color: #203f68;
}

.icon-energyrecovery:before {
    content: "\e903";
    color: #04baff;
}

.icon-filtermaintenance:before {
    content: "\e904";
    color: #04baff;
}

.icon-caretdown:before {
    content: "\e905";
    color: #7f7e83;
}

.icon-caretup:before {
    content: "\e906";
    color: #7f7e83;
}

.icon-flow:before {
    content: "\e908";
    color: #7f7e83;
}

.icon-hotwater:before {
    content: "\e90a";
    color: #ed1f24;
}

.icon-temperature:before {
    content: "\e90b";
    color: #f69f3a;
}

.icon-dry:before {
    content: "\e90c";
    color: #02b1a4;
}

.icon-arrowdown:before {
    content: "\e90d";
    color: #7f7e83;
}

.icon-arrowleft:before {
    content: "\e90e";
    color: #7f7e83;
}

.icon-arrowright:before {
    content: "\e90f";
    color: #7f7e83;
}

.icon-arrowup:before {
    content: "\e910";
    color: #7f7e83;
}

.icon-auto:before {
    content: "\e911";
    color: #3ddf77;
}

.icon-checkmark .path1:before {
    content: "\e912";
    color: rgb(6, 175, 0);
    opacity: 0.1;
}

.icon-checkmark .path2:before {
    content: "\e913";
    margin-left: -1em;
    color: rgb(6, 175, 0);
}

.icon-coremaint:before {
    content: "\e914";
    color: #203f68;
}

.icon-down-caret:before {
    content: "\e915";
    color: #fff;
}

.icon-energyrecov:before {
    content: "\e916";
    color: #04baff;
}

.icon-fan:before {
    content: "\e917";
    color: #203f68;
}

.icon-filtermaint:before {
    content: "\e918";
    color: #04baff;
}

.icon-hand:before {
    content: "\e919";
    color: #203f68;
}

.icon-homeinactive:before {
    content: "\e91a";
}

.icon-homemapinactive:before {
    content: "\e91b";
    color: #3ddf77;
}

.icon-location:before {
    content: "\e91c";
    color: #454f63;
}

.icon-plus:before {
    content: "\e91d";
    color: #505054;
}

.icon-power:before {
    content: "\e91e";
    color: #7f7e83;
}

.icon-swing:before {
    content: "\e91f";
    color: #04baff;
}

.icon-timer:before {
    content: "\e920";
    color: #203f68;
}

.icon-alert .path1:before {
    content: "\e921";
    color: rgb(255, 0, 0);
}

.icon-alert .path2:before {
    content: "\e922";
    margin-left: -1em;
    color: none;
}

.icon-alert .path3:before {
    content: "\e923";
    margin-left: -1em;
    color: rgb(255, 255, 255);
}

.icon-arrow-nav-select:before {
    content: "\e924";
    color: #e4e4e4;
}

.icon-bedroom:before {
    content: "\e925";
    color: #203f68;
}

.icon-calendar:before {
    content: "\e926";
    color: #adb6c3;
}

.icon-cloud:before {
    content: "\e927";
    color: #203f68;
}

.icon-cross:before {
    content: "\e928";
    color: #203f68;
}

.icon-homemap .path1:before {
    content: "\e929";
    color: rgb(0, 0, 0);
    opacity: 0.23;
}

.icon-homemap .path2:before {
    content: "\e92a";
    margin-left: -1.076171875em;
    color: rgb(61, 223, 119);
}

.icon-homemap .path3:before {
    content: "\e92b";
    margin-left: -1.076171875em;
    color: none;
}

.icon-library:before {
    content: "\e92c";
    color: #203f68;
}

.icon-lounge:before {
    content: "\e92d";
    color: #203f68;
}

.icon-map:before {
    content: "\e92e";
    color: #adb6c3;
}

.icon-office:before {
    content: "\e92f";
    color: #203f68;
}

.icon-report:before {
    content: "\e930";
    color: #adb6c3;
}

.icon-search:before {
    content: "\e931";
    color: #adb6c3;
}

.icon-vanehor:before {
    content: "\e932";
    color: #7f7e83;
}

.icon-vanevert:before {
    content: "\e933";
    color: #7f7e83;
}
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-Th.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Th.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Th.ttf') format('truetype');*/
/*    font-weight: 100;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-Ex.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Ex.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Ex.ttf') format('truetype');*/
/*    font-weight: normal;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-Md.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Md.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Md.ttf') format('truetype');*/
/*    font-weight: 500;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-Blk.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Blk.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Blk.ttf') format('truetype');*/
/*    font-weight: 900;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-UltLt.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-UltLt.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-UltLt.ttf') format('truetype');*/
/*    font-weight: 200;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-Bd.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Bd.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Bd.ttf') format('truetype');*/
/*    font-weight: bold;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-Roman.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Roman.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Roman.ttf') format('truetype');*/
/*    font-weight: normal;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-Hv.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Hv.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Hv.ttf') format('truetype');*/
/*    font-weight: 900;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
/*@font-face {*/
/*    font-family: 'Helvetica Neue LT Std';*/
/*    src: url('/assets/fonts/HelveticaNeueLTStd-Lt.woff2') format('woff2'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Lt.woff') format('woff'),*/
/*    url('/assets/fonts/HelveticaNeueLTStd-Lt.ttf') format('truetype');*/
/*    font-weight: 300;*/
/*    font-style: normal;*/
/*    font-display: swap;*/
/*}*/
.app {
    position: relative;
    display: flex;
    height: 100%;
    min-height: 100vh;
    flex-direction: column;
    font-family: Roboto;
    padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}

.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border-radius: 9999px;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    text-align: center;
    font-size: 11px;
    text-transform: uppercase;
    line-height: 13px;
    --tw-text-opacity: 1;
    color: rgb(173 182 195 / var(--tw-text-opacity));
}

    .btn:disabled {
        background-color: rgba(32,63,104,0.3);
    }

.btn--medium {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    padding-left: 2rem;
    padding-right: 2rem;
    font-size: 15px;
    line-height: 18px;
}

.btn--large {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    padding-left: 1rem;
    padding-right: 1rem;
    font-size: 15px;
    line-height: 18px;
}

.btn--block {
    width: 100%;
}

.btn--blue {
    --tw-bg-opacity: 1;
    background-color: rgb(32 63 104 / var(--tw-bg-opacity));
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

.btn--light-blue {
    --tw-bg-opacity: 1;
    background-color: rgb(231 240 244 / var(--tw-bg-opacity));
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.icon-badge {
    position: relative;
}

.icon-badge__label {
    position: absolute;
    top: -0.5rem;
    left: -0.5rem;
    z-index: 10;
    display: block;
    display: flex;
    min-height: 1rem;
    min-width: 1rem;
    max-width: 1rem;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border-radius: 9999px;
    border-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(255 255 255 / var(--tw-border-opacity));
    padding-left: 0.25rem;
    padding-right: 0.25rem;
    padding-top: 1px;
    text-align: center;
    font-family: Roboto;
    font-size: 8px;
    line-height: 10px;
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

.icon-badge--blue {
    --tw-bg-opacity: 1;
    background-color: rgb(32 63 104 / var(--tw-bg-opacity));
}

.icon-badge--red {
    --tw-bg-opacity: 1;
    background-color: rgb(239 68 68 / var(--tw-bg-opacity));
}

.form-control {
    margin-left: 0.75rem;
    margin-right: 0.75rem;
    margin-bottom: 1.25rem;
    display: flex;
    flex-direction: column;
    text-align: left;
}

.form-control--white .form-select {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

.form-label {
    font-size: 0.875rem;
    line-height: 1.25rem;
    opacity: 0.5;
}

.form-input {
    display: block;
    width: 100%;
    border-width: 0px;
    border-bottom-width: 2px;
    --tw-border-opacity: 1;
    border-color: rgb(229 231 235 / var(--tw-border-opacity));
    background-color: transparent;
    padding-left: 0px;
    padding-right: 0px;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    --tw-text-opacity: 1;
    color: rgb(59 59 59 / var(--tw-text-opacity));
}

    .form-input::-moz-placeholder {
        color: rgba(59,59,59,0.5);
    }

    .form-input::placeholder {
        color: rgba(59,59,59,0.5);
    }

    .form-input:focus {
        --tw-border-opacity: 1;
        border-bottom-color: rgb(32 63 104 / var(--tw-border-opacity));
        outline-width: 0px;
        --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
        --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);
        box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
    }

.form-control__help {
    margin-top: 0.5rem;
    text-align: right;
    font-size: 13px;
    --tw-text-opacity: 1;
    color: rgb(173 182 195 / var(--tw-text-opacity));
}

.form-select {
    margin-top: 0px;
    display: block;
    width: 100%;
    border-width: 0px;
    border-bottom-width: 2px;
    --tw-border-opacity: 1;
    border-color: rgb(229 231 235 / var(--tw-border-opacity));
    background-color: transparent;
    padding-left: 0px;
    padding-right: 0px;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    --tw-text-opacity: 1;
    color: rgb(59 59 59 / var(--tw-text-opacity));
}

    .form-select::-moz-placeholder {
        color: rgba(59,59,59,0.5);
    }

    .form-select::placeholder {
        color: rgba(59,59,59,0.5);
    }

.dashboard-controls {
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 1rem;
    padding-bottom: 0.5rem;
}

.dashboard-controls__navigation {
    margin-top: auto;
    border-bottom-width: 4px;
    --tw-border-opacity: 1;
    border-color: rgb(32 63 104 / var(--tw-border-opacity));
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    font-size: .65rem;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.dashboard-controls__buttons {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.dialog {
    position: fixed;
    top: 0px;
    right: 0px;
    bottom: 0px;
    left: 0px;
    z-index: 10;
    overflow-y: auto;
}

.dialog__inner {
    display: flex;
    min-height: 100vh;
    align-items: center;
    justify-content: center;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 1rem;
    padding-bottom: 5rem;
    text-align: center;
}

@media (min-width: 640px) {

    .dialog__inner {
        display: block;
        padding: 0px;
    }
}

.dialog__backdrop {
    position: fixed;
    top: 0px;
    right: 0px;
    bottom: 0px;
    left: 0px;
    background-color: rgb(107 114 128 / var(--tw-bg-opacity));
    --tw-bg-opacity: 0.75;
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

.dialog__shim {
    display: none;
}

@media (min-width: 640px) {

    .dialog__shim {
        display: inline-block;
        height: 100vh;
        vertical-align: middle;
    }
}

.dialog__content {
    display: inline-block;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    overflow: hidden;
    border-radius: 0.5rem;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding-left: 1rem;
    padding-right: 1rem;
    padding-bottom: 1rem;
    padding-top: 1.25rem;
    text-align: left;
    text-align: center;
    vertical-align: bottom;
    font-size: 0.875rem;
    line-height: 1.25rem;
    --tw-text-opacity: 1;
    color: rgb(107 114 128 / var(--tw-text-opacity));
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
    transition-property: all;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
}

@media (min-width: 640px) {

    .dialog__content {
        margin-bottom: 2rem;
        margin-top: 1.25rem;
        width: 100%;
        max-width: 32rem;
        padding: 1.5rem;
        vertical-align: middle;
    }
}

.dialog__actions {
    margin-top: 1.25rem;
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 0.75rem;
}

@media (min-width: 640px) {

    .dialog__actions {
        margin-top: 1.5rem;
        grid-auto-flow: row dense;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.device-card {
    margin-left: 1rem;
    margin-right: 1rem;
    margin-top: 1rem;
    margin-bottom: 1rem;
    border-radius: 0.5rem;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
}

.device-card--zones .device-card__header:last-of-type {
    border-bottom-width: 1px;
    padding-bottom: 0.75rem;
}

.device-card--zones .device-card__zone {
    border-bottom-width: 1px;
}

    .device-card--zones .device-card__zone:last-of-type {
        border-bottom-width: 0px;
    }

.device-card__zone {
    margin-left: 1rem;
    margin-right: 1rem;
    margin-top: 1rem;
    margin-bottom: 0.25rem;
    padding-bottom: 0.75rem;
}

.device-card__main-toggle {
    margin-top: -0.25rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 700;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.device-card__zone-title {
    margin-top: 0.5rem;
    margin-bottom: 0.375rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.75rem;
    line-height: 1rem;
    font-weight: 700;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.device-card--offline {
    background-color: rgba(255,255,255,0.5);
}

.device-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 0.75rem;
}

.device-card__frost {
    display: flex;
    flex-direction: column;
    font-size: .65rem;
    font-weight: 700;
    line-height: .75rem;
    --tw-text-opacity: 1;
    color: rgb(4 186 255 / var(--tw-text-opacity));
}

    .device-card__frost div {
        flex-basis: 50%;
        font-size: .65rem;
        text-transform: uppercase;
        line-height: 1rem;
    }

.device-card__title {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 18px;
    font-weight: 700;
    text-transform: uppercase;
    line-height: 22px;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.device-card__actions {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    font-size: 11px;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.device-card__schedule {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.device-card__holiday-mode {
    display: flex;
    align-items: center;
    font-size: .65rem;
    line-height: .75rem;
    --tw-text-opacity: 1;
    color: rgb(4 186 255 / var(--tw-text-opacity));
}

.device-card__offline-title {
    font-size: 1.5rem;
    line-height: 2rem;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.device-card__toggle {
    margin-top: auto;
    margin-bottom: 0.25rem;
}

.device-card__states {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.device-card__states--left,
.device-card__states--right {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1.25rem;
}

    .device-card__states--left div,
    .device-card__states--right div {
        min-width: 40px;
    }

.device-card__states--right {
    justify-content: flex-end;
}

.frame {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    padding-bottom: 1.25rem;
}

.frame__inner {
    border-radius: 0.5rem;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.footer-controls {
    margin-top: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.footer-controls__control {
    width: 100%;
    cursor: pointer;
    align-self: stretch;
    border-radius: 0.5rem;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

.footer-controls__control-inner {
    display: flex;
    height: 100%;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
}

.footer-controls__control-title {
    text-align: center;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.footer-controls__control-icon {
    height: 1.5rem;
}

.header {
    width: 100%;
}

@media (min-width: 640px) {

    .header {
        max-width: 640px;
    }
}

@media (min-width: 768px) {

    .header {
        max-width: 768px;
    }
}

@media (min-width: 1024px) {

    .header {
        max-width: 1024px;
    }
}

@media (min-width: 1280px) {

    .header {
        max-width: 1280px;
    }
}

@media (min-width: 1536px) {

    .header {
        max-width: 1536px;
    }
}

.header {
    position: sticky;
    top: 0px;
    z-index: 20;
    display: flex;
    max-width: 100%;
    align-items: center;
    justify-content: space-between;
    --tw-bg-opacity: 1;
    background-color: rgb(231 240 244 / var(--tw-bg-opacity));
    padding-left: 2rem;
    padding-right: 2rem;
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.info-tooltip {
    min-width: 250px;
    border-radius: 0.75rem;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding: 1rem;
    --tw-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.info-tooltip__title {
    margin-bottom: 0.75rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.info-tooltip__icons {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.info-tooltip__icon {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.info-tooltip__label {
    font-weight: 700;
    text-transform: uppercase;
}

.intro {
    display: flex;
    justify-content: space-between;
    padding-left: 2rem;
    padding-right: 2rem;
    padding-top: 0.5rem;
    padding-bottom: 1rem;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.intro__title {
    font-size: 1.125rem;
    line-height: 1.75rem;
}

.intro__subtitle {
    font-size: 1.875rem;
    line-height: 2.25rem;
    font-weight: 700;
}

.intro__weather {
    margin-top: 0.5rem;
    display: flex;
    text-align: right;
    font-size: 0.75rem;
    line-height: 1rem;
}

.intro__weather-icon {
    margin-bottom: 0.25rem;
    margin-left: 0.5rem;
    display: inline;
}

.intro-image {
    width: 100%;
}

.quick-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-left-width: 1px;
    border-right-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(243 243 243 / var(--tw-border-opacity));
}

.quick-controls--three {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

    .quick-controls--three .quick-controls__control:last-child {
        border-right-width: 1px;
        --tw-border-opacity: 1;
        border-right-color: rgb(243 243 243 / var(--tw-border-opacity));
    }

    .quick-controls--three .quick-controls__control:nth-child(3n) {
        border-width: 0px;
    }

.quick-controls__control {
    width: 100%;
    flex-basis: 33.333333%;
    align-self: stretch;
    border-right-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(243 243 243 / var(--tw-border-opacity));
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
}

    .quick-controls__control:last-child {
        border-width: 0px;
    }

.quick-controls__wrapper {
    margin-left: auto;
    margin-right: auto;
    display: flex;
    justify-content: space-between;
}

.quick-controls__group {
    display: flex;
}

.quick-controls__control--active {
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
    --tw-gradient-from: #F9F9FB;
    --tw-gradient-to: rgb(249 249 251 / 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.quick-controls__control_inner {
    display: flex;
    height: 100%;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.quick-controls__label {
    height: 1.5rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    --tw-text-opacity: 1;
    color: rgb(4 186 255 / var(--tw-text-opacity));
}

.quick-controls__icons {
    display: flex;
    height: 1.5rem;
    gap: 0.5rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    font-weight: 500;
    --tw-text-opacity: 1;
    color: rgb(80 80 84 / var(--tw-text-opacity));
}

    .quick-controls__icons i {
        --tw-text-opacity: 1;
        color: rgb(80 80 84 / var(--tw-text-opacity));
    }

.quick-controls__label--orange {
    --tw-text-opacity: 1;
    color: rgb(246 159 58 / var(--tw-text-opacity));
}

.quick-controls__value {
    text-align: center;
    font-size: 8px;
    text-transform: uppercase;
}

.panel {
    display: flex;
    min-height: 100vh;
    flex-direction: column;
    padding-top: 2.5rem;
}

.panel__wrapper {
    display: flex;
    height: 100%;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
}

.panel__inner {
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
}

.panel__background {
    margin-bottom: 1rem;
    width: 100%;
    border-radius: 0.5rem;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    padding-top: 2.5rem;
    padding-bottom: 1rem;
    text-align: center;
}

.panel__title {
    margin-bottom: 0.5rem;
    font-size: 1.5rem;
    text-transform: uppercase;
    line-height: 1.5rem;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.panel__subtitle {
    margin-left: 2rem;
    margin-right: 2rem;
    margin-bottom: 2rem;
    font-size: 0.875rem;
    font-weight: 700;
    line-height: 1rem;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.panel__text {
    margin-bottom: 0.75rem;
    font-size: 13px;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.panel__text--blue {
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.panel__small-print {
    margin-top: 2rem;
    text-align: center;
    font-size: 0.75rem;
    line-height: 1.5rem;
    --tw-text-opacity: 1;
    color: rgb(120 132 158 / var(--tw-text-opacity));
}

.presets {
    margin-top: 2rem;
    margin-bottom: 2.5rem;
    width: 100%;
}

.presets__items {
    display: grid;
    width: 100%;
    flex-wrap: wrap;
    place-items: center;
    row-gap: 1rem;
}

.presets__title {
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 18px;
    font-weight: 700;
    text-transform: uppercase;
    line-height: 22px;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.presets--gradient {
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
    --tw-gradient-from: #F9F9FB;
    --tw-gradient-to: rgb(249 249 251 / 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.presets__items--third {
    flex-basis: 33.333333%;
}

.presets__items--cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

.presets__items--cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.presets__items--cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.presets__items--cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.presets__items--rows-1 {
    grid-template-rows: repeat(1, minmax(0, 1fr));
}

.presets__items--rows-2 {
    grid-template-rows: repeat(2, minmax(0, 1fr));
}

.presets__items--rows-3 {
    grid-template-rows: repeat(3, minmax(0, 1fr));
}

.preset {
    display: block;
    height: 100%;
    width: 100%;
    flex-shrink: 0;
    border-left-width: 1px;
    border-right-width: 1px;
    --tw-border-opacity: 1;
    border-color: rgb(243 243 243 / var(--tw-border-opacity));
    padding-top: 2rem;
    padding-bottom: 2rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.preset--span-2 {
    grid-column: span 2 / span 2;
}

.preset--span-3 {
    grid-column: span 3 / span 3;
}

.preset--span-6 {
    grid-column: span 6 / span 6;
}

.preset--active {
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
    --tw-gradient-from: #F9F9FB;
    --tw-gradient-to: rgb(249 249 251 / 0);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.preset--double {
    grid-column: span 2 / span 2;
}

.preset__inner {
    display: flex;
    height: 100%;
    align-items: center;
    gap: 1.5rem;
}

.preset__inner--centered {
    justify-content: center;
}

.preset__inner--vertical {
    flex-direction: column;
}

.preset__inner--horizontal .preset__label {
    margin-bottom: 0px;
    padding-bottom: 0px;
}

.preset__value {
    font-size: 3.75rem;
    line-height: 1;
    --tw-text-opacity: 1;
    color: rgb(80 80 84 / var(--tw-text-opacity));
}

.preset__label {
    border-bottom-width: 5px;
    --tw-border-opacity: 1;
    border-color: rgb(255 255 255 / var(--tw-border-opacity));
    padding-bottom: 0.5rem;
    text-align: center;
    font-size: 0.875rem;
    line-height: 1.25rem;
    font-weight: 700;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.preset--active .preset__label {
    --tw-border-opacity: 1;
    border-color: rgb(32 63 104 / var(--tw-border-opacity));
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.schedule-day {
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.schedule-day__label {
    width: 3.5rem;
    text-align: center;
    font-size: 0.75rem;
    line-height: 1rem;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.schedule-day__grid {
    display: grid;
    width: 100%;
    font-size: 0.75rem;
    line-height: 1rem;
    text-transform: uppercase;
    grid-template-columns: repeat(24, minmax(0, 1fr));
}

.schedule-day__action {
    margin-left: 0.25rem;
}

.schedule-slot {
    background-color: rgba(173,182,195,0.25);
    padding-left: 0.25rem;
    padding-right: 0.25rem;
    padding-top: 0.25rem;
    padding-bottom: 0.25rem;
    text-align: center;
}

@media (min-width: 1024px) {

    .schedule-slot {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }
}

.schedule-slot--active {
    --tw-bg-opacity: 1;
    background-color: rgb(4 186 255 / var(--tw-bg-opacity));
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity));
}

.schedule-slot[data-span="1"] {
    grid-column: span 1 / span 1;
}

.schedule-slot[data-span="2"] {
    grid-column: span 2 / span 2;
}

.schedule-slot[data-span="3"] {
    grid-column: span 3 / span 3;
}

.schedule-slot[data-span="4"] {
    grid-column: span 4 / span 4;
}

.schedule-slot[data-span="5"] {
    grid-column: span 5 / span 5;
}

.schedule-slot[data-span="6"] {
    grid-column: span 6 / span 6;
}

.schedule-slot[data-span="7"] {
    grid-column: span 7 / span 7;
}

.schedule-slot[data-span="8"] {
    grid-column: span 8 / span 8;
}

.schedule-slot[data-span="9"] {
    grid-column: span 9 / span 9;
}

.schedule-slot[data-span="10"] {
    grid-column: span 10 / span 10;
}

.schedule-slot[data-span="11"] {
    grid-column: span 11 / span 11;
}

.schedule-slot[data-span="12"] {
    grid-column: span 12 / span 12;
}

.schedule-slot[data-span="13"] {
    grid-column: span 13 / span 13;
}

.schedule-slot[data-span="14"] {
    grid-column: span 14 / span 14;
}

.schedule-slot[data-span="15"] {
    grid-column: span 15 / span 15;
}

.schedule-slot[data-span="16"] {
    grid-column: span 16 / span 16;
}

.schedule-slot[data-span="17"] {
    grid-column: span 17 / span 17;
}

.schedule-slot[data-span="18"] {
    grid-column: span 18 / span 18;
}

.schedule-slot[data-span="19"] {
    grid-column: span 19 / span 19;
}

.schedule-slot[data-span="20"] {
    grid-column: span 20 / span 20;
}

.schedule-slot[data-span="21"] {
    grid-column: span 21 / span 21;
}

.schedule-slot[data-span="22"] {
    grid-column: span 22 / span 22;
}

.schedule-slot[data-span="23"] {
    grid-column: span 23 / span 23;
}

.schedule-slot[data-span="24"] {
    grid-column: span 24 / span 24;
}

.screen-controls {
    margin-top: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.screen-controls__header {
    display: flex;
    gap: 1.5rem;
}

.screen-controls__back {
    margin-top: 0.25rem;
}

.screen-controls__location {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.screen-controls__location-icon {
    margin-top: 0.25rem;
}

.screen-controls__title {
    font-size: 1.5rem;
    line-height: 2rem;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.screen-controls__subtitle {
    font-size: 0.75rem;
    line-height: 1rem;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.screen-controls__options {
    padding: 0.75rem;
}

.search-result-item {
    border-bottom-width: 1px;
    border-color: rgba(173,182,195,0.25);
}

.search-result-item__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    font-weight: 700;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.state-indicator {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    gap: 0.25rem;
    text-align: center;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.state-indicator--left {
    align-items: flex-start !important;
}

.state-indicator--bold {
    font-weight: 700;
}

.state-indicator--blue {
    --tw-text-opacity: 1;
    color: rgb(4 186 255 / var(--tw-text-opacity));
}

.state-indicator--orange {
    --tw-text-opacity: 1;
    color: rgb(246 159 58 / var(--tw-text-opacity));
}

.state-indicator__label {
    font-size: .65rem;
    font-weight: 700;
    text-transform: uppercase;
    --tw-text-opacity: 1 !important;
    color: rgb(127 126 131 / var(--tw-text-opacity)) !important;
}

.state-indicator__value {
    height: 24px;
    font-size: 24px;
    text-transform: uppercase;
    line-height: 24px;
}

.tab {
    width: 100%;
    border-bottom-width: 4px;
    --tw-border-opacity: 1;
    border-color: rgb(228 228 228 / var(--tw-border-opacity));
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    font-size: 0.875rem;
    line-height: 1.25rem;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.tab--small {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    font-size: 0.75rem;
    line-height: 1rem;
}

.tab--active {
    --tw-border-opacity: 1;
    border-color: rgb(32 63 104 / var(--tw-border-opacity));
    background-color: rgba(234,237,240,.5);
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.tab__link {
    display: flex;
    width: 100%;
    justify-content: center;
    gap: 0.75rem;
    text-transform: uppercase;
}

.toggle-switch {
}

.toggle-switch__input {
    height: 1.25rem;
    width: 2.25rem;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 9999px;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    --tw-bg-opacity: 1;
    background-color: rgb(190 189 192 / var(--tw-bg-opacity));
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: top;
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

    .toggle-switch__input:focus {
        outline: 2px solid transparent;
        outline-offset: 2px;
    }

.toggle-switch__input {
    margin-top: 0.1rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%22-4 -4 8 8%22%3E%3Ccircle r=%223%22 fill=%22%23fff%22/%3E%3C/svg%3E");
    background-position: 0;
    transition: background-position .15s ease-in-out, background-color .15s ease-in-out;
}

    .toggle-switch__input:checked {
        background-position: 100%;
        background-color: #3DDF77;
        border-color: #3DDF77;
    }

.vane-line {
    transition: fill 300ms;
    --fill: #78849E;
}

.vane-line-auto {
    --fill: #3DDF77;
}

.vane[data-position="1"] .vane-position-1 {
    fill: var(--fill)
}

.vane[data-position="2"] .vane-position-2 {
    fill: var(--fill)
}

.vane[data-position="3"] .vane-position-3 {
    fill: var(--fill)
}

.vane[data-position="4"] .vane-position-4 {
    fill: var(--fill)
}

.vane[data-position="5"] .vane-position-5 {
    fill: var(--fill)
}

.modal {
    position: absolute;
    top: 0px;
    right: 0px;
    bottom: 0px;
    left: 0px;
    z-index: 30;
    background-color: rgba(0,0,0,0.2);
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

.modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom-width: 1px;
    border-color: rgba(173,182,195,0.25);
}

.modal__inner {
    position: relative;
    margin-left: auto;
    margin-right: auto;
    margin-top: 1rem;
    margin-bottom: 1rem;
    max-height: 95vh;
    overflow-y: scroll;
    border-radius: 0.5rem;
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity));
    padding-top: 2rem;
    padding-bottom: 2rem;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
}

.modal__search-results {
    margin-top: 2rem;
    margin-bottom: 2rem;
    max-height: 50vh;
    overflow: auto;
}

.modal__inner--full {
    width: 100%;
}

.modal__inner--slim {
    top: 33.333333%;
    max-width: 320px;
    --tw-translate-y: -33.333333%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.modal__title {
    margin-bottom: 0.5rem;
    font-size: 1.5rem;
    line-height: 2rem;
    text-transform: uppercase;
    line-height: 29px;
    --tw-text-opacity: 1;
    color: rgb(32 63 104 / var(--tw-text-opacity));
}

.modal__text {
    font-size: 13px;
    line-height: 16px;
    --tw-text-opacity: 1;
    color: rgb(127 126 131 / var(--tw-text-opacity));
}

.modal__image {
    margin-left: auto;
    margin-right: auto;
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
    width: 75%;
}

.modal__footer {
    margin-top: 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}

[x-cloak] {
    display: none;
}

.grid-cols-24 {
    grid-template-columns: repeat(24, minmax(0, 1fr));
}

.grid-cols-25 {
    grid-template-columns: repeat(25, minmax(0, 1fr));
}

.scroll-item {
    height: 5rem;
    scroll-snap-align: start;
    border-bottom-width: 1px;
    --tw-border-opacity: 1;
    border-bottom-color: rgb(255 255 255 / var(--tw-border-opacity));
    padding-top: 1.75rem;
    padding-bottom: 1.75rem;
    line-height: 1.5rem;
}

    .scroll-item.scroll-item--mini {
        padding-left: 4rem;
    }

.scroll-item--blank {
    border-radius: 0px;
    border-width: 0px;
}

.scroll-item--active {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    font-size: 3rem;
    line-height: 1;
    line-height: 1.2em;
}

.scroll-item:not(.scroll-item--blank):after {
    content: "°";
}

.safe-padding {
    padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}

astro-root, astro-fragment {
    display: block !important;
    overflow: auto;
}

.odd\:border-l:nth-child(odd) {
    border-left-width: 1px;
}

.third\:border-r:nth-child(3n) {
    border-right-width: 1px;
}

@media (min-width: 640px) {

    .sm\:col-start-2 {
        grid-column-start: 2;
    }

    .sm\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .sm\:p-3 {
        padding: 0.75rem;
    }

    .sm\:px-6 {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (min-width: 768px) {

    .md\:m-3 {
        margin: 0.75rem;
    }

    .md\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) {

    .lg\:m-6 {
        margin: 1.5rem;
    }

    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .lg\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .lg\:px-8 {
        padding-left: 2rem;
        padding-right: 2rem;
    }
}

@media (min-width: 1280px) {

    .xl\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .xl\:grid-cols-5 {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }
}
