*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#f8fafc;color:#1e293b;font-size:14px}nav{background:#1e3a5f;color:#fff;padding:0 1.5rem;display:flex;align-items:center;gap:0;height:52px;box-shadow:0 2px 6px #0003}nav .brand{font-weight:700;font-size:1rem;letter-spacing:.02em;margin-right:2rem;white-space:nowrap}nav a{color:#ffffffbf;text-decoration:none;padding:0 1rem;height:52px;display:flex;align-items:center;font-size:.875rem;font-weight:500;transition:color .15s,background .15s}nav a:hover{color:#fff;background:#ffffff1a}nav a.active{color:#fff;background:#ffffff26;border-bottom:3px solid #60a5fa}.page{max-width:1100px;margin:0 auto;padding:1.5rem}h1{font-size:1.4rem;font-weight:700;margin-bottom:1.25rem;color:#0f172a}h2{font-size:1.1rem;font-weight:600;margin-bottom:.75rem;color:#1e293b}.card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.25rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #0000000d}.form-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}input,select,textarea{border:1px solid #cbd5e1;border-radius:5px;padding:.45rem .6rem;font-size:.9rem;background:#fff;color:#1e293b;outline:none;transition:border .15s}input:focus,select:focus,textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}input[type=number]{width:100px}button{padding:.45rem 1rem;border-radius:5px;border:none;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s,background .15s}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-success{background:#16a34a;color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-secondary{background:#e2e8f0;color:#475569}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.btn-sm{padding:.3rem .65rem;font-size:.8rem}table{width:100%;border-collapse:collapse;font-size:.85rem}th{background:#f1f5f9;padding:.5rem .75rem;text-align:left;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid #e2e8f0;white-space:nowrap}td{padding:.5rem .75rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}tr:hover td{background:#f8fafc}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.badge-ready{background:#dcfce7;color:#16a34a}.badge-partial{background:#fef9c3;color:#a16207}.badge-not-ready{background:#fee2e2;color:#dc2626}.badge-shipped{background:#dbeafe;color:#1d4ed8}.badge-not-shipped{background:#f1f5f9;color:#64748b}.alert{padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.alert-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.alert-info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.upload-area{border:2px dashed #94a3b8;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.upload-area:hover,.upload-area.drag-over{border-color:#3b82f6;background:#eff6ff}.upload-area input[type=file]{display:none}.upload-area .upload-icon{font-size:2.5rem;margin-bottom:.5rem}.section-title{font-size:.8rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.06em;padding:.4rem 0;border-bottom:1px solid #e2e8f0;margin-bottom:.75rem}.order-block{border:1px solid #e2e8f0;border-radius:6px;margin-bottom:.75rem;overflow:hidden}.order-block-header{background:#f8fafc;padding:.6rem .9rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;border-bottom:1px solid #e2e8f0;flex-wrap:wrap}.order-block-header:hover{background:#f1f5f9}.order-no{font-weight:700;font-size:.95rem;color:#1e40af}.order-meta{color:#64748b;font-size:.82rem}.lines-table-wrap{overflow-x:auto}.flex-end{display:flex;justify-content:flex-end;gap:.5rem}.spinner{display:inline-block;width:16px;height:16px;border:2px solid #bfdbfe;border-top-color:#2563eb;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:6px}@keyframes spin{to{transform:rotate(360deg)}}.filter-bar{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}.filter-bar select,.filter-bar input{font-size:.85rem}.qty-input{width:80px}.add-row-btn{margin-top:.5rem}.material-row,.pallet-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem;flex-wrap:wrap}
