/* ===================== X-ORION WEB · Premium Dark Glass theme ===================== */
:root {
    --bg: #0a0c10;
    --bg-2: #0e1116;
    --panel: rgba(22, 27, 34, 0.72);
    --panel-solid: #161b22;
    --stroke: rgba(255, 255, 255, 0.07);
    --stroke-strong: rgba(255, 255, 255, 0.14);
    --text: #eef2f7;
    --text-sec: #9aa6b2;
    --text-dim: #6b7682;
    --accent: #4fd1c5;
    --accent-2: #62a8ff;
    --accent-violet: #a78bfa;
    --accent-gold: #f2b950;
    --grad-brand: linear-gradient(135deg, #4fd1c5 0%, #62a8ff 100%);
    --grad-gold: linear-gradient(135deg, #f2b950 0%, #e8833e 100%);
    --grad-violet: linear-gradient(135deg, #a78bfa 0%, #62a8ff 100%);
    --green: #3ddc84;
    --green-bg: rgba(61, 220, 132, 0.13);
    --red: #ff6b6b;
    --red-bg: rgba(255, 107, 107, 0.12);
    --radius: 16px;
    --shadow: 0 10px 40px rgba(0, 0, 0, 0.45);
    --shadow-lift: 0 20px 60px rgba(0, 0, 0, 0.5), 0 2px 8px rgba(0,0,0,.3);
    --font-ui: 'Manrope', 'Segoe UI', 'Inter', 'Helvetica Neue', Arial, sans-serif;
    --font-display: 'Space Grotesk', 'Manrope', sans-serif;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    font-family: var(--font-ui);
    background:
        radial-gradient(1100px 620px at 85% -8%, rgba(79,209,197,.09) 0%, transparent 55%),
        radial-gradient(900px 560px at -5% 15%, rgba(98,168,255,.07) 0%, transparent 55%),
        radial-gradient(1200px 700px at 80% -10%, #131d27 0%, var(--bg) 55%) fixed,
        var(--bg);
    color: var(--text);
    font-size: 14px;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-feature-settings: "tnum" 1, "ss01" 1;
    font-variant-numeric: tabular-nums;
}

a { color: var(--accent-2); text-decoration: none; }
h1 { font-family: var(--font-display); font-size: 1.7rem; font-weight: 700; margin: 0; letter-spacing: 0.1px; }
h1:focus { outline: none; }
.muted { color: var(--text-sec); padding: 1rem 0; }

.glass {
    background: var(--panel);
    border: 1px solid var(--stroke);
    border-radius: var(--radius);
    backdrop-filter: blur(14px) saturate(120%);
    -webkit-backdrop-filter: blur(14px) saturate(120%);
    box-shadow: var(--shadow);
}

.grad-text {
    background: var(--grad-brand);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

/* ===================== Shell ===================== */
.app-shell {
    display: grid;
    grid-template-columns: 248px 1fr;
    min-height: 100vh;
}

.sidebar {
    background: linear-gradient(180deg, #10151b 0%, #0c1014 100%);
    border-right: 1px solid var(--stroke);
    padding: 22px 14px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: sticky;
    top: 0;
    height: 100vh;
}

.logo { display: flex; align-items: center; gap: 12px; padding: 4px 8px 14px; border-bottom: 1px solid var(--stroke); }
.brand-mark { flex-shrink: 0; filter: drop-shadow(0 0 10px rgba(79,209,197,.35)); }
.brand-title { font-family: var(--font-display); font-weight: 700; letter-spacing: 2px; font-size: 15px; }
.brand-sub { font-size: 10px; letter-spacing: 3px; color: var(--text-dim); }

.side-nav { display: flex; flex-direction: column; gap: 2px; }
.nav-sep { height: 1px; background: var(--stroke); margin: 10px 4px; }
.side-nav .nav-link {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 13px; border-radius: 10px;
    color: var(--text-sec); font-weight: 500; font-size: 13.5px;
    transition: all 0.18s ease;
    position: relative;
}
.side-nav .nav-link .ico { display: flex; align-items: center; justify-content: center; width: 20px; opacity: 0.8; transition: opacity .18s, transform .18s; }
.side-nav .nav-link:hover { background: rgba(255,255,255,0.045); color: var(--text); }
.side-nav .nav-link:hover .ico { opacity: 1; transform: translateX(1px); }
.side-nav .nav-link.active {
    background: linear-gradient(90deg, rgba(79,209,197,0.18), rgba(98,168,255,0.03));
    color: #fff;
    box-shadow: inset 2.5px 0 0 0 var(--accent);
}
.side-nav .nav-link.active .ico { opacity: 1; color: var(--accent); filter: drop-shadow(0 0 6px rgba(79,209,197,.5)); }

.main-col { display: flex; flex-direction: column; min-width: 0; }

.topbar {
    height: 60px;
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 26px;
    border-bottom: 1px solid var(--stroke);
    background: rgba(11, 13, 16, 0.6);
    backdrop-filter: blur(10px);
    position: sticky; top: 0; z-index: 5;
}
.topbar-spacer { flex: 1; }
.user-box { display: flex; align-items: center; gap: 12px; }
.user-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 10px var(--green); }
.user-name { font-size: 13px; color: var(--text-sec); }
.logout-form { margin: 0; }
.btn-ghost {
    display: inline-flex; align-items: center; gap: 6px;
    background: transparent; border: 1px solid var(--stroke-strong);
    color: var(--text-sec); padding: 6px 14px; border-radius: 8px; cursor: pointer;
    font-size: 12.5px; font-family: var(--font-ui); transition: all 0.15s; white-space: nowrap;
}
.btn-ghost:hover { color: #fff; border-color: var(--accent); }

.content { padding: 26px; min-width: 0; }

/* ===================== Page header ===================== */
.page-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 22px; gap: 1rem; flex-wrap: wrap; }
.page-head-title { display: flex; align-items: center; gap: 14px; }
.page-head-ico {
    width: 42px; height: 42px; border-radius: 12px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, rgba(79,209,197,.18), rgba(98,168,255,.10));
    color: var(--accent); border: 1px solid rgba(79,209,197,.2);
}
.page-sub { color: var(--text-sec); font-size: 13px; margin-top: 5px; }

.btn-export {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--panel); border: 1px solid var(--stroke-strong); color: var(--text-sec);
    padding: 9px 16px; border-radius: 9px; cursor: pointer; font-size: 13px; font-weight: 600;
    text-decoration: none; transition: all .18s ease;
}
.btn-export:hover { color: #fff; border-color: var(--accent); background: rgba(79,209,197,.08); box-shadow: 0 4px 16px rgba(79,209,197,.15); }
.btn-export svg { transition: transform .18s ease; }
.btn-export:hover svg { transform: translateY(2px); }

/* ===================== Dashboard cards ===================== */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
.card {
    padding: 22px; display: flex; flex-direction: column; gap: 6px; position: relative; overflow: hidden;
    transition: transform 0.22s cubic-bezier(.2,.8,.2,1), border-color 0.22s, box-shadow 0.22s;
}
.card::before {
    content: ""; position: absolute; inset: 0 0 auto 0; height: 2px;
    background: var(--grad-brand); opacity: 0; transition: opacity .22s;
}
a.card:hover { transform: translateY(-4px); border-color: var(--stroke-strong); box-shadow: var(--shadow-lift); }
a.card:hover::before { opacity: 1; }
.card-ico {
    width: 44px; height: 44px; border-radius: 12px; margin-bottom: 10px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, rgba(79,209,197,.16), rgba(98,168,255,.10));
    color: var(--accent); border: 1px solid rgba(79,209,197,.18);
    transition: transform .22s cubic-bezier(.2,.8,.2,1);
}
a.card:hover .card-ico { transform: scale(1.08) rotate(-3deg); }
.card-title { font-weight: 650; font-size: 15px; letter-spacing: .1px; }
.card-sub { color: var(--text-sec); font-size: 12.5px; line-height: 1.4; }
.card.disabled { opacity: 0.5; }
.card-arrow { position: absolute; top: 20px; right: 18px; opacity: 0; color: var(--text-dim); transition: opacity .2s, transform .2s; }
a.card:hover .card-arrow { opacity: 1; transform: translate(2px,-2px); color: var(--accent); }

/* ===================== Monitoring table ===================== */
.branch-block { padding: 0; margin-bottom: 24px; overflow: hidden; }
.branch-cap {
    padding: 13px 18px; font-weight: 650; font-size: 14px; letter-spacing: 0.5px;
    color: #fff; border-bottom: 1px solid var(--stroke);
    background: linear-gradient(90deg, rgba(79,209,197,0.10), transparent);
}
.table-scroll { overflow-x: auto; }
.mon-table { border-collapse: separate; border-spacing: 0; width: 100%; font-size: 12.5px; white-space: nowrap; }
.mon-table th, .mon-table td { padding: 7px 10px; text-align: right; border-bottom: 1px solid var(--stroke); }
.mon-table thead th {
    position: sticky; top: 0; background: var(--panel-solid); color: var(--text-sec);
    font-weight: 600; font-size: 11.5px; text-align: right; z-index: 2;
}
.mon-table tbody tr:hover td { background: rgba(255,255,255,0.025); }
.sticky-col { position: sticky; left: 0; z-index: 3; background: var(--panel-solid); }
.task-col { text-align: left; min-width: 240px; max-width: 320px; white-space: normal; color: var(--text); font-weight: 500; }
.mon-table thead .task-col { z-index: 4; }
.total-col { font-weight: 700; color: #fff; background: rgba(255,255,255,0.03); }
.cell-up { color: var(--green); background: var(--green-bg); }
.cell-down { color: var(--red); background: var(--red-bg); }

/* ===================== Login ===================== */
.empty-shell {
    min-height: 100vh; display: grid; place-items: center; padding: 20px;
    background:
        radial-gradient(900px 560px at 15% 10%, rgba(79,209,197,.12) 0%, transparent 55%),
        radial-gradient(900px 560px at 85% 90%, rgba(98,168,255,.10) 0%, transparent 55%),
        var(--bg);
}
.login-wrap { width: 100%; max-width: 410px; animation: loginRise .5s cubic-bezier(.2,.8,.2,1) both; }
@keyframes loginRise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
.login-card { padding: 38px 34px; box-shadow: var(--shadow-lift), 0 0 0 1px rgba(79,209,197,.05); }
.login-brand { display: flex; align-items: center; gap: 14px; margin-bottom: 26px; }
.login-brand .brand-mark { filter: drop-shadow(0 0 14px rgba(79,209,197,.4)); }
.login-brand .brand-title { font-size: 17px; }
.login-h { font-size: 1.35rem; font-weight: 650; margin-bottom: 20px; }
.login-form { display: flex; flex-direction: column; gap: 7px; }
.login-form label { font-size: 12px; color: var(--text-sec); margin-top: 8px; font-weight: 600; }
.login-form input {
    background: rgba(0,0,0,0.35); border: 1px solid var(--stroke-strong); border-radius: 9px;
    padding: 12px 14px; color: var(--text); font-size: 14px; outline: none; transition: border-color 0.15s, box-shadow .15s;
}
.login-form input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(79,209,197,.14); }
.btn-primary {
    margin-top: 20px; padding: 13px; border: none; border-radius: 9px; cursor: pointer;
    background: var(--grad-brand); color: #06231f;
    font-weight: 700; font-size: 14px; letter-spacing: 0.3px; transition: filter 0.15s, transform .15s;
    box-shadow: 0 8px 24px rgba(79,209,197,.25);
}
.btn-primary:hover { filter: brightness(1.08); transform: translateY(-1px); }
.btn-primary:active { transform: translateY(0); }
.login-error {
    background: var(--red-bg); border: 1px solid rgba(255,107,107,0.3); color: var(--red);
    padding: 10px 14px; border-radius: 9px; font-size: 13px; margin-bottom: 14px;
}
.login-foot { margin-top: 20px; font-size: 11px; color: var(--text-dim); text-align: center; }

/* ===================== Matrix ===================== */
.mat-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 14px; margin-bottom: 18px; }
.mat-card { padding: 16px 20px; }
.mat-card__label { font-size: 10.5px; font-weight: 700; letter-spacing: 1px; margin-bottom: 6px; }
.mat-card__value { font-size: 22px; font-weight: 700; }
.mat-card--blue  .mat-card__label { color: var(--accent-2); }
.mat-card--blue  .mat-card__value { color: var(--accent-2); }
.mat-card--green .mat-card__label { color: var(--green); }
.mat-card--green .mat-card__value { color: var(--green); }
.mat-card--amber .mat-card__label { color: #f0b429; }
.mat-card--amber .mat-card__value { color: #f0b429; }
.mat-card--purple .mat-card__label { color: #c060ff; }
.mat-card--purple .mat-card__value { color: #c060ff; }

.mat-filters { padding: 16px 20px; margin-bottom: 16px; }
.mat-filters__row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 10px; }
.mat-filters__row:last-child { margin-bottom: 0; }
.mat-filters__label { font-size: 12.5px; font-weight: 600; color: var(--text-sec); white-space: nowrap; }

.mat-abcxyz-grid { display: grid; grid-template-columns: repeat(3, 72px); gap: 3px; }
.mat-abcxyz-btn {
    padding: 5px 0; border: none; border-radius: 4px; cursor: pointer;
    font-size: 12px; font-weight: 700; color: #fff; opacity: 0.75; transition: all 0.15s;
}
.mat-abcxyz-btn:hover { opacity: 1; }
.mat-abcxyz-btn.active { opacity: 1; outline: 2px solid #fff; outline-offset: 1px; }
.ax, .ay { background: #1d8348; } .az { background: #117a65; }
.bx, .by { background: #9a7d0a; } .bz { background: #7d6608; }
.cx, .cy { background: #922b21; } .cz { background: #7b241c; }

.mat-btn-all {
    padding: 5px 16px; border-radius: 6px; cursor: pointer; font-weight: 600; font-size: 12.5px;
    background: var(--panel-solid); color: var(--accent); border: 1px solid var(--stroke-strong); transition: all 0.15s;
}
.mat-btn-all:hover { border-color: var(--accent); }
.mat-btn-all.active { background: var(--accent); color: #06231f; border-color: var(--accent); }

.mat-filter-info { font-size: 12px; color: var(--accent); }
.mat-filter-count { font-size: 12px; color: var(--text-dim); }

.mat-search {
    background: rgba(0,0,0,0.35); border: 1px solid var(--stroke-strong); border-radius: 8px;
    padding: 7px 12px; color: var(--text); font-size: 13px; width: 260px; outline: none; transition: border-color 0.15s;
}
.mat-search:focus { border-color: var(--accent); }
.mat-btn-clear {
    background: transparent; border: none; color: var(--text-dim); cursor: pointer; font-size: 14px; padding: 4px 8px;
}
.mat-btn-clear:hover { color: var(--red); }

.mat-table-wrap { overflow-x: auto; margin-bottom: 16px; border-radius: var(--radius); border: 1px solid var(--stroke); }
.mat-table {
    border-collapse: separate; border-spacing: 0; width: 100%;
    font-size: 12.5px; white-space: nowrap;
}
.mat-table th, .mat-table td { padding: 7px 10px; border-bottom: 1px solid var(--stroke); }
.th-sort { cursor: pointer; user-select: none; transition: color .15s; }
.th-sort:hover { color: var(--text) !important; }
.mat-table thead th {
    position: sticky; top: 0; background: var(--panel-solid); color: var(--text-sec);
    font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; z-index: 2;
}
.mat-table tbody tr { cursor: pointer; transition: background 0.1s; }
.mat-table tbody tr:hover td { background: rgba(255,255,255,0.025); }
.mat-row-sel td { background: rgba(79,209,197,0.08) !important; }
.mat-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.mat-table .bold { font-weight: 700; }
.mat-table .dim { color: var(--text-dim); }
.mat-table .stock { color: var(--accent-2); }
.mat-table .min-col { color: var(--accent-2); }
.mat-table .surplus-col { color: #f0b429; }
.mat-table .trans-route { color: #c060ff; font-size: 11.5px; max-width: 200px; overflow: hidden; text-overflow: ellipsis; }
.mat-td-class { text-align: center; }

.mat-badge {
    display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 700; color: #fff;
}
.badge-a { background: #1d8348; } .badge-b { background: #9a7d0a; } .badge-c { background: #922b21; }

.mat-more {
    text-align: center; padding: 10px; color: var(--text-dim); font-size: 12px;
    border: 1px dashed var(--stroke); border-radius: 8px; margin-bottom: 16px;
}

.mat-detail { padding: 18px 20px; min-height: 80px; }
.mat-detail__head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.mat-detail__sub { color: var(--text-sec); font-size: 12.5px; }
.mat-detail__empty { color: var(--text-dim); padding: 16px 0; font-size: 13px; }
.mat-table--detail { font-size: 12px; }
.mat-table--detail th { font-size: 10.5px; }

/* Раскрытие деталей по филиалам сразу под строкой (вместо панели внизу под 500 строками) */
.mat-chevron { opacity: .5; transition: transform .18s ease, opacity .18s ease; vertical-align: -2px; margin-left: 2px; }
.mat-chevron.open { transform: rotate(-180deg); opacity: 1; color: var(--accent); }
.mat-row-detail { cursor: default; }
.mat-row-detail:hover td { background: transparent !important; }
.mat-row-detail td { padding: 0; border-bottom: 1px solid var(--stroke); }
.mat-inline-detail {
    padding: 16px 20px; background: rgba(79,209,197,.035);
    border-left: 2px solid var(--accent); animation: matDetailIn .2s ease-out both;
}
@keyframes matDetailIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }

.mon-error { background: var(--red-bg); color: var(--red); padding: 14px 18px; border-radius: 10px; margin-bottom: 18px; }

/* ===================== Misc / error UI ===================== */
#blazor-error-ui {
    color-scheme: light dark;
    background: #2a1416; color: #ffb4b4; border-top: 1px solid #5a2a2a;
    bottom: 0; box-shadow: 0 -1px 14px rgba(0,0,0,0.5); display: none;
    left: 0; padding: 0.7rem 1.2rem 0.7rem 1.2rem; position: fixed; width: 100%; z-index: 1000;
}
#blazor-error-ui .dismiss { cursor: pointer; position: absolute; right: 1rem; top: 0.6rem; }
.blazor-error-boundary { background: #b32121; padding: 1rem; color: white; border-radius: 8px; }
.blazor-error-boundary::after { content: "Произошла ошибка."; }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #2a323b; border-radius: 6px; }
::-webkit-scrollbar-thumb:hover { background: #3a444f; }
::-webkit-scrollbar-track { background: transparent; }

/* ===================== Автозаказ ===================== */
.order-page { padding: 1.2rem 1.5rem; }
.order-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; gap: 1rem; flex-wrap: wrap; }
.order-header h2 { font-size: 1.7rem; font-weight: 700; color: var(--text); letter-spacing: .1px; }
.order-header-title { display: flex; align-items: center; gap: 14px; }
.order-controls { display: flex; gap: .7rem; align-items: center; flex-wrap: wrap; }
.branch-switcher { display: flex; gap: 4px; background: var(--panel); border-radius: 8px; padding: 3px; }
.btn-branch { background: transparent; border: none; color: var(--text-sec); padding: .35rem .9rem; border-radius: 6px; cursor: pointer; font-size: .85rem; transition: all .2s; }
.btn-branch.active { background: var(--accent); color: #fff; }
.btn-calc { background: var(--accent); color: #fff; border: none; padding: .45rem 1.2rem; border-radius: 8px; cursor: pointer; font-size: .85rem; font-weight: 500; transition: all .2s; display:flex;align-items:center;gap:.4rem; }
.btn-calc:disabled { opacity: .5; cursor: default; }
.spinner-sm { width: 14px; height: 14px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: spin .6s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }
.tab-strip { display: flex; gap: .3rem; border-bottom: 1px solid var(--stroke); margin: .8rem 0 1rem; }
.tab-btn { background: transparent; border: none; border-bottom: 2px solid transparent; color: var(--text-sec); padding: .55rem 1rem; cursor: pointer; font-size: .88rem; font-weight: 500; transition: all .15s; }
.tab-btn:hover { color: var(--text); }
.tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
.order-table tbody tr { cursor: pointer; }
.order-table tbody tr.selected { background: rgba(255,255,255,.06); }

.order-error { background: rgba(220,50,50,.12); border: 1px solid rgba(220,50,50,.25); color: #f87171; padding: .7rem 1rem; border-radius: 8px; margin-bottom: 1rem; }
.order-empty { color: var(--text-dim); text-align: center; padding: 3rem; }

.order-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: .8rem; margin-bottom: 1rem; }
.summary-card { background: var(--panel); backdrop-filter: blur(16px); border: 1px solid var(--stroke); border-radius: 10px; padding: .8rem 1rem; }
.sc-label { font-size: .72rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: .04em; }
.sc-value { font-size: 1.3rem; font-weight: 600; color: var(--text); margin-top: .2rem; }
.accent-blue .sc-value { color: #60a5fa; }
.accent-green .sc-value { color: #4ade80; }
.accent-yellow .sc-value { color: #fbbf24; }
.accent-red .sc-value { color: #f87171; }

.order-filters { display: flex; gap: .5rem; align-items: center; margin-bottom: .8rem; flex-wrap: wrap; }
.filter-select { background: var(--panel); border: 1px solid var(--stroke); color: var(--text); padding: .35rem .6rem; border-radius: 6px; font-size: .82rem; }
.filter-search { background: var(--panel); border: 1px solid var(--stroke); color: var(--text); padding: .35rem .7rem; border-radius: 6px; font-size: .82rem; min-width: 180px; }
.filter-search::placeholder { color: var(--text-dim); }
.btn-clear-search { background: none; border: none; color: var(--text-dim); cursor: pointer; font-size: .9rem; }
.filter-info { color: var(--text-dim); font-size: .78rem; margin-left: auto; }

.order-table-wrap { overflow-x: auto; margin-bottom: 1rem; }
.order-table { width: 100%; border-collapse: collapse; font-size: .82rem; }
.order-table thead th { background: var(--bg-2); color: var(--text-dim); font-weight: 500; padding: .5rem .6rem; text-align: left; position: sticky; top: 0; border-bottom: 1px solid var(--stroke); white-space: nowrap; }
.order-table tbody td { padding: .4rem .6rem; border-bottom: 1px solid var(--stroke); color: var(--text-sec); }
.order-table tbody tr { cursor: pointer; transition: background .15s; }
.order-table tbody tr:hover { background: rgba(96,165,250,.06); }
.order-table tbody tr.selected { background: rgba(96,165,250,.1); }
.order-table tbody tr.row-zero { background: rgba(248,113,113,.06); }
.order-table tbody tr.row-order { }
.order-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.order-table .cell-article { font-weight: 500; color: var(--text); }
.order-table .cell-rule { font-size: .75rem; color: var(--text-dim); }
.order-table .order-qty { color: #60a5fa; font-weight: 600; }

.badge-abcxyz { font-size: .72rem; padding: .15rem .4rem; border-radius: 4px; font-weight: 500; }
.abc-A { background: rgba(74,222,128,.12); color: #4ade80; }
.abc-B { background: rgba(251,191,36,.12); color: #fbbf24; }
.abc-C { background: rgba(248,113,113,.12); color: #f87171; }
.badge-status { font-size: .72rem; padding: .15rem .45rem; border-radius: 4px; }
.status-order { background: rgba(96,165,250,.12); color: #60a5fa; }
.status-watch { background: rgba(251,191,36,.12); color: #fbbf24; }
.trend-up { color: #4ade80; }
.trend-down { color: #f87171; }

.order-detail { background: var(--panel); border: 1px solid var(--stroke); border-radius: 10px; padding: 1rem 1.2rem; margin-bottom: 1rem; }
.detail-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: .8rem; }
.order-detail h3 { font-size: 1rem; font-weight: 600; color: var(--text); margin: 0; }
.btn-close-detail { background: none; border: none; color: var(--text-dim); font-size: 1.1rem; cursor: pointer; padding: .2rem .5rem; }
.detail-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: .4rem .8rem; }
.dg-item { display: flex; justify-content: space-between; padding: .25rem 0; border-bottom: 1px solid rgba(255,255,255,.04); }
.dg-item.sep { border-top: 1px solid var(--stroke); margin-top: .3rem; padding-top: .45rem; }
.dg-label { color: var(--text-dim); font-size: .78rem; }
.dg-val { color: var(--text); font-size: .82rem; }
.dg-val.bold { font-weight: 600; }
.dg-val.accent { color: #60a5fa; }

.btn-export { background: rgba(74,222,128,.12); color: #4ade80; border: 1px solid rgba(74,222,128,.2); padding: .4rem 1rem; border-radius: 8px; font-size: .82rem; text-decoration: none; transition: all .2s; }
.btn-export:hover { background: rgba(74,222,128,.2); }

.order-pager { display: flex; align-items: center; justify-content: center; gap: .3rem; padding: .6rem 0; }
.pager-btn { background: var(--panel); border: 1px solid var(--stroke); color: var(--text-sec); padding: .3rem .6rem; border-radius: 6px; cursor: pointer; font-size: .8rem; min-width: 32px; transition: all .15s; }
.pager-btn:hover:not(:disabled) { background: rgba(96,165,250,.1); }
.pager-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.pager-btn:disabled { opacity: .3; cursor: default; }
.pager-info { color: var(--text-dim); font-size: .78rem; margin-left: .5rem; }

.order-footer { text-align: center; color: var(--text-dim); font-size: .75rem; padding: .5rem; }

/* === Supply & PriceCheck === */
.supply-page { padding: 1.2rem 1.5rem; }
.price-dates { display: flex; align-items: center; gap: 1rem; padding: .6rem 0; flex-wrap: wrap; }
.date-picker-group { display: flex; align-items: center; gap: .4rem; }
.date-picker-group label { color: var(--text-sec); font-size: .82rem; white-space: nowrap; }
.section-title { color: var(--text); font-size: .95rem; font-weight: 600; margin: 1.2rem 0 .4rem; border-left: 3px solid var(--accent); padding-left: .6rem; }
.kpi-table td:first-child { width: 2rem; text-align: center; color: var(--text-dim); }
.bold { font-weight: 600; }

/* === Trend/Seasonality === */
.trend-search-wrap { position: relative; flex: 1; min-width: 220px; }
.trend-search-wrap .filter-search { width: 100%; }
.trend-suggest { position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 20; background: #1a1f2b; border: 1px solid var(--stroke-strong); border-radius: 8px; max-height: 260px; overflow-y: auto; box-shadow: 0 8px 24px rgba(0,0,0,.4); }
.trend-suggest-item { padding: .5rem .8rem; cursor: pointer; font-size: .85rem; color: var(--text); border-bottom: 1px solid var(--stroke); }
.trend-suggest-item:last-child { border-bottom: none; }
.trend-suggest-item:hover { background: rgba(255,255,255,.06); }
.trend-chart-wrap { background: var(--panel); border: 1px solid var(--stroke); border-radius: 12px; padding: 1rem; margin-top: .8rem; box-shadow: inset 0 1px 0 rgba(255,255,255,.03), 0 12px 32px rgba(0,0,0,.25); }
.trend-svg { width: 100%; height: auto; overflow: visible; }
.trend-hit { cursor: pointer; }
.trend-tooltip { opacity: 0; transition: opacity .15s ease; pointer-events: none; }
.trend-point-group:hover .trend-tooltip { opacity: 1; }
.trend-point-group:hover .trend-pt { r: 6; }
.trend-month-label { transition: fill .15s ease; }
.trend-point-group:hover .trend-month-label { fill: var(--text); }
.trend-area { animation: trendFadeIn .9s ease-out both; }
.trend-line {
    stroke-dasharray: 2400;
    stroke-dashoffset: 2400;
    animation: trendDraw 1.3s cubic-bezier(.16,.84,.44,1) forwards, trendGlowPulse 3.5s ease-in-out 1.3s infinite;
}
.trend-pt { transform-box: fill-box; transform-origin: center; opacity: 0; animation: trendPopIn .45s cubic-bezier(.34,1.56,.64,1) forwards; }
.trend-halo { transform-box: fill-box; transform-origin: center; opacity: 0; animation: trendHaloIn .6s ease-out forwards, trendHaloPulse 2.6s ease-in-out 1s infinite; }
@keyframes trendDraw { to { stroke-dashoffset: 0; } }
@keyframes trendFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes trendPopIn { from { opacity: 0; transform: scale(0); } to { opacity: 1; transform: scale(1); } }
@keyframes trendHaloIn { from { opacity: 0; transform: scale(0); } to { opacity: .16; transform: scale(1); } }
@keyframes trendHaloPulse { 0%, 100% { transform: scale(1); opacity: .16; } 50% { transform: scale(1.35); opacity: .05; } }
@keyframes trendGlowPulse { 0%, 100% { filter: drop-shadow(0 0 2px rgba(94,234,212,.35)); } 50% { filter: drop-shadow(0 0 7px rgba(94,234,212,.6)); } }
