html, body {
    font-family: 'Roboto', sans-serif;
}

#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,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI5MC4xODEgNzUuODQzMkMyOTEuOTcxIDc3LjYzMzIgMjkxLjk3MSA4MC40Njc4IDI5MC4xODEgODIuMjU3OEwyNjYuNjA2IDEwNS44telesMzNDMjY1LjgxMyAxMDYuNTE2IDI2NC43MTcgMTA3IDI2My41MDYgMTA3TDIzNS4wMzEgMTA3QzIzMy42MjYgMTA3IDIzMi41MjkgMTA2LjUxNiAyMzEuNzM3IDEwNS44MzNMMjA4LjE2MiA4Mi4yNTc4QzIwNi4zNzIgODAuNDY3OCAyMDYuMzcyIDc3LjYzMzIgMjA4LjE2MiA3NS44NDMyzIyMzEuNzM3IDUyLjI2NThDMjMyLjUyOSA1MS40ODM3IDIzMy42MjYgNTEgMjM1LjAzMSA1MUwyNjMuNTA2IDUxWiIgZmlsbD0iI0ZGRTAyMiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PHBhdGggZD0iTTI2My41ODcgNTkuMTg3NUMyNjAuMDE2IDU5LjE4NzUgMjU3LjEyIDYyLjA4MzMgMjU3LjEyIDY1LjY1NDJDMjU3LjEyIDY5LjIyNSAyNjAuMDE2IDcyLjEyMDggMjYzLjU4NyA3Mi4xMjA4QzI2Ny4xNTggNzIuMTIwOCAyNzAuMDU0IDY5LjIyNSAyNzAuMDU0IDY1LjY1NDJDMjcwLjA1NCA2Mi4wODMzIDI2Ny4xNTggNTkuMTg3NSAyNjMuNTg3IDU5LjE4NzVaTTI2My41ODcgNDYuODc1QzI1My4wODcgNDYuODc1IDI0NC41IDU1LjQ2MTMgMjQ0LjUgNjUuOTYxM0MyNDQuNSA3Ni40NjEzIDI1My4wODcgODUuMDQ3OSAyNjMuNTg3IDg1LjA0NzlDMjc0LjA4NyA4NS4wNDc5IDI4Mi42NzMgNzYuNDYxMyAyODIuNjczIDY1Ljk2MTNDMjgyLjY3MyA1NS40NjEzIDI3NC4wODcgNDYuODc1IDI2My41ODcgNDYuODc1WiIgZmlsbD0iIzEyMTIxMiIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred."
}

/* Loading spinner */
.spinner-border {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    vertical-align: -0.125em;
    border: 0.25em solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: .75s linear infinite spinner-border;
}

@keyframes spinner-border {
    to {
        transform: rotate(360deg);
    }
}

.text-primary {
    color: #1976d2 !important;
}

/* ===== PDF Export Styles ===== */

/* Export header - hidden on screen, visible during PDF capture */
.export-header {
    display: none;
}

#report-export-content .export-header {
    display: none;
}

/* When html2pdf captures the element, it clones the DOM. 
   We use a class toggled by JS to show the header during export. */
.exporting .export-header {
    display: block !important;
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid #1976d2;
}

.export-header h2 {
    font-size: 1.25rem;
    font-weight: 500;
    color: #1976d2;
    margin: 0 0 0.25rem 0;
}

.export-header p {
    font-size: 0.85rem;
    color: #666;
    margin: 0;
}

.export-header .export-date {
    font-size: 0.75rem;
    color: #999;
    margin-top: 0.25rem;
}

/* Ensure cards and charts render cleanly in PDF */
#report-export-content .mud-paper {
    break-inside: avoid;
}

#report-export-content .mud-grid-item {
    break-inside: avoid;
}

/* During PDF capture, ensure overflow is visible so nothing gets clipped
   before html2canvas can capture it. */
#report-export-content.exporting {
    overflow: visible !important;
}

/* Warehouse Map - Permanent label styling */
.map-label {
    background: rgba(255, 255, 255, 0.9) !important;
    border: 1px solid #ccc !important;
    border-radius: 3px !important;
    padding: 2px 6px !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2) !important;
}

.map-label-council {
    font-weight: 700 !important;
    border-color: #1976D2 !important;
}

.map-label-warehouse {
    font-weight: 600 !important;
    border-color: #388E3C !important;
}
