/* /Components/Layout/MainLayout.razor.rz.scp.css */
.app-layout[b-d4as9q0z1s] {
    display: flex;
    height: 100vh;
    background-color: var(--bg-app);
    overflow: hidden;
}

.main-container[b-d4as9q0z1s] {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    position: relative;
}

.app-bar[b-d4as9q0z1s] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 9px var(--space-8);
    background-color: rgba(255, 255, 255, 0.75);
    backdrop-filter: blur(20px) saturate(200%);
    -webkit-backdrop-filter: blur(20px) saturate(200%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.8);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.04), 0 4px 6px rgba(0, 0, 0, 0.02);
    position: sticky;
    top: 0;
    z-index: var(--z-index-appbar);
    transition: all 0.3s ease;
}

/* Add a subtle highlight line at the top to simulate a premium metallic/glass edge */
.app-bar[b-d4as9q0z1s]::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 1px;
    background: rgba(99, 102, 241, 0.4);
    z-index: 10;
}

.page-title-group[b-d4as9q0z1s] {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.page-title-icon[b-d4as9q0z1s] {
    font-size: 1.3rem;
    color: var(--color-primary, #6366f1);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    background: rgba(99, 102, 241, 0.08);
    border-radius: 10px;
    flex-shrink: 0;
}

.page-title h3[b-d4as9q0z1s] {
    font-size: 1.2rem;
    font-weight: 700;
    margin: 0;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    letter-spacing: -0.01em;
    line-height: 1.2;
}

.page-breadcrumb[b-d4as9q0z1s] {
    font-size: 0.75rem;
    color: var(--text-tertiary, var(--slate-400));
    font-weight: 500;
    letter-spacing: 0.01em;
}

.user-profile[b-d4as9q0z1s] {
    display: flex;
    align-items: center;
    gap: var(--space-5);
}

.user-profile > button[b-d4as9q0z1s],
.user-profile > .notification-container > button[b-d4as9q0z1s],
.user-profile > form button[b-d4as9q0z1s] {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    background-color: var(--bg-surface);
    border: 1px solid rgba(0,0,0,0.05);
    box-shadow: 0 2px 5px rgba(0,0,0,0.02);
    transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
    font-size: 1.15rem;
    position: relative;
    cursor: pointer;
}

.user-profile > button:hover[b-d4as9q0z1s],
.user-profile > .notification-container > button:hover[b-d4as9q0z1s],
.user-profile > form button:hover[b-d4as9q0z1s] {
    background-color: white;
    color: var(--color-primary, #6366f1);
    transform: translateY(-2px);
    box-shadow: 0 6px 15px -3px rgba(99, 102, 241, 0.2), 0 4px 6px -2px rgba(99, 102, 241, 0.1);
    border-color: rgba(99, 102, 241, 0.2);
}

/* Notification dot is now handled dynamically in Razor markup */

.user-avatar-wrapper[b-d4as9q0z1s] {
    position: relative;
    display: inline-flex;
    cursor: pointer;
}

.user-profile img[b-d4as9q0z1s] {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-full);
    object-fit: cover;
    box-shadow: 0 0 0 2px var(--bg-surface), 0 0 0 4px rgba(99, 102, 241, 0.15);
    transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
    cursor: pointer;
}

.user-profile img:hover[b-d4as9q0z1s] {
    transform: scale(1.05) translateY(-2px);
    box-shadow: 0 0 0 2px var(--bg-surface), 0 0 0 4px var(--color-primary, #6366f1), 0 10px 15px -3px rgba(99, 102, 241, 0.3);
}

/* Online status indicator */
.avatar-status-dot[b-d4as9q0z1s] {
    position: absolute;
    bottom: 2px;
    right: 2px;
    width: 12px;
    height: 12px;
    background-color: #22c55e;
    border-radius: 50%;
    border: 2.5px solid white;
    box-sizing: content-box;
}

.content-area[b-d4as9q0z1s] {
    padding: 0.5rem 0.75rem;
    flex: 1;
    max-width: 1600px;
    margin: 0 auto;
    width: 100%;
}

.content[b-d4as9q0z1s] {
    width: 100%;
    animation: fadeIn-b-d4as9q0z1s 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

#blazor-error-ui[b-d4as9q0z1s] {
    background: var(--bg-surface);
    color: var(--color-danger);
    padding: var(--space-4);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--border);
    position: fixed;
    bottom: var(--space-6);
    right: var(--space-6);
    left: auto;
    z-index: 1000;
    display: none;
    max-width: 400px;
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

#blazor-error-ui .dismiss[b-d4as9q0z1s] {
    cursor: pointer;
    margin-left: auto;
    opacity: 0.5;
    padding: 4px;
}

#blazor-error-ui .dismiss:hover[b-d4as9q0z1s] {
    opacity: 1;
}

@keyframes fadeIn-b-d4as9q0z1s {
    from {
        opacity: 0;
        transform: translateY(4px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}
/* /Components/Layout/NavMenu.razor.rz.scp.css */
/* ============================================================
   PREMIUM SIDEBAR — Dark Gradient with Glass & Glow Accents
   ============================================================ */

.sidebar[b-i26eka3aih] {
    width: 270px;
    background: #0f172a;
    display: flex;
    flex-direction: column;
    transition: width 0.4s cubic-bezier(0.22, 1, 0.36, 1);
    height: 100vh;
    z-index: 20;
    overflow-x: hidden;
    overflow-y: hidden;
    position: relative;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
}

.nav-link-button[b-i26eka3aih] {
    width: 100%;
    border: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
    font-family: inherit;
}

.settings-chevron[b-i26eka3aih] {
    margin-left: auto;
    font-size: 0.9rem;
    transition: transform 0.2s ease;
}

.settings-chevron.expanded[b-i26eka3aih] {
    transform: rotate(180deg);
}

.settings-submenu[b-i26eka3aih] {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.25s ease;
}

.settings-submenu.expanded[b-i26eka3aih] {
    max-height: 260px;
}

.settings-submenu-link[b-i26eka3aih] {
    padding-left: 34px;
}

.sidebar.collapsed .settings-submenu[b-i26eka3aih] {
    display: none;
}

.sidebar.collapsed .settings-chevron[b-i26eka3aih] {
    display: none;
}

/* Ambient glow and subtle noise texture overlays removed to enforce pure solid color */

.sidebar.collapsed[b-i26eka3aih] {
    width: 78px;
}

/* ---- Header / Brand ---- */
.sidebar-header[b-i26eka3aih] {
    display: flex;
    align-items: center;
    padding: 20px 20px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: padding 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.sidebar.collapsed .sidebar-header[b-i26eka3aih] {
    padding: 20px 0;
    justify-content: center;
}

.sidebar.collapsed .brand-icon[b-i26eka3aih] {
    width: 46px;
    height: 46px;
    border-radius: 11px;
}

.brand-link[b-i26eka3aih] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    color: #ffffff;
    width: 100%;
    transition: all 0.3s ease;
}

.sidebar.collapsed .brand-link[b-i26eka3aih] {
    justify-content: center;
}

.brand-link:hover[b-i26eka3aih] {
    opacity: 1;
    color: #ffffff;
}

.brand-icon[b-i26eka3aih] {
    width: 100px;
    height: 54px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border-radius: 12px;
    flex-shrink: 0;
    transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.brand-link:hover .brand-icon[b-i26eka3aih] {
    transform: scale(1.08) rotate(-3deg);
    box-shadow: 0 6px 20px rgba(99, 102, 241, 0.5),
                0 0 0 1px rgba(255, 255, 255, 0.15) inset;
}

.brand-name[b-i26eka3aih] {
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: rgba(148, 163, 184, 0.85);
    text-transform: uppercase;
    line-height: 1;
    text-align: center;
}

/* ---- Nav Section ---- */
.nav-menu[b-i26eka3aih] {
    flex: 1;
    padding: 8px 12px;
    overflow-y: auto;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: relative;
    z-index: 1;
    transition: padding 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Ultra-thin scrollbar */
.nav-menu[b-i26eka3aih]::-webkit-scrollbar { width: 3px; }
.nav-menu[b-i26eka3aih]::-webkit-scrollbar-track { background: transparent; }
.nav-menu[b-i26eka3aih]::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 10px;
}

.sidebar.collapsed .nav-menu[b-i26eka3aih] {
    padding: 8px 10px;
}

.nav-group[b-i26eka3aih] {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.nav-group-title[b-i26eka3aih] {
    padding: 0 12px 8px;
    font-size: 0.68rem;
    font-weight: 600;
    color: rgba(148, 163, 184, 0.65);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: opacity 0.25s ease, max-height 0.3s ease, padding 0.3s ease, margin 0.3s ease;
    max-height: 20px;
    opacity: 1;
    white-space: nowrap;
}

.sidebar.collapsed .nav-group-title[b-i26eka3aih] {
    opacity: 0;
    max-height: 0;
    padding: 0;
    margin: 0;
    overflow: hidden;
}

.nav-group-separator[b-i26eka3aih] {
    height: 1px;
    background: rgba(255, 255, 255, 0.06);
    margin: 0 12px;
    transition: margin 0.4s ease;
}

.sidebar.collapsed .nav-group-separator[b-i26eka3aih] {
    margin: 0 16px;
}

/* ---- Text Animation (Collapse) ---- */
.nav-text[b-i26eka3aih], .brand-name[b-i26eka3aih] {
    transition: opacity 0.2s ease 0.05s, max-width 0.35s cubic-bezier(0.22, 1, 0.36, 1), margin 0.35s ease;
    white-space: nowrap;
    overflow: hidden;
    opacity: 1;
    max-width: 180px;
}

.sidebar.collapsed .nav-text[b-i26eka3aih],
.sidebar.collapsed .brand-name[b-i26eka3aih] {
    opacity: 0;
    max-width: 0;
    margin-left: 0;
    transition: opacity 0.15s ease, max-width 0.35s cubic-bezier(0.22, 1, 0.36, 1), margin 0.35s ease;
}

/* ---- Nav Links ---- */
[b-i26eka3aih] .nav-link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    min-height: 44px;
    border-radius: 10px;
    color: rgba(203, 213, 225, 0.75);
    text-decoration: none;
    transition: all 0.2s ease;
    font-size: 0.9rem;
    font-weight: 500;
    position: relative;
    user-select: none;
    overflow: hidden;
}

.sidebar.collapsed[b-i26eka3aih]  .nav-link {
    padding: 10px 0;
    justify-content: center;
    border-radius: 12px;
}

[b-i26eka3aih] .nav-link:hover {
    background-color: rgba(255, 255, 255, 0.06);
    color: #f1f5f9;
    transform: translateX(2px);
}

.sidebar.collapsed[b-i26eka3aih]  .nav-link:hover {
    transform: scale(1.08);
    background-color: rgba(255, 255, 255, 0.08);
}

/* ---- Active State — Glowing Primary ---- */
[b-i26eka3aih] .nav-link.active {
    background: rgba(229, 74, 139, 0.15);
    color: #ffffff;
    font-weight: 600;
    box-shadow: 0 0 20px -5px rgba(229, 74, 139, 0.3);
}

/* Active left indicator bar */
[b-i26eka3aih] .nav-link.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 20px;
    background: #e54a8b;
    border-radius: 0 4px 4px 0;
    box-shadow: 0 0 8px rgba(229, 74, 139, 0.5);
}

.sidebar.collapsed[b-i26eka3aih]  .nav-link.active::before {
    width: 20px;
    height: 3px;
    left: 50%;
    top: auto;
    bottom: 2px;
    transform: translateX(-50%);
    border-radius: 4px;
}

/* ---- Icons ---- */
[b-i26eka3aih] .nav-link i {
    font-size: 1.2rem;
    width: 22px;
    text-align: center;
    color: rgba(148, 163, 184, 0.7);
    transition: all 0.25s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

[b-i26eka3aih] .nav-link:hover i {
    color: #a5b4fc;
}

[b-i26eka3aih] .nav-link.active i {
    color: #e54a8b;
    filter: drop-shadow(0 0 4px rgba(229, 74, 139, 0.4));
}

/* ---- Footer ---- */
.sidebar-footer[b-i26eka3aih] {
    padding: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    margin-top: auto;
    position: relative;
    z-index: 1;
    transition: padding 0.4s ease;
}

.sidebar.collapsed .sidebar-footer[b-i26eka3aih] {
    padding: 16px 0;
    display: flex;
    justify-content: center;
}

.collapse-btn[b-i26eka3aih] {
    width: 100%;
    justify-content: center;
    color: rgba(148, 163, 184, 0.6);
    border: none;
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    background: transparent;
    border-radius: 10px;
    padding: 10px;
    transition: all 0.25s ease;
    overflow: hidden;
    min-height: 44px;
    font-size: 0.85rem;
    font-weight: 500;
    font-family: var(--font-sans);
}

.sidebar:not(.collapsed) .collapse-btn[b-i26eka3aih] {
    justify-content: flex-start;
    padding: 10px 12px;
}

.collapse-icon[b-i26eka3aih] {
    font-size: 1.2rem;
    transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), color 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    flex-shrink: 0;
}

.sidebar.collapsed .collapse-icon[b-i26eka3aih] {
    transform: rotate(180deg);
}

.collapse-btn:hover[b-i26eka3aih] {
    color: #f1f5f9;
    background: rgba(255, 255, 255, 0.06);
}

.collapse-btn:hover .collapse-icon[b-i26eka3aih] {
    color: #a5b4fc;
}

/* ---- Tooltips on collapsed hover ---- */
.sidebar.collapsed[b-i26eka3aih]  .nav-link {
    position: relative;
}

.sidebar.collapsed[b-i26eka3aih]  .nav-link .nav-text {
    position: absolute;
    left: 100%;
    top: 50%;
    transform: translateY(-50%);
    margin-left: 14px;
    background: #1e293b;
    color: #f1f5f9;
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 500;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    max-width: none;
    width: auto;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3),
                0 0 0 1px rgba(255, 255, 255, 0.06);
    z-index: 999;
    transition: opacity 0.2s ease 0.1s;
}

.sidebar.collapsed[b-i26eka3aih]  .nav-link .nav-text::before {
    content: '';
    position: absolute;
    left: -5px;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
    width: 10px;
    height: 10px;
    background: #1e293b;
    box-shadow: -1px 1px 0 0 rgba(255, 255, 255, 0.06);
    z-index: -1;
}

.sidebar.collapsed[b-i26eka3aih]  .nav-link:hover .nav-text {
    opacity: 1;
}
/* /Components/Pages/Admin.razor.rz.scp.css */
/*
   Admin premium styles have been moved to wwwroot/css/admin-premium.css (global)
   because Blazor scoped CSS cannot style deeply-nested or dynamically-rendered child elements.
   This file is kept intentionally empty.
*/
/* /Components/Pages/Dashboard.razor.rz.scp.css */
/* ════════════════════════════════════════════════════
   DASHBOARD — Premium Design System
   Tokens match app.css custom properties
   ════════════════════════════════════════════════════ */

/* ── Root wrapper ───────────────────────────────── */
.db-root[b-ffu13ph2sz] {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding-bottom: 4rem;
    animation: db-fade-in-b-ffu13ph2sz 0.4s ease-out both;
}

@keyframes db-fade-in-b-ffu13ph2sz {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}




/* ════════════════════════════════════════════════════
   HERO BAND
   ════════════════════════════════════════════════════ */
.db-hero[b-ffu13ph2sz] {
    position: relative;
    border-radius: 1.25rem;
    overflow: hidden;
    background: linear-gradient(135deg, #1e1b4b 0%, #312e81 40%, #4338ca 75%, #6366f1 100%);
    box-shadow: 0 20px 40px -8px rgba(99,102,241,.45);
}

.db-hero-bg[b-ffu13ph2sz] {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 80% -20%, rgba(167,139,250,.3) 0%, transparent 55%),
                radial-gradient(ellipse at -10% 110%, rgba(16,185,129,.2) 0%, transparent 50%);
    pointer-events: none;
}

/* subtle mesh-grid overlay */
.db-hero-bg[b-ffu13ph2sz]::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 40px 40px;
}

.db-hero-content[b-ffu13ph2sz] {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    padding: 2.25rem 2rem;
}

/* ── Left text ── */
.db-hero-left[b-ffu13ph2sz] {
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

.db-hero-eyebrow[b-ffu13ph2sz] {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: rgba(199,210,254,.85);
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 999px;
    padding: .25rem .75rem;
    width: fit-content;
    backdrop-filter: blur(8px);
}

.db-hero-title[b-ffu13ph2sz] {
    font-size: 1.875rem;
    font-weight: 800;
    letter-spacing: -.03em;
    color: #fff;
    margin: 0;
    line-height: 1.15;
}

.db-hero-sub[b-ffu13ph2sz] {
    font-size: .8125rem;
    color: rgba(199,210,254,.75);
    font-weight: 500;
    margin: 0;
}

/* ── Right ring ── */
.db-hero-right[b-ffu13ph2sz] {
    flex-shrink: 0;
}

.db-ring-wrap[b-ffu13ph2sz] {
    position: relative;
    width: 100px;
    height: 100px;
}

.db-ring-svg[b-ffu13ph2sz] {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.db-ring-track[b-ffu13ph2sz] {
    fill: none;
    stroke: rgba(255,255,255,.12);
    stroke-width: 8;
}

.db-ring-fill[b-ffu13ph2sz] {
    fill: none;
    stroke: #34d399;
    stroke-width: 8;
    stroke-linecap: round;
    stroke-dasharray: 314.16;
    transition: stroke-dashoffset 1s cubic-bezier(.16,1,.3,1);
    filter: drop-shadow(0 0 6px rgba(52,211,153,.6));
}

.db-ring-label[b-ffu13ph2sz] {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
}

.db-ring-pct[b-ffu13ph2sz] {
    font-size: 1.375rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.04em;
}

.db-ring-sym[b-ffu13ph2sz] {
    font-size: .875rem;
    font-weight: 600;
}

.db-ring-caption[b-ffu13ph2sz] {
    font-size: .625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: rgba(167,243,208,.85);
    margin-top: .125rem;
}

/* ════════════════════════════════════════════════════
   KPI STAT CARDS
   ════════════════════════════════════════════════════ */
.db-kpi-grid[b-ffu13ph2sz] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .875rem;
}

@media (min-width: 768px) {
    .db-kpi-grid[b-ffu13ph2sz] { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1024px) {
    .db-kpi-grid[b-ffu13ph2sz] { grid-template-columns: repeat(6, 1fr); }
}

.db-kpi[b-ffu13ph2sz] {
    position: relative;
    border-radius: 1rem;
    padding: 1.25rem 1.125rem 1.125rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    transition: transform .18s ease, box-shadow .18s ease;
}

.db-kpi:hover[b-ffu13ph2sz] {
    transform: translateY(-3px);
    box-shadow: 0 12px 28px -6px rgba(0,0,0,.12);
}

/* primary accent card */
.db-kpi--primary[b-ffu13ph2sz] {
    background: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%);
    box-shadow: 0 8px 24px -4px rgba(99,102,241,.45);
    color: #fff;
}

/* ghost (white surface) cards */
.db-kpi--ghost[b-ffu13ph2sz] {
    background: #ffffff;
    border: 1px solid var(--slate-100);
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    color: var(--slate-900);
}

/* accent glow */
.db-kpi-glow[b-ffu13ph2sz] {
    position: absolute;
    top: -20px; right: -20px;
    width: 80px; height: 80px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    pointer-events: none;
}

/* icon */
.db-kpi-icon[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: .625rem;
    background: rgba(255,255,255,.18);
    font-size: 1.05rem;
    color: #fff;
    flex-shrink: 0;
    margin-bottom: .25rem;
}

.db-kpi-icon--slate[b-ffu13ph2sz]   { background: var(--slate-100); color: var(--slate-500); }
.db-kpi-icon--amber[b-ffu13ph2sz]   { background: #fffbeb; color: #f59e0b; }
.db-kpi-icon--blue[b-ffu13ph2sz]    { background: #eff6ff; color: #3b82f6; }
.db-kpi-icon--emerald[b-ffu13ph2sz] { background: #ecfdf5; color: #10b981; }

.db-kpi-body[b-ffu13ph2sz] { display: flex; flex-direction: column; gap: .15rem; }

.db-kpi-label[b-ffu13ph2sz] {
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: rgba(255,255,255,.7);
}
.db-kpi--ghost .db-kpi-label[b-ffu13ph2sz] { color: var(--slate-400); }

.db-kpi-value[b-ffu13ph2sz] {
    font-size: 2.25rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.04em;
    color: #fff;
}
.db-kpi--ghost .db-kpi-value[b-ffu13ph2sz] { color: var(--slate-900); }
.db-kpi-value--emerald[b-ffu13ph2sz] { color: #059669 !important; }

.db-kpi-sub[b-ffu13ph2sz] {
    font-size: .6875rem;
    font-weight: 500;
    color: rgba(255,255,255,.65);
}
.db-kpi--ghost .db-kpi-sub[b-ffu13ph2sz] { color: var(--slate-400); }
.db-kpi-sub--amber[b-ffu13ph2sz]   { color: #d97706 !important; }
.db-kpi-sub--blue[b-ffu13ph2sz]    { color: #2563eb !important; }
.db-kpi-sub--emerald[b-ffu13ph2sz] { color: #059669 !important; font-weight: 600; }

/* left-edge accent stripe */
.db-kpi-stripe[b-ffu13ph2sz] {
    position: absolute;
    bottom: 0; left: 0;
    width: 3px; height: 40%;
    border-radius: 0 2px 2px 0;
}
.db-kpi-stripe--indigo[b-ffu13ph2sz]  { background: rgba(255,255,255,.4); }
.db-kpi-stripe--slate[b-ffu13ph2sz]   { background: var(--slate-300); }
.db-kpi-stripe--amber[b-ffu13ph2sz]   { background: #f59e0b; }
.db-kpi-stripe--blue[b-ffu13ph2sz]    { background: #3b82f6; }
.db-kpi-stripe--emerald[b-ffu13ph2sz] { background: #10b981; }

/* ════════════════════════════════════════════════════
   PROGRESS TRACK CARD
   ════════════════════════════════════════════════════ */
.db-track-card[b-ffu13ph2sz] {
    background: #fff;
    border: 1px solid var(--slate-100);
    border-radius: 1rem;
    padding: 1.25rem 1.5rem 1rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.db-track-header[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .875rem;
}

.db-track-title[b-ffu13ph2sz] {
    font-size: .8125rem;
    font-weight: 700;
    color: var(--slate-700);
    display: flex;
    align-items: center;
    gap: .4rem;
}

.db-track-rate[b-ffu13ph2sz] {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: .1rem;
}

.db-track-rate-val[b-ffu13ph2sz] {
    font-size: 1.25rem;
    font-weight: 900;
    color: #059669;
    letter-spacing: -.03em;
    line-height: 1;
}

.db-track-rate-lbl[b-ffu13ph2sz] {
    font-size: .625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--slate-400);
}

/* segmented bar */
.db-seg-bar[b-ffu13ph2sz] {
    display: flex;
    height: .875rem;
    border-radius: 999px;
    overflow: hidden;
    gap: 2px;
    background: var(--slate-100);
}

.db-seg[b-ffu13ph2sz] {
    transition: width .9s cubic-bezier(.16,1,.3,1);
    border-radius: 999px;
    cursor: default;
}

.db-seg--green[b-ffu13ph2sz]  { background: linear-gradient(90deg, #34d399, #10b981); }
.db-seg--blue[b-ffu13ph2sz]   { background: linear-gradient(90deg, #60a5fa, #3b82f6); }
.db-seg--amber[b-ffu13ph2sz]  { background: linear-gradient(90deg, #fbbf24, #f59e0b); }
.db-seg--slate[b-ffu13ph2sz]  { background: var(--slate-200); }

.db-track-legend[b-ffu13ph2sz] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .35rem 1rem;
    margin-top: .75rem;
    font-size: .6875rem;
    font-weight: 600;
    color: var(--slate-500);
}

.db-legend-dot[b-ffu13ph2sz] {
    display: inline-block;
    width: .5rem;
    height: .5rem;
    border-radius: 50%;
    margin-right: .3rem;
}
.db-legend-dot--green[b-ffu13ph2sz]  { background: #10b981; }
.db-legend-dot--blue[b-ffu13ph2sz]   { background: #3b82f6; }
.db-legend-dot--amber[b-ffu13ph2sz]  { background: #f59e0b; }
.db-legend-dot--slate[b-ffu13ph2sz]  { background: var(--slate-300); }

/* ════════════════════════════════════════════════════
   SECTION HEADING
   ════════════════════════════════════════════════════ */
.db-section[b-ffu13ph2sz] { display: flex; flex-direction: column; gap: .875rem; }

.db-section-header[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    gap: .6rem;
}

.db-section-icon[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.875rem;
    height: 1.875rem;
    border-radius: .5rem;
    font-size: .9rem;
}

.db-section-icon--red[b-ffu13ph2sz] { background: #fef2f2; color: #ef4444; }

.db-section-title[b-ffu13ph2sz] {
    font-size: .875rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--slate-600);
    margin: 0;
}

/* ════════════════════════════════════════════════════
   URGENCY BADGES
   ════════════════════════════════════════════════════ */
.db-urgency-badges[b-ffu13ph2sz] {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.db-urgency-badge[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    gap: .875rem;
    padding: .75rem 1.25rem;
    border-radius: .875rem;
    border: 1px solid transparent;
    min-width: 130px;
    text-decoration: none;
    cursor: pointer;
    transition: transform .15s ease, box-shadow .15s ease;
}

.db-urgency-badge:hover[b-ffu13ph2sz] {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px -4px rgba(0,0,0,.15);
}

.db-urgency-badge--red[b-ffu13ph2sz] {
    background: #fef2f2;
    border-color: #fecaca;
    box-shadow: 0 2px 8px -2px rgba(239,68,68,.2);
}

.db-urgency-badge--amber[b-ffu13ph2sz] {
    background: #fffbeb;
    border-color: #fde68a;
    box-shadow: 0 2px 8px -2px rgba(245,158,11,.2);
}

.db-urgency-badge--orange[b-ffu13ph2sz] {
    background: #fff7ed;
    border-color: #fed7aa;
    box-shadow: 0 2px 8px -2px rgba(249,115,22,.2);
}

.db-urgency-badge-icon[b-ffu13ph2sz] {
    font-size: 1.375rem;
}

.db-urgency-badge--red    .db-urgency-badge-icon[b-ffu13ph2sz] { color: #ef4444; }
.db-urgency-badge--amber  .db-urgency-badge-icon[b-ffu13ph2sz] { color: #d97706; }
.db-urgency-badge--orange .db-urgency-badge-icon[b-ffu13ph2sz] { color: #ea580c; }

.db-urgency-num[b-ffu13ph2sz] {
    font-size: 1.75rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.04em;
}
.db-urgency-badge--red    .db-urgency-num[b-ffu13ph2sz] { color: #dc2626; }
.db-urgency-badge--amber  .db-urgency-num[b-ffu13ph2sz] { color: #b45309; }
.db-urgency-badge--orange .db-urgency-num[b-ffu13ph2sz] { color: #c2410c; }

.db-urgency-lbl[b-ffu13ph2sz] {
    font-size: .625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    margin-top: .15rem;
}
.db-urgency-badge--red    .db-urgency-lbl[b-ffu13ph2sz] { color: #ef4444; }
.db-urgency-badge--amber  .db-urgency-lbl[b-ffu13ph2sz] { color: #d97706; }
.db-urgency-badge--orange .db-urgency-lbl[b-ffu13ph2sz] { color: #ea580c; }

/* ════════════════════════════════════════════════════
   PO URGENCY LIST
   ════════════════════════════════════════════════════ */
.db-po-list[b-ffu13ph2sz] {
    background: #fff;
    border: 1px solid var(--slate-100);
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

.db-po-row[b-ffu13ph2sz] {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .75rem 1.25rem .75rem 1.375rem;
    border-bottom: 1px solid var(--slate-50);
    transition: background .12s ease;
}

.db-po-row:last-child[b-ffu13ph2sz] { border-bottom: none; }

.db-po-row:hover[b-ffu13ph2sz] { background: var(--slate-50); }

/* left colored accent bar */
.db-po-accent[b-ffu13ph2sz] {
    position: absolute;
    left: 0; top: 20%; bottom: 20%;
    width: 3px;
    border-radius: 0 2px 2px 0;
}

.db-po-row--red   .db-po-accent[b-ffu13ph2sz] { background: #ef4444; }
.db-po-row--amber .db-po-accent[b-ffu13ph2sz] { background: #f59e0b; }

.db-po-info[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .2rem .35rem;
    font-size: .875rem;
}

.db-po-num[b-ffu13ph2sz]     { font-weight: 700; color: var(--slate-800); }
.db-po-sep[b-ffu13ph2sz]     { color: var(--slate-300); }
.db-po-factory[b-ffu13ph2sz] { color: var(--slate-500); }
.db-po-style[b-ffu13ph2sz]   { color: var(--slate-400); font-size: .8125rem; }

@media (max-width: 480px) {
    .db-po-sep--hide[b-ffu13ph2sz],  .db-po-style[b-ffu13ph2sz] { display: none; }
}

.db-po-tag[b-ffu13ph2sz] {
    font-size: .6875rem;
    font-weight: 700;
    padding: .2rem .7rem;
    border-radius: 999px;
    white-space: nowrap;
    flex-shrink: 0;
}

.db-po-tag--red[b-ffu13ph2sz]   { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.db-po-tag--amber[b-ffu13ph2sz] { background: #fffbeb; color: #92400e; border: 1px solid #fde68a; }

/* ── Group accordion header ── */
.db-group-header[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    gap: .625rem;
    padding: .75rem 1.25rem;
    border-bottom: 1px solid var(--slate-100);
    cursor: pointer;
    user-select: none;
    transition: background .12s ease;
}

.db-group-header:hover[b-ffu13ph2sz] { background: var(--slate-50); }

.db-group-header--red[b-ffu13ph2sz]   { border-left: 3px solid #ef4444; }
.db-group-header--amber[b-ffu13ph2sz] { border-left: 3px solid #f59e0b; }

.db-group-chevron[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    height: 1.25rem;
    font-size: .75rem;
    color: var(--slate-400);
    flex-shrink: 0;
    transition: transform .15s ease;
}

.db-group-info[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.db-group-style[b-ffu13ph2sz] {
    font-size: .8125rem;
    font-weight: 700;
    color: var(--slate-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.db-group-count[b-ffu13ph2sz] {
    font-size: .6875rem;
    font-weight: 600;
    color: var(--slate-400);
    background: var(--slate-100);
    padding: .125rem .5rem;
    border-radius: 999px;
    white-space: nowrap;
    flex-shrink: 0;
}

.db-group-tags[b-ffu13ph2sz] {
    display: flex;
    gap: .375rem;
    flex-shrink: 0;
}

/* ════════════════════════════════════════════════════
   URGENCY DETAIL MODAL
   ════════════════════════════════════════════════════ */
.db-modal-overlay[b-ffu13ph2sz] {
    position: fixed;
    inset: 0;
    z-index: 1000;
    background: rgba(15, 23, 42, .55);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    animation: db-overlay-in-b-ffu13ph2sz .2s ease-out;
}

@keyframes db-overlay-in-b-ffu13ph2sz {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.db-modal[b-ffu13ph2sz] {
    background: #fff;
    border-radius: 1.25rem;
    box-shadow: 0 24px 64px -12px rgba(0, 0, 0, .3);
    width: 100%;
    max-width: 720px;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    animation: db-modal-in-b-ffu13ph2sz .25s cubic-bezier(.16, 1, .3, 1);
}

@keyframes db-modal-in-b-ffu13ph2sz {
    from { opacity: 0; transform: translateY(16px) scale(.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.db-modal-header[b-ffu13ph2sz] {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 1.5rem 1.5rem 1rem;
    border-bottom: 1px solid var(--slate-100);
}

.db-modal-title[b-ffu13ph2sz] {
    font-size: 1.125rem;
    font-weight: 800;
    color: var(--slate-900);
    margin: 0;
    line-height: 1.3;
    letter-spacing: -.02em;
}

.db-modal-subtitle[b-ffu13ph2sz] {
    font-size: .75rem;
    color: var(--slate-400);
    font-weight: 500;
    margin: .25rem 0 0;
}

.db-modal-close[b-ffu13ph2sz] {
    background: none;
    border: none;
    width: 2rem;
    height: 2rem;
    border-radius: .5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--slate-400);
    cursor: pointer;
    transition: all .12s ease;
    flex-shrink: 0;
}

.db-modal-close:hover[b-ffu13ph2sz] {
    background: var(--slate-100);
    color: var(--slate-700);
}

.db-modal-badges[b-ffu13ph2sz] {
    display: flex;
    gap: .5rem;
    padding: .875rem 1.5rem;
    border-bottom: 1px solid var(--slate-50);
}

.db-modal-table-wrap[b-ffu13ph2sz] {
    overflow-y: auto;
    flex: 1;
}

.db-modal-table[b-ffu13ph2sz] {
    width: 100%;
    border-collapse: collapse;
    font-size: .8125rem;
}

.db-modal-table thead tr[b-ffu13ph2sz] {
    border-bottom: 1px solid var(--slate-100);
}

.db-modal-table th[b-ffu13ph2sz] {
    padding: .625rem 1.5rem;
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--slate-400);
    text-align: left;
    position: sticky;
    top: 0;
    background: #fff;
}

.db-modal-row[b-ffu13ph2sz] {
    border-bottom: 1px solid var(--slate-50);
    transition: background .1s ease;
}

.db-modal-row:last-child[b-ffu13ph2sz] { border-bottom: none; }
.db-modal-row:hover[b-ffu13ph2sz] { background: var(--slate-50); }

.db-modal-table td[b-ffu13ph2sz] {
    padding: .625rem 1.5rem;
}

.db-modal-po[b-ffu13ph2sz] {
    font-weight: 700;
    color: var(--slate-800);
}

.db-modal-factory[b-ffu13ph2sz] {
    color: var(--slate-500);
}

.db-modal-days[b-ffu13ph2sz] {
    font-weight: 800;
    font-variant-numeric: tabular-nums;
}

.db-modal-days--red[b-ffu13ph2sz]   { color: #dc2626; }
.db-modal-days--amber[b-ffu13ph2sz] { color: #b45309; }

/* ════════════════════════════════════════════════════
   CHARTS GRID
   ════════════════════════════════════════════════════ */
.db-charts-grid[b-ffu13ph2sz] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 1024px) {
    .db-charts-grid[b-ffu13ph2sz] { grid-template-columns: 1fr 1fr; }
}

.db-chart-card[b-ffu13ph2sz] {
    background: #fff;
    border: 1px solid var(--slate-100);
    border-radius: 1.125rem;
    overflow: hidden;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
    transition: box-shadow .18s ease;
}

.db-chart-card:hover[b-ffu13ph2sz] { box-shadow: 0 8px 24px -4px rgba(0,0,0,.09); }

.db-chart-header[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .875rem 1.375rem;
    border-bottom: 1px solid var(--slate-50);
}

.db-chart-title[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .8125rem;
    font-weight: 700;
    color: var(--slate-700);
}

.db-chart-icon[b-ffu13ph2sz] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: .5rem;
    font-size: .85rem;
}

.db-chart-icon--indigo[b-ffu13ph2sz] { background: #eef2ff; color: #6366f1; }
.db-chart-icon--violet[b-ffu13ph2sz] { background: #f5f3ff; color: #7c3aed; }

.db-chart-link[b-ffu13ph2sz] {
    font-size: .75rem;
    font-weight: 700;
    color: #6366f1;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: .25rem;
    transition: color .12s ease;
}
.db-chart-link:hover[b-ffu13ph2sz] { color: #4338ca; }
.db-chart-link .bi[b-ffu13ph2sz] { margin: 0; font-size: .7rem; }

.db-chart-body[b-ffu13ph2sz] { padding: 1.125rem 1.375rem; display: flex; flex-direction: column; gap: 1rem; }

/* ── Fiber rows ── */
.db-fiber-row[b-ffu13ph2sz] { display: flex; flex-direction: column; gap: .35rem; }

.db-fiber-meta[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.db-fiber-dot[b-ffu13ph2sz] {
    display: inline-block;
    width: .5625rem;
    height: .5625rem;
    border-radius: 50%;
    flex-shrink: 0;
}

.db-fiber-dot--teal[b-ffu13ph2sz]    { background: #2dd4bf; }
.db-fiber-dot--emerald[b-ffu13ph2sz] { background: #10b981; }
.db-fiber-dot--blue[b-ffu13ph2sz]    { background: #3b82f6; }
.db-fiber-dot--rose[b-ffu13ph2sz]    { background: #fb7185; }
.db-fiber-dot--amber[b-ffu13ph2sz]   { background: #f59e0b; }
.db-fiber-dot--violet[b-ffu13ph2sz]  { background: #8b5cf6; }
.db-fiber-dot--cyan[b-ffu13ph2sz]    { background: #06b6d4; }
.db-fiber-dot--orange[b-ffu13ph2sz]  { background: #f97316; }

.db-fiber-name[b-ffu13ph2sz] {
    flex: 1;
    font-size: .8125rem;
    font-weight: 600;
    color: var(--slate-600);
}

.db-fiber-pct[b-ffu13ph2sz] {
    font-size: .8125rem;
    font-weight: 800;
    color: var(--slate-800);
    font-variant-numeric: tabular-nums;
    min-width: 3rem;
    text-align: right;
}

.db-fiber-bar-track[b-ffu13ph2sz] {
    height: .45rem;
    background: var(--slate-100);
    border-radius: 999px;
    overflow: hidden;
}

.db-fiber-bar[b-ffu13ph2sz] {
    height: 100%;
    border-radius: 999px;
    transition: width .8s cubic-bezier(.16,1,.3,1) 0.1s;
}

.db-fiber-bar--teal[b-ffu13ph2sz]    { background: linear-gradient(90deg, #5eead4, #2dd4bf); }
.db-fiber-bar--emerald[b-ffu13ph2sz] { background: linear-gradient(90deg, #34d399, #10b981); }
.db-fiber-bar--blue[b-ffu13ph2sz]    { background: linear-gradient(90deg, #60a5fa, #3b82f6); }
.db-fiber-bar--rose[b-ffu13ph2sz]    { background: linear-gradient(90deg, #fda4af, #fb7185); }
.db-fiber-bar--amber[b-ffu13ph2sz]   { background: linear-gradient(90deg, #fcd34d, #f59e0b); }
.db-fiber-bar--violet[b-ffu13ph2sz]  { background: linear-gradient(90deg, #a78bfa, #8b5cf6); }
.db-fiber-bar--cyan[b-ffu13ph2sz]    { background: linear-gradient(90deg, #22d3ee, #06b6d4); }
.db-fiber-bar--orange[b-ffu13ph2sz]  { background: linear-gradient(90deg, #fb923c, #f97316); }

.db-chart-empty-note[b-ffu13ph2sz] {
    font-size: .6875rem;
    color: var(--slate-400);
    margin: .25rem 0 0;
    display: flex;
    align-items: center;
    gap: .35rem;
}

/* ── Materials table ── */
.db-table-wrap[b-ffu13ph2sz] { overflow-x: auto; }

.db-table[b-ffu13ph2sz] {
    width: 100%;
    border-collapse: collapse;
    font-size: .8125rem;
}

.db-table thead tr[b-ffu13ph2sz] {
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--slate-400);
    border-bottom: 1px solid var(--slate-100);
}

.db-table thead th[b-ffu13ph2sz] {
    padding: .6rem 1.375rem;
    font-weight: 700;
    text-align: left;
}

.db-th-r[b-ffu13ph2sz] { text-align: right !important; }

.db-tr[b-ffu13ph2sz] {
    border-bottom: 1px solid var(--slate-50);
    transition: background .1s ease;
}
.db-tr:last-child[b-ffu13ph2sz] { border-bottom: none; }
.db-tr:hover[b-ffu13ph2sz] { background: var(--slate-50); }

.db-table td[b-ffu13ph2sz] { padding: .7rem 1.375rem; vertical-align: middle; }

.db-td-fiber[b-ffu13ph2sz] {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-weight: 600;
    color: var(--slate-700);
}

.db-td-mono[b-ffu13ph2sz] {
    font-family: 'JetBrains Mono', monospace;
    color: var(--slate-500);
}

.db-td-r[b-ffu13ph2sz] { text-align: right; }

.db-share-pill[b-ffu13ph2sz] {
    display: inline-block;
    padding: .15rem .6rem;
    border-radius: 999px;
    background: var(--slate-100);
    color: var(--slate-600);
    font-size: .6875rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}
/* /Components/Pages/Factory/Factories.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════════
   FACTORIES — Scoped Premium Styles
   ═══════════════════════════════════════════════════════════════════ */

/* ── Hero Header ──────────────────────────────────────────────────── */
.fac-hero[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: linear-gradient(135deg, #eef2ff 0%, #f0fdf4 60%, #ffffff 100%);
    border: 1.5px solid #c7d2fe;
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.25rem;
    position: relative;
    overflow: hidden;
    animation: adminFadeIn 0.4s ease-out;
}

.fac-hero[b-h1mdpjx5xi]::before {
    content: "";
    position: absolute;
    top: -50px;
    right: -50px;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(99, 102, 241, 0.08) 0%, transparent 70%);
    pointer-events: none;
}

.fac-hero[b-h1mdpjx5xi]::after {
    content: "";
    position: absolute;
    bottom: -30px;
    left: 200px;
    width: 90px;
    height: 90px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16, 185, 129, 0.07) 0%, transparent 70%);
    pointer-events: none;
}

.fac-hero-left[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.fac-hero-badge[b-h1mdpjx5xi] {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    background: linear-gradient(135deg, #6366f1, #4f46e5);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 1.4rem;
    box-shadow: 0 4px 16px rgba(99, 102, 241, 0.35), 0 1px 3px rgba(0,0,0,0.1);
    flex-shrink: 0;
}

.fac-eyebrow[b-h1mdpjx5xi] {
    font-size: clamp(0.62rem, 0.8vw, 0.7rem);
    font-weight: 600;
    color: #6366f1;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0 0 4px 0;
    display: flex;
    align-items: center;
    gap: 5px;
}

.fac-title[b-h1mdpjx5xi] {
    font-size: clamp(1.1rem, 1.5vw, 1.35rem);
    font-weight: 700;
    color: #111827;
    margin: 0 0 4px 0;
    font-family: "Outfit", sans-serif;
    letter-spacing: -0.025em;
    line-height: 1.2;
}

.fac-sub[b-h1mdpjx5xi] {
    font-size: clamp(0.72rem, 0.9vw, 0.8rem);
    color: #9ca3af;
    margin: 0;
    font-weight: 400;
    max-width: 520px;
    line-height: 1.5;
}

.fac-hero-actions[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

.fac-action-btn[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* ── Stats Strip ──────────────────────────────────────────────────── */
.fac-stats[b-h1mdpjx5xi] {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
    animation: statSlideUp 0.45s ease-out backwards;
    animation-delay: 0.05s;
}

.fac-stat[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 0.85rem 1.25rem;
    min-width: 150px;
    transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
    position: relative;
    overflow: hidden;
}

.fac-stat:hover[b-h1mdpjx5xi] {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.07);
    transform: translateY(-1px);
}

.fac-stat-icon[b-h1mdpjx5xi] {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.fac-stat-val[b-h1mdpjx5xi] {
    font-size: clamp(1.1rem, 1.4vw, 1.35rem);
    font-family: "Outfit", sans-serif;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.03em;
    color: #0f172a;
}

.fac-stat-lbl[b-h1mdpjx5xi] {
    font-size: clamp(0.65rem, 0.8vw, 0.72rem);
    font-weight: 500;
    color: #64748b;
    margin-top: 2px;
}

/* Total — indigo */
.fac-stat--total[b-h1mdpjx5xi] { border-color: #e0e7ff; }
.fac-stat--total .fac-stat-icon[b-h1mdpjx5xi] { background: #eef2ff; color: #6366f1; }
.fac-stat--total .fac-stat-val[b-h1mdpjx5xi]  { color: #4f46e5; }

/* Success — emerald */
.fac-stat--success[b-h1mdpjx5xi] { border-color: #a7f3d0; }
.fac-stat--success .fac-stat-icon[b-h1mdpjx5xi] { background: #ecfdf5; color: #059669; }
.fac-stat--success .fac-stat-val[b-h1mdpjx5xi]  { color: #059669; }

/* Danger — red */
.fac-stat--danger[b-h1mdpjx5xi] { border-color: #fecaca; }
.fac-stat--danger .fac-stat-icon[b-h1mdpjx5xi] { background: #fef2f2; color: #ef4444; }
.fac-stat--danger .fac-stat-val[b-h1mdpjx5xi]  { color: #dc2626; }

/* ── Search Bar ───────────────────────────────────────────────────── */
.fac-search[b-h1mdpjx5xi] {
    position: relative;
    display: flex;
    align-items: center;
}

.fac-search-icon[b-h1mdpjx5xi] {
    position: absolute;
    left: 10px;
    color: #9ca3af;
    font-size: 0.8rem;
    pointer-events: none;
}

.fac-search-input[b-h1mdpjx5xi] {
    padding: 5px 10px 5px 30px;
    font-size: clamp(0.72rem, 0.85vw, 0.8rem);
    font-weight: 450;
    background: #f9fafb;
    border: 1.5px solid #e5e7eb;
    border-radius: 8px;
    height: 34px;
    color: #374151;
    min-width: 220px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
    outline: none;
}

.fac-search-input:focus[b-h1mdpjx5xi] {
    border-color: #6366f1;
    background: #ffffff;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.08);
}

.fac-search-input[b-h1mdpjx5xi]::placeholder {
    color: #d1d5db;
    font-weight: 400;
}

/* ── State Panels (Error / Empty / No Results) ────────────────────── */
.fac-state[b-h1mdpjx5xi] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3.75rem 1.5rem;
    text-align: center;
    gap: 0.375rem;
}

.fac-state-icon[b-h1mdpjx5xi] {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    margin-bottom: 0.625rem;
}

.fac-state-icon--error[b-h1mdpjx5xi] { background: #fef2f2; color: #dc2626; }
.fac-state-icon--empty[b-h1mdpjx5xi] { background: #eef2ff; color: #6366f1; }

.fac-state-title[b-h1mdpjx5xi] {
    font-size: clamp(0.85rem, 1vw, 0.95rem);
    font-weight: 600;
    color: #111827;
    font-family: "Outfit", sans-serif;
    margin: 0;
}

.fac-state-sub[b-h1mdpjx5xi] {
    font-size: clamp(0.74rem, 0.9vw, 0.82rem);
    color: #9ca3af;
    margin: 0;
    max-width: 380px;
    line-height: 1.55;
}

/* ── Table Cell Enhancements ──────────────────────────────────────── */
.fac-vendor[b-h1mdpjx5xi] {
    display: inline-block;
    font-size: clamp(0.65rem, 0.78vw, 0.72rem);
    font-weight: 700;
    color: #374151;
    background: #f3f4f6;
    padding: 2px 7px;
    border-radius: 4px;
    letter-spacing: 0.03em;
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, monospace;
    border: 1px solid #e5e7eb;
    white-space: nowrap;
}

.fac-name[b-h1mdpjx5xi] {
    font-weight: 600;
    color: #111827;
    font-size: clamp(0.74rem, 0.88vw, 0.82rem);
    line-height: 1.3;
}

.fac-email[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: clamp(0.7rem, 0.84vw, 0.78rem);
    color: #4f46e5;
    text-decoration: none;
    font-weight: 500;
    transition: color 0.15s ease;
    word-break: break-all;
}

.fac-email:hover[b-h1mdpjx5xi] {
    color: #4338ca;
    text-decoration: underline;
}

.fac-missing[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: clamp(0.7rem, 0.84vw, 0.78rem);
    font-weight: 600;
    color: #dc2626;
}

.fac-date[b-h1mdpjx5xi] {
    font-size: clamp(0.72rem, 0.86vw, 0.8rem);
    font-weight: 500;
    color: #374151;
}

.fac-meta[b-h1mdpjx5xi] {
    font-size: 0.75rem;
    color: #9ca3af;
    margin-top: 2px;
}

.fac-zero[b-h1mdpjx5xi] {
    color: #d1d5db;
    font-size: 0.8rem;
    font-weight: 400;
}

.fac-cert-number[b-h1mdpjx5xi] {
    display: inline-block;
    font-size: clamp(0.68rem, 0.82vw, 0.76rem);
    font-weight: 600;
    color: #374151;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    padding: 2px 7px;
    max-width: 140px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.fac-cert-expiry[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    font-size: clamp(0.66rem, 0.8vw, 0.74rem);
    font-weight: 700;
    border-radius: 999px;
    padding: 2px 7px;
    border: 1px solid transparent;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.fac-cert-expiry--ok[b-h1mdpjx5xi] {
    color: #166534;
    background: #ecfdf3;
    border-color: #bbf7d0;
}

.fac-cert-expiry--warning[b-h1mdpjx5xi] {
    color: #92400e;
    background: #fffbeb;
    border-color: #fde68a;
}

.fac-cert-expiry--expired[b-h1mdpjx5xi] {
    color: #991b1b;
    background: #fef2f2;
    border-color: #fecaca;
}

.fac-mills-cell[b-h1mdpjx5xi] {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.fac-mill-item[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    line-height: 1.2;
}

.fac-mill-item-name[b-h1mdpjx5xi] {
    font-size: clamp(0.7rem, 0.84vw, 0.78rem);
    font-weight: 600;
    color: #111827;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ── Mill Type Chips ─────────────────────────────────────────────── */
.fac-mill-item-type[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    font-size: clamp(0.58rem, 0.7vw, 0.65rem);
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 4px;
    white-space: nowrap;
    letter-spacing: 0.02em;
    flex-shrink: 0;
    background: #f1f5f9;
    color: #475569;
}

.fac-mill-chip--spinning[b-h1mdpjx5xi] {
    background: #dbeafe;
    color: #1d4ed8;
}

.fac-mill-chip--fabric[b-h1mdpjx5xi] {
    background: #dcfce7;
    color: #15803d;
}

.fac-mill-chip--dyeing[b-h1mdpjx5xi] {
    background: #fae8ff;
    color: #a21caf;
}

/* ── Name Cell ────────────────────────────────────────────────────── */
.fac-name-cell[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    min-width: 0;
}

/* ── NEW / UPDATED Activity Badges ───────────────────────────────── */
.fac-badge[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    padding: 2px 7px;
    border-radius: 999px;
    line-height: 1.6;
    flex-shrink: 0;
    text-transform: uppercase;
}

.fac-badge--new[b-h1mdpjx5xi] {
    background: #ecfdf5;
    color: #059669;
    border: 1px solid #a7f3d0;
}

.fac-badge--updated[b-h1mdpjx5xi] {
    background: #eef2ff;
    color: #6366f1;
    border: 1px solid #c7d2fe;
}

/* ── Keyframe ─────────────────────────────────────────────────────── */
@keyframes fac-spin-b-h1mdpjx5xi {
    to { transform: rotate(360deg); }
}

.fac-spin[b-h1mdpjx5xi] {
    animation: fac-spin-b-h1mdpjx5xi 0.75s linear infinite;
    display: inline-block;
}

/* ═══════════════════════════════════════════════════════════════════
   CREATE / EDIT FACTORY MODAL (CENTERED)
   ═══════════════════════════════════════════════════════════════════ */

@keyframes fac-drawer-pop-b-h1mdpjx5xi {
    from { opacity: 0; transform: translate(-50%, -48%) scale(0.96); }
    to   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

.fac-drawer-backdrop[b-h1mdpjx5xi] {
    position: fixed;
    inset: 0;
    background: rgba(17, 24, 39, 0.50);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 1050;
    animation: adminFadeIn 0.2s ease-out;
}

.fac-drawer[b-h1mdpjx5xi] {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1051;
    width: min(94vw, 860px);
    max-width: 860px;
    max-height: 90vh;
    background: #ffffff;
    border-radius: 20px;
    box-shadow: 0 36px 90px rgba(0, 0, 0, 0.24), 0 10px 28px rgba(79, 70, 229, 0.14);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1.5px solid #dbe1ff;
    animation: fac-drawer-pop-b-h1mdpjx5xi 0.24s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── Drawer Header ─────────────────────────────────────────────────── */
.fac-drawer-header[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.5rem;
    border-bottom: 1.5px solid #f3f4f6;
    background: linear-gradient(135deg, #f8f9ff 0%, #f0fdf4 100%);
    border-left: 4px solid #6366f1;
}

.fac-drawer-header-left[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.875rem;
}

.fac-drawer-icon[b-h1mdpjx5xi] {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, #6366f1, #4f46e5);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 1.15rem;
    box-shadow: 0 4px 14px rgba(99, 102, 241, 0.35);
    flex-shrink: 0;
}

.fac-drawer-title[b-h1mdpjx5xi] {
    font-size: 1.125rem;
    font-weight: 700;
    color: #111827;
    font-family: "Outfit", sans-serif;
    margin: 0 0 3px 0;
    letter-spacing: -0.02em;
}

.fac-drawer-editing-pill[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 999px;
    background: linear-gradient(135deg, #eef2ff 0%, #e0e7ff 100%);
    color: #4f46e5;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.fac-drawer-vendor-pill[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 999px;
    background: #eef2ff;
    border: 1px solid #c7d2fe;
    color: #4f46e5;
    font-size: 0.72rem;
    font-weight: 700;
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, monospace;
}

.fac-drawer-meta[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.fac-drawer-close[b-h1mdpjx5xi] {
    width: 32px;
    height: 32px;
    border: none;
    background: #f3f4f6;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6b7280;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
    flex-shrink: 0;
}

.fac-drawer-close:hover:not(:disabled)[b-h1mdpjx5xi] {
    background: #fee2e2;
    color: #dc2626;
}

.fac-drawer-close:disabled[b-h1mdpjx5xi] {
    opacity: 0.45;
    cursor: not-allowed;
}

/* ── Drawer Body ───────────────────────────────────────────────────── */
.fac-drawer-body[b-h1mdpjx5xi] {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    flex: 1;
    overflow-y: auto;
    background: #fcfcfd;
}

.fac-drawer-card[b-h1mdpjx5xi] {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    padding: 1.25rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.02);
}

.fac-drawer-alert[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 500;
    padding: 0.6rem 0.875rem;
    border-radius: 10px;
}

.fac-drawer-alert i[b-h1mdpjx5xi] {
    font-size: 1rem;
}

.fac-drawer-alert--success[b-h1mdpjx5xi] {
    background: #ecfdf5;
    color: #065f46;
    border: 1px solid #a7f3d0;
    border-left: 4px solid #10b981;
}

.fac-drawer-alert--error[b-h1mdpjx5xi] {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
    border-left: 4px solid #ef4444;
}

.fac-drawer-field[b-h1mdpjx5xi] {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 1rem;
}

.fac-drawer-field:last-child[b-h1mdpjx5xi] {
    margin-bottom: 0;
}

.fac-drawer-grid[b-h1mdpjx5xi] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 400px) {
    .fac-drawer-grid-2[b-h1mdpjx5xi] {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 1rem;
    }
}

.fac-drawer-label[b-h1mdpjx5xi] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #4b5563;
    letter-spacing: 0.04em;
}

.fac-drawer-input[b-h1mdpjx5xi] {
    width: 100%;
    padding: 10px 14px;
    font-size: 0.875rem;
    font-weight: 450;
    color: #111827;
    background: #ffffff;
    border: 1.5px solid #d1d5db;
    border-radius: 8px;
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    font-family: inherit;
}

.fac-drawer-input:focus[b-h1mdpjx5xi] {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
}

.fac-drawer-input--error[b-h1mdpjx5xi] {
    border-color: #f87171;
    background: #fff7f7;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.06);
}

/* Select */
.fac-drawer-select[b-h1mdpjx5xi] {
    appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, #6b7280 50%), linear-gradient(135deg, #6b7280 50%, transparent 50%);
    background-position: calc(100% - 18px) calc(50% + 1px), calc(100% - 13px) calc(50% + 1px);
    background-size: 5px 5px, 5px 5px;
    background-repeat: no-repeat;
    padding-right: 2.5rem;
}

.fac-drawer-select:disabled[b-h1mdpjx5xi] {
    background-color: #f3f4f6;
    color: #9ca3af;
    cursor: not-allowed;
}

.fac-drawer-select--placeholder[b-h1mdpjx5xi] {
    color: #9ca3af;
}

/* ── Section Headers ──────────────────────────────────────────────── */
.fac-drawer-section-header[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 1.25rem;
}

.fac-drawer-section-num[b-h1mdpjx5xi] {
    font-size: 0.65rem;
    font-weight: 800;
    background: #eef2ff;
    color: #6366f1;
    border-radius: 6px;
    padding: 3px 8px;
    letter-spacing: 0.05em;
}

.fac-drawer-section-title[b-h1mdpjx5xi] {
    font-size: 0.95rem;
    font-weight: 700;
    color: #111827;
}

/* ── Mill Selection Area ──────────────────────────────────────────── */
.fac-drawer-mills-wrap[b-h1mdpjx5xi] {
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 1rem;
}

.fac-drawer-mills-add-btn[b-h1mdpjx5xi] {
    width: 100%;
    height: 42px;
    border: 1px dashed #cbd5e1;
    background: #ffffff;
    color: #4f46e5;
    font-weight: 600;
    font-size: 0.85rem;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: all 0.2s ease;
    cursor: pointer;
}

.fac-drawer-mills-add-btn:hover[b-h1mdpjx5xi] {
    border-color: #6366f1;
    background: #eef2ff;
}

.fac-drawer-mill-preview[b-h1mdpjx5xi] {
    margin-top: 0.5rem;
    font-size: 0.75rem;
    color: #475569;
    padding: 0.5rem;
    background: #f1f5f9;
    border-radius: 6px;
    border-left: 3px solid #3b82f6;
}

.fac-drawer-mills-list[b-h1mdpjx5xi] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 1rem;
}

.fac-drawer-mills-list-header[b-h1mdpjx5xi] {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.fac-drawer-mills-list-header span[b-h1mdpjx5xi] {
    font-size: 0.78rem;
    font-weight: 700;
    color: #1f2937;
}

.fac-drawer-mills-list-header small[b-h1mdpjx5xi] {
    font-size: 0.68rem;
    color: #6b7280;
}

.fac-drawer-mill-card[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.6rem 0.7rem;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    transition: box-shadow 0.2s;
    border-left: 3px solid #9ca3af;
    gap: 0.5rem;
}

.fac-drawer-mill-card:hover[b-h1mdpjx5xi] {
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

.fac-mill-card--spinning[b-h1mdpjx5xi] { border-left-color: #6366f1; }
.fac-mill-card--fabric[b-h1mdpjx5xi] { border-left-color: #f59e0b; }
.fac-mill-card--dyeing[b-h1mdpjx5xi] { border-left-color: #14b8a6; }
.fac-mill-card--other[b-h1mdpjx5xi] { border-left-color: #9ca3af; }

.fac-drawer-mill-info[b-h1mdpjx5xi] {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.fac-drawer-mill-info--row[b-h1mdpjx5xi] {
    display: grid;
    grid-template-columns: minmax(150px, 1.35fr) minmax(110px, 0.9fr) minmax(120px, 1fr) minmax(170px, 1.25fr) minmax(130px, 1fr);
    align-items: center;
    column-gap: 0.6rem;
    min-width: 0;
    flex: 1;
}

.fac-drawer-mill-info strong[b-h1mdpjx5xi] {
    font-size: 0.98rem;
    color: #111827;
}

.fac-drawer-mill-name[b-h1mdpjx5xi] {
    min-width: 0;
    white-space: normal;
    overflow-wrap: anywhere;
}

.fac-drawer-mill-meta-row[b-h1mdpjx5xi] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
}

.fac-mill-type-pill[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 700;
    color: #4338ca;
    background: #eef2ff;
    border: 1px solid #c7d2fe;
}

.fac-drawer-mill-meta[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8rem;
    color: #64748b;
    min-width: 0;
    white-space: normal;
    overflow-wrap: anywhere;
    line-height: 1.3;
}

.fac-drawer-mill-meta i[b-h1mdpjx5xi] {
    flex-shrink: 0;
}


@media (max-width: 1200px) {
    .fac-drawer-mill-info--row[b-h1mdpjx5xi] {
        grid-template-columns: minmax(130px, 1.2fr) minmax(95px, 0.8fr) minmax(95px, 0.9fr) minmax(140px, 1.1fr) minmax(110px, 0.9fr);
        column-gap: 0.45rem;
    }

    .fac-drawer-mill-meta[b-h1mdpjx5xi] {
        font-size: 0.76rem;
    }

    .fac-mill-type-pill[b-h1mdpjx5xi] {
        font-size: 0.68rem;
    }
}

.fac-drawer-mill-extra[b-h1mdpjx5xi] {
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.fac-drawer-mill-extra span[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.8rem;
    color: #64748b;
    line-height: 1.4;
    word-break: break-word;
}

.fac-drawer-mill-remove[b-h1mdpjx5xi] {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    background: #fee2e2;
    color: #dc2626;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s, opacity 0.2s;
    opacity: 0.6;
    flex-shrink: 0;
}

.fac-drawer-mill-card:hover .fac-drawer-mill-remove[b-h1mdpjx5xi] {
    opacity: 1;
}

.fac-drawer-mill-remove:hover[b-h1mdpjx5xi] {
    background: #f87171;
    color: #ffffff;
}

/* ── Drawer Footer ─────────────────────────────────────────────────── */
.fac-drawer-footer[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1.25rem 1.5rem;
    border-top: 1.5px solid #e5e7eb;
    background: #ffffff;
    z-index: 10;
}

.fac-drawer-btn[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 10px 20px;
    border-radius: 8px;
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
    font-family: inherit;
}

.fac-drawer-btn:disabled[b-h1mdpjx5xi] {
    opacity: 0.55;
    cursor: not-allowed;
}

.fac-drawer-btn--cancel[b-h1mdpjx5xi] {
    background: #ffffff;
    color: #374151;
    border: 1px solid #d1d5db;
}

.fac-drawer-btn--cancel:hover:not(:disabled)[b-h1mdpjx5xi] {
    background: #f9fafb;
    border-color: #9ca3af;
}

.fac-drawer-btn--save[b-h1mdpjx5xi] {
    background: #6366f1;
    color: #ffffff;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.25);
}

.fac-drawer-btn--save:hover:not(:disabled)[b-h1mdpjx5xi] {
    background: #4f46e5;
    box-shadow: 0 4px 14px rgba(79, 70, 229, 0.35);
    transform: translateY(-1px);
}

.fac-drawer-spinner[b-h1mdpjx5xi] {
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.35);
    border-top-color: #ffffff;
    border-radius: 50%;
    animation: fac-spin-b-h1mdpjx5xi 0.65s linear infinite;
    display: inline-block;
    flex-shrink: 0;
}

.fac-vendor-readonly[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 42px;
    font-size: 0.8rem;
    font-weight: 600;
    color: #4338ca;
    background: #eef2ff;
    border: 1.5px solid #c7d2fe;
    border-radius: 9px;
    padding: 8px 12px;
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, monospace;
    letter-spacing: 0.04em;
}

.fac-vendor-readonly i[b-h1mdpjx5xi] {
    color: #6366f1;
}

/* ── Responsive ───────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .fac-drawer[b-h1mdpjx5xi] {
        width: calc(100% - 0.75rem);
        max-width: none;
        max-height: 92vh;
        border-radius: 14px;
    }
    .fac-drawer-grid-2[b-h1mdpjx5xi] {
        grid-template-columns: 1fr;
    }
}


/* ═══════════════════════════════════════════════════════════════════
   TABLE CARD STYLING
   ═════════════════════════════════════════════════════════════════ */

.table-card[b-h1mdpjx5xi] {
    background: #ffffff;
    border: 1.5px solid #e5e7eb;
    border-radius: 14px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.03);
    overflow: hidden;
    animation: adminFadeIn 0.4s ease-out;
    transition: box-shadow 0.2s ease;
}

.table-card:hover[b-h1mdpjx5xi] {
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
}

/* Table Card Header */
.table-card-header[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.5rem;
    background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
    border-bottom: 1.5px solid #f3f4f6;
    gap: 1rem;
    flex-wrap: wrap;
}

.table-header-left[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
    min-width: 200px;
}

.table-header-left i[b-h1mdpjx5xi] {
    font-size: 1.1rem;
}

.table-title[b-h1mdpjx5xi] {
    font-size: clamp(0.85rem, 1vw, 0.95rem);
    font-weight: 700;
    color: #111827;
    font-family: "Outfit", sans-serif;
    margin: 0;
    letter-spacing: -0.015em;
}

.record-count[b-h1mdpjx5xi] {
    display: inline-flex;
    align-items: center;
    font-size: clamp(0.68rem, 0.82vw, 0.75rem);
    font-weight: 600;
    color: #6b7280;
    background: #f3f4f6;
    padding: 3px 9px;
    border-radius: 6px;
    letter-spacing: 0.025em;
}

/* Table Container */
.table-container[b-h1mdpjx5xi] {
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
}

.table-container[b-h1mdpjx5xi]::-webkit-scrollbar {
    height: 6px;
}

.table-container[b-h1mdpjx5xi]::-webkit-scrollbar-track {
    background: #f9fafb;
}

.table-container[b-h1mdpjx5xi]::-webkit-scrollbar-thumb {
    background: #d1d5db;
    border-radius: 3px;
}

.table-container[b-h1mdpjx5xi]::-webkit-scrollbar-thumb:hover {
    background: #9ca3af;
}

/* Table Styles — .fac-table overrides admin-premium.css */
.fac-table[b-h1mdpjx5xi] {
    width: 100%;
    margin: 0;
    border-collapse: collapse;
    border-spacing: 0;
    font-size: clamp(0.74rem, 0.88vw, 0.82rem);
    table-layout: auto;
}

.fac-table thead[b-h1mdpjx5xi] {
    position: sticky;
    top: 0;
    z-index: 10;
}

.fac-table thead tr[b-h1mdpjx5xi] {
    background: #f9fafb;
    border-bottom: 1px solid #e5e7eb;
}

.fac-table th[b-h1mdpjx5xi] {
    padding: 0.5rem 0.65rem;
    text-align: left;
    font-size: clamp(0.62rem, 0.74vw, 0.7rem);
    font-weight: 700;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    background: #f9fafb;
    border: none;
    border-bottom: 1px solid #e5e7eb;
    white-space: nowrap;
}

/* Column widths — tuned so Actions can hold Login+Edit side-by-side */
.fac-table th:nth-child(1)[b-h1mdpjx5xi],
.fac-table td:nth-child(1)[b-h1mdpjx5xi] { width: 7%; }    /* Vendor */
.fac-table th:nth-child(2)[b-h1mdpjx5xi],
.fac-table td:nth-child(2)[b-h1mdpjx5xi] { width: 17%; }   /* Factory Name */
.fac-table th:nth-child(3)[b-h1mdpjx5xi],
.fac-table td:nth-child(3)[b-h1mdpjx5xi] { width: 11%; }   /* Mills */
.fac-table th:nth-child(4)[b-h1mdpjx5xi],
.fac-table td:nth-child(4)[b-h1mdpjx5xi] { width: 11%; }   /* Manufacturer */
.fac-table th:nth-child(5)[b-h1mdpjx5xi],
.fac-table td:nth-child(5)[b-h1mdpjx5xi] { width: 16%; }   /* Email */
.fac-table th:nth-child(6)[b-h1mdpjx5xi],
.fac-table td:nth-child(6)[b-h1mdpjx5xi] { width: 11%; }   /* Scope Certificate # */
.fac-table th:nth-child(7)[b-h1mdpjx5xi],
.fac-table td:nth-child(7)[b-h1mdpjx5xi] { width: 10%; }   /* Scope Expiry */
.fac-table th:nth-child(8)[b-h1mdpjx5xi],
.fac-table td:nth-child(8)[b-h1mdpjx5xi] { width: 17%; }   /* Actions */

.fac-table th:last-child[b-h1mdpjx5xi] {
    text-align: right;
}

.fac-table tbody tr[b-h1mdpjx5xi] {
    border-bottom: 1px solid #f3f4f6;
    transition: background-color 0.15s ease;
    background-color: #ffffff;
}

.fac-table tbody tr:hover[b-h1mdpjx5xi] {
    background-color: #fafbfc;
}

.fac-table tbody tr:last-child[b-h1mdpjx5xi] {
    border-bottom: none;
}

.fac-table tbody tr.row-past-due[b-h1mdpjx5xi] {
    background-color: #fffbeb;
}

.fac-table tbody tr.row-past-due:hover[b-h1mdpjx5xi] {
    background-color: #fef3c7;
}

.fac-table td[b-h1mdpjx5xi] {
    padding: 0.4rem 0.65rem;
    color: #374151;
    vertical-align: middle;
    border: none;
    border-bottom: 1px solid #f3f4f6;
}

.fac-table td.text-end[b-h1mdpjx5xi] {
    text-align: right;
}

/* Table Cell Content */
.fac-table tbody td[b-h1mdpjx5xi] {
    font-weight: 450;
    line-height: 1.35;
    font-size: clamp(0.74rem, 0.88vw, 0.82rem);
}

/* Link Button Group */
.link-btn-group[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: nowrap;
    justify-content: flex-end;
}

.link-btn-group .btn[b-h1mdpjx5xi] {
    font-size: clamp(0.63rem, 0.76vw, 0.72rem);
    padding: 3px 8px;
    border-radius: 5px;
    font-weight: 600;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.link-btn-group .btn-outline-success[b-h1mdpjx5xi] {
    color: #059669;
    border-color: #d1fae5;
    background-color: transparent;
}

.link-btn-group .btn-outline-success:hover[b-h1mdpjx5xi] {
    color: #047857;
    background-color: #ecfdf5;
    border-color: #a7f3d0;
    box-shadow: 0 2px 8px rgba(5, 150, 105, 0.15);
}

.link-btn-group .btn-outline-primary[b-h1mdpjx5xi] {
    color: #6366f1;
    border-color: #c7d2fe;
    background-color: transparent;
}

.link-btn-group .btn-outline-primary:hover[b-h1mdpjx5xi] {
    color: #4f46e5;
    background-color: #eef2ff;
    border-color: #a5b4fc;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.15);
}

/* Responsive Adjustments */
@media (max-width: 768px) {
    .fac-hero[b-h1mdpjx5xi] {
        flex-direction: column;
        align-items: flex-start;
    }

    .fac-stats[b-h1mdpjx5xi] {
        flex-direction: column;
    }

    .fac-col-span-2[b-h1mdpjx5xi], .fac-col-span-3[b-h1mdpjx5xi] {
        grid-column: span 1;
    }

    .table-card-header[b-h1mdpjx5xi] {
        flex-direction: column;
        align-items: stretch;
    }

    .table-header-left[b-h1mdpjx5xi] {
        width: 100%;
        min-width: unset;
    }

    .fac-search[b-h1mdpjx5xi] {
        width: 100%;
    }

    .fac-search-input[b-h1mdpjx5xi] {
        width: 100%;
        min-width: unset;
    }

    .fac-table th[b-h1mdpjx5xi] {
        padding: 0.4rem 0.5rem;
        font-size: 0.64rem;
    }

    .fac-table td[b-h1mdpjx5xi] {
        padding: 0.35rem 0.5rem;
        font-size: 0.76rem;
    }

    .link-btn-group .btn[b-h1mdpjx5xi] {
        font-size: 0.65rem;
        padding: 2px 6px;
        gap: 2px;
    }

    .link-btn-group .btn i[b-h1mdpjx5xi] {
        font-size: 0.85rem;
    }
}

/* ═══════════════════════════════════════════════════════════════════
   TABLE SORTING & PAGINATION
   ═════════════════════════════════════════════════════════════════ */

.sortable-th[b-h1mdpjx5xi] {
    cursor: pointer;
    user-select: none;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.fac-table .sortable-th:hover[b-h1mdpjx5xi] {
    background-color: #eef2ff;
    color: #4f46e5;
}

.sort-icon[b-h1mdpjx5xi] {
    font-size: 0.65rem;
    margin-left: 0.35rem;
    vertical-align: middle;
    transition: color 0.15s ease;
}

.fac-pagination[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.5rem;
    border-top: 1.5px solid #f3f4f6;
    background: #ffffff;
    flex-wrap: wrap;
    gap: 1rem;
}

.fac-page-info[b-h1mdpjx5xi] {
    font-size: clamp(0.7rem, 0.85vw, 0.78rem);
    color: #6b7280;
    font-weight: 500;
}

.fac-page-controls[b-h1mdpjx5xi] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.fac-page-btn[b-h1mdpjx5xi] {
    min-width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 8px;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    color: #374151;
    font-size: clamp(0.7rem, 0.85vw, 0.78rem);
    font-weight: 600;
    border-radius: 6px;
    transition: all 0.15s ease;
}

.fac-page-btn:hover:not(:disabled)[b-h1mdpjx5xi] {
    background: #f9fafb;
    border-color: #d1d5db;
    color: #111827;
}

.fac-page-btn--active[b-h1mdpjx5xi] {
    background: #eef2ff !important;
    border-color: #c7d2fe !important;
    color: #4f46e5 !important;
}

.fac-page-btn:disabled[b-h1mdpjx5xi] {
    opacity: 0.5;
    cursor: not-allowed;
    background: #f9fafb;
}

.fac-page-ellipsis[b-h1mdpjx5xi] {
    color: #9ca3af;
    padding: 0 4px;
    font-weight: 600;
}
/* /Components/Pages/Factory/FactoryActionRequired.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════════
   FACTORY ACTION REQUIRED — Scoped Premium Styles
   ═══════════════════════════════════════════════════════════════════ */

/* ── Hero Header ──────────────────────────────────────────────────── */
.far-hero[b-vlny8zqur2] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: linear-gradient(135deg, #fef2f2 0%, #fffbeb 55%, #ffffff 100%);
    border: 1.5px solid #fecaca;
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.25rem;
    position: relative;
    overflow: hidden;
    animation: adminFadeIn 0.4s ease-out;
}

.far-hero[b-vlny8zqur2]::before {
    content: "";
    position: absolute;
    top: -50px;
    right: -50px;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(239, 68, 68, 0.07) 0%, transparent 70%);
    pointer-events: none;
}

.far-hero[b-vlny8zqur2]::after {
    content: "";
    position: absolute;
    bottom: -30px;
    left: 180px;
    width: 90px;
    height: 90px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(245, 158, 11, 0.06) 0%, transparent 70%);
    pointer-events: none;
}

.far-hero-left[b-vlny8zqur2] {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.far-hero-badge[b-vlny8zqur2] {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    background: linear-gradient(135deg, #ef4444, #dc2626);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 1.4rem;
    box-shadow: 0 4px 16px rgba(239, 68, 68, 0.35), 0 1px 3px rgba(0,0,0,0.1);
    flex-shrink: 0;
}

.far-eyebrow[b-vlny8zqur2] {
    font-size: 0.6875rem;
    font-weight: 600;
    color: #ef4444;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0 0 4px 0;
    display: flex;
    align-items: center;
    gap: 5px;
}

.far-title[b-vlny8zqur2] {
    font-size: 1.3rem;
    font-weight: 700;
    color: #111827;
    margin: 0 0 4px 0;
    font-family: "Outfit", sans-serif;
    letter-spacing: -0.025em;
    line-height: 1.2;
}

.far-sub[b-vlny8zqur2] {
    font-size: 0.78rem;
    color: #9ca3af;
    margin: 0;
    font-weight: 400;
    max-width: 520px;
    line-height: 1.5;
}

.far-refresh-btn[b-vlny8zqur2] {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* ── Stats Strip ──────────────────────────────────────────────────── */
.far-stats[b-vlny8zqur2] {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
    animation: statSlideUp 0.45s ease-out backwards;
    animation-delay: 0.05s;
}

.far-stat[b-vlny8zqur2] {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    background: #ffffff;
    border: 1.5px solid #f3f4f6;
    border-radius: 10px;
    padding: 0.75rem 1.25rem;
    min-width: 158px;
    transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
    position: relative;
    overflow: hidden;
}

.far-stat:hover[b-vlny8zqur2] {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.07);
    transform: translateY(-1px);
}

.far-stat-icon[b-vlny8zqur2] {
    width: 42px;
    height: 42px;
    border-radius: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    flex-shrink: 0;
}

.far-stat-val[b-vlny8zqur2] {
    font-size: 1.6rem;
    font-family: "Outfit", sans-serif;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.04em;
}

.far-stat-lbl[b-vlny8zqur2] {
    font-size: 0.6875rem;
    font-weight: 600;
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 3px;
}

/* Total variant */
.far-stat--total[b-vlny8zqur2] {
    border-color: #e0e7ff;
}
.far-stat--total .far-stat-icon[b-vlny8zqur2] {
    background: #eef2ff;
    color: #6366f1;
}
.far-stat--total .far-stat-val[b-vlny8zqur2] {
    color: #4f46e5;
}

/* Danger variant (Missing Email) */
.far-stat--danger[b-vlny8zqur2] {
    border-color: #fecaca;
}
.far-stat--danger .far-stat-icon[b-vlny8zqur2] {
    background: #fef2f2;
    color: #ef4444;
}
.far-stat--danger .far-stat-val[b-vlny8zqur2] {
    color: #dc2626;
}

/* Warning variant (Factory Missing) */
.far-stat--warning[b-vlny8zqur2] {
    border-color: #fde68a;
}
.far-stat--warning .far-stat-icon[b-vlny8zqur2] {
    background: #fffbeb;
    color: #f59e0b;
}
.far-stat--warning .far-stat-val[b-vlny8zqur2] {
    color: #d97706;
}

/* ── States (Loading / Empty / Error) ─────────────────────────────── */
.far-state[b-vlny8zqur2] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3.75rem 1.5rem;
    text-align: center;
    gap: 0.375rem;
}

.far-spinner[b-vlny8zqur2] {
    display: inline-block;
    width: 22px;
    height: 22px;
    border: 2.5px solid #c7d2fe;
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: far-spin-b-vlny8zqur2 0.7s linear infinite;
}

.far-state-icon[b-vlny8zqur2] {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    margin-bottom: 0.625rem;
}

.far-state-icon--success[b-vlny8zqur2] {
    background: #ecfdf5;
    color: #059669;
}

.far-state-icon--error[b-vlny8zqur2] {
    background: #fef2f2;
    color: #dc2626;
}

.far-state-title[b-vlny8zqur2] {
    font-size: 0.9375rem;
    font-weight: 600;
    color: #111827;
    font-family: "Outfit", sans-serif;
    margin: 0;
}

.far-state-sub[b-vlny8zqur2] {
    font-size: 0.8rem;
    color: #9ca3af;
    margin: 0;
    max-width: 380px;
    line-height: 1.55;
}

/* ── Table Cell Enhancements ──────────────────────────────────────── */
.far-vendor[b-vlny8zqur2] {
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 700;
    color: #374151;
    background: #f3f4f6;
    padding: 3px 9px;
    border-radius: 6px;
    letter-spacing: 0.05em;
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, monospace;
    border: 1px solid #e5e7eb;
}

.far-factory[b-vlny8zqur2] {
    font-weight: 500;
    color: #374151;
}

.far-missing[b-vlny8zqur2] {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.75rem;
    font-weight: 600;
    color: #dc2626;
}

.far-email[b-vlny8zqur2] {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.78rem;
    color: #4f46e5;
    text-decoration: none;
    font-weight: 500;
    transition: color 0.15s ease;
}

.far-email:hover[b-vlny8zqur2] {
    color: #4338ca;
    text-decoration: underline;
}

.far-zero[b-vlny8zqur2] {
    color: #d1d5db;
    font-size: 1rem;
    font-weight: 500;
}

/* ── Keyframes ────────────────────────────────────────────────────── */
@keyframes far-spin-b-vlny8zqur2 {
    to { transform: rotate(360deg); }
}

.far-spin[b-vlny8zqur2] {
    animation: far-spin-b-vlny8zqur2 0.75s linear infinite;
    display: inline-block;
}

/* ── Fix Factory Modal ────────────────────────────────────────────── */
.far-modal-backdrop[b-vlny8zqur2] {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 1050;
    animation: adminFadeIn 0.2s ease-out;
}

.far-modal[b-vlny8zqur2] {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1051;
    width: calc(100% - 2rem);
    max-width: 460px;
    background: #ffffff;
    border-radius: 16px;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.06),
        0 8px 24px rgba(0, 0, 0, 0.12),
        0 32px 56px -16px rgba(0, 0, 0, 0.22);
    animation: far-modal-in-b-vlny8zqur2 0.25s cubic-bezier(0.34, 1.4, 0.64, 1);
    overflow: hidden;
}

@keyframes far-modal-in-b-vlny8zqur2 {
    from { opacity: 0; transform: translate(-50%, -46%) scale(0.94); }
    to   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

/* Header */
.far-modal-header[b-vlny8zqur2] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid #f3f4f6;
    background: #f9fafb;
}

.far-modal-header-left[b-vlny8zqur2] {
    display: flex;
    align-items: center;
    gap: 0.875rem;
    min-width: 0;
}

.far-modal-icon[b-vlny8zqur2] {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    flex-shrink: 0;
}

.far-modal-icon--danger[b-vlny8zqur2]  { background: #fef2f2; color: #ef4444; }
.far-modal-icon--warning[b-vlny8zqur2] { background: #fffbeb; color: #f59e0b; }

.far-modal-title[b-vlny8zqur2] {
    font-size: 0.9375rem;
    font-weight: 700;
    color: #111827;
    margin: 0 0 5px 0;
    font-family: "Outfit", sans-serif;
    letter-spacing: -0.01em;
}

.far-modal-meta[b-vlny8zqur2] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.far-modal-close[b-vlny8zqur2] {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    border: 1.5px solid #e5e7eb;
    background: #ffffff;
    color: #9ca3af;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.15s ease;
    font-size: 0.8rem;
    flex-shrink: 0;
}

.far-modal-close:hover:not(:disabled)[b-vlny8zqur2] {
    background: #fef2f2;
    color: #ef4444;
    border-color: #fecaca;
}

/* Body */
.far-modal-body[b-vlny8zqur2] {
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.far-modal-alert[b-vlny8zqur2] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 500;
    padding: 0.625rem 0.875rem;
    border-radius: 9px;
    line-height: 1.45;
}

.far-modal-alert--success[b-vlny8zqur2] {
    background: #ecfdf5;
    color: #065f46;
    border: 1px solid #a7f3d0;
}

.far-modal-alert--error[b-vlny8zqur2] {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

.far-modal-field[b-vlny8zqur2] {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.far-modal-label[b-vlny8zqur2] {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #374151;
}

.far-required[b-vlny8zqur2] {
    color: #ef4444;
}

.far-vendor-readonly[b-vlny8zqur2] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.78rem;
    font-weight: 700;
    color: #374151;
    background: #f3f4f6;
    padding: 7px 12px;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
    font-family: "JetBrains Mono", "Fira Code", ui-monospace, monospace;
    letter-spacing: 0.04em;
    width: fit-content;
}

.far-modal-input[b-vlny8zqur2] {
    width: 100%;
    padding: 0.5rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 450;
    color: #374151;
    background: #ffffff;
    border: 1.5px solid #e5e7eb;
    border-radius: 9px;
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    box-sizing: border-box;
    font-family: "Inter", sans-serif;
}

.far-modal-input:focus[b-vlny8zqur2] {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.far-modal-input--error[b-vlny8zqur2] {
    border-color: #ef4444 !important;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
}

.far-modal-info[b-vlny8zqur2] {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.78rem;
    color: #4f46e5;
    background: #eef2ff;
    border: 1px solid #e0e7ff;
    border-radius: 9px;
    padding: 0.625rem 0.875rem;
    line-height: 1.5;
}

/* Footer */
.far-modal-footer[b-vlny8zqur2] {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 0.875rem 1.25rem;
    border-top: 1px solid #f3f4f6;
    background: #f9fafb;
}

.far-modal-btn[b-vlny8zqur2] {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0.5rem 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    border-radius: 9px;
    border: none;
    cursor: pointer;
    transition: all 0.18s ease;
    font-family: "Inter", sans-serif;
    line-height: 1.4;
}

.far-modal-btn:disabled[b-vlny8zqur2] {
    opacity: 0.55;
    cursor: not-allowed;
}

.far-modal-btn--cancel[b-vlny8zqur2] {
    background: #ffffff;
    color: #6b7280;
    border: 1.5px solid #e5e7eb;
}

.far-modal-btn--cancel:hover:not(:disabled)[b-vlny8zqur2] {
    background: #f9fafb;
    color: #374151;
    border-color: #d1d5db;
}

.far-modal-btn--save[b-vlny8zqur2] {
    background: #4f46e5;
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.28);
}

.far-modal-btn--save:hover:not(:disabled)[b-vlny8zqur2] {
    background: #4338ca;
    box-shadow: 0 4px 14px rgba(99, 102, 241, 0.4);
    transform: translateY(-1px);
}
/* /Components/Pages/Factory/FactoryDashboard.razor.rz.scp.css */
/* Factory Dashboard - All styling handled via Tailwind utility classes in the markup */
/* /Components/Pages/Factory/FactoryLogin.razor.rz.scp.css */
/* =================================================================
   PREMIUM FACTORY LOGIN PAGE
   ================================================================= */

.factory-login-wrapper[b-phl34ske8p] {
    /* Local variable definitions for premium aesthetic */
    --emerald-50: #ecfdf5;
    --emerald-200: #a7f3d0;
    --emerald-300: #6ee7b7;
    --emerald-500: #10b981;
    --emerald-600: #059669;
    --emerald-700: #047857;
    --teal-800: #115e59;
    --slate-50: #f8fafc;
    --slate-200: #e2e8f0;
    --slate-300: #cbd5e1;
    --slate-400: #94a3b8;
    --slate-500: #64748b;
    --slate-700: #334155;
    --slate-900: #0f172a;
    --bg-surface: #ffffff;

    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;

    --font-xs: 0.75rem;
    --font-sm: 0.875rem;
    --font-base: 1rem;
    --font-lg: 1.125rem;
    --font-xl: 1.25rem;
    --font-3xl: 1.875rem;

    min-height: calc(100vh - 80px); /* Adjust based on your header */
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    background: var(--slate-50);
}

/* Split Card Container */
.login-split-card[b-phl34ske8p] {
    display: flex;
    width: 100%;
    max-width: 1100px;
    background: var(--bg-surface);
    border-radius: 24px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0,0,0,0.02);
    overflow: hidden;
    animation: slideUpFade-b-phl34ske8p 0.7s cubic-bezier(0.16, 1, 0.3, 1);
    min-height: 600px;
}

/* Right Form Side */
.login-form-area[b-phl34ske8p] {
    flex: 1;
    padding: var(--space-12) var(--space-10);
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 500px;
}

.login-header[b-phl34ske8p] {
    margin-bottom: var(--space-6);
}

.login-header h3[b-phl34ske8p] {
    font-size: var(--font-3xl);
    font-weight: 800;
    color: var(--slate-900);
    margin: 0 0 var(--space-2);
    letter-spacing: -0.02em;
}

.login-header p[b-phl34ske8p] {
    font-size: var(--font-base);
    color: var(--slate-500);
    margin: 0;
}

/* Left Visual Side */
.login-visual[b-phl34ske8p] {
    flex: 1.2;
    position: relative;
    background: linear-gradient(135deg, var(--emerald-600), var(--teal-800));
    padding: var(--space-12);
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: white;
    overflow: hidden;
}

.visual-overlay[b-phl34ske8p] {
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 100% 100%, rgba(255,255,255,0.1) 0%, transparent 50%),
                      radial-gradient(circle at 0% 0%, rgba(0,0,0,0.2) 0%, transparent 50%);
    z-index: 1;
}

.visual-content[b-phl34ske8p] {
    position: relative;
    z-index: 10;
    max-width: 420px;
}

.brand-badge[b-phl34ske8p] {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(8px);
    padding: var(--space-2) var(--space-4);
    border-radius: 100px;
    font-size: var(--font-sm);
    font-weight: 600;
    margin-bottom: var(--space-8);
    border: 1px solid rgba(255,255,255,0.2);
}

.visual-content h2[b-phl34ske8p] {
    font-size: 3rem;
    font-weight: 800;
    line-height: 1.1;
    margin: 0 0 var(--space-4);
    letter-spacing: -0.03em;
    color: white;
}

.visual-content p[b-phl34ske8p] {
    font-size: var(--font-lg);
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.6;
    margin-bottom: var(--space-8);
}

.features-list[b-phl34ske8p] {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.feature-item[b-phl34ske8p] {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--font-base);
    font-weight: 500;
    color: rgba(255, 255, 255, 0.95);
}

.feature-item i[b-phl34ske8p] {
    font-size: 1.25rem;
    color: var(--emerald-300);
}

/* Abstract glassmorphic shapes */
.visual-shapes[b-phl34ske8p] {
    position: absolute;
    inset: 0;
    z-index: 2;
    overflow: hidden;
    pointer-events: none;
}

.shape[b-phl34ske8p] {
    position: absolute;
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 50%;
}

.shape-1[b-phl34ske8p] {
    width: 300px;
    height: 300px;
    top: -100px;
    right: -100px;
}

.shape-2[b-phl34ske8p] {
    width: 400px;
    height: 400px;
    bottom: -150px;
    right: 10%;
}

.shape-3[b-phl34ske8p] {
    width: 150px;
    height: 150px;
    bottom: 20%;
    left: -50px;
}

/* Form Styles */
.login-body[b-phl34ske8p] {
    position: relative;
}

.form-group[b-phl34ske8p] {
    margin-bottom: var(--space-5);
}

.form-label[b-phl34ske8p] {
    font-weight: 600;
    color: var(--slate-700);
    font-size: var(--font-sm);
    margin-bottom: var(--space-2);
    display: block;
}

.input-with-icon[b-phl34ske8p] {
    position: relative;
    transition: all 0.2s ease;
}

.input-with-icon i[b-phl34ske8p] {
    position: absolute;
    left: var(--space-4);
    top: 50%;
    transform: translateY(-50%);
    color: var(--slate-400);
    font-size: 1.1rem;
    z-index: 1;
    transition: color 0.2s;
}

.input-with-icon .form-control[b-phl34ske8p] {
    padding-left: 2.75rem;
    height: 54px;
    font-size: var(--font-base);
    border-radius: 12px;
    background: var(--slate-50);
    border: 1px solid var(--slate-200);
    transition: all 0.2s ease;
}

.input-with-icon .form-control:focus[b-phl34ske8p] {
    background: white;
    border-color: var(--emerald-500);
    box-shadow: 0 0 0 4px var(--emerald-50);
}

.input-with-icon .form-control:focus ~ i[b-phl34ske8p] {
    color: var(--emerald-600);
}

.btn-login[b-phl34ske8p] {
    height: 54px;
    border-radius: 12px;
    font-weight: 600;
    font-size: var(--font-base);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    background: var(--slate-900);
    border: none;
    color: white;
    transition: all 0.2s ease;
}

.btn-login:hover:not(:disabled)[b-phl34ske8p] {
    background: var(--emerald-700);
    transform: translateY(-1px);
    box-shadow: 0 10px 15px -3px rgba(5, 150, 105, 0.2);
}

.btn-login i[b-phl34ske8p] {
    font-size: 1.1rem;
    transition: transform 0.2s;
}

.btn-login:hover i[b-phl34ske8p] {
    transform: translateX(4px);
}

.full-width[b-phl34ske8p] {
    width: 100%;
}

.secure-footer[b-phl34ske8p] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    margin-top: var(--space-6);
    color: var(--emerald-700);
    font-size: var(--font-xs);
    font-weight: 500;
}

.secure-footer i[b-phl34ske8p] {
    color: var(--emerald-500);
}

/* OTP Specific */
.otp-container[b-phl34ske8p] {
    text-align: center;
    margin-top: var(--space-4);
}

.otp-header[b-phl34ske8p] {
    margin-bottom: var(--space-6);
}

.otp-icon-wrap[b-phl34ske8p] {
    width: 56px;
    height: 56px;
    background: var(--emerald-50);
    color: var(--emerald-600);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    margin: 0 auto var(--space-4);
    box-shadow: 0 4px 6px -1px var(--emerald-50);
}

.otp-header h4[b-phl34ske8p] {
    font-size: var(--font-xl);
    font-weight: 800;
    color: var(--slate-900);
    margin: 0 0 var(--space-2);
}

.otp-header p[b-phl34ske8p] {
    color: var(--slate-500);
    font-size: var(--font-sm);
}

.otp-input-wrap .form-control[b-phl34ske8p] {
    text-align: center;
    font-size: var(--font-xl);
    font-weight: 700;
    padding-left: 1rem; /* Adjust since icon is there */
    letter-spacing: 0.25em;
    color: var(--slate-900);
}

.otp-input-wrap .form-control[b-phl34ske8p]::placeholder {
    letter-spacing: normal;
    font-size: var(--font-base);
    color: var(--slate-400);
    font-weight: 500;
}

.action-link[b-phl34ske8p] {
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--emerald-600);
    text-decoration: none;
    transition: color 0.2s;
}

.action-link:hover[b-phl34ske8p] {
    color: var(--emerald-700);
    text-decoration: underline;
}

.divider[b-phl34ske8p] {
    color: var(--slate-300);
}

/* Alerts */
.custom-alert[b-phl34ske8p] {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    border: none;
    border-radius: 12px;
    padding: var(--space-3) var(--space-4);
    font-size: var(--font-sm);
    font-weight: 500;
}

/* Animations */
@keyframes slideUpFade-b-phl34ske8p {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in[b-phl34ske8p] {
    animation: fadeIn-b-phl34ske8p 0.4s ease-out forwards;
}

.slide-in[b-phl34ske8p] {
    animation: slideIn-b-phl34ske8p 0.3s ease-out forwards;
}

@keyframes fadeIn-b-phl34ske8p {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideIn-b-phl34ske8p {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 900px) {
    .login-split-card[b-phl34ske8p] {
        flex-direction: column;
        min-height: auto;
    }
    
    .login-visual[b-phl34ske8p] {
        padding: var(--space-8) var(--space-6);
    }
    
    .visual-content h2[b-phl34ske8p] {
        font-size: 2rem;
    }
    
    .login-form-area[b-phl34ske8p] {
        padding: var(--space-8) var(--space-6);
        max-width: 100%;
    }
}
/* /Components/Pages/Factory/FactorySurvey.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════
   Survey.razor.css  –  Premium Redesigned Survey UI
   Focus: Clarity, usability, beautiful visual hierarchy
   ═══════════════════════════════════════════════════════════ */

/* ── Page wrapper ──────────────────────────────────────── */
.airtable-page[b-ofbqm5tp9c] {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: #FAFBFC; 
    height: calc(100vh - 95px); /* Adjusted for actual top nav height so the horizontal scrollbar isn't pushed off-screen */
    display: flex;
    flex-direction: column;
    overflow: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ── State overlays (error / locked / success) ─────────── */
.state-overlay[b-ofbqm5tp9c] {
    display: flex; justify-content: center; align-items: center;
    min-height: 80vh; padding: 2rem;
}
.state-card[b-ofbqm5tp9c] {
    background: #fff; border-radius: 20px;
    padding: 3rem 3.5rem; max-width: 540px; width: 100%;
    box-shadow: 0 8px 40px rgba(0,0,0,.08), 0 0 0 1px rgba(0,0,0,.04);
    text-align: center;
}
.state-card h3[b-ofbqm5tp9c] { font-size: clamp(1.25rem, 1.1rem + 0.6vw, 1.5rem); font-weight: 700; margin: 1.2rem 0 .6rem; color: #0f172a; }
.state-card p[b-ofbqm5tp9c]  { color: #64748b; margin-bottom: 1.5rem; font-size: clamp(.85rem, .8rem + .25vw, .95rem); line-height: 1.6; }
.state-icon-wrap[b-ofbqm5tp9c] { font-size: 3.2rem; margin-bottom: .5rem; }
.success-icon[b-ofbqm5tp9c] { color: #22c55e; }
.error-icon[b-ofbqm5tp9c]   { color: #ef4444; }
.state-help[b-ofbqm5tp9c] {
    display: flex; gap: .75rem; background: #f8fafc; border-radius: 12px;
    padding: 1.2rem; text-align: left; font-size: .875rem; color: #475569;
    border: 1px solid #e2e8f0;
}

/* ── Success submission summary ────────────────────────── */
.submission-summary-grid[b-ofbqm5tp9c] { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-top: 1.5rem; text-align: left; }
.sum-item[b-ofbqm5tp9c] { background: #f8fafc; border-radius: 10px; padding: .85rem 1rem; border: 1px solid #e2e8f0; }
.sum-label[b-ofbqm5tp9c] { display: block; font-size: .7rem; font-weight: 600; color: #94a3b8; text-transform: uppercase; letter-spacing: .05em; }
.sum-val[b-ofbqm5tp9c]   { font-size: .95rem; font-weight: 600; color: #1e293b; }
.sum-val.highlight[b-ofbqm5tp9c] { color: #0ea5e9; }

/* ── Toast ─────────────────────────────────────────────── */
.at-toast[b-ofbqm5tp9c] {
    position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 9999;
    background: linear-gradient(135deg, #16a34a, #15803d); color: #fff;
    padding: .85rem 1.5rem;
    border-radius: 12px; font-size: .875rem; font-weight: 600;
    display: flex; align-items: center; gap: .5rem;
    box-shadow: 0 8px 24px rgba(22,163,74,.4);
    animation: slideUp-b-ofbqm5tp9c .35s cubic-bezier(.22,1,.36,1);
}
@keyframes slideUp-b-ofbqm5tp9c {
    from { transform: translateY(20px); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}

/* ══════════════════════════════════════════════════════════
   SITE HEADER  –  Light, minimal, compact design
══════════════════════════════════════════════════════════ */
.sv-header[b-ofbqm5tp9c] {
    background: #ffffff;
    z-index: 120;
    box-shadow: 0 4px 15px rgba(0,0,0,.03), 0 1px 0 #e2e8f0;
    flex-shrink: 0;
}

/* Top row: PO info + actions */
.sv-header-inner[b-ofbqm5tp9c] {
    display: flex; align-items: center; justify-content: space-between;
    padding: clamp(.5rem, .35rem + .5vw, .65rem) clamp(.75rem, .25rem + 1.6vw, 1.5rem);
    gap: clamp(.5rem, .3rem + .7vw, 1rem);
    flex-wrap: wrap;
}
.sv-header-left[b-ofbqm5tp9c]  { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }
.sv-header-right[b-ofbqm5tp9c] { display: flex; align-items: center; gap: .6rem; flex-shrink: 0; }

.sv-breadcrumb[b-ofbqm5tp9c] {
    font-size: .65rem; font-weight: 700; color: #10b981;
    text-transform: uppercase; letter-spacing: .08em;
    display: flex; align-items: center; gap: .4rem;
}
.sv-breadcrumb[b-ofbqm5tp9c]::before {
    content: '';
    width: 6px; height: 6px; border-radius: 50%;
    background: #10b981;
    box-shadow: 0 0 6px rgba(16,185,129,.4);
    animation: pulse-glow-b-ofbqm5tp9c 2s ease infinite;
}
@keyframes pulse-glow-b-ofbqm5tp9c {
    0%, 100% { opacity: 1; box-shadow: 0 0 6px rgba(16,185,129,.4); }
    50%      { opacity: .6; box-shadow: 0 0 3px rgba(16,185,129,.2); }
}

.sv-po-row[b-ofbqm5tp9c] {
    display: flex; align-items: center; gap: .65rem; flex-wrap: wrap;
}
.sv-po-num[b-ofbqm5tp9c] {
    font-size: clamp(.9rem, .75rem + .7vw, 1.05rem); font-weight: 800; color: #1e293b;
    letter-spacing: -.01em;
}
.sv-pipe[b-ofbqm5tp9c] {
    width: 1px; height: 16px;
    background: #cbd5e1; flex-shrink: 0;
}
.sv-factory[b-ofbqm5tp9c] {
    font-size: .85rem; font-weight: 600; color: #64748b;
}
.sv-meta[b-ofbqm5tp9c] {
    display: flex; align-items: center; gap: .3rem;
    font-size: clamp(.68rem, .63rem + .2vw, .75rem); color: #64748b;
    background: #f1f5f9;
    padding: .2rem .5rem; border-radius: 6px;
    border: 1px solid #e2e8f0;
}
.sv-meta i[b-ofbqm5tp9c] { font-size: .72rem; color: #94a3b8; }

/* Guide text for users */
.sv-guide-text[b-ofbqm5tp9c] {
    font-size: clamp(.64rem, .6rem + .2vw, .7rem); color: #64748b; font-weight: 400;
}

/* Garment weight in header – compact light style */
.sv-gw-block[b-ofbqm5tp9c] {
    display: flex; flex-direction: column; gap: .15rem;
    background: #f8fafc;
    padding: .35rem .6rem; border-radius: 8px;
    border: 1px solid #e2e8f0;
}
.sv-gw-label[b-ofbqm5tp9c] {
    font-size: .55rem; font-weight: 700; color: #64748b;
    text-transform: uppercase; letter-spacing: .05em;
}
.sv-gw-input-wrap[b-ofbqm5tp9c] {
    display: flex; align-items: center; overflow: hidden;
    border: 1px solid #cbd5e1; border-radius: 6px;
    background: #fff;
    transition: all .2s;
}
.sv-gw-input-wrap:focus-within[b-ofbqm5tp9c] {
    border-color: #6366f1; box-shadow: 0 0 0 2px rgba(99,102,241,.15);
}
.sv-gw-input[b-ofbqm5tp9c] {
    border: none; outline: none; background: transparent;
    font-size: clamp(.72rem, .64rem + .3vw, .8rem); font-weight: 600; padding: .25rem .45rem;
    width: clamp(52px, 7vw, 60px); color: #1e293b; font-family: inherit;
}
.sv-gw-input[b-ofbqm5tp9c]::-webkit-outer-spin-button,
.sv-gw-input[b-ofbqm5tp9c]::-webkit-inner-spin-button { -webkit-appearance: none; }
.sv-gw-input[b-ofbqm5tp9c]::placeholder { color: #cbd5e1; }
.sv-gw-unit[b-ofbqm5tp9c] {
    padding: .25rem .4rem; font-size: clamp(.58rem, .54rem + .2vw, .65rem); color: #64748b; font-weight: 600;
    border-left: 1px solid #e2e8f0; white-space: nowrap; background: #f8fafc;
}

/* Header buttons — styled for light theme */
.sv-btn[b-ofbqm5tp9c] {
    display: inline-flex; align-items: center; gap: .4rem;
    font-size: clamp(.7rem, .62rem + .3vw, .78rem); font-weight: 600;
    padding: clamp(.38rem, .3rem + .25vw, .45rem) clamp(.75rem, .55rem + .6vw, .9rem);
    border-radius: 8px; border: none; cursor: pointer;
    font-family: inherit; transition: all .2s cubic-bezier(.22,1,.36,1);
    white-space: nowrap;
}
.sv-btn-ghost[b-ofbqm5tp9c] {
    background: #fff;
    color: #475569;
    border: 1px solid #cbd5e1;
}
.sv-btn-ghost:hover[b-ofbqm5tp9c] {
    background: #f8fafc; color: #1e293b;
    border-color: #94a3b8;
    transform: translateY(-1px); box-shadow: 0 2px 5px rgba(0,0,0,.04);
}
.sv-btn-primary[b-ofbqm5tp9c] {
    background: linear-gradient(135deg, #10b981, #059669);
    color: #fff; font-weight: 700; border: 1px solid #047857;
    box-shadow: 0 2px 8px rgba(16,185,129,.2), 0 1px 0 rgba(255,255,255,.2) inset;
}
.sv-btn-primary:hover[b-ofbqm5tp9c] {
    background: linear-gradient(135deg, #059669, #047857);
    box-shadow: 0 4px 12px rgba(16,185,129,.35);
    transform: translateY(-1px);
}
.sv-btn-primary:disabled[b-ofbqm5tp9c] { opacity: .5; cursor: not-allowed; box-shadow: none; transform: none; }

/* ── Metrics strip ──────────────────────────────────────── */
.sv-metrics[b-ofbqm5tp9c] {
    display: flex; align-items: stretch; flex-wrap: wrap;
    border-top: 1px solid #e2e8f0;
    background: #f8fafc;
}
.sv-metric[b-ofbqm5tp9c] {
    flex: 1; display: flex; flex-direction: column; gap: .1rem;
    padding: .5rem 1.25rem;
    position: relative;
}
.sv-metric[b-ofbqm5tp9c]::before {
    content: '';
    position: absolute; top: 0; left: 1rem; right: 1rem;
    height: 2px; border-radius: 0 0 2px 2px;
    opacity: 0; transition: opacity .2s;
}
.sv-metric-fiber[b-ofbqm5tp9c]::before  { background: linear-gradient(90deg, #10b981, #34d399); }
.sv-metric-pkg[b-ofbqm5tp9c]::before    { background: linear-gradient(90deg, #3b82f6, #60a5fa); }
.sv-metric-cov[b-ofbqm5tp9c]::before    { background: linear-gradient(90deg, #06b6d4, #22d3ee); }
.sv-metric-done[b-ofbqm5tp9c]::before   { background: linear-gradient(90deg, #8b5cf6, #a78bfa); }
.sv-metric:hover[b-ofbqm5tp9c]::before  { opacity: 1; }

.sv-metric-div[b-ofbqm5tp9c] {
    width: 1px; background: #e2e8f0;
    margin: .5rem 0; flex-shrink: 0;
}
.sv-metric-label[b-ofbqm5tp9c] {
    font-size: .6rem; font-weight: 700; color: #64748b;
    text-transform: uppercase; letter-spacing: .08em;
    display: flex; align-items: center; gap: .3rem;
}
.sv-metric-label i[b-ofbqm5tp9c] { font-size: .65rem; opacity: .8; color: #94a3b8; }
.sv-metric-val[b-ofbqm5tp9c] {
    font-size: .95rem; font-weight: 700; color: #94a3b8;
    transition: color .2s; line-height: 1.15;
}
.sv-metric-val.sv-live[b-ofbqm5tp9c]  { color: #1e293b; }
.sv-metric-val.sv-warn[b-ofbqm5tp9c]  { color: #ea580c; }
.sv-metric-val.sv-muted[b-ofbqm5tp9c] { color: #cbd5e1; }
.sv-metric-sub[b-ofbqm5tp9c] {
    font-size: .65rem; color: #64748b; margin-top: .05rem;
}

/* completion bar inside metric */
.sv-comp-bar[b-ofbqm5tp9c] {
    height: 4px; background: #e2e8f0;
    border-radius: 9999px; overflow: hidden; margin-top: .25rem;
    width: 100%;
}
.sv-comp-fill[b-ofbqm5tp9c] {
    height: 100%; border-radius: 9999px;
    background: linear-gradient(90deg, #22d3ee, #8b5cf6, #10b981);
    background-size: 200% 100%;
    transition: width .5s cubic-bezier(.22,1,.36,1);
    animation: shimmer-bar-b-ofbqm5tp9c 3s ease infinite;
}
@keyframes shimmer-bar-b-ofbqm5tp9c {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

/* ── Review note (returned) ─────────────────────────────── */
.sv-review-note[b-ofbqm5tp9c] {
    display: flex; gap: .85rem; align-items: flex-start;
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border-left: 4px solid #f59e0b;
    padding: clamp(.8rem, .65rem + .6vw, 1rem) clamp(1rem, .5rem + 1.6vw, 1.75rem);
    font-size: clamp(.8rem, .72rem + .3vw, .9rem);
    color: #92400e;
    margin: 0 clamp(.75rem, .25rem + 1.6vw, 1.5rem);
    border-radius: 0 10px 10px 0;
    box-shadow: 0 2px 8px rgba(245,158,11,.1);
}
.sv-review-note i[b-ofbqm5tp9c] { flex-shrink: 0; margin-top: .15rem; font-size: 1.1rem; }


/* ═══════════════════════════════════════════════════════════
   GRID SHEET  –  the main spreadsheet table
   ═══════════════════════════════════════════════════════════ */
.grid-sheet-wrap[b-ofbqm5tp9c] {
    margin: 1.25rem 1.5rem 0;
    overflow-x: auto;
    border-radius: 16px;
    box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 4px 24px rgba(0,0,0,.06);
}

.grid-sheet[b-ofbqm5tp9c] {
    background: #fff;
    border-radius: 16px;
    border: 1px solid #dfe4ed;
    min-width: 1140px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* ── Column Group Header row ────────────────────────────── */
.cg-row[b-ofbqm5tp9c] {
    display: grid;
    grid-template-columns: 310px 370px 270px 190px;
    border-bottom: 1px solid #dfe4ed;
}
.cg-cell[b-ofbqm5tp9c] {
    padding: .65rem 1.1rem; font-size: .74rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .07em;
    display: flex; align-items: center; gap: .4rem;
}
.cg-unit[b-ofbqm5tp9c] { font-weight: 500; opacity: .55; text-transform: none; font-size: .68rem; }

.cg-style[b-ofbqm5tp9c] {
    background: #f8fafc; color: #475569;
    border-right: 2px solid #dfe4ed;
}
.cg-fiber[b-ofbqm5tp9c] {
    background: linear-gradient(135deg, #f0fdf4, #ecfdf5);
    color: #15803d;
    border-right: 2px solid #dfe4ed;
}
.cg-fiber i[b-ofbqm5tp9c] { color: #22c55e; }
.cg-packaging[b-ofbqm5tp9c] {
    background: linear-gradient(135deg, #eff6ff, #eef2ff);
    color: #1d4ed8;
    border-right: 2px solid #dfe4ed;
}
.cg-packaging i[b-ofbqm5tp9c] { color: #3b82f6; }
.cg-eco[b-ofbqm5tp9c] {
    background: linear-gradient(135deg, #fdf4ff, #faf5ff);
    color: #7c3aed;
}
.cg-eco i[b-ofbqm5tp9c] { color: #8b5cf6; }

/* ── Sub-column Header row ──────────────────────────────── */
.sh-row[b-ofbqm5tp9c] {
    display: grid;
    grid-template-columns: 220px 90px 130px 130px 110px 140px 130px 80px 110px;
    border-bottom: 2px solid #e2e8f0;
    background: #fafbfd;
}
.sh-cell[b-ofbqm5tp9c] {
    padding: .5rem .8rem; font-size: .68rem; font-weight: 700;
    color: #8b95a5; text-transform: uppercase; letter-spacing: .06em;
    border-right: 1px solid #edf0f5;
    display: flex; align-items: center;
    overflow: hidden; white-space: nowrap;
    min-width: 0;
}
.sh-cell:last-child[b-ofbqm5tp9c] { border-right: none; }

/* ── Sheet Toolbar ───────────────────────────────────────── */
.sheet-toolbar[b-ofbqm5tp9c] {
    display: flex; align-items: center; justify-content: space-between;
    padding: .55rem 1.1rem; background: #fafbfd;
    border-bottom: 1px solid #edf0f5; gap: 1rem; flex-wrap: wrap;
}
.sheet-toolbar-left[b-ofbqm5tp9c]  { display: flex; align-items: center; gap: .65rem; }
.sheet-toolbar-right[b-ofbqm5tp9c] { display: flex; align-items: center; gap: .85rem; margin-left: auto; }
.stb-btn[b-ofbqm5tp9c] {
    display: flex; align-items: center; gap: .4rem;
    font-size: .76rem; font-weight: 600; color: #475569;
    background: #fff; border: 1px solid #e2e8f0; border-radius: 8px;
    padding: .38rem .8rem; cursor: pointer; transition: all .2s;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.stb-btn:hover[b-ofbqm5tp9c] {
    background: #eff6ff; border-color: #93c5fd; color: #1d4ed8;
    box-shadow: 0 2px 6px rgba(59,130,246,.1);
    transform: translateY(-1px);
}
.stb-sep[b-ofbqm5tp9c] { width: 1px; height: 20px; background: #e2e8f0; }
.stb-toggle[b-ofbqm5tp9c] {
    display: flex; align-items: center; gap: .45rem;
    font-size: .76rem; font-weight: 500; color: #64748b; cursor: pointer;
}
.stb-toggle input[type="checkbox"][b-ofbqm5tp9c] { display: none; }
.stb-toggle-track[b-ofbqm5tp9c] {
    width: 32px; height: 18px; background: #e2e8f0; border-radius: 9999px;
    position: relative; transition: background .25s; flex-shrink: 0;
}
.stb-toggle input:checked + .stb-toggle-track[b-ofbqm5tp9c] { background: #3b82f6; }
.stb-toggle-thumb[b-ofbqm5tp9c] {
    position: absolute; left: 2px; top: 2px;
    width: 14px; height: 14px; background: #fff;
    border-radius: 50%; transition: left .25s cubic-bezier(.22,1,.36,1);
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
}
.stb-toggle input:checked + .stb-toggle-track .stb-toggle-thumb[b-ofbqm5tp9c] { left: 16px; }
.stb-stat[b-ofbqm5tp9c] {
    font-size: .76rem; color: #64748b;
    display: flex; align-items: center; gap: .3rem;
    background: #fff; padding: .3rem .6rem; border-radius: 6px;
    border: 1px solid #edf0f5;
}
.stb-stat strong[b-ofbqm5tp9c] { color: #1e293b; }
.text-green[b-ofbqm5tp9c] { color: #16a34a; }
.text-blue[b-ofbqm5tp9c]  { color: #2563eb; }

/* ── Collapsible Section Headers ────────────────────────── */
.sec-hdr[b-ofbqm5tp9c] {
    display: flex; align-items: center; gap: .7rem;
    padding: .65rem 1.1rem; cursor: pointer;
    border-bottom: 1px solid #edf0f5;
    border-top: 1px solid #edf0f5;
    background: linear-gradient(180deg, #f8fafb, #f4f6f9);
    user-select: none; transition: all .15s;
    position: relative;
}
.sec-hdr[b-ofbqm5tp9c]::before {
    content: '';
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px; border-radius: 0 2px 2px 0;
    opacity: 0; transition: opacity .2s;
}
.sec-hdr:hover[b-ofbqm5tp9c] { background: linear-gradient(180deg, #f1f5f9, #edf1f6); }
.sec-hdr:hover[b-ofbqm5tp9c]::before { opacity: 1; }
.sec-hdr.sec-hdr-collapsed[b-ofbqm5tp9c] { background: #fafafa; }
.sec-hdr.sec-hdr-collapsed:hover[b-ofbqm5tp9c] { background: #f0f4ff; }

/* Section accent colors on the left edge */
.sec-hdr:nth-of-type(1)[b-ofbqm5tp9c]::before,
.sec-hdr:has(.sec-icon-cotton)[b-ofbqm5tp9c]::before { background: #22c55e; }
.sec-hdr:has(.sec-icon-synth)[b-ofbqm5tp9c]::before  { background: #8b5cf6; }
.sec-hdr:has(.sec-icon-box)[b-ofbqm5tp9c]::before    { background: #f59e0b; }
.sec-hdr:has(.sec-icon-tag)[b-ofbqm5tp9c]::before    { background: #a855f7; }
.sec-hdr:has(.sec-icon-hanger)[b-ofbqm5tp9c]::before { background: #ef4444; }
.sec-hdr:has(.sec-icon-paper)[b-ofbqm5tp9c]::before  { background: #22c55e; }

.sec-chevron[b-ofbqm5tp9c] {
    font-size: .78rem; color: #94a3b8; transition: transform .25s cubic-bezier(.22,1,.36,1);
    flex-shrink: 0;
}
.sec-hdr-collapsed .sec-chevron[b-ofbqm5tp9c] { transform: rotate(-90deg); }

.sec-icon[b-ofbqm5tp9c] {
    width: 28px; height: 28px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: .85rem; flex-shrink: 0;
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.sec-icon-cotton[b-ofbqm5tp9c]  { background: linear-gradient(135deg, #d1fae5, #a7f3d0); color: #065f46; }
.sec-icon-synth[b-ofbqm5tp9c]   { background: linear-gradient(135deg, #ede9fe, #ddd6fe); color: #5b21b6; }
.sec-icon-box[b-ofbqm5tp9c]     { background: linear-gradient(135deg, #fef3c7, #fde68a); color: #92400e; }
.sec-icon-tag[b-ofbqm5tp9c]     { background: linear-gradient(135deg, #f3e8ff, #e9d5ff); color: #6b21a8; }
.sec-icon-hanger[b-ofbqm5tp9c]  { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #991b1b; }
.sec-icon-paper[b-ofbqm5tp9c]   { background: linear-gradient(135deg, #f0fdf4, #dcfce7); color: #15803d; }

.sec-title[b-ofbqm5tp9c] { font-size: .85rem; font-weight: 700; color: #1e293b; }
.sec-unit[b-ofbqm5tp9c]  {
    font-size: .68rem; color: #94a3b8;
    background: #fff; padding: .2rem .5rem; border-radius: 5px;
    border: 1px solid #edf0f5;
}

/* section fill progress bar */
.sec-fill-bar[b-ofbqm5tp9c] {
    flex: 1; max-width: 90px; height: 5px;
    background: #e8ecf1; border-radius: 9999px; overflow: hidden;
    margin-left: auto;
}
.sec-fill-fill[b-ofbqm5tp9c] {
    height: 100%;
    background: linear-gradient(90deg, #22d3ee, #3b82f6);
    border-radius: 9999px; transition: width .4s cubic-bezier(.22,1,.36,1);
}

/* fill count badge */
.sec-count[b-ofbqm5tp9c] {
    font-size: .7rem; font-weight: 600; padding: .22rem .6rem;
    border-radius: 9999px; background: #f1f5f9; color: #94a3b8;
    white-space: nowrap; flex-shrink: 0;
    border: 1px solid transparent;
}
.sec-count-partial[b-ofbqm5tp9c] {
    background: #fffbeb; color: #b45309;
    border-color: #fde68a;
}
.sec-count-done[b-ofbqm5tp9c] {
    background: #f0fdf4; color: #15803d;
    border-color: #bbf7d0;
}


/* ── Grid data rows ─────────────────────────────────────── */
.gs-row[b-ofbqm5tp9c] {
    display: grid;
    grid-template-columns: 220px 90px 130px 130px 110px 140px 130px 80px 110px;
    border-bottom: 1px solid #f0f2f5;
    align-items: center;
    min-height: 50px;
    transition: all .15s;
}
.gs-row:last-of-type[b-ofbqm5tp9c] { border-bottom: none; }
.gs-row:hover[b-ofbqm5tp9c] { background: #f8faff; }

/* Filled row gets a subtle green left accent + background */
.gs-row.gs-row-filled[b-ofbqm5tp9c] {
    background: linear-gradient(90deg, #f0fdf4 0%, #f8fdfb 100%);
    position: relative;
}
.gs-row.gs-row-filled[b-ofbqm5tp9c]::before {
    content: '';
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px; background: #22c55e;
    border-radius: 0 2px 2px 0;
}
.gs-row.gs-row-filled:hover[b-ofbqm5tp9c] { background: linear-gradient(90deg, #dcfce7 0%, #f0fdf4 100%); }

.gs-cell[b-ofbqm5tp9c] {
    padding: .5rem .8rem;
    border-right: 1px solid #f0f2f5;
    font-size: .84rem; color: #334155;
    display: flex; align-items: center; gap: .45rem;
    min-height: 50px;
    min-width: 0;
    overflow: hidden;
}
.gs-cell:last-child[b-ofbqm5tp9c] { border-right: none; }

/* disabled cell (N/A for fiber vs packaging) */
.gs-disabled[b-ofbqm5tp9c] {
    color: #d1d5db !important; font-size: .78rem;
    justify-content: center; background: #fafafa;
    position: relative;
}
/* Subtle diagonal stripe pattern for disabled cells */
.gs-disabled[b-ofbqm5tp9c]::after {
    content: '';
    position: absolute; inset: 0;
    background: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 4px,
        rgba(0,0,0,.015) 4px,
        rgba(0,0,0,.015) 5px
    );
    pointer-events: none;
}

/* material name cell */
.gs-name[b-ofbqm5tp9c] { font-size: .85rem; font-weight: 550; color: #1e293b; letter-spacing: -.01em; }

/* ── Dot indicator ──────────────────────────────────────── */
.dot[b-ofbqm5tp9c] {
    width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0;
    box-shadow: 0 0 0 2.5px rgba(255,255,255,.9);
}
.dot.cotton[b-ofbqm5tp9c]       { background: #10b981; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(16,185,129,.3); }
.dot.cotton.eco[b-ofbqm5tp9c]   { background: #0284c7; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(2,132,199,.3); }
.dot.cotton.green[b-ofbqm5tp9c] { background: #22c55e; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(34,197,94,.3); }
.dot.synth[b-ofbqm5tp9c]        { background: #6366f1; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(99,102,241,.3); }
.dot.synth.green[b-ofbqm5tp9c]  { background: #22c55e; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(34,197,94,.3); }
.dot.box[b-ofbqm5tp9c]          { background: #f59e0b; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(245,158,11,.3); }
.dot.tag[b-ofbqm5tp9c]          { background: #a855f7; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(168,85,247,.3); }
.dot.hanger[b-ofbqm5tp9c]       { background: #ef4444; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(239,68,68,.3); }
.dot.paper[b-ofbqm5tp9c]        { background: #94a3b8; box-shadow: 0 0 0 2px rgba(255,255,255,.8); }
.dot.paper.green[b-ofbqm5tp9c]  { background: #22c55e; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(34,197,94,.3); }

/* ── Category badges ────────────────────────────────────── */
.cat-badge[b-ofbqm5tp9c] {
    font-size: .66rem; font-weight: 700; padding: .22rem .55rem;
    border-radius: 5px; white-space: nowrap;
    letter-spacing: .02em;
}
.cat-cotton[b-ofbqm5tp9c]  { background: #d1fae5; color: #065f46; }
.cat-synth[b-ofbqm5tp9c]   { background: #ede9fe; color: #5b21b6; }
.cat-natural[b-ofbqm5tp9c] { background: #fef9c3; color: #854d0e; }
.cat-other[b-ofbqm5tp9c]   { background: #f1f5f9; color: #475569; }
.cat-box[b-ofbqm5tp9c]     { background: #fef3c7; color: #92400e; }
.cat-tag[b-ofbqm5tp9c]     { background: #f3e8ff; color: #6b21a8; }
.cat-hanger[b-ofbqm5tp9c]  { background: #fee2e2; color: #991b1b; }

/* ── Input cells ────────────────────────────────────────── */
.inp-wrap[b-ofbqm5tp9c] {
    display: flex; align-items: center;
    border: 2px solid #e2e8f0; border-radius: 9px;
    overflow: hidden; background: #fff; width: 100%;
    transition: all .2s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 1px 3px rgba(0,0,0,.02), inset 0 2px 4px rgba(0,0,0,.01);
}
.inp-wrap:hover[b-ofbqm5tp9c] {
    border-color: #cbd5e1;
    box-shadow: 0 2px 6px rgba(0,0,0,.04), inset 0 2px 4px rgba(0,0,0,.01);
}
.inp-wrap:focus-within[b-ofbqm5tp9c] {
    border-color: #6366f1;
    box-shadow: 0 0 0 4px rgba(99,102,241,.15), inset 0 2px 4px rgba(0,0,0,.02);
}
.gs-input[b-ofbqm5tp9c] {
    border: none; outline: none; background: transparent;
    font-size: .88rem; padding: .45rem .6rem; width: 0; flex: 1;
    color: #0f172a; font-weight: 600;
    font-family: inherit;
}
.gs-input[b-ofbqm5tp9c]::-webkit-outer-spin-button,
.gs-input[b-ofbqm5tp9c]::-webkit-inner-spin-button { -webkit-appearance: none; }
.inp-u[b-ofbqm5tp9c] {
    padding: .45rem .55rem; font-size: .72rem; color: #64748b; font-weight: 600;
    background: linear-gradient(180deg, #f8fafc, #f1f5f9); border-left: 1px solid #e2e8f0; white-space: nowrap;
}

/* ── Percent column ──────────────────────────────────────── */
.gs-fiber-p[b-ofbqm5tp9c] { flex-direction: column; align-items: flex-start; gap: .25rem; padding: .35rem .8rem; }
.pct-val[b-ofbqm5tp9c]   { font-size: .78rem; font-weight: 700; color: #334155; }
.pct-bar[b-ofbqm5tp9c]   { width: 100%; height: 5px; background: #e8ecf1; border-radius: 9999px; overflow: hidden; }
.pct-fill[b-ofbqm5tp9c]  { height: 100%; border-radius: 9999px; transition: width .4s cubic-bezier(.22,1,.36,1); }
.pct-fill.cotton[b-ofbqm5tp9c] { background: linear-gradient(90deg, #10b981, #22c55e); }
.pct-fill.synth[b-ofbqm5tp9c]  { background: linear-gradient(90deg, #6366f1, #818cf8); }

/* ── Mini progress bar (absolute scale) ─────────────────── */
.gs-bar[b-ofbqm5tp9c] { padding: .35rem .8rem; }
.mini-bar[b-ofbqm5tp9c]  { width: 100%; height: 5px; background: #e8ecf1; border-radius: 9999px; overflow: hidden; }
.mini-fill[b-ofbqm5tp9c] { height: 100%; border-radius: 9999px; transition: width .4s cubic-bezier(.22,1,.36,1); }
.mini-fill.cotton[b-ofbqm5tp9c]       { background: linear-gradient(90deg, #10b981, #34d399); }
.mini-fill.cotton.eco[b-ofbqm5tp9c]   { background: linear-gradient(90deg, #0284c7, #38bdf8); }
.mini-fill.cotton.green[b-ofbqm5tp9c] { background: linear-gradient(90deg, #22c55e, #4ade80); }
.mini-fill.synth[b-ofbqm5tp9c]        { background: linear-gradient(90deg, #6366f1, #a78bfa); }
.mini-fill.synth.green[b-ofbqm5tp9c]  { background: linear-gradient(90deg, #22c55e, #4ade80); }

/* ── Eco cert column ────────────────────────────────────── */
.cert-none[b-ofbqm5tp9c]  { color: #d1d5db; font-size: .82rem; }
.cert-badge[b-ofbqm5tp9c] {
    font-size: .66rem; font-weight: 700; padding: .22rem .5rem;
    border-radius: 5px;
    box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
.cert-blue[b-ofbqm5tp9c]   { background: linear-gradient(135deg, #dbeafe, #bfdbfe); color: #1d4ed8; }
.cert-green[b-ofbqm5tp9c]  { background: linear-gradient(135deg, #dcfce7, #bbf7d0); color: #15803d; }
.cert-gray[b-ofbqm5tp9c]   { background: #f1f5f9; color: #475569; }
.cert-purple[b-ofbqm5tp9c] { background: linear-gradient(135deg, #f3e8ff, #e9d5ff); color: #7c3aed; }
.cert-red[b-ofbqm5tp9c]    { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #b91c1c; }

/* ── Eco type column ────────────────────────────────────── */
.eco-tag[b-ofbqm5tp9c] {
    font-size: .67rem; font-weight: 600; padding: .22rem .5rem;
    background: #f1f5f9; color: #475569; border-radius: 5px;
    white-space: nowrap;
    border: 1px solid #e8ecf1;
}
.eco-tag.eco-green[b-ofbqm5tp9c] {
    background: linear-gradient(135deg, #f0fdf4, #dcfce7);
    color: #15803d;
    border-color: #bbf7d0;
}

/* ── Totals row ─────────────────────────────────────────── */
.totals-row[b-ofbqm5tp9c] {
    display: grid;
    grid-template-columns: 220px 90px 130px 130px 110px 140px 130px 80px 110px;
    border-top: 2px solid #dfe4ed;
    border-bottom: 1px solid #edf0f5;
    background: linear-gradient(180deg, #f6f8fb, #f0f3f7);
    min-height: 46px;
    align-items: center;
}
.totals-label[b-ofbqm5tp9c] {
    padding: .5rem .8rem; font-size: .78rem; font-weight: 700;
    color: #475569; display: flex; align-items: center; gap: .4rem;
    border-right: 1px solid #e2e8f0;
}
.totals-label i[b-ofbqm5tp9c] { color: #94a3b8; }
.totals-value[b-ofbqm5tp9c] {
    padding: .5rem .8rem; font-size: .82rem; font-weight: 600;
    color: #94a3b8; border-right: 1px solid #edf0f5;
    display: flex; align-items: center; gap: .4rem; flex-wrap: wrap;
}
.totals-value:last-child[b-ofbqm5tp9c] { border-right: none; }
.totals-active[b-ofbqm5tp9c] { color: #1e293b !important; }
.totals-ok[b-ofbqm5tp9c]   { color: #15803d !important; }
.totals-warn[b-ofbqm5tp9c] { color: #c2410c !important; }
.totals-badge[b-ofbqm5tp9c] {
    font-size: .67rem; font-weight: 700;
    padding: .18rem .45rem; border-radius: 5px;
    box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
.badge-ok[b-ofbqm5tp9c]   { background: linear-gradient(135deg, #dcfce7, #bbf7d0); color: #15803d; }
.badge-warn[b-ofbqm5tp9c] { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #b91c1c; }
.totals-formula[b-ofbqm5tp9c] { font-size: .67rem; font-weight: 400; color: #94a3b8; display: block; width: 100%; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 900px) {
    .at-topbar[b-ofbqm5tp9c] { padding: .5rem 1rem; }
    .grid-sheet-wrap[b-ofbqm5tp9c] { margin: .75rem .75rem 0; }
    .at-po-meta span:nth-child(n+5)[b-ofbqm5tp9c] { display: none; }
    .val-banners[b-ofbqm5tp9c] { padding: .5rem .75rem 0; }
    .sv-header-inner[b-ofbqm5tp9c] { padding: .7rem 1rem; }
}

/* ── Scrollbar styling ──────────────────────────────────── */
.grid-sheet-wrap[b-ofbqm5tp9c]::-webkit-scrollbar { height: 8px; }
.grid-sheet-wrap[b-ofbqm5tp9c]::-webkit-scrollbar-track {
    background: #f1f5f9; border-radius: 4px;
}
.grid-sheet-wrap[b-ofbqm5tp9c]::-webkit-scrollbar-thumb {
    background: #cbd5e1; border-radius: 4px;
}
.grid-sheet-wrap[b-ofbqm5tp9c]::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}

/* ── Selection / focus enhancements ─────────────────────── */
.gs-row:focus-within[b-ofbqm5tp9c] {
    background: #f0f7ff;
    box-shadow: 0 0 0 1px rgba(59,130,246,.1) inset;
}
.gs-row.gs-row-filled:focus-within[b-ofbqm5tp9c] {
    background: linear-gradient(90deg, #dcfce7 0%, #f0f7ff 100%);
}


/* ═══════════════════════════════════════════════════════════
   KANBAN BOARD – 4-column card layout
   ═══════════════════════════════════════════════════════════ */

.survey-sections[b-ofbqm5tp9c] {
    padding: 1.25rem 1.5rem;
}

.kanban-board[b-ofbqm5tp9c] {
    display: flex;
    gap: 1.25rem;
    align-items: stretch;
}

/* ── Column ─────────────────────────────────────────────── */
.kb-col[b-ofbqm5tp9c] {
    background: #fff;
    border-radius: 14px;
    border: 1px solid #e2e8f0;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.05), 0 1px 3px rgba(0,0,0,.04);
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
    transition: flex .35s cubic-bezier(.22,1,.36,1), min-width .35s cubic-bezier(.22,1,.36,1), max-width .35s cubic-bezier(.22,1,.36,1);
}

/* collapsed column shrinks to narrow strip */
.kb-col.kb-col-collapsed[b-ofbqm5tp9c] {
    flex: 0 0 auto;
    max-width: 60px;
    min-width: 60px;
}

/* ── Column header ──────────────────────────────────────── */
.kb-col-header[b-ofbqm5tp9c] {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .85rem 1rem;
    border-bottom: 1px solid rgba(0,0,0,.07);
    cursor: pointer;
    user-select: none;
    transition: background .15s, padding .35s;
}
.kb-col-header:hover[b-ofbqm5tp9c] { filter: brightness(.97); }

.kb-col-collapsed .kb-col-header[b-ofbqm5tp9c] {
    flex-direction: column;
    padding: 1.25rem 0;
    gap: 1.25rem;
    flex: 1;
    border-bottom: none;
}

/* ── Chevron toggle icon ───────────────────────────────── */
.kb-chev[b-ofbqm5tp9c] {
    font-size: .7rem;
    color: #94a3b8;
    flex-shrink: 0;
    transition: transform .25s cubic-bezier(.22,1,.36,1);
    width: 14px;
    text-align: center;
}
.kb-col-style  .kb-col-header[b-ofbqm5tp9c] { background: linear-gradient(135deg, #f8fafc, #f1f5f9); border-bottom-color: #e2e8f0; cursor: default; }
.kb-col-cotton .kb-col-header[b-ofbqm5tp9c] { background: linear-gradient(135deg, #f0fdf4, #dcfce7); border-bottom-color: #bbf7d0; }
.kb-col-synth  .kb-col-header[b-ofbqm5tp9c] { background: linear-gradient(135deg, #f5f3ff, #ede9fe); border-bottom-color: #ddd6fe; }
.kb-col-boxlbl .kb-col-header[b-ofbqm5tp9c] { background: linear-gradient(135deg, #fffbeb, #fef3c7); border-bottom-color: #fde68a; }
.kb-col-hangr  .kb-col-header[b-ofbqm5tp9c] { background: linear-gradient(135deg, #fff1f2, #fee2e2); border-bottom-color: #fecaca; }

.kb-col-icon[b-ofbqm5tp9c] {
    width: 32px; height: 32px; border-radius: 9px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; flex-shrink: 0;
}
.kb-col-style  .kb-col-icon[b-ofbqm5tp9c] { background: rgba(100,116,139,.18); color: #475569; }
.kb-col-cotton .kb-col-icon[b-ofbqm5tp9c] { background: rgba(34,197,94,.18); color: #16a34a; }
.kb-col-synth  .kb-col-icon[b-ofbqm5tp9c] { background: rgba(139,92,246,.18); color: #7c3aed; }
.kb-col-boxlbl .kb-col-icon[b-ofbqm5tp9c] { background: rgba(245,158,11,.18); color: #d97706; }
.kb-col-hangr  .kb-col-icon[b-ofbqm5tp9c] { background: rgba(239,68,68,.18); color: #dc2626; }

.kb-col-info[b-ofbqm5tp9c] { flex: 1; min-width: 0; }
.kb-col-title[b-ofbqm5tp9c] { display: block; font-size: .82rem; font-weight: 700; color: #1e293b; white-space: nowrap; }
.kb-col-unit[b-ofbqm5tp9c]  { font-size: .63rem; color: #94a3b8; font-weight: 500; }
.kb-of[b-ofbqm5tp9c]        { font-weight: 400; color: #cbd5e1; }

.kb-col-collapsed .kb-col-info[b-ofbqm5tp9c] {
    writing-mode: vertical-rl;
    text-orientation: upright;
    display: flex;
    align-items: center;
    flex: 0 0 auto;
    letter-spacing: 1px;
}
.kb-col-collapsed .kb-col-title[b-ofbqm5tp9c] {
    white-space: nowrap;
    text-transform: uppercase;
    font-size: .75rem;
    letter-spacing: 2px;
}
.kb-col-collapsed .kb-col-unit[b-ofbqm5tp9c],
.kb-col-collapsed .sec-count[b-ofbqm5tp9c] {
    display: none;
}
.kb-col-collapsed .kb-collapsed-body[b-ofbqm5tp9c],
.kb-col-collapsed .kb-footer[b-ofbqm5tp9c] {
    display: none !important;
}

/* ── Cards container ────────────────────────────────────── */
.kb-cards[b-ofbqm5tp9c] {
    padding: .8rem;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    align-content: start;
    gap: .8rem;
    flex: 1;
    overflow-y: auto;
}
.kb-cards[b-ofbqm5tp9c]::-webkit-scrollbar       { width: 4px; }
.kb-cards[b-ofbqm5tp9c]::-webkit-scrollbar-track { background: transparent; }
.kb-cards[b-ofbqm5tp9c]::-webkit-scrollbar-thumb { background: #e2e8f0; border-radius: 4px; }

/* ── Card ───────────────────────────────────────────────── */
.kb-card[b-ofbqm5tp9c] {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: .6rem .85rem;
    transition: border-color .2s, box-shadow .2s, transform .2s;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .5rem 1.5rem;
    box-shadow: 0 2px 5px rgba(0,0,0,.02);
}
.kb-card:hover[b-ofbqm5tp9c] {
    border-color: #cbd5e1;
    box-shadow: 0 4px 12px rgba(0,0,0,.05);
    transform: translateY(-1px);
}

/* filled accent per column type */
.kb-col-cotton .kb-card.kb-card-filled[b-ofbqm5tp9c] { background: linear-gradient(160deg, #f0fdf4 0%, #ffffff 100%); border-color: #86efac; }
.kb-col-synth  .kb-card.kb-card-filled[b-ofbqm5tp9c] { background: linear-gradient(160deg, #f5f3ff 0%, #ffffff 100%); border-color: #c4b5fd; }
.kb-col-boxlbl .kb-card.kb-card-filled[b-ofbqm5tp9c] { background: linear-gradient(160deg, #fffbeb 0%, #ffffff 100%); border-color: #fcd34d; }
.kb-col-hangr  .kb-card.kb-card-filled[b-ofbqm5tp9c] { background: linear-gradient(160deg, #fff1f2 0%, #ffffff 100%); border-color: #fca5a5; }

.kb-col-style .kb-card.kb-card-filled[b-ofbqm5tp9c] { background: linear-gradient(160deg, #f8fafc 0%, #ffffff 100%); border-color: #cbd5e1; }

/* ── Style Info Body ───────────────────────────────────── */
.kb-style-body[b-ofbqm5tp9c] {
    padding: .8rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    flex: 1;
    overflow-y: auto;
}
.kb-style-row[b-ofbqm5tp9c] {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    padding: .4rem .6rem;
    background: #fafbfd;
    border: 1px solid #edf0f5;
    border-radius: 8px;
}
.kb-style-lbl[b-ofbqm5tp9c] {
    font-size: .65rem;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.kb-style-val[b-ofbqm5tp9c] {
    font-size: .8rem;
    font-weight: 600;
    color: #1e293b;
    word-break: break-word;
}

.kb-card-top[b-ofbqm5tp9c] {
    display: flex; align-items: center; gap: .4rem;
    margin-bottom: 0;
    min-width: 140px;
    flex: 1;
}
.kb-name[b-ofbqm5tp9c] {
    flex: 1; min-width: 0;
    font-size: .79rem; font-weight: 600; color: #334155;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* eco / type badge inside card header */
.kb-eco-tag[b-ofbqm5tp9c] {
    font-size: .6rem; font-weight: 700; padding: .18rem .44rem;
    border-radius: 5px; flex-shrink: 0;
    background: #f1f5f9; color: #475569;
    letter-spacing: .02em;
}
.kb-eco-tag.kb-eco-green[b-ofbqm5tp9c]  { background: linear-gradient(135deg, #f0fdf4, #dcfce7); color: #15803d; }
.kb-eco-tag.kb-eco-box[b-ofbqm5tp9c]    { background: #fef3c7; color: #92400e; }
.kb-eco-tag.kb-eco-tag[b-ofbqm5tp9c]    { background: #f3e8ff; color: #6b21a8; }
.kb-eco-tag.kb-eco-hanger[b-ofbqm5tp9c] { background: #fee2e2; color: #991b1b; }

/* card input row */
.kb-card-row[b-ofbqm5tp9c] {
    display: flex; 
    align-items: center; 
    gap: .75rem; 
    flex: 0 0 auto;
    width: 180px;
    justify-content: flex-end;
}
.kb-card-row .inp-wrap[b-ofbqm5tp9c] { flex: 1; }

/* fiber percentage text */
.kb-pct[b-ofbqm5tp9c] {
    font-size: .75rem; font-weight: 700; color: #64748b;
    white-space: nowrap; min-width: 36px; text-align: right;
}

/* ── Mini progress bar in card ──────────────────────────── */
.kb-bar[b-ofbqm5tp9c] {
    width: 100%; height: 4px;
    background: #e8ecf2; border-radius: 9999px;
    overflow: hidden; margin-top: .15rem;
}
.kb-bar-fill[b-ofbqm5tp9c] {
    height: 100%; border-radius: 9999px;
    transition: width .4s cubic-bezier(.22,1,.36,1);
}
.kb-bar-fill.cotton[b-ofbqm5tp9c]       { background: linear-gradient(90deg, #10b981, #22c55e); }
.kb-bar-fill.cotton.eco[b-ofbqm5tp9c]   { background: linear-gradient(90deg, #0284c7, #38bdf8); }
.kb-bar-fill.cotton.green[b-ofbqm5tp9c] { background: linear-gradient(90deg, #22c55e, #4ade80); }
.kb-bar-fill.synth[b-ofbqm5tp9c]        { background: linear-gradient(90deg, #6366f1, #a78bfa); }
.kb-bar-fill.synth.green[b-ofbqm5tp9c]  { background: linear-gradient(90deg, #22c55e, #4ade80); }
.kb-bar-fill.box[b-ofbqm5tp9c]          { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
.kb-bar-fill.tag[b-ofbqm5tp9c]          { background: linear-gradient(90deg, #a855f7, #c084fc); }
.kb-bar-fill.hanger[b-ofbqm5tp9c]       { background: linear-gradient(90deg, #ef4444, #f87171); }
.kb-bar-fill.paper[b-ofbqm5tp9c]        { background: linear-gradient(90deg, #94a3b8, #cbd5e1); }

/* PO total annotation */
.kb-po-ann[b-ofbqm5tp9c] {
    width: 100%;
    display: block; font-size: .63rem; color: #94a3b8;
    margin-top: .1rem; font-style: italic;
}

/* ── Collapsed summary body ─────────────────────────────── */
.kb-collapsed-body[b-ofbqm5tp9c] {
    padding: .4rem .5rem;
    flex: 1;
    overflow-y: auto;
}
.kb-cl-row[b-ofbqm5tp9c] {
    display: flex;
    align-items: center;
    gap: .45rem;
    padding: .3rem .55rem;
    border-radius: 7px;
    font-size: .75rem;
    color: #94a3b8;
    transition: background .15s;
}
.kb-cl-row:hover[b-ofbqm5tp9c] { background: #f8fafc; }
.kb-cl-row.kb-cl-filled[b-ofbqm5tp9c] { color: #334155; }
.kb-col-cotton .kb-cl-row.kb-cl-filled[b-ofbqm5tp9c] { background: #f0fdf4; }
.kb-col-synth  .kb-cl-row.kb-cl-filled[b-ofbqm5tp9c] { background: #f5f3ff; }
.kb-col-boxlbl .kb-cl-row.kb-cl-filled[b-ofbqm5tp9c] { background: #fffbeb; }
.kb-col-hangr  .kb-cl-row.kb-cl-filled[b-ofbqm5tp9c] { background: #fff1f2; }
.kb-cl-name[b-ofbqm5tp9c] {
    flex: 1; min-width: 0;
    font-weight: 550;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.kb-cl-val[b-ofbqm5tp9c] {
    font-weight: 700;
    font-size: .73rem;
    white-space: nowrap;
    min-width: 32px; text-align: right;
}
.kb-cl-row.kb-cl-filled .kb-cl-val[b-ofbqm5tp9c] { color: #1e293b; }

/* ── Expanded card meta detail line ─────────────────────── */
.kb-card-meta[b-ofbqm5tp9c] {
    width: 100%;
    display: flex;
    align-items: center;
    gap: .3rem;
    flex-wrap: wrap;
    margin-top: .1rem;
    font-size: .63rem;
    color: #94a3b8;
    line-height: 1.5;
}
.kb-meta-eco[b-ofbqm5tp9c] {
    font-weight: 500;
}
.kb-meta-cert[b-ofbqm5tp9c] {
    font-weight: 600;
    color: #15803d;
}
.kb-meta-sep[b-ofbqm5tp9c] {
    color: #cbd5e1;
}
.kb-meta-mix[b-ofbqm5tp9c] {
    font-weight: 600;
    color: #64748b;
}
.kb-meta-gw[b-ofbqm5tp9c] {
    font-weight: 500;
    color: #0284c7;
}
.kb-meta-po[b-ofbqm5tp9c] {
    font-weight: 500;
    font-style: italic;
}

/* ── Column footer ──────────────────────────────────────── */
.kb-footer[b-ofbqm5tp9c] {
    display: flex; justify-content: space-between; align-items: center;
    padding: .6rem 1rem;
    background: #f8fafc;
    border-top: 1px solid #edf0f5;
}
.kb-foot-lbl[b-ofbqm5tp9c] {
    display: flex; align-items: center; gap: .3rem;
    font-size: .72rem; font-weight: 600; color: #94a3b8;
}
.kb-foot-lbl i[b-ofbqm5tp9c] { font-size: .7rem; }
.kb-foot-val[b-ofbqm5tp9c] {
    font-size: .78rem; font-weight: 700; color: #cbd5e1;
    transition: color .3s;
}
.kb-foot-val.kb-foot-live[b-ofbqm5tp9c] { color: #1e293b; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 1200px) {
    .kanban-board[b-ofbqm5tp9c] { flex-wrap: wrap; }
    .kb-col[b-ofbqm5tp9c] { flex: 1 1 calc(50% - .65rem); min-width: 260px; }
    .kb-col.kb-col-collapsed[b-ofbqm5tp9c] { min-width: 60px; max-width: 60px; flex: 0 0 auto; }
}
@media (max-width: 700px) {
    .kanban-board[b-ofbqm5tp9c] { flex-direction: column; }
    .kb-col[b-ofbqm5tp9c] { flex: none; width: 100%; max-width: none; min-width: 0; }

    /* Reset collapsed column to horizontal strip for mobile */
    .kb-col.kb-col-collapsed[b-ofbqm5tp9c] { flex: none; width: 100%; max-width: none; min-width: 0; }
    .kb-col-collapsed .kb-col-header[b-ofbqm5tp9c] { flex-direction: row; padding: .85rem 1rem; gap: .65rem; height: auto; }
    .kb-col-collapsed .kb-col-info[b-ofbqm5tp9c] { writing-mode: horizontal-tb; text-orientation: mixed; display: block; letter-spacing: normal; }
    .kb-col-collapsed .kb-col-title[b-ofbqm5tp9c] { text-transform: none; font-size: .82rem; letter-spacing: normal; white-space: normal; }
    .kb-col-collapsed .kb-col-unit[b-ofbqm5tp9c], .kb-col-collapsed .sec-count[b-ofbqm5tp9c] { display: inline-flex; }

    .survey-sections[b-ofbqm5tp9c] { padding: .75rem; }
}

/* ═══════════════════════════════════════════════════════════
   TABLE VIEW — Spreadsheet-style survey
   ═══════════════════════════════════════════════════════════ */

.survey-sections[b-ofbqm5tp9c] {
    padding: .85rem 1.25rem 0;
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

/* ── Table card container ──────────────────────────────── */
.sv-tbl-scroll[b-ofbqm5tp9c] {
    flex: 1;
    min-height: 0;
    overflow-x: auto;
    overflow-y: auto;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04);
}

/* ═══ RESPONSIVE ═════════════════════════════════════════ */

/* ── Tablet (≤1024px) ─────────────────────────────────── */
@media (max-width: 1024px) {
    .survey-sections[b-ofbqm5tp9c] { padding: .75rem; }
    .sv-header-inner[b-ofbqm5tp9c] { padding: .55rem 1rem; gap: .8rem; }
    .sv-metrics[b-ofbqm5tp9c] { flex-wrap: wrap; }
    .sv-metric[b-ofbqm5tp9c] { padding: .45rem .8rem; min-width: 120px; }
    .sv-th-item[b-ofbqm5tp9c] { min-width: 115px; width: 115px; font-size: .62rem; }
    .sv-col-h[b-ofbqm5tp9c] { min-width: 78px; width: 78px; font-size: .6rem; padding: .3rem .25rem; }
    .sv-td .gs-input[b-ofbqm5tp9c] { font-size: .72rem; padding: .28rem .3rem; }
}

/* ── Mobile (≤768px) ──────────────────────────────────── */
@media (max-width: 768px) {
    .survey-sections[b-ofbqm5tp9c] { padding: .5rem; }

    .sv-header-inner[b-ofbqm5tp9c] {
        flex-direction: column;
        align-items: flex-start;
        padding: .5rem .75rem;
        gap: .5rem;
    }
    .sv-header-right[b-ofbqm5tp9c] {
        width: 100%;
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: .4rem;
    }
    .sv-po-row[b-ofbqm5tp9c] { flex-wrap: wrap; gap: .4rem; }
    .sv-po-num[b-ofbqm5tp9c] { font-size: .9rem; }
    .sv-factory[b-ofbqm5tp9c] { font-size: .75rem; }
    .sv-meta[b-ofbqm5tp9c] { font-size: .68rem; padding: .15rem .35rem; }

    .sv-metrics[b-ofbqm5tp9c] { flex-wrap: wrap; gap: .25rem; }
    .sv-chip[b-ofbqm5tp9c] { font-size: .6rem; padding: .15rem .35rem; }
    .sv-chip-label[b-ofbqm5tp9c] { display: none; }

    .sv-tbl[b-ofbqm5tp9c] { font-size: .72rem; }
    .sv-th[b-ofbqm5tp9c] { padding: .35rem .4rem; font-size: .65rem; }
    .sv-th-item[b-ofbqm5tp9c] { min-width: 100px; width: 100px; font-size: .6rem; padding: .35rem .4rem; }
    .sv-th-group[b-ofbqm5tp9c] { padding: .4rem .5rem .25rem; font-size: .65rem; }
    .sv-col-h[b-ofbqm5tp9c] { min-width: 72px; width: 72px; font-size: .56rem; padding: .28rem .2rem; }
    .sv-td[b-ofbqm5tp9c] { height: 32px; }
    .sv-td-item[b-ofbqm5tp9c] { padding: 0 .4rem; }
    .sv-item-badge[b-ofbqm5tp9c] { font-size: .65rem; }
    .sv-td .gs-input[b-ofbqm5tp9c] { font-size: .68rem; padding: .25rem .25rem; }
    .sv-tfoot-val[b-ofbqm5tp9c] { font-size: .68rem; padding: .4rem .25rem; }
    .sv-tfoot-grand[b-ofbqm5tp9c] { font-size: .72rem; }

    .sv-btn[b-ofbqm5tp9c] { font-size: .7rem; padding: .35rem .6rem; }
    .sv-gw-block[b-ofbqm5tp9c] { padding: .25rem .4rem; }
    .sv-gw-input[b-ofbqm5tp9c] { width: 50px; font-size: .72rem; }
    .sv-calc-start-hint[b-ofbqm5tp9c] { display: none; }
}

/* ── Small Mobile (≤480px) ────────────────────────────── */
@media (max-width: 480px) {
    .survey-sections[b-ofbqm5tp9c] { padding: .25rem; }

    .sv-header-inner[b-ofbqm5tp9c] { padding: .4rem .5rem; }
    .sv-breadcrumb[b-ofbqm5tp9c] { font-size: .55rem; }
    .sv-po-num[b-ofbqm5tp9c] { font-size: .82rem; }
    .sv-factory[b-ofbqm5tp9c] { display: none; }
    .sv-pipe[b-ofbqm5tp9c] { display: none; }
    .sv-guide-text[b-ofbqm5tp9c] { display: none; }

    .sv-metrics[b-ofbqm5tp9c] { gap: .2rem; }
    .sv-chip[b-ofbqm5tp9c] { font-size: .55rem; padding: .12rem .3rem; gap: .2rem; }
    .sv-chip-label[b-ofbqm5tp9c] { display: none; }
    .sv-chip-bar[b-ofbqm5tp9c] { width: 20px; }

    .sv-tbl[b-ofbqm5tp9c] { font-size: .65rem; }
    .sv-th-item[b-ofbqm5tp9c] { min-width: 85px; width: 85px; font-size: .5rem; }
    .sv-col-h[b-ofbqm5tp9c] { min-width: 64px; width: 64px; font-size: .48rem; }
    .sv-td[b-ofbqm5tp9c] { height: 28px; }
    .sv-td .gs-input[b-ofbqm5tp9c] { font-size: .62rem; }
    .sv-th-group[b-ofbqm5tp9c] { font-size: .55rem; }
    .sv-th-group i[b-ofbqm5tp9c] { display: none; }

    .state-card[b-ofbqm5tp9c] { padding: 2rem 1.5rem; }
    .state-card h3[b-ofbqm5tp9c] { font-size: 1.2rem; }
}



/* ═══════════════════════════════════════════════════════════
   TABLE — Airtable / Syncfusion inspired design
   ═══════════════════════════════════════════════════════════ */
.sv-tbl[b-ofbqm5tp9c] {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: .78rem;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    table-layout: auto;
    background: #fff;
}

/* ── Group header row ──────────────────────────────────── */
.sv-tbl-group-row[b-ofbqm5tp9c] { background: #fafbfc; }
.sv-tbl-col-row[b-ofbqm5tp9c]   { background: #fafbfc; }

/* ── Base header cell ──────────────────────────────────── */
.sv-th[b-ofbqm5tp9c] {
    padding: .5rem .55rem;
    text-align: center;
    font-weight: 700;
    color: #374151;
    white-space: nowrap;
    border-bottom: 1px solid #e5e7eb;
    border-right: 1px solid #f0f0f0;
    vertical-align: middle;
    font-size: .72rem;
    letter-spacing: .01em;
}

/* ── Row Index sticky column ────────────────────────────── */
.sv-th-index[b-ofbqm5tp9c] {
    min-width: 38px;
    width: 38px;
    position: sticky;
    left: 0;
    z-index: 5;
    background: #fafbfc;
    border-right: 1px solid #e5e7eb;
    text-align: center;
    color: #9CA3AF;
    font-size: .65rem;
    font-weight: 600;
}

/* ── Item # sticky header ──────────────────────────────── */
.sv-th-item[b-ofbqm5tp9c] {
    text-align: left;
    min-width: 135px;
    width: 135px;
    color: #4B5563;
    font-size: .68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    position: sticky;
    left: 38px;
    z-index: 5;
    background: #fafbfc;
    border-right: 1px solid #e5e7eb;
    overflow: visible;
}

/* ── Calculator sticky header ──────────────────────────── */
.sv-th-calc[b-ofbqm5tp9c] {
    min-width: 32px;
    width: 32px;
    position: sticky;
    left: 173px;
    z-index: 5;
    background: #fafbfc;
    border-right: 1px solid #e5e7eb;
    text-align: center;
    color: #6B7280;
    font-size: .8rem;
}

/* ── Group label cells — colored left accent ───────────── */
.sv-th-group[b-ofbqm5tp9c] {
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .03em;
    padding: .6rem .75rem .45rem;
    color: #1F2937;
    position: relative;
}
.sv-th-group i[b-ofbqm5tp9c] { margin-right: .3rem; font-size: .8rem; opacity: .8; }

/* ── Total column header ──────────────────────────────── */
.sv-th-total[b-ofbqm5tp9c] {
    min-width: 65px;
    width: 65px;
    font-size: .68rem;
    color: #6B7280;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
    background: #fafbfc;
    border-left: 1px solid #e5e7eb;
    position: sticky;
    right: 0;
    z-index: 5;
    box-shadow: -2px 0 5px rgba(0,0,0,0.02);
}

/* ── Unit label ────────────────────────────────────────── */
.sv-th-unit[b-ofbqm5tp9c] {
    font-size: .6rem;
    font-weight: 600;
    display: block;
    line-height: 1;
    margin-top: 2px;
    color: #9CA3AF;
}

/* ═══ GROUP HEADER COLORS — Muted accent bands ═══════════
   Soft background tints with strong left-border accent
   ═══════════════════════════════════════════════════════ */
.sv-grp-cotton[b-ofbqm5tp9c] {
    background: #EEF2FF;
    color: #4338CA;
    border-left: 3px solid #6366F1;
    border-bottom: 1px solid #C7D2FE;
}
.sv-grp-synth[b-ofbqm5tp9c] {
    background: #EFF6FF;
    color: #1E40AF;
    border-left: 3px solid #3B82F6;
    border-bottom: 1px solid #BFDBFE;
}
.sv-grp-box[b-ofbqm5tp9c] {
    background: #FFF7ED;
    color: #C2410C;
    border-left: 3px solid #F97316;
    border-bottom: 1px solid #FED7AA;
}
.sv-grp-tag[b-ofbqm5tp9c] {
    background: #F0FDF4;
    color: #166534;
    border-left: 3px solid #22C55E;
    border-bottom: 1px solid #BBF7D0;
}
.sv-grp-hanger[b-ofbqm5tp9c] {
    background: #FFF1F2;
    color: #BE123C;
    border-left: 3px solid #F43F5E;
    border-bottom: 1px solid #FECDD3;
}
.sv-grp-paper[b-ofbqm5tp9c] {
    background: #ECFDF5;
    color: #065F46;
    border-left: 3px solid #10B981;
    border-bottom: 1px solid #A7F3D0;
}

/* ═══ SUB-COLUMN HEADERS — Clean and tight ═══════════════ */
.sv-col-h[b-ofbqm5tp9c] {
    font-size: .66rem;
    font-weight: 700;
    padding: .4rem .35rem;
    min-width: 88px;
    width: 88px;
    line-height: 1.25;
    white-space: normal;
    word-break: break-word;
    color: #374151;
    background: #fafbfc;
    border-bottom: 2px solid transparent;
}

/* Sub-col accent bottom borders per group */
.sv-col-cotton[b-ofbqm5tp9c]       { border-bottom-color: #A5B4FC; }
.sv-col-cotton-eco[b-ofbqm5tp9c]   { border-bottom-color: #A5B4FC; }
.sv-col-cotton-green[b-ofbqm5tp9c] { border-bottom-color: #86EFAC; }
.sv-col-synth[b-ofbqm5tp9c]        { border-bottom-color: #93C5FD; }
.sv-col-synth-green[b-ofbqm5tp9c]  { border-bottom-color: #86EFAC; }
.sv-col-box[b-ofbqm5tp9c]          { border-bottom-color: #FDBA74; }
.sv-col-tag[b-ofbqm5tp9c]          { border-bottom-color: #86EFAC; }
.sv-col-hanger[b-ofbqm5tp9c]       { border-bottom-color: #FDA4AF; }
.sv-col-paper[b-ofbqm5tp9c]        { border-bottom-color: #6EE7B7; }

/* Hide dots — use border accent instead */
.sv-col-h .dot[b-ofbqm5tp9c] { display: none; }

/* ═══ BODY ROWS ══════════════════════════════════════════ */
.sv-tr[b-ofbqm5tp9c] {
    background: #fff;
    transition: background .1s ease;
}
.sv-tr:nth-child(even)[b-ofbqm5tp9c] { background: #FAFBFC; }
.sv-tr:hover[b-ofbqm5tp9c] { background: #F0F5FF !important; }

/* ═══ DATA CELLS ═════════════════════════════════════════ */
.sv-td[b-ofbqm5tp9c] {
    padding: 0;
    border-right: 1px solid #f0f0f0;
    border-bottom: 1px solid #f0f0f0;
    vertical-align: middle;
    text-align: center;
    height: 36px;
}

/* ── Row Index sticky column ────────────────────────────── */
.sv-td-index[b-ofbqm5tp9c] {
    text-align: center;
    font-weight: 500;
    color: #9CA3AF;
    background: #fafbfc;
    position: sticky;
    left: 0;
    z-index: 2;
    border-right: 1px solid #e5e7eb;
    white-space: nowrap;
    padding: 0 .2rem;
    user-select: none;
    font-variant-numeric: tabular-nums;
}
.sv-tr:nth-child(even) .sv-td-index[b-ofbqm5tp9c] { background: #f3f4f6; }
.sv-tr:hover .sv-td-index[b-ofbqm5tp9c] { background: #E5E7EB !important; color: #6B7280; }

/* ── Item # sticky column ─────────────────────────────── */
.sv-td-item[b-ofbqm5tp9c] {
    text-align: left;
    font-weight: 600;
    color: #374151;
    background: #fff;
    position: sticky;
    left: 38px;
    z-index: 2;
    border-right: 1px solid #e5e7eb;
    white-space: nowrap;
    padding: 0 .6rem;
}
.sv-tr:nth-child(even) .sv-td-item[b-ofbqm5tp9c] { background: #FAFBFC; }
.sv-tr:hover .sv-td-item[b-ofbqm5tp9c] { background: #F0F5FF !important; }

/* ── Calculator sticky column ─────────────────────────── */
.sv-td-calc[b-ofbqm5tp9c] {
    min-width: 32px;
    width: 32px;
    position: sticky;
    left: 173px;
    z-index: 2;
    background: #fff;
    border-right: 1px solid #e5e7eb;
    text-align: center;
    vertical-align: middle;
    color: #4F46E5;
}
.sv-td-calc i:hover[b-ofbqm5tp9c] { color: #4338CA; }
.sv-tr:nth-child(even) .sv-td-calc[b-ofbqm5tp9c] { background: #FAFBFC; }
.sv-tr:hover .sv-td-calc[b-ofbqm5tp9c] { background: #F0F5FF !important; }

/* ── Highlighted Fiber Calculator — teal/emerald accent ── */
.sv-th-calc-highlight[b-ofbqm5tp9c] {
    background: linear-gradient(180deg, #0d9488 0%, #0f766e 100%) !important;
    color: #fff !important;
    border-right: 1px solid #0d9488 !important;
    border-bottom-color: #14b8a6 !important;
    font-size: .65rem;
    padding: .35rem .25rem;
    text-align: center;
    line-height: 1.2;
    cursor: default;
}
.sv-th-calc-highlight i[b-ofbqm5tp9c] {
    font-size: .9rem;
    display: block;
    margin-bottom: 1px;
    filter: drop-shadow(0 1px 1px rgba(0,0,0,.15));
}
.sv-calc-label[b-ofbqm5tp9c] {
    display: block;
    font-size: .5rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    opacity: .85;
}

.sv-td-calc-highlight[b-ofbqm5tp9c] {
    background: linear-gradient(180deg, #f0fdfa 0%, #ccfbf1 100%) !important;
    border-right: 1px solid #99f6e4 !important;
    cursor: pointer;
    transition: all .2s ease;
    text-align: center;
    vertical-align: middle;
}
.sv-td-calc-highlight i[b-ofbqm5tp9c] {
    color: #0d9488;
    font-size: 1rem;
    line-height: 36px;
    vertical-align: middle;
    display: inline-block;
    opacity: 1;
    transition: transform .2s, color .2s;
    cursor: pointer;
}
.sv-td-calc-highlight:hover[b-ofbqm5tp9c] {
    background: linear-gradient(180deg, #ccfbf1 0%, #99f6e4 100%) !important;
    box-shadow: inset 0 0 0 2px #14b8a6;
}
.sv-td-calc-highlight:hover i[b-ofbqm5tp9c] {
    color: #0f766e;
    transform: scale(1.2);
}
.sv-tr:nth-child(even) .sv-td-calc-highlight[b-ofbqm5tp9c] {
    background: linear-gradient(180deg, #ecfdf5 0%, #d1fae5 100%) !important;
}

.sv-calc-start-hint[b-ofbqm5tp9c] { display: none; }

/* Tour CSS moved to wwwroot/css/tour.css (shared with Survey.razor) */

/* Item badge — clean modern text */
.sv-item-badge[b-ofbqm5tp9c] {
    display: inline-flex;
    align-items: center;
    gap: .2rem;
    color: #374151;
    font-size: .72rem;
    font-weight: 600;
    white-space: nowrap;
}
.sv-item-badge i[b-ofbqm5tp9c] { font-size: .58rem; color: #D1D5DB; }


/* ── Row total cell ───────────────────────────────────── */
.sv-td-total[b-ofbqm5tp9c] {
    position: sticky;
    right: 0;
    z-index: 2;
    font-weight: 700;
    font-size: .75rem;
    color: #111827;
    background: #FAFBFC;
    border-left: 1px solid #e5e7eb;
    white-space: nowrap;
    padding: 0 .5rem;
    min-width: 60px;
    font-variant-numeric: tabular-nums;
    box-shadow: -2px 0 5px rgba(0,0,0,0.02);
}

/* ── Empty state ──────────────────────────────────────── */
.sv-td-empty[b-ofbqm5tp9c] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: #9CA3AF;
    font-style: italic;
    font-size: .82rem;
}
.sv-td-index.empty-row[b-ofbqm5tp9c] {
    background: transparent;
    border-right: none;
}
.sv-td-empty i[b-ofbqm5tp9c] { font-size: 1.2rem; display: block; margin-bottom: .4rem; color: #D1D5DB; }

/* ═══ CELL INPUTS — Airtable seamless inline editing ═════
   Invisible border by default. Shows on hover/focus.
   The cell IS the input. Clean, professional, premium.
   ═══════════════════════════════════════════════════════ */
.sv-td .inp-wrap[b-ofbqm5tp9c] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}
.sv-td .gs-input[b-ofbqm5tp9c] {
    width: 100%;
    height: 100%;
    padding: .35rem .4rem;
    border: none;
    border-radius: 0;
    font-size: .78rem;
    font-family: inherit;
    text-align: right;
    background: transparent;
    color: #374151;
    transition: background .12s, box-shadow .12s;
    -moz-appearance: textfield;
    appearance: textfield;
    cursor: cell;
}
.sv-td .gs-input[b-ofbqm5tp9c]::-webkit-inner-spin-button,
.sv-td .gs-input[b-ofbqm5tp9c]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.sv-td .gs-input[b-ofbqm5tp9c]::placeholder {
    color: #D1D5DB;
    font-size: .72rem;
    font-weight: 400;
}

/* Hover — subtle highlight */
.sv-td .gs-input:hover[b-ofbqm5tp9c] {
    background: rgba(99,102,241,.04);
}

/* Focus — Airtable-style blue ring around cell */
.sv-td .gs-input:focus[b-ofbqm5tp9c] {
    outline: none;
    background: #fff;
    box-shadow: inset 0 0 0 2px #6366F1;
    position: relative;
    z-index: 1;
}

/* Filled value — bolder */
.sv-td .gs-input:not(:placeholder-shown)[b-ofbqm5tp9c] {
    font-weight: 600;
    color: #111827;
}

/* Hide unit label */
.sv-td .inp-u[b-ofbqm5tp9c] { display: none; }

/* ── Sticky totals footer ─────────────────────────────── */
.sv-tfoot-row td[b-ofbqm5tp9c],
.sv-tfoot-row th[b-ofbqm5tp9c] {
    position: sticky;
    bottom: 0px;
    background: #F3F4F6;
    border-top: 2px solid #D1D5DB;
    z-index: 3;
}
.sv-tfoot-row .sv-td-index[b-ofbqm5tp9c] {
    background: #E5E7EB; /* distinct gray for bottom-left corner */
    z-index: 4;
    border-right: 1px solid #D1D5DB;
}
.sv-tfoot-row .sv-td-item[b-ofbqm5tp9c],
.sv-tfoot-row .sv-td-calc[b-ofbqm5tp9c] {
    background: #F3F4F6;
    z-index: 4;
}
.sv-tfoot-lbl[b-ofbqm5tp9c] {
    font-weight: 700;
    color: #6B7280;
    font-size: .62rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    text-align: left;
    padding: .5rem .6rem;
    position: sticky;
    left: 0;
    z-index: 5 !important;
    border-right: 1px solid #E5E7EB;
}
.sv-tfoot-val[b-ofbqm5tp9c] {
    font-weight: 700;
    color: #374151;
    font-size: .75rem;
    padding: .5rem .35rem; 
    text-align: center;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.sv-tfoot-grand[b-ofbqm5tp9c] {
    position: sticky;
    right: 0;
    z-index: 5 !important;
    color: #4338CA;
    font-size: .82rem;
    font-weight: 800;
    background: #EEF2FF !important;
    border-left: 2px solid #A5B4FC;
}

/* ═══════════════════════════════════════════════════════════
   PACKAGING SECTION — Separate card-based layout (Boxes & Paper)
   ═══════════════════════════════════════════════════════════ */
.sv-pkg-section[b-ofbqm5tp9c] {
    margin-top: 1rem;
    flex-shrink: 0;
    padding-bottom: 1rem;
}
.sv-pkg-heading[b-ofbqm5tp9c] {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .6rem .85rem;
    font-size: .82rem;
    font-weight: 700;
    color: #1e293b;
    background: #fff;
    border-radius: 8px 8px 0 0;
    border: 1px solid #e2e8f0;
    border-bottom: none;
}
.sv-pkg-heading i[b-ofbqm5tp9c] {
    font-size: .9rem;
    color: #3b82f6;
}
.sv-pkg-hint[b-ofbqm5tp9c] {
    font-size: .65rem;
    font-weight: 500;
    color: #94a3b8;
    background: #f1f5f9;
    padding: .15rem .5rem;
    border-radius: 5px;
    border: 1px solid #e2e8f0;
}
.sv-pkg-total[b-ofbqm5tp9c] {
    margin-left: auto;
    font-size: .75rem;
    font-weight: 700;
    color: #3b82f6;
}

.sv-pkg-grid[b-ofbqm5tp9c] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 0 0 8px 8px;
    overflow: hidden;
}

.sv-pkg-card[b-ofbqm5tp9c] {
    border-right: 1px solid #e2e8f0;
    display: flex;
    flex-direction: column;
}
.sv-pkg-card:last-child[b-ofbqm5tp9c] {
    border-right: none;
}

.sv-pkg-card-header[b-ofbqm5tp9c] {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .6rem .75rem;
    border-bottom: 1px solid rgba(0,0,0,.06);
}
.sv-pkg-box .sv-pkg-card-header[b-ofbqm5tp9c]   { background: linear-gradient(135deg, #fffbeb, #fef3c7); }
.sv-pkg-paper .sv-pkg-card-header[b-ofbqm5tp9c] { background: linear-gradient(135deg, #f0fdf4, #dcfce7); }

.sv-pkg-card-icon[b-ofbqm5tp9c] {
    width: 26px;
    height: 26px;
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .85rem;
    flex-shrink: 0;
}
.sv-pkg-icon-box[b-ofbqm5tp9c]    { background: rgba(245,158,11,.18); color: #d97706; }
.sv-pkg-icon-paper[b-ofbqm5tp9c]  { background: rgba(34,197,94,.18); color: #16a34a; }

.sv-pkg-card-title[b-ofbqm5tp9c] {
    font-size: .78rem;
    font-weight: 700;
    color: #1e293b;
}
.sv-pkg-card-unit[b-ofbqm5tp9c] {
    font-size: .6rem;
    color: #94a3b8;
    margin-left: auto;
}

.sv-pkg-card-body[b-ofbqm5tp9c] {
    padding: .5rem .75rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    flex: 1;
}

.sv-pkg-field[b-ofbqm5tp9c] {
    display: flex;
    align-items: center;
    gap: .5rem;
}
.sv-pkg-label[b-ofbqm5tp9c] {
    display: flex;
    align-items: center;
    gap: .35rem;
    font-size: .72rem;
    font-weight: 600;
    color: #475569;
    white-space: nowrap;
    min-width: 100px;
}
.sv-pkg-label .dot[b-ofbqm5tp9c] {
    width: 8px;
    height: 8px;
}
.sv-pkg-field .inp-wrap[b-ofbqm5tp9c] {
    flex: 1;
    border: 1.5px solid #e2e8f0;
    border-radius: 7px;
    box-shadow: none;
}
.sv-pkg-field .inp-wrap:focus-within[b-ofbqm5tp9c] {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99,102,241,.12);
}
.sv-pkg-field .gs-input[b-ofbqm5tp9c] {
    font-size: .78rem;
    padding: .3rem .45rem;
    text-align: right;
}
.sv-pkg-field .inp-u[b-ofbqm5tp9c] {
    display: flex;
    padding: .3rem .4rem;
    font-size: .65rem;
}

/* ── Responsive packaging grid ────────────────────────── */
@media (max-width: 600px) {
    .sv-pkg-grid[b-ofbqm5tp9c] {
        grid-template-columns: 1fr;
    }
    .sv-pkg-card[b-ofbqm5tp9c] {
        border-right: none;
        border-bottom: 1px solid #e2e8f0;
    }
    .sv-pkg-card:last-child[b-ofbqm5tp9c] {
        border-bottom: none;
    }
}
/* /Components/Pages/FiberCalculator.razor.rz.scp.css */
.fc-overlay[b-eg0x6k19uf] {
    position: fixed;
    inset: 0;
    background: rgba(17, 24, 39, 0.4);
    backdrop-filter: blur(2px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1050;
}

.fc-modal[b-eg0x6k19uf] {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    width: 100%;
    max-width: 750px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.fc-header[b-eg0x6k19uf] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid #E5E7EB;
    background: #ffffff;
}

.fc-title[b-eg0x6k19uf] {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0;
    color: #111827;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.fc-subtitle[b-eg0x6k19uf] {
    font-size: 0.85rem;
    color: #6B7280;
    margin: 4px 0 0;
}

.fc-body[b-eg0x6k19uf] {
    overflow-y: auto;
    flex: 1;
}

.fc-label[b-eg0x6k19uf] {
    font-size: 0.95rem;
    color: #374151;
    margin: 0;
}

.fc-yes-shell[b-eg0x6k19uf] {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding-bottom: 0.25rem;
}

.fc-yes-header-row[b-eg0x6k19uf] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.fc-yes-title[b-eg0x6k19uf] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: #6b7280;
    font-size: 0.86rem;
    font-weight: 600;
}

.fc-yes-title i[b-eg0x6k19uf] {
    font-size: 0.62rem;
    color: #9ca3af;
}

.fc-yes-total[b-eg0x6k19uf] {
    border-radius: 999px;
    font-size: 0.77rem;
    font-weight: 700;
    padding: 0.4rem 0.8rem;
    white-space: nowrap;
}

.fc-yes-total.is-pending[b-eg0x6k19uf] {
    background: #fff3cd;
    color: #8a6a00;
    border: 1px solid #ffe69c;
}

.fc-yes-total.is-complete[b-eg0x6k19uf] {
    background: #e8f5e9;
    color: #1f7a34;
    border: 1px solid #b6dfba;
}

.fc-yes-grid[b-eg0x6k19uf] {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.75rem;
}

.fc-yes-group[b-eg0x6k19uf] {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.fc-yes-group-title[b-eg0x6k19uf] {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    color: #5b4eea;
    font-size: 0.87rem;
    font-weight: 800;
    letter-spacing: 0.5px;
    margin: 0 0 0.5rem;
}

.fc-yes-group-dot[b-eg0x6k19uf] {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    display: inline-block;
    background: radial-gradient(circle at 30% 30%, #c8c2ff, #8f85ff);
}

.fc-yes-row[b-eg0x6k19uf] {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 92px;
    gap: 0.65rem;
    align-items: center;
}

.fc-yes-row label[b-eg0x6k19uf] {
    font-size: 0.84rem;
    font-weight: 500;
    color: #4b5563;
    margin: 0;
}

.fc-yes-input[b-eg0x6k19uf] {
    display: flex;
    align-items: center;
    background: #fff;
    border: 1px solid #d7dce3;
    border-radius: 8px;
    overflow: hidden;
    min-height: 34px;
}

.fc-yes-input input[b-eg0x6k19uf] {
    border: none;
    outline: none;
    width: 100%;
    padding: 0.32rem 0.5rem;
    font-size: 0.86rem;
    text-align: right;
    min-width: 0;
    -moz-appearance: textfield;
}

.fc-yes-input input[b-eg0x6k19uf]::-webkit-outer-spin-button,
.fc-yes-input input[b-eg0x6k19uf]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.fc-yes-input .u[b-eg0x6k19uf] {
    color: #98a1ad;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 0.28rem 0.45rem;
    background: #f8fafc;
    border-left: 1px solid #d7dce3;
    line-height: 1;
}

.fc-segments-stack[b-eg0x6k19uf] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    width: 100%;
}

.fc-fiber-grid[b-eg0x6k19uf] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}

.fc-inp-compact[b-eg0x6k19uf] {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.fc-inp-compact label[b-eg0x6k19uf] {
    font-size: 0.75rem;
    font-weight: 600;
    color: #6c757d;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.inp-pct[b-eg0x6k19uf] {
    display: flex;
    align-items: center;
    background: #fff;
    border: 1px solid #dee2e6;
    border-radius: 6px;
    overflow: hidden;
}

.inp-pct input[b-eg0x6k19uf] {
    border: none;
    outline: none;
    width: 100%;
    padding: 0.25rem 0.5rem;
    font-size: 0.9rem;
    text-align: right;
    min-width: 0;
    -moz-appearance: textfield;
}

.inp-pct input[b-eg0x6k19uf]::-webkit-outer-spin-button,
.inp-pct input[b-eg0x6k19uf]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.inp-pct .u[b-eg0x6k19uf] {
    color: #adb5bd;
    font-size: 0.8rem;
    padding: 0.25rem 0.45rem;
    background: #f8f9fa;
    border-left: 1px solid #dee2e6;
}

.hover-danger:hover[b-eg0x6k19uf] {
    color: #dc3545 !important;
    background-color: #ffe6e6 !important;
    border-radius: 4px;
}

@media (max-width: 768px) {
    .fc-modal[b-eg0x6k19uf] {
        max-width: min(96vw, 750px);
    }

    .fc-yes-grid[b-eg0x6k19uf] {
        grid-template-columns: 1fr;
        gap: 1.2rem;
    }

    .fc-yes-header-row[b-eg0x6k19uf] {
        flex-wrap: wrap;
        justify-content: flex-start;
    }
}
/* /Components/Pages/Home.razor.rz.scp.css */
/* Container & Background */
.home-container[b-yixp7r2ufv] {
  animation: fadeIn-b-yixp7r2ufv 0.6s var(--ease-out);
  position: relative;
  overflow: hidden;
}

/* Background Glow Effect */
.home-container[b-yixp7r2ufv]::before {
  content: "";
  position: absolute;
  top: -10%;
  left: 50%;
  transform: translateX(-50%);
  width: 60vw;
  height: 60vh;
  background: radial-gradient(
    circle,
    rgba(99, 102, 241, 0.15) 0%,
    rgba(255, 255, 255, 0) 70%
  );
  z-index: -1;
  pointer-events: none;
}

/* Hero Section */
.hero-section[b-yixp7r2ufv] {
  text-align: center;
  padding: var(--space-8) var(--space-4) var(--space-6);
  max-width: 900px;
  margin: 0 auto;
  position: relative;
}

/* Hero Badge */
.hero-badge[b-yixp7r2ufv] {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background-color: var(--color-primary-light);
  border: 1px solid rgba(99, 102, 241, 0.2);
  padding: var(--space-1) var(--space-3) var(--space-1) var(--space-1);
  border-radius: var(--radius-full);
  font-size: var(--font-sm);
  font-weight: 500;
  color: var(--color-primary);
  margin-bottom: var(--space-6);
  box-shadow: var(--shadow-sm);
  animation: slideDown-b-yixp7r2ufv 0.5s var(--ease-out);
}

.badge-tag[b-yixp7r2ufv] {
  background-color: var(--color-primary);
  color: white;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: var(--font-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Typography Enhancements */
.hero-title[b-yixp7r2ufv] {
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  margin-bottom: var(--space-6);
  color: var(--text-primary);
  letter-spacing: -0.03em;
  line-height: 1.1;
  animation: titleFadeIn-b-yixp7r2ufv 0.8s var(--ease-out) forwards;
}

.hero-title:focus[b-yixp7r2ufv] {
  outline: none;
}

.text-gradient[b-yixp7r2ufv] {
  background: linear-gradient(
    110deg,
    var(--color-primary) 0%,
    #a855f7 35%,
    #ffffff 50%,
    #a855f7 65%,
    var(--color-primary) 100%
  );
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  border: none;
  outline: none;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  animation: gradientShimmer-b-yixp7r2ufv 3s linear infinite;
}

.hero-subtitle[b-yixp7r2ufv] {
  font-size: var(--font-lg);
  color: var(--text-secondary);
  max-width: 600px;
  margin: 0 auto var(--space-10);
  line-height: 1.6;
}

/* Action Buttons */
.hero-actions[b-yixp7r2ufv] {
  display: flex;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
}

.shine-effect[b-yixp7r2ufv] {
  position: relative;
  overflow: hidden;
}

.shine-effect[b-yixp7r2ufv]::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(
    to right,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.3) 50%,
    rgba(255, 255, 255, 0) 100%
  );
  transform: rotate(30deg);
  animation: shine-b-yixp7r2ufv 4s infinite;
}

@keyframes shine-b-yixp7r2ufv {
  0% {
    transform: translateX(-100%) rotate(30deg);
  }
  20%,
  100% {
    transform: translateX(100%) rotate(30deg);
  }
}

/* Hero Stats */
.hero-stats[b-yixp7r2ufv] {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-8);
  padding-top: var(--space-8);
  border-top: 1px solid var(--border-subtle);
  max-width: 700px;
  margin: 0 auto;
}

.stat-item[b-yixp7r2ufv] {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.stat-value[b-yixp7r2ufv] {
  font-size: var(--font-2xl);
  font-weight: 700;
  color: var(--text-primary);
  font-family: var(--font-mono);
}

.stat-label[b-yixp7r2ufv] {
  font-size: var(--font-sm);
  color: var(--text-secondary);
  font-weight: 500;
}

.stat-divider[b-yixp7r2ufv] {
  width: 1px;
  height: 40px;
  background-color: var(--border-subtle);
}

/* Features Section */
.features-section[b-yixp7r2ufv] {
  padding: var(--space-2) var(--space-6) var(--space-16);
  max-width: 1200px;
  margin: 0 auto;
}

.section-header[b-yixp7r2ufv] {
  text-align: center;
  margin-bottom: var(--space-10);
}

.section-title[b-yixp7r2ufv] {
  font-size: var(--font-2xl);
  font-weight: 700;
  margin-bottom: var(--space-2);
  color: var(--slate-900);
  letter-spacing: -0.02em;
}

.section-subtitle[b-yixp7r2ufv] {
  font-size: var(--font-lg);
  color: var(--text-secondary);
}

/* Feature Grid */
.feature-grid[b-yixp7r2ufv] {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  padding: var(--space-2) 0;
}

/* Premium Responsive Grid Strategy */
@media (min-width: 640px) {
  .feature-grid[b-yixp7r2ufv] {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .feature-grid[b-yixp7r2ufv] {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Premium Feature Cards - Modern Glass & Glow */
.feature-card[b-yixp7r2ufv] {
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: var(--space-8);
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.6);
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  box-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.05);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  z-index: 1;
  overflow: hidden;
  animation: slideUpFade-b-yixp7r2ufv 0.6s cubic-bezier(0.16, 1, 0.3, 1) backwards;
}

/* Staggered load animation */
.feature-card:nth-child(1)[b-yixp7r2ufv] { animation-delay: 0.1s; }
.feature-card:nth-child(2)[b-yixp7r2ufv] { animation-delay: 0.2s; }
.feature-card:nth-child(3)[b-yixp7r2ufv] { animation-delay: 0.3s; }
.feature-card:nth-child(4)[b-yixp7r2ufv] { animation-delay: 0.4s; }

/* Subtle gradient background matched to theme on hover */
.feature-card[b-yixp7r2ufv]::before {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--card-theme-bg) 0%, rgba(255,255,255,0) 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: -1;
  pointer-events: none;
}

.feature-card:hover[b-yixp7r2ufv] {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 20px 40px -10px var(--card-theme-shadow);
  border: 1px solid rgba(255, 255, 255, 1);
}

.feature-card:hover[b-yixp7r2ufv]::before {
  opacity: 1;
}

.feature-icon-wrapper[b-yixp7r2ufv] {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background-color: var(--card-theme-bg);
  color: var(--card-theme-color);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  margin-bottom: var(--space-6);
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  position: relative;
}

.feature-card:hover .feature-icon-wrapper[b-yixp7r2ufv] {
  transform: scale(1.1) translateY(-4px) rotate(-5deg);
  background-color: var(--card-theme-color);
  color: #fff;
  box-shadow: 0 10px 20px -5px var(--card-theme-shadow);
}

.feature-title[b-yixp7r2ufv] {
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: var(--space-3);
  color: var(--text-primary);
  letter-spacing: -0.01em;
}

.feature-text[b-yixp7r2ufv] {
  font-size: 0.95rem;
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 0;
}

/* Animations */
@keyframes fadeIn-b-yixp7r2ufv {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideDown-b-yixp7r2ufv {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideUpFade-b-yixp7r2ufv {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes titleFadeIn-b-yixp7r2ufv {
  from {
    opacity: 0;
    transform: translateY(20px);
    filter: blur(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

@keyframes gradientShimmer-b-yixp7r2ufv {
  0% {
    background-position: 200% center;
  }
  100% {
    background-position: -200% center;
  }
}

/* Responsive Overrides */
@media (max-width: 768px) {
  .hero-section[b-yixp7r2ufv] {
    padding: var(--space-8) var(--space-4);
  }

  .feature-card[b-yixp7r2ufv] {
    padding: var(--space-6);
  }
}
/* /Components/Pages/Manufacturers.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════════
   Manufacturers.razor — Scoped styles
   ═══════════════════════════════════════════════════════════════════ */

/* Hero */
.mfr-hero[b-6tv5w41ty0] { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:1.5rem; flex-wrap:wrap; }
.mfr-hero-left[b-6tv5w41ty0] { display:flex; align-items:center; gap:1rem; }
.mfr-hero-badge[b-6tv5w41ty0] { width:52px; height:52px; display:flex; align-items:center; justify-content:center; border-radius:14px; background:linear-gradient(135deg,#6366f1,#818cf8); color:#fff; font-size:1.5rem; box-shadow:0 4px 14px rgba(99,102,241,.3); flex-shrink:0; }
.mfr-eyebrow[b-6tv5w41ty0] { font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color:#6366f1; margin-bottom:2px; }
.mfr-title[b-6tv5w41ty0] { font-size:1.5rem; font-weight:800; color:#0f172a; line-height:1.2; margin:0; }
.mfr-sub[b-6tv5w41ty0] { font-size:.82rem; color:#64748b; margin:2px 0 0; }
.mfr-hero-actions[b-6tv5w41ty0] { display:flex; gap:.5rem; }
.mfr-action-btn[b-6tv5w41ty0] { display:inline-flex; align-items:center; gap:.4rem; border-radius:10px; font-weight:600; font-size:.82rem; padding:.45rem 1rem; }

/* Stats */
.mfr-stats[b-6tv5w41ty0] { display:flex; gap:.75rem; margin-bottom:1.5rem; flex-wrap:wrap; }
.mfr-stat[b-6tv5w41ty0] { display:flex; align-items:center; gap:.75rem; background:#fff; border:1px solid #e2e8f0; border-radius:14px; padding:.85rem 1.25rem; min-width:150px; transition:all .2s; }
.mfr-stat:hover[b-6tv5w41ty0] { box-shadow:0 4px 16px rgba(0,0,0,.06); transform:translateY(-1px); }
.mfr-stat-icon[b-6tv5w41ty0] { width:40px; height:40px; display:flex; align-items:center; justify-content:center; border-radius:10px; font-size:1.1rem; }
.mfr-stat--total .mfr-stat-icon[b-6tv5w41ty0] { background:#eef2ff; color:#6366f1; }
.mfr-stat--reg   .mfr-stat-icon[b-6tv5w41ty0] { background:#f0fdf4; color:#16a34a; }
.mfr-stat--noreg .mfr-stat-icon[b-6tv5w41ty0] { background:#fef2f2; color:#ef4444; }
.mfr-stat-val[b-6tv5w41ty0] { font-size:1.35rem; font-weight:800; color:#0f172a; line-height:1; }
.mfr-stat-lbl[b-6tv5w41ty0] { font-size:.72rem; color:#64748b; font-weight:500; margin-top:2px; }

/* Reg badge */
.mfr-reg-badge[b-6tv5w41ty0] { display:inline-flex; align-items:center; gap:.3rem; font-size:.78rem; font-weight:600; padding:.2rem .55rem; border-radius:6px; background:#eef2ff; color:#4f46e5; }

/* Search */
.mfr-search[b-6tv5w41ty0] { position:relative; }
.mfr-search-icon[b-6tv5w41ty0] { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:#94a3b8; font-size:.85rem; }
.mfr-search-input[b-6tv5w41ty0] { padding:.45rem .75rem .45rem 2.1rem; border:1px solid #e2e8f0; border-radius:8px; font-size:.82rem; width:260px; transition:border-color .2s; }
.mfr-search-input:focus[b-6tv5w41ty0] { outline:none; border-color:#6366f1; box-shadow:0 0 0 3px rgba(99,102,241,.1); }

/* State */
.mfr-state[b-6tv5w41ty0] { text-align:center; padding:3rem 1rem; }
.mfr-state-icon[b-6tv5w41ty0] { font-size:2.5rem; margin-bottom:.75rem; }
.mfr-state-icon--error[b-6tv5w41ty0] { color:#ef4444; }
.mfr-state-icon--empty[b-6tv5w41ty0] { color:#94a3b8; }
.mfr-state-title[b-6tv5w41ty0] { font-weight:700; color:#1e293b; font-size:1rem; margin:0 0 .25rem; }
.mfr-state-sub[b-6tv5w41ty0] { font-size:.82rem; color:#64748b; margin:0; }

/* Modal */
.mfr-overlay[b-6tv5w41ty0] { position:fixed; inset:0; background:rgba(15,23,42,.5); backdrop-filter:blur(4px); z-index:1000; }
.mfr-modal[b-6tv5w41ty0] { position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); background:#fff; border-radius:16px; box-shadow:0 25px 60px rgba(0,0,0,.25); z-index:1001; width:95%; max-width:520px; max-height:90vh; overflow-y:auto; }
.mfr-modal-header[b-6tv5w41ty0] { display:flex; align-items:center; justify-content:space-between; padding:1.25rem 1.5rem; border-bottom:1px solid #e2e8f0; }
.mfr-modal-header h3[b-6tv5w41ty0] { margin:0; font-size:1.1rem; font-weight:700; color:#0f172a; display:flex; align-items:center; gap:.5rem; }
.mfr-modal-close[b-6tv5w41ty0] { background:none; border:none; font-size:1.1rem; color:#94a3b8; cursor:pointer; padding:.25rem; border-radius:6px; transition:all .15s; }
.mfr-modal-close:hover[b-6tv5w41ty0] { background:#f1f5f9; color:#334155; }
.mfr-modal-body[b-6tv5w41ty0] { padding:1.5rem; }
.mfr-modal-footer[b-6tv5w41ty0] { display:flex; justify-content:flex-end; gap:.5rem; padding:1rem 1.5rem; border-top:1px solid #e2e8f0; }

/* Form */
.mfr-form-grid[b-6tv5w41ty0] { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.mfr-field[b-6tv5w41ty0] { display:flex; flex-direction:column; gap:.3rem; }
.mfr-field--full[b-6tv5w41ty0] { grid-column:1 / -1; }
.mfr-field label[b-6tv5w41ty0] { font-size:.78rem; font-weight:600; color:#334155; }
.mfr-input[b-6tv5w41ty0] { padding:.5rem .75rem; border:1px solid #e2e8f0; border-radius:8px; font-size:.85rem; transition:border-color .2s; width:100%; }
.mfr-input:focus[b-6tv5w41ty0] { outline:none; border-color:#6366f1; box-shadow:0 0 0 3px rgba(99,102,241,.1); }

/* Alerts */
.mfr-alert[b-6tv5w41ty0] { display:flex; align-items:center; gap:.5rem; padding:.65rem 1rem; border-radius:8px; font-size:.82rem; font-weight:500; margin-bottom:1rem; }
.mfr-alert--error[b-6tv5w41ty0] { background:#fef2f2; color:#dc2626; border:1px solid #fecaca; }
.mfr-alert--success[b-6tv5w41ty0] { background:#f0fdf4; color:#16a34a; border:1px solid #bbf7d0; }

/* Spinner */
.mfr-spin[b-6tv5w41ty0] { animation:mfr-rotate-b-6tv5w41ty0 .8s linear infinite; }
@keyframes mfr-rotate-b-6tv5w41ty0 { to { transform:rotate(360deg); } }

/* Responsive */
@media (max-width:640px) {
    .mfr-form-grid[b-6tv5w41ty0] { grid-template-columns:1fr; }
    .mfr-stats[b-6tv5w41ty0] { flex-direction:column; }
    .mfr-search-input[b-6tv5w41ty0] { width:100%; }
    .mfr-hero[b-6tv5w41ty0] { flex-direction:column; align-items:flex-start; }
}
/* /Components/Pages/Mills.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════════
   Mills.razor — Scoped styles (matches Factories page conventions)
   ═══════════════════════════════════════════════════════════════════ */

/* Hero */
.mill-hero[b-2piulwtojc] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.mill-hero-left[b-2piulwtojc] {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.mill-hero-badge[b-2piulwtojc] {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: linear-gradient(135deg, #6366f1, #818cf8);
    color: white;
    font-size: 1.5rem;
    box-shadow: 0 4px 14px rgba(99, 102, 241, 0.3);
    flex-shrink: 0;
}

.mill-eyebrow[b-2piulwtojc] {
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #6366f1;
    margin-bottom: 2px;
}

.mill-title[b-2piulwtojc] {
    font-size: 1.5rem;
    font-weight: 800;
    color: #0f172a;
    line-height: 1.2;
    margin: 0;
}

.mill-sub[b-2piulwtojc] {
    font-size: 0.82rem;
    color: #64748b;
    margin: 2px 0 0;
}

.mill-hero-actions[b-2piulwtojc] {
    display: flex;
    gap: 0.5rem;
}

.mill-action-btn[b-2piulwtojc] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    border-radius: 10px;
    font-weight: 600;
    font-size: 0.82rem;
    padding: 0.45rem 1rem;
}

/* Stats */
.mill-stats[b-2piulwtojc] {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.mill-stat[b-2piulwtojc] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: white;
    border: 1px solid #e2e8f0;
    border-radius: 14px;
    padding: 0.85rem 1.25rem;
    min-width: 140px;
    transition: all 0.2s;
}

.mill-stat:hover[b-2piulwtojc] {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
    transform: translateY(-1px);
}

.mill-stat--active[b-2piulwtojc] {
    border-color: #6366f1;
    box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.15);
}

.mill-stat-icon[b-2piulwtojc] {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    font-size: 1.1rem;
}

.mill-stat--total .mill-stat-icon[b-2piulwtojc] {
    background: #eef2ff;
    color: #6366f1;
}

.mill-stat--type .mill-stat-icon[b-2piulwtojc] {
    background: #f0fdf4;
    color: #16a34a;
}

.mill-stat-val[b-2piulwtojc] {
    font-size: 1.35rem;
    font-weight: 800;
    color: #0f172a;
    line-height: 1;
}

.mill-stat-lbl[b-2piulwtojc] {
    font-size: 0.72rem;
    color: #64748b;
    font-weight: 500;
    margin-top: 2px;
}

/* Search */
.mill-search[b-2piulwtojc] {
    position: relative;
}

.mill-search-icon[b-2piulwtojc] {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #94a3b8;
    font-size: 0.85rem;
}

.mill-search-input[b-2piulwtojc] {
    padding: 0.45rem 0.75rem 0.45rem 2.1rem;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    font-size: 0.82rem;
    width: 240px;
    transition: border-color 0.2s;
}

.mill-search-input:focus[b-2piulwtojc] {
    outline: none;
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

/* State */
.mill-state[b-2piulwtojc] {
    text-align: center;
    padding: 3rem 1rem;
}

.mill-state-icon[b-2piulwtojc] {
    font-size: 2.5rem;
    margin-bottom: 0.75rem;
}

.mill-state-icon--error[b-2piulwtojc] {
    color: #ef4444;
}

.mill-state-icon--empty[b-2piulwtojc] {
    color: #94a3b8;
}

.mill-state-title[b-2piulwtojc] {
    font-weight: 700;
    color: #1e293b;
    font-size: 1rem;
    margin: 0 0 0.25rem;
}

.mill-state-sub[b-2piulwtojc] {
    font-size: 0.82rem;
    color: #64748b;
    margin: 0;
}

/* Type badges */
.mill-type-badge[b-2piulwtojc] {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.65rem;
    border-radius: 8px;
    white-space: nowrap;
}

.mill-badge--spinning[b-2piulwtojc] {
    background: #dbeafe;
    color: #1d4ed8;
}

.mill-badge--fabric[b-2piulwtojc] {
    background: #dcfce7;
    color: #15803d;
}

.mill-badge--dyeing[b-2piulwtojc] {
    background: #fae8ff;
    color: #a21caf;
}

.mill-badge--other[b-2piulwtojc] {
    background: #f1f5f9;
    color: #475569;
}

/* Email link */
.mill-email[b-2piulwtojc] {
    font-size: 0.82rem;
    color: #6366f1;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.mill-email:hover[b-2piulwtojc] {
    text-decoration: underline;
}

/* Modal overlay */
.mill-overlay[b-2piulwtojc] {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.5);
    backdrop-filter: blur(4px);
    z-index: 1000;
}

.mill-modal[b-2piulwtojc] {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: white;
    border-radius: 16px;
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.25);
    z-index: 1001;
    width: 95%;
    max-width: 560px;
    max-height: 90vh;
    overflow-y: auto;
}

.mill-modal-header[b-2piulwtojc] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid #e2e8f0;
}

.mill-modal-header h3[b-2piulwtojc] {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 700;
    color: #0f172a;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.mill-modal-close[b-2piulwtojc] {
    background: none;
    border: none;
    font-size: 1.1rem;
    color: #94a3b8;
    cursor: pointer;
    padding: 0.25rem;
    border-radius: 6px;
    transition: all 0.15s;
}

.mill-modal-close:hover[b-2piulwtojc] {
    background: #f1f5f9;
    color: #334155;
}

.mill-modal-body[b-2piulwtojc] {
    padding: 1.5rem;
}

.mill-modal-footer[b-2piulwtojc] {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 1rem 1.5rem;
    border-top: 1px solid #e2e8f0;
}

/* Form */
.mill-form-grid[b-2piulwtojc] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.mill-field[b-2piulwtojc] {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.mill-field--full[b-2piulwtojc] {
    grid-column: 1 / -1;
}

.mill-field label[b-2piulwtojc] {
    font-size: 0.78rem;
    font-weight: 600;
    color: #334155;
}

.mill-input[b-2piulwtojc] {
    padding: 0.5rem 0.75rem;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    font-size: 0.85rem;
    transition: border-color 0.2s;
    width: 100%;
}

.mill-input:focus[b-2piulwtojc] {
    outline: none;
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

/* Alerts */
.mill-alert[b-2piulwtojc] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 1rem;
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 500;
    margin-bottom: 1rem;
}

.mill-alert--error[b-2piulwtojc] {
    background: #fef2f2;
    color: #dc2626;
    border: 1px solid #fecaca;
}

.mill-alert--success[b-2piulwtojc] {
    background: #f0fdf4;
    color: #16a34a;
    border: 1px solid #bbf7d0;
}

/* Spinner */
.mill-spin[b-2piulwtojc] {
    animation: mill-rotate-b-2piulwtojc 0.8s linear infinite;
}

@keyframes mill-rotate-b-2piulwtojc {
    to { transform: rotate(360deg); }
}

/* Responsive */
@media (max-width: 640px) {
    .mill-form-grid[b-2piulwtojc] {
        grid-template-columns: 1fr;
    }

    .mill-stats[b-2piulwtojc] {
        flex-direction: column;
    }

    .mill-search-input[b-2piulwtojc] {
        width: 100%;
    }

    .mill-hero[b-2piulwtojc] {
        flex-direction: column;
        align-items: flex-start;
    }
}
/* /Components/Pages/Reports.razor.rz.scp.css */
/* Styles relocated to Tailwind classes in Reports.razor */
/* /Components/Pages/Survey.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════
   Survey.razor.css  –  Premium Redesigned Survey UI
   Focus: Clarity, usability, beautiful visual hierarchy
   ═══════════════════════════════════════════════════════════ */

/* ── Page wrapper ──────────────────────────────────────── */
.airtable-page[b-kd2ep2b8u1] {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: #FAFBFC; 
    height: calc(100vh - 95px); /* Adjusted for actual top nav height so the horizontal scrollbar isn't pushed off-screen */
    display: flex;
    flex-direction: column;
    overflow: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ── State overlays (error / locked / success) ─────────── */
.state-overlay[b-kd2ep2b8u1] {
    display: flex; justify-content: center; align-items: center;
    min-height: 80vh; padding: 2rem;
}
.state-card[b-kd2ep2b8u1] {
    background: #fff; border-radius: 20px;
    padding: 3rem 3.5rem; max-width: 540px; width: 100%;
    box-shadow: 0 8px 40px rgba(0,0,0,.08), 0 0 0 1px rgba(0,0,0,.04);
    text-align: center;
}
.state-card h3[b-kd2ep2b8u1] { font-size: 1.5rem; font-weight: 700; margin: 1.2rem 0 .6rem; color: #0f172a; }
.state-card p[b-kd2ep2b8u1]  { color: #64748b; margin-bottom: 1.5rem; font-size: .95rem; line-height: 1.6; }
.state-icon-wrap[b-kd2ep2b8u1] { font-size: 3.2rem; margin-bottom: .5rem; }
.success-icon[b-kd2ep2b8u1] { color: #22c55e; }
.error-icon[b-kd2ep2b8u1]   { color: #ef4444; }
.state-help[b-kd2ep2b8u1] {
    display: flex; gap: .75rem; background: #f8fafc; border-radius: 12px;
    padding: 1.2rem; text-align: left; font-size: .875rem; color: #475569;
    border: 1px solid #e2e8f0;
}

/* ── Success submission summary ────────────────────────── */
.submission-summary-grid[b-kd2ep2b8u1] { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; margin-top: 1.5rem; text-align: left; }
.sum-item[b-kd2ep2b8u1] { background: #f8fafc; border-radius: 10px; padding: .85rem 1rem; border: 1px solid #e2e8f0; }
.sum-label[b-kd2ep2b8u1] { display: block; font-size: .7rem; font-weight: 600; color: #94a3b8; text-transform: uppercase; letter-spacing: .05em; }
.sum-val[b-kd2ep2b8u1]   { font-size: .95rem; font-weight: 600; color: #1e293b; }
.sum-val.highlight[b-kd2ep2b8u1] { color: #0ea5e9; }

/* ── Toast ─────────────────────────────────────────────── */
.at-toast[b-kd2ep2b8u1] {
    position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 9999;
    background: linear-gradient(135deg, #16a34a, #15803d); color: #fff;
    padding: .85rem 1.5rem;
    border-radius: 12px; font-size: .875rem; font-weight: 600;
    display: flex; align-items: center; gap: .5rem;
    box-shadow: 0 8px 24px rgba(22,163,74,.4);
    animation: slideUp-b-kd2ep2b8u1 .35s cubic-bezier(.22,1,.36,1);
}
@keyframes slideUp-b-kd2ep2b8u1 {
    from { transform: translateY(20px); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}

/* ══════════════════════════════════════════════════════════
   SITE HEADER  –  Light, minimal, compact design
══════════════════════════════════════════════════════════ */
.sv-header[b-kd2ep2b8u1] {
    background: #ffffff;
    z-index: 120;
    box-shadow: 0 4px 15px rgba(0,0,0,.03), 0 1px 0 #e2e8f0;
    flex-shrink: 0;
}

/* Top row: PO info + actions */
.sv-header-inner[b-kd2ep2b8u1] {
    display: flex; align-items: center; justify-content: space-between;
    padding: .65rem 1.5rem; gap: 1rem; flex-wrap: wrap;
}
.sv-header-left[b-kd2ep2b8u1]  { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }
.sv-header-right[b-kd2ep2b8u1] { display: flex; align-items: center; gap: .6rem; flex-shrink: 0; }

.sv-breadcrumb[b-kd2ep2b8u1] {
    font-size: .65rem; font-weight: 700; color: #10b981;
    text-transform: uppercase; letter-spacing: .08em;
    display: flex; align-items: center; gap: .4rem;
}
.sv-breadcrumb[b-kd2ep2b8u1]::before {
    content: '';
    width: 6px; height: 6px; border-radius: 50%;
    background: #10b981;
    box-shadow: 0 0 6px rgba(16,185,129,.4);
    animation: pulse-glow-b-kd2ep2b8u1 2s ease infinite;
}
@keyframes pulse-glow-b-kd2ep2b8u1 {
    0%, 100% { opacity: 1; box-shadow: 0 0 6px rgba(16,185,129,.4); }
    50%      { opacity: .6; box-shadow: 0 0 3px rgba(16,185,129,.2); }
}

.sv-po-row[b-kd2ep2b8u1] {
    display: flex; align-items: center; gap: .65rem; flex-wrap: wrap;
}
.sv-po-num[b-kd2ep2b8u1] {
    font-size: 1.05rem; font-weight: 800; color: #1e293b;
    letter-spacing: -.01em;
}
.sv-pipe[b-kd2ep2b8u1] {
    width: 1px; height: 16px;
    background: #cbd5e1; flex-shrink: 0;
}
.sv-factory[b-kd2ep2b8u1] {
    font-size: .85rem; font-weight: 600; color: #64748b;
}
.sv-meta[b-kd2ep2b8u1] {
    display: flex; align-items: center; gap: .3rem;
    font-size: .75rem; color: #64748b;
    background: #f1f5f9;
    padding: .2rem .5rem; border-radius: 6px;
    border: 1px solid #e2e8f0;
}
.sv-meta i[b-kd2ep2b8u1] { font-size: .72rem; color: #94a3b8; }

/* Guide text for users */
.sv-guide-text[b-kd2ep2b8u1] {
    font-size: .7rem; color: #64748b; font-weight: 400;
}

/* Garment weight in header – compact light style */
.sv-gw-block[b-kd2ep2b8u1] {
    display: flex; flex-direction: column; gap: .15rem;
    background: #f8fafc;
    padding: .35rem .6rem; border-radius: 8px;
    border: 1px solid #e2e8f0;
}
.sv-gw-label[b-kd2ep2b8u1] {
    font-size: .55rem; font-weight: 700; color: #64748b;
    text-transform: uppercase; letter-spacing: .05em;
}
.sv-gw-input-wrap[b-kd2ep2b8u1] {
    display: flex; align-items: center; overflow: hidden;
    border: 1px solid #cbd5e1; border-radius: 6px;
    background: #fff;
    transition: all .2s;
}
.sv-gw-input-wrap:focus-within[b-kd2ep2b8u1] {
    border-color: #6366f1; box-shadow: 0 0 0 2px rgba(99,102,241,.15);
}
.sv-gw-input[b-kd2ep2b8u1] {
    border: none; outline: none; background: transparent;
    font-size: .8rem; font-weight: 600; padding: .25rem .45rem;
    width: 60px; color: #1e293b; font-family: inherit;
}
.sv-gw-input[b-kd2ep2b8u1]::-webkit-outer-spin-button,
.sv-gw-input[b-kd2ep2b8u1]::-webkit-inner-spin-button { -webkit-appearance: none; }
.sv-gw-input[b-kd2ep2b8u1]::placeholder { color: #cbd5e1; }
.sv-gw-unit[b-kd2ep2b8u1] {
    padding: .25rem .4rem; font-size: .65rem; color: #64748b; font-weight: 600;
    border-left: 1px solid #e2e8f0; white-space: nowrap; background: #f8fafc;
}

/* Header buttons — styled for light theme */
.sv-btn[b-kd2ep2b8u1] {
    display: inline-flex; align-items: center; gap: .4rem;
    font-size: .78rem; font-weight: 600; padding: .45rem .9rem;
    border-radius: 8px; border: none; cursor: pointer;
    font-family: inherit; transition: all .2s cubic-bezier(.22,1,.36,1);
    white-space: nowrap;
}
.sv-btn-ghost[b-kd2ep2b8u1] {
    background: #fff;
    color: #475569;
    border: 1px solid #cbd5e1;
}
.sv-btn-ghost:hover[b-kd2ep2b8u1] {
    background: #f8fafc; color: #1e293b;
    border-color: #94a3b8;
    transform: translateY(-1px); box-shadow: 0 2px 5px rgba(0,0,0,.04);
}
.sv-btn-primary[b-kd2ep2b8u1] {
    background: linear-gradient(135deg, #10b981, #059669);
    color: #fff; font-weight: 700; border: 1px solid #047857;
    box-shadow: 0 2px 8px rgba(16,185,129,.2), 0 1px 0 rgba(255,255,255,.2) inset;
}
.sv-btn-primary:hover[b-kd2ep2b8u1] {
    background: linear-gradient(135deg, #059669, #047857);
    box-shadow: 0 4px 12px rgba(16,185,129,.35);
    transform: translateY(-1px);
}
.sv-btn-primary:disabled[b-kd2ep2b8u1] { opacity: .5; cursor: not-allowed; box-shadow: none; transform: none; }

/* ── Metrics strip — now uses shared FactorySurveyMetrics component ── */

/* ── Review note (returned) ─────────────────────────────── */
.sv-review-note[b-kd2ep2b8u1] {
    display: flex; gap: .85rem; align-items: flex-start;
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border-left: 4px solid #f59e0b;
    padding: 1rem 1.75rem; font-size: .9rem; color: #92400e;
    margin: 0 1.5rem; border-radius: 0 10px 10px 0;
    box-shadow: 0 2px 8px rgba(245,158,11,.1);
}
.sv-review-note i[b-kd2ep2b8u1] { flex-shrink: 0; margin-top: .15rem; font-size: 1.1rem; }


/* ═══════════════════════════════════════════════════════════
   GRID SHEET  –  the main spreadsheet table
   ═══════════════════════════════════════════════════════════ */
.grid-sheet-wrap[b-kd2ep2b8u1] {
    margin: 1.25rem 1.5rem 0;
    overflow-x: auto;
    border-radius: 16px;
    box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 4px 24px rgba(0,0,0,.06);
}

.grid-sheet[b-kd2ep2b8u1] {
    background: #fff;
    border-radius: 16px;
    border: 1px solid #dfe4ed;
    min-width: 1140px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* ── Column Group Header row ────────────────────────────── */
.cg-row[b-kd2ep2b8u1] {
    display: grid;
    grid-template-columns: 310px 370px 270px 190px;
    border-bottom: 1px solid #dfe4ed;
}
.cg-cell[b-kd2ep2b8u1] {
    padding: .65rem 1.1rem; font-size: .74rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .07em;
    display: flex; align-items: center; gap: .4rem;
}
.cg-unit[b-kd2ep2b8u1] { font-weight: 500; opacity: .55; text-transform: none; font-size: .68rem; }

.cg-style[b-kd2ep2b8u1] {
    background: #f8fafc; color: #475569;
    border-right: 2px solid #dfe4ed;
}
.cg-fiber[b-kd2ep2b8u1] {
    background: linear-gradient(135deg, #f0fdf4, #ecfdf5);
    color: #15803d;
    border-right: 2px solid #dfe4ed;
}
.cg-fiber i[b-kd2ep2b8u1] { color: #22c55e; }
.cg-packaging[b-kd2ep2b8u1] {
    background: linear-gradient(135deg, #eff6ff, #eef2ff);
    color: #1d4ed8;
    border-right: 2px solid #dfe4ed;
}
.cg-packaging i[b-kd2ep2b8u1] { color: #3b82f6; }
.cg-eco[b-kd2ep2b8u1] {
    background: linear-gradient(135deg, #fdf4ff, #faf5ff);
    color: #7c3aed;
}
.cg-eco i[b-kd2ep2b8u1] { color: #8b5cf6; }

/* ── Sub-column Header row ──────────────────────────────── */
.sh-row[b-kd2ep2b8u1] {
    display: grid;
    grid-template-columns: 220px 90px 130px 130px 110px 140px 130px 80px 110px;
    border-bottom: 2px solid #e2e8f0;
    background: #fafbfd;
}
.sh-cell[b-kd2ep2b8u1] {
    padding: .5rem .8rem; font-size: .68rem; font-weight: 700;
    color: #8b95a5; text-transform: uppercase; letter-spacing: .06em;
    border-right: 1px solid #edf0f5;
    display: flex; align-items: center;
    overflow: hidden; white-space: nowrap;
    min-width: 0;
}
.sh-cell:last-child[b-kd2ep2b8u1] { border-right: none; }

/* ── Sheet Toolbar ───────────────────────────────────────── */
.sheet-toolbar[b-kd2ep2b8u1] {
    display: flex; align-items: center; justify-content: space-between;
    padding: .55rem 1.1rem; background: #fafbfd;
    border-bottom: 1px solid #edf0f5; gap: 1rem; flex-wrap: wrap;
}
.sheet-toolbar-left[b-kd2ep2b8u1]  { display: flex; align-items: center; gap: .65rem; }
.sheet-toolbar-right[b-kd2ep2b8u1] { display: flex; align-items: center; gap: .85rem; margin-left: auto; }
.stb-btn[b-kd2ep2b8u1] {
    display: flex; align-items: center; gap: .4rem;
    font-size: .76rem; font-weight: 600; color: #475569;
    background: #fff; border: 1px solid #e2e8f0; border-radius: 8px;
    padding: .38rem .8rem; cursor: pointer; transition: all .2s;
    box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.stb-btn:hover[b-kd2ep2b8u1] {
    background: #eff6ff; border-color: #93c5fd; color: #1d4ed8;
    box-shadow: 0 2px 6px rgba(59,130,246,.1);
    transform: translateY(-1px);
}
.stb-sep[b-kd2ep2b8u1] { width: 1px; height: 20px; background: #e2e8f0; }
.stb-toggle[b-kd2ep2b8u1] {
    display: flex; align-items: center; gap: .45rem;
    font-size: .76rem; font-weight: 500; color: #64748b; cursor: pointer;
}
.stb-toggle input[type="checkbox"][b-kd2ep2b8u1] { display: none; }
.stb-toggle-track[b-kd2ep2b8u1] {
    width: 32px; height: 18px; background: #e2e8f0; border-radius: 9999px;
    position: relative; transition: background .25s; flex-shrink: 0;
}
.stb-toggle input:checked + .stb-toggle-track[b-kd2ep2b8u1] { background: #3b82f6; }
.stb-toggle-thumb[b-kd2ep2b8u1] {
    position: absolute; left: 2px; top: 2px;
    width: 14px; height: 14px; background: #fff;
    border-radius: 50%; transition: left .25s cubic-bezier(.22,1,.36,1);
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
}
.stb-toggle input:checked + .stb-toggle-track .stb-toggle-thumb[b-kd2ep2b8u1] { left: 16px; }
.stb-stat[b-kd2ep2b8u1] {
    font-size: .76rem; color: #64748b;
    display: flex; align-items: center; gap: .3rem;
    background: #fff; padding: .3rem .6rem; border-radius: 6px;
    border: 1px solid #edf0f5;
}
.stb-stat strong[b-kd2ep2b8u1] { color: #1e293b; }
.text-green[b-kd2ep2b8u1] { color: #16a34a; }
.text-blue[b-kd2ep2b8u1]  { color: #2563eb; }

/* ── Collapsible Section Headers ────────────────────────── */
.sec-hdr[b-kd2ep2b8u1] {
    display: flex; align-items: center; gap: .7rem;
    padding: .65rem 1.1rem; cursor: pointer;
    border-bottom: 1px solid #edf0f5;
    border-top: 1px solid #edf0f5;
    background: linear-gradient(180deg, #f8fafb, #f4f6f9);
    user-select: none; transition: all .15s;
    position: relative;
}
.sec-hdr[b-kd2ep2b8u1]::before {
    content: '';
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px; border-radius: 0 2px 2px 0;
    opacity: 0; transition: opacity .2s;
}
.sec-hdr:hover[b-kd2ep2b8u1] { background: linear-gradient(180deg, #f1f5f9, #edf1f6); }
.sec-hdr:hover[b-kd2ep2b8u1]::before { opacity: 1; }
.sec-hdr.sec-hdr-collapsed[b-kd2ep2b8u1] { background: #fafafa; }
.sec-hdr.sec-hdr-collapsed:hover[b-kd2ep2b8u1] { background: #f0f4ff; }

/* Section accent colors on the left edge */
.sec-hdr:nth-of-type(1)[b-kd2ep2b8u1]::before,
.sec-hdr:has(.sec-icon-cotton)[b-kd2ep2b8u1]::before { background: #22c55e; }
.sec-hdr:has(.sec-icon-synth)[b-kd2ep2b8u1]::before  { background: #8b5cf6; }
.sec-hdr:has(.sec-icon-box)[b-kd2ep2b8u1]::before    { background: #f59e0b; }
.sec-hdr:has(.sec-icon-tag)[b-kd2ep2b8u1]::before    { background: #a855f7; }
.sec-hdr:has(.sec-icon-hanger)[b-kd2ep2b8u1]::before { background: #ef4444; }
.sec-hdr:has(.sec-icon-paper)[b-kd2ep2b8u1]::before  { background: #22c55e; }

.sec-chevron[b-kd2ep2b8u1] {
    font-size: .78rem; color: #94a3b8; transition: transform .25s cubic-bezier(.22,1,.36,1);
    flex-shrink: 0;
}
.sec-hdr-collapsed .sec-chevron[b-kd2ep2b8u1] { transform: rotate(-90deg); }

.sec-icon[b-kd2ep2b8u1] {
    width: 28px; height: 28px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: .85rem; flex-shrink: 0;
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.sec-icon-cotton[b-kd2ep2b8u1]  { background: linear-gradient(135deg, #d1fae5, #a7f3d0); color: #065f46; }
.sec-icon-synth[b-kd2ep2b8u1]   { background: linear-gradient(135deg, #ede9fe, #ddd6fe); color: #5b21b6; }
.sec-icon-box[b-kd2ep2b8u1]     { background: linear-gradient(135deg, #fef3c7, #fde68a); color: #92400e; }
.sec-icon-tag[b-kd2ep2b8u1]     { background: linear-gradient(135deg, #f3e8ff, #e9d5ff); color: #6b21a8; }
.sec-icon-hanger[b-kd2ep2b8u1]  { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #991b1b; }
.sec-icon-paper[b-kd2ep2b8u1]   { background: linear-gradient(135deg, #f0fdf4, #dcfce7); color: #15803d; }

.sec-title[b-kd2ep2b8u1] { font-size: .85rem; font-weight: 700; color: #1e293b; }
.sec-unit[b-kd2ep2b8u1]  {
    font-size: .68rem; color: #94a3b8;
    background: #fff; padding: .2rem .5rem; border-radius: 5px;
    border: 1px solid #edf0f5;
}

/* section fill progress bar */
.sec-fill-bar[b-kd2ep2b8u1] {
    flex: 1; max-width: 90px; height: 5px;
    background: #e8ecf1; border-radius: 9999px; overflow: hidden;
    margin-left: auto;
}
.sec-fill-fill[b-kd2ep2b8u1] {
    height: 100%;
    background: linear-gradient(90deg, #22d3ee, #3b82f6);
    border-radius: 9999px; transition: width .4s cubic-bezier(.22,1,.36,1);
}

/* fill count badge */
.sec-count[b-kd2ep2b8u1] {
    font-size: .7rem; font-weight: 600; padding: .22rem .6rem;
    border-radius: 9999px; background: #f1f5f9; color: #94a3b8;
    white-space: nowrap; flex-shrink: 0;
    border: 1px solid transparent;
}
.sec-count-partial[b-kd2ep2b8u1] {
    background: #fffbeb; color: #b45309;
    border-color: #fde68a;
}
.sec-count-done[b-kd2ep2b8u1] {
    background: #f0fdf4; color: #15803d;
    border-color: #bbf7d0;
}


/* ── Grid data rows ─────────────────────────────────────── */
.gs-row[b-kd2ep2b8u1] {
    display: grid;
    grid-template-columns: 220px 90px 130px 130px 110px 140px 130px 80px 110px;
    border-bottom: 1px solid #f0f2f5;
    align-items: center;
    min-height: 50px;
    transition: all .15s;
}
.gs-row:last-of-type[b-kd2ep2b8u1] { border-bottom: none; }
.gs-row:hover[b-kd2ep2b8u1] { background: #f8faff; }

/* Filled row gets a subtle green left accent + background */
.gs-row.gs-row-filled[b-kd2ep2b8u1] {
    background: linear-gradient(90deg, #f0fdf4 0%, #f8fdfb 100%);
    position: relative;
}
.gs-row.gs-row-filled[b-kd2ep2b8u1]::before {
    content: '';
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px; background: #22c55e;
    border-radius: 0 2px 2px 0;
}
.gs-row.gs-row-filled:hover[b-kd2ep2b8u1] { background: linear-gradient(90deg, #dcfce7 0%, #f0fdf4 100%); }

.gs-cell[b-kd2ep2b8u1] {
    padding: .5rem .8rem;
    border-right: 1px solid #f0f2f5;
    font-size: .84rem; color: #334155;
    display: flex; align-items: center; gap: .45rem;
    min-height: 50px;
    min-width: 0;
    overflow: hidden;
}
.gs-cell:last-child[b-kd2ep2b8u1] { border-right: none; }

/* disabled cell (N/A for fiber vs packaging) */
.gs-disabled[b-kd2ep2b8u1] {
    color: #d1d5db !important; font-size: .78rem;
    justify-content: center; background: #fafafa;
    position: relative;
}
/* Subtle diagonal stripe pattern for disabled cells */
.gs-disabled[b-kd2ep2b8u1]::after {
    content: '';
    position: absolute; inset: 0;
    background: repeating-linear-gradient(
        -45deg,
        transparent,
        transparent 4px,
        rgba(0,0,0,.015) 4px,
        rgba(0,0,0,.015) 5px
    );
    pointer-events: none;
}

/* material name cell */
.gs-name[b-kd2ep2b8u1] { font-size: .85rem; font-weight: 550; color: #1e293b; letter-spacing: -.01em; }

/* ── Dot indicator ──────────────────────────────────────── */
.dot[b-kd2ep2b8u1] {
    width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0;
    box-shadow: 0 0 0 2.5px rgba(255,255,255,.9);
}
.dot.cotton[b-kd2ep2b8u1]       { background: #10b981; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(16,185,129,.3); }
.dot.cotton.eco[b-kd2ep2b8u1]   { background: #0284c7; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(2,132,199,.3); }
.dot.cotton.green[b-kd2ep2b8u1] { background: #22c55e; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(34,197,94,.3); }
.dot.synth[b-kd2ep2b8u1]        { background: #6366f1; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(99,102,241,.3); }
.dot.synth.green[b-kd2ep2b8u1]  { background: #22c55e; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(34,197,94,.3); }
.dot.box[b-kd2ep2b8u1]          { background: #f59e0b; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(245,158,11,.3); }
.dot.tag[b-kd2ep2b8u1]          { background: #a855f7; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(168,85,247,.3); }
.dot.hanger[b-kd2ep2b8u1]       { background: #ef4444; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(239,68,68,.3); }
.dot.paper[b-kd2ep2b8u1]        { background: #94a3b8; box-shadow: 0 0 0 2px rgba(255,255,255,.8); }
.dot.paper.green[b-kd2ep2b8u1]  { background: #22c55e; box-shadow: 0 0 0 2px rgba(255,255,255,.8), 0 0 6px rgba(34,197,94,.3); }

/* ── Category badges ────────────────────────────────────── */
.cat-badge[b-kd2ep2b8u1] {
    font-size: .66rem; font-weight: 700; padding: .22rem .55rem;
    border-radius: 5px; white-space: nowrap;
    letter-spacing: .02em;
}
.cat-cotton[b-kd2ep2b8u1]  { background: #d1fae5; color: #065f46; }
.cat-synth[b-kd2ep2b8u1]   { background: #ede9fe; color: #5b21b6; }
.cat-natural[b-kd2ep2b8u1] { background: #fef9c3; color: #854d0e; }
.cat-other[b-kd2ep2b8u1]   { background: #f1f5f9; color: #475569; }
.cat-box[b-kd2ep2b8u1]     { background: #fef3c7; color: #92400e; }
.cat-tag[b-kd2ep2b8u1]     { background: #f3e8ff; color: #6b21a8; }
.cat-hanger[b-kd2ep2b8u1]  { background: #fee2e2; color: #991b1b; }

/* ── Input cells ────────────────────────────────────────── */
.inp-wrap[b-kd2ep2b8u1] {
    display: flex; align-items: center;
    border: 2px solid #e2e8f0; border-radius: 9px;
    overflow: hidden; background: #fff; width: 100%;
    transition: all .2s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 1px 3px rgba(0,0,0,.02), inset 0 2px 4px rgba(0,0,0,.01);
}
.inp-wrap:hover[b-kd2ep2b8u1] {
    border-color: #cbd5e1;
    box-shadow: 0 2px 6px rgba(0,0,0,.04), inset 0 2px 4px rgba(0,0,0,.01);
}
.inp-wrap:focus-within[b-kd2ep2b8u1] {
    border-color: #6366f1;
    box-shadow: 0 0 0 4px rgba(99,102,241,.15), inset 0 2px 4px rgba(0,0,0,.02);
}

/* Disabled / Readonly input state styles */
.inp-wrap:has(.gs-input[readonly])[b-kd2ep2b8u1] {
    background: #f1f5f9;
    border-color: #e2e8f0;
    box-shadow: none;
}
.inp-wrap:has(.gs-input[readonly]):hover[b-kd2ep2b8u1] {
    border-color: #cbd5e1;
}
.gs-input[readonly][b-kd2ep2b8u1] {
    color: #64748b;
}
.inp-wrap:has(.gs-input[readonly]) .inp-u[b-kd2ep2b8u1] {
    background: #e2e8f0;
    color: #64748b;
    border-color: #cbd5e1;
}

.gs-input[b-kd2ep2b8u1] {
    border: none; outline: none; background: transparent;
    font-size: .88rem; padding: .45rem .6rem; width: 0; flex: 1;
    color: #0f172a; font-weight: 600;
    font-family: inherit;
}
.gs-input[b-kd2ep2b8u1]::-webkit-outer-spin-button,
.gs-input[b-kd2ep2b8u1]::-webkit-inner-spin-button { -webkit-appearance: none; }
.inp-u[b-kd2ep2b8u1] {
    padding: .45rem .55rem; font-size: .72rem; color: #64748b; font-weight: 600;
    background: linear-gradient(180deg, #f8fafc, #f1f5f9); border-left: 1px solid #e2e8f0; white-space: nowrap;
}

/* ── Percent column ──────────────────────────────────────── */
.gs-fiber-p[b-kd2ep2b8u1] { flex-direction: column; align-items: flex-start; gap: .25rem; padding: .35rem .8rem; }
.pct-val[b-kd2ep2b8u1]   { font-size: .78rem; font-weight: 700; color: #334155; }
.pct-bar[b-kd2ep2b8u1]   { width: 100%; height: 5px; background: #e8ecf1; border-radius: 9999px; overflow: hidden; }
.pct-fill[b-kd2ep2b8u1]  { height: 100%; border-radius: 9999px; transition: width .4s cubic-bezier(.22,1,.36,1); }
.pct-fill.cotton[b-kd2ep2b8u1] { background: linear-gradient(90deg, #10b981, #22c55e); }
.pct-fill.synth[b-kd2ep2b8u1]  { background: linear-gradient(90deg, #6366f1, #818cf8); }

/* ── Mini progress bar (absolute scale) ─────────────────── */
.gs-bar[b-kd2ep2b8u1] { padding: .35rem .8rem; }
.mini-bar[b-kd2ep2b8u1]  { width: 100%; height: 5px; background: #e8ecf1; border-radius: 9999px; overflow: hidden; }
.mini-fill[b-kd2ep2b8u1] { height: 100%; border-radius: 9999px; transition: width .4s cubic-bezier(.22,1,.36,1); }
.mini-fill.cotton[b-kd2ep2b8u1]       { background: linear-gradient(90deg, #10b981, #34d399); }
.mini-fill.cotton.eco[b-kd2ep2b8u1]   { background: linear-gradient(90deg, #0284c7, #38bdf8); }
.mini-fill.cotton.green[b-kd2ep2b8u1] { background: linear-gradient(90deg, #22c55e, #4ade80); }
.mini-fill.synth[b-kd2ep2b8u1]        { background: linear-gradient(90deg, #6366f1, #a78bfa); }
.mini-fill.synth.green[b-kd2ep2b8u1]  { background: linear-gradient(90deg, #22c55e, #4ade80); }

/* ── Eco cert column ────────────────────────────────────── */
.cert-none[b-kd2ep2b8u1]  { color: #d1d5db; font-size: .82rem; }
.cert-badge[b-kd2ep2b8u1] {
    font-size: .66rem; font-weight: 700; padding: .22rem .5rem;
    border-radius: 5px;
    box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
.cert-blue[b-kd2ep2b8u1]   { background: linear-gradient(135deg, #dbeafe, #bfdbfe); color: #1d4ed8; }
.cert-green[b-kd2ep2b8u1]  { background: linear-gradient(135deg, #dcfce7, #bbf7d0); color: #15803d; }
.cert-gray[b-kd2ep2b8u1]   { background: #f1f5f9; color: #475569; }
.cert-purple[b-kd2ep2b8u1] { background: linear-gradient(135deg, #f3e8ff, #e9d5ff); color: #7c3aed; }
.cert-red[b-kd2ep2b8u1]    { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #b91c1c; }

/* ── Eco type column ────────────────────────────────────── */
.eco-tag[b-kd2ep2b8u1] {
    font-size: .67rem; font-weight: 600; padding: .22rem .5rem;
    background: #f1f5f9; color: #475569; border-radius: 5px;
    white-space: nowrap;
    border: 1px solid #e8ecf1;
}
.eco-tag.eco-green[b-kd2ep2b8u1] {
    background: linear-gradient(135deg, #f0fdf4, #dcfce7);
    color: #15803d;
    border-color: #bbf7d0;
}

/* ── Totals row ─────────────────────────────────────────── */
.totals-row[b-kd2ep2b8u1] {
    display: grid;
    grid-template-columns: 220px 90px 130px 130px 110px 140px 130px 80px 110px;
    border-top: 2px solid #dfe4ed;
    border-bottom: 1px solid #edf0f5;
    background: linear-gradient(180deg, #f6f8fb, #f0f3f7);
    min-height: 46px;
    align-items: center;
}
.totals-label[b-kd2ep2b8u1] {
    padding: .5rem .8rem; font-size: .78rem; font-weight: 700;
    color: #475569; display: flex; align-items: center; gap: .4rem;
    border-right: 1px solid #e2e8f0;
}
.totals-label i[b-kd2ep2b8u1] { color: #94a3b8; }
.totals-value[b-kd2ep2b8u1] {
    padding: .5rem .8rem; font-size: .82rem; font-weight: 600;
    color: #94a3b8; border-right: 1px solid #edf0f5;
    display: flex; align-items: center; gap: .4rem; flex-wrap: wrap;
}
.totals-value:last-child[b-kd2ep2b8u1] { border-right: none; }
.totals-active[b-kd2ep2b8u1] { color: #1e293b !important; }
.totals-ok[b-kd2ep2b8u1]   { color: #15803d !important; }
.totals-warn[b-kd2ep2b8u1] { color: #c2410c !important; }
.totals-badge[b-kd2ep2b8u1] {
    font-size: .67rem; font-weight: 700;
    padding: .18rem .45rem; border-radius: 5px;
    box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
.badge-ok[b-kd2ep2b8u1]   { background: linear-gradient(135deg, #dcfce7, #bbf7d0); color: #15803d; }
.badge-warn[b-kd2ep2b8u1] { background: linear-gradient(135deg, #fee2e2, #fecaca); color: #b91c1c; }
.totals-formula[b-kd2ep2b8u1] { font-size: .67rem; font-weight: 400; color: #94a3b8; display: block; width: 100%; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 900px) {
    .at-topbar[b-kd2ep2b8u1] { padding: .5rem 1rem; }
    .grid-sheet-wrap[b-kd2ep2b8u1] { margin: .75rem .75rem 0; }
    .at-po-meta span:nth-child(n+5)[b-kd2ep2b8u1] { display: none; }
    .val-banners[b-kd2ep2b8u1] { padding: .5rem .75rem 0; }
    .sv-header-inner[b-kd2ep2b8u1] { padding: .7rem 1rem; }
}

/* ── Scrollbar styling ──────────────────────────────────── */
.grid-sheet-wrap[b-kd2ep2b8u1]::-webkit-scrollbar { height: 8px; }
.grid-sheet-wrap[b-kd2ep2b8u1]::-webkit-scrollbar-track {
    background: #f1f5f9; border-radius: 4px;
}
.grid-sheet-wrap[b-kd2ep2b8u1]::-webkit-scrollbar-thumb {
    background: #cbd5e1; border-radius: 4px;
}
.grid-sheet-wrap[b-kd2ep2b8u1]::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}

/* ── Selection / focus enhancements ─────────────────────── */
.gs-row:focus-within[b-kd2ep2b8u1] {
    background: #f0f7ff;
    box-shadow: 0 0 0 1px rgba(59,130,246,.1) inset;
}
.gs-row.gs-row-filled:focus-within[b-kd2ep2b8u1] {
    background: linear-gradient(90deg, #dcfce7 0%, #f0f7ff 100%);
}


/* ═══════════════════════════════════════════════════════════
   KANBAN BOARD – 4-column card layout
   ═══════════════════════════════════════════════════════════ */

.survey-sections[b-kd2ep2b8u1] {
    padding: 1.25rem 1.5rem;
}

.kanban-board[b-kd2ep2b8u1] {
    display: flex;
    gap: 1.25rem;
    align-items: stretch;
}

/* ── Column ─────────────────────────────────────────────── */
.kb-col[b-kd2ep2b8u1] {
    background: #fff;
    border-radius: 14px;
    border: 1px solid #e2e8f0;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.05), 0 1px 3px rgba(0,0,0,.04);
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
    transition: flex .35s cubic-bezier(.22,1,.36,1), min-width .35s cubic-bezier(.22,1,.36,1), max-width .35s cubic-bezier(.22,1,.36,1);
}

/* collapsed column shrinks to narrow strip */
.kb-col.kb-col-collapsed[b-kd2ep2b8u1] {
    flex: 0 0 auto;
    max-width: 60px;
    min-width: 60px;
}

/* ── Column header ──────────────────────────────────────── */
.kb-col-header[b-kd2ep2b8u1] {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .85rem 1rem;
    border-bottom: 1px solid rgba(0,0,0,.07);
    cursor: pointer;
    user-select: none;
    transition: background .15s, padding .35s;
}
.kb-col-header:hover[b-kd2ep2b8u1] { filter: brightness(.97); }

.kb-col-collapsed .kb-col-header[b-kd2ep2b8u1] {
    flex-direction: column;
    padding: 1.25rem 0;
    gap: 1.25rem;
    flex: 1;
    border-bottom: none;
}

/* ── Chevron toggle icon ───────────────────────────────── */
.kb-chev[b-kd2ep2b8u1] {
    font-size: .7rem;
    color: #94a3b8;
    flex-shrink: 0;
    transition: transform .25s cubic-bezier(.22,1,.36,1);
    width: 14px;
    text-align: center;
}
.kb-col-style  .kb-col-header[b-kd2ep2b8u1] { background: linear-gradient(135deg, #f8fafc, #f1f5f9); border-bottom-color: #e2e8f0; cursor: default; }
.kb-col-cotton .kb-col-header[b-kd2ep2b8u1] { background: linear-gradient(135deg, #f0fdf4, #dcfce7); border-bottom-color: #bbf7d0; }
.kb-col-synth  .kb-col-header[b-kd2ep2b8u1] { background: linear-gradient(135deg, #f5f3ff, #ede9fe); border-bottom-color: #ddd6fe; }
.kb-col-boxlbl .kb-col-header[b-kd2ep2b8u1] { background: linear-gradient(135deg, #fffbeb, #fef3c7); border-bottom-color: #fde68a; }
.kb-col-hangr  .kb-col-header[b-kd2ep2b8u1] { background: linear-gradient(135deg, #fff1f2, #fee2e2); border-bottom-color: #fecaca; }

.kb-col-icon[b-kd2ep2b8u1] {
    width: 32px; height: 32px; border-radius: 9px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem; flex-shrink: 0;
}
.kb-col-style  .kb-col-icon[b-kd2ep2b8u1] { background: rgba(100,116,139,.18); color: #475569; }
.kb-col-cotton .kb-col-icon[b-kd2ep2b8u1] { background: rgba(34,197,94,.18); color: #16a34a; }
.kb-col-synth  .kb-col-icon[b-kd2ep2b8u1] { background: rgba(139,92,246,.18); color: #7c3aed; }
.kb-col-boxlbl .kb-col-icon[b-kd2ep2b8u1] { background: rgba(245,158,11,.18); color: #d97706; }
.kb-col-hangr  .kb-col-icon[b-kd2ep2b8u1] { background: rgba(239,68,68,.18); color: #dc2626; }

.kb-col-info[b-kd2ep2b8u1] { flex: 1; min-width: 0; }
.kb-col-title[b-kd2ep2b8u1] { display: block; font-size: .82rem; font-weight: 700; color: #1e293b; white-space: nowrap; }
.kb-col-unit[b-kd2ep2b8u1]  { font-size: .63rem; color: #94a3b8; font-weight: 500; }
.kb-of[b-kd2ep2b8u1]        { font-weight: 400; color: #cbd5e1; }

.kb-col-collapsed .kb-col-info[b-kd2ep2b8u1] {
    writing-mode: vertical-rl;
    text-orientation: upright;
    display: flex;
    align-items: center;
    flex: 0 0 auto;
    letter-spacing: 1px;
}
.kb-col-collapsed .kb-col-title[b-kd2ep2b8u1] {
    white-space: nowrap;
    text-transform: uppercase;
    font-size: .75rem;
    letter-spacing: 2px;
}
.kb-col-collapsed .kb-col-unit[b-kd2ep2b8u1],
.kb-col-collapsed .sec-count[b-kd2ep2b8u1] {
    display: none;
}
.kb-col-collapsed .kb-collapsed-body[b-kd2ep2b8u1],
.kb-col-collapsed .kb-footer[b-kd2ep2b8u1] {
    display: none !important;
}

/* ── Cards container ────────────────────────────────────── */
.kb-cards[b-kd2ep2b8u1] {
    padding: .8rem;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    align-content: start;
    gap: .8rem;
    flex: 1;
    overflow-y: auto;
}
.kb-cards[b-kd2ep2b8u1]::-webkit-scrollbar       { width: 4px; }
.kb-cards[b-kd2ep2b8u1]::-webkit-scrollbar-track { background: transparent; }
.kb-cards[b-kd2ep2b8u1]::-webkit-scrollbar-thumb { background: #e2e8f0; border-radius: 4px; }

/* ── Card ───────────────────────────────────────────────── */
.kb-card[b-kd2ep2b8u1] {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: .6rem .85rem;
    transition: border-color .2s, box-shadow .2s, transform .2s;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .5rem 1.5rem;
    box-shadow: 0 2px 5px rgba(0,0,0,.02);
}
.kb-card:hover[b-kd2ep2b8u1] {
    border-color: #cbd5e1;
    box-shadow: 0 4px 12px rgba(0,0,0,.05);
    transform: translateY(-1px);
}

/* filled accent per column type */
.kb-col-cotton .kb-card.kb-card-filled[b-kd2ep2b8u1] { background: linear-gradient(160deg, #f0fdf4 0%, #ffffff 100%); border-color: #86efac; }
.kb-col-synth  .kb-card.kb-card-filled[b-kd2ep2b8u1] { background: linear-gradient(160deg, #f5f3ff 0%, #ffffff 100%); border-color: #c4b5fd; }
.kb-col-boxlbl .kb-card.kb-card-filled[b-kd2ep2b8u1] { background: linear-gradient(160deg, #fffbeb 0%, #ffffff 100%); border-color: #fcd34d; }
.kb-col-hangr  .kb-card.kb-card-filled[b-kd2ep2b8u1] { background: linear-gradient(160deg, #fff1f2 0%, #ffffff 100%); border-color: #fca5a5; }

.kb-col-style .kb-card.kb-card-filled[b-kd2ep2b8u1] { background: linear-gradient(160deg, #f8fafc 0%, #ffffff 100%); border-color: #cbd5e1; }

/* ── Style Info Body ───────────────────────────────────── */
.kb-style-body[b-kd2ep2b8u1] {
    padding: .8rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    flex: 1;
    overflow-y: auto;
}
.kb-style-row[b-kd2ep2b8u1] {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    padding: .4rem .6rem;
    background: #fafbfd;
    border: 1px solid #edf0f5;
    border-radius: 8px;
}
.kb-style-lbl[b-kd2ep2b8u1] {
    font-size: .65rem;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.kb-style-val[b-kd2ep2b8u1] {
    font-size: .8rem;
    font-weight: 600;
    color: #1e293b;
    word-break: break-word;
}

.kb-card-top[b-kd2ep2b8u1] {
    display: flex; align-items: center; gap: .4rem;
    margin-bottom: 0;
    min-width: 140px;
    flex: 1;
}
.kb-name[b-kd2ep2b8u1] {
    flex: 1; min-width: 0;
    font-size: .79rem; font-weight: 600; color: #334155;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* eco / type badge inside card header */
.kb-eco-tag[b-kd2ep2b8u1] {
    font-size: .6rem; font-weight: 700; padding: .18rem .44rem;
    border-radius: 5px; flex-shrink: 0;
    background: #f1f5f9; color: #475569;
    letter-spacing: .02em;
}
.kb-eco-tag.kb-eco-green[b-kd2ep2b8u1]  { background: linear-gradient(135deg, #f0fdf4, #dcfce7); color: #15803d; }
.kb-eco-tag.kb-eco-box[b-kd2ep2b8u1]    { background: #fef3c7; color: #92400e; }
.kb-eco-tag.kb-eco-tag[b-kd2ep2b8u1]    { background: #f3e8ff; color: #6b21a8; }
.kb-eco-tag.kb-eco-hanger[b-kd2ep2b8u1] { background: #fee2e2; color: #991b1b; }

/* card input row */
.kb-card-row[b-kd2ep2b8u1] {
    display: flex; 
    align-items: center; 
    gap: .75rem; 
    flex: 0 0 auto;
    width: 180px;
    justify-content: flex-end;
}
.kb-card-row .inp-wrap[b-kd2ep2b8u1] { flex: 1; }

/* fiber percentage text */
.kb-pct[b-kd2ep2b8u1] {
    font-size: .75rem; font-weight: 700; color: #64748b;
    white-space: nowrap; min-width: 36px; text-align: right;
}

/* ── Mini progress bar in card ──────────────────────────── */
.kb-bar[b-kd2ep2b8u1] {
    width: 100%; height: 4px;
    background: #e8ecf2; border-radius: 9999px;
    overflow: hidden; margin-top: .15rem;
}
.kb-bar-fill[b-kd2ep2b8u1] {
    height: 100%; border-radius: 9999px;
    transition: width .4s cubic-bezier(.22,1,.36,1);
}
.kb-bar-fill.cotton[b-kd2ep2b8u1]       { background: linear-gradient(90deg, #10b981, #22c55e); }
.kb-bar-fill.cotton.eco[b-kd2ep2b8u1]   { background: linear-gradient(90deg, #0284c7, #38bdf8); }
.kb-bar-fill.cotton.green[b-kd2ep2b8u1] { background: linear-gradient(90deg, #22c55e, #4ade80); }
.kb-bar-fill.synth[b-kd2ep2b8u1]        { background: linear-gradient(90deg, #6366f1, #a78bfa); }
.kb-bar-fill.synth.green[b-kd2ep2b8u1]  { background: linear-gradient(90deg, #22c55e, #4ade80); }
.kb-bar-fill.box[b-kd2ep2b8u1]          { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
.kb-bar-fill.tag[b-kd2ep2b8u1]          { background: linear-gradient(90deg, #a855f7, #c084fc); }
.kb-bar-fill.hanger[b-kd2ep2b8u1]       { background: linear-gradient(90deg, #ef4444, #f87171); }
.kb-bar-fill.paper[b-kd2ep2b8u1]        { background: linear-gradient(90deg, #94a3b8, #cbd5e1); }

/* PO total annotation */
.kb-po-ann[b-kd2ep2b8u1] {
    width: 100%;
    display: block; font-size: .63rem; color: #94a3b8;
    margin-top: .1rem; font-style: italic;
}

/* ── Collapsed summary body ─────────────────────────────── */
.kb-collapsed-body[b-kd2ep2b8u1] {
    padding: .4rem .5rem;
    flex: 1;
    overflow-y: auto;
}
.kb-cl-row[b-kd2ep2b8u1] {
    display: flex;
    align-items: center;
    gap: .45rem;
    padding: .3rem .55rem;
    border-radius: 7px;
    font-size: .75rem;
    color: #94a3b8;
    transition: background .15s;
}
.kb-cl-row:hover[b-kd2ep2b8u1] { background: #f8fafc; }
.kb-cl-row.kb-cl-filled[b-kd2ep2b8u1] { color: #334155; }
.kb-col-cotton .kb-cl-row.kb-cl-filled[b-kd2ep2b8u1] { background: #f0fdf4; }
.kb-col-synth  .kb-cl-row.kb-cl-filled[b-kd2ep2b8u1] { background: #f5f3ff; }
.kb-col-boxlbl .kb-cl-row.kb-cl-filled[b-kd2ep2b8u1] { background: #fffbeb; }
.kb-col-hangr  .kb-cl-row.kb-cl-filled[b-kd2ep2b8u1] { background: #fff1f2; }
.kb-cl-name[b-kd2ep2b8u1] {
    flex: 1; min-width: 0;
    font-weight: 550;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.kb-cl-val[b-kd2ep2b8u1] {
    font-weight: 700;
    font-size: .73rem;
    white-space: nowrap;
    min-width: 32px; text-align: right;
}
.kb-cl-row.kb-cl-filled .kb-cl-val[b-kd2ep2b8u1] { color: #1e293b; }

/* ── Expanded card meta detail line ─────────────────────── */
.kb-card-meta[b-kd2ep2b8u1] {
    width: 100%;
    display: flex;
    align-items: center;
    gap: .3rem;
    flex-wrap: wrap;
    margin-top: .1rem;
    font-size: .63rem;
    color: #94a3b8;
    line-height: 1.5;
}
.kb-meta-eco[b-kd2ep2b8u1] {
    font-weight: 500;
}
.kb-meta-cert[b-kd2ep2b8u1] {
    font-weight: 600;
    color: #15803d;
}
.kb-meta-sep[b-kd2ep2b8u1] {
    color: #cbd5e1;
}
.kb-meta-mix[b-kd2ep2b8u1] {
    font-weight: 600;
    color: #64748b;
}
.kb-meta-gw[b-kd2ep2b8u1] {
    font-weight: 500;
    color: #0284c7;
}
.kb-meta-po[b-kd2ep2b8u1] {
    font-weight: 500;
    font-style: italic;
}

/* ── Column footer ──────────────────────────────────────── */
.kb-footer[b-kd2ep2b8u1] {
    display: flex; justify-content: space-between; align-items: center;
    padding: .6rem 1rem;
    background: #f8fafc;
    border-top: 1px solid #edf0f5;
}
.kb-foot-lbl[b-kd2ep2b8u1] {
    display: flex; align-items: center; gap: .3rem;
    font-size: .72rem; font-weight: 600; color: #94a3b8;
}
.kb-foot-lbl i[b-kd2ep2b8u1] { font-size: .7rem; }
.kb-foot-val[b-kd2ep2b8u1] {
    font-size: .78rem; font-weight: 700; color: #cbd5e1;
    transition: color .3s;
}
.kb-foot-val.kb-foot-live[b-kd2ep2b8u1] { color: #1e293b; }

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 1200px) {
    .kanban-board[b-kd2ep2b8u1] { flex-wrap: wrap; }
    .kb-col[b-kd2ep2b8u1] { flex: 1 1 calc(50% - .65rem); min-width: 260px; }
    .kb-col.kb-col-collapsed[b-kd2ep2b8u1] { min-width: 60px; max-width: 60px; flex: 0 0 auto; }
}
@media (max-width: 700px) {
    .kanban-board[b-kd2ep2b8u1] { flex-direction: column; }
    .kb-col[b-kd2ep2b8u1] { flex: none; width: 100%; max-width: none; min-width: 0; }

    /* Reset collapsed column to horizontal strip for mobile */
    .kb-col.kb-col-collapsed[b-kd2ep2b8u1] { flex: none; width: 100%; max-width: none; min-width: 0; }
    .kb-col-collapsed .kb-col-header[b-kd2ep2b8u1] { flex-direction: row; padding: .85rem 1rem; gap: .65rem; height: auto; }
    .kb-col-collapsed .kb-col-info[b-kd2ep2b8u1] { writing-mode: horizontal-tb; text-orientation: mixed; display: block; letter-spacing: normal; }
    .kb-col-collapsed .kb-col-title[b-kd2ep2b8u1] { text-transform: none; font-size: .82rem; letter-spacing: normal; white-space: normal; }
    .kb-col-collapsed .kb-col-unit[b-kd2ep2b8u1], .kb-col-collapsed .sec-count[b-kd2ep2b8u1] { display: inline-flex; }

    .survey-sections[b-kd2ep2b8u1] { padding: .75rem; }
}

/* ═══════════════════════════════════════════════════════════
   TABLE VIEW — Spreadsheet-style survey
   ═══════════════════════════════════════════════════════════ */

.survey-sections[b-kd2ep2b8u1] {
    padding: .85rem 1.25rem 0;
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

/* ── Table card container ──────────────────────────────── */
.sv-tbl-scroll[b-kd2ep2b8u1] {
    flex: 1;
    min-height: 0;
    overflow-x: auto;
    overflow-y: auto;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04);
}

/* ═══ RESPONSIVE ═════════════════════════════════════════ */

/* ── Tablet (≤1024px) ─────────────────────────────────── */
@media (max-width: 1024px) {
    .survey-sections[b-kd2ep2b8u1] { padding: .75rem; }
    .sv-header-inner[b-kd2ep2b8u1] { padding: .55rem 1rem; gap: .8rem; }
    .sv-metrics[b-kd2ep2b8u1] { flex-wrap: wrap; }
    .sv-metric[b-kd2ep2b8u1] { padding: .45rem .8rem; min-width: 120px; }
    .sv-th-item[b-kd2ep2b8u1] { min-width: 115px; width: 115px; font-size: .62rem; }
    .sv-col-h[b-kd2ep2b8u1] { min-width: 78px; width: 78px; font-size: .6rem; padding: .3rem .25rem; }
    .sv-td .gs-input[b-kd2ep2b8u1] { font-size: .72rem; padding: .28rem .3rem; }
}

/* ── Mobile (≤768px) ──────────────────────────────────── */
@media (max-width: 768px) {
    .survey-sections[b-kd2ep2b8u1] { padding: .5rem; }

    .sv-header-inner[b-kd2ep2b8u1] {
        flex-direction: column;
        align-items: flex-start;
        padding: .5rem .75rem;
        gap: .5rem;
    }
    .sv-header-right[b-kd2ep2b8u1] {
        width: 100%;
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: .4rem;
    }
    .sv-po-row[b-kd2ep2b8u1] { flex-wrap: wrap; gap: .4rem; }
    .sv-po-num[b-kd2ep2b8u1] { font-size: .9rem; }
    .sv-factory[b-kd2ep2b8u1] { font-size: .75rem; }
    .sv-meta[b-kd2ep2b8u1] { font-size: .68rem; padding: .15rem .35rem; }

    .sv-metrics[b-kd2ep2b8u1] {
        flex-direction: column;
    }
    .sv-metric[b-kd2ep2b8u1] {
        padding: .4rem .75rem;
        border-bottom: 1px solid #e5e7eb;
    }
    .sv-metric-div[b-kd2ep2b8u1] { display: none; }
    .sv-metric-val[b-kd2ep2b8u1] { font-size: .85rem; }

    .sv-tbl[b-kd2ep2b8u1] { font-size: .72rem; }
    .sv-th[b-kd2ep2b8u1] { padding: .35rem .4rem; font-size: .65rem; }
    .sv-th-item[b-kd2ep2b8u1] { min-width: 100px; width: 100px; font-size: .6rem; padding: .35rem .4rem; }
    .sv-th-group[b-kd2ep2b8u1] { padding: .4rem .5rem .25rem; font-size: .65rem; }
    .sv-col-h[b-kd2ep2b8u1] { min-width: 72px; width: 72px; font-size: .56rem; padding: .28rem .2rem; }
    .sv-td[b-kd2ep2b8u1] { height: 32px; }
    .sv-td-item[b-kd2ep2b8u1] { padding: 0 .4rem; }
    .sv-item-badge[b-kd2ep2b8u1] { font-size: .65rem; }
    .sv-td .gs-input[b-kd2ep2b8u1] { font-size: .68rem; padding: .25rem .25rem; }
    .sv-tfoot-val[b-kd2ep2b8u1] { font-size: .68rem; padding: .4rem .25rem; }
    .sv-tfoot-grand[b-kd2ep2b8u1] { font-size: .72rem; }

    .sv-btn[b-kd2ep2b8u1] { font-size: .7rem; padding: .35rem .6rem; }
    .sv-gw-block[b-kd2ep2b8u1] { padding: .25rem .4rem; }
    .sv-gw-input[b-kd2ep2b8u1] { width: 50px; font-size: .72rem; }
}

/* ── Small Mobile (≤480px) ────────────────────────────── */
@media (max-width: 480px) {
    .survey-sections[b-kd2ep2b8u1] { padding: .25rem; }

    .sv-header-inner[b-kd2ep2b8u1] { padding: .4rem .5rem; }
    .sv-breadcrumb[b-kd2ep2b8u1] { font-size: .55rem; }
    .sv-po-num[b-kd2ep2b8u1] { font-size: .82rem; }
    .sv-factory[b-kd2ep2b8u1] { display: none; }
    .sv-pipe[b-kd2ep2b8u1] { display: none; }
    .sv-guide-text[b-kd2ep2b8u1] { display: none; }

    .sv-metrics[b-kd2ep2b8u1] { gap: 0; }
    .sv-metric[b-kd2ep2b8u1] { padding: .3rem .5rem; }
    .sv-metric-label[b-kd2ep2b8u1] { font-size: .5rem; }
    .sv-metric-val[b-kd2ep2b8u1] { font-size: .78rem; }

    .sv-tbl[b-kd2ep2b8u1] { font-size: .65rem; }
    .sv-th-item[b-kd2ep2b8u1] { min-width: 85px; width: 85px; font-size: .5rem; }
    .sv-col-h[b-kd2ep2b8u1] { min-width: 64px; width: 64px; font-size: .48rem; }
    .sv-td[b-kd2ep2b8u1] { height: 28px; }
    .sv-td .gs-input[b-kd2ep2b8u1] { font-size: .62rem; }
    .sv-th-group[b-kd2ep2b8u1] { font-size: .55rem; }
    .sv-th-group i[b-kd2ep2b8u1] { display: none; }

    .state-card[b-kd2ep2b8u1] { padding: 2rem 1.5rem; }
    .state-card h3[b-kd2ep2b8u1] { font-size: 1.2rem; }
}



/* ═══════════════════════════════════════════════════════════
   TABLE — Airtable / Syncfusion inspired design
   ═══════════════════════════════════════════════════════════ */
.sv-tbl[b-kd2ep2b8u1] {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: .78rem;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    table-layout: auto;
    background: #fff;
}

/* ── Group header row ──────────────────────────────────── */
.sv-tbl-group-row[b-kd2ep2b8u1] { background: #fafbfc; }
.sv-tbl-col-row[b-kd2ep2b8u1]   { background: #fafbfc; }

/* ── Base header cell ──────────────────────────────────── */
.sv-th[b-kd2ep2b8u1] {
    padding: .5rem .55rem;
    text-align: center;
    font-weight: 700;
    color: #374151;
    white-space: nowrap;
    border-bottom: 1px solid #e5e7eb;
    border-right: 1px solid #f0f0f0;
    vertical-align: middle;
    font-size: .72rem;
    letter-spacing: .01em;
}

/* ── Row Index sticky column ────────────────────────────── */
.sv-th-index[b-kd2ep2b8u1] {
    min-width: 38px;
    width: 38px;
    position: sticky;
    left: 0;
    z-index: 5;
    background: #fafbfc;
    border-right: 1px solid #e5e7eb;
    text-align: center;
    color: #9CA3AF;
    font-size: .65rem;
    font-weight: 600;
}

/* ── Item # sticky header ──────────────────────────────── */
.sv-th-item[b-kd2ep2b8u1] {
    text-align: left;
    min-width: 135px;
    width: 135px;
    color: #4B5563;
    font-size: .68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    position: sticky;
    left: 38px;
    z-index: 5;
    background: #fafbfc;
    border-right: 1px solid #e5e7eb;
}

/* ── Calculator sticky header ──────────────────────────── */
.sv-th-calc[b-kd2ep2b8u1] {
    min-width: 32px;
    width: 32px;
    position: sticky;
    left: 173px;
    z-index: 5;
    background: #fafbfc;
    border-right: 1px solid #e5e7eb;
    text-align: center;
    color: #6B7280;
    font-size: .8rem;
}

/* ── Group label cells — colored left accent ───────────── */
.sv-th-group[b-kd2ep2b8u1] {
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .03em;
    padding: .6rem .75rem .45rem;
    color: #1F2937;
    position: relative;
}
.sv-th-group i[b-kd2ep2b8u1] { margin-right: .3rem; font-size: .8rem; opacity: .8; }

/* ── Total column header ──────────────────────────────── */
.sv-th-total[b-kd2ep2b8u1] {
    min-width: 65px;
    width: 65px;
    font-size: .68rem;
    color: #6B7280;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
    background: #fafbfc;
    border-left: 1px solid #e5e7eb;
    position: sticky;
    right: 0;
    z-index: 5;
    box-shadow: -2px 0 5px rgba(0,0,0,0.02);
}

/* ── Unit label ────────────────────────────────────────── */
.sv-th-unit[b-kd2ep2b8u1] {
    font-size: .6rem;
    font-weight: 600;
    display: block;
    line-height: 1;
    margin-top: 2px;
    color: #9CA3AF;
}

/* ═══ GROUP HEADER COLORS — Muted accent bands ═══════════
   Soft background tints with strong left-border accent
   ═══════════════════════════════════════════════════════ */
.sv-grp-cotton[b-kd2ep2b8u1] {
    background: #EEF2FF;
    color: #4338CA;
    border-left: 3px solid #6366F1;
    border-bottom: 1px solid #C7D2FE;
}
.sv-grp-synth[b-kd2ep2b8u1] {
    background: #EFF6FF;
    color: #1E40AF;
    border-left: 3px solid #3B82F6;
    border-bottom: 1px solid #BFDBFE;
}
.sv-grp-box[b-kd2ep2b8u1] {
    background: #FFF7ED;
    color: #C2410C;
    border-left: 3px solid #F97316;
    border-bottom: 1px solid #FED7AA;
}
.sv-grp-tag[b-kd2ep2b8u1] {
    background: #F0FDF4;
    color: #166534;
    border-left: 3px solid #22C55E;
    border-bottom: 1px solid #BBF7D0;
}
.sv-grp-hanger[b-kd2ep2b8u1] {
    background: #FFF1F2;
    color: #BE123C;
    border-left: 3px solid #F43F5E;
    border-bottom: 1px solid #FECDD3;
}
.sv-grp-paper[b-kd2ep2b8u1] {
    background: #ECFDF5;
    color: #065F46;
    border-left: 3px solid #10B981;
    border-bottom: 1px solid #A7F3D0;
}

/* ═══ SUB-COLUMN HEADERS — Clean and tight ═══════════════ */
.sv-col-h[b-kd2ep2b8u1] {
    font-size: .66rem;
    font-weight: 700;
    padding: .4rem .35rem;
    min-width: 88px;
    width: 88px;
    line-height: 1.25;
    white-space: normal;
    word-break: break-word;
    color: #374151;
    background: #fafbfc;
    border-bottom: 2px solid transparent;
}

/* Sub-col accent bottom borders per group */
.sv-col-cotton[b-kd2ep2b8u1]       { border-bottom-color: #A5B4FC; }
.sv-col-cotton-eco[b-kd2ep2b8u1]   { border-bottom-color: #A5B4FC; }
.sv-col-cotton-green[b-kd2ep2b8u1] { border-bottom-color: #86EFAC; }
.sv-col-synth[b-kd2ep2b8u1]        { border-bottom-color: #93C5FD; }
.sv-col-synth-green[b-kd2ep2b8u1]  { border-bottom-color: #86EFAC; }
.sv-col-box[b-kd2ep2b8u1]          { border-bottom-color: #FDBA74; }
.sv-col-tag[b-kd2ep2b8u1]          { border-bottom-color: #86EFAC; }
.sv-col-hanger[b-kd2ep2b8u1]       { border-bottom-color: #FDA4AF; }
.sv-col-paper[b-kd2ep2b8u1]        { border-bottom-color: #6EE7B7; }

/* Hide dots — use border accent instead */
.sv-col-h .dot[b-kd2ep2b8u1] { display: none; }

/* ═══ BODY ROWS ══════════════════════════════════════════ */
.sv-tr[b-kd2ep2b8u1] {
    background: #fff;
    transition: background .1s ease;
}
.sv-tr:nth-child(even)[b-kd2ep2b8u1] { background: #FAFBFC; }
.sv-tr:hover[b-kd2ep2b8u1] { background: #F0F5FF !important; }

/* ═══ DATA CELLS ═════════════════════════════════════════ */
.sv-td[b-kd2ep2b8u1] {
    padding: 0;
    border-right: 1px solid #f0f0f0;
    border-bottom: 1px solid #f0f0f0;
    vertical-align: middle;
    text-align: center;
    height: 36px;
}

/* ── Row Index sticky column ────────────────────────────── */
.sv-td-index[b-kd2ep2b8u1] {
    text-align: center;
    font-weight: 500;
    color: #9CA3AF;
    background: #fafbfc;
    position: sticky;
    left: 0;
    z-index: 2;
    border-right: 1px solid #e5e7eb;
    white-space: nowrap;
    padding: 0 .2rem;
    user-select: none;
    font-variant-numeric: tabular-nums;
}
.sv-tr:nth-child(even) .sv-td-index[b-kd2ep2b8u1] { background: #f3f4f6; }
.sv-tr:hover .sv-td-index[b-kd2ep2b8u1] { background: #E5E7EB !important; color: #6B7280; }

/* ── Item # sticky column ─────────────────────────────── */
.sv-td-item[b-kd2ep2b8u1] {
    text-align: left;
    font-weight: 600;
    color: #374151;
    background: #fff;
    position: sticky;
    left: 38px;
    z-index: 2;
    border-right: 1px solid #e5e7eb;
    white-space: nowrap;
    padding: 0 .6rem;
}
.sv-tr:nth-child(even) .sv-td-item[b-kd2ep2b8u1] { background: #FAFBFC; }
.sv-tr:hover .sv-td-item[b-kd2ep2b8u1] { background: #F0F5FF !important; }

/* ── Calculator sticky column ─────────────────────────── */
.sv-td-calc[b-kd2ep2b8u1] {
    min-width: 32px;
    width: 32px;
    position: sticky;
    left: 173px;
    z-index: 2;
    background: #fff;
    border-right: 1px solid #e5e7eb;
    text-align: center;
    color: #4F46E5;
}
.sv-td-calc i:hover[b-kd2ep2b8u1] { color: #4338CA; }
.sv-tr:nth-child(even) .sv-td-calc[b-kd2ep2b8u1] { background: #FAFBFC; }
.sv-tr:hover .sv-td-calc[b-kd2ep2b8u1] { background: #F0F5FF !important; }

/* ── Highlighted Fiber Calculator — teal/emerald accent ── */
.sv-th-calc-highlight[b-kd2ep2b8u1] {
    background: linear-gradient(180deg, #0d9488 0%, #0f766e 100%) !important;
    color: #fff !important;
    border-right: 1px solid #0d9488 !important;
    border-bottom-color: #14b8a6 !important;
    font-size: .65rem;
    padding: .35rem .25rem;
    text-align: center;
    line-height: 1.2;
    cursor: default;
}
.sv-th-calc-highlight i[b-kd2ep2b8u1] {
    font-size: .9rem;
    display: block;
    margin-bottom: 1px;
    filter: drop-shadow(0 1px 1px rgba(0,0,0,.15));
}
.sv-calc-label[b-kd2ep2b8u1] {
    display: block;
    font-size: .5rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
    opacity: .85;
}

.sv-td-calc-highlight[b-kd2ep2b8u1] {
    background: linear-gradient(180deg, #f0fdfa 0%, #ccfbf1 100%) !important;
    border-right: 1px solid #99f6e4 !important;
    cursor: pointer;
    transition: all .2s ease;
}
.sv-td-calc-highlight i[b-kd2ep2b8u1] {
    color: #0d9488;
    font-size: .85rem;
    opacity: 1;
    transition: transform .2s, color .2s;
    cursor: pointer;
}
.sv-td-calc-highlight:hover[b-kd2ep2b8u1] {
    background: linear-gradient(180deg, #ccfbf1 0%, #99f6e4 100%) !important;
    box-shadow: inset 0 0 0 2px #14b8a6;
}
.sv-td-calc-highlight:hover i[b-kd2ep2b8u1] {
    color: #0f766e;
    transform: scale(1.2);
}
.sv-tr:nth-child(even) .sv-td-calc-highlight[b-kd2ep2b8u1] {
    background: linear-gradient(180deg, #ecfdf5 0%, #d1fae5 100%) !important;
}

/* Item badge — clean modern text */
.sv-item-badge[b-kd2ep2b8u1] {
    display: inline-flex;
    align-items: center;
    gap: .2rem;
    color: #374151;
    font-size: .72rem;
    font-weight: 600;
    white-space: nowrap;
}
.sv-item-badge i[b-kd2ep2b8u1] { font-size: .58rem; color: #D1D5DB; }


/* ── Row total cell ───────────────────────────────────── */
.sv-td-total[b-kd2ep2b8u1] {
    position: sticky;
    right: 0;
    z-index: 2;
    font-weight: 700;
    font-size: .75rem;
    color: #111827;
    background: #FAFBFC;
    border-left: 1px solid #e5e7eb;
    white-space: nowrap;
    padding: 0 .5rem;
    min-width: 60px;
    font-variant-numeric: tabular-nums;
    box-shadow: -2px 0 5px rgba(0,0,0,0.02);
}

/* ── Empty state ──────────────────────────────────────── */
.sv-td-empty[b-kd2ep2b8u1] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: #9CA3AF;
    font-style: italic;
    font-size: .82rem;
}
.sv-td-index.empty-row[b-kd2ep2b8u1] {
    background: transparent;
    border-right: none;
}
.sv-td-empty i[b-kd2ep2b8u1] { font-size: 1.2rem; display: block; margin-bottom: .4rem; color: #D1D5DB; }

/* ═══ CELL INPUTS — Airtable seamless inline editing ═════
   Invisible border by default. Shows on hover/focus.
   The cell IS the input. Clean, professional, premium.
   ═══════════════════════════════════════════════════════ */
.sv-td .inp-wrap[b-kd2ep2b8u1] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}
.sv-td .gs-input[b-kd2ep2b8u1] {
    width: 100%;
    height: 100%;
    padding: .35rem .4rem;
    border: none;
    border-radius: 0;
    font-size: .78rem;
    font-family: inherit;
    text-align: right;
    background: transparent;
    color: #374151;
    transition: background .12s, box-shadow .12s;
    -moz-appearance: textfield;
    appearance: textfield;
    cursor: cell;
}
.sv-td .gs-input[b-kd2ep2b8u1]::-webkit-inner-spin-button,
.sv-td .gs-input[b-kd2ep2b8u1]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.sv-td .gs-input[b-kd2ep2b8u1]::placeholder {
    color: #D1D5DB;
    font-size: .72rem;
    font-weight: 400;
}

/* Hover — subtle highlight */
.sv-td .gs-input:hover[b-kd2ep2b8u1] {
    background: rgba(99,102,241,.04);
}

/* Focus — Airtable-style blue ring around cell */
.sv-td .gs-input:focus[b-kd2ep2b8u1] {
    outline: none;
    background: #fff;
    box-shadow: inset 0 0 0 2px #6366F1;
    position: relative;
    z-index: 1;
}

/* Filled value — bolder */
.sv-td .gs-input:not(:placeholder-shown)[b-kd2ep2b8u1] {
    font-weight: 600;
    color: #111827;
}

/* Hide unit label */
.sv-td .inp-u[b-kd2ep2b8u1] { display: none; }

/* ── Sticky totals footer ─────────────────────────────── */
.sv-tfoot-row td[b-kd2ep2b8u1],
.sv-tfoot-row th[b-kd2ep2b8u1] {
    position: sticky;
    bottom: 0px;
    background: #F3F4F6;
    border-top: 2px solid #D1D5DB;
    z-index: 3;
}
.sv-tfoot-row .sv-td-index[b-kd2ep2b8u1] {
    background: #E5E7EB; /* distinct gray for bottom-left corner */
    z-index: 4;
    border-right: 1px solid #D1D5DB;
}
.sv-tfoot-row .sv-td-item[b-kd2ep2b8u1],
.sv-tfoot-row .sv-td-calc[b-kd2ep2b8u1] {
    background: #F3F4F6;
    z-index: 4;
}
.sv-tfoot-lbl[b-kd2ep2b8u1] {
    font-weight: 700;
    color: #6B7280;
    font-size: .62rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    text-align: left;
    padding: .5rem .6rem;
    position: sticky;
    left: 0;
    z-index: 5 !important;
    border-right: 1px solid #E5E7EB;
}
.sv-tfoot-val[b-kd2ep2b8u1] {
    font-weight: 700;
    color: #374151;
    font-size: .75rem;
    padding: .5rem .35rem; 
    text-align: center;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.sv-tfoot-grand[b-kd2ep2b8u1] {
    position: sticky;
    right: 0;
    z-index: 5 !important;
    color: #4338CA;
    font-size: .82rem;
    font-weight: 800;
    background: #EEF2FF !important;
    border-left: 2px solid #A5B4FC;
}

/* ═══════════════════════════════════════════════════════════
   PACKAGING SECTION — Separate card-based layout
   ═══════════════════════════════════════════════════════════ */
.sv-pkg-section[b-kd2ep2b8u1] {
    margin-top: 1rem;
    flex-shrink: 0;
    padding-bottom: 1rem;
}
.sv-pkg-heading[b-kd2ep2b8u1] {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .6rem .85rem;
    font-size: .82rem;
    font-weight: 700;
    color: #1e293b;
    background: #fff;
    border-radius: 8px 8px 0 0;
    border: 1px solid #e2e8f0;
    border-bottom: none;
}
.sv-pkg-heading i[b-kd2ep2b8u1] {
    font-size: .9rem;
    color: #3b82f6;
}
.sv-pkg-hint[b-kd2ep2b8u1] {
    font-size: .65rem;
    font-weight: 500;
    color: #94a3b8;
    background: #f1f5f9;
    padding: .15rem .5rem;
    border-radius: 5px;
    border: 1px solid #e2e8f0;
}
.sv-pkg-total[b-kd2ep2b8u1] {
    margin-left: auto;
    font-size: .75rem;
    font-weight: 700;
    color: #3b82f6;
}

.sv-pkg-grid[b-kd2ep2b8u1] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 0 0 8px 8px;
    overflow: hidden;
}

.sv-pkg-card[b-kd2ep2b8u1] {
    border-right: 1px solid #e2e8f0;
    display: flex;
    flex-direction: column;
}
.sv-pkg-card:last-child[b-kd2ep2b8u1] {
    border-right: none;
}

.sv-pkg-card-header[b-kd2ep2b8u1] {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .6rem .75rem;
    border-bottom: 1px solid rgba(0,0,0,.06);
}
.sv-pkg-box .sv-pkg-card-header[b-kd2ep2b8u1]   { background: linear-gradient(135deg, #fffbeb, #fef3c7); }
.sv-pkg-tag .sv-pkg-card-header[b-kd2ep2b8u1]   { background: linear-gradient(135deg, #f3e8ff, #e9d5ff); }
.sv-pkg-hanger .sv-pkg-card-header[b-kd2ep2b8u1] { background: linear-gradient(135deg, #fff1f2, #fee2e2); }
.sv-pkg-paper .sv-pkg-card-header[b-kd2ep2b8u1] { background: linear-gradient(135deg, #f0fdf4, #dcfce7); }

.sv-pkg-card-icon[b-kd2ep2b8u1] {
    width: 26px;
    height: 26px;
    border-radius: 7px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .85rem;
    flex-shrink: 0;
}
.sv-pkg-icon-box[b-kd2ep2b8u1]    { background: rgba(245,158,11,.18); color: #d97706; }
.sv-pkg-icon-tag[b-kd2ep2b8u1]    { background: rgba(168,85,247,.18); color: #7c3aed; }
.sv-pkg-icon-hanger[b-kd2ep2b8u1] { background: rgba(239,68,68,.18); color: #dc2626; }
.sv-pkg-icon-paper[b-kd2ep2b8u1]  { background: rgba(34,197,94,.18); color: #16a34a; }

.sv-pkg-card-title[b-kd2ep2b8u1] {
    font-size: .78rem;
    font-weight: 700;
    color: #1e293b;
}
.sv-pkg-card-unit[b-kd2ep2b8u1] {
    font-size: .6rem;
    color: #94a3b8;
    margin-left: auto;
}

.sv-pkg-card-body[b-kd2ep2b8u1] {
    padding: .5rem .75rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    flex: 1;
}

.sv-pkg-field[b-kd2ep2b8u1] {
    display: flex;
    align-items: center;
    gap: .5rem;
}
.sv-pkg-label[b-kd2ep2b8u1] {
    display: flex;
    align-items: center;
    gap: .35rem;
    font-size: .72rem;
    font-weight: 600;
    color: #475569;
    white-space: nowrap;
    min-width: 100px;
}
.sv-pkg-label .dot[b-kd2ep2b8u1] {
    width: 8px;
    height: 8px;
}
.sv-pkg-field .inp-wrap[b-kd2ep2b8u1] {
    flex: 1;
    border: 1.5px solid #e2e8f0;
    border-radius: 7px;
    box-shadow: none;
}
.sv-pkg-field .inp-wrap:focus-within[b-kd2ep2b8u1] {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99,102,241,.12);
}
.sv-pkg-field .gs-input[b-kd2ep2b8u1] {
    font-size: .78rem;
    padding: .3rem .45rem;
    text-align: right;
}
.sv-pkg-field .inp-u[b-kd2ep2b8u1] {
    display: flex;
    padding: .3rem .4rem;
    font-size: .65rem;
}

/* ── Responsive packaging grid ────────────────────────── */
@media (max-width: 1024px) {
    .sv-pkg-grid[b-kd2ep2b8u1] {
        grid-template-columns: repeat(2, 1fr);
    }
    .sv-pkg-card:nth-child(2)[b-kd2ep2b8u1] {
        border-right: none;
    }
    .sv-pkg-card:nth-child(1)[b-kd2ep2b8u1],
    .sv-pkg-card:nth-child(2)[b-kd2ep2b8u1] {
        border-bottom: 1px solid #e2e8f0;
    }
}
@media (max-width: 600px) {
    .sv-pkg-grid[b-kd2ep2b8u1] {
        grid-template-columns: 1fr;
    }
    .sv-pkg-card[b-kd2ep2b8u1] {
        border-right: none;
        border-bottom: 1px solid #e2e8f0;
    }
    .sv-pkg-card:last-child[b-kd2ep2b8u1] {
        border-bottom: none;
    }
}
/* /Components/Pages/SurveySubmissionView.razor.rz.scp.css */
/* All styles handled via Tailwind utility classes in the .razor file */
/* /Components/Pages/UrgencyDetail.razor.rz.scp.css */
/* ════════════════════════════════════════════════════
   URGENCY DETAIL PAGE
   ════════════════════════════════════════════════════ */
.urgency-root[b-0b93lae7gu] {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    padding-bottom: 4rem;
    animation: db-fade-in 0.4s ease-out both;
}

/* ── Header ── */
.urgency-header[b-0b93lae7gu] {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.urgency-back[b-0b93lae7gu] {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    background: none;
    border: none;
    color: var(--slate-500);
    font-size: .8125rem;
    font-weight: 600;
    cursor: pointer;
    padding: .25rem .5rem;
    border-radius: .5rem;
    transition: all .12s ease;
    width: fit-content;
}

.urgency-back:hover[b-0b93lae7gu] {
    color: #6366f1;
    background: #eef2ff;
}

.urgency-title-row[b-0b93lae7gu] {
    display: flex;
    align-items: center;
    gap: .875rem;
}

.urgency-icon[b-0b93lae7gu] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: .875rem;
    font-size: 1.25rem;
    flex-shrink: 0;
}

.urgency-icon--red[b-0b93lae7gu]    { background: #fef2f2; color: #ef4444; }
.urgency-icon--amber[b-0b93lae7gu]  { background: #fffbeb; color: #d97706; }
.urgency-icon--orange[b-0b93lae7gu] { background: #fff7ed; color: #ea580c; }

.urgency-title[b-0b93lae7gu] {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--slate-900);
    margin: 0;
    letter-spacing: -.03em;
    line-height: 1.2;
}

.urgency-subtitle[b-0b93lae7gu] {
    font-size: .8125rem;
    color: var(--slate-400);
    font-weight: 500;
    margin: .125rem 0 0;
}

/* ── Loading / Empty ── */
.urgency-loading[b-0b93lae7gu] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 12rem;
    gap: 1rem;
}

.urgency-empty[b-0b93lae7gu] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 12rem;
    gap: .75rem;
    color: var(--slate-400);
    font-size: .875rem;
}

.urgency-empty .bi[b-0b93lae7gu] {
    font-size: 2.5rem;
    color: #10b981;
}

/* ── Table card ── */
.urgency-table-card[b-0b93lae7gu] {
    background: #fff;
    border: 1px solid var(--slate-100);
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.urgency-table[b-0b93lae7gu] {
    width: 100%;
    border-collapse: collapse;
    font-size: .8125rem;
}

.urgency-table thead tr[b-0b93lae7gu] {
    border-bottom: 1px solid var(--slate-100);
}

.urgency-table th[b-0b93lae7gu] {
    padding: .75rem 1.25rem;
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--slate-400);
    text-align: left;
    position: sticky;
    top: 0;
    background: #fff;
}

.urgency-th-r[b-0b93lae7gu] { text-align: right !important; }

.urgency-row[b-0b93lae7gu] {
    border-bottom: 1px solid var(--slate-50);
    transition: background .1s ease;
}

.urgency-row:last-child[b-0b93lae7gu] { border-bottom: none; }
.urgency-row:hover[b-0b93lae7gu] { background: var(--slate-50); }

.urgency-table td[b-0b93lae7gu] {
    padding: .625rem 1.25rem;
}

.urgency-td-index[b-0b93lae7gu] {
    color: var(--slate-300);
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    width: 2rem;
}

.urgency-td-po[b-0b93lae7gu] {
    font-weight: 700;
    color: var(--slate-800);
}

.urgency-td-factory[b-0b93lae7gu] {
    color: var(--slate-500);
}

.urgency-td-style[b-0b93lae7gu] {
    color: var(--slate-400);
    font-size: .75rem;
    max-width: 220px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.urgency-td-days[b-0b93lae7gu] {
    font-weight: 800;
    font-variant-numeric: tabular-nums;
}

.urgency-td-days--red[b-0b93lae7gu]   { color: #dc2626; }
.urgency-td-days--amber[b-0b93lae7gu] { color: #b45309; }

.urgency-tag[b-0b93lae7gu] {
    font-size: .6875rem;
    font-weight: 700;
    padding: .2rem .7rem;
    border-radius: 999px;
    white-space: nowrap;
}

.urgency-tag--red[b-0b93lae7gu]   { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.urgency-tag--amber[b-0b93lae7gu] { background: #fffbeb; color: #92400e; border: 1px solid #fde68a; }

/* ── Responsive ── */
@media (max-width: 640px) {
    .urgency-td-style[b-0b93lae7gu] { display: none; }
    .urgency-td-index[b-0b93lae7gu] { display: none; }
    .urgency-table th:first-child[b-0b93lae7gu] { display: none; }
}
/* /Components/Shared/FactorySurveyMetrics.razor.rz.scp.css */
/* ── Compact metric strip — inline chips ─────────────── */
.sv-metrics[b-2dftqvbflk] {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    flex-wrap: nowrap;
}

/* ── Individual chip ─────────────────────────────────── */
.sv-chip[b-2dftqvbflk] {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .2rem .5rem;
    border-radius: 8px;
    font-size: .68rem;
    font-weight: 600;
    background: #fff;
    border: 1px solid #e2e8f0;
    color: #64748b;
    transition: all .2s;
    cursor: default;
    position: relative;
    white-space: nowrap;
}

.sv-chip:hover[b-2dftqvbflk] {
    border-color: #cbd5e1;
    box-shadow: 0 2px 6px rgba(0,0,0,.06);
}

.sv-chip i[b-2dftqvbflk] {
    font-size: .7rem;
    flex-shrink: 0;
}

.sv-chip-label[b-2dftqvbflk] {
    font-size: .58rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #94a3b8;
}

.sv-chip-val[b-2dftqvbflk] {
    font-weight: 800;
    color: #94a3b8;
    transition: color .2s;
}

.sv-chip-val.sv-chip-live[b-2dftqvbflk] {
    color: #1e293b;
}

.sv-chip-val.sv-chip-warn[b-2dftqvbflk] {
    color: #ea580c;
}

.sv-chip-dim[b-2dftqvbflk] {
    font-weight: 600;
    color: #94a3b8;
    font-size: .6rem;
}

/* ── Chip color accents ──────────────────────────────── */
.sv-chip-fiber i[b-2dftqvbflk] { color: #10b981; }
.sv-chip-fiber:hover[b-2dftqvbflk] { background: #ecfdf5; border-color: #a7f3d0; }

.sv-chip-pkg i[b-2dftqvbflk] { color: #3b82f6; }
.sv-chip-pkg:hover[b-2dftqvbflk] { background: #eff6ff; border-color: #bfdbfe; }

.sv-chip-cov i[b-2dftqvbflk] { color: #06b6d4; }
.sv-chip-cov:hover[b-2dftqvbflk] { background: #ecfeff; border-color: #a5f3fc; }

.sv-chip-done i[b-2dftqvbflk] { color: #8b5cf6; }
.sv-chip-done:hover[b-2dftqvbflk] { background: #f5f3ff; border-color: #c4b5fd; }

/* ── Mini progress bar inside completion chip ────────── */
.sv-chip-bar[b-2dftqvbflk] {
    width: 32px;
    height: 3px;
    background: #e2e8f0;
    border-radius: 9999px;
    overflow: hidden;
    flex-shrink: 0;
}

.sv-chip-bar-fill[b-2dftqvbflk] {
    height: 100%;
    border-radius: 9999px;
    background: linear-gradient(90deg, #8b5cf6, #a78bfa);
    transition: width .5s cubic-bezier(.22,1,.36,1);
}
/* /Components/Shared/LoadingSpinner.razor.rz.scp.css */
/* ════════════════════════════════════════════════════
   LoadingSpinner — Scoped Component Styles
   ════════════════════════════════════════════════════ */

/* ── Wrapper ── */
.ls-wrap[b-5y4kz5yt8j] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 2.5rem 1rem;
}

.ls-wrap--fullpage[b-5y4kz5yt8j] {
    position: fixed;
    inset: 0;
    z-index: 999;
    background: rgba(248, 250, 252, 0.85);
    backdrop-filter: blur(4px);
    padding: 0;
}

/* ── Spinner shell ── */
.ls-spinner[b-5y4kz5yt8j] {
    position: relative;
    flex-shrink: 0;
}

/* sizes */
.ls-spinner--sm[b-5y4kz5yt8j] { width: 36px; height: 36px; }
.ls-spinner--md[b-5y4kz5yt8j] { width: 52px; height: 52px; }
.ls-spinner--lg[b-5y4kz5yt8j] { width: 72px; height: 72px; }

/* animated ring */
.ls-ring[b-5y4kz5yt8j] {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 3px solid #e2e8f0;  /* slate-200 */
}

.ls-ring[b-5y4kz5yt8j]::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 50%;
    border: 3px solid transparent;
    border-top-color: #6366f1;     /* indigo-500 */
    border-right-color: #a5b4fc;   /* indigo-300 — subtle trailing arc */
    animation: ls-spin-b-5y4kz5yt8j 0.75s cubic-bezier(0.5, 0, 0.5, 1) infinite;
}

/* second slower ring for depth */
.ls-ring[b-5y4kz5yt8j]::after {
    content: '';
    position: absolute;
    inset: 6px;
    border-radius: 50%;
    border: 2px solid transparent;
    border-bottom-color: #34d399;  /* emerald-400 */
    animation: ls-spin-b-5y4kz5yt8j 1.4s cubic-bezier(0.5, 0, 0.5, 1) infinite reverse;
}

/* sizes — adjust inner ring offset */
.ls-spinner--sm .ls-ring[b-5y4kz5yt8j]::after { inset: 4px; border-width: 2px; }
.ls-spinner--lg .ls-ring[b-5y4kz5yt8j]::after { inset: 8px; border-width: 2px; }

/* leaf icon in the centre */
.ls-leaf[b-5y4kz5yt8j] {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6366f1;
    animation: ls-pulse-b-5y4kz5yt8j 1.8s ease-in-out infinite;
}

.ls-spinner--sm .ls-leaf[b-5y4kz5yt8j] { font-size: .75rem; }
.ls-spinner--md .ls-leaf[b-5y4kz5yt8j] { font-size: 1.05rem; }
.ls-spinner--lg .ls-leaf[b-5y4kz5yt8j] { font-size: 1.5rem; }

/* ── Label ── */
.ls-label[b-5y4kz5yt8j] {
    font-size: .8125rem;
    font-weight: 500;
    color: #94a3b8;   /* slate-400 */
    letter-spacing: .01em;
    margin: 0;
    animation: ls-pulse-b-5y4kz5yt8j 1.8s ease-in-out infinite;
    text-align: center;
}

.ls-wrap--sm .ls-label[b-5y4kz5yt8j] { font-size: .75rem; }
.ls-wrap--lg .ls-label[b-5y4kz5yt8j] { font-size: .9375rem; }

/* ── Keyframes ── */
@keyframes ls-spin-b-5y4kz5yt8j {
    to { transform: rotate(360deg); }
}

@keyframes ls-pulse-b-5y4kz5yt8j {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0.45; }
}
