:root{color:#15262e;background:#e6eaee;font-family:Space Grotesk,Noto Sans TC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px}*{box-sizing:border-box}html{background:#e6eaee}body{background:#e6eaee;min-height:100svh;margin:0}button,input,select,textarea{font:inherit;letter-spacing:0}button{cursor:pointer;border:0}button:disabled{cursor:not-allowed;opacity:.52}input,select,textarea{width:100%}textarea{resize:vertical}h1,h2,h3,p{letter-spacing:0;margin:0}.proto{--accent:#0e7c92;--page:#e6eaee;--app-bg:#f2f4f6;--surface:#fff;--surface2:#eaeef1;--ink:#15262e;--muted:#687d8a;--line:#dfe6eb;--acc:var(--accent);--acc-soft:color-mix(in srgb, var(--accent) 10%, #fff);--acc-line:color-mix(in srgb, var(--accent) 35%, #fff);--demand:#c2701d;--demand-soft:#faf0e2;--hot:#c2362b;--hot-soft:#fbeae8;--danger:#c2362b;--ok:#1f8a5b;--ok-soft:#e6f3ec;--shadow:0 1px 2px #15262e0d, 0 6px 18px #15262e0f;color:var(--ink)}.proto[data-theme=light]{--accent:#0e7c92}.p-logo{background:var(--acc);color:#fff;border-radius:9px;justify-content:center;place-items:center;width:38px;height:38px;font-weight:800;display:inline-flex}.p-row{align-items:center;gap:10px;display:flex}.p-col{flex-direction:column;gap:4px;display:flex}.p-muted{color:var(--muted)}.p-sm{font-size:12px}.p-btn{background:var(--acc);color:#fff;min-height:42px;box-shadow:none;white-space:nowrap;border-radius:12px;justify-content:center;align-items:center;gap:6px;padding:0 18px;font-size:15px;font-weight:700;transition:filter .15s,transform 50ms;display:inline-flex}.p-btn:hover{filter:brightness(1.08)}.p-btn:active{transform:scale(.97)}.p-btn.sm{border-radius:10px;min-height:34px;padding:0 13px;font-size:13px}.p-btn.ghost{background:var(--surface2);color:var(--ink)}.p-btn.soft{background:var(--acc-soft);color:var(--acc)}.p-btn.danger{background:var(--hot-soft);color:var(--hot)}.p-icon{place-items:center;width:20px;height:20px;font-size:16px;line-height:1;display:inline-grid}.p-tag,.p-chip{background:var(--surface2);min-height:26px;color:var(--muted);white-space:nowrap;border:0;border-radius:7px;justify-content:center;align-items:center;gap:5px;padding:0 10px;font-size:11.5px;font-weight:700;display:inline-flex}.p-tag.supply,.p-chip.supply{background:var(--acc-soft);color:var(--acc)}.p-tag.demand,.p-chip.demand{background:var(--demand-soft);color:var(--demand)}.p-tag.hot,.p-chip.hot{background:var(--hot-soft);color:var(--hot)}.p-tag.accent,.p-chip.accent{background:var(--acc);color:#fff}.p-tag.danger,.p-chip.danger{color:var(--danger);background:#ef44441c;border-color:#ef44443d}.p-field{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.p-field-label{color:var(--muted);font-size:12.5px;font-weight:500}.p-input{border:1px solid var(--line);background:var(--surface);min-height:42px;color:var(--ink);border-radius:11px;outline:none;padding:11px 12px}.p-input:focus{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc-soft)}.p-model-combo{gap:6px;display:grid;position:relative}.p-model-combo:after{content:"⌄";color:var(--muted);pointer-events:none;line-height:1;position:absolute;top:12px;right:14px}.p-model-combo .p-input{min-width:0;padding-right:36px}.p-model-combo .p-input::-webkit-calendar-picker-indicator{opacity:0;pointer-events:none}.p-combo-meta{color:var(--muted);font-size:12.5px;line-height:1.35}.p-combo-meta.ok{color:var(--acc);font-weight:700}.p-app{background:var(--app-bg);min-height:100svh;color:var(--ink);flex-direction:column;display:flex;overflow:hidden}.p-appbar{z-index:20;padding:calc(28px + env(safe-area-inset-top)) 18px 12px;background:var(--app-bg);justify-content:space-between;align-items:center;gap:12px;display:flex;position:relative}.p-brand{color:var(--ink);letter-spacing:.2px;text-transform:none;font-size:17px;font-weight:700}.p-appbar h1{font-size:19px;line-height:1.15}.p-status{color:var(--muted);align-items:center;gap:6px;font-size:12px;font-weight:800;display:inline-flex}.p-content{flex:1;width:100%;max-width:560px;min-height:0;margin:0 auto;padding:4px 18px 24px;overflow-y:auto}.p-screen{flex-direction:column;gap:12px;animation:.24s both pIn;display:flex}@keyframes pIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.p-hero{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:16px;gap:12px;padding:18px;display:grid}.p-hero h2{font-size:26px;line-height:1.08}.p-hero p{color:var(--muted);line-height:1.5}.p-panel,.p-card{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:16px}.p-panel{padding:16px}.p-panel-head,.p-card-top,.p-card-bot{justify-content:space-between;align-items:center;gap:8px;display:flex}.p-panel-head{margin-bottom:12px}.p-stack{flex-direction:column;gap:10px;display:flex}.p-form{gap:12px;display:grid}.p-search{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:12px;align-items:center;gap:8px;padding:0 12px;display:flex}.p-search input{min-width:0;color:var(--ink);background:0 0;border:0;outline:none;flex:1;padding:11px 0}.p-search input::placeholder{color:var(--muted);opacity:.7}.p-search button{background:var(--surface2);width:22px;height:22px;color:var(--muted);border-radius:50%;justify-content:center;align-items:center;padding:0;display:inline-flex}.p-seg{background:var(--surface2);border-radius:12px;gap:2px;padding:3px;display:flex}.p-seg button{min-height:38px;color:var(--muted);background:0 0;border-radius:10px;flex:1;font-size:14px;font-weight:500}.p-seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow);font-weight:700}.p-chiprow{scrollbar-width:none;gap:8px;padding:2px 2px 8px;display:flex;overflow-x:auto}.p-chiprow::-webkit-scrollbar{display:none}.p-chip{border:1px solid var(--line);background:var(--surface);border-radius:99px;min-height:31px;padding:0 13px;font-size:13px;font-weight:500}.p-chip.on{background:var(--ink);color:var(--app-bg);border-color:var(--ink);font-weight:700}.p-card{gap:8px;padding:14px 16px;display:grid}.p-card.mine{border-style:dashed;border-color:var(--acc-line)}.p-card.accent-card{border-color:var(--acc-line);background:linear-gradient(180deg, var(--acc-soft), var(--surface) 70%)}.p-card-main{justify-content:space-between;align-items:center;gap:12px;display:flex}.p-model{font-size:19px;font-weight:700;line-height:1.1}.p-qty{color:var(--acc);font-size:16px;font-weight:700}.p-qty small{color:var(--muted);font-size:11px;font-weight:800;display:block}.p-card-note{color:var(--muted);font-size:13.5px;line-height:1.45}.p-empty{min-height:118px;color:var(--muted);text-align:center;background:0 0;border:0;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px 0;font-size:14px;display:flex}.p-kpis{gap:10px;display:flex}.p-kpi{border:1px solid var(--line);background:var(--surface);min-height:84px;box-shadow:var(--shadow);border-radius:16px;flex-direction:column;flex:1;gap:4px;padding:14px 16px;display:flex;position:relative;overflow:hidden}.p-kpi strong{font-size:30px;line-height:1}.p-kpi:before{content:"";width:4px;position:absolute;top:0;bottom:0;left:0}.p-kpi.supply:before{background:var(--acc-soft)}.p-kpi.demand:before{background:var(--demand-soft)}.p-kpi span{color:var(--muted);font-size:12px;font-weight:800}.p-legend{color:var(--muted);align-items:center;gap:6px;font-size:12px;font-weight:700;display:inline-flex}.p-legend i{border-radius:3px;width:14px;height:8px;display:inline-block}.p-legend .s{background:var(--acc)}.p-legend .d{background:var(--demand)}.p-barpair{border-top:1px solid var(--line);gap:4px;padding:10px 0;display:grid}.p-panel-head+.p-barpair{border-top:0;padding-top:0}.p-barpair-head{justify-content:space-between;align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.p-track{background:var(--surface2);border-radius:999px;height:9px;overflow:hidden}.p-fill{border-radius:inherit;min-width:4px;height:100%;transition:width .6s cubic-bezier(.2,.8,.2,1)}.p-fill.s{background:var(--acc)}.p-fill.d{background:var(--demand)}.p-list{gap:10px;display:grid}.p-notice{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:16px;gap:6px;padding:14px;display:grid}.p-notice time{color:var(--muted);font-size:12px;font-weight:700}.p-tabbar{z-index:30;border-top:1px solid var(--line);background:var(--surface);width:100%;max-width:560px;box-shadow:none;padding:6px 8px calc(22px + env(safe-area-inset-bottom));margin:0 auto;display:flex;position:relative}.p-tabbar button{color:var(--muted);background:0 0;border-radius:0;flex-direction:column;flex:1;align-items:center;gap:3px;padding:7px 0 2px;font-size:11px;font-weight:500;display:flex;position:relative}.p-tabbar button.on{color:var(--acc);background:0 0;font-weight:700}.p-badge{background:var(--danger);color:#fff;border-radius:999px;min-width:17px;height:17px;font-size:10px;line-height:17px;position:absolute;top:5px;right:18%}.p-scrim{z-index:40;background:#0a101473;position:fixed;inset:0}.p-sheet{z-index:50;background:var(--surface);max-width:560px;box-shadow:none;padding:10px 20px calc(32px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0;flex-direction:column;gap:14px;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}.p-sheet-grab{background:var(--line);border-radius:999px;width:42px;height:4px;margin:0 auto 12px}.p-stepper{border:1px solid var(--line);background:var(--surface);border-radius:11px;align-items:center;gap:0;display:flex;overflow:hidden}.p-stepper button,.p-stepper input{background:var(--surface2);min-height:38px;color:var(--ink);text-align:center;border:0;border-radius:0;font-size:16px;font-weight:700}.p-stepper input{background:var(--surface);width:44px}.p-toast{left:50%;right:auto;bottom:calc(110px + env(safe-area-inset-bottom));z-index:60;background:var(--ink);max-width:calc(100vw - 32px);color:var(--app-bg);box-shadow:var(--shadow);white-space:nowrap;border:0;border-radius:99px;padding:10px 18px;font-size:13.5px;font-weight:500;position:fixed;transform:translate(-50%)}.p-alert,.p-loading{border:1px solid var(--line);border-radius:8px;padding:12px 14px;line-height:1.45}.p-alert.error{color:#b42318;background:#ef44441a;border-color:#ef444438}.p-alert.success,.p-loading{border-color:var(--acc-line);background:var(--acc-soft);color:var(--acc)}.center-screen{background:#e6eaee;place-items:center;min-height:100svh;padding:24px;display:grid}.notice-panel{border:1px solid var(--line);background:var(--surface);width:min(100%,420px);box-shadow:var(--shadow);border-radius:8px;padding:28px}.notice-panel h1{margin:10px 0 12px;font-size:30px;line-height:1.12}.notice-panel p{line-height:1.6}@media (width>=720px){body{justify-items:center;display:grid}#root{width:min(100%,560px)}.p-app{width:min(100vw,560px);height:100svh;box-shadow:0 0 0 1px #0f172a0f}}@media (width<=380px){.p-appbar,.p-content{padding-left:12px;padding-right:12px}.p-btn{padding-inline:12px}.p-kpis{flex-direction:column}}.p-center{text-align:center}.p-body{color:var(--ink);gap:4px;margin:8px 0 0;font-size:14px;line-height:1.5;display:grid}.p-panel-title{margin-top:4px;font-size:14.5px;font-weight:700}.p-avatar{background:var(--acc-soft);width:44px;height:44px;color:var(--acc);border-radius:50%;flex:none;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:inline-flex}.p-iconbtn{background:var(--surface2);width:34px;height:34px;color:var(--ink);border-radius:50%;justify-content:center;align-items:center;padding:0;display:inline-flex}.p-hint{background:var(--acc-soft);color:var(--acc);border-radius:12px;align-items:center;gap:8px;padding:11px 14px;font-size:13px;font-weight:500;line-height:1.5;display:flex}.p-linkbtn{color:var(--muted);cursor:pointer;background:0 0;border:none;align-self:center;padding:6px;font-size:13px;text-decoration:underline}.p-gaprow{border-top:1px solid var(--line);grid-template-columns:1fr .7fr 1.1fr auto;align-items:center;gap:8px;padding:9px 0;display:grid}.p-panel-head+.p-gaprow{border-top:0}
