vaadin-popover-overlay::part(overlay) {
    display: compact;
}

vaadin-grid.route-edit {
    /*--vaadin-grid-cell-padding: 0;*/
}
vaadin-combo-box.special {
    --vaadin-input-field-placeholder-color: var(--lumo-body-text-color);
    --vaadin-input-field-border-width: 0;
}

vaadin-text-field.suggest {
    --vaadin-input-field-disabled-value-color: var(--lumo-body-text-color);
    --vaadin-input-field-color: red;
}

vaadin-combo-box.special::part(toggle-button) {
    visibility: hidden;
    display: none;

}


.device-form {
    height: 100%;
    overflow: auto;
    flex-shrink: 0;
    box-shadow: var(--overlay-box-shadow);
}

.category__edit {
    margin: 0 0 0 auto;
}

.view-toolbar {
    display: flex;
    background-color: var(--lumo-base-color);
    box-shadow: 0 1px 0 0 var(--lumo-contrast-10pct);
    margin: 0 calc(-50vw + 50%);
    padding: 8px calc(50vw - 50% + 16px);
    position: relative;
    z-index: 1;
    flex: none;
}

.view-toolbar__search-field {
    flex: auto;
    min-width: 0;
    margin-right: 16px;
}

html {
    /*background-color: var(--lumo-contrast-5pct);*/
}

body {
    /*background-color: var(--lumo-contrast-5pct);*/
}

.main-layout {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    min-height: 100vh;
    max-width: 100%;
    margin: 0 auto;
}

.main-layout__title {
    font-size: 1em;
    margin: 0;
    /* Allow the nav-items to take all the space so they are centered */
    width: 0;
    line-height: 1;
    letter-spacing: -0.02em;
    font-weight: 500;
}

.main-layout > * {
    flex: auto;
}

.main-layout__header {
    display: flex;
    flex: none;
    align-items: center;
    height: var(--main-layout-header-height);

    /* Stretch to fill the entire browser viewport, while keeping the content constrained to
       parent element max-width */
    margin: 0 calc(-50vw + 50%);
    padding: 16px calc(50vw - 50% + 16px);

    background-color: var(--lumo-base-color);
    box-shadow: 0 1px 0 0 var(--lumo-contrast-5pct);
}

.main-layout__nav {
    display: flex;
    flex: 1;
    justify-content: center;
}

.main-layout__nav-item {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    padding: 4px 8px;
    cursor: pointer;
    transition: 0.3s color, 0.3s transform;
    will-change: transform;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    font-size: var(--lumo-font-size-s);
    color: var(--lumo-secondary-text-color);
    font-weight: 500;
    line-height: 1.3;
}

.main-layout__nav-item:hover {
    text-decoration: none;
}

.main-layout__nav-item:not([highlight]):hover {
    color: inherit;
}

.main-layout__nav-item[highlight] {
    color: var(--lumo-primary-text-color);
    cursor: default;
}

.main-layout__nav-item iron-icon {
    /* Vaadin icons are using a 16x16 grid */
    padding: 4px;
    box-sizing: border-box;
    pointer-events: none;
}


#outlet {
    overflow: auto;
}

/*.components-view2 {*/
/*    padding: var(--lumo-space-l);*/
/*}*/

.components-view .card {
    padding: var(--lumo-space-l);
    border-radius: var(--lumo-border-radius-l);
    background: radial-gradient(circle at 25% 0%, hsl(0 0% 100% / 0.9), transparent 50%), hsl(0 0% 98% / 0.7);
    background-origin: border-box;
    box-shadow: inset 0 0 0 1px hsl(0 0% 100% / 0.06), 0 0 0 1px hsl(0 0% 0% / 0.06);
}

.components-view vaadin-date-time-picker vaadin-date-picker {
    --vaadin-field-default-width: 10em;
}

.components-view vaadin-date-time-picker vaadin-time-picker {
    --vaadin-field-default-width: 6em;
}

.components-view vaadin-select.state-select {
    padding: 0;
}

/* dark theme */
[theme~=dark] .components-view .card {
    background: radial-gradient(circle at 25% 0%, hsl(0 0% 100% / 0.1), transparent 50%), hsl(var(--primary-h) calc(var(--primary-s) / 5) 20% / 0.5);
    background-origin: border-box;
}

@media screen and (max-width: 1200px) {
    .components-view .view-content {
        flex-wrap: wrap;
    }
}