﻿﻿﻿﻿﻿:root {
    --sk-blue-blue100: #05A6FF;

    /* Surface Colors */
    --sk-color-surface-default: #FFFFFF;
    --sk-color-surface-variant: #FAFAFB;
    --sk-color-surface-inverse: #1E1F22;
    --sk-color-surface-muted: #EBEDEE;
    --sk-color-surface-accent-tint: #F2FAFF;
    --sk-color-surface-accent-tint-alt: #E6F7FF;

    /* Text Colors */
    --sk-color-text-default: #2B2E30;
    --sk-color-text-subtle: #545A5F;
    --sk-color-text-muted: #99A5AC;
    --sk-color-text-inverse: #FFFFFF;
    --sk-color-text-on-surface: #2B2E30;
    --sk-color-text-on-surface-variant: #70797E;
    --sk-color-text-on-primary-variant: #054B7C;

    /* Brand Colors */
    --sk-color-brand-default: #0588D3;
    --sk-color-brand-hover: #097AB8;
    --sk-color-brand-active: #0588D3;
    --sk-color-brand-bg: #DAF2FF;
    --sk-color-brand-on: #EBEDEE;


    /* Primary Colors */
    --sk-color-primary-default: #0588D3;
    --sk-color-primary-variant: #DAF2FF;
    --sk-color-primary-container: #097AB8;
    --sk-color-primary-on-variant: #B4E5FF;
    --sk-color-primary-on-container: #0588D3;

    /* Status Colors */
    --sk-color-success-fg: #16AD25;
    --sk-color-success-bg: #DCF3DF;
    --sk-color-success-on: #124F1A;
    --sk-color-danger-fg: #D31145;
    --sk-color-danger-bg: #FFE7E7;
    --sk-color-danger-on: #A90E37;
    --sk-color-warning-fg: #FFA930;
    --sk-color-warning-bg: #FFF7CC;
    --sk-color-warning-on: #343D71;
    --sk-color-info-fg: #379FFA;
    --sk-color-info-bg: #DAF2FF;
    --sk-color-info-on: #343D71;

    /* Notification Colors */
    --sk-color-notification-bg: #F9E8DC;
    --sk-color-notification-dot: #D31145;

    /* Focus & Outline Colors */
    --sk-color-focus-ring: #0588D3;
    --sk-color-focus-ring-alt: #81D2FF;
    --sk-color-outline-default: #EBEDEE;
    --sk-color-outline-subtle: #D6DBDE;
    --sk-color-outline-emphasis: #81D2FF;
    --sk-color-outline-variant: #D9D9D9;

    /* Typography */
    --sk-font-family-default: "Instrument Sans", system-ui, -apple-system, sans-serif;
    --sk-font-family-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --sk-font-size-body-sm: 12px;
    --sk-font-size-body-md: 14px;
    --sk-font-size-body-lg: 16px;
    --sk-font-size-label-sm: 12px;
    --sk-font-size-label-md: 14px;
    --sk-font-size-label-lg: 16px;
    --sk-font-size-h1: 48px;
    --sk-font-size-h2: 32px;
    --sk-font-size-h3: 24px;
    --sk-line-height-body: 1.5;
    --sk-line-height-heading: 1.2;
    --sk-line-height-display: 1.1;
    --sk-font-weight-regular: 400;
    --sk-font-weight-medium: 500;
    --sk-font-weight-semibold: 600;
    --sk-font-weight-bold: 700;

    /* Spacing - Numeric scale */
    --sk-space-0: 0;
    --sk-space-1: 0.25rem;
    --sk-space-2: 0.5rem;
    --sk-space-3: 0.75rem;
    --sk-space-4: 1rem;
    --sk-space-5: 1.25rem;
    --sk-space-6: 1.5rem;
    --sk-space-7: 1.75rem;
    --sk-space-8: 2rem;
    --sk-space-9: 2.5rem;
    --sk-space-10: 3rem;

    /* Spacing - Semantic scale */
    --sk-space-xxxxs: 0.25rem; /* 4px */
    --sk-space-xxxs: 0.375rem; /* 6px */
    --sk-space-xxs: 0.5rem; /* 8px */
    --sk-space-xs: 0.625rem; /* 10px */
    --sk-space-sm: 0.75rem; /* 12px */
    --sk-space-md: 1rem; /* 16px */
    --sk-space-lg: 1.25rem; /* 20px */
    --sk-space-xl: 1.5rem; /* 24px */
    --sk-space-xxl: 1.75rem; /* 28px */
    --sk-space-xxxl: 2rem; /* 32px */
    --sk-space-xxxxl: 2.25rem; /* 36px */

    /* Border Radius */
    --sk-radius-xxxs: .375rem;
    --sk-radius-xs: 2px;
    --sk-radius-sm: 4px;
    --sk-radius-md: 6px;
    --sk-radius-lg: 8px;
    --sk-radius-pill: 999px;
    --sk-radius-control: 4px;
    --sk-radius-object: 4px;
    --sk-radius-xxxxs: 4px;
    --sk-radius-interactive: var(--sk-radius-control);

    /* Elevation (box-shadow) */
    --sk-elevation-1: 0 1px 2px rgba(0, 0, 0, 0.08);
    --sk-elevation-2: 0 2px 4px rgba(0, 0, 0, 0.1);
    --sk-elevation-3: 0 4px 8px rgba(0, 0, 0, 0.12);
    --sk-elevation-dialog: 0px 2px 4px 0px rgba(0, 0, 0, 0.14), 0px 0px 2px 0px rgba(0, 0, 0, 0.12);

    /* Motion */
    --sk-motion-duration-fast: 150ms;
    --sk-motion-duration-base: 300ms;
    --sk-motion-duration-slow: 450ms;
    --sk-motion-easing-standard: cubic-bezier(.4, 0, .2, 1);
    --sk-motion-easing-emphasis: cubic-bezier(.4, 0, .3, 1);
    --sk-motion-easing-decelerate: cubic-bezier(0, 0, .2, 1);

    /* Z-Index */
    --sk-z-overlay: 10;
    --sk-z-popover: 20;
    --sk-z-modal: 30;

    /* Component Sizing Tokens */
    --sk-icon-size-sm: 14px;
    --sk-icon-size-md: 16px;
    --sk-icon-size-lg: 18px;
    --sk-button-height-sm: 28px;
    --sk-button-height-md: 32px;
    --sk-button-height-lg: 40px;

    /* Disabled State Tokens */
    --sk-opacity-disabled: 0.5;
    --sk-color-disabled-bg: var(--sk-color-surface-muted);
    --sk-color-disabled-fg: var(--sk-color-text-muted);
    --sk-color-disabled-border: var(--sk-color-outline-subtle);

    /* Button Disabled Variant Tokens */
    --sk-button-disabled-bg-default: var(--sk-color-brand-active);
    --sk-button-disabled-fg-default: var(--sk-color-text-inverse);
    --sk-button-disabled-border-default: var(--sk-color-outline-default);
    --sk-button-disabled-bg-secondary: var(--sk-color-info-bg);
    --sk-button-disabled-fg-secondary: var(--sk-color-text-on-primary-variant);
    --sk-button-disabled-border-secondary: var(--sk-color-info-bg);
    --sk-button-disabled-bg-outline: var(--sk-color-surface-default);
    --sk-button-disabled-fg-outline: var(--sk-color-text-default);
    --sk-button-disabled-border-outline: var(--sk-color-outline-default);
    --sk-button-disabled-bg-danger: var(--sk-color-danger-bg);
    --sk-button-disabled-fg-danger: var(--sk-color-danger-fg);
    --sk-button-disabled-border-danger: var(--sk-color-danger-bg);
    --sk-button-disabled-bg-warning: var(--sk-color-warning-bg);
    --sk-button-disabled-fg-warning: var(--sk-color-warning-on);
    --sk-button-disabled-border-warning: var(--sk-color-warning-bg);

    /* Spinner Tokens */
    --sk-spinner-size-sm: 14px;
    --sk-spinner-size-md: 18px;
    --sk-spinner-size-lg: 22px;
    --sk-spinner-border-width: 3px;
    --sk-spinner-speed: 0.75s;
    --sk-spinner-color-default: var(--sk-color-brand-active);
    --sk-spinner-track-default: var(--sk-color-outline-subtle);
    --sk-spinner-color-inverse: #FFFFFF;
    --sk-spinner-track-inverse: rgba(255, 255, 255, 0.35);

    /* Spinner Variant Colors */
    --sk-spinner-color-subtle: var(--sk-color-brand-active);
    --sk-spinner-track-subtle: var(--sk-color-outline-subtle);
    --sk-spinner-color-success: var(--sk-color-success-fg);
    --sk-spinner-track-success: var(--sk-color-success-bg);
    --sk-spinner-color-danger: var(--sk-color-danger-fg);
    --sk-spinner-track-danger: var(--sk-color-danger-bg);
    --sk-spinner-color-warning: var(--sk-color-warning-fg);
    --sk-spinner-track-warning: var(--sk-color-warning-bg);
    --sk-spinner-color-info: var(--sk-color-info-fg);
    --sk-spinner-track-info: var(--sk-color-info-bg);
}

.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

@font-face {
    font-family: "Instrument Sans";
    font-style: normal;
    font-stretch: 100%;
    src: url('../font/InstrumentSans-Regular.ttf') format('truetype');
}

@font-face {
    font-family: "Instrument Sans";
    font-style: italic;
    font-stretch: 100%;
    src: url('../font/InstrumentSans-Italic.ttf') format('truetype');
}

body {
    --body-font: "Instrument Sans";
    font-family: var(--body-font);
    font-size: var(--type-ramp-base-font-size);
    line-height: var(--type-ramp-base-line-height);
    margin: 0;
}

fluent-dialog[aria-label="sidekick-panel"]::part(control) {
    --design-unit: 0;
    height: 100%;
    max-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* Debug panel: prevent dialog body from scrolling; let tab content scroll instead.
   !important needed because FluentUI sets overflow-y: auto inline/internally. */
fluent-dialog[aria-label="sidekick-panel"] .fluent-dialog-body {
    display: flex;
    flex-direction: column;
    overflow: hidden !important;
    flex: 1;
    min-height: 0;
}

.main {
    color: var(--neutral-foreground-rest);
    -webkit-box-align: stretch !important;
    -ms-flex-align: stretch !important;
    align-items: stretch !important;
    overflow-x: hidden !important;
    height: 100vh;
}

.body-content {
    -ms-flex-item-align: stretch;
    align-self: stretch;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.content {
    -ms-flex-item-align: stretch !important;
    align-self: stretch !important;
    width: 100%;
    display: flex;
    flex-direction: column;
}

footer {
    display: grid;
    grid-template-columns: 10px auto auto 10px;
    background: var(--neutral-layer-4);
    color: var(--neutral-foreground-rest);
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 10px 10px;
}

    footer .link1 {
        grid-column: 2;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: start;
    }

    footer .link2 {
        grid-column: 3;
        justify-self: end;
    }

    footer a {
        color: var(--neutral-foreground-rest);
        text-decoration: none;
    }

        footer a:focus {
            outline: 1px dashed;
            outline-offset: 3px;
        }

        footer a:hover {
            text-decoration: underline;
        }

.alert {
    border: 1px dashed var(--accent-fill-rest);
    padding: 5px;
}


#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    -webkit-box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
            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;
    margin: 20px 0;
}

    #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::before {
        content: "An error has occurred. "
    }

/* Initial bootstrap loader container */
.initial-loader { display:flex; flex-direction:column; align-items:center; justify-content:center; padding-top:18vh; }
.loading-progress { width:8rem; height:8rem; display:block; }

    .loading-progress circle {
        fill: none;
        stroke: #e0e0e0;
        stroke-width: 0.6rem;
        -webkit-transform-origin: 50% 50%;
            -ms-transform-origin: 50% 50%;
                transform-origin: 50% 50%;
        -webkit-transform: rotate(-90deg);
            -ms-transform: rotate(-90deg);
                transform: rotate(-90deg);
    }

    .loading-progress circle:last-child {
            stroke: #1b6ec2;
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            -webkit-transition: stroke-dasharray 0.05s ease-in-out;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

/* Anchor highlight animation for mention navigation */
.anchor-highlight {
    animation: anchor-pulse 3s ease-in-out;
}

@keyframes anchor-pulse {
    0% {
        background-color: var(--sk-color-brand-bg, #DAF2FF);
        box-shadow: 0 0 0 3px var(--sk-color-brand-default, #0588D3);
    }
    100% {
        background-color: transparent;
        box-shadow: none;
    }
}



code {
    color: #c02d76;
}

@media (max-width: 600px) {
    .main {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        row-gap: 0 !important;
    }

    #main-menu {
        width: 250px;
    }

        #main-menu > div:first-child:is(.expander) {
            display: none;
        }
}

/* Remove focus outline from fluent-dialog header tabindex elements */
fluent-dialog div[tabindex]:focus,
fluent-dialog .fluent-dialog-header div[tabindex="0"]:focus {
    outline: none !important;
}

/* ==========================================================================
   FluentDataGrid Workarounds for FluentUI Blazor 4.12+
   
   Behavior changes introduced by resizable columns feature in v4.12.0:
   - PR #3767: https://github.com/microsoft/fluentui-blazor/pull/3767
   - PR #3760: https://github.com/microsoft/fluentui-blazor/pull/3760
   
   Workaround 1: Column headers have overflow-y: auto allowing unwanted vertical scrolling
   Workaround 2: Resize handles have visible border-right creating separator bars between columns
   ========================================================================== */

/* Workaround: Prevent vertical scrolling inside column header cells */
th.column-header {
    overflow: hidden !important;
    overflow-y: hidden !important;
}

/* Workaround: Hide the visible border on resize-handle elements */
.resize-handle {
    border-right: none !important;
    border-right-color: transparent !important;
}

/* Workaround: FluentUI sets inline width: calc(100% - 10px) on .col-title with
   justify-content: center on the parent, creating a 5px header/body misalignment.
   Override globally since Blazor scoped CSS can't reach cross-component inline styles. */
.col-title {
    width: 100% !important;
}

/*# sourceMappingURL=R:\Source\Sidekick\Client\wwwroot\css\app.css.map */