/* ============================================================
   SPC Design Tokens — single source of truth for brand colors,
   typography, and shape. All components reference these vars.
   ============================================================ */
:root {
    /* Typography */
    --spc-font: 'Manrope', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;

    /* Brand accent: sky-blue — used in kiosk header, PIN dots, highlights */
    --spc-accent: #f59e0b;
    --spc-accent-dark: #d97706;
    --spc-accent-light: rgba(245, 158, 11, 0.25);

    /* Dark surface palette — kiosk, dialog headers, nav overlays */
    --spc-bg-900: #0d1117;
    --spc-bg-800: #161b22;
    --spc-bg-700: #1f2937;
    --spc-bg-600: #21262d;

    /* Text */
    --spc-text-white: #f0f6ff;
    --spc-text-muted: #8b949e;
    /* timestamps, subtitles */
    --spc-text-label: #8b949e;
    /* column headers */
    --spc-text-body: #c9d1d9;
    /* primary body text   */

    /* Status */
    --spc-success: #4caf50;
    --spc-success-dim: rgba(76, 175, 80, 0.1);

    /* Shape */
    --spc-radius-card: 16px;
    --spc-radius-btn: 8px;
}

/* Apply Manrope globally */
body {
    font-family: var(--spc-font);
}

/* Standard Blazor WASM error/loading UI */

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

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiPjxwYXRoIGQ9Ik0xMy4yNTkgMTYuNzUyTDEzLjI1OSAzMi4yNDhDMTMuMjU5IDMyLjk5NiAxMy41NzQgMzMuNzA0IDE0LjExNiAzNC4yMTlMMjYuNjE2IDQ2LjIxOUMyNy4xOTIgNDYuNzY0IDI3Ljk5IDQ3IDI4LjgxMyA0N0w0Mi41NzkgNDdDNDMuNDAyIDQ3IDQ0LjEyNiA0Ni43MTQgNDQuNjY4IDQ2LjE3OUw1NC41MzEgMzYuNzMxQzU1LjA3MyAzNi4xOTYgNTUuMzMzIDM1LjQ0OCA1NS4zMzMgMzQuNjJMNTUuMzMzIDIwLjM5OUM1NS4zMzMgMTkuNTcxIDU1LjA3MyAxOC44NjMgNTQuNTMxIDE4LjI4OEw0NC42NjggOC44MkM0NC4xMjYgOC4yNzUgNDMuNDAyIDggNDIuNTc5IDhMMjguODEzIDhDMjcuOTkgOCAyNy4xOTIgOC4yNzUgMjYuNjE2IDguODJMMTQuMTE2IDIwLjgyQzEzLjU3NCAyMS4zNTUgMTMuMjU5IDIyLjA2MyAxMy4yNTkgMjIuODExWiIgZmlsbD0iI0ZGNjY2NiIgZmlsbC1vcGFjaXR5PSIxIi8+PHBhdGggZD0iTTM1LjUgMjhMMzUuNSAyMCIgc3Ryb2tlPSJ3aGl0ZSIgc3Ryb2tlLXdpZHRoPSIzIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48cGF0aCBkPSJNMzUuNSAzNEwzNS41IDMyIiBzdHJva2U9IndoaXRlIiBzdHJva2Utd2lkdGg9IjMiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 20vh auto 1rem auto;
}

.loading-progress circle {
    fill: none;
    stroke: #e0e0e0;
    stroke-width: 0.6rem;
    transform-origin: 50% 50%;
    transform: rotate(-90deg);
}

.loading-progress circle:last-child {
    stroke: #1976d2;
    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: bold;
    inset: calc(20vh + 3.25rem) 0 auto 0.2rem;
}

.loading-progress-text:after {
    content: var(--blazor-load-percentage-text, "Loading");
}