:root{--bg:#f4f5f7;--panel:#fff;--border:#d9dce1;--text:#1f2430;--muted:#6b7280;--primary:#1f6feb;--primary-dark:#1a5fce;--green:#1a7f37;--red:#c4302b;--amber:#b7791f}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{background:var(--bg);color:var(--text);font-family:Segoe UI,Heebo,Arial,sans-serif;font-size:14px;line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}h1{font-size:22px;margin-bottom:16px}h2{font-size:17px;margin-bottom:12px}.muted{color:var(--muted);font-weight:400}.nav{background:#1f2430;color:#fff;display:flex;align-items:center;flex-wrap:wrap;gap:4px;padding:7px 16px;min-height:52px}.nav-spacer{flex:1 1}.nav-user{color:#c9ced8;font-size:13px;padding:0 8px}.nav-logout{background:#2c3242;color:#fff;padding:7px 14px;font-size:13px}.nav-logout:hover{background:#3a4255}.nav .brand{font-weight:700;font-size:16px;color:#fff;margin-left:20px}.nav a{color:#c9ced8;padding:8px 14px;border-radius:6px;font-size:14px}.nav a:hover{background:#2c3242;color:#fff;text-decoration:none}.nav a.active{background:var(--primary);color:#fff}.container{margin:24px 0;padding:0 24px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:20px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:14px;gap:14px;margin-bottom:24px}.card{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:16px 18px}.card .value{font-size:28px;font-weight:700}.card .label{color:var(--muted);margin-top:4px}.card .label,.card a{font-size:13px}table.grid{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--border);border-radius:8px;overflow:hidden}table.grid td,table.grid th{text-align:right;padding:9px 12px;border-bottom:1px solid var(--border)}table.grid th{background:#eef0f3;font-weight:600;font-size:13px}table.grid tbody tr:hover{background:#f7f9fc}table.grid tbody tr:last-child td{border-bottom:none}.num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.table-scroll{overflow-x:auto}.table-scroll table.grid{min-width:100%;width:max-content}.table-scroll td,.table-scroll th{white-space:nowrap}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600}.badge.ok{background:#e6f4ea;color:var(--green)}.badge.err{background:#fbeaea;color:var(--red)}.badge.pending{background:#fbf1dd;color:var(--amber)}.badge-gray,.badge.neutral{background:#eef0f3;color:var(--muted)}.badge-blue{background:#e8f0fe;color:#1a56db}.badge-green{background:#e6f4ea;color:var(--green)}.badge-red{background:#fbeaea;color:var(--red)}.badge-amber{background:#fbf1dd;color:var(--amber)}.progress-bar{position:relative;width:120px;height:18px;background:#eef0f3;border-radius:9px;overflow:hidden}.progress-fill{position:absolute;top:0;left:0;bottom:0;background:var(--green);border-radius:9px;transition:width .2s}.progress-label{position:absolute;width:100%;text-align:center;font-size:11px;font-weight:600;color:#333;line-height:18px;z-index:1}.searchbar{display:flex;gap:8px;margin-bottom:16px}input:not([type]),input[type=number],input[type=password],input[type=text],select{border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:14px;font-family:inherit;background:#fff}input:not([type]),input[type=password],input[type=text]{min-width:220px}button{background:var(--primary);color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-family:inherit;cursor:pointer}button:hover{background:var(--primary-dark)}button.secondary{background:#eef0f3;color:var(--text)}.pagination{gap:14px;margin-top:16px;font-size:13px}.pagination,.toolbar{display:flex;align-items:center}.toolbar{justify-content:space-between;margin-bottom:16px}.back{font-size:13px;margin-bottom:10px;display:inline-block}dl.kv{display:grid;grid-template-columns:max-content 1fr;grid-gap:6px 18px;gap:6px 18px}dl.kv dt{color:var(--muted)}pre.payload{background:#1f2430;color:#e6e6e6;padding:14px;border-radius:8px;overflow:auto;max-height:460px;font-size:12px;direction:ltr;text-align:left;white-space:pre-wrap;word-break:break-all}.empty{color:var(--muted);padding:24px;text-align:center}.rf{max-width:560px;margin:0 auto;min-height:100vh;background:#fff;display:flex;flex-direction:column}.rf-header{background:#1f2430;display:flex;justify-content:space-between;align-items:center;padding:14px 18px;font-size:17px}.rf-header,.rf-home-btn{color:#fff;font-weight:600}.rf-home-btn{background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.25);border-radius:8px;padding:5px 14px;font-size:15px;text-decoration:none;white-space:nowrap}.rf-home-btn:active{background:hsla(0,0%,100%,.28)}.rf-main{flex:1 1;padding:16px}.rf h1,.rf-greet{font-size:20px}.rf-greet{margin-bottom:18px}.rf-error{background:#fde2e2;border:1px solid #e0a0a0;color:#8a1f1f;padding:10px 12px;border-radius:8px}.rf-btn,.rf-error{margin-bottom:12px;font-weight:600}.rf-btn{display:block;width:100%;background:var(--primary);color:#fff;border:none;border-radius:10px;padding:16px;font-size:18px;text-align:center;cursor:pointer}.rf-btn.secondary{background:#eef0f3;color:var(--text)}.rf-form{display:flex;flex-direction:column;gap:10px}.rf-form label{font-size:16px;font-weight:600}.rf input{width:100%;min-width:0;padding:14px;font-size:18px;font-family:inherit}.rf input,.rf-card{border:1px solid var(--border);border-radius:10px}.rf-card{display:block;padding:14px 16px;margin-bottom:12px;background:#fff;color:var(--text)}.rf-card:hover{text-decoration:none}.rf-card .title{font-size:18px;font-weight:700}.rf-card .sub{color:var(--muted);font-size:14px;margin-top:2px}.rf-line{border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:14px}.rf-line .sku{font-size:18px;font-weight:700}.rf-line .qty{color:var(--muted);font-size:14px;margin:4px 0 10px}.rf-pick-form{display:flex;flex-direction:column;gap:8px}.rf-banner,.rf-done{color:var(--green);font-size:17px;font-weight:700}.rf-banner{background:#e6f4ea;border-radius:10px;padding:14px;text-align:center;margin-bottom:16px}.rf-progress{height:8px;background:#eef0f3;border-radius:999px;overflow:hidden;margin-top:8px}@keyframes spin{to{transform:rotate(1turn)}}.rf-progress>span{display:block;height:100%;background:var(--green)}