:root{--bg:#f4f5f7;--panel:#ffffff;--border:#e2e5ea;--border-strong:#cbd2db;--ink:#1c2330;--muted:#6b7585;--accent:#2f6df6;--green:#1f9d57;--green-bg:#e6f6ec;--yellow-bg:#fff7d6;--orange-bg:#ffe9c7;--row-hover:#f0f4ff;--header-bg:#d6ead9}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,Roboto,Helvetica,Arial,sans-serif;font-size:13px}.app{max-width:1500px;margin:0 auto;padding:18px 20px 60px}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);color:var(--muted)}.auth-card{background:var(--panel);border:1px solid var(--border-strong);border-radius:14px;padding:32px 30px;width:340px;box-shadow:0 10px 40px rgba(20,30,50,.1);display:flex;flex-direction:column}.auth-title{font-size:20px;font-weight:800;color:var(--ink)}.auth-sub{font-size:13px;color:var(--muted);margin:2px 0 20px}.auth-label{font-size:12px;font-weight:600;color:var(--muted);margin-bottom:5px}.auth-input{border:1px solid var(--border-strong);border-radius:8px;padding:10px 12px;font-size:14px;margin-bottom:14px}.auth-input:focus{outline:2px solid var(--accent);border-color:transparent}.auth-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:11px;font-size:14px;font-weight:700;cursor:pointer;margin-top:4px}.auth-btn:disabled{opacity:.6}.auth-error{background:#fde8e8;border:1px solid #f4b8b8;color:#a12525;padding:8px 11px;border-radius:8px;font-size:12px;font-weight:600;margin-bottom:12px}.topbar{display:flex;align-items:center;gap:16px;margin-bottom:14px;flex-wrap:wrap}.title{font-size:20px;font-weight:700;letter-spacing:-.2px}.title small{font-size:12px;font-weight:500;color:var(--muted);margin-left:8px}.spacer{flex:1 1}.count-pill{background:var(--panel);border:1px solid var(--border);border-radius:999px;padding:5px 12px;color:var(--muted);font-weight:600}.btn{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;transition:filter .15s,transform .05s}.btn:hover{filter:brightness(1.05)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:default}.btn.ghost{background:var(--panel);color:var(--ink);border:1px solid var(--border-strong)}.btn-add-big{background:var(--accent);color:#fff;border:none;border-radius:12px;min-width:130px;height:54px;font-size:17px;font-weight:800;letter-spacing:1px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:4px;box-shadow:0 3px 10px rgba(47,109,246,.32);transition:filter .15s,transform .05s}.btn-add-big:hover{filter:brightness(1.07)}.btn-add-big:active{transform:translateY(1px)}.seg{display:inline-flex;background:var(--panel);border:1px solid var(--border-strong);border-radius:8px;overflow:hidden}.seg button{border:none;background:transparent;padding:7px 14px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}.seg button.on{background:var(--accent);color:#fff}.hint{background:var(--orange-bg);border:1px solid #f0cf9b;color:#8a5a16;border-radius:8px;padding:7px 12px;font-weight:600;font-size:12px}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}.tb-label{font-size:12px;font-weight:700;color:var(--muted)}.tb-divider{width:1px;height:18px;background:var(--border-strong);margin:0 4px}.chip{border:1px solid var(--border-strong);background:var(--panel);color:var(--ink);border-radius:999px;padding:6px 13px;font-size:12px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s}.chip:hover{background:var(--bg)}.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}.chip.clear{color:var(--muted);border-style:dashed}.tablewrap{background:var(--panel);border:1px solid var(--border-strong);border-radius:12px;overflow:auto;box-shadow:0 1px 3px rgba(20,30,50,.05)}table{border-collapse:collapse;width:100%;min-width:1100px}thead th{position:-webkit-sticky;position:sticky;top:0;z-index:2;background:var(--header-bg);color:#234a30;font-weight:700;font-size:12px;text-align:left;padding:10px;border-bottom:2px solid var(--border-strong);white-space:nowrap}tbody td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:top}tbody tr:hover{background:var(--row-hover)}.col-center{text-align:center}.ticket{font-weight:700;color:var(--accent);white-space:nowrap}.cust{font-weight:600}.date,.mobile{color:var(--muted);font-size:12px}.date{white-space:nowrap}.device{font-weight:600}.repair{color:var(--muted);font-size:12px}.tag-row{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}.status-tag{font-weight:600;background:#eef1f5;color:#54607a}.instore-tag,.status-tag{display:inline-block;font-size:11px;padding:1px 7px;border-radius:999px}.instore-tag{background:var(--green-bg)}.instore-tag,.pay .paid{font-weight:700;color:var(--green)}.pay .due{color:#cc3b3b;font-weight:700}textarea.notes{width:240px;min-height:38px;resize:vertical;border:1px solid var(--border);border-radius:6px;padding:6px 8px;font:inherit;font-size:12px;background:#fff}textarea.notes:focus{outline:2px solid var(--accent);border-color:transparent}.chk{width:22px;height:22px;cursor:pointer;accent-color:var(--green)}.timed-check{display:flex;flex-direction:column;align-items:center;gap:3px}.timed-check .stamp{font-size:10px;line-height:1}.flag-btn,.timed-check .stamp{color:var(--muted);white-space:nowrap}.flag-btn{border:1px solid var(--border-strong);background:#fff;border-radius:6px;padding:4px 9px;font-size:11px;font-weight:600;cursor:pointer}.flag-btn.on{background:var(--orange-bg);border-color:#f0cf9b;color:#8a5a16}tr.done td{background:var(--green-bg)}tr.done:hover td{background:#d8f0e1}tr.pending-order td{background:var(--yellow-bg)}tr.pending-order:hover td{background:#fff0bf}tr.completed td{background:#eef0f3;color:#8a93a3}tr.completed:hover td{background:#e6e9ee}tr.completed .paid,tr.completed .ticket{color:#8a93a3}.empty,.loading{padding:50px;text-align:center;color:var(--muted)}.saving-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);margin-left:6px;animation:pulse .9s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.modal-overlay{position:fixed;inset:0;background:rgba(20,28,45,.45);display:flex;align-items:flex-start;justify-content:center;padding-top:6vh;z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--panel);width:480px;max-width:calc(100vw - 32px);max-height:88vh;overflow:auto;border-radius:14px;box-shadow:0 20px 60px rgba(15,25,50,.3);animation:pop .12s ease-out}@keyframes pop{0%{transform:translateY(-8px) scale(.98);opacity:0}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-size:16px;font-weight:700}.modal-x{border:none;background:transparent;font-size:16px;cursor:pointer;color:var(--muted);padding:4px 8px;border-radius:6px}.modal-x:hover{background:var(--bg)}.modal-body{padding:18px 20px;gap:14px}.field,.modal-body{display:flex;flex-direction:column}.field{gap:5px}.field label{font-size:12px;font-weight:600;color:var(--muted)}.field input,.modal-notes{border:1px solid var(--border-strong);border-radius:8px;padding:9px 11px;font:inherit;font-size:14px;background:#fff}.field input:focus,.modal-notes:focus{outline:2px solid var(--accent);border-color:transparent}.field-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.lookup-row{display:flex;gap:8px}.big-input{flex:1 1;font-weight:700!important;letter-spacing:1px;font-size:16px!important}.spinner{display:inline-block;width:22px;height:22px;border:3px solid #d7e0ee;border-top:3px solid var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.spinner.small{width:14px;height:14px;border-width:2px}@keyframes spin{to{transform:rotate(1turn)}}.lookup-status{margin-top:8px;display:flex;align-items:center;gap:8px;color:var(--accent);font-weight:600;font-size:13px}.matched-badge{margin-top:7px;display:inline-block;background:var(--green-bg);color:var(--green);font-weight:700;font-size:12px;padding:4px 10px;border-radius:999px}.modal-notes{min-height:64px;resize:vertical}.toggle-row{display:flex;gap:20px}.toggle{display:flex;align-items:center;gap:7px;font-weight:600;font-size:13px;cursor:pointer}.toggle input{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.modal-error{background:#fde8e8;border:1px solid #f4b8b8;color:#a12525;padding:9px 12px;border-radius:8px;font-weight:600;font-size:12px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--border)}.del-btn{border:none;background:transparent;font-size:15px;cursor:pointer;opacity:.45;padding:4px;border-radius:6px}.del-btn:hover{opacity:1;background:#fde8e8}.row-actions{display:inline-flex;gap:2px}.edit-btn{border:none;background:transparent;font-size:14px;cursor:pointer;opacity:.5;padding:4px;border-radius:6px}.edit-btn:hover{opacity:1;background:var(--row-hover)}.manual-tag{background:#eef1f5;color:#54607a;font-size:11px;padding:1px 8px;border-radius:6px}.cn-badge,.manual-tag{display:inline-block;font-weight:700}.cn-badge{margin-left:7px;background:var(--orange-bg);border:1px solid #f0cf9b;color:#8a5a16;font-size:10px;padding:1px 7px;border-radius:999px;vertical-align:middle}.edit-ticket-id{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;letter-spacing:1px;padding:4px 0}.del-confirm{display:inline-flex;gap:4px}.del-yes{border:none;background:#cc3b3b;color:#fff;font-weight:700;border-radius:6px;padding:4px 9px}.del-no,.del-yes{cursor:pointer;font-size:12px}.del-no{border:1px solid var(--border-strong);background:#fff;color:var(--muted);border-radius:6px;padding:4px 8px}.err{background:#fde8e8;border:1px solid #f4b8b8;color:#a12525;padding:10px 14px;border-radius:8px;margin-bottom:12px;font-weight:600}