html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

/* ============ SmallERP shell ============ */
html, body { height: 100%; margin: 0; }
.erp-shell { display: flex; height: 100vh; overflow: hidden; }

.erp-sidebar {
    width: 240px; flex: 0 0 240px;
    background: #1f2b3a; color: #cdd7e2;
    display: flex; flex-direction: column;
    overflow-y: auto;
}
.erp-main { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; background: #f4f6f9; }

.erp-brand { padding: 14px 16px; font-size: 1.15rem; font-weight: 700; color: #fff; background: #16202c; }
.erp-brand .brand-mark { color: #4da3ff; margin-right: 6px; }

.user-box { padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,.10); }

.erp-nav { padding: 6px 0 24px; }
.erp-nav .nav-section { padding: 14px 16px 4px; color: #6f8bab; font-size: .68rem; letter-spacing: .08em; }
.erp-nav .nav-item { padding: 0 8px; }
.erp-nav .nav-link {
    display: flex; align-items: center; gap: 8px;
    width: 100%; text-align: left; border: 0; background: transparent;
    color: #cdd7e2; padding: 7px 12px; border-radius: 6px; font-size: .9rem; cursor: pointer;
}
.erp-nav .nav-link:hover { background: rgba(255,255,255,.08); color: #fff; }
.erp-nav .nav-link.active { background: #2d6cdf; color: #fff; }

/* ---- Tabs ---- */
.tabhost { display: flex; flex-direction: column; height: 100%; }
.tabstrip {
    display: flex; align-items: stretch; gap: 2px;
    background: #e4e9f1; padding: 6px 8px 0; overflow-x: auto; flex: 0 0 auto;
}
.tabstrip .tab {
    display: flex; align-items: center; gap: 8px;
    padding: 7px 12px; background: #cfd8e6; color: #2a3b52;
    border-radius: 8px 8px 0 0; cursor: pointer; white-space: nowrap; font-size: .86rem;
}
.tabstrip .tab:hover { background: #dde4ef; }
.tabstrip .tab.active { background: #f4f6f9; color: #16202c; font-weight: 600; }
.tabstrip .tab .tab-close {
    font-size: 1rem; line-height: 1; color: #7185a0; border-radius: 4px; padding: 0 4px;
}
.tabstrip .tab .tab-close:hover { background: rgba(0,0,0,.12); color: #b3261e; }

.tabbody { flex: 1 1 auto; overflow: auto; padding: 16px 18px; }
.tabpane { height: 100%; }
.tab-empty { display: flex; align-items: center; justify-content: center; height: 100%; }

/* ---- KPI cards ---- */
.kpi-card { border: 0; box-shadow: 0 2px 8px rgba(20,40,80,.06); }
.kpi-card .kpi-label { font-weight: 600; }
.kpi-card .kpi-sub { font-size: .8rem; color: #6b7990; }

/* ---- Tables in panes ---- */
.tabpane .table { background: #fff; }
.toolbar { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 12px; }

/* ============ Print documents ============ */
.print-page { max-width: 820px; margin: 0 auto; padding: 24px 28px; color: #000; background: #fff; font-size: 13px; }
.print-doc h2.doc-title { text-align: center; margin: 8px 0 2px; font-size: 20px; }
.print-doc .doc-sub { text-align: center; margin-bottom: 14px; color: #333; }
.print-doc .company { font-size: 12px; line-height: 1.4; }
.print-doc .company .cname { font-weight: 700; font-size: 14px; text-transform: uppercase; }
.print-doc table.doc-table { width: 100%; border-collapse: collapse; margin: 10px 0; }
.print-doc table.doc-table th, .print-doc table.doc-table td { border: 1px solid #000; padding: 5px 7px; }
.print-doc table.doc-table th { background: #eee; }
.print-doc .meta { margin: 6px 0; line-height: 1.7; }
.print-doc .sign-row { display: flex; justify-content: space-around; margin-top: 36px; text-align: center; }
.print-doc .sign-row .sign-col { width: 30%; }
.print-doc .sign-row .sign-title { font-weight: 700; }
.print-doc .sign-row .sign-note { font-style: italic; font-size: 12px; }
.print-toolbar { text-align: center; margin: 16px 0; }

@media print {
    .print-toolbar { display: none !important; }
    .print-page { max-width: none; padding: 0; }
    @page { margin: 14mm; }
}

/* ============ Blazor error UI (ẩn mặc định, chỉ hiện khi có lỗi thật) ============ */
#blazor-error-ui {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}
#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}

/* ============ Dashboard năng suất máy ============ */
.ns-kpi { border:0; box-shadow:0 2px 8px rgba(20,40,80,.06); }
.ns-kpi .v { font-size:1.5rem; font-weight:700; line-height:1.1; }
.ns-kpi .l { font-size:.78rem; color:#6b7990; }
.ns-bar-row { display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.ns-bar-label { width:160px; flex:0 0 160px; font-size:.85rem; text-align:right; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ns-bar-track { flex:1 1 auto; background:#eef2f7; border-radius:4px; height:20px; position:relative; }
.ns-bar-fill { background:linear-gradient(90deg,#2d6cdf,#4da3ff); height:100%; border-radius:4px; min-width:2px; }
.ns-bar-val { font-size:.82rem; width:90px; flex:0 0 90px; }
.ns-trend { display:flex; align-items:flex-end; gap:6px; height:140px; padding-top:8px; }
.ns-trend .col { flex:1 1 0; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; }
.ns-trend .col .fill { width:70%; background:linear-gradient(180deg,#4da3ff,#2d6cdf); border-radius:3px 3px 0 0; min-height:2px; }
.ns-trend .col .d { font-size:.7rem; color:#6b7990; margin-top:3px; }

/* ============ Gauge / đồng hồ năng suất ============ */
.gauge-svg { width:100%; max-width:230px; height:auto; display:block; margin:0 auto; }
.gauge-card { border:0; box-shadow:0 2px 10px rgba(20,40,80,.08); }
.gauge-card .gc-title { font-weight:600; text-align:center; }
.gauge-card .gc-stat { text-align:center; font-size:.82rem; color:#52617a; }
.gauge-card .gc-stat b { color:#1f2b3a; }
.hour-grid input { text-align:right; }
.hour-cell-pct { font-weight:600; }
.spark { display:flex; gap:1px; height:34px; align-items:flex-end; margin-top:6px; }
.spark .b { flex:1 1 0; min-height:1px; border-radius:1px 1px 0 0; background:#cdd7e6; }
.spark .b.g { background:#3fb27f; } .spark .b.a { background:#f0ad4e; } .spark .b.r { background:#e25563; }
.gauge-card.gc-ok     { border-top:4px solid #3fb27f; }
.gauge-card.gc-warn   { border-top:4px solid #f0ad4e; background:#fffaf2; }
.gauge-card.gc-danger { border-top:4px solid #e25563; background:#fff5f6; }
.gauge-card .gc-flag  { display:inline-block; font-size:.72rem; font-weight:700; padding:1px 7px; border-radius:10px; }
.gauge-card .gc-flag.low  { background:#e25563; color:#fff; }
.gauge-card .gc-flag.warn { background:#f0ad4e; color:#3a2a00; }

/* ============ THEME: Vàng đồng + Nâu đất ============ */
.erp-sidebar {
    background: linear-gradient(180deg, #3b2a1a 0%, #2b1f12 100%);
    color: #ecdfc6;
    transition: width .18s ease, flex-basis .18s ease, min-width .18s ease;
}
.erp-brand {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 16px; background: #241a0e;
    border-bottom: 2px solid #b8860b;
}
.brand-logo { width: 32px; height: 32px; border-radius: 8px; object-fit: cover; box-shadow: 0 0 0 1px rgba(205,164,52,.4); }
.brand-name { font-weight: 700; font-size: 1.15rem; color: #f2e6c8; letter-spacing: .02em; }

.user-box { border-bottom: 1px solid rgba(205,164,52,.22); }
.user-box .text-warning { color: #e7c66b !important; }

.erp-nav .nav-section { color: #d2a857; font-weight: 600; }
.erp-nav .nav-link { color: #e8dcc4; }
.erp-nav .nav-link:hover { background: rgba(205,164,52,.16); color: #fff; }
.erp-nav .nav-link.active {
    background: linear-gradient(90deg, #b8860b 0%, #d2a234 100%);
    color: #2a1c0a; font-weight: 600;
}
.erp-nav .nav-link i { color: #d2a857; }
.erp-nav .nav-link.active i { color: #2a1c0a; }

/* ---- Top bar + nút ẩn/hiện menu ---- */
.erp-main { display: flex; flex-direction: column; }
.erp-topbar {
    flex: 0 0 auto; display: flex; align-items: center; gap: 10px;
    height: 46px; padding: 0 12px; background: #fff;
    border-bottom: 1px solid #e8dfce; box-shadow: 0 2px 0 rgba(184,134,11,.18);
}
.erp-burger {
    border: 0; background: transparent; color: #5c4326; cursor: pointer;
    font-size: 1.3rem; line-height: 1; padding: 4px 10px; border-radius: 7px;
}
.erp-burger:hover { background: #f3ecde; color: #2b1f12; }
.topbar-logo { height: 26px; width: 26px; border-radius: 6px; object-fit: cover; }
.topbar-title { font-weight: 700; color: #5c4326; }
.erp-body { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; }

/* ---- Trạng thái thu gọn menu ---- */
.erp-shell.nav-collapsed .erp-sidebar { width: 0; flex-basis: 0; min-width: 0; overflow: hidden; }
