
*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Inter,system-ui,Roboto,Arial,sans-serif;background:#f6f8fb;color:#0f172a;line-height:1.45}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:12px 20px;color:#fff;background:linear-gradient(90deg,#22c55e,#4ade80);box-shadow:0 2px 12px rgba(0,0,0,.08)}
.topbar nav a{color:#fff;font-weight:700;margin:0 10px;padding:6px 8px;border-radius:8px;opacity:.95;text-decoration:none}
.topbar nav a:hover{opacity:1;background:rgba(255,255,255,.12)}
.brand{font-weight:800}
.container{max-width:1100px;margin:24px auto;padding:0 16px}
.card{background:#fff;border-radius:16px;box-shadow:0 8px 24px rgba(15,23,42,.06);padding:16px;margin-bottom:18px;border:1px solid #e2e8f0}
.grid{display:grid;gap:16px}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:960px){.grid-2,.grid-3{grid-template-columns:1fr}}
h2{margin:.25em 0 .5em}h3{margin:.25em 0 .4em;color:#64748b}
.footer{max-width:1100px;margin:24px auto;padding:8px 16px;color:#64748b;font-size:12px}
.muted{color:#64748b}.flex{display:flex;gap:12px;align-items:center}.right{margin-left:auto}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:0;border-radius:12px;cursor:pointer;font-weight:800;background:#3b82f6;color:#fff;box-shadow:0 2px 10px rgba(59,130,246,.18)}.btn:hover{transform:translateY(-1px)}.btn.small{padding:6px 10px;border-radius:10px;font-size:13px}.btn.secondary{background:#10b981}.btn.outline{background:#fff;color:#3b82f6;border:2px solid #3b82f6}
label{display:block;margin:8px 0 6px;font-size:12px;color:#64748b;font-weight:700}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;color:#0f172a;outline:none}
input:focus,select:focus,textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 4px rgba(59,130,246,.12)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:720px){.form-row{grid-template-columns:1fr}}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden}
thead th{background:#f1f5f9;color:#0f172a;text-align:left;padding:10px;border-bottom:1px solid #e2e8f0;font-weight:700}
td{padding:10px;border-bottom:1px solid #e2e8f0}tbody tr:hover{background:#f8fafc}
.badge{display:inline-block;font-size:12px;font-weight:800;padding:4px 10px;border-radius:999px}
.badge.ok{background:#dcfce7;color:#166534}.badge.warn{background:#fef9c3;color:#854d0e}.badge.danger{background:#fee2e2;color:#7f1d1d}
.preview-label{border:1px dashed #e2e8f0;border-radius:16px;padding:16px;background:#fff}.label-title{font-weight:900;font-size:18px}.kv{display:grid;grid-template-columns:120px 1fr;gap:6px;font-size:13px}.qr{width:96px;height:96px}hr.sep{border:0;border-top:1px dashed #e2e8f0;margin:8px 0}
/* Compact label 80x50mm */
.label-compact-wrap{display:inline-block;background:#fff;border:1px dashed #e2e8f0;border-radius:16px;padding:8px}
.label-compact{width:80mm;height:50mm;padding:4mm 5mm;box-sizing:border-box;font-family:Inter,Arial,sans-serif;font-size:9pt;line-height:1.25}
.label-compact .label-title{font-size:11pt;margin:0 0 2mm 0}
.label-compact .kv{display:grid;grid-template-columns:24mm 1fr;gap:1.2mm 2.2mm;font-size:9pt}
.label-compact .qr{width:22mm;height:22mm}
@media print{@page{size:80mm 50mm;margin:0}.topbar,.footer,nav,.btn,.card:not(.print-area){display:none!important}.container{margin:0;padding:0;max-width:none}.label-compact-wrap{border:0;padding:0;border-radius:0}.label-compact{width:80mm;height:50mm;padding:4mm 5mm}}
