/* /Components/Layout/MainLayout.razor.rz.scp.css */
/* ══════════════════════════════════════════════════════════════
   MainLayout.razor.css
   Blazor CSS isolation — these rules are scoped to MainLayout
   automatically by the build pipeline.
   Sidebar width constants must match Sidebar.razor:
     closed  →  66px   (--sb-w-closed)
     open    →  230px  (--sb-w-open)
     timing  →  0.26s cubic-bezier(.4,0,.2,1)
   ══════════════════════════════════════════════════════════════ */

/* ══ Shell ══ */
.ml-shell[b-7xj0fltxfc] {
    display: flex;
    min-height: 100vh;
    background: #f1f5f9;
    font-family: system-ui, -apple-system, sans-serif;
}

/* ══ Main area — offset for the fixed sidebar ══ */
.ml-main[b-7xj0fltxfc] {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    margin-left: 66px; /* sidebar closed width */
    transition: margin-left 0.26s cubic-bezier(.4,0,.2,1);
    overflow-x: hidden;
}

/* Sidebar is pinned/hovered open */
.ml-main-expanded[b-7xj0fltxfc] {
    margin-left: 230px; /* sidebar open width */
}

/* ══ Topbar ══ */
.ml-topbar[b-7xj0fltxfc] {
    position: sticky;
    top: 0;
    z-index: 450;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    gap: 12px;
    flex-shrink: 0;
    /* Same dark gradient as sidebar header — creates a unified chrome */
    background: linear-gradient(90deg, #0a1628 0%, #0d2344 55%, #1a3a6b 100%);
    border-bottom: 1px solid rgba(255,255,255,.07);
    box-shadow: 0 1px 12px rgba(0,0,0,.25);
}

.ml-topbar-left[b-7xj0fltxfc] {
    display: flex;
    align-items: center;
    gap: 14px;
}

.ml-topbar-right[b-7xj0fltxfc] {
    display: flex;
    align-items: center;
    gap: 6px;
}

/* ══ Mobile hamburger ══ */
.ml-hamburger[b-7xj0fltxfc] {
    display: none; /* hidden on desktop */
    width: 34px;
    height: 34px;
    border-radius: 9px;
    border: 1px solid rgba(255,255,255,.15);
    background: rgba(255,255,255,.07);
    color: rgba(255,255,255,.75);
    cursor: pointer;
    align-items: center;
    justify-content: center;
    transition: background .15s, color .15s;
    flex-shrink: 0;
}

    .ml-hamburger:hover[b-7xj0fltxfc] {
        background: rgba(255,255,255,.14);
        color: #fff;
    }

/* ══ Company name ══ */
.ml-company[b-7xj0fltxfc] {
    display: flex;
    align-items: center;
    gap: 8px;
}

.ml-company-dot[b-7xj0fltxfc] {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #3b82f6;
    box-shadow: 0 0 8px rgba(59,130,246,.6);
    animation: mlPulse-b-7xj0fltxfc 2.4s ease infinite;
    flex-shrink: 0;
}

@keyframes mlPulse-b-7xj0fltxfc {
    0%, 100% {
        box-shadow: 0 0 6px rgba(59,130,246,.6);
    }

    50% {
        box-shadow: 0 0 14px rgba(59,130,246,.9);
    }
}

.ml-company-name[b-7xj0fltxfc] {
    display: inline-block;
    font-size: .9375rem;
    font-weight: 800;
    color: #ffffff;
    letter-spacing: -.01em;
    white-space: nowrap;
}

/* ══ Icon buttons (bell, settings) ══ */
.ml-icon-btn[b-7xj0fltxfc] {
    position: relative;
    width: 34px;
    height: 34px;
    border-radius: 9px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.65);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: background .15s, color .15s, border-color .15s;
    flex-shrink: 0;
}

    .ml-icon-btn:hover[b-7xj0fltxfc] {
        background: rgba(255,255,255,.13);
        color: #fff;
        border-color: rgba(255,255,255,.20);
    }

/* Notification indicator */
.ml-notif-dot[b-7xj0fltxfc] {
    position: absolute;
    top: 7px;
    right: 7px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #f97316;
    border: 1.5px solid #0d2344;
    pointer-events: none;
}

/* Vertical separator */
.ml-sep[b-7xj0fltxfc] {
    width: 1px;
    height: 22px;
    background: rgba(255,255,255,.10);
    margin: 0 4px;
    flex-shrink: 0;
}

/* ══ User button ══ */
.ml-user-wrap[b-7xj0fltxfc] {
    position: relative;
}

.ml-user-btn[b-7xj0fltxfc] {
    display: flex;
    align-items: center;
    gap: 9px;
    height: 36px;
    padding: 0 10px 0 5px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.07);
    color: rgba(255,255,255,.85);
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
    transition: background .15s, border-color .15s;
}

    .ml-user-btn:hover[b-7xj0fltxfc],
    .ml-user-btn-open[b-7xj0fltxfc] {
        background: rgba(255,255,255,.13);
        border-color: rgba(255,255,255,.22);
    }

/* Avatar */
.ml-avatar[b-7xj0fltxfc] {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    flex-shrink: 0;
    background: linear-gradient(135deg, #1e3a6e 0%, #2563b0 100%);
    border: 1.5px solid rgba(59,130,246,.50);
    color: #b6c0d1;
    font-size: .72rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 10px rgba(59,130,246,.20);
}

/* Name + email stack */
.ml-user-meta[b-7xj0fltxfc] {
    display: flex;
    flex-direction: column;
    gap: 0;
    line-height: 1.2;
}

.ml-user-name[b-7xj0fltxfc] {
    font-size: .8rem;
    font-weight: 700;
    color: #fff;
}

.ml-user-email[b-7xj0fltxfc] {
    font-size: .67rem;
    color: rgba(255,255,255,.45);
    max-width: 130px;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Animated chevron */
.ml-chevron[b-7xj0fltxfc] {
    color: rgba(255,255,255,.40);
    transition: transform 0.2s cubic-bezier(.4,0,.2,1), color .15s;
    flex-shrink: 0;
}

.ml-chevron-open[b-7xj0fltxfc] {
    transform: rotate(180deg);
    color: rgba(255,255,255,.70);
}

/* ══ Dropdown ══ */
.ml-dropdown[b-7xj0fltxfc] {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 222px;
    background: #0f264d;
    border: 1px solid #2c2c2e;
    border-radius: 14px;
    box-shadow: 0 16px 40px rgba(0,0,0,.16), 0 0 0 1px rgba(0,0,0,.04);
    overflow: hidden;
    z-index: 500;
    animation: mlDdIn-b-7xj0fltxfc .18s cubic-bezier(.34,1.4,.64,1) both;
}

@keyframes mlDdIn-b-7xj0fltxfc {
    from {
        opacity: 0;
        transform: translateY(-6px) scale(.97);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* Dropdown header block */
.ml-dd-header[b-7xj0fltxfc] {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 16px 12px;
    background: #0f264d;
    border-bottom: 1px solid #f1f5f9;
}

.ml-dd-avatar[b-7xj0fltxfc] {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    flex-shrink: 0;
    background: linear-gradient(135deg, #1e3a6e 0%, #2563b0 100%);
    border: 1.5px solid rgba(37,99,176,.3);
    color: #b6c0d1;
    font-size: .8rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ml-dd-name[b-7xj0fltxfc] {
    font-size: .8125rem;
    font-weight: 800;
    color: #b6c0d1;
}

.ml-dd-email[b-7xj0fltxfc] {
    font-size: .72rem;
    color: #94a3b8;
    margin-top: 1px;
}

.ml-dd-divider[b-7xj0fltxfc] {
    height: 1px;
    background: #b6c0d1;
    margin: 4px 0;
}

/* Dropdown items */
.ml-dd-item[b-7xj0fltxfc] {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 9px 16px;
    font-size: .8375rem;
    font-weight: 600;
    color: #b6c0d1;
    background: none;
    border: none;
    cursor: pointer;
    text-decoration: none;
    font-family: inherit;
    text-align: left;
    transition: background .1s, color .1s;
}

    .ml-dd-item:hover[b-7xj0fltxfc] {
        background: #f0f6ff;
        color: #b6c0d1;
    }

/* Icon container inside each item */
.ml-dd-icon[b-7xj0fltxfc] {
    width: 26px;
    height: 26px;
    border-radius: 7px;
    background: #f1f5f9;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #64748b;
    flex-shrink: 0;
    transition: background .1s, color .1s;
}

.ml-dd-item:hover .ml-dd-icon[b-7xj0fltxfc] {
    background: #dde8f5;
    color: #2563b0;
}

/* Danger (sign out) item */
.ml-dd-item-danger[b-7xj0fltxfc] {
    color: #dc2626;
}

    .ml-dd-item-danger:hover[b-7xj0fltxfc] {
        background: #fef2f2;
        color: #b91c1c;
    }

    .ml-dd-item-danger .ml-dd-icon[b-7xj0fltxfc] {
        color: #dc2626;
    }

    .ml-dd-item-danger:hover .ml-dd-icon[b-7xj0fltxfc] {
        background: #fecaca;
        color: #b91c1c;
    }

.ml-create-grid[b-7xj0fltxfc] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

    .ml-create-grid > div[b-7xj0fltxfc] {
        min-width: 0;
    }

.ml-create-modal-card[b-7xj0fltxfc] {
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    box-shadow: 0 14px 38px rgba(2, 6, 23, .14);
    overflow: hidden;
}

.ml-create-modal-header[b-7xj0fltxfc] {
    background: linear-gradient(160deg, #0a1628 0%, #0d2344 58%, #1a3a6b 100%);
    padding: 16px 18px 14px;
}

    .ml-create-modal-header .modal-title[b-7xj0fltxfc] {
        color: #f8fafc;
        font-weight: 800;
        letter-spacing: -.01em;
    }

    .ml-create-modal-header .text-muted[b-7xj0fltxfc] {
        color: rgba(255,255,255,.62) !important;
    }

    .ml-create-modal-header .btn-close[b-7xj0fltxfc] {
        filter: invert(1) grayscale(1) brightness(180%);
        opacity: .88;
    }

.ml-create-modal-body[b-7xj0fltxfc] {
    background: #f8fafc;
}

.ml-create-steps[b-7xj0fltxfc] {
    display: flex;
    align-items: center;
    gap: 10px;
}

    .ml-create-step small[b-7xj0fltxfc] {
        font-weight: 700;
    }

.ml-create-step[b-7xj0fltxfc] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #64748b;
    font-size: .78rem;
    font-weight: 700;
}

    .ml-create-step span[b-7xj0fltxfc] {
        width: 24px;
        height: 24px;
        border-radius: 999px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: #e2e8f0;
        color: #334155;
        font-size: .75rem;
        font-weight: 800;
    }

    .ml-create-step.active[b-7xj0fltxfc] {
        color: #1d4ed8;
    }

    .ml-create-step.active span[b-7xj0fltxfc] {
        background: #dbeafe;
        color: #1d4ed8;
    }

    .ml-create-step.done span[b-7xj0fltxfc] {
        background: #d1fae5;
        color: #047857;
    }

.ml-create-step-line[b-7xj0fltxfc] {
    flex: 1;
    height: 2px;
    background: #e2e8f0;
}

.ml-legal-picker[b-7xj0fltxfc] {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ml-legal-btn[b-7xj0fltxfc] {
    border: 1.5px solid #d7e0ee;
    background: #ffffff;
    color: #334155;
    border-radius: 9px;
    padding: 7px 12px;
    font-size: .78rem;
    font-weight: 700;
}

    .ml-legal-btn:hover[b-7xj0fltxfc] {
        background: #e2e8f0;
    }

.ml-legal-active[b-7xj0fltxfc] {
    border-color: #2563eb;
    background: #eaf1ff;
    color: #1d4ed8;
    box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}

.ml-create-label[b-7xj0fltxfc] {
    color: #334155;
}

.ml-create-input[b-7xj0fltxfc] {
    border-radius: 10px;
    border: 1.5px solid #dbe4f0;
    background: #fff;
}

    .ml-create-input:focus[b-7xj0fltxfc] {
        border-color: #2563b0;
        box-shadow: 0 0 0 3px rgba(37,99,176,.12);
    }

.ml-create-primary-btn[b-7xj0fltxfc] {
    box-shadow: 0 8px 18px rgba(37,99,176,.22);
}

@media (max-width: 640px) {
    .ml-create-grid[b-7xj0fltxfc] {
        grid-template-columns: 1fr;
    }
}

/* ══ Backdrops ══ */
.ml-backdrop[b-7xj0fltxfc] {
    position: fixed;
    inset: 0;
    z-index: 400;
    background: transparent;
}

.ml-sidebar-backdrop[b-7xj0fltxfc] {
    position: fixed;
    inset: 0;
    z-index: 150;
    background: rgba(7,17,31,.45);
    backdrop-filter: blur(2px);
    animation: mlFadeIn-b-7xj0fltxfc .2s ease;
}

@keyframes mlFadeIn-b-7xj0fltxfc {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

/* ══ Page content area ══ */
.ml-content[b-7xj0fltxfc] {
    flex: 1;
    min-width: 0;
    width: 100%;
    background: #f1f5f9;
    overflow-x: hidden;
}

.ml-footer[b-7xj0fltxfc] {
    flex-shrink: 0;
    padding: 10px 18px 14px;
    font-size: .75rem;
    color: #94a3b8;
    text-align: right;
    border-top: 1px solid #e2e8f0;
    background: #f8fafc;
}

/* ══ Blazor error UI ══ */
#blazor-error-ui[b-7xj0fltxfc] {
    display: none;
    position: fixed;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
}

.ml-err-inner[b-7xj0fltxfc] {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #0f172a;
    color: #f8fafc;
    padding: 12px 18px;
    border-radius: 12px;
    font-size: .875rem;
    font-weight: 500;
    box-shadow: 0 8px 30px rgba(0,0,0,.35);
    border: 1px solid rgba(255,255,255,.10);
    white-space: nowrap;
}

.ml-err-reload[b-7xj0fltxfc] {
    color: #60a5fa;
    font-weight: 700;
    text-decoration: none;
    margin-left: 4px;
}

    .ml-err-reload:hover[b-7xj0fltxfc] {
        color: #93c5fd;
    }

.ml-err-dismiss[b-7xj0fltxfc] {
    background: none;
    border: none;
    color: rgba(255,255,255,.45);
    cursor: pointer;
    font-size: .875rem;
    padding: 0 0 0 6px;
    line-height: 1;
    transition: color .15s;
}

    .ml-err-dismiss:hover[b-7xj0fltxfc] {
        color: #fff;
    }

/* ══ Responsive ══ */
@media (max-width: 768px) {
    .ml-main[b-7xj0fltxfc] {
        margin-left: 0 !important;
    }

    .ml-hamburger[b-7xj0fltxfc] {
        display: flex;
    }

    .ml-user-email[b-7xj0fltxfc] {
        display: none;
    }
}

@media (max-width: 640px) {
    .ml-topbar[b-7xj0fltxfc] {
        padding: 0 14px;
    }

    .ml-user-meta[b-7xj0fltxfc] {
        display: none;
    }

    .ml-user-btn[b-7xj0fltxfc] {
        padding: 0 6px;
    }

    .ml-company-name[b-7xj0fltxfc] {
        max-width: 120px;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .ml-footer[b-7xj0fltxfc] {
        text-align: center;
        padding: 10px 12px 14px;
    }
}
/* /Components/Layout/NavMenu.razor.rz.scp.css */
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-8q4aokuz1j],
.components-reconnect-repeated-attempt-visible[b-8q4aokuz1j],
.components-reconnect-failed-visible[b-8q4aokuz1j],
.components-pause-visible[b-8q4aokuz1j],
.components-resume-failed-visible[b-8q4aokuz1j],
.components-rejoining-animation[b-8q4aokuz1j] {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible[b-8q4aokuz1j],
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation[b-8q4aokuz1j],
#components-reconnect-modal.components-reconnect-paused .components-pause-visible[b-8q4aokuz1j],
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible[b-8q4aokuz1j],
#components-reconnect-modal.components-reconnect-retrying[b-8q4aokuz1j],
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible[b-8q4aokuz1j],
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation[b-8q4aokuz1j],
#components-reconnect-modal.components-reconnect-failed[b-8q4aokuz1j],
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible[b-8q4aokuz1j] {
    display: block;
}


#components-reconnect-modal[b-8q4aokuz1j] {
    background-color: white;
    width: 20rem;
    margin: 20vh auto;
    padding: 2rem;
    border: 0;
    border-radius: 0.5rem;
    box-shadow: 0 3px 6px 2px rgba(0, 0, 0, 0.3);
    opacity: 0;
    transition: display 0.5s allow-discrete, overlay 0.5s allow-discrete;
    animation: components-reconnect-modal-fadeOutOpacity-b-8q4aokuz1j 0.5s both;
    &[open]

{
    animation: components-reconnect-modal-slideUp-b-8q4aokuz1j 1.5s cubic-bezier(.05, .89, .25, 1.02) 0.3s, components-reconnect-modal-fadeInOpacity-b-8q4aokuz1j 0.5s ease-in-out 0.3s;
    animation-fill-mode: both;
}

}

#components-reconnect-modal[b-8q4aokuz1j]::backdrop {
    background-color: rgba(0, 0, 0, 0.4);
    animation: components-reconnect-modal-fadeInOpacity-b-8q4aokuz1j 0.5s ease-in-out;
    opacity: 1;
}

@keyframes components-reconnect-modal-slideUp-b-8q4aokuz1j {
    0% {
        transform: translateY(30px) scale(0.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity-b-8q4aokuz1j {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity-b-8q4aokuz1j {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.components-reconnect-container[b-8q4aokuz1j] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#components-reconnect-modal p[b-8q4aokuz1j] {
    margin: 0;
    text-align: center;
}

#components-reconnect-modal button[b-8q4aokuz1j] {
    border: 0;
    background-color: #6b9ed2;
    color: white;
    padding: 4px 24px;
    border-radius: 4px;
}

    #components-reconnect-modal button:hover[b-8q4aokuz1j] {
        background-color: #3b6ea2;
    }

    #components-reconnect-modal button:active[b-8q4aokuz1j] {
        background-color: #6b9ed2;
    }

.components-rejoining-animation[b-8q4aokuz1j] {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div[b-8q4aokuz1j] {
        position: absolute;
        border: 3px solid #0087ff;
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation-b-8q4aokuz1j 1.5s cubic-bezier(0, 0.2, 0.8, 1) infinite;
    }

        .components-rejoining-animation div:nth-child(2)[b-8q4aokuz1j] {
            animation-delay: -0.5s;
        }

@keyframes components-rejoining-animation-b-8q4aokuz1j {
    0% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    4.9% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    5% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 1;
    }

    100% {
        top: 0px;
        left: 0px;
        width: 80px;
        height: 80px;
        opacity: 0;
    }
}
/* /Components/Pages/Expenses/CreateExpense.razor.rz.scp.css */
.exp-create-page .exp-form-grid[b-j35mdczvc7] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 1.25rem;
}

.exp-create-page .exp-form-main[b-j35mdczvc7] {
    display: grid;
    gap: 1rem;
}

.exp-create-page .exp-form-side[b-j35mdczvc7] {
    align-self: start;
}

.exp-create-page .exp-summary-card[b-j35mdczvc7] {
    position: sticky;
    top: 1rem;
}

.exp-create-page .exp-fields[b-j35mdczvc7] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.exp-create-page .exp-field[b-j35mdczvc7],
.exp-create-page .exp-field-category[b-j35mdczvc7] {
    display: grid;
    gap: .45rem;
}

.exp-create-page .exp-label[b-j35mdczvc7] {
    font-size: .82rem;
    font-weight: 600;
    color: var(--fms-text-body);
    letter-spacing: .02em;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: .5rem;
}

.exp-create-page .exp-toggle-btn[b-j35mdczvc7] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: 1.5px solid var(--fms-border);
    background: #fff;
    color: var(--fms-text-body);
    border-radius: 8px;
    cursor: pointer;
    transition: all .2s ease;
    padding: 0;
    margin-left: auto;
}

    .exp-create-page .exp-toggle-btn:hover[b-j35mdczvc7] {
        background: var(--fms-accent-soft);
        border-color: var(--fms-accent-bright);
        color: var(--fms-accent);
        transform: scale(1.05);
    }

    .exp-create-page .exp-toggle-btn:active[b-j35mdczvc7] {
        transform: scale(0.95);
    }

.exp-create-page[b-j35mdczvc7]  .exp-input,
.exp-create-page[b-j35mdczvc7]  .exp-textarea {
    width: 100%;
    border: 1.5px solid var(--fms-border);
    border-radius: 12px;
    background: #f8fafc;
    color: var(--fms-text-strong);
    font: inherit;
    padding: .78rem .9rem;
    transition: border-color var(--fms-t), box-shadow var(--fms-t), background var(--fms-t);
}

.exp-create-page[b-j35mdczvc7]  select.exp-input {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.exp-create-page[b-j35mdczvc7]  .exp-input:focus,
.exp-create-page[b-j35mdczvc7]  .exp-textarea:focus {
    outline: none;
    border-color: var(--fms-accent-bright);
    box-shadow: 0 0 0 3px rgba(37,99,176,.1);
    background: #fff;
}

.exp-create-page[b-j35mdczvc7]  .exp-input-readonly {
    background: #f8fafc;
    color: var(--fms-text-dim);
}

.exp-create-page[b-j35mdczvc7]  .exp-input-number {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.exp-create-page[b-j35mdczvc7]  .exp-input-total {
    font-weight: 700;
    color: var(--fms-accent);
    background: #eff6ff;
    border-color: var(--fms-accent-bright);
}

.exp-create-page .exp-textarea[b-j35mdczvc7] {
    min-height: 140px;
    resize: vertical;
}

.exp-create-page .exp-with-action[b-j35mdczvc7] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 42px;
    gap: .55rem;
    align-items: center;
}

.exp-create-page .exp-add-btn[b-j35mdczvc7] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 44px;
    border: 1.5px solid var(--fms-accent-bright);
    background: var(--fms-accent-soft);
    color: var(--fms-accent);
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s ease;
}

    .exp-create-page .exp-add-btn:hover[b-j35mdczvc7] {
        background: var(--fms-accent);
        color: #fff;
        transform: scale(1.05);
        box-shadow: 0 4px 12px rgba(37,99,176,.25);
    }

.exp-create-page .exp-back-btn[b-j35mdczvc7] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(148,163,184,.35);
    background: rgba(255,255,255,.08);
    color: #e2e8f0;
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s ease;
}

    .exp-create-page .exp-back-btn:hover[b-j35mdczvc7] {
        background: rgba(255,255,255,.15);
        transform: translateX(-2px);
    }

.exp-create-page .exp-summary-row[b-j35mdczvc7] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: .65rem 0;
    color: var(--fms-text-body);
    border-bottom: 1px solid var(--fms-border);
}

    .exp-create-page .exp-summary-row:last-of-type[b-j35mdczvc7] {
        border-bottom: none;
    }

    .exp-create-page .exp-summary-row strong[b-j35mdczvc7] {
        color: var(--fms-text-strong);
        font-variant-numeric: tabular-nums;
    }

.exp-create-page .exp-status-badge[b-j35mdczvc7] {
    display: inline-flex;
    align-items: center;
    padding: .25rem .7rem;
    border-radius: 20px;
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .02em;
}

.exp-create-page .exp-status-draft[b-j35mdczvc7] {
    background: #fef3c7;
    color: #92400e;
}

.exp-create-page .exp-status-submitted[b-j35mdczvc7] {
    background: #dcfce7;
    color: #166534;
}

.exp-create-page .exp-actions[b-j35mdczvc7] {
    display: grid;
    gap: .75rem;
    margin-top: 1rem;
}

    .exp-create-page .exp-actions .fms-btn[b-j35mdczvc7] {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: .5rem;
    }

/* ══ Supplier modal validation ══ */
.fms-input-error[b-j35mdczvc7] {
    border-color: #dc2626 !important;
    background: #fef2f2 !important;
}

    .fms-input-error:focus[b-j35mdczvc7] {
        box-shadow: 0 0 0 3px rgba(220,38,38,.12) !important;
        border-color: #dc2626 !important;
    }

.sup-mf-msg[b-j35mdczvc7] {
    font-size: .73rem;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}

.sup-mf-ok[b-j35mdczvc7] {
    color: #059669;
}

.sup-mf-err[b-j35mdczvc7] {
    color: #dc2626;
}

@media (max-width: 1080px) {
    .exp-create-page .exp-form-grid[b-j35mdczvc7] {
        grid-template-columns: 1fr;
    }

    .exp-create-page .exp-form-side[b-j35mdczvc7] {
        order: -1;
    }
}

@media (max-width: 720px) {
    .exp-create-page .exp-fields[b-j35mdczvc7] {
        grid-template-columns: 1fr;
    }
}

/* ══ OCR scan zone ══ */
.exp-create-page .exp-scan-zone[b-j35mdczvc7] {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    margin-bottom: 1rem;
}

.exp-create-page .exp-scan-label[b-j35mdczvc7] {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    padding: .6rem 1rem;
    border: 1.5px dashed var(--fms-border);
    border-radius: 12px;
    background: #f8fafc;
    color: var(--fms-text-body);
    font-size: .85rem;
    font-weight: 500;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    width: fit-content;
}

    .exp-create-page .exp-scan-label:hover[b-j35mdczvc7] {
        border-color: var(--fms-accent-bright);
        background: var(--fms-accent-soft);
        color: var(--fms-accent);
    }

.exp-create-page .exp-scan-zone-done .exp-scan-label[b-j35mdczvc7] {
    border-color: #059669;
    border-style: solid;
    background: #f0fdf4;
    color: #059669;
}

.exp-create-page .exp-scan-input[b-j35mdczvc7] {
    display: none;
}

.exp-create-page .exp-scan-error[b-j35mdczvc7] {
    font-size: .82rem;
    color: #dc2626;
    padding: .4rem .75rem;
    background: #fef2f2;
    border-radius: 8px;
    border: 1px solid #fecaca;
}

/* spinner reused from sup-spinner */
.exp-create-page .exp-scan-spinner[b-j35mdczvc7] {
    width: 14px;
    height: 14px;
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin-b-j35mdczvc7 .7s linear infinite;
    display: inline-block;
    flex-shrink: 0;
}

@keyframes spin-b-j35mdczvc7 {
    to {
        transform: rotate(360deg);
    }
}

/* ══ Scan error ══ */
.exp-create-page .exp-scan-error[b-j35mdczvc7] {
    display: flex;
    align-items: center;
    gap: .45rem;
}

/* ══ Scan results summary ══ */
.exp-create-page .exp-scan-summary[b-j35mdczvc7] {
    margin-bottom: 1.25rem;
    border: 1px solid #d1fae5;
    border-radius: 14px;
    background: #f0fdf4;
    overflow: hidden;
    animation: fadeSlideIn-b-j35mdczvc7 .22s ease;
}

.exp-create-page .exp-scan-summary-partial[b-j35mdczvc7] {
    border-color: #fde68a;
    background: #fffbeb;
}

@keyframes fadeSlideIn-b-j35mdczvc7 {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.exp-create-page .exp-scan-summary-header[b-j35mdczvc7] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .65rem 1rem;
    border-bottom: 1px solid rgba(0,0,0,.06);
    background: rgba(255,255,255,.55);
}

.exp-create-page .exp-scan-summary-title[b-j35mdczvc7] {
    display: flex;
    align-items: center;
    gap: .45rem;
    font-size: .82rem;
    font-weight: 600;
    color: var(--fms-text-head, #111827);
}

.exp-create-page .exp-scan-summary-meta[b-j35mdczvc7] {
    display: flex;
    align-items: center;
    gap: .6rem;
}

.exp-create-page .exp-scan-conf-badge[b-j35mdczvc7] {
    font-size: .73rem;
    font-weight: 600;
    padding: .18rem .55rem;
    border-radius: 20px;
    background: #d1fae5;
    color: #065f46;
}

.exp-create-page .exp-scan-summary-partial .exp-scan-conf-badge[b-j35mdczvc7] {
    background: #fde68a;
    color: #92400e;
}

.exp-create-page .exp-scan-dismiss[b-j35mdczvc7] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--fms-text-muted, #6b7280);
    cursor: pointer;
    transition: background .15s, color .15s;
}

    .exp-create-page .exp-scan-dismiss:hover[b-j35mdczvc7] {
        background: rgba(0,0,0,.07);
        color: var(--fms-text-head, #111827);
    }

/* Results grid — 2 columns on desktop, 1 on mobile */
.exp-create-page .exp-scan-summary-grid[b-j35mdczvc7] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}

.exp-create-page .exp-scan-rf[b-j35mdczvc7] {
    display: grid;
    grid-template-columns: 16px 1fr auto;
    align-items: center;
    gap: .4rem;
    padding: .5rem 1rem;
    border-bottom: 1px solid rgba(0,0,0,.05);
    font-size: .8rem;
}

    .exp-create-page .exp-scan-rf:nth-child(odd)[b-j35mdczvc7] {
        border-right: 1px solid rgba(0,0,0,.05);
    }

    .exp-create-page .exp-scan-rf:nth-last-child(-n+2)[b-j35mdczvc7] {
        border-bottom: none;
    }

.exp-create-page .exp-scan-rf svg[b-j35mdczvc7] {
    color: #059669;
    flex-shrink: 0;
}

.exp-create-page .exp-scan-rf-miss svg[b-j35mdczvc7],
.exp-create-page .exp-scan-dash[b-j35mdczvc7] {
    color: #9ca3af;
}

.exp-create-page .exp-scan-rf-label[b-j35mdczvc7] {
    color: var(--fms-text-muted, #6b7280);
    font-weight: 500;
    white-space: nowrap;
}

.exp-create-page .exp-scan-rf-val[b-j35mdczvc7] {
    font-weight: 600;
    color: var(--fms-text-head, #111827);
    text-align: right;
}

.exp-create-page .exp-scan-rf-miss .exp-scan-rf-val[b-j35mdczvc7] {
    font-weight: 400;
    color: #9ca3af;
    font-style: italic;
}

.exp-create-page .exp-scan-rf-clamp[b-j35mdczvc7] {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.exp-create-page .exp-scan-summary-note[b-j35mdczvc7] {
    display: flex;
    align-items: center;
    gap: .45rem;
    padding: .55rem 1rem;
    font-size: .78rem;
    font-weight: 500;
}

.exp-create-page .exp-scan-note-ok[b-j35mdczvc7] {
    color: #065f46;
    background: rgba(5,150,105,.08);
    border-top: 1px solid rgba(5,150,105,.15);
}

.exp-create-page .exp-scan-note-warn[b-j35mdczvc7] {
    color: #92400e;
    background: rgba(245,158,11,.08);
    border-top: 1px solid rgba(245,158,11,.18);
}

@media (max-width: 600px) {
    .exp-create-page .exp-scan-summary-grid[b-j35mdczvc7] {
        grid-template-columns: 1fr;
    }

    .exp-create-page .exp-scan-rf:nth-child(odd)[b-j35mdczvc7] {
        border-right: none;
    }

    .exp-create-page .exp-scan-rf:last-child[b-j35mdczvc7] {
        border-bottom: none;
    }
}
/* /Components/Pages/Expenses/EditExpense.razor.rz.scp.css */
.exp-create-page .exp-form-grid[b-w4aw7f7buj] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 1.25rem;
}

.exp-create-page .exp-form-main[b-w4aw7f7buj] {
    display: grid;
    gap: 1rem;
}

.exp-create-page .exp-form-side[b-w4aw7f7buj] {
    align-self: start;
}

.exp-create-page .exp-summary-card[b-w4aw7f7buj] {
    position: sticky;
    top: 1rem;
}

.exp-create-page .exp-fields[b-w4aw7f7buj] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.exp-create-page .exp-field[b-w4aw7f7buj],
.exp-create-page .exp-field-category[b-w4aw7f7buj] {
    display: grid;
    gap: .45rem;
}

.exp-create-page .exp-label[b-w4aw7f7buj] {
    font-size: .82rem;
    font-weight: 600;
    color: var(--fms-text-body);
    letter-spacing: .02em;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: .5rem;
}

.exp-create-page .exp-toggle-btn[b-w4aw7f7buj] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: 1.5px solid var(--fms-border);
    background: #fff;
    color: var(--fms-text-body);
    border-radius: 8px;
    cursor: pointer;
    transition: all .2s ease;
    padding: 0;
    margin-left: auto;
}

.exp-create-page .exp-toggle-btn:hover[b-w4aw7f7buj] {
    background: var(--fms-accent-soft);
    border-color: var(--fms-accent-bright);
    color: var(--fms-accent);
    transform: scale(1.05);
}

.exp-create-page .exp-toggle-btn:active[b-w4aw7f7buj] {
    transform: scale(0.95);
}

.exp-create-page[b-w4aw7f7buj]  .exp-input,
.exp-create-page[b-w4aw7f7buj]  .exp-textarea {
    width: 100%;
    border: 1.5px solid var(--fms-border);
    border-radius: 12px;
    background: #f8fafc;
    color: var(--fms-text-strong);
    font: inherit;
    padding: .78rem .9rem;
    transition: border-color var(--fms-t), box-shadow var(--fms-t), background var(--fms-t);
}

.exp-create-page[b-w4aw7f7buj]  select.exp-input {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.exp-create-page[b-w4aw7f7buj]  .exp-input:focus,
.exp-create-page[b-w4aw7f7buj]  .exp-textarea:focus {
    outline: none;
    border-color: var(--fms-accent-bright);
    box-shadow: 0 0 0 3px rgba(37,99,176,.1);
    background: #fff;
}

.exp-create-page[b-w4aw7f7buj]  .exp-input-readonly {
    background: #f8fafc;
    color: var(--fms-text-dim);
}

.exp-create-page[b-w4aw7f7buj]  .exp-input-number {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.exp-create-page[b-w4aw7f7buj]  .exp-input-total {
    font-weight: 700;
    color: var(--fms-accent);
    background: #eff6ff;
    border-color: var(--fms-accent-bright);
}

.exp-create-page .exp-textarea[b-w4aw7f7buj] {
    min-height: 140px;
    resize: vertical;
}

.exp-create-page .exp-with-action[b-w4aw7f7buj] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 42px;
    gap: .55rem;
    align-items: center;
}

.exp-create-page .exp-add-btn[b-w4aw7f7buj] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 44px;
    border: 1.5px solid var(--fms-accent-bright);
    background: var(--fms-accent-soft);
    color: var(--fms-accent);
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s ease;
}

.exp-create-page .exp-add-btn:hover[b-w4aw7f7buj] {
    background: var(--fms-accent);
    color: #fff;
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(37,99,176,.25);
}

.exp-create-page .exp-back-btn[b-w4aw7f7buj] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(148,163,184,.35);
    background: rgba(255,255,255,.08);
    color: #e2e8f0;
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s ease;
}

.exp-create-page .exp-back-btn:hover[b-w4aw7f7buj] {
    background: rgba(255,255,255,.15);
    transform: translateX(-2px);
}

.exp-create-page .exp-summary-row[b-w4aw7f7buj] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: .65rem 0;
    color: var(--fms-text-body);
    border-bottom: 1px solid var(--fms-border);
}

.exp-create-page .exp-summary-row:last-of-type[b-w4aw7f7buj] {
    border-bottom: none;
}

.exp-create-page .exp-summary-row strong[b-w4aw7f7buj] {
    color: var(--fms-text-strong);
    font-variant-numeric: tabular-nums;
}

.exp-create-page .exp-status-badge[b-w4aw7f7buj] {
    display: inline-flex;
    align-items: center;
    padding: .25rem .7rem;
    border-radius: 20px;
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .02em;
}

.exp-create-page .exp-status-draft[b-w4aw7f7buj] {
    background: #fef3c7;
    color: #92400e;
}

.exp-create-page .exp-status-submitted[b-w4aw7f7buj] {
    background: #dcfce7;
    color: #166534;
}

.exp-create-page .exp-actions[b-w4aw7f7buj] {
    display: grid;
    gap: .75rem;
    margin-top: 1rem;
}

.exp-create-page .exp-actions .fms-btn[b-w4aw7f7buj] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}

/* ══ Supplier modal validation ══ */
.fms-input-error[b-w4aw7f7buj] {
    border-color: #dc2626 !important;
    background: #fef2f2 !important;
}

.fms-input-error:focus[b-w4aw7f7buj] {
    box-shadow: 0 0 0 3px rgba(220,38,38,.12) !important;
    border-color: #dc2626 !important;
}

.sup-mf-msg[b-w4aw7f7buj] {
    font-size: .73rem;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}

.sup-mf-ok[b-w4aw7f7buj] { color: #059669; }
.sup-mf-err[b-w4aw7f7buj] { color: #dc2626; }
@media (max-width: 1080px) {
    .exp-create-page .exp-form-grid[b-w4aw7f7buj] {
        grid-template-columns: 1fr;
    }

    .exp-create-page .exp-form-side[b-w4aw7f7buj] {
        order: -1;
    }
}

@media (max-width: 720px) {
    .exp-create-page .exp-fields[b-w4aw7f7buj] {
        grid-template-columns: 1fr;
    }
}
/* /Components/Pages/Expenses/ExpenseForm.razor.rz.scp.css */
.exp-create-page .exp-form-grid[b-ucyk9mgkdx] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 1.25rem;
}

.exp-create-page .exp-form-main[b-ucyk9mgkdx] {
    display: grid;
    gap: 1rem;
}

.exp-create-page .exp-form-side[b-ucyk9mgkdx] {
    align-self: start;
}

.exp-create-page .exp-summary-card[b-ucyk9mgkdx] {
    position: sticky;
    top: 1rem;
}

.exp-create-page .exp-fields[b-ucyk9mgkdx] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.exp-create-page .exp-field[b-ucyk9mgkdx],
.exp-create-page .exp-field-category[b-ucyk9mgkdx] {
    display: grid;
    gap: .45rem;
}

.exp-create-page .exp-label[b-ucyk9mgkdx] {
    font-size: .82rem;
    font-weight: 600;
    color: var(--fms-text-body);
    letter-spacing: .02em;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: .5rem;
}

.exp-create-page .exp-toggle-btn[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: 1.5px solid var(--fms-border);
    background: #fff;
    color: var(--fms-text-body);
    border-radius: 8px;
    cursor: pointer;
    transition: all .2s ease;
    padding: 0;
    margin-left: auto;
}

.exp-create-page .exp-toggle-btn:hover[b-ucyk9mgkdx] {
    background: var(--fms-accent-soft);
    border-color: var(--fms-accent-bright);
    color: var(--fms-accent);
    transform: scale(1.05);
}

.exp-create-page .exp-toggle-btn:active[b-ucyk9mgkdx] {
    transform: scale(0.95);
}

.exp-create-page[b-ucyk9mgkdx]  .exp-input,
.exp-create-page[b-ucyk9mgkdx]  .exp-textarea {
    width: 100%;
    border: 1.5px solid var(--fms-border);
    border-radius: 12px;
    background: #f8fafc;
    color: var(--fms-text-strong);
    font: inherit;
    padding: .78rem .9rem;
    transition: border-color var(--fms-t), box-shadow var(--fms-t), background var(--fms-t);
}

.exp-create-page[b-ucyk9mgkdx]  select.exp-input {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.exp-create-page[b-ucyk9mgkdx]  .exp-input:focus,
.exp-create-page[b-ucyk9mgkdx]  .exp-textarea:focus {
    outline: none;
    border-color: var(--fms-accent-bright);
    box-shadow: 0 0 0 3px rgba(37,99,176,.1);
    background: #fff;
}

.exp-create-page[b-ucyk9mgkdx]  .exp-input-readonly {
    background: #f8fafc;
    color: var(--fms-text-dim);
}

.exp-create-page[b-ucyk9mgkdx]  .exp-input-number {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.exp-create-page[b-ucyk9mgkdx]  .exp-input-total {
    font-weight: 700;
    color: var(--fms-accent);
    background: #eff6ff;
    border-color: var(--fms-accent-bright);
}

.exp-create-page .exp-textarea[b-ucyk9mgkdx] {
    min-height: 140px;
    resize: vertical;
}

.exp-create-page .exp-with-action[b-ucyk9mgkdx] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 42px;
    gap: .55rem;
    align-items: center;
}

.exp-create-page .exp-add-btn[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 44px;
    border: 1.5px solid var(--fms-accent-bright);
    background: var(--fms-accent-soft);
    color: var(--fms-accent);
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s ease;
}

.exp-create-page .exp-add-btn:hover[b-ucyk9mgkdx] {
    background: var(--fms-accent);
    color: #fff;
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(37,99,176,.25);
}

.exp-create-page .exp-back-btn[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(148,163,184,.35);
    background: rgba(255,255,255,.08);
    color: #e2e8f0;
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s ease;
}

.exp-create-page .exp-back-btn:hover[b-ucyk9mgkdx] {
    background: rgba(255,255,255,.15);
    transform: translateX(-2px);
}

.exp-create-page .exp-summary-row[b-ucyk9mgkdx] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: .65rem 0;
    color: var(--fms-text-body);
    border-bottom: 1px solid var(--fms-border);
}

.exp-create-page .exp-summary-row:last-of-type[b-ucyk9mgkdx] {
    border-bottom: none;
}

.exp-create-page .exp-summary-row strong[b-ucyk9mgkdx] {
    color: var(--fms-text-strong);
    font-variant-numeric: tabular-nums;
}

.exp-create-page .exp-status-badge[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    padding: .25rem .7rem;
    border-radius: 20px;
    font-size: .78rem;
    font-weight: 600;
    letter-spacing: .02em;
}

.exp-create-page .exp-status-draft[b-ucyk9mgkdx] {
    background: #fef3c7;
    color: #92400e;
}

.exp-create-page .exp-status-submitted[b-ucyk9mgkdx] {
    background: #dcfce7;
    color: #166534;
}

.exp-create-page .exp-actions[b-ucyk9mgkdx] {
    display: grid;
    gap: .75rem;
    margin-top: 1rem;
}

.exp-create-page .exp-actions .fms-btn[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}

/* ══ Supplier modal validation ══ */
.fms-input-error[b-ucyk9mgkdx] {
    border-color: #dc2626 !important;
    background: #fef2f2 !important;
}

.fms-input-error:focus[b-ucyk9mgkdx] {
    box-shadow: 0 0 0 3px rgba(220,38,38,.12) !important;
    border-color: #dc2626 !important;
}

.sup-mf-msg[b-ucyk9mgkdx] {
    font-size: .73rem;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}

.sup-mf-ok[b-ucyk9mgkdx] { color: #059669; }
.sup-mf-err[b-ucyk9mgkdx] { color: #dc2626; }

/* ══ Receipt upload area ══ */
.exp-upload-area[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px dashed var(--fms-border);
    border-radius: 14px;
    padding: 2rem 1.5rem;
    cursor: pointer;
    transition: all .25s ease;
    background: #f8fafc;
}

.exp-upload-area:hover[b-ucyk9mgkdx] {
    border-color: var(--fms-accent-bright);
    background: var(--fms-accent-soft);
    transform: translateY(-1px);
}

.exp-upload-area input[type="file"][b-ucyk9mgkdx] {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    overflow: hidden;
}

.exp-upload-content[b-ucyk9mgkdx] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    color: var(--fms-text-dim);
}

.exp-upload-content svg[b-ucyk9mgkdx] {
    color: var(--fms-accent);
    opacity: .65;
}

.exp-upload-label[b-ucyk9mgkdx] {
    font-size: .88rem;
    font-weight: 600;
    color: var(--fms-accent);
}

.exp-upload-hint[b-ucyk9mgkdx] {
    font-size: .73rem;
    color: var(--fms-text-dim);
}

/* ── Receipt file info ── */
.exp-receipt-info[b-ucyk9mgkdx] {
    display: grid;
    gap: .65rem;
}

.exp-receipt-file[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .75rem .85rem;
    border: 1.5px solid var(--fms-border);
    border-radius: 12px;
    background: #f8fafc;
}

.exp-receipt-file svg[b-ucyk9mgkdx] {
    color: var(--fms-accent);
    flex-shrink: 0;
}

.exp-receipt-meta[b-ucyk9mgkdx] {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}

.exp-receipt-name[b-ucyk9mgkdx] {
    font-size: .85rem;
    font-weight: 600;
    color: var(--fms-text-strong);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.exp-receipt-size[b-ucyk9mgkdx] {
    font-size: .73rem;
    color: var(--fms-text-dim);
}

.exp-receipt-remove[b-ucyk9mgkdx],
.exp-receipt-download[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1.5px solid var(--fms-border);
    background: #fff;
    border-radius: 8px;
    cursor: pointer;
    transition: all .2s ease;
    flex-shrink: 0;
    padding: 0;
}

.exp-receipt-remove:hover[b-ucyk9mgkdx] {
    background: #fef2f2;
    border-color: #fca5a5;
    color: #dc2626;
}

.exp-receipt-download:hover[b-ucyk9mgkdx] {
    background: var(--fms-accent-soft);
    border-color: var(--fms-accent-bright);
    color: var(--fms-accent);
}

/* ── Extraction status ── */
.exp-extracting[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-size: .82rem;
    color: var(--fms-accent);
    font-weight: 500;
    padding: .4rem 0;
}

.exp-extracting-spinner[b-ucyk9mgkdx] {
    width: 16px;
    height: 16px;
    border: 2.5px solid var(--fms-accent-soft);
    border-top-color: var(--fms-accent);
    border-radius: 50%;
    animation: exp-spin-b-ucyk9mgkdx .7s linear infinite;
}

@keyframes exp-spin-b-ucyk9mgkdx {
    to { transform: rotate(360deg); }
}

.exp-extraction-done[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .82rem;
    color: #059669;
    font-weight: 600;
    padding: .4rem 0;
}

@media (max-width: 1080px) {
    .exp-create-page .exp-form-grid[b-ucyk9mgkdx] {
        grid-template-columns: 1fr;
    }

    .exp-create-page .exp-form-side[b-ucyk9mgkdx] {
        order: -1;
    }
}

@media (max-width: 720px) {
    .exp-create-page .exp-fields[b-ucyk9mgkdx] {
        grid-template-columns: 1fr;
    }
}

.exp-receipt-preview[b-ucyk9mgkdx] {
    margin-top: .75rem;
    border-radius: .4rem;
    overflow: hidden;
    background-color: #f8fafc;
    border: 1px solid #e2e8f0;
    max-height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: zoom-in;
    transition: opacity .15s;
}

.exp-receipt-preview:hover[b-ucyk9mgkdx] {
    opacity: .9;
}

.exp-receipt-preview img[b-ucyk9mgkdx] {
    max-width: 100%;
    max-height: 300px;
    object-fit: contain;
}

.exp-receipt-card[b-ucyk9mgkdx] {
    display: flex;
    flex-direction: column;
    padding: .5rem 0;
    border-bottom: 1px solid #f1f5f9;
}

.exp-receipt-card:last-child[b-ucyk9mgkdx] {
    border-bottom: none;
}
.exp-scan-overlay[b-ucyk9mgkdx] {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    backdrop-filter: blur(3px);
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: expFadeIn-b-ucyk9mgkdx 0.2s ease;
}

.exp-scan-box[b-ucyk9mgkdx] {
    width: 420px;
    max-width: calc(100vw - 40px);
    background: #fff;
    border-radius: 22px;
    padding: 34px 28px;
    box-shadow: 0 25px 60px rgba(15, 23, 42, 0.22);
    text-align: center;
}

.exp-scan-spinner[b-ucyk9mgkdx] {
    width: 68px;
    height: 68px;
    border-radius: 50%;
    border: 5px solid #dbeafe;
    border-top-color: #2563eb;
    margin: 0 auto 24px auto;
    animation: expSpin-b-ucyk9mgkdx 0.9s linear infinite;
}

.exp-scan-title[b-ucyk9mgkdx] {
    font-size: 22px;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 8px;
}

.exp-scan-subtitle[b-ucyk9mgkdx] {
    font-size: 14px;
    line-height: 1.6;
    color: #64748b;
}

@keyframes expSpin-b-ucyk9mgkdx {
    to {
        transform: rotate(360deg);
    }
}

@keyframes expFadeIn-b-ucyk9mgkdx {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

.exp-actions-head[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    min-height: 44px;
}

.exp-actions-head-left[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    gap: 10px;
}

.exp-scan-btn[b-ucyk9mgkdx] {
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: none;
    border-radius: 14px;
    padding: 10px 16px;
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    color: white;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.25s ease;
    box-shadow: 0 8px 22px rgba(37, 99, 235, 0.35), 0 0 0 rgba(59, 130, 246, 0.4);
}

    .exp-scan-btn:hover[b-ucyk9mgkdx] {
        transform: translateY(-1px) scale(1.02);
        box-shadow: 0 12px 28px rgba(37, 99, 235, 0.45), 0 0 22px rgba(59, 130, 246, 0.55);
    }

    .exp-scan-btn:disabled[b-ucyk9mgkdx] {
        opacity: 0.7;
        cursor: not-allowed;
    }

.exp-scan-btn-glow[b-ucyk9mgkdx] {
    position: absolute;
    top: -40%;
    left: -120%;
    width: 70%;
    height: 180%;
    background: rgba(255,255,255,0.35);
    transform: rotate(24deg);
    animation: expScanShine-b-ucyk9mgkdx 2.8s infinite;
}

@keyframes expScanShine-b-ucyk9mgkdx {
    0% {
        left: -120%;
    }

    45% {
        left: 140%;
    }

    100% {
        left: 140%;
    }
}

.fms-topbar[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.fms-topbar-right[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
}

.exp-scan-btn-header[b-ucyk9mgkdx] {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    gap: 12px;
    border: none;
    border-radius: 18px;
    padding: 14px 22px;
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    color: white;
    cursor: pointer;
    box-shadow: 0 10px 30px rgba(37, 99, 235, 0.30), 0 4px 12px rgba(37, 99, 235, 0.18);
    transition: all 0.25s ease;
}

    .exp-scan-btn-header:hover[b-ucyk9mgkdx] {
        transform: translateY(-2px);
        box-shadow: 0 14px 40px rgba(37, 99, 235, 0.38), 0 6px 18px rgba(37, 99, 235, 0.24);
    }

.exp-scan-btn-content[b-ucyk9mgkdx] {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.1;
}

.exp-scan-btn-title[b-ucyk9mgkdx] {
    font-size: 15px;
    font-weight: 700;
}

.exp-scan-btn-sub[b-ucyk9mgkdx] {
    font-size: 11px;
    opacity: 0.82;
    margin-top: 3px;
}

.exp-scan-btn-glow[b-ucyk9mgkdx] {
    position: absolute;
    top: 0;
    left: -120%;
    width: 60%;
    height: 100%;
    background: linear-gradient( 90deg, transparent, rgba(255,255,255,0.35), transparent );
    transform: skewX(-20deg);
    animation: expScanGlow 2.8s infinite;
}

@@keyframes expScanGlow {
    100%[b-ucyk9mgkdx] {
        left: 160%;
    }
}
/* ── RAS inline (inside Amounts card) ─────────────────────────────────────── */

.exp-ras-inline[b-ucyk9mgkdx] {
    margin-top: 1.25rem;
    border-top: 1.5px dashed var(--fms-border);
    padding-top: 1rem;
}

.exp-ras-inline-header[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: .85rem;
}

.exp-ras-inline-title[b-ucyk9mgkdx] {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .78rem;
    font-weight: 700;
    color: var(--fms-text-body);
    letter-spacing: .04em;
    text-transform: uppercase;
}

.exp-ras-inline-body[b-ucyk9mgkdx] {
    display: grid;
    gap: .75rem;
}

.exp-ras-fields[b-ucyk9mgkdx] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.exp-ras-badge[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 20px;
    white-space: nowrap;
}

.exp-ras-badge-on[b-ucyk9mgkdx] {
    background: #dcfce7;
    color: #15803d;
    border: 1px solid #86efac;
}

.exp-ras-badge-off[b-ucyk9mgkdx] {
    background: #f1f5f9;
    color: #64748b;
    border: 1px solid #e2e8f0;
}

.exp-ras-badge-pending[b-ucyk9mgkdx] {
    background: #fefce8;
    color: #92400e;
    border: 1px solid #fde68a;
}

.exp-ras-override-chip[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    font-size: 10px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 10px;
    background: #ede9fe;
    color: #6d28d9;
    border: 1px solid #c4b5fd;
    text-transform: none;
    letter-spacing: 0;
}

.exp-ras-override-field[b-ucyk9mgkdx] {
    display: grid;
    gap: .45rem;
}

/* Toggle switch (button-based, no hidden checkbox) */
.exp-ras-toggle[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    user-select: none;
    height: 40px;
    padding: 0 10px 0 0;
    background: none;
    border: 1.5px solid var(--fms-border);
    border-radius: 10px;
    transition: border-color .2s, background .2s;
    width: 100%;
}

.exp-ras-toggle:hover[b-ucyk9mgkdx] {
    border-color: #a5b4fc;
    background: #f5f3ff;
}

.exp-ras-toggle-on[b-ucyk9mgkdx] {
    border-color: #6366f1;
    background: #f5f3ff;
}

.exp-ras-toggle-track[b-ucyk9mgkdx] {
    position: relative;
    width: 34px;
    height: 18px;
    background: #e2e8f0;
    border-radius: 9px;
    transition: background .2s;
    flex-shrink: 0;
    margin-left: 10px;
}

.exp-ras-toggle-on .exp-ras-toggle-track[b-ucyk9mgkdx] {
    background: #6366f1;
}

.exp-ras-toggle-thumb[b-ucyk9mgkdx] {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 14px;
    height: 14px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 1px 3px rgba(0,0,0,.25);
    transition: transform .2s cubic-bezier(.4,0,.2,1);
}

.exp-ras-toggle-on .exp-ras-toggle-thumb[b-ucyk9mgkdx] {
    transform: translateX(16px);
}

.exp-ras-toggle-label[b-ucyk9mgkdx] {
    font-size: 12px;
    color: #64748b;
    font-weight: 600;
    flex: 1;
    text-align: left;
}

.exp-ras-toggle-on .exp-ras-toggle-label[b-ucyk9mgkdx] {
    color: #4f46e5;
}

.exp-ras-reason[b-ucyk9mgkdx] {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    padding: 8px 10px;
    background: #fff7ed;
    border: 1px solid #fed7aa;
    border-radius: 6px;
    font-size: 12px;
    color: #92400e;
    line-height: 1.45;
}

/* RAS loading spinner */
.exp-ras-spinner[b-ucyk9mgkdx] {
    display: inline-block;
    width: 10px;
    height: 10px;
    border: 1.5px solid #f59e0b;
    border-top-color: transparent;
    border-radius: 50%;
    animation: exp-ras-spin-b-ucyk9mgkdx .6s linear infinite;
    flex-shrink: 0;
}

@keyframes exp-ras-spin-b-ucyk9mgkdx {
    to { transform: rotate(360deg); }
}

/* RAS calculation result */
.exp-ras-calc[b-ucyk9mgkdx] {
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    overflow: hidden;
    background: #f8fafc;
}

.exp-ras-calc-row[b-ucyk9mgkdx] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 7px 12px;
    font-size: 12.5px;
    color: #475569;
    border-bottom: 1px solid #f1f5f9;
    font-variant-numeric: tabular-nums;
}

.exp-ras-calc-row:last-child[b-ucyk9mgkdx] {
    border-bottom: none;
}

.exp-ras-calc-base[b-ucyk9mgkdx] {
    font-size: 10px;
    color: #94a3b8;
    font-weight: 400;
}

.exp-ras-calc-deduct[b-ucyk9mgkdx] {
    color: #b91c1c;
}

.exp-ras-calc-net[b-ucyk9mgkdx] {
    background: #eff6ff;
    font-size: 13px;
    font-weight: 700;
    color: #1e40af;
}

/* ── Summary sidebar breakdown ─────────────────────────────────────────────── */

.exp-summary-sub[b-ucyk9mgkdx] {
    color: var(--fms-text-dim);
    font-size: .82rem;
    padding: .45rem 0;
}

.exp-summary-sub span:last-child[b-ucyk9mgkdx] {
    font-variant-numeric: tabular-nums;
    color: var(--fms-text-body);
}

.exp-summary-ttc[b-ucyk9mgkdx] {
    border-top: 1.5px solid var(--fms-border) !important;
    border-bottom: 1.5px solid var(--fms-border) !important;
    padding: .7rem 0 !important;
    margin: .1rem 0;
}

.exp-summary-ttc strong[b-ucyk9mgkdx] {
    color: var(--fms-accent) !important;
    font-size: 1rem;
}

.exp-summary-ras[b-ucyk9mgkdx] {
    color: #b91c1c !important;
    font-size: .82rem;
    padding: .45rem 0;
}

.exp-summary-ras span:last-child[b-ucyk9mgkdx] {
    font-variant-numeric: tabular-nums;
}

.exp-summary-net[b-ucyk9mgkdx] {
    background: #eff6ff;
    border-radius: 8px;
    padding: .6rem .75rem !important;
    margin: 0 -.75rem;
    border-bottom: none !important;
}

.exp-summary-net strong[b-ucyk9mgkdx] {
    color: #1e40af !important;
    font-size: .95rem;
}

/* ── Supplier fiscal context strip ─────────────────────────────────────────── */

.exp-supplier-fiscal[b-ucyk9mgkdx] {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    padding-top: 2px;
}

.exp-fiscal-tag[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .03em;
    padding: 2px 8px;
    border-radius: 6px;
    background: #eff6ff;
    color: #1d4ed8;
    border: 1px solid #bfdbfe;
    font-variant-numeric: tabular-nums;
    transition: background .15s;
}

.exp-fiscal-tag-public[b-ucyk9mgkdx] {
    background: #fef3c7;
    color: #92400e;
    border-color: #fde68a;
}

.exp-fiscal-tag-missing[b-ucyk9mgkdx] {
    background: #f8fafc;
    color: #94a3b8;
    border-color: #e2e8f0;
    font-weight: 500;
    font-style: italic;
}

/* ── TEJ XML Export button ────────────────────────────────────────────────── */

.exp-tej-btn[b-ucyk9mgkdx] {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 16px;
    border: 1.5px solid #10b981;
    border-radius: 10px;
    background: #f0fdf4;
    color: #065f46;
    font-size: .8125rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, box-shadow .15s, transform .12s;
    white-space: nowrap;
    margin-left: 10px;
}

.exp-tej-btn:hover:not(:disabled)[b-ucyk9mgkdx] {
    background: #d1fae5;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.20);
    transform: translateY(-1px);
}

.exp-tej-btn:disabled[b-ucyk9mgkdx] {
    opacity: 0.6;
    cursor: not-allowed;
}

.exp-tej-btn--warn[b-ucyk9mgkdx] {
    border-color: #f59e0b;
    background: #fffbeb;
    color: #92400e;
}

.exp-tej-btn--warn:hover:not(:disabled)[b-ucyk9mgkdx] {
    background: #fef3c7;
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.20);
}

.exp-tej-warn-icon[b-ucyk9mgkdx] {
    color: #d97706;
    flex-shrink: 0;
}

.exp-tej-spinner[b-ucyk9mgkdx] {
    display: inline-block;
    width: 13px;
    height: 13px;
    border: 2px solid #10b981;
    border-top-color: transparent;
    border-radius: 50%;
    animation: exp-tej-spin .65s linear infinite;
}

@@keyframes exp-tej-spin {
    to[b-ucyk9mgkdx] { transform: rotate(360deg); }
}
/* /Components/Pages/Expenses/Expenses.razor.rz.scp.css */
.exp-page .fms-card-body[b-hjlt61ip1a] {
    padding: 0;
}

.exp-loading[b-hjlt61ip1a],
.exp-empty[b-hjlt61ip1a] {
    padding: 2rem;
    text-align: center;
}

.exp-empty-title[b-hjlt61ip1a] {
    margin: 0 0 .35rem;
    font-weight: 700;
    color: var(--fms-text-strong);
}

.exp-empty-sub[b-hjlt61ip1a] {
    margin: 0;
    color: var(--fms-text-muted);
}

.exp-ref[b-hjlt61ip1a] {
    font-weight: 700;
    color: var(--fms-accent);
}

.exp-badge[b-hjlt61ip1a] {
    display: inline-flex;
    align-items: center;
    padding: .32rem .62rem;
    border-radius: 999px;
    font-size: .77rem;
    font-weight: 700;
    border: 1px solid transparent;
    white-space: nowrap;
}

.exp-badge-draft[b-hjlt61ip1a] {
    background: #eff6ff;
    border-color: #bfdbfe;
    color: #1d4ed8;
}

.exp-badge-submitted[b-hjlt61ip1a] {
    background: #ecfeff;
    border-color: #a5f3fc;
    color: #0f766e;
}

.exp-badge-unpaid[b-hjlt61ip1a] {
    background: #fff7ed;
    border-color: #fed7aa;
    color: #c2410c;
}

.exp-badge-paid[b-hjlt61ip1a] {
    background: #f0fdf4;
    border-color: #bbf7d0;
    color: #15803d;
}

.exp-badge-toreimburse[b-hjlt61ip1a] {
    background: #faf5ff;
    border-color: #e9d5ff;
    color: #7e22ce;
}

.exp-amount[b-hjlt61ip1a] {
    font-variant-numeric: tabular-nums;
    font-weight: 700;
}
/* /Components/Pages/Invoices/InvoiceCreate.razor.rz.scp.css */


.invoice-create-page .section-card[b-zw6xfzapg7] {
    border: 0;
    border-radius: 14px;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.07);
}

.invoice-create-page .form-label[b-zw6xfzapg7] {
    font-weight: 600;
    color: #334155;
}

.invoice-create-page .client-card[b-zw6xfzapg7] {
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 12px 14px;
    background: #f8fafc;
}

.invoice-create-page .invoice-lines-table td[b-zw6xfzapg7],
.invoice-create-page .invoice-lines-table th[b-zw6xfzapg7] {
    vertical-align: top;
}

.invoice-create-page .invoice-lines-table .form-control[b-zw6xfzapg7],
.invoice-create-page .invoice-lines-table .form-select[b-zw6xfzapg7] {
    border-radius: 8px;
}

.invoice-create-page .stock-warning[b-zw6xfzapg7] {
    color: #8a6d1f;
    font-size: 0.76rem;
    background: #fff9db;
    border: 1px solid #f9e2a4;
    border-radius: 6px;
    padding: 2px 6px;
    display: inline-block;
}

.invoice-create-page .totals-card[b-zw6xfzapg7] {
    position: sticky;
    top: 90px;
}

.invoice-create-page .total-ttc[b-zw6xfzapg7] {
    font-size: 1.1rem;
    color: #0f172a;
}

.invoice-create-page .autocomplete-menu[b-zw6xfzapg7] {
    position: absolute;
    z-index: 20;
    left: 0;
    right: 0;
    margin-top: 4px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    background: #fff;
    max-height: 220px;
    overflow-y: auto;
}

.invoice-create-page .autocomplete-item[b-zw6xfzapg7] {
    border: 0;
    width: 100%;
    text-align: left;
    background: transparent;
    padding: 8px 10px;
}

.invoice-create-page .autocomplete-item:hover[b-zw6xfzapg7] {
    background: #f1f5f9;
}
/* /Components/Pages/Invoices/InvoiceEdit.razor.rz.scp.css */
/* /Components/Pages/Suppliers/SupplierCreate.razor.rz.scp.css */
.sup-create-page .sup-form-grid[b-ort4nj62l1] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 1.25rem;
}

.sup-create-page .sup-form-main[b-ort4nj62l1] {
    display: grid;
    gap: 1rem;
}

.sup-create-page .sup-form-side[b-ort4nj62l1] {
    align-self: start;
}

.sup-create-page .sup-summary-card[b-ort4nj62l1] {
    position: sticky;
    top: 1rem;
}

.sup-create-page .sup-fields[b-ort4nj62l1] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.sup-create-page .sup-field[b-ort4nj62l1] {
    display: grid;
    gap: .45rem;
}

.sup-create-page .sup-field-full[b-ort4nj62l1] {
    grid-column: 1 / -1;
}

.sup-create-page .sup-label[b-ort4nj62l1] {
    font-size: .82rem;
    font-weight: 600;
    color: var(--fms-text-body);
    letter-spacing: .02em;
    text-transform: uppercase;
}

.sup-create-page[b-ort4nj62l1]  .sup-input {
    width: 100%;
    border: 1.5px solid var(--fms-border);
    border-radius: 12px;
    background: #f8fafc;
    color: var(--fms-text-strong);
    font: inherit;
    padding: .78rem .9rem;
    transition: border-color var(--fms-t), box-shadow var(--fms-t), background var(--fms-t);
}

.sup-create-page[b-ort4nj62l1]  select.sup-input {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.sup-create-page[b-ort4nj62l1]  .sup-input:focus {
    outline: none;
    border-color: var(--fms-accent-bright);
    box-shadow: 0 0 0 3px rgba(37,99,176,.1);
    background: #fff;
}

.sup-create-page .sup-back-btn[b-ort4nj62l1] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(148,163,184,.35);
    background: rgba(255,255,255,.08);
    color: #e2e8f0;
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s ease;
}

.sup-create-page .sup-back-btn:hover[b-ort4nj62l1] {
    background: rgba(255,255,255,.15);
    transform: translateX(-2px);
}

.sup-create-page .sup-summary-info[b-ort4nj62l1] {
    padding: .75rem 0;
    border-bottom: 1px solid var(--fms-border);
    margin-bottom: .75rem;
}

.sup-create-page .sup-summary-text[b-ort4nj62l1] {
    font-size: .875rem;
    color: var(--fms-text-body);
    line-height: 1.5;
    margin: 0;
}

.sup-create-page .sup-actions[b-ort4nj62l1] {
    display: grid;
    gap: .75rem;
}

.sup-create-page .sup-actions .fms-btn[b-ort4nj62l1] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}

.sup-create-page .sup-loading[b-ort4nj62l1] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .75rem;
    padding: 2rem;
    color: var(--fms-text-body);
}

/* ══ Field helpers ══ */
.sup-create-page .sup-req[b-ort4nj62l1] {
    color: #dc2626;
    margin-left: 2px;
}

.sup-create-page .sup-opt[b-ort4nj62l1] {
    font-size: .7rem;
    font-weight: 500;
    color: #94a3b8;
    margin-left: 4px;
}

/* ══ Matricule fiscal validation ══ */
.sup-create-page .sup-mf-msg[b-ort4nj62l1] {
    font-size: .73rem;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}

.sup-create-page .sup-mf-ok[b-ort4nj62l1] {
    color: #059669;
}

.sup-create-page .sup-mf-err[b-ort4nj62l1] {
    color: #dc2626;
}

/* ══ Input error state ══ */
.sup-create-page[b-ort4nj62l1]  .sup-input-error {
    border-color: #dc2626 !important;
    background: #fef2f2 !important;
}

.sup-create-page[b-ort4nj62l1]  .sup-input-error:focus {
    box-shadow: 0 0 0 3px rgba(220,38,38,.12) !important;
    border-color: #dc2626 !important;
}

/* ══ Toggle row ══ */
.sup-create-page .sup-toggle-row[b-ort4nj62l1] {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-top: 4px;
}

.sup-create-page .sup-toggle-label[b-ort4nj62l1] {
    font-size: .8125rem;
    color: #64748b;
    font-weight: 500;
}

/* ══ Spinner ══ */
.sup-create-page .sup-spinner[b-ort4nj62l1] {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
    border: 2px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    animation: supSpin-b-ort4nj62l1 .7s linear infinite;
}

@keyframes supSpin-b-ort4nj62l1 {
    to { transform: rotate(360deg); }
}

@media (max-width: 1080px) {
    .sup-create-page .sup-form-grid[b-ort4nj62l1] {
        grid-template-columns: 1fr;
    }

    .sup-create-page .sup-form-side[b-ort4nj62l1] {
        order: -1;
    }
}

@media (max-width: 720px) {
    .sup-create-page .sup-fields[b-ort4nj62l1] {
        grid-template-columns: 1fr;
    }
}

/* Made with Bob */
/* /Components/Pages/Suppliers/SupplierEdit.razor.rz.scp.css */
.sup-create-page .sup-form-grid[b-mulc8ot7v9] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 1.25rem;
}

.sup-create-page .sup-form-main[b-mulc8ot7v9] {
    display: grid;
    gap: 1rem;
}

.sup-create-page .sup-form-side[b-mulc8ot7v9] {
    align-self: start;
}

.sup-create-page .sup-summary-card[b-mulc8ot7v9] {
    position: sticky;
    top: 1rem;
}

.sup-create-page .sup-fields[b-mulc8ot7v9] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.sup-create-page .sup-field[b-mulc8ot7v9] {
    display: grid;
    gap: .45rem;
}

.sup-create-page .sup-field-full[b-mulc8ot7v9] {
    grid-column: 1 / -1;
}

.sup-create-page .sup-label[b-mulc8ot7v9] {
    font-size: .82rem;
    font-weight: 600;
    color: var(--fms-text-body);
    letter-spacing: .02em;
    text-transform: uppercase;
}

.sup-create-page[b-mulc8ot7v9]  .sup-input {
    width: 100%;
    border: 1.5px solid var(--fms-border);
    border-radius: 12px;
    background: #f8fafc;
    color: var(--fms-text-strong);
    font: inherit;
    padding: .78rem .9rem;
    transition: border-color var(--fms-t), box-shadow var(--fms-t), background var(--fms-t);
}

.sup-create-page[b-mulc8ot7v9]  select.sup-input {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.sup-create-page[b-mulc8ot7v9]  .sup-input:focus {
    outline: none;
    border-color: var(--fms-accent-bright);
    box-shadow: 0 0 0 3px rgba(37,99,176,.1);
    background: #fff;
}

.sup-create-page .sup-back-btn[b-mulc8ot7v9] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(148,163,184,.35);
    background: rgba(255,255,255,.08);
    color: #e2e8f0;
    border-radius: 12px;
    cursor: pointer;
    transition: all .2s ease;
}

    .sup-create-page .sup-back-btn:hover[b-mulc8ot7v9] {
        background: rgba(255,255,255,.15);
        transform: translateX(-2px);
    }

.sup-create-page .sup-summary-info[b-mulc8ot7v9] {
    padding: .75rem 0;
    border-bottom: 1px solid var(--fms-border);
    margin-bottom: .75rem;
}

.sup-create-page .sup-summary-text[b-mulc8ot7v9] {
    font-size: .875rem;
    color: var(--fms-text-body);
    line-height: 1.5;
    margin: 0;
}

.sup-create-page .sup-actions[b-mulc8ot7v9] {
    display: grid;
    gap: .75rem;
}

    .sup-create-page .sup-actions .fms-btn[b-mulc8ot7v9] {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: .5rem;
    }

.sup-create-page .sup-loading[b-mulc8ot7v9] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .75rem;
    padding: 2rem;
    color: var(--fms-text-body);
}

/* ══ Field helpers ══ */
.sup-create-page .sup-req[b-mulc8ot7v9] {
    color: #dc2626;
    margin-left: 2px;
}

.sup-create-page .sup-opt[b-mulc8ot7v9] {
    font-size: .7rem;
    font-weight: 500;
    color: #94a3b8;
    margin-left: 4px;
}

/* ══ Matricule fiscal validation ══ */
.sup-create-page .sup-mf-msg[b-mulc8ot7v9] {
    font-size: .73rem;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}

.sup-create-page .sup-mf-ok[b-mulc8ot7v9] {
    color: #059669;
}

.sup-create-page .sup-mf-err[b-mulc8ot7v9] {
    color: #dc2626;
}

/* ══ Input error state ══ */
.sup-create-page[b-mulc8ot7v9]  .sup-input-error {
    border-color: #dc2626 !important;
    background: #fef2f2 !important;
}

.sup-create-page[b-mulc8ot7v9]  .sup-input-error:focus {
    box-shadow: 0 0 0 3px rgba(220,38,38,.12) !important;
    border-color: #dc2626 !important;
}

/* ══ Toggle row ══ */
.sup-create-page .sup-toggle-row[b-mulc8ot7v9] {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-top: 4px;
}

.sup-create-page .sup-toggle-label[b-mulc8ot7v9] {
    font-size: .8125rem;
    color: #64748b;
    font-weight: 500;
}

/* ══ Spinner ══ */
.sup-create-page .sup-spinner[b-mulc8ot7v9] {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
    border: 2px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    animation: supSpin-b-mulc8ot7v9 .7s linear infinite;
}

@keyframes supSpin-b-mulc8ot7v9 {
    to {
        transform: rotate(360deg);
    }
}

@media (max-width: 1080px) {
    .sup-create-page .sup-form-grid[b-mulc8ot7v9] {
        grid-template-columns: 1fr;
    }

    .sup-create-page .sup-form-side[b-mulc8ot7v9] {
        order: -1;
    }
}

@media (max-width: 720px) {
    .sup-create-page .sup-fields[b-mulc8ot7v9] {
        grid-template-columns: 1fr;
    }
}

/* Made with Bob */
/* /Components/Pages/Suppliers/Suppliers.razor.rz.scp.css */
/* ══ Supplier Modal — Card-based sections ══ */
.sup-modal-body[b-4a44o4rowo] {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-height: 68vh;
    overflow-y: auto;
    padding: 1.25rem !important;
    background: #f8fafc;
}

.sup-section[b-4a44o4rowo] {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.sup-section-head[b-4a44o4rowo] {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-bottom: 1px solid #f1f5f9;
    background: linear-gradient(to bottom, #fafbff 0%, #f8fafc 100%);
}

.sup-section-ico[b-4a44o4rowo] {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    flex-shrink: 0;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #2563b0;
}

.sup-section-title[b-4a44o4rowo] {
    font-size: .875rem;
    font-weight: 700;
    color: #0f172a;
    letter-spacing: 0.01em;
}

.sup-section-body[b-4a44o4rowo] {
    padding: 16px;
    background: #fff;
}

/* ══ Field helpers ══ */
.sup-req[b-4a44o4rowo] {
    color: #dc2626;
    margin-left: 2px;
}

.sup-opt[b-4a44o4rowo] {
    font-size: .7rem;
    font-weight: 500;
    color: #94a3b8;
    margin-left: 4px;
}

/* ══ Matricule fiscal validation ══ */
.sup-mf-msg[b-4a44o4rowo] {
    font-size: .73rem;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}

.sup-mf-ok[b-4a44o4rowo] {
    color: #059669;
}

.sup-mf-err[b-4a44o4rowo] {
    color: #dc2626;
}

/* ══ Toggle row ══ */
.sup-toggle-row[b-4a44o4rowo] {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-top: 4px;
}

.sup-toggle-label[b-4a44o4rowo] {
    font-size: .8125rem;
    color: #64748b;
    font-weight: 500;
}

/* ══ Spinner ══ */
.sup-spinner[b-4a44o4rowo] {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    flex-shrink: 0;
    border: 2px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    animation: supSpin-b-4a44o4rowo .7s linear infinite;
}

@keyframes supSpin-b-4a44o4rowo {
    to { transform: rotate(360deg); }
}
