:root{--green:#1a7a3c;--green-dark:#155e2e;--green-light:#e8f5ee;--green-border:#9fd6b5;--yellow:#f5c518;--yellow-light:#fffbe6;--yellow-dark:#a67c00;--red:#c0392b;--red-light:#fdf0ef;--blue:#1565c0;--blue-light:#e8f0fe;--orange:#b45309;--orange-light:#fff7ed;--text:#1a1a1a;--text2:#555555;--text3:#888888;--bg:#f0f4f0;--surface:#ffffff;--surface2:#f7f9f7;--border:#e0e8e2;--border-strong:#ccddd4}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body,html{margin:0;padding:0;background:#d7e0d7;color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:15px;-webkit-font-smoothing:antialiased}button{cursor:pointer}button,input,select,textarea{font-family:inherit}.app{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg);position:relative;display:flex;flex-direction:column;box-shadow:0 0 40px rgba(0,0,0,.08)}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:50;height:54px;background:var(--green);color:#fff;justify-content:space-between;padding:0 12px}.topbar,.topbar .brand{display:flex;align-items:center;gap:8px}.topbar .brand{font-weight:800;font-size:16px}.logo-sq{width:32px;height:32px;border-radius:8px;background:var(--yellow);color:var(--green-dark);display:grid;place-items:center;font-weight:900;font-size:18px}.topbar .pills{gap:6px}.pill,.topbar .pills{display:flex;align-items:center}.pill{border:none;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:700;gap:5px;background:rgba(255,255,255,.16);color:#fff}.pill.yellow{background:var(--yellow);color:var(--green-dark)}.dot{width:8px;height:8px;border-radius:50%;background:#7CFFAD;display:inline-block}.dot.off{background:#ff8a80}.screen{flex:1 1;overflow-y:auto;padding:12px 12px calc(74px + env(safe-area-inset-bottom))}.page-title{font-size:18px;font-weight:800;margin:4px 2px 12px}.page-sub{color:var(--text2)}.banner,.page-sub{font-size:12px;font-weight:600}.banner{border-radius:10px;padding:10px 12px;margin-bottom:10px}.banner.green{background:var(--green-light);color:var(--green-dark);border:1px solid var(--green-border)}.banner.yellow{background:var(--yellow-light);color:var(--yellow-dark);border:1px solid #f0dca0}.banner.orange{background:var(--orange-light);color:var(--orange);border:1px solid #f6c98a}.banner.red{background:var(--red-light);color:var(--red);border:1px solid #f1b5af}.download-bar{background:var(--green);color:#fff;border-radius:12px;padding:12px 14px;margin-bottom:12px;width:100%;border:none;text-align:left;display:flex;align-items:center;gap:12px}.download-bar .ico{font-size:22px}.download-bar b{font-size:14px;display:block}.download-bar span{font-size:11px;opacity:.92}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:12px}.card-title{font-size:13px;font-weight:700;margin:0 0 10px;display:flex;align-items:center;justify-content:space-between}.card-title .right{display:flex;gap:6px}.muted{color:var(--text3);font-size:12px;text-align:center;padding:14px 4px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin-bottom:12px}.stat{background:var(--surface);border:1px solid var(--border);border-left-width:4px;border-radius:12px;padding:11px 12px}.stat .label{font-size:11px;color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.3px}.stat .value{font-size:19px;font-weight:800;margin-top:4px}.stat .sub{font-size:10px;color:var(--text3);margin-top:2px}.stat.green{border-left-color:var(--green)}.stat.green .value{color:var(--green)}.stat.red{border-left-color:var(--red)}.stat.red .value{color:var(--red)}.stat.yellow{border-left-color:var(--yellow)}.stat.yellow .value{color:var(--yellow-dark)}.stat.orange{border-left-color:var(--orange)}.stat.orange .value{color:var(--orange)}.stat.blue{border-left-color:var(--blue)}.stat.blue .value{color:var(--blue)}.bar-row{margin-bottom:10px}.bar-row .top{display:flex;justify-content:space-between;font-size:12px;font-weight:600;margin-bottom:4px}.bar-row .top b{color:var(--green-dark)}.bar-track{height:8px;background:var(--surface2);border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:var(--green);border-radius:999px;transition:width .5s ease}.field{margin-bottom:11px}.field label{display:block;font-size:12px;font-weight:700;color:var(--text2);margin-bottom:5px}.input,select.input,textarea.input{width:100%;min-height:50px;border:1.5px solid var(--border-strong);border-radius:9px;padding:0 12px;font-size:15px;background:#fff;color:var(--text);outline:none}textarea.input{min-height:80px;padding:12px;resize:vertical}.input:focus,select.input:focus,textarea.input:focus{border-color:var(--green)}.row2{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.btn{width:100%;min-height:50px;border:none;border-radius:9px;font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:6px}.btn.primary{background:var(--green);color:#fff}.btn.primary:disabled{opacity:.6}.btn.orange{background:var(--orange);color:#fff}.btn.blue{background:var(--blue);color:#fff}.btn.ghost{background:#fff;color:var(--text2);border:1.5px solid var(--border-strong)}.btn.sm{min-height:0;padding:7px 11px;font-size:12px;width:auto;border-radius:8px}.btn-gap{height:9px}.calc{background:var(--green-light);border:1px solid var(--green-border);border-radius:10px;padding:12px;margin:4px 0 12px}.calc.orange{background:var(--orange-light);border-color:#f6c98a}.calc .line{display:flex;justify-content:space-between;font-size:13px;padding:3px 0;color:var(--text2)}.calc .line b{color:var(--text)}.calc .total{border-top:1px dashed var(--green-border);margin-top:6px;padding-top:8px;font-size:16px;font-weight:800}.pos{color:var(--green)}.neg{color:var(--red)}.badge{font-size:10px;font-weight:800;padding:3px 8px;border-radius:999px;display:inline-flex;align-items:center;gap:3px}.badge.green{background:var(--green-light);color:var(--green-dark)}.badge.yellow{background:var(--yellow-light);color:var(--yellow-dark)}.badge.red{background:var(--red-light);color:var(--red)}.badge.orange{background:var(--orange-light);color:var(--orange)}.badge.count{min-width:22px;height:22px;justify-content:center}.row{display:flex;align-items:center;gap:10px;padding:10px 4px;border-bottom:1px solid var(--border)}.row:last-child{border-bottom:none}.row .icon{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:15px;flex-shrink:0}.icon.in{background:var(--green-light);color:var(--green)}.icon.out{background:var(--red-light);color:var(--red)}.icon.exp{background:var(--yellow-light);color:var(--yellow-dark)}.icon.pay{background:var(--blue-light);color:var(--blue)}.icon.sh{background:var(--orange-light);color:var(--orange)}.row .body{flex:1 1;min-width:0}.row .body .t{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row .body .s{font-size:11px;color:var(--text3);margin-top:1px}.row .amt{font-size:14px;font-weight:800;white-space:nowrap}.row.tap{cursor:pointer;border-radius:9px}.row.tap:active{background:var(--surface2)}.tappable-card{background:var(--orange-light);border:1px solid #f6c98a;border-radius:10px;padding:10px 12px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;cursor:pointer}.tabs{display:flex;gap:8px;margin-bottom:12px}.tab{flex:1 1;min-height:44px;border:1.5px solid var(--border-strong);background:#fff;border-radius:9px;font-weight:700;font-size:13px;color:var(--text2)}.tab.active{background:var(--green);color:#fff;border-color:var(--green)}.chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:10px}.chip{border:1.5px solid var(--border-strong);background:#fff;color:var(--text2);border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700}.chip.active{background:var(--green);color:#fff;border-color:var(--green)}.race-nums{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}.race-num{width:52px;height:52px;border-radius:12px;border:1.5px solid var(--border-strong);background:#fff;color:var(--text2);font-size:18px;font-weight:800}.race-num.sel{border-color:var(--green);background:var(--green-light);color:var(--green-dark)}.race-head{background:var(--green);color:#fff;border-radius:12px;padding:12px 14px;margin-bottom:12px}.race-head b{font-size:15px}.race-head .sub{font-size:12px;opacity:.92;margin-top:2px}.race-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:12px;background:#fff}.race-card .bar{background:var(--green-dark);color:#fff;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:700}.race-card .bar .status{font-size:11px;font-weight:700}.race-card .pad{padding:10px 12px}.race-line{display:flex;align-items:center;gap:10px;margin-bottom:8px}.race-line label{flex:1 1;font-size:12px;font-weight:700;color:var(--text2)}.race-line .input{width:130px;min-height:44px}.race-line.auto{background:var(--surface2);border-radius:8px;padding:8px 10px;margin:0 -2px 8px}.race-line.auto .val{width:130px;text-align:right;font-weight:800;color:var(--yellow-dark)}.race-profit{background:var(--green-light);border-radius:8px;padding:9px 12px;display:flex;justify-content:space-between;font-weight:800;font-size:14px}.tbl{width:100%;border-collapse:collapse;font-size:12px}.tbl td,.tbl th{padding:7px 6px;text-align:right;border-bottom:1px solid var(--border)}.tbl td:first-child,.tbl th:first-child{text-align:left}.tbl th{color:var(--text2);font-weight:700;font-size:11px}.tbl tr.total td{background:var(--green-light);font-weight:800;border-bottom:none}.vendor-card{border:1px solid var(--border);border-radius:12px;padding:12px;margin-bottom:10px;background:#fff}.vendor-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}.avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;flex-shrink:0}.avatar,.vendor-top .nm{font-weight:800;font-size:15px}.vendor-top .meta{font-size:11px;color:var(--text3);margin-top:1px}.vendor-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:6px;gap:6px;text-align:center}.vendor-stats .vs{background:var(--surface2);border-radius:8px;padding:8px 4px}.vendor-stats .vs .l{font-size:10px;color:var(--text3);font-weight:700}.vendor-stats .vs .v{font-size:13px;font-weight:800;margin-top:2px}.vendor-actions{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:6px;gap:6px;margin-top:8px}.vendor-actions .va{border:1px solid var(--border-strong);background:#fff;border-radius:8px;padding:8px 4px;text-align:center;font-size:11px;font-weight:700}.vendor-actions .va.pay{background:var(--green-light);color:var(--green-dark);border-color:var(--green-border)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;height:calc(62px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:#fff;border-top:1px solid var(--border);display:flex;z-index:60}.nav-item{flex:1 1;border:none;background:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text3);font-size:10px;font-weight:700}.nav-item.active{color:var(--green)}.nav-item .ic{font-size:18px;line-height:1}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:100;display:flex;align-items:flex-end;justify-content:center}.modal{width:100%;max-width:480px;background:#fff;border-radius:18px 18px 0 0;max-height:88vh;overflow-y:auto;padding:16px 16px calc(20px + env(safe-area-inset-bottom));animation:slideUp .22s ease}@keyframes slideUp{0%{transform:translateY(40px);opacity:.6}to{transform:translateY(0);opacity:1}}.modal h3{margin:0 0 12px;font-size:17px;font-weight:800}.modal .det{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border)}.modal .det b{font-weight:800}.snack{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);background:var(--green-dark);color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:600;z-index:200;max-width:90%;box-shadow:0 6px 20px rgba(0,0,0,.25);animation:snackIn .2s ease}.snack.err{background:var(--red)}@keyframes snackIn{0%{transform:translate(-50%,12px);opacity:0}to{transform:translate(-50%);opacity:1}}.spin{display:inline-block;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-screen{min-height:100vh;display:grid;place-items:center;color:var(--green-dark);font-weight:700}.report-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.report-btn{border:1px solid var(--border);background:var(--surface2);border-radius:10px;padding:14px 8px;text-align:center;font-size:12px;font-weight:700;color:var(--text)}.report-btn .e{font-size:22px;display:block;margin-bottom:4px}.role-card{border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;display:flex;gap:10px;align-items:flex-start}.role-card .re{font-size:22px}.role-card .rt{font-weight:800;font-size:14px}.role-card .rd{font-size:11px;color:var(--text2);margin-top:2px}.sync-tbl .det:last-child{border-bottom:none}.config-box{background:var(--surface2);border:1px dashed var(--border-strong);border-radius:8px;padding:10px;font-size:11px;color:var(--text2);font-family:ui-monospace,monospace;white-space:pre-wrap;word-break:break-all}