*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#222}.app-root{display:flex;flex-direction:column;height:100vh}.app-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;border-bottom:1px solid #d0d7de;background:linear-gradient(90deg,#f5f5f5,#fff)}.app-title{display:flex;flex-direction:column}.app-name{font-weight:600}.app-db{font-size:.8rem;color:#555}.app-nav a{margin-left:1rem;text-decoration:none;color:#444;padding-bottom:.2rem}.app-nav a.active{border-bottom:2px solid #0078d4;color:#0078d4}.app-body{flex:1;display:grid;grid-template-columns:minmax(0,1fr)}.app-sidebar,.app-sidebar-right{padding:1rem;border-right:1px solid #e1e4e8;background:#f8fafc}.app-sidebar-right{border-right:none;border-left:1px solid #e1e4e8}.app-sidebar h2,.app-sidebar-right h2{margin-top:0;font-size:.95rem}.app-sidebar ul,.app-sidebar-right ul{list-style:none;padding-left:0}.app-sidebar li,.app-sidebar-right li{padding:.25rem 0;font-size:.9rem}.app-content{padding:1rem 1.5rem;overflow:auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.page-header h1{margin:0;font-size:1.25rem}.page-header-actions button{margin-left:.5rem}.table-wrapper{border:1px solid #d0d7de;border-radius:4px;overflow:auto;max-height:calc(100vh - 200px)}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table thead{position:sticky;top:0;background:#f3f4f6;z-index:1}.data-table th,.data-table td{border-bottom:1px solid #e5e7eb;padding:.35rem .5rem;text-align:left}.data-table thead th{text-align:left;white-space:normal;vertical-align:top}.data-table tbody td{white-space:nowrap}.data-table tr:nth-child(2n){background-color:#f9fafb}.clickable-row{cursor:pointer}.clickable-row:hover{background-color:#e5f3ff}.hero-card{margin-top:1rem;display:flex;align-items:center;padding:1.5rem;border-radius:8px;border:1px solid #e5e7eb;background:#f9fafb}.hero-barcode{width:140px;height:100px;margin-right:1.5rem;background:repeating-linear-gradient(90deg,#111,#111 4px,#fff 4px,#fff 8px)}.drawer-barcode{width:160px;height:60px;margin-top:.25rem;background:repeating-linear-gradient(90deg,#111,#111 3px,#fff 3px,#fff 6px)}.hero-text h2{margin:0 0 .25rem}.error{color:#b91c1c}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;z-index:40}.dialog-panel{background:#fff;border-radius:8px;box-shadow:0 10px 40px #0f172a59;max-height:80vh;display:flex;flex-direction:column}.dialog-header{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.dialog-body{padding:.75rem 1rem;overflow:auto}.drawer-panel{position:fixed;top:0;right:0;height:100vh;width:380px;background:#fff;box-shadow:-4px 0 20px #0f172a40;z-index:50;display:flex;flex-direction:column}.drawer-header{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.drawer-body{padding:.75rem 1rem;overflow:auto}.form-grid{display:grid;grid-template-columns:120px minmax(0,1fr);gap:.4rem .75rem;align-items:center}.form-grid label{font-size:.85rem;color:#374151}.form-grid input,.form-grid select{padding:.25rem .4rem}.dialog-footer,.drawer-footer{padding:.5rem 1rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.5rem}.filter-row{display:flex;align-items:center;gap:.35rem}.filter-button{padding:.25rem .6rem}.filter-clear{padding:.25rem .5rem}
