*{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{min-width:0;flex:1;margin:0;font-size:18px;overflow-wrap:anywhere}.content{width:100%;max-width:540px;min-width:0;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;word-break:break-word;overflow-wrap:anywhere}.field{min-width:0;display:grid;gap:4px}.form-textarea{width:100%;min-height:72px;padding:10px 12px;border:1px solid #d1d5db;border-radius:10px;font-size:14px;line-height:1.5;resize:vertical;word-break:break-word;overflow-wrap:anywhere}.name-textarea{min-height:72px}.field-hint{margin:0;color:#9ca3af;font-size:12px;text-align:right}.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{width:100%;min-width:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.grid>*{min-width:0}.product-card{width:100%;min-width:0;display:grid;gap:8px;padding:10px;overflow:hidden;border:1px solid #e4e8ed;border-radius:8px;background:#fff}.product-card-image{width:100%;max-width:100%;min-width:0;aspect-ratio:1 / 1;overflow:hidden;border-radius:6px;background:#eef1f4}.product-card-image img,.product-card>img{width:100%;height:100%;max-width:100%;display:block;object-fit:cover;background:#eef1f4}.product-card>img{aspect-ratio:1 / 1;overflow:hidden;border-radius:6px}.product-card-title,.product-card strong{min-width:0;max-width:100%;min-height:40px;line-height:20px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;overflow-wrap:anywhere}.product-card span,.price{min-width:0;max-width:100%;color:#c2410c;font-weight:700;word-break:break-word;overflow-wrap:anywhere}.list{display:grid;gap:10px}.row,.cart-row,.order-card,.panel{background:#fff;border:1px solid #e4e8ed;border-radius:8px}.row{min-width:0;min-height:50px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;overflow:hidden}.row span,.row b{min-width:0;overflow-wrap:anywhere}.checkout-item{width:100%;min-width:0;display:flex;align-items:flex-start;gap:10px;padding:10px;overflow:hidden;border:1px solid #e4e8ed;border-radius:8px;background:#fff}.checkout-item-image{flex:0 0 56px;width:56px;height:56px;overflow:hidden;border-radius:8px;background:#f3f4f6}.checkout-item-image img{width:100%;height:100%;display:block;object-fit:cover}.checkout-item-info{flex:1;min-width:0;overflow:hidden}.checkout-item-name,.line-item-name{min-width:0;max-width:100%;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;overflow-wrap:anywhere}.checkout-item-name{color:#111827;font-size:14px}.checkout-item-meta{margin:4px 0 0;color:#6b7280;font-size:12px}.checkout-item-price,.line-item-price,.line-item-action{flex:0 0 auto;min-width:72px;text-align:right;white-space:nowrap}.checkout-item-price,.line-item-price{color:#ef4444;font-weight:700}.cart-row{min-width:0;display:grid;grid-template-columns:72px minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px;overflow:hidden}.cart-row>*{min-width:0}.cart-row img{width:72px;height:72px;max-width:100%;display:block;object-fit:cover;border-radius:6px;background:#eef1f4}.cart-row strong,.cart-row span,.cart-row p,.cart-row b{min-width:0;max-width:100%;word-break:break-word;overflow-wrap:anywhere}.cart-row p,.order-card p,.panel p{margin:6px 0 0;color:#667085}.order-card{min-width:0;display:grid;gap:4px;padding:12px;overflow:hidden}.order-card div{min-width:0;display:flex;justify-content:space-between;gap:10px}.order-card strong,.order-card span{min-width:0;overflow-wrap:anywhere}.panel{min-width:0;padding:14px;margin-bottom:12px;overflow:hidden}.panel h2{margin:0 0 8px;font-size:20px;word-break:break-word;overflow-wrap:anywhere}.product-detail-title{word-break:break-word;overflow-wrap:anywhere}.hero-img{width:100%;max-width:100%;display:block;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}.product-actions{min-width:0;display:grid;gap:14px;margin-top:16px;padding:14px;overflow:hidden;border-radius:14px;background:#fff}.quantity-row{min-width:0;display:flex;align-items:center;justify-content:space-between;gap:12px}.quantity-label{flex:0 0 auto;color:#374151;font-size:14px;white-space:nowrap}.quantity-control{flex:0 0 auto;height:36px;display:inline-flex;align-items:center;overflow:hidden;border:1px solid #e5e7eb;border-radius:999px;background:#fff}.quantity-control button{width:36px;height:36px;border:0;border-right:1px solid #e5e7eb;background:#f9fafb;font-size:18px}.quantity-control button:last-child{border-right:0;border-left:1px solid #e5e7eb}.quantity-control span{min-width:40px;padding:0 6px;text-align:center;font-size:14px}.action-buttons{min-width:0;display:flex;gap:12px;width:100%}.action-buttons button{flex:1;min-width:0;min-height:46px;padding:0 10px;border-radius:999px;font-size:15px;font-weight:700}.add-cart-btn{border:1px solid #fed7aa;background:#fff7ed;color:#ea580c}.buy-now-btn{background:#ef4444;color:#fff}.bottom-action{min-width:0;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;overflow:hidden;background:#fff;border:1px solid #e4e8ed;border-radius:8px}.bottom-action b{min-width:0;overflow-wrap:anywhere}.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{min-width:0;display:grid;grid-template-columns:repeat(2,minmax(0,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}.category-page{min-width:0;min-height:calc(100vh - 126px - env(safe-area-inset-bottom));display:flex;flex-direction:column;margin:-14px;background:#f6f7f9;overflow:hidden}.category-search{display:flex;gap:10px;padding:12px;background:#fff}.category-search input{flex:1;min-width:0;height:40px;min-height:40px;border:0;border-radius:999px;background:#f3f4f6;padding:0 14px;font-size:14px}.category-search button{flex:0 0 auto;height:40px;padding:0 18px;border-radius:999px;background:#f97316;color:#fff;font-size:14px;font-weight:700}.category-layout{flex:1;min-height:0;min-width:0;display:flex;overflow:hidden}.category-sidebar{flex:0 0 92px;width:92px;overflow-y:auto;background:#f3f4f6}.category-sidebar-item{width:100%;min-height:54px;display:flex;align-items:center;justify-content:center;padding:12px 8px;border-left:3px solid transparent;background:transparent;color:#374151;font-size:14px;line-height:1.35;text-align:center;word-break:break-word;overflow-wrap:anywhere}.category-sidebar-item.active{border-left-color:#f97316;background:#fff;color:#f97316;font-weight:700}.category-main{flex:1;min-width:0;overflow-y:auto;padding:10px}.subcategory-section{min-width:0;margin-bottom:14px}.subcategory-title{margin:8px 0 10px;color:#111827;font-size:15px;font-weight:700}.category-product-card{min-width:0;display:flex;align-items:center;gap:10px;padding:10px;margin-bottom:10px;overflow:hidden;border-radius:12px;background:#fff}.category-product-image{flex:0 0 72px;width:72px;height:72px;overflow:hidden;border-radius:10px;background:#f3f4f6}.category-product-image img{width:100%;height:100%;display:block;object-fit:cover}.category-product-info{flex:1;min-width:0;overflow:hidden}.category-product-name{min-width:0;max-width:100%;color:#111827;font-size:14px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;overflow-wrap:anywhere}.category-product-price{margin:6px 0 0;color:#f97316;font-weight:700;white-space:nowrap}.category-cart-btn{flex:0 0 38px;width:38px;height:38px;border:1px solid #f97316;border-radius:999px;background:#fff;color:#f97316;font-size:22px;line-height:1;font-weight:700}.category-admin-form{display:grid;gap:10px;padding:12px;margin-bottom:12px;border:1px solid #e4e8ed;border-radius:8px;background:#fff}.category-admin-row.child{margin-left:18px}.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{min-width:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:10px}.thumbs img{width:100%;max-width:100%;display:block;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}.line-item-action{min-width:64px}.action-buttons{gap:8px}.action-buttons button{font-size:14px}.inline-form,.date-grid,.search-actions{grid-template-columns:1fr}}@media (min-width: 768px){.grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
