:root{color-scheme:light;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:#eef1f5;color:#172033;--green: #27c79a;--green-dark: #16b186;--blue: #2388f2;--line: #edf0f4;--muted: #9aa4b2;--danger: #fa5151}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#eef1f5}button,input,select{font:inherit}button{border:0;background:none;cursor:pointer}input,select{border:0;outline:none;background:transparent;color:#182232;min-width:0}select{text-align:right;-webkit-appearance:none;-moz-appearance:none;appearance:none}.phone-shell{width:min(414px,100vw);min-height:100vh;margin:0 auto;background:#f6f7f9;position:relative;box-shadow:0 0 0 1px #e1e5eb;overflow-x:hidden}.page{min-height:100vh;padding:14px 12px calc(96px + env(safe-area-inset-bottom))}.page-header{display:grid;grid-template-columns:40px 1fr 40px;align-items:center;gap:12px;margin-bottom:14px}.page-title{justify-self:center;font-size:18px;color:#172033}.text-action{color:var(--green);font-size:14px;font-weight:600;white-space:nowrap}.back-btn,.header-placeholder{width:40px;height:40px}.back-btn{display:grid;place-items:center;border-radius:12px;background:#fff;border:1px solid #e7ebf1;color:#172033;font-size:18px;line-height:1;box-shadow:0 6px 16px #0f172a0d}.back-btn:active{transform:scale(.97)}.header-placeholder{display:block}.search-box{height:38px;background:#fff;display:flex;align-items:center;gap:8px;padding:0 10px;margin:0 0 24px;color:#9da5b0;border-radius:4px}.search-box input{flex:1}.search-action{min-width:52px;height:28px;border-radius:14px;background:#eefbf6;color:var(--green);font-size:13px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);background:#fff;margin:0 4px 12px;border-radius:2px;overflow:hidden}.stat-card{height:70px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid var(--line);border-bottom:1px solid var(--line);color:#303948}.stat-card:nth-child(3n){border-right:0}.stat-card:nth-child(n+4){border-bottom:0}.stat-card b{font-size:25px;line-height:1.1}.stat-card span{font-size:13px;margin-top:5px}.tabs{display:flex;align-items:center;gap:4px;margin:0 4px 8px}.tabs button{color:#9aa3af;padding:7px 11px;border-radius:0}.tabs button.active{color:var(--green);background:#e9fbf5}.tabs button:last-child{margin-left:auto}.list-panel{background:#fff;margin:0 4px}.row{width:100%;min-height:42px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid var(--line);color:#121826;text-align:left}.row em{font-style:normal;color:#8a94a5}.empty{color:#9aa3af;text-align:center;padding:28px 12px;font-size:14px;background:#fff;margin:0 4px 10px}.item-cards{margin:14px 4px;display:flex;flex-direction:column;gap:10px}.item-card{background:#fff;border-radius:12px;padding:10px;display:flex;align-items:center;gap:10px;box-shadow:0 4px 18px #0f172a0a}.thumb{width:54px;height:54px;border-radius:10px;background:#f1f4f8 center/cover no-repeat;display:grid;place-items:center;color:#c2c8d0;flex:0 0 auto;overflow:hidden}.thumb.tiny{width:38px;height:38px;border-radius:9px}.item-main{min-width:0;flex:1;display:grid;gap:3px}.item-main strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-main small{color:#8a94a5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.next{color:#b0b8c4;font-style:normal;font-size:20px}.badge{font-style:normal;font-size:12px;border-radius:999px;padding:4px 8px;white-space:nowrap}.badge.normal{background:#e8fff6;color:#13aa7d}.badge.expiring{background:#fff6d7;color:#a76d00}.badge.expired{background:#ffe8e8;color:#d92d20}.badge.unknown{background:#edf1f6;color:#667085}.fab-stack{position:fixed;right:max(14px,calc((100vw - 414px)/2 + 14px));bottom:108px;display:flex;flex-direction:column;gap:12px;z-index:5}.fab{width:56px;height:56px;border-radius:50%;background:var(--green);color:#fff;font-size:25px;box-shadow:0 7px 18px #14a47b47;display:grid;place-items:center;position:relative}.fab.small{font-size:13px;line-height:1.15}.fab-scan{padding:0}.scan-mark{position:relative;width:22px;height:22px;display:block}.scan-mark i{position:absolute;width:8px;height:8px;border-color:#fff;border-style:solid}.scan-mark .tl{top:0;left:0;border-width:2px 0 0 2px;border-top-left-radius:2px}.scan-mark .tr{top:0;right:0;border-width:2px 2px 0 0;border-top-right-radius:2px}.scan-mark .bl{bottom:0;left:0;border-width:0 0 2px 2px;border-bottom-left-radius:2px}.scan-mark .br{bottom:0;right:0;border-width:0 2px 2px 0;border-bottom-right-radius:2px}.bottom-actions{position:fixed;left:50%;transform:translate(-50%);bottom:calc(18px + env(safe-area-inset-bottom));display:flex;gap:10px;z-index:4}.bottom-actions button{background:#fff;color:#8a94a5;border:1px solid #edf0f4;border-radius:999px;padding:8px 12px;box-shadow:0 4px 12px #0f172a0a}.scan-line{display:flex;align-items:center;gap:8px;padding:0 10px 8px;color:#123;font-size:14px}.scan-icon{color:var(--green);font-size:20px}.mini-scan-mark{width:18px;height:18px;border:2px solid var(--green);border-radius:4px;display:block;position:relative}.mini-scan-mark:after{content:"";position:absolute;top:6px;right:2px;bottom:6px;left:2px;border-top:2px solid var(--green)}.mini-btn{margin-left:auto;background:var(--green);color:#fff;font-size:12px;padding:5px 8px;border-radius:4px}.mini-btn.light{margin-left:0;background:#eefbf6;color:var(--green)}.section-title{margin:0 10px 7px;color:#8d97a5;font-size:13px}.card{background:#fff;border-radius:7px;margin:0 8px 10px}.form-card label{min-height:47px;display:flex;align-items:center;gap:10px;padding:0 14px;border-bottom:1px solid var(--line)}.form-card label:last-child{border-bottom:0}.form-card label>span{width:116px;flex:0 0 auto;color:#1f2937}.form-card label>span small{display:block;color:#9aa3af;font-size:12px;margin-top:4px}.form-card input,.form-card select{flex:1;text-align:right;height:36px}.required{color:#d92d20!important}.upload-btn{width:auto!important;min-height:0!important;border:0!important;padding:6px 9px!important;border-radius:5px;background:#eefbf6;color:var(--green);font-size:12px;white-space:nowrap}.upload-btn input{display:none}.photo-line input{text-align:right}.inline-product{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:8px;color:#667085}.stepper{display:flex;align-items:center;justify-content:flex-end;flex:1}.stepper button{width:32px;height:30px;background:#f3f5f8;color:#667085}.stepper input{width:34px;height:30px;background:#fff;text-align:center;border-left:1px solid #fff;border-right:1px solid #fff;flex:0 0 auto}.period input{border-bottom:1px solid #eef1f5;margin-left:auto;max-width:74px}.units{display:flex;gap:6px;margin-left:4px}.units button{width:34px;height:30px;background:#f3f5f8;color:#9099a8}.units button.on{background:#e8fff6;color:var(--green)}.switch-row{flex:1;display:flex;justify-content:flex-end;align-items:center;gap:10px}.remind-input{max-width:96px;background:#f8fafc;border-radius:5px;padding:0 8px}.switch{width:48px!important;flex:0 0 48px!important;height:28px!important;min-height:0!important;display:inline-flex!important;padding:0!important;border:0!important;position:relative}.switch input{display:none}.switch i{width:48px;height:28px;border-radius:99px;background:#eef1f5;box-shadow:inset 0 0 0 1px #dde3ea;position:relative;transition:.2s}.switch i:after{content:"";width:24px;height:24px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 2px 5px #00000029;transition:.2s}.switch input:checked+i{background:var(--green)}.switch input:checked+i:after{transform:translate(20px)}.scan-btn{background:#eefbf6;color:var(--green);padding:6px 8px;border-radius:5px;white-space:nowrap}.save-actions{display:grid;grid-template-columns:1fr 1fr;gap:16px 10px;margin:16px 8px 0}.save-actions.single{grid-template-columns:1fr}.primary{min-height:44px;background:var(--green);color:#fff;border-radius:4px;padding:0 16px}.primary.blue{background:var(--blue)}.primary.wide{grid-column:1 / -1;width:100%}.ghost{min-height:42px;border:1px solid #dbe2ea;color:#4b5563;border-radius:4px;background:#fff;margin-top:8px}.detail-card{background:#fff;margin:12px 8px;border-radius:12px;padding:16px}.big-thumb{height:180px;border-radius:12px;background:#f1f4f8 center/contain no-repeat;display:grid;place-items:center;color:#c3c9d2;font-size:40px}.detail-card h2{margin:16px 0 8px}dl{display:grid;grid-template-columns:100px 1fr;gap:12px 6px;margin:18px 0}dt{color:#8a94a5}dd{margin:0;word-break:break-all}.wx-card{padding:16px}.wx-card h3{margin:0 0 10px}.wx-card p{margin:8px 0}.hint{color:#8a94a5;font-size:13px;line-height:1.6}.ok{color:var(--green)}.danger,.danger-text{color:var(--danger)!important}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0f172a73;display:grid;place-items:center;padding:18px}.scanner-box{background:#fff;border-radius:14px;padding:14px;width:min(380px,100%)}#reader{min-height:260px;overflow:hidden;border-radius:10px;background:#111}.scanner-box p{text-align:center;color:#667085;font-size:13px}.toast{position:fixed;top:18px;left:50%;transform:translate(-50%);z-index:100;background:#111827e0;color:#fff;padding:10px 14px;border-radius:999px;font-size:13px;max-width:86vw}.loading{position:fixed;inset:auto 0 22px;margin:auto;width:max-content;background:#ffffffe6;border:1px solid #e5e7eb;border-radius:999px;padding:8px 12px;color:#667085}.access-page{display:grid;place-items:center;padding:26px 18px;background:linear-gradient(180deg,#effaf6,#f6f7f9 45%,#f6f7f9)}.access-card{width:100%;background:#fff;border-radius:18px;padding:28px 20px;box-shadow:0 14px 36px #0f172a14;display:grid;gap:14px;text-align:center}.access-logo{width:64px;height:64px;border-radius:22px;margin:0 auto 4px;background:#e9fbf5;display:grid;place-items:center;font-size:32px}.access-card h1{margin:0;font-size:24px}.access-card p{margin:0;color:#8a94a5;line-height:1.6}.access-card input[type=password]{height:46px;border-radius:10px;background:#f6f7f9;padding:0 14px;text-align:left}.remember-line{display:flex;align-items:center;justify-content:center;gap:8px;color:#667085;font-size:13px}.remember-line input{width:16px;height:16px}.access-error{color:var(--danger)!important;font-size:13px}@media(min-width:415px){.phone-shell{min-height:812px;margin-top:12px;border-radius:10px}}.user-card{background:#fff;border-radius:12px;margin:0 8px 12px;padding:16px;display:flex;align-items:center;gap:12px}.user-card .avatar{width:54px;height:54px;border-radius:50%;background:#e9fbf5;display:grid;place-items:center;font-size:28px}.user-card strong{font-size:17px}.user-card p{margin:4px 0 0;color:#8a94a5;font-size:13px}.settings-grid{background:#fff;margin:0 8px 12px;display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line)}.settings-grid button{min-height:82px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);color:#303948}.settings-grid button:nth-child(3n){border-right:0}.settings-grid button:nth-child(n+4){border-bottom:0}.settings-grid .icon{font-size:24px;line-height:1}.settings-grid .green{color:#27c79a}.settings-grid .orange{color:#ffb020}.settings-grid .blue{color:#2388f2}.settings-grid .red{color:#fa5151}.settings-grid .purple{color:#d946ef}.settings-grid .teal{color:#10b981}.setting-list{background:#fff;margin:0 8px}.setting-row{width:100%;min-height:48px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid var(--line);color:#172033;text-align:left}.setting-row em{color:#9aa4b2;font-style:normal}.page-primary{margin:18px 8px 0;width:calc(100% - 16px)}.danger-tip{color:#fa5151;margin:4px 8px 14px;font-size:14px}.export-form select{flex:1;border:0;outline:0;background:transparent;text-align:right;direction:rtl;color:#98a2b3;font:inherit;min-width:0}.export-form select option{direction:ltr;color:#172033}.export-form input[type=date]{color:#98a2b3}.export-btn{margin:18px 8px 0;width:calc(100% - 16px);min-height:48px;font-size:16px}.admin-page .page-header{margin-bottom:14px}.product-search-block{border-bottom:1px solid var(--line)}.product-search-block>label{border-bottom:1px solid var(--line)!important}.product-search-results{max-height:260px;overflow-y:auto;padding:8px 10px;display:grid;gap:8px}.product-search-results button{width:100%;min-height:56px;border:1px solid #edf0f4;border-radius:10px;padding:7px;display:flex;align-items:center;gap:9px;background:#fff;text-align:left}.product-search-results button.selected{border-color:var(--green);background:#effdf8}.product-search-results strong{display:block;color:#172033;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-search-results small{display:block;color:#8a94a5;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty.mini{padding:14px 8px}.textarea-line{align-items:flex-start!important;padding-top:12px!important;padding-bottom:12px!important}.textarea-line textarea{flex:1;min-height:150px;resize:vertical;border:0;outline:0;background:#f8fafc;border-radius:8px;padding:10px;color:#172033;line-height:1.6;font:inherit}.category-select-line select{flex:1;min-width:0;height:36px;border:0;outline:0;background:transparent;text-align:right;color:#172033;font:inherit}.config-btn{margin-left:8px;background:#eefbf6;color:var(--green);padding:6px 8px;border-radius:5px;white-space:nowrap;font-size:13px}.image-preview-card{margin:0 14px 12px;padding:10px;background:#f8fafc;border-radius:10px;display:flex;align-items:center;gap:10px;color:#667085;font-size:13px}.thumb.preview{width:72px;height:72px;border-radius:10px;background-size:cover}.category-config-page{padding:0;display:flex;align-items:flex-start;justify-content:center;background:#0f172a40}.category-panel{width:100%;min-height:330px;background:#fff;border-radius:14px 14px 0 0;padding:16px 16px 18px;box-shadow:0 -8px 28px #0f172a1f}.category-panel-header{height:32px;display:grid;grid-template-columns:32px 1fr 32px;align-items:center;margin-bottom:18px}.category-panel-header strong{text-align:center;font-size:16px}.category-tags{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.category-panel-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}.category-picker-line{cursor:pointer}.category-picker-value{flex:1;min-width:0;height:36px;text-align:right;color:#172033;font:inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-picker-line em{color:#b8c0cc;font-style:normal;font-size:18px;margin-left:6px}.category-config-page{padding:0!important;background:#fff!important;display:block!important}.category-panel{width:100%!important;min-height:100vh!important;background:#fff!important;border-radius:0!important;padding:18px 16px 24px!important;box-shadow:none!important}.category-panel-header{height:32px;display:grid;grid-template-columns:32px 1fr 32px;align-items:center;margin-bottom:22px}.category-panel-header strong{text-align:center;font-size:17px;color:#172033}.category-panel-header button{color:#b8c0cc;font-size:32px;line-height:1}.category-tools{display:grid;grid-template-columns:1fr 1.35fr;gap:12px;align-items:center;margin-bottom:14px}.category-tools p{margin:0;color:#9aa4b2;font-size:13px}.category-search{height:36px;background:#f6f7f9;display:flex;align-items:center;gap:8px;padding:0 10px;color:#9aa4b2}.category-search input{flex:1;text-align:left}.category-tags{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:18px}.category-chip{min-height:34px;padding:0 14px;border-radius:5px;background:#2589ff;color:#fff;font-size:14px}.category-chip.active{background:var(--green)}.category-add-chip{min-height:34px;padding:0 12px;border:1px solid #e6eaf0;border-radius:5px;color:#172033;background:#fff}.category-panel-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.category-panel-actions .ghost,.category-panel-actions .primary{margin:0;min-height:44px}.image-preview-card img{width:72px;height:72px;object-fit:cover;border-radius:10px;background:#eef1f5;display:block}
