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

* {
    box-sizing: border-box;
}
:root {
    --global-size: 16px;
}

html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    margin: 0;
    height: 100%;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    font-size: var(--global-size);
}

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

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

.button-link {
    text-decoration: unset;
}

#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;
    }

.title {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding-bottom: 0.625rem;
}

    .title.title-secondary {
        padding-top: 0.313rem;
        padding-bottom: 0;
        color: var(--bs-secondary-color, var(--dxds-color-content-neutral-default-rest));
    }

.title-header-text {
    font-size: 2.5rem;
    line-height: 3rem;
    font-weight: 600;
    letter-spacing: 0rem;
    padding: 0.3125rem 0;
}

.title-content-text {
    font-size: 1.75rem;
    font-weight: 400;
    line-height: 2.5rem;
    letter-spacing: 0rem;
}

.main-content {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 100%;
}

.block-content {
    width: 31.25rem;
    height: auto;
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    max-width: 100%;
}

.icon {
    width: var(--icon-width, 1rem);
    height: var(--icon-height, 1rem);
    background-color: currentcolor;
    mask-position: center center;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-image: var(--icon-mask-image);
    mask-image: var(--icon-mask-image);
    mask-size: cover;
}
/* Theme-aware bootstrap form controls (works across DevExpress themes) */
.form-control,
.form-select,
.form-check-input,
.input-group-text {
    background-color: var(--dxds-color-surface-neutral-default-rest, var(--bs-body-bg, #fff));
    color: var(--dxds-color-content-neutral-default-rest, var(--bs-body-color, #212529));
    border-color: var(--dxds-color-border-neutral-default-rest, var(--bs-border-color, #dee2e6));
}

.form-control::placeholder {
    color: var(--dxds-color-content-neutral-default-rest, var(--bs-secondary-color, #6c757d));
    opacity: 0.7;
}

.form-select:focus,
.form-control:focus,
.form-check-input:focus {
    box-shadow: 0 0 0 0.15rem rgba(13, 110, 253, 0.25);
    border-color: var(--bs-primary, #0d6efd);
}

/* Custom facility dropdown (Portionen) */
.facility-select-button {
    background-color: var(--dxds-color-surface-neutral-default-rest, var(--bs-body-bg, #fff));
    color: var(--dxds-color-content-neutral-default-rest, var(--bs-body-color, #212529));
    border-color: var(--dxds-color-border-neutral-default-rest, var(--bs-border-color, #dee2e6));
}

.facility-select-panel {
    background-color: var(--dxds-color-surface-neutral-default-rest, var(--bs-body-bg, #fff));
    border: 1px solid var(--dxds-color-border-neutral-default-rest, var(--bs-border-color, #dee2e6));
    border-radius: 0.5rem;
    box-shadow: 0 .5rem 1rem rgba(0, 0, 0, 0.15);
}

.facility-select-search {
    background-color: var(--dxds-color-surface-neutral-default-rest, var(--bs-body-bg, #fff));
    color: var(--dxds-color-content-neutral-default-rest, var(--bs-body-color, #212529));
    border-color: var(--dxds-color-border-neutral-default-rest, var(--bs-border-color, #dee2e6));
}

.facility-select-item {
    padding: 0.375rem 0.75rem;
    color: var(--dxds-color-content-neutral-default-rest, var(--bs-body-color, #212529));
}

.facility-select-item:hover {
    background-color: var(--dxds-color-surface-neutral-default-hovered, var(--bs-tertiary-bg, #f1f3f5));
}

.facility-select-empty {
    padding: 0.5rem 0.75rem;
    color: var(--bs-secondary-color, #6c757d);
}



/* Ensure icon mask variables are set globally (drawer/menu may render outside scoped CSS). */
.icon-back { --icon-mask-image: var(--icon-back-mask-image); }
.icon-close { --icon-mask-image: var(--icon-close-mask-image); }
.icon-menu { --icon-mask-image: var(--icon-menu-mask-image); }
.icon-logout { --icon-mask-image: var(--icon-logout-mask-image); }
.icon-login { --icon-mask-image: var(--icon-login-mask-image); }
.icon-dashboard { --icon-mask-image: var(--icon-dashboard-mask-image); }
.icon-portionen { --icon-mask-image: var(--icon-portionen-mask-image); }
.icon-teilnehmer { --icon-mask-image: var(--icon-teilnehmer-mask-image); }
.icon-abrechnung { --icon-mask-image: var(--icon-abrechnung-mask-image); }
.icon-nachrichten { --icon-mask-image: var(--icon-nachrichten-mask-image); }
.icon-hilfe { --icon-mask-image: var(--icon-hilfe-mask-image); }
.icon-traffic { --icon-mask-image: var(--icon-traffic-mask-image); }
.icon-benutzer { --icon-mask-image: var(--icon-benutzer-mask-image); }

/* Bootstrap Icons sizing in menus */
.dxbl-menu .bi,
.dxbl-menu-item-icon .bi {
    font-size: 1rem;
    line-height: 1;
    display: inline-block;
}

.dashboard-grid-wrap {
    overflow-y: auto;
    max-height: calc(100vh - 320px);
}

@media (max-width: 768px) {
    .dxbl-grid .col-hide-sm {
        display: none !important;
    }
}

