@import '_content/Microsoft.FluentUI.AspNetCore.Components/css/reboot.css';

/* Base body styles - optimized for Fluent UI theming */
body {
    margin: 0;
    padding: 0;
    height: 100vh;
    font-family: var(--body-font);
    font-size: var(--type-ramp-base-font-size);
    line-height: var(--type-ramp-base-line-height);
    font-weight: var(--font-weight);
    color: var(--neutral-foreground-rest);
    background: var(--neutral-fill-layer-rest);
    transition: color 0.3s ease, background-color 0.3s ease;
}

/* Theme responsive styles */
.theme-container {
    background: var(--neutral-fill-layer-rest);
    color: var(--neutral-foreground-rest);
    min-height: 100vh;
}

/* AppBar theme enhancements */
.fluent-appbar {
 background: var(--neutral-layer-2) !important;
    border-bottom: 1px solid var(--neutral-stroke-divider-rest);
}

.navmenu-icon {
    display: none;
}

.main {
    min-height: calc(100dvh - 86px);
    color: var(--neutral-foreground-rest);
    align-items: stretch !important;
    background: var(--neutral-fill-layer-rest);
}

.body-content {
    align-self: stretch;
    height: calc(100dvh - 86px) !important;
    display: flex;
    background: var(--neutral-fill-layer-rest);
}

.content {
padding: 0.5rem 1.5rem;
    align-self: stretch !important;
    width: 100%;
    background: var(--neutral-fill-layer-rest);
}

.manage {
    width: 100dvw;
}

/* Footer with theme support */
footer {
    background: var(--neutral-layer-4);
    color: var(--neutral-foreground-rest);
    align-items: center;
    padding: 10px 10px;
    border-top: 1px solid var(--neutral-stroke-divider-rest);
}

    footer a {
        color: var(--accent-foreground-rest);
        text-decoration: none;
        transition: color 0.2s ease;
    }

        footer a:focus {
   outline: 1px dashed var(--focus-stroke-outer);
          outline-offset: 3px;
        }

   footer a:hover {
   text-decoration: underline;
          color: var(--accent-foreground-hover);
        }

/* Theme-aware alert styles */
.alert {
    border: 1px dashed var(--accent-fill-rest);
    padding: 5px;
    background: var(--neutral-fill-subtle-rest);
    color: var(--neutral-foreground-rest);
}

/* Enhanced error UI with theme support */
#blazor-error-ui {
    background: var(--error-fill-rest, #ffffe0);
    color: var(--error-foreground-rest, #8b0000);
    bottom: 0;
    box-shadow: 0 -1px 2px var(--elevation-shadow);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
    margin: 20px 0;
    border: 1px solid var(--error-stroke-rest, #ff6b6b);
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
position: absolute;
        right: 0.75rem;
        top: 0.5rem;
        color: var(--error-foreground-rest, #8b0000);
    }

/* Theme-aware error boundary */
.blazor-error-boundary {
    background: linear-gradient(135deg, var(--error-fill-rest), var(--error-fill-hover)) no-repeat 1rem/1.8rem,
     var(--error-fill-rest);
    padding: 1rem 1rem 1rem 3.7rem;
    color: var(--error-foreground-rest);
    border: 1px solid var(--error-stroke-rest);
    border-radius: var(--control-corner-radius);
}

    .blazor-error-boundary::before {
        content: "An error has occurred. ";
        font-weight: var(--font-weight-semibold);
}

/* Loading progress with theme support */
.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 20vh auto 1rem auto;
}

    .loading-progress circle {
        fill: none;
        stroke: var(--neutral-stroke-accessible-rest);
        stroke-width: 0.6rem;
 transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

        .loading-progress circle:last-child {
  stroke: var(--accent-fill-rest);
            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: var(--font-weight-semibold);
    color: var(--neutral-foreground-rest);
    inset: calc(20vh + 3.25rem) 0 auto 0.2rem;
}

    .loading-progress-text:after {
      content: var(--blazor-load-percentage-text, "Loading");
    }

/* Code styling with theme support */
code {
    color: var(--accent-foreground-rest);
    background: var(--neutral-fill-subtle-rest);
    padding: 0.2rem 0.4rem;
 border-radius: var(--control-corner-radius);
    font-family: var(--font-monospace);
}

/* Theme selector styles in AppBar */
.theme-controls {
    margin-left: auto;
    display: flex;
    gap: 10px;
    align-items: center;
}



/* Dark mode specific adjustments */
@media (prefers-color-scheme: dark) {
    body {
        scrollbar-color: var(--neutral-fill-rest) var(--neutral-fill-layer-rest);
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .alert {
        border-width: 2px;
    }
  
    #blazor-error-ui {
        border-width: 2px;
    }
}
