:root{--accent: #1a5fd6;--accent-dark: #1148ac;--ink: #15181c;--ink2: #22262b;--muted: #6b7280;--muted2: #9aa3b0;--line: #eceef1;--line2: #e2e6ea;--bg: #f4f5f7;--green: #138a4f;--green-dark: #0e6b3d;--amber: #c77c0a;--red: #d23b36;font-family:Hanken Grotesk,system-ui,-apple-system,sans-serif;color:var(--ink)}*{box-sizing:border-box}html,body{margin:0;background:var(--bg);-webkit-font-smoothing:antialiased}body{overscroll-behavior:none}input,textarea,button,select{font-family:inherit}input:focus,textarea:focus,select:focus{outline:none}.mono{font-family:JetBrains Mono,monospace}#root{min-height:100vh}.app{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg);display:flex;flex-direction:column;box-shadow:0 0 0 1px #00000008}@media (min-width: 520px){body{background:#15171b;background-image:radial-gradient(circle at 50% 0%,#23262c,#15171b 60%)}.app{margin:24px auto;min-height:calc(100vh - 48px);border-radius:30px;overflow:hidden;box-shadow:0 30px 70px #00000080}}.scr{flex:1;min-height:0;display:flex;flex-direction:column}.scr-head{flex:none;padding:16px 18px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}.scr-head h1{font-size:18px;font-weight:800;margin:0;letter-spacing:-.2px}.scr-head .sub{font-size:12px;color:var(--muted2);font-weight:600;margin:0}.scr-body{flex:1;overflow-y:auto;padding:18px 18px 28px}.scr-body::-webkit-scrollbar{width:0}.scr-foot{flex:none;padding:14px 18px;background:#fff;border-top:1px solid var(--line);padding-bottom:max(14px,env(safe-area-inset-bottom))}.iconbtn{width:40px;height:40px;border-radius:11px;border:1.5px solid var(--line2);background:#fff;display:grid;place-items:center;cursor:pointer;flex:none;padding:0;color:var(--ink2);font-size:20px}button{cursor:pointer;font-weight:700;font-size:16px;border:none;border-radius:15px;background:var(--accent);color:#fff;padding:0 18px;min-height:56px}button:active{transform:translateY(1px)}button:disabled{background:#c2c8d0;box-shadow:none;cursor:default}button.primary{box-shadow:0 3px 0 var(--accent-dark)}button.green{background:var(--green);box-shadow:0 3px 0 var(--green-dark)}button.dark{background:var(--ink)}button.amber{background:var(--amber);box-shadow:0 3px #b45d05}button.block{width:100%}button.outline{background:#fff;color:var(--accent);border:1.5px solid var(--accent);box-shadow:none}button.soft{background:#fff;color:var(--ink);border:1.5px solid var(--line2);box-shadow:none;min-height:52px}button.sm{min-height:44px;font-size:14px;border-radius:12px}button.link{background:none;color:var(--accent);min-height:auto;padding:0;font-size:13px;box-shadow:none}input,textarea,select{width:100%;min-height:48px;border:1.5px solid var(--line2);border-radius:13px;padding:0 14px;font-size:15px;background:#fff;color:var(--ink)}textarea{padding:12px 14px;resize:none;min-height:90px}input:focus,textarea:focus,select:focus{border-color:var(--accent)}.card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:12px}.muted{color:var(--muted)}.error{color:var(--red);font-weight:700}.greet{padding:18px 22px 16px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.greet .date{font-size:13px;color:var(--muted);font-weight:600}.greet .hi{font-size:23px;font-weight:800;letter-spacing:-.3px}.avatar{width:46px;height:46px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:700;font-size:16px;cursor:pointer;border:none}.actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.act{min-height:118px;border-radius:18px;border:1.5px solid var(--line2);background:#fff;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;padding:16px;text-align:left;color:var(--ink);box-shadow:none}.act.wide{grid-column:1/3;min-height:96px;flex-direction:row;align-items:center;gap:16px;border:none}.act.primary{background:var(--accent);color:#fff;box-shadow:0 3px 0 var(--accent-dark)}.act.warn{grid-column:1/3;min-height:62px;flex-direction:row;align-items:center;gap:14px;border-color:#f1d7a8;background:#fffbf3;color:#9a6604;font-weight:700}.act .ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-size:22px}.act .t{font-size:17px;font-weight:800}.act.primary .t{font-size:20px}.act .d{font-size:12px;color:var(--muted);font-weight:500}.act.primary .d{color:#ffffffd9}.banner{background:var(--ink);border-radius:16px;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;color:#fff}.banner small{color:#8e97a3;font-size:12px}.section-h{display:flex;align-items:center;gap:8px;margin:18px 2px 8px;font-size:13px;font-weight:800}.dot{width:7px;height:7px;border-radius:50%}.list-row{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line)}.rowico{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:none}.pick{width:100%;background:#fff;border:1.5px solid var(--line2);border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:13px;margin-bottom:9px;text-align:left;color:var(--ink);box-shadow:none;min-height:auto}.pick.on{border-color:var(--accent)}.ava{width:42px;height:42px;border-radius:50%;color:#fff;display:grid;place-items:center;font-weight:700;font-size:15px;flex:none}.catdot{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;flex:none}.catdot i{width:9px;height:9px;border-radius:50%;display:block}.pick .nm{font-size:15px;font-weight:700}.pick .meta{font-size:12px;color:var(--muted2)}.scanbox{position:relative;aspect-ratio:1/1;width:100%;background:#0c0d10;border-radius:22px;overflow:hidden;display:grid;place-items:center}.scanbox.wide{aspect-ratio:16/11}.scanbox .frame{position:absolute;top:20px;right:20px;bottom:20px;left:20px;border-radius:16px;border:2px dashed rgba(255,255,255,.16)}.scanbox video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.scanbox .hint{position:absolute;bottom:16px;color:#7c8694;font-size:12px}@keyframes scanline{0%{top:12%}50%{top:84%}to{top:12%}}.scanbox .scanline{position:absolute;left:14%;right:14%;height:2px;animation:scanline 2.2s ease-in-out infinite}.scanbox .ph{position:absolute;color:#cdd3db;font-weight:700;font-size:14px;text-align:center;padding:0 20px}.cartcount{font-size:12px;font-weight:800;color:#fff;background:var(--accent);min-width:24px;height:24px;border-radius:12px;display:inline-grid;place-items:center;padding:0 8px}.scan-dark{width:100%;min-height:64px;background:var(--ink);color:#fff;border-radius:15px;display:flex;align-items:center;justify-content:center;gap:10px;font-size:16px;font-weight:700;box-shadow:none}.wchip{background:#f0f4fb;border:1px solid #dbe6f7;border-radius:13px;padding:10px 12px;display:flex;align-items:center;gap:11px;margin-bottom:14px}.pill{font-size:11.5px;font-weight:800;padding:5px 10px;border-radius:20px;flex:none}.pill.avail{color:var(--green);background:#e7f4ed}.pill.out{color:var(--amber);background:#fceeda}.pill.over{color:var(--red);background:#fdecec}.steps-bar{height:4px;background:var(--line);flex:none}.steps-bar>div{height:100%;background:var(--accent);transition:width .3s}.success{padding:40px 22px;display:flex;flex-direction:column;align-items:center;text-align:center}.success .circle{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;margin-bottom:18px;font-size:40px}.empty{border:1.5px dashed #d7dce2;border-radius:14px;padding:26px;text-align:center;color:var(--muted2);font-size:13px}table{border-collapse:collapse;width:100%;font-size:14px}th{text-align:left;padding:10px 8px;color:var(--muted);font-size:11px;text-transform:uppercase;border-bottom:1px solid var(--line)}td{padding:11px 8px;border-bottom:1px solid var(--line)}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:130px}label{font-size:12px;font-weight:600;color:var(--muted)}.badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--bg);color:var(--muted);text-transform:capitalize}.badge.available{background:#e7f4ed;color:var(--green)}.badge.loaned{background:#eaeff9;color:var(--accent)}.badge.warn,.badge.disabled{background:#fdecec;color:var(--red)}.login{max-width:380px;margin:12vh auto;padding:30px;background:#fff;border-radius:22px;box-shadow:0 20px 50px #0000001f;display:grid;gap:14px}.login .brand{display:flex;align-items:center;justify-content:center;gap:10px;font-size:22px;font-weight:800}.login .logo{width:34px;height:34px;border-radius:9px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:800}
