:root{--bg:#0f0f11;--surface:#18181b;--surface2:#212126;--border:#2e2e35;--border2:#3f3f47;--text:#f4f4f5;--muted:#a1a1aa;--hint:#52525b;--accent:#10b981;--accent-h:#059669;--accent-bg:rgba(16,185,129,.12);--blue:#3b82f6;--blue-bg:rgba(59,130,246,.12);--amber:#f59e0b;--amber-bg:rgba(245,158,11,.12);--red:#ef4444;--red-bg:rgba(239,68,68,.12);--purple:#8b5cf6;--purple-bg:rgba(139,92,246,.12);--radius:8px;--radius-lg:12px;--sidebar-w:224px;--header-h:56px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-h)}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
.layout{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .25s}
.sidebar-brand{padding:18px 16px 14px;border-bottom:1px solid var(--border)}
.logo{font-size:1rem;font-weight:700;color:var(--text);letter-spacing:-.02em;display:flex;align-items:center;gap:9px}
.logo-icon{width:26px;height:26px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.75rem}
.sidebar-nav{flex:1;overflow-y:auto;padding:10px 8px}
.nav-section-label{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--hint);padding:12px 10px 5px}
.nav-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--radius);color:var(--muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s;margin-bottom:1px;text-decoration:none}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:var(--accent-bg);color:var(--accent)}
.nav-icon{font-size:.9rem;width:16px;text-align:center;flex-shrink:0}
.nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:.62rem;font-weight:700;padding:1px 6px;border-radius:10px;min-width:17px;text-align:center}
.sidebar-footer{padding:10px 8px;border-top:1px solid var(--border)}
.user-card{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius);background:var(--surface2)}
.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}
.user-info{flex:1;overflow:hidden}
.user-name{font-size:.78rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:.68rem;color:var(--muted)}
.logout-btn{background:none;border:none;cursor:pointer;color:var(--hint);padding:4px;border-radius:4px;transition:color .15s}.logout-btn:hover{color:var(--red)}
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 22px;gap:14px;position:sticky;top:0;z-index:50}
.topbar-title{font-size:.95rem;font-weight:600}
.topbar-actions{margin-left:auto;display:flex;gap:8px;align-items:center}
.content{padding:22px;flex:1;max-width:1360px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px}
.card-title{font-size:.9rem;font-weight:600}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;display:flex;flex-direction:column;gap:5px}
.stat-label{font-size:.7rem;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}
.stat-value{font-size:1.7rem;font-weight:700;letter-spacing:-.03em}
.stat-value.green{color:var(--accent)}.stat-value.amber{color:var(--amber)}.stat-value.red{color:var(--red)}.stat-value.blue{color:var(--blue)}.stat-value.purple{color:var(--purple)}
.stat-sub{font-size:.72rem;color:var(--hint)}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.855rem}
thead th{padding:9px 13px;text-align:left;font-size:.67rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--hint);border-bottom:1px solid var(--border);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--border);transition:background .1s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--surface2)}
tbody td{padding:10px 13px;color:var(--text);vertical-align:middle}
tbody td.muted{color:var(--muted);font-size:.8rem}
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:.7rem;font-weight:600;letter-spacing:.03em;white-space:nowrap}
.badge-green{background:var(--accent-bg);color:var(--accent)}.badge-amber{background:var(--amber-bg);color:var(--amber)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-purple{background:var(--purple-bg);color:var(--purple)}.badge-gray{background:var(--surface2);color:var(--muted)}
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:var(--radius);font-size:.815rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s;white-space:nowrap;text-decoration:none;font-family:inherit}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-h);color:#fff}
.btn-secondary{background:var(--surface2);color:var(--text);border-color:var(--border2)}.btn-secondary:hover{background:var(--border)}
.btn-danger{background:var(--red-bg);color:var(--red)}.btn-danger:hover{background:var(--red);color:#fff}
.btn-amber{background:var(--amber-bg);color:var(--amber)}.btn-amber:hover{background:var(--amber);color:#000}
.btn-blue{background:var(--blue-bg);color:var(--blue)}.btn-blue:hover{background:var(--blue);color:#fff}
.btn-purple{background:var(--purple-bg);color:var(--purple)}.btn-purple:hover{background:var(--purple);color:#fff}
.btn-sm{padding:4px 9px;font-size:.76rem}.btn-icon{padding:6px}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}
.form-group{display:flex;flex-direction:column;gap:5px}.form-group.full{grid-column:1/-1}
label{font-size:.78rem;font-weight:500;color:var(--muted)}
.form-control{background:var(--surface2);border:1px solid var(--border2);color:var(--text);border-radius:var(--radius);padding:8px 11px;font-size:.855rem;font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none;width:100%}
.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.form-control::placeholder{color:var(--hint)}
textarea.form-control{resize:vertical;min-height:90px}
.filters-bar{display:flex;gap:9px;flex-wrap:wrap;align-items:flex-end;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:13px 15px;margin-bottom:14px}
.filters-bar .form-group{flex:1;min-width:150px;margin:0}
.alert{padding:10px 15px;border-radius:var(--radius);font-size:.855rem;margin-bottom:14px;border:1px solid transparent}
.alert-success{background:var(--accent-bg);color:var(--accent);border-color:rgba(16,185,129,.25)}
.alert-error{background:var(--red-bg);color:var(--red);border-color:rgba(239,68,68,.25)}
.alert-warning{background:var(--amber-bg);color:var(--amber);border-color:rgba(245,158,11,.25)}
.pagination{display:flex;gap:4px;align-items:center;padding-top:14px;justify-content:flex-end;flex-wrap:wrap}
.page-btn{padding:5px 10px;border-radius:var(--radius);font-size:.78rem;font-weight:500;background:var(--surface2);color:var(--muted);border:1px solid var(--border);cursor:pointer;text-decoration:none;transition:all .15s}
.page-btn:hover,.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.page-btn.disabled{opacity:.3;pointer-events:none}
.activity-row{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--border)}
.activity-row:last-child{border-bottom:none;padding-bottom:0}
.activity-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.8rem;flex-shrink:0}
.activity-icon.in{background:var(--accent-bg);color:var(--accent)}.activity-icon.out{background:var(--red-bg);color:var(--red)}.activity-icon.adjust{background:var(--amber-bg);color:var(--amber)}.activity-icon.transfer{background:var(--purple-bg);color:var(--purple)}
.activity-body{flex:1;min-width:0}
.activity-title{font-size:.81rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-meta{font-size:.72rem;color:var(--hint)}
.activity-qty{font-size:.81rem;font-weight:600}.activity-qty.pos{color:var(--accent)}.activity-qty.neg{color:var(--red)}.activity-qty.trn{color:var(--purple)}
.stock-bar-wrap{display:flex;align-items:center;gap:7px}
.stock-bar{flex:1;height:3px;background:var(--surface2);border-radius:2px;overflow:hidden;min-width:40px}
.stock-bar-fill{height:100%;border-radius:2px;transition:width .3s}
.chart-wrap{position:relative;height:185px}
.wh-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:10px}
.wh-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.wh-code{font-size:.68rem;font-weight:700;letter-spacing:.07em;color:var(--accent);background:var(--accent-bg);padding:2px 7px;border-radius:10px}
.wh-name{font-size:.9rem;font-weight:600}
.wh-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.wh-stat{font-size:.77rem;color:var(--muted)}.wh-stat strong{display:block;font-size:.95rem;font-weight:700;color:var(--text)}
.po-items-table{width:100%;border-collapse:collapse;font-size:.84rem}
.po-items-table th{padding:7px 11px;background:var(--surface2);text-align:left;font-size:.68rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--hint)}
.po-items-table td{padding:9px 11px;border-top:1px solid var(--border);vertical-align:middle}
.po-remove{cursor:pointer;color:var(--hint);background:none;border:none;font-size:1rem;transition:color .15s}.po-remove:hover{color:var(--red)}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}
.login-card{width:100%;max-width:370px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:34px}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:26px;justify-content:center}
.login-logo-icon{width:34px;height:34px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.9rem}
.login-logo-text{font-size:1.1rem;font-weight:700}
.tmpl-notice{background:var(--amber-bg);border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:16px}
.tmpl-notice-title{font-size:.85rem;font-weight:600;color:var(--amber);margin-bottom:4px}
.tmpl-notice-body{font-size:.82rem;color:var(--muted);line-height:1.6}
.tmpl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.tmpl-type-badge{font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 9px;border-radius:10px}
.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.ms-auto{margin-left:auto}
.text-muted{color:var(--muted)}.text-hint{color:var(--hint)}.text-sm{font-size:.8rem}.text-xs{font-size:.7rem}.fw-600{font-weight:600}
.mt-2{margin-top:10px}.mt-3{margin-top:16px}.mb-2{margin-bottom:10px}.mb-3{margin-bottom:16px}
.d-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.d-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.d-grid-wh{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.w-100{width:100%}
@media(max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main{margin-left:0}.stats-grid{grid-template-columns:1fr 1fr}.d-grid-2,.d-grid-3{grid-column:1/-1;grid-template-columns:1fr}.d-grid-wh{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.stats-grid,.d-grid-wh{grid-template-columns:1fr}}
