*{box-sizing:border-box}body{margin:0;background:#f5f7f8;color:#1f2933;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{border:0}.page{min-height:100vh;padding-bottom:calc(76px + env(safe-area-inset-bottom))}.topbar{position:sticky;top:0;z-index:2;display:flex;align-items:center;gap:10px;height:52px;padding:0 14px;background:#fff;border-bottom:1px solid #e5e9ee}.topbar h1{flex:1;margin:0;font-size:18px}.content{max-width:540px;margin:0 auto;padding:14px}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:3;display:grid;grid-template-columns:repeat(5,1fr);min-height:calc(62px + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:#fff;border-top:1px solid #e5e9ee}.tabbar a{display:grid;align-content:center;justify-items:center;gap:3px;color:#64748b;font-size:12px}.tabbar svg{width:22px;height:22px}.tabbar a.router-link-active{color:#1f2933;font-weight:700}.auth-page{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:28px;background:#fff}.auth-page h1{margin:0 0 28px;font-size:28px}.form{display:grid;gap:12px}.password-form{padding:14px;border:1px solid #e4e8ed;border-radius:8px;background:#fff}input,textarea,select{width:100%;min-height:44px;padding:10px 12px;border:1px solid #d7dde4;border-radius:8px;background:#fff;color:#1f2933}textarea{min-height:92px;resize:vertical}.primary,.danger,.link-btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 16px;border-radius:8px;background:#0f8a5f;color:#fff;font-weight:700}.danger{width:100%;margin-top:18px;background:#c2410c}.icon-btn{width:34px;height:34px;border-radius:8px;background:#edf2f7;font-size:26px;line-height:1}.text-btn,.mini-link{color:#0f8a5f;background:transparent;font-weight:700}.search{margin-bottom:12px}.home-brand{display:grid;grid-template-columns:1fr 82px;align-items:center;gap:14px;padding:14px;margin-bottom:12px;border:1px solid #e4e8ed;border-radius:8px;background:#fff}.home-brand p{margin:8px 0 0;color:#667085}.app-logo{min-height:34px;display:inline-flex;align-items:center;color:#1f2933;font-size:24px;font-weight:800}.app-logo.small{min-height:28px;font-size:18px}.app-logo img{max-width:154px;max-height:46px;object-fit:contain}.app-logo.small img{max-width:112px;max-height:32px}.home-icon{width:78px;height:78px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#edf7f2;color:#0f8a5f}.home-icon img{width:62px;height:62px;object-fit:contain}.home-icon svg{width:48px;height:48px}.profile-panel{display:grid;gap:12px}.profile-head{display:grid;grid-template-columns:58px 1fr;gap:12px;align-items:center}.avatar{width:58px;height:58px;display:flex;align-items:center;justify-content:center;border-radius:999px;background:#111827;color:#fff;font-size:24px;font-weight:800}.profile-info{min-width:0;display:grid;gap:4px}.profile-info h2{margin:2px 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-info p{margin:0}.role-tag{width:max-content;max-width:100%;display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;font-size:12px;font-weight:700}.role-tag.normal{background:#edf2f7;color:#475569}.role-tag.admin{background:#edf7f2;color:#0f8a5f}.role-tag.platform{background:#fff7ed;color:#c2410c}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.product-card{display:grid;gap:8px;padding:10px;border:1px solid #e4e8ed;border-radius:8px;background:#fff}.product-card img{width:100%;aspect-ratio:1.2;object-fit:cover;border-radius:6px;background:#eef1f4}.product-card strong{min-height:40px;line-height:20px}.product-card span,.price{color:#c2410c;font-weight:700}.list{display:grid;gap:10px}.row,.cart-row,.order-card,.panel{background:#fff;border:1px solid #e4e8ed;border-radius:8px}.row{min-height:50px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px}.cart-row{display:grid;grid-template-columns:72px 1fr auto;gap:10px;align-items:center;padding:10px}.cart-row img{width:72px;height:72px;object-fit:cover;border-radius:6px;background:#eef1f4}.cart-row p,.order-card p,.panel p{margin:6px 0 0;color:#667085}.order-card{display:grid;gap:4px;padding:12px}.order-card div{display:flex;justify-content:space-between;gap:10px}.panel{padding:14px;margin-bottom:12px}.panel h2{margin:0 0 8px;font-size:20px}.hero-img{width:100%;aspect-ratio:1.45;object-fit:cover;border-radius:8px;background:#eef1f4;margin-bottom:12px}.stepper{display:inline-grid;grid-template-columns:42px 48px 42px;align-items:center;margin:12px 0;border:1px solid #d7dde4;border-radius:8px;overflow:hidden}.stepper button{height:38px;background:#edf2f7}.stepper span{text-align:center}.stepper.small{grid-template-columns:32px 38px 32px;margin:6px 0 0}.bottom-action{position:sticky;bottom:calc(76px + env(safe-area-inset-bottom));display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;margin-top:12px;background:#fff;border:1px solid #e4e8ed;border-radius:8px}.empty,.muted{color:#667085}.error{color:#b42318}.ok{color:#0f8a5f;overflow-wrap:anywhere}.status{display:inline-block;padding:4px 8px;border-radius:999px;background:#edf7f2;color:#0f8a5f}.admin-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.admin-grid a,.admin-grid span{min-height:92px;display:flex;align-items:center;justify-content:center;text-align:center;padding:12px;border-radius:8px;background:#fff;border:1px solid #e4e8ed;font-weight:700}.admin-search{display:grid;gap:10px;padding:12px;margin-bottom:12px;border:1px solid #e4e8ed;border-radius:8px;background:#fff}.date-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.search-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.admin-order-card{gap:6px}.admin-order-card .status{margin-left:auto;white-space:nowrap}.pagination-bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;margin-top:12px;padding:10px;border:1px solid #e4e8ed;border-radius:8px;background:#fff}.pagination-bar span{color:#667085;font-weight:700}button:disabled{opacity:.45;cursor:not-allowed}.inline-form{display:grid;grid-template-columns:1fr 88px 78px;gap:8px;margin-bottom:12px}.actions{display:grid;gap:8px;font-size:13px;color:#0f8a5f;font-weight:700}.check{display:flex;align-items:center;gap:8px}.check input{width:auto;min-height:auto}.upload-box{display:grid;gap:10px;padding:10px;border:1px solid #e4e8ed;border-radius:8px;background:#fff}.upload-box img{width:100%;aspect-ratio:1.45;object-fit:cover;border-radius:6px;background:#eef1f4}.upload-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.upload-actions.block{margin-bottom:12px}.secondary-btn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border-radius:8px;background:#edf2f7;color:#1f2933;font-weight:700;position:relative;overflow:hidden}.secondary-btn input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.secondary-btn.disabled{opacity:.55;pointer-events:none}.secondary-btn.inline{width:auto;margin-top:12px}.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.thumbs img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;background:#eef1f4}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;padding:20px;background:#0f172a7a}.contact-card{width:min(100%,330px);display:grid;justify-items:center;gap:14px;padding:20px;border-radius:12px;background:#fff;box-shadow:0 18px 50px #0f172a38}.contact-card h2{margin:0;font-size:20px}.qrcode-wrap{width:220px;min-height:220px;display:flex;align-items:center;justify-content:center;padding:10px;border:1px solid #e4e8ed;border-radius:8px;background:#f8fafc;text-align:center;color:#667085}.qrcode-wrap img{width:200px;height:200px;object-fit:contain}.contact-card .primary{width:100%}.floating-contact-hit-area{position:fixed;z-index:8;width:64px;height:64px;touch-action:none;user-select:none;-webkit-user-select:none}.floating-contact-button{width:64px;height:64px;display:flex;align-items:center;justify-content:center;padding:0;border-radius:999px;background:transparent;color:#fff;touch-action:none;user-select:none;-webkit-user-select:none}.floating-contact-visual{position:relative;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:999px;background:#111827;box-shadow:0 14px 30px #0f172a57;pointer-events:none}.floating-contact-button:active .floating-contact-visual{transform:scale(.97);box-shadow:0 10px 24px #0f172a47}.floating-contact-button svg{width:29px;height:29px;pointer-events:none}.online-dot{position:absolute;right:7px;bottom:7px;width:11px;height:11px;border:2px solid #ffffff;border-radius:999px;background:#22c55e;pointer-events:none}@media (max-width: 360px){.grid{grid-template-columns:1fr}.cart-row{grid-template-columns:60px 1fr}.cart-row>.text-btn,.cart-row>b,.cart-row>.actions{grid-column:2;justify-self:start}.inline-form,.date-grid,.search-actions{grid-template-columns:1fr}}
