.mud-menu-list {
    border: 1px solid hsl(120 15% 88%);
    background: hsl(0 0% 100%);
    box-shadow: var(--s24-dash-shadow-lg);
    border-radius: 0.75rem;
}
.mud-snackbar {
    box-shadow: var(--s24-dash-shadow-lg) !important;
    border-radius: 0.75rem !important;
    background-color: white !important;
}
.h1 {
    box-sizing: unset !important;
}
*:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}
.mud-alert-filled-success {
    background-color: var(--s24-search-success) !important;
    color: white !important;
}
.mud-dialog {
    z-index: 1201 !important;
    background: white !important;
    box-shadow: var(--s24-dash-shadow-lg) !important;
    border-radius: 0.75rem !important;
    max-height: 80vh !important;
    margin-left: 15px;
    margin-right: 15px;
}
.mud-overlay {
    background: rgba(255, 255, 255, 0.4); /* weiß & transparent */
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px); /* Safari */
    border-radius: 12px;
    padding: 20px;
    border: 1px solid rgba(255, 255, 255, 0.6);
    /*position: absolute !important;*/
    /*z-index: 999 !important;*/
}
.mud-dialog-title {
    display: none !important;
}
.leaflet-container {
    border-radius: 13px !important;
    z-index: 0 !important;
}
/* ===== UnserMarkt Reconnect UI ===== */

/* Blazor nutzt diese Klassen am Modal:
   components-reconnect-hide / -show / -rejected / -failed
   (je nach .NET Version können ein paar davon variieren)
*/
#components-reconnect-modal.um-reconnect {
    position: fixed;
    inset: 0;
    z-index: 2147483647;
    display: grid;
    place-items: center;
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Hide by default (Blazor toggles class) */
#components-reconnect-modal.components-reconnect-hide {
    display: none !important;
}

.um-reconnect__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(10, 14, 12, 0.38);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.um-reconnect__card {
    position: relative;
    width: min(520px, calc(100vw - 32px));
    border-radius: 18px;
    padding: 18px 18px 14px;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 22px 70px rgba(0,0,0,.25);
    border: 1px solid rgba(16, 185, 129, 0.22);
    transform: translateY(8px);
    animation: um-pop 180ms ease-out forwards;
}

@keyframes um-pop {
    to { transform: translateY(0); }
}

.um-reconnect__header {
    display: grid;
    grid-template-columns: 44px 1fr 24px;
    gap: 12px;
    align-items: center;
}

.um-reconnect__icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: rgba(16, 185, 129, 0.12);
    color: rgb(16, 185, 129);
}

.um-reconnect__icon svg {
    width: 26px;
    height: 26px;
}

.um-reconnect__title {
    font-weight: 750;
    letter-spacing: -0.02em;
    font-size: 18px;
    color: #0b1410;
    margin-bottom: 2px;
}

.um-reconnect__subtitle {
    font-size: 13px;
    color: rgba(11, 20, 16, 0.68);
    line-height: 1.35;
}

.um-reconnect__spinner {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    border: 2px solid rgba(0,0,0,.12);
    border-top-color: rgba(16, 185, 129, 0.95);
    animation: um-spin 700ms linear infinite;
}

@keyframes um-spin {
    to { transform: rotate(360deg); }
}

.um-reconnect__progress {
    margin-top: 14px;
    height: 10px;
    border-radius: 999px;
    background: rgba(0,0,0,.06);
    overflow: hidden;
}

.um-reconnect__bar {
    height: 100%;
    width: 45%;
    border-radius: 999px;
    background: linear-gradient(90deg,
    rgba(16,185,129,0.25),
    rgba(16,185,129,0.95),
    rgba(16,185,129,0.25)
    );
    animation: um-sweep 1.2s ease-in-out infinite;
}

@keyframes um-sweep {
    0%   { transform: translateX(-120%); }
    100% { transform: translateX(260%); }
}

.um-reconnect__actions {
    display: flex;
    gap: 10px;
    margin-top: 14px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.um-reconnect__btn {
    border: 0;
    cursor: pointer;
    border-radius: 12px;
    padding: 10px 12px;
    font-weight: 650;
    font-size: 13px;
    transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease, color 120ms ease;
    user-select: none;
}

.um-reconnect__btn:active {
    transform: translateY(1px);
}

.um-reconnect__btn--primary {
    background: rgb(16, 185, 129);
    color: #062014;
    box-shadow: 0 10px 25px rgba(16,185,129,.25);
}

.um-reconnect__btn--primary:hover {
    box-shadow: 0 14px 32px rgba(16,185,129,.32);
}

.um-reconnect__btn--ghost {
    background: rgba(0,0,0,.05);
    color: rgba(11, 20, 16, 0.75);
}

.um-reconnect__btn--ghost:hover {
    background: rgba(0,0,0,.075);
}

.um-reconnect__hint {
    margin-top: 10px;
    font-size: 12px;
    color: rgba(11, 20, 16, 0.6);
}

/* Status-spezifisch (optional) */
#components-reconnect-modal.components-reconnect-rejected .um-reconnect__title {
    color: #7a2d2d;
}
#components-reconnect-modal.components-reconnect-failed .um-reconnect__title {
    color: #7a2d2d;
}
#components-reconnect-modal.components-reconnect-rejected .um-reconnect__spinner,
#components-reconnect-modal.components-reconnect-failed .um-reconnect__spinner {
    display: none;
}
#components-reconnect-modal.components-reconnect-rejected .um-reconnect__bar,
#components-reconnect-modal.components-reconnect-failed .um-reconnect__bar {
    animation: none;
    width: 100%;
    background: rgba(185, 16, 16, 0.22);
}

/* Optional: das "graue" Default Error UI komplett kontrollieren */
#blazor-error-ui.um-blazor-error {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 12px;
    box-shadow: 0 16px 46px rgba(0,0,0,.22);
    bottom: 16px;
    left: 16px;
    right: 16px;
    padding: 10px 12px;
    position: fixed;
    display: none; /* standardmäßig aus */
    z-index: 2147483647;
}
#blazor-error-ui.um-blazor-error .dismiss {
    float: right;
    cursor: pointer;
    text-decoration: none;
    padding: 0 6px;
}
#blazor-error-ui.um-blazor-error .reload {
    margin-left: 10px;
    font-weight: 650;
}
.mud-dialog-container {
    /*position: absolute !important;*/
    position: fixed !important;
    z-index: 999 !important;
    inset: 0;
}