*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f0f2f5;color:#1a1a2e;-webkit-font-smoothing:antialiased;width:100%;overflow-x:hidden}html{width:100%;overflow-x:hidden}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;width:100%;max-width:100%;margin:0 auto}.header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#1a1a2e;color:#fff;position:sticky;top:0;z-index:10}.back-btn{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:4px 8px}.header-title{font-weight:600;font-size:16px}.main{flex:1;padding:12px 12px 80px}.footer{position:fixed;bottom:0;left:0;right:0;padding:12px;padding-bottom:calc(12px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid #e0e0e0;width:100%}.btn-close{width:100%;padding:14px;background:#2563eb;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer}.page{width:100%}.banner{background:#fff;padding:14px 16px;border-radius:12px;margin-bottom:16px;font-weight:600;box-shadow:0 1px 3px #00000014}.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #00000014;border:none;text-align:left;cursor:pointer}.category-card{padding-bottom:10px}.card-image{position:relative;aspect-ratio:1;background:#f8f9fa;display:flex;align-items:center;justify-content:center}.card-image img{width:100%;height:100%;object-fit:cover}.placeholder-img{font-size:40px;opacity:.4}.badge{position:absolute;top:8px;right:8px;background:#22c55e;color:#fff;font-size:12px;font-weight:700;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}.card-title{padding:8px 10px 0;font-size:13px;font-weight:500;line-height:1.3}.product-card{padding-bottom:10px}.price{padding:4px 10px;color:#22c55e;font-weight:700;font-size:14px}.qty-controls{display:flex;align-items:center;gap:8px;padding:6px 10px 10px}.btn-minus,.btn-plus{width:32px;height:32px;border:none;border-radius:8px;font-size:18px;font-weight:700;cursor:pointer}.btn-minus{background:#fee2e2;color:#dc2626}.btn-plus{background:#dbeafe;color:#2563eb}.btn-plus:disabled{opacity:.4;cursor:not-allowed}.qty{min-width:24px;text-align:center;font-weight:600}.search-bar{margin-bottom:12px}.search-bar input{width:100%;padding:12px 16px;border:none;border-radius:12px;background:#fff;font-size:15px;box-shadow:0 1px 3px #00000014}.fab{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom));right:16px;width:56px;height:56px;border-radius:50%;background:#22c55e;border:none;font-size:24px;cursor:pointer;box-shadow:0 4px 12px #22c55e66;z-index:5}.fab-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center}.loading,.empty{text-align:center;padding:40px;color:#6b7280}.section-title{font-size:14px;font-weight:700;margin-bottom:16px;color:#374151}.cart-list{display:flex;flex-direction:column;gap:12px}.cart-item{display:flex;gap:12px;background:#fff;border-radius:12px;padding:12px;box-shadow:0 1px 3px #00000014}.cart-item-img{width:72px;height:72px;border-radius:8px;overflow:hidden;flex-shrink:0;background:#f8f9fa}.cart-item-img img{width:100%;height:100%;object-fit:cover}.cart-item-name{font-weight:600;font-size:14px;margin-bottom:4px}.cart-item-meta{font-size:12px;color:#6b7280;margin-bottom:8px}.btn-delete{background:none;border:none;font-size:18px;cursor:pointer;margin-left:auto}.cart-summary{background:#fff;border-radius:12px;padding:16px;margin-top:16px;box-shadow:0 1px 3px #00000014}.cart-summary div{margin-bottom:8px;font-weight:500}.btn-submit{width:100%;margin-top:12px;padding:14px;background:#2563eb;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.message{margin-top:12px;padding:12px;background:#dcfce7;border-radius:8px;text-align:center;color:#166534}.message-error{background:#fee2e2;color:#991b1b}
